diff --git a/docs/index.html b/docs/index.html
new file mode 100644
index 0000000..40974c0
--- /dev/null
+++ b/docs/index.html
@@ -0,0 +1,24 @@
+<!doctype html>
+<html>
+  <head>
+    <style>
+      body *:not(script) {
+        display: block;
+        position: relative;
+        width: 250px;
+        margin: 0px;
+        padding: 0px;
+        left: calc(50vw - 125px);
+        top: 20vh;
+      }
+    </style>
+  </head>
+  <body>
+    <audio controls autoplay></audio>
+    <select></select>
+    <textarea></textarea>
+    <button>Save generated WAV file</button>
+    <a target="_blank" href="https://github.com/guest271314/vits-web/tree/patch-1/docs">Source code on GitHub</a>
+    <script type="module" src="./index.js"></script>
+  </body>
+</html>
diff --git a/docs/index.js b/docs/index.js
new file mode 100644
index 0000000..61b28da
--- /dev/null
+++ b/docs/index.js
@@ -0,0 +1,411 @@
+import { createPiperPhonemize } from "./piper.js";
+import * as ort from "./onyx-runtimeweb.js";
+
+const HF_BASE =
+  "https://huggingface.co/diffusionstudio/piper-voices/resolve/main";
+const ONNX_BASE =
+  "https://cdnjs.cloudflare.com/ajax/libs/onnxruntime-web/1.18.0/";
+const WASM_BASE =
+  "https://cdn.jsdelivr.net/npm/@diffusionstudio/piper-wasm@1.0.0/build/piper_phonemize";
+const PATH_MAP = {
+  "ar_JO-kareem-low": "ar/ar_JO/kareem/low/ar_JO-kareem-low.onnx",
+  "ar_JO-kareem-medium": "ar/ar_JO/kareem/medium/ar_JO-kareem-medium.onnx",
+  "ca_ES-upc_ona-medium": "ca/ca_ES/upc_ona/medium/ca_ES-upc_ona-medium.onnx",
+  "ca_ES-upc_ona-x_low": "ca/ca_ES/upc_ona/x_low/ca_ES-upc_ona-x_low.onnx",
+  "ca_ES-upc_pau-x_low": "ca/ca_ES/upc_pau/x_low/ca_ES-upc_pau-x_low.onnx",
+  "cs_CZ-jirka-low": "cs/cs_CZ/jirka/low/cs_CZ-jirka-low.onnx",
+  "cs_CZ-jirka-medium": "cs/cs_CZ/jirka/medium/cs_CZ-jirka-medium.onnx",
+  "da_DK-talesyntese-medium":
+    "da/da_DK/talesyntese/medium/da_DK-talesyntese-medium.onnx",
+  "de_DE-eva_k-x_low": "de/de_DE/eva_k/x_low/de_DE-eva_k-x_low.onnx",
+  "de_DE-karlsson-low": "de/de_DE/karlsson/low/de_DE-karlsson-low.onnx",
+  "de_DE-kerstin-low": "de/de_DE/kerstin/low/de_DE-kerstin-low.onnx",
+  "de_DE-mls-medium": "de/de_DE/mls/medium/de_DE-mls-medium.onnx",
+  "de_DE-pavoque-low": "de/de_DE/pavoque/low/de_DE-pavoque-low.onnx",
+  "de_DE-ramona-low": "de/de_DE/ramona/low/de_DE-ramona-low.onnx",
+  "de_DE-thorsten-high": "de/de_DE/thorsten/high/de_DE-thorsten-high.onnx",
+  "de_DE-thorsten-low": "de/de_DE/thorsten/low/de_DE-thorsten-low.onnx",
+  "de_DE-thorsten-medium":
+    "de/de_DE/thorsten/medium/de_DE-thorsten-medium.onnx",
+  "de_DE-thorsten_emotional-medium":
+    "de/de_DE/thorsten_emotional/medium/de_DE-thorsten_emotional-medium.onnx",
+  "el_GR-rapunzelina-low":
+    "el/el_GR/rapunzelina/low/el_GR-rapunzelina-low.onnx",
+  "en_GB-alan-low": "en/en_GB/alan/low/en_GB-alan-low.onnx",
+  "en_GB-alan-medium": "en/en_GB/alan/medium/en_GB-alan-medium.onnx",
+  "en_GB-alba-medium": "en/en_GB/alba/medium/en_GB-alba-medium.onnx",
+  "en_GB-aru-medium": "en/en_GB/aru/medium/en_GB-aru-medium.onnx",
+  "en_GB-cori-high": "en/en_GB/cori/high/en_GB-cori-high.onnx",
+  "en_GB-cori-medium": "en/en_GB/cori/medium/en_GB-cori-medium.onnx",
+  "en_GB-jenny_dioco-medium":
+    "en/en_GB/jenny_dioco/medium/en_GB-jenny_dioco-medium.onnx",
+  "en_GB-northern_english_male-medium":
+    "en/en_GB/northern_english_male/medium/en_GB-northern_english_male-medium.onnx",
+  "en_GB-semaine-medium": "en/en_GB/semaine/medium/en_GB-semaine-medium.onnx",
+  "en_GB-southern_english_female-low":
+    "en/en_GB/southern_english_female/low/en_GB-southern_english_female-low.onnx",
+  "en_GB-vctk-medium": "en/en_GB/vctk/medium/en_GB-vctk-medium.onnx",
+  "en_US-amy-low": "en/en_US/amy/low/en_US-amy-low.onnx",
+  "en_US-amy-medium": "en/en_US/amy/medium/en_US-amy-medium.onnx",
+  "en_US-arctic-medium": "en/en_US/arctic/medium/en_US-arctic-medium.onnx",
+  "en_US-danny-low": "en/en_US/danny/low/en_US-danny-low.onnx",
+  "en_US-hfc_female-medium":
+    "en/en_US/hfc_female/medium/en_US-hfc_female-medium.onnx",
+  "en_US-hfc_male-medium":
+    "en/en_US/hfc_male/medium/en_US-hfc_male-medium.onnx",
+  "en_US-joe-medium": "en/en_US/joe/medium/en_US-joe-medium.onnx",
+  "en_US-kathleen-low": "en/en_US/kathleen/low/en_US-kathleen-low.onnx",
+  "en_US-kristin-medium": "en/en_US/kristin/medium/en_US-kristin-medium.onnx",
+  "en_US-kusal-medium": "en/en_US/kusal/medium/en_US-kusal-medium.onnx",
+  "en_US-l2arctic-medium":
+    "en/en_US/l2arctic/medium/en_US-l2arctic-medium.onnx",
+  "en_US-lessac-high": "en/en_US/lessac/high/en_US-lessac-high.onnx",
+  "en_US-lessac-low": "en/en_US/lessac/low/en_US-lessac-low.onnx",
+  "en_US-lessac-medium": "en/en_US/lessac/medium/en_US-lessac-medium.onnx",
+  "en_US-libritts-high": "en/en_US/libritts/high/en_US-libritts-high.onnx",
+  "en_US-libritts_r-medium":
+    "en/en_US/libritts_r/medium/en_US-libritts_r-medium.onnx",
+  "en_US-ljspeech-high": "en/en_US/ljspeech/high/en_US-ljspeech-high.onnx",
+  "en_US-ljspeech-medium":
+    "en/en_US/ljspeech/medium/en_US-ljspeech-medium.onnx",
+  "en_US-ryan-high": "en/en_US/ryan/high/en_US-ryan-high.onnx",
+  "en_US-ryan-low": "en/en_US/ryan/low/en_US-ryan-low.onnx",
+  "en_US-ryan-medium": "en/en_US/ryan/medium/en_US-ryan-medium.onnx",
+  "es_ES-carlfm-x_low": "es/es_ES/carlfm/x_low/es_ES-carlfm-x_low.onnx",
+  "es_ES-davefx-medium": "es/es_ES/davefx/medium/es_ES-davefx-medium.onnx",
+  "es_ES-mls_10246-low": "es/es_ES/mls_10246/low/es_ES-mls_10246-low.onnx",
+  "es_ES-mls_9972-low": "es/es_ES/mls_9972/low/es_ES-mls_9972-low.onnx",
+  "es_ES-sharvard-medium":
+    "es/es_ES/sharvard/medium/es_ES-sharvard-medium.onnx",
+  "es_MX-ald-medium": "es/es_MX/ald/medium/es_MX-ald-medium.onnx",
+  "es_MX-claude-high": "es/es_MX/claude/high/es_MX-claude-high.onnx",
+  "fa_IR-amir-medium": "fa/fa_IR/amir/medium/fa_IR-amir-medium.onnx",
+  "fa_IR-gyro-medium": "fa/fa_IR/gyro/medium/fa_IR-gyro-medium.onnx",
+  "fi_FI-harri-low": "fi/fi_FI/harri/low/fi_FI-harri-low.onnx",
+  "fi_FI-harri-medium": "fi/fi_FI/harri/medium/fi_FI-harri-medium.onnx",
+  "fr_FR-gilles-low": "fr/fr_FR/gilles/low/fr_FR-gilles-low.onnx",
+  "fr_FR-mls-medium": "fr/fr_FR/mls/medium/fr_FR-mls-medium.onnx",
+  "fr_FR-mls_1840-low": "fr/fr_FR/mls_1840/low/fr_FR-mls_1840-low.onnx",
+  "fr_FR-siwis-low": "fr/fr_FR/siwis/low/fr_FR-siwis-low.onnx",
+  "fr_FR-siwis-medium": "fr/fr_FR/siwis/medium/fr_FR-siwis-medium.onnx",
+  "fr_FR-tom-medium": "fr/fr_FR/tom/medium/fr_FR-tom-medium.onnx",
+  "fr_FR-upmc-medium": "fr/fr_FR/upmc/medium/fr_FR-upmc-medium.onnx",
+  "hu_HU-anna-medium": "hu/hu_HU/anna/medium/hu_HU-anna-medium.onnx",
+  "hu_HU-berta-medium": "hu/hu_HU/berta/medium/hu_HU-berta-medium.onnx",
+  "hu_HU-imre-medium": "hu/hu_HU/imre/medium/hu_HU-imre-medium.onnx",
+  "is_IS-bui-medium": "is/is_IS/bui/medium/is_IS-bui-medium.onnx",
+  "is_IS-salka-medium": "is/is_IS/salka/medium/is_IS-salka-medium.onnx",
+  "is_IS-steinn-medium": "is/is_IS/steinn/medium/is_IS-steinn-medium.onnx",
+  "is_IS-ugla-medium": "is/is_IS/ugla/medium/is_IS-ugla-medium.onnx",
+  "it_IT-riccardo-x_low": "it/it_IT/riccardo/x_low/it_IT-riccardo-x_low.onnx",
+  "ka_GE-natia-medium": "ka/ka_GE/natia/medium/ka_GE-natia-medium.onnx",
+  "kk_KZ-iseke-x_low": "kk/kk_KZ/iseke/x_low/kk_KZ-iseke-x_low.onnx",
+  "kk_KZ-issai-high": "kk/kk_KZ/issai/high/kk_KZ-issai-high.onnx",
+  "kk_KZ-raya-x_low": "kk/kk_KZ/raya/x_low/kk_KZ-raya-x_low.onnx",
+  "lb_LU-marylux-medium": "lb/lb_LU/marylux/medium/lb_LU-marylux-medium.onnx",
+  "ne_NP-google-medium": "ne/ne_NP/google/medium/ne_NP-google-medium.onnx",
+  "ne_NP-google-x_low": "ne/ne_NP/google/x_low/ne_NP-google-x_low.onnx",
+  "nl_BE-nathalie-medium":
+    "nl/nl_BE/nathalie/medium/nl_BE-nathalie-medium.onnx",
+  "nl_BE-nathalie-x_low": "nl/nl_BE/nathalie/x_low/nl_BE-nathalie-x_low.onnx",
+  "nl_BE-rdh-medium": "nl/nl_BE/rdh/medium/nl_BE-rdh-medium.onnx",
+  "nl_BE-rdh-x_low": "nl/nl_BE/rdh/x_low/nl_BE-rdh-x_low.onnx",
+  "nl_NL-mls-medium": "nl/nl_NL/mls/medium/nl_NL-mls-medium.onnx",
+  "nl_NL-mls_5809-low": "nl/nl_NL/mls_5809/low/nl_NL-mls_5809-low.onnx",
+  "nl_NL-mls_7432-low": "nl/nl_NL/mls_7432/low/nl_NL-mls_7432-low.onnx",
+  "no_NO-talesyntese-medium":
+    "no/no_NO/talesyntese/medium/no_NO-talesyntese-medium.onnx",
+  "pl_PL-darkman-medium": "pl/pl_PL/darkman/medium/pl_PL-darkman-medium.onnx",
+  "pl_PL-gosia-medium": "pl/pl_PL/gosia/medium/pl_PL-gosia-medium.onnx",
+  "pl_PL-mc_speech-medium":
+    "pl/pl_PL/mc_speech/medium/pl_PL-mc_speech-medium.onnx",
+  "pl_PL-mls_6892-low": "pl/pl_PL/mls_6892/low/pl_PL-mls_6892-low.onnx",
+  "pt_BR-edresson-low": "pt/pt_BR/edresson/low/pt_BR-edresson-low.onnx",
+  "pt_BR-faber-medium": "pt/pt_BR/faber/medium/pt_BR-faber-medium.onnx",
+  "pt_PT-tugão-medium": "pt/pt_PT/tugão/medium/pt_PT-tugão-medium.onnx",
+  "ro_RO-mihai-medium": "ro/ro_RO/mihai/medium/ro_RO-mihai-medium.onnx",
+  "ru_RU-denis-medium": "ru/ru_RU/denis/medium/ru_RU-denis-medium.onnx",
+  "ru_RU-dmitri-medium": "ru/ru_RU/dmitri/medium/ru_RU-dmitri-medium.onnx",
+  "ru_RU-irina-medium": "ru/ru_RU/irina/medium/ru_RU-irina-medium.onnx",
+  "ru_RU-ruslan-medium": "ru/ru_RU/ruslan/medium/ru_RU-ruslan-medium.onnx",
+  "sk_SK-lili-medium": "sk/sk_SK/lili/medium/sk_SK-lili-medium.onnx",
+  "sl_SI-artur-medium": "sl/sl_SI/artur/medium/sl_SI-artur-medium.onnx",
+  "sr_RS-serbski_institut-medium":
+    "sr/sr_RS/serbski_institut/medium/sr_RS-serbski_institut-medium.onnx",
+  "sv_SE-nst-medium": "sv/sv_SE/nst/medium/sv_SE-nst-medium.onnx",
+  "sw_CD-lanfrica-medium":
+    "sw/sw_CD/lanfrica/medium/sw_CD-lanfrica-medium.onnx",
+  "tr_TR-dfki-medium": "tr/tr_TR/dfki/medium/tr_TR-dfki-medium.onnx",
+  "tr_TR-fahrettin-medium":
+    "tr/tr_TR/fahrettin/medium/tr_TR-fahrettin-medium.onnx",
+  "tr_TR-fettah-medium": "tr/tr_TR/fettah/medium/tr_TR-fettah-medium.onnx",
+  "uk_UA-lada-x_low": "uk/uk_UA/lada/x_low/uk_UA-lada-x_low.onnx",
+  "uk_UA-ukrainian_tts-medium":
+    "uk/uk_UA/ukrainian_tts/medium/uk_UA-ukrainian_tts-medium.onnx",
+  "vi_VN-25hours_single-low":
+    "vi/vi_VN/25hours_single/low/vi_VN-25hours_single-low.onnx",
+  "vi_VN-vais1000-medium":
+    "vi/vi_VN/vais1000/medium/vi_VN-vais1000-medium.onnx",
+  "vi_VN-vivos-x_low": "vi/vi_VN/vivos/x_low/vi_VN-vivos-x_low.onnx",
+  "zh_CN-huayan-medium": "zh/zh_CN/huayan/medium/zh_CN-huayan-medium.onnx",
+  "zh_CN-huayan-x_low": "zh/zh_CN/huayan/x_low/zh_CN-huayan-x_low.onnx",
+};
+
+function pcm2wav(buffer, numChannels, sampleRate) {
+  const bufferLength = buffer.length;
+  const view = new DataView(
+    new ArrayBuffer(bufferLength * numChannels * 2 + 44),
+  );
+  view.setUint32(0, 0x46464952, true);
+  view.setUint32(4, view.buffer.byteLength - 8, true);
+  view.setUint32(8, 0x45564157, true);
+  view.setUint32(12, 0x20746d66, true);
+  view.setUint32(16, 0x10, true);
+  view.setUint16(20, 0x0001, true);
+  view.setUint16(22, numChannels, true);
+  view.setUint32(24, sampleRate, true);
+  view.setUint32(28, numChannels * 2 * sampleRate, true);
+  view.setUint16(32, numChannels * 2, true);
+  view.setUint16(34, 16, true);
+  view.setUint32(36, 0x61746164, true);
+  view.setUint32(40, 2 * bufferLength, true);
+  let p = 44;
+  for (let i = 0; i < bufferLength; i++) {
+    const v = buffer[i];
+    if (v >= 1) view.setInt16(p, 0x7fff, true);
+    else if (v <= -1) view.setInt16(p, -0x8000, true);
+    else view.setInt16(p, (v * 0x8000) | 0, true);
+    p += 2;
+  }
+  return view.buffer;
+}
+
+async function predict(config, callback) {
+  const path = PATH_MAP[config.voiceId];
+  const input = JSON.stringify([
+    {
+      text: config.text.trim(),
+    },
+  ]);
+  const piperPhonemizeWasm = (await createBlobUrl(`${WASM_BASE}.wasm`)).url;
+  const piperPhonemizeData = (await createBlobUrl(`${WASM_BASE}.data`)).url;
+  ort.env.wasm.numThreads = navigator.hardwareConcurrency;
+  ort.env.wasm.wasmPaths = ONNX_BASE;
+  const modelConfigBlob = (await createBlobUrl(`${HF_BASE}/${path}.json`)).blob;
+  const modelConfig = JSON.parse(await modelConfigBlob.text());
+  const phonemeIds = await new Promise(async (resolve) => {
+    const module = await createPiperPhonemize({
+      print: (data) => {
+        resolve(JSON.parse(data).phoneme_ids);
+      },
+      printErr: (message) => {
+        throw new Error(message);
+      },
+      locateFile: (url) => {
+        if (url.endsWith(".wasm")) return piperPhonemizeWasm;
+        if (url.endsWith(".data")) return piperPhonemizeData;
+        return url;
+      },
+    });
+    module.callMain([
+      "-l",
+      modelConfig.espeak.voice,
+      "--input",
+      input,
+      "--espeak_data",
+      "/espeak-ng-data",
+    ]);
+  });
+  const sampleRate = modelConfig.audio.sample_rate;
+  const noiseScale = modelConfig.inference.noise_scale;
+  const lengthScale = modelConfig.inference.length_scale;
+  const noiseW = modelConfig.inference.noise_w;
+  const modelBlob = (await createBlobUrl(`${HF_BASE}/${path}`, callback)).url;
+  const session = await ort.InferenceSession.create(modelBlob);
+  const feeds = {
+    input: new ort.Tensor("int64", phonemeIds, [1, phonemeIds.length]),
+    input_lengths: new ort.Tensor("int64", [phonemeIds.length]),
+    scales: new ort.Tensor("float32", [noiseScale, lengthScale, noiseW]),
+  };
+  if (Object.keys(modelConfig.speaker_id_map).length) {
+    Object.assign(feeds, {
+      sid: new ort.Tensor("int64", [0]),
+    });
+  }
+  const {
+    output: { data: pcm },
+  } = await session.run(feeds);
+  return new Blob([pcm2wav(pcm, 1, sampleRate)], {
+    type: "audio/x-wav",
+  });
+}
+
+async function writeBlob(url, blob) {
+  if (!url.match("https://huggingface.co")) {
+    return;
+  }
+  try {
+    const root = await navigator.storage.getDirectory();
+    const dir = await root.getDirectoryHandle("piper", {
+      create: true,
+    });
+    const path = url.split("/").at(-1);
+    const file = await dir.getFileHandle(path, {
+      create: true,
+    });
+    const writable = await file.createWritable();
+    await writable.write(blob);
+    await writable.close();
+  } catch (e) {
+    console.error(e);
+  }
+}
+async function removeBlob(url) {
+  try {
+    const root = await navigator.storage.getDirectory();
+    const dir = await root.getDirectoryHandle("piper");
+    const path = url.split("/").at(-1);
+    const file = await dir.getFileHandle(path);
+    await file.remove();
+  } catch (e) {
+    console.error(e);
+  }
+}
+async function readBlob(url) {
+  if (!url.match("https://huggingface.co")) {
+    return;
+  }
+  try {
+    const root = await navigator.storage.getDirectory();
+    const dir = await root.getDirectoryHandle("piper", {
+      create: true,
+    });
+    const path = url.split("/").at(-1);
+    const file = await dir.getFileHandle(path);
+    return await file.getFile();
+  } catch (e) {
+    return undefined;
+  }
+}
+
+async function createBlobUrl(url, callback) {
+  let blob = await readBlob(url);
+  if (!blob) {
+    blob = await fetchBlob(url, callback);
+    await writeBlob(url, blob);
+  }
+  return {
+    url: URL.createObjectURL(blob),
+    blob,
+  };
+}
+// export { predict as predict };
+async function download(voiceId, callback) {
+  const path = PATH_MAP[voiceId];
+  const urls = [`${HF_BASE}/${path}`, `${HF_BASE}/${path}.json`];
+  await Promise.all(urls.map(async (url) => {
+    writeBlob(
+      url,
+      await fetchBlob(url, url.endsWith(".onnx") ? callback : undefined),
+    );
+  }));
+}
+async function remove(voiceId) {
+  const path = PATH_MAP[voiceId];
+  const urls = [`${HF_BASE}/${path}`, `${HF_BASE}/${path}.json`];
+  await Promise.all(urls.map((url) => removeBlob(url)));
+}
+async function stored() {
+  const root = await navigator.storage.getDirectory();
+  const dir = await root.getDirectoryHandle("piper", {
+    create: true,
+  });
+  const result = [];
+  for await (const name of dir.keys()) {
+    const key = name.split(".")[0];
+    if (name.endsWith(".onnx") && key in PATH_MAP) {
+      result.push(key);
+    }
+  }
+  return result;
+}
+async function flush() {
+  try {
+    const root = await navigator.storage.getDirectory();
+    const dir = await root.getDirectoryHandle("piper");
+    await dir.remove({
+      recursive: true,
+    });
+  } catch (e) {
+    console.error(e);
+  }
+}
+// export { download as download };
+// export { remove as remove };
+// export { stored as stored };
+// export { flush as flush };
+
+async function fetchBlob(url) {
+  const request = await fetch(url);
+  const type = request.headers.get("content-type");
+  console.log(`Done fetching ${url}. Content-Type: ${type}`);
+  return new Blob([await request.arrayBuffer()], { type });
+}
+async function voices() {
+  const res = await fetch(`${HF_BASE}/voices.json`);
+  if (!res.ok) {
+    throw new Error("Could not retrieve voices file from huggingface");
+  }
+  return Object.values(await res.json());
+}
+
+const text = "Text to speech in the browser is amazing!";
+const select = document.querySelector("select");
+const audio = document.querySelector("audio");
+const textarea = document.querySelector("textarea");
+const button = document.querySelector("button");
+const a = document.querySelector("a");
+textarea.placeholder = text;
+const entries = Object.entries(PATH_MAP);
+
+for (let i = 0; i < entries.length + 1; i++) {
+  if (i === 0) {
+    select[i] = new Option(
+      "Choose a voice for Text-To-Speech:",
+      "",
+      true,
+      true,
+    );
+    continue;
+  }
+  const [key] = entries[i - 1];
+  select[i] = new Option(key);
+}
+
+let blobURL;
+
+select.addEventListener("change", async (e) => {
+  const value = e.target.value.trim();
+  if (value) {
+    await download(value);
+    const wav = await predict({
+      text: textarea.value.trim() ||
+        text,
+      voiceId: value,
+    });
+    if (blobURL?.length) {
+      URL.revokeObjectURL(blobURL);
+    }
+    blobURL = URL.createObjectURL(wav);
+    audio.src = blobURL;
+  }
+});
+
+button.addEventListener("click", (e) => {
+  if (blobURL) {
+    a.href = blobURL;
+    a.download = `${select.value}.wav`
+    a.click();
+  }
+});
+// export { voices as voices };
diff --git a/docs/onyx-runtimeweb.js b/docs/onyx-runtimeweb.js
new file mode 100644
index 0000000..7cb3c7a
--- /dev/null
+++ b/docs/onyx-runtimeweb.js
@@ -0,0 +1,1827 @@
+var W5=function(Q,H){if(!Q)throw new Error(typeof H=="string"?H:H())},N6=function(Q){return(new TextDecoder()).decode(Q)},$H=function(Q){switch(Q){case"bool":case"int8":case"uint8":return 1;case"int16":case"uint16":return 2;case"int32":case"uint32":case"float32":return 4;case"float64":return 8;default:throw new Error(`cannot calculate sizeof() on type ${Q}`)}},f7=function(Q){switch(Q){case o.onnx.TensorProto.DataType.UINT8:case o.onnx.TensorProto.DataType.INT8:case o.onnx.TensorProto.DataType.BOOL:return 1;case o.onnx.TensorProto.DataType.UINT16:case o.onnx.TensorProto.DataType.INT16:return 2;case o.onnx.TensorProto.DataType.FLOAT:case o.onnx.TensorProto.DataType.INT32:case o.onnx.TensorProto.DataType.UINT32:return 4;case o.onnx.TensorProto.DataType.INT64:case o.onnx.TensorProto.DataType.DOUBLE:case o.onnx.TensorProto.DataType.UINT64:return 8;default:throw new Error(`cannot calculate sizeof() on type ${o.onnx.TensorProto.DataType[Q]}`)}},LH=function(Q,H){return new(A2(H))(Q)},A2=function(Q){switch(Q){case"bool":case"uint8":return Uint8Array;case"int8":return Int8Array;case"int16":return Int16Array;case"uint16":return Uint16Array;case"int32":return Int32Array;case"uint32":return Uint32Array;case"int64":return BigInt64Array;case"float32":return Float32Array;case"float64":return Float64Array;default:throw new Error("unspecified error")}},M6=function(Q,H){if(H===o.onnx.TensorProto.DataType.INT64||H===q5.TensorDataType.INT64){if(Q.greaterThanOrEqual(2147483648)||Q.lessThan(-2147483648))throw new TypeError("int64 is not supported")}else if(H===o.onnx.TensorProto.DataType.UINT32||H===q5.TensorDataType.UINT32||H===o.onnx.TensorProto.DataType.UINT64||H===q5.TensorDataType.UINT64){if(Q.greaterThanOrEqual(4294967296)||Q.lessThan(0))throw new TypeError("uint64 is not supported")}else throw new TypeError(`not a LONG type: ${o.onnx.TensorProto.DataType[H]}`);return Q.toNumber()},l7=function(Q,H,j){switch(H){case o.onnx.TensorProto.DataType.BOOL:case o.onnx.TensorProto.DataType.UINT8:return Q.getUint8(j);case o.onnx.TensorProto.DataType.INT8:return Q.getInt8(j);case o.onnx.TensorProto.DataType.UINT16:return Q.getUint16(j,!0);case o.onnx.TensorProto.DataType.INT16:return Q.getInt16(j,!0);case o.onnx.TensorProto.DataType.FLOAT:return Q.getFloat32(j,!0);case o.onnx.TensorProto.DataType.INT32:return Q.getInt32(j,!0);case o.onnx.TensorProto.DataType.UINT32:return Q.getUint32(j,!0);case o.onnx.TensorProto.DataType.INT64:return M6(_3.fromBits(Q.getUint32(j,!0),Q.getUint32(j+4,!0),!1),H);case o.onnx.TensorProto.DataType.DOUBLE:return Q.getFloat64(j,!0);case o.onnx.TensorProto.DataType.UINT64:return M6(_3.fromBits(Q.getUint32(j,!0),Q.getUint32(j+4,!0),!0),H);default:throw new Error(`cannot read from DataView for type ${o.onnx.TensorProto.DataType[H]}`)}},r=function(Q){return Q===1?e2:Q0},vH=function(Q){let H=r(Q);return`${H.version}
+      precision highp float;
+      ${H.attribute} vec3 position;
+      ${H.attribute} vec2 textureCoord;
+
+      ${H.varyingVertex} vec2 TexCoords;
+
+      void main()
+      {
+          gl_Position = vec4(position, 1.0);
+          TexCoords = textureCoord;
+      }`},wH=function(Q){let H=r(Q);return`${H.version}
+    precision highp float;
+    precision highp int;
+    precision highp sampler2D;
+    ${H.varyingFrag} vec2 TexCoords;
+    ${H.outputDeclaration}
+    const vec2 halfCR = vec2(0.5, 0.5);
+
+    // Custom vector types to handle higher dimenalities.
+    struct ivec5
+    {
+      int x;
+      int y;
+      int z;
+      int w;
+      int u;
+    };
+
+    struct ivec6
+    {
+      int x;
+      int y;
+      int z;
+      int w;
+      int u;
+      int v;
+    };
+
+    int imod(int x, int y) {
+      return x - y * (x / y);
+    }
+
+    `},TH=function(Q,H){let j=r(Q);return`
+  void main() {
+    int indices[${H}];
+    toVec(TexCoords, indices);
+    vec4 result = vec4(process(indices));
+    ${j.output} = result;
+  }
+  `};async function u7(Q,H=(K)=>0,j){return new Promise((K,W)=>{let U=0,Z=()=>{if(Q()){K();return}U++;let q=H(U);if(j!=null&&U>=j){W();return}setTimeout(Z,q)};Z()})}var P5=function(Q){return W5(typeof Q<"u"&&Q.length!==0,()=>"empty string found for sampler name"),"get"+Q.charAt(0).toUpperCase()+Q.slice(1)},DH=function(Q){return W5(typeof Q<"u"&&Q.length!==0,()=>"empty string found for sampler name"),"get"+Q.charAt(0).toUpperCase()+Q.slice(1)+"AtOutCoords"},F4=function(Q,H){let j=JSON.parse(JSON.stringify(Q));return j=H,j},k4=function(Q,H){return H.map((j)=>Q[j]).join(", ")},P3=function(Q){if(Q<=1)return"int";if(Q===2)return"ivec2";if(Q===3)return"ivec3";if(Q===4)return"ivec4";if(Q===5)return"ivec5";if(Q===6)return"ivec6";throw Error(`GPU for rank ${Q} is not yet supported`)},H4=function(Q=6){return["x","y","z","w","u","v"].slice(0,Q)},_H=function(Q,H){return H4(H).map((j)=>`${Q}.${j}`)},n6=function(Q,H){return H===1?[Q]:_H(Q,H)},c4=function(){return`
+    float getChannel(vec4 frag, int dim) {
+      int modCoord = imod(dim, 2);
+      return modCoord == 0 ? frag.r : frag.g;
+    }
+
+    float getChannel(vec4 frag, vec2 innerDims) {
+      vec2 modCoord = mod(innerDims, 2.);
+      return modCoord.x == 0. ?
+        (modCoord.y == 0. ? frag.r : frag.g) :
+        (modCoord.y == 0. ? frag.b : frag.a);
+    }
+  `},PH=function(Q,H,j){if(Q===0)return"false";if(Q===1)return`rc > ${H[0]}`;let K="";for(let W=Q-2;W<Q;W++)K+=`${j[W]} >= ${H[W-Q+2]}`,W<Q-1&&(K+="||");return K},EH=function(Q,H){let j=Q.length;if(j===0)return"getA(), 0, 0, 0";if(j===1)return`getA(rc),
+            rc + 1 >= ${Q[0]} ? 0. : getA(rc + 1),
+            0, 0`;let K="r, c",W="r, cp1",U="rp1, c",Z="rp1, cp1",q="";if(j>2)for(let G=0;G<j-2;++G)q=q+`${H[G]},`;return`getA(${q}${K}),
+          rEdge ? 0. : getA(${q}${U}),
+          cEdge ? 0. : getA(${q}${W}),
+          rEdge || cEdge ? 0. : getA(${q}${Z})`},IH=function(Q,H,j,K){return Q===0||Q===1?"":`
+    int r = ${H[Q-2]};
+    int c = ${H[Q-1]};
+    int rp1 = ${H[Q-2]} + 1;
+    int cp1 = ${H[Q-1]} + 1;
+    bool rEdge = rp1 >= ${K};
+    bool cEdge = cp1 >= ${j};
+    `},s7=function(Q){if(Q.length===0)return[1,1,1];let H=1;for(let j=0;j<Q.length-2;++j)H*=Q[j];return[H,Q.length>1?Q[Q.length-2]:1,Q[Q.length-1]]},xH=function(Q,H){let j=!1;return Q.length===0||H.length===0?j=!0:Q.length<2||H.length<2?j=Q[Q.length-1]===H[H.length-1]:j=Q[Q.length-1]===H[H.length-1]&&Q[Q.length-2]===H[H.length-2],j},OH=function(Q){let H=u.computeStrides(Q),j=["b","r","c"],K="index";return`
+    ivec3 inputCoordsFromReshapedOutCoords(int index) {
+      ${H.map((W,U)=>{let Z=`int ${j[U]} = ${K} / ${W}`,q=U===H.length-1?`int ${j[U+1]} = ${K} - ${j[U]} * ${W}`:`index -= ${j[U]} * ${W}`;return`${Z}; ${q};`}).join("")}
+      return ivec3(b, r, c);
+    }
+  `},gH=function(Q){let H=u.computeStrides(Q);return`
+  int getFlattenedIndex(ivec3 coords) {
+    // reverse y, z order
+    return coords.x * ${H[0]} + coords.z * ${H[1]} + coords.y;
+  }
+`},yH=function(Q,H){if(Q===1)return"rc";let j="";for(let K=0;K<Q;K++)j+=H[K],K<Q-1&&(j+=",");return j},dH=function(){let Q="add_";return{body:`
+  float ${Q}(float a, float b) {
+    return a + b;
+  }
+  vec4 ${Q}(vec4 v1, vec4 v2) {
+    return v1 + v2;
+  }
+  `,name:Q,type:0}},pH=function(){let Q="div_";return{body:`
+  float ${Q}(float a, float b) {
+    return a / b;
+  }
+  vec4 ${Q}(vec4 v1, vec4 v2) {
+    return v1 / v2;
+  }
+  `,name:Q,type:0}},hH=function(){let Q="mul_";return{body:`
+  float ${Q}(float a, float b) {
+    return a * b;
+  }
+  vec4 ${Q}(vec4 v1, vec4 v2) {
+    return v1 * v2;
+  }
+  `,name:Q,type:0}},bH=function(){let Q="sub_";return{body:`
+  float ${Q}(float a, float b) {
+    return a - b;
+  }
+  vec4 ${Q}(vec4 v1, vec4 v2) {
+    return v1 - v2;
+  }
+  `,name:Q,type:0}},mH=function(){let Q="equal_";return{body:`
+  float ${Q}(float a, float b) {
+    return float(a == b);
+  }
+  vec4 ${Q}(vec4 v1, vec4 v2) {
+    return vec4(equal(v1, v2));
+  }
+  `,name:Q,type:0}},cH=function(){let Q="greater_";return{body:`
+  float ${Q}(float a, float b) {
+    return float(a > b);
+  }
+  vec4 ${Q}(vec4 v1, vec4 v2) {
+    return vec4( v1.r > v2.r ,
+      v1.g > v2.g,
+      v1.b > v2.b,
+      v1.a > v2.a );
+  }
+  `,name:Q,type:0}},fH=function(){let Q="less_";return{body:`
+  float ${Q}(float a, float b) {
+    return float(a < b);
+  }
+  vec4 ${Q}(vec4 v1, vec4 v2) {
+    return vec4( v1.r < v2.r ,
+                v1.g < v2.g,
+                v1.b < v2.b,
+                v1.a < v2.a );
+  }
+  `,name:Q,type:0}},lH=function(){let Q="and_";return{body:`
+  float ${Q}(float a, float b) {
+    return float( bool(a) && bool(b) );
+  }
+  vec4 ${Q}(vec4 v1, vec4 v2) {
+    bvec4 b1 = bvec4(v1);
+    bvec4 b2 = bvec4(v2);
+    return vec4( b1.r && b2.r ,
+                b1.g && b2.g,
+                b1.b && b2.b,
+                b1.a && b2.a );
+  }
+  `,name:Q,type:0}},uH=function(){let Q="or_";return{body:`
+  float ${Q}(float a, float b) {
+    return float( bool(a) || bool(b) );
+  }
+  vec4 ${Q}(vec4 v1, vec4 v2) {
+    bvec4 b1 = bvec4(v1);
+    bvec4 b2 = bvec4(v2);
+    return vec4( b1.r || b2.r ,
+                b1.g || b2.g,
+                b1.b || b2.b,
+                b1.a || b2.a );
+  }
+  `,name:Q,type:0}},sH=function(){let Q="xor_";return{body:`
+  float ${Q}(float a, float b) {
+    return float( bool(a) ^^ bool(b) );
+  }
+  vec4 ${Q}(vec4 v1, vec4 v2) {
+    bvec4 b1 = bvec4(v1);
+    bvec4 b2 = bvec4(v2);
+    return vec4( b1.r ^^ b2.r ,
+                b1.g ^^ b2.g,
+                b1.b ^^ b2.b,
+                b1.a ^^ b2.a );
+  }
+  `,name:Q,type:0}},iH=function(){return aH("pow")},oH=function(){let Q="prelu_";return{body:`
+  float ${Q}(float a, float b) {
+    return a < 0.0 ? a * b: a;
+  }
+  vec4 ${Q}(vec4 v1, vec4 v2) {
+    return vec4(
+      v1.r < 0.0 ? v1.r * v2.r: v1.r,
+      v1.g < 0.0 ? v1.g * v2.g: v1.g,
+      v1.b < 0.0 ? v1.b * v2.b: v1.b,
+      v1.a < 0.0 ? v1.a * v2.a: v1.a
+      );
+  }
+  `,name:Q,type:0}},aH=function(Q){let H=`${Q}_`;return{body:`
+  float ${H}(float a, float b) {
+    return ${Q}(a, b);
+  }
+  vec4 ${H}(vec4 v1, vec4 v2) {
+    return ${Q}(v1, v2);
+  }
+  `,name:H,type:0}},nH=function(){return Q3("abs")},rH=function(){return Q3("acos")},tH=function(){return Q3("asin")},eH=function(){return Q3("atan")},QZ=function(){return Q3("ceil")},JZ=function(){return Q3("cos")},HZ=function(Q){let H="elu";return{body:`
+  const float alpha = float(${Q});
+
+  float ${H}_(float a) {
+    return a >= 0.0 ? a: (exp(a) - 1.0) * alpha;
+  }
+  vec4 ${H}_(vec4 v) {
+    return vec4(${H}_(v.x), ${H}_(v.y), ${H}_(v.z), ${H}_(v.w));
+  }
+  `,name:H,type:0}},ZZ=function(){return Q3("exp")},jZ=function(){return Q3("floor")},S2=function(Q,H){let j="clip";return{body:`
+  const float min = float(${Q});
+  const float max = float(${H});
+
+  float ${j}_(float a) {
+    return clamp(a, min, max);
+  }
+  vec4 ${j}_(vec4 v) {
+    return clamp(v, min, max);
+  }
+  `,name:j,type:0}},VZ=function(){let Q="indentity";return{body:`
+  float ${Q}_(float a) {
+    return a;
+  }
+  vec4 ${Q}_(vec4 v) {
+    return v;
+  }
+  `,name:Q,type:0}},XZ=function(Q){let H="leakyRelu";return{body:`
+  const float alpha = float(${Q});
+
+  float ${H}_(float a) {
+    return a < 0.0 ? a * alpha : a;
+  }
+  vec4 ${H}_(vec4 v) {
+    return vec4(${H}_(v.x), ${H}_(v.y), ${H}_(v.z), ${H}_(v.w));
+  }
+  `,name:H,type:0}},KZ=function(){return Q3("log")},UZ=function(){let Q="neg";return{body:`
+  float ${Q}_(float a) {
+    return -a;
+  }
+  vec4 ${Q}_(vec4 v) {
+    return -v;
+  }
+  `,name:Q,type:0}},qZ=function(){let Q="not";return{body:`
+  float ${Q}_(float a) {
+    return float( ! bool(a) );
+  }
+  bool ${Q}_(bool a) {
+    return !a;
+  }
+  vec4 ${Q}_(vec4 v) {
+    return vec4(!bool(v.x), !bool(v.y), !bool(v.z), !bool(v.w));
+  }
+  bvec4 ${Q}_(bvec4 v) {
+    return bvec4(!v.x, !v.y, !v.z, !v.w);
+  }
+  `,name:Q,type:0}},WZ=function(){return Q3("sin")},$2=function(){let Q="relu";return{body:`
+  float ${Q}_(float a) {
+    return max( a, 0.0 );
+  }
+  vec4 ${Q}_(vec4 v) {
+    return max( v, 0.0 );
+  }
+  `,name:Q,type:0}},L2=function(){let Q="sigmoid";return{body:`
+  float ${Q}_(float a) {
+    return 1.0 / (1.0 + exp(-a));
+  }
+  vec4 ${Q}_(vec4 v) {
+    return 1.0 / (1.0 + exp(-v));
+  }
+  `,name:Q,type:0}},GZ=function(){return Q3("sqrt")},RZ=function(){return Q3("tan")},zZ=function(){let Q="tanh";return{body:`
+  float ${Q}_(float a) {
+    a = clamp(a, -10., 10.);
+    a = exp(2.*a);
+    return (a - 1.) / (a + 1.);
+  }
+  vec4 ${Q}_(vec4 v) {
+    v = clamp(v, -10., 10.);
+    v = exp(2.*v);
+    return (v - 1.) / (v + 1.);
+  }
+  `,name:Q,type:0}},Q3=function(Q){return{body:`
+  float ${Q}_(float a) {
+    return ${Q}(a);
+  }
+  vec4 ${Q}_(vec4 v) {
+    return ${Q}(v);
+  }
+  `,name:Q,type:0}},f4=function(Q){let H;switch(Q.activation){case"Relu":H=$2();break;case"Sigmoid":H=L2();break;case"Clip":H=S2(Q.clipMin,Q.clipMax);break;default:return{activationFunction:"",applyActivation:""}}let{name:j,body:K}=H,W=`value = ${j}_(value);`;return{activationFunction:K,applyActivation:W}},NZ=function(Q,H,j){let K=H[0].dims,W=H[1].dims,U=R3.calcShape(K,W,!0);if(!U)throw new Error("Can't use matmul on the given tensors");let Z=P3(U.length),q=H4(),{activationFunction:G,applyActivation:J}=f4(j),X=H.length>2,V=X?"value += getBiasForMatmul();":"",R=X?`${w2(Z,q,H[2].dims,U,!1)}`:"",z=U.length,Y=K.length,B=W.length,k=K[K.length-1],w=`
+    ${G}
+    ${R}
+    float process(int indices[${z}]) {
+        int a[${Y}];
+        int b[${B}];
+        bcastMatmulIndices_A(indices, a);
+        bcastMatmulIndices_B(indices, b);
+
+        float value;
+        for (int k=0; k<${k}; ++k) {
+            a[${Y-1}] = k;
+            b[${B-2}] = k;
+            value += _A(a) * _B(b);
+        }
+        ${V}
+        ${J}
+        return value;
+    }`;return{...Q,output:{dims:U,type:H[0].type,textureType:0},shaderSource:w}},v2=function(Q,H){let j=ZQ(Q.length>2,H.activationCacheKey);return{...j,get:()=>NZ(j,Q,H)}},w2=function(Q,H,j,K,W){let U="",Z=j.length,q=K.length,G=q-Z;q<2&&Z>0?U="coords":U=j.map((R,z)=>`coords.${H[z+G]}`).join(", ");let J=R3.getBroadcastDims(j,K).map((R)=>`coords.${H[R+G]} = 0;`).join(`
+`),X=u.size(j)===1,V="vec4(outputValue.xx, outputValue.yy)";return X&&(V="vec4(outputValue.x)"),W?`
+vec4 getBiasForMatmul() {
+  ${Q} coords = getOutputCoords();
+  ${J}
+  vec4 outputValue = getBias(${U});
+  return ${V};
+}`:`
+float getBiasForMatmul() {
+  ${Q} coords = getOutputCoords();
+  ${J}
+  return getBias(coords.x);
+}`},MZ=function(Q,H,j,K){let W=[],U=[],Z=j[0].dims,q=j[1].dims,G=Z.length,J=q.length,X=K.length,V=X-G,R=X-J;W=Z.map((A,D)=>`coords.${H[D+V]}`),W[G-1]="i*2",W.join(", "),U=q.map((A,D)=>`coords.${H[D+R]}`),U[J-2]="i*2",U.join(", ");let z=R3.getBroadcastDims(Z,K),Y=R3.getBroadcastDims(q,K),B=z.map((A)=>`coords.${H[A+V]} = 0;`).join(`
+`),k=Y.map((A)=>`coords.${H[A+R]} = 0;`).join(`
+`),w=`int lastDim = coords.${H[X-1]};
+  coords.${H[X-1]} = coords.${H[X-2]};
+  coords.${H[X-2]} = lastDim;`;return`
+vec4 getAAtOutCoordsMatmul(int i) {
+  ${Q} coords = getOutputCoords();
+  ${w}
+  ${B}
+  vec4 outputValue = getA(${W});
+  return outputValue;
+}
+
+vec4 getBAtOutCoordsMatmul(int i) {
+  ${Q} coords = getOutputCoords();
+  ${w}
+  ${k}
+  vec4 outputValue = getB(${U});
+  return outputValue;
+}`},YZ=function(Q,H){let j="";for(let K=0;K<H-2;K++)j+=`rc.${Q[K]}, `;return j+=`rc.${Q[H-2]}, i*2`,j},CZ=function(Q,H){let j="";for(let K=0;K<H-2;K++)j+=`rc.${Q[K]}, `;return j+=`i*2, rc.${Q[H-1]}`,j},BZ=function(Q,H){let j=Q[0].dims[1],K=Q[0].dims.length,W=-Math.floor((H.size-1)/2),U=Math.ceil((H.size-1)/2),Z=`float(${H.alpha}) / float(${H.size})`,q=`float(${H.bias})`,G=`float(${H.beta})`,J=`
+    float process(int indices[${K}]) {
+        int c = indices[1];
+        float x = _X(indices);
+        float square_sum = 0.0;
+
+        for (int i = ${W}; i <= ${U}; i++) {
+          int idx = c + i;
+          if (c >= 0 && c < ${j}) {
+            indices[1] = idx;
+            float j = _X(indices);
+            square_sum += j * j;
+          }
+        }
+        return x / pow(${q} + ${Z} * square_sum, ${G});
+    }`;return{...K7,cacheHint:H.cacheKey,output:{dims:Q[0].dims,type:Q[0].type,textureType:0},shaderSource:J}},FZ=function(Q,H){return{...K7,cacheHint:H.cacheKey,get:()=>BZ(Q,H)}},kZ=function(Q){let H={},j;for(;(j=m6.exec(Q))!==null;){let K=j[3].split(",").map((W)=>{let U=W.trim().split(" ");return U&&U.length===2?{type:U[0],name:U[1]}:null}).filter((W)=>W!==null);H[j[2]]={params:K,body:j[4]}}for(let K in H){let W=RJ.replace("__FUNC__",K),U=new RegExp(W,"gm");for(;(j=U.exec(Q))!==null;){let Z=j[1],q=j[2],G=j[3].split(","),J=Z?`${Z} ${q};`:"",X=H[K].body,V="";H[K].params.forEach((z,Y)=>{z&&(V+=`${z.type} ${z.name} = ${G[Y]};
+`)}),X=`${V}
+ ${X}`,X=X.replace("return",`${q} = `);let R=`
+      ${J}
+      {
+        ${X}
+      }
+      `;Q=Q.replace(j[0],R)}}return Q=Q.replace(m6,""),Q},E4=function(Q,H){let j=[],K=[],W=H!=null&&Array.isArray(H)&&H.length===0,U=H==null||W?null:AZ(H,Q).sort(),Z=0;for(let q=0;q<Q.length;++q){if(U!=null){if(U[Z]===q&&Q[q]!==1)throw new Error(`Can't squeeze axis ${q} since its dim '${Q[q]}' is not 1`);(U[Z]==null||U[Z]>q)&&Q[q]===1&&(j.push(Q[q]),K.push(q)),U[Z]<=q&&Z++}Q[q]!==1&&(j.push(Q[q]),K.push(q))}return{newShape:j,keptDims:K}},AZ=function(Q,H){let j=H.length;return Q=Q==null?H.map((K,W)=>W):[].concat(Q),W5(Q.every((K)=>K>=-j&&K<j),()=>`All values in axis param must be in range [-${j}, ${j}) but got axis ${Q}`),W5(Q.every(SZ),()=>`All values in axis param must be integers but got axis ${Q}`),Q.map((K)=>K<0?j+K:K)},SZ=function(Q){return Q%1===0},$Z=function(Q){if(Q.length===0)return 1;let H=Q[0];for(let j=1;j<Q.length;j++)H*=Q[j];return H},i7=function(Q){let H=Math.ceil(Math.sqrt(Q));return[H,Math.ceil(Q/H)]},LZ=function(Q){let H=0;for(;H<Q.length&&Q[H]();++H);return H-1},T2=function(Q){let H;if((!Q||Q==="webgl2")&&"webgl2"in u3?H=u3.webgl2:(!Q||Q==="webgl")&&("webgl"in u3)&&(H=u3.webgl),!H)try{let K=wZ();H=o7(K,Q)}catch{let K=vZ();H=o7(K,Q)}Q=Q||H.version===1?"webgl":"webgl2";let j=H.gl;return u3[Q]=H,j.isContextLost()?(delete u3[Q],T2(Q)):(j.disable(j.DEPTH_TEST),j.disable(j.STENCIL_TEST),j.disable(j.BLEND),j.disable(j.DITHER),j.disable(j.POLYGON_OFFSET_FILL),j.disable(j.SAMPLE_COVERAGE),j.enable(j.SCISSOR_TEST),j.enable(j.CULL_FACE),j.cullFace(j.BACK),H)},o7=function(Q,H){let j={alpha:!1,depth:!1,antialias:!1,stencil:!1,preserveDrawingBuffer:!1,premultipliedAlpha:!1,failIfMajorPerformanceCaveat:!1},K,W=j;if((!H||H==="webgl2")&&(K=Q.getContext("webgl2",W),K))try{return new f6(K,2)}catch(U){C1.warning("GlContextFactory",`failed to create WebGLContext using contextId 'webgl2'. Error: ${U}`)}if((!H||H==="webgl")&&(K=Q.getContext("webgl",W)||Q.getContext("experimental-webgl",W),K))try{return new f6(K,1)}catch(U){C1.warning("GlContextFactory",`failed to create WebGLContext using contextId 'webgl' or 'experimental-webgl'. Error: ${U}`)}throw new Error("WebGL is not supported")},vZ=function(){if(typeof document>"u")throw new TypeError("failed to create canvas: document is not supported");let Q=document.createElement("canvas");return Q.width=1,Q.height=1,Q},wZ=function(){if(typeof OffscreenCanvas>"u")throw new TypeError("failed to create offscreen canvas: OffscreenCanvas is not supported");return new OffscreenCanvas(1,1)};async function D2(Q){if(Q){let H=typeof Q=="string"?[Q]:Q;for(let j of H){let K=U7.get(j);if(K)return K;let W=await TZ(j);if(W)return W}}else return D2(["webgl"]);throw new Error("no available backend to use")}async function TZ(Q){let H=vJ;if(typeof H[Q]<"u"&&DZ(H[Q])){let j=H[Q],K=j.initialize();if(typeof K=="object"&&"then"in K&&(K=await K),K)return U7.set(Q,j),j}}var DZ=function(Q){let H=Q;return"initialize"in H&&typeof H.initialize=="function"&&"createSessionHandler"in H&&typeof H.createSessionHandler=="function"&&"dispose"in H&&typeof H.dispose=="function"},s3=function(Q,H,j,K){if(H===void 0)return kH(Q);if(j===void 0)H5(Q,H,1);else if(typeof j=="number"&&K===void 0)H5(Q,H,j);else if(typeof j=="string"&&K===void 0)H5(Q,j,1,H);else if(typeof j=="string"&&typeof K=="number")H5(Q,j,K,H);else throw new TypeError("input is valid")},kH=function(Q){return{verbose:s3.verbose.bind(null,Q),info:s3.info.bind(null,Q),warning:s3.warning.bind(null,Q),error:s3.error.bind(null,Q),fatal:s3.fatal.bind(null,Q)}},H5=function(Q,H,j,K){let W=J4[K||""]||J4[""];C6[Q]<C6[W.minimalSeverity]||(W.logDateTime&&(H=`${(new Date()).toISOString()}|${H}`),W.logSourceLocation,i2[W.provider].log(Q,H,K))},AH=function(Q,H,j){for(let K of j){let W=K[0],U=K[1],Z=K[2],q=K[3],G=K[4];if(Q.opType===W){for(let J of H)if((J.domain===U||J.domain==="ai.onnx"&&U==="")&&SH(J.version,Z))return{opImpl:q,opInit:G}}}throw new TypeError(`cannot resolve operator '${Q.opType}' with opsets: ${H.map((K)=>`${K.domain||"ai.onnx"} v${K.version}`).join(", ")}`)},SH=function(Q,H){if(H.endsWith("+")){let j=Number.parseInt(H.substring(0,H.length-1),10);return!isNaN(j)&&j<=Q}else if(H.split("-").length===2){let j=H.split("-"),K=Number.parseInt(j[0],10),W=Number.parseInt(j[1],10);return!isNaN(K)&&!isNaN(W)&&K<=Q&&Q<=W}else return Number.parseInt(H,10)===Q},X1=function(Q,H,j){this.low=Q|0,this.high=H|0,this.unsigned=!!j},I1=function(Q){return(Q&&Q.__isLong__)===!0},c7=function(Q){var H=Math.clz32(Q&-Q);return Q?31-H:H},b3=function(Q,H){var j,K,W;return H?(Q>>>=0,(W=0<=Q&&Q<256)&&(K=F6[Q],K)?K:(j=e(Q,0,!0),W&&(F6[Q]=j),j)):(Q|=0,(W=-128<=Q&&Q<128)&&(K=B6[Q],K)?K:(j=e(Q,Q<0?-1:0,!1),W&&(B6[Q]=j),j))},e1=function(Q,H){if(isNaN(Q))return H?W3:t1;if(H){if(Q<0)return W3;if(Q>=k6)return $6}else{if(Q<=-A6)return y1;if(Q+1>=A6)return S6}return Q<0?e1(-Q,H).neg():e(Q%o3|0,Q/o3|0,H)},e=function(Q,H,j){return new X1(Q,H,j)},a6=function(Q,H,j){if(Q.length===0)throw Error("empty string");if(typeof H=="number"?(j=H,H=!1):H=!!H,Q==="NaN"||Q==="Infinity"||Q==="+Infinity"||Q==="-Infinity")return H?W3:t1;if(j=j||10,j<2||36<j)throw RangeError("radix");var K;if((K=Q.indexOf("-"))>0)throw Error("interior hyphen");if(K===0)return a6(Q.substring(1),H,j).neg();for(var W=e1(O4(j,8)),U=t1,Z=0;Z<Q.length;Z+=8){var q=Math.min(8,Q.length-Z),G=parseInt(Q.substring(Z,Z+q),j);if(q<8){var J=e1(O4(j,q));U=U.mul(J).add(e1(G))}else U=U.mul(W),U=U.add(e1(G))}return U.unsigned=H,U},Z3=function(Q,H){return typeof Q=="number"?e1(Q,H):typeof Q=="string"?a6(Q,H):e(Q.low,Q.high,typeof H=="boolean"?H:Q.unsigned)},r6="./",G5="./onyx-runtimeweb.js";/*!
+ * ONNX Runtime Web v1.18.0
+ * Copyright (c) Microsoft Corporation. All rights reserved.
+ * Licensed under the MIT License.
+ */var{create:_Z,defineProperty:C5,getOwnPropertyDescriptor:PZ,getOwnPropertyNames:EZ,getPrototypeOf:IZ}=Object,xZ=Object.prototype.hasOwnProperty,E=(Q,H)=>()=>(Q&&(H=Q(Q=0)),H),U1=(Q,H)=>()=>(H||Q((H={exports:{}}).exports,H),H.exports),X4=(Q,H)=>{for(var j in H)C5(Q,j,{get:H[j],enumerable:!0})},_2=(Q,H,j,K)=>{if(H&&typeof H=="object"||typeof H=="function")for(let W of EZ(H))!xZ.call(Q,W)&&W!==j&&C5(Q,W,{get:()=>H[W],enumerable:!(K=PZ(H,W))||K.enumerable});return Q},Z4=(Q,H,j)=>(j=Q!=null?_Z(IZ(Q)):{},_2(H||!Q||!Q.__esModule?C5(j,"default",{value:Q,enumerable:!0}):j,Q)),a3=(Q)=>_2(C5({},"__esModule",{value:!0}),Q),A4,v3,p4,a7,t6,e6=E(()=>{A4=new Map,v3=[],p4=(Q,H,j)=>{if(H&&typeof H.init=="function"&&typeof H.createInferenceSessionHandler=="function"){let K=A4.get(Q);if(K===void 0)A4.set(Q,{backend:H,priority:j});else{if(K.priority>j)return;if(K.priority===j&&K.backend!==H)throw new Error(`cannot register backend "${Q}" using priority ${j}`)}if(j>=0){let W=v3.indexOf(Q);W!==-1&&v3.splice(W,1);for(let U=0;U<v3.length;U++)if(A4.get(v3[U]).priority<=j){v3.splice(U,0,Q);return}v3.push(Q)}return}throw new TypeError("not a valid backend")},a7=async(Q)=>{let H=A4.get(Q);if(!H)return"backend not found.";if(H.initialized)return H.backend;if(H.aborted)return H.error;{let j=!!H.initPromise;try{return j||(H.initPromise=H.backend.init(Q)),await H.initPromise,H.initialized=!0,H.backend}catch(K){return j||(H.error=`${K}`,H.aborted=!0),H.error}finally{delete H.initPromise}}},t6=async(Q)=>{let H=Q.executionProviders||[],j=H.map((G)=>typeof G=="string"?G:G.name),K=j.length===0?v3:j,W,U=[],Z=new Set;for(let G of K){let J=await a7(G);typeof J=="string"?U.push({name:G,err:J}):(W||(W=J),W===J&&Z.add(G))}if(!W)throw new Error(`no available backend found. ERR: ${U.map((G)=>`[${G.name}] ${G.err}`).join(", ")}`);for(let{name:G,err:J}of U)j.includes(G)&&console.warn(`removing requested execution provider "${G}" from session options because it is not available: ${J}`);let q=H.filter((G)=>Z.has(typeof G=="string"?G:G.name));return[W,new Proxy(Q,{get:(G,J)=>J==="executionProviders"?q:Reflect.get(G,J)})]}}),OZ=E(()=>{e6()}),P2,gZ=E(()=>{P2="1.18.0"}),E5,r1,E2=E(()=>{gZ(),E5="warning",r1={wasm:{},webgl:{},webgpu:{},versions:{common:P2},set logLevel(Q){if(Q!==void 0){if(typeof Q!="string"||["verbose","info","warning","error","fatal"].indexOf(Q)===-1)throw new Error(`Unsupported logging level: ${Q}`);E5=Q}},get logLevel(){return E5}},Object.defineProperty(r1,"logLevel",{enumerable:!0})}),i,yZ=E(()=>{E2(),i=r1}),I2,x2,dZ=E(()=>{I2=(Q,H)=>{let j=typeof document<"u"?document.createElement("canvas"):new OffscreenCanvas(1,1);j.width=Q.dims[3],j.height=Q.dims[2];let K=j.getContext("2d");if(K!=null){let W,U;H?.tensorLayout!==void 0&&H.tensorLayout==="NHWC"?(W=Q.dims[2],U=Q.dims[3]):(W=Q.dims[3],U=Q.dims[2]);let Z=H?.format!==void 0?H.format:"RGB",q=H?.norm,G,J;q===void 0||q.mean===void 0?G=[255,255,255,255]:typeof q.mean=="number"?G=[q.mean,q.mean,q.mean,q.mean]:(G=[q.mean[0],q.mean[1],q.mean[2],0],q.mean[3]!==void 0&&(G[3]=q.mean[3])),q===void 0||q.bias===void 0?J=[0,0,0,0]:typeof q.bias=="number"?J=[q.bias,q.bias,q.bias,q.bias]:(J=[q.bias[0],q.bias[1],q.bias[2],0],q.bias[3]!==void 0&&(J[3]=q.bias[3]));let X=U*W,V=0,R=X,z=X*2,Y=-1;Z==="RGBA"?(V=0,R=X,z=X*2,Y=X*3):Z==="RGB"?(V=0,R=X,z=X*2):Z==="RBG"&&(V=0,z=X,R=X*2);for(let B=0;B<U;B++)for(let k=0;k<W;k++){let w=(Q.data[V++]-J[0])*G[0],A=(Q.data[R++]-J[1])*G[1],D=(Q.data[z++]-J[2])*G[2],I=Y===-1?255:(Q.data[Y++]-J[3])*G[3];K.fillStyle="rgba("+w+","+A+","+D+","+I+")",K.fillRect(k,B,1,1)}if("toDataURL"in j)return j.toDataURL();throw new Error("toDataURL is not supported")}else throw new Error("Can not access image data")},x2=(Q,H)=>{let j=typeof document<"u"?document.createElement("canvas").getContext("2d"):new OffscreenCanvas(1,1).getContext("2d"),K;if(j!=null){let W,U,Z;H?.tensorLayout!==void 0&&H.tensorLayout==="NHWC"?(W=Q.dims[2],U=Q.dims[1],Z=Q.dims[3]):(W=Q.dims[3],U=Q.dims[2],Z=Q.dims[1]);let q=H!==void 0&&H.format!==void 0?H.format:"RGB",G=H?.norm,J,X;G===void 0||G.mean===void 0?J=[255,255,255,255]:typeof G.mean=="number"?J=[G.mean,G.mean,G.mean,G.mean]:(J=[G.mean[0],G.mean[1],G.mean[2],255],G.mean[3]!==void 0&&(J[3]=G.mean[3])),G===void 0||G.bias===void 0?X=[0,0,0,0]:typeof G.bias=="number"?X=[G.bias,G.bias,G.bias,G.bias]:(X=[G.bias[0],G.bias[1],G.bias[2],0],G.bias[3]!==void 0&&(X[3]=G.bias[3]));let V=U*W;if(H!==void 0&&(H.format!==void 0&&Z===4&&H.format!=="RGBA"||Z===3&&H.format!=="RGB"&&H.format!=="BGR"))throw new Error("Tensor format doesn't match input tensor dims");let R=4,z=0,Y=1,B=2,k=3,w=0,A=V,D=V*2,I=-1;q==="RGBA"?(w=0,A=V,D=V*2,I=V*3):q==="RGB"?(w=0,A=V,D=V*2):q==="RBG"&&(w=0,D=V,A=V*2),K=j.createImageData(W,U);for(let h=0;h<U*W;z+=R,Y+=R,B+=R,k+=R,h++)K.data[z]=(Q.data[w++]-X[0])*J[0],K.data[Y]=(Q.data[A++]-X[1])*J[1],K.data[B]=(Q.data[D++]-X[2])*J[2],K.data[k]=I===-1?255:(Q.data[I++]-X[3])*J[3]}else throw new Error("Can not access image data");return K}}),Z5,O2,g2,y2,d2,pZ=E(()=>{Q7(),Z5=(Q,H)=>{if(Q===void 0)throw new Error("Image buffer must be defined");if(H.height===void 0||H.width===void 0)throw new Error("Image height and width must be defined");if(H.tensorLayout==="NHWC")throw new Error("NHWC Tensor layout is not supported yet");let{height:j,width:K}=H,W=H.norm??{mean:255,bias:0},U,Z;typeof W.mean=="number"?U=[W.mean,W.mean,W.mean,W.mean]:U=[W.mean[0],W.mean[1],W.mean[2],W.mean[3]??255],typeof W.bias=="number"?Z=[W.bias,W.bias,W.bias,W.bias]:Z=[W.bias[0],W.bias[1],W.bias[2],W.bias[3]??0];let q=H.format!==void 0?H.format:"RGBA",G=H.tensorFormat!==void 0&&H.tensorFormat!==void 0?H.tensorFormat:"RGB",J=j*K,X=G==="RGBA"?new Float32Array(J*4):new Float32Array(J*3),V=4,R=0,z=1,Y=2,B=3,k=0,w=J,A=J*2,D=-1;q==="RGB"&&(V=3,R=0,z=1,Y=2,B=-1),G==="RGBA"?D=J*3:G==="RBG"?(k=0,A=J,w=J*2):G==="BGR"&&(A=0,w=J,k=J*2);for(let I=0;I<J;I++,R+=V,Y+=V,z+=V,B+=V)X[k++]=(Q[R]+Z[0])/U[0],X[w++]=(Q[z]+Z[1])/U[1],X[A++]=(Q[Y]+Z[2])/U[2],D!==-1&&B!==-1&&(X[D++]=(Q[B]+Z[3])/U[3]);return G==="RGBA"?new j3("float32",X,[1,4,j,K]):new j3("float32",X,[1,3,j,K])},O2=async(Q,H)=>{let j=typeof HTMLImageElement<"u"&&Q instanceof HTMLImageElement,K=typeof ImageData<"u"&&Q instanceof ImageData,W=typeof ImageBitmap<"u"&&Q instanceof ImageBitmap,U=typeof Q=="string",Z,q=H??{},G=()=>{if(typeof document<"u")return document.createElement("canvas");if(typeof OffscreenCanvas<"u")return new OffscreenCanvas(1,1);throw new Error("Canvas is not supported")},J=(X)=>X instanceof HTMLCanvasElement||X instanceof OffscreenCanvas?X.getContext("2d"):null;if(j){let X=G();X.width=Q.width,X.height=Q.height;let V=J(X);if(V!=null){let{height:R,width:z}=Q;if(H!==void 0&&H.resizedHeight!==void 0&&H.resizedWidth!==void 0&&(R=H.resizedHeight,z=H.resizedWidth),H!==void 0){if(q=H,H.tensorFormat!==void 0)throw new Error("Image input config format must be RGBA for HTMLImageElement");q.tensorFormat="RGBA",q.height=R,q.width=z}else q.tensorFormat="RGBA",q.height=R,q.width=z;V.drawImage(Q,0,0),Z=V.getImageData(0,0,z,R).data}else throw new Error("Can not access image data")}else if(K){let X,V;if(H!==void 0&&H.resizedWidth!==void 0&&H.resizedHeight!==void 0?(X=H.resizedHeight,V=H.resizedWidth):(X=Q.height,V=Q.width),H!==void 0&&(q=H),q.format="RGBA",q.height=X,q.width=V,H!==void 0){let R=G();R.width=V,R.height=X;let z=J(R);if(z!=null)z.putImageData(Q,0,0),Z=z.getImageData(0,0,V,X).data;else throw new Error("Can not access image data")}else Z=Q.data}else if(W){if(H===void 0)throw new Error("Please provide image config with format for Imagebitmap");let X=G();X.width=Q.width,X.height=Q.height;let V=J(X);if(V!=null){let{height:R,width:z}=Q;return V.drawImage(Q,0,0,z,R),Z=V.getImageData(0,0,z,R).data,q.height=R,q.width=z,Z5(Z,q)}else throw new Error("Can not access image data")}else{if(U)return new Promise((X,V)=>{let R=G(),z=J(R);if(!Q||!z)return V();let Y=new Image;Y.crossOrigin="Anonymous",Y.src=Q,Y.onload=()=>{R.width=Y.width,R.height=Y.height,z.drawImage(Y,0,0,R.width,R.height);let B=z.getImageData(0,0,R.width,R.height);q.height=R.height,q.width=R.width,X(Z5(B.data,q))}});throw new Error("Input data provided is not supported - aborted tensor creation")}if(Z!==void 0)return Z5(Z,q);throw new Error("Input data provided is not supported - aborted tensor creation")},g2=(Q,H)=>{let{width:j,height:K,download:W,dispose:U}=H;return new j3({location:"texture",type:"float32",texture:Q,dims:[1,K,j,4],download:W,dispose:U})},y2=(Q,H)=>{let{dataType:j,dims:K,download:W,dispose:U}=H;return new j3({location:"gpu-buffer",type:j??"float32",gpuBuffer:Q,dims:K,download:W,dispose:U})},d2=(Q,H,j)=>new j3({location:"cpu-pinned",type:Q,data:H,dims:j??[H.length]})}),i3,I4,I5,p2,hZ=E(()=>{i3=new Map([["float32",Float32Array],["uint8",Uint8Array],["int8",Int8Array],["uint16",Uint16Array],["int16",Int16Array],["int32",Int32Array],["bool",Uint8Array],["float64",Float64Array],["uint32",Uint32Array]]),I4=new Map([[Float32Array,"float32"],[Uint8Array,"uint8"],[Int8Array,"int8"],[Uint16Array,"uint16"],[Int16Array,"int16"],[Int32Array,"int32"],[Float64Array,"float64"],[Uint32Array,"uint32"]]),I5=!1,p2=()=>{if(!I5){I5=!0;let Q=typeof BigInt64Array<"u"&&BigInt64Array.from,H=typeof BigUint64Array<"u"&&BigUint64Array.from,j=typeof Float16Array<"u"&&Float16Array.from;Q&&(i3.set("int64",BigInt64Array),I4.set(BigInt64Array,"int64")),H&&(i3.set("uint64",BigUint64Array),I4.set(BigUint64Array,"uint64")),j?(i3.set("float16",Float16Array),I4.set(Float16Array,"float16")):i3.set("float16",Uint16Array)}}}),h2,b2,bZ=E(()=>{Q7(),h2=(Q)=>{let H=1;for(let j=0;j<Q.length;j++){let K=Q[j];if(typeof K!="number"||!Number.isSafeInteger(K))throw new TypeError(`dims[${j}] must be an integer, got: ${K}`);if(K<0)throw new RangeError(`dims[${j}] must be a non-negative integer, got: ${K}`);H*=K}return H},b2=(Q,H)=>{switch(Q.location){case"cpu":return new j3(Q.type,Q.data,H);case"cpu-pinned":return new j3({location:"cpu-pinned",data:Q.data,type:Q.type,dims:H});case"texture":return new j3({location:"texture",texture:Q.texture,type:Q.type,dims:H});case"gpu-buffer":return new j3({location:"gpu-buffer",gpuBuffer:Q.gpuBuffer,type:Q.type,dims:H});default:throw new Error(`tensorReshape: tensor location ${Q.location} is not supported`)}}}),j3,Q7=E(()=>{dZ(),pZ(),hZ(),bZ(),j3=class{constructor(Q,H,j){p2();let K,W;if(typeof Q=="object"&&"location"in Q)switch(this.dataLocation=Q.location,K=Q.type,W=Q.dims,Q.location){case"cpu-pinned":{let Z=i3.get(K);if(!Z)throw new TypeError(`unsupported type "${K}" to create tensor from pinned buffer`);if(!(Q.data instanceof Z))throw new TypeError(`buffer should be of type ${Z.name}`);this.cpuData=Q.data;break}case"texture":{if(K!=="float32")throw new TypeError(`unsupported type "${K}" to create tensor from texture`);this.gpuTextureData=Q.texture,this.downloader=Q.download,this.disposer=Q.dispose;break}case"gpu-buffer":{if(K!=="float32"&&K!=="float16"&&K!=="int32"&&K!=="int64"&&K!=="uint32"&&K!=="uint8"&&K!=="bool")throw new TypeError(`unsupported type "${K}" to create tensor from gpu buffer`);this.gpuBufferData=Q.gpuBuffer,this.downloader=Q.download,this.disposer=Q.dispose;break}default:throw new Error(`Tensor constructor: unsupported location '${this.dataLocation}'`)}else{let Z,q;if(typeof Q=="string")if(K=Q,q=j,Q==="string"){if(!Array.isArray(H))throw new TypeError("A string tensor's data must be a string array.");Z=H}else{let G=i3.get(Q);if(G===void 0)throw new TypeError(`Unsupported tensor type: ${Q}.`);if(Array.isArray(H)){if(Q==="float16"&&G===Uint16Array)throw new TypeError("Creating a float16 tensor from number array is not supported. Please use Uint16Array as data.");Q==="uint64"||Q==="int64"?Z=G.from(H,BigInt):Z=G.from(H)}else if(H instanceof G)Z=H;else throw new TypeError(`A ${K} tensor's data must be type of ${G}`)}else if(q=H,Array.isArray(Q)){if(Q.length===0)throw new TypeError("Tensor type cannot be inferred from an empty array.");let G=typeof Q[0];if(G==="string")K="string",Z=Q;else if(G==="boolean")K="bool",Z=Uint8Array.from(Q);else throw new TypeError(`Invalid element type of data array: ${G}.`)}else{let G=I4.get(Q.constructor);if(G===void 0)throw new TypeError(`Unsupported type for tensor data: ${Q.constructor}.`);K=G,Z=Q}if(q===void 0)q=[Z.length];else if(!Array.isArray(q))throw new TypeError("A tensor's dims must be a number array");W=q,this.cpuData=Z,this.dataLocation="cpu"}let U=h2(W);if(this.cpuData&&U!==this.cpuData.length)throw new Error(`Tensor's size(${U}) does not match data length(${this.cpuData.length}).`);this.type=K,this.dims=W,this.size=U}static async fromImage(Q,H){return O2(Q,H)}static fromTexture(Q,H){return g2(Q,H)}static fromGpuBuffer(Q,H){return y2(Q,H)}static fromPinnedBuffer(Q,H,j){return d2(Q,H,j)}toDataURL(Q){return I2(this,Q)}toImageData(Q){return x2(this,Q)}get data(){if(this.ensureValid(),!this.cpuData)throw new Error("The data is not on CPU. Use `getData()` to download GPU data to CPU, or use `texture` or `gpuBuffer` property to access the GPU data directly.");return this.cpuData}get location(){return this.dataLocation}get texture(){if(this.ensureValid(),!this.gpuTextureData)throw new Error("The data is not stored as a WebGL texture.");return this.gpuTextureData}get gpuBuffer(){if(this.ensureValid(),!this.gpuBufferData)throw new Error("The data is not stored as a WebGPU buffer.");return this.gpuBufferData}async getData(Q){switch(this.ensureValid(),this.dataLocation){case"cpu":case"cpu-pinned":return this.data;case"texture":case"gpu-buffer":{if(!this.downloader)throw new Error("The current tensor is not created with a specified data downloader.");if(this.isDownloading)throw new Error("The current tensor is being downloaded.");try{this.isDownloading=!0;let H=await this.downloader();return this.downloader=void 0,this.dataLocation="cpu",this.cpuData=H,Q&&this.disposer&&(this.disposer(),this.disposer=void 0),H}finally{this.isDownloading=!1}}default:throw new Error(`cannot get data from location: ${this.dataLocation}`)}}dispose(){if(this.isDownloading)throw new Error("The current tensor is being downloaded.");this.disposer&&(this.disposer(),this.disposer=void 0),this.cpuData=void 0,this.gpuTextureData=void 0,this.gpuBufferData=void 0,this.downloader=void 0,this.isDownloading=void 0,this.dataLocation="none"}ensureValid(){if(this.dataLocation==="none")throw new Error("The tensor is disposed.")}reshape(Q){if(this.ensureValid(),this.downloader||this.disposer)throw new Error("Cannot reshape a tensor that owns GPU resource.");return b2(this,Q)}}}),d1,J7=E(()=>{Q7(),d1=j3}),Y6,x5,j4,V4,m2=E(()=>{E2(),Y6=(Q,H)=>{(typeof r1.trace>"u"?!r1.wasm.trace:!r1.trace)||console.timeStamp(`${Q}::ORT::${H}`)},x5=(Q,H)=>{let j=new Error().stack?.split(/\r\n|\r|\n/g)||[],K=!1;for(let W=0;W<j.length;W++){if(K&&!j[W].includes("TRACE_FUNC")){let U=`FUNC_${Q}::${j[W].trim().split(" ")[1]}`;H&&(U+=`::${H}`),Y6("CPU",U);return}j[W].includes("TRACE_FUNC")&&(K=!0)}},j4=(Q)=>{(typeof r1.trace>"u"?!r1.wasm.trace:!r1.trace)||x5("BEGIN",Q)},V4=(Q)=>{(typeof r1.trace>"u"?!r1.wasm.trace:!r1.trace)||x5("END",Q)}}),c2,mZ=E(()=>{e6(),J7(),m2(),c2=class Q{constructor(H){this.handler=H}async run(H,j,K){j4();let W={},U={};if(typeof H!="object"||H===null||H instanceof d1||Array.isArray(H))throw new TypeError("'feeds' must be an object that use input names as keys and OnnxValue as corresponding values.");let Z=!0;if(typeof j=="object"){if(j===null)throw new TypeError("Unexpected argument[1]: cannot be null.");if(j instanceof d1)throw new TypeError("'fetches' cannot be a Tensor");if(Array.isArray(j)){if(j.length===0)throw new TypeError("'fetches' cannot be an empty array.");Z=!1;for(let J of j){if(typeof J!="string")throw new TypeError("'fetches' must be a string array or an object.");if(this.outputNames.indexOf(J)===-1)throw new RangeError(`'fetches' contains invalid output name: ${J}.`);W[J]=null}if(typeof K=="object"&&K!==null)U=K;else if(typeof K<"u")throw new TypeError("'options' must be an object.")}else{let J=!1,X=Object.getOwnPropertyNames(j);for(let V of this.outputNames)if(X.indexOf(V)!==-1){let R=j[V];(R===null||R instanceof d1)&&(J=!0,Z=!1,W[V]=R)}if(J){if(typeof K=="object"&&K!==null)U=K;else if(typeof K<"u")throw new TypeError("'options' must be an object.")}else U=j}}else if(typeof j<"u")throw new TypeError("Unexpected argument[1]: must be 'fetches' or 'options'.");for(let J of this.inputNames)if(typeof H[J]>"u")throw new Error(`input '${J}' is missing in 'feeds'.`);if(Z)for(let J of this.outputNames)W[J]=null;let q=await this.handler.run(H,W,U),G={};for(let J in q)if(Object.hasOwnProperty.call(q,J)){let X=q[J];X instanceof d1?G[J]=X:G[J]=new d1(X.type,X.data,X.dims)}return V4(),G}async release(){return this.handler.dispose()}static async create(H,j,K,W){j4();let U,Z={};if(typeof H=="string"){if(U=H,typeof j=="object"&&j!==null)Z=j;else if(typeof j<"u")throw new TypeError("'options' must be an object.")}else if(H instanceof Uint8Array){if(U=H,typeof j=="object"&&j!==null)Z=j;else if(typeof j<"u")throw new TypeError("'options' must be an object.")}else if(H instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&H instanceof SharedArrayBuffer){let X=H,V=0,R=H.byteLength;if(typeof j=="object"&&j!==null)Z=j;else if(typeof j=="number"){if(V=j,!Number.isSafeInteger(V))throw new RangeError("'byteOffset' must be an integer.");if(V<0||V>=X.byteLength)throw new RangeError(`'byteOffset' is out of range [0, ${X.byteLength}).`);if(R=H.byteLength-V,typeof K=="number"){if(R=K,!Number.isSafeInteger(R))throw new RangeError("'byteLength' must be an integer.");if(R<=0||V+R>X.byteLength)throw new RangeError(`'byteLength' is out of range (0, ${X.byteLength-V}].`);if(typeof W=="object"&&W!==null)Z=W;else if(typeof W<"u")throw new TypeError("'options' must be an object.")}else if(typeof K<"u")throw new TypeError("'byteLength' must be a number.")}else if(typeof j<"u")throw new TypeError("'options' must be an object.");U=new Uint8Array(X,V,R)}else throw new TypeError("Unexpected argument[0]: must be 'path' or 'buffer'.");let[q,G]=await t6(Z),J=await q.createInferenceSessionHandler(U,G);return V4(),new Q(J)}startProfiling(){this.handler.startProfiling()}endProfiling(){this.handler.endProfiling()}get inputNames(){return this.handler.inputNames}get outputNames(){return this.handler.outputNames}}}),f2,cZ=E(()=>{mZ(),f2=c2}),fZ=E(()=>{}),lZ=E(()=>{}),uZ=E(()=>{}),sZ=E(()=>{}),n7,l2,iZ=E(()=>{e6(),J7(),n7="Training backend could not be resolved. Make sure you're using the correct configuration & WebAssembly files.",l2=class Q{constructor(H,j,K){this.handler=H,this.hasOptimizerModel=j,this.hasEvalModel=K}get trainingInputNames(){return this.handler.inputNames}get trainingOutputNames(){return this.handler.outputNames}get evalInputNames(){if(this.hasEvalModel)return this.handler.evalInputNames;throw new Error("This training session has no evalModel loaded.")}get evalOutputNames(){if(this.hasEvalModel)return this.handler.evalOutputNames;throw new Error("This training session has no evalModel loaded.")}static async create(H,j){let K=H.evalModel||"",W=H.optimizerModel||"",U=j||{},[Z,q]=await t6(U);if(Z.createTrainingSessionHandler){let G=await Z.createTrainingSessionHandler(H.checkpointState,H.trainModel,K,W,q);return new Q(G,!!H.optimizerModel,!!H.evalModel)}else throw new Error(n7)}typeNarrowingForRunStep(H,j,K,W,U){let Z={},q={};if(typeof K!="object"||K===null||K instanceof d1||Array.isArray(K))throw new TypeError("'feeds' must be an object that use input names as keys and OnnxValue as corresponding values.");let G=!0;if(typeof W=="object"){if(W===null)throw new TypeError("Unexpected argument[1]: cannot be null.");if(W instanceof d1)throw new TypeError("'fetches' cannot be a Tensor");if(Array.isArray(W)){if(W.length===0)throw new TypeError("'fetches' cannot be an empty array.");G=!1;for(let J of W){if(typeof J!="string")throw new TypeError("'fetches' must be a string array or an object.");if(j.indexOf(J)===-1)throw new RangeError(`'fetches' contains invalid output name: ${J}.`);Z[J]=null}if(typeof U=="object"&&U!==null)q=U;else if(typeof U<"u")throw new TypeError("'options' must be an object.")}else{let J=!1,X=Object.getOwnPropertyNames(W);for(let V of j)if(X.indexOf(V)!==-1){let R=W[V];(R===null||R instanceof d1)&&(J=!0,G=!1,Z[V]=R)}if(J){if(typeof U=="object"&&U!==null)q=U;else if(typeof U<"u")throw new TypeError("'options' must be an object.")}else q=W}}else if(typeof W<"u")throw new TypeError("Unexpected argument[1]: must be 'fetches' or 'options'.");for(let J of H)if(typeof K[J]>"u")throw new Error(`input '${J}' is missing in 'feeds'.`);if(G)for(let J of j)Z[J]=null;return[Z,q]}convertHandlerReturnTypeToMapOfTensors(H){let j={};for(let K in H)if(Object.hasOwnProperty.call(H,K)){let W=H[K];W instanceof d1?j[K]=W:j[K]=new d1(W.type,W.data,W.dims)}return j}async lazyResetGrad(){await this.handler.lazyResetGrad()}async runTrainStep(H,j,K){let[W,U]=this.typeNarrowingForRunStep(this.trainingInputNames,this.trainingOutputNames,H,j,K),Z=await this.handler.runTrainStep(H,W,U);return this.convertHandlerReturnTypeToMapOfTensors(Z)}async runOptimizerStep(H){if(this.hasOptimizerModel)await this.handler.runOptimizerStep(H||{});else throw new Error("This TrainingSession has no OptimizerModel loaded.")}async runEvalStep(H,j,K){if(this.hasEvalModel){let[W,U]=this.typeNarrowingForRunStep(this.evalInputNames,this.evalOutputNames,H,j,K),Z=await this.handler.runEvalStep(H,W,U);return this.convertHandlerReturnTypeToMapOfTensors(Z)}else throw new Error("This TrainingSession has no EvalModel loaded.")}async getParametersSize(H=!0){return this.handler.getParametersSize(H)}async loadParametersBuffer(H,j=!0){let K=await this.getParametersSize(j);if(H.length!==4*K)throw new Error("Size of the buffer passed into loadParametersBuffer must match the number of parameters in the model. Please use getParametersSize method to check.");return this.handler.loadParametersBuffer(H,j)}async getContiguousParameters(H=!0){return this.handler.getContiguousParameters(H)}async release(){return this.handler.dispose()}}}),u2,oZ=E(()=>{iZ(),u2=l2}),s2={};X4(s2,{InferenceSession:()=>f2,TRACE:()=>Y6,TRACE_FUNC_BEGIN:()=>j4,TRACE_FUNC_END:()=>V4,Tensor:()=>d1,TrainingSession:()=>u2,env:()=>i,registerBackend:()=>p4});var z3=E(()=>{OZ(),yZ(),cZ(),J7(),fZ(),lZ(),m2(),uZ(),sZ(),oZ()}),r7,t7,C6,i2,O5,J4,C1,g5,y5,o2,S4,V3=E(()=>{r7=class{log(Q,H,j){}},t7=class{log(Q,H,j){console.log(`${this.color(Q)} ${j?"\x1B[35m"+j+"\x1B[0m ":""}${H}`)}color(Q){switch(Q){case"verbose":return"\x1B[34;40mv\x1B[0m";case"info":return"\x1B[32mi\x1B[0m";case"warning":return"\x1B[30;43mw\x1B[0m";case"error":return"\x1B[31;40me\x1B[0m";case"fatal":return"\x1B[101mf\x1B[0m";default:throw new Error(`unsupported severity: ${Q}`)}}},C6={verbose:1000,info:2000,warning:4000,error:5000,fatal:6000},i2={none:new r7,console:new t7},O5={provider:"console",minimalSeverity:"warning",logDateTime:!0,logSourceLocation:!1},J4={"":O5},((Q)=>{function H(J,X){Q("verbose",J,X)}Q.verbose=H;function j(J,X){Q("info",J,X)}Q.info=j;function K(J,X){Q("warning",J,X)}Q.warning=K;function W(J,X){Q("error",J,X)}Q.error=W;function U(J,X){Q("fatal",J,X)}Q.fatal=U;function Z(J){J4={},q("",J||{})}Q.reset=Z;function q(J,X){if(J==="*")Z(X);else{let V=J4[J]||O5;J4[J]={provider:X.provider||V.provider,minimalSeverity:X.minimalSeverity||V.minimalSeverity,logDateTime:X.logDateTime===void 0?V.logDateTime:X.logDateTime,logSourceLocation:X.logSourceLocation===void 0?V.logSourceLocation:X.logSourceLocation}}}Q.set=q;function G(J){let X={};J.logLevel&&(X.minimalSeverity=J.logLevel),q("",X)}Q.setWithEnv=G})(s3||={}),C1=s3,g5=class{constructor(Q,H,j,K,W,U){this.category=Q,this.name=H,this.startTime=j,this.endCallback=K,this.timer=W,this.ctx=U}async end(){return this.endCallback(this)}async checkTimer(){if(this.ctx===void 0||this.timer===void 0)throw new Error("No webgl timer found");return this.ctx.endTimer(),this.ctx.waitForQueryAndGetTime(this.timer)}},y5=class{constructor(Q,H,j,K){this.category=Q,this.name=H,this.startTime=j,this.endTime=K}},o2=class{constructor(Q,H,j){this._started=!1,this._flushPointer=0,this._started=!1,this._maxNumberEvents=Q===void 0?1e4:Q,this._flushBatchSize=H===void 0?10:H,this._flushIntervalInMilliseconds=j===void 0?5000:j}static create(Q){return Q===void 0?new this:new this(Q.maxNumberEvents,Q.flushBatchSize,Q.flushIntervalInMilliseconds)}start(){this._started=!0,this._timingEvents=[],this._flushTime=S4(),this._flushPointer=0}stop(){for(this._started=!1;this._flushPointer<this._timingEvents.length;this._flushPointer++)this.logOneEvent(this._timingEvents[this._flushPointer])}event(Q,H,j,K){let W=this._started?this.begin(Q,H,K):void 0,U=!1,Z=j();if(Z&&typeof Z.then=="function")return U=!0,new Promise((q,G)=>{Z.then(async(J)=>{W&&await W.end(),q(J)},async(J)=>{W&&await W.end(),G(J)})});if(!U&&W){let q=W.end();if(q&&typeof q.then=="function")return new Promise((G,J)=>{q.then(()=>{G(Z)},(X)=>{J(X)})})}return Z}begin(Q,H,j){if(!this._started)throw new Error("profiler is not started yet");if(j===void 0){let K=S4();return this.flush(K),new g5(Q,H,K,(W)=>this.endSync(W))}else{let K=j.beginTimer();return new g5(Q,H,0,async(W)=>this.end(W),K,j)}}async end(Q){let H=await Q.checkTimer();this._timingEvents.length<this._maxNumberEvents&&(this._timingEvents.push(new y5(Q.category,Q.name,Q.startTime,H)),this.flush(H))}endSync(Q){let H=S4();this._timingEvents.length<this._maxNumberEvents&&(this._timingEvents.push(new y5(Q.category,Q.name,Q.startTime,H)),this.flush(H))}logOneEvent(Q){C1.verbose(`Profiler.${Q.category}`,`${(Q.endTime-Q.startTime).toFixed(2)}ms on event '${Q.name}' at ${Q.endTime.toFixed(2)}`)}flush(Q){if(this._timingEvents.length-this._flushPointer>=this._flushBatchSize||Q-this._flushTime>=this._flushIntervalInMilliseconds){for(let H=this._flushPointer;this._flushPointer<H+this._flushBatchSize&&this._flushPointer<this._timingEvents.length;this._flushPointer++)this.logOneEvent(this._timingEvents[this._flushPointer]);this._flushTime=S4()}}get started(){return this._started}},S4=typeof performance<"u"&&performance.now?()=>performance.now():Date.now}),aZ=E(()=>{}),nZ=U1((Q)=>{Q.__esModule=!0;var H=function(){function j(K){if(!K)throw new TypeError("Invalid argument; `value` has no value.");this.value=j.EMPTY,K&&j.isGuid(K)&&(this.value=K)}return j.isGuid=function(K){var W=K.toString();return K&&(K instanceof j||j.validator.test(W))},j.create=function(){return new j([j.gen(2),j.gen(1),j.gen(1),j.gen(1),j.gen(3)].join("-"))},j.createEmpty=function(){return new j("emptyguid")},j.parse=function(K){return new j(K)},j.raw=function(){return[j.gen(2),j.gen(1),j.gen(1),j.gen(1),j.gen(3)].join("-")},j.gen=function(K){for(var W="",U=0;U<K;U++)W+=((1+Math.random())*65536|0).toString(16).substring(1);return W},j.prototype.equals=function(K){return j.isGuid(K)&&this.value===K.toString()},j.prototype.isEmpty=function(){return this.value===j.EMPTY},j.prototype.toString=function(){return this.value},j.prototype.toJSON=function(){return{value:this.value}},j.validator=new RegExp("^[a-z0-9]{8}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{12}$","i"),j.EMPTY="00000000-0000-0000-0000-000000000000",j}();Q.Guid=H}),l1,B6,F6,O4,d5,e7,o3,k6,A6,p5,t1,W3,m3,h5,j5,S6,$6,y1,O,_3,a2=E(()=>{l1=null;try{l1=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{}X1.prototype.__isLong__,Object.defineProperty(X1.prototype,"__isLong__",{value:!0}),X1.isLong=I1,B6={},F6={},X1.fromInt=b3,X1.fromNumber=e1,X1.fromBits=e,O4=Math.pow,X1.fromString=a6,X1.fromValue=Z3,d5=65536,e7=1<<24,o3=d5*d5,k6=o3*o3,A6=k6/2,p5=b3(e7),t1=b3(0),X1.ZERO=t1,W3=b3(0,!0),X1.UZERO=W3,m3=b3(1),X1.ONE=m3,h5=b3(1,!0),X1.UONE=h5,j5=b3(-1),X1.NEG_ONE=j5,S6=e(-1,2147483647,!1),X1.MAX_VALUE=S6,$6=e(-1,-1,!0),X1.MAX_UNSIGNED_VALUE=$6,y1=e(0,-2147483648,!1),X1.MIN_VALUE=y1,O=X1.prototype,O.toInt=function(){return this.unsigned?this.low>>>0:this.low},O.toNumber=function(){return this.unsigned?(this.high>>>0)*o3+(this.low>>>0):this.high*o3+(this.low>>>0)},O.toString=function(Q){if(Q=Q||10,Q<2||36<Q)throw RangeError("radix");if(this.isZero())return"0";if(this.isNegative())if(this.eq(y1)){var H=e1(Q),j=this.div(H),K=j.mul(H).sub(this);return j.toString(Q)+K.toInt().toString(Q)}else return"-"+this.neg().toString(Q);for(var W=e1(O4(Q,6),this.unsigned),U=this,Z="";;){var q=U.div(W),G=U.sub(q.mul(W)).toInt()>>>0,J=G.toString(Q);if(U=q,U.isZero())return J+Z;for(;J.length<6;)J="0"+J;Z=""+J+Z}},O.getHighBits=function(){return this.high},O.getHighBitsUnsigned=function(){return this.high>>>0},O.getLowBits=function(){return this.low},O.getLowBitsUnsigned=function(){return this.low>>>0},O.getNumBitsAbs=function(){if(this.isNegative())return this.eq(y1)?64:this.neg().getNumBitsAbs();for(var Q=this.high!=0?this.high:this.low,H=31;H>0&&!(Q&1<<H);H--);return this.high!=0?H+33:H+1},O.isZero=function(){return this.high===0&&this.low===0},O.eqz=O.isZero,O.isNegative=function(){return!this.unsigned&&this.high<0},O.isPositive=function(){return this.unsigned||this.high>=0},O.isOdd=function(){return(this.low&1)===1},O.isEven=function(){return(this.low&1)===0},O.equals=function(Q){return I1(Q)||(Q=Z3(Q)),this.unsigned!==Q.unsigned&&this.high>>>31===1&&Q.high>>>31===1?!1:this.high===Q.high&&this.low===Q.low},O.eq=O.equals,O.notEquals=function(Q){return!this.eq(Q)},O.neq=O.notEquals,O.ne=O.notEquals,O.lessThan=function(Q){return this.comp(Q)<0},O.lt=O.lessThan,O.lessThanOrEqual=function(Q){return this.comp(Q)<=0},O.lte=O.lessThanOrEqual,O.le=O.lessThanOrEqual,O.greaterThan=function(Q){return this.comp(Q)>0},O.gt=O.greaterThan,O.greaterThanOrEqual=function(Q){return this.comp(Q)>=0},O.gte=O.greaterThanOrEqual,O.ge=O.greaterThanOrEqual,O.compare=function(Q){if(I1(Q)||(Q=Z3(Q)),this.eq(Q))return 0;var H=this.isNegative(),j=Q.isNegative();return H&&!j?-1:!H&&j?1:this.unsigned?Q.high>>>0>this.high>>>0||Q.high===this.high&&Q.low>>>0>this.low>>>0?-1:1:this.sub(Q).isNegative()?-1:1},O.comp=O.compare,O.negate=function(){return!this.unsigned&&this.eq(y1)?y1:this.not().add(m3)},O.neg=O.negate,O.add=function(Q){I1(Q)||(Q=Z3(Q));var H=this.high>>>16,j=this.high&65535,K=this.low>>>16,W=this.low&65535,U=Q.high>>>16,Z=Q.high&65535,q=Q.low>>>16,G=Q.low&65535,J=0,X=0,V=0,R=0;return R+=W+G,V+=R>>>16,R&=65535,V+=K+q,X+=V>>>16,V&=65535,X+=j+Z,J+=X>>>16,X&=65535,J+=H+U,J&=65535,e(V<<16|R,J<<16|X,this.unsigned)},O.subtract=function(Q){return I1(Q)||(Q=Z3(Q)),this.add(Q.neg())},O.sub=O.subtract,O.multiply=function(Q){if(this.isZero())return this;if(I1(Q)||(Q=Z3(Q)),l1){var H=l1.mul(this.low,this.high,Q.low,Q.high);return e(H,l1.get_high(),this.unsigned)}if(Q.isZero())return this.unsigned?W3:t1;if(this.eq(y1))return Q.isOdd()?y1:t1;if(Q.eq(y1))return this.isOdd()?y1:t1;if(this.isNegative())return Q.isNegative()?this.neg().mul(Q.neg()):this.neg().mul(Q).neg();if(Q.isNegative())return this.mul(Q.neg()).neg();if(this.lt(p5)&&Q.lt(p5))return e1(this.toNumber()*Q.toNumber(),this.unsigned);var j=this.high>>>16,K=this.high&65535,W=this.low>>>16,U=this.low&65535,Z=Q.high>>>16,q=Q.high&65535,G=Q.low>>>16,J=Q.low&65535,X=0,V=0,R=0,z=0;return z+=U*J,R+=z>>>16,z&=65535,R+=W*J,V+=R>>>16,R&=65535,R+=U*G,V+=R>>>16,R&=65535,V+=K*J,X+=V>>>16,V&=65535,V+=W*G,X+=V>>>16,V&=65535,V+=U*q,X+=V>>>16,V&=65535,X+=j*J+K*G+W*q+U*Z,X&=65535,e(R<<16|z,X<<16|V,this.unsigned)},O.mul=O.multiply,O.divide=function(Q){if(I1(Q)||(Q=Z3(Q)),Q.isZero())throw Error("division by zero");if(l1){if(!this.unsigned&&this.high===-2147483648&&Q.low===-1&&Q.high===-1)return this;var H=(this.unsigned?l1.div_u:l1.div_s)(this.low,this.high,Q.low,Q.high);return e(H,l1.get_high(),this.unsigned)}if(this.isZero())return this.unsigned?W3:t1;var j,K,W;if(this.unsigned){if(Q.unsigned||(Q=Q.toUnsigned()),Q.gt(this))return W3;if(Q.gt(this.shru(1)))return h5;W=W3}else{if(this.eq(y1)){if(Q.eq(m3)||Q.eq(j5))return y1;if(Q.eq(y1))return m3;var U=this.shr(1);return j=U.div(Q).shl(1),j.eq(t1)?Q.isNegative()?m3:j5:(K=this.sub(Q.mul(j)),W=j.add(K.div(Q)),W)}else if(Q.eq(y1))return this.unsigned?W3:t1;if(this.isNegative())return Q.isNegative()?this.neg().div(Q.neg()):this.neg().div(Q).neg();if(Q.isNegative())return this.div(Q.neg()).neg();W=t1}for(K=this;K.gte(Q);){j=Math.max(1,Math.floor(K.toNumber()/Q.toNumber()));for(var Z=Math.ceil(Math.log(j)/Math.LN2),q=Z<=48?1:O4(2,Z-48),G=e1(j),J=G.mul(Q);J.isNegative()||J.gt(K);)j-=q,G=e1(j,this.unsigned),J=G.mul(Q);G.isZero()&&(G=m3),W=W.add(G),K=K.sub(J)}return W},O.div=O.divide,O.modulo=function(Q){if(I1(Q)||(Q=Z3(Q)),l1){var H=(this.unsigned?l1.rem_u:l1.rem_s)(this.low,this.high,Q.low,Q.high);return e(H,l1.get_high(),this.unsigned)}return this.sub(this.div(Q).mul(Q))},O.mod=O.modulo,O.rem=O.modulo,O.not=function(){return e(~this.low,~this.high,this.unsigned)},O.countLeadingZeros=function(){return this.high?Math.clz32(this.high):Math.clz32(this.low)+32},O.clz=O.countLeadingZeros,O.countTrailingZeros=function(){return this.low?c7(this.low):c7(this.high)+32},O.ctz=O.countTrailingZeros,O.and=function(Q){return I1(Q)||(Q=Z3(Q)),e(this.low&Q.low,this.high&Q.high,this.unsigned)},O.or=function(Q){return I1(Q)||(Q=Z3(Q)),e(this.low|Q.low,this.high|Q.high,this.unsigned)},O.xor=function(Q){return I1(Q)||(Q=Z3(Q)),e(this.low^Q.low,this.high^Q.high,this.unsigned)},O.shiftLeft=function(Q){return I1(Q)&&(Q=Q.toInt()),(Q&=63)===0?this:Q<32?e(this.low<<Q,this.high<<Q|this.low>>>32-Q,this.unsigned):e(0,this.low<<Q-32,this.unsigned)},O.shl=O.shiftLeft,O.shiftRight=function(Q){return I1(Q)&&(Q=Q.toInt()),(Q&=63)===0?this:Q<32?e(this.low>>>Q|this.high<<32-Q,this.high>>Q,this.unsigned):e(this.high>>Q-32,this.high>=0?0:-1,this.unsigned)},O.shr=O.shiftRight,O.shiftRightUnsigned=function(Q){return I1(Q)&&(Q=Q.toInt()),(Q&=63)===0?this:Q<32?e(this.low>>>Q|this.high<<32-Q,this.high>>>Q,this.unsigned):Q===32?e(this.high,0,this.unsigned):e(this.high>>>Q-32,0,this.unsigned)},O.shru=O.shiftRightUnsigned,O.shr_u=O.shiftRightUnsigned,O.rotateLeft=function(Q){var H;return I1(Q)&&(Q=Q.toInt()),(Q&=63)===0?this:Q===32?e(this.high,this.low,this.unsigned):Q<32?(H=32-Q,e(this.low<<Q|this.high>>>H,this.high<<Q|this.low>>>H,this.unsigned)):(Q-=32,H=32-Q,e(this.high<<Q|this.low>>>H,this.low<<Q|this.high>>>H,this.unsigned))},O.rotl=O.rotateLeft,O.rotateRight=function(Q){var H;return I1(Q)&&(Q=Q.toInt()),(Q&=63)===0?this:Q===32?e(this.high,this.low,this.unsigned):Q<32?(H=32-Q,e(this.high<<H|this.low>>>Q,this.low<<H|this.high>>>Q,this.unsigned)):(Q-=32,H=32-Q,e(this.low<<H|this.high>>>Q,this.high<<H|this.low>>>Q,this.unsigned))},O.rotr=O.rotateRight,O.toSigned=function(){return this.unsigned?e(this.low,this.high,!1):this},O.toUnsigned=function(){return this.unsigned?this:e(this.low,this.high,!0)},O.toBytes=function(Q){return Q?this.toBytesLE():this.toBytesBE()},O.toBytesLE=function(){var Q=this.high,H=this.low;return[H&255,H>>>8&255,H>>>16&255,H>>>24,Q&255,Q>>>8&255,Q>>>16&255,Q>>>24]},O.toBytesBE=function(){var Q=this.high,H=this.low;return[Q>>>24,Q>>>16&255,Q>>>8&255,Q&255,H>>>24,H>>>16&255,H>>>8&255,H&255]},X1.fromBytes=function(Q,H,j){return j?X1.fromBytesLE(Q,H):X1.fromBytesBE(Q,H)},X1.fromBytesLE=function(Q,H){return new X1(Q[0]|Q[1]<<8|Q[2]<<16|Q[3]<<24,Q[4]|Q[5]<<8|Q[6]<<16|Q[7]<<24,H)},X1.fromBytesBE=function(Q,H){return new X1(Q[4]<<24|Q[5]<<16|Q[6]<<8|Q[7],Q[0]<<24|Q[1]<<16|Q[2]<<8|Q[3],H)},_3=X1}),$,H7=E(()=>{$={},$.Offset,$.Table,$.SIZEOF_SHORT=2,$.SIZEOF_INT=4,$.FILE_IDENTIFIER_LENGTH=4,$.SIZE_PREFIX_LENGTH=4,$.Encoding={UTF8_BYTES:1,UTF16_STRING:2},$.int32=new Int32Array(2),$.float32=new Float32Array($.int32.buffer),$.float64=new Float64Array($.int32.buffer),$.isLittleEndian=new Uint16Array(new Uint8Array([1,0]).buffer)[0]===1,$.Long=function(Q,H){this.low=Q|0,this.high=H|0},$.Long.create=function(Q,H){return Q==0&&H==0?$.Long.ZERO:new $.Long(Q,H)},$.Long.prototype.toFloat64=function(){return(this.low>>>0)+this.high*4294967296},$.Long.prototype.equals=function(Q){return this.low==Q.low&&this.high==Q.high},$.Long.ZERO=new $.Long(0,0),$.Builder=function(Q){if(Q)var H=Q;else var H=1024;this.bb=$.ByteBuffer.allocate(H),this.space=H,this.minalign=1,this.vtable=null,this.vtable_in_use=0,this.isNested=!1,this.object_start=0,this.vtables=[],this.vector_num_elems=0,this.force_defaults=!1},$.Builder.prototype.clear=function(){this.bb.clear(),this.space=this.bb.capacity(),this.minalign=1,this.vtable=null,this.vtable_in_use=0,this.isNested=!1,this.object_start=0,this.vtables=[],this.vector_num_elems=0,this.force_defaults=!1},$.Builder.prototype.forceDefaults=function(Q){this.force_defaults=Q},$.Builder.prototype.dataBuffer=function(){return this.bb},$.Builder.prototype.asUint8Array=function(){return this.bb.bytes().subarray(this.bb.position(),this.bb.position()+this.offset())},$.Builder.prototype.prep=function(Q,H){Q>this.minalign&&(this.minalign=Q);for(var j=~(this.bb.capacity()-this.space+H)+1&Q-1;this.space<j+Q+H;){var K=this.bb.capacity();this.bb=$.Builder.growByteBuffer(this.bb),this.space+=this.bb.capacity()-K}this.pad(j)},$.Builder.prototype.pad=function(Q){for(var H=0;H<Q;H++)this.bb.writeInt8(--this.space,0)},$.Builder.prototype.writeInt8=function(Q){this.bb.writeInt8(this.space-=1,Q)},$.Builder.prototype.writeInt16=function(Q){this.bb.writeInt16(this.space-=2,Q)},$.Builder.prototype.writeInt32=function(Q){this.bb.writeInt32(this.space-=4,Q)},$.Builder.prototype.writeInt64=function(Q){this.bb.writeInt64(this.space-=8,Q)},$.Builder.prototype.writeFloat32=function(Q){this.bb.writeFloat32(this.space-=4,Q)},$.Builder.prototype.writeFloat64=function(Q){this.bb.writeFloat64(this.space-=8,Q)},$.Builder.prototype.addInt8=function(Q){this.prep(1,0),this.writeInt8(Q)},$.Builder.prototype.addInt16=function(Q){this.prep(2,0),this.writeInt16(Q)},$.Builder.prototype.addInt32=function(Q){this.prep(4,0),this.writeInt32(Q)},$.Builder.prototype.addInt64=function(Q){this.prep(8,0),this.writeInt64(Q)},$.Builder.prototype.addFloat32=function(Q){this.prep(4,0),this.writeFloat32(Q)},$.Builder.prototype.addFloat64=function(Q){this.prep(8,0),this.writeFloat64(Q)},$.Builder.prototype.addFieldInt8=function(Q,H,j){(this.force_defaults||H!=j)&&(this.addInt8(H),this.slot(Q))},$.Builder.prototype.addFieldInt16=function(Q,H,j){(this.force_defaults||H!=j)&&(this.addInt16(H),this.slot(Q))},$.Builder.prototype.addFieldInt32=function(Q,H,j){(this.force_defaults||H!=j)&&(this.addInt32(H),this.slot(Q))},$.Builder.prototype.addFieldInt64=function(Q,H,j){(this.force_defaults||!H.equals(j))&&(this.addInt64(H),this.slot(Q))},$.Builder.prototype.addFieldFloat32=function(Q,H,j){(this.force_defaults||H!=j)&&(this.addFloat32(H),this.slot(Q))},$.Builder.prototype.addFieldFloat64=function(Q,H,j){(this.force_defaults||H!=j)&&(this.addFloat64(H),this.slot(Q))},$.Builder.prototype.addFieldOffset=function(Q,H,j){(this.force_defaults||H!=j)&&(this.addOffset(H),this.slot(Q))},$.Builder.prototype.addFieldStruct=function(Q,H,j){H!=j&&(this.nested(H),this.slot(Q))},$.Builder.prototype.nested=function(Q){if(Q!=this.offset())throw new Error("FlatBuffers: struct must be serialized inline.")},$.Builder.prototype.notNested=function(){if(this.isNested)throw new Error("FlatBuffers: object serialization must not be nested.")},$.Builder.prototype.slot=function(Q){this.vtable[Q]=this.offset()},$.Builder.prototype.offset=function(){return this.bb.capacity()-this.space},$.Builder.growByteBuffer=function(Q){var H=Q.capacity();if(H&3221225472)throw new Error("FlatBuffers: cannot grow buffer beyond 2 gigabytes.");var j=H<<1,K=$.ByteBuffer.allocate(j);return K.setPosition(j-H),K.bytes().set(Q.bytes(),j-H),K},$.Builder.prototype.addOffset=function(Q){this.prep($.SIZEOF_INT,0),this.writeInt32(this.offset()-Q+$.SIZEOF_INT)},$.Builder.prototype.startObject=function(Q){this.notNested(),this.vtable==null&&(this.vtable=[]),this.vtable_in_use=Q;for(var H=0;H<Q;H++)this.vtable[H]=0;this.isNested=!0,this.object_start=this.offset()},$.Builder.prototype.endObject=function(){if(this.vtable==null||!this.isNested)throw new Error("FlatBuffers: endObject called without startObject");this.addInt32(0);for(var Q=this.offset(),H=this.vtable_in_use-1;H>=0&&this.vtable[H]==0;H--);for(var j=H+1;H>=0;H--)this.addInt16(this.vtable[H]!=0?Q-this.vtable[H]:0);var K=2;this.addInt16(Q-this.object_start);var W=(j+K)*$.SIZEOF_SHORT;this.addInt16(W);var U=0,Z=this.space;Q:for(H=0;H<this.vtables.length;H++){var q=this.bb.capacity()-this.vtables[H];if(W==this.bb.readInt16(q)){for(var G=$.SIZEOF_SHORT;G<W;G+=$.SIZEOF_SHORT)if(this.bb.readInt16(Z+G)!=this.bb.readInt16(q+G))continue Q;U=this.vtables[H];break}}return U?(this.space=this.bb.capacity()-Q,this.bb.writeInt32(this.space,U-Q)):(this.vtables.push(this.offset()),this.bb.writeInt32(this.bb.capacity()-Q,this.offset()-Q)),this.isNested=!1,Q},$.Builder.prototype.finish=function(Q,H,j){var K=j?$.SIZE_PREFIX_LENGTH:0;if(H){var W=H;if(this.prep(this.minalign,$.SIZEOF_INT+$.FILE_IDENTIFIER_LENGTH+K),W.length!=$.FILE_IDENTIFIER_LENGTH)throw new Error("FlatBuffers: file identifier must be length "+$.FILE_IDENTIFIER_LENGTH);for(var U=$.FILE_IDENTIFIER_LENGTH-1;U>=0;U--)this.writeInt8(W.charCodeAt(U))}this.prep(this.minalign,$.SIZEOF_INT+K),this.addOffset(Q),K&&this.addInt32(this.bb.capacity()-this.space),this.bb.setPosition(this.space)},$.Builder.prototype.finishSizePrefixed=function(Q,H){this.finish(Q,H,!0)},$.Builder.prototype.requiredField=function(Q,H){var j=this.bb.capacity()-Q,K=j-this.bb.readInt32(j),W=this.bb.readInt16(K+H)!=0;if(!W)throw new Error("FlatBuffers: field "+H+" must be set")},$.Builder.prototype.startVector=function(Q,H,j){this.notNested(),this.vector_num_elems=H,this.prep($.SIZEOF_INT,Q*H),this.prep(j,Q*H)},$.Builder.prototype.endVector=function(){return this.writeInt32(this.vector_num_elems),this.offset()},$.Builder.prototype.createString=function(Q){if(Q instanceof Uint8Array)var H=Q;else for(var H=[],j=0;j<Q.length;){var K,W=Q.charCodeAt(j++);if(W<55296||W>=56320)K=W;else{var U=Q.charCodeAt(j++);K=(W<<10)+U+-56613888}K<128?H.push(K):(K<2048?H.push(K>>6&31|192):(K<65536?H.push(K>>12&15|224):H.push(K>>18&7|240,K>>12&63|128),H.push(K>>6&63|128)),H.push(K&63|128))}this.addInt8(0),this.startVector(1,H.length,1),this.bb.setPosition(this.space-=H.length);for(var j=0,Z=this.space,q=this.bb.bytes();j<H.length;j++)q[Z++]=H[j];return this.endVector()},$.Builder.prototype.createLong=function(Q,H){return $.Long.create(Q,H)},$.ByteBuffer=function(Q){this.bytes_=Q,this.position_=0},$.ByteBuffer.allocate=function(Q){return new $.ByteBuffer(new Uint8Array(Q))},$.ByteBuffer.prototype.clear=function(){this.position_=0},$.ByteBuffer.prototype.bytes=function(){return this.bytes_},$.ByteBuffer.prototype.position=function(){return this.position_},$.ByteBuffer.prototype.setPosition=function(Q){this.position_=Q},$.ByteBuffer.prototype.capacity=function(){return this.bytes_.length},$.ByteBuffer.prototype.readInt8=function(Q){return this.readUint8(Q)<<24>>24},$.ByteBuffer.prototype.readUint8=function(Q){return this.bytes_[Q]},$.ByteBuffer.prototype.readInt16=function(Q){return this.readUint16(Q)<<16>>16},$.ByteBuffer.prototype.readUint16=function(Q){return this.bytes_[Q]|this.bytes_[Q+1]<<8},$.ByteBuffer.prototype.readInt32=function(Q){return this.bytes_[Q]|this.bytes_[Q+1]<<8|this.bytes_[Q+2]<<16|this.bytes_[Q+3]<<24},$.ByteBuffer.prototype.readUint32=function(Q){return this.readInt32(Q)>>>0},$.ByteBuffer.prototype.readInt64=function(Q){return new $.Long(this.readInt32(Q),this.readInt32(Q+4))},$.ByteBuffer.prototype.readUint64=function(Q){return new $.Long(this.readUint32(Q),this.readUint32(Q+4))},$.ByteBuffer.prototype.readFloat32=function(Q){return $.int32[0]=this.readInt32(Q),$.float32[0]},$.ByteBuffer.prototype.readFloat64=function(Q){return $.int32[$.isLittleEndian?0:1]=this.readInt32(Q),$.int32[$.isLittleEndian?1:0]=this.readInt32(Q+4),$.float64[0]},$.ByteBuffer.prototype.writeInt8=function(Q,H){this.bytes_[Q]=H},$.ByteBuffer.prototype.writeUint8=function(Q,H){this.bytes_[Q]=H},$.ByteBuffer.prototype.writeInt16=function(Q,H){this.bytes_[Q]=H,this.bytes_[Q+1]=H>>8},$.ByteBuffer.prototype.writeUint16=function(Q,H){this.bytes_[Q]=H,this.bytes_[Q+1]=H>>8},$.ByteBuffer.prototype.writeInt32=function(Q,H){this.bytes_[Q]=H,this.bytes_[Q+1]=H>>8,this.bytes_[Q+2]=H>>16,this.bytes_[Q+3]=H>>24},$.ByteBuffer.prototype.writeUint32=function(Q,H){this.bytes_[Q]=H,this.bytes_[Q+1]=H>>8,this.bytes_[Q+2]=H>>16,this.bytes_[Q+3]=H>>24},$.ByteBuffer.prototype.writeInt64=function(Q,H){this.writeInt32(Q,H.low),this.writeInt32(Q+4,H.high)},$.ByteBuffer.prototype.writeUint64=function(Q,H){this.writeUint32(Q,H.low),this.writeUint32(Q+4,H.high)},$.ByteBuffer.prototype.writeFloat32=function(Q,H){$.float32[0]=H,this.writeInt32(Q,$.int32[0])},$.ByteBuffer.prototype.writeFloat64=function(Q,H){$.float64[0]=H,this.writeInt32(Q,$.int32[$.isLittleEndian?0:1]),this.writeInt32(Q+4,$.int32[$.isLittleEndian?1:0])},$.ByteBuffer.prototype.getBufferIdentifier=function(){if(this.bytes_.length<this.position_+$.SIZEOF_INT+$.FILE_IDENTIFIER_LENGTH)throw new Error("FlatBuffers: ByteBuffer is too short to contain an identifier.");for(var Q="",H=0;H<$.FILE_IDENTIFIER_LENGTH;H++)Q+=String.fromCharCode(this.readInt8(this.position_+$.SIZEOF_INT+H));return Q},$.ByteBuffer.prototype.__offset=function(Q,H){var j=Q-this.readInt32(Q);return H<this.readInt16(j)?this.readInt16(j+H):0},$.ByteBuffer.prototype.__union=function(Q,H){return Q.bb_pos=H+this.readInt32(H),Q.bb=this,Q},$.ByteBuffer.prototype.__string=function(Q,H){Q+=this.readInt32(Q);var j=this.readInt32(Q),K="",W=0;if(Q+=$.SIZEOF_INT,H===$.Encoding.UTF8_BYTES)return this.bytes_.subarray(Q,Q+j);for(;W<j;){var U,Z=this.readUint8(Q+W++);if(Z<192)U=Z;else{var q=this.readUint8(Q+W++);if(Z<224)U=(Z&31)<<6|q&63;else{var G=this.readUint8(Q+W++);if(Z<240)U=(Z&15)<<12|(q&63)<<6|G&63;else{var J=this.readUint8(Q+W++);U=(Z&7)<<18|(q&63)<<12|(G&63)<<6|J&63}}}U<65536?K+=String.fromCharCode(U):(U-=65536,K+=String.fromCharCode((U>>10)+55296,(U&1023)+56320))}return K},$.ByteBuffer.prototype.__indirect=function(Q){return Q+this.readInt32(Q)},$.ByteBuffer.prototype.__vector=function(Q){return Q+this.readInt32(Q)+$.SIZEOF_INT},$.ByteBuffer.prototype.__vector_len=function(Q){return this.readInt32(Q+this.readInt32(Q))},$.ByteBuffer.prototype.__has_identifier=function(Q){if(Q.length!=$.FILE_IDENTIFIER_LENGTH)throw new Error("FlatBuffers: file identifier must be length "+$.FILE_IDENTIFIER_LENGTH);for(var H=0;H<$.FILE_IDENTIFIER_LENGTH;H++)if(Q.charCodeAt(H)!=this.readInt8(this.position_+$.SIZEOF_INT+H))return!1;return!0},$.ByteBuffer.prototype.createLong=function(Q,H){return $.Long.create(Q,H)}}),H1,B5=E(()=>{H7(),((Q)=>{let H;((j)=>{let K;((W)=>{let U;((Z)=>(Z[Z.UNDEFINED=0]="UNDEFINED",Z[Z.FLOAT=1]="FLOAT",Z[Z.INT=2]="INT",Z[Z.STRING=3]="STRING",Z[Z.TENSOR=4]="TENSOR",Z[Z.GRAPH=5]="GRAPH",Z[Z.FLOATS=6]="FLOATS",Z[Z.INTS=7]="INTS",Z[Z.STRINGS=8]="STRINGS",Z[Z.TENSORS=9]="TENSORS",Z[Z.GRAPHS=10]="GRAPHS",Z[Z.SPARSE_TENSOR=11]="SPARSE_TENSOR",Z[Z.SPARSE_TENSORS=12]="SPARSE_TENSORS"))(U=W.AttributeType||={})})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{let U;((Z)=>(Z[Z.UNKNOWN=0]="UNKNOWN",Z[Z.VALUE=1]="VALUE",Z[Z.PARAM=2]="PARAM"))(U=W.DimensionValueType||={})})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{let U;((Z)=>(Z[Z.UNDEFINED=0]="UNDEFINED",Z[Z.FLOAT=1]="FLOAT",Z[Z.UINT8=2]="UINT8",Z[Z.INT8=3]="INT8",Z[Z.UINT16=4]="UINT16",Z[Z.INT16=5]="INT16",Z[Z.INT32=6]="INT32",Z[Z.INT64=7]="INT64",Z[Z.STRING=8]="STRING",Z[Z.BOOL=9]="BOOL",Z[Z.FLOAT16=10]="FLOAT16",Z[Z.DOUBLE=11]="DOUBLE",Z[Z.UINT32=12]="UINT32",Z[Z.UINT64=13]="UINT64",Z[Z.COMPLEX64=14]="COMPLEX64",Z[Z.COMPLEX128=15]="COMPLEX128",Z[Z.BFLOAT16=16]="BFLOAT16",Z[Z.FLOAT8E4M3FN=17]="FLOAT8E4M3FN",Z[Z.FLOAT8E4M3FNUZ=18]="FLOAT8E4M3FNUZ",Z[Z.FLOAT8E5M2=19]="FLOAT8E5M2",Z[Z.FLOAT8E5M2FNUZ=20]="FLOAT8E5M2FNUZ"))(U=W.TensorDataType||={})})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{let U;((Z)=>(Z[Z.Primitive=0]="Primitive",Z[Z.Fused=1]="Fused"))(U=W.NodeType||={})})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{let U;((Z)=>(Z[Z.NONE=0]="NONE",Z[Z.tensor_type=1]="tensor_type",Z[Z.sequence_type=2]="sequence_type",Z[Z.map_type=3]="map_type"))(U=W.TypeInfoValue||={})})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsShape(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsShape(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}dim(Z,q){let G=this.bb.__offset(this.bb_pos,4);return G?(q||new Q.experimental.fbs.Dimension).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+G)+Z*4),this.bb):null}dimLength(){let Z=this.bb.__offset(this.bb_pos,4);return Z?this.bb.__vector_len(this.bb_pos+Z):0}static startShape(Z){Z.startObject(1)}static addDim(Z,q){Z.addFieldOffset(0,q,0)}static createDimVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startDimVector(Z,q){Z.startVector(4,q,4)}static endShape(Z){return Z.endObject()}static createShape(Z,q){return U.startShape(Z),U.addDim(Z,q),U.endShape(Z)}}W.Shape=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsDimension(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsDimension(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}value(Z){let q=this.bb.__offset(this.bb_pos,4);return q?(Z||new Q.experimental.fbs.DimensionValue).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}denotation(Z){let q=this.bb.__offset(this.bb_pos,6);return q?this.bb.__string(this.bb_pos+q,Z):null}static startDimension(Z){Z.startObject(2)}static addValue(Z,q){Z.addFieldOffset(0,q,0)}static addDenotation(Z,q){Z.addFieldOffset(1,q,0)}static endDimension(Z){return Z.endObject()}static createDimension(Z,q,G){return U.startDimension(Z),U.addValue(Z,q),U.addDenotation(Z,G),U.endDimension(Z)}}W.Dimension=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsDimensionValue(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsDimensionValue(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}dimType(){let Z=this.bb.__offset(this.bb_pos,4);return Z?this.bb.readInt8(this.bb_pos+Z):0}dimValue(){let Z=this.bb.__offset(this.bb_pos,6);return Z?this.bb.readInt64(this.bb_pos+Z):this.bb.createLong(0,0)}dimParam(Z){let q=this.bb.__offset(this.bb_pos,8);return q?this.bb.__string(this.bb_pos+q,Z):null}static startDimensionValue(Z){Z.startObject(3)}static addDimType(Z,q){Z.addFieldInt8(0,q,0)}static addDimValue(Z,q){Z.addFieldInt64(1,q,Z.createLong(0,0))}static addDimParam(Z,q){Z.addFieldOffset(2,q,0)}static endDimensionValue(Z){return Z.endObject()}static createDimensionValue(Z,q,G,J){return U.startDimensionValue(Z),U.addDimType(Z,q),U.addDimValue(Z,G),U.addDimParam(Z,J),U.endDimensionValue(Z)}}W.DimensionValue=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsTensorTypeAndShape(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsTensorTypeAndShape(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}elemType(){let Z=this.bb.__offset(this.bb_pos,4);return Z?this.bb.readInt32(this.bb_pos+Z):0}shape(Z){let q=this.bb.__offset(this.bb_pos,6);return q?(Z||new Q.experimental.fbs.Shape).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}static startTensorTypeAndShape(Z){Z.startObject(2)}static addElemType(Z,q){Z.addFieldInt32(0,q,0)}static addShape(Z,q){Z.addFieldOffset(1,q,0)}static endTensorTypeAndShape(Z){return Z.endObject()}static createTensorTypeAndShape(Z,q,G){return U.startTensorTypeAndShape(Z),U.addElemType(Z,q),U.addShape(Z,G),U.endTensorTypeAndShape(Z)}}W.TensorTypeAndShape=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsMapType(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsMapType(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}keyType(){let Z=this.bb.__offset(this.bb_pos,4);return Z?this.bb.readInt32(this.bb_pos+Z):0}valueType(Z){let q=this.bb.__offset(this.bb_pos,6);return q?(Z||new Q.experimental.fbs.TypeInfo).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}static startMapType(Z){Z.startObject(2)}static addKeyType(Z,q){Z.addFieldInt32(0,q,0)}static addValueType(Z,q){Z.addFieldOffset(1,q,0)}static endMapType(Z){return Z.endObject()}static createMapType(Z,q,G){return U.startMapType(Z),U.addKeyType(Z,q),U.addValueType(Z,G),U.endMapType(Z)}}W.MapType=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsSequenceType(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsSequenceType(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}elemType(Z){let q=this.bb.__offset(this.bb_pos,4);return q?(Z||new Q.experimental.fbs.TypeInfo).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}static startSequenceType(Z){Z.startObject(1)}static addElemType(Z,q){Z.addFieldOffset(0,q,0)}static endSequenceType(Z){return Z.endObject()}static createSequenceType(Z,q){return U.startSequenceType(Z),U.addElemType(Z,q),U.endSequenceType(Z)}}W.SequenceType=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}nodeIndex(){return this.bb.readUint32(this.bb_pos)}srcArgIndex(){return this.bb.readInt32(this.bb_pos+4)}dstArgIndex(){return this.bb.readInt32(this.bb_pos+8)}static createEdgeEnd(Z,q,G,J){return Z.prep(4,12),Z.writeInt32(J),Z.writeInt32(G),Z.writeInt32(q),Z.offset()}}W.EdgeEnd=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsNodeEdge(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsNodeEdge(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}nodeIndex(){let Z=this.bb.__offset(this.bb_pos,4);return Z?this.bb.readUint32(this.bb_pos+Z):0}inputEdges(Z,q){let G=this.bb.__offset(this.bb_pos,6);return G?(q||new Q.experimental.fbs.EdgeEnd).__init(this.bb.__vector(this.bb_pos+G)+Z*12,this.bb):null}inputEdgesLength(){let Z=this.bb.__offset(this.bb_pos,6);return Z?this.bb.__vector_len(this.bb_pos+Z):0}outputEdges(Z,q){let G=this.bb.__offset(this.bb_pos,8);return G?(q||new Q.experimental.fbs.EdgeEnd).__init(this.bb.__vector(this.bb_pos+G)+Z*12,this.bb):null}outputEdgesLength(){let Z=this.bb.__offset(this.bb_pos,8);return Z?this.bb.__vector_len(this.bb_pos+Z):0}static startNodeEdge(Z){Z.startObject(3)}static addNodeIndex(Z,q){Z.addFieldInt32(0,q,0)}static addInputEdges(Z,q){Z.addFieldOffset(1,q,0)}static startInputEdgesVector(Z,q){Z.startVector(12,q,4)}static addOutputEdges(Z,q){Z.addFieldOffset(2,q,0)}static startOutputEdgesVector(Z,q){Z.startVector(12,q,4)}static endNodeEdge(Z){return Z.endObject()}static createNodeEdge(Z,q,G,J){return U.startNodeEdge(Z),U.addNodeIndex(Z,q),U.addInputEdges(Z,G),U.addOutputEdges(Z,J),U.endNodeEdge(Z)}}W.NodeEdge=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsNode(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsNode(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}name(Z){let q=this.bb.__offset(this.bb_pos,4);return q?this.bb.__string(this.bb_pos+q,Z):null}docString(Z){let q=this.bb.__offset(this.bb_pos,6);return q?this.bb.__string(this.bb_pos+q,Z):null}domain(Z){let q=this.bb.__offset(this.bb_pos,8);return q?this.bb.__string(this.bb_pos+q,Z):null}sinceVersion(){let Z=this.bb.__offset(this.bb_pos,10);return Z?this.bb.readInt32(this.bb_pos+Z):0}index(){let Z=this.bb.__offset(this.bb_pos,12);return Z?this.bb.readUint32(this.bb_pos+Z):0}opType(Z){let q=this.bb.__offset(this.bb_pos,14);return q?this.bb.__string(this.bb_pos+q,Z):null}type(){let Z=this.bb.__offset(this.bb_pos,16);return Z?this.bb.readInt32(this.bb_pos+Z):0}executionProviderType(Z){let q=this.bb.__offset(this.bb_pos,18);return q?this.bb.__string(this.bb_pos+q,Z):null}inputs(Z,q){let G=this.bb.__offset(this.bb_pos,20);return G?this.bb.__string(this.bb.__vector(this.bb_pos+G)+Z*4,q):null}inputsLength(){let Z=this.bb.__offset(this.bb_pos,20);return Z?this.bb.__vector_len(this.bb_pos+Z):0}outputs(Z,q){let G=this.bb.__offset(this.bb_pos,22);return G?this.bb.__string(this.bb.__vector(this.bb_pos+G)+Z*4,q):null}outputsLength(){let Z=this.bb.__offset(this.bb_pos,22);return Z?this.bb.__vector_len(this.bb_pos+Z):0}attributes(Z,q){let G=this.bb.__offset(this.bb_pos,24);return G?(q||new Q.experimental.fbs.Attribute).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+G)+Z*4),this.bb):null}attributesLength(){let Z=this.bb.__offset(this.bb_pos,24);return Z?this.bb.__vector_len(this.bb_pos+Z):0}inputArgCounts(Z){let q=this.bb.__offset(this.bb_pos,26);return q?this.bb.readInt32(this.bb.__vector(this.bb_pos+q)+Z*4):0}inputArgCountsLength(){let Z=this.bb.__offset(this.bb_pos,26);return Z?this.bb.__vector_len(this.bb_pos+Z):0}inputArgCountsArray(){let Z=this.bb.__offset(this.bb_pos,26);return Z?new Int32Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+Z),this.bb.__vector_len(this.bb_pos+Z)):null}implicitInputs(Z,q){let G=this.bb.__offset(this.bb_pos,28);return G?this.bb.__string(this.bb.__vector(this.bb_pos+G)+Z*4,q):null}implicitInputsLength(){let Z=this.bb.__offset(this.bb_pos,28);return Z?this.bb.__vector_len(this.bb_pos+Z):0}static startNode(Z){Z.startObject(13)}static addName(Z,q){Z.addFieldOffset(0,q,0)}static addDocString(Z,q){Z.addFieldOffset(1,q,0)}static addDomain(Z,q){Z.addFieldOffset(2,q,0)}static addSinceVersion(Z,q){Z.addFieldInt32(3,q,0)}static addIndex(Z,q){Z.addFieldInt32(4,q,0)}static addOpType(Z,q){Z.addFieldOffset(5,q,0)}static addType(Z,q){Z.addFieldInt32(6,q,0)}static addExecutionProviderType(Z,q){Z.addFieldOffset(7,q,0)}static addInputs(Z,q){Z.addFieldOffset(8,q,0)}static createInputsVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startInputsVector(Z,q){Z.startVector(4,q,4)}static addOutputs(Z,q){Z.addFieldOffset(9,q,0)}static createOutputsVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startOutputsVector(Z,q){Z.startVector(4,q,4)}static addAttributes(Z,q){Z.addFieldOffset(10,q,0)}static createAttributesVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startAttributesVector(Z,q){Z.startVector(4,q,4)}static addInputArgCounts(Z,q){Z.addFieldOffset(11,q,0)}static createInputArgCountsVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addInt32(q[G]);return Z.endVector()}static startInputArgCountsVector(Z,q){Z.startVector(4,q,4)}static addImplicitInputs(Z,q){Z.addFieldOffset(12,q,0)}static createImplicitInputsVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startImplicitInputsVector(Z,q){Z.startVector(4,q,4)}static endNode(Z){return Z.endObject()}static createNode(Z,q,G,J,X,V,R,z,Y,B,k,w,A,D){return U.startNode(Z),U.addName(Z,q),U.addDocString(Z,G),U.addDomain(Z,J),U.addSinceVersion(Z,X),U.addIndex(Z,V),U.addOpType(Z,R),U.addType(Z,z),U.addExecutionProviderType(Z,Y),U.addInputs(Z,B),U.addOutputs(Z,k),U.addAttributes(Z,w),U.addInputArgCounts(Z,A),U.addImplicitInputs(Z,D),U.endNode(Z)}}W.Node=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsValueInfo(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsValueInfo(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}name(Z){let q=this.bb.__offset(this.bb_pos,4);return q?this.bb.__string(this.bb_pos+q,Z):null}docString(Z){let q=this.bb.__offset(this.bb_pos,6);return q?this.bb.__string(this.bb_pos+q,Z):null}type(Z){let q=this.bb.__offset(this.bb_pos,8);return q?(Z||new Q.experimental.fbs.TypeInfo).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}static startValueInfo(Z){Z.startObject(3)}static addName(Z,q){Z.addFieldOffset(0,q,0)}static addDocString(Z,q){Z.addFieldOffset(1,q,0)}static addType(Z,q){Z.addFieldOffset(2,q,0)}static endValueInfo(Z){return Z.endObject()}static createValueInfo(Z,q,G,J){return U.startValueInfo(Z),U.addName(Z,q),U.addDocString(Z,G),U.addType(Z,J),U.endValueInfo(Z)}}W.ValueInfo=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsTypeInfo(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsTypeInfo(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}denotation(Z){let q=this.bb.__offset(this.bb_pos,4);return q?this.bb.__string(this.bb_pos+q,Z):null}valueType(){let Z=this.bb.__offset(this.bb_pos,6);return Z?this.bb.readUint8(this.bb_pos+Z):0}value(Z){let q=this.bb.__offset(this.bb_pos,8);return q?this.bb.__union(Z,this.bb_pos+q):null}static startTypeInfo(Z){Z.startObject(3)}static addDenotation(Z,q){Z.addFieldOffset(0,q,0)}static addValueType(Z,q){Z.addFieldInt8(1,q,0)}static addValue(Z,q){Z.addFieldOffset(2,q,0)}static endTypeInfo(Z){return Z.endObject()}static createTypeInfo(Z,q,G,J){return U.startTypeInfo(Z),U.addDenotation(Z,q),U.addValueType(Z,G),U.addValue(Z,J),U.endTypeInfo(Z)}}W.TypeInfo=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsOperatorSetId(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsOperatorSetId(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}domain(Z){let q=this.bb.__offset(this.bb_pos,4);return q?this.bb.__string(this.bb_pos+q,Z):null}version(){let Z=this.bb.__offset(this.bb_pos,6);return Z?this.bb.readInt64(this.bb_pos+Z):this.bb.createLong(0,0)}static startOperatorSetId(Z){Z.startObject(2)}static addDomain(Z,q){Z.addFieldOffset(0,q,0)}static addVersion(Z,q){Z.addFieldInt64(1,q,Z.createLong(0,0))}static endOperatorSetId(Z){return Z.endObject()}static createOperatorSetId(Z,q,G){return U.startOperatorSetId(Z),U.addDomain(Z,q),U.addVersion(Z,G),U.endOperatorSetId(Z)}}W.OperatorSetId=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsTensor(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsTensor(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}name(Z){let q=this.bb.__offset(this.bb_pos,4);return q?this.bb.__string(this.bb_pos+q,Z):null}docString(Z){let q=this.bb.__offset(this.bb_pos,6);return q?this.bb.__string(this.bb_pos+q,Z):null}dims(Z){let q=this.bb.__offset(this.bb_pos,8);return q?this.bb.readInt64(this.bb.__vector(this.bb_pos+q)+Z*8):this.bb.createLong(0,0)}dimsLength(){let Z=this.bb.__offset(this.bb_pos,8);return Z?this.bb.__vector_len(this.bb_pos+Z):0}dataType(){let Z=this.bb.__offset(this.bb_pos,10);return Z?this.bb.readInt32(this.bb_pos+Z):0}rawData(Z){let q=this.bb.__offset(this.bb_pos,12);return q?this.bb.readUint8(this.bb.__vector(this.bb_pos+q)+Z):0}rawDataLength(){let Z=this.bb.__offset(this.bb_pos,12);return Z?this.bb.__vector_len(this.bb_pos+Z):0}rawDataArray(){let Z=this.bb.__offset(this.bb_pos,12);return Z?new Uint8Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+Z),this.bb.__vector_len(this.bb_pos+Z)):null}stringData(Z,q){let G=this.bb.__offset(this.bb_pos,14);return G?this.bb.__string(this.bb.__vector(this.bb_pos+G)+Z*4,q):null}stringDataLength(){let Z=this.bb.__offset(this.bb_pos,14);return Z?this.bb.__vector_len(this.bb_pos+Z):0}static startTensor(Z){Z.startObject(6)}static addName(Z,q){Z.addFieldOffset(0,q,0)}static addDocString(Z,q){Z.addFieldOffset(1,q,0)}static addDims(Z,q){Z.addFieldOffset(2,q,0)}static createDimsVector(Z,q){Z.startVector(8,q.length,8);for(let G=q.length-1;G>=0;G--)Z.addInt64(q[G]);return Z.endVector()}static startDimsVector(Z,q){Z.startVector(8,q,8)}static addDataType(Z,q){Z.addFieldInt32(3,q,0)}static addRawData(Z,q){Z.addFieldOffset(4,q,0)}static createRawDataVector(Z,q){Z.startVector(1,q.length,1);for(let G=q.length-1;G>=0;G--)Z.addInt8(q[G]);return Z.endVector()}static startRawDataVector(Z,q){Z.startVector(1,q,1)}static addStringData(Z,q){Z.addFieldOffset(5,q,0)}static createStringDataVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startStringDataVector(Z,q){Z.startVector(4,q,4)}static endTensor(Z){return Z.endObject()}static createTensor(Z,q,G,J,X,V,R){return U.startTensor(Z),U.addName(Z,q),U.addDocString(Z,G),U.addDims(Z,J),U.addDataType(Z,X),U.addRawData(Z,V),U.addStringData(Z,R),U.endTensor(Z)}}W.Tensor=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsSparseTensor(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsSparseTensor(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}values(Z){let q=this.bb.__offset(this.bb_pos,4);return q?(Z||new Q.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}indices(Z){let q=this.bb.__offset(this.bb_pos,6);return q?(Z||new Q.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}dims(Z){let q=this.bb.__offset(this.bb_pos,8);return q?this.bb.readInt64(this.bb.__vector(this.bb_pos+q)+Z*8):this.bb.createLong(0,0)}dimsLength(){let Z=this.bb.__offset(this.bb_pos,8);return Z?this.bb.__vector_len(this.bb_pos+Z):0}static startSparseTensor(Z){Z.startObject(3)}static addValues(Z,q){Z.addFieldOffset(0,q,0)}static addIndices(Z,q){Z.addFieldOffset(1,q,0)}static addDims(Z,q){Z.addFieldOffset(2,q,0)}static createDimsVector(Z,q){Z.startVector(8,q.length,8);for(let G=q.length-1;G>=0;G--)Z.addInt64(q[G]);return Z.endVector()}static startDimsVector(Z,q){Z.startVector(8,q,8)}static endSparseTensor(Z){return Z.endObject()}static createSparseTensor(Z,q,G,J){return U.startSparseTensor(Z),U.addValues(Z,q),U.addIndices(Z,G),U.addDims(Z,J),U.endSparseTensor(Z)}}W.SparseTensor=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsAttribute(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsAttribute(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}name(Z){let q=this.bb.__offset(this.bb_pos,4);return q?this.bb.__string(this.bb_pos+q,Z):null}docString(Z){let q=this.bb.__offset(this.bb_pos,6);return q?this.bb.__string(this.bb_pos+q,Z):null}type(){let Z=this.bb.__offset(this.bb_pos,8);return Z?this.bb.readInt32(this.bb_pos+Z):0}f(){let Z=this.bb.__offset(this.bb_pos,10);return Z?this.bb.readFloat32(this.bb_pos+Z):0}i(){let Z=this.bb.__offset(this.bb_pos,12);return Z?this.bb.readInt64(this.bb_pos+Z):this.bb.createLong(0,0)}s(Z){let q=this.bb.__offset(this.bb_pos,14);return q?this.bb.__string(this.bb_pos+q,Z):null}t(Z){let q=this.bb.__offset(this.bb_pos,16);return q?(Z||new Q.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}g(Z){let q=this.bb.__offset(this.bb_pos,18);return q?(Z||new Q.experimental.fbs.Graph).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}floats(Z){let q=this.bb.__offset(this.bb_pos,20);return q?this.bb.readFloat32(this.bb.__vector(this.bb_pos+q)+Z*4):0}floatsLength(){let Z=this.bb.__offset(this.bb_pos,20);return Z?this.bb.__vector_len(this.bb_pos+Z):0}floatsArray(){let Z=this.bb.__offset(this.bb_pos,20);return Z?new Float32Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+Z),this.bb.__vector_len(this.bb_pos+Z)):null}ints(Z){let q=this.bb.__offset(this.bb_pos,22);return q?this.bb.readInt64(this.bb.__vector(this.bb_pos+q)+Z*8):this.bb.createLong(0,0)}intsLength(){let Z=this.bb.__offset(this.bb_pos,22);return Z?this.bb.__vector_len(this.bb_pos+Z):0}strings(Z,q){let G=this.bb.__offset(this.bb_pos,24);return G?this.bb.__string(this.bb.__vector(this.bb_pos+G)+Z*4,q):null}stringsLength(){let Z=this.bb.__offset(this.bb_pos,24);return Z?this.bb.__vector_len(this.bb_pos+Z):0}tensors(Z,q){let G=this.bb.__offset(this.bb_pos,26);return G?(q||new Q.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+G)+Z*4),this.bb):null}tensorsLength(){let Z=this.bb.__offset(this.bb_pos,26);return Z?this.bb.__vector_len(this.bb_pos+Z):0}graphs(Z,q){let G=this.bb.__offset(this.bb_pos,28);return G?(q||new Q.experimental.fbs.Graph).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+G)+Z*4),this.bb):null}graphsLength(){let Z=this.bb.__offset(this.bb_pos,28);return Z?this.bb.__vector_len(this.bb_pos+Z):0}static startAttribute(Z){Z.startObject(13)}static addName(Z,q){Z.addFieldOffset(0,q,0)}static addDocString(Z,q){Z.addFieldOffset(1,q,0)}static addType(Z,q){Z.addFieldInt32(2,q,0)}static addF(Z,q){Z.addFieldFloat32(3,q,0)}static addI(Z,q){Z.addFieldInt64(4,q,Z.createLong(0,0))}static addS(Z,q){Z.addFieldOffset(5,q,0)}static addT(Z,q){Z.addFieldOffset(6,q,0)}static addG(Z,q){Z.addFieldOffset(7,q,0)}static addFloats(Z,q){Z.addFieldOffset(8,q,0)}static createFloatsVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addFloat32(q[G]);return Z.endVector()}static startFloatsVector(Z,q){Z.startVector(4,q,4)}static addInts(Z,q){Z.addFieldOffset(9,q,0)}static createIntsVector(Z,q){Z.startVector(8,q.length,8);for(let G=q.length-1;G>=0;G--)Z.addInt64(q[G]);return Z.endVector()}static startIntsVector(Z,q){Z.startVector(8,q,8)}static addStrings(Z,q){Z.addFieldOffset(10,q,0)}static createStringsVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startStringsVector(Z,q){Z.startVector(4,q,4)}static addTensors(Z,q){Z.addFieldOffset(11,q,0)}static createTensorsVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startTensorsVector(Z,q){Z.startVector(4,q,4)}static addGraphs(Z,q){Z.addFieldOffset(12,q,0)}static createGraphsVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startGraphsVector(Z,q){Z.startVector(4,q,4)}static endAttribute(Z){return Z.endObject()}static createAttribute(Z,q,G,J,X,V,R,z,Y,B,k,w,A,D){return U.startAttribute(Z),U.addName(Z,q),U.addDocString(Z,G),U.addType(Z,J),U.addF(Z,X),U.addI(Z,V),U.addS(Z,R),U.addT(Z,z),U.addG(Z,Y),U.addFloats(Z,B),U.addInts(Z,k),U.addStrings(Z,w),U.addTensors(Z,A),U.addGraphs(Z,D),U.endAttribute(Z)}}W.Attribute=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsGraph(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsGraph(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}initializers(Z,q){let G=this.bb.__offset(this.bb_pos,4);return G?(q||new Q.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+G)+Z*4),this.bb):null}initializersLength(){let Z=this.bb.__offset(this.bb_pos,4);return Z?this.bb.__vector_len(this.bb_pos+Z):0}nodeArgs(Z,q){let G=this.bb.__offset(this.bb_pos,6);return G?(q||new Q.experimental.fbs.ValueInfo).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+G)+Z*4),this.bb):null}nodeArgsLength(){let Z=this.bb.__offset(this.bb_pos,6);return Z?this.bb.__vector_len(this.bb_pos+Z):0}nodes(Z,q){let G=this.bb.__offset(this.bb_pos,8);return G?(q||new Q.experimental.fbs.Node).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+G)+Z*4),this.bb):null}nodesLength(){let Z=this.bb.__offset(this.bb_pos,8);return Z?this.bb.__vector_len(this.bb_pos+Z):0}maxNodeIndex(){let Z=this.bb.__offset(this.bb_pos,10);return Z?this.bb.readUint32(this.bb_pos+Z):0}nodeEdges(Z,q){let G=this.bb.__offset(this.bb_pos,12);return G?(q||new Q.experimental.fbs.NodeEdge).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+G)+Z*4),this.bb):null}nodeEdgesLength(){let Z=this.bb.__offset(this.bb_pos,12);return Z?this.bb.__vector_len(this.bb_pos+Z):0}inputs(Z,q){let G=this.bb.__offset(this.bb_pos,14);return G?this.bb.__string(this.bb.__vector(this.bb_pos+G)+Z*4,q):null}inputsLength(){let Z=this.bb.__offset(this.bb_pos,14);return Z?this.bb.__vector_len(this.bb_pos+Z):0}outputs(Z,q){let G=this.bb.__offset(this.bb_pos,16);return G?this.bb.__string(this.bb.__vector(this.bb_pos+G)+Z*4,q):null}outputsLength(){let Z=this.bb.__offset(this.bb_pos,16);return Z?this.bb.__vector_len(this.bb_pos+Z):0}sparseInitializers(Z,q){let G=this.bb.__offset(this.bb_pos,18);return G?(q||new Q.experimental.fbs.SparseTensor).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+G)+Z*4),this.bb):null}sparseInitializersLength(){let Z=this.bb.__offset(this.bb_pos,18);return Z?this.bb.__vector_len(this.bb_pos+Z):0}static startGraph(Z){Z.startObject(8)}static addInitializers(Z,q){Z.addFieldOffset(0,q,0)}static createInitializersVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startInitializersVector(Z,q){Z.startVector(4,q,4)}static addNodeArgs(Z,q){Z.addFieldOffset(1,q,0)}static createNodeArgsVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startNodeArgsVector(Z,q){Z.startVector(4,q,4)}static addNodes(Z,q){Z.addFieldOffset(2,q,0)}static createNodesVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startNodesVector(Z,q){Z.startVector(4,q,4)}static addMaxNodeIndex(Z,q){Z.addFieldInt32(3,q,0)}static addNodeEdges(Z,q){Z.addFieldOffset(4,q,0)}static createNodeEdgesVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startNodeEdgesVector(Z,q){Z.startVector(4,q,4)}static addInputs(Z,q){Z.addFieldOffset(5,q,0)}static createInputsVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startInputsVector(Z,q){Z.startVector(4,q,4)}static addOutputs(Z,q){Z.addFieldOffset(6,q,0)}static createOutputsVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startOutputsVector(Z,q){Z.startVector(4,q,4)}static addSparseInitializers(Z,q){Z.addFieldOffset(7,q,0)}static createSparseInitializersVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startSparseInitializersVector(Z,q){Z.startVector(4,q,4)}static endGraph(Z){return Z.endObject()}static createGraph(Z,q,G,J,X,V,R,z,Y){return U.startGraph(Z),U.addInitializers(Z,q),U.addNodeArgs(Z,G),U.addNodes(Z,J),U.addMaxNodeIndex(Z,X),U.addNodeEdges(Z,V),U.addInputs(Z,R),U.addOutputs(Z,z),U.addSparseInitializers(Z,Y),U.endGraph(Z)}}W.Graph=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsModel(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsModel(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}irVersion(){let Z=this.bb.__offset(this.bb_pos,4);return Z?this.bb.readInt64(this.bb_pos+Z):this.bb.createLong(0,0)}opsetImport(Z,q){let G=this.bb.__offset(this.bb_pos,6);return G?(q||new Q.experimental.fbs.OperatorSetId).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+G)+Z*4),this.bb):null}opsetImportLength(){let Z=this.bb.__offset(this.bb_pos,6);return Z?this.bb.__vector_len(this.bb_pos+Z):0}producerName(Z){let q=this.bb.__offset(this.bb_pos,8);return q?this.bb.__string(this.bb_pos+q,Z):null}producerVersion(Z){let q=this.bb.__offset(this.bb_pos,10);return q?this.bb.__string(this.bb_pos+q,Z):null}domain(Z){let q=this.bb.__offset(this.bb_pos,12);return q?this.bb.__string(this.bb_pos+q,Z):null}modelVersion(){let Z=this.bb.__offset(this.bb_pos,14);return Z?this.bb.readInt64(this.bb_pos+Z):this.bb.createLong(0,0)}docString(Z){let q=this.bb.__offset(this.bb_pos,16);return q?this.bb.__string(this.bb_pos+q,Z):null}graph(Z){let q=this.bb.__offset(this.bb_pos,18);return q?(Z||new Q.experimental.fbs.Graph).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}graphDocString(Z){let q=this.bb.__offset(this.bb_pos,20);return q?this.bb.__string(this.bb_pos+q,Z):null}static startModel(Z){Z.startObject(9)}static addIrVersion(Z,q){Z.addFieldInt64(0,q,Z.createLong(0,0))}static addOpsetImport(Z,q){Z.addFieldOffset(1,q,0)}static createOpsetImportVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startOpsetImportVector(Z,q){Z.startVector(4,q,4)}static addProducerName(Z,q){Z.addFieldOffset(2,q,0)}static addProducerVersion(Z,q){Z.addFieldOffset(3,q,0)}static addDomain(Z,q){Z.addFieldOffset(4,q,0)}static addModelVersion(Z,q){Z.addFieldInt64(5,q,Z.createLong(0,0))}static addDocString(Z,q){Z.addFieldOffset(6,q,0)}static addGraph(Z,q){Z.addFieldOffset(7,q,0)}static addGraphDocString(Z,q){Z.addFieldOffset(8,q,0)}static endModel(Z){return Z.endObject()}static createModel(Z,q,G,J,X,V,R,z,Y,B){return U.startModel(Z),U.addIrVersion(Z,q),U.addOpsetImport(Z,G),U.addProducerName(Z,J),U.addProducerVersion(Z,X),U.addDomain(Z,V),U.addModelVersion(Z,R),U.addDocString(Z,z),U.addGraph(Z,Y),U.addGraphDocString(Z,B),U.endModel(Z)}}W.Model=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsKernelCreateInfos(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsKernelCreateInfos(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}nodeIndices(Z){let q=this.bb.__offset(this.bb_pos,4);return q?this.bb.readUint32(this.bb.__vector(this.bb_pos+q)+Z*4):0}nodeIndicesLength(){let Z=this.bb.__offset(this.bb_pos,4);return Z?this.bb.__vector_len(this.bb_pos+Z):0}nodeIndicesArray(){let Z=this.bb.__offset(this.bb_pos,4);return Z?new Uint32Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+Z),this.bb.__vector_len(this.bb_pos+Z)):null}kernelDefHashes(Z){let q=this.bb.__offset(this.bb_pos,6);return q?this.bb.readUint64(this.bb.__vector(this.bb_pos+q)+Z*8):this.bb.createLong(0,0)}kernelDefHashesLength(){let Z=this.bb.__offset(this.bb_pos,6);return Z?this.bb.__vector_len(this.bb_pos+Z):0}static startKernelCreateInfos(Z){Z.startObject(2)}static addNodeIndices(Z,q){Z.addFieldOffset(0,q,0)}static createNodeIndicesVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addInt32(q[G]);return Z.endVector()}static startNodeIndicesVector(Z,q){Z.startVector(4,q,4)}static addKernelDefHashes(Z,q){Z.addFieldOffset(1,q,0)}static createKernelDefHashesVector(Z,q){Z.startVector(8,q.length,8);for(let G=q.length-1;G>=0;G--)Z.addInt64(q[G]);return Z.endVector()}static startKernelDefHashesVector(Z,q){Z.startVector(8,q,8)}static endKernelCreateInfos(Z){return Z.endObject()}static createKernelCreateInfos(Z,q,G){return U.startKernelCreateInfos(Z),U.addNodeIndices(Z,q),U.addKernelDefHashes(Z,G),U.endKernelCreateInfos(Z)}}W.KernelCreateInfos=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsSubGraphSessionState(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsSubGraphSessionState(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}graphId(Z){let q=this.bb.__offset(this.bb_pos,4);return q?this.bb.__string(this.bb_pos+q,Z):null}sessionState(Z){let q=this.bb.__offset(this.bb_pos,6);return q?(Z||new Q.experimental.fbs.SessionState).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}static startSubGraphSessionState(Z){Z.startObject(2)}static addGraphId(Z,q){Z.addFieldOffset(0,q,0)}static addSessionState(Z,q){Z.addFieldOffset(1,q,0)}static endSubGraphSessionState(Z){let q=Z.endObject();return Z.requiredField(q,4),q}static createSubGraphSessionState(Z,q,G){return U.startSubGraphSessionState(Z),U.addGraphId(Z,q),U.addSessionState(Z,G),U.endSubGraphSessionState(Z)}}W.SubGraphSessionState=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsSessionState(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsSessionState(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}kernels(Z){let q=this.bb.__offset(this.bb_pos,4);return q?(Z||new Q.experimental.fbs.KernelCreateInfos).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}subGraphSessionStates(Z,q){let G=this.bb.__offset(this.bb_pos,6);return G?(q||new Q.experimental.fbs.SubGraphSessionState).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+G)+Z*4),this.bb):null}subGraphSessionStatesLength(){let Z=this.bb.__offset(this.bb_pos,6);return Z?this.bb.__vector_len(this.bb_pos+Z):0}static startSessionState(Z){Z.startObject(2)}static addKernels(Z,q){Z.addFieldOffset(0,q,0)}static addSubGraphSessionStates(Z,q){Z.addFieldOffset(1,q,0)}static createSubGraphSessionStatesVector(Z,q){Z.startVector(4,q.length,4);for(let G=q.length-1;G>=0;G--)Z.addOffset(q[G]);return Z.endVector()}static startSubGraphSessionStatesVector(Z,q){Z.startVector(4,q,4)}static endSessionState(Z){return Z.endObject()}static createSessionState(Z,q,G){return U.startSessionState(Z),U.addKernels(Z,q),U.addSubGraphSessionStates(Z,G),U.endSessionState(Z)}}W.SessionState=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={}),((Q)=>{let H;((j)=>{let K;((W)=>{class U{constructor(){this.bb=null,this.bb_pos=0}__init(Z,q){return this.bb_pos=Z,this.bb=q,this}static getRootAsInferenceSession(Z,q){return(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static getSizePrefixedRootAsInferenceSession(Z,q){return Z.setPosition(Z.position()+$.SIZE_PREFIX_LENGTH),(q||new U).__init(Z.readInt32(Z.position())+Z.position(),Z)}static bufferHasIdentifier(Z){return Z.__has_identifier("ORTM")}ortVersion(Z){let q=this.bb.__offset(this.bb_pos,4);return q?this.bb.__string(this.bb_pos+q,Z):null}model(Z){let q=this.bb.__offset(this.bb_pos,6);return q?(Z||new Q.experimental.fbs.Model).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}sessionState(Z){let q=this.bb.__offset(this.bb_pos,8);return q?(Z||new Q.experimental.fbs.SessionState).__init(this.bb.__indirect(this.bb_pos+q),this.bb):null}static startInferenceSession(Z){Z.startObject(3)}static addOrtVersion(Z,q){Z.addFieldOffset(0,q,0)}static addModel(Z,q){Z.addFieldOffset(1,q,0)}static addSessionState(Z,q){Z.addFieldOffset(2,q,0)}static endInferenceSession(Z){return Z.endObject()}static finishInferenceSessionBuffer(Z,q){Z.finish(q,"ORTM")}static finishSizePrefixedInferenceSessionBuffer(Z,q){Z.finish(q,"ORTM",!0)}static createInferenceSession(Z,q,G,J){return U.startInferenceSession(Z),U.addOrtVersion(Z,q),U.addModel(Z,G),U.addSessionState(Z,J),U.endInferenceSession(Z)}}W.InferenceSession=U})(K=j.fbs||={})})(H=Q.experimental||={})})(H1||={})}),rZ=U1((Q,H)=>{H.exports=j;function j(K,W){for(var U=new Array(arguments.length-1),Z=0,q=2,G=!0;q<arguments.length;)U[Z++]=arguments[q++];return new Promise(function(J,X){U[Z]=function(V){if(G)if(G=!1,V)X(V);else{for(var R=new Array(arguments.length-1),z=0;z<R.length;)R[z++]=arguments[z];J.apply(null,R)}};try{K.apply(W||null,U)}catch(V){G&&(G=!1,X(V))}})}}),tZ=U1((Q)=>{var H=Q;H.length=function(Z){var q=Z.length;if(!q)return 0;for(var G=0;--q%4>1&&Z.charAt(q)==="=";)++G;return Math.ceil(Z.length*3)/4-G};var j=new Array(64),K=new Array(123);for(W=0;W<64;)K[j[W]=W<26?W+65:W<52?W+71:W<62?W-4:W-59|43]=W++;var W;H.encode=function(Z,q,G){for(var J=null,X=[],V=0,R=0,z;q<G;){var Y=Z[q++];switch(R){case 0:X[V++]=j[Y>>2],z=(Y&3)<<4,R=1;break;case 1:X[V++]=j[z|Y>>4],z=(Y&15)<<2,R=2;break;case 2:X[V++]=j[z|Y>>6],X[V++]=j[Y&63],R=0;break}V>8191&&((J||(J=[])).push(String.fromCharCode.apply(String,X)),V=0)}return R&&(X[V++]=j[z],X[V++]=61,R===1&&(X[V++]=61)),J?(V&&J.push(String.fromCharCode.apply(String,X.slice(0,V))),J.join("")):String.fromCharCode.apply(String,X.slice(0,V))};var U="invalid encoding";H.decode=function(Z,q,G){for(var J=G,X=0,V,R=0;R<Z.length;){var z=Z.charCodeAt(R++);if(z===61&&X>1)break;if((z=K[z])===void 0)throw Error(U);switch(X){case 0:V=z,X=1;break;case 1:q[G++]=V<<2|(z&48)>>4,V=z,X=2;break;case 2:q[G++]=(V&15)<<4|(z&60)>>2,V=z,X=3;break;case 3:q[G++]=(V&3)<<6|z,X=0;break}}if(X===1)throw Error(U);return G-J},H.test=function(Z){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(Z)}}),eZ=U1((Q,H)=>{H.exports=j;function j(){this._listeners={}}j.prototype.on=function(K,W,U){return(this._listeners[K]||(this._listeners[K]=[])).push({fn:W,ctx:U||this}),this},j.prototype.off=function(K,W){if(K===void 0)this._listeners={};else if(W===void 0)this._listeners[K]=[];else for(var U=this._listeners[K],Z=0;Z<U.length;)U[Z].fn===W?U.splice(Z,1):++Z;return this},j.prototype.emit=function(K){var W=this._listeners[K];if(W){for(var U=[],Z=1;Z<arguments.length;)U.push(arguments[Z++]);for(Z=0;Z<W.length;)W[Z].fn.apply(W[Z++].ctx,U)}return this}}),Qj=U1((Q,H)=>{H.exports=j(j);function j(q){return typeof Float32Array<"u"?function(){var G=new Float32Array([-0]),J=new Uint8Array(G.buffer),X=J[3]===128;function V(B,k,w){G[0]=B,k[w]=J[0],k[w+1]=J[1],k[w+2]=J[2],k[w+3]=J[3]}function R(B,k,w){G[0]=B,k[w]=J[3],k[w+1]=J[2],k[w+2]=J[1],k[w+3]=J[0]}q.writeFloatLE=X?V:R,q.writeFloatBE=X?R:V;function z(B,k){return J[0]=B[k],J[1]=B[k+1],J[2]=B[k+2],J[3]=B[k+3],G[0]}function Y(B,k){return J[3]=B[k],J[2]=B[k+1],J[1]=B[k+2],J[0]=B[k+3],G[0]}q.readFloatLE=X?z:Y,q.readFloatBE=X?Y:z}():function(){function G(X,V,R,z){var Y=V<0?1:0;if(Y&&(V=-V),V===0)X(1/V>0?0:2147483648,R,z);else if(isNaN(V))X(2143289344,R,z);else if(V>340282346638528860000000000000000000000)X((Y<<31|2139095040)>>>0,R,z);else if(V<0.000000000000000000000000000000000000011754943508222875)X((Y<<31|Math.round(V/0.000000000000000000000000000000000000000000001401298464324817))>>>0,R,z);else{var B=Math.floor(Math.log(V)/Math.LN2),k=Math.round(V*Math.pow(2,-B)*8388608)&8388607;X((Y<<31|B+127<<23|k)>>>0,R,z)}}q.writeFloatLE=G.bind(null,K),q.writeFloatBE=G.bind(null,W);function J(X,V,R){var z=X(V,R),Y=(z>>31)*2+1,B=z>>>23&255,k=z&8388607;return B===255?k?NaN:Y*(1/0):B===0?Y*0.000000000000000000000000000000000000000000001401298464324817*k:Y*Math.pow(2,B-150)*(k+8388608)}q.readFloatLE=J.bind(null,U),q.readFloatBE=J.bind(null,Z)}(),typeof Float64Array<"u"?function(){var G=new Float64Array([-0]),J=new Uint8Array(G.buffer),X=J[7]===128;function V(B,k,w){G[0]=B,k[w]=J[0],k[w+1]=J[1],k[w+2]=J[2],k[w+3]=J[3],k[w+4]=J[4],k[w+5]=J[5],k[w+6]=J[6],k[w+7]=J[7]}function R(B,k,w){G[0]=B,k[w]=J[7],k[w+1]=J[6],k[w+2]=J[5],k[w+3]=J[4],k[w+4]=J[3],k[w+5]=J[2],k[w+6]=J[1],k[w+7]=J[0]}q.writeDoubleLE=X?V:R,q.writeDoubleBE=X?R:V;function z(B,k){return J[0]=B[k],J[1]=B[k+1],J[2]=B[k+2],J[3]=B[k+3],J[4]=B[k+4],J[5]=B[k+5],J[6]=B[k+6],J[7]=B[k+7],G[0]}function Y(B,k){return J[7]=B[k],J[6]=B[k+1],J[5]=B[k+2],J[4]=B[k+3],J[3]=B[k+4],J[2]=B[k+5],J[1]=B[k+6],J[0]=B[k+7],G[0]}q.readDoubleLE=X?z:Y,q.readDoubleBE=X?Y:z}():function(){function G(X,V,R,z,Y,B){var k=z<0?1:0;if(k&&(z=-z),z===0)X(0,Y,B+V),X(1/z>0?0:2147483648,Y,B+R);else if(isNaN(z))X(0,Y,B+V),X(2146959360,Y,B+R);else if(z>179769313486231570000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000)X(0,Y,B+V),X((k<<31|2146435072)>>>0,Y,B+R);else{var w;if(z<0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000022250738585072014)w=z/0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000005,X(w>>>0,Y,B+V),X((k<<31|w/4294967296)>>>0,Y,B+R);else{var A=Math.floor(Math.log(z)/Math.LN2);A===1024&&(A=1023),w=z*Math.pow(2,-A),X(w*4503599627370496>>>0,Y,B+V),X((k<<31|A+1023<<20|w*1048576&1048575)>>>0,Y,B+R)}}}q.writeDoubleLE=G.bind(null,K,0,4),q.writeDoubleBE=G.bind(null,W,4,0);function J(X,V,R,z,Y){var B=X(z,Y+V),k=X(z,Y+R),w=(k>>31)*2+1,A=k>>>20&2047,D=4294967296*(k&1048575)+B;return A===2047?D?NaN:w*(1/0):A===0?w*0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000005*D:w*Math.pow(2,A-1075)*(D+4503599627370496)}q.readDoubleLE=J.bind(null,U,0,4),q.readDoubleBE=J.bind(null,Z,4,0)}(),q}function K(q,G,J){G[J]=q&255,G[J+1]=q>>>8&255,G[J+2]=q>>>16&255,G[J+3]=q>>>24}function W(q,G,J){G[J]=q>>>24,G[J+1]=q>>>16&255,G[J+2]=q>>>8&255,G[J+3]=q&255}function U(q,G){return(q[G]|q[G+1]<<8|q[G+2]<<16|q[G+3]<<24)>>>0}function Z(q,G){return(q[G]<<24|q[G+1]<<16|q[G+2]<<8|q[G+3])>>>0}}),Jj=U1((exports,module)=>{module.exports=inquire;function inquire(moduleName){try{var mod=eval("quire".replace(/^/,"re"))(moduleName);if(mod&&(mod.length||Object.keys(mod).length))return mod}catch(Q){}return null}}),Hj=U1((Q)=>{var H=Q;H.length=function(j){for(var K=0,W=0,U=0;U<j.length;++U)W=j.charCodeAt(U),W<128?K+=1:W<2048?K+=2:(W&64512)===55296&&(j.charCodeAt(U+1)&64512)===56320?(++U,K+=4):K+=3;return K},H.read=function(j,K,W){var U=W-K;if(U<1)return"";for(var Z=null,q=[],G=0,J;K<W;)J=j[K++],J<128?q[G++]=J:J>191&&J<224?q[G++]=(J&31)<<6|j[K++]&63:J>239&&J<365?(J=((J&7)<<18|(j[K++]&63)<<12|(j[K++]&63)<<6|j[K++]&63)-65536,q[G++]=55296+(J>>10),q[G++]=56320+(J&1023)):q[G++]=(J&15)<<12|(j[K++]&63)<<6|j[K++]&63,G>8191&&((Z||(Z=[])).push(String.fromCharCode.apply(String,q)),G=0);return Z?(G&&Z.push(String.fromCharCode.apply(String,q.slice(0,G))),Z.join("")):String.fromCharCode.apply(String,q.slice(0,G))},H.write=function(j,K,W){for(var U=W,Z,q,G=0;G<j.length;++G)Z=j.charCodeAt(G),Z<128?K[W++]=Z:Z<2048?(K[W++]=Z>>6|192,K[W++]=Z&63|128):(Z&64512)===55296&&((q=j.charCodeAt(G+1))&64512)===56320?(Z=65536+((Z&1023)<<10)+(q&1023),++G,K[W++]=Z>>18|240,K[W++]=Z>>12&63|128,K[W++]=Z>>6&63|128,K[W++]=Z&63|128):(K[W++]=Z>>12|224,K[W++]=Z>>6&63|128,K[W++]=Z&63|128);return W-U}}),Zj=U1((Q,H)=>{H.exports=j;function j(K,W,U){var Z=U||8192,q=Z>>>1,G=null,J=Z;return function(X){if(X<1||X>q)return K(X);J+X>Z&&(G=K(Z),J=0);var V=W.call(G,J,J+=X);return J&7&&(J=(J|7)+1),V}}}),jj=U1((Q,H)=>{H.exports=K;var j=n3();function K(q,G){this.lo=q>>>0,this.hi=G>>>0}var W=K.zero=new K(0,0);W.toNumber=function(){return 0},W.zzEncode=W.zzDecode=function(){return this},W.length=function(){return 1};var U=K.zeroHash="\0\0\0\0\0\0\0\0";K.fromNumber=function(q){if(q===0)return W;var G=q<0;G&&(q=-q);var J=q>>>0,X=(q-J)/4294967296>>>0;return G&&(X=~X>>>0,J=~J>>>0,++J>4294967295&&(J=0,++X>4294967295&&(X=0))),new K(J,X)},K.from=function(q){if(typeof q=="number")return K.fromNumber(q);if(j.isString(q))if(j.Long)q=j.Long.fromString(q);else return K.fromNumber(parseInt(q,10));return q.low||q.high?new K(q.low>>>0,q.high>>>0):W},K.prototype.toNumber=function(q){if(!q&&this.hi>>>31){var G=~this.lo+1>>>0,J=~this.hi>>>0;return G||(J=J+1>>>0),-(G+J*4294967296)}return this.lo+this.hi*4294967296},K.prototype.toLong=function(q){return j.Long?new j.Long(this.lo|0,this.hi|0,!!q):{low:this.lo|0,high:this.hi|0,unsigned:!!q}};var Z=String.prototype.charCodeAt;K.fromHash=function(q){return q===U?W:new K((Z.call(q,0)|Z.call(q,1)<<8|Z.call(q,2)<<16|Z.call(q,3)<<24)>>>0,(Z.call(q,4)|Z.call(q,5)<<8|Z.call(q,6)<<16|Z.call(q,7)<<24)>>>0)},K.prototype.toHash=function(){return String.fromCharCode(this.lo&255,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,this.hi&255,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)},K.prototype.zzEncode=function(){var q=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^q)>>>0,this.lo=(this.lo<<1^q)>>>0,this},K.prototype.zzDecode=function(){var q=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^q)>>>0,this.hi=(this.hi>>>1^q)>>>0,this},K.prototype.length=function(){var q=this.lo,G=(this.lo>>>28|this.hi<<4)>>>0,J=this.hi>>>24;return J===0?G===0?q<16384?q<128?1:2:q<2097152?3:4:G<16384?G<128?5:6:G<2097152?7:8:J<128?9:10}}),n3=U1((Q)=>{var H=Q;H.asPromise=rZ(),H.base64=tZ(),H.EventEmitter=eZ(),H.float=Qj(),H.inquire=Jj(),H.utf8=Hj(),H.pool=Zj(),H.LongBits=jj(),H.isNode=!!(typeof global<"u"&&global&&global.process&&global.process.versions&&global.process.versions.node),H.global=H.isNode&&global||typeof window<"u"&&window||typeof self<"u"&&self||Q,H.emptyArray=Object.freeze?Object.freeze([]):[],H.emptyObject=Object.freeze?Object.freeze({}):{},H.isInteger=Number.isInteger||function(W){return typeof W=="number"&&isFinite(W)&&Math.floor(W)===W},H.isString=function(W){return typeof W=="string"||W instanceof String},H.isObject=function(W){return W&&typeof W=="object"},H.isset=H.isSet=function(W,U){var Z=W[U];return Z!=null&&W.hasOwnProperty(U)?typeof Z!="object"||(Array.isArray(Z)?Z.length:Object.keys(Z).length)>0:!1},H.Buffer=function(){try{var W=H.inquire("buffer").Buffer;return W.prototype.utf8Write?W:null}catch{return null}}(),H._Buffer_from=null,H._Buffer_allocUnsafe=null,H.newBuffer=function(W){return typeof W=="number"?H.Buffer?H._Buffer_allocUnsafe(W):new H.Array(W):H.Buffer?H._Buffer_from(W):typeof Uint8Array>"u"?W:new Uint8Array(W)},H.Array=typeof Uint8Array<"u"?Uint8Array:Array,H.Long=H.global.dcodeIO&&H.global.dcodeIO.Long||H.global.Long||H.inquire("long"),H.key2Re=/^true|false|0|1$/,H.key32Re=/^-?(?:0|[1-9][0-9]*)$/,H.key64Re=/^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/,H.longToHash=function(W){return W?H.LongBits.from(W).toHash():H.LongBits.zeroHash},H.longFromHash=function(W,U){var Z=H.LongBits.fromHash(W);return H.Long?H.Long.fromBits(Z.lo,Z.hi,U):Z.toNumber(!!U)};function j(W,U,Z){for(var q=Object.keys(U),G=0;G<q.length;++G)(W[q[G]]===void 0||!Z)&&(W[q[G]]=U[q[G]]);return W}H.merge=j,H.lcFirst=function(W){return W.charAt(0).toLowerCase()+W.substring(1)};function K(W){function U(Z,q){if(!(this instanceof U))return new U(Z,q);Object.defineProperty(this,"message",{get:function(){return Z}}),Error.captureStackTrace?Error.captureStackTrace(this,U):Object.defineProperty(this,"stack",{value:new Error().stack||""}),q&&j(this,q)}return U.prototype=Object.create(Error.prototype,{constructor:{value:U,writable:!0,enumerable:!1,configurable:!0},name:{get:function(){return W},set:void 0,enumerable:!1,configurable:!0},toString:{value:function(){return this.name+": "+this.message},writable:!0,enumerable:!1,configurable:!0}}),U}H.newError=K,H.ProtocolError=K("ProtocolError"),H.oneOfGetter=function(W){for(var U={},Z=0;Z<W.length;++Z)U[W[Z]]=1;return function(){for(var q=Object.keys(this),G=q.length-1;G>-1;--G)if(U[q[G]]===1&&this[q[G]]!==void 0&&this[q[G]]!==null)return q[G]}},H.oneOfSetter=function(W){return function(U){for(var Z=0;Z<W.length;++Z)W[Z]!==U&&delete this[W[Z]]}},H.toJSONOptions={longs:String,enums:String,bytes:String,json:!0},H._configure=function(){var W=H.Buffer;if(!W){H._Buffer_from=H._Buffer_allocUnsafe=null;return}H._Buffer_from=W.from!==Uint8Array.from&&W.from||function(U,Z){return new W(U,Z)},H._Buffer_allocUnsafe=W.allocUnsafe||function(U){return new W(U)}}}),n2=U1((Q,H)=>{H.exports=X;var j=n3(),K,W=j.LongBits,U=j.base64,Z=j.utf8;function q(A,D,I){this.fn=A,this.len=D,this.next=void 0,this.val=I}function G(){}function J(A){this.head=A.head,this.tail=A.tail,this.len=A.len,this.next=A.states}function X(){this.len=0,this.head=new q(G,0,0),this.tail=this.head,this.states=null}var V=function(){return j.Buffer?function(){return(X.create=function(){return new K})()}:function(){return new X}};X.create=V(),X.alloc=function(A){return new j.Array(A)},j.Array!==Array&&(X.alloc=j.pool(X.alloc,j.Array.prototype.subarray)),X.prototype._push=function(A,D,I){return this.tail=this.tail.next=new q(A,D,I),this.len+=D,this};function R(A,D,I){D[I]=A&255}function z(A,D,I){for(;A>127;)D[I++]=A&127|128,A>>>=7;D[I]=A}function Y(A,D){this.len=A,this.next=void 0,this.val=D}Y.prototype=Object.create(q.prototype),Y.prototype.fn=z,X.prototype.uint32=function(A){return this.len+=(this.tail=this.tail.next=new Y((A=A>>>0)<128?1:A<16384?2:A<2097152?3:A<268435456?4:5,A)).len,this},X.prototype.int32=function(A){return A<0?this._push(B,10,W.fromNumber(A)):this.uint32(A)},X.prototype.sint32=function(A){return this.uint32((A<<1^A>>31)>>>0)};function B(A,D,I){for(;A.hi;)D[I++]=A.lo&127|128,A.lo=(A.lo>>>7|A.hi<<25)>>>0,A.hi>>>=7;for(;A.lo>127;)D[I++]=A.lo&127|128,A.lo=A.lo>>>7;D[I++]=A.lo}X.prototype.uint64=function(A){var D=W.from(A);return this._push(B,D.length(),D)},X.prototype.int64=X.prototype.uint64,X.prototype.sint64=function(A){var D=W.from(A).zzEncode();return this._push(B,D.length(),D)},X.prototype.bool=function(A){return this._push(R,1,A?1:0)};function k(A,D,I){D[I]=A&255,D[I+1]=A>>>8&255,D[I+2]=A>>>16&255,D[I+3]=A>>>24}X.prototype.fixed32=function(A){return this._push(k,4,A>>>0)},X.prototype.sfixed32=X.prototype.fixed32,X.prototype.fixed64=function(A){var D=W.from(A);return this._push(k,4,D.lo)._push(k,4,D.hi)},X.prototype.sfixed64=X.prototype.fixed64,X.prototype.float=function(A){return this._push(j.float.writeFloatLE,4,A)},X.prototype.double=function(A){return this._push(j.float.writeDoubleLE,8,A)};var w=j.Array.prototype.set?function(A,D,I){D.set(A,I)}:function(A,D,I){for(var h=0;h<A.length;++h)D[I+h]=A[h]};X.prototype.bytes=function(A){var D=A.length>>>0;if(!D)return this._push(R,1,0);if(j.isString(A)){var I=X.alloc(D=U.length(A));U.decode(A,I,0),A=I}return this.uint32(D)._push(w,D,A)},X.prototype.string=function(A){var D=Z.length(A);return D?this.uint32(D)._push(Z.write,D,A):this._push(R,1,0)},X.prototype.fork=function(){return this.states=new J(this),this.head=this.tail=new q(G,0,0),this.len=0,this},X.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new q(G,0,0),this.len=0),this},X.prototype.ldelim=function(){var A=this.head,D=this.tail,I=this.len;return this.reset().uint32(I),I&&(this.tail.next=A.next,this.tail=D,this.len+=I),this},X.prototype.finish=function(){for(var A=this.head.next,D=this.constructor.alloc(this.len),I=0;A;)A.fn(A.val,D,I),I+=A.len,A=A.next;return D},X._configure=function(A){K=A,X.create=V(),K._configure()}}),Vj=U1((Q,H)=>{H.exports=W;var j=n2();(W.prototype=Object.create(j.prototype)).constructor=W;var K=n3();function W(){j.call(this)}W._configure=function(){W.alloc=K._Buffer_allocUnsafe,W.writeBytesBuffer=K.Buffer&&K.Buffer.prototype instanceof Uint8Array&&K.Buffer.prototype.set.name==="set"?function(Z,q,G){q.set(Z,G)}:function(Z,q,G){if(Z.copy)Z.copy(q,G,0,Z.length);else for(var J=0;J<Z.length;)q[G++]=Z[J++]}},W.prototype.bytes=function(Z){K.isString(Z)&&(Z=K._Buffer_from(Z,"base64"));var q=Z.length>>>0;return this.uint32(q),q&&this._push(W.writeBytesBuffer,q,Z),this};function U(Z,q,G){Z.length<40?K.utf8.write(Z,q,G):q.utf8Write?q.utf8Write(Z,G):q.write(Z,G)}W.prototype.string=function(Z){var q=K.Buffer.byteLength(Z);return this.uint32(q),q&&this._push(U,q,Z),this},W._configure()}),r2=U1((Q,H)=>{H.exports=q;var j=n3(),K,W=j.LongBits,U=j.utf8;function Z(z,Y){return RangeError("index out of range: "+z.pos+" + "+(Y||1)+" > "+z.len)}function q(z){this.buf=z,this.pos=0,this.len=z.length}var G=typeof Uint8Array<"u"?function(z){if(z instanceof Uint8Array||Array.isArray(z))return new q(z);throw Error("illegal buffer")}:function(z){if(Array.isArray(z))return new q(z);throw Error("illegal buffer")},J=function(){return j.Buffer?function(z){return(q.create=function(Y){return j.Buffer.isBuffer(Y)?new K(Y):G(Y)})(z)}:G};q.create=J(),q.prototype._slice=j.Array.prototype.subarray||j.Array.prototype.slice,q.prototype.uint32=function(){var z=4294967295;return function(){if(z=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(z=(z|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(z=(z|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(z=(z|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(z=(z|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return z;if((this.pos+=5)>this.len)throw this.pos=this.len,Z(this,10);return z}}(),q.prototype.int32=function(){return this.uint32()|0},q.prototype.sint32=function(){var z=this.uint32();return z>>>1^-(z&1)|0};function X(){var z=new W(0,0),Y=0;if(this.len-this.pos>4){for(;Y<4;++Y)if(z.lo=(z.lo|(this.buf[this.pos]&127)<<Y*7)>>>0,this.buf[this.pos++]<128)return z;if(z.lo=(z.lo|(this.buf[this.pos]&127)<<28)>>>0,z.hi=(z.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return z;Y=0}else{for(;Y<3;++Y){if(this.pos>=this.len)throw Z(this);if(z.lo=(z.lo|(this.buf[this.pos]&127)<<Y*7)>>>0,this.buf[this.pos++]<128)return z}return z.lo=(z.lo|(this.buf[this.pos++]&127)<<Y*7)>>>0,z}if(this.len-this.pos>4){for(;Y<5;++Y)if(z.hi=(z.hi|(this.buf[this.pos]&127)<<Y*7+3)>>>0,this.buf[this.pos++]<128)return z}else for(;Y<5;++Y){if(this.pos>=this.len)throw Z(this);if(z.hi=(z.hi|(this.buf[this.pos]&127)<<Y*7+3)>>>0,this.buf[this.pos++]<128)return z}throw Error("invalid varint encoding")}q.prototype.bool=function(){return this.uint32()!==0};function V(z,Y){return(z[Y-4]|z[Y-3]<<8|z[Y-2]<<16|z[Y-1]<<24)>>>0}q.prototype.fixed32=function(){if(this.pos+4>this.len)throw Z(this,4);return V(this.buf,this.pos+=4)},q.prototype.sfixed32=function(){if(this.pos+4>this.len)throw Z(this,4);return V(this.buf,this.pos+=4)|0};function R(){if(this.pos+8>this.len)throw Z(this,8);return new W(V(this.buf,this.pos+=4),V(this.buf,this.pos+=4))}q.prototype.float=function(){if(this.pos+4>this.len)throw Z(this,4);var z=j.float.readFloatLE(this.buf,this.pos);return this.pos+=4,z},q.prototype.double=function(){if(this.pos+8>this.len)throw Z(this,4);var z=j.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,z},q.prototype.bytes=function(){var z=this.uint32(),Y=this.pos,B=this.pos+z;if(B>this.len)throw Z(this,z);if(this.pos+=z,Array.isArray(this.buf))return this.buf.slice(Y,B);if(Y===B){var k=j.Buffer;return k?k.alloc(0):new this.buf.constructor(0)}return this._slice.call(this.buf,Y,B)},q.prototype.string=function(){var z=this.bytes();return U.read(z,0,z.length)},q.prototype.skip=function(z){if(typeof z=="number"){if(this.pos+z>this.len)throw Z(this,z);this.pos+=z}else do if(this.pos>=this.len)throw Z(this);while(this.buf[this.pos++]&128);return this},q.prototype.skipType=function(z){switch(z){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(z=this.uint32()&7)!==4;)this.skipType(z);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+z+" at offset "+this.pos)}return this},q._configure=function(z){K=z,q.create=J(),K._configure();var Y=j.Long?"toLong":"toNumber";j.merge(q.prototype,{int64:function(){return X.call(this)[Y](!1)},uint64:function(){return X.call(this)[Y](!0)},sint64:function(){return X.call(this).zzDecode()[Y](!1)},fixed64:function(){return R.call(this)[Y](!0)},sfixed64:function(){return R.call(this)[Y](!1)}})}}),Xj=U1((Q,H)=>{H.exports=W;var j=r2();(W.prototype=Object.create(j.prototype)).constructor=W;var K=n3();function W(U){j.call(this,U)}W._configure=function(){K.Buffer&&(W.prototype._slice=K.Buffer.prototype.slice)},W.prototype.string=function(){var U=this.uint32();return this.buf.utf8Slice?this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+U,this.len)):this.buf.toString("utf-8",this.pos,this.pos=Math.min(this.pos+U,this.len))},W._configure()}),Kj=U1((Q,H)=>{H.exports=K;var j=n3();(K.prototype=Object.create(j.EventEmitter.prototype)).constructor=K;function K(W,U,Z){if(typeof W!="function")throw TypeError("rpcImpl must be a function");j.EventEmitter.call(this),this.rpcImpl=W,this.requestDelimited=!!U,this.responseDelimited=!!Z}K.prototype.rpcCall=function W(U,Z,q,G,J){if(!G)throw TypeError("request must be specified");var X=this;if(!J)return j.asPromise(W,X,U,Z,q,G);if(!X.rpcImpl){setTimeout(function(){J(Error("already ended"))},0);return}try{return X.rpcImpl(U,Z[X.requestDelimited?"encodeDelimited":"encode"](G).finish(),function(V,R){if(V)return X.emit("error",V,U),J(V);if(R===null){X.end(!0);return}if(!(R instanceof q))try{R=q[X.responseDelimited?"decodeDelimited":"decode"](R)}catch(z){return X.emit("error",z,U),J(z)}return X.emit("data",R,U),J(null,R)})}catch(V){X.emit("error",V,U),setTimeout(function(){J(V)},0);return}},K.prototype.end=function(W){return this.rpcImpl&&(W||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this}}),Uj=U1((Q)=>{var H=Q;H.Service=Kj()}),qj=U1((Q,H)=>{H.exports={}}),Wj=U1((Q)=>{var H=Q;H.build="minimal",H.Writer=n2(),H.BufferWriter=Vj(),H.Reader=r2(),H.BufferReader=Xj(),H.util=n3(),H.rpc=Uj(),H.roots=qj(),H.configure=j;function j(){H.util._configure(),H.Writer._configure(H.BufferWriter),H.Reader._configure(H.BufferReader)}j()}),Gj=U1((Q,H)=>{H.exports=Wj()}),l4=U1((Q,H)=>{var j=Gj(),K=j.Reader,W=j.Writer,U=j.util,Z=j.roots.default||(j.roots.default={});Z.onnx=function(){var q={};return q.Version=function(){var G={},J=Object.create(G);return J[G[0]="_START_VERSION"]=0,J[G[1]="IR_VERSION_2017_10_10"]=1,J[G[2]="IR_VERSION_2017_10_30"]=2,J[G[3]="IR_VERSION_2017_11_3"]=3,J[G[4]="IR_VERSION_2019_1_22"]=4,J[G[5]="IR_VERSION_2019_3_18"]=5,J[G[6]="IR_VERSION_2019_9_19"]=6,J[G[7]="IR_VERSION_2020_5_8"]=7,J[G[8]="IR_VERSION_2021_7_30"]=8,J[G[9]="IR_VERSION"]=9,J}(),q.AttributeProto=function(){function G(J){if(this.floats=[],this.ints=[],this.strings=[],this.tensors=[],this.graphs=[],this.sparseTensors=[],this.typeProtos=[],J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.name="",G.prototype.refAttrName="",G.prototype.docString="",G.prototype.type=0,G.prototype.f=0,G.prototype.i=U.Long?U.Long.fromBits(0,0,!1):0,G.prototype.s=U.newBuffer([]),G.prototype.t=null,G.prototype.g=null,G.prototype.sparseTensor=null,G.prototype.tp=null,G.prototype.floats=U.emptyArray,G.prototype.ints=U.emptyArray,G.prototype.strings=U.emptyArray,G.prototype.tensors=U.emptyArray,G.prototype.graphs=U.emptyArray,G.prototype.sparseTensors=U.emptyArray,G.prototype.typeProtos=U.emptyArray,G.create=function(J){return new G(J)},G.encode=function(J,X){if(X||(X=W.create()),J.name!=null&&Object.hasOwnProperty.call(J,"name")&&X.uint32(10).string(J.name),J.f!=null&&Object.hasOwnProperty.call(J,"f")&&X.uint32(21).float(J.f),J.i!=null&&Object.hasOwnProperty.call(J,"i")&&X.uint32(24).int64(J.i),J.s!=null&&Object.hasOwnProperty.call(J,"s")&&X.uint32(34).bytes(J.s),J.t!=null&&Object.hasOwnProperty.call(J,"t")&&Z.onnx.TensorProto.encode(J.t,X.uint32(42).fork()).ldelim(),J.g!=null&&Object.hasOwnProperty.call(J,"g")&&Z.onnx.GraphProto.encode(J.g,X.uint32(50).fork()).ldelim(),J.floats!=null&&J.floats.length){X.uint32(58).fork();for(var V=0;V<J.floats.length;++V)X.float(J.floats[V]);X.ldelim()}if(J.ints!=null&&J.ints.length){X.uint32(66).fork();for(var V=0;V<J.ints.length;++V)X.int64(J.ints[V]);X.ldelim()}if(J.strings!=null&&J.strings.length)for(var V=0;V<J.strings.length;++V)X.uint32(74).bytes(J.strings[V]);if(J.tensors!=null&&J.tensors.length)for(var V=0;V<J.tensors.length;++V)Z.onnx.TensorProto.encode(J.tensors[V],X.uint32(82).fork()).ldelim();if(J.graphs!=null&&J.graphs.length)for(var V=0;V<J.graphs.length;++V)Z.onnx.GraphProto.encode(J.graphs[V],X.uint32(90).fork()).ldelim();if(J.docString!=null&&Object.hasOwnProperty.call(J,"docString")&&X.uint32(106).string(J.docString),J.tp!=null&&Object.hasOwnProperty.call(J,"tp")&&Z.onnx.TypeProto.encode(J.tp,X.uint32(114).fork()).ldelim(),J.typeProtos!=null&&J.typeProtos.length)for(var V=0;V<J.typeProtos.length;++V)Z.onnx.TypeProto.encode(J.typeProtos[V],X.uint32(122).fork()).ldelim();if(J.type!=null&&Object.hasOwnProperty.call(J,"type")&&X.uint32(160).int32(J.type),J.refAttrName!=null&&Object.hasOwnProperty.call(J,"refAttrName")&&X.uint32(170).string(J.refAttrName),J.sparseTensor!=null&&Object.hasOwnProperty.call(J,"sparseTensor")&&Z.onnx.SparseTensorProto.encode(J.sparseTensor,X.uint32(178).fork()).ldelim(),J.sparseTensors!=null&&J.sparseTensors.length)for(var V=0;V<J.sparseTensors.length;++V)Z.onnx.SparseTensorProto.encode(J.sparseTensors[V],X.uint32(186).fork()).ldelim();return X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.AttributeProto;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{R.name=J.string();break}case 21:{R.refAttrName=J.string();break}case 13:{R.docString=J.string();break}case 20:{R.type=J.int32();break}case 2:{R.f=J.float();break}case 3:{R.i=J.int64();break}case 4:{R.s=J.bytes();break}case 5:{R.t=Z.onnx.TensorProto.decode(J,J.uint32());break}case 6:{R.g=Z.onnx.GraphProto.decode(J,J.uint32());break}case 22:{R.sparseTensor=Z.onnx.SparseTensorProto.decode(J,J.uint32());break}case 14:{R.tp=Z.onnx.TypeProto.decode(J,J.uint32());break}case 7:{if(R.floats&&R.floats.length||(R.floats=[]),(z&7)===2)for(var Y=J.uint32()+J.pos;J.pos<Y;)R.floats.push(J.float());else R.floats.push(J.float());break}case 8:{if(R.ints&&R.ints.length||(R.ints=[]),(z&7)===2)for(var Y=J.uint32()+J.pos;J.pos<Y;)R.ints.push(J.int64());else R.ints.push(J.int64());break}case 9:{R.strings&&R.strings.length||(R.strings=[]),R.strings.push(J.bytes());break}case 10:{R.tensors&&R.tensors.length||(R.tensors=[]),R.tensors.push(Z.onnx.TensorProto.decode(J,J.uint32()));break}case 11:{R.graphs&&R.graphs.length||(R.graphs=[]),R.graphs.push(Z.onnx.GraphProto.decode(J,J.uint32()));break}case 23:{R.sparseTensors&&R.sparseTensors.length||(R.sparseTensors=[]),R.sparseTensors.push(Z.onnx.SparseTensorProto.decode(J,J.uint32()));break}case 15:{R.typeProtos&&R.typeProtos.length||(R.typeProtos=[]),R.typeProtos.push(Z.onnx.TypeProto.decode(J,J.uint32()));break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){if(typeof J!="object"||J===null)return"object expected";if(J.name!=null&&J.hasOwnProperty("name")&&!U.isString(J.name))return"name: string expected";if(J.refAttrName!=null&&J.hasOwnProperty("refAttrName")&&!U.isString(J.refAttrName))return"refAttrName: string expected";if(J.docString!=null&&J.hasOwnProperty("docString")&&!U.isString(J.docString))return"docString: string expected";if(J.type!=null&&J.hasOwnProperty("type"))switch(J.type){default:return"type: enum value expected";case 0:case 1:case 2:case 3:case 4:case 5:case 11:case 13:case 6:case 7:case 8:case 9:case 10:case 12:case 14:break}if(J.f!=null&&J.hasOwnProperty("f")&&typeof J.f!="number")return"f: number expected";if(J.i!=null&&J.hasOwnProperty("i")&&!U.isInteger(J.i)&&!(J.i&&U.isInteger(J.i.low)&&U.isInteger(J.i.high)))return"i: integer|Long expected";if(J.s!=null&&J.hasOwnProperty("s")&&!(J.s&&typeof J.s.length=="number"||U.isString(J.s)))return"s: buffer expected";if(J.t!=null&&J.hasOwnProperty("t")){var X=Z.onnx.TensorProto.verify(J.t);if(X)return"t."+X}if(J.g!=null&&J.hasOwnProperty("g")){var X=Z.onnx.GraphProto.verify(J.g);if(X)return"g."+X}if(J.sparseTensor!=null&&J.hasOwnProperty("sparseTensor")){var X=Z.onnx.SparseTensorProto.verify(J.sparseTensor);if(X)return"sparseTensor."+X}if(J.tp!=null&&J.hasOwnProperty("tp")){var X=Z.onnx.TypeProto.verify(J.tp);if(X)return"tp."+X}if(J.floats!=null&&J.hasOwnProperty("floats")){if(!Array.isArray(J.floats))return"floats: array expected";for(var V=0;V<J.floats.length;++V)if(typeof J.floats[V]!="number")return"floats: number[] expected"}if(J.ints!=null&&J.hasOwnProperty("ints")){if(!Array.isArray(J.ints))return"ints: array expected";for(var V=0;V<J.ints.length;++V)if(!U.isInteger(J.ints[V])&&!(J.ints[V]&&U.isInteger(J.ints[V].low)&&U.isInteger(J.ints[V].high)))return"ints: integer|Long[] expected"}if(J.strings!=null&&J.hasOwnProperty("strings")){if(!Array.isArray(J.strings))return"strings: array expected";for(var V=0;V<J.strings.length;++V)if(!(J.strings[V]&&typeof J.strings[V].length=="number"||U.isString(J.strings[V])))return"strings: buffer[] expected"}if(J.tensors!=null&&J.hasOwnProperty("tensors")){if(!Array.isArray(J.tensors))return"tensors: array expected";for(var V=0;V<J.tensors.length;++V){var X=Z.onnx.TensorProto.verify(J.tensors[V]);if(X)return"tensors."+X}}if(J.graphs!=null&&J.hasOwnProperty("graphs")){if(!Array.isArray(J.graphs))return"graphs: array expected";for(var V=0;V<J.graphs.length;++V){var X=Z.onnx.GraphProto.verify(J.graphs[V]);if(X)return"graphs."+X}}if(J.sparseTensors!=null&&J.hasOwnProperty("sparseTensors")){if(!Array.isArray(J.sparseTensors))return"sparseTensors: array expected";for(var V=0;V<J.sparseTensors.length;++V){var X=Z.onnx.SparseTensorProto.verify(J.sparseTensors[V]);if(X)return"sparseTensors."+X}}if(J.typeProtos!=null&&J.hasOwnProperty("typeProtos")){if(!Array.isArray(J.typeProtos))return"typeProtos: array expected";for(var V=0;V<J.typeProtos.length;++V){var X=Z.onnx.TypeProto.verify(J.typeProtos[V]);if(X)return"typeProtos."+X}}return null},G.fromObject=function(J){if(J instanceof Z.onnx.AttributeProto)return J;var X=new Z.onnx.AttributeProto;switch(J.name!=null&&(X.name=String(J.name)),J.refAttrName!=null&&(X.refAttrName=String(J.refAttrName)),J.docString!=null&&(X.docString=String(J.docString)),J.type){default:if(typeof J.type=="number"){X.type=J.type;break}break;case"UNDEFINED":case 0:X.type=0;break;case"FLOAT":case 1:X.type=1;break;case"INT":case 2:X.type=2;break;case"STRING":case 3:X.type=3;break;case"TENSOR":case 4:X.type=4;break;case"GRAPH":case 5:X.type=5;break;case"SPARSE_TENSOR":case 11:X.type=11;break;case"TYPE_PROTO":case 13:X.type=13;break;case"FLOATS":case 6:X.type=6;break;case"INTS":case 7:X.type=7;break;case"STRINGS":case 8:X.type=8;break;case"TENSORS":case 9:X.type=9;break;case"GRAPHS":case 10:X.type=10;break;case"SPARSE_TENSORS":case 12:X.type=12;break;case"TYPE_PROTOS":case 14:X.type=14;break}if(J.f!=null&&(X.f=Number(J.f)),J.i!=null&&(U.Long?(X.i=U.Long.fromValue(J.i)).unsigned=!1:typeof J.i=="string"?X.i=parseInt(J.i,10):typeof J.i=="number"?X.i=J.i:typeof J.i=="object"&&(X.i=new U.LongBits(J.i.low>>>0,J.i.high>>>0).toNumber())),J.s!=null&&(typeof J.s=="string"?U.base64.decode(J.s,X.s=U.newBuffer(U.base64.length(J.s)),0):J.s.length>=0&&(X.s=J.s)),J.t!=null){if(typeof J.t!="object")throw TypeError(".onnx.AttributeProto.t: object expected");X.t=Z.onnx.TensorProto.fromObject(J.t)}if(J.g!=null){if(typeof J.g!="object")throw TypeError(".onnx.AttributeProto.g: object expected");X.g=Z.onnx.GraphProto.fromObject(J.g)}if(J.sparseTensor!=null){if(typeof J.sparseTensor!="object")throw TypeError(".onnx.AttributeProto.sparseTensor: object expected");X.sparseTensor=Z.onnx.SparseTensorProto.fromObject(J.sparseTensor)}if(J.tp!=null){if(typeof J.tp!="object")throw TypeError(".onnx.AttributeProto.tp: object expected");X.tp=Z.onnx.TypeProto.fromObject(J.tp)}if(J.floats){if(!Array.isArray(J.floats))throw TypeError(".onnx.AttributeProto.floats: array expected");X.floats=[];for(var V=0;V<J.floats.length;++V)X.floats[V]=Number(J.floats[V])}if(J.ints){if(!Array.isArray(J.ints))throw TypeError(".onnx.AttributeProto.ints: array expected");X.ints=[];for(var V=0;V<J.ints.length;++V)U.Long?(X.ints[V]=U.Long.fromValue(J.ints[V])).unsigned=!1:typeof J.ints[V]=="string"?X.ints[V]=parseInt(J.ints[V],10):typeof J.ints[V]=="number"?X.ints[V]=J.ints[V]:typeof J.ints[V]=="object"&&(X.ints[V]=new U.LongBits(J.ints[V].low>>>0,J.ints[V].high>>>0).toNumber())}if(J.strings){if(!Array.isArray(J.strings))throw TypeError(".onnx.AttributeProto.strings: array expected");X.strings=[];for(var V=0;V<J.strings.length;++V)typeof J.strings[V]=="string"?U.base64.decode(J.strings[V],X.strings[V]=U.newBuffer(U.base64.length(J.strings[V])),0):J.strings[V].length>=0&&(X.strings[V]=J.strings[V])}if(J.tensors){if(!Array.isArray(J.tensors))throw TypeError(".onnx.AttributeProto.tensors: array expected");X.tensors=[];for(var V=0;V<J.tensors.length;++V){if(typeof J.tensors[V]!="object")throw TypeError(".onnx.AttributeProto.tensors: object expected");X.tensors[V]=Z.onnx.TensorProto.fromObject(J.tensors[V])}}if(J.graphs){if(!Array.isArray(J.graphs))throw TypeError(".onnx.AttributeProto.graphs: array expected");X.graphs=[];for(var V=0;V<J.graphs.length;++V){if(typeof J.graphs[V]!="object")throw TypeError(".onnx.AttributeProto.graphs: object expected");X.graphs[V]=Z.onnx.GraphProto.fromObject(J.graphs[V])}}if(J.sparseTensors){if(!Array.isArray(J.sparseTensors))throw TypeError(".onnx.AttributeProto.sparseTensors: array expected");X.sparseTensors=[];for(var V=0;V<J.sparseTensors.length;++V){if(typeof J.sparseTensors[V]!="object")throw TypeError(".onnx.AttributeProto.sparseTensors: object expected");X.sparseTensors[V]=Z.onnx.SparseTensorProto.fromObject(J.sparseTensors[V])}}if(J.typeProtos){if(!Array.isArray(J.typeProtos))throw TypeError(".onnx.AttributeProto.typeProtos: array expected");X.typeProtos=[];for(var V=0;V<J.typeProtos.length;++V){if(typeof J.typeProtos[V]!="object")throw TypeError(".onnx.AttributeProto.typeProtos: object expected");X.typeProtos[V]=Z.onnx.TypeProto.fromObject(J.typeProtos[V])}}return X},G.toObject=function(J,X){X||(X={});var V={};if((X.arrays||X.defaults)&&(V.floats=[],V.ints=[],V.strings=[],V.tensors=[],V.graphs=[],V.typeProtos=[],V.sparseTensors=[]),X.defaults){if(V.name="",V.f=0,U.Long){var R=new U.Long(0,0,!1);V.i=X.longs===String?R.toString():X.longs===Number?R.toNumber():R}else V.i=X.longs===String?"0":0;X.bytes===String?V.s="":(V.s=[],X.bytes!==Array&&(V.s=U.newBuffer(V.s))),V.t=null,V.g=null,V.docString="",V.tp=null,V.type=X.enums===String?"UNDEFINED":0,V.refAttrName="",V.sparseTensor=null}if(J.name!=null&&J.hasOwnProperty("name")&&(V.name=J.name),J.f!=null&&J.hasOwnProperty("f")&&(V.f=X.json&&!isFinite(J.f)?String(J.f):J.f),J.i!=null&&J.hasOwnProperty("i")&&(typeof J.i=="number"?V.i=X.longs===String?String(J.i):J.i:V.i=X.longs===String?U.Long.prototype.toString.call(J.i):X.longs===Number?new U.LongBits(J.i.low>>>0,J.i.high>>>0).toNumber():J.i),J.s!=null&&J.hasOwnProperty("s")&&(V.s=X.bytes===String?U.base64.encode(J.s,0,J.s.length):X.bytes===Array?Array.prototype.slice.call(J.s):J.s),J.t!=null&&J.hasOwnProperty("t")&&(V.t=Z.onnx.TensorProto.toObject(J.t,X)),J.g!=null&&J.hasOwnProperty("g")&&(V.g=Z.onnx.GraphProto.toObject(J.g,X)),J.floats&&J.floats.length){V.floats=[];for(var z=0;z<J.floats.length;++z)V.floats[z]=X.json&&!isFinite(J.floats[z])?String(J.floats[z]):J.floats[z]}if(J.ints&&J.ints.length){V.ints=[];for(var z=0;z<J.ints.length;++z)typeof J.ints[z]=="number"?V.ints[z]=X.longs===String?String(J.ints[z]):J.ints[z]:V.ints[z]=X.longs===String?U.Long.prototype.toString.call(J.ints[z]):X.longs===Number?new U.LongBits(J.ints[z].low>>>0,J.ints[z].high>>>0).toNumber():J.ints[z]}if(J.strings&&J.strings.length){V.strings=[];for(var z=0;z<J.strings.length;++z)V.strings[z]=X.bytes===String?U.base64.encode(J.strings[z],0,J.strings[z].length):X.bytes===Array?Array.prototype.slice.call(J.strings[z]):J.strings[z]}if(J.tensors&&J.tensors.length){V.tensors=[];for(var z=0;z<J.tensors.length;++z)V.tensors[z]=Z.onnx.TensorProto.toObject(J.tensors[z],X)}if(J.graphs&&J.graphs.length){V.graphs=[];for(var z=0;z<J.graphs.length;++z)V.graphs[z]=Z.onnx.GraphProto.toObject(J.graphs[z],X)}if(J.docString!=null&&J.hasOwnProperty("docString")&&(V.docString=J.docString),J.tp!=null&&J.hasOwnProperty("tp")&&(V.tp=Z.onnx.TypeProto.toObject(J.tp,X)),J.typeProtos&&J.typeProtos.length){V.typeProtos=[];for(var z=0;z<J.typeProtos.length;++z)V.typeProtos[z]=Z.onnx.TypeProto.toObject(J.typeProtos[z],X)}if(J.type!=null&&J.hasOwnProperty("type")&&(V.type=X.enums===String?Z.onnx.AttributeProto.AttributeType[J.type]===void 0?J.type:Z.onnx.AttributeProto.AttributeType[J.type]:J.type),J.refAttrName!=null&&J.hasOwnProperty("refAttrName")&&(V.refAttrName=J.refAttrName),J.sparseTensor!=null&&J.hasOwnProperty("sparseTensor")&&(V.sparseTensor=Z.onnx.SparseTensorProto.toObject(J.sparseTensor,X)),J.sparseTensors&&J.sparseTensors.length){V.sparseTensors=[];for(var z=0;z<J.sparseTensors.length;++z)V.sparseTensors[z]=Z.onnx.SparseTensorProto.toObject(J.sparseTensors[z],X)}return V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.AttributeProto"},G.AttributeType=function(){var J={},X=Object.create(J);return X[J[0]="UNDEFINED"]=0,X[J[1]="FLOAT"]=1,X[J[2]="INT"]=2,X[J[3]="STRING"]=3,X[J[4]="TENSOR"]=4,X[J[5]="GRAPH"]=5,X[J[11]="SPARSE_TENSOR"]=11,X[J[13]="TYPE_PROTO"]=13,X[J[6]="FLOATS"]=6,X[J[7]="INTS"]=7,X[J[8]="STRINGS"]=8,X[J[9]="TENSORS"]=9,X[J[10]="GRAPHS"]=10,X[J[12]="SPARSE_TENSORS"]=12,X[J[14]="TYPE_PROTOS"]=14,X}(),G}(),q.ValueInfoProto=function(){function G(J){if(J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.name="",G.prototype.type=null,G.prototype.docString="",G.create=function(J){return new G(J)},G.encode=function(J,X){return X||(X=W.create()),J.name!=null&&Object.hasOwnProperty.call(J,"name")&&X.uint32(10).string(J.name),J.type!=null&&Object.hasOwnProperty.call(J,"type")&&Z.onnx.TypeProto.encode(J.type,X.uint32(18).fork()).ldelim(),J.docString!=null&&Object.hasOwnProperty.call(J,"docString")&&X.uint32(26).string(J.docString),X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.ValueInfoProto;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{R.name=J.string();break}case 2:{R.type=Z.onnx.TypeProto.decode(J,J.uint32());break}case 3:{R.docString=J.string();break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){if(typeof J!="object"||J===null)return"object expected";if(J.name!=null&&J.hasOwnProperty("name")&&!U.isString(J.name))return"name: string expected";if(J.type!=null&&J.hasOwnProperty("type")){var X=Z.onnx.TypeProto.verify(J.type);if(X)return"type."+X}return J.docString!=null&&J.hasOwnProperty("docString")&&!U.isString(J.docString)?"docString: string expected":null},G.fromObject=function(J){if(J instanceof Z.onnx.ValueInfoProto)return J;var X=new Z.onnx.ValueInfoProto;if(J.name!=null&&(X.name=String(J.name)),J.type!=null){if(typeof J.type!="object")throw TypeError(".onnx.ValueInfoProto.type: object expected");X.type=Z.onnx.TypeProto.fromObject(J.type)}return J.docString!=null&&(X.docString=String(J.docString)),X},G.toObject=function(J,X){X||(X={});var V={};return X.defaults&&(V.name="",V.type=null,V.docString=""),J.name!=null&&J.hasOwnProperty("name")&&(V.name=J.name),J.type!=null&&J.hasOwnProperty("type")&&(V.type=Z.onnx.TypeProto.toObject(J.type,X)),J.docString!=null&&J.hasOwnProperty("docString")&&(V.docString=J.docString),V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.ValueInfoProto"},G}(),q.NodeProto=function(){function G(J){if(this.input=[],this.output=[],this.attribute=[],J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.input=U.emptyArray,G.prototype.output=U.emptyArray,G.prototype.name="",G.prototype.opType="",G.prototype.domain="",G.prototype.attribute=U.emptyArray,G.prototype.docString="",G.create=function(J){return new G(J)},G.encode=function(J,X){if(X||(X=W.create()),J.input!=null&&J.input.length)for(var V=0;V<J.input.length;++V)X.uint32(10).string(J.input[V]);if(J.output!=null&&J.output.length)for(var V=0;V<J.output.length;++V)X.uint32(18).string(J.output[V]);if(J.name!=null&&Object.hasOwnProperty.call(J,"name")&&X.uint32(26).string(J.name),J.opType!=null&&Object.hasOwnProperty.call(J,"opType")&&X.uint32(34).string(J.opType),J.attribute!=null&&J.attribute.length)for(var V=0;V<J.attribute.length;++V)Z.onnx.AttributeProto.encode(J.attribute[V],X.uint32(42).fork()).ldelim();return J.docString!=null&&Object.hasOwnProperty.call(J,"docString")&&X.uint32(50).string(J.docString),J.domain!=null&&Object.hasOwnProperty.call(J,"domain")&&X.uint32(58).string(J.domain),X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.NodeProto;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{R.input&&R.input.length||(R.input=[]),R.input.push(J.string());break}case 2:{R.output&&R.output.length||(R.output=[]),R.output.push(J.string());break}case 3:{R.name=J.string();break}case 4:{R.opType=J.string();break}case 7:{R.domain=J.string();break}case 5:{R.attribute&&R.attribute.length||(R.attribute=[]),R.attribute.push(Z.onnx.AttributeProto.decode(J,J.uint32()));break}case 6:{R.docString=J.string();break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){if(typeof J!="object"||J===null)return"object expected";if(J.input!=null&&J.hasOwnProperty("input")){if(!Array.isArray(J.input))return"input: array expected";for(var X=0;X<J.input.length;++X)if(!U.isString(J.input[X]))return"input: string[] expected"}if(J.output!=null&&J.hasOwnProperty("output")){if(!Array.isArray(J.output))return"output: array expected";for(var X=0;X<J.output.length;++X)if(!U.isString(J.output[X]))return"output: string[] expected"}if(J.name!=null&&J.hasOwnProperty("name")&&!U.isString(J.name))return"name: string expected";if(J.opType!=null&&J.hasOwnProperty("opType")&&!U.isString(J.opType))return"opType: string expected";if(J.domain!=null&&J.hasOwnProperty("domain")&&!U.isString(J.domain))return"domain: string expected";if(J.attribute!=null&&J.hasOwnProperty("attribute")){if(!Array.isArray(J.attribute))return"attribute: array expected";for(var X=0;X<J.attribute.length;++X){var V=Z.onnx.AttributeProto.verify(J.attribute[X]);if(V)return"attribute."+V}}return J.docString!=null&&J.hasOwnProperty("docString")&&!U.isString(J.docString)?"docString: string expected":null},G.fromObject=function(J){if(J instanceof Z.onnx.NodeProto)return J;var X=new Z.onnx.NodeProto;if(J.input){if(!Array.isArray(J.input))throw TypeError(".onnx.NodeProto.input: array expected");X.input=[];for(var V=0;V<J.input.length;++V)X.input[V]=String(J.input[V])}if(J.output){if(!Array.isArray(J.output))throw TypeError(".onnx.NodeProto.output: array expected");X.output=[];for(var V=0;V<J.output.length;++V)X.output[V]=String(J.output[V])}if(J.name!=null&&(X.name=String(J.name)),J.opType!=null&&(X.opType=String(J.opType)),J.domain!=null&&(X.domain=String(J.domain)),J.attribute){if(!Array.isArray(J.attribute))throw TypeError(".onnx.NodeProto.attribute: array expected");X.attribute=[];for(var V=0;V<J.attribute.length;++V){if(typeof J.attribute[V]!="object")throw TypeError(".onnx.NodeProto.attribute: object expected");X.attribute[V]=Z.onnx.AttributeProto.fromObject(J.attribute[V])}}return J.docString!=null&&(X.docString=String(J.docString)),X},G.toObject=function(J,X){X||(X={});var V={};if((X.arrays||X.defaults)&&(V.input=[],V.output=[],V.attribute=[]),X.defaults&&(V.name="",V.opType="",V.docString="",V.domain=""),J.input&&J.input.length){V.input=[];for(var R=0;R<J.input.length;++R)V.input[R]=J.input[R]}if(J.output&&J.output.length){V.output=[];for(var R=0;R<J.output.length;++R)V.output[R]=J.output[R]}if(J.name!=null&&J.hasOwnProperty("name")&&(V.name=J.name),J.opType!=null&&J.hasOwnProperty("opType")&&(V.opType=J.opType),J.attribute&&J.attribute.length){V.attribute=[];for(var R=0;R<J.attribute.length;++R)V.attribute[R]=Z.onnx.AttributeProto.toObject(J.attribute[R],X)}return J.docString!=null&&J.hasOwnProperty("docString")&&(V.docString=J.docString),J.domain!=null&&J.hasOwnProperty("domain")&&(V.domain=J.domain),V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.NodeProto"},G}(),q.TrainingInfoProto=function(){function G(J){if(this.initializationBinding=[],this.updateBinding=[],J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.initialization=null,G.prototype.algorithm=null,G.prototype.initializationBinding=U.emptyArray,G.prototype.updateBinding=U.emptyArray,G.create=function(J){return new G(J)},G.encode=function(J,X){if(X||(X=W.create()),J.initialization!=null&&Object.hasOwnProperty.call(J,"initialization")&&Z.onnx.GraphProto.encode(J.initialization,X.uint32(10).fork()).ldelim(),J.algorithm!=null&&Object.hasOwnProperty.call(J,"algorithm")&&Z.onnx.GraphProto.encode(J.algorithm,X.uint32(18).fork()).ldelim(),J.initializationBinding!=null&&J.initializationBinding.length)for(var V=0;V<J.initializationBinding.length;++V)Z.onnx.StringStringEntryProto.encode(J.initializationBinding[V],X.uint32(26).fork()).ldelim();if(J.updateBinding!=null&&J.updateBinding.length)for(var V=0;V<J.updateBinding.length;++V)Z.onnx.StringStringEntryProto.encode(J.updateBinding[V],X.uint32(34).fork()).ldelim();return X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.TrainingInfoProto;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{R.initialization=Z.onnx.GraphProto.decode(J,J.uint32());break}case 2:{R.algorithm=Z.onnx.GraphProto.decode(J,J.uint32());break}case 3:{R.initializationBinding&&R.initializationBinding.length||(R.initializationBinding=[]),R.initializationBinding.push(Z.onnx.StringStringEntryProto.decode(J,J.uint32()));break}case 4:{R.updateBinding&&R.updateBinding.length||(R.updateBinding=[]),R.updateBinding.push(Z.onnx.StringStringEntryProto.decode(J,J.uint32()));break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){if(typeof J!="object"||J===null)return"object expected";if(J.initialization!=null&&J.hasOwnProperty("initialization")){var X=Z.onnx.GraphProto.verify(J.initialization);if(X)return"initialization."+X}if(J.algorithm!=null&&J.hasOwnProperty("algorithm")){var X=Z.onnx.GraphProto.verify(J.algorithm);if(X)return"algorithm."+X}if(J.initializationBinding!=null&&J.hasOwnProperty("initializationBinding")){if(!Array.isArray(J.initializationBinding))return"initializationBinding: array expected";for(var V=0;V<J.initializationBinding.length;++V){var X=Z.onnx.StringStringEntryProto.verify(J.initializationBinding[V]);if(X)return"initializationBinding."+X}}if(J.updateBinding!=null&&J.hasOwnProperty("updateBinding")){if(!Array.isArray(J.updateBinding))return"updateBinding: array expected";for(var V=0;V<J.updateBinding.length;++V){var X=Z.onnx.StringStringEntryProto.verify(J.updateBinding[V]);if(X)return"updateBinding."+X}}return null},G.fromObject=function(J){if(J instanceof Z.onnx.TrainingInfoProto)return J;var X=new Z.onnx.TrainingInfoProto;if(J.initialization!=null){if(typeof J.initialization!="object")throw TypeError(".onnx.TrainingInfoProto.initialization: object expected");X.initialization=Z.onnx.GraphProto.fromObject(J.initialization)}if(J.algorithm!=null){if(typeof J.algorithm!="object")throw TypeError(".onnx.TrainingInfoProto.algorithm: object expected");X.algorithm=Z.onnx.GraphProto.fromObject(J.algorithm)}if(J.initializationBinding){if(!Array.isArray(J.initializationBinding))throw TypeError(".onnx.TrainingInfoProto.initializationBinding: array expected");X.initializationBinding=[];for(var V=0;V<J.initializationBinding.length;++V){if(typeof J.initializationBinding[V]!="object")throw TypeError(".onnx.TrainingInfoProto.initializationBinding: object expected");X.initializationBinding[V]=Z.onnx.StringStringEntryProto.fromObject(J.initializationBinding[V])}}if(J.updateBinding){if(!Array.isArray(J.updateBinding))throw TypeError(".onnx.TrainingInfoProto.updateBinding: array expected");X.updateBinding=[];for(var V=0;V<J.updateBinding.length;++V){if(typeof J.updateBinding[V]!="object")throw TypeError(".onnx.TrainingInfoProto.updateBinding: object expected");X.updateBinding[V]=Z.onnx.StringStringEntryProto.fromObject(J.updateBinding[V])}}return X},G.toObject=function(J,X){X||(X={});var V={};if((X.arrays||X.defaults)&&(V.initializationBinding=[],V.updateBinding=[]),X.defaults&&(V.initialization=null,V.algorithm=null),J.initialization!=null&&J.hasOwnProperty("initialization")&&(V.initialization=Z.onnx.GraphProto.toObject(J.initialization,X)),J.algorithm!=null&&J.hasOwnProperty("algorithm")&&(V.algorithm=Z.onnx.GraphProto.toObject(J.algorithm,X)),J.initializationBinding&&J.initializationBinding.length){V.initializationBinding=[];for(var R=0;R<J.initializationBinding.length;++R)V.initializationBinding[R]=Z.onnx.StringStringEntryProto.toObject(J.initializationBinding[R],X)}if(J.updateBinding&&J.updateBinding.length){V.updateBinding=[];for(var R=0;R<J.updateBinding.length;++R)V.updateBinding[R]=Z.onnx.StringStringEntryProto.toObject(J.updateBinding[R],X)}return V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.TrainingInfoProto"},G}(),q.ModelProto=function(){function G(J){if(this.opsetImport=[],this.metadataProps=[],this.trainingInfo=[],this.functions=[],J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.irVersion=U.Long?U.Long.fromBits(0,0,!1):0,G.prototype.opsetImport=U.emptyArray,G.prototype.producerName="",G.prototype.producerVersion="",G.prototype.domain="",G.prototype.modelVersion=U.Long?U.Long.fromBits(0,0,!1):0,G.prototype.docString="",G.prototype.graph=null,G.prototype.metadataProps=U.emptyArray,G.prototype.trainingInfo=U.emptyArray,G.prototype.functions=U.emptyArray,G.create=function(J){return new G(J)},G.encode=function(J,X){if(X||(X=W.create()),J.irVersion!=null&&Object.hasOwnProperty.call(J,"irVersion")&&X.uint32(8).int64(J.irVersion),J.producerName!=null&&Object.hasOwnProperty.call(J,"producerName")&&X.uint32(18).string(J.producerName),J.producerVersion!=null&&Object.hasOwnProperty.call(J,"producerVersion")&&X.uint32(26).string(J.producerVersion),J.domain!=null&&Object.hasOwnProperty.call(J,"domain")&&X.uint32(34).string(J.domain),J.modelVersion!=null&&Object.hasOwnProperty.call(J,"modelVersion")&&X.uint32(40).int64(J.modelVersion),J.docString!=null&&Object.hasOwnProperty.call(J,"docString")&&X.uint32(50).string(J.docString),J.graph!=null&&Object.hasOwnProperty.call(J,"graph")&&Z.onnx.GraphProto.encode(J.graph,X.uint32(58).fork()).ldelim(),J.opsetImport!=null&&J.opsetImport.length)for(var V=0;V<J.opsetImport.length;++V)Z.onnx.OperatorSetIdProto.encode(J.opsetImport[V],X.uint32(66).fork()).ldelim();if(J.metadataProps!=null&&J.metadataProps.length)for(var V=0;V<J.metadataProps.length;++V)Z.onnx.StringStringEntryProto.encode(J.metadataProps[V],X.uint32(114).fork()).ldelim();if(J.trainingInfo!=null&&J.trainingInfo.length)for(var V=0;V<J.trainingInfo.length;++V)Z.onnx.TrainingInfoProto.encode(J.trainingInfo[V],X.uint32(162).fork()).ldelim();if(J.functions!=null&&J.functions.length)for(var V=0;V<J.functions.length;++V)Z.onnx.FunctionProto.encode(J.functions[V],X.uint32(202).fork()).ldelim();return X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.ModelProto;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{R.irVersion=J.int64();break}case 8:{R.opsetImport&&R.opsetImport.length||(R.opsetImport=[]),R.opsetImport.push(Z.onnx.OperatorSetIdProto.decode(J,J.uint32()));break}case 2:{R.producerName=J.string();break}case 3:{R.producerVersion=J.string();break}case 4:{R.domain=J.string();break}case 5:{R.modelVersion=J.int64();break}case 6:{R.docString=J.string();break}case 7:{R.graph=Z.onnx.GraphProto.decode(J,J.uint32());break}case 14:{R.metadataProps&&R.metadataProps.length||(R.metadataProps=[]),R.metadataProps.push(Z.onnx.StringStringEntryProto.decode(J,J.uint32()));break}case 20:{R.trainingInfo&&R.trainingInfo.length||(R.trainingInfo=[]),R.trainingInfo.push(Z.onnx.TrainingInfoProto.decode(J,J.uint32()));break}case 25:{R.functions&&R.functions.length||(R.functions=[]),R.functions.push(Z.onnx.FunctionProto.decode(J,J.uint32()));break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){if(typeof J!="object"||J===null)return"object expected";if(J.irVersion!=null&&J.hasOwnProperty("irVersion")&&!U.isInteger(J.irVersion)&&!(J.irVersion&&U.isInteger(J.irVersion.low)&&U.isInteger(J.irVersion.high)))return"irVersion: integer|Long expected";if(J.opsetImport!=null&&J.hasOwnProperty("opsetImport")){if(!Array.isArray(J.opsetImport))return"opsetImport: array expected";for(var X=0;X<J.opsetImport.length;++X){var V=Z.onnx.OperatorSetIdProto.verify(J.opsetImport[X]);if(V)return"opsetImport."+V}}if(J.producerName!=null&&J.hasOwnProperty("producerName")&&!U.isString(J.producerName))return"producerName: string expected";if(J.producerVersion!=null&&J.hasOwnProperty("producerVersion")&&!U.isString(J.producerVersion))return"producerVersion: string expected";if(J.domain!=null&&J.hasOwnProperty("domain")&&!U.isString(J.domain))return"domain: string expected";if(J.modelVersion!=null&&J.hasOwnProperty("modelVersion")&&!U.isInteger(J.modelVersion)&&!(J.modelVersion&&U.isInteger(J.modelVersion.low)&&U.isInteger(J.modelVersion.high)))return"modelVersion: integer|Long expected";if(J.docString!=null&&J.hasOwnProperty("docString")&&!U.isString(J.docString))return"docString: string expected";if(J.graph!=null&&J.hasOwnProperty("graph")){var V=Z.onnx.GraphProto.verify(J.graph);if(V)return"graph."+V}if(J.metadataProps!=null&&J.hasOwnProperty("metadataProps")){if(!Array.isArray(J.metadataProps))return"metadataProps: array expected";for(var X=0;X<J.metadataProps.length;++X){var V=Z.onnx.StringStringEntryProto.verify(J.metadataProps[X]);if(V)return"metadataProps."+V}}if(J.trainingInfo!=null&&J.hasOwnProperty("trainingInfo")){if(!Array.isArray(J.trainingInfo))return"trainingInfo: array expected";for(var X=0;X<J.trainingInfo.length;++X){var V=Z.onnx.TrainingInfoProto.verify(J.trainingInfo[X]);if(V)return"trainingInfo."+V}}if(J.functions!=null&&J.hasOwnProperty("functions")){if(!Array.isArray(J.functions))return"functions: array expected";for(var X=0;X<J.functions.length;++X){var V=Z.onnx.FunctionProto.verify(J.functions[X]);if(V)return"functions."+V}}return null},G.fromObject=function(J){if(J instanceof Z.onnx.ModelProto)return J;var X=new Z.onnx.ModelProto;if(J.irVersion!=null&&(U.Long?(X.irVersion=U.Long.fromValue(J.irVersion)).unsigned=!1:typeof J.irVersion=="string"?X.irVersion=parseInt(J.irVersion,10):typeof J.irVersion=="number"?X.irVersion=J.irVersion:typeof J.irVersion=="object"&&(X.irVersion=new U.LongBits(J.irVersion.low>>>0,J.irVersion.high>>>0).toNumber())),J.opsetImport){if(!Array.isArray(J.opsetImport))throw TypeError(".onnx.ModelProto.opsetImport: array expected");X.opsetImport=[];for(var V=0;V<J.opsetImport.length;++V){if(typeof J.opsetImport[V]!="object")throw TypeError(".onnx.ModelProto.opsetImport: object expected");X.opsetImport[V]=Z.onnx.OperatorSetIdProto.fromObject(J.opsetImport[V])}}if(J.producerName!=null&&(X.producerName=String(J.producerName)),J.producerVersion!=null&&(X.producerVersion=String(J.producerVersion)),J.domain!=null&&(X.domain=String(J.domain)),J.modelVersion!=null&&(U.Long?(X.modelVersion=U.Long.fromValue(J.modelVersion)).unsigned=!1:typeof J.modelVersion=="string"?X.modelVersion=parseInt(J.modelVersion,10):typeof J.modelVersion=="number"?X.modelVersion=J.modelVersion:typeof J.modelVersion=="object"&&(X.modelVersion=new U.LongBits(J.modelVersion.low>>>0,J.modelVersion.high>>>0).toNumber())),J.docString!=null&&(X.docString=String(J.docString)),J.graph!=null){if(typeof J.graph!="object")throw TypeError(".onnx.ModelProto.graph: object expected");X.graph=Z.onnx.GraphProto.fromObject(J.graph)}if(J.metadataProps){if(!Array.isArray(J.metadataProps))throw TypeError(".onnx.ModelProto.metadataProps: array expected");X.metadataProps=[];for(var V=0;V<J.metadataProps.length;++V){if(typeof J.metadataProps[V]!="object")throw TypeError(".onnx.ModelProto.metadataProps: object expected");X.metadataProps[V]=Z.onnx.StringStringEntryProto.fromObject(J.metadataProps[V])}}if(J.trainingInfo){if(!Array.isArray(J.trainingInfo))throw TypeError(".onnx.ModelProto.trainingInfo: array expected");X.trainingInfo=[];for(var V=0;V<J.trainingInfo.length;++V){if(typeof J.trainingInfo[V]!="object")throw TypeError(".onnx.ModelProto.trainingInfo: object expected");X.trainingInfo[V]=Z.onnx.TrainingInfoProto.fromObject(J.trainingInfo[V])}}if(J.functions){if(!Array.isArray(J.functions))throw TypeError(".onnx.ModelProto.functions: array expected");X.functions=[];for(var V=0;V<J.functions.length;++V){if(typeof J.functions[V]!="object")throw TypeError(".onnx.ModelProto.functions: object expected");X.functions[V]=Z.onnx.FunctionProto.fromObject(J.functions[V])}}return X},G.toObject=function(J,X){X||(X={});var V={};if((X.arrays||X.defaults)&&(V.opsetImport=[],V.metadataProps=[],V.trainingInfo=[],V.functions=[]),X.defaults){if(U.Long){var R=new U.Long(0,0,!1);V.irVersion=X.longs===String?R.toString():X.longs===Number?R.toNumber():R}else V.irVersion=X.longs===String?"0":0;if(V.producerName="",V.producerVersion="",V.domain="",U.Long){var R=new U.Long(0,0,!1);V.modelVersion=X.longs===String?R.toString():X.longs===Number?R.toNumber():R}else V.modelVersion=X.longs===String?"0":0;V.docString="",V.graph=null}if(J.irVersion!=null&&J.hasOwnProperty("irVersion")&&(typeof J.irVersion=="number"?V.irVersion=X.longs===String?String(J.irVersion):J.irVersion:V.irVersion=X.longs===String?U.Long.prototype.toString.call(J.irVersion):X.longs===Number?new U.LongBits(J.irVersion.low>>>0,J.irVersion.high>>>0).toNumber():J.irVersion),J.producerName!=null&&J.hasOwnProperty("producerName")&&(V.producerName=J.producerName),J.producerVersion!=null&&J.hasOwnProperty("producerVersion")&&(V.producerVersion=J.producerVersion),J.domain!=null&&J.hasOwnProperty("domain")&&(V.domain=J.domain),J.modelVersion!=null&&J.hasOwnProperty("modelVersion")&&(typeof J.modelVersion=="number"?V.modelVersion=X.longs===String?String(J.modelVersion):J.modelVersion:V.modelVersion=X.longs===String?U.Long.prototype.toString.call(J.modelVersion):X.longs===Number?new U.LongBits(J.modelVersion.low>>>0,J.modelVersion.high>>>0).toNumber():J.modelVersion),J.docString!=null&&J.hasOwnProperty("docString")&&(V.docString=J.docString),J.graph!=null&&J.hasOwnProperty("graph")&&(V.graph=Z.onnx.GraphProto.toObject(J.graph,X)),J.opsetImport&&J.opsetImport.length){V.opsetImport=[];for(var z=0;z<J.opsetImport.length;++z)V.opsetImport[z]=Z.onnx.OperatorSetIdProto.toObject(J.opsetImport[z],X)}if(J.metadataProps&&J.metadataProps.length){V.metadataProps=[];for(var z=0;z<J.metadataProps.length;++z)V.metadataProps[z]=Z.onnx.StringStringEntryProto.toObject(J.metadataProps[z],X)}if(J.trainingInfo&&J.trainingInfo.length){V.trainingInfo=[];for(var z=0;z<J.trainingInfo.length;++z)V.trainingInfo[z]=Z.onnx.TrainingInfoProto.toObject(J.trainingInfo[z],X)}if(J.functions&&J.functions.length){V.functions=[];for(var z=0;z<J.functions.length;++z)V.functions[z]=Z.onnx.FunctionProto.toObject(J.functions[z],X)}return V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.ModelProto"},G}(),q.StringStringEntryProto=function(){function G(J){if(J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.key="",G.prototype.value="",G.create=function(J){return new G(J)},G.encode=function(J,X){return X||(X=W.create()),J.key!=null&&Object.hasOwnProperty.call(J,"key")&&X.uint32(10).string(J.key),J.value!=null&&Object.hasOwnProperty.call(J,"value")&&X.uint32(18).string(J.value),X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.StringStringEntryProto;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{R.key=J.string();break}case 2:{R.value=J.string();break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){return typeof J!="object"||J===null?"object expected":J.key!=null&&J.hasOwnProperty("key")&&!U.isString(J.key)?"key: string expected":J.value!=null&&J.hasOwnProperty("value")&&!U.isString(J.value)?"value: string expected":null},G.fromObject=function(J){if(J instanceof Z.onnx.StringStringEntryProto)return J;var X=new Z.onnx.StringStringEntryProto;return J.key!=null&&(X.key=String(J.key)),J.value!=null&&(X.value=String(J.value)),X},G.toObject=function(J,X){X||(X={});var V={};return X.defaults&&(V.key="",V.value=""),J.key!=null&&J.hasOwnProperty("key")&&(V.key=J.key),J.value!=null&&J.hasOwnProperty("value")&&(V.value=J.value),V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.StringStringEntryProto"},G}(),q.TensorAnnotation=function(){function G(J){if(this.quantParameterTensorNames=[],J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.tensorName="",G.prototype.quantParameterTensorNames=U.emptyArray,G.create=function(J){return new G(J)},G.encode=function(J,X){if(X||(X=W.create()),J.tensorName!=null&&Object.hasOwnProperty.call(J,"tensorName")&&X.uint32(10).string(J.tensorName),J.quantParameterTensorNames!=null&&J.quantParameterTensorNames.length)for(var V=0;V<J.quantParameterTensorNames.length;++V)Z.onnx.StringStringEntryProto.encode(J.quantParameterTensorNames[V],X.uint32(18).fork()).ldelim();return X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.TensorAnnotation;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{R.tensorName=J.string();break}case 2:{R.quantParameterTensorNames&&R.quantParameterTensorNames.length||(R.quantParameterTensorNames=[]),R.quantParameterTensorNames.push(Z.onnx.StringStringEntryProto.decode(J,J.uint32()));break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){if(typeof J!="object"||J===null)return"object expected";if(J.tensorName!=null&&J.hasOwnProperty("tensorName")&&!U.isString(J.tensorName))return"tensorName: string expected";if(J.quantParameterTensorNames!=null&&J.hasOwnProperty("quantParameterTensorNames")){if(!Array.isArray(J.quantParameterTensorNames))return"quantParameterTensorNames: array expected";for(var X=0;X<J.quantParameterTensorNames.length;++X){var V=Z.onnx.StringStringEntryProto.verify(J.quantParameterTensorNames[X]);if(V)return"quantParameterTensorNames."+V}}return null},G.fromObject=function(J){if(J instanceof Z.onnx.TensorAnnotation)return J;var X=new Z.onnx.TensorAnnotation;if(J.tensorName!=null&&(X.tensorName=String(J.tensorName)),J.quantParameterTensorNames){if(!Array.isArray(J.quantParameterTensorNames))throw TypeError(".onnx.TensorAnnotation.quantParameterTensorNames: array expected");X.quantParameterTensorNames=[];for(var V=0;V<J.quantParameterTensorNames.length;++V){if(typeof J.quantParameterTensorNames[V]!="object")throw TypeError(".onnx.TensorAnnotation.quantParameterTensorNames: object expected");X.quantParameterTensorNames[V]=Z.onnx.StringStringEntryProto.fromObject(J.quantParameterTensorNames[V])}}return X},G.toObject=function(J,X){X||(X={});var V={};if((X.arrays||X.defaults)&&(V.quantParameterTensorNames=[]),X.defaults&&(V.tensorName=""),J.tensorName!=null&&J.hasOwnProperty("tensorName")&&(V.tensorName=J.tensorName),J.quantParameterTensorNames&&J.quantParameterTensorNames.length){V.quantParameterTensorNames=[];for(var R=0;R<J.quantParameterTensorNames.length;++R)V.quantParameterTensorNames[R]=Z.onnx.StringStringEntryProto.toObject(J.quantParameterTensorNames[R],X)}return V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.TensorAnnotation"},G}(),q.GraphProto=function(){function G(J){if(this.node=[],this.initializer=[],this.sparseInitializer=[],this.input=[],this.output=[],this.valueInfo=[],this.quantizationAnnotation=[],J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.node=U.emptyArray,G.prototype.name="",G.prototype.initializer=U.emptyArray,G.prototype.sparseInitializer=U.emptyArray,G.prototype.docString="",G.prototype.input=U.emptyArray,G.prototype.output=U.emptyArray,G.prototype.valueInfo=U.emptyArray,G.prototype.quantizationAnnotation=U.emptyArray,G.create=function(J){return new G(J)},G.encode=function(J,X){if(X||(X=W.create()),J.node!=null&&J.node.length)for(var V=0;V<J.node.length;++V)Z.onnx.NodeProto.encode(J.node[V],X.uint32(10).fork()).ldelim();if(J.name!=null&&Object.hasOwnProperty.call(J,"name")&&X.uint32(18).string(J.name),J.initializer!=null&&J.initializer.length)for(var V=0;V<J.initializer.length;++V)Z.onnx.TensorProto.encode(J.initializer[V],X.uint32(42).fork()).ldelim();if(J.docString!=null&&Object.hasOwnProperty.call(J,"docString")&&X.uint32(82).string(J.docString),J.input!=null&&J.input.length)for(var V=0;V<J.input.length;++V)Z.onnx.ValueInfoProto.encode(J.input[V],X.uint32(90).fork()).ldelim();if(J.output!=null&&J.output.length)for(var V=0;V<J.output.length;++V)Z.onnx.ValueInfoProto.encode(J.output[V],X.uint32(98).fork()).ldelim();if(J.valueInfo!=null&&J.valueInfo.length)for(var V=0;V<J.valueInfo.length;++V)Z.onnx.ValueInfoProto.encode(J.valueInfo[V],X.uint32(106).fork()).ldelim();if(J.quantizationAnnotation!=null&&J.quantizationAnnotation.length)for(var V=0;V<J.quantizationAnnotation.length;++V)Z.onnx.TensorAnnotation.encode(J.quantizationAnnotation[V],X.uint32(114).fork()).ldelim();if(J.sparseInitializer!=null&&J.sparseInitializer.length)for(var V=0;V<J.sparseInitializer.length;++V)Z.onnx.SparseTensorProto.encode(J.sparseInitializer[V],X.uint32(122).fork()).ldelim();return X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.GraphProto;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{R.node&&R.node.length||(R.node=[]),R.node.push(Z.onnx.NodeProto.decode(J,J.uint32()));break}case 2:{R.name=J.string();break}case 5:{R.initializer&&R.initializer.length||(R.initializer=[]),R.initializer.push(Z.onnx.TensorProto.decode(J,J.uint32()));break}case 15:{R.sparseInitializer&&R.sparseInitializer.length||(R.sparseInitializer=[]),R.sparseInitializer.push(Z.onnx.SparseTensorProto.decode(J,J.uint32()));break}case 10:{R.docString=J.string();break}case 11:{R.input&&R.input.length||(R.input=[]),R.input.push(Z.onnx.ValueInfoProto.decode(J,J.uint32()));break}case 12:{R.output&&R.output.length||(R.output=[]),R.output.push(Z.onnx.ValueInfoProto.decode(J,J.uint32()));break}case 13:{R.valueInfo&&R.valueInfo.length||(R.valueInfo=[]),R.valueInfo.push(Z.onnx.ValueInfoProto.decode(J,J.uint32()));break}case 14:{R.quantizationAnnotation&&R.quantizationAnnotation.length||(R.quantizationAnnotation=[]),R.quantizationAnnotation.push(Z.onnx.TensorAnnotation.decode(J,J.uint32()));break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){if(typeof J!="object"||J===null)return"object expected";if(J.node!=null&&J.hasOwnProperty("node")){if(!Array.isArray(J.node))return"node: array expected";for(var X=0;X<J.node.length;++X){var V=Z.onnx.NodeProto.verify(J.node[X]);if(V)return"node."+V}}if(J.name!=null&&J.hasOwnProperty("name")&&!U.isString(J.name))return"name: string expected";if(J.initializer!=null&&J.hasOwnProperty("initializer")){if(!Array.isArray(J.initializer))return"initializer: array expected";for(var X=0;X<J.initializer.length;++X){var V=Z.onnx.TensorProto.verify(J.initializer[X]);if(V)return"initializer."+V}}if(J.sparseInitializer!=null&&J.hasOwnProperty("sparseInitializer")){if(!Array.isArray(J.sparseInitializer))return"sparseInitializer: array expected";for(var X=0;X<J.sparseInitializer.length;++X){var V=Z.onnx.SparseTensorProto.verify(J.sparseInitializer[X]);if(V)return"sparseInitializer."+V}}if(J.docString!=null&&J.hasOwnProperty("docString")&&!U.isString(J.docString))return"docString: string expected";if(J.input!=null&&J.hasOwnProperty("input")){if(!Array.isArray(J.input))return"input: array expected";for(var X=0;X<J.input.length;++X){var V=Z.onnx.ValueInfoProto.verify(J.input[X]);if(V)return"input."+V}}if(J.output!=null&&J.hasOwnProperty("output")){if(!Array.isArray(J.output))return"output: array expected";for(var X=0;X<J.output.length;++X){var V=Z.onnx.ValueInfoProto.verify(J.output[X]);if(V)return"output."+V}}if(J.valueInfo!=null&&J.hasOwnProperty("valueInfo")){if(!Array.isArray(J.valueInfo))return"valueInfo: array expected";for(var X=0;X<J.valueInfo.length;++X){var V=Z.onnx.ValueInfoProto.verify(J.valueInfo[X]);if(V)return"valueInfo."+V}}if(J.quantizationAnnotation!=null&&J.hasOwnProperty("quantizationAnnotation")){if(!Array.isArray(J.quantizationAnnotation))return"quantizationAnnotation: array expected";for(var X=0;X<J.quantizationAnnotation.length;++X){var V=Z.onnx.TensorAnnotation.verify(J.quantizationAnnotation[X]);if(V)return"quantizationAnnotation."+V}}return null},G.fromObject=function(J){if(J instanceof Z.onnx.GraphProto)return J;var X=new Z.onnx.GraphProto;if(J.node){if(!Array.isArray(J.node))throw TypeError(".onnx.GraphProto.node: array expected");X.node=[];for(var V=0;V<J.node.length;++V){if(typeof J.node[V]!="object")throw TypeError(".onnx.GraphProto.node: object expected");X.node[V]=Z.onnx.NodeProto.fromObject(J.node[V])}}if(J.name!=null&&(X.name=String(J.name)),J.initializer){if(!Array.isArray(J.initializer))throw TypeError(".onnx.GraphProto.initializer: array expected");X.initializer=[];for(var V=0;V<J.initializer.length;++V){if(typeof J.initializer[V]!="object")throw TypeError(".onnx.GraphProto.initializer: object expected");X.initializer[V]=Z.onnx.TensorProto.fromObject(J.initializer[V])}}if(J.sparseInitializer){if(!Array.isArray(J.sparseInitializer))throw TypeError(".onnx.GraphProto.sparseInitializer: array expected");X.sparseInitializer=[];for(var V=0;V<J.sparseInitializer.length;++V){if(typeof J.sparseInitializer[V]!="object")throw TypeError(".onnx.GraphProto.sparseInitializer: object expected");X.sparseInitializer[V]=Z.onnx.SparseTensorProto.fromObject(J.sparseInitializer[V])}}if(J.docString!=null&&(X.docString=String(J.docString)),J.input){if(!Array.isArray(J.input))throw TypeError(".onnx.GraphProto.input: array expected");X.input=[];for(var V=0;V<J.input.length;++V){if(typeof J.input[V]!="object")throw TypeError(".onnx.GraphProto.input: object expected");X.input[V]=Z.onnx.ValueInfoProto.fromObject(J.input[V])}}if(J.output){if(!Array.isArray(J.output))throw TypeError(".onnx.GraphProto.output: array expected");X.output=[];for(var V=0;V<J.output.length;++V){if(typeof J.output[V]!="object")throw TypeError(".onnx.GraphProto.output: object expected");X.output[V]=Z.onnx.ValueInfoProto.fromObject(J.output[V])}}if(J.valueInfo){if(!Array.isArray(J.valueInfo))throw TypeError(".onnx.GraphProto.valueInfo: array expected");X.valueInfo=[];for(var V=0;V<J.valueInfo.length;++V){if(typeof J.valueInfo[V]!="object")throw TypeError(".onnx.GraphProto.valueInfo: object expected");X.valueInfo[V]=Z.onnx.ValueInfoProto.fromObject(J.valueInfo[V])}}if(J.quantizationAnnotation){if(!Array.isArray(J.quantizationAnnotation))throw TypeError(".onnx.GraphProto.quantizationAnnotation: array expected");X.quantizationAnnotation=[];for(var V=0;V<J.quantizationAnnotation.length;++V){if(typeof J.quantizationAnnotation[V]!="object")throw TypeError(".onnx.GraphProto.quantizationAnnotation: object expected");X.quantizationAnnotation[V]=Z.onnx.TensorAnnotation.fromObject(J.quantizationAnnotation[V])}}return X},G.toObject=function(J,X){X||(X={});var V={};if((X.arrays||X.defaults)&&(V.node=[],V.initializer=[],V.input=[],V.output=[],V.valueInfo=[],V.quantizationAnnotation=[],V.sparseInitializer=[]),X.defaults&&(V.name="",V.docString=""),J.node&&J.node.length){V.node=[];for(var R=0;R<J.node.length;++R)V.node[R]=Z.onnx.NodeProto.toObject(J.node[R],X)}if(J.name!=null&&J.hasOwnProperty("name")&&(V.name=J.name),J.initializer&&J.initializer.length){V.initializer=[];for(var R=0;R<J.initializer.length;++R)V.initializer[R]=Z.onnx.TensorProto.toObject(J.initializer[R],X)}if(J.docString!=null&&J.hasOwnProperty("docString")&&(V.docString=J.docString),J.input&&J.input.length){V.input=[];for(var R=0;R<J.input.length;++R)V.input[R]=Z.onnx.ValueInfoProto.toObject(J.input[R],X)}if(J.output&&J.output.length){V.output=[];for(var R=0;R<J.output.length;++R)V.output[R]=Z.onnx.ValueInfoProto.toObject(J.output[R],X)}if(J.valueInfo&&J.valueInfo.length){V.valueInfo=[];for(var R=0;R<J.valueInfo.length;++R)V.valueInfo[R]=Z.onnx.ValueInfoProto.toObject(J.valueInfo[R],X)}if(J.quantizationAnnotation&&J.quantizationAnnotation.length){V.quantizationAnnotation=[];for(var R=0;R<J.quantizationAnnotation.length;++R)V.quantizationAnnotation[R]=Z.onnx.TensorAnnotation.toObject(J.quantizationAnnotation[R],X)}if(J.sparseInitializer&&J.sparseInitializer.length){V.sparseInitializer=[];for(var R=0;R<J.sparseInitializer.length;++R)V.sparseInitializer[R]=Z.onnx.SparseTensorProto.toObject(J.sparseInitializer[R],X)}return V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.GraphProto"},G}(),q.TensorProto=function(){function G(J){if(this.dims=[],this.floatData=[],this.int32Data=[],this.stringData=[],this.int64Data=[],this.externalData=[],this.doubleData=[],this.uint64Data=[],J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.dims=U.emptyArray,G.prototype.dataType=0,G.prototype.segment=null,G.prototype.floatData=U.emptyArray,G.prototype.int32Data=U.emptyArray,G.prototype.stringData=U.emptyArray,G.prototype.int64Data=U.emptyArray,G.prototype.name="",G.prototype.docString="",G.prototype.rawData=U.newBuffer([]),G.prototype.externalData=U.emptyArray,G.prototype.dataLocation=0,G.prototype.doubleData=U.emptyArray,G.prototype.uint64Data=U.emptyArray,G.create=function(J){return new G(J)},G.encode=function(J,X){if(X||(X=W.create()),J.dims!=null&&J.dims.length){X.uint32(10).fork();for(var V=0;V<J.dims.length;++V)X.int64(J.dims[V]);X.ldelim()}if(J.dataType!=null&&Object.hasOwnProperty.call(J,"dataType")&&X.uint32(16).int32(J.dataType),J.segment!=null&&Object.hasOwnProperty.call(J,"segment")&&Z.onnx.TensorProto.Segment.encode(J.segment,X.uint32(26).fork()).ldelim(),J.floatData!=null&&J.floatData.length){X.uint32(34).fork();for(var V=0;V<J.floatData.length;++V)X.float(J.floatData[V]);X.ldelim()}if(J.int32Data!=null&&J.int32Data.length){X.uint32(42).fork();for(var V=0;V<J.int32Data.length;++V)X.int32(J.int32Data[V]);X.ldelim()}if(J.stringData!=null&&J.stringData.length)for(var V=0;V<J.stringData.length;++V)X.uint32(50).bytes(J.stringData[V]);if(J.int64Data!=null&&J.int64Data.length){X.uint32(58).fork();for(var V=0;V<J.int64Data.length;++V)X.int64(J.int64Data[V]);X.ldelim()}if(J.name!=null&&Object.hasOwnProperty.call(J,"name")&&X.uint32(66).string(J.name),J.rawData!=null&&Object.hasOwnProperty.call(J,"rawData")&&X.uint32(74).bytes(J.rawData),J.doubleData!=null&&J.doubleData.length){X.uint32(82).fork();for(var V=0;V<J.doubleData.length;++V)X.double(J.doubleData[V]);X.ldelim()}if(J.uint64Data!=null&&J.uint64Data.length){X.uint32(90).fork();for(var V=0;V<J.uint64Data.length;++V)X.uint64(J.uint64Data[V]);X.ldelim()}if(J.docString!=null&&Object.hasOwnProperty.call(J,"docString")&&X.uint32(98).string(J.docString),J.externalData!=null&&J.externalData.length)for(var V=0;V<J.externalData.length;++V)Z.onnx.StringStringEntryProto.encode(J.externalData[V],X.uint32(106).fork()).ldelim();return J.dataLocation!=null&&Object.hasOwnProperty.call(J,"dataLocation")&&X.uint32(112).int32(J.dataLocation),X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.TensorProto;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{if(R.dims&&R.dims.length||(R.dims=[]),(z&7)===2)for(var Y=J.uint32()+J.pos;J.pos<Y;)R.dims.push(J.int64());else R.dims.push(J.int64());break}case 2:{R.dataType=J.int32();break}case 3:{R.segment=Z.onnx.TensorProto.Segment.decode(J,J.uint32());break}case 4:{if(R.floatData&&R.floatData.length||(R.floatData=[]),(z&7)===2)for(var Y=J.uint32()+J.pos;J.pos<Y;)R.floatData.push(J.float());else R.floatData.push(J.float());break}case 5:{if(R.int32Data&&R.int32Data.length||(R.int32Data=[]),(z&7)===2)for(var Y=J.uint32()+J.pos;J.pos<Y;)R.int32Data.push(J.int32());else R.int32Data.push(J.int32());break}case 6:{R.stringData&&R.stringData.length||(R.stringData=[]),R.stringData.push(J.bytes());break}case 7:{if(R.int64Data&&R.int64Data.length||(R.int64Data=[]),(z&7)===2)for(var Y=J.uint32()+J.pos;J.pos<Y;)R.int64Data.push(J.int64());else R.int64Data.push(J.int64());break}case 8:{R.name=J.string();break}case 12:{R.docString=J.string();break}case 9:{R.rawData=J.bytes();break}case 13:{R.externalData&&R.externalData.length||(R.externalData=[]),R.externalData.push(Z.onnx.StringStringEntryProto.decode(J,J.uint32()));break}case 14:{R.dataLocation=J.int32();break}case 10:{if(R.doubleData&&R.doubleData.length||(R.doubleData=[]),(z&7)===2)for(var Y=J.uint32()+J.pos;J.pos<Y;)R.doubleData.push(J.double());else R.doubleData.push(J.double());break}case 11:{if(R.uint64Data&&R.uint64Data.length||(R.uint64Data=[]),(z&7)===2)for(var Y=J.uint32()+J.pos;J.pos<Y;)R.uint64Data.push(J.uint64());else R.uint64Data.push(J.uint64());break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){if(typeof J!="object"||J===null)return"object expected";if(J.dims!=null&&J.hasOwnProperty("dims")){if(!Array.isArray(J.dims))return"dims: array expected";for(var X=0;X<J.dims.length;++X)if(!U.isInteger(J.dims[X])&&!(J.dims[X]&&U.isInteger(J.dims[X].low)&&U.isInteger(J.dims[X].high)))return"dims: integer|Long[] expected"}if(J.dataType!=null&&J.hasOwnProperty("dataType")&&!U.isInteger(J.dataType))return"dataType: integer expected";if(J.segment!=null&&J.hasOwnProperty("segment")){var V=Z.onnx.TensorProto.Segment.verify(J.segment);if(V)return"segment."+V}if(J.floatData!=null&&J.hasOwnProperty("floatData")){if(!Array.isArray(J.floatData))return"floatData: array expected";for(var X=0;X<J.floatData.length;++X)if(typeof J.floatData[X]!="number")return"floatData: number[] expected"}if(J.int32Data!=null&&J.hasOwnProperty("int32Data")){if(!Array.isArray(J.int32Data))return"int32Data: array expected";for(var X=0;X<J.int32Data.length;++X)if(!U.isInteger(J.int32Data[X]))return"int32Data: integer[] expected"}if(J.stringData!=null&&J.hasOwnProperty("stringData")){if(!Array.isArray(J.stringData))return"stringData: array expected";for(var X=0;X<J.stringData.length;++X)if(!(J.stringData[X]&&typeof J.stringData[X].length=="number"||U.isString(J.stringData[X])))return"stringData: buffer[] expected"}if(J.int64Data!=null&&J.hasOwnProperty("int64Data")){if(!Array.isArray(J.int64Data))return"int64Data: array expected";for(var X=0;X<J.int64Data.length;++X)if(!U.isInteger(J.int64Data[X])&&!(J.int64Data[X]&&U.isInteger(J.int64Data[X].low)&&U.isInteger(J.int64Data[X].high)))return"int64Data: integer|Long[] expected"}if(J.name!=null&&J.hasOwnProperty("name")&&!U.isString(J.name))return"name: string expected";if(J.docString!=null&&J.hasOwnProperty("docString")&&!U.isString(J.docString))return"docString: string expected";if(J.rawData!=null&&J.hasOwnProperty("rawData")&&!(J.rawData&&typeof J.rawData.length=="number"||U.isString(J.rawData)))return"rawData: buffer expected";if(J.externalData!=null&&J.hasOwnProperty("externalData")){if(!Array.isArray(J.externalData))return"externalData: array expected";for(var X=0;X<J.externalData.length;++X){var V=Z.onnx.StringStringEntryProto.verify(J.externalData[X]);if(V)return"externalData."+V}}if(J.dataLocation!=null&&J.hasOwnProperty("dataLocation"))switch(J.dataLocation){default:return"dataLocation: enum value expected";case 0:case 1:break}if(J.doubleData!=null&&J.hasOwnProperty("doubleData")){if(!Array.isArray(J.doubleData))return"doubleData: array expected";for(var X=0;X<J.doubleData.length;++X)if(typeof J.doubleData[X]!="number")return"doubleData: number[] expected"}if(J.uint64Data!=null&&J.hasOwnProperty("uint64Data")){if(!Array.isArray(J.uint64Data))return"uint64Data: array expected";for(var X=0;X<J.uint64Data.length;++X)if(!U.isInteger(J.uint64Data[X])&&!(J.uint64Data[X]&&U.isInteger(J.uint64Data[X].low)&&U.isInteger(J.uint64Data[X].high)))return"uint64Data: integer|Long[] expected"}return null},G.fromObject=function(J){if(J instanceof Z.onnx.TensorProto)return J;var X=new Z.onnx.TensorProto;if(J.dims){if(!Array.isArray(J.dims))throw TypeError(".onnx.TensorProto.dims: array expected");X.dims=[];for(var V=0;V<J.dims.length;++V)U.Long?(X.dims[V]=U.Long.fromValue(J.dims[V])).unsigned=!1:typeof J.dims[V]=="string"?X.dims[V]=parseInt(J.dims[V],10):typeof J.dims[V]=="number"?X.dims[V]=J.dims[V]:typeof J.dims[V]=="object"&&(X.dims[V]=new U.LongBits(J.dims[V].low>>>0,J.dims[V].high>>>0).toNumber())}if(J.dataType!=null&&(X.dataType=J.dataType|0),J.segment!=null){if(typeof J.segment!="object")throw TypeError(".onnx.TensorProto.segment: object expected");X.segment=Z.onnx.TensorProto.Segment.fromObject(J.segment)}if(J.floatData){if(!Array.isArray(J.floatData))throw TypeError(".onnx.TensorProto.floatData: array expected");X.floatData=[];for(var V=0;V<J.floatData.length;++V)X.floatData[V]=Number(J.floatData[V])}if(J.int32Data){if(!Array.isArray(J.int32Data))throw TypeError(".onnx.TensorProto.int32Data: array expected");X.int32Data=[];for(var V=0;V<J.int32Data.length;++V)X.int32Data[V]=J.int32Data[V]|0}if(J.stringData){if(!Array.isArray(J.stringData))throw TypeError(".onnx.TensorProto.stringData: array expected");X.stringData=[];for(var V=0;V<J.stringData.length;++V)typeof J.stringData[V]=="string"?U.base64.decode(J.stringData[V],X.stringData[V]=U.newBuffer(U.base64.length(J.stringData[V])),0):J.stringData[V].length>=0&&(X.stringData[V]=J.stringData[V])}if(J.int64Data){if(!Array.isArray(J.int64Data))throw TypeError(".onnx.TensorProto.int64Data: array expected");X.int64Data=[];for(var V=0;V<J.int64Data.length;++V)U.Long?(X.int64Data[V]=U.Long.fromValue(J.int64Data[V])).unsigned=!1:typeof J.int64Data[V]=="string"?X.int64Data[V]=parseInt(J.int64Data[V],10):typeof J.int64Data[V]=="number"?X.int64Data[V]=J.int64Data[V]:typeof J.int64Data[V]=="object"&&(X.int64Data[V]=new U.LongBits(J.int64Data[V].low>>>0,J.int64Data[V].high>>>0).toNumber())}if(J.name!=null&&(X.name=String(J.name)),J.docString!=null&&(X.docString=String(J.docString)),J.rawData!=null&&(typeof J.rawData=="string"?U.base64.decode(J.rawData,X.rawData=U.newBuffer(U.base64.length(J.rawData)),0):J.rawData.length>=0&&(X.rawData=J.rawData)),J.externalData){if(!Array.isArray(J.externalData))throw TypeError(".onnx.TensorProto.externalData: array expected");X.externalData=[];for(var V=0;V<J.externalData.length;++V){if(typeof J.externalData[V]!="object")throw TypeError(".onnx.TensorProto.externalData: object expected");X.externalData[V]=Z.onnx.StringStringEntryProto.fromObject(J.externalData[V])}}switch(J.dataLocation){default:if(typeof J.dataLocation=="number"){X.dataLocation=J.dataLocation;break}break;case"DEFAULT":case 0:X.dataLocation=0;break;case"EXTERNAL":case 1:X.dataLocation=1;break}if(J.doubleData){if(!Array.isArray(J.doubleData))throw TypeError(".onnx.TensorProto.doubleData: array expected");X.doubleData=[];for(var V=0;V<J.doubleData.length;++V)X.doubleData[V]=Number(J.doubleData[V])}if(J.uint64Data){if(!Array.isArray(J.uint64Data))throw TypeError(".onnx.TensorProto.uint64Data: array expected");X.uint64Data=[];for(var V=0;V<J.uint64Data.length;++V)U.Long?(X.uint64Data[V]=U.Long.fromValue(J.uint64Data[V])).unsigned=!0:typeof J.uint64Data[V]=="string"?X.uint64Data[V]=parseInt(J.uint64Data[V],10):typeof J.uint64Data[V]=="number"?X.uint64Data[V]=J.uint64Data[V]:typeof J.uint64Data[V]=="object"&&(X.uint64Data[V]=new U.LongBits(J.uint64Data[V].low>>>0,J.uint64Data[V].high>>>0).toNumber(!0))}return X},G.toObject=function(J,X){X||(X={});var V={};if((X.arrays||X.defaults)&&(V.dims=[],V.floatData=[],V.int32Data=[],V.stringData=[],V.int64Data=[],V.doubleData=[],V.uint64Data=[],V.externalData=[]),X.defaults&&(V.dataType=0,V.segment=null,V.name="",X.bytes===String?V.rawData="":(V.rawData=[],X.bytes!==Array&&(V.rawData=U.newBuffer(V.rawData))),V.docString="",V.dataLocation=X.enums===String?"DEFAULT":0),J.dims&&J.dims.length){V.dims=[];for(var R=0;R<J.dims.length;++R)typeof J.dims[R]=="number"?V.dims[R]=X.longs===String?String(J.dims[R]):J.dims[R]:V.dims[R]=X.longs===String?U.Long.prototype.toString.call(J.dims[R]):X.longs===Number?new U.LongBits(J.dims[R].low>>>0,J.dims[R].high>>>0).toNumber():J.dims[R]}if(J.dataType!=null&&J.hasOwnProperty("dataType")&&(V.dataType=J.dataType),J.segment!=null&&J.hasOwnProperty("segment")&&(V.segment=Z.onnx.TensorProto.Segment.toObject(J.segment,X)),J.floatData&&J.floatData.length){V.floatData=[];for(var R=0;R<J.floatData.length;++R)V.floatData[R]=X.json&&!isFinite(J.floatData[R])?String(J.floatData[R]):J.floatData[R]}if(J.int32Data&&J.int32Data.length){V.int32Data=[];for(var R=0;R<J.int32Data.length;++R)V.int32Data[R]=J.int32Data[R]}if(J.stringData&&J.stringData.length){V.stringData=[];for(var R=0;R<J.stringData.length;++R)V.stringData[R]=X.bytes===String?U.base64.encode(J.stringData[R],0,J.stringData[R].length):X.bytes===Array?Array.prototype.slice.call(J.stringData[R]):J.stringData[R]}if(J.int64Data&&J.int64Data.length){V.int64Data=[];for(var R=0;R<J.int64Data.length;++R)typeof J.int64Data[R]=="number"?V.int64Data[R]=X.longs===String?String(J.int64Data[R]):J.int64Data[R]:V.int64Data[R]=X.longs===String?U.Long.prototype.toString.call(J.int64Data[R]):X.longs===Number?new U.LongBits(J.int64Data[R].low>>>0,J.int64Data[R].high>>>0).toNumber():J.int64Data[R]}if(J.name!=null&&J.hasOwnProperty("name")&&(V.name=J.name),J.rawData!=null&&J.hasOwnProperty("rawData")&&(V.rawData=X.bytes===String?U.base64.encode(J.rawData,0,J.rawData.length):X.bytes===Array?Array.prototype.slice.call(J.rawData):J.rawData),J.doubleData&&J.doubleData.length){V.doubleData=[];for(var R=0;R<J.doubleData.length;++R)V.doubleData[R]=X.json&&!isFinite(J.doubleData[R])?String(J.doubleData[R]):J.doubleData[R]}if(J.uint64Data&&J.uint64Data.length){V.uint64Data=[];for(var R=0;R<J.uint64Data.length;++R)typeof J.uint64Data[R]=="number"?V.uint64Data[R]=X.longs===String?String(J.uint64Data[R]):J.uint64Data[R]:V.uint64Data[R]=X.longs===String?U.Long.prototype.toString.call(J.uint64Data[R]):X.longs===Number?new U.LongBits(J.uint64Data[R].low>>>0,J.uint64Data[R].high>>>0).toNumber(!0):J.uint64Data[R]}if(J.docString!=null&&J.hasOwnProperty("docString")&&(V.docString=J.docString),J.externalData&&J.externalData.length){V.externalData=[];for(var R=0;R<J.externalData.length;++R)V.externalData[R]=Z.onnx.StringStringEntryProto.toObject(J.externalData[R],X)}return J.dataLocation!=null&&J.hasOwnProperty("dataLocation")&&(V.dataLocation=X.enums===String?Z.onnx.TensorProto.DataLocation[J.dataLocation]===void 0?J.dataLocation:Z.onnx.TensorProto.DataLocation[J.dataLocation]:J.dataLocation),V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.TensorProto"},G.DataType=function(){var J={},X=Object.create(J);return X[J[0]="UNDEFINED"]=0,X[J[1]="FLOAT"]=1,X[J[2]="UINT8"]=2,X[J[3]="INT8"]=3,X[J[4]="UINT16"]=4,X[J[5]="INT16"]=5,X[J[6]="INT32"]=6,X[J[7]="INT64"]=7,X[J[8]="STRING"]=8,X[J[9]="BOOL"]=9,X[J[10]="FLOAT16"]=10,X[J[11]="DOUBLE"]=11,X[J[12]="UINT32"]=12,X[J[13]="UINT64"]=13,X[J[14]="COMPLEX64"]=14,X[J[15]="COMPLEX128"]=15,X[J[16]="BFLOAT16"]=16,X[J[17]="FLOAT8E4M3FN"]=17,X[J[18]="FLOAT8E4M3FNUZ"]=18,X[J[19]="FLOAT8E5M2"]=19,X[J[20]="FLOAT8E5M2FNUZ"]=20,X}(),G.Segment=function(){function J(X){if(X)for(var V=Object.keys(X),R=0;R<V.length;++R)X[V[R]]!=null&&(this[V[R]]=X[V[R]])}return J.prototype.begin=U.Long?U.Long.fromBits(0,0,!1):0,J.prototype.end=U.Long?U.Long.fromBits(0,0,!1):0,J.create=function(X){return new J(X)},J.encode=function(X,V){return V||(V=W.create()),X.begin!=null&&Object.hasOwnProperty.call(X,"begin")&&V.uint32(8).int64(X.begin),X.end!=null&&Object.hasOwnProperty.call(X,"end")&&V.uint32(16).int64(X.end),V},J.encodeDelimited=function(X,V){return this.encode(X,V).ldelim()},J.decode=function(X,V){X instanceof K||(X=K.create(X));for(var R=V===void 0?X.len:X.pos+V,z=new Z.onnx.TensorProto.Segment;X.pos<R;){var Y=X.uint32();switch(Y>>>3){case 1:{z.begin=X.int64();break}case 2:{z.end=X.int64();break}default:X.skipType(Y&7);break}}return z},J.decodeDelimited=function(X){return X instanceof K||(X=new K(X)),this.decode(X,X.uint32())},J.verify=function(X){return typeof X!="object"||X===null?"object expected":X.begin!=null&&X.hasOwnProperty("begin")&&!U.isInteger(X.begin)&&!(X.begin&&U.isInteger(X.begin.low)&&U.isInteger(X.begin.high))?"begin: integer|Long expected":X.end!=null&&X.hasOwnProperty("end")&&!U.isInteger(X.end)&&!(X.end&&U.isInteger(X.end.low)&&U.isInteger(X.end.high))?"end: integer|Long expected":null},J.fromObject=function(X){if(X instanceof Z.onnx.TensorProto.Segment)return X;var V=new Z.onnx.TensorProto.Segment;return X.begin!=null&&(U.Long?(V.begin=U.Long.fromValue(X.begin)).unsigned=!1:typeof X.begin=="string"?V.begin=parseInt(X.begin,10):typeof X.begin=="number"?V.begin=X.begin:typeof X.begin=="object"&&(V.begin=new U.LongBits(X.begin.low>>>0,X.begin.high>>>0).toNumber())),X.end!=null&&(U.Long?(V.end=U.Long.fromValue(X.end)).unsigned=!1:typeof X.end=="string"?V.end=parseInt(X.end,10):typeof X.end=="number"?V.end=X.end:typeof X.end=="object"&&(V.end=new U.LongBits(X.end.low>>>0,X.end.high>>>0).toNumber())),V},J.toObject=function(X,V){V||(V={});var R={};if(V.defaults){if(U.Long){var z=new U.Long(0,0,!1);R.begin=V.longs===String?z.toString():V.longs===Number?z.toNumber():z}else R.begin=V.longs===String?"0":0;if(U.Long){var z=new U.Long(0,0,!1);R.end=V.longs===String?z.toString():V.longs===Number?z.toNumber():z}else R.end=V.longs===String?"0":0}return X.begin!=null&&X.hasOwnProperty("begin")&&(typeof X.begin=="number"?R.begin=V.longs===String?String(X.begin):X.begin:R.begin=V.longs===String?U.Long.prototype.toString.call(X.begin):V.longs===Number?new U.LongBits(X.begin.low>>>0,X.begin.high>>>0).toNumber():X.begin),X.end!=null&&X.hasOwnProperty("end")&&(typeof X.end=="number"?R.end=V.longs===String?String(X.end):X.end:R.end=V.longs===String?U.Long.prototype.toString.call(X.end):V.longs===Number?new U.LongBits(X.end.low>>>0,X.end.high>>>0).toNumber():X.end),R},J.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},J.getTypeUrl=function(X){return X===void 0&&(X="type.googleapis.com"),X+"/onnx.TensorProto.Segment"},J}(),G.DataLocation=function(){var J={},X=Object.create(J);return X[J[0]="DEFAULT"]=0,X[J[1]="EXTERNAL"]=1,X}(),G}(),q.SparseTensorProto=function(){function G(J){if(this.dims=[],J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.values=null,G.prototype.indices=null,G.prototype.dims=U.emptyArray,G.create=function(J){return new G(J)},G.encode=function(J,X){if(X||(X=W.create()),J.values!=null&&Object.hasOwnProperty.call(J,"values")&&Z.onnx.TensorProto.encode(J.values,X.uint32(10).fork()).ldelim(),J.indices!=null&&Object.hasOwnProperty.call(J,"indices")&&Z.onnx.TensorProto.encode(J.indices,X.uint32(18).fork()).ldelim(),J.dims!=null&&J.dims.length){X.uint32(26).fork();for(var V=0;V<J.dims.length;++V)X.int64(J.dims[V]);X.ldelim()}return X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.SparseTensorProto;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{R.values=Z.onnx.TensorProto.decode(J,J.uint32());break}case 2:{R.indices=Z.onnx.TensorProto.decode(J,J.uint32());break}case 3:{if(R.dims&&R.dims.length||(R.dims=[]),(z&7)===2)for(var Y=J.uint32()+J.pos;J.pos<Y;)R.dims.push(J.int64());else R.dims.push(J.int64());break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){if(typeof J!="object"||J===null)return"object expected";if(J.values!=null&&J.hasOwnProperty("values")){var X=Z.onnx.TensorProto.verify(J.values);if(X)return"values."+X}if(J.indices!=null&&J.hasOwnProperty("indices")){var X=Z.onnx.TensorProto.verify(J.indices);if(X)return"indices."+X}if(J.dims!=null&&J.hasOwnProperty("dims")){if(!Array.isArray(J.dims))return"dims: array expected";for(var V=0;V<J.dims.length;++V)if(!U.isInteger(J.dims[V])&&!(J.dims[V]&&U.isInteger(J.dims[V].low)&&U.isInteger(J.dims[V].high)))return"dims: integer|Long[] expected"}return null},G.fromObject=function(J){if(J instanceof Z.onnx.SparseTensorProto)return J;var X=new Z.onnx.SparseTensorProto;if(J.values!=null){if(typeof J.values!="object")throw TypeError(".onnx.SparseTensorProto.values: object expected");X.values=Z.onnx.TensorProto.fromObject(J.values)}if(J.indices!=null){if(typeof J.indices!="object")throw TypeError(".onnx.SparseTensorProto.indices: object expected");X.indices=Z.onnx.TensorProto.fromObject(J.indices)}if(J.dims){if(!Array.isArray(J.dims))throw TypeError(".onnx.SparseTensorProto.dims: array expected");X.dims=[];for(var V=0;V<J.dims.length;++V)U.Long?(X.dims[V]=U.Long.fromValue(J.dims[V])).unsigned=!1:typeof J.dims[V]=="string"?X.dims[V]=parseInt(J.dims[V],10):typeof J.dims[V]=="number"?X.dims[V]=J.dims[V]:typeof J.dims[V]=="object"&&(X.dims[V]=new U.LongBits(J.dims[V].low>>>0,J.dims[V].high>>>0).toNumber())}return X},G.toObject=function(J,X){X||(X={});var V={};if((X.arrays||X.defaults)&&(V.dims=[]),X.defaults&&(V.values=null,V.indices=null),J.values!=null&&J.hasOwnProperty("values")&&(V.values=Z.onnx.TensorProto.toObject(J.values,X)),J.indices!=null&&J.hasOwnProperty("indices")&&(V.indices=Z.onnx.TensorProto.toObject(J.indices,X)),J.dims&&J.dims.length){V.dims=[];for(var R=0;R<J.dims.length;++R)typeof J.dims[R]=="number"?V.dims[R]=X.longs===String?String(J.dims[R]):J.dims[R]:V.dims[R]=X.longs===String?U.Long.prototype.toString.call(J.dims[R]):X.longs===Number?new U.LongBits(J.dims[R].low>>>0,J.dims[R].high>>>0).toNumber():J.dims[R]}return V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.SparseTensorProto"},G}(),q.TensorShapeProto=function(){function G(J){if(this.dim=[],J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.dim=U.emptyArray,G.create=function(J){return new G(J)},G.encode=function(J,X){if(X||(X=W.create()),J.dim!=null&&J.dim.length)for(var V=0;V<J.dim.length;++V)Z.onnx.TensorShapeProto.Dimension.encode(J.dim[V],X.uint32(10).fork()).ldelim();return X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.TensorShapeProto;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{R.dim&&R.dim.length||(R.dim=[]),R.dim.push(Z.onnx.TensorShapeProto.Dimension.decode(J,J.uint32()));break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){if(typeof J!="object"||J===null)return"object expected";if(J.dim!=null&&J.hasOwnProperty("dim")){if(!Array.isArray(J.dim))return"dim: array expected";for(var X=0;X<J.dim.length;++X){var V=Z.onnx.TensorShapeProto.Dimension.verify(J.dim[X]);if(V)return"dim."+V}}return null},G.fromObject=function(J){if(J instanceof Z.onnx.TensorShapeProto)return J;var X=new Z.onnx.TensorShapeProto;if(J.dim){if(!Array.isArray(J.dim))throw TypeError(".onnx.TensorShapeProto.dim: array expected");X.dim=[];for(var V=0;V<J.dim.length;++V){if(typeof J.dim[V]!="object")throw TypeError(".onnx.TensorShapeProto.dim: object expected");X.dim[V]=Z.onnx.TensorShapeProto.Dimension.fromObject(J.dim[V])}}return X},G.toObject=function(J,X){X||(X={});var V={};if((X.arrays||X.defaults)&&(V.dim=[]),J.dim&&J.dim.length){V.dim=[];for(var R=0;R<J.dim.length;++R)V.dim[R]=Z.onnx.TensorShapeProto.Dimension.toObject(J.dim[R],X)}return V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.TensorShapeProto"},G.Dimension=function(){function J(V){if(V)for(var R=Object.keys(V),z=0;z<R.length;++z)V[R[z]]!=null&&(this[R[z]]=V[R[z]])}J.prototype.dimValue=null,J.prototype.dimParam=null,J.prototype.denotation="";var X;return Object.defineProperty(J.prototype,"value",{get:U.oneOfGetter(X=["dimValue","dimParam"]),set:U.oneOfSetter(X)}),J.create=function(V){return new J(V)},J.encode=function(V,R){return R||(R=W.create()),V.dimValue!=null&&Object.hasOwnProperty.call(V,"dimValue")&&R.uint32(8).int64(V.dimValue),V.dimParam!=null&&Object.hasOwnProperty.call(V,"dimParam")&&R.uint32(18).string(V.dimParam),V.denotation!=null&&Object.hasOwnProperty.call(V,"denotation")&&R.uint32(26).string(V.denotation),R},J.encodeDelimited=function(V,R){return this.encode(V,R).ldelim()},J.decode=function(V,R){V instanceof K||(V=K.create(V));for(var z=R===void 0?V.len:V.pos+R,Y=new Z.onnx.TensorShapeProto.Dimension;V.pos<z;){var B=V.uint32();switch(B>>>3){case 1:{Y.dimValue=V.int64();break}case 2:{Y.dimParam=V.string();break}case 3:{Y.denotation=V.string();break}default:V.skipType(B&7);break}}return Y},J.decodeDelimited=function(V){return V instanceof K||(V=new K(V)),this.decode(V,V.uint32())},J.verify=function(V){if(typeof V!="object"||V===null)return"object expected";var R={};if(V.dimValue!=null&&V.hasOwnProperty("dimValue")&&(R.value=1,!U.isInteger(V.dimValue)&&!(V.dimValue&&U.isInteger(V.dimValue.low)&&U.isInteger(V.dimValue.high))))return"dimValue: integer|Long expected";if(V.dimParam!=null&&V.hasOwnProperty("dimParam")){if(R.value===1)return"value: multiple values";if(R.value=1,!U.isString(V.dimParam))return"dimParam: string expected"}return V.denotation!=null&&V.hasOwnProperty("denotation")&&!U.isString(V.denotation)?"denotation: string expected":null},J.fromObject=function(V){if(V instanceof Z.onnx.TensorShapeProto.Dimension)return V;var R=new Z.onnx.TensorShapeProto.Dimension;return V.dimValue!=null&&(U.Long?(R.dimValue=U.Long.fromValue(V.dimValue)).unsigned=!1:typeof V.dimValue=="string"?R.dimValue=parseInt(V.dimValue,10):typeof V.dimValue=="number"?R.dimValue=V.dimValue:typeof V.dimValue=="object"&&(R.dimValue=new U.LongBits(V.dimValue.low>>>0,V.dimValue.high>>>0).toNumber())),V.dimParam!=null&&(R.dimParam=String(V.dimParam)),V.denotation!=null&&(R.denotation=String(V.denotation)),R},J.toObject=function(V,R){R||(R={});var z={};return R.defaults&&(z.denotation=""),V.dimValue!=null&&V.hasOwnProperty("dimValue")&&(typeof V.dimValue=="number"?z.dimValue=R.longs===String?String(V.dimValue):V.dimValue:z.dimValue=R.longs===String?U.Long.prototype.toString.call(V.dimValue):R.longs===Number?new U.LongBits(V.dimValue.low>>>0,V.dimValue.high>>>0).toNumber():V.dimValue,R.oneofs&&(z.value="dimValue")),V.dimParam!=null&&V.hasOwnProperty("dimParam")&&(z.dimParam=V.dimParam,R.oneofs&&(z.value="dimParam")),V.denotation!=null&&V.hasOwnProperty("denotation")&&(z.denotation=V.denotation),z},J.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},J.getTypeUrl=function(V){return V===void 0&&(V="type.googleapis.com"),V+"/onnx.TensorShapeProto.Dimension"},J}(),G}(),q.TypeProto=function(){function G(X){if(X)for(var V=Object.keys(X),R=0;R<V.length;++R)X[V[R]]!=null&&(this[V[R]]=X[V[R]])}G.prototype.tensorType=null,G.prototype.sequenceType=null,G.prototype.mapType=null,G.prototype.optionalType=null,G.prototype.sparseTensorType=null,G.prototype.denotation="";var J;return Object.defineProperty(G.prototype,"value",{get:U.oneOfGetter(J=["tensorType","sequenceType","mapType","optionalType","sparseTensorType"]),set:U.oneOfSetter(J)}),G.create=function(X){return new G(X)},G.encode=function(X,V){return V||(V=W.create()),X.tensorType!=null&&Object.hasOwnProperty.call(X,"tensorType")&&Z.onnx.TypeProto.Tensor.encode(X.tensorType,V.uint32(10).fork()).ldelim(),X.sequenceType!=null&&Object.hasOwnProperty.call(X,"sequenceType")&&Z.onnx.TypeProto.Sequence.encode(X.sequenceType,V.uint32(34).fork()).ldelim(),X.mapType!=null&&Object.hasOwnProperty.call(X,"mapType")&&Z.onnx.TypeProto.Map.encode(X.mapType,V.uint32(42).fork()).ldelim(),X.denotation!=null&&Object.hasOwnProperty.call(X,"denotation")&&V.uint32(50).string(X.denotation),X.sparseTensorType!=null&&Object.hasOwnProperty.call(X,"sparseTensorType")&&Z.onnx.TypeProto.SparseTensor.encode(X.sparseTensorType,V.uint32(66).fork()).ldelim(),X.optionalType!=null&&Object.hasOwnProperty.call(X,"optionalType")&&Z.onnx.TypeProto.Optional.encode(X.optionalType,V.uint32(74).fork()).ldelim(),V},G.encodeDelimited=function(X,V){return this.encode(X,V).ldelim()},G.decode=function(X,V){X instanceof K||(X=K.create(X));for(var R=V===void 0?X.len:X.pos+V,z=new Z.onnx.TypeProto;X.pos<R;){var Y=X.uint32();switch(Y>>>3){case 1:{z.tensorType=Z.onnx.TypeProto.Tensor.decode(X,X.uint32());break}case 4:{z.sequenceType=Z.onnx.TypeProto.Sequence.decode(X,X.uint32());break}case 5:{z.mapType=Z.onnx.TypeProto.Map.decode(X,X.uint32());break}case 9:{z.optionalType=Z.onnx.TypeProto.Optional.decode(X,X.uint32());break}case 8:{z.sparseTensorType=Z.onnx.TypeProto.SparseTensor.decode(X,X.uint32());break}case 6:{z.denotation=X.string();break}default:X.skipType(Y&7);break}}return z},G.decodeDelimited=function(X){return X instanceof K||(X=new K(X)),this.decode(X,X.uint32())},G.verify=function(X){if(typeof X!="object"||X===null)return"object expected";var V={};if(X.tensorType!=null&&X.hasOwnProperty("tensorType")){V.value=1;{var R=Z.onnx.TypeProto.Tensor.verify(X.tensorType);if(R)return"tensorType."+R}}if(X.sequenceType!=null&&X.hasOwnProperty("sequenceType")){if(V.value===1)return"value: multiple values";V.value=1;{var R=Z.onnx.TypeProto.Sequence.verify(X.sequenceType);if(R)return"sequenceType."+R}}if(X.mapType!=null&&X.hasOwnProperty("mapType")){if(V.value===1)return"value: multiple values";V.value=1;{var R=Z.onnx.TypeProto.Map.verify(X.mapType);if(R)return"mapType."+R}}if(X.optionalType!=null&&X.hasOwnProperty("optionalType")){if(V.value===1)return"value: multiple values";V.value=1;{var R=Z.onnx.TypeProto.Optional.verify(X.optionalType);if(R)return"optionalType."+R}}if(X.sparseTensorType!=null&&X.hasOwnProperty("sparseTensorType")){if(V.value===1)return"value: multiple values";V.value=1;{var R=Z.onnx.TypeProto.SparseTensor.verify(X.sparseTensorType);if(R)return"sparseTensorType."+R}}return X.denotation!=null&&X.hasOwnProperty("denotation")&&!U.isString(X.denotation)?"denotation: string expected":null},G.fromObject=function(X){if(X instanceof Z.onnx.TypeProto)return X;var V=new Z.onnx.TypeProto;if(X.tensorType!=null){if(typeof X.tensorType!="object")throw TypeError(".onnx.TypeProto.tensorType: object expected");V.tensorType=Z.onnx.TypeProto.Tensor.fromObject(X.tensorType)}if(X.sequenceType!=null){if(typeof X.sequenceType!="object")throw TypeError(".onnx.TypeProto.sequenceType: object expected");V.sequenceType=Z.onnx.TypeProto.Sequence.fromObject(X.sequenceType)}if(X.mapType!=null){if(typeof X.mapType!="object")throw TypeError(".onnx.TypeProto.mapType: object expected");V.mapType=Z.onnx.TypeProto.Map.fromObject(X.mapType)}if(X.optionalType!=null){if(typeof X.optionalType!="object")throw TypeError(".onnx.TypeProto.optionalType: object expected");V.optionalType=Z.onnx.TypeProto.Optional.fromObject(X.optionalType)}if(X.sparseTensorType!=null){if(typeof X.sparseTensorType!="object")throw TypeError(".onnx.TypeProto.sparseTensorType: object expected");V.sparseTensorType=Z.onnx.TypeProto.SparseTensor.fromObject(X.sparseTensorType)}return X.denotation!=null&&(V.denotation=String(X.denotation)),V},G.toObject=function(X,V){V||(V={});var R={};return V.defaults&&(R.denotation=""),X.tensorType!=null&&X.hasOwnProperty("tensorType")&&(R.tensorType=Z.onnx.TypeProto.Tensor.toObject(X.tensorType,V),V.oneofs&&(R.value="tensorType")),X.sequenceType!=null&&X.hasOwnProperty("sequenceType")&&(R.sequenceType=Z.onnx.TypeProto.Sequence.toObject(X.sequenceType,V),V.oneofs&&(R.value="sequenceType")),X.mapType!=null&&X.hasOwnProperty("mapType")&&(R.mapType=Z.onnx.TypeProto.Map.toObject(X.mapType,V),V.oneofs&&(R.value="mapType")),X.denotation!=null&&X.hasOwnProperty("denotation")&&(R.denotation=X.denotation),X.sparseTensorType!=null&&X.hasOwnProperty("sparseTensorType")&&(R.sparseTensorType=Z.onnx.TypeProto.SparseTensor.toObject(X.sparseTensorType,V),V.oneofs&&(R.value="sparseTensorType")),X.optionalType!=null&&X.hasOwnProperty("optionalType")&&(R.optionalType=Z.onnx.TypeProto.Optional.toObject(X.optionalType,V),V.oneofs&&(R.value="optionalType")),R},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(X){return X===void 0&&(X="type.googleapis.com"),X+"/onnx.TypeProto"},G.Tensor=function(){function X(V){if(V)for(var R=Object.keys(V),z=0;z<R.length;++z)V[R[z]]!=null&&(this[R[z]]=V[R[z]])}return X.prototype.elemType=0,X.prototype.shape=null,X.create=function(V){return new X(V)},X.encode=function(V,R){return R||(R=W.create()),V.elemType!=null&&Object.hasOwnProperty.call(V,"elemType")&&R.uint32(8).int32(V.elemType),V.shape!=null&&Object.hasOwnProperty.call(V,"shape")&&Z.onnx.TensorShapeProto.encode(V.shape,R.uint32(18).fork()).ldelim(),R},X.encodeDelimited=function(V,R){return this.encode(V,R).ldelim()},X.decode=function(V,R){V instanceof K||(V=K.create(V));for(var z=R===void 0?V.len:V.pos+R,Y=new Z.onnx.TypeProto.Tensor;V.pos<z;){var B=V.uint32();switch(B>>>3){case 1:{Y.elemType=V.int32();break}case 2:{Y.shape=Z.onnx.TensorShapeProto.decode(V,V.uint32());break}default:V.skipType(B&7);break}}return Y},X.decodeDelimited=function(V){return V instanceof K||(V=new K(V)),this.decode(V,V.uint32())},X.verify=function(V){if(typeof V!="object"||V===null)return"object expected";if(V.elemType!=null&&V.hasOwnProperty("elemType")&&!U.isInteger(V.elemType))return"elemType: integer expected";if(V.shape!=null&&V.hasOwnProperty("shape")){var R=Z.onnx.TensorShapeProto.verify(V.shape);if(R)return"shape."+R}return null},X.fromObject=function(V){if(V instanceof Z.onnx.TypeProto.Tensor)return V;var R=new Z.onnx.TypeProto.Tensor;if(V.elemType!=null&&(R.elemType=V.elemType|0),V.shape!=null){if(typeof V.shape!="object")throw TypeError(".onnx.TypeProto.Tensor.shape: object expected");R.shape=Z.onnx.TensorShapeProto.fromObject(V.shape)}return R},X.toObject=function(V,R){R||(R={});var z={};return R.defaults&&(z.elemType=0,z.shape=null),V.elemType!=null&&V.hasOwnProperty("elemType")&&(z.elemType=V.elemType),V.shape!=null&&V.hasOwnProperty("shape")&&(z.shape=Z.onnx.TensorShapeProto.toObject(V.shape,R)),z},X.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},X.getTypeUrl=function(V){return V===void 0&&(V="type.googleapis.com"),V+"/onnx.TypeProto.Tensor"},X}(),G.Sequence=function(){function X(V){if(V)for(var R=Object.keys(V),z=0;z<R.length;++z)V[R[z]]!=null&&(this[R[z]]=V[R[z]])}return X.prototype.elemType=null,X.create=function(V){return new X(V)},X.encode=function(V,R){return R||(R=W.create()),V.elemType!=null&&Object.hasOwnProperty.call(V,"elemType")&&Z.onnx.TypeProto.encode(V.elemType,R.uint32(10).fork()).ldelim(),R},X.encodeDelimited=function(V,R){return this.encode(V,R).ldelim()},X.decode=function(V,R){V instanceof K||(V=K.create(V));for(var z=R===void 0?V.len:V.pos+R,Y=new Z.onnx.TypeProto.Sequence;V.pos<z;){var B=V.uint32();switch(B>>>3){case 1:{Y.elemType=Z.onnx.TypeProto.decode(V,V.uint32());break}default:V.skipType(B&7);break}}return Y},X.decodeDelimited=function(V){return V instanceof K||(V=new K(V)),this.decode(V,V.uint32())},X.verify=function(V){if(typeof V!="object"||V===null)return"object expected";if(V.elemType!=null&&V.hasOwnProperty("elemType")){var R=Z.onnx.TypeProto.verify(V.elemType);if(R)return"elemType."+R}return null},X.fromObject=function(V){if(V instanceof Z.onnx.TypeProto.Sequence)return V;var R=new Z.onnx.TypeProto.Sequence;if(V.elemType!=null){if(typeof V.elemType!="object")throw TypeError(".onnx.TypeProto.Sequence.elemType: object expected");R.elemType=Z.onnx.TypeProto.fromObject(V.elemType)}return R},X.toObject=function(V,R){R||(R={});var z={};return R.defaults&&(z.elemType=null),V.elemType!=null&&V.hasOwnProperty("elemType")&&(z.elemType=Z.onnx.TypeProto.toObject(V.elemType,R)),z},X.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},X.getTypeUrl=function(V){return V===void 0&&(V="type.googleapis.com"),V+"/onnx.TypeProto.Sequence"},X}(),G.Map=function(){function X(V){if(V)for(var R=Object.keys(V),z=0;z<R.length;++z)V[R[z]]!=null&&(this[R[z]]=V[R[z]])}return X.prototype.keyType=0,X.prototype.valueType=null,X.create=function(V){return new X(V)},X.encode=function(V,R){return R||(R=W.create()),V.keyType!=null&&Object.hasOwnProperty.call(V,"keyType")&&R.uint32(8).int32(V.keyType),V.valueType!=null&&Object.hasOwnProperty.call(V,"valueType")&&Z.onnx.TypeProto.encode(V.valueType,R.uint32(18).fork()).ldelim(),R},X.encodeDelimited=function(V,R){return this.encode(V,R).ldelim()},X.decode=function(V,R){V instanceof K||(V=K.create(V));for(var z=R===void 0?V.len:V.pos+R,Y=new Z.onnx.TypeProto.Map;V.pos<z;){var B=V.uint32();switch(B>>>3){case 1:{Y.keyType=V.int32();break}case 2:{Y.valueType=Z.onnx.TypeProto.decode(V,V.uint32());break}default:V.skipType(B&7);break}}return Y},X.decodeDelimited=function(V){return V instanceof K||(V=new K(V)),this.decode(V,V.uint32())},X.verify=function(V){if(typeof V!="object"||V===null)return"object expected";if(V.keyType!=null&&V.hasOwnProperty("keyType")&&!U.isInteger(V.keyType))return"keyType: integer expected";if(V.valueType!=null&&V.hasOwnProperty("valueType")){var R=Z.onnx.TypeProto.verify(V.valueType);if(R)return"valueType."+R}return null},X.fromObject=function(V){if(V instanceof Z.onnx.TypeProto.Map)return V;var R=new Z.onnx.TypeProto.Map;if(V.keyType!=null&&(R.keyType=V.keyType|0),V.valueType!=null){if(typeof V.valueType!="object")throw TypeError(".onnx.TypeProto.Map.valueType: object expected");R.valueType=Z.onnx.TypeProto.fromObject(V.valueType)}return R},X.toObject=function(V,R){R||(R={});var z={};return R.defaults&&(z.keyType=0,z.valueType=null),V.keyType!=null&&V.hasOwnProperty("keyType")&&(z.keyType=V.keyType),V.valueType!=null&&V.hasOwnProperty("valueType")&&(z.valueType=Z.onnx.TypeProto.toObject(V.valueType,R)),z},X.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},X.getTypeUrl=function(V){return V===void 0&&(V="type.googleapis.com"),V+"/onnx.TypeProto.Map"},X}(),G.Optional=function(){function X(V){if(V)for(var R=Object.keys(V),z=0;z<R.length;++z)V[R[z]]!=null&&(this[R[z]]=V[R[z]])}return X.prototype.elemType=null,X.create=function(V){return new X(V)},X.encode=function(V,R){return R||(R=W.create()),V.elemType!=null&&Object.hasOwnProperty.call(V,"elemType")&&Z.onnx.TypeProto.encode(V.elemType,R.uint32(10).fork()).ldelim(),R},X.encodeDelimited=function(V,R){return this.encode(V,R).ldelim()},X.decode=function(V,R){V instanceof K||(V=K.create(V));for(var z=R===void 0?V.len:V.pos+R,Y=new Z.onnx.TypeProto.Optional;V.pos<z;){var B=V.uint32();switch(B>>>3){case 1:{Y.elemType=Z.onnx.TypeProto.decode(V,V.uint32());break}default:V.skipType(B&7);break}}return Y},X.decodeDelimited=function(V){return V instanceof K||(V=new K(V)),this.decode(V,V.uint32())},X.verify=function(V){if(typeof V!="object"||V===null)return"object expected";if(V.elemType!=null&&V.hasOwnProperty("elemType")){var R=Z.onnx.TypeProto.verify(V.elemType);if(R)return"elemType."+R}return null},X.fromObject=function(V){if(V instanceof Z.onnx.TypeProto.Optional)return V;var R=new Z.onnx.TypeProto.Optional;if(V.elemType!=null){if(typeof V.elemType!="object")throw TypeError(".onnx.TypeProto.Optional.elemType: object expected");R.elemType=Z.onnx.TypeProto.fromObject(V.elemType)}return R},X.toObject=function(V,R){R||(R={});var z={};return R.defaults&&(z.elemType=null),V.elemType!=null&&V.hasOwnProperty("elemType")&&(z.elemType=Z.onnx.TypeProto.toObject(V.elemType,R)),z},X.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},X.getTypeUrl=function(V){return V===void 0&&(V="type.googleapis.com"),V+"/onnx.TypeProto.Optional"},X}(),G.SparseTensor=function(){function X(V){if(V)for(var R=Object.keys(V),z=0;z<R.length;++z)V[R[z]]!=null&&(this[R[z]]=V[R[z]])}return X.prototype.elemType=0,X.prototype.shape=null,X.create=function(V){return new X(V)},X.encode=function(V,R){return R||(R=W.create()),V.elemType!=null&&Object.hasOwnProperty.call(V,"elemType")&&R.uint32(8).int32(V.elemType),V.shape!=null&&Object.hasOwnProperty.call(V,"shape")&&Z.onnx.TensorShapeProto.encode(V.shape,R.uint32(18).fork()).ldelim(),R},X.encodeDelimited=function(V,R){return this.encode(V,R).ldelim()},X.decode=function(V,R){V instanceof K||(V=K.create(V));for(var z=R===void 0?V.len:V.pos+R,Y=new Z.onnx.TypeProto.SparseTensor;V.pos<z;){var B=V.uint32();switch(B>>>3){case 1:{Y.elemType=V.int32();break}case 2:{Y.shape=Z.onnx.TensorShapeProto.decode(V,V.uint32());break}default:V.skipType(B&7);break}}return Y},X.decodeDelimited=function(V){return V instanceof K||(V=new K(V)),this.decode(V,V.uint32())},X.verify=function(V){if(typeof V!="object"||V===null)return"object expected";if(V.elemType!=null&&V.hasOwnProperty("elemType")&&!U.isInteger(V.elemType))return"elemType: integer expected";if(V.shape!=null&&V.hasOwnProperty("shape")){var R=Z.onnx.TensorShapeProto.verify(V.shape);if(R)return"shape."+R}return null},X.fromObject=function(V){if(V instanceof Z.onnx.TypeProto.SparseTensor)return V;var R=new Z.onnx.TypeProto.SparseTensor;if(V.elemType!=null&&(R.elemType=V.elemType|0),V.shape!=null){if(typeof V.shape!="object")throw TypeError(".onnx.TypeProto.SparseTensor.shape: object expected");R.shape=Z.onnx.TensorShapeProto.fromObject(V.shape)}return R},X.toObject=function(V,R){R||(R={});var z={};return R.defaults&&(z.elemType=0,z.shape=null),V.elemType!=null&&V.hasOwnProperty("elemType")&&(z.elemType=V.elemType),V.shape!=null&&V.hasOwnProperty("shape")&&(z.shape=Z.onnx.TensorShapeProto.toObject(V.shape,R)),z},X.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},X.getTypeUrl=function(V){return V===void 0&&(V="type.googleapis.com"),V+"/onnx.TypeProto.SparseTensor"},X}(),G}(),q.OperatorSetIdProto=function(){function G(J){if(J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.domain="",G.prototype.version=U.Long?U.Long.fromBits(0,0,!1):0,G.create=function(J){return new G(J)},G.encode=function(J,X){return X||(X=W.create()),J.domain!=null&&Object.hasOwnProperty.call(J,"domain")&&X.uint32(10).string(J.domain),J.version!=null&&Object.hasOwnProperty.call(J,"version")&&X.uint32(16).int64(J.version),X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.OperatorSetIdProto;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{R.domain=J.string();break}case 2:{R.version=J.int64();break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){return typeof J!="object"||J===null?"object expected":J.domain!=null&&J.hasOwnProperty("domain")&&!U.isString(J.domain)?"domain: string expected":J.version!=null&&J.hasOwnProperty("version")&&!U.isInteger(J.version)&&!(J.version&&U.isInteger(J.version.low)&&U.isInteger(J.version.high))?"version: integer|Long expected":null},G.fromObject=function(J){if(J instanceof Z.onnx.OperatorSetIdProto)return J;var X=new Z.onnx.OperatorSetIdProto;return J.domain!=null&&(X.domain=String(J.domain)),J.version!=null&&(U.Long?(X.version=U.Long.fromValue(J.version)).unsigned=!1:typeof J.version=="string"?X.version=parseInt(J.version,10):typeof J.version=="number"?X.version=J.version:typeof J.version=="object"&&(X.version=new U.LongBits(J.version.low>>>0,J.version.high>>>0).toNumber())),X},G.toObject=function(J,X){X||(X={});var V={};if(X.defaults)if(V.domain="",U.Long){var R=new U.Long(0,0,!1);V.version=X.longs===String?R.toString():X.longs===Number?R.toNumber():R}else V.version=X.longs===String?"0":0;return J.domain!=null&&J.hasOwnProperty("domain")&&(V.domain=J.domain),J.version!=null&&J.hasOwnProperty("version")&&(typeof J.version=="number"?V.version=X.longs===String?String(J.version):J.version:V.version=X.longs===String?U.Long.prototype.toString.call(J.version):X.longs===Number?new U.LongBits(J.version.low>>>0,J.version.high>>>0).toNumber():J.version),V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.OperatorSetIdProto"},G}(),q.OperatorStatus=function(){var G={},J=Object.create(G);return J[G[0]="EXPERIMENTAL"]=0,J[G[1]="STABLE"]=1,J}(),q.FunctionProto=function(){function G(J){if(this.input=[],this.output=[],this.attribute=[],this.attributeProto=[],this.node=[],this.opsetImport=[],J)for(var X=Object.keys(J),V=0;V<X.length;++V)J[X[V]]!=null&&(this[X[V]]=J[X[V]])}return G.prototype.name="",G.prototype.input=U.emptyArray,G.prototype.output=U.emptyArray,G.prototype.attribute=U.emptyArray,G.prototype.attributeProto=U.emptyArray,G.prototype.node=U.emptyArray,G.prototype.docString="",G.prototype.opsetImport=U.emptyArray,G.prototype.domain="",G.create=function(J){return new G(J)},G.encode=function(J,X){if(X||(X=W.create()),J.name!=null&&Object.hasOwnProperty.call(J,"name")&&X.uint32(10).string(J.name),J.input!=null&&J.input.length)for(var V=0;V<J.input.length;++V)X.uint32(34).string(J.input[V]);if(J.output!=null&&J.output.length)for(var V=0;V<J.output.length;++V)X.uint32(42).string(J.output[V]);if(J.attribute!=null&&J.attribute.length)for(var V=0;V<J.attribute.length;++V)X.uint32(50).string(J.attribute[V]);if(J.node!=null&&J.node.length)for(var V=0;V<J.node.length;++V)Z.onnx.NodeProto.encode(J.node[V],X.uint32(58).fork()).ldelim();if(J.docString!=null&&Object.hasOwnProperty.call(J,"docString")&&X.uint32(66).string(J.docString),J.opsetImport!=null&&J.opsetImport.length)for(var V=0;V<J.opsetImport.length;++V)Z.onnx.OperatorSetIdProto.encode(J.opsetImport[V],X.uint32(74).fork()).ldelim();if(J.domain!=null&&Object.hasOwnProperty.call(J,"domain")&&X.uint32(82).string(J.domain),J.attributeProto!=null&&J.attributeProto.length)for(var V=0;V<J.attributeProto.length;++V)Z.onnx.AttributeProto.encode(J.attributeProto[V],X.uint32(90).fork()).ldelim();return X},G.encodeDelimited=function(J,X){return this.encode(J,X).ldelim()},G.decode=function(J,X){J instanceof K||(J=K.create(J));for(var V=X===void 0?J.len:J.pos+X,R=new Z.onnx.FunctionProto;J.pos<V;){var z=J.uint32();switch(z>>>3){case 1:{R.name=J.string();break}case 4:{R.input&&R.input.length||(R.input=[]),R.input.push(J.string());break}case 5:{R.output&&R.output.length||(R.output=[]),R.output.push(J.string());break}case 6:{R.attribute&&R.attribute.length||(R.attribute=[]),R.attribute.push(J.string());break}case 11:{R.attributeProto&&R.attributeProto.length||(R.attributeProto=[]),R.attributeProto.push(Z.onnx.AttributeProto.decode(J,J.uint32()));break}case 7:{R.node&&R.node.length||(R.node=[]),R.node.push(Z.onnx.NodeProto.decode(J,J.uint32()));break}case 8:{R.docString=J.string();break}case 9:{R.opsetImport&&R.opsetImport.length||(R.opsetImport=[]),R.opsetImport.push(Z.onnx.OperatorSetIdProto.decode(J,J.uint32()));break}case 10:{R.domain=J.string();break}default:J.skipType(z&7);break}}return R},G.decodeDelimited=function(J){return J instanceof K||(J=new K(J)),this.decode(J,J.uint32())},G.verify=function(J){if(typeof J!="object"||J===null)return"object expected";if(J.name!=null&&J.hasOwnProperty("name")&&!U.isString(J.name))return"name: string expected";if(J.input!=null&&J.hasOwnProperty("input")){if(!Array.isArray(J.input))return"input: array expected";for(var X=0;X<J.input.length;++X)if(!U.isString(J.input[X]))return"input: string[] expected"}if(J.output!=null&&J.hasOwnProperty("output")){if(!Array.isArray(J.output))return"output: array expected";for(var X=0;X<J.output.length;++X)if(!U.isString(J.output[X]))return"output: string[] expected"}if(J.attribute!=null&&J.hasOwnProperty("attribute")){if(!Array.isArray(J.attribute))return"attribute: array expected";for(var X=0;X<J.attribute.length;++X)if(!U.isString(J.attribute[X]))return"attribute: string[] expected"}if(J.attributeProto!=null&&J.hasOwnProperty("attributeProto")){if(!Array.isArray(J.attributeProto))return"attributeProto: array expected";for(var X=0;X<J.attributeProto.length;++X){var V=Z.onnx.AttributeProto.verify(J.attributeProto[X]);if(V)return"attributeProto."+V}}if(J.node!=null&&J.hasOwnProperty("node")){if(!Array.isArray(J.node))return"node: array expected";for(var X=0;X<J.node.length;++X){var V=Z.onnx.NodeProto.verify(J.node[X]);if(V)return"node."+V}}if(J.docString!=null&&J.hasOwnProperty("docString")&&!U.isString(J.docString))return"docString: string expected";if(J.opsetImport!=null&&J.hasOwnProperty("opsetImport")){if(!Array.isArray(J.opsetImport))return"opsetImport: array expected";for(var X=0;X<J.opsetImport.length;++X){var V=Z.onnx.OperatorSetIdProto.verify(J.opsetImport[X]);if(V)return"opsetImport."+V}}return J.domain!=null&&J.hasOwnProperty("domain")&&!U.isString(J.domain)?"domain: string expected":null},G.fromObject=function(J){if(J instanceof Z.onnx.FunctionProto)return J;var X=new Z.onnx.FunctionProto;if(J.name!=null&&(X.name=String(J.name)),J.input){if(!Array.isArray(J.input))throw TypeError(".onnx.FunctionProto.input: array expected");X.input=[];for(var V=0;V<J.input.length;++V)X.input[V]=String(J.input[V])}if(J.output){if(!Array.isArray(J.output))throw TypeError(".onnx.FunctionProto.output: array expected");X.output=[];for(var V=0;V<J.output.length;++V)X.output[V]=String(J.output[V])}if(J.attribute){if(!Array.isArray(J.attribute))throw TypeError(".onnx.FunctionProto.attribute: array expected");X.attribute=[];for(var V=0;V<J.attribute.length;++V)X.attribute[V]=String(J.attribute[V])}if(J.attributeProto){if(!Array.isArray(J.attributeProto))throw TypeError(".onnx.FunctionProto.attributeProto: array expected");X.attributeProto=[];for(var V=0;V<J.attributeProto.length;++V){if(typeof J.attributeProto[V]!="object")throw TypeError(".onnx.FunctionProto.attributeProto: object expected");X.attributeProto[V]=Z.onnx.AttributeProto.fromObject(J.attributeProto[V])}}if(J.node){if(!Array.isArray(J.node))throw TypeError(".onnx.FunctionProto.node: array expected");X.node=[];for(var V=0;V<J.node.length;++V){if(typeof J.node[V]!="object")throw TypeError(".onnx.FunctionProto.node: object expected");X.node[V]=Z.onnx.NodeProto.fromObject(J.node[V])}}if(J.docString!=null&&(X.docString=String(J.docString)),J.opsetImport){if(!Array.isArray(J.opsetImport))throw TypeError(".onnx.FunctionProto.opsetImport: array expected");X.opsetImport=[];for(var V=0;V<J.opsetImport.length;++V){if(typeof J.opsetImport[V]!="object")throw TypeError(".onnx.FunctionProto.opsetImport: object expected");X.opsetImport[V]=Z.onnx.OperatorSetIdProto.fromObject(J.opsetImport[V])}}return J.domain!=null&&(X.domain=String(J.domain)),X},G.toObject=function(J,X){X||(X={});var V={};if((X.arrays||X.defaults)&&(V.input=[],V.output=[],V.attribute=[],V.node=[],V.opsetImport=[],V.attributeProto=[]),X.defaults&&(V.name="",V.docString="",V.domain=""),J.name!=null&&J.hasOwnProperty("name")&&(V.name=J.name),J.input&&J.input.length){V.input=[];for(var R=0;R<J.input.length;++R)V.input[R]=J.input[R]}if(J.output&&J.output.length){V.output=[];for(var R=0;R<J.output.length;++R)V.output[R]=J.output[R]}if(J.attribute&&J.attribute.length){V.attribute=[];for(var R=0;R<J.attribute.length;++R)V.attribute[R]=J.attribute[R]}if(J.node&&J.node.length){V.node=[];for(var R=0;R<J.node.length;++R)V.node[R]=Z.onnx.NodeProto.toObject(J.node[R],X)}if(J.docString!=null&&J.hasOwnProperty("docString")&&(V.docString=J.docString),J.opsetImport&&J.opsetImport.length){V.opsetImport=[];for(var R=0;R<J.opsetImport.length;++R)V.opsetImport[R]=Z.onnx.OperatorSetIdProto.toObject(J.opsetImport[R],X)}if(J.domain!=null&&J.hasOwnProperty("domain")&&(V.domain=J.domain),J.attributeProto&&J.attributeProto.length){V.attributeProto=[];for(var R=0;R<J.attributeProto.length;++R)V.attributeProto[R]=Z.onnx.AttributeProto.toObject(J.attributeProto[R],X)}return V},G.prototype.toJSON=function(){return this.constructor.toObject(this,j.util.toJSONOptions)},G.getTypeUrl=function(J){return J===void 0&&(J="type.googleapis.com"),J+"/onnx.FunctionProto"},G}(),q}(),H.exports=Z}),V1,x4,Q8,R3,t2,i1,G3,u,L6,R5,h4,b4,Q1=E(()=>{H7(),a2(),V1=Z4(l4()),K4(),x4=class{static arraysEqual(Q,H){if(Q.length!==H.length)return!1;for(let j=0;j<Q.length;j++)if(Q[j]!==H[j])return!1;return!0}},Q8=class{static preprocessInputShapes(Q,H){let j=Q.length===1?[1,Q[0]]:Q,K=H.length===1?[H[0],1]:H;return[j,K]}static postprocessOutputShape(Q,H,j){H===1&&Q.splice(Q.length-2,1),j===1&&Q.pop()}static calcMatMulShape(Q,H){return Q[1]!==H[0]?void 0:[Q[0],H[1]]}},R3=class Q{static calcShape(H,j,K=!1){let W=H.length,U=j.length;if(W===0)return j;if(U===0)return H;let Z=Math.max(H.length,j.length),q=new Array(Z);if(K){if(W<2||U<2)return;let G=Q8.calcMatMulShape([H[W-2],H[W-1]],[j[U-2],j[U-1]]);if(G===void 0)return;[q[Z-2],q[Z-1]]=G}for(let G=K?3:1;G<=Z;G++){let J=W-G<0?1:H[W-G],X=U-G<0?1:j[U-G];if(J!==X&&J>1&&X>1)return;q[Z-G]=Math.max(J,X)}return q}static index(H,j){let K=new Array(j.length);return Q.fillIndex(H,j,K),K}static fillIndex(H,j,K){let W=H.length-j.length;for(let U=0;U<j.length;U++)K[U]=H[W+U]%j[U]}static calc(H,j,K,W,U){let Z=Q.calcShape(H.dims,j.dims);if(Z){if(W&&!u.areEqual(Z,H.dims))return;let q=u.size(Z),G=W?H:new o1(Z,U||H.type);if(Z.length===0)G.set([],K(H.get([]),j.get([])));else{let J=new Array(Z.length),X=new Array(H.dims.length),V=new Array(j.dims.length),R=0,z=0,Y=!1,B=!1;H.dims.length===0&&(R=H.get([]),Y=!0),j.dims.length===0&&(z=j.get([]),B=!0);let k;for(let w=0;w<q;w++){k=w;for(let A=Z.length-1;A>=0;A--)J[A]=k%Z[A],k=Math.floor(k/Z[A]);Y||(Q.fillIndex(J,H.dims,X),R=H.get(X)),B||(Q.fillIndex(J,j.dims,V),z=j.get(V)),G.set(J,K(R,z))}}return G}}static isValidBroadcast(H,j){let K=H.length,W=j.length;if(K>W)return!1;for(let U=1;U<=K;U++)if(H[K-U]!==1&&H[K-U]!==j[W-U])return!1;return!0}static getBroadcastDims(H,j){let K=H.length,W=[];for(let U=0;U<K;U++){let Z=K-1-U,q=H[Z]||1;(j[j.length-1-U]||1)>1&&q===1&&W.unshift(Z)}return W}},t2=class{static getShapeOfGemmResult(Q,H,j,K,W){if(Q.length!==2||j.length!==2)throw new Error("shape need to be of size 2");let U,Z,q;H?(U=Q[1],Z=Q[0]):(U=Q[0],Z=Q[1]);let G=-1;if(K?(q=j[0],G=1):(q=j[1],G=0),j[G]!==Z)throw new Error("dimension mismatch");if(U<=0||q<=0||Z<=0)throw new Error("invalid shape specified");if(W&&!R3.isValidBroadcast(W,[U,q]))throw new Error("gemm: invalid bias shape for broadcast");return[U,q,Z]}},i1=class Q{static tensorDataTypeFromProto(H){switch(H){case V1.onnx.TensorProto.DataType.INT8:return"int8";case V1.onnx.TensorProto.DataType.UINT8:return"uint8";case V1.onnx.TensorProto.DataType.BOOL:return"bool";case V1.onnx.TensorProto.DataType.INT16:return"int16";case V1.onnx.TensorProto.DataType.UINT16:return"uint16";case V1.onnx.TensorProto.DataType.INT32:return"int32";case V1.onnx.TensorProto.DataType.UINT32:return"uint32";case V1.onnx.TensorProto.DataType.FLOAT:return"float32";case V1.onnx.TensorProto.DataType.DOUBLE:return"float64";case V1.onnx.TensorProto.DataType.STRING:return"string";case V1.onnx.TensorProto.DataType.INT64:return"int32";case V1.onnx.TensorProto.DataType.UINT64:return"uint32";default:throw new Error(`unsupported data type: ${V1.onnx.TensorProto.DataType[H]}`)}}static tensorDataTypeStringToEnum(H){switch(H){case"int8":return V1.onnx.TensorProto.DataType.INT8;case"uint8":return V1.onnx.TensorProto.DataType.UINT8;case"bool":return V1.onnx.TensorProto.DataType.BOOL;case"int16":return V1.onnx.TensorProto.DataType.INT16;case"uint16":return V1.onnx.TensorProto.DataType.UINT16;case"int32":return V1.onnx.TensorProto.DataType.INT32;case"uint32":return V1.onnx.TensorProto.DataType.UINT32;case"float32":return V1.onnx.TensorProto.DataType.FLOAT;case"float64":return V1.onnx.TensorProto.DataType.DOUBLE;case"string":return V1.onnx.TensorProto.DataType.STRING;case"int64":return V1.onnx.TensorProto.DataType.INT64;case"uint64":return V1.onnx.TensorProto.DataType.UINT64;default:throw new Error(`unsupported data type: ${H}`)}}static tensorDimsFromProto(H){return H.map((j)=>_3.isLong(j)?j.toNumber():j)}static tensorValueTypeFromProto(H){return{tensorType:Q.tensorDataTypeFromProto(H.elemType),shape:{dims:Q.tensorDimsFromProto(H.shape.dim.map((j)=>j.dimValue))}}}static tensorDimsFromORTFormat(H){let j=[];for(let K=0;K<H.dimsLength();K++)j.push(G3.longToNumber(H.dims(K)));return j}static tensorAttributesFromORTFormat(H){let j=[];for(let K=0;K<H.attributesLength();K++)j.push(H.attributes(K));return j}},G3=class{static longToNumber(Q,H){return _3.isLong(Q)?Q.toNumber():Q instanceof $.Long?_3.fromValue({low:Q.low,high:Q.high,unsigned:H??!1}).toNumber():Q}static isLong(Q){return _3.isLong(Q)||Q instanceof $.Long}},u=class Q{static size(H){return Q.getSizeFromDimensionRange(H,0,H.length)}static sizeFromDimension(H,j){if(j<0||j>H.length)throw new Error(`invalid dimension of ${j} for sizeFromDimension as Tensor has ${H.length} dimensions.`);return Q.getSizeFromDimensionRange(H,j,H.length)}static sizeToDimension(H,j){if(j<0||j>H.length)throw new Error(`invalid dimension of ${j} for sizeToDimension as Tensor has ${H.length} dimensions.`);return Q.getSizeFromDimensionRange(H,0,j)}static getSizeFromDimensionRange(H,j,K){let W=1;for(let U=j;U<K;U++){if(H[U]<=0)throw new Error("cannot get valid size from specified dimension range. Most likely the range contains 0 or negative values in them.");W*=H[U]}return W}static computeStrides(H){let j=H.length;if(j===0)return[];if(j===1)return[1];let K=new Array(j);K[j-1]=1,K[j-2]=H[j-1];for(let W=j-3;W>=0;--W)K[W]=K[W+1]*H[W+1];return K}static transpose(H){return H.slice().reverse()}static indicesToOffset(H,j,K){K===void 0&&(K=H.length);let W=0;for(let U=0;U<K;++U)W+=j[U]*H[U];return W}static offsetToIndices(H,j){let K=j.length;if(K===0)return[];if(K===1)return[H*j[0]];let W=new Array(j.length);for(let U=0;U<W.length-1;++U)W[U]=Math.floor(H/j[U]),H-=W[U]*j[U];return W[W.length-1]=H,W}static normalizeAxis(H,j){if(H<-j&&H>=j)throw new Error("unsupported axis for this operation.");return H<0?H+j:H}static normalizeAxes(H,j){return H.map((K)=>this.normalizeAxis(K,j))}static incrementIndex(H,j,K){if(j.length===0||H.length===0)throw new Error("Index incrementing unsupported for scalar Tensor");if(K===void 0)K=j.length;else if(K<=0||K>j.length)throw new Error("Incorrect axis to increment on");for(let W=K-1;W>=0&&(H[W]++,!(H[W]<j[W]));--W)H[W]=0}static calculateReshapedDims(H,j){if(j.length===0){if(H.length===0||Q.size(H)===1)return[];throw new Error("cannot reshape to a scalar Tensor")}let K=j.length,W=new Array(K),U=-1,Z=1;for(let G=0;G<K;G++){if(j[G]<-1)throw new Error("a dimension in shape hints cannot be less than -1");if(j[G]===-1){if(U!==-1)throw new Error("at most one dimension in shape hints can be -1");U=G}else{if(j[G]===0){if(G>=H.length)throw new Error("the dimension with value zero exceeds the dimension size of the input tensor");W[G]=H[G]}else W[G]=j[G];Z*=W[G]}}let q=Q.size(H);if(U!==-1){if(q%Z!==0)throw new Error(`the input tensor cannot be reshaped to the requested shape. Input shape: [${H}] Output shape: [${j}]`);W[U]=q/Z}else if(Z!==q)throw new Error("reshapedDims and originalDims don't have matching sizes");return W}static sortBasedOnPerm(H,j){return j?j.map((K)=>H[K]):H.slice().reverse()}static padShape(H,j){let K=H.length;return H.map((W,U)=>W+j[U]+j[U+K])}static areEqual(H,j){return H.length!==j.length?!1:H.every((K,W)=>K===j[W])}static validateDimsAndCalcSize(H){if(H.length>6)throw new TypeError("Only rank 0 to 6 is supported for tensor shape.");let j=1;for(let K of H){if(!Number.isInteger(K))throw new TypeError(`Invalid shape: ${K} is not an integer`);if(K<0||K>2147483647)throw new TypeError(`Invalid shape: length ${K} is not allowed`);j*=K}return j}static flattenShape(H,j){j<0&&(j+=H.length);let K=H.reduce((U,Z)=>U*Z,1),W=H.slice(j).reduce((U,Z)=>U*Z,1);return[K/W,W]}static squeezeShape(H,j){let K=new Array;j=Q.normalizeAxes(j,H.length);for(let W=0;W<H.length;W++){let U=j.indexOf(W)>=0;if(U&&H[W]!==1)throw new Error("squeeze an axis of size different than 1");(j.length===0&&H[W]>1||j.length>0&&!U)&&K.push(H[W])}return K}static unsqueezeShape(H,j){let K=new Array(H.length+j.length);K.fill(0);for(let U=0;U<j.length;U++){let Z=Q.normalizeAxis(j[U],K.length);if(Z>=K.length)throw new Error("'axes' has an out of range axis");if(K[Z]!==0)throw new Error("'axes' has a duplicate axis");K[Z]=1}let W=0;for(let U=0;U<K.length;U++)K[U]===0&&(K[U]=H[W++]);if(W!==H.length)throw new Error("the unsqueezed dimension could not be established");return K}},L6=class Q{static splitShape(H,j,K,W){if(K.length===0){if(!W)throw new Error("need to know number of outputs when the 'split' attribute is not specified");Q.determineSplit(H[j],W,K)}let U=[],Z=[0];for(let q=0;q<K.length;++q){q!==0&&Z.push(Z[q-1]+K[q-1]);let G=H.slice();G[j]=K[q],U.push(G)}return[U,Z]}static determineSplit(H,j,K){if(H%j!==0)throw new Error("cannot split tensor to equal sized parts");for(let W=0;W<j;++W)K.push(H/j)}},R5=class Q{static adjustPoolAttributes(H,j,K,W,U,Z){if(!H&&K.length!==j.length-2)throw new Error("length of specified kernel shapes should be 2 less than length of input dimensions");if(H)for(let q=0;q<j.length-2;q++)q>=K.length?K.push(j[q+2]):K[q]=j[q+2];for(let q=0;q<K.length;q++)if(q<W.length){if(W[q]<0)throw new Error("strides should be greater than or equal to 1")}else W.push(1);for(let q=0;q<K.length;q++)if(q<U.length){if(U[q]<0)throw new Error("dilations should be greater than or equal to 1")}else U.push(1);for(let q=0;q<K.length*2;q++)if(q<Z.length){if(Z[q]<0)throw new Error("pad should be greater than or equal to 1")}else Z.push(0);for(let q=0;q<K.length;q++){if(K[q]<=0)throw new Error("kernel shapes need to be greater than 0");if(Z[q]>=K[q]||Z[q+K.length]>=K[q])throw new Error("pads should be smaller than kernel")}}static adjustPadsBasedOnAutoPad(H,j,K,W,U,Z){if(Z){if(U.length!==2*(H.length-2))throw new Error("length of pads should be twice the length of data dimensions");if(j.length!==H.length-2)throw new Error("length of strides should be the length of data dimensions");if(W.length!==H.length-2)throw new Error("length of kernel shapes should be the length of data dimensions");for(let q=0;q<H.length-2;q++)Q.adjustPadAndReturnShape(H[q+2],j[q],K[q],W[q],U,q,q+H.length-2,Z)}}static computePoolOutputShape(H,j,K,W,U,Z,q){if(j.length<=0)throw new Error("input shape must be of size greater than 0");let G=[j[0],j[1]];return Q.computeShapeHelper(H,j,G,K,W,U,Z,q),G}static computeConvOutputShape(H,j,K,W,U,Z,q){if(H.length<=0||j.length<=0)throw new Error("invalid input tensor dims or invalid filter tensor dims");let G=[H[0],j[0]];return Q.computeShapeHelper(!1,H,G,K,W,U,Z,q),G}static computeShapeHelper(H,j,K,W,U,Z,q,G){if(H)for(let J=0;J<j.length-2;J++)K.push(1);else for(let J=0;J<j.length-2;J++)K.push(Q.adjustPadAndReturnShape(j[J+2],W[J],U[J],Z[J],q,J,J+j.length-2,G))}static adjustPadAndReturnShape(H,j,K,W,U,Z,q,G){let J=K*(W-1)+1;if(G&&G!=="NOTSET")switch(G){case"VALID":return U[Z]=0,U[q]=0,Math.floor((H-J)/j+1);case"SAME_LOWER":case"SAME_UPPER":if(K!==1)throw new Error("Dilation not supported for SAME_UPPER or SAME_LOWER");{let X=((H+j-1)/j-1)*j+W-H;return U[Z]=Math.floor(G==="SAME_LOWER"?(X+1)/2:X/2),U[q]=X-U[Z],Math.floor((H+X-W)/j+1)}default:throw new Error("Unsupported AutoPad type")}else return Math.floor((H+U[Z]+U[q]-J)/j+1)}},h4=-340282346638528860000000000000000000000,b4=340282346638528860000000000000000000000}),J8,o,q5,o1,K4=E(()=>{J8=Z4(nZ()),a2(),B5(),o=Z4(l4()),Q1(),q5=H1.experimental.fbs,o1=class Q{constructor(H,j,K,W,U,Z=J8.Guid.create()){this.dims=H,this.type=j,this.dataProvider=K,this.asyncDataProvider=W,this.cache=U,this.dataId=Z,this.size=u.validateDimsAndCalcSize(H);let q=this.size,G=K===void 0&&W===void 0&&U===void 0;if(U!==void 0&&U.length!==q)throw new RangeError("Input dims doesn't match data length.");if(j==="string"){if(U!==void 0&&(!Array.isArray(U)||!U.every((J)=>typeof J=="string")))throw new TypeError("cache should be a string array");G&&(this.cache=new Array(q))}else{if(U!==void 0){let J=A2(j);if(!(U instanceof J))throw new TypeError(`cache should be type ${J.name}`)}if(G){let J=new ArrayBuffer(q*$H(j));this.cache=LH(J,j)}}}get data(){if(this.cache===void 0){let H=this.dataProvider(this.dataId);if(H.length!==this.size)throw new Error("Length of data provided by the Data Provider is inconsistent with the dims of this Tensor.");this.cache=H}return this.cache}get stringData(){if(this.type!=="string")throw new TypeError("data type is not string");return this.data}get integerData(){switch(this.type){case"uint8":case"int8":case"uint16":case"int16":case"int32":case"uint32":case"bool":return this.data;default:throw new TypeError("data type is not integer (uint8, int8, uint16, int16, int32, uint32, bool)")}}get floatData(){switch(this.type){case"float32":case"float64":return this.data;default:throw new TypeError("data type is not float (float32, float64)")}}get numberData(){if(this.type!=="string")return this.data;throw new TypeError("type cannot be non-number (string)")}get(H){return this.data[u.indicesToOffset(H,this.strides)]}set(H,j){this.data[u.indicesToOffset(H,this.strides)]=j}async getData(){return this.cache===void 0&&(this.cache=await this.asyncDataProvider(this.dataId)),this.cache}get strides(){return this._strides||(this._strides=u.computeStrides(this.dims)),this._strides}static fromProto(H){if(!H)throw new Error("cannot construct Value from an empty tensor");let j=i1.tensorDataTypeFromProto(H.dataType),K=i1.tensorDimsFromProto(H.dims),W=new Q(K,j);if(j==="string")H.stringData.forEach((U,Z)=>{W.data[Z]=N6(U)});else if(H.rawData&&typeof H.rawData.byteLength=="number"&&H.rawData.byteLength>0){let U=W.data,Z=new DataView(H.rawData.buffer,H.rawData.byteOffset,H.rawData.byteLength),q=f7(H.dataType),G=H.rawData.byteLength/q;if(H.rawData.byteLength%q!==0)throw new Error("invalid buffer length");if(U.length!==G)throw new Error("buffer length mismatch");for(let J=0;J<G;J++){let X=l7(Z,H.dataType,J*q);U[J]=X}}else{let U;switch(H.dataType){case o.onnx.TensorProto.DataType.FLOAT:U=H.floatData;break;case o.onnx.TensorProto.DataType.INT32:case o.onnx.TensorProto.DataType.INT16:case o.onnx.TensorProto.DataType.UINT16:case o.onnx.TensorProto.DataType.INT8:case o.onnx.TensorProto.DataType.UINT8:case o.onnx.TensorProto.DataType.BOOL:U=H.int32Data;break;case o.onnx.TensorProto.DataType.INT64:U=H.int64Data;break;case o.onnx.TensorProto.DataType.DOUBLE:U=H.doubleData;break;case o.onnx.TensorProto.DataType.UINT32:case o.onnx.TensorProto.DataType.UINT64:U=H.uint64Data;break;default:throw new Error("unspecific error")}if(U==null)throw new Error("failed to populate data from a tensorproto value");let Z=W.data;if(Z.length!==U.length)throw new Error("array length mismatch");for(let q=0;q<U.length;q++){let G=U[q];_3.isLong(G)?Z[q]=M6(G,H.dataType):Z[q]=G}}return W}static fromData(H,j,K){return new Q(j,K,void 0,void 0,H)}static fromOrtTensor(H){if(!H)throw new Error("cannot construct Value from an empty tensor");let j=i1.tensorDimsFromORTFormat(H),K=i1.tensorDataTypeFromProto(H.dataType()),W=new Q(j,K);if(K==="string")for(let U=0;U<H.stringDataLength();U++)W.data[U]=H.stringData(U);else if(H.rawDataArray()&&typeof H.rawDataLength()=="number"&&H.rawDataLength()>0){let U=W.data,Z=new DataView(H.rawDataArray().buffer,H.rawDataArray().byteOffset,H.rawDataLength()),q=f7(H.dataType()),G=H.rawDataLength()/q;if(H.rawDataLength()%q!==0)throw new Error("invalid buffer length");if(U.length!==G)throw new Error("buffer length mismatch");for(let J=0;J<G;J++){let X=l7(Z,H.dataType(),J*q);U[J]=X}}return W}}}),e2,Q0,W1=E(()=>{e2={version:"",attribute:"attribute",varyingVertex:"varying",varyingFrag:"varying",texture2D:"texture2D",output:"gl_FragColor",outputDeclaration:""},Q0={version:"#version 300 es",attribute:"in",varyingVertex:"out",varyingFrag:"in",texture2D:"texture",output:"outputColor",outputDeclaration:"out vec4 outputColor;"}}),t=E(()=>{}),F3=E(()=>{Q1()}),U4=E(()=>{F3()}),b5,H8,J0,Rj=E(()=>{W1(),t(),F3(),U4(),b5={name:"pack",inputNames:["A"],inputTypes:[1]},H8=(Q,H)=>{let j=r(Q.session.backend.glContext.version),K=H.dims,W=K.length,U=H.dims.length,Z=P3(U),q=n6("rc",U),G=IH(U,q,K[K.length-2],K[K.length-1]),J;W===0?J=[1,1]:W===1?J=[K[0],1]:J=[K[U-1],K[U-2]];let X=PH(U,J,q),V=EH(K,q),R=`
+        void main() {
+          ${Z} rc = getOutputCoords();
+
+          if(${X}) {
+            ${j.output} = vec4(0);
+          } else {
+            ${G}
+
+            ${j.output} = vec4(${V});
+          }
+        }
+      `;return{...b5,hasMain:!0,output:{dims:H.dims,type:H.type,textureType:2},shaderSource:R}},J0=(Q,H)=>({...b5,get:()=>H8(Q,H)})}),Z8,j8,H0,zj=E(()=>{Q1(),W1(),t(),U4(),Z8=(Q)=>({name:"Reshape (packed)",inputTypes:[2],inputNames:["A"],cacheHint:`${Q}`}),j8=(Q,H,j,K)=>{let W=H.dims,U=K,Z="";for(let J=0;J<4;J++){let X="";switch(J){case 0:X="outputCoords = rc;";break;case 1:X="outputCoords = ivec3(rc.x, rc.y+1, rc.z);";break;case 2:X="outputCoords = ivec3(rc.x, rc.y, rc.z+1);";break;case 3:X="outputCoords = ivec3(rc.x, rc.y+1, rc.z+1);";break;default:throw new Error}Z+=`
+        ${X}
+        ${J>0?"if(outputCoords.y < rows && outputCoords.z < cols){":""}
+          int flattenedIndex = getFlattenedIndex(outputCoords);
+
+          ivec3 inputRC = inputCoordsFromReshapedOutCoords(flattenedIndex);
+          vec2 innerDims = vec2(float(inputRC.y),float(inputRC.z));
+
+          result[${J}] = getChannel(getA(inputRC.x, inputRC.y, inputRC.z), innerDims);
+
+        ${J>0?"}":""}
+      `}let q=r(Q.session.backend.glContext.version),G=`
+      ${OH(W)}
+      ${gH(U)}
+      ${c4()}
+
+      void main() {
+        ivec3 rc = getOutputCoords();
+
+        vec4 result = vec4(0.0);
+
+        ivec3 outputCoords;
+        int rows = ${U[2]};
+        int cols = ${U[1]};
+
+        ${Z}
+        ${q.output} = result;
+      }
+    `;return{...j,output:{dims:U,type:H.type,textureType:2},shaderSource:G,hasMain:!0}},H0=(Q,H,j)=>{let K=Z8(j);return{...K,get:()=>j8(Q,H,K,j)}}}),v6,Nj=E(()=>{W1(),t(),v6=(Q,H)=>{let j=H.shape,K=r(Q.session.backend.glContext.version),W=`
+    const float FLOAT_MAX = 1.70141184e38;
+    const float FLOAT_MIN = 1.17549435e-38;
+
+    bool isNaN(float val) {
+      return (val < 1.0 || 0.0 < val || val == 0.0) ? false : true;
+    }
+
+    highp vec4 encodeAsUint8(highp float v) {
+      if (isNaN(v)) {
+        return vec4(255, 255, 255, 255);
+      }
+
+      highp float av = abs(v);
+
+      if(av < FLOAT_MIN) {
+        return vec4(0.0, 0.0, 0.0, 0.0);
+      } else if(v > FLOAT_MAX) {
+        return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;
+      } else if(v < -FLOAT_MAX) {
+        return vec4(0.0, 0.0,  128.0, 255.0) / 255.0;
+      }
+
+      highp vec4 c = vec4(0,0,0,0);
+
+      highp float e = floor(log2(av));
+      highp float m = exp2(fract(log2(av))) - 1.0;
+
+      c[2] = floor(128.0 * m);
+      m -= c[2] / 128.0;
+      c[1] = floor(32768.0 * m);
+      m -= c[1] / 32768.0;
+      c[0] = floor(8388608.0 * m);
+
+      highp float ebias = e + 127.0;
+      c[3] = floor(ebias / 2.0);
+      ebias -= c[3] * 2.0;
+      c[2] += floor(ebias) * 128.0;
+
+      c[3] += 128.0 * step(0.0, -v);
+
+      return c / 255.0;
+    }
+
+    void main() {
+      float value = ${K.texture2D}(X,TexCoords).r;
+      ${K.output} = encodeAsUint8(value);
+    }`,U={name:"Uint8Encode",inputTypes:[0],inputNames:["X"],output:{dims:j,type:H.tensor.type,textureType:3},shaderSource:W,hasMain:!0};return Q.executeProgram(U,[H.tensor])}}),m5,V8,Z0,Mj=E(()=>{W1(),t(),F3(),U4(),m5={name:"unpack",inputNames:["A"],inputTypes:[2]},V8=(Q,H)=>{let j=H.dims.length,K=n6("rc",j),W=K.slice(-2),U=P3(j),Z=c4(),q=H.dims.length===0?"":yH(j,K),G=j<=1?"rc":`vec2(${W.join(",")})`,J=r(Q.session.backend.glContext.version),X=`
+    ${Z}
+    void main() {
+      ${U} rc = getOutputCoords();
+
+       // Sample the texture with the coords to get the rgba channel value.
+       vec4 packedInput = getA(${q});
+
+       ${J.output} = vec4(getChannel(packedInput, ${G}), 0, 0, 0);
+     }
+   `;return{...m5,hasMain:!0,output:{dims:H.dims,type:H.type,textureType:0},shaderSource:X}},Z0=(Q,H)=>({...m5,get:()=>V8(Q,H)})}),j0,w6,V0,z5=E(()=>{V3(),j0=class{constructor(Q,H=1){if(H===1)this.internalFormat=Q.R32F,this.format=Q.RED,this.textureType=Q.FLOAT,this.channelSize=H;else if(H===4)this.internalFormat=Q.RGBA32F,this.format=Q.RGBA,this.textureType=Q.FLOAT,this.channelSize=H;else throw new Error(`Invalid number of channels: ${H}`)}encode(Q,H){let j,K;return Q.constructor!==Float32Array&&(C1.warning("Encoder","data was not of type Float32; creating new Float32Array"),K=new Float32Array(Q)),H*this.channelSize>Q.length?(C1.warning("Encoder","Source data too small. Allocating larger array"),K=Q,j=this.allocate(H*this.channelSize),K.forEach((W,U)=>j[U]=W)):(K=Q,j=K),j}allocate(Q){return new Float32Array(Q*4)}decode(Q,H){return this.channelSize===1?Q.filter((j,K)=>K%4===0).subarray(0,H):Q.subarray(0,H)}},w6=class{constructor(Q,H=1,j){if(H!==1&&H!==4)throw new Error(`Invalid number of channels: ${H}`);this.internalFormat=Q.RGBA,this.format=Q.RGBA,this.channelSize=H,this.textureType=j||Q.FLOAT}encode(Q,H){let j=Q;return this.channelSize===1&&(C1.verbose("Encoder","Exploding into a larger array"),j=this.allocate(H),Q.forEach((K,W)=>j[W*4]=K)),j}allocate(Q){return new Float32Array(Q*4)}decode(Q,H){return this.channelSize===1?Q.filter((j,K)=>K%4===0).subarray(0,H):Q.subarray(0,H)}},V0=class{constructor(Q,H=1){if(this.channelSize=4,H===1)this.internalFormat=Q.ALPHA,this.format=Q.ALPHA,this.textureType=Q.UNSIGNED_BYTE,this.channelSize=H;else if(H===4)this.internalFormat=Q.RGBA,this.format=Q.RGBA,this.textureType=Q.UNSIGNED_BYTE,this.channelSize=H;else throw new Error(`Invalid number of channels: ${H}`)}encode(Q,H){return new Uint8Array(Q.buffer,Q.byteOffset,Q.byteLength)}allocate(Q){return new Uint8Array(Q*this.channelSize)}decode(Q,H){if(Q instanceof Uint8Array)return Q.subarray(0,H);throw new Error(`Invalid array type: ${Q.constructor}`)}}}),g4,X0,T6,Yj=E(()=>{Q1(),t(),g4=(Q,H,j)=>{let K=j===0||j===1?1:4,W=j===2,U=j===1||j===2,Z=j===4?H.length-1:void 0,q=j===4?H.map((G,J)=>J===H.length-1?G*4:G):void 0;return T6(Q,H,K,q,{isPacked:W,reverseWH:U,breakAxis:Z})},X0=(Q,H,j)=>{let K=g4(Q,H,j);return[K.width,K.height]},T6=(Q,H,j=1,K,W)=>{let U=!!(W&&W.isPacked),[Z,q]=Q.computeTextureWH(U&&K||H,W),G=H.length,J=H.slice(0);if(G===0&&(J=[1]),j===1)K=H;else if(U){if(j!==4)throw new Error("a packed texture must be 4-channel");K=H,G>0&&(J[G-1]=Math.ceil(J[G-1]/2)),G>1&&(J[G-2]=Math.ceil(J[G-2]/2))}else if(!K)throw new Error("Unpacked shape is needed when using channels > 1");return{width:Z,height:q,channels:j,isPacked:U,shape:J,strides:u.computeStrides(J),unpackedShape:K,reversedWH:W&&W.reverseWH}}}),X8,K0,Cj=E(()=>{V3(),K4(),Q1(),Rj(),zj(),Nj(),Mj(),z5(),Yj(),t(),X8=(Q,H)=>{let j=H.map((W)=>`${W.unpackedShape.join(",")};${W.width}x${W.height}`).join("_"),K=Q.name;return Q.cacheHint&&(K+="["+Q.cacheHint+"]"),K+=":"+j,K},K0=class{constructor(Q){this.session=Q,this.packedTextureDataCache=new Map,this.unpackedTextureDataCache=new Map}calculateTextureWidthAndHeight(Q,H){return X0(this.session.layoutStrategy,Q,H)}executeProgram(Q,H){if(H.length<Q.inputNames.length)throw new Error(`Input size mustn't be less than ${Q.inputNames.length}.`);if(Q.inputNames.length!==Q.inputTypes.length)throw new Error("input names size does not match input types");let j=[];for(let G=0;G<Q.inputNames.length;++G)j[G]=this.getOrCreateTextureData(H[G],Q.inputTypes[G]);let K=X8(Q,j),W=this.session.programManager.getArtifact(K),U=W?W.programInfo:typeof Q.get=="function"?Q.get():Q,Z=g4(this.session.layoutStrategy,U.output.dims,U.output.textureType),q=this.createTextureData(Z,U.output.type);return W||(W=this.session.programManager.build(U,j,q),this.session.programManager.setArtifact(K,W)),this.runProgram(W,j,q),q}run(Q,H){return this.executeProgram(Q,H).tensor}runProgram(Q,H,j){for(let K=0;K<H.length;++K)if(!!H[K].isPacked!=(Q.programInfo.inputTypes[K]===2))throw new Error(`input[${K}] property packed inconsistent`);if(!!j.isPacked!=(Q.programInfo.output.textureType===2))throw new Error("output property packed inconsistent");this.session.programManager.run(Q,H,j)}getOrCreateTextureData(Q,H){let j=this.getTextureData(Q.dataId,H===2);if(!j&&(j=this.getTextureData(Q.dataId,H!==2),j))return H===2?this.pack(j):this.unpack(j);if(!j){let K=g4(this.session.layoutStrategy,Q.dims,H);if(H===4){let W=Q.dims;if(W.length===4){let U=[W[0],Math.ceil(W[1]*W[2]*W[3]/4)],Z=g4(this.session.layoutStrategy,U,H),q=Q.numberData;if(W[1]*W[2]*W[3]%4!==0){let G=W[0],J=W[1]*W[2]*W[3],X=Math.ceil(J*1/4)*4,V=G*X;q=new Float32Array(V);for(let R=0;R<G;++R){let z=R*J,Y=R*X+R%1*J;q.set(Q.numberData.subarray(z,z+J),Y)}}return this.createTextureData(Z,Q.type,q,Q,1)}}if(H===2){let W=T6(this.session.layoutStrategy,Q.dims,1,[],{reverseWH:!0}),U=this.createTextureData(W,Q.type,Q.numberData,Q,1);j=this.pack(U)}else j=this.createTextureData(K,Q.type,Q.numberData,Q,1)}return j}createTextureDataFromLayoutBindTensor(Q,H,j,K){return this.createTextureData(Q,H,j,K,1)}createTextureData(Q,H,j,K,W){C1.verbose("InferenceHandler",`Creating TextureData: layout:[${JSON.stringify(Q)}]`);let U=this.session.textureManager.createTextureFromLayout(H,Q,j,W);return this.createTextureDataFromTexture(Q,H,U,K)}reshapeUnpacked(Q,H){let j=this.getOrCreateTextureData(Q,0),K={channels:j.channels,height:j.height,width:j.width,shape:H.length!==0?H:[1],strides:u.computeStrides(H),unpackedShape:H};return this.createTextureDataFromTexture(K,Q.type,j.texture).tensor}reshapePacked(Q,H){let j=this.getOrCreateTextureData(Q,2);if(xH(Q.dims,H)){let q={channels:j.channels,height:j.height,width:j.width,shape:H.length!==0?H:[1],strides:u.computeStrides(H),unpackedShape:H,isPacked:!0};return this.createTextureDataFromTexture(q,Q.type,j.texture).tensor}let K=s7(Q.dims),W=s7(H),U=this.reshapePacked(Q,K),Z=this.run(H0(this,U,W),[U]);return this.reshapePacked(Z,H)}cast(Q,H){let j=this.getOrCreateTextureData(Q,0);return this.createTextureDataFromTexture(j,H,j.texture).tensor}createTextureDataFromTexture(Q,H,j,K,W){let U={...Q,tensor:K||new o1(Q.unpackedShape,H,(Z)=>this.readTexture(U),async(Z)=>this.readTextureAsync(U),void 0,W),texture:j};return this.setTextureData(U.tensor.dataId,U,Q.isPacked),U}getTextureData(Q,H=!1){return this.session.isInitializer(Q)?this.session.getTextureData(Q,H):H?this.packedTextureDataCache.get(Q):this.unpackedTextureDataCache.get(Q)}setTextureData(Q,H,j=!1){this.session.isInitializer(Q)?this.session.setTextureData(Q,H,j):(j?this.packedTextureDataCache:this.unpackedTextureDataCache).set(Q,H)}isTextureLayoutCached(Q,H=!1){return!!this.getTextureData(Q.dataId,H)}dispose(){this.session.textureManager.clearActiveTextures(),this.packedTextureDataCache.forEach((Q)=>this.session.textureManager.releaseTexture(Q)),this.packedTextureDataCache=new Map,this.unpackedTextureDataCache.forEach((Q)=>this.session.textureManager.releaseTexture(Q)),this.unpackedTextureDataCache=new Map}readTexture(Q){return Q.isPacked?this.readTexture(this.unpack(Q)):this.session.backend.glContext.isFloat32DownloadSupported?this.session.textureManager.readTexture(Q,Q.tensor.type,Q.channels):this.session.textureManager.readUint8TextureAsFloat(v6(this,Q))}async readTextureAsync(Q){return Q.isPacked?this.readTextureAsync(this.unpack(Q)):this.session.backend.glContext.isFloat32DownloadSupported?this.session.textureManager.readTextureAsync(Q,Q.tensor.type,Q.channels):this.session.textureManager.readUint8TextureAsFloat(v6(this,Q))}pack(Q){return this.executeProgram(J0(this,Q.tensor),[Q.tensor])}unpack(Q){return this.executeProgram(Z0(this,Q.tensor),[Q.tensor])}}}),K8,K1,_1=E(()=>{K8=class{constructor(Q){Object.assign(this,Q)}get cacheKey(){return this.key||(this.key=Object.getOwnPropertyNames(this).sort().map((Q)=>`${this[Q]}`).join(";")),this.key}},K1=(Q)=>new K8(Q)}),c5,U0,q0,U8,q8,Bj=E(()=>{_1(),W1(),t(),c5={name:"BatchNormalization",inputNames:["A","Scale","B","Mean","Variance"],inputTypes:[0,0,0,0,0]},U0=(Q,H,j)=>(q8(H),[Q.run({...c5,cacheHint:j.cacheKey,get:()=>U8(Q,H,j)},H)]),q0=(Q)=>{let H=Q.attributes.getFloat("epsilon",0.00001),j=Q.attributes.getFloat("momentum",0.9),K=Q.attributes.getInt("spatial",1);return K1({epsilon:H,momentum:j,spatial:K})},U8=(Q,H,j)=>{let K=r(Q.session.backend.glContext.version),W=H[0].dims.length,[U,Z]=Q.calculateTextureWidthAndHeight(H[1].dims,0),q=`
+  float process(int[${W}] indices) {
+    vec2 position = offsetToCoords(indices[1], ${U}, ${Z});
+    float scale = getColorAsFloat(${K.texture2D}(Scale, position));
+    float mean = getColorAsFloat(${K.texture2D}(Mean, position));
+    float variance = getColorAsFloat(${K.texture2D}(Variance, position));
+    float b = getColorAsFloat(${K.texture2D}(B, position));
+
+    return scale * ( (_A(indices) - mean) / sqrt(variance + float(${j.epsilon})) ) + b;
+  }`;return{...c5,output:{dims:H[0].dims,type:H[0].type,textureType:0},shaderSource:q}},q8=(Q)=>{if(!Q||Q.length!==5)throw new Error("BatchNormalization requires 5 inputs.");let H=Q[0],j=Q[1],K=Q[2],W=Q[3],U=Q[4];if(H.dims.length<3||j.dims.length!==1||K.dims.length!==1||W.dims.length!==1||U.dims.length!==1)throw new Error("invalid input shape.");if(j.dims[0]!==H.dims[1]||K.dims[0]!==H.dims[1]||W.dims[0]!==H.dims[1]||U.dims[0]!==H.dims[1])throw new Error("invalid input shape.");if(H.type!=="float32"&&H.type!=="float64"||j.type!=="float32"&&j.type!=="float64"||K.type!=="float32"&&K.type!=="float64"||W.type!=="float32"&&W.type!=="float64"||U.type!=="float32"&&U.type!=="float64")throw new Error("invalid input tensor types.")}}),W0,q4,y,D6,G0,E3=E(()=>{W0=class{constructor(Q,H,j,K){this.glContext=Q,this.programInfo=H,this.inputTextureLayouts=j,this.outputTextureLayout=K}},q4=class{constructor(Q){this.context=Q}},y=class{constructor(Q,H){this.routineBody=Q,this.dependencies=H}},D6=class{constructor(Q,H,j){this.name=Q,j?this.dependencies=j:this.dependencies=[],H&&(this.routineBody=H)}addDependency(Q){Q&&this.dependencies.push(Q)}},G0=class{static returnOrderedNodes(Q){if(!Q||Q.length===0)return[];if(Q.length===1)return Q;let H=new Set,j=new Set,K=new Array;return this.createOrderedNodes(Q,H,j,K),K}static createOrderedNodes(Q,H,j,K){for(let W=0;W<Q.length;++W)this.dfsTraverse(Q[W],H,j,K)}static dfsTraverse(Q,H,j,K){if(!Q||j.has(Q.name))return;if(H.has(Q.name))throw new Error("Cyclic dependency detected. Can't topologically sort routines needed for shader.");H.add(Q.name);let W=Q.dependencies;if(W&&W.length>0)for(let U=0;U<W.length;++U)this.dfsTraverse(W[U],H,j,K);K.push(Q),j.add(Q.name),H.delete(Q.name)}}}),u1,W8,R0,z0,N0,M0,Y0,C0,B0,F0,k0,A0,S0,$0,Fj=E(()=>{Q1(),E3(),W1(),t(),u1=(Q,H,j,K=H[0].type,W)=>{let U=Q.session.pack?2:0;return{name:j.name,inputNames:["A","B"],inputTypes:[U,U],cacheHint:W,get:()=>W8(Q,H,j,K)}},W8=(Q,H,j,K=H[0].type)=>{let W=Q.session.pack?2:0,U=!u.areEqual(H[0].dims,H[1].dims),Z=H[0].dims,q=Q.session.pack;if(U){let X=R3.calcShape(H[0].dims,H[1].dims,!1);if(!X)throw new Error("Can't perform binary op on the given tensors");Z=X;let V=Z.length,R=H[0].dims.length!==0?H[0].dims.length:1,z=H[1].dims.length!==0?H[1].dims.length:1,Y=H[0].dims.length!==0?"bcastIndices_A(indices, aindices);":"aindices[0] = 0;",B=H[1].dims.length!==0?"bcastIndices_B(indices, bindices);":"bindices[0] = 0;",k=r(Q.session.backend.glContext.version),w=q?`
+      ${j.body}
+      void main() {
+        vec4 a = getAAtOutCoords();
+        vec4 b = getBAtOutCoords();
+        vec4 result = ${j.name}(a, b);
+        ${k.output} = result;
+      }`:`
+      ${j.body}
+      float process(int indices[${V}]) {
+        int aindices[${R}];
+        int bindices[${z}];
+        ${Y}
+        ${B}
+        return ${j.name}(_A(aindices), _B(bindices));
+      }`;return{name:j.name,inputNames:["A","B"],inputTypes:[W,W],output:{dims:Z,type:K,textureType:W},shaderSource:w,hasMain:q}}let G=r(Q.session.backend.glContext.version),J=`
+    ${j.body}
+    void main() {
+      vec4 v1 = ${G.texture2D}(A, TexCoords);
+      vec4 v2 = ${G.texture2D}(B, TexCoords);
+      vec4 result = ${j.name}(v1, v2);
+      ${G.output} = result;
+    }
+    `;return{name:j.name,inputNames:["A","B"],inputTypes:[W,W],output:{dims:H[0].dims,type:K,textureType:W},shaderSource:J,hasMain:!0}},R0=(Q,H)=>[Q.run(u1(Q,H,dH()),H)],z0=(Q,H)=>[Q.run(u1(Q,H,lH(),"bool"),H)],N0=(Q,H)=>[Q.run(u1(Q,H,pH()),H)],M0=(Q,H)=>[Q.run(u1(Q,H,mH(),"bool"),H)],Y0=(Q,H)=>[Q.run(u1(Q,H,cH(),"bool"),H)],C0=(Q,H)=>[Q.run(u1(Q,H,fH(),"bool"),H)],B0=(Q,H)=>[Q.run(u1(Q,H,hH()),H)],F0=(Q,H)=>[Q.run(u1(Q,H,uH(),"bool"),H)],k0=(Q,H)=>[Q.run(u1(Q,H,iH()),H)],A0=(Q,H)=>[Q.run(u1(Q,H,oH()),H)],S0=(Q,H)=>[Q.run(u1(Q,H,bH()),H)],$0=(Q,H)=>[Q.run(u1(Q,H,sH(),"bool"),H)]}),L0,v0,G8,kj=E(()=>{Q1(),L0=(Q,H,j)=>(G8(H),[Q.cast(H[0],j)]),v0=(Q)=>i1.tensorDataTypeFromProto(Q.attributes.getInt("to")),G8=(Q)=>{if(!Q||Q.length!==1)throw new Error("Cast requires 1 input.");if(Q[0].type==="string")throw new Error("Invalid input type.")}}),R8,z8,w0,$4,Aj=E(()=>{W1(),t(),F3(),U4(),R8=(Q,H)=>({name:"Concat (packed)",inputNames:Array.from({length:Q},(j,K)=>`X${K}`),inputTypes:Array(Q).fill(2),cacheHint:H}),z8=(Q,H,j,K)=>{let W=j[0].dims.slice();if(K>=W.length||K<-1*W.length)throw new Error("axis specified for concat doesn't match input dimensionality");K<0&&(K=W.length+K);let U=W.slice(0);for(let h=1;h<j.length;h++){let $1=j[h].dims.slice();for(let L1=0;L1<W.length;L1++)if(L1===K)U[K]+=$1[L1];else if(W[L1]!==$1[L1])throw new Error("non concat dimensions must match")}let Z=U.length,q=n6("coords",Z),G=P3(Z),J=c4(),X=j.map((h)=>h.dims),V=H4(Z),R=new Array(X.length-1);R[0]=X[0][K];for(let h=1;h<R.length;h++)R[h]=R[h-1]+X[h][K];let z=V[K],Y=V.slice(-2),B=V.join(),k=`if (${z} < ${R[0]}) {
+        return getChannel(
+            getX0(${B}), vec2(${Y.join()}));
+        }`;for(let h=1;h<R.length;h++){let $1=R[h-1];k+=`
+            if (${z} < ${R[h]}  && ${z} >= ${R[h-1]}) {
+              return getChannel(
+                getX${h}(${$4(V,z,$1)}),
+                vec2(${$4(Y,z,$1)}));
+            }`}let w=R.length,A=R[R.length-1];k+=`
+            return getChannel(
+              getX${w}(${$4(V,z,A)}),
+              vec2(${$4(Y,z,A)}));`;let D=r(Q.session.backend.glContext.version),I=`
+          ${J}
+          float getValue(${V.map((h)=>"int "+h)}) {
+            ${k}
+          }
+
+          void main() {
+            ${G} coords = getOutputCoords();
+            int lastDim = coords.${V[Z-1]};
+            coords.${V[Z-1]} = coords.${V[Z-2]};
+            coords.${V[Z-2]} = lastDim;
+
+            vec4 result = vec4(getValue(${q}), 0., 0., 0.);
+
+            ${q[Z-1]} = ${q[Z-1]} + 1;
+            if (${q[Z-1]} < ${U[Z-1]}) {
+              result.g = getValue(${q});
+            }
+
+            ${q[Z-2]} = ${q[Z-2]} + 1;
+            if (${q[Z-2]} < ${U[Z-2]}) {
+              result.a = getValue(${q});
+            }
+
+            ${q[Z-1]} = ${q[Z-1]} - 1;
+            if (${q[Z-2]} < ${U[Z-2]} &&
+                ${q[Z-1]} < ${U[Z-1]}) {
+              result.b = getValue(${q});
+            }
+            ${D.output} = result;
+          }
+        `;return{...H,output:{dims:U,type:j[0].type,textureType:2},shaderSource:I,hasMain:!0}},w0=(Q,H,j)=>{let K=R8(H.length,j.cacheKey);return{...K,get:()=>z8(Q,K,H,j.axis)}},$4=(Q,H,j)=>{let K=Q.indexOf(H);return Q.map((W,U)=>U===K?`${W} - ${j}`:W).join()}}),T0,N8,M8,Y8,f5,C8,B8,F8,D0,k8,Sj=E(()=>{_1(),t(),Aj(),T0=(Q,H,j)=>(k8(H),Q.session.pack&&H[0].dims.length>1?[Q.run(w0(Q,H,j),H)]:[Q.run(Y8(Q,H,j),H)]),N8=(Q,H)=>({name:"Concat",inputNames:Array.from({length:Q},(j,K)=>`X${K}`),inputTypes:Array(Q).fill(0),cacheHint:H}),M8=(Q,H,j,K)=>{let W=j[0].dims.slice();if(K>=W.length||K<-1*W.length)throw new Error("axis specified for concat doesn't match input dimensionality");K<0&&(K=W.length+K);let U=W.slice(0);for(let z=1;z<j.length;z++){let Y=j[z].dims.slice();for(let B=0;B<W.length;B++)if(B===K)U[K]+=Y[B];else if(W[B]!==Y[B])throw new Error("non concat dimensions must match")}let Z=U.length,q=new Array(j.length),G=0;for(let z=0;z<q.length;++z)G+=j[z].dims[K],q[z]=G;let J="";j.length<5?J=f5(q):J=C8(q);let X=B8(j.length,Z),V=F8(q),R=`
+        ${X}
+        ${V}
+        ${J}
+        float process(int indices[${Z}]) {
+          int textureIndex = getTextureWhereDataResides (indices[${K}]);
+
+          if(textureIndex != 0) {
+            indices[${K}] = indices[${K}] - int(getSizeInConcatAxisValueFromIndex(textureIndex-int(1)));
+          }
+
+          return fetchDataFromCorrectTexture(textureIndex, indices);
+        }`;return{...H,output:{dims:U,type:j[0].type,textureType:0},shaderSource:R}},Y8=(Q,H,j)=>{let K=N8(H.length,j.cacheKey);return{...K,get:()=>M8(Q,K,H,j.axis)}},f5=(Q)=>`int getTextureWhereDataResides(int index) {
+      ${Q.map((H,j)=>`if(index<${H}) {return ${j};}
+`).join("")}
+    }`,C8=(Q)=>f5(Q),B8=(Q,H)=>{let j=[`float fetchDataFromCorrectTexture(int textureIndex, int indices[${H}]) {`];for(let K=0;K<Q;++K)K===0?j.push(`	if (textureIndex == ${K}) { return _X${K}(indices); }`):K===Q-1?j.push(`	else { return _X${K}(indices); }`):j.push(`	else if (textureIndex == ${K}) { return _X${K}(indices); }`);return j.push("	}"),j.join(`
+`)},F8=(Q)=>{let H=["int getSizeInConcatAxisValueFromIndex(int index) {"];for(let j=0;j<Q.length;++j)j===0?H.push(`	if (index == ${j}) { return ${Q[j]}; }`):j===Q.length-1?H.push(`	else { return ${Q[j]}; }`):H.push(`	else if (index == ${j}) { return ${Q[j]}; }`);return H.push("	}"),H.join(`
+`)},D0=(Q)=>K1({axis:Q.attributes.getInt("axis")}),k8=(Q)=>{if(!Q||Q.length<1)throw new Error("too few inputs");let H=Q[0].type,j=Q[0].dims.length;if(H==="string")throw new Error("string tensor is not supported yet");for(let K of Q){if(K.type!==H)throw new Error("input tensors should be one type");if(K.dims.length!==j)throw new Error("input tensors should have the same shape")}}}),A8,Y1,_0,P0,E0,I0,_6,x0,O0,S8,g0,y0,d0,p0,h0,b0,P6,m0,c0,f0,l0,u0,s0,i0,o0,a0,n0,r0,t0=E(()=>{_1(),Q1(),E3(),W1(),t(),A8=(Q,H,j,K)=>{let W=Q.session.pack?2:0,U=r(Q.session.backend.glContext.version);return{...H,output:{dims:j.dims,type:j.type,textureType:W},shaderSource:`
+     ${K.body}
+     void main() {
+       vec4 v = ${U.texture2D}(A, TexCoords);
+       v = ${K.name}_(v);
+       ${U.output} = v;
+     }
+     `,hasMain:!0}},Y1=(Q,H,j,K)=>{let W=Q.session.pack?2:0,U={name:j.name,inputTypes:[W],inputNames:["A"],cacheHint:K};return{...U,get:()=>A8(Q,U,H,j)}},_0=(Q,H)=>[Q.run(Y1(Q,H[0],nH()),H)],P0=(Q,H)=>[Q.run(Y1(Q,H[0],rH()),H)],E0=(Q,H)=>[Q.run(Y1(Q,H[0],tH()),H)],I0=(Q,H)=>[Q.run(Y1(Q,H[0],eH()),H)],_6=(Q,H,j)=>[Q.run(Y1(Q,H[0],S2(j.min,j.max),j.cacheKey),H)],x0=(Q)=>K1({min:Q.attributes.getFloat("min",h4),max:Q.attributes.getFloat("max",b4)}),O0=(Q,H)=>{let j=S8(Q,H);return _6(Q,[H[0]],j)},S8=(Q,H)=>{if(H.length>=3&&(!Q.session.isInitializer(H[1].dataId)||!Q.session.isInitializer(H[2].dataId)))throw new Error("dynamic clip attributes are not allowed");let j=H.length>=3?H[1].numberData[0]:h4,K=H.length>=3?H[2].numberData[0]:b4;return K1({min:j,max:K})},g0=(Q,H)=>[Q.run(Y1(Q,H[0],QZ()),H)],y0=(Q,H)=>[Q.run(Y1(Q,H[0],JZ()),H)],d0=(Q,H,j)=>[Q.run(Y1(Q,H[0],HZ(j.alpha),j.cacheKey),H)],p0=(Q)=>K1({alpha:Q.attributes.getFloat("alpha",1)}),h0=(Q,H)=>[Q.run(Y1(Q,H[0],ZZ()),H)],b0=(Q,H)=>[Q.run(Y1(Q,H[0],jZ()),H)],P6=(Q,H)=>[Q.run(Y1(Q,H[0],VZ()),H)],m0=(Q,H,j)=>[Q.run(Y1(Q,H[0],XZ(j.alpha),j.cacheKey),H)],c0=(Q)=>K1({alpha:Q.attributes.getFloat("alpha",0.01)}),f0=(Q,H)=>[Q.run(Y1(Q,H[0],KZ()),H)],l0=(Q,H)=>[Q.run(Y1(Q,H[0],UZ()),H)],u0=(Q,H)=>[Q.run(Y1(Q,H[0],qZ()),H)],s0=(Q,H)=>[Q.run(Y1(Q,H[0],$2()),H)],i0=(Q,H)=>[Q.run(Y1(Q,H[0],L2()),H)],o0=(Q,H)=>[Q.run(Y1(Q,H[0],WZ()),H)],a0=(Q,H)=>[Q.run(Y1(Q,H[0],GZ()),H)],n0=(Q,H)=>[Q.run(Y1(Q,H[0],RZ()),H)],r0=(Q,H)=>[Q.run(Y1(Q,H[0],zZ()),H)]}),F5,W4=E(()=>{Q1(),t0(),F5=(Q)=>{let H=Q.getString("activation","");if(H==="Clip"){let[j,K]=Q.getFloats("activation_params",[h4,b4]);return{activation:H,clipMax:K,clipMin:j,activationCacheKey:`${H}:${j},${K}`}}return{activation:H,activationCacheKey:H}}}),$8,L8,e0,$j=E(()=>{V3(),W1(),t(),V7(),W4(),$8=(Q,H)=>({name:"GroupedConv",inputNames:Q?["X","W","Bias"]:["X","W"],inputTypes:Q?[0,0,0]:[0,0],cacheHint:H}),L8=(Q,H,j,K)=>{let W=H.length>2?"value += getBias(output_channel);":"",U=H[0].dims.slice(),Z=H[1].dims.slice(),q=Z[0]/K.group;C1.verbose("GroupedConv",`autpPad:${K.autoPad}, dilations:${K.dilations}, group:${K.group}, kernelShape:${K.kernelShape}, pads:${K.pads}, strides:${K.strides}`);let G=y4(U,Z,K.dilations,K.pads,K.strides),J=r(Q.session.backend.glContext.version),{activationFunction:X,applyActivation:V}=f4(K),R=`
+  const ivec2 strides = ivec2(${K.strides[0]}, ${K.strides[1]});
+  const ivec2 pads = ivec2(${K.pads[0]}, ${K.pads[1]});
+  ${X}
+  void main() {
+    ivec4 coords = getOutputCoords();
+    int batch = coords.x;
+    int output_channel = coords.y;
+    ivec2 xRCCorner = coords.zw * strides - pads;
+    int group_id = output_channel / ${q};
+
+    float value = 0.0;
+    for (int wInChannel = 0; wInChannel < ${Z[1]}; wInChannel++) {
+      int input_channel = group_id * ${Z[1]} + wInChannel;
+      for (int wHeight = 0; wHeight < ${Z[2]}; wHeight++) {
+        int xHeight = xRCCorner.x + wHeight * ${K.dilations[0]};
+
+        if (xHeight < 0 || xHeight >= ${U[2]}) {
+          continue;
+        }
+
+        for (int wWidth = 0; wWidth < ${Z[3]}; wWidth++) {
+          int xWidth = xRCCorner.y + wWidth * ${K.dilations[1]};
+          if (xWidth < 0 || xWidth >= ${U[3]}) {
+            continue;
+          }
+
+          float xVal = getX(batch, input_channel, xWidth, xHeight);
+          float wVal = getW(output_channel, wInChannel, wWidth, wHeight);
+          value += xVal*wVal;
+        }
+      }
+    }
+    ${W}
+    ${V}
+    ${J.output} = vec4(value, .0, .0, .0);
+  }
+`;return{...j,output:{dims:G,type:H[0].type,textureType:0},shaderSource:R,hasMain:!0}},e0=(Q,H,j)=>{let K=$8(H.length>2,j.cacheKey);return{...K,get:()=>L8(Q,H,K,j)}}}),v8,w8,QQ,Lj=E(()=>{W1(),t(),U4(),v8=(Q)=>({name:"Im2Col (packed)",inputNames:["A"],inputTypes:[2],cacheHint:Q}),w8=(Q,H,j,K,W,U)=>{let Z=j.dims,q=K.dims,G=2,J=3,X=W.length,V=[q[1]*q[2]*q[3],W[2]*W[3]],R=q[2]*q[3],z=c4(),Y=r(Q.session.backend.glContext.version),B="";for(let w=0;w<=1;w++)for(let A=0;A<=1;A++)B+=`
+            blockIndex = rc.x + ${A};
+            pos = rc.y + ${w};
+
+            if(blockIndex < ${V[1]} && pos < ${V[0]}) {
+              offsetY = int(blockIndex / (${W[X-1]})) * ${U.strides[0]} -
+                ${U.pads[0]};
+              d0 = offsetY + ${U.dilations[0]} * (imod(pos, ${R}) / ${q[2]});
+
+              if(d0 < ${Z[G]} && d0 >= 0) {
+                offsetX = imod(blockIndex, ${W[X-1]}) * ${U.strides[1]} -
+                  ${U.pads[1]};
+                d1 = offsetX + ${U.dilations[1]} * imod(imod(pos, ${R}), ${q[2]});
+
+                if(d1 < ${Z[J]} && d1 >= 0) {
+
+                  ch = int(float(pos)/ ${R}.);
+                    innerDims = vec2(d0, d1);
+                    result[${w*2+A}] = getChannel(
+                      getA(0, ch, int(innerDims.x),
+                      int(innerDims.y)), innerDims);
+                }
+              }
+            }
+
+          `;let k=`
+      ${z}
+
+      void main() {
+        ivec2 rc = getOutputCoords();
+          vec4 result = vec4(0.0);
+          int blockIndex, pos, offsetY, d0, offsetX, d1, ch;
+          vec2 innerDims;
+          ${B}
+          ${Y.output} = result;
+      }
+            `;return{...H,output:{dims:V,type:j.type,textureType:2},shaderSource:k,hasMain:!0}},QQ=(Q,H,j,K,W)=>{let U=v8(W.cacheKey);return{...U,get:()=>w8(Q,U,H,j,K,W)}}}),JQ,HQ,ZQ,T8,Z7=E(()=>{Q1(),t(),F3(),W4(),jQ(),JQ=(Q,H,j)=>(T8(H),Q.session.pack?[Q.run(j7(Q,H,j),H)]:[Q.run(v2(H,j),H)]),HQ=(Q)=>F5(Q.attributes),ZQ=(Q,H)=>({name:"MatMul",inputNames:Q?["A","B","Bias"]:["A","B"],inputTypes:Q?[0,0,0]:[0,0],cacheHint:H}),T8=(Q)=>{if(!Q||Q.length!==2)throw new Error("MatMul requires 2 inputs.");if(Q[0].dims[Q[0].dims.length-1]!==Q[1].dims[Q[1].dims.length-2])throw new Error("shared dimension does not match.");if(Q[0].type!=="float32"&&Q[0].type!=="float64"||Q[1].type!=="float32"&&Q[1].type!=="float64")throw new Error("inputs should be float type");if(Q[0].type!==Q[1].type)throw new Error("inputs types should match")}}),D8,_8,j7,jQ=E(()=>{Q1(),W1(),t(),F3(),W4(),Z7(),D8=(Q,H)=>({name:"MatMul (packed)",inputNames:Q?["A","B","Bias"]:["A","B"],inputTypes:Q?[2,2,2]:[2,2],cacheHint:H}),_8=(Q,H,j,K)=>{let W=j.length>2,U=W?"value += getBiasForMatmul();":"",Z=j[0].dims,q=j[1].dims,G=R3.calcShape(Z,q,!0),J=!u.areEqual(j[0].dims,j[1].dims);if(!G)throw new Error("Can't use matmul on the given tensors");let X=Z[Z.length-1],V=Math.ceil(X/2),R=Z.length,z=q.length,Y=r(Q.session.backend.glContext.version),B=P3(G.length),k=G.length,w=H4(),{activationFunction:A,applyActivation:D}=f4(K),I=W?`${w2(B,w,j[2].dims,G,!0)}`:"",h=J?`${MZ(B,w,j,G)}`:"",$1=J?"getAAtOutCoordsMatmul(i)":`getA(${YZ(w,R)})`,L1=J?"getBAtOutCoordsMatmul(i)":`getB(${CZ(w,z)})`,x1=J?"":`${B} rc =
+          getOutputCoords(); int lastDim = rc.${w[k-1]}; rc.${w[k-1]} =
+          rc.${w[k-2]}; rc.${w[k-2]} = lastDim;
+      `,G1=`
+            ${h}
+            ${I}
+            ${A}
+            void main() {
+              ${x1}
+
+              vec4 value = vec4(0);
+              for (int i = 0; i < ${V}; i++) {
+                vec4 a = ${$1};
+                vec4 b = ${L1};
+
+                value += (a.rrbb * b.rgrg);
+                value += (a.ggaa * b.baba);
+              }
+              ${U}
+              ${D}
+              ${Y.output} = value;
+            }`;return{...H,output:{dims:G,type:j[0].type,textureType:2},shaderSource:G1,hasMain:!0}},j7=(Q,H,j)=>{let K=D8(H.length>2,j.activationCacheKey);return{...K,get:()=>_8(Q,K,H,j)}}}),VQ,vj=E(()=>{V7(),Lj(),jQ(),VQ=(Q,H,j)=>{let K=H[0].dims,W=H[1].dims,U=y4(K,W,j.dilations,j.pads,j.strides),Z=Q.run(QQ(Q,H[0],H[1],U,j),[H[0]]),q=Q.reshapePacked(H[1],[W[0],W[1]*W[2]*W[3]]),G=H.length===3?[q,Z,H[2]]:[q,Z],J=Q.run(j7(Q,G,j),G);return Q.reshapePacked(J,U)}}),P8,E8,XQ,E6,KQ=E(()=>{t(),P8=(Q)=>({name:"Im2Col",inputNames:["X"],inputTypes:[0],cacheHint:Q}),E8=(Q,H,j,K,W,U)=>{let Z=j.dims,q=K.dims,G=W.length,J=E6(Z,q,W,4),X=`
+        const int XC = ${Z[1]};
+        const int XH = ${Z[2]};
+        const int XW = ${Z[3]};
+        const int KH = ${U.kernelShape[0]};
+        const int KW = ${U.kernelShape[1]};
+        const int dilationH = ${U.dilations[0]};
+        const int dilationW = ${U.dilations[1]};
+        const int strideH = ${U.strides[0]};
+        const int strideW = ${U.strides[1]};
+        const int padH = ${U.pads[0]};
+        const int padW = ${U.pads[1]};
+        const int KHKW = KH*KW;
+        const int XCKHKW = XC * KHKW;
+        const int outputChannels = 4;
+        vec4 process(int indices[${G}]) {
+          int b  = indices[0]; // batch size
+          int oh = indices[1] * strideH - padH; //output height
+          int ow = indices[2] * strideW - padW; //output width
+          int p = indices[3] * outputChannels; //patch
+          vec4 value = vec4(0.0);
+          for(int i=0; i < outputChannels; ++i) {
+            if(p < XCKHKW) {
+              int patchC = p / KHKW;
+              int patchH = (p - patchC*KHKW) / KW;
+              int patchW = (p - patchC*KHKW) - patchH * KW;
+              int xh2 = oh + patchH * dilationH;
+              int xw2 = ow + patchW * dilationW;
+              int x[${Z.length}];
+              x[0] = b;
+              x[1] = patchC;
+              x[2] = xh2;
+              x[3] = xw2;
+              if(xh2 >= 0 &&
+                  xh2 < XH &&
+                  xw2 >= 0 &&
+                  xw2 < XW) {
+                value[i] = _X(x);
+              }
+            }
+            ++p;
+          }
+          return value;
+        }
+        `;return{...H,output:{dims:J,type:j.type,textureType:4},shaderSource:X}},XQ=(Q,H,j,K,W)=>{let U=P8(W.cacheKey);return{...U,get:()=>E8(Q,U,H,j,K,W)}},E6=(Q,H,j,K=4)=>[j[0],j[2],j[3],Math.ceil(Q[1]*H[2]*H[3]/K)]}),I8,x8,UQ,wj=E(()=>{Q1(),W1(),t(),W4(),KQ(),I8=(Q,H)=>({name:"ConvDotProduct",inputNames:Q?["Im2Col","K","B"]:["Im2Col","K"],inputTypes:Q?[0,4,0]:[0,4],cacheKey:H.activationCacheKey}),x8=(Q,H,j,K,W)=>{let U=j[0].dims,Z=j[1].dims,q=[Z[0],Math.ceil(U[1]*Z[2]*Z[3]/4)],G=E6(U,Z,K),[J,X]=Q.calculateTextureWidthAndHeight(q,4),V=u.computeStrides(G),[R,z]=Q.calculateTextureWidthAndHeight(G,4),Y=K.length,B=j.length<3?"0.0":"_B(b)",k=Math.ceil(U[1]*Z[2]*Z[3]/4),{activationFunction:w,applyActivation:A}=f4(W),D=r(Q.session.backend.glContext.version),I=`
+${w}
+float process(int indices[${Y}]) {
+  int b[1];
+  b[0] = indices[1];
+  int im2col[4];
+  im2col[0] = indices[0];
+  im2col[1] = indices[2];
+  im2col[2] = indices[3];
+  int im2colOffset = im2col[0] * ${V[0]} + im2col[1] * ${V[1]} + im2col[2] * ${V[2]};
+  int kernelOffset = indices[1] * ${q[1]};
+  float value = ${B};
+  for (int i = 0; i < ${k}; ++i) {
+    vec2 im2colCoords = offsetToCoords(im2colOffset, ${R}, ${z});
+    vec2 kernelCoords = offsetToCoords(kernelOffset, ${J}, ${X});
+    value += dot(${D.texture2D}(Im2Col, im2colCoords), ${D.texture2D}(K, kernelCoords));
+    ++im2colOffset;
+    ++kernelOffset;
+  }
+  ${A}
+  return value;
+}`;return{...H,output:{dims:K,type:j[0].type,textureType:0},shaderSource:I}},UQ=(Q,H,j,K)=>{let W=I8(H.length>2,K);return{...W,get:()=>x8(Q,W,H,j,K)}}}),y4,I6,O8,g8,y8,d8,x6,p8,V7=E(()=>{_1(),Q1(),$j(),vj(),wj(),W4(),KQ(),Z7(),y4=(Q,H,j,K,W)=>{let U=Q[0],Z=Q.slice(2),q=Z.length,G=H[0],J=H.slice(2).map((V,R)=>V+(V-1)*(j[R]-1)),X=Z.map((V,R)=>V+K[R]+K[R+q]).map((V,R)=>Math.floor((V-J[R]+W[R])/W[R]));return[U,G].concat(...X)},I6=(Q,H,j)=>(p8(H,j),O8(Q,H,j)),O8=(Q,H,j)=>{let K=d8(j,H),W=Q.session.pack,U=K.kernelShape[0]===1&&K.kernelShape[1]===1;return K.group>1?[Q.run(e0(Q,H,K),H)]:U&&W?[g8(Q,H,K)]:W&&H[0].dims.length===4&&H[0].dims[0]===1&&!U?[VQ(Q,H,K)]:[y8(Q,H,K)]},g8=(Q,H,j)=>{let K=H[0].dims,W=H[1].dims,U=y4(K,W,j.dilations,j.pads,j.strides),Z=Q.reshapeUnpacked(H[0],[K[1],K[2]*K[3]]),q=Q.reshapeUnpacked(H[1],[W[0],W[1]]),G=H.length>2?[q,Z,H[2]]:[q,Z],J=Q.run(v2(G,j),G);return Q.reshapeUnpacked(J,U)},y8=(Q,H,j)=>{let K=H[0].dims,W=H[1].dims,U=y4(K,W,j.dilations,j.pads,j.strides),Z=Q.run(XQ(Q,H[0],H[1],U,j),[H[0]]),q=H.length===3?[Z,H[1],H[2]]:[Z,H[1]];return Q.run(UQ(Q,H,U,j),q)},d8=(Q,H)=>{let j=Q.kernelShape.slice();if(Q.kernelShape.length===0)for(let U=2;U<H[1].dims.length;++U)j.push(H[1].dims[U]);let K=Q.pads.slice();R5.adjustPadsBasedOnAutoPad(H[0].dims,Q.strides,Q.dilations,j,K,Q.autoPad);let W=Object.assign({},Q);return Object.assign(W,{kernelShape:j,pads:K,cacheKey:Q.cacheKey}),W},x6=(Q)=>{let H=Q.attributes,j=F5(H),K=H.getString("auto_pad","NOTSET"),W=H.getInts("dilations",[1,1]),U=H.getInt("group",1),Z=H.getInts("kernel_shape",[]),q=H.getInts("pads",[0,0,0,0]),G=H.getInts("strides",[1,1]);return K1({autoPad:K,dilations:W,group:U,kernelShape:Z,pads:q,strides:G,...j})},p8=(Q,H)=>{if(!Q||Q.length!==2&&Q.length!==3)throw new Error("Conv requires 2 or 3 inputs");if(Q[0].dims.length!==4||Q[1].dims.length!==4)throw new Error("currently only support 2-dimensional conv");let j=Q[0].dims[1],K=Q[1].dims[1]*H.group;if(j!==K)throw new Error("FILTER_IN_CHANNEL should be equal to DATA_CHANNEL");if(Q.length===3&&(Q[2].dims.length!==1||Q[1].dims[0]!==Q[2].dims[0]))throw new Error("invalid bias");let W=Q[0].dims.length-2;if(H.dilations.length!==W)throw new Error(`dilations should be ${W}D`);if(H.strides.length!==W)throw new Error(`strides should be ${W}D`);if(H.pads.length!==W*2)throw new Error(`pads should be ${W*2}D`);if(H.kernelShape.length!==0&&H.kernelShape.length!==Q[1].dims.length-2)throw new Error("invalid kernel shape");if(Q[0].type!=="float32"||Q[1].type!=="float32")throw new Error("Conv input(X,W) should be float tensor");if(Q.length===3&&Q[2].type!=="float32")throw new Error("Conv input(bias) should be float tensor")}}),h8,b8,m8,qQ,c8,f8,l8,u8,s8,i8,WQ,o8,Tj=E(()=>{_1(),W1(),t(),W4(),h8=(Q,H,j,K,W,U)=>(Q-1)*H+j+(K-1)*W+1-U,b8=(Q,H,j,K,W)=>{let U=Math.floor(Q/2);H==="SAME_UPPER"?(j[K]=U,j[W]=Q-U):H==="SAME_LOWER"&&(j[K]=Q-U,j[W]=U)},m8=(Q,H,j,K,W,U,Z,q)=>{let G=Q.length-2,J=q.length===0;for(let X=0;X<G;++X){let V=J?Q[X+2]*U[X]:q[X],R=h8(Q[X+2],U[X],W[X],H[X],j[X],V);b8(R,K,W,X,X+G),J&&q.push(U[X]*(Q[X+2]-1)+Z[X]+(H[X]-1)*j[X]+1-W[X]-W[X+G])}},qQ=(Q,H,j)=>(o8(H,j),c8(Q,H,j)),c8=(Q,H,j)=>{let K=i8(j,H);return[s8(Q,H,K)]},f8=(Q,H)=>({name:"ConvTranspose",inputNames:Q?["X","W","B"]:["X","W"],inputTypes:Q?[0,0,0]:[0,0],cacheHint:H}),l8=(Q,H,j,K)=>{let W=H.length>2?"getB(output_channel)":"0.0",U=H[0].dims,Z=H[1].dims,q=Z[1],G=Z[0]/K.group,J=[H[0].dims[0],H[1].dims[1]*K.group,...K.outputShape],X=r(Q.session.backend.glContext.version),{activationFunction:V,applyActivation:R}=f4(K),z=`
+  const ivec2 strides = ivec2(${K.strides[0]}, ${K.strides[1]});
+  const ivec2 pads = ivec2(${K.pads[0]}, ${K.pads[1]});
+  ${V}
+  void main() {
+    ivec4 coords = getOutputCoords();
+    int batch = coords.x;
+    int output_channel = coords.y;
+
+    ivec2 loc = coords.zw + pads;
+
+    int group_id = output_channel / ${q};
+    int wOutChannel = output_channel - group_id * ${q};
+
+    float value = ${W};
+    for (int inChannelOffset = 0; inChannelOffset < ${G}; inChannelOffset++) {
+      int input_channel = group_id * ${G} + inChannelOffset;
+      for (int wWOff = 0; wWOff < ${Z[2]}; wWOff++) {
+        for (int wHOff = 0; wHOff < ${Z[3]}; wHOff++) {
+          ivec2 wOff = ivec2(wWOff * ${K.dilations[0]}, wHOff * ${K.dilations[1]});
+          ivec2 wLoc = loc - wOff;
+          ivec2 wLocIn = wLoc / strides;
+          if (
+            wLocIn * strides == wLoc &&
+            wLocIn.x >= 0 && wLocIn.x < ${U[2]} &&
+            wLocIn.y >= 0 && wLocIn.y < ${U[3]}
+          ) {
+            float xVal = getX(batch, input_channel, wLocIn.y, wLocIn.x);
+            float wVal = getW(input_channel, wOutChannel, wHOff, wWOff);
+            value += xVal * wVal;
+          }
+        }
+      }
+    }
+    ${R}
+    ${X.output} = vec4(value, .0, .0, .0);
+  }
+`;return{...j,output:{dims:J,type:H[0].type,textureType:0},shaderSource:z,hasMain:!0}},u8=(Q,H,j)=>{let K=f8(H.length>2,j.cacheKey);return{...K,get:()=>l8(Q,H,K,j)}},s8=(Q,H,j)=>Q.run(u8(Q,H,j),H),i8=(Q,H)=>{let j=Q.kernelShape.slice();if(Q.kernelShape.length===0)for(let q=2;q<H[1].dims.length;++q)j.push(H[1].dims[q]);let K=Q.pads.slice(),W=Q.outputShape.slice(),U=H[0].dims;m8(U,j,Q.dilations,Q.autoPad,K,Q.strides,Q.outputPadding,W);let Z=Object.assign({},Q);return Object.assign(Z,{kernelShape:j,pads:K,outputShape:W,cacheKey:Q.cacheKey}),Z},WQ=(Q)=>{let H=Q.attributes,j=F5(H),K=H.getString("auto_pad","NOTSET"),W=H.getInts("dilations",[1,1]),U=H.getInt("group",1),Z=H.getInts("kernel_shape",[]),q=H.getInts("output_padding",[0,0]),G=H.getInts("output_shape",[]),J=H.getInts("pads",[0,0,0,0]),X=H.getInts("strides",[1,1]);return K1({autoPad:K,dilations:W,group:U,kernelShape:Z,outputPadding:q,outputShape:G,pads:J,strides:X,...j})},o8=(Q,H)=>{if(!Q||Q.length!==2&&Q.length!==3)throw new Error("Conv requires 2 or 3 inputs");if(Q[0].dims.length!==4||Q[1].dims.length!==4)throw new Error("currently only support 2-dimensional conv");let j=Q[0].dims[1],K=Q[1].dims[0];if(j!==K)throw new Error("FILTER_IN_CHANNEL should be equal to DATA_CHANNEL");let W=Q[1].dims[1]*H.group;if(Q.length===3&&(Q[2].dims.length!==1||Q[2].dims[0]!==W))throw new Error("invalid bias");let U=Q[0].dims.length-2;if(H.dilations.length!==U)throw new Error(`dilations should be ${U}D`);if(H.strides.length!==U)throw new Error(`strides should be ${U}D`);if(H.pads.length!==U*2)throw new Error(`pads should be ${U*2}D`);if(H.outputPadding.length!==U)throw new Error(`output_padding should be ${U}D`);if(H.kernelShape.length!==0&&H.kernelShape.length!==Q[1].dims.length-2)throw new Error("invalid kernel shape");if(H.outputShape.length!==0&&H.outputShape.length!==Q[0].dims.length-2)throw new Error("invalid output shape");if(Q[0].type!=="float32"||Q[1].type!=="float32")throw new Error("ConvTranspose input(X,W) should be float tensor");if(Q.length===3&&Q[2].type!=="float32")throw new Error("ConvTranspose input(bias) should be float tensor")}}),l5,m4,GQ,a8,u5,n8,r8,t8,X7=E(()=>{_1(),Q1(),t(),l5={name:"Transpose",inputNames:["A"],inputTypes:[0]},m4=(Q,H,j)=>(t8(H),[Q.run({...l5,cacheHint:j.cacheKey,get:()=>a8(Q,H[0],j.perm)},H)]),GQ=(Q)=>K1({perm:Q.attributes.getInts("perm",[])}),a8=(Q,H,j)=>{let K=H.dims;j=u5(K,j);let W=n8(K,j),U=K.length,Z=`
+      ${r8("perm",j,U)}
+      float process(int indices[${U}]) {
+        int a[${U}];
+        perm(a, indices);
+        return _A(a);
+      }`;return{...l5,output:{dims:W,type:H.type,textureType:0},shaderSource:Z}},u5=(Q,H)=>(H&&H.length!==Q.length&&(H=[...Q.keys()].reverse()),H),n8=(Q,H)=>(H=u5(Q,H),u.sortBasedOnPerm(Q,H)),r8=(Q,H,j)=>{let K=[];K.push(`void ${Q}(out int a[${j}], int src[${j}]) {`);for(let W=0;W<j;++W)K.push(`	a[${H[W]}]=src[${W}];`);return K.push("	}"),K.join(`
+`)},t8=(Q)=>{if(!Q||Q.length!==1)throw new Error("Transpose requires 1 input.");if(Q[0].type!=="float32"&&Q[0].type!=="float64")throw new Error("input should be float tensor")}}),RQ,zQ,e8,Dj=E(()=>{X7(),RQ=(Q,H,j)=>{e8(H);let K=j.blocksize,W=K*K,U=j.mode==="DCR"?[0,3,4,1,5,2]:[0,1,4,2,5,3],Z=j.mode==="DCR"?[H[0].dims[0],K,K,H[0].dims[1]/W,H[0].dims[2],H[0].dims[3]]:[H[0].dims[0],H[0].dims[1]/W,K,K,H[0].dims[2],H[0].dims[3]],q=Q.reshapeUnpacked(H[0],Z),G={perm:U,cacheKey:`${U}`},[J]=m4(Q,[q],G),X=[H[0].dims[0],H[0].dims[1]/W,H[0].dims[2]*K,H[0].dims[3]*K];return[Q.reshapeUnpacked(J,X)]},zQ=(Q)=>{let H=Q.attributes.getInt("blocksize");if(H<1)throw new Error(`blocksize must be >= 1, but got : ${H} for DepthToSpace`);let j=Q.attributes.getString("mode","DCR");if(j!=="DCR"&&j!=="CRD")throw new Error(`unrecognized mode: ${j} for DepthToSpace`);return{mode:j,blocksize:H}},e8=(Q)=>{if(Q.length!==1)throw new Error(`DepthToSpace expect 1 inputs, but got ${Q.length}`);if(Q[0].type==="string"||Q[0].dims.length!==4)throw new TypeError("DepthToSpace input should be a 4-D numeric tensor")}}),NQ,MQ,Q9,_j=E(()=>{Q1(),NQ=(Q,H,j)=>{Q9(H,j);let K=u.flattenShape(H[0].dims,j);return[Q.reshapeUnpacked(H[0],K)]},MQ=(Q)=>Q.attributes.getInt("axis",1),Q9=(Q,H)=>{if(!Q||Q.length!==1)throw new Error("Flatten requires 1 input.");let j=Q[0].dims.length;if(j===0)throw new Error("scalar tensor is not supported.");if(H<-j||H>j)throw new Error("Invalid axis");if(Q[0].type==="string")throw new Error("string tensor is not supported.")}}),u4,k5=E(()=>{u4=["float32","float64","int32","int16","int8","uint16","uint32","uint8"]}),YQ,CQ,J9,H9,Z9,j9,Pj=E(()=>{_1(),k5(),Q1(),t(),YQ=(Q,H,j)=>(j9(H,j.axis),[Q.run(Z9(Q,H,j),H)]),CQ=(Q)=>K1({axis:Q.attributes.getInt("axis",0)}),J9={name:"Gather",inputNames:["A","B"],inputTypes:[0,0]},H9=(Q,H,j,K)=>{let W=j[0].dims.slice(),U=j[1].dims.slice(),Z=new Array(W.length+U.length-1);K=u.normalizeAxis(K,W.length);let q=[];for(let R=0;R<Z.length;R++)R<K?(Z[R]=W[R],q.push(`inputIdx[${R}] = outputIdx[${R}];`)):R<K+U.length?(Z[R]=U[R-K],q.push(`indexDataIdx[${R-K}] = outputIdx[${R}];`)):(Z[R]=W[R-U.length+1],q.push(`inputIdx[${R-U.length+1}] = outputIdx[${R}];`));let G=Z.length||1,J=W.length,X=U.length||1,V=`
+      float process(int outputIdx[${G}]) {
+        int inputIdx[${J}];
+        int indexDataIdx[${X}];
+        indexDataIdx[0] = 0;
+        ${q.join(`
+        `)}
+        int idx = int(_B(indexDataIdx));
+        inputIdx[${K}] = idx < 0 ? idx + ${W[K]} : idx;
+        return _A(inputIdx);
+      }`;return{...H,output:{dims:Z,type:j[0].type,textureType:0},shaderSource:V}},Z9=(Q,H,j)=>{let K={...J9,cacheHint:j.cacheKey};return{...K,get:()=>H9(Q,K,H,j.axis)}},j9=(Q,H)=>{if(!Q||Q.length!==2)throw new Error("Gather requires 2 inputs.");let j=Q[0].dims.length;if(j<1)throw new Error("Invalid input shape.");if(H<-j||H>j-1)throw new Error("Invalid axis.");if(u4.indexOf(Q[0].type)===-1)throw new Error("Invaid input type.");if(Q[1].type!=="int32"&&Q[1].type!=="int16")throw new Error("Invaid input type.")}}),O6,s5,BQ,FQ,V9,X9,K9,Ej=E(()=>{_1(),Q1(),t(),O6=(Q,H,j)=>(K9(H,j),[Q.run(V9(H,j),H)]),s5=(Q,H)=>{let j=Q.attributes.getInt("transA",0)!==0,K=Q.attributes.getInt("transB",0)!==0,W=Q.attributes.getFloat("alpha",1),U=Q.attributes.getFloat("beta",1);return K1({transA:j,transB:K,alpha:W,beta:U,isOptionalC:H})},BQ=(Q)=>s5(Q,!1),FQ=(Q)=>s5(Q,!0),V9=(Q,H)=>{let j={name:"Gemm",inputNames:Q.length===3?["A","B","C"]:["A","B"],inputTypes:Q.length===3?[0,0,0]:[0,0],key:H.cacheKey};return{...j,get:()=>X9(j,Q,H)}},X9=(Q,H,j)=>{let K=H[0].dims.slice(),W=H[1].dims.slice(),[U,Z]=t2.getShapeOfGemmResult(K,j.transA,W,j.transB,H.length===3?H[2].dims:void 0),q=[U,Z];if(!q)throw new Error("Can't use gemm on the given tensors");let G=K[K.length-1],J="";j.transA&&(G=K[0]),j.transA&&j.transB?J="value += _A_T(a) * _B_T(b);":j.transA&&!j.transB?J="value += _A_T(a) * _B(b);":!j.transA&&j.transB?J="value += _A(a) * _B_T(b);":!j.transA&&!j.transB&&(J="value += _A(a) * _B(b);");let X=q.length,V=H.length===3?`int c[${H[2].dims.length}];`:"",R=H.length===3?"bcastIndices_C(indices, c);":"",z=H.length===3?"value += beta * _C(c);":"",Y=`
+      float process(int indices[${X}]) {
+          int a[${X}];
+          int b[${X}];
+          ${V}
+
+          copyVec(indices, a);
+          copyVec(indices, b);
+          ${R}
+
+          float value = 0.0;
+          for (int k=0; k<${G}; ++k) {
+              a[${X-1}] = k;
+              b[${X-2}] = k;
+              ${J}
+          }
+
+          value = value * alpha;
+          ${z}
+          return value;
+      }`;return{...Q,output:{dims:q,type:H[0].type,textureType:0},variables:[{name:"alpha",type:"float",data:j.alpha},{name:"beta",type:"float",data:j.beta}],shaderSource:Y}},K9=(Q,H)=>{if(!Q)throw new Error("Input is missing");if(H.isOptionalC&&(Q.length<2||Q.length>3))throw new Error("Invaid input shape.");if(!H.isOptionalC&&Q.length!==3)throw new Error("Gemm requires 3 inputs");if(Q.length===3&&Q[2].dims.length!==1&&Q[2].dims.length!==2)throw new Error("Invalid input shape of C");if(Q[0].type!=="float32"&&Q[0].type!=="float64"||Q[1].type!=="float32"&&Q[1].type!=="float64"||Q.length===3&&Q[2].type!=="float32"&&Q[2].type!=="float64")throw new Error("Invalid input type.");if(Q[0].type!==Q[1].type||Q.length===3&&Q[0].type!==Q[2].type)throw new Error("Input types are mismatched")}}),kQ,AQ,U9,q9,W9,G9,R9,Ij=E(()=>{_1(),t(),kQ=(Q,H,j)=>(R9(H),[Q.run(W9(Q,H,j),H)]),AQ=(Q)=>{let H=Q.attributes.getFloat("scale"),j=Q.attributes.getFloats("bias");return K1({scale:H,bias:j})},U9={name:"ImageScaler",inputNames:["X"],inputTypes:[0]},q9=(Q,H,j,K)=>{let W=j[0].dims.slice(),U=W.length,Z=`
+      ${G9(K.bias.length)}
+      float process(int indices[${U}]) {
+        return _X(indices) * scale + getBias(bias, indices[1]);
+      }`;return{...H,output:{dims:W,type:j[0].type,textureType:0},variables:[{name:"bias",type:"float",arrayLength:K.bias.length,data:K.bias},{name:"scale",type:"float",data:K.scale}],shaderSource:Z}},W9=(Q,H,j)=>{let K={...U9,cacheHint:j.cacheKey};return{...K,get:()=>q9(Q,K,H,j)}},G9=(Q)=>{let H=[`float getBias(float bias[${Q}], int channel) {`];for(let j=0;j<Q;++j)j===0?H.push(`	if (channel == ${j}) { return bias[${j}]; }`):j===Q-1?H.push(`	else { return bias[${j}]; }`):H.push(`	else if (channel == ${j}) { return bias[${j}]; }`);return H.push("	}"),H.join(`
+`)},R9=(Q)=>{if(!Q||Q.length!==1)throw new Error("ImageScaler requires 1 input.");if(Q[0].dims.length!==4)throw new Error("Invalid input shape.");if(Q[0].type!=="float32"&&Q[0].type!=="float64")throw new Error("Invalid input type.")}}),SQ,$Q,i5,z9,N9,M9,Y9,C9,B9,xj=E(()=>{W1(),t(),SQ=(Q,H,j)=>{B9(H);let K=Q.run(N9(H[0]),H);return[Q.run(C9(Q,H[0],j,K.dims),[H[0],K,H[1],H[2]])]},$Q=(Q)=>Q.attributes.getFloat("epsilon",0.00001),i5={name:"InstanceNormalization_MeanAndVariance",inputNames:["X"],inputTypes:[0]},z9=(Q,H)=>{let j=H.dims.slice(),K=j[1],W=j[2]*j[3],U=[j[0],K],Z=`
+      vec4 process(int[2] indices) {
+        vec4 v = vec4(0.0);
+        int a[4];
+        a[0] = indices[0];
+        a[1] = indices[1];
+        float temp = 0.0;
+        for(int a2=0; a2<${j[2]}; a2++) {
+          a[2] = a2;
+          for(int a3=0; a3<${j[3]}; a3++) {
+            a[3] = a3;
+            float x = _X(a);
+            temp += x;
+          }
+        }
+        float mean = temp / float(${W});
+        temp = 0.0;
+        for(int a2=0; a2<${j[2]}; a2++) {
+          a[2] = a2;
+          for(int a3=0; a3<${j[3]}; a3++) {
+            a[3] = a3;
+            float x = _X(a);
+            temp += (x - mean) * (x - mean);
+          }
+        }
+        v.r = mean;
+        v.g = temp / float(${W});
+
+        return v;
+      }`;return{...Q,output:{dims:U,type:H.type,textureType:4},shaderSource:Z}},N9=(Q)=>({...i5,get:()=>z9(i5,Q)}),M9={name:"InstanceNormalization_ComputeOutput",inputNames:["X","MeanAndVariance","Scale","B"],inputTypes:[0,4,0,0]},Y9=(Q,H,j,K,W)=>{let U=r(Q.session.backend.glContext.version),[Z,q]=Q.calculateTextureWidthAndHeight(W,4),[G,J]=[Z/4,q],X=`
+      vec4 get_MeanAndVariance(int[2] mv) {
+        int offset = indicesToOffset_MeanAndVariance(mv);
+        vec2 coords = offsetToCoords(offset, ${G}, ${J});
+        return ${U.texture2D}(MeanAndVariance, coords);
+      }
+
+      float process(int[4] indices) {
+        int mv[2];
+        mv[0] = indices[0];
+        mv[1] = indices[1];
+        vec4 mean_and_variance = get_MeanAndVariance(mv);
+        float mean = mean_and_variance.r;
+        float variance = mean_and_variance.g;
+
+        int sb[1];
+        sb[0] = indices[1];
+        float scale = _Scale(sb);
+        float b = _B(sb);
+
+        return scale * (_X(indices) - mean) / sqrt(variance + epsilon) + b;
+      }`;return{...H,output:{dims:j.dims,type:j.type,textureType:0},variables:[{name:"epsilon",type:"float",data:K}],shaderSource:X}},C9=(Q,H,j,K)=>{let W={...M9,cacheHint:`${j}`};return{...W,get:()=>Y9(Q,W,H,j,K)}},B9=(Q)=>{if(!Q||Q.length!==3)throw new Error("InstanceNormalization requires 3 inputs.");let H=Q[0],j=Q[1],K=Q[2];if(H.dims.length<3||j.dims.length!==1||K.dims.length!==1)throw new Error("Invalid input shape.");if(j.dims[0]!==H.dims[1]||K.dims[0]!==H.dims[1])throw new Error("Input shapes are mismatched.");if(H.type!=="float32"&&H.type!=="float64"||j.type!=="float32"&&j.type!=="float64"||K.type!=="float32"&&K.type!=="float64")throw new Error("Invalid input type.");if(Q[0].dims.length!==4)throw new Error("Only support 4-D input shape.")}}),LQ,vQ,K7,F9,Oj=E(()=>{_1(),t(),LQ=(Q,H,j)=>(F9(H),[Q.run(FZ(H,j),H)]),vQ=(Q)=>{let H=Q.attributes.getFloat("alpha",0.0001),j=Q.attributes.getFloat("beta",0.75),K=Q.attributes.getFloat("bias",1),W=Q.attributes.getInt("size");return K1({alpha:H,beta:j,bias:K,size:W})},K7={name:"LRN",inputNames:["X"],inputTypes:[0]},F9=(Q)=>{if(!Q||Q.length!==1)throw new Error("LRN requires 1 input.");if(Q[0].dims.length!==4)throw new Error('currently only support LRN for input with "NCHW" format');if(Q[0].type!=="float32")throw new Error("input should be float type")}}),k9,g6,wQ,TQ,DQ,A9,S9,$9,L9,v9,w9,T9,D9,gj=E(()=>{_1(),Q1(),W1(),t(),k9={name:"Pad",inputNames:["A"],inputTypes:[0]},g6=(Q,H,j)=>($9(H),[Q.run({...k9,cacheHint:j.cacheKey,get:()=>S9(Q,H[0],j)},H)]),wQ=(Q)=>{let H=Q.attributes.getString("mode","constant"),j=Q.attributes.getFloat("value",0),K=Q.attributes.getInts("pads");return K1({mode:H,value:j,pads:K})},TQ=(Q,H,j)=>{L9(H);let K=A9(Q,H,j);return g6(Q,[H[0]],K)},DQ=(Q)=>Q.attributes.getString("mode","constant"),A9=(Q,H,j)=>{if(!Q.session.isInitializer(H[1].dataId)||H.length>=3&&!Q.session.isInitializer(H[2].dataId))throw new Error("dynamic pad attributes are not allowed");let K=Array.from(H[1].integerData),W=H.length>=3?H[2].floatData[0]:0;return K1({mode:j,pads:K,value:W})},S9=(Q,H,j)=>{let K=u.padShape(H.dims.slice(),j.pads),W=K.length,U=`
+      ${v9(Q,H,j)}
+      float process(int[${W}] indices) {
+          return padA(indices);
+      }`;return{name:"Pad",inputNames:["A"],inputTypes:[0],output:{dims:K,type:H.type,textureType:0},shaderSource:U}},$9=(Q)=>{if(!Q||Q.length!==1)throw new Error("Pad requires 1 input");if(Q[0].type!=="float32"&&Q[0].type!=="float64")throw new Error("Invalid input type.")},L9=(Q)=>{if(!Q||Q.length!==2&&Q.length!==3)throw new Error("Pad requires 2 or 3 inputs");if(Q[1].type!=="int32")throw new Error("Invalid input type.");if(Q.length>=3&&Q[2].type==="string")throw new Error("Invalid input type.")},v9=(Q,H,j)=>{let K=r(Q.session.backend.glContext.version),[W,U]=Q.calculateTextureWidthAndHeight(H.dims,0),Z=u.computeStrides(H.dims);switch(j.mode){case"constant":return w9(K,H.dims,Z,W,U,j.pads,j.value);case"reflect":return T9(K,H.dims,Z,W,U,j.pads);case"edge":return D9(K,H.dims,Z,W,U,j.pads);default:throw new Error("Invalid mode")}},w9=(Q,H,j,K,W,U,Z)=>{let q=H.length,G="";for(let J=q-1;J>=0;--J)G+=`
+        k = m[${J}] - ${U[J]};
+        if (k < 0)  return constant;
+        if (k >= ${H[J]}) return constant;
+        offset += k * ${j[J]};
+        `;return`
+      float padA(int m[${q}]) {
+        const float constant = float(${Z});
+        int offset = 0;
+        int k = 0;
+        ${G}
+        vec2 coords = offsetToCoords(offset, ${K}, ${W});
+        float value = getColorAsFloat(${Q.texture2D}(A, coords));
+        return value;
+      }
+      `},T9=(Q,H,j,K,W,U)=>{let Z=H.length,q="";for(let G=Z-1;G>=0;--G)q+=`
+        k = m[${G}] - ${U[G]};
+        if (k < 0) { k = -k; }
+        {
+          const int _2n_1 = ${2*(H[G]-1)};
+          k = int( mod( float(k), float(_2n_1) ) ) ;
+          if(k >= ${H[G]}) { k = _2n_1 - k; }
+        }
+        offset += k * ${j[G]};
+        `;return`
+      float padA(int m[${Z}]) {
+        int offset = 0;
+        int k = 0;
+        ${q}
+        vec2 coords = offsetToCoords(offset, ${K}, ${W});
+        float value = getColorAsFloat(${Q.texture2D}(A, coords));
+        return value;
+      }
+      `},D9=(Q,H,j,K,W,U)=>{let Z=H.length,q="";for(let G=Z-1;G>=0;--G)q+=`
+        k = m[${G}] - ${U[G]};
+        if (k < 0)  k = 0;
+        if (k >= ${H[G]}) k = ${H[G]-1};
+        offset += k * ${j[G]};
+      `;return`
+      float padA(int m[${Z}]) {
+        int offset = 0;
+        int k = 0;
+        ${q}
+        vec2 coords = offsetToCoords(offset, ${K}, ${W});
+        float value = getColorAsFloat(${Q.texture2D}(A, coords));
+        return value;
+      }
+      `}}),_Q,PQ,o5,EQ,IQ,xQ,OQ,a5,n5,_9,r5,gQ,L4,t5,v4,P9,yj=E(()=>{_1(),Q1(),t(),_Q=(Q,H,j)=>{L4(H);let K={name:"AveragePool",inputNames:["X"],inputTypes:[0],cacheHint:j.cacheKey};return[Q.run({...K,get:()=>o5(H,K,!1,j)},H)]},PQ=(Q)=>{let H=Q.attributes.getString("auto_pad","NOTSET"),j=Q.attributes.getInt("ceil_mode",0),K=Q.attributes.getInt("count_include_pad",0)!==0,W=Q.attributes.getInts("kernel_shape"),U=Q.attributes.getInts("strides",[]),Z=Q.attributes.getInts("pads",[]);if(j!==0)throw new Error("using ceil() in shape computation is not yet supported for AveragePool");return K1({autoPad:H,ceilMode:j,countIncludePad:K,kernelShape:W,strides:U,pads:Z})},o5=(Q,H,j,K)=>{let[W,U]=n5(Q,K,j),Z=u.size(W.kernelShape),q="value += _X(x);",G="";W.countIncludePad?G+=`value /= float(${Z});`:G+=`value /= float(${Z} - pad);`;let J=`
+        ${t5(Q[0].dims,W,q,G,"0.0")}
+      `;return{...H,output:{dims:U,type:Q[0].type,textureType:0},shaderSource:J}},EQ=(Q,H,j)=>{L4(H);let K={name:"GlobalAveragePool",inputNames:["X"],inputTypes:[0],cacheHint:`${j.countIncludePad}`};return[Q.run({...K,get:()=>o5(H,K,!0,j)},H)]},IQ=(Q)=>{let H=Q.attributes.getInt("count_include_pad",0)!==0;return K1({autoPad:"",ceilMode:0,countIncludePad:H,kernelShape:[],strides:[],pads:[]})},xQ=(Q,H,j)=>{L4(H);let K={name:"MaxPool",inputNames:["X"],inputTypes:[0],cacheHint:j.cacheKey};return[Q.run({...K,get:()=>a5(H,K,!1,j)},H)]},OQ=(Q)=>{let H=Q.attributes.getString("auto_pad","NOTSET"),j=Q.attributes.getInt("ceil_mode",0),K=Q.attributes.getInts("kernel_shape"),W=Q.attributes.getInts("strides",[]),U=Q.attributes.getInts("pads",[]),Z=Q.attributes.getInt("storage_order",0),q=Q.attributes.getInts("dilations",[]);if(Z!==0)throw new Error("column major storage order is not yet supported for MaxPool");if(j!==0)throw new Error("using ceil() in shape computation is not yet supported for MaxPool");return K1({autoPad:H,ceilMode:j,countIncludePad:!1,kernelShape:K,strides:W,pads:U,storageOrder:Z,dilations:q})},a5=(Q,H,j,K)=>{let[W,U]=n5(Q,K,j),Z=`
+      value = max(_X(x), value);
+    `,q="",G=`
+      ${t5(Q[0].dims,W,Z,q,"-1e5")}
+    `;return{...H,output:{dims:U,type:Q[0].type,textureType:0},shaderSource:G}},n5=(Q,H,j)=>{let K=Q[0].dims.slice(),W=Object.hasOwnProperty.call(H,"dilations"),U=H.kernelShape.slice(),Z=H.strides.slice(),q=W?H.dilations.slice():[],G=H.pads.slice();R5.adjustPoolAttributes(j,K,U,Z,q,G);let J=R5.computePoolOutputShape(j,K,Z,q,U,G,H.autoPad),X=Object.assign({},H);return W?Object.assign(X,{kernelShape:U,strides:Z,pads:G,dilations:q,cacheKey:H.cacheKey}):Object.assign(X,{kernelShape:U,strides:Z,pads:G,cacheKey:H.cacheKey}),[X,J]},_9={autoPad:"",ceilMode:0,countIncludePad:!1,kernelShape:[],strides:[],pads:[],storageOrder:0,dilations:[],cacheKey:""},r5={name:"GlobalMaxPool",inputNames:["X"],inputTypes:[0]},gQ=(Q,H)=>(L4(H),[Q.run({...r5,get:()=>a5(H,r5,!0,_9)},H)]),L4=(Q)=>{if(!Q||Q.length!==1)throw new Error("Pool ops requires 1 input.");if(Q[0].type!=="float32"&&Q[0].type!=="float64")throw new Error("Invalid input type.")},t5=(Q,H,j,K,W)=>{let U=Q.length;if(H.kernelShape.length<=2){let Z=H.kernelShape[H.kernelShape.length-1],q=H.strides[H.strides.length-1],G=H.pads[H.pads.length/2-1],J=H.pads[H.pads.length-1],X=Q[U-1],V="",R="",z="";if(G+J!==0?V=`
+          for (int i = 0; i < ${Z}; i++) {
+            x[${U} - 1] = indices[${U} - 1] * ${q} - ${G} + i;
+            if (x[${U} - 1] < 0 || x[${U} - 1] >= ${X}) {
+              pad++;
+              continue;
+            }
+            ${j}
+          }`:V=`
+          for (int i = 0; i < ${Z}; i++) {
+            x[${U} - 1] = indices[${U} - 1] * ${q} - ${G} + i;
+            ${j}
+          }`,H.kernelShape.length===2){let Y=H.kernelShape[H.kernelShape.length-2],B=H.strides[H.strides.length-2],k=H.pads[H.pads.length/2-2],w=H.pads[H.pads.length-2],A=Q[U-2];k+w!==0?R=`
+            for (int j = 0; j < ${Y}; j++) {
+              x[${U} - 2] = indices[${U} - 2] * ${B} - ${k} + j;
+              if (x[${U} - 2] < 0 || x[${U} - 2] >= ${A}) {
+                pad+= ${Z};
+                continue;
+              }
+          `:R=`
+            for (int j = 0; j < ${Y}; j++) {
+              x[${U} - 2] = indices[${U} - 2] * ${B} - ${k} + j;
+            `,z=`
+          }
+        `}return`
+        float process(int indices[${U}]) {
+          int x[${U}];
+          copyVec(indices, x);
+
+          float value = ${W};
+          int pad = 0;
+          ${R}
+          ${V}
+          ${z}
+          ${K}
+          return value;
+        }
+      `}else{let Z=u.size(H.kernelShape),q=u.computeStrides(H.kernelShape),G=q.length,J=H.pads.length,X=P9(G),V=v4(Q,"inputDims"),R=v4(H.pads,"pads"),z=v4(q,"kernelStrides"),Y=v4(H.strides,"strides"),B=H.pads.reduce((w,A)=>w+A),k="";return B?k=`
+            if (x[j] >= inputDims[j] || x[j] < 0) {
+              pad++;
+              isPad = true;
+              break;
+            }
+          }
+          if (!isPad) {
+            ${j}
+          }`:k=`
+          }
+          ${j}
+        `,`
+        ${X}
+        float process(int indices[${U}]) {
+          int x[${U}];
+          copyVec(indices, x);
+          int offset[${G}];
+          int pads[${J}];
+          int inputDims[${U}];
+          int kernelStrides[${G}];
+          int strides[${G}];
+          ${R}
+          ${V}
+          ${Y}
+          ${z}
+
+          float value = ${W};
+          int pad = 0;
+          bool isPad = false;
+          for (int i = 0; i < ${Z}; i++) {
+            offsetToIndices(i, kernelStrides, offset);
+            isPad = false;
+            for (int j = ${U} - ${G}; j < ${U}; j++) {
+              x[j] = indices[j] * strides[j - ${U} + ${G}]
+                + offset[j - ${U} + ${G}] - pads[j - 2];
+              ${k}
+          }
+          ${K}
+
+          return value;
+        }
+      `}},v4=(Q,H)=>{let j="";for(let K=0;K<Q.length;K++)j+=`
+      ${H}[${K}] = ${Q[K]};
+    `;return j},P9=(Q)=>`
+  void offsetToIndices(int offset, int[${Q}] strides, out int[${Q}] indices) {
+    if (${Q} == 0) {
+      return;
+    }
+    for (int i = 0; i < ${Q} - 1; ++i) {
+      indices[i] = offset / strides[i];
+      offset -= indices[i] * strides[i];
+    }
+    indices[${Q} - 1] = offset;
+  }`}),w3,D3,E9,I9,yQ,dQ,pQ,hQ,bQ,mQ,cQ,dj=E(()=>{_1(),k5(),Q1(),t(),w3=(Q,H,j,K,W)=>{I9(H);let U={name:K,inputNames:["A"],inputTypes:[0]};return[Q.run({...U,cacheHint:j.cacheKey,get:()=>E9(Q,H,j,K,W,U)},H)]},D3=(Q)=>{let H=Q.attributes.getInts("axes",[]),j=Q.attributes.getInt("keepdims",1)===1;return K1({axes:H,keepDims:j})},E9=(Q,H,j,K,W,U)=>{let Z=[],q=H[0].dims.length||1,G=[],J=u.normalizeAxes(j.axes,H[0].dims.length),X=W(H,J),V=X[1];for(let z=0;z<H[0].dims.length;z++)J.indexOf(z)>=0||J.length===0?(j.keepDims&&Z.push(1),V=`
+          for(int j${z} = 0; j${z} < ${H[0].dims[z]}; j${z}++) {
+            inputIdx[${z}] = j${z};
+            ${V}
+          }`):(G.push(`inputIdx[${z}] = outputIdx[${Z.length}];`),Z.push(H[0].dims[z]));let R=`
+      float process(int outputIdx[${Z.length||1}]) {
+        float value;                 // final result
+        int inputIdx[${q}];      // addressing input data
+        ${G.join(`
+`)}
+        ${X[0]}       // init ops for reduce max/min
+        ${V}
+        ${X[2]}       // final computation for reduce mean
+        return value;
+      }`;return{...U,output:{dims:Z,type:H[0].type,textureType:0},shaderSource:R}},I9=(Q)=>{if(!Q||Q.length!==1)throw new Error("Reduce op requires 1 input.");if(u4.indexOf(Q[0].type)===-1)throw new Error("Invalid input type.")},yQ=(Q,H,j)=>w3(Q,H,j,"ReduceSum",()=>["value = 0.0;","value += _A(inputIdx);",""]),dQ=(Q,H,j)=>w3(Q,H,j,"ReduceMean",(K,W)=>{let U=1;for(let Z=0;Z<K[0].dims.length;Z++)(W.indexOf(Z)>=0||W.length===0)&&(U*=K[0].dims[Z]);return["value = 0.0;","value += _A(inputIdx);",`value /= ${U}.;`]}),pQ=(Q,H,j)=>w3(Q,H,j,"ReduceMax",(K,W)=>{let U=[];for(let Z=0;Z<K[0].dims.length;Z++)(W.indexOf(Z)>=0||W.length===0)&&U.push(`inputIdx[${Z}] = 0;`);return[`${U.join(`
+`)}
+value = _A(inputIdx);`,"value = max(value, _A(inputIdx));",""]}),hQ=(Q,H,j)=>w3(Q,H,j,"ReduceMin",(K,W)=>{let U=[];for(let Z=0;Z<K[0].dims.length;Z++)(W.indexOf(Z)>=0||W.length===0)&&U.push(`inputIdx[${Z}] = 0;`);return[`${U.join(`
+`)}
+value = _A(inputIdx);`,"value = min(value, _A(inputIdx));",""]}),bQ=(Q,H,j)=>w3(Q,H,j,"ReduceProd",()=>["value = 1.0;","value *= _A(inputIdx);",""]),mQ=(Q,H,j)=>w3(Q,H,j,"ReduceLogSum",()=>["value = 0.0;","value += _A(inputIdx);","value = log(value);"]),cQ=(Q,H,j)=>w3(Q,H,j,"ReduceLogSumSquare",()=>["float t; value = 0.0;","t = _A(inputIdx); value += t * t;",""])}),fQ,pj=E(()=>{Q1(),fQ=(Q,H)=>{let j=u.calculateReshapedDims(H[0].dims,H[1].integerData);return Q.session.pack?[Q.reshapePacked(H[0],j)]:[Q.reshapeUnpacked(H[0],j)]}}),e5,y6,lQ,uQ,d4,x9,d6,N5,sQ=E(()=>{_1(),W1(),t(),e5={name:"Upsample",inputNames:["X"],inputTypes:[0]},y6=(Q,H,j)=>(d6(H,j),[Q.run({...e5,cacheHint:j.cacheKey,get:()=>x9(Q,H,j)},H)]),lQ=(Q)=>d4(Q,7),uQ=(Q)=>d4(Q,9),d4=(Q,H)=>{let j=H>=10,K=Q.attributes.getString("mode","nearest");if(K!=="nearest"&&K!=="linear"&&(H<11||K!=="cubic"))throw new Error(`unrecognized mode: ${K}`);let W=[];H<9&&(W=Q.attributes.getFloats("scales"),N5(W,K,j));let U=Q.attributes.getFloat("extrapolation_value",0),Z=H>10?Q.attributes.getString("coordinate_transformation_mode","half_pixel"):"asymmetric";if(["asymmetric","pytorch_half_pixel","tf_half_pixel_for_nn","align_corners","tf_crop_and_resize","half_pixel"].indexOf(Z)===-1)throw new Error(`coordinate_transform_mode '${Z}' is not supported`);let q=Z==="tf_crop_and_resize",G=q,J=K==="nearest"&&H>=11?Q.attributes.getString("nearest_mode","round_prefer_floor"):"";if(["round_prefer_floor","round_prefer_ceil","floor","ceil",""].indexOf(J)===-1)throw new Error(`nearest_mode '${J}' is not supported`);let X=Q.attributes.getFloat("cubic_coeff_a",-0.75),V=Q.attributes.getInt("exclude_outside",0)!==0;if(V&&K!=="cubic")throw new Error("exclude_outside can be set to 1 only when mode is CUBIC.");let R=H<11?!0:K==="nearest"&&Z==="asymmetric"&&J==="floor",z=0,Y=0,B=0;return H>10?Q.inputs.length>2?(z=1,Y=2,B=3):(Y=1,B=2):H===9&&(Y=1),K1({opset:H,isResize:j,mode:K,scales:W,extrapolationValue:U,coordinateTransformMode:Z,useExtrapolation:G,needRoiInput:q,nearestMode:J,cubicCoefficientA:X,excludeOutside:V,useNearest2xOptimization:R,roiInputIdx:z,scalesInputIdx:Y,sizesInputIdx:B})},x9=(Q,H,j)=>{let K=r(Q.session.backend.glContext.version),[W,U]=Q.calculateTextureWidthAndHeight(H[0].dims,0),Z=H[0].dims.map((B,k)=>Math.floor(B*j.scales[k])),[q,G]=Q.calculateTextureWidthAndHeight(Z,0),J=Z.length,X=new Array(J),V=new Array(J),R=`
+      int output_pitches[${J}];
+      int input_pitches[${J}];
+      `;for(let B=J-1;B>=0;B--)X[B]=B===J-1?1:X[B+1]*Z[B+1],V[B]=B===J-1?1:V[B+1]*H[0].dims[B+1],R+=`
+        output_pitches[${B}] = ${X[B]};
+        input_pitches[${B}] = ${V[B]};
+        `;let z=`
+      float getInputFloat(int index) {
+        vec2 coords = offsetToCoords(index, ${W}, ${U});
+        float value = getColorAsFloat(${K.texture2D}(X, coords));
+        return value;
+      }
+      `,Y=j.mode==="nearest"?`
+    ${z}
+    float process(int indices[${J}]) {
+      int input_index = 0;
+      int output_index = coordsToOffset(TexCoords, ${q}, ${G});
+
+      ${R}
+
+      int d, m;
+      for (int dim = 0; dim < ${J}; ++dim) {
+        d = output_index / output_pitches[dim];
+        m = output_index - d * output_pitches[dim];
+        output_index = m;
+
+        if (scales[dim] != 1 && d > 0) {
+          int d2 = d / scales[dim];
+          m = d - d2 * scales[dim];
+          d = d2;
+        }
+        input_index += input_pitches[dim] * d;
+      }
+
+      return getInputFloat(input_index);
+    }`:J===4?`
+    ${z}
+    float process(int indices[4]) {
+      int input_index = 0;
+      int output_index = coordsToOffset(TexCoords, ${q}, ${G});
+
+      ${R}
+
+      int m;
+      int index_of_dim0, index_of_dim1, index_of_dim2, index_of_dim3;
+      index_of_dim0 = output_index / output_pitches[0];
+      m = output_index - index_of_dim0 * output_pitches[0];
+      index_of_dim1 = m / output_pitches[1];
+      m = m - index_of_dim1 * output_pitches[1];
+      index_of_dim2 = m / output_pitches[2];
+      m = m - index_of_dim2 * output_pitches[2];
+      index_of_dim3 = m;
+
+      int index_of_input_dim2, index_of_input_dim3, x_offset, y_offset;
+      index_of_input_dim2 = index_of_dim2 / scales[2];
+      y_offset = index_of_dim2 - index_of_input_dim2 * scales[2];
+      index_of_input_dim3 = index_of_dim3 / scales[3];
+      x_offset = index_of_dim3 - index_of_input_dim3 * scales[3];
+
+      input_index = index_of_dim0 * input_pitches[0] +
+            index_of_dim1 * input_pitches[1] +
+            index_of_input_dim2 * input_pitches[2] +
+            index_of_input_dim3;
+
+      float x00 = getInputFloat(input_index);
+      float x10, x01, x11;
+
+      bool end_of_dim2 = false;
+      if (index_of_input_dim2 == (${H[0].dims[2]} - 1)) {
+        // It's the end in dimension 2
+        x01 = x00;
+        end_of_dim2 = true;
+      } else {
+        x01 = getInputFloat(input_index + input_pitches[2]);
+      }
+
+      if (index_of_input_dim3 == (input_pitches[2] - 1)) {
+        // It's the end in dimension 3
+        x10 = x00;
+        x11 = x01;
+      }
+      else {
+        x10 = getInputFloat(input_index + 1);
+        x11 = end_of_dim2 ? x10 : getInputFloat(input_index + input_pitches[2] + 1);
+      }
+
+      float y0 = x00 + float(y_offset) * (x01 - x00) / float(scales[2]);
+      float y1 = x10 + float(y_offset) * (x11 - x10) / float(scales[2]);
+      return y0 + float(x_offset) * (y1 - y0) / float(scales[3]);
+    }`:`
+    ${z}
+    float process(int indices[2]) {
+      int input_index = 0;
+      int output_index = coordsToOffset(TexCoords, ${q}, ${G});
+
+      ${R}
+
+      int m;
+      int index_of_dim0, index_of_dim1;
+      index_of_dim0 = output_index / output_pitches[0];
+      m = output_index - index_of_dim0 * output_pitches[0];
+      index_of_dim1 = m;
+
+      int index_of_input_dim0, index_of_input_dim1, x_offset, y_offset;
+      index_of_input_dim0 = index_of_dim0 / scales[0];
+      y_offset = index_of_dim0 - index_of_input_dim0 * scales[0];
+      index_of_input_dim1 = index_of_dim1 / scales[1];
+      x_offset = index_of_dim1 - index_of_input_dim1 * scales[1];
+
+      input_index = index_of_input_dim0 * input_pitches[0] + index_of_input_dim1;
+
+      float x00 = getInputFloat(input_index);
+      float x10, x01, x11;
+
+      bool end_of_dim0 = false;
+      if (index_of_input_dim0 == (${H[0].dims[0]} - 1)) {
+        // It's the end in dimension 0
+        x01 = x00;
+        end_of_dim0 = true;
+      } else {
+        x01 = getInputFloat(input_index + input_pitches[0]);
+      }
+
+      if (index_of_input_dim1 == (input_pitches[0] - 1)) {
+        // It's the end in dimension 1
+        x10 = x00;
+        x11 = x01;
+      }
+      else {
+        x10 = getInputFloat(input_index + 1);
+        x11 = end_of_dim0 ? x10 : getInputFloat(input_index + input_pitches[0] + 1);
+      }
+
+      float y0 = x00 + float(y_offset) * (x01 - x00) / float(scales[0]);
+      float y1 = x10 + float(y_offset) * (x11 - x10) / float(scales[0]);
+      return y0 + float(x_offset) * (y1 - y0) / float(scales[1]);
+    }`;return{...e5,output:{dims:Z,type:H[0].type,textureType:0},shaderSource:Y,variables:[{name:"scales",type:"int",arrayLength:j.scales.length,data:j.scales.map((B)=>Math.ceil(B))}]}},d6=(Q,H)=>{if(!Q||H.opset<9&&Q.length!==1||H.opset>=9&&H.opset<11&&Q.length!==2||H.opset>=11&&Q.length<2)throw new Error("invalid inputs.");if(H.scales.length>0&&Q[0].dims.length!==H.scales.length)throw new Error("Invalid input shape.");if(Q[0].type==="string")throw new Error("Invalid input tensor types.")},N5=(Q,H,j)=>{if(j){for(let K of Q)if(K<=0)throw new Error("Scale value should be greater than 0.")}else for(let K of Q)if(K<1)throw new Error("Scale value should be greater than or equal to 1.");if((H==="linear"||H==="cubic")&&Q.length!==2&&(Q.length!==4||Q[0]!==1||Q[1]!==1))throw new Error(`'Linear' mode and 'Cubic' mode only support 2-D inputs ('Bilinear', 'Bicubic')         or 4-D inputs with the corresponding outermost 2 scale values being 1         in the ${j?"Resize":"Upsample"} opeartor.`)}}),V5,p6,iQ,oQ,O9,g9,y9,d9,hj=E(()=>{W1(),t(),F3(),U4(),sQ(),V5={name:"Resize",inputNames:["A"],inputTypes:[2]},p6=(Q,H,j)=>(d6(H,j),[Q.run({...V5,cacheHint:j.cacheKey,get:()=>O9(Q,H,j)},H)]),iQ=(Q)=>d4(Q,10),oQ=(Q)=>d4(Q,11),O9=(Q,H,j)=>{let K=r(Q.session.backend.glContext.version),[W,U]=g9(H,j);if(W.every((A)=>A===1)&&j.coordinateTransformMode!=="tf_crop_and_resize")return{...V5,output:{dims:U,type:H[0].type,textureType:2},hasMain:!0,shaderSource:`void main() {
+                    vec4 v = ${K.texture2D}(X, TexCoords);
+                    ${K.output} = v;
+                }`};let Z=U.length;if(Z<2)throw new Error(`output dimension should be at least 2, but got ${Z}`);let q=U[Z-2],G=U[Z-1],J=H[0].dims;if(Z!==J.length)throw new Error(`output dimension should match input ${J.length}, but got ${Z}`);let X=J[Z-2],V=J[Z-1],R=W[Z-2],z=W[Z-1],Y="";if(j.mode!=="linear")throw new Error(`resize (packed) does not support mode: '${j.mode}'`);switch(j.coordinateTransformMode){case"asymmetric":Y=`
+                    vec4 getSourceFracIndex(ivec4 coords) {
+                        return vec4(coords) / scaleWHWH;
+                    }
+                `;break;case"half_pixel":Y=`
+                    vec4 getSourceFracIndex(ivec4 coords) {
+                        return (vec4(coords) + 0.5) / scaleWHWH - 0.5;
+                    }
+                `;break;case"pytorch_half_pixel":Y=`
+                    vec4 getSourceFracIndex(ivec4 coords) {
+                        vec4 fcoords = vec4(coords);
+                        return vec4(
+                            ${G}.0 > 1.0 ? (fcoords.x + 0.5) / scaleWHWH.x - 0.5 : 0.0,
+                            ${q}.0 > 1.0 ? (fcoords.y + 0.5) / scaleWHWH.y - 0.5 : 0.0,
+                            ${G}.0 > 1.0 ? (fcoords.z + 0.5) / scaleWHWH.z - 0.5 : 0.0,
+                            ${q}.0 > 1.0 ? (fcoords.w + 0.5) / scaleWHWH.w - 0.5 : 0.0
+                          );
+                    }
+                `;break;case"align_corners":Y=`
+                    vec4 getSourceFracIndex(ivec4 coords) {
+                        vec4 resized = vec4(${G}.0 - 1.0, ${q}.0 - 1.0, ${G}.0 - 1.0,
+                            ${q}.0 - 1.0);
+                        vec4 original = vec4(${V}.0 - 1.0, ${X}.0 - 1.0, ${V}.0 - 1.0,
+                            ${X}.0 - 1.0);
+                        vec4 new_scale = original / resized;
+                        return vec4(coords) * new_scale;
+                    }
+                `;break;default:throw new Error(`resize (packed) does not support coordinateTransformMode:                                 '${j.coordinateTransformMode}'`)}let B=P3(Z),k=c4(),w=`
+            const vec2 inputWH = vec2(${X}.0, ${V}.0);
+            const vec4 scaleWHWH = vec4(float(${R}), float(${z}), float(${R}), float(${z}));
+            ${k}
+            ${Y}
+            float getAValue(int x10, int r, int c, int d) {
+                return getChannel(getA(x10, r, c, d), vec2(c, d));
+            }
+            void main() {
+                ${B} rc = getOutputCoords();
+
+                int batch = rc[0];
+                int depth = rc[1];
+
+                // retrieve the 4 coordinates that is used in the 4 packed output values.
+                ivec4 coords = ivec4(rc.wz, rc.w + 1, rc.z + 1);
+
+                // calculate the source index in fraction
+                vec4 sourceFrac = getSourceFracIndex(coords);
+
+                // get the lower and upper bound of the 4 values that will be packed into one texel.
+                ivec4 x00 = ivec4(max(sourceFrac.xy, vec2(0.0)), min(inputWH - 1.0, ceil(sourceFrac.xy)));
+                ivec4 x01 = ivec4(max(sourceFrac.xw, vec2(0.0)), min(inputWH - 1.0, ceil(sourceFrac.xw)));
+                ivec4 x10 = ivec4(max(sourceFrac.zy, vec2(0.0)), min(inputWH - 1.0, ceil(sourceFrac.zy)));
+                ivec4 x11 = ivec4(max(sourceFrac.zw, vec2(0.0)), min(inputWH - 1.0, ceil(sourceFrac.zw)));
+
+                bool hasNextRow = rc.w < ${q-1};
+                bool hasNextCol = rc.z < ${G-1};
+
+                // pack x00, x01, x10, x11's top-left corner into one vec4 structure
+                vec4 topLeft = vec4(
+                    getAValue(batch, depth, x00.x, x00.y),
+                    hasNextCol ? getAValue(batch, depth, x01.x, x01.y) : 0.0,
+                    hasNextRow ? getAValue(batch, depth, x10.x, x10.y) : 0.0,
+                    (hasNextRow && hasNextCol) ? getAValue(batch, depth, x11.x, x11.y) : 0.0);
+
+                // pack x00, x01, x10, x11's top-right corner into one vec4 structure
+                vec4 topRight = vec4(
+                    getAValue(batch, depth, x00.x, x00.w),
+                    hasNextCol ? getAValue(batch, depth, x01.x, x01.w) : 0.0,
+                    hasNextRow ? getAValue(batch, depth, x10.x, x10.w) : 0.0,
+                    (hasNextRow && hasNextCol) ? getAValue(batch, depth, x11.x, x11.w) : 0.0);
+
+                // pack x00, x01, x10, x11's bottom-left corner into one vec4 structure
+                vec4 bottomLeft = vec4(
+                    getAValue(batch, depth, x00.z, x00.y),
+                    hasNextCol ? getAValue(batch, depth, x01.z, x01.y) : 0.0,
+                    hasNextRow ? getAValue(batch, depth, x10.z, x10.y) : 0.0,
+                    (hasNextRow && hasNextCol) ? getAValue(batch, depth, x11.z, x11.y) : 0.0);
+
+                // pack x00, x01, x10, x11's bottom-right corner into one vec4 structure
+                vec4 bottomRight = vec4(
+                    getAValue(batch, depth, x00.z, x00.w),
+                    hasNextCol ? getAValue(batch, depth, x01.z, x01.w) : 0.0,
+                    hasNextRow ? getAValue(batch, depth, x10.z, x10.w) : 0.0,
+                    (hasNextRow && hasNextCol) ? getAValue(batch, depth, x11.z, x11.w) : 0.0);
+
+                // calculate the interpolation fraction on u and v direction
+                vec4 frac = vec4(sourceFrac) - floor(sourceFrac);
+                vec4 clampFrac = clamp(frac, vec4(0.0), vec4(1.0));
+
+                vec4 top = mix(topLeft, topRight, clampFrac.ywyw);
+                vec4 bottom = mix(bottomLeft, bottomRight, clampFrac.ywyw);
+                vec4 newValue = mix(top, bottom, clampFrac.xxzz);
+
+                ${K.output} = vec4(newValue);
+            }
+        `;return{...V5,output:{dims:U,type:H[0].type,textureType:2},hasMain:!0,shaderSource:w}},g9=(Q,H)=>{let j=Q[0].dims,K=H.scales,W;if(K.length===0){let Z=Q[H.scalesInputIdx];if(Z&&Z.size!==0){if(Q[H.sizesInputIdx])throw new Error("Only one of scales or sizes must be provided as input.");K=y9(Z,H.mode,H.isResize)}else{let q=Q[H.sizesInputIdx];if(!q||q.size===0)throw new Error("Either scales or sizes MUST be provided as input.");W=Array.from(q.integerData),K=d9(W,j,H.mode,H.isResize)}}else if(Q[H.sizesInputIdx])throw new Error("Only one of scales or sizes must be provided as input.");let U=W||j.map((Z,q)=>Math.floor(Z*K[q]));return[K,U]},y9=(Q,H,j)=>{let K=Array.from(Q.floatData);return N5(K,H,j),K},d9=(Q,H,j,K)=>{let W=H.length,U=new Array(W);for(let Z=0,q=W;Z<q;Z++)if(H[Z]===0){if(Q[Z]!==0)throw new Error("Input dim is zero but required output dim is non-zero.");U[Z]=1}else U[Z]=Q[Z]/H[Z];return N5(U,j,K),U}}),aQ,p9,bj=E(()=>{K4(),aQ=(Q,H)=>(p9(H),[new o1([H[0].dims.length],"int32",void 0,void 0,new Int32Array(H[0].dims))]),p9=(Q)=>{if(!Q||Q.length!==1)throw new Error("Shape requires 1 input.")}}),X5,nQ,rQ,Q6,h9,tQ,b9,m9,mj=E(()=>{_1(),k5(),Q1(),t(),X5={name:"Slice",inputNames:["A"],inputTypes:[0]},nQ=(Q,H,j)=>(h9(H),[Q.run({...X5,cacheHint:j.cacheKey,get:()=>Q6(Q,H[0],j)},H)]),rQ=(Q)=>{let H=Q.attributes.getInts("starts"),j=Q.attributes.getInts("ends"),K=Q.attributes.getInts("axes",[]);return K1({starts:H,ends:j,axes:K})},Q6=(Q,H,j)=>{let K=j.axes.length===0?H.dims.slice(0).map((X,V)=>V):j.axes,W=u.normalizeAxes(K,H.dims.length),U=j.starts.map((X,V)=>X>H.dims[W[V]]-1?H.dims[W[V]]:u.normalizeAxis(X,H.dims[W[V]])),Z=j.ends.map((X,V)=>X>H.dims[W[V]]-1?H.dims[W[V]]:u.normalizeAxis(X,H.dims[W[V]])),q=H.dims.slice(),G=[];for(let X=0;X<W.length;X++)q[W[X]]=Z[X]-U[X],U[X]>0&&G.push(`outputIdx[${W[X]}] += ${U[X]};`);let J=`
+      float process(int outputIdx[${q.length}]) {
+        ${G.join(`
+      `)}
+        return _A(outputIdx);
+      }`;return{...X5,output:{dims:q,type:H.type,textureType:0},shaderSource:J}},h9=(Q)=>{if(!Q||Q.length!==1)throw new Error("Slice requires 1 input.");if(u4.indexOf(Q[0].type)===-1)throw new Error("Invalid input type.")},tQ=(Q,H)=>{m9(H);let j=b9(Q,H);return[Q.run({...X5,cacheHint:j.cacheKey,get:()=>Q6(Q,H[0],j)},[H[0]])]},b9=(Q,H)=>{if(!Q.session.isInitializer(H[1].dataId)||!Q.session.isInitializer(H[2].dataId)||H.length>=4&&!Q.session.isInitializer(H[3].dataId)||H.length>=5&&!Q.session.isInitializer(H[4].dataId))throw new Error("dynamic slice attributes are not allowed");if(H.length>=5&&H[4].integerData.some((Z)=>Z!==1))throw new Error("currently non-1 steps is not supported for Slice");let j=Array.from(H[1].integerData),K=Array.from(H[2].integerData),W=H.length>=4?Array.from(H[3].integerData):[],U=`${W};${j};${K}`;return{starts:j,ends:K,axes:W,cacheKey:U}},m9=(Q)=>{if(!Q||Q.length<3||Q.length>5)throw new Error("Invalid input number.");if(Q[1].type!=="int32"||Q[1].dims.length!==1)throw new Error("Invalid input type.");if(Q[2].type!=="int32"||Q[2].dims.length!==1)throw new Error("Invalid input type.");if(Q.length>=4&&(Q[3].type!=="int32"||Q[3].dims.length!==1))throw new Error("Invalid input type.");if(Q.length>=5&&(Q[4].type!=="int32"||Q[4].dims.length!==1))throw new Error("Invalid input type.")}}),J6,H6,Z6,eQ,QJ,JJ,HJ,j6,c9,f9,l9,V6,cj=E(()=>{_1(),Q1(),W1(),t(),X7(),J6={name:"SoftmaxComputeMax",inputNames:["A"],inputTypes:[0]},H6={name:"SoftmaxComputeScale",inputNames:["A","Max"],inputTypes:[0,0]},Z6={name:"SoftMax",inputNames:["A","Max","Norm"],inputTypes:[0,0,0]},eQ=(Q,H,j)=>{V6(H);let K=H[0].dims.slice(),W=u.normalizeAxis(j.axis,K.length),U=u.sizeToDimension(K,W),Z=u.sizeFromDimension(K,W);return j6(Q,H,j,U,Z)},QJ=(Q)=>K1({axis:Q.attributes.getInt("axis",1)}),JJ=(Q)=>K1({axis:Q.attributes.getInt("axis",-1)}),HJ=(Q,H,j)=>{V6(H);let K=H[0].dims.slice(),W=u.normalizeAxis(j.axis,K.length),U=K.length,Z=W!==U-1,q=[],G=[],J=[],X;Z&&(G=Array.from({length:U}).map((Y,B)=>B),G[W]=U-1,G[U-1]=W,G.map((Y)=>q.push(K[Y])),X=K1({perm:G}),J=m4(Q,H,X));let V=Z?u.sizeToDimension(q,U-1):u.sizeToDimension(K,U-1),R=Z?u.sizeFromDimension(q,U-1):u.sizeFromDimension(K,U-1),z=j6(Q,Z?J:H,j,V,R);return Z?m4(Q,z,X):z},j6=(Q,H,j,K,W)=>{let U=c9(Q,H[0],K,W,[K]),Z=Q.run({...J6,cacheHint:j.cacheKey,get:()=>U},H),q=f9(Q,H[0],K,W,U.output.dims,[K]),G=Q.run({...H6,cacheHint:j.cacheKey,get:()=>q},[H[0],Z]),J=l9(Q,H[0],K,W,U.output.dims,q.output.dims);return[Q.run({...Z6,cacheHint:j.cacheKey,get:()=>J},[H[0],Z,G])]},c9=(Q,H,j,K,W)=>{let[U,Z]=Q.calculateTextureWidthAndHeight(H.dims,0),q=W.length;if(j<1||K<1)throw new Error("Logical row count N and feature count D must be greater than or equal to 1");if(W.length!==1)throw new Error("Dimensionality of the output should be 1");if(W[0]!==j)throw new Error("Shape of the output should be equal to logical row count");let G=r(Q.session.backend.glContext.version),J=`
+      float process(int[${q}] indices) {
+        int logical_row_start_offset = indices[0] * ${K};
+
+        float max = getColorAsFloat(${G.texture2D}(A, offsetToCoords(logical_row_start_offset, ${U},
+        ${Z} )));
+        for(int i=1; i<${K}; ++i)
+        {
+          float current = getColorAsFloat(${G.texture2D}(A, offsetToCoords(logical_row_start_offset + i,
+            ${U}, ${Z})));
+          if(current > max)
+          max = current;
+        }
+
+        return max;
+      }`;return{...J6,output:{dims:W,type:H.type,textureType:0},shaderSource:J}},f9=(Q,H,j,K,W,U)=>{let[Z,q]=Q.calculateTextureWidthAndHeight(H.dims,0),G=U.length;if(j<1||K<1)throw new Error("Logical row count N and feature count D must be greater than or equal to 1");if(U.length!==1)throw new Error("Dimensionality of the output should be 1");if(U[0]!==j)throw new Error("Shape of the output should be equal to logical row count");if(W.length!==1)throw new Error("Dimensionality of the intermediate results should be 1");if(W[0]!==j)throw new Error("Shape of the intermediate results should be equal to logical row count");let J=r(Q.session.backend.glContext.version),X=`
+      float process(int[${G}] indices) {
+        int logical_row_start_offset = indices[0] * ${K};
+
+        float norm_factor = 0.0;
+        float max = _Max(indices);
+        for(int i=0; i<${K}; ++i)
+        {
+          norm_factor += exp(getColorAsFloat(${J.texture2D}(A, offsetToCoords(logical_row_start_offset + i,
+            ${Z}, ${q}))) - max);
+        }
+
+        return norm_factor;
+      }`;return{...H6,output:{dims:U,type:H.type,textureType:0},shaderSource:X}},l9=(Q,H,j,K,W,U)=>{let[Z,q]=Q.calculateTextureWidthAndHeight(H.dims,0),G=H.dims.length;if(j<1||K<1)throw new Error("Logical row count N and feature count D must be greater than or equal to 1");if(W.length!==1||U.length!==1)throw new Error("Dimensionality of the intermediate results should be 1");if(W[0]!==j||U[0]!==j)throw new Error("Shape of the intermediate results should be equal to logical row count");let J=`
+      float process(int[${G}] indices) {
+
+      // get offset of current logical tensor index from the 2-D texture coordinates (TexCoords)
+      int offset = coordsToOffset(TexCoords, ${Z}, ${q});
+
+      //determine the logical row for this index
+      int logical_row_index[1];
+      logical_row_index[0] = offset / ${K};
+
+      float norm_factor = _Norm(logical_row_index);
+
+      // avoid possible division by 0
+      // if norm_facor is 0, all elements are zero
+      // if so, return 0
+      if(norm_factor == 0.0)
+        return 0.0;
+
+      return exp(_A(indices) - _Max(logical_row_index)) / norm_factor;
+    }`;return{...Z6,output:{dims:H.dims,type:H.type,textureType:0},shaderSource:J}},V6=(Q)=>{if(!Q||Q.length!==1)throw new Error("Softmax requires 1 input.");if(Q[0].type!=="float32"&&Q[0].type!=="float64")throw new Error("Invalid input type")}}),X6,ZJ,jJ,u9,s9,i9,fj=E(()=>{_1(),Q1(),t(),X6={name:"Split",inputNames:["A"],inputTypes:[0]},ZJ=(Q,H,j)=>{i9(H);let K=u.normalizeAxis(j.axis,H[0].dims.length),W=u9(Q,H,K,j),U=[];for(let Z=0;Z<W;++Z)U.push(Q.run({...X6,cacheHint:`${j.cacheKey};${Z}`,get:()=>s9(Q,H[0],j,K,Z)},H));return U},jJ=(Q)=>{let H=Q.attributes.getInt("axis",0),j=Q.attributes.getInts("split",[]),K=Q.outputs.length;return K1({axis:H,split:j,numOutputs:K})},u9=(Q,H,j,K)=>{let[,W]=L6.splitShape(H[0].dims,j,K.split,K.numOutputs);return W.length},s9=(Q,H,j,K,W)=>{let[U,Z]=L6.splitShape(H.dims,K,j.split,j.numOutputs),q=Z[W],G=U[W],J=`
+      float process(int indices[${G.length}]) {
+        indices[${K}] += ${q};
+        return _A(indices);
+      }
+    `;return{...X6,cacheHint:`${j.cacheKey}:${W}`,output:{dims:G,type:H.type,textureType:0},shaderSource:J}},i9=(Q)=>{if(!Q||Q.length!==1)throw new Error("Split requires one input.");if(Q[0].type!=="int8"&&Q[0].type!=="uint8"&&Q[0].type!=="int16"&&Q[0].type!=="uint16"&&Q[0].type!=="int32"&&Q[0].type!=="uint32"&&Q[0].type!=="float32"&&Q[0].type!=="float64"&&Q[0].type!=="bool")throw new Error("Invalid input type.")}}),h6,VJ,XJ,o9,a9,lj=E(()=>{Q1(),h6=(Q,H,j)=>{o9(H);let K=u.squeezeShape(H[0].dims,j);return[Q.reshapeUnpacked(H[0],K)]},VJ=(Q,H)=>(a9(H),h6(Q,[H[0]],Array.from(H[1].integerData))),XJ=(Q)=>Q.attributes.getInts("axes"),o9=(Q)=>{if(!Q||Q.length!==1)throw new Error("Squeeze requires 1 input.");if(Q[0].type==="string")throw new Error("invalid input tensor types.")},a9=(Q)=>{if(!Q||Q.length!==2)throw new Error("Squeeze requires 2 inputs.");if(Q[1].type!=="int32")throw new Error("Invalid input type.")}}),KJ,n9,r9,uj=E(()=>{W1(),t(),KJ=(Q,H)=>{r9(H);let j={name:"Sum",inputNames:H.map((K,W)=>`X${W}`),inputTypes:new Array(H.length).fill(0)};return[Q.run({...j,get:()=>n9(Q,H,j)},H)]},n9=(Q,H,j)=>{let K=r(Q.session.backend.glContext.version),W=H[0].dims.slice(),U=`
+      void main() {
+        vec4 result = ${H.map((Z,q)=>`${K.texture2D}(X${q},TexCoords)`).join(" + ")};
+        ${K.output} = result;
+      }
+    `;return{...j,output:{dims:W,type:H[0].type,textureType:0},hasMain:!0,shaderSource:U}},r9=(Q)=>{if(!Q||Q.length===0)throw new Error("Sum requires inputs.");let H=Q[0].dims.length;for(let j=1;j<Q.length;j++){if(H!==Q[j].dims.length)throw new Error("Input shapes are mismatched.");for(let K=0;K<H;K++)if(Q[0].dims[K]!==Q[j].dims[K])throw new Error("Input shapes are not matched.")}if(Q[0].type!=="float32"&&Q[0].type!=="float64")throw new Error("Invalid input type.");for(let j=1;j<Q.length;j++)if(Q[0].type!==Q[j].type)throw new Error("Input types are not matched.")}}),UJ,t9,e9,sj=E(()=>{k5(),t(),UJ=(Q,H)=>{e9(H);let j={name:"Tile",inputNames:["A"],inputTypes:[0]};return[Q.run({...j,get:()=>t9(Q,H,j)},H)]},t9=(Q,H,j)=>{let K=H[0].dims.slice(),W=new Array(K.length),U=[];for(let G=0;G<K.length;G++)W[G]=K[G]*H[1].numberData[G],U.push(`inputIdx[${G}] = int(mod(float(outputIdx[${G}]), ${K[G]}.));`);let Z=W.length,q=`
+      float process(int outputIdx[${Z}]) {
+        int inputIdx[${Z}];
+        ${U.join(`
+`)}
+        return _A(inputIdx);
+      }
+    `;return{...j,output:{dims:W,type:H[0].type,textureType:0},shaderSource:q}},e9=(Q)=>{if(!Q||Q.length!==2)throw new Error("Tile requires 2 input.");if(Q[1].dims.length!==1)throw new Error("The second input shape must 1 dimension.");if(Q[1].dims[0]!==Q[0].dims.length)throw new Error("Invalid input shape.");if(u4.indexOf(Q[0].type)===-1)throw new Error("Invalid input type.");if(Q[1].type!=="int32"&&Q[1].type!=="int16")throw new Error("Invalid repeat type.")}}),b6,qJ,WJ,Q2,J2,ij=E(()=>{Q1(),b6=(Q,H,j)=>{Q2(H);let K=u.unsqueezeShape(H[0].dims,j);return[Q.reshapeUnpacked(H[0],K)]},qJ=(Q,H)=>(J2(H),b6(Q,[H[0]],Array.from(H[1].integerData))),WJ=(Q)=>Q.attributes.getInts("axes"),Q2=(Q)=>{if(!Q||Q.length!==1)throw new Error("Unsqueeze requires 1 input.");if(Q[0].type==="string")throw new Error("invalid input tensor types.")},J2=(Q)=>{if(!Q||Q.length!==2)throw new Error("Unsqueeze requires 2 inputs.");if(Q[1].type!=="int32")throw new Error("Invalid input type.")}}),GJ,oj=E(()=>{Bj(),Fj(),kj(),Sj(),V7(),Tj(),Dj(),_j(),Pj(),Ej(),Ij(),xj(),Oj(),Z7(),gj(),yj(),dj(),pj(),hj(),bj(),mj(),cj(),fj(),lj(),uj(),sj(),X7(),t0(),ij(),sQ(),GJ=[["Abs","","6+",_0],["Acos","","7+",P0],["Add","","7+",R0],["And","","7+",z0],["Asin","","7+",E0],["Atan","","7+",I0],["AveragePool","","7+",_Q,PQ],["BatchNormalization","","7+",U0,q0],["Cast","","6+",L0,v0],["Ceil","","6+",g0],["Clip","","6-10",_6,x0],["Clip","","11+",O0],["Concat","","4+",T0,D0],["Conv","","1+",I6,x6],["ConvTranspose","","1+",qQ,WQ],["Cos","","7+",y0],["Div","","7+",N0],["Dropout","","7+",P6],["DepthToSpace","","1+",RQ,zQ],["Equal","","7+",M0],["Elu","","6+",d0,p0],["Exp","","6+",h0],["Flatten","","1+",NQ,MQ],["Floor","","6+",b0],["FusedConv","com.microsoft","1+",I6,x6],["Gather","","1+",YQ,CQ],["Gemm","","7-10",O6,BQ],["Gemm","","11+",O6,FQ],["GlobalAveragePool","","1+",EQ,IQ],["GlobalMaxPool","","1+",gQ],["Greater","","7+",Y0],["Identity","","1+",P6],["ImageScaler","","1+",kQ,AQ],["InstanceNormalization","","6+",SQ,$Q],["LeakyRelu","","6+",m0,c0],["Less","","7+",C0],["LRN","","1+",LQ,vQ],["Log","","6+",f0],["MatMul","","1+",JQ,HQ],["MaxPool","","1+",xQ,OQ],["Mul","","7+",B0],["Neg","","6+",l0],["Not","","1+",u0],["Or","","7+",F0],["Pad","","2-10",g6,wQ],["Pad","","11+",TQ,DQ],["Pow","","7+",k0],["PRelu","","7+",A0],["ReduceLogSum","","1+",mQ,D3],["ReduceMax","","1+",pQ,D3],["ReduceMean","","1+",dQ,D3],["ReduceMin","","1+",hQ,D3],["ReduceProd","","1+",bQ,D3],["ReduceSum","","1-12",yQ,D3],["ReduceSumSquare","","1+",cQ,D3],["Relu","","6+",s0],["Reshape","","5+",fQ],["Resize","","10",p6,iQ],["Resize","","11+",p6,oQ],["Shape","","1+",aQ],["Sigmoid","","6+",i0],["Sin","","7+",o0],["Slice","","10+",tQ],["Slice","","1-9",nQ,rQ],["Softmax","","1-12",eQ,QJ],["Softmax","","13+",HJ,JJ],["Split","","2-12",ZJ,jJ],["Sqrt","","6+",a0],["Squeeze","","1-12",h6,XJ],["Squeeze","","13+",VJ],["Sub","","7+",S0],["Sum","","6+",KJ],["Tan","","7+",n0],["Tanh","","6+",r0],["Tile","","6+",UJ],["Transpose","","1+",m4,GQ],["Upsample","","7-8",y6,lQ],["Upsample","","9",y6,uQ],["Unsqueeze","","1-12",b6,WJ],["Unsqueeze","","13+",qJ],["Xor","","7+",$0]]}),m6,RJ,aj=E(()=>{m6=/@inline[\s\n\r]+(\w+)[\s\n\r]+([0-9a-zA-Z_]+)\s*\(([^)]*)\)\s*{(([^}]|[\n\r])*)}/gm,RJ="(\\w+)?\\s+([_0-9a-zA-Z]+)\\s+=\\s+__FUNC__\\((.*)\\)\\s*;"}),zJ,NJ=E(()=>{V3(),Q1(),zJ=class{constructor(Q){this.maxTextureSize=Q}computeTextureWH(Q,H){let j=this.computeTexture(Q,H);return H&&H.isPacked&&(j[0]/=2,j[1]/=2),H&&H.reverseWH?[j[1],j[0]]:j}computeTexture(Q,H){let j=H&&H.isPacked;if(Q.length===0)return j?[2,2]:[1,1];let K=this.maxTextureSize;if(H&&H.breakAxis!==void 0){let Z=H.breakAxis>=Q.length?1:Q.slice(H.breakAxis).reduce((G,J)=>G*J),q=H.breakAxis<=0?1:Q.slice(0,H.breakAxis).reduce((G,J)=>G*J);if(Z>K||q>K)C1.verbose("TextureLayout",`Given width/height preferences were unattainable: shape:${Q}, breakAxis:${H.breakAxis}`);else return[Z,q]}let W=Q.slice(0);j&&(K=K*2,W=W.map((Z,q)=>q>=W.length-2?W[q]%2===0?W[q]:W[q]+1:W[q]),W.length===1&&(W=[2,W[0]])),W.length!==2&&(W=E4(W).newShape);let U=$Z(W);return W.length<=1&&U<=K?[1,U]:W.length===2&&W[0]<=K&&W[1]<=K?W:W.length===3&&W[0]*W[1]<=K&&W[2]<=K?[W[0]*W[1],W[2]]:W.length===3&&W[0]<=K&&W[1]*W[2]<=K?[W[0],W[1]*W[2]]:W.length===4&&W[0]*W[1]*W[2]<=K&&W[3]<=K?[W[0]*W[1]*W[2],W[3]]:W.length===4&&W[0]<=K&&W[1]*W[2]*W[3]<=K?[W[0],W[1]*W[2]*W[3]]:j?i7(U/4).map((Z)=>Z*2):i7(U)}}}),MJ,nj=E(()=>{Q1(),E3(),W1(),NJ(),F3(),MJ=class extends q4{constructor(Q){super(Q)}getFunctions(){return{...this.offsetToCoords(),...this.coordsToOffset(),...this.toVec(),...this.valueFrom(),...this.getCommonUtilFuncs(),...this.getInputsSamplingSnippets(),...this.getOutputSamplingSnippet()}}getCustomTypes(){return{}}offsetToCoords(){return{offsetToCoords:new y(`
+      vec2 ${"offsetToCoords"}(int offset, int width, int height) {
+        int t = offset / width;
+        int s = offset - t*width;
+        vec2 coords = (vec2(s,t) + vec2(0.5,0.5)) / vec2(width, height);
+        return coords;
+      }
+      `)}}coordsToOffset(){return{coordsToOffset:new y(`
+      int ${"coordsToOffset"}(vec2 coords, int width, int height) {
+        float s = coords.s * float(width);
+        float t = coords.t * float(height);
+        int offset = int(t) * width + int(s);
+        return offset;
+      }
+      `)}}getOutputSamplingSnippet(){let Q=this.context.outputTextureLayout;return Q.isPacked?this.getPackedOutputSamplingSnippet(Q):this.getUnpackedOutputSamplingSnippet(Q)}getPackedOutputSamplingSnippet(Q){let H=Q.unpackedShape,j=[Q.width,Q.height],K={},W="getOutputCoords";switch(H.length){case 0:K[W]=this.getOutputScalarCoords();break;case 1:K[W]=this.getOutputPacked1DCoords(H,j);break;case 2:K[W]=this.getOutputPacked2DCoords(H,j);break;case 3:K[W]=this.getOutputPacked3DCoords(H,j);break;default:K[W]=this.getOutputPackedNDCoords(H,j)}let U=`
+      void setOutput(vec4 val) {
+        ${r(this.context.glContext.version).output} = val;
+      }
+    `,Z="floatTextureSetRGBA";return K[Z]=new y(U),K}getUnpackedOutputSamplingSnippet(Q){let H=Q.unpackedShape,j=[Q.width,Q.height],K={},W="getOutputCoords";switch(H.length){case 0:K[W]=this.getOutputScalarCoords();break;case 1:K[W]=this.getOutputUnpacked1DCoords(H,j);break;case 2:K[W]=this.getOutputUnpacked2DCoords(H,j);break;case 3:K[W]=this.getOutputUnpacked3DCoords(H,j);break;case 4:K[W]=this.getOutputUnpacked4DCoords(H,j);break;case 5:K[W]=this.getOutputUnpacked5DCoords(H,j);break;case 6:K[W]=this.getOutputUnpacked6DCoords(H,j);break;default:throw new Error(`Unsupported output dimensionality: ${H.length}`)}let U=`
+        void setOutput(float val) {
+          ${r(this.context.glContext.version).output} = vec4(val, 0, 0, 0);
+        }
+    `,Z="floatTextureSetR";return K[Z]=new y(U),K}getOutputScalarCoords(){return new y(`
+      int getOutputCoords() {
+        return 0;
+      }
+    `)}getOutputPacked1DCoords(Q,H){let j=H,K="";return j[0]===1?(K=`
+          int getOutputCoords() {
+            return 2 * int(TexCoords.y * ${j[1]}.0);
+          }
+        `,new y(K)):j[1]===1?(K=`
+          int getOutputCoords() {
+            return 2 * int(TexCoords.x * ${j[0]}.0);
+          }
+        `,new y(K)):(K=`
+        int getOutputCoords() {
+          ivec2 resTexRC = ivec2(TexCoords.xy *
+                                 vec2(${j[0]}, ${j[1]}));
+          return 2 * (resTexRC.y * ${j[0]} + resTexRC.x);
+        }
+      `,new y(K))}getOutputPacked2DCoords(Q,H){let j="";if(x4.arraysEqual(Q,H))return j=`
+        ivec2 getOutputCoords() {
+          return 2 * ivec2(TexCoords.xy * vec2(${H[0]}, ${H[1]}));
+        }
+      `,new y(j);let K=H,W=Math.ceil(Q[1]/2);return j=`
+        ivec2 getOutputCoords() {
+          ivec2 resTexRC = ivec2(TexCoords.xy *
+                                vec2(${K[0]}, ${K[1]}));
+
+          int index = resTexRC.y * ${K[0]} + resTexRC.x;
+
+          // reverse r and c order for packed texture
+          int r = imod(index, ${W}) * 2;
+          int c = 2 * (index / ${W});
+
+          return ivec2(r, c);
+        }
+      `,new y(j)}getOutputPacked3DCoords(Q,H){let j=[H[0],H[1]],K=Math.ceil(Q[2]/2),W=K*Math.ceil(Q[1]/2),U=`
+        ivec3 getOutputCoords() {
+          ivec2 resTexRC = ivec2(TexCoords.xy *
+                                vec2(${j[0]}, ${j[1]}));
+          int index = resTexRC.y * ${j[0]} + resTexRC.x;
+
+          int b = index / ${W};
+          index -= b * ${W};
+
+          // reverse r and c order for packed texture
+          int r = imod(index, ${K}) * 2;
+          int c = 2 * (index / ${K});
+
+          return ivec3(b, r, c);
+        }
+      `;return new y(U)}getOutputPackedNDCoords(Q,H){let j=[H[0],H[1]],K=Math.ceil(Q[Q.length-1]/2),W=K*Math.ceil(Q[Q.length-2]/2),U=W,Z="",q="b, r, c";for(let J=2;J<Q.length-1;J++)U*=Q[Q.length-J-1],Z=`
+      int b${J} = index / ${U};
+      index -= b${J} * ${U};
+    `+Z,q=`b${J}, `+q;let G=`
+      ivec${Q.length} getOutputCoords() {
+        ivec2 resTexRC = ivec2(TexCoords.xy *
+                              vec2(${j[0]}, ${j[1]}));
+        int index = resTexRC.y * ${j[0]} + resTexRC.x;
+
+        ${Z}
+
+        int b = index / ${W};
+        index -= b * ${W};
+
+        // reverse r and c order for packed texture
+        int r = imod(index, ${K}) * 2;
+        int c = 2 * (index / ${K});
+
+        return ivec${Q.length}(${q});
+      }
+    `;return new y(G)}getOutputUnpacked1DCoords(Q,H){let j=`
+        int getOutputCoords() {
+          ivec2 resTexRC = ivec2(TexCoords.xy *
+                                vec2(${H[0]}, ${H[1]}));
+          return resTexRC.y * ${H[0]} + resTexRC.x;
+        }
+      `;return new y(j)}getOutputUnpacked2DCoords(Q,H){let j=`
+        ivec2 getOutputCoords() {
+          ivec2 resTexRC = ivec2(TexCoords.xy *
+                                vec2(${H[0]}, ${H[1]}));
+          int index = resTexRC.y * ${H[0]} + resTexRC.x;
+          int r = index / ${Q[1]};
+          int c = index - r * ${Q[1]};
+          return ivec2(r, c);
+        }
+      `;return new y(j)}getOutputUnpacked3DCoords(Q,H){let j="",K=Q.length,W=null;K<2&&(W=[]),W=new Array(K-1),W[K-2]=Q[K-1];for(let q=K-3;q>=0;--q)W[q]=W[q+1]*Q[q+1];let U=["r","c","d"],Z=W.map((q,G)=>{let J=`int ${U[G]} = index / ${q}`,X=G===W.length-1?`int ${U[G+1]} = index - ${U[G]} * ${q}`:`index -= ${U[G]} * ${q}`;return`${J}; ${X};`}).join("");return j=`
+        ivec3 getOutputCoords() {
+          ivec2 resTexRC = ivec2(TexCoords.xy *
+                                vec2(${H[0]}, ${H[1]}));
+          int index = resTexRC.y * ${H[0]} + resTexRC.x;
+          ${Z}
+          return ivec3(r, c, d);
+        }
+      `,new y(j)}getOutputUnpacked4DCoords(Q,H){let j="",K=Q.length,W=null;K<2&&(W=[]),W=new Array(K-1),W[K-2]=Q[K-1];for(let q=K-3;q>=0;--q)W[q]=W[q+1]*Q[q+1];let U=["r","c","d","d2"],Z=W.map((q,G)=>{let J=`int ${U[G]} = index / ${q}`,X=G===W.length-1?`int ${U[G+1]} = index - ${U[G]} * ${q}`:`index -= ${U[G]} * ${q}`;return`${J}; ${X};`}).join("");return j=`
+      ivec4 getOutputCoords() {
+          ivec2 resTexRC = ivec2(TexCoords.xy *
+                                vec2(${H[0]}, ${H[1]}));
+          int index = resTexRC.y * ${H[0]} + resTexRC.x;
+          ${Z}
+          return ivec4(r, c, d, d2);
+        }
+      `,new y(j)}getOutputUnpacked5DCoords(Q,H){let j="",K=Q.length,W=null;K<2&&(W=[]),W=new Array(K-1),W[K-2]=Q[K-1];for(let q=K-3;q>=0;--q)W[q]=W[q+1]*Q[q+1];let U=["r","c","d","d2","d3"],Z=W.map((q,G)=>{let J=`int ${U[G]} = index / ${q}`,X=G===W.length-1?`int ${U[G+1]} = index - ${U[G]} * ${q}`:`index -= ${U[G]} * ${q}`;return`${J}; ${X};`}).join("");return j=`
+      ivec5 getOutputCoords() {
+          ivec2 resTexRC = ivec2(TexCoords.xy *
+                                vec2(${H[0]}, ${H[1]}));
+          int index = resTexRC.y * ${H[0]} + resTexRC.x;
+          ${Z}
+          return ivec5(r, c, d, d2, d3);
+        }
+      `,new y(j)}getOutputUnpacked6DCoords(Q,H){let j="",K=Q.length,W=null;K<2&&(W=[]),W=new Array(K-1),W[K-2]=Q[K-1];for(let q=K-3;q>=0;--q)W[q]=W[q+1]*Q[q+1];let U=["r","c","d","d2","d3","d4"],Z=W.map((q,G)=>{let J=`int ${U[G]} = index / ${q}`,X=G===W.length-1?`int ${U[G+1]} = index - ${U[G]} * ${q}`:`index -= ${U[G]} * ${q}`;return`${J}; ${X};`}).join("");return j=`
+     ivec6 getOutputCoords() {
+         ivec2 resTexRC = ivec2(TexCoords.xy *
+                               vec2(${H[0]}, ${H[1]}));
+         int index = resTexRC.y * ${H[0]} + resTexRC.x;
+         ${Z}
+         return ivec6(r, c, d, d2, d3, d4);
+       }
+     `,new y(j)}getCommonUtilFuncs(){let Q={},H="uvFromFlat";Q[H]=new y(`
+    vec2 uvFromFlat(int texNumR, int texNumC, int index) {
+      int texC = index / texNumR;
+      int texR = index - texC * texNumR;
+      // TODO: swap texR, texC order in following function so row is corresponding to u and column is corresponding to
+      //       v.
+      return (vec2(texR, texC) + halfCR) / vec2(texNumR, texNumC);
+    }
+    `),H="packedUVfrom1D",Q[H]=new y(`
+      vec2 packedUVfrom1D(int texNumR, int texNumC, int index) {
+        int texelIndex = index / 2;
+        int texR = texelIndex / texNumC;
+        int texC = texelIndex - texR * texNumC;
+        return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);
+      }
+      `),H="packedUVfrom2D",Q[H]=new y(`
+      vec2 packedUVfrom2D(int texNumR, int texNumC, int texelsInLogicalRow, int row, int col) {
+        int texelIndex = (row / 2) * texelsInLogicalRow + (col / 2);
+        int texR = texelIndex / texNumC;
+        int texC = texelIndex - texR * texNumC;
+        return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);
+      }
+      `),H="packedUVfrom3D",Q[H]=new y(`
+      vec2 packedUVfrom3D(int texNumR, int texNumC,
+          int texelsInBatch, int texelsInLogicalRow, int b,
+          int row, int col) {
+        int index = b * texelsInBatch + (row / 2) * texelsInLogicalRow + (col / 2);
+        int texR = index / texNumC;
+        int texC = index - texR * texNumC;
+        return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);
+      }
+      `),H="sampleTexture";let j=r(this.context.glContext.version);return Q[H]=new y(`
+        float sampleTexture(sampler2D textureSampler, vec2 uv) {
+            return ${j.texture2D}(textureSampler, uv).r;
+        }`),Q}getInputsSamplingSnippets(){let Q={},H=this.context.outputTextureLayout;return this.context.programInfo.inputNames.forEach((j,K)=>{let W=this.context.inputTextureLayouts[K],U=P5(j);W.isPacked?Q[U]=this.getPackedSamplerFromInput(U,j,W):Q[U]=this.getUnpackedSamplerFromInput(U,j,W);let Z=DH(j);W.unpackedShape.length<=H.unpackedShape.length&&(W.isPacked?Q[Z]=this.getPackedSamplerAtOutputCoords(Z,W,H,j):Q[Z]=this.getUnpackedSamplerAtOutputCoords(Z,W,H,j))}),Q}getPackedSamplerAtOutputCoords(Q,H,j,K){let W=H.unpackedShape,U=j.unpackedShape,Z=P5(K),q=W.length,G=U.length,J=R3.getBroadcastDims(W,U),X=P3(G),V=G-q,R,z=H4();q===0?R="":G<2&&J.length>=1?R="coords = 0;":R=J.map((I)=>`coords.${z[I+V]} = 0;`).join(`
+`);let Y="";G<2&&q>0?Y="coords":Y=W.map((I,h)=>`coords.${z[h+V]}`).join(", ");let B="return outputValue;",k=u.size(W)===1,w=u.size(U)===1;if(q===1&&!k&&!w)B=`
+        return vec4(outputValue.xy, outputValue.xy);
+      `;else if(k&&!w)G===1?B=`
+          return vec4(outputValue.x, outputValue.x, 0., 0.);
+        `:B=`
+          return vec4(outputValue.x);
+        `;else if(J.length){let I=q-2,h=q-1;J.indexOf(I)>-1&&J.indexOf(h)>-1?B="return vec4(outputValue.x);":J.indexOf(I)>-1?B="return vec4(outputValue.x, outputValue.y, outputValue.x, outputValue.y);":J.indexOf(h)>-1&&(B="return vec4(outputValue.xx, outputValue.zz);")}let A=`
+        int lastDim = coords.${z[G-1]};
+        coords.${z[G-1]} = coords.${z[G-2]};
+        coords.${z[G-2]} = lastDim;
+      `,D=`
+      vec4 ${Q}() {
+        ${X} coords = getOutputCoords();
+        ${A}
+        ${R}
+        vec4 outputValue = ${Z}(${Y});
+        ${B}
+      }
+    `;return new y(D,["coordinates.getOutputCoords"])}getUnpackedSamplerAtOutputCoords(Q,H,j,K){let W=[j.width,j.height],U=[H.width,H.height],Z=H.unpackedShape.length,q=j.unpackedShape.length,G=H.unpackedShape,J=j.unpackedShape,X=P5(K);if(Z===q&&x4.arraysEqual(U,W)){let A=`
+          float ${Q}() {
+            return sampleTexture(${K}, TexCoords);
+          }
+        `;return new y(A,["coordinates.sampleTexture"])}let V=P3(q),R=R3.getBroadcastDims(G,J),z=q-Z,Y,B=H4();Z===0?Y="":q<2&&R.length>=1?Y="coords = 0;":Y=R.map((A)=>`coords.${B[A+z]} = 0;`).join(`
+`);let k="";q<2&&Z>0?k="coords":k=H.unpackedShape.map((A,D)=>`coords.${B[D+z]}`).join(", ");let w=`
+        float ${Q}() {
+          ${V} coords = getOutputCoords();
+          ${Y}
+          return ${X}(${k});
+        }
+      `;return new y(w,["coordinates.getOutputCoords"])}getPackedSamplerFromInput(Q,H,j){switch(j.unpackedShape.length){case 0:return this.getPackedSamplerScalar(Q,H);case 1:return this.getPackedSampler1D(Q,H,j);case 2:return this.getPackedSampler2D(Q,H,j);case 3:return this.getPackedSampler3D(Q,H,j);default:return this.getPackedSamplerND(Q,H,j)}}getUnpackedSamplerFromInput(Q,H,j){let K=j.unpackedShape;switch(K.length){case 0:return this.getUnpackedSamplerScalar(Q,H,j);case 1:return this.getUnpackedSampler1D(Q,H,j);case 2:return this.getUnpackedSampler2D(Q,H,j);case 3:return this.getUnpackedSampler3D(Q,H,j);case 4:return this.getUnpackedSampler4D(Q,H,j);case 5:return this.getUnpackedSampler5D(Q,H,j);case 6:return this.getUnpackedSampler6D(Q,H,j);default:throw new Error(`Unsupported dimension ${K.length}-D`)}}getPackedSamplerScalar(Q,H){let j=r(this.context.glContext.version),K=`
+          vec4 ${Q}() {
+            return ${j.texture2D}(${H}, halfCR);
+          }
+        `;return new y(K)}getPackedSampler1D(Q,H,j){let K=[j.width,j.height],W=[K[1],K[0]],U=r(this.context.glContext.version),Z=`vec4 ${Q}(int index) {
+      vec2 uv = packedUVfrom1D(
+      ${W[0]}, ${W[1]}, index);
+      return ${U.texture2D}(${H}, uv);
+    }`;return new y(Z,["coordinates.packedUVfrom1D"])}getPackedSampler2D(Q,H,j){let K=j.unpackedShape,W=[j.width,j.height],U=r(this.context.glContext.version),Z=W[0],q=W[1];if(W!=null&&x4.arraysEqual(K,W)){let V=`vec4 ${Q}(int row, int col) {
+        vec2 uv = (vec2(col, row) + halfCR) / vec2(${q}.0, ${Z}.0);
+        return ${U.texture2D}(${H}, uv);
+      }`;return new y(V)}let G=W,J=Math.ceil(K[1]/2),X=`vec4 ${Q}(int row, int col) {
+      vec2 uv = packedUVfrom2D(${G[1]}, ${G[0]}, ${J}, row, col);
+      return ${U.texture2D}(${H}, uv);
+    }`;return new y(X,["coordinates.packedUVfrom2D"])}getPackedSampler3D(Q,H,j){let K=j.unpackedShape,W=[j.width,j.height],U=[W[0],W[1]],Z=r(this.context.glContext.version);if(K[0]===1){let R=K.slice(1),z=[1,2],Y=F4(K,R),B=["b","row","col"],k=JSON.parse(JSON.stringify(j));k.unpackedShape=Y;let w=this.getPackedSamplerFromInput(Q,H,k),A=`${w.routineBody}
+      vec4 ${Q}(int b, int row, int col) {
+        return ${Q}(${k4(B,z)});
+      } `;return new y(A,w.dependencies)}let q=U[0],G=U[1],J=Math.ceil(K[2]/2),X=J*Math.ceil(K[1]/2),V=`vec4 ${Q}(int b, int row, int col) {
+      vec2 uv = packedUVfrom3D(
+        ${G}, ${q}, ${X}, ${J}, b, row, col);
+      return ${Z.texture2D}(${H}, uv);}`;return new y(V,["coordinates.packedUVfrom3D"])}getPackedSamplerND(Q,H,j){let K=j.unpackedShape,W=K.length,U=[j.width,j.height],Z=r(this.context.glContext.version),q=[U[0],U[1]],G=q[1],J=q[0],X=Math.ceil(K[W-1]/2),V=X*Math.ceil(K[W-2]/2),R="int b, int row, int col",z=`b * ${V} + (row / 2) * ${X} + (col / 2)`;for(let B=2;B<W-1;B++)R=`int b${B}, `+R,V*=K[W-B-1],z=`b${B} * ${V} + `+z;let Y=`vec4 ${Q}(${R}) {
+      int index = ${z};
+      int texR = index / ${J};
+      int texC = index - texR * ${J};
+      vec2 uv = (vec2(texC, texR) + halfCR) / vec2(${J}, ${G});
+      return ${Z.texture2D}(${H}, uv);
+    }`;return new y(Y)}getUnpackedSamplerScalar(Q,H,j){let[K,W]=[j.width,j.height];if(K===1&&W===1){let Z=`
+          float ${Q}() {
+            return sampleTexture(${H}, halfCR);
+          }
+        `;return new y(Z,["coordinates.sampleTexture"])}let U=`
+        float ${Q}() {
+          int offset_${H} = coordsToOffset(TexCoords, ${K}, ${W});
+          vec2 uv = uvFromFlat(${K}, ${W}, offset_${H});
+          return sampleTexture(${H}, uv);
+        }
+      `;return new y(U,["coordinates.uvFromFlat","coordinates.sampleTexture","coordinates.coordsToOffset"])}getUnpackedSampler1D(Q,H,j){let{width:K,height:W}=j;if(W===1&&K===1){let Z=`
+        float ${Q}(int index) {
+          return sampleTexture(${H}, halfCR);
+        }
+      `;return new y(Z,["coordinates.sampleTexture"])}if(W===1){let Z=`
+          float ${Q}(int index) {
+            vec2 uv = vec2((float(index) + 0.5) / ${K}.0, 0.5);
+            return sampleTexture(${H}, uv);
+          }
+        `;return new y(Z,["coordinates.sampleTexture"])}if(K===1){let Z=`
+          float ${Q}(int index) {
+            vec2 uv = vec2(0.5, (float(index) + 0.5) / ${W}.0);
+            return sampleTexture(${H}, uv);
+          }
+        `;return new y(Z,["coordinates.sampleTexture"])}let U=`
+        float ${Q}(int index) {
+          vec2 uv = uvFromFlat(${K}, ${W}, index);
+          return sampleTexture(${H}, uv);
+        }
+      `;return new y(U,["coordinates.uvFromFlat","coordinates.sampleTexture"])}getUnpackedSampler2D(Q,H,j){let K=j.unpackedShape,W=[j.height,j.width];if(W!=null&&x4.arraysEqual(K,W)){let V=W[1],R=W[0],z=`
+          float ${Q}(int row, int col) {
+            vec2 uv = (vec2(row, col) + halfCR) / vec2(${V}.0, ${R}.0);
+            return sampleTexture(${H}, uv);
+          }
+        `;return new y(z,["coordinates.sampleTexture"])}let{newShape:U,keptDims:Z}=E4(K),q=U;if(q.length<K.length){let V=F4(K,q),R=JSON.parse(JSON.stringify(j));R.unpackedShape=V;let z=["col","row"],Y=`
+          ${this.getUnpackedSamplerFromInput(Q,H,R).routineBody}
+          float ${Q}(int row, int col) {
+            return ${Q}(${k4(z,Z)});
+          }
+        `;return new y(Y,["coordinates.sampleTexture"])}let G=W[1],J=W[0];if(J===1){let V=`
+          float ${Q}(int row, int col) {
+            int offset_${H} = coordsToOffset(TexCoords, ${G}, ${J});
+            float index = dot(vec3(row, col, offset_${H}), vec3(${K[1]}, 1, 1));
+            vec2 uv = vec2(0.5, (index + 0.5) / ${G}.0);
+            return sampleTexture(${H}, uv);
+          }
+        `;return new y(V,["coordinates.sampleTexture","coordinates.coordsToOffset"])}if(G===1){let V=`
+          float ${Q}(int row, int col) {
+            int offset_${H} = coordsToOffset(TexCoords, ${G}, ${J});
+            float index = dot(vec3(row, col, offset_${H}), vec3(${K[1]}, 1, 1));
+            vec2 uv = vec2((index + 0.5) / ${J}.0, 0.5);
+            return sampleTexture(${H}, uv);
+          }
+        `;return new y(V,["coordinates.sampleTexture","coordinates.coordsToOffset"])}let X=`
+        float ${Q}(int row, int col) {
+          int index = col * ${K[1]} + row;
+          vec2 uv = uvFromFlat(${G}, ${J}, index);
+          return sampleTexture(${H}, uv);
+        }
+      `;return new y(X,["coordinates.uvFromFlat","coordinates.sampleTexture","coordinates.coordsToOffset"])}getUnpackedSampler3D(Q,H,j){let K=j.unpackedShape,W=K[1]*K[2],U=K[2],{newShape:Z,keptDims:q}=E4(K),G=Z;if(G.length<K.length){let R=F4(K,G),z=["batch","col","row"],Y=JSON.parse(JSON.stringify(j));Y.unpackedShape=R;let B=this.getUnpackedSamplerFromInput(Q,H,Y),k=q.reverse(),w=`
+          ${B.routineBody}
+          float ${Q}(int batch, int row, int col) {
+            return ${Q}(${k4(z,k)});
+          }
+        `;return new y(w,B.dependencies)}let{width:J,height:X}=j,V=`
+          float ${Q}(int depth, int row, int col) {
+            // Explicitly use integer operations as dot() only works on floats.
+            int index = depth * ${W} + col * ${U} + row;
+            vec2 uv = uvFromFlat(${J}, ${X}, index);
+            return sampleTexture(${H}, uv);
+          }
+      `;return new y(V,["coordinates.uvFromFlat","coordinates.sampleTexture","coordinates.coordsToOffset"])}getUnpackedSampler4D(Q,H,j){let K=j.unpackedShape,W=K[3],U=K[2]*W,Z=K[1]*U,q=j.width,G=j.height,J=`
+        float ${Q}(int row, int col, int depth, int depth2) {
+          int index = row * ${Z} + col * ${U} +
+              depth2 * ${W} + depth;
+          vec2 uv = uvFromFlat(${q}, ${G}, index);
+          return sampleTexture(${H}, uv);
+        }
+      `;return new y(J,["coordinates.uvFromFlat","coordinates.sampleTexture"])}getUnpackedSampler5D(Q,H,j){let K=j.unpackedShape,W=K[4],U=K[3]*W,Z=K[2]*U,q=K[1]*Z,{newShape:G,keptDims:J}=E4(K);if(G.length<K.length){let z=F4(K,G),Y=["row","col","depth","depth2","depth3"],B=JSON.parse(JSON.stringify(j));B.unpackedShape=z;let k=`
+          ${this.getUnpackedSamplerFromInput(Q,H,B).routineBody}
+          float ${Q}(int row, int col, int depth, int depth2, int depth3) {
+            return ${Q}(${k4(Y,J)});
+          }
+        `;return new y(k,["coordinates.sampleTexture","coordinates.uvFromFlat"])}let{width:X,height:V}=j,R=`
+        float ${Q}(int row, int col, int depth, int depth2, int depth3) {
+          int index = row * ${q} + col * ${Z} + depth * ${U} +
+          depth3 * ${W} + depth2;
+          vec2 uv = uvFromFlat(${X}, ${V}, index);
+          return sampleTexture(${H}, uv);
+        }
+      `;return new y(R,["coordinates.sampleTexture","coordinates.uvFromFlat"])}getUnpackedSampler6D(Q,H,j){let K=j.unpackedShape,W=K[5],U=K[4]*W,Z=K[3]*U,q=K[2]*Z,G=K[1]*q,{newShape:J,keptDims:X}=E4(K);if(J.length<K.length){let Y=F4(K,J),B=["row","col","depth","depth2","depth3","depth4"],k=JSON.parse(JSON.stringify(j));k.unpackedShape=Y;let w=`
+            ${this.getUnpackedSamplerFromInput(Q,H,k).routineBody}
+            float ${Q}(int row, int col, int depth,
+              int depth2, int depth3, int depth4) {
+              return ${Q}(${k4(B,X)});
+            }
+          `;return new y(w,["coordinates.sampleTexture","coordinates.uvFromFlat"])}let{width:V,height:R}=j,z=`
+          float ${Q}(int row, int col, int depth,
+            int depth2, int depth3, int depth4) {
+            int index = row * ${G} + col * ${q} + depth * ${Z} +
+            depth2 * ${U} + depth3 * ${W} + depth4;
+            vec2 uv = uvFromFlat(${V}, ${R}, index);
+            return sampleTexture(${H}, uv);
+          }
+        `;return new y(z,["coordinates.uvFromFlat","coordinates.sampleTexture","coordinates.coordsToOffset"])}toVec(){let Q=this.context.outputTextureLayout,H=Q.shape.length,j=Q.strides,K=Q.width,W=Q.height,U=[];for(let q=0;q<H-1;++q)U.push(`
+        c[${q}] = offset / ${j[q]};`),U.push(`
+        offset -= c[${q}] * ${j[q]};`);U.push(`
+        c[${H-1}] = offset;`);let Z=`
+      void toVec(vec2 texCoords, out int c[${H}]) {
+        int offset = coordsToOffset(texCoords, ${K}, ${W});
+        ${U.join("")}
+      }
+      void toVec(int offset, out int c[${H}]) {
+        ${U.join("")}
+      }
+    `;return{toVec:new y(Z,["coordinates.coordsToOffset"])}}valueFrom(){let Q={};return this.context.programInfo.inputNames.forEach((H,j)=>{let K=this.context.inputTextureLayouts[j],W=(K.unpackedShape.length>0?K.unpackedShape:K.shape).length,U=`_${H}`;Q[U]=new y(this.getValueFromSingle(H,W,K.width,K.height,!1),[`shapeUtils.indicesToOffset${U}`,"coordinates.offsetToCoords","fragcolor.getColorAsFloat"]),U=U+"_T",Q[U]=new y(this.getValueFromSingle(H,W,K.width,K.height,!0),[`shapeUtils.indicesToOffset${U}`,"coordinates.offsetToCoords","fragcolor.getColorAsFloat"])}),Q}getValueFromSingle(Q,H,j,K,W){let U=`_${Q}`;W&&(U=U+"_T");let Z=r(this.context.glContext.version);return`
+        float ${U}(int m[${H}]) {
+          int offset = indicesToOffset${U}(m);
+          vec2 coords = offsetToCoords(offset, ${j}, ${K});
+          float value = getColorAsFloat(${Z.texture2D}(${Q}, coords));
+          return value;
+        }
+        `}getPackedValueFrom(Q,H,j,K,W){let U=`_${Q}_Pack`;W&&(U=U+"_T");let Z=r(this.context.glContext.version);return`
+        vec4 ${U}(int m[${H}]) {
+          int offset = indicesToOffset_${Q}(m);
+          vec2 coords = offsetToCoords(offset, ${j}, ${K});
+          return ${Z.texture2D}(${Q}, coords);
+        }
+        `}}}),YJ,rj=E(()=>{E3(),YJ=class Q extends q4{constructor(H){super(H)}getFunctions(){return{...this.encodeFloat32(),...this.decodeFloat32()}}getCustomTypes(){return{}}encodeFloat32(){return{encode:new y(`highp vec4 encode(highp float f) {
+        return vec4(f, 0.0, 0.0, 0.0);
+      }
+        `)}}decodeFloat32(){return{decode:new y(`highp float decode(highp vec4 rgba) {
+        return rgba.r;
+      }
+        `)}}encodeUint8(){let H=Q.isLittleEndian()?"rgba.rgba=rgba.abgr;":"";return{encode:new y(`
+      highp vec4 encode(highp float f) {
+        highp float F = abs(f);
+        highp float Sign = step(0.0,-f);
+        highp float Exponent = floor(log2(F));
+        highp float Mantissa = (exp2(- Exponent) * F);
+        Exponent = floor(log2(F) + 127.0) + floor(log2(Mantissa));
+        highp vec4 rgba;
+        rgba[0] = 128.0 * Sign  + floor(Exponent*exp2(-1.0));
+        rgba[1] = 128.0 * mod(Exponent,2.0) + mod(floor(Mantissa*128.0),128.0);
+        rgba[2] = floor(mod(floor(Mantissa*exp2(23.0 -8.0)),exp2(8.0)));
+        rgba[3] = floor(exp2(23.0)*mod(Mantissa,exp2(-15.0)));
+        ${H}
+        rgba = rgba / 255.0; // values need to be normalized to [0,1]
+        return rgba;
+    }
+        `)}}decodeUint8(){let H=Q.isLittleEndian()?"rgba.rgba=rgba.abgr;":"";return{decode:new y(`
+        highp float decode(highp vec4 rgba) {
+          rgba = rgba * 255.0; // values need to be de-normalized from [0,1] to [0,255]
+          ${H}
+          highp float Sign = 1.0 - step(128.0,rgba[0])*2.0;
+          highp float Exponent = 2.0 * mod(rgba[0],128.0) + step(128.0,rgba[1]) - 127.0;
+          highp float Mantissa = mod(rgba[1],128.0)*65536.0 + rgba[2]*256.0 +rgba[3] + float(0x800000);
+          highp float Result =  Sign * exp2(Exponent) * (Mantissa * exp2(-23.0 ));
+          return Result;
+      }
+        `)}}static isLittleEndian(){let H=new ArrayBuffer(4),j=new Uint32Array(H),K=new Uint8Array(H);if(j[0]=3735928559,K[0]===239)return!0;if(K[0]===222)return!1;throw new Error("unknown endianness")}}}),CJ,tj=E(()=>{E3(),W1(),CJ=class extends q4{constructor(Q){super(Q)}getFunctions(){return{...this.setFragColor(),...this.getColorAsFloat()}}getCustomTypes(){return{}}setFragColor(){let Q=r(this.context.glContext.version);return{setFragColor:new y(`
+        void setFragColor(float value) {
+            ${Q.output} = encode(value);
+        }
+        `,["encoding.encode"])}}getColorAsFloat(){return{getColorAsFloat:new y(`
+        float getColorAsFloat(vec4 color) {
+            return decode(color);
+        }
+        `,["encoding.decode"])}}}}),BJ,ej=E(()=>{E3(),BJ=class Q extends q4{constructor(H){super(H)}getFunctions(){return{...this.bcastIndex(),...this.bcastMatmulIndex(),...this.offsetToIndices(),...this.indicesToOffset(),...this.incrementIndices()}}getCustomTypes(){return{}}bcastIndex(){let H=this.context.outputTextureLayout.shape.length,j={};return this.context.programInfo.inputNames.forEach((K,W)=>{let U=this.context.inputTextureLayouts[W].unpackedShape;if(U.length<=H){let Z=U.length,q=H-Z,G=`bcastIndices_${K}`,J="";for(let V=0;V<Z;++V)J+=`
+          realIndices[${V}] = int( mod(float(bcastedIndices[${q+V}]), ${U[V]}.0) );
+          `;let X=`
+        void ${G} (int bcastedIndices[${H}], out int realIndices[${Z}]) {
+          ${J}
+        }
+        `;j[G]=new y(X)}}),j}bcastMatmulIndex(){let H=this.context.outputTextureLayout.shape.length,j={};return this.context.programInfo.inputNames.forEach((K,W)=>{let U=this.context.inputTextureLayouts[W].shape;if(!(U.length<2||U.length>H)){let Z=U.length,q=H-Z,G=`bcastMatmulIndices_${K}`,J="";for(let V=0;V<Z-2;++V)J+=`
+          realIndices[${V}] = int( mod(float(bcastedIndices[${q+V}]), ${U[V]}.0) );
+          `;let X=`
+        void ${G}(int bcastedIndices[${H}], out int realIndices[${Z}]) {
+          ${J}
+          realIndices[${Z-1}] = bcastedIndices[${H-1}];
+          realIndices[${Z-2}] = bcastedIndices[${H-2}];
+        }
+        `;j[G]=new y(X)}}),j}indicesToOffset(){let H={};return this.context.programInfo.inputNames.forEach((j,K)=>{let W=this.context.inputTextureLayouts[K].shape,U=this.context.inputTextureLayouts[K].strides,Z=W.length,q=`indicesToOffset_${j}`;H[q]=new y(Q.indexToOffsetSingle(q,Z,U)),q=`indicesToOffset_${j}_T`,H[q]=new y(Q.indexToOffsetSingle(q,Z,U.slice().reverse()))}),H}static indexToOffsetSingle(H,j,K){let W="";for(let U=j-1;U>=0;--U)W+=`
+        offset += indices[${U}] * ${K[U]};
+        `;return`
+      int ${H}(int indices[${j}]) {
+        int offset = 0;
+        ${W}
+        return offset;
+      }
+      `}offsetToIndices(){let H={};return this.context.programInfo.inputNames.forEach((j,K)=>{let W=this.context.inputTextureLayouts[K].shape,U=this.context.inputTextureLayouts[K].strides,Z=W.length,q=`offsetToIndices_${j}`;H[q]=new y(Q.offsetToIndicesSingle(q,Z,U)),q=`offsetToIndices_${j}_T`,H[q]=new y(Q.offsetToIndicesSingle(q,Z,U.slice().reverse()))}),H}static offsetToIndicesSingle(H,j,K){let W=[];for(let U=0;U<j-1;++U)W.push(`
+      indices[${U}] = offset / ${K[U]};`),W.push(`
+        offset -= indices[${U}] * ${K[U]};`);return W.push(`
+      indices[${j-1}] = offset;`),`
+      void ${H}(int offset, out int indices[${j}]) {
+        ${W.join("")}
+      }
+      `}incrementIndices(){let H={};return this.context.programInfo.inputNames.forEach((j,K)=>{let W=this.context.inputTextureLayouts[K].shape,U=W.length,Z=`incrementIndices_${j}`,q="";for(let J=0;J<U;++J)q+=`
+        shape[${J}] = ${W[J]};`;let G=`
+        void ${Z}(int axis, out int indices[${U}]) {
+          int shape[${U}];
+          ${q};
+          for(int i = ${U} -1 ; i >= 0; --i) {
+            if(i > axis) continue;
+            indices[i] += 1;
+            if(indices[i] < shape[i]) {
+              break;
+            }
+            indices[i] = 0;
+          }
+        }
+        `;H[Z]=new y(G)}),H}}}),FJ,QV=E(()=>{E3(),FJ=class extends q4{constructor(Q){super(Q)}getCustomTypes(){return{}}getFunctions(){return{...this.binaryVecFunctions(),...this.copyVec(),...this.setVecItem(),...this.getVecItem()}}binaryVecFunctions(){let Q=this.context.outputTextureLayout.shape.length,H={add:"+=",sub:"-=",mul:"*=",div:"/="},j={};for(let K in H){let W=`${K}Vec`,U="";for(let q=0;q<Q;++q)U+=`
+          dest[${q}] ${H[K]} src[${q}];
+          `;let Z=`
+        void ${W}(int src[${Q}], out int dest[${Q}]) {
+          ${U}
+        }
+        `;j[W]=new y(Z)}return j}copyVec(){let Q=this.context.outputTextureLayout.shape.length,H="";for(let K=0;K<Q;++K)H+=`
+        dest[${K}] = src[${K}];
+        `;let j=`
+      void copyVec(int src[${Q}], out int dest[${Q}]) {
+        ${H}
+      }
+      `;return{copyVec:new y(j)}}setVecItem(){let Q=this.context.outputTextureLayout.shape.length,H=`
+        if(index < 0)
+            index =${Q} + index;
+        if (index == 0)
+            m[0] = value;
+        `;for(let K=1;K<Q-1;++K)H+=`
+        else if (index == ${K})
+            m[${K}] = value;
+            `;H+=`
+        else
+            m[${Q-1}] = value;
+        `;let j=`
+      void setVecItem(out int m[${Q}], int index, int value) {
+        ${H}
+      }
+        `;return{setVecItem:new y(j)}}getVecItem(){let Q=this.context.outputTextureLayout.shape.length,H=`
+        if(index < 0)
+            index = ${Q} + index;
+        if (index == 0)
+            return m[0];
+      `;for(let K=1;K<Q-1;++K)H+=`
+        else if (index == ${K})
+            return m[${K}];
+      `;H+=`
+        else
+            return m[${Q-1}];
+        `;let j=`
+      int getVecItem(int m[${Q}], int index) {
+        ${H}
+      }
+    `;return{getVecItem:new y(j)}}}}),c6,JV=E(()=>{nj(),rj(),tj(),ej(),QV(),c6={encoding:YJ,fragcolor:CJ,vec:FJ,shapeUtils:BJ,coordinates:MJ}}),kJ,HV=E(()=>{E3(),aj(),JV(),W1(),kJ=class{constructor(Q,H,j,K){this.libs={},this.glslLibRoutineDependencyGraph={},this.context=new W0(Q,H,j,K),Object.keys(c6).forEach((U)=>{let Z=new c6[U](this.context);this.libs[U]=Z});let W=this.glslLibRoutineDependencyGraph;for(let U in this.libs){let Z=this.libs[U].getFunctions();for(let q in Z){let G=U+"."+q,J;W[G]?(J=W[G],J.routineBody=Z[q].routineBody):(J=new D6(G,Z[q].routineBody),W[G]=J);let X=Z[q].dependencies;if(X)for(let V=0;V<X.length;++V)if(W[X[V]])J.addDependency(W[X[V]]);else{let R=new D6(X[V]);W[X[V]]=R,J.addDependency(R)}}}}preprocess(){let Q=this.context.programInfo,H=Q.shaderSource;return this.context.programInfo.hasMain||(H=`${H}
+      ${TH(this.context.glContext.version,this.context.outputTextureLayout.shape.length)}`),H=kZ(H),`${wH(this.context.glContext.version)}
+    ${this.getUniforms(Q.inputNames,Q.variables)}
+    ${this.getImports(H)}
+    ${H}`}getImports(Q){let H=this.selectGlslLibRoutinesToBeIncluded(Q);if(H.length===0)return"";let j="";for(let K=0;K<H.length;++K)if(H[K].routineBody)j+=H[K].routineBody+`
+`;else throw new Error(`Missing body for the Glsl Library routine: ${H[K].name}`);return j}selectGlslLibRoutinesToBeIncluded(Q){let H=[];return Object.keys(this.glslLibRoutineDependencyGraph).forEach((j)=>{let K=j.split(".")[1];Q.indexOf(K)!==-1&&H.push(this.glslLibRoutineDependencyGraph[j])}),G0.returnOrderedNodes(H)}getUniforms(Q,H){let j=[];if(Q)for(let K of Q)j.push(`uniform sampler2D ${K};`);if(H)for(let K of H)j.push(`uniform ${K.type} ${K.name}${K.arrayLength?`[${K.arrayLength}]`:""};`);return j.join(`
+`)}}}),AJ,ZV=E(()=>{z3(),V3(),HV(),W1(),AJ=class{constructor(Q,H,j){this.profiler=Q,this.glContext=H,this.textureLayoutStrategy=j,this.repo=new Map,this.attributesBound=!1}getArtifact(Q){return this.repo.get(Q)}setArtifact(Q,H){this.repo.set(Q,H)}run(Q,H,j){this.profiler.event("op",`ProgramManager.run ${Q.programInfo.name??"unknown kernel"}`,()=>{let K=this.glContext.gl,W=Q.program;K.useProgram(W);try{this.bindOutput(j),this.attributesBound||this.bindAttributes(Q.attribLocations),this.bindUniforms(Q.uniformLocations,Q.programInfo.variables??[],H)}catch(U){throw C1.error("ProgramManager",Q.programInfo.shaderSource),U}this.profiler.event("backend","GlContext.draw()",()=>{this.glContext.draw()})},this.glContext)}dispose(){this.vertexShader&&this.glContext.deleteShader(this.vertexShader),this.repo.forEach((Q)=>this.glContext.deleteProgram(Q.program))}build(Q,H,j){return this.profiler.event("backend","ProgramManager.build",()=>{let K=new kJ(this.glContext,Q,H,j),W=K.preprocess(),U=this.compile(W);return{programInfo:Q,program:U,uniformLocations:this.getUniformLocations(U,K.context.programInfo.inputNames,K.context.programInfo.variables),attribLocations:this.getAttribLocations(U)}})}compile(Q){if(!this.vertexShader){C1.verbose("ProrgramManager","Compiling and caching Vertex shader for the first time");let K=vH(this.glContext.version);this.vertexShader=this.glContext.compileShader(K,this.glContext.gl.VERTEX_SHADER)}i.debug&&C1.verbose("ProrgramManager",`FragShader:
+${Q}
+`);let H=this.glContext.compileShader(Q,this.glContext.gl.FRAGMENT_SHADER),j=this.glContext.createProgram(this.vertexShader,H);return this.glContext.deleteShader(H),j}bindOutput(Q){let{width:H,height:j}=Q;C1.verbose("ProrgramManager",`Binding output texture to Framebuffer: w/h=${H}/${j}, shape=${Q.shape}, type=${Q.tensor.type}`),this.glContext.attachFramebuffer(Q.texture,H,j)}bindAttributes(Q){let{position:H,textureCoord:j}=Q;this.glContext.setVertexAttributes(H,j),this.attributesBound=!0}bindUniforms(Q,H,j){let K=this.glContext.gl,W=0;for(let{name:U,type:Z,location:q,arrayLength:G}of Q){let J=H.find((X)=>X.name===U)?.data;if(Z!=="sampler2D"&&!J)throw new Error(`variable '${U}' does not have data defined in program info`);switch(Z){case"sampler2D":this.bindTexture(j[W],q,W),W++;break;case"float":G?K.uniform1fv(q,J):K.uniform1f(q,J);break;case"int":G?K.uniform1iv(q,J):K.uniform1i(q,J);break;default:throw new Error(`Uniform not implemented: ${Z}`)}}}bindTexture(Q,H,j){this.glContext.bindTextureToUniform(Q.texture,j,H)}getAttribLocations(Q){return{position:this.getAttribLocation(Q,"position"),textureCoord:this.getAttribLocation(Q,"textureCoord")}}getUniformLocations(Q,H,j){let K=[];if(H)for(let W of H)K.push({name:W,type:"sampler2D",location:this.getUniformLocation(Q,W)});if(j)for(let W of j)K.push({...W,location:this.getUniformLocation(Q,W.name)});return K}getUniformLocation(Q,H){let j=this.glContext.gl.getUniformLocation(Q,H);if(j===null)throw new Error(`Uniform ${H} not found.`);return j}getAttribLocation(Q,H){return this.glContext.gl.getAttribLocation(Q,H)}}}),SJ,jV=E(()=>{V3(),z5(),SJ=class{constructor(Q,H,j,K){this.glContext=Q,this.layoutStrategy=H,this.profiler=j,this.config=K,this.pendingRead=new Map,K.reuseTextures&&(this.inUseTextures=new Map,this.idleTextures=new Map,this.textureLookup=new Map)}createTextureFromLayout(Q,H,j,K){let W=this.toEncoderType(Q),U=this.glContext.getEncoder(W,H.channels||1,K);if(H.isPacked&&K===1)throw new Error("not implemented");let{width:Z,height:q}=H,G,J;if(this.config.reuseTextures){G=`${Z}x${q}_${U.format}_${U.internalFormat}_${U.textureType}`,J=this.inUseTextures.get(G),J||(J=[],this.inUseTextures.set(G,J));let V=this.idleTextures.get(G);if(V&&V.length>0){let R=V.pop();return J.push(R),K===1&&this.glContext.updateTexture(R,Z,q,U,this.toTextureData(Q,j)),R}}C1.verbose("TextureManager",`Creating new texture of size ${H.width}x${H.height}`);let X=this.glContext.allocateTexture(Z,q,U,this.toTextureData(Q,j));return this.config.reuseTextures&&(J.push(X),this.textureLookup.set(X,G)),X}readTexture(Q,H,j){return j||(j=1),this.profiler.event("backend","TextureManager.readTexture",()=>{let K=Q.shape.reduce((U,Z)=>U*Z)*j,W=this.glContext.readTexture(Q.texture,Q.width,Q.height,K,this.toEncoderType(H),j);return this.toTensorData(H,W)})}async readTextureAsync(Q,H,j){let K=Q.tensor.dataId;if(j||(j=1),this.pendingRead.has(K)){let W=this.pendingRead.get(K);return new Promise((U)=>W?.push(U))}return this.profiler.event("backend","TextureManager.readTextureAsync",async()=>{this.pendingRead.set(K,[]);let W=Q.shape.reduce((G,J)=>G*J)*j;await this.glContext.createAndWaitForFence();let U=this.glContext.readTexture(Q.texture,Q.width,Q.height,W,this.toEncoderType(H),j),Z=this.toTensorData(H,U),q=this.pendingRead.get(K);return this.pendingRead.delete(K),q?.forEach((G)=>G(Z)),Z})}readUint8TextureAsFloat(Q){return this.profiler.event("backend","TextureManager.readUint8TextureAsFloat",()=>{let H=Q.shape.reduce((K,W)=>K*W),j=this.glContext.readTexture(Q.texture,Q.width,Q.height,H*4,"byte",4);return new Float32Array(j.buffer,j.byteOffset,H)})}releaseTexture(Q,H){let j;if(this.config.reuseTextures&&(j=this.textureLookup.get(Q.texture),j)){H&&this.textureLookup.delete(j);let K=this.inUseTextures.get(j);if(K){let W=K.indexOf(Q.texture);if(W!==-1){K.splice(W,1);let U=this.idleTextures.get(j);U||(U=[],this.idleTextures.set(j,U)),U.push(Q.texture)}}}(!j||H)&&(C1.verbose("TextureManager",`Deleting texture of size ${Q.width}x${Q.height}`),this.glContext.deleteTexture(Q.texture))}toTensorData(Q,H){switch(Q){case"int16":return H instanceof Int16Array?H:Int16Array.from(H);case"int32":return H instanceof Int32Array?H:Int32Array.from(H);case"int8":return H instanceof Int8Array?H:Int8Array.from(H);case"uint16":return H instanceof Uint16Array?H:Uint16Array.from(H);case"uint32":return H instanceof Uint32Array?H:Uint32Array.from(H);case"uint8":case"bool":return H instanceof Uint8Array?H:Uint8Array.from(H);case"float32":return H instanceof Float32Array?H:Float32Array.from(H);case"float64":return H instanceof Float64Array?H:Float64Array.from(H);default:throw new Error(`TensorData type ${Q} is not supported`)}}toTextureData(Q,H){if(H)return H instanceof Float32Array?H:new Float32Array(H)}toEncoderType(Q){return"float"}clearActiveTextures(){this.glContext.clearActiveTextures()}}}),$J,VV=E(()=>{V3(),aZ(),Cj(),oj(),ZV(),NJ(),jV(),$J=class{constructor(Q,H){this.backend=Q,this.context=H,this.layoutStrategy=new zJ(Q.glContext.maxTextureSize),this.programManager=new AJ(this.context.profiler,Q.glContext,this.layoutStrategy),this.textureManager=new SJ(Q.glContext,this.layoutStrategy,this.context.profiler,{reuseTextures:Q.textureCacheMode==="full"}),this.packedTextureDataCache=new Map,this.unpackedTextureDataCache=new Map,this.pack=Q.pack,this.pack2unpackMap=new Map,this.unpack2packMap=new Map}createInferenceHandler(){return new K0(this)}onGraphInitialized(Q){let H=Q.getValues().filter((j)=>j.from===-1&&j.tensor).map((j)=>j.tensor.dataId);this.initializers=new Set(H)}isInitializer(Q){return this.initializers?this.initializers.has(Q):!1}addInitializer(Q){this.initializers.add(Q)}getTextureData(Q,H){return H?this.packedTextureDataCache.get(Q):this.unpackedTextureDataCache.get(Q)}setTextureData(Q,H,j=!1){C1.verbose("WebGLSessionHandler","Storing Texture data in cache"),j?this.packedTextureDataCache.set(Q,H):this.unpackedTextureDataCache.set(Q,H)}dispose(){this.programManager.dispose(),this.textureManager.clearActiveTextures(),this.packedTextureDataCache.forEach((Q)=>this.textureManager.releaseTexture(Q,!0)),this.packedTextureDataCache=new Map,this.unpackedTextureDataCache.forEach((Q)=>this.textureManager.releaseTexture(Q,!0)),this.unpackedTextureDataCache=new Map}resolve(Q,H,j){let K=AH(Q,H,GJ);return{impl:K.opImpl,context:K.opInit?K.opInit(Q,j):Q}}}}),f6,XV=E(()=>{z3(),z5(),z5(),F3(),f6=class{constructor(Q,H){this.frameBufferBound=!1,this.itemsToPoll=[],this.gl=Q,this.version=H,this.getExtensions(),this.vertexbuffer=this.createVertexbuffer(),this.framebuffer=this.createFramebuffer(),this.queryVitalParameters()}allocateTexture(Q,H,j,K){let W=this.gl,U=W.createTexture();W.bindTexture(W.TEXTURE_2D,U),W.texParameteri(W.TEXTURE_2D,W.TEXTURE_MIN_FILTER,W.NEAREST),W.texParameteri(W.TEXTURE_2D,W.TEXTURE_MAG_FILTER,W.NEAREST),W.texParameteri(W.TEXTURE_2D,W.TEXTURE_WRAP_S,W.CLAMP_TO_EDGE),W.texParameteri(W.TEXTURE_2D,W.TEXTURE_WRAP_T,W.CLAMP_TO_EDGE);let Z=K?j.encode(K,Q*H):null;return W.texImage2D(W.TEXTURE_2D,0,j.internalFormat,Q,H,0,j.format,j.textureType,Z),this.checkError(),U}updateTexture(Q,H,j,K,W){let U=this.gl;U.bindTexture(U.TEXTURE_2D,Q);let Z=K.encode(W,H*j);U.texSubImage2D(U.TEXTURE_2D,0,0,0,H,j,K.format,K.textureType,Z),this.checkError()}attachFramebuffer(Q,H,j){let K=this.gl;K.bindTexture(K.TEXTURE_2D,Q),K.bindFramebuffer(K.FRAMEBUFFER,this.framebuffer),K.framebufferTexture2D(K.FRAMEBUFFER,K.COLOR_ATTACHMENT0,K.TEXTURE_2D,Q,0),this.checkError(),K.viewport(0,0,H,j),K.scissor(0,0,H,j)}readTexture(Q,H,j,K,W,U){let Z=this.gl;U||(U=1),this.frameBufferBound||this.attachFramebuffer(Q,H,j);let q=this.getEncoder(W,U),G=q.allocate(H*j);return Z.bindTexture(Z.TEXTURE_2D,Q),Z.framebufferTexture2D(Z.FRAMEBUFFER,Z.COLOR_ATTACHMENT0,Z.TEXTURE_2D,Q,0),Z.readPixels(0,0,H,j,Z.RGBA,q.textureType,G),this.checkError(),q.decode(G,K)}isFramebufferReady(){return!0}getActiveTexture(){let Q=this.gl;return`TEXTURE${Q.getParameter(this.gl.ACTIVE_TEXTURE)-Q.TEXTURE0}`}getTextureBinding(){return this.gl.getParameter(this.gl.TEXTURE_BINDING_2D)}getFramebufferBinding(){return this.gl.getParameter(this.gl.FRAMEBUFFER_BINDING)}setVertexAttributes(Q,H){let j=this.gl;j.vertexAttribPointer(Q,3,j.FLOAT,!1,20,0),j.enableVertexAttribArray(Q),H!==-1&&(j.vertexAttribPointer(H,2,j.FLOAT,!1,20,12),j.enableVertexAttribArray(H)),this.checkError()}createProgram(Q,H){let j=this.gl,K=j.createProgram();return j.attachShader(K,Q),j.attachShader(K,H),j.linkProgram(K),K}compileShader(Q,H){let j=this.gl,K=j.createShader(H);if(!K)throw new Error(`createShader() returned null with type ${H}`);if(j.shaderSource(K,Q),j.compileShader(K),j.getShaderParameter(K,j.COMPILE_STATUS)===!1)throw new Error(`Failed to compile shader: ${j.getShaderInfoLog(K)}
+Shader source:
+${Q}`);return K}deleteShader(Q){this.gl.deleteShader(Q)}bindTextureToUniform(Q,H,j){let K=this.gl;K.activeTexture(K.TEXTURE0+H),this.checkError(),K.bindTexture(K.TEXTURE_2D,Q),this.checkError(),K.uniform1i(j,H),this.checkError()}draw(){this.gl.drawArrays(this.gl.TRIANGLE_STRIP,0,4),this.checkError()}checkError(){if(i.debug){let Q=this.gl,H=Q.getError(),j="";switch(H){case Q.NO_ERROR:return;case Q.INVALID_ENUM:j="INVALID_ENUM";break;case Q.INVALID_VALUE:j="INVALID_VALUE";break;case Q.INVALID_OPERATION:j="INVALID_OPERATION";break;case Q.INVALID_FRAMEBUFFER_OPERATION:j="INVALID_FRAMEBUFFER_OPERATION";break;case Q.OUT_OF_MEMORY:j="OUT_OF_MEMORY";break;case Q.CONTEXT_LOST_WEBGL:j="CONTEXT_LOST_WEBGL";break;default:j=`Unknown WebGL Error: ${H.toString(16)}`}throw new Error(j)}}deleteTexture(Q){this.gl.deleteTexture(Q)}deleteProgram(Q){this.gl.deleteProgram(Q)}getEncoder(Q,H,j=0){if(this.version===2)return new j0(this.gl,H);switch(Q){case"float":return j===1||this.isRenderFloat32Supported?new w6(this.gl,H):new w6(this.gl,H,this.textureHalfFloatExtension.HALF_FLOAT_OES);case"int":throw new Error("not implemented");case"byte":return new V0(this.gl,H);default:throw new Error(`Invalid dataType: ${Q}`)}}clearActiveTextures(){let Q=this.gl;for(let H=0;H<this.maxTextureImageUnits;++H)Q.activeTexture(Q.TEXTURE0+H),Q.bindTexture(Q.TEXTURE_2D,null)}dispose(){if(this.disposed)return;let Q=this.gl;Q.bindFramebuffer(Q.FRAMEBUFFER,null),Q.deleteFramebuffer(this.framebuffer),Q.bindBuffer(Q.ARRAY_BUFFER,null),Q.deleteBuffer(this.vertexbuffer),Q.bindBuffer(Q.ELEMENT_ARRAY_BUFFER,null),Q.finish(),this.disposed=!0}createDefaultGeometry(){return new Float32Array([-1,1,0,0,1,-1,-1,0,0,0,1,1,0,1,1,1,-1,0,1,0])}createVertexbuffer(){let Q=this.gl,H=Q.createBuffer();if(!H)throw new Error("createBuffer() returned null");let j=this.createDefaultGeometry();return Q.bindBuffer(Q.ARRAY_BUFFER,H),Q.bufferData(Q.ARRAY_BUFFER,j,Q.STATIC_DRAW),this.checkError(),H}createFramebuffer(){let Q=this.gl.createFramebuffer();if(!Q)throw new Error("createFramebuffer returned null");return Q}queryVitalParameters(){let Q=this.gl;if(this.isFloatTextureAttachableToFrameBuffer=this.checkFloatTextureAttachableToFrameBuffer(),this.isRenderFloat32Supported=this.checkRenderFloat32(),this.isFloat32DownloadSupported=this.checkFloat32Download(),this.version===1&&!this.textureHalfFloatExtension&&!this.isRenderFloat32Supported)throw new Error("both float32 and float16 TextureType are not supported");this.isBlendSupported=!this.isRenderFloat32Supported||this.checkFloat32Blend(),this.maxTextureSize=Q.getParameter(Q.MAX_TEXTURE_SIZE),this.maxTextureImageUnits=Q.getParameter(Q.MAX_TEXTURE_IMAGE_UNITS),this.version}getExtensions(){this.version===2?(this.colorBufferFloatExtension=this.gl.getExtension("EXT_color_buffer_float"),this.disjointTimerQueryWebgl2Extension=this.gl.getExtension("EXT_disjoint_timer_query_webgl2")):(this.textureFloatExtension=this.gl.getExtension("OES_texture_float"),this.textureHalfFloatExtension=this.gl.getExtension("OES_texture_half_float"))}checkFloatTextureAttachableToFrameBuffer(){let Q=this.gl,H=Q.createTexture();Q.bindTexture(Q.TEXTURE_2D,H);let j=this.version===2?Q.RGBA32F:Q.RGBA;Q.texImage2D(Q.TEXTURE_2D,0,j,1,1,0,Q.RGBA,Q.FLOAT,null);let K=Q.createFramebuffer();Q.bindFramebuffer(Q.FRAMEBUFFER,K),Q.framebufferTexture2D(Q.FRAMEBUFFER,Q.COLOR_ATTACHMENT0,Q.TEXTURE_2D,H,0);let W=Q.checkFramebufferStatus(Q.FRAMEBUFFER)===Q.FRAMEBUFFER_COMPLETE;return Q.bindTexture(Q.TEXTURE_2D,null),Q.bindFramebuffer(Q.FRAMEBUFFER,null),Q.deleteTexture(H),Q.deleteFramebuffer(K),W}checkRenderFloat32(){if(this.version===2){if(!this.colorBufferFloatExtension)return!1}else if(!this.textureFloatExtension)return!1;return this.isFloatTextureAttachableToFrameBuffer}checkFloat32Download(){if(this.version===2){if(!this.colorBufferFloatExtension)return!1}else if(!this.textureFloatExtension||!this.gl.getExtension("WEBGL_color_buffer_float"))return!1;return this.isFloatTextureAttachableToFrameBuffer}checkFloat32Blend(){let Q=this.gl,H,j,K,W,U;try{H=Q.createTexture(),j=Q.createFramebuffer(),Q.bindTexture(Q.TEXTURE_2D,H);let Z=this.version===2?Q.RGBA32F:Q.RGBA;return Q.texImage2D(Q.TEXTURE_2D,0,Z,1,1,0,Q.RGBA,Q.FLOAT,null),Q.bindFramebuffer(Q.FRAMEBUFFER,j),Q.framebufferTexture2D(Q.FRAMEBUFFER,Q.COLOR_ATTACHMENT0,Q.TEXTURE_2D,H,0),Q.enable(Q.BLEND),K=Q.createShader(Q.VERTEX_SHADER),!K||(Q.shaderSource(K,"void main(){}"),Q.compileShader(K),W=Q.createShader(Q.FRAGMENT_SHADER),!W)||(Q.shaderSource(W,"precision highp float;void main(){gl_FragColor=vec4(0.5);}"),Q.compileShader(W),U=Q.createProgram(),!U)?!1:(Q.attachShader(U,K),Q.attachShader(U,W),Q.linkProgram(U),Q.useProgram(U),Q.drawArrays(Q.POINTS,0,1),Q.getError()===Q.NO_ERROR)}finally{Q.disable(Q.BLEND),U&&Q.deleteProgram(U),K&&Q.deleteShader(K),W&&Q.deleteShader(W),j&&(Q.bindFramebuffer(Q.FRAMEBUFFER,null),Q.deleteFramebuffer(j)),H&&(Q.bindTexture(Q.TEXTURE_2D,null),Q.deleteTexture(H))}}beginTimer(){if(this.version===2&&this.disjointTimerQueryWebgl2Extension){let Q=this.gl,H=this.disjointTimerQueryWebgl2Extension,j=Q.createQuery();return Q.beginQuery(H.TIME_ELAPSED_EXT,j),j}else throw new Error("WebGL1 profiling currently not supported.")}endTimer(){if(this.version===2&&this.disjointTimerQueryWebgl2Extension){let Q=this.gl,H=this.disjointTimerQueryWebgl2Extension;Q.endQuery(H.TIME_ELAPSED_EXT);return}else throw new Error("WebGL1 profiling currently not supported")}isTimerResultAvailable(Q){let H=!1,j=!1;if(this.version===2&&this.disjointTimerQueryWebgl2Extension){let K=this.gl,W=this.disjointTimerQueryWebgl2Extension;H=K.getQueryParameter(Q,K.QUERY_RESULT_AVAILABLE),j=K.getParameter(W.GPU_DISJOINT_EXT)}else throw new Error("WebGL1 profiling currently not supported");return H&&!j}getTimerResult(Q){let H=0;if(this.version===2){let j=this.gl;H=j.getQueryParameter(Q,j.QUERY_RESULT),j.deleteQuery(Q)}else throw new Error("WebGL1 profiling currently not supported");return H/1e6}async waitForQueryAndGetTime(Q){return await u7(()=>this.isTimerResultAvailable(Q)),this.getTimerResult(Q)}async createAndWaitForFence(){let Q=this.createFence(this.gl);return this.pollFence(Q)}createFence(Q){let H,j=Q,K=j.fenceSync(j.SYNC_GPU_COMMANDS_COMPLETE,0);return Q.flush(),K===null?H=()=>!0:H=()=>{let W=j.clientWaitSync(K,0,0);return W===j.ALREADY_SIGNALED||W===j.CONDITION_SATISFIED},{query:K,isFencePassed:H}}async pollFence(Q){return new Promise((H)=>{this.addItemToPoll(()=>Q.isFencePassed(),()=>H())})}pollItems(){let Q=LZ(this.itemsToPoll.map((H)=>H.isDoneFn));for(let H=0;H<=Q;++H){let{resolveFn:j}=this.itemsToPoll[H];j()}this.itemsToPoll=this.itemsToPoll.slice(Q+1)}async addItemToPoll(Q,H){this.itemsToPoll.push({isDoneFn:Q,resolveFn:H}),!(this.itemsToPoll.length>1)&&await u7(()=>(this.pollItems(),this.itemsToPoll.length===0))}}}),u3,KV=E(()=>{V3(),XV(),u3={}}),LJ,UV=E(()=>{z3(),V3(),VV(),KV(),LJ=class{get contextId(){return i.webgl.contextId}set contextId(Q){i.webgl.contextId=Q}get matmulMaxBatchSize(){return i.webgl.matmulMaxBatchSize}set matmulMaxBatchSize(Q){i.webgl.matmulMaxBatchSize=Q}get textureCacheMode(){return i.webgl.textureCacheMode}set textureCacheMode(Q){i.webgl.textureCacheMode=Q}get pack(){return i.webgl.pack}set pack(Q){i.webgl.pack=Q}get async(){return i.webgl.async}set async(Q){i.webgl.async=Q}initialize(){try{return this.glContext=T2(this.contextId),typeof this.matmulMaxBatchSize!="number"&&(this.matmulMaxBatchSize=16),typeof this.textureCacheMode!="string"&&(this.textureCacheMode="full"),typeof this.pack!="boolean"&&(this.pack=!1),typeof this.async!="boolean"&&(this.async=!1),C1.setWithEnv(i),i.webgl.context||Object.defineProperty(i.webgl,"context",{value:this.glContext.gl}),C1.verbose("WebGLBackend",`Created WebGLContext: ${typeof this.glContext} with matmulMaxBatchSize: ${this.matmulMaxBatchSize}; textureCacheMode: ${this.textureCacheMode}; pack: ${this.pack}; async: ${this.async}.`),!0}catch(Q){return C1.warning("WebGLBackend",`Unable to initialize WebGLBackend. ${Q}`),!1}}createSessionHandler(Q){return new $J(this,Q)}dispose(){this.glContext.dispose()}}}),U7,vJ,qV=E(()=>{UV(),U7=new Map,vJ={webgl:new LJ}}),H2,wJ,WV=E(()=>{V3(),H2=class{constructor(Q,H){this.op=Q,this.node=H}},wJ=class{constructor(Q,H,j){this.graph=Q,this.profiler=j,this.initialize(H)}initialize(Q){this.profiler.event("session","ExecutionPlan.initialize",()=>{let H=this.graph.getNodes();if(H.length!==Q.length)throw new Error("The size of nodes and OPs do not match.");this._ops=Q.map((j,K)=>new H2(j,H[K])),this.reset(),this._starter=[],this._ops.forEach((j,K)=>{let W=!0;for(let U of j.node.inputs)if(!this._values[U]&&this.graph.getInputIndices().indexOf(U)===-1){W=!1;break}W&&this._starter.push(K)})})}reset(){this._values=this.graph.getValues().map((Q)=>Q.tensor)}async execute(Q,H){return this.profiler.event("session","ExecutionPlan.execute",async()=>{this.reset();let j=Q.createInferenceHandler(),K=this.graph.getInputIndices();if(H.length!==K.length)throw new Error(`number of input tensors don't match the number of inputs to the model: actual: ${H.length} expected: ${K.length}`);H.forEach((J,X)=>{let V=K[X];this._values[V]=J});let W=this._starter.slice(0),U=this.graph.getValues(),Z=this.graph.getNodes(),q=0;for(;q<W.length;){let J=W[q++],X=this._ops[J],V=X.node.inputs.map((B)=>this._values[B]);if(V.indexOf(void 0)!==-1)throw new Error(`unresolved input detected: op: ${X.node}`);let R=V;C1.verbose("ExecPlan",`Runing op:${X.node.name} (${R.map((B,k)=>`'${X.node.inputs[k]}': ${B.type}[${B.dims.join(",")}]`).join(", ")})`);let z=await this.profiler.event("node",X.node.name,async()=>X.op.impl(j,R,X.op.context));if(z.length!==X.node.outputs.length)throw new Error("the size of output does not match model definition.");z.forEach((B,k)=>{let w=X.node.outputs[k];if(this._values[w])throw new Error(`output [${w}] already has value: op:${X.node.name}`);this._values[w]=B});let Y=new Set;z.forEach((B,k)=>{let w=X.node.outputs[k];for(let A of U[w].to){let D=Z[A],I=!0;for(let h of D.inputs)if(!this._values[h]){I=!1;break}I&&Y.add(A)}}),W.push(...Y)}let G=[];for(let J=0;J<this.graph.getOutputIndices().length;J++){let X=this.graph.getOutputIndices()[J],V=this._values[X];if(V===void 0)throw new Error(`required output [${X}] does not have value`);X===0?await V.getData():V.data,G.push(V)}return C1.verbose("ExecPlan","disposing of inferenceHandler"),j.dispose(),G})}}}),n,s1,l6,GV=E(()=>{B5(),n=Z4(l4()),K4(),Q1(),s1=H1.experimental.fbs,l6=class Q{constructor(H){if(this._attributes=new Map,H!=null){for(let j of H)j instanceof n.onnx.AttributeProto?this._attributes.set(j.name,[Q.getValue(j),Q.getType(j)]):j instanceof s1.Attribute&&this._attributes.set(j.name(),[Q.getValue(j),Q.getType(j)]);if(this._attributes.size<H.length)throw new Error("duplicated attribute names")}}set(H,j,K){this._attributes.set(H,[K,j])}delete(H){this._attributes.delete(H)}getFloat(H,j){return this.get(H,"float",j)}getInt(H,j){return this.get(H,"int",j)}getString(H,j){return this.get(H,"string",j)}getTensor(H,j){return this.get(H,"tensor",j)}getFloats(H,j){return this.get(H,"floats",j)}getInts(H,j){return this.get(H,"ints",j)}getStrings(H,j){return this.get(H,"strings",j)}getTensors(H,j){return this.get(H,"tensors",j)}get(H,j,K){let W=this._attributes.get(H);if(W===void 0){if(K!==void 0)return K;throw new Error(`required attribute not found: ${H}`)}if(W[1]!==j)throw new Error(`type mismatch: expected ${j} but got ${W[1]}`);return W[0]}static getType(H){let j=H instanceof n.onnx.AttributeProto?H.type:H.type();switch(j){case n.onnx.AttributeProto.AttributeType.FLOAT:return"float";case n.onnx.AttributeProto.AttributeType.INT:return"int";case n.onnx.AttributeProto.AttributeType.STRING:return"string";case n.onnx.AttributeProto.AttributeType.TENSOR:return"tensor";case n.onnx.AttributeProto.AttributeType.FLOATS:return"floats";case n.onnx.AttributeProto.AttributeType.INTS:return"ints";case n.onnx.AttributeProto.AttributeType.STRINGS:return"strings";case n.onnx.AttributeProto.AttributeType.TENSORS:return"tensors";default:throw new Error(`attribute type is not supported yet: ${n.onnx.AttributeProto.AttributeType[j]}`)}}static getValue(H){let j=H instanceof n.onnx.AttributeProto?H.type:H.type();if(j===n.onnx.AttributeProto.AttributeType.GRAPH||j===n.onnx.AttributeProto.AttributeType.GRAPHS)throw new Error("graph attribute is not supported yet");let K=this.getValueNoCheck(H);if(j===n.onnx.AttributeProto.AttributeType.INT&&G3.isLong(K))return G3.longToNumber(K);if(j===n.onnx.AttributeProto.AttributeType.INTS){let W=K,U=new Array(W.length);for(let Z=0;Z<W.length;Z++){let q=W[Z];U[Z]=G3.longToNumber(q)}return U}if(j===n.onnx.AttributeProto.AttributeType.TENSOR)return H instanceof n.onnx.AttributeProto?o1.fromProto(K):o1.fromOrtTensor(K);if(j===n.onnx.AttributeProto.AttributeType.TENSORS){if(H instanceof n.onnx.AttributeProto)return K.map((W)=>o1.fromProto(W));if(H instanceof s1.Attribute)return K.map((W)=>o1.fromOrtTensor(W))}return j===n.onnx.AttributeProto.AttributeType.STRING&&H instanceof n.onnx.AttributeProto?N6(K):j===n.onnx.AttributeProto.AttributeType.STRINGS&&H instanceof n.onnx.AttributeProto?K.map(N6):K}static getValueNoCheck(H){return H instanceof n.onnx.AttributeProto?this.getValueNoCheckFromOnnxFormat(H):this.getValueNoCheckFromOrtFormat(H)}static getValueNoCheckFromOnnxFormat(H){switch(H.type){case n.onnx.AttributeProto.AttributeType.FLOAT:return H.f;case n.onnx.AttributeProto.AttributeType.INT:return H.i;case n.onnx.AttributeProto.AttributeType.STRING:return H.s;case n.onnx.AttributeProto.AttributeType.TENSOR:return H.t;case n.onnx.AttributeProto.AttributeType.GRAPH:return H.g;case n.onnx.AttributeProto.AttributeType.FLOATS:return H.floats;case n.onnx.AttributeProto.AttributeType.INTS:return H.ints;case n.onnx.AttributeProto.AttributeType.STRINGS:return H.strings;case n.onnx.AttributeProto.AttributeType.TENSORS:return H.tensors;case n.onnx.AttributeProto.AttributeType.GRAPHS:return H.graphs;default:throw new Error(`unsupported attribute type: ${n.onnx.AttributeProto.AttributeType[H.type]}`)}}static getValueNoCheckFromOrtFormat(H){switch(H.type()){case s1.AttributeType.FLOAT:return H.f();case s1.AttributeType.INT:return H.i();case s1.AttributeType.STRING:return H.s();case s1.AttributeType.TENSOR:return H.t();case s1.AttributeType.GRAPH:return H.g();case s1.AttributeType.FLOATS:return H.floatsArray();case s1.AttributeType.INTS:{let j=[];for(let K=0;K<H.intsLength();K++)j.push(H.ints(K));return j}case s1.AttributeType.STRINGS:{let j=[];for(let K=0;K<H.stringsLength();K++)j.push(H.strings(K));return j}case s1.AttributeType.TENSORS:{let j=[];for(let K=0;K<H.tensorsLength();K++)j.push(H.tensors(K));return j}default:throw new Error(`unsupported attribute type: ${s1.AttributeType[H.type()]}`)}}}}),K6,w4,u6,B3,U6,Z2,RV=E(()=>{GV(),B5(),K6=Z4(l4()),K4(),Q1(),w4=H1.experimental.fbs,u6={from:(Q,H)=>new Z2(Q,H)},B3=class{constructor(Q){this._from=void 0,this._to=[],this.tensor=void 0,this.type=void 0,Q&&(this.type=i1.tensorValueTypeFromProto(Q.type.tensorType))}get from(){return this._from}get to(){return this._to}},U6=class{constructor(Q,H){Q instanceof K6.onnx.NodeProto?(this.name=Q.name,this.opType=Q.opType,this.attributes=new l6(Q.attribute)):Q instanceof w4.Node&&(this.name=H??Q.name(),this.opType=Q.opType(),this.attributes=new l6(i1.tensorAttributesFromORTFormat(Q))),this.inputs=[],this.outputs=[],this.executeNode=!0}},Z2=class{constructor(Q,H){if(!Q)throw new TypeError("graph is empty");this.buildGraph(Q),this.transformGraph(H),this.checkIsAcyclic()}getInputIndices(){return this._allInputIndices}getInputNames(){return this._allInputNames}getOutputIndices(){return this._allOutputIndices}getOutputNames(){return this._allOutputNames}getValues(){return this._allData}getNodes(){return this._nodes}buildGraph(Q){if(Q instanceof K6.onnx.GraphProto)this.buildGraphFromOnnxFormat(Q);else if(Q instanceof w4.Graph)this.buildGraphFromOrtFormat(Q);else throw new TypeError("Graph type is not supported.")}buildGraphFromOnnxFormat(Q){let H=new Map;this._allData=[],this._allInputIndices=[],this._allInputNames=[],this._allOutputIndices=[],this._allOutputNames=[],this._nodes=[];let j=new Map;if(!Q.input)throw new Error("missing information in graph: input");let K=[];for(let W of Q.input){if(H.has(W.name))throw new Error(`duplicated input name: ${W.name}`);let U=this._allData.push(new B3(W))-1;H.set(W.name,U),K.push(W.name)}if(!Q.initializer)throw new Error("missing information in graph: initializer");for(let W of Q.initializer){let U=H.get(W.name);if(U===void 0){let Z=new B3;Z.type={shape:{dims:i1.tensorDimsFromProto(W.dims)},tensorType:i1.tensorDataTypeFromProto(W.dataType)},U=this._allData.push(Z)-1,H.set(W.name,U)}this._allData[U]._from=-1,this._allData[U].tensor=o1.fromProto(W)}for(let W=0;W<this._allData.length;W++)this._allData[W].tensor||(this._allInputIndices.push(W),this._allInputNames.push(K[W]));if(!Q.output)throw new Error("missing information in graph: output");for(let W of Q.output){if(H.has(W.name))throw new Error(`duplicated output name: ${W.name}`);let U=this._allData.push(new B3(W))-1;H.set(W.name,U),this._allOutputIndices.push(U),this._allOutputNames.push(W.name)}if(!Q.node)throw new Error("missing information in graph: node");for(let W of Q.node){if(!W.name)for(let Z=0;;Z++){let q=`unnamed_${W.opType}_${Z}`;if(!j.has(q)){W.name=q;break}}if(j.has(W.name))throw new Error(`duplicated node name: ${W.name}`);let U=this._nodes.push(new U6(W))-1;j.set(W.name,U)}for(let W=0;W<this._nodes.length;W++){let U=this._nodes[W],Z=Q.node[W];if(!Z.output)throw new Error(`missing output for node: ${Z.name}`);for(let q of Z.output){let G=H.get(q);if(typeof G>"u"&&(G=this._allData.push(new B3)-1,H.set(q,G)),U.outputs.push(G),this._allData[G]._from!==void 0)throw new Error(`multiple nodes output to one data value: ${G}`);if(this._allData[G]._from=W,Z.opType==="Constant"){if(!Z.attribute||Z.attribute.length!==1||!Z.attribute[0].t)throw new Error("missing attributes or missing tensor value in attributes for this Constant operator");if(!Z.output||Z.output.length!==1)throw new Error("missing output or incorrect number of outputs for this Constant operator");U.outputs.pop(),U.executeNode=!1,this._allData[G]._from=-1,this._allData[G].tensor=o1.fromProto(Z.attribute[0].t)}}}for(let W=0;W<this._nodes.length;W++){let U=this._nodes[W],Z=Q.node[W];if(!Z.input)throw new Error(`missing input for node: ${Z.name}`);for(let q of Z.input){let G=H.get(q);if(typeof G>"u"){if(q===""&&(Z.input.length===3||Z.input.length===4)&&Z.opType==="Resize")continue;throw new Error(`unrecognized input '${q}' for node: ${Z.name}`)}U.inputs.push(G),this._allData[G]._to.push(W)}}return!0}buildGraphFromOrtFormat(Q){let H=new Map;this._allData=[],this._allInputIndices=[],this._allInputNames=[],this._allOutputIndices=[],this._allOutputNames=[],this._nodes=[];let j=new Map,K=[];for(let W=0;W<Q.inputsLength();W++){let U=Q.inputs(W);if(H.has(U))throw new Error(`duplicated input name: ${U}`);for(let Z=0;Z<Q.nodeArgsLength();Z++)if(Q.nodeArgs(Z)?.name()===U){let q=new B3;if(Q.nodeArgs(Z)?.type()?.valueType()!==w4.TypeInfoValue.tensor_type)throw new Error("Unexpected value type for the nodeArg.");let G=Q.nodeArgs(Z).type().value(new w4.TensorTypeAndShape),J=i1.tensorDataTypeFromProto(G.elemType()),X=G.shape(),V=[];for(let z=0;z<X.dimLength();z++)V.push(G3.longToNumber(X.dim(z).value().dimValue()));q.type={shape:{dims:V},tensorType:J};let R=this._allData.push(q)-1;H.set(U,R),K.push(U)}}for(let W=0;W<Q.initializersLength();W++){let U=Q.initializers(W),Z=H.get(U.name());if(Z===void 0){let q=new B3,G=i1.tensorDimsFromORTFormat(U),J=i1.tensorDataTypeFromProto(U.dataType());q.type={shape:{dims:G},tensorType:J},Z=this._allData.push(q)-1,H.set(U.name(),Z)}this._allData[Z]._from=-1,this._allData[Z].tensor=o1.fromOrtTensor(U)}for(let W=0;W<this._allData.length;W++)this._allData[W].tensor||(this._allInputIndices.push(W),this._allInputNames.push(K[W]));for(let W=0;W<Q.outputsLength();W++){let U=Q.outputs(W);if(H.has(U))throw new Error(`duplicated output name: ${U}`);let Z=this._allData.push(new B3)-1;H.set(U,Z),this._allOutputIndices.push(Z),this._allOutputNames.push(U)}if(!Q.nodes)throw new Error("missing information in graph: node");for(let W=0;W<Q.nodesLength();W++){let U=Q.nodes(W),Z=U.name();if(!Z)for(let G=0;Z=`unnamed_${U.opType()}_${G}`,!!j.has(Z);G++);if(j.has(Z))throw new Error(`duplicated node name: ${Z}`);let q=this._nodes.push(new U6(U,Z))-1;j.set(Z,q)}for(let W=0;W<this._nodes.length;W++){let U=this._nodes[W],Z=Q.nodes(W);if(Z==null)throw new Error(`No node exists at index ${W}`);if(Z?.outputsLength()===0)throw new Error(`missing output for node: ${Z.name}`);for(let q=0;q<Z?.outputsLength();q++){let G=Z?.outputs(q),J=H.get(G);if(typeof J>"u"&&(J=this._allData.push(new B3)-1,H.set(G,J)),U.outputs.push(J),this._allData[J]._from!==void 0)throw new Error(`multiple nodes output to one data value: ${J}`);if(this._allData[J]._from=W,Z.opType()==="Constant"){if(Z.attributesLength()!==1||!Z.attributes(0).t())throw new Error("missing attributes or missing tensor value in attributes for this Constant operator");if(Z.outputsLength()!==1)throw new Error("missing output or incorrect number of outputs for this Constant operator");U.outputs.pop(),U.executeNode=!1,this._allData[J]._from=-1,this._allData[J].tensor=o1.fromOrtTensor(Z.attributes(0).t())}}}for(let W=0;W<this._nodes.length;W++){let U=this._nodes[W],Z=Q.nodes(W);if(Z.inputsLength()===0)throw new Error(`missing input for node: ${Z.name}`);for(let q=0;q<Z.inputsLength();q++){let G=Z.inputs(q),J=H.get(G);if(typeof J>"u")throw new Error(`unrecognized input '${G}' for node: ${Z.name()}`);U.inputs.push(J),this._allData[J]._to.push(W)}}}checkIsAcyclic(){let Q=new Set;this._allInputIndices.forEach((K)=>{this._allData[K]._to.forEach((W)=>{Q.add(W)})});let H=Array.from(Q),j=new Array(this._nodes.length).fill("white");for(;H.length>0;){let K=H.pop();j[K]==="gray"?j[K]="black":(H.push(K),j[K]="gray",this._nodes[K].outputs.forEach((W)=>{let U=this._allData[W];if(typeof U.tensor<"u")throw new Error("node outputs should not be initialized");if(U._from!==K)throw new Error("from property of the Value object doesn't match index of Node being processed");U._to.forEach((Z)=>{if(j[Z]==="gray")throw new Error("model graph is cyclic");j[Z]==="white"&&H.push(Z)})}))}}transformGraph(Q){this.removeAllIdentityNodes(),this.removeAllDropoutNodes(),this.fuseConvActivationNodes(),Q&&Q.transformGraph(this),this.finalizeGraph()}finalizeGraph(){let Q=0,H=new Array(this._nodes.length,0),j=0;for(let K=0;K<this._nodes.length;K++)H[K]=j,this._nodes[K].executeNode?(j!==K&&(this._nodes[j]=this._nodes[K]),j++):this._nodes[K].outputs.forEach((W)=>{this._allData[W]._from=-2});this._nodes.splice(j,this._nodes.length-j);for(let K=0;K<this._allData.length;K++){let W=this._allData[K];W._from!==void 0&&W._from!==-1&&W._from!==-2&&(W._from=H[W._from]);for(let U=0;U<W._to.length;U++)if(W._to[U]>=0)W._to[U]=H[W._to[U]];else throw new Error("Trying to update a removed node")}Q=0;for(let K=0;K<this._allData.length;K++){if(this._allData[K].from===-2&&this._allOutputIndices.indexOf(K+Q)===-1){Q++,this._allData.splice(K,1),K--;continue}if(Q>0){let W=-1;this._allData[K].from!==void 0&&this._allData[K].from!==-1?(W=this._nodes[this._allData[K].from].outputs.indexOf(K+Q),W!==-1&&(this._nodes[this._allData[K].from].outputs[W]=K)):(W=this._allInputIndices.indexOf(K+Q),W!==-1&&(this._allInputIndices[W]=K)),this._allData[K].to.forEach((U)=>{W=this._nodes[U].inputs.indexOf(K+Q),W!==-1&&(this._nodes[U].inputs[W]=K)}),this._allData[K].to.length===0&&(W=this._allOutputIndices.indexOf(K+Q),W!==-1&&(this._allOutputIndices[W]=K))}}}deleteNode(Q){let H=this._nodes[Q];if(H.outputs.length>1){for(let Z=1;Z<H.outputs.length;Z++)if(this._allData[H.outputs[Z]].to.length>0)throw new Error("Node deletion with more than one output connected to other nodes is not supported. ")}H.executeNode=!1;let j=H.inputs[0],K=H.outputs[0],W=this._allData[K].to;for(let Z=0;Z<H.inputs.length;Z++){let q=this._allData[H.inputs[Z]].to.indexOf(Q);if(q===-1)throw new Error("The Value object doesn't have the current Node in it's 'to' property ");this._allData[H.inputs[Z]].to.splice(q,1)}this._allData[K]._to=[];let U=this._allOutputIndices.indexOf(K);if(U!==-1&&(this._allOutputIndices[U]=j),W&&W.length>0)for(let Z of W){let q=this._nodes[Z].inputs.indexOf(K);if(q===-1)throw new Error("The Node object doesn't have the output Value in it's 'inputs' property ");this._nodes[Z].inputs[q]=j,this._allData[j].to.push(Z)}}removeAllDropoutNodes(){let Q=0;for(let H of this._nodes){if(H.opType==="Dropout"){if(H.inputs.length!==1)throw new Error("Dropout nodes should only contain one input. ");if(H.outputs.length!==1&&H.outputs.length!==2)throw new Error("Dropout nodes should contain either 1 or 2 output(s)");if(H.outputs.length===2&&this._allData[H.outputs[1]]._to.length!==0)throw new Error("Dropout nodes's second output should not be referenced by other nodes");this.deleteNode(Q)}Q++}}removeAllIdentityNodes(){let Q=0;for(let H of this._nodes)H.opType==="Identity"&&this.deleteNode(Q),Q++}isActivation(Q){switch(Q.opType){case"Relu":case"Sigmoid":case"Clip":return!0;default:return!1}}fuseConvActivationNodes(){for(let Q of this._nodes)if(Q.opType==="Conv"){let H=this._allData[Q.outputs[0]]._to;if(H.length===1&&this.isActivation(this._nodes[H[0]])){let j=this._nodes[H[0]];if(j.opType==="Clip")if(j.inputs.length===1)try{Q.attributes.set("activation_params","floats",[j.attributes.getFloat("min"),j.attributes.getFloat("max")])}catch{Q.attributes.set("activation_params","floats",[h4,b4])}else if(j.inputs.length>=3&&this._allData[j.inputs[1]].tensor!==void 0&&this._allData[j.inputs[2]].tensor!==void 0)Q.attributes.set("activation_params","floats",[this._allData[j.inputs[1]].tensor.floatData[0],this._allData[j.inputs[2]].tensor.floatData[0]]);else continue;Q.attributes.set("activation","string",j.opType),this.deleteNode(H[0])}}}}}),j2,V2,TJ,zV=E(()=>{H7(),RV(),B5(),j2=Z4(l4()),Q1(),V2=H1.experimental.fbs,TJ=class{constructor(){}load(Q,H,j){let K;if(!j)try{this.loadFromOnnxFormat(Q,H);return}catch(W){if(j!==void 0)throw W;K=W}try{this.loadFromOrtFormat(Q,H)}catch(W){throw j!==void 0?W:new Error(`Failed to load model as ONNX format: ${K}
+as ORT format: ${W}`)}}loadFromOnnxFormat(Q,H){let j=j2.onnx.ModelProto.decode(Q);if(G3.longToNumber(j.irVersion)<3)throw new Error("only support ONNX model with IR_VERSION>=3");this._opsets=j.opsetImport.map((K)=>({domain:K.domain,version:G3.longToNumber(K.version)})),this._graph=u6.from(j.graph,H)}loadFromOrtFormat(Q,H){let j=new $.ByteBuffer(Q),K=V2.InferenceSession.getRootAsInferenceSession(j).model();if(G3.longToNumber(K.irVersion())<3)throw new Error("only support ONNX model with IR_VERSION>=3");this._opsets=[];for(let W=0;W<K.opsetImportLength();W++){let U=K.opsetImport(W);this._opsets.push({domain:U?.domain(),version:G3.longToNumber(U.version())})}this._graph=u6.from(K.graph(),H)}get graph(){return this._graph}get opsets(){return this._opsets}}}),DJ,NV=E(()=>{qV(),WV(),V3(),zV(),DJ=class{constructor(Q={}){this._initialized=!1,this.backendHint=Q.backendHint,this.profiler=o2.create(Q.profiler),this.context={profiler:this.profiler,graphInputTypes:[],graphInputDims:[]}}get inputNames(){return this._model.graph.getInputNames()}get outputNames(){return this._model.graph.getOutputNames()}startProfiling(){this.profiler.start()}endProfiling(){this.profiler.stop()}async loadModel(Q,H,j){await this.profiler.event("session","Session.loadModel",async()=>{let K=await D2(this.backendHint);if(this.sessionHandler=K.createSessionHandler(this.context),this._model=new TJ,typeof Q=="string"){let W=Q.endsWith(".ort");if(typeof process<"u"&&process.versions&&process.versions.node){let U=await(void 0)(Q);this.initialize(U,W)}else{let U=await(await fetch(Q)).arrayBuffer();this.initialize(new Uint8Array(U),W)}}else if(ArrayBuffer.isView(Q))this.initialize(Q);else{let W=new Uint8Array(Q,H||0,j||Q.byteLength);this.initialize(W)}})}initialize(Q,H){if(this._initialized)throw new Error("already initialized");this.profiler.event("session","Session.initialize",()=>{let j=this.sessionHandler.transformGraph?this.sessionHandler:void 0;this._model.load(Q,j,H),this.sessionHandler.onGraphInitialized&&this.sessionHandler.onGraphInitialized(this._model.graph),this.initializeOps(this._model.graph),this._executionPlan=new wJ(this._model.graph,this._ops,this.profiler)}),this._initialized=!0}async run(Q){if(!this._initialized)throw new Error("session not initialized yet");return this.profiler.event("session","Session.run",async()=>{let H=this.normalizeAndValidateInputs(Q),j=await this._executionPlan.execute(this.sessionHandler,H);return this.createOutput(j)})}normalizeAndValidateInputs(Q){let H=this._model.graph.getInputNames();if(Array.isArray(Q)){if(Q.length!==H.length)throw new Error(`incorrect input array length: expected ${H.length} but got ${Q.length}`)}else{if(Q.size!==H.length)throw new Error(`incorrect input map size: expected ${H.length} but got ${Q.size}`);let j=new Array(Q.size),K=0;for(let W=0;W<H.length;++W){let U=Q.get(H[W]);if(!U)throw new Error(`missing input tensor for: '${name}'`);j[K++]=U}Q=j}if(!this.context.graphInputTypes||this.context.graphInputTypes.length===0||!this.context.graphInputDims||this.context.graphInputDims.length===0){let j=this._model.graph.getInputIndices(),K=this._model.graph.getValues(),W=new Array(j.length);for(let U=0;U<j.length;++U){let Z=K[j[U]];W[U]=Z.type.shape.dims,this.context.graphInputTypes.push(Z.type.tensorType),this.context.graphInputDims.push(Q[U].dims)}this.validateInputTensorDims(W,Q,!0)}else this.validateInputTensorDims(this.context.graphInputDims,Q,!1);return this.validateInputTensorTypes(this.context.graphInputTypes,Q),Q}validateInputTensorTypes(Q,H){for(let j=0;j<H.length;j++){let K=Q[j],W=H[j].type;if(K!==W)throw new Error(`input tensor[${j}] check failed: expected type '${K}' but got ${W}`)}}validateInputTensorDims(Q,H,j){for(let K=0;K<H.length;K++){let W=Q[K],U=H[K].dims;if(!this.compareTensorDims(W,U,j))throw new Error(`input tensor[${K}] check failed: expected shape '[${W.join(",")}]' but got [${U.join(",")}]`)}}compareTensorDims(Q,H,j){if(Q.length!==H.length)return!1;for(let K=0;K<Q.length;++K)if(Q[K]!==H[K]&&(!j||Q[K]!==0))return!1;return!0}createOutput(Q){let H=this._model.graph.getOutputNames();if(Q.length!==H.length)throw new Error("expected number of outputs do not match number of generated outputs");let j=new Map;for(let K=0;K<H.length;++K)j.set(H[K],Q[K]);return j}initializeOps(Q){let H=Q.getNodes();this._ops=new Array(H.length);for(let j=0;j<H.length;j++)this._ops[j]=this.sessionHandler.resolve(H[j],this._model.opsets,Q)}}}),_J,MV=E(()=>{z3(),K4(),_J=class{constructor(Q){this.session=Q,this.inputNames=this.session.inputNames,this.outputNames=this.session.outputNames}async dispose(){}async run(Q,H,j){let K=new Map;for(let Z in Q)if(Object.hasOwnProperty.call(Q,Z)){let q=Q[Z];K.set(Z,new o1(q.dims,q.type,void 0,void 0,q.data))}let W=await this.session.run(K),U={};return W.forEach((Z,q)=>{U[q]=new d1(Z.type,Z.data,Z.dims)}),U}startProfiling(){this.session.startProfiling()}endProfiling(){this.session.endProfiling()}}}),PJ={};X4(PJ,{onnxjsBackend:()=>EJ});var X2,EJ,YV=E(()=>{NV(),MV(),X2=class{async init(){}async createInferenceSessionHandler(Q,H){let j=new DJ(H);return typeof Q=="string"?await j.loadModel(Q):await j.loadModel(Q),new _J(j)}},EJ=new X2}),q7={};X4(q7,{createReadStream:()=>OJ,readFile:()=>IJ,readFileSync:()=>xJ});var IJ,xJ,OJ,gJ=E(()=>{IJ=void 0,xJ=void 0,OJ=void 0}),W7={};X4(W7,{join:()=>yJ});var yJ,dJ=E(()=>{yJ=void 0}),CV=U1((Q,H)=>{var j=(()=>{var K=typeof document<"u"?document.currentScript?.src:void 0;return typeof G5<"u"&&(K||=G5),function(W={}){var U=W,Z,q,G=new Promise((M,S)=>{Z=M,q=S}),J=Object.assign({},U),X="./this.program",V=typeof window=="object",R=typeof importScripts=="function",z=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",Y="",B,k,w;if(z){var A=(gJ(),a3(q7)),D=(dJ(),a3(W7));Y=R?D.dirname(Y)+"/":r6+"/",B=(M,S)=>(M=O1(M)?new URL(M):D.normalize(M),A.readFileSync(M,S?void 0:"utf8")),w=(M)=>(M=B(M,!0),M.buffer||(M=new Uint8Array(M)),M),k=(M,S,L,P=!0)=>{M=O1(M)?new URL(M):D.normalize(M),A.readFile(M,P?void 0:"utf8",(d,m)=>{d?L(d):S(P?m.buffer:m)})},!U.thisProgram&&1<process.argv.length&&(X=process.argv[1].replace(/\\/g,"/")),process.argv.slice(2)}else(V||R)&&(R?Y=self.location.href:typeof document<"u"&&document.currentScript&&(Y=document.currentScript.src),K&&(Y=K),Y.startsWith("blob:")?Y="":Y=Y.substr(0,Y.replace(/[?#].*/,"").lastIndexOf("/")+1),B=(M)=>{var S=new XMLHttpRequest;return S.open("GET",M,!1),S.send(null),S.responseText},R&&(w=(M)=>{var S=new XMLHttpRequest;return S.open("GET",M,!1),S.responseType="arraybuffer",S.send(null),new Uint8Array(S.response)}),k=(M,S,L)=>{var P=new XMLHttpRequest;P.open("GET",M,!0),P.responseType="arraybuffer",P.onload=()=>{P.status==200||P.status==0&&P.response?S(P.response):L()},P.onerror=L,P.send(null)});var I=console.log.bind(console),h=console.error.bind(console);Object.assign(U,J),J=null;var $1,L1=!1,x1,G1,p,S1,I3;function x3(){var M=$1.buffer;U.HEAP8=x1=new Int8Array(M),U.HEAP16=new Int16Array(M),U.HEAPU8=G1=new Uint8Array(M),U.HEAPU16=new Uint16Array(M),U.HEAP32=p=new Int32Array(M),U.HEAPU32=S1=new Uint32Array(M),U.HEAPF32=new Float32Array(M),U.HEAPF64=I3=new Float64Array(M)}var k3=[],R1=[],l=[],h1=0,X3=null,v1=null;function b1(M){throw M="Aborted("+M+")",h(M),L1=!0,M=new WebAssembly.RuntimeError(M+". Build with -sASSERTIONS for more info."),q(M),M}var P1=(M)=>M.startsWith("data:application/octet-stream;base64,"),O1=(M)=>M.startsWith("file://"),m1;if(m1="ort-wasm.wasm",!P1(m1)){var A3=m1;m1=U.locateFile?U.locateFile(A3,Y):Y+A3}function c1(M){if(w)return w(M);throw"both async and sync fetching of the wasm failed"}function r3(M){if(V||R){if(typeof fetch=="function"&&!O1(M))return fetch(M,{credentials:"same-origin"}).then((S)=>{if(!S.ok)throw`failed to load wasm binary file at '${M}'`;return S.arrayBuffer()}).catch(()=>c1(M));if(k)return new Promise((S,L)=>{k(M,(P)=>S(new Uint8Array(P)),L)})}return Promise.resolve().then(()=>c1(M))}function a1(M,S,L){return r3(M).then((P)=>WebAssembly.instantiate(P,S)).then(L,(P)=>{h(`failed to asynchronously prepare wasm: ${P}`),b1(P)})}function J3(M,S){var L=m1;return typeof WebAssembly.instantiateStreaming!="function"||P1(L)||O1(L)||z||typeof fetch!="function"?a1(L,M,S):fetch(L,{credentials:"same-origin"}).then((P)=>WebAssembly.instantiateStreaming(P,M).then(S,function(d){return h(`wasm streaming compile failed: ${d}`),h("falling back to ArrayBuffer instantiation"),a1(L,M,S)}))}var H3,z1={798088:(M,S,L,P)=>{if(typeof U>"u"||!U.ya)return 1;if(M=N3(M>>>0),M.startsWith("./")&&(M=M.substring(2)),M=U.ya.get(M),!M)return 2;if(S>>>=0,L>>>=0,S+L>M.byteLength)return 3;try{return G1.set(M.subarray(S,S+L),P>>>0>>>0),0}catch{return 4}}};class k1{constructor(M){this.wa=M-24}}var g1=0,O3=0,g3=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,G4=(M,S,L)=>{S>>>=0;var P=S+L;for(L=S;M[L]&&!(L>=P);)++L;if(16<L-S&&M.buffer&&g3)return g3.decode(M.subarray(S,L));for(P="";S<L;){var d=M[S++];if(d&128){var m=M[S++]&63;if((d&224)==192)P+=String.fromCharCode((d&31)<<6|m);else{var a=M[S++]&63;d=(d&240)==224?(d&15)<<12|m<<6|a:(d&7)<<18|m<<12|a<<6|M[S++]&63,65536>d?P+=String.fromCharCode(d):(d-=65536,P+=String.fromCharCode(55296|d>>10,56320|d&1023))}}else P+=String.fromCharCode(d)}return P},N3=(M,S)=>(M>>>=0)?G4(G1,M,S):"",S3=(M)=>{for(var S=0,L=0;L<M.length;++L){var P=M.charCodeAt(L);127>=P?S++:2047>=P?S+=2:55296<=P&&57343>=P?(S+=4,++L):S+=3}return S},M3=(M,S,L,P)=>{if(L>>>=0,!(0<P))return 0;var d=L;P=L+P-1;for(var m=0;m<M.length;++m){var a=M.charCodeAt(m);if(55296<=a&&57343>=a){var A1=M.charCodeAt(++m);a=65536+((a&1023)<<10)|A1&1023}if(127>=a){if(L>=P)break;S[L++>>>0]=a}else{if(2047>=a){if(L+1>=P)break;S[L++>>>0]=192|a>>6}else{if(65535>=a){if(L+2>=P)break;S[L++>>>0]=224|a>>12}else{if(L+3>=P)break;S[L++>>>0]=240|a>>18,S[L++>>>0]=128|a>>12&63}S[L++>>>0]=128|a>>6&63}S[L++>>>0]=128|a&63}}return S[L>>>0]=0,L-d},$3=(M)=>M%4===0&&(M%100!==0||M%400===0),R4=[0,31,60,91,121,152,182,213,244,274,305,335],i4=[0,31,59,90,120,151,181,212,243,273,304,334],K3=[],t3={},y3=()=>{if(!d3){var M={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",_:X||"./this.program"},S;for(S in t3)t3[S]===void 0?delete M[S]:M[S]=t3[S];var L=[];for(S in M)L.push(`${S}=${M[S]}`);d3=L}return d3},d3,o4=[null,[],[]],Y3=[31,29,31,30,31,30,31,31,30,31,30,31],a4=[31,28,31,30,31,30,31,31,30,31,30,31];function j1(M){var S=Array(S3(M)+1);return M3(M,S,0,S.length),S}function z4(M,S,L,P){function d(T,J1,q1){for(T=typeof T=="number"?T.toString():T||"";T.length<J1;)T=q1[0]+T;return T}function m(T,J1){return d(T,J1,"0")}function a(T,J1){function q1(B4){return 0>B4?-1:0<B4?1:0}var U3;return(U3=q1(T.getFullYear()-J1.getFullYear()))===0&&(U3=q1(T.getMonth()-J1.getMonth()))===0&&(U3=q1(T.getDate()-J1.getDate())),U3}function A1(T){switch(T.getDay()){case 0:return new Date(T.getFullYear()-1,11,29);case 1:return T;case 2:return new Date(T.getFullYear(),0,3);case 3:return new Date(T.getFullYear(),0,2);case 4:return new Date(T.getFullYear(),0,1);case 5:return new Date(T.getFullYear()-1,11,31);case 6:return new Date(T.getFullYear()-1,11,30)}}function f1(T){var J1=T.sa;for(T=new Date(new Date(T.ta+1900,0,1).getTime());0<J1;){var q1=T.getMonth(),U3=($3(T.getFullYear())?Y3:a4)[q1];if(J1>U3-T.getDate())J1-=U3-T.getDate()+1,T.setDate(1),11>q1?T.setMonth(q1+1):(T.setMonth(0),T.setFullYear(T.getFullYear()+1));else{T.setDate(T.getDate()+J1);break}}return q1=new Date(T.getFullYear()+1,0,4),J1=A1(new Date(T.getFullYear(),0,4)),q1=A1(q1),0>=a(J1,T)?0>=a(q1,T)?T.getFullYear()+1:T.getFullYear():T.getFullYear()-1}M>>>=0,S>>>=0,L>>>=0,P>>>=0;var T1=S1[P+40>>>2>>>0];P={Ba:p[P>>>2>>>0],Aa:p[P+4>>>2>>>0],ua:p[P+8>>>2>>>0],xa:p[P+12>>>2>>>0],va:p[P+16>>>2>>>0],ta:p[P+20>>>2>>>0],na:p[P+24>>>2>>>0],sa:p[P+28>>>2>>>0],Da:p[P+32>>>2>>>0],za:p[P+36>>>2>>>0],Ca:T1?N3(T1):""},L=N3(L),T1={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var D1 in T1)L=L.replace(new RegExp(D1,"g"),T1[D1]);var C4="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),L3="January February March April May June July August September October November December".split(" ");T1={"%a":(T)=>C4[T.na].substring(0,3),"%A":(T)=>C4[T.na],"%b":(T)=>L3[T.va].substring(0,3),"%B":(T)=>L3[T.va],"%C":(T)=>m((T.ta+1900)/100|0,2),"%d":(T)=>m(T.xa,2),"%e":(T)=>d(T.xa,2," "),"%g":(T)=>f1(T).toString().substring(2),"%G":f1,"%H":(T)=>m(T.ua,2),"%I":(T)=>(T=T.ua,T==0?T=12:12<T&&(T-=12),m(T,2)),"%j":(T)=>{for(var J1=0,q1=0;q1<=T.va-1;J1+=($3(T.ta+1900)?Y3:a4)[q1++]);return m(T.xa+J1,3)},"%m":(T)=>m(T.va+1,2),"%M":(T)=>m(T.Aa,2),"%n":()=>`
+`,"%p":(T)=>0<=T.ua&&12>T.ua?"AM":"PM","%S":(T)=>m(T.Ba,2),"%t":()=>"	","%u":(T)=>T.na||7,"%U":(T)=>m(Math.floor((T.sa+7-T.na)/7),2),"%V":(T)=>{var J1=Math.floor((T.sa+7-(T.na+6)%7)/7);if(2>=(T.na+371-T.sa-2)%7&&J1++,J1)J1==53&&(q1=(T.na+371-T.sa)%7,q1==4||q1==3&&$3(T.ta)||(J1=1));else{J1=52;var q1=(T.na+7-T.sa-1)%7;(q1==4||q1==5&&$3(T.ta%400-1))&&J1++}return m(J1,2)},"%w":(T)=>T.na,"%W":(T)=>m(Math.floor((T.sa+7-(T.na+6)%7)/7),2),"%y":(T)=>(T.ta+1900).toString().substring(2),"%Y":(T)=>T.ta+1900,"%z":(T)=>{T=T.za;var J1=0<=T;return T=Math.abs(T)/60,(J1?"+":"-")+("0000"+(T/60*100+T%60)).slice(-4)},"%Z":(T)=>T.Ca,"%%":()=>"%"},L=L.replace(/%%/g,"\0\0");for(D1 in T1)L.includes(D1)&&(L=L.replace(new RegExp(D1,"g"),T1[D1](P)));return L=L.replace(/\0\0/g,"%"),D1=j1(L),D1.length>S?0:(x1.set(D1,M>>>0),D1.length-1)}var N4={a:function(M,S,L){M>>>=0;var P=new k1(M);throw S1[P.wa+16>>>2>>>0]=0,S1[P.wa+4>>>2>>>0]=S>>>0,S1[P.wa+8>>>2>>>0]=L>>>0,g1=M,O3++,g1},e:function(){return 0},H:function(){},x:function(){},z:function(){},J:function(){return 0},F:function(){},A:function(){},E:function(){},g:function(){},y:function(){},v:function(){},G:function(){},w:function(){},k:()=>1,I:function(M,S,L){return S>>>=0,G1.copyWithin(M>>>0>>>0,S>>>0,S+(L>>>0)>>>0)},n:function(M,S,L){M=S+2097152>>>0<4194305-!!M?(M>>>0)+4294967296*S:NaN,L>>>=0,M=new Date(1000*M),p[L>>>2>>>0]=M.getUTCSeconds(),p[L+4>>>2>>>0]=M.getUTCMinutes(),p[L+8>>>2>>>0]=M.getUTCHours(),p[L+12>>>2>>>0]=M.getUTCDate(),p[L+16>>>2>>>0]=M.getUTCMonth(),p[L+20>>>2>>>0]=M.getUTCFullYear()-1900,p[L+24>>>2>>>0]=M.getUTCDay(),p[L+28>>>2>>>0]=(M.getTime()-Date.UTC(M.getUTCFullYear(),0,1,0,0,0,0))/86400000|0},o:function(M,S,L){M=S+2097152>>>0<4194305-!!M?(M>>>0)+4294967296*S:NaN,L>>>=0,M=new Date(1000*M),p[L>>>2>>>0]=M.getSeconds(),p[L+4>>>2>>>0]=M.getMinutes(),p[L+8>>>2>>>0]=M.getHours(),p[L+12>>>2>>>0]=M.getDate(),p[L+16>>>2>>>0]=M.getMonth(),p[L+20>>>2>>>0]=M.getFullYear()-1900,p[L+24>>>2>>>0]=M.getDay(),p[L+28>>>2>>>0]=($3(M.getFullYear())?R4:i4)[M.getMonth()]+M.getDate()-1|0,p[L+36>>>2>>>0]=-(60*M.getTimezoneOffset()),S=new Date(M.getFullYear(),6,1).getTimezoneOffset();var P=new Date(M.getFullYear(),0,1).getTimezoneOffset();p[L+32>>>2>>>0]=(S!=P&&M.getTimezoneOffset()==Math.min(P,S))|0},p:function(M){M>>>=0;var S=new Date(p[M+20>>>2>>>0]+1900,p[M+16>>>2>>>0],p[M+12>>>2>>>0],p[M+8>>>2>>>0],p[M+4>>>2>>>0],p[M>>>2>>>0],0),L=p[M+32>>>2>>>0],P=S.getTimezoneOffset(),d=new Date(S.getFullYear(),6,1).getTimezoneOffset(),m=new Date(S.getFullYear(),0,1).getTimezoneOffset(),a=Math.min(m,d);return 0>L?p[M+32>>>2>>>0]=+(d!=m&&a==P):0<L!=(a==P)&&(d=Math.max(m,d),S.setTime(S.getTime()+60000*((0<L?a:d)-P))),p[M+24>>>2>>>0]=S.getDay(),p[M+28>>>2>>>0]=($3(S.getFullYear())?R4:i4)[S.getMonth()]+S.getDate()-1|0,p[M>>>2>>>0]=S.getSeconds(),p[M+4>>>2>>>0]=S.getMinutes(),p[M+8>>>2>>>0]=S.getHours(),p[M+12>>>2>>>0]=S.getDate(),p[M+16>>>2>>>0]=S.getMonth(),p[M+20>>>2>>>0]=S.getYear(),M=S.getTime(),M=isNaN(M)?-1:M/1000,M4((H3=M,1<=+Math.abs(H3)?0<H3?+Math.floor(H3/4294967296)>>>0:~~+Math.ceil((H3-+(~~H3>>>0))/4294967296)>>>0:0)),M>>>0},l:function(){return-52},m:function(){},t:function(M,S,L,P){L>>>=0,P>>>=0;var d=(new Date()).getFullYear(),m=new Date(d,0,1),a=new Date(d,6,1);d=m.getTimezoneOffset();var A1=a.getTimezoneOffset();S1[M>>>0>>>2>>>0]=60*Math.max(d,A1),p[S>>>0>>>2>>>0]=+(d!=A1),M=(f1)=>f1.toLocaleTimeString(void 0,{hour12:!1,timeZoneName:"short"}).split(" ")[1],m=M(m),a=M(a),A1<d?(M3(m,G1,L,17),M3(a,G1,P,17)):(M3(m,G1,P,17),M3(a,G1,L,17))},d:()=>{b1("")},B:function(M,S,L){M>>>=0,S>>>=0,L>>>=0,K3.length=0;for(var P;P=G1[S++>>>0];){var d=P!=105;d&=P!=112,L+=d&&L%8?4:0,K3.push(P==112?S1[L>>>2>>>0]:P==105?p[L>>>2>>>0]:I3[L>>>3>>>0]),L+=d?8:4}return z1[M](...K3)},h:()=>Date.now(),u:function(){return 4294901760},b:()=>performance.now(),s:function(M){M>>>=0;var S=G1.length;if(4294901760<M)return!1;for(var L=1;4>=L;L*=2){var P=S*(1+0.2/L);P=Math.min(P,M+100663296);var d=Math;P=Math.max(M,P);Q:{d=(d.min.call(d,4294901760,P+(65536-P%65536)%65536)-$1.buffer.byteLength+65535)/65536;try{$1.grow(d),x3();var m=1;break Q}catch{}m=void 0}if(m)return!0}return!1},C:function(M,S){M>>>=0,S>>>=0;var L=0;return y3().forEach((P,d)=>{var m=S+L;for(d=S1[M+4*d>>>2>>>0]=m,m=0;m<P.length;++m)x1[d++>>>0]=P.charCodeAt(m);x1[d>>>0]=0,L+=P.length+1}),0},D:function(M,S){M>>>=0,S>>>=0;var L=y3();S1[M>>>2>>>0]=L.length;var P=0;return L.forEach((d)=>P+=d.length+1),S1[S>>>2>>>0]=P,0},f:()=>52,j:function(){return 52},q:function(){return 70},i:function(M,S,L,P){S>>>=0,L>>>=0,P>>>=0;for(var d=0,m=0;m<L;m++){var a=S1[S>>>2>>>0],A1=S1[S+4>>>2>>>0];S+=8;for(var f1=0;f1<A1;f1++){var T1=G1[a+f1>>>0],D1=o4[M];T1===0||T1===10?((M===1?I:h)(G4(D1,0)),D1.length=0):D1.push(T1)}d+=A1}return S1[P>>>2>>>0]=d,0},r:z4,c:function(M,S,L,P){return z4(M>>>0,S>>>0,L>>>0,P>>>0)}},s=function(){function M(L){return s=L.exports,s=r4(),$1=s.K,x3(),R1.unshift(s.L),h1--,h1==0&&(X3!==null&&(clearInterval(X3),X3=null),v1&&(L=v1,v1=null,L())),s}var S={a:N4};if(h1++,U.instantiateWasm)try{return U.instantiateWasm(S,M)}catch(L){h(`Module.instantiateWasm callback failed with error: ${L}`),q(L)}return J3(S,function(L){M(L.instance)}).catch(q),{}}();U._OrtInit=(M,S)=>(U._OrtInit=s.M)(M,S),U._OrtGetLastError=(M,S)=>(U._OrtGetLastError=s.N)(M,S),U._OrtCreateSessionOptions=(M,S,L,P,d,m,a,A1,f1,T1)=>(U._OrtCreateSessionOptions=s.O)(M,S,L,P,d,m,a,A1,f1,T1),U._OrtAppendExecutionProvider=(M,S)=>(U._OrtAppendExecutionProvider=s.P)(M,S),U._OrtAddFreeDimensionOverride=(M,S,L)=>(U._OrtAddFreeDimensionOverride=s.Q)(M,S,L),U._OrtAddSessionConfigEntry=(M,S,L)=>(U._OrtAddSessionConfigEntry=s.R)(M,S,L),U._OrtReleaseSessionOptions=(M)=>(U._OrtReleaseSessionOptions=s.S)(M),U._OrtCreateSession=(M,S,L)=>(U._OrtCreateSession=s.T)(M,S,L),U._OrtReleaseSession=(M)=>(U._OrtReleaseSession=s.U)(M),U._OrtGetInputOutputCount=(M,S,L)=>(U._OrtGetInputOutputCount=s.V)(M,S,L),U._OrtGetInputName=(M,S)=>(U._OrtGetInputName=s.W)(M,S),U._OrtGetOutputName=(M,S)=>(U._OrtGetOutputName=s.X)(M,S),U._OrtFree=(M)=>(U._OrtFree=s.Y)(M),U._OrtCreateTensor=(M,S,L,P,d,m)=>(U._OrtCreateTensor=s.Z)(M,S,L,P,d,m),U._OrtGetTensorData=(M,S,L,P,d)=>(U._OrtGetTensorData=s._)(M,S,L,P,d),U._OrtReleaseTensor=(M)=>(U._OrtReleaseTensor=s.$)(M),U._OrtCreateRunOptions=(M,S,L,P)=>(U._OrtCreateRunOptions=s.aa)(M,S,L,P),U._OrtAddRunConfigEntry=(M,S,L)=>(U._OrtAddRunConfigEntry=s.ba)(M,S,L),U._OrtReleaseRunOptions=(M)=>(U._OrtReleaseRunOptions=s.ca)(M),U._OrtCreateBinding=(M)=>(U._OrtCreateBinding=s.da)(M),U._OrtBindInput=(M,S,L)=>(U._OrtBindInput=s.ea)(M,S,L),U._OrtBindOutput=(M,S,L,P)=>(U._OrtBindOutput=s.fa)(M,S,L,P),U._OrtClearBoundOutputs=(M)=>(U._OrtClearBoundOutputs=s.ga)(M),U._OrtReleaseBinding=(M)=>(U._OrtReleaseBinding=s.ha)(M),U._OrtRunWithBinding=(M,S,L,P,d)=>(U._OrtRunWithBinding=s.ia)(M,S,L,P,d),U._OrtRun=(M,S,L,P,d,m,a,A1)=>(U._OrtRun=s.ja)(M,S,L,P,d,m,a,A1),U._OrtEndProfiling=(M)=>(U._OrtEndProfiling=s.ka)(M),U._malloc=(M)=>(U._malloc=s.la)(M),U._free=(M)=>(U._free=s.ma)(M);var M4=(M)=>(M4=s.oa)(M),n4=(M)=>(n4=s.pa)(M),c=(M)=>(c=s.qa)(M),p3=()=>(p3=s.ra)();function r4(){var M=s;M=Object.assign({},M);var S=(L)=>(P)=>L(P)>>>0;return M.la=S(M.la),M.qa=S(M.qa),M.ra=((L)=>()=>L()>>>0)(M.ra),M}U.stackSave=()=>p3(),U.stackRestore=(M)=>n4(M),U.stackAlloc=(M)=>c(M),U.UTF8ToString=N3,U.stringToUTF8=(M,S,L)=>M3(M,G1,S,L),U.lengthBytesUTF8=S3;var C3;v1=function M(){C3||Y4(),C3||(v1=M)};function Y4(){if(!(0<h1)){if(U.preRun)for(typeof U.preRun=="function"&&(U.preRun=[U.preRun]);U.preRun.length;){var M=U.preRun.shift();k3.unshift(M)}for(;0<k3.length;)k3.shift()(U);if(!(0<h1||C3||(C3=!0,U.calledRun=!0,L1))){for(;0<R1.length;)R1.shift()(U);for(Z(U);0<l.length;)l.shift()(U)}}}return Y4(),G}})();typeof Q=="object"&&typeof H=="object"?H.exports=j:typeof define=="function"&&define.amd&&define([],()=>j)}),BV=U1(()=>{}),FV=U1(()=>{}),pJ={};X4(pJ,{cpus:()=>hJ});var hJ,kV=E(()=>{hJ=void 0}),AV=U1((Q,H)=>{var j=(()=>{var K=typeof document<"u"?document.currentScript?.src:void 0;return typeof G5<"u"&&(K||=G5),function(W={}){function U(){return l.buffer!=b1.buffer&&c1(),b1}function Z(){return l.buffer!=b1.buffer&&c1(),P1}function q(){return l.buffer!=b1.buffer&&c1(),O1}function G(){return l.buffer!=b1.buffer&&c1(),m1}function J(){return l.buffer!=b1.buffer&&c1(),A3}var X=W,V,R,z=new Promise((N,C)=>{V=N,R=C}),Y=Object.assign({},X),B="./this.program",k=(N,C)=>{throw C},w=typeof window=="object",A=typeof importScripts=="function",D=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",I=X.ENVIRONMENT_IS_PTHREAD||!1,h="";function $1(N){return X.locateFile?X.locateFile(N,h):h+N}var L1,x1,G1;if(D){var p=(gJ(),a3(q7)),S1=(dJ(),a3(W7));h=A?S1.dirname(h)+"/":r6+"/",L1=(N,C)=>(N=N3(N)?new URL(N):S1.normalize(N),p.readFileSync(N,C?void 0:"utf8")),G1=(N)=>(N=L1(N,!0),N.buffer||(N=new Uint8Array(N)),N),x1=(N,C,F,v=!0)=>{N=N3(N)?new URL(N):S1.normalize(N),p.readFile(N,v?void 0:"utf8",(g,x)=>{g?F(g):C(v?x.buffer:x)})},!X.thisProgram&&1<process.argv.length&&(B=process.argv[1].replace(/\\/g,"/")),process.argv.slice(2),k=(N,C)=>{throw process.exitCode=N,C},global.Worker=BV().Worker}else(w||A)&&(A?h=self.location.href:typeof document<"u"&&document.currentScript&&(h=document.currentScript.src),typeof K<"u"&&K&&(h=K),h.startsWith("blob:")?h="":h=h.substr(0,h.replace(/[?#].*/,"").lastIndexOf("/")+1),D||(L1=(N)=>{var C=new XMLHttpRequest;return C.open("GET",N,!1),C.send(null),C.responseText},A&&(G1=(N)=>{var C=new XMLHttpRequest;return C.open("GET",N,!1),C.responseType="arraybuffer",C.send(null),new Uint8Array(C.response)}),x1=(N,C,F)=>{var v=new XMLHttpRequest;v.open("GET",N,!0),v.responseType="arraybuffer",v.onload=()=>{v.status==200||v.status==0&&v.response?C(v.response):F()},v.onerror=F,v.send(null)}));D&&typeof performance>"u"&&(global.performance=FV().performance);var I3=console.log.bind(console),x3=console.error.bind(console);D&&(I3=(...N)=>p.writeSync(1,N.join(" ")+`
+`),x3=(...N)=>p.writeSync(2,N.join(" ")+`
+`));var k3=I3,R1=x3;Object.assign(X,Y),Y=null;var l,h1,X3=!1,v1,b1,P1,O1,m1,A3;function c1(){var N=l.buffer;X.HEAP8=b1=new Int8Array(N),X.HEAP16=new Int16Array(N),X.HEAPU8=P1=new Uint8Array(N),X.HEAPU16=new Uint16Array(N),X.HEAP32=O1=new Int32Array(N),X.HEAPU32=m1=new Uint32Array(N),X.HEAPF32=new Float32Array(N),X.HEAPF64=A3=new Float64Array(N)}var r3=16777216;if(I)l=X.wasmMemory;else if(X.wasmMemory)l=X.wasmMemory;else if(l=new WebAssembly.Memory({initial:r3/65536,maximum:65536,shared:!0}),!(l.buffer instanceof SharedArrayBuffer))throw R1("requested a shared WebAssembly.Memory but the returned buffer is not a SharedArrayBuffer, indicating that while the browser has SharedArrayBuffer it does not have WebAssembly threads support - you may need to set a flag"),D&&R1("(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and/or recent version)"),Error("bad memory");c1(),r3=l.buffer.byteLength;var a1=[],J3=[],H3=[],z1=0,k1=null,g1=null;function O3(){if(z1--,z1==0&&(k1!==null&&(clearInterval(k1),k1=null),g1)){var N=g1;g1=null,N()}}function g3(N){throw N="Aborted("+N+")",R1(N),X3=!0,v1=1,N=new WebAssembly.RuntimeError(N+". Build with -sASSERTIONS for more info."),R(N),N}var G4=(N)=>N.startsWith("data:application/octet-stream;base64,"),N3=(N)=>N.startsWith("file://"),S3;S3="ort-wasm-threaded.wasm",G4(S3)||(S3=$1(S3));function M3(N){if(G1)return G1(N);throw"both async and sync fetching of the wasm failed"}function $3(N){if(w||A){if(typeof fetch=="function"&&!N3(N))return fetch(N,{credentials:"same-origin"}).then((C)=>{if(!C.ok)throw`failed to load wasm binary file at '${N}'`;return C.arrayBuffer()}).catch(()=>M3(N));if(x1)return new Promise((C,F)=>{x1(N,(v)=>C(new Uint8Array(v)),F)})}return Promise.resolve().then(()=>M3(N))}function R4(N,C,F){return $3(N).then((v)=>WebAssembly.instantiate(v,C)).then(F,(v)=>{R1(`failed to asynchronously prepare wasm: ${v}`),g3(v)})}function i4(N,C){var F=S3;return typeof WebAssembly.instantiateStreaming!="function"||G4(F)||N3(F)||D||typeof fetch!="function"?R4(F,N,C):fetch(F,{credentials:"same-origin"}).then((v)=>WebAssembly.instantiateStreaming(v,N).then(C,function(g){return R1(`wasm streaming compile failed: ${g}`),R1("falling back to ArrayBuffer instantiation"),R4(F,N,C)}))}var K3,t3={799444:(N,C,F,v)=>{if(typeof X>"u"||!X.bb)return 1;if(N=A1(N>>>0),N.startsWith("./")&&(N=N.substring(2)),N=X.bb.get(N),!N)return 2;if(C>>>=0,F>>>=0,v>>>=0,C+F>N.byteLength)return 3;try{return Z().set(N.subarray(C,C+F),v>>>0),0}catch{return 4}}};function y3(N){this.name="ExitStatus",this.message=`Program terminated with exit(${N})`,this.status=N}var d3=(N)=>{N.terminate(),N.onmessage=()=>{}},o4=(N)=>{c.Oa.length==0&&(M4(),c.Xa(c.Oa[0]));var C=c.Oa.pop();if(!C)return 6;c.Pa.push(C),c.La[N.Na]=C,C.Na=N.Na;var F={cmd:"run",start_routine:N.gb,arg:N.cb,pthread_ptr:N.Na};return D&&C.unref(),C.postMessage(F,N.mb),0},Y3=0,a4=(N)=>{var C=_5();return N=N(),Q5(C),N},j1=(N,C,...F)=>a4(()=>{for(var v=F.length,g=D5(8*v),x=g>>>3,b=0;b<F.length;b++){var N1=F[b];J()[x+b>>>0]=N1}return O7(N,0,v,g,C)});function z4(N){if(I)return j1(0,1,N);v1=N,0<Y3||(c.hb(),X.onExit?.(N),X3=!0),k(N,new y3(N))}var N4=(N)=>{if(v1=N,I)throw r4(N),"unwind";z4(N)};function s(){for(var N=X.numThreads;N--;)M4();a1.unshift(()=>{z1++,n4(()=>O3())})}function M4(){var N=$1("ort-wasm-threaded.worker.js");N=new Worker(N),c.Oa.push(N)}function n4(N){I?N():Promise.all(c.Oa.map(c.Xa)).then(N)}var c={Oa:[],Pa:[],ab:[],La:{},Va(){I?(c.receiveObjectTransfer=c.fb,c.threadInitTLS=c.$a,c.setExitStatus=c.Za):s()},Za:(N)=>v1=N,pb:["$terminateWorker"],hb:()=>{for(var N of c.Pa)d3(N);for(N of c.Oa)d3(N);c.Oa=[],c.Pa=[],c.La=[]},Ya:(N)=>{var C=N.Na;delete c.La[C],c.Oa.push(N),c.Pa.splice(c.Pa.indexOf(N),1),N.Na=0,w5(C)},fb(){},$a(){c.ab.forEach((N)=>N())},Xa:(N)=>new Promise((C)=>{N.onmessage=(x)=>{x=x.data;var b=x.cmd;if(x.targetThread&&x.targetThread!=e4()){var N1=c.La[x.targetThread];N1?N1.postMessage(x,x.transferList):R1(`Internal error! Worker sent a message "${b}" to target pthread ${x.targetThread}, but that thread no longer exists!`)}else b==="checkMailbox"?t4():b==="spawnThread"?o4(x):b==="cleanupThread"?c.Ya(c.La[x.thread]):b==="killThread"?(x=x.thread,b=c.La[x],delete c.La[x],d3(b),w5(x),c.Pa.splice(c.Pa.indexOf(b),1),b.Na=0):b==="cancelThread"?c.La[x.thread].postMessage({cmd:"cancel"}):b==="loaded"?(N.loaded=!0,D&&!N.Na&&N.unref(),C(N)):b==="alert"?alert(`Thread ${x.threadId}: ${x.text}`):x.target==="setimmediate"?N.postMessage(x):b==="callHandler"?X[x.handler](...x.args):b&&R1(`worker sent an unknown command ${b}`)},N.onerror=(x)=>{throw R1(`worker sent an error! ${x.filename}:${x.lineno}: ${x.message}`),x},D&&(N.on("message",(x)=>N.onmessage({data:x})),N.on("error",(x)=>N.onerror(x)));var F=[],v=["onExit"],g;for(g of v)X.hasOwnProperty(g)&&F.push(g);N.postMessage({cmd:"load",handlers:F,urlOrBlob:X.mainScriptUrlOrBlob||K,wasmMemory:l,wasmModule:h1})})};X.PThread=c;var p3=(N)=>{for(;0<N.length;)N.shift()(X)};X.establishStackSpace=()=>{var N=e4(),C=G()[N+52>>>2>>>0];N=G()[N+56>>>2>>>0],d7(C,C-N),Q5(C)};function r4(N){if(I)return j1(1,0,N);N4(N)}var C3=[],Y4;X.invokeEntryPoint=(N,C)=>{Y3=0;var F=C3[N];F||(N>=C3.length&&(C3.length=N+1),C3[N]=F=Y4.get(N)),N=F(C),0<Y3?c.Za(N):T5(N)};class M{constructor(N){this.Ua=N-24}Va(N,C){G()[this.Ua+16>>>2>>>0]=0,G()[this.Ua+4>>>2>>>0]=N,G()[this.Ua+8>>>2>>>0]=C}}var S=0,L=0;function P(N,C,F,v){return I?j1(2,1,N,C,F,v):d(N,C,F,v)}function d(N,C,F,v){if(N>>>=0,C>>>=0,F>>>=0,v>>>=0,typeof SharedArrayBuffer>"u")return R1("Current environment does not support SharedArrayBuffer, pthreads are not available!"),6;var g=[];return I&&g.length===0?P(N,C,F,v):(N={gb:F,Na:N,cb:v,mb:g},I?(N.ob="spawnThread",postMessage(N,g),0):o4(N))}var m=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,a=(N,C,F)=>{C>>>=0;var v=C+F;for(F=C;N[F]&&!(F>=v);)++F;if(16<F-C&&N.buffer&&m)return m.decode(N.buffer instanceof SharedArrayBuffer?N.slice(C,F):N.subarray(C,F));for(v="";C<F;){var g=N[C++];if(g&128){var x=N[C++]&63;if((g&224)==192)v+=String.fromCharCode((g&31)<<6|x);else{var b=N[C++]&63;g=(g&240)==224?(g&15)<<12|x<<6|b:(g&7)<<18|x<<12|b<<6|N[C++]&63,65536>g?v+=String.fromCharCode(g):(g-=65536,v+=String.fromCharCode(55296|g>>10,56320|g&1023))}}else v+=String.fromCharCode(g)}return v},A1=(N,C)=>(N>>>=0)?a(Z(),N,C):"";function f1(N,C,F){return I?j1(3,1,N,C,F):0}function T1(N,C){if(I)return j1(4,1,N,C)}var D1=(N)=>{for(var C=0,F=0;F<N.length;++F){var v=N.charCodeAt(F);127>=v?C++:2047>=v?C+=2:55296<=v&&57343>=v?(C+=4,++F):C+=3}return C},C4=(N,C,F,v)=>{if(F>>>=0,!(0<v))return 0;var g=F;v=F+v-1;for(var x=0;x<N.length;++x){var b=N.charCodeAt(x);if(55296<=b&&57343>=b){var N1=N.charCodeAt(++x);b=65536+((b&1023)<<10)|N1&1023}if(127>=b){if(F>=v)break;C[F++>>>0]=b}else{if(2047>=b){if(F+1>=v)break;C[F++>>>0]=192|b>>6}else{if(65535>=b){if(F+2>=v)break;C[F++>>>0]=224|b>>12}else{if(F+3>=v)break;C[F++>>>0]=240|b>>18,C[F++>>>0]=128|b>>12&63}C[F++>>>0]=128|b>>6&63}C[F++>>>0]=128|b&63}}return C[F>>>0]=0,F-g},L3=(N,C,F)=>C4(N,Z(),C,F);function T(N,C){if(I)return j1(5,1,N,C)}function J1(N,C,F){if(I)return j1(6,1,N,C,F)}function q1(N,C,F){return I?j1(7,1,N,C,F):0}function U3(N,C){if(I)return j1(8,1,N,C)}function B4(N,C,F){if(I)return j1(9,1,N,C,F)}function z7(N,C,F,v){if(I)return j1(10,1,N,C,F,v)}function N7(N,C,F,v){if(I)return j1(11,1,N,C,F,v)}function M7(N,C,F,v){if(I)return j1(12,1,N,C,F,v)}function Y7(N){if(I)return j1(13,1,N)}function C7(N,C){if(I)return j1(14,1,N,C)}function B7(N,C,F){if(I)return j1(15,1,N,C,F)}function A5(N){N>>>=0,typeof Atomics.nb=="function"&&(Atomics.nb(q(),N>>>2,N).value.then(t4),N+=128,Atomics.store(q(),N>>>2,1))}X.__emscripten_thread_mailbox_await=A5;var t4=()=>{var N=e4();if(N&&(A5(N),N=g7,!X3))try{if(N(),!(0<Y3))try{I?T5(v1):N4(v1)}catch(C){C instanceof y3||C=="unwind"||k(1,C)}}catch(C){C instanceof y3||C=="unwind"||k(1,C)}};X.checkMailbox=t4;var S5=[],e3=(N)=>N%4===0&&(N%100!==0||N%400===0),F7=[0,31,60,91,121,152,182,213,244,274,305,335],k7=[0,31,59,90,120,151,181,212,243,273,304,334];function A7(N,C,F,v,g,x,b,N1){return I?j1(16,1,N,C,F,v,g,x,b,N1):-52}function S7(N,C,F,v,g,x,b){if(I)return j1(17,1,N,C,F,v,g,x,b)}var $5=[],L5={},$7=()=>{if(!v5){var N={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",_:B||"./this.program"},C;for(C in L5)L5[C]===void 0?delete N[C]:N[C]=L5[C];var F=[];for(C in N)F.push(`${C}=${N[C]}`);v5=F}return v5},v5;function L7(N,C){if(I)return j1(18,1,N,C);N>>>=0,C>>>=0;var F=0;return $7().forEach((v,g)=>{var x=C+F;for(g=G()[N+4*g>>>2>>>0]=x,x=0;x<v.length;++x)U()[g++>>>0]=v.charCodeAt(x);U()[g>>>0]=0,F+=v.length+1}),0}function v7(N,C){if(I)return j1(19,1,N,C);N>>>=0,C>>>=0;var F=$7();G()[N>>>2>>>0]=F.length;var v=0;return F.forEach((g)=>v+=g.length+1),G()[C>>>2>>>0]=v,0}function w7(N){return I?j1(20,1,N):52}function T7(N,C,F,v){return I?j1(21,1,N,C,F,v):52}function D7(N,C,F,v,g){return I?j1(22,1,N,C,F,v,g):70}var NH=[null,[],[]];function _7(N,C,F,v){if(I)return j1(23,1,N,C,F,v);C>>>=0,F>>>=0,v>>>=0;for(var g=0,x=0;x<F;x++){var b=G()[C>>>2>>>0],N1=G()[C+4>>>2>>>0];C+=8;for(var q3=0;q3<N1;q3++){var E1=Z()[b+q3>>>0],p1=NH[N];E1===0||E1===10?((N===1?k3:R1)(a(p1,0)),p1.length=0):p1.push(E1)}g+=N1}return G()[v>>>2>>>0]=g,0}var P7=[31,29,31,30,31,30,31,31,30,31,30,31],E7=[31,28,31,30,31,30,31,31,30,31,30,31];function MH(N){var C=Array(D1(N)+1);return C4(N,C,0,C.length),C}var YH=(N,C)=>{U().set(N,C>>>0)};function I7(N,C,F,v){function g(_,Z1,M1){for(_=typeof _=="number"?_.toString():_||"";_.length<Z1;)_=M1[0]+_;return _}function x(_,Z1){return g(_,Z1,"0")}function b(_,Z1){function M1(m7){return 0>m7?-1:0<m7?1:0}var h3;return(h3=M1(_.getFullYear()-Z1.getFullYear()))===0&&(h3=M1(_.getMonth()-Z1.getMonth()))===0&&(h3=M1(_.getDate()-Z1.getDate())),h3}function N1(_){switch(_.getDay()){case 0:return new Date(_.getFullYear()-1,11,29);case 1:return _;case 2:return new Date(_.getFullYear(),0,3);case 3:return new Date(_.getFullYear(),0,2);case 4:return new Date(_.getFullYear(),0,1);case 5:return new Date(_.getFullYear()-1,11,31);case 6:return new Date(_.getFullYear()-1,11,30)}}function q3(_){var Z1=_.Qa;for(_=new Date(new Date(_.Ra+1900,0,1).getTime());0<Z1;){var M1=_.getMonth(),h3=(e3(_.getFullYear())?P7:E7)[M1];if(Z1>h3-_.getDate())Z1-=h3-_.getDate()+1,_.setDate(1),11>M1?_.setMonth(M1+1):(_.setMonth(0),_.setFullYear(_.getFullYear()+1));else{_.setDate(_.getDate()+Z1);break}}return M1=new Date(_.getFullYear()+1,0,4),Z1=N1(new Date(_.getFullYear(),0,4)),M1=N1(M1),0>=b(Z1,_)?0>=b(M1,_)?_.getFullYear()+1:_.getFullYear():_.getFullYear()-1}N>>>=0,C>>>=0,F>>>=0,v>>>=0;var E1=G()[v+40>>>2>>>0];v={kb:q()[v>>>2>>>0],jb:q()[v+4>>>2>>>0],Sa:q()[v+8>>>2>>>0],Wa:q()[v+12>>>2>>>0],Ta:q()[v+16>>>2>>>0],Ra:q()[v+20>>>2>>>0],Ma:q()[v+24>>>2>>>0],Qa:q()[v+28>>>2>>>0],qb:q()[v+32>>>2>>>0],ib:q()[v+36>>>2>>>0],lb:E1?A1(E1):""},F=A1(F),E1={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var p1 in E1)F=F.replace(new RegExp(p1,"g"),E1[p1]);var h7="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),b7="January February March April May June July August September October November December".split(" ");E1={"%a":(_)=>h7[_.Ma].substring(0,3),"%A":(_)=>h7[_.Ma],"%b":(_)=>b7[_.Ta].substring(0,3),"%B":(_)=>b7[_.Ta],"%C":(_)=>x((_.Ra+1900)/100|0,2),"%d":(_)=>x(_.Wa,2),"%e":(_)=>g(_.Wa,2," "),"%g":(_)=>q3(_).toString().substring(2),"%G":q3,"%H":(_)=>x(_.Sa,2),"%I":(_)=>(_=_.Sa,_==0?_=12:12<_&&(_-=12),x(_,2)),"%j":(_)=>{for(var Z1=0,M1=0;M1<=_.Ta-1;Z1+=(e3(_.Ra+1900)?P7:E7)[M1++]);return x(_.Wa+Z1,3)},"%m":(_)=>x(_.Ta+1,2),"%M":(_)=>x(_.jb,2),"%n":()=>`
+`,"%p":(_)=>0<=_.Sa&&12>_.Sa?"AM":"PM","%S":(_)=>x(_.kb,2),"%t":()=>"	","%u":(_)=>_.Ma||7,"%U":(_)=>x(Math.floor((_.Qa+7-_.Ma)/7),2),"%V":(_)=>{var Z1=Math.floor((_.Qa+7-(_.Ma+6)%7)/7);if(2>=(_.Ma+371-_.Qa-2)%7&&Z1++,Z1)Z1==53&&(M1=(_.Ma+371-_.Qa)%7,M1==4||M1==3&&e3(_.Ra)||(Z1=1));else{Z1=52;var M1=(_.Ma+7-_.Qa-1)%7;(M1==4||M1==5&&e3(_.Ra%400-1))&&Z1++}return x(Z1,2)},"%w":(_)=>_.Ma,"%W":(_)=>x(Math.floor((_.Qa+7-(_.Ma+6)%7)/7),2),"%y":(_)=>(_.Ra+1900).toString().substring(2),"%Y":(_)=>_.Ra+1900,"%z":(_)=>{_=_.ib;var Z1=0<=_;return _=Math.abs(_)/60,(Z1?"+":"-")+("0000"+(_/60*100+_%60)).slice(-4)},"%Z":(_)=>_.lb,"%%":()=>"%"},F=F.replace(/%%/g,"\0\0");for(p1 in E1)F.includes(p1)&&(F=F.replace(new RegExp(p1,"g"),E1[p1](v)));return F=F.replace(/\0\0/g,"%"),p1=MH(F),p1.length>C?0:(YH(p1,N),p1.length-1)}c.Va();var CH=[z4,r4,P,f1,T1,T,J1,q1,U3,B4,z7,N7,M7,Y7,C7,B7,A7,S7,L7,v7,w7,T7,D7,_7],BH={b:function(N,C,F){throw N>>>=0,new M(N).Va(C>>>0,F>>>0),S=N,L++,S},L:function(N){x7(N>>>0,!A,1,!w,131072,!1),c.$a()},j:function(N){N>>>=0,I?postMessage({cmd:"cleanupThread",thread:N}):c.Ya(c.La[N])},H:d,h:f1,S:T1,D:T,F:J1,T:q1,Q:U3,J:B4,P:z7,n:N7,E:M7,B:Y7,R:C7,C:B7,p:()=>1,z:function(N,C){N>>>=0,N==C>>>0?setTimeout(t4):I?postMessage({targetThread:N,cmd:"checkMailbox"}):(N=c.La[N])&&N.postMessage({cmd:"checkMailbox"})},I:function(N,C,F,v,g){C>>>=0,F>>>=0,S5.length=v,g=g>>>0>>>3;for(var x=0;x<v;x++)S5[x]=J()[g+x>>>0];return N=C?t3[C]:CH[N],c.eb=F,F=N(...S5),c.eb=0,F},K:A5,o:function(N){D&&c.La[N>>>0].ref()},s:function(N,C,F){N=C+2097152>>>0<4194305-!!N?(N>>>0)+4294967296*C:NaN,F>>>=0,N=new Date(1000*N),q()[F>>>2>>>0]=N.getUTCSeconds(),q()[F+4>>>2>>>0]=N.getUTCMinutes(),q()[F+8>>>2>>>0]=N.getUTCHours(),q()[F+12>>>2>>>0]=N.getUTCDate(),q()[F+16>>>2>>>0]=N.getUTCMonth(),q()[F+20>>>2>>>0]=N.getUTCFullYear()-1900,q()[F+24>>>2>>>0]=N.getUTCDay(),N=(N.getTime()-Date.UTC(N.getUTCFullYear(),0,1,0,0,0,0))/86400000|0,q()[F+28>>>2>>>0]=N},t:function(N,C,F){N=C+2097152>>>0<4194305-!!N?(N>>>0)+4294967296*C:NaN,F>>>=0,N=new Date(1000*N),q()[F>>>2>>>0]=N.getSeconds(),q()[F+4>>>2>>>0]=N.getMinutes(),q()[F+8>>>2>>>0]=N.getHours(),q()[F+12>>>2>>>0]=N.getDate(),q()[F+16>>>2>>>0]=N.getMonth(),q()[F+20>>>2>>>0]=N.getFullYear()-1900,q()[F+24>>>2>>>0]=N.getDay(),C=(e3(N.getFullYear())?F7:k7)[N.getMonth()]+N.getDate()-1|0,q()[F+28>>>2>>>0]=C,q()[F+36>>>2>>>0]=-(60*N.getTimezoneOffset()),C=new Date(N.getFullYear(),6,1).getTimezoneOffset();var v=new Date(N.getFullYear(),0,1).getTimezoneOffset();N=(C!=v&&N.getTimezoneOffset()==Math.min(v,C))|0,q()[F+32>>>2>>>0]=N},u:function(N){N>>>=0;var C=new Date(q()[N+20>>>2>>>0]+1900,q()[N+16>>>2>>>0],q()[N+12>>>2>>>0],q()[N+8>>>2>>>0],q()[N+4>>>2>>>0],q()[N>>>2>>>0],0),F=q()[N+32>>>2>>>0],v=C.getTimezoneOffset(),g=new Date(C.getFullYear(),6,1).getTimezoneOffset(),x=new Date(C.getFullYear(),0,1).getTimezoneOffset(),b=Math.min(x,g);return 0>F?q()[N+32>>>2>>>0]=+(g!=x&&b==v):0<F!=(b==v)&&(g=Math.max(x,g),C.setTime(C.getTime()+60000*((0<F?b:g)-v))),q()[N+24>>>2>>>0]=C.getDay(),F=(e3(C.getFullYear())?F7:k7)[C.getMonth()]+C.getDate()-1|0,q()[N+28>>>2>>>0]=F,q()[N>>>2>>>0]=C.getSeconds(),q()[N+4>>>2>>>0]=C.getMinutes(),q()[N+8>>>2>>>0]=C.getHours(),q()[N+12>>>2>>>0]=C.getDate(),q()[N+16>>>2>>>0]=C.getMonth(),q()[N+20>>>2>>>0]=C.getYear(),N=C.getTime(),N=isNaN(N)?-1:N/1000,y7((K3=N,1<=+Math.abs(K3)?0<K3?+Math.floor(K3/4294967296)>>>0:~~+Math.ceil((K3-+(~~K3>>>0))/4294967296)>>>0:0)),N>>>0},q:A7,r:S7,y:function(N,C,F,v){N>>>=0,C>>>=0,F>>>=0,v>>>=0;var g=(new Date()).getFullYear(),x=new Date(g,0,1),b=new Date(g,6,1);g=x.getTimezoneOffset();var N1=b.getTimezoneOffset(),q3=Math.max(g,N1);G()[N>>>2>>>0]=60*q3,q()[C>>>2>>>0]=+(g!=N1),N=(E1)=>E1.toLocaleTimeString(void 0,{hour12:!1,timeZoneName:"short"}).split(" ")[1],x=N(x),b=N(b),N1<g?(L3(x,F,17),L3(b,v,17)):(L3(x,v,17),L3(b,F,17))},c:()=>{g3("")},O:function(N,C,F){N>>>=0,C>>>=0,F>>>=0,$5.length=0;for(var v;v=Z()[C++>>>0];){var g=v!=105;g&=v!=112,F+=g&&F%8?4:0,$5.push(v==112?G()[F>>>2>>>0]:v==105?q()[F>>>2>>>0]:J()[F>>>3>>>0]),F+=g?8:4}return t3[N](...$5)},k:()=>{},i:()=>Date.now(),U:()=>{throw Y3+=1,"unwind"},A:function(){return 4294901760},e:()=>performance.timeOrigin+performance.now(),f:()=>D?(kV(),a3(pJ)).cpus().length:navigator.hardwareConcurrency,x:function(N){N>>>=0;var C=Z().length;if(N<=C||4294901760<N)return!1;for(var F=1;4>=F;F*=2){var v=C*(1+0.2/F);v=Math.min(v,N+100663296);var g=Math;v=Math.max(N,v);Q:{g=(g.min.call(g,4294901760,v+(65536-v%65536)%65536)-l.buffer.byteLength+65535)/65536;try{l.grow(g),c1();var x=1;break Q}catch{}x=void 0}if(x)return!0}return!1},M:L7,N:v7,G:N4,g:w7,m:T7,v:D7,l:_7,a:l||X.wasmMemory,w:I7,d:function(N,C,F,v){return I7(N>>>0,C>>>0,F>>>0,v>>>0)}},f=function(){function N(F,v){return f=F.exports,f=FH(),c.ab.push(f.ya),Y4=f.za,J3.unshift(f.V),h1=v,O3(),f}var C={a:BH};if(z1++,X.instantiateWasm)try{return X.instantiateWasm(C,N)}catch(F){R1(`Module.instantiateWasm callback failed with error: ${F}`),R(F)}return i4(C,function(F){N(F.instance,F.module)}).catch(R),{}}();X._OrtInit=(N,C)=>(X._OrtInit=f.W)(N,C),X._OrtGetLastError=(N,C)=>(X._OrtGetLastError=f.X)(N,C),X._OrtCreateSessionOptions=(N,C,F,v,g,x,b,N1,q3,E1)=>(X._OrtCreateSessionOptions=f.Y)(N,C,F,v,g,x,b,N1,q3,E1),X._OrtAppendExecutionProvider=(N,C)=>(X._OrtAppendExecutionProvider=f.Z)(N,C),X._OrtAddFreeDimensionOverride=(N,C,F)=>(X._OrtAddFreeDimensionOverride=f._)(N,C,F),X._OrtAddSessionConfigEntry=(N,C,F)=>(X._OrtAddSessionConfigEntry=f.$)(N,C,F),X._OrtReleaseSessionOptions=(N)=>(X._OrtReleaseSessionOptions=f.aa)(N),X._OrtCreateSession=(N,C,F)=>(X._OrtCreateSession=f.ba)(N,C,F),X._OrtReleaseSession=(N)=>(X._OrtReleaseSession=f.ca)(N),X._OrtGetInputOutputCount=(N,C,F)=>(X._OrtGetInputOutputCount=f.da)(N,C,F),X._OrtGetInputName=(N,C)=>(X._OrtGetInputName=f.ea)(N,C),X._OrtGetOutputName=(N,C)=>(X._OrtGetOutputName=f.fa)(N,C),X._OrtFree=(N)=>(X._OrtFree=f.ga)(N),X._OrtCreateTensor=(N,C,F,v,g,x)=>(X._OrtCreateTensor=f.ha)(N,C,F,v,g,x),X._OrtGetTensorData=(N,C,F,v,g)=>(X._OrtGetTensorData=f.ia)(N,C,F,v,g),X._OrtReleaseTensor=(N)=>(X._OrtReleaseTensor=f.ja)(N),X._OrtCreateRunOptions=(N,C,F,v)=>(X._OrtCreateRunOptions=f.ka)(N,C,F,v),X._OrtAddRunConfigEntry=(N,C,F)=>(X._OrtAddRunConfigEntry=f.la)(N,C,F),X._OrtReleaseRunOptions=(N)=>(X._OrtReleaseRunOptions=f.ma)(N),X._OrtCreateBinding=(N)=>(X._OrtCreateBinding=f.na)(N),X._OrtBindInput=(N,C,F)=>(X._OrtBindInput=f.oa)(N,C,F),X._OrtBindOutput=(N,C,F,v)=>(X._OrtBindOutput=f.pa)(N,C,F,v),X._OrtClearBoundOutputs=(N)=>(X._OrtClearBoundOutputs=f.qa)(N),X._OrtReleaseBinding=(N)=>(X._OrtReleaseBinding=f.ra)(N),X._OrtRunWithBinding=(N,C,F,v,g)=>(X._OrtRunWithBinding=f.sa)(N,C,F,v,g),X._OrtRun=(N,C,F,v,g,x,b,N1)=>(X._OrtRun=f.ta)(N,C,F,v,g,x,b,N1),X._OrtEndProfiling=(N)=>(X._OrtEndProfiling=f.ua)(N);var e4=X._pthread_self=()=>(e4=X._pthread_self=f.va)();X._malloc=(N)=>(X._malloc=f.wa)(N),X._free=(N)=>(X._free=f.xa)(N),X.__emscripten_tls_init=()=>(X.__emscripten_tls_init=f.ya)();var x7=X.__emscripten_thread_init=(N,C,F,v,g,x)=>(x7=X.__emscripten_thread_init=f.Aa)(N,C,F,v,g,x);X.__emscripten_thread_crashed=()=>(X.__emscripten_thread_crashed=f.Ba)();var O7=(N,C,F,v,g)=>(O7=f.Ca)(N,C,F,v,g),w5=(N)=>(w5=f.Da)(N),T5=X.__emscripten_thread_exit=(N)=>(T5=X.__emscripten_thread_exit=f.Ea)(N),g7=()=>(g7=f.Fa)(),y7=(N)=>(y7=f.Ga)(N),d7=(N,C)=>(d7=f.Ha)(N,C),Q5=(N)=>(Q5=f.Ia)(N),D5=(N)=>(D5=f.Ja)(N),_5=()=>(_5=f.Ka)();function FH(){var N=f;N=Object.assign({},N);var C=(v)=>()=>v()>>>0,F=(v)=>(g)=>v(g)>>>0;return N.va=C(N.va),N.wa=F(N.wa),N.emscripten_main_runtime_thread_id=C(N.emscripten_main_runtime_thread_id),N.Ja=F(N.Ja),N.Ka=C(N.Ka),N}X.wasmMemory=l,X.stackSave=()=>_5(),X.stackRestore=(N)=>Q5(N),X.stackAlloc=(N)=>D5(N),X.keepRuntimeAlive=()=>0<Y3,X.UTF8ToString=A1,X.stringToUTF8=L3,X.lengthBytesUTF8=D1,X.ExitStatus=y3,X.PThread=c;var J5;g1=function N(){J5||p7(),J5||(g1=N)};function p7(){if(!(0<z1))if(I)V(X),I||p3(J3),startWorker(X);else{if(X.preRun)for(typeof X.preRun=="function"&&(X.preRun=[X.preRun]);X.preRun.length;)a1.unshift(X.preRun.shift());p3(a1),0<z1||J5||(J5=!0,X.calledRun=!0,X3||(I||p3(J3),V(X),I||p3(H3)))}}return p7(),z}})();typeof Q=="object"&&typeof H=="object"?H.exports=j:typeof define=="function"&&define.amd&&define([],()=>j)}),SV=U1((Q,H)=>{H.exports='"use strict";var Module={},ENVIRONMENT_IS_NODE=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string";if(ENVIRONMENT_IS_NODE){var nodeWorkerThreads=require("worker_threads"),parentPort=nodeWorkerThreads.parentPort;parentPort.on("message",e=>onmessage({data:e}));var fs=require("fs"),vm=require("vm");Object.assign(global,{self:global,require,Module,location:{href:__filename},Worker:nodeWorkerThreads.Worker,importScripts:e=>vm.runInThisContext(fs.readFileSync(e,"utf8"),{filename:e}),postMessage:e=>parentPort.postMessage(e),performance:global.performance||{now:Date.now}})}var initializedJS=!1;function threadPrintErr(...e){var a=e.join(" ");if(ENVIRONMENT_IS_NODE){fs.writeSync(2,a+`\n`);return}console.error(a)}function threadAlert(...e){var a=e.join(" ");postMessage({cmd:"alert",text:a,threadId:Module._pthread_self()})}var err=threadPrintErr;self.alert=threadAlert,Module.instantiateWasm=(e,a)=>{var r=Module.wasmModule;Module.wasmModule=null;var t=new WebAssembly.Instance(r,e);return a(t)},self.onunhandledrejection=e=>{throw e.reason||e};function handleMessage(e){try{if(e.data.cmd==="load"){let r=[];self.onmessage=t=>r.push(t),self.startWorker=t=>{Module=t,postMessage({cmd:"loaded"});for(let s of r)handleMessage(s);self.onmessage=handleMessage},Module.wasmModule=e.data.wasmModule;for(const t of e.data.handlers)Module[t]=(...s)=>{postMessage({cmd:"callHandler",handler:t,args:s})};if(Module.wasmMemory=e.data.wasmMemory,Module.buffer=Module.wasmMemory.buffer,Module.ENVIRONMENT_IS_PTHREAD=!0,typeof e.data.urlOrBlob=="string")importScripts(e.data.urlOrBlob);else{var a=URL.createObjectURL(e.data.urlOrBlob);importScripts(a),URL.revokeObjectURL(a)}ortWasmThreaded(Module)}else if(e.data.cmd==="run"){Module.__emscripten_thread_init(e.data.pthread_ptr,0,0,1),Module.__emscripten_thread_mailbox_await(e.data.pthread_ptr),Module.establishStackSpace(),Module.PThread.receiveObjectTransfer(e.data),Module.PThread.threadInitTLS(),initializedJS||(initializedJS=!0);try{Module.invokeEntryPoint(e.data.start_routine,e.data.arg)}catch(r){if(r!="unwind")throw r}}else e.data.cmd==="cancel"?Module._pthread_self()&&Module.__emscripten_thread_exit(-1):e.data.target==="setimmediate"||(e.data.cmd==="checkMailbox"?initializedJS&&Module.checkMailbox():e.data.cmd&&(err(`worker.js received unknown command ${e.data.cmd}`),err(e.data)))}catch(r){throw Module.__emscripten_thread_crashed?.(),r}}self.onmessage=handleMessage;\n'}),K2,U2,q6,K5,T4,W6,q2,W2,G2,bJ,w1,s4=E(()=>{K2=CV(),U2=AV(),K5=!1,T4=!1,W6=!1,q2=(Q)=>{if(Q===1)return!1;if(typeof SharedArrayBuffer>"u")return typeof self<"u"&&!self.crossOriginIsolated&&console.warn("env.wasm.numThreads is set to "+Q+", but this will not work unless you enable crossOriginIsolated mode. See https://web.dev/cross-origin-isolation-guide/ for more info."),!1;typeof process<"u"&&process.versions&&process.versions.node&&console.warn("env.wasm.numThreads is set to "+Q+", however, currently onnxruntime-web does not support multi-threads in Node.js. Please consider using onnxruntime-node for performance critical scenarios.");try{return typeof MessageChannel<"u"&&new MessageChannel().port1.postMessage(new SharedArrayBuffer(1)),WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,5,4,1,3,1,1,10,11,1,9,0,65,0,254,16,2,0,26,11]))}catch{return!1}},W2=()=>{try{return WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,10,30,1,28,0,65,0,253,15,253,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,253,186,1,26,11]))}catch{return!1}},G2=(Q,H)=>Q?H?"ort-wasm-simd-threaded.wasm":"ort-wasm-simd.wasm":H?"ort-wasm-threaded.wasm":"ort-wasm.wasm",bJ=async(Q)=>{if(K5)return Promise.resolve();if(T4)throw new Error("multiple calls to 'initializeWebAssembly()' detected.");if(W6)throw new Error("previous call to 'initializeWebAssembly()' failed.");T4=!0;let{initTimeout:H,numThreads:j,simd:K}=Q,W=q2(j),U=K&&W2(),Z=Q.wasmPaths,q=typeof Z=="string"?Z:void 0,G=G2(U,W),J=typeof Z=="object"?Z[G]:void 0,X=!1,V=[];if(H>0&&V.push(new Promise((R)=>{setTimeout(()=>{X=!0,R()},H)})),V.push(new Promise((R,z)=>{let Y=W?U2:K2,B={locateFile:(k,w)=>W&&k.endsWith(".worker.js")&&typeof Blob<"u"?URL.createObjectURL(new Blob([SV()],{type:"text/javascript"})):k.endsWith(".wasm")?J||(q??w)+G:w+k};if(W)if(B.numThreads=j,typeof Blob>"u")B.mainScriptUrlOrBlob=(void 0)(r6,"ort-wasm-threaded.js");else{let k=`var ortWasmThreaded=${Y.toString()};`;B.mainScriptUrlOrBlob=new Blob([k],{type:"text/javascript"})}Y(B).then((k)=>{T4=!1,K5=!0,q6=k,R()},(k)=>{T4=!1,W6=!0,z(k)})})),await Promise.race(V),X)throw new Error(`WebAssembly backend initializing failed due to timeout: ${H}ms`)},w1=()=>{if(K5&&q6)return q6;throw new Error("WebAssembly is not initialized yet.")}}),B1,M5,F1,G7=E(()=>{s4(),B1=(Q,H)=>{let j=w1(),K=j.lengthBytesUTF8(Q)+1,W=j._malloc(K);return j.stringToUTF8(Q,W,K),H.push(W),W},M5=(Q,H,j,K)=>{if(typeof Q=="object"&&Q!==null){if(j.has(Q))throw new Error("Circular reference in options");j.add(Q)}Object.entries(Q).forEach(([W,U])=>{let Z=H?H+W:W;if(typeof U=="object")M5(U,Z+".",j,K);else if(typeof U=="string"||typeof U=="number")K(Z,U.toString());else if(typeof U=="boolean")K(Z,U?"1":"0");else throw new Error(`Can't handle extra config type: ${typeof U}`)})},F1=(Q)=>{let H=w1(),j=H.stackSave();try{let K=H.stackAlloc(8);H._OrtGetLastError(K,K+4);let W=H.HEAP32[K/4],U=H.HEAPU32[K/4+1],Z=U?H.UTF8ToString(U):"";throw new Error(`${Q} ERROR_CODE: ${W}, ERROR_MESSAGE: ${Z}`)}finally{H.stackRestore(j)}}}),mJ,$V=E(()=>{s4(),G7(),mJ=(Q)=>{let H=w1(),j=0,K=[],W=Q||{};try{if(Q?.logSeverityLevel===void 0)W.logSeverityLevel=2;else if(typeof Q.logSeverityLevel!="number"||!Number.isInteger(Q.logSeverityLevel)||Q.logSeverityLevel<0||Q.logSeverityLevel>4)throw new Error(`log serverity level is not valid: ${Q.logSeverityLevel}`);if(Q?.logVerbosityLevel===void 0)W.logVerbosityLevel=0;else if(typeof Q.logVerbosityLevel!="number"||!Number.isInteger(Q.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${Q.logVerbosityLevel}`);Q?.terminate===void 0&&(W.terminate=!1);let U=0;return Q?.tag!==void 0&&(U=B1(Q.tag,K)),j=H._OrtCreateRunOptions(W.logSeverityLevel,W.logVerbosityLevel,!!W.terminate,U),j===0&&F1("Can't create run options."),Q?.extra!==void 0&&M5(Q.extra,"",new WeakSet,(Z,q)=>{let G=B1(Z,K),J=B1(q,K);H._OrtAddRunConfigEntry(j,G,J)!==0&&F1(`Can't set a run config entry: ${Z} - ${q}.`)}),[j,K]}catch(U){throw j!==0&&H._OrtReleaseRunOptions(j),K.forEach((Z)=>H._free(Z)),U}}}),R2,z2,N2,M2,cJ,LV=E(()=>{s4(),G7(),R2=(Q)=>{switch(Q){case"disabled":return 0;case"basic":return 1;case"extended":return 2;case"all":return 99;default:throw new Error(`unsupported graph optimization level: ${Q}`)}},z2=(Q)=>{switch(Q){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${Q}`)}},N2=(Q)=>{Q.extra||(Q.extra={}),Q.extra.session||(Q.extra.session={});let H=Q.extra.session;H.use_ort_model_bytes_directly||(H.use_ort_model_bytes_directly="1"),Q.executionProviders&&Q.executionProviders.some((j)=>(typeof j=="string"?j:j.name)==="webgpu")&&(Q.enableMemPattern=!1)},M2=(Q,H,j)=>{for(let K of H){let W=typeof K=="string"?K:K.name;switch(W){case"webnn":if(W="WEBNN",typeof K!="string"){let Z=K;if(Z?.deviceType){let q=B1("deviceType",j),G=B1(Z.deviceType,j);w1()._OrtAddSessionConfigEntry(Q,q,G)!==0&&F1(`Can't set a session config entry: 'deviceType' - ${Z.deviceType}.`)}if(Z?.numThreads){let q=Z.numThreads;(typeof q!="number"||!Number.isInteger(q)||q<0)&&(q=0);let G=B1("numThreads",j),J=B1(q.toString(),j);w1()._OrtAddSessionConfigEntry(Q,G,J)!==0&&F1(`Can't set a session config entry: 'numThreads' - ${Z.numThreads}.`)}if(Z?.powerPreference){let q=B1("powerPreference",j),G=B1(Z.powerPreference,j);w1()._OrtAddSessionConfigEntry(Q,q,G)!==0&&F1(`Can't set a session config entry: 'powerPreference' - ${Z.powerPreference}.`)}}break;case"webgpu":if(W="JS",typeof K!="string"){let Z=K;if(Z?.preferredLayout){if(Z.preferredLayout!=="NCHW"&&Z.preferredLayout!=="NHWC")throw new Error(`preferredLayout must be either 'NCHW' or 'NHWC': ${Z.preferredLayout}`);let q=B1("preferredLayout",j),G=B1(Z.preferredLayout,j);w1()._OrtAddSessionConfigEntry(Q,q,G)!==0&&F1(`Can't set a session config entry: 'preferredLayout' - ${Z.preferredLayout}.`)}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${W}`)}let U=B1(W,j);w1()._OrtAppendExecutionProvider(Q,U)!==0&&F1(`Can't append execution provider: ${W}.`)}},cJ=(Q)=>{let H=w1(),j=0,K=[],W=Q||{};N2(W);try{let U=R2(W.graphOptimizationLevel??"all"),Z=z2(W.executionMode??"sequential"),q=typeof W.logId=="string"?B1(W.logId,K):0,G=W.logSeverityLevel??2;if(!Number.isInteger(G)||G<0||G>4)throw new Error(`log serverity level is not valid: ${G}`);let J=W.logVerbosityLevel??0;if(!Number.isInteger(J)||J<0||J>4)throw new Error(`log verbosity level is not valid: ${J}`);let X=typeof W.optimizedModelFilePath=="string"?B1(W.optimizedModelFilePath,K):0;if(j=H._OrtCreateSessionOptions(U,!!W.enableCpuMemArena,!!W.enableMemPattern,Z,!!W.enableProfiling,0,q,G,J,X),j===0&&F1("Can't create session options."),W.executionProviders&&M2(j,W.executionProviders,K),W.enableGraphCapture!==void 0){if(typeof W.enableGraphCapture!="boolean")throw new Error(`enableGraphCapture must be a boolean value: ${W.enableGraphCapture}`);let V=B1("enableGraphCapture",K),R=B1(W.enableGraphCapture.toString(),K);H._OrtAddSessionConfigEntry(j,V,R)!==0&&F1(`Can't set a session config entry: 'enableGraphCapture' - ${W.enableGraphCapture}.`)}if(W.freeDimensionOverrides)for(let[V,R]of Object.entries(W.freeDimensionOverrides)){if(typeof V!="string")throw new Error(`free dimension override name must be a string: ${V}`);if(typeof R!="number"||!Number.isInteger(R)||R<0)throw new Error(`free dimension override value must be a non-negative integer: ${R}`);let z=B1(V,K);H._OrtAddFreeDimensionOverride(j,z,R)!==0&&F1(`Can't set a free dimension override: ${V} - ${R}.`)}return W.extra!==void 0&&M5(W.extra,"",new WeakSet,(V,R)=>{let z=B1(V,K),Y=B1(R,K);H._OrtAddSessionConfigEntry(j,z,Y)!==0&&F1(`Can't set a session config entry: ${V} - ${R}.`)}),[j,K]}catch(U){throw j!==0&&H._OrtReleaseSessionOptions(j),K.forEach((Z)=>H._free(Z)),U}}}),s6,fJ,i6,lJ,uJ,R7,sJ,iJ=E(()=>{s6=(Q)=>{switch(Q){case"int8":return 3;case"uint8":return 2;case"bool":return 9;case"int16":return 5;case"uint16":return 4;case"int32":return 6;case"uint32":return 12;case"float16":return 10;case"float32":return 1;case"float64":return 11;case"string":return 8;case"int64":return 7;case"uint64":return 13;default:throw new Error(`unsupported data type: ${Q}`)}},fJ=(Q)=>{switch(Q){case 3:return"int8";case 2:return"uint8";case 9:return"bool";case 5:return"int16";case 4:return"uint16";case 6:return"int32";case 12:return"uint32";case 10:return"float16";case 1:return"float32";case 11:return"float64";case 8:return"string";case 7:return"int64";case 13:return"uint64";default:throw new Error(`unsupported data type: ${Q}`)}},i6=(Q)=>[void 0,4,1,1,2,2,4,8,void 0,1,2,8,4,8,void 0,void 0,void 0][Q],lJ=(Q)=>{switch(Q){case"float16":return typeof Float16Array<"u"&&Float16Array.from?Float16Array:Uint16Array;case"float32":return Float32Array;case"uint8":return Uint8Array;case"int8":return Int8Array;case"uint16":return Uint16Array;case"int16":return Int16Array;case"int32":return Int32Array;case"bool":return Uint8Array;case"float64":return Float64Array;case"uint32":return Uint32Array;case"int64":return BigInt64Array;case"uint64":return BigUint64Array;default:throw new Error(`unsupported type: ${Q}`)}},uJ=(Q)=>{switch(Q){case"verbose":return 0;case"info":return 1;case"warning":return 2;case"error":return 3;case"fatal":return 4;default:throw new Error(`unsupported logging level: ${Q}`)}},R7=(Q)=>Q==="float32"||Q==="float16"||Q==="int32"||Q==="int64"||Q==="uint32"||Q==="uint8"||Q==="bool",sJ=(Q)=>{switch(Q){case"none":return 0;case"cpu":return 1;case"cpu-pinned":return 2;case"texture":return 3;case"gpu-buffer":return 4;default:throw new Error(`unsupported data location: ${Q}`)}}}),Y5,oJ=E(()=>{Y5=async(Q)=>{if(typeof Q=="string")if(typeof process<"u"&&process.versions&&process.versions.node)try{return new Uint8Array(await(void 0)(Q))}catch(H){if(H.code==="ERR_FS_FILE_TOO_LARGE"){let j=(void 0)(Q),K=[];for await(let W of j)K.push(W);return new Uint8Array(Buffer.concat(K))}throw H}else{let H=await fetch(Q);if(!H.ok)throw new Error(`failed to load external data file: ${Q}`);let j=H.headers.get("Content-Length"),K=j?parseInt(j,10):0;if(K<1073741824)return new Uint8Array(await H.arrayBuffer());{if(!H.body)throw new Error(`failed to load external data file: ${Q}, no response body.`);let W=H.body.getReader(),U;try{U=new ArrayBuffer(K)}catch(q){if(q instanceof RangeError){let G=Math.ceil(K/65536);U=new WebAssembly.Memory({initial:G,maximum:G}).buffer}else throw q}let Z=0;for(;;){let{done:q,value:G}=await W.read();if(q)break;let J=G.byteLength;new Uint8Array(U,Z,J).set(G),Z+=J}return new Uint8Array(U,0,K)}}else return Q instanceof Blob?new Uint8Array(await Q.arrayBuffer()):Q instanceof Uint8Array?Q:new Uint8Array(Q)}}),Y2,aJ,nJ,c3,C2,o6,rJ,tJ,G6,eJ,QH,JH,vV=E(()=>{$V(),LV(),iJ(),s4(),G7(),oJ(),Y2=(Q,H)=>{w1()._OrtInit(Q,H)!==0&&F1("Can't initialize onnxruntime.")},aJ=async(Q)=>{Y2(Q.wasm.numThreads,uJ(Q.logLevel))},nJ=async(Q,H)=>{},c3=new Map,C2=(Q)=>{let H=w1(),j=H.stackSave();try{let K=H.stackAlloc(8);return H._OrtGetInputOutputCount(Q,K,K+4)!==0&&F1("Can't get session input/output count."),[H.HEAP32[K/4],H.HEAP32[K/4+1]]}finally{H.stackRestore(j)}},o6=(Q)=>{let H=w1(),j=H._malloc(Q.byteLength);if(j===0)throw new Error(`Can't create a session. failed to allocate a buffer of size ${Q.byteLength}.`);return H.HEAPU8.set(Q,j),[j,Q.byteLength]},rJ=async(Q,H)=>{let j,K,W=w1();Array.isArray(Q)?[j,K]=Q:Q.buffer===W.HEAPU8.buffer?[j,K]=[Q.byteOffset,Q.byteLength]:[j,K]=o6(Q);let U=0,Z=0,q=0,G=[],J=[],X=[];try{if([Z,G]=cJ(H),H?.externalData&&W.mountExternalData){let A=[];for(let D of H.externalData){let I=typeof D=="string"?D:D.path;A.push(Y5(typeof D=="string"?D:D.data).then((h)=>{W.mountExternalData(I,h)}))}await Promise.all(A)}U=await W._OrtCreateSession(j,K,Z),U===0&&F1("Can't create a session.");let[V,R]=C2(U),z=!!H?.enableGraphCapture,Y=[],B=[],k=[];for(let A=0;A<V;A++){let D=W._OrtGetInputName(U,A);D===0&&F1("Can't get an input name."),J.push(D),Y.push(W.UTF8ToString(D))}for(let A=0;A<R;A++){let D=W._OrtGetOutputName(U,A);D===0&&F1("Can't get an output name."),X.push(D);let I=W.UTF8ToString(D);B.push(I)}let w=null;return c3.set(U,[U,J,X,w,z,!1]),[U,Y,B]}catch(V){throw J.forEach((R)=>W._OrtFree(R)),X.forEach((R)=>W._OrtFree(R)),q!==0&&W._OrtReleaseBinding(q),U!==0&&W._OrtReleaseSession(U),V}finally{W._free(j),Z!==0&&W._OrtReleaseSessionOptions(Z),G.forEach((V)=>W._free(V)),W.unmountExternalData?.()}},tJ=(Q)=>{let H=w1(),j=c3.get(Q);if(!j)throw new Error(`cannot release session. invalid session id: ${Q}`);let[K,W,U,Z,q]=j;Z&&(q&&H._OrtClearBoundOutputs(Z.handle),H._OrtReleaseBinding(Z.handle)),H.jsepOnReleaseSession?.(Q),W.forEach((G)=>H._OrtFree(G)),U.forEach((G)=>H._OrtFree(G)),H._OrtReleaseSession(K),c3.delete(Q)},G6=(Q,H,j,K,W,U=!1)=>{if(!Q){H.push(0);return}let Z=w1(),q=Q[0],G=Q[1],J=Q[3],X,V;if(q==="string"&&J==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");if(U&&J!=="gpu-buffer")throw new Error(`External buffer must be provided for input/output index ${W} when enableGraphCapture is true.`);if(J==="gpu-buffer"){let Y=Q[2].gpuBuffer,B=i6(s6(q));V=G.reduce((w,A)=>w*A,1)*B;let k=Z.jsepRegisterBuffer;if(!k)throw new Error('Tensor location "gpu-buffer" is not supported without using WebGPU.');X=k(K,W,Y,V)}else{let Y=Q[2];if(Array.isArray(Y)){V=4*Y.length,X=Z._malloc(V),j.push(X);let B=X/4;for(let k=0;k<Y.length;k++){if(typeof Y[k]!="string")throw new TypeError(`tensor data at index ${k} is not a string`);Z.HEAPU32[B++]=B1(Y[k],j)}}else V=Y.byteLength,X=Z._malloc(V),j.push(X),Z.HEAPU8.set(new Uint8Array(Y.buffer,Y.byteOffset,V),X)}let R=Z.stackSave(),z=Z.stackAlloc(4*G.length);try{let Y=z/4;G.forEach((k)=>Z.HEAP32[Y++]=k);let B=Z._OrtCreateTensor(s6(q),X,V,z,G.length,sJ(J));B===0&&F1(`Can't create tensor for input/output. session=${K}, index=${W}.`),H.push(B)}finally{Z.stackRestore(R)}},eJ=async(Q,H,j,K,W,U)=>{let Z=w1(),q=c3.get(Q);if(!q)throw new Error(`cannot run inference. invalid session id: ${Q}`);let G=q[0],J=q[1],X=q[2],V=q[3],R=q[4],z=q[5],Y=H.length,B=K.length,k=0,w=[],A=[],D=[],I=[],h=Z.stackSave(),$1=Z.stackAlloc(Y*4),L1=Z.stackAlloc(Y*4),x1=Z.stackAlloc(B*4),G1=Z.stackAlloc(B*4);try{[k,w]=mJ(U);for(let l=0;l<Y;l++)G6(j[l],A,I,Q,H[l],R);for(let l=0;l<B;l++)G6(W[l],D,I,Q,Y+K[l],R);let p=$1/4,S1=L1/4,I3=x1/4,x3=G1/4;for(let l=0;l<Y;l++)Z.HEAPU32[p++]=A[l],Z.HEAPU32[S1++]=J[H[l]];for(let l=0;l<B;l++)Z.HEAPU32[I3++]=D[l],Z.HEAPU32[x3++]=X[K[l]];Z.jsepOnRunStart?.(G);let k3;k3=await Z._OrtRun(G,L1,$1,Y,G1,B,x1,k),k3!==0&&F1("failed to call OrtRun().");let R1=[];for(let l=0;l<B;l++){let h1=Z.HEAPU32[x1/4+l];if(h1===D[l]){R1.push(W[l]);continue}let X3=Z.stackSave(),v1=Z.stackAlloc(16),b1=!1,P1,O1=0;try{Z._OrtGetTensorData(h1,v1,v1+4,v1+8,v1+12)!==0&&F1(`Can't access output tensor data on index ${l}.`);let m1=v1/4,A3=Z.HEAPU32[m1++];O1=Z.HEAPU32[m1++];let c1=Z.HEAPU32[m1++],r3=Z.HEAPU32[m1++],a1=[];for(let z1=0;z1<r3;z1++)a1.push(Z.HEAPU32[c1/4+z1]);Z._OrtFree(c1);let J3=a1.reduce((z1,k1)=>z1*k1,1);P1=fJ(A3);let H3=V?.outputPreferredLocations[K[l]];if(P1==="string"){if(H3==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");let z1=[],k1=O1/4;for(let g1=0;g1<J3;g1++){let O3=Z.HEAPU32[k1++],g3=g1===J3-1?void 0:Z.HEAPU32[k1]-O3;z1.push(Z.UTF8ToString(O3,g3))}R1.push([P1,a1,z1,"cpu"])}else if(H3==="gpu-buffer"&&J3>0){let z1=Z.jsepGetBuffer;if(!z1)throw new Error('preferredLocation "gpu-buffer" is not supported without using WebGPU.');let k1=z1(O1),g1=i6(A3);if(g1===void 0||!R7(P1))throw new Error(`Unsupported data type: ${P1}`);b1=!0,R1.push([P1,a1,{gpuBuffer:k1,download:Z.jsepCreateDownloader(k1,J3*g1,P1),dispose:()=>{Z._OrtReleaseTensor(h1)}},"gpu-buffer"])}else{let z1=lJ(P1),k1=new z1(J3);new Uint8Array(k1.buffer,k1.byteOffset,k1.byteLength).set(Z.HEAPU8.subarray(O1,O1+k1.byteLength)),R1.push([P1,a1,k1,"cpu"])}}finally{Z.stackRestore(X3),P1==="string"&&O1&&Z._free(O1),b1||Z._OrtReleaseTensor(h1)}}return V&&!R&&(Z._OrtClearBoundOutputs(V.handle),c3.set(Q,[G,J,X,V,R,!1])),R1}finally{Z.stackRestore(h),A.forEach((p)=>Z._OrtReleaseTensor(p)),D.forEach((p)=>Z._OrtReleaseTensor(p)),I.forEach((p)=>Z._free(p)),k!==0&&Z._OrtReleaseRunOptions(k),w.forEach((p)=>Z._free(p))}},QH=(Q)=>{let H=w1(),j=c3.get(Q);if(!j)throw new Error("invalid session id");let K=j[0],W=H._OrtEndProfiling(K);W===0&&F1("Can't get an profile file name."),H._OrtFree(W)},JH=(Q)=>{let H=[];for(let j of Q){let K=j[2];!Array.isArray(K)&&"buffer"in K&&H.push(K.buffer)}return H}}),wV=U1((Q,H)=>{H.exports='/*!\n * ONNX Runtime Web v1.18.0\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n"use strict";(()=>{var vt=Object.defineProperty;var qr=Object.getOwnPropertyDescriptor;var Vr=Object.getOwnPropertyNames;var Jr=Object.prototype.hasOwnProperty;var _t=(i,c)=>()=>(i&&(c=i(i=0)),c);var Ke=(i,c)=>()=>(c||i((c={exports:{}}).exports,c),c.exports),Et=(i,c)=>{for(var a in c)vt(i,a,{get:c[a],enumerable:!0})},Xr=(i,c,a,h)=>{if(c&&typeof c=="object"||typeof c=="function")for(let f of Vr(c))!Jr.call(i,f)&&f!==a&&vt(i,f,{get:()=>c[f],enumerable:!(h=qr(c,f))||h.enumerable});return i};var et=i=>Xr(vt({},"__esModule",{value:!0}),i);var St={};Et(St,{createReadStream:()=>lr,readFile:()=>Qr,readFileSync:()=>Zr});var Qr,Zr,lr,At=_t(()=>{Qr=void 0,Zr=void 0,lr=void 0});var Tt={};Et(Tt,{join:()=>Kr});var Kr,Mt=_t(()=>{Kr=void 0});var pr=Ke((dr,Ct)=>{"use strict";var cr=(()=>{var i=typeof document<"u"?document.currentScript?.src:void 0;return typeof __filename<"u"&&(i||=__filename),function(c={}){var a=c,h,f,w=new Promise((t,o)=>{h=t,f=o}),g=Object.assign({},a),s="./this.program",S=typeof window=="object",x=typeof importScripts=="function",H=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",A="",I,V,R;if(H){var B=(At(),et(St)),D=(Mt(),et(Tt));A=x?D.dirname(A)+"/":__dirname+"/",I=(t,o)=>(t=ce(t)?new URL(t):D.normalize(t),B.readFileSync(t,o?void 0:"utf8")),R=t=>(t=I(t,!0),t.buffer||(t=new Uint8Array(t)),t),V=(t,o,u,m=!0)=>{t=ce(t)?new URL(t):D.normalize(t),B.readFile(t,m?void 0:"utf8",(O,E)=>{O?u(O):o(m?E.buffer:E)})},!a.thisProgram&&1<process.argv.length&&(s=process.argv[1].replace(/\\\\/g,"/")),process.argv.slice(2)}else(S||x)&&(x?A=self.location.href:typeof document<"u"&&document.currentScript&&(A=document.currentScript.src),i&&(A=i),A.startsWith("blob:")?A="":A=A.substr(0,A.replace(/[?#].*/,"").lastIndexOf("/")+1),I=t=>{var o=new XMLHttpRequest;return o.open("GET",t,!1),o.send(null),o.responseText},x&&(R=t=>{var o=new XMLHttpRequest;return o.open("GET",t,!1),o.responseType="arraybuffer",o.send(null),new Uint8Array(o.response)}),V=(t,o,u)=>{var m=new XMLHttpRequest;m.open("GET",t,!0),m.responseType="arraybuffer",m.onload=()=>{m.status==200||m.status==0&&m.response?o(m.response):u()},m.onerror=u,m.send(null)});var T=console.log.bind(console),L=console.error.bind(console);Object.assign(a,g),g=null;var W,de=!1,pe,Z,_,J,Pe;function le(){var t=W.buffer;a.HEAP8=pe=new Int8Array(t),a.HEAP16=new Int16Array(t),a.HEAPU8=Z=new Uint8Array(t),a.HEAPU16=new Uint16Array(t),a.HEAP32=_=new Int32Array(t),a.HEAPU32=J=new Uint32Array(t),a.HEAPF32=new Float32Array(t),a.HEAPF64=Pe=new Float64Array(t)}var Ie=[],ne=[],X=[],we=0,me=null,F=null;function ie(t){throw t="Aborted("+t+")",L(t),de=!0,t=new WebAssembly.RuntimeError(t+". Build with -sASSERTIONS for more info."),f(t),t}var xe=t=>t.startsWith("data:application/octet-stream;base64,"),ce=t=>t.startsWith("file://"),be;if(be="ort-wasm.wasm",!xe(be)){var ae=be;be=a.locateFile?a.locateFile(ae,A):A+ae}function K(t){if(R)return R(t);throw"both async and sync fetching of the wasm failed"}function je(t){if(S||x){if(typeof fetch=="function"&&!ce(t))return fetch(t,{credentials:"same-origin"}).then(o=>{if(!o.ok)throw`failed to load wasm binary file at \'${t}\'`;return o.arrayBuffer()}).catch(()=>K(t));if(V)return new Promise((o,u)=>{V(t,m=>o(new Uint8Array(m)),u)})}return Promise.resolve().then(()=>K(t))}function Oe(t,o,u){return je(t).then(m=>WebAssembly.instantiate(m,o)).then(u,m=>{L(`failed to asynchronously prepare wasm: ${m}`),ie(m)})}function Ue(t,o){var u=be;return typeof WebAssembly.instantiateStreaming!="function"||xe(u)||ce(u)||H||typeof fetch!="function"?Oe(u,t,o):fetch(u,{credentials:"same-origin"}).then(m=>WebAssembly.instantiateStreaming(m,t).then(o,function(O){return L(`wasm streaming compile failed: ${O}`),L("falling back to ArrayBuffer instantiation"),Oe(u,t,o)}))}var ve,Ae={798088:(t,o,u,m)=>{if(typeof a>"u"||!a.ya)return 1;if(t=ue(t>>>0),t.startsWith("./")&&(t=t.substring(2)),t=a.ya.get(t),!t)return 2;if(o>>>=0,u>>>=0,o+u>t.byteLength)return 3;try{return Z.set(t.subarray(o,o+u),m>>>0>>>0),0}catch{return 4}}};class _e{constructor(o){this.wa=o-24}}var ge=0,Be=0,te=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,re=(t,o,u)=>{o>>>=0;var m=o+u;for(u=o;t[u]&&!(u>=m);)++u;if(16<u-o&&t.buffer&&te)return te.decode(t.subarray(o,u));for(m="";o<u;){var O=t[o++];if(O&128){var E=t[o++]&63;if((O&224)==192)m+=String.fromCharCode((O&31)<<6|E);else{var U=t[o++]&63;O=(O&240)==224?(O&15)<<12|E<<6|U:(O&7)<<18|E<<12|U<<6|t[o++]&63,65536>O?m+=String.fromCharCode(O):(O-=65536,m+=String.fromCharCode(55296|O>>10,56320|O&1023))}}else m+=String.fromCharCode(O)}return m},ue=(t,o)=>(t>>>=0)?re(Z,t,o):"",Ee=t=>{for(var o=0,u=0;u<t.length;++u){var m=t.charCodeAt(u);127>=m?o++:2047>=m?o+=2:55296<=m&&57343>=m?(o+=4,++u):o+=3}return o},Se=(t,o,u,m)=>{if(u>>>=0,!(0<m))return 0;var O=u;m=u+m-1;for(var E=0;E<t.length;++E){var U=t.charCodeAt(E);if(55296<=U&&57343>=U){var ee=t.charCodeAt(++E);U=65536+((U&1023)<<10)|ee&1023}if(127>=U){if(u>=m)break;o[u++>>>0]=U}else{if(2047>=U){if(u+1>=m)break;o[u++>>>0]=192|U>>6}else{if(65535>=U){if(u+2>=m)break;o[u++>>>0]=224|U>>12}else{if(u+3>=m)break;o[u++>>>0]=240|U>>18,o[u++>>>0]=128|U>>12&63}o[u++>>>0]=128|U>>6&63}o[u++>>>0]=128|U&63}}return o[u>>>0]=0,u-O},Le=t=>t%4===0&&(t%100!==0||t%400===0),ze=[0,31,60,91,121,152,182,213,244,274,305,335],rt=[0,31,59,90,120,151,181,212,243,273,304,334],Te=[],Ge={},ke=()=>{if(!We){var t={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",_:s||"./this.program"},o;for(o in Ge)Ge[o]===void 0?delete t[o]:t[o]=Ge[o];var u=[];for(o in t)u.push(`${o}=${t[o]}`);We=u}return We},We,nt=[null,[],[]],De=[31,29,31,30,31,30,31,31,30,31,30,31],at=[31,28,31,30,31,30,31,31,30,31,30,31];function G(t){var o=Array(Ee(t)+1);return Se(t,o,0,o.length),o}function qe(t,o,u,m){function O(d,k,$){for(d=typeof d=="number"?d.toString():d||"";d.length<k;)d=$[0]+d;return d}function E(d,k){return O(d,k,"0")}function U(d,k){function $(Ze){return 0>Ze?-1:0<Ze?1:0}var Me;return(Me=$(d.getFullYear()-k.getFullYear()))===0&&(Me=$(d.getMonth()-k.getMonth()))===0&&(Me=$(d.getDate()-k.getDate())),Me}function ee(d){switch(d.getDay()){case 0:return new Date(d.getFullYear()-1,11,29);case 1:return d;case 2:return new Date(d.getFullYear(),0,3);case 3:return new Date(d.getFullYear(),0,2);case 4:return new Date(d.getFullYear(),0,1);case 5:return new Date(d.getFullYear()-1,11,31);case 6:return new Date(d.getFullYear()-1,11,30)}}function ye(d){var k=d.sa;for(d=new Date(new Date(d.ta+1900,0,1).getTime());0<k;){var $=d.getMonth(),Me=(Le(d.getFullYear())?De:at)[$];if(k>Me-d.getDate())k-=Me-d.getDate()+1,d.setDate(1),11>$?d.setMonth($+1):(d.setMonth(0),d.setFullYear(d.getFullYear()+1));else{d.setDate(d.getDate()+k);break}}return $=new Date(d.getFullYear()+1,0,4),k=ee(new Date(d.getFullYear(),0,4)),$=ee($),0>=U(k,d)?0>=U($,d)?d.getFullYear()+1:d.getFullYear():d.getFullYear()-1}t>>>=0,o>>>=0,u>>>=0,m>>>=0;var oe=J[m+40>>>2>>>0];m={Ba:_[m>>>2>>>0],Aa:_[m+4>>>2>>>0],ua:_[m+8>>>2>>>0],xa:_[m+12>>>2>>>0],va:_[m+16>>>2>>>0],ta:_[m+20>>>2>>>0],na:_[m+24>>>2>>>0],sa:_[m+28>>>2>>>0],Da:_[m+32>>>2>>>0],za:_[m+36>>>2>>>0],Ca:oe?ue(oe):""},u=ue(u),oe={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var se in oe)u=u.replace(new RegExp(se,"g"),oe[se]);var Qe="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),Re="January February March April May June July August September October November December".split(" ");oe={"%a":d=>Qe[d.na].substring(0,3),"%A":d=>Qe[d.na],"%b":d=>Re[d.va].substring(0,3),"%B":d=>Re[d.va],"%C":d=>E((d.ta+1900)/100|0,2),"%d":d=>E(d.xa,2),"%e":d=>O(d.xa,2," "),"%g":d=>ye(d).toString().substring(2),"%G":ye,"%H":d=>E(d.ua,2),"%I":d=>(d=d.ua,d==0?d=12:12<d&&(d-=12),E(d,2)),"%j":d=>{for(var k=0,$=0;$<=d.va-1;k+=(Le(d.ta+1900)?De:at)[$++]);return E(d.xa+k,3)},"%m":d=>E(d.va+1,2),"%M":d=>E(d.Aa,2),"%n":()=>`\n`,"%p":d=>0<=d.ua&&12>d.ua?"AM":"PM","%S":d=>E(d.Ba,2),"%t":()=>"	","%u":d=>d.na||7,"%U":d=>E(Math.floor((d.sa+7-d.na)/7),2),"%V":d=>{var k=Math.floor((d.sa+7-(d.na+6)%7)/7);if(2>=(d.na+371-d.sa-2)%7&&k++,k)k==53&&($=(d.na+371-d.sa)%7,$==4||$==3&&Le(d.ta)||(k=1));else{k=52;var $=(d.na+7-d.sa-1)%7;($==4||$==5&&Le(d.ta%400-1))&&k++}return E(k,2)},"%w":d=>d.na,"%W":d=>E(Math.floor((d.sa+7-(d.na+6)%7)/7),2),"%y":d=>(d.ta+1900).toString().substring(2),"%Y":d=>d.ta+1900,"%z":d=>{d=d.za;var k=0<=d;return d=Math.abs(d)/60,(k?"+":"-")+("0000"+(d/60*100+d%60)).slice(-4)},"%Z":d=>d.Ca,"%%":()=>"%"},u=u.replace(/%%/g,"\\0\\0");for(se in oe)u.includes(se)&&(u=u.replace(new RegExp(se,"g"),oe[se](m)));return u=u.replace(/\\0\\0/g,"%"),se=G(u),se.length>o?0:(pe.set(se,t>>>0),se.length-1)}var Ve={a:function(t,o,u){t>>>=0;var m=new _e(t);throw J[m.wa+16>>>2>>>0]=0,J[m.wa+4>>>2>>>0]=o>>>0,J[m.wa+8>>>2>>>0]=u>>>0,ge=t,Be++,ge},e:function(){return 0},H:function(){},x:function(){},z:function(){},J:function(){return 0},F:function(){},A:function(){},E:function(){},g:function(){},y:function(){},v:function(){},G:function(){},w:function(){},k:()=>1,I:function(t,o,u){return o>>>=0,Z.copyWithin(t>>>0>>>0,o>>>0,o+(u>>>0)>>>0)},n:function(t,o,u){t=o+2097152>>>0<4194305-!!t?(t>>>0)+4294967296*o:NaN,u>>>=0,t=new Date(1e3*t),_[u>>>2>>>0]=t.getUTCSeconds(),_[u+4>>>2>>>0]=t.getUTCMinutes(),_[u+8>>>2>>>0]=t.getUTCHours(),_[u+12>>>2>>>0]=t.getUTCDate(),_[u+16>>>2>>>0]=t.getUTCMonth(),_[u+20>>>2>>>0]=t.getUTCFullYear()-1900,_[u+24>>>2>>>0]=t.getUTCDay(),_[u+28>>>2>>>0]=(t.getTime()-Date.UTC(t.getUTCFullYear(),0,1,0,0,0,0))/864e5|0},o:function(t,o,u){t=o+2097152>>>0<4194305-!!t?(t>>>0)+4294967296*o:NaN,u>>>=0,t=new Date(1e3*t),_[u>>>2>>>0]=t.getSeconds(),_[u+4>>>2>>>0]=t.getMinutes(),_[u+8>>>2>>>0]=t.getHours(),_[u+12>>>2>>>0]=t.getDate(),_[u+16>>>2>>>0]=t.getMonth(),_[u+20>>>2>>>0]=t.getFullYear()-1900,_[u+24>>>2>>>0]=t.getDay(),_[u+28>>>2>>>0]=(Le(t.getFullYear())?ze:rt)[t.getMonth()]+t.getDate()-1|0,_[u+36>>>2>>>0]=-(60*t.getTimezoneOffset()),o=new Date(t.getFullYear(),6,1).getTimezoneOffset();var m=new Date(t.getFullYear(),0,1).getTimezoneOffset();_[u+32>>>2>>>0]=(o!=m&&t.getTimezoneOffset()==Math.min(m,o))|0},p:function(t){t>>>=0;var o=new Date(_[t+20>>>2>>>0]+1900,_[t+16>>>2>>>0],_[t+12>>>2>>>0],_[t+8>>>2>>>0],_[t+4>>>2>>>0],_[t>>>2>>>0],0),u=_[t+32>>>2>>>0],m=o.getTimezoneOffset(),O=new Date(o.getFullYear(),6,1).getTimezoneOffset(),E=new Date(o.getFullYear(),0,1).getTimezoneOffset(),U=Math.min(E,O);return 0>u?_[t+32>>>2>>>0]=+(O!=E&&U==m):0<u!=(U==m)&&(O=Math.max(E,O),o.setTime(o.getTime()+6e4*((0<u?U:O)-m))),_[t+24>>>2>>>0]=o.getDay(),_[t+28>>>2>>>0]=(Le(o.getFullYear())?ze:rt)[o.getMonth()]+o.getDate()-1|0,_[t>>>2>>>0]=o.getSeconds(),_[t+4>>>2>>>0]=o.getMinutes(),_[t+8>>>2>>>0]=o.getHours(),_[t+12>>>2>>>0]=o.getDate(),_[t+16>>>2>>>0]=o.getMonth(),_[t+20>>>2>>>0]=o.getYear(),t=o.getTime(),t=isNaN(t)?-1:t/1e3,Je((ve=t,1<=+Math.abs(ve)?0<ve?+Math.floor(ve/4294967296)>>>0:~~+Math.ceil((ve-+(~~ve>>>0))/4294967296)>>>0:0)),t>>>0},l:function(){return-52},m:function(){},t:function(t,o,u,m){u>>>=0,m>>>=0;var O=new Date().getFullYear(),E=new Date(O,0,1),U=new Date(O,6,1);O=E.getTimezoneOffset();var ee=U.getTimezoneOffset();J[t>>>0>>>2>>>0]=60*Math.max(O,ee),_[o>>>0>>>2>>>0]=+(O!=ee),t=ye=>ye.toLocaleTimeString(void 0,{hour12:!1,timeZoneName:"short"}).split(" ")[1],E=t(E),U=t(U),ee<O?(Se(E,Z,u,17),Se(U,Z,m,17)):(Se(E,Z,m,17),Se(U,Z,u,17))},d:()=>{ie("")},B:function(t,o,u){t>>>=0,o>>>=0,u>>>=0,Te.length=0;for(var m;m=Z[o++>>>0];){var O=m!=105;O&=m!=112,u+=O&&u%8?4:0,Te.push(m==112?J[u>>>2>>>0]:m==105?_[u>>>2>>>0]:Pe[u>>>3>>>0]),u+=O?8:4}return Ae[t](...Te)},h:()=>Date.now(),u:function(){return 4294901760},b:()=>performance.now(),s:function(t){t>>>=0;var o=Z.length;if(4294901760<t)return!1;for(var u=1;4>=u;u*=2){var m=o*(1+.2/u);m=Math.min(m,t+100663296);var O=Math;m=Math.max(t,m);e:{O=(O.min.call(O,4294901760,m+(65536-m%65536)%65536)-W.buffer.byteLength+65535)/65536;try{W.grow(O),le();var E=1;break e}catch{}E=void 0}if(E)return!0}return!1},C:function(t,o){t>>>=0,o>>>=0;var u=0;return ke().forEach((m,O)=>{var E=o+u;for(O=J[t+4*O>>>2>>>0]=E,E=0;E<m.length;++E)pe[O++>>>0]=m.charCodeAt(E);pe[O>>>0]=0,u+=m.length+1}),0},D:function(t,o){t>>>=0,o>>>=0;var u=ke();J[t>>>2>>>0]=u.length;var m=0;return u.forEach(O=>m+=O.length+1),J[o>>>2>>>0]=m,0},f:()=>52,j:function(){return 52},q:function(){return 70},i:function(t,o,u,m){o>>>=0,u>>>=0,m>>>=0;for(var O=0,E=0;E<u;E++){var U=J[o>>>2>>>0],ee=J[o+4>>>2>>>0];o+=8;for(var ye=0;ye<ee;ye++){var oe=Z[U+ye>>>0],se=nt[t];oe===0||oe===10?((t===1?T:L)(re(se,0)),se.length=0):se.push(oe)}O+=ee}return J[m>>>2>>>0]=O,0},r:qe,c:function(t,o,u,m){return qe(t>>>0,o>>>0,u>>>0,m>>>0)}},P=function(){function t(u){return P=u.exports,P=st(),W=P.K,le(),ne.unshift(P.L),we--,we==0&&(me!==null&&(clearInterval(me),me=null),F&&(u=F,F=null,u())),P}var o={a:Ve};if(we++,a.instantiateWasm)try{return a.instantiateWasm(o,t)}catch(u){L(`Module.instantiateWasm callback failed with error: ${u}`),f(u)}return Ue(o,function(u){t(u.instance)}).catch(f),{}}();a._OrtInit=(t,o)=>(a._OrtInit=P.M)(t,o),a._OrtGetLastError=(t,o)=>(a._OrtGetLastError=P.N)(t,o),a._OrtCreateSessionOptions=(t,o,u,m,O,E,U,ee,ye,oe)=>(a._OrtCreateSessionOptions=P.O)(t,o,u,m,O,E,U,ee,ye,oe),a._OrtAppendExecutionProvider=(t,o)=>(a._OrtAppendExecutionProvider=P.P)(t,o),a._OrtAddFreeDimensionOverride=(t,o,u)=>(a._OrtAddFreeDimensionOverride=P.Q)(t,o,u),a._OrtAddSessionConfigEntry=(t,o,u)=>(a._OrtAddSessionConfigEntry=P.R)(t,o,u),a._OrtReleaseSessionOptions=t=>(a._OrtReleaseSessionOptions=P.S)(t),a._OrtCreateSession=(t,o,u)=>(a._OrtCreateSession=P.T)(t,o,u),a._OrtReleaseSession=t=>(a._OrtReleaseSession=P.U)(t),a._OrtGetInputOutputCount=(t,o,u)=>(a._OrtGetInputOutputCount=P.V)(t,o,u),a._OrtGetInputName=(t,o)=>(a._OrtGetInputName=P.W)(t,o),a._OrtGetOutputName=(t,o)=>(a._OrtGetOutputName=P.X)(t,o),a._OrtFree=t=>(a._OrtFree=P.Y)(t),a._OrtCreateTensor=(t,o,u,m,O,E)=>(a._OrtCreateTensor=P.Z)(t,o,u,m,O,E),a._OrtGetTensorData=(t,o,u,m,O)=>(a._OrtGetTensorData=P._)(t,o,u,m,O),a._OrtReleaseTensor=t=>(a._OrtReleaseTensor=P.$)(t),a._OrtCreateRunOptions=(t,o,u,m)=>(a._OrtCreateRunOptions=P.aa)(t,o,u,m),a._OrtAddRunConfigEntry=(t,o,u)=>(a._OrtAddRunConfigEntry=P.ba)(t,o,u),a._OrtReleaseRunOptions=t=>(a._OrtReleaseRunOptions=P.ca)(t),a._OrtCreateBinding=t=>(a._OrtCreateBinding=P.da)(t),a._OrtBindInput=(t,o,u)=>(a._OrtBindInput=P.ea)(t,o,u),a._OrtBindOutput=(t,o,u,m)=>(a._OrtBindOutput=P.fa)(t,o,u,m),a._OrtClearBoundOutputs=t=>(a._OrtClearBoundOutputs=P.ga)(t),a._OrtReleaseBinding=t=>(a._OrtReleaseBinding=P.ha)(t),a._OrtRunWithBinding=(t,o,u,m,O)=>(a._OrtRunWithBinding=P.ia)(t,o,u,m,O),a._OrtRun=(t,o,u,m,O,E,U,ee)=>(a._OrtRun=P.ja)(t,o,u,m,O,E,U,ee),a._OrtEndProfiling=t=>(a._OrtEndProfiling=P.ka)(t),a._malloc=t=>(a._malloc=P.la)(t),a._free=t=>(a._free=P.ma)(t);var Je=t=>(Je=P.oa)(t),ot=t=>(ot=P.pa)(t),M=t=>(M=P.qa)(t),Ne=()=>(Ne=P.ra)();function st(){var t=P;t=Object.assign({},t);var o=u=>m=>u(m)>>>0;return t.la=o(t.la),t.qa=o(t.qa),t.ra=(u=>()=>u()>>>0)(t.ra),t}a.stackSave=()=>Ne(),a.stackRestore=t=>ot(t),a.stackAlloc=t=>M(t),a.UTF8ToString=ue,a.stringToUTF8=(t,o,u)=>Se(t,Z,o,u),a.lengthBytesUTF8=Ee;var Fe;F=function t(){Fe||Xe(),Fe||(F=t)};function Xe(){if(!(0<we)){if(a.preRun)for(typeof a.preRun=="function"&&(a.preRun=[a.preRun]);a.preRun.length;){var t=a.preRun.shift();Ie.unshift(t)}for(;0<Ie.length;)Ie.shift()(a);if(!(0<we||Fe||(Fe=!0,a.calledRun=!0,de))){for(;0<ne.length;)ne.shift()(a);for(h(a);0<X.length;)X.shift()(a)}}}return Xe(),w}})();typeof dr=="object"&&typeof Ct=="object"?Ct.exports=cr:typeof define=="function"&&define.amd&&define([],()=>cr)});var mr=Ke(()=>{});var gr=Ke(()=>{});var hr={};Et(hr,{cpus:()=>en});var en,br=_t(()=>{en=void 0});var Or=Ke((wr,Dt)=>{"use strict";var yr=(()=>{var i=typeof document<"u"?document.currentScript?.src:void 0;return typeof __filename<"u"&&(i||=__filename),function(c={}){function a(){return X.buffer!=ie.buffer&&K(),ie}function h(){return X.buffer!=ie.buffer&&K(),xe}function f(){return X.buffer!=ie.buffer&&K(),ce}function w(){return X.buffer!=ie.buffer&&K(),be}function g(){return X.buffer!=ie.buffer&&K(),ae}var s=c,S,x,H=new Promise((e,r)=>{S=e,x=r}),A=Object.assign({},s),I="./this.program",V=(e,r)=>{throw r},R=typeof window=="object",B=typeof importScripts=="function",D=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",T=s.ENVIRONMENT_IS_PTHREAD||!1,L="";function W(e){return s.locateFile?s.locateFile(e,L):L+e}var de,pe,Z;if(D){var _=(At(),et(St)),J=(Mt(),et(Tt));L=B?J.dirname(L)+"/":__dirname+"/",de=(e,r)=>(e=ue(e)?new URL(e):J.normalize(e),_.readFileSync(e,r?void 0:"utf8")),Z=e=>(e=de(e,!0),e.buffer||(e=new Uint8Array(e)),e),pe=(e,r,n,l=!0)=>{e=ue(e)?new URL(e):J.normalize(e),_.readFile(e,l?void 0:"utf8",(y,b)=>{y?n(y):r(l?b.buffer:b)})},!s.thisProgram&&1<process.argv.length&&(I=process.argv[1].replace(/\\\\/g,"/")),process.argv.slice(2),V=(e,r)=>{throw process.exitCode=e,r},global.Worker=mr().Worker}else(R||B)&&(B?L=self.location.href:typeof document<"u"&&document.currentScript&&(L=document.currentScript.src),typeof i<"u"&&i&&(L=i),L.startsWith("blob:")?L="":L=L.substr(0,L.replace(/[?#].*/,"").lastIndexOf("/")+1),D||(de=e=>{var r=new XMLHttpRequest;return r.open("GET",e,!1),r.send(null),r.responseText},B&&(Z=e=>{var r=new XMLHttpRequest;return r.open("GET",e,!1),r.responseType="arraybuffer",r.send(null),new Uint8Array(r.response)}),pe=(e,r,n)=>{var l=new XMLHttpRequest;l.open("GET",e,!0),l.responseType="arraybuffer",l.onload=()=>{l.status==200||l.status==0&&l.response?r(l.response):n()},l.onerror=n,l.send(null)}));D&&typeof performance>"u"&&(global.performance=gr().performance);var Pe=console.log.bind(console),le=console.error.bind(console);D&&(Pe=(...e)=>_.writeSync(1,e.join(" ")+`\n`),le=(...e)=>_.writeSync(2,e.join(" ")+`\n`));var Ie=Pe,ne=le;Object.assign(s,A),A=null;var X,we,me=!1,F,ie,xe,ce,be,ae;function K(){var e=X.buffer;s.HEAP8=ie=new Int8Array(e),s.HEAP16=new Int16Array(e),s.HEAPU8=xe=new Uint8Array(e),s.HEAPU16=new Uint16Array(e),s.HEAP32=ce=new Int32Array(e),s.HEAPU32=be=new Uint32Array(e),s.HEAPF32=new Float32Array(e),s.HEAPF64=ae=new Float64Array(e)}var je=16777216;if(T)X=s.wasmMemory;else if(s.wasmMemory)X=s.wasmMemory;else if(X=new WebAssembly.Memory({initial:je/65536,maximum:65536,shared:!0}),!(X.buffer instanceof SharedArrayBuffer))throw ne("requested a shared WebAssembly.Memory but the returned buffer is not a SharedArrayBuffer, indicating that while the browser has SharedArrayBuffer it does not have WebAssembly threads support - you may need to set a flag"),D&&ne("(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and/or recent version)"),Error("bad memory");K(),je=X.buffer.byteLength;var Oe=[],Ue=[],ve=[],Ae=0,_e=null,ge=null;function Be(){if(Ae--,Ae==0&&(_e!==null&&(clearInterval(_e),_e=null),ge)){var e=ge;ge=null,e()}}function te(e){throw e="Aborted("+e+")",ne(e),me=!0,F=1,e=new WebAssembly.RuntimeError(e+". Build with -sASSERTIONS for more info."),x(e),e}var re=e=>e.startsWith("data:application/octet-stream;base64,"),ue=e=>e.startsWith("file://"),Ee;Ee="ort-wasm-threaded.wasm",re(Ee)||(Ee=W(Ee));function Se(e){if(Z)return Z(e);throw"both async and sync fetching of the wasm failed"}function Le(e){if(R||B){if(typeof fetch=="function"&&!ue(e))return fetch(e,{credentials:"same-origin"}).then(r=>{if(!r.ok)throw`failed to load wasm binary file at \'${e}\'`;return r.arrayBuffer()}).catch(()=>Se(e));if(pe)return new Promise((r,n)=>{pe(e,l=>r(new Uint8Array(l)),n)})}return Promise.resolve().then(()=>Se(e))}function ze(e,r,n){return Le(e).then(l=>WebAssembly.instantiate(l,r)).then(n,l=>{ne(`failed to asynchronously prepare wasm: ${l}`),te(l)})}function rt(e,r){var n=Ee;return typeof WebAssembly.instantiateStreaming!="function"||re(n)||ue(n)||D||typeof fetch!="function"?ze(n,e,r):fetch(n,{credentials:"same-origin"}).then(l=>WebAssembly.instantiateStreaming(l,e).then(r,function(y){return ne(`wasm streaming compile failed: ${y}`),ne("falling back to ArrayBuffer instantiation"),ze(n,e,r)}))}var Te,Ge={799444:(e,r,n,l)=>{if(typeof s>"u"||!s.bb)return 1;if(e=ee(e>>>0),e.startsWith("./")&&(e=e.substring(2)),e=s.bb.get(e),!e)return 2;if(r>>>=0,n>>>=0,l>>>=0,r+n>e.byteLength)return 3;try{return h().set(e.subarray(r,r+n),l>>>0),0}catch{return 4}}};function ke(e){this.name="ExitStatus",this.message=`Program terminated with exit(${e})`,this.status=e}var We=e=>{e.terminate(),e.onmessage=()=>{}},nt=e=>{M.Oa.length==0&&(Je(),M.Xa(M.Oa[0]));var r=M.Oa.pop();if(!r)return 6;M.Pa.push(r),M.La[e.Na]=r,r.Na=e.Na;var n={cmd:"run",start_routine:e.gb,arg:e.cb,pthread_ptr:e.Na};return D&&r.unref(),r.postMessage(n,e.mb),0},De=0,at=e=>{var r=Ot();return e=e(),ft(r),e},G=(e,r,...n)=>at(()=>{for(var l=n.length,y=wt(8*l),b=y>>>3,v=0;v<n.length;v++){var z=n[v];g()[b+v>>>0]=z}return rr(e,0,l,y,r)});function qe(e){if(T)return G(0,1,e);F=e,0<De||(M.hb(),s.onExit?.(e),me=!0),V(e,new ke(e))}var Ve=e=>{if(F=e,T)throw st(e),"unwind";qe(e)};function P(){for(var e=s.numThreads;e--;)Je();Oe.unshift(()=>{Ae++,ot(()=>Be())})}function Je(){var e=W("ort-wasm-threaded.worker.js");e=new Worker(e),M.Oa.push(e)}function ot(e){T?e():Promise.all(M.Oa.map(M.Xa)).then(e)}var M={Oa:[],Pa:[],ab:[],La:{},Va(){T?(M.receiveObjectTransfer=M.fb,M.threadInitTLS=M.$a,M.setExitStatus=M.Za):P()},Za:e=>F=e,pb:["$terminateWorker"],hb:()=>{for(var e of M.Pa)We(e);for(e of M.Oa)We(e);M.Oa=[],M.Pa=[],M.La=[]},Ya:e=>{var r=e.Na;delete M.La[r],M.Oa.push(e),M.Pa.splice(M.Pa.indexOf(e),1),e.Na=0,bt(r)},fb(){},$a(){M.ab.forEach(e=>e())},Xa:e=>new Promise(r=>{e.onmessage=b=>{b=b.data;var v=b.cmd;if(b.targetThread&&b.targetThread!=ut()){var z=M.La[b.targetThread];z?z.postMessage(b,b.transferList):ne(`Internal error! Worker sent a message "${v}" to target pthread ${b.targetThread}, but that thread no longer exists!`)}else v==="checkMailbox"?it():v==="spawnThread"?nt(b):v==="cleanupThread"?M.Ya(M.La[b.thread]):v==="killThread"?(b=b.thread,v=M.La[b],delete M.La[b],We(v),bt(b),M.Pa.splice(M.Pa.indexOf(v),1),v.Na=0):v==="cancelThread"?M.La[b.thread].postMessage({cmd:"cancel"}):v==="loaded"?(e.loaded=!0,D&&!e.Na&&e.unref(),r(e)):v==="alert"?alert(`Thread ${b.threadId}: ${b.text}`):b.target==="setimmediate"?e.postMessage(b):v==="callHandler"?s[b.handler](...b.args):v&&ne(`worker sent an unknown command ${v}`)},e.onerror=b=>{throw ne(`worker sent an error! ${b.filename}:${b.lineno}: ${b.message}`),b},D&&(e.on("message",b=>e.onmessage({data:b})),e.on("error",b=>e.onerror(b)));var n=[],l=["onExit"],y;for(y of l)s.hasOwnProperty(y)&&n.push(y);e.postMessage({cmd:"load",handlers:n,urlOrBlob:s.mainScriptUrlOrBlob||i,wasmMemory:X,wasmModule:we})})};s.PThread=M;var Ne=e=>{for(;0<e.length;)e.shift()(s)};s.establishStackSpace=()=>{var e=ut(),r=w()[e+52>>>2>>>0];e=w()[e+56>>>2>>>0],or(r,r-e),ft(r)};function st(e){if(T)return G(1,0,e);Ve(e)}var Fe=[],Xe;s.invokeEntryPoint=(e,r)=>{De=0;var n=Fe[e];n||(e>=Fe.length&&(Fe.length=e+1),Fe[e]=n=Xe.get(e)),e=n(r),0<De?M.Za(e):yt(e)};class t{constructor(r){this.Ua=r-24}Va(r,n){w()[this.Ua+16>>>2>>>0]=0,w()[this.Ua+4>>>2>>>0]=r,w()[this.Ua+8>>>2>>>0]=n}}var o=0,u=0;function m(e,r,n,l){return T?G(2,1,e,r,n,l):O(e,r,n,l)}function O(e,r,n,l){if(e>>>=0,r>>>=0,n>>>=0,l>>>=0,typeof SharedArrayBuffer>"u")return ne("Current environment does not support SharedArrayBuffer, pthreads are not available!"),6;var y=[];return T&&y.length===0?m(e,r,n,l):(e={gb:n,Na:e,cb:l,mb:y},T?(e.ob="spawnThread",postMessage(e,y),0):nt(e))}var E=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,U=(e,r,n)=>{r>>>=0;var l=r+n;for(n=r;e[n]&&!(n>=l);)++n;if(16<n-r&&e.buffer&&E)return E.decode(e.buffer instanceof SharedArrayBuffer?e.slice(r,n):e.subarray(r,n));for(l="";r<n;){var y=e[r++];if(y&128){var b=e[r++]&63;if((y&224)==192)l+=String.fromCharCode((y&31)<<6|b);else{var v=e[r++]&63;y=(y&240)==224?(y&15)<<12|b<<6|v:(y&7)<<18|b<<12|v<<6|e[r++]&63,65536>y?l+=String.fromCharCode(y):(y-=65536,l+=String.fromCharCode(55296|y>>10,56320|y&1023))}}else l+=String.fromCharCode(y)}return l},ee=(e,r)=>(e>>>=0)?U(h(),e,r):"";function ye(e,r,n){return T?G(3,1,e,r,n):0}function oe(e,r){if(T)return G(4,1,e,r)}var se=e=>{for(var r=0,n=0;n<e.length;++n){var l=e.charCodeAt(n);127>=l?r++:2047>=l?r+=2:55296<=l&&57343>=l?(r+=4,++n):r+=3}return r},Qe=(e,r,n,l)=>{if(n>>>=0,!(0<l))return 0;var y=n;l=n+l-1;for(var b=0;b<e.length;++b){var v=e.charCodeAt(b);if(55296<=v&&57343>=v){var z=e.charCodeAt(++b);v=65536+((v&1023)<<10)|z&1023}if(127>=v){if(n>=l)break;r[n++>>>0]=v}else{if(2047>=v){if(n+1>=l)break;r[n++>>>0]=192|v>>6}else{if(65535>=v){if(n+2>=l)break;r[n++>>>0]=224|v>>12}else{if(n+3>=l)break;r[n++>>>0]=240|v>>18,r[n++>>>0]=128|v>>12&63}r[n++>>>0]=128|v>>6&63}r[n++>>>0]=128|v&63}}return r[n>>>0]=0,n-y},Re=(e,r,n)=>Qe(e,h(),r,n);function d(e,r){if(T)return G(5,1,e,r)}function k(e,r,n){if(T)return G(6,1,e,r,n)}function $(e,r,n){return T?G(7,1,e,r,n):0}function Me(e,r){if(T)return G(8,1,e,r)}function Ze(e,r,n){if(T)return G(9,1,e,r,n)}function Rt(e,r,n,l){if(T)return G(10,1,e,r,n,l)}function It(e,r,n,l){if(T)return G(11,1,e,r,n,l)}function Bt(e,r,n,l){if(T)return G(12,1,e,r,n,l)}function kt(e){if(T)return G(13,1,e)}function Wt(e,r){if(T)return G(14,1,e,r)}function Nt(e,r,n){if(T)return G(15,1,e,r,n)}function dt(e){e>>>=0,typeof Atomics.nb=="function"&&(Atomics.nb(f(),e>>>2,e).value.then(it),e+=128,Atomics.store(f(),e>>>2,1))}s.__emscripten_thread_mailbox_await=dt;var it=()=>{var e=ut();if(e&&(dt(e),e=nr,!me))try{if(e(),!(0<De))try{T?yt(F):Ve(F)}catch(r){r instanceof ke||r=="unwind"||V(1,r)}}catch(r){r instanceof ke||r=="unwind"||V(1,r)}};s.checkMailbox=it;var pt=[],$e=e=>e%4===0&&(e%100!==0||e%400===0),Ht=[0,31,60,91,121,152,182,213,244,274,305,335],Gt=[0,31,59,90,120,151,181,212,243,273,304,334];function $t(e,r,n,l,y,b,v,z){return T?G(16,1,e,r,n,l,y,b,v,z):-52}function Yt(e,r,n,l,y,b,v){if(T)return G(17,1,e,r,n,l,y,b,v)}var mt=[],gt={},jt=()=>{if(!ht){var e={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",_:I||"./this.program"},r;for(r in gt)gt[r]===void 0?delete e[r]:e[r]=gt[r];var n=[];for(r in e)n.push(`${r}=${e[r]}`);ht=n}return ht},ht;function zt(e,r){if(T)return G(18,1,e,r);e>>>=0,r>>>=0;var n=0;return jt().forEach((l,y)=>{var b=r+n;for(y=w()[e+4*y>>>2>>>0]=b,b=0;b<l.length;++b)a()[y++>>>0]=l.charCodeAt(b);a()[y>>>0]=0,n+=l.length+1}),0}function qt(e,r){if(T)return G(19,1,e,r);e>>>=0,r>>>=0;var n=jt();w()[e>>>2>>>0]=n.length;var l=0;return n.forEach(y=>l+=y.length+1),w()[r>>>2>>>0]=l,0}function Vt(e){return T?G(20,1,e):52}function Jt(e,r,n,l){return T?G(21,1,e,r,n,l):52}function Xt(e,r,n,l,y){return T?G(22,1,e,r,n,l,y):70}var Hr=[null,[],[]];function Qt(e,r,n,l){if(T)return G(23,1,e,r,n,l);r>>>=0,n>>>=0,l>>>=0;for(var y=0,b=0;b<n;b++){var v=w()[r>>>2>>>0],z=w()[r+4>>>2>>>0];r+=8;for(var Ce=0;Ce<z;Ce++){var fe=h()[v+Ce>>>0],he=Hr[e];fe===0||fe===10?((e===1?Ie:ne)(U(he,0)),he.length=0):he.push(fe)}y+=z}return w()[l>>>2>>>0]=y,0}var Zt=[31,29,31,30,31,30,31,31,30,31,30,31],Kt=[31,28,31,30,31,30,31,31,30,31,30,31];function Gr(e){var r=Array(se(e)+1);return Qe(e,r,0,r.length),r}var $r=(e,r)=>{a().set(e,r>>>0)};function er(e,r,n,l){function y(p,N,q){for(p=typeof p=="number"?p.toString():p||"";p.length<N;)p=q[0]+p;return p}function b(p,N){return y(p,N,"0")}function v(p,N){function q(fr){return 0>fr?-1:0<fr?1:0}var He;return(He=q(p.getFullYear()-N.getFullYear()))===0&&(He=q(p.getMonth()-N.getMonth()))===0&&(He=q(p.getDate()-N.getDate())),He}function z(p){switch(p.getDay()){case 0:return new Date(p.getFullYear()-1,11,29);case 1:return p;case 2:return new Date(p.getFullYear(),0,3);case 3:return new Date(p.getFullYear(),0,2);case 4:return new Date(p.getFullYear(),0,1);case 5:return new Date(p.getFullYear()-1,11,31);case 6:return new Date(p.getFullYear()-1,11,30)}}function Ce(p){var N=p.Qa;for(p=new Date(new Date(p.Ra+1900,0,1).getTime());0<N;){var q=p.getMonth(),He=($e(p.getFullYear())?Zt:Kt)[q];if(N>He-p.getDate())N-=He-p.getDate()+1,p.setDate(1),11>q?p.setMonth(q+1):(p.setMonth(0),p.setFullYear(p.getFullYear()+1));else{p.setDate(p.getDate()+N);break}}return q=new Date(p.getFullYear()+1,0,4),N=z(new Date(p.getFullYear(),0,4)),q=z(q),0>=v(N,p)?0>=v(q,p)?p.getFullYear()+1:p.getFullYear():p.getFullYear()-1}e>>>=0,r>>>=0,n>>>=0,l>>>=0;var fe=w()[l+40>>>2>>>0];l={kb:f()[l>>>2>>>0],jb:f()[l+4>>>2>>>0],Sa:f()[l+8>>>2>>>0],Wa:f()[l+12>>>2>>>0],Ta:f()[l+16>>>2>>>0],Ra:f()[l+20>>>2>>>0],Ma:f()[l+24>>>2>>>0],Qa:f()[l+28>>>2>>>0],qb:f()[l+32>>>2>>>0],ib:f()[l+36>>>2>>>0],lb:fe?ee(fe):""},n=ee(n),fe={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var he in fe)n=n.replace(new RegExp(he,"g"),fe[he]);var ir="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),ur="January February March April May June July August September October November December".split(" ");fe={"%a":p=>ir[p.Ma].substring(0,3),"%A":p=>ir[p.Ma],"%b":p=>ur[p.Ta].substring(0,3),"%B":p=>ur[p.Ta],"%C":p=>b((p.Ra+1900)/100|0,2),"%d":p=>b(p.Wa,2),"%e":p=>y(p.Wa,2," "),"%g":p=>Ce(p).toString().substring(2),"%G":Ce,"%H":p=>b(p.Sa,2),"%I":p=>(p=p.Sa,p==0?p=12:12<p&&(p-=12),b(p,2)),"%j":p=>{for(var N=0,q=0;q<=p.Ta-1;N+=($e(p.Ra+1900)?Zt:Kt)[q++]);return b(p.Wa+N,3)},"%m":p=>b(p.Ta+1,2),"%M":p=>b(p.jb,2),"%n":()=>`\n`,"%p":p=>0<=p.Sa&&12>p.Sa?"AM":"PM","%S":p=>b(p.kb,2),"%t":()=>"	","%u":p=>p.Ma||7,"%U":p=>b(Math.floor((p.Qa+7-p.Ma)/7),2),"%V":p=>{var N=Math.floor((p.Qa+7-(p.Ma+6)%7)/7);if(2>=(p.Ma+371-p.Qa-2)%7&&N++,N)N==53&&(q=(p.Ma+371-p.Qa)%7,q==4||q==3&&$e(p.Ra)||(N=1));else{N=52;var q=(p.Ma+7-p.Qa-1)%7;(q==4||q==5&&$e(p.Ra%400-1))&&N++}return b(N,2)},"%w":p=>p.Ma,"%W":p=>b(Math.floor((p.Qa+7-(p.Ma+6)%7)/7),2),"%y":p=>(p.Ra+1900).toString().substring(2),"%Y":p=>p.Ra+1900,"%z":p=>{p=p.ib;var N=0<=p;return p=Math.abs(p)/60,(N?"+":"-")+("0000"+(p/60*100+p%60)).slice(-4)},"%Z":p=>p.lb,"%%":()=>"%"},n=n.replace(/%%/g,"\\0\\0");for(he in fe)n.includes(he)&&(n=n.replace(new RegExp(he,"g"),fe[he](l)));return n=n.replace(/\\0\\0/g,"%"),he=Gr(n),he.length>r?0:($r(he,e),he.length-1)}M.Va();var Yr=[qe,st,m,ye,oe,d,k,$,Me,Ze,Rt,It,Bt,kt,Wt,Nt,$t,Yt,zt,qt,Vt,Jt,Xt,Qt],jr={b:function(e,r,n){throw e>>>=0,new t(e).Va(r>>>0,n>>>0),o=e,u++,o},L:function(e){tr(e>>>0,!B,1,!R,131072,!1),M.$a()},j:function(e){e>>>=0,T?postMessage({cmd:"cleanupThread",thread:e}):M.Ya(M.La[e])},H:O,h:ye,S:oe,D:d,F:k,T:$,Q:Me,J:Ze,P:Rt,n:It,E:Bt,B:kt,R:Wt,C:Nt,p:()=>1,z:function(e,r){e>>>=0,e==r>>>0?setTimeout(it):T?postMessage({targetThread:e,cmd:"checkMailbox"}):(e=M.La[e])&&e.postMessage({cmd:"checkMailbox"})},I:function(e,r,n,l,y){r>>>=0,n>>>=0,pt.length=l,y=y>>>0>>>3;for(var b=0;b<l;b++)pt[b]=g()[y+b>>>0];return e=r?Ge[r]:Yr[e],M.eb=n,n=e(...pt),M.eb=0,n},K:dt,o:function(e){D&&M.La[e>>>0].ref()},s:function(e,r,n){e=r+2097152>>>0<4194305-!!e?(e>>>0)+4294967296*r:NaN,n>>>=0,e=new Date(1e3*e),f()[n>>>2>>>0]=e.getUTCSeconds(),f()[n+4>>>2>>>0]=e.getUTCMinutes(),f()[n+8>>>2>>>0]=e.getUTCHours(),f()[n+12>>>2>>>0]=e.getUTCDate(),f()[n+16>>>2>>>0]=e.getUTCMonth(),f()[n+20>>>2>>>0]=e.getUTCFullYear()-1900,f()[n+24>>>2>>>0]=e.getUTCDay(),e=(e.getTime()-Date.UTC(e.getUTCFullYear(),0,1,0,0,0,0))/864e5|0,f()[n+28>>>2>>>0]=e},t:function(e,r,n){e=r+2097152>>>0<4194305-!!e?(e>>>0)+4294967296*r:NaN,n>>>=0,e=new Date(1e3*e),f()[n>>>2>>>0]=e.getSeconds(),f()[n+4>>>2>>>0]=e.getMinutes(),f()[n+8>>>2>>>0]=e.getHours(),f()[n+12>>>2>>>0]=e.getDate(),f()[n+16>>>2>>>0]=e.getMonth(),f()[n+20>>>2>>>0]=e.getFullYear()-1900,f()[n+24>>>2>>>0]=e.getDay(),r=($e(e.getFullYear())?Ht:Gt)[e.getMonth()]+e.getDate()-1|0,f()[n+28>>>2>>>0]=r,f()[n+36>>>2>>>0]=-(60*e.getTimezoneOffset()),r=new Date(e.getFullYear(),6,1).getTimezoneOffset();var l=new Date(e.getFullYear(),0,1).getTimezoneOffset();e=(r!=l&&e.getTimezoneOffset()==Math.min(l,r))|0,f()[n+32>>>2>>>0]=e},u:function(e){e>>>=0;var r=new Date(f()[e+20>>>2>>>0]+1900,f()[e+16>>>2>>>0],f()[e+12>>>2>>>0],f()[e+8>>>2>>>0],f()[e+4>>>2>>>0],f()[e>>>2>>>0],0),n=f()[e+32>>>2>>>0],l=r.getTimezoneOffset(),y=new Date(r.getFullYear(),6,1).getTimezoneOffset(),b=new Date(r.getFullYear(),0,1).getTimezoneOffset(),v=Math.min(b,y);return 0>n?f()[e+32>>>2>>>0]=+(y!=b&&v==l):0<n!=(v==l)&&(y=Math.max(b,y),r.setTime(r.getTime()+6e4*((0<n?v:y)-l))),f()[e+24>>>2>>>0]=r.getDay(),n=($e(r.getFullYear())?Ht:Gt)[r.getMonth()]+r.getDate()-1|0,f()[e+28>>>2>>>0]=n,f()[e>>>2>>>0]=r.getSeconds(),f()[e+4>>>2>>>0]=r.getMinutes(),f()[e+8>>>2>>>0]=r.getHours(),f()[e+12>>>2>>>0]=r.getDate(),f()[e+16>>>2>>>0]=r.getMonth(),f()[e+20>>>2>>>0]=r.getYear(),e=r.getTime(),e=isNaN(e)?-1:e/1e3,ar((Te=e,1<=+Math.abs(Te)?0<Te?+Math.floor(Te/4294967296)>>>0:~~+Math.ceil((Te-+(~~Te>>>0))/4294967296)>>>0:0)),e>>>0},q:$t,r:Yt,y:function(e,r,n,l){e>>>=0,r>>>=0,n>>>=0,l>>>=0;var y=new Date().getFullYear(),b=new Date(y,0,1),v=new Date(y,6,1);y=b.getTimezoneOffset();var z=v.getTimezoneOffset(),Ce=Math.max(y,z);w()[e>>>2>>>0]=60*Ce,f()[r>>>2>>>0]=+(y!=z),e=fe=>fe.toLocaleTimeString(void 0,{hour12:!1,timeZoneName:"short"}).split(" ")[1],b=e(b),v=e(v),z<y?(Re(b,n,17),Re(v,l,17)):(Re(b,l,17),Re(v,n,17))},c:()=>{te("")},O:function(e,r,n){e>>>=0,r>>>=0,n>>>=0,mt.length=0;for(var l;l=h()[r++>>>0];){var y=l!=105;y&=l!=112,n+=y&&n%8?4:0,mt.push(l==112?w()[n>>>2>>>0]:l==105?f()[n>>>2>>>0]:g()[n>>>3>>>0]),n+=y?8:4}return Ge[e](...mt)},k:()=>{},i:()=>Date.now(),U:()=>{throw De+=1,"unwind"},A:function(){return 4294901760},e:()=>performance.timeOrigin+performance.now(),f:()=>D?(br(),et(hr)).cpus().length:navigator.hardwareConcurrency,x:function(e){e>>>=0;var r=h().length;if(e<=r||4294901760<e)return!1;for(var n=1;4>=n;n*=2){var l=r*(1+.2/n);l=Math.min(l,e+100663296);var y=Math;l=Math.max(e,l);e:{y=(y.min.call(y,4294901760,l+(65536-l%65536)%65536)-X.buffer.byteLength+65535)/65536;try{X.grow(y),K();var b=1;break e}catch{}b=void 0}if(b)return!0}return!1},M:zt,N:qt,G:Ve,g:Vt,m:Jt,v:Xt,l:Qt,a:X||s.wasmMemory,w:er,d:function(e,r,n,l){return er(e>>>0,r>>>0,n>>>0,l>>>0)}},C=function(){function e(n,l){return C=n.exports,C=zr(),M.ab.push(C.ya),Xe=C.za,Ue.unshift(C.V),we=l,Be(),C}var r={a:jr};if(Ae++,s.instantiateWasm)try{return s.instantiateWasm(r,e)}catch(n){ne(`Module.instantiateWasm callback failed with error: ${n}`),x(n)}return rt(r,function(n){e(n.instance,n.module)}).catch(x),{}}();s._OrtInit=(e,r)=>(s._OrtInit=C.W)(e,r),s._OrtGetLastError=(e,r)=>(s._OrtGetLastError=C.X)(e,r),s._OrtCreateSessionOptions=(e,r,n,l,y,b,v,z,Ce,fe)=>(s._OrtCreateSessionOptions=C.Y)(e,r,n,l,y,b,v,z,Ce,fe),s._OrtAppendExecutionProvider=(e,r)=>(s._OrtAppendExecutionProvider=C.Z)(e,r),s._OrtAddFreeDimensionOverride=(e,r,n)=>(s._OrtAddFreeDimensionOverride=C._)(e,r,n),s._OrtAddSessionConfigEntry=(e,r,n)=>(s._OrtAddSessionConfigEntry=C.$)(e,r,n),s._OrtReleaseSessionOptions=e=>(s._OrtReleaseSessionOptions=C.aa)(e),s._OrtCreateSession=(e,r,n)=>(s._OrtCreateSession=C.ba)(e,r,n),s._OrtReleaseSession=e=>(s._OrtReleaseSession=C.ca)(e),s._OrtGetInputOutputCount=(e,r,n)=>(s._OrtGetInputOutputCount=C.da)(e,r,n),s._OrtGetInputName=(e,r)=>(s._OrtGetInputName=C.ea)(e,r),s._OrtGetOutputName=(e,r)=>(s._OrtGetOutputName=C.fa)(e,r),s._OrtFree=e=>(s._OrtFree=C.ga)(e),s._OrtCreateTensor=(e,r,n,l,y,b)=>(s._OrtCreateTensor=C.ha)(e,r,n,l,y,b),s._OrtGetTensorData=(e,r,n,l,y)=>(s._OrtGetTensorData=C.ia)(e,r,n,l,y),s._OrtReleaseTensor=e=>(s._OrtReleaseTensor=C.ja)(e),s._OrtCreateRunOptions=(e,r,n,l)=>(s._OrtCreateRunOptions=C.ka)(e,r,n,l),s._OrtAddRunConfigEntry=(e,r,n)=>(s._OrtAddRunConfigEntry=C.la)(e,r,n),s._OrtReleaseRunOptions=e=>(s._OrtReleaseRunOptions=C.ma)(e),s._OrtCreateBinding=e=>(s._OrtCreateBinding=C.na)(e),s._OrtBindInput=(e,r,n)=>(s._OrtBindInput=C.oa)(e,r,n),s._OrtBindOutput=(e,r,n,l)=>(s._OrtBindOutput=C.pa)(e,r,n,l),s._OrtClearBoundOutputs=e=>(s._OrtClearBoundOutputs=C.qa)(e),s._OrtReleaseBinding=e=>(s._OrtReleaseBinding=C.ra)(e),s._OrtRunWithBinding=(e,r,n,l,y)=>(s._OrtRunWithBinding=C.sa)(e,r,n,l,y),s._OrtRun=(e,r,n,l,y,b,v,z)=>(s._OrtRun=C.ta)(e,r,n,l,y,b,v,z),s._OrtEndProfiling=e=>(s._OrtEndProfiling=C.ua)(e);var ut=s._pthread_self=()=>(ut=s._pthread_self=C.va)();s._malloc=e=>(s._malloc=C.wa)(e),s._free=e=>(s._free=C.xa)(e),s.__emscripten_tls_init=()=>(s.__emscripten_tls_init=C.ya)();var tr=s.__emscripten_thread_init=(e,r,n,l,y,b)=>(tr=s.__emscripten_thread_init=C.Aa)(e,r,n,l,y,b);s.__emscripten_thread_crashed=()=>(s.__emscripten_thread_crashed=C.Ba)();var rr=(e,r,n,l,y)=>(rr=C.Ca)(e,r,n,l,y),bt=e=>(bt=C.Da)(e),yt=s.__emscripten_thread_exit=e=>(yt=s.__emscripten_thread_exit=C.Ea)(e),nr=()=>(nr=C.Fa)(),ar=e=>(ar=C.Ga)(e),or=(e,r)=>(or=C.Ha)(e,r),ft=e=>(ft=C.Ia)(e),wt=e=>(wt=C.Ja)(e),Ot=()=>(Ot=C.Ka)();function zr(){var e=C;e=Object.assign({},e);var r=l=>()=>l()>>>0,n=l=>y=>l(y)>>>0;return e.va=r(e.va),e.wa=n(e.wa),e.emscripten_main_runtime_thread_id=r(e.emscripten_main_runtime_thread_id),e.Ja=n(e.Ja),e.Ka=r(e.Ka),e}s.wasmMemory=X,s.stackSave=()=>Ot(),s.stackRestore=e=>ft(e),s.stackAlloc=e=>wt(e),s.keepRuntimeAlive=()=>0<De,s.UTF8ToString=ee,s.stringToUTF8=Re,s.lengthBytesUTF8=se,s.ExitStatus=ke,s.PThread=M;var lt;ge=function e(){lt||sr(),lt||(ge=e)};function sr(){if(!(0<Ae))if(T)S(s),T||Ne(Ue),startWorker(s);else{if(s.preRun)for(typeof s.preRun=="function"&&(s.preRun=[s.preRun]);s.preRun.length;)Oe.unshift(s.preRun.shift());Ne(Oe),0<Ae||lt||(lt=!0,s.calledRun=!0,me||(T||Ne(Ue),S(s),T||Ne(ve)))}}return sr(),H}})();typeof wr=="object"&&typeof Dt=="object"?Dt.exports=yr:typeof define=="function"&&define.amd&&define([],()=>yr)});var vr=Ke((yn,tn)=>{tn.exports=\'"use strict";var Module={},ENVIRONMENT_IS_NODE=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string";if(ENVIRONMENT_IS_NODE){var nodeWorkerThreads=require("worker_threads"),parentPort=nodeWorkerThreads.parentPort;parentPort.on("message",e=>onmessage({data:e}));var fs=require("fs"),vm=require("vm");Object.assign(global,{self:global,require,Module,location:{href:__filename},Worker:nodeWorkerThreads.Worker,importScripts:e=>vm.runInThisContext(fs.readFileSync(e,"utf8"),{filename:e}),postMessage:e=>parentPort.postMessage(e),performance:global.performance||{now:Date.now}})}var initializedJS=!1;function threadPrintErr(...e){var a=e.join(" ");if(ENVIRONMENT_IS_NODE){fs.writeSync(2,a+`\\n`);return}console.error(a)}function threadAlert(...e){var a=e.join(" ");postMessage({cmd:"alert",text:a,threadId:Module._pthread_self()})}var err=threadPrintErr;self.alert=threadAlert,Module.instantiateWasm=(e,a)=>{var r=Module.wasmModule;Module.wasmModule=null;var t=new WebAssembly.Instance(r,e);return a(t)},self.onunhandledrejection=e=>{throw e.reason||e};function handleMessage(e){try{if(e.data.cmd==="load"){let r=[];self.onmessage=t=>r.push(t),self.startWorker=t=>{Module=t,postMessage({cmd:"loaded"});for(let s of r)handleMessage(s);self.onmessage=handleMessage},Module.wasmModule=e.data.wasmModule;for(const t of e.data.handlers)Module[t]=(...s)=>{postMessage({cmd:"callHandler",handler:t,args:s})};if(Module.wasmMemory=e.data.wasmMemory,Module.buffer=Module.wasmMemory.buffer,Module.ENVIRONMENT_IS_PTHREAD=!0,typeof e.data.urlOrBlob=="string")importScripts(e.data.urlOrBlob);else{var a=URL.createObjectURL(e.data.urlOrBlob);importScripts(a),URL.revokeObjectURL(a)}ortWasmThreaded(Module)}else if(e.data.cmd==="run"){Module.__emscripten_thread_init(e.data.pthread_ptr,0,0,1),Module.__emscripten_thread_mailbox_await(e.data.pthread_ptr),Module.establishStackSpace(),Module.PThread.receiveObjectTransfer(e.data),Module.PThread.threadInitTLS(),initializedJS||(initializedJS=!0);try{Module.invokeEntryPoint(e.data.start_routine,e.data.arg)}catch(r){if(r!="unwind")throw r}}else e.data.cmd==="cancel"?Module._pthread_self()&&Module.__emscripten_thread_exit(-1):e.data.target==="setimmediate"||(e.data.cmd==="checkMailbox"?initializedJS&&Module.checkMailbox():e.data.cmd&&(err(`worker.js received unknown command ${e.data.cmd}`),err(e.data)))}catch(r){throw Module.__emscripten_thread_crashed?.(),r}}self.onmessage=handleMessage;\\n\'});var Er;Er=pr();var rn=Or(),Ft,Pt=!1,ct=!1,_r=!1,nn=i=>{if(i===1)return!1;if(typeof SharedArrayBuffer>"u")return typeof self<"u"&&!self.crossOriginIsolated&&console.warn("env.wasm.numThreads is set to "+i+", but this will not work unless you enable crossOriginIsolated mode. See https://web.dev/cross-origin-isolation-guide/ for more info."),!1;typeof process<"u"&&process.versions&&process.versions.node&&console.warn("env.wasm.numThreads is set to "+i+", however, currently onnxruntime-web does not support multi-threads in Node.js. Please consider using onnxruntime-node for performance critical scenarios.");try{return typeof MessageChannel<"u"&&new MessageChannel().port1.postMessage(new SharedArrayBuffer(1)),WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,5,4,1,3,1,1,10,11,1,9,0,65,0,254,16,2,0,26,11]))}catch{return!1}},an=()=>{try{return WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,10,30,1,28,0,65,0,253,15,253,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,253,186,1,26,11]))}catch{return!1}},on=(i,c)=>i?c?"ort-wasm-simd-threaded.wasm":"ort-wasm-simd.wasm":c?"ort-wasm-threaded.wasm":"ort-wasm.wasm",Sr=async i=>{if(Pt)return Promise.resolve();if(ct)throw new Error("multiple calls to \'initializeWebAssembly()\' detected.");if(_r)throw new Error("previous call to \'initializeWebAssembly()\' failed.");ct=!0;let c=i.initTimeout,a=i.numThreads,h=i.simd,f=nn(a),w=h&&an(),g=i.wasmPaths,s=typeof g=="string"?g:void 0,S=on(w,f),x=typeof g=="object"?g[S]:void 0,H=!1,A=[];if(c>0&&A.push(new Promise(I=>{setTimeout(()=>{H=!0,I()},c)})),A.push(new Promise((I,V)=>{let R=f?rn:Er,B={locateFile:(D,T)=>f&&D.endsWith(".worker.js")&&typeof Blob<"u"?URL.createObjectURL(new Blob([vr()],{type:"text/javascript"})):D.endsWith(".wasm")?x||(s??T)+S:T+D};if(f)if(B.numThreads=a,typeof Blob>"u")B.mainScriptUrlOrBlob=(void 0)(__dirname,"ort-wasm-threaded.js");else{let D=`var ortWasmThreaded=${R.toString()};`;B.mainScriptUrlOrBlob=new Blob([D],{type:"text/javascript"})}R(B).then(D=>{ct=!1,Pt=!0,Ft=D,I()},D=>{ct=!1,_r=!0,V(D)})})),await Promise.race(A),H)throw new Error(`WebAssembly backend initializing failed due to timeout: ${c}ms`)},Q=()=>{if(Pt&&Ft)return Ft;throw new Error("WebAssembly is not initialized yet.")};var Y=(i,c)=>{let a=Q(),h=a.lengthBytesUTF8(i)+1,f=a._malloc(h);return a.stringToUTF8(i,f,h),c.push(f),f},tt=(i,c,a,h)=>{if(typeof i=="object"&&i!==null){if(a.has(i))throw new Error("Circular reference in options");a.add(i)}Object.entries(i).forEach(([f,w])=>{let g=c?c+f:f;if(typeof w=="object")tt(w,g+".",a,h);else if(typeof w=="string"||typeof w=="number")h(g,w.toString());else if(typeof w=="boolean")h(g,w?"1":"0");else throw new Error(`Can\'t handle extra config type: ${typeof w}`)})},j=i=>{let c=Q(),a=c.stackSave();try{let h=c.stackAlloc(8);c._OrtGetLastError(h,h+4);let f=c.HEAP32[h/4],w=c.HEAPU32[h/4+1],g=w?c.UTF8ToString(w):"";throw new Error(`${i} ERROR_CODE: ${f}, ERROR_MESSAGE: ${g}`)}finally{c.stackRestore(a)}};var Ar=i=>{let c=Q(),a=0,h=[],f=i||{};try{if(i?.logSeverityLevel===void 0)f.logSeverityLevel=2;else if(typeof i.logSeverityLevel!="number"||!Number.isInteger(i.logSeverityLevel)||i.logSeverityLevel<0||i.logSeverityLevel>4)throw new Error(`log serverity level is not valid: ${i.logSeverityLevel}`);if(i?.logVerbosityLevel===void 0)f.logVerbosityLevel=0;else if(typeof i.logVerbosityLevel!="number"||!Number.isInteger(i.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${i.logVerbosityLevel}`);i?.terminate===void 0&&(f.terminate=!1);let w=0;return i?.tag!==void 0&&(w=Y(i.tag,h)),a=c._OrtCreateRunOptions(f.logSeverityLevel,f.logVerbosityLevel,!!f.terminate,w),a===0&&j("Can\'t create run options."),i?.extra!==void 0&&tt(i.extra,"",new WeakSet,(g,s)=>{let S=Y(g,h),x=Y(s,h);c._OrtAddRunConfigEntry(a,S,x)!==0&&j(`Can\'t set a run config entry: ${g} - ${s}.`)}),[a,h]}catch(w){throw a!==0&&c._OrtReleaseRunOptions(a),h.forEach(g=>c._free(g)),w}};var sn=i=>{switch(i){case"disabled":return 0;case"basic":return 1;case"extended":return 2;case"all":return 99;default:throw new Error(`unsupported graph optimization level: ${i}`)}},un=i=>{switch(i){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${i}`)}},fn=i=>{i.extra||(i.extra={}),i.extra.session||(i.extra.session={});let c=i.extra.session;c.use_ort_model_bytes_directly||(c.use_ort_model_bytes_directly="1"),i.executionProviders&&i.executionProviders.some(a=>(typeof a=="string"?a:a.name)==="webgpu")&&(i.enableMemPattern=!1)},ln=(i,c,a)=>{for(let h of c){let f=typeof h=="string"?h:h.name;switch(f){case"webnn":if(f="WEBNN",typeof h!="string"){let g=h;if(g?.deviceType){let s=Y("deviceType",a),S=Y(g.deviceType,a);Q()._OrtAddSessionConfigEntry(i,s,S)!==0&&j(`Can\'t set a session config entry: \'deviceType\' - ${g.deviceType}.`)}if(g?.numThreads){let s=g.numThreads;(typeof s!="number"||!Number.isInteger(s)||s<0)&&(s=0);let S=Y("numThreads",a),x=Y(s.toString(),a);Q()._OrtAddSessionConfigEntry(i,S,x)!==0&&j(`Can\'t set a session config entry: \'numThreads\' - ${g.numThreads}.`)}if(g?.powerPreference){let s=Y("powerPreference",a),S=Y(g.powerPreference,a);Q()._OrtAddSessionConfigEntry(i,s,S)!==0&&j(`Can\'t set a session config entry: \'powerPreference\' - ${g.powerPreference}.`)}}break;case"webgpu":if(f="JS",typeof h!="string"){let g=h;if(g?.preferredLayout){if(g.preferredLayout!=="NCHW"&&g.preferredLayout!=="NHWC")throw new Error(`preferredLayout must be either \'NCHW\' or \'NHWC\': ${g.preferredLayout}`);let s=Y("preferredLayout",a),S=Y(g.preferredLayout,a);Q()._OrtAddSessionConfigEntry(i,s,S)!==0&&j(`Can\'t set a session config entry: \'preferredLayout\' - ${g.preferredLayout}.`)}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${f}`)}let w=Y(f,a);Q()._OrtAppendExecutionProvider(i,w)!==0&&j(`Can\'t append execution provider: ${f}.`)}},Tr=i=>{let c=Q(),a=0,h=[],f=i||{};fn(f);try{let w=sn(f.graphOptimizationLevel??"all"),g=un(f.executionMode??"sequential"),s=typeof f.logId=="string"?Y(f.logId,h):0,S=f.logSeverityLevel??2;if(!Number.isInteger(S)||S<0||S>4)throw new Error(`log serverity level is not valid: ${S}`);let x=f.logVerbosityLevel??0;if(!Number.isInteger(x)||x<0||x>4)throw new Error(`log verbosity level is not valid: ${x}`);let H=typeof f.optimizedModelFilePath=="string"?Y(f.optimizedModelFilePath,h):0;if(a=c._OrtCreateSessionOptions(w,!!f.enableCpuMemArena,!!f.enableMemPattern,g,!!f.enableProfiling,0,s,S,x,H),a===0&&j("Can\'t create session options."),f.executionProviders&&ln(a,f.executionProviders,h),f.enableGraphCapture!==void 0){if(typeof f.enableGraphCapture!="boolean")throw new Error(`enableGraphCapture must be a boolean value: ${f.enableGraphCapture}`);let A=Y("enableGraphCapture",h),I=Y(f.enableGraphCapture.toString(),h);c._OrtAddSessionConfigEntry(a,A,I)!==0&&j(`Can\'t set a session config entry: \'enableGraphCapture\' - ${f.enableGraphCapture}.`)}if(f.freeDimensionOverrides)for(let[A,I]of Object.entries(f.freeDimensionOverrides)){if(typeof A!="string")throw new Error(`free dimension override name must be a string: ${A}`);if(typeof I!="number"||!Number.isInteger(I)||I<0)throw new Error(`free dimension override value must be a non-negative integer: ${I}`);let V=Y(A,h);c._OrtAddFreeDimensionOverride(a,V,I)!==0&&j(`Can\'t set a free dimension override: ${A} - ${I}.`)}return f.extra!==void 0&&tt(f.extra,"",new WeakSet,(A,I)=>{let V=Y(A,h),R=Y(I,h);c._OrtAddSessionConfigEntry(a,V,R)!==0&&j(`Can\'t set a session config entry: ${A} - ${I}.`)}),[a,h]}catch(w){throw a!==0&&c._OrtReleaseSessionOptions(a),h.forEach(g=>c._free(g)),w}};var xt=i=>{switch(i){case"int8":return 3;case"uint8":return 2;case"bool":return 9;case"int16":return 5;case"uint16":return 4;case"int32":return 6;case"uint32":return 12;case"float16":return 10;case"float32":return 1;case"float64":return 11;case"string":return 8;case"int64":return 7;case"uint64":return 13;default:throw new Error(`unsupported data type: ${i}`)}},Mr=i=>{switch(i){case 3:return"int8";case 2:return"uint8";case 9:return"bool";case 5:return"int16";case 4:return"uint16";case 6:return"int32";case 12:return"uint32";case 10:return"float16";case 1:return"float32";case 11:return"float64";case 8:return"string";case 7:return"int64";case 13:return"uint64";default:throw new Error(`unsupported data type: ${i}`)}},Ut=i=>[void 0,4,1,1,2,2,4,8,void 0,1,2,8,4,8,void 0,void 0,void 0][i],Cr=i=>{switch(i){case"float16":return typeof Float16Array<"u"&&Float16Array.from?Float16Array:Uint16Array;case"float32":return Float32Array;case"uint8":return Uint8Array;case"int8":return Int8Array;case"uint16":return Uint16Array;case"int16":return Int16Array;case"int32":return Int32Array;case"bool":return Uint8Array;case"float64":return Float64Array;case"uint32":return Uint32Array;case"int64":return BigInt64Array;case"uint64":return BigUint64Array;default:throw new Error(`unsupported type: ${i}`)}},Dr=i=>{switch(i){case"verbose":return 0;case"info":return 1;case"warning":return 2;case"error":return 3;case"fatal":return 4;default:throw new Error(`unsupported logging level: ${i}`)}},Fr=i=>i==="float32"||i==="float16"||i==="int32"||i==="int64"||i==="uint32"||i==="uint8"||i==="bool",Pr=i=>{switch(i){case"none":return 0;case"cpu":return 1;case"cpu-pinned":return 2;case"texture":return 3;case"gpu-buffer":return 4;default:throw new Error(`unsupported data location: ${i}`)}};var xr=async i=>{if(typeof i=="string")if(typeof process<"u"&&process.versions&&process.versions.node)try{return new Uint8Array(await(void 0)(i))}catch(c){if(c.code==="ERR_FS_FILE_TOO_LARGE"){let a=(void 0)(i),h=[];for await(let f of a)h.push(f);return new Uint8Array(Buffer.concat(h))}throw c}else{let c=await fetch(i);if(!c.ok)throw new Error(`failed to load external data file: ${i}`);let a=c.headers.get("Content-Length"),h=a?parseInt(a,10):0;if(h<1073741824)return new Uint8Array(await c.arrayBuffer());{if(!c.body)throw new Error(`failed to load external data file: ${i}, no response body.`);let f=c.body.getReader(),w;try{w=new ArrayBuffer(h)}catch(s){if(s instanceof RangeError){let S=Math.ceil(h/65536);w=new WebAssembly.Memory({initial:S,maximum:S}).buffer}else throw s}let g=0;for(;;){let{done:s,value:S}=await f.read();if(s)break;let x=S.byteLength;new Uint8Array(w,g,x).set(S),g+=x}return new Uint8Array(w,0,h)}}else return i instanceof Blob?new Uint8Array(await i.arrayBuffer()):i instanceof Uint8Array?i:new Uint8Array(i)};var cn=(i,c)=>{Q()._OrtInit(i,c)!==0&&j("Can\'t initialize onnxruntime.")},Lr=async i=>{cn(i.wasm.numThreads,Dr(i.logLevel))},Rr=async(i,c)=>{},Ye=new Map,dn=i=>{let c=Q(),a=c.stackSave();try{let h=c.stackAlloc(8);return c._OrtGetInputOutputCount(i,h,h+4)!==0&&j("Can\'t get session input/output count."),[c.HEAP32[h/4],c.HEAP32[h/4+1]]}finally{c.stackRestore(a)}},Lt=i=>{let c=Q(),a=c._malloc(i.byteLength);if(a===0)throw new Error(`Can\'t create a session. failed to allocate a buffer of size ${i.byteLength}.`);return c.HEAPU8.set(i,a),[a,i.byteLength]},Ir=async(i,c)=>{let a,h,f=Q();Array.isArray(i)?[a,h]=i:i.buffer===f.HEAPU8.buffer?[a,h]=[i.byteOffset,i.byteLength]:[a,h]=Lt(i);let w=0,g=0,s=0,S=[],x=[],H=[];try{if([g,S]=Tr(c),c?.externalData&&f.mountExternalData){let L=[];for(let W of c.externalData){let de=typeof W=="string"?W:W.path;L.push(xr(typeof W=="string"?W:W.data).then(pe=>{f.mountExternalData(de,pe)}))}await Promise.all(L)}w=await f._OrtCreateSession(a,h,g),w===0&&j("Can\'t create a session.");let[A,I]=dn(w),V=!!c?.enableGraphCapture,R=[],B=[],D=[];for(let L=0;L<A;L++){let W=f._OrtGetInputName(w,L);W===0&&j("Can\'t get an input name."),x.push(W),R.push(f.UTF8ToString(W))}for(let L=0;L<I;L++){let W=f._OrtGetOutputName(w,L);W===0&&j("Can\'t get an output name."),H.push(W);let de=f.UTF8ToString(W);B.push(de)}let T=null;return Ye.set(w,[w,x,H,T,V,!1]),[w,R,B]}catch(A){throw x.forEach(I=>f._OrtFree(I)),H.forEach(I=>f._OrtFree(I)),s!==0&&f._OrtReleaseBinding(s),w!==0&&f._OrtReleaseSession(w),A}finally{f._free(a),g!==0&&f._OrtReleaseSessionOptions(g),S.forEach(A=>f._free(A)),f.unmountExternalData?.()}},Br=i=>{let c=Q(),a=Ye.get(i);if(!a)throw new Error(`cannot release session. invalid session id: ${i}`);let[h,f,w,g,s]=a;g&&(s&&c._OrtClearBoundOutputs(g.handle),c._OrtReleaseBinding(g.handle)),c.jsepOnReleaseSession?.(i),f.forEach(S=>c._OrtFree(S)),w.forEach(S=>c._OrtFree(S)),c._OrtReleaseSession(h),Ye.delete(i)},Ur=(i,c,a,h,f,w=!1)=>{if(!i){c.push(0);return}let g=Q(),s=i[0],S=i[1],x=i[3],H,A;if(s==="string"&&x==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");if(w&&x!=="gpu-buffer")throw new Error(`External buffer must be provided for input/output index ${f} when enableGraphCapture is true.`);if(x==="gpu-buffer"){let R=i[2].gpuBuffer,B=Ut(xt(s));A=S.reduce((T,L)=>T*L,1)*B;let D=g.jsepRegisterBuffer;if(!D)throw new Error(\'Tensor location "gpu-buffer" is not supported without using WebGPU.\');H=D(h,f,R,A)}else{let R=i[2];if(Array.isArray(R)){A=4*R.length,H=g._malloc(A),a.push(H);let B=H/4;for(let D=0;D<R.length;D++){if(typeof R[D]!="string")throw new TypeError(`tensor data at index ${D} is not a string`);g.HEAPU32[B++]=Y(R[D],a)}}else A=R.byteLength,H=g._malloc(A),a.push(H),g.HEAPU8.set(new Uint8Array(R.buffer,R.byteOffset,A),H)}let I=g.stackSave(),V=g.stackAlloc(4*S.length);try{let R=V/4;S.forEach(D=>g.HEAP32[R++]=D);let B=g._OrtCreateTensor(xt(s),H,A,V,S.length,Pr(x));B===0&&j(`Can\'t create tensor for input/output. session=${h}, index=${f}.`),c.push(B)}finally{g.stackRestore(I)}},kr=async(i,c,a,h,f,w)=>{let g=Q(),s=Ye.get(i);if(!s)throw new Error(`cannot run inference. invalid session id: ${i}`);let S=s[0],x=s[1],H=s[2],A=s[3],I=s[4],V=s[5],R=c.length,B=h.length,D=0,T=[],L=[],W=[],de=[],pe=g.stackSave(),Z=g.stackAlloc(R*4),_=g.stackAlloc(R*4),J=g.stackAlloc(B*4),Pe=g.stackAlloc(B*4);try{[D,T]=Ar(w);for(let F=0;F<R;F++)Ur(a[F],L,de,i,c[F],I);for(let F=0;F<B;F++)Ur(f[F],W,de,i,R+h[F],I);let le=Z/4,Ie=_/4,ne=J/4,X=Pe/4;for(let F=0;F<R;F++)g.HEAPU32[le++]=L[F],g.HEAPU32[Ie++]=x[c[F]];for(let F=0;F<B;F++)g.HEAPU32[ne++]=W[F],g.HEAPU32[X++]=H[h[F]];g.jsepOnRunStart?.(S);let we;we=await g._OrtRun(S,_,Z,R,Pe,B,J,D),we!==0&&j("failed to call OrtRun().");let me=[];for(let F=0;F<B;F++){let ie=g.HEAPU32[J/4+F];if(ie===W[F]){me.push(f[F]);continue}let xe=g.stackSave(),ce=g.stackAlloc(4*4),be=!1,ae,K=0;try{g._OrtGetTensorData(ie,ce,ce+4,ce+8,ce+12)!==0&&j(`Can\'t access output tensor data on index ${F}.`);let Oe=ce/4,Ue=g.HEAPU32[Oe++];K=g.HEAPU32[Oe++];let ve=g.HEAPU32[Oe++],Ae=g.HEAPU32[Oe++],_e=[];for(let te=0;te<Ae;te++)_e.push(g.HEAPU32[ve/4+te]);g._OrtFree(ve);let ge=_e.reduce((te,re)=>te*re,1);ae=Mr(Ue);let Be=A?.outputPreferredLocations[h[F]];if(ae==="string"){if(Be==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");let te=[],re=K/4;for(let ue=0;ue<ge;ue++){let Ee=g.HEAPU32[re++],Se=ue===ge-1?void 0:g.HEAPU32[re]-Ee;te.push(g.UTF8ToString(Ee,Se))}me.push([ae,_e,te,"cpu"])}else if(Be==="gpu-buffer"&&ge>0){let te=g.jsepGetBuffer;if(!te)throw new Error(\'preferredLocation "gpu-buffer" is not supported without using WebGPU.\');let re=te(K),ue=Ut(Ue);if(ue===void 0||!Fr(ae))throw new Error(`Unsupported data type: ${ae}`);be=!0,me.push([ae,_e,{gpuBuffer:re,download:g.jsepCreateDownloader(re,ge*ue,ae),dispose:()=>{g._OrtReleaseTensor(ie)}},"gpu-buffer"])}else{let te=Cr(ae),re=new te(ge);new Uint8Array(re.buffer,re.byteOffset,re.byteLength).set(g.HEAPU8.subarray(K,K+re.byteLength)),me.push([ae,_e,re,"cpu"])}}finally{g.stackRestore(xe),ae==="string"&&K&&g._free(K),be||g._OrtReleaseTensor(ie)}}return A&&!I&&(g._OrtClearBoundOutputs(A.handle),Ye.set(i,[S,x,H,A,I,!1])),me}finally{g.stackRestore(pe),L.forEach(le=>g._OrtReleaseTensor(le)),W.forEach(le=>g._OrtReleaseTensor(le)),de.forEach(le=>g._free(le)),D!==0&&g._OrtReleaseRunOptions(D),T.forEach(le=>g._free(le))}},Wr=i=>{let c=Q(),a=Ye.get(i);if(!a)throw new Error("invalid session id");let h=a[0],f=c._OrtEndProfiling(h);f===0&&j("Can\'t get an profile file name."),c._OrtFree(f)},Nr=i=>{let c=[];for(let a of i){let h=a[2];!Array.isArray(h)&&"buffer"in h&&c.push(h.buffer)}return c};self.onmessage=i=>{let{type:c,in:a}=i.data;try{switch(c){case"init-wasm":Sr(a.wasm).then(()=>{Lr(a).then(()=>{postMessage({type:c})},h=>{postMessage({type:c,err:h})})},h=>{postMessage({type:c,err:h})});break;case"init-ep":{let{epName:h,env:f}=a;Rr(f,h).then(()=>{postMessage({type:c})},w=>{postMessage({type:c,err:w})});break}case"copy-from":{let{buffer:h}=a,f=Lt(h);postMessage({type:c,out:f});break}case"create":{let{model:h,options:f}=a;Ir(h,f).then(w=>{postMessage({type:c,out:w})},w=>{postMessage({type:c,err:w})});break}case"release":Br(a),postMessage({type:c});break;case"run":{let{sessionId:h,inputIndices:f,inputs:w,outputIndices:g,options:s}=a;kr(h,f,w,g,new Array(g.length).fill(null),s).then(S=>{S.some(x=>x[3]!=="cpu")?postMessage({type:c,err:"Proxy does not support non-cpu tensor location."}):postMessage({type:c,out:S},Nr([...w,...S]))},S=>{postMessage({type:c,err:S})});break}case"end-profiling":Wr(a),postMessage({type:c});break;default:}}catch(h){postMessage({type:c,err:h})}};})();\n'}),T3,n1,Q4,D4,_4,R6,U5,f3,l3,B2,P4,HH,ZH,jH,VH,XH,KH,UH,qH=E(()=>{z3(),vV(),s4(),T3=()=>!!i.wasm.proxy&&typeof document<"u",Q4=!1,D4=!1,_4=!1,U5=new Map,f3=(Q,H)=>{let j=U5.get(Q);j?j.push(H):U5.set(Q,[H])},l3=()=>{if(Q4||!D4||_4||!n1)throw new Error("worker not ready")},B2=(Q)=>{switch(Q.data.type){case"init-wasm":Q4=!1,Q.data.err?(_4=!0,R6[1](Q.data.err)):(D4=!0,R6[0]());break;case"init-ep":case"copy-from":case"create":case"release":case"run":case"end-profiling":{let H=U5.get(Q.data.type);Q.data.err?H.shift()[1](Q.data.err):H.shift()[0](Q.data.out);break}default:}},P4=typeof document<"u"?document?.currentScript?.src:void 0,HH=async()=>{if(!D4){if(Q4)throw new Error("multiple calls to 'initWasm()' detected.");if(_4)throw new Error("previous call to 'initWasm()' failed.");if(Q4=!0,T3())return i.wasm.wasmPaths===void 0&&P4&&P4.indexOf("blob:")!==0&&(i.wasm.wasmPaths=P4.substr(0,+P4.lastIndexOf("/")+1)),new Promise((Q,H)=>{n1?.terminate();let j=URL.createObjectURL(new Blob([wV()],{type:"text/javascript"}));n1=new Worker(j,{name:"ort-wasm-proxy-worker"}),n1.onerror=(W)=>H(W),n1.onmessage=B2,URL.revokeObjectURL(j),R6=[Q,H];let K={type:"init-wasm",in:i};n1.postMessage(K)});try{await bJ(i.wasm),await aJ(i),D4=!0}catch(Q){throw _4=!0,Q}finally{Q4=!1}}},ZH=async(Q)=>{if(T3())return l3(),new Promise((H,j)=>{f3("init-ep",[H,j]);let K={type:"init-ep",in:{epName:Q,env:i}};n1.postMessage(K)});await nJ(i,Q)},jH=async(Q)=>T3()?(l3(),new Promise((H,j)=>{f3("copy-from",[H,j]);let K={type:"copy-from",in:{buffer:Q}};n1.postMessage(K,[Q.buffer])})):o6(Q),VH=async(Q,H)=>{if(T3()){if(H?.preferredOutputLocation)throw new Error('session option "preferredOutputLocation" is not supported for proxy.');return l3(),new Promise((j,K)=>{f3("create",[j,K]);let W={type:"create",in:{model:Q,options:{...H}}},U=[];Q instanceof Uint8Array&&U.push(Q.buffer),n1.postMessage(W,U)})}else return rJ(Q,H)},XH=async(Q)=>{if(T3())return l3(),new Promise((H,j)=>{f3("release",[H,j]);let K={type:"release",in:Q};n1.postMessage(K)});tJ(Q)},KH=async(Q,H,j,K,W,U)=>{if(T3()){if(j.some((Z)=>Z[3]!=="cpu"))throw new Error("input tensor on GPU is not supported for proxy.");if(W.some((Z)=>Z))throw new Error("pre-allocated output tensor is not supported for proxy.");return l3(),new Promise((Z,q)=>{f3("run",[Z,q]);let G=j,J={type:"run",in:{sessionId:Q,inputIndices:H,inputs:G,outputIndices:K,options:U}};n1.postMessage(J,JH(G))})}else return eJ(Q,H,j,K,W,U)},UH=async(Q)=>{if(T3())return l3(),new Promise((H,j)=>{f3("end-profiling",[H,j]);let K={type:"end-profiling",in:Q};n1.postMessage(K)});QH(Q)}}),z6,F2,WH,TV=E(()=>{z3(),qH(),iJ(),oJ(),z6=(Q,H)=>{switch(Q.location){case"cpu":return[Q.type,Q.dims,Q.data,"cpu"];case"gpu-buffer":return[Q.type,Q.dims,{gpuBuffer:Q.gpuBuffer},"gpu-buffer"];default:throw new Error(`invalid data location: ${Q.location} for ${H()}`)}},F2=(Q)=>{switch(Q[3]){case"cpu":return new d1(Q[0],Q[2],Q[1]);case"gpu-buffer":{let H=Q[0];if(!R7(H))throw new Error(`not supported data type: ${H} for deserializing GPU tensor`);let{gpuBuffer:j,download:K,dispose:W}=Q[2];return d1.fromGpuBuffer(j,{dataType:H,dims:Q[1],download:K,dispose:W})}default:throw new Error(`invalid data location: ${Q[3]}`)}},WH=class{async fetchModelAndCopyToWasmMemory(Q){return jH(await Y5(Q))}async loadModel(Q,H){j4();let j;typeof Q=="string"?typeof process<"u"&&process.versions&&process.versions.node?j=await Y5(Q):j=await this.fetchModelAndCopyToWasmMemory(Q):j=Q,[this.sessionId,this.inputNames,this.outputNames]=await VH(j,H),V4()}async dispose(){return XH(this.sessionId)}async run(Q,H,j){j4();let K=[],W=[];Object.entries(Q).forEach((V)=>{let R=V[0],z=V[1],Y=this.inputNames.indexOf(R);if(Y===-1)throw new Error(`invalid input '${R}'`);K.push(z),W.push(Y)});let U=[],Z=[];Object.entries(H).forEach((V)=>{let R=V[0],z=V[1],Y=this.outputNames.indexOf(R);if(Y===-1)throw new Error(`invalid output '${R}'`);U.push(z),Z.push(Y)});let q=K.map((V,R)=>z6(V,()=>`input "${this.inputNames[W[R]]}"`)),G=U.map((V,R)=>V?z6(V,()=>`output "${this.outputNames[Z[R]]}"`):null),J=await KH(this.sessionId,W,q,Z,G,j),X={};for(let V=0;V<J.length;V++)X[this.outputNames[Z[V]]]=U[V]??F2(J[V]);return V4(),X}startProfiling(){}endProfiling(){UH(this.sessionId)}}}),k2,GH,DV=E(()=>{z3(),qH(),TV(),k2=()=>{if((typeof i.wasm.initTimeout!="number"||i.wasm.initTimeout<0)&&(i.wasm.initTimeout=0),typeof i.wasm.simd!="boolean"&&(i.wasm.simd=!0),typeof i.wasm.proxy!="boolean"&&(i.wasm.proxy=!1),typeof i.wasm.trace!="boolean"&&(i.wasm.trace=!1),typeof i.wasm.numThreads!="number"||!Number.isInteger(i.wasm.numThreads)||i.wasm.numThreads<=0){(typeof self<"u"&&!self.crossOriginIsolated||typeof process<"u"&&process.versions&&process.versions.node)&&(i.wasm.numThreads=1);let Q=typeof navigator>"u"?(void 0)().length:navigator.hardwareConcurrency;i.wasm.numThreads=Math.min(4,Math.ceil((Q||1)/2))}},GH=class{async init(Q){k2(),await HH(),await ZH(Q)}async createInferenceSessionHandler(Q,H){let j=new WH;return await j.loadModel(Q,H),Promise.resolve(j)}}}),RH={};X4(RH,{wasmBackend:()=>zH});var zH,_V=E(()=>{DV(),zH=new GH});z3();z3();z3();var PV="1.18.0",EV=s2;{let Q=(YV(),a3(PJ)).onnxjsBackend;p4("webgl",Q,-10)}{let Q=(_V(),a3(RH)).wasmBackend;p4("cpu",Q,10),p4("wasm",Q,10)}Object.defineProperty(i.versions,"web",{value:PV,enumerable:!0});/*! Bundled license information:
+
+long/index.js:
+  (**
+   * @license
+   * Copyright 2009 The Closure Library Authors
+   * Copyright 2020 Daniel Wirtz / The long.js Authors.
+   *
+   * Licensed under the Apache License, Version 2.0 (the "License");
+   * you may not use this file except in compliance with the License.
+   * You may obtain a copy of the License at
+   *
+   *     http://www.apache.org/licenses/LICENSE-2.0
+   *
+   * Unless required by applicable law or agreed to in writing, software
+   * distributed under the License is distributed on an "AS IS" BASIS,
+   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+   * See the License for the specific language governing permissions and
+   * limitations under the License.
+   *
+   * SPDX-License-Identifier: Apache-2.0
+   *)
+*/export{p4 as registerBackend,i as env,EV as default,u2 as TrainingSession,d1 as Tensor,V4 as TRACE_FUNC_END,j4 as TRACE_FUNC_BEGIN,Y6 as TRACE,f2 as InferenceSession};
diff --git a/docs/piper.js b/docs/piper.js
new file mode 100644
index 0000000..d126792
--- /dev/null
+++ b/docs/piper.js
@@ -0,0 +1,11 @@
+var QV=((l)=>typeof require!=="undefined"?require:typeof Proxy!=="undefined"?new Proxy(l,{get:(g,R)=>(typeof require!=="undefined"?require:g)[R]}):l)(function(l){if(typeof require!=="undefined")return require.apply(this,arguments);throw Error('Dynamic require of "'+l+'" is not supported')});var{defineProperty:D6,getOwnPropertyNames:X5,getOwnPropertyDescriptor:q5}=Object,G5=Object.prototype.hasOwnProperty,C6=(l)=>{const g=C6.moduleCache??=new WeakMap;var R=g.get(l);if(R)return R;var M=D6({},"__esModule",{value:!0}),B={enumerable:!1};if(l&&typeof l==="object"||typeof l==="function"){for(let A of X5(l))if(!G5.call(M,A))D6(M,A,{get:()=>l[A],enumerable:!(B=q5(l,A))||B.enumerable})}return g.set(l,M),M},M$=(l,g)=>{for(var R in g)D6(l,R,{get:g[R],enumerable:!0,configurable:!0,set:(M)=>g[R]=()=>M})},_$=(l,g)=>()=>(l&&(g=l(l=0)),g),Y5=((l)=>typeof QV!=="undefined"?QV:typeof Proxy!=="undefined"?new Proxy(l,{get:(g,R)=>(typeof QV!=="undefined"?QV:g)[R]}):l)(function(l){if(typeof QV!=="undefined")return QV.apply(this,arguments);throw Error('Dynamic require of "'+l+'" is not supported')}),b$={};M$(b$,{default:()=>{return k6}});var h6,yV,m6,u6,p6,i6,l6,s6,gV,d6,N0,I0,E0,k6,K5=_$(()=>{h6=Object.create,yV=Object.defineProperty,m6=Object.getOwnPropertyDescriptor,u6=Object.getOwnPropertyNames,p6=Object.getPrototypeOf,i6=Object.prototype.hasOwnProperty,l6=(l,g)=>()=>(g||l((g={exports:{}}).exports,g),g.exports),s6=(l,g)=>{for(var R in g)yV(l,R,{get:g[R],enumerable:!0})},gV=(l,g,R,M)=>{if(g&&typeof g=="object"||typeof g=="function")for(let B of u6(g))!i6.call(l,B)&&B!==R&&yV(l,B,{get:()=>g[B],enumerable:!(M=m6(g,B))||M.enumerable});return l},d6=(l,g,R)=>(gV(l,g,"default"),R&&gV(R,g,"default")),N0=(l,g,R)=>(R=l!=null?h6(p6(l)):{},gV(g||!l||!l.__esModule?yV(R,"default",{value:l,enumerable:!0}):R,l)),I0=l6((l,g)=>{function R(q){if(typeof q!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(q))}function M(q,Y){for(var E="",O=0,N=-1,W=0,I,z=0;z<=q.length;++z){if(z<q.length)I=q.charCodeAt(z);else{if(I===47)break;I=47}if(I===47){if(!(N===z-1||W===1))if(N!==z-1&&W===2){if(E.length<2||O!==2||E.charCodeAt(E.length-1)!==46||E.charCodeAt(E.length-2)!==46){if(E.length>2){var j=E.lastIndexOf("/");if(j!==E.length-1){j===-1?(E="",O=0):(E=E.slice(0,j),O=E.length-1-E.lastIndexOf("/")),N=z,W=0;continue}}else if(E.length===2||E.length===1){E="",O=0,N=z,W=0;continue}}Y&&(E.length>0?E+="/..":E="..",O=2)}else E.length>0?E+="/"+q.slice(N+1,z):E=q.slice(N+1,z),O=z-N-1;N=z,W=0}else I===46&&W!==-1?++W:W=-1}return E}function B(q,Y){var E=Y.dir||Y.root,O=Y.base||(Y.name||"")+(Y.ext||"");return E?E===Y.root?E+O:E+q+O:O}var A={resolve:function(){for(var q="",Y=!1,E,O=arguments.length-1;O>=-1&&!Y;O--){var N;O>=0?N=arguments[O]:(E===void 0&&(E=process.cwd()),N=E),R(N),N.length!==0&&(q=N+"/"+q,Y=N.charCodeAt(0)===47)}return q=M(q,!Y),Y?q.length>0?"/"+q:"/":q.length>0?q:"."},normalize:function(q){if(R(q),q.length===0)return".";var Y=q.charCodeAt(0)===47,E=q.charCodeAt(q.length-1)===47;return q=M(q,!Y),q.length===0&&!Y&&(q="."),q.length>0&&E&&(q+="/"),Y?"/"+q:q},isAbsolute:function(q){return R(q),q.length>0&&q.charCodeAt(0)===47},join:function(){if(arguments.length===0)return".";for(var q,Y=0;Y<arguments.length;++Y){var E=arguments[Y];R(E),E.length>0&&(q===void 0?q=E:q+="/"+E)}return q===void 0?".":A.normalize(q)},relative:function(q,Y){if(R(q),R(Y),q===Y||(q=A.resolve(q),Y=A.resolve(Y),q===Y))return"";for(var E=1;E<q.length&&q.charCodeAt(E)===47;++E);for(var O=q.length,N=O-E,W=1;W<Y.length&&Y.charCodeAt(W)===47;++W);for(var I=Y.length,z=I-W,j=N<z?N:z,P=-1,F=0;F<=j;++F){if(F===j){if(z>j){if(Y.charCodeAt(W+F)===47)return Y.slice(W+F+1);if(F===0)return Y.slice(W+F)}else N>j&&(q.charCodeAt(E+F)===47?P=F:F===0&&(P=0));break}var v=q.charCodeAt(E+F),S=Y.charCodeAt(W+F);if(v!==S)break;v===47&&(P=F)}var w="";for(F=E+P+1;F<=O;++F)(F===O||q.charCodeAt(F)===47)&&(w.length===0?w+="..":w+="/..");return w.length>0?w+Y.slice(W+P):(W+=P,Y.charCodeAt(W)===47&&++W,Y.slice(W))},_makeLong:function(q){return q},dirname:function(q){if(R(q),q.length===0)return".";for(var Y=q.charCodeAt(0),E=Y===47,O=-1,N=!0,W=q.length-1;W>=1;--W)if(Y=q.charCodeAt(W),Y===47){if(!N){O=W;break}}else N=!1;return O===-1?E?"/":".":E&&O===1?"//":q.slice(0,O)},basename:function(q,Y){if(Y!==void 0&&typeof Y!="string")throw new TypeError('"ext" argument must be a string');R(q);var E=0,O=-1,N=!0,W;if(Y!==void 0&&Y.length>0&&Y.length<=q.length){if(Y.length===q.length&&Y===q)return"";var I=Y.length-1,z=-1;for(W=q.length-1;W>=0;--W){var j=q.charCodeAt(W);if(j===47){if(!N){E=W+1;break}}else z===-1&&(N=!1,z=W+1),I>=0&&(j===Y.charCodeAt(I)?--I===-1&&(O=W):(I=-1,O=z))}return E===O?O=z:O===-1&&(O=q.length),q.slice(E,O)}else{for(W=q.length-1;W>=0;--W)if(q.charCodeAt(W)===47){if(!N){E=W+1;break}}else O===-1&&(N=!1,O=W+1);return O===-1?"":q.slice(E,O)}},extname:function(q){R(q);for(var Y=-1,E=0,O=-1,N=!0,W=0,I=q.length-1;I>=0;--I){var z=q.charCodeAt(I);if(z===47){if(!N){E=I+1;break}continue}O===-1&&(N=!1,O=I+1),z===46?Y===-1?Y=I:W!==1&&(W=1):Y!==-1&&(W=-1)}return Y===-1||O===-1||W===0||W===1&&Y===O-1&&Y===E+1?"":q.slice(Y,O)},format:function(q){if(q===null||typeof q!="object")throw new TypeError('The "pathObject" argument must be of type Object. Received type '+typeof q);return B("/",q)},parse:function(q){R(q);var Y={root:"",dir:"",base:"",ext:"",name:""};if(q.length===0)return Y;var E=q.charCodeAt(0),O=E===47,N;O?(Y.root="/",N=1):N=0;for(var W=-1,I=0,z=-1,j=!0,P=q.length-1,F=0;P>=N;--P){if(E=q.charCodeAt(P),E===47){if(!j){I=P+1;break}continue}z===-1&&(j=!1,z=P+1),E===46?W===-1?W=P:F!==1&&(F=1):W!==-1&&(F=-1)}return W===-1||z===-1||F===0||F===1&&W===z-1&&W===I+1?z!==-1&&(I===0&&O?Y.base=Y.name=q.slice(1,z):Y.base=Y.name=q.slice(I,z)):(I===0&&O?(Y.name=q.slice(1,W),Y.base=q.slice(1,z)):(Y.name=q.slice(I,W),Y.base=q.slice(I,z)),Y.ext=q.slice(W,z)),I>0?Y.dir=q.slice(0,I-1):O&&(Y.dir="/"),Y},sep:"/",delimiter:":",win32:null,posix:null};A.posix=A,g.exports=A}),E0={},s6(E0,{default:()=>k6}),d6(E0,N0(I0())),k6=N0(I0())}),y$={};M$(y$,{webcrypto:()=>{return j0},timingSafeEqual:()=>{return jV},scryptSync:()=>{return xV},scrypt:()=>{return wV},randomUUID:()=>{return O0},getRandomValues:()=>{return B0},getCurves:()=>{return Y0},default:()=>{return A6},DEFAULT_ENCODING:()=>{return UV}});var Y0,n6,EV,o6,r6,a6,t6,cV,OJ,RV,zV,fV,oQ,fQ,e6,J8,yQ,XQ,VV,JQ,rQ,R0,PV,Q8,z0,$V,P0,L0,F0,ZV,hV,HV,D0,LV,mV,V8,$8,C0,k0,Z8,X8,q8,A0,uV,pV,XV,G8,K8,S0,U8,x0,H8,iV,bQ,iQ,lV,gQ,FV,w0,lQ,W8,aQ,tQ,eQ,Y8,qV,sV,dV,B8,nV,v0,DV,M0,O8,sQ,_0,b0,oV,j8,y0,T8,g0,rV,N8,I8,nQ,WV,E8,c0,f0,h0,R8,m0,u0,p0,i0,z8,l0,s0,hQ,aV,d0,P8,L8,F8,D8,C8,YV,k8,A8,S8,x8,w8,n0,o0,r0,tV,CV,v8,a0,t0,kV,M8,_8,eV,b8,y8,JV,e0,g8,c8,J0,J6,Q6,f8,h8,m8,V6,u8,$6,GV,Z6,X6,KV,Q0,p8,i8,q6,G6,l8,s8,d8,V0,$0,n8,dQ,K6,mQ,AV,o8,r8,a8,U6,pQ,BV,H6,t8,W6,e8,Y6,J$,Q$,V$,$$,Z0,Z$,X0,X$,q$,G$,K$,U$,H$,W$,q0,B6,G0,K0,OV,U0,H0,O6,Y$,j6,T6,B$,N6,O$,j$,T$,I6,N$,I$,E$,R$,SV,E6,z$,P$,L$,F$,D$,R6,z6,W0,P6,C$,k$,A$,S$,L6,F6,x$,UV,B0,O0,w$,jV,xV,wV,j0,A6,U5=_$(()=>{Y0=function(){return w$},n6=Object.create,EV=Object.defineProperty,o6=Object.getOwnPropertyDescriptor,r6=Object.getOwnPropertyNames,a6=Object.getPrototypeOf,t6=Object.prototype.hasOwnProperty,cV=(l,g)=>()=>(l&&(g=l(l=0)),g),OJ=(l,g)=>()=>(g||l((g={exports:{}}).exports,g),g.exports),RV=(l,g)=>{for(var R in g)EV(l,R,{get:g[R],enumerable:!0})},zV=(l,g,R,M)=>{if(g&&typeof g=="object"||typeof g=="function")for(let B of r6(g))!t6.call(l,B)&&B!==R&&EV(l,B,{get:()=>g[B],enumerable:!(M=o6(g,B))||M.enumerable});return l},fV=(l,g,R)=>(zV(l,g,"default"),R&&zV(R,g,"default")),oQ=(l,g,R)=>(R=l!=null?n6(a6(l)):{},zV(g||!l||!l.__esModule?EV(R,"default",{value:l,enumerable:!0}):R,l)),fQ=(l)=>zV(EV({},"__esModule",{value:!0}),l),e6=OJ((l)=>{l.byteLength=E,l.toByteArray=N,l.fromByteArray=z;var g=[],R=[],M=typeof Uint8Array<"u"?Uint8Array:Array,B="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";for(A=0,q=B.length;A<q;++A)g[A]=B[A],R[B.charCodeAt(A)]=A;var A,q;R["-".charCodeAt(0)]=62,R["_".charCodeAt(0)]=63;function Y(j){var P=j.length;if(P%4>0)throw new Error("Invalid string. Length must be a multiple of 4");var F=j.indexOf("=");F===-1&&(F=P);var v=F===P?0:4-F%4;return[F,v]}function E(j){var P=Y(j),F=P[0],v=P[1];return(F+v)*3/4-v}function O(j,P,F){return(P+F)*3/4-F}function N(j){var P,F=Y(j),v=F[0],S=F[1],w=new M(O(j,v,S)),y=0,m=S>0?v-4:v,i;for(i=0;i<m;i+=4)P=R[j.charCodeAt(i)]<<18|R[j.charCodeAt(i+1)]<<12|R[j.charCodeAt(i+2)]<<6|R[j.charCodeAt(i+3)],w[y++]=P>>16&255,w[y++]=P>>8&255,w[y++]=P&255;return S===2&&(P=R[j.charCodeAt(i)]<<2|R[j.charCodeAt(i+1)]>>4,w[y++]=P&255),S===1&&(P=R[j.charCodeAt(i)]<<10|R[j.charCodeAt(i+1)]<<4|R[j.charCodeAt(i+2)]>>2,w[y++]=P>>8&255,w[y++]=P&255),w}function W(j){return g[j>>18&63]+g[j>>12&63]+g[j>>6&63]+g[j&63]}function I(j,P,F){for(var v,S=[],w=P;w<F;w+=3)v=(j[w]<<16&16711680)+(j[w+1]<<8&65280)+(j[w+2]&255),S.push(W(v));return S.join("")}function z(j){for(var P,F=j.length,v=F%3,S=[],w=16383,y=0,m=F-v;y<m;y+=w)S.push(I(j,y,y+w>m?m:y+w));return v===1?(P=j[F-1],S.push(g[P>>2]+g[P<<4&63]+"==")):v===2&&(P=(j[F-2]<<8)+j[F-1],S.push(g[P>>10]+g[P>>4&63]+g[P<<2&63]+"=")),S.join("")}}),J8=OJ((l)=>{l.read=function(g,R,M,B,A){var q,Y,E=A*8-B-1,O=(1<<E)-1,N=O>>1,W=-7,I=M?A-1:0,z=M?-1:1,j=g[R+I];for(I+=z,q=j&(1<<-W)-1,j>>=-W,W+=E;W>0;q=q*256+g[R+I],I+=z,W-=8);for(Y=q&(1<<-W)-1,q>>=-W,W+=B;W>0;Y=Y*256+g[R+I],I+=z,W-=8);if(q===0)q=1-N;else{if(q===O)return Y?NaN:(j?-1:1)*(1/0);Y=Y+Math.pow(2,B),q=q-N}return(j?-1:1)*Y*Math.pow(2,q-B)},l.write=function(g,R,M,B,A,q){var Y,E,O,N=q*8-A-1,W=(1<<N)-1,I=W>>1,z=A===23?Math.pow(2,-24)-Math.pow(2,-77):0,j=B?0:q-1,P=B?1:-1,F=R<0||R===0&&1/R<0?1:0;for(R=Math.abs(R),isNaN(R)||R===1/0?(E=isNaN(R)?1:0,Y=W):(Y=Math.floor(Math.log(R)/Math.LN2),R*(O=Math.pow(2,-Y))<1&&(Y--,O*=2),Y+I>=1?R+=z/O:R+=z*Math.pow(2,1-I),R*O>=2&&(Y++,O/=2),Y+I>=W?(E=0,Y=W):Y+I>=1?(E=(R*O-1)*Math.pow(2,A),Y=Y+I):(E=R*Math.pow(2,I-1)*Math.pow(2,A),Y=0));A>=8;g[M+j]=E&255,j+=P,E/=256,A-=8);for(Y=Y<<A|E,N+=A;N>0;g[M+j]=Y&255,j+=P,Y/=256,N-=8);g[M+j-P]|=F*128}}),yQ=OJ((l)=>{var g=e6(),R=J8(),M=typeof Symbol=="function"&&typeof Symbol.for=="function"?Symbol.for("nodejs.util.inspect.custom"):null;l.Buffer=Y,l.SlowBuffer=S,l.INSPECT_MAX_BYTES=50;var B=2147483647;l.kMaxLength=B,Y.TYPED_ARRAY_SUPPORT=A(),!Y.TYPED_ARRAY_SUPPORT&&typeof console<"u"&&typeof console.error=="function"&&console.error("This browser lacks typed array (Uint8Array) support which is required by `buffer` v5.x. Use `buffer` v4.x if you require old browser support.");function A(){try{let T=new Uint8Array(1),D={foo:function(){return 42}};return Object.setPrototypeOf(D,Uint8Array.prototype),Object.setPrototypeOf(T,D),T.foo()===42}catch{return!1}}Object.defineProperty(Y.prototype,"parent",{enumerable:!0,get:function(){if(Y.isBuffer(this))return this.buffer}}),Object.defineProperty(Y.prototype,"offset",{enumerable:!0,get:function(){if(Y.isBuffer(this))return this.byteOffset}});function q(T){if(T>B)throw new RangeError('The value "'+T+'" is invalid for option "size"');let D=new Uint8Array(T);return Object.setPrototypeOf(D,Y.prototype),D}function Y(T,D,u){if(typeof T=="number"){if(typeof D=="string")throw new TypeError('The "string" argument must be of type string. Received type number');return W(T)}return E(T,D,u)}Y.poolSize=8192;function E(T,D,u){if(typeof T=="string")return I(T,D);if(ArrayBuffer.isView(T))return j(T);if(T==null)throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof T);if(TJ(T,ArrayBuffer)||T&&TJ(T.buffer,ArrayBuffer)||typeof SharedArrayBuffer<"u"&&(TJ(T,SharedArrayBuffer)||T&&TJ(T.buffer,SharedArrayBuffer)))return P(T,D,u);if(typeof T=="number")throw new TypeError('The "value" argument must not be of type number. Received type number');let d=T.valueOf&&T.valueOf();if(d!=null&&d!==T)return Y.from(d,D,u);let a=F(T);if(a)return a;if(typeof Symbol<"u"&&Symbol.toPrimitive!=null&&typeof T[Symbol.toPrimitive]=="function")return Y.from(T[Symbol.toPrimitive]("string"),D,u);throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof T)}Y.from=function(T,D,u){return E(T,D,u)},Object.setPrototypeOf(Y.prototype,Uint8Array.prototype),Object.setPrototypeOf(Y,Uint8Array);function O(T){if(typeof T!="number")throw new TypeError('"size" argument must be of type number');if(T<0)throw new RangeError('The value "'+T+'" is invalid for option "size"')}function N(T,D,u){return O(T),T<=0?q(T):D!==void 0?typeof u=="string"?q(T).fill(D,u):q(T).fill(D):q(T)}Y.alloc=function(T,D,u){return N(T,D,u)};function W(T){return O(T),q(T<0?0:v(T)|0)}Y.allocUnsafe=function(T){return W(T)},Y.allocUnsafeSlow=function(T){return W(T)};function I(T,D){if((typeof D!="string"||D==="")&&(D="utf8"),!Y.isEncoding(D))throw new TypeError("Unknown encoding: "+D);let u=w(T,D)|0,d=q(u),a=d.write(T,D);return a!==u&&(d=d.slice(0,a)),d}function z(T){let D=T.length<0?0:v(T.length)|0,u=q(D);for(let d=0;d<D;d+=1)u[d]=T[d]&255;return u}function j(T){if(TJ(T,Uint8Array)){let D=new Uint8Array(T);return P(D.buffer,D.byteOffset,D.byteLength)}return z(T)}function P(T,D,u){if(D<0||T.byteLength<D)throw new RangeError('"offset" is outside of buffer bounds');if(T.byteLength<D+(u||0))throw new RangeError('"length" is outside of buffer bounds');let d;return D===void 0&&u===void 0?d=new Uint8Array(T):u===void 0?d=new Uint8Array(T,D):d=new Uint8Array(T,D,u),Object.setPrototypeOf(d,Y.prototype),d}function F(T){if(Y.isBuffer(T)){let D=v(T.length)|0,u=q(D);return u.length===0||T.copy(u,0,0,D),u}if(T.length!==void 0)return typeof T.length!="number"||dJ(T.length)?q(0):z(T);if(T.type==="Buffer"&&Array.isArray(T.data))return z(T.data)}function v(T){if(T>=B)throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+B.toString(16)+" bytes");return T|0}function S(T){return+T!=T&&(T=0),Y.alloc(+T)}Y.isBuffer=function(T){return T!=null&&T._isBuffer===!0&&T!==Y.prototype},Y.compare=function(T,D){if(TJ(T,Uint8Array)&&(T=Y.from(T,T.offset,T.byteLength)),TJ(D,Uint8Array)&&(D=Y.from(D,D.offset,D.byteLength)),!Y.isBuffer(T)||!Y.isBuffer(D))throw new TypeError('The "buf1", "buf2" arguments must be one of type Buffer or Uint8Array');if(T===D)return 0;let u=T.length,d=D.length;for(let a=0,CJ=Math.min(u,d);a<CJ;++a)if(T[a]!==D[a]){u=T[a],d=D[a];break}return u<d?-1:d<u?1:0},Y.isEncoding=function(T){switch(String(T).toLowerCase()){case"hex":case"utf8":case"utf-8":case"ascii":case"latin1":case"binary":case"base64":case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return!0;default:return!1}},Y.concat=function(T,D){if(!Array.isArray(T))throw new TypeError('"list" argument must be an Array of Buffers');if(T.length===0)return Y.alloc(0);let u;if(D===void 0)for(D=0,u=0;u<T.length;++u)D+=T[u].length;let d=Y.allocUnsafe(D),a=0;for(u=0;u<T.length;++u){let CJ=T[u];if(TJ(CJ,Uint8Array))a+CJ.length>d.length?(Y.isBuffer(CJ)||(CJ=Y.from(CJ)),CJ.copy(d,a)):Uint8Array.prototype.set.call(d,CJ,a);else if(Y.isBuffer(CJ))CJ.copy(d,a);else throw new TypeError('"list" argument must be an Array of Buffers');a+=CJ.length}return d};function w(T,D){if(Y.isBuffer(T))return T.length;if(ArrayBuffer.isView(T)||TJ(T,ArrayBuffer))return T.byteLength;if(typeof T!="string")throw new TypeError('The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type '+typeof T);let u=T.length,d=arguments.length>2&&arguments[2]===!0;if(!d&&u===0)return 0;let a=!1;for(;;)switch(D){case"ascii":case"latin1":case"binary":return u;case"utf8":case"utf-8":return $J(T).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return u*2;case"hex":return u>>>1;case"base64":return mJ(T).length;default:if(a)return d?-1:$J(T).length;D=(""+D).toLowerCase(),a=!0}}Y.byteLength=w;function y(T,D,u){let d=!1;if((D===void 0||D<0)&&(D=0),D>this.length||((u===void 0||u>this.length)&&(u=this.length),u<=0)||(u>>>=0,D>>>=0,u<=D))return"";for(T||(T="utf8");;)switch(T){case"hex":return G(this,D,u);case"utf8":case"utf-8":return Z(this,D,u);case"ascii":return U(this,D,u);case"latin1":case"binary":return H(this,D,u);case"base64":return V(this,D,u);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return Q(this,D,u);default:if(d)throw new TypeError("Unknown encoding: "+T);T=(T+"").toLowerCase(),d=!0}}Y.prototype._isBuffer=!0;function m(T,D,u){let d=T[D];T[D]=T[u],T[u]=d}Y.prototype.swap16=function(){let T=this.length;if(T%2!==0)throw new RangeError("Buffer size must be a multiple of 16-bits");for(let D=0;D<T;D+=2)m(this,D,D+1);return this},Y.prototype.swap32=function(){let T=this.length;if(T%4!==0)throw new RangeError("Buffer size must be a multiple of 32-bits");for(let D=0;D<T;D+=4)m(this,D,D+3),m(this,D+1,D+2);return this},Y.prototype.swap64=function(){let T=this.length;if(T%8!==0)throw new RangeError("Buffer size must be a multiple of 64-bits");for(let D=0;D<T;D+=8)m(this,D,D+7),m(this,D+1,D+6),m(this,D+2,D+5),m(this,D+3,D+4);return this},Y.prototype.toString=function(){let T=this.length;return T===0?"":arguments.length===0?Z(this,0,T):y.apply(this,arguments)},Y.prototype.toLocaleString=Y.prototype.toString,Y.prototype.equals=function(T){if(!Y.isBuffer(T))throw new TypeError("Argument must be a Buffer");return this===T?!0:Y.compare(this,T)===0},Y.prototype.inspect=function(){let T="",D=l.INSPECT_MAX_BYTES;return T=this.toString("hex",0,D).replace(/(.{2})/g,"$1 ").trim(),this.length>D&&(T+=" ... "),"<Buffer "+T+">"},M&&(Y.prototype[M]=Y.prototype.inspect),Y.prototype.compare=function(T,D,u,d,a){if(TJ(T,Uint8Array)&&(T=Y.from(T,T.offset,T.byteLength)),!Y.isBuffer(T))throw new TypeError('The "target" argument must be one of type Buffer or Uint8Array. Received type '+typeof T);if(D===void 0&&(D=0),u===void 0&&(u=T?T.length:0),d===void 0&&(d=0),a===void 0&&(a=this.length),D<0||u>T.length||d<0||a>this.length)throw new RangeError("out of range index");if(d>=a&&D>=u)return 0;if(d>=a)return-1;if(D>=u)return 1;if(D>>>=0,u>>>=0,d>>>=0,a>>>=0,this===T)return 0;let CJ=a-d,UJ=u-D,EJ=Math.min(CJ,UJ),QQ=this.slice(d,a),FJ=T.slice(D,u);for(let RJ=0;RJ<EJ;++RJ)if(QQ[RJ]!==FJ[RJ]){CJ=QQ[RJ],UJ=FJ[RJ];break}return CJ<UJ?-1:UJ<CJ?1:0};function i(T,D,u,d,a){if(T.length===0)return-1;if(typeof u=="string"?(d=u,u=0):u>2147483647?u=2147483647:u<-2147483648&&(u=-2147483648),u=+u,dJ(u)&&(u=a?0:T.length-1),u<0&&(u=T.length+u),u>=T.length){if(a)return-1;u=T.length-1}else if(u<0)if(a)u=0;else return-1;if(typeof D=="string"&&(D=Y.from(D,d)),Y.isBuffer(D))return D.length===0?-1:JJ(T,D,u,d,a);if(typeof D=="number")return D=D&255,typeof Uint8Array.prototype.indexOf=="function"?a?Uint8Array.prototype.indexOf.call(T,D,u):Uint8Array.prototype.lastIndexOf.call(T,D,u):JJ(T,[D],u,d,a);throw new TypeError("val must be string, number or Buffer")}function JJ(T,D,u,d,a){let CJ=1,UJ=T.length,EJ=D.length;if(d!==void 0&&(d=String(d).toLowerCase(),d==="ucs2"||d==="ucs-2"||d==="utf16le"||d==="utf-16le")){if(T.length<2||D.length<2)return-1;CJ=2,UJ/=2,EJ/=2,u/=2}function QQ(RJ,aJ){return CJ===1?RJ[aJ]:RJ.readUInt16BE(aJ*CJ)}let FJ;if(a){let RJ=-1;for(FJ=u;FJ<UJ;FJ++)if(QQ(T,FJ)===QQ(D,RJ===-1?0:FJ-RJ)){if(RJ===-1&&(RJ=FJ),FJ-RJ+1===EJ)return RJ*CJ}else RJ!==-1&&(FJ-=FJ-RJ),RJ=-1}else for(u+EJ>UJ&&(u=UJ-EJ),FJ=u;FJ>=0;FJ--){let RJ=!0;for(let aJ=0;aJ<EJ;aJ++)if(QQ(T,FJ+aJ)!==QQ(D,aJ)){RJ=!1;break}if(RJ)return FJ}return-1}Y.prototype.includes=function(T,D,u){return this.indexOf(T,D,u)!==-1},Y.prototype.indexOf=function(T,D,u){return i(this,T,D,u,!0)},Y.prototype.lastIndexOf=function(T,D,u){return i(this,T,D,u,!1)};function VJ(T,D,u,d){u=Number(u)||0;let a=T.length-u;d?(d=Number(d),d>a&&(d=a)):d=a;let CJ=D.length;d>CJ/2&&(d=CJ/2);let UJ;for(UJ=0;UJ<d;++UJ){let EJ=parseInt(D.substr(UJ*2,2),16);if(dJ(EJ))return UJ;T[u+UJ]=EJ}return UJ}function HJ(T,D,u,d){return BJ($J(D,T.length-u),T,u,d)}function o(T,D,u,d){return BJ(qJ(D),T,u,d)}function jJ(T,D,u,d){return BJ(mJ(D),T,u,d)}function J(T,D,u,d){return BJ(ZJ(D,T.length-u),T,u,d)}Y.prototype.write=function(T,D,u,d){if(D===void 0)d="utf8",u=this.length,D=0;else if(u===void 0&&typeof D=="string")d=D,u=this.length,D=0;else if(isFinite(D))D=D>>>0,isFinite(u)?(u=u>>>0,d===void 0&&(d="utf8")):(d=u,u=void 0);else throw new Error("Buffer.write(string, encoding, offset[, length]) is no longer supported");let a=this.length-D;if((u===void 0||u>a)&&(u=a),T.length>0&&(u<0||D<0)||D>this.length)throw new RangeError("Attempt to write outside buffer bounds");d||(d="utf8");let CJ=!1;for(;;)switch(d){case"hex":return VJ(this,T,D,u);case"utf8":case"utf-8":return HJ(this,T,D,u);case"ascii":case"latin1":case"binary":return o(this,T,D,u);case"base64":return jJ(this,T,D,u);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return J(this,T,D,u);default:if(CJ)throw new TypeError("Unknown encoding: "+d);d=(""+d).toLowerCase(),CJ=!0}},Y.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};function V(T,D,u){return D===0&&u===T.length?g.fromByteArray(T):g.fromByteArray(T.slice(D,u))}function Z(T,D,u){u=Math.min(T.length,u);let d=[],a=D;for(;a<u;){let CJ=T[a],UJ=null,EJ=CJ>239?4:CJ>223?3:CJ>191?2:1;if(a+EJ<=u){let QQ,FJ,RJ,aJ;switch(EJ){case 1:CJ<128&&(UJ=CJ);break;case 2:QQ=T[a+1],(QQ&192)===128&&(aJ=(CJ&31)<<6|QQ&63,aJ>127&&(UJ=aJ));break;case 3:QQ=T[a+1],FJ=T[a+2],(QQ&192)===128&&(FJ&192)===128&&(aJ=(CJ&15)<<12|(QQ&63)<<6|FJ&63,aJ>2047&&(aJ<55296||aJ>57343)&&(UJ=aJ));break;case 4:QQ=T[a+1],FJ=T[a+2],RJ=T[a+3],(QQ&192)===128&&(FJ&192)===128&&(RJ&192)===128&&(aJ=(CJ&15)<<18|(QQ&63)<<12|(FJ&63)<<6|RJ&63,aJ>65535&&aJ<1114112&&(UJ=aJ))}}UJ===null?(UJ=65533,EJ=1):UJ>65535&&(UJ-=65536,d.push(UJ>>>10&1023|55296),UJ=56320|UJ&1023),d.push(UJ),a+=EJ}return X(d)}var $=4096;function X(T){let D=T.length;if(D<=$)return String.fromCharCode.apply(String,T);let u="",d=0;for(;d<D;)u+=String.fromCharCode.apply(String,T.slice(d,d+=$));return u}function U(T,D,u){let d="";u=Math.min(T.length,u);for(let a=D;a<u;++a)d+=String.fromCharCode(T[a]&127);return d}function H(T,D,u){let d="";u=Math.min(T.length,u);for(let a=D;a<u;++a)d+=String.fromCharCode(T[a]);return d}function G(T,D,u){let d=T.length;(!D||D<0)&&(D=0),(!u||u<0||u>d)&&(u=d);let a="";for(let CJ=D;CJ<u;++CJ)a+=LJ[T[CJ]];return a}function Q(T,D,u){let d=T.slice(D,u),a="";for(let CJ=0;CJ<d.length-1;CJ+=2)a+=String.fromCharCode(d[CJ]+d[CJ+1]*256);return a}Y.prototype.slice=function(T,D){let u=this.length;T=~~T,D=D===void 0?u:~~D,T<0?(T+=u,T<0&&(T=0)):T>u&&(T=u),D<0?(D+=u,D<0&&(D=0)):D>u&&(D=u),D<T&&(D=T);let d=this.subarray(T,D);return Object.setPrototypeOf(d,Y.prototype),d};function K(T,D,u){if(T%1!==0||T<0)throw new RangeError("offset is not uint");if(T+D>u)throw new RangeError("Trying to access beyond buffer length")}Y.prototype.readUintLE=Y.prototype.readUIntLE=function(T,D,u){T=T>>>0,D=D>>>0,u||K(T,D,this.length);let d=this[T],a=1,CJ=0;for(;++CJ<D&&(a*=256);)d+=this[T+CJ]*a;return d},Y.prototype.readUintBE=Y.prototype.readUIntBE=function(T,D,u){T=T>>>0,D=D>>>0,u||K(T,D,this.length);let d=this[T+--D],a=1;for(;D>0&&(a*=256);)d+=this[T+--D]*a;return d},Y.prototype.readUint8=Y.prototype.readUInt8=function(T,D){return T=T>>>0,D||K(T,1,this.length),this[T]},Y.prototype.readUint16LE=Y.prototype.readUInt16LE=function(T,D){return T=T>>>0,D||K(T,2,this.length),this[T]|this[T+1]<<8},Y.prototype.readUint16BE=Y.prototype.readUInt16BE=function(T,D){return T=T>>>0,D||K(T,2,this.length),this[T]<<8|this[T+1]},Y.prototype.readUint32LE=Y.prototype.readUInt32LE=function(T,D){return T=T>>>0,D||K(T,4,this.length),(this[T]|this[T+1]<<8|this[T+2]<<16)+this[T+3]*16777216},Y.prototype.readUint32BE=Y.prototype.readUInt32BE=function(T,D){return T=T>>>0,D||K(T,4,this.length),this[T]*16777216+(this[T+1]<<16|this[T+2]<<8|this[T+3])},Y.prototype.readBigUInt64LE=IJ(function(T){T=T>>>0,WJ(T,"offset");let D=this[T],u=this[T+7];(D===void 0||u===void 0)&&b(T,this.length-8);let d=D+this[++T]*256+this[++T]*65536+this[++T]*16777216,a=this[++T]+this[++T]*256+this[++T]*65536+u*16777216;return BigInt(d)+(BigInt(a)<<BigInt(32))}),Y.prototype.readBigUInt64BE=IJ(function(T){T=T>>>0,WJ(T,"offset");let D=this[T],u=this[T+7];(D===void 0||u===void 0)&&b(T,this.length-8);let d=D*16777216+this[++T]*65536+this[++T]*256+this[++T],a=this[++T]*16777216+this[++T]*65536+this[++T]*256+u;return(BigInt(d)<<BigInt(32))+BigInt(a)}),Y.prototype.readIntLE=function(T,D,u){T=T>>>0,D=D>>>0,u||K(T,D,this.length);let d=this[T],a=1,CJ=0;for(;++CJ<D&&(a*=256);)d+=this[T+CJ]*a;return a*=128,d>=a&&(d-=Math.pow(2,8*D)),d},Y.prototype.readIntBE=function(T,D,u){T=T>>>0,D=D>>>0,u||K(T,D,this.length);let d=D,a=1,CJ=this[T+--d];for(;d>0&&(a*=256);)CJ+=this[T+--d]*a;return a*=128,CJ>=a&&(CJ-=Math.pow(2,8*D)),CJ},Y.prototype.readInt8=function(T,D){return T=T>>>0,D||K(T,1,this.length),this[T]&128?(255-this[T]+1)*-1:this[T]},Y.prototype.readInt16LE=function(T,D){T=T>>>0,D||K(T,2,this.length);let u=this[T]|this[T+1]<<8;return u&32768?u|4294901760:u},Y.prototype.readInt16BE=function(T,D){T=T>>>0,D||K(T,2,this.length);let u=this[T+1]|this[T]<<8;return u&32768?u|4294901760:u},Y.prototype.readInt32LE=function(T,D){return T=T>>>0,D||K(T,4,this.length),this[T]|this[T+1]<<8|this[T+2]<<16|this[T+3]<<24},Y.prototype.readInt32BE=function(T,D){return T=T>>>0,D||K(T,4,this.length),this[T]<<24|this[T+1]<<16|this[T+2]<<8|this[T+3]},Y.prototype.readBigInt64LE=IJ(function(T){T=T>>>0,WJ(T,"offset");let D=this[T],u=this[T+7];(D===void 0||u===void 0)&&b(T,this.length-8);let d=this[T+4]+this[T+5]*256+this[T+6]*65536+(u<<24);return(BigInt(d)<<BigInt(32))+BigInt(D+this[++T]*256+this[++T]*65536+this[++T]*16777216)}),Y.prototype.readBigInt64BE=IJ(function(T){T=T>>>0,WJ(T,"offset");let D=this[T],u=this[T+7];(D===void 0||u===void 0)&&b(T,this.length-8);let d=(D<<24)+this[++T]*65536+this[++T]*256+this[++T];return(BigInt(d)<<BigInt(32))+BigInt(this[++T]*16777216+this[++T]*65536+this[++T]*256+u)}),Y.prototype.readFloatLE=function(T,D){return T=T>>>0,D||K(T,4,this.length),R.read(this,T,!0,23,4)},Y.prototype.readFloatBE=function(T,D){return T=T>>>0,D||K(T,4,this.length),R.read(this,T,!1,23,4)},Y.prototype.readDoubleLE=function(T,D){return T=T>>>0,D||K(T,8,this.length),R.read(this,T,!0,52,8)},Y.prototype.readDoubleBE=function(T,D){return T=T>>>0,D||K(T,8,this.length),R.read(this,T,!1,52,8)};function k(T,D,u,d,a,CJ){if(!Y.isBuffer(T))throw new TypeError('"buffer" argument must be a Buffer instance');if(D>a||D<CJ)throw new RangeError('"value" argument is out of bounds');if(u+d>T.length)throw new RangeError("Index out of range")}Y.prototype.writeUintLE=Y.prototype.writeUIntLE=function(T,D,u,d){if(T=+T,D=D>>>0,u=u>>>0,!d){let UJ=Math.pow(2,8*u)-1;k(this,T,D,u,UJ,0)}let a=1,CJ=0;for(this[D]=T&255;++CJ<u&&(a*=256);)this[D+CJ]=T/a&255;return D+u},Y.prototype.writeUintBE=Y.prototype.writeUIntBE=function(T,D,u,d){if(T=+T,D=D>>>0,u=u>>>0,!d){let UJ=Math.pow(2,8*u)-1;k(this,T,D,u,UJ,0)}let a=u-1,CJ=1;for(this[D+a]=T&255;--a>=0&&(CJ*=256);)this[D+a]=T/CJ&255;return D+u},Y.prototype.writeUint8=Y.prototype.writeUInt8=function(T,D,u){return T=+T,D=D>>>0,u||k(this,T,D,1,255,0),this[D]=T&255,D+1},Y.prototype.writeUint16LE=Y.prototype.writeUInt16LE=function(T,D,u){return T=+T,D=D>>>0,u||k(this,T,D,2,65535,0),this[D]=T&255,this[D+1]=T>>>8,D+2},Y.prototype.writeUint16BE=Y.prototype.writeUInt16BE=function(T,D,u){return T=+T,D=D>>>0,u||k(this,T,D,2,65535,0),this[D]=T>>>8,this[D+1]=T&255,D+2},Y.prototype.writeUint32LE=Y.prototype.writeUInt32LE=function(T,D,u){return T=+T,D=D>>>0,u||k(this,T,D,4,4294967295,0),this[D+3]=T>>>24,this[D+2]=T>>>16,this[D+1]=T>>>8,this[D]=T&255,D+4},Y.prototype.writeUint32BE=Y.prototype.writeUInt32BE=function(T,D,u){return T=+T,D=D>>>0,u||k(this,T,D,4,4294967295,0),this[D]=T>>>24,this[D+1]=T>>>16,this[D+2]=T>>>8,this[D+3]=T&255,D+4};function L(T,D,u,d,a){XJ(D,d,a,T,u,7);let CJ=Number(D&BigInt(4294967295));T[u++]=CJ,CJ=CJ>>8,T[u++]=CJ,CJ=CJ>>8,T[u++]=CJ,CJ=CJ>>8,T[u++]=CJ;let UJ=Number(D>>BigInt(32)&BigInt(4294967295));return T[u++]=UJ,UJ=UJ>>8,T[u++]=UJ,UJ=UJ>>8,T[u++]=UJ,UJ=UJ>>8,T[u++]=UJ,u}function _(T,D,u,d,a){XJ(D,d,a,T,u,7);let CJ=Number(D&BigInt(4294967295));T[u+7]=CJ,CJ=CJ>>8,T[u+6]=CJ,CJ=CJ>>8,T[u+5]=CJ,CJ=CJ>>8,T[u+4]=CJ;let UJ=Number(D>>BigInt(32)&BigInt(4294967295));return T[u+3]=UJ,UJ=UJ>>8,T[u+2]=UJ,UJ=UJ>>8,T[u+1]=UJ,UJ=UJ>>8,T[u]=UJ,u+8}Y.prototype.writeBigUInt64LE=IJ(function(T,D=0){return L(this,T,D,BigInt(0),BigInt("0xffffffffffffffff"))}),Y.prototype.writeBigUInt64BE=IJ(function(T,D=0){return _(this,T,D,BigInt(0),BigInt("0xffffffffffffffff"))}),Y.prototype.writeIntLE=function(T,D,u,d){if(T=+T,D=D>>>0,!d){let EJ=Math.pow(2,8*u-1);k(this,T,D,u,EJ-1,-EJ)}let a=0,CJ=1,UJ=0;for(this[D]=T&255;++a<u&&(CJ*=256);)T<0&&UJ===0&&this[D+a-1]!==0&&(UJ=1),this[D+a]=(T/CJ>>0)-UJ&255;return D+u},Y.prototype.writeIntBE=function(T,D,u,d){if(T=+T,D=D>>>0,!d){let EJ=Math.pow(2,8*u-1);k(this,T,D,u,EJ-1,-EJ)}let a=u-1,CJ=1,UJ=0;for(this[D+a]=T&255;--a>=0&&(CJ*=256);)T<0&&UJ===0&&this[D+a+1]!==0&&(UJ=1),this[D+a]=(T/CJ>>0)-UJ&255;return D+u},Y.prototype.writeInt8=function(T,D,u){return T=+T,D=D>>>0,u||k(this,T,D,1,127,-128),T<0&&(T=255+T+1),this[D]=T&255,D+1},Y.prototype.writeInt16LE=function(T,D,u){return T=+T,D=D>>>0,u||k(this,T,D,2,32767,-32768),this[D]=T&255,this[D+1]=T>>>8,D+2},Y.prototype.writeInt16BE=function(T,D,u){return T=+T,D=D>>>0,u||k(this,T,D,2,32767,-32768),this[D]=T>>>8,this[D+1]=T&255,D+2},Y.prototype.writeInt32LE=function(T,D,u){return T=+T,D=D>>>0,u||k(this,T,D,4,2147483647,-2147483648),this[D]=T&255,this[D+1]=T>>>8,this[D+2]=T>>>16,this[D+3]=T>>>24,D+4},Y.prototype.writeInt32BE=function(T,D,u){return T=+T,D=D>>>0,u||k(this,T,D,4,2147483647,-2147483648),T<0&&(T=4294967295+T+1),this[D]=T>>>24,this[D+1]=T>>>16,this[D+2]=T>>>8,this[D+3]=T&255,D+4},Y.prototype.writeBigInt64LE=IJ(function(T,D=0){return L(this,T,D,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))}),Y.prototype.writeBigInt64BE=IJ(function(T,D=0){return _(this,T,D,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))});function t(T,D,u,d,a,CJ){if(u+d>T.length)throw new RangeError("Index out of range");if(u<0)throw new RangeError("Index out of range")}function QJ(T,D,u,d,a){return D=+D,u=u>>>0,a||t(T,D,u,4,340282346638528860000000000000000000000,-340282346638528860000000000000000000000),R.write(T,D,u,d,23,4),u+4}Y.prototype.writeFloatLE=function(T,D,u){return QJ(this,T,D,!0,u)},Y.prototype.writeFloatBE=function(T,D,u){return QJ(this,T,D,!1,u)};function GJ(T,D,u,d,a){return D=+D,u=u>>>0,a||t(T,D,u,8,179769313486231570000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000,-179769313486231570000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000),R.write(T,D,u,d,52,8),u+8}Y.prototype.writeDoubleLE=function(T,D,u){return GJ(this,T,D,!0,u)},Y.prototype.writeDoubleBE=function(T,D,u){return GJ(this,T,D,!1,u)},Y.prototype.copy=function(T,D,u,d){if(!Y.isBuffer(T))throw new TypeError("argument should be a Buffer");if(u||(u=0),!d&&d!==0&&(d=this.length),D>=T.length&&(D=T.length),D||(D=0),d>0&&d<u&&(d=u),d===u||T.length===0||this.length===0)return 0;if(D<0)throw new RangeError("targetStart out of bounds");if(u<0||u>=this.length)throw new RangeError("Index out of range");if(d<0)throw new RangeError("sourceEnd out of bounds");d>this.length&&(d=this.length),T.length-D<d-u&&(d=T.length-D+u);let a=d-u;return this===T&&typeof Uint8Array.prototype.copyWithin=="function"?this.copyWithin(D,u,d):Uint8Array.prototype.set.call(T,this.subarray(u,d),D),a},Y.prototype.fill=function(T,D,u,d){if(typeof T=="string"){if(typeof D=="string"?(d=D,D=0,u=this.length):typeof u=="string"&&(d=u,u=this.length),d!==void 0&&typeof d!="string")throw new TypeError("encoding must be a string");if(typeof d=="string"&&!Y.isEncoding(d))throw new TypeError("Unknown encoding: "+d);if(T.length===1){let CJ=T.charCodeAt(0);(d==="utf8"&&CJ<128||d==="latin1")&&(T=CJ)}}else typeof T=="number"?T=T&255:typeof T=="boolean"&&(T=Number(T));if(D<0||this.length<D||this.length<u)throw new RangeError("Out of range index");if(u<=D)return this;D=D>>>0,u=u===void 0?this.length:u>>>0,T||(T=0);let a;if(typeof T=="number")for(a=D;a<u;++a)this[a]=T;else{let CJ=Y.isBuffer(T)?T:Y.from(T,d),UJ=CJ.length;if(UJ===0)throw new TypeError('The value "'+T+'" is invalid for argument "value"');for(a=0;a<u-D;++a)this[a+D]=CJ[a%UJ]}return this};var n={};function p(T,D,u){n[T]=class extends u{constructor(){super(),Object.defineProperty(this,"message",{value:D.apply(this,arguments),writable:!0,configurable:!0}),this.name=`${this.name} [${T}]`,this.stack,delete this.name}get code(){return T}set code(d){Object.defineProperty(this,"code",{configurable:!0,enumerable:!0,value:d,writable:!0})}toString(){return`${this.name} [${T}]: ${this.message}`}}}p("ERR_BUFFER_OUT_OF_BOUNDS",function(T){return T?`${T} is outside of buffer bounds`:"Attempt to access memory outside buffer bounds"},RangeError),p("ERR_INVALID_ARG_TYPE",function(T,D){return`The "${T}" argument must be of type number. Received type ${typeof D}`},TypeError),p("ERR_OUT_OF_RANGE",function(T,D,u){let d=`The value of "${T}" is out of range.`,a=u;return Number.isInteger(u)&&Math.abs(u)>4294967296?a=e(String(u)):typeof u=="bigint"&&(a=String(u),(u>BigInt(2)**BigInt(32)||u<-(BigInt(2)**BigInt(32)))&&(a=e(a)),a+="n"),d+=` It must be ${D}. Received ${a}`,d},RangeError);function e(T){let D="",u=T.length,d=T[0]==="-"?1:0;for(;u>=d+4;u-=3)D=`_${T.slice(u-3,u)}${D}`;return`${T.slice(0,u)}${D}`}function PJ(T,D,u){WJ(D,"offset"),(T[D]===void 0||T[D+u]===void 0)&&b(D,T.length-(u+1))}function XJ(T,D,u,d,a,CJ){if(T>u||T<D){let UJ=typeof D=="bigint"?"n":"",EJ;throw CJ>3?D===0||D===BigInt(0)?EJ=`>= 0${UJ} and < 2${UJ} ** ${(CJ+1)*8}${UJ}`:EJ=`>= -(2${UJ} ** ${(CJ+1)*8-1}${UJ}) and < 2 ** ${(CJ+1)*8-1}${UJ}`:EJ=`>= ${D}${UJ} and <= ${u}${UJ}`,new n.ERR_OUT_OF_RANGE("value",EJ,T)}PJ(d,a,CJ)}function WJ(T,D){if(typeof T!="number")throw new n.ERR_INVALID_ARG_TYPE(D,"number",T)}function b(T,D,u){throw Math.floor(T)!==T?(WJ(T,u),new n.ERR_OUT_OF_RANGE(u||"offset","an integer",T)):D<0?new n.ERR_BUFFER_OUT_OF_BOUNDS:new n.ERR_OUT_OF_RANGE(u||"offset",`>= ${u?1:0} and <= ${D}`,T)}var C=/[^+/0-9A-Za-z-_]/g;function h(T){if(T=T.split("=")[0],T=T.trim().replace(C,""),T.length<2)return"";for(;T.length%4!==0;)T=T+"=";return T}function $J(T,D){D=D||1/0;let u,d=T.length,a=null,CJ=[];for(let UJ=0;UJ<d;++UJ){if(u=T.charCodeAt(UJ),u>55295&&u<57344){if(!a){if(u>56319){(D-=3)>-1&&CJ.push(239,191,189);continue}else if(UJ+1===d){(D-=3)>-1&&CJ.push(239,191,189);continue}a=u;continue}if(u<56320){(D-=3)>-1&&CJ.push(239,191,189),a=u;continue}u=(a-55296<<10|u-56320)+65536}else a&&(D-=3)>-1&&CJ.push(239,191,189);if(a=null,u<128){if((D-=1)<0)break;CJ.push(u)}else if(u<2048){if((D-=2)<0)break;CJ.push(u>>6|192,u&63|128)}else if(u<65536){if((D-=3)<0)break;CJ.push(u>>12|224,u>>6&63|128,u&63|128)}else if(u<1114112){if((D-=4)<0)break;CJ.push(u>>18|240,u>>12&63|128,u>>6&63|128,u&63|128)}else throw new Error("Invalid code point")}return CJ}function qJ(T){let D=[];for(let u=0;u<T.length;++u)D.push(T.charCodeAt(u)&255);return D}function ZJ(T,D){let u,d,a,CJ=[];for(let UJ=0;UJ<T.length&&!((D-=2)<0);++UJ)u=T.charCodeAt(UJ),d=u>>8,a=u%256,CJ.push(a),CJ.push(d);return CJ}function mJ(T){return g.toByteArray(h(T))}function BJ(T,D,u,d){let a;for(a=0;a<d&&!(a+u>=D.length||a>=T.length);++a)D[a+u]=T[a];return a}function TJ(T,D){return T instanceof D||T!=null&&T.constructor!=null&&T.constructor.name!=null&&T.constructor.name===D.name}function dJ(T){return T!==T}var LJ=function(){let T="0123456789abcdef",D=new Array(256);for(let u=0;u<16;++u){let d=u*16;for(let a=0;a<16;++a)D[d+a]=T[u]+T[a]}return D}();function IJ(T){return typeof BigInt>"u"?$Q:T}function $Q(){throw new Error("BigInt not supported")}}),XQ=OJ((l,g)=>{var R=yQ(),M=R.Buffer;function B(q,Y){for(var E in q)Y[E]=q[E]}M.from&&M.alloc&&M.allocUnsafe&&M.allocUnsafeSlow?g.exports=R:(B(R,l),l.Buffer=A);function A(q,Y,E){return M(q,Y,E)}A.prototype=Object.create(M.prototype),B(M,A),A.from=function(q,Y,E){if(typeof q=="number")throw new TypeError("Argument must not be a number");return M(q,Y,E)},A.alloc=function(q,Y,E){if(typeof q!="number")throw new TypeError("Argument must be a number");var O=M(q);return Y!==void 0?typeof E=="string"?O.fill(Y,E):O.fill(Y):O.fill(0),O},A.allocUnsafe=function(q){if(typeof q!="number")throw new TypeError("Argument must be a number");return M(q)},A.allocUnsafeSlow=function(q){if(typeof q!="number")throw new TypeError("Argument must be a number");return R.SlowBuffer(q)}}),VV=OJ((l,g)=>{var R=65536,M=4294967295;function B(){throw new Error(`Secure random number generation is not supported by this browser.
+Use Chrome, Firefox or Internet Explorer 11`)}var A=XQ().Buffer,q=global.crypto||global.msCrypto;q&&q.getRandomValues?g.exports=Y:g.exports=B;function Y(E,O){if(E>M)throw new RangeError("requested too many random bytes");var N=A.allocUnsafe(E);if(E>0)if(E>R)for(var W=0;W<E;W+=R)q.getRandomValues(N.slice(W,W+R));else q.getRandomValues(N);return typeof O=="function"?process.nextTick(function(){O(null,N)}):N}}),JQ=OJ((l,g)=>{typeof Object.create=="function"?g.exports=function(R,M){M&&(R.super_=M,R.prototype=Object.create(M.prototype,{constructor:{value:R,enumerable:!1,writable:!0,configurable:!0}}))}:g.exports=function(R,M){if(M){R.super_=M;var B=function(){};B.prototype=M.prototype,R.prototype=new B,R.prototype.constructor=R}}}),rQ=OJ((l,g)=>{var R=typeof Reflect=="object"?Reflect:null,M=R&&typeof R.apply=="function"?R.apply:function(i,JJ,VJ){return Function.prototype.apply.call(i,JJ,VJ)},B;R&&typeof R.ownKeys=="function"?B=R.ownKeys:Object.getOwnPropertySymbols?B=function(i){return Object.getOwnPropertyNames(i).concat(Object.getOwnPropertySymbols(i))}:B=function(i){return Object.getOwnPropertyNames(i)};function A(i){console&&console.warn&&console.warn(i)}var q=Number.isNaN||function(i){return i!==i};function Y(){Y.init.call(this)}g.exports=Y,g.exports.once=w,Y.EventEmitter=Y,Y.prototype._events=void 0,Y.prototype._eventsCount=0,Y.prototype._maxListeners=void 0;var E=10;function O(i){if(typeof i!="function")throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof i)}Object.defineProperty(Y,"defaultMaxListeners",{enumerable:!0,get:function(){return E},set:function(i){if(typeof i!="number"||i<0||q(i))throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received '+i+".");E=i}}),Y.init=function(){(this._events===void 0||this._events===Object.getPrototypeOf(this)._events)&&(this._events=Object.create(null),this._eventsCount=0),this._maxListeners=this._maxListeners||void 0},Y.prototype.setMaxListeners=function(i){if(typeof i!="number"||i<0||q(i))throw new RangeError('The value of "n" is out of range. It must be a non-negative number. Received '+i+".");return this._maxListeners=i,this};function N(i){return i._maxListeners===void 0?Y.defaultMaxListeners:i._maxListeners}Y.prototype.getMaxListeners=function(){return N(this)},Y.prototype.emit=function(i){for(var JJ=[],VJ=1;VJ<arguments.length;VJ++)JJ.push(arguments[VJ]);var HJ=i==="error",o=this._events;if(o!==void 0)HJ=HJ&&o.error===void 0;else if(!HJ)return!1;if(HJ){var jJ;if(JJ.length>0&&(jJ=JJ[0]),jJ instanceof Error)throw jJ;var J=new Error("Unhandled error."+(jJ?" ("+jJ.message+")":""));throw J.context=jJ,J}var V=o[i];if(V===void 0)return!1;if(typeof V=="function")M(V,this,JJ);else for(var Z=V.length,$=F(V,Z),VJ=0;VJ<Z;++VJ)M($[VJ],this,JJ);return!0};function W(i,JJ,VJ,HJ){var o,jJ,J;if(O(VJ),jJ=i._events,jJ===void 0?(jJ=i._events=Object.create(null),i._eventsCount=0):(jJ.newListener!==void 0&&(i.emit("newListener",JJ,VJ.listener?VJ.listener:VJ),jJ=i._events),J=jJ[JJ]),J===void 0)J=jJ[JJ]=VJ,++i._eventsCount;else if(typeof J=="function"?J=jJ[JJ]=HJ?[VJ,J]:[J,VJ]:HJ?J.unshift(VJ):J.push(VJ),o=N(i),o>0&&J.length>o&&!J.warned){J.warned=!0;var V=new Error("Possible EventEmitter memory leak detected. "+J.length+" "+String(JJ)+" listeners added. Use emitter.setMaxListeners() to increase limit");V.name="MaxListenersExceededWarning",V.emitter=i,V.type=JJ,V.count=J.length,A(V)}return i}Y.prototype.addListener=function(i,JJ){return W(this,i,JJ,!1)},Y.prototype.on=Y.prototype.addListener,Y.prototype.prependListener=function(i,JJ){return W(this,i,JJ,!0)};function I(){if(!this.fired)return this.target.removeListener(this.type,this.wrapFn),this.fired=!0,arguments.length===0?this.listener.call(this.target):this.listener.apply(this.target,arguments)}function z(i,JJ,VJ){var HJ={fired:!1,wrapFn:void 0,target:i,type:JJ,listener:VJ},o=I.bind(HJ);return o.listener=VJ,HJ.wrapFn=o,o}Y.prototype.once=function(i,JJ){return O(JJ),this.on(i,z(this,i,JJ)),this},Y.prototype.prependOnceListener=function(i,JJ){return O(JJ),this.prependListener(i,z(this,i,JJ)),this},Y.prototype.removeListener=function(i,JJ){var VJ,HJ,o,jJ,J;if(O(JJ),HJ=this._events,HJ===void 0)return this;if(VJ=HJ[i],VJ===void 0)return this;if(VJ===JJ||VJ.listener===JJ)--this._eventsCount===0?this._events=Object.create(null):(delete HJ[i],HJ.removeListener&&this.emit("removeListener",i,VJ.listener||JJ));else if(typeof VJ!="function"){for(o=-1,jJ=VJ.length-1;jJ>=0;jJ--)if(VJ[jJ]===JJ||VJ[jJ].listener===JJ){J=VJ[jJ].listener,o=jJ;break}if(o<0)return this;o===0?VJ.shift():v(VJ,o),VJ.length===1&&(HJ[i]=VJ[0]),HJ.removeListener!==void 0&&this.emit("removeListener",i,J||JJ)}return this},Y.prototype.off=Y.prototype.removeListener,Y.prototype.removeAllListeners=function(i){var JJ,VJ,HJ;if(VJ=this._events,VJ===void 0)return this;if(VJ.removeListener===void 0)return arguments.length===0?(this._events=Object.create(null),this._eventsCount=0):VJ[i]!==void 0&&(--this._eventsCount===0?this._events=Object.create(null):delete VJ[i]),this;if(arguments.length===0){var o=Object.keys(VJ),jJ;for(HJ=0;HJ<o.length;++HJ)jJ=o[HJ],jJ!=="removeListener"&&this.removeAllListeners(jJ);return this.removeAllListeners("removeListener"),this._events=Object.create(null),this._eventsCount=0,this}if(JJ=VJ[i],typeof JJ=="function")this.removeListener(i,JJ);else if(JJ!==void 0)for(HJ=JJ.length-1;HJ>=0;HJ--)this.removeListener(i,JJ[HJ]);return this};function j(i,JJ,VJ){var HJ=i._events;if(HJ===void 0)return[];var o=HJ[JJ];return o===void 0?[]:typeof o=="function"?VJ?[o.listener||o]:[o]:VJ?S(o):F(o,o.length)}Y.prototype.listeners=function(i){return j(this,i,!0)},Y.prototype.rawListeners=function(i){return j(this,i,!1)},Y.listenerCount=function(i,JJ){return typeof i.listenerCount=="function"?i.listenerCount(JJ):P.call(i,JJ)},Y.prototype.listenerCount=P;function P(i){var JJ=this._events;if(JJ!==void 0){var VJ=JJ[i];if(typeof VJ=="function")return 1;if(VJ!==void 0)return VJ.length}return 0}Y.prototype.eventNames=function(){return this._eventsCount>0?B(this._events):[]};function F(i,JJ){for(var VJ=new Array(JJ),HJ=0;HJ<JJ;++HJ)VJ[HJ]=i[HJ];return VJ}function v(i,JJ){for(;JJ+1<i.length;JJ++)i[JJ]=i[JJ+1];i.pop()}function S(i){for(var JJ=new Array(i.length),VJ=0;VJ<JJ.length;++VJ)JJ[VJ]=i[VJ].listener||i[VJ];return JJ}function w(i,JJ){return new Promise(function(VJ,HJ){function o(J){i.removeListener(JJ,jJ),HJ(J)}function jJ(){typeof i.removeListener=="function"&&i.removeListener("error",o),VJ([].slice.call(arguments))}m(i,JJ,jJ,{once:!0}),JJ!=="error"&&y(i,o,{once:!0})})}function y(i,JJ,VJ){typeof i.on=="function"&&m(i,"error",JJ,VJ)}function m(i,JJ,VJ,HJ){if(typeof i.on=="function")HJ.once?i.once(JJ,VJ):i.on(JJ,VJ);else if(typeof i.addEventListener=="function")i.addEventListener(JJ,function o(jJ){HJ.once&&i.removeEventListener(JJ,o),VJ(jJ)});else throw new TypeError('The "emitter" argument must be of type EventEmitter. Received type '+typeof i)}}),R0=OJ((l,g)=>{g.exports=rQ().EventEmitter}),PV=OJ(()=>{}),Q8=OJ((l,g)=>{function R(j,P){var F=Object.keys(j);if(Object.getOwnPropertySymbols){var v=Object.getOwnPropertySymbols(j);P&&(v=v.filter(function(S){return Object.getOwnPropertyDescriptor(j,S).enumerable})),F.push.apply(F,v)}return F}function M(j){for(var P=1;P<arguments.length;P++){var F=arguments[P]!=null?arguments[P]:{};P%2?R(Object(F),!0).forEach(function(v){B(j,v,F[v])}):Object.getOwnPropertyDescriptors?Object.defineProperties(j,Object.getOwnPropertyDescriptors(F)):R(Object(F)).forEach(function(v){Object.defineProperty(j,v,Object.getOwnPropertyDescriptor(F,v))})}return j}function B(j,P,F){return P in j?Object.defineProperty(j,P,{value:F,enumerable:!0,configurable:!0,writable:!0}):j[P]=F,j}function A(j,P){if(!(j instanceof P))throw new TypeError("Cannot call a class as a function")}function q(j,P){for(var F=0;F<P.length;F++){var v=P[F];v.enumerable=v.enumerable||!1,v.configurable=!0,"value"in v&&(v.writable=!0),Object.defineProperty(j,v.key,v)}}function Y(j,P,F){return P&&q(j.prototype,P),F&&q(j,F),j}var E=yQ(),O=E.Buffer,N=PV(),W=N.inspect,I=W&&W.custom||"inspect";function z(j,P,F){O.prototype.copy.call(j,P,F)}g.exports=function(){function j(){A(this,j),this.head=null,this.tail=null,this.length=0}return Y(j,[{key:"push",value:function(P){var F={data:P,next:null};this.length>0?this.tail.next=F:this.head=F,this.tail=F,++this.length}},{key:"unshift",value:function(P){var F={data:P,next:this.head};this.length===0&&(this.tail=F),this.head=F,++this.length}},{key:"shift",value:function(){if(this.length!==0){var P=this.head.data;return this.length===1?this.head=this.tail=null:this.head=this.head.next,--this.length,P}}},{key:"clear",value:function(){this.head=this.tail=null,this.length=0}},{key:"join",value:function(P){if(this.length===0)return"";for(var F=this.head,v=""+F.data;F=F.next;)v+=P+F.data;return v}},{key:"concat",value:function(P){if(this.length===0)return O.alloc(0);for(var F=O.allocUnsafe(P>>>0),v=this.head,S=0;v;)z(v.data,F,S),S+=v.data.length,v=v.next;return F}},{key:"consume",value:function(P,F){var v;return P<this.head.data.length?(v=this.head.data.slice(0,P),this.head.data=this.head.data.slice(P)):P===this.head.data.length?v=this.shift():v=F?this._getString(P):this._getBuffer(P),v}},{key:"first",value:function(){return this.head.data}},{key:"_getString",value:function(P){var F=this.head,v=1,S=F.data;for(P-=S.length;F=F.next;){var w=F.data,y=P>w.length?w.length:P;if(y===w.length?S+=w:S+=w.slice(0,P),P-=y,P===0){y===w.length?(++v,F.next?this.head=F.next:this.head=this.tail=null):(this.head=F,F.data=w.slice(y));break}++v}return this.length-=v,S}},{key:"_getBuffer",value:function(P){var F=O.allocUnsafe(P),v=this.head,S=1;for(v.data.copy(F),P-=v.data.length;v=v.next;){var w=v.data,y=P>w.length?w.length:P;if(w.copy(F,F.length-P,0,y),P-=y,P===0){y===w.length?(++S,v.next?this.head=v.next:this.head=this.tail=null):(this.head=v,v.data=w.slice(y));break}++S}return this.length-=S,F}},{key:I,value:function(P,F){return W(this,M({},F,{depth:0,customInspect:!1}))}}]),j}()}),z0=OJ((l,g)=>{function R(E,O){var N=this,W=this._readableState&&this._readableState.destroyed,I=this._writableState&&this._writableState.destroyed;return W||I?(O?O(E):E&&(this._writableState?this._writableState.errorEmitted||(this._writableState.errorEmitted=!0,process.nextTick(q,this,E)):process.nextTick(q,this,E)),this):(this._readableState&&(this._readableState.destroyed=!0),this._writableState&&(this._writableState.destroyed=!0),this._destroy(E||null,function(z){!O&&z?N._writableState?N._writableState.errorEmitted?process.nextTick(B,N):(N._writableState.errorEmitted=!0,process.nextTick(M,N,z)):process.nextTick(M,N,z):O?(process.nextTick(B,N),O(z)):process.nextTick(B,N)}),this)}function M(E,O){q(E,O),B(E)}function B(E){E._writableState&&!E._writableState.emitClose||E._readableState&&!E._readableState.emitClose||E.emit("close")}function A(){this._readableState&&(this._readableState.destroyed=!1,this._readableState.reading=!1,this._readableState.ended=!1,this._readableState.endEmitted=!1),this._writableState&&(this._writableState.destroyed=!1,this._writableState.ended=!1,this._writableState.ending=!1,this._writableState.finalCalled=!1,this._writableState.prefinished=!1,this._writableState.finished=!1,this._writableState.errorEmitted=!1)}function q(E,O){E.emit("error",O)}function Y(E,O){var{_readableState:N,_writableState:W}=E;N&&N.autoDestroy||W&&W.autoDestroy?E.destroy(O):E.emit("error",O)}g.exports={destroy:R,undestroy:A,errorOrDestroy:Y}}),$V=OJ((l,g)=>{function R(O,N){O.prototype=Object.create(N.prototype),O.prototype.constructor=O,O.__proto__=N}var M={};function B(O,N,W){W||(W=Error);function I(j,P,F){return typeof N=="string"?N:N(j,P,F)}var z=function(j){R(P,j);function P(F,v,S){return j.call(this,I(F,v,S))||this}return P}(W);z.prototype.name=W.name,z.prototype.code=O,M[O]=z}function A(O,N){if(Array.isArray(O)){var W=O.length;return O=O.map(function(I){return String(I)}),W>2?"one of ".concat(N," ").concat(O.slice(0,W-1).join(", "),", or ")+O[W-1]:W===2?"one of ".concat(N," ").concat(O[0]," or ").concat(O[1]):"of ".concat(N," ").concat(O[0])}else return"of ".concat(N," ").concat(String(O))}function q(O,N,W){return O.substr(!W||W<0?0:+W,N.length)===N}function Y(O,N,W){return(W===void 0||W>O.length)&&(W=O.length),O.substring(W-N.length,W)===N}function E(O,N,W){return typeof W!="number"&&(W=0),W+N.length>O.length?!1:O.indexOf(N,W)!==-1}B("ERR_INVALID_OPT_VALUE",function(O,N){return'The value "'+N+'" is invalid for option "'+O+'"'},TypeError),B("ERR_INVALID_ARG_TYPE",function(O,N,W){var I;typeof N=="string"&&q(N,"not ")?(I="must not be",N=N.replace(/^not /,"")):I="must be";var z;if(Y(O," argument"))z="The ".concat(O," ").concat(I," ").concat(A(N,"type"));else{var j=E(O,".")?"property":"argument";z='The "'.concat(O,'" ').concat(j," ").concat(I," ").concat(A(N,"type"))}return z+=". Received type ".concat(typeof W),z},TypeError),B("ERR_STREAM_PUSH_AFTER_EOF","stream.push() after EOF"),B("ERR_METHOD_NOT_IMPLEMENTED",function(O){return"The "+O+" method is not implemented"}),B("ERR_STREAM_PREMATURE_CLOSE","Premature close"),B("ERR_STREAM_DESTROYED",function(O){return"Cannot call "+O+" after a stream was destroyed"}),B("ERR_MULTIPLE_CALLBACK","Callback called multiple times"),B("ERR_STREAM_CANNOT_PIPE","Cannot pipe, not readable"),B("ERR_STREAM_WRITE_AFTER_END","write after end"),B("ERR_STREAM_NULL_VALUES","May not write null values to stream",TypeError),B("ERR_UNKNOWN_ENCODING",function(O){return"Unknown encoding: "+O},TypeError),B("ERR_STREAM_UNSHIFT_AFTER_END_EVENT","stream.unshift() after end event"),g.exports.codes=M}),P0=OJ((l,g)=>{var R=$V().codes.ERR_INVALID_OPT_VALUE;function M(A,q,Y){return A.highWaterMark!=null?A.highWaterMark:q?A[Y]:null}function B(A,q,Y,E){var O=M(q,E,Y);if(O!=null){if(!(isFinite(O)&&Math.floor(O)===O)||O<0){var N=E?Y:"highWaterMark";throw new R(N,O)}return Math.floor(O)}return A.objectMode?16:16384}g.exports={getHighWaterMark:B}}),L0=OJ((l,g)=>{g.exports=R;function R(B,A){if(M("noDeprecation"))return B;var q=!1;function Y(){if(!q){if(M("throwDeprecation"))throw new Error(A);M("traceDeprecation")?console.trace(A):console.warn(A),q=!0}return B.apply(this,arguments)}return Y}function M(B){try{if(!global.localStorage)return!1}catch{return!1}var A=global.localStorage[B];return A==null?!1:String(A).toLowerCase()==="true"}}),F0=OJ((l,g)=>{g.exports=o;function R(n){var p=this;this.next=null,this.entry=null,this.finish=function(){GJ(p,n)}}var M;o.WritableState=VJ;var B={deprecate:L0()},A=R0(),q=yQ().Buffer,Y=global.Uint8Array||function(){};function E(n){return q.from(n)}function O(n){return q.isBuffer(n)||n instanceof Y}var N=z0(),W=P0(),I=W.getHighWaterMark,z=$V().codes,j=z.ERR_INVALID_ARG_TYPE,P=z.ERR_METHOD_NOT_IMPLEMENTED,F=z.ERR_MULTIPLE_CALLBACK,v=z.ERR_STREAM_CANNOT_PIPE,S=z.ERR_STREAM_DESTROYED,w=z.ERR_STREAM_NULL_VALUES,y=z.ERR_STREAM_WRITE_AFTER_END,m=z.ERR_UNKNOWN_ENCODING,i=N.errorOrDestroy;JQ()(o,A);function JJ(){}function VJ(n,p,e){M=M||ZV(),n=n||{},typeof e!="boolean"&&(e=p instanceof M),this.objectMode=!!n.objectMode,e&&(this.objectMode=this.objectMode||!!n.writableObjectMode),this.highWaterMark=I(this,n,"writableHighWaterMark",e),this.finalCalled=!1,this.needDrain=!1,this.ending=!1,this.ended=!1,this.finished=!1,this.destroyed=!1;var PJ=n.decodeStrings===!1;this.decodeStrings=!PJ,this.defaultEncoding=n.defaultEncoding||"utf8",this.length=0,this.writing=!1,this.corked=0,this.sync=!0,this.bufferProcessing=!1,this.onwrite=function(XJ){H(p,XJ)},this.writecb=null,this.writelen=0,this.bufferedRequest=null,this.lastBufferedRequest=null,this.pendingcb=0,this.prefinished=!1,this.errorEmitted=!1,this.emitClose=n.emitClose!==!1,this.autoDestroy=!!n.autoDestroy,this.bufferedRequestCount=0,this.corkedRequestsFree=new R(this)}VJ.prototype.getBuffer=function(){for(var n=this.bufferedRequest,p=[];n;)p.push(n),n=n.next;return p},function(){try{Object.defineProperty(VJ.prototype,"buffer",{get:B.deprecate(function(){return this.getBuffer()},"_writableState.buffer is deprecated. Use _writableState.getBuffer instead.","DEP0003")})}catch{}}();var HJ;typeof Symbol=="function"&&Symbol.hasInstance&&typeof Function.prototype[Symbol.hasInstance]=="function"?(HJ=Function.prototype[Symbol.hasInstance],Object.defineProperty(o,Symbol.hasInstance,{value:function(n){return HJ.call(this,n)?!0:this!==o?!1:n&&n._writableState instanceof VJ}})):HJ=function(n){return n instanceof this};function o(n){M=M||ZV();var p=this instanceof M;if(!p&&!HJ.call(o,this))return new o(n);this._writableState=new VJ(n,this,p),this.writable=!0,n&&(typeof n.write=="function"&&(this._write=n.write),typeof n.writev=="function"&&(this._writev=n.writev),typeof n.destroy=="function"&&(this._destroy=n.destroy),typeof n.final=="function"&&(this._final=n.final)),A.call(this)}o.prototype.pipe=function(){i(this,new v)};function jJ(n,p){var e=new y;i(n,e),process.nextTick(p,e)}function J(n,p,e,PJ){var XJ;return e===null?XJ=new w:typeof e!="string"&&!p.objectMode&&(XJ=new j("chunk",["string","Buffer"],e)),XJ?(i(n,XJ),process.nextTick(PJ,XJ),!1):!0}o.prototype.write=function(n,p,e){var PJ=this._writableState,XJ=!1,WJ=!PJ.objectMode&&O(n);return WJ&&!q.isBuffer(n)&&(n=E(n)),typeof p=="function"&&(e=p,p=null),WJ?p="buffer":p||(p=PJ.defaultEncoding),typeof e!="function"&&(e=JJ),PJ.ending?jJ(this,e):(WJ||J(this,PJ,n,e))&&(PJ.pendingcb++,XJ=Z(this,PJ,WJ,n,p,e)),XJ},o.prototype.cork=function(){this._writableState.corked++},o.prototype.uncork=function(){var n=this._writableState;n.corked&&(n.corked--,!n.writing&&!n.corked&&!n.bufferProcessing&&n.bufferedRequest&&K(this,n))},o.prototype.setDefaultEncoding=function(n){if(typeof n=="string"&&(n=n.toLowerCase()),!(["hex","utf8","utf-8","ascii","binary","base64","ucs2","ucs-2","utf16le","utf-16le","raw"].indexOf((n+"").toLowerCase())>-1))throw new m(n);return this._writableState.defaultEncoding=n,this},Object.defineProperty(o.prototype,"writableBuffer",{enumerable:!1,get:function(){return this._writableState&&this._writableState.getBuffer()}});function V(n,p,e){return!n.objectMode&&n.decodeStrings!==!1&&typeof p=="string"&&(p=q.from(p,e)),p}Object.defineProperty(o.prototype,"writableHighWaterMark",{enumerable:!1,get:function(){return this._writableState.highWaterMark}});function Z(n,p,e,PJ,XJ,WJ){if(!e){var b=V(p,PJ,XJ);PJ!==b&&(e=!0,XJ="buffer",PJ=b)}var C=p.objectMode?1:PJ.length;p.length+=C;var h=p.length<p.highWaterMark;if(h||(p.needDrain=!0),p.writing||p.corked){var $J=p.lastBufferedRequest;p.lastBufferedRequest={chunk:PJ,encoding:XJ,isBuf:e,callback:WJ,next:null},$J?$J.next=p.lastBufferedRequest:p.bufferedRequest=p.lastBufferedRequest,p.bufferedRequestCount+=1}else $(n,p,!1,C,PJ,XJ,WJ);return h}function $(n,p,e,PJ,XJ,WJ,b){p.writelen=PJ,p.writecb=b,p.writing=!0,p.sync=!0,p.destroyed?p.onwrite(new S("write")):e?n._writev(XJ,p.onwrite):n._write(XJ,WJ,p.onwrite),p.sync=!1}function X(n,p,e,PJ,XJ){--p.pendingcb,e?(process.nextTick(XJ,PJ),process.nextTick(t,n,p),n._writableState.errorEmitted=!0,i(n,PJ)):(XJ(PJ),n._writableState.errorEmitted=!0,i(n,PJ),t(n,p))}function U(n){n.writing=!1,n.writecb=null,n.length-=n.writelen,n.writelen=0}function H(n,p){var e=n._writableState,PJ=e.sync,XJ=e.writecb;if(typeof XJ!="function")throw new F;if(U(e),p)X(n,e,PJ,p,XJ);else{var WJ=k(e)||n.destroyed;!WJ&&!e.corked&&!e.bufferProcessing&&e.bufferedRequest&&K(n,e),PJ?process.nextTick(G,n,e,WJ,XJ):G(n,e,WJ,XJ)}}function G(n,p,e,PJ){e||Q(n,p),p.pendingcb--,PJ(),t(n,p)}function Q(n,p){p.length===0&&p.needDrain&&(p.needDrain=!1,n.emit("drain"))}function K(n,p){p.bufferProcessing=!0;var e=p.bufferedRequest;if(n._writev&&e&&e.next){var PJ=p.bufferedRequestCount,XJ=new Array(PJ),WJ=p.corkedRequestsFree;WJ.entry=e;for(var b=0,C=!0;e;)XJ[b]=e,e.isBuf||(C=!1),e=e.next,b+=1;XJ.allBuffers=C,$(n,p,!0,p.length,XJ,"",WJ.finish),p.pendingcb++,p.lastBufferedRequest=null,WJ.next?(p.corkedRequestsFree=WJ.next,WJ.next=null):p.corkedRequestsFree=new R(p),p.bufferedRequestCount=0}else{for(;e;){var{chunk:h,encoding:$J,callback:qJ}=e,ZJ=p.objectMode?1:h.length;if($(n,p,!1,ZJ,h,$J,qJ),e=e.next,p.bufferedRequestCount--,p.writing)break}e===null&&(p.lastBufferedRequest=null)}p.bufferedRequest=e,p.bufferProcessing=!1}o.prototype._write=function(n,p,e){e(new P("_write()"))},o.prototype._writev=null,o.prototype.end=function(n,p,e){var PJ=this._writableState;return typeof n=="function"?(e=n,n=null,p=null):typeof p=="function"&&(e=p,p=null),n!=null&&this.write(n,p),PJ.corked&&(PJ.corked=1,this.uncork()),PJ.ending||QJ(this,PJ,e),this},Object.defineProperty(o.prototype,"writableLength",{enumerable:!1,get:function(){return this._writableState.length}});function k(n){return n.ending&&n.length===0&&n.bufferedRequest===null&&!n.finished&&!n.writing}function L(n,p){n._final(function(e){p.pendingcb--,e&&i(n,e),p.prefinished=!0,n.emit("prefinish"),t(n,p)})}function _(n,p){!p.prefinished&&!p.finalCalled&&(typeof n._final=="function"&&!p.destroyed?(p.pendingcb++,p.finalCalled=!0,process.nextTick(L,n,p)):(p.prefinished=!0,n.emit("prefinish")))}function t(n,p){var e=k(p);if(e&&(_(n,p),p.pendingcb===0&&(p.finished=!0,n.emit("finish"),p.autoDestroy))){var PJ=n._readableState;(!PJ||PJ.autoDestroy&&PJ.endEmitted)&&n.destroy()}return e}function QJ(n,p,e){p.ending=!0,t(n,p),e&&(p.finished?process.nextTick(e):n.once("finish",e)),p.ended=!0,n.writable=!1}function GJ(n,p,e){var PJ=n.entry;for(n.entry=null;PJ;){var XJ=PJ.callback;p.pendingcb--,XJ(e),PJ=PJ.next}p.corkedRequestsFree.next=n}Object.defineProperty(o.prototype,"destroyed",{enumerable:!1,get:function(){return this._writableState===void 0?!1:this._writableState.destroyed},set:function(n){!this._writableState||(this._writableState.destroyed=n)}}),o.prototype.destroy=N.destroy,o.prototype._undestroy=N.undestroy,o.prototype._destroy=function(n,p){p(n)}}),ZV=OJ((l,g)=>{var R=Object.keys||function(W){var I=[];for(var z in W)I.push(z);return I};g.exports=E;var M=C0(),B=F0();JQ()(E,M);for(A=R(B.prototype),Y=0;Y<A.length;Y++)q=A[Y],E.prototype[q]||(E.prototype[q]=B.prototype[q]);var A,q,Y;function E(W){if(!(this instanceof E))return new E(W);M.call(this,W),B.call(this,W),this.allowHalfOpen=!0,W&&(W.readable===!1&&(this.readable=!1),W.writable===!1&&(this.writable=!1),W.allowHalfOpen===!1&&(this.allowHalfOpen=!1,this.once("end",O)))}Object.defineProperty(E.prototype,"writableHighWaterMark",{enumerable:!1,get:function(){return this._writableState.highWaterMark}}),Object.defineProperty(E.prototype,"writableBuffer",{enumerable:!1,get:function(){return this._writableState&&this._writableState.getBuffer()}}),Object.defineProperty(E.prototype,"writableLength",{enumerable:!1,get:function(){return this._writableState.length}});function O(){this._writableState.ended||process.nextTick(N,this)}function N(W){W.end()}Object.defineProperty(E.prototype,"destroyed",{enumerable:!1,get:function(){return this._readableState===void 0||this._writableState===void 0?!1:this._readableState.destroyed&&this._writableState.destroyed},set:function(W){this._readableState===void 0||this._writableState===void 0||(this._readableState.destroyed=W,this._writableState.destroyed=W)}})}),hV=OJ((l)=>{var g=XQ().Buffer,R=g.isEncoding||function(S){switch(S=""+S,S&&S.toLowerCase()){case"hex":case"utf8":case"utf-8":case"ascii":case"binary":case"base64":case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":case"raw":return!0;default:return!1}};function M(S){if(!S)return"utf8";for(var w;;)switch(S){case"utf8":case"utf-8":return"utf8";case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return"utf16le";case"latin1":case"binary":return"latin1";case"base64":case"ascii":case"hex":return S;default:if(w)return;S=(""+S).toLowerCase(),w=!0}}function B(S){var w=M(S);if(typeof w!="string"&&(g.isEncoding===R||!R(S)))throw new Error("Unknown encoding: "+S);return w||S}l.StringDecoder=A;function A(S){this.encoding=B(S);var w;switch(this.encoding){case"utf16le":this.text=I,this.end=z,w=4;break;case"utf8":this.fillLast=O,w=4;break;case"base64":this.text=j,this.end=P,w=3;break;default:this.write=F,this.end=v;return}this.lastNeed=0,this.lastTotal=0,this.lastChar=g.allocUnsafe(w)}A.prototype.write=function(S){if(S.length===0)return"";var w,y;if(this.lastNeed){if(w=this.fillLast(S),w===void 0)return"";y=this.lastNeed,this.lastNeed=0}else y=0;return y<S.length?w?w+this.text(S,y):this.text(S,y):w||""},A.prototype.end=W,A.prototype.text=N,A.prototype.fillLast=function(S){if(this.lastNeed<=S.length)return S.copy(this.lastChar,this.lastTotal-this.lastNeed,0,this.lastNeed),this.lastChar.toString(this.encoding,0,this.lastTotal);S.copy(this.lastChar,this.lastTotal-this.lastNeed,0,S.length),this.lastNeed-=S.length};function q(S){return S<=127?0:S>>5===6?2:S>>4===14?3:S>>3===30?4:S>>6===2?-1:-2}function Y(S,w,y){var m=w.length-1;if(m<y)return 0;var i=q(w[m]);return i>=0?(i>0&&(S.lastNeed=i-1),i):--m<y||i===-2?0:(i=q(w[m]),i>=0?(i>0&&(S.lastNeed=i-2),i):--m<y||i===-2?0:(i=q(w[m]),i>=0?(i>0&&(i===2?i=0:S.lastNeed=i-3),i):0))}function E(S,w,y){if((w[0]&192)!==128)return S.lastNeed=0,"\uFFFD";if(S.lastNeed>1&&w.length>1){if((w[1]&192)!==128)return S.lastNeed=1,"\uFFFD";if(S.lastNeed>2&&w.length>2&&(w[2]&192)!==128)return S.lastNeed=2,"\uFFFD"}}function O(S){var w=this.lastTotal-this.lastNeed,y=E(this,S,w);if(y!==void 0)return y;if(this.lastNeed<=S.length)return S.copy(this.lastChar,w,0,this.lastNeed),this.lastChar.toString(this.encoding,0,this.lastTotal);S.copy(this.lastChar,w,0,S.length),this.lastNeed-=S.length}function N(S,w){var y=Y(this,S,w);if(!this.lastNeed)return S.toString("utf8",w);this.lastTotal=y;var m=S.length-(y-this.lastNeed);return S.copy(this.lastChar,0,m),S.toString("utf8",w,m)}function W(S){var w=S&&S.length?this.write(S):"";return this.lastNeed?w+"\uFFFD":w}function I(S,w){if((S.length-w)%2===0){var y=S.toString("utf16le",w);if(y){var m=y.charCodeAt(y.length-1);if(m>=55296&&m<=56319)return this.lastNeed=2,this.lastTotal=4,this.lastChar[0]=S[S.length-2],this.lastChar[1]=S[S.length-1],y.slice(0,-1)}return y}return this.lastNeed=1,this.lastTotal=2,this.lastChar[0]=S[S.length-1],S.toString("utf16le",w,S.length-1)}function z(S){var w=S&&S.length?this.write(S):"";if(this.lastNeed){var y=this.lastTotal-this.lastNeed;return w+this.lastChar.toString("utf16le",0,y)}return w}function j(S,w){var y=(S.length-w)%3;return y===0?S.toString("base64",w):(this.lastNeed=3-y,this.lastTotal=3,y===1?this.lastChar[0]=S[S.length-1]:(this.lastChar[0]=S[S.length-2],this.lastChar[1]=S[S.length-1]),S.toString("base64",w,S.length-y))}function P(S){var w=S&&S.length?this.write(S):"";return this.lastNeed?w+this.lastChar.toString("base64",0,3-this.lastNeed):w}function F(S){return S.toString(this.encoding)}function v(S){return S&&S.length?this.write(S):""}}),HV={},RV(HV,{StringDecoder:()=>D0.StringDecoder,default:()=>D0.StringDecoder}),LV=cV(()=>{D0=oQ(hV())}),mV=OJ((l,g)=>{var R=$V().codes.ERR_STREAM_PREMATURE_CLOSE;function M(Y){var E=!1;return function(){if(!E){E=!0;for(var O=arguments.length,N=new Array(O),W=0;W<O;W++)N[W]=arguments[W];Y.apply(this,N)}}}function B(){}function A(Y){return Y.setHeader&&typeof Y.abort=="function"}function q(Y,E,O){if(typeof E=="function")return q(Y,null,E);E||(E={}),O=M(O||B);var N=E.readable||E.readable!==!1&&Y.readable,W=E.writable||E.writable!==!1&&Y.writable,I=function(){Y.writable||j()},z=Y._writableState&&Y._writableState.finished,j=function(){W=!1,z=!0,N||O.call(Y)},P=Y._readableState&&Y._readableState.endEmitted,F=function(){N=!1,P=!0,W||O.call(Y)},v=function(y){O.call(Y,y)},S=function(){var y;if(N&&!P)return(!Y._readableState||!Y._readableState.ended)&&(y=new R),O.call(Y,y);if(W&&!z)return(!Y._writableState||!Y._writableState.ended)&&(y=new R),O.call(Y,y)},w=function(){Y.req.on("finish",j)};return A(Y)?(Y.on("complete",j),Y.on("abort",S),Y.req?w():Y.on("request",w)):W&&!Y._writableState&&(Y.on("end",I),Y.on("close",I)),Y.on("end",F),Y.on("finish",j),E.error!==!1&&Y.on("error",v),Y.on("close",S),function(){Y.removeListener("complete",j),Y.removeListener("abort",S),Y.removeListener("request",w),Y.req&&Y.req.removeListener("finish",j),Y.removeListener("end",I),Y.removeListener("close",I),Y.removeListener("finish",j),Y.removeListener("end",F),Y.removeListener("error",v),Y.removeListener("close",S)}}g.exports=q}),V8=OJ((l,g)=>{var R;function M(w,y,m){return y in w?Object.defineProperty(w,y,{value:m,enumerable:!0,configurable:!0,writable:!0}):w[y]=m,w}var B=mV(),A=Symbol("lastResolve"),q=Symbol("lastReject"),Y=Symbol("error"),E=Symbol("ended"),O=Symbol("lastPromise"),N=Symbol("handlePromise"),W=Symbol("stream");function I(w,y){return{value:w,done:y}}function z(w){var y=w[A];if(y!==null){var m=w[W].read();m!==null&&(w[O]=null,w[A]=null,w[q]=null,y(I(m,!1)))}}function j(w){process.nextTick(z,w)}function P(w,y){return function(m,i){w.then(function(){if(y[E]){m(I(void 0,!0));return}y[N](m,i)},i)}}var F=Object.getPrototypeOf(function(){}),v=Object.setPrototypeOf((R={get stream(){return this[W]},next:function(){var w=this,y=this[Y];if(y!==null)return Promise.reject(y);if(this[E])return Promise.resolve(I(void 0,!0));if(this[W].destroyed)return new Promise(function(VJ,HJ){process.nextTick(function(){w[Y]?HJ(w[Y]):VJ(I(void 0,!0))})});var m=this[O],i;if(m)i=new Promise(P(m,this));else{var JJ=this[W].read();if(JJ!==null)return Promise.resolve(I(JJ,!1));i=new Promise(this[N])}return this[O]=i,i}},M(R,Symbol.asyncIterator,function(){return this}),M(R,"return",function(){var w=this;return new Promise(function(y,m){w[W].destroy(null,function(i){if(i){m(i);return}y(I(void 0,!0))})})}),R),F),S=function(w){var y,m=Object.create(v,(y={},M(y,W,{value:w,writable:!0}),M(y,A,{value:null,writable:!0}),M(y,q,{value:null,writable:!0}),M(y,Y,{value:null,writable:!0}),M(y,E,{value:w._readableState.endEmitted,writable:!0}),M(y,N,{value:function(i,JJ){var VJ=m[W].read();VJ?(m[O]=null,m[A]=null,m[q]=null,i(I(VJ,!1))):(m[A]=i,m[q]=JJ)},writable:!0}),y));return m[O]=null,B(w,function(i){if(i&&i.code!=="ERR_STREAM_PREMATURE_CLOSE"){var JJ=m[q];JJ!==null&&(m[O]=null,m[A]=null,m[q]=null,JJ(i)),m[Y]=i;return}var VJ=m[A];VJ!==null&&(m[O]=null,m[A]=null,m[q]=null,VJ(I(void 0,!0))),m[E]=!0}),w.on("readable",j.bind(null,m)),m};g.exports=S}),$8=OJ((l,g)=>{g.exports=function(){throw new Error("Readable.from is not available in the browser")}}),C0=OJ((l,g)=>{g.exports=J;var R;J.ReadableState=jJ;var M=rQ().EventEmitter,B=function(b,C){return b.listeners(C).length},A=R0(),q=yQ().Buffer,Y=global.Uint8Array||function(){};function E(b){return q.from(b)}function O(b){return q.isBuffer(b)||b instanceof Y}var N=PV(),W;N&&N.debuglog?W=N.debuglog("stream"):W=function(){};var I=Q8(),z=z0(),j=P0(),P=j.getHighWaterMark,F=$V().codes,v=F.ERR_INVALID_ARG_TYPE,S=F.ERR_STREAM_PUSH_AFTER_EOF,w=F.ERR_METHOD_NOT_IMPLEMENTED,y=F.ERR_STREAM_UNSHIFT_AFTER_END_EVENT,m,i,JJ;JQ()(J,A);var VJ=z.errorOrDestroy,HJ=["error","close","destroy","pause","resume"];function o(b,C,h){if(typeof b.prependListener=="function")return b.prependListener(C,h);!b._events||!b._events[C]?b.on(C,h):Array.isArray(b._events[C])?b._events[C].unshift(h):b._events[C]=[h,b._events[C]]}function jJ(b,C,h){R=R||ZV(),b=b||{},typeof h!="boolean"&&(h=C instanceof R),this.objectMode=!!b.objectMode,h&&(this.objectMode=this.objectMode||!!b.readableObjectMode),this.highWaterMark=P(this,b,"readableHighWaterMark",h),this.buffer=new I,this.length=0,this.pipes=null,this.pipesCount=0,this.flowing=null,this.ended=!1,this.endEmitted=!1,this.reading=!1,this.sync=!0,this.needReadable=!1,this.emittedReadable=!1,this.readableListening=!1,this.resumeScheduled=!1,this.paused=!0,this.emitClose=b.emitClose!==!1,this.autoDestroy=!!b.autoDestroy,this.destroyed=!1,this.defaultEncoding=b.defaultEncoding||"utf8",this.awaitDrain=0,this.readingMore=!1,this.decoder=null,this.encoding=null,b.encoding&&(m||(m=(LV(),fQ(HV)).StringDecoder),this.decoder=new m(b.encoding),this.encoding=b.encoding)}function J(b){if(R=R||ZV(),!(this instanceof J))return new J(b);var C=this instanceof R;this._readableState=new jJ(b,this,C),this.readable=!0,b&&(typeof b.read=="function"&&(this._read=b.read),typeof b.destroy=="function"&&(this._destroy=b.destroy)),A.call(this)}Object.defineProperty(J.prototype,"destroyed",{enumerable:!1,get:function(){return this._readableState===void 0?!1:this._readableState.destroyed},set:function(b){!this._readableState||(this._readableState.destroyed=b)}}),J.prototype.destroy=z.destroy,J.prototype._undestroy=z.undestroy,J.prototype._destroy=function(b,C){C(b)},J.prototype.push=function(b,C){var h=this._readableState,$J;return h.objectMode?$J=!0:typeof b=="string"&&(C=C||h.defaultEncoding,C!==h.encoding&&(b=q.from(b,C),C=""),$J=!0),V(this,b,C,!1,$J)},J.prototype.unshift=function(b){return V(this,b,null,!0,!1)};function V(b,C,h,$J,qJ){W("readableAddChunk",C);var ZJ=b._readableState;if(C===null)ZJ.reading=!1,G(b,ZJ);else{var mJ;if(qJ||(mJ=$(ZJ,C)),mJ)VJ(b,mJ);else if(ZJ.objectMode||C&&C.length>0)if(typeof C!="string"&&!ZJ.objectMode&&Object.getPrototypeOf(C)!==q.prototype&&(C=E(C)),$J)ZJ.endEmitted?VJ(b,new y):Z(b,ZJ,C,!0);else if(ZJ.ended)VJ(b,new S);else{if(ZJ.destroyed)return!1;ZJ.reading=!1,ZJ.decoder&&!h?(C=ZJ.decoder.write(C),ZJ.objectMode||C.length!==0?Z(b,ZJ,C,!1):k(b,ZJ)):Z(b,ZJ,C,!1)}else $J||(ZJ.reading=!1,k(b,ZJ))}return!ZJ.ended&&(ZJ.length<ZJ.highWaterMark||ZJ.length===0)}function Z(b,C,h,$J){C.flowing&&C.length===0&&!C.sync?(C.awaitDrain=0,b.emit("data",h)):(C.length+=C.objectMode?1:h.length,$J?C.buffer.unshift(h):C.buffer.push(h),C.needReadable&&Q(b)),k(b,C)}function $(b,C){var h;return!O(C)&&typeof C!="string"&&C!==void 0&&!b.objectMode&&(h=new v("chunk",["string","Buffer","Uint8Array"],C)),h}J.prototype.isPaused=function(){return this._readableState.flowing===!1},J.prototype.setEncoding=function(b){m||(m=(LV(),fQ(HV)).StringDecoder);var C=new m(b);this._readableState.decoder=C,this._readableState.encoding=this._readableState.decoder.encoding;for(var h=this._readableState.buffer.head,$J="";h!==null;)$J+=C.write(h.data),h=h.next;return this._readableState.buffer.clear(),$J!==""&&this._readableState.buffer.push($J),this._readableState.length=$J.length,this};var X=1073741824;function U(b){return b>=X?b=X:(b--,b|=b>>>1,b|=b>>>2,b|=b>>>4,b|=b>>>8,b|=b>>>16,b++),b}function H(b,C){return b<=0||C.length===0&&C.ended?0:C.objectMode?1:b!==b?C.flowing&&C.length?C.buffer.head.data.length:C.length:(b>C.highWaterMark&&(C.highWaterMark=U(b)),b<=C.length?b:C.ended?C.length:(C.needReadable=!0,0))}J.prototype.read=function(b){W("read",b),b=parseInt(b,10);var C=this._readableState,h=b;if(b!==0&&(C.emittedReadable=!1),b===0&&C.needReadable&&((C.highWaterMark!==0?C.length>=C.highWaterMark:C.length>0)||C.ended))return W("read: emitReadable",C.length,C.ended),C.length===0&&C.ended?PJ(this):Q(this),null;if(b=H(b,C),b===0&&C.ended)return C.length===0&&PJ(this),null;var $J=C.needReadable;W("need readable",$J),(C.length===0||C.length-b<C.highWaterMark)&&($J=!0,W("length less than watermark",$J)),C.ended||C.reading?($J=!1,W("reading or ended",$J)):$J&&(W("do read"),C.reading=!0,C.sync=!0,C.length===0&&(C.needReadable=!0),this._read(C.highWaterMark),C.sync=!1,C.reading||(b=H(h,C)));var qJ;return b>0?qJ=e(b,C):qJ=null,qJ===null?(C.needReadable=C.length<=C.highWaterMark,b=0):(C.length-=b,C.awaitDrain=0),C.length===0&&(C.ended||(C.needReadable=!0),h!==b&&C.ended&&PJ(this)),qJ!==null&&this.emit("data",qJ),qJ};function G(b,C){if(W("onEofChunk"),!C.ended){if(C.decoder){var h=C.decoder.end();h&&h.length&&(C.buffer.push(h),C.length+=C.objectMode?1:h.length)}C.ended=!0,C.sync?Q(b):(C.needReadable=!1,C.emittedReadable||(C.emittedReadable=!0,K(b)))}}function Q(b){var C=b._readableState;W("emitReadable",C.needReadable,C.emittedReadable),C.needReadable=!1,C.emittedReadable||(W("emitReadable",C.flowing),C.emittedReadable=!0,process.nextTick(K,b))}function K(b){var C=b._readableState;W("emitReadable_",C.destroyed,C.length,C.ended),!C.destroyed&&(C.length||C.ended)&&(b.emit("readable"),C.emittedReadable=!1),C.needReadable=!C.flowing&&!C.ended&&C.length<=C.highWaterMark,p(b)}function k(b,C){C.readingMore||(C.readingMore=!0,process.nextTick(L,b,C))}function L(b,C){for(;!C.reading&&!C.ended&&(C.length<C.highWaterMark||C.flowing&&C.length===0);){var h=C.length;if(W("maybeReadMore read 0"),b.read(0),h===C.length)break}C.readingMore=!1}J.prototype._read=function(b){VJ(this,new w("_read()"))},J.prototype.pipe=function(b,C){var h=this,$J=this._readableState;switch($J.pipesCount){case 0:$J.pipes=b;break;case 1:$J.pipes=[$J.pipes,b];break;default:$J.pipes.push(b);break}$J.pipesCount+=1,W("pipe count=%d opts=%j",$J.pipesCount,C);var qJ=(!C||C.end!==!1)&&b!==process.stdout&&b!==process.stderr,ZJ=qJ?BJ:u;$J.endEmitted?process.nextTick(ZJ):h.once("end",ZJ),b.on("unpipe",mJ);function mJ(d,a){W("onunpipe"),d===h&&a&&a.hasUnpiped===!1&&(a.hasUnpiped=!0,LJ())}function BJ(){W("onend"),b.end()}var TJ=_(h);b.on("drain",TJ);var dJ=!1;function LJ(){W("cleanup"),b.removeListener("close",T),b.removeListener("finish",D),b.removeListener("drain",TJ),b.removeListener("error",$Q),b.removeListener("unpipe",mJ),h.removeListener("end",BJ),h.removeListener("end",u),h.removeListener("data",IJ),dJ=!0,$J.awaitDrain&&(!b._writableState||b._writableState.needDrain)&&TJ()}h.on("data",IJ);function IJ(d){W("ondata");var a=b.write(d);W("dest.write",a),a===!1&&(($J.pipesCount===1&&$J.pipes===b||$J.pipesCount>1&&WJ($J.pipes,b)!==-1)&&!dJ&&(W("false write response, pause",$J.awaitDrain),$J.awaitDrain++),h.pause())}function $Q(d){W("onerror",d),u(),b.removeListener("error",$Q),B(b,"error")===0&&VJ(b,d)}o(b,"error",$Q);function T(){b.removeListener("finish",D),u()}b.once("close",T);function D(){W("onfinish"),b.removeListener("close",T),u()}b.once("finish",D);function u(){W("unpipe"),h.unpipe(b)}return b.emit("pipe",h),$J.flowing||(W("pipe resume"),h.resume()),b};function _(b){return function(){var C=b._readableState;W("pipeOnDrain",C.awaitDrain),C.awaitDrain&&C.awaitDrain--,C.awaitDrain===0&&B(b,"data")&&(C.flowing=!0,p(b))}}J.prototype.unpipe=function(b){var C=this._readableState,h={hasUnpiped:!1};if(C.pipesCount===0)return this;if(C.pipesCount===1)return b&&b!==C.pipes?this:(b||(b=C.pipes),C.pipes=null,C.pipesCount=0,C.flowing=!1,b&&b.emit("unpipe",this,h),this);if(!b){var{pipes:$J,pipesCount:qJ}=C;C.pipes=null,C.pipesCount=0,C.flowing=!1;for(var ZJ=0;ZJ<qJ;ZJ++)$J[ZJ].emit("unpipe",this,{hasUnpiped:!1});return this}var mJ=WJ(C.pipes,b);return mJ===-1?this:(C.pipes.splice(mJ,1),C.pipesCount-=1,C.pipesCount===1&&(C.pipes=C.pipes[0]),b.emit("unpipe",this,h),this)},J.prototype.on=function(b,C){var h=A.prototype.on.call(this,b,C),$J=this._readableState;return b==="data"?($J.readableListening=this.listenerCount("readable")>0,$J.flowing!==!1&&this.resume()):b==="readable"&&!$J.endEmitted&&!$J.readableListening&&($J.readableListening=$J.needReadable=!0,$J.flowing=!1,$J.emittedReadable=!1,W("on readable",$J.length,$J.reading),$J.length?Q(this):$J.reading||process.nextTick(QJ,this)),h},J.prototype.addListener=J.prototype.on,J.prototype.removeListener=function(b,C){var h=A.prototype.removeListener.call(this,b,C);return b==="readable"&&process.nextTick(t,this),h},J.prototype.removeAllListeners=function(b){var C=A.prototype.removeAllListeners.apply(this,arguments);return(b==="readable"||b===void 0)&&process.nextTick(t,this),C};function t(b){var C=b._readableState;C.readableListening=b.listenerCount("readable")>0,C.resumeScheduled&&!C.paused?C.flowing=!0:b.listenerCount("data")>0&&b.resume()}function QJ(b){W("readable nexttick read 0"),b.read(0)}J.prototype.resume=function(){var b=this._readableState;return b.flowing||(W("resume"),b.flowing=!b.readableListening,GJ(this,b)),b.paused=!1,this};function GJ(b,C){C.resumeScheduled||(C.resumeScheduled=!0,process.nextTick(n,b,C))}function n(b,C){W("resume",C.reading),C.reading||b.read(0),C.resumeScheduled=!1,b.emit("resume"),p(b),C.flowing&&!C.reading&&b.read(0)}J.prototype.pause=function(){return W("call pause flowing=%j",this._readableState.flowing),this._readableState.flowing!==!1&&(W("pause"),this._readableState.flowing=!1,this.emit("pause")),this._readableState.paused=!0,this};function p(b){var C=b._readableState;for(W("flow",C.flowing);C.flowing&&b.read()!==null;);}J.prototype.wrap=function(b){var C=this,h=this._readableState,$J=!1;b.on("end",function(){if(W("wrapped end"),h.decoder&&!h.ended){var mJ=h.decoder.end();mJ&&mJ.length&&C.push(mJ)}C.push(null)}),b.on("data",function(mJ){if(W("wrapped data"),h.decoder&&(mJ=h.decoder.write(mJ)),!(h.objectMode&&mJ==null)&&!(!h.objectMode&&(!mJ||!mJ.length))){var BJ=C.push(mJ);BJ||($J=!0,b.pause())}});for(var qJ in b)this[qJ]===void 0&&typeof b[qJ]=="function"&&(this[qJ]=function(mJ){return function(){return b[mJ].apply(b,arguments)}}(qJ));for(var ZJ=0;ZJ<HJ.length;ZJ++)b.on(HJ[ZJ],this.emit.bind(this,HJ[ZJ]));return this._read=function(mJ){W("wrapped _read",mJ),$J&&($J=!1,b.resume())},this},typeof Symbol=="function"&&(J.prototype[Symbol.asyncIterator]=function(){return i===void 0&&(i=V8()),i(this)}),Object.defineProperty(J.prototype,"readableHighWaterMark",{enumerable:!1,get:function(){return this._readableState.highWaterMark}}),Object.defineProperty(J.prototype,"readableBuffer",{enumerable:!1,get:function(){return this._readableState&&this._readableState.buffer}}),Object.defineProperty(J.prototype,"readableFlowing",{enumerable:!1,get:function(){return this._readableState.flowing},set:function(b){this._readableState&&(this._readableState.flowing=b)}}),J._fromList=e,Object.defineProperty(J.prototype,"readableLength",{enumerable:!1,get:function(){return this._readableState.length}});function e(b,C){if(C.length===0)return null;var h;return C.objectMode?h=C.buffer.shift():!b||b>=C.length?(C.decoder?h=C.buffer.join(""):C.buffer.length===1?h=C.buffer.first():h=C.buffer.concat(C.length),C.buffer.clear()):h=C.buffer.consume(b,C.decoder),h}function PJ(b){var C=b._readableState;W("endReadable",C.endEmitted),C.endEmitted||(C.ended=!0,process.nextTick(XJ,C,b))}function XJ(b,C){if(W("endReadableNT",b.endEmitted,b.length),!b.endEmitted&&b.length===0&&(b.endEmitted=!0,C.readable=!1,C.emit("end"),b.autoDestroy)){var h=C._writableState;(!h||h.autoDestroy&&h.finished)&&C.destroy()}}typeof Symbol=="function"&&(J.from=function(b,C){return JJ===void 0&&(JJ=$8()),JJ(J,b,C)});function WJ(b,C){for(var h=0,$J=b.length;h<$J;h++)if(b[h]===C)return h;return-1}}),k0=OJ((l,g)=>{g.exports=O;var R=$V().codes,M=R.ERR_METHOD_NOT_IMPLEMENTED,B=R.ERR_MULTIPLE_CALLBACK,A=R.ERR_TRANSFORM_ALREADY_TRANSFORMING,q=R.ERR_TRANSFORM_WITH_LENGTH_0,Y=ZV();JQ()(O,Y);function E(I,z){var j=this._transformState;j.transforming=!1;var P=j.writecb;if(P===null)return this.emit("error",new B);j.writechunk=null,j.writecb=null,z!=null&&this.push(z),P(I);var F=this._readableState;F.reading=!1,(F.needReadable||F.length<F.highWaterMark)&&this._read(F.highWaterMark)}function O(I){if(!(this instanceof O))return new O(I);Y.call(this,I),this._transformState={afterTransform:E.bind(this),needTransform:!1,transforming:!1,writecb:null,writechunk:null,writeencoding:null},this._readableState.needReadable=!0,this._readableState.sync=!1,I&&(typeof I.transform=="function"&&(this._transform=I.transform),typeof I.flush=="function"&&(this._flush=I.flush)),this.on("prefinish",N)}function N(){var I=this;typeof this._flush=="function"&&!this._readableState.destroyed?this._flush(function(z,j){W(I,z,j)}):W(this,null,null)}O.prototype.push=function(I,z){return this._transformState.needTransform=!1,Y.prototype.push.call(this,I,z)},O.prototype._transform=function(I,z,j){j(new M("_transform()"))},O.prototype._write=function(I,z,j){var P=this._transformState;if(P.writecb=j,P.writechunk=I,P.writeencoding=z,!P.transforming){var F=this._readableState;(P.needTransform||F.needReadable||F.length<F.highWaterMark)&&this._read(F.highWaterMark)}},O.prototype._read=function(I){var z=this._transformState;z.writechunk!==null&&!z.transforming?(z.transforming=!0,this._transform(z.writechunk,z.writeencoding,z.afterTransform)):z.needTransform=!0},O.prototype._destroy=function(I,z){Y.prototype._destroy.call(this,I,function(j){z(j)})};function W(I,z,j){if(z)return I.emit("error",z);if(j!=null&&I.push(j),I._writableState.length)throw new q;if(I._transformState.transforming)throw new A;return I.push(null)}}),Z8=OJ((l,g)=>{g.exports=M;var R=k0();JQ()(M,R);function M(B){if(!(this instanceof M))return new M(B);R.call(this,B)}M.prototype._transform=function(B,A,q){q(null,B)}}),X8=OJ((l,g)=>{var R;function M(j){var P=!1;return function(){P||(P=!0,j.apply(void 0,arguments))}}var B=$V().codes,A=B.ERR_MISSING_ARGS,q=B.ERR_STREAM_DESTROYED;function Y(j){if(j)throw j}function E(j){return j.setHeader&&typeof j.abort=="function"}function O(j,P,F,v){v=M(v);var S=!1;j.on("close",function(){S=!0}),R===void 0&&(R=mV()),R(j,{readable:P,writable:F},function(y){if(y)return v(y);S=!0,v()});var w=!1;return function(y){if(!S&&!w){if(w=!0,E(j))return j.abort();if(typeof j.destroy=="function")return j.destroy();v(y||new q("pipe"))}}}function N(j){j()}function W(j,P){return j.pipe(P)}function I(j){return!j.length||typeof j[j.length-1]!="function"?Y:j.pop()}function z(){for(var j=arguments.length,P=new Array(j),F=0;F<j;F++)P[F]=arguments[F];var v=I(P);if(Array.isArray(P[0])&&(P=P[0]),P.length<2)throw new A("streams");var S,w=P.map(function(y,m){var i=m<P.length-1,JJ=m>0;return O(y,i,JJ,function(VJ){S||(S=VJ),VJ&&w.forEach(N),!i&&(w.forEach(N),v(S))})});return P.reduce(W)}g.exports=z}),q8=OJ((l,g)=>{l=g.exports=C0(),l.Stream=l,l.Readable=l,l.Writable=F0(),l.Duplex=ZV(),l.Transform=k0(),l.PassThrough=Z8(),l.finished=mV(),l.pipeline=X8()}),A0=OJ((l,g)=>{var R=XQ().Buffer,M=q8().Transform,B=JQ();function A(Y,E){if(!R.isBuffer(Y)&&typeof Y!="string")throw new TypeError(E+" must be a string or a buffer")}function q(Y){M.call(this),this._block=R.allocUnsafe(Y),this._blockSize=Y,this._blockOffset=0,this._length=[0,0,0,0],this._finalized=!1}B(q,M),q.prototype._transform=function(Y,E,O){var N=null;try{this.update(Y,E)}catch(W){N=W}O(N)},q.prototype._flush=function(Y){var E=null;try{this.push(this.digest())}catch(O){E=O}Y(E)},q.prototype.update=function(Y,E){if(A(Y,"Data"),this._finalized)throw new Error("Digest already called");R.isBuffer(Y)||(Y=R.from(Y,E));for(var O=this._block,N=0;this._blockOffset+Y.length-N>=this._blockSize;){for(var W=this._blockOffset;W<this._blockSize;)O[W++]=Y[N++];this._update(),this._blockOffset=0}for(;N<Y.length;)O[this._blockOffset++]=Y[N++];for(var I=0,z=Y.length*8;z>0;++I)this._length[I]+=z,z=this._length[I]/4294967296|0,z>0&&(this._length[I]-=4294967296*z);return this},q.prototype._update=function(){throw new Error("_update is not implemented")},q.prototype.digest=function(Y){if(this._finalized)throw new Error("Digest already called");this._finalized=!0;var E=this._digest();Y!==void 0&&(E=E.toString(Y)),this._block.fill(0),this._blockOffset=0;for(var O=0;O<4;++O)this._length[O]=0;return E},q.prototype._digest=function(){throw new Error("_digest is not implemented")},g.exports=q}),uV=OJ((l,g)=>{var R=JQ(),M=A0(),B=XQ().Buffer,A=new Array(16);function q(){M.call(this,64),this._a=1732584193,this._b=4023233417,this._c=2562383102,this._d=271733878}R(q,M),q.prototype._update=function(){for(var I=A,z=0;z<16;++z)I[z]=this._block.readInt32LE(z*4);var j=this._a,P=this._b,F=this._c,v=this._d;j=E(j,P,F,v,I[0],3614090360,7),v=E(v,j,P,F,I[1],3905402710,12),F=E(F,v,j,P,I[2],606105819,17),P=E(P,F,v,j,I[3],3250441966,22),j=E(j,P,F,v,I[4],4118548399,7),v=E(v,j,P,F,I[5],1200080426,12),F=E(F,v,j,P,I[6],2821735955,17),P=E(P,F,v,j,I[7],4249261313,22),j=E(j,P,F,v,I[8],1770035416,7),v=E(v,j,P,F,I[9],2336552879,12),F=E(F,v,j,P,I[10],4294925233,17),P=E(P,F,v,j,I[11],2304563134,22),j=E(j,P,F,v,I[12],1804603682,7),v=E(v,j,P,F,I[13],4254626195,12),F=E(F,v,j,P,I[14],2792965006,17),P=E(P,F,v,j,I[15],1236535329,22),j=O(j,P,F,v,I[1],4129170786,5),v=O(v,j,P,F,I[6],3225465664,9),F=O(F,v,j,P,I[11],643717713,14),P=O(P,F,v,j,I[0],3921069994,20),j=O(j,P,F,v,I[5],3593408605,5),v=O(v,j,P,F,I[10],38016083,9),F=O(F,v,j,P,I[15],3634488961,14),P=O(P,F,v,j,I[4],3889429448,20),j=O(j,P,F,v,I[9],568446438,5),v=O(v,j,P,F,I[14],3275163606,9),F=O(F,v,j,P,I[3],4107603335,14),P=O(P,F,v,j,I[8],1163531501,20),j=O(j,P,F,v,I[13],2850285829,5),v=O(v,j,P,F,I[2],4243563512,9),F=O(F,v,j,P,I[7],1735328473,14),P=O(P,F,v,j,I[12],2368359562,20),j=N(j,P,F,v,I[5],4294588738,4),v=N(v,j,P,F,I[8],2272392833,11),F=N(F,v,j,P,I[11],1839030562,16),P=N(P,F,v,j,I[14],4259657740,23),j=N(j,P,F,v,I[1],2763975236,4),v=N(v,j,P,F,I[4],1272893353,11),F=N(F,v,j,P,I[7],4139469664,16),P=N(P,F,v,j,I[10],3200236656,23),j=N(j,P,F,v,I[13],681279174,4),v=N(v,j,P,F,I[0],3936430074,11),F=N(F,v,j,P,I[3],3572445317,16),P=N(P,F,v,j,I[6],76029189,23),j=N(j,P,F,v,I[9],3654602809,4),v=N(v,j,P,F,I[12],3873151461,11),F=N(F,v,j,P,I[15],530742520,16),P=N(P,F,v,j,I[2],3299628645,23),j=W(j,P,F,v,I[0],4096336452,6),v=W(v,j,P,F,I[7],1126891415,10),F=W(F,v,j,P,I[14],2878612391,15),P=W(P,F,v,j,I[5],4237533241,21),j=W(j,P,F,v,I[12],1700485571,6),v=W(v,j,P,F,I[3],2399980690,10),F=W(F,v,j,P,I[10],4293915773,15),P=W(P,F,v,j,I[1],2240044497,21),j=W(j,P,F,v,I[8],1873313359,6),v=W(v,j,P,F,I[15],4264355552,10),F=W(F,v,j,P,I[6],2734768916,15),P=W(P,F,v,j,I[13],1309151649,21),j=W(j,P,F,v,I[4],4149444226,6),v=W(v,j,P,F,I[11],3174756917,10),F=W(F,v,j,P,I[2],718787259,15),P=W(P,F,v,j,I[9],3951481745,21),this._a=this._a+j|0,this._b=this._b+P|0,this._c=this._c+F|0,this._d=this._d+v|0},q.prototype._digest=function(){this._block[this._blockOffset++]=128,this._blockOffset>56&&(this._block.fill(0,this._blockOffset,64),this._update(),this._blockOffset=0),this._block.fill(0,this._blockOffset,56),this._block.writeUInt32LE(this._length[0],56),this._block.writeUInt32LE(this._length[1],60),this._update();var I=B.allocUnsafe(16);return I.writeInt32LE(this._a,0),I.writeInt32LE(this._b,4),I.writeInt32LE(this._c,8),I.writeInt32LE(this._d,12),I};function Y(I,z){return I<<z|I>>>32-z}function E(I,z,j,P,F,v,S){return Y(I+(z&j|~z&P)+F+v|0,S)+z|0}function O(I,z,j,P,F,v,S){return Y(I+(z&P|j&~P)+F+v|0,S)+z|0}function N(I,z,j,P,F,v,S){return Y(I+(z^j^P)+F+v|0,S)+z|0}function W(I,z,j,P,F,v,S){return Y(I+(j^(z|~P))+F+v|0,S)+z|0}g.exports=q}),pV=OJ((l,g)=>{var R=yQ().Buffer,M=JQ(),B=A0(),A=new Array(16),q=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,7,4,13,1,10,6,15,3,12,0,9,5,2,14,11,8,3,10,14,4,9,15,8,1,2,7,0,6,13,11,5,12,1,9,11,10,0,8,12,4,13,3,7,15,14,5,6,2,4,0,5,9,7,12,2,10,14,1,3,8,11,6,15,13],Y=[5,14,7,0,9,2,11,4,13,6,15,8,1,10,3,12,6,11,3,7,0,13,5,10,14,15,8,12,4,9,1,2,15,5,1,3,7,14,6,9,11,8,12,2,10,0,4,13,8,6,4,1,3,11,15,0,5,12,2,13,9,7,10,14,12,15,10,4,1,5,8,7,6,2,13,14,0,3,9,11],E=[11,14,15,12,5,8,7,9,11,13,14,15,6,7,9,8,7,6,8,13,11,9,7,15,7,12,15,9,11,7,13,12,11,13,6,7,14,9,13,15,14,8,13,6,5,12,7,5,11,12,14,15,14,15,9,8,9,14,5,6,8,6,5,12,9,15,5,11,6,8,13,12,5,12,13,14,11,8,5,6],O=[8,9,9,11,13,15,15,5,7,7,8,11,14,14,12,6,9,13,15,7,12,8,9,11,7,7,12,7,6,15,13,11,9,7,15,11,8,6,6,14,12,13,5,14,13,13,7,5,15,5,8,11,14,14,6,14,6,9,12,9,12,5,15,8,8,5,12,9,12,5,14,6,8,13,6,5,15,13,11,11],N=[0,1518500249,1859775393,2400959708,2840853838],W=[1352829926,1548603684,1836072691,2053994217,0];function I(){B.call(this,64),this._a=1732584193,this._b=4023233417,this._c=2562383102,this._d=271733878,this._e=3285377520}M(I,B),I.prototype._update=function(){for(var w=A,y=0;y<16;++y)w[y]=this._block.readInt32LE(y*4);for(var m=this._a|0,i=this._b|0,JJ=this._c|0,VJ=this._d|0,HJ=this._e|0,o=this._a|0,jJ=this._b|0,J=this._c|0,V=this._d|0,Z=this._e|0,$=0;$<80;$+=1){var X,U;$<16?(X=j(m,i,JJ,VJ,HJ,w[q[$]],N[0],E[$]),U=S(o,jJ,J,V,Z,w[Y[$]],W[0],O[$])):$<32?(X=P(m,i,JJ,VJ,HJ,w[q[$]],N[1],E[$]),U=v(o,jJ,J,V,Z,w[Y[$]],W[1],O[$])):$<48?(X=F(m,i,JJ,VJ,HJ,w[q[$]],N[2],E[$]),U=F(o,jJ,J,V,Z,w[Y[$]],W[2],O[$])):$<64?(X=v(m,i,JJ,VJ,HJ,w[q[$]],N[3],E[$]),U=P(o,jJ,J,V,Z,w[Y[$]],W[3],O[$])):(X=S(m,i,JJ,VJ,HJ,w[q[$]],N[4],E[$]),U=j(o,jJ,J,V,Z,w[Y[$]],W[4],O[$])),m=HJ,HJ=VJ,VJ=z(JJ,10),JJ=i,i=X,o=Z,Z=V,V=z(J,10),J=jJ,jJ=U}var H=this._b+JJ+V|0;this._b=this._c+VJ+Z|0,this._c=this._d+HJ+o|0,this._d=this._e+m+jJ|0,this._e=this._a+i+J|0,this._a=H},I.prototype._digest=function(){this._block[this._blockOffset++]=128,this._blockOffset>56&&(this._block.fill(0,this._blockOffset,64),this._update(),this._blockOffset=0),this._block.fill(0,this._blockOffset,56),this._block.writeUInt32LE(this._length[0],56),this._block.writeUInt32LE(this._length[1],60),this._update();var w=R.alloc?R.alloc(20):new R(20);return w.writeInt32LE(this._a,0),w.writeInt32LE(this._b,4),w.writeInt32LE(this._c,8),w.writeInt32LE(this._d,12),w.writeInt32LE(this._e,16),w};function z(w,y){return w<<y|w>>>32-y}function j(w,y,m,i,JJ,VJ,HJ,o){return z(w+(y^m^i)+VJ+HJ|0,o)+JJ|0}function P(w,y,m,i,JJ,VJ,HJ,o){return z(w+(y&m|~y&i)+VJ+HJ|0,o)+JJ|0}function F(w,y,m,i,JJ,VJ,HJ,o){return z(w+((y|~m)^i)+VJ+HJ|0,o)+JJ|0}function v(w,y,m,i,JJ,VJ,HJ,o){return z(w+(y&i|m&~i)+VJ+HJ|0,o)+JJ|0}function S(w,y,m,i,JJ,VJ,HJ,o){return z(w+(y^(m|~i))+VJ+HJ|0,o)+JJ|0}g.exports=I}),XV=OJ((l,g)=>{var R=XQ().Buffer;function M(B,A){this._block=R.alloc(B),this._finalSize=A,this._blockSize=B,this._len=0}M.prototype.update=function(B,A){typeof B=="string"&&(A=A||"utf8",B=R.from(B,A));for(var q=this._block,Y=this._blockSize,E=B.length,O=this._len,N=0;N<E;){for(var W=O%Y,I=Math.min(E-N,Y-W),z=0;z<I;z++)q[W+z]=B[N+z];O+=I,N+=I,O%Y===0&&this._update(q)}return this._len+=E,this},M.prototype.digest=function(B){var A=this._len%this._blockSize;this._block[A]=128,this._block.fill(0,A+1),A>=this._finalSize&&(this._update(this._block),this._block.fill(0));var q=this._len*8;if(q<=4294967295)this._block.writeUInt32BE(q,this._blockSize-4);else{var Y=(q&4294967295)>>>0,E=(q-Y)/4294967296;this._block.writeUInt32BE(E,this._blockSize-8),this._block.writeUInt32BE(Y,this._blockSize-4)}this._update(this._block);var O=this._hash();return B?O.toString(B):O},M.prototype._update=function(){throw new Error("_update must be implemented by subclass")},g.exports=M}),G8=OJ((l,g)=>{var R=JQ(),M=XV(),B=XQ().Buffer,A=[1518500249,1859775393,-1894007588,-899497514],q=new Array(80);function Y(){this.init(),this._w=q,M.call(this,64,56)}R(Y,M),Y.prototype.init=function(){return this._a=1732584193,this._b=4023233417,this._c=2562383102,this._d=271733878,this._e=3285377520,this};function E(W){return W<<5|W>>>27}function O(W){return W<<30|W>>>2}function N(W,I,z,j){return W===0?I&z|~I&j:W===2?I&z|I&j|z&j:I^z^j}Y.prototype._update=function(W){for(var I=this._w,z=this._a|0,j=this._b|0,P=this._c|0,F=this._d|0,v=this._e|0,S=0;S<16;++S)I[S]=W.readInt32BE(S*4);for(;S<80;++S)I[S]=I[S-3]^I[S-8]^I[S-14]^I[S-16];for(var w=0;w<80;++w){var y=~~(w/20),m=E(z)+N(y,j,P,F)+v+I[w]+A[y]|0;v=F,F=P,P=O(j),j=z,z=m}this._a=z+this._a|0,this._b=j+this._b|0,this._c=P+this._c|0,this._d=F+this._d|0,this._e=v+this._e|0},Y.prototype._hash=function(){var W=B.allocUnsafe(20);return W.writeInt32BE(this._a|0,0),W.writeInt32BE(this._b|0,4),W.writeInt32BE(this._c|0,8),W.writeInt32BE(this._d|0,12),W.writeInt32BE(this._e|0,16),W},g.exports=Y}),K8=OJ((l,g)=>{var R=JQ(),M=XV(),B=XQ().Buffer,A=[1518500249,1859775393,-1894007588,-899497514],q=new Array(80);function Y(){this.init(),this._w=q,M.call(this,64,56)}R(Y,M),Y.prototype.init=function(){return this._a=1732584193,this._b=4023233417,this._c=2562383102,this._d=271733878,this._e=3285377520,this};function E(I){return I<<1|I>>>31}function O(I){return I<<5|I>>>27}function N(I){return I<<30|I>>>2}function W(I,z,j,P){return I===0?z&j|~z&P:I===2?z&j|z&P|j&P:z^j^P}Y.prototype._update=function(I){for(var z=this._w,j=this._a|0,P=this._b|0,F=this._c|0,v=this._d|0,S=this._e|0,w=0;w<16;++w)z[w]=I.readInt32BE(w*4);for(;w<80;++w)z[w]=E(z[w-3]^z[w-8]^z[w-14]^z[w-16]);for(var y=0;y<80;++y){var m=~~(y/20),i=O(j)+W(m,P,F,v)+S+z[y]+A[m]|0;S=v,v=F,F=N(P),P=j,j=i}this._a=j+this._a|0,this._b=P+this._b|0,this._c=F+this._c|0,this._d=v+this._d|0,this._e=S+this._e|0},Y.prototype._hash=function(){var I=B.allocUnsafe(20);return I.writeInt32BE(this._a|0,0),I.writeInt32BE(this._b|0,4),I.writeInt32BE(this._c|0,8),I.writeInt32BE(this._d|0,12),I.writeInt32BE(this._e|0,16),I},g.exports=Y}),S0=OJ((l,g)=>{var R=JQ(),M=XV(),B=XQ().Buffer,A=[1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298],q=new Array(64);function Y(){this.init(),this._w=q,M.call(this,64,56)}R(Y,M),Y.prototype.init=function(){return this._a=1779033703,this._b=3144134277,this._c=1013904242,this._d=2773480762,this._e=1359893119,this._f=2600822924,this._g=528734635,this._h=1541459225,this};function E(j,P,F){return F^j&(P^F)}function O(j,P,F){return j&P|F&(j|P)}function N(j){return(j>>>2|j<<30)^(j>>>13|j<<19)^(j>>>22|j<<10)}function W(j){return(j>>>6|j<<26)^(j>>>11|j<<21)^(j>>>25|j<<7)}function I(j){return(j>>>7|j<<25)^(j>>>18|j<<14)^j>>>3}function z(j){return(j>>>17|j<<15)^(j>>>19|j<<13)^j>>>10}Y.prototype._update=function(j){for(var P=this._w,F=this._a|0,v=this._b|0,S=this._c|0,w=this._d|0,y=this._e|0,m=this._f|0,i=this._g|0,JJ=this._h|0,VJ=0;VJ<16;++VJ)P[VJ]=j.readInt32BE(VJ*4);for(;VJ<64;++VJ)P[VJ]=z(P[VJ-2])+P[VJ-7]+I(P[VJ-15])+P[VJ-16]|0;for(var HJ=0;HJ<64;++HJ){var o=JJ+W(y)+E(y,m,i)+A[HJ]+P[HJ]|0,jJ=N(F)+O(F,v,S)|0;JJ=i,i=m,m=y,y=w+o|0,w=S,S=v,v=F,F=o+jJ|0}this._a=F+this._a|0,this._b=v+this._b|0,this._c=S+this._c|0,this._d=w+this._d|0,this._e=y+this._e|0,this._f=m+this._f|0,this._g=i+this._g|0,this._h=JJ+this._h|0},Y.prototype._hash=function(){var j=B.allocUnsafe(32);return j.writeInt32BE(this._a,0),j.writeInt32BE(this._b,4),j.writeInt32BE(this._c,8),j.writeInt32BE(this._d,12),j.writeInt32BE(this._e,16),j.writeInt32BE(this._f,20),j.writeInt32BE(this._g,24),j.writeInt32BE(this._h,28),j},g.exports=Y}),U8=OJ((l,g)=>{var R=JQ(),M=S0(),B=XV(),A=XQ().Buffer,q=new Array(64);function Y(){this.init(),this._w=q,B.call(this,64,56)}R(Y,M),Y.prototype.init=function(){return this._a=3238371032,this._b=914150663,this._c=812702999,this._d=4144912697,this._e=4290775857,this._f=1750603025,this._g=1694076839,this._h=3204075428,this},Y.prototype._hash=function(){var E=A.allocUnsafe(28);return E.writeInt32BE(this._a,0),E.writeInt32BE(this._b,4),E.writeInt32BE(this._c,8),E.writeInt32BE(this._d,12),E.writeInt32BE(this._e,16),E.writeInt32BE(this._f,20),E.writeInt32BE(this._g,24),E},g.exports=Y}),x0=OJ((l,g)=>{var R=JQ(),M=XV(),B=XQ().Buffer,A=[1116352408,3609767458,1899447441,602891725,3049323471,3964484399,3921009573,2173295548,961987163,4081628472,1508970993,3053834265,2453635748,2937671579,2870763221,3664609560,3624381080,2734883394,310598401,1164996542,607225278,1323610764,1426881987,3590304994,1925078388,4068182383,2162078206,991336113,2614888103,633803317,3248222580,3479774868,3835390401,2666613458,4022224774,944711139,264347078,2341262773,604807628,2007800933,770255983,1495990901,1249150122,1856431235,1555081692,3175218132,1996064986,2198950837,2554220882,3999719339,2821834349,766784016,2952996808,2566594879,3210313671,3203337956,3336571891,1034457026,3584528711,2466948901,113926993,3758326383,338241895,168717936,666307205,1188179964,773529912,1546045734,1294757372,1522805485,1396182291,2643833823,1695183700,2343527390,1986661051,1014477480,2177026350,1206759142,2456956037,344077627,2730485921,1290863460,2820302411,3158454273,3259730800,3505952657,3345764771,106217008,3516065817,3606008344,3600352804,1432725776,4094571909,1467031594,275423344,851169720,430227734,3100823752,506948616,1363258195,659060556,3750685593,883997877,3785050280,958139571,3318307427,1322822218,3812723403,1537002063,2003034995,1747873779,3602036899,1955562222,1575990012,2024104815,1125592928,2227730452,2716904306,2361852424,442776044,2428436474,593698344,2756734187,3733110249,3204031479,2999351573,3329325298,3815920427,3391569614,3928383900,3515267271,566280711,3940187606,3454069534,4118630271,4000239992,116418474,1914138554,174292421,2731055270,289380356,3203993006,460393269,320620315,685471733,587496836,852142971,1086792851,1017036298,365543100,1126000580,2618297676,1288033470,3409855158,1501505948,4234509866,1607167915,987167468,1816402316,1246189591],q=new Array(160);function Y(){this.init(),this._w=q,M.call(this,128,112)}R(Y,M),Y.prototype.init=function(){return this._ah=1779033703,this._bh=3144134277,this._ch=1013904242,this._dh=2773480762,this._eh=1359893119,this._fh=2600822924,this._gh=528734635,this._hh=1541459225,this._al=4089235720,this._bl=2227873595,this._cl=4271175723,this._dl=1595750129,this._el=2917565137,this._fl=725511199,this._gl=4215389547,this._hl=327033209,this};function E(v,S,w){return w^v&(S^w)}function O(v,S,w){return v&S|w&(v|S)}function N(v,S){return(v>>>28|S<<4)^(S>>>2|v<<30)^(S>>>7|v<<25)}function W(v,S){return(v>>>14|S<<18)^(v>>>18|S<<14)^(S>>>9|v<<23)}function I(v,S){return(v>>>1|S<<31)^(v>>>8|S<<24)^v>>>7}function z(v,S){return(v>>>1|S<<31)^(v>>>8|S<<24)^(v>>>7|S<<25)}function j(v,S){return(v>>>19|S<<13)^(S>>>29|v<<3)^v>>>6}function P(v,S){return(v>>>19|S<<13)^(S>>>29|v<<3)^(v>>>6|S<<26)}function F(v,S){return v>>>0<S>>>0?1:0}Y.prototype._update=function(v){for(var S=this._w,w=this._ah|0,y=this._bh|0,m=this._ch|0,i=this._dh|0,JJ=this._eh|0,VJ=this._fh|0,HJ=this._gh|0,o=this._hh|0,jJ=this._al|0,J=this._bl|0,V=this._cl|0,Z=this._dl|0,$=this._el|0,X=this._fl|0,U=this._gl|0,H=this._hl|0,G=0;G<32;G+=2)S[G]=v.readInt32BE(G*4),S[G+1]=v.readInt32BE(G*4+4);for(;G<160;G+=2){var Q=S[G-30],K=S[G-30+1],k=I(Q,K),L=z(K,Q);Q=S[G-4],K=S[G-4+1];var _=j(Q,K),t=P(K,Q),QJ=S[G-14],GJ=S[G-14+1],n=S[G-32],p=S[G-32+1],e=L+GJ|0,PJ=k+QJ+F(e,L)|0;e=e+t|0,PJ=PJ+_+F(e,t)|0,e=e+p|0,PJ=PJ+n+F(e,p)|0,S[G]=PJ,S[G+1]=e}for(var XJ=0;XJ<160;XJ+=2){PJ=S[XJ],e=S[XJ+1];var WJ=O(w,y,m),b=O(jJ,J,V),C=N(w,jJ),h=N(jJ,w),$J=W(JJ,$),qJ=W($,JJ),ZJ=A[XJ],mJ=A[XJ+1],BJ=E(JJ,VJ,HJ),TJ=E($,X,U),dJ=H+qJ|0,LJ=o+$J+F(dJ,H)|0;dJ=dJ+TJ|0,LJ=LJ+BJ+F(dJ,TJ)|0,dJ=dJ+mJ|0,LJ=LJ+ZJ+F(dJ,mJ)|0,dJ=dJ+e|0,LJ=LJ+PJ+F(dJ,e)|0;var IJ=h+b|0,$Q=C+WJ+F(IJ,h)|0;o=HJ,H=U,HJ=VJ,U=X,VJ=JJ,X=$,$=Z+dJ|0,JJ=i+LJ+F($,Z)|0,i=m,Z=V,m=y,V=J,y=w,J=jJ,jJ=dJ+IJ|0,w=LJ+$Q+F(jJ,dJ)|0}this._al=this._al+jJ|0,this._bl=this._bl+J|0,this._cl=this._cl+V|0,this._dl=this._dl+Z|0,this._el=this._el+$|0,this._fl=this._fl+X|0,this._gl=this._gl+U|0,this._hl=this._hl+H|0,this._ah=this._ah+w+F(this._al,jJ)|0,this._bh=this._bh+y+F(this._bl,J)|0,this._ch=this._ch+m+F(this._cl,V)|0,this._dh=this._dh+i+F(this._dl,Z)|0,this._eh=this._eh+JJ+F(this._el,$)|0,this._fh=this._fh+VJ+F(this._fl,X)|0,this._gh=this._gh+HJ+F(this._gl,U)|0,this._hh=this._hh+o+F(this._hl,H)|0},Y.prototype._hash=function(){var v=B.allocUnsafe(64);function S(w,y,m){v.writeInt32BE(w,m),v.writeInt32BE(y,m+4)}return S(this._ah,this._al,0),S(this._bh,this._bl,8),S(this._ch,this._cl,16),S(this._dh,this._dl,24),S(this._eh,this._el,32),S(this._fh,this._fl,40),S(this._gh,this._gl,48),S(this._hh,this._hl,56),v},g.exports=Y}),H8=OJ((l,g)=>{var R=JQ(),M=x0(),B=XV(),A=XQ().Buffer,q=new Array(160);function Y(){this.init(),this._w=q,B.call(this,128,112)}R(Y,M),Y.prototype.init=function(){return this._ah=3418070365,this._bh=1654270250,this._ch=2438529370,this._dh=355462360,this._eh=1731405415,this._fh=2394180231,this._gh=3675008525,this._hh=1203062813,this._al=3238371032,this._bl=914150663,this._cl=812702999,this._dl=4144912697,this._el=4290775857,this._fl=1750603025,this._gl=1694076839,this._hl=3204075428,this},Y.prototype._hash=function(){var E=A.allocUnsafe(48);function O(N,W,I){E.writeInt32BE(N,I),E.writeInt32BE(W,I+4)}return O(this._ah,this._al,0),O(this._bh,this._bl,8),O(this._ch,this._cl,16),O(this._dh,this._dl,24),O(this._eh,this._el,32),O(this._fh,this._fl,40),E},g.exports=Y}),iV=OJ((R,g)=>{var R=g.exports=function(M){M=M.toLowerCase();var B=R[M];if(!B)throw new Error(M+" is not supported (we accept pull requests)");return new B};R.sha=G8(),R.sha1=K8(),R.sha224=U8(),R.sha256=S0(),R.sha384=H8(),R.sha512=x0()}),bQ=OJ((l,g)=>{g.exports={ArrayIsArray(R){return Array.isArray(R)},ArrayPrototypeIncludes(R,M){return R.includes(M)},ArrayPrototypeIndexOf(R,M){return R.indexOf(M)},ArrayPrototypeJoin(R,M){return R.join(M)},ArrayPrototypeMap(R,M){return R.map(M)},ArrayPrototypePop(R,M){return R.pop(M)},ArrayPrototypePush(R,M){return R.push(M)},ArrayPrototypeSlice(R,M,B){return R.slice(M,B)},Error,FunctionPrototypeCall(R,M,...B){return R.call(M,...B)},FunctionPrototypeSymbolHasInstance(R,M){return Function.prototype[Symbol.hasInstance].call(R,M)},MathFloor:Math.floor,Number,NumberIsInteger:Number.isInteger,NumberIsNaN:Number.isNaN,NumberMAX_SAFE_INTEGER:Number.MAX_SAFE_INTEGER,NumberMIN_SAFE_INTEGER:Number.MIN_SAFE_INTEGER,NumberParseInt:Number.parseInt,ObjectDefineProperties(R,M){return Object.defineProperties(R,M)},ObjectDefineProperty(R,M,B){return Object.defineProperty(R,M,B)},ObjectGetOwnPropertyDescriptor(R,M){return Object.getOwnPropertyDescriptor(R,M)},ObjectKeys(R){return Object.keys(R)},ObjectSetPrototypeOf(R,M){return Object.setPrototypeOf(R,M)},Promise,PromisePrototypeCatch(R,M){return R.catch(M)},PromisePrototypeThen(R,M,B){return R.then(M,B)},PromiseReject(R){return Promise.reject(R)},ReflectApply:Reflect.apply,RegExpPrototypeTest(R,M){return R.test(M)},SafeSet:Set,String,StringPrototypeSlice(R,M,B){return R.slice(M,B)},StringPrototypeToLowerCase(R){return R.toLowerCase()},StringPrototypeToUpperCase(R){return R.toUpperCase()},StringPrototypeTrim(R){return R.trim()},Symbol,SymbolAsyncIterator:Symbol.asyncIterator,SymbolHasInstance:Symbol.hasInstance,SymbolIterator:Symbol.iterator,TypedArrayPrototypeSet(R,M,B){return R.set(M,B)},Uint8Array}}),iQ=OJ((l,g)=>{var R=yQ(),M=Object.getPrototypeOf(async function(){}).constructor,B=globalThis.Blob||R.Blob,A=typeof B<"u"?function(Y){return Y instanceof B}:function(Y){return!1},q=class extends Error{constructor(Y){if(!Array.isArray(Y))throw new TypeError(`Expected input to be an Array, got ${typeof Y}`);let E="";for(let O=0;O<Y.length;O++)E+=`    ${Y[O].stack}
+`;super(E),this.name="AggregateError",this.errors=Y}};g.exports={AggregateError:q,kEmptyObject:Object.freeze({}),once(Y){let E=!1;return function(...O){E||(E=!0,Y.apply(this,O))}},createDeferredPromise:function(){let Y,E;return{promise:new Promise((O,N)=>{Y=O,E=N}),resolve:Y,reject:E}},promisify(Y){return new Promise((E,O)=>{Y((N,...W)=>N?O(N):E(...W))})},debuglog(){return function(){}},format(Y,...E){return Y.replace(/%([sdifj])/g,function(...[O,N]){let W=E.shift();return N==="f"?W.toFixed(6):N==="j"?JSON.stringify(W):N==="s"&&typeof W=="object"?`${W.constructor!==Object?W.constructor.name:""} {}`.trim():W.toString()})},inspect(Y){switch(typeof Y){case"string":if(Y.includes("'"))if(Y.includes('"')){if(!Y.includes("`")&&!Y.includes("${"))return`\`${Y}\``}else return`"${Y}"`;return`'${Y}'`;case"number":return isNaN(Y)?"NaN":Object.is(Y,-0)?String(Y):Y;case"bigint":return`${String(Y)}n`;case"boolean":case"undefined":return String(Y);case"object":return"{}"}},types:{isAsyncFunction(Y){return Y instanceof M},isArrayBufferView(Y){return ArrayBuffer.isView(Y)}},isBlob:A},g.exports.promisify.custom=Symbol.for("nodejs.util.promisify.custom")}),lV=OJ((l,g)=>{var{AbortController:R,AbortSignal:M}=typeof self<"u"?self:typeof window<"u"?window:void 0;g.exports=R,g.exports.AbortSignal=M,g.exports.default=R}),gQ=OJ((l,g)=>{var{format:R,inspect:M,AggregateError:B}=iQ(),A=globalThis.AggregateError||B,q=Symbol("kIsNodeError"),Y=["string","function","number","object","Function","Object","boolean","bigint","symbol"],E=/^([A-Z][a-z0-9]*)+$/,O="__node_internal_",N={};function W(S,w){if(!S)throw new N.ERR_INTERNAL_ASSERTION(w)}function I(S){let w="",y=S.length,m=S[0]==="-"?1:0;for(;y>=m+4;y-=3)w=`_${S.slice(y-3,y)}${w}`;return`${S.slice(0,y)}${w}`}function z(S,w,y){if(typeof w=="function")return W(w.length<=y.length,`Code: ${S}; The provided arguments length (${y.length}) does not match the required ones (${w.length}).`),w(...y);let m=(w.match(/%[dfijoOs]/g)||[]).length;return W(m===y.length,`Code: ${S}; The provided arguments length (${y.length}) does not match the required ones (${m}).`),y.length===0?w:R(w,...y)}function j(S,w,y){y||(y=Error);class m extends y{constructor(...i){super(z(S,w,i))}toString(){return`${this.name} [${S}]: ${this.message}`}}Object.defineProperties(m.prototype,{name:{value:y.name,writable:!0,enumerable:!1,configurable:!0},toString:{value(){return`${this.name} [${S}]: ${this.message}`},writable:!0,enumerable:!1,configurable:!0}}),m.prototype.code=S,m.prototype[q]=!0,N[S]=m}function P(S){let w=O+S.name;return Object.defineProperty(S,"name",{value:w}),S}function F(S,w){if(S&&w&&S!==w){if(Array.isArray(w.errors))return w.errors.push(S),w;let y=new A([w,S],w.message);return y.code=w.code,y}return S||w}var v=class extends Error{constructor(S="The operation was aborted",w=void 0){if(w!==void 0&&typeof w!="object")throw new N.ERR_INVALID_ARG_TYPE("options","Object",w);super(S,w),this.code="ABORT_ERR",this.name="AbortError"}};j("ERR_ASSERTION","%s",Error),j("ERR_INVALID_ARG_TYPE",(S,w,y)=>{W(typeof S=="string","'name' must be a string"),Array.isArray(w)||(w=[w]);let m="The ";S.endsWith(" argument")?m+=`${S} `:m+=`"${S}" ${S.includes(".")?"property":"argument"} `,m+="must be ";let i=[],JJ=[],VJ=[];for(let o of w)W(typeof o=="string","All expected entries have to be of type string"),Y.includes(o)?i.push(o.toLowerCase()):E.test(o)?JJ.push(o):(W(o!=="object",'The value "object" should be written as "Object"'),VJ.push(o));if(JJ.length>0){let o=i.indexOf("object");o!==-1&&(i.splice(i,o,1),JJ.push("Object"))}if(i.length>0){switch(i.length){case 1:m+=`of type ${i[0]}`;break;case 2:m+=`one of type ${i[0]} or ${i[1]}`;break;default:{let o=i.pop();m+=`one of type ${i.join(", ")}, or ${o}`}}(JJ.length>0||VJ.length>0)&&(m+=" or ")}if(JJ.length>0){switch(JJ.length){case 1:m+=`an instance of ${JJ[0]}`;break;case 2:m+=`an instance of ${JJ[0]} or ${JJ[1]}`;break;default:{let o=JJ.pop();m+=`an instance of ${JJ.join(", ")}, or ${o}`}}VJ.length>0&&(m+=" or ")}switch(VJ.length){case 0:break;case 1:VJ[0].toLowerCase()!==VJ[0]&&(m+="an "),m+=`${VJ[0]}`;break;case 2:m+=`one of ${VJ[0]} or ${VJ[1]}`;break;default:{let o=VJ.pop();m+=`one of ${VJ.join(", ")}, or ${o}`}}if(y==null)m+=`. Received ${y}`;else if(typeof y=="function"&&y.name)m+=`. Received function ${y.name}`;else if(typeof y=="object"){var HJ;(HJ=y.constructor)!==null&&HJ!==void 0&&HJ.name?m+=`. Received an instance of ${y.constructor.name}`:m+=`. Received ${M(y,{depth:-1})}`}else{let o=M(y,{colors:!1});o.length>25&&(o=`${o.slice(0,25)}...`),m+=`. Received type ${typeof y} (${o})`}return m},TypeError),j("ERR_INVALID_ARG_VALUE",(S,w,y="is invalid")=>{let m=M(w);return m.length>128&&(m=m.slice(0,128)+"..."),`The ${S.includes(".")?"property":"argument"} '${S}' ${y}. Received ${m}`},TypeError),j("ERR_INVALID_RETURN_VALUE",(S,w,y)=>{var m;let i=y!=null&&(m=y.constructor)!==null&&m!==void 0&&m.name?`instance of ${y.constructor.name}`:`type ${typeof y}`;return`Expected ${S} to be returned from the "${w}" function but got ${i}.`},TypeError),j("ERR_MISSING_ARGS",(...S)=>{W(S.length>0,"At least one arg needs to be specified");let w,y=S.length;switch(S=(Array.isArray(S)?S:[S]).map((m)=>`"${m}"`).join(" or "),y){case 1:w+=`The ${S[0]} argument`;break;case 2:w+=`The ${S[0]} and ${S[1]} arguments`;break;default:{let m=S.pop();w+=`The ${S.join(", ")}, and ${m} arguments`}break}return`${w} must be specified`},TypeError),j("ERR_OUT_OF_RANGE",(S,w,y)=>{W(w,'Missing "range" argument');let m;return Number.isInteger(y)&&Math.abs(y)>4294967296?m=I(String(y)):typeof y=="bigint"?(m=String(y),(y>2n**32n||y<-(2n**32n))&&(m=I(m)),m+="n"):m=M(y),`The value of "${S}" is out of range. It must be ${w}. Received ${m}`},RangeError),j("ERR_MULTIPLE_CALLBACK","Callback called multiple times",Error),j("ERR_METHOD_NOT_IMPLEMENTED","The %s method is not implemented",Error),j("ERR_STREAM_ALREADY_FINISHED","Cannot call %s after a stream was finished",Error),j("ERR_STREAM_CANNOT_PIPE","Cannot pipe, not readable",Error),j("ERR_STREAM_DESTROYED","Cannot call %s after a stream was destroyed",Error),j("ERR_STREAM_NULL_VALUES","May not write null values to stream",TypeError),j("ERR_STREAM_PREMATURE_CLOSE","Premature close",Error),j("ERR_STREAM_PUSH_AFTER_EOF","stream.push() after EOF",Error),j("ERR_STREAM_UNSHIFT_AFTER_END_EVENT","stream.unshift() after end event",Error),j("ERR_STREAM_WRITE_AFTER_END","write after end",Error),j("ERR_UNKNOWN_ENCODING","Unknown encoding: %s",TypeError),g.exports={AbortError:v,aggregateTwoErrors:P(F),hideStackFrames:P,codes:N}}),FV=OJ((l,g)=>{var{ArrayIsArray:R,ArrayPrototypeIncludes:M,ArrayPrototypeJoin:B,ArrayPrototypeMap:A,NumberIsInteger:q,NumberIsNaN:Y,NumberMAX_SAFE_INTEGER:E,NumberMIN_SAFE_INTEGER:O,NumberParseInt:N,ObjectPrototypeHasOwnProperty:W,RegExpPrototypeExec:I,String:z,StringPrototypeToUpperCase:j,StringPrototypeTrim:P}=bQ(),{hideStackFrames:F,codes:{ERR_SOCKET_BAD_PORT:v,ERR_INVALID_ARG_TYPE:S,ERR_INVALID_ARG_VALUE:w,ERR_OUT_OF_RANGE:y,ERR_UNKNOWN_SIGNAL:m}}=gQ(),{normalizeEncoding:i}=iQ(),{isAsyncFunction:JJ,isArrayBufferView:VJ}=iQ().types,HJ={};function o(b){return b===(b|0)}function jJ(b){return b===b>>>0}var J=/^[0-7]+$/,V="must be a 32-bit unsigned integer or an octal string";function Z(b,C,h){if(typeof b>"u"&&(b=h),typeof b=="string"){if(I(J,b)===null)throw new w(C,b,V);b=N(b,8)}return U(b,C),b}var $=F((b,C,h=O,$J=E)=>{if(typeof b!="number")throw new S(C,"number",b);if(!q(b))throw new y(C,"an integer",b);if(b<h||b>$J)throw new y(C,`>= ${h} && <= ${$J}`,b)}),X=F((b,C,h=-2147483648,$J=2147483647)=>{if(typeof b!="number")throw new S(C,"number",b);if(!q(b))throw new y(C,"an integer",b);if(b<h||b>$J)throw new y(C,`>= ${h} && <= ${$J}`,b)}),U=F((b,C,h=!1)=>{if(typeof b!="number")throw new S(C,"number",b);if(!q(b))throw new y(C,"an integer",b);let $J=h?1:0,qJ=4294967295;if(b<$J||b>qJ)throw new y(C,`>= ${$J} && <= ${qJ}`,b)});function H(b,C){if(typeof b!="string")throw new S(C,"string",b)}function G(b,C,h=void 0,$J){if(typeof b!="number")throw new S(C,"number",b);if(h!=null&&b<h||$J!=null&&b>$J||(h!=null||$J!=null)&&Y(b))throw new y(C,`${h!=null?`>= ${h}`:""}${h!=null&&$J!=null?" && ":""}${$J!=null?`<= ${$J}`:""}`,b)}var Q=F((b,C,h)=>{if(!M(h,b)){let $J=B(A(h,(ZJ)=>typeof ZJ=="string"?`'${ZJ}'`:z(ZJ)),", "),qJ="must be one of: "+$J;throw new w(C,b,qJ)}});function K(b,C){if(typeof b!="boolean")throw new S(C,"boolean",b)}function k(b,C,h){return b==null||!W(b,C)?h:b[C]}var L=F((b,C,h=null)=>{let $J=k(h,"allowArray",!1),qJ=k(h,"allowFunction",!1);if(!k(h,"nullable",!1)&&b===null||!$J&&R(b)||typeof b!="object"&&(!qJ||typeof b!="function"))throw new S(C,"Object",b)}),_=F((b,C,h=0)=>{if(!R(b))throw new S(C,"Array",b);if(b.length<h){let $J=`must be longer than ${h}`;throw new w(C,b,$J)}});function t(b,C="signal"){if(H(b,C),HJ[b]===void 0)throw HJ[j(b)]!==void 0?new m(b+" (signals must use all capital letters)"):new m(b)}var QJ=F((b,C="buffer")=>{if(!VJ(b))throw new S(C,["Buffer","TypedArray","DataView"],b)});function GJ(b,C){let h=i(C),$J=b.length;if(h==="hex"&&$J%2!==0)throw new w("encoding",C,`is invalid for data of length ${$J}`)}function n(b,C="Port",h=!0){if(typeof b!="number"&&typeof b!="string"||typeof b=="string"&&P(b).length===0||+b!==+b>>>0||b>65535||b===0&&!h)throw new v(C,b,h);return b|0}var p=F((b,C)=>{if(b!==void 0&&(b===null||typeof b!="object"||!("aborted"in b)))throw new S(C,"AbortSignal",b)}),e=F((b,C)=>{if(typeof b!="function")throw new S(C,"Function",b)}),PJ=F((b,C)=>{if(typeof b!="function"||JJ(b))throw new S(C,"Function",b)}),XJ=F((b,C)=>{if(b!==void 0)throw new S(C,"undefined",b)});function WJ(b,C,h){if(!M(h,b))throw new S(C,`('${B(h,"|")}')`,b)}g.exports={isInt32:o,isUint32:jJ,parseFileMode:Z,validateArray:_,validateBoolean:K,validateBuffer:QJ,validateEncoding:GJ,validateFunction:e,validateInt32:X,validateInteger:$,validateNumber:G,validateObject:L,validateOneOf:Q,validatePlainFunction:PJ,validatePort:n,validateSignalName:t,validateString:H,validateUint32:U,validateUndefined:XJ,validateUnion:WJ,validateAbortSignal:p}}),w0=OJ((l,g)=>{var R=g.exports={},M,B;function A(){throw new Error("setTimeout has not been defined")}function q(){throw new Error("clearTimeout has not been defined")}(function(){try{typeof setTimeout=="function"?M=setTimeout:M=A}catch{M=A}try{typeof clearTimeout=="function"?B=clearTimeout:B=q}catch{B=q}})();function Y(v){if(M===setTimeout)return setTimeout(v,0);if((M===A||!M)&&setTimeout)return M=setTimeout,setTimeout(v,0);try{return M(v,0)}catch{try{return M.call(null,v,0)}catch{return M.call(this,v,0)}}}function E(v){if(B===clearTimeout)return clearTimeout(v);if((B===q||!B)&&clearTimeout)return B=clearTimeout,clearTimeout(v);try{return B(v)}catch{try{return B.call(null,v)}catch{return B.call(this,v)}}}var O=[],N=!1,W,I=-1;function z(){!N||!W||(N=!1,W.length?O=W.concat(O):I=-1,O.length&&j())}function j(){if(!N){var v=Y(z);N=!0;for(var S=O.length;S;){for(W=O,O=[];++I<S;)W&&W[I].run();I=-1,S=O.length}W=null,N=!1,E(v)}}R.nextTick=function(v){var S=new Array(arguments.length-1);if(arguments.length>1)for(var w=1;w<arguments.length;w++)S[w-1]=arguments[w];O.push(new P(v,S)),O.length===1&&!N&&Y(j)};function P(v,S){this.fun=v,this.array=S}P.prototype.run=function(){this.fun.apply(null,this.array)},R.title="browser",R.browser=!0,R.env={},R.argv=[],R.version="",R.versions={};function F(){}R.on=F,R.addListener=F,R.once=F,R.off=F,R.removeListener=F,R.removeAllListeners=F,R.emit=F,R.prependListener=F,R.prependOnceListener=F,R.listeners=function(v){return[]},R.binding=function(v){throw new Error("process.binding is not supported")},R.cwd=function(){return"/"},R.chdir=function(v){throw new Error("process.chdir is not supported")},R.umask=function(){return 0}}),lQ={},RV(lQ,{default:()=>W8}),aQ=cV(()=>{fV(lQ,oQ(w0())),W8=oQ(w0())}),tQ=OJ((l,g)=>{var{Symbol:R,SymbolAsyncIterator:M,SymbolIterator:B}=bQ(),A=R("kDestroyed"),q=R("kIsErrored"),Y=R("kIsReadable"),E=R("kIsDisturbed");function O($,X=!1){var U;return!!($&&typeof $.pipe=="function"&&typeof $.on=="function"&&(!X||typeof $.pause=="function"&&typeof $.resume=="function")&&(!$._writableState||((U=$._readableState)===null||U===void 0?void 0:U.readable)!==!1)&&(!$._writableState||$._readableState))}function N($){var X;return!!($&&typeof $.write=="function"&&typeof $.on=="function"&&(!$._readableState||((X=$._writableState)===null||X===void 0?void 0:X.writable)!==!1))}function W($){return!!($&&typeof $.pipe=="function"&&$._readableState&&typeof $.on=="function"&&typeof $.write=="function")}function I($){return $&&($._readableState||$._writableState||typeof $.write=="function"&&typeof $.on=="function"||typeof $.pipe=="function"&&typeof $.on=="function")}function z($,X){return $==null?!1:X===!0?typeof $[M]=="function":X===!1?typeof $[B]=="function":typeof $[M]=="function"||typeof $[B]=="function"}function j($){if(!I($))return null;let{_writableState:X,_readableState:U}=$,H=X||U;return!!($.destroyed||$[A]||H!=null&&H.destroyed)}function P($){if(!N($))return null;if($.writableEnded===!0)return!0;let X=$._writableState;return X!=null&&X.errored?!1:typeof X?.ended!="boolean"?null:X.ended}function F($,X){if(!N($))return null;if($.writableFinished===!0)return!0;let U=$._writableState;return U!=null&&U.errored?!1:typeof U?.finished!="boolean"?null:!!(U.finished||X===!1&&U.ended===!0&&U.length===0)}function v($){if(!O($))return null;if($.readableEnded===!0)return!0;let X=$._readableState;return!X||X.errored?!1:typeof X?.ended!="boolean"?null:X.ended}function S($,X){if(!O($))return null;let U=$._readableState;return U!=null&&U.errored?!1:typeof U?.endEmitted!="boolean"?null:!!(U.endEmitted||X===!1&&U.ended===!0&&U.length===0)}function w($){return $&&$[Y]!=null?$[Y]:typeof $?.readable!="boolean"?null:j($)?!1:O($)&&$.readable&&!S($)}function y($){return typeof $?.writable!="boolean"?null:j($)?!1:N($)&&$.writable&&!P($)}function m($,X){return I($)?j($)?!0:!(X?.readable!==!1&&w($)||X?.writable!==!1&&y($)):null}function i($){var X,U;return I($)?$.writableErrored?$.writableErrored:(X=(U=$._writableState)===null||U===void 0?void 0:U.errored)!==null&&X!==void 0?X:null:null}function JJ($){var X,U;return I($)?$.readableErrored?$.readableErrored:(X=(U=$._readableState)===null||U===void 0?void 0:U.errored)!==null&&X!==void 0?X:null:null}function VJ($){if(!I($))return null;if(typeof $.closed=="boolean")return $.closed;let{_writableState:X,_readableState:U}=$;return typeof X?.closed=="boolean"||typeof U?.closed=="boolean"?X?.closed||U?.closed:typeof $._closed=="boolean"&&HJ($)?$._closed:null}function HJ($){return typeof $._closed=="boolean"&&typeof $._defaultKeepAlive=="boolean"&&typeof $._removedConnection=="boolean"&&typeof $._removedContLen=="boolean"}function o($){return typeof $._sent100=="boolean"&&HJ($)}function jJ($){var X;return typeof $._consuming=="boolean"&&typeof $._dumped=="boolean"&&((X=$.req)===null||X===void 0?void 0:X.upgradeOrConnect)===void 0}function J($){if(!I($))return null;let{_writableState:X,_readableState:U}=$,H=X||U;return!H&&o($)||!!(H&&H.autoDestroy&&H.emitClose&&H.closed===!1)}function V($){var X;return!!($&&((X=$[E])!==null&&X!==void 0?X:$.readableDidRead||$.readableAborted))}function Z($){var X,U,H,G,Q,K,k,L,_,t;return!!($&&((X=(U=(H=(G=(Q=(K=$[q])!==null&&K!==void 0?K:$.readableErrored)!==null&&Q!==void 0?Q:$.writableErrored)!==null&&G!==void 0?G:(k=$._readableState)===null||k===void 0?void 0:k.errorEmitted)!==null&&H!==void 0?H:(L=$._writableState)===null||L===void 0?void 0:L.errorEmitted)!==null&&U!==void 0?U:(_=$._readableState)===null||_===void 0?void 0:_.errored)!==null&&X!==void 0?X:(t=$._writableState)===null||t===void 0?void 0:t.errored))}g.exports={kDestroyed:A,isDisturbed:V,kIsDisturbed:E,isErrored:Z,kIsErrored:q,isReadable:w,kIsReadable:Y,isClosed:VJ,isDestroyed:j,isDuplexNodeStream:W,isFinished:m,isIterable:z,isReadableNodeStream:O,isReadableEnded:v,isReadableFinished:S,isReadableErrored:JJ,isNodeStream:I,isWritable:y,isWritableNodeStream:N,isWritableEnded:P,isWritableFinished:F,isWritableErrored:i,isServerRequest:jJ,isServerResponse:o,willEmitClose:J}}),eQ=OJ((l,g)=>{var R=(aQ(),fQ(lQ)),{AbortError:M,codes:B}=gQ(),{ERR_INVALID_ARG_TYPE:A,ERR_STREAM_PREMATURE_CLOSE:q}=B,{kEmptyObject:Y,once:E}=iQ(),{validateAbortSignal:O,validateFunction:N,validateObject:W}=FV(),{Promise:I}=bQ(),{isClosed:z,isReadable:j,isReadableNodeStream:P,isReadableFinished:F,isReadableErrored:v,isWritable:S,isWritableNodeStream:w,isWritableFinished:y,isWritableErrored:m,isNodeStream:i,willEmitClose:JJ}=tQ();function VJ(J){return J.setHeader&&typeof J.abort=="function"}var HJ=()=>{};function o(J,V,Z){var $,X;arguments.length===2?(Z=V,V=Y):V==null?V=Y:W(V,"options"),N(Z,"callback"),O(V.signal,"options.signal"),Z=E(Z);let U=($=V.readable)!==null&&$!==void 0?$:P(J),H=(X=V.writable)!==null&&X!==void 0?X:w(J);if(!i(J))throw new A("stream","Stream",J);let{_writableState:G,_readableState:Q}=J,K=()=>{J.writable||_()},k=JJ(J)&&P(J)===U&&w(J)===H,L=y(J,!1),_=()=>{L=!0,J.destroyed&&(k=!1),!(k&&(!J.readable||U))&&(!U||t)&&Z.call(J)},t=F(J,!1),QJ=()=>{t=!0,J.destroyed&&(k=!1),!(k&&(!J.writable||H))&&(!H||L)&&Z.call(J)},GJ=(XJ)=>{Z.call(J,XJ)},n=z(J),p=()=>{n=!0;let XJ=m(J)||v(J);if(XJ&&typeof XJ!="boolean")return Z.call(J,XJ);if(U&&!t&&P(J,!0)&&!F(J,!1))return Z.call(J,new q);if(H&&!L&&!y(J,!1))return Z.call(J,new q);Z.call(J)},e=()=>{J.req.on("finish",_)};VJ(J)?(J.on("complete",_),k||J.on("abort",p),J.req?e():J.on("request",e)):H&&!G&&(J.on("end",K),J.on("close",K)),!k&&typeof J.aborted=="boolean"&&J.on("aborted",p),J.on("end",QJ),J.on("finish",_),V.error!==!1&&J.on("error",GJ),J.on("close",p),n?R.nextTick(p):G!=null&&G.errorEmitted||Q!=null&&Q.errorEmitted?k||R.nextTick(p):(!U&&(!k||j(J))&&(L||S(J)===!1)||!H&&(!k||S(J))&&(t||j(J)===!1)||Q&&J.req&&J.aborted)&&R.nextTick(p);let PJ=()=>{Z=HJ,J.removeListener("aborted",p),J.removeListener("complete",_),J.removeListener("abort",p),J.removeListener("request",e),J.req&&J.req.removeListener("finish",_),J.removeListener("end",K),J.removeListener("close",K),J.removeListener("finish",_),J.removeListener("end",QJ),J.removeListener("error",GJ),J.removeListener("close",p)};if(V.signal&&!n){let XJ=()=>{let WJ=Z;PJ(),WJ.call(J,new M(void 0,{cause:V.signal.reason}))};if(V.signal.aborted)R.nextTick(XJ);else{let WJ=Z;Z=E((...b)=>{V.signal.removeEventListener("abort",XJ),WJ.apply(J,b)}),V.signal.addEventListener("abort",XJ)}}return PJ}function jJ(J,V){return new I((Z,$)=>{o(J,V,(X)=>{X?$(X):Z()})})}g.exports=o,g.exports.finished=jJ}),Y8=OJ((l,g)=>{var R=globalThis.AbortController||lV().AbortController,{codes:{ERR_INVALID_ARG_TYPE:M,ERR_MISSING_ARGS:B,ERR_OUT_OF_RANGE:A},AbortError:q}=gQ(),{validateAbortSignal:Y,validateInteger:E,validateObject:O}=FV(),N=bQ().Symbol("kWeak"),{finished:W}=eQ(),{ArrayPrototypePush:I,MathFloor:z,Number:j,NumberIsNaN:P,Promise:F,PromiseReject:v,PromisePrototypeThen:S,Symbol:w}=bQ(),y=w("kEmpty"),m=w("kEof");function i(Q,K){if(typeof Q!="function")throw new M("fn",["Function","AsyncFunction"],Q);K!=null&&O(K,"options"),K?.signal!=null&&Y(K.signal,"options.signal");let k=1;return K?.concurrency!=null&&(k=z(K.concurrency)),E(k,"concurrency",1),async function*(){var L,_;let t=new R,QJ=this,GJ=[],n=t.signal,p={signal:n},e=()=>t.abort();K!=null&&(L=K.signal)!==null&&L!==void 0&&L.aborted&&e(),K==null||(_=K.signal)===null||_===void 0||_.addEventListener("abort",e);let PJ,XJ,WJ=!1;function b(){WJ=!0}async function C(){try{for await(let qJ of QJ){var h;if(WJ)return;if(n.aborted)throw new q;try{qJ=Q(qJ,p)}catch(ZJ){qJ=v(ZJ)}qJ!==y&&(typeof((h=qJ)===null||h===void 0?void 0:h.catch)=="function"&&qJ.catch(b),GJ.push(qJ),PJ&&(PJ(),PJ=null),!WJ&&GJ.length&&GJ.length>=k&&await new F((ZJ)=>{XJ=ZJ}))}GJ.push(m)}catch(qJ){let ZJ=v(qJ);S(ZJ,void 0,b),GJ.push(ZJ)}finally{var $J;WJ=!0,PJ&&(PJ(),PJ=null),K==null||($J=K.signal)===null||$J===void 0||$J.removeEventListener("abort",e)}}C();try{for(;;){for(;GJ.length>0;){let h=await GJ[0];if(h===m)return;if(n.aborted)throw new q;h!==y&&(yield h),GJ.shift(),XJ&&(XJ(),XJ=null)}await new F((h)=>{PJ=h})}}finally{t.abort(),WJ=!0,XJ&&(XJ(),XJ=null)}}.call(this)}function JJ(Q=void 0){return Q!=null&&O(Q,"options"),Q?.signal!=null&&Y(Q.signal,"options.signal"),async function*(){let K=0;for await(let L of this){var k;if(Q!=null&&(k=Q.signal)!==null&&k!==void 0&&k.aborted)throw new q({cause:Q.signal.reason});yield[K++,L]}}.call(this)}async function VJ(Q,K=void 0){for await(let k of J.call(this,Q,K))return!0;return!1}async function HJ(Q,K=void 0){if(typeof Q!="function")throw new M("fn",["Function","AsyncFunction"],Q);return!await VJ.call(this,async(...k)=>!await Q(...k),K)}async function o(Q,K){for await(let k of J.call(this,Q,K))return k}async function jJ(Q,K){if(typeof Q!="function")throw new M("fn",["Function","AsyncFunction"],Q);async function k(L,_){return await Q(L,_),y}for await(let L of i.call(this,k,K));}function J(Q,K){if(typeof Q!="function")throw new M("fn",["Function","AsyncFunction"],Q);async function k(L,_){return await Q(L,_)?L:y}return i.call(this,k,K)}var V=class extends B{constructor(){super("reduce"),this.message="Reduce of an empty stream requires an initial value"}};async function Z(Q,K,k){var L;if(typeof Q!="function")throw new M("reducer",["Function","AsyncFunction"],Q);k!=null&&O(k,"options"),k?.signal!=null&&Y(k.signal,"options.signal");let _=arguments.length>1;if(k!=null&&(L=k.signal)!==null&&L!==void 0&&L.aborted){let p=new q(void 0,{cause:k.signal.reason});throw this.once("error",()=>{}),await W(this.destroy(p)),p}let t=new R,QJ=t.signal;if(k!=null&&k.signal){let p={once:!0,[N]:this};k.signal.addEventListener("abort",()=>t.abort(),p)}let GJ=!1;try{for await(let p of this){var n;if(GJ=!0,k!=null&&(n=k.signal)!==null&&n!==void 0&&n.aborted)throw new q;_?K=await Q(K,p,{signal:QJ}):(K=p,_=!0)}if(!GJ&&!_)throw new V}finally{t.abort()}return K}async function $(Q){Q!=null&&O(Q,"options"),Q?.signal!=null&&Y(Q.signal,"options.signal");let K=[];for await(let L of this){var k;if(Q!=null&&(k=Q.signal)!==null&&k!==void 0&&k.aborted)throw new q(void 0,{cause:Q.signal.reason});I(K,L)}return K}function X(Q,K){let k=i.call(this,Q,K);return async function*(){for await(let L of k)yield*L}.call(this)}function U(Q){if(Q=j(Q),P(Q))return 0;if(Q<0)throw new A("number",">= 0",Q);return Q}function H(Q,K=void 0){return K!=null&&O(K,"options"),K?.signal!=null&&Y(K.signal,"options.signal"),Q=U(Q),async function*(){var k;if(K!=null&&(k=K.signal)!==null&&k!==void 0&&k.aborted)throw new q;for await(let _ of this){var L;if(K!=null&&(L=K.signal)!==null&&L!==void 0&&L.aborted)throw new q;Q--<=0&&(yield _)}}.call(this)}function G(Q,K=void 0){return K!=null&&O(K,"options"),K?.signal!=null&&Y(K.signal,"options.signal"),Q=U(Q),async function*(){var k;if(K!=null&&(k=K.signal)!==null&&k!==void 0&&k.aborted)throw new q;for await(let _ of this){var L;if(K!=null&&(L=K.signal)!==null&&L!==void 0&&L.aborted)throw new q;if(Q-- >0)yield _;else return}}.call(this)}g.exports.streamReturningOperators={asIndexedPairs:JJ,drop:H,filter:J,flatMap:X,map:i,take:G},g.exports.promiseReturningOperators={every:HJ,forEach:jJ,reduce:Z,toArray:$,some:VJ,find:o}}),qV=OJ((l,g)=>{var R=(aQ(),fQ(lQ)),{aggregateTwoErrors:M,codes:{ERR_MULTIPLE_CALLBACK:B},AbortError:A}=gQ(),{Symbol:q}=bQ(),{kDestroyed:Y,isDestroyed:E,isFinished:O,isServerRequest:N}=tQ(),W=q("kDestroy"),I=q("kConstruct");function z(J,V,Z){J&&(J.stack,V&&!V.errored&&(V.errored=J),Z&&!Z.errored&&(Z.errored=J))}function j(J,V){let Z=this._readableState,$=this._writableState,X=$||Z;return $&&$.destroyed||Z&&Z.destroyed?(typeof V=="function"&&V(),this):(z(J,$,Z),$&&($.destroyed=!0),Z&&(Z.destroyed=!0),X.constructed?P(this,J,V):this.once(W,function(U){P(this,M(U,J),V)}),this)}function P(J,V,Z){let $=!1;function X(U){if($)return;$=!0;let{_readableState:H,_writableState:G}=J;z(U,G,H),G&&(G.closed=!0),H&&(H.closed=!0),typeof Z=="function"&&Z(U),U?R.nextTick(F,J,U):R.nextTick(v,J)}try{J._destroy(V||null,X)}catch(U){X(U)}}function F(J,V){S(J,V),v(J)}function v(J){let{_readableState:V,_writableState:Z}=J;Z&&(Z.closeEmitted=!0),V&&(V.closeEmitted=!0),(Z&&Z.emitClose||V&&V.emitClose)&&J.emit("close")}function S(J,V){let{_readableState:Z,_writableState:$}=J;$&&$.errorEmitted||Z&&Z.errorEmitted||($&&($.errorEmitted=!0),Z&&(Z.errorEmitted=!0),J.emit("error",V))}function w(){let J=this._readableState,V=this._writableState;J&&(J.constructed=!0,J.closed=!1,J.closeEmitted=!1,J.destroyed=!1,J.errored=null,J.errorEmitted=!1,J.reading=!1,J.ended=J.readable===!1,J.endEmitted=J.readable===!1),V&&(V.constructed=!0,V.destroyed=!1,V.closed=!1,V.closeEmitted=!1,V.errored=null,V.errorEmitted=!1,V.finalCalled=!1,V.prefinished=!1,V.ended=V.writable===!1,V.ending=V.writable===!1,V.finished=V.writable===!1)}function y(J,V,Z){let{_readableState:$,_writableState:X}=J;if(X&&X.destroyed||$&&$.destroyed)return this;$&&$.autoDestroy||X&&X.autoDestroy?J.destroy(V):V&&(V.stack,X&&!X.errored&&(X.errored=V),$&&!$.errored&&($.errored=V),Z?R.nextTick(S,J,V):S(J,V))}function m(J,V){if(typeof J._construct!="function")return;let{_readableState:Z,_writableState:$}=J;Z&&(Z.constructed=!1),$&&($.constructed=!1),J.once(I,V),!(J.listenerCount(I)>1)&&R.nextTick(i,J)}function i(J){let V=!1;function Z($){if(V){y(J,$??new B);return}V=!0;let{_readableState:X,_writableState:U}=J,H=U||X;X&&(X.constructed=!0),U&&(U.constructed=!0),H.destroyed?J.emit(W,$):$?y(J,$,!0):R.nextTick(JJ,J)}try{J._construct(Z)}catch($){Z($)}}function JJ(J){J.emit(I)}function VJ(J){return J&&J.setHeader&&typeof J.abort=="function"}function HJ(J){J.emit("close")}function o(J,V){J.emit("error",V),R.nextTick(HJ,J)}function jJ(J,V){!J||E(J)||(!V&&!O(J)&&(V=new A),N(J)?(J.socket=null,J.destroy(V)):VJ(J)?J.abort():VJ(J.req)?J.req.abort():typeof J.destroy=="function"?J.destroy(V):typeof J.close=="function"?J.close():V?R.nextTick(o,J,V):R.nextTick(HJ,J),J.destroyed||(J[Y]=!0))}g.exports={construct:m,destroyer:jJ,destroy:j,undestroy:w,errorOrDestroy:y}}),sV=OJ((l,g)=>{var{ArrayIsArray:R,ObjectSetPrototypeOf:M}=bQ(),{EventEmitter:B}=rQ();function A(Y){B.call(this,Y)}M(A.prototype,B.prototype),M(A,B),A.prototype.pipe=function(Y,E){let O=this;function N(v){Y.writable&&Y.write(v)===!1&&O.pause&&O.pause()}O.on("data",N);function W(){O.readable&&O.resume&&O.resume()}Y.on("drain",W),!Y._isStdio&&(!E||E.end!==!1)&&(O.on("end",z),O.on("close",j));let I=!1;function z(){I||(I=!0,Y.end())}function j(){I||(I=!0,typeof Y.destroy=="function"&&Y.destroy())}function P(v){F(),B.listenerCount(this,"error")===0&&this.emit("error",v)}q(O,"error",P),q(Y,"error",P);function F(){O.removeListener("data",N),Y.removeListener("drain",W),O.removeListener("end",z),O.removeListener("close",j),O.removeListener("error",P),Y.removeListener("error",P),O.removeListener("end",F),O.removeListener("close",F),Y.removeListener("close",F)}return O.on("end",F),O.on("close",F),Y.on("close",F),Y.emit("pipe",O),Y};function q(Y,E,O){if(typeof Y.prependListener=="function")return Y.prependListener(E,O);!Y._events||!Y._events[E]?Y.on(E,O):R(Y._events[E])?Y._events[E].unshift(O):Y._events[E]=[O,Y._events[E]]}g.exports={Stream:A,prependListener:q}}),dV=OJ((l,g)=>{var{AbortError:R,codes:M}=gQ(),B=eQ(),{ERR_INVALID_ARG_TYPE:A}=M,q=(E,O)=>{if(typeof E!="object"||!("aborted"in E))throw new A(O,"AbortSignal",E)};function Y(E){return!!(E&&typeof E.pipe=="function")}g.exports.addAbortSignal=function(E,O){if(q(E,"signal"),!Y(O))throw new A("stream","stream.Stream",O);return g.exports.addAbortSignalNoValidate(E,O)},g.exports.addAbortSignalNoValidate=function(E,O){if(typeof E!="object"||!("aborted"in E))return O;let N=()=>{O.destroy(new R(void 0,{cause:E.reason}))};return E.aborted?N():(E.addEventListener("abort",N),B(O,()=>E.removeEventListener("abort",N))),O}}),B8=OJ((l,g)=>{var{StringPrototypeSlice:R,SymbolIterator:M,TypedArrayPrototypeSet:B,Uint8Array:A}=bQ(),{Buffer:q}=yQ(),{inspect:Y}=iQ();g.exports=class{constructor(){this.head=null,this.tail=null,this.length=0}push(E){let O={data:E,next:null};this.length>0?this.tail.next=O:this.head=O,this.tail=O,++this.length}unshift(E){let O={data:E,next:this.head};this.length===0&&(this.tail=O),this.head=O,++this.length}shift(){if(this.length===0)return;let E=this.head.data;return this.length===1?this.head=this.tail=null:this.head=this.head.next,--this.length,E}clear(){this.head=this.tail=null,this.length=0}join(E){if(this.length===0)return"";let O=this.head,N=""+O.data;for(;(O=O.next)!==null;)N+=E+O.data;return N}concat(E){if(this.length===0)return q.alloc(0);let O=q.allocUnsafe(E>>>0),N=this.head,W=0;for(;N;)B(O,N.data,W),W+=N.data.length,N=N.next;return O}consume(E,O){let N=this.head.data;if(E<N.length){let W=N.slice(0,E);return this.head.data=N.slice(E),W}return E===N.length?this.shift():O?this._getString(E):this._getBuffer(E)}first(){return this.head.data}*[M](){for(let E=this.head;E;E=E.next)yield E.data}_getString(E){let O="",N=this.head,W=0;do{let I=N.data;if(E>I.length)O+=I,E-=I.length;else{E===I.length?(O+=I,++W,N.next?this.head=N.next:this.head=this.tail=null):(O+=R(I,0,E),this.head=N,N.data=R(I,E));break}++W}while((N=N.next)!==null);return this.length-=W,O}_getBuffer(E){let O=q.allocUnsafe(E),N=E,W=this.head,I=0;do{let z=W.data;if(E>z.length)B(O,z,N-E),E-=z.length;else{E===z.length?(B(O,z,N-E),++I,W.next?this.head=W.next:this.head=this.tail=null):(B(O,new A(z.buffer,z.byteOffset,E),N-E),this.head=W,W.data=z.slice(E));break}++I}while((W=W.next)!==null);return this.length-=I,O}[Symbol.for("nodejs.util.inspect.custom")](E,O){return Y(this,{...O,depth:0,customInspect:!1})}}}),nV=OJ((l,g)=>{var{MathFloor:R,NumberIsInteger:M}=bQ(),{ERR_INVALID_ARG_VALUE:B}=gQ().codes;function A(E,O,N){return E.highWaterMark!=null?E.highWaterMark:O?E[N]:null}function q(E){return E?16:16384}function Y(E,O,N,W){let I=A(O,W,N);if(I!=null){if(!M(I)||I<0){let z=W?`options.${N}`:"options.highWaterMark";throw new B(z,I)}return R(I)}return q(E.objectMode)}g.exports={getHighWaterMark:Y,getDefaultHighWaterMark:q}}),v0=OJ((l,g)=>{var R=(aQ(),fQ(lQ)),{PromisePrototypeThen:M,SymbolAsyncIterator:B,SymbolIterator:A}=bQ(),{Buffer:q}=yQ(),{ERR_INVALID_ARG_TYPE:Y,ERR_STREAM_NULL_VALUES:E}=gQ().codes;function O(N,W,I){let z;if(typeof W=="string"||W instanceof q)return new N({objectMode:!0,...I,read(){this.push(W),this.push(null)}});let j;if(W&&W[B])j=!0,z=W[B]();else if(W&&W[A])j=!1,z=W[A]();else throw new Y("iterable",["Iterable"],W);let P=new N({objectMode:!0,highWaterMark:1,...I}),F=!1;P._read=function(){F||(F=!0,S())},P._destroy=function(w,y){M(v(w),()=>R.nextTick(y,w),(m)=>R.nextTick(y,m||w))};async function v(w){let y=w!=null,m=typeof z.throw=="function";if(y&&m){let{value:i,done:JJ}=await z.throw(w);if(await i,JJ)return}if(typeof z.return=="function"){let{value:i}=await z.return();await i}}async function S(){for(;;){try{let{value:w,done:y}=j?await z.next():z.next();if(y)P.push(null);else{let m=w&&typeof w.then=="function"?await w:w;if(m===null)throw F=!1,new E;if(P.push(m))continue;F=!1}}catch(w){P.destroy(w)}break}}return P}g.exports=O}),DV=OJ((l,g)=>{var R=(aQ(),fQ(lQ)),{ArrayPrototypeIndexOf:M,NumberIsInteger:B,NumberIsNaN:A,NumberParseInt:q,ObjectDefineProperties:Y,ObjectKeys:E,ObjectSetPrototypeOf:O,Promise:N,SafeSet:W,SymbolAsyncIterator:I,Symbol:z}=bQ();g.exports=k,k.ReadableState=K;var{EventEmitter:j}=rQ(),{Stream:P,prependListener:F}=sV(),{Buffer:v}=yQ(),{addAbortSignal:S}=dV(),w=eQ(),y=iQ().debuglog("stream",(T)=>{y=T}),m=B8(),i=qV(),{getHighWaterMark:JJ,getDefaultHighWaterMark:VJ}=nV(),{aggregateTwoErrors:HJ,codes:{ERR_INVALID_ARG_TYPE:o,ERR_METHOD_NOT_IMPLEMENTED:jJ,ERR_OUT_OF_RANGE:J,ERR_STREAM_PUSH_AFTER_EOF:V,ERR_STREAM_UNSHIFT_AFTER_END_EVENT:Z}}=gQ(),{validateObject:$}=FV(),X=z("kPaused"),{StringDecoder:U}=hV(),H=v0();O(k.prototype,P.prototype),O(k,P);var G=()=>{},{errorOrDestroy:Q}=i;function K(T,D,u){typeof u!="boolean"&&(u=D instanceof sQ()),this.objectMode=!!(T&&T.objectMode),u&&(this.objectMode=this.objectMode||!!(T&&T.readableObjectMode)),this.highWaterMark=T?JJ(this,T,"readableHighWaterMark",u):VJ(!1),this.buffer=new m,this.length=0,this.pipes=[],this.flowing=null,this.ended=!1,this.endEmitted=!1,this.reading=!1,this.constructed=!0,this.sync=!0,this.needReadable=!1,this.emittedReadable=!1,this.readableListening=!1,this.resumeScheduled=!1,this[X]=null,this.errorEmitted=!1,this.emitClose=!T||T.emitClose!==!1,this.autoDestroy=!T||T.autoDestroy!==!1,this.destroyed=!1,this.errored=null,this.closed=!1,this.closeEmitted=!1,this.defaultEncoding=T&&T.defaultEncoding||"utf8",this.awaitDrainWriters=null,this.multiAwaitDrain=!1,this.readingMore=!1,this.dataEmitted=!1,this.decoder=null,this.encoding=null,T&&T.encoding&&(this.decoder=new U(T.encoding),this.encoding=T.encoding)}function k(T){if(!(this instanceof k))return new k(T);let D=this instanceof sQ();this._readableState=new K(T,this,D),T&&(typeof T.read=="function"&&(this._read=T.read),typeof T.destroy=="function"&&(this._destroy=T.destroy),typeof T.construct=="function"&&(this._construct=T.construct),T.signal&&!D&&S(T.signal,this)),P.call(this,T),i.construct(this,()=>{this._readableState.needReadable&&PJ(this,this._readableState)})}k.prototype.destroy=i.destroy,k.prototype._undestroy=i.undestroy,k.prototype._destroy=function(T,D){D(T)},k.prototype[j.captureRejectionSymbol]=function(T){this.destroy(T)},k.prototype.push=function(T,D){return L(this,T,D,!1)},k.prototype.unshift=function(T,D){return L(this,T,D,!0)};function L(T,D,u,d){y("readableAddChunk",D);let a=T._readableState,CJ;if(a.objectMode||(typeof D=="string"?(u=u||a.defaultEncoding,a.encoding!==u&&(d&&a.encoding?D=v.from(D,u).toString(a.encoding):(D=v.from(D,u),u=""))):D instanceof v?u="":P._isUint8Array(D)?(D=P._uint8ArrayToBuffer(D),u=""):D!=null&&(CJ=new o("chunk",["string","Buffer","Uint8Array"],D))),CJ)Q(T,CJ);else if(D===null)a.reading=!1,n(T,a);else if(a.objectMode||D&&D.length>0)if(d)if(a.endEmitted)Q(T,new Z);else{if(a.destroyed||a.errored)return!1;_(T,a,D,!0)}else if(a.ended)Q(T,new V);else{if(a.destroyed||a.errored)return!1;a.reading=!1,a.decoder&&!u?(D=a.decoder.write(D),a.objectMode||D.length!==0?_(T,a,D,!1):PJ(T,a)):_(T,a,D,!1)}else d||(a.reading=!1,PJ(T,a));return!a.ended&&(a.length<a.highWaterMark||a.length===0)}function _(T,D,u,d){D.flowing&&D.length===0&&!D.sync&&T.listenerCount("data")>0?(D.multiAwaitDrain?D.awaitDrainWriters.clear():D.awaitDrainWriters=null,D.dataEmitted=!0,T.emit("data",u)):(D.length+=D.objectMode?1:u.length,d?D.buffer.unshift(u):D.buffer.push(u),D.needReadable&&p(T)),PJ(T,D)}k.prototype.isPaused=function(){let T=this._readableState;return T[X]===!0||T.flowing===!1},k.prototype.setEncoding=function(T){let D=new U(T);this._readableState.decoder=D,this._readableState.encoding=this._readableState.decoder.encoding;let u=this._readableState.buffer,d="";for(let a of u)d+=D.write(a);return u.clear(),d!==""&&u.push(d),this._readableState.length=d.length,this};var t=1073741824;function QJ(T){if(T>t)throw new J("size","<= 1GiB",T);return T--,T|=T>>>1,T|=T>>>2,T|=T>>>4,T|=T>>>8,T|=T>>>16,T++,T}function GJ(T,D){return T<=0||D.length===0&&D.ended?0:D.objectMode?1:A(T)?D.flowing&&D.length?D.buffer.first().length:D.length:T<=D.length?T:D.ended?D.length:0}k.prototype.read=function(T){y("read",T),T===void 0?T=NaN:B(T)||(T=q(T,10));let D=this._readableState,u=T;if(T>D.highWaterMark&&(D.highWaterMark=QJ(T)),T!==0&&(D.emittedReadable=!1),T===0&&D.needReadable&&((D.highWaterMark!==0?D.length>=D.highWaterMark:D.length>0)||D.ended))return y("read: emitReadable",D.length,D.ended),D.length===0&&D.ended?TJ(this):p(this),null;if(T=GJ(T,D),T===0&&D.ended)return D.length===0&&TJ(this),null;let d=D.needReadable;if(y("need readable",d),(D.length===0||D.length-T<D.highWaterMark)&&(d=!0,y("length less than watermark",d)),D.ended||D.reading||D.destroyed||D.errored||!D.constructed)d=!1,y("reading, ended or constructing",d);else if(d){y("do read"),D.reading=!0,D.sync=!0,D.length===0&&(D.needReadable=!0);try{this._read(D.highWaterMark)}catch(CJ){Q(this,CJ)}D.sync=!1,D.reading||(T=GJ(u,D))}let a;return T>0?a=BJ(T,D):a=null,a===null?(D.needReadable=D.length<=D.highWaterMark,T=0):(D.length-=T,D.multiAwaitDrain?D.awaitDrainWriters.clear():D.awaitDrainWriters=null),D.length===0&&(D.ended||(D.needReadable=!0),u!==T&&D.ended&&TJ(this)),a!==null&&!D.errorEmitted&&!D.closeEmitted&&(D.dataEmitted=!0,this.emit("data",a)),a};function n(T,D){if(y("onEofChunk"),!D.ended){if(D.decoder){let u=D.decoder.end();u&&u.length&&(D.buffer.push(u),D.length+=D.objectMode?1:u.length)}D.ended=!0,D.sync?p(T):(D.needReadable=!1,D.emittedReadable=!0,e(T))}}function p(T){let D=T._readableState;y("emitReadable",D.needReadable,D.emittedReadable),D.needReadable=!1,D.emittedReadable||(y("emitReadable",D.flowing),D.emittedReadable=!0,R.nextTick(e,T))}function e(T){let D=T._readableState;y("emitReadable_",D.destroyed,D.length,D.ended),!D.destroyed&&!D.errored&&(D.length||D.ended)&&(T.emit("readable"),D.emittedReadable=!1),D.needReadable=!D.flowing&&!D.ended&&D.length<=D.highWaterMark,qJ(T)}function PJ(T,D){!D.readingMore&&D.constructed&&(D.readingMore=!0,R.nextTick(XJ,T,D))}function XJ(T,D){for(;!D.reading&&!D.ended&&(D.length<D.highWaterMark||D.flowing&&D.length===0);){let u=D.length;if(y("maybeReadMore read 0"),T.read(0),u===D.length)break}D.readingMore=!1}k.prototype._read=function(T){throw new jJ("_read()")},k.prototype.pipe=function(T,D){let u=this,d=this._readableState;d.pipes.length===1&&(d.multiAwaitDrain||(d.multiAwaitDrain=!0,d.awaitDrainWriters=new W(d.awaitDrainWriters?[d.awaitDrainWriters]:[]))),d.pipes.push(T),y("pipe count=%d opts=%j",d.pipes.length,D);let a=(!D||D.end!==!1)&&T!==R.stdout&&T!==R.stderr?UJ:AJ;d.endEmitted?R.nextTick(a):u.once("end",a),T.on("unpipe",CJ);function CJ(kJ,ZQ){y("onunpipe"),kJ===u&&ZQ&&ZQ.hasUnpiped===!1&&(ZQ.hasUnpiped=!0,FJ())}function UJ(){y("onend"),T.end()}let EJ,QQ=!1;function FJ(){y("cleanup"),T.removeListener("close",xJ),T.removeListener("finish",nJ),EJ&&T.removeListener("drain",EJ),T.removeListener("error",SJ),T.removeListener("unpipe",CJ),u.removeListener("end",UJ),u.removeListener("end",AJ),u.removeListener("data",aJ),QQ=!0,EJ&&d.awaitDrainWriters&&(!T._writableState||T._writableState.needDrain)&&EJ()}function RJ(){QQ||(d.pipes.length===1&&d.pipes[0]===T?(y("false write response, pause",0),d.awaitDrainWriters=T,d.multiAwaitDrain=!1):d.pipes.length>1&&d.pipes.includes(T)&&(y("false write response, pause",d.awaitDrainWriters.size),d.awaitDrainWriters.add(T)),u.pause()),EJ||(EJ=WJ(u,T),T.on("drain",EJ))}u.on("data",aJ);function aJ(kJ){y("ondata");let ZQ=T.write(kJ);y("dest.write",ZQ),ZQ===!1&&RJ()}function SJ(kJ){if(y("onerror",kJ),AJ(),T.removeListener("error",SJ),T.listenerCount("error")===0){let ZQ=T._writableState||T._readableState;ZQ&&!ZQ.errorEmitted?Q(T,kJ):T.emit("error",kJ)}}F(T,"error",SJ);function xJ(){T.removeListener("finish",nJ),AJ()}T.once("close",xJ);function nJ(){y("onfinish"),T.removeListener("close",xJ),AJ()}T.once("finish",nJ);function AJ(){y("unpipe"),u.unpipe(T)}return T.emit("pipe",u),T.writableNeedDrain===!0?d.flowing&&RJ():d.flowing||(y("pipe resume"),u.resume()),T};function WJ(T,D){return function(){let u=T._readableState;u.awaitDrainWriters===D?(y("pipeOnDrain",1),u.awaitDrainWriters=null):u.multiAwaitDrain&&(y("pipeOnDrain",u.awaitDrainWriters.size),u.awaitDrainWriters.delete(D)),(!u.awaitDrainWriters||u.awaitDrainWriters.size===0)&&T.listenerCount("data")&&T.resume()}}k.prototype.unpipe=function(T){let D=this._readableState,u={hasUnpiped:!1};if(D.pipes.length===0)return this;if(!T){let a=D.pipes;D.pipes=[],this.pause();for(let CJ=0;CJ<a.length;CJ++)a[CJ].emit("unpipe",this,{hasUnpiped:!1});return this}let d=M(D.pipes,T);return d===-1?this:(D.pipes.splice(d,1),D.pipes.length===0&&this.pause(),T.emit("unpipe",this,u),this)},k.prototype.on=function(T,D){let u=P.prototype.on.call(this,T,D),d=this._readableState;return T==="data"?(d.readableListening=this.listenerCount("readable")>0,d.flowing!==!1&&this.resume()):T==="readable"&&!d.endEmitted&&!d.readableListening&&(d.readableListening=d.needReadable=!0,d.flowing=!1,d.emittedReadable=!1,y("on readable",d.length,d.reading),d.length?p(this):d.reading||R.nextTick(C,this)),u},k.prototype.addListener=k.prototype.on,k.prototype.removeListener=function(T,D){let u=P.prototype.removeListener.call(this,T,D);return T==="readable"&&R.nextTick(b,this),u},k.prototype.off=k.prototype.removeListener,k.prototype.removeAllListeners=function(T){let D=P.prototype.removeAllListeners.apply(this,arguments);return(T==="readable"||T===void 0)&&R.nextTick(b,this),D};function b(T){let D=T._readableState;D.readableListening=T.listenerCount("readable")>0,D.resumeScheduled&&D[X]===!1?D.flowing=!0:T.listenerCount("data")>0?T.resume():D.readableListening||(D.flowing=null)}function C(T){y("readable nexttick read 0"),T.read(0)}k.prototype.resume=function(){let T=this._readableState;return T.flowing||(y("resume"),T.flowing=!T.readableListening,h(this,T)),T[X]=!1,this};function h(T,D){D.resumeScheduled||(D.resumeScheduled=!0,R.nextTick($J,T,D))}function $J(T,D){y("resume",D.reading),D.reading||T.read(0),D.resumeScheduled=!1,T.emit("resume"),qJ(T),D.flowing&&!D.reading&&T.read(0)}k.prototype.pause=function(){return y("call pause flowing=%j",this._readableState.flowing),this._readableState.flowing!==!1&&(y("pause"),this._readableState.flowing=!1,this.emit("pause")),this._readableState[X]=!0,this};function qJ(T){let D=T._readableState;for(y("flow",D.flowing);D.flowing&&T.read()!==null;);}k.prototype.wrap=function(T){let D=!1;T.on("data",(d)=>{!this.push(d)&&T.pause&&(D=!0,T.pause())}),T.on("end",()=>{this.push(null)}),T.on("error",(d)=>{Q(this,d)}),T.on("close",()=>{this.destroy()}),T.on("destroy",()=>{this.destroy()}),this._read=()=>{D&&T.resume&&(D=!1,T.resume())};let u=E(T);for(let d=1;d<u.length;d++){let a=u[d];this[a]===void 0&&typeof T[a]=="function"&&(this[a]=T[a].bind(T))}return this},k.prototype[I]=function(){return ZJ(this)},k.prototype.iterator=function(T){return T!==void 0&&$(T,"options"),ZJ(this,T)};function ZJ(T,D){typeof T.read!="function"&&(T=k.wrap(T,{objectMode:!0}));let u=mJ(T,D);return u.stream=T,u}async function*mJ(T,D){let u=G;function d(UJ){this===T?(u(),u=G):u=UJ}T.on("readable",d);let a,CJ=w(T,{writable:!1},(UJ)=>{a=UJ?HJ(a,UJ):null,u(),u=G});try{for(;;){let UJ=T.destroyed?null:T.read();if(UJ!==null)yield UJ;else{if(a)throw a;if(a===null)return;await new N(d)}}}catch(UJ){throw a=HJ(a,UJ),a}finally{(a||D?.destroyOnReturn!==!1)&&(a===void 0||T._readableState.autoDestroy)?i.destroyer(T,null):(T.off("readable",d),CJ())}}Y(k.prototype,{readable:{__proto__:null,get(){let T=this._readableState;return!!T&&T.readable!==!1&&!T.destroyed&&!T.errorEmitted&&!T.endEmitted},set(T){this._readableState&&(this._readableState.readable=!!T)}},readableDidRead:{__proto__:null,enumerable:!1,get:function(){return this._readableState.dataEmitted}},readableAborted:{__proto__:null,enumerable:!1,get:function(){return!!(this._readableState.readable!==!1&&(this._readableState.destroyed||this._readableState.errored)&&!this._readableState.endEmitted)}},readableHighWaterMark:{__proto__:null,enumerable:!1,get:function(){return this._readableState.highWaterMark}},readableBuffer:{__proto__:null,enumerable:!1,get:function(){return this._readableState&&this._readableState.buffer}},readableFlowing:{__proto__:null,enumerable:!1,get:function(){return this._readableState.flowing},set:function(T){this._readableState&&(this._readableState.flowing=T)}},readableLength:{__proto__:null,enumerable:!1,get(){return this._readableState.length}},readableObjectMode:{__proto__:null,enumerable:!1,get(){return this._readableState?this._readableState.objectMode:!1}},readableEncoding:{__proto__:null,enumerable:!1,get(){return this._readableState?this._readableState.encoding:null}},errored:{__proto__:null,enumerable:!1,get(){return this._readableState?this._readableState.errored:null}},closed:{__proto__:null,get(){return this._readableState?this._readableState.closed:!1}},destroyed:{__proto__:null,enumerable:!1,get(){return this._readableState?this._readableState.destroyed:!1},set(T){!this._readableState||(this._readableState.destroyed=T)}},readableEnded:{__proto__:null,enumerable:!1,get(){return this._readableState?this._readableState.endEmitted:!1}}}),Y(K.prototype,{pipesCount:{__proto__:null,get(){return this.pipes.length}},paused:{__proto__:null,get(){return this[X]!==!1},set(T){this[X]=!!T}}}),k._fromList=BJ;function BJ(T,D){if(D.length===0)return null;let u;return D.objectMode?u=D.buffer.shift():!T||T>=D.length?(D.decoder?u=D.buffer.join(""):D.buffer.length===1?u=D.buffer.first():u=D.buffer.concat(D.length),D.buffer.clear()):u=D.buffer.consume(T,D.decoder),u}function TJ(T){let D=T._readableState;y("endReadable",D.endEmitted),D.endEmitted||(D.ended=!0,R.nextTick(dJ,D,T))}function dJ(T,D){if(y("endReadableNT",T.endEmitted,T.length),!T.errored&&!T.closeEmitted&&!T.endEmitted&&T.length===0){if(T.endEmitted=!0,D.emit("end"),D.writable&&D.allowHalfOpen===!1)R.nextTick(LJ,D);else if(T.autoDestroy){let u=D._writableState;(!u||u.autoDestroy&&(u.finished||u.writable===!1))&&D.destroy()}}}function LJ(T){T.writable&&!T.writableEnded&&!T.destroyed&&T.end()}k.from=function(T,D){return H(k,T,D)};var IJ;function $Q(){return IJ===void 0&&(IJ={}),IJ}k.fromWeb=function(T,D){return $Q().newStreamReadableFromReadableStream(T,D)},k.toWeb=function(T,D){return $Q().newReadableStreamFromStreamReadable(T,D)},k.wrap=function(T,D){var u,d;return new k({objectMode:(u=(d=T.readableObjectMode)!==null&&d!==void 0?d:T.objectMode)!==null&&u!==void 0?u:!0,...D,destroy(a,CJ){i.destroyer(T,a),CJ(a)}}).wrap(T)}}),M0=OJ((l,g)=>{var R=(aQ(),fQ(lQ)),{ArrayPrototypeSlice:M,Error:B,FunctionPrototypeSymbolHasInstance:A,ObjectDefineProperty:q,ObjectDefineProperties:Y,ObjectSetPrototypeOf:E,StringPrototypeToLowerCase:O,Symbol:N,SymbolHasInstance:W}=bQ();g.exports=U,U.WritableState=$;var{EventEmitter:I}=rQ(),z=sV().Stream,{Buffer:j}=yQ(),P=qV(),{addAbortSignal:F}=dV(),{getHighWaterMark:v,getDefaultHighWaterMark:S}=nV(),{ERR_INVALID_ARG_TYPE:w,ERR_METHOD_NOT_IMPLEMENTED:y,ERR_MULTIPLE_CALLBACK:m,ERR_STREAM_CANNOT_PIPE:i,ERR_STREAM_DESTROYED:JJ,ERR_STREAM_ALREADY_FINISHED:VJ,ERR_STREAM_NULL_VALUES:HJ,ERR_STREAM_WRITE_AFTER_END:o,ERR_UNKNOWN_ENCODING:jJ}=gQ().codes,{errorOrDestroy:J}=P;E(U.prototype,z.prototype),E(U,z);function V(){}var Z=N("kOnFinished");function $(C,h,$J){typeof $J!="boolean"&&($J=h instanceof sQ()),this.objectMode=!!(C&&C.objectMode),$J&&(this.objectMode=this.objectMode||!!(C&&C.writableObjectMode)),this.highWaterMark=C?v(this,C,"writableHighWaterMark",$J):S(!1),this.finalCalled=!1,this.needDrain=!1,this.ending=!1,this.ended=!1,this.finished=!1,this.destroyed=!1;let qJ=!!(C&&C.decodeStrings===!1);this.decodeStrings=!qJ,this.defaultEncoding=C&&C.defaultEncoding||"utf8",this.length=0,this.writing=!1,this.corked=0,this.sync=!0,this.bufferProcessing=!1,this.onwrite=k.bind(void 0,h),this.writecb=null,this.writelen=0,this.afterWriteTickInfo=null,X(this),this.pendingcb=0,this.constructed=!0,this.prefinished=!1,this.errorEmitted=!1,this.emitClose=!C||C.emitClose!==!1,this.autoDestroy=!C||C.autoDestroy!==!1,this.errored=null,this.closed=!1,this.closeEmitted=!1,this[Z]=[]}function X(C){C.buffered=[],C.bufferedIndex=0,C.allBuffers=!0,C.allNoop=!0}$.prototype.getBuffer=function(){return M(this.buffered,this.bufferedIndex)},q($.prototype,"bufferedRequestCount",{__proto__:null,get(){return this.buffered.length-this.bufferedIndex}});function U(C){let h=this instanceof sQ();if(!h&&!A(U,this))return new U(C);this._writableState=new $(C,this,h),C&&(typeof C.write=="function"&&(this._write=C.write),typeof C.writev=="function"&&(this._writev=C.writev),typeof C.destroy=="function"&&(this._destroy=C.destroy),typeof C.final=="function"&&(this._final=C.final),typeof C.construct=="function"&&(this._construct=C.construct),C.signal&&F(C.signal,this)),z.call(this,C),P.construct(this,()=>{let $J=this._writableState;$J.writing||QJ(this,$J),e(this,$J)})}q(U,W,{__proto__:null,value:function(C){return A(this,C)?!0:this!==U?!1:C&&C._writableState instanceof $}}),U.prototype.pipe=function(){J(this,new i)};function H(C,h,$J,qJ){let ZJ=C._writableState;if(typeof $J=="function")qJ=$J,$J=ZJ.defaultEncoding;else{if(!$J)$J=ZJ.defaultEncoding;else if($J!=="buffer"&&!j.isEncoding($J))throw new jJ($J);typeof qJ!="function"&&(qJ=V)}if(h===null)throw new HJ;if(!ZJ.objectMode)if(typeof h=="string")ZJ.decodeStrings!==!1&&(h=j.from(h,$J),$J="buffer");else if(h instanceof j)$J="buffer";else if(z._isUint8Array(h))h=z._uint8ArrayToBuffer(h),$J="buffer";else throw new w("chunk",["string","Buffer","Uint8Array"],h);let mJ;return ZJ.ending?mJ=new o:ZJ.destroyed&&(mJ=new JJ("write")),mJ?(R.nextTick(qJ,mJ),J(C,mJ,!0),mJ):(ZJ.pendingcb++,G(C,ZJ,h,$J,qJ))}U.prototype.write=function(C,h,$J){return H(this,C,h,$J)===!0},U.prototype.cork=function(){this._writableState.corked++},U.prototype.uncork=function(){let C=this._writableState;C.corked&&(C.corked--,C.writing||QJ(this,C))},U.prototype.setDefaultEncoding=function(C){if(typeof C=="string"&&(C=O(C)),!j.isEncoding(C))throw new jJ(C);return this._writableState.defaultEncoding=C,this};function G(C,h,$J,qJ,ZJ){let mJ=h.objectMode?1:$J.length;h.length+=mJ;let BJ=h.length<h.highWaterMark;return BJ||(h.needDrain=!0),h.writing||h.corked||h.errored||!h.constructed?(h.buffered.push({chunk:$J,encoding:qJ,callback:ZJ}),h.allBuffers&&qJ!=="buffer"&&(h.allBuffers=!1),h.allNoop&&ZJ!==V&&(h.allNoop=!1)):(h.writelen=mJ,h.writecb=ZJ,h.writing=!0,h.sync=!0,C._write($J,qJ,h.onwrite),h.sync=!1),BJ&&!h.errored&&!h.destroyed}function Q(C,h,$J,qJ,ZJ,mJ,BJ){h.writelen=qJ,h.writecb=BJ,h.writing=!0,h.sync=!0,h.destroyed?h.onwrite(new JJ("write")):$J?C._writev(ZJ,h.onwrite):C._write(ZJ,mJ,h.onwrite),h.sync=!1}function K(C,h,$J,qJ){--h.pendingcb,qJ($J),t(h),J(C,$J)}function k(C,h){let $J=C._writableState,qJ=$J.sync,ZJ=$J.writecb;if(typeof ZJ!="function"){J(C,new m);return}$J.writing=!1,$J.writecb=null,$J.length-=$J.writelen,$J.writelen=0,h?(h.stack,$J.errored||($J.errored=h),C._readableState&&!C._readableState.errored&&(C._readableState.errored=h),qJ?R.nextTick(K,C,$J,h,ZJ):K(C,$J,h,ZJ)):($J.buffered.length>$J.bufferedIndex&&QJ(C,$J),qJ?$J.afterWriteTickInfo!==null&&$J.afterWriteTickInfo.cb===ZJ?$J.afterWriteTickInfo.count++:($J.afterWriteTickInfo={count:1,cb:ZJ,stream:C,state:$J},R.nextTick(L,$J.afterWriteTickInfo)):_(C,$J,1,ZJ))}function L({stream:C,state:h,count:$J,cb:qJ}){return h.afterWriteTickInfo=null,_(C,h,$J,qJ)}function _(C,h,$J,qJ){for(!h.ending&&!C.destroyed&&h.length===0&&h.needDrain&&(h.needDrain=!1,C.emit("drain"));$J-- >0;)h.pendingcb--,qJ();h.destroyed&&t(h),e(C,h)}function t(C){if(C.writing)return;for(let ZJ=C.bufferedIndex;ZJ<C.buffered.length;++ZJ){var h;let{chunk:mJ,callback:BJ}=C.buffered[ZJ],TJ=C.objectMode?1:mJ.length;C.length-=TJ,BJ((h=C.errored)!==null&&h!==void 0?h:new JJ("write"))}let $J=C[Z].splice(0);for(let ZJ=0;ZJ<$J.length;ZJ++){var qJ;$J[ZJ]((qJ=C.errored)!==null&&qJ!==void 0?qJ:new JJ("end"))}X(C)}function QJ(C,h){if(h.corked||h.bufferProcessing||h.destroyed||!h.constructed)return;let{buffered:$J,bufferedIndex:qJ,objectMode:ZJ}=h,mJ=$J.length-qJ;if(!mJ)return;let BJ=qJ;if(h.bufferProcessing=!0,mJ>1&&C._writev){h.pendingcb-=mJ-1;let TJ=h.allNoop?V:(LJ)=>{for(let IJ=BJ;IJ<$J.length;++IJ)$J[IJ].callback(LJ)},dJ=h.allNoop&&BJ===0?$J:M($J,BJ);dJ.allBuffers=h.allBuffers,Q(C,h,!0,h.length,dJ,"",TJ),X(h)}else{do{let{chunk:TJ,encoding:dJ,callback:LJ}=$J[BJ];$J[BJ++]=null;let IJ=ZJ?1:TJ.length;Q(C,h,!1,IJ,TJ,dJ,LJ)}while(BJ<$J.length&&!h.writing);BJ===$J.length?X(h):BJ>256?($J.splice(0,BJ),h.bufferedIndex=0):h.bufferedIndex=BJ}h.bufferProcessing=!1}U.prototype._write=function(C,h,$J){if(this._writev)this._writev([{chunk:C,encoding:h}],$J);else throw new y("_write()")},U.prototype._writev=null,U.prototype.end=function(C,h,$J){let qJ=this._writableState;typeof C=="function"?($J=C,C=null,h=null):typeof h=="function"&&($J=h,h=null);let ZJ;if(C!=null){let mJ=H(this,C,h);mJ instanceof B&&(ZJ=mJ)}return qJ.corked&&(qJ.corked=1,this.uncork()),ZJ||(!qJ.errored&&!qJ.ending?(qJ.ending=!0,e(this,qJ,!0),qJ.ended=!0):qJ.finished?ZJ=new VJ("end"):qJ.destroyed&&(ZJ=new JJ("end"))),typeof $J=="function"&&(ZJ||qJ.finished?R.nextTick($J,ZJ):qJ[Z].push($J)),this};function GJ(C){return C.ending&&!C.destroyed&&C.constructed&&C.length===0&&!C.errored&&C.buffered.length===0&&!C.finished&&!C.writing&&!C.errorEmitted&&!C.closeEmitted}function n(C,h){let $J=!1;function qJ(ZJ){if($J){J(C,ZJ??m());return}if($J=!0,h.pendingcb--,ZJ){let mJ=h[Z].splice(0);for(let BJ=0;BJ<mJ.length;BJ++)mJ[BJ](ZJ);J(C,ZJ,h.sync)}else GJ(h)&&(h.prefinished=!0,C.emit("prefinish"),h.pendingcb++,R.nextTick(PJ,C,h))}h.sync=!0,h.pendingcb++;try{C._final(qJ)}catch(ZJ){qJ(ZJ)}h.sync=!1}function p(C,h){!h.prefinished&&!h.finalCalled&&(typeof C._final=="function"&&!h.destroyed?(h.finalCalled=!0,n(C,h)):(h.prefinished=!0,C.emit("prefinish")))}function e(C,h,$J){GJ(h)&&(p(C,h),h.pendingcb===0&&($J?(h.pendingcb++,R.nextTick((qJ,ZJ)=>{GJ(ZJ)?PJ(qJ,ZJ):ZJ.pendingcb--},C,h)):GJ(h)&&(h.pendingcb++,PJ(C,h))))}function PJ(C,h){h.pendingcb--,h.finished=!0;let $J=h[Z].splice(0);for(let qJ=0;qJ<$J.length;qJ++)$J[qJ]();if(C.emit("finish"),h.autoDestroy){let qJ=C._readableState;(!qJ||qJ.autoDestroy&&(qJ.endEmitted||qJ.readable===!1))&&C.destroy()}}Y(U.prototype,{closed:{__proto__:null,get(){return this._writableState?this._writableState.closed:!1}},destroyed:{__proto__:null,get(){return this._writableState?this._writableState.destroyed:!1},set(C){this._writableState&&(this._writableState.destroyed=C)}},writable:{__proto__:null,get(){let C=this._writableState;return!!C&&C.writable!==!1&&!C.destroyed&&!C.errored&&!C.ending&&!C.ended},set(C){this._writableState&&(this._writableState.writable=!!C)}},writableFinished:{__proto__:null,get(){return this._writableState?this._writableState.finished:!1}},writableObjectMode:{__proto__:null,get(){return this._writableState?this._writableState.objectMode:!1}},writableBuffer:{__proto__:null,get(){return this._writableState&&this._writableState.getBuffer()}},writableEnded:{__proto__:null,get(){return this._writableState?this._writableState.ending:!1}},writableNeedDrain:{__proto__:null,get(){let C=this._writableState;return C?!C.destroyed&&!C.ending&&C.needDrain:!1}},writableHighWaterMark:{__proto__:null,get(){return this._writableState&&this._writableState.highWaterMark}},writableCorked:{__proto__:null,get(){return this._writableState?this._writableState.corked:0}},writableLength:{__proto__:null,get(){return this._writableState&&this._writableState.length}},errored:{__proto__:null,enumerable:!1,get(){return this._writableState?this._writableState.errored:null}},writableAborted:{__proto__:null,enumerable:!1,get:function(){return!!(this._writableState.writable!==!1&&(this._writableState.destroyed||this._writableState.errored)&&!this._writableState.finished)}}});var XJ=P.destroy;U.prototype.destroy=function(C,h){let $J=this._writableState;return!$J.destroyed&&($J.bufferedIndex<$J.buffered.length||$J[Z].length)&&R.nextTick(t,$J),XJ.call(this,C,h),this},U.prototype._undestroy=P.undestroy,U.prototype._destroy=function(C,h){h(C)},U.prototype[I.captureRejectionSymbol]=function(C){this.destroy(C)};var WJ;function b(){return WJ===void 0&&(WJ={}),WJ}U.fromWeb=function(C,h){return b().newStreamWritableFromWritableStream(C,h)},U.toWeb=function(C){return b().newWritableStreamFromStreamWritable(C)}}),O8=OJ((l,g)=>{var R=(aQ(),fQ(lQ)),M=yQ(),{isReadable:B,isWritable:A,isIterable:q,isNodeStream:Y,isReadableNodeStream:E,isWritableNodeStream:O,isDuplexNodeStream:N}=tQ(),W=eQ(),{AbortError:I,codes:{ERR_INVALID_ARG_TYPE:z,ERR_INVALID_RETURN_VALUE:j}}=gQ(),{destroyer:P}=qV(),F=sQ(),v=DV(),{createDeferredPromise:S}=iQ(),w=v0(),y=globalThis.Blob||M.Blob,m=typeof y<"u"?function(jJ){return jJ instanceof y}:function(jJ){return!1},i=globalThis.AbortController||lV().AbortController,{FunctionPrototypeCall:JJ}=bQ(),VJ=class extends F{constructor(jJ){super(jJ),jJ?.readable===!1&&(this._readableState.readable=!1,this._readableState.ended=!0,this._readableState.endEmitted=!0),jJ?.writable===!1&&(this._writableState.writable=!1,this._writableState.ending=!0,this._writableState.ended=!0,this._writableState.finished=!0)}};g.exports=function jJ(J,V){if(N(J))return J;if(E(J))return o({readable:J});if(O(J))return o({writable:J});if(Y(J))return o({writable:!1,readable:!1});if(typeof J=="function"){let{value:$,write:X,final:U,destroy:H}=HJ(J);if(q($))return w(VJ,$,{objectMode:!0,write:X,final:U,destroy:H});let G=$?.then;if(typeof G=="function"){let Q,K=JJ(G,$,(k)=>{if(k!=null)throw new j("nully","body",k)},(k)=>{P(Q,k)});return Q=new VJ({objectMode:!0,readable:!1,write:X,final(k){U(async()=>{try{await K,R.nextTick(k,null)}catch(L){R.nextTick(k,L)}})},destroy:H})}throw new j("Iterable, AsyncIterable or AsyncFunction",V,$)}if(m(J))return jJ(J.arrayBuffer());if(q(J))return w(VJ,J,{objectMode:!0,writable:!1});if(typeof J?.writable=="object"||typeof J?.readable=="object"){let $=J!=null&&J.readable?E(J?.readable)?J?.readable:jJ(J.readable):void 0,X=J!=null&&J.writable?O(J?.writable)?J?.writable:jJ(J.writable):void 0;return o({readable:$,writable:X})}let Z=J?.then;if(typeof Z=="function"){let $;return JJ(Z,J,(X)=>{X!=null&&$.push(X),$.push(null)},(X)=>{P($,X)}),$=new VJ({objectMode:!0,writable:!1,read(){}})}throw new z(V,["Blob","ReadableStream","WritableStream","Stream","Iterable","AsyncIterable","Function","{ readable, writable } pair","Promise"],J)};function HJ(jJ){let{promise:J,resolve:V}=S(),Z=new i,$=Z.signal;return{value:jJ(async function*(){for(;;){let X=J;J=null;let{chunk:U,done:H,cb:G}=await X;if(R.nextTick(G),H)return;if($.aborted)throw new I(void 0,{cause:$.reason});({promise:J,resolve:V}=S()),yield U}}(),{signal:$}),write(X,U,H){let G=V;V=null,G({chunk:X,done:!1,cb:H})},final(X){let U=V;V=null,U({done:!0,cb:X})},destroy(X,U){Z.abort(),U(X)}}}function o(jJ){let J=jJ.readable&&typeof jJ.readable.read!="function"?v.wrap(jJ.readable):jJ.readable,V=jJ.writable,Z=!!B(J),$=!!A(V),X,U,H,G,Q;function K(k){let L=G;G=null,L?L(k):k?Q.destroy(k):!Z&&!$&&Q.destroy()}return Q=new VJ({readableObjectMode:!!(J!=null&&J.readableObjectMode),writableObjectMode:!!(V!=null&&V.writableObjectMode),readable:Z,writable:$}),$&&(W(V,(k)=>{$=!1,k&&P(J,k),K(k)}),Q._write=function(k,L,_){V.write(k,L)?_():X=_},Q._final=function(k){V.end(),U=k},V.on("drain",function(){if(X){let k=X;X=null,k()}}),V.on("finish",function(){if(U){let k=U;U=null,k()}})),Z&&(W(J,(k)=>{Z=!1,k&&P(J,k),K(k)}),J.on("readable",function(){if(H){let k=H;H=null,k()}}),J.on("end",function(){Q.push(null)}),Q._read=function(){for(;;){let k=J.read();if(k===null){H=Q._read;return}if(!Q.push(k))return}}),Q._destroy=function(k,L){!k&&G!==null&&(k=new I),H=null,X=null,U=null,G===null?L(k):(G=L,P(V,k),P(J,k))},Q}}),sQ=OJ((l,g)=>{var{ObjectDefineProperties:R,ObjectGetOwnPropertyDescriptor:M,ObjectKeys:B,ObjectSetPrototypeOf:A}=bQ();g.exports=E;var q=DV(),Y=M0();A(E.prototype,q.prototype),A(E,q);{let I=B(Y.prototype);for(let z=0;z<I.length;z++){let j=I[z];E.prototype[j]||(E.prototype[j]=Y.prototype[j])}}function E(I){if(!(this instanceof E))return new E(I);q.call(this,I),Y.call(this,I),I?(this.allowHalfOpen=I.allowHalfOpen!==!1,I.readable===!1&&(this._readableState.readable=!1,this._readableState.ended=!0,this._readableState.endEmitted=!0),I.writable===!1&&(this._writableState.writable=!1,this._writableState.ending=!0,this._writableState.ended=!0,this._writableState.finished=!0)):this.allowHalfOpen=!0}R(E.prototype,{writable:{__proto__:null,...M(Y.prototype,"writable")},writableHighWaterMark:{__proto__:null,...M(Y.prototype,"writableHighWaterMark")},writableObjectMode:{__proto__:null,...M(Y.prototype,"writableObjectMode")},writableBuffer:{__proto__:null,...M(Y.prototype,"writableBuffer")},writableLength:{__proto__:null,...M(Y.prototype,"writableLength")},writableFinished:{__proto__:null,...M(Y.prototype,"writableFinished")},writableCorked:{__proto__:null,...M(Y.prototype,"writableCorked")},writableEnded:{__proto__:null,...M(Y.prototype,"writableEnded")},writableNeedDrain:{__proto__:null,...M(Y.prototype,"writableNeedDrain")},destroyed:{__proto__:null,get(){return this._readableState===void 0||this._writableState===void 0?!1:this._readableState.destroyed&&this._writableState.destroyed},set(I){this._readableState&&this._writableState&&(this._readableState.destroyed=I,this._writableState.destroyed=I)}}});var O;function N(){return O===void 0&&(O={}),O}E.fromWeb=function(I,z){return N().newStreamDuplexFromReadableWritablePair(I,z)},E.toWeb=function(I){return N().newReadableWritablePairFromDuplex(I)};var W;E.from=function(I){return W||(W=O8()),W(I,"body")}}),_0=OJ((l,g)=>{var{ObjectSetPrototypeOf:R,Symbol:M}=bQ();g.exports=E;var{ERR_METHOD_NOT_IMPLEMENTED:B}=gQ().codes,A=sQ(),{getHighWaterMark:q}=nV();R(E.prototype,A.prototype),R(E,A);var Y=M("kCallback");function E(W){if(!(this instanceof E))return new E(W);let I=W?q(this,W,"readableHighWaterMark",!0):null;I===0&&(W={...W,highWaterMark:null,readableHighWaterMark:I,writableHighWaterMark:W.writableHighWaterMark||0}),A.call(this,W),this._readableState.sync=!1,this[Y]=null,W&&(typeof W.transform=="function"&&(this._transform=W.transform),typeof W.flush=="function"&&(this._flush=W.flush)),this.on("prefinish",N)}function O(W){typeof this._flush=="function"&&!this.destroyed?this._flush((I,z)=>{if(I){W?W(I):this.destroy(I);return}z!=null&&this.push(z),this.push(null),W&&W()}):(this.push(null),W&&W())}function N(){this._final!==O&&O.call(this)}E.prototype._final=O,E.prototype._transform=function(W,I,z){throw new B("_transform()")},E.prototype._write=function(W,I,z){let j=this._readableState,P=this._writableState,F=j.length;this._transform(W,I,(v,S)=>{if(v){z(v);return}S!=null&&this.push(S),P.ended||F===j.length||j.length<j.highWaterMark?z():this[Y]=z})},E.prototype._read=function(){if(this[Y]){let W=this[Y];this[Y]=null,W()}}}),b0=OJ((l,g)=>{var{ObjectSetPrototypeOf:R}=bQ();g.exports=B;var M=_0();R(B.prototype,M.prototype),R(B,M);function B(A){if(!(this instanceof B))return new B(A);M.call(this,A)}B.prototype._transform=function(A,q,Y){Y(null,A)}}),oV=OJ((l,g)=>{var R=(aQ(),fQ(lQ)),{ArrayIsArray:M,Promise:B,SymbolAsyncIterator:A}=bQ(),q=eQ(),{once:Y}=iQ(),E=qV(),O=sQ(),{aggregateTwoErrors:N,codes:{ERR_INVALID_ARG_TYPE:W,ERR_INVALID_RETURN_VALUE:I,ERR_MISSING_ARGS:z,ERR_STREAM_DESTROYED:j,ERR_STREAM_PREMATURE_CLOSE:P},AbortError:F}=gQ(),{validateFunction:v,validateAbortSignal:S}=FV(),{isIterable:w,isReadable:y,isReadableNodeStream:m,isNodeStream:i}=tQ(),JJ=globalThis.AbortController||lV().AbortController,VJ,HJ;function o(H,G,Q){let K=!1;H.on("close",()=>{K=!0});let k=q(H,{readable:G,writable:Q},(L)=>{K=!L});return{destroy:(L)=>{K||(K=!0,E.destroyer(H,L||new j("pipe")))},cleanup:k}}function jJ(H){return v(H[H.length-1],"streams[stream.length - 1]"),H.pop()}function J(H){if(w(H))return H;if(m(H))return V(H);throw new W("val",["Readable","Iterable","AsyncIterable"],H)}async function*V(H){HJ||(HJ=DV()),yield*HJ.prototype[A].call(H)}async function Z(H,G,Q,{end:K}){let k,L=null,_=(GJ)=>{if(GJ&&(k=GJ),L){let n=L;L=null,n()}},t=()=>new B((GJ,n)=>{k?n(k):L=()=>{k?n(k):GJ()}});G.on("drain",_);let QJ=q(G,{readable:!1},_);try{G.writableNeedDrain&&await t();for await(let GJ of H)G.write(GJ)||await t();K&&G.end(),await t(),Q()}catch(GJ){Q(k!==GJ?N(k,GJ):GJ)}finally{QJ(),G.off("drain",_)}}function $(...H){return X(H,Y(jJ(H)))}function X(H,G,Q){if(H.length===1&&M(H[0])&&(H=H[0]),H.length<2)throw new z("streams");let K=new JJ,k=K.signal,L=Q?.signal,_=[];S(L,"options.signal");function t(){PJ(new F)}L?.addEventListener("abort",t);let QJ,GJ,n=[],p=0;function e(C){PJ(C,--p===0)}function PJ(C,h){if(C&&(!QJ||QJ.code==="ERR_STREAM_PREMATURE_CLOSE")&&(QJ=C),!(!QJ&&!h)){for(;n.length;)n.shift()(QJ);L?.removeEventListener("abort",t),K.abort(),h&&(QJ||_.forEach(($J)=>$J()),R.nextTick(G,QJ,GJ))}}let XJ;for(let C=0;C<H.length;C++){let h=H[C],$J=C<H.length-1,qJ=C>0,ZJ=$J||Q?.end!==!1,mJ=C===H.length-1;if(i(h)){let BJ=function(TJ){TJ&&TJ.name!=="AbortError"&&TJ.code!=="ERR_STREAM_PREMATURE_CLOSE"&&e(TJ)};var WJ=BJ;if(ZJ){let{destroy:TJ,cleanup:dJ}=o(h,$J,qJ);n.push(TJ),y(h)&&mJ&&_.push(dJ)}h.on("error",BJ),y(h)&&mJ&&_.push(()=>{h.removeListener("error",BJ)})}if(C===0)if(typeof h=="function"){if(XJ=h({signal:k}),!w(XJ))throw new I("Iterable, AsyncIterable or Stream","source",XJ)}else w(h)||m(h)?XJ=h:XJ=O.from(h);else if(typeof h=="function")if(XJ=J(XJ),XJ=h(XJ,{signal:k}),$J){if(!w(XJ,!0))throw new I("AsyncIterable",`transform[${C-1}]`,XJ)}else{var b;VJ||(VJ=b0());let BJ=new VJ({objectMode:!0}),TJ=(b=XJ)===null||b===void 0?void 0:b.then;if(typeof TJ=="function")p++,TJ.call(XJ,(IJ)=>{GJ=IJ,IJ!=null&&BJ.write(IJ),ZJ&&BJ.end(),R.nextTick(e)},(IJ)=>{BJ.destroy(IJ),R.nextTick(e,IJ)});else if(w(XJ,!0))p++,Z(XJ,BJ,e,{end:ZJ});else throw new I("AsyncIterable or Promise","destination",XJ);XJ=BJ;let{destroy:dJ,cleanup:LJ}=o(XJ,!1,!0);n.push(dJ),mJ&&_.push(LJ)}else if(i(h)){if(m(XJ)){p+=2;let BJ=U(XJ,h,e,{end:ZJ});y(h)&&mJ&&_.push(BJ)}else if(w(XJ))p++,Z(XJ,h,e,{end:ZJ});else throw new W("val",["Readable","Iterable","AsyncIterable"],XJ);XJ=h}else XJ=O.from(h)}return(k!=null&&k.aborted||L!=null&&L.aborted)&&R.nextTick(t),XJ}function U(H,G,Q,{end:K}){let k=!1;return G.on("close",()=>{k||Q(new P)}),H.pipe(G,{end:K}),K?H.once("end",()=>{k=!0,G.end()}):Q(),q(H,{readable:!0,writable:!1},(L)=>{let _=H._readableState;L&&L.code==="ERR_STREAM_PREMATURE_CLOSE"&&_&&_.ended&&!_.errored&&!_.errorEmitted?H.once("end",Q).once("error",Q):Q(L)}),q(G,{readable:!1,writable:!0},Q)}g.exports={pipelineImpl:X,pipeline:$}}),j8=OJ((l,g)=>{var{pipeline:R}=oV(),M=sQ(),{destroyer:B}=qV(),{isNodeStream:A,isReadable:q,isWritable:Y}=tQ(),{AbortError:E,codes:{ERR_INVALID_ARG_VALUE:O,ERR_MISSING_ARGS:N}}=gQ();g.exports=function(...W){if(W.length===0)throw new N("streams");if(W.length===1)return M.from(W[0]);let I=[...W];if(typeof W[0]=="function"&&(W[0]=M.from(W[0])),typeof W[W.length-1]=="function"){let JJ=W.length-1;W[JJ]=M.from(W[JJ])}for(let JJ=0;JJ<W.length;++JJ)if(A(W[JJ])){if(JJ<W.length-1&&!q(W[JJ]))throw new O(`streams[${JJ}]`,I[JJ],"must be readable");if(JJ>0&&!Y(W[JJ]))throw new O(`streams[${JJ}]`,I[JJ],"must be writable")}let z,j,P,F,v;function S(JJ){let VJ=F;F=null,VJ?VJ(JJ):JJ?v.destroy(JJ):!i&&!m&&v.destroy()}let w=W[0],y=R(W,S),m=!!Y(w),i=!!q(y);return v=new M({writableObjectMode:!!(w!=null&&w.writableObjectMode),readableObjectMode:!!(y!=null&&y.writableObjectMode),writable:m,readable:i}),m&&(v._write=function(JJ,VJ,HJ){w.write(JJ,VJ)?HJ():z=HJ},v._final=function(JJ){w.end(),j=JJ},w.on("drain",function(){if(z){let JJ=z;z=null,JJ()}}),y.on("finish",function(){if(j){let JJ=j;j=null,JJ()}})),i&&(y.on("readable",function(){if(P){let JJ=P;P=null,JJ()}}),y.on("end",function(){v.push(null)}),v._read=function(){for(;;){let JJ=y.read();if(JJ===null){P=v._read;return}if(!v.push(JJ))return}}),v._destroy=function(JJ,VJ){!JJ&&F!==null&&(JJ=new E),P=null,z=null,j=null,F===null?VJ(JJ):(F=VJ,B(y,JJ))},v}}),y0=OJ((l,g)=>{var{ArrayPrototypePop:R,Promise:M}=bQ(),{isIterable:B,isNodeStream:A}=tQ(),{pipelineImpl:q}=oV(),{finished:Y}=eQ();function E(...O){return new M((N,W)=>{let I,z,j=O[O.length-1];if(j&&typeof j=="object"&&!A(j)&&!B(j)){let P=R(O);I=P.signal,z=P.end}q(O,(P,F)=>{P?W(P):N(F)},{signal:I,end:z})})}g.exports={finished:Y,pipeline:E}}),T8=OJ((l,g)=>{var{Buffer:R}=yQ(),{ObjectDefineProperty:M,ObjectKeys:B,ReflectApply:A}=bQ(),{promisify:{custom:q}}=iQ(),{streamReturningOperators:Y,promiseReturningOperators:E}=Y8(),{codes:{ERR_ILLEGAL_CONSTRUCTOR:O}}=gQ(),N=j8(),{pipeline:W}=oV(),{destroyer:I}=qV(),z=eQ(),j=y0(),P=tQ(),F=g.exports=sV().Stream;F.isDisturbed=P.isDisturbed,F.isErrored=P.isErrored,F.isReadable=P.isReadable,F.Readable=DV();for(let w of B(Y)){let y=function(...i){if(new.target)throw O();return F.Readable.from(A(m,this,i))};v=y;let m=Y[w];M(y,"name",{__proto__:null,value:m.name}),M(y,"length",{__proto__:null,value:m.length}),M(F.Readable.prototype,w,{__proto__:null,value:y,enumerable:!1,configurable:!0,writable:!0})}var v;for(let w of B(E)){let y=function(...i){if(new.target)throw O();return A(m,this,i)};v=y;let m=E[w];M(y,"name",{__proto__:null,value:m.name}),M(y,"length",{__proto__:null,value:m.length}),M(F.Readable.prototype,w,{__proto__:null,value:y,enumerable:!1,configurable:!0,writable:!0})}var v;F.Writable=M0(),F.Duplex=sQ(),F.Transform=_0(),F.PassThrough=b0(),F.pipeline=W;var{addAbortSignal:S}=dV();F.addAbortSignal=S,F.finished=z,F.destroy=I,F.compose=N,M(F,"promises",{__proto__:null,configurable:!0,enumerable:!0,get(){return j}}),M(W,q,{__proto__:null,enumerable:!0,get(){return j.pipeline}}),M(z,q,{__proto__:null,enumerable:!0,get(){return j.finished}}),F.Stream=F,F._isUint8Array=function(w){return w instanceof Uint8Array},F._uint8ArrayToBuffer=function(w){return R.from(w.buffer,w.byteOffset,w.byteLength)}}),g0=OJ((l,g)=>{var R=T8(),M=y0(),B=R.Readable.destroy;g.exports=R.Readable,g.exports._uint8ArrayToBuffer=R._uint8ArrayToBuffer,g.exports._isUint8Array=R._isUint8Array,g.exports.isDisturbed=R.isDisturbed,g.exports.isErrored=R.isErrored,g.exports.isReadable=R.isReadable,g.exports.Readable=R.Readable,g.exports.Writable=R.Writable,g.exports.Duplex=R.Duplex,g.exports.Transform=R.Transform,g.exports.PassThrough=R.PassThrough,g.exports.addAbortSignal=R.addAbortSignal,g.exports.finished=R.finished,g.exports.destroy=R.destroy,g.exports.destroy=B,g.exports.pipeline=R.pipeline,g.exports.compose=R.compose,Object.defineProperty(R,"promises",{configurable:!0,enumerable:!0,get(){return M}}),g.exports.Stream=R.Stream,g.exports.default=g.exports}),rV={},RV(rV,{default:()=>N8}),I8=cV(()=>{fV(rV,oQ(g0())),N8=oQ(g0())}),nQ=OJ((l,g)=>{var R=XQ().Buffer,M=(I8(),fQ(rV)).Transform,B=hV().StringDecoder,A=JQ();function q(Y){M.call(this),this.hashMode=typeof Y=="string",this.hashMode?this[Y]=this._finalOrDigest:this.final=this._finalOrDigest,this._final&&(this.__final=this._final,this._final=null),this._decoder=null,this._encoding=null}A(q,M),q.prototype.update=function(Y,E,O){typeof Y=="string"&&(Y=R.from(Y,E));var N=this._update(Y);return this.hashMode?this:(O&&(N=this._toString(N,O)),N)},q.prototype.setAutoPadding=function(){},q.prototype.getAuthTag=function(){throw new Error("trying to get auth tag in unsupported state")},q.prototype.setAuthTag=function(){throw new Error("trying to set auth tag in unsupported state")},q.prototype.setAAD=function(){throw new Error("trying to set aad in unsupported state")},q.prototype._transform=function(Y,E,O){var N;try{this.hashMode?this._update(Y):this.push(this._update(Y))}catch(W){N=W}finally{O(N)}},q.prototype._flush=function(Y){var E;try{this.push(this.__final())}catch(O){E=O}Y(E)},q.prototype._finalOrDigest=function(Y){var E=this.__final()||R.alloc(0);return Y&&(E=this._toString(E,Y,!0)),E},q.prototype._toString=function(Y,E,O){if(this._decoder||(this._decoder=new B(E),this._encoding=E),this._encoding!==E)throw new Error("can't switch encodings");var N=this._decoder.write(Y);return O&&(N+=this._decoder.end()),N},g.exports=q}),WV=OJ((l,g)=>{var R=JQ(),M=uV(),B=pV(),A=iV(),q=nQ();function Y(E){q.call(this,"digest"),this._hash=E}R(Y,q),Y.prototype._update=function(E){this._hash.update(E)},Y.prototype._final=function(){return this._hash.digest()},g.exports=function(E){return E=E.toLowerCase(),E==="md5"?new M:E==="rmd160"||E==="ripemd160"?new B:new Y(A(E))}}),E8=OJ((l,g)=>{var R=JQ(),M=XQ().Buffer,B=nQ(),A=M.alloc(128),q=64;function Y(E,O){B.call(this,"digest"),typeof O=="string"&&(O=M.from(O)),this._alg=E,this._key=O,O.length>q?O=E(O):O.length<q&&(O=M.concat([O,A],q));for(var N=this._ipad=M.allocUnsafe(q),W=this._opad=M.allocUnsafe(q),I=0;I<q;I++)N[I]=O[I]^54,W[I]=O[I]^92;this._hash=[N]}R(Y,B),Y.prototype._update=function(E){this._hash.push(E)},Y.prototype._final=function(){var E=this._alg(M.concat(this._hash));return this._alg(M.concat([this._opad,E]))},g.exports=Y}),c0=OJ((l,g)=>{var R=uV();g.exports=function(M){return new R().update(M).digest()}}),f0=OJ((l,g)=>{var R=JQ(),M=E8(),B=nQ(),A=XQ().Buffer,q=c0(),Y=pV(),E=iV(),O=A.alloc(128);function N(W,I){B.call(this,"digest"),typeof I=="string"&&(I=A.from(I));var z=W==="sha512"||W==="sha384"?128:64;if(this._alg=W,this._key=I,I.length>z){var j=W==="rmd160"?new Y:E(W);I=j.update(I).digest()}else I.length<z&&(I=A.concat([I,O],z));for(var P=this._ipad=A.allocUnsafe(z),F=this._opad=A.allocUnsafe(z),v=0;v<z;v++)P[v]=I[v]^54,F[v]=I[v]^92;this._hash=W==="rmd160"?new Y:E(W),this._hash.update(P)}R(N,B),N.prototype._update=function(W){this._hash.update(W)},N.prototype._final=function(){var W=this._hash.digest(),I=this._alg==="rmd160"?new Y:E(this._alg);return I.update(this._opad).update(W).digest()},g.exports=function(W,I){return W=W.toLowerCase(),W==="rmd160"||W==="ripemd160"?new N("rmd160",I):W==="md5"?new M(q,I):new N(W,I)}}),h0=OJ((l,g)=>{g.exports={sha224WithRSAEncryption:{sign:"rsa",hash:"sha224",id:"302d300d06096086480165030402040500041c"},"RSA-SHA224":{sign:"ecdsa/rsa",hash:"sha224",id:"302d300d06096086480165030402040500041c"},sha256WithRSAEncryption:{sign:"rsa",hash:"sha256",id:"3031300d060960864801650304020105000420"},"RSA-SHA256":{sign:"ecdsa/rsa",hash:"sha256",id:"3031300d060960864801650304020105000420"},sha384WithRSAEncryption:{sign:"rsa",hash:"sha384",id:"3041300d060960864801650304020205000430"},"RSA-SHA384":{sign:"ecdsa/rsa",hash:"sha384",id:"3041300d060960864801650304020205000430"},sha512WithRSAEncryption:{sign:"rsa",hash:"sha512",id:"3051300d060960864801650304020305000440"},"RSA-SHA512":{sign:"ecdsa/rsa",hash:"sha512",id:"3051300d060960864801650304020305000440"},"RSA-SHA1":{sign:"rsa",hash:"sha1",id:"3021300906052b0e03021a05000414"},"ecdsa-with-SHA1":{sign:"ecdsa",hash:"sha1",id:""},sha256:{sign:"ecdsa",hash:"sha256",id:""},sha224:{sign:"ecdsa",hash:"sha224",id:""},sha384:{sign:"ecdsa",hash:"sha384",id:""},sha512:{sign:"ecdsa",hash:"sha512",id:""},"DSA-SHA":{sign:"dsa",hash:"sha1",id:""},"DSA-SHA1":{sign:"dsa",hash:"sha1",id:""},DSA:{sign:"dsa",hash:"sha1",id:""},"DSA-WITH-SHA224":{sign:"dsa",hash:"sha224",id:""},"DSA-SHA224":{sign:"dsa",hash:"sha224",id:""},"DSA-WITH-SHA256":{sign:"dsa",hash:"sha256",id:""},"DSA-SHA256":{sign:"dsa",hash:"sha256",id:""},"DSA-WITH-SHA384":{sign:"dsa",hash:"sha384",id:""},"DSA-SHA384":{sign:"dsa",hash:"sha384",id:""},"DSA-WITH-SHA512":{sign:"dsa",hash:"sha512",id:""},"DSA-SHA512":{sign:"dsa",hash:"sha512",id:""},"DSA-RIPEMD160":{sign:"dsa",hash:"rmd160",id:""},ripemd160WithRSA:{sign:"rsa",hash:"rmd160",id:"3021300906052b2403020105000414"},"RSA-RIPEMD160":{sign:"rsa",hash:"rmd160",id:"3021300906052b2403020105000414"},md5WithRSAEncryption:{sign:"rsa",hash:"md5",id:"3020300c06082a864886f70d020505000410"},"RSA-MD5":{sign:"rsa",hash:"md5",id:"3020300c06082a864886f70d020505000410"}}}),R8=OJ((l,g)=>{g.exports=h0()}),m0=OJ((l,g)=>{var R=Math.pow(2,30)-1;g.exports=function(M,B){if(typeof M!="number")throw new TypeError("Iterations not a number");if(M<0)throw new TypeError("Bad iterations");if(typeof B!="number")throw new TypeError("Key length not a number");if(B<0||B>R||B!==B)throw new TypeError("Bad key length")}}),u0=OJ((l,g)=>{var R;global.process&&global.process.browser?R="utf-8":global.process&&global.process.version?(M=parseInt(process.version.split(".")[0].slice(1),10),R=M>=6?"utf-8":"binary"):R="utf-8";var M;g.exports=R}),p0=OJ((l,g)=>{var R=XQ().Buffer;g.exports=function(M,B,A){if(R.isBuffer(M))return M;if(typeof M=="string")return R.from(M,B);if(ArrayBuffer.isView(M))return R.from(M.buffer);throw new TypeError(A+" must be a string, a Buffer, a typed array or a DataView")}}),i0=OJ((l,g)=>{var R=c0(),M=pV(),B=iV(),A=XQ().Buffer,q=m0(),Y=u0(),E=p0(),O=A.alloc(128),N={md5:16,sha1:20,sha224:28,sha256:32,sha384:48,sha512:64,rmd160:20,ripemd160:20};function W(j,P,F){var v=I(j),S=j==="sha512"||j==="sha384"?128:64;P.length>S?P=v(P):P.length<S&&(P=A.concat([P,O],S));for(var w=A.allocUnsafe(S+N[j]),y=A.allocUnsafe(S+N[j]),m=0;m<S;m++)w[m]=P[m]^54,y[m]=P[m]^92;var i=A.allocUnsafe(S+F+4);w.copy(i,0,0,S),this.ipad1=i,this.ipad2=w,this.opad=y,this.alg=j,this.blocksize=S,this.hash=v,this.size=N[j]}W.prototype.run=function(j,P){j.copy(P,this.blocksize);var F=this.hash(P);return F.copy(this.opad,this.blocksize),this.hash(this.opad)};function I(j){function P(v){return B(j).update(v).digest()}function F(v){return new M().update(v).digest()}return j==="rmd160"||j==="ripemd160"?F:j==="md5"?R:P}function z(j,P,F,v,S){q(F,v),j=E(j,Y,"Password"),P=E(P,Y,"Salt"),S=S||"sha1";var w=new W(S,j,P.length),y=A.allocUnsafe(v),m=A.allocUnsafe(P.length+4);P.copy(m,0,0,P.length);for(var i=0,JJ=N[S],VJ=Math.ceil(v/JJ),HJ=1;HJ<=VJ;HJ++){m.writeUInt32BE(HJ,P.length);for(var o=w.run(m,w.ipad1),jJ=o,J=1;J<F;J++){jJ=w.run(jJ,w.ipad2);for(var V=0;V<JJ;V++)o[V]^=jJ[V]}o.copy(y,i),i+=JJ}return y}g.exports=z}),z8=OJ((l,g)=>{var R=XQ().Buffer,M=m0(),B=u0(),A=i0(),q=p0(),Y,E=global.crypto&&global.crypto.subtle,O={sha:"SHA-1","sha-1":"SHA-1",sha1:"SHA-1",sha256:"SHA-256","sha-256":"SHA-256",sha384:"SHA-384","sha-384":"SHA-384","sha-512":"SHA-512",sha512:"SHA-512"},N=[];function W(F){if(global.process&&!global.process.browser||!E||!E.importKey||!E.deriveBits)return Promise.resolve(!1);if(N[F]!==void 0)return N[F];Y=Y||R.alloc(8);var v=j(Y,Y,10,128,F).then(function(){return!0}).catch(function(){return!1});return N[F]=v,v}var I;function z(){return I||(global.process&&global.process.nextTick?I=global.process.nextTick:global.queueMicrotask?I=global.queueMicrotask:global.setImmediate?I=global.setImmediate:I=global.setTimeout,I)}function j(F,v,S,w,y){return E.importKey("raw",F,{name:"PBKDF2"},!1,["deriveBits"]).then(function(m){return E.deriveBits({name:"PBKDF2",salt:v,iterations:S,hash:{name:y}},m,w<<3)}).then(function(m){return R.from(m)})}function P(F,v){F.then(function(S){z()(function(){v(null,S)})},function(S){z()(function(){v(S)})})}g.exports=function(F,v,S,w,y,m){typeof y=="function"&&(m=y,y=void 0),y=y||"sha1";var i=O[y.toLowerCase()];if(!i||typeof global.Promise!="function"){z()(function(){var JJ;try{JJ=A(F,v,S,w,y)}catch(VJ){return m(VJ)}m(null,JJ)});return}if(M(S,w),F=q(F,B,"Password"),v=q(v,B,"Salt"),typeof m!="function")throw new Error("No callback provided to pbkdf2");P(W(i).then(function(JJ){return JJ?j(F,v,S,w,i):A(F,v,S,w,y)}),m)}}),l0=OJ((l)=>{l.pbkdf2=z8(),l.pbkdf2Sync=i0()}),s0=OJ((l)=>{l.readUInt32BE=function(B,A){var q=B[0+A]<<24|B[1+A]<<16|B[2+A]<<8|B[3+A];return q>>>0},l.writeUInt32BE=function(B,A,q){B[0+q]=A>>>24,B[1+q]=A>>>16&255,B[2+q]=A>>>8&255,B[3+q]=A&255},l.ip=function(B,A,q,Y){for(var E=0,O=0,N=6;N>=0;N-=2){for(var W=0;W<=24;W+=8)E<<=1,E|=A>>>W+N&1;for(var W=0;W<=24;W+=8)E<<=1,E|=B>>>W+N&1}for(var N=6;N>=0;N-=2){for(var W=1;W<=25;W+=8)O<<=1,O|=A>>>W+N&1;for(var W=1;W<=25;W+=8)O<<=1,O|=B>>>W+N&1}q[Y+0]=E>>>0,q[Y+1]=O>>>0},l.rip=function(B,A,q,Y){for(var E=0,O=0,N=0;N<4;N++)for(var W=24;W>=0;W-=8)E<<=1,E|=A>>>W+N&1,E<<=1,E|=B>>>W+N&1;for(var N=4;N<8;N++)for(var W=24;W>=0;W-=8)O<<=1,O|=A>>>W+N&1,O<<=1,O|=B>>>W+N&1;q[Y+0]=E>>>0,q[Y+1]=O>>>0},l.pc1=function(B,A,q,Y){for(var E=0,O=0,N=7;N>=5;N--){for(var W=0;W<=24;W+=8)E<<=1,E|=A>>W+N&1;for(var W=0;W<=24;W+=8)E<<=1,E|=B>>W+N&1}for(var W=0;W<=24;W+=8)E<<=1,E|=A>>W+N&1;for(var N=1;N<=3;N++){for(var W=0;W<=24;W+=8)O<<=1,O|=A>>W+N&1;for(var W=0;W<=24;W+=8)O<<=1,O|=B>>W+N&1}for(var W=0;W<=24;W+=8)O<<=1,O|=B>>W+N&1;q[Y+0]=E>>>0,q[Y+1]=O>>>0},l.r28shl=function(B,A){return B<<A&268435455|B>>>28-A};var g=[14,11,17,4,27,23,25,0,13,22,7,18,5,9,16,24,2,20,12,21,1,8,15,26,15,4,25,19,9,1,26,16,5,11,23,8,12,7,17,0,22,3,10,14,6,20,27,24];l.pc2=function(B,A,q,Y){for(var E=0,O=0,N=g.length>>>1,W=0;W<N;W++)E<<=1,E|=B>>>g[W]&1;for(var W=N;W<g.length;W++)O<<=1,O|=A>>>g[W]&1;q[Y+0]=E>>>0,q[Y+1]=O>>>0},l.expand=function(B,A,q){var Y=0,E=0;Y=(B&1)<<5|B>>>27;for(var O=23;O>=15;O-=4)Y<<=6,Y|=B>>>O&63;for(var O=11;O>=3;O-=4)E|=B>>>O&63,E<<=6;E|=(B&31)<<1|B>>>31,A[q+0]=Y>>>0,A[q+1]=E>>>0};var R=[14,0,4,15,13,7,1,4,2,14,15,2,11,13,8,1,3,10,10,6,6,12,12,11,5,9,9,5,0,3,7,8,4,15,1,12,14,8,8,2,13,4,6,9,2,1,11,7,15,5,12,11,9,3,7,14,3,10,10,0,5,6,0,13,15,3,1,13,8,4,14,7,6,15,11,2,3,8,4,14,9,12,7,0,2,1,13,10,12,6,0,9,5,11,10,5,0,13,14,8,7,10,11,1,10,3,4,15,13,4,1,2,5,11,8,6,12,7,6,12,9,0,3,5,2,14,15,9,10,13,0,7,9,0,14,9,6,3,3,4,15,6,5,10,1,2,13,8,12,5,7,14,11,12,4,11,2,15,8,1,13,1,6,10,4,13,9,0,8,6,15,9,3,8,0,7,11,4,1,15,2,14,12,3,5,11,10,5,14,2,7,12,7,13,13,8,14,11,3,5,0,6,6,15,9,0,10,3,1,4,2,7,8,2,5,12,11,1,12,10,4,14,15,9,10,3,6,15,9,0,0,6,12,10,11,1,7,13,13,8,15,9,1,4,3,5,14,11,5,12,2,7,8,2,4,14,2,14,12,11,4,2,1,12,7,4,10,7,11,13,6,1,8,5,5,0,3,15,15,10,13,3,0,9,14,8,9,6,4,11,2,8,1,12,11,7,10,1,13,14,7,2,8,13,15,6,9,15,12,0,5,9,6,10,3,4,0,5,14,3,12,10,1,15,10,4,15,2,9,7,2,12,6,9,8,5,0,6,13,1,3,13,4,14,14,0,7,11,5,3,11,8,9,4,14,3,15,2,5,12,2,9,8,5,12,15,3,10,7,11,0,14,4,1,10,7,1,6,13,0,11,8,6,13,4,13,11,0,2,11,14,7,15,4,0,9,8,1,13,10,3,14,12,3,9,5,7,12,5,2,10,15,6,8,1,6,1,6,4,11,11,13,13,8,12,1,3,4,7,10,14,7,10,9,15,5,6,0,8,15,0,14,5,2,9,3,2,12,13,1,2,15,8,13,4,8,6,10,15,3,11,7,1,4,10,12,9,5,3,6,14,11,5,0,0,14,12,9,7,2,7,2,11,1,4,14,1,7,9,4,12,10,14,8,2,13,0,15,6,12,10,9,13,0,15,3,3,5,5,6,8,11];l.substitute=function(B,A){for(var q=0,Y=0;Y<4;Y++){var E=B>>>18-Y*6&63,O=R[Y*64+E];q<<=4,q|=O}for(var Y=0;Y<4;Y++){var E=A>>>18-Y*6&63,O=R[256+Y*64+E];q<<=4,q|=O}return q>>>0};var M=[16,25,12,11,3,20,4,15,31,17,9,6,27,14,1,22,30,24,8,18,0,5,29,23,13,19,2,26,10,21,28,7];l.permute=function(B){for(var A=0,q=0;q<M.length;q++)A<<=1,A|=B>>>M[q]&1;return A>>>0},l.padSplit=function(B,A,q){for(var Y=B.toString(2);Y.length<A;)Y="0"+Y;for(var E=[],O=0;O<A;O+=q)E.push(Y.slice(O,O+q));return E.join(" ")}}),hQ=OJ((l,g)=>{g.exports=R;function R(M,B){if(!M)throw new Error(B||"Assertion failed")}R.equal=function(M,B,A){if(M!=B)throw new Error(A||"Assertion failed: "+M+" != "+B)}}),aV=OJ((l,g)=>{var R=hQ();function M(B){this.options=B,this.type=this.options.type,this.blockSize=8,this._init(),this.buffer=new Array(this.blockSize),this.bufferOff=0}g.exports=M,M.prototype._init=function(){},M.prototype.update=function(B){return B.length===0?[]:this.type==="decrypt"?this._updateDecrypt(B):this._updateEncrypt(B)},M.prototype._buffer=function(B,A){for(var q=Math.min(this.buffer.length-this.bufferOff,B.length-A),Y=0;Y<q;Y++)this.buffer[this.bufferOff+Y]=B[A+Y];return this.bufferOff+=q,q},M.prototype._flushBuffer=function(B,A){return this._update(this.buffer,0,B,A),this.bufferOff=0,this.blockSize},M.prototype._updateEncrypt=function(B){var A=0,q=0,Y=(this.bufferOff+B.length)/this.blockSize|0,E=new Array(Y*this.blockSize);this.bufferOff!==0&&(A+=this._buffer(B,A),this.bufferOff===this.buffer.length&&(q+=this._flushBuffer(E,q)));for(var O=B.length-(B.length-A)%this.blockSize;A<O;A+=this.blockSize)this._update(B,A,E,q),q+=this.blockSize;for(;A<B.length;A++,this.bufferOff++)this.buffer[this.bufferOff]=B[A];return E},M.prototype._updateDecrypt=function(B){for(var A=0,q=0,Y=Math.ceil((this.bufferOff+B.length)/this.blockSize)-1,E=new Array(Y*this.blockSize);Y>0;Y--)A+=this._buffer(B,A),q+=this._flushBuffer(E,q);return A+=this._buffer(B,A),E},M.prototype.final=function(B){var A;B&&(A=this.update(B));var q;return this.type==="encrypt"?q=this._finalEncrypt():q=this._finalDecrypt(),A?A.concat(q):q},M.prototype._pad=function(B,A){if(A===0)return!1;for(;A<B.length;)B[A++]=0;return!0},M.prototype._finalEncrypt=function(){if(!this._pad(this.buffer,this.bufferOff))return[];var B=new Array(this.blockSize);return this._update(this.buffer,0,B,0),B},M.prototype._unpad=function(B){return B},M.prototype._finalDecrypt=function(){R.equal(this.bufferOff,this.blockSize,"Not enough data to decrypt");var B=new Array(this.blockSize);return this._flushBuffer(B,0),this._unpad(B)}}),d0=OJ((l,g)=>{var R=hQ(),M=JQ(),B=s0(),A=aV();function q(){this.tmp=new Array(2),this.keys=null}function Y(O){A.call(this,O);var N=new q;this._desState=N,this.deriveKeys(N,O.key)}M(Y,A),g.exports=Y,Y.create=function(O){return new Y(O)};var E=[1,1,2,2,2,2,2,2,1,2,2,2,2,2,2,1];Y.prototype.deriveKeys=function(O,N){O.keys=new Array(32),R.equal(N.length,this.blockSize,"Invalid key length");var W=B.readUInt32BE(N,0),I=B.readUInt32BE(N,4);B.pc1(W,I,O.tmp,0),W=O.tmp[0],I=O.tmp[1];for(var z=0;z<O.keys.length;z+=2){var j=E[z>>>1];W=B.r28shl(W,j),I=B.r28shl(I,j),B.pc2(W,I,O.keys,z)}},Y.prototype._update=function(O,N,W,I){var z=this._desState,j=B.readUInt32BE(O,N),P=B.readUInt32BE(O,N+4);B.ip(j,P,z.tmp,0),j=z.tmp[0],P=z.tmp[1],this.type==="encrypt"?this._encrypt(z,j,P,z.tmp,0):this._decrypt(z,j,P,z.tmp,0),j=z.tmp[0],P=z.tmp[1],B.writeUInt32BE(W,j,I),B.writeUInt32BE(W,P,I+4)},Y.prototype._pad=function(O,N){for(var W=O.length-N,I=N;I<O.length;I++)O[I]=W;return!0},Y.prototype._unpad=function(O){for(var N=O[O.length-1],W=O.length-N;W<O.length;W++)R.equal(O[W],N);return O.slice(0,O.length-N)},Y.prototype._encrypt=function(O,N,W,I,z){for(var j=N,P=W,F=0;F<O.keys.length;F+=2){var v=O.keys[F],S=O.keys[F+1];B.expand(P,O.tmp,0),v^=O.tmp[0],S^=O.tmp[1];var w=B.substitute(v,S),y=B.permute(w),m=P;P=(j^y)>>>0,j=m}B.rip(P,j,I,z)},Y.prototype._decrypt=function(O,N,W,I,z){for(var j=W,P=N,F=O.keys.length-2;F>=0;F-=2){var v=O.keys[F],S=O.keys[F+1];B.expand(j,O.tmp,0),v^=O.tmp[0],S^=O.tmp[1];var w=B.substitute(v,S),y=B.permute(w),m=j;j=(P^y)>>>0,P=m}B.rip(j,P,I,z)}}),P8=OJ((l)=>{var g=hQ(),R=JQ(),M={};function B(q){g.equal(q.length,8,"Invalid IV length"),this.iv=new Array(8);for(var Y=0;Y<this.iv.length;Y++)this.iv[Y]=q[Y]}function A(q){function Y(W){q.call(this,W),this._cbcInit()}R(Y,q);for(var E=Object.keys(M),O=0;O<E.length;O++){var N=E[O];Y.prototype[N]=M[N]}return Y.create=function(W){return new Y(W)},Y}l.instantiate=A,M._cbcInit=function(){var q=new B(this.options.iv);this._cbcState=q},M._update=function(q,Y,E,O){var N=this._cbcState,W=this.constructor.super_.prototype,I=N.iv;if(this.type==="encrypt"){for(var z=0;z<this.blockSize;z++)I[z]^=q[Y+z];W._update.call(this,I,0,E,O);for(var z=0;z<this.blockSize;z++)I[z]=E[O+z]}else{W._update.call(this,q,Y,E,O);for(var z=0;z<this.blockSize;z++)E[O+z]^=I[z];for(var z=0;z<this.blockSize;z++)I[z]=q[Y+z]}}}),L8=OJ((l,g)=>{var R=hQ(),M=JQ(),B=aV(),A=d0();function q(E,O){R.equal(O.length,24,"Invalid key length");var N=O.slice(0,8),W=O.slice(8,16),I=O.slice(16,24);E==="encrypt"?this.ciphers=[A.create({type:"encrypt",key:N}),A.create({type:"decrypt",key:W}),A.create({type:"encrypt",key:I})]:this.ciphers=[A.create({type:"decrypt",key:I}),A.create({type:"encrypt",key:W}),A.create({type:"decrypt",key:N})]}function Y(E){B.call(this,E);var O=new q(this.type,this.options.key);this._edeState=O}M(Y,B),g.exports=Y,Y.create=function(E){return new Y(E)},Y.prototype._update=function(E,O,N,W){var I=this._edeState;I.ciphers[0]._update(E,O,N,W),I.ciphers[1]._update(N,W,N,W),I.ciphers[2]._update(N,W,N,W)},Y.prototype._pad=A.prototype._pad,Y.prototype._unpad=A.prototype._unpad}),F8=OJ((l)=>{l.utils=s0(),l.Cipher=aV(),l.DES=d0(),l.CBC=P8(),l.EDE=L8()}),D8=OJ((l,g)=>{var R=nQ(),M=F8(),B=JQ(),A=XQ().Buffer,q={"des-ede3-cbc":M.CBC.instantiate(M.EDE),"des-ede3":M.EDE,"des-ede-cbc":M.CBC.instantiate(M.EDE),"des-ede":M.EDE,"des-cbc":M.CBC.instantiate(M.DES),"des-ecb":M.DES};q.des=q["des-cbc"],q.des3=q["des-ede3-cbc"],g.exports=Y,B(Y,R);function Y(E){R.call(this);var O=E.mode.toLowerCase(),N=q[O],W;E.decrypt?W="decrypt":W="encrypt";var I=E.key;A.isBuffer(I)||(I=A.from(I)),(O==="des-ede"||O==="des-ede-cbc")&&(I=A.concat([I,I.slice(0,8)]));var z=E.iv;A.isBuffer(z)||(z=A.from(z)),this._des=N.create({key:I,iv:z,type:W})}Y.prototype._update=function(E){return A.from(this._des.update(E))},Y.prototype._final=function(){return A.from(this._des.final())}}),C8=OJ((l)=>{l.encrypt=function(g,R){return g._cipher.encryptBlock(R)},l.decrypt=function(g,R){return g._cipher.decryptBlock(R)}}),YV=OJ((l,g)=>{g.exports=function(R,M){for(var B=Math.min(R.length,M.length),A=new Buffer(B),q=0;q<B;++q)A[q]=R[q]^M[q];return A}}),k8=OJ((l)=>{var g=YV();l.encrypt=function(R,M){var B=g(M,R._prev);return R._prev=R._cipher.encryptBlock(B),R._prev},l.decrypt=function(R,M){var B=R._prev;R._prev=M;var A=R._cipher.decryptBlock(M);return g(A,B)}}),A8=OJ((l)=>{var g=XQ().Buffer,R=YV();function M(B,A,q){var Y=A.length,E=R(A,B._cache);return B._cache=B._cache.slice(Y),B._prev=g.concat([B._prev,q?A:E]),E}l.encrypt=function(B,A,q){for(var Y=g.allocUnsafe(0),E;A.length;)if(B._cache.length===0&&(B._cache=B._cipher.encryptBlock(B._prev),B._prev=g.allocUnsafe(0)),B._cache.length<=A.length)E=B._cache.length,Y=g.concat([Y,M(B,A.slice(0,E),q)]),A=A.slice(E);else{Y=g.concat([Y,M(B,A,q)]);break}return Y}}),S8=OJ((l)=>{var g=XQ().Buffer;function R(M,B,A){var q=M._cipher.encryptBlock(M._prev),Y=q[0]^B;return M._prev=g.concat([M._prev.slice(1),g.from([A?B:Y])]),Y}l.encrypt=function(M,B,A){for(var q=B.length,Y=g.allocUnsafe(q),E=-1;++E<q;)Y[E]=R(M,B[E],A);return Y}}),x8=OJ((l)=>{var g=XQ().Buffer;function R(B,A,q){for(var Y,E=-1,O=8,N=0,W,I;++E<O;)Y=B._cipher.encryptBlock(B._prev),W=A&1<<7-E?128:0,I=Y[0]^W,N+=(I&128)>>E%8,B._prev=M(B._prev,q?W:I);return N}function M(B,A){var q=B.length,Y=-1,E=g.allocUnsafe(B.length);for(B=g.concat([B,g.from([A])]);++Y<q;)E[Y]=B[Y]<<1|B[Y+1]>>7;return E}l.encrypt=function(B,A,q){for(var Y=A.length,E=g.allocUnsafe(Y),O=-1;++O<Y;)E[O]=R(B,A[O],q);return E}}),w8=OJ((l)=>{var g=YV();function R(M){return M._prev=M._cipher.encryptBlock(M._prev),M._prev}l.encrypt=function(M,B){for(;M._cache.length<B.length;)M._cache=Buffer.concat([M._cache,R(M)]);var A=M._cache.slice(0,B.length);return M._cache=M._cache.slice(B.length),g(B,A)}}),n0=OJ((l,g)=>{function R(M){for(var B=M.length,A;B--;)if(A=M.readUInt8(B),A===255)M.writeUInt8(0,B);else{A++,M.writeUInt8(A,B);break}}g.exports=R}),o0=OJ((l)=>{var g=YV(),R=XQ().Buffer,M=n0();function B(q){var Y=q._cipher.encryptBlockRaw(q._prev);return M(q._prev),Y}var A=16;l.encrypt=function(q,Y){var E=Math.ceil(Y.length/A),O=q._cache.length;q._cache=R.concat([q._cache,R.allocUnsafe(E*A)]);for(var N=0;N<E;N++){var W=B(q),I=O+N*A;q._cache.writeUInt32BE(W[0],I+0),q._cache.writeUInt32BE(W[1],I+4),q._cache.writeUInt32BE(W[2],I+8),q._cache.writeUInt32BE(W[3],I+12)}var z=q._cache.slice(0,Y.length);return q._cache=q._cache.slice(Y.length),g(Y,z)}}),r0=OJ((l,g)=>{g.exports={"aes-128-ecb":{cipher:"AES",key:128,iv:0,mode:"ECB",type:"block"},"aes-192-ecb":{cipher:"AES",key:192,iv:0,mode:"ECB",type:"block"},"aes-256-ecb":{cipher:"AES",key:256,iv:0,mode:"ECB",type:"block"},"aes-128-cbc":{cipher:"AES",key:128,iv:16,mode:"CBC",type:"block"},"aes-192-cbc":{cipher:"AES",key:192,iv:16,mode:"CBC",type:"block"},"aes-256-cbc":{cipher:"AES",key:256,iv:16,mode:"CBC",type:"block"},aes128:{cipher:"AES",key:128,iv:16,mode:"CBC",type:"block"},aes192:{cipher:"AES",key:192,iv:16,mode:"CBC",type:"block"},aes256:{cipher:"AES",key:256,iv:16,mode:"CBC",type:"block"},"aes-128-cfb":{cipher:"AES",key:128,iv:16,mode:"CFB",type:"stream"},"aes-192-cfb":{cipher:"AES",key:192,iv:16,mode:"CFB",type:"stream"},"aes-256-cfb":{cipher:"AES",key:256,iv:16,mode:"CFB",type:"stream"},"aes-128-cfb8":{cipher:"AES",key:128,iv:16,mode:"CFB8",type:"stream"},"aes-192-cfb8":{cipher:"AES",key:192,iv:16,mode:"CFB8",type:"stream"},"aes-256-cfb8":{cipher:"AES",key:256,iv:16,mode:"CFB8",type:"stream"},"aes-128-cfb1":{cipher:"AES",key:128,iv:16,mode:"CFB1",type:"stream"},"aes-192-cfb1":{cipher:"AES",key:192,iv:16,mode:"CFB1",type:"stream"},"aes-256-cfb1":{cipher:"AES",key:256,iv:16,mode:"CFB1",type:"stream"},"aes-128-ofb":{cipher:"AES",key:128,iv:16,mode:"OFB",type:"stream"},"aes-192-ofb":{cipher:"AES",key:192,iv:16,mode:"OFB",type:"stream"},"aes-256-ofb":{cipher:"AES",key:256,iv:16,mode:"OFB",type:"stream"},"aes-128-ctr":{cipher:"AES",key:128,iv:16,mode:"CTR",type:"stream"},"aes-192-ctr":{cipher:"AES",key:192,iv:16,mode:"CTR",type:"stream"},"aes-256-ctr":{cipher:"AES",key:256,iv:16,mode:"CTR",type:"stream"},"aes-128-gcm":{cipher:"AES",key:128,iv:12,mode:"GCM",type:"auth"},"aes-192-gcm":{cipher:"AES",key:192,iv:12,mode:"GCM",type:"auth"},"aes-256-gcm":{cipher:"AES",key:256,iv:12,mode:"GCM",type:"auth"}}}),tV=OJ((l,g)=>{var R={ECB:C8(),CBC:k8(),CFB:A8(),CFB8:S8(),CFB1:x8(),OFB:w8(),CTR:o0(),GCM:o0()},M=r0();for(B in M)M[B].module=R[M[B].mode];var B;g.exports=M}),CV=OJ((l,g)=>{var R=XQ().Buffer;function M(O){R.isBuffer(O)||(O=R.from(O));for(var N=O.length/4|0,W=new Array(N),I=0;I<N;I++)W[I]=O.readUInt32BE(I*4);return W}function B(O){for(var N=0;N<O.length;O++)O[N]=0}function A(O,N,W,I,z){for(var j=W[0],P=W[1],F=W[2],v=W[3],S=O[0]^N[0],w=O[1]^N[1],y=O[2]^N[2],m=O[3]^N[3],i,JJ,VJ,HJ,o=4,jJ=1;jJ<z;jJ++)i=j[S>>>24]^P[w>>>16&255]^F[y>>>8&255]^v[m&255]^N[o++],JJ=j[w>>>24]^P[y>>>16&255]^F[m>>>8&255]^v[S&255]^N[o++],VJ=j[y>>>24]^P[m>>>16&255]^F[S>>>8&255]^v[w&255]^N[o++],HJ=j[m>>>24]^P[S>>>16&255]^F[w>>>8&255]^v[y&255]^N[o++],S=i,w=JJ,y=VJ,m=HJ;return i=(I[S>>>24]<<24|I[w>>>16&255]<<16|I[y>>>8&255]<<8|I[m&255])^N[o++],JJ=(I[w>>>24]<<24|I[y>>>16&255]<<16|I[m>>>8&255]<<8|I[S&255])^N[o++],VJ=(I[y>>>24]<<24|I[m>>>16&255]<<16|I[S>>>8&255]<<8|I[w&255])^N[o++],HJ=(I[m>>>24]<<24|I[S>>>16&255]<<16|I[w>>>8&255]<<8|I[y&255])^N[o++],i=i>>>0,JJ=JJ>>>0,VJ=VJ>>>0,HJ=HJ>>>0,[i,JJ,VJ,HJ]}var q=[0,1,2,4,8,16,32,64,128,27,54],Y=function(){for(var O=new Array(256),N=0;N<256;N++)N<128?O[N]=N<<1:O[N]=N<<1^283;for(var W=[],I=[],z=[[],[],[],[]],j=[[],[],[],[]],P=0,F=0,v=0;v<256;++v){var S=F^F<<1^F<<2^F<<3^F<<4;S=S>>>8^S&255^99,W[P]=S,I[S]=P;var w=O[P],y=O[w],m=O[y],i=O[S]*257^S*16843008;z[0][P]=i<<24|i>>>8,z[1][P]=i<<16|i>>>16,z[2][P]=i<<8|i>>>24,z[3][P]=i,i=m*16843009^y*65537^w*257^P*16843008,j[0][S]=i<<24|i>>>8,j[1][S]=i<<16|i>>>16,j[2][S]=i<<8|i>>>24,j[3][S]=i,P===0?P=F=1:(P=w^O[O[O[m^w]]],F^=O[O[F]])}return{SBOX:W,INV_SBOX:I,SUB_MIX:z,INV_SUB_MIX:j}}();function E(O){this._key=M(O),this._reset()}E.blockSize=16,E.keySize=32,E.prototype.blockSize=E.blockSize,E.prototype.keySize=E.keySize,E.prototype._reset=function(){for(var O=this._key,N=O.length,W=N+6,I=(W+1)*4,z=[],j=0;j<N;j++)z[j]=O[j];for(j=N;j<I;j++){var P=z[j-1];j%N===0?(P=P<<8|P>>>24,P=Y.SBOX[P>>>24]<<24|Y.SBOX[P>>>16&255]<<16|Y.SBOX[P>>>8&255]<<8|Y.SBOX[P&255],P^=q[j/N|0]<<24):N>6&&j%N===4&&(P=Y.SBOX[P>>>24]<<24|Y.SBOX[P>>>16&255]<<16|Y.SBOX[P>>>8&255]<<8|Y.SBOX[P&255]),z[j]=z[j-N]^P}for(var F=[],v=0;v<I;v++){var S=I-v,w=z[S-(v%4?0:4)];v<4||S<=4?F[v]=w:F[v]=Y.INV_SUB_MIX[0][Y.SBOX[w>>>24]]^Y.INV_SUB_MIX[1][Y.SBOX[w>>>16&255]]^Y.INV_SUB_MIX[2][Y.SBOX[w>>>8&255]]^Y.INV_SUB_MIX[3][Y.SBOX[w&255]]}this._nRounds=W,this._keySchedule=z,this._invKeySchedule=F},E.prototype.encryptBlockRaw=function(O){return O=M(O),A(O,this._keySchedule,Y.SUB_MIX,Y.SBOX,this._nRounds)},E.prototype.encryptBlock=function(O){var N=this.encryptBlockRaw(O),W=R.allocUnsafe(16);return W.writeUInt32BE(N[0],0),W.writeUInt32BE(N[1],4),W.writeUInt32BE(N[2],8),W.writeUInt32BE(N[3],12),W},E.prototype.decryptBlock=function(O){O=M(O);var N=O[1];O[1]=O[3],O[3]=N;var W=A(O,this._invKeySchedule,Y.INV_SUB_MIX,Y.INV_SBOX,this._nRounds),I=R.allocUnsafe(16);return I.writeUInt32BE(W[0],0),I.writeUInt32BE(W[3],4),I.writeUInt32BE(W[2],8),I.writeUInt32BE(W[1],12),I},E.prototype.scrub=function(){B(this._keySchedule),B(this._invKeySchedule),B(this._key)},g.exports.AES=E}),v8=OJ((l,g)=>{var R=XQ().Buffer,M=R.alloc(16,0);function B(Y){return[Y.readUInt32BE(0),Y.readUInt32BE(4),Y.readUInt32BE(8),Y.readUInt32BE(12)]}function A(Y){var E=R.allocUnsafe(16);return E.writeUInt32BE(Y[0]>>>0,0),E.writeUInt32BE(Y[1]>>>0,4),E.writeUInt32BE(Y[2]>>>0,8),E.writeUInt32BE(Y[3]>>>0,12),E}function q(Y){this.h=Y,this.state=R.alloc(16,0),this.cache=R.allocUnsafe(0)}q.prototype.ghash=function(Y){for(var E=-1;++E<Y.length;)this.state[E]^=Y[E];this._multiply()},q.prototype._multiply=function(){for(var Y=B(this.h),E=[0,0,0,0],O,N,W,I=-1;++I<128;){for(N=(this.state[~~(I/8)]&1<<7-I%8)!==0,N&&(E[0]^=Y[0],E[1]^=Y[1],E[2]^=Y[2],E[3]^=Y[3]),W=(Y[3]&1)!==0,O=3;O>0;O--)Y[O]=Y[O]>>>1|(Y[O-1]&1)<<31;Y[0]=Y[0]>>>1,W&&(Y[0]=Y[0]^225<<24)}this.state=A(E)},q.prototype.update=function(Y){this.cache=R.concat([this.cache,Y]);for(var E;this.cache.length>=16;)E=this.cache.slice(0,16),this.cache=this.cache.slice(16),this.ghash(E)},q.prototype.final=function(Y,E){return this.cache.length&&this.ghash(R.concat([this.cache,M],16)),this.ghash(A([0,Y,0,E])),this.state},g.exports=q}),a0=OJ((l,g)=>{var R=CV(),M=XQ().Buffer,B=nQ(),A=JQ(),q=v8(),Y=YV(),E=n0();function O(I,z){var j=0;I.length!==z.length&&j++;for(var P=Math.min(I.length,z.length),F=0;F<P;++F)j+=I[F]^z[F];return j}function N(I,z,j){if(z.length===12)return I._finID=M.concat([z,M.from([0,0,0,1])]),M.concat([z,M.from([0,0,0,2])]);var P=new q(j),F=z.length,v=F%16;P.update(z),v&&(v=16-v,P.update(M.alloc(v,0))),P.update(M.alloc(8,0));var S=F*8,w=M.alloc(8);w.writeUIntBE(S,0,8),P.update(w),I._finID=P.state;var y=M.from(I._finID);return E(y),y}function W(I,z,j,P){B.call(this);var F=M.alloc(4,0);this._cipher=new R.AES(z);var v=this._cipher.encryptBlock(F);this._ghash=new q(v),j=N(this,j,v),this._prev=M.from(j),this._cache=M.allocUnsafe(0),this._secCache=M.allocUnsafe(0),this._decrypt=P,this._alen=0,this._len=0,this._mode=I,this._authTag=null,this._called=!1}A(W,B),W.prototype._update=function(I){if(!this._called&&this._alen){var z=16-this._alen%16;z<16&&(z=M.alloc(z,0),this._ghash.update(z))}this._called=!0;var j=this._mode.encrypt(this,I);return this._decrypt?this._ghash.update(I):this._ghash.update(j),this._len+=I.length,j},W.prototype._final=function(){if(this._decrypt&&!this._authTag)throw new Error("Unsupported state or unable to authenticate data");var I=Y(this._ghash.final(this._alen*8,this._len*8),this._cipher.encryptBlock(this._finID));if(this._decrypt&&O(I,this._authTag))throw new Error("Unsupported state or unable to authenticate data");this._authTag=I,this._cipher.scrub()},W.prototype.getAuthTag=function(){if(this._decrypt||!M.isBuffer(this._authTag))throw new Error("Attempting to get auth tag in unsupported state");return this._authTag},W.prototype.setAuthTag=function(I){if(!this._decrypt)throw new Error("Attempting to set auth tag in unsupported state");this._authTag=I},W.prototype.setAAD=function(I){if(this._called)throw new Error("Attempting to set AAD in unsupported state");this._ghash.update(I),this._alen+=I.length},g.exports=W}),t0=OJ((l,g)=>{var R=CV(),M=XQ().Buffer,B=nQ(),A=JQ();function q(Y,E,O,N){B.call(this),this._cipher=new R.AES(E),this._prev=M.from(O),this._cache=M.allocUnsafe(0),this._secCache=M.allocUnsafe(0),this._decrypt=N,this._mode=Y}A(q,B),q.prototype._update=function(Y){return this._mode.encrypt(this,Y,this._decrypt)},q.prototype._final=function(){this._cipher.scrub()},g.exports=q}),kV=OJ((l,g)=>{var R=XQ().Buffer,M=uV();function B(A,q,Y,E){if(R.isBuffer(A)||(A=R.from(A,"binary")),q&&(R.isBuffer(q)||(q=R.from(q,"binary")),q.length!==8))throw new RangeError("salt should be Buffer with 8 byte length");for(var O=Y/8,N=R.alloc(O),W=R.alloc(E||0),I=R.alloc(0);O>0||E>0;){var z=new M;z.update(I),z.update(A),q&&z.update(q),I=z.digest();var j=0;if(O>0){var P=N.length-O;j=Math.min(O,I.length),I.copy(N,P,0,j),O-=j}if(j<I.length&&E>0){var F=W.length-E,v=Math.min(E,I.length-j);I.copy(W,F,j,j+v),E-=v}}return I.fill(0),{key:N,iv:W}}g.exports=B}),M8=OJ((l)=>{var g=tV(),R=a0(),M=XQ().Buffer,B=t0(),A=nQ(),q=CV(),Y=kV(),E=JQ();function O(j,P,F){A.call(this),this._cache=new W,this._cipher=new q.AES(P),this._prev=M.from(F),this._mode=j,this._autopadding=!0}E(O,A),O.prototype._update=function(j){this._cache.add(j);for(var P,F,v=[];P=this._cache.get();)F=this._mode.encrypt(this,P),v.push(F);return M.concat(v)};var N=M.alloc(16,16);O.prototype._final=function(){var j=this._cache.flush();if(this._autopadding)return j=this._mode.encrypt(this,j),this._cipher.scrub(),j;if(!j.equals(N))throw this._cipher.scrub(),new Error("data not multiple of block length")},O.prototype.setAutoPadding=function(j){return this._autopadding=!!j,this};function W(){this.cache=M.allocUnsafe(0)}W.prototype.add=function(j){this.cache=M.concat([this.cache,j])},W.prototype.get=function(){if(this.cache.length>15){var j=this.cache.slice(0,16);return this.cache=this.cache.slice(16),j}return null},W.prototype.flush=function(){for(var j=16-this.cache.length,P=M.allocUnsafe(j),F=-1;++F<j;)P.writeUInt8(j,F);return M.concat([this.cache,P])};function I(j,P,F){var v=g[j.toLowerCase()];if(!v)throw new TypeError("invalid suite type");if(typeof P=="string"&&(P=M.from(P)),P.length!==v.key/8)throw new TypeError("invalid key length "+P.length);if(typeof F=="string"&&(F=M.from(F)),v.mode!=="GCM"&&F.length!==v.iv)throw new TypeError("invalid iv length "+F.length);return v.type==="stream"?new B(v.module,P,F):v.type==="auth"?new R(v.module,P,F):new O(v.module,P,F)}function z(j,P){var F=g[j.toLowerCase()];if(!F)throw new TypeError("invalid suite type");var v=Y(P,!1,F.key,F.iv);return I(j,v.key,v.iv)}l.createCipheriv=I,l.createCipher=z}),_8=OJ((l)=>{var g=a0(),R=XQ().Buffer,M=tV(),B=t0(),A=nQ(),q=CV(),Y=kV(),E=JQ();function O(j,P,F){A.call(this),this._cache=new N,this._last=void 0,this._cipher=new q.AES(P),this._prev=R.from(F),this._mode=j,this._autopadding=!0}E(O,A),O.prototype._update=function(j){this._cache.add(j);for(var P,F,v=[];P=this._cache.get(this._autopadding);)F=this._mode.decrypt(this,P),v.push(F);return R.concat(v)},O.prototype._final=function(){var j=this._cache.flush();if(this._autopadding)return W(this._mode.decrypt(this,j));if(j)throw new Error("data not multiple of block length")},O.prototype.setAutoPadding=function(j){return this._autopadding=!!j,this};function N(){this.cache=R.allocUnsafe(0)}N.prototype.add=function(j){this.cache=R.concat([this.cache,j])},N.prototype.get=function(j){var P;if(j){if(this.cache.length>16)return P=this.cache.slice(0,16),this.cache=this.cache.slice(16),P}else if(this.cache.length>=16)return P=this.cache.slice(0,16),this.cache=this.cache.slice(16),P;return null},N.prototype.flush=function(){if(this.cache.length)return this.cache};function W(j){var P=j[15];if(P<1||P>16)throw new Error("unable to decrypt data");for(var F=-1;++F<P;)if(j[F+(16-P)]!==P)throw new Error("unable to decrypt data");if(P!==16)return j.slice(0,16-P)}function I(j,P,F){var v=M[j.toLowerCase()];if(!v)throw new TypeError("invalid suite type");if(typeof F=="string"&&(F=R.from(F)),v.mode!=="GCM"&&F.length!==v.iv)throw new TypeError("invalid iv length "+F.length);if(typeof P=="string"&&(P=R.from(P)),P.length!==v.key/8)throw new TypeError("invalid key length "+P.length);return v.type==="stream"?new B(v.module,P,F,!0):v.type==="auth"?new g(v.module,P,F,!0):new O(v.module,P,F)}function z(j,P){var F=M[j.toLowerCase()];if(!F)throw new TypeError("invalid suite type");var v=Y(P,!1,F.key,F.iv);return I(j,v.key,v.iv)}l.createDecipher=z,l.createDecipheriv=I}),eV=OJ((l)=>{var g=M8(),R=_8(),M=r0();function B(){return Object.keys(M)}l.createCipher=l.Cipher=g.createCipher,l.createCipheriv=l.Cipheriv=g.createCipheriv,l.createDecipher=l.Decipher=R.createDecipher,l.createDecipheriv=l.Decipheriv=R.createDecipheriv,l.listCiphers=l.getCiphers=B}),b8=OJ((l)=>{l["des-ecb"]={key:8,iv:0},l["des-cbc"]=l.des={key:8,iv:8},l["des-ede3-cbc"]=l.des3={key:24,iv:8},l["des-ede3"]={key:24,iv:0},l["des-ede-cbc"]={key:16,iv:8},l["des-ede"]={key:16,iv:0}}),y8=OJ((l)=>{var g=D8(),R=eV(),M=tV(),B=b8(),A=kV();function q(W,I){W=W.toLowerCase();var z,j;if(M[W])z=M[W].key,j=M[W].iv;else if(B[W])z=B[W].key*8,j=B[W].iv;else throw new TypeError("invalid suite type");var P=A(I,!1,z,j);return E(W,P.key,P.iv)}function Y(W,I){W=W.toLowerCase();var z,j;if(M[W])z=M[W].key,j=M[W].iv;else if(B[W])z=B[W].key*8,j=B[W].iv;else throw new TypeError("invalid suite type");var P=A(I,!1,z,j);return O(W,P.key,P.iv)}function E(W,I,z){if(W=W.toLowerCase(),M[W])return R.createCipheriv(W,I,z);if(B[W])return new g({key:I,iv:z,mode:W});throw new TypeError("invalid suite type")}function O(W,I,z){if(W=W.toLowerCase(),M[W])return R.createDecipheriv(W,I,z);if(B[W])return new g({key:I,iv:z,mode:W,decrypt:!0});throw new TypeError("invalid suite type")}function N(){return Object.keys(B).concat(R.getCiphers())}l.createCipher=l.Cipher=q,l.createCipheriv=l.Cipheriv=E,l.createDecipher=l.Decipher=Y,l.createDecipheriv=l.Decipheriv=O,l.listCiphers=l.getCiphers=N}),JV=OJ(()=>{}),e0=OJ((l,g)=>{(function(R,M){function B(J,V){if(!J)throw new Error(V||"Assertion failed")}function A(J,V){J.super_=V;var Z=function(){};Z.prototype=V.prototype,J.prototype=new Z,J.prototype.constructor=J}function q(J,V,Z){if(q.isBN(J))return J;this.negative=0,this.words=null,this.length=0,this.red=null,J!==null&&((V==="le"||V==="be")&&(Z=V,V=10),this._init(J||0,V||10,Z||"be"))}typeof R=="object"?R.exports=q:M.BN=q,q.BN=q,q.wordSize=26;var Y;try{typeof window<"u"&&typeof window.Buffer<"u"?Y=window.Buffer:Y=JV().Buffer}catch{}q.isBN=function(J){return J instanceof q?!0:J!==null&&typeof J=="object"&&J.constructor.wordSize===q.wordSize&&Array.isArray(J.words)},q.max=function(J,V){return J.cmp(V)>0?J:V},q.min=function(J,V){return J.cmp(V)<0?J:V},q.prototype._init=function(J,V,Z){if(typeof J=="number")return this._initNumber(J,V,Z);if(typeof J=="object")return this._initArray(J,V,Z);V==="hex"&&(V=16),B(V===(V|0)&&V>=2&&V<=36),J=J.toString().replace(/\s+/g,"");var $=0;J[0]==="-"&&($++,this.negative=1),$<J.length&&(V===16?this._parseHex(J,$,Z):(this._parseBase(J,V,$),Z==="le"&&this._initArray(this.toArray(),V,Z)))},q.prototype._initNumber=function(J,V,Z){J<0&&(this.negative=1,J=-J),J<67108864?(this.words=[J&67108863],this.length=1):J<4503599627370496?(this.words=[J&67108863,J/67108864&67108863],this.length=2):(B(J<9007199254740992),this.words=[J&67108863,J/67108864&67108863,1],this.length=3),Z==="le"&&this._initArray(this.toArray(),V,Z)},q.prototype._initArray=function(J,V,Z){if(B(typeof J.length=="number"),J.length<=0)return this.words=[0],this.length=1,this;this.length=Math.ceil(J.length/3),this.words=new Array(this.length);for(var $=0;$<this.length;$++)this.words[$]=0;var X,U,H=0;if(Z==="be")for($=J.length-1,X=0;$>=0;$-=3)U=J[$]|J[$-1]<<8|J[$-2]<<16,this.words[X]|=U<<H&67108863,this.words[X+1]=U>>>26-H&67108863,H+=24,H>=26&&(H-=26,X++);else if(Z==="le")for($=0,X=0;$<J.length;$+=3)U=J[$]|J[$+1]<<8|J[$+2]<<16,this.words[X]|=U<<H&67108863,this.words[X+1]=U>>>26-H&67108863,H+=24,H>=26&&(H-=26,X++);return this.strip()};function E(J,V){var Z=J.charCodeAt(V);return Z>=65&&Z<=70?Z-55:Z>=97&&Z<=102?Z-87:Z-48&15}function O(J,V,Z){var $=E(J,Z);return Z-1>=V&&($|=E(J,Z-1)<<4),$}q.prototype._parseHex=function(J,V,Z){this.length=Math.ceil((J.length-V)/6),this.words=new Array(this.length);for(var $=0;$<this.length;$++)this.words[$]=0;var X=0,U=0,H;if(Z==="be")for($=J.length-1;$>=V;$-=2)H=O(J,V,$)<<X,this.words[U]|=H&67108863,X>=18?(X-=18,U+=1,this.words[U]|=H>>>26):X+=8;else{var G=J.length-V;for($=G%2===0?V+1:V;$<J.length;$+=2)H=O(J,V,$)<<X,this.words[U]|=H&67108863,X>=18?(X-=18,U+=1,this.words[U]|=H>>>26):X+=8}this.strip()};function N(J,V,Z,$){for(var X=0,U=Math.min(J.length,Z),H=V;H<U;H++){var G=J.charCodeAt(H)-48;X*=$,G>=49?X+=G-49+10:G>=17?X+=G-17+10:X+=G}return X}q.prototype._parseBase=function(J,V,Z){this.words=[0],this.length=1;for(var $=0,X=1;X<=67108863;X*=V)$++;$--,X=X/V|0;for(var U=J.length-Z,H=U%$,G=Math.min(U,U-H)+Z,Q=0,K=Z;K<G;K+=$)Q=N(J,K,K+$,V),this.imuln(X),this.words[0]+Q<67108864?this.words[0]+=Q:this._iaddn(Q);if(H!==0){var k=1;for(Q=N(J,K,J.length,V),K=0;K<H;K++)k*=V;this.imuln(k),this.words[0]+Q<67108864?this.words[0]+=Q:this._iaddn(Q)}this.strip()},q.prototype.copy=function(J){J.words=new Array(this.length);for(var V=0;V<this.length;V++)J.words[V]=this.words[V];J.length=this.length,J.negative=this.negative,J.red=this.red},q.prototype.clone=function(){var J=new q(null);return this.copy(J),J},q.prototype._expand=function(J){for(;this.length<J;)this.words[this.length++]=0;return this},q.prototype.strip=function(){for(;this.length>1&&this.words[this.length-1]===0;)this.length--;return this._normSign()},q.prototype._normSign=function(){return this.length===1&&this.words[0]===0&&(this.negative=0),this},q.prototype.inspect=function(){return(this.red?"<BN-R: ":"<BN: ")+this.toString(16)+">"};var W=["","0","00","000","0000","00000","000000","0000000","00000000","000000000","0000000000","00000000000","000000000000","0000000000000","00000000000000","000000000000000","0000000000000000","00000000000000000","000000000000000000","0000000000000000000","00000000000000000000","000000000000000000000","0000000000000000000000","00000000000000000000000","000000000000000000000000","0000000000000000000000000"],I=[0,0,25,16,12,11,10,9,8,8,7,7,7,7,6,6,6,6,6,6,6,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5],z=[0,0,33554432,43046721,16777216,48828125,60466176,40353607,16777216,43046721,1e7,19487171,35831808,62748517,7529536,11390625,16777216,24137569,34012224,47045881,64000000,4084101,5153632,6436343,7962624,9765625,11881376,14348907,17210368,20511149,24300000,28629151,33554432,39135393,45435424,52521875,60466176];q.prototype.toString=function(J,V){J=J||10,V=V|0||1;var Z;if(J===16||J==="hex"){Z="";for(var $=0,X=0,U=0;U<this.length;U++){var H=this.words[U],G=((H<<$|X)&16777215).toString(16);X=H>>>24-$&16777215,X!==0||U!==this.length-1?Z=W[6-G.length]+G+Z:Z=G+Z,$+=2,$>=26&&($-=26,U--)}for(X!==0&&(Z=X.toString(16)+Z);Z.length%V!==0;)Z="0"+Z;return this.negative!==0&&(Z="-"+Z),Z}if(J===(J|0)&&J>=2&&J<=36){var Q=I[J],K=z[J];Z="";var k=this.clone();for(k.negative=0;!k.isZero();){var L=k.modn(K).toString(J);k=k.idivn(K),k.isZero()?Z=L+Z:Z=W[Q-L.length]+L+Z}for(this.isZero()&&(Z="0"+Z);Z.length%V!==0;)Z="0"+Z;return this.negative!==0&&(Z="-"+Z),Z}B(!1,"Base should be between 2 and 36")},q.prototype.toNumber=function(){var J=this.words[0];return this.length===2?J+=this.words[1]*67108864:this.length===3&&this.words[2]===1?J+=4503599627370496+this.words[1]*67108864:this.length>2&&B(!1,"Number can only safely store up to 53 bits"),this.negative!==0?-J:J},q.prototype.toJSON=function(){return this.toString(16)},q.prototype.toBuffer=function(J,V){return B(typeof Y<"u"),this.toArrayLike(Y,J,V)},q.prototype.toArray=function(J,V){return this.toArrayLike(Array,J,V)},q.prototype.toArrayLike=function(J,V,Z){var $=this.byteLength(),X=Z||Math.max(1,$);B($<=X,"byte array longer than desired length"),B(X>0,"Requested array length <= 0"),this.strip();var U=V==="le",H=new J(X),G,Q,K=this.clone();if(U){for(Q=0;!K.isZero();Q++)G=K.andln(255),K.iushrn(8),H[Q]=G;for(;Q<X;Q++)H[Q]=0}else{for(Q=0;Q<X-$;Q++)H[Q]=0;for(Q=0;!K.isZero();Q++)G=K.andln(255),K.iushrn(8),H[X-Q-1]=G}return H},Math.clz32?q.prototype._countBits=function(J){return 32-Math.clz32(J)}:q.prototype._countBits=function(J){var V=J,Z=0;return V>=4096&&(Z+=13,V>>>=13),V>=64&&(Z+=7,V>>>=7),V>=8&&(Z+=4,V>>>=4),V>=2&&(Z+=2,V>>>=2),Z+V},q.prototype._zeroBits=function(J){if(J===0)return 26;var V=J,Z=0;return(V&8191)===0&&(Z+=13,V>>>=13),(V&127)===0&&(Z+=7,V>>>=7),(V&15)===0&&(Z+=4,V>>>=4),(V&3)===0&&(Z+=2,V>>>=2),(V&1)===0&&Z++,Z},q.prototype.bitLength=function(){var J=this.words[this.length-1],V=this._countBits(J);return(this.length-1)*26+V};function j(J){for(var V=new Array(J.bitLength()),Z=0;Z<V.length;Z++){var $=Z/26|0,X=Z%26;V[Z]=(J.words[$]&1<<X)>>>X}return V}q.prototype.zeroBits=function(){if(this.isZero())return 0;for(var J=0,V=0;V<this.length;V++){var Z=this._zeroBits(this.words[V]);if(J+=Z,Z!==26)break}return J},q.prototype.byteLength=function(){return Math.ceil(this.bitLength()/8)},q.prototype.toTwos=function(J){return this.negative!==0?this.abs().inotn(J).iaddn(1):this.clone()},q.prototype.fromTwos=function(J){return this.testn(J-1)?this.notn(J).iaddn(1).ineg():this.clone()},q.prototype.isNeg=function(){return this.negative!==0},q.prototype.neg=function(){return this.clone().ineg()},q.prototype.ineg=function(){return this.isZero()||(this.negative^=1),this},q.prototype.iuor=function(J){for(;this.length<J.length;)this.words[this.length++]=0;for(var V=0;V<J.length;V++)this.words[V]=this.words[V]|J.words[V];return this.strip()},q.prototype.ior=function(J){return B((this.negative|J.negative)===0),this.iuor(J)},q.prototype.or=function(J){return this.length>J.length?this.clone().ior(J):J.clone().ior(this)},q.prototype.uor=function(J){return this.length>J.length?this.clone().iuor(J):J.clone().iuor(this)},q.prototype.iuand=function(J){var V;this.length>J.length?V=J:V=this;for(var Z=0;Z<V.length;Z++)this.words[Z]=this.words[Z]&J.words[Z];return this.length=V.length,this.strip()},q.prototype.iand=function(J){return B((this.negative|J.negative)===0),this.iuand(J)},q.prototype.and=function(J){return this.length>J.length?this.clone().iand(J):J.clone().iand(this)},q.prototype.uand=function(J){return this.length>J.length?this.clone().iuand(J):J.clone().iuand(this)},q.prototype.iuxor=function(J){var V,Z;this.length>J.length?(V=this,Z=J):(V=J,Z=this);for(var $=0;$<Z.length;$++)this.words[$]=V.words[$]^Z.words[$];if(this!==V)for(;$<V.length;$++)this.words[$]=V.words[$];return this.length=V.length,this.strip()},q.prototype.ixor=function(J){return B((this.negative|J.negative)===0),this.iuxor(J)},q.prototype.xor=function(J){return this.length>J.length?this.clone().ixor(J):J.clone().ixor(this)},q.prototype.uxor=function(J){return this.length>J.length?this.clone().iuxor(J):J.clone().iuxor(this)},q.prototype.inotn=function(J){B(typeof J=="number"&&J>=0);var V=Math.ceil(J/26)|0,Z=J%26;this._expand(V),Z>0&&V--;for(var $=0;$<V;$++)this.words[$]=~this.words[$]&67108863;return Z>0&&(this.words[$]=~this.words[$]&67108863>>26-Z),this.strip()},q.prototype.notn=function(J){return this.clone().inotn(J)},q.prototype.setn=function(J,V){B(typeof J=="number"&&J>=0);var Z=J/26|0,$=J%26;return this._expand(Z+1),V?this.words[Z]=this.words[Z]|1<<$:this.words[Z]=this.words[Z]&~(1<<$),this.strip()},q.prototype.iadd=function(J){var V;if(this.negative!==0&&J.negative===0)return this.negative=0,V=this.isub(J),this.negative^=1,this._normSign();if(this.negative===0&&J.negative!==0)return J.negative=0,V=this.isub(J),J.negative=1,V._normSign();var Z,$;this.length>J.length?(Z=this,$=J):(Z=J,$=this);for(var X=0,U=0;U<$.length;U++)V=(Z.words[U]|0)+($.words[U]|0)+X,this.words[U]=V&67108863,X=V>>>26;for(;X!==0&&U<Z.length;U++)V=(Z.words[U]|0)+X,this.words[U]=V&67108863,X=V>>>26;if(this.length=Z.length,X!==0)this.words[this.length]=X,this.length++;else if(Z!==this)for(;U<Z.length;U++)this.words[U]=Z.words[U];return this},q.prototype.add=function(J){var V;return J.negative!==0&&this.negative===0?(J.negative=0,V=this.sub(J),J.negative^=1,V):J.negative===0&&this.negative!==0?(this.negative=0,V=J.sub(this),this.negative=1,V):this.length>J.length?this.clone().iadd(J):J.clone().iadd(this)},q.prototype.isub=function(J){if(J.negative!==0){J.negative=0;var V=this.iadd(J);return J.negative=1,V._normSign()}else if(this.negative!==0)return this.negative=0,this.iadd(J),this.negative=1,this._normSign();var Z=this.cmp(J);if(Z===0)return this.negative=0,this.length=1,this.words[0]=0,this;var $,X;Z>0?($=this,X=J):($=J,X=this);for(var U=0,H=0;H<X.length;H++)V=($.words[H]|0)-(X.words[H]|0)+U,U=V>>26,this.words[H]=V&67108863;for(;U!==0&&H<$.length;H++)V=($.words[H]|0)+U,U=V>>26,this.words[H]=V&67108863;if(U===0&&H<$.length&&$!==this)for(;H<$.length;H++)this.words[H]=$.words[H];return this.length=Math.max(this.length,H),$!==this&&(this.negative=1),this.strip()},q.prototype.sub=function(J){return this.clone().isub(J)};function P(J,V,Z){Z.negative=V.negative^J.negative;var $=J.length+V.length|0;Z.length=$,$=$-1|0;var X=J.words[0]|0,U=V.words[0]|0,H=X*U,G=H&67108863,Q=H/67108864|0;Z.words[0]=G;for(var K=1;K<$;K++){for(var k=Q>>>26,L=Q&67108863,_=Math.min(K,V.length-1),t=Math.max(0,K-J.length+1);t<=_;t++){var QJ=K-t|0;X=J.words[QJ]|0,U=V.words[t]|0,H=X*U+L,k+=H/67108864|0,L=H&67108863}Z.words[K]=L|0,Q=k|0}return Q!==0?Z.words[K]=Q|0:Z.length--,Z.strip()}var F=function(J,V,Z){var $=J.words,X=V.words,U=Z.words,H=0,G,Q,K,k=$[0]|0,L=k&8191,_=k>>>13,t=$[1]|0,QJ=t&8191,GJ=t>>>13,n=$[2]|0,p=n&8191,e=n>>>13,PJ=$[3]|0,XJ=PJ&8191,WJ=PJ>>>13,b=$[4]|0,C=b&8191,h=b>>>13,$J=$[5]|0,qJ=$J&8191,ZJ=$J>>>13,mJ=$[6]|0,BJ=mJ&8191,TJ=mJ>>>13,dJ=$[7]|0,LJ=dJ&8191,IJ=dJ>>>13,$Q=$[8]|0,T=$Q&8191,D=$Q>>>13,u=$[9]|0,d=u&8191,a=u>>>13,CJ=X[0]|0,UJ=CJ&8191,EJ=CJ>>>13,QQ=X[1]|0,FJ=QQ&8191,RJ=QQ>>>13,aJ=X[2]|0,SJ=aJ&8191,xJ=aJ>>>13,nJ=X[3]|0,AJ=nJ&8191,kJ=nJ>>>13,ZQ=X[4]|0,vJ=ZQ&8191,MJ=ZQ>>>13,xQ=X[5]|0,wJ=xQ&8191,bJ=xQ>>>13,WQ=X[6]|0,_J=WQ&8191,NJ=WQ>>>13,vQ=X[7]|0,yJ=vQ&8191,gJ=vQ>>>13,MQ=X[8]|0,cJ=MQ&8191,fJ=MQ>>>13,wQ=X[9]|0,f=wQ&8191,zJ=wQ>>>13;Z.negative=J.negative^V.negative,Z.length=19,G=Math.imul(L,UJ),Q=Math.imul(L,EJ),Q=Q+Math.imul(_,UJ)|0,K=Math.imul(_,EJ);var CQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(CQ>>>26)|0,CQ&=67108863,G=Math.imul(QJ,UJ),Q=Math.imul(QJ,EJ),Q=Q+Math.imul(GJ,UJ)|0,K=Math.imul(GJ,EJ),G=G+Math.imul(L,FJ)|0,Q=Q+Math.imul(L,RJ)|0,Q=Q+Math.imul(_,FJ)|0,K=K+Math.imul(_,RJ)|0;var oJ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(oJ>>>26)|0,oJ&=67108863,G=Math.imul(p,UJ),Q=Math.imul(p,EJ),Q=Q+Math.imul(e,UJ)|0,K=Math.imul(e,EJ),G=G+Math.imul(QJ,FJ)|0,Q=Q+Math.imul(QJ,RJ)|0,Q=Q+Math.imul(GJ,FJ)|0,K=K+Math.imul(GJ,RJ)|0,G=G+Math.imul(L,SJ)|0,Q=Q+Math.imul(L,xJ)|0,Q=Q+Math.imul(_,SJ)|0,K=K+Math.imul(_,xJ)|0;var tJ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(tJ>>>26)|0,tJ&=67108863,G=Math.imul(XJ,UJ),Q=Math.imul(XJ,EJ),Q=Q+Math.imul(WJ,UJ)|0,K=Math.imul(WJ,EJ),G=G+Math.imul(p,FJ)|0,Q=Q+Math.imul(p,RJ)|0,Q=Q+Math.imul(e,FJ)|0,K=K+Math.imul(e,RJ)|0,G=G+Math.imul(QJ,SJ)|0,Q=Q+Math.imul(QJ,xJ)|0,Q=Q+Math.imul(GJ,SJ)|0,K=K+Math.imul(GJ,xJ)|0,G=G+Math.imul(L,AJ)|0,Q=Q+Math.imul(L,kJ)|0,Q=Q+Math.imul(_,AJ)|0,K=K+Math.imul(_,kJ)|0;var YQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(YQ>>>26)|0,YQ&=67108863,G=Math.imul(C,UJ),Q=Math.imul(C,EJ),Q=Q+Math.imul(h,UJ)|0,K=Math.imul(h,EJ),G=G+Math.imul(XJ,FJ)|0,Q=Q+Math.imul(XJ,RJ)|0,Q=Q+Math.imul(WJ,FJ)|0,K=K+Math.imul(WJ,RJ)|0,G=G+Math.imul(p,SJ)|0,Q=Q+Math.imul(p,xJ)|0,Q=Q+Math.imul(e,SJ)|0,K=K+Math.imul(e,xJ)|0,G=G+Math.imul(QJ,AJ)|0,Q=Q+Math.imul(QJ,kJ)|0,Q=Q+Math.imul(GJ,AJ)|0,K=K+Math.imul(GJ,kJ)|0,G=G+Math.imul(L,vJ)|0,Q=Q+Math.imul(L,MJ)|0,Q=Q+Math.imul(_,vJ)|0,K=K+Math.imul(_,MJ)|0;var BQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(BQ>>>26)|0,BQ&=67108863,G=Math.imul(qJ,UJ),Q=Math.imul(qJ,EJ),Q=Q+Math.imul(ZJ,UJ)|0,K=Math.imul(ZJ,EJ),G=G+Math.imul(C,FJ)|0,Q=Q+Math.imul(C,RJ)|0,Q=Q+Math.imul(h,FJ)|0,K=K+Math.imul(h,RJ)|0,G=G+Math.imul(XJ,SJ)|0,Q=Q+Math.imul(XJ,xJ)|0,Q=Q+Math.imul(WJ,SJ)|0,K=K+Math.imul(WJ,xJ)|0,G=G+Math.imul(p,AJ)|0,Q=Q+Math.imul(p,kJ)|0,Q=Q+Math.imul(e,AJ)|0,K=K+Math.imul(e,kJ)|0,G=G+Math.imul(QJ,vJ)|0,Q=Q+Math.imul(QJ,MJ)|0,Q=Q+Math.imul(GJ,vJ)|0,K=K+Math.imul(GJ,MJ)|0,G=G+Math.imul(L,wJ)|0,Q=Q+Math.imul(L,bJ)|0,Q=Q+Math.imul(_,wJ)|0,K=K+Math.imul(_,bJ)|0;var OQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(OQ>>>26)|0,OQ&=67108863,G=Math.imul(BJ,UJ),Q=Math.imul(BJ,EJ),Q=Q+Math.imul(TJ,UJ)|0,K=Math.imul(TJ,EJ),G=G+Math.imul(qJ,FJ)|0,Q=Q+Math.imul(qJ,RJ)|0,Q=Q+Math.imul(ZJ,FJ)|0,K=K+Math.imul(ZJ,RJ)|0,G=G+Math.imul(C,SJ)|0,Q=Q+Math.imul(C,xJ)|0,Q=Q+Math.imul(h,SJ)|0,K=K+Math.imul(h,xJ)|0,G=G+Math.imul(XJ,AJ)|0,Q=Q+Math.imul(XJ,kJ)|0,Q=Q+Math.imul(WJ,AJ)|0,K=K+Math.imul(WJ,kJ)|0,G=G+Math.imul(p,vJ)|0,Q=Q+Math.imul(p,MJ)|0,Q=Q+Math.imul(e,vJ)|0,K=K+Math.imul(e,MJ)|0,G=G+Math.imul(QJ,wJ)|0,Q=Q+Math.imul(QJ,bJ)|0,Q=Q+Math.imul(GJ,wJ)|0,K=K+Math.imul(GJ,bJ)|0,G=G+Math.imul(L,_J)|0,Q=Q+Math.imul(L,NJ)|0,Q=Q+Math.imul(_,_J)|0,K=K+Math.imul(_,NJ)|0;var jQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(jQ>>>26)|0,jQ&=67108863,G=Math.imul(LJ,UJ),Q=Math.imul(LJ,EJ),Q=Q+Math.imul(IJ,UJ)|0,K=Math.imul(IJ,EJ),G=G+Math.imul(BJ,FJ)|0,Q=Q+Math.imul(BJ,RJ)|0,Q=Q+Math.imul(TJ,FJ)|0,K=K+Math.imul(TJ,RJ)|0,G=G+Math.imul(qJ,SJ)|0,Q=Q+Math.imul(qJ,xJ)|0,Q=Q+Math.imul(ZJ,SJ)|0,K=K+Math.imul(ZJ,xJ)|0,G=G+Math.imul(C,AJ)|0,Q=Q+Math.imul(C,kJ)|0,Q=Q+Math.imul(h,AJ)|0,K=K+Math.imul(h,kJ)|0,G=G+Math.imul(XJ,vJ)|0,Q=Q+Math.imul(XJ,MJ)|0,Q=Q+Math.imul(WJ,vJ)|0,K=K+Math.imul(WJ,MJ)|0,G=G+Math.imul(p,wJ)|0,Q=Q+Math.imul(p,bJ)|0,Q=Q+Math.imul(e,wJ)|0,K=K+Math.imul(e,bJ)|0,G=G+Math.imul(QJ,_J)|0,Q=Q+Math.imul(QJ,NJ)|0,Q=Q+Math.imul(GJ,_J)|0,K=K+Math.imul(GJ,NJ)|0,G=G+Math.imul(L,yJ)|0,Q=Q+Math.imul(L,gJ)|0,Q=Q+Math.imul(_,yJ)|0,K=K+Math.imul(_,gJ)|0;var TQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(TQ>>>26)|0,TQ&=67108863,G=Math.imul(T,UJ),Q=Math.imul(T,EJ),Q=Q+Math.imul(D,UJ)|0,K=Math.imul(D,EJ),G=G+Math.imul(LJ,FJ)|0,Q=Q+Math.imul(LJ,RJ)|0,Q=Q+Math.imul(IJ,FJ)|0,K=K+Math.imul(IJ,RJ)|0,G=G+Math.imul(BJ,SJ)|0,Q=Q+Math.imul(BJ,xJ)|0,Q=Q+Math.imul(TJ,SJ)|0,K=K+Math.imul(TJ,xJ)|0,G=G+Math.imul(qJ,AJ)|0,Q=Q+Math.imul(qJ,kJ)|0,Q=Q+Math.imul(ZJ,AJ)|0,K=K+Math.imul(ZJ,kJ)|0,G=G+Math.imul(C,vJ)|0,Q=Q+Math.imul(C,MJ)|0,Q=Q+Math.imul(h,vJ)|0,K=K+Math.imul(h,MJ)|0,G=G+Math.imul(XJ,wJ)|0,Q=Q+Math.imul(XJ,bJ)|0,Q=Q+Math.imul(WJ,wJ)|0,K=K+Math.imul(WJ,bJ)|0,G=G+Math.imul(p,_J)|0,Q=Q+Math.imul(p,NJ)|0,Q=Q+Math.imul(e,_J)|0,K=K+Math.imul(e,NJ)|0,G=G+Math.imul(QJ,yJ)|0,Q=Q+Math.imul(QJ,gJ)|0,Q=Q+Math.imul(GJ,yJ)|0,K=K+Math.imul(GJ,gJ)|0,G=G+Math.imul(L,cJ)|0,Q=Q+Math.imul(L,fJ)|0,Q=Q+Math.imul(_,cJ)|0,K=K+Math.imul(_,fJ)|0;var NQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(NQ>>>26)|0,NQ&=67108863,G=Math.imul(d,UJ),Q=Math.imul(d,EJ),Q=Q+Math.imul(a,UJ)|0,K=Math.imul(a,EJ),G=G+Math.imul(T,FJ)|0,Q=Q+Math.imul(T,RJ)|0,Q=Q+Math.imul(D,FJ)|0,K=K+Math.imul(D,RJ)|0,G=G+Math.imul(LJ,SJ)|0,Q=Q+Math.imul(LJ,xJ)|0,Q=Q+Math.imul(IJ,SJ)|0,K=K+Math.imul(IJ,xJ)|0,G=G+Math.imul(BJ,AJ)|0,Q=Q+Math.imul(BJ,kJ)|0,Q=Q+Math.imul(TJ,AJ)|0,K=K+Math.imul(TJ,kJ)|0,G=G+Math.imul(qJ,vJ)|0,Q=Q+Math.imul(qJ,MJ)|0,Q=Q+Math.imul(ZJ,vJ)|0,K=K+Math.imul(ZJ,MJ)|0,G=G+Math.imul(C,wJ)|0,Q=Q+Math.imul(C,bJ)|0,Q=Q+Math.imul(h,wJ)|0,K=K+Math.imul(h,bJ)|0,G=G+Math.imul(XJ,_J)|0,Q=Q+Math.imul(XJ,NJ)|0,Q=Q+Math.imul(WJ,_J)|0,K=K+Math.imul(WJ,NJ)|0,G=G+Math.imul(p,yJ)|0,Q=Q+Math.imul(p,gJ)|0,Q=Q+Math.imul(e,yJ)|0,K=K+Math.imul(e,gJ)|0,G=G+Math.imul(QJ,cJ)|0,Q=Q+Math.imul(QJ,fJ)|0,Q=Q+Math.imul(GJ,cJ)|0,K=K+Math.imul(GJ,fJ)|0,G=G+Math.imul(L,f)|0,Q=Q+Math.imul(L,zJ)|0,Q=Q+Math.imul(_,f)|0,K=K+Math.imul(_,zJ)|0;var IQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(IQ>>>26)|0,IQ&=67108863,G=Math.imul(d,FJ),Q=Math.imul(d,RJ),Q=Q+Math.imul(a,FJ)|0,K=Math.imul(a,RJ),G=G+Math.imul(T,SJ)|0,Q=Q+Math.imul(T,xJ)|0,Q=Q+Math.imul(D,SJ)|0,K=K+Math.imul(D,xJ)|0,G=G+Math.imul(LJ,AJ)|0,Q=Q+Math.imul(LJ,kJ)|0,Q=Q+Math.imul(IJ,AJ)|0,K=K+Math.imul(IJ,kJ)|0,G=G+Math.imul(BJ,vJ)|0,Q=Q+Math.imul(BJ,MJ)|0,Q=Q+Math.imul(TJ,vJ)|0,K=K+Math.imul(TJ,MJ)|0,G=G+Math.imul(qJ,wJ)|0,Q=Q+Math.imul(qJ,bJ)|0,Q=Q+Math.imul(ZJ,wJ)|0,K=K+Math.imul(ZJ,bJ)|0,G=G+Math.imul(C,_J)|0,Q=Q+Math.imul(C,NJ)|0,Q=Q+Math.imul(h,_J)|0,K=K+Math.imul(h,NJ)|0,G=G+Math.imul(XJ,yJ)|0,Q=Q+Math.imul(XJ,gJ)|0,Q=Q+Math.imul(WJ,yJ)|0,K=K+Math.imul(WJ,gJ)|0,G=G+Math.imul(p,cJ)|0,Q=Q+Math.imul(p,fJ)|0,Q=Q+Math.imul(e,cJ)|0,K=K+Math.imul(e,fJ)|0,G=G+Math.imul(QJ,f)|0,Q=Q+Math.imul(QJ,zJ)|0,Q=Q+Math.imul(GJ,f)|0,K=K+Math.imul(GJ,zJ)|0;var EQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(EQ>>>26)|0,EQ&=67108863,G=Math.imul(d,SJ),Q=Math.imul(d,xJ),Q=Q+Math.imul(a,SJ)|0,K=Math.imul(a,xJ),G=G+Math.imul(T,AJ)|0,Q=Q+Math.imul(T,kJ)|0,Q=Q+Math.imul(D,AJ)|0,K=K+Math.imul(D,kJ)|0,G=G+Math.imul(LJ,vJ)|0,Q=Q+Math.imul(LJ,MJ)|0,Q=Q+Math.imul(IJ,vJ)|0,K=K+Math.imul(IJ,MJ)|0,G=G+Math.imul(BJ,wJ)|0,Q=Q+Math.imul(BJ,bJ)|0,Q=Q+Math.imul(TJ,wJ)|0,K=K+Math.imul(TJ,bJ)|0,G=G+Math.imul(qJ,_J)|0,Q=Q+Math.imul(qJ,NJ)|0,Q=Q+Math.imul(ZJ,_J)|0,K=K+Math.imul(ZJ,NJ)|0,G=G+Math.imul(C,yJ)|0,Q=Q+Math.imul(C,gJ)|0,Q=Q+Math.imul(h,yJ)|0,K=K+Math.imul(h,gJ)|0,G=G+Math.imul(XJ,cJ)|0,Q=Q+Math.imul(XJ,fJ)|0,Q=Q+Math.imul(WJ,cJ)|0,K=K+Math.imul(WJ,fJ)|0,G=G+Math.imul(p,f)|0,Q=Q+Math.imul(p,zJ)|0,Q=Q+Math.imul(e,f)|0,K=K+Math.imul(e,zJ)|0;var RQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(RQ>>>26)|0,RQ&=67108863,G=Math.imul(d,AJ),Q=Math.imul(d,kJ),Q=Q+Math.imul(a,AJ)|0,K=Math.imul(a,kJ),G=G+Math.imul(T,vJ)|0,Q=Q+Math.imul(T,MJ)|0,Q=Q+Math.imul(D,vJ)|0,K=K+Math.imul(D,MJ)|0,G=G+Math.imul(LJ,wJ)|0,Q=Q+Math.imul(LJ,bJ)|0,Q=Q+Math.imul(IJ,wJ)|0,K=K+Math.imul(IJ,bJ)|0,G=G+Math.imul(BJ,_J)|0,Q=Q+Math.imul(BJ,NJ)|0,Q=Q+Math.imul(TJ,_J)|0,K=K+Math.imul(TJ,NJ)|0,G=G+Math.imul(qJ,yJ)|0,Q=Q+Math.imul(qJ,gJ)|0,Q=Q+Math.imul(ZJ,yJ)|0,K=K+Math.imul(ZJ,gJ)|0,G=G+Math.imul(C,cJ)|0,Q=Q+Math.imul(C,fJ)|0,Q=Q+Math.imul(h,cJ)|0,K=K+Math.imul(h,fJ)|0,G=G+Math.imul(XJ,f)|0,Q=Q+Math.imul(XJ,zJ)|0,Q=Q+Math.imul(WJ,f)|0,K=K+Math.imul(WJ,zJ)|0;var zQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(zQ>>>26)|0,zQ&=67108863,G=Math.imul(d,vJ),Q=Math.imul(d,MJ),Q=Q+Math.imul(a,vJ)|0,K=Math.imul(a,MJ),G=G+Math.imul(T,wJ)|0,Q=Q+Math.imul(T,bJ)|0,Q=Q+Math.imul(D,wJ)|0,K=K+Math.imul(D,bJ)|0,G=G+Math.imul(LJ,_J)|0,Q=Q+Math.imul(LJ,NJ)|0,Q=Q+Math.imul(IJ,_J)|0,K=K+Math.imul(IJ,NJ)|0,G=G+Math.imul(BJ,yJ)|0,Q=Q+Math.imul(BJ,gJ)|0,Q=Q+Math.imul(TJ,yJ)|0,K=K+Math.imul(TJ,gJ)|0,G=G+Math.imul(qJ,cJ)|0,Q=Q+Math.imul(qJ,fJ)|0,Q=Q+Math.imul(ZJ,cJ)|0,K=K+Math.imul(ZJ,fJ)|0,G=G+Math.imul(C,f)|0,Q=Q+Math.imul(C,zJ)|0,Q=Q+Math.imul(h,f)|0,K=K+Math.imul(h,zJ)|0;var PQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(PQ>>>26)|0,PQ&=67108863,G=Math.imul(d,wJ),Q=Math.imul(d,bJ),Q=Q+Math.imul(a,wJ)|0,K=Math.imul(a,bJ),G=G+Math.imul(T,_J)|0,Q=Q+Math.imul(T,NJ)|0,Q=Q+Math.imul(D,_J)|0,K=K+Math.imul(D,NJ)|0,G=G+Math.imul(LJ,yJ)|0,Q=Q+Math.imul(LJ,gJ)|0,Q=Q+Math.imul(IJ,yJ)|0,K=K+Math.imul(IJ,gJ)|0,G=G+Math.imul(BJ,cJ)|0,Q=Q+Math.imul(BJ,fJ)|0,Q=Q+Math.imul(TJ,cJ)|0,K=K+Math.imul(TJ,fJ)|0,G=G+Math.imul(qJ,f)|0,Q=Q+Math.imul(qJ,zJ)|0,Q=Q+Math.imul(ZJ,f)|0,K=K+Math.imul(ZJ,zJ)|0;var LQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(LQ>>>26)|0,LQ&=67108863,G=Math.imul(d,_J),Q=Math.imul(d,NJ),Q=Q+Math.imul(a,_J)|0,K=Math.imul(a,NJ),G=G+Math.imul(T,yJ)|0,Q=Q+Math.imul(T,gJ)|0,Q=Q+Math.imul(D,yJ)|0,K=K+Math.imul(D,gJ)|0,G=G+Math.imul(LJ,cJ)|0,Q=Q+Math.imul(LJ,fJ)|0,Q=Q+Math.imul(IJ,cJ)|0,K=K+Math.imul(IJ,fJ)|0,G=G+Math.imul(BJ,f)|0,Q=Q+Math.imul(BJ,zJ)|0,Q=Q+Math.imul(TJ,f)|0,K=K+Math.imul(TJ,zJ)|0;var FQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(FQ>>>26)|0,FQ&=67108863,G=Math.imul(d,yJ),Q=Math.imul(d,gJ),Q=Q+Math.imul(a,yJ)|0,K=Math.imul(a,gJ),G=G+Math.imul(T,cJ)|0,Q=Q+Math.imul(T,fJ)|0,Q=Q+Math.imul(D,cJ)|0,K=K+Math.imul(D,fJ)|0,G=G+Math.imul(LJ,f)|0,Q=Q+Math.imul(LJ,zJ)|0,Q=Q+Math.imul(IJ,f)|0,K=K+Math.imul(IJ,zJ)|0;var HQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(HQ>>>26)|0,HQ&=67108863,G=Math.imul(d,cJ),Q=Math.imul(d,fJ),Q=Q+Math.imul(a,cJ)|0,K=Math.imul(a,fJ),G=G+Math.imul(T,f)|0,Q=Q+Math.imul(T,zJ)|0,Q=Q+Math.imul(D,f)|0,K=K+Math.imul(D,zJ)|0;var DQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(DQ>>>26)|0,DQ&=67108863,G=Math.imul(d,f),Q=Math.imul(d,zJ),Q=Q+Math.imul(a,f)|0,K=Math.imul(a,zJ);var KQ=(H+G|0)+((Q&8191)<<13)|0;return H=(K+(Q>>>13)|0)+(KQ>>>26)|0,KQ&=67108863,U[0]=CQ,U[1]=oJ,U[2]=tJ,U[3]=YQ,U[4]=BQ,U[5]=OQ,U[6]=jQ,U[7]=TQ,U[8]=NQ,U[9]=IQ,U[10]=EQ,U[11]=RQ,U[12]=zQ,U[13]=PQ,U[14]=LQ,U[15]=FQ,U[16]=HQ,U[17]=DQ,U[18]=KQ,H!==0&&(U[19]=H,Z.length++),Z};Math.imul||(F=P);function v(J,V,Z){Z.negative=V.negative^J.negative,Z.length=J.length+V.length;for(var $=0,X=0,U=0;U<Z.length-1;U++){var H=X;X=0;for(var G=$&67108863,Q=Math.min(U,V.length-1),K=Math.max(0,U-J.length+1);K<=Q;K++){var k=U-K,L=J.words[k]|0,_=V.words[K]|0,t=L*_,QJ=t&67108863;H=H+(t/67108864|0)|0,QJ=QJ+G|0,G=QJ&67108863,H=H+(QJ>>>26)|0,X+=H>>>26,H&=67108863}Z.words[U]=G,$=H,H=X}return $!==0?Z.words[U]=$:Z.length--,Z.strip()}function S(J,V,Z){var $=new w;return $.mulp(J,V,Z)}q.prototype.mulTo=function(J,V){var Z,$=this.length+J.length;return this.length===10&&J.length===10?Z=F(this,J,V):$<63?Z=P(this,J,V):$<1024?Z=v(this,J,V):Z=S(this,J,V),Z};function w(J,V){this.x=J,this.y=V}w.prototype.makeRBT=function(J){for(var V=new Array(J),Z=q.prototype._countBits(J)-1,$=0;$<J;$++)V[$]=this.revBin($,Z,J);return V},w.prototype.revBin=function(J,V,Z){if(J===0||J===Z-1)return J;for(var $=0,X=0;X<V;X++)$|=(J&1)<<V-X-1,J>>=1;return $},w.prototype.permute=function(J,V,Z,$,X,U){for(var H=0;H<U;H++)$[H]=V[J[H]],X[H]=Z[J[H]]},w.prototype.transform=function(J,V,Z,$,X,U){this.permute(U,J,V,Z,$,X);for(var H=1;H<X;H<<=1)for(var G=H<<1,Q=Math.cos(2*Math.PI/G),K=Math.sin(2*Math.PI/G),k=0;k<X;k+=G)for(var L=Q,_=K,t=0;t<H;t++){var QJ=Z[k+t],GJ=$[k+t],n=Z[k+t+H],p=$[k+t+H],e=L*n-_*p;p=L*p+_*n,n=e,Z[k+t]=QJ+n,$[k+t]=GJ+p,Z[k+t+H]=QJ-n,$[k+t+H]=GJ-p,t!==G&&(e=Q*L-K*_,_=Q*_+K*L,L=e)}},w.prototype.guessLen13b=function(J,V){var Z=Math.max(V,J)|1,$=Z&1,X=0;for(Z=Z/2|0;Z;Z=Z>>>1)X++;return 1<<X+1+$},w.prototype.conjugate=function(J,V,Z){if(!(Z<=1))for(var $=0;$<Z/2;$++){var X=J[$];J[$]=J[Z-$-1],J[Z-$-1]=X,X=V[$],V[$]=-V[Z-$-1],V[Z-$-1]=-X}},w.prototype.normalize13b=function(J,V){for(var Z=0,$=0;$<V/2;$++){var X=Math.round(J[2*$+1]/V)*8192+Math.round(J[2*$]/V)+Z;J[$]=X&67108863,X<67108864?Z=0:Z=X/67108864|0}return J},w.prototype.convert13b=function(J,V,Z,$){for(var X=0,U=0;U<V;U++)X=X+(J[U]|0),Z[2*U]=X&8191,X=X>>>13,Z[2*U+1]=X&8191,X=X>>>13;for(U=2*V;U<$;++U)Z[U]=0;B(X===0),B((X&-8192)===0)},w.prototype.stub=function(J){for(var V=new Array(J),Z=0;Z<J;Z++)V[Z]=0;return V},w.prototype.mulp=function(J,V,Z){var $=2*this.guessLen13b(J.length,V.length),X=this.makeRBT($),U=this.stub($),H=new Array($),G=new Array($),Q=new Array($),K=new Array($),k=new Array($),L=new Array($),_=Z.words;_.length=$,this.convert13b(J.words,J.length,H,$),this.convert13b(V.words,V.length,K,$),this.transform(H,U,G,Q,$,X),this.transform(K,U,k,L,$,X);for(var t=0;t<$;t++){var QJ=G[t]*k[t]-Q[t]*L[t];Q[t]=G[t]*L[t]+Q[t]*k[t],G[t]=QJ}return this.conjugate(G,Q,$),this.transform(G,Q,_,U,$,X),this.conjugate(_,U,$),this.normalize13b(_,$),Z.negative=J.negative^V.negative,Z.length=J.length+V.length,Z.strip()},q.prototype.mul=function(J){var V=new q(null);return V.words=new Array(this.length+J.length),this.mulTo(J,V)},q.prototype.mulf=function(J){var V=new q(null);return V.words=new Array(this.length+J.length),S(this,J,V)},q.prototype.imul=function(J){return this.clone().mulTo(J,this)},q.prototype.imuln=function(J){B(typeof J=="number"),B(J<67108864);for(var V=0,Z=0;Z<this.length;Z++){var $=(this.words[Z]|0)*J,X=($&67108863)+(V&67108863);V>>=26,V+=$/67108864|0,V+=X>>>26,this.words[Z]=X&67108863}return V!==0&&(this.words[Z]=V,this.length++),this},q.prototype.muln=function(J){return this.clone().imuln(J)},q.prototype.sqr=function(){return this.mul(this)},q.prototype.isqr=function(){return this.imul(this.clone())},q.prototype.pow=function(J){var V=j(J);if(V.length===0)return new q(1);for(var Z=this,$=0;$<V.length&&V[$]===0;$++,Z=Z.sqr());if(++$<V.length)for(var X=Z.sqr();$<V.length;$++,X=X.sqr())V[$]!==0&&(Z=Z.mul(X));return Z},q.prototype.iushln=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26,$=67108863>>>26-V<<26-V,X;if(V!==0){var U=0;for(X=0;X<this.length;X++){var H=this.words[X]&$,G=(this.words[X]|0)-H<<V;this.words[X]=G|U,U=H>>>26-V}U&&(this.words[X]=U,this.length++)}if(Z!==0){for(X=this.length-1;X>=0;X--)this.words[X+Z]=this.words[X];for(X=0;X<Z;X++)this.words[X]=0;this.length+=Z}return this.strip()},q.prototype.ishln=function(J){return B(this.negative===0),this.iushln(J)},q.prototype.iushrn=function(J,V,Z){B(typeof J=="number"&&J>=0);var $;V?$=(V-V%26)/26:$=0;var X=J%26,U=Math.min((J-X)/26,this.length),H=67108863^67108863>>>X<<X,G=Z;if($-=U,$=Math.max(0,$),G){for(var Q=0;Q<U;Q++)G.words[Q]=this.words[Q];G.length=U}if(U!==0)if(this.length>U)for(this.length-=U,Q=0;Q<this.length;Q++)this.words[Q]=this.words[Q+U];else this.words[0]=0,this.length=1;var K=0;for(Q=this.length-1;Q>=0&&(K!==0||Q>=$);Q--){var k=this.words[Q]|0;this.words[Q]=K<<26-X|k>>>X,K=k&H}return G&&K!==0&&(G.words[G.length++]=K),this.length===0&&(this.words[0]=0,this.length=1),this.strip()},q.prototype.ishrn=function(J,V,Z){return B(this.negative===0),this.iushrn(J,V,Z)},q.prototype.shln=function(J){return this.clone().ishln(J)},q.prototype.ushln=function(J){return this.clone().iushln(J)},q.prototype.shrn=function(J){return this.clone().ishrn(J)},q.prototype.ushrn=function(J){return this.clone().iushrn(J)},q.prototype.testn=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26,$=1<<V;if(this.length<=Z)return!1;var X=this.words[Z];return!!(X&$)},q.prototype.imaskn=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26;if(B(this.negative===0,"imaskn works only with positive numbers"),this.length<=Z)return this;if(V!==0&&Z++,this.length=Math.min(Z,this.length),V!==0){var $=67108863^67108863>>>V<<V;this.words[this.length-1]&=$}return this.strip()},q.prototype.maskn=function(J){return this.clone().imaskn(J)},q.prototype.iaddn=function(J){return B(typeof J=="number"),B(J<67108864),J<0?this.isubn(-J):this.negative!==0?this.length===1&&(this.words[0]|0)<J?(this.words[0]=J-(this.words[0]|0),this.negative=0,this):(this.negative=0,this.isubn(J),this.negative=1,this):this._iaddn(J)},q.prototype._iaddn=function(J){this.words[0]+=J;for(var V=0;V<this.length&&this.words[V]>=67108864;V++)this.words[V]-=67108864,V===this.length-1?this.words[V+1]=1:this.words[V+1]++;return this.length=Math.max(this.length,V+1),this},q.prototype.isubn=function(J){if(B(typeof J=="number"),B(J<67108864),J<0)return this.iaddn(-J);if(this.negative!==0)return this.negative=0,this.iaddn(J),this.negative=1,this;if(this.words[0]-=J,this.length===1&&this.words[0]<0)this.words[0]=-this.words[0],this.negative=1;else for(var V=0;V<this.length&&this.words[V]<0;V++)this.words[V]+=67108864,this.words[V+1]-=1;return this.strip()},q.prototype.addn=function(J){return this.clone().iaddn(J)},q.prototype.subn=function(J){return this.clone().isubn(J)},q.prototype.iabs=function(){return this.negative=0,this},q.prototype.abs=function(){return this.clone().iabs()},q.prototype._ishlnsubmul=function(J,V,Z){var $=J.length+Z,X;this._expand($);var U,H=0;for(X=0;X<J.length;X++){U=(this.words[X+Z]|0)+H;var G=(J.words[X]|0)*V;U-=G&67108863,H=(U>>26)-(G/67108864|0),this.words[X+Z]=U&67108863}for(;X<this.length-Z;X++)U=(this.words[X+Z]|0)+H,H=U>>26,this.words[X+Z]=U&67108863;if(H===0)return this.strip();for(B(H===-1),H=0,X=0;X<this.length;X++)U=-(this.words[X]|0)+H,H=U>>26,this.words[X]=U&67108863;return this.negative=1,this.strip()},q.prototype._wordDiv=function(J,V){var Z=this.length-J.length,$=this.clone(),X=J,U=X.words[X.length-1]|0,H=this._countBits(U);Z=26-H,Z!==0&&(X=X.ushln(Z),$.iushln(Z),U=X.words[X.length-1]|0);var G=$.length-X.length,Q;if(V!=="mod"){Q=new q(null),Q.length=G+1,Q.words=new Array(Q.length);for(var K=0;K<Q.length;K++)Q.words[K]=0}var k=$.clone()._ishlnsubmul(X,1,G);k.negative===0&&($=k,Q&&(Q.words[G]=1));for(var L=G-1;L>=0;L--){var _=($.words[X.length+L]|0)*67108864+($.words[X.length+L-1]|0);for(_=Math.min(_/U|0,67108863),$._ishlnsubmul(X,_,L);$.negative!==0;)_--,$.negative=0,$._ishlnsubmul(X,1,L),$.isZero()||($.negative^=1);Q&&(Q.words[L]=_)}return Q&&Q.strip(),$.strip(),V!=="div"&&Z!==0&&$.iushrn(Z),{div:Q||null,mod:$}},q.prototype.divmod=function(J,V,Z){if(B(!J.isZero()),this.isZero())return{div:new q(0),mod:new q(0)};var $,X,U;return this.negative!==0&&J.negative===0?(U=this.neg().divmod(J,V),V!=="mod"&&($=U.div.neg()),V!=="div"&&(X=U.mod.neg(),Z&&X.negative!==0&&X.iadd(J)),{div:$,mod:X}):this.negative===0&&J.negative!==0?(U=this.divmod(J.neg(),V),V!=="mod"&&($=U.div.neg()),{div:$,mod:U.mod}):(this.negative&J.negative)!==0?(U=this.neg().divmod(J.neg(),V),V!=="div"&&(X=U.mod.neg(),Z&&X.negative!==0&&X.isub(J)),{div:U.div,mod:X}):J.length>this.length||this.cmp(J)<0?{div:new q(0),mod:this}:J.length===1?V==="div"?{div:this.divn(J.words[0]),mod:null}:V==="mod"?{div:null,mod:new q(this.modn(J.words[0]))}:{div:this.divn(J.words[0]),mod:new q(this.modn(J.words[0]))}:this._wordDiv(J,V)},q.prototype.div=function(J){return this.divmod(J,"div",!1).div},q.prototype.mod=function(J){return this.divmod(J,"mod",!1).mod},q.prototype.umod=function(J){return this.divmod(J,"mod",!0).mod},q.prototype.divRound=function(J){var V=this.divmod(J);if(V.mod.isZero())return V.div;var Z=V.div.negative!==0?V.mod.isub(J):V.mod,$=J.ushrn(1),X=J.andln(1),U=Z.cmp($);return U<0||X===1&&U===0?V.div:V.div.negative!==0?V.div.isubn(1):V.div.iaddn(1)},q.prototype.modn=function(J){B(J<=67108863);for(var V=(1<<26)%J,Z=0,$=this.length-1;$>=0;$--)Z=(V*Z+(this.words[$]|0))%J;return Z},q.prototype.idivn=function(J){B(J<=67108863);for(var V=0,Z=this.length-1;Z>=0;Z--){var $=(this.words[Z]|0)+V*67108864;this.words[Z]=$/J|0,V=$%J}return this.strip()},q.prototype.divn=function(J){return this.clone().idivn(J)},q.prototype.egcd=function(J){B(J.negative===0),B(!J.isZero());var V=this,Z=J.clone();V.negative!==0?V=V.umod(J):V=V.clone();for(var $=new q(1),X=new q(0),U=new q(0),H=new q(1),G=0;V.isEven()&&Z.isEven();)V.iushrn(1),Z.iushrn(1),++G;for(var Q=Z.clone(),K=V.clone();!V.isZero();){for(var k=0,L=1;(V.words[0]&L)===0&&k<26;++k,L<<=1);if(k>0)for(V.iushrn(k);k-- >0;)($.isOdd()||X.isOdd())&&($.iadd(Q),X.isub(K)),$.iushrn(1),X.iushrn(1);for(var _=0,t=1;(Z.words[0]&t)===0&&_<26;++_,t<<=1);if(_>0)for(Z.iushrn(_);_-- >0;)(U.isOdd()||H.isOdd())&&(U.iadd(Q),H.isub(K)),U.iushrn(1),H.iushrn(1);V.cmp(Z)>=0?(V.isub(Z),$.isub(U),X.isub(H)):(Z.isub(V),U.isub($),H.isub(X))}return{a:U,b:H,gcd:Z.iushln(G)}},q.prototype._invmp=function(J){B(J.negative===0),B(!J.isZero());var V=this,Z=J.clone();V.negative!==0?V=V.umod(J):V=V.clone();for(var $=new q(1),X=new q(0),U=Z.clone();V.cmpn(1)>0&&Z.cmpn(1)>0;){for(var H=0,G=1;(V.words[0]&G)===0&&H<26;++H,G<<=1);if(H>0)for(V.iushrn(H);H-- >0;)$.isOdd()&&$.iadd(U),$.iushrn(1);for(var Q=0,K=1;(Z.words[0]&K)===0&&Q<26;++Q,K<<=1);if(Q>0)for(Z.iushrn(Q);Q-- >0;)X.isOdd()&&X.iadd(U),X.iushrn(1);V.cmp(Z)>=0?(V.isub(Z),$.isub(X)):(Z.isub(V),X.isub($))}var k;return V.cmpn(1)===0?k=$:k=X,k.cmpn(0)<0&&k.iadd(J),k},q.prototype.gcd=function(J){if(this.isZero())return J.abs();if(J.isZero())return this.abs();var V=this.clone(),Z=J.clone();V.negative=0,Z.negative=0;for(var $=0;V.isEven()&&Z.isEven();$++)V.iushrn(1),Z.iushrn(1);do{for(;V.isEven();)V.iushrn(1);for(;Z.isEven();)Z.iushrn(1);var X=V.cmp(Z);if(X<0){var U=V;V=Z,Z=U}else if(X===0||Z.cmpn(1)===0)break;V.isub(Z)}while(!0);return Z.iushln($)},q.prototype.invm=function(J){return this.egcd(J).a.umod(J)},q.prototype.isEven=function(){return(this.words[0]&1)===0},q.prototype.isOdd=function(){return(this.words[0]&1)===1},q.prototype.andln=function(J){return this.words[0]&J},q.prototype.bincn=function(J){B(typeof J=="number");var V=J%26,Z=(J-V)/26,$=1<<V;if(this.length<=Z)return this._expand(Z+1),this.words[Z]|=$,this;for(var X=$,U=Z;X!==0&&U<this.length;U++){var H=this.words[U]|0;H+=X,X=H>>>26,H&=67108863,this.words[U]=H}return X!==0&&(this.words[U]=X,this.length++),this},q.prototype.isZero=function(){return this.length===1&&this.words[0]===0},q.prototype.cmpn=function(J){var V=J<0;if(this.negative!==0&&!V)return-1;if(this.negative===0&&V)return 1;this.strip();var Z;if(this.length>1)Z=1;else{V&&(J=-J),B(J<=67108863,"Number is too big");var $=this.words[0]|0;Z=$===J?0:$<J?-1:1}return this.negative!==0?-Z|0:Z},q.prototype.cmp=function(J){if(this.negative!==0&&J.negative===0)return-1;if(this.negative===0&&J.negative!==0)return 1;var V=this.ucmp(J);return this.negative!==0?-V|0:V},q.prototype.ucmp=function(J){if(this.length>J.length)return 1;if(this.length<J.length)return-1;for(var V=0,Z=this.length-1;Z>=0;Z--){var $=this.words[Z]|0,X=J.words[Z]|0;if($!==X){$<X?V=-1:$>X&&(V=1);break}}return V},q.prototype.gtn=function(J){return this.cmpn(J)===1},q.prototype.gt=function(J){return this.cmp(J)===1},q.prototype.gten=function(J){return this.cmpn(J)>=0},q.prototype.gte=function(J){return this.cmp(J)>=0},q.prototype.ltn=function(J){return this.cmpn(J)===-1},q.prototype.lt=function(J){return this.cmp(J)===-1},q.prototype.lten=function(J){return this.cmpn(J)<=0},q.prototype.lte=function(J){return this.cmp(J)<=0},q.prototype.eqn=function(J){return this.cmpn(J)===0},q.prototype.eq=function(J){return this.cmp(J)===0},q.red=function(J){return new o(J)},q.prototype.toRed=function(J){return B(!this.red,"Already a number in reduction context"),B(this.negative===0,"red works only with positives"),J.convertTo(this)._forceRed(J)},q.prototype.fromRed=function(){return B(this.red,"fromRed works only with numbers in reduction context"),this.red.convertFrom(this)},q.prototype._forceRed=function(J){return this.red=J,this},q.prototype.forceRed=function(J){return B(!this.red,"Already a number in reduction context"),this._forceRed(J)},q.prototype.redAdd=function(J){return B(this.red,"redAdd works only with red numbers"),this.red.add(this,J)},q.prototype.redIAdd=function(J){return B(this.red,"redIAdd works only with red numbers"),this.red.iadd(this,J)},q.prototype.redSub=function(J){return B(this.red,"redSub works only with red numbers"),this.red.sub(this,J)},q.prototype.redISub=function(J){return B(this.red,"redISub works only with red numbers"),this.red.isub(this,J)},q.prototype.redShl=function(J){return B(this.red,"redShl works only with red numbers"),this.red.shl(this,J)},q.prototype.redMul=function(J){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,J),this.red.mul(this,J)},q.prototype.redIMul=function(J){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,J),this.red.imul(this,J)},q.prototype.redSqr=function(){return B(this.red,"redSqr works only with red numbers"),this.red._verify1(this),this.red.sqr(this)},q.prototype.redISqr=function(){return B(this.red,"redISqr works only with red numbers"),this.red._verify1(this),this.red.isqr(this)},q.prototype.redSqrt=function(){return B(this.red,"redSqrt works only with red numbers"),this.red._verify1(this),this.red.sqrt(this)},q.prototype.redInvm=function(){return B(this.red,"redInvm works only with red numbers"),this.red._verify1(this),this.red.invm(this)},q.prototype.redNeg=function(){return B(this.red,"redNeg works only with red numbers"),this.red._verify1(this),this.red.neg(this)},q.prototype.redPow=function(J){return B(this.red&&!J.red,"redPow(normalNum)"),this.red._verify1(this),this.red.pow(this,J)};var y={k256:null,p224:null,p192:null,p25519:null};function m(J,V){this.name=J,this.p=new q(V,16),this.n=this.p.bitLength(),this.k=new q(1).iushln(this.n).isub(this.p),this.tmp=this._tmp()}m.prototype._tmp=function(){var J=new q(null);return J.words=new Array(Math.ceil(this.n/13)),J},m.prototype.ireduce=function(J){var V=J,Z;do this.split(V,this.tmp),V=this.imulK(V),V=V.iadd(this.tmp),Z=V.bitLength();while(Z>this.n);var $=Z<this.n?-1:V.ucmp(this.p);return $===0?(V.words[0]=0,V.length=1):$>0?V.isub(this.p):V.strip!==void 0?V.strip():V._strip(),V},m.prototype.split=function(J,V){J.iushrn(this.n,0,V)},m.prototype.imulK=function(J){return J.imul(this.k)};function i(){m.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}A(i,m),i.prototype.split=function(J,V){for(var Z=4194303,$=Math.min(J.length,9),X=0;X<$;X++)V.words[X]=J.words[X];if(V.length=$,J.length<=9){J.words[0]=0,J.length=1;return}var U=J.words[9];for(V.words[V.length++]=U&Z,X=10;X<J.length;X++){var H=J.words[X]|0;J.words[X-10]=(H&Z)<<4|U>>>22,U=H}U>>>=22,J.words[X-10]=U,U===0&&J.length>10?J.length-=10:J.length-=9},i.prototype.imulK=function(J){J.words[J.length]=0,J.words[J.length+1]=0,J.length+=2;for(var V=0,Z=0;Z<J.length;Z++){var $=J.words[Z]|0;V+=$*977,J.words[Z]=V&67108863,V=$*64+(V/67108864|0)}return J.words[J.length-1]===0&&(J.length--,J.words[J.length-1]===0&&J.length--),J};function JJ(){m.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}A(JJ,m);function VJ(){m.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}A(VJ,m);function HJ(){m.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}A(HJ,m),HJ.prototype.imulK=function(J){for(var V=0,Z=0;Z<J.length;Z++){var $=(J.words[Z]|0)*19+V,X=$&67108863;$>>>=26,J.words[Z]=X,V=$}return V!==0&&(J.words[J.length++]=V),J},q._prime=function(J){if(y[J])return y[J];var V;if(J==="k256")V=new i;else if(J==="p224")V=new JJ;else if(J==="p192")V=new VJ;else if(J==="p25519")V=new HJ;else throw new Error("Unknown prime "+J);return y[J]=V,V};function o(J){if(typeof J=="string"){var V=q._prime(J);this.m=V.p,this.prime=V}else B(J.gtn(1),"modulus must be greater than 1"),this.m=J,this.prime=null}o.prototype._verify1=function(J){B(J.negative===0,"red works only with positives"),B(J.red,"red works only with red numbers")},o.prototype._verify2=function(J,V){B((J.negative|V.negative)===0,"red works only with positives"),B(J.red&&J.red===V.red,"red works only with red numbers")},o.prototype.imod=function(J){return this.prime?this.prime.ireduce(J)._forceRed(this):J.umod(this.m)._forceRed(this)},o.prototype.neg=function(J){return J.isZero()?J.clone():this.m.sub(J)._forceRed(this)},o.prototype.add=function(J,V){this._verify2(J,V);var Z=J.add(V);return Z.cmp(this.m)>=0&&Z.isub(this.m),Z._forceRed(this)},o.prototype.iadd=function(J,V){this._verify2(J,V);var Z=J.iadd(V);return Z.cmp(this.m)>=0&&Z.isub(this.m),Z},o.prototype.sub=function(J,V){this._verify2(J,V);var Z=J.sub(V);return Z.cmpn(0)<0&&Z.iadd(this.m),Z._forceRed(this)},o.prototype.isub=function(J,V){this._verify2(J,V);var Z=J.isub(V);return Z.cmpn(0)<0&&Z.iadd(this.m),Z},o.prototype.shl=function(J,V){return this._verify1(J),this.imod(J.ushln(V))},o.prototype.imul=function(J,V){return this._verify2(J,V),this.imod(J.imul(V))},o.prototype.mul=function(J,V){return this._verify2(J,V),this.imod(J.mul(V))},o.prototype.isqr=function(J){return this.imul(J,J.clone())},o.prototype.sqr=function(J){return this.mul(J,J)},o.prototype.sqrt=function(J){if(J.isZero())return J.clone();var V=this.m.andln(3);if(B(V%2===1),V===3){var Z=this.m.add(new q(1)).iushrn(2);return this.pow(J,Z)}for(var $=this.m.subn(1),X=0;!$.isZero()&&$.andln(1)===0;)X++,$.iushrn(1);B(!$.isZero());var U=new q(1).toRed(this),H=U.redNeg(),G=this.m.subn(1).iushrn(1),Q=this.m.bitLength();for(Q=new q(2*Q*Q).toRed(this);this.pow(Q,G).cmp(H)!==0;)Q.redIAdd(H);for(var K=this.pow(Q,$),k=this.pow(J,$.addn(1).iushrn(1)),L=this.pow(J,$),_=X;L.cmp(U)!==0;){for(var t=L,QJ=0;t.cmp(U)!==0;QJ++)t=t.redSqr();B(QJ<_);var GJ=this.pow(K,new q(1).iushln(_-QJ-1));k=k.redMul(GJ),K=GJ.redSqr(),L=L.redMul(K),_=QJ}return k},o.prototype.invm=function(J){var V=J._invmp(this.m);return V.negative!==0?(V.negative=0,this.imod(V).redNeg()):this.imod(V)},o.prototype.pow=function(J,V){if(V.isZero())return new q(1).toRed(this);if(V.cmpn(1)===0)return J.clone();var Z=4,$=new Array(1<<Z);$[0]=new q(1).toRed(this),$[1]=J;for(var X=2;X<$.length;X++)$[X]=this.mul($[X-1],J);var U=$[0],H=0,G=0,Q=V.bitLength()%26;for(Q===0&&(Q=26),X=V.length-1;X>=0;X--){for(var K=V.words[X],k=Q-1;k>=0;k--){var L=K>>k&1;if(U!==$[0]&&(U=this.sqr(U)),L===0&&H===0){G=0;continue}H<<=1,H|=L,G++,!(G!==Z&&(X!==0||k!==0))&&(U=this.mul(U,$[H]),G=0,H=0)}Q=26}return U},o.prototype.convertTo=function(J){var V=J.umod(this.m);return V===J?V.clone():V},o.prototype.convertFrom=function(J){var V=J.clone();return V.red=null,V},q.mont=function(J){return new jJ(J)};function jJ(J){o.call(this,J),this.shift=this.m.bitLength(),this.shift%26!==0&&(this.shift+=26-this.shift%26),this.r=new q(1).iushln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv=this.minv.umod(this.r),this.minv=this.r.sub(this.minv)}A(jJ,o),jJ.prototype.convertTo=function(J){return this.imod(J.ushln(this.shift))},jJ.prototype.convertFrom=function(J){var V=this.imod(J.mul(this.rinv));return V.red=null,V},jJ.prototype.imul=function(J,V){if(J.isZero()||V.isZero())return J.words[0]=0,J.length=1,J;var Z=J.imul(V),$=Z.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),X=Z.isub($).iushrn(this.shift),U=X;return X.cmp(this.m)>=0?U=X.isub(this.m):X.cmpn(0)<0&&(U=X.iadd(this.m)),U._forceRed(this)},jJ.prototype.mul=function(J,V){if(J.isZero()||V.isZero())return new q(0)._forceRed(this);var Z=J.mul(V),$=Z.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),X=Z.isub($).iushrn(this.shift),U=X;return X.cmp(this.m)>=0?U=X.isub(this.m):X.cmpn(0)<0&&(U=X.iadd(this.m)),U._forceRed(this)},jJ.prototype.invm=function(J){var V=this.imod(J._invmp(this.m).mul(this.r2));return V._forceRed(this)}})(typeof g>"u"||g,l)}),g8=OJ((l,g)=>{(function(R,M){function B(J,V){if(!J)throw new Error(V||"Assertion failed")}function A(J,V){J.super_=V;var Z=function(){};Z.prototype=V.prototype,J.prototype=new Z,J.prototype.constructor=J}function q(J,V,Z){if(q.isBN(J))return J;this.negative=0,this.words=null,this.length=0,this.red=null,J!==null&&((V==="le"||V==="be")&&(Z=V,V=10),this._init(J||0,V||10,Z||"be"))}typeof R=="object"?R.exports=q:M.BN=q,q.BN=q,q.wordSize=26;var Y;try{typeof window<"u"&&typeof window.Buffer<"u"?Y=window.Buffer:Y=JV().Buffer}catch{}q.isBN=function(J){return J instanceof q?!0:J!==null&&typeof J=="object"&&J.constructor.wordSize===q.wordSize&&Array.isArray(J.words)},q.max=function(J,V){return J.cmp(V)>0?J:V},q.min=function(J,V){return J.cmp(V)<0?J:V},q.prototype._init=function(J,V,Z){if(typeof J=="number")return this._initNumber(J,V,Z);if(typeof J=="object")return this._initArray(J,V,Z);V==="hex"&&(V=16),B(V===(V|0)&&V>=2&&V<=36),J=J.toString().replace(/\s+/g,"");var $=0;J[0]==="-"&&($++,this.negative=1),$<J.length&&(V===16?this._parseHex(J,$,Z):(this._parseBase(J,V,$),Z==="le"&&this._initArray(this.toArray(),V,Z)))},q.prototype._initNumber=function(J,V,Z){J<0&&(this.negative=1,J=-J),J<67108864?(this.words=[J&67108863],this.length=1):J<4503599627370496?(this.words=[J&67108863,J/67108864&67108863],this.length=2):(B(J<9007199254740992),this.words=[J&67108863,J/67108864&67108863,1],this.length=3),Z==="le"&&this._initArray(this.toArray(),V,Z)},q.prototype._initArray=function(J,V,Z){if(B(typeof J.length=="number"),J.length<=0)return this.words=[0],this.length=1,this;this.length=Math.ceil(J.length/3),this.words=new Array(this.length);for(var $=0;$<this.length;$++)this.words[$]=0;var X,U,H=0;if(Z==="be")for($=J.length-1,X=0;$>=0;$-=3)U=J[$]|J[$-1]<<8|J[$-2]<<16,this.words[X]|=U<<H&67108863,this.words[X+1]=U>>>26-H&67108863,H+=24,H>=26&&(H-=26,X++);else if(Z==="le")for($=0,X=0;$<J.length;$+=3)U=J[$]|J[$+1]<<8|J[$+2]<<16,this.words[X]|=U<<H&67108863,this.words[X+1]=U>>>26-H&67108863,H+=24,H>=26&&(H-=26,X++);return this.strip()};function E(J,V){var Z=J.charCodeAt(V);return Z>=65&&Z<=70?Z-55:Z>=97&&Z<=102?Z-87:Z-48&15}function O(J,V,Z){var $=E(J,Z);return Z-1>=V&&($|=E(J,Z-1)<<4),$}q.prototype._parseHex=function(J,V,Z){this.length=Math.ceil((J.length-V)/6),this.words=new Array(this.length);for(var $=0;$<this.length;$++)this.words[$]=0;var X=0,U=0,H;if(Z==="be")for($=J.length-1;$>=V;$-=2)H=O(J,V,$)<<X,this.words[U]|=H&67108863,X>=18?(X-=18,U+=1,this.words[U]|=H>>>26):X+=8;else{var G=J.length-V;for($=G%2===0?V+1:V;$<J.length;$+=2)H=O(J,V,$)<<X,this.words[U]|=H&67108863,X>=18?(X-=18,U+=1,this.words[U]|=H>>>26):X+=8}this.strip()};function N(J,V,Z,$){for(var X=0,U=Math.min(J.length,Z),H=V;H<U;H++){var G=J.charCodeAt(H)-48;X*=$,G>=49?X+=G-49+10:G>=17?X+=G-17+10:X+=G}return X}q.prototype._parseBase=function(J,V,Z){this.words=[0],this.length=1;for(var $=0,X=1;X<=67108863;X*=V)$++;$--,X=X/V|0;for(var U=J.length-Z,H=U%$,G=Math.min(U,U-H)+Z,Q=0,K=Z;K<G;K+=$)Q=N(J,K,K+$,V),this.imuln(X),this.words[0]+Q<67108864?this.words[0]+=Q:this._iaddn(Q);if(H!==0){var k=1;for(Q=N(J,K,J.length,V),K=0;K<H;K++)k*=V;this.imuln(k),this.words[0]+Q<67108864?this.words[0]+=Q:this._iaddn(Q)}this.strip()},q.prototype.copy=function(J){J.words=new Array(this.length);for(var V=0;V<this.length;V++)J.words[V]=this.words[V];J.length=this.length,J.negative=this.negative,J.red=this.red},q.prototype.clone=function(){var J=new q(null);return this.copy(J),J},q.prototype._expand=function(J){for(;this.length<J;)this.words[this.length++]=0;return this},q.prototype.strip=function(){for(;this.length>1&&this.words[this.length-1]===0;)this.length--;return this._normSign()},q.prototype._normSign=function(){return this.length===1&&this.words[0]===0&&(this.negative=0),this},q.prototype.inspect=function(){return(this.red?"<BN-R: ":"<BN: ")+this.toString(16)+">"};var W=["","0","00","000","0000","00000","000000","0000000","00000000","000000000","0000000000","00000000000","000000000000","0000000000000","00000000000000","000000000000000","0000000000000000","00000000000000000","000000000000000000","0000000000000000000","00000000000000000000","000000000000000000000","0000000000000000000000","00000000000000000000000","000000000000000000000000","0000000000000000000000000"],I=[0,0,25,16,12,11,10,9,8,8,7,7,7,7,6,6,6,6,6,6,6,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5],z=[0,0,33554432,43046721,16777216,48828125,60466176,40353607,16777216,43046721,1e7,19487171,35831808,62748517,7529536,11390625,16777216,24137569,34012224,47045881,64000000,4084101,5153632,6436343,7962624,9765625,11881376,14348907,17210368,20511149,24300000,28629151,33554432,39135393,45435424,52521875,60466176];q.prototype.toString=function(J,V){J=J||10,V=V|0||1;var Z;if(J===16||J==="hex"){Z="";for(var $=0,X=0,U=0;U<this.length;U++){var H=this.words[U],G=((H<<$|X)&16777215).toString(16);X=H>>>24-$&16777215,X!==0||U!==this.length-1?Z=W[6-G.length]+G+Z:Z=G+Z,$+=2,$>=26&&($-=26,U--)}for(X!==0&&(Z=X.toString(16)+Z);Z.length%V!==0;)Z="0"+Z;return this.negative!==0&&(Z="-"+Z),Z}if(J===(J|0)&&J>=2&&J<=36){var Q=I[J],K=z[J];Z="";var k=this.clone();for(k.negative=0;!k.isZero();){var L=k.modn(K).toString(J);k=k.idivn(K),k.isZero()?Z=L+Z:Z=W[Q-L.length]+L+Z}for(this.isZero()&&(Z="0"+Z);Z.length%V!==0;)Z="0"+Z;return this.negative!==0&&(Z="-"+Z),Z}B(!1,"Base should be between 2 and 36")},q.prototype.toNumber=function(){var J=this.words[0];return this.length===2?J+=this.words[1]*67108864:this.length===3&&this.words[2]===1?J+=4503599627370496+this.words[1]*67108864:this.length>2&&B(!1,"Number can only safely store up to 53 bits"),this.negative!==0?-J:J},q.prototype.toJSON=function(){return this.toString(16)},q.prototype.toBuffer=function(J,V){return B(typeof Y<"u"),this.toArrayLike(Y,J,V)},q.prototype.toArray=function(J,V){return this.toArrayLike(Array,J,V)},q.prototype.toArrayLike=function(J,V,Z){var $=this.byteLength(),X=Z||Math.max(1,$);B($<=X,"byte array longer than desired length"),B(X>0,"Requested array length <= 0"),this.strip();var U=V==="le",H=new J(X),G,Q,K=this.clone();if(U){for(Q=0;!K.isZero();Q++)G=K.andln(255),K.iushrn(8),H[Q]=G;for(;Q<X;Q++)H[Q]=0}else{for(Q=0;Q<X-$;Q++)H[Q]=0;for(Q=0;!K.isZero();Q++)G=K.andln(255),K.iushrn(8),H[X-Q-1]=G}return H},Math.clz32?q.prototype._countBits=function(J){return 32-Math.clz32(J)}:q.prototype._countBits=function(J){var V=J,Z=0;return V>=4096&&(Z+=13,V>>>=13),V>=64&&(Z+=7,V>>>=7),V>=8&&(Z+=4,V>>>=4),V>=2&&(Z+=2,V>>>=2),Z+V},q.prototype._zeroBits=function(J){if(J===0)return 26;var V=J,Z=0;return(V&8191)===0&&(Z+=13,V>>>=13),(V&127)===0&&(Z+=7,V>>>=7),(V&15)===0&&(Z+=4,V>>>=4),(V&3)===0&&(Z+=2,V>>>=2),(V&1)===0&&Z++,Z},q.prototype.bitLength=function(){var J=this.words[this.length-1],V=this._countBits(J);return(this.length-1)*26+V};function j(J){for(var V=new Array(J.bitLength()),Z=0;Z<V.length;Z++){var $=Z/26|0,X=Z%26;V[Z]=(J.words[$]&1<<X)>>>X}return V}q.prototype.zeroBits=function(){if(this.isZero())return 0;for(var J=0,V=0;V<this.length;V++){var Z=this._zeroBits(this.words[V]);if(J+=Z,Z!==26)break}return J},q.prototype.byteLength=function(){return Math.ceil(this.bitLength()/8)},q.prototype.toTwos=function(J){return this.negative!==0?this.abs().inotn(J).iaddn(1):this.clone()},q.prototype.fromTwos=function(J){return this.testn(J-1)?this.notn(J).iaddn(1).ineg():this.clone()},q.prototype.isNeg=function(){return this.negative!==0},q.prototype.neg=function(){return this.clone().ineg()},q.prototype.ineg=function(){return this.isZero()||(this.negative^=1),this},q.prototype.iuor=function(J){for(;this.length<J.length;)this.words[this.length++]=0;for(var V=0;V<J.length;V++)this.words[V]=this.words[V]|J.words[V];return this.strip()},q.prototype.ior=function(J){return B((this.negative|J.negative)===0),this.iuor(J)},q.prototype.or=function(J){return this.length>J.length?this.clone().ior(J):J.clone().ior(this)},q.prototype.uor=function(J){return this.length>J.length?this.clone().iuor(J):J.clone().iuor(this)},q.prototype.iuand=function(J){var V;this.length>J.length?V=J:V=this;for(var Z=0;Z<V.length;Z++)this.words[Z]=this.words[Z]&J.words[Z];return this.length=V.length,this.strip()},q.prototype.iand=function(J){return B((this.negative|J.negative)===0),this.iuand(J)},q.prototype.and=function(J){return this.length>J.length?this.clone().iand(J):J.clone().iand(this)},q.prototype.uand=function(J){return this.length>J.length?this.clone().iuand(J):J.clone().iuand(this)},q.prototype.iuxor=function(J){var V,Z;this.length>J.length?(V=this,Z=J):(V=J,Z=this);for(var $=0;$<Z.length;$++)this.words[$]=V.words[$]^Z.words[$];if(this!==V)for(;$<V.length;$++)this.words[$]=V.words[$];return this.length=V.length,this.strip()},q.prototype.ixor=function(J){return B((this.negative|J.negative)===0),this.iuxor(J)},q.prototype.xor=function(J){return this.length>J.length?this.clone().ixor(J):J.clone().ixor(this)},q.prototype.uxor=function(J){return this.length>J.length?this.clone().iuxor(J):J.clone().iuxor(this)},q.prototype.inotn=function(J){B(typeof J=="number"&&J>=0);var V=Math.ceil(J/26)|0,Z=J%26;this._expand(V),Z>0&&V--;for(var $=0;$<V;$++)this.words[$]=~this.words[$]&67108863;return Z>0&&(this.words[$]=~this.words[$]&67108863>>26-Z),this.strip()},q.prototype.notn=function(J){return this.clone().inotn(J)},q.prototype.setn=function(J,V){B(typeof J=="number"&&J>=0);var Z=J/26|0,$=J%26;return this._expand(Z+1),V?this.words[Z]=this.words[Z]|1<<$:this.words[Z]=this.words[Z]&~(1<<$),this.strip()},q.prototype.iadd=function(J){var V;if(this.negative!==0&&J.negative===0)return this.negative=0,V=this.isub(J),this.negative^=1,this._normSign();if(this.negative===0&&J.negative!==0)return J.negative=0,V=this.isub(J),J.negative=1,V._normSign();var Z,$;this.length>J.length?(Z=this,$=J):(Z=J,$=this);for(var X=0,U=0;U<$.length;U++)V=(Z.words[U]|0)+($.words[U]|0)+X,this.words[U]=V&67108863,X=V>>>26;for(;X!==0&&U<Z.length;U++)V=(Z.words[U]|0)+X,this.words[U]=V&67108863,X=V>>>26;if(this.length=Z.length,X!==0)this.words[this.length]=X,this.length++;else if(Z!==this)for(;U<Z.length;U++)this.words[U]=Z.words[U];return this},q.prototype.add=function(J){var V;return J.negative!==0&&this.negative===0?(J.negative=0,V=this.sub(J),J.negative^=1,V):J.negative===0&&this.negative!==0?(this.negative=0,V=J.sub(this),this.negative=1,V):this.length>J.length?this.clone().iadd(J):J.clone().iadd(this)},q.prototype.isub=function(J){if(J.negative!==0){J.negative=0;var V=this.iadd(J);return J.negative=1,V._normSign()}else if(this.negative!==0)return this.negative=0,this.iadd(J),this.negative=1,this._normSign();var Z=this.cmp(J);if(Z===0)return this.negative=0,this.length=1,this.words[0]=0,this;var $,X;Z>0?($=this,X=J):($=J,X=this);for(var U=0,H=0;H<X.length;H++)V=($.words[H]|0)-(X.words[H]|0)+U,U=V>>26,this.words[H]=V&67108863;for(;U!==0&&H<$.length;H++)V=($.words[H]|0)+U,U=V>>26,this.words[H]=V&67108863;if(U===0&&H<$.length&&$!==this)for(;H<$.length;H++)this.words[H]=$.words[H];return this.length=Math.max(this.length,H),$!==this&&(this.negative=1),this.strip()},q.prototype.sub=function(J){return this.clone().isub(J)};function P(J,V,Z){Z.negative=V.negative^J.negative;var $=J.length+V.length|0;Z.length=$,$=$-1|0;var X=J.words[0]|0,U=V.words[0]|0,H=X*U,G=H&67108863,Q=H/67108864|0;Z.words[0]=G;for(var K=1;K<$;K++){for(var k=Q>>>26,L=Q&67108863,_=Math.min(K,V.length-1),t=Math.max(0,K-J.length+1);t<=_;t++){var QJ=K-t|0;X=J.words[QJ]|0,U=V.words[t]|0,H=X*U+L,k+=H/67108864|0,L=H&67108863}Z.words[K]=L|0,Q=k|0}return Q!==0?Z.words[K]=Q|0:Z.length--,Z.strip()}var F=function(J,V,Z){var $=J.words,X=V.words,U=Z.words,H=0,G,Q,K,k=$[0]|0,L=k&8191,_=k>>>13,t=$[1]|0,QJ=t&8191,GJ=t>>>13,n=$[2]|0,p=n&8191,e=n>>>13,PJ=$[3]|0,XJ=PJ&8191,WJ=PJ>>>13,b=$[4]|0,C=b&8191,h=b>>>13,$J=$[5]|0,qJ=$J&8191,ZJ=$J>>>13,mJ=$[6]|0,BJ=mJ&8191,TJ=mJ>>>13,dJ=$[7]|0,LJ=dJ&8191,IJ=dJ>>>13,$Q=$[8]|0,T=$Q&8191,D=$Q>>>13,u=$[9]|0,d=u&8191,a=u>>>13,CJ=X[0]|0,UJ=CJ&8191,EJ=CJ>>>13,QQ=X[1]|0,FJ=QQ&8191,RJ=QQ>>>13,aJ=X[2]|0,SJ=aJ&8191,xJ=aJ>>>13,nJ=X[3]|0,AJ=nJ&8191,kJ=nJ>>>13,ZQ=X[4]|0,vJ=ZQ&8191,MJ=ZQ>>>13,xQ=X[5]|0,wJ=xQ&8191,bJ=xQ>>>13,WQ=X[6]|0,_J=WQ&8191,NJ=WQ>>>13,vQ=X[7]|0,yJ=vQ&8191,gJ=vQ>>>13,MQ=X[8]|0,cJ=MQ&8191,fJ=MQ>>>13,wQ=X[9]|0,f=wQ&8191,zJ=wQ>>>13;Z.negative=J.negative^V.negative,Z.length=19,G=Math.imul(L,UJ),Q=Math.imul(L,EJ),Q=Q+Math.imul(_,UJ)|0,K=Math.imul(_,EJ);var CQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(CQ>>>26)|0,CQ&=67108863,G=Math.imul(QJ,UJ),Q=Math.imul(QJ,EJ),Q=Q+Math.imul(GJ,UJ)|0,K=Math.imul(GJ,EJ),G=G+Math.imul(L,FJ)|0,Q=Q+Math.imul(L,RJ)|0,Q=Q+Math.imul(_,FJ)|0,K=K+Math.imul(_,RJ)|0;var oJ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(oJ>>>26)|0,oJ&=67108863,G=Math.imul(p,UJ),Q=Math.imul(p,EJ),Q=Q+Math.imul(e,UJ)|0,K=Math.imul(e,EJ),G=G+Math.imul(QJ,FJ)|0,Q=Q+Math.imul(QJ,RJ)|0,Q=Q+Math.imul(GJ,FJ)|0,K=K+Math.imul(GJ,RJ)|0,G=G+Math.imul(L,SJ)|0,Q=Q+Math.imul(L,xJ)|0,Q=Q+Math.imul(_,SJ)|0,K=K+Math.imul(_,xJ)|0;var tJ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(tJ>>>26)|0,tJ&=67108863,G=Math.imul(XJ,UJ),Q=Math.imul(XJ,EJ),Q=Q+Math.imul(WJ,UJ)|0,K=Math.imul(WJ,EJ),G=G+Math.imul(p,FJ)|0,Q=Q+Math.imul(p,RJ)|0,Q=Q+Math.imul(e,FJ)|0,K=K+Math.imul(e,RJ)|0,G=G+Math.imul(QJ,SJ)|0,Q=Q+Math.imul(QJ,xJ)|0,Q=Q+Math.imul(GJ,SJ)|0,K=K+Math.imul(GJ,xJ)|0,G=G+Math.imul(L,AJ)|0,Q=Q+Math.imul(L,kJ)|0,Q=Q+Math.imul(_,AJ)|0,K=K+Math.imul(_,kJ)|0;var YQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(YQ>>>26)|0,YQ&=67108863,G=Math.imul(C,UJ),Q=Math.imul(C,EJ),Q=Q+Math.imul(h,UJ)|0,K=Math.imul(h,EJ),G=G+Math.imul(XJ,FJ)|0,Q=Q+Math.imul(XJ,RJ)|0,Q=Q+Math.imul(WJ,FJ)|0,K=K+Math.imul(WJ,RJ)|0,G=G+Math.imul(p,SJ)|0,Q=Q+Math.imul(p,xJ)|0,Q=Q+Math.imul(e,SJ)|0,K=K+Math.imul(e,xJ)|0,G=G+Math.imul(QJ,AJ)|0,Q=Q+Math.imul(QJ,kJ)|0,Q=Q+Math.imul(GJ,AJ)|0,K=K+Math.imul(GJ,kJ)|0,G=G+Math.imul(L,vJ)|0,Q=Q+Math.imul(L,MJ)|0,Q=Q+Math.imul(_,vJ)|0,K=K+Math.imul(_,MJ)|0;var BQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(BQ>>>26)|0,BQ&=67108863,G=Math.imul(qJ,UJ),Q=Math.imul(qJ,EJ),Q=Q+Math.imul(ZJ,UJ)|0,K=Math.imul(ZJ,EJ),G=G+Math.imul(C,FJ)|0,Q=Q+Math.imul(C,RJ)|0,Q=Q+Math.imul(h,FJ)|0,K=K+Math.imul(h,RJ)|0,G=G+Math.imul(XJ,SJ)|0,Q=Q+Math.imul(XJ,xJ)|0,Q=Q+Math.imul(WJ,SJ)|0,K=K+Math.imul(WJ,xJ)|0,G=G+Math.imul(p,AJ)|0,Q=Q+Math.imul(p,kJ)|0,Q=Q+Math.imul(e,AJ)|0,K=K+Math.imul(e,kJ)|0,G=G+Math.imul(QJ,vJ)|0,Q=Q+Math.imul(QJ,MJ)|0,Q=Q+Math.imul(GJ,vJ)|0,K=K+Math.imul(GJ,MJ)|0,G=G+Math.imul(L,wJ)|0,Q=Q+Math.imul(L,bJ)|0,Q=Q+Math.imul(_,wJ)|0,K=K+Math.imul(_,bJ)|0;var OQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(OQ>>>26)|0,OQ&=67108863,G=Math.imul(BJ,UJ),Q=Math.imul(BJ,EJ),Q=Q+Math.imul(TJ,UJ)|0,K=Math.imul(TJ,EJ),G=G+Math.imul(qJ,FJ)|0,Q=Q+Math.imul(qJ,RJ)|0,Q=Q+Math.imul(ZJ,FJ)|0,K=K+Math.imul(ZJ,RJ)|0,G=G+Math.imul(C,SJ)|0,Q=Q+Math.imul(C,xJ)|0,Q=Q+Math.imul(h,SJ)|0,K=K+Math.imul(h,xJ)|0,G=G+Math.imul(XJ,AJ)|0,Q=Q+Math.imul(XJ,kJ)|0,Q=Q+Math.imul(WJ,AJ)|0,K=K+Math.imul(WJ,kJ)|0,G=G+Math.imul(p,vJ)|0,Q=Q+Math.imul(p,MJ)|0,Q=Q+Math.imul(e,vJ)|0,K=K+Math.imul(e,MJ)|0,G=G+Math.imul(QJ,wJ)|0,Q=Q+Math.imul(QJ,bJ)|0,Q=Q+Math.imul(GJ,wJ)|0,K=K+Math.imul(GJ,bJ)|0,G=G+Math.imul(L,_J)|0,Q=Q+Math.imul(L,NJ)|0,Q=Q+Math.imul(_,_J)|0,K=K+Math.imul(_,NJ)|0;var jQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(jQ>>>26)|0,jQ&=67108863,G=Math.imul(LJ,UJ),Q=Math.imul(LJ,EJ),Q=Q+Math.imul(IJ,UJ)|0,K=Math.imul(IJ,EJ),G=G+Math.imul(BJ,FJ)|0,Q=Q+Math.imul(BJ,RJ)|0,Q=Q+Math.imul(TJ,FJ)|0,K=K+Math.imul(TJ,RJ)|0,G=G+Math.imul(qJ,SJ)|0,Q=Q+Math.imul(qJ,xJ)|0,Q=Q+Math.imul(ZJ,SJ)|0,K=K+Math.imul(ZJ,xJ)|0,G=G+Math.imul(C,AJ)|0,Q=Q+Math.imul(C,kJ)|0,Q=Q+Math.imul(h,AJ)|0,K=K+Math.imul(h,kJ)|0,G=G+Math.imul(XJ,vJ)|0,Q=Q+Math.imul(XJ,MJ)|0,Q=Q+Math.imul(WJ,vJ)|0,K=K+Math.imul(WJ,MJ)|0,G=G+Math.imul(p,wJ)|0,Q=Q+Math.imul(p,bJ)|0,Q=Q+Math.imul(e,wJ)|0,K=K+Math.imul(e,bJ)|0,G=G+Math.imul(QJ,_J)|0,Q=Q+Math.imul(QJ,NJ)|0,Q=Q+Math.imul(GJ,_J)|0,K=K+Math.imul(GJ,NJ)|0,G=G+Math.imul(L,yJ)|0,Q=Q+Math.imul(L,gJ)|0,Q=Q+Math.imul(_,yJ)|0,K=K+Math.imul(_,gJ)|0;var TQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(TQ>>>26)|0,TQ&=67108863,G=Math.imul(T,UJ),Q=Math.imul(T,EJ),Q=Q+Math.imul(D,UJ)|0,K=Math.imul(D,EJ),G=G+Math.imul(LJ,FJ)|0,Q=Q+Math.imul(LJ,RJ)|0,Q=Q+Math.imul(IJ,FJ)|0,K=K+Math.imul(IJ,RJ)|0,G=G+Math.imul(BJ,SJ)|0,Q=Q+Math.imul(BJ,xJ)|0,Q=Q+Math.imul(TJ,SJ)|0,K=K+Math.imul(TJ,xJ)|0,G=G+Math.imul(qJ,AJ)|0,Q=Q+Math.imul(qJ,kJ)|0,Q=Q+Math.imul(ZJ,AJ)|0,K=K+Math.imul(ZJ,kJ)|0,G=G+Math.imul(C,vJ)|0,Q=Q+Math.imul(C,MJ)|0,Q=Q+Math.imul(h,vJ)|0,K=K+Math.imul(h,MJ)|0,G=G+Math.imul(XJ,wJ)|0,Q=Q+Math.imul(XJ,bJ)|0,Q=Q+Math.imul(WJ,wJ)|0,K=K+Math.imul(WJ,bJ)|0,G=G+Math.imul(p,_J)|0,Q=Q+Math.imul(p,NJ)|0,Q=Q+Math.imul(e,_J)|0,K=K+Math.imul(e,NJ)|0,G=G+Math.imul(QJ,yJ)|0,Q=Q+Math.imul(QJ,gJ)|0,Q=Q+Math.imul(GJ,yJ)|0,K=K+Math.imul(GJ,gJ)|0,G=G+Math.imul(L,cJ)|0,Q=Q+Math.imul(L,fJ)|0,Q=Q+Math.imul(_,cJ)|0,K=K+Math.imul(_,fJ)|0;var NQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(NQ>>>26)|0,NQ&=67108863,G=Math.imul(d,UJ),Q=Math.imul(d,EJ),Q=Q+Math.imul(a,UJ)|0,K=Math.imul(a,EJ),G=G+Math.imul(T,FJ)|0,Q=Q+Math.imul(T,RJ)|0,Q=Q+Math.imul(D,FJ)|0,K=K+Math.imul(D,RJ)|0,G=G+Math.imul(LJ,SJ)|0,Q=Q+Math.imul(LJ,xJ)|0,Q=Q+Math.imul(IJ,SJ)|0,K=K+Math.imul(IJ,xJ)|0,G=G+Math.imul(BJ,AJ)|0,Q=Q+Math.imul(BJ,kJ)|0,Q=Q+Math.imul(TJ,AJ)|0,K=K+Math.imul(TJ,kJ)|0,G=G+Math.imul(qJ,vJ)|0,Q=Q+Math.imul(qJ,MJ)|0,Q=Q+Math.imul(ZJ,vJ)|0,K=K+Math.imul(ZJ,MJ)|0,G=G+Math.imul(C,wJ)|0,Q=Q+Math.imul(C,bJ)|0,Q=Q+Math.imul(h,wJ)|0,K=K+Math.imul(h,bJ)|0,G=G+Math.imul(XJ,_J)|0,Q=Q+Math.imul(XJ,NJ)|0,Q=Q+Math.imul(WJ,_J)|0,K=K+Math.imul(WJ,NJ)|0,G=G+Math.imul(p,yJ)|0,Q=Q+Math.imul(p,gJ)|0,Q=Q+Math.imul(e,yJ)|0,K=K+Math.imul(e,gJ)|0,G=G+Math.imul(QJ,cJ)|0,Q=Q+Math.imul(QJ,fJ)|0,Q=Q+Math.imul(GJ,cJ)|0,K=K+Math.imul(GJ,fJ)|0,G=G+Math.imul(L,f)|0,Q=Q+Math.imul(L,zJ)|0,Q=Q+Math.imul(_,f)|0,K=K+Math.imul(_,zJ)|0;var IQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(IQ>>>26)|0,IQ&=67108863,G=Math.imul(d,FJ),Q=Math.imul(d,RJ),Q=Q+Math.imul(a,FJ)|0,K=Math.imul(a,RJ),G=G+Math.imul(T,SJ)|0,Q=Q+Math.imul(T,xJ)|0,Q=Q+Math.imul(D,SJ)|0,K=K+Math.imul(D,xJ)|0,G=G+Math.imul(LJ,AJ)|0,Q=Q+Math.imul(LJ,kJ)|0,Q=Q+Math.imul(IJ,AJ)|0,K=K+Math.imul(IJ,kJ)|0,G=G+Math.imul(BJ,vJ)|0,Q=Q+Math.imul(BJ,MJ)|0,Q=Q+Math.imul(TJ,vJ)|0,K=K+Math.imul(TJ,MJ)|0,G=G+Math.imul(qJ,wJ)|0,Q=Q+Math.imul(qJ,bJ)|0,Q=Q+Math.imul(ZJ,wJ)|0,K=K+Math.imul(ZJ,bJ)|0,G=G+Math.imul(C,_J)|0,Q=Q+Math.imul(C,NJ)|0,Q=Q+Math.imul(h,_J)|0,K=K+Math.imul(h,NJ)|0,G=G+Math.imul(XJ,yJ)|0,Q=Q+Math.imul(XJ,gJ)|0,Q=Q+Math.imul(WJ,yJ)|0,K=K+Math.imul(WJ,gJ)|0,G=G+Math.imul(p,cJ)|0,Q=Q+Math.imul(p,fJ)|0,Q=Q+Math.imul(e,cJ)|0,K=K+Math.imul(e,fJ)|0,G=G+Math.imul(QJ,f)|0,Q=Q+Math.imul(QJ,zJ)|0,Q=Q+Math.imul(GJ,f)|0,K=K+Math.imul(GJ,zJ)|0;var EQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(EQ>>>26)|0,EQ&=67108863,G=Math.imul(d,SJ),Q=Math.imul(d,xJ),Q=Q+Math.imul(a,SJ)|0,K=Math.imul(a,xJ),G=G+Math.imul(T,AJ)|0,Q=Q+Math.imul(T,kJ)|0,Q=Q+Math.imul(D,AJ)|0,K=K+Math.imul(D,kJ)|0,G=G+Math.imul(LJ,vJ)|0,Q=Q+Math.imul(LJ,MJ)|0,Q=Q+Math.imul(IJ,vJ)|0,K=K+Math.imul(IJ,MJ)|0,G=G+Math.imul(BJ,wJ)|0,Q=Q+Math.imul(BJ,bJ)|0,Q=Q+Math.imul(TJ,wJ)|0,K=K+Math.imul(TJ,bJ)|0,G=G+Math.imul(qJ,_J)|0,Q=Q+Math.imul(qJ,NJ)|0,Q=Q+Math.imul(ZJ,_J)|0,K=K+Math.imul(ZJ,NJ)|0,G=G+Math.imul(C,yJ)|0,Q=Q+Math.imul(C,gJ)|0,Q=Q+Math.imul(h,yJ)|0,K=K+Math.imul(h,gJ)|0,G=G+Math.imul(XJ,cJ)|0,Q=Q+Math.imul(XJ,fJ)|0,Q=Q+Math.imul(WJ,cJ)|0,K=K+Math.imul(WJ,fJ)|0,G=G+Math.imul(p,f)|0,Q=Q+Math.imul(p,zJ)|0,Q=Q+Math.imul(e,f)|0,K=K+Math.imul(e,zJ)|0;var RQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(RQ>>>26)|0,RQ&=67108863,G=Math.imul(d,AJ),Q=Math.imul(d,kJ),Q=Q+Math.imul(a,AJ)|0,K=Math.imul(a,kJ),G=G+Math.imul(T,vJ)|0,Q=Q+Math.imul(T,MJ)|0,Q=Q+Math.imul(D,vJ)|0,K=K+Math.imul(D,MJ)|0,G=G+Math.imul(LJ,wJ)|0,Q=Q+Math.imul(LJ,bJ)|0,Q=Q+Math.imul(IJ,wJ)|0,K=K+Math.imul(IJ,bJ)|0,G=G+Math.imul(BJ,_J)|0,Q=Q+Math.imul(BJ,NJ)|0,Q=Q+Math.imul(TJ,_J)|0,K=K+Math.imul(TJ,NJ)|0,G=G+Math.imul(qJ,yJ)|0,Q=Q+Math.imul(qJ,gJ)|0,Q=Q+Math.imul(ZJ,yJ)|0,K=K+Math.imul(ZJ,gJ)|0,G=G+Math.imul(C,cJ)|0,Q=Q+Math.imul(C,fJ)|0,Q=Q+Math.imul(h,cJ)|0,K=K+Math.imul(h,fJ)|0,G=G+Math.imul(XJ,f)|0,Q=Q+Math.imul(XJ,zJ)|0,Q=Q+Math.imul(WJ,f)|0,K=K+Math.imul(WJ,zJ)|0;var zQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(zQ>>>26)|0,zQ&=67108863,G=Math.imul(d,vJ),Q=Math.imul(d,MJ),Q=Q+Math.imul(a,vJ)|0,K=Math.imul(a,MJ),G=G+Math.imul(T,wJ)|0,Q=Q+Math.imul(T,bJ)|0,Q=Q+Math.imul(D,wJ)|0,K=K+Math.imul(D,bJ)|0,G=G+Math.imul(LJ,_J)|0,Q=Q+Math.imul(LJ,NJ)|0,Q=Q+Math.imul(IJ,_J)|0,K=K+Math.imul(IJ,NJ)|0,G=G+Math.imul(BJ,yJ)|0,Q=Q+Math.imul(BJ,gJ)|0,Q=Q+Math.imul(TJ,yJ)|0,K=K+Math.imul(TJ,gJ)|0,G=G+Math.imul(qJ,cJ)|0,Q=Q+Math.imul(qJ,fJ)|0,Q=Q+Math.imul(ZJ,cJ)|0,K=K+Math.imul(ZJ,fJ)|0,G=G+Math.imul(C,f)|0,Q=Q+Math.imul(C,zJ)|0,Q=Q+Math.imul(h,f)|0,K=K+Math.imul(h,zJ)|0;var PQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(PQ>>>26)|0,PQ&=67108863,G=Math.imul(d,wJ),Q=Math.imul(d,bJ),Q=Q+Math.imul(a,wJ)|0,K=Math.imul(a,bJ),G=G+Math.imul(T,_J)|0,Q=Q+Math.imul(T,NJ)|0,Q=Q+Math.imul(D,_J)|0,K=K+Math.imul(D,NJ)|0,G=G+Math.imul(LJ,yJ)|0,Q=Q+Math.imul(LJ,gJ)|0,Q=Q+Math.imul(IJ,yJ)|0,K=K+Math.imul(IJ,gJ)|0,G=G+Math.imul(BJ,cJ)|0,Q=Q+Math.imul(BJ,fJ)|0,Q=Q+Math.imul(TJ,cJ)|0,K=K+Math.imul(TJ,fJ)|0,G=G+Math.imul(qJ,f)|0,Q=Q+Math.imul(qJ,zJ)|0,Q=Q+Math.imul(ZJ,f)|0,K=K+Math.imul(ZJ,zJ)|0;var LQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(LQ>>>26)|0,LQ&=67108863,G=Math.imul(d,_J),Q=Math.imul(d,NJ),Q=Q+Math.imul(a,_J)|0,K=Math.imul(a,NJ),G=G+Math.imul(T,yJ)|0,Q=Q+Math.imul(T,gJ)|0,Q=Q+Math.imul(D,yJ)|0,K=K+Math.imul(D,gJ)|0,G=G+Math.imul(LJ,cJ)|0,Q=Q+Math.imul(LJ,fJ)|0,Q=Q+Math.imul(IJ,cJ)|0,K=K+Math.imul(IJ,fJ)|0,G=G+Math.imul(BJ,f)|0,Q=Q+Math.imul(BJ,zJ)|0,Q=Q+Math.imul(TJ,f)|0,K=K+Math.imul(TJ,zJ)|0;var FQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(FQ>>>26)|0,FQ&=67108863,G=Math.imul(d,yJ),Q=Math.imul(d,gJ),Q=Q+Math.imul(a,yJ)|0,K=Math.imul(a,gJ),G=G+Math.imul(T,cJ)|0,Q=Q+Math.imul(T,fJ)|0,Q=Q+Math.imul(D,cJ)|0,K=K+Math.imul(D,fJ)|0,G=G+Math.imul(LJ,f)|0,Q=Q+Math.imul(LJ,zJ)|0,Q=Q+Math.imul(IJ,f)|0,K=K+Math.imul(IJ,zJ)|0;var HQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(HQ>>>26)|0,HQ&=67108863,G=Math.imul(d,cJ),Q=Math.imul(d,fJ),Q=Q+Math.imul(a,cJ)|0,K=Math.imul(a,fJ),G=G+Math.imul(T,f)|0,Q=Q+Math.imul(T,zJ)|0,Q=Q+Math.imul(D,f)|0,K=K+Math.imul(D,zJ)|0;var DQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(DQ>>>26)|0,DQ&=67108863,G=Math.imul(d,f),Q=Math.imul(d,zJ),Q=Q+Math.imul(a,f)|0,K=Math.imul(a,zJ);var KQ=(H+G|0)+((Q&8191)<<13)|0;return H=(K+(Q>>>13)|0)+(KQ>>>26)|0,KQ&=67108863,U[0]=CQ,U[1]=oJ,U[2]=tJ,U[3]=YQ,U[4]=BQ,U[5]=OQ,U[6]=jQ,U[7]=TQ,U[8]=NQ,U[9]=IQ,U[10]=EQ,U[11]=RQ,U[12]=zQ,U[13]=PQ,U[14]=LQ,U[15]=FQ,U[16]=HQ,U[17]=DQ,U[18]=KQ,H!==0&&(U[19]=H,Z.length++),Z};Math.imul||(F=P);function v(J,V,Z){Z.negative=V.negative^J.negative,Z.length=J.length+V.length;for(var $=0,X=0,U=0;U<Z.length-1;U++){var H=X;X=0;for(var G=$&67108863,Q=Math.min(U,V.length-1),K=Math.max(0,U-J.length+1);K<=Q;K++){var k=U-K,L=J.words[k]|0,_=V.words[K]|0,t=L*_,QJ=t&67108863;H=H+(t/67108864|0)|0,QJ=QJ+G|0,G=QJ&67108863,H=H+(QJ>>>26)|0,X+=H>>>26,H&=67108863}Z.words[U]=G,$=H,H=X}return $!==0?Z.words[U]=$:Z.length--,Z.strip()}function S(J,V,Z){var $=new w;return $.mulp(J,V,Z)}q.prototype.mulTo=function(J,V){var Z,$=this.length+J.length;return this.length===10&&J.length===10?Z=F(this,J,V):$<63?Z=P(this,J,V):$<1024?Z=v(this,J,V):Z=S(this,J,V),Z};function w(J,V){this.x=J,this.y=V}w.prototype.makeRBT=function(J){for(var V=new Array(J),Z=q.prototype._countBits(J)-1,$=0;$<J;$++)V[$]=this.revBin($,Z,J);return V},w.prototype.revBin=function(J,V,Z){if(J===0||J===Z-1)return J;for(var $=0,X=0;X<V;X++)$|=(J&1)<<V-X-1,J>>=1;return $},w.prototype.permute=function(J,V,Z,$,X,U){for(var H=0;H<U;H++)$[H]=V[J[H]],X[H]=Z[J[H]]},w.prototype.transform=function(J,V,Z,$,X,U){this.permute(U,J,V,Z,$,X);for(var H=1;H<X;H<<=1)for(var G=H<<1,Q=Math.cos(2*Math.PI/G),K=Math.sin(2*Math.PI/G),k=0;k<X;k+=G)for(var L=Q,_=K,t=0;t<H;t++){var QJ=Z[k+t],GJ=$[k+t],n=Z[k+t+H],p=$[k+t+H],e=L*n-_*p;p=L*p+_*n,n=e,Z[k+t]=QJ+n,$[k+t]=GJ+p,Z[k+t+H]=QJ-n,$[k+t+H]=GJ-p,t!==G&&(e=Q*L-K*_,_=Q*_+K*L,L=e)}},w.prototype.guessLen13b=function(J,V){var Z=Math.max(V,J)|1,$=Z&1,X=0;for(Z=Z/2|0;Z;Z=Z>>>1)X++;return 1<<X+1+$},w.prototype.conjugate=function(J,V,Z){if(!(Z<=1))for(var $=0;$<Z/2;$++){var X=J[$];J[$]=J[Z-$-1],J[Z-$-1]=X,X=V[$],V[$]=-V[Z-$-1],V[Z-$-1]=-X}},w.prototype.normalize13b=function(J,V){for(var Z=0,$=0;$<V/2;$++){var X=Math.round(J[2*$+1]/V)*8192+Math.round(J[2*$]/V)+Z;J[$]=X&67108863,X<67108864?Z=0:Z=X/67108864|0}return J},w.prototype.convert13b=function(J,V,Z,$){for(var X=0,U=0;U<V;U++)X=X+(J[U]|0),Z[2*U]=X&8191,X=X>>>13,Z[2*U+1]=X&8191,X=X>>>13;for(U=2*V;U<$;++U)Z[U]=0;B(X===0),B((X&-8192)===0)},w.prototype.stub=function(J){for(var V=new Array(J),Z=0;Z<J;Z++)V[Z]=0;return V},w.prototype.mulp=function(J,V,Z){var $=2*this.guessLen13b(J.length,V.length),X=this.makeRBT($),U=this.stub($),H=new Array($),G=new Array($),Q=new Array($),K=new Array($),k=new Array($),L=new Array($),_=Z.words;_.length=$,this.convert13b(J.words,J.length,H,$),this.convert13b(V.words,V.length,K,$),this.transform(H,U,G,Q,$,X),this.transform(K,U,k,L,$,X);for(var t=0;t<$;t++){var QJ=G[t]*k[t]-Q[t]*L[t];Q[t]=G[t]*L[t]+Q[t]*k[t],G[t]=QJ}return this.conjugate(G,Q,$),this.transform(G,Q,_,U,$,X),this.conjugate(_,U,$),this.normalize13b(_,$),Z.negative=J.negative^V.negative,Z.length=J.length+V.length,Z.strip()},q.prototype.mul=function(J){var V=new q(null);return V.words=new Array(this.length+J.length),this.mulTo(J,V)},q.prototype.mulf=function(J){var V=new q(null);return V.words=new Array(this.length+J.length),S(this,J,V)},q.prototype.imul=function(J){return this.clone().mulTo(J,this)},q.prototype.imuln=function(J){B(typeof J=="number"),B(J<67108864);for(var V=0,Z=0;Z<this.length;Z++){var $=(this.words[Z]|0)*J,X=($&67108863)+(V&67108863);V>>=26,V+=$/67108864|0,V+=X>>>26,this.words[Z]=X&67108863}return V!==0&&(this.words[Z]=V,this.length++),this},q.prototype.muln=function(J){return this.clone().imuln(J)},q.prototype.sqr=function(){return this.mul(this)},q.prototype.isqr=function(){return this.imul(this.clone())},q.prototype.pow=function(J){var V=j(J);if(V.length===0)return new q(1);for(var Z=this,$=0;$<V.length&&V[$]===0;$++,Z=Z.sqr());if(++$<V.length)for(var X=Z.sqr();$<V.length;$++,X=X.sqr())V[$]!==0&&(Z=Z.mul(X));return Z},q.prototype.iushln=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26,$=67108863>>>26-V<<26-V,X;if(V!==0){var U=0;for(X=0;X<this.length;X++){var H=this.words[X]&$,G=(this.words[X]|0)-H<<V;this.words[X]=G|U,U=H>>>26-V}U&&(this.words[X]=U,this.length++)}if(Z!==0){for(X=this.length-1;X>=0;X--)this.words[X+Z]=this.words[X];for(X=0;X<Z;X++)this.words[X]=0;this.length+=Z}return this.strip()},q.prototype.ishln=function(J){return B(this.negative===0),this.iushln(J)},q.prototype.iushrn=function(J,V,Z){B(typeof J=="number"&&J>=0);var $;V?$=(V-V%26)/26:$=0;var X=J%26,U=Math.min((J-X)/26,this.length),H=67108863^67108863>>>X<<X,G=Z;if($-=U,$=Math.max(0,$),G){for(var Q=0;Q<U;Q++)G.words[Q]=this.words[Q];G.length=U}if(U!==0)if(this.length>U)for(this.length-=U,Q=0;Q<this.length;Q++)this.words[Q]=this.words[Q+U];else this.words[0]=0,this.length=1;var K=0;for(Q=this.length-1;Q>=0&&(K!==0||Q>=$);Q--){var k=this.words[Q]|0;this.words[Q]=K<<26-X|k>>>X,K=k&H}return G&&K!==0&&(G.words[G.length++]=K),this.length===0&&(this.words[0]=0,this.length=1),this.strip()},q.prototype.ishrn=function(J,V,Z){return B(this.negative===0),this.iushrn(J,V,Z)},q.prototype.shln=function(J){return this.clone().ishln(J)},q.prototype.ushln=function(J){return this.clone().iushln(J)},q.prototype.shrn=function(J){return this.clone().ishrn(J)},q.prototype.ushrn=function(J){return this.clone().iushrn(J)},q.prototype.testn=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26,$=1<<V;if(this.length<=Z)return!1;var X=this.words[Z];return!!(X&$)},q.prototype.imaskn=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26;if(B(this.negative===0,"imaskn works only with positive numbers"),this.length<=Z)return this;if(V!==0&&Z++,this.length=Math.min(Z,this.length),V!==0){var $=67108863^67108863>>>V<<V;this.words[this.length-1]&=$}return this.strip()},q.prototype.maskn=function(J){return this.clone().imaskn(J)},q.prototype.iaddn=function(J){return B(typeof J=="number"),B(J<67108864),J<0?this.isubn(-J):this.negative!==0?this.length===1&&(this.words[0]|0)<J?(this.words[0]=J-(this.words[0]|0),this.negative=0,this):(this.negative=0,this.isubn(J),this.negative=1,this):this._iaddn(J)},q.prototype._iaddn=function(J){this.words[0]+=J;for(var V=0;V<this.length&&this.words[V]>=67108864;V++)this.words[V]-=67108864,V===this.length-1?this.words[V+1]=1:this.words[V+1]++;return this.length=Math.max(this.length,V+1),this},q.prototype.isubn=function(J){if(B(typeof J=="number"),B(J<67108864),J<0)return this.iaddn(-J);if(this.negative!==0)return this.negative=0,this.iaddn(J),this.negative=1,this;if(this.words[0]-=J,this.length===1&&this.words[0]<0)this.words[0]=-this.words[0],this.negative=1;else for(var V=0;V<this.length&&this.words[V]<0;V++)this.words[V]+=67108864,this.words[V+1]-=1;return this.strip()},q.prototype.addn=function(J){return this.clone().iaddn(J)},q.prototype.subn=function(J){return this.clone().isubn(J)},q.prototype.iabs=function(){return this.negative=0,this},q.prototype.abs=function(){return this.clone().iabs()},q.prototype._ishlnsubmul=function(J,V,Z){var $=J.length+Z,X;this._expand($);var U,H=0;for(X=0;X<J.length;X++){U=(this.words[X+Z]|0)+H;var G=(J.words[X]|0)*V;U-=G&67108863,H=(U>>26)-(G/67108864|0),this.words[X+Z]=U&67108863}for(;X<this.length-Z;X++)U=(this.words[X+Z]|0)+H,H=U>>26,this.words[X+Z]=U&67108863;if(H===0)return this.strip();for(B(H===-1),H=0,X=0;X<this.length;X++)U=-(this.words[X]|0)+H,H=U>>26,this.words[X]=U&67108863;return this.negative=1,this.strip()},q.prototype._wordDiv=function(J,V){var Z=this.length-J.length,$=this.clone(),X=J,U=X.words[X.length-1]|0,H=this._countBits(U);Z=26-H,Z!==0&&(X=X.ushln(Z),$.iushln(Z),U=X.words[X.length-1]|0);var G=$.length-X.length,Q;if(V!=="mod"){Q=new q(null),Q.length=G+1,Q.words=new Array(Q.length);for(var K=0;K<Q.length;K++)Q.words[K]=0}var k=$.clone()._ishlnsubmul(X,1,G);k.negative===0&&($=k,Q&&(Q.words[G]=1));for(var L=G-1;L>=0;L--){var _=($.words[X.length+L]|0)*67108864+($.words[X.length+L-1]|0);for(_=Math.min(_/U|0,67108863),$._ishlnsubmul(X,_,L);$.negative!==0;)_--,$.negative=0,$._ishlnsubmul(X,1,L),$.isZero()||($.negative^=1);Q&&(Q.words[L]=_)}return Q&&Q.strip(),$.strip(),V!=="div"&&Z!==0&&$.iushrn(Z),{div:Q||null,mod:$}},q.prototype.divmod=function(J,V,Z){if(B(!J.isZero()),this.isZero())return{div:new q(0),mod:new q(0)};var $,X,U;return this.negative!==0&&J.negative===0?(U=this.neg().divmod(J,V),V!=="mod"&&($=U.div.neg()),V!=="div"&&(X=U.mod.neg(),Z&&X.negative!==0&&X.iadd(J)),{div:$,mod:X}):this.negative===0&&J.negative!==0?(U=this.divmod(J.neg(),V),V!=="mod"&&($=U.div.neg()),{div:$,mod:U.mod}):(this.negative&J.negative)!==0?(U=this.neg().divmod(J.neg(),V),V!=="div"&&(X=U.mod.neg(),Z&&X.negative!==0&&X.isub(J)),{div:U.div,mod:X}):J.length>this.length||this.cmp(J)<0?{div:new q(0),mod:this}:J.length===1?V==="div"?{div:this.divn(J.words[0]),mod:null}:V==="mod"?{div:null,mod:new q(this.modn(J.words[0]))}:{div:this.divn(J.words[0]),mod:new q(this.modn(J.words[0]))}:this._wordDiv(J,V)},q.prototype.div=function(J){return this.divmod(J,"div",!1).div},q.prototype.mod=function(J){return this.divmod(J,"mod",!1).mod},q.prototype.umod=function(J){return this.divmod(J,"mod",!0).mod},q.prototype.divRound=function(J){var V=this.divmod(J);if(V.mod.isZero())return V.div;var Z=V.div.negative!==0?V.mod.isub(J):V.mod,$=J.ushrn(1),X=J.andln(1),U=Z.cmp($);return U<0||X===1&&U===0?V.div:V.div.negative!==0?V.div.isubn(1):V.div.iaddn(1)},q.prototype.modn=function(J){B(J<=67108863);for(var V=(1<<26)%J,Z=0,$=this.length-1;$>=0;$--)Z=(V*Z+(this.words[$]|0))%J;return Z},q.prototype.idivn=function(J){B(J<=67108863);for(var V=0,Z=this.length-1;Z>=0;Z--){var $=(this.words[Z]|0)+V*67108864;this.words[Z]=$/J|0,V=$%J}return this.strip()},q.prototype.divn=function(J){return this.clone().idivn(J)},q.prototype.egcd=function(J){B(J.negative===0),B(!J.isZero());var V=this,Z=J.clone();V.negative!==0?V=V.umod(J):V=V.clone();for(var $=new q(1),X=new q(0),U=new q(0),H=new q(1),G=0;V.isEven()&&Z.isEven();)V.iushrn(1),Z.iushrn(1),++G;for(var Q=Z.clone(),K=V.clone();!V.isZero();){for(var k=0,L=1;(V.words[0]&L)===0&&k<26;++k,L<<=1);if(k>0)for(V.iushrn(k);k-- >0;)($.isOdd()||X.isOdd())&&($.iadd(Q),X.isub(K)),$.iushrn(1),X.iushrn(1);for(var _=0,t=1;(Z.words[0]&t)===0&&_<26;++_,t<<=1);if(_>0)for(Z.iushrn(_);_-- >0;)(U.isOdd()||H.isOdd())&&(U.iadd(Q),H.isub(K)),U.iushrn(1),H.iushrn(1);V.cmp(Z)>=0?(V.isub(Z),$.isub(U),X.isub(H)):(Z.isub(V),U.isub($),H.isub(X))}return{a:U,b:H,gcd:Z.iushln(G)}},q.prototype._invmp=function(J){B(J.negative===0),B(!J.isZero());var V=this,Z=J.clone();V.negative!==0?V=V.umod(J):V=V.clone();for(var $=new q(1),X=new q(0),U=Z.clone();V.cmpn(1)>0&&Z.cmpn(1)>0;){for(var H=0,G=1;(V.words[0]&G)===0&&H<26;++H,G<<=1);if(H>0)for(V.iushrn(H);H-- >0;)$.isOdd()&&$.iadd(U),$.iushrn(1);for(var Q=0,K=1;(Z.words[0]&K)===0&&Q<26;++Q,K<<=1);if(Q>0)for(Z.iushrn(Q);Q-- >0;)X.isOdd()&&X.iadd(U),X.iushrn(1);V.cmp(Z)>=0?(V.isub(Z),$.isub(X)):(Z.isub(V),X.isub($))}var k;return V.cmpn(1)===0?k=$:k=X,k.cmpn(0)<0&&k.iadd(J),k},q.prototype.gcd=function(J){if(this.isZero())return J.abs();if(J.isZero())return this.abs();var V=this.clone(),Z=J.clone();V.negative=0,Z.negative=0;for(var $=0;V.isEven()&&Z.isEven();$++)V.iushrn(1),Z.iushrn(1);do{for(;V.isEven();)V.iushrn(1);for(;Z.isEven();)Z.iushrn(1);var X=V.cmp(Z);if(X<0){var U=V;V=Z,Z=U}else if(X===0||Z.cmpn(1)===0)break;V.isub(Z)}while(!0);return Z.iushln($)},q.prototype.invm=function(J){return this.egcd(J).a.umod(J)},q.prototype.isEven=function(){return(this.words[0]&1)===0},q.prototype.isOdd=function(){return(this.words[0]&1)===1},q.prototype.andln=function(J){return this.words[0]&J},q.prototype.bincn=function(J){B(typeof J=="number");var V=J%26,Z=(J-V)/26,$=1<<V;if(this.length<=Z)return this._expand(Z+1),this.words[Z]|=$,this;for(var X=$,U=Z;X!==0&&U<this.length;U++){var H=this.words[U]|0;H+=X,X=H>>>26,H&=67108863,this.words[U]=H}return X!==0&&(this.words[U]=X,this.length++),this},q.prototype.isZero=function(){return this.length===1&&this.words[0]===0},q.prototype.cmpn=function(J){var V=J<0;if(this.negative!==0&&!V)return-1;if(this.negative===0&&V)return 1;this.strip();var Z;if(this.length>1)Z=1;else{V&&(J=-J),B(J<=67108863,"Number is too big");var $=this.words[0]|0;Z=$===J?0:$<J?-1:1}return this.negative!==0?-Z|0:Z},q.prototype.cmp=function(J){if(this.negative!==0&&J.negative===0)return-1;if(this.negative===0&&J.negative!==0)return 1;var V=this.ucmp(J);return this.negative!==0?-V|0:V},q.prototype.ucmp=function(J){if(this.length>J.length)return 1;if(this.length<J.length)return-1;for(var V=0,Z=this.length-1;Z>=0;Z--){var $=this.words[Z]|0,X=J.words[Z]|0;if($!==X){$<X?V=-1:$>X&&(V=1);break}}return V},q.prototype.gtn=function(J){return this.cmpn(J)===1},q.prototype.gt=function(J){return this.cmp(J)===1},q.prototype.gten=function(J){return this.cmpn(J)>=0},q.prototype.gte=function(J){return this.cmp(J)>=0},q.prototype.ltn=function(J){return this.cmpn(J)===-1},q.prototype.lt=function(J){return this.cmp(J)===-1},q.prototype.lten=function(J){return this.cmpn(J)<=0},q.prototype.lte=function(J){return this.cmp(J)<=0},q.prototype.eqn=function(J){return this.cmpn(J)===0},q.prototype.eq=function(J){return this.cmp(J)===0},q.red=function(J){return new o(J)},q.prototype.toRed=function(J){return B(!this.red,"Already a number in reduction context"),B(this.negative===0,"red works only with positives"),J.convertTo(this)._forceRed(J)},q.prototype.fromRed=function(){return B(this.red,"fromRed works only with numbers in reduction context"),this.red.convertFrom(this)},q.prototype._forceRed=function(J){return this.red=J,this},q.prototype.forceRed=function(J){return B(!this.red,"Already a number in reduction context"),this._forceRed(J)},q.prototype.redAdd=function(J){return B(this.red,"redAdd works only with red numbers"),this.red.add(this,J)},q.prototype.redIAdd=function(J){return B(this.red,"redIAdd works only with red numbers"),this.red.iadd(this,J)},q.prototype.redSub=function(J){return B(this.red,"redSub works only with red numbers"),this.red.sub(this,J)},q.prototype.redISub=function(J){return B(this.red,"redISub works only with red numbers"),this.red.isub(this,J)},q.prototype.redShl=function(J){return B(this.red,"redShl works only with red numbers"),this.red.shl(this,J)},q.prototype.redMul=function(J){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,J),this.red.mul(this,J)},q.prototype.redIMul=function(J){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,J),this.red.imul(this,J)},q.prototype.redSqr=function(){return B(this.red,"redSqr works only with red numbers"),this.red._verify1(this),this.red.sqr(this)},q.prototype.redISqr=function(){return B(this.red,"redISqr works only with red numbers"),this.red._verify1(this),this.red.isqr(this)},q.prototype.redSqrt=function(){return B(this.red,"redSqrt works only with red numbers"),this.red._verify1(this),this.red.sqrt(this)},q.prototype.redInvm=function(){return B(this.red,"redInvm works only with red numbers"),this.red._verify1(this),this.red.invm(this)},q.prototype.redNeg=function(){return B(this.red,"redNeg works only with red numbers"),this.red._verify1(this),this.red.neg(this)},q.prototype.redPow=function(J){return B(this.red&&!J.red,"redPow(normalNum)"),this.red._verify1(this),this.red.pow(this,J)};var y={k256:null,p224:null,p192:null,p25519:null};function m(J,V){this.name=J,this.p=new q(V,16),this.n=this.p.bitLength(),this.k=new q(1).iushln(this.n).isub(this.p),this.tmp=this._tmp()}m.prototype._tmp=function(){var J=new q(null);return J.words=new Array(Math.ceil(this.n/13)),J},m.prototype.ireduce=function(J){var V=J,Z;do this.split(V,this.tmp),V=this.imulK(V),V=V.iadd(this.tmp),Z=V.bitLength();while(Z>this.n);var $=Z<this.n?-1:V.ucmp(this.p);return $===0?(V.words[0]=0,V.length=1):$>0?V.isub(this.p):V.strip!==void 0?V.strip():V._strip(),V},m.prototype.split=function(J,V){J.iushrn(this.n,0,V)},m.prototype.imulK=function(J){return J.imul(this.k)};function i(){m.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}A(i,m),i.prototype.split=function(J,V){for(var Z=4194303,$=Math.min(J.length,9),X=0;X<$;X++)V.words[X]=J.words[X];if(V.length=$,J.length<=9){J.words[0]=0,J.length=1;return}var U=J.words[9];for(V.words[V.length++]=U&Z,X=10;X<J.length;X++){var H=J.words[X]|0;J.words[X-10]=(H&Z)<<4|U>>>22,U=H}U>>>=22,J.words[X-10]=U,U===0&&J.length>10?J.length-=10:J.length-=9},i.prototype.imulK=function(J){J.words[J.length]=0,J.words[J.length+1]=0,J.length+=2;for(var V=0,Z=0;Z<J.length;Z++){var $=J.words[Z]|0;V+=$*977,J.words[Z]=V&67108863,V=$*64+(V/67108864|0)}return J.words[J.length-1]===0&&(J.length--,J.words[J.length-1]===0&&J.length--),J};function JJ(){m.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}A(JJ,m);function VJ(){m.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}A(VJ,m);function HJ(){m.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}A(HJ,m),HJ.prototype.imulK=function(J){for(var V=0,Z=0;Z<J.length;Z++){var $=(J.words[Z]|0)*19+V,X=$&67108863;$>>>=26,J.words[Z]=X,V=$}return V!==0&&(J.words[J.length++]=V),J},q._prime=function(J){if(y[J])return y[J];var V;if(J==="k256")V=new i;else if(J==="p224")V=new JJ;else if(J==="p192")V=new VJ;else if(J==="p25519")V=new HJ;else throw new Error("Unknown prime "+J);return y[J]=V,V};function o(J){if(typeof J=="string"){var V=q._prime(J);this.m=V.p,this.prime=V}else B(J.gtn(1),"modulus must be greater than 1"),this.m=J,this.prime=null}o.prototype._verify1=function(J){B(J.negative===0,"red works only with positives"),B(J.red,"red works only with red numbers")},o.prototype._verify2=function(J,V){B((J.negative|V.negative)===0,"red works only with positives"),B(J.red&&J.red===V.red,"red works only with red numbers")},o.prototype.imod=function(J){return this.prime?this.prime.ireduce(J)._forceRed(this):J.umod(this.m)._forceRed(this)},o.prototype.neg=function(J){return J.isZero()?J.clone():this.m.sub(J)._forceRed(this)},o.prototype.add=function(J,V){this._verify2(J,V);var Z=J.add(V);return Z.cmp(this.m)>=0&&Z.isub(this.m),Z._forceRed(this)},o.prototype.iadd=function(J,V){this._verify2(J,V);var Z=J.iadd(V);return Z.cmp(this.m)>=0&&Z.isub(this.m),Z},o.prototype.sub=function(J,V){this._verify2(J,V);var Z=J.sub(V);return Z.cmpn(0)<0&&Z.iadd(this.m),Z._forceRed(this)},o.prototype.isub=function(J,V){this._verify2(J,V);var Z=J.isub(V);return Z.cmpn(0)<0&&Z.iadd(this.m),Z},o.prototype.shl=function(J,V){return this._verify1(J),this.imod(J.ushln(V))},o.prototype.imul=function(J,V){return this._verify2(J,V),this.imod(J.imul(V))},o.prototype.mul=function(J,V){return this._verify2(J,V),this.imod(J.mul(V))},o.prototype.isqr=function(J){return this.imul(J,J.clone())},o.prototype.sqr=function(J){return this.mul(J,J)},o.prototype.sqrt=function(J){if(J.isZero())return J.clone();var V=this.m.andln(3);if(B(V%2===1),V===3){var Z=this.m.add(new q(1)).iushrn(2);return this.pow(J,Z)}for(var $=this.m.subn(1),X=0;!$.isZero()&&$.andln(1)===0;)X++,$.iushrn(1);B(!$.isZero());var U=new q(1).toRed(this),H=U.redNeg(),G=this.m.subn(1).iushrn(1),Q=this.m.bitLength();for(Q=new q(2*Q*Q).toRed(this);this.pow(Q,G).cmp(H)!==0;)Q.redIAdd(H);for(var K=this.pow(Q,$),k=this.pow(J,$.addn(1).iushrn(1)),L=this.pow(J,$),_=X;L.cmp(U)!==0;){for(var t=L,QJ=0;t.cmp(U)!==0;QJ++)t=t.redSqr();B(QJ<_);var GJ=this.pow(K,new q(1).iushln(_-QJ-1));k=k.redMul(GJ),K=GJ.redSqr(),L=L.redMul(K),_=QJ}return k},o.prototype.invm=function(J){var V=J._invmp(this.m);return V.negative!==0?(V.negative=0,this.imod(V).redNeg()):this.imod(V)},o.prototype.pow=function(J,V){if(V.isZero())return new q(1).toRed(this);if(V.cmpn(1)===0)return J.clone();var Z=4,$=new Array(1<<Z);$[0]=new q(1).toRed(this),$[1]=J;for(var X=2;X<$.length;X++)$[X]=this.mul($[X-1],J);var U=$[0],H=0,G=0,Q=V.bitLength()%26;for(Q===0&&(Q=26),X=V.length-1;X>=0;X--){for(var K=V.words[X],k=Q-1;k>=0;k--){var L=K>>k&1;if(U!==$[0]&&(U=this.sqr(U)),L===0&&H===0){G=0;continue}H<<=1,H|=L,G++,!(G!==Z&&(X!==0||k!==0))&&(U=this.mul(U,$[H]),G=0,H=0)}Q=26}return U},o.prototype.convertTo=function(J){var V=J.umod(this.m);return V===J?V.clone():V},o.prototype.convertFrom=function(J){var V=J.clone();return V.red=null,V},q.mont=function(J){return new jJ(J)};function jJ(J){o.call(this,J),this.shift=this.m.bitLength(),this.shift%26!==0&&(this.shift+=26-this.shift%26),this.r=new q(1).iushln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv=this.minv.umod(this.r),this.minv=this.r.sub(this.minv)}A(jJ,o),jJ.prototype.convertTo=function(J){return this.imod(J.ushln(this.shift))},jJ.prototype.convertFrom=function(J){var V=this.imod(J.mul(this.rinv));return V.red=null,V},jJ.prototype.imul=function(J,V){if(J.isZero()||V.isZero())return J.words[0]=0,J.length=1,J;var Z=J.imul(V),$=Z.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),X=Z.isub($).iushrn(this.shift),U=X;return X.cmp(this.m)>=0?U=X.isub(this.m):X.cmpn(0)<0&&(U=X.iadd(this.m)),U._forceRed(this)},jJ.prototype.mul=function(J,V){if(J.isZero()||V.isZero())return new q(0)._forceRed(this);var Z=J.mul(V),$=Z.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),X=Z.isub($).iushrn(this.shift),U=X;return X.cmp(this.m)>=0?U=X.isub(this.m):X.cmpn(0)<0&&(U=X.iadd(this.m)),U._forceRed(this)},jJ.prototype.invm=function(J){var V=this.imod(J._invmp(this.m).mul(this.r2));return V._forceRed(this)}})(typeof g>"u"||g,l)}),c8=OJ(()=>{}),J0=OJ((l,g)=>{var R;g.exports=function(A){return R||(R=new M(null)),R.generate(A)};function M(A){this.rand=A}if(g.exports.Rand=M,M.prototype.generate=function(A){return this._rand(A)},M.prototype._rand=function(A){if(this.rand.getBytes)return this.rand.getBytes(A);for(var q=new Uint8Array(A),Y=0;Y<q.length;Y++)q[Y]=this.rand.getByte();return q},typeof self=="object")self.crypto&&self.crypto.getRandomValues?M.prototype._rand=function(A){var q=new Uint8Array(A);return self.crypto.getRandomValues(q),q}:self.msCrypto&&self.msCrypto.getRandomValues?M.prototype._rand=function(A){var q=new Uint8Array(A);return self.msCrypto.getRandomValues(q),q}:typeof window=="object"&&(M.prototype._rand=function(){throw new Error("Not implemented yet")});else try{if(B=c8(),typeof B.randomBytes!="function")throw new Error("Not supported");M.prototype._rand=function(A){return B.randomBytes(A)}}catch{}var B}),J6=OJ((l,g)=>{var R=g8(),M=J0();function B(A){this.rand=A||new M.Rand}g.exports=B,B.create=function(A){return new B(A)},B.prototype._randbelow=function(A){var q=A.bitLength(),Y=Math.ceil(q/8);do var E=new R(this.rand.generate(Y));while(E.cmp(A)>=0);return E},B.prototype._randrange=function(A,q){var Y=q.sub(A);return A.add(this._randbelow(Y))},B.prototype.test=function(A,q,Y){var E=A.bitLength(),O=R.mont(A),N=new R(1).toRed(O);q||(q=Math.max(1,E/48|0));for(var W=A.subn(1),I=0;!W.testn(I);I++);for(var z=A.shrn(I),j=W.toRed(O),P=!0;q>0;q--){var F=this._randrange(new R(2),W);Y&&Y(F);var v=F.toRed(O).redPow(z);if(!(v.cmp(N)===0||v.cmp(j)===0)){for(var S=1;S<I;S++){if(v=v.redSqr(),v.cmp(N)===0)return!1;if(v.cmp(j)===0)break}if(S===I)return!1}}return P},B.prototype.getDivisor=function(A,q){var Y=A.bitLength(),E=R.mont(A),O=new R(1).toRed(E);q||(q=Math.max(1,Y/48|0));for(var N=A.subn(1),W=0;!N.testn(W);W++);for(var I=A.shrn(W),z=N.toRed(E);q>0;q--){var j=this._randrange(new R(2),N),P=A.gcd(j);if(P.cmpn(1)!==0)return P;var F=j.toRed(E).redPow(I);if(!(F.cmp(O)===0||F.cmp(z)===0)){for(var v=1;v<W;v++){if(F=F.redSqr(),F.cmp(O)===0)return F.fromRed().subn(1).gcd(A);if(F.cmp(z)===0)break}if(v===W)return F=F.redSqr(),F.fromRed().subn(1).gcd(A)}}return!1}}),Q6=OJ((l,g)=>{var R=VV();g.exports=i,i.simpleSieve=y,i.fermatTest=m;var M=e0(),B=new M(24),A=J6(),q=new A,Y=new M(1),E=new M(2),O=new M(5),N=new M(16),W=new M(8),I=new M(10),z=new M(3),j=new M(7),P=new M(11),F=new M(4),v=new M(12),S=null;function w(){if(S!==null)return S;var JJ=1048576,VJ=[];VJ[0]=2;for(var HJ=1,o=3;o<JJ;o+=2){for(var jJ=Math.ceil(Math.sqrt(o)),J=0;J<HJ&&VJ[J]<=jJ&&o%VJ[J]!==0;J++);HJ!==J&&VJ[J]<=jJ||(VJ[HJ++]=o)}return S=VJ,VJ}function y(JJ){for(var VJ=w(),HJ=0;HJ<VJ.length;HJ++)if(JJ.modn(VJ[HJ])===0)return JJ.cmpn(VJ[HJ])===0;return!0}function m(JJ){var VJ=M.mont(JJ);return E.toRed(VJ).redPow(JJ.subn(1)).fromRed().cmpn(1)===0}function i(JJ,VJ){if(JJ<16)return VJ===2||VJ===5?new M([140,123]):new M([140,39]);VJ=new M(VJ);for(var HJ,o;;){for(HJ=new M(R(Math.ceil(JJ/8)));HJ.bitLength()>JJ;)HJ.ishrn(1);if(HJ.isEven()&&HJ.iadd(Y),HJ.testn(1)||HJ.iadd(E),VJ.cmp(E)){if(!VJ.cmp(O))for(;HJ.mod(I).cmp(z);)HJ.iadd(F)}else for(;HJ.mod(B).cmp(P);)HJ.iadd(F);if(o=HJ.shrn(1),y(o)&&y(HJ)&&m(o)&&m(HJ)&&q.test(o)&&q.test(HJ))return HJ}}}),f8=OJ((l,g)=>{g.exports={modp1:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a63a3620ffffffffffffffff"},modp2:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece65381ffffffffffffffff"},modp5:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca237327ffffffffffffffff"},modp14:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aacaa68ffffffffffffffff"},modp15:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a93ad2caffffffffffffffff"},modp16:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c934063199ffffffffffffffff"},modp17:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c93402849236c3fab4d27c7026c1d4dcb2602646dec9751e763dba37bdf8ff9406ad9e530ee5db382f413001aeb06a53ed9027d831179727b0865a8918da3edbebcf9b14ed44ce6cbaced4bb1bdb7f1447e6cc254b332051512bd7af426fb8f401378cd2bf5983ca01c64b92ecf032ea15d1721d03f482d7ce6e74fef6d55e702f46980c82b5a84031900b1c9e59e7c97fbec7e8f323a97a7e36cc88be0f1d45b7ff585ac54bd407b22b4154aacc8f6d7ebf48e1d814cc5ed20f8037e0a79715eef29be32806a1d58bb7c5da76f550aa3d8a1fbff0eb19ccb1a313d55cda56c9ec2ef29632387fe8d76e3c0468043e8f663f4860ee12bf2d5b0b7474d6e694f91e6dcc4024ffffffffffffffff"},modp18:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c93402849236c3fab4d27c7026c1d4dcb2602646dec9751e763dba37bdf8ff9406ad9e530ee5db382f413001aeb06a53ed9027d831179727b0865a8918da3edbebcf9b14ed44ce6cbaced4bb1bdb7f1447e6cc254b332051512bd7af426fb8f401378cd2bf5983ca01c64b92ecf032ea15d1721d03f482d7ce6e74fef6d55e702f46980c82b5a84031900b1c9e59e7c97fbec7e8f323a97a7e36cc88be0f1d45b7ff585ac54bd407b22b4154aacc8f6d7ebf48e1d814cc5ed20f8037e0a79715eef29be32806a1d58bb7c5da76f550aa3d8a1fbff0eb19ccb1a313d55cda56c9ec2ef29632387fe8d76e3c0468043e8f663f4860ee12bf2d5b0b7474d6e694f91e6dbe115974a3926f12fee5e438777cb6a932df8cd8bec4d073b931ba3bc832b68d9dd300741fa7bf8afc47ed2576f6936ba424663aab639c5ae4f5683423b4742bf1c978238f16cbe39d652de3fdb8befc848ad922222e04a4037c0713eb57a81a23f0c73473fc646cea306b4bcbc8862f8385ddfa9d4b7fa2c087e879683303ed5bdd3a062b3cf5b3a278a66d2a13f83f44f82ddf310ee074ab6a364597e899a0255dc164f31cc50846851df9ab48195ded7ea1b1d510bd7ee74d73faf36bc31ecfa268359046f4eb879f924009438b481c6cd7889a002ed5ee382bc9190da6fc026e479558e4475677e9aa9e3050e2765694dfc81f56e880b96e7160c980dd98edd3dfffffffffffffffff"}}}),h8=OJ((l,g)=>{var R=e0(),M=J6(),B=new M,A=new R(24),q=new R(11),Y=new R(10),E=new R(3),O=new R(7),N=Q6(),W=VV();g.exports=F;function I(S,w){return w=w||"utf8",Buffer.isBuffer(S)||(S=new Buffer(S,w)),this._pub=new R(S),this}function z(S,w){return w=w||"utf8",Buffer.isBuffer(S)||(S=new Buffer(S,w)),this._priv=new R(S),this}var j={};function P(S,w){var y=w.toString("hex"),m=[y,S.toString(16)].join("_");if(m in j)return j[m];var i=0;if(S.isEven()||!N.simpleSieve||!N.fermatTest(S)||!B.test(S))return i+=1,y==="02"||y==="05"?i+=8:i+=4,j[m]=i,i;B.test(S.shrn(1))||(i+=2);var JJ;switch(y){case"02":S.mod(A).cmp(q)&&(i+=8);break;case"05":JJ=S.mod(Y),JJ.cmp(E)&&JJ.cmp(O)&&(i+=8);break;default:i+=4}return j[m]=i,i}function F(S,w,y){this.setGenerator(w),this.__prime=new R(S),this._prime=R.mont(this.__prime),this._primeLen=S.length,this._pub=void 0,this._priv=void 0,this._primeCode=void 0,y?(this.setPublicKey=I,this.setPrivateKey=z):this._primeCode=8}Object.defineProperty(F.prototype,"verifyError",{enumerable:!0,get:function(){return typeof this._primeCode!="number"&&(this._primeCode=P(this.__prime,this.__gen)),this._primeCode}}),F.prototype.generateKeys=function(){return this._priv||(this._priv=new R(W(this._primeLen))),this._pub=this._gen.toRed(this._prime).redPow(this._priv).fromRed(),this.getPublicKey()},F.prototype.computeSecret=function(S){S=new R(S),S=S.toRed(this._prime);var w=S.redPow(this._priv).fromRed(),y=new Buffer(w.toArray()),m=this.getPrime();if(y.length<m.length){var i=new Buffer(m.length-y.length);i.fill(0),y=Buffer.concat([i,y])}return y},F.prototype.getPublicKey=function(S){return v(this._pub,S)},F.prototype.getPrivateKey=function(S){return v(this._priv,S)},F.prototype.getPrime=function(S){return v(this.__prime,S)},F.prototype.getGenerator=function(S){return v(this._gen,S)},F.prototype.setGenerator=function(S,w){return w=w||"utf8",Buffer.isBuffer(S)||(S=new Buffer(S,w)),this.__gen=S,this._gen=new R(S),this};function v(S,w){var y=new Buffer(S.toArray());return w?y.toString(w):y}}),m8=OJ((l)=>{var g=Q6(),R=f8(),M=h8();function B(Y){var E=new Buffer(R[Y].prime,"hex"),O=new Buffer(R[Y].gen,"hex");return new M(E,O)}var A={binary:!0,hex:!0,base64:!0};function q(Y,E,O,N){return Buffer.isBuffer(E)||A[E]===void 0?q(Y,"binary",E,O):(E=E||"binary",N=N||"binary",O=O||new Buffer([2]),Buffer.isBuffer(O)||(O=new Buffer(O,N)),typeof Y=="number"?new M(g(Y,O),O,!0):(Buffer.isBuffer(Y)||(Y=new Buffer(Y,E)),new M(Y,O,!0)))}l.DiffieHellmanGroup=l.createDiffieHellmanGroup=l.getDiffieHellman=B,l.createDiffieHellman=l.DiffieHellman=q}),V6=OJ((l,g)=>{g.exports=rQ().EventEmitter}),u8=OJ((l,g)=>{function R(j,P){var F=Object.keys(j);if(Object.getOwnPropertySymbols){var v=Object.getOwnPropertySymbols(j);P&&(v=v.filter(function(S){return Object.getOwnPropertyDescriptor(j,S).enumerable})),F.push.apply(F,v)}return F}function M(j){for(var P=1;P<arguments.length;P++){var F=arguments[P]!=null?arguments[P]:{};P%2?R(Object(F),!0).forEach(function(v){B(j,v,F[v])}):Object.getOwnPropertyDescriptors?Object.defineProperties(j,Object.getOwnPropertyDescriptors(F)):R(Object(F)).forEach(function(v){Object.defineProperty(j,v,Object.getOwnPropertyDescriptor(F,v))})}return j}function B(j,P,F){return P in j?Object.defineProperty(j,P,{value:F,enumerable:!0,configurable:!0,writable:!0}):j[P]=F,j}function A(j,P){if(!(j instanceof P))throw new TypeError("Cannot call a class as a function")}function q(j,P){for(var F=0;F<P.length;F++){var v=P[F];v.enumerable=v.enumerable||!1,v.configurable=!0,"value"in v&&(v.writable=!0),Object.defineProperty(j,v.key,v)}}function Y(j,P,F){return P&&q(j.prototype,P),F&&q(j,F),j}var E=yQ(),O=E.Buffer,N=PV(),W=N.inspect,I=W&&W.custom||"inspect";function z(j,P,F){O.prototype.copy.call(j,P,F)}g.exports=function(){function j(){A(this,j),this.head=null,this.tail=null,this.length=0}return Y(j,[{key:"push",value:function(P){var F={data:P,next:null};this.length>0?this.tail.next=F:this.head=F,this.tail=F,++this.length}},{key:"unshift",value:function(P){var F={data:P,next:this.head};this.length===0&&(this.tail=F),this.head=F,++this.length}},{key:"shift",value:function(){if(this.length!==0){var P=this.head.data;return this.length===1?this.head=this.tail=null:this.head=this.head.next,--this.length,P}}},{key:"clear",value:function(){this.head=this.tail=null,this.length=0}},{key:"join",value:function(P){if(this.length===0)return"";for(var F=this.head,v=""+F.data;F=F.next;)v+=P+F.data;return v}},{key:"concat",value:function(P){if(this.length===0)return O.alloc(0);for(var F=O.allocUnsafe(P>>>0),v=this.head,S=0;v;)z(v.data,F,S),S+=v.data.length,v=v.next;return F}},{key:"consume",value:function(P,F){var v;return P<this.head.data.length?(v=this.head.data.slice(0,P),this.head.data=this.head.data.slice(P)):P===this.head.data.length?v=this.shift():v=F?this._getString(P):this._getBuffer(P),v}},{key:"first",value:function(){return this.head.data}},{key:"_getString",value:function(P){var F=this.head,v=1,S=F.data;for(P-=S.length;F=F.next;){var w=F.data,y=P>w.length?w.length:P;if(y===w.length?S+=w:S+=w.slice(0,P),P-=y,P===0){y===w.length?(++v,F.next?this.head=F.next:this.head=this.tail=null):(this.head=F,F.data=w.slice(y));break}++v}return this.length-=v,S}},{key:"_getBuffer",value:function(P){var F=O.allocUnsafe(P),v=this.head,S=1;for(v.data.copy(F),P-=v.data.length;v=v.next;){var w=v.data,y=P>w.length?w.length:P;if(w.copy(F,F.length-P,0,y),P-=y,P===0){y===w.length?(++S,v.next?this.head=v.next:this.head=this.tail=null):(this.head=v,v.data=w.slice(y));break}++S}return this.length-=S,F}},{key:I,value:function(P,F){return W(this,M({},F,{depth:0,customInspect:!1}))}}]),j}()}),$6=OJ((l,g)=>{function R(E,O){var N=this,W=this._readableState&&this._readableState.destroyed,I=this._writableState&&this._writableState.destroyed;return W||I?(O?O(E):E&&(this._writableState?this._writableState.errorEmitted||(this._writableState.errorEmitted=!0,process.nextTick(q,this,E)):process.nextTick(q,this,E)),this):(this._readableState&&(this._readableState.destroyed=!0),this._writableState&&(this._writableState.destroyed=!0),this._destroy(E||null,function(z){!O&&z?N._writableState?N._writableState.errorEmitted?process.nextTick(B,N):(N._writableState.errorEmitted=!0,process.nextTick(M,N,z)):process.nextTick(M,N,z):O?(process.nextTick(B,N),O(z)):process.nextTick(B,N)}),this)}function M(E,O){q(E,O),B(E)}function B(E){E._writableState&&!E._writableState.emitClose||E._readableState&&!E._readableState.emitClose||E.emit("close")}function A(){this._readableState&&(this._readableState.destroyed=!1,this._readableState.reading=!1,this._readableState.ended=!1,this._readableState.endEmitted=!1),this._writableState&&(this._writableState.destroyed=!1,this._writableState.ended=!1,this._writableState.ending=!1,this._writableState.finalCalled=!1,this._writableState.prefinished=!1,this._writableState.finished=!1,this._writableState.errorEmitted=!1)}function q(E,O){E.emit("error",O)}function Y(E,O){var{_readableState:N,_writableState:W}=E;N&&N.autoDestroy||W&&W.autoDestroy?E.destroy(O):E.emit("error",O)}g.exports={destroy:R,undestroy:A,errorOrDestroy:Y}}),GV=OJ((l,g)=>{function R(O,N){O.prototype=Object.create(N.prototype),O.prototype.constructor=O,O.__proto__=N}var M={};function B(O,N,W){W||(W=Error);function I(j,P,F){return typeof N=="string"?N:N(j,P,F)}var z=function(j){R(P,j);function P(F,v,S){return j.call(this,I(F,v,S))||this}return P}(W);z.prototype.name=W.name,z.prototype.code=O,M[O]=z}function A(O,N){if(Array.isArray(O)){var W=O.length;return O=O.map(function(I){return String(I)}),W>2?"one of ".concat(N," ").concat(O.slice(0,W-1).join(", "),", or ")+O[W-1]:W===2?"one of ".concat(N," ").concat(O[0]," or ").concat(O[1]):"of ".concat(N," ").concat(O[0])}else return"of ".concat(N," ").concat(String(O))}function q(O,N,W){return O.substr(!W||W<0?0:+W,N.length)===N}function Y(O,N,W){return(W===void 0||W>O.length)&&(W=O.length),O.substring(W-N.length,W)===N}function E(O,N,W){return typeof W!="number"&&(W=0),W+N.length>O.length?!1:O.indexOf(N,W)!==-1}B("ERR_INVALID_OPT_VALUE",function(O,N){return'The value "'+N+'" is invalid for option "'+O+'"'},TypeError),B("ERR_INVALID_ARG_TYPE",function(O,N,W){var I;typeof N=="string"&&q(N,"not ")?(I="must not be",N=N.replace(/^not /,"")):I="must be";var z;if(Y(O," argument"))z="The ".concat(O," ").concat(I," ").concat(A(N,"type"));else{var j=E(O,".")?"property":"argument";z='The "'.concat(O,'" ').concat(j," ").concat(I," ").concat(A(N,"type"))}return z+=". Received type ".concat(typeof W),z},TypeError),B("ERR_STREAM_PUSH_AFTER_EOF","stream.push() after EOF"),B("ERR_METHOD_NOT_IMPLEMENTED",function(O){return"The "+O+" method is not implemented"}),B("ERR_STREAM_PREMATURE_CLOSE","Premature close"),B("ERR_STREAM_DESTROYED",function(O){return"Cannot call "+O+" after a stream was destroyed"}),B("ERR_MULTIPLE_CALLBACK","Callback called multiple times"),B("ERR_STREAM_CANNOT_PIPE","Cannot pipe, not readable"),B("ERR_STREAM_WRITE_AFTER_END","write after end"),B("ERR_STREAM_NULL_VALUES","May not write null values to stream",TypeError),B("ERR_UNKNOWN_ENCODING",function(O){return"Unknown encoding: "+O},TypeError),B("ERR_STREAM_UNSHIFT_AFTER_END_EVENT","stream.unshift() after end event"),g.exports.codes=M}),Z6=OJ((l,g)=>{var R=GV().codes.ERR_INVALID_OPT_VALUE;function M(A,q,Y){return A.highWaterMark!=null?A.highWaterMark:q?A[Y]:null}function B(A,q,Y,E){var O=M(q,E,Y);if(O!=null){if(!(isFinite(O)&&Math.floor(O)===O)||O<0){var N=E?Y:"highWaterMark";throw new R(N,O)}return Math.floor(O)}return A.objectMode?16:16384}g.exports={getHighWaterMark:B}}),X6=OJ((l,g)=>{g.exports=o;function R(n){var p=this;this.next=null,this.entry=null,this.finish=function(){GJ(p,n)}}var M;o.WritableState=VJ;var B={deprecate:L0()},A=V6(),q=yQ().Buffer,Y=global.Uint8Array||function(){};function E(n){return q.from(n)}function O(n){return q.isBuffer(n)||n instanceof Y}var N=$6(),W=Z6(),I=W.getHighWaterMark,z=GV().codes,j=z.ERR_INVALID_ARG_TYPE,P=z.ERR_METHOD_NOT_IMPLEMENTED,F=z.ERR_MULTIPLE_CALLBACK,v=z.ERR_STREAM_CANNOT_PIPE,S=z.ERR_STREAM_DESTROYED,w=z.ERR_STREAM_NULL_VALUES,y=z.ERR_STREAM_WRITE_AFTER_END,m=z.ERR_UNKNOWN_ENCODING,i=N.errorOrDestroy;JQ()(o,A);function JJ(){}function VJ(n,p,e){M=M||KV(),n=n||{},typeof e!="boolean"&&(e=p instanceof M),this.objectMode=!!n.objectMode,e&&(this.objectMode=this.objectMode||!!n.writableObjectMode),this.highWaterMark=I(this,n,"writableHighWaterMark",e),this.finalCalled=!1,this.needDrain=!1,this.ending=!1,this.ended=!1,this.finished=!1,this.destroyed=!1;var PJ=n.decodeStrings===!1;this.decodeStrings=!PJ,this.defaultEncoding=n.defaultEncoding||"utf8",this.length=0,this.writing=!1,this.corked=0,this.sync=!0,this.bufferProcessing=!1,this.onwrite=function(XJ){H(p,XJ)},this.writecb=null,this.writelen=0,this.bufferedRequest=null,this.lastBufferedRequest=null,this.pendingcb=0,this.prefinished=!1,this.errorEmitted=!1,this.emitClose=n.emitClose!==!1,this.autoDestroy=!!n.autoDestroy,this.bufferedRequestCount=0,this.corkedRequestsFree=new R(this)}VJ.prototype.getBuffer=function(){for(var n=this.bufferedRequest,p=[];n;)p.push(n),n=n.next;return p},function(){try{Object.defineProperty(VJ.prototype,"buffer",{get:B.deprecate(function(){return this.getBuffer()},"_writableState.buffer is deprecated. Use _writableState.getBuffer instead.","DEP0003")})}catch{}}();var HJ;typeof Symbol=="function"&&Symbol.hasInstance&&typeof Function.prototype[Symbol.hasInstance]=="function"?(HJ=Function.prototype[Symbol.hasInstance],Object.defineProperty(o,Symbol.hasInstance,{value:function(n){return HJ.call(this,n)?!0:this!==o?!1:n&&n._writableState instanceof VJ}})):HJ=function(n){return n instanceof this};function o(n){M=M||KV();var p=this instanceof M;if(!p&&!HJ.call(o,this))return new o(n);this._writableState=new VJ(n,this,p),this.writable=!0,n&&(typeof n.write=="function"&&(this._write=n.write),typeof n.writev=="function"&&(this._writev=n.writev),typeof n.destroy=="function"&&(this._destroy=n.destroy),typeof n.final=="function"&&(this._final=n.final)),A.call(this)}o.prototype.pipe=function(){i(this,new v)};function jJ(n,p){var e=new y;i(n,e),process.nextTick(p,e)}function J(n,p,e,PJ){var XJ;return e===null?XJ=new w:typeof e!="string"&&!p.objectMode&&(XJ=new j("chunk",["string","Buffer"],e)),XJ?(i(n,XJ),process.nextTick(PJ,XJ),!1):!0}o.prototype.write=function(n,p,e){var PJ=this._writableState,XJ=!1,WJ=!PJ.objectMode&&O(n);return WJ&&!q.isBuffer(n)&&(n=E(n)),typeof p=="function"&&(e=p,p=null),WJ?p="buffer":p||(p=PJ.defaultEncoding),typeof e!="function"&&(e=JJ),PJ.ending?jJ(this,e):(WJ||J(this,PJ,n,e))&&(PJ.pendingcb++,XJ=Z(this,PJ,WJ,n,p,e)),XJ},o.prototype.cork=function(){this._writableState.corked++},o.prototype.uncork=function(){var n=this._writableState;n.corked&&(n.corked--,!n.writing&&!n.corked&&!n.bufferProcessing&&n.bufferedRequest&&K(this,n))},o.prototype.setDefaultEncoding=function(n){if(typeof n=="string"&&(n=n.toLowerCase()),!(["hex","utf8","utf-8","ascii","binary","base64","ucs2","ucs-2","utf16le","utf-16le","raw"].indexOf((n+"").toLowerCase())>-1))throw new m(n);return this._writableState.defaultEncoding=n,this},Object.defineProperty(o.prototype,"writableBuffer",{enumerable:!1,get:function(){return this._writableState&&this._writableState.getBuffer()}});function V(n,p,e){return!n.objectMode&&n.decodeStrings!==!1&&typeof p=="string"&&(p=q.from(p,e)),p}Object.defineProperty(o.prototype,"writableHighWaterMark",{enumerable:!1,get:function(){return this._writableState.highWaterMark}});function Z(n,p,e,PJ,XJ,WJ){if(!e){var b=V(p,PJ,XJ);PJ!==b&&(e=!0,XJ="buffer",PJ=b)}var C=p.objectMode?1:PJ.length;p.length+=C;var h=p.length<p.highWaterMark;if(h||(p.needDrain=!0),p.writing||p.corked){var $J=p.lastBufferedRequest;p.lastBufferedRequest={chunk:PJ,encoding:XJ,isBuf:e,callback:WJ,next:null},$J?$J.next=p.lastBufferedRequest:p.bufferedRequest=p.lastBufferedRequest,p.bufferedRequestCount+=1}else $(n,p,!1,C,PJ,XJ,WJ);return h}function $(n,p,e,PJ,XJ,WJ,b){p.writelen=PJ,p.writecb=b,p.writing=!0,p.sync=!0,p.destroyed?p.onwrite(new S("write")):e?n._writev(XJ,p.onwrite):n._write(XJ,WJ,p.onwrite),p.sync=!1}function X(n,p,e,PJ,XJ){--p.pendingcb,e?(process.nextTick(XJ,PJ),process.nextTick(t,n,p),n._writableState.errorEmitted=!0,i(n,PJ)):(XJ(PJ),n._writableState.errorEmitted=!0,i(n,PJ),t(n,p))}function U(n){n.writing=!1,n.writecb=null,n.length-=n.writelen,n.writelen=0}function H(n,p){var e=n._writableState,PJ=e.sync,XJ=e.writecb;if(typeof XJ!="function")throw new F;if(U(e),p)X(n,e,PJ,p,XJ);else{var WJ=k(e)||n.destroyed;!WJ&&!e.corked&&!e.bufferProcessing&&e.bufferedRequest&&K(n,e),PJ?process.nextTick(G,n,e,WJ,XJ):G(n,e,WJ,XJ)}}function G(n,p,e,PJ){e||Q(n,p),p.pendingcb--,PJ(),t(n,p)}function Q(n,p){p.length===0&&p.needDrain&&(p.needDrain=!1,n.emit("drain"))}function K(n,p){p.bufferProcessing=!0;var e=p.bufferedRequest;if(n._writev&&e&&e.next){var PJ=p.bufferedRequestCount,XJ=new Array(PJ),WJ=p.corkedRequestsFree;WJ.entry=e;for(var b=0,C=!0;e;)XJ[b]=e,e.isBuf||(C=!1),e=e.next,b+=1;XJ.allBuffers=C,$(n,p,!0,p.length,XJ,"",WJ.finish),p.pendingcb++,p.lastBufferedRequest=null,WJ.next?(p.corkedRequestsFree=WJ.next,WJ.next=null):p.corkedRequestsFree=new R(p),p.bufferedRequestCount=0}else{for(;e;){var{chunk:h,encoding:$J,callback:qJ}=e,ZJ=p.objectMode?1:h.length;if($(n,p,!1,ZJ,h,$J,qJ),e=e.next,p.bufferedRequestCount--,p.writing)break}e===null&&(p.lastBufferedRequest=null)}p.bufferedRequest=e,p.bufferProcessing=!1}o.prototype._write=function(n,p,e){e(new P("_write()"))},o.prototype._writev=null,o.prototype.end=function(n,p,e){var PJ=this._writableState;return typeof n=="function"?(e=n,n=null,p=null):typeof p=="function"&&(e=p,p=null),n!=null&&this.write(n,p),PJ.corked&&(PJ.corked=1,this.uncork()),PJ.ending||QJ(this,PJ,e),this},Object.defineProperty(o.prototype,"writableLength",{enumerable:!1,get:function(){return this._writableState.length}});function k(n){return n.ending&&n.length===0&&n.bufferedRequest===null&&!n.finished&&!n.writing}function L(n,p){n._final(function(e){p.pendingcb--,e&&i(n,e),p.prefinished=!0,n.emit("prefinish"),t(n,p)})}function _(n,p){!p.prefinished&&!p.finalCalled&&(typeof n._final=="function"&&!p.destroyed?(p.pendingcb++,p.finalCalled=!0,process.nextTick(L,n,p)):(p.prefinished=!0,n.emit("prefinish")))}function t(n,p){var e=k(p);if(e&&(_(n,p),p.pendingcb===0&&(p.finished=!0,n.emit("finish"),p.autoDestroy))){var PJ=n._readableState;(!PJ||PJ.autoDestroy&&PJ.endEmitted)&&n.destroy()}return e}function QJ(n,p,e){p.ending=!0,t(n,p),e&&(p.finished?process.nextTick(e):n.once("finish",e)),p.ended=!0,n.writable=!1}function GJ(n,p,e){var PJ=n.entry;for(n.entry=null;PJ;){var XJ=PJ.callback;p.pendingcb--,XJ(e),PJ=PJ.next}p.corkedRequestsFree.next=n}Object.defineProperty(o.prototype,"destroyed",{enumerable:!1,get:function(){return this._writableState===void 0?!1:this._writableState.destroyed},set:function(n){!this._writableState||(this._writableState.destroyed=n)}}),o.prototype.destroy=N.destroy,o.prototype._undestroy=N.undestroy,o.prototype._destroy=function(n,p){p(n)}}),KV=OJ((l,g)=>{var R=Object.keys||function(W){var I=[];for(var z in W)I.push(z);return I};g.exports=E;var M=q6(),B=X6();JQ()(E,M);for(A=R(B.prototype),Y=0;Y<A.length;Y++)q=A[Y],E.prototype[q]||(E.prototype[q]=B.prototype[q]);var A,q,Y;function E(W){if(!(this instanceof E))return new E(W);M.call(this,W),B.call(this,W),this.allowHalfOpen=!0,W&&(W.readable===!1&&(this.readable=!1),W.writable===!1&&(this.writable=!1),W.allowHalfOpen===!1&&(this.allowHalfOpen=!1,this.once("end",O)))}Object.defineProperty(E.prototype,"writableHighWaterMark",{enumerable:!1,get:function(){return this._writableState.highWaterMark}}),Object.defineProperty(E.prototype,"writableBuffer",{enumerable:!1,get:function(){return this._writableState&&this._writableState.getBuffer()}}),Object.defineProperty(E.prototype,"writableLength",{enumerable:!1,get:function(){return this._writableState.length}});function O(){this._writableState.ended||process.nextTick(N,this)}function N(W){W.end()}Object.defineProperty(E.prototype,"destroyed",{enumerable:!1,get:function(){return this._readableState===void 0||this._writableState===void 0?!1:this._readableState.destroyed&&this._writableState.destroyed},set:function(W){this._readableState===void 0||this._writableState===void 0||(this._readableState.destroyed=W,this._writableState.destroyed=W)}})}),Q0=OJ((l,g)=>{var R=GV().codes.ERR_STREAM_PREMATURE_CLOSE;function M(Y){var E=!1;return function(){if(!E){E=!0;for(var O=arguments.length,N=new Array(O),W=0;W<O;W++)N[W]=arguments[W];Y.apply(this,N)}}}function B(){}function A(Y){return Y.setHeader&&typeof Y.abort=="function"}function q(Y,E,O){if(typeof E=="function")return q(Y,null,E);E||(E={}),O=M(O||B);var N=E.readable||E.readable!==!1&&Y.readable,W=E.writable||E.writable!==!1&&Y.writable,I=function(){Y.writable||j()},z=Y._writableState&&Y._writableState.finished,j=function(){W=!1,z=!0,N||O.call(Y)},P=Y._readableState&&Y._readableState.endEmitted,F=function(){N=!1,P=!0,W||O.call(Y)},v=function(y){O.call(Y,y)},S=function(){var y;if(N&&!P)return(!Y._readableState||!Y._readableState.ended)&&(y=new R),O.call(Y,y);if(W&&!z)return(!Y._writableState||!Y._writableState.ended)&&(y=new R),O.call(Y,y)},w=function(){Y.req.on("finish",j)};return A(Y)?(Y.on("complete",j),Y.on("abort",S),Y.req?w():Y.on("request",w)):W&&!Y._writableState&&(Y.on("end",I),Y.on("close",I)),Y.on("end",F),Y.on("finish",j),E.error!==!1&&Y.on("error",v),Y.on("close",S),function(){Y.removeListener("complete",j),Y.removeListener("abort",S),Y.removeListener("request",w),Y.req&&Y.req.removeListener("finish",j),Y.removeListener("end",I),Y.removeListener("close",I),Y.removeListener("finish",j),Y.removeListener("end",F),Y.removeListener("error",v),Y.removeListener("close",S)}}g.exports=q}),p8=OJ((l,g)=>{var R;function M(w,y,m){return y in w?Object.defineProperty(w,y,{value:m,enumerable:!0,configurable:!0,writable:!0}):w[y]=m,w}var B=Q0(),A=Symbol("lastResolve"),q=Symbol("lastReject"),Y=Symbol("error"),E=Symbol("ended"),O=Symbol("lastPromise"),N=Symbol("handlePromise"),W=Symbol("stream");function I(w,y){return{value:w,done:y}}function z(w){var y=w[A];if(y!==null){var m=w[W].read();m!==null&&(w[O]=null,w[A]=null,w[q]=null,y(I(m,!1)))}}function j(w){process.nextTick(z,w)}function P(w,y){return function(m,i){w.then(function(){if(y[E]){m(I(void 0,!0));return}y[N](m,i)},i)}}var F=Object.getPrototypeOf(function(){}),v=Object.setPrototypeOf((R={get stream(){return this[W]},next:function(){var w=this,y=this[Y];if(y!==null)return Promise.reject(y);if(this[E])return Promise.resolve(I(void 0,!0));if(this[W].destroyed)return new Promise(function(VJ,HJ){process.nextTick(function(){w[Y]?HJ(w[Y]):VJ(I(void 0,!0))})});var m=this[O],i;if(m)i=new Promise(P(m,this));else{var JJ=this[W].read();if(JJ!==null)return Promise.resolve(I(JJ,!1));i=new Promise(this[N])}return this[O]=i,i}},M(R,Symbol.asyncIterator,function(){return this}),M(R,"return",function(){var w=this;return new Promise(function(y,m){w[W].destroy(null,function(i){if(i){m(i);return}y(I(void 0,!0))})})}),R),F),S=function(w){var y,m=Object.create(v,(y={},M(y,W,{value:w,writable:!0}),M(y,A,{value:null,writable:!0}),M(y,q,{value:null,writable:!0}),M(y,Y,{value:null,writable:!0}),M(y,E,{value:w._readableState.endEmitted,writable:!0}),M(y,N,{value:function(i,JJ){var VJ=m[W].read();VJ?(m[O]=null,m[A]=null,m[q]=null,i(I(VJ,!1))):(m[A]=i,m[q]=JJ)},writable:!0}),y));return m[O]=null,B(w,function(i){if(i&&i.code!=="ERR_STREAM_PREMATURE_CLOSE"){var JJ=m[q];JJ!==null&&(m[O]=null,m[A]=null,m[q]=null,JJ(i)),m[Y]=i;return}var VJ=m[A];VJ!==null&&(m[O]=null,m[A]=null,m[q]=null,VJ(I(void 0,!0))),m[E]=!0}),w.on("readable",j.bind(null,m)),m};g.exports=S}),i8=OJ((l,g)=>{g.exports=function(){throw new Error("Readable.from is not available in the browser")}}),q6=OJ((l,g)=>{g.exports=J;var R;J.ReadableState=jJ;var M=rQ().EventEmitter,B=function(b,C){return b.listeners(C).length},A=V6(),q=yQ().Buffer,Y=global.Uint8Array||function(){};function E(b){return q.from(b)}function O(b){return q.isBuffer(b)||b instanceof Y}var N=PV(),W;N&&N.debuglog?W=N.debuglog("stream"):W=function(){};var I=u8(),z=$6(),j=Z6(),P=j.getHighWaterMark,F=GV().codes,v=F.ERR_INVALID_ARG_TYPE,S=F.ERR_STREAM_PUSH_AFTER_EOF,w=F.ERR_METHOD_NOT_IMPLEMENTED,y=F.ERR_STREAM_UNSHIFT_AFTER_END_EVENT,m,i,JJ;JQ()(J,A);var VJ=z.errorOrDestroy,HJ=["error","close","destroy","pause","resume"];function o(b,C,h){if(typeof b.prependListener=="function")return b.prependListener(C,h);!b._events||!b._events[C]?b.on(C,h):Array.isArray(b._events[C])?b._events[C].unshift(h):b._events[C]=[h,b._events[C]]}function jJ(b,C,h){R=R||KV(),b=b||{},typeof h!="boolean"&&(h=C instanceof R),this.objectMode=!!b.objectMode,h&&(this.objectMode=this.objectMode||!!b.readableObjectMode),this.highWaterMark=P(this,b,"readableHighWaterMark",h),this.buffer=new I,this.length=0,this.pipes=null,this.pipesCount=0,this.flowing=null,this.ended=!1,this.endEmitted=!1,this.reading=!1,this.sync=!0,this.needReadable=!1,this.emittedReadable=!1,this.readableListening=!1,this.resumeScheduled=!1,this.paused=!0,this.emitClose=b.emitClose!==!1,this.autoDestroy=!!b.autoDestroy,this.destroyed=!1,this.defaultEncoding=b.defaultEncoding||"utf8",this.awaitDrain=0,this.readingMore=!1,this.decoder=null,this.encoding=null,b.encoding&&(m||(m=(LV(),fQ(HV)).StringDecoder),this.decoder=new m(b.encoding),this.encoding=b.encoding)}function J(b){if(R=R||KV(),!(this instanceof J))return new J(b);var C=this instanceof R;this._readableState=new jJ(b,this,C),this.readable=!0,b&&(typeof b.read=="function"&&(this._read=b.read),typeof b.destroy=="function"&&(this._destroy=b.destroy)),A.call(this)}Object.defineProperty(J.prototype,"destroyed",{enumerable:!1,get:function(){return this._readableState===void 0?!1:this._readableState.destroyed},set:function(b){!this._readableState||(this._readableState.destroyed=b)}}),J.prototype.destroy=z.destroy,J.prototype._undestroy=z.undestroy,J.prototype._destroy=function(b,C){C(b)},J.prototype.push=function(b,C){var h=this._readableState,$J;return h.objectMode?$J=!0:typeof b=="string"&&(C=C||h.defaultEncoding,C!==h.encoding&&(b=q.from(b,C),C=""),$J=!0),V(this,b,C,!1,$J)},J.prototype.unshift=function(b){return V(this,b,null,!0,!1)};function V(b,C,h,$J,qJ){W("readableAddChunk",C);var ZJ=b._readableState;if(C===null)ZJ.reading=!1,G(b,ZJ);else{var mJ;if(qJ||(mJ=$(ZJ,C)),mJ)VJ(b,mJ);else if(ZJ.objectMode||C&&C.length>0)if(typeof C!="string"&&!ZJ.objectMode&&Object.getPrototypeOf(C)!==q.prototype&&(C=E(C)),$J)ZJ.endEmitted?VJ(b,new y):Z(b,ZJ,C,!0);else if(ZJ.ended)VJ(b,new S);else{if(ZJ.destroyed)return!1;ZJ.reading=!1,ZJ.decoder&&!h?(C=ZJ.decoder.write(C),ZJ.objectMode||C.length!==0?Z(b,ZJ,C,!1):k(b,ZJ)):Z(b,ZJ,C,!1)}else $J||(ZJ.reading=!1,k(b,ZJ))}return!ZJ.ended&&(ZJ.length<ZJ.highWaterMark||ZJ.length===0)}function Z(b,C,h,$J){C.flowing&&C.length===0&&!C.sync?(C.awaitDrain=0,b.emit("data",h)):(C.length+=C.objectMode?1:h.length,$J?C.buffer.unshift(h):C.buffer.push(h),C.needReadable&&Q(b)),k(b,C)}function $(b,C){var h;return!O(C)&&typeof C!="string"&&C!==void 0&&!b.objectMode&&(h=new v("chunk",["string","Buffer","Uint8Array"],C)),h}J.prototype.isPaused=function(){return this._readableState.flowing===!1},J.prototype.setEncoding=function(b){m||(m=(LV(),fQ(HV)).StringDecoder);var C=new m(b);this._readableState.decoder=C,this._readableState.encoding=this._readableState.decoder.encoding;for(var h=this._readableState.buffer.head,$J="";h!==null;)$J+=C.write(h.data),h=h.next;return this._readableState.buffer.clear(),$J!==""&&this._readableState.buffer.push($J),this._readableState.length=$J.length,this};var X=1073741824;function U(b){return b>=X?b=X:(b--,b|=b>>>1,b|=b>>>2,b|=b>>>4,b|=b>>>8,b|=b>>>16,b++),b}function H(b,C){return b<=0||C.length===0&&C.ended?0:C.objectMode?1:b!==b?C.flowing&&C.length?C.buffer.head.data.length:C.length:(b>C.highWaterMark&&(C.highWaterMark=U(b)),b<=C.length?b:C.ended?C.length:(C.needReadable=!0,0))}J.prototype.read=function(b){W("read",b),b=parseInt(b,10);var C=this._readableState,h=b;if(b!==0&&(C.emittedReadable=!1),b===0&&C.needReadable&&((C.highWaterMark!==0?C.length>=C.highWaterMark:C.length>0)||C.ended))return W("read: emitReadable",C.length,C.ended),C.length===0&&C.ended?PJ(this):Q(this),null;if(b=H(b,C),b===0&&C.ended)return C.length===0&&PJ(this),null;var $J=C.needReadable;W("need readable",$J),(C.length===0||C.length-b<C.highWaterMark)&&($J=!0,W("length less than watermark",$J)),C.ended||C.reading?($J=!1,W("reading or ended",$J)):$J&&(W("do read"),C.reading=!0,C.sync=!0,C.length===0&&(C.needReadable=!0),this._read(C.highWaterMark),C.sync=!1,C.reading||(b=H(h,C)));var qJ;return b>0?qJ=e(b,C):qJ=null,qJ===null?(C.needReadable=C.length<=C.highWaterMark,b=0):(C.length-=b,C.awaitDrain=0),C.length===0&&(C.ended||(C.needReadable=!0),h!==b&&C.ended&&PJ(this)),qJ!==null&&this.emit("data",qJ),qJ};function G(b,C){if(W("onEofChunk"),!C.ended){if(C.decoder){var h=C.decoder.end();h&&h.length&&(C.buffer.push(h),C.length+=C.objectMode?1:h.length)}C.ended=!0,C.sync?Q(b):(C.needReadable=!1,C.emittedReadable||(C.emittedReadable=!0,K(b)))}}function Q(b){var C=b._readableState;W("emitReadable",C.needReadable,C.emittedReadable),C.needReadable=!1,C.emittedReadable||(W("emitReadable",C.flowing),C.emittedReadable=!0,process.nextTick(K,b))}function K(b){var C=b._readableState;W("emitReadable_",C.destroyed,C.length,C.ended),!C.destroyed&&(C.length||C.ended)&&(b.emit("readable"),C.emittedReadable=!1),C.needReadable=!C.flowing&&!C.ended&&C.length<=C.highWaterMark,p(b)}function k(b,C){C.readingMore||(C.readingMore=!0,process.nextTick(L,b,C))}function L(b,C){for(;!C.reading&&!C.ended&&(C.length<C.highWaterMark||C.flowing&&C.length===0);){var h=C.length;if(W("maybeReadMore read 0"),b.read(0),h===C.length)break}C.readingMore=!1}J.prototype._read=function(b){VJ(this,new w("_read()"))},J.prototype.pipe=function(b,C){var h=this,$J=this._readableState;switch($J.pipesCount){case 0:$J.pipes=b;break;case 1:$J.pipes=[$J.pipes,b];break;default:$J.pipes.push(b);break}$J.pipesCount+=1,W("pipe count=%d opts=%j",$J.pipesCount,C);var qJ=(!C||C.end!==!1)&&b!==process.stdout&&b!==process.stderr,ZJ=qJ?BJ:u;$J.endEmitted?process.nextTick(ZJ):h.once("end",ZJ),b.on("unpipe",mJ);function mJ(d,a){W("onunpipe"),d===h&&a&&a.hasUnpiped===!1&&(a.hasUnpiped=!0,LJ())}function BJ(){W("onend"),b.end()}var TJ=_(h);b.on("drain",TJ);var dJ=!1;function LJ(){W("cleanup"),b.removeListener("close",T),b.removeListener("finish",D),b.removeListener("drain",TJ),b.removeListener("error",$Q),b.removeListener("unpipe",mJ),h.removeListener("end",BJ),h.removeListener("end",u),h.removeListener("data",IJ),dJ=!0,$J.awaitDrain&&(!b._writableState||b._writableState.needDrain)&&TJ()}h.on("data",IJ);function IJ(d){W("ondata");var a=b.write(d);W("dest.write",a),a===!1&&(($J.pipesCount===1&&$J.pipes===b||$J.pipesCount>1&&WJ($J.pipes,b)!==-1)&&!dJ&&(W("false write response, pause",$J.awaitDrain),$J.awaitDrain++),h.pause())}function $Q(d){W("onerror",d),u(),b.removeListener("error",$Q),B(b,"error")===0&&VJ(b,d)}o(b,"error",$Q);function T(){b.removeListener("finish",D),u()}b.once("close",T);function D(){W("onfinish"),b.removeListener("close",T),u()}b.once("finish",D);function u(){W("unpipe"),h.unpipe(b)}return b.emit("pipe",h),$J.flowing||(W("pipe resume"),h.resume()),b};function _(b){return function(){var C=b._readableState;W("pipeOnDrain",C.awaitDrain),C.awaitDrain&&C.awaitDrain--,C.awaitDrain===0&&B(b,"data")&&(C.flowing=!0,p(b))}}J.prototype.unpipe=function(b){var C=this._readableState,h={hasUnpiped:!1};if(C.pipesCount===0)return this;if(C.pipesCount===1)return b&&b!==C.pipes?this:(b||(b=C.pipes),C.pipes=null,C.pipesCount=0,C.flowing=!1,b&&b.emit("unpipe",this,h),this);if(!b){var{pipes:$J,pipesCount:qJ}=C;C.pipes=null,C.pipesCount=0,C.flowing=!1;for(var ZJ=0;ZJ<qJ;ZJ++)$J[ZJ].emit("unpipe",this,{hasUnpiped:!1});return this}var mJ=WJ(C.pipes,b);return mJ===-1?this:(C.pipes.splice(mJ,1),C.pipesCount-=1,C.pipesCount===1&&(C.pipes=C.pipes[0]),b.emit("unpipe",this,h),this)},J.prototype.on=function(b,C){var h=A.prototype.on.call(this,b,C),$J=this._readableState;return b==="data"?($J.readableListening=this.listenerCount("readable")>0,$J.flowing!==!1&&this.resume()):b==="readable"&&!$J.endEmitted&&!$J.readableListening&&($J.readableListening=$J.needReadable=!0,$J.flowing=!1,$J.emittedReadable=!1,W("on readable",$J.length,$J.reading),$J.length?Q(this):$J.reading||process.nextTick(QJ,this)),h},J.prototype.addListener=J.prototype.on,J.prototype.removeListener=function(b,C){var h=A.prototype.removeListener.call(this,b,C);return b==="readable"&&process.nextTick(t,this),h},J.prototype.removeAllListeners=function(b){var C=A.prototype.removeAllListeners.apply(this,arguments);return(b==="readable"||b===void 0)&&process.nextTick(t,this),C};function t(b){var C=b._readableState;C.readableListening=b.listenerCount("readable")>0,C.resumeScheduled&&!C.paused?C.flowing=!0:b.listenerCount("data")>0&&b.resume()}function QJ(b){W("readable nexttick read 0"),b.read(0)}J.prototype.resume=function(){var b=this._readableState;return b.flowing||(W("resume"),b.flowing=!b.readableListening,GJ(this,b)),b.paused=!1,this};function GJ(b,C){C.resumeScheduled||(C.resumeScheduled=!0,process.nextTick(n,b,C))}function n(b,C){W("resume",C.reading),C.reading||b.read(0),C.resumeScheduled=!1,b.emit("resume"),p(b),C.flowing&&!C.reading&&b.read(0)}J.prototype.pause=function(){return W("call pause flowing=%j",this._readableState.flowing),this._readableState.flowing!==!1&&(W("pause"),this._readableState.flowing=!1,this.emit("pause")),this._readableState.paused=!0,this};function p(b){var C=b._readableState;for(W("flow",C.flowing);C.flowing&&b.read()!==null;);}J.prototype.wrap=function(b){var C=this,h=this._readableState,$J=!1;b.on("end",function(){if(W("wrapped end"),h.decoder&&!h.ended){var mJ=h.decoder.end();mJ&&mJ.length&&C.push(mJ)}C.push(null)}),b.on("data",function(mJ){if(W("wrapped data"),h.decoder&&(mJ=h.decoder.write(mJ)),!(h.objectMode&&mJ==null)&&!(!h.objectMode&&(!mJ||!mJ.length))){var BJ=C.push(mJ);BJ||($J=!0,b.pause())}});for(var qJ in b)this[qJ]===void 0&&typeof b[qJ]=="function"&&(this[qJ]=function(mJ){return function(){return b[mJ].apply(b,arguments)}}(qJ));for(var ZJ=0;ZJ<HJ.length;ZJ++)b.on(HJ[ZJ],this.emit.bind(this,HJ[ZJ]));return this._read=function(mJ){W("wrapped _read",mJ),$J&&($J=!1,b.resume())},this},typeof Symbol=="function"&&(J.prototype[Symbol.asyncIterator]=function(){return i===void 0&&(i=p8()),i(this)}),Object.defineProperty(J.prototype,"readableHighWaterMark",{enumerable:!1,get:function(){return this._readableState.highWaterMark}}),Object.defineProperty(J.prototype,"readableBuffer",{enumerable:!1,get:function(){return this._readableState&&this._readableState.buffer}}),Object.defineProperty(J.prototype,"readableFlowing",{enumerable:!1,get:function(){return this._readableState.flowing},set:function(b){this._readableState&&(this._readableState.flowing=b)}}),J._fromList=e,Object.defineProperty(J.prototype,"readableLength",{enumerable:!1,get:function(){return this._readableState.length}});function e(b,C){if(C.length===0)return null;var h;return C.objectMode?h=C.buffer.shift():!b||b>=C.length?(C.decoder?h=C.buffer.join(""):C.buffer.length===1?h=C.buffer.first():h=C.buffer.concat(C.length),C.buffer.clear()):h=C.buffer.consume(b,C.decoder),h}function PJ(b){var C=b._readableState;W("endReadable",C.endEmitted),C.endEmitted||(C.ended=!0,process.nextTick(XJ,C,b))}function XJ(b,C){if(W("endReadableNT",b.endEmitted,b.length),!b.endEmitted&&b.length===0&&(b.endEmitted=!0,C.readable=!1,C.emit("end"),b.autoDestroy)){var h=C._writableState;(!h||h.autoDestroy&&h.finished)&&C.destroy()}}typeof Symbol=="function"&&(J.from=function(b,C){return JJ===void 0&&(JJ=i8()),JJ(J,b,C)});function WJ(b,C){for(var h=0,$J=b.length;h<$J;h++)if(b[h]===C)return h;return-1}}),G6=OJ((l,g)=>{g.exports=O;var R=GV().codes,M=R.ERR_METHOD_NOT_IMPLEMENTED,B=R.ERR_MULTIPLE_CALLBACK,A=R.ERR_TRANSFORM_ALREADY_TRANSFORMING,q=R.ERR_TRANSFORM_WITH_LENGTH_0,Y=KV();JQ()(O,Y);function E(I,z){var j=this._transformState;j.transforming=!1;var P=j.writecb;if(P===null)return this.emit("error",new B);j.writechunk=null,j.writecb=null,z!=null&&this.push(z),P(I);var F=this._readableState;F.reading=!1,(F.needReadable||F.length<F.highWaterMark)&&this._read(F.highWaterMark)}function O(I){if(!(this instanceof O))return new O(I);Y.call(this,I),this._transformState={afterTransform:E.bind(this),needTransform:!1,transforming:!1,writecb:null,writechunk:null,writeencoding:null},this._readableState.needReadable=!0,this._readableState.sync=!1,I&&(typeof I.transform=="function"&&(this._transform=I.transform),typeof I.flush=="function"&&(this._flush=I.flush)),this.on("prefinish",N)}function N(){var I=this;typeof this._flush=="function"&&!this._readableState.destroyed?this._flush(function(z,j){W(I,z,j)}):W(this,null,null)}O.prototype.push=function(I,z){return this._transformState.needTransform=!1,Y.prototype.push.call(this,I,z)},O.prototype._transform=function(I,z,j){j(new M("_transform()"))},O.prototype._write=function(I,z,j){var P=this._transformState;if(P.writecb=j,P.writechunk=I,P.writeencoding=z,!P.transforming){var F=this._readableState;(P.needTransform||F.needReadable||F.length<F.highWaterMark)&&this._read(F.highWaterMark)}},O.prototype._read=function(I){var z=this._transformState;z.writechunk!==null&&!z.transforming?(z.transforming=!0,this._transform(z.writechunk,z.writeencoding,z.afterTransform)):z.needTransform=!0},O.prototype._destroy=function(I,z){Y.prototype._destroy.call(this,I,function(j){z(j)})};function W(I,z,j){if(z)return I.emit("error",z);if(j!=null&&I.push(j),I._writableState.length)throw new q;if(I._transformState.transforming)throw new A;return I.push(null)}}),l8=OJ((l,g)=>{g.exports=M;var R=G6();JQ()(M,R);function M(B){if(!(this instanceof M))return new M(B);R.call(this,B)}M.prototype._transform=function(B,A,q){q(null,B)}}),s8=OJ((l,g)=>{var R;function M(j){var P=!1;return function(){P||(P=!0,j.apply(void 0,arguments))}}var B=GV().codes,A=B.ERR_MISSING_ARGS,q=B.ERR_STREAM_DESTROYED;function Y(j){if(j)throw j}function E(j){return j.setHeader&&typeof j.abort=="function"}function O(j,P,F,v){v=M(v);var S=!1;j.on("close",function(){S=!0}),R===void 0&&(R=Q0()),R(j,{readable:P,writable:F},function(y){if(y)return v(y);S=!0,v()});var w=!1;return function(y){if(!S&&!w){if(w=!0,E(j))return j.abort();if(typeof j.destroy=="function")return j.destroy();v(y||new q("pipe"))}}}function N(j){j()}function W(j,P){return j.pipe(P)}function I(j){return!j.length||typeof j[j.length-1]!="function"?Y:j.pop()}function z(){for(var j=arguments.length,P=new Array(j),F=0;F<j;F++)P[F]=arguments[F];var v=I(P);if(Array.isArray(P[0])&&(P=P[0]),P.length<2)throw new A("streams");var S,w=P.map(function(y,m){var i=m<P.length-1,JJ=m>0;return O(y,i,JJ,function(VJ){S||(S=VJ),VJ&&w.forEach(N),!i&&(w.forEach(N),v(S))})});return P.reduce(W)}g.exports=z}),d8=OJ((l,g)=>{l=g.exports=q6(),l.Stream=l,l.Readable=l,l.Writable=X6(),l.Duplex=KV(),l.Transform=G6(),l.PassThrough=l8(),l.finished=Q0(),l.pipeline=s8()}),V0=OJ((l,g)=>{(function(R,M){function B($,X){if(!$)throw new Error(X||"Assertion failed")}function A($,X){$.super_=X;var U=function(){};U.prototype=X.prototype,$.prototype=new U,$.prototype.constructor=$}function q($,X,U){if(q.isBN($))return $;this.negative=0,this.words=null,this.length=0,this.red=null,$!==null&&((X==="le"||X==="be")&&(U=X,X=10),this._init($||0,X||10,U||"be"))}typeof R=="object"?R.exports=q:M.BN=q,q.BN=q,q.wordSize=26;var Y;try{typeof window<"u"&&typeof window.Buffer<"u"?Y=window.Buffer:Y=JV().Buffer}catch{}q.isBN=function($){return $ instanceof q?!0:$!==null&&typeof $=="object"&&$.constructor.wordSize===q.wordSize&&Array.isArray($.words)},q.max=function($,X){return $.cmp(X)>0?$:X},q.min=function($,X){return $.cmp(X)<0?$:X},q.prototype._init=function($,X,U){if(typeof $=="number")return this._initNumber($,X,U);if(typeof $=="object")return this._initArray($,X,U);X==="hex"&&(X=16),B(X===(X|0)&&X>=2&&X<=36),$=$.toString().replace(/\s+/g,"");var H=0;$[0]==="-"&&(H++,this.negative=1),H<$.length&&(X===16?this._parseHex($,H,U):(this._parseBase($,X,H),U==="le"&&this._initArray(this.toArray(),X,U)))},q.prototype._initNumber=function($,X,U){$<0&&(this.negative=1,$=-$),$<67108864?(this.words=[$&67108863],this.length=1):$<4503599627370496?(this.words=[$&67108863,$/67108864&67108863],this.length=2):(B($<9007199254740992),this.words=[$&67108863,$/67108864&67108863,1],this.length=3),U==="le"&&this._initArray(this.toArray(),X,U)},q.prototype._initArray=function($,X,U){if(B(typeof $.length=="number"),$.length<=0)return this.words=[0],this.length=1,this;this.length=Math.ceil($.length/3),this.words=new Array(this.length);for(var H=0;H<this.length;H++)this.words[H]=0;var G,Q,K=0;if(U==="be")for(H=$.length-1,G=0;H>=0;H-=3)Q=$[H]|$[H-1]<<8|$[H-2]<<16,this.words[G]|=Q<<K&67108863,this.words[G+1]=Q>>>26-K&67108863,K+=24,K>=26&&(K-=26,G++);else if(U==="le")for(H=0,G=0;H<$.length;H+=3)Q=$[H]|$[H+1]<<8|$[H+2]<<16,this.words[G]|=Q<<K&67108863,this.words[G+1]=Q>>>26-K&67108863,K+=24,K>=26&&(K-=26,G++);return this._strip()};function E($,X){var U=$.charCodeAt(X);if(U>=48&&U<=57)return U-48;if(U>=65&&U<=70)return U-55;if(U>=97&&U<=102)return U-87;B(!1,"Invalid character in "+$)}function O($,X,U){var H=E($,U);return U-1>=X&&(H|=E($,U-1)<<4),H}q.prototype._parseHex=function($,X,U){this.length=Math.ceil(($.length-X)/6),this.words=new Array(this.length);for(var H=0;H<this.length;H++)this.words[H]=0;var G=0,Q=0,K;if(U==="be")for(H=$.length-1;H>=X;H-=2)K=O($,X,H)<<G,this.words[Q]|=K&67108863,G>=18?(G-=18,Q+=1,this.words[Q]|=K>>>26):G+=8;else{var k=$.length-X;for(H=k%2===0?X+1:X;H<$.length;H+=2)K=O($,X,H)<<G,this.words[Q]|=K&67108863,G>=18?(G-=18,Q+=1,this.words[Q]|=K>>>26):G+=8}this._strip()};function N($,X,U,H){for(var G=0,Q=0,K=Math.min($.length,U),k=X;k<K;k++){var L=$.charCodeAt(k)-48;G*=H,L>=49?Q=L-49+10:L>=17?Q=L-17+10:Q=L,B(L>=0&&Q<H,"Invalid character"),G+=Q}return G}q.prototype._parseBase=function($,X,U){this.words=[0],this.length=1;for(var H=0,G=1;G<=67108863;G*=X)H++;H--,G=G/X|0;for(var Q=$.length-U,K=Q%H,k=Math.min(Q,Q-K)+U,L=0,_=U;_<k;_+=H)L=N($,_,_+H,X),this.imuln(G),this.words[0]+L<67108864?this.words[0]+=L:this._iaddn(L);if(K!==0){var t=1;for(L=N($,_,$.length,X),_=0;_<K;_++)t*=X;this.imuln(t),this.words[0]+L<67108864?this.words[0]+=L:this._iaddn(L)}this._strip()},q.prototype.copy=function($){$.words=new Array(this.length);for(var X=0;X<this.length;X++)$.words[X]=this.words[X];$.length=this.length,$.negative=this.negative,$.red=this.red};function W($,X){$.words=X.words,$.length=X.length,$.negative=X.negative,$.red=X.red}if(q.prototype._move=function($){W($,this)},q.prototype.clone=function(){var $=new q(null);return this.copy($),$},q.prototype._expand=function($){for(;this.length<$;)this.words[this.length++]=0;return this},q.prototype._strip=function(){for(;this.length>1&&this.words[this.length-1]===0;)this.length--;return this._normSign()},q.prototype._normSign=function(){return this.length===1&&this.words[0]===0&&(this.negative=0),this},typeof Symbol<"u"&&typeof Symbol.for=="function")try{q.prototype[Symbol.for("nodejs.util.inspect.custom")]=I}catch{q.prototype.inspect=I}else q.prototype.inspect=I;function I(){return(this.red?"<BN-R: ":"<BN: ")+this.toString(16)+">"}var z=["","0","00","000","0000","00000","000000","0000000","00000000","000000000","0000000000","00000000000","000000000000","0000000000000","00000000000000","000000000000000","0000000000000000","00000000000000000","000000000000000000","0000000000000000000","00000000000000000000","000000000000000000000","0000000000000000000000","00000000000000000000000","000000000000000000000000","0000000000000000000000000"],j=[0,0,25,16,12,11,10,9,8,8,7,7,7,7,6,6,6,6,6,6,6,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5],P=[0,0,33554432,43046721,16777216,48828125,60466176,40353607,16777216,43046721,1e7,19487171,35831808,62748517,7529536,11390625,16777216,24137569,34012224,47045881,64000000,4084101,5153632,6436343,7962624,9765625,11881376,14348907,17210368,20511149,24300000,28629151,33554432,39135393,45435424,52521875,60466176];q.prototype.toString=function($,X){$=$||10,X=X|0||1;var U;if($===16||$==="hex"){U="";for(var H=0,G=0,Q=0;Q<this.length;Q++){var K=this.words[Q],k=((K<<H|G)&16777215).toString(16);G=K>>>24-H&16777215,H+=2,H>=26&&(H-=26,Q--),G!==0||Q!==this.length-1?U=z[6-k.length]+k+U:U=k+U}for(G!==0&&(U=G.toString(16)+U);U.length%X!==0;)U="0"+U;return this.negative!==0&&(U="-"+U),U}if($===($|0)&&$>=2&&$<=36){var L=j[$],_=P[$];U="";var t=this.clone();for(t.negative=0;!t.isZero();){var QJ=t.modrn(_).toString($);t=t.idivn(_),t.isZero()?U=QJ+U:U=z[L-QJ.length]+QJ+U}for(this.isZero()&&(U="0"+U);U.length%X!==0;)U="0"+U;return this.negative!==0&&(U="-"+U),U}B(!1,"Base should be between 2 and 36")},q.prototype.toNumber=function(){var $=this.words[0];return this.length===2?$+=this.words[1]*67108864:this.length===3&&this.words[2]===1?$+=4503599627370496+this.words[1]*67108864:this.length>2&&B(!1,"Number can only safely store up to 53 bits"),this.negative!==0?-$:$},q.prototype.toJSON=function(){return this.toString(16,2)},Y&&(q.prototype.toBuffer=function($,X){return this.toArrayLike(Y,$,X)}),q.prototype.toArray=function($,X){return this.toArrayLike(Array,$,X)};var F=function($,X){return $.allocUnsafe?$.allocUnsafe(X):new $(X)};q.prototype.toArrayLike=function($,X,U){this._strip();var H=this.byteLength(),G=U||Math.max(1,H);B(H<=G,"byte array longer than desired length"),B(G>0,"Requested array length <= 0");var Q=F($,G),K=X==="le"?"LE":"BE";return this["_toArrayLike"+K](Q,H),Q},q.prototype._toArrayLikeLE=function($,X){for(var U=0,H=0,G=0,Q=0;G<this.length;G++){var K=this.words[G]<<Q|H;$[U++]=K&255,U<$.length&&($[U++]=K>>8&255),U<$.length&&($[U++]=K>>16&255),Q===6?(U<$.length&&($[U++]=K>>24&255),H=0,Q=0):(H=K>>>24,Q+=2)}if(U<$.length)for($[U++]=H;U<$.length;)$[U++]=0},q.prototype._toArrayLikeBE=function($,X){for(var U=$.length-1,H=0,G=0,Q=0;G<this.length;G++){var K=this.words[G]<<Q|H;$[U--]=K&255,U>=0&&($[U--]=K>>8&255),U>=0&&($[U--]=K>>16&255),Q===6?(U>=0&&($[U--]=K>>24&255),H=0,Q=0):(H=K>>>24,Q+=2)}if(U>=0)for($[U--]=H;U>=0;)$[U--]=0},Math.clz32?q.prototype._countBits=function($){return 32-Math.clz32($)}:q.prototype._countBits=function($){var X=$,U=0;return X>=4096&&(U+=13,X>>>=13),X>=64&&(U+=7,X>>>=7),X>=8&&(U+=4,X>>>=4),X>=2&&(U+=2,X>>>=2),U+X},q.prototype._zeroBits=function($){if($===0)return 26;var X=$,U=0;return(X&8191)===0&&(U+=13,X>>>=13),(X&127)===0&&(U+=7,X>>>=7),(X&15)===0&&(U+=4,X>>>=4),(X&3)===0&&(U+=2,X>>>=2),(X&1)===0&&U++,U},q.prototype.bitLength=function(){var $=this.words[this.length-1],X=this._countBits($);return(this.length-1)*26+X};function v($){for(var X=new Array($.bitLength()),U=0;U<X.length;U++){var H=U/26|0,G=U%26;X[U]=$.words[H]>>>G&1}return X}q.prototype.zeroBits=function(){if(this.isZero())return 0;for(var $=0,X=0;X<this.length;X++){var U=this._zeroBits(this.words[X]);if($+=U,U!==26)break}return $},q.prototype.byteLength=function(){return Math.ceil(this.bitLength()/8)},q.prototype.toTwos=function($){return this.negative!==0?this.abs().inotn($).iaddn(1):this.clone()},q.prototype.fromTwos=function($){return this.testn($-1)?this.notn($).iaddn(1).ineg():this.clone()},q.prototype.isNeg=function(){return this.negative!==0},q.prototype.neg=function(){return this.clone().ineg()},q.prototype.ineg=function(){return this.isZero()||(this.negative^=1),this},q.prototype.iuor=function($){for(;this.length<$.length;)this.words[this.length++]=0;for(var X=0;X<$.length;X++)this.words[X]=this.words[X]|$.words[X];return this._strip()},q.prototype.ior=function($){return B((this.negative|$.negative)===0),this.iuor($)},q.prototype.or=function($){return this.length>$.length?this.clone().ior($):$.clone().ior(this)},q.prototype.uor=function($){return this.length>$.length?this.clone().iuor($):$.clone().iuor(this)},q.prototype.iuand=function($){var X;this.length>$.length?X=$:X=this;for(var U=0;U<X.length;U++)this.words[U]=this.words[U]&$.words[U];return this.length=X.length,this._strip()},q.prototype.iand=function($){return B((this.negative|$.negative)===0),this.iuand($)},q.prototype.and=function($){return this.length>$.length?this.clone().iand($):$.clone().iand(this)},q.prototype.uand=function($){return this.length>$.length?this.clone().iuand($):$.clone().iuand(this)},q.prototype.iuxor=function($){var X,U;this.length>$.length?(X=this,U=$):(X=$,U=this);for(var H=0;H<U.length;H++)this.words[H]=X.words[H]^U.words[H];if(this!==X)for(;H<X.length;H++)this.words[H]=X.words[H];return this.length=X.length,this._strip()},q.prototype.ixor=function($){return B((this.negative|$.negative)===0),this.iuxor($)},q.prototype.xor=function($){return this.length>$.length?this.clone().ixor($):$.clone().ixor(this)},q.prototype.uxor=function($){return this.length>$.length?this.clone().iuxor($):$.clone().iuxor(this)},q.prototype.inotn=function($){B(typeof $=="number"&&$>=0);var X=Math.ceil($/26)|0,U=$%26;this._expand(X),U>0&&X--;for(var H=0;H<X;H++)this.words[H]=~this.words[H]&67108863;return U>0&&(this.words[H]=~this.words[H]&67108863>>26-U),this._strip()},q.prototype.notn=function($){return this.clone().inotn($)},q.prototype.setn=function($,X){B(typeof $=="number"&&$>=0);var U=$/26|0,H=$%26;return this._expand(U+1),X?this.words[U]=this.words[U]|1<<H:this.words[U]=this.words[U]&~(1<<H),this._strip()},q.prototype.iadd=function($){var X;if(this.negative!==0&&$.negative===0)return this.negative=0,X=this.isub($),this.negative^=1,this._normSign();if(this.negative===0&&$.negative!==0)return $.negative=0,X=this.isub($),$.negative=1,X._normSign();var U,H;this.length>$.length?(U=this,H=$):(U=$,H=this);for(var G=0,Q=0;Q<H.length;Q++)X=(U.words[Q]|0)+(H.words[Q]|0)+G,this.words[Q]=X&67108863,G=X>>>26;for(;G!==0&&Q<U.length;Q++)X=(U.words[Q]|0)+G,this.words[Q]=X&67108863,G=X>>>26;if(this.length=U.length,G!==0)this.words[this.length]=G,this.length++;else if(U!==this)for(;Q<U.length;Q++)this.words[Q]=U.words[Q];return this},q.prototype.add=function($){var X;return $.negative!==0&&this.negative===0?($.negative=0,X=this.sub($),$.negative^=1,X):$.negative===0&&this.negative!==0?(this.negative=0,X=$.sub(this),this.negative=1,X):this.length>$.length?this.clone().iadd($):$.clone().iadd(this)},q.prototype.isub=function($){if($.negative!==0){$.negative=0;var X=this.iadd($);return $.negative=1,X._normSign()}else if(this.negative!==0)return this.negative=0,this.iadd($),this.negative=1,this._normSign();var U=this.cmp($);if(U===0)return this.negative=0,this.length=1,this.words[0]=0,this;var H,G;U>0?(H=this,G=$):(H=$,G=this);for(var Q=0,K=0;K<G.length;K++)X=(H.words[K]|0)-(G.words[K]|0)+Q,Q=X>>26,this.words[K]=X&67108863;for(;Q!==0&&K<H.length;K++)X=(H.words[K]|0)+Q,Q=X>>26,this.words[K]=X&67108863;if(Q===0&&K<H.length&&H!==this)for(;K<H.length;K++)this.words[K]=H.words[K];return this.length=Math.max(this.length,K),H!==this&&(this.negative=1),this._strip()},q.prototype.sub=function($){return this.clone().isub($)};function S($,X,U){U.negative=X.negative^$.negative;var H=$.length+X.length|0;U.length=H,H=H-1|0;var G=$.words[0]|0,Q=X.words[0]|0,K=G*Q,k=K&67108863,L=K/67108864|0;U.words[0]=k;for(var _=1;_<H;_++){for(var t=L>>>26,QJ=L&67108863,GJ=Math.min(_,X.length-1),n=Math.max(0,_-$.length+1);n<=GJ;n++){var p=_-n|0;G=$.words[p]|0,Q=X.words[n]|0,K=G*Q+QJ,t+=K/67108864|0,QJ=K&67108863}U.words[_]=QJ|0,L=t|0}return L!==0?U.words[_]=L|0:U.length--,U._strip()}var w=function($,X,U){var H=$.words,G=X.words,Q=U.words,K=0,k,L,_,t=H[0]|0,QJ=t&8191,GJ=t>>>13,n=H[1]|0,p=n&8191,e=n>>>13,PJ=H[2]|0,XJ=PJ&8191,WJ=PJ>>>13,b=H[3]|0,C=b&8191,h=b>>>13,$J=H[4]|0,qJ=$J&8191,ZJ=$J>>>13,mJ=H[5]|0,BJ=mJ&8191,TJ=mJ>>>13,dJ=H[6]|0,LJ=dJ&8191,IJ=dJ>>>13,$Q=H[7]|0,T=$Q&8191,D=$Q>>>13,u=H[8]|0,d=u&8191,a=u>>>13,CJ=H[9]|0,UJ=CJ&8191,EJ=CJ>>>13,QQ=G[0]|0,FJ=QQ&8191,RJ=QQ>>>13,aJ=G[1]|0,SJ=aJ&8191,xJ=aJ>>>13,nJ=G[2]|0,AJ=nJ&8191,kJ=nJ>>>13,ZQ=G[3]|0,vJ=ZQ&8191,MJ=ZQ>>>13,xQ=G[4]|0,wJ=xQ&8191,bJ=xQ>>>13,WQ=G[5]|0,_J=WQ&8191,NJ=WQ>>>13,vQ=G[6]|0,yJ=vQ&8191,gJ=vQ>>>13,MQ=G[7]|0,cJ=MQ&8191,fJ=MQ>>>13,wQ=G[8]|0,f=wQ&8191,zJ=wQ>>>13,CQ=G[9]|0,oJ=CQ&8191,tJ=CQ>>>13;U.negative=$.negative^X.negative,U.length=19,k=Math.imul(QJ,FJ),L=Math.imul(QJ,RJ),L=L+Math.imul(GJ,FJ)|0,_=Math.imul(GJ,RJ);var YQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(YQ>>>26)|0,YQ&=67108863,k=Math.imul(p,FJ),L=Math.imul(p,RJ),L=L+Math.imul(e,FJ)|0,_=Math.imul(e,RJ),k=k+Math.imul(QJ,SJ)|0,L=L+Math.imul(QJ,xJ)|0,L=L+Math.imul(GJ,SJ)|0,_=_+Math.imul(GJ,xJ)|0;var BQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(BQ>>>26)|0,BQ&=67108863,k=Math.imul(XJ,FJ),L=Math.imul(XJ,RJ),L=L+Math.imul(WJ,FJ)|0,_=Math.imul(WJ,RJ),k=k+Math.imul(p,SJ)|0,L=L+Math.imul(p,xJ)|0,L=L+Math.imul(e,SJ)|0,_=_+Math.imul(e,xJ)|0,k=k+Math.imul(QJ,AJ)|0,L=L+Math.imul(QJ,kJ)|0,L=L+Math.imul(GJ,AJ)|0,_=_+Math.imul(GJ,kJ)|0;var OQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(OQ>>>26)|0,OQ&=67108863,k=Math.imul(C,FJ),L=Math.imul(C,RJ),L=L+Math.imul(h,FJ)|0,_=Math.imul(h,RJ),k=k+Math.imul(XJ,SJ)|0,L=L+Math.imul(XJ,xJ)|0,L=L+Math.imul(WJ,SJ)|0,_=_+Math.imul(WJ,xJ)|0,k=k+Math.imul(p,AJ)|0,L=L+Math.imul(p,kJ)|0,L=L+Math.imul(e,AJ)|0,_=_+Math.imul(e,kJ)|0,k=k+Math.imul(QJ,vJ)|0,L=L+Math.imul(QJ,MJ)|0,L=L+Math.imul(GJ,vJ)|0,_=_+Math.imul(GJ,MJ)|0;var jQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(jQ>>>26)|0,jQ&=67108863,k=Math.imul(qJ,FJ),L=Math.imul(qJ,RJ),L=L+Math.imul(ZJ,FJ)|0,_=Math.imul(ZJ,RJ),k=k+Math.imul(C,SJ)|0,L=L+Math.imul(C,xJ)|0,L=L+Math.imul(h,SJ)|0,_=_+Math.imul(h,xJ)|0,k=k+Math.imul(XJ,AJ)|0,L=L+Math.imul(XJ,kJ)|0,L=L+Math.imul(WJ,AJ)|0,_=_+Math.imul(WJ,kJ)|0,k=k+Math.imul(p,vJ)|0,L=L+Math.imul(p,MJ)|0,L=L+Math.imul(e,vJ)|0,_=_+Math.imul(e,MJ)|0,k=k+Math.imul(QJ,wJ)|0,L=L+Math.imul(QJ,bJ)|0,L=L+Math.imul(GJ,wJ)|0,_=_+Math.imul(GJ,bJ)|0;var TQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(TQ>>>26)|0,TQ&=67108863,k=Math.imul(BJ,FJ),L=Math.imul(BJ,RJ),L=L+Math.imul(TJ,FJ)|0,_=Math.imul(TJ,RJ),k=k+Math.imul(qJ,SJ)|0,L=L+Math.imul(qJ,xJ)|0,L=L+Math.imul(ZJ,SJ)|0,_=_+Math.imul(ZJ,xJ)|0,k=k+Math.imul(C,AJ)|0,L=L+Math.imul(C,kJ)|0,L=L+Math.imul(h,AJ)|0,_=_+Math.imul(h,kJ)|0,k=k+Math.imul(XJ,vJ)|0,L=L+Math.imul(XJ,MJ)|0,L=L+Math.imul(WJ,vJ)|0,_=_+Math.imul(WJ,MJ)|0,k=k+Math.imul(p,wJ)|0,L=L+Math.imul(p,bJ)|0,L=L+Math.imul(e,wJ)|0,_=_+Math.imul(e,bJ)|0,k=k+Math.imul(QJ,_J)|0,L=L+Math.imul(QJ,NJ)|0,L=L+Math.imul(GJ,_J)|0,_=_+Math.imul(GJ,NJ)|0;var NQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(NQ>>>26)|0,NQ&=67108863,k=Math.imul(LJ,FJ),L=Math.imul(LJ,RJ),L=L+Math.imul(IJ,FJ)|0,_=Math.imul(IJ,RJ),k=k+Math.imul(BJ,SJ)|0,L=L+Math.imul(BJ,xJ)|0,L=L+Math.imul(TJ,SJ)|0,_=_+Math.imul(TJ,xJ)|0,k=k+Math.imul(qJ,AJ)|0,L=L+Math.imul(qJ,kJ)|0,L=L+Math.imul(ZJ,AJ)|0,_=_+Math.imul(ZJ,kJ)|0,k=k+Math.imul(C,vJ)|0,L=L+Math.imul(C,MJ)|0,L=L+Math.imul(h,vJ)|0,_=_+Math.imul(h,MJ)|0,k=k+Math.imul(XJ,wJ)|0,L=L+Math.imul(XJ,bJ)|0,L=L+Math.imul(WJ,wJ)|0,_=_+Math.imul(WJ,bJ)|0,k=k+Math.imul(p,_J)|0,L=L+Math.imul(p,NJ)|0,L=L+Math.imul(e,_J)|0,_=_+Math.imul(e,NJ)|0,k=k+Math.imul(QJ,yJ)|0,L=L+Math.imul(QJ,gJ)|0,L=L+Math.imul(GJ,yJ)|0,_=_+Math.imul(GJ,gJ)|0;var IQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(IQ>>>26)|0,IQ&=67108863,k=Math.imul(T,FJ),L=Math.imul(T,RJ),L=L+Math.imul(D,FJ)|0,_=Math.imul(D,RJ),k=k+Math.imul(LJ,SJ)|0,L=L+Math.imul(LJ,xJ)|0,L=L+Math.imul(IJ,SJ)|0,_=_+Math.imul(IJ,xJ)|0,k=k+Math.imul(BJ,AJ)|0,L=L+Math.imul(BJ,kJ)|0,L=L+Math.imul(TJ,AJ)|0,_=_+Math.imul(TJ,kJ)|0,k=k+Math.imul(qJ,vJ)|0,L=L+Math.imul(qJ,MJ)|0,L=L+Math.imul(ZJ,vJ)|0,_=_+Math.imul(ZJ,MJ)|0,k=k+Math.imul(C,wJ)|0,L=L+Math.imul(C,bJ)|0,L=L+Math.imul(h,wJ)|0,_=_+Math.imul(h,bJ)|0,k=k+Math.imul(XJ,_J)|0,L=L+Math.imul(XJ,NJ)|0,L=L+Math.imul(WJ,_J)|0,_=_+Math.imul(WJ,NJ)|0,k=k+Math.imul(p,yJ)|0,L=L+Math.imul(p,gJ)|0,L=L+Math.imul(e,yJ)|0,_=_+Math.imul(e,gJ)|0,k=k+Math.imul(QJ,cJ)|0,L=L+Math.imul(QJ,fJ)|0,L=L+Math.imul(GJ,cJ)|0,_=_+Math.imul(GJ,fJ)|0;var EQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(EQ>>>26)|0,EQ&=67108863,k=Math.imul(d,FJ),L=Math.imul(d,RJ),L=L+Math.imul(a,FJ)|0,_=Math.imul(a,RJ),k=k+Math.imul(T,SJ)|0,L=L+Math.imul(T,xJ)|0,L=L+Math.imul(D,SJ)|0,_=_+Math.imul(D,xJ)|0,k=k+Math.imul(LJ,AJ)|0,L=L+Math.imul(LJ,kJ)|0,L=L+Math.imul(IJ,AJ)|0,_=_+Math.imul(IJ,kJ)|0,k=k+Math.imul(BJ,vJ)|0,L=L+Math.imul(BJ,MJ)|0,L=L+Math.imul(TJ,vJ)|0,_=_+Math.imul(TJ,MJ)|0,k=k+Math.imul(qJ,wJ)|0,L=L+Math.imul(qJ,bJ)|0,L=L+Math.imul(ZJ,wJ)|0,_=_+Math.imul(ZJ,bJ)|0,k=k+Math.imul(C,_J)|0,L=L+Math.imul(C,NJ)|0,L=L+Math.imul(h,_J)|0,_=_+Math.imul(h,NJ)|0,k=k+Math.imul(XJ,yJ)|0,L=L+Math.imul(XJ,gJ)|0,L=L+Math.imul(WJ,yJ)|0,_=_+Math.imul(WJ,gJ)|0,k=k+Math.imul(p,cJ)|0,L=L+Math.imul(p,fJ)|0,L=L+Math.imul(e,cJ)|0,_=_+Math.imul(e,fJ)|0,k=k+Math.imul(QJ,f)|0,L=L+Math.imul(QJ,zJ)|0,L=L+Math.imul(GJ,f)|0,_=_+Math.imul(GJ,zJ)|0;var RQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(RQ>>>26)|0,RQ&=67108863,k=Math.imul(UJ,FJ),L=Math.imul(UJ,RJ),L=L+Math.imul(EJ,FJ)|0,_=Math.imul(EJ,RJ),k=k+Math.imul(d,SJ)|0,L=L+Math.imul(d,xJ)|0,L=L+Math.imul(a,SJ)|0,_=_+Math.imul(a,xJ)|0,k=k+Math.imul(T,AJ)|0,L=L+Math.imul(T,kJ)|0,L=L+Math.imul(D,AJ)|0,_=_+Math.imul(D,kJ)|0,k=k+Math.imul(LJ,vJ)|0,L=L+Math.imul(LJ,MJ)|0,L=L+Math.imul(IJ,vJ)|0,_=_+Math.imul(IJ,MJ)|0,k=k+Math.imul(BJ,wJ)|0,L=L+Math.imul(BJ,bJ)|0,L=L+Math.imul(TJ,wJ)|0,_=_+Math.imul(TJ,bJ)|0,k=k+Math.imul(qJ,_J)|0,L=L+Math.imul(qJ,NJ)|0,L=L+Math.imul(ZJ,_J)|0,_=_+Math.imul(ZJ,NJ)|0,k=k+Math.imul(C,yJ)|0,L=L+Math.imul(C,gJ)|0,L=L+Math.imul(h,yJ)|0,_=_+Math.imul(h,gJ)|0,k=k+Math.imul(XJ,cJ)|0,L=L+Math.imul(XJ,fJ)|0,L=L+Math.imul(WJ,cJ)|0,_=_+Math.imul(WJ,fJ)|0,k=k+Math.imul(p,f)|0,L=L+Math.imul(p,zJ)|0,L=L+Math.imul(e,f)|0,_=_+Math.imul(e,zJ)|0,k=k+Math.imul(QJ,oJ)|0,L=L+Math.imul(QJ,tJ)|0,L=L+Math.imul(GJ,oJ)|0,_=_+Math.imul(GJ,tJ)|0;var zQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(zQ>>>26)|0,zQ&=67108863,k=Math.imul(UJ,SJ),L=Math.imul(UJ,xJ),L=L+Math.imul(EJ,SJ)|0,_=Math.imul(EJ,xJ),k=k+Math.imul(d,AJ)|0,L=L+Math.imul(d,kJ)|0,L=L+Math.imul(a,AJ)|0,_=_+Math.imul(a,kJ)|0,k=k+Math.imul(T,vJ)|0,L=L+Math.imul(T,MJ)|0,L=L+Math.imul(D,vJ)|0,_=_+Math.imul(D,MJ)|0,k=k+Math.imul(LJ,wJ)|0,L=L+Math.imul(LJ,bJ)|0,L=L+Math.imul(IJ,wJ)|0,_=_+Math.imul(IJ,bJ)|0,k=k+Math.imul(BJ,_J)|0,L=L+Math.imul(BJ,NJ)|0,L=L+Math.imul(TJ,_J)|0,_=_+Math.imul(TJ,NJ)|0,k=k+Math.imul(qJ,yJ)|0,L=L+Math.imul(qJ,gJ)|0,L=L+Math.imul(ZJ,yJ)|0,_=_+Math.imul(ZJ,gJ)|0,k=k+Math.imul(C,cJ)|0,L=L+Math.imul(C,fJ)|0,L=L+Math.imul(h,cJ)|0,_=_+Math.imul(h,fJ)|0,k=k+Math.imul(XJ,f)|0,L=L+Math.imul(XJ,zJ)|0,L=L+Math.imul(WJ,f)|0,_=_+Math.imul(WJ,zJ)|0,k=k+Math.imul(p,oJ)|0,L=L+Math.imul(p,tJ)|0,L=L+Math.imul(e,oJ)|0,_=_+Math.imul(e,tJ)|0;var PQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(PQ>>>26)|0,PQ&=67108863,k=Math.imul(UJ,AJ),L=Math.imul(UJ,kJ),L=L+Math.imul(EJ,AJ)|0,_=Math.imul(EJ,kJ),k=k+Math.imul(d,vJ)|0,L=L+Math.imul(d,MJ)|0,L=L+Math.imul(a,vJ)|0,_=_+Math.imul(a,MJ)|0,k=k+Math.imul(T,wJ)|0,L=L+Math.imul(T,bJ)|0,L=L+Math.imul(D,wJ)|0,_=_+Math.imul(D,bJ)|0,k=k+Math.imul(LJ,_J)|0,L=L+Math.imul(LJ,NJ)|0,L=L+Math.imul(IJ,_J)|0,_=_+Math.imul(IJ,NJ)|0,k=k+Math.imul(BJ,yJ)|0,L=L+Math.imul(BJ,gJ)|0,L=L+Math.imul(TJ,yJ)|0,_=_+Math.imul(TJ,gJ)|0,k=k+Math.imul(qJ,cJ)|0,L=L+Math.imul(qJ,fJ)|0,L=L+Math.imul(ZJ,cJ)|0,_=_+Math.imul(ZJ,fJ)|0,k=k+Math.imul(C,f)|0,L=L+Math.imul(C,zJ)|0,L=L+Math.imul(h,f)|0,_=_+Math.imul(h,zJ)|0,k=k+Math.imul(XJ,oJ)|0,L=L+Math.imul(XJ,tJ)|0,L=L+Math.imul(WJ,oJ)|0,_=_+Math.imul(WJ,tJ)|0;var LQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(LQ>>>26)|0,LQ&=67108863,k=Math.imul(UJ,vJ),L=Math.imul(UJ,MJ),L=L+Math.imul(EJ,vJ)|0,_=Math.imul(EJ,MJ),k=k+Math.imul(d,wJ)|0,L=L+Math.imul(d,bJ)|0,L=L+Math.imul(a,wJ)|0,_=_+Math.imul(a,bJ)|0,k=k+Math.imul(T,_J)|0,L=L+Math.imul(T,NJ)|0,L=L+Math.imul(D,_J)|0,_=_+Math.imul(D,NJ)|0,k=k+Math.imul(LJ,yJ)|0,L=L+Math.imul(LJ,gJ)|0,L=L+Math.imul(IJ,yJ)|0,_=_+Math.imul(IJ,gJ)|0,k=k+Math.imul(BJ,cJ)|0,L=L+Math.imul(BJ,fJ)|0,L=L+Math.imul(TJ,cJ)|0,_=_+Math.imul(TJ,fJ)|0,k=k+Math.imul(qJ,f)|0,L=L+Math.imul(qJ,zJ)|0,L=L+Math.imul(ZJ,f)|0,_=_+Math.imul(ZJ,zJ)|0,k=k+Math.imul(C,oJ)|0,L=L+Math.imul(C,tJ)|0,L=L+Math.imul(h,oJ)|0,_=_+Math.imul(h,tJ)|0;var FQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(FQ>>>26)|0,FQ&=67108863,k=Math.imul(UJ,wJ),L=Math.imul(UJ,bJ),L=L+Math.imul(EJ,wJ)|0,_=Math.imul(EJ,bJ),k=k+Math.imul(d,_J)|0,L=L+Math.imul(d,NJ)|0,L=L+Math.imul(a,_J)|0,_=_+Math.imul(a,NJ)|0,k=k+Math.imul(T,yJ)|0,L=L+Math.imul(T,gJ)|0,L=L+Math.imul(D,yJ)|0,_=_+Math.imul(D,gJ)|0,k=k+Math.imul(LJ,cJ)|0,L=L+Math.imul(LJ,fJ)|0,L=L+Math.imul(IJ,cJ)|0,_=_+Math.imul(IJ,fJ)|0,k=k+Math.imul(BJ,f)|0,L=L+Math.imul(BJ,zJ)|0,L=L+Math.imul(TJ,f)|0,_=_+Math.imul(TJ,zJ)|0,k=k+Math.imul(qJ,oJ)|0,L=L+Math.imul(qJ,tJ)|0,L=L+Math.imul(ZJ,oJ)|0,_=_+Math.imul(ZJ,tJ)|0;var HQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(HQ>>>26)|0,HQ&=67108863,k=Math.imul(UJ,_J),L=Math.imul(UJ,NJ),L=L+Math.imul(EJ,_J)|0,_=Math.imul(EJ,NJ),k=k+Math.imul(d,yJ)|0,L=L+Math.imul(d,gJ)|0,L=L+Math.imul(a,yJ)|0,_=_+Math.imul(a,gJ)|0,k=k+Math.imul(T,cJ)|0,L=L+Math.imul(T,fJ)|0,L=L+Math.imul(D,cJ)|0,_=_+Math.imul(D,fJ)|0,k=k+Math.imul(LJ,f)|0,L=L+Math.imul(LJ,zJ)|0,L=L+Math.imul(IJ,f)|0,_=_+Math.imul(IJ,zJ)|0,k=k+Math.imul(BJ,oJ)|0,L=L+Math.imul(BJ,tJ)|0,L=L+Math.imul(TJ,oJ)|0,_=_+Math.imul(TJ,tJ)|0;var DQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(DQ>>>26)|0,DQ&=67108863,k=Math.imul(UJ,yJ),L=Math.imul(UJ,gJ),L=L+Math.imul(EJ,yJ)|0,_=Math.imul(EJ,gJ),k=k+Math.imul(d,cJ)|0,L=L+Math.imul(d,fJ)|0,L=L+Math.imul(a,cJ)|0,_=_+Math.imul(a,fJ)|0,k=k+Math.imul(T,f)|0,L=L+Math.imul(T,zJ)|0,L=L+Math.imul(D,f)|0,_=_+Math.imul(D,zJ)|0,k=k+Math.imul(LJ,oJ)|0,L=L+Math.imul(LJ,tJ)|0,L=L+Math.imul(IJ,oJ)|0,_=_+Math.imul(IJ,tJ)|0;var KQ=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(KQ>>>26)|0,KQ&=67108863,k=Math.imul(UJ,cJ),L=Math.imul(UJ,fJ),L=L+Math.imul(EJ,cJ)|0,_=Math.imul(EJ,fJ),k=k+Math.imul(d,f)|0,L=L+Math.imul(d,zJ)|0,L=L+Math.imul(a,f)|0,_=_+Math.imul(a,zJ)|0,k=k+Math.imul(T,oJ)|0,L=L+Math.imul(T,tJ)|0,L=L+Math.imul(D,oJ)|0,_=_+Math.imul(D,tJ)|0;var TV=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(TV>>>26)|0,TV&=67108863,k=Math.imul(UJ,f),L=Math.imul(UJ,zJ),L=L+Math.imul(EJ,f)|0,_=Math.imul(EJ,zJ),k=k+Math.imul(d,oJ)|0,L=L+Math.imul(d,tJ)|0,L=L+Math.imul(a,oJ)|0,_=_+Math.imul(a,tJ)|0;var NV=(K+k|0)+((L&8191)<<13)|0;K=(_+(L>>>13)|0)+(NV>>>26)|0,NV&=67108863,k=Math.imul(UJ,oJ),L=Math.imul(UJ,tJ),L=L+Math.imul(EJ,oJ)|0,_=Math.imul(EJ,tJ);var IV=(K+k|0)+((L&8191)<<13)|0;return K=(_+(L>>>13)|0)+(IV>>>26)|0,IV&=67108863,Q[0]=YQ,Q[1]=BQ,Q[2]=OQ,Q[3]=jQ,Q[4]=TQ,Q[5]=NQ,Q[6]=IQ,Q[7]=EQ,Q[8]=RQ,Q[9]=zQ,Q[10]=PQ,Q[11]=LQ,Q[12]=FQ,Q[13]=HQ,Q[14]=DQ,Q[15]=KQ,Q[16]=TV,Q[17]=NV,Q[18]=IV,K!==0&&(Q[19]=K,U.length++),U};Math.imul||(w=S);function y($,X,U){U.negative=X.negative^$.negative,U.length=$.length+X.length;for(var H=0,G=0,Q=0;Q<U.length-1;Q++){var K=G;G=0;for(var k=H&67108863,L=Math.min(Q,X.length-1),_=Math.max(0,Q-$.length+1);_<=L;_++){var t=Q-_,QJ=$.words[t]|0,GJ=X.words[_]|0,n=QJ*GJ,p=n&67108863;K=K+(n/67108864|0)|0,p=p+k|0,k=p&67108863,K=K+(p>>>26)|0,G+=K>>>26,K&=67108863}U.words[Q]=k,H=K,K=G}return H!==0?U.words[Q]=H:U.length--,U._strip()}function m($,X,U){return y($,X,U)}q.prototype.mulTo=function($,X){var U,H=this.length+$.length;return this.length===10&&$.length===10?U=w(this,$,X):H<63?U=S(this,$,X):H<1024?U=y(this,$,X):U=m(this,$,X),U};function i($,X){this.x=$,this.y=X}i.prototype.makeRBT=function($){for(var X=new Array($),U=q.prototype._countBits($)-1,H=0;H<$;H++)X[H]=this.revBin(H,U,$);return X},i.prototype.revBin=function($,X,U){if($===0||$===U-1)return $;for(var H=0,G=0;G<X;G++)H|=($&1)<<X-G-1,$>>=1;return H},i.prototype.permute=function($,X,U,H,G,Q){for(var K=0;K<Q;K++)H[K]=X[$[K]],G[K]=U[$[K]]},i.prototype.transform=function($,X,U,H,G,Q){this.permute(Q,$,X,U,H,G);for(var K=1;K<G;K<<=1)for(var k=K<<1,L=Math.cos(2*Math.PI/k),_=Math.sin(2*Math.PI/k),t=0;t<G;t+=k)for(var QJ=L,GJ=_,n=0;n<K;n++){var p=U[t+n],e=H[t+n],PJ=U[t+n+K],XJ=H[t+n+K],WJ=QJ*PJ-GJ*XJ;XJ=QJ*XJ+GJ*PJ,PJ=WJ,U[t+n]=p+PJ,H[t+n]=e+XJ,U[t+n+K]=p-PJ,H[t+n+K]=e-XJ,n!==k&&(WJ=L*QJ-_*GJ,GJ=L*GJ+_*QJ,QJ=WJ)}},i.prototype.guessLen13b=function($,X){var U=Math.max(X,$)|1,H=U&1,G=0;for(U=U/2|0;U;U=U>>>1)G++;return 1<<G+1+H},i.prototype.conjugate=function($,X,U){if(!(U<=1))for(var H=0;H<U/2;H++){var G=$[H];$[H]=$[U-H-1],$[U-H-1]=G,G=X[H],X[H]=-X[U-H-1],X[U-H-1]=-G}},i.prototype.normalize13b=function($,X){for(var U=0,H=0;H<X/2;H++){var G=Math.round($[2*H+1]/X)*8192+Math.round($[2*H]/X)+U;$[H]=G&67108863,G<67108864?U=0:U=G/67108864|0}return $},i.prototype.convert13b=function($,X,U,H){for(var G=0,Q=0;Q<X;Q++)G=G+($[Q]|0),U[2*Q]=G&8191,G=G>>>13,U[2*Q+1]=G&8191,G=G>>>13;for(Q=2*X;Q<H;++Q)U[Q]=0;B(G===0),B((G&-8192)===0)},i.prototype.stub=function($){for(var X=new Array($),U=0;U<$;U++)X[U]=0;return X},i.prototype.mulp=function($,X,U){var H=2*this.guessLen13b($.length,X.length),G=this.makeRBT(H),Q=this.stub(H),K=new Array(H),k=new Array(H),L=new Array(H),_=new Array(H),t=new Array(H),QJ=new Array(H),GJ=U.words;GJ.length=H,this.convert13b($.words,$.length,K,H),this.convert13b(X.words,X.length,_,H),this.transform(K,Q,k,L,H,G),this.transform(_,Q,t,QJ,H,G);for(var n=0;n<H;n++){var p=k[n]*t[n]-L[n]*QJ[n];L[n]=k[n]*QJ[n]+L[n]*t[n],k[n]=p}return this.conjugate(k,L,H),this.transform(k,L,GJ,Q,H,G),this.conjugate(GJ,Q,H),this.normalize13b(GJ,H),U.negative=$.negative^X.negative,U.length=$.length+X.length,U._strip()},q.prototype.mul=function($){var X=new q(null);return X.words=new Array(this.length+$.length),this.mulTo($,X)},q.prototype.mulf=function($){var X=new q(null);return X.words=new Array(this.length+$.length),m(this,$,X)},q.prototype.imul=function($){return this.clone().mulTo($,this)},q.prototype.imuln=function($){var X=$<0;X&&($=-$),B(typeof $=="number"),B($<67108864);for(var U=0,H=0;H<this.length;H++){var G=(this.words[H]|0)*$,Q=(G&67108863)+(U&67108863);U>>=26,U+=G/67108864|0,U+=Q>>>26,this.words[H]=Q&67108863}return U!==0&&(this.words[H]=U,this.length++),X?this.ineg():this},q.prototype.muln=function($){return this.clone().imuln($)},q.prototype.sqr=function(){return this.mul(this)},q.prototype.isqr=function(){return this.imul(this.clone())},q.prototype.pow=function($){var X=v($);if(X.length===0)return new q(1);for(var U=this,H=0;H<X.length&&X[H]===0;H++,U=U.sqr());if(++H<X.length)for(var G=U.sqr();H<X.length;H++,G=G.sqr())X[H]!==0&&(U=U.mul(G));return U},q.prototype.iushln=function($){B(typeof $=="number"&&$>=0);var X=$%26,U=($-X)/26,H=67108863>>>26-X<<26-X,G;if(X!==0){var Q=0;for(G=0;G<this.length;G++){var K=this.words[G]&H,k=(this.words[G]|0)-K<<X;this.words[G]=k|Q,Q=K>>>26-X}Q&&(this.words[G]=Q,this.length++)}if(U!==0){for(G=this.length-1;G>=0;G--)this.words[G+U]=this.words[G];for(G=0;G<U;G++)this.words[G]=0;this.length+=U}return this._strip()},q.prototype.ishln=function($){return B(this.negative===0),this.iushln($)},q.prototype.iushrn=function($,X,U){B(typeof $=="number"&&$>=0);var H;X?H=(X-X%26)/26:H=0;var G=$%26,Q=Math.min(($-G)/26,this.length),K=67108863^67108863>>>G<<G,k=U;if(H-=Q,H=Math.max(0,H),k){for(var L=0;L<Q;L++)k.words[L]=this.words[L];k.length=Q}if(Q!==0)if(this.length>Q)for(this.length-=Q,L=0;L<this.length;L++)this.words[L]=this.words[L+Q];else this.words[0]=0,this.length=1;var _=0;for(L=this.length-1;L>=0&&(_!==0||L>=H);L--){var t=this.words[L]|0;this.words[L]=_<<26-G|t>>>G,_=t&K}return k&&_!==0&&(k.words[k.length++]=_),this.length===0&&(this.words[0]=0,this.length=1),this._strip()},q.prototype.ishrn=function($,X,U){return B(this.negative===0),this.iushrn($,X,U)},q.prototype.shln=function($){return this.clone().ishln($)},q.prototype.ushln=function($){return this.clone().iushln($)},q.prototype.shrn=function($){return this.clone().ishrn($)},q.prototype.ushrn=function($){return this.clone().iushrn($)},q.prototype.testn=function($){B(typeof $=="number"&&$>=0);var X=$%26,U=($-X)/26,H=1<<X;if(this.length<=U)return!1;var G=this.words[U];return!!(G&H)},q.prototype.imaskn=function($){B(typeof $=="number"&&$>=0);var X=$%26,U=($-X)/26;if(B(this.negative===0,"imaskn works only with positive numbers"),this.length<=U)return this;if(X!==0&&U++,this.length=Math.min(U,this.length),X!==0){var H=67108863^67108863>>>X<<X;this.words[this.length-1]&=H}return this._strip()},q.prototype.maskn=function($){return this.clone().imaskn($)},q.prototype.iaddn=function($){return B(typeof $=="number"),B($<67108864),$<0?this.isubn(-$):this.negative!==0?this.length===1&&(this.words[0]|0)<=$?(this.words[0]=$-(this.words[0]|0),this.negative=0,this):(this.negative=0,this.isubn($),this.negative=1,this):this._iaddn($)},q.prototype._iaddn=function($){this.words[0]+=$;for(var X=0;X<this.length&&this.words[X]>=67108864;X++)this.words[X]-=67108864,X===this.length-1?this.words[X+1]=1:this.words[X+1]++;return this.length=Math.max(this.length,X+1),this},q.prototype.isubn=function($){if(B(typeof $=="number"),B($<67108864),$<0)return this.iaddn(-$);if(this.negative!==0)return this.negative=0,this.iaddn($),this.negative=1,this;if(this.words[0]-=$,this.length===1&&this.words[0]<0)this.words[0]=-this.words[0],this.negative=1;else for(var X=0;X<this.length&&this.words[X]<0;X++)this.words[X]+=67108864,this.words[X+1]-=1;return this._strip()},q.prototype.addn=function($){return this.clone().iaddn($)},q.prototype.subn=function($){return this.clone().isubn($)},q.prototype.iabs=function(){return this.negative=0,this},q.prototype.abs=function(){return this.clone().iabs()},q.prototype._ishlnsubmul=function($,X,U){var H=$.length+U,G;this._expand(H);var Q,K=0;for(G=0;G<$.length;G++){Q=(this.words[G+U]|0)+K;var k=($.words[G]|0)*X;Q-=k&67108863,K=(Q>>26)-(k/67108864|0),this.words[G+U]=Q&67108863}for(;G<this.length-U;G++)Q=(this.words[G+U]|0)+K,K=Q>>26,this.words[G+U]=Q&67108863;if(K===0)return this._strip();for(B(K===-1),K=0,G=0;G<this.length;G++)Q=-(this.words[G]|0)+K,K=Q>>26,this.words[G]=Q&67108863;return this.negative=1,this._strip()},q.prototype._wordDiv=function($,X){var U=this.length-$.length,H=this.clone(),G=$,Q=G.words[G.length-1]|0,K=this._countBits(Q);U=26-K,U!==0&&(G=G.ushln(U),H.iushln(U),Q=G.words[G.length-1]|0);var k=H.length-G.length,L;if(X!=="mod"){L=new q(null),L.length=k+1,L.words=new Array(L.length);for(var _=0;_<L.length;_++)L.words[_]=0}var t=H.clone()._ishlnsubmul(G,1,k);t.negative===0&&(H=t,L&&(L.words[k]=1));for(var QJ=k-1;QJ>=0;QJ--){var GJ=(H.words[G.length+QJ]|0)*67108864+(H.words[G.length+QJ-1]|0);for(GJ=Math.min(GJ/Q|0,67108863),H._ishlnsubmul(G,GJ,QJ);H.negative!==0;)GJ--,H.negative=0,H._ishlnsubmul(G,1,QJ),H.isZero()||(H.negative^=1);L&&(L.words[QJ]=GJ)}return L&&L._strip(),H._strip(),X!=="div"&&U!==0&&H.iushrn(U),{div:L||null,mod:H}},q.prototype.divmod=function($,X,U){if(B(!$.isZero()),this.isZero())return{div:new q(0),mod:new q(0)};var H,G,Q;return this.negative!==0&&$.negative===0?(Q=this.neg().divmod($,X),X!=="mod"&&(H=Q.div.neg()),X!=="div"&&(G=Q.mod.neg(),U&&G.negative!==0&&G.iadd($)),{div:H,mod:G}):this.negative===0&&$.negative!==0?(Q=this.divmod($.neg(),X),X!=="mod"&&(H=Q.div.neg()),{div:H,mod:Q.mod}):(this.negative&$.negative)!==0?(Q=this.neg().divmod($.neg(),X),X!=="div"&&(G=Q.mod.neg(),U&&G.negative!==0&&G.isub($)),{div:Q.div,mod:G}):$.length>this.length||this.cmp($)<0?{div:new q(0),mod:this}:$.length===1?X==="div"?{div:this.divn($.words[0]),mod:null}:X==="mod"?{div:null,mod:new q(this.modrn($.words[0]))}:{div:this.divn($.words[0]),mod:new q(this.modrn($.words[0]))}:this._wordDiv($,X)},q.prototype.div=function($){return this.divmod($,"div",!1).div},q.prototype.mod=function($){return this.divmod($,"mod",!1).mod},q.prototype.umod=function($){return this.divmod($,"mod",!0).mod},q.prototype.divRound=function($){var X=this.divmod($);if(X.mod.isZero())return X.div;var U=X.div.negative!==0?X.mod.isub($):X.mod,H=$.ushrn(1),G=$.andln(1),Q=U.cmp(H);return Q<0||G===1&&Q===0?X.div:X.div.negative!==0?X.div.isubn(1):X.div.iaddn(1)},q.prototype.modrn=function($){var X=$<0;X&&($=-$),B($<=67108863);for(var U=(1<<26)%$,H=0,G=this.length-1;G>=0;G--)H=(U*H+(this.words[G]|0))%$;return X?-H:H},q.prototype.modn=function($){return this.modrn($)},q.prototype.idivn=function($){var X=$<0;X&&($=-$),B($<=67108863);for(var U=0,H=this.length-1;H>=0;H--){var G=(this.words[H]|0)+U*67108864;this.words[H]=G/$|0,U=G%$}return this._strip(),X?this.ineg():this},q.prototype.divn=function($){return this.clone().idivn($)},q.prototype.egcd=function($){B($.negative===0),B(!$.isZero());var X=this,U=$.clone();X.negative!==0?X=X.umod($):X=X.clone();for(var H=new q(1),G=new q(0),Q=new q(0),K=new q(1),k=0;X.isEven()&&U.isEven();)X.iushrn(1),U.iushrn(1),++k;for(var L=U.clone(),_=X.clone();!X.isZero();){for(var t=0,QJ=1;(X.words[0]&QJ)===0&&t<26;++t,QJ<<=1);if(t>0)for(X.iushrn(t);t-- >0;)(H.isOdd()||G.isOdd())&&(H.iadd(L),G.isub(_)),H.iushrn(1),G.iushrn(1);for(var GJ=0,n=1;(U.words[0]&n)===0&&GJ<26;++GJ,n<<=1);if(GJ>0)for(U.iushrn(GJ);GJ-- >0;)(Q.isOdd()||K.isOdd())&&(Q.iadd(L),K.isub(_)),Q.iushrn(1),K.iushrn(1);X.cmp(U)>=0?(X.isub(U),H.isub(Q),G.isub(K)):(U.isub(X),Q.isub(H),K.isub(G))}return{a:Q,b:K,gcd:U.iushln(k)}},q.prototype._invmp=function($){B($.negative===0),B(!$.isZero());var X=this,U=$.clone();X.negative!==0?X=X.umod($):X=X.clone();for(var H=new q(1),G=new q(0),Q=U.clone();X.cmpn(1)>0&&U.cmpn(1)>0;){for(var K=0,k=1;(X.words[0]&k)===0&&K<26;++K,k<<=1);if(K>0)for(X.iushrn(K);K-- >0;)H.isOdd()&&H.iadd(Q),H.iushrn(1);for(var L=0,_=1;(U.words[0]&_)===0&&L<26;++L,_<<=1);if(L>0)for(U.iushrn(L);L-- >0;)G.isOdd()&&G.iadd(Q),G.iushrn(1);X.cmp(U)>=0?(X.isub(U),H.isub(G)):(U.isub(X),G.isub(H))}var t;return X.cmpn(1)===0?t=H:t=G,t.cmpn(0)<0&&t.iadd($),t},q.prototype.gcd=function($){if(this.isZero())return $.abs();if($.isZero())return this.abs();var X=this.clone(),U=$.clone();X.negative=0,U.negative=0;for(var H=0;X.isEven()&&U.isEven();H++)X.iushrn(1),U.iushrn(1);do{for(;X.isEven();)X.iushrn(1);for(;U.isEven();)U.iushrn(1);var G=X.cmp(U);if(G<0){var Q=X;X=U,U=Q}else if(G===0||U.cmpn(1)===0)break;X.isub(U)}while(!0);return U.iushln(H)},q.prototype.invm=function($){return this.egcd($).a.umod($)},q.prototype.isEven=function(){return(this.words[0]&1)===0},q.prototype.isOdd=function(){return(this.words[0]&1)===1},q.prototype.andln=function($){return this.words[0]&$},q.prototype.bincn=function($){B(typeof $=="number");var X=$%26,U=($-X)/26,H=1<<X;if(this.length<=U)return this._expand(U+1),this.words[U]|=H,this;for(var G=H,Q=U;G!==0&&Q<this.length;Q++){var K=this.words[Q]|0;K+=G,G=K>>>26,K&=67108863,this.words[Q]=K}return G!==0&&(this.words[Q]=G,this.length++),this},q.prototype.isZero=function(){return this.length===1&&this.words[0]===0},q.prototype.cmpn=function($){var X=$<0;if(this.negative!==0&&!X)return-1;if(this.negative===0&&X)return 1;this._strip();var U;if(this.length>1)U=1;else{X&&($=-$),B($<=67108863,"Number is too big");var H=this.words[0]|0;U=H===$?0:H<$?-1:1}return this.negative!==0?-U|0:U},q.prototype.cmp=function($){if(this.negative!==0&&$.negative===0)return-1;if(this.negative===0&&$.negative!==0)return 1;var X=this.ucmp($);return this.negative!==0?-X|0:X},q.prototype.ucmp=function($){if(this.length>$.length)return 1;if(this.length<$.length)return-1;for(var X=0,U=this.length-1;U>=0;U--){var H=this.words[U]|0,G=$.words[U]|0;if(H!==G){H<G?X=-1:H>G&&(X=1);break}}return X},q.prototype.gtn=function($){return this.cmpn($)===1},q.prototype.gt=function($){return this.cmp($)===1},q.prototype.gten=function($){return this.cmpn($)>=0},q.prototype.gte=function($){return this.cmp($)>=0},q.prototype.ltn=function($){return this.cmpn($)===-1},q.prototype.lt=function($){return this.cmp($)===-1},q.prototype.lten=function($){return this.cmpn($)<=0},q.prototype.lte=function($){return this.cmp($)<=0},q.prototype.eqn=function($){return this.cmpn($)===0},q.prototype.eq=function($){return this.cmp($)===0},q.red=function($){return new V($)},q.prototype.toRed=function($){return B(!this.red,"Already a number in reduction context"),B(this.negative===0,"red works only with positives"),$.convertTo(this)._forceRed($)},q.prototype.fromRed=function(){return B(this.red,"fromRed works only with numbers in reduction context"),this.red.convertFrom(this)},q.prototype._forceRed=function($){return this.red=$,this},q.prototype.forceRed=function($){return B(!this.red,"Already a number in reduction context"),this._forceRed($)},q.prototype.redAdd=function($){return B(this.red,"redAdd works only with red numbers"),this.red.add(this,$)},q.prototype.redIAdd=function($){return B(this.red,"redIAdd works only with red numbers"),this.red.iadd(this,$)},q.prototype.redSub=function($){return B(this.red,"redSub works only with red numbers"),this.red.sub(this,$)},q.prototype.redISub=function($){return B(this.red,"redISub works only with red numbers"),this.red.isub(this,$)},q.prototype.redShl=function($){return B(this.red,"redShl works only with red numbers"),this.red.shl(this,$)},q.prototype.redMul=function($){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,$),this.red.mul(this,$)},q.prototype.redIMul=function($){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,$),this.red.imul(this,$)},q.prototype.redSqr=function(){return B(this.red,"redSqr works only with red numbers"),this.red._verify1(this),this.red.sqr(this)},q.prototype.redISqr=function(){return B(this.red,"redISqr works only with red numbers"),this.red._verify1(this),this.red.isqr(this)},q.prototype.redSqrt=function(){return B(this.red,"redSqrt works only with red numbers"),this.red._verify1(this),this.red.sqrt(this)},q.prototype.redInvm=function(){return B(this.red,"redInvm works only with red numbers"),this.red._verify1(this),this.red.invm(this)},q.prototype.redNeg=function(){return B(this.red,"redNeg works only with red numbers"),this.red._verify1(this),this.red.neg(this)},q.prototype.redPow=function($){return B(this.red&&!$.red,"redPow(normalNum)"),this.red._verify1(this),this.red.pow(this,$)};var JJ={k256:null,p224:null,p192:null,p25519:null};function VJ($,X){this.name=$,this.p=new q(X,16),this.n=this.p.bitLength(),this.k=new q(1).iushln(this.n).isub(this.p),this.tmp=this._tmp()}VJ.prototype._tmp=function(){var $=new q(null);return $.words=new Array(Math.ceil(this.n/13)),$},VJ.prototype.ireduce=function($){var X=$,U;do this.split(X,this.tmp),X=this.imulK(X),X=X.iadd(this.tmp),U=X.bitLength();while(U>this.n);var H=U<this.n?-1:X.ucmp(this.p);return H===0?(X.words[0]=0,X.length=1):H>0?X.isub(this.p):X.strip!==void 0?X.strip():X._strip(),X},VJ.prototype.split=function($,X){$.iushrn(this.n,0,X)},VJ.prototype.imulK=function($){return $.imul(this.k)};function HJ(){VJ.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}A(HJ,VJ),HJ.prototype.split=function($,X){for(var U=4194303,H=Math.min($.length,9),G=0;G<H;G++)X.words[G]=$.words[G];if(X.length=H,$.length<=9){$.words[0]=0,$.length=1;return}var Q=$.words[9];for(X.words[X.length++]=Q&U,G=10;G<$.length;G++){var K=$.words[G]|0;$.words[G-10]=(K&U)<<4|Q>>>22,Q=K}Q>>>=22,$.words[G-10]=Q,Q===0&&$.length>10?$.length-=10:$.length-=9},HJ.prototype.imulK=function($){$.words[$.length]=0,$.words[$.length+1]=0,$.length+=2;for(var X=0,U=0;U<$.length;U++){var H=$.words[U]|0;X+=H*977,$.words[U]=X&67108863,X=H*64+(X/67108864|0)}return $.words[$.length-1]===0&&($.length--,$.words[$.length-1]===0&&$.length--),$};function o(){VJ.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}A(o,VJ);function jJ(){VJ.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}A(jJ,VJ);function J(){VJ.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}A(J,VJ),J.prototype.imulK=function($){for(var X=0,U=0;U<$.length;U++){var H=($.words[U]|0)*19+X,G=H&67108863;H>>>=26,$.words[U]=G,X=H}return X!==0&&($.words[$.length++]=X),$},q._prime=function($){if(JJ[$])return JJ[$];var X;if($==="k256")X=new HJ;else if($==="p224")X=new o;else if($==="p192")X=new jJ;else if($==="p25519")X=new J;else throw new Error("Unknown prime "+$);return JJ[$]=X,X};function V($){if(typeof $=="string"){var X=q._prime($);this.m=X.p,this.prime=X}else B($.gtn(1),"modulus must be greater than 1"),this.m=$,this.prime=null}V.prototype._verify1=function($){B($.negative===0,"red works only with positives"),B($.red,"red works only with red numbers")},V.prototype._verify2=function($,X){B(($.negative|X.negative)===0,"red works only with positives"),B($.red&&$.red===X.red,"red works only with red numbers")},V.prototype.imod=function($){return this.prime?this.prime.ireduce($)._forceRed(this):(W($,$.umod(this.m)._forceRed(this)),$)},V.prototype.neg=function($){return $.isZero()?$.clone():this.m.sub($)._forceRed(this)},V.prototype.add=function($,X){this._verify2($,X);var U=$.add(X);return U.cmp(this.m)>=0&&U.isub(this.m),U._forceRed(this)},V.prototype.iadd=function($,X){this._verify2($,X);var U=$.iadd(X);return U.cmp(this.m)>=0&&U.isub(this.m),U},V.prototype.sub=function($,X){this._verify2($,X);var U=$.sub(X);return U.cmpn(0)<0&&U.iadd(this.m),U._forceRed(this)},V.prototype.isub=function($,X){this._verify2($,X);var U=$.isub(X);return U.cmpn(0)<0&&U.iadd(this.m),U},V.prototype.shl=function($,X){return this._verify1($),this.imod($.ushln(X))},V.prototype.imul=function($,X){return this._verify2($,X),this.imod($.imul(X))},V.prototype.mul=function($,X){return this._verify2($,X),this.imod($.mul(X))},V.prototype.isqr=function($){return this.imul($,$.clone())},V.prototype.sqr=function($){return this.mul($,$)},V.prototype.sqrt=function($){if($.isZero())return $.clone();var X=this.m.andln(3);if(B(X%2===1),X===3){var U=this.m.add(new q(1)).iushrn(2);return this.pow($,U)}for(var H=this.m.subn(1),G=0;!H.isZero()&&H.andln(1)===0;)G++,H.iushrn(1);B(!H.isZero());var Q=new q(1).toRed(this),K=Q.redNeg(),k=this.m.subn(1).iushrn(1),L=this.m.bitLength();for(L=new q(2*L*L).toRed(this);this.pow(L,k).cmp(K)!==0;)L.redIAdd(K);for(var _=this.pow(L,H),t=this.pow($,H.addn(1).iushrn(1)),QJ=this.pow($,H),GJ=G;QJ.cmp(Q)!==0;){for(var n=QJ,p=0;n.cmp(Q)!==0;p++)n=n.redSqr();B(p<GJ);var e=this.pow(_,new q(1).iushln(GJ-p-1));t=t.redMul(e),_=e.redSqr(),QJ=QJ.redMul(_),GJ=p}return t},V.prototype.invm=function($){var X=$._invmp(this.m);return X.negative!==0?(X.negative=0,this.imod(X).redNeg()):this.imod(X)},V.prototype.pow=function($,X){if(X.isZero())return new q(1).toRed(this);if(X.cmpn(1)===0)return $.clone();var U=4,H=new Array(1<<U);H[0]=new q(1).toRed(this),H[1]=$;for(var G=2;G<H.length;G++)H[G]=this.mul(H[G-1],$);var Q=H[0],K=0,k=0,L=X.bitLength()%26;for(L===0&&(L=26),G=X.length-1;G>=0;G--){for(var _=X.words[G],t=L-1;t>=0;t--){var QJ=_>>t&1;if(Q!==H[0]&&(Q=this.sqr(Q)),QJ===0&&K===0){k=0;continue}K<<=1,K|=QJ,k++,!(k!==U&&(G!==0||t!==0))&&(Q=this.mul(Q,H[K]),k=0,K=0)}L=26}return Q},V.prototype.convertTo=function($){var X=$.umod(this.m);return X===$?X.clone():X},V.prototype.convertFrom=function($){var X=$.clone();return X.red=null,X},q.mont=function($){return new Z($)};function Z($){V.call(this,$),this.shift=this.m.bitLength(),this.shift%26!==0&&(this.shift+=26-this.shift%26),this.r=new q(1).iushln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv=this.minv.umod(this.r),this.minv=this.r.sub(this.minv)}A(Z,V),Z.prototype.convertTo=function($){return this.imod($.ushln(this.shift))},Z.prototype.convertFrom=function($){var X=this.imod($.mul(this.rinv));return X.red=null,X},Z.prototype.imul=function($,X){if($.isZero()||X.isZero())return $.words[0]=0,$.length=1,$;var U=$.imul(X),H=U.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),G=U.isub(H).iushrn(this.shift),Q=G;return G.cmp(this.m)>=0?Q=G.isub(this.m):G.cmpn(0)<0&&(Q=G.iadd(this.m)),Q._forceRed(this)},Z.prototype.mul=function($,X){if($.isZero()||X.isZero())return new q(0)._forceRed(this);var U=$.mul(X),H=U.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),G=U.isub(H).iushrn(this.shift),Q=G;return G.cmp(this.m)>=0?Q=G.isub(this.m):G.cmpn(0)<0&&(Q=G.iadd(this.m)),Q._forceRed(this)},Z.prototype.invm=function($){var X=this.imod($._invmp(this.m).mul(this.r2));return X._forceRed(this)}})(typeof g>"u"||g,l)}),$0=OJ((l,g)=>{var R=V0(),M=VV();function B(Y){var E=A(Y),O=E.toRed(R.mont(Y.modulus)).redPow(new R(Y.publicExponent)).fromRed();return{blinder:O,unblinder:E.invm(Y.modulus)}}function A(Y){var E=Y.modulus.byteLength(),O;do O=new R(M(E));while(O.cmp(Y.modulus)>=0||!O.umod(Y.prime1)||!O.umod(Y.prime2));return O}function q(Y,E){var O=B(E),N=E.modulus.byteLength(),W=new R(Y).mul(O.blinder).umod(E.modulus),I=W.toRed(R.mont(E.prime1)),z=W.toRed(R.mont(E.prime2)),j=E.coefficient,P=E.prime1,F=E.prime2,v=I.redPow(E.exponent1).fromRed(),S=z.redPow(E.exponent2).fromRed(),w=v.isub(S).imul(j).umod(P).imul(F);return S.iadd(w).imul(O.unblinder).umod(E.modulus).toArrayLike(Buffer,"be",N)}q.getr=A,g.exports=q}),n8=OJ((l,g)=>{g.exports={name:"elliptic",version:"6.5.4",description:"EC cryptography",main:"lib/elliptic.js",files:["lib"],scripts:{lint:"eslint lib test","lint:fix":"npm run lint -- --fix",unit:"istanbul test _mocha --reporter=spec test/index.js",test:"npm run lint && npm run unit",version:"grunt dist && git add dist/"},repository:{type:"git",url:"git@github.com:indutny/elliptic"},keywords:["EC","Elliptic","curve","Cryptography"],author:"Fedor Indutny <fedor@indutny.com>",license:"MIT",bugs:{url:"https://github.com/indutny/elliptic/issues"},homepage:"https://github.com/indutny/elliptic",devDependencies:{brfs:"^2.0.2",coveralls:"^3.1.0",eslint:"^7.6.0",grunt:"^1.2.1","grunt-browserify":"^5.3.0","grunt-cli":"^1.3.2","grunt-contrib-connect":"^3.0.0","grunt-contrib-copy":"^1.0.0","grunt-contrib-uglify":"^5.0.0","grunt-mocha-istanbul":"^5.0.2","grunt-saucelabs":"^9.0.1",istanbul:"^0.4.5",mocha:"^8.0.1"},dependencies:{"bn.js":"^4.11.9",brorand:"^1.1.0","hash.js":"^1.0.0","hmac-drbg":"^1.0.1",inherits:"^2.0.4","minimalistic-assert":"^1.0.1","minimalistic-crypto-utils":"^1.0.1"}}}),dQ=OJ((l,g)=>{(function(R,M){function B(J,V){if(!J)throw new Error(V||"Assertion failed")}function A(J,V){J.super_=V;var Z=function(){};Z.prototype=V.prototype,J.prototype=new Z,J.prototype.constructor=J}function q(J,V,Z){if(q.isBN(J))return J;this.negative=0,this.words=null,this.length=0,this.red=null,J!==null&&((V==="le"||V==="be")&&(Z=V,V=10),this._init(J||0,V||10,Z||"be"))}typeof R=="object"?R.exports=q:M.BN=q,q.BN=q,q.wordSize=26;var Y;try{typeof window<"u"&&typeof window.Buffer<"u"?Y=window.Buffer:Y=JV().Buffer}catch{}q.isBN=function(J){return J instanceof q?!0:J!==null&&typeof J=="object"&&J.constructor.wordSize===q.wordSize&&Array.isArray(J.words)},q.max=function(J,V){return J.cmp(V)>0?J:V},q.min=function(J,V){return J.cmp(V)<0?J:V},q.prototype._init=function(J,V,Z){if(typeof J=="number")return this._initNumber(J,V,Z);if(typeof J=="object")return this._initArray(J,V,Z);V==="hex"&&(V=16),B(V===(V|0)&&V>=2&&V<=36),J=J.toString().replace(/\s+/g,"");var $=0;J[0]==="-"&&($++,this.negative=1),$<J.length&&(V===16?this._parseHex(J,$,Z):(this._parseBase(J,V,$),Z==="le"&&this._initArray(this.toArray(),V,Z)))},q.prototype._initNumber=function(J,V,Z){J<0&&(this.negative=1,J=-J),J<67108864?(this.words=[J&67108863],this.length=1):J<4503599627370496?(this.words=[J&67108863,J/67108864&67108863],this.length=2):(B(J<9007199254740992),this.words=[J&67108863,J/67108864&67108863,1],this.length=3),Z==="le"&&this._initArray(this.toArray(),V,Z)},q.prototype._initArray=function(J,V,Z){if(B(typeof J.length=="number"),J.length<=0)return this.words=[0],this.length=1,this;this.length=Math.ceil(J.length/3),this.words=new Array(this.length);for(var $=0;$<this.length;$++)this.words[$]=0;var X,U,H=0;if(Z==="be")for($=J.length-1,X=0;$>=0;$-=3)U=J[$]|J[$-1]<<8|J[$-2]<<16,this.words[X]|=U<<H&67108863,this.words[X+1]=U>>>26-H&67108863,H+=24,H>=26&&(H-=26,X++);else if(Z==="le")for($=0,X=0;$<J.length;$+=3)U=J[$]|J[$+1]<<8|J[$+2]<<16,this.words[X]|=U<<H&67108863,this.words[X+1]=U>>>26-H&67108863,H+=24,H>=26&&(H-=26,X++);return this.strip()};function E(J,V){var Z=J.charCodeAt(V);return Z>=65&&Z<=70?Z-55:Z>=97&&Z<=102?Z-87:Z-48&15}function O(J,V,Z){var $=E(J,Z);return Z-1>=V&&($|=E(J,Z-1)<<4),$}q.prototype._parseHex=function(J,V,Z){this.length=Math.ceil((J.length-V)/6),this.words=new Array(this.length);for(var $=0;$<this.length;$++)this.words[$]=0;var X=0,U=0,H;if(Z==="be")for($=J.length-1;$>=V;$-=2)H=O(J,V,$)<<X,this.words[U]|=H&67108863,X>=18?(X-=18,U+=1,this.words[U]|=H>>>26):X+=8;else{var G=J.length-V;for($=G%2===0?V+1:V;$<J.length;$+=2)H=O(J,V,$)<<X,this.words[U]|=H&67108863,X>=18?(X-=18,U+=1,this.words[U]|=H>>>26):X+=8}this.strip()};function N(J,V,Z,$){for(var X=0,U=Math.min(J.length,Z),H=V;H<U;H++){var G=J.charCodeAt(H)-48;X*=$,G>=49?X+=G-49+10:G>=17?X+=G-17+10:X+=G}return X}q.prototype._parseBase=function(J,V,Z){this.words=[0],this.length=1;for(var $=0,X=1;X<=67108863;X*=V)$++;$--,X=X/V|0;for(var U=J.length-Z,H=U%$,G=Math.min(U,U-H)+Z,Q=0,K=Z;K<G;K+=$)Q=N(J,K,K+$,V),this.imuln(X),this.words[0]+Q<67108864?this.words[0]+=Q:this._iaddn(Q);if(H!==0){var k=1;for(Q=N(J,K,J.length,V),K=0;K<H;K++)k*=V;this.imuln(k),this.words[0]+Q<67108864?this.words[0]+=Q:this._iaddn(Q)}this.strip()},q.prototype.copy=function(J){J.words=new Array(this.length);for(var V=0;V<this.length;V++)J.words[V]=this.words[V];J.length=this.length,J.negative=this.negative,J.red=this.red},q.prototype.clone=function(){var J=new q(null);return this.copy(J),J},q.prototype._expand=function(J){for(;this.length<J;)this.words[this.length++]=0;return this},q.prototype.strip=function(){for(;this.length>1&&this.words[this.length-1]===0;)this.length--;return this._normSign()},q.prototype._normSign=function(){return this.length===1&&this.words[0]===0&&(this.negative=0),this},q.prototype.inspect=function(){return(this.red?"<BN-R: ":"<BN: ")+this.toString(16)+">"};var W=["","0","00","000","0000","00000","000000","0000000","00000000","000000000","0000000000","00000000000","000000000000","0000000000000","00000000000000","000000000000000","0000000000000000","00000000000000000","000000000000000000","0000000000000000000","00000000000000000000","000000000000000000000","0000000000000000000000","00000000000000000000000","000000000000000000000000","0000000000000000000000000"],I=[0,0,25,16,12,11,10,9,8,8,7,7,7,7,6,6,6,6,6,6,6,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5],z=[0,0,33554432,43046721,16777216,48828125,60466176,40353607,16777216,43046721,1e7,19487171,35831808,62748517,7529536,11390625,16777216,24137569,34012224,47045881,64000000,4084101,5153632,6436343,7962624,9765625,11881376,14348907,17210368,20511149,24300000,28629151,33554432,39135393,45435424,52521875,60466176];q.prototype.toString=function(J,V){J=J||10,V=V|0||1;var Z;if(J===16||J==="hex"){Z="";for(var $=0,X=0,U=0;U<this.length;U++){var H=this.words[U],G=((H<<$|X)&16777215).toString(16);X=H>>>24-$&16777215,X!==0||U!==this.length-1?Z=W[6-G.length]+G+Z:Z=G+Z,$+=2,$>=26&&($-=26,U--)}for(X!==0&&(Z=X.toString(16)+Z);Z.length%V!==0;)Z="0"+Z;return this.negative!==0&&(Z="-"+Z),Z}if(J===(J|0)&&J>=2&&J<=36){var Q=I[J],K=z[J];Z="";var k=this.clone();for(k.negative=0;!k.isZero();){var L=k.modn(K).toString(J);k=k.idivn(K),k.isZero()?Z=L+Z:Z=W[Q-L.length]+L+Z}for(this.isZero()&&(Z="0"+Z);Z.length%V!==0;)Z="0"+Z;return this.negative!==0&&(Z="-"+Z),Z}B(!1,"Base should be between 2 and 36")},q.prototype.toNumber=function(){var J=this.words[0];return this.length===2?J+=this.words[1]*67108864:this.length===3&&this.words[2]===1?J+=4503599627370496+this.words[1]*67108864:this.length>2&&B(!1,"Number can only safely store up to 53 bits"),this.negative!==0?-J:J},q.prototype.toJSON=function(){return this.toString(16)},q.prototype.toBuffer=function(J,V){return B(typeof Y<"u"),this.toArrayLike(Y,J,V)},q.prototype.toArray=function(J,V){return this.toArrayLike(Array,J,V)},q.prototype.toArrayLike=function(J,V,Z){var $=this.byteLength(),X=Z||Math.max(1,$);B($<=X,"byte array longer than desired length"),B(X>0,"Requested array length <= 0"),this.strip();var U=V==="le",H=new J(X),G,Q,K=this.clone();if(U){for(Q=0;!K.isZero();Q++)G=K.andln(255),K.iushrn(8),H[Q]=G;for(;Q<X;Q++)H[Q]=0}else{for(Q=0;Q<X-$;Q++)H[Q]=0;for(Q=0;!K.isZero();Q++)G=K.andln(255),K.iushrn(8),H[X-Q-1]=G}return H},Math.clz32?q.prototype._countBits=function(J){return 32-Math.clz32(J)}:q.prototype._countBits=function(J){var V=J,Z=0;return V>=4096&&(Z+=13,V>>>=13),V>=64&&(Z+=7,V>>>=7),V>=8&&(Z+=4,V>>>=4),V>=2&&(Z+=2,V>>>=2),Z+V},q.prototype._zeroBits=function(J){if(J===0)return 26;var V=J,Z=0;return(V&8191)===0&&(Z+=13,V>>>=13),(V&127)===0&&(Z+=7,V>>>=7),(V&15)===0&&(Z+=4,V>>>=4),(V&3)===0&&(Z+=2,V>>>=2),(V&1)===0&&Z++,Z},q.prototype.bitLength=function(){var J=this.words[this.length-1],V=this._countBits(J);return(this.length-1)*26+V};function j(J){for(var V=new Array(J.bitLength()),Z=0;Z<V.length;Z++){var $=Z/26|0,X=Z%26;V[Z]=(J.words[$]&1<<X)>>>X}return V}q.prototype.zeroBits=function(){if(this.isZero())return 0;for(var J=0,V=0;V<this.length;V++){var Z=this._zeroBits(this.words[V]);if(J+=Z,Z!==26)break}return J},q.prototype.byteLength=function(){return Math.ceil(this.bitLength()/8)},q.prototype.toTwos=function(J){return this.negative!==0?this.abs().inotn(J).iaddn(1):this.clone()},q.prototype.fromTwos=function(J){return this.testn(J-1)?this.notn(J).iaddn(1).ineg():this.clone()},q.prototype.isNeg=function(){return this.negative!==0},q.prototype.neg=function(){return this.clone().ineg()},q.prototype.ineg=function(){return this.isZero()||(this.negative^=1),this},q.prototype.iuor=function(J){for(;this.length<J.length;)this.words[this.length++]=0;for(var V=0;V<J.length;V++)this.words[V]=this.words[V]|J.words[V];return this.strip()},q.prototype.ior=function(J){return B((this.negative|J.negative)===0),this.iuor(J)},q.prototype.or=function(J){return this.length>J.length?this.clone().ior(J):J.clone().ior(this)},q.prototype.uor=function(J){return this.length>J.length?this.clone().iuor(J):J.clone().iuor(this)},q.prototype.iuand=function(J){var V;this.length>J.length?V=J:V=this;for(var Z=0;Z<V.length;Z++)this.words[Z]=this.words[Z]&J.words[Z];return this.length=V.length,this.strip()},q.prototype.iand=function(J){return B((this.negative|J.negative)===0),this.iuand(J)},q.prototype.and=function(J){return this.length>J.length?this.clone().iand(J):J.clone().iand(this)},q.prototype.uand=function(J){return this.length>J.length?this.clone().iuand(J):J.clone().iuand(this)},q.prototype.iuxor=function(J){var V,Z;this.length>J.length?(V=this,Z=J):(V=J,Z=this);for(var $=0;$<Z.length;$++)this.words[$]=V.words[$]^Z.words[$];if(this!==V)for(;$<V.length;$++)this.words[$]=V.words[$];return this.length=V.length,this.strip()},q.prototype.ixor=function(J){return B((this.negative|J.negative)===0),this.iuxor(J)},q.prototype.xor=function(J){return this.length>J.length?this.clone().ixor(J):J.clone().ixor(this)},q.prototype.uxor=function(J){return this.length>J.length?this.clone().iuxor(J):J.clone().iuxor(this)},q.prototype.inotn=function(J){B(typeof J=="number"&&J>=0);var V=Math.ceil(J/26)|0,Z=J%26;this._expand(V),Z>0&&V--;for(var $=0;$<V;$++)this.words[$]=~this.words[$]&67108863;return Z>0&&(this.words[$]=~this.words[$]&67108863>>26-Z),this.strip()},q.prototype.notn=function(J){return this.clone().inotn(J)},q.prototype.setn=function(J,V){B(typeof J=="number"&&J>=0);var Z=J/26|0,$=J%26;return this._expand(Z+1),V?this.words[Z]=this.words[Z]|1<<$:this.words[Z]=this.words[Z]&~(1<<$),this.strip()},q.prototype.iadd=function(J){var V;if(this.negative!==0&&J.negative===0)return this.negative=0,V=this.isub(J),this.negative^=1,this._normSign();if(this.negative===0&&J.negative!==0)return J.negative=0,V=this.isub(J),J.negative=1,V._normSign();var Z,$;this.length>J.length?(Z=this,$=J):(Z=J,$=this);for(var X=0,U=0;U<$.length;U++)V=(Z.words[U]|0)+($.words[U]|0)+X,this.words[U]=V&67108863,X=V>>>26;for(;X!==0&&U<Z.length;U++)V=(Z.words[U]|0)+X,this.words[U]=V&67108863,X=V>>>26;if(this.length=Z.length,X!==0)this.words[this.length]=X,this.length++;else if(Z!==this)for(;U<Z.length;U++)this.words[U]=Z.words[U];return this},q.prototype.add=function(J){var V;return J.negative!==0&&this.negative===0?(J.negative=0,V=this.sub(J),J.negative^=1,V):J.negative===0&&this.negative!==0?(this.negative=0,V=J.sub(this),this.negative=1,V):this.length>J.length?this.clone().iadd(J):J.clone().iadd(this)},q.prototype.isub=function(J){if(J.negative!==0){J.negative=0;var V=this.iadd(J);return J.negative=1,V._normSign()}else if(this.negative!==0)return this.negative=0,this.iadd(J),this.negative=1,this._normSign();var Z=this.cmp(J);if(Z===0)return this.negative=0,this.length=1,this.words[0]=0,this;var $,X;Z>0?($=this,X=J):($=J,X=this);for(var U=0,H=0;H<X.length;H++)V=($.words[H]|0)-(X.words[H]|0)+U,U=V>>26,this.words[H]=V&67108863;for(;U!==0&&H<$.length;H++)V=($.words[H]|0)+U,U=V>>26,this.words[H]=V&67108863;if(U===0&&H<$.length&&$!==this)for(;H<$.length;H++)this.words[H]=$.words[H];return this.length=Math.max(this.length,H),$!==this&&(this.negative=1),this.strip()},q.prototype.sub=function(J){return this.clone().isub(J)};function P(J,V,Z){Z.negative=V.negative^J.negative;var $=J.length+V.length|0;Z.length=$,$=$-1|0;var X=J.words[0]|0,U=V.words[0]|0,H=X*U,G=H&67108863,Q=H/67108864|0;Z.words[0]=G;for(var K=1;K<$;K++){for(var k=Q>>>26,L=Q&67108863,_=Math.min(K,V.length-1),t=Math.max(0,K-J.length+1);t<=_;t++){var QJ=K-t|0;X=J.words[QJ]|0,U=V.words[t]|0,H=X*U+L,k+=H/67108864|0,L=H&67108863}Z.words[K]=L|0,Q=k|0}return Q!==0?Z.words[K]=Q|0:Z.length--,Z.strip()}var F=function(J,V,Z){var $=J.words,X=V.words,U=Z.words,H=0,G,Q,K,k=$[0]|0,L=k&8191,_=k>>>13,t=$[1]|0,QJ=t&8191,GJ=t>>>13,n=$[2]|0,p=n&8191,e=n>>>13,PJ=$[3]|0,XJ=PJ&8191,WJ=PJ>>>13,b=$[4]|0,C=b&8191,h=b>>>13,$J=$[5]|0,qJ=$J&8191,ZJ=$J>>>13,mJ=$[6]|0,BJ=mJ&8191,TJ=mJ>>>13,dJ=$[7]|0,LJ=dJ&8191,IJ=dJ>>>13,$Q=$[8]|0,T=$Q&8191,D=$Q>>>13,u=$[9]|0,d=u&8191,a=u>>>13,CJ=X[0]|0,UJ=CJ&8191,EJ=CJ>>>13,QQ=X[1]|0,FJ=QQ&8191,RJ=QQ>>>13,aJ=X[2]|0,SJ=aJ&8191,xJ=aJ>>>13,nJ=X[3]|0,AJ=nJ&8191,kJ=nJ>>>13,ZQ=X[4]|0,vJ=ZQ&8191,MJ=ZQ>>>13,xQ=X[5]|0,wJ=xQ&8191,bJ=xQ>>>13,WQ=X[6]|0,_J=WQ&8191,NJ=WQ>>>13,vQ=X[7]|0,yJ=vQ&8191,gJ=vQ>>>13,MQ=X[8]|0,cJ=MQ&8191,fJ=MQ>>>13,wQ=X[9]|0,f=wQ&8191,zJ=wQ>>>13;Z.negative=J.negative^V.negative,Z.length=19,G=Math.imul(L,UJ),Q=Math.imul(L,EJ),Q=Q+Math.imul(_,UJ)|0,K=Math.imul(_,EJ);var CQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(CQ>>>26)|0,CQ&=67108863,G=Math.imul(QJ,UJ),Q=Math.imul(QJ,EJ),Q=Q+Math.imul(GJ,UJ)|0,K=Math.imul(GJ,EJ),G=G+Math.imul(L,FJ)|0,Q=Q+Math.imul(L,RJ)|0,Q=Q+Math.imul(_,FJ)|0,K=K+Math.imul(_,RJ)|0;var oJ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(oJ>>>26)|0,oJ&=67108863,G=Math.imul(p,UJ),Q=Math.imul(p,EJ),Q=Q+Math.imul(e,UJ)|0,K=Math.imul(e,EJ),G=G+Math.imul(QJ,FJ)|0,Q=Q+Math.imul(QJ,RJ)|0,Q=Q+Math.imul(GJ,FJ)|0,K=K+Math.imul(GJ,RJ)|0,G=G+Math.imul(L,SJ)|0,Q=Q+Math.imul(L,xJ)|0,Q=Q+Math.imul(_,SJ)|0,K=K+Math.imul(_,xJ)|0;var tJ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(tJ>>>26)|0,tJ&=67108863,G=Math.imul(XJ,UJ),Q=Math.imul(XJ,EJ),Q=Q+Math.imul(WJ,UJ)|0,K=Math.imul(WJ,EJ),G=G+Math.imul(p,FJ)|0,Q=Q+Math.imul(p,RJ)|0,Q=Q+Math.imul(e,FJ)|0,K=K+Math.imul(e,RJ)|0,G=G+Math.imul(QJ,SJ)|0,Q=Q+Math.imul(QJ,xJ)|0,Q=Q+Math.imul(GJ,SJ)|0,K=K+Math.imul(GJ,xJ)|0,G=G+Math.imul(L,AJ)|0,Q=Q+Math.imul(L,kJ)|0,Q=Q+Math.imul(_,AJ)|0,K=K+Math.imul(_,kJ)|0;var YQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(YQ>>>26)|0,YQ&=67108863,G=Math.imul(C,UJ),Q=Math.imul(C,EJ),Q=Q+Math.imul(h,UJ)|0,K=Math.imul(h,EJ),G=G+Math.imul(XJ,FJ)|0,Q=Q+Math.imul(XJ,RJ)|0,Q=Q+Math.imul(WJ,FJ)|0,K=K+Math.imul(WJ,RJ)|0,G=G+Math.imul(p,SJ)|0,Q=Q+Math.imul(p,xJ)|0,Q=Q+Math.imul(e,SJ)|0,K=K+Math.imul(e,xJ)|0,G=G+Math.imul(QJ,AJ)|0,Q=Q+Math.imul(QJ,kJ)|0,Q=Q+Math.imul(GJ,AJ)|0,K=K+Math.imul(GJ,kJ)|0,G=G+Math.imul(L,vJ)|0,Q=Q+Math.imul(L,MJ)|0,Q=Q+Math.imul(_,vJ)|0,K=K+Math.imul(_,MJ)|0;var BQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(BQ>>>26)|0,BQ&=67108863,G=Math.imul(qJ,UJ),Q=Math.imul(qJ,EJ),Q=Q+Math.imul(ZJ,UJ)|0,K=Math.imul(ZJ,EJ),G=G+Math.imul(C,FJ)|0,Q=Q+Math.imul(C,RJ)|0,Q=Q+Math.imul(h,FJ)|0,K=K+Math.imul(h,RJ)|0,G=G+Math.imul(XJ,SJ)|0,Q=Q+Math.imul(XJ,xJ)|0,Q=Q+Math.imul(WJ,SJ)|0,K=K+Math.imul(WJ,xJ)|0,G=G+Math.imul(p,AJ)|0,Q=Q+Math.imul(p,kJ)|0,Q=Q+Math.imul(e,AJ)|0,K=K+Math.imul(e,kJ)|0,G=G+Math.imul(QJ,vJ)|0,Q=Q+Math.imul(QJ,MJ)|0,Q=Q+Math.imul(GJ,vJ)|0,K=K+Math.imul(GJ,MJ)|0,G=G+Math.imul(L,wJ)|0,Q=Q+Math.imul(L,bJ)|0,Q=Q+Math.imul(_,wJ)|0,K=K+Math.imul(_,bJ)|0;var OQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(OQ>>>26)|0,OQ&=67108863,G=Math.imul(BJ,UJ),Q=Math.imul(BJ,EJ),Q=Q+Math.imul(TJ,UJ)|0,K=Math.imul(TJ,EJ),G=G+Math.imul(qJ,FJ)|0,Q=Q+Math.imul(qJ,RJ)|0,Q=Q+Math.imul(ZJ,FJ)|0,K=K+Math.imul(ZJ,RJ)|0,G=G+Math.imul(C,SJ)|0,Q=Q+Math.imul(C,xJ)|0,Q=Q+Math.imul(h,SJ)|0,K=K+Math.imul(h,xJ)|0,G=G+Math.imul(XJ,AJ)|0,Q=Q+Math.imul(XJ,kJ)|0,Q=Q+Math.imul(WJ,AJ)|0,K=K+Math.imul(WJ,kJ)|0,G=G+Math.imul(p,vJ)|0,Q=Q+Math.imul(p,MJ)|0,Q=Q+Math.imul(e,vJ)|0,K=K+Math.imul(e,MJ)|0,G=G+Math.imul(QJ,wJ)|0,Q=Q+Math.imul(QJ,bJ)|0,Q=Q+Math.imul(GJ,wJ)|0,K=K+Math.imul(GJ,bJ)|0,G=G+Math.imul(L,_J)|0,Q=Q+Math.imul(L,NJ)|0,Q=Q+Math.imul(_,_J)|0,K=K+Math.imul(_,NJ)|0;var jQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(jQ>>>26)|0,jQ&=67108863,G=Math.imul(LJ,UJ),Q=Math.imul(LJ,EJ),Q=Q+Math.imul(IJ,UJ)|0,K=Math.imul(IJ,EJ),G=G+Math.imul(BJ,FJ)|0,Q=Q+Math.imul(BJ,RJ)|0,Q=Q+Math.imul(TJ,FJ)|0,K=K+Math.imul(TJ,RJ)|0,G=G+Math.imul(qJ,SJ)|0,Q=Q+Math.imul(qJ,xJ)|0,Q=Q+Math.imul(ZJ,SJ)|0,K=K+Math.imul(ZJ,xJ)|0,G=G+Math.imul(C,AJ)|0,Q=Q+Math.imul(C,kJ)|0,Q=Q+Math.imul(h,AJ)|0,K=K+Math.imul(h,kJ)|0,G=G+Math.imul(XJ,vJ)|0,Q=Q+Math.imul(XJ,MJ)|0,Q=Q+Math.imul(WJ,vJ)|0,K=K+Math.imul(WJ,MJ)|0,G=G+Math.imul(p,wJ)|0,Q=Q+Math.imul(p,bJ)|0,Q=Q+Math.imul(e,wJ)|0,K=K+Math.imul(e,bJ)|0,G=G+Math.imul(QJ,_J)|0,Q=Q+Math.imul(QJ,NJ)|0,Q=Q+Math.imul(GJ,_J)|0,K=K+Math.imul(GJ,NJ)|0,G=G+Math.imul(L,yJ)|0,Q=Q+Math.imul(L,gJ)|0,Q=Q+Math.imul(_,yJ)|0,K=K+Math.imul(_,gJ)|0;var TQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(TQ>>>26)|0,TQ&=67108863,G=Math.imul(T,UJ),Q=Math.imul(T,EJ),Q=Q+Math.imul(D,UJ)|0,K=Math.imul(D,EJ),G=G+Math.imul(LJ,FJ)|0,Q=Q+Math.imul(LJ,RJ)|0,Q=Q+Math.imul(IJ,FJ)|0,K=K+Math.imul(IJ,RJ)|0,G=G+Math.imul(BJ,SJ)|0,Q=Q+Math.imul(BJ,xJ)|0,Q=Q+Math.imul(TJ,SJ)|0,K=K+Math.imul(TJ,xJ)|0,G=G+Math.imul(qJ,AJ)|0,Q=Q+Math.imul(qJ,kJ)|0,Q=Q+Math.imul(ZJ,AJ)|0,K=K+Math.imul(ZJ,kJ)|0,G=G+Math.imul(C,vJ)|0,Q=Q+Math.imul(C,MJ)|0,Q=Q+Math.imul(h,vJ)|0,K=K+Math.imul(h,MJ)|0,G=G+Math.imul(XJ,wJ)|0,Q=Q+Math.imul(XJ,bJ)|0,Q=Q+Math.imul(WJ,wJ)|0,K=K+Math.imul(WJ,bJ)|0,G=G+Math.imul(p,_J)|0,Q=Q+Math.imul(p,NJ)|0,Q=Q+Math.imul(e,_J)|0,K=K+Math.imul(e,NJ)|0,G=G+Math.imul(QJ,yJ)|0,Q=Q+Math.imul(QJ,gJ)|0,Q=Q+Math.imul(GJ,yJ)|0,K=K+Math.imul(GJ,gJ)|0,G=G+Math.imul(L,cJ)|0,Q=Q+Math.imul(L,fJ)|0,Q=Q+Math.imul(_,cJ)|0,K=K+Math.imul(_,fJ)|0;var NQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(NQ>>>26)|0,NQ&=67108863,G=Math.imul(d,UJ),Q=Math.imul(d,EJ),Q=Q+Math.imul(a,UJ)|0,K=Math.imul(a,EJ),G=G+Math.imul(T,FJ)|0,Q=Q+Math.imul(T,RJ)|0,Q=Q+Math.imul(D,FJ)|0,K=K+Math.imul(D,RJ)|0,G=G+Math.imul(LJ,SJ)|0,Q=Q+Math.imul(LJ,xJ)|0,Q=Q+Math.imul(IJ,SJ)|0,K=K+Math.imul(IJ,xJ)|0,G=G+Math.imul(BJ,AJ)|0,Q=Q+Math.imul(BJ,kJ)|0,Q=Q+Math.imul(TJ,AJ)|0,K=K+Math.imul(TJ,kJ)|0,G=G+Math.imul(qJ,vJ)|0,Q=Q+Math.imul(qJ,MJ)|0,Q=Q+Math.imul(ZJ,vJ)|0,K=K+Math.imul(ZJ,MJ)|0,G=G+Math.imul(C,wJ)|0,Q=Q+Math.imul(C,bJ)|0,Q=Q+Math.imul(h,wJ)|0,K=K+Math.imul(h,bJ)|0,G=G+Math.imul(XJ,_J)|0,Q=Q+Math.imul(XJ,NJ)|0,Q=Q+Math.imul(WJ,_J)|0,K=K+Math.imul(WJ,NJ)|0,G=G+Math.imul(p,yJ)|0,Q=Q+Math.imul(p,gJ)|0,Q=Q+Math.imul(e,yJ)|0,K=K+Math.imul(e,gJ)|0,G=G+Math.imul(QJ,cJ)|0,Q=Q+Math.imul(QJ,fJ)|0,Q=Q+Math.imul(GJ,cJ)|0,K=K+Math.imul(GJ,fJ)|0,G=G+Math.imul(L,f)|0,Q=Q+Math.imul(L,zJ)|0,Q=Q+Math.imul(_,f)|0,K=K+Math.imul(_,zJ)|0;var IQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(IQ>>>26)|0,IQ&=67108863,G=Math.imul(d,FJ),Q=Math.imul(d,RJ),Q=Q+Math.imul(a,FJ)|0,K=Math.imul(a,RJ),G=G+Math.imul(T,SJ)|0,Q=Q+Math.imul(T,xJ)|0,Q=Q+Math.imul(D,SJ)|0,K=K+Math.imul(D,xJ)|0,G=G+Math.imul(LJ,AJ)|0,Q=Q+Math.imul(LJ,kJ)|0,Q=Q+Math.imul(IJ,AJ)|0,K=K+Math.imul(IJ,kJ)|0,G=G+Math.imul(BJ,vJ)|0,Q=Q+Math.imul(BJ,MJ)|0,Q=Q+Math.imul(TJ,vJ)|0,K=K+Math.imul(TJ,MJ)|0,G=G+Math.imul(qJ,wJ)|0,Q=Q+Math.imul(qJ,bJ)|0,Q=Q+Math.imul(ZJ,wJ)|0,K=K+Math.imul(ZJ,bJ)|0,G=G+Math.imul(C,_J)|0,Q=Q+Math.imul(C,NJ)|0,Q=Q+Math.imul(h,_J)|0,K=K+Math.imul(h,NJ)|0,G=G+Math.imul(XJ,yJ)|0,Q=Q+Math.imul(XJ,gJ)|0,Q=Q+Math.imul(WJ,yJ)|0,K=K+Math.imul(WJ,gJ)|0,G=G+Math.imul(p,cJ)|0,Q=Q+Math.imul(p,fJ)|0,Q=Q+Math.imul(e,cJ)|0,K=K+Math.imul(e,fJ)|0,G=G+Math.imul(QJ,f)|0,Q=Q+Math.imul(QJ,zJ)|0,Q=Q+Math.imul(GJ,f)|0,K=K+Math.imul(GJ,zJ)|0;var EQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(EQ>>>26)|0,EQ&=67108863,G=Math.imul(d,SJ),Q=Math.imul(d,xJ),Q=Q+Math.imul(a,SJ)|0,K=Math.imul(a,xJ),G=G+Math.imul(T,AJ)|0,Q=Q+Math.imul(T,kJ)|0,Q=Q+Math.imul(D,AJ)|0,K=K+Math.imul(D,kJ)|0,G=G+Math.imul(LJ,vJ)|0,Q=Q+Math.imul(LJ,MJ)|0,Q=Q+Math.imul(IJ,vJ)|0,K=K+Math.imul(IJ,MJ)|0,G=G+Math.imul(BJ,wJ)|0,Q=Q+Math.imul(BJ,bJ)|0,Q=Q+Math.imul(TJ,wJ)|0,K=K+Math.imul(TJ,bJ)|0,G=G+Math.imul(qJ,_J)|0,Q=Q+Math.imul(qJ,NJ)|0,Q=Q+Math.imul(ZJ,_J)|0,K=K+Math.imul(ZJ,NJ)|0,G=G+Math.imul(C,yJ)|0,Q=Q+Math.imul(C,gJ)|0,Q=Q+Math.imul(h,yJ)|0,K=K+Math.imul(h,gJ)|0,G=G+Math.imul(XJ,cJ)|0,Q=Q+Math.imul(XJ,fJ)|0,Q=Q+Math.imul(WJ,cJ)|0,K=K+Math.imul(WJ,fJ)|0,G=G+Math.imul(p,f)|0,Q=Q+Math.imul(p,zJ)|0,Q=Q+Math.imul(e,f)|0,K=K+Math.imul(e,zJ)|0;var RQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(RQ>>>26)|0,RQ&=67108863,G=Math.imul(d,AJ),Q=Math.imul(d,kJ),Q=Q+Math.imul(a,AJ)|0,K=Math.imul(a,kJ),G=G+Math.imul(T,vJ)|0,Q=Q+Math.imul(T,MJ)|0,Q=Q+Math.imul(D,vJ)|0,K=K+Math.imul(D,MJ)|0,G=G+Math.imul(LJ,wJ)|0,Q=Q+Math.imul(LJ,bJ)|0,Q=Q+Math.imul(IJ,wJ)|0,K=K+Math.imul(IJ,bJ)|0,G=G+Math.imul(BJ,_J)|0,Q=Q+Math.imul(BJ,NJ)|0,Q=Q+Math.imul(TJ,_J)|0,K=K+Math.imul(TJ,NJ)|0,G=G+Math.imul(qJ,yJ)|0,Q=Q+Math.imul(qJ,gJ)|0,Q=Q+Math.imul(ZJ,yJ)|0,K=K+Math.imul(ZJ,gJ)|0,G=G+Math.imul(C,cJ)|0,Q=Q+Math.imul(C,fJ)|0,Q=Q+Math.imul(h,cJ)|0,K=K+Math.imul(h,fJ)|0,G=G+Math.imul(XJ,f)|0,Q=Q+Math.imul(XJ,zJ)|0,Q=Q+Math.imul(WJ,f)|0,K=K+Math.imul(WJ,zJ)|0;var zQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(zQ>>>26)|0,zQ&=67108863,G=Math.imul(d,vJ),Q=Math.imul(d,MJ),Q=Q+Math.imul(a,vJ)|0,K=Math.imul(a,MJ),G=G+Math.imul(T,wJ)|0,Q=Q+Math.imul(T,bJ)|0,Q=Q+Math.imul(D,wJ)|0,K=K+Math.imul(D,bJ)|0,G=G+Math.imul(LJ,_J)|0,Q=Q+Math.imul(LJ,NJ)|0,Q=Q+Math.imul(IJ,_J)|0,K=K+Math.imul(IJ,NJ)|0,G=G+Math.imul(BJ,yJ)|0,Q=Q+Math.imul(BJ,gJ)|0,Q=Q+Math.imul(TJ,yJ)|0,K=K+Math.imul(TJ,gJ)|0,G=G+Math.imul(qJ,cJ)|0,Q=Q+Math.imul(qJ,fJ)|0,Q=Q+Math.imul(ZJ,cJ)|0,K=K+Math.imul(ZJ,fJ)|0,G=G+Math.imul(C,f)|0,Q=Q+Math.imul(C,zJ)|0,Q=Q+Math.imul(h,f)|0,K=K+Math.imul(h,zJ)|0;var PQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(PQ>>>26)|0,PQ&=67108863,G=Math.imul(d,wJ),Q=Math.imul(d,bJ),Q=Q+Math.imul(a,wJ)|0,K=Math.imul(a,bJ),G=G+Math.imul(T,_J)|0,Q=Q+Math.imul(T,NJ)|0,Q=Q+Math.imul(D,_J)|0,K=K+Math.imul(D,NJ)|0,G=G+Math.imul(LJ,yJ)|0,Q=Q+Math.imul(LJ,gJ)|0,Q=Q+Math.imul(IJ,yJ)|0,K=K+Math.imul(IJ,gJ)|0,G=G+Math.imul(BJ,cJ)|0,Q=Q+Math.imul(BJ,fJ)|0,Q=Q+Math.imul(TJ,cJ)|0,K=K+Math.imul(TJ,fJ)|0,G=G+Math.imul(qJ,f)|0,Q=Q+Math.imul(qJ,zJ)|0,Q=Q+Math.imul(ZJ,f)|0,K=K+Math.imul(ZJ,zJ)|0;var LQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(LQ>>>26)|0,LQ&=67108863,G=Math.imul(d,_J),Q=Math.imul(d,NJ),Q=Q+Math.imul(a,_J)|0,K=Math.imul(a,NJ),G=G+Math.imul(T,yJ)|0,Q=Q+Math.imul(T,gJ)|0,Q=Q+Math.imul(D,yJ)|0,K=K+Math.imul(D,gJ)|0,G=G+Math.imul(LJ,cJ)|0,Q=Q+Math.imul(LJ,fJ)|0,Q=Q+Math.imul(IJ,cJ)|0,K=K+Math.imul(IJ,fJ)|0,G=G+Math.imul(BJ,f)|0,Q=Q+Math.imul(BJ,zJ)|0,Q=Q+Math.imul(TJ,f)|0,K=K+Math.imul(TJ,zJ)|0;var FQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(FQ>>>26)|0,FQ&=67108863,G=Math.imul(d,yJ),Q=Math.imul(d,gJ),Q=Q+Math.imul(a,yJ)|0,K=Math.imul(a,gJ),G=G+Math.imul(T,cJ)|0,Q=Q+Math.imul(T,fJ)|0,Q=Q+Math.imul(D,cJ)|0,K=K+Math.imul(D,fJ)|0,G=G+Math.imul(LJ,f)|0,Q=Q+Math.imul(LJ,zJ)|0,Q=Q+Math.imul(IJ,f)|0,K=K+Math.imul(IJ,zJ)|0;var HQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(HQ>>>26)|0,HQ&=67108863,G=Math.imul(d,cJ),Q=Math.imul(d,fJ),Q=Q+Math.imul(a,cJ)|0,K=Math.imul(a,fJ),G=G+Math.imul(T,f)|0,Q=Q+Math.imul(T,zJ)|0,Q=Q+Math.imul(D,f)|0,K=K+Math.imul(D,zJ)|0;var DQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(DQ>>>26)|0,DQ&=67108863,G=Math.imul(d,f),Q=Math.imul(d,zJ),Q=Q+Math.imul(a,f)|0,K=Math.imul(a,zJ);var KQ=(H+G|0)+((Q&8191)<<13)|0;return H=(K+(Q>>>13)|0)+(KQ>>>26)|0,KQ&=67108863,U[0]=CQ,U[1]=oJ,U[2]=tJ,U[3]=YQ,U[4]=BQ,U[5]=OQ,U[6]=jQ,U[7]=TQ,U[8]=NQ,U[9]=IQ,U[10]=EQ,U[11]=RQ,U[12]=zQ,U[13]=PQ,U[14]=LQ,U[15]=FQ,U[16]=HQ,U[17]=DQ,U[18]=KQ,H!==0&&(U[19]=H,Z.length++),Z};Math.imul||(F=P);function v(J,V,Z){Z.negative=V.negative^J.negative,Z.length=J.length+V.length;for(var $=0,X=0,U=0;U<Z.length-1;U++){var H=X;X=0;for(var G=$&67108863,Q=Math.min(U,V.length-1),K=Math.max(0,U-J.length+1);K<=Q;K++){var k=U-K,L=J.words[k]|0,_=V.words[K]|0,t=L*_,QJ=t&67108863;H=H+(t/67108864|0)|0,QJ=QJ+G|0,G=QJ&67108863,H=H+(QJ>>>26)|0,X+=H>>>26,H&=67108863}Z.words[U]=G,$=H,H=X}return $!==0?Z.words[U]=$:Z.length--,Z.strip()}function S(J,V,Z){var $=new w;return $.mulp(J,V,Z)}q.prototype.mulTo=function(J,V){var Z,$=this.length+J.length;return this.length===10&&J.length===10?Z=F(this,J,V):$<63?Z=P(this,J,V):$<1024?Z=v(this,J,V):Z=S(this,J,V),Z};function w(J,V){this.x=J,this.y=V}w.prototype.makeRBT=function(J){for(var V=new Array(J),Z=q.prototype._countBits(J)-1,$=0;$<J;$++)V[$]=this.revBin($,Z,J);return V},w.prototype.revBin=function(J,V,Z){if(J===0||J===Z-1)return J;for(var $=0,X=0;X<V;X++)$|=(J&1)<<V-X-1,J>>=1;return $},w.prototype.permute=function(J,V,Z,$,X,U){for(var H=0;H<U;H++)$[H]=V[J[H]],X[H]=Z[J[H]]},w.prototype.transform=function(J,V,Z,$,X,U){this.permute(U,J,V,Z,$,X);for(var H=1;H<X;H<<=1)for(var G=H<<1,Q=Math.cos(2*Math.PI/G),K=Math.sin(2*Math.PI/G),k=0;k<X;k+=G)for(var L=Q,_=K,t=0;t<H;t++){var QJ=Z[k+t],GJ=$[k+t],n=Z[k+t+H],p=$[k+t+H],e=L*n-_*p;p=L*p+_*n,n=e,Z[k+t]=QJ+n,$[k+t]=GJ+p,Z[k+t+H]=QJ-n,$[k+t+H]=GJ-p,t!==G&&(e=Q*L-K*_,_=Q*_+K*L,L=e)}},w.prototype.guessLen13b=function(J,V){var Z=Math.max(V,J)|1,$=Z&1,X=0;for(Z=Z/2|0;Z;Z=Z>>>1)X++;return 1<<X+1+$},w.prototype.conjugate=function(J,V,Z){if(!(Z<=1))for(var $=0;$<Z/2;$++){var X=J[$];J[$]=J[Z-$-1],J[Z-$-1]=X,X=V[$],V[$]=-V[Z-$-1],V[Z-$-1]=-X}},w.prototype.normalize13b=function(J,V){for(var Z=0,$=0;$<V/2;$++){var X=Math.round(J[2*$+1]/V)*8192+Math.round(J[2*$]/V)+Z;J[$]=X&67108863,X<67108864?Z=0:Z=X/67108864|0}return J},w.prototype.convert13b=function(J,V,Z,$){for(var X=0,U=0;U<V;U++)X=X+(J[U]|0),Z[2*U]=X&8191,X=X>>>13,Z[2*U+1]=X&8191,X=X>>>13;for(U=2*V;U<$;++U)Z[U]=0;B(X===0),B((X&-8192)===0)},w.prototype.stub=function(J){for(var V=new Array(J),Z=0;Z<J;Z++)V[Z]=0;return V},w.prototype.mulp=function(J,V,Z){var $=2*this.guessLen13b(J.length,V.length),X=this.makeRBT($),U=this.stub($),H=new Array($),G=new Array($),Q=new Array($),K=new Array($),k=new Array($),L=new Array($),_=Z.words;_.length=$,this.convert13b(J.words,J.length,H,$),this.convert13b(V.words,V.length,K,$),this.transform(H,U,G,Q,$,X),this.transform(K,U,k,L,$,X);for(var t=0;t<$;t++){var QJ=G[t]*k[t]-Q[t]*L[t];Q[t]=G[t]*L[t]+Q[t]*k[t],G[t]=QJ}return this.conjugate(G,Q,$),this.transform(G,Q,_,U,$,X),this.conjugate(_,U,$),this.normalize13b(_,$),Z.negative=J.negative^V.negative,Z.length=J.length+V.length,Z.strip()},q.prototype.mul=function(J){var V=new q(null);return V.words=new Array(this.length+J.length),this.mulTo(J,V)},q.prototype.mulf=function(J){var V=new q(null);return V.words=new Array(this.length+J.length),S(this,J,V)},q.prototype.imul=function(J){return this.clone().mulTo(J,this)},q.prototype.imuln=function(J){B(typeof J=="number"),B(J<67108864);for(var V=0,Z=0;Z<this.length;Z++){var $=(this.words[Z]|0)*J,X=($&67108863)+(V&67108863);V>>=26,V+=$/67108864|0,V+=X>>>26,this.words[Z]=X&67108863}return V!==0&&(this.words[Z]=V,this.length++),this},q.prototype.muln=function(J){return this.clone().imuln(J)},q.prototype.sqr=function(){return this.mul(this)},q.prototype.isqr=function(){return this.imul(this.clone())},q.prototype.pow=function(J){var V=j(J);if(V.length===0)return new q(1);for(var Z=this,$=0;$<V.length&&V[$]===0;$++,Z=Z.sqr());if(++$<V.length)for(var X=Z.sqr();$<V.length;$++,X=X.sqr())V[$]!==0&&(Z=Z.mul(X));return Z},q.prototype.iushln=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26,$=67108863>>>26-V<<26-V,X;if(V!==0){var U=0;for(X=0;X<this.length;X++){var H=this.words[X]&$,G=(this.words[X]|0)-H<<V;this.words[X]=G|U,U=H>>>26-V}U&&(this.words[X]=U,this.length++)}if(Z!==0){for(X=this.length-1;X>=0;X--)this.words[X+Z]=this.words[X];for(X=0;X<Z;X++)this.words[X]=0;this.length+=Z}return this.strip()},q.prototype.ishln=function(J){return B(this.negative===0),this.iushln(J)},q.prototype.iushrn=function(J,V,Z){B(typeof J=="number"&&J>=0);var $;V?$=(V-V%26)/26:$=0;var X=J%26,U=Math.min((J-X)/26,this.length),H=67108863^67108863>>>X<<X,G=Z;if($-=U,$=Math.max(0,$),G){for(var Q=0;Q<U;Q++)G.words[Q]=this.words[Q];G.length=U}if(U!==0)if(this.length>U)for(this.length-=U,Q=0;Q<this.length;Q++)this.words[Q]=this.words[Q+U];else this.words[0]=0,this.length=1;var K=0;for(Q=this.length-1;Q>=0&&(K!==0||Q>=$);Q--){var k=this.words[Q]|0;this.words[Q]=K<<26-X|k>>>X,K=k&H}return G&&K!==0&&(G.words[G.length++]=K),this.length===0&&(this.words[0]=0,this.length=1),this.strip()},q.prototype.ishrn=function(J,V,Z){return B(this.negative===0),this.iushrn(J,V,Z)},q.prototype.shln=function(J){return this.clone().ishln(J)},q.prototype.ushln=function(J){return this.clone().iushln(J)},q.prototype.shrn=function(J){return this.clone().ishrn(J)},q.prototype.ushrn=function(J){return this.clone().iushrn(J)},q.prototype.testn=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26,$=1<<V;if(this.length<=Z)return!1;var X=this.words[Z];return!!(X&$)},q.prototype.imaskn=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26;if(B(this.negative===0,"imaskn works only with positive numbers"),this.length<=Z)return this;if(V!==0&&Z++,this.length=Math.min(Z,this.length),V!==0){var $=67108863^67108863>>>V<<V;this.words[this.length-1]&=$}return this.strip()},q.prototype.maskn=function(J){return this.clone().imaskn(J)},q.prototype.iaddn=function(J){return B(typeof J=="number"),B(J<67108864),J<0?this.isubn(-J):this.negative!==0?this.length===1&&(this.words[0]|0)<J?(this.words[0]=J-(this.words[0]|0),this.negative=0,this):(this.negative=0,this.isubn(J),this.negative=1,this):this._iaddn(J)},q.prototype._iaddn=function(J){this.words[0]+=J;for(var V=0;V<this.length&&this.words[V]>=67108864;V++)this.words[V]-=67108864,V===this.length-1?this.words[V+1]=1:this.words[V+1]++;return this.length=Math.max(this.length,V+1),this},q.prototype.isubn=function(J){if(B(typeof J=="number"),B(J<67108864),J<0)return this.iaddn(-J);if(this.negative!==0)return this.negative=0,this.iaddn(J),this.negative=1,this;if(this.words[0]-=J,this.length===1&&this.words[0]<0)this.words[0]=-this.words[0],this.negative=1;else for(var V=0;V<this.length&&this.words[V]<0;V++)this.words[V]+=67108864,this.words[V+1]-=1;return this.strip()},q.prototype.addn=function(J){return this.clone().iaddn(J)},q.prototype.subn=function(J){return this.clone().isubn(J)},q.prototype.iabs=function(){return this.negative=0,this},q.prototype.abs=function(){return this.clone().iabs()},q.prototype._ishlnsubmul=function(J,V,Z){var $=J.length+Z,X;this._expand($);var U,H=0;for(X=0;X<J.length;X++){U=(this.words[X+Z]|0)+H;var G=(J.words[X]|0)*V;U-=G&67108863,H=(U>>26)-(G/67108864|0),this.words[X+Z]=U&67108863}for(;X<this.length-Z;X++)U=(this.words[X+Z]|0)+H,H=U>>26,this.words[X+Z]=U&67108863;if(H===0)return this.strip();for(B(H===-1),H=0,X=0;X<this.length;X++)U=-(this.words[X]|0)+H,H=U>>26,this.words[X]=U&67108863;return this.negative=1,this.strip()},q.prototype._wordDiv=function(J,V){var Z=this.length-J.length,$=this.clone(),X=J,U=X.words[X.length-1]|0,H=this._countBits(U);Z=26-H,Z!==0&&(X=X.ushln(Z),$.iushln(Z),U=X.words[X.length-1]|0);var G=$.length-X.length,Q;if(V!=="mod"){Q=new q(null),Q.length=G+1,Q.words=new Array(Q.length);for(var K=0;K<Q.length;K++)Q.words[K]=0}var k=$.clone()._ishlnsubmul(X,1,G);k.negative===0&&($=k,Q&&(Q.words[G]=1));for(var L=G-1;L>=0;L--){var _=($.words[X.length+L]|0)*67108864+($.words[X.length+L-1]|0);for(_=Math.min(_/U|0,67108863),$._ishlnsubmul(X,_,L);$.negative!==0;)_--,$.negative=0,$._ishlnsubmul(X,1,L),$.isZero()||($.negative^=1);Q&&(Q.words[L]=_)}return Q&&Q.strip(),$.strip(),V!=="div"&&Z!==0&&$.iushrn(Z),{div:Q||null,mod:$}},q.prototype.divmod=function(J,V,Z){if(B(!J.isZero()),this.isZero())return{div:new q(0),mod:new q(0)};var $,X,U;return this.negative!==0&&J.negative===0?(U=this.neg().divmod(J,V),V!=="mod"&&($=U.div.neg()),V!=="div"&&(X=U.mod.neg(),Z&&X.negative!==0&&X.iadd(J)),{div:$,mod:X}):this.negative===0&&J.negative!==0?(U=this.divmod(J.neg(),V),V!=="mod"&&($=U.div.neg()),{div:$,mod:U.mod}):(this.negative&J.negative)!==0?(U=this.neg().divmod(J.neg(),V),V!=="div"&&(X=U.mod.neg(),Z&&X.negative!==0&&X.isub(J)),{div:U.div,mod:X}):J.length>this.length||this.cmp(J)<0?{div:new q(0),mod:this}:J.length===1?V==="div"?{div:this.divn(J.words[0]),mod:null}:V==="mod"?{div:null,mod:new q(this.modn(J.words[0]))}:{div:this.divn(J.words[0]),mod:new q(this.modn(J.words[0]))}:this._wordDiv(J,V)},q.prototype.div=function(J){return this.divmod(J,"div",!1).div},q.prototype.mod=function(J){return this.divmod(J,"mod",!1).mod},q.prototype.umod=function(J){return this.divmod(J,"mod",!0).mod},q.prototype.divRound=function(J){var V=this.divmod(J);if(V.mod.isZero())return V.div;var Z=V.div.negative!==0?V.mod.isub(J):V.mod,$=J.ushrn(1),X=J.andln(1),U=Z.cmp($);return U<0||X===1&&U===0?V.div:V.div.negative!==0?V.div.isubn(1):V.div.iaddn(1)},q.prototype.modn=function(J){B(J<=67108863);for(var V=(1<<26)%J,Z=0,$=this.length-1;$>=0;$--)Z=(V*Z+(this.words[$]|0))%J;return Z},q.prototype.idivn=function(J){B(J<=67108863);for(var V=0,Z=this.length-1;Z>=0;Z--){var $=(this.words[Z]|0)+V*67108864;this.words[Z]=$/J|0,V=$%J}return this.strip()},q.prototype.divn=function(J){return this.clone().idivn(J)},q.prototype.egcd=function(J){B(J.negative===0),B(!J.isZero());var V=this,Z=J.clone();V.negative!==0?V=V.umod(J):V=V.clone();for(var $=new q(1),X=new q(0),U=new q(0),H=new q(1),G=0;V.isEven()&&Z.isEven();)V.iushrn(1),Z.iushrn(1),++G;for(var Q=Z.clone(),K=V.clone();!V.isZero();){for(var k=0,L=1;(V.words[0]&L)===0&&k<26;++k,L<<=1);if(k>0)for(V.iushrn(k);k-- >0;)($.isOdd()||X.isOdd())&&($.iadd(Q),X.isub(K)),$.iushrn(1),X.iushrn(1);for(var _=0,t=1;(Z.words[0]&t)===0&&_<26;++_,t<<=1);if(_>0)for(Z.iushrn(_);_-- >0;)(U.isOdd()||H.isOdd())&&(U.iadd(Q),H.isub(K)),U.iushrn(1),H.iushrn(1);V.cmp(Z)>=0?(V.isub(Z),$.isub(U),X.isub(H)):(Z.isub(V),U.isub($),H.isub(X))}return{a:U,b:H,gcd:Z.iushln(G)}},q.prototype._invmp=function(J){B(J.negative===0),B(!J.isZero());var V=this,Z=J.clone();V.negative!==0?V=V.umod(J):V=V.clone();for(var $=new q(1),X=new q(0),U=Z.clone();V.cmpn(1)>0&&Z.cmpn(1)>0;){for(var H=0,G=1;(V.words[0]&G)===0&&H<26;++H,G<<=1);if(H>0)for(V.iushrn(H);H-- >0;)$.isOdd()&&$.iadd(U),$.iushrn(1);for(var Q=0,K=1;(Z.words[0]&K)===0&&Q<26;++Q,K<<=1);if(Q>0)for(Z.iushrn(Q);Q-- >0;)X.isOdd()&&X.iadd(U),X.iushrn(1);V.cmp(Z)>=0?(V.isub(Z),$.isub(X)):(Z.isub(V),X.isub($))}var k;return V.cmpn(1)===0?k=$:k=X,k.cmpn(0)<0&&k.iadd(J),k},q.prototype.gcd=function(J){if(this.isZero())return J.abs();if(J.isZero())return this.abs();var V=this.clone(),Z=J.clone();V.negative=0,Z.negative=0;for(var $=0;V.isEven()&&Z.isEven();$++)V.iushrn(1),Z.iushrn(1);do{for(;V.isEven();)V.iushrn(1);for(;Z.isEven();)Z.iushrn(1);var X=V.cmp(Z);if(X<0){var U=V;V=Z,Z=U}else if(X===0||Z.cmpn(1)===0)break;V.isub(Z)}while(!0);return Z.iushln($)},q.prototype.invm=function(J){return this.egcd(J).a.umod(J)},q.prototype.isEven=function(){return(this.words[0]&1)===0},q.prototype.isOdd=function(){return(this.words[0]&1)===1},q.prototype.andln=function(J){return this.words[0]&J},q.prototype.bincn=function(J){B(typeof J=="number");var V=J%26,Z=(J-V)/26,$=1<<V;if(this.length<=Z)return this._expand(Z+1),this.words[Z]|=$,this;for(var X=$,U=Z;X!==0&&U<this.length;U++){var H=this.words[U]|0;H+=X,X=H>>>26,H&=67108863,this.words[U]=H}return X!==0&&(this.words[U]=X,this.length++),this},q.prototype.isZero=function(){return this.length===1&&this.words[0]===0},q.prototype.cmpn=function(J){var V=J<0;if(this.negative!==0&&!V)return-1;if(this.negative===0&&V)return 1;this.strip();var Z;if(this.length>1)Z=1;else{V&&(J=-J),B(J<=67108863,"Number is too big");var $=this.words[0]|0;Z=$===J?0:$<J?-1:1}return this.negative!==0?-Z|0:Z},q.prototype.cmp=function(J){if(this.negative!==0&&J.negative===0)return-1;if(this.negative===0&&J.negative!==0)return 1;var V=this.ucmp(J);return this.negative!==0?-V|0:V},q.prototype.ucmp=function(J){if(this.length>J.length)return 1;if(this.length<J.length)return-1;for(var V=0,Z=this.length-1;Z>=0;Z--){var $=this.words[Z]|0,X=J.words[Z]|0;if($!==X){$<X?V=-1:$>X&&(V=1);break}}return V},q.prototype.gtn=function(J){return this.cmpn(J)===1},q.prototype.gt=function(J){return this.cmp(J)===1},q.prototype.gten=function(J){return this.cmpn(J)>=0},q.prototype.gte=function(J){return this.cmp(J)>=0},q.prototype.ltn=function(J){return this.cmpn(J)===-1},q.prototype.lt=function(J){return this.cmp(J)===-1},q.prototype.lten=function(J){return this.cmpn(J)<=0},q.prototype.lte=function(J){return this.cmp(J)<=0},q.prototype.eqn=function(J){return this.cmpn(J)===0},q.prototype.eq=function(J){return this.cmp(J)===0},q.red=function(J){return new o(J)},q.prototype.toRed=function(J){return B(!this.red,"Already a number in reduction context"),B(this.negative===0,"red works only with positives"),J.convertTo(this)._forceRed(J)},q.prototype.fromRed=function(){return B(this.red,"fromRed works only with numbers in reduction context"),this.red.convertFrom(this)},q.prototype._forceRed=function(J){return this.red=J,this},q.prototype.forceRed=function(J){return B(!this.red,"Already a number in reduction context"),this._forceRed(J)},q.prototype.redAdd=function(J){return B(this.red,"redAdd works only with red numbers"),this.red.add(this,J)},q.prototype.redIAdd=function(J){return B(this.red,"redIAdd works only with red numbers"),this.red.iadd(this,J)},q.prototype.redSub=function(J){return B(this.red,"redSub works only with red numbers"),this.red.sub(this,J)},q.prototype.redISub=function(J){return B(this.red,"redISub works only with red numbers"),this.red.isub(this,J)},q.prototype.redShl=function(J){return B(this.red,"redShl works only with red numbers"),this.red.shl(this,J)},q.prototype.redMul=function(J){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,J),this.red.mul(this,J)},q.prototype.redIMul=function(J){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,J),this.red.imul(this,J)},q.prototype.redSqr=function(){return B(this.red,"redSqr works only with red numbers"),this.red._verify1(this),this.red.sqr(this)},q.prototype.redISqr=function(){return B(this.red,"redISqr works only with red numbers"),this.red._verify1(this),this.red.isqr(this)},q.prototype.redSqrt=function(){return B(this.red,"redSqrt works only with red numbers"),this.red._verify1(this),this.red.sqrt(this)},q.prototype.redInvm=function(){return B(this.red,"redInvm works only with red numbers"),this.red._verify1(this),this.red.invm(this)},q.prototype.redNeg=function(){return B(this.red,"redNeg works only with red numbers"),this.red._verify1(this),this.red.neg(this)},q.prototype.redPow=function(J){return B(this.red&&!J.red,"redPow(normalNum)"),this.red._verify1(this),this.red.pow(this,J)};var y={k256:null,p224:null,p192:null,p25519:null};function m(J,V){this.name=J,this.p=new q(V,16),this.n=this.p.bitLength(),this.k=new q(1).iushln(this.n).isub(this.p),this.tmp=this._tmp()}m.prototype._tmp=function(){var J=new q(null);return J.words=new Array(Math.ceil(this.n/13)),J},m.prototype.ireduce=function(J){var V=J,Z;do this.split(V,this.tmp),V=this.imulK(V),V=V.iadd(this.tmp),Z=V.bitLength();while(Z>this.n);var $=Z<this.n?-1:V.ucmp(this.p);return $===0?(V.words[0]=0,V.length=1):$>0?V.isub(this.p):V.strip!==void 0?V.strip():V._strip(),V},m.prototype.split=function(J,V){J.iushrn(this.n,0,V)},m.prototype.imulK=function(J){return J.imul(this.k)};function i(){m.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}A(i,m),i.prototype.split=function(J,V){for(var Z=4194303,$=Math.min(J.length,9),X=0;X<$;X++)V.words[X]=J.words[X];if(V.length=$,J.length<=9){J.words[0]=0,J.length=1;return}var U=J.words[9];for(V.words[V.length++]=U&Z,X=10;X<J.length;X++){var H=J.words[X]|0;J.words[X-10]=(H&Z)<<4|U>>>22,U=H}U>>>=22,J.words[X-10]=U,U===0&&J.length>10?J.length-=10:J.length-=9},i.prototype.imulK=function(J){J.words[J.length]=0,J.words[J.length+1]=0,J.length+=2;for(var V=0,Z=0;Z<J.length;Z++){var $=J.words[Z]|0;V+=$*977,J.words[Z]=V&67108863,V=$*64+(V/67108864|0)}return J.words[J.length-1]===0&&(J.length--,J.words[J.length-1]===0&&J.length--),J};function JJ(){m.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}A(JJ,m);function VJ(){m.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}A(VJ,m);function HJ(){m.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}A(HJ,m),HJ.prototype.imulK=function(J){for(var V=0,Z=0;Z<J.length;Z++){var $=(J.words[Z]|0)*19+V,X=$&67108863;$>>>=26,J.words[Z]=X,V=$}return V!==0&&(J.words[J.length++]=V),J},q._prime=function(J){if(y[J])return y[J];var V;if(J==="k256")V=new i;else if(J==="p224")V=new JJ;else if(J==="p192")V=new VJ;else if(J==="p25519")V=new HJ;else throw new Error("Unknown prime "+J);return y[J]=V,V};function o(J){if(typeof J=="string"){var V=q._prime(J);this.m=V.p,this.prime=V}else B(J.gtn(1),"modulus must be greater than 1"),this.m=J,this.prime=null}o.prototype._verify1=function(J){B(J.negative===0,"red works only with positives"),B(J.red,"red works only with red numbers")},o.prototype._verify2=function(J,V){B((J.negative|V.negative)===0,"red works only with positives"),B(J.red&&J.red===V.red,"red works only with red numbers")},o.prototype.imod=function(J){return this.prime?this.prime.ireduce(J)._forceRed(this):J.umod(this.m)._forceRed(this)},o.prototype.neg=function(J){return J.isZero()?J.clone():this.m.sub(J)._forceRed(this)},o.prototype.add=function(J,V){this._verify2(J,V);var Z=J.add(V);return Z.cmp(this.m)>=0&&Z.isub(this.m),Z._forceRed(this)},o.prototype.iadd=function(J,V){this._verify2(J,V);var Z=J.iadd(V);return Z.cmp(this.m)>=0&&Z.isub(this.m),Z},o.prototype.sub=function(J,V){this._verify2(J,V);var Z=J.sub(V);return Z.cmpn(0)<0&&Z.iadd(this.m),Z._forceRed(this)},o.prototype.isub=function(J,V){this._verify2(J,V);var Z=J.isub(V);return Z.cmpn(0)<0&&Z.iadd(this.m),Z},o.prototype.shl=function(J,V){return this._verify1(J),this.imod(J.ushln(V))},o.prototype.imul=function(J,V){return this._verify2(J,V),this.imod(J.imul(V))},o.prototype.mul=function(J,V){return this._verify2(J,V),this.imod(J.mul(V))},o.prototype.isqr=function(J){return this.imul(J,J.clone())},o.prototype.sqr=function(J){return this.mul(J,J)},o.prototype.sqrt=function(J){if(J.isZero())return J.clone();var V=this.m.andln(3);if(B(V%2===1),V===3){var Z=this.m.add(new q(1)).iushrn(2);return this.pow(J,Z)}for(var $=this.m.subn(1),X=0;!$.isZero()&&$.andln(1)===0;)X++,$.iushrn(1);B(!$.isZero());var U=new q(1).toRed(this),H=U.redNeg(),G=this.m.subn(1).iushrn(1),Q=this.m.bitLength();for(Q=new q(2*Q*Q).toRed(this);this.pow(Q,G).cmp(H)!==0;)Q.redIAdd(H);for(var K=this.pow(Q,$),k=this.pow(J,$.addn(1).iushrn(1)),L=this.pow(J,$),_=X;L.cmp(U)!==0;){for(var t=L,QJ=0;t.cmp(U)!==0;QJ++)t=t.redSqr();B(QJ<_);var GJ=this.pow(K,new q(1).iushln(_-QJ-1));k=k.redMul(GJ),K=GJ.redSqr(),L=L.redMul(K),_=QJ}return k},o.prototype.invm=function(J){var V=J._invmp(this.m);return V.negative!==0?(V.negative=0,this.imod(V).redNeg()):this.imod(V)},o.prototype.pow=function(J,V){if(V.isZero())return new q(1).toRed(this);if(V.cmpn(1)===0)return J.clone();var Z=4,$=new Array(1<<Z);$[0]=new q(1).toRed(this),$[1]=J;for(var X=2;X<$.length;X++)$[X]=this.mul($[X-1],J);var U=$[0],H=0,G=0,Q=V.bitLength()%26;for(Q===0&&(Q=26),X=V.length-1;X>=0;X--){for(var K=V.words[X],k=Q-1;k>=0;k--){var L=K>>k&1;if(U!==$[0]&&(U=this.sqr(U)),L===0&&H===0){G=0;continue}H<<=1,H|=L,G++,!(G!==Z&&(X!==0||k!==0))&&(U=this.mul(U,$[H]),G=0,H=0)}Q=26}return U},o.prototype.convertTo=function(J){var V=J.umod(this.m);return V===J?V.clone():V},o.prototype.convertFrom=function(J){var V=J.clone();return V.red=null,V},q.mont=function(J){return new jJ(J)};function jJ(J){o.call(this,J),this.shift=this.m.bitLength(),this.shift%26!==0&&(this.shift+=26-this.shift%26),this.r=new q(1).iushln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv=this.minv.umod(this.r),this.minv=this.r.sub(this.minv)}A(jJ,o),jJ.prototype.convertTo=function(J){return this.imod(J.ushln(this.shift))},jJ.prototype.convertFrom=function(J){var V=this.imod(J.mul(this.rinv));return V.red=null,V},jJ.prototype.imul=function(J,V){if(J.isZero()||V.isZero())return J.words[0]=0,J.length=1,J;var Z=J.imul(V),$=Z.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),X=Z.isub($).iushrn(this.shift),U=X;return X.cmp(this.m)>=0?U=X.isub(this.m):X.cmpn(0)<0&&(U=X.iadd(this.m)),U._forceRed(this)},jJ.prototype.mul=function(J,V){if(J.isZero()||V.isZero())return new q(0)._forceRed(this);var Z=J.mul(V),$=Z.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),X=Z.isub($).iushrn(this.shift),U=X;return X.cmp(this.m)>=0?U=X.isub(this.m):X.cmpn(0)<0&&(U=X.iadd(this.m)),U._forceRed(this)},jJ.prototype.invm=function(J){var V=this.imod(J._invmp(this.m).mul(this.r2));return V._forceRed(this)}})(typeof g>"u"||g,l)}),K6=OJ((l)=>{var g=l;function R(A,q){if(Array.isArray(A))return A.slice();if(!A)return[];var Y=[];if(typeof A!="string"){for(var E=0;E<A.length;E++)Y[E]=A[E]|0;return Y}if(q==="hex"){A=A.replace(/[^a-z0-9]+/ig,""),A.length%2!==0&&(A="0"+A);for(var E=0;E<A.length;E+=2)Y.push(parseInt(A[E]+A[E+1],16))}else for(var E=0;E<A.length;E++){var O=A.charCodeAt(E),N=O>>8,W=O&255;N?Y.push(N,W):Y.push(W)}return Y}g.toArray=R;function M(A){return A.length===1?"0"+A:A}g.zero2=M;function B(A){for(var q="",Y=0;Y<A.length;Y++)q+=M(A[Y].toString(16));return q}g.toHex=B,g.encode=function(A,q){return q==="hex"?B(A):A}}),mQ=OJ((l)=>{var g=l,R=dQ(),M=hQ(),B=K6();g.assert=M,g.toArray=B.toArray,g.zero2=B.zero2,g.toHex=B.toHex,g.encode=B.encode;function A(N,W,I){var z=new Array(Math.max(N.bitLength(),I)+1);z.fill(0);for(var j=1<<W+1,P=N.clone(),F=0;F<z.length;F++){var v,S=P.andln(j-1);P.isOdd()?(S>(j>>1)-1?v=(j>>1)-S:v=S,P.isubn(v)):v=0,z[F]=v,P.iushrn(1)}return z}g.getNAF=A;function q(N,W){var I=[[],[]];N=N.clone(),W=W.clone();for(var z=0,j=0,P;N.cmpn(-z)>0||W.cmpn(-j)>0;){var F=N.andln(3)+z&3,v=W.andln(3)+j&3;F===3&&(F=-1),v===3&&(v=-1);var S;(F&1)===0?S=0:(P=N.andln(7)+z&7,(P===3||P===5)&&v===2?S=-F:S=F),I[0].push(S);var w;(v&1)===0?w=0:(P=W.andln(7)+j&7,(P===3||P===5)&&F===2?w=-v:w=v),I[1].push(w),2*z===S+1&&(z=1-z),2*j===w+1&&(j=1-j),N.iushrn(1),W.iushrn(1)}return I}g.getJSF=q;function Y(N,W,I){var z="_"+W;N.prototype[W]=function(){return this[z]!==void 0?this[z]:this[z]=I.call(this)}}g.cachedProperty=Y;function E(N){return typeof N=="string"?g.toArray(N,"hex"):N}g.parseBytes=E;function O(N){return new R(N,"hex","le")}g.intFromLE=O}),AV=OJ((l,g)=>{var R=dQ(),M=mQ(),B=M.getNAF,A=M.getJSF,q=M.assert;function Y(O,N){this.type=O,this.p=new R(N.p,16),this.red=N.prime?R.red(N.prime):R.mont(this.p),this.zero=new R(0).toRed(this.red),this.one=new R(1).toRed(this.red),this.two=new R(2).toRed(this.red),this.n=N.n&&new R(N.n,16),this.g=N.g&&this.pointFromJSON(N.g,N.gRed),this._wnafT1=new Array(4),this._wnafT2=new Array(4),this._wnafT3=new Array(4),this._wnafT4=new Array(4),this._bitLength=this.n?this.n.bitLength():0;var W=this.n&&this.p.div(this.n);!W||W.cmpn(100)>0?this.redN=null:(this._maxwellTrick=!0,this.redN=this.n.toRed(this.red))}g.exports=Y,Y.prototype.point=function(){throw new Error("Not implemented")},Y.prototype.validate=function(){throw new Error("Not implemented")},Y.prototype._fixedNafMul=function(O,N){q(O.precomputed);var W=O._getDoubles(),I=B(N,1,this._bitLength),z=(1<<W.step+1)-(W.step%2===0?2:1);z/=3;var j=[],P,F;for(P=0;P<I.length;P+=W.step){F=0;for(var v=P+W.step-1;v>=P;v--)F=(F<<1)+I[v];j.push(F)}for(var S=this.jpoint(null,null,null),w=this.jpoint(null,null,null),y=z;y>0;y--){for(P=0;P<j.length;P++)F=j[P],F===y?w=w.mixedAdd(W.points[P]):F===-y&&(w=w.mixedAdd(W.points[P].neg()));S=S.add(w)}return S.toP()},Y.prototype._wnafMul=function(O,N){var W=4,I=O._getNAFPoints(W);W=I.wnd;for(var z=I.points,j=B(N,W,this._bitLength),P=this.jpoint(null,null,null),F=j.length-1;F>=0;F--){for(var v=0;F>=0&&j[F]===0;F--)v++;if(F>=0&&v++,P=P.dblp(v),F<0)break;var S=j[F];q(S!==0),O.type==="affine"?S>0?P=P.mixedAdd(z[S-1>>1]):P=P.mixedAdd(z[-S-1>>1].neg()):S>0?P=P.add(z[S-1>>1]):P=P.add(z[-S-1>>1].neg())}return O.type==="affine"?P.toP():P},Y.prototype._wnafMulAdd=function(O,N,W,I,z){var j=this._wnafT1,P=this._wnafT2,F=this._wnafT3,v=0,S,w,y;for(S=0;S<I;S++){y=N[S];var m=y._getNAFPoints(O);j[S]=m.wnd,P[S]=m.points}for(S=I-1;S>=1;S-=2){var i=S-1,JJ=S;if(j[i]!==1||j[JJ]!==1){F[i]=B(W[i],j[i],this._bitLength),F[JJ]=B(W[JJ],j[JJ],this._bitLength),v=Math.max(F[i].length,v),v=Math.max(F[JJ].length,v);continue}var VJ=[N[i],null,null,N[JJ]];N[i].y.cmp(N[JJ].y)===0?(VJ[1]=N[i].add(N[JJ]),VJ[2]=N[i].toJ().mixedAdd(N[JJ].neg())):N[i].y.cmp(N[JJ].y.redNeg())===0?(VJ[1]=N[i].toJ().mixedAdd(N[JJ]),VJ[2]=N[i].add(N[JJ].neg())):(VJ[1]=N[i].toJ().mixedAdd(N[JJ]),VJ[2]=N[i].toJ().mixedAdd(N[JJ].neg()));var HJ=[-3,-1,-5,-7,0,7,5,1,3],o=A(W[i],W[JJ]);for(v=Math.max(o[0].length,v),F[i]=new Array(v),F[JJ]=new Array(v),w=0;w<v;w++){var jJ=o[0][w]|0,J=o[1][w]|0;F[i][w]=HJ[(jJ+1)*3+(J+1)],F[JJ][w]=0,P[i]=VJ}}var V=this.jpoint(null,null,null),Z=this._wnafT4;for(S=v;S>=0;S--){for(var $=0;S>=0;){var X=!0;for(w=0;w<I;w++)Z[w]=F[w][S]|0,Z[w]!==0&&(X=!1);if(!X)break;$++,S--}if(S>=0&&$++,V=V.dblp($),S<0)break;for(w=0;w<I;w++){var U=Z[w];U!==0&&(U>0?y=P[w][U-1>>1]:U<0&&(y=P[w][-U-1>>1].neg()),y.type==="affine"?V=V.mixedAdd(y):V=V.add(y))}}for(S=0;S<I;S++)P[S]=null;return z?V:V.toP()};function E(O,N){this.curve=O,this.type=N,this.precomputed=null}Y.BasePoint=E,E.prototype.eq=function(){throw new Error("Not implemented")},E.prototype.validate=function(){return this.curve.validate(this)},Y.prototype.decodePoint=function(O,N){O=M.toArray(O,N);var W=this.p.byteLength();if((O[0]===4||O[0]===6||O[0]===7)&&O.length-1===2*W){O[0]===6?q(O[O.length-1]%2===0):O[0]===7&&q(O[O.length-1]%2===1);var I=this.point(O.slice(1,1+W),O.slice(1+W,1+2*W));return I}else if((O[0]===2||O[0]===3)&&O.length-1===W)return this.pointFromX(O.slice(1,1+W),O[0]===3);throw new Error("Unknown point format")},E.prototype.encodeCompressed=function(O){return this.encode(O,!0)},E.prototype._encode=function(O){var N=this.curve.p.byteLength(),W=this.getX().toArray("be",N);return O?[this.getY().isEven()?2:3].concat(W):[4].concat(W,this.getY().toArray("be",N))},E.prototype.encode=function(O,N){return M.encode(this._encode(N),O)},E.prototype.precompute=function(O){if(this.precomputed)return this;var N={doubles:null,naf:null,beta:null};return N.naf=this._getNAFPoints(8),N.doubles=this._getDoubles(4,O),N.beta=this._getBeta(),this.precomputed=N,this},E.prototype._hasDoubles=function(O){if(!this.precomputed)return!1;var N=this.precomputed.doubles;return N?N.points.length>=Math.ceil((O.bitLength()+1)/N.step):!1},E.prototype._getDoubles=function(O,N){if(this.precomputed&&this.precomputed.doubles)return this.precomputed.doubles;for(var W=[this],I=this,z=0;z<N;z+=O){for(var j=0;j<O;j++)I=I.dbl();W.push(I)}return{step:O,points:W}},E.prototype._getNAFPoints=function(O){if(this.precomputed&&this.precomputed.naf)return this.precomputed.naf;for(var N=[this],W=(1<<O)-1,I=W===1?null:this.dbl(),z=1;z<W;z++)N[z]=N[z-1].add(I);return{wnd:O,points:N}},E.prototype._getBeta=function(){return null},E.prototype.dblp=function(O){for(var N=this,W=0;W<O;W++)N=N.dbl();return N}}),o8=OJ((l,g)=>{var R=mQ(),M=dQ(),B=JQ(),A=AV(),q=R.assert;function Y(N){A.call(this,"short",N),this.a=new M(N.a,16).toRed(this.red),this.b=new M(N.b,16).toRed(this.red),this.tinv=this.two.redInvm(),this.zeroA=this.a.fromRed().cmpn(0)===0,this.threeA=this.a.fromRed().sub(this.p).cmpn(-3)===0,this.endo=this._getEndomorphism(N),this._endoWnafT1=new Array(4),this._endoWnafT2=new Array(4)}B(Y,A),g.exports=Y,Y.prototype._getEndomorphism=function(N){if(!(!this.zeroA||!this.g||!this.n||this.p.modn(3)!==1)){var W,I;if(N.beta)W=new M(N.beta,16).toRed(this.red);else{var z=this._getEndoRoots(this.p);W=z[0].cmp(z[1])<0?z[0]:z[1],W=W.toRed(this.red)}if(N.lambda)I=new M(N.lambda,16);else{var j=this._getEndoRoots(this.n);this.g.mul(j[0]).x.cmp(this.g.x.redMul(W))===0?I=j[0]:(I=j[1],q(this.g.mul(I).x.cmp(this.g.x.redMul(W))===0))}var P;return N.basis?P=N.basis.map(function(F){return{a:new M(F.a,16),b:new M(F.b,16)}}):P=this._getEndoBasis(I),{beta:W,lambda:I,basis:P}}},Y.prototype._getEndoRoots=function(N){var W=N===this.p?this.red:M.mont(N),I=new M(2).toRed(W).redInvm(),z=I.redNeg(),j=new M(3).toRed(W).redNeg().redSqrt().redMul(I),P=z.redAdd(j).fromRed(),F=z.redSub(j).fromRed();return[P,F]},Y.prototype._getEndoBasis=function(N){for(var W=this.n.ushrn(Math.floor(this.n.bitLength()/2)),I=N,z=this.n.clone(),j=new M(1),P=new M(0),F=new M(0),v=new M(1),S,w,y,m,i,JJ,VJ,HJ=0,o,jJ;I.cmpn(0)!==0;){var J=z.div(I);o=z.sub(J.mul(I)),jJ=F.sub(J.mul(j));var V=v.sub(J.mul(P));if(!y&&o.cmp(W)<0)S=VJ.neg(),w=j,y=o.neg(),m=jJ;else if(y&&++HJ===2)break;VJ=o,z=I,I=o,F=j,j=jJ,v=P,P=V}i=o.neg(),JJ=jJ;var Z=y.sqr().add(m.sqr()),$=i.sqr().add(JJ.sqr());return $.cmp(Z)>=0&&(i=S,JJ=w),y.negative&&(y=y.neg(),m=m.neg()),i.negative&&(i=i.neg(),JJ=JJ.neg()),[{a:y,b:m},{a:i,b:JJ}]},Y.prototype._endoSplit=function(N){var W=this.endo.basis,I=W[0],z=W[1],j=z.b.mul(N).divRound(this.n),P=I.b.neg().mul(N).divRound(this.n),F=j.mul(I.a),v=P.mul(z.a),S=j.mul(I.b),w=P.mul(z.b),y=N.sub(F).sub(v),m=S.add(w).neg();return{k1:y,k2:m}},Y.prototype.pointFromX=function(N,W){N=new M(N,16),N.red||(N=N.toRed(this.red));var I=N.redSqr().redMul(N).redIAdd(N.redMul(this.a)).redIAdd(this.b),z=I.redSqrt();if(z.redSqr().redSub(I).cmp(this.zero)!==0)throw new Error("invalid point");var j=z.fromRed().isOdd();return(W&&!j||!W&&j)&&(z=z.redNeg()),this.point(N,z)},Y.prototype.validate=function(N){if(N.inf)return!0;var{x:W,y:I}=N,z=this.a.redMul(W),j=W.redSqr().redMul(W).redIAdd(z).redIAdd(this.b);return I.redSqr().redISub(j).cmpn(0)===0},Y.prototype._endoWnafMulAdd=function(N,W,I){for(var z=this._endoWnafT1,j=this._endoWnafT2,P=0;P<N.length;P++){var F=this._endoSplit(W[P]),v=N[P],S=v._getBeta();F.k1.negative&&(F.k1.ineg(),v=v.neg(!0)),F.k2.negative&&(F.k2.ineg(),S=S.neg(!0)),z[P*2]=v,z[P*2+1]=S,j[P*2]=F.k1,j[P*2+1]=F.k2}for(var w=this._wnafMulAdd(1,z,j,P*2,I),y=0;y<P*2;y++)z[y]=null,j[y]=null;return w};function E(N,W,I,z){A.BasePoint.call(this,N,"affine"),W===null&&I===null?(this.x=null,this.y=null,this.inf=!0):(this.x=new M(W,16),this.y=new M(I,16),z&&(this.x.forceRed(this.curve.red),this.y.forceRed(this.curve.red)),this.x.red||(this.x=this.x.toRed(this.curve.red)),this.y.red||(this.y=this.y.toRed(this.curve.red)),this.inf=!1)}B(E,A.BasePoint),Y.prototype.point=function(N,W,I){return new E(this,N,W,I)},Y.prototype.pointFromJSON=function(N,W){return E.fromJSON(this,N,W)},E.prototype._getBeta=function(){if(this.curve.endo){var N=this.precomputed;if(N&&N.beta)return N.beta;var W=this.curve.point(this.x.redMul(this.curve.endo.beta),this.y);if(N){var I=this.curve,z=function(j){return I.point(j.x.redMul(I.endo.beta),j.y)};N.beta=W,W.precomputed={beta:null,naf:N.naf&&{wnd:N.naf.wnd,points:N.naf.points.map(z)},doubles:N.doubles&&{step:N.doubles.step,points:N.doubles.points.map(z)}}}return W}},E.prototype.toJSON=function(){return this.precomputed?[this.x,this.y,this.precomputed&&{doubles:this.precomputed.doubles&&{step:this.precomputed.doubles.step,points:this.precomputed.doubles.points.slice(1)},naf:this.precomputed.naf&&{wnd:this.precomputed.naf.wnd,points:this.precomputed.naf.points.slice(1)}}]:[this.x,this.y]},E.fromJSON=function(N,W,I){typeof W=="string"&&(W=JSON.parse(W));var z=N.point(W[0],W[1],I);if(!W[2])return z;function j(F){return N.point(F[0],F[1],I)}var P=W[2];return z.precomputed={beta:null,doubles:P.doubles&&{step:P.doubles.step,points:[z].concat(P.doubles.points.map(j))},naf:P.naf&&{wnd:P.naf.wnd,points:[z].concat(P.naf.points.map(j))}},z},E.prototype.inspect=function(){return this.isInfinity()?"<EC Point Infinity>":"<EC Point x: "+this.x.fromRed().toString(16,2)+" y: "+this.y.fromRed().toString(16,2)+">"},E.prototype.isInfinity=function(){return this.inf},E.prototype.add=function(N){if(this.inf)return N;if(N.inf)return this;if(this.eq(N))return this.dbl();if(this.neg().eq(N))return this.curve.point(null,null);if(this.x.cmp(N.x)===0)return this.curve.point(null,null);var W=this.y.redSub(N.y);W.cmpn(0)!==0&&(W=W.redMul(this.x.redSub(N.x).redInvm()));var I=W.redSqr().redISub(this.x).redISub(N.x),z=W.redMul(this.x.redSub(I)).redISub(this.y);return this.curve.point(I,z)},E.prototype.dbl=function(){if(this.inf)return this;var N=this.y.redAdd(this.y);if(N.cmpn(0)===0)return this.curve.point(null,null);var W=this.curve.a,I=this.x.redSqr(),z=N.redInvm(),j=I.redAdd(I).redIAdd(I).redIAdd(W).redMul(z),P=j.redSqr().redISub(this.x.redAdd(this.x)),F=j.redMul(this.x.redSub(P)).redISub(this.y);return this.curve.point(P,F)},E.prototype.getX=function(){return this.x.fromRed()},E.prototype.getY=function(){return this.y.fromRed()},E.prototype.mul=function(N){return N=new M(N,16),this.isInfinity()?this:this._hasDoubles(N)?this.curve._fixedNafMul(this,N):this.curve.endo?this.curve._endoWnafMulAdd([this],[N]):this.curve._wnafMul(this,N)},E.prototype.mulAdd=function(N,W,I){var z=[this,W],j=[N,I];return this.curve.endo?this.curve._endoWnafMulAdd(z,j):this.curve._wnafMulAdd(1,z,j,2)},E.prototype.jmulAdd=function(N,W,I){var z=[this,W],j=[N,I];return this.curve.endo?this.curve._endoWnafMulAdd(z,j,!0):this.curve._wnafMulAdd(1,z,j,2,!0)},E.prototype.eq=function(N){return this===N||this.inf===N.inf&&(this.inf||this.x.cmp(N.x)===0&&this.y.cmp(N.y)===0)},E.prototype.neg=function(N){if(this.inf)return this;var W=this.curve.point(this.x,this.y.redNeg());if(N&&this.precomputed){var I=this.precomputed,z=function(j){return j.neg()};W.precomputed={naf:I.naf&&{wnd:I.naf.wnd,points:I.naf.points.map(z)},doubles:I.doubles&&{step:I.doubles.step,points:I.doubles.points.map(z)}}}return W},E.prototype.toJ=function(){if(this.inf)return this.curve.jpoint(null,null,null);var N=this.curve.jpoint(this.x,this.y,this.curve.one);return N};function O(N,W,I,z){A.BasePoint.call(this,N,"jacobian"),W===null&&I===null&&z===null?(this.x=this.curve.one,this.y=this.curve.one,this.z=new M(0)):(this.x=new M(W,16),this.y=new M(I,16),this.z=new M(z,16)),this.x.red||(this.x=this.x.toRed(this.curve.red)),this.y.red||(this.y=this.y.toRed(this.curve.red)),this.z.red||(this.z=this.z.toRed(this.curve.red)),this.zOne=this.z===this.curve.one}B(O,A.BasePoint),Y.prototype.jpoint=function(N,W,I){return new O(this,N,W,I)},O.prototype.toP=function(){if(this.isInfinity())return this.curve.point(null,null);var N=this.z.redInvm(),W=N.redSqr(),I=this.x.redMul(W),z=this.y.redMul(W).redMul(N);return this.curve.point(I,z)},O.prototype.neg=function(){return this.curve.jpoint(this.x,this.y.redNeg(),this.z)},O.prototype.add=function(N){if(this.isInfinity())return N;if(N.isInfinity())return this;var W=N.z.redSqr(),I=this.z.redSqr(),z=this.x.redMul(W),j=N.x.redMul(I),P=this.y.redMul(W.redMul(N.z)),F=N.y.redMul(I.redMul(this.z)),v=z.redSub(j),S=P.redSub(F);if(v.cmpn(0)===0)return S.cmpn(0)!==0?this.curve.jpoint(null,null,null):this.dbl();var w=v.redSqr(),y=w.redMul(v),m=z.redMul(w),i=S.redSqr().redIAdd(y).redISub(m).redISub(m),JJ=S.redMul(m.redISub(i)).redISub(P.redMul(y)),VJ=this.z.redMul(N.z).redMul(v);return this.curve.jpoint(i,JJ,VJ)},O.prototype.mixedAdd=function(N){if(this.isInfinity())return N.toJ();if(N.isInfinity())return this;var W=this.z.redSqr(),I=this.x,z=N.x.redMul(W),j=this.y,P=N.y.redMul(W).redMul(this.z),F=I.redSub(z),v=j.redSub(P);if(F.cmpn(0)===0)return v.cmpn(0)!==0?this.curve.jpoint(null,null,null):this.dbl();var S=F.redSqr(),w=S.redMul(F),y=I.redMul(S),m=v.redSqr().redIAdd(w).redISub(y).redISub(y),i=v.redMul(y.redISub(m)).redISub(j.redMul(w)),JJ=this.z.redMul(F);return this.curve.jpoint(m,i,JJ)},O.prototype.dblp=function(N){if(N===0)return this;if(this.isInfinity())return this;if(!N)return this.dbl();var W;if(this.curve.zeroA||this.curve.threeA){var I=this;for(W=0;W<N;W++)I=I.dbl();return I}var z=this.curve.a,j=this.curve.tinv,P=this.x,F=this.y,v=this.z,S=v.redSqr().redSqr(),w=F.redAdd(F);for(W=0;W<N;W++){var y=P.redSqr(),m=w.redSqr(),i=m.redSqr(),JJ=y.redAdd(y).redIAdd(y).redIAdd(z.redMul(S)),VJ=P.redMul(m),HJ=JJ.redSqr().redISub(VJ.redAdd(VJ)),o=VJ.redISub(HJ),jJ=JJ.redMul(o);jJ=jJ.redIAdd(jJ).redISub(i);var J=w.redMul(v);W+1<N&&(S=S.redMul(i)),P=HJ,v=J,w=jJ}return this.curve.jpoint(P,w.redMul(j),v)},O.prototype.dbl=function(){return this.isInfinity()?this:this.curve.zeroA?this._zeroDbl():this.curve.threeA?this._threeDbl():this._dbl()},O.prototype._zeroDbl=function(){var N,W,I;if(this.zOne){var z=this.x.redSqr(),j=this.y.redSqr(),P=j.redSqr(),F=this.x.redAdd(j).redSqr().redISub(z).redISub(P);F=F.redIAdd(F);var v=z.redAdd(z).redIAdd(z),S=v.redSqr().redISub(F).redISub(F),w=P.redIAdd(P);w=w.redIAdd(w),w=w.redIAdd(w),N=S,W=v.redMul(F.redISub(S)).redISub(w),I=this.y.redAdd(this.y)}else{var y=this.x.redSqr(),m=this.y.redSqr(),i=m.redSqr(),JJ=this.x.redAdd(m).redSqr().redISub(y).redISub(i);JJ=JJ.redIAdd(JJ);var VJ=y.redAdd(y).redIAdd(y),HJ=VJ.redSqr(),o=i.redIAdd(i);o=o.redIAdd(o),o=o.redIAdd(o),N=HJ.redISub(JJ).redISub(JJ),W=VJ.redMul(JJ.redISub(N)).redISub(o),I=this.y.redMul(this.z),I=I.redIAdd(I)}return this.curve.jpoint(N,W,I)},O.prototype._threeDbl=function(){var N,W,I;if(this.zOne){var z=this.x.redSqr(),j=this.y.redSqr(),P=j.redSqr(),F=this.x.redAdd(j).redSqr().redISub(z).redISub(P);F=F.redIAdd(F);var v=z.redAdd(z).redIAdd(z).redIAdd(this.curve.a),S=v.redSqr().redISub(F).redISub(F);N=S;var w=P.redIAdd(P);w=w.redIAdd(w),w=w.redIAdd(w),W=v.redMul(F.redISub(S)).redISub(w),I=this.y.redAdd(this.y)}else{var y=this.z.redSqr(),m=this.y.redSqr(),i=this.x.redMul(m),JJ=this.x.redSub(y).redMul(this.x.redAdd(y));JJ=JJ.redAdd(JJ).redIAdd(JJ);var VJ=i.redIAdd(i);VJ=VJ.redIAdd(VJ);var HJ=VJ.redAdd(VJ);N=JJ.redSqr().redISub(HJ),I=this.y.redAdd(this.z).redSqr().redISub(m).redISub(y);var o=m.redSqr();o=o.redIAdd(o),o=o.redIAdd(o),o=o.redIAdd(o),W=JJ.redMul(VJ.redISub(N)).redISub(o)}return this.curve.jpoint(N,W,I)},O.prototype._dbl=function(){var N=this.curve.a,W=this.x,I=this.y,z=this.z,j=z.redSqr().redSqr(),P=W.redSqr(),F=I.redSqr(),v=P.redAdd(P).redIAdd(P).redIAdd(N.redMul(j)),S=W.redAdd(W);S=S.redIAdd(S);var w=S.redMul(F),y=v.redSqr().redISub(w.redAdd(w)),m=w.redISub(y),i=F.redSqr();i=i.redIAdd(i),i=i.redIAdd(i),i=i.redIAdd(i);var JJ=v.redMul(m).redISub(i),VJ=I.redAdd(I).redMul(z);return this.curve.jpoint(y,JJ,VJ)},O.prototype.trpl=function(){if(!this.curve.zeroA)return this.dbl().add(this);var N=this.x.redSqr(),W=this.y.redSqr(),I=this.z.redSqr(),z=W.redSqr(),j=N.redAdd(N).redIAdd(N),P=j.redSqr(),F=this.x.redAdd(W).redSqr().redISub(N).redISub(z);F=F.redIAdd(F),F=F.redAdd(F).redIAdd(F),F=F.redISub(P);var v=F.redSqr(),S=z.redIAdd(z);S=S.redIAdd(S),S=S.redIAdd(S),S=S.redIAdd(S);var w=j.redIAdd(F).redSqr().redISub(P).redISub(v).redISub(S),y=W.redMul(w);y=y.redIAdd(y),y=y.redIAdd(y);var m=this.x.redMul(v).redISub(y);m=m.redIAdd(m),m=m.redIAdd(m);var i=this.y.redMul(w.redMul(S.redISub(w)).redISub(F.redMul(v)));i=i.redIAdd(i),i=i.redIAdd(i),i=i.redIAdd(i);var JJ=this.z.redAdd(F).redSqr().redISub(I).redISub(v);return this.curve.jpoint(m,i,JJ)},O.prototype.mul=function(N,W){return N=new M(N,W),this.curve._wnafMul(this,N)},O.prototype.eq=function(N){if(N.type==="affine")return this.eq(N.toJ());if(this===N)return!0;var W=this.z.redSqr(),I=N.z.redSqr();if(this.x.redMul(I).redISub(N.x.redMul(W)).cmpn(0)!==0)return!1;var z=W.redMul(this.z),j=I.redMul(N.z);return this.y.redMul(j).redISub(N.y.redMul(z)).cmpn(0)===0},O.prototype.eqXToP=function(N){var W=this.z.redSqr(),I=N.toRed(this.curve.red).redMul(W);if(this.x.cmp(I)===0)return!0;for(var z=N.clone(),j=this.curve.redN.redMul(W);;){if(z.iadd(this.curve.n),z.cmp(this.curve.p)>=0)return!1;if(I.redIAdd(j),this.x.cmp(I)===0)return!0}},O.prototype.inspect=function(){return this.isInfinity()?"<EC JPoint Infinity>":"<EC JPoint x: "+this.x.toString(16,2)+" y: "+this.y.toString(16,2)+" z: "+this.z.toString(16,2)+">"},O.prototype.isInfinity=function(){return this.z.cmpn(0)===0}}),r8=OJ((l,g)=>{var R=dQ(),M=JQ(),B=AV(),A=mQ();function q(E){B.call(this,"mont",E),this.a=new R(E.a,16).toRed(this.red),this.b=new R(E.b,16).toRed(this.red),this.i4=new R(4).toRed(this.red).redInvm(),this.two=new R(2).toRed(this.red),this.a24=this.i4.redMul(this.a.redAdd(this.two))}M(q,B),g.exports=q,q.prototype.validate=function(E){var O=E.normalize().x,N=O.redSqr(),W=N.redMul(O).redAdd(N.redMul(this.a)).redAdd(O),I=W.redSqrt();return I.redSqr().cmp(W)===0};function Y(E,O,N){B.BasePoint.call(this,E,"projective"),O===null&&N===null?(this.x=this.curve.one,this.z=this.curve.zero):(this.x=new R(O,16),this.z=new R(N,16),this.x.red||(this.x=this.x.toRed(this.curve.red)),this.z.red||(this.z=this.z.toRed(this.curve.red)))}M(Y,B.BasePoint),q.prototype.decodePoint=function(E,O){return this.point(A.toArray(E,O),1)},q.prototype.point=function(E,O){return new Y(this,E,O)},q.prototype.pointFromJSON=function(E){return Y.fromJSON(this,E)},Y.prototype.precompute=function(){},Y.prototype._encode=function(){return this.getX().toArray("be",this.curve.p.byteLength())},Y.fromJSON=function(E,O){return new Y(E,O[0],O[1]||E.one)},Y.prototype.inspect=function(){return this.isInfinity()?"<EC Point Infinity>":"<EC Point x: "+this.x.fromRed().toString(16,2)+" z: "+this.z.fromRed().toString(16,2)+">"},Y.prototype.isInfinity=function(){return this.z.cmpn(0)===0},Y.prototype.dbl=function(){var E=this.x.redAdd(this.z),O=E.redSqr(),N=this.x.redSub(this.z),W=N.redSqr(),I=O.redSub(W),z=O.redMul(W),j=I.redMul(W.redAdd(this.curve.a24.redMul(I)));return this.curve.point(z,j)},Y.prototype.add=function(){throw new Error("Not supported on Montgomery curve")},Y.prototype.diffAdd=function(E,O){var N=this.x.redAdd(this.z),W=this.x.redSub(this.z),I=E.x.redAdd(E.z),z=E.x.redSub(E.z),j=z.redMul(N),P=I.redMul(W),F=O.z.redMul(j.redAdd(P).redSqr()),v=O.x.redMul(j.redISub(P).redSqr());return this.curve.point(F,v)},Y.prototype.mul=function(E){for(var O=E.clone(),N=this,W=this.curve.point(null,null),I=this,z=[];O.cmpn(0)!==0;O.iushrn(1))z.push(O.andln(1));for(var j=z.length-1;j>=0;j--)z[j]===0?(N=N.diffAdd(W,I),W=W.dbl()):(W=N.diffAdd(W,I),N=N.dbl());return W},Y.prototype.mulAdd=function(){throw new Error("Not supported on Montgomery curve")},Y.prototype.jumlAdd=function(){throw new Error("Not supported on Montgomery curve")},Y.prototype.eq=function(E){return this.getX().cmp(E.getX())===0},Y.prototype.normalize=function(){return this.x=this.x.redMul(this.z.redInvm()),this.z=this.curve.one,this},Y.prototype.getX=function(){return this.normalize(),this.x.fromRed()}}),a8=OJ((l,g)=>{var R=mQ(),M=dQ(),B=JQ(),A=AV(),q=R.assert;function Y(O){this.twisted=(O.a|0)!==1,this.mOneA=this.twisted&&(O.a|0)===-1,this.extended=this.mOneA,A.call(this,"edwards",O),this.a=new M(O.a,16).umod(this.red.m),this.a=this.a.toRed(this.red),this.c=new M(O.c,16).toRed(this.red),this.c2=this.c.redSqr(),this.d=new M(O.d,16).toRed(this.red),this.dd=this.d.redAdd(this.d),q(!this.twisted||this.c.fromRed().cmpn(1)===0),this.oneC=(O.c|0)===1}B(Y,A),g.exports=Y,Y.prototype._mulA=function(O){return this.mOneA?O.redNeg():this.a.redMul(O)},Y.prototype._mulC=function(O){return this.oneC?O:this.c.redMul(O)},Y.prototype.jpoint=function(O,N,W,I){return this.point(O,N,W,I)},Y.prototype.pointFromX=function(O,N){O=new M(O,16),O.red||(O=O.toRed(this.red));var W=O.redSqr(),I=this.c2.redSub(this.a.redMul(W)),z=this.one.redSub(this.c2.redMul(this.d).redMul(W)),j=I.redMul(z.redInvm()),P=j.redSqrt();if(P.redSqr().redSub(j).cmp(this.zero)!==0)throw new Error("invalid point");var F=P.fromRed().isOdd();return(N&&!F||!N&&F)&&(P=P.redNeg()),this.point(O,P)},Y.prototype.pointFromY=function(O,N){O=new M(O,16),O.red||(O=O.toRed(this.red));var W=O.redSqr(),I=W.redSub(this.c2),z=W.redMul(this.d).redMul(this.c2).redSub(this.a),j=I.redMul(z.redInvm());if(j.cmp(this.zero)===0){if(N)throw new Error("invalid point");return this.point(this.zero,O)}var P=j.redSqrt();if(P.redSqr().redSub(j).cmp(this.zero)!==0)throw new Error("invalid point");return P.fromRed().isOdd()!==N&&(P=P.redNeg()),this.point(P,O)},Y.prototype.validate=function(O){if(O.isInfinity())return!0;O.normalize();var N=O.x.redSqr(),W=O.y.redSqr(),I=N.redMul(this.a).redAdd(W),z=this.c2.redMul(this.one.redAdd(this.d.redMul(N).redMul(W)));return I.cmp(z)===0};function E(O,N,W,I,z){A.BasePoint.call(this,O,"projective"),N===null&&W===null&&I===null?(this.x=this.curve.zero,this.y=this.curve.one,this.z=this.curve.one,this.t=this.curve.zero,this.zOne=!0):(this.x=new M(N,16),this.y=new M(W,16),this.z=I?new M(I,16):this.curve.one,this.t=z&&new M(z,16),this.x.red||(this.x=this.x.toRed(this.curve.red)),this.y.red||(this.y=this.y.toRed(this.curve.red)),this.z.red||(this.z=this.z.toRed(this.curve.red)),this.t&&!this.t.red&&(this.t=this.t.toRed(this.curve.red)),this.zOne=this.z===this.curve.one,this.curve.extended&&!this.t&&(this.t=this.x.redMul(this.y),this.zOne||(this.t=this.t.redMul(this.z.redInvm()))))}B(E,A.BasePoint),Y.prototype.pointFromJSON=function(O){return E.fromJSON(this,O)},Y.prototype.point=function(O,N,W,I){return new E(this,O,N,W,I)},E.fromJSON=function(O,N){return new E(O,N[0],N[1],N[2])},E.prototype.inspect=function(){return this.isInfinity()?"<EC Point Infinity>":"<EC Point x: "+this.x.fromRed().toString(16,2)+" y: "+this.y.fromRed().toString(16,2)+" z: "+this.z.fromRed().toString(16,2)+">"},E.prototype.isInfinity=function(){return this.x.cmpn(0)===0&&(this.y.cmp(this.z)===0||this.zOne&&this.y.cmp(this.curve.c)===0)},E.prototype._extDbl=function(){var O=this.x.redSqr(),N=this.y.redSqr(),W=this.z.redSqr();W=W.redIAdd(W);var I=this.curve._mulA(O),z=this.x.redAdd(this.y).redSqr().redISub(O).redISub(N),j=I.redAdd(N),P=j.redSub(W),F=I.redSub(N),v=z.redMul(P),S=j.redMul(F),w=z.redMul(F),y=P.redMul(j);return this.curve.point(v,S,y,w)},E.prototype._projDbl=function(){var O=this.x.redAdd(this.y).redSqr(),N=this.x.redSqr(),W=this.y.redSqr(),I,z,j,P,F,v;if(this.curve.twisted){P=this.curve._mulA(N);var S=P.redAdd(W);this.zOne?(I=O.redSub(N).redSub(W).redMul(S.redSub(this.curve.two)),z=S.redMul(P.redSub(W)),j=S.redSqr().redSub(S).redSub(S)):(F=this.z.redSqr(),v=S.redSub(F).redISub(F),I=O.redSub(N).redISub(W).redMul(v),z=S.redMul(P.redSub(W)),j=S.redMul(v))}else P=N.redAdd(W),F=this.curve._mulC(this.z).redSqr(),v=P.redSub(F).redSub(F),I=this.curve._mulC(O.redISub(P)).redMul(v),z=this.curve._mulC(P).redMul(N.redISub(W)),j=P.redMul(v);return this.curve.point(I,z,j)},E.prototype.dbl=function(){return this.isInfinity()?this:this.curve.extended?this._extDbl():this._projDbl()},E.prototype._extAdd=function(O){var N=this.y.redSub(this.x).redMul(O.y.redSub(O.x)),W=this.y.redAdd(this.x).redMul(O.y.redAdd(O.x)),I=this.t.redMul(this.curve.dd).redMul(O.t),z=this.z.redMul(O.z.redAdd(O.z)),j=W.redSub(N),P=z.redSub(I),F=z.redAdd(I),v=W.redAdd(N),S=j.redMul(P),w=F.redMul(v),y=j.redMul(v),m=P.redMul(F);return this.curve.point(S,w,m,y)},E.prototype._projAdd=function(O){var N=this.z.redMul(O.z),W=N.redSqr(),I=this.x.redMul(O.x),z=this.y.redMul(O.y),j=this.curve.d.redMul(I).redMul(z),P=W.redSub(j),F=W.redAdd(j),v=this.x.redAdd(this.y).redMul(O.x.redAdd(O.y)).redISub(I).redISub(z),S=N.redMul(P).redMul(v),w,y;return this.curve.twisted?(w=N.redMul(F).redMul(z.redSub(this.curve._mulA(I))),y=P.redMul(F)):(w=N.redMul(F).redMul(z.redSub(I)),y=this.curve._mulC(P).redMul(F)),this.curve.point(S,w,y)},E.prototype.add=function(O){return this.isInfinity()?O:O.isInfinity()?this:this.curve.extended?this._extAdd(O):this._projAdd(O)},E.prototype.mul=function(O){return this._hasDoubles(O)?this.curve._fixedNafMul(this,O):this.curve._wnafMul(this,O)},E.prototype.mulAdd=function(O,N,W){return this.curve._wnafMulAdd(1,[this,N],[O,W],2,!1)},E.prototype.jmulAdd=function(O,N,W){return this.curve._wnafMulAdd(1,[this,N],[O,W],2,!0)},E.prototype.normalize=function(){if(this.zOne)return this;var O=this.z.redInvm();return this.x=this.x.redMul(O),this.y=this.y.redMul(O),this.t&&(this.t=this.t.redMul(O)),this.z=this.curve.one,this.zOne=!0,this},E.prototype.neg=function(){return this.curve.point(this.x.redNeg(),this.y,this.z,this.t&&this.t.redNeg())},E.prototype.getX=function(){return this.normalize(),this.x.fromRed()},E.prototype.getY=function(){return this.normalize(),this.y.fromRed()},E.prototype.eq=function(O){return this===O||this.getX().cmp(O.getX())===0&&this.getY().cmp(O.getY())===0},E.prototype.eqXToP=function(O){var N=O.toRed(this.curve.red).redMul(this.z);if(this.x.cmp(N)===0)return!0;for(var W=O.clone(),I=this.curve.redN.redMul(this.z);;){if(W.iadd(this.curve.n),W.cmp(this.curve.p)>=0)return!1;if(N.redIAdd(I),this.x.cmp(N)===0)return!0}},E.prototype.toP=E.prototype.normalize,E.prototype.mixedAdd=E.prototype.add}),U6=OJ((l)=>{var g=l;g.base=AV(),g.short=o8(),g.mont=r8(),g.edwards=a8()}),pQ=OJ((l)=>{var g=hQ(),R=JQ();l.inherits=R;function M(V,Z){return(V.charCodeAt(Z)&64512)!==55296||Z<0||Z+1>=V.length?!1:(V.charCodeAt(Z+1)&64512)===56320}function B(V,Z){if(Array.isArray(V))return V.slice();if(!V)return[];var $=[];if(typeof V=="string")if(Z){if(Z==="hex")for(V=V.replace(/[^a-z0-9]+/ig,""),V.length%2!==0&&(V="0"+V),U=0;U<V.length;U+=2)$.push(parseInt(V[U]+V[U+1],16))}else for(var X=0,U=0;U<V.length;U++){var H=V.charCodeAt(U);H<128?$[X++]=H:H<2048?($[X++]=H>>6|192,$[X++]=H&63|128):M(V,U)?(H=65536+((H&1023)<<10)+(V.charCodeAt(++U)&1023),$[X++]=H>>18|240,$[X++]=H>>12&63|128,$[X++]=H>>6&63|128,$[X++]=H&63|128):($[X++]=H>>12|224,$[X++]=H>>6&63|128,$[X++]=H&63|128)}else for(U=0;U<V.length;U++)$[U]=V[U]|0;return $}l.toArray=B;function A(V){for(var Z="",$=0;$<V.length;$++)Z+=E(V[$].toString(16));return Z}l.toHex=A;function q(V){var Z=V>>>24|V>>>8&65280|V<<8&16711680|(V&255)<<24;return Z>>>0}l.htonl=q;function Y(V,Z){for(var $="",X=0;X<V.length;X++){var U=V[X];Z==="little"&&(U=q(U)),$+=O(U.toString(16))}return $}l.toHex32=Y;function E(V){return V.length===1?"0"+V:V}l.zero2=E;function O(V){return V.length===7?"0"+V:V.length===6?"00"+V:V.length===5?"000"+V:V.length===4?"0000"+V:V.length===3?"00000"+V:V.length===2?"000000"+V:V.length===1?"0000000"+V:V}l.zero8=O;function N(V,Z,$,X){var U=$-Z;g(U%4===0);for(var H=new Array(U/4),G=0,Q=Z;G<H.length;G++,Q+=4){var K;X==="big"?K=V[Q]<<24|V[Q+1]<<16|V[Q+2]<<8|V[Q+3]:K=V[Q+3]<<24|V[Q+2]<<16|V[Q+1]<<8|V[Q],H[G]=K>>>0}return H}l.join32=N;function W(V,Z){for(var $=new Array(V.length*4),X=0,U=0;X<V.length;X++,U+=4){var H=V[X];Z==="big"?($[U]=H>>>24,$[U+1]=H>>>16&255,$[U+2]=H>>>8&255,$[U+3]=H&255):($[U+3]=H>>>24,$[U+2]=H>>>16&255,$[U+1]=H>>>8&255,$[U]=H&255)}return $}l.split32=W;function I(V,Z){return V>>>Z|V<<32-Z}l.rotr32=I;function z(V,Z){return V<<Z|V>>>32-Z}l.rotl32=z;function j(V,Z){return V+Z>>>0}l.sum32=j;function P(V,Z,$){return V+Z+$>>>0}l.sum32_3=P;function F(V,Z,$,X){return V+Z+$+X>>>0}l.sum32_4=F;function v(V,Z,$,X,U){return V+Z+$+X+U>>>0}l.sum32_5=v;function S(V,Z,$,X){var U=V[Z],H=V[Z+1],G=X+H>>>0,Q=(G<X?1:0)+$+U;V[Z]=Q>>>0,V[Z+1]=G}l.sum64=S;function w(V,Z,$,X){var U=Z+X>>>0,H=(U<Z?1:0)+V+$;return H>>>0}l.sum64_hi=w;function y(V,Z,$,X){var U=Z+X;return U>>>0}l.sum64_lo=y;function m(V,Z,$,X,U,H,G,Q){var K=0,k=Z;k=k+X>>>0,K+=k<Z?1:0,k=k+H>>>0,K+=k<H?1:0,k=k+Q>>>0,K+=k<Q?1:0;var L=V+$+U+G+K;return L>>>0}l.sum64_4_hi=m;function i(V,Z,$,X,U,H,G,Q){var K=Z+X+H+Q;return K>>>0}l.sum64_4_lo=i;function JJ(V,Z,$,X,U,H,G,Q,K,k){var L=0,_=Z;_=_+X>>>0,L+=_<Z?1:0,_=_+H>>>0,L+=_<H?1:0,_=_+Q>>>0,L+=_<Q?1:0,_=_+k>>>0,L+=_<k?1:0;var t=V+$+U+G+K+L;return t>>>0}l.sum64_5_hi=JJ;function VJ(V,Z,$,X,U,H,G,Q,K,k){var L=Z+X+H+Q+k;return L>>>0}l.sum64_5_lo=VJ;function HJ(V,Z,$){var X=Z<<32-$|V>>>$;return X>>>0}l.rotr64_hi=HJ;function o(V,Z,$){var X=V<<32-$|Z>>>$;return X>>>0}l.rotr64_lo=o;function jJ(V,Z,$){return V>>>$}l.shr64_hi=jJ;function J(V,Z,$){var X=V<<32-$|Z>>>$;return X>>>0}l.shr64_lo=J}),BV=OJ((l)=>{var g=pQ(),R=hQ();function M(){this.pending=null,this.pendingTotal=0,this.blockSize=this.constructor.blockSize,this.outSize=this.constructor.outSize,this.hmacStrength=this.constructor.hmacStrength,this.padLength=this.constructor.padLength/8,this.endian="big",this._delta8=this.blockSize/8,this._delta32=this.blockSize/32}l.BlockHash=M,M.prototype.update=function(B,A){if(B=g.toArray(B,A),this.pending?this.pending=this.pending.concat(B):this.pending=B,this.pendingTotal+=B.length,this.pending.length>=this._delta8){B=this.pending;var q=B.length%this._delta8;this.pending=B.slice(B.length-q,B.length),this.pending.length===0&&(this.pending=null),B=g.join32(B,0,B.length-q,this.endian);for(var Y=0;Y<B.length;Y+=this._delta32)this._update(B,Y,Y+this._delta32)}return this},M.prototype.digest=function(B){return this.update(this._pad()),R(this.pending===null),this._digest(B)},M.prototype._pad=function(){var B=this.pendingTotal,A=this._delta8,q=A-(B+this.padLength)%A,Y=new Array(q+this.padLength);Y[0]=128;for(var E=1;E<q;E++)Y[E]=0;if(B<<=3,this.endian==="big"){for(var O=8;O<this.padLength;O++)Y[E++]=0;Y[E++]=0,Y[E++]=0,Y[E++]=0,Y[E++]=0,Y[E++]=B>>>24&255,Y[E++]=B>>>16&255,Y[E++]=B>>>8&255,Y[E++]=B&255}else for(Y[E++]=B&255,Y[E++]=B>>>8&255,Y[E++]=B>>>16&255,Y[E++]=B>>>24&255,Y[E++]=0,Y[E++]=0,Y[E++]=0,Y[E++]=0,O=8;O<this.padLength;O++)Y[E++]=0;return Y}}),H6=OJ((l)=>{var g=pQ(),R=g.rotr32;function M(W,I,z,j){if(W===0)return B(I,z,j);if(W===1||W===3)return q(I,z,j);if(W===2)return A(I,z,j)}l.ft_1=M;function B(W,I,z){return W&I^~W&z}l.ch32=B;function A(W,I,z){return W&I^W&z^I&z}l.maj32=A;function q(W,I,z){return W^I^z}l.p32=q;function Y(W){return R(W,2)^R(W,13)^R(W,22)}l.s0_256=Y;function E(W){return R(W,6)^R(W,11)^R(W,25)}l.s1_256=E;function O(W){return R(W,7)^R(W,18)^W>>>3}l.g0_256=O;function N(W){return R(W,17)^R(W,19)^W>>>10}l.g1_256=N}),t8=OJ((l,g)=>{var R=pQ(),M=BV(),B=H6(),A=R.rotl32,q=R.sum32,Y=R.sum32_5,E=B.ft_1,O=M.BlockHash,N=[1518500249,1859775393,2400959708,3395469782];function W(){if(!(this instanceof W))return new W;O.call(this),this.h=[1732584193,4023233417,2562383102,271733878,3285377520],this.W=new Array(80)}R.inherits(W,O),g.exports=W,W.blockSize=512,W.outSize=160,W.hmacStrength=80,W.padLength=64,W.prototype._update=function(I,z){for(var j=this.W,P=0;P<16;P++)j[P]=I[z+P];for(;P<j.length;P++)j[P]=A(j[P-3]^j[P-8]^j[P-14]^j[P-16],1);var F=this.h[0],v=this.h[1],S=this.h[2],w=this.h[3],y=this.h[4];for(P=0;P<j.length;P++){var m=~~(P/20),i=Y(A(F,5),E(m,v,S,w),y,j[P],N[m]);y=w,w=S,S=A(v,30),v=F,F=i}this.h[0]=q(this.h[0],F),this.h[1]=q(this.h[1],v),this.h[2]=q(this.h[2],S),this.h[3]=q(this.h[3],w),this.h[4]=q(this.h[4],y)},W.prototype._digest=function(I){return I==="hex"?R.toHex32(this.h,"big"):R.split32(this.h,"big")}}),W6=OJ((l,g)=>{var R=pQ(),M=BV(),B=H6(),A=hQ(),q=R.sum32,Y=R.sum32_4,E=R.sum32_5,O=B.ch32,N=B.maj32,W=B.s0_256,I=B.s1_256,z=B.g0_256,j=B.g1_256,P=M.BlockHash,F=[1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298];function v(){if(!(this instanceof v))return new v;P.call(this),this.h=[1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225],this.k=F,this.W=new Array(64)}R.inherits(v,P),g.exports=v,v.blockSize=512,v.outSize=256,v.hmacStrength=192,v.padLength=64,v.prototype._update=function(S,w){for(var y=this.W,m=0;m<16;m++)y[m]=S[w+m];for(;m<y.length;m++)y[m]=Y(j(y[m-2]),y[m-7],z(y[m-15]),y[m-16]);var i=this.h[0],JJ=this.h[1],VJ=this.h[2],HJ=this.h[3],o=this.h[4],jJ=this.h[5],J=this.h[6],V=this.h[7];for(A(this.k.length===y.length),m=0;m<y.length;m++){var Z=E(V,I(o),O(o,jJ,J),this.k[m],y[m]),$=q(W(i),N(i,JJ,VJ));V=J,J=jJ,jJ=o,o=q(HJ,Z),HJ=VJ,VJ=JJ,JJ=i,i=q(Z,$)}this.h[0]=q(this.h[0],i),this.h[1]=q(this.h[1],JJ),this.h[2]=q(this.h[2],VJ),this.h[3]=q(this.h[3],HJ),this.h[4]=q(this.h[4],o),this.h[5]=q(this.h[5],jJ),this.h[6]=q(this.h[6],J),this.h[7]=q(this.h[7],V)},v.prototype._digest=function(S){return S==="hex"?R.toHex32(this.h,"big"):R.split32(this.h,"big")}}),e8=OJ((l,g)=>{var R=pQ(),M=W6();function B(){if(!(this instanceof B))return new B;M.call(this),this.h=[3238371032,914150663,812702999,4144912697,4290775857,1750603025,1694076839,3204075428]}R.inherits(B,M),g.exports=B,B.blockSize=512,B.outSize=224,B.hmacStrength=192,B.padLength=64,B.prototype._digest=function(A){return A==="hex"?R.toHex32(this.h.slice(0,7),"big"):R.split32(this.h.slice(0,7),"big")}}),Y6=OJ((l,g)=>{var R=pQ(),M=BV(),B=hQ(),A=R.rotr64_hi,q=R.rotr64_lo,Y=R.shr64_hi,E=R.shr64_lo,O=R.sum64,N=R.sum64_hi,W=R.sum64_lo,I=R.sum64_4_hi,z=R.sum64_4_lo,j=R.sum64_5_hi,P=R.sum64_5_lo,F=M.BlockHash,v=[1116352408,3609767458,1899447441,602891725,3049323471,3964484399,3921009573,2173295548,961987163,4081628472,1508970993,3053834265,2453635748,2937671579,2870763221,3664609560,3624381080,2734883394,310598401,1164996542,607225278,1323610764,1426881987,3590304994,1925078388,4068182383,2162078206,991336113,2614888103,633803317,3248222580,3479774868,3835390401,2666613458,4022224774,944711139,264347078,2341262773,604807628,2007800933,770255983,1495990901,1249150122,1856431235,1555081692,3175218132,1996064986,2198950837,2554220882,3999719339,2821834349,766784016,2952996808,2566594879,3210313671,3203337956,3336571891,1034457026,3584528711,2466948901,113926993,3758326383,338241895,168717936,666307205,1188179964,773529912,1546045734,1294757372,1522805485,1396182291,2643833823,1695183700,2343527390,1986661051,1014477480,2177026350,1206759142,2456956037,344077627,2730485921,1290863460,2820302411,3158454273,3259730800,3505952657,3345764771,106217008,3516065817,3606008344,3600352804,1432725776,4094571909,1467031594,275423344,851169720,430227734,3100823752,506948616,1363258195,659060556,3750685593,883997877,3785050280,958139571,3318307427,1322822218,3812723403,1537002063,2003034995,1747873779,3602036899,1955562222,1575990012,2024104815,1125592928,2227730452,2716904306,2361852424,442776044,2428436474,593698344,2756734187,3733110249,3204031479,2999351573,3329325298,3815920427,3391569614,3928383900,3515267271,566280711,3940187606,3454069534,4118630271,4000239992,116418474,1914138554,174292421,2731055270,289380356,3203993006,460393269,320620315,685471733,587496836,852142971,1086792851,1017036298,365543100,1126000580,2618297676,1288033470,3409855158,1501505948,4234509866,1607167915,987167468,1816402316,1246189591];function S(){if(!(this instanceof S))return new S;F.call(this),this.h=[1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209],this.k=v,this.W=new Array(160)}R.inherits(S,F),g.exports=S,S.blockSize=1024,S.outSize=512,S.hmacStrength=192,S.padLength=128,S.prototype._prepareBlock=function($,X){for(var U=this.W,H=0;H<32;H++)U[H]=$[X+H];for(;H<U.length;H+=2){var G=V(U[H-4],U[H-3]),Q=Z(U[H-4],U[H-3]),K=U[H-14],k=U[H-13],L=jJ(U[H-30],U[H-29]),_=J(U[H-30],U[H-29]),t=U[H-32],QJ=U[H-31];U[H]=I(G,Q,K,k,L,_,t,QJ),U[H+1]=z(G,Q,K,k,L,_,t,QJ)}},S.prototype._update=function($,X){this._prepareBlock($,X);var U=this.W,H=this.h[0],G=this.h[1],Q=this.h[2],K=this.h[3],k=this.h[4],L=this.h[5],_=this.h[6],t=this.h[7],QJ=this.h[8],GJ=this.h[9],n=this.h[10],p=this.h[11],e=this.h[12],PJ=this.h[13],XJ=this.h[14],WJ=this.h[15];B(this.k.length===U.length);for(var b=0;b<U.length;b+=2){var C=XJ,h=WJ,$J=HJ(QJ,GJ),qJ=o(QJ,GJ),ZJ=w(QJ,GJ,n,p,e,PJ),mJ=y(QJ,GJ,n,p,e,PJ),BJ=this.k[b],TJ=this.k[b+1],dJ=U[b],LJ=U[b+1],IJ=j(C,h,$J,qJ,ZJ,mJ,BJ,TJ,dJ,LJ),$Q=P(C,h,$J,qJ,ZJ,mJ,BJ,TJ,dJ,LJ);C=JJ(H,G),h=VJ(H,G),$J=m(H,G,Q,K,k,L),qJ=i(H,G,Q,K,k,L);var T=N(C,h,$J,qJ),D=W(C,h,$J,qJ);XJ=e,WJ=PJ,e=n,PJ=p,n=QJ,p=GJ,QJ=N(_,t,IJ,$Q),GJ=W(t,t,IJ,$Q),_=k,t=L,k=Q,L=K,Q=H,K=G,H=N(IJ,$Q,T,D),G=W(IJ,$Q,T,D)}O(this.h,0,H,G),O(this.h,2,Q,K),O(this.h,4,k,L),O(this.h,6,_,t),O(this.h,8,QJ,GJ),O(this.h,10,n,p),O(this.h,12,e,PJ),O(this.h,14,XJ,WJ)},S.prototype._digest=function($){return $==="hex"?R.toHex32(this.h,"big"):R.split32(this.h,"big")};function w($,X,U,H,G){var Q=$&U^~$&G;return Q<0&&(Q+=4294967296),Q}function y($,X,U,H,G,Q){var K=X&H^~X&Q;return K<0&&(K+=4294967296),K}function m($,X,U,H,G){var Q=$&U^$&G^U&G;return Q<0&&(Q+=4294967296),Q}function i($,X,U,H,G,Q){var K=X&H^X&Q^H&Q;return K<0&&(K+=4294967296),K}function JJ($,X){var U=A($,X,28),H=A(X,$,2),G=A(X,$,7),Q=U^H^G;return Q<0&&(Q+=4294967296),Q}function VJ($,X){var U=q($,X,28),H=q(X,$,2),G=q(X,$,7),Q=U^H^G;return Q<0&&(Q+=4294967296),Q}function HJ($,X){var U=A($,X,14),H=A($,X,18),G=A(X,$,9),Q=U^H^G;return Q<0&&(Q+=4294967296),Q}function o($,X){var U=q($,X,14),H=q($,X,18),G=q(X,$,9),Q=U^H^G;return Q<0&&(Q+=4294967296),Q}function jJ($,X){var U=A($,X,1),H=A($,X,8),G=Y($,X,7),Q=U^H^G;return Q<0&&(Q+=4294967296),Q}function J($,X){var U=q($,X,1),H=q($,X,8),G=E($,X,7),Q=U^H^G;return Q<0&&(Q+=4294967296),Q}function V($,X){var U=A($,X,19),H=A(X,$,29),G=Y($,X,6),Q=U^H^G;return Q<0&&(Q+=4294967296),Q}function Z($,X){var U=q($,X,19),H=q(X,$,29),G=E($,X,6),Q=U^H^G;return Q<0&&(Q+=4294967296),Q}}),J$=OJ((l,g)=>{var R=pQ(),M=Y6();function B(){if(!(this instanceof B))return new B;M.call(this),this.h=[3418070365,3238371032,1654270250,914150663,2438529370,812702999,355462360,4144912697,1731405415,4290775857,2394180231,1750603025,3675008525,1694076839,1203062813,3204075428]}R.inherits(B,M),g.exports=B,B.blockSize=1024,B.outSize=384,B.hmacStrength=192,B.padLength=128,B.prototype._digest=function(A){return A==="hex"?R.toHex32(this.h.slice(0,12),"big"):R.split32(this.h.slice(0,12),"big")}}),Q$=OJ((l)=>{l.sha1=t8(),l.sha224=e8(),l.sha256=W6(),l.sha384=J$(),l.sha512=Y6()}),V$=OJ((l)=>{var g=pQ(),R=BV(),M=g.rotl32,B=g.sum32,A=g.sum32_3,q=g.sum32_4,Y=R.BlockHash;function E(){if(!(this instanceof E))return new E;Y.call(this),this.h=[1732584193,4023233417,2562383102,271733878,3285377520],this.endian="little"}g.inherits(E,Y),l.ripemd160=E,E.blockSize=512,E.outSize=160,E.hmacStrength=192,E.padLength=64,E.prototype._update=function(F,v){for(var S=this.h[0],w=this.h[1],y=this.h[2],m=this.h[3],i=this.h[4],JJ=S,VJ=w,HJ=y,o=m,jJ=i,J=0;J<80;J++){var V=B(M(q(S,O(J,w,y,m),F[I[J]+v],N(J)),j[J]),i);S=i,i=m,m=M(y,10),y=w,w=V,V=B(M(q(JJ,O(79-J,VJ,HJ,o),F[z[J]+v],W(J)),P[J]),jJ),JJ=jJ,jJ=o,o=M(HJ,10),HJ=VJ,VJ=V}V=A(this.h[1],y,o),this.h[1]=A(this.h[2],m,jJ),this.h[2]=A(this.h[3],i,JJ),this.h[3]=A(this.h[4],S,VJ),this.h[4]=A(this.h[0],w,HJ),this.h[0]=V},E.prototype._digest=function(F){return F==="hex"?g.toHex32(this.h,"little"):g.split32(this.h,"little")};function O(F,v,S,w){return F<=15?v^S^w:F<=31?v&S|~v&w:F<=47?(v|~S)^w:F<=63?v&w|S&~w:v^(S|~w)}function N(F){return F<=15?0:F<=31?1518500249:F<=47?1859775393:F<=63?2400959708:2840853838}function W(F){return F<=15?1352829926:F<=31?1548603684:F<=47?1836072691:F<=63?2053994217:0}var I=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,7,4,13,1,10,6,15,3,12,0,9,5,2,14,11,8,3,10,14,4,9,15,8,1,2,7,0,6,13,11,5,12,1,9,11,10,0,8,12,4,13,3,7,15,14,5,6,2,4,0,5,9,7,12,2,10,14,1,3,8,11,6,15,13],z=[5,14,7,0,9,2,11,4,13,6,15,8,1,10,3,12,6,11,3,7,0,13,5,10,14,15,8,12,4,9,1,2,15,5,1,3,7,14,6,9,11,8,12,2,10,0,4,13,8,6,4,1,3,11,15,0,5,12,2,13,9,7,10,14,12,15,10,4,1,5,8,7,6,2,13,14,0,3,9,11],j=[11,14,15,12,5,8,7,9,11,13,14,15,6,7,9,8,7,6,8,13,11,9,7,15,7,12,15,9,11,7,13,12,11,13,6,7,14,9,13,15,14,8,13,6,5,12,7,5,11,12,14,15,14,15,9,8,9,14,5,6,8,6,5,12,9,15,5,11,6,8,13,12,5,12,13,14,11,8,5,6],P=[8,9,9,11,13,15,15,5,7,7,8,11,14,14,12,6,9,13,15,7,12,8,9,11,7,7,12,7,6,15,13,11,9,7,15,11,8,6,6,14,12,13,5,14,13,13,7,5,15,5,8,11,14,14,6,14,6,9,12,9,12,5,15,8,8,5,12,9,12,5,14,6,8,13,6,5,15,13,11,11]}),$$=OJ((l,g)=>{var R=pQ(),M=hQ();function B(A,q,Y){if(!(this instanceof B))return new B(A,q,Y);this.Hash=A,this.blockSize=A.blockSize/8,this.outSize=A.outSize/8,this.inner=null,this.outer=null,this._init(R.toArray(q,Y))}g.exports=B,B.prototype._init=function(A){A.length>this.blockSize&&(A=new this.Hash().update(A).digest()),M(A.length<=this.blockSize);for(var q=A.length;q<this.blockSize;q++)A.push(0);for(q=0;q<A.length;q++)A[q]^=54;for(this.inner=new this.Hash().update(A),q=0;q<A.length;q++)A[q]^=106;this.outer=new this.Hash().update(A)},B.prototype.update=function(A,q){return this.inner.update(A,q),this},B.prototype.digest=function(A){return this.outer.update(this.inner.digest()),this.outer.digest(A)}}),Z0=OJ((l)=>{var g=l;g.utils=pQ(),g.common=BV(),g.sha=Q$(),g.ripemd=V$(),g.hmac=$$(),g.sha1=g.sha.sha1,g.sha256=g.sha.sha256,g.sha224=g.sha.sha224,g.sha384=g.sha.sha384,g.sha512=g.sha.sha512,g.ripemd160=g.ripemd.ripemd160}),Z$=OJ((l,g)=>{g.exports={doubles:{step:4,points:[["e60fce93b59e9ec53011aabc21c23e97b2a31369b87a5ae9c44ee89e2a6dec0a","f7e3507399e595929db99f34f57937101296891e44d23f0be1f32cce69616821"],["8282263212c609d9ea2a6e3e172de238d8c39cabd5ac1ca10646e23fd5f51508","11f8a8098557dfe45e8256e830b60ace62d613ac2f7b17bed31b6eaff6e26caf"],["175e159f728b865a72f99cc6c6fc846de0b93833fd2222ed73fce5b551e5b739","d3506e0d9e3c79eba4ef97a51ff71f5eacb5955add24345c6efa6ffee9fed695"],["363d90d447b00c9c99ceac05b6262ee053441c7e55552ffe526bad8f83ff4640","4e273adfc732221953b445397f3363145b9a89008199ecb62003c7f3bee9de9"],["8b4b5f165df3c2be8c6244b5b745638843e4a781a15bcd1b69f79a55dffdf80c","4aad0a6f68d308b4b3fbd7813ab0da04f9e336546162ee56b3eff0c65fd4fd36"],["723cbaa6e5db996d6bf771c00bd548c7b700dbffa6c0e77bcb6115925232fcda","96e867b5595cc498a921137488824d6e2660a0653779494801dc069d9eb39f5f"],["eebfa4d493bebf98ba5feec812c2d3b50947961237a919839a533eca0e7dd7fa","5d9a8ca3970ef0f269ee7edaf178089d9ae4cdc3a711f712ddfd4fdae1de8999"],["100f44da696e71672791d0a09b7bde459f1215a29b3c03bfefd7835b39a48db0","cdd9e13192a00b772ec8f3300c090666b7ff4a18ff5195ac0fbd5cd62bc65a09"],["e1031be262c7ed1b1dc9227a4a04c017a77f8d4464f3b3852c8acde6e534fd2d","9d7061928940405e6bb6a4176597535af292dd419e1ced79a44f18f29456a00d"],["feea6cae46d55b530ac2839f143bd7ec5cf8b266a41d6af52d5e688d9094696d","e57c6b6c97dce1bab06e4e12bf3ecd5c981c8957cc41442d3155debf18090088"],["da67a91d91049cdcb367be4be6ffca3cfeed657d808583de33fa978bc1ec6cb1","9bacaa35481642bc41f463f7ec9780e5dec7adc508f740a17e9ea8e27a68be1d"],["53904faa0b334cdda6e000935ef22151ec08d0f7bb11069f57545ccc1a37b7c0","5bc087d0bc80106d88c9eccac20d3c1c13999981e14434699dcb096b022771c8"],["8e7bcd0bd35983a7719cca7764ca906779b53a043a9b8bcaeff959f43ad86047","10b7770b2a3da4b3940310420ca9514579e88e2e47fd68b3ea10047e8460372a"],["385eed34c1cdff21e6d0818689b81bde71a7f4f18397e6690a841e1599c43862","283bebc3e8ea23f56701de19e9ebf4576b304eec2086dc8cc0458fe5542e5453"],["6f9d9b803ecf191637c73a4413dfa180fddf84a5947fbc9c606ed86c3fac3a7","7c80c68e603059ba69b8e2a30e45c4d47ea4dd2f5c281002d86890603a842160"],["3322d401243c4e2582a2147c104d6ecbf774d163db0f5e5313b7e0e742d0e6bd","56e70797e9664ef5bfb019bc4ddaf9b72805f63ea2873af624f3a2e96c28b2a0"],["85672c7d2de0b7da2bd1770d89665868741b3f9af7643397721d74d28134ab83","7c481b9b5b43b2eb6374049bfa62c2e5e77f17fcc5298f44c8e3094f790313a6"],["948bf809b1988a46b06c9f1919413b10f9226c60f668832ffd959af60c82a0a","53a562856dcb6646dc6b74c5d1c3418c6d4dff08c97cd2bed4cb7f88d8c8e589"],["6260ce7f461801c34f067ce0f02873a8f1b0e44dfc69752accecd819f38fd8e8","bc2da82b6fa5b571a7f09049776a1ef7ecd292238051c198c1a84e95b2b4ae17"],["e5037de0afc1d8d43d8348414bbf4103043ec8f575bfdc432953cc8d2037fa2d","4571534baa94d3b5f9f98d09fb990bddbd5f5b03ec481f10e0e5dc841d755bda"],["e06372b0f4a207adf5ea905e8f1771b4e7e8dbd1c6a6c5b725866a0ae4fce725","7a908974bce18cfe12a27bb2ad5a488cd7484a7787104870b27034f94eee31dd"],["213c7a715cd5d45358d0bbf9dc0ce02204b10bdde2a3f58540ad6908d0559754","4b6dad0b5ae462507013ad06245ba190bb4850f5f36a7eeddff2c27534b458f2"],["4e7c272a7af4b34e8dbb9352a5419a87e2838c70adc62cddf0cc3a3b08fbd53c","17749c766c9d0b18e16fd09f6def681b530b9614bff7dd33e0b3941817dcaae6"],["fea74e3dbe778b1b10f238ad61686aa5c76e3db2be43057632427e2840fb27b6","6e0568db9b0b13297cf674deccb6af93126b596b973f7b77701d3db7f23cb96f"],["76e64113f677cf0e10a2570d599968d31544e179b760432952c02a4417bdde39","c90ddf8dee4e95cf577066d70681f0d35e2a33d2b56d2032b4b1752d1901ac01"],["c738c56b03b2abe1e8281baa743f8f9a8f7cc643df26cbee3ab150242bcbb891","893fb578951ad2537f718f2eacbfbbbb82314eef7880cfe917e735d9699a84c3"],["d895626548b65b81e264c7637c972877d1d72e5f3a925014372e9f6588f6c14b","febfaa38f2bc7eae728ec60818c340eb03428d632bb067e179363ed75d7d991f"],["b8da94032a957518eb0f6433571e8761ceffc73693e84edd49150a564f676e03","2804dfa44805a1e4d7c99cc9762808b092cc584d95ff3b511488e4e74efdf6e7"],["e80fea14441fb33a7d8adab9475d7fab2019effb5156a792f1a11778e3c0df5d","eed1de7f638e00771e89768ca3ca94472d155e80af322ea9fcb4291b6ac9ec78"],["a301697bdfcd704313ba48e51d567543f2a182031efd6915ddc07bbcc4e16070","7370f91cfb67e4f5081809fa25d40f9b1735dbf7c0a11a130c0d1a041e177ea1"],["90ad85b389d6b936463f9d0512678de208cc330b11307fffab7ac63e3fb04ed4","e507a3620a38261affdcbd9427222b839aefabe1582894d991d4d48cb6ef150"],["8f68b9d2f63b5f339239c1ad981f162ee88c5678723ea3351b7b444c9ec4c0da","662a9f2dba063986de1d90c2b6be215dbbea2cfe95510bfdf23cbf79501fff82"],["e4f3fb0176af85d65ff99ff9198c36091f48e86503681e3e6686fd5053231e11","1e63633ad0ef4f1c1661a6d0ea02b7286cc7e74ec951d1c9822c38576feb73bc"],["8c00fa9b18ebf331eb961537a45a4266c7034f2f0d4e1d0716fb6eae20eae29e","efa47267fea521a1a9dc343a3736c974c2fadafa81e36c54e7d2a4c66702414b"],["e7a26ce69dd4829f3e10cec0a9e98ed3143d084f308b92c0997fddfc60cb3e41","2a758e300fa7984b471b006a1aafbb18d0a6b2c0420e83e20e8a9421cf2cfd51"],["b6459e0ee3662ec8d23540c223bcbdc571cbcb967d79424f3cf29eb3de6b80ef","67c876d06f3e06de1dadf16e5661db3c4b3ae6d48e35b2ff30bf0b61a71ba45"],["d68a80c8280bb840793234aa118f06231d6f1fc67e73c5a5deda0f5b496943e8","db8ba9fff4b586d00c4b1f9177b0e28b5b0e7b8f7845295a294c84266b133120"],["324aed7df65c804252dc0270907a30b09612aeb973449cea4095980fc28d3d5d","648a365774b61f2ff130c0c35aec1f4f19213b0c7e332843967224af96ab7c84"],["4df9c14919cde61f6d51dfdbe5fee5dceec4143ba8d1ca888e8bd373fd054c96","35ec51092d8728050974c23a1d85d4b5d506cdc288490192ebac06cad10d5d"],["9c3919a84a474870faed8a9c1cc66021523489054d7f0308cbfc99c8ac1f98cd","ddb84f0f4a4ddd57584f044bf260e641905326f76c64c8e6be7e5e03d4fc599d"],["6057170b1dd12fdf8de05f281d8e06bb91e1493a8b91d4cc5a21382120a959e5","9a1af0b26a6a4807add9a2daf71df262465152bc3ee24c65e899be932385a2a8"],["a576df8e23a08411421439a4518da31880cef0fba7d4df12b1a6973eecb94266","40a6bf20e76640b2c92b97afe58cd82c432e10a7f514d9f3ee8be11ae1b28ec8"],["7778a78c28dec3e30a05fe9629de8c38bb30d1f5cf9a3a208f763889be58ad71","34626d9ab5a5b22ff7098e12f2ff580087b38411ff24ac563b513fc1fd9f43ac"],["928955ee637a84463729fd30e7afd2ed5f96274e5ad7e5cb09eda9c06d903ac","c25621003d3f42a827b78a13093a95eeac3d26efa8a8d83fc5180e935bcd091f"],["85d0fef3ec6db109399064f3a0e3b2855645b4a907ad354527aae75163d82751","1f03648413a38c0be29d496e582cf5663e8751e96877331582c237a24eb1f962"],["ff2b0dce97eece97c1c9b6041798b85dfdfb6d8882da20308f5404824526087e","493d13fef524ba188af4c4dc54d07936c7b7ed6fb90e2ceb2c951e01f0c29907"],["827fbbe4b1e880ea9ed2b2e6301b212b57f1ee148cd6dd28780e5e2cf856e241","c60f9c923c727b0b71bef2c67d1d12687ff7a63186903166d605b68baec293ec"],["eaa649f21f51bdbae7be4ae34ce6e5217a58fdce7f47f9aa7f3b58fa2120e2b3","be3279ed5bbbb03ac69a80f89879aa5a01a6b965f13f7e59d47a5305ba5ad93d"],["e4a42d43c5cf169d9391df6decf42ee541b6d8f0c9a137401e23632dda34d24f","4d9f92e716d1c73526fc99ccfb8ad34ce886eedfa8d8e4f13a7f7131deba9414"],["1ec80fef360cbdd954160fadab352b6b92b53576a88fea4947173b9d4300bf19","aeefe93756b5340d2f3a4958a7abbf5e0146e77f6295a07b671cdc1cc107cefd"],["146a778c04670c2f91b00af4680dfa8bce3490717d58ba889ddb5928366642be","b318e0ec3354028add669827f9d4b2870aaa971d2f7e5ed1d0b297483d83efd0"],["fa50c0f61d22e5f07e3acebb1aa07b128d0012209a28b9776d76a8793180eef9","6b84c6922397eba9b72cd2872281a68a5e683293a57a213b38cd8d7d3f4f2811"],["da1d61d0ca721a11b1a5bf6b7d88e8421a288ab5d5bba5220e53d32b5f067ec2","8157f55a7c99306c79c0766161c91e2966a73899d279b48a655fba0f1ad836f1"],["a8e282ff0c9706907215ff98e8fd416615311de0446f1e062a73b0610d064e13","7f97355b8db81c09abfb7f3c5b2515888b679a3e50dd6bd6cef7c73111f4cc0c"],["174a53b9c9a285872d39e56e6913cab15d59b1fa512508c022f382de8319497c","ccc9dc37abfc9c1657b4155f2c47f9e6646b3a1d8cb9854383da13ac079afa73"],["959396981943785c3d3e57edf5018cdbe039e730e4918b3d884fdff09475b7ba","2e7e552888c331dd8ba0386a4b9cd6849c653f64c8709385e9b8abf87524f2fd"],["d2a63a50ae401e56d645a1153b109a8fcca0a43d561fba2dbb51340c9d82b151","e82d86fb6443fcb7565aee58b2948220a70f750af484ca52d4142174dcf89405"],["64587e2335471eb890ee7896d7cfdc866bacbdbd3839317b3436f9b45617e073","d99fcdd5bf6902e2ae96dd6447c299a185b90a39133aeab358299e5e9faf6589"],["8481bde0e4e4d885b3a546d3e549de042f0aa6cea250e7fd358d6c86dd45e458","38ee7b8cba5404dd84a25bf39cecb2ca900a79c42b262e556d64b1b59779057e"],["13464a57a78102aa62b6979ae817f4637ffcfed3c4b1ce30bcd6303f6caf666b","69be159004614580ef7e433453ccb0ca48f300a81d0942e13f495a907f6ecc27"],["bc4a9df5b713fe2e9aef430bcc1dc97a0cd9ccede2f28588cada3a0d2d83f366","d3a81ca6e785c06383937adf4b798caa6e8a9fbfa547b16d758d666581f33c1"],["8c28a97bf8298bc0d23d8c749452a32e694b65e30a9472a3954ab30fe5324caa","40a30463a3305193378fedf31f7cc0eb7ae784f0451cb9459e71dc73cbef9482"],["8ea9666139527a8c1dd94ce4f071fd23c8b350c5a4bb33748c4ba111faccae0","620efabbc8ee2782e24e7c0cfb95c5d735b783be9cf0f8e955af34a30e62b945"],["dd3625faef5ba06074669716bbd3788d89bdde815959968092f76cc4eb9a9787","7a188fa3520e30d461da2501045731ca941461982883395937f68d00c644a573"],["f710d79d9eb962297e4f6232b40e8f7feb2bc63814614d692c12de752408221e","ea98e67232d3b3295d3b535532115ccac8612c721851617526ae47a9c77bfc82"]]},naf:{wnd:7,points:[["f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9","388f7b0f632de8140fe337e62a37f3566500a99934c2231b6cb9fd7584b8e672"],["2f8bde4d1a07209355b4a7250a5c5128e88b84bddc619ab7cba8d569b240efe4","d8ac222636e5e3d6d4dba9dda6c9c426f788271bab0d6840dca87d3aa6ac62d6"],["5cbdf0646e5db4eaa398f365f2ea7a0e3d419b7e0330e39ce92bddedcac4f9bc","6aebca40ba255960a3178d6d861a54dba813d0b813fde7b5a5082628087264da"],["acd484e2f0c7f65309ad178a9f559abde09796974c57e714c35f110dfc27ccbe","cc338921b0a7d9fd64380971763b61e9add888a4375f8e0f05cc262ac64f9c37"],["774ae7f858a9411e5ef4246b70c65aac5649980be5c17891bbec17895da008cb","d984a032eb6b5e190243dd56d7b7b365372db1e2dff9d6a8301d74c9c953c61b"],["f28773c2d975288bc7d1d205c3748651b075fbc6610e58cddeeddf8f19405aa8","ab0902e8d880a89758212eb65cdaf473a1a06da521fa91f29b5cb52db03ed81"],["d7924d4f7d43ea965a465ae3095ff41131e5946f3c85f79e44adbcf8e27e080e","581e2872a86c72a683842ec228cc6defea40af2bd896d3a5c504dc9ff6a26b58"],["defdea4cdb677750a420fee807eacf21eb9898ae79b9768766e4faa04a2d4a34","4211ab0694635168e997b0ead2a93daeced1f4a04a95c0f6cfb199f69e56eb77"],["2b4ea0a797a443d293ef5cff444f4979f06acfebd7e86d277475656138385b6c","85e89bc037945d93b343083b5a1c86131a01f60c50269763b570c854e5c09b7a"],["352bbf4a4cdd12564f93fa332ce333301d9ad40271f8107181340aef25be59d5","321eb4075348f534d59c18259dda3e1f4a1b3b2e71b1039c67bd3d8bcf81998c"],["2fa2104d6b38d11b0230010559879124e42ab8dfeff5ff29dc9cdadd4ecacc3f","2de1068295dd865b64569335bd5dd80181d70ecfc882648423ba76b532b7d67"],["9248279b09b4d68dab21a9b066edda83263c3d84e09572e269ca0cd7f5453714","73016f7bf234aade5d1aa71bdea2b1ff3fc0de2a887912ffe54a32ce97cb3402"],["daed4f2be3a8bf278e70132fb0beb7522f570e144bf615c07e996d443dee8729","a69dce4a7d6c98e8d4a1aca87ef8d7003f83c230f3afa726ab40e52290be1c55"],["c44d12c7065d812e8acf28d7cbb19f9011ecd9e9fdf281b0e6a3b5e87d22e7db","2119a460ce326cdc76c45926c982fdac0e106e861edf61c5a039063f0e0e6482"],["6a245bf6dc698504c89a20cfded60853152b695336c28063b61c65cbd269e6b4","e022cf42c2bd4a708b3f5126f16a24ad8b33ba48d0423b6efd5e6348100d8a82"],["1697ffa6fd9de627c077e3d2fe541084ce13300b0bec1146f95ae57f0d0bd6a5","b9c398f186806f5d27561506e4557433a2cf15009e498ae7adee9d63d01b2396"],["605bdb019981718b986d0f07e834cb0d9deb8360ffb7f61df982345ef27a7479","2972d2de4f8d20681a78d93ec96fe23c26bfae84fb14db43b01e1e9056b8c49"],["62d14dab4150bf497402fdc45a215e10dcb01c354959b10cfe31c7e9d87ff33d","80fc06bd8cc5b01098088a1950eed0db01aa132967ab472235f5642483b25eaf"],["80c60ad0040f27dade5b4b06c408e56b2c50e9f56b9b8b425e555c2f86308b6f","1c38303f1cc5c30f26e66bad7fe72f70a65eed4cbe7024eb1aa01f56430bd57a"],["7a9375ad6167ad54aa74c6348cc54d344cc5dc9487d847049d5eabb0fa03c8fb","d0e3fa9eca8726909559e0d79269046bdc59ea10c70ce2b02d499ec224dc7f7"],["d528ecd9b696b54c907a9ed045447a79bb408ec39b68df504bb51f459bc3ffc9","eecf41253136e5f99966f21881fd656ebc4345405c520dbc063465b521409933"],["49370a4b5f43412ea25f514e8ecdad05266115e4a7ecb1387231808f8b45963","758f3f41afd6ed428b3081b0512fd62a54c3f3afbb5b6764b653052a12949c9a"],["77f230936ee88cbbd73df930d64702ef881d811e0e1498e2f1c13eb1fc345d74","958ef42a7886b6400a08266e9ba1b37896c95330d97077cbbe8eb3c7671c60d6"],["f2dac991cc4ce4b9ea44887e5c7c0bce58c80074ab9d4dbaeb28531b7739f530","e0dedc9b3b2f8dad4da1f32dec2531df9eb5fbeb0598e4fd1a117dba703a3c37"],["463b3d9f662621fb1b4be8fbbe2520125a216cdfc9dae3debcba4850c690d45b","5ed430d78c296c3543114306dd8622d7c622e27c970a1de31cb377b01af7307e"],["f16f804244e46e2a09232d4aff3b59976b98fac14328a2d1a32496b49998f247","cedabd9b82203f7e13d206fcdf4e33d92a6c53c26e5cce26d6579962c4e31df6"],["caf754272dc84563b0352b7a14311af55d245315ace27c65369e15f7151d41d1","cb474660ef35f5f2a41b643fa5e460575f4fa9b7962232a5c32f908318a04476"],["2600ca4b282cb986f85d0f1709979d8b44a09c07cb86d7c124497bc86f082120","4119b88753c15bd6a693b03fcddbb45d5ac6be74ab5f0ef44b0be9475a7e4b40"],["7635ca72d7e8432c338ec53cd12220bc01c48685e24f7dc8c602a7746998e435","91b649609489d613d1d5e590f78e6d74ecfc061d57048bad9e76f302c5b9c61"],["754e3239f325570cdbbf4a87deee8a66b7f2b33479d468fbc1a50743bf56cc18","673fb86e5bda30fb3cd0ed304ea49a023ee33d0197a695d0c5d98093c536683"],["e3e6bd1071a1e96aff57859c82d570f0330800661d1c952f9fe2694691d9b9e8","59c9e0bba394e76f40c0aa58379a3cb6a5a2283993e90c4167002af4920e37f5"],["186b483d056a033826ae73d88f732985c4ccb1f32ba35f4b4cc47fdcf04aa6eb","3b952d32c67cf77e2e17446e204180ab21fb8090895138b4a4a797f86e80888b"],["df9d70a6b9876ce544c98561f4be4f725442e6d2b737d9c91a8321724ce0963f","55eb2dafd84d6ccd5f862b785dc39d4ab157222720ef9da217b8c45cf2ba2417"],["5edd5cc23c51e87a497ca815d5dce0f8ab52554f849ed8995de64c5f34ce7143","efae9c8dbc14130661e8cec030c89ad0c13c66c0d17a2905cdc706ab7399a868"],["290798c2b6476830da12fe02287e9e777aa3fba1c355b17a722d362f84614fba","e38da76dcd440621988d00bcf79af25d5b29c094db2a23146d003afd41943e7a"],["af3c423a95d9f5b3054754efa150ac39cd29552fe360257362dfdecef4053b45","f98a3fd831eb2b749a93b0e6f35cfb40c8cd5aa667a15581bc2feded498fd9c6"],["766dbb24d134e745cccaa28c99bf274906bb66b26dcf98df8d2fed50d884249a","744b1152eacbe5e38dcc887980da38b897584a65fa06cedd2c924f97cbac5996"],["59dbf46f8c94759ba21277c33784f41645f7b44f6c596a58ce92e666191abe3e","c534ad44175fbc300f4ea6ce648309a042ce739a7919798cd85e216c4a307f6e"],["f13ada95103c4537305e691e74e9a4a8dd647e711a95e73cb62dc6018cfd87b8","e13817b44ee14de663bf4bc808341f326949e21a6a75c2570778419bdaf5733d"],["7754b4fa0e8aced06d4167a2c59cca4cda1869c06ebadfb6488550015a88522c","30e93e864e669d82224b967c3020b8fa8d1e4e350b6cbcc537a48b57841163a2"],["948dcadf5990e048aa3874d46abef9d701858f95de8041d2a6828c99e2262519","e491a42537f6e597d5d28a3224b1bc25df9154efbd2ef1d2cbba2cae5347d57e"],["7962414450c76c1689c7b48f8202ec37fb224cf5ac0bfa1570328a8a3d7c77ab","100b610ec4ffb4760d5c1fc133ef6f6b12507a051f04ac5760afa5b29db83437"],["3514087834964b54b15b160644d915485a16977225b8847bb0dd085137ec47ca","ef0afbb2056205448e1652c48e8127fc6039e77c15c2378b7e7d15a0de293311"],["d3cc30ad6b483e4bc79ce2c9dd8bc54993e947eb8df787b442943d3f7b527eaf","8b378a22d827278d89c5e9be8f9508ae3c2ad46290358630afb34db04eede0a4"],["1624d84780732860ce1c78fcbfefe08b2b29823db913f6493975ba0ff4847610","68651cf9b6da903e0914448c6cd9d4ca896878f5282be4c8cc06e2a404078575"],["733ce80da955a8a26902c95633e62a985192474b5af207da6df7b4fd5fc61cd4","f5435a2bd2badf7d485a4d8b8db9fcce3e1ef8e0201e4578c54673bc1dc5ea1d"],["15d9441254945064cf1a1c33bbd3b49f8966c5092171e699ef258dfab81c045c","d56eb30b69463e7234f5137b73b84177434800bacebfc685fc37bbe9efe4070d"],["a1d0fcf2ec9de675b612136e5ce70d271c21417c9d2b8aaaac138599d0717940","edd77f50bcb5a3cab2e90737309667f2641462a54070f3d519212d39c197a629"],["e22fbe15c0af8ccc5780c0735f84dbe9a790badee8245c06c7ca37331cb36980","a855babad5cd60c88b430a69f53a1a7a38289154964799be43d06d77d31da06"],["311091dd9860e8e20ee13473c1155f5f69635e394704eaa74009452246cfa9b3","66db656f87d1f04fffd1f04788c06830871ec5a64feee685bd80f0b1286d8374"],["34c1fd04d301be89b31c0442d3e6ac24883928b45a9340781867d4232ec2dbdf","9414685e97b1b5954bd46f730174136d57f1ceeb487443dc5321857ba73abee"],["f219ea5d6b54701c1c14de5b557eb42a8d13f3abbcd08affcc2a5e6b049b8d63","4cb95957e83d40b0f73af4544cccf6b1f4b08d3c07b27fb8d8c2962a400766d1"],["d7b8740f74a8fbaab1f683db8f45de26543a5490bca627087236912469a0b448","fa77968128d9c92ee1010f337ad4717eff15db5ed3c049b3411e0315eaa4593b"],["32d31c222f8f6f0ef86f7c98d3a3335ead5bcd32abdd94289fe4d3091aa824bf","5f3032f5892156e39ccd3d7915b9e1da2e6dac9e6f26e961118d14b8462e1661"],["7461f371914ab32671045a155d9831ea8793d77cd59592c4340f86cbc18347b5","8ec0ba238b96bec0cbdddcae0aa442542eee1ff50c986ea6b39847b3cc092ff6"],["ee079adb1df1860074356a25aa38206a6d716b2c3e67453d287698bad7b2b2d6","8dc2412aafe3be5c4c5f37e0ecc5f9f6a446989af04c4e25ebaac479ec1c8c1e"],["16ec93e447ec83f0467b18302ee620f7e65de331874c9dc72bfd8616ba9da6b5","5e4631150e62fb40d0e8c2a7ca5804a39d58186a50e497139626778e25b0674d"],["eaa5f980c245f6f038978290afa70b6bd8855897f98b6aa485b96065d537bd99","f65f5d3e292c2e0819a528391c994624d784869d7e6ea67fb18041024edc07dc"],["78c9407544ac132692ee1910a02439958ae04877151342ea96c4b6b35a49f51","f3e0319169eb9b85d5404795539a5e68fa1fbd583c064d2462b675f194a3ddb4"],["494f4be219a1a77016dcd838431aea0001cdc8ae7a6fc688726578d9702857a5","42242a969283a5f339ba7f075e36ba2af925ce30d767ed6e55f4b031880d562c"],["a598a8030da6d86c6bc7f2f5144ea549d28211ea58faa70ebf4c1e665c1fe9b5","204b5d6f84822c307e4b4a7140737aec23fc63b65b35f86a10026dbd2d864e6b"],["c41916365abb2b5d09192f5f2dbeafec208f020f12570a184dbadc3e58595997","4f14351d0087efa49d245b328984989d5caf9450f34bfc0ed16e96b58fa9913"],["841d6063a586fa475a724604da03bc5b92a2e0d2e0a36acfe4c73a5514742881","73867f59c0659e81904f9a1c7543698e62562d6744c169ce7a36de01a8d6154"],["5e95bb399a6971d376026947f89bde2f282b33810928be4ded112ac4d70e20d5","39f23f366809085beebfc71181313775a99c9aed7d8ba38b161384c746012865"],["36e4641a53948fd476c39f8a99fd974e5ec07564b5315d8bf99471bca0ef2f66","d2424b1b1abe4eb8164227b085c9aa9456ea13493fd563e06fd51cf5694c78fc"],["336581ea7bfbbb290c191a2f507a41cf5643842170e914faeab27c2c579f726","ead12168595fe1be99252129b6e56b3391f7ab1410cd1e0ef3dcdcabd2fda224"],["8ab89816dadfd6b6a1f2634fcf00ec8403781025ed6890c4849742706bd43ede","6fdcef09f2f6d0a044e654aef624136f503d459c3e89845858a47a9129cdd24e"],["1e33f1a746c9c5778133344d9299fcaa20b0938e8acff2544bb40284b8c5fb94","60660257dd11b3aa9c8ed618d24edff2306d320f1d03010e33a7d2057f3b3b6"],["85b7c1dcb3cec1b7ee7f30ded79dd20a0ed1f4cc18cbcfcfa410361fd8f08f31","3d98a9cdd026dd43f39048f25a8847f4fcafad1895d7a633c6fed3c35e999511"],["29df9fbd8d9e46509275f4b125d6d45d7fbe9a3b878a7af872a2800661ac5f51","b4c4fe99c775a606e2d8862179139ffda61dc861c019e55cd2876eb2a27d84b"],["a0b1cae06b0a847a3fea6e671aaf8adfdfe58ca2f768105c8082b2e449fce252","ae434102edde0958ec4b19d917a6a28e6b72da1834aff0e650f049503a296cf2"],["4e8ceafb9b3e9a136dc7ff67e840295b499dfb3b2133e4ba113f2e4c0e121e5","cf2174118c8b6d7a4b48f6d534ce5c79422c086a63460502b827ce62a326683c"],["d24a44e047e19b6f5afb81c7ca2f69080a5076689a010919f42725c2b789a33b","6fb8d5591b466f8fc63db50f1c0f1c69013f996887b8244d2cdec417afea8fa3"],["ea01606a7a6c9cdd249fdfcfacb99584001edd28abbab77b5104e98e8e3b35d4","322af4908c7312b0cfbfe369f7a7b3cdb7d4494bc2823700cfd652188a3ea98d"],["af8addbf2b661c8a6c6328655eb96651252007d8c5ea31be4ad196de8ce2131f","6749e67c029b85f52a034eafd096836b2520818680e26ac8f3dfbcdb71749700"],["e3ae1974566ca06cc516d47e0fb165a674a3dabcfca15e722f0e3450f45889","2aeabe7e4531510116217f07bf4d07300de97e4874f81f533420a72eeb0bd6a4"],["591ee355313d99721cf6993ffed1e3e301993ff3ed258802075ea8ced397e246","b0ea558a113c30bea60fc4775460c7901ff0b053d25ca2bdeee98f1a4be5d196"],["11396d55fda54c49f19aa97318d8da61fa8584e47b084945077cf03255b52984","998c74a8cd45ac01289d5833a7beb4744ff536b01b257be4c5767bea93ea57a4"],["3c5d2a1ba39c5a1790000738c9e0c40b8dcdfd5468754b6405540157e017aa7a","b2284279995a34e2f9d4de7396fc18b80f9b8b9fdd270f6661f79ca4c81bd257"],["cc8704b8a60a0defa3a99a7299f2e9c3fbc395afb04ac078425ef8a1793cc030","bdd46039feed17881d1e0862db347f8cf395b74fc4bcdc4e940b74e3ac1f1b13"],["c533e4f7ea8555aacd9777ac5cad29b97dd4defccc53ee7ea204119b2889b197","6f0a256bc5efdf429a2fb6242f1a43a2d9b925bb4a4b3a26bb8e0f45eb596096"],["c14f8f2ccb27d6f109f6d08d03cc96a69ba8c34eec07bbcf566d48e33da6593","c359d6923bb398f7fd4473e16fe1c28475b740dd098075e6c0e8649113dc3a38"],["a6cbc3046bc6a450bac24789fa17115a4c9739ed75f8f21ce441f72e0b90e6ef","21ae7f4680e889bb130619e2c0f95a360ceb573c70603139862afd617fa9b9f"],["347d6d9a02c48927ebfb86c1359b1caf130a3c0267d11ce6344b39f99d43cc38","60ea7f61a353524d1c987f6ecec92f086d565ab687870cb12689ff1e31c74448"],["da6545d2181db8d983f7dcb375ef5866d47c67b1bf31c8cf855ef7437b72656a","49b96715ab6878a79e78f07ce5680c5d6673051b4935bd897fea824b77dc208a"],["c40747cc9d012cb1a13b8148309c6de7ec25d6945d657146b9d5994b8feb1111","5ca560753be2a12fc6de6caf2cb489565db936156b9514e1bb5e83037e0fa2d4"],["4e42c8ec82c99798ccf3a610be870e78338c7f713348bd34c8203ef4037f3502","7571d74ee5e0fb92a7a8b33a07783341a5492144cc54bcc40a94473693606437"],["3775ab7089bc6af823aba2e1af70b236d251cadb0c86743287522a1b3b0dedea","be52d107bcfa09d8bcb9736a828cfa7fac8db17bf7a76a2c42ad961409018cf7"],["cee31cbf7e34ec379d94fb814d3d775ad954595d1314ba8846959e3e82f74e26","8fd64a14c06b589c26b947ae2bcf6bfa0149ef0be14ed4d80f448a01c43b1c6d"],["b4f9eaea09b6917619f6ea6a4eb5464efddb58fd45b1ebefcdc1a01d08b47986","39e5c9925b5a54b07433a4f18c61726f8bb131c012ca542eb24a8ac07200682a"],["d4263dfc3d2df923a0179a48966d30ce84e2515afc3dccc1b77907792ebcc60e","62dfaf07a0f78feb30e30d6295853ce189e127760ad6cf7fae164e122a208d54"],["48457524820fa65a4f8d35eb6930857c0032acc0a4a2de422233eeda897612c4","25a748ab367979d98733c38a1fa1c2e7dc6cc07db2d60a9ae7a76aaa49bd0f77"],["dfeeef1881101f2cb11644f3a2afdfc2045e19919152923f367a1767c11cceda","ecfb7056cf1de042f9420bab396793c0c390bde74b4bbdff16a83ae09a9a7517"],["6d7ef6b17543f8373c573f44e1f389835d89bcbc6062ced36c82df83b8fae859","cd450ec335438986dfefa10c57fea9bcc521a0959b2d80bbf74b190dca712d10"],["e75605d59102a5a2684500d3b991f2e3f3c88b93225547035af25af66e04541f","f5c54754a8f71ee540b9b48728473e314f729ac5308b06938360990e2bfad125"],["eb98660f4c4dfaa06a2be453d5020bc99a0c2e60abe388457dd43fefb1ed620c","6cb9a8876d9cb8520609af3add26cd20a0a7cd8a9411131ce85f44100099223e"],["13e87b027d8514d35939f2e6892b19922154596941888336dc3563e3b8dba942","fef5a3c68059a6dec5d624114bf1e91aac2b9da568d6abeb2570d55646b8adf1"],["ee163026e9fd6fe017c38f06a5be6fc125424b371ce2708e7bf4491691e5764a","1acb250f255dd61c43d94ccc670d0f58f49ae3fa15b96623e5430da0ad6c62b2"],["b268f5ef9ad51e4d78de3a750c2dc89b1e626d43505867999932e5db33af3d80","5f310d4b3c99b9ebb19f77d41c1dee018cf0d34fd4191614003e945a1216e423"],["ff07f3118a9df035e9fad85eb6c7bfe42b02f01ca99ceea3bf7ffdba93c4750d","438136d603e858a3a5c440c38eccbaddc1d2942114e2eddd4740d098ced1f0d8"],["8d8b9855c7c052a34146fd20ffb658bea4b9f69e0d825ebec16e8c3ce2b526a1","cdb559eedc2d79f926baf44fb84ea4d44bcf50fee51d7ceb30e2e7f463036758"],["52db0b5384dfbf05bfa9d472d7ae26dfe4b851ceca91b1eba54263180da32b63","c3b997d050ee5d423ebaf66a6db9f57b3180c902875679de924b69d84a7b375"],["e62f9490d3d51da6395efd24e80919cc7d0f29c3f3fa48c6fff543becbd43352","6d89ad7ba4876b0b22c2ca280c682862f342c8591f1daf5170e07bfd9ccafa7d"],["7f30ea2476b399b4957509c88f77d0191afa2ff5cb7b14fd6d8e7d65aaab1193","ca5ef7d4b231c94c3b15389a5f6311e9daff7bb67b103e9880ef4bff637acaec"],["5098ff1e1d9f14fb46a210fada6c903fef0fb7b4a1dd1d9ac60a0361800b7a00","9731141d81fc8f8084d37c6e7542006b3ee1b40d60dfe5362a5b132fd17ddc0"],["32b78c7de9ee512a72895be6b9cbefa6e2f3c4ccce445c96b9f2c81e2778ad58","ee1849f513df71e32efc3896ee28260c73bb80547ae2275ba497237794c8753c"],["e2cb74fddc8e9fbcd076eef2a7c72b0ce37d50f08269dfc074b581550547a4f7","d3aa2ed71c9dd2247a62df062736eb0baddea9e36122d2be8641abcb005cc4a4"],["8438447566d4d7bedadc299496ab357426009a35f235cb141be0d99cd10ae3a8","c4e1020916980a4da5d01ac5e6ad330734ef0d7906631c4f2390426b2edd791f"],["4162d488b89402039b584c6fc6c308870587d9c46f660b878ab65c82c711d67e","67163e903236289f776f22c25fb8a3afc1732f2b84b4e95dbda47ae5a0852649"],["3fad3fa84caf0f34f0f89bfd2dcf54fc175d767aec3e50684f3ba4a4bf5f683d","cd1bc7cb6cc407bb2f0ca647c718a730cf71872e7d0d2a53fa20efcdfe61826"],["674f2600a3007a00568c1a7ce05d0816c1fb84bf1370798f1c69532faeb1a86b","299d21f9413f33b3edf43b257004580b70db57da0b182259e09eecc69e0d38a5"],["d32f4da54ade74abb81b815ad1fb3b263d82d6c692714bcff87d29bd5ee9f08f","f9429e738b8e53b968e99016c059707782e14f4535359d582fc416910b3eea87"],["30e4e670435385556e593657135845d36fbb6931f72b08cb1ed954f1e3ce3ff6","462f9bce619898638499350113bbc9b10a878d35da70740dc695a559eb88db7b"],["be2062003c51cc3004682904330e4dee7f3dcd10b01e580bf1971b04d4cad297","62188bc49d61e5428573d48a74e1c655b1c61090905682a0d5558ed72dccb9bc"],["93144423ace3451ed29e0fb9ac2af211cb6e84a601df5993c419859fff5df04a","7c10dfb164c3425f5c71a3f9d7992038f1065224f72bb9d1d902a6d13037b47c"],["b015f8044f5fcbdcf21ca26d6c34fb8197829205c7b7d2a7cb66418c157b112c","ab8c1e086d04e813744a655b2df8d5f83b3cdc6faa3088c1d3aea1454e3a1d5f"],["d5e9e1da649d97d89e4868117a465a3a4f8a18de57a140d36b3f2af341a21b52","4cb04437f391ed73111a13cc1d4dd0db1693465c2240480d8955e8592f27447a"],["d3ae41047dd7ca065dbf8ed77b992439983005cd72e16d6f996a5316d36966bb","bd1aeb21ad22ebb22a10f0303417c6d964f8cdd7df0aca614b10dc14d125ac46"],["463e2763d885f958fc66cdd22800f0a487197d0a82e377b49f80af87c897b065","bfefacdb0e5d0fd7df3a311a94de062b26b80c61fbc97508b79992671ef7ca7f"],["7985fdfd127c0567c6f53ec1bb63ec3158e597c40bfe747c83cddfc910641917","603c12daf3d9862ef2b25fe1de289aed24ed291e0ec6708703a5bd567f32ed03"],["74a1ad6b5f76e39db2dd249410eac7f99e74c59cb83d2d0ed5ff1543da7703e9","cc6157ef18c9c63cd6193d83631bbea0093e0968942e8c33d5737fd790e0db08"],["30682a50703375f602d416664ba19b7fc9bab42c72747463a71d0896b22f6da3","553e04f6b018b4fa6c8f39e7f311d3176290d0e0f19ca73f17714d9977a22ff8"],["9e2158f0d7c0d5f26c3791efefa79597654e7a2b2464f52b1ee6c1347769ef57","712fcdd1b9053f09003a3481fa7762e9ffd7c8ef35a38509e2fbf2629008373"],["176e26989a43c9cfeba4029c202538c28172e566e3c4fce7322857f3be327d66","ed8cc9d04b29eb877d270b4878dc43c19aefd31f4eee09ee7b47834c1fa4b1c3"],["75d46efea3771e6e68abb89a13ad747ecf1892393dfc4f1b7004788c50374da8","9852390a99507679fd0b86fd2b39a868d7efc22151346e1a3ca4726586a6bed8"],["809a20c67d64900ffb698c4c825f6d5f2310fb0451c869345b7319f645605721","9e994980d9917e22b76b061927fa04143d096ccc54963e6a5ebfa5f3f8e286c1"],["1b38903a43f7f114ed4500b4eac7083fdefece1cf29c63528d563446f972c180","4036edc931a60ae889353f77fd53de4a2708b26b6f5da72ad3394119daf408f9"]]}}}),X0=OJ((l)=>{var g=l,R=Z0(),M=U6(),B=mQ(),A=B.assert;function q(O){O.type==="short"?this.curve=new M.short(O):O.type==="edwards"?this.curve=new M.edwards(O):this.curve=new M.mont(O),this.g=this.curve.g,this.n=this.curve.n,this.hash=O.hash,A(this.g.validate(),"Invalid curve"),A(this.g.mul(this.n).isInfinity(),"Invalid curve, G*N != O")}g.PresetCurve=q;function Y(O,N){Object.defineProperty(g,O,{configurable:!0,enumerable:!0,get:function(){var W=new q(N);return Object.defineProperty(g,O,{configurable:!0,enumerable:!0,value:W}),W}})}Y("p192",{type:"short",prime:"p192",p:"ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff",a:"ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc",b:"64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1",n:"ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831",hash:R.sha256,gRed:!1,g:["188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012","07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811"]}),Y("p224",{type:"short",prime:"p224",p:"ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001",a:"ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe",b:"b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4",n:"ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d",hash:R.sha256,gRed:!1,g:["b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21","bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34"]}),Y("p256",{type:"short",prime:null,p:"ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff",a:"ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc",b:"5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b",n:"ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551",hash:R.sha256,gRed:!1,g:["6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296","4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5"]}),Y("p384",{type:"short",prime:null,p:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe ffffffff 00000000 00000000 ffffffff",a:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe ffffffff 00000000 00000000 fffffffc",b:"b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f 5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef",n:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 f4372ddf 581a0db2 48b0a77a ecec196a ccc52973",hash:R.sha384,gRed:!1,g:["aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 5502f25d bf55296c 3a545e38 72760ab7","3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 0a60b1ce 1d7e819d 7a431d7c 90ea0e5f"]}),Y("p521",{type:"short",prime:null,p:"000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff",a:"000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffc",b:"00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b 99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd 3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00",n:"000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409",hash:R.sha512,gRed:!1,g:["000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66","00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 3fad0761 353c7086 a272c240 88be9476 9fd16650"]}),Y("curve25519",{type:"mont",prime:"p25519",p:"7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed",a:"76d06",b:"1",n:"1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed",hash:R.sha256,gRed:!1,g:["9"]}),Y("ed25519",{type:"edwards",prime:"p25519",p:"7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed",a:"-1",c:"1",d:"52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3",n:"1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed",hash:R.sha256,gRed:!1,g:["216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a","6666666666666666666666666666666666666666666666666666666666666658"]});var E;try{E=Z$()}catch{E=void 0}Y("secp256k1",{type:"short",prime:"k256",p:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f",a:"0",b:"7",n:"ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141",h:"1",hash:R.sha256,beta:"7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee",lambda:"5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72",basis:[{a:"3086d221a7d46bcde86c90e49284eb15",b:"-e4437ed6010e88286f547fa90abfe4c3"},{a:"114ca50f7a8e2f3f657c1108d9d44cfd8",b:"3086d221a7d46bcde86c90e49284eb15"}],gRed:!1,g:["79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798","483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8",E]})}),X$=OJ((l,g)=>{var R=Z0(),M=K6(),B=hQ();function A(q){if(!(this instanceof A))return new A(q);this.hash=q.hash,this.predResist=!!q.predResist,this.outLen=this.hash.outSize,this.minEntropy=q.minEntropy||this.hash.hmacStrength,this._reseed=null,this.reseedInterval=null,this.K=null,this.V=null;var Y=M.toArray(q.entropy,q.entropyEnc||"hex"),E=M.toArray(q.nonce,q.nonceEnc||"hex"),O=M.toArray(q.pers,q.persEnc||"hex");B(Y.length>=this.minEntropy/8,"Not enough entropy. Minimum is: "+this.minEntropy+" bits"),this._init(Y,E,O)}g.exports=A,A.prototype._init=function(q,Y,E){var O=q.concat(Y).concat(E);this.K=new Array(this.outLen/8),this.V=new Array(this.outLen/8);for(var N=0;N<this.V.length;N++)this.K[N]=0,this.V[N]=1;this._update(O),this._reseed=1,this.reseedInterval=281474976710656},A.prototype._hmac=function(){return new R.hmac(this.hash,this.K)},A.prototype._update=function(q){var Y=this._hmac().update(this.V).update([0]);q&&(Y=Y.update(q)),this.K=Y.digest(),this.V=this._hmac().update(this.V).digest(),q&&(this.K=this._hmac().update(this.V).update([1]).update(q).digest(),this.V=this._hmac().update(this.V).digest())},A.prototype.reseed=function(q,Y,E,O){typeof Y!="string"&&(O=E,E=Y,Y=null),q=M.toArray(q,Y),E=M.toArray(E,O),B(q.length>=this.minEntropy/8,"Not enough entropy. Minimum is: "+this.minEntropy+" bits"),this._update(q.concat(E||[])),this._reseed=1},A.prototype.generate=function(q,Y,E,O){if(this._reseed>this.reseedInterval)throw new Error("Reseed is required");typeof Y!="string"&&(O=E,E=Y,Y=null),E&&(E=M.toArray(E,O||"hex"),this._update(E));for(var N=[];N.length<q;)this.V=this._hmac().update(this.V).digest(),N=N.concat(this.V);var W=N.slice(0,q);return this._update(E),this._reseed++,M.encode(W,Y)}}),q$=OJ((l,g)=>{var R=dQ(),M=mQ(),B=M.assert;function A(q,Y){this.ec=q,this.priv=null,this.pub=null,Y.priv&&this._importPrivate(Y.priv,Y.privEnc),Y.pub&&this._importPublic(Y.pub,Y.pubEnc)}g.exports=A,A.fromPublic=function(q,Y,E){return Y instanceof A?Y:new A(q,{pub:Y,pubEnc:E})},A.fromPrivate=function(q,Y,E){return Y instanceof A?Y:new A(q,{priv:Y,privEnc:E})},A.prototype.validate=function(){var q=this.getPublic();return q.isInfinity()?{result:!1,reason:"Invalid public key"}:q.validate()?q.mul(this.ec.curve.n).isInfinity()?{result:!0,reason:null}:{result:!1,reason:"Public key * N != O"}:{result:!1,reason:"Public key is not a point"}},A.prototype.getPublic=function(q,Y){return typeof q=="string"&&(Y=q,q=null),this.pub||(this.pub=this.ec.g.mul(this.priv)),Y?this.pub.encode(Y,q):this.pub},A.prototype.getPrivate=function(q){return q==="hex"?this.priv.toString(16,2):this.priv},A.prototype._importPrivate=function(q,Y){this.priv=new R(q,Y||16),this.priv=this.priv.umod(this.ec.curve.n)},A.prototype._importPublic=function(q,Y){if(q.x||q.y){this.ec.curve.type==="mont"?B(q.x,"Need x coordinate"):(this.ec.curve.type==="short"||this.ec.curve.type==="edwards")&&B(q.x&&q.y,"Need both x and y coordinate"),this.pub=this.ec.curve.point(q.x,q.y);return}this.pub=this.ec.curve.decodePoint(q,Y)},A.prototype.derive=function(q){return q.validate()||B(q.validate(),"public point not validated"),q.mul(this.priv).getX()},A.prototype.sign=function(q,Y,E){return this.ec.sign(q,this,Y,E)},A.prototype.verify=function(q,Y){return this.ec.verify(q,Y,this)},A.prototype.inspect=function(){return"<Key priv: "+(this.priv&&this.priv.toString(16,2))+" pub: "+(this.pub&&this.pub.inspect())+" >"}}),G$=OJ((l,g)=>{var R=dQ(),M=mQ(),B=M.assert;function A(N,W){if(N instanceof A)return N;this._importDER(N,W)||(B(N.r&&N.s,"Signature without r or s"),this.r=new R(N.r,16),this.s=new R(N.s,16),N.recoveryParam===void 0?this.recoveryParam=null:this.recoveryParam=N.recoveryParam)}g.exports=A;function q(){this.place=0}function Y(N,W){var I=N[W.place++];if(!(I&128))return I;var z=I&15;if(z===0||z>4)return!1;for(var j=0,P=0,F=W.place;P<z;P++,F++)j<<=8,j|=N[F],j>>>=0;return j<=127?!1:(W.place=F,j)}function E(N){for(var W=0,I=N.length-1;!N[W]&&!(N[W+1]&128)&&W<I;)W++;return W===0?N:N.slice(W)}A.prototype._importDER=function(N,W){N=M.toArray(N,W);var I=new q;if(N[I.place++]!==48)return!1;var z=Y(N,I);if(z===!1||z+I.place!==N.length||N[I.place++]!==2)return!1;var j=Y(N,I);if(j===!1)return!1;var P=N.slice(I.place,j+I.place);if(I.place+=j,N[I.place++]!==2)return!1;var F=Y(N,I);if(F===!1||N.length!==F+I.place)return!1;var v=N.slice(I.place,F+I.place);if(P[0]===0)if(P[1]&128)P=P.slice(1);else return!1;if(v[0]===0)if(v[1]&128)v=v.slice(1);else return!1;return this.r=new R(P),this.s=new R(v),this.recoveryParam=null,!0};function O(N,W){if(W<128){N.push(W);return}var I=1+(Math.log(W)/Math.LN2>>>3);for(N.push(I|128);--I;)N.push(W>>>(I<<3)&255);N.push(W)}A.prototype.toDER=function(N){var W=this.r.toArray(),I=this.s.toArray();for(W[0]&128&&(W=[0].concat(W)),I[0]&128&&(I=[0].concat(I)),W=E(W),I=E(I);!I[0]&&!(I[1]&128);)I=I.slice(1);var z=[2];O(z,W.length),z=z.concat(W),z.push(2),O(z,I.length);var j=z.concat(I),P=[48];return O(P,j.length),P=P.concat(j),M.encode(P,N)}}),K$=OJ((l,g)=>{var R=dQ(),M=X$(),B=mQ(),A=X0(),q=J0(),Y=B.assert,E=q$(),O=G$();function N(W){if(!(this instanceof N))return new N(W);typeof W=="string"&&(Y(Object.prototype.hasOwnProperty.call(A,W),"Unknown curve "+W),W=A[W]),W instanceof A.PresetCurve&&(W={curve:W}),this.curve=W.curve.curve,this.n=this.curve.n,this.nh=this.n.ushrn(1),this.g=this.curve.g,this.g=W.curve.g,this.g.precompute(W.curve.n.bitLength()+1),this.hash=W.hash||W.curve.hash}g.exports=N,N.prototype.keyPair=function(W){return new E(this,W)},N.prototype.keyFromPrivate=function(W,I){return E.fromPrivate(this,W,I)},N.prototype.keyFromPublic=function(W,I){return E.fromPublic(this,W,I)},N.prototype.genKeyPair=function(W){W||(W={});for(var I=new M({hash:this.hash,pers:W.pers,persEnc:W.persEnc||"utf8",entropy:W.entropy||q(this.hash.hmacStrength),entropyEnc:W.entropy&&W.entropyEnc||"utf8",nonce:this.n.toArray()}),z=this.n.byteLength(),j=this.n.sub(new R(2));;){var P=new R(I.generate(z));if(!(P.cmp(j)>0))return P.iaddn(1),this.keyFromPrivate(P)}},N.prototype._truncateToN=function(W,I){var z=W.byteLength()*8-this.n.bitLength();return z>0&&(W=W.ushrn(z)),!I&&W.cmp(this.n)>=0?W.sub(this.n):W},N.prototype.sign=function(W,I,z,j){typeof z=="object"&&(j=z,z=null),j||(j={}),I=this.keyFromPrivate(I,z),W=this._truncateToN(new R(W,16));for(var P=this.n.byteLength(),F=I.getPrivate().toArray("be",P),v=W.toArray("be",P),S=new M({hash:this.hash,entropy:F,nonce:v,pers:j.pers,persEnc:j.persEnc||"utf8"}),w=this.n.sub(new R(1)),y=0;;y++){var m=j.k?j.k(y):new R(S.generate(this.n.byteLength()));if(m=this._truncateToN(m,!0),!(m.cmpn(1)<=0||m.cmp(w)>=0)){var i=this.g.mul(m);if(!i.isInfinity()){var JJ=i.getX(),VJ=JJ.umod(this.n);if(VJ.cmpn(0)!==0){var HJ=m.invm(this.n).mul(VJ.mul(I.getPrivate()).iadd(W));if(HJ=HJ.umod(this.n),HJ.cmpn(0)!==0){var o=(i.getY().isOdd()?1:0)|(JJ.cmp(VJ)!==0?2:0);return j.canonical&&HJ.cmp(this.nh)>0&&(HJ=this.n.sub(HJ),o^=1),new O({r:VJ,s:HJ,recoveryParam:o})}}}}}},N.prototype.verify=function(W,I,z,j){W=this._truncateToN(new R(W,16)),z=this.keyFromPublic(z,j),I=new O(I,"hex");var{r:P,s:F}=I;if(P.cmpn(1)<0||P.cmp(this.n)>=0||F.cmpn(1)<0||F.cmp(this.n)>=0)return!1;var v=F.invm(this.n),S=v.mul(W).umod(this.n),w=v.mul(P).umod(this.n),y;return this.curve._maxwellTrick?(y=this.g.jmulAdd(S,z.getPublic(),w),y.isInfinity()?!1:y.eqXToP(P)):(y=this.g.mulAdd(S,z.getPublic(),w),y.isInfinity()?!1:y.getX().umod(this.n).cmp(P)===0)},N.prototype.recoverPubKey=function(W,I,z,j){Y((3&z)===z,"The recovery param is more than two bits"),I=new O(I,j);var P=this.n,F=new R(W),v=I.r,S=I.s,w=z&1,y=z>>1;if(v.cmp(this.curve.p.umod(this.curve.n))>=0&&y)throw new Error("Unable to find sencond key candinate");y?v=this.curve.pointFromX(v.add(this.curve.n),w):v=this.curve.pointFromX(v,w);var m=I.r.invm(P),i=P.sub(F).mul(m).umod(P),JJ=S.mul(m).umod(P);return this.g.mulAdd(i,v,JJ)},N.prototype.getKeyRecoveryParam=function(W,I,z,j){if(I=new O(I,j),I.recoveryParam!==null)return I.recoveryParam;for(var P=0;P<4;P++){var F;try{F=this.recoverPubKey(W,I,P)}catch{continue}if(F.eq(z))return P}throw new Error("Unable to find valid recovery factor")}}),U$=OJ((l,g)=>{var R=mQ(),M=R.assert,B=R.parseBytes,A=R.cachedProperty;function q(Y,E){this.eddsa=Y,this._secret=B(E.secret),Y.isPoint(E.pub)?this._pub=E.pub:this._pubBytes=B(E.pub)}q.fromPublic=function(Y,E){return E instanceof q?E:new q(Y,{pub:E})},q.fromSecret=function(Y,E){return E instanceof q?E:new q(Y,{secret:E})},q.prototype.secret=function(){return this._secret},A(q,"pubBytes",function(){return this.eddsa.encodePoint(this.pub())}),A(q,"pub",function(){return this._pubBytes?this.eddsa.decodePoint(this._pubBytes):this.eddsa.g.mul(this.priv())}),A(q,"privBytes",function(){var Y=this.eddsa,E=this.hash(),O=Y.encodingLength-1,N=E.slice(0,Y.encodingLength);return N[0]&=248,N[O]&=127,N[O]|=64,N}),A(q,"priv",function(){return this.eddsa.decodeInt(this.privBytes())}),A(q,"hash",function(){return this.eddsa.hash().update(this.secret()).digest()}),A(q,"messagePrefix",function(){return this.hash().slice(this.eddsa.encodingLength)}),q.prototype.sign=function(Y){return M(this._secret,"KeyPair can only verify"),this.eddsa.sign(Y,this)},q.prototype.verify=function(Y,E){return this.eddsa.verify(Y,E,this)},q.prototype.getSecret=function(Y){return M(this._secret,"KeyPair is public only"),R.encode(this.secret(),Y)},q.prototype.getPublic=function(Y){return R.encode(this.pubBytes(),Y)},g.exports=q}),H$=OJ((l,g)=>{var R=dQ(),M=mQ(),B=M.assert,A=M.cachedProperty,q=M.parseBytes;function Y(E,O){this.eddsa=E,typeof O!="object"&&(O=q(O)),Array.isArray(O)&&(O={R:O.slice(0,E.encodingLength),S:O.slice(E.encodingLength)}),B(O.R&&O.S,"Signature without R or S"),E.isPoint(O.R)&&(this._R=O.R),O.S instanceof R&&(this._S=O.S),this._Rencoded=Array.isArray(O.R)?O.R:O.Rencoded,this._Sencoded=Array.isArray(O.S)?O.S:O.Sencoded}A(Y,"S",function(){return this.eddsa.decodeInt(this.Sencoded())}),A(Y,"R",function(){return this.eddsa.decodePoint(this.Rencoded())}),A(Y,"Rencoded",function(){return this.eddsa.encodePoint(this.R())}),A(Y,"Sencoded",function(){return this.eddsa.encodeInt(this.S())}),Y.prototype.toBytes=function(){return this.Rencoded().concat(this.Sencoded())},Y.prototype.toHex=function(){return M.encode(this.toBytes(),"hex").toUpperCase()},g.exports=Y}),W$=OJ((l,g)=>{var R=Z0(),M=X0(),B=mQ(),A=B.assert,q=B.parseBytes,Y=U$(),E=H$();function O(N){if(A(N==="ed25519","only tested with ed25519 so far"),!(this instanceof O))return new O(N);N=M[N].curve,this.curve=N,this.g=N.g,this.g.precompute(N.n.bitLength()+1),this.pointClass=N.point().constructor,this.encodingLength=Math.ceil(N.n.bitLength()/8),this.hash=R.sha512}g.exports=O,O.prototype.sign=function(N,W){N=q(N);var I=this.keyFromSecret(W),z=this.hashInt(I.messagePrefix(),N),j=this.g.mul(z),P=this.encodePoint(j),F=this.hashInt(P,I.pubBytes(),N).mul(I.priv()),v=z.add(F).umod(this.curve.n);return this.makeSignature({R:j,S:v,Rencoded:P})},O.prototype.verify=function(N,W,I){N=q(N),W=this.makeSignature(W);var z=this.keyFromPublic(I),j=this.hashInt(W.Rencoded(),z.pubBytes(),N),P=this.g.mul(W.S()),F=W.R().add(z.pub().mul(j));return F.eq(P)},O.prototype.hashInt=function(){for(var N=this.hash(),W=0;W<arguments.length;W++)N.update(arguments[W]);return B.intFromLE(N.digest()).umod(this.curve.n)},O.prototype.keyFromPublic=function(N){return Y.fromPublic(this,N)},O.prototype.keyFromSecret=function(N){return Y.fromSecret(this,N)},O.prototype.makeSignature=function(N){return N instanceof E?N:new E(this,N)},O.prototype.encodePoint=function(N){var W=N.getY().toArray("le",this.encodingLength);return W[this.encodingLength-1]|=N.getX().isOdd()?128:0,W},O.prototype.decodePoint=function(N){N=B.parseBytes(N);var W=N.length-1,I=N.slice(0,W).concat(N[W]&-129),z=(N[W]&128)!==0,j=B.intFromLE(I);return this.curve.pointFromY(j,z)},O.prototype.encodeInt=function(N){return N.toArray("le",this.encodingLength)},O.prototype.decodeInt=function(N){return B.intFromLE(N)},O.prototype.isPoint=function(N){return N instanceof this.pointClass}}),q0=OJ((l)=>{var g=l;g.version=n8().version,g.utils=mQ(),g.rand=J0(),g.curve=U6(),g.curves=X0(),g.ec=K$(),g.eddsa=W$()}),B6=OJ((l,g)=>{(function(R,M){function B(J,V){if(!J)throw new Error(V||"Assertion failed")}function A(J,V){J.super_=V;var Z=function(){};Z.prototype=V.prototype,J.prototype=new Z,J.prototype.constructor=J}function q(J,V,Z){if(q.isBN(J))return J;this.negative=0,this.words=null,this.length=0,this.red=null,J!==null&&((V==="le"||V==="be")&&(Z=V,V=10),this._init(J||0,V||10,Z||"be"))}typeof R=="object"?R.exports=q:M.BN=q,q.BN=q,q.wordSize=26;var Y;try{typeof window<"u"&&typeof window.Buffer<"u"?Y=window.Buffer:Y=JV().Buffer}catch{}q.isBN=function(J){return J instanceof q?!0:J!==null&&typeof J=="object"&&J.constructor.wordSize===q.wordSize&&Array.isArray(J.words)},q.max=function(J,V){return J.cmp(V)>0?J:V},q.min=function(J,V){return J.cmp(V)<0?J:V},q.prototype._init=function(J,V,Z){if(typeof J=="number")return this._initNumber(J,V,Z);if(typeof J=="object")return this._initArray(J,V,Z);V==="hex"&&(V=16),B(V===(V|0)&&V>=2&&V<=36),J=J.toString().replace(/\s+/g,"");var $=0;J[0]==="-"&&($++,this.negative=1),$<J.length&&(V===16?this._parseHex(J,$,Z):(this._parseBase(J,V,$),Z==="le"&&this._initArray(this.toArray(),V,Z)))},q.prototype._initNumber=function(J,V,Z){J<0&&(this.negative=1,J=-J),J<67108864?(this.words=[J&67108863],this.length=1):J<4503599627370496?(this.words=[J&67108863,J/67108864&67108863],this.length=2):(B(J<9007199254740992),this.words=[J&67108863,J/67108864&67108863,1],this.length=3),Z==="le"&&this._initArray(this.toArray(),V,Z)},q.prototype._initArray=function(J,V,Z){if(B(typeof J.length=="number"),J.length<=0)return this.words=[0],this.length=1,this;this.length=Math.ceil(J.length/3),this.words=new Array(this.length);for(var $=0;$<this.length;$++)this.words[$]=0;var X,U,H=0;if(Z==="be")for($=J.length-1,X=0;$>=0;$-=3)U=J[$]|J[$-1]<<8|J[$-2]<<16,this.words[X]|=U<<H&67108863,this.words[X+1]=U>>>26-H&67108863,H+=24,H>=26&&(H-=26,X++);else if(Z==="le")for($=0,X=0;$<J.length;$+=3)U=J[$]|J[$+1]<<8|J[$+2]<<16,this.words[X]|=U<<H&67108863,this.words[X+1]=U>>>26-H&67108863,H+=24,H>=26&&(H-=26,X++);return this.strip()};function E(J,V){var Z=J.charCodeAt(V);return Z>=65&&Z<=70?Z-55:Z>=97&&Z<=102?Z-87:Z-48&15}function O(J,V,Z){var $=E(J,Z);return Z-1>=V&&($|=E(J,Z-1)<<4),$}q.prototype._parseHex=function(J,V,Z){this.length=Math.ceil((J.length-V)/6),this.words=new Array(this.length);for(var $=0;$<this.length;$++)this.words[$]=0;var X=0,U=0,H;if(Z==="be")for($=J.length-1;$>=V;$-=2)H=O(J,V,$)<<X,this.words[U]|=H&67108863,X>=18?(X-=18,U+=1,this.words[U]|=H>>>26):X+=8;else{var G=J.length-V;for($=G%2===0?V+1:V;$<J.length;$+=2)H=O(J,V,$)<<X,this.words[U]|=H&67108863,X>=18?(X-=18,U+=1,this.words[U]|=H>>>26):X+=8}this.strip()};function N(J,V,Z,$){for(var X=0,U=Math.min(J.length,Z),H=V;H<U;H++){var G=J.charCodeAt(H)-48;X*=$,G>=49?X+=G-49+10:G>=17?X+=G-17+10:X+=G}return X}q.prototype._parseBase=function(J,V,Z){this.words=[0],this.length=1;for(var $=0,X=1;X<=67108863;X*=V)$++;$--,X=X/V|0;for(var U=J.length-Z,H=U%$,G=Math.min(U,U-H)+Z,Q=0,K=Z;K<G;K+=$)Q=N(J,K,K+$,V),this.imuln(X),this.words[0]+Q<67108864?this.words[0]+=Q:this._iaddn(Q);if(H!==0){var k=1;for(Q=N(J,K,J.length,V),K=0;K<H;K++)k*=V;this.imuln(k),this.words[0]+Q<67108864?this.words[0]+=Q:this._iaddn(Q)}this.strip()},q.prototype.copy=function(J){J.words=new Array(this.length);for(var V=0;V<this.length;V++)J.words[V]=this.words[V];J.length=this.length,J.negative=this.negative,J.red=this.red},q.prototype.clone=function(){var J=new q(null);return this.copy(J),J},q.prototype._expand=function(J){for(;this.length<J;)this.words[this.length++]=0;return this},q.prototype.strip=function(){for(;this.length>1&&this.words[this.length-1]===0;)this.length--;return this._normSign()},q.prototype._normSign=function(){return this.length===1&&this.words[0]===0&&(this.negative=0),this},q.prototype.inspect=function(){return(this.red?"<BN-R: ":"<BN: ")+this.toString(16)+">"};var W=["","0","00","000","0000","00000","000000","0000000","00000000","000000000","0000000000","00000000000","000000000000","0000000000000","00000000000000","000000000000000","0000000000000000","00000000000000000","000000000000000000","0000000000000000000","00000000000000000000","000000000000000000000","0000000000000000000000","00000000000000000000000","000000000000000000000000","0000000000000000000000000"],I=[0,0,25,16,12,11,10,9,8,8,7,7,7,7,6,6,6,6,6,6,6,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5],z=[0,0,33554432,43046721,16777216,48828125,60466176,40353607,16777216,43046721,1e7,19487171,35831808,62748517,7529536,11390625,16777216,24137569,34012224,47045881,64000000,4084101,5153632,6436343,7962624,9765625,11881376,14348907,17210368,20511149,24300000,28629151,33554432,39135393,45435424,52521875,60466176];q.prototype.toString=function(J,V){J=J||10,V=V|0||1;var Z;if(J===16||J==="hex"){Z="";for(var $=0,X=0,U=0;U<this.length;U++){var H=this.words[U],G=((H<<$|X)&16777215).toString(16);X=H>>>24-$&16777215,X!==0||U!==this.length-1?Z=W[6-G.length]+G+Z:Z=G+Z,$+=2,$>=26&&($-=26,U--)}for(X!==0&&(Z=X.toString(16)+Z);Z.length%V!==0;)Z="0"+Z;return this.negative!==0&&(Z="-"+Z),Z}if(J===(J|0)&&J>=2&&J<=36){var Q=I[J],K=z[J];Z="";var k=this.clone();for(k.negative=0;!k.isZero();){var L=k.modn(K).toString(J);k=k.idivn(K),k.isZero()?Z=L+Z:Z=W[Q-L.length]+L+Z}for(this.isZero()&&(Z="0"+Z);Z.length%V!==0;)Z="0"+Z;return this.negative!==0&&(Z="-"+Z),Z}B(!1,"Base should be between 2 and 36")},q.prototype.toNumber=function(){var J=this.words[0];return this.length===2?J+=this.words[1]*67108864:this.length===3&&this.words[2]===1?J+=4503599627370496+this.words[1]*67108864:this.length>2&&B(!1,"Number can only safely store up to 53 bits"),this.negative!==0?-J:J},q.prototype.toJSON=function(){return this.toString(16)},q.prototype.toBuffer=function(J,V){return B(typeof Y<"u"),this.toArrayLike(Y,J,V)},q.prototype.toArray=function(J,V){return this.toArrayLike(Array,J,V)},q.prototype.toArrayLike=function(J,V,Z){var $=this.byteLength(),X=Z||Math.max(1,$);B($<=X,"byte array longer than desired length"),B(X>0,"Requested array length <= 0"),this.strip();var U=V==="le",H=new J(X),G,Q,K=this.clone();if(U){for(Q=0;!K.isZero();Q++)G=K.andln(255),K.iushrn(8),H[Q]=G;for(;Q<X;Q++)H[Q]=0}else{for(Q=0;Q<X-$;Q++)H[Q]=0;for(Q=0;!K.isZero();Q++)G=K.andln(255),K.iushrn(8),H[X-Q-1]=G}return H},Math.clz32?q.prototype._countBits=function(J){return 32-Math.clz32(J)}:q.prototype._countBits=function(J){var V=J,Z=0;return V>=4096&&(Z+=13,V>>>=13),V>=64&&(Z+=7,V>>>=7),V>=8&&(Z+=4,V>>>=4),V>=2&&(Z+=2,V>>>=2),Z+V},q.prototype._zeroBits=function(J){if(J===0)return 26;var V=J,Z=0;return(V&8191)===0&&(Z+=13,V>>>=13),(V&127)===0&&(Z+=7,V>>>=7),(V&15)===0&&(Z+=4,V>>>=4),(V&3)===0&&(Z+=2,V>>>=2),(V&1)===0&&Z++,Z},q.prototype.bitLength=function(){var J=this.words[this.length-1],V=this._countBits(J);return(this.length-1)*26+V};function j(J){for(var V=new Array(J.bitLength()),Z=0;Z<V.length;Z++){var $=Z/26|0,X=Z%26;V[Z]=(J.words[$]&1<<X)>>>X}return V}q.prototype.zeroBits=function(){if(this.isZero())return 0;for(var J=0,V=0;V<this.length;V++){var Z=this._zeroBits(this.words[V]);if(J+=Z,Z!==26)break}return J},q.prototype.byteLength=function(){return Math.ceil(this.bitLength()/8)},q.prototype.toTwos=function(J){return this.negative!==0?this.abs().inotn(J).iaddn(1):this.clone()},q.prototype.fromTwos=function(J){return this.testn(J-1)?this.notn(J).iaddn(1).ineg():this.clone()},q.prototype.isNeg=function(){return this.negative!==0},q.prototype.neg=function(){return this.clone().ineg()},q.prototype.ineg=function(){return this.isZero()||(this.negative^=1),this},q.prototype.iuor=function(J){for(;this.length<J.length;)this.words[this.length++]=0;for(var V=0;V<J.length;V++)this.words[V]=this.words[V]|J.words[V];return this.strip()},q.prototype.ior=function(J){return B((this.negative|J.negative)===0),this.iuor(J)},q.prototype.or=function(J){return this.length>J.length?this.clone().ior(J):J.clone().ior(this)},q.prototype.uor=function(J){return this.length>J.length?this.clone().iuor(J):J.clone().iuor(this)},q.prototype.iuand=function(J){var V;this.length>J.length?V=J:V=this;for(var Z=0;Z<V.length;Z++)this.words[Z]=this.words[Z]&J.words[Z];return this.length=V.length,this.strip()},q.prototype.iand=function(J){return B((this.negative|J.negative)===0),this.iuand(J)},q.prototype.and=function(J){return this.length>J.length?this.clone().iand(J):J.clone().iand(this)},q.prototype.uand=function(J){return this.length>J.length?this.clone().iuand(J):J.clone().iuand(this)},q.prototype.iuxor=function(J){var V,Z;this.length>J.length?(V=this,Z=J):(V=J,Z=this);for(var $=0;$<Z.length;$++)this.words[$]=V.words[$]^Z.words[$];if(this!==V)for(;$<V.length;$++)this.words[$]=V.words[$];return this.length=V.length,this.strip()},q.prototype.ixor=function(J){return B((this.negative|J.negative)===0),this.iuxor(J)},q.prototype.xor=function(J){return this.length>J.length?this.clone().ixor(J):J.clone().ixor(this)},q.prototype.uxor=function(J){return this.length>J.length?this.clone().iuxor(J):J.clone().iuxor(this)},q.prototype.inotn=function(J){B(typeof J=="number"&&J>=0);var V=Math.ceil(J/26)|0,Z=J%26;this._expand(V),Z>0&&V--;for(var $=0;$<V;$++)this.words[$]=~this.words[$]&67108863;return Z>0&&(this.words[$]=~this.words[$]&67108863>>26-Z),this.strip()},q.prototype.notn=function(J){return this.clone().inotn(J)},q.prototype.setn=function(J,V){B(typeof J=="number"&&J>=0);var Z=J/26|0,$=J%26;return this._expand(Z+1),V?this.words[Z]=this.words[Z]|1<<$:this.words[Z]=this.words[Z]&~(1<<$),this.strip()},q.prototype.iadd=function(J){var V;if(this.negative!==0&&J.negative===0)return this.negative=0,V=this.isub(J),this.negative^=1,this._normSign();if(this.negative===0&&J.negative!==0)return J.negative=0,V=this.isub(J),J.negative=1,V._normSign();var Z,$;this.length>J.length?(Z=this,$=J):(Z=J,$=this);for(var X=0,U=0;U<$.length;U++)V=(Z.words[U]|0)+($.words[U]|0)+X,this.words[U]=V&67108863,X=V>>>26;for(;X!==0&&U<Z.length;U++)V=(Z.words[U]|0)+X,this.words[U]=V&67108863,X=V>>>26;if(this.length=Z.length,X!==0)this.words[this.length]=X,this.length++;else if(Z!==this)for(;U<Z.length;U++)this.words[U]=Z.words[U];return this},q.prototype.add=function(J){var V;return J.negative!==0&&this.negative===0?(J.negative=0,V=this.sub(J),J.negative^=1,V):J.negative===0&&this.negative!==0?(this.negative=0,V=J.sub(this),this.negative=1,V):this.length>J.length?this.clone().iadd(J):J.clone().iadd(this)},q.prototype.isub=function(J){if(J.negative!==0){J.negative=0;var V=this.iadd(J);return J.negative=1,V._normSign()}else if(this.negative!==0)return this.negative=0,this.iadd(J),this.negative=1,this._normSign();var Z=this.cmp(J);if(Z===0)return this.negative=0,this.length=1,this.words[0]=0,this;var $,X;Z>0?($=this,X=J):($=J,X=this);for(var U=0,H=0;H<X.length;H++)V=($.words[H]|0)-(X.words[H]|0)+U,U=V>>26,this.words[H]=V&67108863;for(;U!==0&&H<$.length;H++)V=($.words[H]|0)+U,U=V>>26,this.words[H]=V&67108863;if(U===0&&H<$.length&&$!==this)for(;H<$.length;H++)this.words[H]=$.words[H];return this.length=Math.max(this.length,H),$!==this&&(this.negative=1),this.strip()},q.prototype.sub=function(J){return this.clone().isub(J)};function P(J,V,Z){Z.negative=V.negative^J.negative;var $=J.length+V.length|0;Z.length=$,$=$-1|0;var X=J.words[0]|0,U=V.words[0]|0,H=X*U,G=H&67108863,Q=H/67108864|0;Z.words[0]=G;for(var K=1;K<$;K++){for(var k=Q>>>26,L=Q&67108863,_=Math.min(K,V.length-1),t=Math.max(0,K-J.length+1);t<=_;t++){var QJ=K-t|0;X=J.words[QJ]|0,U=V.words[t]|0,H=X*U+L,k+=H/67108864|0,L=H&67108863}Z.words[K]=L|0,Q=k|0}return Q!==0?Z.words[K]=Q|0:Z.length--,Z.strip()}var F=function(J,V,Z){var $=J.words,X=V.words,U=Z.words,H=0,G,Q,K,k=$[0]|0,L=k&8191,_=k>>>13,t=$[1]|0,QJ=t&8191,GJ=t>>>13,n=$[2]|0,p=n&8191,e=n>>>13,PJ=$[3]|0,XJ=PJ&8191,WJ=PJ>>>13,b=$[4]|0,C=b&8191,h=b>>>13,$J=$[5]|0,qJ=$J&8191,ZJ=$J>>>13,mJ=$[6]|0,BJ=mJ&8191,TJ=mJ>>>13,dJ=$[7]|0,LJ=dJ&8191,IJ=dJ>>>13,$Q=$[8]|0,T=$Q&8191,D=$Q>>>13,u=$[9]|0,d=u&8191,a=u>>>13,CJ=X[0]|0,UJ=CJ&8191,EJ=CJ>>>13,QQ=X[1]|0,FJ=QQ&8191,RJ=QQ>>>13,aJ=X[2]|0,SJ=aJ&8191,xJ=aJ>>>13,nJ=X[3]|0,AJ=nJ&8191,kJ=nJ>>>13,ZQ=X[4]|0,vJ=ZQ&8191,MJ=ZQ>>>13,xQ=X[5]|0,wJ=xQ&8191,bJ=xQ>>>13,WQ=X[6]|0,_J=WQ&8191,NJ=WQ>>>13,vQ=X[7]|0,yJ=vQ&8191,gJ=vQ>>>13,MQ=X[8]|0,cJ=MQ&8191,fJ=MQ>>>13,wQ=X[9]|0,f=wQ&8191,zJ=wQ>>>13;Z.negative=J.negative^V.negative,Z.length=19,G=Math.imul(L,UJ),Q=Math.imul(L,EJ),Q=Q+Math.imul(_,UJ)|0,K=Math.imul(_,EJ);var CQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(CQ>>>26)|0,CQ&=67108863,G=Math.imul(QJ,UJ),Q=Math.imul(QJ,EJ),Q=Q+Math.imul(GJ,UJ)|0,K=Math.imul(GJ,EJ),G=G+Math.imul(L,FJ)|0,Q=Q+Math.imul(L,RJ)|0,Q=Q+Math.imul(_,FJ)|0,K=K+Math.imul(_,RJ)|0;var oJ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(oJ>>>26)|0,oJ&=67108863,G=Math.imul(p,UJ),Q=Math.imul(p,EJ),Q=Q+Math.imul(e,UJ)|0,K=Math.imul(e,EJ),G=G+Math.imul(QJ,FJ)|0,Q=Q+Math.imul(QJ,RJ)|0,Q=Q+Math.imul(GJ,FJ)|0,K=K+Math.imul(GJ,RJ)|0,G=G+Math.imul(L,SJ)|0,Q=Q+Math.imul(L,xJ)|0,Q=Q+Math.imul(_,SJ)|0,K=K+Math.imul(_,xJ)|0;var tJ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(tJ>>>26)|0,tJ&=67108863,G=Math.imul(XJ,UJ),Q=Math.imul(XJ,EJ),Q=Q+Math.imul(WJ,UJ)|0,K=Math.imul(WJ,EJ),G=G+Math.imul(p,FJ)|0,Q=Q+Math.imul(p,RJ)|0,Q=Q+Math.imul(e,FJ)|0,K=K+Math.imul(e,RJ)|0,G=G+Math.imul(QJ,SJ)|0,Q=Q+Math.imul(QJ,xJ)|0,Q=Q+Math.imul(GJ,SJ)|0,K=K+Math.imul(GJ,xJ)|0,G=G+Math.imul(L,AJ)|0,Q=Q+Math.imul(L,kJ)|0,Q=Q+Math.imul(_,AJ)|0,K=K+Math.imul(_,kJ)|0;var YQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(YQ>>>26)|0,YQ&=67108863,G=Math.imul(C,UJ),Q=Math.imul(C,EJ),Q=Q+Math.imul(h,UJ)|0,K=Math.imul(h,EJ),G=G+Math.imul(XJ,FJ)|0,Q=Q+Math.imul(XJ,RJ)|0,Q=Q+Math.imul(WJ,FJ)|0,K=K+Math.imul(WJ,RJ)|0,G=G+Math.imul(p,SJ)|0,Q=Q+Math.imul(p,xJ)|0,Q=Q+Math.imul(e,SJ)|0,K=K+Math.imul(e,xJ)|0,G=G+Math.imul(QJ,AJ)|0,Q=Q+Math.imul(QJ,kJ)|0,Q=Q+Math.imul(GJ,AJ)|0,K=K+Math.imul(GJ,kJ)|0,G=G+Math.imul(L,vJ)|0,Q=Q+Math.imul(L,MJ)|0,Q=Q+Math.imul(_,vJ)|0,K=K+Math.imul(_,MJ)|0;var BQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(BQ>>>26)|0,BQ&=67108863,G=Math.imul(qJ,UJ),Q=Math.imul(qJ,EJ),Q=Q+Math.imul(ZJ,UJ)|0,K=Math.imul(ZJ,EJ),G=G+Math.imul(C,FJ)|0,Q=Q+Math.imul(C,RJ)|0,Q=Q+Math.imul(h,FJ)|0,K=K+Math.imul(h,RJ)|0,G=G+Math.imul(XJ,SJ)|0,Q=Q+Math.imul(XJ,xJ)|0,Q=Q+Math.imul(WJ,SJ)|0,K=K+Math.imul(WJ,xJ)|0,G=G+Math.imul(p,AJ)|0,Q=Q+Math.imul(p,kJ)|0,Q=Q+Math.imul(e,AJ)|0,K=K+Math.imul(e,kJ)|0,G=G+Math.imul(QJ,vJ)|0,Q=Q+Math.imul(QJ,MJ)|0,Q=Q+Math.imul(GJ,vJ)|0,K=K+Math.imul(GJ,MJ)|0,G=G+Math.imul(L,wJ)|0,Q=Q+Math.imul(L,bJ)|0,Q=Q+Math.imul(_,wJ)|0,K=K+Math.imul(_,bJ)|0;var OQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(OQ>>>26)|0,OQ&=67108863,G=Math.imul(BJ,UJ),Q=Math.imul(BJ,EJ),Q=Q+Math.imul(TJ,UJ)|0,K=Math.imul(TJ,EJ),G=G+Math.imul(qJ,FJ)|0,Q=Q+Math.imul(qJ,RJ)|0,Q=Q+Math.imul(ZJ,FJ)|0,K=K+Math.imul(ZJ,RJ)|0,G=G+Math.imul(C,SJ)|0,Q=Q+Math.imul(C,xJ)|0,Q=Q+Math.imul(h,SJ)|0,K=K+Math.imul(h,xJ)|0,G=G+Math.imul(XJ,AJ)|0,Q=Q+Math.imul(XJ,kJ)|0,Q=Q+Math.imul(WJ,AJ)|0,K=K+Math.imul(WJ,kJ)|0,G=G+Math.imul(p,vJ)|0,Q=Q+Math.imul(p,MJ)|0,Q=Q+Math.imul(e,vJ)|0,K=K+Math.imul(e,MJ)|0,G=G+Math.imul(QJ,wJ)|0,Q=Q+Math.imul(QJ,bJ)|0,Q=Q+Math.imul(GJ,wJ)|0,K=K+Math.imul(GJ,bJ)|0,G=G+Math.imul(L,_J)|0,Q=Q+Math.imul(L,NJ)|0,Q=Q+Math.imul(_,_J)|0,K=K+Math.imul(_,NJ)|0;var jQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(jQ>>>26)|0,jQ&=67108863,G=Math.imul(LJ,UJ),Q=Math.imul(LJ,EJ),Q=Q+Math.imul(IJ,UJ)|0,K=Math.imul(IJ,EJ),G=G+Math.imul(BJ,FJ)|0,Q=Q+Math.imul(BJ,RJ)|0,Q=Q+Math.imul(TJ,FJ)|0,K=K+Math.imul(TJ,RJ)|0,G=G+Math.imul(qJ,SJ)|0,Q=Q+Math.imul(qJ,xJ)|0,Q=Q+Math.imul(ZJ,SJ)|0,K=K+Math.imul(ZJ,xJ)|0,G=G+Math.imul(C,AJ)|0,Q=Q+Math.imul(C,kJ)|0,Q=Q+Math.imul(h,AJ)|0,K=K+Math.imul(h,kJ)|0,G=G+Math.imul(XJ,vJ)|0,Q=Q+Math.imul(XJ,MJ)|0,Q=Q+Math.imul(WJ,vJ)|0,K=K+Math.imul(WJ,MJ)|0,G=G+Math.imul(p,wJ)|0,Q=Q+Math.imul(p,bJ)|0,Q=Q+Math.imul(e,wJ)|0,K=K+Math.imul(e,bJ)|0,G=G+Math.imul(QJ,_J)|0,Q=Q+Math.imul(QJ,NJ)|0,Q=Q+Math.imul(GJ,_J)|0,K=K+Math.imul(GJ,NJ)|0,G=G+Math.imul(L,yJ)|0,Q=Q+Math.imul(L,gJ)|0,Q=Q+Math.imul(_,yJ)|0,K=K+Math.imul(_,gJ)|0;var TQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(TQ>>>26)|0,TQ&=67108863,G=Math.imul(T,UJ),Q=Math.imul(T,EJ),Q=Q+Math.imul(D,UJ)|0,K=Math.imul(D,EJ),G=G+Math.imul(LJ,FJ)|0,Q=Q+Math.imul(LJ,RJ)|0,Q=Q+Math.imul(IJ,FJ)|0,K=K+Math.imul(IJ,RJ)|0,G=G+Math.imul(BJ,SJ)|0,Q=Q+Math.imul(BJ,xJ)|0,Q=Q+Math.imul(TJ,SJ)|0,K=K+Math.imul(TJ,xJ)|0,G=G+Math.imul(qJ,AJ)|0,Q=Q+Math.imul(qJ,kJ)|0,Q=Q+Math.imul(ZJ,AJ)|0,K=K+Math.imul(ZJ,kJ)|0,G=G+Math.imul(C,vJ)|0,Q=Q+Math.imul(C,MJ)|0,Q=Q+Math.imul(h,vJ)|0,K=K+Math.imul(h,MJ)|0,G=G+Math.imul(XJ,wJ)|0,Q=Q+Math.imul(XJ,bJ)|0,Q=Q+Math.imul(WJ,wJ)|0,K=K+Math.imul(WJ,bJ)|0,G=G+Math.imul(p,_J)|0,Q=Q+Math.imul(p,NJ)|0,Q=Q+Math.imul(e,_J)|0,K=K+Math.imul(e,NJ)|0,G=G+Math.imul(QJ,yJ)|0,Q=Q+Math.imul(QJ,gJ)|0,Q=Q+Math.imul(GJ,yJ)|0,K=K+Math.imul(GJ,gJ)|0,G=G+Math.imul(L,cJ)|0,Q=Q+Math.imul(L,fJ)|0,Q=Q+Math.imul(_,cJ)|0,K=K+Math.imul(_,fJ)|0;var NQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(NQ>>>26)|0,NQ&=67108863,G=Math.imul(d,UJ),Q=Math.imul(d,EJ),Q=Q+Math.imul(a,UJ)|0,K=Math.imul(a,EJ),G=G+Math.imul(T,FJ)|0,Q=Q+Math.imul(T,RJ)|0,Q=Q+Math.imul(D,FJ)|0,K=K+Math.imul(D,RJ)|0,G=G+Math.imul(LJ,SJ)|0,Q=Q+Math.imul(LJ,xJ)|0,Q=Q+Math.imul(IJ,SJ)|0,K=K+Math.imul(IJ,xJ)|0,G=G+Math.imul(BJ,AJ)|0,Q=Q+Math.imul(BJ,kJ)|0,Q=Q+Math.imul(TJ,AJ)|0,K=K+Math.imul(TJ,kJ)|0,G=G+Math.imul(qJ,vJ)|0,Q=Q+Math.imul(qJ,MJ)|0,Q=Q+Math.imul(ZJ,vJ)|0,K=K+Math.imul(ZJ,MJ)|0,G=G+Math.imul(C,wJ)|0,Q=Q+Math.imul(C,bJ)|0,Q=Q+Math.imul(h,wJ)|0,K=K+Math.imul(h,bJ)|0,G=G+Math.imul(XJ,_J)|0,Q=Q+Math.imul(XJ,NJ)|0,Q=Q+Math.imul(WJ,_J)|0,K=K+Math.imul(WJ,NJ)|0,G=G+Math.imul(p,yJ)|0,Q=Q+Math.imul(p,gJ)|0,Q=Q+Math.imul(e,yJ)|0,K=K+Math.imul(e,gJ)|0,G=G+Math.imul(QJ,cJ)|0,Q=Q+Math.imul(QJ,fJ)|0,Q=Q+Math.imul(GJ,cJ)|0,K=K+Math.imul(GJ,fJ)|0,G=G+Math.imul(L,f)|0,Q=Q+Math.imul(L,zJ)|0,Q=Q+Math.imul(_,f)|0,K=K+Math.imul(_,zJ)|0;var IQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(IQ>>>26)|0,IQ&=67108863,G=Math.imul(d,FJ),Q=Math.imul(d,RJ),Q=Q+Math.imul(a,FJ)|0,K=Math.imul(a,RJ),G=G+Math.imul(T,SJ)|0,Q=Q+Math.imul(T,xJ)|0,Q=Q+Math.imul(D,SJ)|0,K=K+Math.imul(D,xJ)|0,G=G+Math.imul(LJ,AJ)|0,Q=Q+Math.imul(LJ,kJ)|0,Q=Q+Math.imul(IJ,AJ)|0,K=K+Math.imul(IJ,kJ)|0,G=G+Math.imul(BJ,vJ)|0,Q=Q+Math.imul(BJ,MJ)|0,Q=Q+Math.imul(TJ,vJ)|0,K=K+Math.imul(TJ,MJ)|0,G=G+Math.imul(qJ,wJ)|0,Q=Q+Math.imul(qJ,bJ)|0,Q=Q+Math.imul(ZJ,wJ)|0,K=K+Math.imul(ZJ,bJ)|0,G=G+Math.imul(C,_J)|0,Q=Q+Math.imul(C,NJ)|0,Q=Q+Math.imul(h,_J)|0,K=K+Math.imul(h,NJ)|0,G=G+Math.imul(XJ,yJ)|0,Q=Q+Math.imul(XJ,gJ)|0,Q=Q+Math.imul(WJ,yJ)|0,K=K+Math.imul(WJ,gJ)|0,G=G+Math.imul(p,cJ)|0,Q=Q+Math.imul(p,fJ)|0,Q=Q+Math.imul(e,cJ)|0,K=K+Math.imul(e,fJ)|0,G=G+Math.imul(QJ,f)|0,Q=Q+Math.imul(QJ,zJ)|0,Q=Q+Math.imul(GJ,f)|0,K=K+Math.imul(GJ,zJ)|0;var EQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(EQ>>>26)|0,EQ&=67108863,G=Math.imul(d,SJ),Q=Math.imul(d,xJ),Q=Q+Math.imul(a,SJ)|0,K=Math.imul(a,xJ),G=G+Math.imul(T,AJ)|0,Q=Q+Math.imul(T,kJ)|0,Q=Q+Math.imul(D,AJ)|0,K=K+Math.imul(D,kJ)|0,G=G+Math.imul(LJ,vJ)|0,Q=Q+Math.imul(LJ,MJ)|0,Q=Q+Math.imul(IJ,vJ)|0,K=K+Math.imul(IJ,MJ)|0,G=G+Math.imul(BJ,wJ)|0,Q=Q+Math.imul(BJ,bJ)|0,Q=Q+Math.imul(TJ,wJ)|0,K=K+Math.imul(TJ,bJ)|0,G=G+Math.imul(qJ,_J)|0,Q=Q+Math.imul(qJ,NJ)|0,Q=Q+Math.imul(ZJ,_J)|0,K=K+Math.imul(ZJ,NJ)|0,G=G+Math.imul(C,yJ)|0,Q=Q+Math.imul(C,gJ)|0,Q=Q+Math.imul(h,yJ)|0,K=K+Math.imul(h,gJ)|0,G=G+Math.imul(XJ,cJ)|0,Q=Q+Math.imul(XJ,fJ)|0,Q=Q+Math.imul(WJ,cJ)|0,K=K+Math.imul(WJ,fJ)|0,G=G+Math.imul(p,f)|0,Q=Q+Math.imul(p,zJ)|0,Q=Q+Math.imul(e,f)|0,K=K+Math.imul(e,zJ)|0;var RQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(RQ>>>26)|0,RQ&=67108863,G=Math.imul(d,AJ),Q=Math.imul(d,kJ),Q=Q+Math.imul(a,AJ)|0,K=Math.imul(a,kJ),G=G+Math.imul(T,vJ)|0,Q=Q+Math.imul(T,MJ)|0,Q=Q+Math.imul(D,vJ)|0,K=K+Math.imul(D,MJ)|0,G=G+Math.imul(LJ,wJ)|0,Q=Q+Math.imul(LJ,bJ)|0,Q=Q+Math.imul(IJ,wJ)|0,K=K+Math.imul(IJ,bJ)|0,G=G+Math.imul(BJ,_J)|0,Q=Q+Math.imul(BJ,NJ)|0,Q=Q+Math.imul(TJ,_J)|0,K=K+Math.imul(TJ,NJ)|0,G=G+Math.imul(qJ,yJ)|0,Q=Q+Math.imul(qJ,gJ)|0,Q=Q+Math.imul(ZJ,yJ)|0,K=K+Math.imul(ZJ,gJ)|0,G=G+Math.imul(C,cJ)|0,Q=Q+Math.imul(C,fJ)|0,Q=Q+Math.imul(h,cJ)|0,K=K+Math.imul(h,fJ)|0,G=G+Math.imul(XJ,f)|0,Q=Q+Math.imul(XJ,zJ)|0,Q=Q+Math.imul(WJ,f)|0,K=K+Math.imul(WJ,zJ)|0;var zQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(zQ>>>26)|0,zQ&=67108863,G=Math.imul(d,vJ),Q=Math.imul(d,MJ),Q=Q+Math.imul(a,vJ)|0,K=Math.imul(a,MJ),G=G+Math.imul(T,wJ)|0,Q=Q+Math.imul(T,bJ)|0,Q=Q+Math.imul(D,wJ)|0,K=K+Math.imul(D,bJ)|0,G=G+Math.imul(LJ,_J)|0,Q=Q+Math.imul(LJ,NJ)|0,Q=Q+Math.imul(IJ,_J)|0,K=K+Math.imul(IJ,NJ)|0,G=G+Math.imul(BJ,yJ)|0,Q=Q+Math.imul(BJ,gJ)|0,Q=Q+Math.imul(TJ,yJ)|0,K=K+Math.imul(TJ,gJ)|0,G=G+Math.imul(qJ,cJ)|0,Q=Q+Math.imul(qJ,fJ)|0,Q=Q+Math.imul(ZJ,cJ)|0,K=K+Math.imul(ZJ,fJ)|0,G=G+Math.imul(C,f)|0,Q=Q+Math.imul(C,zJ)|0,Q=Q+Math.imul(h,f)|0,K=K+Math.imul(h,zJ)|0;var PQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(PQ>>>26)|0,PQ&=67108863,G=Math.imul(d,wJ),Q=Math.imul(d,bJ),Q=Q+Math.imul(a,wJ)|0,K=Math.imul(a,bJ),G=G+Math.imul(T,_J)|0,Q=Q+Math.imul(T,NJ)|0,Q=Q+Math.imul(D,_J)|0,K=K+Math.imul(D,NJ)|0,G=G+Math.imul(LJ,yJ)|0,Q=Q+Math.imul(LJ,gJ)|0,Q=Q+Math.imul(IJ,yJ)|0,K=K+Math.imul(IJ,gJ)|0,G=G+Math.imul(BJ,cJ)|0,Q=Q+Math.imul(BJ,fJ)|0,Q=Q+Math.imul(TJ,cJ)|0,K=K+Math.imul(TJ,fJ)|0,G=G+Math.imul(qJ,f)|0,Q=Q+Math.imul(qJ,zJ)|0,Q=Q+Math.imul(ZJ,f)|0,K=K+Math.imul(ZJ,zJ)|0;var LQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(LQ>>>26)|0,LQ&=67108863,G=Math.imul(d,_J),Q=Math.imul(d,NJ),Q=Q+Math.imul(a,_J)|0,K=Math.imul(a,NJ),G=G+Math.imul(T,yJ)|0,Q=Q+Math.imul(T,gJ)|0,Q=Q+Math.imul(D,yJ)|0,K=K+Math.imul(D,gJ)|0,G=G+Math.imul(LJ,cJ)|0,Q=Q+Math.imul(LJ,fJ)|0,Q=Q+Math.imul(IJ,cJ)|0,K=K+Math.imul(IJ,fJ)|0,G=G+Math.imul(BJ,f)|0,Q=Q+Math.imul(BJ,zJ)|0,Q=Q+Math.imul(TJ,f)|0,K=K+Math.imul(TJ,zJ)|0;var FQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(FQ>>>26)|0,FQ&=67108863,G=Math.imul(d,yJ),Q=Math.imul(d,gJ),Q=Q+Math.imul(a,yJ)|0,K=Math.imul(a,gJ),G=G+Math.imul(T,cJ)|0,Q=Q+Math.imul(T,fJ)|0,Q=Q+Math.imul(D,cJ)|0,K=K+Math.imul(D,fJ)|0,G=G+Math.imul(LJ,f)|0,Q=Q+Math.imul(LJ,zJ)|0,Q=Q+Math.imul(IJ,f)|0,K=K+Math.imul(IJ,zJ)|0;var HQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(HQ>>>26)|0,HQ&=67108863,G=Math.imul(d,cJ),Q=Math.imul(d,fJ),Q=Q+Math.imul(a,cJ)|0,K=Math.imul(a,fJ),G=G+Math.imul(T,f)|0,Q=Q+Math.imul(T,zJ)|0,Q=Q+Math.imul(D,f)|0,K=K+Math.imul(D,zJ)|0;var DQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(DQ>>>26)|0,DQ&=67108863,G=Math.imul(d,f),Q=Math.imul(d,zJ),Q=Q+Math.imul(a,f)|0,K=Math.imul(a,zJ);var KQ=(H+G|0)+((Q&8191)<<13)|0;return H=(K+(Q>>>13)|0)+(KQ>>>26)|0,KQ&=67108863,U[0]=CQ,U[1]=oJ,U[2]=tJ,U[3]=YQ,U[4]=BQ,U[5]=OQ,U[6]=jQ,U[7]=TQ,U[8]=NQ,U[9]=IQ,U[10]=EQ,U[11]=RQ,U[12]=zQ,U[13]=PQ,U[14]=LQ,U[15]=FQ,U[16]=HQ,U[17]=DQ,U[18]=KQ,H!==0&&(U[19]=H,Z.length++),Z};Math.imul||(F=P);function v(J,V,Z){Z.negative=V.negative^J.negative,Z.length=J.length+V.length;for(var $=0,X=0,U=0;U<Z.length-1;U++){var H=X;X=0;for(var G=$&67108863,Q=Math.min(U,V.length-1),K=Math.max(0,U-J.length+1);K<=Q;K++){var k=U-K,L=J.words[k]|0,_=V.words[K]|0,t=L*_,QJ=t&67108863;H=H+(t/67108864|0)|0,QJ=QJ+G|0,G=QJ&67108863,H=H+(QJ>>>26)|0,X+=H>>>26,H&=67108863}Z.words[U]=G,$=H,H=X}return $!==0?Z.words[U]=$:Z.length--,Z.strip()}function S(J,V,Z){var $=new w;return $.mulp(J,V,Z)}q.prototype.mulTo=function(J,V){var Z,$=this.length+J.length;return this.length===10&&J.length===10?Z=F(this,J,V):$<63?Z=P(this,J,V):$<1024?Z=v(this,J,V):Z=S(this,J,V),Z};function w(J,V){this.x=J,this.y=V}w.prototype.makeRBT=function(J){for(var V=new Array(J),Z=q.prototype._countBits(J)-1,$=0;$<J;$++)V[$]=this.revBin($,Z,J);return V},w.prototype.revBin=function(J,V,Z){if(J===0||J===Z-1)return J;for(var $=0,X=0;X<V;X++)$|=(J&1)<<V-X-1,J>>=1;return $},w.prototype.permute=function(J,V,Z,$,X,U){for(var H=0;H<U;H++)$[H]=V[J[H]],X[H]=Z[J[H]]},w.prototype.transform=function(J,V,Z,$,X,U){this.permute(U,J,V,Z,$,X);for(var H=1;H<X;H<<=1)for(var G=H<<1,Q=Math.cos(2*Math.PI/G),K=Math.sin(2*Math.PI/G),k=0;k<X;k+=G)for(var L=Q,_=K,t=0;t<H;t++){var QJ=Z[k+t],GJ=$[k+t],n=Z[k+t+H],p=$[k+t+H],e=L*n-_*p;p=L*p+_*n,n=e,Z[k+t]=QJ+n,$[k+t]=GJ+p,Z[k+t+H]=QJ-n,$[k+t+H]=GJ-p,t!==G&&(e=Q*L-K*_,_=Q*_+K*L,L=e)}},w.prototype.guessLen13b=function(J,V){var Z=Math.max(V,J)|1,$=Z&1,X=0;for(Z=Z/2|0;Z;Z=Z>>>1)X++;return 1<<X+1+$},w.prototype.conjugate=function(J,V,Z){if(!(Z<=1))for(var $=0;$<Z/2;$++){var X=J[$];J[$]=J[Z-$-1],J[Z-$-1]=X,X=V[$],V[$]=-V[Z-$-1],V[Z-$-1]=-X}},w.prototype.normalize13b=function(J,V){for(var Z=0,$=0;$<V/2;$++){var X=Math.round(J[2*$+1]/V)*8192+Math.round(J[2*$]/V)+Z;J[$]=X&67108863,X<67108864?Z=0:Z=X/67108864|0}return J},w.prototype.convert13b=function(J,V,Z,$){for(var X=0,U=0;U<V;U++)X=X+(J[U]|0),Z[2*U]=X&8191,X=X>>>13,Z[2*U+1]=X&8191,X=X>>>13;for(U=2*V;U<$;++U)Z[U]=0;B(X===0),B((X&-8192)===0)},w.prototype.stub=function(J){for(var V=new Array(J),Z=0;Z<J;Z++)V[Z]=0;return V},w.prototype.mulp=function(J,V,Z){var $=2*this.guessLen13b(J.length,V.length),X=this.makeRBT($),U=this.stub($),H=new Array($),G=new Array($),Q=new Array($),K=new Array($),k=new Array($),L=new Array($),_=Z.words;_.length=$,this.convert13b(J.words,J.length,H,$),this.convert13b(V.words,V.length,K,$),this.transform(H,U,G,Q,$,X),this.transform(K,U,k,L,$,X);for(var t=0;t<$;t++){var QJ=G[t]*k[t]-Q[t]*L[t];Q[t]=G[t]*L[t]+Q[t]*k[t],G[t]=QJ}return this.conjugate(G,Q,$),this.transform(G,Q,_,U,$,X),this.conjugate(_,U,$),this.normalize13b(_,$),Z.negative=J.negative^V.negative,Z.length=J.length+V.length,Z.strip()},q.prototype.mul=function(J){var V=new q(null);return V.words=new Array(this.length+J.length),this.mulTo(J,V)},q.prototype.mulf=function(J){var V=new q(null);return V.words=new Array(this.length+J.length),S(this,J,V)},q.prototype.imul=function(J){return this.clone().mulTo(J,this)},q.prototype.imuln=function(J){B(typeof J=="number"),B(J<67108864);for(var V=0,Z=0;Z<this.length;Z++){var $=(this.words[Z]|0)*J,X=($&67108863)+(V&67108863);V>>=26,V+=$/67108864|0,V+=X>>>26,this.words[Z]=X&67108863}return V!==0&&(this.words[Z]=V,this.length++),this},q.prototype.muln=function(J){return this.clone().imuln(J)},q.prototype.sqr=function(){return this.mul(this)},q.prototype.isqr=function(){return this.imul(this.clone())},q.prototype.pow=function(J){var V=j(J);if(V.length===0)return new q(1);for(var Z=this,$=0;$<V.length&&V[$]===0;$++,Z=Z.sqr());if(++$<V.length)for(var X=Z.sqr();$<V.length;$++,X=X.sqr())V[$]!==0&&(Z=Z.mul(X));return Z},q.prototype.iushln=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26,$=67108863>>>26-V<<26-V,X;if(V!==0){var U=0;for(X=0;X<this.length;X++){var H=this.words[X]&$,G=(this.words[X]|0)-H<<V;this.words[X]=G|U,U=H>>>26-V}U&&(this.words[X]=U,this.length++)}if(Z!==0){for(X=this.length-1;X>=0;X--)this.words[X+Z]=this.words[X];for(X=0;X<Z;X++)this.words[X]=0;this.length+=Z}return this.strip()},q.prototype.ishln=function(J){return B(this.negative===0),this.iushln(J)},q.prototype.iushrn=function(J,V,Z){B(typeof J=="number"&&J>=0);var $;V?$=(V-V%26)/26:$=0;var X=J%26,U=Math.min((J-X)/26,this.length),H=67108863^67108863>>>X<<X,G=Z;if($-=U,$=Math.max(0,$),G){for(var Q=0;Q<U;Q++)G.words[Q]=this.words[Q];G.length=U}if(U!==0)if(this.length>U)for(this.length-=U,Q=0;Q<this.length;Q++)this.words[Q]=this.words[Q+U];else this.words[0]=0,this.length=1;var K=0;for(Q=this.length-1;Q>=0&&(K!==0||Q>=$);Q--){var k=this.words[Q]|0;this.words[Q]=K<<26-X|k>>>X,K=k&H}return G&&K!==0&&(G.words[G.length++]=K),this.length===0&&(this.words[0]=0,this.length=1),this.strip()},q.prototype.ishrn=function(J,V,Z){return B(this.negative===0),this.iushrn(J,V,Z)},q.prototype.shln=function(J){return this.clone().ishln(J)},q.prototype.ushln=function(J){return this.clone().iushln(J)},q.prototype.shrn=function(J){return this.clone().ishrn(J)},q.prototype.ushrn=function(J){return this.clone().iushrn(J)},q.prototype.testn=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26,$=1<<V;if(this.length<=Z)return!1;var X=this.words[Z];return!!(X&$)},q.prototype.imaskn=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26;if(B(this.negative===0,"imaskn works only with positive numbers"),this.length<=Z)return this;if(V!==0&&Z++,this.length=Math.min(Z,this.length),V!==0){var $=67108863^67108863>>>V<<V;this.words[this.length-1]&=$}return this.strip()},q.prototype.maskn=function(J){return this.clone().imaskn(J)},q.prototype.iaddn=function(J){return B(typeof J=="number"),B(J<67108864),J<0?this.isubn(-J):this.negative!==0?this.length===1&&(this.words[0]|0)<J?(this.words[0]=J-(this.words[0]|0),this.negative=0,this):(this.negative=0,this.isubn(J),this.negative=1,this):this._iaddn(J)},q.prototype._iaddn=function(J){this.words[0]+=J;for(var V=0;V<this.length&&this.words[V]>=67108864;V++)this.words[V]-=67108864,V===this.length-1?this.words[V+1]=1:this.words[V+1]++;return this.length=Math.max(this.length,V+1),this},q.prototype.isubn=function(J){if(B(typeof J=="number"),B(J<67108864),J<0)return this.iaddn(-J);if(this.negative!==0)return this.negative=0,this.iaddn(J),this.negative=1,this;if(this.words[0]-=J,this.length===1&&this.words[0]<0)this.words[0]=-this.words[0],this.negative=1;else for(var V=0;V<this.length&&this.words[V]<0;V++)this.words[V]+=67108864,this.words[V+1]-=1;return this.strip()},q.prototype.addn=function(J){return this.clone().iaddn(J)},q.prototype.subn=function(J){return this.clone().isubn(J)},q.prototype.iabs=function(){return this.negative=0,this},q.prototype.abs=function(){return this.clone().iabs()},q.prototype._ishlnsubmul=function(J,V,Z){var $=J.length+Z,X;this._expand($);var U,H=0;for(X=0;X<J.length;X++){U=(this.words[X+Z]|0)+H;var G=(J.words[X]|0)*V;U-=G&67108863,H=(U>>26)-(G/67108864|0),this.words[X+Z]=U&67108863}for(;X<this.length-Z;X++)U=(this.words[X+Z]|0)+H,H=U>>26,this.words[X+Z]=U&67108863;if(H===0)return this.strip();for(B(H===-1),H=0,X=0;X<this.length;X++)U=-(this.words[X]|0)+H,H=U>>26,this.words[X]=U&67108863;return this.negative=1,this.strip()},q.prototype._wordDiv=function(J,V){var Z=this.length-J.length,$=this.clone(),X=J,U=X.words[X.length-1]|0,H=this._countBits(U);Z=26-H,Z!==0&&(X=X.ushln(Z),$.iushln(Z),U=X.words[X.length-1]|0);var G=$.length-X.length,Q;if(V!=="mod"){Q=new q(null),Q.length=G+1,Q.words=new Array(Q.length);for(var K=0;K<Q.length;K++)Q.words[K]=0}var k=$.clone()._ishlnsubmul(X,1,G);k.negative===0&&($=k,Q&&(Q.words[G]=1));for(var L=G-1;L>=0;L--){var _=($.words[X.length+L]|0)*67108864+($.words[X.length+L-1]|0);for(_=Math.min(_/U|0,67108863),$._ishlnsubmul(X,_,L);$.negative!==0;)_--,$.negative=0,$._ishlnsubmul(X,1,L),$.isZero()||($.negative^=1);Q&&(Q.words[L]=_)}return Q&&Q.strip(),$.strip(),V!=="div"&&Z!==0&&$.iushrn(Z),{div:Q||null,mod:$}},q.prototype.divmod=function(J,V,Z){if(B(!J.isZero()),this.isZero())return{div:new q(0),mod:new q(0)};var $,X,U;return this.negative!==0&&J.negative===0?(U=this.neg().divmod(J,V),V!=="mod"&&($=U.div.neg()),V!=="div"&&(X=U.mod.neg(),Z&&X.negative!==0&&X.iadd(J)),{div:$,mod:X}):this.negative===0&&J.negative!==0?(U=this.divmod(J.neg(),V),V!=="mod"&&($=U.div.neg()),{div:$,mod:U.mod}):(this.negative&J.negative)!==0?(U=this.neg().divmod(J.neg(),V),V!=="div"&&(X=U.mod.neg(),Z&&X.negative!==0&&X.isub(J)),{div:U.div,mod:X}):J.length>this.length||this.cmp(J)<0?{div:new q(0),mod:this}:J.length===1?V==="div"?{div:this.divn(J.words[0]),mod:null}:V==="mod"?{div:null,mod:new q(this.modn(J.words[0]))}:{div:this.divn(J.words[0]),mod:new q(this.modn(J.words[0]))}:this._wordDiv(J,V)},q.prototype.div=function(J){return this.divmod(J,"div",!1).div},q.prototype.mod=function(J){return this.divmod(J,"mod",!1).mod},q.prototype.umod=function(J){return this.divmod(J,"mod",!0).mod},q.prototype.divRound=function(J){var V=this.divmod(J);if(V.mod.isZero())return V.div;var Z=V.div.negative!==0?V.mod.isub(J):V.mod,$=J.ushrn(1),X=J.andln(1),U=Z.cmp($);return U<0||X===1&&U===0?V.div:V.div.negative!==0?V.div.isubn(1):V.div.iaddn(1)},q.prototype.modn=function(J){B(J<=67108863);for(var V=(1<<26)%J,Z=0,$=this.length-1;$>=0;$--)Z=(V*Z+(this.words[$]|0))%J;return Z},q.prototype.idivn=function(J){B(J<=67108863);for(var V=0,Z=this.length-1;Z>=0;Z--){var $=(this.words[Z]|0)+V*67108864;this.words[Z]=$/J|0,V=$%J}return this.strip()},q.prototype.divn=function(J){return this.clone().idivn(J)},q.prototype.egcd=function(J){B(J.negative===0),B(!J.isZero());var V=this,Z=J.clone();V.negative!==0?V=V.umod(J):V=V.clone();for(var $=new q(1),X=new q(0),U=new q(0),H=new q(1),G=0;V.isEven()&&Z.isEven();)V.iushrn(1),Z.iushrn(1),++G;for(var Q=Z.clone(),K=V.clone();!V.isZero();){for(var k=0,L=1;(V.words[0]&L)===0&&k<26;++k,L<<=1);if(k>0)for(V.iushrn(k);k-- >0;)($.isOdd()||X.isOdd())&&($.iadd(Q),X.isub(K)),$.iushrn(1),X.iushrn(1);for(var _=0,t=1;(Z.words[0]&t)===0&&_<26;++_,t<<=1);if(_>0)for(Z.iushrn(_);_-- >0;)(U.isOdd()||H.isOdd())&&(U.iadd(Q),H.isub(K)),U.iushrn(1),H.iushrn(1);V.cmp(Z)>=0?(V.isub(Z),$.isub(U),X.isub(H)):(Z.isub(V),U.isub($),H.isub(X))}return{a:U,b:H,gcd:Z.iushln(G)}},q.prototype._invmp=function(J){B(J.negative===0),B(!J.isZero());var V=this,Z=J.clone();V.negative!==0?V=V.umod(J):V=V.clone();for(var $=new q(1),X=new q(0),U=Z.clone();V.cmpn(1)>0&&Z.cmpn(1)>0;){for(var H=0,G=1;(V.words[0]&G)===0&&H<26;++H,G<<=1);if(H>0)for(V.iushrn(H);H-- >0;)$.isOdd()&&$.iadd(U),$.iushrn(1);for(var Q=0,K=1;(Z.words[0]&K)===0&&Q<26;++Q,K<<=1);if(Q>0)for(Z.iushrn(Q);Q-- >0;)X.isOdd()&&X.iadd(U),X.iushrn(1);V.cmp(Z)>=0?(V.isub(Z),$.isub(X)):(Z.isub(V),X.isub($))}var k;return V.cmpn(1)===0?k=$:k=X,k.cmpn(0)<0&&k.iadd(J),k},q.prototype.gcd=function(J){if(this.isZero())return J.abs();if(J.isZero())return this.abs();var V=this.clone(),Z=J.clone();V.negative=0,Z.negative=0;for(var $=0;V.isEven()&&Z.isEven();$++)V.iushrn(1),Z.iushrn(1);do{for(;V.isEven();)V.iushrn(1);for(;Z.isEven();)Z.iushrn(1);var X=V.cmp(Z);if(X<0){var U=V;V=Z,Z=U}else if(X===0||Z.cmpn(1)===0)break;V.isub(Z)}while(!0);return Z.iushln($)},q.prototype.invm=function(J){return this.egcd(J).a.umod(J)},q.prototype.isEven=function(){return(this.words[0]&1)===0},q.prototype.isOdd=function(){return(this.words[0]&1)===1},q.prototype.andln=function(J){return this.words[0]&J},q.prototype.bincn=function(J){B(typeof J=="number");var V=J%26,Z=(J-V)/26,$=1<<V;if(this.length<=Z)return this._expand(Z+1),this.words[Z]|=$,this;for(var X=$,U=Z;X!==0&&U<this.length;U++){var H=this.words[U]|0;H+=X,X=H>>>26,H&=67108863,this.words[U]=H}return X!==0&&(this.words[U]=X,this.length++),this},q.prototype.isZero=function(){return this.length===1&&this.words[0]===0},q.prototype.cmpn=function(J){var V=J<0;if(this.negative!==0&&!V)return-1;if(this.negative===0&&V)return 1;this.strip();var Z;if(this.length>1)Z=1;else{V&&(J=-J),B(J<=67108863,"Number is too big");var $=this.words[0]|0;Z=$===J?0:$<J?-1:1}return this.negative!==0?-Z|0:Z},q.prototype.cmp=function(J){if(this.negative!==0&&J.negative===0)return-1;if(this.negative===0&&J.negative!==0)return 1;var V=this.ucmp(J);return this.negative!==0?-V|0:V},q.prototype.ucmp=function(J){if(this.length>J.length)return 1;if(this.length<J.length)return-1;for(var V=0,Z=this.length-1;Z>=0;Z--){var $=this.words[Z]|0,X=J.words[Z]|0;if($!==X){$<X?V=-1:$>X&&(V=1);break}}return V},q.prototype.gtn=function(J){return this.cmpn(J)===1},q.prototype.gt=function(J){return this.cmp(J)===1},q.prototype.gten=function(J){return this.cmpn(J)>=0},q.prototype.gte=function(J){return this.cmp(J)>=0},q.prototype.ltn=function(J){return this.cmpn(J)===-1},q.prototype.lt=function(J){return this.cmp(J)===-1},q.prototype.lten=function(J){return this.cmpn(J)<=0},q.prototype.lte=function(J){return this.cmp(J)<=0},q.prototype.eqn=function(J){return this.cmpn(J)===0},q.prototype.eq=function(J){return this.cmp(J)===0},q.red=function(J){return new o(J)},q.prototype.toRed=function(J){return B(!this.red,"Already a number in reduction context"),B(this.negative===0,"red works only with positives"),J.convertTo(this)._forceRed(J)},q.prototype.fromRed=function(){return B(this.red,"fromRed works only with numbers in reduction context"),this.red.convertFrom(this)},q.prototype._forceRed=function(J){return this.red=J,this},q.prototype.forceRed=function(J){return B(!this.red,"Already a number in reduction context"),this._forceRed(J)},q.prototype.redAdd=function(J){return B(this.red,"redAdd works only with red numbers"),this.red.add(this,J)},q.prototype.redIAdd=function(J){return B(this.red,"redIAdd works only with red numbers"),this.red.iadd(this,J)},q.prototype.redSub=function(J){return B(this.red,"redSub works only with red numbers"),this.red.sub(this,J)},q.prototype.redISub=function(J){return B(this.red,"redISub works only with red numbers"),this.red.isub(this,J)},q.prototype.redShl=function(J){return B(this.red,"redShl works only with red numbers"),this.red.shl(this,J)},q.prototype.redMul=function(J){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,J),this.red.mul(this,J)},q.prototype.redIMul=function(J){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,J),this.red.imul(this,J)},q.prototype.redSqr=function(){return B(this.red,"redSqr works only with red numbers"),this.red._verify1(this),this.red.sqr(this)},q.prototype.redISqr=function(){return B(this.red,"redISqr works only with red numbers"),this.red._verify1(this),this.red.isqr(this)},q.prototype.redSqrt=function(){return B(this.red,"redSqrt works only with red numbers"),this.red._verify1(this),this.red.sqrt(this)},q.prototype.redInvm=function(){return B(this.red,"redInvm works only with red numbers"),this.red._verify1(this),this.red.invm(this)},q.prototype.redNeg=function(){return B(this.red,"redNeg works only with red numbers"),this.red._verify1(this),this.red.neg(this)},q.prototype.redPow=function(J){return B(this.red&&!J.red,"redPow(normalNum)"),this.red._verify1(this),this.red.pow(this,J)};var y={k256:null,p224:null,p192:null,p25519:null};function m(J,V){this.name=J,this.p=new q(V,16),this.n=this.p.bitLength(),this.k=new q(1).iushln(this.n).isub(this.p),this.tmp=this._tmp()}m.prototype._tmp=function(){var J=new q(null);return J.words=new Array(Math.ceil(this.n/13)),J},m.prototype.ireduce=function(J){var V=J,Z;do this.split(V,this.tmp),V=this.imulK(V),V=V.iadd(this.tmp),Z=V.bitLength();while(Z>this.n);var $=Z<this.n?-1:V.ucmp(this.p);return $===0?(V.words[0]=0,V.length=1):$>0?V.isub(this.p):V.strip!==void 0?V.strip():V._strip(),V},m.prototype.split=function(J,V){J.iushrn(this.n,0,V)},m.prototype.imulK=function(J){return J.imul(this.k)};function i(){m.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}A(i,m),i.prototype.split=function(J,V){for(var Z=4194303,$=Math.min(J.length,9),X=0;X<$;X++)V.words[X]=J.words[X];if(V.length=$,J.length<=9){J.words[0]=0,J.length=1;return}var U=J.words[9];for(V.words[V.length++]=U&Z,X=10;X<J.length;X++){var H=J.words[X]|0;J.words[X-10]=(H&Z)<<4|U>>>22,U=H}U>>>=22,J.words[X-10]=U,U===0&&J.length>10?J.length-=10:J.length-=9},i.prototype.imulK=function(J){J.words[J.length]=0,J.words[J.length+1]=0,J.length+=2;for(var V=0,Z=0;Z<J.length;Z++){var $=J.words[Z]|0;V+=$*977,J.words[Z]=V&67108863,V=$*64+(V/67108864|0)}return J.words[J.length-1]===0&&(J.length--,J.words[J.length-1]===0&&J.length--),J};function JJ(){m.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}A(JJ,m);function VJ(){m.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}A(VJ,m);function HJ(){m.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}A(HJ,m),HJ.prototype.imulK=function(J){for(var V=0,Z=0;Z<J.length;Z++){var $=(J.words[Z]|0)*19+V,X=$&67108863;$>>>=26,J.words[Z]=X,V=$}return V!==0&&(J.words[J.length++]=V),J},q._prime=function(J){if(y[J])return y[J];var V;if(J==="k256")V=new i;else if(J==="p224")V=new JJ;else if(J==="p192")V=new VJ;else if(J==="p25519")V=new HJ;else throw new Error("Unknown prime "+J);return y[J]=V,V};function o(J){if(typeof J=="string"){var V=q._prime(J);this.m=V.p,this.prime=V}else B(J.gtn(1),"modulus must be greater than 1"),this.m=J,this.prime=null}o.prototype._verify1=function(J){B(J.negative===0,"red works only with positives"),B(J.red,"red works only with red numbers")},o.prototype._verify2=function(J,V){B((J.negative|V.negative)===0,"red works only with positives"),B(J.red&&J.red===V.red,"red works only with red numbers")},o.prototype.imod=function(J){return this.prime?this.prime.ireduce(J)._forceRed(this):J.umod(this.m)._forceRed(this)},o.prototype.neg=function(J){return J.isZero()?J.clone():this.m.sub(J)._forceRed(this)},o.prototype.add=function(J,V){this._verify2(J,V);var Z=J.add(V);return Z.cmp(this.m)>=0&&Z.isub(this.m),Z._forceRed(this)},o.prototype.iadd=function(J,V){this._verify2(J,V);var Z=J.iadd(V);return Z.cmp(this.m)>=0&&Z.isub(this.m),Z},o.prototype.sub=function(J,V){this._verify2(J,V);var Z=J.sub(V);return Z.cmpn(0)<0&&Z.iadd(this.m),Z._forceRed(this)},o.prototype.isub=function(J,V){this._verify2(J,V);var Z=J.isub(V);return Z.cmpn(0)<0&&Z.iadd(this.m),Z},o.prototype.shl=function(J,V){return this._verify1(J),this.imod(J.ushln(V))},o.prototype.imul=function(J,V){return this._verify2(J,V),this.imod(J.imul(V))},o.prototype.mul=function(J,V){return this._verify2(J,V),this.imod(J.mul(V))},o.prototype.isqr=function(J){return this.imul(J,J.clone())},o.prototype.sqr=function(J){return this.mul(J,J)},o.prototype.sqrt=function(J){if(J.isZero())return J.clone();var V=this.m.andln(3);if(B(V%2===1),V===3){var Z=this.m.add(new q(1)).iushrn(2);return this.pow(J,Z)}for(var $=this.m.subn(1),X=0;!$.isZero()&&$.andln(1)===0;)X++,$.iushrn(1);B(!$.isZero());var U=new q(1).toRed(this),H=U.redNeg(),G=this.m.subn(1).iushrn(1),Q=this.m.bitLength();for(Q=new q(2*Q*Q).toRed(this);this.pow(Q,G).cmp(H)!==0;)Q.redIAdd(H);for(var K=this.pow(Q,$),k=this.pow(J,$.addn(1).iushrn(1)),L=this.pow(J,$),_=X;L.cmp(U)!==0;){for(var t=L,QJ=0;t.cmp(U)!==0;QJ++)t=t.redSqr();B(QJ<_);var GJ=this.pow(K,new q(1).iushln(_-QJ-1));k=k.redMul(GJ),K=GJ.redSqr(),L=L.redMul(K),_=QJ}return k},o.prototype.invm=function(J){var V=J._invmp(this.m);return V.negative!==0?(V.negative=0,this.imod(V).redNeg()):this.imod(V)},o.prototype.pow=function(J,V){if(V.isZero())return new q(1).toRed(this);if(V.cmpn(1)===0)return J.clone();var Z=4,$=new Array(1<<Z);$[0]=new q(1).toRed(this),$[1]=J;for(var X=2;X<$.length;X++)$[X]=this.mul($[X-1],J);var U=$[0],H=0,G=0,Q=V.bitLength()%26;for(Q===0&&(Q=26),X=V.length-1;X>=0;X--){for(var K=V.words[X],k=Q-1;k>=0;k--){var L=K>>k&1;if(U!==$[0]&&(U=this.sqr(U)),L===0&&H===0){G=0;continue}H<<=1,H|=L,G++,!(G!==Z&&(X!==0||k!==0))&&(U=this.mul(U,$[H]),G=0,H=0)}Q=26}return U},o.prototype.convertTo=function(J){var V=J.umod(this.m);return V===J?V.clone():V},o.prototype.convertFrom=function(J){var V=J.clone();return V.red=null,V},q.mont=function(J){return new jJ(J)};function jJ(J){o.call(this,J),this.shift=this.m.bitLength(),this.shift%26!==0&&(this.shift+=26-this.shift%26),this.r=new q(1).iushln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv=this.minv.umod(this.r),this.minv=this.r.sub(this.minv)}A(jJ,o),jJ.prototype.convertTo=function(J){return this.imod(J.ushln(this.shift))},jJ.prototype.convertFrom=function(J){var V=this.imod(J.mul(this.rinv));return V.red=null,V},jJ.prototype.imul=function(J,V){if(J.isZero()||V.isZero())return J.words[0]=0,J.length=1,J;var Z=J.imul(V),$=Z.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),X=Z.isub($).iushrn(this.shift),U=X;return X.cmp(this.m)>=0?U=X.isub(this.m):X.cmpn(0)<0&&(U=X.iadd(this.m)),U._forceRed(this)},jJ.prototype.mul=function(J,V){if(J.isZero()||V.isZero())return new q(0)._forceRed(this);var Z=J.mul(V),$=Z.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),X=Z.isub($).iushrn(this.shift),U=X;return X.cmp(this.m)>=0?U=X.isub(this.m):X.cmpn(0)<0&&(U=X.iadd(this.m)),U._forceRed(this)},jJ.prototype.invm=function(J){var V=this.imod(J._invmp(this.m).mul(this.r2));return V._forceRed(this)}})(typeof g>"u"||g,l)}),G0=OJ((l,g)=>{var R=yQ(),M=R.Buffer,B={},A;for(A in R)!R.hasOwnProperty(A)||A==="SlowBuffer"||A==="Buffer"||(B[A]=R[A]);var q=B.Buffer={};for(A in M)!M.hasOwnProperty(A)||A==="allocUnsafe"||A==="allocUnsafeSlow"||(q[A]=M[A]);if(B.Buffer.prototype=M.prototype,(!q.from||q.from===Uint8Array.from)&&(q.from=function(Y,E,O){if(typeof Y=="number")throw new TypeError('The "value" argument must not be of type number. Received type '+typeof Y);if(Y&&typeof Y.length>"u")throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof Y);return M(Y,E,O)}),q.alloc||(q.alloc=function(Y,E,O){if(typeof Y!="number")throw new TypeError('The "size" argument must be of type number. Received type '+typeof Y);if(Y<0||Y>=2*(1<<30))throw new RangeError('The value "'+Y+'" is invalid for option "size"');var N=M(Y);return!E||E.length===0?N.fill(0):typeof O=="string"?N.fill(E,O):N.fill(E),N}),!B.kStringMaxLength)try{B.kStringMaxLength=process.binding("buffer").kStringMaxLength}catch{}B.constants||(B.constants={MAX_LENGTH:B.kMaxLength},B.kStringMaxLength&&(B.constants.MAX_STRING_LENGTH=B.kStringMaxLength)),g.exports=B}),K0=OJ((l)=>{var g=JQ();function R(B){this._reporterState={obj:null,path:[],options:B||{},errors:[]}}l.Reporter=R,R.prototype.isError=function(B){return B instanceof M},R.prototype.save=function(){let B=this._reporterState;return{obj:B.obj,pathLen:B.path.length}},R.prototype.restore=function(B){let A=this._reporterState;A.obj=B.obj,A.path=A.path.slice(0,B.pathLen)},R.prototype.enterKey=function(B){return this._reporterState.path.push(B)},R.prototype.exitKey=function(B){let A=this._reporterState;A.path=A.path.slice(0,B-1)},R.prototype.leaveKey=function(B,A,q){let Y=this._reporterState;this.exitKey(B),Y.obj!==null&&(Y.obj[A]=q)},R.prototype.path=function(){return this._reporterState.path.join("/")},R.prototype.enterObject=function(){let B=this._reporterState,A=B.obj;return B.obj={},A},R.prototype.leaveObject=function(B){let A=this._reporterState,q=A.obj;return A.obj=B,q},R.prototype.error=function(B){let A,q=this._reporterState,Y=B instanceof M;if(Y?A=B:A=new M(q.path.map(function(E){return"["+JSON.stringify(E)+"]"}).join(""),B.message||B,B.stack),!q.options.partial)throw A;return Y||q.errors.push(A),A},R.prototype.wrapResult=function(B){let A=this._reporterState;return A.options.partial?{result:this.isError(B)?null:B,errors:A.errors}:B};function M(B,A){this.path=B,this.rethrow(A)}g(M,Error),M.prototype.rethrow=function(B){if(this.message=B+" at: "+(this.path||"(shallow)"),Error.captureStackTrace&&Error.captureStackTrace(this,M),!this.stack)try{throw new Error(this.message)}catch(A){this.stack=A.stack}return this}}),OV=OJ((l)=>{var g=JQ(),R=K0().Reporter,M=G0().Buffer;function B(q,Y){if(R.call(this,Y),!M.isBuffer(q)){this.error("Input not Buffer");return}this.base=q,this.offset=0,this.length=q.length}g(B,R),l.DecoderBuffer=B,B.isDecoderBuffer=function(q){return q instanceof B?!0:typeof q=="object"&&M.isBuffer(q.base)&&q.constructor.name==="DecoderBuffer"&&typeof q.offset=="number"&&typeof q.length=="number"&&typeof q.save=="function"&&typeof q.restore=="function"&&typeof q.isEmpty=="function"&&typeof q.readUInt8=="function"&&typeof q.skip=="function"&&typeof q.raw=="function"},B.prototype.save=function(){return{offset:this.offset,reporter:R.prototype.save.call(this)}},B.prototype.restore=function(q){let Y=new B(this.base);return Y.offset=q.offset,Y.length=this.offset,this.offset=q.offset,R.prototype.restore.call(this,q.reporter),Y},B.prototype.isEmpty=function(){return this.offset===this.length},B.prototype.readUInt8=function(q){return this.offset+1<=this.length?this.base.readUInt8(this.offset++,!0):this.error(q||"DecoderBuffer overrun")},B.prototype.skip=function(q,Y){if(!(this.offset+q<=this.length))return this.error(Y||"DecoderBuffer overrun");let E=new B(this.base);return E._reporterState=this._reporterState,E.offset=this.offset,E.length=this.offset+q,this.offset+=q,E},B.prototype.raw=function(q){return this.base.slice(q?q.offset:this.offset,this.length)};function A(q,Y){if(Array.isArray(q))this.length=0,this.value=q.map(function(E){return A.isEncoderBuffer(E)||(E=new A(E,Y)),this.length+=E.length,E},this);else if(typeof q=="number"){if(!(0<=q&&q<=255))return Y.error("non-byte EncoderBuffer value");this.value=q,this.length=1}else if(typeof q=="string")this.value=q,this.length=M.byteLength(q);else if(M.isBuffer(q))this.value=q,this.length=q.length;else return Y.error("Unsupported type: "+typeof q)}l.EncoderBuffer=A,A.isEncoderBuffer=function(q){return q instanceof A?!0:typeof q=="object"&&q.constructor.name==="EncoderBuffer"&&typeof q.length=="number"&&typeof q.join=="function"},A.prototype.join=function(q,Y){return q||(q=M.alloc(this.length)),Y||(Y=0),this.length===0||(Array.isArray(this.value)?this.value.forEach(function(E){E.join(q,Y),Y+=E.length}):(typeof this.value=="number"?q[Y]=this.value:typeof this.value=="string"?q.write(this.value,Y):M.isBuffer(this.value)&&this.value.copy(q,Y),Y+=this.length)),q}}),U0=OJ((l,g)=>{var R=K0().Reporter,M=OV().EncoderBuffer,B=OV().DecoderBuffer,A=hQ(),q=["seq","seqof","set","setof","objid","bool","gentime","utctime","null_","enum","int","objDesc","bitstr","bmpstr","charstr","genstr","graphstr","ia5str","iso646str","numstr","octstr","printstr","t61str","unistr","utf8str","videostr"],Y=["key","obj","use","optional","explicit","implicit","def","choice","any","contains"].concat(q),E=["_peekTag","_decodeTag","_use","_decodeStr","_decodeObjid","_decodeTime","_decodeNull","_decodeInt","_decodeBool","_decodeList","_encodeComposite","_encodeStr","_encodeObjid","_encodeTime","_encodeNull","_encodeInt","_encodeBool"];function O(W,I,z){let j={};this._baseState=j,j.name=z,j.enc=W,j.parent=I||null,j.children=null,j.tag=null,j.args=null,j.reverseArgs=null,j.choice=null,j.optional=!1,j.any=!1,j.obj=!1,j.use=null,j.useDecoder=null,j.key=null,j.default=null,j.explicit=null,j.implicit=null,j.contains=null,j.parent||(j.children=[],this._wrap())}g.exports=O;var N=["enc","parent","children","tag","args","reverseArgs","choice","optional","any","obj","use","alteredUse","key","default","explicit","implicit","contains"];O.prototype.clone=function(){let W=this._baseState,I={};N.forEach(function(j){I[j]=W[j]});let z=new this.constructor(I.parent);return z._baseState=I,z},O.prototype._wrap=function(){let W=this._baseState;Y.forEach(function(I){this[I]=function(){let z=new this.constructor(this);return W.children.push(z),z[I].apply(z,arguments)}},this)},O.prototype._init=function(W){let I=this._baseState;A(I.parent===null),W.call(this),I.children=I.children.filter(function(z){return z._baseState.parent===this},this),A.equal(I.children.length,1,"Root node can have only one child")},O.prototype._useArgs=function(W){let I=this._baseState,z=W.filter(function(j){return j instanceof this.constructor},this);W=W.filter(function(j){return!(j instanceof this.constructor)},this),z.length!==0&&(A(I.children===null),I.children=z,z.forEach(function(j){j._baseState.parent=this},this)),W.length!==0&&(A(I.args===null),I.args=W,I.reverseArgs=W.map(function(j){if(typeof j!="object"||j.constructor!==Object)return j;let P={};return Object.keys(j).forEach(function(F){F==(F|0)&&(F|=0);let v=j[F];P[v]=F}),P}))},E.forEach(function(W){O.prototype[W]=function(){let I=this._baseState;throw new Error(W+" not implemented for encoding: "+I.enc)}}),q.forEach(function(W){O.prototype[W]=function(){let I=this._baseState,z=Array.prototype.slice.call(arguments);return A(I.tag===null),I.tag=W,this._useArgs(z),this}}),O.prototype.use=function(W){A(W);let I=this._baseState;return A(I.use===null),I.use=W,this},O.prototype.optional=function(){let W=this._baseState;return W.optional=!0,this},O.prototype.def=function(W){let I=this._baseState;return A(I.default===null),I.default=W,I.optional=!0,this},O.prototype.explicit=function(W){let I=this._baseState;return A(I.explicit===null&&I.implicit===null),I.explicit=W,this},O.prototype.implicit=function(W){let I=this._baseState;return A(I.explicit===null&&I.implicit===null),I.implicit=W,this},O.prototype.obj=function(){let W=this._baseState,I=Array.prototype.slice.call(arguments);return W.obj=!0,I.length!==0&&this._useArgs(I),this},O.prototype.key=function(W){let I=this._baseState;return A(I.key===null),I.key=W,this},O.prototype.any=function(){let W=this._baseState;return W.any=!0,this},O.prototype.choice=function(W){let I=this._baseState;return A(I.choice===null),I.choice=W,this._useArgs(Object.keys(W).map(function(z){return W[z]})),this},O.prototype.contains=function(W){let I=this._baseState;return A(I.use===null),I.contains=W,this},O.prototype._decode=function(W,I){let z=this._baseState;if(z.parent===null)return W.wrapResult(z.children[0]._decode(W,I));let j=z.default,P=!0,F=null;if(z.key!==null&&(F=W.enterKey(z.key)),z.optional){let S=null;if(z.explicit!==null?S=z.explicit:z.implicit!==null?S=z.implicit:z.tag!==null&&(S=z.tag),S===null&&!z.any){let w=W.save();try{z.choice===null?this._decodeGeneric(z.tag,W,I):this._decodeChoice(W,I),P=!0}catch{P=!1}W.restore(w)}else if(P=this._peekTag(W,S,z.any),W.isError(P))return P}let v;if(z.obj&&P&&(v=W.enterObject()),P){if(z.explicit!==null){let w=this._decodeTag(W,z.explicit);if(W.isError(w))return w;W=w}let S=W.offset;if(z.use===null&&z.choice===null){let w;z.any&&(w=W.save());let y=this._decodeTag(W,z.implicit!==null?z.implicit:z.tag,z.any);if(W.isError(y))return y;z.any?j=W.raw(w):W=y}if(I&&I.track&&z.tag!==null&&I.track(W.path(),S,W.length,"tagged"),I&&I.track&&z.tag!==null&&I.track(W.path(),W.offset,W.length,"content"),z.any||(z.choice===null?j=this._decodeGeneric(z.tag,W,I):j=this._decodeChoice(W,I)),W.isError(j))return j;if(!z.any&&z.choice===null&&z.children!==null&&z.children.forEach(function(w){w._decode(W,I)}),z.contains&&(z.tag==="octstr"||z.tag==="bitstr")){let w=new B(j);j=this._getUse(z.contains,W._reporterState.obj)._decode(w,I)}}return z.obj&&P&&(j=W.leaveObject(v)),z.key!==null&&(j!==null||P===!0)?W.leaveKey(F,z.key,j):F!==null&&W.exitKey(F),j},O.prototype._decodeGeneric=function(W,I,z){let j=this._baseState;return W==="seq"||W==="set"?null:W==="seqof"||W==="setof"?this._decodeList(I,W,j.args[0],z):/str$/.test(W)?this._decodeStr(I,W,z):W==="objid"&&j.args?this._decodeObjid(I,j.args[0],j.args[1],z):W==="objid"?this._decodeObjid(I,null,null,z):W==="gentime"||W==="utctime"?this._decodeTime(I,W,z):W==="null_"?this._decodeNull(I,z):W==="bool"?this._decodeBool(I,z):W==="objDesc"?this._decodeStr(I,W,z):W==="int"||W==="enum"?this._decodeInt(I,j.args&&j.args[0],z):j.use!==null?this._getUse(j.use,I._reporterState.obj)._decode(I,z):I.error("unknown tag: "+W)},O.prototype._getUse=function(W,I){let z=this._baseState;return z.useDecoder=this._use(W,I),A(z.useDecoder._baseState.parent===null),z.useDecoder=z.useDecoder._baseState.children[0],z.implicit!==z.useDecoder._baseState.implicit&&(z.useDecoder=z.useDecoder.clone(),z.useDecoder._baseState.implicit=z.implicit),z.useDecoder},O.prototype._decodeChoice=function(W,I){let z=this._baseState,j=null,P=!1;return Object.keys(z.choice).some(function(F){let v=W.save(),S=z.choice[F];try{let w=S._decode(W,I);if(W.isError(w))return!1;j={type:F,value:w},P=!0}catch{return W.restore(v),!1}return!0},this),P?j:W.error("Choice not matched")},O.prototype._createEncoderBuffer=function(W){return new M(W,this.reporter)},O.prototype._encode=function(W,I,z){let j=this._baseState;if(j.default!==null&&j.default===W)return;let P=this._encodeValue(W,I,z);if(P!==void 0&&!this._skipDefault(P,I,z))return P},O.prototype._encodeValue=function(W,I,z){let j=this._baseState;if(j.parent===null)return j.children[0]._encode(W,I||new R);let P=null;if(this.reporter=I,j.optional&&W===void 0)if(j.default!==null)W=j.default;else return;let F=null,v=!1;if(j.any)P=this._createEncoderBuffer(W);else if(j.choice)P=this._encodeChoice(W,I);else if(j.contains)F=this._getUse(j.contains,z)._encode(W,I),v=!0;else if(j.children)F=j.children.map(function(S){if(S._baseState.tag==="null_")return S._encode(null,I,W);if(S._baseState.key===null)return I.error("Child should have a key");let w=I.enterKey(S._baseState.key);if(typeof W!="object")return I.error("Child expected, but input is not object");let y=S._encode(W[S._baseState.key],I,W);return I.leaveKey(w),y},this).filter(function(S){return S}),F=this._createEncoderBuffer(F);else if(j.tag==="seqof"||j.tag==="setof"){if(!(j.args&&j.args.length===1))return I.error("Too many args for : "+j.tag);if(!Array.isArray(W))return I.error("seqof/setof, but data is not Array");let S=this.clone();S._baseState.implicit=null,F=this._createEncoderBuffer(W.map(function(w){let y=this._baseState;return this._getUse(y.args[0],W)._encode(w,I)},S))}else j.use!==null?P=this._getUse(j.use,z)._encode(W,I):(F=this._encodePrimitive(j.tag,W),v=!0);if(!j.any&&j.choice===null){let S=j.implicit!==null?j.implicit:j.tag,w=j.implicit===null?"universal":"context";S===null?j.use===null&&I.error("Tag could be omitted only for .use()"):j.use===null&&(P=this._encodeComposite(S,v,w,F))}return j.explicit!==null&&(P=this._encodeComposite(j.explicit,!1,"context",P)),P},O.prototype._encodeChoice=function(W,I){let z=this._baseState,j=z.choice[W.type];return j||A(!1,W.type+" not found in "+JSON.stringify(Object.keys(z.choice))),j._encode(W.value,I)},O.prototype._encodePrimitive=function(W,I){let z=this._baseState;if(/str$/.test(W))return this._encodeStr(I,W);if(W==="objid"&&z.args)return this._encodeObjid(I,z.reverseArgs[0],z.args[1]);if(W==="objid")return this._encodeObjid(I,null,null);if(W==="gentime"||W==="utctime")return this._encodeTime(I,W);if(W==="null_")return this._encodeNull();if(W==="int"||W==="enum")return this._encodeInt(I,z.args&&z.reverseArgs[0]);if(W==="bool")return this._encodeBool(I);if(W==="objDesc")return this._encodeStr(I,W);throw new Error("Unsupported tag: "+W)},O.prototype._isNumstr=function(W){return/^[0-9 ]*$/.test(W)},O.prototype._isPrintstr=function(W){return/^[A-Za-z0-9 '()+,-./:=?]*$/.test(W)}}),H0=OJ((l)=>{function g(R){let M={};return Object.keys(R).forEach(function(B){(B|0)==B&&(B=B|0);let A=R[B];M[A]=B}),M}l.tagClass={0:"universal",1:"application",2:"context",3:"private"},l.tagClassByName=g(l.tagClass),l.tag={0:"end",1:"bool",2:"int",3:"bitstr",4:"octstr",5:"null_",6:"objid",7:"objDesc",8:"external",9:"real",10:"enum",11:"embed",12:"utf8str",13:"relativeOid",16:"seq",17:"set",18:"numstr",19:"printstr",20:"t61str",21:"videostr",22:"ia5str",23:"utctime",24:"gentime",25:"graphstr",26:"iso646str",27:"genstr",28:"unistr",29:"charstr",30:"bmpstr"},l.tagByName=g(l.tag)}),O6=OJ((l,g)=>{var R=JQ(),M=G0().Buffer,B=U0(),A=H0();function q(N){this.enc="der",this.name=N.name,this.entity=N,this.tree=new Y,this.tree._init(N.body)}g.exports=q,q.prototype.encode=function(N,W){return this.tree._encode(N,W).join()};function Y(N){B.call(this,"der",N)}R(Y,B),Y.prototype._encodeComposite=function(N,W,I,z){let j=O(N,W,I,this.reporter);if(z.length<128){let v=M.alloc(2);return v[0]=j,v[1]=z.length,this._createEncoderBuffer([v,z])}let P=1;for(let v=z.length;v>=256;v>>=8)P++;let F=M.alloc(2+P);F[0]=j,F[1]=128|P;for(let v=1+P,S=z.length;S>0;v--,S>>=8)F[v]=S&255;return this._createEncoderBuffer([F,z])},Y.prototype._encodeStr=function(N,W){if(W==="bitstr")return this._createEncoderBuffer([N.unused|0,N.data]);if(W==="bmpstr"){let I=M.alloc(N.length*2);for(let z=0;z<N.length;z++)I.writeUInt16BE(N.charCodeAt(z),z*2);return this._createEncoderBuffer(I)}else return W==="numstr"?this._isNumstr(N)?this._createEncoderBuffer(N):this.reporter.error("Encoding of string type: numstr supports only digits and space"):W==="printstr"?this._isPrintstr(N)?this._createEncoderBuffer(N):this.reporter.error("Encoding of string type: printstr supports only latin upper and lower case letters, digits, space, apostrophe, left and rigth parenthesis, plus sign, comma, hyphen, dot, slash, colon, equal sign, question mark"):/str$/.test(W)?this._createEncoderBuffer(N):W==="objDesc"?this._createEncoderBuffer(N):this.reporter.error("Encoding of string type: "+W+" unsupported")},Y.prototype._encodeObjid=function(N,W,I){if(typeof N=="string"){if(!W)return this.reporter.error("string objid given, but no values map found");if(!W.hasOwnProperty(N))return this.reporter.error("objid not found in values map");N=W[N].split(/[\s.]+/g);for(let F=0;F<N.length;F++)N[F]|=0}else if(Array.isArray(N)){N=N.slice();for(let F=0;F<N.length;F++)N[F]|=0}if(!Array.isArray(N))return this.reporter.error("objid() should be either array or string, got: "+JSON.stringify(N));if(!I){if(N[1]>=40)return this.reporter.error("Second objid identifier OOB");N.splice(0,2,N[0]*40+N[1])}let z=0;for(let F=0;F<N.length;F++){let v=N[F];for(z++;v>=128;v>>=7)z++}let j=M.alloc(z),P=j.length-1;for(let F=N.length-1;F>=0;F--){let v=N[F];for(j[P--]=v&127;(v>>=7)>0;)j[P--]=128|v&127}return this._createEncoderBuffer(j)};function E(N){return N<10?"0"+N:N}Y.prototype._encodeTime=function(N,W){let I,z=new Date(N);return W==="gentime"?I=[E(z.getUTCFullYear()),E(z.getUTCMonth()+1),E(z.getUTCDate()),E(z.getUTCHours()),E(z.getUTCMinutes()),E(z.getUTCSeconds()),"Z"].join(""):W==="utctime"?I=[E(z.getUTCFullYear()%100),E(z.getUTCMonth()+1),E(z.getUTCDate()),E(z.getUTCHours()),E(z.getUTCMinutes()),E(z.getUTCSeconds()),"Z"].join(""):this.reporter.error("Encoding "+W+" time is not supported yet"),this._encodeStr(I,"octstr")},Y.prototype._encodeNull=function(){return this._createEncoderBuffer("")},Y.prototype._encodeInt=function(N,W){if(typeof N=="string"){if(!W)return this.reporter.error("String int or enum given, but no values map");if(!W.hasOwnProperty(N))return this.reporter.error("Values map doesn't contain: "+JSON.stringify(N));N=W[N]}if(typeof N!="number"&&!M.isBuffer(N)){let j=N.toArray();!N.sign&&j[0]&128&&j.unshift(0),N=M.from(j)}if(M.isBuffer(N)){let j=N.length;N.length===0&&j++;let P=M.alloc(j);return N.copy(P),N.length===0&&(P[0]=0),this._createEncoderBuffer(P)}if(N<128)return this._createEncoderBuffer(N);if(N<256)return this._createEncoderBuffer([0,N]);let I=1;for(let j=N;j>=256;j>>=8)I++;let z=new Array(I);for(let j=z.length-1;j>=0;j--)z[j]=N&255,N>>=8;return z[0]&128&&z.unshift(0),this._createEncoderBuffer(M.from(z))},Y.prototype._encodeBool=function(N){return this._createEncoderBuffer(N?255:0)},Y.prototype._use=function(N,W){return typeof N=="function"&&(N=N(W)),N._getEncoder("der").tree},Y.prototype._skipDefault=function(N,W,I){let z=this._baseState,j;if(z.default===null)return!1;let P=N.join();if(z.defaultBuffer===void 0&&(z.defaultBuffer=this._encodeValue(z.default,W,I).join()),P.length!==z.defaultBuffer.length)return!1;for(j=0;j<P.length;j++)if(P[j]!==z.defaultBuffer[j])return!1;return!0};function O(N,W,I,z){let j;if(N==="seqof"?N="seq":N==="setof"&&(N="set"),A.tagByName.hasOwnProperty(N))j=A.tagByName[N];else if(typeof N=="number"&&(N|0)===N)j=N;else return z.error("Unknown tag: "+N);return j>=31?z.error("Multi-octet tag encoding unsupported"):(W||(j|=32),j|=A.tagClassByName[I||"universal"]<<6,j)}}),Y$=OJ((l,g)=>{var R=JQ(),M=O6();function B(A){M.call(this,A),this.enc="pem"}R(B,M),g.exports=B,B.prototype.encode=function(A,q){let Y=M.prototype.encode.call(this,A).toString("base64"),E=["-----BEGIN "+q.label+"-----"];for(let O=0;O<Y.length;O+=64)E.push(Y.slice(O,O+64));return E.push("-----END "+q.label+"-----"),E.join(`
+`)}}),j6=OJ((l)=>{var g=l;g.der=O6(),g.pem=Y$()}),T6=OJ((l,g)=>{var R=JQ(),M=B6(),B=OV().DecoderBuffer,A=U0(),q=H0();function Y(W){this.enc="der",this.name=W.name,this.entity=W,this.tree=new E,this.tree._init(W.body)}g.exports=Y,Y.prototype.decode=function(W,I){return B.isDecoderBuffer(W)||(W=new B(W,I)),this.tree._decode(W,I)};function E(W){A.call(this,"der",W)}R(E,A),E.prototype._peekTag=function(W,I,z){if(W.isEmpty())return!1;let j=W.save(),P=O(W,'Failed to peek tag: "'+I+'"');return W.isError(P)?P:(W.restore(j),P.tag===I||P.tagStr===I||P.tagStr+"of"===I||z)},E.prototype._decodeTag=function(W,I,z){let j=O(W,'Failed to decode tag of "'+I+'"');if(W.isError(j))return j;let P=N(W,j.primitive,'Failed to get length of "'+I+'"');if(W.isError(P))return P;if(!z&&j.tag!==I&&j.tagStr!==I&&j.tagStr+"of"!==I)return W.error('Failed to match tag: "'+I+'"');if(j.primitive||P!==null)return W.skip(P,'Failed to match body of: "'+I+'"');let F=W.save(),v=this._skipUntilEnd(W,'Failed to skip indefinite length body: "'+this.tag+'"');return W.isError(v)?v:(P=W.offset-F.offset,W.restore(F),W.skip(P,'Failed to match body of: "'+I+'"'))},E.prototype._skipUntilEnd=function(W,I){for(;;){let z=O(W,I);if(W.isError(z))return z;let j=N(W,z.primitive,I);if(W.isError(j))return j;let P;if(z.primitive||j!==null?P=W.skip(j):P=this._skipUntilEnd(W,I),W.isError(P))return P;if(z.tagStr==="end")break}},E.prototype._decodeList=function(W,I,z,j){let P=[];for(;!W.isEmpty();){let F=this._peekTag(W,"end");if(W.isError(F))return F;let v=z.decode(W,"der",j);if(W.isError(v)&&F)break;P.push(v)}return P},E.prototype._decodeStr=function(W,I){if(I==="bitstr"){let z=W.readUInt8();return W.isError(z)?z:{unused:z,data:W.raw()}}else if(I==="bmpstr"){let z=W.raw();if(z.length%2===1)return W.error("Decoding of string type: bmpstr length mismatch");let j="";for(let P=0;P<z.length/2;P++)j+=String.fromCharCode(z.readUInt16BE(P*2));return j}else if(I==="numstr"){let z=W.raw().toString("ascii");return this._isNumstr(z)?z:W.error("Decoding of string type: numstr unsupported characters")}else{if(I==="octstr")return W.raw();if(I==="objDesc")return W.raw();if(I==="printstr"){let z=W.raw().toString("ascii");return this._isPrintstr(z)?z:W.error("Decoding of string type: printstr unsupported characters")}else return/str$/.test(I)?W.raw().toString():W.error("Decoding of string type: "+I+" unsupported")}},E.prototype._decodeObjid=function(W,I,z){let j,P=[],F=0,v=0;for(;!W.isEmpty();)v=W.readUInt8(),F<<=7,F|=v&127,(v&128)===0&&(P.push(F),F=0);v&128&&P.push(F);let S=P[0]/40|0,w=P[0]%40;if(z?j=P:j=[S,w].concat(P.slice(1)),I){let y=I[j.join(" ")];y===void 0&&(y=I[j.join(".")]),y!==void 0&&(j=y)}return j},E.prototype._decodeTime=function(W,I){let z=W.raw().toString(),j,P,F,v,S,w;if(I==="gentime")j=z.slice(0,4)|0,P=z.slice(4,6)|0,F=z.slice(6,8)|0,v=z.slice(8,10)|0,S=z.slice(10,12)|0,w=z.slice(12,14)|0;else if(I==="utctime")j=z.slice(0,2)|0,P=z.slice(2,4)|0,F=z.slice(4,6)|0,v=z.slice(6,8)|0,S=z.slice(8,10)|0,w=z.slice(10,12)|0,j<70?j=2000+j:j=1900+j;else return W.error("Decoding "+I+" time is not supported yet");return Date.UTC(j,P-1,F,v,S,w,0)},E.prototype._decodeNull=function(){return null},E.prototype._decodeBool=function(W){let I=W.readUInt8();return W.isError(I)?I:I!==0},E.prototype._decodeInt=function(W,I){let z=W.raw(),j=new M(z);return I&&(j=I[j.toString(10)]||j),j},E.prototype._use=function(W,I){return typeof W=="function"&&(W=W(I)),W._getDecoder("der").tree};function O(W,I){let z=W.readUInt8(I);if(W.isError(z))return z;let j=q.tagClass[z>>6],P=(z&32)===0;if((z&31)===31){let v=z;for(z=0;(v&128)===128;){if(v=W.readUInt8(I),W.isError(v))return v;z<<=7,z|=v&127}}else z&=31;let F=q.tag[z];return{cls:j,primitive:P,tag:z,tagStr:F}}function N(W,I,z){let j=W.readUInt8(z);if(W.isError(j))return j;if(!I&&j===128)return null;if((j&128)===0)return j;let P=j&127;if(P>4)return W.error("length octect is too long");j=0;for(let F=0;F<P;F++){j<<=8;let v=W.readUInt8(z);if(W.isError(v))return v;j|=v}return j}}),B$=OJ((l,g)=>{var R=JQ(),M=G0().Buffer,B=T6();function A(q){B.call(this,q),this.enc="pem"}R(A,B),g.exports=A,A.prototype.decode=function(q,Y){let E=q.toString().split(/[\r\n]+/g),O=Y.label.toUpperCase(),N=/^-----(BEGIN|END) ([^-]+)-----$/,W=-1,I=-1;for(let P=0;P<E.length;P++){let F=E[P].match(N);if(F!==null&&F[2]===O)if(W===-1){if(F[1]!=="BEGIN")break;W=P}else{if(F[1]!=="END")break;I=P;break}}if(W===-1||I===-1)throw new Error("PEM section not found for: "+O);let z=E.slice(W+1,I).join("");z.replace(/[^a-z0-9+/=]+/gi,"");let j=M.from(z,"base64");return B.prototype.decode.call(this,j,Y)}}),N6=OJ((l)=>{var g=l;g.der=T6(),g.pem=B$()}),O$=OJ((l)=>{var g=j6(),R=N6(),M=JQ(),B=l;B.define=function(q,Y){return new A(q,Y)};function A(q,Y){this.name=q,this.body=Y,this.decoders={},this.encoders={}}A.prototype._createNamed=function(q){let Y=this.name;function E(O){this._initNamed(O,Y)}return M(E,q),E.prototype._initNamed=function(O,N){q.call(this,O,N)},new E(this)},A.prototype._getDecoder=function(q){return q=q||"der",this.decoders.hasOwnProperty(q)||(this.decoders[q]=this._createNamed(R[q])),this.decoders[q]},A.prototype.decode=function(q,Y,E){return this._getDecoder(Y).decode(q,E)},A.prototype._getEncoder=function(q){return q=q||"der",this.encoders.hasOwnProperty(q)||(this.encoders[q]=this._createNamed(g[q])),this.encoders[q]},A.prototype.encode=function(q,Y,E){return this._getEncoder(Y).encode(q,E)}}),j$=OJ((l)=>{var g=l;g.Reporter=K0().Reporter,g.DecoderBuffer=OV().DecoderBuffer,g.EncoderBuffer=OV().EncoderBuffer,g.Node=U0()}),T$=OJ((l)=>{var g=l;g._reverse=function(R){let M={};return Object.keys(R).forEach(function(B){(B|0)==B&&(B=B|0);let A=R[B];M[A]=B}),M},g.der=H0()}),I6=OJ((l)=>{var g=l;g.bignum=B6(),g.define=O$().define,g.base=j$(),g.constants=T$(),g.decoders=N6(),g.encoders=j6()}),N$=OJ((l,g)=>{var R=I6(),M=R.define("Time",function(){this.choice({utcTime:this.utctime(),generalTime:this.gentime()})}),B=R.define("AttributeTypeValue",function(){this.seq().obj(this.key("type").objid(),this.key("value").any())}),A=R.define("AlgorithmIdentifier",function(){this.seq().obj(this.key("algorithm").objid(),this.key("parameters").optional(),this.key("curve").objid().optional())}),q=R.define("SubjectPublicKeyInfo",function(){this.seq().obj(this.key("algorithm").use(A),this.key("subjectPublicKey").bitstr())}),Y=R.define("RelativeDistinguishedName",function(){this.setof(B)}),E=R.define("RDNSequence",function(){this.seqof(Y)}),O=R.define("Name",function(){this.choice({rdnSequence:this.use(E)})}),N=R.define("Validity",function(){this.seq().obj(this.key("notBefore").use(M),this.key("notAfter").use(M))}),W=R.define("Extension",function(){this.seq().obj(this.key("extnID").objid(),this.key("critical").bool().def(!1),this.key("extnValue").octstr())}),I=R.define("TBSCertificate",function(){this.seq().obj(this.key("version").explicit(0).int().optional(),this.key("serialNumber").int(),this.key("signature").use(A),this.key("issuer").use(O),this.key("validity").use(N),this.key("subject").use(O),this.key("subjectPublicKeyInfo").use(q),this.key("issuerUniqueID").implicit(1).bitstr().optional(),this.key("subjectUniqueID").implicit(2).bitstr().optional(),this.key("extensions").explicit(3).seqof(W).optional())}),z=R.define("X509Certificate",function(){this.seq().obj(this.key("tbsCertificate").use(I),this.key("signatureAlgorithm").use(A),this.key("signatureValue").bitstr())});g.exports=z}),I$=OJ((l)=>{var g=I6();l.certificate=N$();var R=g.define("RSAPrivateKey",function(){this.seq().obj(this.key("version").int(),this.key("modulus").int(),this.key("publicExponent").int(),this.key("privateExponent").int(),this.key("prime1").int(),this.key("prime2").int(),this.key("exponent1").int(),this.key("exponent2").int(),this.key("coefficient").int())});l.RSAPrivateKey=R;var M=g.define("RSAPublicKey",function(){this.seq().obj(this.key("modulus").int(),this.key("publicExponent").int())});l.RSAPublicKey=M;var B=g.define("SubjectPublicKeyInfo",function(){this.seq().obj(this.key("algorithm").use(A),this.key("subjectPublicKey").bitstr())});l.PublicKey=B;var A=g.define("AlgorithmIdentifier",function(){this.seq().obj(this.key("algorithm").objid(),this.key("none").null_().optional(),this.key("curve").objid().optional(),this.key("params").seq().obj(this.key("p").int(),this.key("q").int(),this.key("g").int()).optional())}),q=g.define("PrivateKeyInfo",function(){this.seq().obj(this.key("version").int(),this.key("algorithm").use(A),this.key("subjectPrivateKey").octstr())});l.PrivateKey=q;var Y=g.define("EncryptedPrivateKeyInfo",function(){this.seq().obj(this.key("algorithm").seq().obj(this.key("id").objid(),this.key("decrypt").seq().obj(this.key("kde").seq().obj(this.key("id").objid(),this.key("kdeparams").seq().obj(this.key("salt").octstr(),this.key("iters").int())),this.key("cipher").seq().obj(this.key("algo").objid(),this.key("iv").octstr()))),this.key("subjectPrivateKey").octstr())});l.EncryptedPrivateKey=Y;var E=g.define("DSAPrivateKey",function(){this.seq().obj(this.key("version").int(),this.key("p").int(),this.key("q").int(),this.key("g").int(),this.key("pub_key").int(),this.key("priv_key").int())});l.DSAPrivateKey=E,l.DSAparam=g.define("DSAparam",function(){this.int()});var O=g.define("ECPrivateKey",function(){this.seq().obj(this.key("version").int(),this.key("privateKey").octstr(),this.key("parameters").optional().explicit(0).use(N),this.key("publicKey").optional().explicit(1).bitstr())});l.ECPrivateKey=O;var N=g.define("ECParameters",function(){this.choice({namedCurve:this.objid()})});l.signature=g.define("signature",function(){this.seq().obj(this.key("r").int(),this.key("s").int())})}),E$=OJ((l,g)=>{g.exports={"2.16.840.1.101.3.4.1.1":"aes-128-ecb","2.16.840.1.101.3.4.1.2":"aes-128-cbc","2.16.840.1.101.3.4.1.3":"aes-128-ofb","2.16.840.1.101.3.4.1.4":"aes-128-cfb","2.16.840.1.101.3.4.1.21":"aes-192-ecb","2.16.840.1.101.3.4.1.22":"aes-192-cbc","2.16.840.1.101.3.4.1.23":"aes-192-ofb","2.16.840.1.101.3.4.1.24":"aes-192-cfb","2.16.840.1.101.3.4.1.41":"aes-256-ecb","2.16.840.1.101.3.4.1.42":"aes-256-cbc","2.16.840.1.101.3.4.1.43":"aes-256-ofb","2.16.840.1.101.3.4.1.44":"aes-256-cfb"}}),R$=OJ((l,g)=>{var R=/Proc-Type: 4,ENCRYPTED[\n\r]+DEK-Info: AES-((?:128)|(?:192)|(?:256))-CBC,([0-9A-H]+)[\n\r]+([0-9A-z\n\r+/=]+)[\n\r]+/m,M=/^-----BEGIN ((?:.*? KEY)|CERTIFICATE)-----/m,B=/^-----BEGIN ((?:.*? KEY)|CERTIFICATE)-----([0-9A-z\n\r+/=]+)-----END \1-----$/m,A=kV(),q=eV(),Y=XQ().Buffer;g.exports=function(E,O){var N=E.toString(),W=N.match(R),I;if(W){var z="aes"+W[1],j=Y.from(W[2],"hex"),P=Y.from(W[3].replace(/[\r\n]/g,""),"base64"),F=A(O,j.slice(0,8),parseInt(W[1],10)).key,v=[],S=q.createDecipheriv(z,F,j);v.push(S.update(P)),v.push(S.final()),I=Y.concat(v)}else{var w=N.match(B);I=Y.from(w[2].replace(/[\r\n]/g,""),"base64")}var y=N.match(M)[1];return{tag:y,data:I}}}),SV=OJ((l,g)=>{var R=I$(),M=E$(),B=R$(),A=eV(),q=l0(),Y=XQ().Buffer;g.exports=E;function E(N){var W;typeof N=="object"&&!Y.isBuffer(N)&&(W=N.passphrase,N=N.key),typeof N=="string"&&(N=Y.from(N));var I=B(N,W),z=I.tag,j=I.data,P,F;switch(z){case"CERTIFICATE":F=R.certificate.decode(j,"der").tbsCertificate.subjectPublicKeyInfo;case"PUBLIC KEY":switch(F||(F=R.PublicKey.decode(j,"der")),P=F.algorithm.algorithm.join("."),P){case"1.2.840.113549.1.1.1":return R.RSAPublicKey.decode(F.subjectPublicKey.data,"der");case"1.2.840.10045.2.1":return F.subjectPrivateKey=F.subjectPublicKey,{type:"ec",data:F};case"1.2.840.10040.4.1":return F.algorithm.params.pub_key=R.DSAparam.decode(F.subjectPublicKey.data,"der"),{type:"dsa",data:F.algorithm.params};default:throw new Error("unknown key id "+P)}case"ENCRYPTED PRIVATE KEY":j=R.EncryptedPrivateKey.decode(j,"der"),j=O(j,W);case"PRIVATE KEY":switch(F=R.PrivateKey.decode(j,"der"),P=F.algorithm.algorithm.join("."),P){case"1.2.840.113549.1.1.1":return R.RSAPrivateKey.decode(F.subjectPrivateKey,"der");case"1.2.840.10045.2.1":return{curve:F.algorithm.curve,privateKey:R.ECPrivateKey.decode(F.subjectPrivateKey,"der").privateKey};case"1.2.840.10040.4.1":return F.algorithm.params.priv_key=R.DSAparam.decode(F.subjectPrivateKey,"der"),{type:"dsa",params:F.algorithm.params};default:throw new Error("unknown key id "+P)}case"RSA PUBLIC KEY":return R.RSAPublicKey.decode(j,"der");case"RSA PRIVATE KEY":return R.RSAPrivateKey.decode(j,"der");case"DSA PRIVATE KEY":return{type:"dsa",params:R.DSAPrivateKey.decode(j,"der")};case"EC PRIVATE KEY":return j=R.ECPrivateKey.decode(j,"der"),{curve:j.parameters.value,privateKey:j.privateKey};default:throw new Error("unknown key type "+z)}}E.signature=R.signature;function O(N,W){var I=N.algorithm.decrypt.kde.kdeparams.salt,z=parseInt(N.algorithm.decrypt.kde.kdeparams.iters.toString(),10),j=M[N.algorithm.decrypt.cipher.algo.join(".")],P=N.algorithm.decrypt.cipher.iv,F=N.subjectPrivateKey,v=parseInt(j.split("-")[1],10)/8,S=q.pbkdf2Sync(W,I,z,v,"sha1"),w=A.createDecipheriv(j,S,P),y=[];return y.push(w.update(F)),y.push(w.final()),Y.concat(y)}}),E6=OJ((l,g)=>{g.exports={"1.3.132.0.10":"secp256k1","1.3.132.0.33":"p224","1.2.840.10045.3.1.1":"p192","1.2.840.10045.3.1.7":"p256","1.3.132.0.34":"p384","1.3.132.0.35":"p521"}}),z$=OJ((l,g)=>{var R=XQ().Buffer,M=f0(),B=$0(),A=q0().ec,q=V0(),Y=SV(),E=E6();function O(S,w,y,m,i){var JJ=Y(w);if(JJ.curve){if(m!=="ecdsa"&&m!=="ecdsa/rsa")throw new Error("wrong private key type");return N(S,JJ)}else if(JJ.type==="dsa"){if(m!=="dsa")throw new Error("wrong private key type");return W(S,JJ,y)}else if(m!=="rsa"&&m!=="ecdsa/rsa")throw new Error("wrong private key type");S=R.concat([i,S]);for(var VJ=JJ.modulus.byteLength(),HJ=[0,1];S.length+HJ.length+1<VJ;)HJ.push(255);HJ.push(0);for(var o=-1;++o<S.length;)HJ.push(S[o]);var jJ=B(HJ,JJ);return jJ}function N(S,w){var y=E[w.curve.join(".")];if(!y)throw new Error("unknown curve "+w.curve.join("."));var m=new A(y),i=m.keyFromPrivate(w.privateKey),JJ=i.sign(S);return R.from(JJ.toDER())}function W(S,w,y){for(var m=w.params.priv_key,i=w.params.p,JJ=w.params.q,VJ=w.params.g,HJ=new q(0),o,jJ=j(S,JJ).mod(JJ),J=!1,V=z(m,JJ,S,y);J===!1;)o=F(JJ,V,y),HJ=v(VJ,o,i,JJ),J=o.invm(JJ).imul(jJ.add(m.mul(HJ))).mod(JJ),J.cmpn(0)===0&&(J=!1,HJ=new q(0));return I(HJ,J)}function I(S,w){S=S.toArray(),w=w.toArray(),S[0]&128&&(S=[0].concat(S)),w[0]&128&&(w=[0].concat(w));var y=S.length+w.length+4,m=[48,y,2,S.length];return m=m.concat(S,[2,w.length],w),R.from(m)}function z(S,w,y,m){if(S=R.from(S.toArray()),S.length<w.byteLength()){var i=R.alloc(w.byteLength()-S.length);S=R.concat([i,S])}var JJ=y.length,VJ=P(y,w),HJ=R.alloc(JJ);HJ.fill(1);var o=R.alloc(JJ);return o=M(m,o).update(HJ).update(R.from([0])).update(S).update(VJ).digest(),HJ=M(m,o).update(HJ).digest(),o=M(m,o).update(HJ).update(R.from([1])).update(S).update(VJ).digest(),HJ=M(m,o).update(HJ).digest(),{k:o,v:HJ}}function j(S,w){var y=new q(S),m=(S.length<<3)-w.bitLength();return m>0&&y.ishrn(m),y}function P(S,w){S=j(S,w),S=S.mod(w);var y=R.from(S.toArray());if(y.length<w.byteLength()){var m=R.alloc(w.byteLength()-y.length);y=R.concat([m,y])}return y}function F(S,w,y){var m,i;do{for(m=R.alloc(0);m.length*8<S.bitLength();)w.v=M(y,w.k).update(w.v).digest(),m=R.concat([m,w.v]);i=j(m,S),w.k=M(y,w.k).update(w.v).update(R.from([0])).digest(),w.v=M(y,w.k).update(w.v).digest()}while(i.cmp(S)!==-1);return i}function v(S,w,y,m){return S.toRed(q.mont(y)).redPow(w).fromRed().mod(m)}g.exports=O,g.exports.getKey=z,g.exports.makeKey=F}),P$=OJ((l,g)=>{var R=XQ().Buffer,M=V0(),B=q0().ec,A=SV(),q=E6();function Y(W,I,z,j,P){var F=A(z);if(F.type==="ec"){if(j!=="ecdsa"&&j!=="ecdsa/rsa")throw new Error("wrong public key type");return E(W,I,F)}else if(F.type==="dsa"){if(j!=="dsa")throw new Error("wrong public key type");return O(W,I,F)}else if(j!=="rsa"&&j!=="ecdsa/rsa")throw new Error("wrong public key type");I=R.concat([P,I]);for(var v=F.modulus.byteLength(),S=[1],w=0;I.length+S.length+2<v;)S.push(255),w++;S.push(0);for(var y=-1;++y<I.length;)S.push(I[y]);S=R.from(S);var m=M.mont(F.modulus);W=new M(W).toRed(m),W=W.redPow(new M(F.publicExponent)),W=R.from(W.fromRed().toArray());var i=w<8?1:0;for(v=Math.min(W.length,S.length),W.length!==S.length&&(i=1),y=-1;++y<v;)i|=W[y]^S[y];return i===0}function E(W,I,z){var j=q[z.data.algorithm.curve.join(".")];if(!j)throw new Error("unknown curve "+z.data.algorithm.curve.join("."));var P=new B(j),F=z.data.subjectPrivateKey.data;return P.verify(I,W,F)}function O(W,I,z){var j=z.data.p,P=z.data.q,F=z.data.g,v=z.data.pub_key,S=A.signature.decode(W,"der"),w=S.s,y=S.r;N(w,P),N(y,P);var m=M.mont(j),i=w.invm(P),JJ=F.toRed(m).redPow(new M(I).mul(i).mod(P)).fromRed().mul(v.toRed(m).redPow(y.mul(i).mod(P)).fromRed()).mod(j).mod(P);return JJ.cmp(y)===0}function N(W,I){if(W.cmpn(0)<=0)throw new Error("invalid sig");if(W.cmp(I)>=I)throw new Error("invalid sig")}g.exports=Y}),L$=OJ((l,g)=>{var R=XQ().Buffer,M=WV(),B=d8(),A=JQ(),q=z$(),Y=P$(),E=h0();Object.keys(E).forEach(function(z){E[z].id=R.from(E[z].id,"hex"),E[z.toLowerCase()]=E[z]});function O(z){B.Writable.call(this);var j=E[z];if(!j)throw new Error("Unknown message digest");this._hashType=j.hash,this._hash=M(j.hash),this._tag=j.id,this._signType=j.sign}A(O,B.Writable),O.prototype._write=function(z,j,P){this._hash.update(z),P()},O.prototype.update=function(z,j){return typeof z=="string"&&(z=R.from(z,j)),this._hash.update(z),this},O.prototype.sign=function(z,j){this.end();var P=this._hash.digest(),F=q(P,z,this._hashType,this._signType,this._tag);return j?F.toString(j):F};function N(z){B.Writable.call(this);var j=E[z];if(!j)throw new Error("Unknown message digest");this._hash=M(j.hash),this._tag=j.id,this._signType=j.sign}A(N,B.Writable),N.prototype._write=function(z,j,P){this._hash.update(z),P()},N.prototype.update=function(z,j){return typeof z=="string"&&(z=R.from(z,j)),this._hash.update(z),this},N.prototype.verify=function(z,j,P){typeof j=="string"&&(j=R.from(j,P)),this.end();var F=this._hash.digest();return Y(j,F,z,this._signType,this._tag)};function W(z){return new O(z)}function I(z){return new N(z)}g.exports={Sign:W,Verify:I,createSign:W,createVerify:I}}),F$=OJ((l,g)=>{(function(R,M){function B(J,V){if(!J)throw new Error(V||"Assertion failed")}function A(J,V){J.super_=V;var Z=function(){};Z.prototype=V.prototype,J.prototype=new Z,J.prototype.constructor=J}function q(J,V,Z){if(q.isBN(J))return J;this.negative=0,this.words=null,this.length=0,this.red=null,J!==null&&((V==="le"||V==="be")&&(Z=V,V=10),this._init(J||0,V||10,Z||"be"))}typeof R=="object"?R.exports=q:M.BN=q,q.BN=q,q.wordSize=26;var Y;try{typeof window<"u"&&typeof window.Buffer<"u"?Y=window.Buffer:Y=JV().Buffer}catch{}q.isBN=function(J){return J instanceof q?!0:J!==null&&typeof J=="object"&&J.constructor.wordSize===q.wordSize&&Array.isArray(J.words)},q.max=function(J,V){return J.cmp(V)>0?J:V},q.min=function(J,V){return J.cmp(V)<0?J:V},q.prototype._init=function(J,V,Z){if(typeof J=="number")return this._initNumber(J,V,Z);if(typeof J=="object")return this._initArray(J,V,Z);V==="hex"&&(V=16),B(V===(V|0)&&V>=2&&V<=36),J=J.toString().replace(/\s+/g,"");var $=0;J[0]==="-"&&($++,this.negative=1),$<J.length&&(V===16?this._parseHex(J,$,Z):(this._parseBase(J,V,$),Z==="le"&&this._initArray(this.toArray(),V,Z)))},q.prototype._initNumber=function(J,V,Z){J<0&&(this.negative=1,J=-J),J<67108864?(this.words=[J&67108863],this.length=1):J<4503599627370496?(this.words=[J&67108863,J/67108864&67108863],this.length=2):(B(J<9007199254740992),this.words=[J&67108863,J/67108864&67108863,1],this.length=3),Z==="le"&&this._initArray(this.toArray(),V,Z)},q.prototype._initArray=function(J,V,Z){if(B(typeof J.length=="number"),J.length<=0)return this.words=[0],this.length=1,this;this.length=Math.ceil(J.length/3),this.words=new Array(this.length);for(var $=0;$<this.length;$++)this.words[$]=0;var X,U,H=0;if(Z==="be")for($=J.length-1,X=0;$>=0;$-=3)U=J[$]|J[$-1]<<8|J[$-2]<<16,this.words[X]|=U<<H&67108863,this.words[X+1]=U>>>26-H&67108863,H+=24,H>=26&&(H-=26,X++);else if(Z==="le")for($=0,X=0;$<J.length;$+=3)U=J[$]|J[$+1]<<8|J[$+2]<<16,this.words[X]|=U<<H&67108863,this.words[X+1]=U>>>26-H&67108863,H+=24,H>=26&&(H-=26,X++);return this.strip()};function E(J,V){var Z=J.charCodeAt(V);return Z>=65&&Z<=70?Z-55:Z>=97&&Z<=102?Z-87:Z-48&15}function O(J,V,Z){var $=E(J,Z);return Z-1>=V&&($|=E(J,Z-1)<<4),$}q.prototype._parseHex=function(J,V,Z){this.length=Math.ceil((J.length-V)/6),this.words=new Array(this.length);for(var $=0;$<this.length;$++)this.words[$]=0;var X=0,U=0,H;if(Z==="be")for($=J.length-1;$>=V;$-=2)H=O(J,V,$)<<X,this.words[U]|=H&67108863,X>=18?(X-=18,U+=1,this.words[U]|=H>>>26):X+=8;else{var G=J.length-V;for($=G%2===0?V+1:V;$<J.length;$+=2)H=O(J,V,$)<<X,this.words[U]|=H&67108863,X>=18?(X-=18,U+=1,this.words[U]|=H>>>26):X+=8}this.strip()};function N(J,V,Z,$){for(var X=0,U=Math.min(J.length,Z),H=V;H<U;H++){var G=J.charCodeAt(H)-48;X*=$,G>=49?X+=G-49+10:G>=17?X+=G-17+10:X+=G}return X}q.prototype._parseBase=function(J,V,Z){this.words=[0],this.length=1;for(var $=0,X=1;X<=67108863;X*=V)$++;$--,X=X/V|0;for(var U=J.length-Z,H=U%$,G=Math.min(U,U-H)+Z,Q=0,K=Z;K<G;K+=$)Q=N(J,K,K+$,V),this.imuln(X),this.words[0]+Q<67108864?this.words[0]+=Q:this._iaddn(Q);if(H!==0){var k=1;for(Q=N(J,K,J.length,V),K=0;K<H;K++)k*=V;this.imuln(k),this.words[0]+Q<67108864?this.words[0]+=Q:this._iaddn(Q)}this.strip()},q.prototype.copy=function(J){J.words=new Array(this.length);for(var V=0;V<this.length;V++)J.words[V]=this.words[V];J.length=this.length,J.negative=this.negative,J.red=this.red},q.prototype.clone=function(){var J=new q(null);return this.copy(J),J},q.prototype._expand=function(J){for(;this.length<J;)this.words[this.length++]=0;return this},q.prototype.strip=function(){for(;this.length>1&&this.words[this.length-1]===0;)this.length--;return this._normSign()},q.prototype._normSign=function(){return this.length===1&&this.words[0]===0&&(this.negative=0),this},q.prototype.inspect=function(){return(this.red?"<BN-R: ":"<BN: ")+this.toString(16)+">"};var W=["","0","00","000","0000","00000","000000","0000000","00000000","000000000","0000000000","00000000000","000000000000","0000000000000","00000000000000","000000000000000","0000000000000000","00000000000000000","000000000000000000","0000000000000000000","00000000000000000000","000000000000000000000","0000000000000000000000","00000000000000000000000","000000000000000000000000","0000000000000000000000000"],I=[0,0,25,16,12,11,10,9,8,8,7,7,7,7,6,6,6,6,6,6,6,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5],z=[0,0,33554432,43046721,16777216,48828125,60466176,40353607,16777216,43046721,1e7,19487171,35831808,62748517,7529536,11390625,16777216,24137569,34012224,47045881,64000000,4084101,5153632,6436343,7962624,9765625,11881376,14348907,17210368,20511149,24300000,28629151,33554432,39135393,45435424,52521875,60466176];q.prototype.toString=function(J,V){J=J||10,V=V|0||1;var Z;if(J===16||J==="hex"){Z="";for(var $=0,X=0,U=0;U<this.length;U++){var H=this.words[U],G=((H<<$|X)&16777215).toString(16);X=H>>>24-$&16777215,X!==0||U!==this.length-1?Z=W[6-G.length]+G+Z:Z=G+Z,$+=2,$>=26&&($-=26,U--)}for(X!==0&&(Z=X.toString(16)+Z);Z.length%V!==0;)Z="0"+Z;return this.negative!==0&&(Z="-"+Z),Z}if(J===(J|0)&&J>=2&&J<=36){var Q=I[J],K=z[J];Z="";var k=this.clone();for(k.negative=0;!k.isZero();){var L=k.modn(K).toString(J);k=k.idivn(K),k.isZero()?Z=L+Z:Z=W[Q-L.length]+L+Z}for(this.isZero()&&(Z="0"+Z);Z.length%V!==0;)Z="0"+Z;return this.negative!==0&&(Z="-"+Z),Z}B(!1,"Base should be between 2 and 36")},q.prototype.toNumber=function(){var J=this.words[0];return this.length===2?J+=this.words[1]*67108864:this.length===3&&this.words[2]===1?J+=4503599627370496+this.words[1]*67108864:this.length>2&&B(!1,"Number can only safely store up to 53 bits"),this.negative!==0?-J:J},q.prototype.toJSON=function(){return this.toString(16)},q.prototype.toBuffer=function(J,V){return B(typeof Y<"u"),this.toArrayLike(Y,J,V)},q.prototype.toArray=function(J,V){return this.toArrayLike(Array,J,V)},q.prototype.toArrayLike=function(J,V,Z){var $=this.byteLength(),X=Z||Math.max(1,$);B($<=X,"byte array longer than desired length"),B(X>0,"Requested array length <= 0"),this.strip();var U=V==="le",H=new J(X),G,Q,K=this.clone();if(U){for(Q=0;!K.isZero();Q++)G=K.andln(255),K.iushrn(8),H[Q]=G;for(;Q<X;Q++)H[Q]=0}else{for(Q=0;Q<X-$;Q++)H[Q]=0;for(Q=0;!K.isZero();Q++)G=K.andln(255),K.iushrn(8),H[X-Q-1]=G}return H},Math.clz32?q.prototype._countBits=function(J){return 32-Math.clz32(J)}:q.prototype._countBits=function(J){var V=J,Z=0;return V>=4096&&(Z+=13,V>>>=13),V>=64&&(Z+=7,V>>>=7),V>=8&&(Z+=4,V>>>=4),V>=2&&(Z+=2,V>>>=2),Z+V},q.prototype._zeroBits=function(J){if(J===0)return 26;var V=J,Z=0;return(V&8191)===0&&(Z+=13,V>>>=13),(V&127)===0&&(Z+=7,V>>>=7),(V&15)===0&&(Z+=4,V>>>=4),(V&3)===0&&(Z+=2,V>>>=2),(V&1)===0&&Z++,Z},q.prototype.bitLength=function(){var J=this.words[this.length-1],V=this._countBits(J);return(this.length-1)*26+V};function j(J){for(var V=new Array(J.bitLength()),Z=0;Z<V.length;Z++){var $=Z/26|0,X=Z%26;V[Z]=(J.words[$]&1<<X)>>>X}return V}q.prototype.zeroBits=function(){if(this.isZero())return 0;for(var J=0,V=0;V<this.length;V++){var Z=this._zeroBits(this.words[V]);if(J+=Z,Z!==26)break}return J},q.prototype.byteLength=function(){return Math.ceil(this.bitLength()/8)},q.prototype.toTwos=function(J){return this.negative!==0?this.abs().inotn(J).iaddn(1):this.clone()},q.prototype.fromTwos=function(J){return this.testn(J-1)?this.notn(J).iaddn(1).ineg():this.clone()},q.prototype.isNeg=function(){return this.negative!==0},q.prototype.neg=function(){return this.clone().ineg()},q.prototype.ineg=function(){return this.isZero()||(this.negative^=1),this},q.prototype.iuor=function(J){for(;this.length<J.length;)this.words[this.length++]=0;for(var V=0;V<J.length;V++)this.words[V]=this.words[V]|J.words[V];return this.strip()},q.prototype.ior=function(J){return B((this.negative|J.negative)===0),this.iuor(J)},q.prototype.or=function(J){return this.length>J.length?this.clone().ior(J):J.clone().ior(this)},q.prototype.uor=function(J){return this.length>J.length?this.clone().iuor(J):J.clone().iuor(this)},q.prototype.iuand=function(J){var V;this.length>J.length?V=J:V=this;for(var Z=0;Z<V.length;Z++)this.words[Z]=this.words[Z]&J.words[Z];return this.length=V.length,this.strip()},q.prototype.iand=function(J){return B((this.negative|J.negative)===0),this.iuand(J)},q.prototype.and=function(J){return this.length>J.length?this.clone().iand(J):J.clone().iand(this)},q.prototype.uand=function(J){return this.length>J.length?this.clone().iuand(J):J.clone().iuand(this)},q.prototype.iuxor=function(J){var V,Z;this.length>J.length?(V=this,Z=J):(V=J,Z=this);for(var $=0;$<Z.length;$++)this.words[$]=V.words[$]^Z.words[$];if(this!==V)for(;$<V.length;$++)this.words[$]=V.words[$];return this.length=V.length,this.strip()},q.prototype.ixor=function(J){return B((this.negative|J.negative)===0),this.iuxor(J)},q.prototype.xor=function(J){return this.length>J.length?this.clone().ixor(J):J.clone().ixor(this)},q.prototype.uxor=function(J){return this.length>J.length?this.clone().iuxor(J):J.clone().iuxor(this)},q.prototype.inotn=function(J){B(typeof J=="number"&&J>=0);var V=Math.ceil(J/26)|0,Z=J%26;this._expand(V),Z>0&&V--;for(var $=0;$<V;$++)this.words[$]=~this.words[$]&67108863;return Z>0&&(this.words[$]=~this.words[$]&67108863>>26-Z),this.strip()},q.prototype.notn=function(J){return this.clone().inotn(J)},q.prototype.setn=function(J,V){B(typeof J=="number"&&J>=0);var Z=J/26|0,$=J%26;return this._expand(Z+1),V?this.words[Z]=this.words[Z]|1<<$:this.words[Z]=this.words[Z]&~(1<<$),this.strip()},q.prototype.iadd=function(J){var V;if(this.negative!==0&&J.negative===0)return this.negative=0,V=this.isub(J),this.negative^=1,this._normSign();if(this.negative===0&&J.negative!==0)return J.negative=0,V=this.isub(J),J.negative=1,V._normSign();var Z,$;this.length>J.length?(Z=this,$=J):(Z=J,$=this);for(var X=0,U=0;U<$.length;U++)V=(Z.words[U]|0)+($.words[U]|0)+X,this.words[U]=V&67108863,X=V>>>26;for(;X!==0&&U<Z.length;U++)V=(Z.words[U]|0)+X,this.words[U]=V&67108863,X=V>>>26;if(this.length=Z.length,X!==0)this.words[this.length]=X,this.length++;else if(Z!==this)for(;U<Z.length;U++)this.words[U]=Z.words[U];return this},q.prototype.add=function(J){var V;return J.negative!==0&&this.negative===0?(J.negative=0,V=this.sub(J),J.negative^=1,V):J.negative===0&&this.negative!==0?(this.negative=0,V=J.sub(this),this.negative=1,V):this.length>J.length?this.clone().iadd(J):J.clone().iadd(this)},q.prototype.isub=function(J){if(J.negative!==0){J.negative=0;var V=this.iadd(J);return J.negative=1,V._normSign()}else if(this.negative!==0)return this.negative=0,this.iadd(J),this.negative=1,this._normSign();var Z=this.cmp(J);if(Z===0)return this.negative=0,this.length=1,this.words[0]=0,this;var $,X;Z>0?($=this,X=J):($=J,X=this);for(var U=0,H=0;H<X.length;H++)V=($.words[H]|0)-(X.words[H]|0)+U,U=V>>26,this.words[H]=V&67108863;for(;U!==0&&H<$.length;H++)V=($.words[H]|0)+U,U=V>>26,this.words[H]=V&67108863;if(U===0&&H<$.length&&$!==this)for(;H<$.length;H++)this.words[H]=$.words[H];return this.length=Math.max(this.length,H),$!==this&&(this.negative=1),this.strip()},q.prototype.sub=function(J){return this.clone().isub(J)};function P(J,V,Z){Z.negative=V.negative^J.negative;var $=J.length+V.length|0;Z.length=$,$=$-1|0;var X=J.words[0]|0,U=V.words[0]|0,H=X*U,G=H&67108863,Q=H/67108864|0;Z.words[0]=G;for(var K=1;K<$;K++){for(var k=Q>>>26,L=Q&67108863,_=Math.min(K,V.length-1),t=Math.max(0,K-J.length+1);t<=_;t++){var QJ=K-t|0;X=J.words[QJ]|0,U=V.words[t]|0,H=X*U+L,k+=H/67108864|0,L=H&67108863}Z.words[K]=L|0,Q=k|0}return Q!==0?Z.words[K]=Q|0:Z.length--,Z.strip()}var F=function(J,V,Z){var $=J.words,X=V.words,U=Z.words,H=0,G,Q,K,k=$[0]|0,L=k&8191,_=k>>>13,t=$[1]|0,QJ=t&8191,GJ=t>>>13,n=$[2]|0,p=n&8191,e=n>>>13,PJ=$[3]|0,XJ=PJ&8191,WJ=PJ>>>13,b=$[4]|0,C=b&8191,h=b>>>13,$J=$[5]|0,qJ=$J&8191,ZJ=$J>>>13,mJ=$[6]|0,BJ=mJ&8191,TJ=mJ>>>13,dJ=$[7]|0,LJ=dJ&8191,IJ=dJ>>>13,$Q=$[8]|0,T=$Q&8191,D=$Q>>>13,u=$[9]|0,d=u&8191,a=u>>>13,CJ=X[0]|0,UJ=CJ&8191,EJ=CJ>>>13,QQ=X[1]|0,FJ=QQ&8191,RJ=QQ>>>13,aJ=X[2]|0,SJ=aJ&8191,xJ=aJ>>>13,nJ=X[3]|0,AJ=nJ&8191,kJ=nJ>>>13,ZQ=X[4]|0,vJ=ZQ&8191,MJ=ZQ>>>13,xQ=X[5]|0,wJ=xQ&8191,bJ=xQ>>>13,WQ=X[6]|0,_J=WQ&8191,NJ=WQ>>>13,vQ=X[7]|0,yJ=vQ&8191,gJ=vQ>>>13,MQ=X[8]|0,cJ=MQ&8191,fJ=MQ>>>13,wQ=X[9]|0,f=wQ&8191,zJ=wQ>>>13;Z.negative=J.negative^V.negative,Z.length=19,G=Math.imul(L,UJ),Q=Math.imul(L,EJ),Q=Q+Math.imul(_,UJ)|0,K=Math.imul(_,EJ);var CQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(CQ>>>26)|0,CQ&=67108863,G=Math.imul(QJ,UJ),Q=Math.imul(QJ,EJ),Q=Q+Math.imul(GJ,UJ)|0,K=Math.imul(GJ,EJ),G=G+Math.imul(L,FJ)|0,Q=Q+Math.imul(L,RJ)|0,Q=Q+Math.imul(_,FJ)|0,K=K+Math.imul(_,RJ)|0;var oJ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(oJ>>>26)|0,oJ&=67108863,G=Math.imul(p,UJ),Q=Math.imul(p,EJ),Q=Q+Math.imul(e,UJ)|0,K=Math.imul(e,EJ),G=G+Math.imul(QJ,FJ)|0,Q=Q+Math.imul(QJ,RJ)|0,Q=Q+Math.imul(GJ,FJ)|0,K=K+Math.imul(GJ,RJ)|0,G=G+Math.imul(L,SJ)|0,Q=Q+Math.imul(L,xJ)|0,Q=Q+Math.imul(_,SJ)|0,K=K+Math.imul(_,xJ)|0;var tJ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(tJ>>>26)|0,tJ&=67108863,G=Math.imul(XJ,UJ),Q=Math.imul(XJ,EJ),Q=Q+Math.imul(WJ,UJ)|0,K=Math.imul(WJ,EJ),G=G+Math.imul(p,FJ)|0,Q=Q+Math.imul(p,RJ)|0,Q=Q+Math.imul(e,FJ)|0,K=K+Math.imul(e,RJ)|0,G=G+Math.imul(QJ,SJ)|0,Q=Q+Math.imul(QJ,xJ)|0,Q=Q+Math.imul(GJ,SJ)|0,K=K+Math.imul(GJ,xJ)|0,G=G+Math.imul(L,AJ)|0,Q=Q+Math.imul(L,kJ)|0,Q=Q+Math.imul(_,AJ)|0,K=K+Math.imul(_,kJ)|0;var YQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(YQ>>>26)|0,YQ&=67108863,G=Math.imul(C,UJ),Q=Math.imul(C,EJ),Q=Q+Math.imul(h,UJ)|0,K=Math.imul(h,EJ),G=G+Math.imul(XJ,FJ)|0,Q=Q+Math.imul(XJ,RJ)|0,Q=Q+Math.imul(WJ,FJ)|0,K=K+Math.imul(WJ,RJ)|0,G=G+Math.imul(p,SJ)|0,Q=Q+Math.imul(p,xJ)|0,Q=Q+Math.imul(e,SJ)|0,K=K+Math.imul(e,xJ)|0,G=G+Math.imul(QJ,AJ)|0,Q=Q+Math.imul(QJ,kJ)|0,Q=Q+Math.imul(GJ,AJ)|0,K=K+Math.imul(GJ,kJ)|0,G=G+Math.imul(L,vJ)|0,Q=Q+Math.imul(L,MJ)|0,Q=Q+Math.imul(_,vJ)|0,K=K+Math.imul(_,MJ)|0;var BQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(BQ>>>26)|0,BQ&=67108863,G=Math.imul(qJ,UJ),Q=Math.imul(qJ,EJ),Q=Q+Math.imul(ZJ,UJ)|0,K=Math.imul(ZJ,EJ),G=G+Math.imul(C,FJ)|0,Q=Q+Math.imul(C,RJ)|0,Q=Q+Math.imul(h,FJ)|0,K=K+Math.imul(h,RJ)|0,G=G+Math.imul(XJ,SJ)|0,Q=Q+Math.imul(XJ,xJ)|0,Q=Q+Math.imul(WJ,SJ)|0,K=K+Math.imul(WJ,xJ)|0,G=G+Math.imul(p,AJ)|0,Q=Q+Math.imul(p,kJ)|0,Q=Q+Math.imul(e,AJ)|0,K=K+Math.imul(e,kJ)|0,G=G+Math.imul(QJ,vJ)|0,Q=Q+Math.imul(QJ,MJ)|0,Q=Q+Math.imul(GJ,vJ)|0,K=K+Math.imul(GJ,MJ)|0,G=G+Math.imul(L,wJ)|0,Q=Q+Math.imul(L,bJ)|0,Q=Q+Math.imul(_,wJ)|0,K=K+Math.imul(_,bJ)|0;var OQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(OQ>>>26)|0,OQ&=67108863,G=Math.imul(BJ,UJ),Q=Math.imul(BJ,EJ),Q=Q+Math.imul(TJ,UJ)|0,K=Math.imul(TJ,EJ),G=G+Math.imul(qJ,FJ)|0,Q=Q+Math.imul(qJ,RJ)|0,Q=Q+Math.imul(ZJ,FJ)|0,K=K+Math.imul(ZJ,RJ)|0,G=G+Math.imul(C,SJ)|0,Q=Q+Math.imul(C,xJ)|0,Q=Q+Math.imul(h,SJ)|0,K=K+Math.imul(h,xJ)|0,G=G+Math.imul(XJ,AJ)|0,Q=Q+Math.imul(XJ,kJ)|0,Q=Q+Math.imul(WJ,AJ)|0,K=K+Math.imul(WJ,kJ)|0,G=G+Math.imul(p,vJ)|0,Q=Q+Math.imul(p,MJ)|0,Q=Q+Math.imul(e,vJ)|0,K=K+Math.imul(e,MJ)|0,G=G+Math.imul(QJ,wJ)|0,Q=Q+Math.imul(QJ,bJ)|0,Q=Q+Math.imul(GJ,wJ)|0,K=K+Math.imul(GJ,bJ)|0,G=G+Math.imul(L,_J)|0,Q=Q+Math.imul(L,NJ)|0,Q=Q+Math.imul(_,_J)|0,K=K+Math.imul(_,NJ)|0;var jQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(jQ>>>26)|0,jQ&=67108863,G=Math.imul(LJ,UJ),Q=Math.imul(LJ,EJ),Q=Q+Math.imul(IJ,UJ)|0,K=Math.imul(IJ,EJ),G=G+Math.imul(BJ,FJ)|0,Q=Q+Math.imul(BJ,RJ)|0,Q=Q+Math.imul(TJ,FJ)|0,K=K+Math.imul(TJ,RJ)|0,G=G+Math.imul(qJ,SJ)|0,Q=Q+Math.imul(qJ,xJ)|0,Q=Q+Math.imul(ZJ,SJ)|0,K=K+Math.imul(ZJ,xJ)|0,G=G+Math.imul(C,AJ)|0,Q=Q+Math.imul(C,kJ)|0,Q=Q+Math.imul(h,AJ)|0,K=K+Math.imul(h,kJ)|0,G=G+Math.imul(XJ,vJ)|0,Q=Q+Math.imul(XJ,MJ)|0,Q=Q+Math.imul(WJ,vJ)|0,K=K+Math.imul(WJ,MJ)|0,G=G+Math.imul(p,wJ)|0,Q=Q+Math.imul(p,bJ)|0,Q=Q+Math.imul(e,wJ)|0,K=K+Math.imul(e,bJ)|0,G=G+Math.imul(QJ,_J)|0,Q=Q+Math.imul(QJ,NJ)|0,Q=Q+Math.imul(GJ,_J)|0,K=K+Math.imul(GJ,NJ)|0,G=G+Math.imul(L,yJ)|0,Q=Q+Math.imul(L,gJ)|0,Q=Q+Math.imul(_,yJ)|0,K=K+Math.imul(_,gJ)|0;var TQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(TQ>>>26)|0,TQ&=67108863,G=Math.imul(T,UJ),Q=Math.imul(T,EJ),Q=Q+Math.imul(D,UJ)|0,K=Math.imul(D,EJ),G=G+Math.imul(LJ,FJ)|0,Q=Q+Math.imul(LJ,RJ)|0,Q=Q+Math.imul(IJ,FJ)|0,K=K+Math.imul(IJ,RJ)|0,G=G+Math.imul(BJ,SJ)|0,Q=Q+Math.imul(BJ,xJ)|0,Q=Q+Math.imul(TJ,SJ)|0,K=K+Math.imul(TJ,xJ)|0,G=G+Math.imul(qJ,AJ)|0,Q=Q+Math.imul(qJ,kJ)|0,Q=Q+Math.imul(ZJ,AJ)|0,K=K+Math.imul(ZJ,kJ)|0,G=G+Math.imul(C,vJ)|0,Q=Q+Math.imul(C,MJ)|0,Q=Q+Math.imul(h,vJ)|0,K=K+Math.imul(h,MJ)|0,G=G+Math.imul(XJ,wJ)|0,Q=Q+Math.imul(XJ,bJ)|0,Q=Q+Math.imul(WJ,wJ)|0,K=K+Math.imul(WJ,bJ)|0,G=G+Math.imul(p,_J)|0,Q=Q+Math.imul(p,NJ)|0,Q=Q+Math.imul(e,_J)|0,K=K+Math.imul(e,NJ)|0,G=G+Math.imul(QJ,yJ)|0,Q=Q+Math.imul(QJ,gJ)|0,Q=Q+Math.imul(GJ,yJ)|0,K=K+Math.imul(GJ,gJ)|0,G=G+Math.imul(L,cJ)|0,Q=Q+Math.imul(L,fJ)|0,Q=Q+Math.imul(_,cJ)|0,K=K+Math.imul(_,fJ)|0;var NQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(NQ>>>26)|0,NQ&=67108863,G=Math.imul(d,UJ),Q=Math.imul(d,EJ),Q=Q+Math.imul(a,UJ)|0,K=Math.imul(a,EJ),G=G+Math.imul(T,FJ)|0,Q=Q+Math.imul(T,RJ)|0,Q=Q+Math.imul(D,FJ)|0,K=K+Math.imul(D,RJ)|0,G=G+Math.imul(LJ,SJ)|0,Q=Q+Math.imul(LJ,xJ)|0,Q=Q+Math.imul(IJ,SJ)|0,K=K+Math.imul(IJ,xJ)|0,G=G+Math.imul(BJ,AJ)|0,Q=Q+Math.imul(BJ,kJ)|0,Q=Q+Math.imul(TJ,AJ)|0,K=K+Math.imul(TJ,kJ)|0,G=G+Math.imul(qJ,vJ)|0,Q=Q+Math.imul(qJ,MJ)|0,Q=Q+Math.imul(ZJ,vJ)|0,K=K+Math.imul(ZJ,MJ)|0,G=G+Math.imul(C,wJ)|0,Q=Q+Math.imul(C,bJ)|0,Q=Q+Math.imul(h,wJ)|0,K=K+Math.imul(h,bJ)|0,G=G+Math.imul(XJ,_J)|0,Q=Q+Math.imul(XJ,NJ)|0,Q=Q+Math.imul(WJ,_J)|0,K=K+Math.imul(WJ,NJ)|0,G=G+Math.imul(p,yJ)|0,Q=Q+Math.imul(p,gJ)|0,Q=Q+Math.imul(e,yJ)|0,K=K+Math.imul(e,gJ)|0,G=G+Math.imul(QJ,cJ)|0,Q=Q+Math.imul(QJ,fJ)|0,Q=Q+Math.imul(GJ,cJ)|0,K=K+Math.imul(GJ,fJ)|0,G=G+Math.imul(L,f)|0,Q=Q+Math.imul(L,zJ)|0,Q=Q+Math.imul(_,f)|0,K=K+Math.imul(_,zJ)|0;var IQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(IQ>>>26)|0,IQ&=67108863,G=Math.imul(d,FJ),Q=Math.imul(d,RJ),Q=Q+Math.imul(a,FJ)|0,K=Math.imul(a,RJ),G=G+Math.imul(T,SJ)|0,Q=Q+Math.imul(T,xJ)|0,Q=Q+Math.imul(D,SJ)|0,K=K+Math.imul(D,xJ)|0,G=G+Math.imul(LJ,AJ)|0,Q=Q+Math.imul(LJ,kJ)|0,Q=Q+Math.imul(IJ,AJ)|0,K=K+Math.imul(IJ,kJ)|0,G=G+Math.imul(BJ,vJ)|0,Q=Q+Math.imul(BJ,MJ)|0,Q=Q+Math.imul(TJ,vJ)|0,K=K+Math.imul(TJ,MJ)|0,G=G+Math.imul(qJ,wJ)|0,Q=Q+Math.imul(qJ,bJ)|0,Q=Q+Math.imul(ZJ,wJ)|0,K=K+Math.imul(ZJ,bJ)|0,G=G+Math.imul(C,_J)|0,Q=Q+Math.imul(C,NJ)|0,Q=Q+Math.imul(h,_J)|0,K=K+Math.imul(h,NJ)|0,G=G+Math.imul(XJ,yJ)|0,Q=Q+Math.imul(XJ,gJ)|0,Q=Q+Math.imul(WJ,yJ)|0,K=K+Math.imul(WJ,gJ)|0,G=G+Math.imul(p,cJ)|0,Q=Q+Math.imul(p,fJ)|0,Q=Q+Math.imul(e,cJ)|0,K=K+Math.imul(e,fJ)|0,G=G+Math.imul(QJ,f)|0,Q=Q+Math.imul(QJ,zJ)|0,Q=Q+Math.imul(GJ,f)|0,K=K+Math.imul(GJ,zJ)|0;var EQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(EQ>>>26)|0,EQ&=67108863,G=Math.imul(d,SJ),Q=Math.imul(d,xJ),Q=Q+Math.imul(a,SJ)|0,K=Math.imul(a,xJ),G=G+Math.imul(T,AJ)|0,Q=Q+Math.imul(T,kJ)|0,Q=Q+Math.imul(D,AJ)|0,K=K+Math.imul(D,kJ)|0,G=G+Math.imul(LJ,vJ)|0,Q=Q+Math.imul(LJ,MJ)|0,Q=Q+Math.imul(IJ,vJ)|0,K=K+Math.imul(IJ,MJ)|0,G=G+Math.imul(BJ,wJ)|0,Q=Q+Math.imul(BJ,bJ)|0,Q=Q+Math.imul(TJ,wJ)|0,K=K+Math.imul(TJ,bJ)|0,G=G+Math.imul(qJ,_J)|0,Q=Q+Math.imul(qJ,NJ)|0,Q=Q+Math.imul(ZJ,_J)|0,K=K+Math.imul(ZJ,NJ)|0,G=G+Math.imul(C,yJ)|0,Q=Q+Math.imul(C,gJ)|0,Q=Q+Math.imul(h,yJ)|0,K=K+Math.imul(h,gJ)|0,G=G+Math.imul(XJ,cJ)|0,Q=Q+Math.imul(XJ,fJ)|0,Q=Q+Math.imul(WJ,cJ)|0,K=K+Math.imul(WJ,fJ)|0,G=G+Math.imul(p,f)|0,Q=Q+Math.imul(p,zJ)|0,Q=Q+Math.imul(e,f)|0,K=K+Math.imul(e,zJ)|0;var RQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(RQ>>>26)|0,RQ&=67108863,G=Math.imul(d,AJ),Q=Math.imul(d,kJ),Q=Q+Math.imul(a,AJ)|0,K=Math.imul(a,kJ),G=G+Math.imul(T,vJ)|0,Q=Q+Math.imul(T,MJ)|0,Q=Q+Math.imul(D,vJ)|0,K=K+Math.imul(D,MJ)|0,G=G+Math.imul(LJ,wJ)|0,Q=Q+Math.imul(LJ,bJ)|0,Q=Q+Math.imul(IJ,wJ)|0,K=K+Math.imul(IJ,bJ)|0,G=G+Math.imul(BJ,_J)|0,Q=Q+Math.imul(BJ,NJ)|0,Q=Q+Math.imul(TJ,_J)|0,K=K+Math.imul(TJ,NJ)|0,G=G+Math.imul(qJ,yJ)|0,Q=Q+Math.imul(qJ,gJ)|0,Q=Q+Math.imul(ZJ,yJ)|0,K=K+Math.imul(ZJ,gJ)|0,G=G+Math.imul(C,cJ)|0,Q=Q+Math.imul(C,fJ)|0,Q=Q+Math.imul(h,cJ)|0,K=K+Math.imul(h,fJ)|0,G=G+Math.imul(XJ,f)|0,Q=Q+Math.imul(XJ,zJ)|0,Q=Q+Math.imul(WJ,f)|0,K=K+Math.imul(WJ,zJ)|0;var zQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(zQ>>>26)|0,zQ&=67108863,G=Math.imul(d,vJ),Q=Math.imul(d,MJ),Q=Q+Math.imul(a,vJ)|0,K=Math.imul(a,MJ),G=G+Math.imul(T,wJ)|0,Q=Q+Math.imul(T,bJ)|0,Q=Q+Math.imul(D,wJ)|0,K=K+Math.imul(D,bJ)|0,G=G+Math.imul(LJ,_J)|0,Q=Q+Math.imul(LJ,NJ)|0,Q=Q+Math.imul(IJ,_J)|0,K=K+Math.imul(IJ,NJ)|0,G=G+Math.imul(BJ,yJ)|0,Q=Q+Math.imul(BJ,gJ)|0,Q=Q+Math.imul(TJ,yJ)|0,K=K+Math.imul(TJ,gJ)|0,G=G+Math.imul(qJ,cJ)|0,Q=Q+Math.imul(qJ,fJ)|0,Q=Q+Math.imul(ZJ,cJ)|0,K=K+Math.imul(ZJ,fJ)|0,G=G+Math.imul(C,f)|0,Q=Q+Math.imul(C,zJ)|0,Q=Q+Math.imul(h,f)|0,K=K+Math.imul(h,zJ)|0;var PQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(PQ>>>26)|0,PQ&=67108863,G=Math.imul(d,wJ),Q=Math.imul(d,bJ),Q=Q+Math.imul(a,wJ)|0,K=Math.imul(a,bJ),G=G+Math.imul(T,_J)|0,Q=Q+Math.imul(T,NJ)|0,Q=Q+Math.imul(D,_J)|0,K=K+Math.imul(D,NJ)|0,G=G+Math.imul(LJ,yJ)|0,Q=Q+Math.imul(LJ,gJ)|0,Q=Q+Math.imul(IJ,yJ)|0,K=K+Math.imul(IJ,gJ)|0,G=G+Math.imul(BJ,cJ)|0,Q=Q+Math.imul(BJ,fJ)|0,Q=Q+Math.imul(TJ,cJ)|0,K=K+Math.imul(TJ,fJ)|0,G=G+Math.imul(qJ,f)|0,Q=Q+Math.imul(qJ,zJ)|0,Q=Q+Math.imul(ZJ,f)|0,K=K+Math.imul(ZJ,zJ)|0;var LQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(LQ>>>26)|0,LQ&=67108863,G=Math.imul(d,_J),Q=Math.imul(d,NJ),Q=Q+Math.imul(a,_J)|0,K=Math.imul(a,NJ),G=G+Math.imul(T,yJ)|0,Q=Q+Math.imul(T,gJ)|0,Q=Q+Math.imul(D,yJ)|0,K=K+Math.imul(D,gJ)|0,G=G+Math.imul(LJ,cJ)|0,Q=Q+Math.imul(LJ,fJ)|0,Q=Q+Math.imul(IJ,cJ)|0,K=K+Math.imul(IJ,fJ)|0,G=G+Math.imul(BJ,f)|0,Q=Q+Math.imul(BJ,zJ)|0,Q=Q+Math.imul(TJ,f)|0,K=K+Math.imul(TJ,zJ)|0;var FQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(FQ>>>26)|0,FQ&=67108863,G=Math.imul(d,yJ),Q=Math.imul(d,gJ),Q=Q+Math.imul(a,yJ)|0,K=Math.imul(a,gJ),G=G+Math.imul(T,cJ)|0,Q=Q+Math.imul(T,fJ)|0,Q=Q+Math.imul(D,cJ)|0,K=K+Math.imul(D,fJ)|0,G=G+Math.imul(LJ,f)|0,Q=Q+Math.imul(LJ,zJ)|0,Q=Q+Math.imul(IJ,f)|0,K=K+Math.imul(IJ,zJ)|0;var HQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(HQ>>>26)|0,HQ&=67108863,G=Math.imul(d,cJ),Q=Math.imul(d,fJ),Q=Q+Math.imul(a,cJ)|0,K=Math.imul(a,fJ),G=G+Math.imul(T,f)|0,Q=Q+Math.imul(T,zJ)|0,Q=Q+Math.imul(D,f)|0,K=K+Math.imul(D,zJ)|0;var DQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(DQ>>>26)|0,DQ&=67108863,G=Math.imul(d,f),Q=Math.imul(d,zJ),Q=Q+Math.imul(a,f)|0,K=Math.imul(a,zJ);var KQ=(H+G|0)+((Q&8191)<<13)|0;return H=(K+(Q>>>13)|0)+(KQ>>>26)|0,KQ&=67108863,U[0]=CQ,U[1]=oJ,U[2]=tJ,U[3]=YQ,U[4]=BQ,U[5]=OQ,U[6]=jQ,U[7]=TQ,U[8]=NQ,U[9]=IQ,U[10]=EQ,U[11]=RQ,U[12]=zQ,U[13]=PQ,U[14]=LQ,U[15]=FQ,U[16]=HQ,U[17]=DQ,U[18]=KQ,H!==0&&(U[19]=H,Z.length++),Z};Math.imul||(F=P);function v(J,V,Z){Z.negative=V.negative^J.negative,Z.length=J.length+V.length;for(var $=0,X=0,U=0;U<Z.length-1;U++){var H=X;X=0;for(var G=$&67108863,Q=Math.min(U,V.length-1),K=Math.max(0,U-J.length+1);K<=Q;K++){var k=U-K,L=J.words[k]|0,_=V.words[K]|0,t=L*_,QJ=t&67108863;H=H+(t/67108864|0)|0,QJ=QJ+G|0,G=QJ&67108863,H=H+(QJ>>>26)|0,X+=H>>>26,H&=67108863}Z.words[U]=G,$=H,H=X}return $!==0?Z.words[U]=$:Z.length--,Z.strip()}function S(J,V,Z){var $=new w;return $.mulp(J,V,Z)}q.prototype.mulTo=function(J,V){var Z,$=this.length+J.length;return this.length===10&&J.length===10?Z=F(this,J,V):$<63?Z=P(this,J,V):$<1024?Z=v(this,J,V):Z=S(this,J,V),Z};function w(J,V){this.x=J,this.y=V}w.prototype.makeRBT=function(J){for(var V=new Array(J),Z=q.prototype._countBits(J)-1,$=0;$<J;$++)V[$]=this.revBin($,Z,J);return V},w.prototype.revBin=function(J,V,Z){if(J===0||J===Z-1)return J;for(var $=0,X=0;X<V;X++)$|=(J&1)<<V-X-1,J>>=1;return $},w.prototype.permute=function(J,V,Z,$,X,U){for(var H=0;H<U;H++)$[H]=V[J[H]],X[H]=Z[J[H]]},w.prototype.transform=function(J,V,Z,$,X,U){this.permute(U,J,V,Z,$,X);for(var H=1;H<X;H<<=1)for(var G=H<<1,Q=Math.cos(2*Math.PI/G),K=Math.sin(2*Math.PI/G),k=0;k<X;k+=G)for(var L=Q,_=K,t=0;t<H;t++){var QJ=Z[k+t],GJ=$[k+t],n=Z[k+t+H],p=$[k+t+H],e=L*n-_*p;p=L*p+_*n,n=e,Z[k+t]=QJ+n,$[k+t]=GJ+p,Z[k+t+H]=QJ-n,$[k+t+H]=GJ-p,t!==G&&(e=Q*L-K*_,_=Q*_+K*L,L=e)}},w.prototype.guessLen13b=function(J,V){var Z=Math.max(V,J)|1,$=Z&1,X=0;for(Z=Z/2|0;Z;Z=Z>>>1)X++;return 1<<X+1+$},w.prototype.conjugate=function(J,V,Z){if(!(Z<=1))for(var $=0;$<Z/2;$++){var X=J[$];J[$]=J[Z-$-1],J[Z-$-1]=X,X=V[$],V[$]=-V[Z-$-1],V[Z-$-1]=-X}},w.prototype.normalize13b=function(J,V){for(var Z=0,$=0;$<V/2;$++){var X=Math.round(J[2*$+1]/V)*8192+Math.round(J[2*$]/V)+Z;J[$]=X&67108863,X<67108864?Z=0:Z=X/67108864|0}return J},w.prototype.convert13b=function(J,V,Z,$){for(var X=0,U=0;U<V;U++)X=X+(J[U]|0),Z[2*U]=X&8191,X=X>>>13,Z[2*U+1]=X&8191,X=X>>>13;for(U=2*V;U<$;++U)Z[U]=0;B(X===0),B((X&-8192)===0)},w.prototype.stub=function(J){for(var V=new Array(J),Z=0;Z<J;Z++)V[Z]=0;return V},w.prototype.mulp=function(J,V,Z){var $=2*this.guessLen13b(J.length,V.length),X=this.makeRBT($),U=this.stub($),H=new Array($),G=new Array($),Q=new Array($),K=new Array($),k=new Array($),L=new Array($),_=Z.words;_.length=$,this.convert13b(J.words,J.length,H,$),this.convert13b(V.words,V.length,K,$),this.transform(H,U,G,Q,$,X),this.transform(K,U,k,L,$,X);for(var t=0;t<$;t++){var QJ=G[t]*k[t]-Q[t]*L[t];Q[t]=G[t]*L[t]+Q[t]*k[t],G[t]=QJ}return this.conjugate(G,Q,$),this.transform(G,Q,_,U,$,X),this.conjugate(_,U,$),this.normalize13b(_,$),Z.negative=J.negative^V.negative,Z.length=J.length+V.length,Z.strip()},q.prototype.mul=function(J){var V=new q(null);return V.words=new Array(this.length+J.length),this.mulTo(J,V)},q.prototype.mulf=function(J){var V=new q(null);return V.words=new Array(this.length+J.length),S(this,J,V)},q.prototype.imul=function(J){return this.clone().mulTo(J,this)},q.prototype.imuln=function(J){B(typeof J=="number"),B(J<67108864);for(var V=0,Z=0;Z<this.length;Z++){var $=(this.words[Z]|0)*J,X=($&67108863)+(V&67108863);V>>=26,V+=$/67108864|0,V+=X>>>26,this.words[Z]=X&67108863}return V!==0&&(this.words[Z]=V,this.length++),this},q.prototype.muln=function(J){return this.clone().imuln(J)},q.prototype.sqr=function(){return this.mul(this)},q.prototype.isqr=function(){return this.imul(this.clone())},q.prototype.pow=function(J){var V=j(J);if(V.length===0)return new q(1);for(var Z=this,$=0;$<V.length&&V[$]===0;$++,Z=Z.sqr());if(++$<V.length)for(var X=Z.sqr();$<V.length;$++,X=X.sqr())V[$]!==0&&(Z=Z.mul(X));return Z},q.prototype.iushln=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26,$=67108863>>>26-V<<26-V,X;if(V!==0){var U=0;for(X=0;X<this.length;X++){var H=this.words[X]&$,G=(this.words[X]|0)-H<<V;this.words[X]=G|U,U=H>>>26-V}U&&(this.words[X]=U,this.length++)}if(Z!==0){for(X=this.length-1;X>=0;X--)this.words[X+Z]=this.words[X];for(X=0;X<Z;X++)this.words[X]=0;this.length+=Z}return this.strip()},q.prototype.ishln=function(J){return B(this.negative===0),this.iushln(J)},q.prototype.iushrn=function(J,V,Z){B(typeof J=="number"&&J>=0);var $;V?$=(V-V%26)/26:$=0;var X=J%26,U=Math.min((J-X)/26,this.length),H=67108863^67108863>>>X<<X,G=Z;if($-=U,$=Math.max(0,$),G){for(var Q=0;Q<U;Q++)G.words[Q]=this.words[Q];G.length=U}if(U!==0)if(this.length>U)for(this.length-=U,Q=0;Q<this.length;Q++)this.words[Q]=this.words[Q+U];else this.words[0]=0,this.length=1;var K=0;for(Q=this.length-1;Q>=0&&(K!==0||Q>=$);Q--){var k=this.words[Q]|0;this.words[Q]=K<<26-X|k>>>X,K=k&H}return G&&K!==0&&(G.words[G.length++]=K),this.length===0&&(this.words[0]=0,this.length=1),this.strip()},q.prototype.ishrn=function(J,V,Z){return B(this.negative===0),this.iushrn(J,V,Z)},q.prototype.shln=function(J){return this.clone().ishln(J)},q.prototype.ushln=function(J){return this.clone().iushln(J)},q.prototype.shrn=function(J){return this.clone().ishrn(J)},q.prototype.ushrn=function(J){return this.clone().iushrn(J)},q.prototype.testn=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26,$=1<<V;if(this.length<=Z)return!1;var X=this.words[Z];return!!(X&$)},q.prototype.imaskn=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26;if(B(this.negative===0,"imaskn works only with positive numbers"),this.length<=Z)return this;if(V!==0&&Z++,this.length=Math.min(Z,this.length),V!==0){var $=67108863^67108863>>>V<<V;this.words[this.length-1]&=$}return this.strip()},q.prototype.maskn=function(J){return this.clone().imaskn(J)},q.prototype.iaddn=function(J){return B(typeof J=="number"),B(J<67108864),J<0?this.isubn(-J):this.negative!==0?this.length===1&&(this.words[0]|0)<J?(this.words[0]=J-(this.words[0]|0),this.negative=0,this):(this.negative=0,this.isubn(J),this.negative=1,this):this._iaddn(J)},q.prototype._iaddn=function(J){this.words[0]+=J;for(var V=0;V<this.length&&this.words[V]>=67108864;V++)this.words[V]-=67108864,V===this.length-1?this.words[V+1]=1:this.words[V+1]++;return this.length=Math.max(this.length,V+1),this},q.prototype.isubn=function(J){if(B(typeof J=="number"),B(J<67108864),J<0)return this.iaddn(-J);if(this.negative!==0)return this.negative=0,this.iaddn(J),this.negative=1,this;if(this.words[0]-=J,this.length===1&&this.words[0]<0)this.words[0]=-this.words[0],this.negative=1;else for(var V=0;V<this.length&&this.words[V]<0;V++)this.words[V]+=67108864,this.words[V+1]-=1;return this.strip()},q.prototype.addn=function(J){return this.clone().iaddn(J)},q.prototype.subn=function(J){return this.clone().isubn(J)},q.prototype.iabs=function(){return this.negative=0,this},q.prototype.abs=function(){return this.clone().iabs()},q.prototype._ishlnsubmul=function(J,V,Z){var $=J.length+Z,X;this._expand($);var U,H=0;for(X=0;X<J.length;X++){U=(this.words[X+Z]|0)+H;var G=(J.words[X]|0)*V;U-=G&67108863,H=(U>>26)-(G/67108864|0),this.words[X+Z]=U&67108863}for(;X<this.length-Z;X++)U=(this.words[X+Z]|0)+H,H=U>>26,this.words[X+Z]=U&67108863;if(H===0)return this.strip();for(B(H===-1),H=0,X=0;X<this.length;X++)U=-(this.words[X]|0)+H,H=U>>26,this.words[X]=U&67108863;return this.negative=1,this.strip()},q.prototype._wordDiv=function(J,V){var Z=this.length-J.length,$=this.clone(),X=J,U=X.words[X.length-1]|0,H=this._countBits(U);Z=26-H,Z!==0&&(X=X.ushln(Z),$.iushln(Z),U=X.words[X.length-1]|0);var G=$.length-X.length,Q;if(V!=="mod"){Q=new q(null),Q.length=G+1,Q.words=new Array(Q.length);for(var K=0;K<Q.length;K++)Q.words[K]=0}var k=$.clone()._ishlnsubmul(X,1,G);k.negative===0&&($=k,Q&&(Q.words[G]=1));for(var L=G-1;L>=0;L--){var _=($.words[X.length+L]|0)*67108864+($.words[X.length+L-1]|0);for(_=Math.min(_/U|0,67108863),$._ishlnsubmul(X,_,L);$.negative!==0;)_--,$.negative=0,$._ishlnsubmul(X,1,L),$.isZero()||($.negative^=1);Q&&(Q.words[L]=_)}return Q&&Q.strip(),$.strip(),V!=="div"&&Z!==0&&$.iushrn(Z),{div:Q||null,mod:$}},q.prototype.divmod=function(J,V,Z){if(B(!J.isZero()),this.isZero())return{div:new q(0),mod:new q(0)};var $,X,U;return this.negative!==0&&J.negative===0?(U=this.neg().divmod(J,V),V!=="mod"&&($=U.div.neg()),V!=="div"&&(X=U.mod.neg(),Z&&X.negative!==0&&X.iadd(J)),{div:$,mod:X}):this.negative===0&&J.negative!==0?(U=this.divmod(J.neg(),V),V!=="mod"&&($=U.div.neg()),{div:$,mod:U.mod}):(this.negative&J.negative)!==0?(U=this.neg().divmod(J.neg(),V),V!=="div"&&(X=U.mod.neg(),Z&&X.negative!==0&&X.isub(J)),{div:U.div,mod:X}):J.length>this.length||this.cmp(J)<0?{div:new q(0),mod:this}:J.length===1?V==="div"?{div:this.divn(J.words[0]),mod:null}:V==="mod"?{div:null,mod:new q(this.modn(J.words[0]))}:{div:this.divn(J.words[0]),mod:new q(this.modn(J.words[0]))}:this._wordDiv(J,V)},q.prototype.div=function(J){return this.divmod(J,"div",!1).div},q.prototype.mod=function(J){return this.divmod(J,"mod",!1).mod},q.prototype.umod=function(J){return this.divmod(J,"mod",!0).mod},q.prototype.divRound=function(J){var V=this.divmod(J);if(V.mod.isZero())return V.div;var Z=V.div.negative!==0?V.mod.isub(J):V.mod,$=J.ushrn(1),X=J.andln(1),U=Z.cmp($);return U<0||X===1&&U===0?V.div:V.div.negative!==0?V.div.isubn(1):V.div.iaddn(1)},q.prototype.modn=function(J){B(J<=67108863);for(var V=(1<<26)%J,Z=0,$=this.length-1;$>=0;$--)Z=(V*Z+(this.words[$]|0))%J;return Z},q.prototype.idivn=function(J){B(J<=67108863);for(var V=0,Z=this.length-1;Z>=0;Z--){var $=(this.words[Z]|0)+V*67108864;this.words[Z]=$/J|0,V=$%J}return this.strip()},q.prototype.divn=function(J){return this.clone().idivn(J)},q.prototype.egcd=function(J){B(J.negative===0),B(!J.isZero());var V=this,Z=J.clone();V.negative!==0?V=V.umod(J):V=V.clone();for(var $=new q(1),X=new q(0),U=new q(0),H=new q(1),G=0;V.isEven()&&Z.isEven();)V.iushrn(1),Z.iushrn(1),++G;for(var Q=Z.clone(),K=V.clone();!V.isZero();){for(var k=0,L=1;(V.words[0]&L)===0&&k<26;++k,L<<=1);if(k>0)for(V.iushrn(k);k-- >0;)($.isOdd()||X.isOdd())&&($.iadd(Q),X.isub(K)),$.iushrn(1),X.iushrn(1);for(var _=0,t=1;(Z.words[0]&t)===0&&_<26;++_,t<<=1);if(_>0)for(Z.iushrn(_);_-- >0;)(U.isOdd()||H.isOdd())&&(U.iadd(Q),H.isub(K)),U.iushrn(1),H.iushrn(1);V.cmp(Z)>=0?(V.isub(Z),$.isub(U),X.isub(H)):(Z.isub(V),U.isub($),H.isub(X))}return{a:U,b:H,gcd:Z.iushln(G)}},q.prototype._invmp=function(J){B(J.negative===0),B(!J.isZero());var V=this,Z=J.clone();V.negative!==0?V=V.umod(J):V=V.clone();for(var $=new q(1),X=new q(0),U=Z.clone();V.cmpn(1)>0&&Z.cmpn(1)>0;){for(var H=0,G=1;(V.words[0]&G)===0&&H<26;++H,G<<=1);if(H>0)for(V.iushrn(H);H-- >0;)$.isOdd()&&$.iadd(U),$.iushrn(1);for(var Q=0,K=1;(Z.words[0]&K)===0&&Q<26;++Q,K<<=1);if(Q>0)for(Z.iushrn(Q);Q-- >0;)X.isOdd()&&X.iadd(U),X.iushrn(1);V.cmp(Z)>=0?(V.isub(Z),$.isub(X)):(Z.isub(V),X.isub($))}var k;return V.cmpn(1)===0?k=$:k=X,k.cmpn(0)<0&&k.iadd(J),k},q.prototype.gcd=function(J){if(this.isZero())return J.abs();if(J.isZero())return this.abs();var V=this.clone(),Z=J.clone();V.negative=0,Z.negative=0;for(var $=0;V.isEven()&&Z.isEven();$++)V.iushrn(1),Z.iushrn(1);do{for(;V.isEven();)V.iushrn(1);for(;Z.isEven();)Z.iushrn(1);var X=V.cmp(Z);if(X<0){var U=V;V=Z,Z=U}else if(X===0||Z.cmpn(1)===0)break;V.isub(Z)}while(!0);return Z.iushln($)},q.prototype.invm=function(J){return this.egcd(J).a.umod(J)},q.prototype.isEven=function(){return(this.words[0]&1)===0},q.prototype.isOdd=function(){return(this.words[0]&1)===1},q.prototype.andln=function(J){return this.words[0]&J},q.prototype.bincn=function(J){B(typeof J=="number");var V=J%26,Z=(J-V)/26,$=1<<V;if(this.length<=Z)return this._expand(Z+1),this.words[Z]|=$,this;for(var X=$,U=Z;X!==0&&U<this.length;U++){var H=this.words[U]|0;H+=X,X=H>>>26,H&=67108863,this.words[U]=H}return X!==0&&(this.words[U]=X,this.length++),this},q.prototype.isZero=function(){return this.length===1&&this.words[0]===0},q.prototype.cmpn=function(J){var V=J<0;if(this.negative!==0&&!V)return-1;if(this.negative===0&&V)return 1;this.strip();var Z;if(this.length>1)Z=1;else{V&&(J=-J),B(J<=67108863,"Number is too big");var $=this.words[0]|0;Z=$===J?0:$<J?-1:1}return this.negative!==0?-Z|0:Z},q.prototype.cmp=function(J){if(this.negative!==0&&J.negative===0)return-1;if(this.negative===0&&J.negative!==0)return 1;var V=this.ucmp(J);return this.negative!==0?-V|0:V},q.prototype.ucmp=function(J){if(this.length>J.length)return 1;if(this.length<J.length)return-1;for(var V=0,Z=this.length-1;Z>=0;Z--){var $=this.words[Z]|0,X=J.words[Z]|0;if($!==X){$<X?V=-1:$>X&&(V=1);break}}return V},q.prototype.gtn=function(J){return this.cmpn(J)===1},q.prototype.gt=function(J){return this.cmp(J)===1},q.prototype.gten=function(J){return this.cmpn(J)>=0},q.prototype.gte=function(J){return this.cmp(J)>=0},q.prototype.ltn=function(J){return this.cmpn(J)===-1},q.prototype.lt=function(J){return this.cmp(J)===-1},q.prototype.lten=function(J){return this.cmpn(J)<=0},q.prototype.lte=function(J){return this.cmp(J)<=0},q.prototype.eqn=function(J){return this.cmpn(J)===0},q.prototype.eq=function(J){return this.cmp(J)===0},q.red=function(J){return new o(J)},q.prototype.toRed=function(J){return B(!this.red,"Already a number in reduction context"),B(this.negative===0,"red works only with positives"),J.convertTo(this)._forceRed(J)},q.prototype.fromRed=function(){return B(this.red,"fromRed works only with numbers in reduction context"),this.red.convertFrom(this)},q.prototype._forceRed=function(J){return this.red=J,this},q.prototype.forceRed=function(J){return B(!this.red,"Already a number in reduction context"),this._forceRed(J)},q.prototype.redAdd=function(J){return B(this.red,"redAdd works only with red numbers"),this.red.add(this,J)},q.prototype.redIAdd=function(J){return B(this.red,"redIAdd works only with red numbers"),this.red.iadd(this,J)},q.prototype.redSub=function(J){return B(this.red,"redSub works only with red numbers"),this.red.sub(this,J)},q.prototype.redISub=function(J){return B(this.red,"redISub works only with red numbers"),this.red.isub(this,J)},q.prototype.redShl=function(J){return B(this.red,"redShl works only with red numbers"),this.red.shl(this,J)},q.prototype.redMul=function(J){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,J),this.red.mul(this,J)},q.prototype.redIMul=function(J){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,J),this.red.imul(this,J)},q.prototype.redSqr=function(){return B(this.red,"redSqr works only with red numbers"),this.red._verify1(this),this.red.sqr(this)},q.prototype.redISqr=function(){return B(this.red,"redISqr works only with red numbers"),this.red._verify1(this),this.red.isqr(this)},q.prototype.redSqrt=function(){return B(this.red,"redSqrt works only with red numbers"),this.red._verify1(this),this.red.sqrt(this)},q.prototype.redInvm=function(){return B(this.red,"redInvm works only with red numbers"),this.red._verify1(this),this.red.invm(this)},q.prototype.redNeg=function(){return B(this.red,"redNeg works only with red numbers"),this.red._verify1(this),this.red.neg(this)},q.prototype.redPow=function(J){return B(this.red&&!J.red,"redPow(normalNum)"),this.red._verify1(this),this.red.pow(this,J)};var y={k256:null,p224:null,p192:null,p25519:null};function m(J,V){this.name=J,this.p=new q(V,16),this.n=this.p.bitLength(),this.k=new q(1).iushln(this.n).isub(this.p),this.tmp=this._tmp()}m.prototype._tmp=function(){var J=new q(null);return J.words=new Array(Math.ceil(this.n/13)),J},m.prototype.ireduce=function(J){var V=J,Z;do this.split(V,this.tmp),V=this.imulK(V),V=V.iadd(this.tmp),Z=V.bitLength();while(Z>this.n);var $=Z<this.n?-1:V.ucmp(this.p);return $===0?(V.words[0]=0,V.length=1):$>0?V.isub(this.p):V.strip!==void 0?V.strip():V._strip(),V},m.prototype.split=function(J,V){J.iushrn(this.n,0,V)},m.prototype.imulK=function(J){return J.imul(this.k)};function i(){m.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}A(i,m),i.prototype.split=function(J,V){for(var Z=4194303,$=Math.min(J.length,9),X=0;X<$;X++)V.words[X]=J.words[X];if(V.length=$,J.length<=9){J.words[0]=0,J.length=1;return}var U=J.words[9];for(V.words[V.length++]=U&Z,X=10;X<J.length;X++){var H=J.words[X]|0;J.words[X-10]=(H&Z)<<4|U>>>22,U=H}U>>>=22,J.words[X-10]=U,U===0&&J.length>10?J.length-=10:J.length-=9},i.prototype.imulK=function(J){J.words[J.length]=0,J.words[J.length+1]=0,J.length+=2;for(var V=0,Z=0;Z<J.length;Z++){var $=J.words[Z]|0;V+=$*977,J.words[Z]=V&67108863,V=$*64+(V/67108864|0)}return J.words[J.length-1]===0&&(J.length--,J.words[J.length-1]===0&&J.length--),J};function JJ(){m.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}A(JJ,m);function VJ(){m.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}A(VJ,m);function HJ(){m.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}A(HJ,m),HJ.prototype.imulK=function(J){for(var V=0,Z=0;Z<J.length;Z++){var $=(J.words[Z]|0)*19+V,X=$&67108863;$>>>=26,J.words[Z]=X,V=$}return V!==0&&(J.words[J.length++]=V),J},q._prime=function(J){if(y[J])return y[J];var V;if(J==="k256")V=new i;else if(J==="p224")V=new JJ;else if(J==="p192")V=new VJ;else if(J==="p25519")V=new HJ;else throw new Error("Unknown prime "+J);return y[J]=V,V};function o(J){if(typeof J=="string"){var V=q._prime(J);this.m=V.p,this.prime=V}else B(J.gtn(1),"modulus must be greater than 1"),this.m=J,this.prime=null}o.prototype._verify1=function(J){B(J.negative===0,"red works only with positives"),B(J.red,"red works only with red numbers")},o.prototype._verify2=function(J,V){B((J.negative|V.negative)===0,"red works only with positives"),B(J.red&&J.red===V.red,"red works only with red numbers")},o.prototype.imod=function(J){return this.prime?this.prime.ireduce(J)._forceRed(this):J.umod(this.m)._forceRed(this)},o.prototype.neg=function(J){return J.isZero()?J.clone():this.m.sub(J)._forceRed(this)},o.prototype.add=function(J,V){this._verify2(J,V);var Z=J.add(V);return Z.cmp(this.m)>=0&&Z.isub(this.m),Z._forceRed(this)},o.prototype.iadd=function(J,V){this._verify2(J,V);var Z=J.iadd(V);return Z.cmp(this.m)>=0&&Z.isub(this.m),Z},o.prototype.sub=function(J,V){this._verify2(J,V);var Z=J.sub(V);return Z.cmpn(0)<0&&Z.iadd(this.m),Z._forceRed(this)},o.prototype.isub=function(J,V){this._verify2(J,V);var Z=J.isub(V);return Z.cmpn(0)<0&&Z.iadd(this.m),Z},o.prototype.shl=function(J,V){return this._verify1(J),this.imod(J.ushln(V))},o.prototype.imul=function(J,V){return this._verify2(J,V),this.imod(J.imul(V))},o.prototype.mul=function(J,V){return this._verify2(J,V),this.imod(J.mul(V))},o.prototype.isqr=function(J){return this.imul(J,J.clone())},o.prototype.sqr=function(J){return this.mul(J,J)},o.prototype.sqrt=function(J){if(J.isZero())return J.clone();var V=this.m.andln(3);if(B(V%2===1),V===3){var Z=this.m.add(new q(1)).iushrn(2);return this.pow(J,Z)}for(var $=this.m.subn(1),X=0;!$.isZero()&&$.andln(1)===0;)X++,$.iushrn(1);B(!$.isZero());var U=new q(1).toRed(this),H=U.redNeg(),G=this.m.subn(1).iushrn(1),Q=this.m.bitLength();for(Q=new q(2*Q*Q).toRed(this);this.pow(Q,G).cmp(H)!==0;)Q.redIAdd(H);for(var K=this.pow(Q,$),k=this.pow(J,$.addn(1).iushrn(1)),L=this.pow(J,$),_=X;L.cmp(U)!==0;){for(var t=L,QJ=0;t.cmp(U)!==0;QJ++)t=t.redSqr();B(QJ<_);var GJ=this.pow(K,new q(1).iushln(_-QJ-1));k=k.redMul(GJ),K=GJ.redSqr(),L=L.redMul(K),_=QJ}return k},o.prototype.invm=function(J){var V=J._invmp(this.m);return V.negative!==0?(V.negative=0,this.imod(V).redNeg()):this.imod(V)},o.prototype.pow=function(J,V){if(V.isZero())return new q(1).toRed(this);if(V.cmpn(1)===0)return J.clone();var Z=4,$=new Array(1<<Z);$[0]=new q(1).toRed(this),$[1]=J;for(var X=2;X<$.length;X++)$[X]=this.mul($[X-1],J);var U=$[0],H=0,G=0,Q=V.bitLength()%26;for(Q===0&&(Q=26),X=V.length-1;X>=0;X--){for(var K=V.words[X],k=Q-1;k>=0;k--){var L=K>>k&1;if(U!==$[0]&&(U=this.sqr(U)),L===0&&H===0){G=0;continue}H<<=1,H|=L,G++,!(G!==Z&&(X!==0||k!==0))&&(U=this.mul(U,$[H]),G=0,H=0)}Q=26}return U},o.prototype.convertTo=function(J){var V=J.umod(this.m);return V===J?V.clone():V},o.prototype.convertFrom=function(J){var V=J.clone();return V.red=null,V},q.mont=function(J){return new jJ(J)};function jJ(J){o.call(this,J),this.shift=this.m.bitLength(),this.shift%26!==0&&(this.shift+=26-this.shift%26),this.r=new q(1).iushln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv=this.minv.umod(this.r),this.minv=this.r.sub(this.minv)}A(jJ,o),jJ.prototype.convertTo=function(J){return this.imod(J.ushln(this.shift))},jJ.prototype.convertFrom=function(J){var V=this.imod(J.mul(this.rinv));return V.red=null,V},jJ.prototype.imul=function(J,V){if(J.isZero()||V.isZero())return J.words[0]=0,J.length=1,J;var Z=J.imul(V),$=Z.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),X=Z.isub($).iushrn(this.shift),U=X;return X.cmp(this.m)>=0?U=X.isub(this.m):X.cmpn(0)<0&&(U=X.iadd(this.m)),U._forceRed(this)},jJ.prototype.mul=function(J,V){if(J.isZero()||V.isZero())return new q(0)._forceRed(this);var Z=J.mul(V),$=Z.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),X=Z.isub($).iushrn(this.shift),U=X;return X.cmp(this.m)>=0?U=X.isub(this.m):X.cmpn(0)<0&&(U=X.iadd(this.m)),U._forceRed(this)},jJ.prototype.invm=function(J){var V=this.imod(J._invmp(this.m).mul(this.r2));return V._forceRed(this)}})(typeof g>"u"||g,l)}),D$=OJ((l,g)=>{var R=q0(),M=F$();g.exports=function(Y){return new A(Y)};var B={secp256k1:{name:"secp256k1",byteLength:32},secp224r1:{name:"p224",byteLength:28},prime256v1:{name:"p256",byteLength:32},prime192v1:{name:"p192",byteLength:24},ed25519:{name:"ed25519",byteLength:32},secp384r1:{name:"p384",byteLength:48},secp521r1:{name:"p521",byteLength:66}};B.p224=B.secp224r1,B.p256=B.secp256r1=B.prime256v1,B.p192=B.secp192r1=B.prime192v1,B.p384=B.secp384r1,B.p521=B.secp521r1;function A(Y){this.curveType=B[Y],this.curveType||(this.curveType={name:Y}),this.curve=new R.ec(this.curveType.name),this.keys=void 0}A.prototype.generateKeys=function(Y,E){return this.keys=this.curve.genKeyPair(),this.getPublicKey(Y,E)},A.prototype.computeSecret=function(Y,E,O){E=E||"utf8",Buffer.isBuffer(Y)||(Y=new Buffer(Y,E));var N=this.curve.keyFromPublic(Y).getPublic(),W=N.mul(this.keys.getPrivate()).getX();return q(W,O,this.curveType.byteLength)},A.prototype.getPublicKey=function(Y,E){var O=this.keys.getPublic(E==="compressed",!0);return E==="hybrid"&&(O[O.length-1]%2?O[0]=7:O[0]=6),q(O,Y)},A.prototype.getPrivateKey=function(Y){return q(this.keys.getPrivate(),Y)},A.prototype.setPublicKey=function(Y,E){return E=E||"utf8",Buffer.isBuffer(Y)||(Y=new Buffer(Y,E)),this.keys._importPublic(Y),this},A.prototype.setPrivateKey=function(Y,E){E=E||"utf8",Buffer.isBuffer(Y)||(Y=new Buffer(Y,E));var O=new M(Y);return O=O.toString(16),this.keys=this.curve.genKeyPair(),this.keys._importPrivate(O),this};function q(Y,E,O){Array.isArray(Y)||(Y=Y.toArray());var N=new Buffer(Y);if(O&&N.length<O){var W=new Buffer(O-N.length);W.fill(0),N=Buffer.concat([W,N])}return E?N.toString(E):N}}),R6=OJ((l,g)=>{var R=WV(),M=XQ().Buffer;g.exports=function(A,q){for(var Y=M.alloc(0),E=0,O;Y.length<q;)O=B(E++),Y=M.concat([Y,R("sha1").update(A).update(O).digest()]);return Y.slice(0,q)};function B(A){var q=M.allocUnsafe(4);return q.writeUInt32BE(A,0),q}}),z6=OJ((l,g)=>{g.exports=function(R,M){for(var B=R.length,A=-1;++A<B;)R[A]^=M[A];return R}}),W0=OJ((l,g)=>{(function(R,M){function B(J,V){if(!J)throw new Error(V||"Assertion failed")}function A(J,V){J.super_=V;var Z=function(){};Z.prototype=V.prototype,J.prototype=new Z,J.prototype.constructor=J}function q(J,V,Z){if(q.isBN(J))return J;this.negative=0,this.words=null,this.length=0,this.red=null,J!==null&&((V==="le"||V==="be")&&(Z=V,V=10),this._init(J||0,V||10,Z||"be"))}typeof R=="object"?R.exports=q:M.BN=q,q.BN=q,q.wordSize=26;var Y;try{typeof window<"u"&&typeof window.Buffer<"u"?Y=window.Buffer:Y=JV().Buffer}catch{}q.isBN=function(J){return J instanceof q?!0:J!==null&&typeof J=="object"&&J.constructor.wordSize===q.wordSize&&Array.isArray(J.words)},q.max=function(J,V){return J.cmp(V)>0?J:V},q.min=function(J,V){return J.cmp(V)<0?J:V},q.prototype._init=function(J,V,Z){if(typeof J=="number")return this._initNumber(J,V,Z);if(typeof J=="object")return this._initArray(J,V,Z);V==="hex"&&(V=16),B(V===(V|0)&&V>=2&&V<=36),J=J.toString().replace(/\s+/g,"");var $=0;J[0]==="-"&&($++,this.negative=1),$<J.length&&(V===16?this._parseHex(J,$,Z):(this._parseBase(J,V,$),Z==="le"&&this._initArray(this.toArray(),V,Z)))},q.prototype._initNumber=function(J,V,Z){J<0&&(this.negative=1,J=-J),J<67108864?(this.words=[J&67108863],this.length=1):J<4503599627370496?(this.words=[J&67108863,J/67108864&67108863],this.length=2):(B(J<9007199254740992),this.words=[J&67108863,J/67108864&67108863,1],this.length=3),Z==="le"&&this._initArray(this.toArray(),V,Z)},q.prototype._initArray=function(J,V,Z){if(B(typeof J.length=="number"),J.length<=0)return this.words=[0],this.length=1,this;this.length=Math.ceil(J.length/3),this.words=new Array(this.length);for(var $=0;$<this.length;$++)this.words[$]=0;var X,U,H=0;if(Z==="be")for($=J.length-1,X=0;$>=0;$-=3)U=J[$]|J[$-1]<<8|J[$-2]<<16,this.words[X]|=U<<H&67108863,this.words[X+1]=U>>>26-H&67108863,H+=24,H>=26&&(H-=26,X++);else if(Z==="le")for($=0,X=0;$<J.length;$+=3)U=J[$]|J[$+1]<<8|J[$+2]<<16,this.words[X]|=U<<H&67108863,this.words[X+1]=U>>>26-H&67108863,H+=24,H>=26&&(H-=26,X++);return this.strip()};function E(J,V){var Z=J.charCodeAt(V);return Z>=65&&Z<=70?Z-55:Z>=97&&Z<=102?Z-87:Z-48&15}function O(J,V,Z){var $=E(J,Z);return Z-1>=V&&($|=E(J,Z-1)<<4),$}q.prototype._parseHex=function(J,V,Z){this.length=Math.ceil((J.length-V)/6),this.words=new Array(this.length);for(var $=0;$<this.length;$++)this.words[$]=0;var X=0,U=0,H;if(Z==="be")for($=J.length-1;$>=V;$-=2)H=O(J,V,$)<<X,this.words[U]|=H&67108863,X>=18?(X-=18,U+=1,this.words[U]|=H>>>26):X+=8;else{var G=J.length-V;for($=G%2===0?V+1:V;$<J.length;$+=2)H=O(J,V,$)<<X,this.words[U]|=H&67108863,X>=18?(X-=18,U+=1,this.words[U]|=H>>>26):X+=8}this.strip()};function N(J,V,Z,$){for(var X=0,U=Math.min(J.length,Z),H=V;H<U;H++){var G=J.charCodeAt(H)-48;X*=$,G>=49?X+=G-49+10:G>=17?X+=G-17+10:X+=G}return X}q.prototype._parseBase=function(J,V,Z){this.words=[0],this.length=1;for(var $=0,X=1;X<=67108863;X*=V)$++;$--,X=X/V|0;for(var U=J.length-Z,H=U%$,G=Math.min(U,U-H)+Z,Q=0,K=Z;K<G;K+=$)Q=N(J,K,K+$,V),this.imuln(X),this.words[0]+Q<67108864?this.words[0]+=Q:this._iaddn(Q);if(H!==0){var k=1;for(Q=N(J,K,J.length,V),K=0;K<H;K++)k*=V;this.imuln(k),this.words[0]+Q<67108864?this.words[0]+=Q:this._iaddn(Q)}this.strip()},q.prototype.copy=function(J){J.words=new Array(this.length);for(var V=0;V<this.length;V++)J.words[V]=this.words[V];J.length=this.length,J.negative=this.negative,J.red=this.red},q.prototype.clone=function(){var J=new q(null);return this.copy(J),J},q.prototype._expand=function(J){for(;this.length<J;)this.words[this.length++]=0;return this},q.prototype.strip=function(){for(;this.length>1&&this.words[this.length-1]===0;)this.length--;return this._normSign()},q.prototype._normSign=function(){return this.length===1&&this.words[0]===0&&(this.negative=0),this},q.prototype.inspect=function(){return(this.red?"<BN-R: ":"<BN: ")+this.toString(16)+">"};var W=["","0","00","000","0000","00000","000000","0000000","00000000","000000000","0000000000","00000000000","000000000000","0000000000000","00000000000000","000000000000000","0000000000000000","00000000000000000","000000000000000000","0000000000000000000","00000000000000000000","000000000000000000000","0000000000000000000000","00000000000000000000000","000000000000000000000000","0000000000000000000000000"],I=[0,0,25,16,12,11,10,9,8,8,7,7,7,7,6,6,6,6,6,6,6,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5],z=[0,0,33554432,43046721,16777216,48828125,60466176,40353607,16777216,43046721,1e7,19487171,35831808,62748517,7529536,11390625,16777216,24137569,34012224,47045881,64000000,4084101,5153632,6436343,7962624,9765625,11881376,14348907,17210368,20511149,24300000,28629151,33554432,39135393,45435424,52521875,60466176];q.prototype.toString=function(J,V){J=J||10,V=V|0||1;var Z;if(J===16||J==="hex"){Z="";for(var $=0,X=0,U=0;U<this.length;U++){var H=this.words[U],G=((H<<$|X)&16777215).toString(16);X=H>>>24-$&16777215,X!==0||U!==this.length-1?Z=W[6-G.length]+G+Z:Z=G+Z,$+=2,$>=26&&($-=26,U--)}for(X!==0&&(Z=X.toString(16)+Z);Z.length%V!==0;)Z="0"+Z;return this.negative!==0&&(Z="-"+Z),Z}if(J===(J|0)&&J>=2&&J<=36){var Q=I[J],K=z[J];Z="";var k=this.clone();for(k.negative=0;!k.isZero();){var L=k.modn(K).toString(J);k=k.idivn(K),k.isZero()?Z=L+Z:Z=W[Q-L.length]+L+Z}for(this.isZero()&&(Z="0"+Z);Z.length%V!==0;)Z="0"+Z;return this.negative!==0&&(Z="-"+Z),Z}B(!1,"Base should be between 2 and 36")},q.prototype.toNumber=function(){var J=this.words[0];return this.length===2?J+=this.words[1]*67108864:this.length===3&&this.words[2]===1?J+=4503599627370496+this.words[1]*67108864:this.length>2&&B(!1,"Number can only safely store up to 53 bits"),this.negative!==0?-J:J},q.prototype.toJSON=function(){return this.toString(16)},q.prototype.toBuffer=function(J,V){return B(typeof Y<"u"),this.toArrayLike(Y,J,V)},q.prototype.toArray=function(J,V){return this.toArrayLike(Array,J,V)},q.prototype.toArrayLike=function(J,V,Z){var $=this.byteLength(),X=Z||Math.max(1,$);B($<=X,"byte array longer than desired length"),B(X>0,"Requested array length <= 0"),this.strip();var U=V==="le",H=new J(X),G,Q,K=this.clone();if(U){for(Q=0;!K.isZero();Q++)G=K.andln(255),K.iushrn(8),H[Q]=G;for(;Q<X;Q++)H[Q]=0}else{for(Q=0;Q<X-$;Q++)H[Q]=0;for(Q=0;!K.isZero();Q++)G=K.andln(255),K.iushrn(8),H[X-Q-1]=G}return H},Math.clz32?q.prototype._countBits=function(J){return 32-Math.clz32(J)}:q.prototype._countBits=function(J){var V=J,Z=0;return V>=4096&&(Z+=13,V>>>=13),V>=64&&(Z+=7,V>>>=7),V>=8&&(Z+=4,V>>>=4),V>=2&&(Z+=2,V>>>=2),Z+V},q.prototype._zeroBits=function(J){if(J===0)return 26;var V=J,Z=0;return(V&8191)===0&&(Z+=13,V>>>=13),(V&127)===0&&(Z+=7,V>>>=7),(V&15)===0&&(Z+=4,V>>>=4),(V&3)===0&&(Z+=2,V>>>=2),(V&1)===0&&Z++,Z},q.prototype.bitLength=function(){var J=this.words[this.length-1],V=this._countBits(J);return(this.length-1)*26+V};function j(J){for(var V=new Array(J.bitLength()),Z=0;Z<V.length;Z++){var $=Z/26|0,X=Z%26;V[Z]=(J.words[$]&1<<X)>>>X}return V}q.prototype.zeroBits=function(){if(this.isZero())return 0;for(var J=0,V=0;V<this.length;V++){var Z=this._zeroBits(this.words[V]);if(J+=Z,Z!==26)break}return J},q.prototype.byteLength=function(){return Math.ceil(this.bitLength()/8)},q.prototype.toTwos=function(J){return this.negative!==0?this.abs().inotn(J).iaddn(1):this.clone()},q.prototype.fromTwos=function(J){return this.testn(J-1)?this.notn(J).iaddn(1).ineg():this.clone()},q.prototype.isNeg=function(){return this.negative!==0},q.prototype.neg=function(){return this.clone().ineg()},q.prototype.ineg=function(){return this.isZero()||(this.negative^=1),this},q.prototype.iuor=function(J){for(;this.length<J.length;)this.words[this.length++]=0;for(var V=0;V<J.length;V++)this.words[V]=this.words[V]|J.words[V];return this.strip()},q.prototype.ior=function(J){return B((this.negative|J.negative)===0),this.iuor(J)},q.prototype.or=function(J){return this.length>J.length?this.clone().ior(J):J.clone().ior(this)},q.prototype.uor=function(J){return this.length>J.length?this.clone().iuor(J):J.clone().iuor(this)},q.prototype.iuand=function(J){var V;this.length>J.length?V=J:V=this;for(var Z=0;Z<V.length;Z++)this.words[Z]=this.words[Z]&J.words[Z];return this.length=V.length,this.strip()},q.prototype.iand=function(J){return B((this.negative|J.negative)===0),this.iuand(J)},q.prototype.and=function(J){return this.length>J.length?this.clone().iand(J):J.clone().iand(this)},q.prototype.uand=function(J){return this.length>J.length?this.clone().iuand(J):J.clone().iuand(this)},q.prototype.iuxor=function(J){var V,Z;this.length>J.length?(V=this,Z=J):(V=J,Z=this);for(var $=0;$<Z.length;$++)this.words[$]=V.words[$]^Z.words[$];if(this!==V)for(;$<V.length;$++)this.words[$]=V.words[$];return this.length=V.length,this.strip()},q.prototype.ixor=function(J){return B((this.negative|J.negative)===0),this.iuxor(J)},q.prototype.xor=function(J){return this.length>J.length?this.clone().ixor(J):J.clone().ixor(this)},q.prototype.uxor=function(J){return this.length>J.length?this.clone().iuxor(J):J.clone().iuxor(this)},q.prototype.inotn=function(J){B(typeof J=="number"&&J>=0);var V=Math.ceil(J/26)|0,Z=J%26;this._expand(V),Z>0&&V--;for(var $=0;$<V;$++)this.words[$]=~this.words[$]&67108863;return Z>0&&(this.words[$]=~this.words[$]&67108863>>26-Z),this.strip()},q.prototype.notn=function(J){return this.clone().inotn(J)},q.prototype.setn=function(J,V){B(typeof J=="number"&&J>=0);var Z=J/26|0,$=J%26;return this._expand(Z+1),V?this.words[Z]=this.words[Z]|1<<$:this.words[Z]=this.words[Z]&~(1<<$),this.strip()},q.prototype.iadd=function(J){var V;if(this.negative!==0&&J.negative===0)return this.negative=0,V=this.isub(J),this.negative^=1,this._normSign();if(this.negative===0&&J.negative!==0)return J.negative=0,V=this.isub(J),J.negative=1,V._normSign();var Z,$;this.length>J.length?(Z=this,$=J):(Z=J,$=this);for(var X=0,U=0;U<$.length;U++)V=(Z.words[U]|0)+($.words[U]|0)+X,this.words[U]=V&67108863,X=V>>>26;for(;X!==0&&U<Z.length;U++)V=(Z.words[U]|0)+X,this.words[U]=V&67108863,X=V>>>26;if(this.length=Z.length,X!==0)this.words[this.length]=X,this.length++;else if(Z!==this)for(;U<Z.length;U++)this.words[U]=Z.words[U];return this},q.prototype.add=function(J){var V;return J.negative!==0&&this.negative===0?(J.negative=0,V=this.sub(J),J.negative^=1,V):J.negative===0&&this.negative!==0?(this.negative=0,V=J.sub(this),this.negative=1,V):this.length>J.length?this.clone().iadd(J):J.clone().iadd(this)},q.prototype.isub=function(J){if(J.negative!==0){J.negative=0;var V=this.iadd(J);return J.negative=1,V._normSign()}else if(this.negative!==0)return this.negative=0,this.iadd(J),this.negative=1,this._normSign();var Z=this.cmp(J);if(Z===0)return this.negative=0,this.length=1,this.words[0]=0,this;var $,X;Z>0?($=this,X=J):($=J,X=this);for(var U=0,H=0;H<X.length;H++)V=($.words[H]|0)-(X.words[H]|0)+U,U=V>>26,this.words[H]=V&67108863;for(;U!==0&&H<$.length;H++)V=($.words[H]|0)+U,U=V>>26,this.words[H]=V&67108863;if(U===0&&H<$.length&&$!==this)for(;H<$.length;H++)this.words[H]=$.words[H];return this.length=Math.max(this.length,H),$!==this&&(this.negative=1),this.strip()},q.prototype.sub=function(J){return this.clone().isub(J)};function P(J,V,Z){Z.negative=V.negative^J.negative;var $=J.length+V.length|0;Z.length=$,$=$-1|0;var X=J.words[0]|0,U=V.words[0]|0,H=X*U,G=H&67108863,Q=H/67108864|0;Z.words[0]=G;for(var K=1;K<$;K++){for(var k=Q>>>26,L=Q&67108863,_=Math.min(K,V.length-1),t=Math.max(0,K-J.length+1);t<=_;t++){var QJ=K-t|0;X=J.words[QJ]|0,U=V.words[t]|0,H=X*U+L,k+=H/67108864|0,L=H&67108863}Z.words[K]=L|0,Q=k|0}return Q!==0?Z.words[K]=Q|0:Z.length--,Z.strip()}var F=function(J,V,Z){var $=J.words,X=V.words,U=Z.words,H=0,G,Q,K,k=$[0]|0,L=k&8191,_=k>>>13,t=$[1]|0,QJ=t&8191,GJ=t>>>13,n=$[2]|0,p=n&8191,e=n>>>13,PJ=$[3]|0,XJ=PJ&8191,WJ=PJ>>>13,b=$[4]|0,C=b&8191,h=b>>>13,$J=$[5]|0,qJ=$J&8191,ZJ=$J>>>13,mJ=$[6]|0,BJ=mJ&8191,TJ=mJ>>>13,dJ=$[7]|0,LJ=dJ&8191,IJ=dJ>>>13,$Q=$[8]|0,T=$Q&8191,D=$Q>>>13,u=$[9]|0,d=u&8191,a=u>>>13,CJ=X[0]|0,UJ=CJ&8191,EJ=CJ>>>13,QQ=X[1]|0,FJ=QQ&8191,RJ=QQ>>>13,aJ=X[2]|0,SJ=aJ&8191,xJ=aJ>>>13,nJ=X[3]|0,AJ=nJ&8191,kJ=nJ>>>13,ZQ=X[4]|0,vJ=ZQ&8191,MJ=ZQ>>>13,xQ=X[5]|0,wJ=xQ&8191,bJ=xQ>>>13,WQ=X[6]|0,_J=WQ&8191,NJ=WQ>>>13,vQ=X[7]|0,yJ=vQ&8191,gJ=vQ>>>13,MQ=X[8]|0,cJ=MQ&8191,fJ=MQ>>>13,wQ=X[9]|0,f=wQ&8191,zJ=wQ>>>13;Z.negative=J.negative^V.negative,Z.length=19,G=Math.imul(L,UJ),Q=Math.imul(L,EJ),Q=Q+Math.imul(_,UJ)|0,K=Math.imul(_,EJ);var CQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(CQ>>>26)|0,CQ&=67108863,G=Math.imul(QJ,UJ),Q=Math.imul(QJ,EJ),Q=Q+Math.imul(GJ,UJ)|0,K=Math.imul(GJ,EJ),G=G+Math.imul(L,FJ)|0,Q=Q+Math.imul(L,RJ)|0,Q=Q+Math.imul(_,FJ)|0,K=K+Math.imul(_,RJ)|0;var oJ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(oJ>>>26)|0,oJ&=67108863,G=Math.imul(p,UJ),Q=Math.imul(p,EJ),Q=Q+Math.imul(e,UJ)|0,K=Math.imul(e,EJ),G=G+Math.imul(QJ,FJ)|0,Q=Q+Math.imul(QJ,RJ)|0,Q=Q+Math.imul(GJ,FJ)|0,K=K+Math.imul(GJ,RJ)|0,G=G+Math.imul(L,SJ)|0,Q=Q+Math.imul(L,xJ)|0,Q=Q+Math.imul(_,SJ)|0,K=K+Math.imul(_,xJ)|0;var tJ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(tJ>>>26)|0,tJ&=67108863,G=Math.imul(XJ,UJ),Q=Math.imul(XJ,EJ),Q=Q+Math.imul(WJ,UJ)|0,K=Math.imul(WJ,EJ),G=G+Math.imul(p,FJ)|0,Q=Q+Math.imul(p,RJ)|0,Q=Q+Math.imul(e,FJ)|0,K=K+Math.imul(e,RJ)|0,G=G+Math.imul(QJ,SJ)|0,Q=Q+Math.imul(QJ,xJ)|0,Q=Q+Math.imul(GJ,SJ)|0,K=K+Math.imul(GJ,xJ)|0,G=G+Math.imul(L,AJ)|0,Q=Q+Math.imul(L,kJ)|0,Q=Q+Math.imul(_,AJ)|0,K=K+Math.imul(_,kJ)|0;var YQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(YQ>>>26)|0,YQ&=67108863,G=Math.imul(C,UJ),Q=Math.imul(C,EJ),Q=Q+Math.imul(h,UJ)|0,K=Math.imul(h,EJ),G=G+Math.imul(XJ,FJ)|0,Q=Q+Math.imul(XJ,RJ)|0,Q=Q+Math.imul(WJ,FJ)|0,K=K+Math.imul(WJ,RJ)|0,G=G+Math.imul(p,SJ)|0,Q=Q+Math.imul(p,xJ)|0,Q=Q+Math.imul(e,SJ)|0,K=K+Math.imul(e,xJ)|0,G=G+Math.imul(QJ,AJ)|0,Q=Q+Math.imul(QJ,kJ)|0,Q=Q+Math.imul(GJ,AJ)|0,K=K+Math.imul(GJ,kJ)|0,G=G+Math.imul(L,vJ)|0,Q=Q+Math.imul(L,MJ)|0,Q=Q+Math.imul(_,vJ)|0,K=K+Math.imul(_,MJ)|0;var BQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(BQ>>>26)|0,BQ&=67108863,G=Math.imul(qJ,UJ),Q=Math.imul(qJ,EJ),Q=Q+Math.imul(ZJ,UJ)|0,K=Math.imul(ZJ,EJ),G=G+Math.imul(C,FJ)|0,Q=Q+Math.imul(C,RJ)|0,Q=Q+Math.imul(h,FJ)|0,K=K+Math.imul(h,RJ)|0,G=G+Math.imul(XJ,SJ)|0,Q=Q+Math.imul(XJ,xJ)|0,Q=Q+Math.imul(WJ,SJ)|0,K=K+Math.imul(WJ,xJ)|0,G=G+Math.imul(p,AJ)|0,Q=Q+Math.imul(p,kJ)|0,Q=Q+Math.imul(e,AJ)|0,K=K+Math.imul(e,kJ)|0,G=G+Math.imul(QJ,vJ)|0,Q=Q+Math.imul(QJ,MJ)|0,Q=Q+Math.imul(GJ,vJ)|0,K=K+Math.imul(GJ,MJ)|0,G=G+Math.imul(L,wJ)|0,Q=Q+Math.imul(L,bJ)|0,Q=Q+Math.imul(_,wJ)|0,K=K+Math.imul(_,bJ)|0;var OQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(OQ>>>26)|0,OQ&=67108863,G=Math.imul(BJ,UJ),Q=Math.imul(BJ,EJ),Q=Q+Math.imul(TJ,UJ)|0,K=Math.imul(TJ,EJ),G=G+Math.imul(qJ,FJ)|0,Q=Q+Math.imul(qJ,RJ)|0,Q=Q+Math.imul(ZJ,FJ)|0,K=K+Math.imul(ZJ,RJ)|0,G=G+Math.imul(C,SJ)|0,Q=Q+Math.imul(C,xJ)|0,Q=Q+Math.imul(h,SJ)|0,K=K+Math.imul(h,xJ)|0,G=G+Math.imul(XJ,AJ)|0,Q=Q+Math.imul(XJ,kJ)|0,Q=Q+Math.imul(WJ,AJ)|0,K=K+Math.imul(WJ,kJ)|0,G=G+Math.imul(p,vJ)|0,Q=Q+Math.imul(p,MJ)|0,Q=Q+Math.imul(e,vJ)|0,K=K+Math.imul(e,MJ)|0,G=G+Math.imul(QJ,wJ)|0,Q=Q+Math.imul(QJ,bJ)|0,Q=Q+Math.imul(GJ,wJ)|0,K=K+Math.imul(GJ,bJ)|0,G=G+Math.imul(L,_J)|0,Q=Q+Math.imul(L,NJ)|0,Q=Q+Math.imul(_,_J)|0,K=K+Math.imul(_,NJ)|0;var jQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(jQ>>>26)|0,jQ&=67108863,G=Math.imul(LJ,UJ),Q=Math.imul(LJ,EJ),Q=Q+Math.imul(IJ,UJ)|0,K=Math.imul(IJ,EJ),G=G+Math.imul(BJ,FJ)|0,Q=Q+Math.imul(BJ,RJ)|0,Q=Q+Math.imul(TJ,FJ)|0,K=K+Math.imul(TJ,RJ)|0,G=G+Math.imul(qJ,SJ)|0,Q=Q+Math.imul(qJ,xJ)|0,Q=Q+Math.imul(ZJ,SJ)|0,K=K+Math.imul(ZJ,xJ)|0,G=G+Math.imul(C,AJ)|0,Q=Q+Math.imul(C,kJ)|0,Q=Q+Math.imul(h,AJ)|0,K=K+Math.imul(h,kJ)|0,G=G+Math.imul(XJ,vJ)|0,Q=Q+Math.imul(XJ,MJ)|0,Q=Q+Math.imul(WJ,vJ)|0,K=K+Math.imul(WJ,MJ)|0,G=G+Math.imul(p,wJ)|0,Q=Q+Math.imul(p,bJ)|0,Q=Q+Math.imul(e,wJ)|0,K=K+Math.imul(e,bJ)|0,G=G+Math.imul(QJ,_J)|0,Q=Q+Math.imul(QJ,NJ)|0,Q=Q+Math.imul(GJ,_J)|0,K=K+Math.imul(GJ,NJ)|0,G=G+Math.imul(L,yJ)|0,Q=Q+Math.imul(L,gJ)|0,Q=Q+Math.imul(_,yJ)|0,K=K+Math.imul(_,gJ)|0;var TQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(TQ>>>26)|0,TQ&=67108863,G=Math.imul(T,UJ),Q=Math.imul(T,EJ),Q=Q+Math.imul(D,UJ)|0,K=Math.imul(D,EJ),G=G+Math.imul(LJ,FJ)|0,Q=Q+Math.imul(LJ,RJ)|0,Q=Q+Math.imul(IJ,FJ)|0,K=K+Math.imul(IJ,RJ)|0,G=G+Math.imul(BJ,SJ)|0,Q=Q+Math.imul(BJ,xJ)|0,Q=Q+Math.imul(TJ,SJ)|0,K=K+Math.imul(TJ,xJ)|0,G=G+Math.imul(qJ,AJ)|0,Q=Q+Math.imul(qJ,kJ)|0,Q=Q+Math.imul(ZJ,AJ)|0,K=K+Math.imul(ZJ,kJ)|0,G=G+Math.imul(C,vJ)|0,Q=Q+Math.imul(C,MJ)|0,Q=Q+Math.imul(h,vJ)|0,K=K+Math.imul(h,MJ)|0,G=G+Math.imul(XJ,wJ)|0,Q=Q+Math.imul(XJ,bJ)|0,Q=Q+Math.imul(WJ,wJ)|0,K=K+Math.imul(WJ,bJ)|0,G=G+Math.imul(p,_J)|0,Q=Q+Math.imul(p,NJ)|0,Q=Q+Math.imul(e,_J)|0,K=K+Math.imul(e,NJ)|0,G=G+Math.imul(QJ,yJ)|0,Q=Q+Math.imul(QJ,gJ)|0,Q=Q+Math.imul(GJ,yJ)|0,K=K+Math.imul(GJ,gJ)|0,G=G+Math.imul(L,cJ)|0,Q=Q+Math.imul(L,fJ)|0,Q=Q+Math.imul(_,cJ)|0,K=K+Math.imul(_,fJ)|0;var NQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(NQ>>>26)|0,NQ&=67108863,G=Math.imul(d,UJ),Q=Math.imul(d,EJ),Q=Q+Math.imul(a,UJ)|0,K=Math.imul(a,EJ),G=G+Math.imul(T,FJ)|0,Q=Q+Math.imul(T,RJ)|0,Q=Q+Math.imul(D,FJ)|0,K=K+Math.imul(D,RJ)|0,G=G+Math.imul(LJ,SJ)|0,Q=Q+Math.imul(LJ,xJ)|0,Q=Q+Math.imul(IJ,SJ)|0,K=K+Math.imul(IJ,xJ)|0,G=G+Math.imul(BJ,AJ)|0,Q=Q+Math.imul(BJ,kJ)|0,Q=Q+Math.imul(TJ,AJ)|0,K=K+Math.imul(TJ,kJ)|0,G=G+Math.imul(qJ,vJ)|0,Q=Q+Math.imul(qJ,MJ)|0,Q=Q+Math.imul(ZJ,vJ)|0,K=K+Math.imul(ZJ,MJ)|0,G=G+Math.imul(C,wJ)|0,Q=Q+Math.imul(C,bJ)|0,Q=Q+Math.imul(h,wJ)|0,K=K+Math.imul(h,bJ)|0,G=G+Math.imul(XJ,_J)|0,Q=Q+Math.imul(XJ,NJ)|0,Q=Q+Math.imul(WJ,_J)|0,K=K+Math.imul(WJ,NJ)|0,G=G+Math.imul(p,yJ)|0,Q=Q+Math.imul(p,gJ)|0,Q=Q+Math.imul(e,yJ)|0,K=K+Math.imul(e,gJ)|0,G=G+Math.imul(QJ,cJ)|0,Q=Q+Math.imul(QJ,fJ)|0,Q=Q+Math.imul(GJ,cJ)|0,K=K+Math.imul(GJ,fJ)|0,G=G+Math.imul(L,f)|0,Q=Q+Math.imul(L,zJ)|0,Q=Q+Math.imul(_,f)|0,K=K+Math.imul(_,zJ)|0;var IQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(IQ>>>26)|0,IQ&=67108863,G=Math.imul(d,FJ),Q=Math.imul(d,RJ),Q=Q+Math.imul(a,FJ)|0,K=Math.imul(a,RJ),G=G+Math.imul(T,SJ)|0,Q=Q+Math.imul(T,xJ)|0,Q=Q+Math.imul(D,SJ)|0,K=K+Math.imul(D,xJ)|0,G=G+Math.imul(LJ,AJ)|0,Q=Q+Math.imul(LJ,kJ)|0,Q=Q+Math.imul(IJ,AJ)|0,K=K+Math.imul(IJ,kJ)|0,G=G+Math.imul(BJ,vJ)|0,Q=Q+Math.imul(BJ,MJ)|0,Q=Q+Math.imul(TJ,vJ)|0,K=K+Math.imul(TJ,MJ)|0,G=G+Math.imul(qJ,wJ)|0,Q=Q+Math.imul(qJ,bJ)|0,Q=Q+Math.imul(ZJ,wJ)|0,K=K+Math.imul(ZJ,bJ)|0,G=G+Math.imul(C,_J)|0,Q=Q+Math.imul(C,NJ)|0,Q=Q+Math.imul(h,_J)|0,K=K+Math.imul(h,NJ)|0,G=G+Math.imul(XJ,yJ)|0,Q=Q+Math.imul(XJ,gJ)|0,Q=Q+Math.imul(WJ,yJ)|0,K=K+Math.imul(WJ,gJ)|0,G=G+Math.imul(p,cJ)|0,Q=Q+Math.imul(p,fJ)|0,Q=Q+Math.imul(e,cJ)|0,K=K+Math.imul(e,fJ)|0,G=G+Math.imul(QJ,f)|0,Q=Q+Math.imul(QJ,zJ)|0,Q=Q+Math.imul(GJ,f)|0,K=K+Math.imul(GJ,zJ)|0;var EQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(EQ>>>26)|0,EQ&=67108863,G=Math.imul(d,SJ),Q=Math.imul(d,xJ),Q=Q+Math.imul(a,SJ)|0,K=Math.imul(a,xJ),G=G+Math.imul(T,AJ)|0,Q=Q+Math.imul(T,kJ)|0,Q=Q+Math.imul(D,AJ)|0,K=K+Math.imul(D,kJ)|0,G=G+Math.imul(LJ,vJ)|0,Q=Q+Math.imul(LJ,MJ)|0,Q=Q+Math.imul(IJ,vJ)|0,K=K+Math.imul(IJ,MJ)|0,G=G+Math.imul(BJ,wJ)|0,Q=Q+Math.imul(BJ,bJ)|0,Q=Q+Math.imul(TJ,wJ)|0,K=K+Math.imul(TJ,bJ)|0,G=G+Math.imul(qJ,_J)|0,Q=Q+Math.imul(qJ,NJ)|0,Q=Q+Math.imul(ZJ,_J)|0,K=K+Math.imul(ZJ,NJ)|0,G=G+Math.imul(C,yJ)|0,Q=Q+Math.imul(C,gJ)|0,Q=Q+Math.imul(h,yJ)|0,K=K+Math.imul(h,gJ)|0,G=G+Math.imul(XJ,cJ)|0,Q=Q+Math.imul(XJ,fJ)|0,Q=Q+Math.imul(WJ,cJ)|0,K=K+Math.imul(WJ,fJ)|0,G=G+Math.imul(p,f)|0,Q=Q+Math.imul(p,zJ)|0,Q=Q+Math.imul(e,f)|0,K=K+Math.imul(e,zJ)|0;var RQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(RQ>>>26)|0,RQ&=67108863,G=Math.imul(d,AJ),Q=Math.imul(d,kJ),Q=Q+Math.imul(a,AJ)|0,K=Math.imul(a,kJ),G=G+Math.imul(T,vJ)|0,Q=Q+Math.imul(T,MJ)|0,Q=Q+Math.imul(D,vJ)|0,K=K+Math.imul(D,MJ)|0,G=G+Math.imul(LJ,wJ)|0,Q=Q+Math.imul(LJ,bJ)|0,Q=Q+Math.imul(IJ,wJ)|0,K=K+Math.imul(IJ,bJ)|0,G=G+Math.imul(BJ,_J)|0,Q=Q+Math.imul(BJ,NJ)|0,Q=Q+Math.imul(TJ,_J)|0,K=K+Math.imul(TJ,NJ)|0,G=G+Math.imul(qJ,yJ)|0,Q=Q+Math.imul(qJ,gJ)|0,Q=Q+Math.imul(ZJ,yJ)|0,K=K+Math.imul(ZJ,gJ)|0,G=G+Math.imul(C,cJ)|0,Q=Q+Math.imul(C,fJ)|0,Q=Q+Math.imul(h,cJ)|0,K=K+Math.imul(h,fJ)|0,G=G+Math.imul(XJ,f)|0,Q=Q+Math.imul(XJ,zJ)|0,Q=Q+Math.imul(WJ,f)|0,K=K+Math.imul(WJ,zJ)|0;var zQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(zQ>>>26)|0,zQ&=67108863,G=Math.imul(d,vJ),Q=Math.imul(d,MJ),Q=Q+Math.imul(a,vJ)|0,K=Math.imul(a,MJ),G=G+Math.imul(T,wJ)|0,Q=Q+Math.imul(T,bJ)|0,Q=Q+Math.imul(D,wJ)|0,K=K+Math.imul(D,bJ)|0,G=G+Math.imul(LJ,_J)|0,Q=Q+Math.imul(LJ,NJ)|0,Q=Q+Math.imul(IJ,_J)|0,K=K+Math.imul(IJ,NJ)|0,G=G+Math.imul(BJ,yJ)|0,Q=Q+Math.imul(BJ,gJ)|0,Q=Q+Math.imul(TJ,yJ)|0,K=K+Math.imul(TJ,gJ)|0,G=G+Math.imul(qJ,cJ)|0,Q=Q+Math.imul(qJ,fJ)|0,Q=Q+Math.imul(ZJ,cJ)|0,K=K+Math.imul(ZJ,fJ)|0,G=G+Math.imul(C,f)|0,Q=Q+Math.imul(C,zJ)|0,Q=Q+Math.imul(h,f)|0,K=K+Math.imul(h,zJ)|0;var PQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(PQ>>>26)|0,PQ&=67108863,G=Math.imul(d,wJ),Q=Math.imul(d,bJ),Q=Q+Math.imul(a,wJ)|0,K=Math.imul(a,bJ),G=G+Math.imul(T,_J)|0,Q=Q+Math.imul(T,NJ)|0,Q=Q+Math.imul(D,_J)|0,K=K+Math.imul(D,NJ)|0,G=G+Math.imul(LJ,yJ)|0,Q=Q+Math.imul(LJ,gJ)|0,Q=Q+Math.imul(IJ,yJ)|0,K=K+Math.imul(IJ,gJ)|0,G=G+Math.imul(BJ,cJ)|0,Q=Q+Math.imul(BJ,fJ)|0,Q=Q+Math.imul(TJ,cJ)|0,K=K+Math.imul(TJ,fJ)|0,G=G+Math.imul(qJ,f)|0,Q=Q+Math.imul(qJ,zJ)|0,Q=Q+Math.imul(ZJ,f)|0,K=K+Math.imul(ZJ,zJ)|0;var LQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(LQ>>>26)|0,LQ&=67108863,G=Math.imul(d,_J),Q=Math.imul(d,NJ),Q=Q+Math.imul(a,_J)|0,K=Math.imul(a,NJ),G=G+Math.imul(T,yJ)|0,Q=Q+Math.imul(T,gJ)|0,Q=Q+Math.imul(D,yJ)|0,K=K+Math.imul(D,gJ)|0,G=G+Math.imul(LJ,cJ)|0,Q=Q+Math.imul(LJ,fJ)|0,Q=Q+Math.imul(IJ,cJ)|0,K=K+Math.imul(IJ,fJ)|0,G=G+Math.imul(BJ,f)|0,Q=Q+Math.imul(BJ,zJ)|0,Q=Q+Math.imul(TJ,f)|0,K=K+Math.imul(TJ,zJ)|0;var FQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(FQ>>>26)|0,FQ&=67108863,G=Math.imul(d,yJ),Q=Math.imul(d,gJ),Q=Q+Math.imul(a,yJ)|0,K=Math.imul(a,gJ),G=G+Math.imul(T,cJ)|0,Q=Q+Math.imul(T,fJ)|0,Q=Q+Math.imul(D,cJ)|0,K=K+Math.imul(D,fJ)|0,G=G+Math.imul(LJ,f)|0,Q=Q+Math.imul(LJ,zJ)|0,Q=Q+Math.imul(IJ,f)|0,K=K+Math.imul(IJ,zJ)|0;var HQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(HQ>>>26)|0,HQ&=67108863,G=Math.imul(d,cJ),Q=Math.imul(d,fJ),Q=Q+Math.imul(a,cJ)|0,K=Math.imul(a,fJ),G=G+Math.imul(T,f)|0,Q=Q+Math.imul(T,zJ)|0,Q=Q+Math.imul(D,f)|0,K=K+Math.imul(D,zJ)|0;var DQ=(H+G|0)+((Q&8191)<<13)|0;H=(K+(Q>>>13)|0)+(DQ>>>26)|0,DQ&=67108863,G=Math.imul(d,f),Q=Math.imul(d,zJ),Q=Q+Math.imul(a,f)|0,K=Math.imul(a,zJ);var KQ=(H+G|0)+((Q&8191)<<13)|0;return H=(K+(Q>>>13)|0)+(KQ>>>26)|0,KQ&=67108863,U[0]=CQ,U[1]=oJ,U[2]=tJ,U[3]=YQ,U[4]=BQ,U[5]=OQ,U[6]=jQ,U[7]=TQ,U[8]=NQ,U[9]=IQ,U[10]=EQ,U[11]=RQ,U[12]=zQ,U[13]=PQ,U[14]=LQ,U[15]=FQ,U[16]=HQ,U[17]=DQ,U[18]=KQ,H!==0&&(U[19]=H,Z.length++),Z};Math.imul||(F=P);function v(J,V,Z){Z.negative=V.negative^J.negative,Z.length=J.length+V.length;for(var $=0,X=0,U=0;U<Z.length-1;U++){var H=X;X=0;for(var G=$&67108863,Q=Math.min(U,V.length-1),K=Math.max(0,U-J.length+1);K<=Q;K++){var k=U-K,L=J.words[k]|0,_=V.words[K]|0,t=L*_,QJ=t&67108863;H=H+(t/67108864|0)|0,QJ=QJ+G|0,G=QJ&67108863,H=H+(QJ>>>26)|0,X+=H>>>26,H&=67108863}Z.words[U]=G,$=H,H=X}return $!==0?Z.words[U]=$:Z.length--,Z.strip()}function S(J,V,Z){var $=new w;return $.mulp(J,V,Z)}q.prototype.mulTo=function(J,V){var Z,$=this.length+J.length;return this.length===10&&J.length===10?Z=F(this,J,V):$<63?Z=P(this,J,V):$<1024?Z=v(this,J,V):Z=S(this,J,V),Z};function w(J,V){this.x=J,this.y=V}w.prototype.makeRBT=function(J){for(var V=new Array(J),Z=q.prototype._countBits(J)-1,$=0;$<J;$++)V[$]=this.revBin($,Z,J);return V},w.prototype.revBin=function(J,V,Z){if(J===0||J===Z-1)return J;for(var $=0,X=0;X<V;X++)$|=(J&1)<<V-X-1,J>>=1;return $},w.prototype.permute=function(J,V,Z,$,X,U){for(var H=0;H<U;H++)$[H]=V[J[H]],X[H]=Z[J[H]]},w.prototype.transform=function(J,V,Z,$,X,U){this.permute(U,J,V,Z,$,X);for(var H=1;H<X;H<<=1)for(var G=H<<1,Q=Math.cos(2*Math.PI/G),K=Math.sin(2*Math.PI/G),k=0;k<X;k+=G)for(var L=Q,_=K,t=0;t<H;t++){var QJ=Z[k+t],GJ=$[k+t],n=Z[k+t+H],p=$[k+t+H],e=L*n-_*p;p=L*p+_*n,n=e,Z[k+t]=QJ+n,$[k+t]=GJ+p,Z[k+t+H]=QJ-n,$[k+t+H]=GJ-p,t!==G&&(e=Q*L-K*_,_=Q*_+K*L,L=e)}},w.prototype.guessLen13b=function(J,V){var Z=Math.max(V,J)|1,$=Z&1,X=0;for(Z=Z/2|0;Z;Z=Z>>>1)X++;return 1<<X+1+$},w.prototype.conjugate=function(J,V,Z){if(!(Z<=1))for(var $=0;$<Z/2;$++){var X=J[$];J[$]=J[Z-$-1],J[Z-$-1]=X,X=V[$],V[$]=-V[Z-$-1],V[Z-$-1]=-X}},w.prototype.normalize13b=function(J,V){for(var Z=0,$=0;$<V/2;$++){var X=Math.round(J[2*$+1]/V)*8192+Math.round(J[2*$]/V)+Z;J[$]=X&67108863,X<67108864?Z=0:Z=X/67108864|0}return J},w.prototype.convert13b=function(J,V,Z,$){for(var X=0,U=0;U<V;U++)X=X+(J[U]|0),Z[2*U]=X&8191,X=X>>>13,Z[2*U+1]=X&8191,X=X>>>13;for(U=2*V;U<$;++U)Z[U]=0;B(X===0),B((X&-8192)===0)},w.prototype.stub=function(J){for(var V=new Array(J),Z=0;Z<J;Z++)V[Z]=0;return V},w.prototype.mulp=function(J,V,Z){var $=2*this.guessLen13b(J.length,V.length),X=this.makeRBT($),U=this.stub($),H=new Array($),G=new Array($),Q=new Array($),K=new Array($),k=new Array($),L=new Array($),_=Z.words;_.length=$,this.convert13b(J.words,J.length,H,$),this.convert13b(V.words,V.length,K,$),this.transform(H,U,G,Q,$,X),this.transform(K,U,k,L,$,X);for(var t=0;t<$;t++){var QJ=G[t]*k[t]-Q[t]*L[t];Q[t]=G[t]*L[t]+Q[t]*k[t],G[t]=QJ}return this.conjugate(G,Q,$),this.transform(G,Q,_,U,$,X),this.conjugate(_,U,$),this.normalize13b(_,$),Z.negative=J.negative^V.negative,Z.length=J.length+V.length,Z.strip()},q.prototype.mul=function(J){var V=new q(null);return V.words=new Array(this.length+J.length),this.mulTo(J,V)},q.prototype.mulf=function(J){var V=new q(null);return V.words=new Array(this.length+J.length),S(this,J,V)},q.prototype.imul=function(J){return this.clone().mulTo(J,this)},q.prototype.imuln=function(J){B(typeof J=="number"),B(J<67108864);for(var V=0,Z=0;Z<this.length;Z++){var $=(this.words[Z]|0)*J,X=($&67108863)+(V&67108863);V>>=26,V+=$/67108864|0,V+=X>>>26,this.words[Z]=X&67108863}return V!==0&&(this.words[Z]=V,this.length++),this},q.prototype.muln=function(J){return this.clone().imuln(J)},q.prototype.sqr=function(){return this.mul(this)},q.prototype.isqr=function(){return this.imul(this.clone())},q.prototype.pow=function(J){var V=j(J);if(V.length===0)return new q(1);for(var Z=this,$=0;$<V.length&&V[$]===0;$++,Z=Z.sqr());if(++$<V.length)for(var X=Z.sqr();$<V.length;$++,X=X.sqr())V[$]!==0&&(Z=Z.mul(X));return Z},q.prototype.iushln=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26,$=67108863>>>26-V<<26-V,X;if(V!==0){var U=0;for(X=0;X<this.length;X++){var H=this.words[X]&$,G=(this.words[X]|0)-H<<V;this.words[X]=G|U,U=H>>>26-V}U&&(this.words[X]=U,this.length++)}if(Z!==0){for(X=this.length-1;X>=0;X--)this.words[X+Z]=this.words[X];for(X=0;X<Z;X++)this.words[X]=0;this.length+=Z}return this.strip()},q.prototype.ishln=function(J){return B(this.negative===0),this.iushln(J)},q.prototype.iushrn=function(J,V,Z){B(typeof J=="number"&&J>=0);var $;V?$=(V-V%26)/26:$=0;var X=J%26,U=Math.min((J-X)/26,this.length),H=67108863^67108863>>>X<<X,G=Z;if($-=U,$=Math.max(0,$),G){for(var Q=0;Q<U;Q++)G.words[Q]=this.words[Q];G.length=U}if(U!==0)if(this.length>U)for(this.length-=U,Q=0;Q<this.length;Q++)this.words[Q]=this.words[Q+U];else this.words[0]=0,this.length=1;var K=0;for(Q=this.length-1;Q>=0&&(K!==0||Q>=$);Q--){var k=this.words[Q]|0;this.words[Q]=K<<26-X|k>>>X,K=k&H}return G&&K!==0&&(G.words[G.length++]=K),this.length===0&&(this.words[0]=0,this.length=1),this.strip()},q.prototype.ishrn=function(J,V,Z){return B(this.negative===0),this.iushrn(J,V,Z)},q.prototype.shln=function(J){return this.clone().ishln(J)},q.prototype.ushln=function(J){return this.clone().iushln(J)},q.prototype.shrn=function(J){return this.clone().ishrn(J)},q.prototype.ushrn=function(J){return this.clone().iushrn(J)},q.prototype.testn=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26,$=1<<V;if(this.length<=Z)return!1;var X=this.words[Z];return!!(X&$)},q.prototype.imaskn=function(J){B(typeof J=="number"&&J>=0);var V=J%26,Z=(J-V)/26;if(B(this.negative===0,"imaskn works only with positive numbers"),this.length<=Z)return this;if(V!==0&&Z++,this.length=Math.min(Z,this.length),V!==0){var $=67108863^67108863>>>V<<V;this.words[this.length-1]&=$}return this.strip()},q.prototype.maskn=function(J){return this.clone().imaskn(J)},q.prototype.iaddn=function(J){return B(typeof J=="number"),B(J<67108864),J<0?this.isubn(-J):this.negative!==0?this.length===1&&(this.words[0]|0)<J?(this.words[0]=J-(this.words[0]|0),this.negative=0,this):(this.negative=0,this.isubn(J),this.negative=1,this):this._iaddn(J)},q.prototype._iaddn=function(J){this.words[0]+=J;for(var V=0;V<this.length&&this.words[V]>=67108864;V++)this.words[V]-=67108864,V===this.length-1?this.words[V+1]=1:this.words[V+1]++;return this.length=Math.max(this.length,V+1),this},q.prototype.isubn=function(J){if(B(typeof J=="number"),B(J<67108864),J<0)return this.iaddn(-J);if(this.negative!==0)return this.negative=0,this.iaddn(J),this.negative=1,this;if(this.words[0]-=J,this.length===1&&this.words[0]<0)this.words[0]=-this.words[0],this.negative=1;else for(var V=0;V<this.length&&this.words[V]<0;V++)this.words[V]+=67108864,this.words[V+1]-=1;return this.strip()},q.prototype.addn=function(J){return this.clone().iaddn(J)},q.prototype.subn=function(J){return this.clone().isubn(J)},q.prototype.iabs=function(){return this.negative=0,this},q.prototype.abs=function(){return this.clone().iabs()},q.prototype._ishlnsubmul=function(J,V,Z){var $=J.length+Z,X;this._expand($);var U,H=0;for(X=0;X<J.length;X++){U=(this.words[X+Z]|0)+H;var G=(J.words[X]|0)*V;U-=G&67108863,H=(U>>26)-(G/67108864|0),this.words[X+Z]=U&67108863}for(;X<this.length-Z;X++)U=(this.words[X+Z]|0)+H,H=U>>26,this.words[X+Z]=U&67108863;if(H===0)return this.strip();for(B(H===-1),H=0,X=0;X<this.length;X++)U=-(this.words[X]|0)+H,H=U>>26,this.words[X]=U&67108863;return this.negative=1,this.strip()},q.prototype._wordDiv=function(J,V){var Z=this.length-J.length,$=this.clone(),X=J,U=X.words[X.length-1]|0,H=this._countBits(U);Z=26-H,Z!==0&&(X=X.ushln(Z),$.iushln(Z),U=X.words[X.length-1]|0);var G=$.length-X.length,Q;if(V!=="mod"){Q=new q(null),Q.length=G+1,Q.words=new Array(Q.length);for(var K=0;K<Q.length;K++)Q.words[K]=0}var k=$.clone()._ishlnsubmul(X,1,G);k.negative===0&&($=k,Q&&(Q.words[G]=1));for(var L=G-1;L>=0;L--){var _=($.words[X.length+L]|0)*67108864+($.words[X.length+L-1]|0);for(_=Math.min(_/U|0,67108863),$._ishlnsubmul(X,_,L);$.negative!==0;)_--,$.negative=0,$._ishlnsubmul(X,1,L),$.isZero()||($.negative^=1);Q&&(Q.words[L]=_)}return Q&&Q.strip(),$.strip(),V!=="div"&&Z!==0&&$.iushrn(Z),{div:Q||null,mod:$}},q.prototype.divmod=function(J,V,Z){if(B(!J.isZero()),this.isZero())return{div:new q(0),mod:new q(0)};var $,X,U;return this.negative!==0&&J.negative===0?(U=this.neg().divmod(J,V),V!=="mod"&&($=U.div.neg()),V!=="div"&&(X=U.mod.neg(),Z&&X.negative!==0&&X.iadd(J)),{div:$,mod:X}):this.negative===0&&J.negative!==0?(U=this.divmod(J.neg(),V),V!=="mod"&&($=U.div.neg()),{div:$,mod:U.mod}):(this.negative&J.negative)!==0?(U=this.neg().divmod(J.neg(),V),V!=="div"&&(X=U.mod.neg(),Z&&X.negative!==0&&X.isub(J)),{div:U.div,mod:X}):J.length>this.length||this.cmp(J)<0?{div:new q(0),mod:this}:J.length===1?V==="div"?{div:this.divn(J.words[0]),mod:null}:V==="mod"?{div:null,mod:new q(this.modn(J.words[0]))}:{div:this.divn(J.words[0]),mod:new q(this.modn(J.words[0]))}:this._wordDiv(J,V)},q.prototype.div=function(J){return this.divmod(J,"div",!1).div},q.prototype.mod=function(J){return this.divmod(J,"mod",!1).mod},q.prototype.umod=function(J){return this.divmod(J,"mod",!0).mod},q.prototype.divRound=function(J){var V=this.divmod(J);if(V.mod.isZero())return V.div;var Z=V.div.negative!==0?V.mod.isub(J):V.mod,$=J.ushrn(1),X=J.andln(1),U=Z.cmp($);return U<0||X===1&&U===0?V.div:V.div.negative!==0?V.div.isubn(1):V.div.iaddn(1)},q.prototype.modn=function(J){B(J<=67108863);for(var V=(1<<26)%J,Z=0,$=this.length-1;$>=0;$--)Z=(V*Z+(this.words[$]|0))%J;return Z},q.prototype.idivn=function(J){B(J<=67108863);for(var V=0,Z=this.length-1;Z>=0;Z--){var $=(this.words[Z]|0)+V*67108864;this.words[Z]=$/J|0,V=$%J}return this.strip()},q.prototype.divn=function(J){return this.clone().idivn(J)},q.prototype.egcd=function(J){B(J.negative===0),B(!J.isZero());var V=this,Z=J.clone();V.negative!==0?V=V.umod(J):V=V.clone();for(var $=new q(1),X=new q(0),U=new q(0),H=new q(1),G=0;V.isEven()&&Z.isEven();)V.iushrn(1),Z.iushrn(1),++G;for(var Q=Z.clone(),K=V.clone();!V.isZero();){for(var k=0,L=1;(V.words[0]&L)===0&&k<26;++k,L<<=1);if(k>0)for(V.iushrn(k);k-- >0;)($.isOdd()||X.isOdd())&&($.iadd(Q),X.isub(K)),$.iushrn(1),X.iushrn(1);for(var _=0,t=1;(Z.words[0]&t)===0&&_<26;++_,t<<=1);if(_>0)for(Z.iushrn(_);_-- >0;)(U.isOdd()||H.isOdd())&&(U.iadd(Q),H.isub(K)),U.iushrn(1),H.iushrn(1);V.cmp(Z)>=0?(V.isub(Z),$.isub(U),X.isub(H)):(Z.isub(V),U.isub($),H.isub(X))}return{a:U,b:H,gcd:Z.iushln(G)}},q.prototype._invmp=function(J){B(J.negative===0),B(!J.isZero());var V=this,Z=J.clone();V.negative!==0?V=V.umod(J):V=V.clone();for(var $=new q(1),X=new q(0),U=Z.clone();V.cmpn(1)>0&&Z.cmpn(1)>0;){for(var H=0,G=1;(V.words[0]&G)===0&&H<26;++H,G<<=1);if(H>0)for(V.iushrn(H);H-- >0;)$.isOdd()&&$.iadd(U),$.iushrn(1);for(var Q=0,K=1;(Z.words[0]&K)===0&&Q<26;++Q,K<<=1);if(Q>0)for(Z.iushrn(Q);Q-- >0;)X.isOdd()&&X.iadd(U),X.iushrn(1);V.cmp(Z)>=0?(V.isub(Z),$.isub(X)):(Z.isub(V),X.isub($))}var k;return V.cmpn(1)===0?k=$:k=X,k.cmpn(0)<0&&k.iadd(J),k},q.prototype.gcd=function(J){if(this.isZero())return J.abs();if(J.isZero())return this.abs();var V=this.clone(),Z=J.clone();V.negative=0,Z.negative=0;for(var $=0;V.isEven()&&Z.isEven();$++)V.iushrn(1),Z.iushrn(1);do{for(;V.isEven();)V.iushrn(1);for(;Z.isEven();)Z.iushrn(1);var X=V.cmp(Z);if(X<0){var U=V;V=Z,Z=U}else if(X===0||Z.cmpn(1)===0)break;V.isub(Z)}while(!0);return Z.iushln($)},q.prototype.invm=function(J){return this.egcd(J).a.umod(J)},q.prototype.isEven=function(){return(this.words[0]&1)===0},q.prototype.isOdd=function(){return(this.words[0]&1)===1},q.prototype.andln=function(J){return this.words[0]&J},q.prototype.bincn=function(J){B(typeof J=="number");var V=J%26,Z=(J-V)/26,$=1<<V;if(this.length<=Z)return this._expand(Z+1),this.words[Z]|=$,this;for(var X=$,U=Z;X!==0&&U<this.length;U++){var H=this.words[U]|0;H+=X,X=H>>>26,H&=67108863,this.words[U]=H}return X!==0&&(this.words[U]=X,this.length++),this},q.prototype.isZero=function(){return this.length===1&&this.words[0]===0},q.prototype.cmpn=function(J){var V=J<0;if(this.negative!==0&&!V)return-1;if(this.negative===0&&V)return 1;this.strip();var Z;if(this.length>1)Z=1;else{V&&(J=-J),B(J<=67108863,"Number is too big");var $=this.words[0]|0;Z=$===J?0:$<J?-1:1}return this.negative!==0?-Z|0:Z},q.prototype.cmp=function(J){if(this.negative!==0&&J.negative===0)return-1;if(this.negative===0&&J.negative!==0)return 1;var V=this.ucmp(J);return this.negative!==0?-V|0:V},q.prototype.ucmp=function(J){if(this.length>J.length)return 1;if(this.length<J.length)return-1;for(var V=0,Z=this.length-1;Z>=0;Z--){var $=this.words[Z]|0,X=J.words[Z]|0;if($!==X){$<X?V=-1:$>X&&(V=1);break}}return V},q.prototype.gtn=function(J){return this.cmpn(J)===1},q.prototype.gt=function(J){return this.cmp(J)===1},q.prototype.gten=function(J){return this.cmpn(J)>=0},q.prototype.gte=function(J){return this.cmp(J)>=0},q.prototype.ltn=function(J){return this.cmpn(J)===-1},q.prototype.lt=function(J){return this.cmp(J)===-1},q.prototype.lten=function(J){return this.cmpn(J)<=0},q.prototype.lte=function(J){return this.cmp(J)<=0},q.prototype.eqn=function(J){return this.cmpn(J)===0},q.prototype.eq=function(J){return this.cmp(J)===0},q.red=function(J){return new o(J)},q.prototype.toRed=function(J){return B(!this.red,"Already a number in reduction context"),B(this.negative===0,"red works only with positives"),J.convertTo(this)._forceRed(J)},q.prototype.fromRed=function(){return B(this.red,"fromRed works only with numbers in reduction context"),this.red.convertFrom(this)},q.prototype._forceRed=function(J){return this.red=J,this},q.prototype.forceRed=function(J){return B(!this.red,"Already a number in reduction context"),this._forceRed(J)},q.prototype.redAdd=function(J){return B(this.red,"redAdd works only with red numbers"),this.red.add(this,J)},q.prototype.redIAdd=function(J){return B(this.red,"redIAdd works only with red numbers"),this.red.iadd(this,J)},q.prototype.redSub=function(J){return B(this.red,"redSub works only with red numbers"),this.red.sub(this,J)},q.prototype.redISub=function(J){return B(this.red,"redISub works only with red numbers"),this.red.isub(this,J)},q.prototype.redShl=function(J){return B(this.red,"redShl works only with red numbers"),this.red.shl(this,J)},q.prototype.redMul=function(J){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,J),this.red.mul(this,J)},q.prototype.redIMul=function(J){return B(this.red,"redMul works only with red numbers"),this.red._verify2(this,J),this.red.imul(this,J)},q.prototype.redSqr=function(){return B(this.red,"redSqr works only with red numbers"),this.red._verify1(this),this.red.sqr(this)},q.prototype.redISqr=function(){return B(this.red,"redISqr works only with red numbers"),this.red._verify1(this),this.red.isqr(this)},q.prototype.redSqrt=function(){return B(this.red,"redSqrt works only with red numbers"),this.red._verify1(this),this.red.sqrt(this)},q.prototype.redInvm=function(){return B(this.red,"redInvm works only with red numbers"),this.red._verify1(this),this.red.invm(this)},q.prototype.redNeg=function(){return B(this.red,"redNeg works only with red numbers"),this.red._verify1(this),this.red.neg(this)},q.prototype.redPow=function(J){return B(this.red&&!J.red,"redPow(normalNum)"),this.red._verify1(this),this.red.pow(this,J)};var y={k256:null,p224:null,p192:null,p25519:null};function m(J,V){this.name=J,this.p=new q(V,16),this.n=this.p.bitLength(),this.k=new q(1).iushln(this.n).isub(this.p),this.tmp=this._tmp()}m.prototype._tmp=function(){var J=new q(null);return J.words=new Array(Math.ceil(this.n/13)),J},m.prototype.ireduce=function(J){var V=J,Z;do this.split(V,this.tmp),V=this.imulK(V),V=V.iadd(this.tmp),Z=V.bitLength();while(Z>this.n);var $=Z<this.n?-1:V.ucmp(this.p);return $===0?(V.words[0]=0,V.length=1):$>0?V.isub(this.p):V.strip!==void 0?V.strip():V._strip(),V},m.prototype.split=function(J,V){J.iushrn(this.n,0,V)},m.prototype.imulK=function(J){return J.imul(this.k)};function i(){m.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}A(i,m),i.prototype.split=function(J,V){for(var Z=4194303,$=Math.min(J.length,9),X=0;X<$;X++)V.words[X]=J.words[X];if(V.length=$,J.length<=9){J.words[0]=0,J.length=1;return}var U=J.words[9];for(V.words[V.length++]=U&Z,X=10;X<J.length;X++){var H=J.words[X]|0;J.words[X-10]=(H&Z)<<4|U>>>22,U=H}U>>>=22,J.words[X-10]=U,U===0&&J.length>10?J.length-=10:J.length-=9},i.prototype.imulK=function(J){J.words[J.length]=0,J.words[J.length+1]=0,J.length+=2;for(var V=0,Z=0;Z<J.length;Z++){var $=J.words[Z]|0;V+=$*977,J.words[Z]=V&67108863,V=$*64+(V/67108864|0)}return J.words[J.length-1]===0&&(J.length--,J.words[J.length-1]===0&&J.length--),J};function JJ(){m.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}A(JJ,m);function VJ(){m.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}A(VJ,m);function HJ(){m.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}A(HJ,m),HJ.prototype.imulK=function(J){for(var V=0,Z=0;Z<J.length;Z++){var $=(J.words[Z]|0)*19+V,X=$&67108863;$>>>=26,J.words[Z]=X,V=$}return V!==0&&(J.words[J.length++]=V),J},q._prime=function(J){if(y[J])return y[J];var V;if(J==="k256")V=new i;else if(J==="p224")V=new JJ;else if(J==="p192")V=new VJ;else if(J==="p25519")V=new HJ;else throw new Error("Unknown prime "+J);return y[J]=V,V};function o(J){if(typeof J=="string"){var V=q._prime(J);this.m=V.p,this.prime=V}else B(J.gtn(1),"modulus must be greater than 1"),this.m=J,this.prime=null}o.prototype._verify1=function(J){B(J.negative===0,"red works only with positives"),B(J.red,"red works only with red numbers")},o.prototype._verify2=function(J,V){B((J.negative|V.negative)===0,"red works only with positives"),B(J.red&&J.red===V.red,"red works only with red numbers")},o.prototype.imod=function(J){return this.prime?this.prime.ireduce(J)._forceRed(this):J.umod(this.m)._forceRed(this)},o.prototype.neg=function(J){return J.isZero()?J.clone():this.m.sub(J)._forceRed(this)},o.prototype.add=function(J,V){this._verify2(J,V);var Z=J.add(V);return Z.cmp(this.m)>=0&&Z.isub(this.m),Z._forceRed(this)},o.prototype.iadd=function(J,V){this._verify2(J,V);var Z=J.iadd(V);return Z.cmp(this.m)>=0&&Z.isub(this.m),Z},o.prototype.sub=function(J,V){this._verify2(J,V);var Z=J.sub(V);return Z.cmpn(0)<0&&Z.iadd(this.m),Z._forceRed(this)},o.prototype.isub=function(J,V){this._verify2(J,V);var Z=J.isub(V);return Z.cmpn(0)<0&&Z.iadd(this.m),Z},o.prototype.shl=function(J,V){return this._verify1(J),this.imod(J.ushln(V))},o.prototype.imul=function(J,V){return this._verify2(J,V),this.imod(J.imul(V))},o.prototype.mul=function(J,V){return this._verify2(J,V),this.imod(J.mul(V))},o.prototype.isqr=function(J){return this.imul(J,J.clone())},o.prototype.sqr=function(J){return this.mul(J,J)},o.prototype.sqrt=function(J){if(J.isZero())return J.clone();var V=this.m.andln(3);if(B(V%2===1),V===3){var Z=this.m.add(new q(1)).iushrn(2);return this.pow(J,Z)}for(var $=this.m.subn(1),X=0;!$.isZero()&&$.andln(1)===0;)X++,$.iushrn(1);B(!$.isZero());var U=new q(1).toRed(this),H=U.redNeg(),G=this.m.subn(1).iushrn(1),Q=this.m.bitLength();for(Q=new q(2*Q*Q).toRed(this);this.pow(Q,G).cmp(H)!==0;)Q.redIAdd(H);for(var K=this.pow(Q,$),k=this.pow(J,$.addn(1).iushrn(1)),L=this.pow(J,$),_=X;L.cmp(U)!==0;){for(var t=L,QJ=0;t.cmp(U)!==0;QJ++)t=t.redSqr();B(QJ<_);var GJ=this.pow(K,new q(1).iushln(_-QJ-1));k=k.redMul(GJ),K=GJ.redSqr(),L=L.redMul(K),_=QJ}return k},o.prototype.invm=function(J){var V=J._invmp(this.m);return V.negative!==0?(V.negative=0,this.imod(V).redNeg()):this.imod(V)},o.prototype.pow=function(J,V){if(V.isZero())return new q(1).toRed(this);if(V.cmpn(1)===0)return J.clone();var Z=4,$=new Array(1<<Z);$[0]=new q(1).toRed(this),$[1]=J;for(var X=2;X<$.length;X++)$[X]=this.mul($[X-1],J);var U=$[0],H=0,G=0,Q=V.bitLength()%26;for(Q===0&&(Q=26),X=V.length-1;X>=0;X--){for(var K=V.words[X],k=Q-1;k>=0;k--){var L=K>>k&1;if(U!==$[0]&&(U=this.sqr(U)),L===0&&H===0){G=0;continue}H<<=1,H|=L,G++,!(G!==Z&&(X!==0||k!==0))&&(U=this.mul(U,$[H]),G=0,H=0)}Q=26}return U},o.prototype.convertTo=function(J){var V=J.umod(this.m);return V===J?V.clone():V},o.prototype.convertFrom=function(J){var V=J.clone();return V.red=null,V},q.mont=function(J){return new jJ(J)};function jJ(J){o.call(this,J),this.shift=this.m.bitLength(),this.shift%26!==0&&(this.shift+=26-this.shift%26),this.r=new q(1).iushln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv=this.minv.umod(this.r),this.minv=this.r.sub(this.minv)}A(jJ,o),jJ.prototype.convertTo=function(J){return this.imod(J.ushln(this.shift))},jJ.prototype.convertFrom=function(J){var V=this.imod(J.mul(this.rinv));return V.red=null,V},jJ.prototype.imul=function(J,V){if(J.isZero()||V.isZero())return J.words[0]=0,J.length=1,J;var Z=J.imul(V),$=Z.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),X=Z.isub($).iushrn(this.shift),U=X;return X.cmp(this.m)>=0?U=X.isub(this.m):X.cmpn(0)<0&&(U=X.iadd(this.m)),U._forceRed(this)},jJ.prototype.mul=function(J,V){if(J.isZero()||V.isZero())return new q(0)._forceRed(this);var Z=J.mul(V),$=Z.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),X=Z.isub($).iushrn(this.shift),U=X;return X.cmp(this.m)>=0?U=X.isub(this.m):X.cmpn(0)<0&&(U=X.iadd(this.m)),U._forceRed(this)},jJ.prototype.invm=function(J){var V=this.imod(J._invmp(this.m).mul(this.r2));return V._forceRed(this)}})(typeof g>"u"||g,l)}),P6=OJ((l,g)=>{var R=W0(),M=XQ().Buffer;function B(A,q){return M.from(A.toRed(R.mont(q.modulus)).redPow(new R(q.publicExponent)).fromRed().toArray())}g.exports=B}),C$=OJ((l,g)=>{var R=SV(),M=VV(),B=WV(),A=R6(),q=z6(),Y=W0(),E=P6(),O=$0(),N=XQ().Buffer;g.exports=function(j,P,F){var v;j.padding?v=j.padding:F?v=1:v=4;var S=R(j),w;if(v===4)w=W(S,P);else if(v===1)w=I(S,P,F);else if(v===3){if(w=new Y(P),w.cmp(S.modulus)>=0)throw new Error("data too long for modulus")}else throw new Error("unknown padding");return F?O(w,S):E(w,S)};function W(j,P){var F=j.modulus.byteLength(),v=P.length,S=B("sha1").update(N.alloc(0)).digest(),w=S.length,y=2*w;if(v>F-y-2)throw new Error("message too long");var m=N.alloc(F-v-y-2),i=F-w-1,JJ=M(w),VJ=q(N.concat([S,m,N.alloc(1,1),P],i),A(JJ,i)),HJ=q(JJ,A(VJ,w));return new Y(N.concat([N.alloc(1),HJ,VJ],F))}function I(j,P,F){var v=P.length,S=j.modulus.byteLength();if(v>S-11)throw new Error("message too long");var w;return F?w=N.alloc(S-v-3,255):w=z(S-v-3),new Y(N.concat([N.from([0,F?1:2]),w,N.alloc(1),P],S))}function z(j){for(var P=N.allocUnsafe(j),F=0,v=M(j*2),S=0,w;F<j;)S===v.length&&(v=M(j*2),S=0),w=v[S++],w&&(P[F++]=w);return P}}),k$=OJ((l,g)=>{var R=SV(),M=R6(),B=z6(),A=W0(),q=$0(),Y=WV(),E=P6(),O=XQ().Buffer;g.exports=function(z,j,P){var F;z.padding?F=z.padding:P?F=1:F=4;var v=R(z),S=v.modulus.byteLength();if(j.length>S||new A(j).cmp(v.modulus)>=0)throw new Error("decryption error");var w;P?w=E(new A(j),v):w=q(j,v);var y=O.alloc(S-w.length);if(w=O.concat([y,w],S),F===4)return N(v,w);if(F===1)return W(v,w,P);if(F===3)return w;throw new Error("unknown padding")};function N(z,j){var P=z.modulus.byteLength(),F=Y("sha1").update(O.alloc(0)).digest(),v=F.length;if(j[0]!==0)throw new Error("decryption error");var S=j.slice(1,v+1),w=j.slice(v+1),y=B(S,M(w,v)),m=B(w,M(y,P-v-1));if(I(F,m.slice(0,v)))throw new Error("decryption error");for(var i=v;m[i]===0;)i++;if(m[i++]!==1)throw new Error("decryption error");return m.slice(i)}function W(z,j,P){for(var F=j.slice(0,2),v=2,S=0;j[v++]!==0;)if(v>=j.length){S++;break}var w=j.slice(2,v-1);if((F.toString("hex")!=="0002"&&!P||F.toString("hex")!=="0001"&&P)&&S++,w.length<8&&S++,S)throw new Error("decryption error");return j.slice(v)}function I(z,j){z=O.from(z),j=O.from(j);var P=0,F=z.length;z.length!==j.length&&(P++,F=Math.min(z.length,j.length));for(var v=-1;++v<F;)P+=z[v]^j[v];return P}}),A$=OJ((l)=>{l.publicEncrypt=C$(),l.privateDecrypt=k$(),l.privateEncrypt=function(g,R){return l.publicEncrypt(g,R,!0)},l.publicDecrypt=function(g,R){return l.privateDecrypt(g,R,!0)}}),S$=OJ((l)=>{function g(){throw new Error(`secure random number generation not supported by this browser
+use chrome, FireFox or Internet Explorer 11`)}var R=XQ(),M=VV(),B=R.Buffer,A=R.kMaxLength,q=global.crypto||global.msCrypto,Y=Math.pow(2,32)-1;function E(z,j){if(typeof z!="number"||z!==z)throw new TypeError("offset must be a number");if(z>Y||z<0)throw new TypeError("offset must be a uint32");if(z>A||z>j)throw new RangeError("offset out of range")}function O(z,j,P){if(typeof z!="number"||z!==z)throw new TypeError("size must be a number");if(z>Y||z<0)throw new TypeError("size must be a uint32");if(z+j>P||z>A)throw new RangeError("buffer too small")}q&&q.getRandomValues?(l.randomFill=N,l.randomFillSync=I):(l.randomFill=g,l.randomFillSync=g);function N(z,j,P,F){if(!B.isBuffer(z)&&!(z instanceof global.Uint8Array))throw new TypeError('"buf" argument must be a Buffer or Uint8Array');if(typeof j=="function")F=j,j=0,P=z.length;else if(typeof P=="function")F=P,P=z.length-j;else if(typeof F!="function")throw new TypeError('"cb" argument must be a function');return E(j,z.length),O(P,j,z.length),W(z,j,P,F)}function W(z,j,P,F){var v=z.buffer,S=new Uint8Array(v,j,P);if(q.getRandomValues(S),F){process.nextTick(function(){F(null,z)});return}return z;var w}function I(z,j,P){if(typeof j>"u"&&(j=0),!B.isBuffer(z)&&!(z instanceof global.Uint8Array))throw new TypeError('"buf" argument must be a Buffer or Uint8Array');return E(j,z.length),P===void 0&&(P=z.length-j),O(P,j,z.length),W(z,j,P)}}),L6=OJ((l)=>{l.randomBytes=l.rng=l.pseudoRandomBytes=l.prng=VV(),l.createHash=l.Hash=WV(),l.createHmac=l.Hmac=f0();var g=R8(),R=Object.keys(g),M=["sha1","sha224","sha256","sha384","sha512","md5","rmd160"].concat(R);l.getHashes=function(){return M};var B=l0();l.pbkdf2=B.pbkdf2,l.pbkdf2Sync=B.pbkdf2Sync;var A=y8();l.Cipher=A.Cipher,l.createCipher=A.createCipher,l.Cipheriv=A.Cipheriv,l.createCipheriv=A.createCipheriv,l.Decipher=A.Decipher,l.createDecipher=A.createDecipher,l.Decipheriv=A.Decipheriv,l.createDecipheriv=A.createDecipheriv,l.getCiphers=A.getCiphers,l.listCiphers=A.listCiphers;var q=m8();l.DiffieHellmanGroup=q.DiffieHellmanGroup,l.createDiffieHellmanGroup=q.createDiffieHellmanGroup,l.getDiffieHellman=q.getDiffieHellman,l.createDiffieHellman=q.createDiffieHellman,l.DiffieHellman=q.DiffieHellman;var Y=L$();l.createSign=Y.createSign,l.Sign=Y.Sign,l.createVerify=Y.createVerify,l.Verify=Y.Verify,l.createECDH=D$();var E=A$();l.publicEncrypt=E.publicEncrypt,l.privateEncrypt=E.privateEncrypt,l.publicDecrypt=E.publicDecrypt,l.privateDecrypt=E.privateDecrypt;var O=S$();l.randomFill=O.randomFill,l.randomFillSync=O.randomFillSync,l.createCredentials=function(){throw new Error(["sorry, createCredentials is not implemented yet","we accept pull requests","https://github.com/crypto-browserify/crypto-browserify"].join(`
+`))},l.constants={DH_CHECK_P_NOT_SAFE_PRIME:2,DH_CHECK_P_NOT_PRIME:1,DH_UNABLE_TO_CHECK_GENERATOR:4,DH_NOT_SUITABLE_GENERATOR:8,NPN_ENABLED:1,ALPN_ENABLED:1,RSA_PKCS1_PADDING:1,RSA_SSLV23_PADDING:2,RSA_NO_PADDING:3,RSA_PKCS1_OAEP_PADDING:4,RSA_X931_PADDING:5,RSA_PKCS1_PSS_PADDING:6,POINT_CONVERSION_COMPRESSED:2,POINT_CONVERSION_UNCOMPRESSED:4,POINT_CONVERSION_HYBRID:6}}),F6={},RV(F6,{DEFAULT_ENCODING:()=>UV,default:()=>A6,getCurves:()=>Y0,getRandomValues:()=>B0,randomUUID:()=>O0,scrypt:()=>wV,scryptSync:()=>xV,timingSafeEqual:()=>jV,webcrypto:()=>j0}),fV(F6,oQ(L6())),x$=oQ(L6()),UV="buffer",B0=(l)=>crypto.getRandomValues(l),O0=()=>crypto.randomUUID(),w$=["p192","p224","p256","p384","p521","curve25519","ed25519","secp256k1","secp224r1","prime256v1","prime192v1","ed25519","secp384r1","secp521r1"],jV="timingSafeEqual"in crypto?(l,g)=>{let{byteLength:R}=l,{byteLength:M}=g;if(typeof R!="number"||typeof M!="number")throw new TypeError("Input must be an array buffer view");if(R!==M)throw new RangeError("Input buffers must have the same length");return crypto.timingSafeEqual(l,g)}:void 0,xV="scryptSync"in crypto?(l,g,R,M)=>{let B=crypto.scryptSync(l,g,R,M);return UV!=="buffer"?new Buffer(B).toString(UV):new Buffer(B)}:void 0,wV="scryptSync"in crypto?function(l,g,R,M,B){if(typeof M=="function"&&(B=M,M=void 0),typeof B!="function"){var A=new TypeError("callback must be a function");throw A.code="ERR_INVALID_CALLBACK",A}try{let q=crypto.scryptSync(l,g,R,M);process.nextTick(B,null,UV!=="buffer"?new Buffer(q).toString(UV):new Buffer(q))}catch(q){throw q}}:void 0,jV&&(Object.defineProperty(jV,"name",{value:"::bunternal::"}),Object.defineProperty(wV,"name",{value:"::bunternal::"}),Object.defineProperty(xV,"name",{value:"::bunternal::"})),j0=crypto,A6={...x$,getRandomValues:B0,randomUUID:O0,timingSafeEqual:jV,scryptSync:xV,scrypt:wV,webcrypto:j0,getCurves:Y0};/*!
+   * The buffer module from node.js, for the browser.
+   *
+   * @author   Feross Aboukhadijeh <https://feross.org>
+   * @license  MIT
+   *//*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> *//*! safe-buffer. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */}),H5="./",v$="./piper.js",B5=(()=>{var l=typeof document!=="undefined"&&document.currentScript?document.currentScript.src:void 0;if(typeof v$!=="undefined")l=l||v$;return function(g={}){var R=g,M,B;if(R.ready=new Promise((x,c)=>{M=x,B=c}),!R.expectedDataFileDownloads)R.expectedDataFileDownloads=0;R.expectedDataFileDownloads++,function(){if(R.ENVIRONMENT_IS_PTHREAD||R.$ww)return;var x=function(c){var s="";if(typeof window==="object")s=window.encodeURIComponent(window.location.pathname.toString().substring(0,window.location.pathname.toString().lastIndexOf("/"))+"/");else if(typeof process==="undefined"&&typeof location!=="undefined")s=encodeURIComponent(location.pathname.toString().substring(0,location.pathname.toString().lastIndexOf("/"))+"/");var r="piper_phonemize.data",KJ="piper_phonemize.data";if(typeof R.locateFilePackage==="function"&&!R.locateFile)R.locateFile=R.locateFilePackage,y("warning: you defined Module.locateFilePackage, that has been renamed to Module.locateFile (using your locateFilePackage for now)");var YJ=R.locateFile?R.locateFile(KJ,""):KJ,DJ=c.remote_package_size;function hJ(iJ,lJ,eJ,SQ){if(typeof process==="object"&&typeof process.versions==="object"&&typeof process.versions.node==="string"){(()=>({})).readFile(iJ,function(qQ,uJ){if(qQ)SQ(qQ);else eJ(uJ.buffer)});return}var UQ=new XMLHttpRequest;UQ.open("GET",iJ,!0),UQ.responseType="arraybuffer",UQ.onprogress=function(qQ){var uJ=iJ,sJ=lJ;if(qQ.total)sJ=qQ.total;if(qQ.loaded){if(!UQ.addedTotal){if(UQ.addedTotal=!0,!R.dataFileDownloads)R.dataFileDownloads={};R.dataFileDownloads[uJ]={loaded:qQ.loaded,total:sJ}}else R.dataFileDownloads[uJ].loaded=qQ.loaded;var AQ=0,kQ=0,cQ=0;for(var _Q in R.dataFileDownloads){var f6=R.dataFileDownloads[_Q];AQ+=f6.total,kQ+=f6.loaded,cQ++}if(AQ=Math.ceil(AQ*R.expectedDataFileDownloads/cQ),R.setStatus)R.setStatus(`Downloading data... (${kQ}/${AQ})`)}else if(!R.dataFileDownloads){if(R.setStatus)R.setStatus("Downloading data...")}},UQ.onerror=function(qQ){throw new Error("NetworkError for: "+iJ)},UQ.onload=function(qQ){if(UQ.status==200||UQ.status==304||UQ.status==206||UQ.status==0&&UQ.response){var uJ=UQ.response;eJ(uJ)}else throw new Error(UQ.statusText+" : "+UQ.responseURL)},UQ.send(null)}function pJ(iJ){console.error("package error:",iJ)}var rJ=null,VQ=R.getPreloadedPackage?R.getPreloadedPackage(YJ,DJ):null;if(!VQ)hJ(YJ,DJ,function(iJ){if(rJ)rJ(iJ),rJ=null;else VQ=iJ},pJ);function GQ(){function iJ(qQ,uJ){if(!qQ)throw uJ+new Error().stack}R.FS_createPath("/","espeak-ng-data",!0,!0),R.FS_createPath("/espeak-ng-data","lang",!0,!0),R.FS_createPath("/espeak-ng-data/lang","aav",!0,!0),R.FS_createPath("/espeak-ng-data/lang","art",!0,!0),R.FS_createPath("/espeak-ng-data/lang","azc",!0,!0),R.FS_createPath("/espeak-ng-data/lang","bat",!0,!0),R.FS_createPath("/espeak-ng-data/lang","bnt",!0,!0),R.FS_createPath("/espeak-ng-data/lang","ccs",!0,!0),R.FS_createPath("/espeak-ng-data/lang","cel",!0,!0),R.FS_createPath("/espeak-ng-data/lang","cus",!0,!0),R.FS_createPath("/espeak-ng-data/lang","dra",!0,!0),R.FS_createPath("/espeak-ng-data/lang","esx",!0,!0),R.FS_createPath("/espeak-ng-data/lang","gmq",!0,!0),R.FS_createPath("/espeak-ng-data/lang","gmw",!0,!0),R.FS_createPath("/espeak-ng-data/lang","grk",!0,!0),R.FS_createPath("/espeak-ng-data/lang","inc",!0,!0),R.FS_createPath("/espeak-ng-data/lang","ine",!0,!0),R.FS_createPath("/espeak-ng-data/lang","ira",!0,!0),R.FS_createPath("/espeak-ng-data/lang","iro",!0,!0),R.FS_createPath("/espeak-ng-data/lang","itc",!0,!0),R.FS_createPath("/espeak-ng-data/lang","jpx",!0,!0),R.FS_createPath("/espeak-ng-data/lang","map",!0,!0),R.FS_createPath("/espeak-ng-data/lang","miz",!0,!0),R.FS_createPath("/espeak-ng-data/lang","myn",!0,!0),R.FS_createPath("/espeak-ng-data/lang","poz",!0,!0),R.FS_createPath("/espeak-ng-data/lang","roa",!0,!0),R.FS_createPath("/espeak-ng-data/lang","sai",!0,!0),R.FS_createPath("/espeak-ng-data/lang","sem",!0,!0),R.FS_createPath("/espeak-ng-data/lang","sit",!0,!0),R.FS_createPath("/espeak-ng-data/lang","tai",!0,!0),R.FS_createPath("/espeak-ng-data/lang","trk",!0,!0),R.FS_createPath("/espeak-ng-data/lang","urj",!0,!0),R.FS_createPath("/espeak-ng-data/lang","zle",!0,!0),R.FS_createPath("/espeak-ng-data/lang","zls",!0,!0),R.FS_createPath("/espeak-ng-data/lang","zlw",!0,!0),R.FS_createPath("/espeak-ng-data","mbrola_ph",!0,!0),R.FS_createPath("/espeak-ng-data","voices",!0,!0),R.FS_createPath("/espeak-ng-data/voices","!v",!0,!0),R.FS_createPath("/espeak-ng-data/voices","mb",!0,!0);function lJ(qQ,uJ,sJ){this.start=qQ,this.end=uJ,this.audio=sJ}lJ.prototype={requests:{},open:function(qQ,uJ){this.name=uJ,this.requests[uJ]=this,R.addRunDependency(`fp ${this.name}`)},send:function(){},onload:function(){var qQ=this.byteArray.subarray(this.start,this.end);this.finish(qQ)},finish:function(qQ){var uJ=this;R.FS_createDataFile(this.name,null,qQ,!0,!0,!0),R.removeRunDependency(`fp ${uJ.name}`),this.requests[this.name]=null}};var eJ=c.files;for(var SQ=0;SQ<eJ.length;++SQ)new lJ(eJ[SQ].start,eJ[SQ].end,eJ[SQ].audio||0).open("GET",eJ[SQ].filename);function UQ(qQ){iJ(qQ,"Loading data file failed."),iJ(qQ.constructor.name===ArrayBuffer.name,"bad input to processPackageData");var uJ=new Uint8Array(qQ);lJ.prototype.byteArray=uJ;var sJ=c.files;for(var AQ=0;AQ<sJ.length;++AQ)lJ.prototype.requests[sJ[AQ].filename].onload();R.removeRunDependency("datafile_piper_phonemize.data")}if(R.addRunDependency("datafile_piper_phonemize.data"),!R.preloadResults)R.preloadResults={};if(R.preloadResults[r]={fromCache:!1},VQ)UQ(VQ),VQ=null;else rJ=UQ}if(R.calledRun)GQ();else{if(!R.preRun)R.preRun=[];R.preRun.push(GQ)}};x({files:[{filename:"/espeak-ng-data/af_dict",start:0,end:121473},{filename:"/espeak-ng-data/am_dict",start:121473,end:185351},{filename:"/espeak-ng-data/an_dict",start:185351,end:192042},{filename:"/espeak-ng-data/ar_dict",start:192042,end:670207},{filename:"/espeak-ng-data/as_dict",start:670207,end:675212},{filename:"/espeak-ng-data/az_dict",start:675212,end:718985},{filename:"/espeak-ng-data/ba_dict",start:718985,end:721083},{filename:"/espeak-ng-data/be_dict",start:721083,end:723735},{filename:"/espeak-ng-data/bg_dict",start:723735,end:810786},{filename:"/espeak-ng-data/bn_dict",start:810786,end:900765},{filename:"/espeak-ng-data/bpy_dict",start:900765,end:905991},{filename:"/espeak-ng-data/bs_dict",start:905991,end:953059},{filename:"/espeak-ng-data/ca_dict",start:953059,end:998625},{filename:"/espeak-ng-data/chr_dict",start:998625,end:1001484},{filename:"/espeak-ng-data/cmn_dict",start:1001484,end:2567819},{filename:"/espeak-ng-data/cs_dict",start:2567819,end:2617464},{filename:"/espeak-ng-data/cv_dict",start:2617464,end:2618808},{filename:"/espeak-ng-data/cy_dict",start:2618808,end:2661938},{filename:"/espeak-ng-data/da_dict",start:2661938,end:2907225},{filename:"/espeak-ng-data/de_dict",start:2907225,end:2975501},{filename:"/espeak-ng-data/el_dict",start:2975501,end:3048342},{filename:"/espeak-ng-data/en_dict",start:3048342,end:3215286},{filename:"/espeak-ng-data/eo_dict",start:3215286,end:3219952},{filename:"/espeak-ng-data/es_dict",start:3219952,end:3269204},{filename:"/espeak-ng-data/et_dict",start:3269204,end:3313467},{filename:"/espeak-ng-data/eu_dict",start:3313467,end:3362308},{filename:"/espeak-ng-data/fa_dict",start:3362308,end:3655543},{filename:"/espeak-ng-data/fi_dict",start:3655543,end:3699471},{filename:"/espeak-ng-data/fr_dict",start:3699471,end:3763198},{filename:"/espeak-ng-data/ga_dict",start:3763198,end:3815871},{filename:"/espeak-ng-data/gd_dict",start:3815871,end:3864992},{filename:"/espeak-ng-data/gn_dict",start:3864992,end:3868240},{filename:"/espeak-ng-data/grc_dict",start:3868240,end:3871673},{filename:"/espeak-ng-data/gu_dict",start:3871673,end:3954153},{filename:"/espeak-ng-data/hak_dict",start:3954153,end:3957488},{filename:"/espeak-ng-data/haw_dict",start:3957488,end:3959931},{filename:"/espeak-ng-data/he_dict",start:3959931,end:3966894},{filename:"/espeak-ng-data/hi_dict",start:3966894,end:4059037},{filename:"/espeak-ng-data/hr_dict",start:4059037,end:4108425},{filename:"/espeak-ng-data/ht_dict",start:4108425,end:4110228},{filename:"/espeak-ng-data/hu_dict",start:4110228,end:4264013},{filename:"/espeak-ng-data/hy_dict",start:4264013,end:4326276},{filename:"/espeak-ng-data/ia_dict",start:4326276,end:4657551},{filename:"/espeak-ng-data/id_dict",start:4657551,end:4701009},{filename:"/espeak-ng-data/intonations",start:4701009,end:4703049},{filename:"/espeak-ng-data/io_dict",start:4703049,end:4705214},{filename:"/espeak-ng-data/is_dict",start:4705214,end:4749568},{filename:"/espeak-ng-data/it_dict",start:4749568,end:4902457},{filename:"/espeak-ng-data/ja_dict",start:4902457,end:4950109},{filename:"/espeak-ng-data/jbo_dict",start:4950109,end:4952352},{filename:"/espeak-ng-data/ka_dict",start:4952352,end:5040127},{filename:"/espeak-ng-data/kk_dict",start:5040127,end:5041986},{filename:"/espeak-ng-data/kl_dict",start:5041986,end:5044824},{filename:"/espeak-ng-data/kn_dict",start:5044824,end:5132652},{filename:"/espeak-ng-data/ko_dict",start:5132652,end:5180175},{filename:"/espeak-ng-data/kok_dict",start:5180175,end:5186569},{filename:"/espeak-ng-data/ku_dict",start:5186569,end:5188834},{filename:"/espeak-ng-data/ky_dict",start:5188834,end:5253811},{filename:"/espeak-ng-data/la_dict",start:5253811,end:5257617},{filename:"/espeak-ng-data/lang/aav/vi",start:5257617,end:5257728},{filename:"/espeak-ng-data/lang/aav/vi-VN-x-central",start:5257728,end:5257871},{filename:"/espeak-ng-data/lang/aav/vi-VN-x-south",start:5257871,end:5258013},{filename:"/espeak-ng-data/lang/art/eo",start:5258013,end:5258054},{filename:"/espeak-ng-data/lang/art/ia",start:5258054,end:5258083},{filename:"/espeak-ng-data/lang/art/io",start:5258083,end:5258133},{filename:"/espeak-ng-data/lang/art/jbo",start:5258133,end:5258202},{filename:"/espeak-ng-data/lang/art/lfn",start:5258202,end:5258337},{filename:"/espeak-ng-data/lang/art/piqd",start:5258337,end:5258393},{filename:"/espeak-ng-data/lang/art/py",start:5258393,end:5258533},{filename:"/espeak-ng-data/lang/art/qdb",start:5258533,end:5258590},{filename:"/espeak-ng-data/lang/art/qya",start:5258590,end:5258763},{filename:"/espeak-ng-data/lang/art/sjn",start:5258763,end:5258938},{filename:"/espeak-ng-data/lang/azc/nci",start:5258938,end:5259052},{filename:"/espeak-ng-data/lang/bat/lt",start:5259052,end:5259080},{filename:"/espeak-ng-data/lang/bat/ltg",start:5259080,end:5259392},{filename:"/espeak-ng-data/lang/bat/lv",start:5259392,end:5259621},{filename:"/espeak-ng-data/lang/bnt/sw",start:5259621,end:5259662},{filename:"/espeak-ng-data/lang/bnt/tn",start:5259662,end:5259704},{filename:"/espeak-ng-data/lang/ccs/ka",start:5259704,end:5259828},{filename:"/espeak-ng-data/lang/cel/cy",start:5259828,end:5259865},{filename:"/espeak-ng-data/lang/cel/ga",start:5259865,end:5259931},{filename:"/espeak-ng-data/lang/cel/gd",start:5259931,end:5259982},{filename:"/espeak-ng-data/lang/cus/om",start:5259982,end:5260021},{filename:"/espeak-ng-data/lang/dra/kn",start:5260021,end:5260076},{filename:"/espeak-ng-data/lang/dra/ml",start:5260076,end:5260133},{filename:"/espeak-ng-data/lang/dra/ta",start:5260133,end:5260184},{filename:"/espeak-ng-data/lang/dra/te",start:5260184,end:5260254},{filename:"/espeak-ng-data/lang/esx/kl",start:5260254,end:5260284},{filename:"/espeak-ng-data/lang/eu",start:5260284,end:5260338},{filename:"/espeak-ng-data/lang/gmq/da",start:5260338,end:5260381},{filename:"/espeak-ng-data/lang/gmq/is",start:5260381,end:5260408},{filename:"/espeak-ng-data/lang/gmq/nb",start:5260408,end:5260495},{filename:"/espeak-ng-data/lang/gmq/sv",start:5260495,end:5260520},{filename:"/espeak-ng-data/lang/gmw/af",start:5260520,end:5260643},{filename:"/espeak-ng-data/lang/gmw/de",start:5260643,end:5260685},{filename:"/espeak-ng-data/lang/gmw/en",start:5260685,end:5260825},{filename:"/espeak-ng-data/lang/gmw/en-029",start:5260825,end:5261160},{filename:"/espeak-ng-data/lang/gmw/en-GB-scotland",start:5261160,end:5261455},{filename:"/espeak-ng-data/lang/gmw/en-GB-x-gbclan",start:5261455,end:5261693},{filename:"/espeak-ng-data/lang/gmw/en-GB-x-gbcwmd",start:5261693,end:5261881},{filename:"/espeak-ng-data/lang/gmw/en-GB-x-rp",start:5261881,end:5262130},{filename:"/espeak-ng-data/lang/gmw/en-US",start:5262130,end:5262387},{filename:"/espeak-ng-data/lang/gmw/en-US-nyc",start:5262387,end:5262658},{filename:"/espeak-ng-data/lang/gmw/lb",start:5262658,end:5262689},{filename:"/espeak-ng-data/lang/gmw/nl",start:5262689,end:5262712},{filename:"/espeak-ng-data/lang/grk/el",start:5262712,end:5262735},{filename:"/espeak-ng-data/lang/grk/grc",start:5262735,end:5262834},{filename:"/espeak-ng-data/lang/inc/as",start:5262834,end:5262876},{filename:"/espeak-ng-data/lang/inc/bn",start:5262876,end:5262901},{filename:"/espeak-ng-data/lang/inc/bpy",start:5262901,end:5262940},{filename:"/espeak-ng-data/lang/inc/gu",start:5262940,end:5262982},{filename:"/espeak-ng-data/lang/inc/hi",start:5262982,end:5263005},{filename:"/espeak-ng-data/lang/inc/kok",start:5263005,end:5263031},{filename:"/espeak-ng-data/lang/inc/mr",start:5263031,end:5263072},{filename:"/espeak-ng-data/lang/inc/ne",start:5263072,end:5263109},{filename:"/espeak-ng-data/lang/inc/or",start:5263109,end:5263148},{filename:"/espeak-ng-data/lang/inc/pa",start:5263148,end:5263173},{filename:"/espeak-ng-data/lang/inc/sd",start:5263173,end:5263239},{filename:"/espeak-ng-data/lang/inc/si",start:5263239,end:5263294},{filename:"/espeak-ng-data/lang/inc/ur",start:5263294,end:5263388},{filename:"/espeak-ng-data/lang/ine/hy",start:5263388,end:5263449},{filename:"/espeak-ng-data/lang/ine/hyw",start:5263449,end:5263814},{filename:"/espeak-ng-data/lang/ine/sq",start:5263814,end:5263917},{filename:"/espeak-ng-data/lang/ira/fa",start:5263917,end:5264007},{filename:"/espeak-ng-data/lang/ira/fa-Latn",start:5264007,end:5264276},{filename:"/espeak-ng-data/lang/ira/ku",start:5264276,end:5264316},{filename:"/espeak-ng-data/lang/iro/chr",start:5264316,end:5264885},{filename:"/espeak-ng-data/lang/itc/la",start:5264885,end:5265182},{filename:"/espeak-ng-data/lang/jpx/ja",start:5265182,end:5265234},{filename:"/espeak-ng-data/lang/ko",start:5265234,end:5265285},{filename:"/espeak-ng-data/lang/map/haw",start:5265285,end:5265327},{filename:"/espeak-ng-data/lang/miz/mto",start:5265327,end:5265510},{filename:"/espeak-ng-data/lang/myn/quc",start:5265510,end:5265720},{filename:"/espeak-ng-data/lang/poz/id",start:5265720,end:5265854},{filename:"/espeak-ng-data/lang/poz/mi",start:5265854,end:5266221},{filename:"/espeak-ng-data/lang/poz/ms",start:5266221,end:5266651},{filename:"/espeak-ng-data/lang/qu",start:5266651,end:5266739},{filename:"/espeak-ng-data/lang/roa/an",start:5266739,end:5266766},{filename:"/espeak-ng-data/lang/roa/ca",start:5266766,end:5266791},{filename:"/espeak-ng-data/lang/roa/es",start:5266791,end:5266854},{filename:"/espeak-ng-data/lang/roa/es-419",start:5266854,end:5267021},{filename:"/espeak-ng-data/lang/roa/fr",start:5267021,end:5267100},{filename:"/espeak-ng-data/lang/roa/fr-BE",start:5267100,end:5267184},{filename:"/espeak-ng-data/lang/roa/fr-CH",start:5267184,end:5267270},{filename:"/espeak-ng-data/lang/roa/ht",start:5267270,end:5267410},{filename:"/espeak-ng-data/lang/roa/it",start:5267410,end:5267519},{filename:"/espeak-ng-data/lang/roa/pap",start:5267519,end:5267581},{filename:"/espeak-ng-data/lang/roa/pt",start:5267581,end:5267676},{filename:"/espeak-ng-data/lang/roa/pt-BR",start:5267676,end:5267785},{filename:"/espeak-ng-data/lang/roa/ro",start:5267785,end:5267811},{filename:"/espeak-ng-data/lang/sai/gn",start:5267811,end:5267858},{filename:"/espeak-ng-data/lang/sem/am",start:5267858,end:5267899},{filename:"/espeak-ng-data/lang/sem/ar",start:5267899,end:5267949},{filename:"/espeak-ng-data/lang/sem/he",start:5267949,end:5267989},{filename:"/espeak-ng-data/lang/sem/mt",start:5267989,end:5268030},{filename:"/espeak-ng-data/lang/sit/cmn",start:5268030,end:5268716},{filename:"/espeak-ng-data/lang/sit/cmn-Latn-pinyin",start:5268716,end:5268877},{filename:"/espeak-ng-data/lang/sit/hak",start:5268877,end:5269005},{filename:"/espeak-ng-data/lang/sit/my",start:5269005,end:5269061},{filename:"/espeak-ng-data/lang/sit/yue",start:5269061,end:5269255},{filename:"/espeak-ng-data/lang/sit/yue-Latn-jyutping",start:5269255,end:5269468},{filename:"/espeak-ng-data/lang/tai/shn",start:5269468,end:5269560},{filename:"/espeak-ng-data/lang/tai/th",start:5269560,end:5269597},{filename:"/espeak-ng-data/lang/trk/az",start:5269597,end:5269642},{filename:"/espeak-ng-data/lang/trk/ba",start:5269642,end:5269667},{filename:"/espeak-ng-data/lang/trk/cv",start:5269667,end:5269707},{filename:"/espeak-ng-data/lang/trk/kk",start:5269707,end:5269747},{filename:"/espeak-ng-data/lang/trk/ky",start:5269747,end:5269790},{filename:"/espeak-ng-data/lang/trk/nog",start:5269790,end:5269829},{filename:"/espeak-ng-data/lang/trk/tk",start:5269829,end:5269854},{filename:"/espeak-ng-data/lang/trk/tr",start:5269854,end:5269879},{filename:"/espeak-ng-data/lang/trk/tt",start:5269879,end:5269902},{filename:"/espeak-ng-data/lang/trk/ug",start:5269902,end:5269926},{filename:"/espeak-ng-data/lang/trk/uz",start:5269926,end:5269965},{filename:"/espeak-ng-data/lang/urj/et",start:5269965,end:5270202},{filename:"/espeak-ng-data/lang/urj/fi",start:5270202,end:5270439},{filename:"/espeak-ng-data/lang/urj/hu",start:5270439,end:5270512},{filename:"/espeak-ng-data/lang/urj/smj",start:5270512,end:5270557},{filename:"/espeak-ng-data/lang/zle/be",start:5270557,end:5270609},{filename:"/espeak-ng-data/lang/zle/ru",start:5270609,end:5270666},{filename:"/espeak-ng-data/lang/zle/ru-LV",start:5270666,end:5270946},{filename:"/espeak-ng-data/lang/zle/ru-cl",start:5270946,end:5271037},{filename:"/espeak-ng-data/lang/zle/uk",start:5271037,end:5271134},{filename:"/espeak-ng-data/lang/zls/bg",start:5271134,end:5271245},{filename:"/espeak-ng-data/lang/zls/bs",start:5271245,end:5271475},{filename:"/espeak-ng-data/lang/zls/hr",start:5271475,end:5271737},{filename:"/espeak-ng-data/lang/zls/mk",start:5271737,end:5271765},{filename:"/espeak-ng-data/lang/zls/sl",start:5271765,end:5271808},{filename:"/espeak-ng-data/lang/zls/sr",start:5271808,end:5272058},{filename:"/espeak-ng-data/lang/zlw/cs",start:5272058,end:5272081},{filename:"/espeak-ng-data/lang/zlw/pl",start:5272081,end:5272119},{filename:"/espeak-ng-data/lang/zlw/sk",start:5272119,end:5272143},{filename:"/espeak-ng-data/lb_dict",start:5272143,end:5960074},{filename:"/espeak-ng-data/lfn_dict",start:5960074,end:5962867},{filename:"/espeak-ng-data/lt_dict",start:5962867,end:6012757},{filename:"/espeak-ng-data/lv_dict",start:6012757,end:6079094},{filename:"/espeak-ng-data/mbrola_ph/af1_phtrans",start:6079094,end:6080730},{filename:"/espeak-ng-data/mbrola_ph/ar1_phtrans",start:6080730,end:6082342},{filename:"/espeak-ng-data/mbrola_ph/ar2_phtrans",start:6082342,end:6083954},{filename:"/espeak-ng-data/mbrola_ph/ca_phtrans",start:6083954,end:6085950},{filename:"/espeak-ng-data/mbrola_ph/cmn_phtrans",start:6085950,end:6087442},{filename:"/espeak-ng-data/mbrola_ph/cr1_phtrans",start:6087442,end:6089606},{filename:"/espeak-ng-data/mbrola_ph/cs_phtrans",start:6089606,end:6090186},{filename:"/espeak-ng-data/mbrola_ph/de2_phtrans",start:6090186,end:6091918},{filename:"/espeak-ng-data/mbrola_ph/de4_phtrans",start:6091918,end:6093722},{filename:"/espeak-ng-data/mbrola_ph/de6_phtrans",start:6093722,end:6095118},{filename:"/espeak-ng-data/mbrola_ph/de8_phtrans",start:6095118,end:6096274},{filename:"/espeak-ng-data/mbrola_ph/ee1_phtrans",start:6096274,end:6097718},{filename:"/espeak-ng-data/mbrola_ph/en1_phtrans",start:6097718,end:6098514},{filename:"/espeak-ng-data/mbrola_ph/es3_phtrans",start:6098514,end:6099574},{filename:"/espeak-ng-data/mbrola_ph/es4_phtrans",start:6099574,end:6100682},{filename:"/espeak-ng-data/mbrola_ph/es_phtrans",start:6100682,end:6102414},{filename:"/espeak-ng-data/mbrola_ph/fr_phtrans",start:6102414,end:6104386},{filename:"/espeak-ng-data/mbrola_ph/gr1_phtrans",start:6104386,end:6106598},{filename:"/espeak-ng-data/mbrola_ph/gr2_phtrans",start:6106598,end:6108810},{filename:"/espeak-ng-data/mbrola_ph/grc-de6_phtrans",start:6108810,end:6109294},{filename:"/espeak-ng-data/mbrola_ph/he_phtrans",start:6109294,end:6110042},{filename:"/espeak-ng-data/mbrola_ph/hn1_phtrans",start:6110042,end:6110574},{filename:"/espeak-ng-data/mbrola_ph/hu1_phtrans",start:6110574,end:6112018},{filename:"/espeak-ng-data/mbrola_ph/ic1_phtrans",start:6112018,end:6113150},{filename:"/espeak-ng-data/mbrola_ph/id1_phtrans",start:6113150,end:6114858},{filename:"/espeak-ng-data/mbrola_ph/in_phtrans",start:6114858,end:6116302},{filename:"/espeak-ng-data/mbrola_ph/ir1_phtrans",start:6116302,end:6122114},{filename:"/espeak-ng-data/mbrola_ph/it1_phtrans",start:6122114,end:6123438},{filename:"/espeak-ng-data/mbrola_ph/it3_phtrans",start:6123438,end:6124330},{filename:"/espeak-ng-data/mbrola_ph/jp_phtrans",start:6124330,end:6125366},{filename:"/espeak-ng-data/mbrola_ph/la1_phtrans",start:6125366,end:6126114},{filename:"/espeak-ng-data/mbrola_ph/lt_phtrans",start:6126114,end:6127174},{filename:"/espeak-ng-data/mbrola_ph/ma1_phtrans",start:6127174,end:6128114},{filename:"/espeak-ng-data/mbrola_ph/mx1_phtrans",start:6128114,end:6129918},{filename:"/espeak-ng-data/mbrola_ph/mx2_phtrans",start:6129918,end:6131746},{filename:"/espeak-ng-data/mbrola_ph/nl_phtrans",start:6131746,end:6133430},{filename:"/espeak-ng-data/mbrola_ph/nz1_phtrans",start:6133430,end:6134154},{filename:"/espeak-ng-data/mbrola_ph/pl1_phtrans",start:6134154,end:6135742},{filename:"/espeak-ng-data/mbrola_ph/pt1_phtrans",start:6135742,end:6137834},{filename:"/espeak-ng-data/mbrola_ph/ptbr4_phtrans",start:6137834,end:6140190},{filename:"/espeak-ng-data/mbrola_ph/ptbr_phtrans",start:6140190,end:6142714},{filename:"/espeak-ng-data/mbrola_ph/ro1_phtrans",start:6142714,end:6144878},{filename:"/espeak-ng-data/mbrola_ph/sv2_phtrans",start:6144878,end:6146466},{filename:"/espeak-ng-data/mbrola_ph/sv_phtrans",start:6146466,end:6148054},{filename:"/espeak-ng-data/mbrola_ph/tl1_phtrans",start:6148054,end:6148826},{filename:"/espeak-ng-data/mbrola_ph/tr1_phtrans",start:6148826,end:6149190},{filename:"/espeak-ng-data/mbrola_ph/us3_phtrans",start:6149190,end:6150346},{filename:"/espeak-ng-data/mbrola_ph/us_phtrans",start:6150346,end:6151574},{filename:"/espeak-ng-data/mbrola_ph/vz_phtrans",start:6151574,end:6153858},{filename:"/espeak-ng-data/mi_dict",start:6153858,end:6155204},{filename:"/espeak-ng-data/mk_dict",start:6155204,end:6219063},{filename:"/espeak-ng-data/ml_dict",start:6219063,end:6311408},{filename:"/espeak-ng-data/mr_dict",start:6311408,end:6398799},{filename:"/espeak-ng-data/ms_dict",start:6398799,end:6452340},{filename:"/espeak-ng-data/mt_dict",start:6452340,end:6456724},{filename:"/espeak-ng-data/mto_dict",start:6456724,end:6460684},{filename:"/espeak-ng-data/my_dict",start:6460684,end:6556632},{filename:"/espeak-ng-data/nci_dict",start:6556632,end:6558166},{filename:"/espeak-ng-data/ne_dict",start:6558166,end:6653543},{filename:"/espeak-ng-data/nl_dict",start:6653543,end:6719522},{filename:"/espeak-ng-data/no_dict",start:6719522,end:6723700},{filename:"/espeak-ng-data/nog_dict",start:6723700,end:6726994},{filename:"/espeak-ng-data/om_dict",start:6726994,end:6729296},{filename:"/espeak-ng-data/or_dict",start:6729296,end:6818542},{filename:"/espeak-ng-data/pa_dict",start:6818542,end:6898495},{filename:"/espeak-ng-data/pap_dict",start:6898495,end:6900623},{filename:"/espeak-ng-data/phondata",start:6900623,end:7451047},{filename:"/espeak-ng-data/phondata-manifest",start:7451047,end:7472868},{filename:"/espeak-ng-data/phonindex",start:7472868,end:7511942},{filename:"/espeak-ng-data/phontab",start:7511942,end:7567738},{filename:"/espeak-ng-data/piqd_dict",start:7567738,end:7569448},{filename:"/espeak-ng-data/pl_dict",start:7569448,end:7646178},{filename:"/espeak-ng-data/pt_dict",start:7646178,end:7713995},{filename:"/espeak-ng-data/py_dict",start:7713995,end:7716404},{filename:"/espeak-ng-data/qdb_dict",start:7716404,end:7719432},{filename:"/espeak-ng-data/qu_dict",start:7719432,end:7721351},{filename:"/espeak-ng-data/quc_dict",start:7721351,end:7722801},{filename:"/espeak-ng-data/qya_dict",start:7722801,end:7724740},{filename:"/espeak-ng-data/ro_dict",start:7724740,end:7793278},{filename:"/espeak-ng-data/ru_dict",start:7793278,end:16325670},{filename:"/espeak-ng-data/sd_dict",start:16325670,end:16385598},{filename:"/espeak-ng-data/shn_dict",start:16385598,end:16473770},{filename:"/espeak-ng-data/si_dict",start:16473770,end:16559154},{filename:"/espeak-ng-data/sjn_dict",start:16559154,end:16560937},{filename:"/espeak-ng-data/sk_dict",start:16560937,end:16610939},{filename:"/espeak-ng-data/sl_dict",start:16610939,end:16655986},{filename:"/espeak-ng-data/smj_dict",start:16655986,end:16691081},{filename:"/espeak-ng-data/sq_dict",start:16691081,end:16736084},{filename:"/espeak-ng-data/sr_dict",start:16736084,end:16782916},{filename:"/espeak-ng-data/sv_dict",start:16782916,end:16830752},{filename:"/espeak-ng-data/sw_dict",start:16830752,end:16878556},{filename:"/espeak-ng-data/ta_dict",start:16878556,end:17088109},{filename:"/espeak-ng-data/te_dict",start:17088109,end:17182946},{filename:"/espeak-ng-data/th_dict",start:17182946,end:17185247},{filename:"/espeak-ng-data/tk_dict",start:17185247,end:17206115},{filename:"/espeak-ng-data/tn_dict",start:17206115,end:17209187},{filename:"/espeak-ng-data/tr_dict",start:17209187,end:17255980},{filename:"/espeak-ng-data/tt_dict",start:17255980,end:17258101},{filename:"/espeak-ng-data/ug_dict",start:17258101,end:17260171},{filename:"/espeak-ng-data/uk_dict",start:17260171,end:17263663},{filename:"/espeak-ng-data/ur_dict",start:17263663,end:17397219},{filename:"/espeak-ng-data/uz_dict",start:17397219,end:17399759},{filename:"/espeak-ng-data/vi_dict",start:17399759,end:17452367},{filename:"/espeak-ng-data/voices/!v/Alex",start:17452367,end:17452495},{filename:"/espeak-ng-data/voices/!v/Alicia",start:17452495,end:17452969},{filename:"/espeak-ng-data/voices/!v/Andrea",start:17452969,end:17453326},{filename:"/espeak-ng-data/voices/!v/Andy",start:17453326,end:17453646},{filename:"/espeak-ng-data/voices/!v/Annie",start:17453646,end:17453961},{filename:"/espeak-ng-data/voices/!v/AnxiousAndy",start:17453961,end:17454322},{filename:"/espeak-ng-data/voices/!v/Demonic",start:17454322,end:17458180},{filename:"/espeak-ng-data/voices/!v/Denis",start:17458180,end:17458485},{filename:"/espeak-ng-data/voices/!v/Diogo",start:17458485,end:17458864},{filename:"/espeak-ng-data/voices/!v/Gene",start:17458864,end:17459145},{filename:"/espeak-ng-data/voices/!v/Gene2",start:17459145,end:17459428},{filename:"/espeak-ng-data/voices/!v/Henrique",start:17459428,end:17459809},{filename:"/espeak-ng-data/voices/!v/Hugo",start:17459809,end:17460187},{filename:"/espeak-ng-data/voices/!v/Jacky",start:17460187,end:17460454},{filename:"/espeak-ng-data/voices/!v/Lee",start:17460454,end:17460792},{filename:"/espeak-ng-data/voices/!v/Marco",start:17460792,end:17461259},{filename:"/espeak-ng-data/voices/!v/Mario",start:17461259,end:17461529},{filename:"/espeak-ng-data/voices/!v/Michael",start:17461529,end:17461799},{filename:"/espeak-ng-data/voices/!v/Mike",start:17461799,end:17461911},{filename:"/espeak-ng-data/voices/!v/Mr serious",start:17461911,end:17465104},{filename:"/espeak-ng-data/voices/!v/Nguyen",start:17465104,end:17465384},{filename:"/espeak-ng-data/voices/!v/Reed",start:17465384,end:17465586},{filename:"/espeak-ng-data/voices/!v/RicishayMax",start:17465586,end:17465819},{filename:"/espeak-ng-data/voices/!v/RicishayMax2",start:17465819,end:17466254},{filename:"/espeak-ng-data/voices/!v/RicishayMax3",start:17466254,end:17466689},{filename:"/espeak-ng-data/voices/!v/Storm",start:17466689,end:17467109},{filename:"/espeak-ng-data/voices/!v/Tweaky",start:17467109,end:17470298},{filename:"/espeak-ng-data/voices/!v/UniRobot",start:17470298,end:17470715},{filename:"/espeak-ng-data/voices/!v/adam",start:17470715,end:17470790},{filename:"/espeak-ng-data/voices/!v/anika",start:17470790,end:17471283},{filename:"/espeak-ng-data/voices/!v/anikaRobot",start:17471283,end:17471795},{filename:"/espeak-ng-data/voices/!v/announcer",start:17471795,end:17472095},{filename:"/espeak-ng-data/voices/!v/antonio",start:17472095,end:17472476},{filename:"/espeak-ng-data/voices/!v/aunty",start:17472476,end:17472834},{filename:"/espeak-ng-data/voices/!v/belinda",start:17472834,end:17473174},{filename:"/espeak-ng-data/voices/!v/benjamin",start:17473174,end:17473375},{filename:"/espeak-ng-data/voices/!v/boris",start:17473375,end:17473599},{filename:"/espeak-ng-data/voices/!v/caleb",start:17473599,end:17473656},{filename:"/espeak-ng-data/voices/!v/croak",start:17473656,end:17473749},{filename:"/espeak-ng-data/voices/!v/david",start:17473749,end:17473861},{filename:"/espeak-ng-data/voices/!v/ed",start:17473861,end:17474148},{filename:"/espeak-ng-data/voices/!v/edward",start:17474148,end:17474299},{filename:"/espeak-ng-data/voices/!v/edward2",start:17474299,end:17474451},{filename:"/espeak-ng-data/voices/!v/f1",start:17474451,end:17474775},{filename:"/espeak-ng-data/voices/!v/f2",start:17474775,end:17475132},{filename:"/espeak-ng-data/voices/!v/f3",start:17475132,end:17475507},{filename:"/espeak-ng-data/voices/!v/f4",start:17475507,end:17475857},{filename:"/espeak-ng-data/voices/!v/f5",start:17475857,end:17476289},{filename:"/espeak-ng-data/voices/!v/fast",start:17476289,end:17476438},{filename:"/espeak-ng-data/voices/!v/grandma",start:17476438,end:17476701},{filename:"/espeak-ng-data/voices/!v/grandpa",start:17476701,end:17476957},{filename:"/espeak-ng-data/voices/!v/gustave",start:17476957,end:17477210},{filename:"/espeak-ng-data/voices/!v/ian",start:17477210,end:17480378},{filename:"/espeak-ng-data/voices/!v/iven",start:17480378,end:17480639},{filename:"/espeak-ng-data/voices/!v/iven2",start:17480639,end:17480918},{filename:"/espeak-ng-data/voices/!v/iven3",start:17480918,end:17481180},{filename:"/espeak-ng-data/voices/!v/iven4",start:17481180,end:17481441},{filename:"/espeak-ng-data/voices/!v/john",start:17481441,end:17484627},{filename:"/espeak-ng-data/voices/!v/kaukovalta",start:17484627,end:17484988},{filename:"/espeak-ng-data/voices/!v/klatt",start:17484988,end:17485026},{filename:"/espeak-ng-data/voices/!v/klatt2",start:17485026,end:17485064},{filename:"/espeak-ng-data/voices/!v/klatt3",start:17485064,end:17485103},{filename:"/espeak-ng-data/voices/!v/klatt4",start:17485103,end:17485142},{filename:"/espeak-ng-data/voices/!v/klatt5",start:17485142,end:17485181},{filename:"/espeak-ng-data/voices/!v/klatt6",start:17485181,end:17485220},{filename:"/espeak-ng-data/voices/!v/linda",start:17485220,end:17485570},{filename:"/espeak-ng-data/voices/!v/m1",start:17485570,end:17485905},{filename:"/espeak-ng-data/voices/!v/m2",start:17485905,end:17486169},{filename:"/espeak-ng-data/voices/!v/m3",start:17486169,end:17486469},{filename:"/espeak-ng-data/voices/!v/m4",start:17486469,end:17486759},{filename:"/espeak-ng-data/voices/!v/m5",start:17486759,end:17487021},{filename:"/espeak-ng-data/voices/!v/m6",start:17487021,end:17487209},{filename:"/espeak-ng-data/voices/!v/m7",start:17487209,end:17487463},{filename:"/espeak-ng-data/voices/!v/m8",start:17487463,end:17487747},{filename:"/espeak-ng-data/voices/!v/marcelo",start:17487747,end:17487998},{filename:"/espeak-ng-data/voices/!v/max",start:17487998,end:17488223},{filename:"/espeak-ng-data/voices/!v/michel",start:17488223,end:17488627},{filename:"/espeak-ng-data/voices/!v/miguel",start:17488627,end:17489009},{filename:"/espeak-ng-data/voices/!v/mike2",start:17489009,end:17489197},{filename:"/espeak-ng-data/voices/!v/norbert",start:17489197,end:17492386},{filename:"/espeak-ng-data/voices/!v/pablo",start:17492386,end:17495528},{filename:"/espeak-ng-data/voices/!v/paul",start:17495528,end:17495812},{filename:"/espeak-ng-data/voices/!v/pedro",start:17495812,end:17496164},{filename:"/espeak-ng-data/voices/!v/quincy",start:17496164,end:17496518},{filename:"/espeak-ng-data/voices/!v/rob",start:17496518,end:17496783},{filename:"/espeak-ng-data/voices/!v/robert",start:17496783,end:17497057},{filename:"/espeak-ng-data/voices/!v/robosoft",start:17497057,end:17497508},{filename:"/espeak-ng-data/voices/!v/robosoft2",start:17497508,end:17497962},{filename:"/espeak-ng-data/voices/!v/robosoft3",start:17497962,end:17498417},{filename:"/espeak-ng-data/voices/!v/robosoft4",start:17498417,end:17498864},{filename:"/espeak-ng-data/voices/!v/robosoft5",start:17498864,end:17499309},{filename:"/espeak-ng-data/voices/!v/robosoft6",start:17499309,end:17499596},{filename:"/espeak-ng-data/voices/!v/robosoft7",start:17499596,end:17500006},{filename:"/espeak-ng-data/voices/!v/robosoft8",start:17500006,end:17500249},{filename:"/espeak-ng-data/voices/!v/sandro",start:17500249,end:17500779},{filename:"/espeak-ng-data/voices/!v/shelby",start:17500779,end:17501059},{filename:"/espeak-ng-data/voices/!v/steph",start:17501059,end:17501423},{filename:"/espeak-ng-data/voices/!v/steph2",start:17501423,end:17501790},{filename:"/espeak-ng-data/voices/!v/steph3",start:17501790,end:17502167},{filename:"/espeak-ng-data/voices/!v/travis",start:17502167,end:17502550},{filename:"/espeak-ng-data/voices/!v/victor",start:17502550,end:17502803},{filename:"/espeak-ng-data/voices/!v/whisper",start:17502803,end:17502989},{filename:"/espeak-ng-data/voices/!v/whisperf",start:17502989,end:17503381},{filename:"/espeak-ng-data/voices/!v/zac",start:17503381,end:17503656},{filename:"/espeak-ng-data/voices/mb/mb-af1",start:17503656,end:17503744},{filename:"/espeak-ng-data/voices/mb/mb-af1-en",start:17503744,end:17503827},{filename:"/espeak-ng-data/voices/mb/mb-ar1",start:17503827,end:17503911},{filename:"/espeak-ng-data/voices/mb/mb-ar2",start:17503911,end:17503995},{filename:"/espeak-ng-data/voices/mb/mb-br1",start:17503995,end:17504127},{filename:"/espeak-ng-data/voices/mb/mb-br2",start:17504127,end:17504263},{filename:"/espeak-ng-data/voices/mb/mb-br3",start:17504263,end:17504395},{filename:"/espeak-ng-data/voices/mb/mb-br4",start:17504395,end:17504531},{filename:"/espeak-ng-data/voices/mb/mb-ca1",start:17504531,end:17504636},{filename:"/espeak-ng-data/voices/mb/mb-ca2",start:17504636,end:17504741},{filename:"/espeak-ng-data/voices/mb/mb-cn1",start:17504741,end:17504833},{filename:"/espeak-ng-data/voices/mb/mb-cr1",start:17504833,end:17504944},{filename:"/espeak-ng-data/voices/mb/mb-cz1",start:17504944,end:17505014},{filename:"/espeak-ng-data/voices/mb/mb-cz2",start:17505014,end:17505096},{filename:"/espeak-ng-data/voices/mb/mb-de1",start:17505096,end:17505240},{filename:"/espeak-ng-data/voices/mb/mb-de1-en",start:17505240,end:17505336},{filename:"/espeak-ng-data/voices/mb/mb-de2",start:17505336,end:17505464},{filename:"/espeak-ng-data/voices/mb/mb-de2-en",start:17505464,end:17505544},{filename:"/espeak-ng-data/voices/mb/mb-de3",start:17505544,end:17505643},{filename:"/espeak-ng-data/voices/mb/mb-de3-en",start:17505643,end:17505739},{filename:"/espeak-ng-data/voices/mb/mb-de4",start:17505739,end:17505868},{filename:"/espeak-ng-data/voices/mb/mb-de4-en",start:17505868,end:17505949},{filename:"/espeak-ng-data/voices/mb/mb-de5",start:17505949,end:17506185},{filename:"/espeak-ng-data/voices/mb/mb-de5-en",start:17506185,end:17506275},{filename:"/espeak-ng-data/voices/mb/mb-de6",start:17506275,end:17506397},{filename:"/espeak-ng-data/voices/mb/mb-de6-en",start:17506397,end:17506471},{filename:"/espeak-ng-data/voices/mb/mb-de6-grc",start:17506471,end:17506554},{filename:"/espeak-ng-data/voices/mb/mb-de7",start:17506554,end:17506704},{filename:"/espeak-ng-data/voices/mb/mb-de8",start:17506704,end:17506775},{filename:"/espeak-ng-data/voices/mb/mb-ee1",start:17506775,end:17506872},{filename:"/espeak-ng-data/voices/mb/mb-en1",start:17506872,end:17507003},{filename:"/espeak-ng-data/voices/mb/mb-es1",start:17507003,end:17507117},{filename:"/espeak-ng-data/voices/mb/mb-es2",start:17507117,end:17507225},{filename:"/espeak-ng-data/voices/mb/mb-es3",start:17507225,end:17507329},{filename:"/espeak-ng-data/voices/mb/mb-es4",start:17507329,end:17507417},{filename:"/espeak-ng-data/voices/mb/mb-fr1",start:17507417,end:17507583},{filename:"/espeak-ng-data/voices/mb/mb-fr1-en",start:17507583,end:17507687},{filename:"/espeak-ng-data/voices/mb/mb-fr2",start:17507687,end:17507790},{filename:"/espeak-ng-data/voices/mb/mb-fr3",start:17507790,end:17507890},{filename:"/espeak-ng-data/voices/mb/mb-fr4",start:17507890,end:17508017},{filename:"/espeak-ng-data/voices/mb/mb-fr4-en",start:17508017,end:17508124},{filename:"/espeak-ng-data/voices/mb/mb-fr5",start:17508124,end:17508224},{filename:"/espeak-ng-data/voices/mb/mb-fr6",start:17508224,end:17508324},{filename:"/espeak-ng-data/voices/mb/mb-fr7",start:17508324,end:17508407},{filename:"/espeak-ng-data/voices/mb/mb-gr1",start:17508407,end:17508501},{filename:"/espeak-ng-data/voices/mb/mb-gr2",start:17508501,end:17508595},{filename:"/espeak-ng-data/voices/mb/mb-gr2-en",start:17508595,end:17508683},{filename:"/espeak-ng-data/voices/mb/mb-hb1",start:17508683,end:17508751},{filename:"/espeak-ng-data/voices/mb/mb-hb2",start:17508751,end:17508834},{filename:"/espeak-ng-data/voices/mb/mb-hu1",start:17508834,end:17508936},{filename:"/espeak-ng-data/voices/mb/mb-hu1-en",start:17508936,end:17509033},{filename:"/espeak-ng-data/voices/mb/mb-ic1",start:17509033,end:17509121},{filename:"/espeak-ng-data/voices/mb/mb-id1",start:17509121,end:17509222},{filename:"/espeak-ng-data/voices/mb/mb-in1",start:17509222,end:17509291},{filename:"/espeak-ng-data/voices/mb/mb-in2",start:17509291,end:17509376},{filename:"/espeak-ng-data/voices/mb/mb-ir1",start:17509376,end:17510129},{filename:"/espeak-ng-data/voices/mb/mb-it1",start:17510129,end:17510213},{filename:"/espeak-ng-data/voices/mb/mb-it2",start:17510213,end:17510300},{filename:"/espeak-ng-data/voices/mb/mb-it3",start:17510300,end:17510442},{filename:"/espeak-ng-data/voices/mb/mb-it4",start:17510442,end:17510587},{filename:"/espeak-ng-data/voices/mb/mb-jp1",start:17510587,end:17510658},{filename:"/espeak-ng-data/voices/mb/mb-jp2",start:17510658,end:17510759},{filename:"/espeak-ng-data/voices/mb/mb-jp3",start:17510759,end:17510846},{filename:"/espeak-ng-data/voices/mb/mb-la1",start:17510846,end:17510929},{filename:"/espeak-ng-data/voices/mb/mb-lt1",start:17510929,end:17511016},{filename:"/espeak-ng-data/voices/mb/mb-lt2",start:17511016,end:17511103},{filename:"/espeak-ng-data/voices/mb/mb-ma1",start:17511103,end:17511201},{filename:"/espeak-ng-data/voices/mb/mb-mx1",start:17511201,end:17511321},{filename:"/espeak-ng-data/voices/mb/mb-mx2",start:17511321,end:17511441},{filename:"/espeak-ng-data/voices/mb/mb-nl1",start:17511441,end:17511510},{filename:"/espeak-ng-data/voices/mb/mb-nl2",start:17511510,end:17511606},{filename:"/espeak-ng-data/voices/mb/mb-nl2-en",start:17511606,end:17511697},{filename:"/espeak-ng-data/voices/mb/mb-nl3",start:17511697,end:17511782},{filename:"/espeak-ng-data/voices/mb/mb-nz1",start:17511782,end:17511850},{filename:"/espeak-ng-data/voices/mb/mb-pl1",start:17511850,end:17511949},{filename:"/espeak-ng-data/voices/mb/mb-pl1-en",start:17511949,end:17512031},{filename:"/espeak-ng-data/voices/mb/mb-pt1",start:17512031,end:17512162},{filename:"/espeak-ng-data/voices/mb/mb-ro1",start:17512162,end:17512249},{filename:"/espeak-ng-data/voices/mb/mb-ro1-en",start:17512249,end:17512330},{filename:"/espeak-ng-data/voices/mb/mb-sw1",start:17512330,end:17512428},{filename:"/espeak-ng-data/voices/mb/mb-sw1-en",start:17512428,end:17512521},{filename:"/espeak-ng-data/voices/mb/mb-sw2",start:17512521,end:17512623},{filename:"/espeak-ng-data/voices/mb/mb-sw2-en",start:17512623,end:17512722},{filename:"/espeak-ng-data/voices/mb/mb-tl1",start:17512722,end:17512807},{filename:"/espeak-ng-data/voices/mb/mb-tr1",start:17512807,end:17512892},{filename:"/espeak-ng-data/voices/mb/mb-tr2",start:17512892,end:17513006},{filename:"/espeak-ng-data/voices/mb/mb-us1",start:17513006,end:17513176},{filename:"/espeak-ng-data/voices/mb/mb-us2",start:17513176,end:17513354},{filename:"/espeak-ng-data/voices/mb/mb-us3",start:17513354,end:17513534},{filename:"/espeak-ng-data/voices/mb/mb-vz1",start:17513534,end:17513678},{filename:"/espeak-ng-data/yue_dict",start:17513678,end:18077249}],remote_package_size:18077249})}();var A=Object.assign({},R),q=[],Y="./this.program",E=(x,c)=>{throw c},O=typeof window=="object",N=typeof importScripts=="function",W=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",I="";function z(x){if(R.locateFile)return R.locateFile(x,I);return I+x}var j,P,F;if(W){var v=()=>({}),S=(K5(),C6(b$));if(N)I=S.dirname(I)+"/";else I=H5+"/";if(j=(x,c)=>{return x=mJ(x)?new URL(x):S.normalize(x),v.readFileSync(x,c?void 0:"utf8")},F=(x)=>{var c=j(x,!0);if(!c.buffer)c=new Uint8Array(c);return c},P=(x,c,s,r=!0)=>{x=mJ(x)?new URL(x):S.normalize(x),v.readFile(x,r?void 0:"utf8",(KJ,YJ)=>{if(KJ)s(KJ);else c(r?YJ.buffer:YJ)})},!R.thisProgram&&process.argv.length>1)Y=process.argv[1].replace(/\\/g,"/");q=process.argv.slice(2),E=(x,c)=>{throw process.exitCode=x,c},R.inspect=()=>"[Emscripten Module object]"}else if(O||N){if(N)I=self.location.href;else if(typeof document!="undefined"&&document.currentScript)I=document.currentScript.src;if(l)I=l;if(I.indexOf("blob:")!==0)I=I.substr(0,I.replace(/[?#].*/,"").lastIndexOf("/")+1);else I="";{if(j=(x)=>{var c=new XMLHttpRequest;return c.open("GET",x,!1),c.send(null),c.responseText},N)F=(x)=>{var c=new XMLHttpRequest;return c.open("GET",x,!1),c.responseType="arraybuffer",c.send(null),new Uint8Array(c.response)};P=(x,c,s)=>{var r=new XMLHttpRequest;r.open("GET",x,!0),r.responseType="arraybuffer",r.onload=()=>{if(r.status==200||r.status==0&&r.response){c(r.response);return}s()},r.onerror=s,r.send(null)}}}var w=R.print||console.log.bind(console),y=R.printErr||console.error.bind(console);if(Object.assign(R,A),A=null,R.arguments)q=R.arguments;if(R.thisProgram)Y=R.thisProgram;if(R.quit)E=R.quit;var m;if(R.wasmBinary)m=R.wasmBinary;if(typeof WebAssembly!="object")$J("no native wasm support detected");var i,JJ=!1,VJ;function HJ(x,c){if(!x)$J(c)}var o,jJ,J,V,Z,$,X,U;function H(){var x=i.buffer;R.HEAP8=o=new Int8Array(x),R.HEAP16=J=new Int16Array(x),R.HEAPU8=jJ=new Uint8Array(x),R.HEAPU16=V=new Uint16Array(x),R.HEAP32=Z=new Int32Array(x),R.HEAPU32=$=new Uint32Array(x),R.HEAPF32=X=new Float32Array(x),R.HEAPF64=U=new Float64Array(x)}var G=[],Q=[],K=[],k=[],L=!1;function _(){if(R.preRun){if(typeof R.preRun=="function")R.preRun=[R.preRun];while(R.preRun.length)n(R.preRun.shift())}d(G)}function t(){if(L=!0,!R.noFSInit&&!f.init.initialized)f.init();f.ignorePermissions=!1,WQ.init(),d(Q)}function QJ(){d(K)}function GJ(){if(R.postRun){if(typeof R.postRun=="function")R.postRun=[R.postRun];while(R.postRun.length)e(R.postRun.shift())}d(k)}function n(x){G.unshift(x)}function p(x){Q.unshift(x)}function e(x){k.unshift(x)}var PJ=0,XJ=null,WJ=null;function b(x){return x}function C(x){if(PJ++,R.monitorRunDependencies)R.monitorRunDependencies(PJ)}function h(x){if(PJ--,R.monitorRunDependencies)R.monitorRunDependencies(PJ);if(PJ==0){if(XJ!==null)clearInterval(XJ),XJ=null;if(WJ){var c=WJ;WJ=null,c()}}}function $J(x){if(R.onAbort)R.onAbort(x);x="Aborted("+x+")",y(x),JJ=!0,VJ=1,x+=". Build with -sASSERTIONS for more info.";var c=new WebAssembly.RuntimeError(x);throw B(c),c}var qJ="data:application/octet-stream;base64,",ZJ=(x)=>x.startsWith(qJ),mJ=(x)=>x.startsWith("file://"),BJ;if(BJ="piper_phonemize.wasm",!ZJ(BJ))BJ=z(BJ);function TJ(x){if(x==BJ&&m)return new Uint8Array(m);if(F)return F(x);throw"both async and sync fetching of the wasm failed"}function dJ(x){if(!m&&(O||N)){if(typeof fetch=="function"&&!mJ(x))return fetch(x,{credentials:"same-origin"}).then((c)=>{if(!c.ok)throw"failed to load wasm binary file at '"+x+"'";return c.arrayBuffer()}).catch(()=>TJ(x));else if(P)return new Promise((c,s)=>{P(x,(r)=>c(new Uint8Array(r)),s)})}return Promise.resolve().then(()=>TJ(x))}function LJ(x,c,s){return dJ(x).then((r)=>WebAssembly.instantiate(r,c)).then((r)=>r).then(s,(r)=>{y(`failed to asynchronously prepare wasm: ${r}`),$J(r)})}function IJ(x,c,s,r){if(!x&&typeof WebAssembly.instantiateStreaming=="function"&&!ZJ(c)&&!mJ(c)&&!W&&typeof fetch=="function")return fetch(c,{credentials:"same-origin"}).then((KJ)=>{var YJ=WebAssembly.instantiateStreaming(KJ,s);return YJ.then(r,function(DJ){return y(`wasm streaming compile failed: ${DJ}`),y("falling back to ArrayBuffer instantiation"),LJ(c,s,r)})});return LJ(c,s,r)}function $Q(){var x={a:Q5};function c(r,KJ){return uQ=r.exports,i=uQ.w,H(),p(uQ.x),h("wasm-instantiate"),uQ}C("wasm-instantiate");function s(r){c(r.instance)}if(R.instantiateWasm)try{return R.instantiateWasm(x,c)}catch(r){y(`Module.instantiateWasm callback failed with error: ${r}`),B(r)}return IJ(m,BJ,x,s).catch(B),{}}var T,D;function u(x){this.name="ExitStatus",this.message=`Program terminated with exit(${x})`,this.status=x}var d=(x)=>{while(x.length>0)x.shift()(R)},a=R.noExitRuntime||!0,CJ=typeof TextDecoder!="undefined"?new TextDecoder("utf8"):void 0,UJ=(x,c,s)=>{var r=c+s,KJ=c;while(x[KJ]&&!(KJ>=r))++KJ;if(KJ-c>16&&x.buffer&&CJ)return CJ.decode(x.subarray(c,KJ));var YJ="";while(c<KJ){var DJ=x[c++];if(!(DJ&128)){YJ+=String.fromCharCode(DJ);continue}var hJ=x[c++]&63;if((DJ&224)==192){YJ+=String.fromCharCode((DJ&31)<<6|hJ);continue}var pJ=x[c++]&63;if((DJ&240)==224)DJ=(DJ&15)<<12|hJ<<6|pJ;else DJ=(DJ&7)<<18|hJ<<12|pJ<<6|x[c++]&63;if(DJ<65536)YJ+=String.fromCharCode(DJ);else{var rJ=DJ-65536;YJ+=String.fromCharCode(55296|rJ>>10,56320|rJ&1023)}}return YJ},EJ=(x,c)=>x?UJ(jJ,x,c):"",QQ=(x,c,s,r)=>{$J(`Assertion failed: ${EJ(x)}, at: `+[c?EJ(c):"unknown filename",s,r?EJ(r):"unknown function"])};function FJ(x){this.excPtr=x,this.ptr=x-24,this.set_type=function(c){$[this.ptr+4>>2]=c},this.get_type=function(){return $[this.ptr+4>>2]},this.set_destructor=function(c){$[this.ptr+8>>2]=c},this.get_destructor=function(){return $[this.ptr+8>>2]},this.set_caught=function(c){c=c?1:0,o[this.ptr+12>>0]=c},this.get_caught=function(){return o[this.ptr+12>>0]!=0},this.set_rethrown=function(c){c=c?1:0,o[this.ptr+13>>0]=c},this.get_rethrown=function(){return o[this.ptr+13>>0]!=0},this.init=function(c,s){this.set_adjusted_ptr(0),this.set_type(c),this.set_destructor(s)},this.set_adjusted_ptr=function(c){$[this.ptr+16>>2]=c},this.get_adjusted_ptr=function(){return $[this.ptr+16>>2]},this.get_exception_ptr=function(){var c=b6(this.get_type());if(c)return $[this.excPtr>>2];var s=this.get_adjusted_ptr();if(s!==0)return s;return this.excPtr}}var RJ=0,aJ=0,SJ=(x,c,s)=>{var r=new FJ(x);throw r.init(c,s),RJ=x,aJ++,RJ},xJ=(x)=>{return Z[_6()>>2]=x,x},nJ={isAbs:(x)=>x.charAt(0)==="/",splitPath:(x)=>{var c=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;return c.exec(x).slice(1)},normalizeArray:(x,c)=>{var s=0;for(var r=x.length-1;r>=0;r--){var KJ=x[r];if(KJ===".")x.splice(r,1);else if(KJ==="..")x.splice(r,1),s++;else if(s)x.splice(r,1),s--}if(c)for(;s;s--)x.unshift("..");return x},normalize:(x)=>{var c=nJ.isAbs(x),s=x.substr(-1)==="/";if(x=nJ.normalizeArray(x.split("/").filter((r)=>!!r),!c).join("/"),!x&&!c)x=".";if(x&&s)x+="/";return(c?"/":"")+x},dirname:(x)=>{var c=nJ.splitPath(x),s=c[0],r=c[1];if(!s&&!r)return".";if(r)r=r.substr(0,r.length-1);return s+r},basename:(x)=>{if(x==="/")return"/";x=nJ.normalize(x),x=x.replace(/\/$/,"");var c=x.lastIndexOf("/");if(c===-1)return x;return x.substr(c+1)},join:function(){var x=Array.prototype.slice.call(arguments);return nJ.normalize(x.join("/"))},join2:(x,c)=>nJ.normalize(x+"/"+c)},AJ=()=>{if(typeof crypto=="object"&&typeof crypto.getRandomValues=="function")return(r)=>crypto.getRandomValues(r);else if(W)try{var x=(U5(),C6(y$)),c=x.randomFillSync;if(c)return(r)=>x.randomFillSync(r);var s=x.randomBytes;return(r)=>(r.set(s(r.byteLength)),r)}catch(r){}$J("initRandomDevice")},kJ=(x)=>(kJ=AJ())(x),ZQ={resolve:function(){var x="",c=!1;for(var s=arguments.length-1;s>=-1&&!c;s--){var r=s>=0?arguments[s]:f.cwd();if(typeof r!="string")throw new TypeError("Arguments to path.resolve must be strings");else if(!r)return"";x=r+"/"+x,c=nJ.isAbs(r)}return x=nJ.normalizeArray(x.split("/").filter((KJ)=>!!KJ),!c).join("/"),(c?"/":"")+x||"."},relative:(x,c)=>{x=ZQ.resolve(x).substr(1),c=ZQ.resolve(c).substr(1);function s(rJ){var VQ=0;for(;VQ<rJ.length;VQ++)if(rJ[VQ]!=="")break;var GQ=rJ.length-1;for(;GQ>=0;GQ--)if(rJ[GQ]!=="")break;if(VQ>GQ)return[];return rJ.slice(VQ,GQ-VQ+1)}var r=s(x.split("/")),KJ=s(c.split("/")),YJ=Math.min(r.length,KJ.length),DJ=YJ;for(var hJ=0;hJ<YJ;hJ++)if(r[hJ]!==KJ[hJ]){DJ=hJ;break}var pJ=[];for(var hJ=DJ;hJ<r.length;hJ++)pJ.push("..");return pJ=pJ.concat(KJ.slice(DJ)),pJ.join("/")}},vJ=[],MJ=(x)=>{var c=0;for(var s=0;s<x.length;++s){var r=x.charCodeAt(s);if(r<=127)c++;else if(r<=2047)c+=2;else if(r>=55296&&r<=57343)c+=4,++s;else c+=3}return c},xQ=(x,c,s,r)=>{if(!(r>0))return 0;var KJ=s,YJ=s+r-1;for(var DJ=0;DJ<x.length;++DJ){var hJ=x.charCodeAt(DJ);if(hJ>=55296&&hJ<=57343){var pJ=x.charCodeAt(++DJ);hJ=65536+((hJ&1023)<<10)|pJ&1023}if(hJ<=127){if(s>=YJ)break;c[s++]=hJ}else if(hJ<=2047){if(s+1>=YJ)break;c[s++]=192|hJ>>6,c[s++]=128|hJ&63}else if(hJ<=65535){if(s+2>=YJ)break;c[s++]=224|hJ>>12,c[s++]=128|hJ>>6&63,c[s++]=128|hJ&63}else{if(s+3>=YJ)break;c[s++]=240|hJ>>18,c[s++]=128|hJ>>12&63,c[s++]=128|hJ>>6&63,c[s++]=128|hJ&63}}return c[s]=0,s-KJ};function wJ(x,c,s){var r=s>0?s:MJ(x)+1,KJ=new Array(r),YJ=xQ(x,KJ,0,KJ.length);if(c)KJ.length=YJ;return KJ}var bJ=()=>{if(!vJ.length){var x=null;if(W){var c=256,s=Buffer.alloc(c),r=0,KJ=process.stdin.fd;try{r=v.readSync(KJ,s)}catch(YJ){if(YJ.toString().includes("EOF"))r=0;else throw YJ}if(r>0)x=s.slice(0,r).toString("utf-8");else x=null}else if(typeof window!="undefined"&&typeof window.prompt=="function"){if(x=window.prompt("Input: "),x!==null)x+="\n"}else if(typeof readline=="function"){if(x=readline(),x!==null)x+="\n"}if(!x)return null;vJ=wJ(x,!0)}return vJ.shift()},WQ={ttys:[],init(){},shutdown(){},register(x,c){WQ.ttys[x]={input:[],output:[],ops:c},f.registerDevice(x,WQ.stream_ops)},stream_ops:{open(x){var c=WQ.ttys[x.node.rdev];if(!c)throw new f.ErrnoError(43);x.tty=c,x.seekable=!1},close(x){x.tty.ops.fsync(x.tty)},fsync(x){x.tty.ops.fsync(x.tty)},read(x,c,s,r,KJ){if(!x.tty||!x.tty.ops.get_char)throw new f.ErrnoError(60);var YJ=0;for(var DJ=0;DJ<r;DJ++){var hJ;try{hJ=x.tty.ops.get_char(x.tty)}catch(pJ){throw new f.ErrnoError(29)}if(hJ===void 0&&YJ===0)throw new f.ErrnoError(6);if(hJ===null||hJ===void 0)break;YJ++,c[s+DJ]=hJ}if(YJ)x.node.timestamp=Date.now();return YJ},write(x,c,s,r,KJ){if(!x.tty||!x.tty.ops.put_char)throw new f.ErrnoError(60);try{for(var YJ=0;YJ<r;YJ++)x.tty.ops.put_char(x.tty,c[s+YJ])}catch(DJ){throw new f.ErrnoError(29)}if(r)x.node.timestamp=Date.now();return YJ}},default_tty_ops:{get_char(x){return bJ()},put_char(x,c){if(c===null||c===10)w(UJ(x.output,0)),x.output=[];else if(c!=0)x.output.push(c)},fsync(x){if(x.output&&x.output.length>0)w(UJ(x.output,0)),x.output=[]},ioctl_tcgets(x){return{c_iflag:25856,c_oflag:5,c_cflag:191,c_lflag:35387,c_cc:[3,28,127,21,4,0,1,0,17,19,26,0,18,15,23,22,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]}},ioctl_tcsets(x,c,s){return 0},ioctl_tiocgwinsz(x){return[24,80]}},default_tty1_ops:{put_char(x,c){if(c===null||c===10)y(UJ(x.output,0)),x.output=[];else if(c!=0)x.output.push(c)},fsync(x){if(x.output&&x.output.length>0)y(UJ(x.output,0)),x.output=[]}}},_J=(x)=>{$J()},NJ={ops_table:null,mount(x){return NJ.createNode(null,"/",16384|511,0)},createNode(x,c,s,r){if(f.isBlkdev(s)||f.isFIFO(s))throw new f.ErrnoError(63);if(!NJ.ops_table)NJ.ops_table={dir:{node:{getattr:NJ.node_ops.getattr,setattr:NJ.node_ops.setattr,lookup:NJ.node_ops.lookup,mknod:NJ.node_ops.mknod,rename:NJ.node_ops.rename,unlink:NJ.node_ops.unlink,rmdir:NJ.node_ops.rmdir,readdir:NJ.node_ops.readdir,symlink:NJ.node_ops.symlink},stream:{llseek:NJ.stream_ops.llseek}},file:{node:{getattr:NJ.node_ops.getattr,setattr:NJ.node_ops.setattr},stream:{llseek:NJ.stream_ops.llseek,read:NJ.stream_ops.read,write:NJ.stream_ops.write,allocate:NJ.stream_ops.allocate,mmap:NJ.stream_ops.mmap,msync:NJ.stream_ops.msync}},link:{node:{getattr:NJ.node_ops.getattr,setattr:NJ.node_ops.setattr,readlink:NJ.node_ops.readlink},stream:{}},chrdev:{node:{getattr:NJ.node_ops.getattr,setattr:NJ.node_ops.setattr},stream:f.chrdev_stream_ops}};var KJ=f.createNode(x,c,s,r);if(f.isDir(KJ.mode))KJ.node_ops=NJ.ops_table.dir.node,KJ.stream_ops=NJ.ops_table.dir.stream,KJ.contents={};else if(f.isFile(KJ.mode))KJ.node_ops=NJ.ops_table.file.node,KJ.stream_ops=NJ.ops_table.file.stream,KJ.usedBytes=0,KJ.contents=null;else if(f.isLink(KJ.mode))KJ.node_ops=NJ.ops_table.link.node,KJ.stream_ops=NJ.ops_table.link.stream;else if(f.isChrdev(KJ.mode))KJ.node_ops=NJ.ops_table.chrdev.node,KJ.stream_ops=NJ.ops_table.chrdev.stream;if(KJ.timestamp=Date.now(),x)x.contents[c]=KJ,x.timestamp=KJ.timestamp;return KJ},getFileDataAsTypedArray(x){if(!x.contents)return new Uint8Array(0);if(x.contents.subarray)return x.contents.subarray(0,x.usedBytes);return new Uint8Array(x.contents)},expandFileStorage(x,c){var s=x.contents?x.contents.length:0;if(s>=c)return;var r=1048576;if(c=Math.max(c,s*(s<r?2:1.125)>>>0),s!=0)c=Math.max(c,256);var KJ=x.contents;if(x.contents=new Uint8Array(c),x.usedBytes>0)x.contents.set(KJ.subarray(0,x.usedBytes),0)},resizeFileStorage(x,c){if(x.usedBytes==c)return;if(c==0)x.contents=null,x.usedBytes=0;else{var s=x.contents;if(x.contents=new Uint8Array(c),s)x.contents.set(s.subarray(0,Math.min(c,x.usedBytes)));x.usedBytes=c}},node_ops:{getattr(x){var c={};if(c.dev=f.isChrdev(x.mode)?x.id:1,c.ino=x.id,c.mode=x.mode,c.nlink=1,c.uid=0,c.gid=0,c.rdev=x.rdev,f.isDir(x.mode))c.size=4096;else if(f.isFile(x.mode))c.size=x.usedBytes;else if(f.isLink(x.mode))c.size=x.link.length;else c.size=0;return c.atime=new Date(x.timestamp),c.mtime=new Date(x.timestamp),c.ctime=new Date(x.timestamp),c.blksize=4096,c.blocks=Math.ceil(c.size/c.blksize),c},setattr(x,c){if(c.mode!==void 0)x.mode=c.mode;if(c.timestamp!==void 0)x.timestamp=c.timestamp;if(c.size!==void 0)NJ.resizeFileStorage(x,c.size)},lookup(x,c){throw f.genericErrors[44]},mknod(x,c,s,r){return NJ.createNode(x,c,s,r)},rename(x,c,s){if(f.isDir(x.mode)){var r;try{r=f.lookupNode(c,s)}catch(YJ){}if(r)for(var KJ in r.contents)throw new f.ErrnoError(55)}delete x.parent.contents[x.name],x.parent.timestamp=Date.now(),x.name=s,c.contents[s]=x,c.timestamp=x.parent.timestamp,x.parent=c},unlink(x,c){delete x.contents[c],x.timestamp=Date.now()},rmdir(x,c){var s=f.lookupNode(x,c);for(var r in s.contents)throw new f.ErrnoError(55);delete x.contents[c],x.timestamp=Date.now()},readdir(x){var c=[".",".."];for(var s in x.contents){if(!x.contents.hasOwnProperty(s))continue;c.push(s)}return c},symlink(x,c,s){var r=NJ.createNode(x,c,511|40960,0);return r.link=s,r},readlink(x){if(!f.isLink(x.mode))throw new f.ErrnoError(28);return x.link}},stream_ops:{read(x,c,s,r,KJ){var YJ=x.node.contents;if(KJ>=x.node.usedBytes)return 0;var DJ=Math.min(x.node.usedBytes-KJ,r);if(DJ>8&&YJ.subarray)c.set(YJ.subarray(KJ,KJ+DJ),s);else for(var hJ=0;hJ<DJ;hJ++)c[s+hJ]=YJ[KJ+hJ];return DJ},write(x,c,s,r,KJ,YJ){if(!r)return 0;var DJ=x.node;if(DJ.timestamp=Date.now(),c.subarray&&(!DJ.contents||DJ.contents.subarray)){if(YJ)return DJ.contents=c.subarray(s,s+r),DJ.usedBytes=r,r;else if(DJ.usedBytes===0&&KJ===0)return DJ.contents=c.slice(s,s+r),DJ.usedBytes=r,r;else if(KJ+r<=DJ.usedBytes)return DJ.contents.set(c.subarray(s,s+r),KJ),r}if(NJ.expandFileStorage(DJ,KJ+r),DJ.contents.subarray&&c.subarray)DJ.contents.set(c.subarray(s,s+r),KJ);else for(var hJ=0;hJ<r;hJ++)DJ.contents[KJ+hJ]=c[s+hJ];return DJ.usedBytes=Math.max(DJ.usedBytes,KJ+r),r},llseek(x,c,s){var r=c;if(s===1)r+=x.position;else if(s===2){if(f.isFile(x.node.mode))r+=x.node.usedBytes}if(r<0)throw new f.ErrnoError(28);return r},allocate(x,c,s){NJ.expandFileStorage(x.node,c+s),x.node.usedBytes=Math.max(x.node.usedBytes,c+s)},mmap(x,c,s,r,KJ){if(!f.isFile(x.node.mode))throw new f.ErrnoError(43);var YJ,DJ,hJ=x.node.contents;if(!(KJ&2)&&hJ.buffer===o.buffer)DJ=!1,YJ=hJ.byteOffset;else{if(s>0||s+c<hJ.length)if(hJ.subarray)hJ=hJ.subarray(s,s+c);else hJ=Array.prototype.slice.call(hJ,s,s+c);if(DJ=!0,YJ=_J(c),!YJ)throw new f.ErrnoError(48);o.set(hJ,YJ)}return{ptr:YJ,allocated:DJ}},msync(x,c,s,r,KJ){return NJ.stream_ops.write(x,c,0,r,s,!1),0}}},vQ=(x,c,s,r)=>{var KJ=!r?b(`al ${x}`):"";if(P(x,(YJ)=>{if(HJ(YJ,`Loading data file "${x}" failed (no arrayBuffer).`),c(new Uint8Array(YJ)),KJ)h(KJ)},(YJ)=>{if(s)s();else throw`Loading data file "${x}" failed.`}),KJ)C(KJ)},yJ=(x,c,s,r,KJ,YJ)=>f.createDataFile(x,c,s,r,KJ,YJ),gJ=R.preloadPlugins||[],MQ=(x,c,s,r)=>{if(typeof Browser!="undefined")Browser.init();var KJ=!1;return gJ.forEach((YJ)=>{if(KJ)return;if(YJ.canHandle(c))YJ.handle(x,c,s,r),KJ=!0}),KJ},cJ=(x,c,s,r,KJ,YJ,DJ,hJ,pJ,rJ)=>{var VQ=c?ZQ.resolve(nJ.join2(x,c)):x,GQ=b(`cp ${VQ}`);function iJ(lJ){function eJ(SQ){if(rJ)rJ();if(!hJ)yJ(x,c,SQ,r,KJ,pJ);if(YJ)YJ();h(GQ)}if(MQ(lJ,VQ,eJ,()=>{if(DJ)DJ();h(GQ)}))return;eJ(lJ)}if(C(GQ),typeof s=="string")vQ(s,(lJ)=>iJ(lJ),DJ);else iJ(s)},fJ=(x)=>{var c={r:0,"r+":2,w:512|64|1,"w+":512|64|2,a:1024|64|1,"a+":1024|64|2},s=c[x];if(typeof s=="undefined")throw new Error(`Unknown file open mode: ${x}`);return s},wQ=(x,c)=>{var s=0;if(x)s|=292|73;if(c)s|=146;return s},f={root:null,mounts:[],devices:{},streams:[],nextInode:1,nameTable:null,currentPath:"/",initialized:!1,ignorePermissions:!0,ErrnoError:null,genericErrors:{},filesystems:null,syncFSRequests:0,lookupPath(x,c={}){if(x=ZQ.resolve(x),!x)return{path:"",node:null};var s={follow_mount:!0,recurse_count:0};if(c=Object.assign(s,c),c.recurse_count>8)throw new f.ErrnoError(32);var r=x.split("/").filter((GQ)=>!!GQ),KJ=f.root,YJ="/";for(var DJ=0;DJ<r.length;DJ++){var hJ=DJ===r.length-1;if(hJ&&c.parent)break;if(KJ=f.lookupNode(KJ,r[DJ]),YJ=nJ.join2(YJ,r[DJ]),f.isMountpoint(KJ)){if(!hJ||hJ&&c.follow_mount)KJ=KJ.mounted.root}if(!hJ||c.follow){var pJ=0;while(f.isLink(KJ.mode)){var rJ=f.readlink(YJ);YJ=ZQ.resolve(nJ.dirname(YJ),rJ);var VQ=f.lookupPath(YJ,{recurse_count:c.recurse_count+1});if(KJ=VQ.node,pJ++>40)throw new f.ErrnoError(32)}}}return{path:YJ,node:KJ}},getPath(x){var c;while(!0){if(f.isRoot(x)){var s=x.mount.mountpoint;if(!c)return s;return s[s.length-1]!=="/"?`${s}/${c}`:s+c}c=c?`${x.name}/${c}`:x.name,x=x.parent}},hashName(x,c){var s=0;for(var r=0;r<c.length;r++)s=(s<<5)-s+c.charCodeAt(r)|0;return(x+s>>>0)%f.nameTable.length},hashAddNode(x){var c=f.hashName(x.parent.id,x.name);x.name_next=f.nameTable[c],f.nameTable[c]=x},hashRemoveNode(x){var c=f.hashName(x.parent.id,x.name);if(f.nameTable[c]===x)f.nameTable[c]=x.name_next;else{var s=f.nameTable[c];while(s){if(s.name_next===x){s.name_next=x.name_next;break}s=s.name_next}}},lookupNode(x,c){var s=f.mayLookup(x);if(s)throw new f.ErrnoError(s,x);var r=f.hashName(x.id,c);for(var KJ=f.nameTable[r];KJ;KJ=KJ.name_next){var YJ=KJ.name;if(KJ.parent.id===x.id&&YJ===c)return KJ}return f.lookup(x,c)},createNode(x,c,s,r){var KJ=new f.FSNode(x,c,s,r);return f.hashAddNode(KJ),KJ},destroyNode(x){f.hashRemoveNode(x)},isRoot(x){return x===x.parent},isMountpoint(x){return!!x.mounted},isFile(x){return(x&61440)===32768},isDir(x){return(x&61440)===16384},isLink(x){return(x&61440)===40960},isChrdev(x){return(x&61440)===8192},isBlkdev(x){return(x&61440)===24576},isFIFO(x){return(x&61440)===4096},isSocket(x){return(x&49152)===49152},flagsToPermissionString(x){var c=["r","w","rw"][x&3];if(x&512)c+="w";return c},nodePermissions(x,c){if(f.ignorePermissions)return 0;if(c.includes("r")&&!(x.mode&292))return 2;else if(c.includes("w")&&!(x.mode&146))return 2;else if(c.includes("x")&&!(x.mode&73))return 2;return 0},mayLookup(x){var c=f.nodePermissions(x,"x");if(c)return c;if(!x.node_ops.lookup)return 2;return 0},mayCreate(x,c){try{var s=f.lookupNode(x,c);return 20}catch(r){}return f.nodePermissions(x,"wx")},mayDelete(x,c,s){var r;try{r=f.lookupNode(x,c)}catch(YJ){return YJ.errno}var KJ=f.nodePermissions(x,"wx");if(KJ)return KJ;if(s){if(!f.isDir(r.mode))return 54;if(f.isRoot(r)||f.getPath(r)===f.cwd())return 10}else if(f.isDir(r.mode))return 31;return 0},mayOpen(x,c){if(!x)return 44;if(f.isLink(x.mode))return 32;else if(f.isDir(x.mode)){if(f.flagsToPermissionString(c)!=="r"||c&512)return 31}return f.nodePermissions(x,f.flagsToPermissionString(c))},MAX_OPEN_FDS:4096,nextfd(){for(var x=0;x<=f.MAX_OPEN_FDS;x++)if(!f.streams[x])return x;throw new f.ErrnoError(33)},getStreamChecked(x){var c=f.getStream(x);if(!c)throw new f.ErrnoError(8);return c},getStream:(x)=>f.streams[x],createStream(x,c=-1){if(!f.FSStream)f.FSStream=function(){this.shared={}},f.FSStream.prototype={},Object.defineProperties(f.FSStream.prototype,{object:{get(){return this.node},set(s){this.node=s}},isRead:{get(){return(this.flags&2097155)!==1}},isWrite:{get(){return(this.flags&2097155)!==0}},isAppend:{get(){return this.flags&1024}},flags:{get(){return this.shared.flags},set(s){this.shared.flags=s}},position:{get(){return this.shared.position},set(s){this.shared.position=s}}});if(x=Object.assign(new f.FSStream,x),c==-1)c=f.nextfd();return x.fd=c,f.streams[c]=x,x},closeStream(x){f.streams[x]=null},chrdev_stream_ops:{open(x){var c=f.getDevice(x.node.rdev);if(x.stream_ops=c.stream_ops,x.stream_ops.open)x.stream_ops.open(x)},llseek(){throw new f.ErrnoError(70)}},major:(x)=>x>>8,minor:(x)=>x&255,makedev:(x,c)=>x<<8|c,registerDevice(x,c){f.devices[x]={stream_ops:c}},getDevice:(x)=>f.devices[x],getMounts(x){var c=[],s=[x];while(s.length){var r=s.pop();c.push(r),s.push.apply(s,r.mounts)}return c},syncfs(x,c){if(typeof x=="function")c=x,x=!1;if(f.syncFSRequests++,f.syncFSRequests>1)y(`warning: ${f.syncFSRequests} FS.syncfs operations in flight at once, probably just doing extra work`);var s=f.getMounts(f.root.mount),r=0;function KJ(DJ){return f.syncFSRequests--,c(DJ)}function YJ(DJ){if(DJ){if(!YJ.errored)return YJ.errored=!0,KJ(DJ);return}if(++r>=s.length)KJ(null)}s.forEach((DJ)=>{if(!DJ.type.syncfs)return YJ(null);DJ.type.syncfs(DJ,x,YJ)})},mount(x,c,s){var r=s==="/",KJ=!s,YJ;if(r&&f.root)throw new f.ErrnoError(10);else if(!r&&!KJ){var DJ=f.lookupPath(s,{follow_mount:!1});if(s=DJ.path,YJ=DJ.node,f.isMountpoint(YJ))throw new f.ErrnoError(10);if(!f.isDir(YJ.mode))throw new f.ErrnoError(54)}var hJ={type:x,opts:c,mountpoint:s,mounts:[]},pJ=x.mount(hJ);if(pJ.mount=hJ,hJ.root=pJ,r)f.root=pJ;else if(YJ){if(YJ.mounted=hJ,YJ.mount)YJ.mount.mounts.push(hJ)}return pJ},unmount(x){var c=f.lookupPath(x,{follow_mount:!1});if(!f.isMountpoint(c.node))throw new f.ErrnoError(28);var s=c.node,r=s.mounted,KJ=f.getMounts(r);Object.keys(f.nameTable).forEach((DJ)=>{var hJ=f.nameTable[DJ];while(hJ){var pJ=hJ.name_next;if(KJ.includes(hJ.mount))f.destroyNode(hJ);hJ=pJ}}),s.mounted=null;var YJ=s.mount.mounts.indexOf(r);s.mount.mounts.splice(YJ,1)},lookup(x,c){return x.node_ops.lookup(x,c)},mknod(x,c,s){var r=f.lookupPath(x,{parent:!0}),KJ=r.node,YJ=nJ.basename(x);if(!YJ||YJ==="."||YJ==="..")throw new f.ErrnoError(28);var DJ=f.mayCreate(KJ,YJ);if(DJ)throw new f.ErrnoError(DJ);if(!KJ.node_ops.mknod)throw new f.ErrnoError(63);return KJ.node_ops.mknod(KJ,YJ,c,s)},create(x,c){return c=c!==void 0?c:438,c&=4095,c|=32768,f.mknod(x,c,0)},mkdir(x,c){return c=c!==void 0?c:511,c&=511|512,c|=16384,f.mknod(x,c,0)},mkdirTree(x,c){var s=x.split("/"),r="";for(var KJ=0;KJ<s.length;++KJ){if(!s[KJ])continue;r+="/"+s[KJ];try{f.mkdir(r,c)}catch(YJ){if(YJ.errno!=20)throw YJ}}},mkdev(x,c,s){if(typeof s=="undefined")s=c,c=438;return c|=8192,f.mknod(x,c,s)},symlink(x,c){if(!ZQ.resolve(x))throw new f.ErrnoError(44);var s=f.lookupPath(c,{parent:!0}),r=s.node;if(!r)throw new f.ErrnoError(44);var KJ=nJ.basename(c),YJ=f.mayCreate(r,KJ);if(YJ)throw new f.ErrnoError(YJ);if(!r.node_ops.symlink)throw new f.ErrnoError(63);return r.node_ops.symlink(r,KJ,x)},rename(x,c){var s=nJ.dirname(x),r=nJ.dirname(c),KJ=nJ.basename(x),YJ=nJ.basename(c),DJ,hJ,pJ;if(DJ=f.lookupPath(x,{parent:!0}),hJ=DJ.node,DJ=f.lookupPath(c,{parent:!0}),pJ=DJ.node,!hJ||!pJ)throw new f.ErrnoError(44);if(hJ.mount!==pJ.mount)throw new f.ErrnoError(75);var rJ=f.lookupNode(hJ,KJ),VQ=ZQ.relative(x,r);if(VQ.charAt(0)!==".")throw new f.ErrnoError(28);if(VQ=ZQ.relative(c,s),VQ.charAt(0)!==".")throw new f.ErrnoError(55);var GQ;try{GQ=f.lookupNode(pJ,YJ)}catch(eJ){}if(rJ===GQ)return;var iJ=f.isDir(rJ.mode),lJ=f.mayDelete(hJ,KJ,iJ);if(lJ)throw new f.ErrnoError(lJ);if(lJ=GQ?f.mayDelete(pJ,YJ,iJ):f.mayCreate(pJ,YJ),lJ)throw new f.ErrnoError(lJ);if(!hJ.node_ops.rename)throw new f.ErrnoError(63);if(f.isMountpoint(rJ)||GQ&&f.isMountpoint(GQ))throw new f.ErrnoError(10);if(pJ!==hJ){if(lJ=f.nodePermissions(hJ,"w"),lJ)throw new f.ErrnoError(lJ)}f.hashRemoveNode(rJ);try{hJ.node_ops.rename(rJ,pJ,YJ)}catch(eJ){throw eJ}finally{f.hashAddNode(rJ)}},rmdir(x){var c=f.lookupPath(x,{parent:!0}),s=c.node,r=nJ.basename(x),KJ=f.lookupNode(s,r),YJ=f.mayDelete(s,r,!0);if(YJ)throw new f.ErrnoError(YJ);if(!s.node_ops.rmdir)throw new f.ErrnoError(63);if(f.isMountpoint(KJ))throw new f.ErrnoError(10);s.node_ops.rmdir(s,r),f.destroyNode(KJ)},readdir(x){var c=f.lookupPath(x,{follow:!0}),s=c.node;if(!s.node_ops.readdir)throw new f.ErrnoError(54);return s.node_ops.readdir(s)},unlink(x){var c=f.lookupPath(x,{parent:!0}),s=c.node;if(!s)throw new f.ErrnoError(44);var r=nJ.basename(x),KJ=f.lookupNode(s,r),YJ=f.mayDelete(s,r,!1);if(YJ)throw new f.ErrnoError(YJ);if(!s.node_ops.unlink)throw new f.ErrnoError(63);if(f.isMountpoint(KJ))throw new f.ErrnoError(10);s.node_ops.unlink(s,r),f.destroyNode(KJ)},readlink(x){var c=f.lookupPath(x),s=c.node;if(!s)throw new f.ErrnoError(44);if(!s.node_ops.readlink)throw new f.ErrnoError(28);return ZQ.resolve(f.getPath(s.parent),s.node_ops.readlink(s))},stat(x,c){var s=f.lookupPath(x,{follow:!c}),r=s.node;if(!r)throw new f.ErrnoError(44);if(!r.node_ops.getattr)throw new f.ErrnoError(63);return r.node_ops.getattr(r)},lstat(x){return f.stat(x,!0)},chmod(x,c,s){var r;if(typeof x=="string"){var KJ=f.lookupPath(x,{follow:!s});r=KJ.node}else r=x;if(!r.node_ops.setattr)throw new f.ErrnoError(63);r.node_ops.setattr(r,{mode:c&4095|r.mode&~4095,timestamp:Date.now()})},lchmod(x,c){f.chmod(x,c,!0)},fchmod(x,c){var s=f.getStreamChecked(x);f.chmod(s.node,c)},chown(x,c,s,r){var KJ;if(typeof x=="string"){var YJ=f.lookupPath(x,{follow:!r});KJ=YJ.node}else KJ=x;if(!KJ.node_ops.setattr)throw new f.ErrnoError(63);KJ.node_ops.setattr(KJ,{timestamp:Date.now()})},lchown(x,c,s){f.chown(x,c,s,!0)},fchown(x,c,s){var r=f.getStreamChecked(x);f.chown(r.node,c,s)},truncate(x,c){if(c<0)throw new f.ErrnoError(28);var s;if(typeof x=="string"){var r=f.lookupPath(x,{follow:!0});s=r.node}else s=x;if(!s.node_ops.setattr)throw new f.ErrnoError(63);if(f.isDir(s.mode))throw new f.ErrnoError(31);if(!f.isFile(s.mode))throw new f.ErrnoError(28);var KJ=f.nodePermissions(s,"w");if(KJ)throw new f.ErrnoError(KJ);s.node_ops.setattr(s,{size:c,timestamp:Date.now()})},ftruncate(x,c){var s=f.getStreamChecked(x);if((s.flags&2097155)===0)throw new f.ErrnoError(28);f.truncate(s.node,c)},utime(x,c,s){var r=f.lookupPath(x,{follow:!0}),KJ=r.node;KJ.node_ops.setattr(KJ,{timestamp:Math.max(c,s)})},open(x,c,s){if(x==="")throw new f.ErrnoError(44);if(c=typeof c=="string"?fJ(c):c,s=typeof s=="undefined"?438:s,c&64)s=s&4095|32768;else s=0;var r;if(typeof x=="object")r=x;else{x=nJ.normalize(x);try{var KJ=f.lookupPath(x,{follow:!(c&131072)});r=KJ.node}catch(pJ){}}var YJ=!1;if(c&64)if(r){if(c&128)throw new f.ErrnoError(20)}else r=f.mknod(x,s,0),YJ=!0;if(!r)throw new f.ErrnoError(44);if(f.isChrdev(r.mode))c&=~512;if(c&65536&&!f.isDir(r.mode))throw new f.ErrnoError(54);if(!YJ){var DJ=f.mayOpen(r,c);if(DJ)throw new f.ErrnoError(DJ)}if(c&512&&!YJ)f.truncate(r,0);c&=~(128|512|131072);var hJ=f.createStream({node:r,path:f.getPath(r),flags:c,seekable:!0,position:0,stream_ops:r.stream_ops,ungotten:[],error:!1});if(hJ.stream_ops.open)hJ.stream_ops.open(hJ);if(R.logReadFiles&&!(c&1)){if(!f.readFiles)f.readFiles={};if(!(x in f.readFiles))f.readFiles[x]=1}return hJ},close(x){if(f.isClosed(x))throw new f.ErrnoError(8);if(x.getdents)x.getdents=null;try{if(x.stream_ops.close)x.stream_ops.close(x)}catch(c){throw c}finally{f.closeStream(x.fd)}x.fd=null},isClosed(x){return x.fd===null},llseek(x,c,s){if(f.isClosed(x))throw new f.ErrnoError(8);if(!x.seekable||!x.stream_ops.llseek)throw new f.ErrnoError(70);if(s!=0&&s!=1&&s!=2)throw new f.ErrnoError(28);return x.position=x.stream_ops.llseek(x,c,s),x.ungotten=[],x.position},read(x,c,s,r,KJ){if(r<0||KJ<0)throw new f.ErrnoError(28);if(f.isClosed(x))throw new f.ErrnoError(8);if((x.flags&2097155)===1)throw new f.ErrnoError(8);if(f.isDir(x.node.mode))throw new f.ErrnoError(31);if(!x.stream_ops.read)throw new f.ErrnoError(28);var YJ=typeof KJ!="undefined";if(!YJ)KJ=x.position;else if(!x.seekable)throw new f.ErrnoError(70);var DJ=x.stream_ops.read(x,c,s,r,KJ);if(!YJ)x.position+=DJ;return DJ},write(x,c,s,r,KJ,YJ){if(r<0||KJ<0)throw new f.ErrnoError(28);if(f.isClosed(x))throw new f.ErrnoError(8);if((x.flags&2097155)===0)throw new f.ErrnoError(8);if(f.isDir(x.node.mode))throw new f.ErrnoError(31);if(!x.stream_ops.write)throw new f.ErrnoError(28);if(x.seekable&&x.flags&1024)f.llseek(x,0,2);var DJ=typeof KJ!="undefined";if(!DJ)KJ=x.position;else if(!x.seekable)throw new f.ErrnoError(70);var hJ=x.stream_ops.write(x,c,s,r,KJ,YJ);if(!DJ)x.position+=hJ;return hJ},allocate(x,c,s){if(f.isClosed(x))throw new f.ErrnoError(8);if(c<0||s<=0)throw new f.ErrnoError(28);if((x.flags&2097155)===0)throw new f.ErrnoError(8);if(!f.isFile(x.node.mode)&&!f.isDir(x.node.mode))throw new f.ErrnoError(43);if(!x.stream_ops.allocate)throw new f.ErrnoError(138);x.stream_ops.allocate(x,c,s)},mmap(x,c,s,r,KJ){if((r&2)!==0&&(KJ&2)===0&&(x.flags&2097155)!==2)throw new f.ErrnoError(2);if((x.flags&2097155)===1)throw new f.ErrnoError(2);if(!x.stream_ops.mmap)throw new f.ErrnoError(43);return x.stream_ops.mmap(x,c,s,r,KJ)},msync(x,c,s,r,KJ){if(!x.stream_ops.msync)return 0;return x.stream_ops.msync(x,c,s,r,KJ)},munmap:(x)=>0,ioctl(x,c,s){if(!x.stream_ops.ioctl)throw new f.ErrnoError(59);return x.stream_ops.ioctl(x,c,s)},readFile(x,c={}){if(c.flags=c.flags||0,c.encoding=c.encoding||"binary",c.encoding!=="utf8"&&c.encoding!=="binary")throw new Error(`Invalid encoding type "${c.encoding}"`);var s,r=f.open(x,c.flags),KJ=f.stat(x),YJ=KJ.size,DJ=new Uint8Array(YJ);if(f.read(r,DJ,0,YJ,0),c.encoding==="utf8")s=UJ(DJ,0);else if(c.encoding==="binary")s=DJ;return f.close(r),s},writeFile(x,c,s={}){s.flags=s.flags||577;var r=f.open(x,s.flags,s.mode);if(typeof c=="string"){var KJ=new Uint8Array(MJ(c)+1),YJ=xQ(c,KJ,0,KJ.length);f.write(r,KJ,0,YJ,void 0,s.canOwn)}else if(ArrayBuffer.isView(c))f.write(r,c,0,c.byteLength,void 0,s.canOwn);else throw new Error("Unsupported data type");f.close(r)},cwd:()=>f.currentPath,chdir(x){var c=f.lookupPath(x,{follow:!0});if(c.node===null)throw new f.ErrnoError(44);if(!f.isDir(c.node.mode))throw new f.ErrnoError(54);var s=f.nodePermissions(c.node,"x");if(s)throw new f.ErrnoError(s);f.currentPath=c.path},createDefaultDirectories(){f.mkdir("/tmp"),f.mkdir("/home"),f.mkdir("/home/web_user")},createDefaultDevices(){f.mkdir("/dev"),f.registerDevice(f.makedev(1,3),{read:()=>0,write:(r,KJ,YJ,DJ,hJ)=>DJ}),f.mkdev("/dev/null",f.makedev(1,3)),WQ.register(f.makedev(5,0),WQ.default_tty_ops),WQ.register(f.makedev(6,0),WQ.default_tty1_ops),f.mkdev("/dev/tty",f.makedev(5,0)),f.mkdev("/dev/tty1",f.makedev(6,0));var x=new Uint8Array(1024),c=0,s=()=>{if(c===0)c=kJ(x).byteLength;return x[--c]};f.createDevice("/dev","random",s),f.createDevice("/dev","urandom",s),f.mkdir("/dev/shm"),f.mkdir("/dev/shm/tmp")},createSpecialDirectories(){f.mkdir("/proc");var x=f.mkdir("/proc/self");f.mkdir("/proc/self/fd"),f.mount({mount(){var c=f.createNode(x,"fd",16384|511,73);return c.node_ops={lookup(s,r){var KJ=+r,YJ=f.getStreamChecked(KJ),DJ={parent:null,mount:{mountpoint:"fake"},node_ops:{readlink:()=>YJ.path}};return DJ.parent=DJ,DJ}},c}},{},"/proc/self/fd")},createStandardStreams(){if(R.stdin)f.createDevice("/dev","stdin",R.stdin);else f.symlink("/dev/tty","/dev/stdin");if(R.stdout)f.createDevice("/dev","stdout",null,R.stdout);else f.symlink("/dev/tty","/dev/stdout");if(R.stderr)f.createDevice("/dev","stderr",null,R.stderr);else f.symlink("/dev/tty1","/dev/stderr");var x=f.open("/dev/stdin",0),c=f.open("/dev/stdout",1),s=f.open("/dev/stderr",1)},ensureErrnoError(){if(f.ErrnoError)return;f.ErrnoError=function x(c,s){this.name="ErrnoError",this.node=s,this.setErrno=function(r){this.errno=r},this.setErrno(c),this.message="FS error"},f.ErrnoError.prototype=new Error,f.ErrnoError.prototype.constructor=f.ErrnoError,[44].forEach((x)=>{f.genericErrors[x]=new f.ErrnoError(x),f.genericErrors[x].stack="<generic error, no stack>"})},staticInit(){f.ensureErrnoError(),f.nameTable=new Array(4096),f.mount(NJ,{},"/"),f.createDefaultDirectories(),f.createDefaultDevices(),f.createSpecialDirectories(),f.filesystems={MEMFS:NJ}},init(x,c,s){f.init.initialized=!0,f.ensureErrnoError(),R.stdin=x||R.stdin,R.stdout=c||R.stdout,R.stderr=s||R.stderr,f.createStandardStreams()},quit(){f.init.initialized=!1;for(var x=0;x<f.streams.length;x++){var c=f.streams[x];if(!c)continue;f.close(c)}},findObject(x,c){var s=f.analyzePath(x,c);if(!s.exists)return null;return s.object},analyzePath(x,c){try{var s=f.lookupPath(x,{follow:!c});x=s.path}catch(KJ){}var r={isRoot:!1,exists:!1,error:0,name:null,path:null,object:null,parentExists:!1,parentPath:null,parentObject:null};try{var s=f.lookupPath(x,{parent:!0});r.parentExists=!0,r.parentPath=s.path,r.parentObject=s.node,r.name=nJ.basename(x),s=f.lookupPath(x,{follow:!c}),r.exists=!0,r.path=s.path,r.object=s.node,r.name=s.node.name,r.isRoot=s.path==="/"}catch(KJ){r.error=KJ.errno}return r},createPath(x,c,s,r){x=typeof x=="string"?x:f.getPath(x);var KJ=c.split("/").reverse();while(KJ.length){var YJ=KJ.pop();if(!YJ)continue;var DJ=nJ.join2(x,YJ);try{f.mkdir(DJ)}catch(hJ){}x=DJ}return DJ},createFile(x,c,s,r,KJ){var YJ=nJ.join2(typeof x=="string"?x:f.getPath(x),c),DJ=wQ(r,KJ);return f.create(YJ,DJ)},createDataFile(x,c,s,r,KJ,YJ){var DJ=c;if(x)x=typeof x=="string"?x:f.getPath(x),DJ=c?nJ.join2(x,c):x;var hJ=wQ(r,KJ),pJ=f.create(DJ,hJ);if(s){if(typeof s=="string"){var rJ=new Array(s.length);for(var VQ=0,GQ=s.length;VQ<GQ;++VQ)rJ[VQ]=s.charCodeAt(VQ);s=rJ}f.chmod(pJ,hJ|146);var iJ=f.open(pJ,577);f.write(iJ,s,0,s.length,0,YJ),f.close(iJ),f.chmod(pJ,hJ)}return pJ},createDevice(x,c,s,r){var KJ=nJ.join2(typeof x=="string"?x:f.getPath(x),c),YJ=wQ(!!s,!!r);if(!f.createDevice.major)f.createDevice.major=64;var DJ=f.makedev(f.createDevice.major++,0);return f.registerDevice(DJ,{open(hJ){hJ.seekable=!1},close(hJ){if(r&&r.buffer&&r.buffer.length)r(10)},read(hJ,pJ,rJ,VQ,GQ){var iJ=0;for(var lJ=0;lJ<VQ;lJ++){var eJ;try{eJ=s()}catch(SQ){throw new f.ErrnoError(29)}if(eJ===void 0&&iJ===0)throw new f.ErrnoError(6);if(eJ===null||eJ===void 0)break;iJ++,pJ[rJ+lJ]=eJ}if(iJ)hJ.node.timestamp=Date.now();return iJ},write(hJ,pJ,rJ,VQ,GQ){for(var iJ=0;iJ<VQ;iJ++)try{r(pJ[rJ+iJ])}catch(lJ){throw new f.ErrnoError(29)}if(VQ)hJ.node.timestamp=Date.now();return iJ}}),f.mkdev(KJ,YJ,DJ)},forceLoadFile(x){if(x.isDevice||x.isFolder||x.link||x.contents)return!0;if(typeof XMLHttpRequest!="undefined")throw new Error("Lazy loading should have been performed (contents set) in createLazyFile, but it was not. Lazy loading only works in web workers. Use --embed-file or --preload-file in emcc on the main thread.");else if(j)try{x.contents=wJ(j(x.url),!0),x.usedBytes=x.contents.length}catch(c){throw new f.ErrnoError(29)}else throw new Error("Cannot load without read() or XMLHttpRequest.")},createLazyFile(x,c,s,r,KJ){function YJ(){this.lengthKnown=!1,this.chunks=[]}if(YJ.prototype.get=function iJ(lJ){if(lJ>this.length-1||lJ<0)return;var eJ=lJ%this.chunkSize,SQ=lJ/this.chunkSize|0;return this.getter(SQ)[eJ]},YJ.prototype.setDataGetter=function iJ(lJ){this.getter=lJ},YJ.prototype.cacheLength=function iJ(){var lJ=new XMLHttpRequest;if(lJ.open("HEAD",s,!1),lJ.send(null),!(lJ.status>=200&&lJ.status<300||lJ.status===304))throw new Error("Couldn't load "+s+". Status: "+lJ.status);var eJ=Number(lJ.getResponseHeader("Content-length")),SQ,UQ=(SQ=lJ.getResponseHeader("Accept-Ranges"))&&SQ==="bytes",qQ=(SQ=lJ.getResponseHeader("Content-Encoding"))&&SQ==="gzip",uJ=1048576;if(!UQ)uJ=eJ;var sJ=(kQ,cQ)=>{if(kQ>cQ)throw new Error("invalid range ("+kQ+", "+cQ+") or no bytes requested!");if(cQ>eJ-1)throw new Error("only "+eJ+" bytes available! programmer error!");var _Q=new XMLHttpRequest;if(_Q.open("GET",s,!1),eJ!==uJ)_Q.setRequestHeader("Range","bytes="+kQ+"-"+cQ);if(_Q.responseType="arraybuffer",_Q.overrideMimeType)_Q.overrideMimeType("text/plain; charset=x-user-defined");if(_Q.send(null),!(_Q.status>=200&&_Q.status<300||_Q.status===304))throw new Error("Couldn't load "+s+". Status: "+_Q.status);if(_Q.response!==void 0)return new Uint8Array(_Q.response||[]);return wJ(_Q.responseText||"",!0)},AQ=this;if(AQ.setDataGetter((kQ)=>{var cQ=kQ*uJ,_Q=(kQ+1)*uJ-1;if(_Q=Math.min(_Q,eJ-1),typeof AQ.chunks[kQ]=="undefined")AQ.chunks[kQ]=sJ(cQ,_Q);if(typeof AQ.chunks[kQ]=="undefined")throw new Error("doXHR failed!");return AQ.chunks[kQ]}),qQ||!eJ)uJ=eJ=1,eJ=this.getter(0).length,uJ=eJ,w("LazyFiles on gzip forces download of the whole file when length is accessed");this._length=eJ,this._chunkSize=uJ,this.lengthKnown=!0},typeof XMLHttpRequest!="undefined"){if(!N)throw"Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";var DJ=new YJ;Object.defineProperties(DJ,{length:{get:function(){if(!this.lengthKnown)this.cacheLength();return this._length}},chunkSize:{get:function(){if(!this.lengthKnown)this.cacheLength();return this._chunkSize}}});var hJ={isDevice:!1,contents:DJ}}else var hJ={isDevice:!1,url:s};var pJ=f.createFile(x,c,hJ,r,KJ);if(hJ.contents)pJ.contents=hJ.contents;else if(hJ.url)pJ.contents=null,pJ.url=hJ.url;Object.defineProperties(pJ,{usedBytes:{get:function(){return this.contents.length}}});var rJ={},VQ=Object.keys(pJ.stream_ops);VQ.forEach((iJ)=>{var lJ=pJ.stream_ops[iJ];rJ[iJ]=function eJ(){return f.forceLoadFile(pJ),lJ.apply(null,arguments)}});function GQ(iJ,lJ,eJ,SQ,UQ){var qQ=iJ.node.contents;if(UQ>=qQ.length)return 0;var uJ=Math.min(qQ.length-UQ,SQ);if(qQ.slice)for(var sJ=0;sJ<uJ;sJ++)lJ[eJ+sJ]=qQ[UQ+sJ];else for(var sJ=0;sJ<uJ;sJ++)lJ[eJ+sJ]=qQ.get(UQ+sJ);return uJ}return rJ.read=(iJ,lJ,eJ,SQ,UQ)=>{return f.forceLoadFile(pJ),GQ(iJ,lJ,eJ,SQ,UQ)},rJ.mmap=(iJ,lJ,eJ,SQ,UQ)=>{f.forceLoadFile(pJ);var qQ=_J(lJ);if(!qQ)throw new f.ErrnoError(48);return GQ(iJ,o,qQ,lJ,eJ),{ptr:qQ,allocated:!0}},pJ.stream_ops=rJ,pJ}},zJ={DEFAULT_POLLMASK:5,calculateAt(x,c,s){if(nJ.isAbs(c))return c;var r;if(x===-100)r=f.cwd();else{var KJ=zJ.getStreamFromFD(x);r=KJ.path}if(c.length==0){if(!s)throw new f.ErrnoError(44);return r}return nJ.join2(r,c)},doStat(x,c,s){try{var r=x(c)}catch(hJ){if(hJ&&hJ.node&&nJ.normalize(c)!==nJ.normalize(f.getPath(hJ.node)))return-54;throw hJ}Z[s>>2]=r.dev,Z[s+4>>2]=r.mode,$[s+8>>2]=r.nlink,Z[s+12>>2]=r.uid,Z[s+16>>2]=r.gid,Z[s+20>>2]=r.rdev,D=[r.size>>>0,(T=r.size,+Math.abs(T)>=1?T>0?+Math.floor(T/4294967296)>>>0:~~+Math.ceil((T-+(~~T>>>0))/4294967296)>>>0:0)],Z[s+24>>2]=D[0],Z[s+28>>2]=D[1],Z[s+32>>2]=4096,Z[s+36>>2]=r.blocks;var KJ=r.atime.getTime(),YJ=r.mtime.getTime(),DJ=r.ctime.getTime();return D=[Math.floor(KJ/1000)>>>0,(T=Math.floor(KJ/1000),+Math.abs(T)>=1?T>0?+Math.floor(T/4294967296)>>>0:~~+Math.ceil((T-+(~~T>>>0))/4294967296)>>>0:0)],Z[s+40>>2]=D[0],Z[s+44>>2]=D[1],$[s+48>>2]=KJ%1000*1000,D=[Math.floor(YJ/1000)>>>0,(T=Math.floor(YJ/1000),+Math.abs(T)>=1?T>0?+Math.floor(T/4294967296)>>>0:~~+Math.ceil((T-+(~~T>>>0))/4294967296)>>>0:0)],Z[s+56>>2]=D[0],Z[s+60>>2]=D[1],$[s+64>>2]=YJ%1000*1000,D=[Math.floor(DJ/1000)>>>0,(T=Math.floor(DJ/1000),+Math.abs(T)>=1?T>0?+Math.floor(T/4294967296)>>>0:~~+Math.ceil((T-+(~~T>>>0))/4294967296)>>>0:0)],Z[s+72>>2]=D[0],Z[s+76>>2]=D[1],$[s+80>>2]=DJ%1000*1000,D=[r.ino>>>0,(T=r.ino,+Math.abs(T)>=1?T>0?+Math.floor(T/4294967296)>>>0:~~+Math.ceil((T-+(~~T>>>0))/4294967296)>>>0:0)],Z[s+88>>2]=D[0],Z[s+92>>2]=D[1],0},doMsync(x,c,s,r,KJ){if(!f.isFile(c.node.mode))throw new f.ErrnoError(43);if(r&2)return 0;var YJ=jJ.slice(x,x+s);f.msync(c,YJ,KJ,s,r)},varargs:void 0,get(){var x=Z[+zJ.varargs>>2];return zJ.varargs+=4,x},getp(){return zJ.get()},getStr(x){var c=EJ(x);return c},getStreamFromFD(x){var c=f.getStreamChecked(x);return c}};function CQ(x,c,s){zJ.varargs=s;try{var r=zJ.getStreamFromFD(x);switch(c){case 0:{var KJ=zJ.get();if(KJ<0)return-28;while(f.streams[KJ])KJ++;var YJ=f.createStream(r,KJ);return YJ.fd}case 1:case 2:return 0;case 3:return r.flags;case 4:{var KJ=zJ.get();return r.flags|=KJ,0}case 5:{var KJ=zJ.getp(),DJ=0;return J[KJ+DJ>>1]=2,0}case 6:case 7:return 0;case 16:case 8:return-28;case 9:return xJ(28),-1;default:return-28}}catch(hJ){if(typeof f=="undefined"||hJ.name!=="ErrnoError")throw hJ;return-hJ.errno}}var oJ=(x,c,s)=>xQ(x,jJ,c,s);function tJ(x,c,s){try{var r=zJ.getStreamFromFD(x);if(!r.getdents)r.getdents=f.readdir(r.path);var KJ=280,YJ=0,DJ=f.llseek(r,0,1),hJ=Math.floor(DJ/KJ);while(hJ<r.getdents.length&&YJ+KJ<=s){var pJ,rJ,VQ=r.getdents[hJ];if(VQ===".")pJ=r.node.id,rJ=4;else if(VQ===".."){var GQ=f.lookupPath(r.path,{parent:!0});pJ=GQ.node.id,rJ=4}else{var iJ=f.lookupNode(r.node,VQ);pJ=iJ.id,rJ=f.isChrdev(iJ.mode)?2:f.isDir(iJ.mode)?4:f.isLink(iJ.mode)?10:8}D=[pJ>>>0,(T=pJ,+Math.abs(T)>=1?T>0?+Math.floor(T/4294967296)>>>0:~~+Math.ceil((T-+(~~T>>>0))/4294967296)>>>0:0)],Z[c+YJ>>2]=D[0],Z[c+YJ+4>>2]=D[1],D=[(hJ+1)*KJ>>>0,(T=(hJ+1)*KJ,+Math.abs(T)>=1?T>0?+Math.floor(T/4294967296)>>>0:~~+Math.ceil((T-+(~~T>>>0))/4294967296)>>>0:0)],Z[c+YJ+8>>2]=D[0],Z[c+YJ+12>>2]=D[1],J[c+YJ+16>>1]=280,o[c+YJ+18>>0]=rJ,oJ(VQ,c+YJ+19,256),YJ+=KJ,hJ+=1}return f.llseek(r,hJ*KJ,0),YJ}catch(lJ){if(typeof f=="undefined"||lJ.name!=="ErrnoError")throw lJ;return-lJ.errno}}function YQ(x,c,s){zJ.varargs=s;try{var r=zJ.getStreamFromFD(x);switch(c){case 21509:{if(!r.tty)return-59;return 0}case 21505:{if(!r.tty)return-59;if(r.tty.ops.ioctl_tcgets){var KJ=r.tty.ops.ioctl_tcgets(r),YJ=zJ.getp();Z[YJ>>2]=KJ.c_iflag||0,Z[YJ+4>>2]=KJ.c_oflag||0,Z[YJ+8>>2]=KJ.c_cflag||0,Z[YJ+12>>2]=KJ.c_lflag||0;for(var DJ=0;DJ<32;DJ++)o[YJ+DJ+17>>0]=KJ.c_cc[DJ]||0;return 0}return 0}case 21510:case 21511:case 21512:{if(!r.tty)return-59;return 0}case 21506:case 21507:case 21508:{if(!r.tty)return-59;if(r.tty.ops.ioctl_tcsets){var YJ=zJ.getp(),hJ=Z[YJ>>2],pJ=Z[YJ+4>>2],rJ=Z[YJ+8>>2],VQ=Z[YJ+12>>2],GQ=[];for(var DJ=0;DJ<32;DJ++)GQ.push(o[YJ+DJ+17>>0]);return r.tty.ops.ioctl_tcsets(r.tty,c,{c_iflag:hJ,c_oflag:pJ,c_cflag:rJ,c_lflag:VQ,c_cc:GQ})}return 0}case 21519:{if(!r.tty)return-59;var YJ=zJ.getp();return Z[YJ>>2]=0,0}case 21520:{if(!r.tty)return-59;return-28}case 21531:{var YJ=zJ.getp();return f.ioctl(r,c,YJ)}case 21523:{if(!r.tty)return-59;if(r.tty.ops.ioctl_tiocgwinsz){var iJ=r.tty.ops.ioctl_tiocgwinsz(r.tty),YJ=zJ.getp();J[YJ>>1]=iJ[0],J[YJ+2>>1]=iJ[1]}return 0}case 21524:{if(!r.tty)return-59;return 0}case 21515:{if(!r.tty)return-59;return 0}default:return-28}}catch(lJ){if(typeof f=="undefined"||lJ.name!=="ErrnoError")throw lJ;return-lJ.errno}}function BQ(x,c,s,r){zJ.varargs=r;try{c=zJ.getStr(c),c=zJ.calculateAt(x,c);var KJ=r?zJ.get():0;return f.open(c,s,KJ).fd}catch(YJ){if(typeof f=="undefined"||YJ.name!=="ErrnoError")throw YJ;return-YJ.errno}}function OQ(x){try{return x=zJ.getStr(x),f.rmdir(x),0}catch(c){if(typeof f=="undefined"||c.name!=="ErrnoError")throw c;return-c.errno}}function jQ(x,c){try{return x=zJ.getStr(x),zJ.doStat(f.stat,x,c)}catch(s){if(typeof f=="undefined"||s.name!=="ErrnoError")throw s;return-s.errno}}function TQ(x,c,s){try{if(c=zJ.getStr(c),c=zJ.calculateAt(x,c),s===0)f.unlink(c);else if(s===512)f.rmdir(c);else $J("Invalid flags passed to unlinkat");return 0}catch(r){if(typeof f=="undefined"||r.name!=="ErrnoError")throw r;return-r.errno}}var NQ=!0,IQ=()=>NQ,EQ=()=>{$J("")},RQ=()=>Date.now(),zQ;zQ=()=>performance.now();var PQ=(x,c,s)=>jJ.copyWithin(x,c,c+s),LQ=(x)=>{$J("OOM")},FQ=(x)=>{var c=jJ.length;x>>>=0,LQ(x)},HQ={},DQ=()=>Y||"./this.program",KQ=()=>{if(!KQ.strings){var x=(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",c={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:x,_:DQ()};for(var s in HQ)if(HQ[s]===void 0)delete c[s];else c[s]=HQ[s];var r=[];for(var s in c)r.push(`${s}=${c[s]}`);KQ.strings=r}return KQ.strings},TV=(x,c)=>{for(var s=0;s<x.length;++s)o[c++>>0]=x.charCodeAt(s);o[c>>0]=0},NV=(x,c)=>{var s=0;return KQ().forEach((r,KJ)=>{var YJ=c+s;$[x+KJ*4>>2]=YJ,TV(r,YJ),s+=r.length+1}),0},IV=(x,c)=>{var s=KQ();$[x>>2]=s.length;var r=0;return s.forEach((KJ)=>r+=KJ.length+1),$[c>>2]=r,0},g$=0,c$=()=>a||g$>0,f$=(x)=>{if(VJ=x,!c$()){if(R.onExit)R.onExit(x);JJ=!0}E(x,new u(x))},S6=(x,c)=>{VJ=x,f$(x)},h$=S6;function m$(x){try{var c=zJ.getStreamFromFD(x);return f.close(c),0}catch(s){if(typeof f=="undefined"||s.name!=="ErrnoError")throw s;return s.errno}}var u$=(x,c,s,r)=>{var KJ=0;for(var YJ=0;YJ<s;YJ++){var DJ=$[c>>2],hJ=$[c+4>>2];c+=8;var pJ=f.read(x,o,DJ,hJ,r);if(pJ<0)return-1;if(KJ+=pJ,pJ<hJ)break;if(typeof r!=="undefined")r+=pJ}return KJ};function p$(x,c,s,r){try{var KJ=zJ.getStreamFromFD(x),YJ=u$(KJ,c,s);return $[r>>2]=YJ,0}catch(DJ){if(typeof f=="undefined"||DJ.name!=="ErrnoError")throw DJ;return DJ.errno}}var i$=(x,c)=>c+2097152>>>0<4194305-!!x?(x>>>0)+c*4294967296:NaN;function l$(x,c,s,r,KJ){var YJ=i$(c,s);try{if(isNaN(YJ))return 61;var DJ=zJ.getStreamFromFD(x);if(f.llseek(DJ,YJ,r),D=[DJ.position>>>0,(T=DJ.position,+Math.abs(T)>=1?T>0?+Math.floor(T/4294967296)>>>0:~~+Math.ceil((T-+(~~T>>>0))/4294967296)>>>0:0)],Z[KJ>>2]=D[0],Z[KJ+4>>2]=D[1],DJ.getdents&&YJ===0&&r===0)DJ.getdents=null;return 0}catch(hJ){if(typeof f=="undefined"||hJ.name!=="ErrnoError")throw hJ;return hJ.errno}}var s$=(x,c,s,r)=>{var KJ=0;for(var YJ=0;YJ<s;YJ++){var DJ=$[c>>2],hJ=$[c+4>>2];c+=8;var pJ=f.write(x,o,DJ,hJ,r);if(pJ<0)return-1;if(KJ+=pJ,typeof r!=="undefined")r+=pJ}return KJ};function d$(x,c,s,r){try{var KJ=zJ.getStreamFromFD(x),YJ=s$(KJ,c,s);return $[r>>2]=YJ,0}catch(DJ){if(typeof f=="undefined"||DJ.name!=="ErrnoError")throw DJ;return DJ.errno}}var vV=(x)=>x%4===0&&(x%100!==0||x%400===0),n$=(x,c)=>{var s=0;for(var r=0;r<=c;s+=x[r++]);return s},x6=[31,29,31,30,31,30,31,31,30,31,30,31],w6=[31,28,31,30,31,30,31,31,30,31,30,31],o$=(x,c)=>{var s=new Date(x.getTime());while(c>0){var r=vV(s.getFullYear()),KJ=s.getMonth(),YJ=(r?x6:w6)[KJ];if(c>YJ-s.getDate())if(c-=YJ-s.getDate()+1,s.setDate(1),KJ<11)s.setMonth(KJ+1);else s.setMonth(0),s.setFullYear(s.getFullYear()+1);else return s.setDate(s.getDate()+c),s}return s},r$=(x,c)=>{o.set(x,c)},a$=(x,c,s,r)=>{var KJ=$[r+40>>2],YJ={tm_sec:Z[r>>2],tm_min:Z[r+4>>2],tm_hour:Z[r+8>>2],tm_mday:Z[r+12>>2],tm_mon:Z[r+16>>2],tm_year:Z[r+20>>2],tm_wday:Z[r+24>>2],tm_yday:Z[r+28>>2],tm_isdst:Z[r+32>>2],tm_gmtoff:Z[r+36>>2],tm_zone:KJ?EJ(KJ):""},DJ=EJ(s),hJ={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var pJ in hJ)DJ=DJ.replace(new RegExp(pJ,"g"),hJ[pJ]);var rJ=["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],VQ=["January","February","March","April","May","June","July","August","September","October","November","December"];function GQ(uJ,sJ,AQ){var kQ=typeof uJ=="number"?uJ.toString():uJ||"";while(kQ.length<sJ)kQ=AQ[0]+kQ;return kQ}function iJ(uJ,sJ){return GQ(uJ,sJ,"0")}function lJ(uJ,sJ){function AQ(cQ){return cQ<0?-1:cQ>0?1:0}var kQ;if((kQ=AQ(uJ.getFullYear()-sJ.getFullYear()))===0){if((kQ=AQ(uJ.getMonth()-sJ.getMonth()))===0)kQ=AQ(uJ.getDate()-sJ.getDate())}return kQ}function eJ(uJ){switch(uJ.getDay()){case 0:return new Date(uJ.getFullYear()-1,11,29);case 1:return uJ;case 2:return new Date(uJ.getFullYear(),0,3);case 3:return new Date(uJ.getFullYear(),0,2);case 4:return new Date(uJ.getFullYear(),0,1);case 5:return new Date(uJ.getFullYear()-1,11,31);case 6:return new Date(uJ.getFullYear()-1,11,30)}}function SQ(uJ){var sJ=o$(new Date(uJ.tm_year+1900,0,1),uJ.tm_yday),AQ=new Date(sJ.getFullYear(),0,4),kQ=new Date(sJ.getFullYear()+1,0,4),cQ=eJ(AQ),_Q=eJ(kQ);if(lJ(cQ,sJ)<=0){if(lJ(_Q,sJ)<=0)return sJ.getFullYear()+1;return sJ.getFullYear()}return sJ.getFullYear()-1}var UQ={"%a":(uJ)=>rJ[uJ.tm_wday].substring(0,3),"%A":(uJ)=>rJ[uJ.tm_wday],"%b":(uJ)=>VQ[uJ.tm_mon].substring(0,3),"%B":(uJ)=>VQ[uJ.tm_mon],"%C":(uJ)=>{var sJ=uJ.tm_year+1900;return iJ(sJ/100|0,2)},"%d":(uJ)=>iJ(uJ.tm_mday,2),"%e":(uJ)=>GQ(uJ.tm_mday,2," "),"%g":(uJ)=>SQ(uJ).toString().substring(2),"%G":(uJ)=>SQ(uJ),"%H":(uJ)=>iJ(uJ.tm_hour,2),"%I":(uJ)=>{var sJ=uJ.tm_hour;if(sJ==0)sJ=12;else if(sJ>12)sJ-=12;return iJ(sJ,2)},"%j":(uJ)=>iJ(uJ.tm_mday+n$(vV(uJ.tm_year+1900)?x6:w6,uJ.tm_mon-1),3),"%m":(uJ)=>iJ(uJ.tm_mon+1,2),"%M":(uJ)=>iJ(uJ.tm_min,2),"%n":()=>"\n","%p":(uJ)=>{if(uJ.tm_hour>=0&&uJ.tm_hour<12)return"AM";return"PM"},"%S":(uJ)=>iJ(uJ.tm_sec,2),"%t":()=>"\t","%u":(uJ)=>uJ.tm_wday||7,"%U":(uJ)=>{var sJ=uJ.tm_yday+7-uJ.tm_wday;return iJ(Math.floor(sJ/7),2)},"%V":(uJ)=>{var sJ=Math.floor((uJ.tm_yday+7-(uJ.tm_wday+6)%7)/7);if((uJ.tm_wday+371-uJ.tm_yday-2)%7<=2)sJ++;if(!sJ){sJ=52;var AQ=(uJ.tm_wday+7-uJ.tm_yday-1)%7;if(AQ==4||AQ==5&&vV(uJ.tm_year%400-1))sJ++}else if(sJ==53){var kQ=(uJ.tm_wday+371-uJ.tm_yday)%7;if(kQ!=4&&(kQ!=3||!vV(uJ.tm_year)))sJ=1}return iJ(sJ,2)},"%w":(uJ)=>uJ.tm_wday,"%W":(uJ)=>{var sJ=uJ.tm_yday+7-(uJ.tm_wday+6)%7;return iJ(Math.floor(sJ/7),2)},"%y":(uJ)=>(uJ.tm_year+1900).toString().substring(2),"%Y":(uJ)=>uJ.tm_year+1900,"%z":(uJ)=>{var sJ=uJ.tm_gmtoff,AQ=sJ>=0;return sJ=Math.abs(sJ)/60,sJ=sJ/60*100+sJ%60,(AQ?"+":"-")+String("0000"+sJ).slice(-4)},"%Z":(uJ)=>uJ.tm_zone,"%%":()=>"%"};DJ=DJ.replace(/%%/g,"\0\0");for(var pJ in UQ)if(DJ.includes(pJ))DJ=DJ.replace(new RegExp(pJ,"g"),UQ[pJ](YJ));DJ=DJ.replace(/\0\0/g,"%");var qQ=wJ(DJ,!1);if(qQ.length>c)return 0;return r$(qQ,x),qQ.length-1},t$=(x,c,s,r,KJ)=>a$(x,c,s,r),e$=(x)=>{if(x instanceof u||x=="unwind")return VJ;E(1,x)},J5=(x)=>{var c=MJ(x)+1,s=T0(c);return oJ(x,s,c),s},v6=function(x,c,s,r){if(!x)x=this;this.parent=x,this.mount=x.mount,this.mounted=null,this.id=f.nextInode++,this.name=c,this.mode=s,this.node_ops={},this.stream_ops={},this.rdev=r},MV=292|73,_V=146;Object.defineProperties(v6.prototype,{read:{get:function(){return(this.mode&MV)===MV},set:function(x){x?this.mode|=MV:this.mode&=~MV}},write:{get:function(){return(this.mode&_V)===_V},set:function(x){x?this.mode|=_V:this.mode&=~_V}},isFolder:{get:function(){return f.isDir(this.mode)}},isDevice:{get:function(){return f.isChrdev(this.mode)}}}),f.FSNode=v6,f.createPreloadedFile=cJ,f.staticInit(),R.FS_createPath=f.createPath,R.FS_createDataFile=f.createDataFile,R.FS_createPreloadedFile=f.createPreloadedFile,R.FS_unlink=f.unlink,R.FS_createLazyFile=f.createLazyFile,R.FS_createDevice=f.createDevice;var Q5={a:QQ,b:SJ,e:CQ,r:tJ,v:YQ,f:BQ,p:OQ,o:jQ,q:TQ,j:IQ,h:EQ,g:RQ,k:PQ,n:FQ,s:NV,t:IV,d:h$,c:m$,u:p$,l:l$,i:d$,m:t$},uQ=$Q(),V5=()=>(V5=uQ.x)(),M6=R._main=(x,c)=>(M6=R._main=uQ.y)(x,c),_6=()=>(_6=uQ.z)(),$5=(x)=>($5=uQ.free)(x),Z5=(x)=>(Z5=uQ.malloc)(x),T0=(x)=>(T0=uQ.B)(x),b6=(x)=>(b6=uQ.C)(x);R.addRunDependency=C,R.removeRunDependency=h,R.FS_createPath=f.createPath,R.FS_createLazyFile=f.createLazyFile,R.FS_createDevice=f.createDevice,R.callMain=y6,R.FS_createPreloadedFile=f.createPreloadedFile,R.FS=f,R.FS_createDataFile=f.createDataFile,R.FS_unlink=f.unlink;var bV;WJ=function x(){if(!bV)g6();if(!bV)WJ=x};function y6(x=[]){var c=M6;x.unshift(Y);var s=x.length,r=T0((s+1)*4),KJ=r;x.forEach((DJ)=>{$[KJ>>2]=J5(DJ),KJ+=4}),$[KJ>>2]=0;try{var YJ=c(s,r);return S6(YJ,!0),YJ}catch(DJ){return e$(DJ)}}function g6(x=q){if(PJ>0)return;if(_(),PJ>0)return;function c(){if(bV)return;if(bV=!0,R.calledRun=!0,JJ)return;if(t(),QJ(),M(R),R.onRuntimeInitialized)R.onRuntimeInitialized();if(c6)y6(x);GJ()}if(R.setStatus)R.setStatus("Running..."),setTimeout(function(){setTimeout(function(){R.setStatus("")},1),c()},1);else c()}if(R.preInit){if(typeof R.preInit=="function")R.preInit=[R.preInit];while(R.preInit.length>0)R.preInit.pop()()}var c6=!1;if(R.noInitialRun)c6=!1;return g6(),g.ready}})();export{B5 as createPiperPhonemize};
diff --git a/example/browser-standalone-bundle.js b/example/browser-standalone-bundle.js
new file mode 100644
index 0000000..88912fb
--- /dev/null
+++ b/example/browser-standalone-bundle.js
@@ -0,0 +1,377 @@
+// deno-fmt-ignore-file
+// deno-lint-ignore-file
+// This code was bundled using `deno bundle` and it's not recommended to edit it manually
+
+const HF_BASE = 'https://huggingface.co/diffusionstudio/piper-voices/resolve/main';
+const ONNX_BASE = 'https://cdnjs.cloudflare.com/ajax/libs/onnxruntime-web/1.18.0/';
+const WASM_BASE = "https://cdn.jsdelivr.net/npm/@diffusionstudio/piper-wasm@1.0.0/build/piper_phonemize";
+const PATH_MAP = {
+  /*  'ar_JO-kareem-low': 'ar/ar_JO/kareem/low/ar_JO-kareem-low.onnx',
+    'ar_JO-kareem-medium': 'ar/ar_JO/kareem/medium/ar_JO-kareem-medium.onnx',
+    'ca_ES-upc_ona-medium': 'ca/ca_ES/upc_ona/medium/ca_ES-upc_ona-medium.onnx',
+    'ca_ES-upc_ona-x_low': 'ca/ca_ES/upc_ona/x_low/ca_ES-upc_ona-x_low.onnx',
+    'ca_ES-upc_pau-x_low': 'ca/ca_ES/upc_pau/x_low/ca_ES-upc_pau-x_low.onnx',
+    'cs_CZ-jirka-low': 'cs/cs_CZ/jirka/low/cs_CZ-jirka-low.onnx',
+    'cs_CZ-jirka-medium': 'cs/cs_CZ/jirka/medium/cs_CZ-jirka-medium.onnx',
+    'da_DK-talesyntese-medium': 'da/da_DK/talesyntese/medium/da_DK-talesyntese-medium.onnx',
+    'de_DE-eva_k-x_low': 'de/de_DE/eva_k/x_low/de_DE-eva_k-x_low.onnx',
+    'de_DE-karlsson-low': 'de/de_DE/karlsson/low/de_DE-karlsson-low.onnx',
+    'de_DE-kerstin-low': 'de/de_DE/kerstin/low/de_DE-kerstin-low.onnx',
+    'de_DE-mls-medium': 'de/de_DE/mls/medium/de_DE-mls-medium.onnx',
+    'de_DE-pavoque-low': 'de/de_DE/pavoque/low/de_DE-pavoque-low.onnx',
+    'de_DE-ramona-low': 'de/de_DE/ramona/low/de_DE-ramona-low.onnx',
+    'de_DE-thorsten-high': 'de/de_DE/thorsten/high/de_DE-thorsten-high.onnx',
+    'de_DE-thorsten-low': 'de/de_DE/thorsten/low/de_DE-thorsten-low.onnx',
+    'de_DE-thorsten-medium': 'de/de_DE/thorsten/medium/de_DE-thorsten-medium.onnx',
+    'de_DE-thorsten_emotional-medium': 'de/de_DE/thorsten_emotional/medium/de_DE-thorsten_emotional-medium.onnx',
+    'el_GR-rapunzelina-low': 'el/el_GR/rapunzelina/low/el_GR-rapunzelina-low.onnx',
+    'en_GB-alan-low': 'en/en_GB/alan/low/en_GB-alan-low.onnx',
+    'en_GB-alan-medium': 'en/en_GB/alan/medium/en_GB-alan-medium.onnx',
+    'en_GB-alba-medium': 'en/en_GB/alba/medium/en_GB-alba-medium.onnx',
+    'en_GB-aru-medium': 'en/en_GB/aru/medium/en_GB-aru-medium.onnx',
+    'en_GB-cori-high': 'en/en_GB/cori/high/en_GB-cori-high.onnx',
+    'en_GB-cori-medium': 'en/en_GB/cori/medium/en_GB-cori-medium.onnx',
+    'en_GB-jenny_dioco-medium': 'en/en_GB/jenny_dioco/medium/en_GB-jenny_dioco-medium.onnx',
+    'en_GB-northern_english_male-medium': 'en/en_GB/northern_english_male/medium/en_GB-northern_english_male-medium.onnx',
+    'en_GB-semaine-medium': 'en/en_GB/semaine/medium/en_GB-semaine-medium.onnx',
+    'en_GB-southern_english_female-low': 'en/en_GB/southern_english_female/low/en_GB-southern_english_female-low.onnx',
+  'en_GB-vctk-medium': 'en/en_GB/vctk/medium/en_GB-vctk-medium.onnx',
+  'en_US-amy-low': 'en/en_US/amy/low/en_US-amy-low.onnx',
+  'en_US-amy-medium': 'en/en_US/amy/medium/en_US-amy-medium.onnx',
+  'en_US-arctic-medium': 'en/en_US/arctic/medium/en_US-arctic-medium.onnx',
+  'en_US-danny-low': 'en/en_US/danny/low/en_US-danny-low.onnx', */
+  'en_US-hfc_female-medium': 'en/en_US/hfc_female/medium/en_US-hfc_female-medium.onnx',
+  /* 'en_US-hfc_male-medium': 'en/en_US/hfc_male/medium/en_US-hfc_male-medium.onnx',
+  'en_US-joe-medium': 'en/en_US/joe/medium/en_US-joe-medium.onnx',
+  'en_US-kathleen-low': 'en/en_US/kathleen/low/en_US-kathleen-low.onnx',
+  'en_US-kristin-medium': 'en/en_US/kristin/medium/en_US-kristin-medium.onnx',
+  'en_US-kusal-medium': 'en/en_US/kusal/medium/en_US-kusal-medium.onnx',
+  'en_US-l2arctic-medium': 'en/en_US/l2arctic/medium/en_US-l2arctic-medium.onnx',
+  'en_US-lessac-high': 'en/en_US/lessac/high/en_US-lessac-high.onnx',
+  'en_US-lessac-low': 'en/en_US/lessac/low/en_US-lessac-low.onnx',
+  'en_US-lessac-medium': 'en/en_US/lessac/medium/en_US-lessac-medium.onnx',
+  'en_US-libritts-high': 'en/en_US/libritts/high/en_US-libritts-high.onnx',
+  'en_US-libritts_r-medium': 'en/en_US/libritts_r/medium/en_US-libritts_r-medium.onnx',
+  'en_US-ljspeech-high': 'en/en_US/ljspeech/high/en_US-ljspeech-high.onnx',
+  'en_US-ljspeech-medium': 'en/en_US/ljspeech/medium/en_US-ljspeech-medium.onnx',
+  'en_US-ryan-high': 'en/en_US/ryan/high/en_US-ryan-high.onnx',
+  'en_US-ryan-low': 'en/en_US/ryan/low/en_US-ryan-low.onnx',
+  'en_US-ryan-medium': 'en/en_US/ryan/medium/en_US-ryan-medium.onnx',
+  'es_ES-carlfm-x_low': 'es/es_ES/carlfm/x_low/es_ES-carlfm-x_low.onnx',
+    'es_ES-davefx-medium': 'es/es_ES/davefx/medium/es_ES-davefx-medium.onnx',
+    'es_ES-mls_10246-low': 'es/es_ES/mls_10246/low/es_ES-mls_10246-low.onnx',
+    'es_ES-mls_9972-low': 'es/es_ES/mls_9972/low/es_ES-mls_9972-low.onnx',
+    'es_ES-sharvard-medium': 'es/es_ES/sharvard/medium/es_ES-sharvard-medium.onnx',
+    'es_MX-ald-medium': 'es/es_MX/ald/medium/es_MX-ald-medium.onnx',
+    'es_MX-claude-high': 'es/es_MX/claude/high/es_MX-claude-high.onnx',
+    'fa_IR-amir-medium': 'fa/fa_IR/amir/medium/fa_IR-amir-medium.onnx',
+    'fa_IR-gyro-medium': 'fa/fa_IR/gyro/medium/fa_IR-gyro-medium.onnx',
+    'fi_FI-harri-low': 'fi/fi_FI/harri/low/fi_FI-harri-low.onnx',
+    'fi_FI-harri-medium': 'fi/fi_FI/harri/medium/fi_FI-harri-medium.onnx',
+    'fr_FR-gilles-low': 'fr/fr_FR/gilles/low/fr_FR-gilles-low.onnx',
+    'fr_FR-mls-medium': 'fr/fr_FR/mls/medium/fr_FR-mls-medium.onnx',
+    'fr_FR-mls_1840-low': 'fr/fr_FR/mls_1840/low/fr_FR-mls_1840-low.onnx',
+    'fr_FR-siwis-low': 'fr/fr_FR/siwis/low/fr_FR-siwis-low.onnx',
+    'fr_FR-siwis-medium': 'fr/fr_FR/siwis/medium/fr_FR-siwis-medium.onnx',
+    'fr_FR-tom-medium': 'fr/fr_FR/tom/medium/fr_FR-tom-medium.onnx',
+    'fr_FR-upmc-medium': 'fr/fr_FR/upmc/medium/fr_FR-upmc-medium.onnx',
+    'hu_HU-anna-medium': 'hu/hu_HU/anna/medium/hu_HU-anna-medium.onnx',
+    'hu_HU-berta-medium': 'hu/hu_HU/berta/medium/hu_HU-berta-medium.onnx',
+    'hu_HU-imre-medium': 'hu/hu_HU/imre/medium/hu_HU-imre-medium.onnx',
+    'is_IS-bui-medium': 'is/is_IS/bui/medium/is_IS-bui-medium.onnx',
+    'is_IS-salka-medium': 'is/is_IS/salka/medium/is_IS-salka-medium.onnx',
+    'is_IS-steinn-medium': 'is/is_IS/steinn/medium/is_IS-steinn-medium.onnx',
+    'is_IS-ugla-medium': 'is/is_IS/ugla/medium/is_IS-ugla-medium.onnx',
+    'it_IT-riccardo-x_low': 'it/it_IT/riccardo/x_low/it_IT-riccardo-x_low.onnx',
+    'ka_GE-natia-medium': 'ka/ka_GE/natia/medium/ka_GE-natia-medium.onnx',
+    'kk_KZ-iseke-x_low': 'kk/kk_KZ/iseke/x_low/kk_KZ-iseke-x_low.onnx',
+    'kk_KZ-issai-high': 'kk/kk_KZ/issai/high/kk_KZ-issai-high.onnx',
+    'kk_KZ-raya-x_low': 'kk/kk_KZ/raya/x_low/kk_KZ-raya-x_low.onnx',
+    'lb_LU-marylux-medium': 'lb/lb_LU/marylux/medium/lb_LU-marylux-medium.onnx',
+    'ne_NP-google-medium': 'ne/ne_NP/google/medium/ne_NP-google-medium.onnx',
+    'ne_NP-google-x_low': 'ne/ne_NP/google/x_low/ne_NP-google-x_low.onnx',
+    'nl_BE-nathalie-medium': 'nl/nl_BE/nathalie/medium/nl_BE-nathalie-medium.onnx',
+    'nl_BE-nathalie-x_low': 'nl/nl_BE/nathalie/x_low/nl_BE-nathalie-x_low.onnx',
+    'nl_BE-rdh-medium': 'nl/nl_BE/rdh/medium/nl_BE-rdh-medium.onnx',
+    'nl_BE-rdh-x_low': 'nl/nl_BE/rdh/x_low/nl_BE-rdh-x_low.onnx',
+    'nl_NL-mls-medium': 'nl/nl_NL/mls/medium/nl_NL-mls-medium.onnx',
+    'nl_NL-mls_5809-low': 'nl/nl_NL/mls_5809/low/nl_NL-mls_5809-low.onnx',
+    'nl_NL-mls_7432-low': 'nl/nl_NL/mls_7432/low/nl_NL-mls_7432-low.onnx',
+    'no_NO-talesyntese-medium': 'no/no_NO/talesyntese/medium/no_NO-talesyntese-medium.onnx',
+    'pl_PL-darkman-medium': 'pl/pl_PL/darkman/medium/pl_PL-darkman-medium.onnx',
+    'pl_PL-gosia-medium': 'pl/pl_PL/gosia/medium/pl_PL-gosia-medium.onnx',
+    'pl_PL-mc_speech-medium': 'pl/pl_PL/mc_speech/medium/pl_PL-mc_speech-medium.onnx',
+    'pl_PL-mls_6892-low': 'pl/pl_PL/mls_6892/low/pl_PL-mls_6892-low.onnx',
+    'pt_BR-edresson-low': 'pt/pt_BR/edresson/low/pt_BR-edresson-low.onnx',
+    'pt_BR-faber-medium': 'pt/pt_BR/faber/medium/pt_BR-faber-medium.onnx',
+    'pt_PT-tugão-medium': 'pt/pt_PT/tugão/medium/pt_PT-tugão-medium.onnx',
+    'ro_RO-mihai-medium': 'ro/ro_RO/mihai/medium/ro_RO-mihai-medium.onnx',
+    'ru_RU-denis-medium': 'ru/ru_RU/denis/medium/ru_RU-denis-medium.onnx',
+    'ru_RU-dmitri-medium': 'ru/ru_RU/dmitri/medium/ru_RU-dmitri-medium.onnx',
+    'ru_RU-irina-medium': 'ru/ru_RU/irina/medium/ru_RU-irina-medium.onnx',
+    'ru_RU-ruslan-medium': 'ru/ru_RU/ruslan/medium/ru_RU-ruslan-medium.onnx',
+    'sk_SK-lili-medium': 'sk/sk_SK/lili/medium/sk_SK-lili-medium.onnx',
+    'sl_SI-artur-medium': 'sl/sl_SI/artur/medium/sl_SI-artur-medium.onnx',
+    'sr_RS-serbski_institut-medium': 'sr/sr_RS/serbski_institut/medium/sr_RS-serbski_institut-medium.onnx',
+    'sv_SE-nst-medium': 'sv/sv_SE/nst/medium/sv_SE-nst-medium.onnx',
+    'sw_CD-lanfrica-medium': 'sw/sw_CD/lanfrica/medium/sw_CD-lanfrica-medium.onnx',
+    'tr_TR-dfki-medium': 'tr/tr_TR/dfki/medium/tr_TR-dfki-medium.onnx',
+    'tr_TR-fahrettin-medium': 'tr/tr_TR/fahrettin/medium/tr_TR-fahrettin-medium.onnx',
+    'tr_TR-fettah-medium': 'tr/tr_TR/fettah/medium/tr_TR-fettah-medium.onnx',
+    'uk_UA-lada-x_low': 'uk/uk_UA/lada/x_low/uk_UA-lada-x_low.onnx',
+    'uk_UA-ukrainian_tts-medium': 'uk/uk_UA/ukrainian_tts/medium/uk_UA-ukrainian_tts-medium.onnx',
+    'vi_VN-25hours_single-low': 'vi/vi_VN/25hours_single/low/vi_VN-25hours_single-low.onnx',
+    'vi_VN-vais1000-medium': 'vi/vi_VN/vais1000/medium/vi_VN-vais1000-medium.onnx',
+    'vi_VN-vivos-x_low': 'vi/vi_VN/vivos/x_low/vi_VN-vivos-x_low.onnx',
+    'zh_CN-huayan-medium': 'zh/zh_CN/huayan/medium/zh_CN-huayan-medium.onnx',
+    'zh_CN-huayan-x_low': 'zh/zh_CN/huayan/x_low/zh_CN-huayan-x_low.onnx' */
+};
+//export { HF_BASE as HF_BASE };
+//export { ONNX_BASE as ONNX_BASE };
+//export { WASM_BASE as WASM_BASE };
+//export { PATH_MAP as PATH_MAP };
+async function writeBlob(url, blob) {
+  if (!url.match('https://huggingface.co'))
+    return;
+  try {
+    console.log(blob);
+    const root = await navigator.storage.getDirectory();
+    const dir = await root.getDirectoryHandle('piper', {
+      create: true
+    });
+    const path = url.split('/').at(-1);
+    const file = await dir.getFileHandle(path, {
+      create: true
+    });
+    const writable = await file.createWritable();
+    await writable.write(blob);
+    await writable.close();
+  } catch (e) {
+    console.error(e);
+  }
+}
+async function removeBlob(url) {
+  try {
+    const root = await navigator.storage.getDirectory();
+    const dir = await root.getDirectoryHandle('piper');
+    const path = url.split('/').at(-1);
+    const file = await dir.getFileHandle(path);
+    await file.remove();
+  } catch (e) {
+    console.error(e);
+  }
+}
+async function readBlob(url) {
+  if (!url.match('https://huggingface.co'))
+    return;
+  try {
+    const root = await navigator.storage.getDirectory();
+    const dir = await root.getDirectoryHandle('piper', {
+      create: true
+    });
+    const path = url.split('/').at(-1);
+    const file = await dir.getFileHandle(path);
+    return await file.getFile();
+  } catch (e) {
+    return undefined;
+  }
+}
+async function fetchBlob(url, callback) {
+  console.log(url);
+  return await new Promise( (resolve) => {
+    let xContentLength;
+    const xhr = new XMLHttpRequest();
+    xhr.responseType = "blob";
+    
+    xhr.onprogress = (event) => {
+      callback?.({
+        url,
+        total: xContentLength ??= event.total,
+        loaded: event.loaded
+      });
+    }
+    ;
+    
+    xhr.onreadystatechange = () => {
+      if (xhr.readyState >= xhr.HEADERS_RECEIVED && xContentLength == undefined && xhr.getAllResponseHeaders().includes("x-content-length")) {
+        xContentLength = Number(xhr.getResponseHeader("x-content-length"));
+      }
+      if (xhr.readyState === xhr.DONE) {
+        callback?.({
+          url,
+          total: xContentLength,
+          loaded: xContentLength
+        });
+        resolve(xhr.response);
+      }
+    }
+    ;
+    xhr.open("GET", url);
+    xhr.send();
+  }
+  );
+}
+function pcm2wav(buffer, numChannels, sampleRate) {
+  const bufferLength = buffer.length;
+  const view = new DataView(new ArrayBuffer(bufferLength * numChannels * 2 + 44));
+  view.setUint32(0, 0x46464952, true);
+  view.setUint32(4, view.buffer.byteLength - 8, true);
+  view.setUint32(8, 0x45564157, true);
+  view.setUint32(12, 0x20746d66, true);
+  view.setUint32(16, 0x10, true);
+  view.setUint16(20, 0x0001, true);
+  view.setUint16(22, numChannels, true);
+  view.setUint32(24, sampleRate, true);
+  view.setUint32(28, numChannels * 2 * sampleRate, true);
+  view.setUint16(32, numChannels * 2, true);
+  view.setUint16(34, 16, true);
+  view.setUint32(36, 0x61746164, true);
+  view.setUint32(40, 2 * bufferLength, true);
+  let p = 44;
+  for (let i = 0; i < bufferLength; i++) {
+    const v = buffer[i];
+    if (v >= 1)
+      view.setInt16(p, 0x7fff, true);
+    else if (v <= -1)
+      view.setInt16(p, -0x8000, true);
+    else
+      view.setInt16(p, v * 0x8000 | 0, true);
+    p += 2;
+  }
+  return view.buffer;
+}
+async function predict(config, callback) {
+  const {createPiperPhonemize} = await import('data:text/javascript;base64,var __defProp = Object.defineProperty;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __toCommonJS = (from) => {
  const moduleCache = __toCommonJS.moduleCache ??= new WeakMap;
  var cached = moduleCache.get(from);
  if (cached)
    return cached;
  var to = __defProp({}, "__esModule", { value: true });
  var desc = { enumerable: false };
  if (from && typeof from === "object" || typeof from === "function") {
    for (let key of __getOwnPropNames(from))
      if (!__hasOwnProp.call(to, key))
        __defProp(to, key, {
          get: () => from[key],
          enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
        });
  }
  moduleCache.set(from, to);
  return to;
};
var __export = (target, all) => {
  for (var name in all)
    __defProp(target, name, {
      get: all[name],
      enumerable: true,
      configurable: true,
      set: (newValue) => all[name] = () => newValue
    });
};
var __esm = (fn, res) => () => (fn && (res = fn(fn = 0)), res);
var __require = ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
  get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
}) : x)(function(x) {
  if (typeof require !== "undefined")
    return require.apply(this, arguments);
  throw Error('Dynamic require of "' + x + '" is not supported');
});

// node:path
var exports_path = {};
__export(exports_path, {
  default: () => {
    {
      return q;
    }
  }
});
var L, b, z, D, T, R, _, E, C, A, y, h, m, q;
var init_path = __esm(() => {
  L = Object.create;
  b = Object.defineProperty;
  z = Object.getOwnPropertyDescriptor;
  D = Object.getOwnPropertyNames;
  T = Object.getPrototypeOf;
  R = Object.prototype.hasOwnProperty;
  _ = (f, e) => () => (e || f((e = { exports: {} }).exports, e), e.exports);
  E = (f, e) => {
    for (var r in e)
      b(f, r, { get: e[r], enumerable: true });
  };
  C = (f, e, r, l) => {
    if (e && typeof e == "object" || typeof e == "function")
      for (let i of D(e))
        !R.call(f, i) && i !== r && b(f, i, { get: () => e[i], enumerable: !(l = z(e, i)) || l.enumerable });
    return f;
  };
  A = (f, e, r) => (C(f, e, "default"), r && C(r, e, "default"));
  y = (f, e, r) => (r = f != null ? L(T(f)) : {}, C(e || !f || !f.__esModule ? b(r, "default", { value: f, enumerable: true }) : r, f));
  h = _((F, S) => {
    function c(f) {
      if (typeof f != "string")
        throw new TypeError("Path must be a string. Received " + JSON.stringify(f));
    }
    function w(f, e) {
      for (var r = "", l = 0, i = -1, s = 0, n, t = 0;t <= f.length; ++t) {
        if (t < f.length)
          n = f.charCodeAt(t);
        else {
          if (n === 47)
            break;
          n = 47;
        }
        if (n === 47) {
          if (!(i === t - 1 || s === 1))
            if (i !== t - 1 && s === 2) {
              if (r.length < 2 || l !== 2 || r.charCodeAt(r.length - 1) !== 46 || r.charCodeAt(r.length - 2) !== 46) {
                if (r.length > 2) {
                  var a = r.lastIndexOf("/");
                  if (a !== r.length - 1) {
                    a === -1 ? (r = "", l = 0) : (r = r.slice(0, a), l = r.length - 1 - r.lastIndexOf("/")), i = t, s = 0;
                    continue;
                  }
                } else if (r.length === 2 || r.length === 1) {
                  r = "", l = 0, i = t, s = 0;
                  continue;
                }
              }
              e && (r.length > 0 ? r += "/.." : r = "..", l = 2);
            } else
              r.length > 0 ? r += "/" + f.slice(i + 1, t) : r = f.slice(i + 1, t), l = t - i - 1;
          i = t, s = 0;
        } else
          n === 46 && s !== -1 ? ++s : s = -1;
      }
      return r;
    }
    function J(f, e) {
      var r = e.dir || e.root, l = e.base || (e.name || "") + (e.ext || "");
      return r ? r === e.root ? r + l : r + f + l : l;
    }
    var g = { resolve: function() {
      for (var e = "", r = false, l, i = arguments.length - 1;i >= -1 && !r; i--) {
        var s;
        i >= 0 ? s = arguments[i] : (l === undefined && (l = process.cwd()), s = l), c(s), s.length !== 0 && (e = s + "/" + e, r = s.charCodeAt(0) === 47);
      }
      return e = w(e, !r), r ? e.length > 0 ? "/" + e : "/" : e.length > 0 ? e : ".";
    }, normalize: function(e) {
      if (c(e), e.length === 0)
        return ".";
      var r = e.charCodeAt(0) === 47, l = e.charCodeAt(e.length - 1) === 47;
      return e = w(e, !r), e.length === 0 && !r && (e = "."), e.length > 0 && l && (e += "/"), r ? "/" + e : e;
    }, isAbsolute: function(e) {
      return c(e), e.length > 0 && e.charCodeAt(0) === 47;
    }, join: function() {
      if (arguments.length === 0)
        return ".";
      for (var e, r = 0;r < arguments.length; ++r) {
        var l = arguments[r];
        c(l), l.length > 0 && (e === undefined ? e = l : e += "/" + l);
      }
      return e === undefined ? "." : g.normalize(e);
    }, relative: function(e, r) {
      if (c(e), c(r), e === r || (e = g.resolve(e), r = g.resolve(r), e === r))
        return "";
      for (var l = 1;l < e.length && e.charCodeAt(l) === 47; ++l)
        ;
      for (var i = e.length, s = i - l, n = 1;n < r.length && r.charCodeAt(n) === 47; ++n)
        ;
      for (var t = r.length, a = t - n, v = s < a ? s : a, u = -1, o = 0;o <= v; ++o) {
        if (o === v) {
          if (a > v) {
            if (r.charCodeAt(n + o) === 47)
              return r.slice(n + o + 1);
            if (o === 0)
              return r.slice(n + o);
          } else
            s > v && (e.charCodeAt(l + o) === 47 ? u = o : o === 0 && (u = 0));
          break;
        }
        var k = e.charCodeAt(l + o), P = r.charCodeAt(n + o);
        if (k !== P)
          break;
        k === 47 && (u = o);
      }
      var d = "";
      for (o = l + u + 1;o <= i; ++o)
        (o === i || e.charCodeAt(o) === 47) && (d.length === 0 ? d += ".." : d += "/..");
      return d.length > 0 ? d + r.slice(n + u) : (n += u, r.charCodeAt(n) === 47 && ++n, r.slice(n));
    }, _makeLong: function(e) {
      return e;
    }, dirname: function(e) {
      if (c(e), e.length === 0)
        return ".";
      for (var r = e.charCodeAt(0), l = r === 47, i = -1, s = true, n = e.length - 1;n >= 1; --n)
        if (r = e.charCodeAt(n), r === 47) {
          if (!s) {
            i = n;
            break;
          }
        } else
          s = false;
      return i === -1 ? l ? "/" : "." : l && i === 1 ? "//" : e.slice(0, i);
    }, basename: function(e, r) {
      if (r !== undefined && typeof r != "string")
        throw new TypeError('"ext" argument must be a string');
      c(e);
      var l = 0, i = -1, s = true, n;
      if (r !== undefined && r.length > 0 && r.length <= e.length) {
        if (r.length === e.length && r === e)
          return "";
        var t = r.length - 1, a = -1;
        for (n = e.length - 1;n >= 0; --n) {
          var v = e.charCodeAt(n);
          if (v === 47) {
            if (!s) {
              l = n + 1;
              break;
            }
          } else
            a === -1 && (s = false, a = n + 1), t >= 0 && (v === r.charCodeAt(t) ? --t === -1 && (i = n) : (t = -1, i = a));
        }
        return l === i ? i = a : i === -1 && (i = e.length), e.slice(l, i);
      } else {
        for (n = e.length - 1;n >= 0; --n)
          if (e.charCodeAt(n) === 47) {
            if (!s) {
              l = n + 1;
              break;
            }
          } else
            i === -1 && (s = false, i = n + 1);
        return i === -1 ? "" : e.slice(l, i);
      }
    }, extname: function(e) {
      c(e);
      for (var r = -1, l = 0, i = -1, s = true, n = 0, t = e.length - 1;t >= 0; --t) {
        var a = e.charCodeAt(t);
        if (a === 47) {
          if (!s) {
            l = t + 1;
            break;
          }
          continue;
        }
        i === -1 && (s = false, i = t + 1), a === 46 ? r === -1 ? r = t : n !== 1 && (n = 1) : r !== -1 && (n = -1);
      }
      return r === -1 || i === -1 || n === 0 || n === 1 && r === i - 1 && r === l + 1 ? "" : e.slice(r, i);
    }, format: function(e) {
      if (e === null || typeof e != "object")
        throw new TypeError('The "pathObject" argument must be of type Object. Received type ' + typeof e);
      return J("/", e);
    }, parse: function(e) {
      c(e);
      var r = { root: "", dir: "", base: "", ext: "", name: "" };
      if (e.length === 0)
        return r;
      var l = e.charCodeAt(0), i = l === 47, s;
      i ? (r.root = "/", s = 1) : s = 0;
      for (var n = -1, t = 0, a = -1, v = true, u = e.length - 1, o = 0;u >= s; --u) {
        if (l = e.charCodeAt(u), l === 47) {
          if (!v) {
            t = u + 1;
            break;
          }
          continue;
        }
        a === -1 && (v = false, a = u + 1), l === 46 ? n === -1 ? n = u : o !== 1 && (o = 1) : n !== -1 && (o = -1);
      }
      return n === -1 || a === -1 || o === 0 || o === 1 && n === a - 1 && n === t + 1 ? a !== -1 && (t === 0 && i ? r.base = r.name = e.slice(1, a) : r.base = r.name = e.slice(t, a)) : (t === 0 && i ? (r.name = e.slice(1, n), r.base = e.slice(1, a)) : (r.name = e.slice(t, n), r.base = e.slice(t, a)), r.ext = e.slice(n, a)), t > 0 ? r.dir = e.slice(0, t - 1) : i && (r.dir = "/"), r;
    }, sep: "/", delimiter: ":", win32: null, posix: null };
    g.posix = g;
    S.exports = g;
  });
  m = {};
  E(m, { default: () => q });
  A(m, y(h()));
  q = y(h());
});

// node:crypto
var exports_crypto = {};
__export(exports_crypto, {
  webcrypto: () => {
    {
      return cw;
    }
  },
  timingSafeEqual: () => {
    {
      return x0;
    }
  },
  scryptSync: () => {
    {
      return Id;
    }
  },
  scrypt: () => {
    {
      return Td;
    }
  },
  randomUUID: () => {
    {
      return lw;
    }
  },
  getRandomValues: () => {
    {
      return uw;
    }
  },
  getCurves: () => {
    {
      return dw;
    }
  },
  default: () => {
    {
      return Wq;
    }
  },
  DEFAULT_ENCODING: () => {
    {
      return Ga;
    }
  }
});
var dw, pw, Xa, vw, bw, mw, gw, R0, T2, Ja, Ya, ot, rn, ur, Nd, Dd, Ut, Te, on, Ie, ki, W0, $f, pc, Z0, sn, V0, G0, J0, hn, co, Jf, po, Qf, vo, Pc, Oc, th, ph, Qc, np, ap, bh, Ao, Bo, pn, _p, Ep, gh, qp, yh, Op, ko, Tt, Gr, No, Jt, pa, Rh, pr, Y_, Oi, Fi, Ui, k1, yn, Vo, Go, Z1, Xo, Fh, ba, Jh, Dv, Qr, fu, ou, os, eb, cu, lb, bu, vf, S7, db, yi, bf, wb, mu, wu, Mu, Eb, _u, xu, Eu, Au, Ub, Iu, Tu, ar, vs, ku, Yb, Qb, em, im, nm, yf, om, um, dm, pm, bm, Pu, Ou, Fu, ws, Aa, Em, Wu, ju, Ba, Dm, Fm, Es, Hm, Vm, ji, Yu, Ym, Xm, As, tl, ol, rg, ag, hg, hl, pg, dl, kn, cl, bl, Ln, Ds, Lg, Dg, yl, Il, Yg, t2, i2, Ws, Ks, s2, ri, Nl, or, Oa, b2, y2, _2, Pl, Cr, Tf, Cl, N2, Fl, F2, Wl, Z2, V2, Q2, ty, e0, ny, t0, uy, dy, vy, yy, xy, Ey, Iy, o0, td, h0, u0, Kf, d0, c0, nd, Hy, od, hd, Jy, dd, r3, n3, o3, cd, d3, p3, v3, m3, Ha, bd, _3, A3, k3, N3, P3, _d, xd, w0, Ed, j3, Y3, X3, ow, qd, Xt, zq, Ga, uw, lw, Hq, x0, Id, Td, cw, Wq;
var init_crypto = __esm(() => {
  dw = function() {
    return Hq;
  };
  pw = Object.create;
  Xa = Object.defineProperty;
  vw = Object.getOwnPropertyDescriptor;
  bw = Object.getOwnPropertyNames;
  mw = Object.getPrototypeOf;
  gw = Object.prototype.hasOwnProperty;
  R0 = (t, e) => () => (t && (e = t(t = 0)), e);
  T2 = (t, e) => () => (e || t((e = { exports: {} }).exports, e), e.exports);
  Ja = (t, e) => {
    for (var r in e)
      Xa(t, r, { get: e[r], enumerable: true });
  };
  Ya = (t, e, r, o) => {
    if (e && typeof e == "object" || typeof e == "function")
      for (let f of bw(e))
        !gw.call(t, f) && f !== r && Xa(t, f, { get: () => e[f], enumerable: !(o = vw(e, f)) || o.enumerable });
    return t;
  };
  ot = (t, e, r) => (Ya(t, e, "default"), r && Ya(r, e, "default"));
  rn = (t, e, r) => (r = t != null ? pw(mw(t)) : {}, Ya(e || !t || !t.__esModule ? Xa(r, "default", { value: t, enumerable: true }) : r, t));
  ur = (t) => Ya(Xa({}, "__esModule", { value: true }), t);
  Nd = T2((Qa) => {
    Qa.byteLength = ww;
    Qa.toByteArray = _w;
    Qa.fromByteArray = Ew;
    var jr = [], lr = [], yw = typeof Uint8Array < "u" ? Uint8Array : Array, B0 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
    for (nn = 0, kd = B0.length;nn < kd; ++nn)
      jr[nn] = B0[nn], lr[B0.charCodeAt(nn)] = nn;
    var nn, kd;
    lr["-".charCodeAt(0)] = 62;
    lr["_".charCodeAt(0)] = 63;
    function Ld(t) {
      var e = t.length;
      if (e % 4 > 0)
        throw new Error("Invalid string. Length must be a multiple of 4");
      var r = t.indexOf("=");
      r === -1 && (r = e);
      var o = r === e ? 0 : 4 - r % 4;
      return [r, o];
    }
    function ww(t) {
      var e = Ld(t), r = e[0], o = e[1];
      return (r + o) * 3 / 4 - o;
    }
    function Mw(t, e, r) {
      return (e + r) * 3 / 4 - r;
    }
    function _w(t) {
      var e, r = Ld(t), o = r[0], f = r[1], p = new yw(Mw(t, o, f)), m2 = 0, y2 = f > 0 ? o - 4 : o, M;
      for (M = 0;M < y2; M += 4)
        e = lr[t.charCodeAt(M)] << 18 | lr[t.charCodeAt(M + 1)] << 12 | lr[t.charCodeAt(M + 2)] << 6 | lr[t.charCodeAt(M + 3)], p[m2++] = e >> 16 & 255, p[m2++] = e >> 8 & 255, p[m2++] = e & 255;
      return f === 2 && (e = lr[t.charCodeAt(M)] << 2 | lr[t.charCodeAt(M + 1)] >> 4, p[m2++] = e & 255), f === 1 && (e = lr[t.charCodeAt(M)] << 10 | lr[t.charCodeAt(M + 1)] << 4 | lr[t.charCodeAt(M + 2)] >> 2, p[m2++] = e >> 8 & 255, p[m2++] = e & 255), p;
    }
    function xw(t) {
      return jr[t >> 18 & 63] + jr[t >> 12 & 63] + jr[t >> 6 & 63] + jr[t & 63];
    }
    function Sw(t, e, r) {
      for (var o, f = [], p = e;p < r; p += 3)
        o = (t[p] << 16 & 16711680) + (t[p + 1] << 8 & 65280) + (t[p + 2] & 255), f.push(xw(o));
      return f.join("");
    }
    function Ew(t) {
      for (var e, r = t.length, o = r % 3, f = [], p = 16383, m2 = 0, y2 = r - o;m2 < y2; m2 += p)
        f.push(Sw(t, m2, m2 + p > y2 ? y2 : m2 + p));
      return o === 1 ? (e = t[r - 1], f.push(jr[e >> 2] + jr[e << 4 & 63] + "==")) : o === 2 && (e = (t[r - 2] << 8) + t[r - 1], f.push(jr[e >> 10] + jr[e >> 4 & 63] + jr[e << 2 & 63] + "=")), f.join("");
    }
  });
  Dd = T2((q0) => {
    q0.read = function(t, e, r, o, f) {
      var p, m2, y2 = f * 8 - o - 1, M = (1 << y2) - 1, x = M >> 1, S = -7, E2 = r ? f - 1 : 0, B = r ? -1 : 1, q2 = t[e + E2];
      for (E2 += B, p = q2 & (1 << -S) - 1, q2 >>= -S, S += y2;S > 0; p = p * 256 + t[e + E2], E2 += B, S -= 8)
        ;
      for (m2 = p & (1 << -S) - 1, p >>= -S, S += o;S > 0; m2 = m2 * 256 + t[e + E2], E2 += B, S -= 8)
        ;
      if (p === 0)
        p = 1 - x;
      else {
        if (p === M)
          return m2 ? NaN : (q2 ? -1 : 1) * (1 / 0);
        m2 = m2 + Math.pow(2, o), p = p - x;
      }
      return (q2 ? -1 : 1) * m2 * Math.pow(2, p - o);
    };
    q0.write = function(t, e, r, o, f, p) {
      var m2, y2, M, x = p * 8 - f - 1, S = (1 << x) - 1, E2 = S >> 1, B = f === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0, q2 = o ? 0 : p - 1, L2 = o ? 1 : -1, ge = e < 0 || e === 0 && 1 / e < 0 ? 1 : 0;
      for (e = Math.abs(e), isNaN(e) || e === 1 / 0 ? (y2 = isNaN(e) ? 1 : 0, m2 = S) : (m2 = Math.floor(Math.log(e) / Math.LN2), e * (M = Math.pow(2, -m2)) < 1 && (m2--, M *= 2), m2 + E2 >= 1 ? e += B / M : e += B * Math.pow(2, 1 - E2), e * M >= 2 && (m2++, M /= 2), m2 + E2 >= S ? (y2 = 0, m2 = S) : m2 + E2 >= 1 ? (y2 = (e * M - 1) * Math.pow(2, f), m2 = m2 + E2) : (y2 = e * Math.pow(2, E2 - 1) * Math.pow(2, f), m2 = 0));f >= 8; t[r + q2] = y2 & 255, q2 += L2, y2 /= 256, f -= 8)
        ;
      for (m2 = m2 << f | y2, x += f;x > 0; t[r + q2] = m2 & 255, q2 += L2, m2 /= 256, x -= 8)
        ;
      t[r + q2 - L2] |= ge * 128;
    };
  });
  Ut = T2((Xn) => {
    var I0 = Nd(), Gn = Dd(), Pd = typeof Symbol == "function" && typeof Symbol.for == "function" ? Symbol.for("nodejs.util.inspect.custom") : null;
    Xn.Buffer = me;
    Xn.SlowBuffer = Tw;
    Xn.INSPECT_MAX_BYTES = 50;
    var eo = 2147483647;
    Xn.kMaxLength = eo;
    me.TYPED_ARRAY_SUPPORT = Aw();
    !me.TYPED_ARRAY_SUPPORT && typeof console < "u" && typeof console.error == "function" && console.error("This browser lacks typed array (Uint8Array) support which is required by `buffer` v5.x. Use `buffer` v4.x if you require old browser support.");
    function Aw() {
      try {
        let t = new Uint8Array(1), e = { foo: function() {
          return 42;
        } };
        return Object.setPrototypeOf(e, Uint8Array.prototype), Object.setPrototypeOf(t, e), t.foo() === 42;
      } catch {
        return false;
      }
    }
    Object.defineProperty(me.prototype, "parent", { enumerable: true, get: function() {
      if (!!me.isBuffer(this))
        return this.buffer;
    } });
    Object.defineProperty(me.prototype, "offset", { enumerable: true, get: function() {
      if (!!me.isBuffer(this))
        return this.byteOffset;
    } });
    function li(t) {
      if (t > eo)
        throw new RangeError('The value "' + t + '" is invalid for option "size"');
      let e = new Uint8Array(t);
      return Object.setPrototypeOf(e, me.prototype), e;
    }
    function me(t, e, r) {
      if (typeof t == "number") {
        if (typeof e == "string")
          throw new TypeError('The "string" argument must be of type string. Received type number');
        return N0(t);
      }
      return Ud(t, e, r);
    }
    me.poolSize = 8192;
    function Ud(t, e, r) {
      if (typeof t == "string")
        return Bw(t, e);
      if (ArrayBuffer.isView(t))
        return qw(t);
      if (t == null)
        throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type " + typeof t);
      if (Zr(t, ArrayBuffer) || t && Zr(t.buffer, ArrayBuffer) || typeof SharedArrayBuffer < "u" && (Zr(t, SharedArrayBuffer) || t && Zr(t.buffer, SharedArrayBuffer)))
        return k0(t, e, r);
      if (typeof t == "number")
        throw new TypeError('The "value" argument must not be of type number. Received type number');
      let o = t.valueOf && t.valueOf();
      if (o != null && o !== t)
        return me.from(o, e, r);
      let f = Iw(t);
      if (f)
        return f;
      if (typeof Symbol < "u" && Symbol.toPrimitive != null && typeof t[Symbol.toPrimitive] == "function")
        return me.from(t[Symbol.toPrimitive]("string"), e, r);
      throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type " + typeof t);
    }
    me.from = function(t, e, r) {
      return Ud(t, e, r);
    };
    Object.setPrototypeOf(me.prototype, Uint8Array.prototype);
    Object.setPrototypeOf(me, Uint8Array);
    function zd(t) {
      if (typeof t != "number")
        throw new TypeError('"size" argument must be of type number');
      if (t < 0)
        throw new RangeError('The value "' + t + '" is invalid for option "size"');
    }
    function Rw(t, e, r) {
      return zd(t), t <= 0 ? li(t) : e !== undefined ? typeof r == "string" ? li(t).fill(e, r) : li(t).fill(e) : li(t);
    }
    me.alloc = function(t, e, r) {
      return Rw(t, e, r);
    };
    function N0(t) {
      return zd(t), li(t < 0 ? 0 : D0(t) | 0);
    }
    me.allocUnsafe = function(t) {
      return N0(t);
    };
    me.allocUnsafeSlow = function(t) {
      return N0(t);
    };
    function Bw(t, e) {
      if ((typeof e != "string" || e === "") && (e = "utf8"), !me.isEncoding(e))
        throw new TypeError("Unknown encoding: " + e);
      let r = Hd(t, e) | 0, o = li(r), f = o.write(t, e);
      return f !== r && (o = o.slice(0, f)), o;
    }
    function T0(t) {
      let e = t.length < 0 ? 0 : D0(t.length) | 0, r = li(e);
      for (let o = 0;o < e; o += 1)
        r[o] = t[o] & 255;
      return r;
    }
    function qw(t) {
      if (Zr(t, Uint8Array)) {
        let e = new Uint8Array(t);
        return k0(e.buffer, e.byteOffset, e.byteLength);
      }
      return T0(t);
    }
    function k0(t, e, r) {
      if (e < 0 || t.byteLength < e)
        throw new RangeError('"offset" is outside of buffer bounds');
      if (t.byteLength < e + (r || 0))
        throw new RangeError('"length" is outside of buffer bounds');
      let o;
      return e === undefined && r === undefined ? o = new Uint8Array(t) : r === undefined ? o = new Uint8Array(t, e) : o = new Uint8Array(t, e, r), Object.setPrototypeOf(o, me.prototype), o;
    }
    function Iw(t) {
      if (me.isBuffer(t)) {
        let e = D0(t.length) | 0, r = li(e);
        return r.length === 0 || t.copy(r, 0, 0, e), r;
      }
      if (t.length !== undefined)
        return typeof t.length != "number" || C0(t.length) ? li(0) : T0(t);
      if (t.type === "Buffer" && Array.isArray(t.data))
        return T0(t.data);
    }
    function D0(t) {
      if (t >= eo)
        throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x" + eo.toString(16) + " bytes");
      return t | 0;
    }
    function Tw(t) {
      return +t != t && (t = 0), me.alloc(+t);
    }
    me.isBuffer = function(e) {
      return e != null && e._isBuffer === true && e !== me.prototype;
    };
    me.compare = function(e, r) {
      if (Zr(e, Uint8Array) && (e = me.from(e, e.offset, e.byteLength)), Zr(r, Uint8Array) && (r = me.from(r, r.offset, r.byteLength)), !me.isBuffer(e) || !me.isBuffer(r))
        throw new TypeError('The "buf1", "buf2" arguments must be one of type Buffer or Uint8Array');
      if (e === r)
        return 0;
      let o = e.length, f = r.length;
      for (let p = 0, m2 = Math.min(o, f);p < m2; ++p)
        if (e[p] !== r[p]) {
          o = e[p], f = r[p];
          break;
        }
      return o < f ? -1 : f < o ? 1 : 0;
    };
    me.isEncoding = function(e) {
      switch (String(e).toLowerCase()) {
        case "hex":
        case "utf8":
        case "utf-8":
        case "ascii":
        case "latin1":
        case "binary":
        case "base64":
        case "ucs2":
        case "ucs-2":
        case "utf16le":
        case "utf-16le":
          return true;
        default:
          return false;
      }
    };
    me.concat = function(e, r) {
      if (!Array.isArray(e))
        throw new TypeError('"list" argument must be an Array of Buffers');
      if (e.length === 0)
        return me.alloc(0);
      let o;
      if (r === undefined)
        for (r = 0, o = 0;o < e.length; ++o)
          r += e[o].length;
      let f = me.allocUnsafe(r), p = 0;
      for (o = 0;o < e.length; ++o) {
        let m2 = e[o];
        if (Zr(m2, Uint8Array))
          p + m2.length > f.length ? (me.isBuffer(m2) || (m2 = me.from(m2)), m2.copy(f, p)) : Uint8Array.prototype.set.call(f, m2, p);
        else if (me.isBuffer(m2))
          m2.copy(f, p);
        else
          throw new TypeError('"list" argument must be an Array of Buffers');
        p += m2.length;
      }
      return f;
    };
    function Hd(t, e) {
      if (me.isBuffer(t))
        return t.length;
      if (ArrayBuffer.isView(t) || Zr(t, ArrayBuffer))
        return t.byteLength;
      if (typeof t != "string")
        throw new TypeError('The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type ' + typeof t);
      let r = t.length, o = arguments.length > 2 && arguments[2] === true;
      if (!o && r === 0)
        return 0;
      let f = false;
      for (;; )
        switch (e) {
          case "ascii":
          case "latin1":
          case "binary":
            return r;
          case "utf8":
          case "utf-8":
            return L0(t).length;
          case "ucs2":
          case "ucs-2":
          case "utf16le":
          case "utf-16le":
            return r * 2;
          case "hex":
            return r >>> 1;
          case "base64":
            return Xd(t).length;
          default:
            if (f)
              return o ? -1 : L0(t).length;
            e = ("" + e).toLowerCase(), f = true;
        }
    }
    me.byteLength = Hd;
    function kw(t, e, r) {
      let o = false;
      if ((e === undefined || e < 0) && (e = 0), e > this.length || ((r === undefined || r > this.length) && (r = this.length), r <= 0) || (r >>>= 0, e >>>= 0, r <= e))
        return "";
      for (t || (t = "utf8");; )
        switch (t) {
          case "hex":
            return Hw(this, e, r);
          case "utf8":
          case "utf-8":
            return Kd(this, e, r);
          case "ascii":
            return Uw(this, e, r);
          case "latin1":
          case "binary":
            return zw(this, e, r);
          case "base64":
            return Ow(this, e, r);
          case "ucs2":
          case "ucs-2":
          case "utf16le":
          case "utf-16le":
            return Ww(this, e, r);
          default:
            if (o)
              throw new TypeError("Unknown encoding: " + t);
            t = (t + "").toLowerCase(), o = true;
        }
    }
    me.prototype._isBuffer = true;
    function fn(t, e, r) {
      let o = t[e];
      t[e] = t[r], t[r] = o;
    }
    me.prototype.swap16 = function() {
      let e = this.length;
      if (e % 2 !== 0)
        throw new RangeError("Buffer size must be a multiple of 16-bits");
      for (let r = 0;r < e; r += 2)
        fn(this, r, r + 1);
      return this;
    };
    me.prototype.swap32 = function() {
      let e = this.length;
      if (e % 4 !== 0)
        throw new RangeError("Buffer size must be a multiple of 32-bits");
      for (let r = 0;r < e; r += 4)
        fn(this, r, r + 3), fn(this, r + 1, r + 2);
      return this;
    };
    me.prototype.swap64 = function() {
      let e = this.length;
      if (e % 8 !== 0)
        throw new RangeError("Buffer size must be a multiple of 64-bits");
      for (let r = 0;r < e; r += 8)
        fn(this, r, r + 7), fn(this, r + 1, r + 6), fn(this, r + 2, r + 5), fn(this, r + 3, r + 4);
      return this;
    };
    me.prototype.toString = function() {
      let e = this.length;
      return e === 0 ? "" : arguments.length === 0 ? Kd(this, 0, e) : kw.apply(this, arguments);
    };
    me.prototype.toLocaleString = me.prototype.toString;
    me.prototype.equals = function(e) {
      if (!me.isBuffer(e))
        throw new TypeError("Argument must be a Buffer");
      return this === e ? true : me.compare(this, e) === 0;
    };
    me.prototype.inspect = function() {
      let e = "", r = Xn.INSPECT_MAX_BYTES;
      return e = this.toString("hex", 0, r).replace(/(.{2})/g, "$1 ").trim(), this.length > r && (e += " ... "), "<Buffer " + e + ">";
    };
    Pd && (me.prototype[Pd] = me.prototype.inspect);
    me.prototype.compare = function(e, r, o, f, p) {
      if (Zr(e, Uint8Array) && (e = me.from(e, e.offset, e.byteLength)), !me.isBuffer(e))
        throw new TypeError('The "target" argument must be one of type Buffer or Uint8Array. Received type ' + typeof e);
      if (r === undefined && (r = 0), o === undefined && (o = e ? e.length : 0), f === undefined && (f = 0), p === undefined && (p = this.length), r < 0 || o > e.length || f < 0 || p > this.length)
        throw new RangeError("out of range index");
      if (f >= p && r >= o)
        return 0;
      if (f >= p)
        return -1;
      if (r >= o)
        return 1;
      if (r >>>= 0, o >>>= 0, f >>>= 0, p >>>= 0, this === e)
        return 0;
      let m2 = p - f, y2 = o - r, M = Math.min(m2, y2), x = this.slice(f, p), S = e.slice(r, o);
      for (let E2 = 0;E2 < M; ++E2)
        if (x[E2] !== S[E2]) {
          m2 = x[E2], y2 = S[E2];
          break;
        }
      return m2 < y2 ? -1 : y2 < m2 ? 1 : 0;
    };
    function Wd(t, e, r, o, f) {
      if (t.length === 0)
        return -1;
      if (typeof r == "string" ? (o = r, r = 0) : r > 2147483647 ? r = 2147483647 : r < -2147483648 && (r = -2147483648), r = +r, C0(r) && (r = f ? 0 : t.length - 1), r < 0 && (r = t.length + r), r >= t.length) {
        if (f)
          return -1;
        r = t.length - 1;
      } else if (r < 0)
        if (f)
          r = 0;
        else
          return -1;
      if (typeof e == "string" && (e = me.from(e, o)), me.isBuffer(e))
        return e.length === 0 ? -1 : Cd(t, e, r, o, f);
      if (typeof e == "number")
        return e = e & 255, typeof Uint8Array.prototype.indexOf == "function" ? f ? Uint8Array.prototype.indexOf.call(t, e, r) : Uint8Array.prototype.lastIndexOf.call(t, e, r) : Cd(t, [e], r, o, f);
      throw new TypeError("val must be string, number or Buffer");
    }
    function Cd(t, e, r, o, f) {
      let p = 1, m2 = t.length, y2 = e.length;
      if (o !== undefined && (o = String(o).toLowerCase(), o === "ucs2" || o === "ucs-2" || o === "utf16le" || o === "utf-16le")) {
        if (t.length < 2 || e.length < 2)
          return -1;
        p = 2, m2 /= 2, y2 /= 2, r /= 2;
      }
      function M(S, E2) {
        return p === 1 ? S[E2] : S.readUInt16BE(E2 * p);
      }
      let x;
      if (f) {
        let S = -1;
        for (x = r;x < m2; x++)
          if (M(t, x) === M(e, S === -1 ? 0 : x - S)) {
            if (S === -1 && (S = x), x - S + 1 === y2)
              return S * p;
          } else
            S !== -1 && (x -= x - S), S = -1;
      } else
        for (r + y2 > m2 && (r = m2 - y2), x = r;x >= 0; x--) {
          let S = true;
          for (let E2 = 0;E2 < y2; E2++)
            if (M(t, x + E2) !== M(e, E2)) {
              S = false;
              break;
            }
          if (S)
            return x;
        }
      return -1;
    }
    me.prototype.includes = function(e, r, o) {
      return this.indexOf(e, r, o) !== -1;
    };
    me.prototype.indexOf = function(e, r, o) {
      return Wd(this, e, r, o, true);
    };
    me.prototype.lastIndexOf = function(e, r, o) {
      return Wd(this, e, r, o, false);
    };
    function Lw(t, e, r, o) {
      r = Number(r) || 0;
      let f = t.length - r;
      o ? (o = Number(o), o > f && (o = f)) : o = f;
      let p = e.length;
      o > p / 2 && (o = p / 2);
      let m2;
      for (m2 = 0;m2 < o; ++m2) {
        let y2 = parseInt(e.substr(m2 * 2, 2), 16);
        if (C0(y2))
          return m2;
        t[r + m2] = y2;
      }
      return m2;
    }
    function Nw(t, e, r, o) {
      return to(L0(e, t.length - r), t, r, o);
    }
    function Dw(t, e, r, o) {
      return to(Vw(e), t, r, o);
    }
    function Pw(t, e, r, o) {
      return to(Xd(e), t, r, o);
    }
    function Cw(t, e, r, o) {
      return to($w(e, t.length - r), t, r, o);
    }
    me.prototype.write = function(e, r, o, f) {
      if (r === undefined)
        f = "utf8", o = this.length, r = 0;
      else if (o === undefined && typeof r == "string")
        f = r, o = this.length, r = 0;
      else if (isFinite(r))
        r = r >>> 0, isFinite(o) ? (o = o >>> 0, f === undefined && (f = "utf8")) : (f = o, o = undefined);
      else
        throw new Error("Buffer.write(string, encoding, offset[, length]) is no longer supported");
      let p = this.length - r;
      if ((o === undefined || o > p) && (o = p), e.length > 0 && (o < 0 || r < 0) || r > this.length)
        throw new RangeError("Attempt to write outside buffer bounds");
      f || (f = "utf8");
      let m2 = false;
      for (;; )
        switch (f) {
          case "hex":
            return Lw(this, e, r, o);
          case "utf8":
          case "utf-8":
            return Nw(this, e, r, o);
          case "ascii":
          case "latin1":
          case "binary":
            return Dw(this, e, r, o);
          case "base64":
            return Pw(this, e, r, o);
          case "ucs2":
          case "ucs-2":
          case "utf16le":
          case "utf-16le":
            return Cw(this, e, r, o);
          default:
            if (m2)
              throw new TypeError("Unknown encoding: " + f);
            f = ("" + f).toLowerCase(), m2 = true;
        }
    };
    me.prototype.toJSON = function() {
      return { type: "Buffer", data: Array.prototype.slice.call(this._arr || this, 0) };
    };
    function Ow(t, e, r) {
      return e === 0 && r === t.length ? I0.fromByteArray(t) : I0.fromByteArray(t.slice(e, r));
    }
    function Kd(t, e, r) {
      r = Math.min(t.length, r);
      let o = [], f = e;
      for (;f < r; ) {
        let p = t[f], m2 = null, y2 = p > 239 ? 4 : p > 223 ? 3 : p > 191 ? 2 : 1;
        if (f + y2 <= r) {
          let M, x, S, E2;
          switch (y2) {
            case 1:
              p < 128 && (m2 = p);
              break;
            case 2:
              M = t[f + 1], (M & 192) === 128 && (E2 = (p & 31) << 6 | M & 63, E2 > 127 && (m2 = E2));
              break;
            case 3:
              M = t[f + 1], x = t[f + 2], (M & 192) === 128 && (x & 192) === 128 && (E2 = (p & 15) << 12 | (M & 63) << 6 | x & 63, E2 > 2047 && (E2 < 55296 || E2 > 57343) && (m2 = E2));
              break;
            case 4:
              M = t[f + 1], x = t[f + 2], S = t[f + 3], (M & 192) === 128 && (x & 192) === 128 && (S & 192) === 128 && (E2 = (p & 15) << 18 | (M & 63) << 12 | (x & 63) << 6 | S & 63, E2 > 65535 && E2 < 1114112 && (m2 = E2));
          }
        }
        m2 === null ? (m2 = 65533, y2 = 1) : m2 > 65535 && (m2 -= 65536, o.push(m2 >>> 10 & 1023 | 55296), m2 = 56320 | m2 & 1023), o.push(m2), f += y2;
      }
      return Fw(o);
    }
    var Od = 4096;
    function Fw(t) {
      let e = t.length;
      if (e <= Od)
        return String.fromCharCode.apply(String, t);
      let r = "", o = 0;
      for (;o < e; )
        r += String.fromCharCode.apply(String, t.slice(o, o += Od));
      return r;
    }
    function Uw(t, e, r) {
      let o = "";
      r = Math.min(t.length, r);
      for (let f = e;f < r; ++f)
        o += String.fromCharCode(t[f] & 127);
      return o;
    }
    function zw(t, e, r) {
      let o = "";
      r = Math.min(t.length, r);
      for (let f = e;f < r; ++f)
        o += String.fromCharCode(t[f]);
      return o;
    }
    function Hw(t, e, r) {
      let o = t.length;
      (!e || e < 0) && (e = 0), (!r || r < 0 || r > o) && (r = o);
      let f = "";
      for (let p = e;p < r; ++p)
        f += Gw[t[p]];
      return f;
    }
    function Ww(t, e, r) {
      let o = t.slice(e, r), f = "";
      for (let p = 0;p < o.length - 1; p += 2)
        f += String.fromCharCode(o[p] + o[p + 1] * 256);
      return f;
    }
    me.prototype.slice = function(e, r) {
      let o = this.length;
      e = ~~e, r = r === undefined ? o : ~~r, e < 0 ? (e += o, e < 0 && (e = 0)) : e > o && (e = o), r < 0 ? (r += o, r < 0 && (r = 0)) : r > o && (r = o), r < e && (r = e);
      let f = this.subarray(e, r);
      return Object.setPrototypeOf(f, me.prototype), f;
    };
    function Dt(t, e, r) {
      if (t % 1 !== 0 || t < 0)
        throw new RangeError("offset is not uint");
      if (t + e > r)
        throw new RangeError("Trying to access beyond buffer length");
    }
    me.prototype.readUintLE = me.prototype.readUIntLE = function(e, r, o) {
      e = e >>> 0, r = r >>> 0, o || Dt(e, r, this.length);
      let f = this[e], p = 1, m2 = 0;
      for (;++m2 < r && (p *= 256); )
        f += this[e + m2] * p;
      return f;
    };
    me.prototype.readUintBE = me.prototype.readUIntBE = function(e, r, o) {
      e = e >>> 0, r = r >>> 0, o || Dt(e, r, this.length);
      let f = this[e + --r], p = 1;
      for (;r > 0 && (p *= 256); )
        f += this[e + --r] * p;
      return f;
    };
    me.prototype.readUint8 = me.prototype.readUInt8 = function(e, r) {
      return e = e >>> 0, r || Dt(e, 1, this.length), this[e];
    };
    me.prototype.readUint16LE = me.prototype.readUInt16LE = function(e, r) {
      return e = e >>> 0, r || Dt(e, 2, this.length), this[e] | this[e + 1] << 8;
    };
    me.prototype.readUint16BE = me.prototype.readUInt16BE = function(e, r) {
      return e = e >>> 0, r || Dt(e, 2, this.length), this[e] << 8 | this[e + 1];
    };
    me.prototype.readUint32LE = me.prototype.readUInt32LE = function(e, r) {
      return e = e >>> 0, r || Dt(e, 4, this.length), (this[e] | this[e + 1] << 8 | this[e + 2] << 16) + this[e + 3] * 16777216;
    };
    me.prototype.readUint32BE = me.prototype.readUInt32BE = function(e, r) {
      return e = e >>> 0, r || Dt(e, 4, this.length), this[e] * 16777216 + (this[e + 1] << 16 | this[e + 2] << 8 | this[e + 3]);
    };
    me.prototype.readBigUInt64LE = Ti(function(e) {
      e = e >>> 0, Yn(e, "offset");
      let r = this[e], o = this[e + 7];
      (r === undefined || o === undefined) && Vf(e, this.length - 8);
      let f = r + this[++e] * 2 ** 8 + this[++e] * 2 ** 16 + this[++e] * 2 ** 24, p = this[++e] + this[++e] * 2 ** 8 + this[++e] * 2 ** 16 + o * 2 ** 24;
      return BigInt(f) + (BigInt(p) << BigInt(32));
    });
    me.prototype.readBigUInt64BE = Ti(function(e) {
      e = e >>> 0, Yn(e, "offset");
      let r = this[e], o = this[e + 7];
      (r === undefined || o === undefined) && Vf(e, this.length - 8);
      let f = r * 2 ** 24 + this[++e] * 2 ** 16 + this[++e] * 2 ** 8 + this[++e], p = this[++e] * 2 ** 24 + this[++e] * 2 ** 16 + this[++e] * 2 ** 8 + o;
      return (BigInt(f) << BigInt(32)) + BigInt(p);
    });
    me.prototype.readIntLE = function(e, r, o) {
      e = e >>> 0, r = r >>> 0, o || Dt(e, r, this.length);
      let f = this[e], p = 1, m2 = 0;
      for (;++m2 < r && (p *= 256); )
        f += this[e + m2] * p;
      return p *= 128, f >= p && (f -= Math.pow(2, 8 * r)), f;
    };
    me.prototype.readIntBE = function(e, r, o) {
      e = e >>> 0, r = r >>> 0, o || Dt(e, r, this.length);
      let f = r, p = 1, m2 = this[e + --f];
      for (;f > 0 && (p *= 256); )
        m2 += this[e + --f] * p;
      return p *= 128, m2 >= p && (m2 -= Math.pow(2, 8 * r)), m2;
    };
    me.prototype.readInt8 = function(e, r) {
      return e = e >>> 0, r || Dt(e, 1, this.length), this[e] & 128 ? (255 - this[e] + 1) * -1 : this[e];
    };
    me.prototype.readInt16LE = function(e, r) {
      e = e >>> 0, r || Dt(e, 2, this.length);
      let o = this[e] | this[e + 1] << 8;
      return o & 32768 ? o | 4294901760 : o;
    };
    me.prototype.readInt16BE = function(e, r) {
      e = e >>> 0, r || Dt(e, 2, this.length);
      let o = this[e + 1] | this[e] << 8;
      return o & 32768 ? o | 4294901760 : o;
    };
    me.prototype.readInt32LE = function(e, r) {
      return e = e >>> 0, r || Dt(e, 4, this.length), this[e] | this[e + 1] << 8 | this[e + 2] << 16 | this[e + 3] << 24;
    };
    me.prototype.readInt32BE = function(e, r) {
      return e = e >>> 0, r || Dt(e, 4, this.length), this[e] << 24 | this[e + 1] << 16 | this[e + 2] << 8 | this[e + 3];
    };
    me.prototype.readBigInt64LE = Ti(function(e) {
      e = e >>> 0, Yn(e, "offset");
      let r = this[e], o = this[e + 7];
      (r === undefined || o === undefined) && Vf(e, this.length - 8);
      let f = this[e + 4] + this[e + 5] * 2 ** 8 + this[e + 6] * 2 ** 16 + (o << 24);
      return (BigInt(f) << BigInt(32)) + BigInt(r + this[++e] * 2 ** 8 + this[++e] * 2 ** 16 + this[++e] * 2 ** 24);
    });
    me.prototype.readBigInt64BE = Ti(function(e) {
      e = e >>> 0, Yn(e, "offset");
      let r = this[e], o = this[e + 7];
      (r === undefined || o === undefined) && Vf(e, this.length - 8);
      let f = (r << 24) + this[++e] * 2 ** 16 + this[++e] * 2 ** 8 + this[++e];
      return (BigInt(f) << BigInt(32)) + BigInt(this[++e] * 2 ** 24 + this[++e] * 2 ** 16 + this[++e] * 2 ** 8 + o);
    });
    me.prototype.readFloatLE = function(e, r) {
      return e = e >>> 0, r || Dt(e, 4, this.length), Gn.read(this, e, true, 23, 4);
    };
    me.prototype.readFloatBE = function(e, r) {
      return e = e >>> 0, r || Dt(e, 4, this.length), Gn.read(this, e, false, 23, 4);
    };
    me.prototype.readDoubleLE = function(e, r) {
      return e = e >>> 0, r || Dt(e, 8, this.length), Gn.read(this, e, true, 52, 8);
    };
    me.prototype.readDoubleBE = function(e, r) {
      return e = e >>> 0, r || Dt(e, 8, this.length), Gn.read(this, e, false, 52, 8);
    };
    function er(t, e, r, o, f, p) {
      if (!me.isBuffer(t))
        throw new TypeError('"buffer" argument must be a Buffer instance');
      if (e > f || e < p)
        throw new RangeError('"value" argument is out of bounds');
      if (r + o > t.length)
        throw new RangeError("Index out of range");
    }
    me.prototype.writeUintLE = me.prototype.writeUIntLE = function(e, r, o, f) {
      if (e = +e, r = r >>> 0, o = o >>> 0, !f) {
        let y2 = Math.pow(2, 8 * o) - 1;
        er(this, e, r, o, y2, 0);
      }
      let p = 1, m2 = 0;
      for (this[r] = e & 255;++m2 < o && (p *= 256); )
        this[r + m2] = e / p & 255;
      return r + o;
    };
    me.prototype.writeUintBE = me.prototype.writeUIntBE = function(e, r, o, f) {
      if (e = +e, r = r >>> 0, o = o >>> 0, !f) {
        let y2 = Math.pow(2, 8 * o) - 1;
        er(this, e, r, o, y2, 0);
      }
      let p = o - 1, m2 = 1;
      for (this[r + p] = e & 255;--p >= 0 && (m2 *= 256); )
        this[r + p] = e / m2 & 255;
      return r + o;
    };
    me.prototype.writeUint8 = me.prototype.writeUInt8 = function(e, r, o) {
      return e = +e, r = r >>> 0, o || er(this, e, r, 1, 255, 0), this[r] = e & 255, r + 1;
    };
    me.prototype.writeUint16LE = me.prototype.writeUInt16LE = function(e, r, o) {
      return e = +e, r = r >>> 0, o || er(this, e, r, 2, 65535, 0), this[r] = e & 255, this[r + 1] = e >>> 8, r + 2;
    };
    me.prototype.writeUint16BE = me.prototype.writeUInt16BE = function(e, r, o) {
      return e = +e, r = r >>> 0, o || er(this, e, r, 2, 65535, 0), this[r] = e >>> 8, this[r + 1] = e & 255, r + 2;
    };
    me.prototype.writeUint32LE = me.prototype.writeUInt32LE = function(e, r, o) {
      return e = +e, r = r >>> 0, o || er(this, e, r, 4, 4294967295, 0), this[r + 3] = e >>> 24, this[r + 2] = e >>> 16, this[r + 1] = e >>> 8, this[r] = e & 255, r + 4;
    };
    me.prototype.writeUint32BE = me.prototype.writeUInt32BE = function(e, r, o) {
      return e = +e, r = r >>> 0, o || er(this, e, r, 4, 4294967295, 0), this[r] = e >>> 24, this[r + 1] = e >>> 16, this[r + 2] = e >>> 8, this[r + 3] = e & 255, r + 4;
    };
    function jd(t, e, r, o, f) {
      Yd(e, o, f, t, r, 7);
      let p = Number(e & BigInt(4294967295));
      t[r++] = p, p = p >> 8, t[r++] = p, p = p >> 8, t[r++] = p, p = p >> 8, t[r++] = p;
      let m2 = Number(e >> BigInt(32) & BigInt(4294967295));
      return t[r++] = m2, m2 = m2 >> 8, t[r++] = m2, m2 = m2 >> 8, t[r++] = m2, m2 = m2 >> 8, t[r++] = m2, r;
    }
    function Zd(t, e, r, o, f) {
      Yd(e, o, f, t, r, 7);
      let p = Number(e & BigInt(4294967295));
      t[r + 7] = p, p = p >> 8, t[r + 6] = p, p = p >> 8, t[r + 5] = p, p = p >> 8, t[r + 4] = p;
      let m2 = Number(e >> BigInt(32) & BigInt(4294967295));
      return t[r + 3] = m2, m2 = m2 >> 8, t[r + 2] = m2, m2 = m2 >> 8, t[r + 1] = m2, m2 = m2 >> 8, t[r] = m2, r + 8;
    }
    me.prototype.writeBigUInt64LE = Ti(function(e, r = 0) {
      return jd(this, e, r, BigInt(0), BigInt("0xffffffffffffffff"));
    });
    me.prototype.writeBigUInt64BE = Ti(function(e, r = 0) {
      return Zd(this, e, r, BigInt(0), BigInt("0xffffffffffffffff"));
    });
    me.prototype.writeIntLE = function(e, r, o, f) {
      if (e = +e, r = r >>> 0, !f) {
        let M = Math.pow(2, 8 * o - 1);
        er(this, e, r, o, M - 1, -M);
      }
      let p = 0, m2 = 1, y2 = 0;
      for (this[r] = e & 255;++p < o && (m2 *= 256); )
        e < 0 && y2 === 0 && this[r + p - 1] !== 0 && (y2 = 1), this[r + p] = (e / m2 >> 0) - y2 & 255;
      return r + o;
    };
    me.prototype.writeIntBE = function(e, r, o, f) {
      if (e = +e, r = r >>> 0, !f) {
        let M = Math.pow(2, 8 * o - 1);
        er(this, e, r, o, M - 1, -M);
      }
      let p = o - 1, m2 = 1, y2 = 0;
      for (this[r + p] = e & 255;--p >= 0 && (m2 *= 256); )
        e < 0 && y2 === 0 && this[r + p + 1] !== 0 && (y2 = 1), this[r + p] = (e / m2 >> 0) - y2 & 255;
      return r + o;
    };
    me.prototype.writeInt8 = function(e, r, o) {
      return e = +e, r = r >>> 0, o || er(this, e, r, 1, 127, -128), e < 0 && (e = 255 + e + 1), this[r] = e & 255, r + 1;
    };
    me.prototype.writeInt16LE = function(e, r, o) {
      return e = +e, r = r >>> 0, o || er(this, e, r, 2, 32767, -32768), this[r] = e & 255, this[r + 1] = e >>> 8, r + 2;
    };
    me.prototype.writeInt16BE = function(e, r, o) {
      return e = +e, r = r >>> 0, o || er(this, e, r, 2, 32767, -32768), this[r] = e >>> 8, this[r + 1] = e & 255, r + 2;
    };
    me.prototype.writeInt32LE = function(e, r, o) {
      return e = +e, r = r >>> 0, o || er(this, e, r, 4, 2147483647, -2147483648), this[r] = e & 255, this[r + 1] = e >>> 8, this[r + 2] = e >>> 16, this[r + 3] = e >>> 24, r + 4;
    };
    me.prototype.writeInt32BE = function(e, r, o) {
      return e = +e, r = r >>> 0, o || er(this, e, r, 4, 2147483647, -2147483648), e < 0 && (e = 4294967295 + e + 1), this[r] = e >>> 24, this[r + 1] = e >>> 16, this[r + 2] = e >>> 8, this[r + 3] = e & 255, r + 4;
    };
    me.prototype.writeBigInt64LE = Ti(function(e, r = 0) {
      return jd(this, e, r, -BigInt("0x8000000000000000"), BigInt("0x7fffffffffffffff"));
    });
    me.prototype.writeBigInt64BE = Ti(function(e, r = 0) {
      return Zd(this, e, r, -BigInt("0x8000000000000000"), BigInt("0x7fffffffffffffff"));
    });
    function Vd(t, e, r, o, f, p) {
      if (r + o > t.length)
        throw new RangeError("Index out of range");
      if (r < 0)
        throw new RangeError("Index out of range");
    }
    function $d(t, e, r, o, f) {
      return e = +e, r = r >>> 0, f || Vd(t, e, r, 4, 340282346638528860000000000000000000000, -340282346638528860000000000000000000000), Gn.write(t, e, r, o, 23, 4), r + 4;
    }
    me.prototype.writeFloatLE = function(e, r, o) {
      return $d(this, e, r, true, o);
    };
    me.prototype.writeFloatBE = function(e, r, o) {
      return $d(this, e, r, false, o);
    };
    function Gd(t, e, r, o, f) {
      return e = +e, r = r >>> 0, f || Vd(t, e, r, 8, 179769313486231570000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000, -179769313486231570000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000), Gn.write(t, e, r, o, 52, 8), r + 8;
    }
    me.prototype.writeDoubleLE = function(e, r, o) {
      return Gd(this, e, r, true, o);
    };
    me.prototype.writeDoubleBE = function(e, r, o) {
      return Gd(this, e, r, false, o);
    };
    me.prototype.copy = function(e, r, o, f) {
      if (!me.isBuffer(e))
        throw new TypeError("argument should be a Buffer");
      if (o || (o = 0), !f && f !== 0 && (f = this.length), r >= e.length && (r = e.length), r || (r = 0), f > 0 && f < o && (f = o), f === o || e.length === 0 || this.length === 0)
        return 0;
      if (r < 0)
        throw new RangeError("targetStart out of bounds");
      if (o < 0 || o >= this.length)
        throw new RangeError("Index out of range");
      if (f < 0)
        throw new RangeError("sourceEnd out of bounds");
      f > this.length && (f = this.length), e.length - r < f - o && (f = e.length - r + o);
      let p = f - o;
      return this === e && typeof Uint8Array.prototype.copyWithin == "function" ? this.copyWithin(r, o, f) : Uint8Array.prototype.set.call(e, this.subarray(o, f), r), p;
    };
    me.prototype.fill = function(e, r, o, f) {
      if (typeof e == "string") {
        if (typeof r == "string" ? (f = r, r = 0, o = this.length) : typeof o == "string" && (f = o, o = this.length), f !== undefined && typeof f != "string")
          throw new TypeError("encoding must be a string");
        if (typeof f == "string" && !me.isEncoding(f))
          throw new TypeError("Unknown encoding: " + f);
        if (e.length === 1) {
          let m2 = e.charCodeAt(0);
          (f === "utf8" && m2 < 128 || f === "latin1") && (e = m2);
        }
      } else
        typeof e == "number" ? e = e & 255 : typeof e == "boolean" && (e = Number(e));
      if (r < 0 || this.length < r || this.length < o)
        throw new RangeError("Out of range index");
      if (o <= r)
        return this;
      r = r >>> 0, o = o === undefined ? this.length : o >>> 0, e || (e = 0);
      let p;
      if (typeof e == "number")
        for (p = r;p < o; ++p)
          this[p] = e;
      else {
        let m2 = me.isBuffer(e) ? e : me.from(e, f), y2 = m2.length;
        if (y2 === 0)
          throw new TypeError('The value "' + e + '" is invalid for argument "value"');
        for (p = 0;p < o - r; ++p)
          this[p + r] = m2[p % y2];
      }
      return this;
    };
    var $n = {};
    function P0(t, e, r) {
      $n[t] = class extends r {
        constructor() {
          super(), Object.defineProperty(this, "message", { value: e.apply(this, arguments), writable: true, configurable: true }), this.name = `${this.name} [${t}]`, this.stack, delete this.name;
        }
        get code() {
          return t;
        }
        set code(f) {
          Object.defineProperty(this, "code", { configurable: true, enumerable: true, value: f, writable: true });
        }
        toString() {
          return `${this.name} [${t}]: ${this.message}`;
        }
      };
    }
    P0("ERR_BUFFER_OUT_OF_BOUNDS", function(t) {
      return t ? `${t} is outside of buffer bounds` : "Attempt to access memory outside buffer bounds";
    }, RangeError);
    P0("ERR_INVALID_ARG_TYPE", function(t, e) {
      return `The "${t}" argument must be of type number. Received type ${typeof e}`;
    }, TypeError);
    P0("ERR_OUT_OF_RANGE", function(t, e, r) {
      let o = `The value of "${t}" is out of range.`, f = r;
      return Number.isInteger(r) && Math.abs(r) > 2 ** 32 ? f = Fd(String(r)) : typeof r == "bigint" && (f = String(r), (r > BigInt(2) ** BigInt(32) || r < -(BigInt(2) ** BigInt(32))) && (f = Fd(f)), f += "n"), o += ` It must be ${e}. Received ${f}`, o;
    }, RangeError);
    function Fd(t) {
      let e = "", r = t.length, o = t[0] === "-" ? 1 : 0;
      for (;r >= o + 4; r -= 3)
        e = `_${t.slice(r - 3, r)}${e}`;
      return `${t.slice(0, r)}${e}`;
    }
    function Kw(t, e, r) {
      Yn(e, "offset"), (t[e] === undefined || t[e + r] === undefined) && Vf(e, t.length - (r + 1));
    }
    function Yd(t, e, r, o, f, p) {
      if (t > r || t < e) {
        let m2 = typeof e == "bigint" ? "n" : "", y2;
        throw p > 3 ? e === 0 || e === BigInt(0) ? y2 = `>= 0${m2} and < 2${m2} ** ${(p + 1) * 8}${m2}` : y2 = `>= -(2${m2} ** ${(p + 1) * 8 - 1}${m2}) and < 2 ** ${(p + 1) * 8 - 1}${m2}` : y2 = `>= ${e}${m2} and <= ${r}${m2}`, new $n.ERR_OUT_OF_RANGE("value", y2, t);
      }
      Kw(o, f, p);
    }
    function Yn(t, e) {
      if (typeof t != "number")
        throw new $n.ERR_INVALID_ARG_TYPE(e, "number", t);
    }
    function Vf(t, e, r) {
      throw Math.floor(t) !== t ? (Yn(t, r), new $n.ERR_OUT_OF_RANGE(r || "offset", "an integer", t)) : e < 0 ? new $n.ERR_BUFFER_OUT_OF_BOUNDS : new $n.ERR_OUT_OF_RANGE(r || "offset", `>= ${r ? 1 : 0} and <= ${e}`, t);
    }
    var jw = /[^+/0-9A-Za-z-_]/g;
    function Zw(t) {
      if (t = t.split("=")[0], t = t.trim().replace(jw, ""), t.length < 2)
        return "";
      for (;t.length % 4 !== 0; )
        t = t + "=";
      return t;
    }
    function L0(t, e) {
      e = e || 1 / 0;
      let r, o = t.length, f = null, p = [];
      for (let m2 = 0;m2 < o; ++m2) {
        if (r = t.charCodeAt(m2), r > 55295 && r < 57344) {
          if (!f) {
            if (r > 56319) {
              (e -= 3) > -1 && p.push(239, 191, 189);
              continue;
            } else if (m2 + 1 === o) {
              (e -= 3) > -1 && p.push(239, 191, 189);
              continue;
            }
            f = r;
            continue;
          }
          if (r < 56320) {
            (e -= 3) > -1 && p.push(239, 191, 189), f = r;
            continue;
          }
          r = (f - 55296 << 10 | r - 56320) + 65536;
        } else
          f && (e -= 3) > -1 && p.push(239, 191, 189);
        if (f = null, r < 128) {
          if ((e -= 1) < 0)
            break;
          p.push(r);
        } else if (r < 2048) {
          if ((e -= 2) < 0)
            break;
          p.push(r >> 6 | 192, r & 63 | 128);
        } else if (r < 65536) {
          if ((e -= 3) < 0)
            break;
          p.push(r >> 12 | 224, r >> 6 & 63 | 128, r & 63 | 128);
        } else if (r < 1114112) {
          if ((e -= 4) < 0)
            break;
          p.push(r >> 18 | 240, r >> 12 & 63 | 128, r >> 6 & 63 | 128, r & 63 | 128);
        } else
          throw new Error("Invalid code point");
      }
      return p;
    }
    function Vw(t) {
      let e = [];
      for (let r = 0;r < t.length; ++r)
        e.push(t.charCodeAt(r) & 255);
      return e;
    }
    function $w(t, e) {
      let r, o, f, p = [];
      for (let m2 = 0;m2 < t.length && !((e -= 2) < 0); ++m2)
        r = t.charCodeAt(m2), o = r >> 8, f = r % 256, p.push(f), p.push(o);
      return p;
    }
    function Xd(t) {
      return I0.toByteArray(Zw(t));
    }
    function to(t, e, r, o) {
      let f;
      for (f = 0;f < o && !(f + r >= e.length || f >= t.length); ++f)
        e[f + r] = t[f];
      return f;
    }
    function Zr(t, e) {
      return t instanceof e || t != null && t.constructor != null && t.constructor.name != null && t.constructor.name === e.name;
    }
    function C0(t) {
      return t !== t;
    }
    var Gw = function() {
      let t = "0123456789abcdef", e = new Array(256);
      for (let r = 0;r < 16; ++r) {
        let o = r * 16;
        for (let f = 0;f < 16; ++f)
          e[o + f] = t[r] + t[f];
      }
      return e;
    }();
    function Ti(t) {
      return typeof BigInt > "u" ? Yw : t;
    }
    function Yw() {
      throw new Error("BigInt not supported");
    }
  });
  Te = T2((O0, Qd) => {
    var ro = Ut(), Vr = ro.Buffer;
    function Jd(t, e) {
      for (var r in t)
        e[r] = t[r];
    }
    Vr.from && Vr.alloc && Vr.allocUnsafe && Vr.allocUnsafeSlow ? Qd.exports = ro : (Jd(ro, O0), O0.Buffer = an);
    function an(t, e, r) {
      return Vr(t, e, r);
    }
    an.prototype = Object.create(Vr.prototype);
    Jd(Vr, an);
    an.from = function(t, e, r) {
      if (typeof t == "number")
        throw new TypeError("Argument must not be a number");
      return Vr(t, e, r);
    };
    an.alloc = function(t, e, r) {
      if (typeof t != "number")
        throw new TypeError("Argument must be a number");
      var o = Vr(t);
      return e !== undefined ? typeof r == "string" ? o.fill(e, r) : o.fill(e) : o.fill(0), o;
    };
    an.allocUnsafe = function(t) {
      if (typeof t != "number")
        throw new TypeError("Argument must be a number");
      return Vr(t);
    };
    an.allocUnsafeSlow = function(t) {
      if (typeof t != "number")
        throw new TypeError("Argument must be a number");
      return ro.SlowBuffer(t);
    };
  });
  on = T2((Gq, U0) => {
    var F0 = 65536, Xw = 4294967295;
    function Jw() {
      throw new Error(`Secure random number generation is not supported by this browser.
Use Chrome, Firefox or Internet Explorer 11`);
    }
    var Qw = Te().Buffer, io = global.crypto || global.msCrypto;
    io && io.getRandomValues ? U0.exports = e6 : U0.exports = Jw;
    function e6(t, e) {
      if (t > Xw)
        throw new RangeError("requested too many random bytes");
      var r = Qw.allocUnsafe(t);
      if (t > 0)
        if (t > F0)
          for (var o = 0;o < t; o += F0)
            io.getRandomValues(r.slice(o, o + F0));
        else
          io.getRandomValues(r);
      return typeof e == "function" ? process.nextTick(function() {
        e(null, r);
      }) : r;
    }
  });
  Ie = T2((Yq, z0) => {
    typeof Object.create == "function" ? z0.exports = function(e, r) {
      r && (e.super_ = r, e.prototype = Object.create(r.prototype, { constructor: { value: e, enumerable: false, writable: true, configurable: true } }));
    } : z0.exports = function(e, r) {
      if (r) {
        e.super_ = r;
        var o = function() {
        };
        o.prototype = r.prototype, e.prototype = new o, e.prototype.constructor = e;
      }
    };
  });
  ki = T2((Xq, H0) => {
    var Jn = typeof Reflect == "object" ? Reflect : null, ec = Jn && typeof Jn.apply == "function" ? Jn.apply : function(e, r, o) {
      return Function.prototype.apply.call(e, r, o);
    }, no;
    Jn && typeof Jn.ownKeys == "function" ? no = Jn.ownKeys : Object.getOwnPropertySymbols ? no = function(e) {
      return Object.getOwnPropertyNames(e).concat(Object.getOwnPropertySymbols(e));
    } : no = function(e) {
      return Object.getOwnPropertyNames(e);
    };
    function t6(t) {
      console && console.warn && console.warn(t);
    }
    var rc = Number.isNaN || function(e) {
      return e !== e;
    };
    function Fe() {
      Fe.init.call(this);
    }
    H0.exports = Fe;
    H0.exports.once = f6;
    Fe.EventEmitter = Fe;
    Fe.prototype._events = undefined;
    Fe.prototype._eventsCount = 0;
    Fe.prototype._maxListeners = undefined;
    var tc = 10;
    function fo(t) {
      if (typeof t != "function")
        throw new TypeError('The "listener" argument must be of type Function. Received type ' + typeof t);
    }
    Object.defineProperty(Fe, "defaultMaxListeners", { enumerable: true, get: function() {
      return tc;
    }, set: function(t) {
      if (typeof t != "number" || t < 0 || rc(t))
        throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received ' + t + ".");
      tc = t;
    } });
    Fe.init = function() {
      (this._events === undefined || this._events === Object.getPrototypeOf(this)._events) && (this._events = Object.create(null), this._eventsCount = 0), this._maxListeners = this._maxListeners || undefined;
    };
    Fe.prototype.setMaxListeners = function(e) {
      if (typeof e != "number" || e < 0 || rc(e))
        throw new RangeError('The value of "n" is out of range. It must be a non-negative number. Received ' + e + ".");
      return this._maxListeners = e, this;
    };
    function ic(t) {
      return t._maxListeners === undefined ? Fe.defaultMaxListeners : t._maxListeners;
    }
    Fe.prototype.getMaxListeners = function() {
      return ic(this);
    };
    Fe.prototype.emit = function(e) {
      for (var r = [], o = 1;o < arguments.length; o++)
        r.push(arguments[o]);
      var f = e === "error", p = this._events;
      if (p !== undefined)
        f = f && p.error === undefined;
      else if (!f)
        return false;
      if (f) {
        var m2;
        if (r.length > 0 && (m2 = r[0]), m2 instanceof Error)
          throw m2;
        var y2 = new Error("Unhandled error." + (m2 ? " (" + m2.message + ")" : ""));
        throw y2.context = m2, y2;
      }
      var M = p[e];
      if (M === undefined)
        return false;
      if (typeof M == "function")
        ec(M, this, r);
      else
        for (var x = M.length, S = sc(M, x), o = 0;o < x; ++o)
          ec(S[o], this, r);
      return true;
    };
    function nc(t, e, r, o) {
      var f, p, m2;
      if (fo(r), p = t._events, p === undefined ? (p = t._events = Object.create(null), t._eventsCount = 0) : (p.newListener !== undefined && (t.emit("newListener", e, r.listener ? r.listener : r), p = t._events), m2 = p[e]), m2 === undefined)
        m2 = p[e] = r, ++t._eventsCount;
      else if (typeof m2 == "function" ? m2 = p[e] = o ? [r, m2] : [m2, r] : o ? m2.unshift(r) : m2.push(r), f = ic(t), f > 0 && m2.length > f && !m2.warned) {
        m2.warned = true;
        var y2 = new Error("Possible EventEmitter memory leak detected. " + m2.length + " " + String(e) + " listeners added. Use emitter.setMaxListeners() to increase limit");
        y2.name = "MaxListenersExceededWarning", y2.emitter = t, y2.type = e, y2.count = m2.length, t6(y2);
      }
      return t;
    }
    Fe.prototype.addListener = function(e, r) {
      return nc(this, e, r, false);
    };
    Fe.prototype.on = Fe.prototype.addListener;
    Fe.prototype.prependListener = function(e, r) {
      return nc(this, e, r, true);
    };
    function r6() {
      if (!this.fired)
        return this.target.removeListener(this.type, this.wrapFn), this.fired = true, arguments.length === 0 ? this.listener.call(this.target) : this.listener.apply(this.target, arguments);
    }
    function fc(t, e, r) {
      var o = { fired: false, wrapFn: undefined, target: t, type: e, listener: r }, f = r6.bind(o);
      return f.listener = r, o.wrapFn = f, f;
    }
    Fe.prototype.once = function(e, r) {
      return fo(r), this.on(e, fc(this, e, r)), this;
    };
    Fe.prototype.prependOnceListener = function(e, r) {
      return fo(r), this.prependListener(e, fc(this, e, r)), this;
    };
    Fe.prototype.removeListener = function(e, r) {
      var o, f, p, m2, y2;
      if (fo(r), f = this._events, f === undefined)
        return this;
      if (o = f[e], o === undefined)
        return this;
      if (o === r || o.listener === r)
        --this._eventsCount === 0 ? this._events = Object.create(null) : (delete f[e], f.removeListener && this.emit("removeListener", e, o.listener || r));
      else if (typeof o != "function") {
        for (p = -1, m2 = o.length - 1;m2 >= 0; m2--)
          if (o[m2] === r || o[m2].listener === r) {
            y2 = o[m2].listener, p = m2;
            break;
          }
        if (p < 0)
          return this;
        p === 0 ? o.shift() : i6(o, p), o.length === 1 && (f[e] = o[0]), f.removeListener !== undefined && this.emit("removeListener", e, y2 || r);
      }
      return this;
    };
    Fe.prototype.off = Fe.prototype.removeListener;
    Fe.prototype.removeAllListeners = function(e) {
      var r, o, f;
      if (o = this._events, o === undefined)
        return this;
      if (o.removeListener === undefined)
        return arguments.length === 0 ? (this._events = Object.create(null), this._eventsCount = 0) : o[e] !== undefined && (--this._eventsCount === 0 ? this._events = Object.create(null) : delete o[e]), this;
      if (arguments.length === 0) {
        var p = Object.keys(o), m2;
        for (f = 0;f < p.length; ++f)
          m2 = p[f], m2 !== "removeListener" && this.removeAllListeners(m2);
        return this.removeAllListeners("removeListener"), this._events = Object.create(null), this._eventsCount = 0, this;
      }
      if (r = o[e], typeof r == "function")
        this.removeListener(e, r);
      else if (r !== undefined)
        for (f = r.length - 1;f >= 0; f--)
          this.removeListener(e, r[f]);
      return this;
    };
    function ac(t, e, r) {
      var o = t._events;
      if (o === undefined)
        return [];
      var f = o[e];
      return f === undefined ? [] : typeof f == "function" ? r ? [f.listener || f] : [f] : r ? n6(f) : sc(f, f.length);
    }
    Fe.prototype.listeners = function(e) {
      return ac(this, e, true);
    };
    Fe.prototype.rawListeners = function(e) {
      return ac(this, e, false);
    };
    Fe.listenerCount = function(t, e) {
      return typeof t.listenerCount == "function" ? t.listenerCount(e) : oc.call(t, e);
    };
    Fe.prototype.listenerCount = oc;
    function oc(t) {
      var e = this._events;
      if (e !== undefined) {
        var r = e[t];
        if (typeof r == "function")
          return 1;
        if (r !== undefined)
          return r.length;
      }
      return 0;
    }
    Fe.prototype.eventNames = function() {
      return this._eventsCount > 0 ? no(this._events) : [];
    };
    function sc(t, e) {
      for (var r = new Array(e), o = 0;o < e; ++o)
        r[o] = t[o];
      return r;
    }
    function i6(t, e) {
      for (;e + 1 < t.length; e++)
        t[e] = t[e + 1];
      t.pop();
    }
    function n6(t) {
      for (var e = new Array(t.length), r = 0;r < e.length; ++r)
        e[r] = t[r].listener || t[r];
      return e;
    }
    function f6(t, e) {
      return new Promise(function(r, o) {
        function f(m2) {
          t.removeListener(e, p), o(m2);
        }
        function p() {
          typeof t.removeListener == "function" && t.removeListener("error", f), r([].slice.call(arguments));
        }
        hc(t, e, p, { once: true }), e !== "error" && a6(t, f, { once: true });
      });
    }
    function a6(t, e, r) {
      typeof t.on == "function" && hc(t, "error", e, r);
    }
    function hc(t, e, r, o) {
      if (typeof t.on == "function")
        o.once ? t.once(e, r) : t.on(e, r);
      else if (typeof t.addEventListener == "function")
        t.addEventListener(e, function f(p) {
          o.once && t.removeEventListener(e, f), r(p);
        });
      else
        throw new TypeError('The "emitter" argument must be of type EventEmitter. Received type ' + typeof t);
    }
  });
  W0 = T2((Jq, uc) => {
    uc.exports = ki().EventEmitter;
  });
  $f = T2(() => {
  });
  pc = T2((tI, cc) => {
    function lc(t, e) {
      var r = Object.keys(t);
      if (Object.getOwnPropertySymbols) {
        var o = Object.getOwnPropertySymbols(t);
        e && (o = o.filter(function(f) {
          return Object.getOwnPropertyDescriptor(t, f).enumerable;
        })), r.push.apply(r, o);
      }
      return r;
    }
    function o6(t) {
      for (var e = 1;e < arguments.length; e++) {
        var r = arguments[e] != null ? arguments[e] : {};
        e % 2 ? lc(Object(r), true).forEach(function(o) {
          s6(t, o, r[o]);
        }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(t, Object.getOwnPropertyDescriptors(r)) : lc(Object(r)).forEach(function(o) {
          Object.defineProperty(t, o, Object.getOwnPropertyDescriptor(r, o));
        });
      }
      return t;
    }
    function s6(t, e, r) {
      return e in t ? Object.defineProperty(t, e, { value: r, enumerable: true, configurable: true, writable: true }) : t[e] = r, t;
    }
    function h6(t, e) {
      if (!(t instanceof e))
        throw new TypeError("Cannot call a class as a function");
    }
    function dc(t, e) {
      for (var r = 0;r < e.length; r++) {
        var o = e[r];
        o.enumerable = o.enumerable || false, o.configurable = true, "value" in o && (o.writable = true), Object.defineProperty(t, o.key, o);
      }
    }
    function u6(t, e, r) {
      return e && dc(t.prototype, e), r && dc(t, r), t;
    }
    var l6 = Ut(), ao = l6.Buffer, d6 = $f(), K0 = d6.inspect, c6 = K0 && K0.custom || "inspect";
    function p6(t, e, r) {
      ao.prototype.copy.call(t, e, r);
    }
    cc.exports = function() {
      function t() {
        h6(this, t), this.head = null, this.tail = null, this.length = 0;
      }
      return u6(t, [{ key: "push", value: function(r) {
        var o = { data: r, next: null };
        this.length > 0 ? this.tail.next = o : this.head = o, this.tail = o, ++this.length;
      } }, { key: "unshift", value: function(r) {
        var o = { data: r, next: this.head };
        this.length === 0 && (this.tail = o), this.head = o, ++this.length;
      } }, { key: "shift", value: function() {
        if (this.length !== 0) {
          var r = this.head.data;
          return this.length === 1 ? this.head = this.tail = null : this.head = this.head.next, --this.length, r;
        }
      } }, { key: "clear", value: function() {
        this.head = this.tail = null, this.length = 0;
      } }, { key: "join", value: function(r) {
        if (this.length === 0)
          return "";
        for (var o = this.head, f = "" + o.data;o = o.next; )
          f += r + o.data;
        return f;
      } }, { key: "concat", value: function(r) {
        if (this.length === 0)
          return ao.alloc(0);
        for (var o = ao.allocUnsafe(r >>> 0), f = this.head, p = 0;f; )
          p6(f.data, o, p), p += f.data.length, f = f.next;
        return o;
      } }, { key: "consume", value: function(r, o) {
        var f;
        return r < this.head.data.length ? (f = this.head.data.slice(0, r), this.head.data = this.head.data.slice(r)) : r === this.head.data.length ? f = this.shift() : f = o ? this._getString(r) : this._getBuffer(r), f;
      } }, { key: "first", value: function() {
        return this.head.data;
      } }, { key: "_getString", value: function(r) {
        var o = this.head, f = 1, p = o.data;
        for (r -= p.length;o = o.next; ) {
          var m2 = o.data, y2 = r > m2.length ? m2.length : r;
          if (y2 === m2.length ? p += m2 : p += m2.slice(0, r), r -= y2, r === 0) {
            y2 === m2.length ? (++f, o.next ? this.head = o.next : this.head = this.tail = null) : (this.head = o, o.data = m2.slice(y2));
            break;
          }
          ++f;
        }
        return this.length -= f, p;
      } }, { key: "_getBuffer", value: function(r) {
        var o = ao.allocUnsafe(r), f = this.head, p = 1;
        for (f.data.copy(o), r -= f.data.length;f = f.next; ) {
          var m2 = f.data, y2 = r > m2.length ? m2.length : r;
          if (m2.copy(o, o.length - r, 0, y2), r -= y2, r === 0) {
            y2 === m2.length ? (++p, f.next ? this.head = f.next : this.head = this.tail = null) : (this.head = f, f.data = m2.slice(y2));
            break;
          }
          ++p;
        }
        return this.length -= p, o;
      } }, { key: c6, value: function(r, o) {
        return K0(this, o6({}, o, { depth: 0, customInspect: false }));
      } }]), t;
    }();
  });
  Z0 = T2((rI, bc) => {
    function v6(t, e) {
      var r = this, o = this._readableState && this._readableState.destroyed, f = this._writableState && this._writableState.destroyed;
      return o || f ? (e ? e(t) : t && (this._writableState ? this._writableState.errorEmitted || (this._writableState.errorEmitted = true, process.nextTick(j0, this, t)) : process.nextTick(j0, this, t)), this) : (this._readableState && (this._readableState.destroyed = true), this._writableState && (this._writableState.destroyed = true), this._destroy(t || null, function(p) {
        !e && p ? r._writableState ? r._writableState.errorEmitted ? process.nextTick(oo, r) : (r._writableState.errorEmitted = true, process.nextTick(vc, r, p)) : process.nextTick(vc, r, p) : e ? (process.nextTick(oo, r), e(p)) : process.nextTick(oo, r);
      }), this);
    }
    function vc(t, e) {
      j0(t, e), oo(t);
    }
    function oo(t) {
      t._writableState && !t._writableState.emitClose || t._readableState && !t._readableState.emitClose || t.emit("close");
    }
    function b6() {
      this._readableState && (this._readableState.destroyed = false, this._readableState.reading = false, this._readableState.ended = false, this._readableState.endEmitted = false), this._writableState && (this._writableState.destroyed = false, this._writableState.ended = false, this._writableState.ending = false, this._writableState.finalCalled = false, this._writableState.prefinished = false, this._writableState.finished = false, this._writableState.errorEmitted = false);
    }
    function j0(t, e) {
      t.emit("error", e);
    }
    function m6(t, e) {
      var { _readableState: r, _writableState: o } = t;
      r && r.autoDestroy || o && o.autoDestroy ? t.destroy(e) : t.emit("error", e);
    }
    bc.exports = { destroy: v6, undestroy: b6, errorOrDestroy: m6 };
  });
  sn = T2((iI, yc) => {
    function g6(t, e) {
      t.prototype = Object.create(e.prototype), t.prototype.constructor = t, t.__proto__ = e;
    }
    var gc = {};
    function dr(t, e, r) {
      r || (r = Error);
      function o(p, m2, y2) {
        return typeof e == "string" ? e : e(p, m2, y2);
      }
      var f = function(p) {
        g6(m2, p);
        function m2(y2, M, x) {
          return p.call(this, o(y2, M, x)) || this;
        }
        return m2;
      }(r);
      f.prototype.name = r.name, f.prototype.code = t, gc[t] = f;
    }
    function mc(t, e) {
      if (Array.isArray(t)) {
        var r = t.length;
        return t = t.map(function(o) {
          return String(o);
        }), r > 2 ? "one of ".concat(e, " ").concat(t.slice(0, r - 1).join(", "), ", or ") + t[r - 1] : r === 2 ? "one of ".concat(e, " ").concat(t[0], " or ").concat(t[1]) : "of ".concat(e, " ").concat(t[0]);
      } else
        return "of ".concat(e, " ").concat(String(t));
    }
    function y6(t, e, r) {
      return t.substr(!r || r < 0 ? 0 : +r, e.length) === e;
    }
    function w6(t, e, r) {
      return (r === undefined || r > t.length) && (r = t.length), t.substring(r - e.length, r) === e;
    }
    function M6(t, e, r) {
      return typeof r != "number" && (r = 0), r + e.length > t.length ? false : t.indexOf(e, r) !== -1;
    }
    dr("ERR_INVALID_OPT_VALUE", function(t, e) {
      return 'The value "' + e + '" is invalid for option "' + t + '"';
    }, TypeError);
    dr("ERR_INVALID_ARG_TYPE", function(t, e, r) {
      var o;
      typeof e == "string" && y6(e, "not ") ? (o = "must not be", e = e.replace(/^not /, "")) : o = "must be";
      var f;
      if (w6(t, " argument"))
        f = "The ".concat(t, " ").concat(o, " ").concat(mc(e, "type"));
      else {
        var p = M6(t, ".") ? "property" : "argument";
        f = 'The "'.concat(t, '" ').concat(p, " ").concat(o, " ").concat(mc(e, "type"));
      }
      return f += ". Received type ".concat(typeof r), f;
    }, TypeError);
    dr("ERR_STREAM_PUSH_AFTER_EOF", "stream.push() after EOF");
    dr("ERR_METHOD_NOT_IMPLEMENTED", function(t) {
      return "The " + t + " method is not implemented";
    });
    dr("ERR_STREAM_PREMATURE_CLOSE", "Premature close");
    dr("ERR_STREAM_DESTROYED", function(t) {
      return "Cannot call " + t + " after a stream was destroyed";
    });
    dr("ERR_MULTIPLE_CALLBACK", "Callback called multiple times");
    dr("ERR_STREAM_CANNOT_PIPE", "Cannot pipe, not readable");
    dr("ERR_STREAM_WRITE_AFTER_END", "write after end");
    dr("ERR_STREAM_NULL_VALUES", "May not write null values to stream", TypeError);
    dr("ERR_UNKNOWN_ENCODING", function(t) {
      return "Unknown encoding: " + t;
    }, TypeError);
    dr("ERR_STREAM_UNSHIFT_AFTER_END_EVENT", "stream.unshift() after end event");
    yc.exports.codes = gc;
  });
  V0 = T2((nI, wc) => {
    var _6 = sn().codes.ERR_INVALID_OPT_VALUE;
    function x6(t, e, r) {
      return t.highWaterMark != null ? t.highWaterMark : e ? t[r] : null;
    }
    function S6(t, e, r, o) {
      var f = x6(e, o, r);
      if (f != null) {
        if (!(isFinite(f) && Math.floor(f) === f) || f < 0) {
          var p = o ? r : "highWaterMark";
          throw new _6(p, f);
        }
        return Math.floor(f);
      }
      return t.objectMode ? 16 : 16 * 1024;
    }
    wc.exports = { getHighWaterMark: S6 };
  });
  G0 = T2((fI, Mc) => {
    Mc.exports = E6;
    function E6(t, e) {
      if ($0("noDeprecation"))
        return t;
      var r = false;
      function o() {
        if (!r) {
          if ($0("throwDeprecation"))
            throw new Error(e);
          $0("traceDeprecation") ? console.trace(e) : console.warn(e), r = true;
        }
        return t.apply(this, arguments);
      }
      return o;
    }
    function $0(t) {
      try {
        if (!global.localStorage)
          return false;
      } catch {
        return false;
      }
      var e = global.localStorage[t];
      return e == null ? false : String(e).toLowerCase() === "true";
    }
  });
  J0 = T2((aI, Rc) => {
    Rc.exports = ht;
    function xc(t) {
      var e = this;
      this.next = null, this.entry = null, this.finish = function() {
        J6(e, t);
      };
    }
    var Qn;
    ht.WritableState = Yf;
    var A6 = { deprecate: G0() }, Sc = W0(), ho = Ut().Buffer, R6 = global.Uint8Array || function() {
    };
    function B6(t) {
      return ho.from(t);
    }
    function q6(t) {
      return ho.isBuffer(t) || t instanceof R6;
    }
    var X0 = Z0(), I6 = V0(), T6 = I6.getHighWaterMark, Li = sn().codes, k6 = Li.ERR_INVALID_ARG_TYPE, L6 = Li.ERR_METHOD_NOT_IMPLEMENTED, N6 = Li.ERR_MULTIPLE_CALLBACK, D6 = Li.ERR_STREAM_CANNOT_PIPE, P6 = Li.ERR_STREAM_DESTROYED, C6 = Li.ERR_STREAM_NULL_VALUES, O6 = Li.ERR_STREAM_WRITE_AFTER_END, F6 = Li.ERR_UNKNOWN_ENCODING, ef = X0.errorOrDestroy;
    Ie()(ht, Sc);
    function U6() {
    }
    function Yf(t, e, r) {
      Qn = Qn || hn(), t = t || {}, typeof r != "boolean" && (r = e instanceof Qn), this.objectMode = !!t.objectMode, r && (this.objectMode = this.objectMode || !!t.writableObjectMode), this.highWaterMark = T6(this, t, "writableHighWaterMark", r), this.finalCalled = false, this.needDrain = false, this.ending = false, this.ended = false, this.finished = false, this.destroyed = false;
      var o = t.decodeStrings === false;
      this.decodeStrings = !o, this.defaultEncoding = t.defaultEncoding || "utf8", this.length = 0, this.writing = false, this.corked = 0, this.sync = true, this.bufferProcessing = false, this.onwrite = function(f) {
        V6(e, f);
      }, this.writecb = null, this.writelen = 0, this.bufferedRequest = null, this.lastBufferedRequest = null, this.pendingcb = 0, this.prefinished = false, this.errorEmitted = false, this.emitClose = t.emitClose !== false, this.autoDestroy = !!t.autoDestroy, this.bufferedRequestCount = 0, this.corkedRequestsFree = new xc(this);
    }
    Yf.prototype.getBuffer = function() {
      for (var e = this.bufferedRequest, r = [];e; )
        r.push(e), e = e.next;
      return r;
    };
    (function() {
      try {
        Object.defineProperty(Yf.prototype, "buffer", { get: A6.deprecate(function() {
          return this.getBuffer();
        }, "_writableState.buffer is deprecated. Use _writableState.getBuffer instead.", "DEP0003") });
      } catch {
      }
    })();
    var so;
    typeof Symbol == "function" && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] == "function" ? (so = Function.prototype[Symbol.hasInstance], Object.defineProperty(ht, Symbol.hasInstance, { value: function(e) {
      return so.call(this, e) ? true : this !== ht ? false : e && e._writableState instanceof Yf;
    } })) : so = function(e) {
      return e instanceof this;
    };
    function ht(t) {
      Qn = Qn || hn();
      var e = this instanceof Qn;
      if (!e && !so.call(ht, this))
        return new ht(t);
      this._writableState = new Yf(t, this, e), this.writable = true, t && (typeof t.write == "function" && (this._write = t.write), typeof t.writev == "function" && (this._writev = t.writev), typeof t.destroy == "function" && (this._destroy = t.destroy), typeof t.final == "function" && (this._final = t.final)), Sc.call(this);
    }
    ht.prototype.pipe = function() {
      ef(this, new D6);
    };
    function z6(t, e) {
      var r = new O6;
      ef(t, r), process.nextTick(e, r);
    }
    function H6(t, e, r, o) {
      var f;
      return r === null ? f = new C6 : typeof r != "string" && !e.objectMode && (f = new k6("chunk", ["string", "Buffer"], r)), f ? (ef(t, f), process.nextTick(o, f), false) : true;
    }
    ht.prototype.write = function(t, e, r) {
      var o = this._writableState, f = false, p = !o.objectMode && q6(t);
      return p && !ho.isBuffer(t) && (t = B6(t)), typeof e == "function" && (r = e, e = null), p ? e = "buffer" : e || (e = o.defaultEncoding), typeof r != "function" && (r = U6), o.ending ? z6(this, r) : (p || H6(this, o, t, r)) && (o.pendingcb++, f = K6(this, o, p, t, e, r)), f;
    };
    ht.prototype.cork = function() {
      this._writableState.corked++;
    };
    ht.prototype.uncork = function() {
      var t = this._writableState;
      t.corked && (t.corked--, !t.writing && !t.corked && !t.bufferProcessing && t.bufferedRequest && Ec(this, t));
    };
    ht.prototype.setDefaultEncoding = function(e) {
      if (typeof e == "string" && (e = e.toLowerCase()), !(["hex", "utf8", "utf-8", "ascii", "binary", "base64", "ucs2", "ucs-2", "utf16le", "utf-16le", "raw"].indexOf((e + "").toLowerCase()) > -1))
        throw new F6(e);
      return this._writableState.defaultEncoding = e, this;
    };
    Object.defineProperty(ht.prototype, "writableBuffer", { enumerable: false, get: function() {
      return this._writableState && this._writableState.getBuffer();
    } });
    function W6(t, e, r) {
      return !t.objectMode && t.decodeStrings !== false && typeof e == "string" && (e = ho.from(e, r)), e;
    }
    Object.defineProperty(ht.prototype, "writableHighWaterMark", { enumerable: false, get: function() {
      return this._writableState.highWaterMark;
    } });
    function K6(t, e, r, o, f, p) {
      if (!r) {
        var m2 = W6(e, o, f);
        o !== m2 && (r = true, f = "buffer", o = m2);
      }
      var y2 = e.objectMode ? 1 : o.length;
      e.length += y2;
      var M = e.length < e.highWaterMark;
      if (M || (e.needDrain = true), e.writing || e.corked) {
        var x = e.lastBufferedRequest;
        e.lastBufferedRequest = { chunk: o, encoding: f, isBuf: r, callback: p, next: null }, x ? x.next = e.lastBufferedRequest : e.bufferedRequest = e.lastBufferedRequest, e.bufferedRequestCount += 1;
      } else
        Y0(t, e, false, y2, o, f, p);
      return M;
    }
    function Y0(t, e, r, o, f, p, m2) {
      e.writelen = o, e.writecb = m2, e.writing = true, e.sync = true, e.destroyed ? e.onwrite(new P6("write")) : r ? t._writev(f, e.onwrite) : t._write(f, p, e.onwrite), e.sync = false;
    }
    function j6(t, e, r, o, f) {
      --e.pendingcb, r ? (process.nextTick(f, o), process.nextTick(Gf, t, e), t._writableState.errorEmitted = true, ef(t, o)) : (f(o), t._writableState.errorEmitted = true, ef(t, o), Gf(t, e));
    }
    function Z6(t) {
      t.writing = false, t.writecb = null, t.length -= t.writelen, t.writelen = 0;
    }
    function V6(t, e) {
      var r = t._writableState, o = r.sync, f = r.writecb;
      if (typeof f != "function")
        throw new N6;
      if (Z6(r), e)
        j6(t, r, o, e, f);
      else {
        var p = Ac(r) || t.destroyed;
        !p && !r.corked && !r.bufferProcessing && r.bufferedRequest && Ec(t, r), o ? process.nextTick(_c, t, r, p, f) : _c(t, r, p, f);
      }
    }
    function _c(t, e, r, o) {
      r || $6(t, e), e.pendingcb--, o(), Gf(t, e);
    }
    function $6(t, e) {
      e.length === 0 && e.needDrain && (e.needDrain = false, t.emit("drain"));
    }
    function Ec(t, e) {
      e.bufferProcessing = true;
      var r = e.bufferedRequest;
      if (t._writev && r && r.next) {
        var o = e.bufferedRequestCount, f = new Array(o), p = e.corkedRequestsFree;
        p.entry = r;
        for (var m2 = 0, y2 = true;r; )
          f[m2] = r, r.isBuf || (y2 = false), r = r.next, m2 += 1;
        f.allBuffers = y2, Y0(t, e, true, e.length, f, "", p.finish), e.pendingcb++, e.lastBufferedRequest = null, p.next ? (e.corkedRequestsFree = p.next, p.next = null) : e.corkedRequestsFree = new xc(e), e.bufferedRequestCount = 0;
      } else {
        for (;r; ) {
          var { chunk: M, encoding: x, callback: S } = r, E2 = e.objectMode ? 1 : M.length;
          if (Y0(t, e, false, E2, M, x, S), r = r.next, e.bufferedRequestCount--, e.writing)
            break;
        }
        r === null && (e.lastBufferedRequest = null);
      }
      e.bufferedRequest = r, e.bufferProcessing = false;
    }
    ht.prototype._write = function(t, e, r) {
      r(new L6("_write()"));
    };
    ht.prototype._writev = null;
    ht.prototype.end = function(t, e, r) {
      var o = this._writableState;
      return typeof t == "function" ? (r = t, t = null, e = null) : typeof e == "function" && (r = e, e = null), t != null && this.write(t, e), o.corked && (o.corked = 1, this.uncork()), o.ending || X6(this, o, r), this;
    };
    Object.defineProperty(ht.prototype, "writableLength", { enumerable: false, get: function() {
      return this._writableState.length;
    } });
    function Ac(t) {
      return t.ending && t.length === 0 && t.bufferedRequest === null && !t.finished && !t.writing;
    }
    function G6(t, e) {
      t._final(function(r) {
        e.pendingcb--, r && ef(t, r), e.prefinished = true, t.emit("prefinish"), Gf(t, e);
      });
    }
    function Y6(t, e) {
      !e.prefinished && !e.finalCalled && (typeof t._final == "function" && !e.destroyed ? (e.pendingcb++, e.finalCalled = true, process.nextTick(G6, t, e)) : (e.prefinished = true, t.emit("prefinish")));
    }
    function Gf(t, e) {
      var r = Ac(e);
      if (r && (Y6(t, e), e.pendingcb === 0 && (e.finished = true, t.emit("finish"), e.autoDestroy))) {
        var o = t._readableState;
        (!o || o.autoDestroy && o.endEmitted) && t.destroy();
      }
      return r;
    }
    function X6(t, e, r) {
      e.ending = true, Gf(t, e), r && (e.finished ? process.nextTick(r) : t.once("finish", r)), e.ended = true, t.writable = false;
    }
    function J6(t, e, r) {
      var o = t.entry;
      for (t.entry = null;o; ) {
        var f = o.callback;
        e.pendingcb--, f(r), o = o.next;
      }
      e.corkedRequestsFree.next = t;
    }
    Object.defineProperty(ht.prototype, "destroyed", { enumerable: false, get: function() {
      return this._writableState === undefined ? false : this._writableState.destroyed;
    }, set: function(e) {
      !this._writableState || (this._writableState.destroyed = e);
    } });
    ht.prototype.destroy = X0.destroy;
    ht.prototype._undestroy = X0.undestroy;
    ht.prototype._destroy = function(t, e) {
      e(t);
    };
  });
  hn = T2((oI, qc) => {
    var Q6 = Object.keys || function(t) {
      var e = [];
      for (var r in t)
        e.push(r);
      return e;
    };
    qc.exports = $r;
    var Bc = th(), eh = J0();
    Ie()($r, Bc);
    for (Q0 = Q6(eh.prototype), uo = 0;uo < Q0.length; uo++)
      lo = Q0[uo], $r.prototype[lo] || ($r.prototype[lo] = eh.prototype[lo]);
    var Q0, lo, uo;
    function $r(t) {
      if (!(this instanceof $r))
        return new $r(t);
      Bc.call(this, t), eh.call(this, t), this.allowHalfOpen = true, t && (t.readable === false && (this.readable = false), t.writable === false && (this.writable = false), t.allowHalfOpen === false && (this.allowHalfOpen = false, this.once("end", eM)));
    }
    Object.defineProperty($r.prototype, "writableHighWaterMark", { enumerable: false, get: function() {
      return this._writableState.highWaterMark;
    } });
    Object.defineProperty($r.prototype, "writableBuffer", { enumerable: false, get: function() {
      return this._writableState && this._writableState.getBuffer();
    } });
    Object.defineProperty($r.prototype, "writableLength", { enumerable: false, get: function() {
      return this._writableState.length;
    } });
    function eM() {
      this._writableState.ended || process.nextTick(tM, this);
    }
    function tM(t) {
      t.end();
    }
    Object.defineProperty($r.prototype, "destroyed", { enumerable: false, get: function() {
      return this._readableState === undefined || this._writableState === undefined ? false : this._readableState.destroyed && this._writableState.destroyed;
    }, set: function(e) {
      this._readableState === undefined || this._writableState === undefined || (this._readableState.destroyed = e, this._writableState.destroyed = e);
    } });
  });
  co = T2((Tc) => {
    var ih = Te().Buffer, Ic = ih.isEncoding || function(t) {
      switch (t = "" + t, t && t.toLowerCase()) {
        case "hex":
        case "utf8":
        case "utf-8":
        case "ascii":
        case "binary":
        case "base64":
        case "ucs2":
        case "ucs-2":
        case "utf16le":
        case "utf-16le":
        case "raw":
          return true;
        default:
          return false;
      }
    };
    function rM(t) {
      if (!t)
        return "utf8";
      for (var e;; )
        switch (t) {
          case "utf8":
          case "utf-8":
            return "utf8";
          case "ucs2":
          case "ucs-2":
          case "utf16le":
          case "utf-16le":
            return "utf16le";
          case "latin1":
          case "binary":
            return "latin1";
          case "base64":
          case "ascii":
          case "hex":
            return t;
          default:
            if (e)
              return;
            t = ("" + t).toLowerCase(), e = true;
        }
    }
    function iM(t) {
      var e = rM(t);
      if (typeof e != "string" && (ih.isEncoding === Ic || !Ic(t)))
        throw new Error("Unknown encoding: " + t);
      return e || t;
    }
    Tc.StringDecoder = Xf;
    function Xf(t) {
      this.encoding = iM(t);
      var e;
      switch (this.encoding) {
        case "utf16le":
          this.text = hM, this.end = uM, e = 4;
          break;
        case "utf8":
          this.fillLast = aM, e = 4;
          break;
        case "base64":
          this.text = lM, this.end = dM, e = 3;
          break;
        default:
          this.write = cM, this.end = pM;
          return;
      }
      this.lastNeed = 0, this.lastTotal = 0, this.lastChar = ih.allocUnsafe(e);
    }
    Xf.prototype.write = function(t) {
      if (t.length === 0)
        return "";
      var e, r;
      if (this.lastNeed) {
        if (e = this.fillLast(t), e === undefined)
          return "";
        r = this.lastNeed, this.lastNeed = 0;
      } else
        r = 0;
      return r < t.length ? e ? e + this.text(t, r) : this.text(t, r) : e || "";
    };
    Xf.prototype.end = sM;
    Xf.prototype.text = oM;
    Xf.prototype.fillLast = function(t) {
      if (this.lastNeed <= t.length)
        return t.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed), this.lastChar.toString(this.encoding, 0, this.lastTotal);
      t.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, t.length), this.lastNeed -= t.length;
    };
    function rh(t) {
      return t <= 127 ? 0 : t >> 5 === 6 ? 2 : t >> 4 === 14 ? 3 : t >> 3 === 30 ? 4 : t >> 6 === 2 ? -1 : -2;
    }
    function nM(t, e, r) {
      var o = e.length - 1;
      if (o < r)
        return 0;
      var f = rh(e[o]);
      return f >= 0 ? (f > 0 && (t.lastNeed = f - 1), f) : --o < r || f === -2 ? 0 : (f = rh(e[o]), f >= 0 ? (f > 0 && (t.lastNeed = f - 2), f) : --o < r || f === -2 ? 0 : (f = rh(e[o]), f >= 0 ? (f > 0 && (f === 2 ? f = 0 : t.lastNeed = f - 3), f) : 0));
    }
    function fM(t, e, r) {
      if ((e[0] & 192) !== 128)
        return t.lastNeed = 0, "\uFFFD";
      if (t.lastNeed > 1 && e.length > 1) {
        if ((e[1] & 192) !== 128)
          return t.lastNeed = 1, "\uFFFD";
        if (t.lastNeed > 2 && e.length > 2 && (e[2] & 192) !== 128)
          return t.lastNeed = 2, "\uFFFD";
      }
    }
    function aM(t) {
      var e = this.lastTotal - this.lastNeed, r = fM(this, t, e);
      if (r !== undefined)
        return r;
      if (this.lastNeed <= t.length)
        return t.copy(this.lastChar, e, 0, this.lastNeed), this.lastChar.toString(this.encoding, 0, this.lastTotal);
      t.copy(this.lastChar, e, 0, t.length), this.lastNeed -= t.length;
    }
    function oM(t, e) {
      var r = nM(this, t, e);
      if (!this.lastNeed)
        return t.toString("utf8", e);
      this.lastTotal = r;
      var o = t.length - (r - this.lastNeed);
      return t.copy(this.lastChar, 0, o), t.toString("utf8", e, o);
    }
    function sM(t) {
      var e = t && t.length ? this.write(t) : "";
      return this.lastNeed ? e + "\uFFFD" : e;
    }
    function hM(t, e) {
      if ((t.length - e) % 2 === 0) {
        var r = t.toString("utf16le", e);
        if (r) {
          var o = r.charCodeAt(r.length - 1);
          if (o >= 55296 && o <= 56319)
            return this.lastNeed = 2, this.lastTotal = 4, this.lastChar[0] = t[t.length - 2], this.lastChar[1] = t[t.length - 1], r.slice(0, -1);
        }
        return r;
      }
      return this.lastNeed = 1, this.lastTotal = 2, this.lastChar[0] = t[t.length - 1], t.toString("utf16le", e, t.length - 1);
    }
    function uM(t) {
      var e = t && t.length ? this.write(t) : "";
      if (this.lastNeed) {
        var r = this.lastTotal - this.lastNeed;
        return e + this.lastChar.toString("utf16le", 0, r);
      }
      return e;
    }
    function lM(t, e) {
      var r = (t.length - e) % 3;
      return r === 0 ? t.toString("base64", e) : (this.lastNeed = 3 - r, this.lastTotal = 3, r === 1 ? this.lastChar[0] = t[t.length - 1] : (this.lastChar[0] = t[t.length - 2], this.lastChar[1] = t[t.length - 1]), t.toString("base64", e, t.length - r));
    }
    function dM(t) {
      var e = t && t.length ? this.write(t) : "";
      return this.lastNeed ? e + this.lastChar.toString("base64", 0, 3 - this.lastNeed) : e;
    }
    function cM(t) {
      return t.toString(this.encoding);
    }
    function pM(t) {
      return t && t.length ? this.write(t) : "";
    }
  });
  Jf = {};
  Ja(Jf, { StringDecoder: () => po.StringDecoder, default: () => po.StringDecoder });
  Qf = R0(() => {
    po = rn(co());
  });
  vo = T2((hI, Nc) => {
    var kc = sn().codes.ERR_STREAM_PREMATURE_CLOSE;
    function vM(t) {
      var e = false;
      return function() {
        if (!e) {
          e = true;
          for (var r = arguments.length, o = new Array(r), f = 0;f < r; f++)
            o[f] = arguments[f];
          t.apply(this, o);
        }
      };
    }
    function bM() {
    }
    function mM(t) {
      return t.setHeader && typeof t.abort == "function";
    }
    function Lc(t, e, r) {
      if (typeof e == "function")
        return Lc(t, null, e);
      e || (e = {}), r = vM(r || bM);
      var o = e.readable || e.readable !== false && t.readable, f = e.writable || e.writable !== false && t.writable, p = function() {
        t.writable || y2();
      }, m2 = t._writableState && t._writableState.finished, y2 = function() {
        f = false, m2 = true, o || r.call(t);
      }, M = t._readableState && t._readableState.endEmitted, x = function() {
        o = false, M = true, f || r.call(t);
      }, S = function(L2) {
        r.call(t, L2);
      }, E2 = function() {
        var L2;
        if (o && !M)
          return (!t._readableState || !t._readableState.ended) && (L2 = new kc), r.call(t, L2);
        if (f && !m2)
          return (!t._writableState || !t._writableState.ended) && (L2 = new kc), r.call(t, L2);
      }, B = function() {
        t.req.on("finish", y2);
      };
      return mM(t) ? (t.on("complete", y2), t.on("abort", E2), t.req ? B() : t.on("request", B)) : f && !t._writableState && (t.on("end", p), t.on("close", p)), t.on("end", x), t.on("finish", y2), e.error !== false && t.on("error", S), t.on("close", E2), function() {
        t.removeListener("complete", y2), t.removeListener("abort", E2), t.removeListener("request", B), t.req && t.req.removeListener("finish", y2), t.removeListener("end", p), t.removeListener("close", p), t.removeListener("finish", y2), t.removeListener("end", x), t.removeListener("error", S), t.removeListener("close", E2);
      };
    }
    Nc.exports = Lc;
  });
  Pc = T2((uI, Dc) => {
    var bo;
    function Ni(t, e, r) {
      return e in t ? Object.defineProperty(t, e, { value: r, enumerable: true, configurable: true, writable: true }) : t[e] = r, t;
    }
    var gM = vo(), Di = Symbol("lastResolve"), un = Symbol("lastReject"), ea = Symbol("error"), mo = Symbol("ended"), ln = Symbol("lastPromise"), nh = Symbol("handlePromise"), dn = Symbol("stream");
    function Pi(t, e) {
      return { value: t, done: e };
    }
    function yM(t) {
      var e = t[Di];
      if (e !== null) {
        var r = t[dn].read();
        r !== null && (t[ln] = null, t[Di] = null, t[un] = null, e(Pi(r, false)));
      }
    }
    function wM(t) {
      process.nextTick(yM, t);
    }
    function MM(t, e) {
      return function(r, o) {
        t.then(function() {
          if (e[mo]) {
            r(Pi(undefined, true));
            return;
          }
          e[nh](r, o);
        }, o);
      };
    }
    var _M = Object.getPrototypeOf(function() {
    }), xM = Object.setPrototypeOf((bo = { get stream() {
      return this[dn];
    }, next: function() {
      var e = this, r = this[ea];
      if (r !== null)
        return Promise.reject(r);
      if (this[mo])
        return Promise.resolve(Pi(undefined, true));
      if (this[dn].destroyed)
        return new Promise(function(m2, y2) {
          process.nextTick(function() {
            e[ea] ? y2(e[ea]) : m2(Pi(undefined, true));
          });
        });
      var o = this[ln], f;
      if (o)
        f = new Promise(MM(o, this));
      else {
        var p = this[dn].read();
        if (p !== null)
          return Promise.resolve(Pi(p, false));
        f = new Promise(this[nh]);
      }
      return this[ln] = f, f;
    } }, Ni(bo, Symbol.asyncIterator, function() {
      return this;
    }), Ni(bo, "return", function() {
      var e = this;
      return new Promise(function(r, o) {
        e[dn].destroy(null, function(f) {
          if (f) {
            o(f);
            return;
          }
          r(Pi(undefined, true));
        });
      });
    }), bo), _M), SM = function(e) {
      var r, o = Object.create(xM, (r = {}, Ni(r, dn, { value: e, writable: true }), Ni(r, Di, { value: null, writable: true }), Ni(r, un, { value: null, writable: true }), Ni(r, ea, { value: null, writable: true }), Ni(r, mo, { value: e._readableState.endEmitted, writable: true }), Ni(r, nh, { value: function(p, m2) {
        var y2 = o[dn].read();
        y2 ? (o[ln] = null, o[Di] = null, o[un] = null, p(Pi(y2, false))) : (o[Di] = p, o[un] = m2);
      }, writable: true }), r));
      return o[ln] = null, gM(e, function(f) {
        if (f && f.code !== "ERR_STREAM_PREMATURE_CLOSE") {
          var p = o[un];
          p !== null && (o[ln] = null, o[Di] = null, o[un] = null, p(f)), o[ea] = f;
          return;
        }
        var m2 = o[Di];
        m2 !== null && (o[ln] = null, o[Di] = null, o[un] = null, m2(Pi(undefined, true))), o[mo] = true;
      }), e.on("readable", wM.bind(null, o)), o;
    };
    Dc.exports = SM;
  });
  Oc = T2((lI, Cc) => {
    Cc.exports = function() {
      throw new Error("Readable.from is not available in the browser");
    };
  });
  th = T2((cI, $c) => {
    $c.exports = Ce;
    var tf;
    Ce.ReadableState = Hc;
    var dI = ki().EventEmitter, zc = function(e, r) {
      return e.listeners(r).length;
    }, ra = W0(), go = Ut().Buffer, EM = global.Uint8Array || function() {
    };
    function AM(t) {
      return go.from(t);
    }
    function RM(t) {
      return go.isBuffer(t) || t instanceof EM;
    }
    var fh = $f(), Ne;
    fh && fh.debuglog ? Ne = fh.debuglog("stream") : Ne = function() {
    };
    var BM = pc(), dh = Z0(), qM = V0(), IM = qM.getHighWaterMark, yo = sn().codes, TM = yo.ERR_INVALID_ARG_TYPE, kM = yo.ERR_STREAM_PUSH_AFTER_EOF, LM = yo.ERR_METHOD_NOT_IMPLEMENTED, NM = yo.ERR_STREAM_UNSHIFT_AFTER_END_EVENT, rf, ah, oh;
    Ie()(Ce, ra);
    var ta = dh.errorOrDestroy, sh = ["error", "close", "destroy", "pause", "resume"];
    function DM(t, e, r) {
      if (typeof t.prependListener == "function")
        return t.prependListener(e, r);
      !t._events || !t._events[e] ? t.on(e, r) : Array.isArray(t._events[e]) ? t._events[e].unshift(r) : t._events[e] = [r, t._events[e]];
    }
    function Hc(t, e, r) {
      tf = tf || hn(), t = t || {}, typeof r != "boolean" && (r = e instanceof tf), this.objectMode = !!t.objectMode, r && (this.objectMode = this.objectMode || !!t.readableObjectMode), this.highWaterMark = IM(this, t, "readableHighWaterMark", r), this.buffer = new BM, this.length = 0, this.pipes = null, this.pipesCount = 0, this.flowing = null, this.ended = false, this.endEmitted = false, this.reading = false, this.sync = true, this.needReadable = false, this.emittedReadable = false, this.readableListening = false, this.resumeScheduled = false, this.paused = true, this.emitClose = t.emitClose !== false, this.autoDestroy = !!t.autoDestroy, this.destroyed = false, this.defaultEncoding = t.defaultEncoding || "utf8", this.awaitDrain = 0, this.readingMore = false, this.decoder = null, this.encoding = null, t.encoding && (rf || (rf = (Qf(), ur(Jf)).StringDecoder), this.decoder = new rf(t.encoding), this.encoding = t.encoding);
    }
    function Ce(t) {
      if (tf = tf || hn(), !(this instanceof Ce))
        return new Ce(t);
      var e = this instanceof tf;
      this._readableState = new Hc(t, this, e), this.readable = true, t && (typeof t.read == "function" && (this._read = t.read), typeof t.destroy == "function" && (this._destroy = t.destroy)), ra.call(this);
    }
    Object.defineProperty(Ce.prototype, "destroyed", { enumerable: false, get: function() {
      return this._readableState === undefined ? false : this._readableState.destroyed;
    }, set: function(e) {
      !this._readableState || (this._readableState.destroyed = e);
    } });
    Ce.prototype.destroy = dh.destroy;
    Ce.prototype._undestroy = dh.undestroy;
    Ce.prototype._destroy = function(t, e) {
      e(t);
    };
    Ce.prototype.push = function(t, e) {
      var r = this._readableState, o;
      return r.objectMode ? o = true : typeof t == "string" && (e = e || r.defaultEncoding, e !== r.encoding && (t = go.from(t, e), e = ""), o = true), Wc(this, t, e, false, o);
    };
    Ce.prototype.unshift = function(t) {
      return Wc(this, t, null, true, false);
    };
    function Wc(t, e, r, o, f) {
      Ne("readableAddChunk", e);
      var p = t._readableState;
      if (e === null)
        p.reading = false, OM(t, p);
      else {
        var m2;
        if (f || (m2 = PM(p, e)), m2)
          ta(t, m2);
        else if (p.objectMode || e && e.length > 0)
          if (typeof e != "string" && !p.objectMode && Object.getPrototypeOf(e) !== go.prototype && (e = AM(e)), o)
            p.endEmitted ? ta(t, new NM) : hh(t, p, e, true);
          else if (p.ended)
            ta(t, new kM);
          else {
            if (p.destroyed)
              return false;
            p.reading = false, p.decoder && !r ? (e = p.decoder.write(e), p.objectMode || e.length !== 0 ? hh(t, p, e, false) : lh(t, p)) : hh(t, p, e, false);
          }
        else
          o || (p.reading = false, lh(t, p));
      }
      return !p.ended && (p.length < p.highWaterMark || p.length === 0);
    }
    function hh(t, e, r, o) {
      e.flowing && e.length === 0 && !e.sync ? (e.awaitDrain = 0, t.emit("data", r)) : (e.length += e.objectMode ? 1 : r.length, o ? e.buffer.unshift(r) : e.buffer.push(r), e.needReadable && wo(t)), lh(t, e);
    }
    function PM(t, e) {
      var r;
      return !RM(e) && typeof e != "string" && e !== undefined && !t.objectMode && (r = new TM("chunk", ["string", "Buffer", "Uint8Array"], e)), r;
    }
    Ce.prototype.isPaused = function() {
      return this._readableState.flowing === false;
    };
    Ce.prototype.setEncoding = function(t) {
      rf || (rf = (Qf(), ur(Jf)).StringDecoder);
      var e = new rf(t);
      this._readableState.decoder = e, this._readableState.encoding = this._readableState.decoder.encoding;
      for (var r = this._readableState.buffer.head, o = "";r !== null; )
        o += e.write(r.data), r = r.next;
      return this._readableState.buffer.clear(), o !== "" && this._readableState.buffer.push(o), this._readableState.length = o.length, this;
    };
    var Fc = 1073741824;
    function CM(t) {
      return t >= Fc ? t = Fc : (t--, t |= t >>> 1, t |= t >>> 2, t |= t >>> 4, t |= t >>> 8, t |= t >>> 16, t++), t;
    }
    function Uc(t, e) {
      return t <= 0 || e.length === 0 && e.ended ? 0 : e.objectMode ? 1 : t !== t ? e.flowing && e.length ? e.buffer.head.data.length : e.length : (t > e.highWaterMark && (e.highWaterMark = CM(t)), t <= e.length ? t : e.ended ? e.length : (e.needReadable = true, 0));
    }
    Ce.prototype.read = function(t) {
      Ne("read", t), t = parseInt(t, 10);
      var e = this._readableState, r = t;
      if (t !== 0 && (e.emittedReadable = false), t === 0 && e.needReadable && ((e.highWaterMark !== 0 ? e.length >= e.highWaterMark : e.length > 0) || e.ended))
        return Ne("read: emitReadable", e.length, e.ended), e.length === 0 && e.ended ? uh(this) : wo(this), null;
      if (t = Uc(t, e), t === 0 && e.ended)
        return e.length === 0 && uh(this), null;
      var o = e.needReadable;
      Ne("need readable", o), (e.length === 0 || e.length - t < e.highWaterMark) && (o = true, Ne("length less than watermark", o)), e.ended || e.reading ? (o = false, Ne("reading or ended", o)) : o && (Ne("do read"), e.reading = true, e.sync = true, e.length === 0 && (e.needReadable = true), this._read(e.highWaterMark), e.sync = false, e.reading || (t = Uc(r, e)));
      var f;
      return t > 0 ? f = Zc(t, e) : f = null, f === null ? (e.needReadable = e.length <= e.highWaterMark, t = 0) : (e.length -= t, e.awaitDrain = 0), e.length === 0 && (e.ended || (e.needReadable = true), r !== t && e.ended && uh(this)), f !== null && this.emit("data", f), f;
    };
    function OM(t, e) {
      if (Ne("onEofChunk"), !e.ended) {
        if (e.decoder) {
          var r = e.decoder.end();
          r && r.length && (e.buffer.push(r), e.length += e.objectMode ? 1 : r.length);
        }
        e.ended = true, e.sync ? wo(t) : (e.needReadable = false, e.emittedReadable || (e.emittedReadable = true, Kc(t)));
      }
    }
    function wo(t) {
      var e = t._readableState;
      Ne("emitReadable", e.needReadable, e.emittedReadable), e.needReadable = false, e.emittedReadable || (Ne("emitReadable", e.flowing), e.emittedReadable = true, process.nextTick(Kc, t));
    }
    function Kc(t) {
      var e = t._readableState;
      Ne("emitReadable_", e.destroyed, e.length, e.ended), !e.destroyed && (e.length || e.ended) && (t.emit("readable"), e.emittedReadable = false), e.needReadable = !e.flowing && !e.ended && e.length <= e.highWaterMark, ch(t);
    }
    function lh(t, e) {
      e.readingMore || (e.readingMore = true, process.nextTick(FM, t, e));
    }
    function FM(t, e) {
      for (;!e.reading && !e.ended && (e.length < e.highWaterMark || e.flowing && e.length === 0); ) {
        var r = e.length;
        if (Ne("maybeReadMore read 0"), t.read(0), r === e.length)
          break;
      }
      e.readingMore = false;
    }
    Ce.prototype._read = function(t) {
      ta(this, new LM("_read()"));
    };
    Ce.prototype.pipe = function(t, e) {
      var r = this, o = this._readableState;
      switch (o.pipesCount) {
        case 0:
          o.pipes = t;
          break;
        case 1:
          o.pipes = [o.pipes, t];
          break;
        default:
          o.pipes.push(t);
          break;
      }
      o.pipesCount += 1, Ne("pipe count=%d opts=%j", o.pipesCount, e);
      var f = (!e || e.end !== false) && t !== process.stdout && t !== process.stderr, p = f ? y2 : ge;
      o.endEmitted ? process.nextTick(p) : r.once("end", p), t.on("unpipe", m2);
      function m2(_e, N) {
        Ne("onunpipe"), _e === r && N && N.hasUnpiped === false && (N.hasUnpiped = true, S());
      }
      function y2() {
        Ne("onend"), t.end();
      }
      var M = UM(r);
      t.on("drain", M);
      var x = false;
      function S() {
        Ne("cleanup"), t.removeListener("close", q2), t.removeListener("finish", L2), t.removeListener("drain", M), t.removeListener("error", B), t.removeListener("unpipe", m2), r.removeListener("end", y2), r.removeListener("end", ge), r.removeListener("data", E2), x = true, o.awaitDrain && (!t._writableState || t._writableState.needDrain) && M();
      }
      r.on("data", E2);
      function E2(_e) {
        Ne("ondata");
        var N = t.write(_e);
        Ne("dest.write", N), N === false && ((o.pipesCount === 1 && o.pipes === t || o.pipesCount > 1 && Vc(o.pipes, t) !== -1) && !x && (Ne("false write response, pause", o.awaitDrain), o.awaitDrain++), r.pause());
      }
      function B(_e) {
        Ne("onerror", _e), ge(), t.removeListener("error", B), zc(t, "error") === 0 && ta(t, _e);
      }
      DM(t, "error", B);
      function q2() {
        t.removeListener("finish", L2), ge();
      }
      t.once("close", q2);
      function L2() {
        Ne("onfinish"), t.removeListener("close", q2), ge();
      }
      t.once("finish", L2);
      function ge() {
        Ne("unpipe"), r.unpipe(t);
      }
      return t.emit("pipe", r), o.flowing || (Ne("pipe resume"), r.resume()), t;
    };
    function UM(t) {
      return function() {
        var r = t._readableState;
        Ne("pipeOnDrain", r.awaitDrain), r.awaitDrain && r.awaitDrain--, r.awaitDrain === 0 && zc(t, "data") && (r.flowing = true, ch(t));
      };
    }
    Ce.prototype.unpipe = function(t) {
      var e = this._readableState, r = { hasUnpiped: false };
      if (e.pipesCount === 0)
        return this;
      if (e.pipesCount === 1)
        return t && t !== e.pipes ? this : (t || (t = e.pipes), e.pipes = null, e.pipesCount = 0, e.flowing = false, t && t.emit("unpipe", this, r), this);
      if (!t) {
        var { pipes: o, pipesCount: f } = e;
        e.pipes = null, e.pipesCount = 0, e.flowing = false;
        for (var p = 0;p < f; p++)
          o[p].emit("unpipe", this, { hasUnpiped: false });
        return this;
      }
      var m2 = Vc(e.pipes, t);
      return m2 === -1 ? this : (e.pipes.splice(m2, 1), e.pipesCount -= 1, e.pipesCount === 1 && (e.pipes = e.pipes[0]), t.emit("unpipe", this, r), this);
    };
    Ce.prototype.on = function(t, e) {
      var r = ra.prototype.on.call(this, t, e), o = this._readableState;
      return t === "data" ? (o.readableListening = this.listenerCount("readable") > 0, o.flowing !== false && this.resume()) : t === "readable" && !o.endEmitted && !o.readableListening && (o.readableListening = o.needReadable = true, o.flowing = false, o.emittedReadable = false, Ne("on readable", o.length, o.reading), o.length ? wo(this) : o.reading || process.nextTick(zM, this)), r;
    };
    Ce.prototype.addListener = Ce.prototype.on;
    Ce.prototype.removeListener = function(t, e) {
      var r = ra.prototype.removeListener.call(this, t, e);
      return t === "readable" && process.nextTick(jc, this), r;
    };
    Ce.prototype.removeAllListeners = function(t) {
      var e = ra.prototype.removeAllListeners.apply(this, arguments);
      return (t === "readable" || t === undefined) && process.nextTick(jc, this), e;
    };
    function jc(t) {
      var e = t._readableState;
      e.readableListening = t.listenerCount("readable") > 0, e.resumeScheduled && !e.paused ? e.flowing = true : t.listenerCount("data") > 0 && t.resume();
    }
    function zM(t) {
      Ne("readable nexttick read 0"), t.read(0);
    }
    Ce.prototype.resume = function() {
      var t = this._readableState;
      return t.flowing || (Ne("resume"), t.flowing = !t.readableListening, HM(this, t)), t.paused = false, this;
    };
    function HM(t, e) {
      e.resumeScheduled || (e.resumeScheduled = true, process.nextTick(WM, t, e));
    }
    function WM(t, e) {
      Ne("resume", e.reading), e.reading || t.read(0), e.resumeScheduled = false, t.emit("resume"), ch(t), e.flowing && !e.reading && t.read(0);
    }
    Ce.prototype.pause = function() {
      return Ne("call pause flowing=%j", this._readableState.flowing), this._readableState.flowing !== false && (Ne("pause"), this._readableState.flowing = false, this.emit("pause")), this._readableState.paused = true, this;
    };
    function ch(t) {
      var e = t._readableState;
      for (Ne("flow", e.flowing);e.flowing && t.read() !== null; )
        ;
    }
    Ce.prototype.wrap = function(t) {
      var e = this, r = this._readableState, o = false;
      t.on("end", function() {
        if (Ne("wrapped end"), r.decoder && !r.ended) {
          var m2 = r.decoder.end();
          m2 && m2.length && e.push(m2);
        }
        e.push(null);
      }), t.on("data", function(m2) {
        if (Ne("wrapped data"), r.decoder && (m2 = r.decoder.write(m2)), !(r.objectMode && m2 == null) && !(!r.objectMode && (!m2 || !m2.length))) {
          var y2 = e.push(m2);
          y2 || (o = true, t.pause());
        }
      });
      for (var f in t)
        this[f] === undefined && typeof t[f] == "function" && (this[f] = function(y2) {
          return function() {
            return t[y2].apply(t, arguments);
          };
        }(f));
      for (var p = 0;p < sh.length; p++)
        t.on(sh[p], this.emit.bind(this, sh[p]));
      return this._read = function(m2) {
        Ne("wrapped _read", m2), o && (o = false, t.resume());
      }, this;
    };
    typeof Symbol == "function" && (Ce.prototype[Symbol.asyncIterator] = function() {
      return ah === undefined && (ah = Pc()), ah(this);
    });
    Object.defineProperty(Ce.prototype, "readableHighWaterMark", { enumerable: false, get: function() {
      return this._readableState.highWaterMark;
    } });
    Object.defineProperty(Ce.prototype, "readableBuffer", { enumerable: false, get: function() {
      return this._readableState && this._readableState.buffer;
    } });
    Object.defineProperty(Ce.prototype, "readableFlowing", { enumerable: false, get: function() {
      return this._readableState.flowing;
    }, set: function(e) {
      this._readableState && (this._readableState.flowing = e);
    } });
    Ce._fromList = Zc;
    Object.defineProperty(Ce.prototype, "readableLength", { enumerable: false, get: function() {
      return this._readableState.length;
    } });
    function Zc(t, e) {
      if (e.length === 0)
        return null;
      var r;
      return e.objectMode ? r = e.buffer.shift() : !t || t >= e.length ? (e.decoder ? r = e.buffer.join("") : e.buffer.length === 1 ? r = e.buffer.first() : r = e.buffer.concat(e.length), e.buffer.clear()) : r = e.buffer.consume(t, e.decoder), r;
    }
    function uh(t) {
      var e = t._readableState;
      Ne("endReadable", e.endEmitted), e.endEmitted || (e.ended = true, process.nextTick(KM, e, t));
    }
    function KM(t, e) {
      if (Ne("endReadableNT", t.endEmitted, t.length), !t.endEmitted && t.length === 0 && (t.endEmitted = true, e.readable = false, e.emit("end"), t.autoDestroy)) {
        var r = e._writableState;
        (!r || r.autoDestroy && r.finished) && e.destroy();
      }
    }
    typeof Symbol == "function" && (Ce.from = function(t, e) {
      return oh === undefined && (oh = Oc()), oh(Ce, t, e);
    });
    function Vc(t, e) {
      for (var r = 0, o = t.length;r < o; r++)
        if (t[r] === e)
          return r;
      return -1;
    }
  });
  ph = T2((pI, Yc) => {
    Yc.exports = di;
    var Mo = sn().codes, jM = Mo.ERR_METHOD_NOT_IMPLEMENTED, ZM = Mo.ERR_MULTIPLE_CALLBACK, VM = Mo.ERR_TRANSFORM_ALREADY_TRANSFORMING, $M = Mo.ERR_TRANSFORM_WITH_LENGTH_0, _o = hn();
    Ie()(di, _o);
    function GM(t, e) {
      var r = this._transformState;
      r.transforming = false;
      var o = r.writecb;
      if (o === null)
        return this.emit("error", new ZM);
      r.writechunk = null, r.writecb = null, e != null && this.push(e), o(t);
      var f = this._readableState;
      f.reading = false, (f.needReadable || f.length < f.highWaterMark) && this._read(f.highWaterMark);
    }
    function di(t) {
      if (!(this instanceof di))
        return new di(t);
      _o.call(this, t), this._transformState = { afterTransform: GM.bind(this), needTransform: false, transforming: false, writecb: null, writechunk: null, writeencoding: null }, this._readableState.needReadable = true, this._readableState.sync = false, t && (typeof t.transform == "function" && (this._transform = t.transform), typeof t.flush == "function" && (this._flush = t.flush)), this.on("prefinish", YM);
    }
    function YM() {
      var t = this;
      typeof this._flush == "function" && !this._readableState.destroyed ? this._flush(function(e, r) {
        Gc(t, e, r);
      }) : Gc(this, null, null);
    }
    di.prototype.push = function(t, e) {
      return this._transformState.needTransform = false, _o.prototype.push.call(this, t, e);
    };
    di.prototype._transform = function(t, e, r) {
      r(new jM("_transform()"));
    };
    di.prototype._write = function(t, e, r) {
      var o = this._transformState;
      if (o.writecb = r, o.writechunk = t, o.writeencoding = e, !o.transforming) {
        var f = this._readableState;
        (o.needTransform || f.needReadable || f.length < f.highWaterMark) && this._read(f.highWaterMark);
      }
    };
    di.prototype._read = function(t) {
      var e = this._transformState;
      e.writechunk !== null && !e.transforming ? (e.transforming = true, this._transform(e.writechunk, e.writeencoding, e.afterTransform)) : e.needTransform = true;
    };
    di.prototype._destroy = function(t, e) {
      _o.prototype._destroy.call(this, t, function(r) {
        e(r);
      });
    };
    function Gc(t, e, r) {
      if (e)
        return t.emit("error", e);
      if (r != null && t.push(r), t._writableState.length)
        throw new $M;
      if (t._transformState.transforming)
        throw new VM;
      return t.push(null);
    }
  });
  Qc = T2((vI, Jc) => {
    Jc.exports = ia;
    var Xc = ph();
    Ie()(ia, Xc);
    function ia(t) {
      if (!(this instanceof ia))
        return new ia(t);
      Xc.call(this, t);
    }
    ia.prototype._transform = function(t, e, r) {
      r(null, t);
    };
  });
  np = T2((bI, ip) => {
    var vh;
    function XM(t) {
      var e = false;
      return function() {
        e || (e = true, t.apply(undefined, arguments));
      };
    }
    var rp = sn().codes, JM = rp.ERR_MISSING_ARGS, QM = rp.ERR_STREAM_DESTROYED;
    function ep(t) {
      if (t)
        throw t;
    }
    function e4(t) {
      return t.setHeader && typeof t.abort == "function";
    }
    function t4(t, e, r, o) {
      o = XM(o);
      var f = false;
      t.on("close", function() {
        f = true;
      }), vh === undefined && (vh = vo()), vh(t, { readable: e, writable: r }, function(m2) {
        if (m2)
          return o(m2);
        f = true, o();
      });
      var p = false;
      return function(m2) {
        if (!f && !p) {
          if (p = true, e4(t))
            return t.abort();
          if (typeof t.destroy == "function")
            return t.destroy();
          o(m2 || new QM("pipe"));
        }
      };
    }
    function tp(t) {
      t();
    }
    function r4(t, e) {
      return t.pipe(e);
    }
    function i4(t) {
      return !t.length || typeof t[t.length - 1] != "function" ? ep : t.pop();
    }
    function n4() {
      for (var t = arguments.length, e = new Array(t), r = 0;r < t; r++)
        e[r] = arguments[r];
      var o = i4(e);
      if (Array.isArray(e[0]) && (e = e[0]), e.length < 2)
        throw new JM("streams");
      var f, p = e.map(function(m2, y2) {
        var M = y2 < e.length - 1, x = y2 > 0;
        return t4(m2, M, x, function(S) {
          f || (f = S), S && p.forEach(tp), !M && (p.forEach(tp), o(f));
        });
      });
      return e.reduce(r4);
    }
    ip.exports = n4;
  });
  ap = T2((cr, fp) => {
    cr = fp.exports = th();
    cr.Stream = cr;
    cr.Readable = cr;
    cr.Writable = J0();
    cr.Duplex = hn();
    cr.Transform = ph();
    cr.PassThrough = Qc();
    cr.finished = vo();
    cr.pipeline = np();
  });
  bh = T2((mI, sp) => {
    var xo = Te().Buffer, op = ap().Transform, f4 = Ie();
    function a4(t, e) {
      if (!xo.isBuffer(t) && typeof t != "string")
        throw new TypeError(e + " must be a string or a buffer");
    }
    function Ci(t) {
      op.call(this), this._block = xo.allocUnsafe(t), this._blockSize = t, this._blockOffset = 0, this._length = [0, 0, 0, 0], this._finalized = false;
    }
    f4(Ci, op);
    Ci.prototype._transform = function(t, e, r) {
      var o = null;
      try {
        this.update(t, e);
      } catch (f) {
        o = f;
      }
      r(o);
    };
    Ci.prototype._flush = function(t) {
      var e = null;
      try {
        this.push(this.digest());
      } catch (r) {
        e = r;
      }
      t(e);
    };
    Ci.prototype.update = function(t, e) {
      if (a4(t, "Data"), this._finalized)
        throw new Error("Digest already called");
      xo.isBuffer(t) || (t = xo.from(t, e));
      for (var r = this._block, o = 0;this._blockOffset + t.length - o >= this._blockSize; ) {
        for (var f = this._blockOffset;f < this._blockSize; )
          r[f++] = t[o++];
        this._update(), this._blockOffset = 0;
      }
      for (;o < t.length; )
        r[this._blockOffset++] = t[o++];
      for (var p = 0, m2 = t.length * 8;m2 > 0; ++p)
        this._length[p] += m2, m2 = this._length[p] / 4294967296 | 0, m2 > 0 && (this._length[p] -= 4294967296 * m2);
      return this;
    };
    Ci.prototype._update = function() {
      throw new Error("_update is not implemented");
    };
    Ci.prototype.digest = function(t) {
      if (this._finalized)
        throw new Error("Digest already called");
      this._finalized = true;
      var e = this._digest();
      t !== undefined && (e = e.toString(t)), this._block.fill(0), this._blockOffset = 0;
      for (var r = 0;r < 4; ++r)
        this._length[r] = 0;
      return e;
    };
    Ci.prototype._digest = function() {
      throw new Error("_digest is not implemented");
    };
    sp.exports = Ci;
  });
  Ao = T2((gI, up) => {
    var o4 = Ie(), hp = bh(), s4 = Te().Buffer, h4 = new Array(16);
    function So() {
      hp.call(this, 64), this._a = 1732584193, this._b = 4023233417, this._c = 2562383102, this._d = 271733878;
    }
    o4(So, hp);
    So.prototype._update = function() {
      for (var t = h4, e = 0;e < 16; ++e)
        t[e] = this._block.readInt32LE(e * 4);
      var r = this._a, o = this._b, f = this._c, p = this._d;
      r = jt(r, o, f, p, t[0], 3614090360, 7), p = jt(p, r, o, f, t[1], 3905402710, 12), f = jt(f, p, r, o, t[2], 606105819, 17), o = jt(o, f, p, r, t[3], 3250441966, 22), r = jt(r, o, f, p, t[4], 4118548399, 7), p = jt(p, r, o, f, t[5], 1200080426, 12), f = jt(f, p, r, o, t[6], 2821735955, 17), o = jt(o, f, p, r, t[7], 4249261313, 22), r = jt(r, o, f, p, t[8], 1770035416, 7), p = jt(p, r, o, f, t[9], 2336552879, 12), f = jt(f, p, r, o, t[10], 4294925233, 17), o = jt(o, f, p, r, t[11], 2304563134, 22), r = jt(r, o, f, p, t[12], 1804603682, 7), p = jt(p, r, o, f, t[13], 4254626195, 12), f = jt(f, p, r, o, t[14], 2792965006, 17), o = jt(o, f, p, r, t[15], 1236535329, 22), r = Zt(r, o, f, p, t[1], 4129170786, 5), p = Zt(p, r, o, f, t[6], 3225465664, 9), f = Zt(f, p, r, o, t[11], 643717713, 14), o = Zt(o, f, p, r, t[0], 3921069994, 20), r = Zt(r, o, f, p, t[5], 3593408605, 5), p = Zt(p, r, o, f, t[10], 38016083, 9), f = Zt(f, p, r, o, t[15], 3634488961, 14), o = Zt(o, f, p, r, t[4], 3889429448, 20), r = Zt(r, o, f, p, t[9], 568446438, 5), p = Zt(p, r, o, f, t[14], 3275163606, 9), f = Zt(f, p, r, o, t[3], 4107603335, 14), o = Zt(o, f, p, r, t[8], 1163531501, 20), r = Zt(r, o, f, p, t[13], 2850285829, 5), p = Zt(p, r, o, f, t[2], 4243563512, 9), f = Zt(f, p, r, o, t[7], 1735328473, 14), o = Zt(o, f, p, r, t[12], 2368359562, 20), r = Vt(r, o, f, p, t[5], 4294588738, 4), p = Vt(p, r, o, f, t[8], 2272392833, 11), f = Vt(f, p, r, o, t[11], 1839030562, 16), o = Vt(o, f, p, r, t[14], 4259657740, 23), r = Vt(r, o, f, p, t[1], 2763975236, 4), p = Vt(p, r, o, f, t[4], 1272893353, 11), f = Vt(f, p, r, o, t[7], 4139469664, 16), o = Vt(o, f, p, r, t[10], 3200236656, 23), r = Vt(r, o, f, p, t[13], 681279174, 4), p = Vt(p, r, o, f, t[0], 3936430074, 11), f = Vt(f, p, r, o, t[3], 3572445317, 16), o = Vt(o, f, p, r, t[6], 76029189, 23), r = Vt(r, o, f, p, t[9], 3654602809, 4), p = Vt(p, r, o, f, t[12], 3873151461, 11), f = Vt(f, p, r, o, t[15], 530742520, 16), o = Vt(o, f, p, r, t[2], 3299628645, 23), r = $t(r, o, f, p, t[0], 4096336452, 6), p = $t(p, r, o, f, t[7], 1126891415, 10), f = $t(f, p, r, o, t[14], 2878612391, 15), o = $t(o, f, p, r, t[5], 4237533241, 21), r = $t(r, o, f, p, t[12], 1700485571, 6), p = $t(p, r, o, f, t[3], 2399980690, 10), f = $t(f, p, r, o, t[10], 4293915773, 15), o = $t(o, f, p, r, t[1], 2240044497, 21), r = $t(r, o, f, p, t[8], 1873313359, 6), p = $t(p, r, o, f, t[15], 4264355552, 10), f = $t(f, p, r, o, t[6], 2734768916, 15), o = $t(o, f, p, r, t[13], 1309151649, 21), r = $t(r, o, f, p, t[4], 4149444226, 6), p = $t(p, r, o, f, t[11], 3174756917, 10), f = $t(f, p, r, o, t[2], 718787259, 15), o = $t(o, f, p, r, t[9], 3951481745, 21), this._a = this._a + r | 0, this._b = this._b + o | 0, this._c = this._c + f | 0, this._d = this._d + p | 0;
    };
    So.prototype._digest = function() {
      this._block[this._blockOffset++] = 128, this._blockOffset > 56 && (this._block.fill(0, this._blockOffset, 64), this._update(), this._blockOffset = 0), this._block.fill(0, this._blockOffset, 56), this._block.writeUInt32LE(this._length[0], 56), this._block.writeUInt32LE(this._length[1], 60), this._update();
      var t = s4.allocUnsafe(16);
      return t.writeInt32LE(this._a, 0), t.writeInt32LE(this._b, 4), t.writeInt32LE(this._c, 8), t.writeInt32LE(this._d, 12), t;
    };
    function Eo(t, e) {
      return t << e | t >>> 32 - e;
    }
    function jt(t, e, r, o, f, p, m2) {
      return Eo(t + (e & r | ~e & o) + f + p | 0, m2) + e | 0;
    }
    function Zt(t, e, r, o, f, p, m2) {
      return Eo(t + (e & o | r & ~o) + f + p | 0, m2) + e | 0;
    }
    function Vt(t, e, r, o, f, p, m2) {
      return Eo(t + (e ^ r ^ o) + f + p | 0, m2) + e | 0;
    }
    function $t(t, e, r, o, f, p, m2) {
      return Eo(t + (r ^ (e | ~o)) + f + p | 0, m2) + e | 0;
    }
    up.exports = So;
  });
  Bo = T2((yI, mp) => {
    var mh = Ut().Buffer, u4 = Ie(), bp = bh(), l4 = new Array(16), na = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8, 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12, 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2, 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13], fa = [5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12, 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2, 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13, 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14, 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11], aa = [11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8, 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12, 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5, 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12, 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6], oa = [8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6, 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11, 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5, 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8, 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11], sa = [0, 1518500249, 1859775393, 2400959708, 2840853838], ha = [1352829926, 1548603684, 1836072691, 2053994217, 0];
    function Ro() {
      bp.call(this, 64), this._a = 1732584193, this._b = 4023233417, this._c = 2562383102, this._d = 271733878, this._e = 3285377520;
    }
    u4(Ro, bp);
    Ro.prototype._update = function() {
      for (var t = l4, e = 0;e < 16; ++e)
        t[e] = this._block.readInt32LE(e * 4);
      for (var r = this._a | 0, o = this._b | 0, f = this._c | 0, p = this._d | 0, m2 = this._e | 0, y2 = this._a | 0, M = this._b | 0, x = this._c | 0, S = this._d | 0, E2 = this._e | 0, B = 0;B < 80; B += 1) {
        var q2, L2;
        B < 16 ? (q2 = lp(r, o, f, p, m2, t[na[B]], sa[0], aa[B]), L2 = vp(y2, M, x, S, E2, t[fa[B]], ha[0], oa[B])) : B < 32 ? (q2 = dp(r, o, f, p, m2, t[na[B]], sa[1], aa[B]), L2 = pp(y2, M, x, S, E2, t[fa[B]], ha[1], oa[B])) : B < 48 ? (q2 = cp(r, o, f, p, m2, t[na[B]], sa[2], aa[B]), L2 = cp(y2, M, x, S, E2, t[fa[B]], ha[2], oa[B])) : B < 64 ? (q2 = pp(r, o, f, p, m2, t[na[B]], sa[3], aa[B]), L2 = dp(y2, M, x, S, E2, t[fa[B]], ha[3], oa[B])) : (q2 = vp(r, o, f, p, m2, t[na[B]], sa[4], aa[B]), L2 = lp(y2, M, x, S, E2, t[fa[B]], ha[4], oa[B])), r = m2, m2 = p, p = cn(f, 10), f = o, o = q2, y2 = E2, E2 = S, S = cn(x, 10), x = M, M = L2;
      }
      var ge = this._b + f + S | 0;
      this._b = this._c + p + E2 | 0, this._c = this._d + m2 + y2 | 0, this._d = this._e + r + M | 0, this._e = this._a + o + x | 0, this._a = ge;
    };
    Ro.prototype._digest = function() {
      this._block[this._blockOffset++] = 128, this._blockOffset > 56 && (this._block.fill(0, this._blockOffset, 64), this._update(), this._blockOffset = 0), this._block.fill(0, this._blockOffset, 56), this._block.writeUInt32LE(this._length[0], 56), this._block.writeUInt32LE(this._length[1], 60), this._update();
      var t = mh.alloc ? mh.alloc(20) : new mh(20);
      return t.writeInt32LE(this._a, 0), t.writeInt32LE(this._b, 4), t.writeInt32LE(this._c, 8), t.writeInt32LE(this._d, 12), t.writeInt32LE(this._e, 16), t;
    };
    function cn(t, e) {
      return t << e | t >>> 32 - e;
    }
    function lp(t, e, r, o, f, p, m2, y2) {
      return cn(t + (e ^ r ^ o) + p + m2 | 0, y2) + f | 0;
    }
    function dp(t, e, r, o, f, p, m2, y2) {
      return cn(t + (e & r | ~e & o) + p + m2 | 0, y2) + f | 0;
    }
    function cp(t, e, r, o, f, p, m2, y2) {
      return cn(t + ((e | ~r) ^ o) + p + m2 | 0, y2) + f | 0;
    }
    function pp(t, e, r, o, f, p, m2, y2) {
      return cn(t + (e & o | r & ~o) + p + m2 | 0, y2) + f | 0;
    }
    function vp(t, e, r, o, f, p, m2, y2) {
      return cn(t + (e ^ (r | ~o)) + p + m2 | 0, y2) + f | 0;
    }
    mp.exports = Ro;
  });
  pn = T2((wI, yp) => {
    var gp = Te().Buffer;
    function qo(t, e) {
      this._block = gp.alloc(t), this._finalSize = e, this._blockSize = t, this._len = 0;
    }
    qo.prototype.update = function(t, e) {
      typeof t == "string" && (e = e || "utf8", t = gp.from(t, e));
      for (var r = this._block, o = this._blockSize, f = t.length, p = this._len, m2 = 0;m2 < f; ) {
        for (var y2 = p % o, M = Math.min(f - m2, o - y2), x = 0;x < M; x++)
          r[y2 + x] = t[m2 + x];
        p += M, m2 += M, p % o === 0 && this._update(r);
      }
      return this._len += f, this;
    };
    qo.prototype.digest = function(t) {
      var e = this._len % this._blockSize;
      this._block[e] = 128, this._block.fill(0, e + 1), e >= this._finalSize && (this._update(this._block), this._block.fill(0));
      var r = this._len * 8;
      if (r <= 4294967295)
        this._block.writeUInt32BE(r, this._blockSize - 4);
      else {
        var o = (r & 4294967295) >>> 0, f = (r - o) / 4294967296;
        this._block.writeUInt32BE(f, this._blockSize - 8), this._block.writeUInt32BE(o, this._blockSize - 4);
      }
      this._update(this._block);
      var p = this._hash();
      return t ? p.toString(t) : p;
    };
    qo.prototype._update = function() {
      throw new Error("_update must be implemented by subclass");
    };
    yp.exports = qo;
  });
  _p = T2((MI, Mp) => {
    var d4 = Ie(), wp = pn(), c4 = Te().Buffer, p4 = [1518500249, 1859775393, -1894007588, -899497514], v4 = new Array(80);
    function ua() {
      this.init(), this._w = v4, wp.call(this, 64, 56);
    }
    d4(ua, wp);
    ua.prototype.init = function() {
      return this._a = 1732584193, this._b = 4023233417, this._c = 2562383102, this._d = 271733878, this._e = 3285377520, this;
    };
    function b4(t) {
      return t << 5 | t >>> 27;
    }
    function m4(t) {
      return t << 30 | t >>> 2;
    }
    function g4(t, e, r, o) {
      return t === 0 ? e & r | ~e & o : t === 2 ? e & r | e & o | r & o : e ^ r ^ o;
    }
    ua.prototype._update = function(t) {
      for (var e = this._w, r = this._a | 0, o = this._b | 0, f = this._c | 0, p = this._d | 0, m2 = this._e | 0, y2 = 0;y2 < 16; ++y2)
        e[y2] = t.readInt32BE(y2 * 4);
      for (;y2 < 80; ++y2)
        e[y2] = e[y2 - 3] ^ e[y2 - 8] ^ e[y2 - 14] ^ e[y2 - 16];
      for (var M = 0;M < 80; ++M) {
        var x = ~~(M / 20), S = b4(r) + g4(x, o, f, p) + m2 + e[M] + p4[x] | 0;
        m2 = p, p = f, f = m4(o), o = r, r = S;
      }
      this._a = r + this._a | 0, this._b = o + this._b | 0, this._c = f + this._c | 0, this._d = p + this._d | 0, this._e = m2 + this._e | 0;
    };
    ua.prototype._hash = function() {
      var t = c4.allocUnsafe(20);
      return t.writeInt32BE(this._a | 0, 0), t.writeInt32BE(this._b | 0, 4), t.writeInt32BE(this._c | 0, 8), t.writeInt32BE(this._d | 0, 12), t.writeInt32BE(this._e | 0, 16), t;
    };
    Mp.exports = ua;
  });
  Ep = T2((_I, Sp) => {
    var y4 = Ie(), xp = pn(), w4 = Te().Buffer, M4 = [1518500249, 1859775393, -1894007588, -899497514], _4 = new Array(80);
    function la() {
      this.init(), this._w = _4, xp.call(this, 64, 56);
    }
    y4(la, xp);
    la.prototype.init = function() {
      return this._a = 1732584193, this._b = 4023233417, this._c = 2562383102, this._d = 271733878, this._e = 3285377520, this;
    };
    function x4(t) {
      return t << 1 | t >>> 31;
    }
    function S4(t) {
      return t << 5 | t >>> 27;
    }
    function E4(t) {
      return t << 30 | t >>> 2;
    }
    function A4(t, e, r, o) {
      return t === 0 ? e & r | ~e & o : t === 2 ? e & r | e & o | r & o : e ^ r ^ o;
    }
    la.prototype._update = function(t) {
      for (var e = this._w, r = this._a | 0, o = this._b | 0, f = this._c | 0, p = this._d | 0, m2 = this._e | 0, y2 = 0;y2 < 16; ++y2)
        e[y2] = t.readInt32BE(y2 * 4);
      for (;y2 < 80; ++y2)
        e[y2] = x4(e[y2 - 3] ^ e[y2 - 8] ^ e[y2 - 14] ^ e[y2 - 16]);
      for (var M = 0;M < 80; ++M) {
        var x = ~~(M / 20), S = S4(r) + A4(x, o, f, p) + m2 + e[M] + M4[x] | 0;
        m2 = p, p = f, f = E4(o), o = r, r = S;
      }
      this._a = r + this._a | 0, this._b = o + this._b | 0, this._c = f + this._c | 0, this._d = p + this._d | 0, this._e = m2 + this._e | 0;
    };
    la.prototype._hash = function() {
      var t = w4.allocUnsafe(20);
      return t.writeInt32BE(this._a | 0, 0), t.writeInt32BE(this._b | 0, 4), t.writeInt32BE(this._c | 0, 8), t.writeInt32BE(this._d | 0, 12), t.writeInt32BE(this._e | 0, 16), t;
    };
    Sp.exports = la;
  });
  gh = T2((xI, Rp) => {
    var R4 = Ie(), Ap = pn(), B4 = Te().Buffer, q4 = [1116352408, 1899447441, 3049323471, 3921009573, 961987163, 1508970993, 2453635748, 2870763221, 3624381080, 310598401, 607225278, 1426881987, 1925078388, 2162078206, 2614888103, 3248222580, 3835390401, 4022224774, 264347078, 604807628, 770255983, 1249150122, 1555081692, 1996064986, 2554220882, 2821834349, 2952996808, 3210313671, 3336571891, 3584528711, 113926993, 338241895, 666307205, 773529912, 1294757372, 1396182291, 1695183700, 1986661051, 2177026350, 2456956037, 2730485921, 2820302411, 3259730800, 3345764771, 3516065817, 3600352804, 4094571909, 275423344, 430227734, 506948616, 659060556, 883997877, 958139571, 1322822218, 1537002063, 1747873779, 1955562222, 2024104815, 2227730452, 2361852424, 2428436474, 2756734187, 3204031479, 3329325298], I4 = new Array(64);
    function da() {
      this.init(), this._w = I4, Ap.call(this, 64, 56);
    }
    R4(da, Ap);
    da.prototype.init = function() {
      return this._a = 1779033703, this._b = 3144134277, this._c = 1013904242, this._d = 2773480762, this._e = 1359893119, this._f = 2600822924, this._g = 528734635, this._h = 1541459225, this;
    };
    function T4(t, e, r) {
      return r ^ t & (e ^ r);
    }
    function k4(t, e, r) {
      return t & e | r & (t | e);
    }
    function L4(t) {
      return (t >>> 2 | t << 30) ^ (t >>> 13 | t << 19) ^ (t >>> 22 | t << 10);
    }
    function N4(t) {
      return (t >>> 6 | t << 26) ^ (t >>> 11 | t << 21) ^ (t >>> 25 | t << 7);
    }
    function D4(t) {
      return (t >>> 7 | t << 25) ^ (t >>> 18 | t << 14) ^ t >>> 3;
    }
    function P4(t) {
      return (t >>> 17 | t << 15) ^ (t >>> 19 | t << 13) ^ t >>> 10;
    }
    da.prototype._update = function(t) {
      for (var e = this._w, r = this._a | 0, o = this._b | 0, f = this._c | 0, p = this._d | 0, m2 = this._e | 0, y2 = this._f | 0, M = this._g | 0, x = this._h | 0, S = 0;S < 16; ++S)
        e[S] = t.readInt32BE(S * 4);
      for (;S < 64; ++S)
        e[S] = P4(e[S - 2]) + e[S - 7] + D4(e[S - 15]) + e[S - 16] | 0;
      for (var E2 = 0;E2 < 64; ++E2) {
        var B = x + N4(m2) + T4(m2, y2, M) + q4[E2] + e[E2] | 0, q2 = L4(r) + k4(r, o, f) | 0;
        x = M, M = y2, y2 = m2, m2 = p + B | 0, p = f, f = o, o = r, r = B + q2 | 0;
      }
      this._a = r + this._a | 0, this._b = o + this._b | 0, this._c = f + this._c | 0, this._d = p + this._d | 0, this._e = m2 + this._e | 0, this._f = y2 + this._f | 0, this._g = M + this._g | 0, this._h = x + this._h | 0;
    };
    da.prototype._hash = function() {
      var t = B4.allocUnsafe(32);
      return t.writeInt32BE(this._a, 0), t.writeInt32BE(this._b, 4), t.writeInt32BE(this._c, 8), t.writeInt32BE(this._d, 12), t.writeInt32BE(this._e, 16), t.writeInt32BE(this._f, 20), t.writeInt32BE(this._g, 24), t.writeInt32BE(this._h, 28), t;
    };
    Rp.exports = da;
  });
  qp = T2((SI, Bp) => {
    var C4 = Ie(), O4 = gh(), F4 = pn(), U4 = Te().Buffer, z4 = new Array(64);
    function Io() {
      this.init(), this._w = z4, F4.call(this, 64, 56);
    }
    C4(Io, O4);
    Io.prototype.init = function() {
      return this._a = 3238371032, this._b = 914150663, this._c = 812702999, this._d = 4144912697, this._e = 4290775857, this._f = 1750603025, this._g = 1694076839, this._h = 3204075428, this;
    };
    Io.prototype._hash = function() {
      var t = U4.allocUnsafe(28);
      return t.writeInt32BE(this._a, 0), t.writeInt32BE(this._b, 4), t.writeInt32BE(this._c, 8), t.writeInt32BE(this._d, 12), t.writeInt32BE(this._e, 16), t.writeInt32BE(this._f, 20), t.writeInt32BE(this._g, 24), t;
    };
    Bp.exports = Io;
  });
  yh = T2((EI, Pp) => {
    var H4 = Ie(), Dp = pn(), W4 = Te().Buffer, Ip = [1116352408, 3609767458, 1899447441, 602891725, 3049323471, 3964484399, 3921009573, 2173295548, 961987163, 4081628472, 1508970993, 3053834265, 2453635748, 2937671579, 2870763221, 3664609560, 3624381080, 2734883394, 310598401, 1164996542, 607225278, 1323610764, 1426881987, 3590304994, 1925078388, 4068182383, 2162078206, 991336113, 2614888103, 633803317, 3248222580, 3479774868, 3835390401, 2666613458, 4022224774, 944711139, 264347078, 2341262773, 604807628, 2007800933, 770255983, 1495990901, 1249150122, 1856431235, 1555081692, 3175218132, 1996064986, 2198950837, 2554220882, 3999719339, 2821834349, 766784016, 2952996808, 2566594879, 3210313671, 3203337956, 3336571891, 1034457026, 3584528711, 2466948901, 113926993, 3758326383, 338241895, 168717936, 666307205, 1188179964, 773529912, 1546045734, 1294757372, 1522805485, 1396182291, 2643833823, 1695183700, 2343527390, 1986661051, 1014477480, 2177026350, 1206759142, 2456956037, 344077627, 2730485921, 1290863460, 2820302411, 3158454273, 3259730800, 3505952657, 3345764771, 106217008, 3516065817, 3606008344, 3600352804, 1432725776, 4094571909, 1467031594, 275423344, 851169720, 430227734, 3100823752, 506948616, 1363258195, 659060556, 3750685593, 883997877, 3785050280, 958139571, 3318307427, 1322822218, 3812723403, 1537002063, 2003034995, 1747873779, 3602036899, 1955562222, 1575990012, 2024104815, 1125592928, 2227730452, 2716904306, 2361852424, 442776044, 2428436474, 593698344, 2756734187, 3733110249, 3204031479, 2999351573, 3329325298, 3815920427, 3391569614, 3928383900, 3515267271, 566280711, 3940187606, 3454069534, 4118630271, 4000239992, 116418474, 1914138554, 174292421, 2731055270, 289380356, 3203993006, 460393269, 320620315, 685471733, 587496836, 852142971, 1086792851, 1017036298, 365543100, 1126000580, 2618297676, 1288033470, 3409855158, 1501505948, 4234509866, 1607167915, 987167468, 1816402316, 1246189591], K4 = new Array(160);
    function ca() {
      this.init(), this._w = K4, Dp.call(this, 128, 112);
    }
    H4(ca, Dp);
    ca.prototype.init = function() {
      return this._ah = 1779033703, this._bh = 3144134277, this._ch = 1013904242, this._dh = 2773480762, this._eh = 1359893119, this._fh = 2600822924, this._gh = 528734635, this._hh = 1541459225, this._al = 4089235720, this._bl = 2227873595, this._cl = 4271175723, this._dl = 1595750129, this._el = 2917565137, this._fl = 725511199, this._gl = 4215389547, this._hl = 327033209, this;
    };
    function Tp(t, e, r) {
      return r ^ t & (e ^ r);
    }
    function kp(t, e, r) {
      return t & e | r & (t | e);
    }
    function Lp(t, e) {
      return (t >>> 28 | e << 4) ^ (e >>> 2 | t << 30) ^ (e >>> 7 | t << 25);
    }
    function Np(t, e) {
      return (t >>> 14 | e << 18) ^ (t >>> 18 | e << 14) ^ (e >>> 9 | t << 23);
    }
    function j4(t, e) {
      return (t >>> 1 | e << 31) ^ (t >>> 8 | e << 24) ^ t >>> 7;
    }
    function Z4(t, e) {
      return (t >>> 1 | e << 31) ^ (t >>> 8 | e << 24) ^ (t >>> 7 | e << 25);
    }
    function V4(t, e) {
      return (t >>> 19 | e << 13) ^ (e >>> 29 | t << 3) ^ t >>> 6;
    }
    function $4(t, e) {
      return (t >>> 19 | e << 13) ^ (e >>> 29 | t << 3) ^ (t >>> 6 | e << 26);
    }
    function Pt(t, e) {
      return t >>> 0 < e >>> 0 ? 1 : 0;
    }
    ca.prototype._update = function(t) {
      for (var e = this._w, r = this._ah | 0, o = this._bh | 0, f = this._ch | 0, p = this._dh | 0, m2 = this._eh | 0, y2 = this._fh | 0, M = this._gh | 0, x = this._hh | 0, S = this._al | 0, E2 = this._bl | 0, B = this._cl | 0, q2 = this._dl | 0, L2 = this._el | 0, ge = this._fl | 0, _e = this._gl | 0, N = this._hl | 0, we = 0;we < 32; we += 2)
        e[we] = t.readInt32BE(we * 4), e[we + 1] = t.readInt32BE(we * 4 + 4);
      for (;we < 160; we += 2) {
        var ye = e[we - 30], xe = e[we - 15 * 2 + 1], Re = j4(ye, xe), Ee = Z4(xe, ye);
        ye = e[we - 2 * 2], xe = e[we - 2 * 2 + 1];
        var Ae = V4(ye, xe), P = $4(xe, ye), Se = e[we - 7 * 2], v = e[we - 7 * 2 + 1], i = e[we - 16 * 2], a = e[we - 16 * 2 + 1], h2 = Ee + v | 0, s = Re + Se + Pt(h2, Ee) | 0;
        h2 = h2 + P | 0, s = s + Ae + Pt(h2, P) | 0, h2 = h2 + a | 0, s = s + i + Pt(h2, a) | 0, e[we] = s, e[we + 1] = h2;
      }
      for (var u = 0;u < 160; u += 2) {
        s = e[u], h2 = e[u + 1];
        var c = kp(r, o, f), b2 = kp(S, E2, B), l = Lp(r, S), n = Lp(S, r), d = Np(m2, L2), w = Np(L2, m2), g = Ip[u], _2 = Ip[u + 1], A2 = Tp(m2, y2, M), R2 = Tp(L2, ge, _e), I = N + w | 0, Me = x + d + Pt(I, N) | 0;
        I = I + R2 | 0, Me = Me + A2 + Pt(I, R2) | 0, I = I + _2 | 0, Me = Me + g + Pt(I, _2) | 0, I = I + h2 | 0, Me = Me + s + Pt(I, h2) | 0;
        var k = n + b2 | 0, D2 = l + c + Pt(k, n) | 0;
        x = M, N = _e, M = y2, _e = ge, y2 = m2, ge = L2, L2 = q2 + I | 0, m2 = p + Me + Pt(L2, q2) | 0, p = f, q2 = B, f = o, B = E2, o = r, E2 = S, S = I + k | 0, r = Me + D2 + Pt(S, I) | 0;
      }
      this._al = this._al + S | 0, this._bl = this._bl + E2 | 0, this._cl = this._cl + B | 0, this._dl = this._dl + q2 | 0, this._el = this._el + L2 | 0, this._fl = this._fl + ge | 0, this._gl = this._gl + _e | 0, this._hl = this._hl + N | 0, this._ah = this._ah + r + Pt(this._al, S) | 0, this._bh = this._bh + o + Pt(this._bl, E2) | 0, this._ch = this._ch + f + Pt(this._cl, B) | 0, this._dh = this._dh + p + Pt(this._dl, q2) | 0, this._eh = this._eh + m2 + Pt(this._el, L2) | 0, this._fh = this._fh + y2 + Pt(this._fl, ge) | 0, this._gh = this._gh + M + Pt(this._gl, _e) | 0, this._hh = this._hh + x + Pt(this._hl, N) | 0;
    };
    ca.prototype._hash = function() {
      var t = W4.allocUnsafe(64);
      function e(r, o, f) {
        t.writeInt32BE(r, f), t.writeInt32BE(o, f + 4);
      }
      return e(this._ah, this._al, 0), e(this._bh, this._bl, 8), e(this._ch, this._cl, 16), e(this._dh, this._dl, 24), e(this._eh, this._el, 32), e(this._fh, this._fl, 40), e(this._gh, this._gl, 48), e(this._hh, this._hl, 56), t;
    };
    Pp.exports = ca;
  });
  Op = T2((AI, Cp) => {
    var G4 = Ie(), Y4 = yh(), X4 = pn(), J4 = Te().Buffer, Q4 = new Array(160);
    function To() {
      this.init(), this._w = Q4, X4.call(this, 128, 112);
    }
    G4(To, Y4);
    To.prototype.init = function() {
      return this._ah = 3418070365, this._bh = 1654270250, this._ch = 2438529370, this._dh = 355462360, this._eh = 1731405415, this._fh = 2394180231, this._gh = 3675008525, this._hh = 1203062813, this._al = 3238371032, this._bl = 914150663, this._cl = 812702999, this._dl = 4144912697, this._el = 4290775857, this._fl = 1750603025, this._gl = 1694076839, this._hl = 3204075428, this;
    };
    To.prototype._hash = function() {
      var t = J4.allocUnsafe(48);
      function e(r, o, f) {
        t.writeInt32BE(r, f), t.writeInt32BE(o, f + 4);
      }
      return e(this._ah, this._al, 0), e(this._bh, this._bl, 8), e(this._ch, this._cl, 16), e(this._dh, this._dl, 24), e(this._eh, this._el, 32), e(this._fh, this._fl, 40), t;
    };
    Cp.exports = To;
  });
  ko = T2((ci, Fp) => {
    var ci = Fp.exports = function(e) {
      e = e.toLowerCase();
      var r = ci[e];
      if (!r)
        throw new Error(e + " is not supported (we accept pull requests)");
      return new r;
    };
    ci.sha = _p();
    ci.sha1 = Ep();
    ci.sha224 = qp();
    ci.sha256 = gh();
    ci.sha384 = Op();
    ci.sha512 = yh();
  });
  Tt = T2((RI, Up) => {
    Up.exports = { ArrayIsArray(t) {
      return Array.isArray(t);
    }, ArrayPrototypeIncludes(t, e) {
      return t.includes(e);
    }, ArrayPrototypeIndexOf(t, e) {
      return t.indexOf(e);
    }, ArrayPrototypeJoin(t, e) {
      return t.join(e);
    }, ArrayPrototypeMap(t, e) {
      return t.map(e);
    }, ArrayPrototypePop(t, e) {
      return t.pop(e);
    }, ArrayPrototypePush(t, e) {
      return t.push(e);
    }, ArrayPrototypeSlice(t, e, r) {
      return t.slice(e, r);
    }, Error, FunctionPrototypeCall(t, e, ...r) {
      return t.call(e, ...r);
    }, FunctionPrototypeSymbolHasInstance(t, e) {
      return Function.prototype[Symbol.hasInstance].call(t, e);
    }, MathFloor: Math.floor, Number, NumberIsInteger: Number.isInteger, NumberIsNaN: Number.isNaN, NumberMAX_SAFE_INTEGER: Number.MAX_SAFE_INTEGER, NumberMIN_SAFE_INTEGER: Number.MIN_SAFE_INTEGER, NumberParseInt: Number.parseInt, ObjectDefineProperties(t, e) {
      return Object.defineProperties(t, e);
    }, ObjectDefineProperty(t, e, r) {
      return Object.defineProperty(t, e, r);
    }, ObjectGetOwnPropertyDescriptor(t, e) {
      return Object.getOwnPropertyDescriptor(t, e);
    }, ObjectKeys(t) {
      return Object.keys(t);
    }, ObjectSetPrototypeOf(t, e) {
      return Object.setPrototypeOf(t, e);
    }, Promise, PromisePrototypeCatch(t, e) {
      return t.catch(e);
    }, PromisePrototypeThen(t, e, r) {
      return t.then(e, r);
    }, PromiseReject(t) {
      return Promise.reject(t);
    }, ReflectApply: Reflect.apply, RegExpPrototypeTest(t, e) {
      return t.test(e);
    }, SafeSet: Set, String, StringPrototypeSlice(t, e, r) {
      return t.slice(e, r);
    }, StringPrototypeToLowerCase(t) {
      return t.toLowerCase();
    }, StringPrototypeToUpperCase(t) {
      return t.toUpperCase();
    }, StringPrototypeTrim(t) {
      return t.trim();
    }, Symbol, SymbolAsyncIterator: Symbol.asyncIterator, SymbolHasInstance: Symbol.hasInstance, SymbolIterator: Symbol.iterator, TypedArrayPrototypeSet(t, e, r) {
      return t.set(e, r);
    }, Uint8Array };
  });
  Gr = T2((BI, Mh) => {
    var e_ = Ut(), t_ = Object.getPrototypeOf(async function() {
    }).constructor, zp = globalThis.Blob || e_.Blob, r_ = typeof zp < "u" ? function(e) {
      return e instanceof zp;
    } : function(e) {
      return false;
    }, wh = class extends Error {
      constructor(e) {
        if (!Array.isArray(e))
          throw new TypeError(`Expected input to be an Array, got ${typeof e}`);
        let r = "";
        for (let o = 0;o < e.length; o++)
          r += `    ${e[o].stack}
`;
        super(r), this.name = "AggregateError", this.errors = e;
      }
    };
    Mh.exports = { AggregateError: wh, kEmptyObject: Object.freeze({}), once(t) {
      let e = false;
      return function(...r) {
        e || (e = true, t.apply(this, r));
      };
    }, createDeferredPromise: function() {
      let t, e;
      return { promise: new Promise((o, f) => {
        t = o, e = f;
      }), resolve: t, reject: e };
    }, promisify(t) {
      return new Promise((e, r) => {
        t((o, ...f) => o ? r(o) : e(...f));
      });
    }, debuglog() {
      return function() {
      };
    }, format(t, ...e) {
      return t.replace(/%([sdifj])/g, function(...[r, o]) {
        let f = e.shift();
        return o === "f" ? f.toFixed(6) : o === "j" ? JSON.stringify(f) : o === "s" && typeof f == "object" ? `${f.constructor !== Object ? f.constructor.name : ""} {}`.trim() : f.toString();
      });
    }, inspect(t) {
      switch (typeof t) {
        case "string":
          if (t.includes("'"))
            if (t.includes('"')) {
              if (!t.includes("`") && !t.includes("${"))
                return `\`${t}\``;
            } else
              return `"${t}"`;
          return `'${t}'`;
        case "number":
          return isNaN(t) ? "NaN" : Object.is(t, -0) ? String(t) : t;
        case "bigint":
          return `${String(t)}n`;
        case "boolean":
        case "undefined":
          return String(t);
        case "object":
          return "{}";
      }
    }, types: { isAsyncFunction(t) {
      return t instanceof t_;
    }, isArrayBufferView(t) {
      return ArrayBuffer.isView(t);
    } }, isBlob: r_ };
    Mh.exports.promisify.custom = Symbol.for("nodejs.util.promisify.custom");
  });
  No = T2((qI, Lo) => {
    var { AbortController: Hp, AbortSignal: i_ } = typeof self < "u" ? self : typeof window < "u" ? window : undefined;
    Lo.exports = Hp;
    Lo.exports.AbortSignal = i_;
    Lo.exports.default = Hp;
  });
  Jt = T2((II, jp) => {
    var { format: n_, inspect: Do, AggregateError: f_ } = Gr(), a_ = globalThis.AggregateError || f_, o_ = Symbol("kIsNodeError"), s_ = ["string", "function", "number", "object", "Function", "Object", "boolean", "bigint", "symbol"], h_ = /^([A-Z][a-z0-9]*)+$/, u_ = "__node_internal_", Po = {};
    function vn(t, e) {
      if (!t)
        throw new Po.ERR_INTERNAL_ASSERTION(e);
    }
    function Wp(t) {
      let e = "", r = t.length, o = t[0] === "-" ? 1 : 0;
      for (;r >= o + 4; r -= 3)
        e = `_${t.slice(r - 3, r)}${e}`;
      return `${t.slice(0, r)}${e}`;
    }
    function l_(t, e, r) {
      if (typeof e == "function")
        return vn(e.length <= r.length, `Code: ${t}; The provided arguments length (${r.length}) does not match the required ones (${e.length}).`), e(...r);
      let o = (e.match(/%[dfijoOs]/g) || []).length;
      return vn(o === r.length, `Code: ${t}; The provided arguments length (${r.length}) does not match the required ones (${o}).`), r.length === 0 ? e : n_(e, ...r);
    }
    function zt(t, e, r) {
      r || (r = Error);

      class o extends r {
        constructor(...p) {
          super(l_(t, e, p));
        }
        toString() {
          return `${this.name} [${t}]: ${this.message}`;
        }
      }
      Object.defineProperties(o.prototype, { name: { value: r.name, writable: true, enumerable: false, configurable: true }, toString: { value() {
        return `${this.name} [${t}]: ${this.message}`;
      }, writable: true, enumerable: false, configurable: true } }), o.prototype.code = t, o.prototype[o_] = true, Po[t] = o;
    }
    function Kp(t) {
      let e = u_ + t.name;
      return Object.defineProperty(t, "name", { value: e }), t;
    }
    function d_(t, e) {
      if (t && e && t !== e) {
        if (Array.isArray(e.errors))
          return e.errors.push(t), e;
        let r = new a_([e, t], e.message);
        return r.code = e.code, r;
      }
      return t || e;
    }
    var _h = class extends Error {
      constructor(e = "The operation was aborted", r = undefined) {
        if (r !== undefined && typeof r != "object")
          throw new Po.ERR_INVALID_ARG_TYPE("options", "Object", r);
        super(e, r), this.code = "ABORT_ERR", this.name = "AbortError";
      }
    };
    zt("ERR_ASSERTION", "%s", Error);
    zt("ERR_INVALID_ARG_TYPE", (t, e, r) => {
      vn(typeof t == "string", "'name' must be a string"), Array.isArray(e) || (e = [e]);
      let o = "The ";
      t.endsWith(" argument") ? o += `${t} ` : o += `"${t}" ${t.includes(".") ? "property" : "argument"} `, o += "must be ";
      let f = [], p = [], m2 = [];
      for (let M of e)
        vn(typeof M == "string", "All expected entries have to be of type string"), s_.includes(M) ? f.push(M.toLowerCase()) : h_.test(M) ? p.push(M) : (vn(M !== "object", 'The value "object" should be written as "Object"'), m2.push(M));
      if (p.length > 0) {
        let M = f.indexOf("object");
        M !== -1 && (f.splice(f, M, 1), p.push("Object"));
      }
      if (f.length > 0) {
        switch (f.length) {
          case 1:
            o += `of type ${f[0]}`;
            break;
          case 2:
            o += `one of type ${f[0]} or ${f[1]}`;
            break;
          default: {
            let M = f.pop();
            o += `one of type ${f.join(", ")}, or ${M}`;
          }
        }
        (p.length > 0 || m2.length > 0) && (o += " or ");
      }
      if (p.length > 0) {
        switch (p.length) {
          case 1:
            o += `an instance of ${p[0]}`;
            break;
          case 2:
            o += `an instance of ${p[0]} or ${p[1]}`;
            break;
          default: {
            let M = p.pop();
            o += `an instance of ${p.join(", ")}, or ${M}`;
          }
        }
        m2.length > 0 && (o += " or ");
      }
      switch (m2.length) {
        case 0:
          break;
        case 1:
          m2[0].toLowerCase() !== m2[0] && (o += "an "), o += `${m2[0]}`;
          break;
        case 2:
          o += `one of ${m2[0]} or ${m2[1]}`;
          break;
        default: {
          let M = m2.pop();
          o += `one of ${m2.join(", ")}, or ${M}`;
        }
      }
      if (r == null)
        o += `. Received ${r}`;
      else if (typeof r == "function" && r.name)
        o += `. Received function ${r.name}`;
      else if (typeof r == "object") {
        var y2;
        (y2 = r.constructor) !== null && y2 !== undefined && y2.name ? o += `. Received an instance of ${r.constructor.name}` : o += `. Received ${Do(r, { depth: -1 })}`;
      } else {
        let M = Do(r, { colors: false });
        M.length > 25 && (M = `${M.slice(0, 25)}...`), o += `. Received type ${typeof r} (${M})`;
      }
      return o;
    }, TypeError);
    zt("ERR_INVALID_ARG_VALUE", (t, e, r = "is invalid") => {
      let o = Do(e);
      return o.length > 128 && (o = o.slice(0, 128) + "..."), `The ${t.includes(".") ? "property" : "argument"} '${t}' ${r}. Received ${o}`;
    }, TypeError);
    zt("ERR_INVALID_RETURN_VALUE", (t, e, r) => {
      var o;
      let f = r != null && (o = r.constructor) !== null && o !== undefined && o.name ? `instance of ${r.constructor.name}` : `type ${typeof r}`;
      return `Expected ${t} to be returned from the "${e}" function but got ${f}.`;
    }, TypeError);
    zt("ERR_MISSING_ARGS", (...t) => {
      vn(t.length > 0, "At least one arg needs to be specified");
      let e, r = t.length;
      switch (t = (Array.isArray(t) ? t : [t]).map((o) => `"${o}"`).join(" or "), r) {
        case 1:
          e += `The ${t[0]} argument`;
          break;
        case 2:
          e += `The ${t[0]} and ${t[1]} arguments`;
          break;
        default:
          {
            let o = t.pop();
            e += `The ${t.join(", ")}, and ${o} arguments`;
          }
          break;
      }
      return `${e} must be specified`;
    }, TypeError);
    zt("ERR_OUT_OF_RANGE", (t, e, r) => {
      vn(e, 'Missing "range" argument');
      let o;
      return Number.isInteger(r) && Math.abs(r) > 2 ** 32 ? o = Wp(String(r)) : typeof r == "bigint" ? (o = String(r), (r > 2n ** 32n || r < -(2n ** 32n)) && (o = Wp(o)), o += "n") : o = Do(r), `The value of "${t}" is out of range. It must be ${e}. Received ${o}`;
    }, RangeError);
    zt("ERR_MULTIPLE_CALLBACK", "Callback called multiple times", Error);
    zt("ERR_METHOD_NOT_IMPLEMENTED", "The %s method is not implemented", Error);
    zt("ERR_STREAM_ALREADY_FINISHED", "Cannot call %s after a stream was finished", Error);
    zt("ERR_STREAM_CANNOT_PIPE", "Cannot pipe, not readable", Error);
    zt("ERR_STREAM_DESTROYED", "Cannot call %s after a stream was destroyed", Error);
    zt("ERR_STREAM_NULL_VALUES", "May not write null values to stream", TypeError);
    zt("ERR_STREAM_PREMATURE_CLOSE", "Premature close", Error);
    zt("ERR_STREAM_PUSH_AFTER_EOF", "stream.push() after EOF", Error);
    zt("ERR_STREAM_UNSHIFT_AFTER_END_EVENT", "stream.unshift() after end event", Error);
    zt("ERR_STREAM_WRITE_AFTER_END", "write after end", Error);
    zt("ERR_UNKNOWN_ENCODING", "Unknown encoding: %s", TypeError);
    jp.exports = { AbortError: _h, aggregateTwoErrors: Kp(d_), hideStackFrames: Kp, codes: Po };
  });
  pa = T2((TI, Qp) => {
    var { ArrayIsArray: $p, ArrayPrototypeIncludes: Gp, ArrayPrototypeJoin: Yp, ArrayPrototypeMap: c_, NumberIsInteger: Sh, NumberIsNaN: p_, NumberMAX_SAFE_INTEGER: v_, NumberMIN_SAFE_INTEGER: b_, NumberParseInt: m_, ObjectPrototypeHasOwnProperty: g_, RegExpPrototypeExec: y_, String: w_, StringPrototypeToUpperCase: M_, StringPrototypeTrim: __ } = Tt(), { hideStackFrames: Ir, codes: { ERR_SOCKET_BAD_PORT: x_, ERR_INVALID_ARG_TYPE: tr, ERR_INVALID_ARG_VALUE: Co, ERR_OUT_OF_RANGE: bn, ERR_UNKNOWN_SIGNAL: Zp } } = Jt(), { normalizeEncoding: S_ } = Gr(), { isAsyncFunction: E_, isArrayBufferView: A_ } = Gr().types, Vp = {};
    function R_(t) {
      return t === (t | 0);
    }
    function B_(t) {
      return t === t >>> 0;
    }
    var q_ = /^[0-7]+$/, I_ = "must be a 32-bit unsigned integer or an octal string";
    function T_(t, e, r) {
      if (typeof t > "u" && (t = r), typeof t == "string") {
        if (y_(q_, t) === null)
          throw new Co(e, t, I_);
        t = m_(t, 8);
      }
      return Xp(t, e), t;
    }
    var k_ = Ir((t, e, r = b_, o = v_) => {
      if (typeof t != "number")
        throw new tr(e, "number", t);
      if (!Sh(t))
        throw new bn(e, "an integer", t);
      if (t < r || t > o)
        throw new bn(e, `>= ${r} && <= ${o}`, t);
    }), L_ = Ir((t, e, r = -2147483648, o = 2147483647) => {
      if (typeof t != "number")
        throw new tr(e, "number", t);
      if (!Sh(t))
        throw new bn(e, "an integer", t);
      if (t < r || t > o)
        throw new bn(e, `>= ${r} && <= ${o}`, t);
    }), Xp = Ir((t, e, r = false) => {
      if (typeof t != "number")
        throw new tr(e, "number", t);
      if (!Sh(t))
        throw new bn(e, "an integer", t);
      let o = r ? 1 : 0, f = 4294967295;
      if (t < o || t > f)
        throw new bn(e, `>= ${o} && <= ${f}`, t);
    });
    function Jp(t, e) {
      if (typeof t != "string")
        throw new tr(e, "string", t);
    }
    function N_(t, e, r = undefined, o) {
      if (typeof t != "number")
        throw new tr(e, "number", t);
      if (r != null && t < r || o != null && t > o || (r != null || o != null) && p_(t))
        throw new bn(e, `${r != null ? `>= ${r}` : ""}${r != null && o != null ? " && " : ""}${o != null ? `<= ${o}` : ""}`, t);
    }
    var D_ = Ir((t, e, r) => {
      if (!Gp(r, t)) {
        let o = Yp(c_(r, (p) => typeof p == "string" ? `'${p}'` : w_(p)), ", "), f = "must be one of: " + o;
        throw new Co(e, t, f);
      }
    });
    function P_(t, e) {
      if (typeof t != "boolean")
        throw new tr(e, "boolean", t);
    }
    function xh(t, e, r) {
      return t == null || !g_(t, e) ? r : t[e];
    }
    var C_ = Ir((t, e, r = null) => {
      let o = xh(r, "allowArray", false), f = xh(r, "allowFunction", false);
      if (!xh(r, "nullable", false) && t === null || !o && $p(t) || typeof t != "object" && (!f || typeof t != "function"))
        throw new tr(e, "Object", t);
    }), O_ = Ir((t, e, r = 0) => {
      if (!$p(t))
        throw new tr(e, "Array", t);
      if (t.length < r) {
        let o = `must be longer than ${r}`;
        throw new Co(e, t, o);
      }
    });
    function F_(t, e = "signal") {
      if (Jp(t, e), Vp[t] === undefined)
        throw Vp[M_(t)] !== undefined ? new Zp(t + " (signals must use all capital letters)") : new Zp(t);
    }
    var U_ = Ir((t, e = "buffer") => {
      if (!A_(t))
        throw new tr(e, ["Buffer", "TypedArray", "DataView"], t);
    });
    function z_(t, e) {
      let r = S_(e), o = t.length;
      if (r === "hex" && o % 2 !== 0)
        throw new Co("encoding", e, `is invalid for data of length ${o}`);
    }
    function H_(t, e = "Port", r = true) {
      if (typeof t != "number" && typeof t != "string" || typeof t == "string" && __(t).length === 0 || +t !== +t >>> 0 || t > 65535 || t === 0 && !r)
        throw new x_(e, t, r);
      return t | 0;
    }
    var W_ = Ir((t, e) => {
      if (t !== undefined && (t === null || typeof t != "object" || !("aborted" in t)))
        throw new tr(e, "AbortSignal", t);
    }), K_ = Ir((t, e) => {
      if (typeof t != "function")
        throw new tr(e, "Function", t);
    }), j_ = Ir((t, e) => {
      if (typeof t != "function" || E_(t))
        throw new tr(e, "Function", t);
    }), Z_ = Ir((t, e) => {
      if (t !== undefined)
        throw new tr(e, "undefined", t);
    });
    function V_(t, e, r) {
      if (!Gp(r, t))
        throw new tr(e, `('${Yp(r, "|")}')`, t);
    }
    Qp.exports = { isInt32: R_, isUint32: B_, parseFileMode: T_, validateArray: O_, validateBoolean: P_, validateBuffer: U_, validateEncoding: z_, validateFunction: K_, validateInt32: L_, validateInteger: k_, validateNumber: N_, validateObject: C_, validateOneOf: D_, validatePlainFunction: j_, validatePort: H_, validateSignalName: F_, validateString: Jp, validateUint32: Xp, validateUndefined: Z_, validateUnion: V_, validateAbortSignal: W_ };
  });
  Rh = T2((kI, i1) => {
    var dt = i1.exports = {}, Yr, Xr;
    function Eh() {
      throw new Error("setTimeout has not been defined");
    }
    function Ah() {
      throw new Error("clearTimeout has not been defined");
    }
    (function() {
      try {
        typeof setTimeout == "function" ? Yr = setTimeout : Yr = Eh;
      } catch {
        Yr = Eh;
      }
      try {
        typeof clearTimeout == "function" ? Xr = clearTimeout : Xr = Ah;
      } catch {
        Xr = Ah;
      }
    })();
    function e1(t) {
      if (Yr === setTimeout)
        return setTimeout(t, 0);
      if ((Yr === Eh || !Yr) && setTimeout)
        return Yr = setTimeout, setTimeout(t, 0);
      try {
        return Yr(t, 0);
      } catch {
        try {
          return Yr.call(null, t, 0);
        } catch {
          return Yr.call(this, t, 0);
        }
      }
    }
    function $_(t) {
      if (Xr === clearTimeout)
        return clearTimeout(t);
      if ((Xr === Ah || !Xr) && clearTimeout)
        return Xr = clearTimeout, clearTimeout(t);
      try {
        return Xr(t);
      } catch {
        try {
          return Xr.call(null, t);
        } catch {
          return Xr.call(this, t);
        }
      }
    }
    var pi = [], nf = false, mn, Oo = -1;
    function G_() {
      !nf || !mn || (nf = false, mn.length ? pi = mn.concat(pi) : Oo = -1, pi.length && t1());
    }
    function t1() {
      if (!nf) {
        var t = e1(G_);
        nf = true;
        for (var e = pi.length;e; ) {
          for (mn = pi, pi = [];++Oo < e; )
            mn && mn[Oo].run();
          Oo = -1, e = pi.length;
        }
        mn = null, nf = false, $_(t);
      }
    }
    dt.nextTick = function(t) {
      var e = new Array(arguments.length - 1);
      if (arguments.length > 1)
        for (var r = 1;r < arguments.length; r++)
          e[r - 1] = arguments[r];
      pi.push(new r1(t, e)), pi.length === 1 && !nf && e1(t1);
    };
    function r1(t, e) {
      this.fun = t, this.array = e;
    }
    r1.prototype.run = function() {
      this.fun.apply(null, this.array);
    };
    dt.title = "browser";
    dt.browser = true;
    dt.env = {};
    dt.argv = [];
    dt.version = "";
    dt.versions = {};
    function vi() {
    }
    dt.on = vi;
    dt.addListener = vi;
    dt.once = vi;
    dt.off = vi;
    dt.removeListener = vi;
    dt.removeAllListeners = vi;
    dt.emit = vi;
    dt.prependListener = vi;
    dt.prependOnceListener = vi;
    dt.listeners = function(t) {
      return [];
    };
    dt.binding = function(t) {
      throw new Error("process.binding is not supported");
    };
    dt.cwd = function() {
      return "/";
    };
    dt.chdir = function(t) {
      throw new Error("process.chdir is not supported");
    };
    dt.umask = function() {
      return 0;
    };
  });
  pr = {};
  Ja(pr, { default: () => Y_ });
  Oi = R0(() => {
    ot(pr, rn(Rh()));
    Y_ = rn(Rh());
  });
  Fi = T2((NI, v1) => {
    var { Symbol: Fo, SymbolAsyncIterator: n1, SymbolIterator: f1 } = Tt(), a1 = Fo("kDestroyed"), o1 = Fo("kIsErrored"), Bh = Fo("kIsReadable"), s1 = Fo("kIsDisturbed");
    function Uo(t, e = false) {
      var r;
      return !!(t && typeof t.pipe == "function" && typeof t.on == "function" && (!e || typeof t.pause == "function" && typeof t.resume == "function") && (!t._writableState || ((r = t._readableState) === null || r === undefined ? undefined : r.readable) !== false) && (!t._writableState || t._readableState));
    }
    function zo(t) {
      var e;
      return !!(t && typeof t.write == "function" && typeof t.on == "function" && (!t._readableState || ((e = t._writableState) === null || e === undefined ? undefined : e.writable) !== false));
    }
    function X_(t) {
      return !!(t && typeof t.pipe == "function" && t._readableState && typeof t.on == "function" && typeof t.write == "function");
    }
    function gn(t) {
      return t && (t._readableState || t._writableState || typeof t.write == "function" && typeof t.on == "function" || typeof t.pipe == "function" && typeof t.on == "function");
    }
    function J_(t, e) {
      return t == null ? false : e === true ? typeof t[n1] == "function" : e === false ? typeof t[f1] == "function" : typeof t[n1] == "function" || typeof t[f1] == "function";
    }
    function Ho(t) {
      if (!gn(t))
        return null;
      let { _writableState: e, _readableState: r } = t, o = e || r;
      return !!(t.destroyed || t[a1] || o != null && o.destroyed);
    }
    function h1(t) {
      if (!zo(t))
        return null;
      if (t.writableEnded === true)
        return true;
      let e = t._writableState;
      return e != null && e.errored ? false : typeof e?.ended != "boolean" ? null : e.ended;
    }
    function Q_(t, e) {
      if (!zo(t))
        return null;
      if (t.writableFinished === true)
        return true;
      let r = t._writableState;
      return r != null && r.errored ? false : typeof r?.finished != "boolean" ? null : !!(r.finished || e === false && r.ended === true && r.length === 0);
    }
    function e8(t) {
      if (!Uo(t))
        return null;
      if (t.readableEnded === true)
        return true;
      let e = t._readableState;
      return !e || e.errored ? false : typeof e?.ended != "boolean" ? null : e.ended;
    }
    function u1(t, e) {
      if (!Uo(t))
        return null;
      let r = t._readableState;
      return r != null && r.errored ? false : typeof r?.endEmitted != "boolean" ? null : !!(r.endEmitted || e === false && r.ended === true && r.length === 0);
    }
    function l1(t) {
      return t && t[Bh] != null ? t[Bh] : typeof t?.readable != "boolean" ? null : Ho(t) ? false : Uo(t) && t.readable && !u1(t);
    }
    function d1(t) {
      return typeof t?.writable != "boolean" ? null : Ho(t) ? false : zo(t) && t.writable && !h1(t);
    }
    function t8(t, e) {
      return gn(t) ? Ho(t) ? true : !(e?.readable !== false && l1(t) || e?.writable !== false && d1(t)) : null;
    }
    function r8(t) {
      var e, r;
      return gn(t) ? t.writableErrored ? t.writableErrored : (e = (r = t._writableState) === null || r === undefined ? undefined : r.errored) !== null && e !== undefined ? e : null : null;
    }
    function i8(t) {
      var e, r;
      return gn(t) ? t.readableErrored ? t.readableErrored : (e = (r = t._readableState) === null || r === undefined ? undefined : r.errored) !== null && e !== undefined ? e : null : null;
    }
    function n8(t) {
      if (!gn(t))
        return null;
      if (typeof t.closed == "boolean")
        return t.closed;
      let { _writableState: e, _readableState: r } = t;
      return typeof e?.closed == "boolean" || typeof r?.closed == "boolean" ? e?.closed || r?.closed : typeof t._closed == "boolean" && c1(t) ? t._closed : null;
    }
    function c1(t) {
      return typeof t._closed == "boolean" && typeof t._defaultKeepAlive == "boolean" && typeof t._removedConnection == "boolean" && typeof t._removedContLen == "boolean";
    }
    function p1(t) {
      return typeof t._sent100 == "boolean" && c1(t);
    }
    function f8(t) {
      var e;
      return typeof t._consuming == "boolean" && typeof t._dumped == "boolean" && ((e = t.req) === null || e === undefined ? undefined : e.upgradeOrConnect) === undefined;
    }
    function a8(t) {
      if (!gn(t))
        return null;
      let { _writableState: e, _readableState: r } = t, o = e || r;
      return !o && p1(t) || !!(o && o.autoDestroy && o.emitClose && o.closed === false);
    }
    function o8(t) {
      var e;
      return !!(t && ((e = t[s1]) !== null && e !== undefined ? e : t.readableDidRead || t.readableAborted));
    }
    function s8(t) {
      var e, r, o, f, p, m2, y2, M, x, S;
      return !!(t && ((e = (r = (o = (f = (p = (m2 = t[o1]) !== null && m2 !== undefined ? m2 : t.readableErrored) !== null && p !== undefined ? p : t.writableErrored) !== null && f !== undefined ? f : (y2 = t._readableState) === null || y2 === undefined ? undefined : y2.errorEmitted) !== null && o !== undefined ? o : (M = t._writableState) === null || M === undefined ? undefined : M.errorEmitted) !== null && r !== undefined ? r : (x = t._readableState) === null || x === undefined ? undefined : x.errored) !== null && e !== undefined ? e : (S = t._writableState) === null || S === undefined ? undefined : S.errored));
    }
    v1.exports = { kDestroyed: a1, isDisturbed: o8, kIsDisturbed: s1, isErrored: s8, kIsErrored: o1, isReadable: l1, kIsReadable: Bh, isClosed: n8, isDestroyed: Ho, isDuplexNodeStream: X_, isFinished: t8, isIterable: J_, isReadableNodeStream: Uo, isReadableEnded: e8, isReadableFinished: u1, isReadableErrored: i8, isNodeStream: gn, isWritable: d1, isWritableNodeStream: zo, isWritableEnded: h1, isWritableFinished: Q_, isWritableErrored: r8, isServerRequest: f8, isServerResponse: p1, willEmitClose: a8 };
  });
  Ui = T2((DI, Ih) => {
    var ff = (Oi(), ur(pr)), { AbortError: h8, codes: u8 } = Jt(), { ERR_INVALID_ARG_TYPE: l8, ERR_STREAM_PREMATURE_CLOSE: b1 } = u8, { kEmptyObject: m1, once: g1 } = Gr(), { validateAbortSignal: d8, validateFunction: c8, validateObject: p8 } = pa(), { Promise: v8 } = Tt(), { isClosed: b8, isReadable: y1, isReadableNodeStream: qh, isReadableFinished: w1, isReadableErrored: m8, isWritable: M1, isWritableNodeStream: _1, isWritableFinished: x1, isWritableErrored: g8, isNodeStream: y8, willEmitClose: w8 } = Fi();
    function M8(t) {
      return t.setHeader && typeof t.abort == "function";
    }
    var _8 = () => {
    };
    function S1(t, e, r) {
      var o, f;
      arguments.length === 2 ? (r = e, e = m1) : e == null ? e = m1 : p8(e, "options"), c8(r, "callback"), d8(e.signal, "options.signal"), r = g1(r);
      let p = (o = e.readable) !== null && o !== undefined ? o : qh(t), m2 = (f = e.writable) !== null && f !== undefined ? f : _1(t);
      if (!y8(t))
        throw new l8("stream", "Stream", t);
      let { _writableState: y2, _readableState: M } = t, x = () => {
        t.writable || B();
      }, S = w8(t) && qh(t) === p && _1(t) === m2, E2 = x1(t, false), B = () => {
        E2 = true, t.destroyed && (S = false), !(S && (!t.readable || p)) && (!p || q2) && r.call(t);
      }, q2 = w1(t, false), L2 = () => {
        q2 = true, t.destroyed && (S = false), !(S && (!t.writable || m2)) && (!m2 || E2) && r.call(t);
      }, ge = (xe) => {
        r.call(t, xe);
      }, _e = b8(t), N = () => {
        _e = true;
        let xe = g8(t) || m8(t);
        if (xe && typeof xe != "boolean")
          return r.call(t, xe);
        if (p && !q2 && qh(t, true) && !w1(t, false))
          return r.call(t, new b1);
        if (m2 && !E2 && !x1(t, false))
          return r.call(t, new b1);
        r.call(t);
      }, we = () => {
        t.req.on("finish", B);
      };
      M8(t) ? (t.on("complete", B), S || t.on("abort", N), t.req ? we() : t.on("request", we)) : m2 && !y2 && (t.on("end", x), t.on("close", x)), !S && typeof t.aborted == "boolean" && t.on("aborted", N), t.on("end", L2), t.on("finish", B), e.error !== false && t.on("error", ge), t.on("close", N), _e ? ff.nextTick(N) : y2 != null && y2.errorEmitted || M != null && M.errorEmitted ? S || ff.nextTick(N) : (!p && (!S || y1(t)) && (E2 || M1(t) === false) || !m2 && (!S || M1(t)) && (q2 || y1(t) === false) || M && t.req && t.aborted) && ff.nextTick(N);
      let ye = () => {
        r = _8, t.removeListener("aborted", N), t.removeListener("complete", B), t.removeListener("abort", N), t.removeListener("request", we), t.req && t.req.removeListener("finish", B), t.removeListener("end", x), t.removeListener("close", x), t.removeListener("finish", B), t.removeListener("end", L2), t.removeListener("error", ge), t.removeListener("close", N);
      };
      if (e.signal && !_e) {
        let xe = () => {
          let Re = r;
          ye(), Re.call(t, new h8(undefined, { cause: e.signal.reason }));
        };
        if (e.signal.aborted)
          ff.nextTick(xe);
        else {
          let Re = r;
          r = g1((...Ee) => {
            e.signal.removeEventListener("abort", xe), Re.apply(t, Ee);
          }), e.signal.addEventListener("abort", xe);
        }
      }
      return ye;
    }
    function x8(t, e) {
      return new v8((r, o) => {
        S1(t, e, (f) => {
          f ? o(f) : r();
        });
      });
    }
    Ih.exports = S1;
    Ih.exports.finished = x8;
  });
  k1 = T2((PI, Lh) => {
    var B1 = globalThis.AbortController || No().AbortController, { codes: { ERR_INVALID_ARG_TYPE: va, ERR_MISSING_ARGS: S8, ERR_OUT_OF_RANGE: E8 }, AbortError: Jr } = Jt(), { validateAbortSignal: af, validateInteger: A8, validateObject: of } = pa(), R8 = Tt().Symbol("kWeak"), { finished: B8 } = Ui(), { ArrayPrototypePush: q8, MathFloor: I8, Number: T8, NumberIsNaN: k8, Promise: E1, PromiseReject: A1, PromisePrototypeThen: L8, Symbol: q1 } = Tt(), Wo = q1("kEmpty"), R1 = q1("kEof");
    function Ko(t, e) {
      if (typeof t != "function")
        throw new va("fn", ["Function", "AsyncFunction"], t);
      e != null && of(e, "options"), e?.signal != null && af(e.signal, "options.signal");
      let r = 1;
      return e?.concurrency != null && (r = I8(e.concurrency)), A8(r, "concurrency", 1), async function* () {
        var f, p;
        let m2 = new B1, y2 = this, M = [], x = m2.signal, S = { signal: x }, E2 = () => m2.abort();
        e != null && (f = e.signal) !== null && f !== undefined && f.aborted && E2(), e == null || (p = e.signal) === null || p === undefined || p.addEventListener("abort", E2);
        let B, q2, L2 = false;
        function ge() {
          L2 = true;
        }
        async function _e() {
          try {
            for await (let ye of y2) {
              var N;
              if (L2)
                return;
              if (x.aborted)
                throw new Jr;
              try {
                ye = t(ye, S);
              } catch (xe) {
                ye = A1(xe);
              }
              ye !== Wo && (typeof ((N = ye) === null || N === undefined ? undefined : N.catch) == "function" && ye.catch(ge), M.push(ye), B && (B(), B = null), !L2 && M.length && M.length >= r && await new E1((xe) => {
                q2 = xe;
              }));
            }
            M.push(R1);
          } catch (ye) {
            let xe = A1(ye);
            L8(xe, undefined, ge), M.push(xe);
          } finally {
            var we;
            L2 = true, B && (B(), B = null), e == null || (we = e.signal) === null || we === undefined || we.removeEventListener("abort", E2);
          }
        }
        _e();
        try {
          for (;; ) {
            for (;M.length > 0; ) {
              let N = await M[0];
              if (N === R1)
                return;
              if (x.aborted)
                throw new Jr;
              N !== Wo && (yield N), M.shift(), q2 && (q2(), q2 = null);
            }
            await new E1((N) => {
              B = N;
            });
          }
        } finally {
          m2.abort(), L2 = true, q2 && (q2(), q2 = null);
        }
      }.call(this);
    }
    function N8(t = undefined) {
      return t != null && of(t, "options"), t?.signal != null && af(t.signal, "options.signal"), async function* () {
        let r = 0;
        for await (let f of this) {
          var o;
          if (t != null && (o = t.signal) !== null && o !== undefined && o.aborted)
            throw new Jr({ cause: t.signal.reason });
          yield [r++, f];
        }
      }.call(this);
    }
    async function I1(t, e = undefined) {
      for await (let r of kh.call(this, t, e))
        return true;
      return false;
    }
    async function D8(t, e = undefined) {
      if (typeof t != "function")
        throw new va("fn", ["Function", "AsyncFunction"], t);
      return !await I1.call(this, async (...r) => !await t(...r), e);
    }
    async function P8(t, e) {
      for await (let r of kh.call(this, t, e))
        return r;
    }
    async function C8(t, e) {
      if (typeof t != "function")
        throw new va("fn", ["Function", "AsyncFunction"], t);
      async function r(o, f) {
        return await t(o, f), Wo;
      }
      for await (let o of Ko.call(this, r, e))
        ;
    }
    function kh(t, e) {
      if (typeof t != "function")
        throw new va("fn", ["Function", "AsyncFunction"], t);
      async function r(o, f) {
        return await t(o, f) ? o : Wo;
      }
      return Ko.call(this, r, e);
    }
    var Th = class extends S8 {
      constructor() {
        super("reduce"), this.message = "Reduce of an empty stream requires an initial value";
      }
    };
    async function O8(t, e, r) {
      var o;
      if (typeof t != "function")
        throw new va("reducer", ["Function", "AsyncFunction"], t);
      r != null && of(r, "options"), r?.signal != null && af(r.signal, "options.signal");
      let f = arguments.length > 1;
      if (r != null && (o = r.signal) !== null && o !== undefined && o.aborted) {
        let x = new Jr(undefined, { cause: r.signal.reason });
        throw this.once("error", () => {
        }), await B8(this.destroy(x)), x;
      }
      let p = new B1, m2 = p.signal;
      if (r != null && r.signal) {
        let x = { once: true, [R8]: this };
        r.signal.addEventListener("abort", () => p.abort(), x);
      }
      let y2 = false;
      try {
        for await (let x of this) {
          var M;
          if (y2 = true, r != null && (M = r.signal) !== null && M !== undefined && M.aborted)
            throw new Jr;
          f ? e = await t(e, x, { signal: m2 }) : (e = x, f = true);
        }
        if (!y2 && !f)
          throw new Th;
      } finally {
        p.abort();
      }
      return e;
    }
    async function F8(t) {
      t != null && of(t, "options"), t?.signal != null && af(t.signal, "options.signal");
      let e = [];
      for await (let o of this) {
        var r;
        if (t != null && (r = t.signal) !== null && r !== undefined && r.aborted)
          throw new Jr(undefined, { cause: t.signal.reason });
        q8(e, o);
      }
      return e;
    }
    function U8(t, e) {
      let r = Ko.call(this, t, e);
      return async function* () {
        for await (let f of r)
          yield* f;
      }.call(this);
    }
    function T1(t) {
      if (t = T8(t), k8(t))
        return 0;
      if (t < 0)
        throw new E8("number", ">= 0", t);
      return t;
    }
    function z8(t, e = undefined) {
      return e != null && of(e, "options"), e?.signal != null && af(e.signal, "options.signal"), t = T1(t), async function* () {
        var o;
        if (e != null && (o = e.signal) !== null && o !== undefined && o.aborted)
          throw new Jr;
        for await (let p of this) {
          var f;
          if (e != null && (f = e.signal) !== null && f !== undefined && f.aborted)
            throw new Jr;
          t-- <= 0 && (yield p);
        }
      }.call(this);
    }
    function H8(t, e = undefined) {
      return e != null && of(e, "options"), e?.signal != null && af(e.signal, "options.signal"), t = T1(t), async function* () {
        var o;
        if (e != null && (o = e.signal) !== null && o !== undefined && o.aborted)
          throw new Jr;
        for await (let p of this) {
          var f;
          if (e != null && (f = e.signal) !== null && f !== undefined && f.aborted)
            throw new Jr;
          if (t-- > 0)
            yield p;
          else
            return;
        }
      }.call(this);
    }
    Lh.exports.streamReturningOperators = { asIndexedPairs: N8, drop: z8, filter: kh, flatMap: U8, map: Ko, take: H8 };
    Lh.exports.promiseReturningOperators = { every: D8, forEach: C8, reduce: O8, toArray: F8, some: I1, find: P8 };
  });
  yn = T2((CI, U1) => {
    var zi = (Oi(), ur(pr)), { aggregateTwoErrors: W8, codes: { ERR_MULTIPLE_CALLBACK: K8 }, AbortError: j8 } = Jt(), { Symbol: D1 } = Tt(), { kDestroyed: Z8, isDestroyed: V8, isFinished: $8, isServerRequest: G8 } = Fi(), P1 = D1("kDestroy"), Nh = D1("kConstruct");
    function C1(t, e, r) {
      t && (t.stack, e && !e.errored && (e.errored = t), r && !r.errored && (r.errored = t));
    }
    function Y8(t, e) {
      let r = this._readableState, o = this._writableState, f = o || r;
      return o && o.destroyed || r && r.destroyed ? (typeof e == "function" && e(), this) : (C1(t, o, r), o && (o.destroyed = true), r && (r.destroyed = true), f.constructed ? L1(this, t, e) : this.once(P1, function(p) {
        L1(this, W8(p, t), e);
      }), this);
    }
    function L1(t, e, r) {
      let o = false;
      function f(p) {
        if (o)
          return;
        o = true;
        let { _readableState: m2, _writableState: y2 } = t;
        C1(p, y2, m2), y2 && (y2.closed = true), m2 && (m2.closed = true), typeof r == "function" && r(p), p ? zi.nextTick(X8, t, p) : zi.nextTick(O1, t);
      }
      try {
        t._destroy(e || null, f);
      } catch (p) {
        f(p);
      }
    }
    function X8(t, e) {
      Dh(t, e), O1(t);
    }
    function O1(t) {
      let { _readableState: e, _writableState: r } = t;
      r && (r.closeEmitted = true), e && (e.closeEmitted = true), (r && r.emitClose || e && e.emitClose) && t.emit("close");
    }
    function Dh(t, e) {
      let { _readableState: r, _writableState: o } = t;
      o && o.errorEmitted || r && r.errorEmitted || (o && (o.errorEmitted = true), r && (r.errorEmitted = true), t.emit("error", e));
    }
    function J8() {
      let t = this._readableState, e = this._writableState;
      t && (t.constructed = true, t.closed = false, t.closeEmitted = false, t.destroyed = false, t.errored = null, t.errorEmitted = false, t.reading = false, t.ended = t.readable === false, t.endEmitted = t.readable === false), e && (e.constructed = true, e.destroyed = false, e.closed = false, e.closeEmitted = false, e.errored = null, e.errorEmitted = false, e.finalCalled = false, e.prefinished = false, e.ended = e.writable === false, e.ending = e.writable === false, e.finished = e.writable === false);
    }
    function Ph(t, e, r) {
      let { _readableState: o, _writableState: f } = t;
      if (f && f.destroyed || o && o.destroyed)
        return this;
      o && o.autoDestroy || f && f.autoDestroy ? t.destroy(e) : e && (e.stack, f && !f.errored && (f.errored = e), o && !o.errored && (o.errored = e), r ? zi.nextTick(Dh, t, e) : Dh(t, e));
    }
    function Q8(t, e) {
      if (typeof t._construct != "function")
        return;
      let { _readableState: r, _writableState: o } = t;
      r && (r.constructed = false), o && (o.constructed = false), t.once(Nh, e), !(t.listenerCount(Nh) > 1) && zi.nextTick(e5, t);
    }
    function e5(t) {
      let e = false;
      function r(o) {
        if (e) {
          Ph(t, o ?? new K8);
          return;
        }
        e = true;
        let { _readableState: f, _writableState: p } = t, m2 = p || f;
        f && (f.constructed = true), p && (p.constructed = true), m2.destroyed ? t.emit(P1, o) : o ? Ph(t, o, true) : zi.nextTick(t5, t);
      }
      try {
        t._construct(r);
      } catch (o) {
        r(o);
      }
    }
    function t5(t) {
      t.emit(Nh);
    }
    function N1(t) {
      return t && t.setHeader && typeof t.abort == "function";
    }
    function F1(t) {
      t.emit("close");
    }
    function r5(t, e) {
      t.emit("error", e), zi.nextTick(F1, t);
    }
    function i5(t, e) {
      !t || V8(t) || (!e && !$8(t) && (e = new j8), G8(t) ? (t.socket = null, t.destroy(e)) : N1(t) ? t.abort() : N1(t.req) ? t.req.abort() : typeof t.destroy == "function" ? t.destroy(e) : typeof t.close == "function" ? t.close() : e ? zi.nextTick(r5, t, e) : zi.nextTick(F1, t), t.destroyed || (t[Z8] = true));
    }
    U1.exports = { construct: Q8, destroyer: i5, destroy: Y8, undestroy: J8, errorOrDestroy: Ph };
  });
  Vo = T2((OI, H1) => {
    var { ArrayIsArray: n5, ObjectSetPrototypeOf: z1 } = Tt(), { EventEmitter: jo } = ki();
    function Zo(t) {
      jo.call(this, t);
    }
    z1(Zo.prototype, jo.prototype);
    z1(Zo, jo);
    Zo.prototype.pipe = function(t, e) {
      let r = this;
      function o(S) {
        t.writable && t.write(S) === false && r.pause && r.pause();
      }
      r.on("data", o);
      function f() {
        r.readable && r.resume && r.resume();
      }
      t.on("drain", f), !t._isStdio && (!e || e.end !== false) && (r.on("end", m2), r.on("close", y2));
      let p = false;
      function m2() {
        p || (p = true, t.end());
      }
      function y2() {
        p || (p = true, typeof t.destroy == "function" && t.destroy());
      }
      function M(S) {
        x(), jo.listenerCount(this, "error") === 0 && this.emit("error", S);
      }
      Ch(r, "error", M), Ch(t, "error", M);
      function x() {
        r.removeListener("data", o), t.removeListener("drain", f), r.removeListener("end", m2), r.removeListener("close", y2), r.removeListener("error", M), t.removeListener("error", M), r.removeListener("end", x), r.removeListener("close", x), t.removeListener("close", x);
      }
      return r.on("end", x), r.on("close", x), t.on("close", x), t.emit("pipe", r), t;
    };
    function Ch(t, e, r) {
      if (typeof t.prependListener == "function")
        return t.prependListener(e, r);
      !t._events || !t._events[e] ? t.on(e, r) : n5(t._events[e]) ? t._events[e].unshift(r) : t._events[e] = [r, t._events[e]];
    }
    H1.exports = { Stream: Zo, prependListener: Ch };
  });
  Go = T2((FI, $o) => {
    var { AbortError: f5, codes: a5 } = Jt(), o5 = Ui(), { ERR_INVALID_ARG_TYPE: W1 } = a5, s5 = (t, e) => {
      if (typeof t != "object" || !("aborted" in t))
        throw new W1(e, "AbortSignal", t);
    };
    function h5(t) {
      return !!(t && typeof t.pipe == "function");
    }
    $o.exports.addAbortSignal = function(e, r) {
      if (s5(e, "signal"), !h5(r))
        throw new W1("stream", "stream.Stream", r);
      return $o.exports.addAbortSignalNoValidate(e, r);
    };
    $o.exports.addAbortSignalNoValidate = function(t, e) {
      if (typeof t != "object" || !("aborted" in t))
        return e;
      let r = () => {
        e.destroy(new f5(undefined, { cause: t.reason }));
      };
      return t.aborted ? r() : (t.addEventListener("abort", r), o5(e, () => t.removeEventListener("abort", r))), e;
    };
  });
  Z1 = T2((zI, j1) => {
    var { StringPrototypeSlice: K1, SymbolIterator: u5, TypedArrayPrototypeSet: Yo, Uint8Array: l5 } = Tt(), { Buffer: Oh } = Ut(), { inspect: d5 } = Gr();
    j1.exports = class {
      constructor() {
        this.head = null, this.tail = null, this.length = 0;
      }
      push(e) {
        let r = { data: e, next: null };
        this.length > 0 ? this.tail.next = r : this.head = r, this.tail = r, ++this.length;
      }
      unshift(e) {
        let r = { data: e, next: this.head };
        this.length === 0 && (this.tail = r), this.head = r, ++this.length;
      }
      shift() {
        if (this.length === 0)
          return;
        let e = this.head.data;
        return this.length === 1 ? this.head = this.tail = null : this.head = this.head.next, --this.length, e;
      }
      clear() {
        this.head = this.tail = null, this.length = 0;
      }
      join(e) {
        if (this.length === 0)
          return "";
        let r = this.head, o = "" + r.data;
        for (;(r = r.next) !== null; )
          o += e + r.data;
        return o;
      }
      concat(e) {
        if (this.length === 0)
          return Oh.alloc(0);
        let r = Oh.allocUnsafe(e >>> 0), o = this.head, f = 0;
        for (;o; )
          Yo(r, o.data, f), f += o.data.length, o = o.next;
        return r;
      }
      consume(e, r) {
        let o = this.head.data;
        if (e < o.length) {
          let f = o.slice(0, e);
          return this.head.data = o.slice(e), f;
        }
        return e === o.length ? this.shift() : r ? this._getString(e) : this._getBuffer(e);
      }
      first() {
        return this.head.data;
      }
      *[u5]() {
        for (let e = this.head;e; e = e.next)
          yield e.data;
      }
      _getString(e) {
        let r = "", o = this.head, f = 0;
        do {
          let p = o.data;
          if (e > p.length)
            r += p, e -= p.length;
          else {
            e === p.length ? (r += p, ++f, o.next ? this.head = o.next : this.head = this.tail = null) : (r += K1(p, 0, e), this.head = o, o.data = K1(p, e));
            break;
          }
          ++f;
        } while ((o = o.next) !== null);
        return this.length -= f, r;
      }
      _getBuffer(e) {
        let r = Oh.allocUnsafe(e), o = e, f = this.head, p = 0;
        do {
          let m2 = f.data;
          if (e > m2.length)
            Yo(r, m2, o - e), e -= m2.length;
          else {
            e === m2.length ? (Yo(r, m2, o - e), ++p, f.next ? this.head = f.next : this.head = this.tail = null) : (Yo(r, new l5(m2.buffer, m2.byteOffset, e), o - e), this.head = f, f.data = m2.slice(e));
            break;
          }
          ++p;
        } while ((f = f.next) !== null);
        return this.length -= p, r;
      }
      [Symbol.for("nodejs.util.inspect.custom")](e, r) {
        return d5(this, { ...r, depth: 0, customInspect: false });
      }
    };
  });
  Xo = T2((HI, $1) => {
    var { MathFloor: c5, NumberIsInteger: p5 } = Tt(), { ERR_INVALID_ARG_VALUE: v5 } = Jt().codes;
    function b5(t, e, r) {
      return t.highWaterMark != null ? t.highWaterMark : e ? t[r] : null;
    }
    function V1(t) {
      return t ? 16 : 16 * 1024;
    }
    function m5(t, e, r, o) {
      let f = b5(e, o, r);
      if (f != null) {
        if (!p5(f) || f < 0) {
          let p = o ? `options.${r}` : "options.highWaterMark";
          throw new v5(p, f);
        }
        return c5(f);
      }
      return V1(t.objectMode);
    }
    $1.exports = { getHighWaterMark: m5, getDefaultHighWaterMark: V1 };
  });
  Fh = T2((WI, J1) => {
    var G1 = (Oi(), ur(pr)), { PromisePrototypeThen: g5, SymbolAsyncIterator: Y1, SymbolIterator: X1 } = Tt(), { Buffer: y5 } = Ut(), { ERR_INVALID_ARG_TYPE: w5, ERR_STREAM_NULL_VALUES: M5 } = Jt().codes;
    function _5(t, e, r) {
      let o;
      if (typeof e == "string" || e instanceof y5)
        return new t({ objectMode: true, ...r, read() {
          this.push(e), this.push(null);
        } });
      let f;
      if (e && e[Y1])
        f = true, o = e[Y1]();
      else if (e && e[X1])
        f = false, o = e[X1]();
      else
        throw new w5("iterable", ["Iterable"], e);
      let p = new t({ objectMode: true, highWaterMark: 1, ...r }), m2 = false;
      p._read = function() {
        m2 || (m2 = true, M());
      }, p._destroy = function(x, S) {
        g5(y2(x), () => G1.nextTick(S, x), (E2) => G1.nextTick(S, E2 || x));
      };
      async function y2(x) {
        let S = x != null, E2 = typeof o.throw == "function";
        if (S && E2) {
          let { value: B, done: q2 } = await o.throw(x);
          if (await B, q2)
            return;
        }
        if (typeof o.return == "function") {
          let { value: B } = await o.return();
          await B;
        }
      }
      async function M() {
        for (;; ) {
          try {
            let { value: x, done: S } = f ? await o.next() : o.next();
            if (S)
              p.push(null);
            else {
              let E2 = x && typeof x.then == "function" ? await x : x;
              if (E2 === null)
                throw m2 = false, new M5;
              if (p.push(E2))
                continue;
              m2 = false;
            }
          } catch (x) {
            p.destroy(x);
          }
          break;
        }
      }
      return p;
    }
    J1.exports = _5;
  });
  ba = T2((KI, lv) => {
    var Tr = (Oi(), ur(pr)), { ArrayPrototypeIndexOf: x5, NumberIsInteger: S5, NumberIsNaN: E5, NumberParseInt: A5, ObjectDefineProperties: tv, ObjectKeys: R5, ObjectSetPrototypeOf: rv, Promise: B5, SafeSet: q5, SymbolAsyncIterator: I5, Symbol: T5 } = Tt();
    lv.exports = Le;
    Le.ReadableState = jh;
    var { EventEmitter: k5 } = ki(), { Stream: Hi, prependListener: L5 } = Vo(), { Buffer: Uh } = Ut(), { addAbortSignal: N5 } = Go(), D5 = Ui(), Pe = Gr().debuglog("stream", (t) => {
      Pe = t;
    }), P5 = Z1(), hf = yn(), { getHighWaterMark: C5, getDefaultHighWaterMark: O5 } = Xo(), { aggregateTwoErrors: Q1, codes: { ERR_INVALID_ARG_TYPE: F5, ERR_METHOD_NOT_IMPLEMENTED: U5, ERR_OUT_OF_RANGE: z5, ERR_STREAM_PUSH_AFTER_EOF: H5, ERR_STREAM_UNSHIFT_AFTER_END_EVENT: W5 } } = Jt(), { validateObject: K5 } = pa(), wn = T5("kPaused"), { StringDecoder: iv } = co(), j5 = Fh();
    rv(Le.prototype, Hi.prototype);
    rv(Le, Hi);
    var zh = () => {
    }, { errorOrDestroy: sf } = hf;
    function jh(t, e, r) {
      typeof r != "boolean" && (r = e instanceof Qr()), this.objectMode = !!(t && t.objectMode), r && (this.objectMode = this.objectMode || !!(t && t.readableObjectMode)), this.highWaterMark = t ? C5(this, t, "readableHighWaterMark", r) : O5(false), this.buffer = new P5, this.length = 0, this.pipes = [], this.flowing = null, this.ended = false, this.endEmitted = false, this.reading = false, this.constructed = true, this.sync = true, this.needReadable = false, this.emittedReadable = false, this.readableListening = false, this.resumeScheduled = false, this[wn] = null, this.errorEmitted = false, this.emitClose = !t || t.emitClose !== false, this.autoDestroy = !t || t.autoDestroy !== false, this.destroyed = false, this.errored = null, this.closed = false, this.closeEmitted = false, this.defaultEncoding = t && t.defaultEncoding || "utf8", this.awaitDrainWriters = null, this.multiAwaitDrain = false, this.readingMore = false, this.dataEmitted = false, this.decoder = null, this.encoding = null, t && t.encoding && (this.decoder = new iv(t.encoding), this.encoding = t.encoding);
    }
    function Le(t) {
      if (!(this instanceof Le))
        return new Le(t);
      let e = this instanceof Qr();
      this._readableState = new jh(t, this, e), t && (typeof t.read == "function" && (this._read = t.read), typeof t.destroy == "function" && (this._destroy = t.destroy), typeof t.construct == "function" && (this._construct = t.construct), t.signal && !e && N5(t.signal, this)), Hi.call(this, t), hf.construct(this, () => {
        this._readableState.needReadable && Jo(this, this._readableState);
      });
    }
    Le.prototype.destroy = hf.destroy;
    Le.prototype._undestroy = hf.undestroy;
    Le.prototype._destroy = function(t, e) {
      e(t);
    };
    Le.prototype[k5.captureRejectionSymbol] = function(t) {
      this.destroy(t);
    };
    Le.prototype.push = function(t, e) {
      return nv(this, t, e, false);
    };
    Le.prototype.unshift = function(t, e) {
      return nv(this, t, e, true);
    };
    function nv(t, e, r, o) {
      Pe("readableAddChunk", e);
      let f = t._readableState, p;
      if (f.objectMode || (typeof e == "string" ? (r = r || f.defaultEncoding, f.encoding !== r && (o && f.encoding ? e = Uh.from(e, r).toString(f.encoding) : (e = Uh.from(e, r), r = ""))) : e instanceof Uh ? r = "" : Hi._isUint8Array(e) ? (e = Hi._uint8ArrayToBuffer(e), r = "") : e != null && (p = new F5("chunk", ["string", "Buffer", "Uint8Array"], e))), p)
        sf(t, p);
      else if (e === null)
        f.reading = false, $5(t, f);
      else if (f.objectMode || e && e.length > 0)
        if (o)
          if (f.endEmitted)
            sf(t, new W5);
          else {
            if (f.destroyed || f.errored)
              return false;
            Hh(t, f, e, true);
          }
        else if (f.ended)
          sf(t, new H5);
        else {
          if (f.destroyed || f.errored)
            return false;
          f.reading = false, f.decoder && !r ? (e = f.decoder.write(e), f.objectMode || e.length !== 0 ? Hh(t, f, e, false) : Jo(t, f)) : Hh(t, f, e, false);
        }
      else
        o || (f.reading = false, Jo(t, f));
      return !f.ended && (f.length < f.highWaterMark || f.length === 0);
    }
    function Hh(t, e, r, o) {
      e.flowing && e.length === 0 && !e.sync && t.listenerCount("data") > 0 ? (e.multiAwaitDrain ? e.awaitDrainWriters.clear() : e.awaitDrainWriters = null, e.dataEmitted = true, t.emit("data", r)) : (e.length += e.objectMode ? 1 : r.length, o ? e.buffer.unshift(r) : e.buffer.push(r), e.needReadable && Qo(t)), Jo(t, e);
    }
    Le.prototype.isPaused = function() {
      let t = this._readableState;
      return t[wn] === true || t.flowing === false;
    };
    Le.prototype.setEncoding = function(t) {
      let e = new iv(t);
      this._readableState.decoder = e, this._readableState.encoding = this._readableState.decoder.encoding;
      let r = this._readableState.buffer, o = "";
      for (let f of r)
        o += e.write(f);
      return r.clear(), o !== "" && r.push(o), this._readableState.length = o.length, this;
    };
    var Z5 = 1073741824;
    function V5(t) {
      if (t > Z5)
        throw new z5("size", "<= 1GiB", t);
      return t--, t |= t >>> 1, t |= t >>> 2, t |= t >>> 4, t |= t >>> 8, t |= t >>> 16, t++, t;
    }
    function ev(t, e) {
      return t <= 0 || e.length === 0 && e.ended ? 0 : e.objectMode ? 1 : E5(t) ? e.flowing && e.length ? e.buffer.first().length : e.length : t <= e.length ? t : e.ended ? e.length : 0;
    }
    Le.prototype.read = function(t) {
      Pe("read", t), t === undefined ? t = NaN : S5(t) || (t = A5(t, 10));
      let e = this._readableState, r = t;
      if (t > e.highWaterMark && (e.highWaterMark = V5(t)), t !== 0 && (e.emittedReadable = false), t === 0 && e.needReadable && ((e.highWaterMark !== 0 ? e.length >= e.highWaterMark : e.length > 0) || e.ended))
        return Pe("read: emitReadable", e.length, e.ended), e.length === 0 && e.ended ? Wh(this) : Qo(this), null;
      if (t = ev(t, e), t === 0 && e.ended)
        return e.length === 0 && Wh(this), null;
      let o = e.needReadable;
      if (Pe("need readable", o), (e.length === 0 || e.length - t < e.highWaterMark) && (o = true, Pe("length less than watermark", o)), e.ended || e.reading || e.destroyed || e.errored || !e.constructed)
        o = false, Pe("reading, ended or constructing", o);
      else if (o) {
        Pe("do read"), e.reading = true, e.sync = true, e.length === 0 && (e.needReadable = true);
        try {
          this._read(e.highWaterMark);
        } catch (p) {
          sf(this, p);
        }
        e.sync = false, e.reading || (t = ev(r, e));
      }
      let f;
      return t > 0 ? f = hv(t, e) : f = null, f === null ? (e.needReadable = e.length <= e.highWaterMark, t = 0) : (e.length -= t, e.multiAwaitDrain ? e.awaitDrainWriters.clear() : e.awaitDrainWriters = null), e.length === 0 && (e.ended || (e.needReadable = true), r !== t && e.ended && Wh(this)), f !== null && !e.errorEmitted && !e.closeEmitted && (e.dataEmitted = true, this.emit("data", f)), f;
    };
    function $5(t, e) {
      if (Pe("onEofChunk"), !e.ended) {
        if (e.decoder) {
          let r = e.decoder.end();
          r && r.length && (e.buffer.push(r), e.length += e.objectMode ? 1 : r.length);
        }
        e.ended = true, e.sync ? Qo(t) : (e.needReadable = false, e.emittedReadable = true, fv(t));
      }
    }
    function Qo(t) {
      let e = t._readableState;
      Pe("emitReadable", e.needReadable, e.emittedReadable), e.needReadable = false, e.emittedReadable || (Pe("emitReadable", e.flowing), e.emittedReadable = true, Tr.nextTick(fv, t));
    }
    function fv(t) {
      let e = t._readableState;
      Pe("emitReadable_", e.destroyed, e.length, e.ended), !e.destroyed && !e.errored && (e.length || e.ended) && (t.emit("readable"), e.emittedReadable = false), e.needReadable = !e.flowing && !e.ended && e.length <= e.highWaterMark, ov(t);
    }
    function Jo(t, e) {
      !e.readingMore && e.constructed && (e.readingMore = true, Tr.nextTick(G5, t, e));
    }
    function G5(t, e) {
      for (;!e.reading && !e.ended && (e.length < e.highWaterMark || e.flowing && e.length === 0); ) {
        let r = e.length;
        if (Pe("maybeReadMore read 0"), t.read(0), r === e.length)
          break;
      }
      e.readingMore = false;
    }
    Le.prototype._read = function(t) {
      throw new U5("_read()");
    };
    Le.prototype.pipe = function(t, e) {
      let r = this, o = this._readableState;
      o.pipes.length === 1 && (o.multiAwaitDrain || (o.multiAwaitDrain = true, o.awaitDrainWriters = new q5(o.awaitDrainWriters ? [o.awaitDrainWriters] : []))), o.pipes.push(t), Pe("pipe count=%d opts=%j", o.pipes.length, e);
      let p = (!e || e.end !== false) && t !== Tr.stdout && t !== Tr.stderr ? y2 : _e;
      o.endEmitted ? Tr.nextTick(p) : r.once("end", p), t.on("unpipe", m2);
      function m2(N, we) {
        Pe("onunpipe"), N === r && we && we.hasUnpiped === false && (we.hasUnpiped = true, S());
      }
      function y2() {
        Pe("onend"), t.end();
      }
      let M, x = false;
      function S() {
        Pe("cleanup"), t.removeListener("close", L2), t.removeListener("finish", ge), M && t.removeListener("drain", M), t.removeListener("error", q2), t.removeListener("unpipe", m2), r.removeListener("end", y2), r.removeListener("end", _e), r.removeListener("data", B), x = true, M && o.awaitDrainWriters && (!t._writableState || t._writableState.needDrain) && M();
      }
      function E2() {
        x || (o.pipes.length === 1 && o.pipes[0] === t ? (Pe("false write response, pause", 0), o.awaitDrainWriters = t, o.multiAwaitDrain = false) : o.pipes.length > 1 && o.pipes.includes(t) && (Pe("false write response, pause", o.awaitDrainWriters.size), o.awaitDrainWriters.add(t)), r.pause()), M || (M = Y5(r, t), t.on("drain", M));
      }
      r.on("data", B);
      function B(N) {
        Pe("ondata");
        let we = t.write(N);
        Pe("dest.write", we), we === false && E2();
      }
      function q2(N) {
        if (Pe("onerror", N), _e(), t.removeListener("error", q2), t.listenerCount("error") === 0) {
          let we = t._writableState || t._readableState;
          we && !we.errorEmitted ? sf(t, N) : t.emit("error", N);
        }
      }
      L5(t, "error", q2);
      function L2() {
        t.removeListener("finish", ge), _e();
      }
      t.once("close", L2);
      function ge() {
        Pe("onfinish"), t.removeListener("close", L2), _e();
      }
      t.once("finish", ge);
      function _e() {
        Pe("unpipe"), r.unpipe(t);
      }
      return t.emit("pipe", r), t.writableNeedDrain === true ? o.flowing && E2() : o.flowing || (Pe("pipe resume"), r.resume()), t;
    };
    function Y5(t, e) {
      return function() {
        let o = t._readableState;
        o.awaitDrainWriters === e ? (Pe("pipeOnDrain", 1), o.awaitDrainWriters = null) : o.multiAwaitDrain && (Pe("pipeOnDrain", o.awaitDrainWriters.size), o.awaitDrainWriters.delete(e)), (!o.awaitDrainWriters || o.awaitDrainWriters.size === 0) && t.listenerCount("data") && t.resume();
      };
    }
    Le.prototype.unpipe = function(t) {
      let e = this._readableState, r = { hasUnpiped: false };
      if (e.pipes.length === 0)
        return this;
      if (!t) {
        let f = e.pipes;
        e.pipes = [], this.pause();
        for (let p = 0;p < f.length; p++)
          f[p].emit("unpipe", this, { hasUnpiped: false });
        return this;
      }
      let o = x5(e.pipes, t);
      return o === -1 ? this : (e.pipes.splice(o, 1), e.pipes.length === 0 && this.pause(), t.emit("unpipe", this, r), this);
    };
    Le.prototype.on = function(t, e) {
      let r = Hi.prototype.on.call(this, t, e), o = this._readableState;
      return t === "data" ? (o.readableListening = this.listenerCount("readable") > 0, o.flowing !== false && this.resume()) : t === "readable" && !o.endEmitted && !o.readableListening && (o.readableListening = o.needReadable = true, o.flowing = false, o.emittedReadable = false, Pe("on readable", o.length, o.reading), o.length ? Qo(this) : o.reading || Tr.nextTick(X5, this)), r;
    };
    Le.prototype.addListener = Le.prototype.on;
    Le.prototype.removeListener = function(t, e) {
      let r = Hi.prototype.removeListener.call(this, t, e);
      return t === "readable" && Tr.nextTick(av, this), r;
    };
    Le.prototype.off = Le.prototype.removeListener;
    Le.prototype.removeAllListeners = function(t) {
      let e = Hi.prototype.removeAllListeners.apply(this, arguments);
      return (t === "readable" || t === undefined) && Tr.nextTick(av, this), e;
    };
    function av(t) {
      let e = t._readableState;
      e.readableListening = t.listenerCount("readable") > 0, e.resumeScheduled && e[wn] === false ? e.flowing = true : t.listenerCount("data") > 0 ? t.resume() : e.readableListening || (e.flowing = null);
    }
    function X5(t) {
      Pe("readable nexttick read 0"), t.read(0);
    }
    Le.prototype.resume = function() {
      let t = this._readableState;
      return t.flowing || (Pe("resume"), t.flowing = !t.readableListening, J5(this, t)), t[wn] = false, this;
    };
    function J5(t, e) {
      e.resumeScheduled || (e.resumeScheduled = true, Tr.nextTick(Q5, t, e));
    }
    function Q5(t, e) {
      Pe("resume", e.reading), e.reading || t.read(0), e.resumeScheduled = false, t.emit("resume"), ov(t), e.flowing && !e.reading && t.read(0);
    }
    Le.prototype.pause = function() {
      return Pe("call pause flowing=%j", this._readableState.flowing), this._readableState.flowing !== false && (Pe("pause"), this._readableState.flowing = false, this.emit("pause")), this._readableState[wn] = true, this;
    };
    function ov(t) {
      let e = t._readableState;
      for (Pe("flow", e.flowing);e.flowing && t.read() !== null; )
        ;
    }
    Le.prototype.wrap = function(t) {
      let e = false;
      t.on("data", (o) => {
        !this.push(o) && t.pause && (e = true, t.pause());
      }), t.on("end", () => {
        this.push(null);
      }), t.on("error", (o) => {
        sf(this, o);
      }), t.on("close", () => {
        this.destroy();
      }), t.on("destroy", () => {
        this.destroy();
      }), this._read = () => {
        e && t.resume && (e = false, t.resume());
      };
      let r = R5(t);
      for (let o = 1;o < r.length; o++) {
        let f = r[o];
        this[f] === undefined && typeof t[f] == "function" && (this[f] = t[f].bind(t));
      }
      return this;
    };
    Le.prototype[I5] = function() {
      return sv(this);
    };
    Le.prototype.iterator = function(t) {
      return t !== undefined && K5(t, "options"), sv(this, t);
    };
    function sv(t, e) {
      typeof t.read != "function" && (t = Le.wrap(t, { objectMode: true }));
      let r = ex(t, e);
      return r.stream = t, r;
    }
    async function* ex(t, e) {
      let r = zh;
      function o(m2) {
        this === t ? (r(), r = zh) : r = m2;
      }
      t.on("readable", o);
      let f, p = D5(t, { writable: false }, (m2) => {
        f = m2 ? Q1(f, m2) : null, r(), r = zh;
      });
      try {
        for (;; ) {
          let m2 = t.destroyed ? null : t.read();
          if (m2 !== null)
            yield m2;
          else {
            if (f)
              throw f;
            if (f === null)
              return;
            await new B5(o);
          }
        }
      } catch (m2) {
        throw f = Q1(f, m2), f;
      } finally {
        (f || e?.destroyOnReturn !== false) && (f === undefined || t._readableState.autoDestroy) ? hf.destroyer(t, null) : (t.off("readable", o), p());
      }
    }
    tv(Le.prototype, { readable: { __proto__: null, get() {
      let t = this._readableState;
      return !!t && t.readable !== false && !t.destroyed && !t.errorEmitted && !t.endEmitted;
    }, set(t) {
      this._readableState && (this._readableState.readable = !!t);
    } }, readableDidRead: { __proto__: null, enumerable: false, get: function() {
      return this._readableState.dataEmitted;
    } }, readableAborted: { __proto__: null, enumerable: false, get: function() {
      return !!(this._readableState.readable !== false && (this._readableState.destroyed || this._readableState.errored) && !this._readableState.endEmitted);
    } }, readableHighWaterMark: { __proto__: null, enumerable: false, get: function() {
      return this._readableState.highWaterMark;
    } }, readableBuffer: { __proto__: null, enumerable: false, get: function() {
      return this._readableState && this._readableState.buffer;
    } }, readableFlowing: { __proto__: null, enumerable: false, get: function() {
      return this._readableState.flowing;
    }, set: function(t) {
      this._readableState && (this._readableState.flowing = t);
    } }, readableLength: { __proto__: null, enumerable: false, get() {
      return this._readableState.length;
    } }, readableObjectMode: { __proto__: null, enumerable: false, get() {
      return this._readableState ? this._readableState.objectMode : false;
    } }, readableEncoding: { __proto__: null, enumerable: false, get() {
      return this._readableState ? this._readableState.encoding : null;
    } }, errored: { __proto__: null, enumerable: false, get() {
      return this._readableState ? this._readableState.errored : null;
    } }, closed: { __proto__: null, get() {
      return this._readableState ? this._readableState.closed : false;
    } }, destroyed: { __proto__: null, enumerable: false, get() {
      return this._readableState ? this._readableState.destroyed : false;
    }, set(t) {
      !this._readableState || (this._readableState.destroyed = t);
    } }, readableEnded: { __proto__: null, enumerable: false, get() {
      return this._readableState ? this._readableState.endEmitted : false;
    } } });
    tv(jh.prototype, { pipesCount: { __proto__: null, get() {
      return this.pipes.length;
    } }, paused: { __proto__: null, get() {
      return this[wn] !== false;
    }, set(t) {
      this[wn] = !!t;
    } } });
    Le._fromList = hv;
    function hv(t, e) {
      if (e.length === 0)
        return null;
      let r;
      return e.objectMode ? r = e.buffer.shift() : !t || t >= e.length ? (e.decoder ? r = e.buffer.join("") : e.buffer.length === 1 ? r = e.buffer.first() : r = e.buffer.concat(e.length), e.buffer.clear()) : r = e.buffer.consume(t, e.decoder), r;
    }
    function Wh(t) {
      let e = t._readableState;
      Pe("endReadable", e.endEmitted), e.endEmitted || (e.ended = true, Tr.nextTick(tx, e, t));
    }
    function tx(t, e) {
      if (Pe("endReadableNT", t.endEmitted, t.length), !t.errored && !t.closeEmitted && !t.endEmitted && t.length === 0) {
        if (t.endEmitted = true, e.emit("end"), e.writable && e.allowHalfOpen === false)
          Tr.nextTick(rx, e);
        else if (t.autoDestroy) {
          let r = e._writableState;
          (!r || r.autoDestroy && (r.finished || r.writable === false)) && e.destroy();
        }
      }
    }
    function rx(t) {
      t.writable && !t.writableEnded && !t.destroyed && t.end();
    }
    Le.from = function(t, e) {
      return j5(Le, t, e);
    };
    var Kh;
    function uv() {
      return Kh === undefined && (Kh = {}), Kh;
    }
    Le.fromWeb = function(t, e) {
      return uv().newStreamReadableFromReadableStream(t, e);
    };
    Le.toWeb = function(t, e) {
      return uv().newReadableStreamFromStreamReadable(t, e);
    };
    Le.wrap = function(t, e) {
      var r, o;
      return new Le({ objectMode: (r = (o = t.readableObjectMode) !== null && o !== undefined ? o : t.objectMode) !== null && r !== undefined ? r : true, ...e, destroy(f, p) {
        hf.destroyer(t, f), p(f);
      } }).wrap(t);
    };
  });
  Jh = T2((jI, xv) => {
    var Mn = (Oi(), ur(pr)), { ArrayPrototypeSlice: pv, Error: ix, FunctionPrototypeSymbolHasInstance: vv, ObjectDefineProperty: bv, ObjectDefineProperties: nx, ObjectSetPrototypeOf: mv, StringPrototypeToLowerCase: fx, Symbol: ax, SymbolHasInstance: ox } = Tt();
    xv.exports = st;
    st.WritableState = ya;
    var { EventEmitter: sx } = ki(), ma = Vo().Stream, { Buffer: es } = Ut(), is = yn(), { addAbortSignal: hx } = Go(), { getHighWaterMark: ux, getDefaultHighWaterMark: lx } = Xo(), { ERR_INVALID_ARG_TYPE: dx, ERR_METHOD_NOT_IMPLEMENTED: cx, ERR_MULTIPLE_CALLBACK: gv, ERR_STREAM_CANNOT_PIPE: px, ERR_STREAM_DESTROYED: ga, ERR_STREAM_ALREADY_FINISHED: vx, ERR_STREAM_NULL_VALUES: bx, ERR_STREAM_WRITE_AFTER_END: mx, ERR_UNKNOWN_ENCODING: yv } = Jt().codes, { errorOrDestroy: uf } = is;
    mv(st.prototype, ma.prototype);
    mv(st, ma);
    function $h() {
    }
    var lf = ax("kOnFinished");
    function ya(t, e, r) {
      typeof r != "boolean" && (r = e instanceof Qr()), this.objectMode = !!(t && t.objectMode), r && (this.objectMode = this.objectMode || !!(t && t.writableObjectMode)), this.highWaterMark = t ? ux(this, t, "writableHighWaterMark", r) : lx(false), this.finalCalled = false, this.needDrain = false, this.ending = false, this.ended = false, this.finished = false, this.destroyed = false;
      let o = !!(t && t.decodeStrings === false);
      this.decodeStrings = !o, this.defaultEncoding = t && t.defaultEncoding || "utf8", this.length = 0, this.writing = false, this.corked = 0, this.sync = true, this.bufferProcessing = false, this.onwrite = yx.bind(undefined, e), this.writecb = null, this.writelen = 0, this.afterWriteTickInfo = null, rs(this), this.pendingcb = 0, this.constructed = true, this.prefinished = false, this.errorEmitted = false, this.emitClose = !t || t.emitClose !== false, this.autoDestroy = !t || t.autoDestroy !== false, this.errored = null, this.closed = false, this.closeEmitted = false, this[lf] = [];
    }
    function rs(t) {
      t.buffered = [], t.bufferedIndex = 0, t.allBuffers = true, t.allNoop = true;
    }
    ya.prototype.getBuffer = function() {
      return pv(this.buffered, this.bufferedIndex);
    };
    bv(ya.prototype, "bufferedRequestCount", { __proto__: null, get() {
      return this.buffered.length - this.bufferedIndex;
    } });
    function st(t) {
      let e = this instanceof Qr();
      if (!e && !vv(st, this))
        return new st(t);
      this._writableState = new ya(t, this, e), t && (typeof t.write == "function" && (this._write = t.write), typeof t.writev == "function" && (this._writev = t.writev), typeof t.destroy == "function" && (this._destroy = t.destroy), typeof t.final == "function" && (this._final = t.final), typeof t.construct == "function" && (this._construct = t.construct), t.signal && hx(t.signal, this)), ma.call(this, t), is.construct(this, () => {
        let r = this._writableState;
        r.writing || Yh(this, r), Xh(this, r);
      });
    }
    bv(st, ox, { __proto__: null, value: function(t) {
      return vv(this, t) ? true : this !== st ? false : t && t._writableState instanceof ya;
    } });
    st.prototype.pipe = function() {
      uf(this, new px);
    };
    function wv(t, e, r, o) {
      let f = t._writableState;
      if (typeof r == "function")
        o = r, r = f.defaultEncoding;
      else {
        if (!r)
          r = f.defaultEncoding;
        else if (r !== "buffer" && !es.isEncoding(r))
          throw new yv(r);
        typeof o != "function" && (o = $h);
      }
      if (e === null)
        throw new bx;
      if (!f.objectMode)
        if (typeof e == "string")
          f.decodeStrings !== false && (e = es.from(e, r), r = "buffer");
        else if (e instanceof es)
          r = "buffer";
        else if (ma._isUint8Array(e))
          e = ma._uint8ArrayToBuffer(e), r = "buffer";
        else
          throw new dx("chunk", ["string", "Buffer", "Uint8Array"], e);
      let p;
      return f.ending ? p = new mx : f.destroyed && (p = new ga("write")), p ? (Mn.nextTick(o, p), uf(t, p, true), p) : (f.pendingcb++, gx(t, f, e, r, o));
    }
    st.prototype.write = function(t, e, r) {
      return wv(this, t, e, r) === true;
    };
    st.prototype.cork = function() {
      this._writableState.corked++;
    };
    st.prototype.uncork = function() {
      let t = this._writableState;
      t.corked && (t.corked--, t.writing || Yh(this, t));
    };
    st.prototype.setDefaultEncoding = function(e) {
      if (typeof e == "string" && (e = fx(e)), !es.isEncoding(e))
        throw new yv(e);
      return this._writableState.defaultEncoding = e, this;
    };
    function gx(t, e, r, o, f) {
      let p = e.objectMode ? 1 : r.length;
      e.length += p;
      let m2 = e.length < e.highWaterMark;
      return m2 || (e.needDrain = true), e.writing || e.corked || e.errored || !e.constructed ? (e.buffered.push({ chunk: r, encoding: o, callback: f }), e.allBuffers && o !== "buffer" && (e.allBuffers = false), e.allNoop && f !== $h && (e.allNoop = false)) : (e.writelen = p, e.writecb = f, e.writing = true, e.sync = true, t._write(r, o, e.onwrite), e.sync = false), m2 && !e.errored && !e.destroyed;
    }
    function dv(t, e, r, o, f, p, m2) {
      e.writelen = o, e.writecb = m2, e.writing = true, e.sync = true, e.destroyed ? e.onwrite(new ga("write")) : r ? t._writev(f, e.onwrite) : t._write(f, p, e.onwrite), e.sync = false;
    }
    function cv(t, e, r, o) {
      --e.pendingcb, o(r), Gh(e), uf(t, r);
    }
    function yx(t, e) {
      let r = t._writableState, o = r.sync, f = r.writecb;
      if (typeof f != "function") {
        uf(t, new gv);
        return;
      }
      r.writing = false, r.writecb = null, r.length -= r.writelen, r.writelen = 0, e ? (e.stack, r.errored || (r.errored = e), t._readableState && !t._readableState.errored && (t._readableState.errored = e), o ? Mn.nextTick(cv, t, r, e, f) : cv(t, r, e, f)) : (r.buffered.length > r.bufferedIndex && Yh(t, r), o ? r.afterWriteTickInfo !== null && r.afterWriteTickInfo.cb === f ? r.afterWriteTickInfo.count++ : (r.afterWriteTickInfo = { count: 1, cb: f, stream: t, state: r }, Mn.nextTick(wx, r.afterWriteTickInfo)) : Mv(t, r, 1, f));
    }
    function wx({ stream: t, state: e, count: r, cb: o }) {
      return e.afterWriteTickInfo = null, Mv(t, e, r, o);
    }
    function Mv(t, e, r, o) {
      for (!e.ending && !t.destroyed && e.length === 0 && e.needDrain && (e.needDrain = false, t.emit("drain"));r-- > 0; )
        e.pendingcb--, o();
      e.destroyed && Gh(e), Xh(t, e);
    }
    function Gh(t) {
      if (t.writing)
        return;
      for (let f = t.bufferedIndex;f < t.buffered.length; ++f) {
        var e;
        let { chunk: p, callback: m2 } = t.buffered[f], y2 = t.objectMode ? 1 : p.length;
        t.length -= y2, m2((e = t.errored) !== null && e !== undefined ? e : new ga("write"));
      }
      let r = t[lf].splice(0);
      for (let f = 0;f < r.length; f++) {
        var o;
        r[f]((o = t.errored) !== null && o !== undefined ? o : new ga("end"));
      }
      rs(t);
    }
    function Yh(t, e) {
      if (e.corked || e.bufferProcessing || e.destroyed || !e.constructed)
        return;
      let { buffered: r, bufferedIndex: o, objectMode: f } = e, p = r.length - o;
      if (!p)
        return;
      let m2 = o;
      if (e.bufferProcessing = true, p > 1 && t._writev) {
        e.pendingcb -= p - 1;
        let y2 = e.allNoop ? $h : (x) => {
          for (let S = m2;S < r.length; ++S)
            r[S].callback(x);
        }, M = e.allNoop && m2 === 0 ? r : pv(r, m2);
        M.allBuffers = e.allBuffers, dv(t, e, true, e.length, M, "", y2), rs(e);
      } else {
        do {
          let { chunk: y2, encoding: M, callback: x } = r[m2];
          r[m2++] = null;
          let S = f ? 1 : y2.length;
          dv(t, e, false, S, y2, M, x);
        } while (m2 < r.length && !e.writing);
        m2 === r.length ? rs(e) : m2 > 256 ? (r.splice(0, m2), e.bufferedIndex = 0) : e.bufferedIndex = m2;
      }
      e.bufferProcessing = false;
    }
    st.prototype._write = function(t, e, r) {
      if (this._writev)
        this._writev([{ chunk: t, encoding: e }], r);
      else
        throw new cx("_write()");
    };
    st.prototype._writev = null;
    st.prototype.end = function(t, e, r) {
      let o = this._writableState;
      typeof t == "function" ? (r = t, t = null, e = null) : typeof e == "function" && (r = e, e = null);
      let f;
      if (t != null) {
        let p = wv(this, t, e);
        p instanceof ix && (f = p);
      }
      return o.corked && (o.corked = 1, this.uncork()), f || (!o.errored && !o.ending ? (o.ending = true, Xh(this, o, true), o.ended = true) : o.finished ? f = new vx("end") : o.destroyed && (f = new ga("end"))), typeof r == "function" && (f || o.finished ? Mn.nextTick(r, f) : o[lf].push(r)), this;
    };
    function ts(t) {
      return t.ending && !t.destroyed && t.constructed && t.length === 0 && !t.errored && t.buffered.length === 0 && !t.finished && !t.writing && !t.errorEmitted && !t.closeEmitted;
    }
    function Mx(t, e) {
      let r = false;
      function o(f) {
        if (r) {
          uf(t, f ?? gv());
          return;
        }
        if (r = true, e.pendingcb--, f) {
          let p = e[lf].splice(0);
          for (let m2 = 0;m2 < p.length; m2++)
            p[m2](f);
          uf(t, f, e.sync);
        } else
          ts(e) && (e.prefinished = true, t.emit("prefinish"), e.pendingcb++, Mn.nextTick(Vh, t, e));
      }
      e.sync = true, e.pendingcb++;
      try {
        t._final(o);
      } catch (f) {
        o(f);
      }
      e.sync = false;
    }
    function _x(t, e) {
      !e.prefinished && !e.finalCalled && (typeof t._final == "function" && !e.destroyed ? (e.finalCalled = true, Mx(t, e)) : (e.prefinished = true, t.emit("prefinish")));
    }
    function Xh(t, e, r) {
      ts(e) && (_x(t, e), e.pendingcb === 0 && (r ? (e.pendingcb++, Mn.nextTick((o, f) => {
        ts(f) ? Vh(o, f) : f.pendingcb--;
      }, t, e)) : ts(e) && (e.pendingcb++, Vh(t, e))));
    }
    function Vh(t, e) {
      e.pendingcb--, e.finished = true;
      let r = e[lf].splice(0);
      for (let o = 0;o < r.length; o++)
        r[o]();
      if (t.emit("finish"), e.autoDestroy) {
        let o = t._readableState;
        (!o || o.autoDestroy && (o.endEmitted || o.readable === false)) && t.destroy();
      }
    }
    nx(st.prototype, { closed: { __proto__: null, get() {
      return this._writableState ? this._writableState.closed : false;
    } }, destroyed: { __proto__: null, get() {
      return this._writableState ? this._writableState.destroyed : false;
    }, set(t) {
      this._writableState && (this._writableState.destroyed = t);
    } }, writable: { __proto__: null, get() {
      let t = this._writableState;
      return !!t && t.writable !== false && !t.destroyed && !t.errored && !t.ending && !t.ended;
    }, set(t) {
      this._writableState && (this._writableState.writable = !!t);
    } }, writableFinished: { __proto__: null, get() {
      return this._writableState ? this._writableState.finished : false;
    } }, writableObjectMode: { __proto__: null, get() {
      return this._writableState ? this._writableState.objectMode : false;
    } }, writableBuffer: { __proto__: null, get() {
      return this._writableState && this._writableState.getBuffer();
    } }, writableEnded: { __proto__: null, get() {
      return this._writableState ? this._writableState.ending : false;
    } }, writableNeedDrain: { __proto__: null, get() {
      let t = this._writableState;
      return t ? !t.destroyed && !t.ending && t.needDrain : false;
    } }, writableHighWaterMark: { __proto__: null, get() {
      return this._writableState && this._writableState.highWaterMark;
    } }, writableCorked: { __proto__: null, get() {
      return this._writableState ? this._writableState.corked : 0;
    } }, writableLength: { __proto__: null, get() {
      return this._writableState && this._writableState.length;
    } }, errored: { __proto__: null, enumerable: false, get() {
      return this._writableState ? this._writableState.errored : null;
    } }, writableAborted: { __proto__: null, enumerable: false, get: function() {
      return !!(this._writableState.writable !== false && (this._writableState.destroyed || this._writableState.errored) && !this._writableState.finished);
    } } });
    var xx = is.destroy;
    st.prototype.destroy = function(t, e) {
      let r = this._writableState;
      return !r.destroyed && (r.bufferedIndex < r.buffered.length || r[lf].length) && Mn.nextTick(Gh, r), xx.call(this, t, e), this;
    };
    st.prototype._undestroy = is.undestroy;
    st.prototype._destroy = function(t, e) {
      e(t);
    };
    st.prototype[sx.captureRejectionSymbol] = function(t) {
      this.destroy(t);
    };
    var Zh;
    function _v() {
      return Zh === undefined && (Zh = {}), Zh;
    }
    st.fromWeb = function(t, e) {
      return _v().newStreamWritableFromWritableStream(t, e);
    };
    st.toWeb = function(t) {
      return _v().newWritableStreamFromStreamWritable(t);
    };
  });
  Dv = T2((ZI, Nv) => {
    var Qh = (Oi(), ur(pr)), Sx = Ut(), { isReadable: Ex, isWritable: Ax, isIterable: Sv, isNodeStream: Rx, isReadableNodeStream: Ev, isWritableNodeStream: Av, isDuplexNodeStream: Bx } = Fi(), Rv = Ui(), { AbortError: Lv, codes: { ERR_INVALID_ARG_TYPE: qx, ERR_INVALID_RETURN_VALUE: Bv } } = Jt(), { destroyer: df } = yn(), Ix = Qr(), Tx = ba(), { createDeferredPromise: qv } = Gr(), Iv = Fh(), Tv = globalThis.Blob || Sx.Blob, kx = typeof Tv < "u" ? function(e) {
      return e instanceof Tv;
    } : function(e) {
      return false;
    }, Lx = globalThis.AbortController || No().AbortController, { FunctionPrototypeCall: kv } = Tt(), _n = class extends Ix {
      constructor(e) {
        super(e), e?.readable === false && (this._readableState.readable = false, this._readableState.ended = true, this._readableState.endEmitted = true), e?.writable === false && (this._writableState.writable = false, this._writableState.ending = true, this._writableState.ended = true, this._writableState.finished = true);
      }
    };
    Nv.exports = function t(e, r) {
      if (Bx(e))
        return e;
      if (Ev(e))
        return ns({ readable: e });
      if (Av(e))
        return ns({ writable: e });
      if (Rx(e))
        return ns({ writable: false, readable: false });
      if (typeof e == "function") {
        let { value: f, write: p, final: m2, destroy: y2 } = Nx(e);
        if (Sv(f))
          return Iv(_n, f, { objectMode: true, write: p, final: m2, destroy: y2 });
        let M = f?.then;
        if (typeof M == "function") {
          let x, S = kv(M, f, (E2) => {
            if (E2 != null)
              throw new Bv("nully", "body", E2);
          }, (E2) => {
            df(x, E2);
          });
          return x = new _n({ objectMode: true, readable: false, write: p, final(E2) {
            m2(async () => {
              try {
                await S, Qh.nextTick(E2, null);
              } catch (B) {
                Qh.nextTick(E2, B);
              }
            });
          }, destroy: y2 });
        }
        throw new Bv("Iterable, AsyncIterable or AsyncFunction", r, f);
      }
      if (kx(e))
        return t(e.arrayBuffer());
      if (Sv(e))
        return Iv(_n, e, { objectMode: true, writable: false });
      if (typeof e?.writable == "object" || typeof e?.readable == "object") {
        let f = e != null && e.readable ? Ev(e?.readable) ? e?.readable : t(e.readable) : undefined, p = e != null && e.writable ? Av(e?.writable) ? e?.writable : t(e.writable) : undefined;
        return ns({ readable: f, writable: p });
      }
      let o = e?.then;
      if (typeof o == "function") {
        let f;
        return kv(o, e, (p) => {
          p != null && f.push(p), f.push(null);
        }, (p) => {
          df(f, p);
        }), f = new _n({ objectMode: true, writable: false, read() {
        } });
      }
      throw new qx(r, ["Blob", "ReadableStream", "WritableStream", "Stream", "Iterable", "AsyncIterable", "Function", "{ readable, writable } pair", "Promise"], e);
    };
    function Nx(t) {
      let { promise: e, resolve: r } = qv(), o = new Lx, f = o.signal;
      return { value: t(async function* () {
        for (;; ) {
          let m2 = e;
          e = null;
          let { chunk: y2, done: M, cb: x } = await m2;
          if (Qh.nextTick(x), M)
            return;
          if (f.aborted)
            throw new Lv(undefined, { cause: f.reason });
          ({ promise: e, resolve: r } = qv()), yield y2;
        }
      }(), { signal: f }), write(m2, y2, M) {
        let x = r;
        r = null, x({ chunk: m2, done: false, cb: M });
      }, final(m2) {
        let y2 = r;
        r = null, y2({ done: true, cb: m2 });
      }, destroy(m2, y2) {
        o.abort(), y2(m2);
      } };
    }
    function ns(t) {
      let e = t.readable && typeof t.readable.read != "function" ? Tx.wrap(t.readable) : t.readable, r = t.writable, o = !!Ex(e), f = !!Ax(r), p, m2, y2, M, x;
      function S(E2) {
        let B = M;
        M = null, B ? B(E2) : E2 ? x.destroy(E2) : !o && !f && x.destroy();
      }
      return x = new _n({ readableObjectMode: !!(e != null && e.readableObjectMode), writableObjectMode: !!(r != null && r.writableObjectMode), readable: o, writable: f }), f && (Rv(r, (E2) => {
        f = false, E2 && df(e, E2), S(E2);
      }), x._write = function(E2, B, q2) {
        r.write(E2, B) ? q2() : p = q2;
      }, x._final = function(E2) {
        r.end(), m2 = E2;
      }, r.on("drain", function() {
        if (p) {
          let E2 = p;
          p = null, E2();
        }
      }), r.on("finish", function() {
        if (m2) {
          let E2 = m2;
          m2 = null, E2();
        }
      })), o && (Rv(e, (E2) => {
        o = false, E2 && df(e, E2), S(E2);
      }), e.on("readable", function() {
        if (y2) {
          let E2 = y2;
          y2 = null, E2();
        }
      }), e.on("end", function() {
        x.push(null);
      }), x._read = function() {
        for (;; ) {
          let E2 = e.read();
          if (E2 === null) {
            y2 = x._read;
            return;
          }
          if (!x.push(E2))
            return;
        }
      }), x._destroy = function(E2, B) {
        !E2 && M !== null && (E2 = new Lv), y2 = null, p = null, m2 = null, M === null ? B(E2) : (M = B, df(r, E2), df(e, E2));
      }, x;
    }
  });
  Qr = T2((VI, Ov) => {
    var { ObjectDefineProperties: Dx, ObjectGetOwnPropertyDescriptor: bi, ObjectKeys: Px, ObjectSetPrototypeOf: Pv } = Tt();
    Ov.exports = kr;
    var ru = ba(), vr = Jh();
    Pv(kr.prototype, ru.prototype);
    Pv(kr, ru);
    {
      let t = Px(vr.prototype);
      for (let e = 0;e < t.length; e++) {
        let r = t[e];
        kr.prototype[r] || (kr.prototype[r] = vr.prototype[r]);
      }
    }
    function kr(t) {
      if (!(this instanceof kr))
        return new kr(t);
      ru.call(this, t), vr.call(this, t), t ? (this.allowHalfOpen = t.allowHalfOpen !== false, t.readable === false && (this._readableState.readable = false, this._readableState.ended = true, this._readableState.endEmitted = true), t.writable === false && (this._writableState.writable = false, this._writableState.ending = true, this._writableState.ended = true, this._writableState.finished = true)) : this.allowHalfOpen = true;
    }
    Dx(kr.prototype, { writable: { __proto__: null, ...bi(vr.prototype, "writable") }, writableHighWaterMark: { __proto__: null, ...bi(vr.prototype, "writableHighWaterMark") }, writableObjectMode: { __proto__: null, ...bi(vr.prototype, "writableObjectMode") }, writableBuffer: { __proto__: null, ...bi(vr.prototype, "writableBuffer") }, writableLength: { __proto__: null, ...bi(vr.prototype, "writableLength") }, writableFinished: { __proto__: null, ...bi(vr.prototype, "writableFinished") }, writableCorked: { __proto__: null, ...bi(vr.prototype, "writableCorked") }, writableEnded: { __proto__: null, ...bi(vr.prototype, "writableEnded") }, writableNeedDrain: { __proto__: null, ...bi(vr.prototype, "writableNeedDrain") }, destroyed: { __proto__: null, get() {
      return this._readableState === undefined || this._writableState === undefined ? false : this._readableState.destroyed && this._writableState.destroyed;
    }, set(t) {
      this._readableState && this._writableState && (this._readableState.destroyed = t, this._writableState.destroyed = t);
    } } });
    var eu;
    function Cv() {
      return eu === undefined && (eu = {}), eu;
    }
    kr.fromWeb = function(t, e) {
      return Cv().newStreamDuplexFromReadableWritablePair(t, e);
    };
    kr.toWeb = function(t) {
      return Cv().newReadableWritablePairFromDuplex(t);
    };
    var tu;
    kr.from = function(t) {
      return tu || (tu = Dv()), tu(t, "body");
    };
  });
  fu = T2(($I, Uv) => {
    var { ObjectSetPrototypeOf: Fv, Symbol: Cx } = Tt();
    Uv.exports = mi;
    var { ERR_METHOD_NOT_IMPLEMENTED: Ox } = Jt().codes, nu = Qr(), { getHighWaterMark: Fx } = Xo();
    Fv(mi.prototype, nu.prototype);
    Fv(mi, nu);
    var wa = Cx("kCallback");
    function mi(t) {
      if (!(this instanceof mi))
        return new mi(t);
      let e = t ? Fx(this, t, "readableHighWaterMark", true) : null;
      e === 0 && (t = { ...t, highWaterMark: null, readableHighWaterMark: e, writableHighWaterMark: t.writableHighWaterMark || 0 }), nu.call(this, t), this._readableState.sync = false, this[wa] = null, t && (typeof t.transform == "function" && (this._transform = t.transform), typeof t.flush == "function" && (this._flush = t.flush)), this.on("prefinish", Ux);
    }
    function iu(t) {
      typeof this._flush == "function" && !this.destroyed ? this._flush((e, r) => {
        if (e) {
          t ? t(e) : this.destroy(e);
          return;
        }
        r != null && this.push(r), this.push(null), t && t();
      }) : (this.push(null), t && t());
    }
    function Ux() {
      this._final !== iu && iu.call(this);
    }
    mi.prototype._final = iu;
    mi.prototype._transform = function(t, e, r) {
      throw new Ox("_transform()");
    };
    mi.prototype._write = function(t, e, r) {
      let o = this._readableState, f = this._writableState, p = o.length;
      this._transform(t, e, (m2, y2) => {
        if (m2) {
          r(m2);
          return;
        }
        y2 != null && this.push(y2), f.ended || p === o.length || o.length < o.highWaterMark ? r() : this[wa] = r;
      });
    };
    mi.prototype._read = function() {
      if (this[wa]) {
        let t = this[wa];
        this[wa] = null, t();
      }
    };
  });
  ou = T2((GI, Hv) => {
    var { ObjectSetPrototypeOf: zv } = Tt();
    Hv.exports = cf;
    var au = fu();
    zv(cf.prototype, au.prototype);
    zv(cf, au);
    function cf(t) {
      if (!(this instanceof cf))
        return new cf(t);
      au.call(this, t);
    }
    cf.prototype._transform = function(t, e, r) {
      r(null, t);
    };
  });
  os = T2((YI, Gv) => {
    var fs = (Oi(), ur(pr)), { ArrayIsArray: zx, Promise: Hx, SymbolAsyncIterator: Wx } = Tt(), as = Ui(), { once: Kx } = Gr(), jx = yn(), Wv = Qr(), { aggregateTwoErrors: Zx, codes: { ERR_INVALID_ARG_TYPE: Vv, ERR_INVALID_RETURN_VALUE: su, ERR_MISSING_ARGS: Vx, ERR_STREAM_DESTROYED: $x, ERR_STREAM_PREMATURE_CLOSE: Gx }, AbortError: Yx } = Jt(), { validateFunction: Xx, validateAbortSignal: Jx } = pa(), { isIterable: pf, isReadable: hu, isReadableNodeStream: du, isNodeStream: Kv } = Fi(), Qx = globalThis.AbortController || No().AbortController, uu, lu;
    function jv(t, e, r) {
      let o = false;
      t.on("close", () => {
        o = true;
      });
      let f = as(t, { readable: e, writable: r }, (p) => {
        o = !p;
      });
      return { destroy: (p) => {
        o || (o = true, jx.destroyer(t, p || new $x("pipe")));
      }, cleanup: f };
    }
    function e7(t) {
      return Xx(t[t.length - 1], "streams[stream.length - 1]"), t.pop();
    }
    function t7(t) {
      if (pf(t))
        return t;
      if (du(t))
        return r7(t);
      throw new Vv("val", ["Readable", "Iterable", "AsyncIterable"], t);
    }
    async function* r7(t) {
      lu || (lu = ba()), yield* lu.prototype[Wx].call(t);
    }
    async function Zv(t, e, r, { end: o }) {
      let f, p = null, m2 = (x) => {
        if (x && (f = x), p) {
          let S = p;
          p = null, S();
        }
      }, y2 = () => new Hx((x, S) => {
        f ? S(f) : p = () => {
          f ? S(f) : x();
        };
      });
      e.on("drain", m2);
      let M = as(e, { readable: false }, m2);
      try {
        e.writableNeedDrain && await y2();
        for await (let x of t)
          e.write(x) || await y2();
        o && e.end(), await y2(), r();
      } catch (x) {
        r(f !== x ? Zx(f, x) : x);
      } finally {
        M(), e.off("drain", m2);
      }
    }
    function i7(...t) {
      return $v(t, Kx(e7(t)));
    }
    function $v(t, e, r) {
      if (t.length === 1 && zx(t[0]) && (t = t[0]), t.length < 2)
        throw new Vx("streams");
      let o = new Qx, f = o.signal, p = r?.signal, m2 = [];
      Jx(p, "options.signal");
      function y2() {
        q2(new Yx);
      }
      p?.addEventListener("abort", y2);
      let M, x, S = [], E2 = 0;
      function B(N) {
        q2(N, --E2 === 0);
      }
      function q2(N, we) {
        if (N && (!M || M.code === "ERR_STREAM_PREMATURE_CLOSE") && (M = N), !(!M && !we)) {
          for (;S.length; )
            S.shift()(M);
          p?.removeEventListener("abort", y2), o.abort(), we && (M || m2.forEach((ye) => ye()), fs.nextTick(e, M, x));
        }
      }
      let L2;
      for (let N = 0;N < t.length; N++) {
        let we = t[N], ye = N < t.length - 1, xe = N > 0, Re = ye || r?.end !== false, Ee = N === t.length - 1;
        if (Kv(we)) {
          let Ae = function(P) {
            P && P.name !== "AbortError" && P.code !== "ERR_STREAM_PREMATURE_CLOSE" && B(P);
          };
          var _e = Ae;
          if (Re) {
            let { destroy: P, cleanup: Se } = jv(we, ye, xe);
            S.push(P), hu(we) && Ee && m2.push(Se);
          }
          we.on("error", Ae), hu(we) && Ee && m2.push(() => {
            we.removeListener("error", Ae);
          });
        }
        if (N === 0)
          if (typeof we == "function") {
            if (L2 = we({ signal: f }), !pf(L2))
              throw new su("Iterable, AsyncIterable or Stream", "source", L2);
          } else
            pf(we) || du(we) ? L2 = we : L2 = Wv.from(we);
        else if (typeof we == "function")
          if (L2 = t7(L2), L2 = we(L2, { signal: f }), ye) {
            if (!pf(L2, true))
              throw new su("AsyncIterable", `transform[${N - 1}]`, L2);
          } else {
            var ge;
            uu || (uu = ou());
            let Ae = new uu({ objectMode: true }), P = (ge = L2) === null || ge === undefined ? undefined : ge.then;
            if (typeof P == "function")
              E2++, P.call(L2, (i) => {
                x = i, i != null && Ae.write(i), Re && Ae.end(), fs.nextTick(B);
              }, (i) => {
                Ae.destroy(i), fs.nextTick(B, i);
              });
            else if (pf(L2, true))
              E2++, Zv(L2, Ae, B, { end: Re });
            else
              throw new su("AsyncIterable or Promise", "destination", L2);
            L2 = Ae;
            let { destroy: Se, cleanup: v } = jv(L2, false, true);
            S.push(Se), Ee && m2.push(v);
          }
        else if (Kv(we)) {
          if (du(L2)) {
            E2 += 2;
            let Ae = n7(L2, we, B, { end: Re });
            hu(we) && Ee && m2.push(Ae);
          } else if (pf(L2))
            E2++, Zv(L2, we, B, { end: Re });
          else
            throw new Vv("val", ["Readable", "Iterable", "AsyncIterable"], L2);
          L2 = we;
        } else
          L2 = Wv.from(we);
      }
      return (f != null && f.aborted || p != null && p.aborted) && fs.nextTick(y2), L2;
    }
    function n7(t, e, r, { end: o }) {
      let f = false;
      return e.on("close", () => {
        f || r(new Gx);
      }), t.pipe(e, { end: o }), o ? t.once("end", () => {
        f = true, e.end();
      }) : r(), as(t, { readable: true, writable: false }, (p) => {
        let m2 = t._readableState;
        p && p.code === "ERR_STREAM_PREMATURE_CLOSE" && m2 && m2.ended && !m2.errored && !m2.errorEmitted ? t.once("end", r).once("error", r) : r(p);
      }), as(e, { readable: false, writable: true }, r);
    }
    Gv.exports = { pipelineImpl: $v, pipeline: i7 };
  });
  eb = T2((XI, Qv) => {
    var { pipeline: f7 } = os(), ss = Qr(), { destroyer: a7 } = yn(), { isNodeStream: o7, isReadable: Yv, isWritable: Xv } = Fi(), { AbortError: s7, codes: { ERR_INVALID_ARG_VALUE: Jv, ERR_MISSING_ARGS: h7 } } = Jt();
    Qv.exports = function(...e) {
      if (e.length === 0)
        throw new h7("streams");
      if (e.length === 1)
        return ss.from(e[0]);
      let r = [...e];
      if (typeof e[0] == "function" && (e[0] = ss.from(e[0])), typeof e[e.length - 1] == "function") {
        let q2 = e.length - 1;
        e[q2] = ss.from(e[q2]);
      }
      for (let q2 = 0;q2 < e.length; ++q2)
        if (!!o7(e[q2])) {
          if (q2 < e.length - 1 && !Yv(e[q2]))
            throw new Jv(`streams[${q2}]`, r[q2], "must be readable");
          if (q2 > 0 && !Xv(e[q2]))
            throw new Jv(`streams[${q2}]`, r[q2], "must be writable");
        }
      let o, f, p, m2, y2;
      function M(q2) {
        let L2 = m2;
        m2 = null, L2 ? L2(q2) : q2 ? y2.destroy(q2) : !B && !E2 && y2.destroy();
      }
      let x = e[0], S = f7(e, M), E2 = !!Xv(x), B = !!Yv(S);
      return y2 = new ss({ writableObjectMode: !!(x != null && x.writableObjectMode), readableObjectMode: !!(S != null && S.writableObjectMode), writable: E2, readable: B }), E2 && (y2._write = function(q2, L2, ge) {
        x.write(q2, L2) ? ge() : o = ge;
      }, y2._final = function(q2) {
        x.end(), f = q2;
      }, x.on("drain", function() {
        if (o) {
          let q2 = o;
          o = null, q2();
        }
      }), S.on("finish", function() {
        if (f) {
          let q2 = f;
          f = null, q2();
        }
      })), B && (S.on("readable", function() {
        if (p) {
          let q2 = p;
          p = null, q2();
        }
      }), S.on("end", function() {
        y2.push(null);
      }), y2._read = function() {
        for (;; ) {
          let q2 = S.read();
          if (q2 === null) {
            p = y2._read;
            return;
          }
          if (!y2.push(q2))
            return;
        }
      }), y2._destroy = function(q2, L2) {
        !q2 && m2 !== null && (q2 = new s7), p = null, o = null, f = null, m2 === null ? L2(q2) : (m2 = L2, a7(S, q2));
      }, y2;
    };
  });
  cu = T2((JI, tb) => {
    var { ArrayPrototypePop: u7, Promise: l7 } = Tt(), { isIterable: d7, isNodeStream: c7 } = Fi(), { pipelineImpl: p7 } = os(), { finished: v7 } = Ui();
    function b7(...t) {
      return new l7((e, r) => {
        let o, f, p = t[t.length - 1];
        if (p && typeof p == "object" && !c7(p) && !d7(p)) {
          let m2 = u7(t);
          o = m2.signal, f = m2.end;
        }
        p7(t, (m2, y2) => {
          m2 ? r(m2) : e(y2);
        }, { signal: o, end: f });
      });
    }
    tb.exports = { finished: v7, pipeline: b7 };
  });
  lb = T2((QI, ub) => {
    var { Buffer: m7 } = Ut(), { ObjectDefineProperty: gi, ObjectKeys: nb, ReflectApply: fb } = Tt(), { promisify: { custom: ab } } = Gr(), { streamReturningOperators: rb, promiseReturningOperators: ib } = k1(), { codes: { ERR_ILLEGAL_CONSTRUCTOR: ob } } = Jt(), g7 = eb(), { pipeline: sb } = os(), { destroyer: y7 } = yn(), hb = Ui(), pu = cu(), vu = Fi(), ct = ub.exports = Vo().Stream;
    ct.isDisturbed = vu.isDisturbed;
    ct.isErrored = vu.isErrored;
    ct.isReadable = vu.isReadable;
    ct.Readable = ba();
    for (let t of nb(rb)) {
      let r = function(...o) {
        if (new.target)
          throw ob();
        return ct.Readable.from(fb(e, this, o));
      };
      M7 = r;
      let e = rb[t];
      gi(r, "name", { __proto__: null, value: e.name }), gi(r, "length", { __proto__: null, value: e.length }), gi(ct.Readable.prototype, t, { __proto__: null, value: r, enumerable: false, configurable: true, writable: true });
    }
    var M7;
    for (let t of nb(ib)) {
      let r = function(...f) {
        if (new.target)
          throw ob();
        return fb(e, this, f);
      };
      M7 = r;
      let e = ib[t];
      gi(r, "name", { __proto__: null, value: e.name }), gi(r, "length", { __proto__: null, value: e.length }), gi(ct.Readable.prototype, t, { __proto__: null, value: r, enumerable: false, configurable: true, writable: true });
    }
    var M7;
    ct.Writable = Jh();
    ct.Duplex = Qr();
    ct.Transform = fu();
    ct.PassThrough = ou();
    ct.pipeline = sb;
    var { addAbortSignal: w7 } = Go();
    ct.addAbortSignal = w7;
    ct.finished = hb;
    ct.destroy = y7;
    ct.compose = g7;
    gi(ct, "promises", { __proto__: null, configurable: true, enumerable: true, get() {
      return pu;
    } });
    gi(sb, ab, { __proto__: null, enumerable: true, get() {
      return pu.pipeline;
    } });
    gi(hb, ab, { __proto__: null, enumerable: true, get() {
      return pu.finished;
    } });
    ct.Stream = ct;
    ct._isUint8Array = function(e) {
      return e instanceof Uint8Array;
    };
    ct._uint8ArrayToBuffer = function(e) {
      return m7.from(e.buffer, e.byteOffset, e.byteLength);
    };
  });
  bu = T2((eT, pt) => {
    var Lt = lb(), _7 = cu(), x7 = Lt.Readable.destroy;
    pt.exports = Lt.Readable;
    pt.exports._uint8ArrayToBuffer = Lt._uint8ArrayToBuffer;
    pt.exports._isUint8Array = Lt._isUint8Array;
    pt.exports.isDisturbed = Lt.isDisturbed;
    pt.exports.isErrored = Lt.isErrored;
    pt.exports.isReadable = Lt.isReadable;
    pt.exports.Readable = Lt.Readable;
    pt.exports.Writable = Lt.Writable;
    pt.exports.Duplex = Lt.Duplex;
    pt.exports.Transform = Lt.Transform;
    pt.exports.PassThrough = Lt.PassThrough;
    pt.exports.addAbortSignal = Lt.addAbortSignal;
    pt.exports.finished = Lt.finished;
    pt.exports.destroy = Lt.destroy;
    pt.exports.destroy = x7;
    pt.exports.pipeline = Lt.pipeline;
    pt.exports.compose = Lt.compose;
    Object.defineProperty(Lt, "promises", { configurable: true, enumerable: true, get() {
      return _7;
    } });
    pt.exports.Stream = Lt.Stream;
    pt.exports.default = pt.exports;
  });
  vf = {};
  Ja(vf, { default: () => S7 });
  db = R0(() => {
    ot(vf, rn(bu()));
    S7 = rn(bu());
  });
  yi = T2((rT, vb) => {
    var cb = Te().Buffer, pb = (db(), ur(vf)).Transform, E7 = co().StringDecoder, A7 = Ie();
    function Lr(t) {
      pb.call(this), this.hashMode = typeof t == "string", this.hashMode ? this[t] = this._finalOrDigest : this.final = this._finalOrDigest, this._final && (this.__final = this._final, this._final = null), this._decoder = null, this._encoding = null;
    }
    A7(Lr, pb);
    Lr.prototype.update = function(t, e, r) {
      typeof t == "string" && (t = cb.from(t, e));
      var o = this._update(t);
      return this.hashMode ? this : (r && (o = this._toString(o, r)), o);
    };
    Lr.prototype.setAutoPadding = function() {
    };
    Lr.prototype.getAuthTag = function() {
      throw new Error("trying to get auth tag in unsupported state");
    };
    Lr.prototype.setAuthTag = function() {
      throw new Error("trying to set auth tag in unsupported state");
    };
    Lr.prototype.setAAD = function() {
      throw new Error("trying to set aad in unsupported state");
    };
    Lr.prototype._transform = function(t, e, r) {
      var o;
      try {
        this.hashMode ? this._update(t) : this.push(this._update(t));
      } catch (f) {
        o = f;
      } finally {
        r(o);
      }
    };
    Lr.prototype._flush = function(t) {
      var e;
      try {
        this.push(this.__final());
      } catch (r) {
        e = r;
      }
      t(e);
    };
    Lr.prototype._finalOrDigest = function(t) {
      var e = this.__final() || cb.alloc(0);
      return t && (e = this._toString(e, t, true)), e;
    };
    Lr.prototype._toString = function(t, e, r) {
      if (this._decoder || (this._decoder = new E7(e), this._encoding = e), this._encoding !== e)
        throw new Error("can't switch encodings");
      var o = this._decoder.write(t);
      return r && (o += this._decoder.end()), o;
    };
    vb.exports = Lr;
  });
  bf = T2((iT, mb) => {
    var R7 = Ie(), B7 = Ao(), q7 = Bo(), I7 = ko(), bb = yi();
    function hs(t) {
      bb.call(this, "digest"), this._hash = t;
    }
    R7(hs, bb);
    hs.prototype._update = function(t) {
      this._hash.update(t);
    };
    hs.prototype._final = function() {
      return this._hash.digest();
    };
    mb.exports = function(e) {
      return e = e.toLowerCase(), e === "md5" ? new B7 : e === "rmd160" || e === "ripemd160" ? new q7 : new hs(I7(e));
    };
  });
  wb = T2((nT, yb) => {
    var T7 = Ie(), xn = Te().Buffer, gb = yi(), k7 = xn.alloc(128), mf = 64;
    function us(t, e) {
      gb.call(this, "digest"), typeof e == "string" && (e = xn.from(e)), this._alg = t, this._key = e, e.length > mf ? e = t(e) : e.length < mf && (e = xn.concat([e, k7], mf));
      for (var r = this._ipad = xn.allocUnsafe(mf), o = this._opad = xn.allocUnsafe(mf), f = 0;f < mf; f++)
        r[f] = e[f] ^ 54, o[f] = e[f] ^ 92;
      this._hash = [r];
    }
    T7(us, gb);
    us.prototype._update = function(t) {
      this._hash.push(t);
    };
    us.prototype._final = function() {
      var t = this._alg(xn.concat(this._hash));
      return this._alg(xn.concat([this._opad, t]));
    };
    yb.exports = us;
  });
  mu = T2((fT, Mb) => {
    var L7 = Ao();
    Mb.exports = function(t) {
      return new L7().update(t).digest();
    };
  });
  wu = T2((aT, xb) => {
    var N7 = Ie(), D7 = wb(), _b = yi(), Ma = Te().Buffer, P7 = mu(), gu = Bo(), yu = ko(), C7 = Ma.alloc(128);
    function _a(t, e) {
      _b.call(this, "digest"), typeof e == "string" && (e = Ma.from(e));
      var r = t === "sha512" || t === "sha384" ? 128 : 64;
      if (this._alg = t, this._key = e, e.length > r) {
        var o = t === "rmd160" ? new gu : yu(t);
        e = o.update(e).digest();
      } else
        e.length < r && (e = Ma.concat([e, C7], r));
      for (var f = this._ipad = Ma.allocUnsafe(r), p = this._opad = Ma.allocUnsafe(r), m2 = 0;m2 < r; m2++)
        f[m2] = e[m2] ^ 54, p[m2] = e[m2] ^ 92;
      this._hash = t === "rmd160" ? new gu : yu(t), this._hash.update(f);
    }
    N7(_a, _b);
    _a.prototype._update = function(t) {
      this._hash.update(t);
    };
    _a.prototype._final = function() {
      var t = this._hash.digest(), e = this._alg === "rmd160" ? new gu : yu(this._alg);
      return e.update(this._opad).update(t).digest();
    };
    xb.exports = function(e, r) {
      return e = e.toLowerCase(), e === "rmd160" || e === "ripemd160" ? new _a("rmd160", r) : e === "md5" ? new D7(P7, r) : new _a(e, r);
    };
  });
  Mu = T2((oT, O7) => {
    O7.exports = { sha224WithRSAEncryption: { sign: "rsa", hash: "sha224", id: "302d300d06096086480165030402040500041c" }, "RSA-SHA224": { sign: "ecdsa/rsa", hash: "sha224", id: "302d300d06096086480165030402040500041c" }, sha256WithRSAEncryption: { sign: "rsa", hash: "sha256", id: "3031300d060960864801650304020105000420" }, "RSA-SHA256": { sign: "ecdsa/rsa", hash: "sha256", id: "3031300d060960864801650304020105000420" }, sha384WithRSAEncryption: { sign: "rsa", hash: "sha384", id: "3041300d060960864801650304020205000430" }, "RSA-SHA384": { sign: "ecdsa/rsa", hash: "sha384", id: "3041300d060960864801650304020205000430" }, sha512WithRSAEncryption: { sign: "rsa", hash: "sha512", id: "3051300d060960864801650304020305000440" }, "RSA-SHA512": { sign: "ecdsa/rsa", hash: "sha512", id: "3051300d060960864801650304020305000440" }, "RSA-SHA1": { sign: "rsa", hash: "sha1", id: "3021300906052b0e03021a05000414" }, "ecdsa-with-SHA1": { sign: "ecdsa", hash: "sha1", id: "" }, sha256: { sign: "ecdsa", hash: "sha256", id: "" }, sha224: { sign: "ecdsa", hash: "sha224", id: "" }, sha384: { sign: "ecdsa", hash: "sha384", id: "" }, sha512: { sign: "ecdsa", hash: "sha512", id: "" }, "DSA-SHA": { sign: "dsa", hash: "sha1", id: "" }, "DSA-SHA1": { sign: "dsa", hash: "sha1", id: "" }, DSA: { sign: "dsa", hash: "sha1", id: "" }, "DSA-WITH-SHA224": { sign: "dsa", hash: "sha224", id: "" }, "DSA-SHA224": { sign: "dsa", hash: "sha224", id: "" }, "DSA-WITH-SHA256": { sign: "dsa", hash: "sha256", id: "" }, "DSA-SHA256": { sign: "dsa", hash: "sha256", id: "" }, "DSA-WITH-SHA384": { sign: "dsa", hash: "sha384", id: "" }, "DSA-SHA384": { sign: "dsa", hash: "sha384", id: "" }, "DSA-WITH-SHA512": { sign: "dsa", hash: "sha512", id: "" }, "DSA-SHA512": { sign: "dsa", hash: "sha512", id: "" }, "DSA-RIPEMD160": { sign: "dsa", hash: "rmd160", id: "" }, ripemd160WithRSA: { sign: "rsa", hash: "rmd160", id: "3021300906052b2403020105000414" }, "RSA-RIPEMD160": { sign: "rsa", hash: "rmd160", id: "3021300906052b2403020105000414" }, md5WithRSAEncryption: { sign: "rsa", hash: "md5", id: "3020300c06082a864886f70d020505000410" }, "RSA-MD5": { sign: "rsa", hash: "md5", id: "3020300c06082a864886f70d020505000410" } };
  });
  Eb = T2((sT, Sb) => {
    Sb.exports = Mu();
  });
  _u = T2((hT, Ab) => {
    var F7 = Math.pow(2, 30) - 1;
    Ab.exports = function(t, e) {
      if (typeof t != "number")
        throw new TypeError("Iterations not a number");
      if (t < 0)
        throw new TypeError("Bad iterations");
      if (typeof e != "number")
        throw new TypeError("Key length not a number");
      if (e < 0 || e > F7 || e !== e)
        throw new TypeError("Bad key length");
    };
  });
  xu = T2((uT, Bb) => {
    var ls;
    global.process && global.process.browser ? ls = "utf-8" : global.process && global.process.version ? (Rb = parseInt(process.version.split(".")[0].slice(1), 10), ls = Rb >= 6 ? "utf-8" : "binary") : ls = "utf-8";
    var Rb;
    Bb.exports = ls;
  });
  Eu = T2((lT, qb) => {
    var Su = Te().Buffer;
    qb.exports = function(t, e, r) {
      if (Su.isBuffer(t))
        return t;
      if (typeof t == "string")
        return Su.from(t, e);
      if (ArrayBuffer.isView(t))
        return Su.from(t.buffer);
      throw new TypeError(r + " must be a string, a Buffer, a typed array or a DataView");
    };
  });
  Au = T2((dT, Lb) => {
    var U7 = mu(), z7 = Bo(), H7 = ko(), Sn = Te().Buffer, W7 = _u(), Ib = xu(), Tb = Eu(), K7 = Sn.alloc(128), ds = { md5: 16, sha1: 20, sha224: 28, sha256: 32, sha384: 48, sha512: 64, rmd160: 20, ripemd160: 20 };
    function kb(t, e, r) {
      var o = j7(t), f = t === "sha512" || t === "sha384" ? 128 : 64;
      e.length > f ? e = o(e) : e.length < f && (e = Sn.concat([e, K7], f));
      for (var p = Sn.allocUnsafe(f + ds[t]), m2 = Sn.allocUnsafe(f + ds[t]), y2 = 0;y2 < f; y2++)
        p[y2] = e[y2] ^ 54, m2[y2] = e[y2] ^ 92;
      var M = Sn.allocUnsafe(f + r + 4);
      p.copy(M, 0, 0, f), this.ipad1 = M, this.ipad2 = p, this.opad = m2, this.alg = t, this.blocksize = f, this.hash = o, this.size = ds[t];
    }
    kb.prototype.run = function(t, e) {
      t.copy(e, this.blocksize);
      var r = this.hash(e);
      return r.copy(this.opad, this.blocksize), this.hash(this.opad);
    };
    function j7(t) {
      function e(o) {
        return H7(t).update(o).digest();
      }
      function r(o) {
        return new z7().update(o).digest();
      }
      return t === "rmd160" || t === "ripemd160" ? r : t === "md5" ? U7 : e;
    }
    function Z7(t, e, r, o, f) {
      W7(r, o), t = Tb(t, Ib, "Password"), e = Tb(e, Ib, "Salt"), f = f || "sha1";
      var p = new kb(f, t, e.length), m2 = Sn.allocUnsafe(o), y2 = Sn.allocUnsafe(e.length + 4);
      e.copy(y2, 0, 0, e.length);
      for (var M = 0, x = ds[f], S = Math.ceil(o / x), E2 = 1;E2 <= S; E2++) {
        y2.writeUInt32BE(E2, e.length);
        for (var B = p.run(y2, p.ipad1), q2 = B, L2 = 1;L2 < r; L2++) {
          q2 = p.run(q2, p.ipad2);
          for (var ge = 0;ge < x; ge++)
            B[ge] ^= q2[ge];
        }
        B.copy(m2, M), M += x;
      }
      return m2;
    }
    Lb.exports = Z7;
  });
  Ub = T2((cT, Fb) => {
    var Cb = Te().Buffer, V7 = _u(), Nb = xu(), Db = Au(), Pb = Eu(), cs, xa = global.crypto && global.crypto.subtle, $7 = { sha: "SHA-1", "sha-1": "SHA-1", sha1: "SHA-1", sha256: "SHA-256", "sha-256": "SHA-256", sha384: "SHA-384", "sha-384": "SHA-384", "sha-512": "SHA-512", sha512: "SHA-512" }, Ru = [];
    function G7(t) {
      if (global.process && !global.process.browser || !xa || !xa.importKey || !xa.deriveBits)
        return Promise.resolve(false);
      if (Ru[t] !== undefined)
        return Ru[t];
      cs = cs || Cb.alloc(8);
      var e = Ob(cs, cs, 10, 128, t).then(function() {
        return true;
      }).catch(function() {
        return false;
      });
      return Ru[t] = e, e;
    }
    var En;
    function Bu() {
      return En || (global.process && global.process.nextTick ? En = global.process.nextTick : global.queueMicrotask ? En = global.queueMicrotask : global.setImmediate ? En = global.setImmediate : En = global.setTimeout, En);
    }
    function Ob(t, e, r, o, f) {
      return xa.importKey("raw", t, { name: "PBKDF2" }, false, ["deriveBits"]).then(function(p) {
        return xa.deriveBits({ name: "PBKDF2", salt: e, iterations: r, hash: { name: f } }, p, o << 3);
      }).then(function(p) {
        return Cb.from(p);
      });
    }
    function Y7(t, e) {
      t.then(function(r) {
        Bu()(function() {
          e(null, r);
        });
      }, function(r) {
        Bu()(function() {
          e(r);
        });
      });
    }
    Fb.exports = function(t, e, r, o, f, p) {
      typeof f == "function" && (p = f, f = undefined), f = f || "sha1";
      var m2 = $7[f.toLowerCase()];
      if (!m2 || typeof global.Promise != "function") {
        Bu()(function() {
          var y2;
          try {
            y2 = Db(t, e, r, o, f);
          } catch (M) {
            return p(M);
          }
          p(null, y2);
        });
        return;
      }
      if (V7(r, o), t = Pb(t, Nb, "Password"), e = Pb(e, Nb, "Salt"), typeof p != "function")
        throw new Error("No callback provided to pbkdf2");
      Y7(G7(m2).then(function(y2) {
        return y2 ? Ob(t, e, r, o, m2) : Db(t, e, r, o, f);
      }), p);
    };
  });
  Iu = T2((qu) => {
    qu.pbkdf2 = Ub();
    qu.pbkdf2Sync = Au();
  });
  Tu = T2((br) => {
    br.readUInt32BE = function(e, r) {
      var o = e[0 + r] << 24 | e[1 + r] << 16 | e[2 + r] << 8 | e[3 + r];
      return o >>> 0;
    };
    br.writeUInt32BE = function(e, r, o) {
      e[0 + o] = r >>> 24, e[1 + o] = r >>> 16 & 255, e[2 + o] = r >>> 8 & 255, e[3 + o] = r & 255;
    };
    br.ip = function(e, r, o, f) {
      for (var p = 0, m2 = 0, y2 = 6;y2 >= 0; y2 -= 2) {
        for (var M = 0;M <= 24; M += 8)
          p <<= 1, p |= r >>> M + y2 & 1;
        for (var M = 0;M <= 24; M += 8)
          p <<= 1, p |= e >>> M + y2 & 1;
      }
      for (var y2 = 6;y2 >= 0; y2 -= 2) {
        for (var M = 1;M <= 25; M += 8)
          m2 <<= 1, m2 |= r >>> M + y2 & 1;
        for (var M = 1;M <= 25; M += 8)
          m2 <<= 1, m2 |= e >>> M + y2 & 1;
      }
      o[f + 0] = p >>> 0, o[f + 1] = m2 >>> 0;
    };
    br.rip = function(e, r, o, f) {
      for (var p = 0, m2 = 0, y2 = 0;y2 < 4; y2++)
        for (var M = 24;M >= 0; M -= 8)
          p <<= 1, p |= r >>> M + y2 & 1, p <<= 1, p |= e >>> M + y2 & 1;
      for (var y2 = 4;y2 < 8; y2++)
        for (var M = 24;M >= 0; M -= 8)
          m2 <<= 1, m2 |= r >>> M + y2 & 1, m2 <<= 1, m2 |= e >>> M + y2 & 1;
      o[f + 0] = p >>> 0, o[f + 1] = m2 >>> 0;
    };
    br.pc1 = function(e, r, o, f) {
      for (var p = 0, m2 = 0, y2 = 7;y2 >= 5; y2--) {
        for (var M = 0;M <= 24; M += 8)
          p <<= 1, p |= r >> M + y2 & 1;
        for (var M = 0;M <= 24; M += 8)
          p <<= 1, p |= e >> M + y2 & 1;
      }
      for (var M = 0;M <= 24; M += 8)
        p <<= 1, p |= r >> M + y2 & 1;
      for (var y2 = 1;y2 <= 3; y2++) {
        for (var M = 0;M <= 24; M += 8)
          m2 <<= 1, m2 |= r >> M + y2 & 1;
        for (var M = 0;M <= 24; M += 8)
          m2 <<= 1, m2 |= e >> M + y2 & 1;
      }
      for (var M = 0;M <= 24; M += 8)
        m2 <<= 1, m2 |= e >> M + y2 & 1;
      o[f + 0] = p >>> 0, o[f + 1] = m2 >>> 0;
    };
    br.r28shl = function(e, r) {
      return e << r & 268435455 | e >>> 28 - r;
    };
    var ps = [14, 11, 17, 4, 27, 23, 25, 0, 13, 22, 7, 18, 5, 9, 16, 24, 2, 20, 12, 21, 1, 8, 15, 26, 15, 4, 25, 19, 9, 1, 26, 16, 5, 11, 23, 8, 12, 7, 17, 0, 22, 3, 10, 14, 6, 20, 27, 24];
    br.pc2 = function(e, r, o, f) {
      for (var p = 0, m2 = 0, y2 = ps.length >>> 1, M = 0;M < y2; M++)
        p <<= 1, p |= e >>> ps[M] & 1;
      for (var M = y2;M < ps.length; M++)
        m2 <<= 1, m2 |= r >>> ps[M] & 1;
      o[f + 0] = p >>> 0, o[f + 1] = m2 >>> 0;
    };
    br.expand = function(e, r, o) {
      var f = 0, p = 0;
      f = (e & 1) << 5 | e >>> 27;
      for (var m2 = 23;m2 >= 15; m2 -= 4)
        f <<= 6, f |= e >>> m2 & 63;
      for (var m2 = 11;m2 >= 3; m2 -= 4)
        p |= e >>> m2 & 63, p <<= 6;
      p |= (e & 31) << 1 | e >>> 31, r[o + 0] = f >>> 0, r[o + 1] = p >>> 0;
    };
    var zb = [14, 0, 4, 15, 13, 7, 1, 4, 2, 14, 15, 2, 11, 13, 8, 1, 3, 10, 10, 6, 6, 12, 12, 11, 5, 9, 9, 5, 0, 3, 7, 8, 4, 15, 1, 12, 14, 8, 8, 2, 13, 4, 6, 9, 2, 1, 11, 7, 15, 5, 12, 11, 9, 3, 7, 14, 3, 10, 10, 0, 5, 6, 0, 13, 15, 3, 1, 13, 8, 4, 14, 7, 6, 15, 11, 2, 3, 8, 4, 14, 9, 12, 7, 0, 2, 1, 13, 10, 12, 6, 0, 9, 5, 11, 10, 5, 0, 13, 14, 8, 7, 10, 11, 1, 10, 3, 4, 15, 13, 4, 1, 2, 5, 11, 8, 6, 12, 7, 6, 12, 9, 0, 3, 5, 2, 14, 15, 9, 10, 13, 0, 7, 9, 0, 14, 9, 6, 3, 3, 4, 15, 6, 5, 10, 1, 2, 13, 8, 12, 5, 7, 14, 11, 12, 4, 11, 2, 15, 8, 1, 13, 1, 6, 10, 4, 13, 9, 0, 8, 6, 15, 9, 3, 8, 0, 7, 11, 4, 1, 15, 2, 14, 12, 3, 5, 11, 10, 5, 14, 2, 7, 12, 7, 13, 13, 8, 14, 11, 3, 5, 0, 6, 6, 15, 9, 0, 10, 3, 1, 4, 2, 7, 8, 2, 5, 12, 11, 1, 12, 10, 4, 14, 15, 9, 10, 3, 6, 15, 9, 0, 0, 6, 12, 10, 11, 1, 7, 13, 13, 8, 15, 9, 1, 4, 3, 5, 14, 11, 5, 12, 2, 7, 8, 2, 4, 14, 2, 14, 12, 11, 4, 2, 1, 12, 7, 4, 10, 7, 11, 13, 6, 1, 8, 5, 5, 0, 3, 15, 15, 10, 13, 3, 0, 9, 14, 8, 9, 6, 4, 11, 2, 8, 1, 12, 11, 7, 10, 1, 13, 14, 7, 2, 8, 13, 15, 6, 9, 15, 12, 0, 5, 9, 6, 10, 3, 4, 0, 5, 14, 3, 12, 10, 1, 15, 10, 4, 15, 2, 9, 7, 2, 12, 6, 9, 8, 5, 0, 6, 13, 1, 3, 13, 4, 14, 14, 0, 7, 11, 5, 3, 11, 8, 9, 4, 14, 3, 15, 2, 5, 12, 2, 9, 8, 5, 12, 15, 3, 10, 7, 11, 0, 14, 4, 1, 10, 7, 1, 6, 13, 0, 11, 8, 6, 13, 4, 13, 11, 0, 2, 11, 14, 7, 15, 4, 0, 9, 8, 1, 13, 10, 3, 14, 12, 3, 9, 5, 7, 12, 5, 2, 10, 15, 6, 8, 1, 6, 1, 6, 4, 11, 11, 13, 13, 8, 12, 1, 3, 4, 7, 10, 14, 7, 10, 9, 15, 5, 6, 0, 8, 15, 0, 14, 5, 2, 9, 3, 2, 12, 13, 1, 2, 15, 8, 13, 4, 8, 6, 10, 15, 3, 11, 7, 1, 4, 10, 12, 9, 5, 3, 6, 14, 11, 5, 0, 0, 14, 12, 9, 7, 2, 7, 2, 11, 1, 4, 14, 1, 7, 9, 4, 12, 10, 14, 8, 2, 13, 0, 15, 6, 12, 10, 9, 13, 0, 15, 3, 3, 5, 5, 6, 8, 11];
    br.substitute = function(e, r) {
      for (var o = 0, f = 0;f < 4; f++) {
        var p = e >>> 18 - f * 6 & 63, m2 = zb[f * 64 + p];
        o <<= 4, o |= m2;
      }
      for (var f = 0;f < 4; f++) {
        var p = r >>> 18 - f * 6 & 63, m2 = zb[4 * 64 + f * 64 + p];
        o <<= 4, o |= m2;
      }
      return o >>> 0;
    };
    var Hb = [16, 25, 12, 11, 3, 20, 4, 15, 31, 17, 9, 6, 27, 14, 1, 22, 30, 24, 8, 18, 0, 5, 29, 23, 13, 19, 2, 26, 10, 21, 28, 7];
    br.permute = function(e) {
      for (var r = 0, o = 0;o < Hb.length; o++)
        r <<= 1, r |= e >>> Hb[o] & 1;
      return r >>> 0;
    };
    br.padSplit = function(e, r, o) {
      for (var f = e.toString(2);f.length < r; )
        f = "0" + f;
      for (var p = [], m2 = 0;m2 < r; m2 += o)
        p.push(f.slice(m2, m2 + o));
      return p.join(" ");
    };
  });
  ar = T2((bT, Kb) => {
    Kb.exports = Wb;
    function Wb(t, e) {
      if (!t)
        throw new Error(e || "Assertion failed");
    }
    Wb.equal = function(e, r, o) {
      if (e != r)
        throw new Error(o || "Assertion failed: " + e + " != " + r);
    };
  });
  vs = T2((mT, jb) => {
    var X7 = ar();
    function mr(t) {
      this.options = t, this.type = this.options.type, this.blockSize = 8, this._init(), this.buffer = new Array(this.blockSize), this.bufferOff = 0;
    }
    jb.exports = mr;
    mr.prototype._init = function() {
    };
    mr.prototype.update = function(e) {
      return e.length === 0 ? [] : this.type === "decrypt" ? this._updateDecrypt(e) : this._updateEncrypt(e);
    };
    mr.prototype._buffer = function(e, r) {
      for (var o = Math.min(this.buffer.length - this.bufferOff, e.length - r), f = 0;f < o; f++)
        this.buffer[this.bufferOff + f] = e[r + f];
      return this.bufferOff += o, o;
    };
    mr.prototype._flushBuffer = function(e, r) {
      return this._update(this.buffer, 0, e, r), this.bufferOff = 0, this.blockSize;
    };
    mr.prototype._updateEncrypt = function(e) {
      var r = 0, o = 0, f = (this.bufferOff + e.length) / this.blockSize | 0, p = new Array(f * this.blockSize);
      this.bufferOff !== 0 && (r += this._buffer(e, r), this.bufferOff === this.buffer.length && (o += this._flushBuffer(p, o)));
      for (var m2 = e.length - (e.length - r) % this.blockSize;r < m2; r += this.blockSize)
        this._update(e, r, p, o), o += this.blockSize;
      for (;r < e.length; r++, this.bufferOff++)
        this.buffer[this.bufferOff] = e[r];
      return p;
    };
    mr.prototype._updateDecrypt = function(e) {
      for (var r = 0, o = 0, f = Math.ceil((this.bufferOff + e.length) / this.blockSize) - 1, p = new Array(f * this.blockSize);f > 0; f--)
        r += this._buffer(e, r), o += this._flushBuffer(p, o);
      return r += this._buffer(e, r), p;
    };
    mr.prototype.final = function(e) {
      var r;
      e && (r = this.update(e));
      var o;
      return this.type === "encrypt" ? o = this._finalEncrypt() : o = this._finalDecrypt(), r ? r.concat(o) : o;
    };
    mr.prototype._pad = function(e, r) {
      if (r === 0)
        return false;
      for (;r < e.length; )
        e[r++] = 0;
      return true;
    };
    mr.prototype._finalEncrypt = function() {
      if (!this._pad(this.buffer, this.bufferOff))
        return [];
      var e = new Array(this.blockSize);
      return this._update(this.buffer, 0, e, 0), e;
    };
    mr.prototype._unpad = function(e) {
      return e;
    };
    mr.prototype._finalDecrypt = function() {
      X7.equal(this.bufferOff, this.blockSize, "Not enough data to decrypt");
      var e = new Array(this.blockSize);
      return this._flushBuffer(e, 0), this._unpad(e);
    };
  });
  ku = T2((gT, $b) => {
    var Zb = ar(), J7 = Ie(), Nt = Tu(), Vb = vs();
    function Q7() {
      this.tmp = new Array(2), this.keys = null;
    }
    function ei(t) {
      Vb.call(this, t);
      var e = new Q7;
      this._desState = e, this.deriveKeys(e, t.key);
    }
    J7(ei, Vb);
    $b.exports = ei;
    ei.create = function(e) {
      return new ei(e);
    };
    var e9 = [1, 1, 2, 2, 2, 2, 2, 2, 1, 2, 2, 2, 2, 2, 2, 1];
    ei.prototype.deriveKeys = function(e, r) {
      e.keys = new Array(16 * 2), Zb.equal(r.length, this.blockSize, "Invalid key length");
      var o = Nt.readUInt32BE(r, 0), f = Nt.readUInt32BE(r, 4);
      Nt.pc1(o, f, e.tmp, 0), o = e.tmp[0], f = e.tmp[1];
      for (var p = 0;p < e.keys.length; p += 2) {
        var m2 = e9[p >>> 1];
        o = Nt.r28shl(o, m2), f = Nt.r28shl(f, m2), Nt.pc2(o, f, e.keys, p);
      }
    };
    ei.prototype._update = function(e, r, o, f) {
      var p = this._desState, m2 = Nt.readUInt32BE(e, r), y2 = Nt.readUInt32BE(e, r + 4);
      Nt.ip(m2, y2, p.tmp, 0), m2 = p.tmp[0], y2 = p.tmp[1], this.type === "encrypt" ? this._encrypt(p, m2, y2, p.tmp, 0) : this._decrypt(p, m2, y2, p.tmp, 0), m2 = p.tmp[0], y2 = p.tmp[1], Nt.writeUInt32BE(o, m2, f), Nt.writeUInt32BE(o, y2, f + 4);
    };
    ei.prototype._pad = function(e, r) {
      for (var o = e.length - r, f = r;f < e.length; f++)
        e[f] = o;
      return true;
    };
    ei.prototype._unpad = function(e) {
      for (var r = e[e.length - 1], o = e.length - r;o < e.length; o++)
        Zb.equal(e[o], r);
      return e.slice(0, e.length - r);
    };
    ei.prototype._encrypt = function(e, r, o, f, p) {
      for (var m2 = r, y2 = o, M = 0;M < e.keys.length; M += 2) {
        var x = e.keys[M], S = e.keys[M + 1];
        Nt.expand(y2, e.tmp, 0), x ^= e.tmp[0], S ^= e.tmp[1];
        var E2 = Nt.substitute(x, S), B = Nt.permute(E2), q2 = y2;
        y2 = (m2 ^ B) >>> 0, m2 = q2;
      }
      Nt.rip(y2, m2, f, p);
    };
    ei.prototype._decrypt = function(e, r, o, f, p) {
      for (var m2 = o, y2 = r, M = e.keys.length - 2;M >= 0; M -= 2) {
        var x = e.keys[M], S = e.keys[M + 1];
        Nt.expand(m2, e.tmp, 0), x ^= e.tmp[0], S ^= e.tmp[1];
        var E2 = Nt.substitute(x, S), B = Nt.permute(E2), q2 = m2;
        m2 = (y2 ^ B) >>> 0, y2 = q2;
      }
      Nt.rip(m2, y2, f, p);
    };
  });
  Yb = T2((Gb) => {
    var t9 = ar(), r9 = Ie(), bs = {};
    function i9(t) {
      t9.equal(t.length, 8, "Invalid IV length"), this.iv = new Array(8);
      for (var e = 0;e < this.iv.length; e++)
        this.iv[e] = t[e];
    }
    function n9(t) {
      function e(p) {
        t.call(this, p), this._cbcInit();
      }
      r9(e, t);
      for (var r = Object.keys(bs), o = 0;o < r.length; o++) {
        var f = r[o];
        e.prototype[f] = bs[f];
      }
      return e.create = function(m2) {
        return new e(m2);
      }, e;
    }
    Gb.instantiate = n9;
    bs._cbcInit = function() {
      var e = new i9(this.options.iv);
      this._cbcState = e;
    };
    bs._update = function(e, r, o, f) {
      var p = this._cbcState, m2 = this.constructor.super_.prototype, y2 = p.iv;
      if (this.type === "encrypt") {
        for (var M = 0;M < this.blockSize; M++)
          y2[M] ^= e[r + M];
        m2._update.call(this, y2, 0, o, f);
        for (var M = 0;M < this.blockSize; M++)
          y2[M] = o[f + M];
      } else {
        m2._update.call(this, e, r, o, f);
        for (var M = 0;M < this.blockSize; M++)
          o[f + M] ^= y2[M];
        for (var M = 0;M < this.blockSize; M++)
          y2[M] = e[r + M];
      }
    };
  });
  Qb = T2((wT, Jb) => {
    var f9 = ar(), a9 = Ie(), Xb = vs(), Wi = ku();
    function o9(t, e) {
      f9.equal(e.length, 24, "Invalid key length");
      var r = e.slice(0, 8), o = e.slice(8, 16), f = e.slice(16, 24);
      t === "encrypt" ? this.ciphers = [Wi.create({ type: "encrypt", key: r }), Wi.create({ type: "decrypt", key: o }), Wi.create({ type: "encrypt", key: f })] : this.ciphers = [Wi.create({ type: "decrypt", key: f }), Wi.create({ type: "encrypt", key: o }), Wi.create({ type: "decrypt", key: r })];
    }
    function An(t) {
      Xb.call(this, t);
      var e = new o9(this.type, this.options.key);
      this._edeState = e;
    }
    a9(An, Xb);
    Jb.exports = An;
    An.create = function(e) {
      return new An(e);
    };
    An.prototype._update = function(e, r, o, f) {
      var p = this._edeState;
      p.ciphers[0]._update(e, r, o, f), p.ciphers[1]._update(o, f, o, f), p.ciphers[2]._update(o, f, o, f);
    };
    An.prototype._pad = Wi.prototype._pad;
    An.prototype._unpad = Wi.prototype._unpad;
  });
  em = T2((gf) => {
    gf.utils = Tu();
    gf.Cipher = vs();
    gf.DES = ku();
    gf.CBC = Yb();
    gf.EDE = Qb();
  });
  im = T2((_T, rm) => {
    var tm = yi(), wi = em(), s9 = Ie(), Rn = Te().Buffer, Sa = { "des-ede3-cbc": wi.CBC.instantiate(wi.EDE), "des-ede3": wi.EDE, "des-ede-cbc": wi.CBC.instantiate(wi.EDE), "des-ede": wi.EDE, "des-cbc": wi.CBC.instantiate(wi.DES), "des-ecb": wi.DES };
    Sa.des = Sa["des-cbc"];
    Sa.des3 = Sa["des-ede3-cbc"];
    rm.exports = ms;
    s9(ms, tm);
    function ms(t) {
      tm.call(this);
      var e = t.mode.toLowerCase(), r = Sa[e], o;
      t.decrypt ? o = "decrypt" : o = "encrypt";
      var f = t.key;
      Rn.isBuffer(f) || (f = Rn.from(f)), (e === "des-ede" || e === "des-ede-cbc") && (f = Rn.concat([f, f.slice(0, 8)]));
      var p = t.iv;
      Rn.isBuffer(p) || (p = Rn.from(p)), this._des = r.create({ key: f, iv: p, type: o });
    }
    ms.prototype._update = function(t) {
      return Rn.from(this._des.update(t));
    };
    ms.prototype._final = function() {
      return Rn.from(this._des.final());
    };
  });
  nm = T2((Lu) => {
    Lu.encrypt = function(t, e) {
      return t._cipher.encryptBlock(e);
    };
    Lu.decrypt = function(t, e) {
      return t._cipher.decryptBlock(e);
    };
  });
  yf = T2((ST, fm) => {
    fm.exports = function(e, r) {
      for (var o = Math.min(e.length, r.length), f = new Buffer(o), p = 0;p < o; ++p)
        f[p] = e[p] ^ r[p];
      return f;
    };
  });
  om = T2((Nu) => {
    var am = yf();
    Nu.encrypt = function(t, e) {
      var r = am(e, t._prev);
      return t._prev = t._cipher.encryptBlock(r), t._prev;
    };
    Nu.decrypt = function(t, e) {
      var r = t._prev;
      t._prev = e;
      var o = t._cipher.decryptBlock(e);
      return am(o, r);
    };
  });
  um = T2((hm) => {
    var Ea = Te().Buffer, h9 = yf();
    function sm(t, e, r) {
      var o = e.length, f = h9(e, t._cache);
      return t._cache = t._cache.slice(o), t._prev = Ea.concat([t._prev, r ? e : f]), f;
    }
    hm.encrypt = function(t, e, r) {
      for (var o = Ea.allocUnsafe(0), f;e.length; )
        if (t._cache.length === 0 && (t._cache = t._cipher.encryptBlock(t._prev), t._prev = Ea.allocUnsafe(0)), t._cache.length <= e.length)
          f = t._cache.length, o = Ea.concat([o, sm(t, e.slice(0, f), r)]), e = e.slice(f);
        else {
          o = Ea.concat([o, sm(t, e, r)]);
          break;
        }
      return o;
    };
  });
  dm = T2((lm) => {
    var Du = Te().Buffer;
    function u9(t, e, r) {
      var o = t._cipher.encryptBlock(t._prev), f = o[0] ^ e;
      return t._prev = Du.concat([t._prev.slice(1), Du.from([r ? e : f])]), f;
    }
    lm.encrypt = function(t, e, r) {
      for (var o = e.length, f = Du.allocUnsafe(o), p = -1;++p < o; )
        f[p] = u9(t, e[p], r);
      return f;
    };
  });
  pm = T2((cm) => {
    var gs = Te().Buffer;
    function l9(t, e, r) {
      for (var o, f = -1, p = 8, m2 = 0, y2, M;++f < p; )
        o = t._cipher.encryptBlock(t._prev), y2 = e & 1 << 7 - f ? 128 : 0, M = o[0] ^ y2, m2 += (M & 128) >> f % 8, t._prev = d9(t._prev, r ? y2 : M);
      return m2;
    }
    function d9(t, e) {
      var r = t.length, o = -1, f = gs.allocUnsafe(t.length);
      for (t = gs.concat([t, gs.from([e])]);++o < r; )
        f[o] = t[o] << 1 | t[o + 1] >> 7;
      return f;
    }
    cm.encrypt = function(t, e, r) {
      for (var o = e.length, f = gs.allocUnsafe(o), p = -1;++p < o; )
        f[p] = l9(t, e[p], r);
      return f;
    };
  });
  bm = T2((vm) => {
    var c9 = yf();
    function p9(t) {
      return t._prev = t._cipher.encryptBlock(t._prev), t._prev;
    }
    vm.encrypt = function(t, e) {
      for (;t._cache.length < e.length; )
        t._cache = Buffer.concat([t._cache, p9(t)]);
      var r = t._cache.slice(0, e.length);
      return t._cache = t._cache.slice(e.length), c9(e, r);
    };
  });
  Pu = T2((IT, mm) => {
    function v9(t) {
      for (var e = t.length, r;e--; )
        if (r = t.readUInt8(e), r === 255)
          t.writeUInt8(0, e);
        else {
          r++, t.writeUInt8(r, e);
          break;
        }
    }
    mm.exports = v9;
  });
  Ou = T2((ym) => {
    var b9 = yf(), gm = Te().Buffer, m9 = Pu();
    function g9(t) {
      var e = t._cipher.encryptBlockRaw(t._prev);
      return m9(t._prev), e;
    }
    var Cu = 16;
    ym.encrypt = function(t, e) {
      var r = Math.ceil(e.length / Cu), o = t._cache.length;
      t._cache = gm.concat([t._cache, gm.allocUnsafe(r * Cu)]);
      for (var f = 0;f < r; f++) {
        var p = g9(t), m2 = o + f * Cu;
        t._cache.writeUInt32BE(p[0], m2 + 0), t._cache.writeUInt32BE(p[1], m2 + 4), t._cache.writeUInt32BE(p[2], m2 + 8), t._cache.writeUInt32BE(p[3], m2 + 12);
      }
      var y2 = t._cache.slice(0, e.length);
      return t._cache = t._cache.slice(e.length), b9(e, y2);
    };
  });
  Fu = T2((kT, y9) => {
    y9.exports = { "aes-128-ecb": { cipher: "AES", key: 128, iv: 0, mode: "ECB", type: "block" }, "aes-192-ecb": { cipher: "AES", key: 192, iv: 0, mode: "ECB", type: "block" }, "aes-256-ecb": { cipher: "AES", key: 256, iv: 0, mode: "ECB", type: "block" }, "aes-128-cbc": { cipher: "AES", key: 128, iv: 16, mode: "CBC", type: "block" }, "aes-192-cbc": { cipher: "AES", key: 192, iv: 16, mode: "CBC", type: "block" }, "aes-256-cbc": { cipher: "AES", key: 256, iv: 16, mode: "CBC", type: "block" }, aes128: { cipher: "AES", key: 128, iv: 16, mode: "CBC", type: "block" }, aes192: { cipher: "AES", key: 192, iv: 16, mode: "CBC", type: "block" }, aes256: { cipher: "AES", key: 256, iv: 16, mode: "CBC", type: "block" }, "aes-128-cfb": { cipher: "AES", key: 128, iv: 16, mode: "CFB", type: "stream" }, "aes-192-cfb": { cipher: "AES", key: 192, iv: 16, mode: "CFB", type: "stream" }, "aes-256-cfb": { cipher: "AES", key: 256, iv: 16, mode: "CFB", type: "stream" }, "aes-128-cfb8": { cipher: "AES", key: 128, iv: 16, mode: "CFB8", type: "stream" }, "aes-192-cfb8": { cipher: "AES", key: 192, iv: 16, mode: "CFB8", type: "stream" }, "aes-256-cfb8": { cipher: "AES", key: 256, iv: 16, mode: "CFB8", type: "stream" }, "aes-128-cfb1": { cipher: "AES", key: 128, iv: 16, mode: "CFB1", type: "stream" }, "aes-192-cfb1": { cipher: "AES", key: 192, iv: 16, mode: "CFB1", type: "stream" }, "aes-256-cfb1": { cipher: "AES", key: 256, iv: 16, mode: "CFB1", type: "stream" }, "aes-128-ofb": { cipher: "AES", key: 128, iv: 16, mode: "OFB", type: "stream" }, "aes-192-ofb": { cipher: "AES", key: 192, iv: 16, mode: "OFB", type: "stream" }, "aes-256-ofb": { cipher: "AES", key: 256, iv: 16, mode: "OFB", type: "stream" }, "aes-128-ctr": { cipher: "AES", key: 128, iv: 16, mode: "CTR", type: "stream" }, "aes-192-ctr": { cipher: "AES", key: 192, iv: 16, mode: "CTR", type: "stream" }, "aes-256-ctr": { cipher: "AES", key: 256, iv: 16, mode: "CTR", type: "stream" }, "aes-128-gcm": { cipher: "AES", key: 128, iv: 12, mode: "GCM", type: "auth" }, "aes-192-gcm": { cipher: "AES", key: 192, iv: 12, mode: "GCM", type: "auth" }, "aes-256-gcm": { cipher: "AES", key: 256, iv: 12, mode: "GCM", type: "auth" } };
  });
  ws = T2((LT, wm) => {
    var w9 = { ECB: nm(), CBC: om(), CFB: um(), CFB8: dm(), CFB1: pm(), OFB: bm(), CTR: Ou(), GCM: Ou() }, ys = Fu();
    for (Uu in ys)
      ys[Uu].module = w9[ys[Uu].mode];
    var Uu;
    wm.exports = ys;
  });
  Aa = T2((NT, _m) => {
    var Ms = Te().Buffer;
    function Hu(t) {
      Ms.isBuffer(t) || (t = Ms.from(t));
      for (var e = t.length / 4 | 0, r = new Array(e), o = 0;o < e; o++)
        r[o] = t.readUInt32BE(o * 4);
      return r;
    }
    function zu(t) {
      for (var e = 0;e < t.length; t++)
        t[e] = 0;
    }
    function Mm(t, e, r, o, f) {
      for (var p = r[0], m2 = r[1], y2 = r[2], M = r[3], x = t[0] ^ e[0], S = t[1] ^ e[1], E2 = t[2] ^ e[2], B = t[3] ^ e[3], q2, L2, ge, _e, N = 4, we = 1;we < f; we++)
        q2 = p[x >>> 24] ^ m2[S >>> 16 & 255] ^ y2[E2 >>> 8 & 255] ^ M[B & 255] ^ e[N++], L2 = p[S >>> 24] ^ m2[E2 >>> 16 & 255] ^ y2[B >>> 8 & 255] ^ M[x & 255] ^ e[N++], ge = p[E2 >>> 24] ^ m2[B >>> 16 & 255] ^ y2[x >>> 8 & 255] ^ M[S & 255] ^ e[N++], _e = p[B >>> 24] ^ m2[x >>> 16 & 255] ^ y2[S >>> 8 & 255] ^ M[E2 & 255] ^ e[N++], x = q2, S = L2, E2 = ge, B = _e;
      return q2 = (o[x >>> 24] << 24 | o[S >>> 16 & 255] << 16 | o[E2 >>> 8 & 255] << 8 | o[B & 255]) ^ e[N++], L2 = (o[S >>> 24] << 24 | o[E2 >>> 16 & 255] << 16 | o[B >>> 8 & 255] << 8 | o[x & 255]) ^ e[N++], ge = (o[E2 >>> 24] << 24 | o[B >>> 16 & 255] << 16 | o[x >>> 8 & 255] << 8 | o[S & 255]) ^ e[N++], _e = (o[B >>> 24] << 24 | o[x >>> 16 & 255] << 16 | o[S >>> 8 & 255] << 8 | o[E2 & 255]) ^ e[N++], q2 = q2 >>> 0, L2 = L2 >>> 0, ge = ge >>> 0, _e = _e >>> 0, [q2, L2, ge, _e];
    }
    var M9 = [0, 1, 2, 4, 8, 16, 32, 64, 128, 27, 54], kt = function() {
      for (var t = new Array(256), e = 0;e < 256; e++)
        e < 128 ? t[e] = e << 1 : t[e] = e << 1 ^ 283;
      for (var r = [], o = [], f = [[], [], [], []], p = [[], [], [], []], m2 = 0, y2 = 0, M = 0;M < 256; ++M) {
        var x = y2 ^ y2 << 1 ^ y2 << 2 ^ y2 << 3 ^ y2 << 4;
        x = x >>> 8 ^ x & 255 ^ 99, r[m2] = x, o[x] = m2;
        var S = t[m2], E2 = t[S], B = t[E2], q2 = t[x] * 257 ^ x * 16843008;
        f[0][m2] = q2 << 24 | q2 >>> 8, f[1][m2] = q2 << 16 | q2 >>> 16, f[2][m2] = q2 << 8 | q2 >>> 24, f[3][m2] = q2, q2 = B * 16843009 ^ E2 * 65537 ^ S * 257 ^ m2 * 16843008, p[0][x] = q2 << 24 | q2 >>> 8, p[1][x] = q2 << 16 | q2 >>> 16, p[2][x] = q2 << 8 | q2 >>> 24, p[3][x] = q2, m2 === 0 ? m2 = y2 = 1 : (m2 = S ^ t[t[t[B ^ S]]], y2 ^= t[t[y2]]);
      }
      return { SBOX: r, INV_SBOX: o, SUB_MIX: f, INV_SUB_MIX: p };
    }();
    function gr(t) {
      this._key = Hu(t), this._reset();
    }
    gr.blockSize = 4 * 4;
    gr.keySize = 256 / 8;
    gr.prototype.blockSize = gr.blockSize;
    gr.prototype.keySize = gr.keySize;
    gr.prototype._reset = function() {
      for (var t = this._key, e = t.length, r = e + 6, o = (r + 1) * 4, f = [], p = 0;p < e; p++)
        f[p] = t[p];
      for (p = e;p < o; p++) {
        var m2 = f[p - 1];
        p % e === 0 ? (m2 = m2 << 8 | m2 >>> 24, m2 = kt.SBOX[m2 >>> 24] << 24 | kt.SBOX[m2 >>> 16 & 255] << 16 | kt.SBOX[m2 >>> 8 & 255] << 8 | kt.SBOX[m2 & 255], m2 ^= M9[p / e | 0] << 24) : e > 6 && p % e === 4 && (m2 = kt.SBOX[m2 >>> 24] << 24 | kt.SBOX[m2 >>> 16 & 255] << 16 | kt.SBOX[m2 >>> 8 & 255] << 8 | kt.SBOX[m2 & 255]), f[p] = f[p - e] ^ m2;
      }
      for (var y2 = [], M = 0;M < o; M++) {
        var x = o - M, S = f[x - (M % 4 ? 0 : 4)];
        M < 4 || x <= 4 ? y2[M] = S : y2[M] = kt.INV_SUB_MIX[0][kt.SBOX[S >>> 24]] ^ kt.INV_SUB_MIX[1][kt.SBOX[S >>> 16 & 255]] ^ kt.INV_SUB_MIX[2][kt.SBOX[S >>> 8 & 255]] ^ kt.INV_SUB_MIX[3][kt.SBOX[S & 255]];
      }
      this._nRounds = r, this._keySchedule = f, this._invKeySchedule = y2;
    };
    gr.prototype.encryptBlockRaw = function(t) {
      return t = Hu(t), Mm(t, this._keySchedule, kt.SUB_MIX, kt.SBOX, this._nRounds);
    };
    gr.prototype.encryptBlock = function(t) {
      var e = this.encryptBlockRaw(t), r = Ms.allocUnsafe(16);
      return r.writeUInt32BE(e[0], 0), r.writeUInt32BE(e[1], 4), r.writeUInt32BE(e[2], 8), r.writeUInt32BE(e[3], 12), r;
    };
    gr.prototype.decryptBlock = function(t) {
      t = Hu(t);
      var e = t[1];
      t[1] = t[3], t[3] = e;
      var r = Mm(t, this._invKeySchedule, kt.INV_SUB_MIX, kt.INV_SBOX, this._nRounds), o = Ms.allocUnsafe(16);
      return o.writeUInt32BE(r[0], 0), o.writeUInt32BE(r[3], 4), o.writeUInt32BE(r[2], 8), o.writeUInt32BE(r[1], 12), o;
    };
    gr.prototype.scrub = function() {
      zu(this._keySchedule), zu(this._invKeySchedule), zu(this._key);
    };
    _m.exports.AES = gr;
  });
  Em = T2((DT, Sm) => {
    var wf = Te().Buffer, _9 = wf.alloc(16, 0);
    function x9(t) {
      return [t.readUInt32BE(0), t.readUInt32BE(4), t.readUInt32BE(8), t.readUInt32BE(12)];
    }
    function xm(t) {
      var e = wf.allocUnsafe(16);
      return e.writeUInt32BE(t[0] >>> 0, 0), e.writeUInt32BE(t[1] >>> 0, 4), e.writeUInt32BE(t[2] >>> 0, 8), e.writeUInt32BE(t[3] >>> 0, 12), e;
    }
    function Ra(t) {
      this.h = t, this.state = wf.alloc(16, 0), this.cache = wf.allocUnsafe(0);
    }
    Ra.prototype.ghash = function(t) {
      for (var e = -1;++e < t.length; )
        this.state[e] ^= t[e];
      this._multiply();
    };
    Ra.prototype._multiply = function() {
      for (var t = x9(this.h), e = [0, 0, 0, 0], r, o, f, p = -1;++p < 128; ) {
        for (o = (this.state[~~(p / 8)] & 1 << 7 - p % 8) !== 0, o && (e[0] ^= t[0], e[1] ^= t[1], e[2] ^= t[2], e[3] ^= t[3]), f = (t[3] & 1) !== 0, r = 3;r > 0; r--)
          t[r] = t[r] >>> 1 | (t[r - 1] & 1) << 31;
        t[0] = t[0] >>> 1, f && (t[0] = t[0] ^ 225 << 24);
      }
      this.state = xm(e);
    };
    Ra.prototype.update = function(t) {
      this.cache = wf.concat([this.cache, t]);
      for (var e;this.cache.length >= 16; )
        e = this.cache.slice(0, 16), this.cache = this.cache.slice(16), this.ghash(e);
    };
    Ra.prototype.final = function(t, e) {
      return this.cache.length && this.ghash(wf.concat([this.cache, _9], 16)), this.ghash(xm([0, t, 0, e])), this.state;
    };
    Sm.exports = Ra;
  });
  Wu = T2((PT, Bm) => {
    var S9 = Aa(), rr = Te().Buffer, Am = yi(), E9 = Ie(), Rm = Em(), A9 = yf(), R9 = Pu();
    function B9(t, e) {
      var r = 0;
      t.length !== e.length && r++;
      for (var o = Math.min(t.length, e.length), f = 0;f < o; ++f)
        r += t[f] ^ e[f];
      return r;
    }
    function q9(t, e, r) {
      if (e.length === 12)
        return t._finID = rr.concat([e, rr.from([0, 0, 0, 1])]), rr.concat([e, rr.from([0, 0, 0, 2])]);
      var o = new Rm(r), f = e.length, p = f % 16;
      o.update(e), p && (p = 16 - p, o.update(rr.alloc(p, 0))), o.update(rr.alloc(8, 0));
      var m2 = f * 8, y2 = rr.alloc(8);
      y2.writeUIntBE(m2, 0, 8), o.update(y2), t._finID = o.state;
      var M = rr.from(t._finID);
      return R9(M), M;
    }
    function Bn(t, e, r, o) {
      Am.call(this);
      var f = rr.alloc(4, 0);
      this._cipher = new S9.AES(e);
      var p = this._cipher.encryptBlock(f);
      this._ghash = new Rm(p), r = q9(this, r, p), this._prev = rr.from(r), this._cache = rr.allocUnsafe(0), this._secCache = rr.allocUnsafe(0), this._decrypt = o, this._alen = 0, this._len = 0, this._mode = t, this._authTag = null, this._called = false;
    }
    E9(Bn, Am);
    Bn.prototype._update = function(t) {
      if (!this._called && this._alen) {
        var e = 16 - this._alen % 16;
        e < 16 && (e = rr.alloc(e, 0), this._ghash.update(e));
      }
      this._called = true;
      var r = this._mode.encrypt(this, t);
      return this._decrypt ? this._ghash.update(t) : this._ghash.update(r), this._len += t.length, r;
    };
    Bn.prototype._final = function() {
      if (this._decrypt && !this._authTag)
        throw new Error("Unsupported state or unable to authenticate data");
      var t = A9(this._ghash.final(this._alen * 8, this._len * 8), this._cipher.encryptBlock(this._finID));
      if (this._decrypt && B9(t, this._authTag))
        throw new Error("Unsupported state or unable to authenticate data");
      this._authTag = t, this._cipher.scrub();
    };
    Bn.prototype.getAuthTag = function() {
      if (this._decrypt || !rr.isBuffer(this._authTag))
        throw new Error("Attempting to get auth tag in unsupported state");
      return this._authTag;
    };
    Bn.prototype.setAuthTag = function(e) {
      if (!this._decrypt)
        throw new Error("Attempting to set auth tag in unsupported state");
      this._authTag = e;
    };
    Bn.prototype.setAAD = function(e) {
      if (this._called)
        throw new Error("Attempting to set AAD in unsupported state");
      this._ghash.update(e), this._alen += e.length;
    };
    Bm.exports = Bn;
  });
  ju = T2((CT, Im) => {
    var I9 = Aa(), Ku = Te().Buffer, qm = yi(), T9 = Ie();
    function _s(t, e, r, o) {
      qm.call(this), this._cipher = new I9.AES(e), this._prev = Ku.from(r), this._cache = Ku.allocUnsafe(0), this._secCache = Ku.allocUnsafe(0), this._decrypt = o, this._mode = t;
    }
    T9(_s, qm);
    _s.prototype._update = function(t) {
      return this._mode.encrypt(this, t, this._decrypt);
    };
    _s.prototype._final = function() {
      this._cipher.scrub();
    };
    Im.exports = _s;
  });
  Ba = T2((OT, Tm) => {
    var qn = Te().Buffer, k9 = Ao();
    function L9(t, e, r, o) {
      if (qn.isBuffer(t) || (t = qn.from(t, "binary")), e && (qn.isBuffer(e) || (e = qn.from(e, "binary")), e.length !== 8))
        throw new RangeError("salt should be Buffer with 8 byte length");
      for (var f = r / 8, p = qn.alloc(f), m2 = qn.alloc(o || 0), y2 = qn.alloc(0);f > 0 || o > 0; ) {
        var M = new k9;
        M.update(y2), M.update(t), e && M.update(e), y2 = M.digest();
        var x = 0;
        if (f > 0) {
          var S = p.length - f;
          x = Math.min(f, y2.length), y2.copy(p, S, 0, x), f -= x;
        }
        if (x < y2.length && o > 0) {
          var E2 = m2.length - o, B = Math.min(o, y2.length - x);
          y2.copy(m2, E2, x, x + B), o -= B;
        }
      }
      return y2.fill(0), { key: p, iv: m2 };
    }
    Tm.exports = L9;
  });
  Dm = T2((Zu) => {
    var km = ws(), N9 = Wu(), Mi = Te().Buffer, D9 = ju(), Lm = yi(), P9 = Aa(), C9 = Ba(), O9 = Ie();
    function qa(t, e, r) {
      Lm.call(this), this._cache = new xs, this._cipher = new P9.AES(e), this._prev = Mi.from(r), this._mode = t, this._autopadding = true;
    }
    O9(qa, Lm);
    qa.prototype._update = function(t) {
      this._cache.add(t);
      for (var e, r, o = [];e = this._cache.get(); )
        r = this._mode.encrypt(this, e), o.push(r);
      return Mi.concat(o);
    };
    var F9 = Mi.alloc(16, 16);
    qa.prototype._final = function() {
      var t = this._cache.flush();
      if (this._autopadding)
        return t = this._mode.encrypt(this, t), this._cipher.scrub(), t;
      if (!t.equals(F9))
        throw this._cipher.scrub(), new Error("data not multiple of block length");
    };
    qa.prototype.setAutoPadding = function(t) {
      return this._autopadding = !!t, this;
    };
    function xs() {
      this.cache = Mi.allocUnsafe(0);
    }
    xs.prototype.add = function(t) {
      this.cache = Mi.concat([this.cache, t]);
    };
    xs.prototype.get = function() {
      if (this.cache.length > 15) {
        var t = this.cache.slice(0, 16);
        return this.cache = this.cache.slice(16), t;
      }
      return null;
    };
    xs.prototype.flush = function() {
      for (var t = 16 - this.cache.length, e = Mi.allocUnsafe(t), r = -1;++r < t; )
        e.writeUInt8(t, r);
      return Mi.concat([this.cache, e]);
    };
    function Nm(t, e, r) {
      var o = km[t.toLowerCase()];
      if (!o)
        throw new TypeError("invalid suite type");
      if (typeof e == "string" && (e = Mi.from(e)), e.length !== o.key / 8)
        throw new TypeError("invalid key length " + e.length);
      if (typeof r == "string" && (r = Mi.from(r)), o.mode !== "GCM" && r.length !== o.iv)
        throw new TypeError("invalid iv length " + r.length);
      return o.type === "stream" ? new D9(o.module, e, r) : o.type === "auth" ? new N9(o.module, e, r) : new qa(o.module, e, r);
    }
    function U9(t, e) {
      var r = km[t.toLowerCase()];
      if (!r)
        throw new TypeError("invalid suite type");
      var o = C9(e, false, r.key, r.iv);
      return Nm(t, o.key, o.iv);
    }
    Zu.createCipheriv = Nm;
    Zu.createCipher = U9;
  });
  Fm = T2((Vu) => {
    var z9 = Wu(), Mf = Te().Buffer, Pm = ws(), H9 = ju(), Cm = yi(), W9 = Aa(), K9 = Ba(), j9 = Ie();
    function Ia(t, e, r) {
      Cm.call(this), this._cache = new Ss, this._last = undefined, this._cipher = new W9.AES(e), this._prev = Mf.from(r), this._mode = t, this._autopadding = true;
    }
    j9(Ia, Cm);
    Ia.prototype._update = function(t) {
      this._cache.add(t);
      for (var e, r, o = [];e = this._cache.get(this._autopadding); )
        r = this._mode.decrypt(this, e), o.push(r);
      return Mf.concat(o);
    };
    Ia.prototype._final = function() {
      var t = this._cache.flush();
      if (this._autopadding)
        return Z9(this._mode.decrypt(this, t));
      if (t)
        throw new Error("data not multiple of block length");
    };
    Ia.prototype.setAutoPadding = function(t) {
      return this._autopadding = !!t, this;
    };
    function Ss() {
      this.cache = Mf.allocUnsafe(0);
    }
    Ss.prototype.add = function(t) {
      this.cache = Mf.concat([this.cache, t]);
    };
    Ss.prototype.get = function(t) {
      var e;
      if (t) {
        if (this.cache.length > 16)
          return e = this.cache.slice(0, 16), this.cache = this.cache.slice(16), e;
      } else if (this.cache.length >= 16)
        return e = this.cache.slice(0, 16), this.cache = this.cache.slice(16), e;
      return null;
    };
    Ss.prototype.flush = function() {
      if (this.cache.length)
        return this.cache;
    };
    function Z9(t) {
      var e = t[15];
      if (e < 1 || e > 16)
        throw new Error("unable to decrypt data");
      for (var r = -1;++r < e; )
        if (t[r + (16 - e)] !== e)
          throw new Error("unable to decrypt data");
      if (e !== 16)
        return t.slice(0, 16 - e);
    }
    function Om(t, e, r) {
      var o = Pm[t.toLowerCase()];
      if (!o)
        throw new TypeError("invalid suite type");
      if (typeof r == "string" && (r = Mf.from(r)), o.mode !== "GCM" && r.length !== o.iv)
        throw new TypeError("invalid iv length " + r.length);
      if (typeof e == "string" && (e = Mf.from(e)), e.length !== o.key / 8)
        throw new TypeError("invalid key length " + e.length);
      return o.type === "stream" ? new H9(o.module, e, r, true) : o.type === "auth" ? new z9(o.module, e, r, true) : new Ia(o.module, e, r);
    }
    function V9(t, e) {
      var r = Pm[t.toLowerCase()];
      if (!r)
        throw new TypeError("invalid suite type");
      var o = K9(e, false, r.key, r.iv);
      return Om(t, o.key, o.iv);
    }
    Vu.createDecipher = V9;
    Vu.createDecipheriv = Om;
  });
  Es = T2((Nr) => {
    var Um = Dm(), zm = Fm(), $9 = Fu();
    function G9() {
      return Object.keys($9);
    }
    Nr.createCipher = Nr.Cipher = Um.createCipher;
    Nr.createCipheriv = Nr.Cipheriv = Um.createCipheriv;
    Nr.createDecipher = Nr.Decipher = zm.createDecipher;
    Nr.createDecipheriv = Nr.Decipheriv = zm.createDecipheriv;
    Nr.listCiphers = Nr.getCiphers = G9;
  });
  Hm = T2((_i) => {
    _i["des-ecb"] = { key: 8, iv: 0 };
    _i["des-cbc"] = _i.des = { key: 8, iv: 8 };
    _i["des-ede3-cbc"] = _i.des3 = { key: 24, iv: 8 };
    _i["des-ede3"] = { key: 24, iv: 0 };
    _i["des-ede-cbc"] = { key: 16, iv: 8 };
    _i["des-ede"] = { key: 16, iv: 0 };
  });
  Vm = T2((Dr) => {
    var Wm = im(), $u = Es(), Ki = ws(), xi = Hm(), Km = Ba();
    function Y9(t, e) {
      t = t.toLowerCase();
      var r, o;
      if (Ki[t])
        r = Ki[t].key, o = Ki[t].iv;
      else if (xi[t])
        r = xi[t].key * 8, o = xi[t].iv;
      else
        throw new TypeError("invalid suite type");
      var f = Km(e, false, r, o);
      return jm(t, f.key, f.iv);
    }
    function X9(t, e) {
      t = t.toLowerCase();
      var r, o;
      if (Ki[t])
        r = Ki[t].key, o = Ki[t].iv;
      else if (xi[t])
        r = xi[t].key * 8, o = xi[t].iv;
      else
        throw new TypeError("invalid suite type");
      var f = Km(e, false, r, o);
      return Zm(t, f.key, f.iv);
    }
    function jm(t, e, r) {
      if (t = t.toLowerCase(), Ki[t])
        return $u.createCipheriv(t, e, r);
      if (xi[t])
        return new Wm({ key: e, iv: r, mode: t });
      throw new TypeError("invalid suite type");
    }
    function Zm(t, e, r) {
      if (t = t.toLowerCase(), Ki[t])
        return $u.createDecipheriv(t, e, r);
      if (xi[t])
        return new Wm({ key: e, iv: r, mode: t, decrypt: true });
      throw new TypeError("invalid suite type");
    }
    function J9() {
      return Object.keys(xi).concat($u.getCiphers());
    }
    Dr.createCipher = Dr.Cipher = Y9;
    Dr.createCipheriv = Dr.Cipheriv = jm;
    Dr.createDecipher = Dr.Decipher = X9;
    Dr.createDecipheriv = Dr.Decipheriv = Zm;
    Dr.listCiphers = Dr.getCiphers = J9;
  });
  ji = T2(() => {
  });
  Yu = T2(($m, Gu) => {
    (function(t, e) {
      function r(v, i) {
        if (!v)
          throw new Error(i || "Assertion failed");
      }
      function o(v, i) {
        v.super_ = i;
        var a = function() {
        };
        a.prototype = i.prototype, v.prototype = new a, v.prototype.constructor = v;
      }
      function f(v, i, a) {
        if (f.isBN(v))
          return v;
        this.negative = 0, this.words = null, this.length = 0, this.red = null, v !== null && ((i === "le" || i === "be") && (a = i, i = 10), this._init(v || 0, i || 10, a || "be"));
      }
      typeof t == "object" ? t.exports = f : e.BN = f, f.BN = f, f.wordSize = 26;
      var p;
      try {
        typeof window < "u" && typeof window.Buffer < "u" ? p = window.Buffer : p = ji().Buffer;
      } catch {
      }
      f.isBN = function(i) {
        return i instanceof f ? true : i !== null && typeof i == "object" && i.constructor.wordSize === f.wordSize && Array.isArray(i.words);
      }, f.max = function(i, a) {
        return i.cmp(a) > 0 ? i : a;
      }, f.min = function(i, a) {
        return i.cmp(a) < 0 ? i : a;
      }, f.prototype._init = function(i, a, h2) {
        if (typeof i == "number")
          return this._initNumber(i, a, h2);
        if (typeof i == "object")
          return this._initArray(i, a, h2);
        a === "hex" && (a = 16), r(a === (a | 0) && a >= 2 && a <= 36), i = i.toString().replace(/\s+/g, "");
        var s = 0;
        i[0] === "-" && (s++, this.negative = 1), s < i.length && (a === 16 ? this._parseHex(i, s, h2) : (this._parseBase(i, a, s), h2 === "le" && this._initArray(this.toArray(), a, h2)));
      }, f.prototype._initNumber = function(i, a, h2) {
        i < 0 && (this.negative = 1, i = -i), i < 67108864 ? (this.words = [i & 67108863], this.length = 1) : i < 4503599627370496 ? (this.words = [i & 67108863, i / 67108864 & 67108863], this.length = 2) : (r(i < 9007199254740992), this.words = [i & 67108863, i / 67108864 & 67108863, 1], this.length = 3), h2 === "le" && this._initArray(this.toArray(), a, h2);
      }, f.prototype._initArray = function(i, a, h2) {
        if (r(typeof i.length == "number"), i.length <= 0)
          return this.words = [0], this.length = 1, this;
        this.length = Math.ceil(i.length / 3), this.words = new Array(this.length);
        for (var s = 0;s < this.length; s++)
          this.words[s] = 0;
        var u, c, b2 = 0;
        if (h2 === "be")
          for (s = i.length - 1, u = 0;s >= 0; s -= 3)
            c = i[s] | i[s - 1] << 8 | i[s - 2] << 16, this.words[u] |= c << b2 & 67108863, this.words[u + 1] = c >>> 26 - b2 & 67108863, b2 += 24, b2 >= 26 && (b2 -= 26, u++);
        else if (h2 === "le")
          for (s = 0, u = 0;s < i.length; s += 3)
            c = i[s] | i[s + 1] << 8 | i[s + 2] << 16, this.words[u] |= c << b2 & 67108863, this.words[u + 1] = c >>> 26 - b2 & 67108863, b2 += 24, b2 >= 26 && (b2 -= 26, u++);
        return this.strip();
      };
      function m2(v, i) {
        var a = v.charCodeAt(i);
        return a >= 65 && a <= 70 ? a - 55 : a >= 97 && a <= 102 ? a - 87 : a - 48 & 15;
      }
      function y2(v, i, a) {
        var h2 = m2(v, a);
        return a - 1 >= i && (h2 |= m2(v, a - 1) << 4), h2;
      }
      f.prototype._parseHex = function(i, a, h2) {
        this.length = Math.ceil((i.length - a) / 6), this.words = new Array(this.length);
        for (var s = 0;s < this.length; s++)
          this.words[s] = 0;
        var u = 0, c = 0, b2;
        if (h2 === "be")
          for (s = i.length - 1;s >= a; s -= 2)
            b2 = y2(i, a, s) << u, this.words[c] |= b2 & 67108863, u >= 18 ? (u -= 18, c += 1, this.words[c] |= b2 >>> 26) : u += 8;
        else {
          var l = i.length - a;
          for (s = l % 2 === 0 ? a + 1 : a;s < i.length; s += 2)
            b2 = y2(i, a, s) << u, this.words[c] |= b2 & 67108863, u >= 18 ? (u -= 18, c += 1, this.words[c] |= b2 >>> 26) : u += 8;
        }
        this.strip();
      };
      function M(v, i, a, h2) {
        for (var s = 0, u = Math.min(v.length, a), c = i;c < u; c++) {
          var b2 = v.charCodeAt(c) - 48;
          s *= h2, b2 >= 49 ? s += b2 - 49 + 10 : b2 >= 17 ? s += b2 - 17 + 10 : s += b2;
        }
        return s;
      }
      f.prototype._parseBase = function(i, a, h2) {
        this.words = [0], this.length = 1;
        for (var s = 0, u = 1;u <= 67108863; u *= a)
          s++;
        s--, u = u / a | 0;
        for (var c = i.length - h2, b2 = c % s, l = Math.min(c, c - b2) + h2, n = 0, d = h2;d < l; d += s)
          n = M(i, d, d + s, a), this.imuln(u), this.words[0] + n < 67108864 ? this.words[0] += n : this._iaddn(n);
        if (b2 !== 0) {
          var w = 1;
          for (n = M(i, d, i.length, a), d = 0;d < b2; d++)
            w *= a;
          this.imuln(w), this.words[0] + n < 67108864 ? this.words[0] += n : this._iaddn(n);
        }
        this.strip();
      }, f.prototype.copy = function(i) {
        i.words = new Array(this.length);
        for (var a = 0;a < this.length; a++)
          i.words[a] = this.words[a];
        i.length = this.length, i.negative = this.negative, i.red = this.red;
      }, f.prototype.clone = function() {
        var i = new f(null);
        return this.copy(i), i;
      }, f.prototype._expand = function(i) {
        for (;this.length < i; )
          this.words[this.length++] = 0;
        return this;
      }, f.prototype.strip = function() {
        for (;this.length > 1 && this.words[this.length - 1] === 0; )
          this.length--;
        return this._normSign();
      }, f.prototype._normSign = function() {
        return this.length === 1 && this.words[0] === 0 && (this.negative = 0), this;
      }, f.prototype.inspect = function() {
        return (this.red ? "<BN-R: " : "<BN: ") + this.toString(16) + ">";
      };
      var x = ["", "0", "00", "000", "0000", "00000", "000000", "0000000", "00000000", "000000000", "0000000000", "00000000000", "000000000000", "0000000000000", "00000000000000", "000000000000000", "0000000000000000", "00000000000000000", "000000000000000000", "0000000000000000000", "00000000000000000000", "000000000000000000000", "0000000000000000000000", "00000000000000000000000", "000000000000000000000000", "0000000000000000000000000"], S = [0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5], E2 = [0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 1e7, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176];
      f.prototype.toString = function(i, a) {
        i = i || 10, a = a | 0 || 1;
        var h2;
        if (i === 16 || i === "hex") {
          h2 = "";
          for (var s = 0, u = 0, c = 0;c < this.length; c++) {
            var b2 = this.words[c], l = ((b2 << s | u) & 16777215).toString(16);
            u = b2 >>> 24 - s & 16777215, u !== 0 || c !== this.length - 1 ? h2 = x[6 - l.length] + l + h2 : h2 = l + h2, s += 2, s >= 26 && (s -= 26, c--);
          }
          for (u !== 0 && (h2 = u.toString(16) + h2);h2.length % a !== 0; )
            h2 = "0" + h2;
          return this.negative !== 0 && (h2 = "-" + h2), h2;
        }
        if (i === (i | 0) && i >= 2 && i <= 36) {
          var n = S[i], d = E2[i];
          h2 = "";
          var w = this.clone();
          for (w.negative = 0;!w.isZero(); ) {
            var g = w.modn(d).toString(i);
            w = w.idivn(d), w.isZero() ? h2 = g + h2 : h2 = x[n - g.length] + g + h2;
          }
          for (this.isZero() && (h2 = "0" + h2);h2.length % a !== 0; )
            h2 = "0" + h2;
          return this.negative !== 0 && (h2 = "-" + h2), h2;
        }
        r(false, "Base should be between 2 and 36");
      }, f.prototype.toNumber = function() {
        var i = this.words[0];
        return this.length === 2 ? i += this.words[1] * 67108864 : this.length === 3 && this.words[2] === 1 ? i += 4503599627370496 + this.words[1] * 67108864 : this.length > 2 && r(false, "Number can only safely store up to 53 bits"), this.negative !== 0 ? -i : i;
      }, f.prototype.toJSON = function() {
        return this.toString(16);
      }, f.prototype.toBuffer = function(i, a) {
        return r(typeof p < "u"), this.toArrayLike(p, i, a);
      }, f.prototype.toArray = function(i, a) {
        return this.toArrayLike(Array, i, a);
      }, f.prototype.toArrayLike = function(i, a, h2) {
        var s = this.byteLength(), u = h2 || Math.max(1, s);
        r(s <= u, "byte array longer than desired length"), r(u > 0, "Requested array length <= 0"), this.strip();
        var c = a === "le", b2 = new i(u), l, n, d = this.clone();
        if (c) {
          for (n = 0;!d.isZero(); n++)
            l = d.andln(255), d.iushrn(8), b2[n] = l;
          for (;n < u; n++)
            b2[n] = 0;
        } else {
          for (n = 0;n < u - s; n++)
            b2[n] = 0;
          for (n = 0;!d.isZero(); n++)
            l = d.andln(255), d.iushrn(8), b2[u - n - 1] = l;
        }
        return b2;
      }, Math.clz32 ? f.prototype._countBits = function(i) {
        return 32 - Math.clz32(i);
      } : f.prototype._countBits = function(i) {
        var a = i, h2 = 0;
        return a >= 4096 && (h2 += 13, a >>>= 13), a >= 64 && (h2 += 7, a >>>= 7), a >= 8 && (h2 += 4, a >>>= 4), a >= 2 && (h2 += 2, a >>>= 2), h2 + a;
      }, f.prototype._zeroBits = function(i) {
        if (i === 0)
          return 26;
        var a = i, h2 = 0;
        return (a & 8191) === 0 && (h2 += 13, a >>>= 13), (a & 127) === 0 && (h2 += 7, a >>>= 7), (a & 15) === 0 && (h2 += 4, a >>>= 4), (a & 3) === 0 && (h2 += 2, a >>>= 2), (a & 1) === 0 && h2++, h2;
      }, f.prototype.bitLength = function() {
        var i = this.words[this.length - 1], a = this._countBits(i);
        return (this.length - 1) * 26 + a;
      };
      function B(v) {
        for (var i = new Array(v.bitLength()), a = 0;a < i.length; a++) {
          var h2 = a / 26 | 0, s = a % 26;
          i[a] = (v.words[h2] & 1 << s) >>> s;
        }
        return i;
      }
      f.prototype.zeroBits = function() {
        if (this.isZero())
          return 0;
        for (var i = 0, a = 0;a < this.length; a++) {
          var h2 = this._zeroBits(this.words[a]);
          if (i += h2, h2 !== 26)
            break;
        }
        return i;
      }, f.prototype.byteLength = function() {
        return Math.ceil(this.bitLength() / 8);
      }, f.prototype.toTwos = function(i) {
        return this.negative !== 0 ? this.abs().inotn(i).iaddn(1) : this.clone();
      }, f.prototype.fromTwos = function(i) {
        return this.testn(i - 1) ? this.notn(i).iaddn(1).ineg() : this.clone();
      }, f.prototype.isNeg = function() {
        return this.negative !== 0;
      }, f.prototype.neg = function() {
        return this.clone().ineg();
      }, f.prototype.ineg = function() {
        return this.isZero() || (this.negative ^= 1), this;
      }, f.prototype.iuor = function(i) {
        for (;this.length < i.length; )
          this.words[this.length++] = 0;
        for (var a = 0;a < i.length; a++)
          this.words[a] = this.words[a] | i.words[a];
        return this.strip();
      }, f.prototype.ior = function(i) {
        return r((this.negative | i.negative) === 0), this.iuor(i);
      }, f.prototype.or = function(i) {
        return this.length > i.length ? this.clone().ior(i) : i.clone().ior(this);
      }, f.prototype.uor = function(i) {
        return this.length > i.length ? this.clone().iuor(i) : i.clone().iuor(this);
      }, f.prototype.iuand = function(i) {
        var a;
        this.length > i.length ? a = i : a = this;
        for (var h2 = 0;h2 < a.length; h2++)
          this.words[h2] = this.words[h2] & i.words[h2];
        return this.length = a.length, this.strip();
      }, f.prototype.iand = function(i) {
        return r((this.negative | i.negative) === 0), this.iuand(i);
      }, f.prototype.and = function(i) {
        return this.length > i.length ? this.clone().iand(i) : i.clone().iand(this);
      }, f.prototype.uand = function(i) {
        return this.length > i.length ? this.clone().iuand(i) : i.clone().iuand(this);
      }, f.prototype.iuxor = function(i) {
        var a, h2;
        this.length > i.length ? (a = this, h2 = i) : (a = i, h2 = this);
        for (var s = 0;s < h2.length; s++)
          this.words[s] = a.words[s] ^ h2.words[s];
        if (this !== a)
          for (;s < a.length; s++)
            this.words[s] = a.words[s];
        return this.length = a.length, this.strip();
      }, f.prototype.ixor = function(i) {
        return r((this.negative | i.negative) === 0), this.iuxor(i);
      }, f.prototype.xor = function(i) {
        return this.length > i.length ? this.clone().ixor(i) : i.clone().ixor(this);
      }, f.prototype.uxor = function(i) {
        return this.length > i.length ? this.clone().iuxor(i) : i.clone().iuxor(this);
      }, f.prototype.inotn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = Math.ceil(i / 26) | 0, h2 = i % 26;
        this._expand(a), h2 > 0 && a--;
        for (var s = 0;s < a; s++)
          this.words[s] = ~this.words[s] & 67108863;
        return h2 > 0 && (this.words[s] = ~this.words[s] & 67108863 >> 26 - h2), this.strip();
      }, f.prototype.notn = function(i) {
        return this.clone().inotn(i);
      }, f.prototype.setn = function(i, a) {
        r(typeof i == "number" && i >= 0);
        var h2 = i / 26 | 0, s = i % 26;
        return this._expand(h2 + 1), a ? this.words[h2] = this.words[h2] | 1 << s : this.words[h2] = this.words[h2] & ~(1 << s), this.strip();
      }, f.prototype.iadd = function(i) {
        var a;
        if (this.negative !== 0 && i.negative === 0)
          return this.negative = 0, a = this.isub(i), this.negative ^= 1, this._normSign();
        if (this.negative === 0 && i.negative !== 0)
          return i.negative = 0, a = this.isub(i), i.negative = 1, a._normSign();
        var h2, s;
        this.length > i.length ? (h2 = this, s = i) : (h2 = i, s = this);
        for (var u = 0, c = 0;c < s.length; c++)
          a = (h2.words[c] | 0) + (s.words[c] | 0) + u, this.words[c] = a & 67108863, u = a >>> 26;
        for (;u !== 0 && c < h2.length; c++)
          a = (h2.words[c] | 0) + u, this.words[c] = a & 67108863, u = a >>> 26;
        if (this.length = h2.length, u !== 0)
          this.words[this.length] = u, this.length++;
        else if (h2 !== this)
          for (;c < h2.length; c++)
            this.words[c] = h2.words[c];
        return this;
      }, f.prototype.add = function(i) {
        var a;
        return i.negative !== 0 && this.negative === 0 ? (i.negative = 0, a = this.sub(i), i.negative ^= 1, a) : i.negative === 0 && this.negative !== 0 ? (this.negative = 0, a = i.sub(this), this.negative = 1, a) : this.length > i.length ? this.clone().iadd(i) : i.clone().iadd(this);
      }, f.prototype.isub = function(i) {
        if (i.negative !== 0) {
          i.negative = 0;
          var a = this.iadd(i);
          return i.negative = 1, a._normSign();
        } else if (this.negative !== 0)
          return this.negative = 0, this.iadd(i), this.negative = 1, this._normSign();
        var h2 = this.cmp(i);
        if (h2 === 0)
          return this.negative = 0, this.length = 1, this.words[0] = 0, this;
        var s, u;
        h2 > 0 ? (s = this, u = i) : (s = i, u = this);
        for (var c = 0, b2 = 0;b2 < u.length; b2++)
          a = (s.words[b2] | 0) - (u.words[b2] | 0) + c, c = a >> 26, this.words[b2] = a & 67108863;
        for (;c !== 0 && b2 < s.length; b2++)
          a = (s.words[b2] | 0) + c, c = a >> 26, this.words[b2] = a & 67108863;
        if (c === 0 && b2 < s.length && s !== this)
          for (;b2 < s.length; b2++)
            this.words[b2] = s.words[b2];
        return this.length = Math.max(this.length, b2), s !== this && (this.negative = 1), this.strip();
      }, f.prototype.sub = function(i) {
        return this.clone().isub(i);
      };
      function q2(v, i, a) {
        a.negative = i.negative ^ v.negative;
        var h2 = v.length + i.length | 0;
        a.length = h2, h2 = h2 - 1 | 0;
        var s = v.words[0] | 0, u = i.words[0] | 0, c = s * u, b2 = c & 67108863, l = c / 67108864 | 0;
        a.words[0] = b2;
        for (var n = 1;n < h2; n++) {
          for (var d = l >>> 26, w = l & 67108863, g = Math.min(n, i.length - 1), _2 = Math.max(0, n - v.length + 1);_2 <= g; _2++) {
            var A2 = n - _2 | 0;
            s = v.words[A2] | 0, u = i.words[_2] | 0, c = s * u + w, d += c / 67108864 | 0, w = c & 67108863;
          }
          a.words[n] = w | 0, l = d | 0;
        }
        return l !== 0 ? a.words[n] = l | 0 : a.length--, a.strip();
      }
      var L2 = function(i, a, h2) {
        var s = i.words, u = a.words, c = h2.words, b2 = 0, l, n, d, w = s[0] | 0, g = w & 8191, _2 = w >>> 13, A2 = s[1] | 0, R2 = A2 & 8191, I = A2 >>> 13, Me = s[2] | 0, k = Me & 8191, D2 = Me >>> 13, nt = s[3] | 0, C2 = nt & 8191, O = nt >>> 13, vt = s[4] | 0, F = vt & 8191, U = vt >>> 13, bt = s[5] | 0, z2 = bt & 8191, H = bt >>> 13, mt = s[6] | 0, W = mt & 8191, K = mt >>> 13, gt = s[7] | 0, j = gt & 8191, Z = gt >>> 13, yt = s[8] | 0, V = yt & 8191, $ = yt >>> 13, wt = s[9] | 0, G = wt & 8191, Y = wt >>> 13, Mt = u[0] | 0, X = Mt & 8191, J = Mt >>> 13, _t = u[1] | 0, Q = _t & 8191, ee = _t >>> 13, xt = u[2] | 0, te = xt & 8191, re = xt >>> 13, St = u[3] | 0, ie = St & 8191, ne = St >>> 13, Et = u[4] | 0, fe = Et & 8191, ae = Et >>> 13, At = u[5] | 0, oe = At & 8191, se = At >>> 13, Rt = u[6] | 0, he = Rt & 8191, ue = Rt >>> 13, Bt = u[7] | 0, le = Bt & 8191, de = Bt >>> 13, qt = u[8] | 0, ce = qt & 8191, pe = qt >>> 13, It = u[9] | 0, ve = It & 8191, be = It >>> 13;
        h2.negative = i.negative ^ a.negative, h2.length = 19, l = Math.imul(g, X), n = Math.imul(g, J), n = n + Math.imul(_2, X) | 0, d = Math.imul(_2, J);
        var ft = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (ft >>> 26) | 0, ft &= 67108863, l = Math.imul(R2, X), n = Math.imul(R2, J), n = n + Math.imul(I, X) | 0, d = Math.imul(I, J), l = l + Math.imul(g, Q) | 0, n = n + Math.imul(g, ee) | 0, n = n + Math.imul(_2, Q) | 0, d = d + Math.imul(_2, ee) | 0;
        var Be = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Be >>> 26) | 0, Be &= 67108863, l = Math.imul(k, X), n = Math.imul(k, J), n = n + Math.imul(D2, X) | 0, d = Math.imul(D2, J), l = l + Math.imul(R2, Q) | 0, n = n + Math.imul(R2, ee) | 0, n = n + Math.imul(I, Q) | 0, d = d + Math.imul(I, ee) | 0, l = l + Math.imul(g, te) | 0, n = n + Math.imul(g, re) | 0, n = n + Math.imul(_2, te) | 0, d = d + Math.imul(_2, re) | 0;
        var qe = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (qe >>> 26) | 0, qe &= 67108863, l = Math.imul(C2, X), n = Math.imul(C2, J), n = n + Math.imul(O, X) | 0, d = Math.imul(O, J), l = l + Math.imul(k, Q) | 0, n = n + Math.imul(k, ee) | 0, n = n + Math.imul(D2, Q) | 0, d = d + Math.imul(D2, ee) | 0, l = l + Math.imul(R2, te) | 0, n = n + Math.imul(R2, re) | 0, n = n + Math.imul(I, te) | 0, d = d + Math.imul(I, re) | 0, l = l + Math.imul(g, ie) | 0, n = n + Math.imul(g, ne) | 0, n = n + Math.imul(_2, ie) | 0, d = d + Math.imul(_2, ne) | 0;
        var ze = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (ze >>> 26) | 0, ze &= 67108863, l = Math.imul(F, X), n = Math.imul(F, J), n = n + Math.imul(U, X) | 0, d = Math.imul(U, J), l = l + Math.imul(C2, Q) | 0, n = n + Math.imul(C2, ee) | 0, n = n + Math.imul(O, Q) | 0, d = d + Math.imul(O, ee) | 0, l = l + Math.imul(k, te) | 0, n = n + Math.imul(k, re) | 0, n = n + Math.imul(D2, te) | 0, d = d + Math.imul(D2, re) | 0, l = l + Math.imul(R2, ie) | 0, n = n + Math.imul(R2, ne) | 0, n = n + Math.imul(I, ie) | 0, d = d + Math.imul(I, ne) | 0, l = l + Math.imul(g, fe) | 0, n = n + Math.imul(g, ae) | 0, n = n + Math.imul(_2, fe) | 0, d = d + Math.imul(_2, ae) | 0;
        var He = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (He >>> 26) | 0, He &= 67108863, l = Math.imul(z2, X), n = Math.imul(z2, J), n = n + Math.imul(H, X) | 0, d = Math.imul(H, J), l = l + Math.imul(F, Q) | 0, n = n + Math.imul(F, ee) | 0, n = n + Math.imul(U, Q) | 0, d = d + Math.imul(U, ee) | 0, l = l + Math.imul(C2, te) | 0, n = n + Math.imul(C2, re) | 0, n = n + Math.imul(O, te) | 0, d = d + Math.imul(O, re) | 0, l = l + Math.imul(k, ie) | 0, n = n + Math.imul(k, ne) | 0, n = n + Math.imul(D2, ie) | 0, d = d + Math.imul(D2, ne) | 0, l = l + Math.imul(R2, fe) | 0, n = n + Math.imul(R2, ae) | 0, n = n + Math.imul(I, fe) | 0, d = d + Math.imul(I, ae) | 0, l = l + Math.imul(g, oe) | 0, n = n + Math.imul(g, se) | 0, n = n + Math.imul(_2, oe) | 0, d = d + Math.imul(_2, se) | 0;
        var We = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (We >>> 26) | 0, We &= 67108863, l = Math.imul(W, X), n = Math.imul(W, J), n = n + Math.imul(K, X) | 0, d = Math.imul(K, J), l = l + Math.imul(z2, Q) | 0, n = n + Math.imul(z2, ee) | 0, n = n + Math.imul(H, Q) | 0, d = d + Math.imul(H, ee) | 0, l = l + Math.imul(F, te) | 0, n = n + Math.imul(F, re) | 0, n = n + Math.imul(U, te) | 0, d = d + Math.imul(U, re) | 0, l = l + Math.imul(C2, ie) | 0, n = n + Math.imul(C2, ne) | 0, n = n + Math.imul(O, ie) | 0, d = d + Math.imul(O, ne) | 0, l = l + Math.imul(k, fe) | 0, n = n + Math.imul(k, ae) | 0, n = n + Math.imul(D2, fe) | 0, d = d + Math.imul(D2, ae) | 0, l = l + Math.imul(R2, oe) | 0, n = n + Math.imul(R2, se) | 0, n = n + Math.imul(I, oe) | 0, d = d + Math.imul(I, se) | 0, l = l + Math.imul(g, he) | 0, n = n + Math.imul(g, ue) | 0, n = n + Math.imul(_2, he) | 0, d = d + Math.imul(_2, ue) | 0;
        var Ke = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ke >>> 26) | 0, Ke &= 67108863, l = Math.imul(j, X), n = Math.imul(j, J), n = n + Math.imul(Z, X) | 0, d = Math.imul(Z, J), l = l + Math.imul(W, Q) | 0, n = n + Math.imul(W, ee) | 0, n = n + Math.imul(K, Q) | 0, d = d + Math.imul(K, ee) | 0, l = l + Math.imul(z2, te) | 0, n = n + Math.imul(z2, re) | 0, n = n + Math.imul(H, te) | 0, d = d + Math.imul(H, re) | 0, l = l + Math.imul(F, ie) | 0, n = n + Math.imul(F, ne) | 0, n = n + Math.imul(U, ie) | 0, d = d + Math.imul(U, ne) | 0, l = l + Math.imul(C2, fe) | 0, n = n + Math.imul(C2, ae) | 0, n = n + Math.imul(O, fe) | 0, d = d + Math.imul(O, ae) | 0, l = l + Math.imul(k, oe) | 0, n = n + Math.imul(k, se) | 0, n = n + Math.imul(D2, oe) | 0, d = d + Math.imul(D2, se) | 0, l = l + Math.imul(R2, he) | 0, n = n + Math.imul(R2, ue) | 0, n = n + Math.imul(I, he) | 0, d = d + Math.imul(I, ue) | 0, l = l + Math.imul(g, le) | 0, n = n + Math.imul(g, de) | 0, n = n + Math.imul(_2, le) | 0, d = d + Math.imul(_2, de) | 0;
        var je = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (je >>> 26) | 0, je &= 67108863, l = Math.imul(V, X), n = Math.imul(V, J), n = n + Math.imul($, X) | 0, d = Math.imul($, J), l = l + Math.imul(j, Q) | 0, n = n + Math.imul(j, ee) | 0, n = n + Math.imul(Z, Q) | 0, d = d + Math.imul(Z, ee) | 0, l = l + Math.imul(W, te) | 0, n = n + Math.imul(W, re) | 0, n = n + Math.imul(K, te) | 0, d = d + Math.imul(K, re) | 0, l = l + Math.imul(z2, ie) | 0, n = n + Math.imul(z2, ne) | 0, n = n + Math.imul(H, ie) | 0, d = d + Math.imul(H, ne) | 0, l = l + Math.imul(F, fe) | 0, n = n + Math.imul(F, ae) | 0, n = n + Math.imul(U, fe) | 0, d = d + Math.imul(U, ae) | 0, l = l + Math.imul(C2, oe) | 0, n = n + Math.imul(C2, se) | 0, n = n + Math.imul(O, oe) | 0, d = d + Math.imul(O, se) | 0, l = l + Math.imul(k, he) | 0, n = n + Math.imul(k, ue) | 0, n = n + Math.imul(D2, he) | 0, d = d + Math.imul(D2, ue) | 0, l = l + Math.imul(R2, le) | 0, n = n + Math.imul(R2, de) | 0, n = n + Math.imul(I, le) | 0, d = d + Math.imul(I, de) | 0, l = l + Math.imul(g, ce) | 0, n = n + Math.imul(g, pe) | 0, n = n + Math.imul(_2, ce) | 0, d = d + Math.imul(_2, pe) | 0;
        var Ze = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ze >>> 26) | 0, Ze &= 67108863, l = Math.imul(G, X), n = Math.imul(G, J), n = n + Math.imul(Y, X) | 0, d = Math.imul(Y, J), l = l + Math.imul(V, Q) | 0, n = n + Math.imul(V, ee) | 0, n = n + Math.imul($, Q) | 0, d = d + Math.imul($, ee) | 0, l = l + Math.imul(j, te) | 0, n = n + Math.imul(j, re) | 0, n = n + Math.imul(Z, te) | 0, d = d + Math.imul(Z, re) | 0, l = l + Math.imul(W, ie) | 0, n = n + Math.imul(W, ne) | 0, n = n + Math.imul(K, ie) | 0, d = d + Math.imul(K, ne) | 0, l = l + Math.imul(z2, fe) | 0, n = n + Math.imul(z2, ae) | 0, n = n + Math.imul(H, fe) | 0, d = d + Math.imul(H, ae) | 0, l = l + Math.imul(F, oe) | 0, n = n + Math.imul(F, se) | 0, n = n + Math.imul(U, oe) | 0, d = d + Math.imul(U, se) | 0, l = l + Math.imul(C2, he) | 0, n = n + Math.imul(C2, ue) | 0, n = n + Math.imul(O, he) | 0, d = d + Math.imul(O, ue) | 0, l = l + Math.imul(k, le) | 0, n = n + Math.imul(k, de) | 0, n = n + Math.imul(D2, le) | 0, d = d + Math.imul(D2, de) | 0, l = l + Math.imul(R2, ce) | 0, n = n + Math.imul(R2, pe) | 0, n = n + Math.imul(I, ce) | 0, d = d + Math.imul(I, pe) | 0, l = l + Math.imul(g, ve) | 0, n = n + Math.imul(g, be) | 0, n = n + Math.imul(_2, ve) | 0, d = d + Math.imul(_2, be) | 0;
        var Ve = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ve >>> 26) | 0, Ve &= 67108863, l = Math.imul(G, Q), n = Math.imul(G, ee), n = n + Math.imul(Y, Q) | 0, d = Math.imul(Y, ee), l = l + Math.imul(V, te) | 0, n = n + Math.imul(V, re) | 0, n = n + Math.imul($, te) | 0, d = d + Math.imul($, re) | 0, l = l + Math.imul(j, ie) | 0, n = n + Math.imul(j, ne) | 0, n = n + Math.imul(Z, ie) | 0, d = d + Math.imul(Z, ne) | 0, l = l + Math.imul(W, fe) | 0, n = n + Math.imul(W, ae) | 0, n = n + Math.imul(K, fe) | 0, d = d + Math.imul(K, ae) | 0, l = l + Math.imul(z2, oe) | 0, n = n + Math.imul(z2, se) | 0, n = n + Math.imul(H, oe) | 0, d = d + Math.imul(H, se) | 0, l = l + Math.imul(F, he) | 0, n = n + Math.imul(F, ue) | 0, n = n + Math.imul(U, he) | 0, d = d + Math.imul(U, ue) | 0, l = l + Math.imul(C2, le) | 0, n = n + Math.imul(C2, de) | 0, n = n + Math.imul(O, le) | 0, d = d + Math.imul(O, de) | 0, l = l + Math.imul(k, ce) | 0, n = n + Math.imul(k, pe) | 0, n = n + Math.imul(D2, ce) | 0, d = d + Math.imul(D2, pe) | 0, l = l + Math.imul(R2, ve) | 0, n = n + Math.imul(R2, be) | 0, n = n + Math.imul(I, ve) | 0, d = d + Math.imul(I, be) | 0;
        var $e = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + ($e >>> 26) | 0, $e &= 67108863, l = Math.imul(G, te), n = Math.imul(G, re), n = n + Math.imul(Y, te) | 0, d = Math.imul(Y, re), l = l + Math.imul(V, ie) | 0, n = n + Math.imul(V, ne) | 0, n = n + Math.imul($, ie) | 0, d = d + Math.imul($, ne) | 0, l = l + Math.imul(j, fe) | 0, n = n + Math.imul(j, ae) | 0, n = n + Math.imul(Z, fe) | 0, d = d + Math.imul(Z, ae) | 0, l = l + Math.imul(W, oe) | 0, n = n + Math.imul(W, se) | 0, n = n + Math.imul(K, oe) | 0, d = d + Math.imul(K, se) | 0, l = l + Math.imul(z2, he) | 0, n = n + Math.imul(z2, ue) | 0, n = n + Math.imul(H, he) | 0, d = d + Math.imul(H, ue) | 0, l = l + Math.imul(F, le) | 0, n = n + Math.imul(F, de) | 0, n = n + Math.imul(U, le) | 0, d = d + Math.imul(U, de) | 0, l = l + Math.imul(C2, ce) | 0, n = n + Math.imul(C2, pe) | 0, n = n + Math.imul(O, ce) | 0, d = d + Math.imul(O, pe) | 0, l = l + Math.imul(k, ve) | 0, n = n + Math.imul(k, be) | 0, n = n + Math.imul(D2, ve) | 0, d = d + Math.imul(D2, be) | 0;
        var Ge = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ge >>> 26) | 0, Ge &= 67108863, l = Math.imul(G, ie), n = Math.imul(G, ne), n = n + Math.imul(Y, ie) | 0, d = Math.imul(Y, ne), l = l + Math.imul(V, fe) | 0, n = n + Math.imul(V, ae) | 0, n = n + Math.imul($, fe) | 0, d = d + Math.imul($, ae) | 0, l = l + Math.imul(j, oe) | 0, n = n + Math.imul(j, se) | 0, n = n + Math.imul(Z, oe) | 0, d = d + Math.imul(Z, se) | 0, l = l + Math.imul(W, he) | 0, n = n + Math.imul(W, ue) | 0, n = n + Math.imul(K, he) | 0, d = d + Math.imul(K, ue) | 0, l = l + Math.imul(z2, le) | 0, n = n + Math.imul(z2, de) | 0, n = n + Math.imul(H, le) | 0, d = d + Math.imul(H, de) | 0, l = l + Math.imul(F, ce) | 0, n = n + Math.imul(F, pe) | 0, n = n + Math.imul(U, ce) | 0, d = d + Math.imul(U, pe) | 0, l = l + Math.imul(C2, ve) | 0, n = n + Math.imul(C2, be) | 0, n = n + Math.imul(O, ve) | 0, d = d + Math.imul(O, be) | 0;
        var Ye = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ye >>> 26) | 0, Ye &= 67108863, l = Math.imul(G, fe), n = Math.imul(G, ae), n = n + Math.imul(Y, fe) | 0, d = Math.imul(Y, ae), l = l + Math.imul(V, oe) | 0, n = n + Math.imul(V, se) | 0, n = n + Math.imul($, oe) | 0, d = d + Math.imul($, se) | 0, l = l + Math.imul(j, he) | 0, n = n + Math.imul(j, ue) | 0, n = n + Math.imul(Z, he) | 0, d = d + Math.imul(Z, ue) | 0, l = l + Math.imul(W, le) | 0, n = n + Math.imul(W, de) | 0, n = n + Math.imul(K, le) | 0, d = d + Math.imul(K, de) | 0, l = l + Math.imul(z2, ce) | 0, n = n + Math.imul(z2, pe) | 0, n = n + Math.imul(H, ce) | 0, d = d + Math.imul(H, pe) | 0, l = l + Math.imul(F, ve) | 0, n = n + Math.imul(F, be) | 0, n = n + Math.imul(U, ve) | 0, d = d + Math.imul(U, be) | 0;
        var Xe = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Xe >>> 26) | 0, Xe &= 67108863, l = Math.imul(G, oe), n = Math.imul(G, se), n = n + Math.imul(Y, oe) | 0, d = Math.imul(Y, se), l = l + Math.imul(V, he) | 0, n = n + Math.imul(V, ue) | 0, n = n + Math.imul($, he) | 0, d = d + Math.imul($, ue) | 0, l = l + Math.imul(j, le) | 0, n = n + Math.imul(j, de) | 0, n = n + Math.imul(Z, le) | 0, d = d + Math.imul(Z, de) | 0, l = l + Math.imul(W, ce) | 0, n = n + Math.imul(W, pe) | 0, n = n + Math.imul(K, ce) | 0, d = d + Math.imul(K, pe) | 0, l = l + Math.imul(z2, ve) | 0, n = n + Math.imul(z2, be) | 0, n = n + Math.imul(H, ve) | 0, d = d + Math.imul(H, be) | 0;
        var Je = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Je >>> 26) | 0, Je &= 67108863, l = Math.imul(G, he), n = Math.imul(G, ue), n = n + Math.imul(Y, he) | 0, d = Math.imul(Y, ue), l = l + Math.imul(V, le) | 0, n = n + Math.imul(V, de) | 0, n = n + Math.imul($, le) | 0, d = d + Math.imul($, de) | 0, l = l + Math.imul(j, ce) | 0, n = n + Math.imul(j, pe) | 0, n = n + Math.imul(Z, ce) | 0, d = d + Math.imul(Z, pe) | 0, l = l + Math.imul(W, ve) | 0, n = n + Math.imul(W, be) | 0, n = n + Math.imul(K, ve) | 0, d = d + Math.imul(K, be) | 0;
        var Qe = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Qe >>> 26) | 0, Qe &= 67108863, l = Math.imul(G, le), n = Math.imul(G, de), n = n + Math.imul(Y, le) | 0, d = Math.imul(Y, de), l = l + Math.imul(V, ce) | 0, n = n + Math.imul(V, pe) | 0, n = n + Math.imul($, ce) | 0, d = d + Math.imul($, pe) | 0, l = l + Math.imul(j, ve) | 0, n = n + Math.imul(j, be) | 0, n = n + Math.imul(Z, ve) | 0, d = d + Math.imul(Z, be) | 0;
        var et = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (et >>> 26) | 0, et &= 67108863, l = Math.imul(G, ce), n = Math.imul(G, pe), n = n + Math.imul(Y, ce) | 0, d = Math.imul(Y, pe), l = l + Math.imul(V, ve) | 0, n = n + Math.imul(V, be) | 0, n = n + Math.imul($, ve) | 0, d = d + Math.imul($, be) | 0;
        var tt = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (tt >>> 26) | 0, tt &= 67108863, l = Math.imul(G, ve), n = Math.imul(G, be), n = n + Math.imul(Y, ve) | 0, d = Math.imul(Y, be);
        var rt = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        return b2 = (d + (n >>> 13) | 0) + (rt >>> 26) | 0, rt &= 67108863, c[0] = ft, c[1] = Be, c[2] = qe, c[3] = ze, c[4] = He, c[5] = We, c[6] = Ke, c[7] = je, c[8] = Ze, c[9] = Ve, c[10] = $e, c[11] = Ge, c[12] = Ye, c[13] = Xe, c[14] = Je, c[15] = Qe, c[16] = et, c[17] = tt, c[18] = rt, b2 !== 0 && (c[19] = b2, h2.length++), h2;
      };
      Math.imul || (L2 = q2);
      function ge(v, i, a) {
        a.negative = i.negative ^ v.negative, a.length = v.length + i.length;
        for (var h2 = 0, s = 0, u = 0;u < a.length - 1; u++) {
          var c = s;
          s = 0;
          for (var b2 = h2 & 67108863, l = Math.min(u, i.length - 1), n = Math.max(0, u - v.length + 1);n <= l; n++) {
            var d = u - n, w = v.words[d] | 0, g = i.words[n] | 0, _2 = w * g, A2 = _2 & 67108863;
            c = c + (_2 / 67108864 | 0) | 0, A2 = A2 + b2 | 0, b2 = A2 & 67108863, c = c + (A2 >>> 26) | 0, s += c >>> 26, c &= 67108863;
          }
          a.words[u] = b2, h2 = c, c = s;
        }
        return h2 !== 0 ? a.words[u] = h2 : a.length--, a.strip();
      }
      function _e(v, i, a) {
        var h2 = new N;
        return h2.mulp(v, i, a);
      }
      f.prototype.mulTo = function(i, a) {
        var h2, s = this.length + i.length;
        return this.length === 10 && i.length === 10 ? h2 = L2(this, i, a) : s < 63 ? h2 = q2(this, i, a) : s < 1024 ? h2 = ge(this, i, a) : h2 = _e(this, i, a), h2;
      };
      function N(v, i) {
        this.x = v, this.y = i;
      }
      N.prototype.makeRBT = function(i) {
        for (var a = new Array(i), h2 = f.prototype._countBits(i) - 1, s = 0;s < i; s++)
          a[s] = this.revBin(s, h2, i);
        return a;
      }, N.prototype.revBin = function(i, a, h2) {
        if (i === 0 || i === h2 - 1)
          return i;
        for (var s = 0, u = 0;u < a; u++)
          s |= (i & 1) << a - u - 1, i >>= 1;
        return s;
      }, N.prototype.permute = function(i, a, h2, s, u, c) {
        for (var b2 = 0;b2 < c; b2++)
          s[b2] = a[i[b2]], u[b2] = h2[i[b2]];
      }, N.prototype.transform = function(i, a, h2, s, u, c) {
        this.permute(c, i, a, h2, s, u);
        for (var b2 = 1;b2 < u; b2 <<= 1)
          for (var l = b2 << 1, n = Math.cos(2 * Math.PI / l), d = Math.sin(2 * Math.PI / l), w = 0;w < u; w += l)
            for (var g = n, _2 = d, A2 = 0;A2 < b2; A2++) {
              var R2 = h2[w + A2], I = s[w + A2], Me = h2[w + A2 + b2], k = s[w + A2 + b2], D2 = g * Me - _2 * k;
              k = g * k + _2 * Me, Me = D2, h2[w + A2] = R2 + Me, s[w + A2] = I + k, h2[w + A2 + b2] = R2 - Me, s[w + A2 + b2] = I - k, A2 !== l && (D2 = n * g - d * _2, _2 = n * _2 + d * g, g = D2);
            }
      }, N.prototype.guessLen13b = function(i, a) {
        var h2 = Math.max(a, i) | 1, s = h2 & 1, u = 0;
        for (h2 = h2 / 2 | 0;h2; h2 = h2 >>> 1)
          u++;
        return 1 << u + 1 + s;
      }, N.prototype.conjugate = function(i, a, h2) {
        if (!(h2 <= 1))
          for (var s = 0;s < h2 / 2; s++) {
            var u = i[s];
            i[s] = i[h2 - s - 1], i[h2 - s - 1] = u, u = a[s], a[s] = -a[h2 - s - 1], a[h2 - s - 1] = -u;
          }
      }, N.prototype.normalize13b = function(i, a) {
        for (var h2 = 0, s = 0;s < a / 2; s++) {
          var u = Math.round(i[2 * s + 1] / a) * 8192 + Math.round(i[2 * s] / a) + h2;
          i[s] = u & 67108863, u < 67108864 ? h2 = 0 : h2 = u / 67108864 | 0;
        }
        return i;
      }, N.prototype.convert13b = function(i, a, h2, s) {
        for (var u = 0, c = 0;c < a; c++)
          u = u + (i[c] | 0), h2[2 * c] = u & 8191, u = u >>> 13, h2[2 * c + 1] = u & 8191, u = u >>> 13;
        for (c = 2 * a;c < s; ++c)
          h2[c] = 0;
        r(u === 0), r((u & -8192) === 0);
      }, N.prototype.stub = function(i) {
        for (var a = new Array(i), h2 = 0;h2 < i; h2++)
          a[h2] = 0;
        return a;
      }, N.prototype.mulp = function(i, a, h2) {
        var s = 2 * this.guessLen13b(i.length, a.length), u = this.makeRBT(s), c = this.stub(s), b2 = new Array(s), l = new Array(s), n = new Array(s), d = new Array(s), w = new Array(s), g = new Array(s), _2 = h2.words;
        _2.length = s, this.convert13b(i.words, i.length, b2, s), this.convert13b(a.words, a.length, d, s), this.transform(b2, c, l, n, s, u), this.transform(d, c, w, g, s, u);
        for (var A2 = 0;A2 < s; A2++) {
          var R2 = l[A2] * w[A2] - n[A2] * g[A2];
          n[A2] = l[A2] * g[A2] + n[A2] * w[A2], l[A2] = R2;
        }
        return this.conjugate(l, n, s), this.transform(l, n, _2, c, s, u), this.conjugate(_2, c, s), this.normalize13b(_2, s), h2.negative = i.negative ^ a.negative, h2.length = i.length + a.length, h2.strip();
      }, f.prototype.mul = function(i) {
        var a = new f(null);
        return a.words = new Array(this.length + i.length), this.mulTo(i, a);
      }, f.prototype.mulf = function(i) {
        var a = new f(null);
        return a.words = new Array(this.length + i.length), _e(this, i, a);
      }, f.prototype.imul = function(i) {
        return this.clone().mulTo(i, this);
      }, f.prototype.imuln = function(i) {
        r(typeof i == "number"), r(i < 67108864);
        for (var a = 0, h2 = 0;h2 < this.length; h2++) {
          var s = (this.words[h2] | 0) * i, u = (s & 67108863) + (a & 67108863);
          a >>= 26, a += s / 67108864 | 0, a += u >>> 26, this.words[h2] = u & 67108863;
        }
        return a !== 0 && (this.words[h2] = a, this.length++), this;
      }, f.prototype.muln = function(i) {
        return this.clone().imuln(i);
      }, f.prototype.sqr = function() {
        return this.mul(this);
      }, f.prototype.isqr = function() {
        return this.imul(this.clone());
      }, f.prototype.pow = function(i) {
        var a = B(i);
        if (a.length === 0)
          return new f(1);
        for (var h2 = this, s = 0;s < a.length && a[s] === 0; s++, h2 = h2.sqr())
          ;
        if (++s < a.length)
          for (var u = h2.sqr();s < a.length; s++, u = u.sqr())
            a[s] !== 0 && (h2 = h2.mul(u));
        return h2;
      }, f.prototype.iushln = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26, s = 67108863 >>> 26 - a << 26 - a, u;
        if (a !== 0) {
          var c = 0;
          for (u = 0;u < this.length; u++) {
            var b2 = this.words[u] & s, l = (this.words[u] | 0) - b2 << a;
            this.words[u] = l | c, c = b2 >>> 26 - a;
          }
          c && (this.words[u] = c, this.length++);
        }
        if (h2 !== 0) {
          for (u = this.length - 1;u >= 0; u--)
            this.words[u + h2] = this.words[u];
          for (u = 0;u < h2; u++)
            this.words[u] = 0;
          this.length += h2;
        }
        return this.strip();
      }, f.prototype.ishln = function(i) {
        return r(this.negative === 0), this.iushln(i);
      }, f.prototype.iushrn = function(i, a, h2) {
        r(typeof i == "number" && i >= 0);
        var s;
        a ? s = (a - a % 26) / 26 : s = 0;
        var u = i % 26, c = Math.min((i - u) / 26, this.length), b2 = 67108863 ^ 67108863 >>> u << u, l = h2;
        if (s -= c, s = Math.max(0, s), l) {
          for (var n = 0;n < c; n++)
            l.words[n] = this.words[n];
          l.length = c;
        }
        if (c !== 0)
          if (this.length > c)
            for (this.length -= c, n = 0;n < this.length; n++)
              this.words[n] = this.words[n + c];
          else
            this.words[0] = 0, this.length = 1;
        var d = 0;
        for (n = this.length - 1;n >= 0 && (d !== 0 || n >= s); n--) {
          var w = this.words[n] | 0;
          this.words[n] = d << 26 - u | w >>> u, d = w & b2;
        }
        return l && d !== 0 && (l.words[l.length++] = d), this.length === 0 && (this.words[0] = 0, this.length = 1), this.strip();
      }, f.prototype.ishrn = function(i, a, h2) {
        return r(this.negative === 0), this.iushrn(i, a, h2);
      }, f.prototype.shln = function(i) {
        return this.clone().ishln(i);
      }, f.prototype.ushln = function(i) {
        return this.clone().iushln(i);
      }, f.prototype.shrn = function(i) {
        return this.clone().ishrn(i);
      }, f.prototype.ushrn = function(i) {
        return this.clone().iushrn(i);
      }, f.prototype.testn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26, s = 1 << a;
        if (this.length <= h2)
          return false;
        var u = this.words[h2];
        return !!(u & s);
      }, f.prototype.imaskn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26;
        if (r(this.negative === 0, "imaskn works only with positive numbers"), this.length <= h2)
          return this;
        if (a !== 0 && h2++, this.length = Math.min(h2, this.length), a !== 0) {
          var s = 67108863 ^ 67108863 >>> a << a;
          this.words[this.length - 1] &= s;
        }
        return this.strip();
      }, f.prototype.maskn = function(i) {
        return this.clone().imaskn(i);
      }, f.prototype.iaddn = function(i) {
        return r(typeof i == "number"), r(i < 67108864), i < 0 ? this.isubn(-i) : this.negative !== 0 ? this.length === 1 && (this.words[0] | 0) < i ? (this.words[0] = i - (this.words[0] | 0), this.negative = 0, this) : (this.negative = 0, this.isubn(i), this.negative = 1, this) : this._iaddn(i);
      }, f.prototype._iaddn = function(i) {
        this.words[0] += i;
        for (var a = 0;a < this.length && this.words[a] >= 67108864; a++)
          this.words[a] -= 67108864, a === this.length - 1 ? this.words[a + 1] = 1 : this.words[a + 1]++;
        return this.length = Math.max(this.length, a + 1), this;
      }, f.prototype.isubn = function(i) {
        if (r(typeof i == "number"), r(i < 67108864), i < 0)
          return this.iaddn(-i);
        if (this.negative !== 0)
          return this.negative = 0, this.iaddn(i), this.negative = 1, this;
        if (this.words[0] -= i, this.length === 1 && this.words[0] < 0)
          this.words[0] = -this.words[0], this.negative = 1;
        else
          for (var a = 0;a < this.length && this.words[a] < 0; a++)
            this.words[a] += 67108864, this.words[a + 1] -= 1;
        return this.strip();
      }, f.prototype.addn = function(i) {
        return this.clone().iaddn(i);
      }, f.prototype.subn = function(i) {
        return this.clone().isubn(i);
      }, f.prototype.iabs = function() {
        return this.negative = 0, this;
      }, f.prototype.abs = function() {
        return this.clone().iabs();
      }, f.prototype._ishlnsubmul = function(i, a, h2) {
        var s = i.length + h2, u;
        this._expand(s);
        var c, b2 = 0;
        for (u = 0;u < i.length; u++) {
          c = (this.words[u + h2] | 0) + b2;
          var l = (i.words[u] | 0) * a;
          c -= l & 67108863, b2 = (c >> 26) - (l / 67108864 | 0), this.words[u + h2] = c & 67108863;
        }
        for (;u < this.length - h2; u++)
          c = (this.words[u + h2] | 0) + b2, b2 = c >> 26, this.words[u + h2] = c & 67108863;
        if (b2 === 0)
          return this.strip();
        for (r(b2 === -1), b2 = 0, u = 0;u < this.length; u++)
          c = -(this.words[u] | 0) + b2, b2 = c >> 26, this.words[u] = c & 67108863;
        return this.negative = 1, this.strip();
      }, f.prototype._wordDiv = function(i, a) {
        var h2 = this.length - i.length, s = this.clone(), u = i, c = u.words[u.length - 1] | 0, b2 = this._countBits(c);
        h2 = 26 - b2, h2 !== 0 && (u = u.ushln(h2), s.iushln(h2), c = u.words[u.length - 1] | 0);
        var l = s.length - u.length, n;
        if (a !== "mod") {
          n = new f(null), n.length = l + 1, n.words = new Array(n.length);
          for (var d = 0;d < n.length; d++)
            n.words[d] = 0;
        }
        var w = s.clone()._ishlnsubmul(u, 1, l);
        w.negative === 0 && (s = w, n && (n.words[l] = 1));
        for (var g = l - 1;g >= 0; g--) {
          var _2 = (s.words[u.length + g] | 0) * 67108864 + (s.words[u.length + g - 1] | 0);
          for (_2 = Math.min(_2 / c | 0, 67108863), s._ishlnsubmul(u, _2, g);s.negative !== 0; )
            _2--, s.negative = 0, s._ishlnsubmul(u, 1, g), s.isZero() || (s.negative ^= 1);
          n && (n.words[g] = _2);
        }
        return n && n.strip(), s.strip(), a !== "div" && h2 !== 0 && s.iushrn(h2), { div: n || null, mod: s };
      }, f.prototype.divmod = function(i, a, h2) {
        if (r(!i.isZero()), this.isZero())
          return { div: new f(0), mod: new f(0) };
        var s, u, c;
        return this.negative !== 0 && i.negative === 0 ? (c = this.neg().divmod(i, a), a !== "mod" && (s = c.div.neg()), a !== "div" && (u = c.mod.neg(), h2 && u.negative !== 0 && u.iadd(i)), { div: s, mod: u }) : this.negative === 0 && i.negative !== 0 ? (c = this.divmod(i.neg(), a), a !== "mod" && (s = c.div.neg()), { div: s, mod: c.mod }) : (this.negative & i.negative) !== 0 ? (c = this.neg().divmod(i.neg(), a), a !== "div" && (u = c.mod.neg(), h2 && u.negative !== 0 && u.isub(i)), { div: c.div, mod: u }) : i.length > this.length || this.cmp(i) < 0 ? { div: new f(0), mod: this } : i.length === 1 ? a === "div" ? { div: this.divn(i.words[0]), mod: null } : a === "mod" ? { div: null, mod: new f(this.modn(i.words[0])) } : { div: this.divn(i.words[0]), mod: new f(this.modn(i.words[0])) } : this._wordDiv(i, a);
      }, f.prototype.div = function(i) {
        return this.divmod(i, "div", false).div;
      }, f.prototype.mod = function(i) {
        return this.divmod(i, "mod", false).mod;
      }, f.prototype.umod = function(i) {
        return this.divmod(i, "mod", true).mod;
      }, f.prototype.divRound = function(i) {
        var a = this.divmod(i);
        if (a.mod.isZero())
          return a.div;
        var h2 = a.div.negative !== 0 ? a.mod.isub(i) : a.mod, s = i.ushrn(1), u = i.andln(1), c = h2.cmp(s);
        return c < 0 || u === 1 && c === 0 ? a.div : a.div.negative !== 0 ? a.div.isubn(1) : a.div.iaddn(1);
      }, f.prototype.modn = function(i) {
        r(i <= 67108863);
        for (var a = (1 << 26) % i, h2 = 0, s = this.length - 1;s >= 0; s--)
          h2 = (a * h2 + (this.words[s] | 0)) % i;
        return h2;
      }, f.prototype.idivn = function(i) {
        r(i <= 67108863);
        for (var a = 0, h2 = this.length - 1;h2 >= 0; h2--) {
          var s = (this.words[h2] | 0) + a * 67108864;
          this.words[h2] = s / i | 0, a = s % i;
        }
        return this.strip();
      }, f.prototype.divn = function(i) {
        return this.clone().idivn(i);
      }, f.prototype.egcd = function(i) {
        r(i.negative === 0), r(!i.isZero());
        var a = this, h2 = i.clone();
        a.negative !== 0 ? a = a.umod(i) : a = a.clone();
        for (var s = new f(1), u = new f(0), c = new f(0), b2 = new f(1), l = 0;a.isEven() && h2.isEven(); )
          a.iushrn(1), h2.iushrn(1), ++l;
        for (var n = h2.clone(), d = a.clone();!a.isZero(); ) {
          for (var w = 0, g = 1;(a.words[0] & g) === 0 && w < 26; ++w, g <<= 1)
            ;
          if (w > 0)
            for (a.iushrn(w);w-- > 0; )
              (s.isOdd() || u.isOdd()) && (s.iadd(n), u.isub(d)), s.iushrn(1), u.iushrn(1);
          for (var _2 = 0, A2 = 1;(h2.words[0] & A2) === 0 && _2 < 26; ++_2, A2 <<= 1)
            ;
          if (_2 > 0)
            for (h2.iushrn(_2);_2-- > 0; )
              (c.isOdd() || b2.isOdd()) && (c.iadd(n), b2.isub(d)), c.iushrn(1), b2.iushrn(1);
          a.cmp(h2) >= 0 ? (a.isub(h2), s.isub(c), u.isub(b2)) : (h2.isub(a), c.isub(s), b2.isub(u));
        }
        return { a: c, b: b2, gcd: h2.iushln(l) };
      }, f.prototype._invmp = function(i) {
        r(i.negative === 0), r(!i.isZero());
        var a = this, h2 = i.clone();
        a.negative !== 0 ? a = a.umod(i) : a = a.clone();
        for (var s = new f(1), u = new f(0), c = h2.clone();a.cmpn(1) > 0 && h2.cmpn(1) > 0; ) {
          for (var b2 = 0, l = 1;(a.words[0] & l) === 0 && b2 < 26; ++b2, l <<= 1)
            ;
          if (b2 > 0)
            for (a.iushrn(b2);b2-- > 0; )
              s.isOdd() && s.iadd(c), s.iushrn(1);
          for (var n = 0, d = 1;(h2.words[0] & d) === 0 && n < 26; ++n, d <<= 1)
            ;
          if (n > 0)
            for (h2.iushrn(n);n-- > 0; )
              u.isOdd() && u.iadd(c), u.iushrn(1);
          a.cmp(h2) >= 0 ? (a.isub(h2), s.isub(u)) : (h2.isub(a), u.isub(s));
        }
        var w;
        return a.cmpn(1) === 0 ? w = s : w = u, w.cmpn(0) < 0 && w.iadd(i), w;
      }, f.prototype.gcd = function(i) {
        if (this.isZero())
          return i.abs();
        if (i.isZero())
          return this.abs();
        var a = this.clone(), h2 = i.clone();
        a.negative = 0, h2.negative = 0;
        for (var s = 0;a.isEven() && h2.isEven(); s++)
          a.iushrn(1), h2.iushrn(1);
        do {
          for (;a.isEven(); )
            a.iushrn(1);
          for (;h2.isEven(); )
            h2.iushrn(1);
          var u = a.cmp(h2);
          if (u < 0) {
            var c = a;
            a = h2, h2 = c;
          } else if (u === 0 || h2.cmpn(1) === 0)
            break;
          a.isub(h2);
        } while (true);
        return h2.iushln(s);
      }, f.prototype.invm = function(i) {
        return this.egcd(i).a.umod(i);
      }, f.prototype.isEven = function() {
        return (this.words[0] & 1) === 0;
      }, f.prototype.isOdd = function() {
        return (this.words[0] & 1) === 1;
      }, f.prototype.andln = function(i) {
        return this.words[0] & i;
      }, f.prototype.bincn = function(i) {
        r(typeof i == "number");
        var a = i % 26, h2 = (i - a) / 26, s = 1 << a;
        if (this.length <= h2)
          return this._expand(h2 + 1), this.words[h2] |= s, this;
        for (var u = s, c = h2;u !== 0 && c < this.length; c++) {
          var b2 = this.words[c] | 0;
          b2 += u, u = b2 >>> 26, b2 &= 67108863, this.words[c] = b2;
        }
        return u !== 0 && (this.words[c] = u, this.length++), this;
      }, f.prototype.isZero = function() {
        return this.length === 1 && this.words[0] === 0;
      }, f.prototype.cmpn = function(i) {
        var a = i < 0;
        if (this.negative !== 0 && !a)
          return -1;
        if (this.negative === 0 && a)
          return 1;
        this.strip();
        var h2;
        if (this.length > 1)
          h2 = 1;
        else {
          a && (i = -i), r(i <= 67108863, "Number is too big");
          var s = this.words[0] | 0;
          h2 = s === i ? 0 : s < i ? -1 : 1;
        }
        return this.negative !== 0 ? -h2 | 0 : h2;
      }, f.prototype.cmp = function(i) {
        if (this.negative !== 0 && i.negative === 0)
          return -1;
        if (this.negative === 0 && i.negative !== 0)
          return 1;
        var a = this.ucmp(i);
        return this.negative !== 0 ? -a | 0 : a;
      }, f.prototype.ucmp = function(i) {
        if (this.length > i.length)
          return 1;
        if (this.length < i.length)
          return -1;
        for (var a = 0, h2 = this.length - 1;h2 >= 0; h2--) {
          var s = this.words[h2] | 0, u = i.words[h2] | 0;
          if (s !== u) {
            s < u ? a = -1 : s > u && (a = 1);
            break;
          }
        }
        return a;
      }, f.prototype.gtn = function(i) {
        return this.cmpn(i) === 1;
      }, f.prototype.gt = function(i) {
        return this.cmp(i) === 1;
      }, f.prototype.gten = function(i) {
        return this.cmpn(i) >= 0;
      }, f.prototype.gte = function(i) {
        return this.cmp(i) >= 0;
      }, f.prototype.ltn = function(i) {
        return this.cmpn(i) === -1;
      }, f.prototype.lt = function(i) {
        return this.cmp(i) === -1;
      }, f.prototype.lten = function(i) {
        return this.cmpn(i) <= 0;
      }, f.prototype.lte = function(i) {
        return this.cmp(i) <= 0;
      }, f.prototype.eqn = function(i) {
        return this.cmpn(i) === 0;
      }, f.prototype.eq = function(i) {
        return this.cmp(i) === 0;
      }, f.red = function(i) {
        return new P(i);
      }, f.prototype.toRed = function(i) {
        return r(!this.red, "Already a number in reduction context"), r(this.negative === 0, "red works only with positives"), i.convertTo(this)._forceRed(i);
      }, f.prototype.fromRed = function() {
        return r(this.red, "fromRed works only with numbers in reduction context"), this.red.convertFrom(this);
      }, f.prototype._forceRed = function(i) {
        return this.red = i, this;
      }, f.prototype.forceRed = function(i) {
        return r(!this.red, "Already a number in reduction context"), this._forceRed(i);
      }, f.prototype.redAdd = function(i) {
        return r(this.red, "redAdd works only with red numbers"), this.red.add(this, i);
      }, f.prototype.redIAdd = function(i) {
        return r(this.red, "redIAdd works only with red numbers"), this.red.iadd(this, i);
      }, f.prototype.redSub = function(i) {
        return r(this.red, "redSub works only with red numbers"), this.red.sub(this, i);
      }, f.prototype.redISub = function(i) {
        return r(this.red, "redISub works only with red numbers"), this.red.isub(this, i);
      }, f.prototype.redShl = function(i) {
        return r(this.red, "redShl works only with red numbers"), this.red.shl(this, i);
      }, f.prototype.redMul = function(i) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, i), this.red.mul(this, i);
      }, f.prototype.redIMul = function(i) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, i), this.red.imul(this, i);
      }, f.prototype.redSqr = function() {
        return r(this.red, "redSqr works only with red numbers"), this.red._verify1(this), this.red.sqr(this);
      }, f.prototype.redISqr = function() {
        return r(this.red, "redISqr works only with red numbers"), this.red._verify1(this), this.red.isqr(this);
      }, f.prototype.redSqrt = function() {
        return r(this.red, "redSqrt works only with red numbers"), this.red._verify1(this), this.red.sqrt(this);
      }, f.prototype.redInvm = function() {
        return r(this.red, "redInvm works only with red numbers"), this.red._verify1(this), this.red.invm(this);
      }, f.prototype.redNeg = function() {
        return r(this.red, "redNeg works only with red numbers"), this.red._verify1(this), this.red.neg(this);
      }, f.prototype.redPow = function(i) {
        return r(this.red && !i.red, "redPow(normalNum)"), this.red._verify1(this), this.red.pow(this, i);
      };
      var we = { k256: null, p224: null, p192: null, p25519: null };
      function ye(v, i) {
        this.name = v, this.p = new f(i, 16), this.n = this.p.bitLength(), this.k = new f(1).iushln(this.n).isub(this.p), this.tmp = this._tmp();
      }
      ye.prototype._tmp = function() {
        var i = new f(null);
        return i.words = new Array(Math.ceil(this.n / 13)), i;
      }, ye.prototype.ireduce = function(i) {
        var a = i, h2;
        do
          this.split(a, this.tmp), a = this.imulK(a), a = a.iadd(this.tmp), h2 = a.bitLength();
        while (h2 > this.n);
        var s = h2 < this.n ? -1 : a.ucmp(this.p);
        return s === 0 ? (a.words[0] = 0, a.length = 1) : s > 0 ? a.isub(this.p) : a.strip !== undefined ? a.strip() : a._strip(), a;
      }, ye.prototype.split = function(i, a) {
        i.iushrn(this.n, 0, a);
      }, ye.prototype.imulK = function(i) {
        return i.imul(this.k);
      };
      function xe() {
        ye.call(this, "k256", "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f");
      }
      o(xe, ye), xe.prototype.split = function(i, a) {
        for (var h2 = 4194303, s = Math.min(i.length, 9), u = 0;u < s; u++)
          a.words[u] = i.words[u];
        if (a.length = s, i.length <= 9) {
          i.words[0] = 0, i.length = 1;
          return;
        }
        var c = i.words[9];
        for (a.words[a.length++] = c & h2, u = 10;u < i.length; u++) {
          var b2 = i.words[u] | 0;
          i.words[u - 10] = (b2 & h2) << 4 | c >>> 22, c = b2;
        }
        c >>>= 22, i.words[u - 10] = c, c === 0 && i.length > 10 ? i.length -= 10 : i.length -= 9;
      }, xe.prototype.imulK = function(i) {
        i.words[i.length] = 0, i.words[i.length + 1] = 0, i.length += 2;
        for (var a = 0, h2 = 0;h2 < i.length; h2++) {
          var s = i.words[h2] | 0;
          a += s * 977, i.words[h2] = a & 67108863, a = s * 64 + (a / 67108864 | 0);
        }
        return i.words[i.length - 1] === 0 && (i.length--, i.words[i.length - 1] === 0 && i.length--), i;
      };
      function Re() {
        ye.call(this, "p224", "ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001");
      }
      o(Re, ye);
      function Ee() {
        ye.call(this, "p192", "ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff");
      }
      o(Ee, ye);
      function Ae() {
        ye.call(this, "25519", "7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed");
      }
      o(Ae, ye), Ae.prototype.imulK = function(i) {
        for (var a = 0, h2 = 0;h2 < i.length; h2++) {
          var s = (i.words[h2] | 0) * 19 + a, u = s & 67108863;
          s >>>= 26, i.words[h2] = u, a = s;
        }
        return a !== 0 && (i.words[i.length++] = a), i;
      }, f._prime = function(i) {
        if (we[i])
          return we[i];
        var a;
        if (i === "k256")
          a = new xe;
        else if (i === "p224")
          a = new Re;
        else if (i === "p192")
          a = new Ee;
        else if (i === "p25519")
          a = new Ae;
        else
          throw new Error("Unknown prime " + i);
        return we[i] = a, a;
      };
      function P(v) {
        if (typeof v == "string") {
          var i = f._prime(v);
          this.m = i.p, this.prime = i;
        } else
          r(v.gtn(1), "modulus must be greater than 1"), this.m = v, this.prime = null;
      }
      P.prototype._verify1 = function(i) {
        r(i.negative === 0, "red works only with positives"), r(i.red, "red works only with red numbers");
      }, P.prototype._verify2 = function(i, a) {
        r((i.negative | a.negative) === 0, "red works only with positives"), r(i.red && i.red === a.red, "red works only with red numbers");
      }, P.prototype.imod = function(i) {
        return this.prime ? this.prime.ireduce(i)._forceRed(this) : i.umod(this.m)._forceRed(this);
      }, P.prototype.neg = function(i) {
        return i.isZero() ? i.clone() : this.m.sub(i)._forceRed(this);
      }, P.prototype.add = function(i, a) {
        this._verify2(i, a);
        var h2 = i.add(a);
        return h2.cmp(this.m) >= 0 && h2.isub(this.m), h2._forceRed(this);
      }, P.prototype.iadd = function(i, a) {
        this._verify2(i, a);
        var h2 = i.iadd(a);
        return h2.cmp(this.m) >= 0 && h2.isub(this.m), h2;
      }, P.prototype.sub = function(i, a) {
        this._verify2(i, a);
        var h2 = i.sub(a);
        return h2.cmpn(0) < 0 && h2.iadd(this.m), h2._forceRed(this);
      }, P.prototype.isub = function(i, a) {
        this._verify2(i, a);
        var h2 = i.isub(a);
        return h2.cmpn(0) < 0 && h2.iadd(this.m), h2;
      }, P.prototype.shl = function(i, a) {
        return this._verify1(i), this.imod(i.ushln(a));
      }, P.prototype.imul = function(i, a) {
        return this._verify2(i, a), this.imod(i.imul(a));
      }, P.prototype.mul = function(i, a) {
        return this._verify2(i, a), this.imod(i.mul(a));
      }, P.prototype.isqr = function(i) {
        return this.imul(i, i.clone());
      }, P.prototype.sqr = function(i) {
        return this.mul(i, i);
      }, P.prototype.sqrt = function(i) {
        if (i.isZero())
          return i.clone();
        var a = this.m.andln(3);
        if (r(a % 2 === 1), a === 3) {
          var h2 = this.m.add(new f(1)).iushrn(2);
          return this.pow(i, h2);
        }
        for (var s = this.m.subn(1), u = 0;!s.isZero() && s.andln(1) === 0; )
          u++, s.iushrn(1);
        r(!s.isZero());
        var c = new f(1).toRed(this), b2 = c.redNeg(), l = this.m.subn(1).iushrn(1), n = this.m.bitLength();
        for (n = new f(2 * n * n).toRed(this);this.pow(n, l).cmp(b2) !== 0; )
          n.redIAdd(b2);
        for (var d = this.pow(n, s), w = this.pow(i, s.addn(1).iushrn(1)), g = this.pow(i, s), _2 = u;g.cmp(c) !== 0; ) {
          for (var A2 = g, R2 = 0;A2.cmp(c) !== 0; R2++)
            A2 = A2.redSqr();
          r(R2 < _2);
          var I = this.pow(d, new f(1).iushln(_2 - R2 - 1));
          w = w.redMul(I), d = I.redSqr(), g = g.redMul(d), _2 = R2;
        }
        return w;
      }, P.prototype.invm = function(i) {
        var a = i._invmp(this.m);
        return a.negative !== 0 ? (a.negative = 0, this.imod(a).redNeg()) : this.imod(a);
      }, P.prototype.pow = function(i, a) {
        if (a.isZero())
          return new f(1).toRed(this);
        if (a.cmpn(1) === 0)
          return i.clone();
        var h2 = 4, s = new Array(1 << h2);
        s[0] = new f(1).toRed(this), s[1] = i;
        for (var u = 2;u < s.length; u++)
          s[u] = this.mul(s[u - 1], i);
        var c = s[0], b2 = 0, l = 0, n = a.bitLength() % 26;
        for (n === 0 && (n = 26), u = a.length - 1;u >= 0; u--) {
          for (var d = a.words[u], w = n - 1;w >= 0; w--) {
            var g = d >> w & 1;
            if (c !== s[0] && (c = this.sqr(c)), g === 0 && b2 === 0) {
              l = 0;
              continue;
            }
            b2 <<= 1, b2 |= g, l++, !(l !== h2 && (u !== 0 || w !== 0)) && (c = this.mul(c, s[b2]), l = 0, b2 = 0);
          }
          n = 26;
        }
        return c;
      }, P.prototype.convertTo = function(i) {
        var a = i.umod(this.m);
        return a === i ? a.clone() : a;
      }, P.prototype.convertFrom = function(i) {
        var a = i.clone();
        return a.red = null, a;
      }, f.mont = function(i) {
        return new Se(i);
      };
      function Se(v) {
        P.call(this, v), this.shift = this.m.bitLength(), this.shift % 26 !== 0 && (this.shift += 26 - this.shift % 26), this.r = new f(1).iushln(this.shift), this.r2 = this.imod(this.r.sqr()), this.rinv = this.r._invmp(this.m), this.minv = this.rinv.mul(this.r).isubn(1).div(this.m), this.minv = this.minv.umod(this.r), this.minv = this.r.sub(this.minv);
      }
      o(Se, P), Se.prototype.convertTo = function(i) {
        return this.imod(i.ushln(this.shift));
      }, Se.prototype.convertFrom = function(i) {
        var a = this.imod(i.mul(this.rinv));
        return a.red = null, a;
      }, Se.prototype.imul = function(i, a) {
        if (i.isZero() || a.isZero())
          return i.words[0] = 0, i.length = 1, i;
        var h2 = i.imul(a), s = h2.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), u = h2.isub(s).iushrn(this.shift), c = u;
        return u.cmp(this.m) >= 0 ? c = u.isub(this.m) : u.cmpn(0) < 0 && (c = u.iadd(this.m)), c._forceRed(this);
      }, Se.prototype.mul = function(i, a) {
        if (i.isZero() || a.isZero())
          return new f(0)._forceRed(this);
        var h2 = i.mul(a), s = h2.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), u = h2.isub(s).iushrn(this.shift), c = u;
        return u.cmp(this.m) >= 0 ? c = u.isub(this.m) : u.cmpn(0) < 0 && (c = u.iadd(this.m)), c._forceRed(this);
      }, Se.prototype.invm = function(i) {
        var a = this.imod(i._invmp(this.m).mul(this.r2));
        return a._forceRed(this);
      };
    })(typeof Gu > "u" || Gu, $m);
  });
  Ym = T2((Gm, Xu) => {
    (function(t, e) {
      function r(v, i) {
        if (!v)
          throw new Error(i || "Assertion failed");
      }
      function o(v, i) {
        v.super_ = i;
        var a = function() {
        };
        a.prototype = i.prototype, v.prototype = new a, v.prototype.constructor = v;
      }
      function f(v, i, a) {
        if (f.isBN(v))
          return v;
        this.negative = 0, this.words = null, this.length = 0, this.red = null, v !== null && ((i === "le" || i === "be") && (a = i, i = 10), this._init(v || 0, i || 10, a || "be"));
      }
      typeof t == "object" ? t.exports = f : e.BN = f, f.BN = f, f.wordSize = 26;
      var p;
      try {
        typeof window < "u" && typeof window.Buffer < "u" ? p = window.Buffer : p = ji().Buffer;
      } catch {
      }
      f.isBN = function(i) {
        return i instanceof f ? true : i !== null && typeof i == "object" && i.constructor.wordSize === f.wordSize && Array.isArray(i.words);
      }, f.max = function(i, a) {
        return i.cmp(a) > 0 ? i : a;
      }, f.min = function(i, a) {
        return i.cmp(a) < 0 ? i : a;
      }, f.prototype._init = function(i, a, h2) {
        if (typeof i == "number")
          return this._initNumber(i, a, h2);
        if (typeof i == "object")
          return this._initArray(i, a, h2);
        a === "hex" && (a = 16), r(a === (a | 0) && a >= 2 && a <= 36), i = i.toString().replace(/\s+/g, "");
        var s = 0;
        i[0] === "-" && (s++, this.negative = 1), s < i.length && (a === 16 ? this._parseHex(i, s, h2) : (this._parseBase(i, a, s), h2 === "le" && this._initArray(this.toArray(), a, h2)));
      }, f.prototype._initNumber = function(i, a, h2) {
        i < 0 && (this.negative = 1, i = -i), i < 67108864 ? (this.words = [i & 67108863], this.length = 1) : i < 4503599627370496 ? (this.words = [i & 67108863, i / 67108864 & 67108863], this.length = 2) : (r(i < 9007199254740992), this.words = [i & 67108863, i / 67108864 & 67108863, 1], this.length = 3), h2 === "le" && this._initArray(this.toArray(), a, h2);
      }, f.prototype._initArray = function(i, a, h2) {
        if (r(typeof i.length == "number"), i.length <= 0)
          return this.words = [0], this.length = 1, this;
        this.length = Math.ceil(i.length / 3), this.words = new Array(this.length);
        for (var s = 0;s < this.length; s++)
          this.words[s] = 0;
        var u, c, b2 = 0;
        if (h2 === "be")
          for (s = i.length - 1, u = 0;s >= 0; s -= 3)
            c = i[s] | i[s - 1] << 8 | i[s - 2] << 16, this.words[u] |= c << b2 & 67108863, this.words[u + 1] = c >>> 26 - b2 & 67108863, b2 += 24, b2 >= 26 && (b2 -= 26, u++);
        else if (h2 === "le")
          for (s = 0, u = 0;s < i.length; s += 3)
            c = i[s] | i[s + 1] << 8 | i[s + 2] << 16, this.words[u] |= c << b2 & 67108863, this.words[u + 1] = c >>> 26 - b2 & 67108863, b2 += 24, b2 >= 26 && (b2 -= 26, u++);
        return this.strip();
      };
      function m2(v, i) {
        var a = v.charCodeAt(i);
        return a >= 65 && a <= 70 ? a - 55 : a >= 97 && a <= 102 ? a - 87 : a - 48 & 15;
      }
      function y2(v, i, a) {
        var h2 = m2(v, a);
        return a - 1 >= i && (h2 |= m2(v, a - 1) << 4), h2;
      }
      f.prototype._parseHex = function(i, a, h2) {
        this.length = Math.ceil((i.length - a) / 6), this.words = new Array(this.length);
        for (var s = 0;s < this.length; s++)
          this.words[s] = 0;
        var u = 0, c = 0, b2;
        if (h2 === "be")
          for (s = i.length - 1;s >= a; s -= 2)
            b2 = y2(i, a, s) << u, this.words[c] |= b2 & 67108863, u >= 18 ? (u -= 18, c += 1, this.words[c] |= b2 >>> 26) : u += 8;
        else {
          var l = i.length - a;
          for (s = l % 2 === 0 ? a + 1 : a;s < i.length; s += 2)
            b2 = y2(i, a, s) << u, this.words[c] |= b2 & 67108863, u >= 18 ? (u -= 18, c += 1, this.words[c] |= b2 >>> 26) : u += 8;
        }
        this.strip();
      };
      function M(v, i, a, h2) {
        for (var s = 0, u = Math.min(v.length, a), c = i;c < u; c++) {
          var b2 = v.charCodeAt(c) - 48;
          s *= h2, b2 >= 49 ? s += b2 - 49 + 10 : b2 >= 17 ? s += b2 - 17 + 10 : s += b2;
        }
        return s;
      }
      f.prototype._parseBase = function(i, a, h2) {
        this.words = [0], this.length = 1;
        for (var s = 0, u = 1;u <= 67108863; u *= a)
          s++;
        s--, u = u / a | 0;
        for (var c = i.length - h2, b2 = c % s, l = Math.min(c, c - b2) + h2, n = 0, d = h2;d < l; d += s)
          n = M(i, d, d + s, a), this.imuln(u), this.words[0] + n < 67108864 ? this.words[0] += n : this._iaddn(n);
        if (b2 !== 0) {
          var w = 1;
          for (n = M(i, d, i.length, a), d = 0;d < b2; d++)
            w *= a;
          this.imuln(w), this.words[0] + n < 67108864 ? this.words[0] += n : this._iaddn(n);
        }
        this.strip();
      }, f.prototype.copy = function(i) {
        i.words = new Array(this.length);
        for (var a = 0;a < this.length; a++)
          i.words[a] = this.words[a];
        i.length = this.length, i.negative = this.negative, i.red = this.red;
      }, f.prototype.clone = function() {
        var i = new f(null);
        return this.copy(i), i;
      }, f.prototype._expand = function(i) {
        for (;this.length < i; )
          this.words[this.length++] = 0;
        return this;
      }, f.prototype.strip = function() {
        for (;this.length > 1 && this.words[this.length - 1] === 0; )
          this.length--;
        return this._normSign();
      }, f.prototype._normSign = function() {
        return this.length === 1 && this.words[0] === 0 && (this.negative = 0), this;
      }, f.prototype.inspect = function() {
        return (this.red ? "<BN-R: " : "<BN: ") + this.toString(16) + ">";
      };
      var x = ["", "0", "00", "000", "0000", "00000", "000000", "0000000", "00000000", "000000000", "0000000000", "00000000000", "000000000000", "0000000000000", "00000000000000", "000000000000000", "0000000000000000", "00000000000000000", "000000000000000000", "0000000000000000000", "00000000000000000000", "000000000000000000000", "0000000000000000000000", "00000000000000000000000", "000000000000000000000000", "0000000000000000000000000"], S = [0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5], E2 = [0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 1e7, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176];
      f.prototype.toString = function(i, a) {
        i = i || 10, a = a | 0 || 1;
        var h2;
        if (i === 16 || i === "hex") {
          h2 = "";
          for (var s = 0, u = 0, c = 0;c < this.length; c++) {
            var b2 = this.words[c], l = ((b2 << s | u) & 16777215).toString(16);
            u = b2 >>> 24 - s & 16777215, u !== 0 || c !== this.length - 1 ? h2 = x[6 - l.length] + l + h2 : h2 = l + h2, s += 2, s >= 26 && (s -= 26, c--);
          }
          for (u !== 0 && (h2 = u.toString(16) + h2);h2.length % a !== 0; )
            h2 = "0" + h2;
          return this.negative !== 0 && (h2 = "-" + h2), h2;
        }
        if (i === (i | 0) && i >= 2 && i <= 36) {
          var n = S[i], d = E2[i];
          h2 = "";
          var w = this.clone();
          for (w.negative = 0;!w.isZero(); ) {
            var g = w.modn(d).toString(i);
            w = w.idivn(d), w.isZero() ? h2 = g + h2 : h2 = x[n - g.length] + g + h2;
          }
          for (this.isZero() && (h2 = "0" + h2);h2.length % a !== 0; )
            h2 = "0" + h2;
          return this.negative !== 0 && (h2 = "-" + h2), h2;
        }
        r(false, "Base should be between 2 and 36");
      }, f.prototype.toNumber = function() {
        var i = this.words[0];
        return this.length === 2 ? i += this.words[1] * 67108864 : this.length === 3 && this.words[2] === 1 ? i += 4503599627370496 + this.words[1] * 67108864 : this.length > 2 && r(false, "Number can only safely store up to 53 bits"), this.negative !== 0 ? -i : i;
      }, f.prototype.toJSON = function() {
        return this.toString(16);
      }, f.prototype.toBuffer = function(i, a) {
        return r(typeof p < "u"), this.toArrayLike(p, i, a);
      }, f.prototype.toArray = function(i, a) {
        return this.toArrayLike(Array, i, a);
      }, f.prototype.toArrayLike = function(i, a, h2) {
        var s = this.byteLength(), u = h2 || Math.max(1, s);
        r(s <= u, "byte array longer than desired length"), r(u > 0, "Requested array length <= 0"), this.strip();
        var c = a === "le", b2 = new i(u), l, n, d = this.clone();
        if (c) {
          for (n = 0;!d.isZero(); n++)
            l = d.andln(255), d.iushrn(8), b2[n] = l;
          for (;n < u; n++)
            b2[n] = 0;
        } else {
          for (n = 0;n < u - s; n++)
            b2[n] = 0;
          for (n = 0;!d.isZero(); n++)
            l = d.andln(255), d.iushrn(8), b2[u - n - 1] = l;
        }
        return b2;
      }, Math.clz32 ? f.prototype._countBits = function(i) {
        return 32 - Math.clz32(i);
      } : f.prototype._countBits = function(i) {
        var a = i, h2 = 0;
        return a >= 4096 && (h2 += 13, a >>>= 13), a >= 64 && (h2 += 7, a >>>= 7), a >= 8 && (h2 += 4, a >>>= 4), a >= 2 && (h2 += 2, a >>>= 2), h2 + a;
      }, f.prototype._zeroBits = function(i) {
        if (i === 0)
          return 26;
        var a = i, h2 = 0;
        return (a & 8191) === 0 && (h2 += 13, a >>>= 13), (a & 127) === 0 && (h2 += 7, a >>>= 7), (a & 15) === 0 && (h2 += 4, a >>>= 4), (a & 3) === 0 && (h2 += 2, a >>>= 2), (a & 1) === 0 && h2++, h2;
      }, f.prototype.bitLength = function() {
        var i = this.words[this.length - 1], a = this._countBits(i);
        return (this.length - 1) * 26 + a;
      };
      function B(v) {
        for (var i = new Array(v.bitLength()), a = 0;a < i.length; a++) {
          var h2 = a / 26 | 0, s = a % 26;
          i[a] = (v.words[h2] & 1 << s) >>> s;
        }
        return i;
      }
      f.prototype.zeroBits = function() {
        if (this.isZero())
          return 0;
        for (var i = 0, a = 0;a < this.length; a++) {
          var h2 = this._zeroBits(this.words[a]);
          if (i += h2, h2 !== 26)
            break;
        }
        return i;
      }, f.prototype.byteLength = function() {
        return Math.ceil(this.bitLength() / 8);
      }, f.prototype.toTwos = function(i) {
        return this.negative !== 0 ? this.abs().inotn(i).iaddn(1) : this.clone();
      }, f.prototype.fromTwos = function(i) {
        return this.testn(i - 1) ? this.notn(i).iaddn(1).ineg() : this.clone();
      }, f.prototype.isNeg = function() {
        return this.negative !== 0;
      }, f.prototype.neg = function() {
        return this.clone().ineg();
      }, f.prototype.ineg = function() {
        return this.isZero() || (this.negative ^= 1), this;
      }, f.prototype.iuor = function(i) {
        for (;this.length < i.length; )
          this.words[this.length++] = 0;
        for (var a = 0;a < i.length; a++)
          this.words[a] = this.words[a] | i.words[a];
        return this.strip();
      }, f.prototype.ior = function(i) {
        return r((this.negative | i.negative) === 0), this.iuor(i);
      }, f.prototype.or = function(i) {
        return this.length > i.length ? this.clone().ior(i) : i.clone().ior(this);
      }, f.prototype.uor = function(i) {
        return this.length > i.length ? this.clone().iuor(i) : i.clone().iuor(this);
      }, f.prototype.iuand = function(i) {
        var a;
        this.length > i.length ? a = i : a = this;
        for (var h2 = 0;h2 < a.length; h2++)
          this.words[h2] = this.words[h2] & i.words[h2];
        return this.length = a.length, this.strip();
      }, f.prototype.iand = function(i) {
        return r((this.negative | i.negative) === 0), this.iuand(i);
      }, f.prototype.and = function(i) {
        return this.length > i.length ? this.clone().iand(i) : i.clone().iand(this);
      }, f.prototype.uand = function(i) {
        return this.length > i.length ? this.clone().iuand(i) : i.clone().iuand(this);
      }, f.prototype.iuxor = function(i) {
        var a, h2;
        this.length > i.length ? (a = this, h2 = i) : (a = i, h2 = this);
        for (var s = 0;s < h2.length; s++)
          this.words[s] = a.words[s] ^ h2.words[s];
        if (this !== a)
          for (;s < a.length; s++)
            this.words[s] = a.words[s];
        return this.length = a.length, this.strip();
      }, f.prototype.ixor = function(i) {
        return r((this.negative | i.negative) === 0), this.iuxor(i);
      }, f.prototype.xor = function(i) {
        return this.length > i.length ? this.clone().ixor(i) : i.clone().ixor(this);
      }, f.prototype.uxor = function(i) {
        return this.length > i.length ? this.clone().iuxor(i) : i.clone().iuxor(this);
      }, f.prototype.inotn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = Math.ceil(i / 26) | 0, h2 = i % 26;
        this._expand(a), h2 > 0 && a--;
        for (var s = 0;s < a; s++)
          this.words[s] = ~this.words[s] & 67108863;
        return h2 > 0 && (this.words[s] = ~this.words[s] & 67108863 >> 26 - h2), this.strip();
      }, f.prototype.notn = function(i) {
        return this.clone().inotn(i);
      }, f.prototype.setn = function(i, a) {
        r(typeof i == "number" && i >= 0);
        var h2 = i / 26 | 0, s = i % 26;
        return this._expand(h2 + 1), a ? this.words[h2] = this.words[h2] | 1 << s : this.words[h2] = this.words[h2] & ~(1 << s), this.strip();
      }, f.prototype.iadd = function(i) {
        var a;
        if (this.negative !== 0 && i.negative === 0)
          return this.negative = 0, a = this.isub(i), this.negative ^= 1, this._normSign();
        if (this.negative === 0 && i.negative !== 0)
          return i.negative = 0, a = this.isub(i), i.negative = 1, a._normSign();
        var h2, s;
        this.length > i.length ? (h2 = this, s = i) : (h2 = i, s = this);
        for (var u = 0, c = 0;c < s.length; c++)
          a = (h2.words[c] | 0) + (s.words[c] | 0) + u, this.words[c] = a & 67108863, u = a >>> 26;
        for (;u !== 0 && c < h2.length; c++)
          a = (h2.words[c] | 0) + u, this.words[c] = a & 67108863, u = a >>> 26;
        if (this.length = h2.length, u !== 0)
          this.words[this.length] = u, this.length++;
        else if (h2 !== this)
          for (;c < h2.length; c++)
            this.words[c] = h2.words[c];
        return this;
      }, f.prototype.add = function(i) {
        var a;
        return i.negative !== 0 && this.negative === 0 ? (i.negative = 0, a = this.sub(i), i.negative ^= 1, a) : i.negative === 0 && this.negative !== 0 ? (this.negative = 0, a = i.sub(this), this.negative = 1, a) : this.length > i.length ? this.clone().iadd(i) : i.clone().iadd(this);
      }, f.prototype.isub = function(i) {
        if (i.negative !== 0) {
          i.negative = 0;
          var a = this.iadd(i);
          return i.negative = 1, a._normSign();
        } else if (this.negative !== 0)
          return this.negative = 0, this.iadd(i), this.negative = 1, this._normSign();
        var h2 = this.cmp(i);
        if (h2 === 0)
          return this.negative = 0, this.length = 1, this.words[0] = 0, this;
        var s, u;
        h2 > 0 ? (s = this, u = i) : (s = i, u = this);
        for (var c = 0, b2 = 0;b2 < u.length; b2++)
          a = (s.words[b2] | 0) - (u.words[b2] | 0) + c, c = a >> 26, this.words[b2] = a & 67108863;
        for (;c !== 0 && b2 < s.length; b2++)
          a = (s.words[b2] | 0) + c, c = a >> 26, this.words[b2] = a & 67108863;
        if (c === 0 && b2 < s.length && s !== this)
          for (;b2 < s.length; b2++)
            this.words[b2] = s.words[b2];
        return this.length = Math.max(this.length, b2), s !== this && (this.negative = 1), this.strip();
      }, f.prototype.sub = function(i) {
        return this.clone().isub(i);
      };
      function q2(v, i, a) {
        a.negative = i.negative ^ v.negative;
        var h2 = v.length + i.length | 0;
        a.length = h2, h2 = h2 - 1 | 0;
        var s = v.words[0] | 0, u = i.words[0] | 0, c = s * u, b2 = c & 67108863, l = c / 67108864 | 0;
        a.words[0] = b2;
        for (var n = 1;n < h2; n++) {
          for (var d = l >>> 26, w = l & 67108863, g = Math.min(n, i.length - 1), _2 = Math.max(0, n - v.length + 1);_2 <= g; _2++) {
            var A2 = n - _2 | 0;
            s = v.words[A2] | 0, u = i.words[_2] | 0, c = s * u + w, d += c / 67108864 | 0, w = c & 67108863;
          }
          a.words[n] = w | 0, l = d | 0;
        }
        return l !== 0 ? a.words[n] = l | 0 : a.length--, a.strip();
      }
      var L2 = function(i, a, h2) {
        var s = i.words, u = a.words, c = h2.words, b2 = 0, l, n, d, w = s[0] | 0, g = w & 8191, _2 = w >>> 13, A2 = s[1] | 0, R2 = A2 & 8191, I = A2 >>> 13, Me = s[2] | 0, k = Me & 8191, D2 = Me >>> 13, nt = s[3] | 0, C2 = nt & 8191, O = nt >>> 13, vt = s[4] | 0, F = vt & 8191, U = vt >>> 13, bt = s[5] | 0, z2 = bt & 8191, H = bt >>> 13, mt = s[6] | 0, W = mt & 8191, K = mt >>> 13, gt = s[7] | 0, j = gt & 8191, Z = gt >>> 13, yt = s[8] | 0, V = yt & 8191, $ = yt >>> 13, wt = s[9] | 0, G = wt & 8191, Y = wt >>> 13, Mt = u[0] | 0, X = Mt & 8191, J = Mt >>> 13, _t = u[1] | 0, Q = _t & 8191, ee = _t >>> 13, xt = u[2] | 0, te = xt & 8191, re = xt >>> 13, St = u[3] | 0, ie = St & 8191, ne = St >>> 13, Et = u[4] | 0, fe = Et & 8191, ae = Et >>> 13, At = u[5] | 0, oe = At & 8191, se = At >>> 13, Rt = u[6] | 0, he = Rt & 8191, ue = Rt >>> 13, Bt = u[7] | 0, le = Bt & 8191, de = Bt >>> 13, qt = u[8] | 0, ce = qt & 8191, pe = qt >>> 13, It = u[9] | 0, ve = It & 8191, be = It >>> 13;
        h2.negative = i.negative ^ a.negative, h2.length = 19, l = Math.imul(g, X), n = Math.imul(g, J), n = n + Math.imul(_2, X) | 0, d = Math.imul(_2, J);
        var ft = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (ft >>> 26) | 0, ft &= 67108863, l = Math.imul(R2, X), n = Math.imul(R2, J), n = n + Math.imul(I, X) | 0, d = Math.imul(I, J), l = l + Math.imul(g, Q) | 0, n = n + Math.imul(g, ee) | 0, n = n + Math.imul(_2, Q) | 0, d = d + Math.imul(_2, ee) | 0;
        var Be = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Be >>> 26) | 0, Be &= 67108863, l = Math.imul(k, X), n = Math.imul(k, J), n = n + Math.imul(D2, X) | 0, d = Math.imul(D2, J), l = l + Math.imul(R2, Q) | 0, n = n + Math.imul(R2, ee) | 0, n = n + Math.imul(I, Q) | 0, d = d + Math.imul(I, ee) | 0, l = l + Math.imul(g, te) | 0, n = n + Math.imul(g, re) | 0, n = n + Math.imul(_2, te) | 0, d = d + Math.imul(_2, re) | 0;
        var qe = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (qe >>> 26) | 0, qe &= 67108863, l = Math.imul(C2, X), n = Math.imul(C2, J), n = n + Math.imul(O, X) | 0, d = Math.imul(O, J), l = l + Math.imul(k, Q) | 0, n = n + Math.imul(k, ee) | 0, n = n + Math.imul(D2, Q) | 0, d = d + Math.imul(D2, ee) | 0, l = l + Math.imul(R2, te) | 0, n = n + Math.imul(R2, re) | 0, n = n + Math.imul(I, te) | 0, d = d + Math.imul(I, re) | 0, l = l + Math.imul(g, ie) | 0, n = n + Math.imul(g, ne) | 0, n = n + Math.imul(_2, ie) | 0, d = d + Math.imul(_2, ne) | 0;
        var ze = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (ze >>> 26) | 0, ze &= 67108863, l = Math.imul(F, X), n = Math.imul(F, J), n = n + Math.imul(U, X) | 0, d = Math.imul(U, J), l = l + Math.imul(C2, Q) | 0, n = n + Math.imul(C2, ee) | 0, n = n + Math.imul(O, Q) | 0, d = d + Math.imul(O, ee) | 0, l = l + Math.imul(k, te) | 0, n = n + Math.imul(k, re) | 0, n = n + Math.imul(D2, te) | 0, d = d + Math.imul(D2, re) | 0, l = l + Math.imul(R2, ie) | 0, n = n + Math.imul(R2, ne) | 0, n = n + Math.imul(I, ie) | 0, d = d + Math.imul(I, ne) | 0, l = l + Math.imul(g, fe) | 0, n = n + Math.imul(g, ae) | 0, n = n + Math.imul(_2, fe) | 0, d = d + Math.imul(_2, ae) | 0;
        var He = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (He >>> 26) | 0, He &= 67108863, l = Math.imul(z2, X), n = Math.imul(z2, J), n = n + Math.imul(H, X) | 0, d = Math.imul(H, J), l = l + Math.imul(F, Q) | 0, n = n + Math.imul(F, ee) | 0, n = n + Math.imul(U, Q) | 0, d = d + Math.imul(U, ee) | 0, l = l + Math.imul(C2, te) | 0, n = n + Math.imul(C2, re) | 0, n = n + Math.imul(O, te) | 0, d = d + Math.imul(O, re) | 0, l = l + Math.imul(k, ie) | 0, n = n + Math.imul(k, ne) | 0, n = n + Math.imul(D2, ie) | 0, d = d + Math.imul(D2, ne) | 0, l = l + Math.imul(R2, fe) | 0, n = n + Math.imul(R2, ae) | 0, n = n + Math.imul(I, fe) | 0, d = d + Math.imul(I, ae) | 0, l = l + Math.imul(g, oe) | 0, n = n + Math.imul(g, se) | 0, n = n + Math.imul(_2, oe) | 0, d = d + Math.imul(_2, se) | 0;
        var We = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (We >>> 26) | 0, We &= 67108863, l = Math.imul(W, X), n = Math.imul(W, J), n = n + Math.imul(K, X) | 0, d = Math.imul(K, J), l = l + Math.imul(z2, Q) | 0, n = n + Math.imul(z2, ee) | 0, n = n + Math.imul(H, Q) | 0, d = d + Math.imul(H, ee) | 0, l = l + Math.imul(F, te) | 0, n = n + Math.imul(F, re) | 0, n = n + Math.imul(U, te) | 0, d = d + Math.imul(U, re) | 0, l = l + Math.imul(C2, ie) | 0, n = n + Math.imul(C2, ne) | 0, n = n + Math.imul(O, ie) | 0, d = d + Math.imul(O, ne) | 0, l = l + Math.imul(k, fe) | 0, n = n + Math.imul(k, ae) | 0, n = n + Math.imul(D2, fe) | 0, d = d + Math.imul(D2, ae) | 0, l = l + Math.imul(R2, oe) | 0, n = n + Math.imul(R2, se) | 0, n = n + Math.imul(I, oe) | 0, d = d + Math.imul(I, se) | 0, l = l + Math.imul(g, he) | 0, n = n + Math.imul(g, ue) | 0, n = n + Math.imul(_2, he) | 0, d = d + Math.imul(_2, ue) | 0;
        var Ke = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ke >>> 26) | 0, Ke &= 67108863, l = Math.imul(j, X), n = Math.imul(j, J), n = n + Math.imul(Z, X) | 0, d = Math.imul(Z, J), l = l + Math.imul(W, Q) | 0, n = n + Math.imul(W, ee) | 0, n = n + Math.imul(K, Q) | 0, d = d + Math.imul(K, ee) | 0, l = l + Math.imul(z2, te) | 0, n = n + Math.imul(z2, re) | 0, n = n + Math.imul(H, te) | 0, d = d + Math.imul(H, re) | 0, l = l + Math.imul(F, ie) | 0, n = n + Math.imul(F, ne) | 0, n = n + Math.imul(U, ie) | 0, d = d + Math.imul(U, ne) | 0, l = l + Math.imul(C2, fe) | 0, n = n + Math.imul(C2, ae) | 0, n = n + Math.imul(O, fe) | 0, d = d + Math.imul(O, ae) | 0, l = l + Math.imul(k, oe) | 0, n = n + Math.imul(k, se) | 0, n = n + Math.imul(D2, oe) | 0, d = d + Math.imul(D2, se) | 0, l = l + Math.imul(R2, he) | 0, n = n + Math.imul(R2, ue) | 0, n = n + Math.imul(I, he) | 0, d = d + Math.imul(I, ue) | 0, l = l + Math.imul(g, le) | 0, n = n + Math.imul(g, de) | 0, n = n + Math.imul(_2, le) | 0, d = d + Math.imul(_2, de) | 0;
        var je = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (je >>> 26) | 0, je &= 67108863, l = Math.imul(V, X), n = Math.imul(V, J), n = n + Math.imul($, X) | 0, d = Math.imul($, J), l = l + Math.imul(j, Q) | 0, n = n + Math.imul(j, ee) | 0, n = n + Math.imul(Z, Q) | 0, d = d + Math.imul(Z, ee) | 0, l = l + Math.imul(W, te) | 0, n = n + Math.imul(W, re) | 0, n = n + Math.imul(K, te) | 0, d = d + Math.imul(K, re) | 0, l = l + Math.imul(z2, ie) | 0, n = n + Math.imul(z2, ne) | 0, n = n + Math.imul(H, ie) | 0, d = d + Math.imul(H, ne) | 0, l = l + Math.imul(F, fe) | 0, n = n + Math.imul(F, ae) | 0, n = n + Math.imul(U, fe) | 0, d = d + Math.imul(U, ae) | 0, l = l + Math.imul(C2, oe) | 0, n = n + Math.imul(C2, se) | 0, n = n + Math.imul(O, oe) | 0, d = d + Math.imul(O, se) | 0, l = l + Math.imul(k, he) | 0, n = n + Math.imul(k, ue) | 0, n = n + Math.imul(D2, he) | 0, d = d + Math.imul(D2, ue) | 0, l = l + Math.imul(R2, le) | 0, n = n + Math.imul(R2, de) | 0, n = n + Math.imul(I, le) | 0, d = d + Math.imul(I, de) | 0, l = l + Math.imul(g, ce) | 0, n = n + Math.imul(g, pe) | 0, n = n + Math.imul(_2, ce) | 0, d = d + Math.imul(_2, pe) | 0;
        var Ze = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ze >>> 26) | 0, Ze &= 67108863, l = Math.imul(G, X), n = Math.imul(G, J), n = n + Math.imul(Y, X) | 0, d = Math.imul(Y, J), l = l + Math.imul(V, Q) | 0, n = n + Math.imul(V, ee) | 0, n = n + Math.imul($, Q) | 0, d = d + Math.imul($, ee) | 0, l = l + Math.imul(j, te) | 0, n = n + Math.imul(j, re) | 0, n = n + Math.imul(Z, te) | 0, d = d + Math.imul(Z, re) | 0, l = l + Math.imul(W, ie) | 0, n = n + Math.imul(W, ne) | 0, n = n + Math.imul(K, ie) | 0, d = d + Math.imul(K, ne) | 0, l = l + Math.imul(z2, fe) | 0, n = n + Math.imul(z2, ae) | 0, n = n + Math.imul(H, fe) | 0, d = d + Math.imul(H, ae) | 0, l = l + Math.imul(F, oe) | 0, n = n + Math.imul(F, se) | 0, n = n + Math.imul(U, oe) | 0, d = d + Math.imul(U, se) | 0, l = l + Math.imul(C2, he) | 0, n = n + Math.imul(C2, ue) | 0, n = n + Math.imul(O, he) | 0, d = d + Math.imul(O, ue) | 0, l = l + Math.imul(k, le) | 0, n = n + Math.imul(k, de) | 0, n = n + Math.imul(D2, le) | 0, d = d + Math.imul(D2, de) | 0, l = l + Math.imul(R2, ce) | 0, n = n + Math.imul(R2, pe) | 0, n = n + Math.imul(I, ce) | 0, d = d + Math.imul(I, pe) | 0, l = l + Math.imul(g, ve) | 0, n = n + Math.imul(g, be) | 0, n = n + Math.imul(_2, ve) | 0, d = d + Math.imul(_2, be) | 0;
        var Ve = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ve >>> 26) | 0, Ve &= 67108863, l = Math.imul(G, Q), n = Math.imul(G, ee), n = n + Math.imul(Y, Q) | 0, d = Math.imul(Y, ee), l = l + Math.imul(V, te) | 0, n = n + Math.imul(V, re) | 0, n = n + Math.imul($, te) | 0, d = d + Math.imul($, re) | 0, l = l + Math.imul(j, ie) | 0, n = n + Math.imul(j, ne) | 0, n = n + Math.imul(Z, ie) | 0, d = d + Math.imul(Z, ne) | 0, l = l + Math.imul(W, fe) | 0, n = n + Math.imul(W, ae) | 0, n = n + Math.imul(K, fe) | 0, d = d + Math.imul(K, ae) | 0, l = l + Math.imul(z2, oe) | 0, n = n + Math.imul(z2, se) | 0, n = n + Math.imul(H, oe) | 0, d = d + Math.imul(H, se) | 0, l = l + Math.imul(F, he) | 0, n = n + Math.imul(F, ue) | 0, n = n + Math.imul(U, he) | 0, d = d + Math.imul(U, ue) | 0, l = l + Math.imul(C2, le) | 0, n = n + Math.imul(C2, de) | 0, n = n + Math.imul(O, le) | 0, d = d + Math.imul(O, de) | 0, l = l + Math.imul(k, ce) | 0, n = n + Math.imul(k, pe) | 0, n = n + Math.imul(D2, ce) | 0, d = d + Math.imul(D2, pe) | 0, l = l + Math.imul(R2, ve) | 0, n = n + Math.imul(R2, be) | 0, n = n + Math.imul(I, ve) | 0, d = d + Math.imul(I, be) | 0;
        var $e = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + ($e >>> 26) | 0, $e &= 67108863, l = Math.imul(G, te), n = Math.imul(G, re), n = n + Math.imul(Y, te) | 0, d = Math.imul(Y, re), l = l + Math.imul(V, ie) | 0, n = n + Math.imul(V, ne) | 0, n = n + Math.imul($, ie) | 0, d = d + Math.imul($, ne) | 0, l = l + Math.imul(j, fe) | 0, n = n + Math.imul(j, ae) | 0, n = n + Math.imul(Z, fe) | 0, d = d + Math.imul(Z, ae) | 0, l = l + Math.imul(W, oe) | 0, n = n + Math.imul(W, se) | 0, n = n + Math.imul(K, oe) | 0, d = d + Math.imul(K, se) | 0, l = l + Math.imul(z2, he) | 0, n = n + Math.imul(z2, ue) | 0, n = n + Math.imul(H, he) | 0, d = d + Math.imul(H, ue) | 0, l = l + Math.imul(F, le) | 0, n = n + Math.imul(F, de) | 0, n = n + Math.imul(U, le) | 0, d = d + Math.imul(U, de) | 0, l = l + Math.imul(C2, ce) | 0, n = n + Math.imul(C2, pe) | 0, n = n + Math.imul(O, ce) | 0, d = d + Math.imul(O, pe) | 0, l = l + Math.imul(k, ve) | 0, n = n + Math.imul(k, be) | 0, n = n + Math.imul(D2, ve) | 0, d = d + Math.imul(D2, be) | 0;
        var Ge = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ge >>> 26) | 0, Ge &= 67108863, l = Math.imul(G, ie), n = Math.imul(G, ne), n = n + Math.imul(Y, ie) | 0, d = Math.imul(Y, ne), l = l + Math.imul(V, fe) | 0, n = n + Math.imul(V, ae) | 0, n = n + Math.imul($, fe) | 0, d = d + Math.imul($, ae) | 0, l = l + Math.imul(j, oe) | 0, n = n + Math.imul(j, se) | 0, n = n + Math.imul(Z, oe) | 0, d = d + Math.imul(Z, se) | 0, l = l + Math.imul(W, he) | 0, n = n + Math.imul(W, ue) | 0, n = n + Math.imul(K, he) | 0, d = d + Math.imul(K, ue) | 0, l = l + Math.imul(z2, le) | 0, n = n + Math.imul(z2, de) | 0, n = n + Math.imul(H, le) | 0, d = d + Math.imul(H, de) | 0, l = l + Math.imul(F, ce) | 0, n = n + Math.imul(F, pe) | 0, n = n + Math.imul(U, ce) | 0, d = d + Math.imul(U, pe) | 0, l = l + Math.imul(C2, ve) | 0, n = n + Math.imul(C2, be) | 0, n = n + Math.imul(O, ve) | 0, d = d + Math.imul(O, be) | 0;
        var Ye = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ye >>> 26) | 0, Ye &= 67108863, l = Math.imul(G, fe), n = Math.imul(G, ae), n = n + Math.imul(Y, fe) | 0, d = Math.imul(Y, ae), l = l + Math.imul(V, oe) | 0, n = n + Math.imul(V, se) | 0, n = n + Math.imul($, oe) | 0, d = d + Math.imul($, se) | 0, l = l + Math.imul(j, he) | 0, n = n + Math.imul(j, ue) | 0, n = n + Math.imul(Z, he) | 0, d = d + Math.imul(Z, ue) | 0, l = l + Math.imul(W, le) | 0, n = n + Math.imul(W, de) | 0, n = n + Math.imul(K, le) | 0, d = d + Math.imul(K, de) | 0, l = l + Math.imul(z2, ce) | 0, n = n + Math.imul(z2, pe) | 0, n = n + Math.imul(H, ce) | 0, d = d + Math.imul(H, pe) | 0, l = l + Math.imul(F, ve) | 0, n = n + Math.imul(F, be) | 0, n = n + Math.imul(U, ve) | 0, d = d + Math.imul(U, be) | 0;
        var Xe = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Xe >>> 26) | 0, Xe &= 67108863, l = Math.imul(G, oe), n = Math.imul(G, se), n = n + Math.imul(Y, oe) | 0, d = Math.imul(Y, se), l = l + Math.imul(V, he) | 0, n = n + Math.imul(V, ue) | 0, n = n + Math.imul($, he) | 0, d = d + Math.imul($, ue) | 0, l = l + Math.imul(j, le) | 0, n = n + Math.imul(j, de) | 0, n = n + Math.imul(Z, le) | 0, d = d + Math.imul(Z, de) | 0, l = l + Math.imul(W, ce) | 0, n = n + Math.imul(W, pe) | 0, n = n + Math.imul(K, ce) | 0, d = d + Math.imul(K, pe) | 0, l = l + Math.imul(z2, ve) | 0, n = n + Math.imul(z2, be) | 0, n = n + Math.imul(H, ve) | 0, d = d + Math.imul(H, be) | 0;
        var Je = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Je >>> 26) | 0, Je &= 67108863, l = Math.imul(G, he), n = Math.imul(G, ue), n = n + Math.imul(Y, he) | 0, d = Math.imul(Y, ue), l = l + Math.imul(V, le) | 0, n = n + Math.imul(V, de) | 0, n = n + Math.imul($, le) | 0, d = d + Math.imul($, de) | 0, l = l + Math.imul(j, ce) | 0, n = n + Math.imul(j, pe) | 0, n = n + Math.imul(Z, ce) | 0, d = d + Math.imul(Z, pe) | 0, l = l + Math.imul(W, ve) | 0, n = n + Math.imul(W, be) | 0, n = n + Math.imul(K, ve) | 0, d = d + Math.imul(K, be) | 0;
        var Qe = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Qe >>> 26) | 0, Qe &= 67108863, l = Math.imul(G, le), n = Math.imul(G, de), n = n + Math.imul(Y, le) | 0, d = Math.imul(Y, de), l = l + Math.imul(V, ce) | 0, n = n + Math.imul(V, pe) | 0, n = n + Math.imul($, ce) | 0, d = d + Math.imul($, pe) | 0, l = l + Math.imul(j, ve) | 0, n = n + Math.imul(j, be) | 0, n = n + Math.imul(Z, ve) | 0, d = d + Math.imul(Z, be) | 0;
        var et = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (et >>> 26) | 0, et &= 67108863, l = Math.imul(G, ce), n = Math.imul(G, pe), n = n + Math.imul(Y, ce) | 0, d = Math.imul(Y, pe), l = l + Math.imul(V, ve) | 0, n = n + Math.imul(V, be) | 0, n = n + Math.imul($, ve) | 0, d = d + Math.imul($, be) | 0;
        var tt = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (tt >>> 26) | 0, tt &= 67108863, l = Math.imul(G, ve), n = Math.imul(G, be), n = n + Math.imul(Y, ve) | 0, d = Math.imul(Y, be);
        var rt = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        return b2 = (d + (n >>> 13) | 0) + (rt >>> 26) | 0, rt &= 67108863, c[0] = ft, c[1] = Be, c[2] = qe, c[3] = ze, c[4] = He, c[5] = We, c[6] = Ke, c[7] = je, c[8] = Ze, c[9] = Ve, c[10] = $e, c[11] = Ge, c[12] = Ye, c[13] = Xe, c[14] = Je, c[15] = Qe, c[16] = et, c[17] = tt, c[18] = rt, b2 !== 0 && (c[19] = b2, h2.length++), h2;
      };
      Math.imul || (L2 = q2);
      function ge(v, i, a) {
        a.negative = i.negative ^ v.negative, a.length = v.length + i.length;
        for (var h2 = 0, s = 0, u = 0;u < a.length - 1; u++) {
          var c = s;
          s = 0;
          for (var b2 = h2 & 67108863, l = Math.min(u, i.length - 1), n = Math.max(0, u - v.length + 1);n <= l; n++) {
            var d = u - n, w = v.words[d] | 0, g = i.words[n] | 0, _2 = w * g, A2 = _2 & 67108863;
            c = c + (_2 / 67108864 | 0) | 0, A2 = A2 + b2 | 0, b2 = A2 & 67108863, c = c + (A2 >>> 26) | 0, s += c >>> 26, c &= 67108863;
          }
          a.words[u] = b2, h2 = c, c = s;
        }
        return h2 !== 0 ? a.words[u] = h2 : a.length--, a.strip();
      }
      function _e(v, i, a) {
        var h2 = new N;
        return h2.mulp(v, i, a);
      }
      f.prototype.mulTo = function(i, a) {
        var h2, s = this.length + i.length;
        return this.length === 10 && i.length === 10 ? h2 = L2(this, i, a) : s < 63 ? h2 = q2(this, i, a) : s < 1024 ? h2 = ge(this, i, a) : h2 = _e(this, i, a), h2;
      };
      function N(v, i) {
        this.x = v, this.y = i;
      }
      N.prototype.makeRBT = function(i) {
        for (var a = new Array(i), h2 = f.prototype._countBits(i) - 1, s = 0;s < i; s++)
          a[s] = this.revBin(s, h2, i);
        return a;
      }, N.prototype.revBin = function(i, a, h2) {
        if (i === 0 || i === h2 - 1)
          return i;
        for (var s = 0, u = 0;u < a; u++)
          s |= (i & 1) << a - u - 1, i >>= 1;
        return s;
      }, N.prototype.permute = function(i, a, h2, s, u, c) {
        for (var b2 = 0;b2 < c; b2++)
          s[b2] = a[i[b2]], u[b2] = h2[i[b2]];
      }, N.prototype.transform = function(i, a, h2, s, u, c) {
        this.permute(c, i, a, h2, s, u);
        for (var b2 = 1;b2 < u; b2 <<= 1)
          for (var l = b2 << 1, n = Math.cos(2 * Math.PI / l), d = Math.sin(2 * Math.PI / l), w = 0;w < u; w += l)
            for (var g = n, _2 = d, A2 = 0;A2 < b2; A2++) {
              var R2 = h2[w + A2], I = s[w + A2], Me = h2[w + A2 + b2], k = s[w + A2 + b2], D2 = g * Me - _2 * k;
              k = g * k + _2 * Me, Me = D2, h2[w + A2] = R2 + Me, s[w + A2] = I + k, h2[w + A2 + b2] = R2 - Me, s[w + A2 + b2] = I - k, A2 !== l && (D2 = n * g - d * _2, _2 = n * _2 + d * g, g = D2);
            }
      }, N.prototype.guessLen13b = function(i, a) {
        var h2 = Math.max(a, i) | 1, s = h2 & 1, u = 0;
        for (h2 = h2 / 2 | 0;h2; h2 = h2 >>> 1)
          u++;
        return 1 << u + 1 + s;
      }, N.prototype.conjugate = function(i, a, h2) {
        if (!(h2 <= 1))
          for (var s = 0;s < h2 / 2; s++) {
            var u = i[s];
            i[s] = i[h2 - s - 1], i[h2 - s - 1] = u, u = a[s], a[s] = -a[h2 - s - 1], a[h2 - s - 1] = -u;
          }
      }, N.prototype.normalize13b = function(i, a) {
        for (var h2 = 0, s = 0;s < a / 2; s++) {
          var u = Math.round(i[2 * s + 1] / a) * 8192 + Math.round(i[2 * s] / a) + h2;
          i[s] = u & 67108863, u < 67108864 ? h2 = 0 : h2 = u / 67108864 | 0;
        }
        return i;
      }, N.prototype.convert13b = function(i, a, h2, s) {
        for (var u = 0, c = 0;c < a; c++)
          u = u + (i[c] | 0), h2[2 * c] = u & 8191, u = u >>> 13, h2[2 * c + 1] = u & 8191, u = u >>> 13;
        for (c = 2 * a;c < s; ++c)
          h2[c] = 0;
        r(u === 0), r((u & -8192) === 0);
      }, N.prototype.stub = function(i) {
        for (var a = new Array(i), h2 = 0;h2 < i; h2++)
          a[h2] = 0;
        return a;
      }, N.prototype.mulp = function(i, a, h2) {
        var s = 2 * this.guessLen13b(i.length, a.length), u = this.makeRBT(s), c = this.stub(s), b2 = new Array(s), l = new Array(s), n = new Array(s), d = new Array(s), w = new Array(s), g = new Array(s), _2 = h2.words;
        _2.length = s, this.convert13b(i.words, i.length, b2, s), this.convert13b(a.words, a.length, d, s), this.transform(b2, c, l, n, s, u), this.transform(d, c, w, g, s, u);
        for (var A2 = 0;A2 < s; A2++) {
          var R2 = l[A2] * w[A2] - n[A2] * g[A2];
          n[A2] = l[A2] * g[A2] + n[A2] * w[A2], l[A2] = R2;
        }
        return this.conjugate(l, n, s), this.transform(l, n, _2, c, s, u), this.conjugate(_2, c, s), this.normalize13b(_2, s), h2.negative = i.negative ^ a.negative, h2.length = i.length + a.length, h2.strip();
      }, f.prototype.mul = function(i) {
        var a = new f(null);
        return a.words = new Array(this.length + i.length), this.mulTo(i, a);
      }, f.prototype.mulf = function(i) {
        var a = new f(null);
        return a.words = new Array(this.length + i.length), _e(this, i, a);
      }, f.prototype.imul = function(i) {
        return this.clone().mulTo(i, this);
      }, f.prototype.imuln = function(i) {
        r(typeof i == "number"), r(i < 67108864);
        for (var a = 0, h2 = 0;h2 < this.length; h2++) {
          var s = (this.words[h2] | 0) * i, u = (s & 67108863) + (a & 67108863);
          a >>= 26, a += s / 67108864 | 0, a += u >>> 26, this.words[h2] = u & 67108863;
        }
        return a !== 0 && (this.words[h2] = a, this.length++), this;
      }, f.prototype.muln = function(i) {
        return this.clone().imuln(i);
      }, f.prototype.sqr = function() {
        return this.mul(this);
      }, f.prototype.isqr = function() {
        return this.imul(this.clone());
      }, f.prototype.pow = function(i) {
        var a = B(i);
        if (a.length === 0)
          return new f(1);
        for (var h2 = this, s = 0;s < a.length && a[s] === 0; s++, h2 = h2.sqr())
          ;
        if (++s < a.length)
          for (var u = h2.sqr();s < a.length; s++, u = u.sqr())
            a[s] !== 0 && (h2 = h2.mul(u));
        return h2;
      }, f.prototype.iushln = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26, s = 67108863 >>> 26 - a << 26 - a, u;
        if (a !== 0) {
          var c = 0;
          for (u = 0;u < this.length; u++) {
            var b2 = this.words[u] & s, l = (this.words[u] | 0) - b2 << a;
            this.words[u] = l | c, c = b2 >>> 26 - a;
          }
          c && (this.words[u] = c, this.length++);
        }
        if (h2 !== 0) {
          for (u = this.length - 1;u >= 0; u--)
            this.words[u + h2] = this.words[u];
          for (u = 0;u < h2; u++)
            this.words[u] = 0;
          this.length += h2;
        }
        return this.strip();
      }, f.prototype.ishln = function(i) {
        return r(this.negative === 0), this.iushln(i);
      }, f.prototype.iushrn = function(i, a, h2) {
        r(typeof i == "number" && i >= 0);
        var s;
        a ? s = (a - a % 26) / 26 : s = 0;
        var u = i % 26, c = Math.min((i - u) / 26, this.length), b2 = 67108863 ^ 67108863 >>> u << u, l = h2;
        if (s -= c, s = Math.max(0, s), l) {
          for (var n = 0;n < c; n++)
            l.words[n] = this.words[n];
          l.length = c;
        }
        if (c !== 0)
          if (this.length > c)
            for (this.length -= c, n = 0;n < this.length; n++)
              this.words[n] = this.words[n + c];
          else
            this.words[0] = 0, this.length = 1;
        var d = 0;
        for (n = this.length - 1;n >= 0 && (d !== 0 || n >= s); n--) {
          var w = this.words[n] | 0;
          this.words[n] = d << 26 - u | w >>> u, d = w & b2;
        }
        return l && d !== 0 && (l.words[l.length++] = d), this.length === 0 && (this.words[0] = 0, this.length = 1), this.strip();
      }, f.prototype.ishrn = function(i, a, h2) {
        return r(this.negative === 0), this.iushrn(i, a, h2);
      }, f.prototype.shln = function(i) {
        return this.clone().ishln(i);
      }, f.prototype.ushln = function(i) {
        return this.clone().iushln(i);
      }, f.prototype.shrn = function(i) {
        return this.clone().ishrn(i);
      }, f.prototype.ushrn = function(i) {
        return this.clone().iushrn(i);
      }, f.prototype.testn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26, s = 1 << a;
        if (this.length <= h2)
          return false;
        var u = this.words[h2];
        return !!(u & s);
      }, f.prototype.imaskn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26;
        if (r(this.negative === 0, "imaskn works only with positive numbers"), this.length <= h2)
          return this;
        if (a !== 0 && h2++, this.length = Math.min(h2, this.length), a !== 0) {
          var s = 67108863 ^ 67108863 >>> a << a;
          this.words[this.length - 1] &= s;
        }
        return this.strip();
      }, f.prototype.maskn = function(i) {
        return this.clone().imaskn(i);
      }, f.prototype.iaddn = function(i) {
        return r(typeof i == "number"), r(i < 67108864), i < 0 ? this.isubn(-i) : this.negative !== 0 ? this.length === 1 && (this.words[0] | 0) < i ? (this.words[0] = i - (this.words[0] | 0), this.negative = 0, this) : (this.negative = 0, this.isubn(i), this.negative = 1, this) : this._iaddn(i);
      }, f.prototype._iaddn = function(i) {
        this.words[0] += i;
        for (var a = 0;a < this.length && this.words[a] >= 67108864; a++)
          this.words[a] -= 67108864, a === this.length - 1 ? this.words[a + 1] = 1 : this.words[a + 1]++;
        return this.length = Math.max(this.length, a + 1), this;
      }, f.prototype.isubn = function(i) {
        if (r(typeof i == "number"), r(i < 67108864), i < 0)
          return this.iaddn(-i);
        if (this.negative !== 0)
          return this.negative = 0, this.iaddn(i), this.negative = 1, this;
        if (this.words[0] -= i, this.length === 1 && this.words[0] < 0)
          this.words[0] = -this.words[0], this.negative = 1;
        else
          for (var a = 0;a < this.length && this.words[a] < 0; a++)
            this.words[a] += 67108864, this.words[a + 1] -= 1;
        return this.strip();
      }, f.prototype.addn = function(i) {
        return this.clone().iaddn(i);
      }, f.prototype.subn = function(i) {
        return this.clone().isubn(i);
      }, f.prototype.iabs = function() {
        return this.negative = 0, this;
      }, f.prototype.abs = function() {
        return this.clone().iabs();
      }, f.prototype._ishlnsubmul = function(i, a, h2) {
        var s = i.length + h2, u;
        this._expand(s);
        var c, b2 = 0;
        for (u = 0;u < i.length; u++) {
          c = (this.words[u + h2] | 0) + b2;
          var l = (i.words[u] | 0) * a;
          c -= l & 67108863, b2 = (c >> 26) - (l / 67108864 | 0), this.words[u + h2] = c & 67108863;
        }
        for (;u < this.length - h2; u++)
          c = (this.words[u + h2] | 0) + b2, b2 = c >> 26, this.words[u + h2] = c & 67108863;
        if (b2 === 0)
          return this.strip();
        for (r(b2 === -1), b2 = 0, u = 0;u < this.length; u++)
          c = -(this.words[u] | 0) + b2, b2 = c >> 26, this.words[u] = c & 67108863;
        return this.negative = 1, this.strip();
      }, f.prototype._wordDiv = function(i, a) {
        var h2 = this.length - i.length, s = this.clone(), u = i, c = u.words[u.length - 1] | 0, b2 = this._countBits(c);
        h2 = 26 - b2, h2 !== 0 && (u = u.ushln(h2), s.iushln(h2), c = u.words[u.length - 1] | 0);
        var l = s.length - u.length, n;
        if (a !== "mod") {
          n = new f(null), n.length = l + 1, n.words = new Array(n.length);
          for (var d = 0;d < n.length; d++)
            n.words[d] = 0;
        }
        var w = s.clone()._ishlnsubmul(u, 1, l);
        w.negative === 0 && (s = w, n && (n.words[l] = 1));
        for (var g = l - 1;g >= 0; g--) {
          var _2 = (s.words[u.length + g] | 0) * 67108864 + (s.words[u.length + g - 1] | 0);
          for (_2 = Math.min(_2 / c | 0, 67108863), s._ishlnsubmul(u, _2, g);s.negative !== 0; )
            _2--, s.negative = 0, s._ishlnsubmul(u, 1, g), s.isZero() || (s.negative ^= 1);
          n && (n.words[g] = _2);
        }
        return n && n.strip(), s.strip(), a !== "div" && h2 !== 0 && s.iushrn(h2), { div: n || null, mod: s };
      }, f.prototype.divmod = function(i, a, h2) {
        if (r(!i.isZero()), this.isZero())
          return { div: new f(0), mod: new f(0) };
        var s, u, c;
        return this.negative !== 0 && i.negative === 0 ? (c = this.neg().divmod(i, a), a !== "mod" && (s = c.div.neg()), a !== "div" && (u = c.mod.neg(), h2 && u.negative !== 0 && u.iadd(i)), { div: s, mod: u }) : this.negative === 0 && i.negative !== 0 ? (c = this.divmod(i.neg(), a), a !== "mod" && (s = c.div.neg()), { div: s, mod: c.mod }) : (this.negative & i.negative) !== 0 ? (c = this.neg().divmod(i.neg(), a), a !== "div" && (u = c.mod.neg(), h2 && u.negative !== 0 && u.isub(i)), { div: c.div, mod: u }) : i.length > this.length || this.cmp(i) < 0 ? { div: new f(0), mod: this } : i.length === 1 ? a === "div" ? { div: this.divn(i.words[0]), mod: null } : a === "mod" ? { div: null, mod: new f(this.modn(i.words[0])) } : { div: this.divn(i.words[0]), mod: new f(this.modn(i.words[0])) } : this._wordDiv(i, a);
      }, f.prototype.div = function(i) {
        return this.divmod(i, "div", false).div;
      }, f.prototype.mod = function(i) {
        return this.divmod(i, "mod", false).mod;
      }, f.prototype.umod = function(i) {
        return this.divmod(i, "mod", true).mod;
      }, f.prototype.divRound = function(i) {
        var a = this.divmod(i);
        if (a.mod.isZero())
          return a.div;
        var h2 = a.div.negative !== 0 ? a.mod.isub(i) : a.mod, s = i.ushrn(1), u = i.andln(1), c = h2.cmp(s);
        return c < 0 || u === 1 && c === 0 ? a.div : a.div.negative !== 0 ? a.div.isubn(1) : a.div.iaddn(1);
      }, f.prototype.modn = function(i) {
        r(i <= 67108863);
        for (var a = (1 << 26) % i, h2 = 0, s = this.length - 1;s >= 0; s--)
          h2 = (a * h2 + (this.words[s] | 0)) % i;
        return h2;
      }, f.prototype.idivn = function(i) {
        r(i <= 67108863);
        for (var a = 0, h2 = this.length - 1;h2 >= 0; h2--) {
          var s = (this.words[h2] | 0) + a * 67108864;
          this.words[h2] = s / i | 0, a = s % i;
        }
        return this.strip();
      }, f.prototype.divn = function(i) {
        return this.clone().idivn(i);
      }, f.prototype.egcd = function(i) {
        r(i.negative === 0), r(!i.isZero());
        var a = this, h2 = i.clone();
        a.negative !== 0 ? a = a.umod(i) : a = a.clone();
        for (var s = new f(1), u = new f(0), c = new f(0), b2 = new f(1), l = 0;a.isEven() && h2.isEven(); )
          a.iushrn(1), h2.iushrn(1), ++l;
        for (var n = h2.clone(), d = a.clone();!a.isZero(); ) {
          for (var w = 0, g = 1;(a.words[0] & g) === 0 && w < 26; ++w, g <<= 1)
            ;
          if (w > 0)
            for (a.iushrn(w);w-- > 0; )
              (s.isOdd() || u.isOdd()) && (s.iadd(n), u.isub(d)), s.iushrn(1), u.iushrn(1);
          for (var _2 = 0, A2 = 1;(h2.words[0] & A2) === 0 && _2 < 26; ++_2, A2 <<= 1)
            ;
          if (_2 > 0)
            for (h2.iushrn(_2);_2-- > 0; )
              (c.isOdd() || b2.isOdd()) && (c.iadd(n), b2.isub(d)), c.iushrn(1), b2.iushrn(1);
          a.cmp(h2) >= 0 ? (a.isub(h2), s.isub(c), u.isub(b2)) : (h2.isub(a), c.isub(s), b2.isub(u));
        }
        return { a: c, b: b2, gcd: h2.iushln(l) };
      }, f.prototype._invmp = function(i) {
        r(i.negative === 0), r(!i.isZero());
        var a = this, h2 = i.clone();
        a.negative !== 0 ? a = a.umod(i) : a = a.clone();
        for (var s = new f(1), u = new f(0), c = h2.clone();a.cmpn(1) > 0 && h2.cmpn(1) > 0; ) {
          for (var b2 = 0, l = 1;(a.words[0] & l) === 0 && b2 < 26; ++b2, l <<= 1)
            ;
          if (b2 > 0)
            for (a.iushrn(b2);b2-- > 0; )
              s.isOdd() && s.iadd(c), s.iushrn(1);
          for (var n = 0, d = 1;(h2.words[0] & d) === 0 && n < 26; ++n, d <<= 1)
            ;
          if (n > 0)
            for (h2.iushrn(n);n-- > 0; )
              u.isOdd() && u.iadd(c), u.iushrn(1);
          a.cmp(h2) >= 0 ? (a.isub(h2), s.isub(u)) : (h2.isub(a), u.isub(s));
        }
        var w;
        return a.cmpn(1) === 0 ? w = s : w = u, w.cmpn(0) < 0 && w.iadd(i), w;
      }, f.prototype.gcd = function(i) {
        if (this.isZero())
          return i.abs();
        if (i.isZero())
          return this.abs();
        var a = this.clone(), h2 = i.clone();
        a.negative = 0, h2.negative = 0;
        for (var s = 0;a.isEven() && h2.isEven(); s++)
          a.iushrn(1), h2.iushrn(1);
        do {
          for (;a.isEven(); )
            a.iushrn(1);
          for (;h2.isEven(); )
            h2.iushrn(1);
          var u = a.cmp(h2);
          if (u < 0) {
            var c = a;
            a = h2, h2 = c;
          } else if (u === 0 || h2.cmpn(1) === 0)
            break;
          a.isub(h2);
        } while (true);
        return h2.iushln(s);
      }, f.prototype.invm = function(i) {
        return this.egcd(i).a.umod(i);
      }, f.prototype.isEven = function() {
        return (this.words[0] & 1) === 0;
      }, f.prototype.isOdd = function() {
        return (this.words[0] & 1) === 1;
      }, f.prototype.andln = function(i) {
        return this.words[0] & i;
      }, f.prototype.bincn = function(i) {
        r(typeof i == "number");
        var a = i % 26, h2 = (i - a) / 26, s = 1 << a;
        if (this.length <= h2)
          return this._expand(h2 + 1), this.words[h2] |= s, this;
        for (var u = s, c = h2;u !== 0 && c < this.length; c++) {
          var b2 = this.words[c] | 0;
          b2 += u, u = b2 >>> 26, b2 &= 67108863, this.words[c] = b2;
        }
        return u !== 0 && (this.words[c] = u, this.length++), this;
      }, f.prototype.isZero = function() {
        return this.length === 1 && this.words[0] === 0;
      }, f.prototype.cmpn = function(i) {
        var a = i < 0;
        if (this.negative !== 0 && !a)
          return -1;
        if (this.negative === 0 && a)
          return 1;
        this.strip();
        var h2;
        if (this.length > 1)
          h2 = 1;
        else {
          a && (i = -i), r(i <= 67108863, "Number is too big");
          var s = this.words[0] | 0;
          h2 = s === i ? 0 : s < i ? -1 : 1;
        }
        return this.negative !== 0 ? -h2 | 0 : h2;
      }, f.prototype.cmp = function(i) {
        if (this.negative !== 0 && i.negative === 0)
          return -1;
        if (this.negative === 0 && i.negative !== 0)
          return 1;
        var a = this.ucmp(i);
        return this.negative !== 0 ? -a | 0 : a;
      }, f.prototype.ucmp = function(i) {
        if (this.length > i.length)
          return 1;
        if (this.length < i.length)
          return -1;
        for (var a = 0, h2 = this.length - 1;h2 >= 0; h2--) {
          var s = this.words[h2] | 0, u = i.words[h2] | 0;
          if (s !== u) {
            s < u ? a = -1 : s > u && (a = 1);
            break;
          }
        }
        return a;
      }, f.prototype.gtn = function(i) {
        return this.cmpn(i) === 1;
      }, f.prototype.gt = function(i) {
        return this.cmp(i) === 1;
      }, f.prototype.gten = function(i) {
        return this.cmpn(i) >= 0;
      }, f.prototype.gte = function(i) {
        return this.cmp(i) >= 0;
      }, f.prototype.ltn = function(i) {
        return this.cmpn(i) === -1;
      }, f.prototype.lt = function(i) {
        return this.cmp(i) === -1;
      }, f.prototype.lten = function(i) {
        return this.cmpn(i) <= 0;
      }, f.prototype.lte = function(i) {
        return this.cmp(i) <= 0;
      }, f.prototype.eqn = function(i) {
        return this.cmpn(i) === 0;
      }, f.prototype.eq = function(i) {
        return this.cmp(i) === 0;
      }, f.red = function(i) {
        return new P(i);
      }, f.prototype.toRed = function(i) {
        return r(!this.red, "Already a number in reduction context"), r(this.negative === 0, "red works only with positives"), i.convertTo(this)._forceRed(i);
      }, f.prototype.fromRed = function() {
        return r(this.red, "fromRed works only with numbers in reduction context"), this.red.convertFrom(this);
      }, f.prototype._forceRed = function(i) {
        return this.red = i, this;
      }, f.prototype.forceRed = function(i) {
        return r(!this.red, "Already a number in reduction context"), this._forceRed(i);
      }, f.prototype.redAdd = function(i) {
        return r(this.red, "redAdd works only with red numbers"), this.red.add(this, i);
      }, f.prototype.redIAdd = function(i) {
        return r(this.red, "redIAdd works only with red numbers"), this.red.iadd(this, i);
      }, f.prototype.redSub = function(i) {
        return r(this.red, "redSub works only with red numbers"), this.red.sub(this, i);
      }, f.prototype.redISub = function(i) {
        return r(this.red, "redISub works only with red numbers"), this.red.isub(this, i);
      }, f.prototype.redShl = function(i) {
        return r(this.red, "redShl works only with red numbers"), this.red.shl(this, i);
      }, f.prototype.redMul = function(i) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, i), this.red.mul(this, i);
      }, f.prototype.redIMul = function(i) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, i), this.red.imul(this, i);
      }, f.prototype.redSqr = function() {
        return r(this.red, "redSqr works only with red numbers"), this.red._verify1(this), this.red.sqr(this);
      }, f.prototype.redISqr = function() {
        return r(this.red, "redISqr works only with red numbers"), this.red._verify1(this), this.red.isqr(this);
      }, f.prototype.redSqrt = function() {
        return r(this.red, "redSqrt works only with red numbers"), this.red._verify1(this), this.red.sqrt(this);
      }, f.prototype.redInvm = function() {
        return r(this.red, "redInvm works only with red numbers"), this.red._verify1(this), this.red.invm(this);
      }, f.prototype.redNeg = function() {
        return r(this.red, "redNeg works only with red numbers"), this.red._verify1(this), this.red.neg(this);
      }, f.prototype.redPow = function(i) {
        return r(this.red && !i.red, "redPow(normalNum)"), this.red._verify1(this), this.red.pow(this, i);
      };
      var we = { k256: null, p224: null, p192: null, p25519: null };
      function ye(v, i) {
        this.name = v, this.p = new f(i, 16), this.n = this.p.bitLength(), this.k = new f(1).iushln(this.n).isub(this.p), this.tmp = this._tmp();
      }
      ye.prototype._tmp = function() {
        var i = new f(null);
        return i.words = new Array(Math.ceil(this.n / 13)), i;
      }, ye.prototype.ireduce = function(i) {
        var a = i, h2;
        do
          this.split(a, this.tmp), a = this.imulK(a), a = a.iadd(this.tmp), h2 = a.bitLength();
        while (h2 > this.n);
        var s = h2 < this.n ? -1 : a.ucmp(this.p);
        return s === 0 ? (a.words[0] = 0, a.length = 1) : s > 0 ? a.isub(this.p) : a.strip !== undefined ? a.strip() : a._strip(), a;
      }, ye.prototype.split = function(i, a) {
        i.iushrn(this.n, 0, a);
      }, ye.prototype.imulK = function(i) {
        return i.imul(this.k);
      };
      function xe() {
        ye.call(this, "k256", "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f");
      }
      o(xe, ye), xe.prototype.split = function(i, a) {
        for (var h2 = 4194303, s = Math.min(i.length, 9), u = 0;u < s; u++)
          a.words[u] = i.words[u];
        if (a.length = s, i.length <= 9) {
          i.words[0] = 0, i.length = 1;
          return;
        }
        var c = i.words[9];
        for (a.words[a.length++] = c & h2, u = 10;u < i.length; u++) {
          var b2 = i.words[u] | 0;
          i.words[u - 10] = (b2 & h2) << 4 | c >>> 22, c = b2;
        }
        c >>>= 22, i.words[u - 10] = c, c === 0 && i.length > 10 ? i.length -= 10 : i.length -= 9;
      }, xe.prototype.imulK = function(i) {
        i.words[i.length] = 0, i.words[i.length + 1] = 0, i.length += 2;
        for (var a = 0, h2 = 0;h2 < i.length; h2++) {
          var s = i.words[h2] | 0;
          a += s * 977, i.words[h2] = a & 67108863, a = s * 64 + (a / 67108864 | 0);
        }
        return i.words[i.length - 1] === 0 && (i.length--, i.words[i.length - 1] === 0 && i.length--), i;
      };
      function Re() {
        ye.call(this, "p224", "ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001");
      }
      o(Re, ye);
      function Ee() {
        ye.call(this, "p192", "ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff");
      }
      o(Ee, ye);
      function Ae() {
        ye.call(this, "25519", "7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed");
      }
      o(Ae, ye), Ae.prototype.imulK = function(i) {
        for (var a = 0, h2 = 0;h2 < i.length; h2++) {
          var s = (i.words[h2] | 0) * 19 + a, u = s & 67108863;
          s >>>= 26, i.words[h2] = u, a = s;
        }
        return a !== 0 && (i.words[i.length++] = a), i;
      }, f._prime = function(i) {
        if (we[i])
          return we[i];
        var a;
        if (i === "k256")
          a = new xe;
        else if (i === "p224")
          a = new Re;
        else if (i === "p192")
          a = new Ee;
        else if (i === "p25519")
          a = new Ae;
        else
          throw new Error("Unknown prime " + i);
        return we[i] = a, a;
      };
      function P(v) {
        if (typeof v == "string") {
          var i = f._prime(v);
          this.m = i.p, this.prime = i;
        } else
          r(v.gtn(1), "modulus must be greater than 1"), this.m = v, this.prime = null;
      }
      P.prototype._verify1 = function(i) {
        r(i.negative === 0, "red works only with positives"), r(i.red, "red works only with red numbers");
      }, P.prototype._verify2 = function(i, a) {
        r((i.negative | a.negative) === 0, "red works only with positives"), r(i.red && i.red === a.red, "red works only with red numbers");
      }, P.prototype.imod = function(i) {
        return this.prime ? this.prime.ireduce(i)._forceRed(this) : i.umod(this.m)._forceRed(this);
      }, P.prototype.neg = function(i) {
        return i.isZero() ? i.clone() : this.m.sub(i)._forceRed(this);
      }, P.prototype.add = function(i, a) {
        this._verify2(i, a);
        var h2 = i.add(a);
        return h2.cmp(this.m) >= 0 && h2.isub(this.m), h2._forceRed(this);
      }, P.prototype.iadd = function(i, a) {
        this._verify2(i, a);
        var h2 = i.iadd(a);
        return h2.cmp(this.m) >= 0 && h2.isub(this.m), h2;
      }, P.prototype.sub = function(i, a) {
        this._verify2(i, a);
        var h2 = i.sub(a);
        return h2.cmpn(0) < 0 && h2.iadd(this.m), h2._forceRed(this);
      }, P.prototype.isub = function(i, a) {
        this._verify2(i, a);
        var h2 = i.isub(a);
        return h2.cmpn(0) < 0 && h2.iadd(this.m), h2;
      }, P.prototype.shl = function(i, a) {
        return this._verify1(i), this.imod(i.ushln(a));
      }, P.prototype.imul = function(i, a) {
        return this._verify2(i, a), this.imod(i.imul(a));
      }, P.prototype.mul = function(i, a) {
        return this._verify2(i, a), this.imod(i.mul(a));
      }, P.prototype.isqr = function(i) {
        return this.imul(i, i.clone());
      }, P.prototype.sqr = function(i) {
        return this.mul(i, i);
      }, P.prototype.sqrt = function(i) {
        if (i.isZero())
          return i.clone();
        var a = this.m.andln(3);
        if (r(a % 2 === 1), a === 3) {
          var h2 = this.m.add(new f(1)).iushrn(2);
          return this.pow(i, h2);
        }
        for (var s = this.m.subn(1), u = 0;!s.isZero() && s.andln(1) === 0; )
          u++, s.iushrn(1);
        r(!s.isZero());
        var c = new f(1).toRed(this), b2 = c.redNeg(), l = this.m.subn(1).iushrn(1), n = this.m.bitLength();
        for (n = new f(2 * n * n).toRed(this);this.pow(n, l).cmp(b2) !== 0; )
          n.redIAdd(b2);
        for (var d = this.pow(n, s), w = this.pow(i, s.addn(1).iushrn(1)), g = this.pow(i, s), _2 = u;g.cmp(c) !== 0; ) {
          for (var A2 = g, R2 = 0;A2.cmp(c) !== 0; R2++)
            A2 = A2.redSqr();
          r(R2 < _2);
          var I = this.pow(d, new f(1).iushln(_2 - R2 - 1));
          w = w.redMul(I), d = I.redSqr(), g = g.redMul(d), _2 = R2;
        }
        return w;
      }, P.prototype.invm = function(i) {
        var a = i._invmp(this.m);
        return a.negative !== 0 ? (a.negative = 0, this.imod(a).redNeg()) : this.imod(a);
      }, P.prototype.pow = function(i, a) {
        if (a.isZero())
          return new f(1).toRed(this);
        if (a.cmpn(1) === 0)
          return i.clone();
        var h2 = 4, s = new Array(1 << h2);
        s[0] = new f(1).toRed(this), s[1] = i;
        for (var u = 2;u < s.length; u++)
          s[u] = this.mul(s[u - 1], i);
        var c = s[0], b2 = 0, l = 0, n = a.bitLength() % 26;
        for (n === 0 && (n = 26), u = a.length - 1;u >= 0; u--) {
          for (var d = a.words[u], w = n - 1;w >= 0; w--) {
            var g = d >> w & 1;
            if (c !== s[0] && (c = this.sqr(c)), g === 0 && b2 === 0) {
              l = 0;
              continue;
            }
            b2 <<= 1, b2 |= g, l++, !(l !== h2 && (u !== 0 || w !== 0)) && (c = this.mul(c, s[b2]), l = 0, b2 = 0);
          }
          n = 26;
        }
        return c;
      }, P.prototype.convertTo = function(i) {
        var a = i.umod(this.m);
        return a === i ? a.clone() : a;
      }, P.prototype.convertFrom = function(i) {
        var a = i.clone();
        return a.red = null, a;
      }, f.mont = function(i) {
        return new Se(i);
      };
      function Se(v) {
        P.call(this, v), this.shift = this.m.bitLength(), this.shift % 26 !== 0 && (this.shift += 26 - this.shift % 26), this.r = new f(1).iushln(this.shift), this.r2 = this.imod(this.r.sqr()), this.rinv = this.r._invmp(this.m), this.minv = this.rinv.mul(this.r).isubn(1).div(this.m), this.minv = this.minv.umod(this.r), this.minv = this.r.sub(this.minv);
      }
      o(Se, P), Se.prototype.convertTo = function(i) {
        return this.imod(i.ushln(this.shift));
      }, Se.prototype.convertFrom = function(i) {
        var a = this.imod(i.mul(this.rinv));
        return a.red = null, a;
      }, Se.prototype.imul = function(i, a) {
        if (i.isZero() || a.isZero())
          return i.words[0] = 0, i.length = 1, i;
        var h2 = i.imul(a), s = h2.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), u = h2.isub(s).iushrn(this.shift), c = u;
        return u.cmp(this.m) >= 0 ? c = u.isub(this.m) : u.cmpn(0) < 0 && (c = u.iadd(this.m)), c._forceRed(this);
      }, Se.prototype.mul = function(i, a) {
        if (i.isZero() || a.isZero())
          return new f(0)._forceRed(this);
        var h2 = i.mul(a), s = h2.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), u = h2.isub(s).iushrn(this.shift), c = u;
        return u.cmp(this.m) >= 0 ? c = u.isub(this.m) : u.cmpn(0) < 0 && (c = u.iadd(this.m)), c._forceRed(this);
      }, Se.prototype.invm = function(i) {
        var a = this.imod(i._invmp(this.m).mul(this.r2));
        return a._forceRed(this);
      };
    })(typeof Xu > "u" || Xu, Gm);
  });
  Xm = T2(() => {
  });
  As = T2(($T, el) => {
    var Ju;
    el.exports = function(e) {
      return Ju || (Ju = new Zi(null)), Ju.generate(e);
    };
    function Zi(t) {
      this.rand = t;
    }
    el.exports.Rand = Zi;
    Zi.prototype.generate = function(e) {
      return this._rand(e);
    };
    Zi.prototype._rand = function(e) {
      if (this.rand.getBytes)
        return this.rand.getBytes(e);
      for (var r = new Uint8Array(e), o = 0;o < r.length; o++)
        r[o] = this.rand.getByte();
      return r;
    };
    if (typeof self == "object")
      self.crypto && self.crypto.getRandomValues ? Zi.prototype._rand = function(e) {
        var r = new Uint8Array(e);
        return self.crypto.getRandomValues(r), r;
      } : self.msCrypto && self.msCrypto.getRandomValues ? Zi.prototype._rand = function(e) {
        var r = new Uint8Array(e);
        return self.msCrypto.getRandomValues(r), r;
      } : typeof window == "object" && (Zi.prototype._rand = function() {
        throw new Error("Not implemented yet");
      });
    else
      try {
        if (Qu = Xm(), typeof Qu.randomBytes != "function")
          throw new Error("Not supported");
        Zi.prototype._rand = function(e) {
          return Qu.randomBytes(e);
        };
      } catch {
      }
    var Qu;
  });
  tl = T2((GT, Jm) => {
    var In = Ym(), Q9 = As();
    function Tn(t) {
      this.rand = t || new Q9.Rand;
    }
    Jm.exports = Tn;
    Tn.create = function(e) {
      return new Tn(e);
    };
    Tn.prototype._randbelow = function(e) {
      var r = e.bitLength(), o = Math.ceil(r / 8);
      do
        var f = new In(this.rand.generate(o));
      while (f.cmp(e) >= 0);
      return f;
    };
    Tn.prototype._randrange = function(e, r) {
      var o = r.sub(e);
      return e.add(this._randbelow(o));
    };
    Tn.prototype.test = function(e, r, o) {
      var f = e.bitLength(), p = In.mont(e), m2 = new In(1).toRed(p);
      r || (r = Math.max(1, f / 48 | 0));
      for (var y2 = e.subn(1), M = 0;!y2.testn(M); M++)
        ;
      for (var x = e.shrn(M), S = y2.toRed(p), E2 = true;r > 0; r--) {
        var B = this._randrange(new In(2), y2);
        o && o(B);
        var q2 = B.toRed(p).redPow(x);
        if (!(q2.cmp(m2) === 0 || q2.cmp(S) === 0)) {
          for (var L2 = 1;L2 < M; L2++) {
            if (q2 = q2.redSqr(), q2.cmp(m2) === 0)
              return false;
            if (q2.cmp(S) === 0)
              break;
          }
          if (L2 === M)
            return false;
        }
      }
      return E2;
    };
    Tn.prototype.getDivisor = function(e, r) {
      var o = e.bitLength(), f = In.mont(e), p = new In(1).toRed(f);
      r || (r = Math.max(1, o / 48 | 0));
      for (var m2 = e.subn(1), y2 = 0;!m2.testn(y2); y2++)
        ;
      for (var M = e.shrn(y2), x = m2.toRed(f);r > 0; r--) {
        var S = this._randrange(new In(2), m2), E2 = e.gcd(S);
        if (E2.cmpn(1) !== 0)
          return E2;
        var B = S.toRed(f).redPow(M);
        if (!(B.cmp(p) === 0 || B.cmp(x) === 0)) {
          for (var q2 = 1;q2 < y2; q2++) {
            if (B = B.redSqr(), B.cmp(p) === 0)
              return B.fromRed().subn(1).gcd(e);
            if (B.cmp(x) === 0)
              break;
          }
          if (q2 === y2)
            return B = B.redSqr(), B.fromRed().subn(1).gcd(e);
        }
      }
      return false;
    };
  });
  ol = T2((ek, tg) => {
    var eS = on();
    tg.exports = al;
    al.simpleSieve = nl;
    al.fermatTest = fl;
    var Ht = Yu(), tS = new Ht(24), rS = tl(), Qm = new rS, iS = new Ht(1), il = new Ht(2), nS = new Ht(5), YT = new Ht(16), XT = new Ht(8), fS = new Ht(10), aS = new Ht(3), JT = new Ht(7), oS = new Ht(11), eg = new Ht(4), QT = new Ht(12), rl = null;
    function sS() {
      if (rl !== null)
        return rl;
      var t = 1048576, e = [];
      e[0] = 2;
      for (var r = 1, o = 3;o < t; o += 2) {
        for (var f = Math.ceil(Math.sqrt(o)), p = 0;p < r && e[p] <= f && o % e[p] !== 0; p++)
          ;
        r !== p && e[p] <= f || (e[r++] = o);
      }
      return rl = e, e;
    }
    function nl(t) {
      for (var e = sS(), r = 0;r < e.length; r++)
        if (t.modn(e[r]) === 0)
          return t.cmpn(e[r]) === 0;
      return true;
    }
    function fl(t) {
      var e = Ht.mont(t);
      return il.toRed(e).redPow(t.subn(1)).fromRed().cmpn(1) === 0;
    }
    function al(t, e) {
      if (t < 16)
        return e === 2 || e === 5 ? new Ht([140, 123]) : new Ht([140, 39]);
      e = new Ht(e);
      for (var r, o;; ) {
        for (r = new Ht(eS(Math.ceil(t / 8)));r.bitLength() > t; )
          r.ishrn(1);
        if (r.isEven() && r.iadd(iS), r.testn(1) || r.iadd(il), e.cmp(il)) {
          if (!e.cmp(nS))
            for (;r.mod(fS).cmp(aS); )
              r.iadd(eg);
        } else
          for (;r.mod(tS).cmp(oS); )
            r.iadd(eg);
        if (o = r.shrn(1), nl(o) && nl(r) && fl(o) && fl(r) && Qm.test(o) && Qm.test(r))
          return r;
      }
    }
  });
  rg = T2((tk, hS) => {
    hS.exports = { modp1: { gen: "02", prime: "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a63a3620ffffffffffffffff" }, modp2: { gen: "02", prime: "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece65381ffffffffffffffff" }, modp5: { gen: "02", prime: "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca237327ffffffffffffffff" }, modp14: { gen: "02", prime: "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aacaa68ffffffffffffffff" }, modp15: { gen: "02", prime: "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a93ad2caffffffffffffffff" }, modp16: { gen: "02", prime: "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c934063199ffffffffffffffff" }, modp17: { gen: "02", prime: "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c93402849236c3fab4d27c7026c1d4dcb2602646dec9751e763dba37bdf8ff9406ad9e530ee5db382f413001aeb06a53ed9027d831179727b0865a8918da3edbebcf9b14ed44ce6cbaced4bb1bdb7f1447e6cc254b332051512bd7af426fb8f401378cd2bf5983ca01c64b92ecf032ea15d1721d03f482d7ce6e74fef6d55e702f46980c82b5a84031900b1c9e59e7c97fbec7e8f323a97a7e36cc88be0f1d45b7ff585ac54bd407b22b4154aacc8f6d7ebf48e1d814cc5ed20f8037e0a79715eef29be32806a1d58bb7c5da76f550aa3d8a1fbff0eb19ccb1a313d55cda56c9ec2ef29632387fe8d76e3c0468043e8f663f4860ee12bf2d5b0b7474d6e694f91e6dcc4024ffffffffffffffff" }, modp18: { gen: "02", prime: "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c93402849236c3fab4d27c7026c1d4dcb2602646dec9751e763dba37bdf8ff9406ad9e530ee5db382f413001aeb06a53ed9027d831179727b0865a8918da3edbebcf9b14ed44ce6cbaced4bb1bdb7f1447e6cc254b332051512bd7af426fb8f401378cd2bf5983ca01c64b92ecf032ea15d1721d03f482d7ce6e74fef6d55e702f46980c82b5a84031900b1c9e59e7c97fbec7e8f323a97a7e36cc88be0f1d45b7ff585ac54bd407b22b4154aacc8f6d7ebf48e1d814cc5ed20f8037e0a79715eef29be32806a1d58bb7c5da76f550aa3d8a1fbff0eb19ccb1a313d55cda56c9ec2ef29632387fe8d76e3c0468043e8f663f4860ee12bf2d5b0b7474d6e694f91e6dbe115974a3926f12fee5e438777cb6a932df8cd8bec4d073b931ba3bc832b68d9dd300741fa7bf8afc47ed2576f6936ba424663aab639c5ae4f5683423b4742bf1c978238f16cbe39d652de3fdb8befc848ad922222e04a4037c0713eb57a81a23f0c73473fc646cea306b4bcbc8862f8385ddfa9d4b7fa2c087e879683303ed5bdd3a062b3cf5b3a278a66d2a13f83f44f82ddf310ee074ab6a364597e899a0255dc164f31cc50846851df9ab48195ded7ea1b1d510bd7ee74d73faf36bc31ecfa268359046f4eb879f924009438b481c6cd7889a002ed5ee382bc9190da6fc026e479558e4475677e9aa9e3050e2765694dfc81f56e880b96e7160c980dd98edd3dfffffffffffffffff" } };
  });
  ag = T2((rk, fg) => {
    var yr = Yu(), uS = tl(), ig = new uS, lS = new yr(24), dS = new yr(11), cS = new yr(10), pS = new yr(3), vS = new yr(7), ng = ol(), bS = on();
    fg.exports = Si;
    function mS(t, e) {
      return e = e || "utf8", Buffer.isBuffer(t) || (t = new Buffer(t, e)), this._pub = new yr(t), this;
    }
    function gS(t, e) {
      return e = e || "utf8", Buffer.isBuffer(t) || (t = new Buffer(t, e)), this._priv = new yr(t), this;
    }
    var Rs = {};
    function yS(t, e) {
      var r = e.toString("hex"), o = [r, t.toString(16)].join("_");
      if (o in Rs)
        return Rs[o];
      var f = 0;
      if (t.isEven() || !ng.simpleSieve || !ng.fermatTest(t) || !ig.test(t))
        return f += 1, r === "02" || r === "05" ? f += 8 : f += 4, Rs[o] = f, f;
      ig.test(t.shrn(1)) || (f += 2);
      var p;
      switch (r) {
        case "02":
          t.mod(lS).cmp(dS) && (f += 8);
          break;
        case "05":
          p = t.mod(cS), p.cmp(pS) && p.cmp(vS) && (f += 8);
          break;
        default:
          f += 4;
      }
      return Rs[o] = f, f;
    }
    function Si(t, e, r) {
      this.setGenerator(e), this.__prime = new yr(t), this._prime = yr.mont(this.__prime), this._primeLen = t.length, this._pub = undefined, this._priv = undefined, this._primeCode = undefined, r ? (this.setPublicKey = mS, this.setPrivateKey = gS) : this._primeCode = 8;
    }
    Object.defineProperty(Si.prototype, "verifyError", { enumerable: true, get: function() {
      return typeof this._primeCode != "number" && (this._primeCode = yS(this.__prime, this.__gen)), this._primeCode;
    } });
    Si.prototype.generateKeys = function() {
      return this._priv || (this._priv = new yr(bS(this._primeLen))), this._pub = this._gen.toRed(this._prime).redPow(this._priv).fromRed(), this.getPublicKey();
    };
    Si.prototype.computeSecret = function(t) {
      t = new yr(t), t = t.toRed(this._prime);
      var e = t.redPow(this._priv).fromRed(), r = new Buffer(e.toArray()), o = this.getPrime();
      if (r.length < o.length) {
        var f = new Buffer(o.length - r.length);
        f.fill(0), r = Buffer.concat([f, r]);
      }
      return r;
    };
    Si.prototype.getPublicKey = function(e) {
      return Bs(this._pub, e);
    };
    Si.prototype.getPrivateKey = function(e) {
      return Bs(this._priv, e);
    };
    Si.prototype.getPrime = function(t) {
      return Bs(this.__prime, t);
    };
    Si.prototype.getGenerator = function(t) {
      return Bs(this._gen, t);
    };
    Si.prototype.setGenerator = function(t, e) {
      return e = e || "utf8", Buffer.isBuffer(t) || (t = new Buffer(t, e)), this.__gen = t, this._gen = new yr(t), this;
    };
    function Bs(t, e) {
      var r = new Buffer(t.toArray());
      return e ? r.toString(e) : r;
    }
  });
  hg = T2((_f) => {
    var wS = ol(), og = rg(), sl = ag();
    function MS(t) {
      var e = new Buffer(og[t].prime, "hex"), r = new Buffer(og[t].gen, "hex");
      return new sl(e, r);
    }
    var _S = { binary: true, hex: true, base64: true };
    function sg(t, e, r, o) {
      return Buffer.isBuffer(e) || _S[e] === undefined ? sg(t, "binary", e, r) : (e = e || "binary", o = o || "binary", r = r || new Buffer([2]), Buffer.isBuffer(r) || (r = new Buffer(r, o)), typeof t == "number" ? new sl(wS(t, r), r, true) : (Buffer.isBuffer(t) || (t = new Buffer(t, e)), new sl(t, r, true)));
    }
    _f.DiffieHellmanGroup = _f.createDiffieHellmanGroup = _f.getDiffieHellman = MS;
    _f.createDiffieHellman = _f.DiffieHellman = sg;
  });
  hl = T2((nk, ug) => {
    ug.exports = ki().EventEmitter;
  });
  pg = T2((fk, cg) => {
    function lg(t, e) {
      var r = Object.keys(t);
      if (Object.getOwnPropertySymbols) {
        var o = Object.getOwnPropertySymbols(t);
        e && (o = o.filter(function(f) {
          return Object.getOwnPropertyDescriptor(t, f).enumerable;
        })), r.push.apply(r, o);
      }
      return r;
    }
    function xS(t) {
      for (var e = 1;e < arguments.length; e++) {
        var r = arguments[e] != null ? arguments[e] : {};
        e % 2 ? lg(Object(r), true).forEach(function(o) {
          SS(t, o, r[o]);
        }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(t, Object.getOwnPropertyDescriptors(r)) : lg(Object(r)).forEach(function(o) {
          Object.defineProperty(t, o, Object.getOwnPropertyDescriptor(r, o));
        });
      }
      return t;
    }
    function SS(t, e, r) {
      return e in t ? Object.defineProperty(t, e, { value: r, enumerable: true, configurable: true, writable: true }) : t[e] = r, t;
    }
    function ES(t, e) {
      if (!(t instanceof e))
        throw new TypeError("Cannot call a class as a function");
    }
    function dg(t, e) {
      for (var r = 0;r < e.length; r++) {
        var o = e[r];
        o.enumerable = o.enumerable || false, o.configurable = true, "value" in o && (o.writable = true), Object.defineProperty(t, o.key, o);
      }
    }
    function AS(t, e, r) {
      return e && dg(t.prototype, e), r && dg(t, r), t;
    }
    var RS = Ut(), qs = RS.Buffer, BS = $f(), ul = BS.inspect, qS = ul && ul.custom || "inspect";
    function IS(t, e, r) {
      qs.prototype.copy.call(t, e, r);
    }
    cg.exports = function() {
      function t() {
        ES(this, t), this.head = null, this.tail = null, this.length = 0;
      }
      return AS(t, [{ key: "push", value: function(r) {
        var o = { data: r, next: null };
        this.length > 0 ? this.tail.next = o : this.head = o, this.tail = o, ++this.length;
      } }, { key: "unshift", value: function(r) {
        var o = { data: r, next: this.head };
        this.length === 0 && (this.tail = o), this.head = o, ++this.length;
      } }, { key: "shift", value: function() {
        if (this.length !== 0) {
          var r = this.head.data;
          return this.length === 1 ? this.head = this.tail = null : this.head = this.head.next, --this.length, r;
        }
      } }, { key: "clear", value: function() {
        this.head = this.tail = null, this.length = 0;
      } }, { key: "join", value: function(r) {
        if (this.length === 0)
          return "";
        for (var o = this.head, f = "" + o.data;o = o.next; )
          f += r + o.data;
        return f;
      } }, { key: "concat", value: function(r) {
        if (this.length === 0)
          return qs.alloc(0);
        for (var o = qs.allocUnsafe(r >>> 0), f = this.head, p = 0;f; )
          IS(f.data, o, p), p += f.data.length, f = f.next;
        return o;
      } }, { key: "consume", value: function(r, o) {
        var f;
        return r < this.head.data.length ? (f = this.head.data.slice(0, r), this.head.data = this.head.data.slice(r)) : r === this.head.data.length ? f = this.shift() : f = o ? this._getString(r) : this._getBuffer(r), f;
      } }, { key: "first", value: function() {
        return this.head.data;
      } }, { key: "_getString", value: function(r) {
        var o = this.head, f = 1, p = o.data;
        for (r -= p.length;o = o.next; ) {
          var m2 = o.data, y2 = r > m2.length ? m2.length : r;
          if (y2 === m2.length ? p += m2 : p += m2.slice(0, r), r -= y2, r === 0) {
            y2 === m2.length ? (++f, o.next ? this.head = o.next : this.head = this.tail = null) : (this.head = o, o.data = m2.slice(y2));
            break;
          }
          ++f;
        }
        return this.length -= f, p;
      } }, { key: "_getBuffer", value: function(r) {
        var o = qs.allocUnsafe(r), f = this.head, p = 1;
        for (f.data.copy(o), r -= f.data.length;f = f.next; ) {
          var m2 = f.data, y2 = r > m2.length ? m2.length : r;
          if (m2.copy(o, o.length - r, 0, y2), r -= y2, r === 0) {
            y2 === m2.length ? (++p, f.next ? this.head = f.next : this.head = this.tail = null) : (this.head = f, f.data = m2.slice(y2));
            break;
          }
          ++p;
        }
        return this.length -= p, o;
      } }, { key: qS, value: function(r, o) {
        return ul(this, xS({}, o, { depth: 0, customInspect: false }));
      } }]), t;
    }();
  });
  dl = T2((ak, bg) => {
    function TS(t, e) {
      var r = this, o = this._readableState && this._readableState.destroyed, f = this._writableState && this._writableState.destroyed;
      return o || f ? (e ? e(t) : t && (this._writableState ? this._writableState.errorEmitted || (this._writableState.errorEmitted = true, process.nextTick(ll, this, t)) : process.nextTick(ll, this, t)), this) : (this._readableState && (this._readableState.destroyed = true), this._writableState && (this._writableState.destroyed = true), this._destroy(t || null, function(p) {
        !e && p ? r._writableState ? r._writableState.errorEmitted ? process.nextTick(Is, r) : (r._writableState.errorEmitted = true, process.nextTick(vg, r, p)) : process.nextTick(vg, r, p) : e ? (process.nextTick(Is, r), e(p)) : process.nextTick(Is, r);
      }), this);
    }
    function vg(t, e) {
      ll(t, e), Is(t);
    }
    function Is(t) {
      t._writableState && !t._writableState.emitClose || t._readableState && !t._readableState.emitClose || t.emit("close");
    }
    function kS() {
      this._readableState && (this._readableState.destroyed = false, this._readableState.reading = false, this._readableState.ended = false, this._readableState.endEmitted = false), this._writableState && (this._writableState.destroyed = false, this._writableState.ended = false, this._writableState.ending = false, this._writableState.finalCalled = false, this._writableState.prefinished = false, this._writableState.finished = false, this._writableState.errorEmitted = false);
    }
    function ll(t, e) {
      t.emit("error", e);
    }
    function LS(t, e) {
      var { _readableState: r, _writableState: o } = t;
      r && r.autoDestroy || o && o.autoDestroy ? t.destroy(e) : t.emit("error", e);
    }
    bg.exports = { destroy: TS, undestroy: kS, errorOrDestroy: LS };
  });
  kn = T2((ok, yg) => {
    function NS(t, e) {
      t.prototype = Object.create(e.prototype), t.prototype.constructor = t, t.__proto__ = e;
    }
    var gg = {};
    function wr(t, e, r) {
      r || (r = Error);
      function o(p, m2, y2) {
        return typeof e == "string" ? e : e(p, m2, y2);
      }
      var f = function(p) {
        NS(m2, p);
        function m2(y2, M, x) {
          return p.call(this, o(y2, M, x)) || this;
        }
        return m2;
      }(r);
      f.prototype.name = r.name, f.prototype.code = t, gg[t] = f;
    }
    function mg(t, e) {
      if (Array.isArray(t)) {
        var r = t.length;
        return t = t.map(function(o) {
          return String(o);
        }), r > 2 ? "one of ".concat(e, " ").concat(t.slice(0, r - 1).join(", "), ", or ") + t[r - 1] : r === 2 ? "one of ".concat(e, " ").concat(t[0], " or ").concat(t[1]) : "of ".concat(e, " ").concat(t[0]);
      } else
        return "of ".concat(e, " ").concat(String(t));
    }
    function DS(t, e, r) {
      return t.substr(!r || r < 0 ? 0 : +r, e.length) === e;
    }
    function PS(t, e, r) {
      return (r === undefined || r > t.length) && (r = t.length), t.substring(r - e.length, r) === e;
    }
    function CS(t, e, r) {
      return typeof r != "number" && (r = 0), r + e.length > t.length ? false : t.indexOf(e, r) !== -1;
    }
    wr("ERR_INVALID_OPT_VALUE", function(t, e) {
      return 'The value "' + e + '" is invalid for option "' + t + '"';
    }, TypeError);
    wr("ERR_INVALID_ARG_TYPE", function(t, e, r) {
      var o;
      typeof e == "string" && DS(e, "not ") ? (o = "must not be", e = e.replace(/^not /, "")) : o = "must be";
      var f;
      if (PS(t, " argument"))
        f = "The ".concat(t, " ").concat(o, " ").concat(mg(e, "type"));
      else {
        var p = CS(t, ".") ? "property" : "argument";
        f = 'The "'.concat(t, '" ').concat(p, " ").concat(o, " ").concat(mg(e, "type"));
      }
      return f += ". Received type ".concat(typeof r), f;
    }, TypeError);
    wr("ERR_STREAM_PUSH_AFTER_EOF", "stream.push() after EOF");
    wr("ERR_METHOD_NOT_IMPLEMENTED", function(t) {
      return "The " + t + " method is not implemented";
    });
    wr("ERR_STREAM_PREMATURE_CLOSE", "Premature close");
    wr("ERR_STREAM_DESTROYED", function(t) {
      return "Cannot call " + t + " after a stream was destroyed";
    });
    wr("ERR_MULTIPLE_CALLBACK", "Callback called multiple times");
    wr("ERR_STREAM_CANNOT_PIPE", "Cannot pipe, not readable");
    wr("ERR_STREAM_WRITE_AFTER_END", "write after end");
    wr("ERR_STREAM_NULL_VALUES", "May not write null values to stream", TypeError);
    wr("ERR_UNKNOWN_ENCODING", function(t) {
      return "Unknown encoding: " + t;
    }, TypeError);
    wr("ERR_STREAM_UNSHIFT_AFTER_END_EVENT", "stream.unshift() after end event");
    yg.exports.codes = gg;
  });
  cl = T2((sk, wg) => {
    var OS = kn().codes.ERR_INVALID_OPT_VALUE;
    function FS(t, e, r) {
      return t.highWaterMark != null ? t.highWaterMark : e ? t[r] : null;
    }
    function US(t, e, r, o) {
      var f = FS(e, o, r);
      if (f != null) {
        if (!(isFinite(f) && Math.floor(f) === f) || f < 0) {
          var p = o ? r : "highWaterMark";
          throw new OS(p, f);
        }
        return Math.floor(f);
      }
      return t.objectMode ? 16 : 16 * 1024;
    }
    wg.exports = { getHighWaterMark: US };
  });
  bl = T2((hk, Ag) => {
    Ag.exports = ut;
    function _g(t) {
      var e = this;
      this.next = null, this.entry = null, this.finish = function() {
        cE(e, t);
      };
    }
    var xf;
    ut.WritableState = ka;
    var zS = { deprecate: G0() }, xg = hl(), ks = Ut().Buffer, HS = global.Uint8Array || function() {
    };
    function WS(t) {
      return ks.from(t);
    }
    function KS(t) {
      return ks.isBuffer(t) || t instanceof HS;
    }
    var vl = dl(), jS = cl(), ZS = jS.getHighWaterMark, Vi = kn().codes, VS = Vi.ERR_INVALID_ARG_TYPE, $S = Vi.ERR_METHOD_NOT_IMPLEMENTED, GS = Vi.ERR_MULTIPLE_CALLBACK, YS = Vi.ERR_STREAM_CANNOT_PIPE, XS = Vi.ERR_STREAM_DESTROYED, JS = Vi.ERR_STREAM_NULL_VALUES, QS = Vi.ERR_STREAM_WRITE_AFTER_END, eE = Vi.ERR_UNKNOWN_ENCODING, Sf = vl.errorOrDestroy;
    Ie()(ut, xg);
    function tE() {
    }
    function ka(t, e, r) {
      xf = xf || Ln(), t = t || {}, typeof r != "boolean" && (r = e instanceof xf), this.objectMode = !!t.objectMode, r && (this.objectMode = this.objectMode || !!t.writableObjectMode), this.highWaterMark = ZS(this, t, "writableHighWaterMark", r), this.finalCalled = false, this.needDrain = false, this.ending = false, this.ended = false, this.finished = false, this.destroyed = false;
      var o = t.decodeStrings === false;
      this.decodeStrings = !o, this.defaultEncoding = t.defaultEncoding || "utf8", this.length = 0, this.writing = false, this.corked = 0, this.sync = true, this.bufferProcessing = false, this.onwrite = function(f) {
        sE(e, f);
      }, this.writecb = null, this.writelen = 0, this.bufferedRequest = null, this.lastBufferedRequest = null, this.pendingcb = 0, this.prefinished = false, this.errorEmitted = false, this.emitClose = t.emitClose !== false, this.autoDestroy = !!t.autoDestroy, this.bufferedRequestCount = 0, this.corkedRequestsFree = new _g(this);
    }
    ka.prototype.getBuffer = function() {
      for (var e = this.bufferedRequest, r = [];e; )
        r.push(e), e = e.next;
      return r;
    };
    (function() {
      try {
        Object.defineProperty(ka.prototype, "buffer", { get: zS.deprecate(function() {
          return this.getBuffer();
        }, "_writableState.buffer is deprecated. Use _writableState.getBuffer instead.", "DEP0003") });
      } catch {
      }
    })();
    var Ts;
    typeof Symbol == "function" && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] == "function" ? (Ts = Function.prototype[Symbol.hasInstance], Object.defineProperty(ut, Symbol.hasInstance, { value: function(e) {
      return Ts.call(this, e) ? true : this !== ut ? false : e && e._writableState instanceof ka;
    } })) : Ts = function(e) {
      return e instanceof this;
    };
    function ut(t) {
      xf = xf || Ln();
      var e = this instanceof xf;
      if (!e && !Ts.call(ut, this))
        return new ut(t);
      this._writableState = new ka(t, this, e), this.writable = true, t && (typeof t.write == "function" && (this._write = t.write), typeof t.writev == "function" && (this._writev = t.writev), typeof t.destroy == "function" && (this._destroy = t.destroy), typeof t.final == "function" && (this._final = t.final)), xg.call(this);
    }
    ut.prototype.pipe = function() {
      Sf(this, new YS);
    };
    function rE(t, e) {
      var r = new QS;
      Sf(t, r), process.nextTick(e, r);
    }
    function iE(t, e, r, o) {
      var f;
      return r === null ? f = new JS : typeof r != "string" && !e.objectMode && (f = new VS("chunk", ["string", "Buffer"], r)), f ? (Sf(t, f), process.nextTick(o, f), false) : true;
    }
    ut.prototype.write = function(t, e, r) {
      var o = this._writableState, f = false, p = !o.objectMode && KS(t);
      return p && !ks.isBuffer(t) && (t = WS(t)), typeof e == "function" && (r = e, e = null), p ? e = "buffer" : e || (e = o.defaultEncoding), typeof r != "function" && (r = tE), o.ending ? rE(this, r) : (p || iE(this, o, t, r)) && (o.pendingcb++, f = fE(this, o, p, t, e, r)), f;
    };
    ut.prototype.cork = function() {
      this._writableState.corked++;
    };
    ut.prototype.uncork = function() {
      var t = this._writableState;
      t.corked && (t.corked--, !t.writing && !t.corked && !t.bufferProcessing && t.bufferedRequest && Sg(this, t));
    };
    ut.prototype.setDefaultEncoding = function(e) {
      if (typeof e == "string" && (e = e.toLowerCase()), !(["hex", "utf8", "utf-8", "ascii", "binary", "base64", "ucs2", "ucs-2", "utf16le", "utf-16le", "raw"].indexOf((e + "").toLowerCase()) > -1))
        throw new eE(e);
      return this._writableState.defaultEncoding = e, this;
    };
    Object.defineProperty(ut.prototype, "writableBuffer", { enumerable: false, get: function() {
      return this._writableState && this._writableState.getBuffer();
    } });
    function nE(t, e, r) {
      return !t.objectMode && t.decodeStrings !== false && typeof e == "string" && (e = ks.from(e, r)), e;
    }
    Object.defineProperty(ut.prototype, "writableHighWaterMark", { enumerable: false, get: function() {
      return this._writableState.highWaterMark;
    } });
    function fE(t, e, r, o, f, p) {
      if (!r) {
        var m2 = nE(e, o, f);
        o !== m2 && (r = true, f = "buffer", o = m2);
      }
      var y2 = e.objectMode ? 1 : o.length;
      e.length += y2;
      var M = e.length < e.highWaterMark;
      if (M || (e.needDrain = true), e.writing || e.corked) {
        var x = e.lastBufferedRequest;
        e.lastBufferedRequest = { chunk: o, encoding: f, isBuf: r, callback: p, next: null }, x ? x.next = e.lastBufferedRequest : e.bufferedRequest = e.lastBufferedRequest, e.bufferedRequestCount += 1;
      } else
        pl(t, e, false, y2, o, f, p);
      return M;
    }
    function pl(t, e, r, o, f, p, m2) {
      e.writelen = o, e.writecb = m2, e.writing = true, e.sync = true, e.destroyed ? e.onwrite(new XS("write")) : r ? t._writev(f, e.onwrite) : t._write(f, p, e.onwrite), e.sync = false;
    }
    function aE(t, e, r, o, f) {
      --e.pendingcb, r ? (process.nextTick(f, o), process.nextTick(Ta, t, e), t._writableState.errorEmitted = true, Sf(t, o)) : (f(o), t._writableState.errorEmitted = true, Sf(t, o), Ta(t, e));
    }
    function oE(t) {
      t.writing = false, t.writecb = null, t.length -= t.writelen, t.writelen = 0;
    }
    function sE(t, e) {
      var r = t._writableState, o = r.sync, f = r.writecb;
      if (typeof f != "function")
        throw new GS;
      if (oE(r), e)
        aE(t, r, o, e, f);
      else {
        var p = Eg(r) || t.destroyed;
        !p && !r.corked && !r.bufferProcessing && r.bufferedRequest && Sg(t, r), o ? process.nextTick(Mg, t, r, p, f) : Mg(t, r, p, f);
      }
    }
    function Mg(t, e, r, o) {
      r || hE(t, e), e.pendingcb--, o(), Ta(t, e);
    }
    function hE(t, e) {
      e.length === 0 && e.needDrain && (e.needDrain = false, t.emit("drain"));
    }
    function Sg(t, e) {
      e.bufferProcessing = true;
      var r = e.bufferedRequest;
      if (t._writev && r && r.next) {
        var o = e.bufferedRequestCount, f = new Array(o), p = e.corkedRequestsFree;
        p.entry = r;
        for (var m2 = 0, y2 = true;r; )
          f[m2] = r, r.isBuf || (y2 = false), r = r.next, m2 += 1;
        f.allBuffers = y2, pl(t, e, true, e.length, f, "", p.finish), e.pendingcb++, e.lastBufferedRequest = null, p.next ? (e.corkedRequestsFree = p.next, p.next = null) : e.corkedRequestsFree = new _g(e), e.bufferedRequestCount = 0;
      } else {
        for (;r; ) {
          var { chunk: M, encoding: x, callback: S } = r, E2 = e.objectMode ? 1 : M.length;
          if (pl(t, e, false, E2, M, x, S), r = r.next, e.bufferedRequestCount--, e.writing)
            break;
        }
        r === null && (e.lastBufferedRequest = null);
      }
      e.bufferedRequest = r, e.bufferProcessing = false;
    }
    ut.prototype._write = function(t, e, r) {
      r(new $S("_write()"));
    };
    ut.prototype._writev = null;
    ut.prototype.end = function(t, e, r) {
      var o = this._writableState;
      return typeof t == "function" ? (r = t, t = null, e = null) : typeof e == "function" && (r = e, e = null), t != null && this.write(t, e), o.corked && (o.corked = 1, this.uncork()), o.ending || dE(this, o, r), this;
    };
    Object.defineProperty(ut.prototype, "writableLength", { enumerable: false, get: function() {
      return this._writableState.length;
    } });
    function Eg(t) {
      return t.ending && t.length === 0 && t.bufferedRequest === null && !t.finished && !t.writing;
    }
    function uE(t, e) {
      t._final(function(r) {
        e.pendingcb--, r && Sf(t, r), e.prefinished = true, t.emit("prefinish"), Ta(t, e);
      });
    }
    function lE(t, e) {
      !e.prefinished && !e.finalCalled && (typeof t._final == "function" && !e.destroyed ? (e.pendingcb++, e.finalCalled = true, process.nextTick(uE, t, e)) : (e.prefinished = true, t.emit("prefinish")));
    }
    function Ta(t, e) {
      var r = Eg(e);
      if (r && (lE(t, e), e.pendingcb === 0 && (e.finished = true, t.emit("finish"), e.autoDestroy))) {
        var o = t._readableState;
        (!o || o.autoDestroy && o.endEmitted) && t.destroy();
      }
      return r;
    }
    function dE(t, e, r) {
      e.ending = true, Ta(t, e), r && (e.finished ? process.nextTick(r) : t.once("finish", r)), e.ended = true, t.writable = false;
    }
    function cE(t, e, r) {
      var o = t.entry;
      for (t.entry = null;o; ) {
        var f = o.callback;
        e.pendingcb--, f(r), o = o.next;
      }
      e.corkedRequestsFree.next = t;
    }
    Object.defineProperty(ut.prototype, "destroyed", { enumerable: false, get: function() {
      return this._writableState === undefined ? false : this._writableState.destroyed;
    }, set: function(e) {
      !this._writableState || (this._writableState.destroyed = e);
    } });
    ut.prototype.destroy = vl.destroy;
    ut.prototype._undestroy = vl.undestroy;
    ut.prototype._destroy = function(t, e) {
      e(t);
    };
  });
  Ln = T2((uk, Bg) => {
    var pE = Object.keys || function(t) {
      var e = [];
      for (var r in t)
        e.push(r);
      return e;
    };
    Bg.exports = ti;
    var Rg = yl(), gl = bl();
    Ie()(ti, Rg);
    for (ml = pE(gl.prototype), Ls = 0;Ls < ml.length; Ls++)
      Ns = ml[Ls], ti.prototype[Ns] || (ti.prototype[Ns] = gl.prototype[Ns]);
    var ml, Ns, Ls;
    function ti(t) {
      if (!(this instanceof ti))
        return new ti(t);
      Rg.call(this, t), gl.call(this, t), this.allowHalfOpen = true, t && (t.readable === false && (this.readable = false), t.writable === false && (this.writable = false), t.allowHalfOpen === false && (this.allowHalfOpen = false, this.once("end", vE)));
    }
    Object.defineProperty(ti.prototype, "writableHighWaterMark", { enumerable: false, get: function() {
      return this._writableState.highWaterMark;
    } });
    Object.defineProperty(ti.prototype, "writableBuffer", { enumerable: false, get: function() {
      return this._writableState && this._writableState.getBuffer();
    } });
    Object.defineProperty(ti.prototype, "writableLength", { enumerable: false, get: function() {
      return this._writableState.length;
    } });
    function vE() {
      this._writableState.ended || process.nextTick(bE, this);
    }
    function bE(t) {
      t.end();
    }
    Object.defineProperty(ti.prototype, "destroyed", { enumerable: false, get: function() {
      return this._readableState === undefined || this._writableState === undefined ? false : this._readableState.destroyed && this._writableState.destroyed;
    }, set: function(e) {
      this._readableState === undefined || this._writableState === undefined || (this._readableState.destroyed = e, this._writableState.destroyed = e);
    } });
  });
  Ds = T2((lk, Tg) => {
    var qg = kn().codes.ERR_STREAM_PREMATURE_CLOSE;
    function mE(t) {
      var e = false;
      return function() {
        if (!e) {
          e = true;
          for (var r = arguments.length, o = new Array(r), f = 0;f < r; f++)
            o[f] = arguments[f];
          t.apply(this, o);
        }
      };
    }
    function gE() {
    }
    function yE(t) {
      return t.setHeader && typeof t.abort == "function";
    }
    function Ig(t, e, r) {
      if (typeof e == "function")
        return Ig(t, null, e);
      e || (e = {}), r = mE(r || gE);
      var o = e.readable || e.readable !== false && t.readable, f = e.writable || e.writable !== false && t.writable, p = function() {
        t.writable || y2();
      }, m2 = t._writableState && t._writableState.finished, y2 = function() {
        f = false, m2 = true, o || r.call(t);
      }, M = t._readableState && t._readableState.endEmitted, x = function() {
        o = false, M = true, f || r.call(t);
      }, S = function(L2) {
        r.call(t, L2);
      }, E2 = function() {
        var L2;
        if (o && !M)
          return (!t._readableState || !t._readableState.ended) && (L2 = new qg), r.call(t, L2);
        if (f && !m2)
          return (!t._writableState || !t._writableState.ended) && (L2 = new qg), r.call(t, L2);
      }, B = function() {
        t.req.on("finish", y2);
      };
      return yE(t) ? (t.on("complete", y2), t.on("abort", E2), t.req ? B() : t.on("request", B)) : f && !t._writableState && (t.on("end", p), t.on("close", p)), t.on("end", x), t.on("finish", y2), e.error !== false && t.on("error", S), t.on("close", E2), function() {
        t.removeListener("complete", y2), t.removeListener("abort", E2), t.removeListener("request", B), t.req && t.req.removeListener("finish", y2), t.removeListener("end", p), t.removeListener("close", p), t.removeListener("finish", y2), t.removeListener("end", x), t.removeListener("error", S), t.removeListener("close", E2);
      };
    }
    Tg.exports = Ig;
  });
  Lg = T2((dk, kg) => {
    var Ps;
    function $i(t, e, r) {
      return e in t ? Object.defineProperty(t, e, { value: r, enumerable: true, configurable: true, writable: true }) : t[e] = r, t;
    }
    var wE = Ds(), Gi = Symbol("lastResolve"), Nn = Symbol("lastReject"), La = Symbol("error"), Cs = Symbol("ended"), Dn = Symbol("lastPromise"), wl = Symbol("handlePromise"), Pn = Symbol("stream");
    function Yi(t, e) {
      return { value: t, done: e };
    }
    function ME(t) {
      var e = t[Gi];
      if (e !== null) {
        var r = t[Pn].read();
        r !== null && (t[Dn] = null, t[Gi] = null, t[Nn] = null, e(Yi(r, false)));
      }
    }
    function _E(t) {
      process.nextTick(ME, t);
    }
    function xE(t, e) {
      return function(r, o) {
        t.then(function() {
          if (e[Cs]) {
            r(Yi(undefined, true));
            return;
          }
          e[wl](r, o);
        }, o);
      };
    }
    var SE = Object.getPrototypeOf(function() {
    }), EE = Object.setPrototypeOf((Ps = { get stream() {
      return this[Pn];
    }, next: function() {
      var e = this, r = this[La];
      if (r !== null)
        return Promise.reject(r);
      if (this[Cs])
        return Promise.resolve(Yi(undefined, true));
      if (this[Pn].destroyed)
        return new Promise(function(m2, y2) {
          process.nextTick(function() {
            e[La] ? y2(e[La]) : m2(Yi(undefined, true));
          });
        });
      var o = this[Dn], f;
      if (o)
        f = new Promise(xE(o, this));
      else {
        var p = this[Pn].read();
        if (p !== null)
          return Promise.resolve(Yi(p, false));
        f = new Promise(this[wl]);
      }
      return this[Dn] = f, f;
    } }, $i(Ps, Symbol.asyncIterator, function() {
      return this;
    }), $i(Ps, "return", function() {
      var e = this;
      return new Promise(function(r, o) {
        e[Pn].destroy(null, function(f) {
          if (f) {
            o(f);
            return;
          }
          r(Yi(undefined, true));
        });
      });
    }), Ps), SE), AE = function(e) {
      var r, o = Object.create(EE, (r = {}, $i(r, Pn, { value: e, writable: true }), $i(r, Gi, { value: null, writable: true }), $i(r, Nn, { value: null, writable: true }), $i(r, La, { value: null, writable: true }), $i(r, Cs, { value: e._readableState.endEmitted, writable: true }), $i(r, wl, { value: function(p, m2) {
        var y2 = o[Pn].read();
        y2 ? (o[Dn] = null, o[Gi] = null, o[Nn] = null, p(Yi(y2, false))) : (o[Gi] = p, o[Nn] = m2);
      }, writable: true }), r));
      return o[Dn] = null, wE(e, function(f) {
        if (f && f.code !== "ERR_STREAM_PREMATURE_CLOSE") {
          var p = o[Nn];
          p !== null && (o[Dn] = null, o[Gi] = null, o[Nn] = null, p(f)), o[La] = f;
          return;
        }
        var m2 = o[Gi];
        m2 !== null && (o[Dn] = null, o[Gi] = null, o[Nn] = null, m2(Yi(undefined, true))), o[Cs] = true;
      }), e.on("readable", _E.bind(null, o)), o;
    };
    kg.exports = AE;
  });
  Dg = T2((ck, Ng) => {
    Ng.exports = function() {
      throw new Error("Readable.from is not available in the browser");
    };
  });
  yl = T2((vk, jg) => {
    jg.exports = Oe;
    var Ef;
    Oe.ReadableState = Fg;
    var pk = ki().EventEmitter, Og = function(e, r) {
      return e.listeners(r).length;
    }, Da = hl(), Os = Ut().Buffer, RE = global.Uint8Array || function() {
    };
    function BE(t) {
      return Os.from(t);
    }
    function qE(t) {
      return Os.isBuffer(t) || t instanceof RE;
    }
    var Ml = $f(), De;
    Ml && Ml.debuglog ? De = Ml.debuglog("stream") : De = function() {
    };
    var IE = pg(), Bl = dl(), TE = cl(), kE = TE.getHighWaterMark, Fs = kn().codes, LE = Fs.ERR_INVALID_ARG_TYPE, NE = Fs.ERR_STREAM_PUSH_AFTER_EOF, DE = Fs.ERR_METHOD_NOT_IMPLEMENTED, PE = Fs.ERR_STREAM_UNSHIFT_AFTER_END_EVENT, Af, _l, xl;
    Ie()(Oe, Da);
    var Na = Bl.errorOrDestroy, Sl = ["error", "close", "destroy", "pause", "resume"];
    function CE(t, e, r) {
      if (typeof t.prependListener == "function")
        return t.prependListener(e, r);
      !t._events || !t._events[e] ? t.on(e, r) : Array.isArray(t._events[e]) ? t._events[e].unshift(r) : t._events[e] = [r, t._events[e]];
    }
    function Fg(t, e, r) {
      Ef = Ef || Ln(), t = t || {}, typeof r != "boolean" && (r = e instanceof Ef), this.objectMode = !!t.objectMode, r && (this.objectMode = this.objectMode || !!t.readableObjectMode), this.highWaterMark = kE(this, t, "readableHighWaterMark", r), this.buffer = new IE, this.length = 0, this.pipes = null, this.pipesCount = 0, this.flowing = null, this.ended = false, this.endEmitted = false, this.reading = false, this.sync = true, this.needReadable = false, this.emittedReadable = false, this.readableListening = false, this.resumeScheduled = false, this.paused = true, this.emitClose = t.emitClose !== false, this.autoDestroy = !!t.autoDestroy, this.destroyed = false, this.defaultEncoding = t.defaultEncoding || "utf8", this.awaitDrain = 0, this.readingMore = false, this.decoder = null, this.encoding = null, t.encoding && (Af || (Af = (Qf(), ur(Jf)).StringDecoder), this.decoder = new Af(t.encoding), this.encoding = t.encoding);
    }
    function Oe(t) {
      if (Ef = Ef || Ln(), !(this instanceof Oe))
        return new Oe(t);
      var e = this instanceof Ef;
      this._readableState = new Fg(t, this, e), this.readable = true, t && (typeof t.read == "function" && (this._read = t.read), typeof t.destroy == "function" && (this._destroy = t.destroy)), Da.call(this);
    }
    Object.defineProperty(Oe.prototype, "destroyed", { enumerable: false, get: function() {
      return this._readableState === undefined ? false : this._readableState.destroyed;
    }, set: function(e) {
      !this._readableState || (this._readableState.destroyed = e);
    } });
    Oe.prototype.destroy = Bl.destroy;
    Oe.prototype._undestroy = Bl.undestroy;
    Oe.prototype._destroy = function(t, e) {
      e(t);
    };
    Oe.prototype.push = function(t, e) {
      var r = this._readableState, o;
      return r.objectMode ? o = true : typeof t == "string" && (e = e || r.defaultEncoding, e !== r.encoding && (t = Os.from(t, e), e = ""), o = true), Ug(this, t, e, false, o);
    };
    Oe.prototype.unshift = function(t) {
      return Ug(this, t, null, true, false);
    };
    function Ug(t, e, r, o, f) {
      De("readableAddChunk", e);
      var p = t._readableState;
      if (e === null)
        p.reading = false, UE(t, p);
      else {
        var m2;
        if (f || (m2 = OE(p, e)), m2)
          Na(t, m2);
        else if (p.objectMode || e && e.length > 0)
          if (typeof e != "string" && !p.objectMode && Object.getPrototypeOf(e) !== Os.prototype && (e = BE(e)), o)
            p.endEmitted ? Na(t, new PE) : El(t, p, e, true);
          else if (p.ended)
            Na(t, new NE);
          else {
            if (p.destroyed)
              return false;
            p.reading = false, p.decoder && !r ? (e = p.decoder.write(e), p.objectMode || e.length !== 0 ? El(t, p, e, false) : Rl(t, p)) : El(t, p, e, false);
          }
        else
          o || (p.reading = false, Rl(t, p));
      }
      return !p.ended && (p.length < p.highWaterMark || p.length === 0);
    }
    function El(t, e, r, o) {
      e.flowing && e.length === 0 && !e.sync ? (e.awaitDrain = 0, t.emit("data", r)) : (e.length += e.objectMode ? 1 : r.length, o ? e.buffer.unshift(r) : e.buffer.push(r), e.needReadable && Us(t)), Rl(t, e);
    }
    function OE(t, e) {
      var r;
      return !qE(e) && typeof e != "string" && e !== undefined && !t.objectMode && (r = new LE("chunk", ["string", "Buffer", "Uint8Array"], e)), r;
    }
    Oe.prototype.isPaused = function() {
      return this._readableState.flowing === false;
    };
    Oe.prototype.setEncoding = function(t) {
      Af || (Af = (Qf(), ur(Jf)).StringDecoder);
      var e = new Af(t);
      this._readableState.decoder = e, this._readableState.encoding = this._readableState.decoder.encoding;
      for (var r = this._readableState.buffer.head, o = "";r !== null; )
        o += e.write(r.data), r = r.next;
      return this._readableState.buffer.clear(), o !== "" && this._readableState.buffer.push(o), this._readableState.length = o.length, this;
    };
    var Pg = 1073741824;
    function FE(t) {
      return t >= Pg ? t = Pg : (t--, t |= t >>> 1, t |= t >>> 2, t |= t >>> 4, t |= t >>> 8, t |= t >>> 16, t++), t;
    }
    function Cg(t, e) {
      return t <= 0 || e.length === 0 && e.ended ? 0 : e.objectMode ? 1 : t !== t ? e.flowing && e.length ? e.buffer.head.data.length : e.length : (t > e.highWaterMark && (e.highWaterMark = FE(t)), t <= e.length ? t : e.ended ? e.length : (e.needReadable = true, 0));
    }
    Oe.prototype.read = function(t) {
      De("read", t), t = parseInt(t, 10);
      var e = this._readableState, r = t;
      if (t !== 0 && (e.emittedReadable = false), t === 0 && e.needReadable && ((e.highWaterMark !== 0 ? e.length >= e.highWaterMark : e.length > 0) || e.ended))
        return De("read: emitReadable", e.length, e.ended), e.length === 0 && e.ended ? Al(this) : Us(this), null;
      if (t = Cg(t, e), t === 0 && e.ended)
        return e.length === 0 && Al(this), null;
      var o = e.needReadable;
      De("need readable", o), (e.length === 0 || e.length - t < e.highWaterMark) && (o = true, De("length less than watermark", o)), e.ended || e.reading ? (o = false, De("reading or ended", o)) : o && (De("do read"), e.reading = true, e.sync = true, e.length === 0 && (e.needReadable = true), this._read(e.highWaterMark), e.sync = false, e.reading || (t = Cg(r, e)));
      var f;
      return t > 0 ? f = Wg(t, e) : f = null, f === null ? (e.needReadable = e.length <= e.highWaterMark, t = 0) : (e.length -= t, e.awaitDrain = 0), e.length === 0 && (e.ended || (e.needReadable = true), r !== t && e.ended && Al(this)), f !== null && this.emit("data", f), f;
    };
    function UE(t, e) {
      if (De("onEofChunk"), !e.ended) {
        if (e.decoder) {
          var r = e.decoder.end();
          r && r.length && (e.buffer.push(r), e.length += e.objectMode ? 1 : r.length);
        }
        e.ended = true, e.sync ? Us(t) : (e.needReadable = false, e.emittedReadable || (e.emittedReadable = true, zg(t)));
      }
    }
    function Us(t) {
      var e = t._readableState;
      De("emitReadable", e.needReadable, e.emittedReadable), e.needReadable = false, e.emittedReadable || (De("emitReadable", e.flowing), e.emittedReadable = true, process.nextTick(zg, t));
    }
    function zg(t) {
      var e = t._readableState;
      De("emitReadable_", e.destroyed, e.length, e.ended), !e.destroyed && (e.length || e.ended) && (t.emit("readable"), e.emittedReadable = false), e.needReadable = !e.flowing && !e.ended && e.length <= e.highWaterMark, ql(t);
    }
    function Rl(t, e) {
      e.readingMore || (e.readingMore = true, process.nextTick(zE, t, e));
    }
    function zE(t, e) {
      for (;!e.reading && !e.ended && (e.length < e.highWaterMark || e.flowing && e.length === 0); ) {
        var r = e.length;
        if (De("maybeReadMore read 0"), t.read(0), r === e.length)
          break;
      }
      e.readingMore = false;
    }
    Oe.prototype._read = function(t) {
      Na(this, new DE("_read()"));
    };
    Oe.prototype.pipe = function(t, e) {
      var r = this, o = this._readableState;
      switch (o.pipesCount) {
        case 0:
          o.pipes = t;
          break;
        case 1:
          o.pipes = [o.pipes, t];
          break;
        default:
          o.pipes.push(t);
          break;
      }
      o.pipesCount += 1, De("pipe count=%d opts=%j", o.pipesCount, e);
      var f = (!e || e.end !== false) && t !== process.stdout && t !== process.stderr, p = f ? y2 : ge;
      o.endEmitted ? process.nextTick(p) : r.once("end", p), t.on("unpipe", m2);
      function m2(_e, N) {
        De("onunpipe"), _e === r && N && N.hasUnpiped === false && (N.hasUnpiped = true, S());
      }
      function y2() {
        De("onend"), t.end();
      }
      var M = HE(r);
      t.on("drain", M);
      var x = false;
      function S() {
        De("cleanup"), t.removeListener("close", q2), t.removeListener("finish", L2), t.removeListener("drain", M), t.removeListener("error", B), t.removeListener("unpipe", m2), r.removeListener("end", y2), r.removeListener("end", ge), r.removeListener("data", E2), x = true, o.awaitDrain && (!t._writableState || t._writableState.needDrain) && M();
      }
      r.on("data", E2);
      function E2(_e) {
        De("ondata");
        var N = t.write(_e);
        De("dest.write", N), N === false && ((o.pipesCount === 1 && o.pipes === t || o.pipesCount > 1 && Kg(o.pipes, t) !== -1) && !x && (De("false write response, pause", o.awaitDrain), o.awaitDrain++), r.pause());
      }
      function B(_e) {
        De("onerror", _e), ge(), t.removeListener("error", B), Og(t, "error") === 0 && Na(t, _e);
      }
      CE(t, "error", B);
      function q2() {
        t.removeListener("finish", L2), ge();
      }
      t.once("close", q2);
      function L2() {
        De("onfinish"), t.removeListener("close", q2), ge();
      }
      t.once("finish", L2);
      function ge() {
        De("unpipe"), r.unpipe(t);
      }
      return t.emit("pipe", r), o.flowing || (De("pipe resume"), r.resume()), t;
    };
    function HE(t) {
      return function() {
        var r = t._readableState;
        De("pipeOnDrain", r.awaitDrain), r.awaitDrain && r.awaitDrain--, r.awaitDrain === 0 && Og(t, "data") && (r.flowing = true, ql(t));
      };
    }
    Oe.prototype.unpipe = function(t) {
      var e = this._readableState, r = { hasUnpiped: false };
      if (e.pipesCount === 0)
        return this;
      if (e.pipesCount === 1)
        return t && t !== e.pipes ? this : (t || (t = e.pipes), e.pipes = null, e.pipesCount = 0, e.flowing = false, t && t.emit("unpipe", this, r), this);
      if (!t) {
        var { pipes: o, pipesCount: f } = e;
        e.pipes = null, e.pipesCount = 0, e.flowing = false;
        for (var p = 0;p < f; p++)
          o[p].emit("unpipe", this, { hasUnpiped: false });
        return this;
      }
      var m2 = Kg(e.pipes, t);
      return m2 === -1 ? this : (e.pipes.splice(m2, 1), e.pipesCount -= 1, e.pipesCount === 1 && (e.pipes = e.pipes[0]), t.emit("unpipe", this, r), this);
    };
    Oe.prototype.on = function(t, e) {
      var r = Da.prototype.on.call(this, t, e), o = this._readableState;
      return t === "data" ? (o.readableListening = this.listenerCount("readable") > 0, o.flowing !== false && this.resume()) : t === "readable" && !o.endEmitted && !o.readableListening && (o.readableListening = o.needReadable = true, o.flowing = false, o.emittedReadable = false, De("on readable", o.length, o.reading), o.length ? Us(this) : o.reading || process.nextTick(WE, this)), r;
    };
    Oe.prototype.addListener = Oe.prototype.on;
    Oe.prototype.removeListener = function(t, e) {
      var r = Da.prototype.removeListener.call(this, t, e);
      return t === "readable" && process.nextTick(Hg, this), r;
    };
    Oe.prototype.removeAllListeners = function(t) {
      var e = Da.prototype.removeAllListeners.apply(this, arguments);
      return (t === "readable" || t === undefined) && process.nextTick(Hg, this), e;
    };
    function Hg(t) {
      var e = t._readableState;
      e.readableListening = t.listenerCount("readable") > 0, e.resumeScheduled && !e.paused ? e.flowing = true : t.listenerCount("data") > 0 && t.resume();
    }
    function WE(t) {
      De("readable nexttick read 0"), t.read(0);
    }
    Oe.prototype.resume = function() {
      var t = this._readableState;
      return t.flowing || (De("resume"), t.flowing = !t.readableListening, KE(this, t)), t.paused = false, this;
    };
    function KE(t, e) {
      e.resumeScheduled || (e.resumeScheduled = true, process.nextTick(jE, t, e));
    }
    function jE(t, e) {
      De("resume", e.reading), e.reading || t.read(0), e.resumeScheduled = false, t.emit("resume"), ql(t), e.flowing && !e.reading && t.read(0);
    }
    Oe.prototype.pause = function() {
      return De("call pause flowing=%j", this._readableState.flowing), this._readableState.flowing !== false && (De("pause"), this._readableState.flowing = false, this.emit("pause")), this._readableState.paused = true, this;
    };
    function ql(t) {
      var e = t._readableState;
      for (De("flow", e.flowing);e.flowing && t.read() !== null; )
        ;
    }
    Oe.prototype.wrap = function(t) {
      var e = this, r = this._readableState, o = false;
      t.on("end", function() {
        if (De("wrapped end"), r.decoder && !r.ended) {
          var m2 = r.decoder.end();
          m2 && m2.length && e.push(m2);
        }
        e.push(null);
      }), t.on("data", function(m2) {
        if (De("wrapped data"), r.decoder && (m2 = r.decoder.write(m2)), !(r.objectMode && m2 == null) && !(!r.objectMode && (!m2 || !m2.length))) {
          var y2 = e.push(m2);
          y2 || (o = true, t.pause());
        }
      });
      for (var f in t)
        this[f] === undefined && typeof t[f] == "function" && (this[f] = function(y2) {
          return function() {
            return t[y2].apply(t, arguments);
          };
        }(f));
      for (var p = 0;p < Sl.length; p++)
        t.on(Sl[p], this.emit.bind(this, Sl[p]));
      return this._read = function(m2) {
        De("wrapped _read", m2), o && (o = false, t.resume());
      }, this;
    };
    typeof Symbol == "function" && (Oe.prototype[Symbol.asyncIterator] = function() {
      return _l === undefined && (_l = Lg()), _l(this);
    });
    Object.defineProperty(Oe.prototype, "readableHighWaterMark", { enumerable: false, get: function() {
      return this._readableState.highWaterMark;
    } });
    Object.defineProperty(Oe.prototype, "readableBuffer", { enumerable: false, get: function() {
      return this._readableState && this._readableState.buffer;
    } });
    Object.defineProperty(Oe.prototype, "readableFlowing", { enumerable: false, get: function() {
      return this._readableState.flowing;
    }, set: function(e) {
      this._readableState && (this._readableState.flowing = e);
    } });
    Oe._fromList = Wg;
    Object.defineProperty(Oe.prototype, "readableLength", { enumerable: false, get: function() {
      return this._readableState.length;
    } });
    function Wg(t, e) {
      if (e.length === 0)
        return null;
      var r;
      return e.objectMode ? r = e.buffer.shift() : !t || t >= e.length ? (e.decoder ? r = e.buffer.join("") : e.buffer.length === 1 ? r = e.buffer.first() : r = e.buffer.concat(e.length), e.buffer.clear()) : r = e.buffer.consume(t, e.decoder), r;
    }
    function Al(t) {
      var e = t._readableState;
      De("endReadable", e.endEmitted), e.endEmitted || (e.ended = true, process.nextTick(ZE, e, t));
    }
    function ZE(t, e) {
      if (De("endReadableNT", t.endEmitted, t.length), !t.endEmitted && t.length === 0 && (t.endEmitted = true, e.readable = false, e.emit("end"), t.autoDestroy)) {
        var r = e._writableState;
        (!r || r.autoDestroy && r.finished) && e.destroy();
      }
    }
    typeof Symbol == "function" && (Oe.from = function(t, e) {
      return xl === undefined && (xl = Dg()), xl(Oe, t, e);
    });
    function Kg(t, e) {
      for (var r = 0, o = t.length;r < o; r++)
        if (t[r] === e)
          return r;
      return -1;
    }
  });
  Il = T2((bk, Vg) => {
    Vg.exports = Ei;
    var zs = kn().codes, VE = zs.ERR_METHOD_NOT_IMPLEMENTED, $E = zs.ERR_MULTIPLE_CALLBACK, GE = zs.ERR_TRANSFORM_ALREADY_TRANSFORMING, YE = zs.ERR_TRANSFORM_WITH_LENGTH_0, Hs = Ln();
    Ie()(Ei, Hs);
    function XE(t, e) {
      var r = this._transformState;
      r.transforming = false;
      var o = r.writecb;
      if (o === null)
        return this.emit("error", new $E);
      r.writechunk = null, r.writecb = null, e != null && this.push(e), o(t);
      var f = this._readableState;
      f.reading = false, (f.needReadable || f.length < f.highWaterMark) && this._read(f.highWaterMark);
    }
    function Ei(t) {
      if (!(this instanceof Ei))
        return new Ei(t);
      Hs.call(this, t), this._transformState = { afterTransform: XE.bind(this), needTransform: false, transforming: false, writecb: null, writechunk: null, writeencoding: null }, this._readableState.needReadable = true, this._readableState.sync = false, t && (typeof t.transform == "function" && (this._transform = t.transform), typeof t.flush == "function" && (this._flush = t.flush)), this.on("prefinish", JE);
    }
    function JE() {
      var t = this;
      typeof this._flush == "function" && !this._readableState.destroyed ? this._flush(function(e, r) {
        Zg(t, e, r);
      }) : Zg(this, null, null);
    }
    Ei.prototype.push = function(t, e) {
      return this._transformState.needTransform = false, Hs.prototype.push.call(this, t, e);
    };
    Ei.prototype._transform = function(t, e, r) {
      r(new VE("_transform()"));
    };
    Ei.prototype._write = function(t, e, r) {
      var o = this._transformState;
      if (o.writecb = r, o.writechunk = t, o.writeencoding = e, !o.transforming) {
        var f = this._readableState;
        (o.needTransform || f.needReadable || f.length < f.highWaterMark) && this._read(f.highWaterMark);
      }
    };
    Ei.prototype._read = function(t) {
      var e = this._transformState;
      e.writechunk !== null && !e.transforming ? (e.transforming = true, this._transform(e.writechunk, e.writeencoding, e.afterTransform)) : e.needTransform = true;
    };
    Ei.prototype._destroy = function(t, e) {
      Hs.prototype._destroy.call(this, t, function(r) {
        e(r);
      });
    };
    function Zg(t, e, r) {
      if (e)
        return t.emit("error", e);
      if (r != null && t.push(r), t._writableState.length)
        throw new YE;
      if (t._transformState.transforming)
        throw new GE;
      return t.push(null);
    }
  });
  Yg = T2((mk, Gg) => {
    Gg.exports = Pa;
    var $g = Il();
    Ie()(Pa, $g);
    function Pa(t) {
      if (!(this instanceof Pa))
        return new Pa(t);
      $g.call(this, t);
    }
    Pa.prototype._transform = function(t, e, r) {
      r(null, t);
    };
  });
  t2 = T2((gk, e2) => {
    var Tl;
    function QE(t) {
      var e = false;
      return function() {
        e || (e = true, t.apply(undefined, arguments));
      };
    }
    var Qg = kn().codes, eA = Qg.ERR_MISSING_ARGS, tA = Qg.ERR_STREAM_DESTROYED;
    function Xg(t) {
      if (t)
        throw t;
    }
    function rA(t) {
      return t.setHeader && typeof t.abort == "function";
    }
    function iA(t, e, r, o) {
      o = QE(o);
      var f = false;
      t.on("close", function() {
        f = true;
      }), Tl === undefined && (Tl = Ds()), Tl(t, { readable: e, writable: r }, function(m2) {
        if (m2)
          return o(m2);
        f = true, o();
      });
      var p = false;
      return function(m2) {
        if (!f && !p) {
          if (p = true, rA(t))
            return t.abort();
          if (typeof t.destroy == "function")
            return t.destroy();
          o(m2 || new tA("pipe"));
        }
      };
    }
    function Jg(t) {
      t();
    }
    function nA(t, e) {
      return t.pipe(e);
    }
    function fA(t) {
      return !t.length || typeof t[t.length - 1] != "function" ? Xg : t.pop();
    }
    function aA() {
      for (var t = arguments.length, e = new Array(t), r = 0;r < t; r++)
        e[r] = arguments[r];
      var o = fA(e);
      if (Array.isArray(e[0]) && (e = e[0]), e.length < 2)
        throw new eA("streams");
      var f, p = e.map(function(m2, y2) {
        var M = y2 < e.length - 1, x = y2 > 0;
        return iA(m2, M, x, function(S) {
          f || (f = S), S && p.forEach(Jg), !M && (p.forEach(Jg), o(f));
        });
      });
      return e.reduce(nA);
    }
    e2.exports = aA;
  });
  i2 = T2((Mr, r2) => {
    Mr = r2.exports = yl();
    Mr.Stream = Mr;
    Mr.Readable = Mr;
    Mr.Writable = bl();
    Mr.Duplex = Ln();
    Mr.Transform = Il();
    Mr.PassThrough = Yg();
    Mr.finished = Ds();
    Mr.pipeline = t2();
  });
  Ws = T2((n2, kl) => {
    (function(t, e) {
      function r(h2, s) {
        if (!h2)
          throw new Error(s || "Assertion failed");
      }
      function o(h2, s) {
        h2.super_ = s;
        var u = function() {
        };
        u.prototype = s.prototype, h2.prototype = new u, h2.prototype.constructor = h2;
      }
      function f(h2, s, u) {
        if (f.isBN(h2))
          return h2;
        this.negative = 0, this.words = null, this.length = 0, this.red = null, h2 !== null && ((s === "le" || s === "be") && (u = s, s = 10), this._init(h2 || 0, s || 10, u || "be"));
      }
      typeof t == "object" ? t.exports = f : e.BN = f, f.BN = f, f.wordSize = 26;
      var p;
      try {
        typeof window < "u" && typeof window.Buffer < "u" ? p = window.Buffer : p = ji().Buffer;
      } catch {
      }
      f.isBN = function(s) {
        return s instanceof f ? true : s !== null && typeof s == "object" && s.constructor.wordSize === f.wordSize && Array.isArray(s.words);
      }, f.max = function(s, u) {
        return s.cmp(u) > 0 ? s : u;
      }, f.min = function(s, u) {
        return s.cmp(u) < 0 ? s : u;
      }, f.prototype._init = function(s, u, c) {
        if (typeof s == "number")
          return this._initNumber(s, u, c);
        if (typeof s == "object")
          return this._initArray(s, u, c);
        u === "hex" && (u = 16), r(u === (u | 0) && u >= 2 && u <= 36), s = s.toString().replace(/\s+/g, "");
        var b2 = 0;
        s[0] === "-" && (b2++, this.negative = 1), b2 < s.length && (u === 16 ? this._parseHex(s, b2, c) : (this._parseBase(s, u, b2), c === "le" && this._initArray(this.toArray(), u, c)));
      }, f.prototype._initNumber = function(s, u, c) {
        s < 0 && (this.negative = 1, s = -s), s < 67108864 ? (this.words = [s & 67108863], this.length = 1) : s < 4503599627370496 ? (this.words = [s & 67108863, s / 67108864 & 67108863], this.length = 2) : (r(s < 9007199254740992), this.words = [s & 67108863, s / 67108864 & 67108863, 1], this.length = 3), c === "le" && this._initArray(this.toArray(), u, c);
      }, f.prototype._initArray = function(s, u, c) {
        if (r(typeof s.length == "number"), s.length <= 0)
          return this.words = [0], this.length = 1, this;
        this.length = Math.ceil(s.length / 3), this.words = new Array(this.length);
        for (var b2 = 0;b2 < this.length; b2++)
          this.words[b2] = 0;
        var l, n, d = 0;
        if (c === "be")
          for (b2 = s.length - 1, l = 0;b2 >= 0; b2 -= 3)
            n = s[b2] | s[b2 - 1] << 8 | s[b2 - 2] << 16, this.words[l] |= n << d & 67108863, this.words[l + 1] = n >>> 26 - d & 67108863, d += 24, d >= 26 && (d -= 26, l++);
        else if (c === "le")
          for (b2 = 0, l = 0;b2 < s.length; b2 += 3)
            n = s[b2] | s[b2 + 1] << 8 | s[b2 + 2] << 16, this.words[l] |= n << d & 67108863, this.words[l + 1] = n >>> 26 - d & 67108863, d += 24, d >= 26 && (d -= 26, l++);
        return this._strip();
      };
      function m2(h2, s) {
        var u = h2.charCodeAt(s);
        if (u >= 48 && u <= 57)
          return u - 48;
        if (u >= 65 && u <= 70)
          return u - 55;
        if (u >= 97 && u <= 102)
          return u - 87;
        r(false, "Invalid character in " + h2);
      }
      function y2(h2, s, u) {
        var c = m2(h2, u);
        return u - 1 >= s && (c |= m2(h2, u - 1) << 4), c;
      }
      f.prototype._parseHex = function(s, u, c) {
        this.length = Math.ceil((s.length - u) / 6), this.words = new Array(this.length);
        for (var b2 = 0;b2 < this.length; b2++)
          this.words[b2] = 0;
        var l = 0, n = 0, d;
        if (c === "be")
          for (b2 = s.length - 1;b2 >= u; b2 -= 2)
            d = y2(s, u, b2) << l, this.words[n] |= d & 67108863, l >= 18 ? (l -= 18, n += 1, this.words[n] |= d >>> 26) : l += 8;
        else {
          var w = s.length - u;
          for (b2 = w % 2 === 0 ? u + 1 : u;b2 < s.length; b2 += 2)
            d = y2(s, u, b2) << l, this.words[n] |= d & 67108863, l >= 18 ? (l -= 18, n += 1, this.words[n] |= d >>> 26) : l += 8;
        }
        this._strip();
      };
      function M(h2, s, u, c) {
        for (var b2 = 0, l = 0, n = Math.min(h2.length, u), d = s;d < n; d++) {
          var w = h2.charCodeAt(d) - 48;
          b2 *= c, w >= 49 ? l = w - 49 + 10 : w >= 17 ? l = w - 17 + 10 : l = w, r(w >= 0 && l < c, "Invalid character"), b2 += l;
        }
        return b2;
      }
      f.prototype._parseBase = function(s, u, c) {
        this.words = [0], this.length = 1;
        for (var b2 = 0, l = 1;l <= 67108863; l *= u)
          b2++;
        b2--, l = l / u | 0;
        for (var n = s.length - c, d = n % b2, w = Math.min(n, n - d) + c, g = 0, _2 = c;_2 < w; _2 += b2)
          g = M(s, _2, _2 + b2, u), this.imuln(l), this.words[0] + g < 67108864 ? this.words[0] += g : this._iaddn(g);
        if (d !== 0) {
          var A2 = 1;
          for (g = M(s, _2, s.length, u), _2 = 0;_2 < d; _2++)
            A2 *= u;
          this.imuln(A2), this.words[0] + g < 67108864 ? this.words[0] += g : this._iaddn(g);
        }
        this._strip();
      }, f.prototype.copy = function(s) {
        s.words = new Array(this.length);
        for (var u = 0;u < this.length; u++)
          s.words[u] = this.words[u];
        s.length = this.length, s.negative = this.negative, s.red = this.red;
      };
      function x(h2, s) {
        h2.words = s.words, h2.length = s.length, h2.negative = s.negative, h2.red = s.red;
      }
      if (f.prototype._move = function(s) {
        x(s, this);
      }, f.prototype.clone = function() {
        var s = new f(null);
        return this.copy(s), s;
      }, f.prototype._expand = function(s) {
        for (;this.length < s; )
          this.words[this.length++] = 0;
        return this;
      }, f.prototype._strip = function() {
        for (;this.length > 1 && this.words[this.length - 1] === 0; )
          this.length--;
        return this._normSign();
      }, f.prototype._normSign = function() {
        return this.length === 1 && this.words[0] === 0 && (this.negative = 0), this;
      }, typeof Symbol < "u" && typeof Symbol.for == "function")
        try {
          f.prototype[Symbol.for("nodejs.util.inspect.custom")] = S;
        } catch {
          f.prototype.inspect = S;
        }
      else
        f.prototype.inspect = S;
      function S() {
        return (this.red ? "<BN-R: " : "<BN: ") + this.toString(16) + ">";
      }
      var E2 = ["", "0", "00", "000", "0000", "00000", "000000", "0000000", "00000000", "000000000", "0000000000", "00000000000", "000000000000", "0000000000000", "00000000000000", "000000000000000", "0000000000000000", "00000000000000000", "000000000000000000", "0000000000000000000", "00000000000000000000", "000000000000000000000", "0000000000000000000000", "00000000000000000000000", "000000000000000000000000", "0000000000000000000000000"], B = [0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5], q2 = [0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 1e7, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176];
      f.prototype.toString = function(s, u) {
        s = s || 10, u = u | 0 || 1;
        var c;
        if (s === 16 || s === "hex") {
          c = "";
          for (var b2 = 0, l = 0, n = 0;n < this.length; n++) {
            var d = this.words[n], w = ((d << b2 | l) & 16777215).toString(16);
            l = d >>> 24 - b2 & 16777215, b2 += 2, b2 >= 26 && (b2 -= 26, n--), l !== 0 || n !== this.length - 1 ? c = E2[6 - w.length] + w + c : c = w + c;
          }
          for (l !== 0 && (c = l.toString(16) + c);c.length % u !== 0; )
            c = "0" + c;
          return this.negative !== 0 && (c = "-" + c), c;
        }
        if (s === (s | 0) && s >= 2 && s <= 36) {
          var g = B[s], _2 = q2[s];
          c = "";
          var A2 = this.clone();
          for (A2.negative = 0;!A2.isZero(); ) {
            var R2 = A2.modrn(_2).toString(s);
            A2 = A2.idivn(_2), A2.isZero() ? c = R2 + c : c = E2[g - R2.length] + R2 + c;
          }
          for (this.isZero() && (c = "0" + c);c.length % u !== 0; )
            c = "0" + c;
          return this.negative !== 0 && (c = "-" + c), c;
        }
        r(false, "Base should be between 2 and 36");
      }, f.prototype.toNumber = function() {
        var s = this.words[0];
        return this.length === 2 ? s += this.words[1] * 67108864 : this.length === 3 && this.words[2] === 1 ? s += 4503599627370496 + this.words[1] * 67108864 : this.length > 2 && r(false, "Number can only safely store up to 53 bits"), this.negative !== 0 ? -s : s;
      }, f.prototype.toJSON = function() {
        return this.toString(16, 2);
      }, p && (f.prototype.toBuffer = function(s, u) {
        return this.toArrayLike(p, s, u);
      }), f.prototype.toArray = function(s, u) {
        return this.toArrayLike(Array, s, u);
      };
      var L2 = function(s, u) {
        return s.allocUnsafe ? s.allocUnsafe(u) : new s(u);
      };
      f.prototype.toArrayLike = function(s, u, c) {
        this._strip();
        var b2 = this.byteLength(), l = c || Math.max(1, b2);
        r(b2 <= l, "byte array longer than desired length"), r(l > 0, "Requested array length <= 0");
        var n = L2(s, l), d = u === "le" ? "LE" : "BE";
        return this["_toArrayLike" + d](n, b2), n;
      }, f.prototype._toArrayLikeLE = function(s, u) {
        for (var c = 0, b2 = 0, l = 0, n = 0;l < this.length; l++) {
          var d = this.words[l] << n | b2;
          s[c++] = d & 255, c < s.length && (s[c++] = d >> 8 & 255), c < s.length && (s[c++] = d >> 16 & 255), n === 6 ? (c < s.length && (s[c++] = d >> 24 & 255), b2 = 0, n = 0) : (b2 = d >>> 24, n += 2);
        }
        if (c < s.length)
          for (s[c++] = b2;c < s.length; )
            s[c++] = 0;
      }, f.prototype._toArrayLikeBE = function(s, u) {
        for (var c = s.length - 1, b2 = 0, l = 0, n = 0;l < this.length; l++) {
          var d = this.words[l] << n | b2;
          s[c--] = d & 255, c >= 0 && (s[c--] = d >> 8 & 255), c >= 0 && (s[c--] = d >> 16 & 255), n === 6 ? (c >= 0 && (s[c--] = d >> 24 & 255), b2 = 0, n = 0) : (b2 = d >>> 24, n += 2);
        }
        if (c >= 0)
          for (s[c--] = b2;c >= 0; )
            s[c--] = 0;
      }, Math.clz32 ? f.prototype._countBits = function(s) {
        return 32 - Math.clz32(s);
      } : f.prototype._countBits = function(s) {
        var u = s, c = 0;
        return u >= 4096 && (c += 13, u >>>= 13), u >= 64 && (c += 7, u >>>= 7), u >= 8 && (c += 4, u >>>= 4), u >= 2 && (c += 2, u >>>= 2), c + u;
      }, f.prototype._zeroBits = function(s) {
        if (s === 0)
          return 26;
        var u = s, c = 0;
        return (u & 8191) === 0 && (c += 13, u >>>= 13), (u & 127) === 0 && (c += 7, u >>>= 7), (u & 15) === 0 && (c += 4, u >>>= 4), (u & 3) === 0 && (c += 2, u >>>= 2), (u & 1) === 0 && c++, c;
      }, f.prototype.bitLength = function() {
        var s = this.words[this.length - 1], u = this._countBits(s);
        return (this.length - 1) * 26 + u;
      };
      function ge(h2) {
        for (var s = new Array(h2.bitLength()), u = 0;u < s.length; u++) {
          var c = u / 26 | 0, b2 = u % 26;
          s[u] = h2.words[c] >>> b2 & 1;
        }
        return s;
      }
      f.prototype.zeroBits = function() {
        if (this.isZero())
          return 0;
        for (var s = 0, u = 0;u < this.length; u++) {
          var c = this._zeroBits(this.words[u]);
          if (s += c, c !== 26)
            break;
        }
        return s;
      }, f.prototype.byteLength = function() {
        return Math.ceil(this.bitLength() / 8);
      }, f.prototype.toTwos = function(s) {
        return this.negative !== 0 ? this.abs().inotn(s).iaddn(1) : this.clone();
      }, f.prototype.fromTwos = function(s) {
        return this.testn(s - 1) ? this.notn(s).iaddn(1).ineg() : this.clone();
      }, f.prototype.isNeg = function() {
        return this.negative !== 0;
      }, f.prototype.neg = function() {
        return this.clone().ineg();
      }, f.prototype.ineg = function() {
        return this.isZero() || (this.negative ^= 1), this;
      }, f.prototype.iuor = function(s) {
        for (;this.length < s.length; )
          this.words[this.length++] = 0;
        for (var u = 0;u < s.length; u++)
          this.words[u] = this.words[u] | s.words[u];
        return this._strip();
      }, f.prototype.ior = function(s) {
        return r((this.negative | s.negative) === 0), this.iuor(s);
      }, f.prototype.or = function(s) {
        return this.length > s.length ? this.clone().ior(s) : s.clone().ior(this);
      }, f.prototype.uor = function(s) {
        return this.length > s.length ? this.clone().iuor(s) : s.clone().iuor(this);
      }, f.prototype.iuand = function(s) {
        var u;
        this.length > s.length ? u = s : u = this;
        for (var c = 0;c < u.length; c++)
          this.words[c] = this.words[c] & s.words[c];
        return this.length = u.length, this._strip();
      }, f.prototype.iand = function(s) {
        return r((this.negative | s.negative) === 0), this.iuand(s);
      }, f.prototype.and = function(s) {
        return this.length > s.length ? this.clone().iand(s) : s.clone().iand(this);
      }, f.prototype.uand = function(s) {
        return this.length > s.length ? this.clone().iuand(s) : s.clone().iuand(this);
      }, f.prototype.iuxor = function(s) {
        var u, c;
        this.length > s.length ? (u = this, c = s) : (u = s, c = this);
        for (var b2 = 0;b2 < c.length; b2++)
          this.words[b2] = u.words[b2] ^ c.words[b2];
        if (this !== u)
          for (;b2 < u.length; b2++)
            this.words[b2] = u.words[b2];
        return this.length = u.length, this._strip();
      }, f.prototype.ixor = function(s) {
        return r((this.negative | s.negative) === 0), this.iuxor(s);
      }, f.prototype.xor = function(s) {
        return this.length > s.length ? this.clone().ixor(s) : s.clone().ixor(this);
      }, f.prototype.uxor = function(s) {
        return this.length > s.length ? this.clone().iuxor(s) : s.clone().iuxor(this);
      }, f.prototype.inotn = function(s) {
        r(typeof s == "number" && s >= 0);
        var u = Math.ceil(s / 26) | 0, c = s % 26;
        this._expand(u), c > 0 && u--;
        for (var b2 = 0;b2 < u; b2++)
          this.words[b2] = ~this.words[b2] & 67108863;
        return c > 0 && (this.words[b2] = ~this.words[b2] & 67108863 >> 26 - c), this._strip();
      }, f.prototype.notn = function(s) {
        return this.clone().inotn(s);
      }, f.prototype.setn = function(s, u) {
        r(typeof s == "number" && s >= 0);
        var c = s / 26 | 0, b2 = s % 26;
        return this._expand(c + 1), u ? this.words[c] = this.words[c] | 1 << b2 : this.words[c] = this.words[c] & ~(1 << b2), this._strip();
      }, f.prototype.iadd = function(s) {
        var u;
        if (this.negative !== 0 && s.negative === 0)
          return this.negative = 0, u = this.isub(s), this.negative ^= 1, this._normSign();
        if (this.negative === 0 && s.negative !== 0)
          return s.negative = 0, u = this.isub(s), s.negative = 1, u._normSign();
        var c, b2;
        this.length > s.length ? (c = this, b2 = s) : (c = s, b2 = this);
        for (var l = 0, n = 0;n < b2.length; n++)
          u = (c.words[n] | 0) + (b2.words[n] | 0) + l, this.words[n] = u & 67108863, l = u >>> 26;
        for (;l !== 0 && n < c.length; n++)
          u = (c.words[n] | 0) + l, this.words[n] = u & 67108863, l = u >>> 26;
        if (this.length = c.length, l !== 0)
          this.words[this.length] = l, this.length++;
        else if (c !== this)
          for (;n < c.length; n++)
            this.words[n] = c.words[n];
        return this;
      }, f.prototype.add = function(s) {
        var u;
        return s.negative !== 0 && this.negative === 0 ? (s.negative = 0, u = this.sub(s), s.negative ^= 1, u) : s.negative === 0 && this.negative !== 0 ? (this.negative = 0, u = s.sub(this), this.negative = 1, u) : this.length > s.length ? this.clone().iadd(s) : s.clone().iadd(this);
      }, f.prototype.isub = function(s) {
        if (s.negative !== 0) {
          s.negative = 0;
          var u = this.iadd(s);
          return s.negative = 1, u._normSign();
        } else if (this.negative !== 0)
          return this.negative = 0, this.iadd(s), this.negative = 1, this._normSign();
        var c = this.cmp(s);
        if (c === 0)
          return this.negative = 0, this.length = 1, this.words[0] = 0, this;
        var b2, l;
        c > 0 ? (b2 = this, l = s) : (b2 = s, l = this);
        for (var n = 0, d = 0;d < l.length; d++)
          u = (b2.words[d] | 0) - (l.words[d] | 0) + n, n = u >> 26, this.words[d] = u & 67108863;
        for (;n !== 0 && d < b2.length; d++)
          u = (b2.words[d] | 0) + n, n = u >> 26, this.words[d] = u & 67108863;
        if (n === 0 && d < b2.length && b2 !== this)
          for (;d < b2.length; d++)
            this.words[d] = b2.words[d];
        return this.length = Math.max(this.length, d), b2 !== this && (this.negative = 1), this._strip();
      }, f.prototype.sub = function(s) {
        return this.clone().isub(s);
      };
      function _e(h2, s, u) {
        u.negative = s.negative ^ h2.negative;
        var c = h2.length + s.length | 0;
        u.length = c, c = c - 1 | 0;
        var b2 = h2.words[0] | 0, l = s.words[0] | 0, n = b2 * l, d = n & 67108863, w = n / 67108864 | 0;
        u.words[0] = d;
        for (var g = 1;g < c; g++) {
          for (var _2 = w >>> 26, A2 = w & 67108863, R2 = Math.min(g, s.length - 1), I = Math.max(0, g - h2.length + 1);I <= R2; I++) {
            var Me = g - I | 0;
            b2 = h2.words[Me] | 0, l = s.words[I] | 0, n = b2 * l + A2, _2 += n / 67108864 | 0, A2 = n & 67108863;
          }
          u.words[g] = A2 | 0, w = _2 | 0;
        }
        return w !== 0 ? u.words[g] = w | 0 : u.length--, u._strip();
      }
      var N = function(s, u, c) {
        var b2 = s.words, l = u.words, n = c.words, d = 0, w, g, _2, A2 = b2[0] | 0, R2 = A2 & 8191, I = A2 >>> 13, Me = b2[1] | 0, k = Me & 8191, D2 = Me >>> 13, nt = b2[2] | 0, C2 = nt & 8191, O = nt >>> 13, vt = b2[3] | 0, F = vt & 8191, U = vt >>> 13, bt = b2[4] | 0, z2 = bt & 8191, H = bt >>> 13, mt = b2[5] | 0, W = mt & 8191, K = mt >>> 13, gt = b2[6] | 0, j = gt & 8191, Z = gt >>> 13, yt = b2[7] | 0, V = yt & 8191, $ = yt >>> 13, wt = b2[8] | 0, G = wt & 8191, Y = wt >>> 13, Mt = b2[9] | 0, X = Mt & 8191, J = Mt >>> 13, _t = l[0] | 0, Q = _t & 8191, ee = _t >>> 13, xt = l[1] | 0, te = xt & 8191, re = xt >>> 13, St = l[2] | 0, ie = St & 8191, ne = St >>> 13, Et = l[3] | 0, fe = Et & 8191, ae = Et >>> 13, At = l[4] | 0, oe = At & 8191, se = At >>> 13, Rt = l[5] | 0, he = Rt & 8191, ue = Rt >>> 13, Bt = l[6] | 0, le = Bt & 8191, de = Bt >>> 13, qt = l[7] | 0, ce = qt & 8191, pe = qt >>> 13, It = l[8] | 0, ve = It & 8191, be = It >>> 13, ft = l[9] | 0, Be = ft & 8191, qe = ft >>> 13;
        c.negative = s.negative ^ u.negative, c.length = 19, w = Math.imul(R2, Q), g = Math.imul(R2, ee), g = g + Math.imul(I, Q) | 0, _2 = Math.imul(I, ee);
        var ze = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (ze >>> 26) | 0, ze &= 67108863, w = Math.imul(k, Q), g = Math.imul(k, ee), g = g + Math.imul(D2, Q) | 0, _2 = Math.imul(D2, ee), w = w + Math.imul(R2, te) | 0, g = g + Math.imul(R2, re) | 0, g = g + Math.imul(I, te) | 0, _2 = _2 + Math.imul(I, re) | 0;
        var He = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (He >>> 26) | 0, He &= 67108863, w = Math.imul(C2, Q), g = Math.imul(C2, ee), g = g + Math.imul(O, Q) | 0, _2 = Math.imul(O, ee), w = w + Math.imul(k, te) | 0, g = g + Math.imul(k, re) | 0, g = g + Math.imul(D2, te) | 0, _2 = _2 + Math.imul(D2, re) | 0, w = w + Math.imul(R2, ie) | 0, g = g + Math.imul(R2, ne) | 0, g = g + Math.imul(I, ie) | 0, _2 = _2 + Math.imul(I, ne) | 0;
        var We = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (We >>> 26) | 0, We &= 67108863, w = Math.imul(F, Q), g = Math.imul(F, ee), g = g + Math.imul(U, Q) | 0, _2 = Math.imul(U, ee), w = w + Math.imul(C2, te) | 0, g = g + Math.imul(C2, re) | 0, g = g + Math.imul(O, te) | 0, _2 = _2 + Math.imul(O, re) | 0, w = w + Math.imul(k, ie) | 0, g = g + Math.imul(k, ne) | 0, g = g + Math.imul(D2, ie) | 0, _2 = _2 + Math.imul(D2, ne) | 0, w = w + Math.imul(R2, fe) | 0, g = g + Math.imul(R2, ae) | 0, g = g + Math.imul(I, fe) | 0, _2 = _2 + Math.imul(I, ae) | 0;
        var Ke = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (Ke >>> 26) | 0, Ke &= 67108863, w = Math.imul(z2, Q), g = Math.imul(z2, ee), g = g + Math.imul(H, Q) | 0, _2 = Math.imul(H, ee), w = w + Math.imul(F, te) | 0, g = g + Math.imul(F, re) | 0, g = g + Math.imul(U, te) | 0, _2 = _2 + Math.imul(U, re) | 0, w = w + Math.imul(C2, ie) | 0, g = g + Math.imul(C2, ne) | 0, g = g + Math.imul(O, ie) | 0, _2 = _2 + Math.imul(O, ne) | 0, w = w + Math.imul(k, fe) | 0, g = g + Math.imul(k, ae) | 0, g = g + Math.imul(D2, fe) | 0, _2 = _2 + Math.imul(D2, ae) | 0, w = w + Math.imul(R2, oe) | 0, g = g + Math.imul(R2, se) | 0, g = g + Math.imul(I, oe) | 0, _2 = _2 + Math.imul(I, se) | 0;
        var je = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (je >>> 26) | 0, je &= 67108863, w = Math.imul(W, Q), g = Math.imul(W, ee), g = g + Math.imul(K, Q) | 0, _2 = Math.imul(K, ee), w = w + Math.imul(z2, te) | 0, g = g + Math.imul(z2, re) | 0, g = g + Math.imul(H, te) | 0, _2 = _2 + Math.imul(H, re) | 0, w = w + Math.imul(F, ie) | 0, g = g + Math.imul(F, ne) | 0, g = g + Math.imul(U, ie) | 0, _2 = _2 + Math.imul(U, ne) | 0, w = w + Math.imul(C2, fe) | 0, g = g + Math.imul(C2, ae) | 0, g = g + Math.imul(O, fe) | 0, _2 = _2 + Math.imul(O, ae) | 0, w = w + Math.imul(k, oe) | 0, g = g + Math.imul(k, se) | 0, g = g + Math.imul(D2, oe) | 0, _2 = _2 + Math.imul(D2, se) | 0, w = w + Math.imul(R2, he) | 0, g = g + Math.imul(R2, ue) | 0, g = g + Math.imul(I, he) | 0, _2 = _2 + Math.imul(I, ue) | 0;
        var Ze = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (Ze >>> 26) | 0, Ze &= 67108863, w = Math.imul(j, Q), g = Math.imul(j, ee), g = g + Math.imul(Z, Q) | 0, _2 = Math.imul(Z, ee), w = w + Math.imul(W, te) | 0, g = g + Math.imul(W, re) | 0, g = g + Math.imul(K, te) | 0, _2 = _2 + Math.imul(K, re) | 0, w = w + Math.imul(z2, ie) | 0, g = g + Math.imul(z2, ne) | 0, g = g + Math.imul(H, ie) | 0, _2 = _2 + Math.imul(H, ne) | 0, w = w + Math.imul(F, fe) | 0, g = g + Math.imul(F, ae) | 0, g = g + Math.imul(U, fe) | 0, _2 = _2 + Math.imul(U, ae) | 0, w = w + Math.imul(C2, oe) | 0, g = g + Math.imul(C2, se) | 0, g = g + Math.imul(O, oe) | 0, _2 = _2 + Math.imul(O, se) | 0, w = w + Math.imul(k, he) | 0, g = g + Math.imul(k, ue) | 0, g = g + Math.imul(D2, he) | 0, _2 = _2 + Math.imul(D2, ue) | 0, w = w + Math.imul(R2, le) | 0, g = g + Math.imul(R2, de) | 0, g = g + Math.imul(I, le) | 0, _2 = _2 + Math.imul(I, de) | 0;
        var Ve = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (Ve >>> 26) | 0, Ve &= 67108863, w = Math.imul(V, Q), g = Math.imul(V, ee), g = g + Math.imul($, Q) | 0, _2 = Math.imul($, ee), w = w + Math.imul(j, te) | 0, g = g + Math.imul(j, re) | 0, g = g + Math.imul(Z, te) | 0, _2 = _2 + Math.imul(Z, re) | 0, w = w + Math.imul(W, ie) | 0, g = g + Math.imul(W, ne) | 0, g = g + Math.imul(K, ie) | 0, _2 = _2 + Math.imul(K, ne) | 0, w = w + Math.imul(z2, fe) | 0, g = g + Math.imul(z2, ae) | 0, g = g + Math.imul(H, fe) | 0, _2 = _2 + Math.imul(H, ae) | 0, w = w + Math.imul(F, oe) | 0, g = g + Math.imul(F, se) | 0, g = g + Math.imul(U, oe) | 0, _2 = _2 + Math.imul(U, se) | 0, w = w + Math.imul(C2, he) | 0, g = g + Math.imul(C2, ue) | 0, g = g + Math.imul(O, he) | 0, _2 = _2 + Math.imul(O, ue) | 0, w = w + Math.imul(k, le) | 0, g = g + Math.imul(k, de) | 0, g = g + Math.imul(D2, le) | 0, _2 = _2 + Math.imul(D2, de) | 0, w = w + Math.imul(R2, ce) | 0, g = g + Math.imul(R2, pe) | 0, g = g + Math.imul(I, ce) | 0, _2 = _2 + Math.imul(I, pe) | 0;
        var $e = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + ($e >>> 26) | 0, $e &= 67108863, w = Math.imul(G, Q), g = Math.imul(G, ee), g = g + Math.imul(Y, Q) | 0, _2 = Math.imul(Y, ee), w = w + Math.imul(V, te) | 0, g = g + Math.imul(V, re) | 0, g = g + Math.imul($, te) | 0, _2 = _2 + Math.imul($, re) | 0, w = w + Math.imul(j, ie) | 0, g = g + Math.imul(j, ne) | 0, g = g + Math.imul(Z, ie) | 0, _2 = _2 + Math.imul(Z, ne) | 0, w = w + Math.imul(W, fe) | 0, g = g + Math.imul(W, ae) | 0, g = g + Math.imul(K, fe) | 0, _2 = _2 + Math.imul(K, ae) | 0, w = w + Math.imul(z2, oe) | 0, g = g + Math.imul(z2, se) | 0, g = g + Math.imul(H, oe) | 0, _2 = _2 + Math.imul(H, se) | 0, w = w + Math.imul(F, he) | 0, g = g + Math.imul(F, ue) | 0, g = g + Math.imul(U, he) | 0, _2 = _2 + Math.imul(U, ue) | 0, w = w + Math.imul(C2, le) | 0, g = g + Math.imul(C2, de) | 0, g = g + Math.imul(O, le) | 0, _2 = _2 + Math.imul(O, de) | 0, w = w + Math.imul(k, ce) | 0, g = g + Math.imul(k, pe) | 0, g = g + Math.imul(D2, ce) | 0, _2 = _2 + Math.imul(D2, pe) | 0, w = w + Math.imul(R2, ve) | 0, g = g + Math.imul(R2, be) | 0, g = g + Math.imul(I, ve) | 0, _2 = _2 + Math.imul(I, be) | 0;
        var Ge = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (Ge >>> 26) | 0, Ge &= 67108863, w = Math.imul(X, Q), g = Math.imul(X, ee), g = g + Math.imul(J, Q) | 0, _2 = Math.imul(J, ee), w = w + Math.imul(G, te) | 0, g = g + Math.imul(G, re) | 0, g = g + Math.imul(Y, te) | 0, _2 = _2 + Math.imul(Y, re) | 0, w = w + Math.imul(V, ie) | 0, g = g + Math.imul(V, ne) | 0, g = g + Math.imul($, ie) | 0, _2 = _2 + Math.imul($, ne) | 0, w = w + Math.imul(j, fe) | 0, g = g + Math.imul(j, ae) | 0, g = g + Math.imul(Z, fe) | 0, _2 = _2 + Math.imul(Z, ae) | 0, w = w + Math.imul(W, oe) | 0, g = g + Math.imul(W, se) | 0, g = g + Math.imul(K, oe) | 0, _2 = _2 + Math.imul(K, se) | 0, w = w + Math.imul(z2, he) | 0, g = g + Math.imul(z2, ue) | 0, g = g + Math.imul(H, he) | 0, _2 = _2 + Math.imul(H, ue) | 0, w = w + Math.imul(F, le) | 0, g = g + Math.imul(F, de) | 0, g = g + Math.imul(U, le) | 0, _2 = _2 + Math.imul(U, de) | 0, w = w + Math.imul(C2, ce) | 0, g = g + Math.imul(C2, pe) | 0, g = g + Math.imul(O, ce) | 0, _2 = _2 + Math.imul(O, pe) | 0, w = w + Math.imul(k, ve) | 0, g = g + Math.imul(k, be) | 0, g = g + Math.imul(D2, ve) | 0, _2 = _2 + Math.imul(D2, be) | 0, w = w + Math.imul(R2, Be) | 0, g = g + Math.imul(R2, qe) | 0, g = g + Math.imul(I, Be) | 0, _2 = _2 + Math.imul(I, qe) | 0;
        var Ye = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (Ye >>> 26) | 0, Ye &= 67108863, w = Math.imul(X, te), g = Math.imul(X, re), g = g + Math.imul(J, te) | 0, _2 = Math.imul(J, re), w = w + Math.imul(G, ie) | 0, g = g + Math.imul(G, ne) | 0, g = g + Math.imul(Y, ie) | 0, _2 = _2 + Math.imul(Y, ne) | 0, w = w + Math.imul(V, fe) | 0, g = g + Math.imul(V, ae) | 0, g = g + Math.imul($, fe) | 0, _2 = _2 + Math.imul($, ae) | 0, w = w + Math.imul(j, oe) | 0, g = g + Math.imul(j, se) | 0, g = g + Math.imul(Z, oe) | 0, _2 = _2 + Math.imul(Z, se) | 0, w = w + Math.imul(W, he) | 0, g = g + Math.imul(W, ue) | 0, g = g + Math.imul(K, he) | 0, _2 = _2 + Math.imul(K, ue) | 0, w = w + Math.imul(z2, le) | 0, g = g + Math.imul(z2, de) | 0, g = g + Math.imul(H, le) | 0, _2 = _2 + Math.imul(H, de) | 0, w = w + Math.imul(F, ce) | 0, g = g + Math.imul(F, pe) | 0, g = g + Math.imul(U, ce) | 0, _2 = _2 + Math.imul(U, pe) | 0, w = w + Math.imul(C2, ve) | 0, g = g + Math.imul(C2, be) | 0, g = g + Math.imul(O, ve) | 0, _2 = _2 + Math.imul(O, be) | 0, w = w + Math.imul(k, Be) | 0, g = g + Math.imul(k, qe) | 0, g = g + Math.imul(D2, Be) | 0, _2 = _2 + Math.imul(D2, qe) | 0;
        var Xe = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (Xe >>> 26) | 0, Xe &= 67108863, w = Math.imul(X, ie), g = Math.imul(X, ne), g = g + Math.imul(J, ie) | 0, _2 = Math.imul(J, ne), w = w + Math.imul(G, fe) | 0, g = g + Math.imul(G, ae) | 0, g = g + Math.imul(Y, fe) | 0, _2 = _2 + Math.imul(Y, ae) | 0, w = w + Math.imul(V, oe) | 0, g = g + Math.imul(V, se) | 0, g = g + Math.imul($, oe) | 0, _2 = _2 + Math.imul($, se) | 0, w = w + Math.imul(j, he) | 0, g = g + Math.imul(j, ue) | 0, g = g + Math.imul(Z, he) | 0, _2 = _2 + Math.imul(Z, ue) | 0, w = w + Math.imul(W, le) | 0, g = g + Math.imul(W, de) | 0, g = g + Math.imul(K, le) | 0, _2 = _2 + Math.imul(K, de) | 0, w = w + Math.imul(z2, ce) | 0, g = g + Math.imul(z2, pe) | 0, g = g + Math.imul(H, ce) | 0, _2 = _2 + Math.imul(H, pe) | 0, w = w + Math.imul(F, ve) | 0, g = g + Math.imul(F, be) | 0, g = g + Math.imul(U, ve) | 0, _2 = _2 + Math.imul(U, be) | 0, w = w + Math.imul(C2, Be) | 0, g = g + Math.imul(C2, qe) | 0, g = g + Math.imul(O, Be) | 0, _2 = _2 + Math.imul(O, qe) | 0;
        var Je = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (Je >>> 26) | 0, Je &= 67108863, w = Math.imul(X, fe), g = Math.imul(X, ae), g = g + Math.imul(J, fe) | 0, _2 = Math.imul(J, ae), w = w + Math.imul(G, oe) | 0, g = g + Math.imul(G, se) | 0, g = g + Math.imul(Y, oe) | 0, _2 = _2 + Math.imul(Y, se) | 0, w = w + Math.imul(V, he) | 0, g = g + Math.imul(V, ue) | 0, g = g + Math.imul($, he) | 0, _2 = _2 + Math.imul($, ue) | 0, w = w + Math.imul(j, le) | 0, g = g + Math.imul(j, de) | 0, g = g + Math.imul(Z, le) | 0, _2 = _2 + Math.imul(Z, de) | 0, w = w + Math.imul(W, ce) | 0, g = g + Math.imul(W, pe) | 0, g = g + Math.imul(K, ce) | 0, _2 = _2 + Math.imul(K, pe) | 0, w = w + Math.imul(z2, ve) | 0, g = g + Math.imul(z2, be) | 0, g = g + Math.imul(H, ve) | 0, _2 = _2 + Math.imul(H, be) | 0, w = w + Math.imul(F, Be) | 0, g = g + Math.imul(F, qe) | 0, g = g + Math.imul(U, Be) | 0, _2 = _2 + Math.imul(U, qe) | 0;
        var Qe = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (Qe >>> 26) | 0, Qe &= 67108863, w = Math.imul(X, oe), g = Math.imul(X, se), g = g + Math.imul(J, oe) | 0, _2 = Math.imul(J, se), w = w + Math.imul(G, he) | 0, g = g + Math.imul(G, ue) | 0, g = g + Math.imul(Y, he) | 0, _2 = _2 + Math.imul(Y, ue) | 0, w = w + Math.imul(V, le) | 0, g = g + Math.imul(V, de) | 0, g = g + Math.imul($, le) | 0, _2 = _2 + Math.imul($, de) | 0, w = w + Math.imul(j, ce) | 0, g = g + Math.imul(j, pe) | 0, g = g + Math.imul(Z, ce) | 0, _2 = _2 + Math.imul(Z, pe) | 0, w = w + Math.imul(W, ve) | 0, g = g + Math.imul(W, be) | 0, g = g + Math.imul(K, ve) | 0, _2 = _2 + Math.imul(K, be) | 0, w = w + Math.imul(z2, Be) | 0, g = g + Math.imul(z2, qe) | 0, g = g + Math.imul(H, Be) | 0, _2 = _2 + Math.imul(H, qe) | 0;
        var et = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (et >>> 26) | 0, et &= 67108863, w = Math.imul(X, he), g = Math.imul(X, ue), g = g + Math.imul(J, he) | 0, _2 = Math.imul(J, ue), w = w + Math.imul(G, le) | 0, g = g + Math.imul(G, de) | 0, g = g + Math.imul(Y, le) | 0, _2 = _2 + Math.imul(Y, de) | 0, w = w + Math.imul(V, ce) | 0, g = g + Math.imul(V, pe) | 0, g = g + Math.imul($, ce) | 0, _2 = _2 + Math.imul($, pe) | 0, w = w + Math.imul(j, ve) | 0, g = g + Math.imul(j, be) | 0, g = g + Math.imul(Z, ve) | 0, _2 = _2 + Math.imul(Z, be) | 0, w = w + Math.imul(W, Be) | 0, g = g + Math.imul(W, qe) | 0, g = g + Math.imul(K, Be) | 0, _2 = _2 + Math.imul(K, qe) | 0;
        var tt = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (tt >>> 26) | 0, tt &= 67108863, w = Math.imul(X, le), g = Math.imul(X, de), g = g + Math.imul(J, le) | 0, _2 = Math.imul(J, de), w = w + Math.imul(G, ce) | 0, g = g + Math.imul(G, pe) | 0, g = g + Math.imul(Y, ce) | 0, _2 = _2 + Math.imul(Y, pe) | 0, w = w + Math.imul(V, ve) | 0, g = g + Math.imul(V, be) | 0, g = g + Math.imul($, ve) | 0, _2 = _2 + Math.imul($, be) | 0, w = w + Math.imul(j, Be) | 0, g = g + Math.imul(j, qe) | 0, g = g + Math.imul(Z, Be) | 0, _2 = _2 + Math.imul(Z, qe) | 0;
        var rt = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (rt >>> 26) | 0, rt &= 67108863, w = Math.imul(X, ce), g = Math.imul(X, pe), g = g + Math.imul(J, ce) | 0, _2 = Math.imul(J, pe), w = w + Math.imul(G, ve) | 0, g = g + Math.imul(G, be) | 0, g = g + Math.imul(Y, ve) | 0, _2 = _2 + Math.imul(Y, be) | 0, w = w + Math.imul(V, Be) | 0, g = g + Math.imul(V, qe) | 0, g = g + Math.imul($, Be) | 0, _2 = _2 + Math.imul($, qe) | 0;
        var S0 = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (S0 >>> 26) | 0, S0 &= 67108863, w = Math.imul(X, ve), g = Math.imul(X, be), g = g + Math.imul(J, ve) | 0, _2 = Math.imul(J, be), w = w + Math.imul(G, Be) | 0, g = g + Math.imul(G, qe) | 0, g = g + Math.imul(Y, Be) | 0, _2 = _2 + Math.imul(Y, qe) | 0;
        var E0 = (d + w | 0) + ((g & 8191) << 13) | 0;
        d = (_2 + (g >>> 13) | 0) + (E0 >>> 26) | 0, E0 &= 67108863, w = Math.imul(X, Be), g = Math.imul(X, qe), g = g + Math.imul(J, Be) | 0, _2 = Math.imul(J, qe);
        var A0 = (d + w | 0) + ((g & 8191) << 13) | 0;
        return d = (_2 + (g >>> 13) | 0) + (A0 >>> 26) | 0, A0 &= 67108863, n[0] = ze, n[1] = He, n[2] = We, n[3] = Ke, n[4] = je, n[5] = Ze, n[6] = Ve, n[7] = $e, n[8] = Ge, n[9] = Ye, n[10] = Xe, n[11] = Je, n[12] = Qe, n[13] = et, n[14] = tt, n[15] = rt, n[16] = S0, n[17] = E0, n[18] = A0, d !== 0 && (n[19] = d, c.length++), c;
      };
      Math.imul || (N = _e);
      function we(h2, s, u) {
        u.negative = s.negative ^ h2.negative, u.length = h2.length + s.length;
        for (var c = 0, b2 = 0, l = 0;l < u.length - 1; l++) {
          var n = b2;
          b2 = 0;
          for (var d = c & 67108863, w = Math.min(l, s.length - 1), g = Math.max(0, l - h2.length + 1);g <= w; g++) {
            var _2 = l - g, A2 = h2.words[_2] | 0, R2 = s.words[g] | 0, I = A2 * R2, Me = I & 67108863;
            n = n + (I / 67108864 | 0) | 0, Me = Me + d | 0, d = Me & 67108863, n = n + (Me >>> 26) | 0, b2 += n >>> 26, n &= 67108863;
          }
          u.words[l] = d, c = n, n = b2;
        }
        return c !== 0 ? u.words[l] = c : u.length--, u._strip();
      }
      function ye(h2, s, u) {
        return we(h2, s, u);
      }
      f.prototype.mulTo = function(s, u) {
        var c, b2 = this.length + s.length;
        return this.length === 10 && s.length === 10 ? c = N(this, s, u) : b2 < 63 ? c = _e(this, s, u) : b2 < 1024 ? c = we(this, s, u) : c = ye(this, s, u), c;
      };
      function xe(h2, s) {
        this.x = h2, this.y = s;
      }
      xe.prototype.makeRBT = function(s) {
        for (var u = new Array(s), c = f.prototype._countBits(s) - 1, b2 = 0;b2 < s; b2++)
          u[b2] = this.revBin(b2, c, s);
        return u;
      }, xe.prototype.revBin = function(s, u, c) {
        if (s === 0 || s === c - 1)
          return s;
        for (var b2 = 0, l = 0;l < u; l++)
          b2 |= (s & 1) << u - l - 1, s >>= 1;
        return b2;
      }, xe.prototype.permute = function(s, u, c, b2, l, n) {
        for (var d = 0;d < n; d++)
          b2[d] = u[s[d]], l[d] = c[s[d]];
      }, xe.prototype.transform = function(s, u, c, b2, l, n) {
        this.permute(n, s, u, c, b2, l);
        for (var d = 1;d < l; d <<= 1)
          for (var w = d << 1, g = Math.cos(2 * Math.PI / w), _2 = Math.sin(2 * Math.PI / w), A2 = 0;A2 < l; A2 += w)
            for (var R2 = g, I = _2, Me = 0;Me < d; Me++) {
              var k = c[A2 + Me], D2 = b2[A2 + Me], nt = c[A2 + Me + d], C2 = b2[A2 + Me + d], O = R2 * nt - I * C2;
              C2 = R2 * C2 + I * nt, nt = O, c[A2 + Me] = k + nt, b2[A2 + Me] = D2 + C2, c[A2 + Me + d] = k - nt, b2[A2 + Me + d] = D2 - C2, Me !== w && (O = g * R2 - _2 * I, I = g * I + _2 * R2, R2 = O);
            }
      }, xe.prototype.guessLen13b = function(s, u) {
        var c = Math.max(u, s) | 1, b2 = c & 1, l = 0;
        for (c = c / 2 | 0;c; c = c >>> 1)
          l++;
        return 1 << l + 1 + b2;
      }, xe.prototype.conjugate = function(s, u, c) {
        if (!(c <= 1))
          for (var b2 = 0;b2 < c / 2; b2++) {
            var l = s[b2];
            s[b2] = s[c - b2 - 1], s[c - b2 - 1] = l, l = u[b2], u[b2] = -u[c - b2 - 1], u[c - b2 - 1] = -l;
          }
      }, xe.prototype.normalize13b = function(s, u) {
        for (var c = 0, b2 = 0;b2 < u / 2; b2++) {
          var l = Math.round(s[2 * b2 + 1] / u) * 8192 + Math.round(s[2 * b2] / u) + c;
          s[b2] = l & 67108863, l < 67108864 ? c = 0 : c = l / 67108864 | 0;
        }
        return s;
      }, xe.prototype.convert13b = function(s, u, c, b2) {
        for (var l = 0, n = 0;n < u; n++)
          l = l + (s[n] | 0), c[2 * n] = l & 8191, l = l >>> 13, c[2 * n + 1] = l & 8191, l = l >>> 13;
        for (n = 2 * u;n < b2; ++n)
          c[n] = 0;
        r(l === 0), r((l & -8192) === 0);
      }, xe.prototype.stub = function(s) {
        for (var u = new Array(s), c = 0;c < s; c++)
          u[c] = 0;
        return u;
      }, xe.prototype.mulp = function(s, u, c) {
        var b2 = 2 * this.guessLen13b(s.length, u.length), l = this.makeRBT(b2), n = this.stub(b2), d = new Array(b2), w = new Array(b2), g = new Array(b2), _2 = new Array(b2), A2 = new Array(b2), R2 = new Array(b2), I = c.words;
        I.length = b2, this.convert13b(s.words, s.length, d, b2), this.convert13b(u.words, u.length, _2, b2), this.transform(d, n, w, g, b2, l), this.transform(_2, n, A2, R2, b2, l);
        for (var Me = 0;Me < b2; Me++) {
          var k = w[Me] * A2[Me] - g[Me] * R2[Me];
          g[Me] = w[Me] * R2[Me] + g[Me] * A2[Me], w[Me] = k;
        }
        return this.conjugate(w, g, b2), this.transform(w, g, I, n, b2, l), this.conjugate(I, n, b2), this.normalize13b(I, b2), c.negative = s.negative ^ u.negative, c.length = s.length + u.length, c._strip();
      }, f.prototype.mul = function(s) {
        var u = new f(null);
        return u.words = new Array(this.length + s.length), this.mulTo(s, u);
      }, f.prototype.mulf = function(s) {
        var u = new f(null);
        return u.words = new Array(this.length + s.length), ye(this, s, u);
      }, f.prototype.imul = function(s) {
        return this.clone().mulTo(s, this);
      }, f.prototype.imuln = function(s) {
        var u = s < 0;
        u && (s = -s), r(typeof s == "number"), r(s < 67108864);
        for (var c = 0, b2 = 0;b2 < this.length; b2++) {
          var l = (this.words[b2] | 0) * s, n = (l & 67108863) + (c & 67108863);
          c >>= 26, c += l / 67108864 | 0, c += n >>> 26, this.words[b2] = n & 67108863;
        }
        return c !== 0 && (this.words[b2] = c, this.length++), u ? this.ineg() : this;
      }, f.prototype.muln = function(s) {
        return this.clone().imuln(s);
      }, f.prototype.sqr = function() {
        return this.mul(this);
      }, f.prototype.isqr = function() {
        return this.imul(this.clone());
      }, f.prototype.pow = function(s) {
        var u = ge(s);
        if (u.length === 0)
          return new f(1);
        for (var c = this, b2 = 0;b2 < u.length && u[b2] === 0; b2++, c = c.sqr())
          ;
        if (++b2 < u.length)
          for (var l = c.sqr();b2 < u.length; b2++, l = l.sqr())
            u[b2] !== 0 && (c = c.mul(l));
        return c;
      }, f.prototype.iushln = function(s) {
        r(typeof s == "number" && s >= 0);
        var u = s % 26, c = (s - u) / 26, b2 = 67108863 >>> 26 - u << 26 - u, l;
        if (u !== 0) {
          var n = 0;
          for (l = 0;l < this.length; l++) {
            var d = this.words[l] & b2, w = (this.words[l] | 0) - d << u;
            this.words[l] = w | n, n = d >>> 26 - u;
          }
          n && (this.words[l] = n, this.length++);
        }
        if (c !== 0) {
          for (l = this.length - 1;l >= 0; l--)
            this.words[l + c] = this.words[l];
          for (l = 0;l < c; l++)
            this.words[l] = 0;
          this.length += c;
        }
        return this._strip();
      }, f.prototype.ishln = function(s) {
        return r(this.negative === 0), this.iushln(s);
      }, f.prototype.iushrn = function(s, u, c) {
        r(typeof s == "number" && s >= 0);
        var b2;
        u ? b2 = (u - u % 26) / 26 : b2 = 0;
        var l = s % 26, n = Math.min((s - l) / 26, this.length), d = 67108863 ^ 67108863 >>> l << l, w = c;
        if (b2 -= n, b2 = Math.max(0, b2), w) {
          for (var g = 0;g < n; g++)
            w.words[g] = this.words[g];
          w.length = n;
        }
        if (n !== 0)
          if (this.length > n)
            for (this.length -= n, g = 0;g < this.length; g++)
              this.words[g] = this.words[g + n];
          else
            this.words[0] = 0, this.length = 1;
        var _2 = 0;
        for (g = this.length - 1;g >= 0 && (_2 !== 0 || g >= b2); g--) {
          var A2 = this.words[g] | 0;
          this.words[g] = _2 << 26 - l | A2 >>> l, _2 = A2 & d;
        }
        return w && _2 !== 0 && (w.words[w.length++] = _2), this.length === 0 && (this.words[0] = 0, this.length = 1), this._strip();
      }, f.prototype.ishrn = function(s, u, c) {
        return r(this.negative === 0), this.iushrn(s, u, c);
      }, f.prototype.shln = function(s) {
        return this.clone().ishln(s);
      }, f.prototype.ushln = function(s) {
        return this.clone().iushln(s);
      }, f.prototype.shrn = function(s) {
        return this.clone().ishrn(s);
      }, f.prototype.ushrn = function(s) {
        return this.clone().iushrn(s);
      }, f.prototype.testn = function(s) {
        r(typeof s == "number" && s >= 0);
        var u = s % 26, c = (s - u) / 26, b2 = 1 << u;
        if (this.length <= c)
          return false;
        var l = this.words[c];
        return !!(l & b2);
      }, f.prototype.imaskn = function(s) {
        r(typeof s == "number" && s >= 0);
        var u = s % 26, c = (s - u) / 26;
        if (r(this.negative === 0, "imaskn works only with positive numbers"), this.length <= c)
          return this;
        if (u !== 0 && c++, this.length = Math.min(c, this.length), u !== 0) {
          var b2 = 67108863 ^ 67108863 >>> u << u;
          this.words[this.length - 1] &= b2;
        }
        return this._strip();
      }, f.prototype.maskn = function(s) {
        return this.clone().imaskn(s);
      }, f.prototype.iaddn = function(s) {
        return r(typeof s == "number"), r(s < 67108864), s < 0 ? this.isubn(-s) : this.negative !== 0 ? this.length === 1 && (this.words[0] | 0) <= s ? (this.words[0] = s - (this.words[0] | 0), this.negative = 0, this) : (this.negative = 0, this.isubn(s), this.negative = 1, this) : this._iaddn(s);
      }, f.prototype._iaddn = function(s) {
        this.words[0] += s;
        for (var u = 0;u < this.length && this.words[u] >= 67108864; u++)
          this.words[u] -= 67108864, u === this.length - 1 ? this.words[u + 1] = 1 : this.words[u + 1]++;
        return this.length = Math.max(this.length, u + 1), this;
      }, f.prototype.isubn = function(s) {
        if (r(typeof s == "number"), r(s < 67108864), s < 0)
          return this.iaddn(-s);
        if (this.negative !== 0)
          return this.negative = 0, this.iaddn(s), this.negative = 1, this;
        if (this.words[0] -= s, this.length === 1 && this.words[0] < 0)
          this.words[0] = -this.words[0], this.negative = 1;
        else
          for (var u = 0;u < this.length && this.words[u] < 0; u++)
            this.words[u] += 67108864, this.words[u + 1] -= 1;
        return this._strip();
      }, f.prototype.addn = function(s) {
        return this.clone().iaddn(s);
      }, f.prototype.subn = function(s) {
        return this.clone().isubn(s);
      }, f.prototype.iabs = function() {
        return this.negative = 0, this;
      }, f.prototype.abs = function() {
        return this.clone().iabs();
      }, f.prototype._ishlnsubmul = function(s, u, c) {
        var b2 = s.length + c, l;
        this._expand(b2);
        var n, d = 0;
        for (l = 0;l < s.length; l++) {
          n = (this.words[l + c] | 0) + d;
          var w = (s.words[l] | 0) * u;
          n -= w & 67108863, d = (n >> 26) - (w / 67108864 | 0), this.words[l + c] = n & 67108863;
        }
        for (;l < this.length - c; l++)
          n = (this.words[l + c] | 0) + d, d = n >> 26, this.words[l + c] = n & 67108863;
        if (d === 0)
          return this._strip();
        for (r(d === -1), d = 0, l = 0;l < this.length; l++)
          n = -(this.words[l] | 0) + d, d = n >> 26, this.words[l] = n & 67108863;
        return this.negative = 1, this._strip();
      }, f.prototype._wordDiv = function(s, u) {
        var c = this.length - s.length, b2 = this.clone(), l = s, n = l.words[l.length - 1] | 0, d = this._countBits(n);
        c = 26 - d, c !== 0 && (l = l.ushln(c), b2.iushln(c), n = l.words[l.length - 1] | 0);
        var w = b2.length - l.length, g;
        if (u !== "mod") {
          g = new f(null), g.length = w + 1, g.words = new Array(g.length);
          for (var _2 = 0;_2 < g.length; _2++)
            g.words[_2] = 0;
        }
        var A2 = b2.clone()._ishlnsubmul(l, 1, w);
        A2.negative === 0 && (b2 = A2, g && (g.words[w] = 1));
        for (var R2 = w - 1;R2 >= 0; R2--) {
          var I = (b2.words[l.length + R2] | 0) * 67108864 + (b2.words[l.length + R2 - 1] | 0);
          for (I = Math.min(I / n | 0, 67108863), b2._ishlnsubmul(l, I, R2);b2.negative !== 0; )
            I--, b2.negative = 0, b2._ishlnsubmul(l, 1, R2), b2.isZero() || (b2.negative ^= 1);
          g && (g.words[R2] = I);
        }
        return g && g._strip(), b2._strip(), u !== "div" && c !== 0 && b2.iushrn(c), { div: g || null, mod: b2 };
      }, f.prototype.divmod = function(s, u, c) {
        if (r(!s.isZero()), this.isZero())
          return { div: new f(0), mod: new f(0) };
        var b2, l, n;
        return this.negative !== 0 && s.negative === 0 ? (n = this.neg().divmod(s, u), u !== "mod" && (b2 = n.div.neg()), u !== "div" && (l = n.mod.neg(), c && l.negative !== 0 && l.iadd(s)), { div: b2, mod: l }) : this.negative === 0 && s.negative !== 0 ? (n = this.divmod(s.neg(), u), u !== "mod" && (b2 = n.div.neg()), { div: b2, mod: n.mod }) : (this.negative & s.negative) !== 0 ? (n = this.neg().divmod(s.neg(), u), u !== "div" && (l = n.mod.neg(), c && l.negative !== 0 && l.isub(s)), { div: n.div, mod: l }) : s.length > this.length || this.cmp(s) < 0 ? { div: new f(0), mod: this } : s.length === 1 ? u === "div" ? { div: this.divn(s.words[0]), mod: null } : u === "mod" ? { div: null, mod: new f(this.modrn(s.words[0])) } : { div: this.divn(s.words[0]), mod: new f(this.modrn(s.words[0])) } : this._wordDiv(s, u);
      }, f.prototype.div = function(s) {
        return this.divmod(s, "div", false).div;
      }, f.prototype.mod = function(s) {
        return this.divmod(s, "mod", false).mod;
      }, f.prototype.umod = function(s) {
        return this.divmod(s, "mod", true).mod;
      }, f.prototype.divRound = function(s) {
        var u = this.divmod(s);
        if (u.mod.isZero())
          return u.div;
        var c = u.div.negative !== 0 ? u.mod.isub(s) : u.mod, b2 = s.ushrn(1), l = s.andln(1), n = c.cmp(b2);
        return n < 0 || l === 1 && n === 0 ? u.div : u.div.negative !== 0 ? u.div.isubn(1) : u.div.iaddn(1);
      }, f.prototype.modrn = function(s) {
        var u = s < 0;
        u && (s = -s), r(s <= 67108863);
        for (var c = (1 << 26) % s, b2 = 0, l = this.length - 1;l >= 0; l--)
          b2 = (c * b2 + (this.words[l] | 0)) % s;
        return u ? -b2 : b2;
      }, f.prototype.modn = function(s) {
        return this.modrn(s);
      }, f.prototype.idivn = function(s) {
        var u = s < 0;
        u && (s = -s), r(s <= 67108863);
        for (var c = 0, b2 = this.length - 1;b2 >= 0; b2--) {
          var l = (this.words[b2] | 0) + c * 67108864;
          this.words[b2] = l / s | 0, c = l % s;
        }
        return this._strip(), u ? this.ineg() : this;
      }, f.prototype.divn = function(s) {
        return this.clone().idivn(s);
      }, f.prototype.egcd = function(s) {
        r(s.negative === 0), r(!s.isZero());
        var u = this, c = s.clone();
        u.negative !== 0 ? u = u.umod(s) : u = u.clone();
        for (var b2 = new f(1), l = new f(0), n = new f(0), d = new f(1), w = 0;u.isEven() && c.isEven(); )
          u.iushrn(1), c.iushrn(1), ++w;
        for (var g = c.clone(), _2 = u.clone();!u.isZero(); ) {
          for (var A2 = 0, R2 = 1;(u.words[0] & R2) === 0 && A2 < 26; ++A2, R2 <<= 1)
            ;
          if (A2 > 0)
            for (u.iushrn(A2);A2-- > 0; )
              (b2.isOdd() || l.isOdd()) && (b2.iadd(g), l.isub(_2)), b2.iushrn(1), l.iushrn(1);
          for (var I = 0, Me = 1;(c.words[0] & Me) === 0 && I < 26; ++I, Me <<= 1)
            ;
          if (I > 0)
            for (c.iushrn(I);I-- > 0; )
              (n.isOdd() || d.isOdd()) && (n.iadd(g), d.isub(_2)), n.iushrn(1), d.iushrn(1);
          u.cmp(c) >= 0 ? (u.isub(c), b2.isub(n), l.isub(d)) : (c.isub(u), n.isub(b2), d.isub(l));
        }
        return { a: n, b: d, gcd: c.iushln(w) };
      }, f.prototype._invmp = function(s) {
        r(s.negative === 0), r(!s.isZero());
        var u = this, c = s.clone();
        u.negative !== 0 ? u = u.umod(s) : u = u.clone();
        for (var b2 = new f(1), l = new f(0), n = c.clone();u.cmpn(1) > 0 && c.cmpn(1) > 0; ) {
          for (var d = 0, w = 1;(u.words[0] & w) === 0 && d < 26; ++d, w <<= 1)
            ;
          if (d > 0)
            for (u.iushrn(d);d-- > 0; )
              b2.isOdd() && b2.iadd(n), b2.iushrn(1);
          for (var g = 0, _2 = 1;(c.words[0] & _2) === 0 && g < 26; ++g, _2 <<= 1)
            ;
          if (g > 0)
            for (c.iushrn(g);g-- > 0; )
              l.isOdd() && l.iadd(n), l.iushrn(1);
          u.cmp(c) >= 0 ? (u.isub(c), b2.isub(l)) : (c.isub(u), l.isub(b2));
        }
        var A2;
        return u.cmpn(1) === 0 ? A2 = b2 : A2 = l, A2.cmpn(0) < 0 && A2.iadd(s), A2;
      }, f.prototype.gcd = function(s) {
        if (this.isZero())
          return s.abs();
        if (s.isZero())
          return this.abs();
        var u = this.clone(), c = s.clone();
        u.negative = 0, c.negative = 0;
        for (var b2 = 0;u.isEven() && c.isEven(); b2++)
          u.iushrn(1), c.iushrn(1);
        do {
          for (;u.isEven(); )
            u.iushrn(1);
          for (;c.isEven(); )
            c.iushrn(1);
          var l = u.cmp(c);
          if (l < 0) {
            var n = u;
            u = c, c = n;
          } else if (l === 0 || c.cmpn(1) === 0)
            break;
          u.isub(c);
        } while (true);
        return c.iushln(b2);
      }, f.prototype.invm = function(s) {
        return this.egcd(s).a.umod(s);
      }, f.prototype.isEven = function() {
        return (this.words[0] & 1) === 0;
      }, f.prototype.isOdd = function() {
        return (this.words[0] & 1) === 1;
      }, f.prototype.andln = function(s) {
        return this.words[0] & s;
      }, f.prototype.bincn = function(s) {
        r(typeof s == "number");
        var u = s % 26, c = (s - u) / 26, b2 = 1 << u;
        if (this.length <= c)
          return this._expand(c + 1), this.words[c] |= b2, this;
        for (var l = b2, n = c;l !== 0 && n < this.length; n++) {
          var d = this.words[n] | 0;
          d += l, l = d >>> 26, d &= 67108863, this.words[n] = d;
        }
        return l !== 0 && (this.words[n] = l, this.length++), this;
      }, f.prototype.isZero = function() {
        return this.length === 1 && this.words[0] === 0;
      }, f.prototype.cmpn = function(s) {
        var u = s < 0;
        if (this.negative !== 0 && !u)
          return -1;
        if (this.negative === 0 && u)
          return 1;
        this._strip();
        var c;
        if (this.length > 1)
          c = 1;
        else {
          u && (s = -s), r(s <= 67108863, "Number is too big");
          var b2 = this.words[0] | 0;
          c = b2 === s ? 0 : b2 < s ? -1 : 1;
        }
        return this.negative !== 0 ? -c | 0 : c;
      }, f.prototype.cmp = function(s) {
        if (this.negative !== 0 && s.negative === 0)
          return -1;
        if (this.negative === 0 && s.negative !== 0)
          return 1;
        var u = this.ucmp(s);
        return this.negative !== 0 ? -u | 0 : u;
      }, f.prototype.ucmp = function(s) {
        if (this.length > s.length)
          return 1;
        if (this.length < s.length)
          return -1;
        for (var u = 0, c = this.length - 1;c >= 0; c--) {
          var b2 = this.words[c] | 0, l = s.words[c] | 0;
          if (b2 !== l) {
            b2 < l ? u = -1 : b2 > l && (u = 1);
            break;
          }
        }
        return u;
      }, f.prototype.gtn = function(s) {
        return this.cmpn(s) === 1;
      }, f.prototype.gt = function(s) {
        return this.cmp(s) === 1;
      }, f.prototype.gten = function(s) {
        return this.cmpn(s) >= 0;
      }, f.prototype.gte = function(s) {
        return this.cmp(s) >= 0;
      }, f.prototype.ltn = function(s) {
        return this.cmpn(s) === -1;
      }, f.prototype.lt = function(s) {
        return this.cmp(s) === -1;
      }, f.prototype.lten = function(s) {
        return this.cmpn(s) <= 0;
      }, f.prototype.lte = function(s) {
        return this.cmp(s) <= 0;
      }, f.prototype.eqn = function(s) {
        return this.cmpn(s) === 0;
      }, f.prototype.eq = function(s) {
        return this.cmp(s) === 0;
      }, f.red = function(s) {
        return new i(s);
      }, f.prototype.toRed = function(s) {
        return r(!this.red, "Already a number in reduction context"), r(this.negative === 0, "red works only with positives"), s.convertTo(this)._forceRed(s);
      }, f.prototype.fromRed = function() {
        return r(this.red, "fromRed works only with numbers in reduction context"), this.red.convertFrom(this);
      }, f.prototype._forceRed = function(s) {
        return this.red = s, this;
      }, f.prototype.forceRed = function(s) {
        return r(!this.red, "Already a number in reduction context"), this._forceRed(s);
      }, f.prototype.redAdd = function(s) {
        return r(this.red, "redAdd works only with red numbers"), this.red.add(this, s);
      }, f.prototype.redIAdd = function(s) {
        return r(this.red, "redIAdd works only with red numbers"), this.red.iadd(this, s);
      }, f.prototype.redSub = function(s) {
        return r(this.red, "redSub works only with red numbers"), this.red.sub(this, s);
      }, f.prototype.redISub = function(s) {
        return r(this.red, "redISub works only with red numbers"), this.red.isub(this, s);
      }, f.prototype.redShl = function(s) {
        return r(this.red, "redShl works only with red numbers"), this.red.shl(this, s);
      }, f.prototype.redMul = function(s) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, s), this.red.mul(this, s);
      }, f.prototype.redIMul = function(s) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, s), this.red.imul(this, s);
      }, f.prototype.redSqr = function() {
        return r(this.red, "redSqr works only with red numbers"), this.red._verify1(this), this.red.sqr(this);
      }, f.prototype.redISqr = function() {
        return r(this.red, "redISqr works only with red numbers"), this.red._verify1(this), this.red.isqr(this);
      }, f.prototype.redSqrt = function() {
        return r(this.red, "redSqrt works only with red numbers"), this.red._verify1(this), this.red.sqrt(this);
      }, f.prototype.redInvm = function() {
        return r(this.red, "redInvm works only with red numbers"), this.red._verify1(this), this.red.invm(this);
      }, f.prototype.redNeg = function() {
        return r(this.red, "redNeg works only with red numbers"), this.red._verify1(this), this.red.neg(this);
      }, f.prototype.redPow = function(s) {
        return r(this.red && !s.red, "redPow(normalNum)"), this.red._verify1(this), this.red.pow(this, s);
      };
      var Re = { k256: null, p224: null, p192: null, p25519: null };
      function Ee(h2, s) {
        this.name = h2, this.p = new f(s, 16), this.n = this.p.bitLength(), this.k = new f(1).iushln(this.n).isub(this.p), this.tmp = this._tmp();
      }
      Ee.prototype._tmp = function() {
        var s = new f(null);
        return s.words = new Array(Math.ceil(this.n / 13)), s;
      }, Ee.prototype.ireduce = function(s) {
        var u = s, c;
        do
          this.split(u, this.tmp), u = this.imulK(u), u = u.iadd(this.tmp), c = u.bitLength();
        while (c > this.n);
        var b2 = c < this.n ? -1 : u.ucmp(this.p);
        return b2 === 0 ? (u.words[0] = 0, u.length = 1) : b2 > 0 ? u.isub(this.p) : u.strip !== undefined ? u.strip() : u._strip(), u;
      }, Ee.prototype.split = function(s, u) {
        s.iushrn(this.n, 0, u);
      }, Ee.prototype.imulK = function(s) {
        return s.imul(this.k);
      };
      function Ae() {
        Ee.call(this, "k256", "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f");
      }
      o(Ae, Ee), Ae.prototype.split = function(s, u) {
        for (var c = 4194303, b2 = Math.min(s.length, 9), l = 0;l < b2; l++)
          u.words[l] = s.words[l];
        if (u.length = b2, s.length <= 9) {
          s.words[0] = 0, s.length = 1;
          return;
        }
        var n = s.words[9];
        for (u.words[u.length++] = n & c, l = 10;l < s.length; l++) {
          var d = s.words[l] | 0;
          s.words[l - 10] = (d & c) << 4 | n >>> 22, n = d;
        }
        n >>>= 22, s.words[l - 10] = n, n === 0 && s.length > 10 ? s.length -= 10 : s.length -= 9;
      }, Ae.prototype.imulK = function(s) {
        s.words[s.length] = 0, s.words[s.length + 1] = 0, s.length += 2;
        for (var u = 0, c = 0;c < s.length; c++) {
          var b2 = s.words[c] | 0;
          u += b2 * 977, s.words[c] = u & 67108863, u = b2 * 64 + (u / 67108864 | 0);
        }
        return s.words[s.length - 1] === 0 && (s.length--, s.words[s.length - 1] === 0 && s.length--), s;
      };
      function P() {
        Ee.call(this, "p224", "ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001");
      }
      o(P, Ee);
      function Se() {
        Ee.call(this, "p192", "ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff");
      }
      o(Se, Ee);
      function v() {
        Ee.call(this, "25519", "7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed");
      }
      o(v, Ee), v.prototype.imulK = function(s) {
        for (var u = 0, c = 0;c < s.length; c++) {
          var b2 = (s.words[c] | 0) * 19 + u, l = b2 & 67108863;
          b2 >>>= 26, s.words[c] = l, u = b2;
        }
        return u !== 0 && (s.words[s.length++] = u), s;
      }, f._prime = function(s) {
        if (Re[s])
          return Re[s];
        var u;
        if (s === "k256")
          u = new Ae;
        else if (s === "p224")
          u = new P;
        else if (s === "p192")
          u = new Se;
        else if (s === "p25519")
          u = new v;
        else
          throw new Error("Unknown prime " + s);
        return Re[s] = u, u;
      };
      function i(h2) {
        if (typeof h2 == "string") {
          var s = f._prime(h2);
          this.m = s.p, this.prime = s;
        } else
          r(h2.gtn(1), "modulus must be greater than 1"), this.m = h2, this.prime = null;
      }
      i.prototype._verify1 = function(s) {
        r(s.negative === 0, "red works only with positives"), r(s.red, "red works only with red numbers");
      }, i.prototype._verify2 = function(s, u) {
        r((s.negative | u.negative) === 0, "red works only with positives"), r(s.red && s.red === u.red, "red works only with red numbers");
      }, i.prototype.imod = function(s) {
        return this.prime ? this.prime.ireduce(s)._forceRed(this) : (x(s, s.umod(this.m)._forceRed(this)), s);
      }, i.prototype.neg = function(s) {
        return s.isZero() ? s.clone() : this.m.sub(s)._forceRed(this);
      }, i.prototype.add = function(s, u) {
        this._verify2(s, u);
        var c = s.add(u);
        return c.cmp(this.m) >= 0 && c.isub(this.m), c._forceRed(this);
      }, i.prototype.iadd = function(s, u) {
        this._verify2(s, u);
        var c = s.iadd(u);
        return c.cmp(this.m) >= 0 && c.isub(this.m), c;
      }, i.prototype.sub = function(s, u) {
        this._verify2(s, u);
        var c = s.sub(u);
        return c.cmpn(0) < 0 && c.iadd(this.m), c._forceRed(this);
      }, i.prototype.isub = function(s, u) {
        this._verify2(s, u);
        var c = s.isub(u);
        return c.cmpn(0) < 0 && c.iadd(this.m), c;
      }, i.prototype.shl = function(s, u) {
        return this._verify1(s), this.imod(s.ushln(u));
      }, i.prototype.imul = function(s, u) {
        return this._verify2(s, u), this.imod(s.imul(u));
      }, i.prototype.mul = function(s, u) {
        return this._verify2(s, u), this.imod(s.mul(u));
      }, i.prototype.isqr = function(s) {
        return this.imul(s, s.clone());
      }, i.prototype.sqr = function(s) {
        return this.mul(s, s);
      }, i.prototype.sqrt = function(s) {
        if (s.isZero())
          return s.clone();
        var u = this.m.andln(3);
        if (r(u % 2 === 1), u === 3) {
          var c = this.m.add(new f(1)).iushrn(2);
          return this.pow(s, c);
        }
        for (var b2 = this.m.subn(1), l = 0;!b2.isZero() && b2.andln(1) === 0; )
          l++, b2.iushrn(1);
        r(!b2.isZero());
        var n = new f(1).toRed(this), d = n.redNeg(), w = this.m.subn(1).iushrn(1), g = this.m.bitLength();
        for (g = new f(2 * g * g).toRed(this);this.pow(g, w).cmp(d) !== 0; )
          g.redIAdd(d);
        for (var _2 = this.pow(g, b2), A2 = this.pow(s, b2.addn(1).iushrn(1)), R2 = this.pow(s, b2), I = l;R2.cmp(n) !== 0; ) {
          for (var Me = R2, k = 0;Me.cmp(n) !== 0; k++)
            Me = Me.redSqr();
          r(k < I);
          var D2 = this.pow(_2, new f(1).iushln(I - k - 1));
          A2 = A2.redMul(D2), _2 = D2.redSqr(), R2 = R2.redMul(_2), I = k;
        }
        return A2;
      }, i.prototype.invm = function(s) {
        var u = s._invmp(this.m);
        return u.negative !== 0 ? (u.negative = 0, this.imod(u).redNeg()) : this.imod(u);
      }, i.prototype.pow = function(s, u) {
        if (u.isZero())
          return new f(1).toRed(this);
        if (u.cmpn(1) === 0)
          return s.clone();
        var c = 4, b2 = new Array(1 << c);
        b2[0] = new f(1).toRed(this), b2[1] = s;
        for (var l = 2;l < b2.length; l++)
          b2[l] = this.mul(b2[l - 1], s);
        var n = b2[0], d = 0, w = 0, g = u.bitLength() % 26;
        for (g === 0 && (g = 26), l = u.length - 1;l >= 0; l--) {
          for (var _2 = u.words[l], A2 = g - 1;A2 >= 0; A2--) {
            var R2 = _2 >> A2 & 1;
            if (n !== b2[0] && (n = this.sqr(n)), R2 === 0 && d === 0) {
              w = 0;
              continue;
            }
            d <<= 1, d |= R2, w++, !(w !== c && (l !== 0 || A2 !== 0)) && (n = this.mul(n, b2[d]), w = 0, d = 0);
          }
          g = 26;
        }
        return n;
      }, i.prototype.convertTo = function(s) {
        var u = s.umod(this.m);
        return u === s ? u.clone() : u;
      }, i.prototype.convertFrom = function(s) {
        var u = s.clone();
        return u.red = null, u;
      }, f.mont = function(s) {
        return new a(s);
      };
      function a(h2) {
        i.call(this, h2), this.shift = this.m.bitLength(), this.shift % 26 !== 0 && (this.shift += 26 - this.shift % 26), this.r = new f(1).iushln(this.shift), this.r2 = this.imod(this.r.sqr()), this.rinv = this.r._invmp(this.m), this.minv = this.rinv.mul(this.r).isubn(1).div(this.m), this.minv = this.minv.umod(this.r), this.minv = this.r.sub(this.minv);
      }
      o(a, i), a.prototype.convertTo = function(s) {
        return this.imod(s.ushln(this.shift));
      }, a.prototype.convertFrom = function(s) {
        var u = this.imod(s.mul(this.rinv));
        return u.red = null, u;
      }, a.prototype.imul = function(s, u) {
        if (s.isZero() || u.isZero())
          return s.words[0] = 0, s.length = 1, s;
        var c = s.imul(u), b2 = c.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), l = c.isub(b2).iushrn(this.shift), n = l;
        return l.cmp(this.m) >= 0 ? n = l.isub(this.m) : l.cmpn(0) < 0 && (n = l.iadd(this.m)), n._forceRed(this);
      }, a.prototype.mul = function(s, u) {
        if (s.isZero() || u.isZero())
          return new f(0)._forceRed(this);
        var c = s.mul(u), b2 = c.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), l = c.isub(b2).iushrn(this.shift), n = l;
        return l.cmp(this.m) >= 0 ? n = l.isub(this.m) : l.cmpn(0) < 0 && (n = l.iadd(this.m)), n._forceRed(this);
      }, a.prototype.invm = function(s) {
        var u = this.imod(s._invmp(this.m).mul(this.r2));
        return u._forceRed(this);
      };
    })(typeof kl > "u" || kl, n2);
  });
  Ks = T2((yk, o2) => {
    var Rf = Ws(), oA = on();
    function sA(t) {
      var e = f2(t), r = e.toRed(Rf.mont(t.modulus)).redPow(new Rf(t.publicExponent)).fromRed();
      return { blinder: r, unblinder: e.invm(t.modulus) };
    }
    function f2(t) {
      var e = t.modulus.byteLength(), r;
      do
        r = new Rf(oA(e));
      while (r.cmp(t.modulus) >= 0 || !r.umod(t.prime1) || !r.umod(t.prime2));
      return r;
    }
    function a2(t, e) {
      var r = sA(e), o = e.modulus.byteLength(), f = new Rf(t).mul(r.blinder).umod(e.modulus), p = f.toRed(Rf.mont(e.prime1)), m2 = f.toRed(Rf.mont(e.prime2)), y2 = e.coefficient, M = e.prime1, x = e.prime2, S = p.redPow(e.exponent1).fromRed(), E2 = m2.redPow(e.exponent2).fromRed(), B = S.isub(E2).imul(y2).umod(M).imul(x);
      return E2.iadd(B).imul(r.unblinder).umod(e.modulus).toArrayLike(Buffer, "be", o);
    }
    a2.getr = f2;
    o2.exports = a2;
  });
  s2 = T2((wk, hA) => {
    hA.exports = { name: "elliptic", version: "6.5.4", description: "EC cryptography", main: "lib/elliptic.js", files: ["lib"], scripts: { lint: "eslint lib test", "lint:fix": "npm run lint -- --fix", unit: "istanbul test _mocha --reporter=spec test/index.js", test: "npm run lint && npm run unit", version: "grunt dist && git add dist/" }, repository: { type: "git", url: "git@github.com:indutny/elliptic" }, keywords: ["EC", "Elliptic", "curve", "Cryptography"], author: "Fedor Indutny <fedor@indutny.com>", license: "MIT", bugs: { url: "https://github.com/indutny/elliptic/issues" }, homepage: "https://github.com/indutny/elliptic", devDependencies: { brfs: "^2.0.2", coveralls: "^3.1.0", eslint: "^7.6.0", grunt: "^1.2.1", "grunt-browserify": "^5.3.0", "grunt-cli": "^1.3.2", "grunt-contrib-connect": "^3.0.0", "grunt-contrib-copy": "^1.0.0", "grunt-contrib-uglify": "^5.0.0", "grunt-mocha-istanbul": "^5.0.2", "grunt-saucelabs": "^9.0.1", istanbul: "^0.4.5", mocha: "^8.0.1" }, dependencies: { "bn.js": "^4.11.9", brorand: "^1.1.0", "hash.js": "^1.0.0", "hmac-drbg": "^1.0.1", inherits: "^2.0.4", "minimalistic-assert": "^1.0.1", "minimalistic-crypto-utils": "^1.0.1" } };
  });
  ri = T2((h2, Ll) => {
    (function(t, e) {
      function r(v, i) {
        if (!v)
          throw new Error(i || "Assertion failed");
      }
      function o(v, i) {
        v.super_ = i;
        var a = function() {
        };
        a.prototype = i.prototype, v.prototype = new a, v.prototype.constructor = v;
      }
      function f(v, i, a) {
        if (f.isBN(v))
          return v;
        this.negative = 0, this.words = null, this.length = 0, this.red = null, v !== null && ((i === "le" || i === "be") && (a = i, i = 10), this._init(v || 0, i || 10, a || "be"));
      }
      typeof t == "object" ? t.exports = f : e.BN = f, f.BN = f, f.wordSize = 26;
      var p;
      try {
        typeof window < "u" && typeof window.Buffer < "u" ? p = window.Buffer : p = ji().Buffer;
      } catch {
      }
      f.isBN = function(i) {
        return i instanceof f ? true : i !== null && typeof i == "object" && i.constructor.wordSize === f.wordSize && Array.isArray(i.words);
      }, f.max = function(i, a) {
        return i.cmp(a) > 0 ? i : a;
      }, f.min = function(i, a) {
        return i.cmp(a) < 0 ? i : a;
      }, f.prototype._init = function(i, a, h3) {
        if (typeof i == "number")
          return this._initNumber(i, a, h3);
        if (typeof i == "object")
          return this._initArray(i, a, h3);
        a === "hex" && (a = 16), r(a === (a | 0) && a >= 2 && a <= 36), i = i.toString().replace(/\s+/g, "");
        var s = 0;
        i[0] === "-" && (s++, this.negative = 1), s < i.length && (a === 16 ? this._parseHex(i, s, h3) : (this._parseBase(i, a, s), h3 === "le" && this._initArray(this.toArray(), a, h3)));
      }, f.prototype._initNumber = function(i, a, h3) {
        i < 0 && (this.negative = 1, i = -i), i < 67108864 ? (this.words = [i & 67108863], this.length = 1) : i < 4503599627370496 ? (this.words = [i & 67108863, i / 67108864 & 67108863], this.length = 2) : (r(i < 9007199254740992), this.words = [i & 67108863, i / 67108864 & 67108863, 1], this.length = 3), h3 === "le" && this._initArray(this.toArray(), a, h3);
      }, f.prototype._initArray = function(i, a, h3) {
        if (r(typeof i.length == "number"), i.length <= 0)
          return this.words = [0], this.length = 1, this;
        this.length = Math.ceil(i.length / 3), this.words = new Array(this.length);
        for (var s = 0;s < this.length; s++)
          this.words[s] = 0;
        var u, c, b2 = 0;
        if (h3 === "be")
          for (s = i.length - 1, u = 0;s >= 0; s -= 3)
            c = i[s] | i[s - 1] << 8 | i[s - 2] << 16, this.words[u] |= c << b2 & 67108863, this.words[u + 1] = c >>> 26 - b2 & 67108863, b2 += 24, b2 >= 26 && (b2 -= 26, u++);
        else if (h3 === "le")
          for (s = 0, u = 0;s < i.length; s += 3)
            c = i[s] | i[s + 1] << 8 | i[s + 2] << 16, this.words[u] |= c << b2 & 67108863, this.words[u + 1] = c >>> 26 - b2 & 67108863, b2 += 24, b2 >= 26 && (b2 -= 26, u++);
        return this.strip();
      };
      function m2(v, i) {
        var a = v.charCodeAt(i);
        return a >= 65 && a <= 70 ? a - 55 : a >= 97 && a <= 102 ? a - 87 : a - 48 & 15;
      }
      function y2(v, i, a) {
        var h3 = m2(v, a);
        return a - 1 >= i && (h3 |= m2(v, a - 1) << 4), h3;
      }
      f.prototype._parseHex = function(i, a, h3) {
        this.length = Math.ceil((i.length - a) / 6), this.words = new Array(this.length);
        for (var s = 0;s < this.length; s++)
          this.words[s] = 0;
        var u = 0, c = 0, b2;
        if (h3 === "be")
          for (s = i.length - 1;s >= a; s -= 2)
            b2 = y2(i, a, s) << u, this.words[c] |= b2 & 67108863, u >= 18 ? (u -= 18, c += 1, this.words[c] |= b2 >>> 26) : u += 8;
        else {
          var l = i.length - a;
          for (s = l % 2 === 0 ? a + 1 : a;s < i.length; s += 2)
            b2 = y2(i, a, s) << u, this.words[c] |= b2 & 67108863, u >= 18 ? (u -= 18, c += 1, this.words[c] |= b2 >>> 26) : u += 8;
        }
        this.strip();
      };
      function M(v, i, a, h3) {
        for (var s = 0, u = Math.min(v.length, a), c = i;c < u; c++) {
          var b2 = v.charCodeAt(c) - 48;
          s *= h3, b2 >= 49 ? s += b2 - 49 + 10 : b2 >= 17 ? s += b2 - 17 + 10 : s += b2;
        }
        return s;
      }
      f.prototype._parseBase = function(i, a, h3) {
        this.words = [0], this.length = 1;
        for (var s = 0, u = 1;u <= 67108863; u *= a)
          s++;
        s--, u = u / a | 0;
        for (var c = i.length - h3, b2 = c % s, l = Math.min(c, c - b2) + h3, n = 0, d = h3;d < l; d += s)
          n = M(i, d, d + s, a), this.imuln(u), this.words[0] + n < 67108864 ? this.words[0] += n : this._iaddn(n);
        if (b2 !== 0) {
          var w = 1;
          for (n = M(i, d, i.length, a), d = 0;d < b2; d++)
            w *= a;
          this.imuln(w), this.words[0] + n < 67108864 ? this.words[0] += n : this._iaddn(n);
        }
        this.strip();
      }, f.prototype.copy = function(i) {
        i.words = new Array(this.length);
        for (var a = 0;a < this.length; a++)
          i.words[a] = this.words[a];
        i.length = this.length, i.negative = this.negative, i.red = this.red;
      }, f.prototype.clone = function() {
        var i = new f(null);
        return this.copy(i), i;
      }, f.prototype._expand = function(i) {
        for (;this.length < i; )
          this.words[this.length++] = 0;
        return this;
      }, f.prototype.strip = function() {
        for (;this.length > 1 && this.words[this.length - 1] === 0; )
          this.length--;
        return this._normSign();
      }, f.prototype._normSign = function() {
        return this.length === 1 && this.words[0] === 0 && (this.negative = 0), this;
      }, f.prototype.inspect = function() {
        return (this.red ? "<BN-R: " : "<BN: ") + this.toString(16) + ">";
      };
      var x = ["", "0", "00", "000", "0000", "00000", "000000", "0000000", "00000000", "000000000", "0000000000", "00000000000", "000000000000", "0000000000000", "00000000000000", "000000000000000", "0000000000000000", "00000000000000000", "000000000000000000", "0000000000000000000", "00000000000000000000", "000000000000000000000", "0000000000000000000000", "00000000000000000000000", "000000000000000000000000", "0000000000000000000000000"], S = [0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5], E2 = [0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 1e7, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176];
      f.prototype.toString = function(i, a) {
        i = i || 10, a = a | 0 || 1;
        var h3;
        if (i === 16 || i === "hex") {
          h3 = "";
          for (var s = 0, u = 0, c = 0;c < this.length; c++) {
            var b2 = this.words[c], l = ((b2 << s | u) & 16777215).toString(16);
            u = b2 >>> 24 - s & 16777215, u !== 0 || c !== this.length - 1 ? h3 = x[6 - l.length] + l + h3 : h3 = l + h3, s += 2, s >= 26 && (s -= 26, c--);
          }
          for (u !== 0 && (h3 = u.toString(16) + h3);h3.length % a !== 0; )
            h3 = "0" + h3;
          return this.negative !== 0 && (h3 = "-" + h3), h3;
        }
        if (i === (i | 0) && i >= 2 && i <= 36) {
          var n = S[i], d = E2[i];
          h3 = "";
          var w = this.clone();
          for (w.negative = 0;!w.isZero(); ) {
            var g = w.modn(d).toString(i);
            w = w.idivn(d), w.isZero() ? h3 = g + h3 : h3 = x[n - g.length] + g + h3;
          }
          for (this.isZero() && (h3 = "0" + h3);h3.length % a !== 0; )
            h3 = "0" + h3;
          return this.negative !== 0 && (h3 = "-" + h3), h3;
        }
        r(false, "Base should be between 2 and 36");
      }, f.prototype.toNumber = function() {
        var i = this.words[0];
        return this.length === 2 ? i += this.words[1] * 67108864 : this.length === 3 && this.words[2] === 1 ? i += 4503599627370496 + this.words[1] * 67108864 : this.length > 2 && r(false, "Number can only safely store up to 53 bits"), this.negative !== 0 ? -i : i;
      }, f.prototype.toJSON = function() {
        return this.toString(16);
      }, f.prototype.toBuffer = function(i, a) {
        return r(typeof p < "u"), this.toArrayLike(p, i, a);
      }, f.prototype.toArray = function(i, a) {
        return this.toArrayLike(Array, i, a);
      }, f.prototype.toArrayLike = function(i, a, h3) {
        var s = this.byteLength(), u = h3 || Math.max(1, s);
        r(s <= u, "byte array longer than desired length"), r(u > 0, "Requested array length <= 0"), this.strip();
        var c = a === "le", b2 = new i(u), l, n, d = this.clone();
        if (c) {
          for (n = 0;!d.isZero(); n++)
            l = d.andln(255), d.iushrn(8), b2[n] = l;
          for (;n < u; n++)
            b2[n] = 0;
        } else {
          for (n = 0;n < u - s; n++)
            b2[n] = 0;
          for (n = 0;!d.isZero(); n++)
            l = d.andln(255), d.iushrn(8), b2[u - n - 1] = l;
        }
        return b2;
      }, Math.clz32 ? f.prototype._countBits = function(i) {
        return 32 - Math.clz32(i);
      } : f.prototype._countBits = function(i) {
        var a = i, h3 = 0;
        return a >= 4096 && (h3 += 13, a >>>= 13), a >= 64 && (h3 += 7, a >>>= 7), a >= 8 && (h3 += 4, a >>>= 4), a >= 2 && (h3 += 2, a >>>= 2), h3 + a;
      }, f.prototype._zeroBits = function(i) {
        if (i === 0)
          return 26;
        var a = i, h3 = 0;
        return (a & 8191) === 0 && (h3 += 13, a >>>= 13), (a & 127) === 0 && (h3 += 7, a >>>= 7), (a & 15) === 0 && (h3 += 4, a >>>= 4), (a & 3) === 0 && (h3 += 2, a >>>= 2), (a & 1) === 0 && h3++, h3;
      }, f.prototype.bitLength = function() {
        var i = this.words[this.length - 1], a = this._countBits(i);
        return (this.length - 1) * 26 + a;
      };
      function B(v) {
        for (var i = new Array(v.bitLength()), a = 0;a < i.length; a++) {
          var h3 = a / 26 | 0, s = a % 26;
          i[a] = (v.words[h3] & 1 << s) >>> s;
        }
        return i;
      }
      f.prototype.zeroBits = function() {
        if (this.isZero())
          return 0;
        for (var i = 0, a = 0;a < this.length; a++) {
          var h3 = this._zeroBits(this.words[a]);
          if (i += h3, h3 !== 26)
            break;
        }
        return i;
      }, f.prototype.byteLength = function() {
        return Math.ceil(this.bitLength() / 8);
      }, f.prototype.toTwos = function(i) {
        return this.negative !== 0 ? this.abs().inotn(i).iaddn(1) : this.clone();
      }, f.prototype.fromTwos = function(i) {
        return this.testn(i - 1) ? this.notn(i).iaddn(1).ineg() : this.clone();
      }, f.prototype.isNeg = function() {
        return this.negative !== 0;
      }, f.prototype.neg = function() {
        return this.clone().ineg();
      }, f.prototype.ineg = function() {
        return this.isZero() || (this.negative ^= 1), this;
      }, f.prototype.iuor = function(i) {
        for (;this.length < i.length; )
          this.words[this.length++] = 0;
        for (var a = 0;a < i.length; a++)
          this.words[a] = this.words[a] | i.words[a];
        return this.strip();
      }, f.prototype.ior = function(i) {
        return r((this.negative | i.negative) === 0), this.iuor(i);
      }, f.prototype.or = function(i) {
        return this.length > i.length ? this.clone().ior(i) : i.clone().ior(this);
      }, f.prototype.uor = function(i) {
        return this.length > i.length ? this.clone().iuor(i) : i.clone().iuor(this);
      }, f.prototype.iuand = function(i) {
        var a;
        this.length > i.length ? a = i : a = this;
        for (var h3 = 0;h3 < a.length; h3++)
          this.words[h3] = this.words[h3] & i.words[h3];
        return this.length = a.length, this.strip();
      }, f.prototype.iand = function(i) {
        return r((this.negative | i.negative) === 0), this.iuand(i);
      }, f.prototype.and = function(i) {
        return this.length > i.length ? this.clone().iand(i) : i.clone().iand(this);
      }, f.prototype.uand = function(i) {
        return this.length > i.length ? this.clone().iuand(i) : i.clone().iuand(this);
      }, f.prototype.iuxor = function(i) {
        var a, h3;
        this.length > i.length ? (a = this, h3 = i) : (a = i, h3 = this);
        for (var s = 0;s < h3.length; s++)
          this.words[s] = a.words[s] ^ h3.words[s];
        if (this !== a)
          for (;s < a.length; s++)
            this.words[s] = a.words[s];
        return this.length = a.length, this.strip();
      }, f.prototype.ixor = function(i) {
        return r((this.negative | i.negative) === 0), this.iuxor(i);
      }, f.prototype.xor = function(i) {
        return this.length > i.length ? this.clone().ixor(i) : i.clone().ixor(this);
      }, f.prototype.uxor = function(i) {
        return this.length > i.length ? this.clone().iuxor(i) : i.clone().iuxor(this);
      }, f.prototype.inotn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = Math.ceil(i / 26) | 0, h3 = i % 26;
        this._expand(a), h3 > 0 && a--;
        for (var s = 0;s < a; s++)
          this.words[s] = ~this.words[s] & 67108863;
        return h3 > 0 && (this.words[s] = ~this.words[s] & 67108863 >> 26 - h3), this.strip();
      }, f.prototype.notn = function(i) {
        return this.clone().inotn(i);
      }, f.prototype.setn = function(i, a) {
        r(typeof i == "number" && i >= 0);
        var h3 = i / 26 | 0, s = i % 26;
        return this._expand(h3 + 1), a ? this.words[h3] = this.words[h3] | 1 << s : this.words[h3] = this.words[h3] & ~(1 << s), this.strip();
      }, f.prototype.iadd = function(i) {
        var a;
        if (this.negative !== 0 && i.negative === 0)
          return this.negative = 0, a = this.isub(i), this.negative ^= 1, this._normSign();
        if (this.negative === 0 && i.negative !== 0)
          return i.negative = 0, a = this.isub(i), i.negative = 1, a._normSign();
        var h3, s;
        this.length > i.length ? (h3 = this, s = i) : (h3 = i, s = this);
        for (var u = 0, c = 0;c < s.length; c++)
          a = (h3.words[c] | 0) + (s.words[c] | 0) + u, this.words[c] = a & 67108863, u = a >>> 26;
        for (;u !== 0 && c < h3.length; c++)
          a = (h3.words[c] | 0) + u, this.words[c] = a & 67108863, u = a >>> 26;
        if (this.length = h3.length, u !== 0)
          this.words[this.length] = u, this.length++;
        else if (h3 !== this)
          for (;c < h3.length; c++)
            this.words[c] = h3.words[c];
        return this;
      }, f.prototype.add = function(i) {
        var a;
        return i.negative !== 0 && this.negative === 0 ? (i.negative = 0, a = this.sub(i), i.negative ^= 1, a) : i.negative === 0 && this.negative !== 0 ? (this.negative = 0, a = i.sub(this), this.negative = 1, a) : this.length > i.length ? this.clone().iadd(i) : i.clone().iadd(this);
      }, f.prototype.isub = function(i) {
        if (i.negative !== 0) {
          i.negative = 0;
          var a = this.iadd(i);
          return i.negative = 1, a._normSign();
        } else if (this.negative !== 0)
          return this.negative = 0, this.iadd(i), this.negative = 1, this._normSign();
        var h3 = this.cmp(i);
        if (h3 === 0)
          return this.negative = 0, this.length = 1, this.words[0] = 0, this;
        var s, u;
        h3 > 0 ? (s = this, u = i) : (s = i, u = this);
        for (var c = 0, b2 = 0;b2 < u.length; b2++)
          a = (s.words[b2] | 0) - (u.words[b2] | 0) + c, c = a >> 26, this.words[b2] = a & 67108863;
        for (;c !== 0 && b2 < s.length; b2++)
          a = (s.words[b2] | 0) + c, c = a >> 26, this.words[b2] = a & 67108863;
        if (c === 0 && b2 < s.length && s !== this)
          for (;b2 < s.length; b2++)
            this.words[b2] = s.words[b2];
        return this.length = Math.max(this.length, b2), s !== this && (this.negative = 1), this.strip();
      }, f.prototype.sub = function(i) {
        return this.clone().isub(i);
      };
      function q2(v, i, a) {
        a.negative = i.negative ^ v.negative;
        var h3 = v.length + i.length | 0;
        a.length = h3, h3 = h3 - 1 | 0;
        var s = v.words[0] | 0, u = i.words[0] | 0, c = s * u, b2 = c & 67108863, l = c / 67108864 | 0;
        a.words[0] = b2;
        for (var n = 1;n < h3; n++) {
          for (var d = l >>> 26, w = l & 67108863, g = Math.min(n, i.length - 1), _2 = Math.max(0, n - v.length + 1);_2 <= g; _2++) {
            var A2 = n - _2 | 0;
            s = v.words[A2] | 0, u = i.words[_2] | 0, c = s * u + w, d += c / 67108864 | 0, w = c & 67108863;
          }
          a.words[n] = w | 0, l = d | 0;
        }
        return l !== 0 ? a.words[n] = l | 0 : a.length--, a.strip();
      }
      var L2 = function(i, a, h3) {
        var s = i.words, u = a.words, c = h3.words, b2 = 0, l, n, d, w = s[0] | 0, g = w & 8191, _2 = w >>> 13, A2 = s[1] | 0, R2 = A2 & 8191, I = A2 >>> 13, Me = s[2] | 0, k = Me & 8191, D2 = Me >>> 13, nt = s[3] | 0, C2 = nt & 8191, O = nt >>> 13, vt = s[4] | 0, F = vt & 8191, U = vt >>> 13, bt = s[5] | 0, z2 = bt & 8191, H = bt >>> 13, mt = s[6] | 0, W = mt & 8191, K = mt >>> 13, gt = s[7] | 0, j = gt & 8191, Z = gt >>> 13, yt = s[8] | 0, V = yt & 8191, $ = yt >>> 13, wt = s[9] | 0, G = wt & 8191, Y = wt >>> 13, Mt = u[0] | 0, X = Mt & 8191, J = Mt >>> 13, _t = u[1] | 0, Q = _t & 8191, ee = _t >>> 13, xt = u[2] | 0, te = xt & 8191, re = xt >>> 13, St = u[3] | 0, ie = St & 8191, ne = St >>> 13, Et = u[4] | 0, fe = Et & 8191, ae = Et >>> 13, At = u[5] | 0, oe = At & 8191, se = At >>> 13, Rt = u[6] | 0, he = Rt & 8191, ue = Rt >>> 13, Bt = u[7] | 0, le = Bt & 8191, de = Bt >>> 13, qt = u[8] | 0, ce = qt & 8191, pe = qt >>> 13, It = u[9] | 0, ve = It & 8191, be = It >>> 13;
        h3.negative = i.negative ^ a.negative, h3.length = 19, l = Math.imul(g, X), n = Math.imul(g, J), n = n + Math.imul(_2, X) | 0, d = Math.imul(_2, J);
        var ft = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (ft >>> 26) | 0, ft &= 67108863, l = Math.imul(R2, X), n = Math.imul(R2, J), n = n + Math.imul(I, X) | 0, d = Math.imul(I, J), l = l + Math.imul(g, Q) | 0, n = n + Math.imul(g, ee) | 0, n = n + Math.imul(_2, Q) | 0, d = d + Math.imul(_2, ee) | 0;
        var Be = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Be >>> 26) | 0, Be &= 67108863, l = Math.imul(k, X), n = Math.imul(k, J), n = n + Math.imul(D2, X) | 0, d = Math.imul(D2, J), l = l + Math.imul(R2, Q) | 0, n = n + Math.imul(R2, ee) | 0, n = n + Math.imul(I, Q) | 0, d = d + Math.imul(I, ee) | 0, l = l + Math.imul(g, te) | 0, n = n + Math.imul(g, re) | 0, n = n + Math.imul(_2, te) | 0, d = d + Math.imul(_2, re) | 0;
        var qe = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (qe >>> 26) | 0, qe &= 67108863, l = Math.imul(C2, X), n = Math.imul(C2, J), n = n + Math.imul(O, X) | 0, d = Math.imul(O, J), l = l + Math.imul(k, Q) | 0, n = n + Math.imul(k, ee) | 0, n = n + Math.imul(D2, Q) | 0, d = d + Math.imul(D2, ee) | 0, l = l + Math.imul(R2, te) | 0, n = n + Math.imul(R2, re) | 0, n = n + Math.imul(I, te) | 0, d = d + Math.imul(I, re) | 0, l = l + Math.imul(g, ie) | 0, n = n + Math.imul(g, ne) | 0, n = n + Math.imul(_2, ie) | 0, d = d + Math.imul(_2, ne) | 0;
        var ze = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (ze >>> 26) | 0, ze &= 67108863, l = Math.imul(F, X), n = Math.imul(F, J), n = n + Math.imul(U, X) | 0, d = Math.imul(U, J), l = l + Math.imul(C2, Q) | 0, n = n + Math.imul(C2, ee) | 0, n = n + Math.imul(O, Q) | 0, d = d + Math.imul(O, ee) | 0, l = l + Math.imul(k, te) | 0, n = n + Math.imul(k, re) | 0, n = n + Math.imul(D2, te) | 0, d = d + Math.imul(D2, re) | 0, l = l + Math.imul(R2, ie) | 0, n = n + Math.imul(R2, ne) | 0, n = n + Math.imul(I, ie) | 0, d = d + Math.imul(I, ne) | 0, l = l + Math.imul(g, fe) | 0, n = n + Math.imul(g, ae) | 0, n = n + Math.imul(_2, fe) | 0, d = d + Math.imul(_2, ae) | 0;
        var He = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (He >>> 26) | 0, He &= 67108863, l = Math.imul(z2, X), n = Math.imul(z2, J), n = n + Math.imul(H, X) | 0, d = Math.imul(H, J), l = l + Math.imul(F, Q) | 0, n = n + Math.imul(F, ee) | 0, n = n + Math.imul(U, Q) | 0, d = d + Math.imul(U, ee) | 0, l = l + Math.imul(C2, te) | 0, n = n + Math.imul(C2, re) | 0, n = n + Math.imul(O, te) | 0, d = d + Math.imul(O, re) | 0, l = l + Math.imul(k, ie) | 0, n = n + Math.imul(k, ne) | 0, n = n + Math.imul(D2, ie) | 0, d = d + Math.imul(D2, ne) | 0, l = l + Math.imul(R2, fe) | 0, n = n + Math.imul(R2, ae) | 0, n = n + Math.imul(I, fe) | 0, d = d + Math.imul(I, ae) | 0, l = l + Math.imul(g, oe) | 0, n = n + Math.imul(g, se) | 0, n = n + Math.imul(_2, oe) | 0, d = d + Math.imul(_2, se) | 0;
        var We = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (We >>> 26) | 0, We &= 67108863, l = Math.imul(W, X), n = Math.imul(W, J), n = n + Math.imul(K, X) | 0, d = Math.imul(K, J), l = l + Math.imul(z2, Q) | 0, n = n + Math.imul(z2, ee) | 0, n = n + Math.imul(H, Q) | 0, d = d + Math.imul(H, ee) | 0, l = l + Math.imul(F, te) | 0, n = n + Math.imul(F, re) | 0, n = n + Math.imul(U, te) | 0, d = d + Math.imul(U, re) | 0, l = l + Math.imul(C2, ie) | 0, n = n + Math.imul(C2, ne) | 0, n = n + Math.imul(O, ie) | 0, d = d + Math.imul(O, ne) | 0, l = l + Math.imul(k, fe) | 0, n = n + Math.imul(k, ae) | 0, n = n + Math.imul(D2, fe) | 0, d = d + Math.imul(D2, ae) | 0, l = l + Math.imul(R2, oe) | 0, n = n + Math.imul(R2, se) | 0, n = n + Math.imul(I, oe) | 0, d = d + Math.imul(I, se) | 0, l = l + Math.imul(g, he) | 0, n = n + Math.imul(g, ue) | 0, n = n + Math.imul(_2, he) | 0, d = d + Math.imul(_2, ue) | 0;
        var Ke = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ke >>> 26) | 0, Ke &= 67108863, l = Math.imul(j, X), n = Math.imul(j, J), n = n + Math.imul(Z, X) | 0, d = Math.imul(Z, J), l = l + Math.imul(W, Q) | 0, n = n + Math.imul(W, ee) | 0, n = n + Math.imul(K, Q) | 0, d = d + Math.imul(K, ee) | 0, l = l + Math.imul(z2, te) | 0, n = n + Math.imul(z2, re) | 0, n = n + Math.imul(H, te) | 0, d = d + Math.imul(H, re) | 0, l = l + Math.imul(F, ie) | 0, n = n + Math.imul(F, ne) | 0, n = n + Math.imul(U, ie) | 0, d = d + Math.imul(U, ne) | 0, l = l + Math.imul(C2, fe) | 0, n = n + Math.imul(C2, ae) | 0, n = n + Math.imul(O, fe) | 0, d = d + Math.imul(O, ae) | 0, l = l + Math.imul(k, oe) | 0, n = n + Math.imul(k, se) | 0, n = n + Math.imul(D2, oe) | 0, d = d + Math.imul(D2, se) | 0, l = l + Math.imul(R2, he) | 0, n = n + Math.imul(R2, ue) | 0, n = n + Math.imul(I, he) | 0, d = d + Math.imul(I, ue) | 0, l = l + Math.imul(g, le) | 0, n = n + Math.imul(g, de) | 0, n = n + Math.imul(_2, le) | 0, d = d + Math.imul(_2, de) | 0;
        var je = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (je >>> 26) | 0, je &= 67108863, l = Math.imul(V, X), n = Math.imul(V, J), n = n + Math.imul($, X) | 0, d = Math.imul($, J), l = l + Math.imul(j, Q) | 0, n = n + Math.imul(j, ee) | 0, n = n + Math.imul(Z, Q) | 0, d = d + Math.imul(Z, ee) | 0, l = l + Math.imul(W, te) | 0, n = n + Math.imul(W, re) | 0, n = n + Math.imul(K, te) | 0, d = d + Math.imul(K, re) | 0, l = l + Math.imul(z2, ie) | 0, n = n + Math.imul(z2, ne) | 0, n = n + Math.imul(H, ie) | 0, d = d + Math.imul(H, ne) | 0, l = l + Math.imul(F, fe) | 0, n = n + Math.imul(F, ae) | 0, n = n + Math.imul(U, fe) | 0, d = d + Math.imul(U, ae) | 0, l = l + Math.imul(C2, oe) | 0, n = n + Math.imul(C2, se) | 0, n = n + Math.imul(O, oe) | 0, d = d + Math.imul(O, se) | 0, l = l + Math.imul(k, he) | 0, n = n + Math.imul(k, ue) | 0, n = n + Math.imul(D2, he) | 0, d = d + Math.imul(D2, ue) | 0, l = l + Math.imul(R2, le) | 0, n = n + Math.imul(R2, de) | 0, n = n + Math.imul(I, le) | 0, d = d + Math.imul(I, de) | 0, l = l + Math.imul(g, ce) | 0, n = n + Math.imul(g, pe) | 0, n = n + Math.imul(_2, ce) | 0, d = d + Math.imul(_2, pe) | 0;
        var Ze = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ze >>> 26) | 0, Ze &= 67108863, l = Math.imul(G, X), n = Math.imul(G, J), n = n + Math.imul(Y, X) | 0, d = Math.imul(Y, J), l = l + Math.imul(V, Q) | 0, n = n + Math.imul(V, ee) | 0, n = n + Math.imul($, Q) | 0, d = d + Math.imul($, ee) | 0, l = l + Math.imul(j, te) | 0, n = n + Math.imul(j, re) | 0, n = n + Math.imul(Z, te) | 0, d = d + Math.imul(Z, re) | 0, l = l + Math.imul(W, ie) | 0, n = n + Math.imul(W, ne) | 0, n = n + Math.imul(K, ie) | 0, d = d + Math.imul(K, ne) | 0, l = l + Math.imul(z2, fe) | 0, n = n + Math.imul(z2, ae) | 0, n = n + Math.imul(H, fe) | 0, d = d + Math.imul(H, ae) | 0, l = l + Math.imul(F, oe) | 0, n = n + Math.imul(F, se) | 0, n = n + Math.imul(U, oe) | 0, d = d + Math.imul(U, se) | 0, l = l + Math.imul(C2, he) | 0, n = n + Math.imul(C2, ue) | 0, n = n + Math.imul(O, he) | 0, d = d + Math.imul(O, ue) | 0, l = l + Math.imul(k, le) | 0, n = n + Math.imul(k, de) | 0, n = n + Math.imul(D2, le) | 0, d = d + Math.imul(D2, de) | 0, l = l + Math.imul(R2, ce) | 0, n = n + Math.imul(R2, pe) | 0, n = n + Math.imul(I, ce) | 0, d = d + Math.imul(I, pe) | 0, l = l + Math.imul(g, ve) | 0, n = n + Math.imul(g, be) | 0, n = n + Math.imul(_2, ve) | 0, d = d + Math.imul(_2, be) | 0;
        var Ve = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ve >>> 26) | 0, Ve &= 67108863, l = Math.imul(G, Q), n = Math.imul(G, ee), n = n + Math.imul(Y, Q) | 0, d = Math.imul(Y, ee), l = l + Math.imul(V, te) | 0, n = n + Math.imul(V, re) | 0, n = n + Math.imul($, te) | 0, d = d + Math.imul($, re) | 0, l = l + Math.imul(j, ie) | 0, n = n + Math.imul(j, ne) | 0, n = n + Math.imul(Z, ie) | 0, d = d + Math.imul(Z, ne) | 0, l = l + Math.imul(W, fe) | 0, n = n + Math.imul(W, ae) | 0, n = n + Math.imul(K, fe) | 0, d = d + Math.imul(K, ae) | 0, l = l + Math.imul(z2, oe) | 0, n = n + Math.imul(z2, se) | 0, n = n + Math.imul(H, oe) | 0, d = d + Math.imul(H, se) | 0, l = l + Math.imul(F, he) | 0, n = n + Math.imul(F, ue) | 0, n = n + Math.imul(U, he) | 0, d = d + Math.imul(U, ue) | 0, l = l + Math.imul(C2, le) | 0, n = n + Math.imul(C2, de) | 0, n = n + Math.imul(O, le) | 0, d = d + Math.imul(O, de) | 0, l = l + Math.imul(k, ce) | 0, n = n + Math.imul(k, pe) | 0, n = n + Math.imul(D2, ce) | 0, d = d + Math.imul(D2, pe) | 0, l = l + Math.imul(R2, ve) | 0, n = n + Math.imul(R2, be) | 0, n = n + Math.imul(I, ve) | 0, d = d + Math.imul(I, be) | 0;
        var $e = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + ($e >>> 26) | 0, $e &= 67108863, l = Math.imul(G, te), n = Math.imul(G, re), n = n + Math.imul(Y, te) | 0, d = Math.imul(Y, re), l = l + Math.imul(V, ie) | 0, n = n + Math.imul(V, ne) | 0, n = n + Math.imul($, ie) | 0, d = d + Math.imul($, ne) | 0, l = l + Math.imul(j, fe) | 0, n = n + Math.imul(j, ae) | 0, n = n + Math.imul(Z, fe) | 0, d = d + Math.imul(Z, ae) | 0, l = l + Math.imul(W, oe) | 0, n = n + Math.imul(W, se) | 0, n = n + Math.imul(K, oe) | 0, d = d + Math.imul(K, se) | 0, l = l + Math.imul(z2, he) | 0, n = n + Math.imul(z2, ue) | 0, n = n + Math.imul(H, he) | 0, d = d + Math.imul(H, ue) | 0, l = l + Math.imul(F, le) | 0, n = n + Math.imul(F, de) | 0, n = n + Math.imul(U, le) | 0, d = d + Math.imul(U, de) | 0, l = l + Math.imul(C2, ce) | 0, n = n + Math.imul(C2, pe) | 0, n = n + Math.imul(O, ce) | 0, d = d + Math.imul(O, pe) | 0, l = l + Math.imul(k, ve) | 0, n = n + Math.imul(k, be) | 0, n = n + Math.imul(D2, ve) | 0, d = d + Math.imul(D2, be) | 0;
        var Ge = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ge >>> 26) | 0, Ge &= 67108863, l = Math.imul(G, ie), n = Math.imul(G, ne), n = n + Math.imul(Y, ie) | 0, d = Math.imul(Y, ne), l = l + Math.imul(V, fe) | 0, n = n + Math.imul(V, ae) | 0, n = n + Math.imul($, fe) | 0, d = d + Math.imul($, ae) | 0, l = l + Math.imul(j, oe) | 0, n = n + Math.imul(j, se) | 0, n = n + Math.imul(Z, oe) | 0, d = d + Math.imul(Z, se) | 0, l = l + Math.imul(W, he) | 0, n = n + Math.imul(W, ue) | 0, n = n + Math.imul(K, he) | 0, d = d + Math.imul(K, ue) | 0, l = l + Math.imul(z2, le) | 0, n = n + Math.imul(z2, de) | 0, n = n + Math.imul(H, le) | 0, d = d + Math.imul(H, de) | 0, l = l + Math.imul(F, ce) | 0, n = n + Math.imul(F, pe) | 0, n = n + Math.imul(U, ce) | 0, d = d + Math.imul(U, pe) | 0, l = l + Math.imul(C2, ve) | 0, n = n + Math.imul(C2, be) | 0, n = n + Math.imul(O, ve) | 0, d = d + Math.imul(O, be) | 0;
        var Ye = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Ye >>> 26) | 0, Ye &= 67108863, l = Math.imul(G, fe), n = Math.imul(G, ae), n = n + Math.imul(Y, fe) | 0, d = Math.imul(Y, ae), l = l + Math.imul(V, oe) | 0, n = n + Math.imul(V, se) | 0, n = n + Math.imul($, oe) | 0, d = d + Math.imul($, se) | 0, l = l + Math.imul(j, he) | 0, n = n + Math.imul(j, ue) | 0, n = n + Math.imul(Z, he) | 0, d = d + Math.imul(Z, ue) | 0, l = l + Math.imul(W, le) | 0, n = n + Math.imul(W, de) | 0, n = n + Math.imul(K, le) | 0, d = d + Math.imul(K, de) | 0, l = l + Math.imul(z2, ce) | 0, n = n + Math.imul(z2, pe) | 0, n = n + Math.imul(H, ce) | 0, d = d + Math.imul(H, pe) | 0, l = l + Math.imul(F, ve) | 0, n = n + Math.imul(F, be) | 0, n = n + Math.imul(U, ve) | 0, d = d + Math.imul(U, be) | 0;
        var Xe = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Xe >>> 26) | 0, Xe &= 67108863, l = Math.imul(G, oe), n = Math.imul(G, se), n = n + Math.imul(Y, oe) | 0, d = Math.imul(Y, se), l = l + Math.imul(V, he) | 0, n = n + Math.imul(V, ue) | 0, n = n + Math.imul($, he) | 0, d = d + Math.imul($, ue) | 0, l = l + Math.imul(j, le) | 0, n = n + Math.imul(j, de) | 0, n = n + Math.imul(Z, le) | 0, d = d + Math.imul(Z, de) | 0, l = l + Math.imul(W, ce) | 0, n = n + Math.imul(W, pe) | 0, n = n + Math.imul(K, ce) | 0, d = d + Math.imul(K, pe) | 0, l = l + Math.imul(z2, ve) | 0, n = n + Math.imul(z2, be) | 0, n = n + Math.imul(H, ve) | 0, d = d + Math.imul(H, be) | 0;
        var Je = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Je >>> 26) | 0, Je &= 67108863, l = Math.imul(G, he), n = Math.imul(G, ue), n = n + Math.imul(Y, he) | 0, d = Math.imul(Y, ue), l = l + Math.imul(V, le) | 0, n = n + Math.imul(V, de) | 0, n = n + Math.imul($, le) | 0, d = d + Math.imul($, de) | 0, l = l + Math.imul(j, ce) | 0, n = n + Math.imul(j, pe) | 0, n = n + Math.imul(Z, ce) | 0, d = d + Math.imul(Z, pe) | 0, l = l + Math.imul(W, ve) | 0, n = n + Math.imul(W, be) | 0, n = n + Math.imul(K, ve) | 0, d = d + Math.imul(K, be) | 0;
        var Qe = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (Qe >>> 26) | 0, Qe &= 67108863, l = Math.imul(G, le), n = Math.imul(G, de), n = n + Math.imul(Y, le) | 0, d = Math.imul(Y, de), l = l + Math.imul(V, ce) | 0, n = n + Math.imul(V, pe) | 0, n = n + Math.imul($, ce) | 0, d = d + Math.imul($, pe) | 0, l = l + Math.imul(j, ve) | 0, n = n + Math.imul(j, be) | 0, n = n + Math.imul(Z, ve) | 0, d = d + Math.imul(Z, be) | 0;
        var et = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (et >>> 26) | 0, et &= 67108863, l = Math.imul(G, ce), n = Math.imul(G, pe), n = n + Math.imul(Y, ce) | 0, d = Math.imul(Y, pe), l = l + Math.imul(V, ve) | 0, n = n + Math.imul(V, be) | 0, n = n + Math.imul($, ve) | 0, d = d + Math.imul($, be) | 0;
        var tt = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        b2 = (d + (n >>> 13) | 0) + (tt >>> 26) | 0, tt &= 67108863, l = Math.imul(G, ve), n = Math.imul(G, be), n = n + Math.imul(Y, ve) | 0, d = Math.imul(Y, be);
        var rt = (b2 + l | 0) + ((n & 8191) << 13) | 0;
        return b2 = (d + (n >>> 13) | 0) + (rt >>> 26) | 0, rt &= 67108863, c[0] = ft, c[1] = Be, c[2] = qe, c[3] = ze, c[4] = He, c[5] = We, c[6] = Ke, c[7] = je, c[8] = Ze, c[9] = Ve, c[10] = $e, c[11] = Ge, c[12] = Ye, c[13] = Xe, c[14] = Je, c[15] = Qe, c[16] = et, c[17] = tt, c[18] = rt, b2 !== 0 && (c[19] = b2, h3.length++), h3;
      };
      Math.imul || (L2 = q2);
      function ge(v, i, a) {
        a.negative = i.negative ^ v.negative, a.length = v.length + i.length;
        for (var h3 = 0, s = 0, u = 0;u < a.length - 1; u++) {
          var c = s;
          s = 0;
          for (var b2 = h3 & 67108863, l = Math.min(u, i.length - 1), n = Math.max(0, u - v.length + 1);n <= l; n++) {
            var d = u - n, w = v.words[d] | 0, g = i.words[n] | 0, _2 = w * g, A2 = _2 & 67108863;
            c = c + (_2 / 67108864 | 0) | 0, A2 = A2 + b2 | 0, b2 = A2 & 67108863, c = c + (A2 >>> 26) | 0, s += c >>> 26, c &= 67108863;
          }
          a.words[u] = b2, h3 = c, c = s;
        }
        return h3 !== 0 ? a.words[u] = h3 : a.length--, a.strip();
      }
      function _e(v, i, a) {
        var h3 = new N;
        return h3.mulp(v, i, a);
      }
      f.prototype.mulTo = function(i, a) {
        var h3, s = this.length + i.length;
        return this.length === 10 && i.length === 10 ? h3 = L2(this, i, a) : s < 63 ? h3 = q2(this, i, a) : s < 1024 ? h3 = ge(this, i, a) : h3 = _e(this, i, a), h3;
      };
      function N(v, i) {
        this.x = v, this.y = i;
      }
      N.prototype.makeRBT = function(i) {
        for (var a = new Array(i), h3 = f.prototype._countBits(i) - 1, s = 0;s < i; s++)
          a[s] = this.revBin(s, h3, i);
        return a;
      }, N.prototype.revBin = function(i, a, h3) {
        if (i === 0 || i === h3 - 1)
          return i;
        for (var s = 0, u = 0;u < a; u++)
          s |= (i & 1) << a - u - 1, i >>= 1;
        return s;
      }, N.prototype.permute = function(i, a, h3, s, u, c) {
        for (var b2 = 0;b2 < c; b2++)
          s[b2] = a[i[b2]], u[b2] = h3[i[b2]];
      }, N.prototype.transform = function(i, a, h3, s, u, c) {
        this.permute(c, i, a, h3, s, u);
        for (var b2 = 1;b2 < u; b2 <<= 1)
          for (var l = b2 << 1, n = Math.cos(2 * Math.PI / l), d = Math.sin(2 * Math.PI / l), w = 0;w < u; w += l)
            for (var g = n, _2 = d, A2 = 0;A2 < b2; A2++) {
              var R2 = h3[w + A2], I = s[w + A2], Me = h3[w + A2 + b2], k = s[w + A2 + b2], D2 = g * Me - _2 * k;
              k = g * k + _2 * Me, Me = D2, h3[w + A2] = R2 + Me, s[w + A2] = I + k, h3[w + A2 + b2] = R2 - Me, s[w + A2 + b2] = I - k, A2 !== l && (D2 = n * g - d * _2, _2 = n * _2 + d * g, g = D2);
            }
      }, N.prototype.guessLen13b = function(i, a) {
        var h3 = Math.max(a, i) | 1, s = h3 & 1, u = 0;
        for (h3 = h3 / 2 | 0;h3; h3 = h3 >>> 1)
          u++;
        return 1 << u + 1 + s;
      }, N.prototype.conjugate = function(i, a, h3) {
        if (!(h3 <= 1))
          for (var s = 0;s < h3 / 2; s++) {
            var u = i[s];
            i[s] = i[h3 - s - 1], i[h3 - s - 1] = u, u = a[s], a[s] = -a[h3 - s - 1], a[h3 - s - 1] = -u;
          }
      }, N.prototype.normalize13b = function(i, a) {
        for (var h3 = 0, s = 0;s < a / 2; s++) {
          var u = Math.round(i[2 * s + 1] / a) * 8192 + Math.round(i[2 * s] / a) + h3;
          i[s] = u & 67108863, u < 67108864 ? h3 = 0 : h3 = u / 67108864 | 0;
        }
        return i;
      }, N.prototype.convert13b = function(i, a, h3, s) {
        for (var u = 0, c = 0;c < a; c++)
          u = u + (i[c] | 0), h3[2 * c] = u & 8191, u = u >>> 13, h3[2 * c + 1] = u & 8191, u = u >>> 13;
        for (c = 2 * a;c < s; ++c)
          h3[c] = 0;
        r(u === 0), r((u & -8192) === 0);
      }, N.prototype.stub = function(i) {
        for (var a = new Array(i), h3 = 0;h3 < i; h3++)
          a[h3] = 0;
        return a;
      }, N.prototype.mulp = function(i, a, h3) {
        var s = 2 * this.guessLen13b(i.length, a.length), u = this.makeRBT(s), c = this.stub(s), b2 = new Array(s), l = new Array(s), n = new Array(s), d = new Array(s), w = new Array(s), g = new Array(s), _2 = h3.words;
        _2.length = s, this.convert13b(i.words, i.length, b2, s), this.convert13b(a.words, a.length, d, s), this.transform(b2, c, l, n, s, u), this.transform(d, c, w, g, s, u);
        for (var A2 = 0;A2 < s; A2++) {
          var R2 = l[A2] * w[A2] - n[A2] * g[A2];
          n[A2] = l[A2] * g[A2] + n[A2] * w[A2], l[A2] = R2;
        }
        return this.conjugate(l, n, s), this.transform(l, n, _2, c, s, u), this.conjugate(_2, c, s), this.normalize13b(_2, s), h3.negative = i.negative ^ a.negative, h3.length = i.length + a.length, h3.strip();
      }, f.prototype.mul = function(i) {
        var a = new f(null);
        return a.words = new Array(this.length + i.length), this.mulTo(i, a);
      }, f.prototype.mulf = function(i) {
        var a = new f(null);
        return a.words = new Array(this.length + i.length), _e(this, i, a);
      }, f.prototype.imul = function(i) {
        return this.clone().mulTo(i, this);
      }, f.prototype.imuln = function(i) {
        r(typeof i == "number"), r(i < 67108864);
        for (var a = 0, h3 = 0;h3 < this.length; h3++) {
          var s = (this.words[h3] | 0) * i, u = (s & 67108863) + (a & 67108863);
          a >>= 26, a += s / 67108864 | 0, a += u >>> 26, this.words[h3] = u & 67108863;
        }
        return a !== 0 && (this.words[h3] = a, this.length++), this;
      }, f.prototype.muln = function(i) {
        return this.clone().imuln(i);
      }, f.prototype.sqr = function() {
        return this.mul(this);
      }, f.prototype.isqr = function() {
        return this.imul(this.clone());
      }, f.prototype.pow = function(i) {
        var a = B(i);
        if (a.length === 0)
          return new f(1);
        for (var h3 = this, s = 0;s < a.length && a[s] === 0; s++, h3 = h3.sqr())
          ;
        if (++s < a.length)
          for (var u = h3.sqr();s < a.length; s++, u = u.sqr())
            a[s] !== 0 && (h3 = h3.mul(u));
        return h3;
      }, f.prototype.iushln = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h3 = (i - a) / 26, s = 67108863 >>> 26 - a << 26 - a, u;
        if (a !== 0) {
          var c = 0;
          for (u = 0;u < this.length; u++) {
            var b2 = this.words[u] & s, l = (this.words[u] | 0) - b2 << a;
            this.words[u] = l | c, c = b2 >>> 26 - a;
          }
          c && (this.words[u] = c, this.length++);
        }
        if (h3 !== 0) {
          for (u = this.length - 1;u >= 0; u--)
            this.words[u + h3] = this.words[u];
          for (u = 0;u < h3; u++)
            this.words[u] = 0;
          this.length += h3;
        }
        return this.strip();
      }, f.prototype.ishln = function(i) {
        return r(this.negative === 0), this.iushln(i);
      }, f.prototype.iushrn = function(i, a, h3) {
        r(typeof i == "number" && i >= 0);
        var s;
        a ? s = (a - a % 26) / 26 : s = 0;
        var u = i % 26, c = Math.min((i - u) / 26, this.length), b2 = 67108863 ^ 67108863 >>> u << u, l = h3;
        if (s -= c, s = Math.max(0, s), l) {
          for (var n = 0;n < c; n++)
            l.words[n] = this.words[n];
          l.length = c;
        }
        if (c !== 0)
          if (this.length > c)
            for (this.length -= c, n = 0;n < this.length; n++)
              this.words[n] = this.words[n + c];
          else
            this.words[0] = 0, this.length = 1;
        var d = 0;
        for (n = this.length - 1;n >= 0 && (d !== 0 || n >= s); n--) {
          var w = this.words[n] | 0;
          this.words[n] = d << 26 - u | w >>> u, d = w & b2;
        }
        return l && d !== 0 && (l.words[l.length++] = d), this.length === 0 && (this.words[0] = 0, this.length = 1), this.strip();
      }, f.prototype.ishrn = function(i, a, h3) {
        return r(this.negative === 0), this.iushrn(i, a, h3);
      }, f.prototype.shln = function(i) {
        return this.clone().ishln(i);
      }, f.prototype.ushln = function(i) {
        return this.clone().iushln(i);
      }, f.prototype.shrn = function(i) {
        return this.clone().ishrn(i);
      }, f.prototype.ushrn = function(i) {
        return this.clone().iushrn(i);
      }, f.prototype.testn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h3 = (i - a) / 26, s = 1 << a;
        if (this.length <= h3)
          return false;
        var u = this.words[h3];
        return !!(u & s);
      }, f.prototype.imaskn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h3 = (i - a) / 26;
        if (r(this.negative === 0, "imaskn works only with positive numbers"), this.length <= h3)
          return this;
        if (a !== 0 && h3++, this.length = Math.min(h3, this.length), a !== 0) {
          var s = 67108863 ^ 67108863 >>> a << a;
          this.words[this.length - 1] &= s;
        }
        return this.strip();
      }, f.prototype.maskn = function(i) {
        return this.clone().imaskn(i);
      }, f.prototype.iaddn = function(i) {
        return r(typeof i == "number"), r(i < 67108864), i < 0 ? this.isubn(-i) : this.negative !== 0 ? this.length === 1 && (this.words[0] | 0) < i ? (this.words[0] = i - (this.words[0] | 0), this.negative = 0, this) : (this.negative = 0, this.isubn(i), this.negative = 1, this) : this._iaddn(i);
      }, f.prototype._iaddn = function(i) {
        this.words[0] += i;
        for (var a = 0;a < this.length && this.words[a] >= 67108864; a++)
          this.words[a] -= 67108864, a === this.length - 1 ? this.words[a + 1] = 1 : this.words[a + 1]++;
        return this.length = Math.max(this.length, a + 1), this;
      }, f.prototype.isubn = function(i) {
        if (r(typeof i == "number"), r(i < 67108864), i < 0)
          return this.iaddn(-i);
        if (this.negative !== 0)
          return this.negative = 0, this.iaddn(i), this.negative = 1, this;
        if (this.words[0] -= i, this.length === 1 && this.words[0] < 0)
          this.words[0] = -this.words[0], this.negative = 1;
        else
          for (var a = 0;a < this.length && this.words[a] < 0; a++)
            this.words[a] += 67108864, this.words[a + 1] -= 1;
        return this.strip();
      }, f.prototype.addn = function(i) {
        return this.clone().iaddn(i);
      }, f.prototype.subn = function(i) {
        return this.clone().isubn(i);
      }, f.prototype.iabs = function() {
        return this.negative = 0, this;
      }, f.prototype.abs = function() {
        return this.clone().iabs();
      }, f.prototype._ishlnsubmul = function(i, a, h3) {
        var s = i.length + h3, u;
        this._expand(s);
        var c, b2 = 0;
        for (u = 0;u < i.length; u++) {
          c = (this.words[u + h3] | 0) + b2;
          var l = (i.words[u] | 0) * a;
          c -= l & 67108863, b2 = (c >> 26) - (l / 67108864 | 0), this.words[u + h3] = c & 67108863;
        }
        for (;u < this.length - h3; u++)
          c = (this.words[u + h3] | 0) + b2, b2 = c >> 26, this.words[u + h3] = c & 67108863;
        if (b2 === 0)
          return this.strip();
        for (r(b2 === -1), b2 = 0, u = 0;u < this.length; u++)
          c = -(this.words[u] | 0) + b2, b2 = c >> 26, this.words[u] = c & 67108863;
        return this.negative = 1, this.strip();
      }, f.prototype._wordDiv = function(i, a) {
        var h3 = this.length - i.length, s = this.clone(), u = i, c = u.words[u.length - 1] | 0, b2 = this._countBits(c);
        h3 = 26 - b2, h3 !== 0 && (u = u.ushln(h3), s.iushln(h3), c = u.words[u.length - 1] | 0);
        var l = s.length - u.length, n;
        if (a !== "mod") {
          n = new f(null), n.length = l + 1, n.words = new Array(n.length);
          for (var d = 0;d < n.length; d++)
            n.words[d] = 0;
        }
        var w = s.clone()._ishlnsubmul(u, 1, l);
        w.negative === 0 && (s = w, n && (n.words[l] = 1));
        for (var g = l - 1;g >= 0; g--) {
          var _2 = (s.words[u.length + g] | 0) * 67108864 + (s.words[u.length + g - 1] | 0);
          for (_2 = Math.min(_2 / c | 0, 67108863), s._ishlnsubmul(u, _2, g);s.negative !== 0; )
            _2--, s.negative = 0, s._ishlnsubmul(u, 1, g), s.isZero() || (s.negative ^= 1);
          n && (n.words[g] = _2);
        }
        return n && n.strip(), s.strip(), a !== "div" && h3 !== 0 && s.iushrn(h3), { div: n || null, mod: s };
      }, f.prototype.divmod = function(i, a, h3) {
        if (r(!i.isZero()), this.isZero())
          return { div: new f(0), mod: new f(0) };
        var s, u, c;
        return this.negative !== 0 && i.negative === 0 ? (c = this.neg().divmod(i, a), a !== "mod" && (s = c.div.neg()), a !== "div" && (u = c.mod.neg(), h3 && u.negative !== 0 && u.iadd(i)), { div: s, mod: u }) : this.negative === 0 && i.negative !== 0 ? (c = this.divmod(i.neg(), a), a !== "mod" && (s = c.div.neg()), { div: s, mod: c.mod }) : (this.negative & i.negative) !== 0 ? (c = this.neg().divmod(i.neg(), a), a !== "div" && (u = c.mod.neg(), h3 && u.negative !== 0 && u.isub(i)), { div: c.div, mod: u }) : i.length > this.length || this.cmp(i) < 0 ? { div: new f(0), mod: this } : i.length === 1 ? a === "div" ? { div: this.divn(i.words[0]), mod: null } : a === "mod" ? { div: null, mod: new f(this.modn(i.words[0])) } : { div: this.divn(i.words[0]), mod: new f(this.modn(i.words[0])) } : this._wordDiv(i, a);
      }, f.prototype.div = function(i) {
        return this.divmod(i, "div", false).div;
      }, f.prototype.mod = function(i) {
        return this.divmod(i, "mod", false).mod;
      }, f.prototype.umod = function(i) {
        return this.divmod(i, "mod", true).mod;
      }, f.prototype.divRound = function(i) {
        var a = this.divmod(i);
        if (a.mod.isZero())
          return a.div;
        var h3 = a.div.negative !== 0 ? a.mod.isub(i) : a.mod, s = i.ushrn(1), u = i.andln(1), c = h3.cmp(s);
        return c < 0 || u === 1 && c === 0 ? a.div : a.div.negative !== 0 ? a.div.isubn(1) : a.div.iaddn(1);
      }, f.prototype.modn = function(i) {
        r(i <= 67108863);
        for (var a = (1 << 26) % i, h3 = 0, s = this.length - 1;s >= 0; s--)
          h3 = (a * h3 + (this.words[s] | 0)) % i;
        return h3;
      }, f.prototype.idivn = function(i) {
        r(i <= 67108863);
        for (var a = 0, h3 = this.length - 1;h3 >= 0; h3--) {
          var s = (this.words[h3] | 0) + a * 67108864;
          this.words[h3] = s / i | 0, a = s % i;
        }
        return this.strip();
      }, f.prototype.divn = function(i) {
        return this.clone().idivn(i);
      }, f.prototype.egcd = function(i) {
        r(i.negative === 0), r(!i.isZero());
        var a = this, h3 = i.clone();
        a.negative !== 0 ? a = a.umod(i) : a = a.clone();
        for (var s = new f(1), u = new f(0), c = new f(0), b2 = new f(1), l = 0;a.isEven() && h3.isEven(); )
          a.iushrn(1), h3.iushrn(1), ++l;
        for (var n = h3.clone(), d = a.clone();!a.isZero(); ) {
          for (var w = 0, g = 1;(a.words[0] & g) === 0 && w < 26; ++w, g <<= 1)
            ;
          if (w > 0)
            for (a.iushrn(w);w-- > 0; )
              (s.isOdd() || u.isOdd()) && (s.iadd(n), u.isub(d)), s.iushrn(1), u.iushrn(1);
          for (var _2 = 0, A2 = 1;(h3.words[0] & A2) === 0 && _2 < 26; ++_2, A2 <<= 1)
            ;
          if (_2 > 0)
            for (h3.iushrn(_2);_2-- > 0; )
              (c.isOdd() || b2.isOdd()) && (c.iadd(n), b2.isub(d)), c.iushrn(1), b2.iushrn(1);
          a.cmp(h3) >= 0 ? (a.isub(h3), s.isub(c), u.isub(b2)) : (h3.isub(a), c.isub(s), b2.isub(u));
        }
        return { a: c, b: b2, gcd: h3.iushln(l) };
      }, f.prototype._invmp = function(i) {
        r(i.negative === 0), r(!i.isZero());
        var a = this, h3 = i.clone();
        a.negative !== 0 ? a = a.umod(i) : a = a.clone();
        for (var s = new f(1), u = new f(0), c = h3.clone();a.cmpn(1) > 0 && h3.cmpn(1) > 0; ) {
          for (var b2 = 0, l = 1;(a.words[0] & l) === 0 && b2 < 26; ++b2, l <<= 1)
            ;
          if (b2 > 0)
            for (a.iushrn(b2);b2-- > 0; )
              s.isOdd() && s.iadd(c), s.iushrn(1);
          for (var n = 0, d = 1;(h3.words[0] & d) === 0 && n < 26; ++n, d <<= 1)
            ;
          if (n > 0)
            for (h3.iushrn(n);n-- > 0; )
              u.isOdd() && u.iadd(c), u.iushrn(1);
          a.cmp(h3) >= 0 ? (a.isub(h3), s.isub(u)) : (h3.isub(a), u.isub(s));
        }
        var w;
        return a.cmpn(1) === 0 ? w = s : w = u, w.cmpn(0) < 0 && w.iadd(i), w;
      }, f.prototype.gcd = function(i) {
        if (this.isZero())
          return i.abs();
        if (i.isZero())
          return this.abs();
        var a = this.clone(), h3 = i.clone();
        a.negative = 0, h3.negative = 0;
        for (var s = 0;a.isEven() && h3.isEven(); s++)
          a.iushrn(1), h3.iushrn(1);
        do {
          for (;a.isEven(); )
            a.iushrn(1);
          for (;h3.isEven(); )
            h3.iushrn(1);
          var u = a.cmp(h3);
          if (u < 0) {
            var c = a;
            a = h3, h3 = c;
          } else if (u === 0 || h3.cmpn(1) === 0)
            break;
          a.isub(h3);
        } while (true);
        return h3.iushln(s);
      }, f.prototype.invm = function(i) {
        return this.egcd(i).a.umod(i);
      }, f.prototype.isEven = function() {
        return (this.words[0] & 1) === 0;
      }, f.prototype.isOdd = function() {
        return (this.words[0] & 1) === 1;
      }, f.prototype.andln = function(i) {
        return this.words[0] & i;
      }, f.prototype.bincn = function(i) {
        r(typeof i == "number");
        var a = i % 26, h3 = (i - a) / 26, s = 1 << a;
        if (this.length <= h3)
          return this._expand(h3 + 1), this.words[h3] |= s, this;
        for (var u = s, c = h3;u !== 0 && c < this.length; c++) {
          var b2 = this.words[c] | 0;
          b2 += u, u = b2 >>> 26, b2 &= 67108863, this.words[c] = b2;
        }
        return u !== 0 && (this.words[c] = u, this.length++), this;
      }, f.prototype.isZero = function() {
        return this.length === 1 && this.words[0] === 0;
      }, f.prototype.cmpn = function(i) {
        var a = i < 0;
        if (this.negative !== 0 && !a)
          return -1;
        if (this.negative === 0 && a)
          return 1;
        this.strip();
        var h3;
        if (this.length > 1)
          h3 = 1;
        else {
          a && (i = -i), r(i <= 67108863, "Number is too big");
          var s = this.words[0] | 0;
          h3 = s === i ? 0 : s < i ? -1 : 1;
        }
        return this.negative !== 0 ? -h3 | 0 : h3;
      }, f.prototype.cmp = function(i) {
        if (this.negative !== 0 && i.negative === 0)
          return -1;
        if (this.negative === 0 && i.negative !== 0)
          return 1;
        var a = this.ucmp(i);
        return this.negative !== 0 ? -a | 0 : a;
      }, f.prototype.ucmp = function(i) {
        if (this.length > i.length)
          return 1;
        if (this.length < i.length)
          return -1;
        for (var a = 0, h3 = this.length - 1;h3 >= 0; h3--) {
          var s = this.words[h3] | 0, u = i.words[h3] | 0;
          if (s !== u) {
            s < u ? a = -1 : s > u && (a = 1);
            break;
          }
        }
        return a;
      }, f.prototype.gtn = function(i) {
        return this.cmpn(i) === 1;
      }, f.prototype.gt = function(i) {
        return this.cmp(i) === 1;
      }, f.prototype.gten = function(i) {
        return this.cmpn(i) >= 0;
      }, f.prototype.gte = function(i) {
        return this.cmp(i) >= 0;
      }, f.prototype.ltn = function(i) {
        return this.cmpn(i) === -1;
      }, f.prototype.lt = function(i) {
        return this.cmp(i) === -1;
      }, f.prototype.lten = function(i) {
        return this.cmpn(i) <= 0;
      }, f.prototype.lte = function(i) {
        return this.cmp(i) <= 0;
      }, f.prototype.eqn = function(i) {
        return this.cmpn(i) === 0;
      }, f.prototype.eq = function(i) {
        return this.cmp(i) === 0;
      }, f.red = function(i) {
        return new P(i);
      }, f.prototype.toRed = function(i) {
        return r(!this.red, "Already a number in reduction context"), r(this.negative === 0, "red works only with positives"), i.convertTo(this)._forceRed(i);
      }, f.prototype.fromRed = function() {
        return r(this.red, "fromRed works only with numbers in reduction context"), this.red.convertFrom(this);
      }, f.prototype._forceRed = function(i) {
        return this.red = i, this;
      }, f.prototype.forceRed = function(i) {
        return r(!this.red, "Already a number in reduction context"), this._forceRed(i);
      }, f.prototype.redAdd = function(i) {
        return r(this.red, "redAdd works only with red numbers"), this.red.add(this, i);
      }, f.prototype.redIAdd = function(i) {
        return r(this.red, "redIAdd works only with red numbers"), this.red.iadd(this, i);
      }, f.prototype.redSub = function(i) {
        return r(this.red, "redSub works only with red numbers"), this.red.sub(this, i);
      }, f.prototype.redISub = function(i) {
        return r(this.red, "redISub works only with red numbers"), this.red.isub(this, i);
      }, f.prototype.redShl = function(i) {
        return r(this.red, "redShl works only with red numbers"), this.red.shl(this, i);
      }, f.prototype.redMul = function(i) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, i), this.red.mul(this, i);
      }, f.prototype.redIMul = function(i) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, i), this.red.imul(this, i);
      }, f.prototype.redSqr = function() {
        return r(this.red, "redSqr works only with red numbers"), this.red._verify1(this), this.red.sqr(this);
      }, f.prototype.redISqr = function() {
        return r(this.red, "redISqr works only with red numbers"), this.red._verify1(this), this.red.isqr(this);
      }, f.prototype.redSqrt = function() {
        return r(this.red, "redSqrt works only with red numbers"), this.red._verify1(this), this.red.sqrt(this);
      }, f.prototype.redInvm = function() {
        return r(this.red, "redInvm works only with red numbers"), this.red._verify1(this), this.red.invm(this);
      }, f.prototype.redNeg = function() {
        return r(this.red, "redNeg works only with red numbers"), this.red._verify1(this), this.red.neg(this);
      }, f.prototype.redPow = function(i) {
        return r(this.red && !i.red, "redPow(normalNum)"), this.red._verify1(this), this.red.pow(this, i);
      };
      var we = { k256: null, p224: null, p192: null, p25519: null };
      function ye(v, i) {
        this.name = v, this.p = new f(i, 16), this.n = this.p.bitLength(), this.k = new f(1).iushln(this.n).isub(this.p), this.tmp = this._tmp();
      }
      ye.prototype._tmp = function() {
        var i = new f(null);
        return i.words = new Array(Math.ceil(this.n / 13)), i;
      }, ye.prototype.ireduce = function(i) {
        var a = i, h3;
        do
          this.split(a, this.tmp), a = this.imulK(a), a = a.iadd(this.tmp), h3 = a.bitLength();
        while (h3 > this.n);
        var s = h3 < this.n ? -1 : a.ucmp(this.p);
        return s === 0 ? (a.words[0] = 0, a.length = 1) : s > 0 ? a.isub(this.p) : a.strip !== undefined ? a.strip() : a._strip(), a;
      }, ye.prototype.split = function(i, a) {
        i.iushrn(this.n, 0, a);
      }, ye.prototype.imulK = function(i) {
        return i.imul(this.k);
      };
      function xe() {
        ye.call(this, "k256", "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f");
      }
      o(xe, ye), xe.prototype.split = function(i, a) {
        for (var h3 = 4194303, s = Math.min(i.length, 9), u = 0;u < s; u++)
          a.words[u] = i.words[u];
        if (a.length = s, i.length <= 9) {
          i.words[0] = 0, i.length = 1;
          return;
        }
        var c = i.words[9];
        for (a.words[a.length++] = c & h3, u = 10;u < i.length; u++) {
          var b2 = i.words[u] | 0;
          i.words[u - 10] = (b2 & h3) << 4 | c >>> 22, c = b2;
        }
        c >>>= 22, i.words[u - 10] = c, c === 0 && i.length > 10 ? i.length -= 10 : i.length -= 9;
      }, xe.prototype.imulK = function(i) {
        i.words[i.length] = 0, i.words[i.length + 1] = 0, i.length += 2;
        for (var a = 0, h3 = 0;h3 < i.length; h3++) {
          var s = i.words[h3] | 0;
          a += s * 977, i.words[h3] = a & 67108863, a = s * 64 + (a / 67108864 | 0);
        }
        return i.words[i.length - 1] === 0 && (i.length--, i.words[i.length - 1] === 0 && i.length--), i;
      };
      function Re() {
        ye.call(this, "p224", "ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001");
      }
      o(Re, ye);
      function Ee() {
        ye.call(this, "p192", "ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff");
      }
      o(Ee, ye);
      function Ae() {
        ye.call(this, "25519", "7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed");
      }
      o(Ae, ye), Ae.prototype.imulK = function(i) {
        for (var a = 0, h3 = 0;h3 < i.length; h3++) {
          var s = (i.words[h3] | 0) * 19 + a, u = s & 67108863;
          s >>>= 26, i.words[h3] = u, a = s;
        }
        return a !== 0 && (i.words[i.length++] = a), i;
      }, f._prime = function(i) {
        if (we[i])
          return we[i];
        var a;
        if (i === "k256")
          a = new xe;
        else if (i === "p224")
          a = new Re;
        else if (i === "p192")
          a = new Ee;
        else if (i === "p25519")
          a = new Ae;
        else
          throw new Error("Unknown prime " + i);
        return we[i] = a, a;
      };
      function P(v) {
        if (typeof v == "string") {
          var i = f._prime(v);
          this.m = i.p, this.prime = i;
        } else
          r(v.gtn(1), "modulus must be greater than 1"), this.m = v, this.prime = null;
      }
      P.prototype._verify1 = function(i) {
        r(i.negative === 0, "red works only with positives"), r(i.red, "red works only with red numbers");
      }, P.prototype._verify2 = function(i, a) {
        r((i.negative | a.negative) === 0, "red works only with positives"), r(i.red && i.red === a.red, "red works only with red numbers");
      }, P.prototype.imod = function(i) {
        return this.prime ? this.prime.ireduce(i)._forceRed(this) : i.umod(this.m)._forceRed(this);
      }, P.prototype.neg = function(i) {
        return i.isZero() ? i.clone() : this.m.sub(i)._forceRed(this);
      }, P.prototype.add = function(i, a) {
        this._verify2(i, a);
        var h3 = i.add(a);
        return h3.cmp(this.m) >= 0 && h3.isub(this.m), h3._forceRed(this);
      }, P.prototype.iadd = function(i, a) {
        this._verify2(i, a);
        var h3 = i.iadd(a);
        return h3.cmp(this.m) >= 0 && h3.isub(this.m), h3;
      }, P.prototype.sub = function(i, a) {
        this._verify2(i, a);
        var h3 = i.sub(a);
        return h3.cmpn(0) < 0 && h3.iadd(this.m), h3._forceRed(this);
      }, P.prototype.isub = function(i, a) {
        this._verify2(i, a);
        var h3 = i.isub(a);
        return h3.cmpn(0) < 0 && h3.iadd(this.m), h3;
      }, P.prototype.shl = function(i, a) {
        return this._verify1(i), this.imod(i.ushln(a));
      }, P.prototype.imul = function(i, a) {
        return this._verify2(i, a), this.imod(i.imul(a));
      }, P.prototype.mul = function(i, a) {
        return this._verify2(i, a), this.imod(i.mul(a));
      }, P.prototype.isqr = function(i) {
        return this.imul(i, i.clone());
      }, P.prototype.sqr = function(i) {
        return this.mul(i, i);
      }, P.prototype.sqrt = function(i) {
        if (i.isZero())
          return i.clone();
        var a = this.m.andln(3);
        if (r(a % 2 === 1), a === 3) {
          var h3 = this.m.add(new f(1)).iushrn(2);
          return this.pow(i, h3);
        }
        for (var s = this.m.subn(1), u = 0;!s.isZero() && s.andln(1) === 0; )
          u++, s.iushrn(1);
        r(!s.isZero());
        var c = new f(1).toRed(this), b2 = c.redNeg(), l = this.m.subn(1).iushrn(1), n = this.m.bitLength();
        for (n = new f(2 * n * n).toRed(this);this.pow(n, l).cmp(b2) !== 0; )
          n.redIAdd(b2);
        for (var d = this.pow(n, s), w = this.pow(i, s.addn(1).iushrn(1)), g = this.pow(i, s), _2 = u;g.cmp(c) !== 0; ) {
          for (var A2 = g, R2 = 0;A2.cmp(c) !== 0; R2++)
            A2 = A2.redSqr();
          r(R2 < _2);
          var I = this.pow(d, new f(1).iushln(_2 - R2 - 1));
          w = w.redMul(I), d = I.redSqr(), g = g.redMul(d), _2 = R2;
        }
        return w;
      }, P.prototype.invm = function(i) {
        var a = i._invmp(this.m);
        return a.negative !== 0 ? (a.negative = 0, this.imod(a).redNeg()) : this.imod(a);
      }, P.prototype.pow = function(i, a) {
        if (a.isZero())
          return new f(1).toRed(this);
        if (a.cmpn(1) === 0)
          return i.clone();
        var h3 = 4, s = new Array(1 << h3);
        s[0] = new f(1).toRed(this), s[1] = i;
        for (var u = 2;u < s.length; u++)
          s[u] = this.mul(s[u - 1], i);
        var c = s[0], b2 = 0, l = 0, n = a.bitLength() % 26;
        for (n === 0 && (n = 26), u = a.length - 1;u >= 0; u--) {
          for (var d = a.words[u], w = n - 1;w >= 0; w--) {
            var g = d >> w & 1;
            if (c !== s[0] && (c = this.sqr(c)), g === 0 && b2 === 0) {
              l = 0;
              continue;
            }
            b2 <<= 1, b2 |= g, l++, !(l !== h3 && (u !== 0 || w !== 0)) && (c = this.mul(c, s[b2]), l = 0, b2 = 0);
          }
          n = 26;
        }
        return c;
      }, P.prototype.convertTo = function(i) {
        var a = i.umod(this.m);
        return a === i ? a.clone() : a;
      }, P.prototype.convertFrom = function(i) {
        var a = i.clone();
        return a.red = null, a;
      }, f.mont = function(i) {
        return new Se(i);
      };
      function Se(v) {
        P.call(this, v), this.shift = this.m.bitLength(), this.shift % 26 !== 0 && (this.shift += 26 - this.shift % 26), this.r = new f(1).iushln(this.shift), this.r2 = this.imod(this.r.sqr()), this.rinv = this.r._invmp(this.m), this.minv = this.rinv.mul(this.r).isubn(1).div(this.m), this.minv = this.minv.umod(this.r), this.minv = this.r.sub(this.minv);
      }
      o(Se, P), Se.prototype.convertTo = function(i) {
        return this.imod(i.ushln(this.shift));
      }, Se.prototype.convertFrom = function(i) {
        var a = this.imod(i.mul(this.rinv));
        return a.red = null, a;
      }, Se.prototype.imul = function(i, a) {
        if (i.isZero() || a.isZero())
          return i.words[0] = 0, i.length = 1, i;
        var h3 = i.imul(a), s = h3.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), u = h3.isub(s).iushrn(this.shift), c = u;
        return u.cmp(this.m) >= 0 ? c = u.isub(this.m) : u.cmpn(0) < 0 && (c = u.iadd(this.m)), c._forceRed(this);
      }, Se.prototype.mul = function(i, a) {
        if (i.isZero() || a.isZero())
          return new f(0)._forceRed(this);
        var h3 = i.mul(a), s = h3.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), u = h3.isub(s).iushrn(this.shift), c = u;
        return u.cmp(this.m) >= 0 ? c = u.isub(this.m) : u.cmpn(0) < 0 && (c = u.iadd(this.m)), c._forceRed(this);
      }, Se.prototype.invm = function(i) {
        var a = this.imod(i._invmp(this.m).mul(this.r2));
        return a._forceRed(this);
      };
    })(typeof Ll > "u" || Ll, h2);
  });
  Nl = T2((d2) => {
    var js = d2;
    function uA(t, e) {
      if (Array.isArray(t))
        return t.slice();
      if (!t)
        return [];
      var r = [];
      if (typeof t != "string") {
        for (var o = 0;o < t.length; o++)
          r[o] = t[o] | 0;
        return r;
      }
      if (e === "hex") {
        t = t.replace(/[^a-z0-9]+/ig, ""), t.length % 2 !== 0 && (t = "0" + t);
        for (var o = 0;o < t.length; o += 2)
          r.push(parseInt(t[o] + t[o + 1], 16));
      } else
        for (var o = 0;o < t.length; o++) {
          var f = t.charCodeAt(o), p = f >> 8, m2 = f & 255;
          p ? r.push(p, m2) : r.push(m2);
        }
      return r;
    }
    js.toArray = uA;
    function u2(t) {
      return t.length === 1 ? "0" + t : t;
    }
    js.zero2 = u2;
    function l2(t) {
      for (var e = "", r = 0;r < t.length; r++)
        e += u2(t[r].toString(16));
      return e;
    }
    js.toHex = l2;
    js.encode = function(e, r) {
      return r === "hex" ? l2(e) : e;
    };
  });
  or = T2((c2) => {
    var Pr = c2, lA = ri(), dA = ar(), Zs = Nl();
    Pr.assert = dA;
    Pr.toArray = Zs.toArray;
    Pr.zero2 = Zs.zero2;
    Pr.toHex = Zs.toHex;
    Pr.encode = Zs.encode;
    function cA(t, e, r) {
      var o = new Array(Math.max(t.bitLength(), r) + 1);
      o.fill(0);
      for (var f = 1 << e + 1, p = t.clone(), m2 = 0;m2 < o.length; m2++) {
        var y2, M = p.andln(f - 1);
        p.isOdd() ? (M > (f >> 1) - 1 ? y2 = (f >> 1) - M : y2 = M, p.isubn(y2)) : y2 = 0, o[m2] = y2, p.iushrn(1);
      }
      return o;
    }
    Pr.getNAF = cA;
    function pA(t, e) {
      var r = [[], []];
      t = t.clone(), e = e.clone();
      for (var o = 0, f = 0, p;t.cmpn(-o) > 0 || e.cmpn(-f) > 0; ) {
        var m2 = t.andln(3) + o & 3, y2 = e.andln(3) + f & 3;
        m2 === 3 && (m2 = -1), y2 === 3 && (y2 = -1);
        var M;
        (m2 & 1) === 0 ? M = 0 : (p = t.andln(7) + o & 7, (p === 3 || p === 5) && y2 === 2 ? M = -m2 : M = m2), r[0].push(M);
        var x;
        (y2 & 1) === 0 ? x = 0 : (p = e.andln(7) + f & 7, (p === 3 || p === 5) && m2 === 2 ? x = -y2 : x = y2), r[1].push(x), 2 * o === M + 1 && (o = 1 - o), 2 * f === x + 1 && (f = 1 - f), t.iushrn(1), e.iushrn(1);
      }
      return r;
    }
    Pr.getJSF = pA;
    function vA(t, e, r) {
      var o = "_" + e;
      t.prototype[e] = function() {
        return this[o] !== undefined ? this[o] : this[o] = r.call(this);
      };
    }
    Pr.cachedProperty = vA;
    function bA(t) {
      return typeof t == "string" ? Pr.toArray(t, "hex") : t;
    }
    Pr.parseBytes = bA;
    function mA(t) {
      return new lA(t, "hex", "le");
    }
    Pr.intFromLE = mA;
  });
  Oa = T2((xk, p2) => {
    var Cn = ri(), Ca = or(), Vs = Ca.getNAF, gA = Ca.getJSF, $s = Ca.assert;
    function Xi(t, e) {
      this.type = t, this.p = new Cn(e.p, 16), this.red = e.prime ? Cn.red(e.prime) : Cn.mont(this.p), this.zero = new Cn(0).toRed(this.red), this.one = new Cn(1).toRed(this.red), this.two = new Cn(2).toRed(this.red), this.n = e.n && new Cn(e.n, 16), this.g = e.g && this.pointFromJSON(e.g, e.gRed), this._wnafT1 = new Array(4), this._wnafT2 = new Array(4), this._wnafT3 = new Array(4), this._wnafT4 = new Array(4), this._bitLength = this.n ? this.n.bitLength() : 0;
      var r = this.n && this.p.div(this.n);
      !r || r.cmpn(100) > 0 ? this.redN = null : (this._maxwellTrick = true, this.redN = this.n.toRed(this.red));
    }
    p2.exports = Xi;
    Xi.prototype.point = function() {
      throw new Error("Not implemented");
    };
    Xi.prototype.validate = function() {
      throw new Error("Not implemented");
    };
    Xi.prototype._fixedNafMul = function(e, r) {
      $s(e.precomputed);
      var o = e._getDoubles(), f = Vs(r, 1, this._bitLength), p = (1 << o.step + 1) - (o.step % 2 === 0 ? 2 : 1);
      p /= 3;
      var m2 = [], y2, M;
      for (y2 = 0;y2 < f.length; y2 += o.step) {
        M = 0;
        for (var x = y2 + o.step - 1;x >= y2; x--)
          M = (M << 1) + f[x];
        m2.push(M);
      }
      for (var S = this.jpoint(null, null, null), E2 = this.jpoint(null, null, null), B = p;B > 0; B--) {
        for (y2 = 0;y2 < m2.length; y2++)
          M = m2[y2], M === B ? E2 = E2.mixedAdd(o.points[y2]) : M === -B && (E2 = E2.mixedAdd(o.points[y2].neg()));
        S = S.add(E2);
      }
      return S.toP();
    };
    Xi.prototype._wnafMul = function(e, r) {
      var o = 4, f = e._getNAFPoints(o);
      o = f.wnd;
      for (var p = f.points, m2 = Vs(r, o, this._bitLength), y2 = this.jpoint(null, null, null), M = m2.length - 1;M >= 0; M--) {
        for (var x = 0;M >= 0 && m2[M] === 0; M--)
          x++;
        if (M >= 0 && x++, y2 = y2.dblp(x), M < 0)
          break;
        var S = m2[M];
        $s(S !== 0), e.type === "affine" ? S > 0 ? y2 = y2.mixedAdd(p[S - 1 >> 1]) : y2 = y2.mixedAdd(p[-S - 1 >> 1].neg()) : S > 0 ? y2 = y2.add(p[S - 1 >> 1]) : y2 = y2.add(p[-S - 1 >> 1].neg());
      }
      return e.type === "affine" ? y2.toP() : y2;
    };
    Xi.prototype._wnafMulAdd = function(e, r, o, f, p) {
      var m2 = this._wnafT1, y2 = this._wnafT2, M = this._wnafT3, x = 0, S, E2, B;
      for (S = 0;S < f; S++) {
        B = r[S];
        var q2 = B._getNAFPoints(e);
        m2[S] = q2.wnd, y2[S] = q2.points;
      }
      for (S = f - 1;S >= 1; S -= 2) {
        var L2 = S - 1, ge = S;
        if (m2[L2] !== 1 || m2[ge] !== 1) {
          M[L2] = Vs(o[L2], m2[L2], this._bitLength), M[ge] = Vs(o[ge], m2[ge], this._bitLength), x = Math.max(M[L2].length, x), x = Math.max(M[ge].length, x);
          continue;
        }
        var _e = [r[L2], null, null, r[ge]];
        r[L2].y.cmp(r[ge].y) === 0 ? (_e[1] = r[L2].add(r[ge]), _e[2] = r[L2].toJ().mixedAdd(r[ge].neg())) : r[L2].y.cmp(r[ge].y.redNeg()) === 0 ? (_e[1] = r[L2].toJ().mixedAdd(r[ge]), _e[2] = r[L2].add(r[ge].neg())) : (_e[1] = r[L2].toJ().mixedAdd(r[ge]), _e[2] = r[L2].toJ().mixedAdd(r[ge].neg()));
        var N = [-3, -1, -5, -7, 0, 7, 5, 1, 3], we = gA(o[L2], o[ge]);
        for (x = Math.max(we[0].length, x), M[L2] = new Array(x), M[ge] = new Array(x), E2 = 0;E2 < x; E2++) {
          var ye = we[0][E2] | 0, xe = we[1][E2] | 0;
          M[L2][E2] = N[(ye + 1) * 3 + (xe + 1)], M[ge][E2] = 0, y2[L2] = _e;
        }
      }
      var Re = this.jpoint(null, null, null), Ee = this._wnafT4;
      for (S = x;S >= 0; S--) {
        for (var Ae = 0;S >= 0; ) {
          var P = true;
          for (E2 = 0;E2 < f; E2++)
            Ee[E2] = M[E2][S] | 0, Ee[E2] !== 0 && (P = false);
          if (!P)
            break;
          Ae++, S--;
        }
        if (S >= 0 && Ae++, Re = Re.dblp(Ae), S < 0)
          break;
        for (E2 = 0;E2 < f; E2++) {
          var Se = Ee[E2];
          Se !== 0 && (Se > 0 ? B = y2[E2][Se - 1 >> 1] : Se < 0 && (B = y2[E2][-Se - 1 >> 1].neg()), B.type === "affine" ? Re = Re.mixedAdd(B) : Re = Re.add(B));
        }
      }
      for (S = 0;S < f; S++)
        y2[S] = null;
      return p ? Re : Re.toP();
    };
    function _r(t, e) {
      this.curve = t, this.type = e, this.precomputed = null;
    }
    Xi.BasePoint = _r;
    _r.prototype.eq = function() {
      throw new Error("Not implemented");
    };
    _r.prototype.validate = function() {
      return this.curve.validate(this);
    };
    Xi.prototype.decodePoint = function(e, r) {
      e = Ca.toArray(e, r);
      var o = this.p.byteLength();
      if ((e[0] === 4 || e[0] === 6 || e[0] === 7) && e.length - 1 === 2 * o) {
        e[0] === 6 ? $s(e[e.length - 1] % 2 === 0) : e[0] === 7 && $s(e[e.length - 1] % 2 === 1);
        var f = this.point(e.slice(1, 1 + o), e.slice(1 + o, 1 + 2 * o));
        return f;
      } else if ((e[0] === 2 || e[0] === 3) && e.length - 1 === o)
        return this.pointFromX(e.slice(1, 1 + o), e[0] === 3);
      throw new Error("Unknown point format");
    };
    _r.prototype.encodeCompressed = function(e) {
      return this.encode(e, true);
    };
    _r.prototype._encode = function(e) {
      var r = this.curve.p.byteLength(), o = this.getX().toArray("be", r);
      return e ? [this.getY().isEven() ? 2 : 3].concat(o) : [4].concat(o, this.getY().toArray("be", r));
    };
    _r.prototype.encode = function(e, r) {
      return Ca.encode(this._encode(r), e);
    };
    _r.prototype.precompute = function(e) {
      if (this.precomputed)
        return this;
      var r = { doubles: null, naf: null, beta: null };
      return r.naf = this._getNAFPoints(8), r.doubles = this._getDoubles(4, e), r.beta = this._getBeta(), this.precomputed = r, this;
    };
    _r.prototype._hasDoubles = function(e) {
      if (!this.precomputed)
        return false;
      var r = this.precomputed.doubles;
      return r ? r.points.length >= Math.ceil((e.bitLength() + 1) / r.step) : false;
    };
    _r.prototype._getDoubles = function(e, r) {
      if (this.precomputed && this.precomputed.doubles)
        return this.precomputed.doubles;
      for (var o = [this], f = this, p = 0;p < r; p += e) {
        for (var m2 = 0;m2 < e; m2++)
          f = f.dbl();
        o.push(f);
      }
      return { step: e, points: o };
    };
    _r.prototype._getNAFPoints = function(e) {
      if (this.precomputed && this.precomputed.naf)
        return this.precomputed.naf;
      for (var r = [this], o = (1 << e) - 1, f = o === 1 ? null : this.dbl(), p = 1;p < o; p++)
        r[p] = r[p - 1].add(f);
      return { wnd: e, points: r };
    };
    _r.prototype._getBeta = function() {
      return null;
    };
    _r.prototype.dblp = function(e) {
      for (var r = this, o = 0;o < e; o++)
        r = r.dbl();
      return r;
    };
  });
  b2 = T2((Sk, v2) => {
    var yA = or(), lt = ri(), Dl = Ie(), Bf = Oa(), wA = yA.assert;
    function xr(t) {
      Bf.call(this, "short", t), this.a = new lt(t.a, 16).toRed(this.red), this.b = new lt(t.b, 16).toRed(this.red), this.tinv = this.two.redInvm(), this.zeroA = this.a.fromRed().cmpn(0) === 0, this.threeA = this.a.fromRed().sub(this.p).cmpn(-3) === 0, this.endo = this._getEndomorphism(t), this._endoWnafT1 = new Array(4), this._endoWnafT2 = new Array(4);
    }
    Dl(xr, Bf);
    v2.exports = xr;
    xr.prototype._getEndomorphism = function(e) {
      if (!(!this.zeroA || !this.g || !this.n || this.p.modn(3) !== 1)) {
        var r, o;
        if (e.beta)
          r = new lt(e.beta, 16).toRed(this.red);
        else {
          var f = this._getEndoRoots(this.p);
          r = f[0].cmp(f[1]) < 0 ? f[0] : f[1], r = r.toRed(this.red);
        }
        if (e.lambda)
          o = new lt(e.lambda, 16);
        else {
          var p = this._getEndoRoots(this.n);
          this.g.mul(p[0]).x.cmp(this.g.x.redMul(r)) === 0 ? o = p[0] : (o = p[1], wA(this.g.mul(o).x.cmp(this.g.x.redMul(r)) === 0));
        }
        var m2;
        return e.basis ? m2 = e.basis.map(function(y2) {
          return { a: new lt(y2.a, 16), b: new lt(y2.b, 16) };
        }) : m2 = this._getEndoBasis(o), { beta: r, lambda: o, basis: m2 };
      }
    };
    xr.prototype._getEndoRoots = function(e) {
      var r = e === this.p ? this.red : lt.mont(e), o = new lt(2).toRed(r).redInvm(), f = o.redNeg(), p = new lt(3).toRed(r).redNeg().redSqrt().redMul(o), m2 = f.redAdd(p).fromRed(), y2 = f.redSub(p).fromRed();
      return [m2, y2];
    };
    xr.prototype._getEndoBasis = function(e) {
      for (var r = this.n.ushrn(Math.floor(this.n.bitLength() / 2)), o = e, f = this.n.clone(), p = new lt(1), m2 = new lt(0), y2 = new lt(0), M = new lt(1), x, S, E2, B, q2, L2, ge, _e = 0, N, we;o.cmpn(0) !== 0; ) {
        var ye = f.div(o);
        N = f.sub(ye.mul(o)), we = y2.sub(ye.mul(p));
        var xe = M.sub(ye.mul(m2));
        if (!E2 && N.cmp(r) < 0)
          x = ge.neg(), S = p, E2 = N.neg(), B = we;
        else if (E2 && ++_e === 2)
          break;
        ge = N, f = o, o = N, y2 = p, p = we, M = m2, m2 = xe;
      }
      q2 = N.neg(), L2 = we;
      var Re = E2.sqr().add(B.sqr()), Ee = q2.sqr().add(L2.sqr());
      return Ee.cmp(Re) >= 0 && (q2 = x, L2 = S), E2.negative && (E2 = E2.neg(), B = B.neg()), q2.negative && (q2 = q2.neg(), L2 = L2.neg()), [{ a: E2, b: B }, { a: q2, b: L2 }];
    };
    xr.prototype._endoSplit = function(e) {
      var r = this.endo.basis, o = r[0], f = r[1], p = f.b.mul(e).divRound(this.n), m2 = o.b.neg().mul(e).divRound(this.n), y2 = p.mul(o.a), M = m2.mul(f.a), x = p.mul(o.b), S = m2.mul(f.b), E2 = e.sub(y2).sub(M), B = x.add(S).neg();
      return { k1: E2, k2: B };
    };
    xr.prototype.pointFromX = function(e, r) {
      e = new lt(e, 16), e.red || (e = e.toRed(this.red));
      var o = e.redSqr().redMul(e).redIAdd(e.redMul(this.a)).redIAdd(this.b), f = o.redSqrt();
      if (f.redSqr().redSub(o).cmp(this.zero) !== 0)
        throw new Error("invalid point");
      var p = f.fromRed().isOdd();
      return (r && !p || !r && p) && (f = f.redNeg()), this.point(e, f);
    };
    xr.prototype.validate = function(e) {
      if (e.inf)
        return true;
      var { x: r, y: o } = e, f = this.a.redMul(r), p = r.redSqr().redMul(r).redIAdd(f).redIAdd(this.b);
      return o.redSqr().redISub(p).cmpn(0) === 0;
    };
    xr.prototype._endoWnafMulAdd = function(e, r, o) {
      for (var f = this._endoWnafT1, p = this._endoWnafT2, m2 = 0;m2 < e.length; m2++) {
        var y2 = this._endoSplit(r[m2]), M = e[m2], x = M._getBeta();
        y2.k1.negative && (y2.k1.ineg(), M = M.neg(true)), y2.k2.negative && (y2.k2.ineg(), x = x.neg(true)), f[m2 * 2] = M, f[m2 * 2 + 1] = x, p[m2 * 2] = y2.k1, p[m2 * 2 + 1] = y2.k2;
      }
      for (var S = this._wnafMulAdd(1, f, p, m2 * 2, o), E2 = 0;E2 < m2 * 2; E2++)
        f[E2] = null, p[E2] = null;
      return S;
    };
    function Ct(t, e, r, o) {
      Bf.BasePoint.call(this, t, "affine"), e === null && r === null ? (this.x = null, this.y = null, this.inf = true) : (this.x = new lt(e, 16), this.y = new lt(r, 16), o && (this.x.forceRed(this.curve.red), this.y.forceRed(this.curve.red)), this.x.red || (this.x = this.x.toRed(this.curve.red)), this.y.red || (this.y = this.y.toRed(this.curve.red)), this.inf = false);
    }
    Dl(Ct, Bf.BasePoint);
    xr.prototype.point = function(e, r, o) {
      return new Ct(this, e, r, o);
    };
    xr.prototype.pointFromJSON = function(e, r) {
      return Ct.fromJSON(this, e, r);
    };
    Ct.prototype._getBeta = function() {
      if (!!this.curve.endo) {
        var e = this.precomputed;
        if (e && e.beta)
          return e.beta;
        var r = this.curve.point(this.x.redMul(this.curve.endo.beta), this.y);
        if (e) {
          var o = this.curve, f = function(p) {
            return o.point(p.x.redMul(o.endo.beta), p.y);
          };
          e.beta = r, r.precomputed = { beta: null, naf: e.naf && { wnd: e.naf.wnd, points: e.naf.points.map(f) }, doubles: e.doubles && { step: e.doubles.step, points: e.doubles.points.map(f) } };
        }
        return r;
      }
    };
    Ct.prototype.toJSON = function() {
      return this.precomputed ? [this.x, this.y, this.precomputed && { doubles: this.precomputed.doubles && { step: this.precomputed.doubles.step, points: this.precomputed.doubles.points.slice(1) }, naf: this.precomputed.naf && { wnd: this.precomputed.naf.wnd, points: this.precomputed.naf.points.slice(1) } }] : [this.x, this.y];
    };
    Ct.fromJSON = function(e, r, o) {
      typeof r == "string" && (r = JSON.parse(r));
      var f = e.point(r[0], r[1], o);
      if (!r[2])
        return f;
      function p(y2) {
        return e.point(y2[0], y2[1], o);
      }
      var m2 = r[2];
      return f.precomputed = { beta: null, doubles: m2.doubles && { step: m2.doubles.step, points: [f].concat(m2.doubles.points.map(p)) }, naf: m2.naf && { wnd: m2.naf.wnd, points: [f].concat(m2.naf.points.map(p)) } }, f;
    };
    Ct.prototype.inspect = function() {
      return this.isInfinity() ? "<EC Point Infinity>" : "<EC Point x: " + this.x.fromRed().toString(16, 2) + " y: " + this.y.fromRed().toString(16, 2) + ">";
    };
    Ct.prototype.isInfinity = function() {
      return this.inf;
    };
    Ct.prototype.add = function(e) {
      if (this.inf)
        return e;
      if (e.inf)
        return this;
      if (this.eq(e))
        return this.dbl();
      if (this.neg().eq(e))
        return this.curve.point(null, null);
      if (this.x.cmp(e.x) === 0)
        return this.curve.point(null, null);
      var r = this.y.redSub(e.y);
      r.cmpn(0) !== 0 && (r = r.redMul(this.x.redSub(e.x).redInvm()));
      var o = r.redSqr().redISub(this.x).redISub(e.x), f = r.redMul(this.x.redSub(o)).redISub(this.y);
      return this.curve.point(o, f);
    };
    Ct.prototype.dbl = function() {
      if (this.inf)
        return this;
      var e = this.y.redAdd(this.y);
      if (e.cmpn(0) === 0)
        return this.curve.point(null, null);
      var r = this.curve.a, o = this.x.redSqr(), f = e.redInvm(), p = o.redAdd(o).redIAdd(o).redIAdd(r).redMul(f), m2 = p.redSqr().redISub(this.x.redAdd(this.x)), y2 = p.redMul(this.x.redSub(m2)).redISub(this.y);
      return this.curve.point(m2, y2);
    };
    Ct.prototype.getX = function() {
      return this.x.fromRed();
    };
    Ct.prototype.getY = function() {
      return this.y.fromRed();
    };
    Ct.prototype.mul = function(e) {
      return e = new lt(e, 16), this.isInfinity() ? this : this._hasDoubles(e) ? this.curve._fixedNafMul(this, e) : this.curve.endo ? this.curve._endoWnafMulAdd([this], [e]) : this.curve._wnafMul(this, e);
    };
    Ct.prototype.mulAdd = function(e, r, o) {
      var f = [this, r], p = [e, o];
      return this.curve.endo ? this.curve._endoWnafMulAdd(f, p) : this.curve._wnafMulAdd(1, f, p, 2);
    };
    Ct.prototype.jmulAdd = function(e, r, o) {
      var f = [this, r], p = [e, o];
      return this.curve.endo ? this.curve._endoWnafMulAdd(f, p, true) : this.curve._wnafMulAdd(1, f, p, 2, true);
    };
    Ct.prototype.eq = function(e) {
      return this === e || this.inf === e.inf && (this.inf || this.x.cmp(e.x) === 0 && this.y.cmp(e.y) === 0);
    };
    Ct.prototype.neg = function(e) {
      if (this.inf)
        return this;
      var r = this.curve.point(this.x, this.y.redNeg());
      if (e && this.precomputed) {
        var o = this.precomputed, f = function(p) {
          return p.neg();
        };
        r.precomputed = { naf: o.naf && { wnd: o.naf.wnd, points: o.naf.points.map(f) }, doubles: o.doubles && { step: o.doubles.step, points: o.doubles.points.map(f) } };
      }
      return r;
    };
    Ct.prototype.toJ = function() {
      if (this.inf)
        return this.curve.jpoint(null, null, null);
      var e = this.curve.jpoint(this.x, this.y, this.curve.one);
      return e;
    };
    function Wt(t, e, r, o) {
      Bf.BasePoint.call(this, t, "jacobian"), e === null && r === null && o === null ? (this.x = this.curve.one, this.y = this.curve.one, this.z = new lt(0)) : (this.x = new lt(e, 16), this.y = new lt(r, 16), this.z = new lt(o, 16)), this.x.red || (this.x = this.x.toRed(this.curve.red)), this.y.red || (this.y = this.y.toRed(this.curve.red)), this.z.red || (this.z = this.z.toRed(this.curve.red)), this.zOne = this.z === this.curve.one;
    }
    Dl(Wt, Bf.BasePoint);
    xr.prototype.jpoint = function(e, r, o) {
      return new Wt(this, e, r, o);
    };
    Wt.prototype.toP = function() {
      if (this.isInfinity())
        return this.curve.point(null, null);
      var e = this.z.redInvm(), r = e.redSqr(), o = this.x.redMul(r), f = this.y.redMul(r).redMul(e);
      return this.curve.point(o, f);
    };
    Wt.prototype.neg = function() {
      return this.curve.jpoint(this.x, this.y.redNeg(), this.z);
    };
    Wt.prototype.add = function(e) {
      if (this.isInfinity())
        return e;
      if (e.isInfinity())
        return this;
      var r = e.z.redSqr(), o = this.z.redSqr(), f = this.x.redMul(r), p = e.x.redMul(o), m2 = this.y.redMul(r.redMul(e.z)), y2 = e.y.redMul(o.redMul(this.z)), M = f.redSub(p), x = m2.redSub(y2);
      if (M.cmpn(0) === 0)
        return x.cmpn(0) !== 0 ? this.curve.jpoint(null, null, null) : this.dbl();
      var S = M.redSqr(), E2 = S.redMul(M), B = f.redMul(S), q2 = x.redSqr().redIAdd(E2).redISub(B).redISub(B), L2 = x.redMul(B.redISub(q2)).redISub(m2.redMul(E2)), ge = this.z.redMul(e.z).redMul(M);
      return this.curve.jpoint(q2, L2, ge);
    };
    Wt.prototype.mixedAdd = function(e) {
      if (this.isInfinity())
        return e.toJ();
      if (e.isInfinity())
        return this;
      var r = this.z.redSqr(), o = this.x, f = e.x.redMul(r), p = this.y, m2 = e.y.redMul(r).redMul(this.z), y2 = o.redSub(f), M = p.redSub(m2);
      if (y2.cmpn(0) === 0)
        return M.cmpn(0) !== 0 ? this.curve.jpoint(null, null, null) : this.dbl();
      var x = y2.redSqr(), S = x.redMul(y2), E2 = o.redMul(x), B = M.redSqr().redIAdd(S).redISub(E2).redISub(E2), q2 = M.redMul(E2.redISub(B)).redISub(p.redMul(S)), L2 = this.z.redMul(y2);
      return this.curve.jpoint(B, q2, L2);
    };
    Wt.prototype.dblp = function(e) {
      if (e === 0)
        return this;
      if (this.isInfinity())
        return this;
      if (!e)
        return this.dbl();
      var r;
      if (this.curve.zeroA || this.curve.threeA) {
        var o = this;
        for (r = 0;r < e; r++)
          o = o.dbl();
        return o;
      }
      var f = this.curve.a, p = this.curve.tinv, m2 = this.x, y2 = this.y, M = this.z, x = M.redSqr().redSqr(), S = y2.redAdd(y2);
      for (r = 0;r < e; r++) {
        var E2 = m2.redSqr(), B = S.redSqr(), q2 = B.redSqr(), L2 = E2.redAdd(E2).redIAdd(E2).redIAdd(f.redMul(x)), ge = m2.redMul(B), _e = L2.redSqr().redISub(ge.redAdd(ge)), N = ge.redISub(_e), we = L2.redMul(N);
        we = we.redIAdd(we).redISub(q2);
        var ye = S.redMul(M);
        r + 1 < e && (x = x.redMul(q2)), m2 = _e, M = ye, S = we;
      }
      return this.curve.jpoint(m2, S.redMul(p), M);
    };
    Wt.prototype.dbl = function() {
      return this.isInfinity() ? this : this.curve.zeroA ? this._zeroDbl() : this.curve.threeA ? this._threeDbl() : this._dbl();
    };
    Wt.prototype._zeroDbl = function() {
      var e, r, o;
      if (this.zOne) {
        var f = this.x.redSqr(), p = this.y.redSqr(), m2 = p.redSqr(), y2 = this.x.redAdd(p).redSqr().redISub(f).redISub(m2);
        y2 = y2.redIAdd(y2);
        var M = f.redAdd(f).redIAdd(f), x = M.redSqr().redISub(y2).redISub(y2), S = m2.redIAdd(m2);
        S = S.redIAdd(S), S = S.redIAdd(S), e = x, r = M.redMul(y2.redISub(x)).redISub(S), o = this.y.redAdd(this.y);
      } else {
        var E2 = this.x.redSqr(), B = this.y.redSqr(), q2 = B.redSqr(), L2 = this.x.redAdd(B).redSqr().redISub(E2).redISub(q2);
        L2 = L2.redIAdd(L2);
        var ge = E2.redAdd(E2).redIAdd(E2), _e = ge.redSqr(), N = q2.redIAdd(q2);
        N = N.redIAdd(N), N = N.redIAdd(N), e = _e.redISub(L2).redISub(L2), r = ge.redMul(L2.redISub(e)).redISub(N), o = this.y.redMul(this.z), o = o.redIAdd(o);
      }
      return this.curve.jpoint(e, r, o);
    };
    Wt.prototype._threeDbl = function() {
      var e, r, o;
      if (this.zOne) {
        var f = this.x.redSqr(), p = this.y.redSqr(), m2 = p.redSqr(), y2 = this.x.redAdd(p).redSqr().redISub(f).redISub(m2);
        y2 = y2.redIAdd(y2);
        var M = f.redAdd(f).redIAdd(f).redIAdd(this.curve.a), x = M.redSqr().redISub(y2).redISub(y2);
        e = x;
        var S = m2.redIAdd(m2);
        S = S.redIAdd(S), S = S.redIAdd(S), r = M.redMul(y2.redISub(x)).redISub(S), o = this.y.redAdd(this.y);
      } else {
        var E2 = this.z.redSqr(), B = this.y.redSqr(), q2 = this.x.redMul(B), L2 = this.x.redSub(E2).redMul(this.x.redAdd(E2));
        L2 = L2.redAdd(L2).redIAdd(L2);
        var ge = q2.redIAdd(q2);
        ge = ge.redIAdd(ge);
        var _e = ge.redAdd(ge);
        e = L2.redSqr().redISub(_e), o = this.y.redAdd(this.z).redSqr().redISub(B).redISub(E2);
        var N = B.redSqr();
        N = N.redIAdd(N), N = N.redIAdd(N), N = N.redIAdd(N), r = L2.redMul(ge.redISub(e)).redISub(N);
      }
      return this.curve.jpoint(e, r, o);
    };
    Wt.prototype._dbl = function() {
      var e = this.curve.a, r = this.x, o = this.y, f = this.z, p = f.redSqr().redSqr(), m2 = r.redSqr(), y2 = o.redSqr(), M = m2.redAdd(m2).redIAdd(m2).redIAdd(e.redMul(p)), x = r.redAdd(r);
      x = x.redIAdd(x);
      var S = x.redMul(y2), E2 = M.redSqr().redISub(S.redAdd(S)), B = S.redISub(E2), q2 = y2.redSqr();
      q2 = q2.redIAdd(q2), q2 = q2.redIAdd(q2), q2 = q2.redIAdd(q2);
      var L2 = M.redMul(B).redISub(q2), ge = o.redAdd(o).redMul(f);
      return this.curve.jpoint(E2, L2, ge);
    };
    Wt.prototype.trpl = function() {
      if (!this.curve.zeroA)
        return this.dbl().add(this);
      var e = this.x.redSqr(), r = this.y.redSqr(), o = this.z.redSqr(), f = r.redSqr(), p = e.redAdd(e).redIAdd(e), m2 = p.redSqr(), y2 = this.x.redAdd(r).redSqr().redISub(e).redISub(f);
      y2 = y2.redIAdd(y2), y2 = y2.redAdd(y2).redIAdd(y2), y2 = y2.redISub(m2);
      var M = y2.redSqr(), x = f.redIAdd(f);
      x = x.redIAdd(x), x = x.redIAdd(x), x = x.redIAdd(x);
      var S = p.redIAdd(y2).redSqr().redISub(m2).redISub(M).redISub(x), E2 = r.redMul(S);
      E2 = E2.redIAdd(E2), E2 = E2.redIAdd(E2);
      var B = this.x.redMul(M).redISub(E2);
      B = B.redIAdd(B), B = B.redIAdd(B);
      var q2 = this.y.redMul(S.redMul(x.redISub(S)).redISub(y2.redMul(M)));
      q2 = q2.redIAdd(q2), q2 = q2.redIAdd(q2), q2 = q2.redIAdd(q2);
      var L2 = this.z.redAdd(y2).redSqr().redISub(o).redISub(M);
      return this.curve.jpoint(B, q2, L2);
    };
    Wt.prototype.mul = function(e, r) {
      return e = new lt(e, r), this.curve._wnafMul(this, e);
    };
    Wt.prototype.eq = function(e) {
      if (e.type === "affine")
        return this.eq(e.toJ());
      if (this === e)
        return true;
      var r = this.z.redSqr(), o = e.z.redSqr();
      if (this.x.redMul(o).redISub(e.x.redMul(r)).cmpn(0) !== 0)
        return false;
      var f = r.redMul(this.z), p = o.redMul(e.z);
      return this.y.redMul(p).redISub(e.y.redMul(f)).cmpn(0) === 0;
    };
    Wt.prototype.eqXToP = function(e) {
      var r = this.z.redSqr(), o = e.toRed(this.curve.red).redMul(r);
      if (this.x.cmp(o) === 0)
        return true;
      for (var f = e.clone(), p = this.curve.redN.redMul(r);; ) {
        if (f.iadd(this.curve.n), f.cmp(this.curve.p) >= 0)
          return false;
        if (o.redIAdd(p), this.x.cmp(o) === 0)
          return true;
      }
    };
    Wt.prototype.inspect = function() {
      return this.isInfinity() ? "<EC JPoint Infinity>" : "<EC JPoint x: " + this.x.toString(16, 2) + " y: " + this.y.toString(16, 2) + " z: " + this.z.toString(16, 2) + ">";
    };
    Wt.prototype.isInfinity = function() {
      return this.z.cmpn(0) === 0;
    };
  });
  y2 = T2((Ek, g2) => {
    var qf = ri(), m2 = Ie(), Gs = Oa(), MA = or();
    function If(t) {
      Gs.call(this, "mont", t), this.a = new qf(t.a, 16).toRed(this.red), this.b = new qf(t.b, 16).toRed(this.red), this.i4 = new qf(4).toRed(this.red).redInvm(), this.two = new qf(2).toRed(this.red), this.a24 = this.i4.redMul(this.a.redAdd(this.two));
    }
    m2(If, Gs);
    g2.exports = If;
    If.prototype.validate = function(e) {
      var r = e.normalize().x, o = r.redSqr(), f = o.redMul(r).redAdd(o.redMul(this.a)).redAdd(r), p = f.redSqrt();
      return p.redSqr().cmp(f) === 0;
    };
    function Ot(t, e, r) {
      Gs.BasePoint.call(this, t, "projective"), e === null && r === null ? (this.x = this.curve.one, this.z = this.curve.zero) : (this.x = new qf(e, 16), this.z = new qf(r, 16), this.x.red || (this.x = this.x.toRed(this.curve.red)), this.z.red || (this.z = this.z.toRed(this.curve.red)));
    }
    m2(Ot, Gs.BasePoint);
    If.prototype.decodePoint = function(e, r) {
      return this.point(MA.toArray(e, r), 1);
    };
    If.prototype.point = function(e, r) {
      return new Ot(this, e, r);
    };
    If.prototype.pointFromJSON = function(e) {
      return Ot.fromJSON(this, e);
    };
    Ot.prototype.precompute = function() {
    };
    Ot.prototype._encode = function() {
      return this.getX().toArray("be", this.curve.p.byteLength());
    };
    Ot.fromJSON = function(e, r) {
      return new Ot(e, r[0], r[1] || e.one);
    };
    Ot.prototype.inspect = function() {
      return this.isInfinity() ? "<EC Point Infinity>" : "<EC Point x: " + this.x.fromRed().toString(16, 2) + " z: " + this.z.fromRed().toString(16, 2) + ">";
    };
    Ot.prototype.isInfinity = function() {
      return this.z.cmpn(0) === 0;
    };
    Ot.prototype.dbl = function() {
      var e = this.x.redAdd(this.z), r = e.redSqr(), o = this.x.redSub(this.z), f = o.redSqr(), p = r.redSub(f), m3 = r.redMul(f), y3 = p.redMul(f.redAdd(this.curve.a24.redMul(p)));
      return this.curve.point(m3, y3);
    };
    Ot.prototype.add = function() {
      throw new Error("Not supported on Montgomery curve");
    };
    Ot.prototype.diffAdd = function(e, r) {
      var o = this.x.redAdd(this.z), f = this.x.redSub(this.z), p = e.x.redAdd(e.z), m3 = e.x.redSub(e.z), y3 = m3.redMul(o), M = p.redMul(f), x = r.z.redMul(y3.redAdd(M).redSqr()), S = r.x.redMul(y3.redISub(M).redSqr());
      return this.curve.point(x, S);
    };
    Ot.prototype.mul = function(e) {
      for (var r = e.clone(), o = this, f = this.curve.point(null, null), p = this, m3 = [];r.cmpn(0) !== 0; r.iushrn(1))
        m3.push(r.andln(1));
      for (var y3 = m3.length - 1;y3 >= 0; y3--)
        m3[y3] === 0 ? (o = o.diffAdd(f, p), f = f.dbl()) : (f = o.diffAdd(f, p), o = o.dbl());
      return f;
    };
    Ot.prototype.mulAdd = function() {
      throw new Error("Not supported on Montgomery curve");
    };
    Ot.prototype.jumlAdd = function() {
      throw new Error("Not supported on Montgomery curve");
    };
    Ot.prototype.eq = function(e) {
      return this.getX().cmp(e.getX()) === 0;
    };
    Ot.prototype.normalize = function() {
      return this.x = this.x.redMul(this.z.redInvm()), this.z = this.curve.one, this;
    };
    Ot.prototype.getX = function() {
      return this.normalize(), this.x.fromRed();
    };
  });
  _2 = T2((Ak, M2) => {
    var _A = or(), Ai = ri(), w2 = Ie(), Ys = Oa(), xA = _A.assert;
    function ii(t) {
      this.twisted = (t.a | 0) !== 1, this.mOneA = this.twisted && (t.a | 0) === -1, this.extended = this.mOneA, Ys.call(this, "edwards", t), this.a = new Ai(t.a, 16).umod(this.red.m), this.a = this.a.toRed(this.red), this.c = new Ai(t.c, 16).toRed(this.red), this.c2 = this.c.redSqr(), this.d = new Ai(t.d, 16).toRed(this.red), this.dd = this.d.redAdd(this.d), xA(!this.twisted || this.c.fromRed().cmpn(1) === 0), this.oneC = (t.c | 0) === 1;
    }
    w2(ii, Ys);
    M2.exports = ii;
    ii.prototype._mulA = function(e) {
      return this.mOneA ? e.redNeg() : this.a.redMul(e);
    };
    ii.prototype._mulC = function(e) {
      return this.oneC ? e : this.c.redMul(e);
    };
    ii.prototype.jpoint = function(e, r, o, f) {
      return this.point(e, r, o, f);
    };
    ii.prototype.pointFromX = function(e, r) {
      e = new Ai(e, 16), e.red || (e = e.toRed(this.red));
      var o = e.redSqr(), f = this.c2.redSub(this.a.redMul(o)), p = this.one.redSub(this.c2.redMul(this.d).redMul(o)), m2 = f.redMul(p.redInvm()), y3 = m2.redSqrt();
      if (y3.redSqr().redSub(m2).cmp(this.zero) !== 0)
        throw new Error("invalid point");
      var M = y3.fromRed().isOdd();
      return (r && !M || !r && M) && (y3 = y3.redNeg()), this.point(e, y3);
    };
    ii.prototype.pointFromY = function(e, r) {
      e = new Ai(e, 16), e.red || (e = e.toRed(this.red));
      var o = e.redSqr(), f = o.redSub(this.c2), p = o.redMul(this.d).redMul(this.c2).redSub(this.a), m2 = f.redMul(p.redInvm());
      if (m2.cmp(this.zero) === 0) {
        if (r)
          throw new Error("invalid point");
        return this.point(this.zero, e);
      }
      var y3 = m2.redSqrt();
      if (y3.redSqr().redSub(m2).cmp(this.zero) !== 0)
        throw new Error("invalid point");
      return y3.fromRed().isOdd() !== r && (y3 = y3.redNeg()), this.point(y3, e);
    };
    ii.prototype.validate = function(e) {
      if (e.isInfinity())
        return true;
      e.normalize();
      var r = e.x.redSqr(), o = e.y.redSqr(), f = r.redMul(this.a).redAdd(o), p = this.c2.redMul(this.one.redAdd(this.d.redMul(r).redMul(o)));
      return f.cmp(p) === 0;
    };
    function at(t, e, r, o, f) {
      Ys.BasePoint.call(this, t, "projective"), e === null && r === null && o === null ? (this.x = this.curve.zero, this.y = this.curve.one, this.z = this.curve.one, this.t = this.curve.zero, this.zOne = true) : (this.x = new Ai(e, 16), this.y = new Ai(r, 16), this.z = o ? new Ai(o, 16) : this.curve.one, this.t = f && new Ai(f, 16), this.x.red || (this.x = this.x.toRed(this.curve.red)), this.y.red || (this.y = this.y.toRed(this.curve.red)), this.z.red || (this.z = this.z.toRed(this.curve.red)), this.t && !this.t.red && (this.t = this.t.toRed(this.curve.red)), this.zOne = this.z === this.curve.one, this.curve.extended && !this.t && (this.t = this.x.redMul(this.y), this.zOne || (this.t = this.t.redMul(this.z.redInvm()))));
    }
    w2(at, Ys.BasePoint);
    ii.prototype.pointFromJSON = function(e) {
      return at.fromJSON(this, e);
    };
    ii.prototype.point = function(e, r, o, f) {
      return new at(this, e, r, o, f);
    };
    at.fromJSON = function(e, r) {
      return new at(e, r[0], r[1], r[2]);
    };
    at.prototype.inspect = function() {
      return this.isInfinity() ? "<EC Point Infinity>" : "<EC Point x: " + this.x.fromRed().toString(16, 2) + " y: " + this.y.fromRed().toString(16, 2) + " z: " + this.z.fromRed().toString(16, 2) + ">";
    };
    at.prototype.isInfinity = function() {
      return this.x.cmpn(0) === 0 && (this.y.cmp(this.z) === 0 || this.zOne && this.y.cmp(this.curve.c) === 0);
    };
    at.prototype._extDbl = function() {
      var e = this.x.redSqr(), r = this.y.redSqr(), o = this.z.redSqr();
      o = o.redIAdd(o);
      var f = this.curve._mulA(e), p = this.x.redAdd(this.y).redSqr().redISub(e).redISub(r), m2 = f.redAdd(r), y3 = m2.redSub(o), M = f.redSub(r), x = p.redMul(y3), S = m2.redMul(M), E2 = p.redMul(M), B = y3.redMul(m2);
      return this.curve.point(x, S, B, E2);
    };
    at.prototype._projDbl = function() {
      var e = this.x.redAdd(this.y).redSqr(), r = this.x.redSqr(), o = this.y.redSqr(), f, p, m2, y3, M, x;
      if (this.curve.twisted) {
        y3 = this.curve._mulA(r);
        var S = y3.redAdd(o);
        this.zOne ? (f = e.redSub(r).redSub(o).redMul(S.redSub(this.curve.two)), p = S.redMul(y3.redSub(o)), m2 = S.redSqr().redSub(S).redSub(S)) : (M = this.z.redSqr(), x = S.redSub(M).redISub(M), f = e.redSub(r).redISub(o).redMul(x), p = S.redMul(y3.redSub(o)), m2 = S.redMul(x));
      } else
        y3 = r.redAdd(o), M = this.curve._mulC(this.z).redSqr(), x = y3.redSub(M).redSub(M), f = this.curve._mulC(e.redISub(y3)).redMul(x), p = this.curve._mulC(y3).redMul(r.redISub(o)), m2 = y3.redMul(x);
      return this.curve.point(f, p, m2);
    };
    at.prototype.dbl = function() {
      return this.isInfinity() ? this : this.curve.extended ? this._extDbl() : this._projDbl();
    };
    at.prototype._extAdd = function(e) {
      var r = this.y.redSub(this.x).redMul(e.y.redSub(e.x)), o = this.y.redAdd(this.x).redMul(e.y.redAdd(e.x)), f = this.t.redMul(this.curve.dd).redMul(e.t), p = this.z.redMul(e.z.redAdd(e.z)), m2 = o.redSub(r), y3 = p.redSub(f), M = p.redAdd(f), x = o.redAdd(r), S = m2.redMul(y3), E2 = M.redMul(x), B = m2.redMul(x), q2 = y3.redMul(M);
      return this.curve.point(S, E2, q2, B);
    };
    at.prototype._projAdd = function(e) {
      var r = this.z.redMul(e.z), o = r.redSqr(), f = this.x.redMul(e.x), p = this.y.redMul(e.y), m2 = this.curve.d.redMul(f).redMul(p), y3 = o.redSub(m2), M = o.redAdd(m2), x = this.x.redAdd(this.y).redMul(e.x.redAdd(e.y)).redISub(f).redISub(p), S = r.redMul(y3).redMul(x), E2, B;
      return this.curve.twisted ? (E2 = r.redMul(M).redMul(p.redSub(this.curve._mulA(f))), B = y3.redMul(M)) : (E2 = r.redMul(M).redMul(p.redSub(f)), B = this.curve._mulC(y3).redMul(M)), this.curve.point(S, E2, B);
    };
    at.prototype.add = function(e) {
      return this.isInfinity() ? e : e.isInfinity() ? this : this.curve.extended ? this._extAdd(e) : this._projAdd(e);
    };
    at.prototype.mul = function(e) {
      return this._hasDoubles(e) ? this.curve._fixedNafMul(this, e) : this.curve._wnafMul(this, e);
    };
    at.prototype.mulAdd = function(e, r, o) {
      return this.curve._wnafMulAdd(1, [this, r], [e, o], 2, false);
    };
    at.prototype.jmulAdd = function(e, r, o) {
      return this.curve._wnafMulAdd(1, [this, r], [e, o], 2, true);
    };
    at.prototype.normalize = function() {
      if (this.zOne)
        return this;
      var e = this.z.redInvm();
      return this.x = this.x.redMul(e), this.y = this.y.redMul(e), this.t && (this.t = this.t.redMul(e)), this.z = this.curve.one, this.zOne = true, this;
    };
    at.prototype.neg = function() {
      return this.curve.point(this.x.redNeg(), this.y, this.z, this.t && this.t.redNeg());
    };
    at.prototype.getX = function() {
      return this.normalize(), this.x.fromRed();
    };
    at.prototype.getY = function() {
      return this.normalize(), this.y.fromRed();
    };
    at.prototype.eq = function(e) {
      return this === e || this.getX().cmp(e.getX()) === 0 && this.getY().cmp(e.getY()) === 0;
    };
    at.prototype.eqXToP = function(e) {
      var r = e.toRed(this.curve.red).redMul(this.z);
      if (this.x.cmp(r) === 0)
        return true;
      for (var o = e.clone(), f = this.curve.redN.redMul(this.z);; ) {
        if (o.iadd(this.curve.n), o.cmp(this.curve.p) >= 0)
          return false;
        if (r.redIAdd(f), this.x.cmp(r) === 0)
          return true;
      }
    };
    at.prototype.toP = at.prototype.normalize;
    at.prototype.mixedAdd = at.prototype.add;
  });
  Pl = T2((x2) => {
    var Xs = x2;
    Xs.base = Oa();
    Xs.short = b2();
    Xs.mont = y2();
    Xs.edwards = _2();
  });
  Cr = T2((it) => {
    var SA = ar(), EA = Ie();
    it.inherits = EA;
    function AA(t, e) {
      return (t.charCodeAt(e) & 64512) !== 55296 || e < 0 || e + 1 >= t.length ? false : (t.charCodeAt(e + 1) & 64512) === 56320;
    }
    function RA(t, e) {
      if (Array.isArray(t))
        return t.slice();
      if (!t)
        return [];
      var r = [];
      if (typeof t == "string")
        if (e) {
          if (e === "hex")
            for (t = t.replace(/[^a-z0-9]+/ig, ""), t.length % 2 !== 0 && (t = "0" + t), f = 0;f < t.length; f += 2)
              r.push(parseInt(t[f] + t[f + 1], 16));
        } else
          for (var o = 0, f = 0;f < t.length; f++) {
            var p = t.charCodeAt(f);
            p < 128 ? r[o++] = p : p < 2048 ? (r[o++] = p >> 6 | 192, r[o++] = p & 63 | 128) : AA(t, f) ? (p = 65536 + ((p & 1023) << 10) + (t.charCodeAt(++f) & 1023), r[o++] = p >> 18 | 240, r[o++] = p >> 12 & 63 | 128, r[o++] = p >> 6 & 63 | 128, r[o++] = p & 63 | 128) : (r[o++] = p >> 12 | 224, r[o++] = p >> 6 & 63 | 128, r[o++] = p & 63 | 128);
          }
      else
        for (f = 0;f < t.length; f++)
          r[f] = t[f] | 0;
      return r;
    }
    it.toArray = RA;
    function BA(t) {
      for (var e = "", r = 0;r < t.length; r++)
        e += E2(t[r].toString(16));
      return e;
    }
    it.toHex = BA;
    function S2(t) {
      var e = t >>> 24 | t >>> 8 & 65280 | t << 8 & 16711680 | (t & 255) << 24;
      return e >>> 0;
    }
    it.htonl = S2;
    function qA(t, e) {
      for (var r = "", o = 0;o < t.length; o++) {
        var f = t[o];
        e === "little" && (f = S2(f)), r += A2(f.toString(16));
      }
      return r;
    }
    it.toHex32 = qA;
    function E2(t) {
      return t.length === 1 ? "0" + t : t;
    }
    it.zero2 = E2;
    function A2(t) {
      return t.length === 7 ? "0" + t : t.length === 6 ? "00" + t : t.length === 5 ? "000" + t : t.length === 4 ? "0000" + t : t.length === 3 ? "00000" + t : t.length === 2 ? "000000" + t : t.length === 1 ? "0000000" + t : t;
    }
    it.zero8 = A2;
    function IA(t, e, r, o) {
      var f = r - e;
      SA(f % 4 === 0);
      for (var p = new Array(f / 4), m2 = 0, y3 = e;m2 < p.length; m2++, y3 += 4) {
        var M;
        o === "big" ? M = t[y3] << 24 | t[y3 + 1] << 16 | t[y3 + 2] << 8 | t[y3 + 3] : M = t[y3 + 3] << 24 | t[y3 + 2] << 16 | t[y3 + 1] << 8 | t[y3], p[m2] = M >>> 0;
      }
      return p;
    }
    it.join32 = IA;
    function TA(t, e) {
      for (var r = new Array(t.length * 4), o = 0, f = 0;o < t.length; o++, f += 4) {
        var p = t[o];
        e === "big" ? (r[f] = p >>> 24, r[f + 1] = p >>> 16 & 255, r[f + 2] = p >>> 8 & 255, r[f + 3] = p & 255) : (r[f + 3] = p >>> 24, r[f + 2] = p >>> 16 & 255, r[f + 1] = p >>> 8 & 255, r[f] = p & 255);
      }
      return r;
    }
    it.split32 = TA;
    function kA(t, e) {
      return t >>> e | t << 32 - e;
    }
    it.rotr32 = kA;
    function LA(t, e) {
      return t << e | t >>> 32 - e;
    }
    it.rotl32 = LA;
    function NA(t, e) {
      return t + e >>> 0;
    }
    it.sum32 = NA;
    function DA(t, e, r) {
      return t + e + r >>> 0;
    }
    it.sum32_3 = DA;
    function PA(t, e, r, o) {
      return t + e + r + o >>> 0;
    }
    it.sum32_4 = PA;
    function CA(t, e, r, o, f) {
      return t + e + r + o + f >>> 0;
    }
    it.sum32_5 = CA;
    function OA(t, e, r, o) {
      var f = t[e], p = t[e + 1], m2 = o + p >>> 0, y3 = (m2 < o ? 1 : 0) + r + f;
      t[e] = y3 >>> 0, t[e + 1] = m2;
    }
    it.sum64 = OA;
    function FA(t, e, r, o) {
      var f = e + o >>> 0, p = (f < e ? 1 : 0) + t + r;
      return p >>> 0;
    }
    it.sum64_hi = FA;
    function UA(t, e, r, o) {
      var f = e + o;
      return f >>> 0;
    }
    it.sum64_lo = UA;
    function zA(t, e, r, o, f, p, m2, y3) {
      var M = 0, x = e;
      x = x + o >>> 0, M += x < e ? 1 : 0, x = x + p >>> 0, M += x < p ? 1 : 0, x = x + y3 >>> 0, M += x < y3 ? 1 : 0;
      var S = t + r + f + m2 + M;
      return S >>> 0;
    }
    it.sum64_4_hi = zA;
    function HA(t, e, r, o, f, p, m2, y3) {
      var M = e + o + p + y3;
      return M >>> 0;
    }
    it.sum64_4_lo = HA;
    function WA(t, e, r, o, f, p, m2, y3, M, x) {
      var S = 0, E3 = e;
      E3 = E3 + o >>> 0, S += E3 < e ? 1 : 0, E3 = E3 + p >>> 0, S += E3 < p ? 1 : 0, E3 = E3 + y3 >>> 0, S += E3 < y3 ? 1 : 0, E3 = E3 + x >>> 0, S += E3 < x ? 1 : 0;
      var B = t + r + f + m2 + M + S;
      return B >>> 0;
    }
    it.sum64_5_hi = WA;
    function KA(t, e, r, o, f, p, m2, y3, M, x) {
      var S = e + o + p + y3 + x;
      return S >>> 0;
    }
    it.sum64_5_lo = KA;
    function jA(t, e, r) {
      var o = e << 32 - r | t >>> r;
      return o >>> 0;
    }
    it.rotr64_hi = jA;
    function ZA(t, e, r) {
      var o = t << 32 - r | e >>> r;
      return o >>> 0;
    }
    it.rotr64_lo = ZA;
    function VA(t, e, r) {
      return t >>> r;
    }
    it.shr64_hi = VA;
    function $A(t, e, r) {
      var o = t << 32 - r | e >>> r;
      return o >>> 0;
    }
    it.shr64_lo = $A;
  });
  Tf = T2((B2) => {
    var R2 = Cr(), GA = ar();
    function Js() {
      this.pending = null, this.pendingTotal = 0, this.blockSize = this.constructor.blockSize, this.outSize = this.constructor.outSize, this.hmacStrength = this.constructor.hmacStrength, this.padLength = this.constructor.padLength / 8, this.endian = "big", this._delta8 = this.blockSize / 8, this._delta32 = this.blockSize / 32;
    }
    B2.BlockHash = Js;
    Js.prototype.update = function(e, r) {
      if (e = R2.toArray(e, r), this.pending ? this.pending = this.pending.concat(e) : this.pending = e, this.pendingTotal += e.length, this.pending.length >= this._delta8) {
        e = this.pending;
        var o = e.length % this._delta8;
        this.pending = e.slice(e.length - o, e.length), this.pending.length === 0 && (this.pending = null), e = R2.join32(e, 0, e.length - o, this.endian);
        for (var f = 0;f < e.length; f += this._delta32)
          this._update(e, f, f + this._delta32);
      }
      return this;
    };
    Js.prototype.digest = function(e) {
      return this.update(this._pad()), GA(this.pending === null), this._digest(e);
    };
    Js.prototype._pad = function() {
      var e = this.pendingTotal, r = this._delta8, o = r - (e + this.padLength) % r, f = new Array(o + this.padLength);
      f[0] = 128;
      for (var p = 1;p < o; p++)
        f[p] = 0;
      if (e <<= 3, this.endian === "big") {
        for (var m2 = 8;m2 < this.padLength; m2++)
          f[p++] = 0;
        f[p++] = 0, f[p++] = 0, f[p++] = 0, f[p++] = 0, f[p++] = e >>> 24 & 255, f[p++] = e >>> 16 & 255, f[p++] = e >>> 8 & 255, f[p++] = e & 255;
      } else
        for (f[p++] = e & 255, f[p++] = e >>> 8 & 255, f[p++] = e >>> 16 & 255, f[p++] = e >>> 24 & 255, f[p++] = 0, f[p++] = 0, f[p++] = 0, f[p++] = 0, m2 = 8;m2 < this.padLength; m2++)
          f[p++] = 0;
      return f;
    };
  });
  Cl = T2((Ri) => {
    var YA = Cr(), ni = YA.rotr32;
    function XA(t, e, r, o) {
      if (t === 0)
        return q2(e, r, o);
      if (t === 1 || t === 3)
        return T22(e, r, o);
      if (t === 2)
        return I2(e, r, o);
    }
    Ri.ft_1 = XA;
    function q2(t, e, r) {
      return t & e ^ ~t & r;
    }
    Ri.ch32 = q2;
    function I2(t, e, r) {
      return t & e ^ t & r ^ e & r;
    }
    Ri.maj32 = I2;
    function T22(t, e, r) {
      return t ^ e ^ r;
    }
    Ri.p32 = T22;
    function JA(t) {
      return ni(t, 2) ^ ni(t, 13) ^ ni(t, 22);
    }
    Ri.s0_256 = JA;
    function QA(t) {
      return ni(t, 6) ^ ni(t, 11) ^ ni(t, 25);
    }
    Ri.s1_256 = QA;
    function eR(t) {
      return ni(t, 7) ^ ni(t, 18) ^ t >>> 3;
    }
    Ri.g0_256 = eR;
    function tR(t) {
      return ni(t, 17) ^ ni(t, 19) ^ t >>> 10;
    }
    Ri.g1_256 = tR;
  });
  N2 = T2((Tk, L2) => {
    var kf = Cr(), rR = Tf(), iR = Cl(), Ol = kf.rotl32, Fa = kf.sum32, nR = kf.sum32_5, fR = iR.ft_1, k2 = rR.BlockHash, aR = [1518500249, 1859775393, 2400959708, 3395469782];
    function fi() {
      if (!(this instanceof fi))
        return new fi;
      k2.call(this), this.h = [1732584193, 4023233417, 2562383102, 271733878, 3285377520], this.W = new Array(80);
    }
    kf.inherits(fi, k2);
    L2.exports = fi;
    fi.blockSize = 512;
    fi.outSize = 160;
    fi.hmacStrength = 80;
    fi.padLength = 64;
    fi.prototype._update = function(e, r) {
      for (var o = this.W, f = 0;f < 16; f++)
        o[f] = e[r + f];
      for (;f < o.length; f++)
        o[f] = Ol(o[f - 3] ^ o[f - 8] ^ o[f - 14] ^ o[f - 16], 1);
      var p = this.h[0], m2 = this.h[1], y3 = this.h[2], M = this.h[3], x = this.h[4];
      for (f = 0;f < o.length; f++) {
        var S = ~~(f / 20), E2 = nR(Ol(p, 5), fR(S, m2, y3, M), x, o[f], aR[S]);
        x = M, M = y3, y3 = Ol(m2, 30), m2 = p, p = E2;
      }
      this.h[0] = Fa(this.h[0], p), this.h[1] = Fa(this.h[1], m2), this.h[2] = Fa(this.h[2], y3), this.h[3] = Fa(this.h[3], M), this.h[4] = Fa(this.h[4], x);
    };
    fi.prototype._digest = function(e) {
      return e === "hex" ? kf.toHex32(this.h, "big") : kf.split32(this.h, "big");
    };
  });
  Fl = T2((kk, P2) => {
    var Lf = Cr(), oR = Tf(), Nf = Cl(), sR = ar(), Or = Lf.sum32, hR = Lf.sum32_4, uR = Lf.sum32_5, lR = Nf.ch32, dR = Nf.maj32, cR = Nf.s0_256, pR = Nf.s1_256, vR = Nf.g0_256, bR = Nf.g1_256, D2 = oR.BlockHash, mR = [1116352408, 1899447441, 3049323471, 3921009573, 961987163, 1508970993, 2453635748, 2870763221, 3624381080, 310598401, 607225278, 1426881987, 1925078388, 2162078206, 2614888103, 3248222580, 3835390401, 4022224774, 264347078, 604807628, 770255983, 1249150122, 1555081692, 1996064986, 2554220882, 2821834349, 2952996808, 3210313671, 3336571891, 3584528711, 113926993, 338241895, 666307205, 773529912, 1294757372, 1396182291, 1695183700, 1986661051, 2177026350, 2456956037, 2730485921, 2820302411, 3259730800, 3345764771, 3516065817, 3600352804, 4094571909, 275423344, 430227734, 506948616, 659060556, 883997877, 958139571, 1322822218, 1537002063, 1747873779, 1955562222, 2024104815, 2227730452, 2361852424, 2428436474, 2756734187, 3204031479, 3329325298];
    function ai() {
      if (!(this instanceof ai))
        return new ai;
      D2.call(this), this.h = [1779033703, 3144134277, 1013904242, 2773480762, 1359893119, 2600822924, 528734635, 1541459225], this.k = mR, this.W = new Array(64);
    }
    Lf.inherits(ai, D2);
    P2.exports = ai;
    ai.blockSize = 512;
    ai.outSize = 256;
    ai.hmacStrength = 192;
    ai.padLength = 64;
    ai.prototype._update = function(e, r) {
      for (var o = this.W, f = 0;f < 16; f++)
        o[f] = e[r + f];
      for (;f < o.length; f++)
        o[f] = hR(bR(o[f - 2]), o[f - 7], vR(o[f - 15]), o[f - 16]);
      var p = this.h[0], m2 = this.h[1], y3 = this.h[2], M = this.h[3], x = this.h[4], S = this.h[5], E2 = this.h[6], B = this.h[7];
      for (sR(this.k.length === o.length), f = 0;f < o.length; f++) {
        var q2 = uR(B, pR(x), lR(x, S, E2), this.k[f], o[f]), L2 = Or(cR(p), dR(p, m2, y3));
        B = E2, E2 = S, S = x, x = Or(M, q2), M = y3, y3 = m2, m2 = p, p = Or(q2, L2);
      }
      this.h[0] = Or(this.h[0], p), this.h[1] = Or(this.h[1], m2), this.h[2] = Or(this.h[2], y3), this.h[3] = Or(this.h[3], M), this.h[4] = Or(this.h[4], x), this.h[5] = Or(this.h[5], S), this.h[6] = Or(this.h[6], E2), this.h[7] = Or(this.h[7], B);
    };
    ai.prototype._digest = function(e) {
      return e === "hex" ? Lf.toHex32(this.h, "big") : Lf.split32(this.h, "big");
    };
  });
  F2 = T2((Lk, O2) => {
    var Ul = Cr(), C2 = Fl();
    function Bi() {
      if (!(this instanceof Bi))
        return new Bi;
      C2.call(this), this.h = [3238371032, 914150663, 812702999, 4144912697, 4290775857, 1750603025, 1694076839, 3204075428];
    }
    Ul.inherits(Bi, C2);
    O2.exports = Bi;
    Bi.blockSize = 512;
    Bi.outSize = 224;
    Bi.hmacStrength = 192;
    Bi.padLength = 64;
    Bi.prototype._digest = function(e) {
      return e === "hex" ? Ul.toHex32(this.h.slice(0, 7), "big") : Ul.split32(this.h.slice(0, 7), "big");
    };
  });
  Wl = T2((Nk, W2) => {
    var ir = Cr(), gR = Tf(), yR = ar(), oi = ir.rotr64_hi, si = ir.rotr64_lo, U2 = ir.shr64_hi, z2 = ir.shr64_lo, Ji = ir.sum64, zl = ir.sum64_hi, Hl = ir.sum64_lo, wR = ir.sum64_4_hi, MR = ir.sum64_4_lo, _R = ir.sum64_5_hi, xR = ir.sum64_5_lo, H2 = gR.BlockHash, SR = [1116352408, 3609767458, 1899447441, 602891725, 3049323471, 3964484399, 3921009573, 2173295548, 961987163, 4081628472, 1508970993, 3053834265, 2453635748, 2937671579, 2870763221, 3664609560, 3624381080, 2734883394, 310598401, 1164996542, 607225278, 1323610764, 1426881987, 3590304994, 1925078388, 4068182383, 2162078206, 991336113, 2614888103, 633803317, 3248222580, 3479774868, 3835390401, 2666613458, 4022224774, 944711139, 264347078, 2341262773, 604807628, 2007800933, 770255983, 1495990901, 1249150122, 1856431235, 1555081692, 3175218132, 1996064986, 2198950837, 2554220882, 3999719339, 2821834349, 766784016, 2952996808, 2566594879, 3210313671, 3203337956, 3336571891, 1034457026, 3584528711, 2466948901, 113926993, 3758326383, 338241895, 168717936, 666307205, 1188179964, 773529912, 1546045734, 1294757372, 1522805485, 1396182291, 2643833823, 1695183700, 2343527390, 1986661051, 1014477480, 2177026350, 1206759142, 2456956037, 344077627, 2730485921, 1290863460, 2820302411, 3158454273, 3259730800, 3505952657, 3345764771, 106217008, 3516065817, 3606008344, 3600352804, 1432725776, 4094571909, 1467031594, 275423344, 851169720, 430227734, 3100823752, 506948616, 1363258195, 659060556, 3750685593, 883997877, 3785050280, 958139571, 3318307427, 1322822218, 3812723403, 1537002063, 2003034995, 1747873779, 3602036899, 1955562222, 1575990012, 2024104815, 1125592928, 2227730452, 2716904306, 2361852424, 442776044, 2428436474, 593698344, 2756734187, 3733110249, 3204031479, 2999351573, 3329325298, 3815920427, 3391569614, 3928383900, 3515267271, 566280711, 3940187606, 3454069534, 4118630271, 4000239992, 116418474, 1914138554, 174292421, 2731055270, 289380356, 3203993006, 460393269, 320620315, 685471733, 587496836, 852142971, 1086792851, 1017036298, 365543100, 1126000580, 2618297676, 1288033470, 3409855158, 1501505948, 4234509866, 1607167915, 987167468, 1816402316, 1246189591];
    function Fr() {
      if (!(this instanceof Fr))
        return new Fr;
      H2.call(this), this.h = [1779033703, 4089235720, 3144134277, 2227873595, 1013904242, 4271175723, 2773480762, 1595750129, 1359893119, 2917565137, 2600822924, 725511199, 528734635, 4215389547, 1541459225, 327033209], this.k = SR, this.W = new Array(160);
    }
    ir.inherits(Fr, H2);
    W2.exports = Fr;
    Fr.blockSize = 1024;
    Fr.outSize = 512;
    Fr.hmacStrength = 192;
    Fr.padLength = 128;
    Fr.prototype._prepareBlock = function(e, r) {
      for (var o = this.W, f = 0;f < 32; f++)
        o[f] = e[r + f];
      for (;f < o.length; f += 2) {
        var p = DR(o[f - 4], o[f - 3]), m2 = PR(o[f - 4], o[f - 3]), y3 = o[f - 14], M = o[f - 13], x = LR(o[f - 30], o[f - 29]), S = NR(o[f - 30], o[f - 29]), E2 = o[f - 32], B = o[f - 31];
        o[f] = wR(p, m2, y3, M, x, S, E2, B), o[f + 1] = MR(p, m2, y3, M, x, S, E2, B);
      }
    };
    Fr.prototype._update = function(e, r) {
      this._prepareBlock(e, r);
      var o = this.W, f = this.h[0], p = this.h[1], m2 = this.h[2], y3 = this.h[3], M = this.h[4], x = this.h[5], S = this.h[6], E2 = this.h[7], B = this.h[8], q2 = this.h[9], L2 = this.h[10], ge = this.h[11], _e = this.h[12], N = this.h[13], we = this.h[14], ye = this.h[15];
      yR(this.k.length === o.length);
      for (var xe = 0;xe < o.length; xe += 2) {
        var Re = we, Ee = ye, Ae = TR(B, q2), P = kR(B, q2), Se = ER(B, q2, L2, ge, _e, N), v = AR(B, q2, L2, ge, _e, N), i = this.k[xe], a = this.k[xe + 1], h2 = o[xe], s = o[xe + 1], u = _R(Re, Ee, Ae, P, Se, v, i, a, h2, s), c = xR(Re, Ee, Ae, P, Se, v, i, a, h2, s);
        Re = qR(f, p), Ee = IR(f, p), Ae = RR(f, p, m2, y3, M, x), P = BR(f, p, m2, y3, M, x);
        var b3 = zl(Re, Ee, Ae, P), l = Hl(Re, Ee, Ae, P);
        we = _e, ye = N, _e = L2, N = ge, L2 = B, ge = q2, B = zl(S, E2, u, c), q2 = Hl(E2, E2, u, c), S = M, E2 = x, M = m2, x = y3, m2 = f, y3 = p, f = zl(u, c, b3, l), p = Hl(u, c, b3, l);
      }
      Ji(this.h, 0, f, p), Ji(this.h, 2, m2, y3), Ji(this.h, 4, M, x), Ji(this.h, 6, S, E2), Ji(this.h, 8, B, q2), Ji(this.h, 10, L2, ge), Ji(this.h, 12, _e, N), Ji(this.h, 14, we, ye);
    };
    Fr.prototype._digest = function(e) {
      return e === "hex" ? ir.toHex32(this.h, "big") : ir.split32(this.h, "big");
    };
    function ER(t, e, r, o, f) {
      var p = t & r ^ ~t & f;
      return p < 0 && (p += 4294967296), p;
    }
    function AR(t, e, r, o, f, p) {
      var m2 = e & o ^ ~e & p;
      return m2 < 0 && (m2 += 4294967296), m2;
    }
    function RR(t, e, r, o, f) {
      var p = t & r ^ t & f ^ r & f;
      return p < 0 && (p += 4294967296), p;
    }
    function BR(t, e, r, o, f, p) {
      var m2 = e & o ^ e & p ^ o & p;
      return m2 < 0 && (m2 += 4294967296), m2;
    }
    function qR(t, e) {
      var r = oi(t, e, 28), o = oi(e, t, 2), f = oi(e, t, 7), p = r ^ o ^ f;
      return p < 0 && (p += 4294967296), p;
    }
    function IR(t, e) {
      var r = si(t, e, 28), o = si(e, t, 2), f = si(e, t, 7), p = r ^ o ^ f;
      return p < 0 && (p += 4294967296), p;
    }
    function TR(t, e) {
      var r = oi(t, e, 14), o = oi(t, e, 18), f = oi(e, t, 9), p = r ^ o ^ f;
      return p < 0 && (p += 4294967296), p;
    }
    function kR(t, e) {
      var r = si(t, e, 14), o = si(t, e, 18), f = si(e, t, 9), p = r ^ o ^ f;
      return p < 0 && (p += 4294967296), p;
    }
    function LR(t, e) {
      var r = oi(t, e, 1), o = oi(t, e, 8), f = U2(t, e, 7), p = r ^ o ^ f;
      return p < 0 && (p += 4294967296), p;
    }
    function NR(t, e) {
      var r = si(t, e, 1), o = si(t, e, 8), f = z2(t, e, 7), p = r ^ o ^ f;
      return p < 0 && (p += 4294967296), p;
    }
    function DR(t, e) {
      var r = oi(t, e, 19), o = oi(e, t, 29), f = U2(t, e, 6), p = r ^ o ^ f;
      return p < 0 && (p += 4294967296), p;
    }
    function PR(t, e) {
      var r = si(t, e, 19), o = si(e, t, 29), f = z2(t, e, 6), p = r ^ o ^ f;
      return p < 0 && (p += 4294967296), p;
    }
  });
  Z2 = T2((Dk, j2) => {
    var Kl = Cr(), K2 = Wl();
    function qi() {
      if (!(this instanceof qi))
        return new qi;
      K2.call(this), this.h = [3418070365, 3238371032, 1654270250, 914150663, 2438529370, 812702999, 355462360, 4144912697, 1731405415, 4290775857, 2394180231, 1750603025, 3675008525, 1694076839, 1203062813, 3204075428];
    }
    Kl.inherits(qi, K2);
    j2.exports = qi;
    qi.blockSize = 1024;
    qi.outSize = 384;
    qi.hmacStrength = 192;
    qi.padLength = 128;
    qi.prototype._digest = function(e) {
      return e === "hex" ? Kl.toHex32(this.h.slice(0, 12), "big") : Kl.split32(this.h.slice(0, 12), "big");
    };
  });
  V2 = T2((Df) => {
    Df.sha1 = N2();
    Df.sha224 = F2();
    Df.sha256 = Fl();
    Df.sha384 = Z2();
    Df.sha512 = Wl();
  });
  Q2 = T2((J2) => {
    var On = Cr(), CR = Tf(), Qs = On.rotl32, $2 = On.sum32, Ua = On.sum32_3, G2 = On.sum32_4, X2 = CR.BlockHash;
    function hi() {
      if (!(this instanceof hi))
        return new hi;
      X2.call(this), this.h = [1732584193, 4023233417, 2562383102, 271733878, 3285377520], this.endian = "little";
    }
    On.inherits(hi, X2);
    J2.ripemd160 = hi;
    hi.blockSize = 512;
    hi.outSize = 160;
    hi.hmacStrength = 192;
    hi.padLength = 64;
    hi.prototype._update = function(e, r) {
      for (var o = this.h[0], f = this.h[1], p = this.h[2], m2 = this.h[3], y3 = this.h[4], M = o, x = f, S = p, E2 = m2, B = y3, q2 = 0;q2 < 80; q2++) {
        var L2 = $2(Qs(G2(o, Y2(q2, f, p, m2), e[UR[q2] + r], OR(q2)), HR[q2]), y3);
        o = y3, y3 = m2, m2 = Qs(p, 10), p = f, f = L2, L2 = $2(Qs(G2(M, Y2(79 - q2, x, S, E2), e[zR[q2] + r], FR(q2)), WR[q2]), B), M = B, B = E2, E2 = Qs(S, 10), S = x, x = L2;
      }
      L2 = Ua(this.h[1], p, E2), this.h[1] = Ua(this.h[2], m2, B), this.h[2] = Ua(this.h[3], y3, M), this.h[3] = Ua(this.h[4], o, x), this.h[4] = Ua(this.h[0], f, S), this.h[0] = L2;
    };
    hi.prototype._digest = function(e) {
      return e === "hex" ? On.toHex32(this.h, "little") : On.split32(this.h, "little");
    };
    function Y2(t, e, r, o) {
      return t <= 15 ? e ^ r ^ o : t <= 31 ? e & r | ~e & o : t <= 47 ? (e | ~r) ^ o : t <= 63 ? e & o | r & ~o : e ^ (r | ~o);
    }
    function OR(t) {
      return t <= 15 ? 0 : t <= 31 ? 1518500249 : t <= 47 ? 1859775393 : t <= 63 ? 2400959708 : 2840853838;
    }
    function FR(t) {
      return t <= 15 ? 1352829926 : t <= 31 ? 1548603684 : t <= 47 ? 1836072691 : t <= 63 ? 2053994217 : 0;
    }
    var UR = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8, 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12, 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2, 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13], zR = [5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12, 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2, 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13, 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14, 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11], HR = [11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8, 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12, 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5, 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12, 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6], WR = [8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6, 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11, 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5, 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8, 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11];
  });
  ty = T2((Ok, ey) => {
    var KR = Cr(), jR = ar();
    function Pf(t, e, r) {
      if (!(this instanceof Pf))
        return new Pf(t, e, r);
      this.Hash = t, this.blockSize = t.blockSize / 8, this.outSize = t.outSize / 8, this.inner = null, this.outer = null, this._init(KR.toArray(e, r));
    }
    ey.exports = Pf;
    Pf.prototype._init = function(e) {
      e.length > this.blockSize && (e = new this.Hash().update(e).digest()), jR(e.length <= this.blockSize);
      for (var r = e.length;r < this.blockSize; r++)
        e.push(0);
      for (r = 0;r < e.length; r++)
        e[r] ^= 54;
      for (this.inner = new this.Hash().update(e), r = 0;r < e.length; r++)
        e[r] ^= 106;
      this.outer = new this.Hash().update(e);
    };
    Pf.prototype.update = function(e, r) {
      return this.inner.update(e, r), this;
    };
    Pf.prototype.digest = function(e) {
      return this.outer.update(this.inner.digest()), this.outer.digest(e);
    };
  });
  e0 = T2((ry) => {
    var Kt = ry;
    Kt.utils = Cr();
    Kt.common = Tf();
    Kt.sha = V2();
    Kt.ripemd = Q2();
    Kt.hmac = ty();
    Kt.sha1 = Kt.sha.sha1;
    Kt.sha256 = Kt.sha.sha256;
    Kt.sha224 = Kt.sha.sha224;
    Kt.sha384 = Kt.sha.sha384;
    Kt.sha512 = Kt.sha.sha512;
    Kt.ripemd160 = Kt.ripemd.ripemd160;
  });
  ny = T2((Uk, iy) => {
    iy.exports = { doubles: { step: 4, points: [["e60fce93b59e9ec53011aabc21c23e97b2a31369b87a5ae9c44ee89e2a6dec0a", "f7e3507399e595929db99f34f57937101296891e44d23f0be1f32cce69616821"], ["8282263212c609d9ea2a6e3e172de238d8c39cabd5ac1ca10646e23fd5f51508", "11f8a8098557dfe45e8256e830b60ace62d613ac2f7b17bed31b6eaff6e26caf"], ["175e159f728b865a72f99cc6c6fc846de0b93833fd2222ed73fce5b551e5b739", "d3506e0d9e3c79eba4ef97a51ff71f5eacb5955add24345c6efa6ffee9fed695"], ["363d90d447b00c9c99ceac05b6262ee053441c7e55552ffe526bad8f83ff4640", "4e273adfc732221953b445397f3363145b9a89008199ecb62003c7f3bee9de9"], ["8b4b5f165df3c2be8c6244b5b745638843e4a781a15bcd1b69f79a55dffdf80c", "4aad0a6f68d308b4b3fbd7813ab0da04f9e336546162ee56b3eff0c65fd4fd36"], ["723cbaa6e5db996d6bf771c00bd548c7b700dbffa6c0e77bcb6115925232fcda", "96e867b5595cc498a921137488824d6e2660a0653779494801dc069d9eb39f5f"], ["eebfa4d493bebf98ba5feec812c2d3b50947961237a919839a533eca0e7dd7fa", "5d9a8ca3970ef0f269ee7edaf178089d9ae4cdc3a711f712ddfd4fdae1de8999"], ["100f44da696e71672791d0a09b7bde459f1215a29b3c03bfefd7835b39a48db0", "cdd9e13192a00b772ec8f3300c090666b7ff4a18ff5195ac0fbd5cd62bc65a09"], ["e1031be262c7ed1b1dc9227a4a04c017a77f8d4464f3b3852c8acde6e534fd2d", "9d7061928940405e6bb6a4176597535af292dd419e1ced79a44f18f29456a00d"], ["feea6cae46d55b530ac2839f143bd7ec5cf8b266a41d6af52d5e688d9094696d", "e57c6b6c97dce1bab06e4e12bf3ecd5c981c8957cc41442d3155debf18090088"], ["da67a91d91049cdcb367be4be6ffca3cfeed657d808583de33fa978bc1ec6cb1", "9bacaa35481642bc41f463f7ec9780e5dec7adc508f740a17e9ea8e27a68be1d"], ["53904faa0b334cdda6e000935ef22151ec08d0f7bb11069f57545ccc1a37b7c0", "5bc087d0bc80106d88c9eccac20d3c1c13999981e14434699dcb096b022771c8"], ["8e7bcd0bd35983a7719cca7764ca906779b53a043a9b8bcaeff959f43ad86047", "10b7770b2a3da4b3940310420ca9514579e88e2e47fd68b3ea10047e8460372a"], ["385eed34c1cdff21e6d0818689b81bde71a7f4f18397e6690a841e1599c43862", "283bebc3e8ea23f56701de19e9ebf4576b304eec2086dc8cc0458fe5542e5453"], ["6f9d9b803ecf191637c73a4413dfa180fddf84a5947fbc9c606ed86c3fac3a7", "7c80c68e603059ba69b8e2a30e45c4d47ea4dd2f5c281002d86890603a842160"], ["3322d401243c4e2582a2147c104d6ecbf774d163db0f5e5313b7e0e742d0e6bd", "56e70797e9664ef5bfb019bc4ddaf9b72805f63ea2873af624f3a2e96c28b2a0"], ["85672c7d2de0b7da2bd1770d89665868741b3f9af7643397721d74d28134ab83", "7c481b9b5b43b2eb6374049bfa62c2e5e77f17fcc5298f44c8e3094f790313a6"], ["948bf809b1988a46b06c9f1919413b10f9226c60f668832ffd959af60c82a0a", "53a562856dcb6646dc6b74c5d1c3418c6d4dff08c97cd2bed4cb7f88d8c8e589"], ["6260ce7f461801c34f067ce0f02873a8f1b0e44dfc69752accecd819f38fd8e8", "bc2da82b6fa5b571a7f09049776a1ef7ecd292238051c198c1a84e95b2b4ae17"], ["e5037de0afc1d8d43d8348414bbf4103043ec8f575bfdc432953cc8d2037fa2d", "4571534baa94d3b5f9f98d09fb990bddbd5f5b03ec481f10e0e5dc841d755bda"], ["e06372b0f4a207adf5ea905e8f1771b4e7e8dbd1c6a6c5b725866a0ae4fce725", "7a908974bce18cfe12a27bb2ad5a488cd7484a7787104870b27034f94eee31dd"], ["213c7a715cd5d45358d0bbf9dc0ce02204b10bdde2a3f58540ad6908d0559754", "4b6dad0b5ae462507013ad06245ba190bb4850f5f36a7eeddff2c27534b458f2"], ["4e7c272a7af4b34e8dbb9352a5419a87e2838c70adc62cddf0cc3a3b08fbd53c", "17749c766c9d0b18e16fd09f6def681b530b9614bff7dd33e0b3941817dcaae6"], ["fea74e3dbe778b1b10f238ad61686aa5c76e3db2be43057632427e2840fb27b6", "6e0568db9b0b13297cf674deccb6af93126b596b973f7b77701d3db7f23cb96f"], ["76e64113f677cf0e10a2570d599968d31544e179b760432952c02a4417bdde39", "c90ddf8dee4e95cf577066d70681f0d35e2a33d2b56d2032b4b1752d1901ac01"], ["c738c56b03b2abe1e8281baa743f8f9a8f7cc643df26cbee3ab150242bcbb891", "893fb578951ad2537f718f2eacbfbbbb82314eef7880cfe917e735d9699a84c3"], ["d895626548b65b81e264c7637c972877d1d72e5f3a925014372e9f6588f6c14b", "febfaa38f2bc7eae728ec60818c340eb03428d632bb067e179363ed75d7d991f"], ["b8da94032a957518eb0f6433571e8761ceffc73693e84edd49150a564f676e03", "2804dfa44805a1e4d7c99cc9762808b092cc584d95ff3b511488e4e74efdf6e7"], ["e80fea14441fb33a7d8adab9475d7fab2019effb5156a792f1a11778e3c0df5d", "eed1de7f638e00771e89768ca3ca94472d155e80af322ea9fcb4291b6ac9ec78"], ["a301697bdfcd704313ba48e51d567543f2a182031efd6915ddc07bbcc4e16070", "7370f91cfb67e4f5081809fa25d40f9b1735dbf7c0a11a130c0d1a041e177ea1"], ["90ad85b389d6b936463f9d0512678de208cc330b11307fffab7ac63e3fb04ed4", "e507a3620a38261affdcbd9427222b839aefabe1582894d991d4d48cb6ef150"], ["8f68b9d2f63b5f339239c1ad981f162ee88c5678723ea3351b7b444c9ec4c0da", "662a9f2dba063986de1d90c2b6be215dbbea2cfe95510bfdf23cbf79501fff82"], ["e4f3fb0176af85d65ff99ff9198c36091f48e86503681e3e6686fd5053231e11", "1e63633ad0ef4f1c1661a6d0ea02b7286cc7e74ec951d1c9822c38576feb73bc"], ["8c00fa9b18ebf331eb961537a45a4266c7034f2f0d4e1d0716fb6eae20eae29e", "efa47267fea521a1a9dc343a3736c974c2fadafa81e36c54e7d2a4c66702414b"], ["e7a26ce69dd4829f3e10cec0a9e98ed3143d084f308b92c0997fddfc60cb3e41", "2a758e300fa7984b471b006a1aafbb18d0a6b2c0420e83e20e8a9421cf2cfd51"], ["b6459e0ee3662ec8d23540c223bcbdc571cbcb967d79424f3cf29eb3de6b80ef", "67c876d06f3e06de1dadf16e5661db3c4b3ae6d48e35b2ff30bf0b61a71ba45"], ["d68a80c8280bb840793234aa118f06231d6f1fc67e73c5a5deda0f5b496943e8", "db8ba9fff4b586d00c4b1f9177b0e28b5b0e7b8f7845295a294c84266b133120"], ["324aed7df65c804252dc0270907a30b09612aeb973449cea4095980fc28d3d5d", "648a365774b61f2ff130c0c35aec1f4f19213b0c7e332843967224af96ab7c84"], ["4df9c14919cde61f6d51dfdbe5fee5dceec4143ba8d1ca888e8bd373fd054c96", "35ec51092d8728050974c23a1d85d4b5d506cdc288490192ebac06cad10d5d"], ["9c3919a84a474870faed8a9c1cc66021523489054d7f0308cbfc99c8ac1f98cd", "ddb84f0f4a4ddd57584f044bf260e641905326f76c64c8e6be7e5e03d4fc599d"], ["6057170b1dd12fdf8de05f281d8e06bb91e1493a8b91d4cc5a21382120a959e5", "9a1af0b26a6a4807add9a2daf71df262465152bc3ee24c65e899be932385a2a8"], ["a576df8e23a08411421439a4518da31880cef0fba7d4df12b1a6973eecb94266", "40a6bf20e76640b2c92b97afe58cd82c432e10a7f514d9f3ee8be11ae1b28ec8"], ["7778a78c28dec3e30a05fe9629de8c38bb30d1f5cf9a3a208f763889be58ad71", "34626d9ab5a5b22ff7098e12f2ff580087b38411ff24ac563b513fc1fd9f43ac"], ["928955ee637a84463729fd30e7afd2ed5f96274e5ad7e5cb09eda9c06d903ac", "c25621003d3f42a827b78a13093a95eeac3d26efa8a8d83fc5180e935bcd091f"], ["85d0fef3ec6db109399064f3a0e3b2855645b4a907ad354527aae75163d82751", "1f03648413a38c0be29d496e582cf5663e8751e96877331582c237a24eb1f962"], ["ff2b0dce97eece97c1c9b6041798b85dfdfb6d8882da20308f5404824526087e", "493d13fef524ba188af4c4dc54d07936c7b7ed6fb90e2ceb2c951e01f0c29907"], ["827fbbe4b1e880ea9ed2b2e6301b212b57f1ee148cd6dd28780e5e2cf856e241", "c60f9c923c727b0b71bef2c67d1d12687ff7a63186903166d605b68baec293ec"], ["eaa649f21f51bdbae7be4ae34ce6e5217a58fdce7f47f9aa7f3b58fa2120e2b3", "be3279ed5bbbb03ac69a80f89879aa5a01a6b965f13f7e59d47a5305ba5ad93d"], ["e4a42d43c5cf169d9391df6decf42ee541b6d8f0c9a137401e23632dda34d24f", "4d9f92e716d1c73526fc99ccfb8ad34ce886eedfa8d8e4f13a7f7131deba9414"], ["1ec80fef360cbdd954160fadab352b6b92b53576a88fea4947173b9d4300bf19", "aeefe93756b5340d2f3a4958a7abbf5e0146e77f6295a07b671cdc1cc107cefd"], ["146a778c04670c2f91b00af4680dfa8bce3490717d58ba889ddb5928366642be", "b318e0ec3354028add669827f9d4b2870aaa971d2f7e5ed1d0b297483d83efd0"], ["fa50c0f61d22e5f07e3acebb1aa07b128d0012209a28b9776d76a8793180eef9", "6b84c6922397eba9b72cd2872281a68a5e683293a57a213b38cd8d7d3f4f2811"], ["da1d61d0ca721a11b1a5bf6b7d88e8421a288ab5d5bba5220e53d32b5f067ec2", "8157f55a7c99306c79c0766161c91e2966a73899d279b48a655fba0f1ad836f1"], ["a8e282ff0c9706907215ff98e8fd416615311de0446f1e062a73b0610d064e13", "7f97355b8db81c09abfb7f3c5b2515888b679a3e50dd6bd6cef7c73111f4cc0c"], ["174a53b9c9a285872d39e56e6913cab15d59b1fa512508c022f382de8319497c", "ccc9dc37abfc9c1657b4155f2c47f9e6646b3a1d8cb9854383da13ac079afa73"], ["959396981943785c3d3e57edf5018cdbe039e730e4918b3d884fdff09475b7ba", "2e7e552888c331dd8ba0386a4b9cd6849c653f64c8709385e9b8abf87524f2fd"], ["d2a63a50ae401e56d645a1153b109a8fcca0a43d561fba2dbb51340c9d82b151", "e82d86fb6443fcb7565aee58b2948220a70f750af484ca52d4142174dcf89405"], ["64587e2335471eb890ee7896d7cfdc866bacbdbd3839317b3436f9b45617e073", "d99fcdd5bf6902e2ae96dd6447c299a185b90a39133aeab358299e5e9faf6589"], ["8481bde0e4e4d885b3a546d3e549de042f0aa6cea250e7fd358d6c86dd45e458", "38ee7b8cba5404dd84a25bf39cecb2ca900a79c42b262e556d64b1b59779057e"], ["13464a57a78102aa62b6979ae817f4637ffcfed3c4b1ce30bcd6303f6caf666b", "69be159004614580ef7e433453ccb0ca48f300a81d0942e13f495a907f6ecc27"], ["bc4a9df5b713fe2e9aef430bcc1dc97a0cd9ccede2f28588cada3a0d2d83f366", "d3a81ca6e785c06383937adf4b798caa6e8a9fbfa547b16d758d666581f33c1"], ["8c28a97bf8298bc0d23d8c749452a32e694b65e30a9472a3954ab30fe5324caa", "40a30463a3305193378fedf31f7cc0eb7ae784f0451cb9459e71dc73cbef9482"], ["8ea9666139527a8c1dd94ce4f071fd23c8b350c5a4bb33748c4ba111faccae0", "620efabbc8ee2782e24e7c0cfb95c5d735b783be9cf0f8e955af34a30e62b945"], ["dd3625faef5ba06074669716bbd3788d89bdde815959968092f76cc4eb9a9787", "7a188fa3520e30d461da2501045731ca941461982883395937f68d00c644a573"], ["f710d79d9eb962297e4f6232b40e8f7feb2bc63814614d692c12de752408221e", "ea98e67232d3b3295d3b535532115ccac8612c721851617526ae47a9c77bfc82"]] }, naf: { wnd: 7, points: [["f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9", "388f7b0f632de8140fe337e62a37f3566500a99934c2231b6cb9fd7584b8e672"], ["2f8bde4d1a07209355b4a7250a5c5128e88b84bddc619ab7cba8d569b240efe4", "d8ac222636e5e3d6d4dba9dda6c9c426f788271bab0d6840dca87d3aa6ac62d6"], ["5cbdf0646e5db4eaa398f365f2ea7a0e3d419b7e0330e39ce92bddedcac4f9bc", "6aebca40ba255960a3178d6d861a54dba813d0b813fde7b5a5082628087264da"], ["acd484e2f0c7f65309ad178a9f559abde09796974c57e714c35f110dfc27ccbe", "cc338921b0a7d9fd64380971763b61e9add888a4375f8e0f05cc262ac64f9c37"], ["774ae7f858a9411e5ef4246b70c65aac5649980be5c17891bbec17895da008cb", "d984a032eb6b5e190243dd56d7b7b365372db1e2dff9d6a8301d74c9c953c61b"], ["f28773c2d975288bc7d1d205c3748651b075fbc6610e58cddeeddf8f19405aa8", "ab0902e8d880a89758212eb65cdaf473a1a06da521fa91f29b5cb52db03ed81"], ["d7924d4f7d43ea965a465ae3095ff41131e5946f3c85f79e44adbcf8e27e080e", "581e2872a86c72a683842ec228cc6defea40af2bd896d3a5c504dc9ff6a26b58"], ["defdea4cdb677750a420fee807eacf21eb9898ae79b9768766e4faa04a2d4a34", "4211ab0694635168e997b0ead2a93daeced1f4a04a95c0f6cfb199f69e56eb77"], ["2b4ea0a797a443d293ef5cff444f4979f06acfebd7e86d277475656138385b6c", "85e89bc037945d93b343083b5a1c86131a01f60c50269763b570c854e5c09b7a"], ["352bbf4a4cdd12564f93fa332ce333301d9ad40271f8107181340aef25be59d5", "321eb4075348f534d59c18259dda3e1f4a1b3b2e71b1039c67bd3d8bcf81998c"], ["2fa2104d6b38d11b0230010559879124e42ab8dfeff5ff29dc9cdadd4ecacc3f", "2de1068295dd865b64569335bd5dd80181d70ecfc882648423ba76b532b7d67"], ["9248279b09b4d68dab21a9b066edda83263c3d84e09572e269ca0cd7f5453714", "73016f7bf234aade5d1aa71bdea2b1ff3fc0de2a887912ffe54a32ce97cb3402"], ["daed4f2be3a8bf278e70132fb0beb7522f570e144bf615c07e996d443dee8729", "a69dce4a7d6c98e8d4a1aca87ef8d7003f83c230f3afa726ab40e52290be1c55"], ["c44d12c7065d812e8acf28d7cbb19f9011ecd9e9fdf281b0e6a3b5e87d22e7db", "2119a460ce326cdc76c45926c982fdac0e106e861edf61c5a039063f0e0e6482"], ["6a245bf6dc698504c89a20cfded60853152b695336c28063b61c65cbd269e6b4", "e022cf42c2bd4a708b3f5126f16a24ad8b33ba48d0423b6efd5e6348100d8a82"], ["1697ffa6fd9de627c077e3d2fe541084ce13300b0bec1146f95ae57f0d0bd6a5", "b9c398f186806f5d27561506e4557433a2cf15009e498ae7adee9d63d01b2396"], ["605bdb019981718b986d0f07e834cb0d9deb8360ffb7f61df982345ef27a7479", "2972d2de4f8d20681a78d93ec96fe23c26bfae84fb14db43b01e1e9056b8c49"], ["62d14dab4150bf497402fdc45a215e10dcb01c354959b10cfe31c7e9d87ff33d", "80fc06bd8cc5b01098088a1950eed0db01aa132967ab472235f5642483b25eaf"], ["80c60ad0040f27dade5b4b06c408e56b2c50e9f56b9b8b425e555c2f86308b6f", "1c38303f1cc5c30f26e66bad7fe72f70a65eed4cbe7024eb1aa01f56430bd57a"], ["7a9375ad6167ad54aa74c6348cc54d344cc5dc9487d847049d5eabb0fa03c8fb", "d0e3fa9eca8726909559e0d79269046bdc59ea10c70ce2b02d499ec224dc7f7"], ["d528ecd9b696b54c907a9ed045447a79bb408ec39b68df504bb51f459bc3ffc9", "eecf41253136e5f99966f21881fd656ebc4345405c520dbc063465b521409933"], ["49370a4b5f43412ea25f514e8ecdad05266115e4a7ecb1387231808f8b45963", "758f3f41afd6ed428b3081b0512fd62a54c3f3afbb5b6764b653052a12949c9a"], ["77f230936ee88cbbd73df930d64702ef881d811e0e1498e2f1c13eb1fc345d74", "958ef42a7886b6400a08266e9ba1b37896c95330d97077cbbe8eb3c7671c60d6"], ["f2dac991cc4ce4b9ea44887e5c7c0bce58c80074ab9d4dbaeb28531b7739f530", "e0dedc9b3b2f8dad4da1f32dec2531df9eb5fbeb0598e4fd1a117dba703a3c37"], ["463b3d9f662621fb1b4be8fbbe2520125a216cdfc9dae3debcba4850c690d45b", "5ed430d78c296c3543114306dd8622d7c622e27c970a1de31cb377b01af7307e"], ["f16f804244e46e2a09232d4aff3b59976b98fac14328a2d1a32496b49998f247", "cedabd9b82203f7e13d206fcdf4e33d92a6c53c26e5cce26d6579962c4e31df6"], ["caf754272dc84563b0352b7a14311af55d245315ace27c65369e15f7151d41d1", "cb474660ef35f5f2a41b643fa5e460575f4fa9b7962232a5c32f908318a04476"], ["2600ca4b282cb986f85d0f1709979d8b44a09c07cb86d7c124497bc86f082120", "4119b88753c15bd6a693b03fcddbb45d5ac6be74ab5f0ef44b0be9475a7e4b40"], ["7635ca72d7e8432c338ec53cd12220bc01c48685e24f7dc8c602a7746998e435", "91b649609489d613d1d5e590f78e6d74ecfc061d57048bad9e76f302c5b9c61"], ["754e3239f325570cdbbf4a87deee8a66b7f2b33479d468fbc1a50743bf56cc18", "673fb86e5bda30fb3cd0ed304ea49a023ee33d0197a695d0c5d98093c536683"], ["e3e6bd1071a1e96aff57859c82d570f0330800661d1c952f9fe2694691d9b9e8", "59c9e0bba394e76f40c0aa58379a3cb6a5a2283993e90c4167002af4920e37f5"], ["186b483d056a033826ae73d88f732985c4ccb1f32ba35f4b4cc47fdcf04aa6eb", "3b952d32c67cf77e2e17446e204180ab21fb8090895138b4a4a797f86e80888b"], ["df9d70a6b9876ce544c98561f4be4f725442e6d2b737d9c91a8321724ce0963f", "55eb2dafd84d6ccd5f862b785dc39d4ab157222720ef9da217b8c45cf2ba2417"], ["5edd5cc23c51e87a497ca815d5dce0f8ab52554f849ed8995de64c5f34ce7143", "efae9c8dbc14130661e8cec030c89ad0c13c66c0d17a2905cdc706ab7399a868"], ["290798c2b6476830da12fe02287e9e777aa3fba1c355b17a722d362f84614fba", "e38da76dcd440621988d00bcf79af25d5b29c094db2a23146d003afd41943e7a"], ["af3c423a95d9f5b3054754efa150ac39cd29552fe360257362dfdecef4053b45", "f98a3fd831eb2b749a93b0e6f35cfb40c8cd5aa667a15581bc2feded498fd9c6"], ["766dbb24d134e745cccaa28c99bf274906bb66b26dcf98df8d2fed50d884249a", "744b1152eacbe5e38dcc887980da38b897584a65fa06cedd2c924f97cbac5996"], ["59dbf46f8c94759ba21277c33784f41645f7b44f6c596a58ce92e666191abe3e", "c534ad44175fbc300f4ea6ce648309a042ce739a7919798cd85e216c4a307f6e"], ["f13ada95103c4537305e691e74e9a4a8dd647e711a95e73cb62dc6018cfd87b8", "e13817b44ee14de663bf4bc808341f326949e21a6a75c2570778419bdaf5733d"], ["7754b4fa0e8aced06d4167a2c59cca4cda1869c06ebadfb6488550015a88522c", "30e93e864e669d82224b967c3020b8fa8d1e4e350b6cbcc537a48b57841163a2"], ["948dcadf5990e048aa3874d46abef9d701858f95de8041d2a6828c99e2262519", "e491a42537f6e597d5d28a3224b1bc25df9154efbd2ef1d2cbba2cae5347d57e"], ["7962414450c76c1689c7b48f8202ec37fb224cf5ac0bfa1570328a8a3d7c77ab", "100b610ec4ffb4760d5c1fc133ef6f6b12507a051f04ac5760afa5b29db83437"], ["3514087834964b54b15b160644d915485a16977225b8847bb0dd085137ec47ca", "ef0afbb2056205448e1652c48e8127fc6039e77c15c2378b7e7d15a0de293311"], ["d3cc30ad6b483e4bc79ce2c9dd8bc54993e947eb8df787b442943d3f7b527eaf", "8b378a22d827278d89c5e9be8f9508ae3c2ad46290358630afb34db04eede0a4"], ["1624d84780732860ce1c78fcbfefe08b2b29823db913f6493975ba0ff4847610", "68651cf9b6da903e0914448c6cd9d4ca896878f5282be4c8cc06e2a404078575"], ["733ce80da955a8a26902c95633e62a985192474b5af207da6df7b4fd5fc61cd4", "f5435a2bd2badf7d485a4d8b8db9fcce3e1ef8e0201e4578c54673bc1dc5ea1d"], ["15d9441254945064cf1a1c33bbd3b49f8966c5092171e699ef258dfab81c045c", "d56eb30b69463e7234f5137b73b84177434800bacebfc685fc37bbe9efe4070d"], ["a1d0fcf2ec9de675b612136e5ce70d271c21417c9d2b8aaaac138599d0717940", "edd77f50bcb5a3cab2e90737309667f2641462a54070f3d519212d39c197a629"], ["e22fbe15c0af8ccc5780c0735f84dbe9a790badee8245c06c7ca37331cb36980", "a855babad5cd60c88b430a69f53a1a7a38289154964799be43d06d77d31da06"], ["311091dd9860e8e20ee13473c1155f5f69635e394704eaa74009452246cfa9b3", "66db656f87d1f04fffd1f04788c06830871ec5a64feee685bd80f0b1286d8374"], ["34c1fd04d301be89b31c0442d3e6ac24883928b45a9340781867d4232ec2dbdf", "9414685e97b1b5954bd46f730174136d57f1ceeb487443dc5321857ba73abee"], ["f219ea5d6b54701c1c14de5b557eb42a8d13f3abbcd08affcc2a5e6b049b8d63", "4cb95957e83d40b0f73af4544cccf6b1f4b08d3c07b27fb8d8c2962a400766d1"], ["d7b8740f74a8fbaab1f683db8f45de26543a5490bca627087236912469a0b448", "fa77968128d9c92ee1010f337ad4717eff15db5ed3c049b3411e0315eaa4593b"], ["32d31c222f8f6f0ef86f7c98d3a3335ead5bcd32abdd94289fe4d3091aa824bf", "5f3032f5892156e39ccd3d7915b9e1da2e6dac9e6f26e961118d14b8462e1661"], ["7461f371914ab32671045a155d9831ea8793d77cd59592c4340f86cbc18347b5", "8ec0ba238b96bec0cbdddcae0aa442542eee1ff50c986ea6b39847b3cc092ff6"], ["ee079adb1df1860074356a25aa38206a6d716b2c3e67453d287698bad7b2b2d6", "8dc2412aafe3be5c4c5f37e0ecc5f9f6a446989af04c4e25ebaac479ec1c8c1e"], ["16ec93e447ec83f0467b18302ee620f7e65de331874c9dc72bfd8616ba9da6b5", "5e4631150e62fb40d0e8c2a7ca5804a39d58186a50e497139626778e25b0674d"], ["eaa5f980c245f6f038978290afa70b6bd8855897f98b6aa485b96065d537bd99", "f65f5d3e292c2e0819a528391c994624d784869d7e6ea67fb18041024edc07dc"], ["78c9407544ac132692ee1910a02439958ae04877151342ea96c4b6b35a49f51", "f3e0319169eb9b85d5404795539a5e68fa1fbd583c064d2462b675f194a3ddb4"], ["494f4be219a1a77016dcd838431aea0001cdc8ae7a6fc688726578d9702857a5", "42242a969283a5f339ba7f075e36ba2af925ce30d767ed6e55f4b031880d562c"], ["a598a8030da6d86c6bc7f2f5144ea549d28211ea58faa70ebf4c1e665c1fe9b5", "204b5d6f84822c307e4b4a7140737aec23fc63b65b35f86a10026dbd2d864e6b"], ["c41916365abb2b5d09192f5f2dbeafec208f020f12570a184dbadc3e58595997", "4f14351d0087efa49d245b328984989d5caf9450f34bfc0ed16e96b58fa9913"], ["841d6063a586fa475a724604da03bc5b92a2e0d2e0a36acfe4c73a5514742881", "73867f59c0659e81904f9a1c7543698e62562d6744c169ce7a36de01a8d6154"], ["5e95bb399a6971d376026947f89bde2f282b33810928be4ded112ac4d70e20d5", "39f23f366809085beebfc71181313775a99c9aed7d8ba38b161384c746012865"], ["36e4641a53948fd476c39f8a99fd974e5ec07564b5315d8bf99471bca0ef2f66", "d2424b1b1abe4eb8164227b085c9aa9456ea13493fd563e06fd51cf5694c78fc"], ["336581ea7bfbbb290c191a2f507a41cf5643842170e914faeab27c2c579f726", "ead12168595fe1be99252129b6e56b3391f7ab1410cd1e0ef3dcdcabd2fda224"], ["8ab89816dadfd6b6a1f2634fcf00ec8403781025ed6890c4849742706bd43ede", "6fdcef09f2f6d0a044e654aef624136f503d459c3e89845858a47a9129cdd24e"], ["1e33f1a746c9c5778133344d9299fcaa20b0938e8acff2544bb40284b8c5fb94", "60660257dd11b3aa9c8ed618d24edff2306d320f1d03010e33a7d2057f3b3b6"], ["85b7c1dcb3cec1b7ee7f30ded79dd20a0ed1f4cc18cbcfcfa410361fd8f08f31", "3d98a9cdd026dd43f39048f25a8847f4fcafad1895d7a633c6fed3c35e999511"], ["29df9fbd8d9e46509275f4b125d6d45d7fbe9a3b878a7af872a2800661ac5f51", "b4c4fe99c775a606e2d8862179139ffda61dc861c019e55cd2876eb2a27d84b"], ["a0b1cae06b0a847a3fea6e671aaf8adfdfe58ca2f768105c8082b2e449fce252", "ae434102edde0958ec4b19d917a6a28e6b72da1834aff0e650f049503a296cf2"], ["4e8ceafb9b3e9a136dc7ff67e840295b499dfb3b2133e4ba113f2e4c0e121e5", "cf2174118c8b6d7a4b48f6d534ce5c79422c086a63460502b827ce62a326683c"], ["d24a44e047e19b6f5afb81c7ca2f69080a5076689a010919f42725c2b789a33b", "6fb8d5591b466f8fc63db50f1c0f1c69013f996887b8244d2cdec417afea8fa3"], ["ea01606a7a6c9cdd249fdfcfacb99584001edd28abbab77b5104e98e8e3b35d4", "322af4908c7312b0cfbfe369f7a7b3cdb7d4494bc2823700cfd652188a3ea98d"], ["af8addbf2b661c8a6c6328655eb96651252007d8c5ea31be4ad196de8ce2131f", "6749e67c029b85f52a034eafd096836b2520818680e26ac8f3dfbcdb71749700"], ["e3ae1974566ca06cc516d47e0fb165a674a3dabcfca15e722f0e3450f45889", "2aeabe7e4531510116217f07bf4d07300de97e4874f81f533420a72eeb0bd6a4"], ["591ee355313d99721cf6993ffed1e3e301993ff3ed258802075ea8ced397e246", "b0ea558a113c30bea60fc4775460c7901ff0b053d25ca2bdeee98f1a4be5d196"], ["11396d55fda54c49f19aa97318d8da61fa8584e47b084945077cf03255b52984", "998c74a8cd45ac01289d5833a7beb4744ff536b01b257be4c5767bea93ea57a4"], ["3c5d2a1ba39c5a1790000738c9e0c40b8dcdfd5468754b6405540157e017aa7a", "b2284279995a34e2f9d4de7396fc18b80f9b8b9fdd270f6661f79ca4c81bd257"], ["cc8704b8a60a0defa3a99a7299f2e9c3fbc395afb04ac078425ef8a1793cc030", "bdd46039feed17881d1e0862db347f8cf395b74fc4bcdc4e940b74e3ac1f1b13"], ["c533e4f7ea8555aacd9777ac5cad29b97dd4defccc53ee7ea204119b2889b197", "6f0a256bc5efdf429a2fb6242f1a43a2d9b925bb4a4b3a26bb8e0f45eb596096"], ["c14f8f2ccb27d6f109f6d08d03cc96a69ba8c34eec07bbcf566d48e33da6593", "c359d6923bb398f7fd4473e16fe1c28475b740dd098075e6c0e8649113dc3a38"], ["a6cbc3046bc6a450bac24789fa17115a4c9739ed75f8f21ce441f72e0b90e6ef", "21ae7f4680e889bb130619e2c0f95a360ceb573c70603139862afd617fa9b9f"], ["347d6d9a02c48927ebfb86c1359b1caf130a3c0267d11ce6344b39f99d43cc38", "60ea7f61a353524d1c987f6ecec92f086d565ab687870cb12689ff1e31c74448"], ["da6545d2181db8d983f7dcb375ef5866d47c67b1bf31c8cf855ef7437b72656a", "49b96715ab6878a79e78f07ce5680c5d6673051b4935bd897fea824b77dc208a"], ["c40747cc9d012cb1a13b8148309c6de7ec25d6945d657146b9d5994b8feb1111", "5ca560753be2a12fc6de6caf2cb489565db936156b9514e1bb5e83037e0fa2d4"], ["4e42c8ec82c99798ccf3a610be870e78338c7f713348bd34c8203ef4037f3502", "7571d74ee5e0fb92a7a8b33a07783341a5492144cc54bcc40a94473693606437"], ["3775ab7089bc6af823aba2e1af70b236d251cadb0c86743287522a1b3b0dedea", "be52d107bcfa09d8bcb9736a828cfa7fac8db17bf7a76a2c42ad961409018cf7"], ["cee31cbf7e34ec379d94fb814d3d775ad954595d1314ba8846959e3e82f74e26", "8fd64a14c06b589c26b947ae2bcf6bfa0149ef0be14ed4d80f448a01c43b1c6d"], ["b4f9eaea09b6917619f6ea6a4eb5464efddb58fd45b1ebefcdc1a01d08b47986", "39e5c9925b5a54b07433a4f18c61726f8bb131c012ca542eb24a8ac07200682a"], ["d4263dfc3d2df923a0179a48966d30ce84e2515afc3dccc1b77907792ebcc60e", "62dfaf07a0f78feb30e30d6295853ce189e127760ad6cf7fae164e122a208d54"], ["48457524820fa65a4f8d35eb6930857c0032acc0a4a2de422233eeda897612c4", "25a748ab367979d98733c38a1fa1c2e7dc6cc07db2d60a9ae7a76aaa49bd0f77"], ["dfeeef1881101f2cb11644f3a2afdfc2045e19919152923f367a1767c11cceda", "ecfb7056cf1de042f9420bab396793c0c390bde74b4bbdff16a83ae09a9a7517"], ["6d7ef6b17543f8373c573f44e1f389835d89bcbc6062ced36c82df83b8fae859", "cd450ec335438986dfefa10c57fea9bcc521a0959b2d80bbf74b190dca712d10"], ["e75605d59102a5a2684500d3b991f2e3f3c88b93225547035af25af66e04541f", "f5c54754a8f71ee540b9b48728473e314f729ac5308b06938360990e2bfad125"], ["eb98660f4c4dfaa06a2be453d5020bc99a0c2e60abe388457dd43fefb1ed620c", "6cb9a8876d9cb8520609af3add26cd20a0a7cd8a9411131ce85f44100099223e"], ["13e87b027d8514d35939f2e6892b19922154596941888336dc3563e3b8dba942", "fef5a3c68059a6dec5d624114bf1e91aac2b9da568d6abeb2570d55646b8adf1"], ["ee163026e9fd6fe017c38f06a5be6fc125424b371ce2708e7bf4491691e5764a", "1acb250f255dd61c43d94ccc670d0f58f49ae3fa15b96623e5430da0ad6c62b2"], ["b268f5ef9ad51e4d78de3a750c2dc89b1e626d43505867999932e5db33af3d80", "5f310d4b3c99b9ebb19f77d41c1dee018cf0d34fd4191614003e945a1216e423"], ["ff07f3118a9df035e9fad85eb6c7bfe42b02f01ca99ceea3bf7ffdba93c4750d", "438136d603e858a3a5c440c38eccbaddc1d2942114e2eddd4740d098ced1f0d8"], ["8d8b9855c7c052a34146fd20ffb658bea4b9f69e0d825ebec16e8c3ce2b526a1", "cdb559eedc2d79f926baf44fb84ea4d44bcf50fee51d7ceb30e2e7f463036758"], ["52db0b5384dfbf05bfa9d472d7ae26dfe4b851ceca91b1eba54263180da32b63", "c3b997d050ee5d423ebaf66a6db9f57b3180c902875679de924b69d84a7b375"], ["e62f9490d3d51da6395efd24e80919cc7d0f29c3f3fa48c6fff543becbd43352", "6d89ad7ba4876b0b22c2ca280c682862f342c8591f1daf5170e07bfd9ccafa7d"], ["7f30ea2476b399b4957509c88f77d0191afa2ff5cb7b14fd6d8e7d65aaab1193", "ca5ef7d4b231c94c3b15389a5f6311e9daff7bb67b103e9880ef4bff637acaec"], ["5098ff1e1d9f14fb46a210fada6c903fef0fb7b4a1dd1d9ac60a0361800b7a00", "9731141d81fc8f8084d37c6e7542006b3ee1b40d60dfe5362a5b132fd17ddc0"], ["32b78c7de9ee512a72895be6b9cbefa6e2f3c4ccce445c96b9f2c81e2778ad58", "ee1849f513df71e32efc3896ee28260c73bb80547ae2275ba497237794c8753c"], ["e2cb74fddc8e9fbcd076eef2a7c72b0ce37d50f08269dfc074b581550547a4f7", "d3aa2ed71c9dd2247a62df062736eb0baddea9e36122d2be8641abcb005cc4a4"], ["8438447566d4d7bedadc299496ab357426009a35f235cb141be0d99cd10ae3a8", "c4e1020916980a4da5d01ac5e6ad330734ef0d7906631c4f2390426b2edd791f"], ["4162d488b89402039b584c6fc6c308870587d9c46f660b878ab65c82c711d67e", "67163e903236289f776f22c25fb8a3afc1732f2b84b4e95dbda47ae5a0852649"], ["3fad3fa84caf0f34f0f89bfd2dcf54fc175d767aec3e50684f3ba4a4bf5f683d", "cd1bc7cb6cc407bb2f0ca647c718a730cf71872e7d0d2a53fa20efcdfe61826"], ["674f2600a3007a00568c1a7ce05d0816c1fb84bf1370798f1c69532faeb1a86b", "299d21f9413f33b3edf43b257004580b70db57da0b182259e09eecc69e0d38a5"], ["d32f4da54ade74abb81b815ad1fb3b263d82d6c692714bcff87d29bd5ee9f08f", "f9429e738b8e53b968e99016c059707782e14f4535359d582fc416910b3eea87"], ["30e4e670435385556e593657135845d36fbb6931f72b08cb1ed954f1e3ce3ff6", "462f9bce619898638499350113bbc9b10a878d35da70740dc695a559eb88db7b"], ["be2062003c51cc3004682904330e4dee7f3dcd10b01e580bf1971b04d4cad297", "62188bc49d61e5428573d48a74e1c655b1c61090905682a0d5558ed72dccb9bc"], ["93144423ace3451ed29e0fb9ac2af211cb6e84a601df5993c419859fff5df04a", "7c10dfb164c3425f5c71a3f9d7992038f1065224f72bb9d1d902a6d13037b47c"], ["b015f8044f5fcbdcf21ca26d6c34fb8197829205c7b7d2a7cb66418c157b112c", "ab8c1e086d04e813744a655b2df8d5f83b3cdc6faa3088c1d3aea1454e3a1d5f"], ["d5e9e1da649d97d89e4868117a465a3a4f8a18de57a140d36b3f2af341a21b52", "4cb04437f391ed73111a13cc1d4dd0db1693465c2240480d8955e8592f27447a"], ["d3ae41047dd7ca065dbf8ed77b992439983005cd72e16d6f996a5316d36966bb", "bd1aeb21ad22ebb22a10f0303417c6d964f8cdd7df0aca614b10dc14d125ac46"], ["463e2763d885f958fc66cdd22800f0a487197d0a82e377b49f80af87c897b065", "bfefacdb0e5d0fd7df3a311a94de062b26b80c61fbc97508b79992671ef7ca7f"], ["7985fdfd127c0567c6f53ec1bb63ec3158e597c40bfe747c83cddfc910641917", "603c12daf3d9862ef2b25fe1de289aed24ed291e0ec6708703a5bd567f32ed03"], ["74a1ad6b5f76e39db2dd249410eac7f99e74c59cb83d2d0ed5ff1543da7703e9", "cc6157ef18c9c63cd6193d83631bbea0093e0968942e8c33d5737fd790e0db08"], ["30682a50703375f602d416664ba19b7fc9bab42c72747463a71d0896b22f6da3", "553e04f6b018b4fa6c8f39e7f311d3176290d0e0f19ca73f17714d9977a22ff8"], ["9e2158f0d7c0d5f26c3791efefa79597654e7a2b2464f52b1ee6c1347769ef57", "712fcdd1b9053f09003a3481fa7762e9ffd7c8ef35a38509e2fbf2629008373"], ["176e26989a43c9cfeba4029c202538c28172e566e3c4fce7322857f3be327d66", "ed8cc9d04b29eb877d270b4878dc43c19aefd31f4eee09ee7b47834c1fa4b1c3"], ["75d46efea3771e6e68abb89a13ad747ecf1892393dfc4f1b7004788c50374da8", "9852390a99507679fd0b86fd2b39a868d7efc22151346e1a3ca4726586a6bed8"], ["809a20c67d64900ffb698c4c825f6d5f2310fb0451c869345b7319f645605721", "9e994980d9917e22b76b061927fa04143d096ccc54963e6a5ebfa5f3f8e286c1"], ["1b38903a43f7f114ed4500b4eac7083fdefece1cf29c63528d563446f972c180", "4036edc931a60ae889353f77fd53de4a2708b26b6f5da72ad3394119daf408f9"]] } };
  });
  t0 = T2((oy) => {
    var Zl = oy, Qi = e0(), jl = Pl(), ZR = or(), fy = ZR.assert;
    function ay(t) {
      t.type === "short" ? this.curve = new jl.short(t) : t.type === "edwards" ? this.curve = new jl.edwards(t) : this.curve = new jl.mont(t), this.g = this.curve.g, this.n = this.curve.n, this.hash = t.hash, fy(this.g.validate(), "Invalid curve"), fy(this.g.mul(this.n).isInfinity(), "Invalid curve, G*N != O");
    }
    Zl.PresetCurve = ay;
    function en(t, e) {
      Object.defineProperty(Zl, t, { configurable: true, enumerable: true, get: function() {
        var r = new ay(e);
        return Object.defineProperty(Zl, t, { configurable: true, enumerable: true, value: r }), r;
      } });
    }
    en("p192", { type: "short", prime: "p192", p: "ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff", a: "ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc", b: "64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1", n: "ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831", hash: Qi.sha256, gRed: false, g: ["188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012", "07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811"] });
    en("p224", { type: "short", prime: "p224", p: "ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001", a: "ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe", b: "b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4", n: "ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d", hash: Qi.sha256, gRed: false, g: ["b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21", "bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34"] });
    en("p256", { type: "short", prime: null, p: "ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff", a: "ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc", b: "5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b", n: "ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551", hash: Qi.sha256, gRed: false, g: ["6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296", "4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5"] });
    en("p384", { type: "short", prime: null, p: "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe ffffffff 00000000 00000000 ffffffff", a: "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe ffffffff 00000000 00000000 fffffffc", b: "b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f 5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef", n: "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 f4372ddf 581a0db2 48b0a77a ecec196a ccc52973", hash: Qi.sha384, gRed: false, g: ["aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 5502f25d bf55296c 3a545e38 72760ab7", "3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 0a60b1ce 1d7e819d 7a431d7c 90ea0e5f"] });
    en("p521", { type: "short", prime: null, p: "000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff", a: "000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffc", b: "00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b 99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd 3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00", n: "000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409", hash: Qi.sha512, gRed: false, g: ["000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66", "00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 3fad0761 353c7086 a272c240 88be9476 9fd16650"] });
    en("curve25519", { type: "mont", prime: "p25519", p: "7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed", a: "76d06", b: "1", n: "1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed", hash: Qi.sha256, gRed: false, g: ["9"] });
    en("ed25519", { type: "edwards", prime: "p25519", p: "7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed", a: "-1", c: "1", d: "52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3", n: "1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed", hash: Qi.sha256, gRed: false, g: ["216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a", "6666666666666666666666666666666666666666666666666666666666666658"] });
    var Vl;
    try {
      Vl = ny();
    } catch {
      Vl = undefined;
    }
    en("secp256k1", { type: "short", prime: "k256", p: "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f", a: "0", b: "7", n: "ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141", h: "1", hash: Qi.sha256, beta: "7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee", lambda: "5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72", basis: [{ a: "3086d221a7d46bcde86c90e49284eb15", b: "-e4437ed6010e88286f547fa90abfe4c3" }, { a: "114ca50f7a8e2f3f657c1108d9d44cfd8", b: "3086d221a7d46bcde86c90e49284eb15" }], gRed: false, g: ["79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798", "483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8", Vl] });
  });
  uy = T2((Hk, hy) => {
    var VR = e0(), Fn = Nl(), sy = ar();
    function tn(t) {
      if (!(this instanceof tn))
        return new tn(t);
      this.hash = t.hash, this.predResist = !!t.predResist, this.outLen = this.hash.outSize, this.minEntropy = t.minEntropy || this.hash.hmacStrength, this._reseed = null, this.reseedInterval = null, this.K = null, this.V = null;
      var e = Fn.toArray(t.entropy, t.entropyEnc || "hex"), r = Fn.toArray(t.nonce, t.nonceEnc || "hex"), o = Fn.toArray(t.pers, t.persEnc || "hex");
      sy(e.length >= this.minEntropy / 8, "Not enough entropy. Minimum is: " + this.minEntropy + " bits"), this._init(e, r, o);
    }
    hy.exports = tn;
    tn.prototype._init = function(e, r, o) {
      var f = e.concat(r).concat(o);
      this.K = new Array(this.outLen / 8), this.V = new Array(this.outLen / 8);
      for (var p = 0;p < this.V.length; p++)
        this.K[p] = 0, this.V[p] = 1;
      this._update(f), this._reseed = 1, this.reseedInterval = 281474976710656;
    };
    tn.prototype._hmac = function() {
      return new VR.hmac(this.hash, this.K);
    };
    tn.prototype._update = function(e) {
      var r = this._hmac().update(this.V).update([0]);
      e && (r = r.update(e)), this.K = r.digest(), this.V = this._hmac().update(this.V).digest(), e && (this.K = this._hmac().update(this.V).update([1]).update(e).digest(), this.V = this._hmac().update(this.V).digest());
    };
    tn.prototype.reseed = function(e, r, o, f) {
      typeof r != "string" && (f = o, o = r, r = null), e = Fn.toArray(e, r), o = Fn.toArray(o, f), sy(e.length >= this.minEntropy / 8, "Not enough entropy. Minimum is: " + this.minEntropy + " bits"), this._update(e.concat(o || [])), this._reseed = 1;
    };
    tn.prototype.generate = function(e, r, o, f) {
      if (this._reseed > this.reseedInterval)
        throw new Error("Reseed is required");
      typeof r != "string" && (f = o, o = r, r = null), o && (o = Fn.toArray(o, f || "hex"), this._update(o));
      for (var p = [];p.length < e; )
        this.V = this._hmac().update(this.V).digest(), p = p.concat(this.V);
      var m2 = p.slice(0, e);
      return this._update(o), this._reseed++, Fn.encode(m2, r);
    };
  });
  dy = T2((Wk, ly) => {
    var $R = ri(), GR = or(), $l = GR.assert;
    function Gt(t, e) {
      this.ec = t, this.priv = null, this.pub = null, e.priv && this._importPrivate(e.priv, e.privEnc), e.pub && this._importPublic(e.pub, e.pubEnc);
    }
    ly.exports = Gt;
    Gt.fromPublic = function(e, r, o) {
      return r instanceof Gt ? r : new Gt(e, { pub: r, pubEnc: o });
    };
    Gt.fromPrivate = function(e, r, o) {
      return r instanceof Gt ? r : new Gt(e, { priv: r, privEnc: o });
    };
    Gt.prototype.validate = function() {
      var e = this.getPublic();
      return e.isInfinity() ? { result: false, reason: "Invalid public key" } : e.validate() ? e.mul(this.ec.curve.n).isInfinity() ? { result: true, reason: null } : { result: false, reason: "Public key * N != O" } : { result: false, reason: "Public key is not a point" };
    };
    Gt.prototype.getPublic = function(e, r) {
      return typeof e == "string" && (r = e, e = null), this.pub || (this.pub = this.ec.g.mul(this.priv)), r ? this.pub.encode(r, e) : this.pub;
    };
    Gt.prototype.getPrivate = function(e) {
      return e === "hex" ? this.priv.toString(16, 2) : this.priv;
    };
    Gt.prototype._importPrivate = function(e, r) {
      this.priv = new $R(e, r || 16), this.priv = this.priv.umod(this.ec.curve.n);
    };
    Gt.prototype._importPublic = function(e, r) {
      if (e.x || e.y) {
        this.ec.curve.type === "mont" ? $l(e.x, "Need x coordinate") : (this.ec.curve.type === "short" || this.ec.curve.type === "edwards") && $l(e.x && e.y, "Need both x and y coordinate"), this.pub = this.ec.curve.point(e.x, e.y);
        return;
      }
      this.pub = this.ec.curve.decodePoint(e, r);
    };
    Gt.prototype.derive = function(e) {
      return e.validate() || $l(e.validate(), "public point not validated"), e.mul(this.priv).getX();
    };
    Gt.prototype.sign = function(e, r, o) {
      return this.ec.sign(e, this, r, o);
    };
    Gt.prototype.verify = function(e, r) {
      return this.ec.verify(e, r, this);
    };
    Gt.prototype.inspect = function() {
      return "<Key priv: " + (this.priv && this.priv.toString(16, 2)) + " pub: " + (this.pub && this.pub.inspect()) + " >";
    };
  });
  vy = T2((Kk, py) => {
    var r0 = ri(), Xl = or(), YR = Xl.assert;
    function i0(t, e) {
      if (t instanceof i0)
        return t;
      this._importDER(t, e) || (YR(t.r && t.s, "Signature without r or s"), this.r = new r0(t.r, 16), this.s = new r0(t.s, 16), t.recoveryParam === undefined ? this.recoveryParam = null : this.recoveryParam = t.recoveryParam);
    }
    py.exports = i0;
    function XR() {
      this.place = 0;
    }
    function Gl(t, e) {
      var r = t[e.place++];
      if (!(r & 128))
        return r;
      var o = r & 15;
      if (o === 0 || o > 4)
        return false;
      for (var f = 0, p = 0, m2 = e.place;p < o; p++, m2++)
        f <<= 8, f |= t[m2], f >>>= 0;
      return f <= 127 ? false : (e.place = m2, f);
    }
    function cy(t) {
      for (var e = 0, r = t.length - 1;!t[e] && !(t[e + 1] & 128) && e < r; )
        e++;
      return e === 0 ? t : t.slice(e);
    }
    i0.prototype._importDER = function(e, r) {
      e = Xl.toArray(e, r);
      var o = new XR;
      if (e[o.place++] !== 48)
        return false;
      var f = Gl(e, o);
      if (f === false || f + o.place !== e.length || e[o.place++] !== 2)
        return false;
      var p = Gl(e, o);
      if (p === false)
        return false;
      var m2 = e.slice(o.place, p + o.place);
      if (o.place += p, e[o.place++] !== 2)
        return false;
      var y3 = Gl(e, o);
      if (y3 === false || e.length !== y3 + o.place)
        return false;
      var M = e.slice(o.place, y3 + o.place);
      if (m2[0] === 0)
        if (m2[1] & 128)
          m2 = m2.slice(1);
        else
          return false;
      if (M[0] === 0)
        if (M[1] & 128)
          M = M.slice(1);
        else
          return false;
      return this.r = new r0(m2), this.s = new r0(M), this.recoveryParam = null, true;
    };
    function Yl(t, e) {
      if (e < 128) {
        t.push(e);
        return;
      }
      var r = 1 + (Math.log(e) / Math.LN2 >>> 3);
      for (t.push(r | 128);--r; )
        t.push(e >>> (r << 3) & 255);
      t.push(e);
    }
    i0.prototype.toDER = function(e) {
      var r = this.r.toArray(), o = this.s.toArray();
      for (r[0] & 128 && (r = [0].concat(r)), o[0] & 128 && (o = [0].concat(o)), r = cy(r), o = cy(o);!o[0] && !(o[1] & 128); )
        o = o.slice(1);
      var f = [2];
      Yl(f, r.length), f = f.concat(r), f.push(2), Yl(f, o.length);
      var p = f.concat(o), m2 = [48];
      return Yl(m2, p.length), m2 = m2.concat(p), Xl.encode(m2, e);
    };
  });
  yy = T2((jk, gy) => {
    var Un = ri(), by = uy(), JR = or(), Jl = t0(), QR = As(), my = JR.assert, Ql = dy(), n0 = vy();
    function Sr(t) {
      if (!(this instanceof Sr))
        return new Sr(t);
      typeof t == "string" && (my(Object.prototype.hasOwnProperty.call(Jl, t), "Unknown curve " + t), t = Jl[t]), t instanceof Jl.PresetCurve && (t = { curve: t }), this.curve = t.curve.curve, this.n = this.curve.n, this.nh = this.n.ushrn(1), this.g = this.curve.g, this.g = t.curve.g, this.g.precompute(t.curve.n.bitLength() + 1), this.hash = t.hash || t.curve.hash;
    }
    gy.exports = Sr;
    Sr.prototype.keyPair = function(e) {
      return new Ql(this, e);
    };
    Sr.prototype.keyFromPrivate = function(e, r) {
      return Ql.fromPrivate(this, e, r);
    };
    Sr.prototype.keyFromPublic = function(e, r) {
      return Ql.fromPublic(this, e, r);
    };
    Sr.prototype.genKeyPair = function(e) {
      e || (e = {});
      for (var r = new by({ hash: this.hash, pers: e.pers, persEnc: e.persEnc || "utf8", entropy: e.entropy || QR(this.hash.hmacStrength), entropyEnc: e.entropy && e.entropyEnc || "utf8", nonce: this.n.toArray() }), o = this.n.byteLength(), f = this.n.sub(new Un(2));; ) {
        var p = new Un(r.generate(o));
        if (!(p.cmp(f) > 0))
          return p.iaddn(1), this.keyFromPrivate(p);
      }
    };
    Sr.prototype._truncateToN = function(e, r) {
      var o = e.byteLength() * 8 - this.n.bitLength();
      return o > 0 && (e = e.ushrn(o)), !r && e.cmp(this.n) >= 0 ? e.sub(this.n) : e;
    };
    Sr.prototype.sign = function(e, r, o, f) {
      typeof o == "object" && (f = o, o = null), f || (f = {}), r = this.keyFromPrivate(r, o), e = this._truncateToN(new Un(e, 16));
      for (var p = this.n.byteLength(), m2 = r.getPrivate().toArray("be", p), y3 = e.toArray("be", p), M = new by({ hash: this.hash, entropy: m2, nonce: y3, pers: f.pers, persEnc: f.persEnc || "utf8" }), x = this.n.sub(new Un(1)), S = 0;; S++) {
        var E2 = f.k ? f.k(S) : new Un(M.generate(this.n.byteLength()));
        if (E2 = this._truncateToN(E2, true), !(E2.cmpn(1) <= 0 || E2.cmp(x) >= 0)) {
          var B = this.g.mul(E2);
          if (!B.isInfinity()) {
            var q2 = B.getX(), L2 = q2.umod(this.n);
            if (L2.cmpn(0) !== 0) {
              var ge = E2.invm(this.n).mul(L2.mul(r.getPrivate()).iadd(e));
              if (ge = ge.umod(this.n), ge.cmpn(0) !== 0) {
                var _e = (B.getY().isOdd() ? 1 : 0) | (q2.cmp(L2) !== 0 ? 2 : 0);
                return f.canonical && ge.cmp(this.nh) > 0 && (ge = this.n.sub(ge), _e ^= 1), new n0({ r: L2, s: ge, recoveryParam: _e });
              }
            }
          }
        }
      }
    };
    Sr.prototype.verify = function(e, r, o, f) {
      e = this._truncateToN(new Un(e, 16)), o = this.keyFromPublic(o, f), r = new n0(r, "hex");
      var { r: p, s: m2 } = r;
      if (p.cmpn(1) < 0 || p.cmp(this.n) >= 0 || m2.cmpn(1) < 0 || m2.cmp(this.n) >= 0)
        return false;
      var y3 = m2.invm(this.n), M = y3.mul(e).umod(this.n), x = y3.mul(p).umod(this.n), S;
      return this.curve._maxwellTrick ? (S = this.g.jmulAdd(M, o.getPublic(), x), S.isInfinity() ? false : S.eqXToP(p)) : (S = this.g.mulAdd(M, o.getPublic(), x), S.isInfinity() ? false : S.getX().umod(this.n).cmp(p) === 0);
    };
    Sr.prototype.recoverPubKey = function(t, e, r, o) {
      my((3 & r) === r, "The recovery param is more than two bits"), e = new n0(e, o);
      var f = this.n, p = new Un(t), m2 = e.r, y3 = e.s, M = r & 1, x = r >> 1;
      if (m2.cmp(this.curve.p.umod(this.curve.n)) >= 0 && x)
        throw new Error("Unable to find sencond key candinate");
      x ? m2 = this.curve.pointFromX(m2.add(this.curve.n), M) : m2 = this.curve.pointFromX(m2, M);
      var S = e.r.invm(f), E2 = f.sub(p).mul(S).umod(f), B = y3.mul(S).umod(f);
      return this.g.mulAdd(E2, m2, B);
    };
    Sr.prototype.getKeyRecoveryParam = function(t, e, r, o) {
      if (e = new n0(e, o), e.recoveryParam !== null)
        return e.recoveryParam;
      for (var f = 0;f < 4; f++) {
        var p;
        try {
          p = this.recoverPubKey(t, e, f);
        } catch {
          continue;
        }
        if (p.eq(r))
          return f;
      }
      throw new Error("Unable to find valid recovery factor");
    };
  });
  xy = T2((Zk, _y) => {
    var za = or(), My = za.assert, wy = za.parseBytes, Cf = za.cachedProperty;
    function Ft(t, e) {
      this.eddsa = t, this._secret = wy(e.secret), t.isPoint(e.pub) ? this._pub = e.pub : this._pubBytes = wy(e.pub);
    }
    Ft.fromPublic = function(e, r) {
      return r instanceof Ft ? r : new Ft(e, { pub: r });
    };
    Ft.fromSecret = function(e, r) {
      return r instanceof Ft ? r : new Ft(e, { secret: r });
    };
    Ft.prototype.secret = function() {
      return this._secret;
    };
    Cf(Ft, "pubBytes", function() {
      return this.eddsa.encodePoint(this.pub());
    });
    Cf(Ft, "pub", function() {
      return this._pubBytes ? this.eddsa.decodePoint(this._pubBytes) : this.eddsa.g.mul(this.priv());
    });
    Cf(Ft, "privBytes", function() {
      var e = this.eddsa, r = this.hash(), o = e.encodingLength - 1, f = r.slice(0, e.encodingLength);
      return f[0] &= 248, f[o] &= 127, f[o] |= 64, f;
    });
    Cf(Ft, "priv", function() {
      return this.eddsa.decodeInt(this.privBytes());
    });
    Cf(Ft, "hash", function() {
      return this.eddsa.hash().update(this.secret()).digest();
    });
    Cf(Ft, "messagePrefix", function() {
      return this.hash().slice(this.eddsa.encodingLength);
    });
    Ft.prototype.sign = function(e) {
      return My(this._secret, "KeyPair can only verify"), this.eddsa.sign(e, this);
    };
    Ft.prototype.verify = function(e, r) {
      return this.eddsa.verify(e, r, this);
    };
    Ft.prototype.getSecret = function(e) {
      return My(this._secret, "KeyPair is public only"), za.encode(this.secret(), e);
    };
    Ft.prototype.getPublic = function(e) {
      return za.encode(this.pubBytes(), e);
    };
    _y.exports = Ft;
  });
  Ey = T2((Vk, Sy) => {
    var eB = ri(), f0 = or(), tB = f0.assert, a0 = f0.cachedProperty, rB = f0.parseBytes;
    function zn(t, e) {
      this.eddsa = t, typeof e != "object" && (e = rB(e)), Array.isArray(e) && (e = { R: e.slice(0, t.encodingLength), S: e.slice(t.encodingLength) }), tB(e.R && e.S, "Signature without R or S"), t.isPoint(e.R) && (this._R = e.R), e.S instanceof eB && (this._S = e.S), this._Rencoded = Array.isArray(e.R) ? e.R : e.Rencoded, this._Sencoded = Array.isArray(e.S) ? e.S : e.Sencoded;
    }
    a0(zn, "S", function() {
      return this.eddsa.decodeInt(this.Sencoded());
    });
    a0(zn, "R", function() {
      return this.eddsa.decodePoint(this.Rencoded());
    });
    a0(zn, "Rencoded", function() {
      return this.eddsa.encodePoint(this.R());
    });
    a0(zn, "Sencoded", function() {
      return this.eddsa.encodeInt(this.S());
    });
    zn.prototype.toBytes = function() {
      return this.Rencoded().concat(this.Sencoded());
    };
    zn.prototype.toHex = function() {
      return f0.encode(this.toBytes(), "hex").toUpperCase();
    };
    Sy.exports = zn;
  });
  Iy = T2(($k, qy) => {
    var iB = e0(), nB = t0(), Of = or(), fB = Of.assert, Ry = Of.parseBytes, By = xy(), Ay = Ey();
    function nr(t) {
      if (fB(t === "ed25519", "only tested with ed25519 so far"), !(this instanceof nr))
        return new nr(t);
      t = nB[t].curve, this.curve = t, this.g = t.g, this.g.precompute(t.n.bitLength() + 1), this.pointClass = t.point().constructor, this.encodingLength = Math.ceil(t.n.bitLength() / 8), this.hash = iB.sha512;
    }
    qy.exports = nr;
    nr.prototype.sign = function(e, r) {
      e = Ry(e);
      var o = this.keyFromSecret(r), f = this.hashInt(o.messagePrefix(), e), p = this.g.mul(f), m2 = this.encodePoint(p), y3 = this.hashInt(m2, o.pubBytes(), e).mul(o.priv()), M = f.add(y3).umod(this.curve.n);
      return this.makeSignature({ R: p, S: M, Rencoded: m2 });
    };
    nr.prototype.verify = function(e, r, o) {
      e = Ry(e), r = this.makeSignature(r);
      var f = this.keyFromPublic(o), p = this.hashInt(r.Rencoded(), f.pubBytes(), e), m2 = this.g.mul(r.S()), y3 = r.R().add(f.pub().mul(p));
      return y3.eq(m2);
    };
    nr.prototype.hashInt = function() {
      for (var e = this.hash(), r = 0;r < arguments.length; r++)
        e.update(arguments[r]);
      return Of.intFromLE(e.digest()).umod(this.curve.n);
    };
    nr.prototype.keyFromPublic = function(e) {
      return By.fromPublic(this, e);
    };
    nr.prototype.keyFromSecret = function(e) {
      return By.fromSecret(this, e);
    };
    nr.prototype.makeSignature = function(e) {
      return e instanceof Ay ? e : new Ay(this, e);
    };
    nr.prototype.encodePoint = function(e) {
      var r = e.getY().toArray("le", this.encodingLength);
      return r[this.encodingLength - 1] |= e.getX().isOdd() ? 128 : 0, r;
    };
    nr.prototype.decodePoint = function(e) {
      e = Of.parseBytes(e);
      var r = e.length - 1, o = e.slice(0, r).concat(e[r] & -129), f = (e[r] & 128) !== 0, p = Of.intFromLE(o);
      return this.curve.pointFromY(p, f);
    };
    nr.prototype.encodeInt = function(e) {
      return e.toArray("le", this.encodingLength);
    };
    nr.prototype.decodeInt = function(e) {
      return Of.intFromLE(e);
    };
    nr.prototype.isPoint = function(e) {
      return e instanceof this.pointClass;
    };
  });
  o0 = T2((Ty) => {
    var Hn = Ty;
    Hn.version = s2().version;
    Hn.utils = or();
    Hn.rand = As();
    Hn.curve = Pl();
    Hn.curves = t0();
    Hn.ec = yy();
    Hn.eddsa = Iy();
  });
  td = T2((ky, ed) => {
    (function(t, e) {
      function r(v, i) {
        if (!v)
          throw new Error(i || "Assertion failed");
      }
      function o(v, i) {
        v.super_ = i;
        var a = function() {
        };
        a.prototype = i.prototype, v.prototype = new a, v.prototype.constructor = v;
      }
      function f(v, i, a) {
        if (f.isBN(v))
          return v;
        this.negative = 0, this.words = null, this.length = 0, this.red = null, v !== null && ((i === "le" || i === "be") && (a = i, i = 10), this._init(v || 0, i || 10, a || "be"));
      }
      typeof t == "object" ? t.exports = f : e.BN = f, f.BN = f, f.wordSize = 26;
      var p;
      try {
        typeof window < "u" && typeof window.Buffer < "u" ? p = window.Buffer : p = ji().Buffer;
      } catch {
      }
      f.isBN = function(i) {
        return i instanceof f ? true : i !== null && typeof i == "object" && i.constructor.wordSize === f.wordSize && Array.isArray(i.words);
      }, f.max = function(i, a) {
        return i.cmp(a) > 0 ? i : a;
      }, f.min = function(i, a) {
        return i.cmp(a) < 0 ? i : a;
      }, f.prototype._init = function(i, a, h2) {
        if (typeof i == "number")
          return this._initNumber(i, a, h2);
        if (typeof i == "object")
          return this._initArray(i, a, h2);
        a === "hex" && (a = 16), r(a === (a | 0) && a >= 2 && a <= 36), i = i.toString().replace(/\s+/g, "");
        var s = 0;
        i[0] === "-" && (s++, this.negative = 1), s < i.length && (a === 16 ? this._parseHex(i, s, h2) : (this._parseBase(i, a, s), h2 === "le" && this._initArray(this.toArray(), a, h2)));
      }, f.prototype._initNumber = function(i, a, h2) {
        i < 0 && (this.negative = 1, i = -i), i < 67108864 ? (this.words = [i & 67108863], this.length = 1) : i < 4503599627370496 ? (this.words = [i & 67108863, i / 67108864 & 67108863], this.length = 2) : (r(i < 9007199254740992), this.words = [i & 67108863, i / 67108864 & 67108863, 1], this.length = 3), h2 === "le" && this._initArray(this.toArray(), a, h2);
      }, f.prototype._initArray = function(i, a, h2) {
        if (r(typeof i.length == "number"), i.length <= 0)
          return this.words = [0], this.length = 1, this;
        this.length = Math.ceil(i.length / 3), this.words = new Array(this.length);
        for (var s = 0;s < this.length; s++)
          this.words[s] = 0;
        var u, c, b3 = 0;
        if (h2 === "be")
          for (s = i.length - 1, u = 0;s >= 0; s -= 3)
            c = i[s] | i[s - 1] << 8 | i[s - 2] << 16, this.words[u] |= c << b3 & 67108863, this.words[u + 1] = c >>> 26 - b3 & 67108863, b3 += 24, b3 >= 26 && (b3 -= 26, u++);
        else if (h2 === "le")
          for (s = 0, u = 0;s < i.length; s += 3)
            c = i[s] | i[s + 1] << 8 | i[s + 2] << 16, this.words[u] |= c << b3 & 67108863, this.words[u + 1] = c >>> 26 - b3 & 67108863, b3 += 24, b3 >= 26 && (b3 -= 26, u++);
        return this.strip();
      };
      function m2(v, i) {
        var a = v.charCodeAt(i);
        return a >= 65 && a <= 70 ? a - 55 : a >= 97 && a <= 102 ? a - 87 : a - 48 & 15;
      }
      function y3(v, i, a) {
        var h2 = m2(v, a);
        return a - 1 >= i && (h2 |= m2(v, a - 1) << 4), h2;
      }
      f.prototype._parseHex = function(i, a, h2) {
        this.length = Math.ceil((i.length - a) / 6), this.words = new Array(this.length);
        for (var s = 0;s < this.length; s++)
          this.words[s] = 0;
        var u = 0, c = 0, b3;
        if (h2 === "be")
          for (s = i.length - 1;s >= a; s -= 2)
            b3 = y3(i, a, s) << u, this.words[c] |= b3 & 67108863, u >= 18 ? (u -= 18, c += 1, this.words[c] |= b3 >>> 26) : u += 8;
        else {
          var l = i.length - a;
          for (s = l % 2 === 0 ? a + 1 : a;s < i.length; s += 2)
            b3 = y3(i, a, s) << u, this.words[c] |= b3 & 67108863, u >= 18 ? (u -= 18, c += 1, this.words[c] |= b3 >>> 26) : u += 8;
        }
        this.strip();
      };
      function M(v, i, a, h2) {
        for (var s = 0, u = Math.min(v.length, a), c = i;c < u; c++) {
          var b3 = v.charCodeAt(c) - 48;
          s *= h2, b3 >= 49 ? s += b3 - 49 + 10 : b3 >= 17 ? s += b3 - 17 + 10 : s += b3;
        }
        return s;
      }
      f.prototype._parseBase = function(i, a, h2) {
        this.words = [0], this.length = 1;
        for (var s = 0, u = 1;u <= 67108863; u *= a)
          s++;
        s--, u = u / a | 0;
        for (var c = i.length - h2, b3 = c % s, l = Math.min(c, c - b3) + h2, n = 0, d = h2;d < l; d += s)
          n = M(i, d, d + s, a), this.imuln(u), this.words[0] + n < 67108864 ? this.words[0] += n : this._iaddn(n);
        if (b3 !== 0) {
          var w = 1;
          for (n = M(i, d, i.length, a), d = 0;d < b3; d++)
            w *= a;
          this.imuln(w), this.words[0] + n < 67108864 ? this.words[0] += n : this._iaddn(n);
        }
        this.strip();
      }, f.prototype.copy = function(i) {
        i.words = new Array(this.length);
        for (var a = 0;a < this.length; a++)
          i.words[a] = this.words[a];
        i.length = this.length, i.negative = this.negative, i.red = this.red;
      }, f.prototype.clone = function() {
        var i = new f(null);
        return this.copy(i), i;
      }, f.prototype._expand = function(i) {
        for (;this.length < i; )
          this.words[this.length++] = 0;
        return this;
      }, f.prototype.strip = function() {
        for (;this.length > 1 && this.words[this.length - 1] === 0; )
          this.length--;
        return this._normSign();
      }, f.prototype._normSign = function() {
        return this.length === 1 && this.words[0] === 0 && (this.negative = 0), this;
      }, f.prototype.inspect = function() {
        return (this.red ? "<BN-R: " : "<BN: ") + this.toString(16) + ">";
      };
      var x = ["", "0", "00", "000", "0000", "00000", "000000", "0000000", "00000000", "000000000", "0000000000", "00000000000", "000000000000", "0000000000000", "00000000000000", "000000000000000", "0000000000000000", "00000000000000000", "000000000000000000", "0000000000000000000", "00000000000000000000", "000000000000000000000", "0000000000000000000000", "00000000000000000000000", "000000000000000000000000", "0000000000000000000000000"], S = [0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5], E2 = [0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 1e7, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176];
      f.prototype.toString = function(i, a) {
        i = i || 10, a = a | 0 || 1;
        var h2;
        if (i === 16 || i === "hex") {
          h2 = "";
          for (var s = 0, u = 0, c = 0;c < this.length; c++) {
            var b3 = this.words[c], l = ((b3 << s | u) & 16777215).toString(16);
            u = b3 >>> 24 - s & 16777215, u !== 0 || c !== this.length - 1 ? h2 = x[6 - l.length] + l + h2 : h2 = l + h2, s += 2, s >= 26 && (s -= 26, c--);
          }
          for (u !== 0 && (h2 = u.toString(16) + h2);h2.length % a !== 0; )
            h2 = "0" + h2;
          return this.negative !== 0 && (h2 = "-" + h2), h2;
        }
        if (i === (i | 0) && i >= 2 && i <= 36) {
          var n = S[i], d = E2[i];
          h2 = "";
          var w = this.clone();
          for (w.negative = 0;!w.isZero(); ) {
            var g = w.modn(d).toString(i);
            w = w.idivn(d), w.isZero() ? h2 = g + h2 : h2 = x[n - g.length] + g + h2;
          }
          for (this.isZero() && (h2 = "0" + h2);h2.length % a !== 0; )
            h2 = "0" + h2;
          return this.negative !== 0 && (h2 = "-" + h2), h2;
        }
        r(false, "Base should be between 2 and 36");
      }, f.prototype.toNumber = function() {
        var i = this.words[0];
        return this.length === 2 ? i += this.words[1] * 67108864 : this.length === 3 && this.words[2] === 1 ? i += 4503599627370496 + this.words[1] * 67108864 : this.length > 2 && r(false, "Number can only safely store up to 53 bits"), this.negative !== 0 ? -i : i;
      }, f.prototype.toJSON = function() {
        return this.toString(16);
      }, f.prototype.toBuffer = function(i, a) {
        return r(typeof p < "u"), this.toArrayLike(p, i, a);
      }, f.prototype.toArray = function(i, a) {
        return this.toArrayLike(Array, i, a);
      }, f.prototype.toArrayLike = function(i, a, h2) {
        var s = this.byteLength(), u = h2 || Math.max(1, s);
        r(s <= u, "byte array longer than desired length"), r(u > 0, "Requested array length <= 0"), this.strip();
        var c = a === "le", b3 = new i(u), l, n, d = this.clone();
        if (c) {
          for (n = 0;!d.isZero(); n++)
            l = d.andln(255), d.iushrn(8), b3[n] = l;
          for (;n < u; n++)
            b3[n] = 0;
        } else {
          for (n = 0;n < u - s; n++)
            b3[n] = 0;
          for (n = 0;!d.isZero(); n++)
            l = d.andln(255), d.iushrn(8), b3[u - n - 1] = l;
        }
        return b3;
      }, Math.clz32 ? f.prototype._countBits = function(i) {
        return 32 - Math.clz32(i);
      } : f.prototype._countBits = function(i) {
        var a = i, h2 = 0;
        return a >= 4096 && (h2 += 13, a >>>= 13), a >= 64 && (h2 += 7, a >>>= 7), a >= 8 && (h2 += 4, a >>>= 4), a >= 2 && (h2 += 2, a >>>= 2), h2 + a;
      }, f.prototype._zeroBits = function(i) {
        if (i === 0)
          return 26;
        var a = i, h2 = 0;
        return (a & 8191) === 0 && (h2 += 13, a >>>= 13), (a & 127) === 0 && (h2 += 7, a >>>= 7), (a & 15) === 0 && (h2 += 4, a >>>= 4), (a & 3) === 0 && (h2 += 2, a >>>= 2), (a & 1) === 0 && h2++, h2;
      }, f.prototype.bitLength = function() {
        var i = this.words[this.length - 1], a = this._countBits(i);
        return (this.length - 1) * 26 + a;
      };
      function B(v) {
        for (var i = new Array(v.bitLength()), a = 0;a < i.length; a++) {
          var h2 = a / 26 | 0, s = a % 26;
          i[a] = (v.words[h2] & 1 << s) >>> s;
        }
        return i;
      }
      f.prototype.zeroBits = function() {
        if (this.isZero())
          return 0;
        for (var i = 0, a = 0;a < this.length; a++) {
          var h2 = this._zeroBits(this.words[a]);
          if (i += h2, h2 !== 26)
            break;
        }
        return i;
      }, f.prototype.byteLength = function() {
        return Math.ceil(this.bitLength() / 8);
      }, f.prototype.toTwos = function(i) {
        return this.negative !== 0 ? this.abs().inotn(i).iaddn(1) : this.clone();
      }, f.prototype.fromTwos = function(i) {
        return this.testn(i - 1) ? this.notn(i).iaddn(1).ineg() : this.clone();
      }, f.prototype.isNeg = function() {
        return this.negative !== 0;
      }, f.prototype.neg = function() {
        return this.clone().ineg();
      }, f.prototype.ineg = function() {
        return this.isZero() || (this.negative ^= 1), this;
      }, f.prototype.iuor = function(i) {
        for (;this.length < i.length; )
          this.words[this.length++] = 0;
        for (var a = 0;a < i.length; a++)
          this.words[a] = this.words[a] | i.words[a];
        return this.strip();
      }, f.prototype.ior = function(i) {
        return r((this.negative | i.negative) === 0), this.iuor(i);
      }, f.prototype.or = function(i) {
        return this.length > i.length ? this.clone().ior(i) : i.clone().ior(this);
      }, f.prototype.uor = function(i) {
        return this.length > i.length ? this.clone().iuor(i) : i.clone().iuor(this);
      }, f.prototype.iuand = function(i) {
        var a;
        this.length > i.length ? a = i : a = this;
        for (var h2 = 0;h2 < a.length; h2++)
          this.words[h2] = this.words[h2] & i.words[h2];
        return this.length = a.length, this.strip();
      }, f.prototype.iand = function(i) {
        return r((this.negative | i.negative) === 0), this.iuand(i);
      }, f.prototype.and = function(i) {
        return this.length > i.length ? this.clone().iand(i) : i.clone().iand(this);
      }, f.prototype.uand = function(i) {
        return this.length > i.length ? this.clone().iuand(i) : i.clone().iuand(this);
      }, f.prototype.iuxor = function(i) {
        var a, h2;
        this.length > i.length ? (a = this, h2 = i) : (a = i, h2 = this);
        for (var s = 0;s < h2.length; s++)
          this.words[s] = a.words[s] ^ h2.words[s];
        if (this !== a)
          for (;s < a.length; s++)
            this.words[s] = a.words[s];
        return this.length = a.length, this.strip();
      }, f.prototype.ixor = function(i) {
        return r((this.negative | i.negative) === 0), this.iuxor(i);
      }, f.prototype.xor = function(i) {
        return this.length > i.length ? this.clone().ixor(i) : i.clone().ixor(this);
      }, f.prototype.uxor = function(i) {
        return this.length > i.length ? this.clone().iuxor(i) : i.clone().iuxor(this);
      }, f.prototype.inotn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = Math.ceil(i / 26) | 0, h2 = i % 26;
        this._expand(a), h2 > 0 && a--;
        for (var s = 0;s < a; s++)
          this.words[s] = ~this.words[s] & 67108863;
        return h2 > 0 && (this.words[s] = ~this.words[s] & 67108863 >> 26 - h2), this.strip();
      }, f.prototype.notn = function(i) {
        return this.clone().inotn(i);
      }, f.prototype.setn = function(i, a) {
        r(typeof i == "number" && i >= 0);
        var h2 = i / 26 | 0, s = i % 26;
        return this._expand(h2 + 1), a ? this.words[h2] = this.words[h2] | 1 << s : this.words[h2] = this.words[h2] & ~(1 << s), this.strip();
      }, f.prototype.iadd = function(i) {
        var a;
        if (this.negative !== 0 && i.negative === 0)
          return this.negative = 0, a = this.isub(i), this.negative ^= 1, this._normSign();
        if (this.negative === 0 && i.negative !== 0)
          return i.negative = 0, a = this.isub(i), i.negative = 1, a._normSign();
        var h2, s;
        this.length > i.length ? (h2 = this, s = i) : (h2 = i, s = this);
        for (var u = 0, c = 0;c < s.length; c++)
          a = (h2.words[c] | 0) + (s.words[c] | 0) + u, this.words[c] = a & 67108863, u = a >>> 26;
        for (;u !== 0 && c < h2.length; c++)
          a = (h2.words[c] | 0) + u, this.words[c] = a & 67108863, u = a >>> 26;
        if (this.length = h2.length, u !== 0)
          this.words[this.length] = u, this.length++;
        else if (h2 !== this)
          for (;c < h2.length; c++)
            this.words[c] = h2.words[c];
        return this;
      }, f.prototype.add = function(i) {
        var a;
        return i.negative !== 0 && this.negative === 0 ? (i.negative = 0, a = this.sub(i), i.negative ^= 1, a) : i.negative === 0 && this.negative !== 0 ? (this.negative = 0, a = i.sub(this), this.negative = 1, a) : this.length > i.length ? this.clone().iadd(i) : i.clone().iadd(this);
      }, f.prototype.isub = function(i) {
        if (i.negative !== 0) {
          i.negative = 0;
          var a = this.iadd(i);
          return i.negative = 1, a._normSign();
        } else if (this.negative !== 0)
          return this.negative = 0, this.iadd(i), this.negative = 1, this._normSign();
        var h2 = this.cmp(i);
        if (h2 === 0)
          return this.negative = 0, this.length = 1, this.words[0] = 0, this;
        var s, u;
        h2 > 0 ? (s = this, u = i) : (s = i, u = this);
        for (var c = 0, b3 = 0;b3 < u.length; b3++)
          a = (s.words[b3] | 0) - (u.words[b3] | 0) + c, c = a >> 26, this.words[b3] = a & 67108863;
        for (;c !== 0 && b3 < s.length; b3++)
          a = (s.words[b3] | 0) + c, c = a >> 26, this.words[b3] = a & 67108863;
        if (c === 0 && b3 < s.length && s !== this)
          for (;b3 < s.length; b3++)
            this.words[b3] = s.words[b3];
        return this.length = Math.max(this.length, b3), s !== this && (this.negative = 1), this.strip();
      }, f.prototype.sub = function(i) {
        return this.clone().isub(i);
      };
      function q2(v, i, a) {
        a.negative = i.negative ^ v.negative;
        var h2 = v.length + i.length | 0;
        a.length = h2, h2 = h2 - 1 | 0;
        var s = v.words[0] | 0, u = i.words[0] | 0, c = s * u, b3 = c & 67108863, l = c / 67108864 | 0;
        a.words[0] = b3;
        for (var n = 1;n < h2; n++) {
          for (var d = l >>> 26, w = l & 67108863, g = Math.min(n, i.length - 1), _3 = Math.max(0, n - v.length + 1);_3 <= g; _3++) {
            var A2 = n - _3 | 0;
            s = v.words[A2] | 0, u = i.words[_3] | 0, c = s * u + w, d += c / 67108864 | 0, w = c & 67108863;
          }
          a.words[n] = w | 0, l = d | 0;
        }
        return l !== 0 ? a.words[n] = l | 0 : a.length--, a.strip();
      }
      var L2 = function(i, a, h2) {
        var s = i.words, u = a.words, c = h2.words, b3 = 0, l, n, d, w = s[0] | 0, g = w & 8191, _3 = w >>> 13, A2 = s[1] | 0, R2 = A2 & 8191, I = A2 >>> 13, Me = s[2] | 0, k = Me & 8191, D2 = Me >>> 13, nt = s[3] | 0, C2 = nt & 8191, O = nt >>> 13, vt = s[4] | 0, F = vt & 8191, U = vt >>> 13, bt = s[5] | 0, z2 = bt & 8191, H = bt >>> 13, mt = s[6] | 0, W = mt & 8191, K = mt >>> 13, gt = s[7] | 0, j = gt & 8191, Z = gt >>> 13, yt = s[8] | 0, V = yt & 8191, $ = yt >>> 13, wt = s[9] | 0, G = wt & 8191, Y = wt >>> 13, Mt = u[0] | 0, X = Mt & 8191, J = Mt >>> 13, _t = u[1] | 0, Q = _t & 8191, ee = _t >>> 13, xt = u[2] | 0, te = xt & 8191, re = xt >>> 13, St = u[3] | 0, ie = St & 8191, ne = St >>> 13, Et = u[4] | 0, fe = Et & 8191, ae = Et >>> 13, At = u[5] | 0, oe = At & 8191, se = At >>> 13, Rt = u[6] | 0, he = Rt & 8191, ue = Rt >>> 13, Bt = u[7] | 0, le = Bt & 8191, de = Bt >>> 13, qt = u[8] | 0, ce = qt & 8191, pe = qt >>> 13, It = u[9] | 0, ve = It & 8191, be = It >>> 13;
        h2.negative = i.negative ^ a.negative, h2.length = 19, l = Math.imul(g, X), n = Math.imul(g, J), n = n + Math.imul(_3, X) | 0, d = Math.imul(_3, J);
        var ft = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (ft >>> 26) | 0, ft &= 67108863, l = Math.imul(R2, X), n = Math.imul(R2, J), n = n + Math.imul(I, X) | 0, d = Math.imul(I, J), l = l + Math.imul(g, Q) | 0, n = n + Math.imul(g, ee) | 0, n = n + Math.imul(_3, Q) | 0, d = d + Math.imul(_3, ee) | 0;
        var Be = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Be >>> 26) | 0, Be &= 67108863, l = Math.imul(k, X), n = Math.imul(k, J), n = n + Math.imul(D2, X) | 0, d = Math.imul(D2, J), l = l + Math.imul(R2, Q) | 0, n = n + Math.imul(R2, ee) | 0, n = n + Math.imul(I, Q) | 0, d = d + Math.imul(I, ee) | 0, l = l + Math.imul(g, te) | 0, n = n + Math.imul(g, re) | 0, n = n + Math.imul(_3, te) | 0, d = d + Math.imul(_3, re) | 0;
        var qe = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (qe >>> 26) | 0, qe &= 67108863, l = Math.imul(C2, X), n = Math.imul(C2, J), n = n + Math.imul(O, X) | 0, d = Math.imul(O, J), l = l + Math.imul(k, Q) | 0, n = n + Math.imul(k, ee) | 0, n = n + Math.imul(D2, Q) | 0, d = d + Math.imul(D2, ee) | 0, l = l + Math.imul(R2, te) | 0, n = n + Math.imul(R2, re) | 0, n = n + Math.imul(I, te) | 0, d = d + Math.imul(I, re) | 0, l = l + Math.imul(g, ie) | 0, n = n + Math.imul(g, ne) | 0, n = n + Math.imul(_3, ie) | 0, d = d + Math.imul(_3, ne) | 0;
        var ze = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (ze >>> 26) | 0, ze &= 67108863, l = Math.imul(F, X), n = Math.imul(F, J), n = n + Math.imul(U, X) | 0, d = Math.imul(U, J), l = l + Math.imul(C2, Q) | 0, n = n + Math.imul(C2, ee) | 0, n = n + Math.imul(O, Q) | 0, d = d + Math.imul(O, ee) | 0, l = l + Math.imul(k, te) | 0, n = n + Math.imul(k, re) | 0, n = n + Math.imul(D2, te) | 0, d = d + Math.imul(D2, re) | 0, l = l + Math.imul(R2, ie) | 0, n = n + Math.imul(R2, ne) | 0, n = n + Math.imul(I, ie) | 0, d = d + Math.imul(I, ne) | 0, l = l + Math.imul(g, fe) | 0, n = n + Math.imul(g, ae) | 0, n = n + Math.imul(_3, fe) | 0, d = d + Math.imul(_3, ae) | 0;
        var He = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (He >>> 26) | 0, He &= 67108863, l = Math.imul(z2, X), n = Math.imul(z2, J), n = n + Math.imul(H, X) | 0, d = Math.imul(H, J), l = l + Math.imul(F, Q) | 0, n = n + Math.imul(F, ee) | 0, n = n + Math.imul(U, Q) | 0, d = d + Math.imul(U, ee) | 0, l = l + Math.imul(C2, te) | 0, n = n + Math.imul(C2, re) | 0, n = n + Math.imul(O, te) | 0, d = d + Math.imul(O, re) | 0, l = l + Math.imul(k, ie) | 0, n = n + Math.imul(k, ne) | 0, n = n + Math.imul(D2, ie) | 0, d = d + Math.imul(D2, ne) | 0, l = l + Math.imul(R2, fe) | 0, n = n + Math.imul(R2, ae) | 0, n = n + Math.imul(I, fe) | 0, d = d + Math.imul(I, ae) | 0, l = l + Math.imul(g, oe) | 0, n = n + Math.imul(g, se) | 0, n = n + Math.imul(_3, oe) | 0, d = d + Math.imul(_3, se) | 0;
        var We = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (We >>> 26) | 0, We &= 67108863, l = Math.imul(W, X), n = Math.imul(W, J), n = n + Math.imul(K, X) | 0, d = Math.imul(K, J), l = l + Math.imul(z2, Q) | 0, n = n + Math.imul(z2, ee) | 0, n = n + Math.imul(H, Q) | 0, d = d + Math.imul(H, ee) | 0, l = l + Math.imul(F, te) | 0, n = n + Math.imul(F, re) | 0, n = n + Math.imul(U, te) | 0, d = d + Math.imul(U, re) | 0, l = l + Math.imul(C2, ie) | 0, n = n + Math.imul(C2, ne) | 0, n = n + Math.imul(O, ie) | 0, d = d + Math.imul(O, ne) | 0, l = l + Math.imul(k, fe) | 0, n = n + Math.imul(k, ae) | 0, n = n + Math.imul(D2, fe) | 0, d = d + Math.imul(D2, ae) | 0, l = l + Math.imul(R2, oe) | 0, n = n + Math.imul(R2, se) | 0, n = n + Math.imul(I, oe) | 0, d = d + Math.imul(I, se) | 0, l = l + Math.imul(g, he) | 0, n = n + Math.imul(g, ue) | 0, n = n + Math.imul(_3, he) | 0, d = d + Math.imul(_3, ue) | 0;
        var Ke = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ke >>> 26) | 0, Ke &= 67108863, l = Math.imul(j, X), n = Math.imul(j, J), n = n + Math.imul(Z, X) | 0, d = Math.imul(Z, J), l = l + Math.imul(W, Q) | 0, n = n + Math.imul(W, ee) | 0, n = n + Math.imul(K, Q) | 0, d = d + Math.imul(K, ee) | 0, l = l + Math.imul(z2, te) | 0, n = n + Math.imul(z2, re) | 0, n = n + Math.imul(H, te) | 0, d = d + Math.imul(H, re) | 0, l = l + Math.imul(F, ie) | 0, n = n + Math.imul(F, ne) | 0, n = n + Math.imul(U, ie) | 0, d = d + Math.imul(U, ne) | 0, l = l + Math.imul(C2, fe) | 0, n = n + Math.imul(C2, ae) | 0, n = n + Math.imul(O, fe) | 0, d = d + Math.imul(O, ae) | 0, l = l + Math.imul(k, oe) | 0, n = n + Math.imul(k, se) | 0, n = n + Math.imul(D2, oe) | 0, d = d + Math.imul(D2, se) | 0, l = l + Math.imul(R2, he) | 0, n = n + Math.imul(R2, ue) | 0, n = n + Math.imul(I, he) | 0, d = d + Math.imul(I, ue) | 0, l = l + Math.imul(g, le) | 0, n = n + Math.imul(g, de) | 0, n = n + Math.imul(_3, le) | 0, d = d + Math.imul(_3, de) | 0;
        var je = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (je >>> 26) | 0, je &= 67108863, l = Math.imul(V, X), n = Math.imul(V, J), n = n + Math.imul($, X) | 0, d = Math.imul($, J), l = l + Math.imul(j, Q) | 0, n = n + Math.imul(j, ee) | 0, n = n + Math.imul(Z, Q) | 0, d = d + Math.imul(Z, ee) | 0, l = l + Math.imul(W, te) | 0, n = n + Math.imul(W, re) | 0, n = n + Math.imul(K, te) | 0, d = d + Math.imul(K, re) | 0, l = l + Math.imul(z2, ie) | 0, n = n + Math.imul(z2, ne) | 0, n = n + Math.imul(H, ie) | 0, d = d + Math.imul(H, ne) | 0, l = l + Math.imul(F, fe) | 0, n = n + Math.imul(F, ae) | 0, n = n + Math.imul(U, fe) | 0, d = d + Math.imul(U, ae) | 0, l = l + Math.imul(C2, oe) | 0, n = n + Math.imul(C2, se) | 0, n = n + Math.imul(O, oe) | 0, d = d + Math.imul(O, se) | 0, l = l + Math.imul(k, he) | 0, n = n + Math.imul(k, ue) | 0, n = n + Math.imul(D2, he) | 0, d = d + Math.imul(D2, ue) | 0, l = l + Math.imul(R2, le) | 0, n = n + Math.imul(R2, de) | 0, n = n + Math.imul(I, le) | 0, d = d + Math.imul(I, de) | 0, l = l + Math.imul(g, ce) | 0, n = n + Math.imul(g, pe) | 0, n = n + Math.imul(_3, ce) | 0, d = d + Math.imul(_3, pe) | 0;
        var Ze = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ze >>> 26) | 0, Ze &= 67108863, l = Math.imul(G, X), n = Math.imul(G, J), n = n + Math.imul(Y, X) | 0, d = Math.imul(Y, J), l = l + Math.imul(V, Q) | 0, n = n + Math.imul(V, ee) | 0, n = n + Math.imul($, Q) | 0, d = d + Math.imul($, ee) | 0, l = l + Math.imul(j, te) | 0, n = n + Math.imul(j, re) | 0, n = n + Math.imul(Z, te) | 0, d = d + Math.imul(Z, re) | 0, l = l + Math.imul(W, ie) | 0, n = n + Math.imul(W, ne) | 0, n = n + Math.imul(K, ie) | 0, d = d + Math.imul(K, ne) | 0, l = l + Math.imul(z2, fe) | 0, n = n + Math.imul(z2, ae) | 0, n = n + Math.imul(H, fe) | 0, d = d + Math.imul(H, ae) | 0, l = l + Math.imul(F, oe) | 0, n = n + Math.imul(F, se) | 0, n = n + Math.imul(U, oe) | 0, d = d + Math.imul(U, se) | 0, l = l + Math.imul(C2, he) | 0, n = n + Math.imul(C2, ue) | 0, n = n + Math.imul(O, he) | 0, d = d + Math.imul(O, ue) | 0, l = l + Math.imul(k, le) | 0, n = n + Math.imul(k, de) | 0, n = n + Math.imul(D2, le) | 0, d = d + Math.imul(D2, de) | 0, l = l + Math.imul(R2, ce) | 0, n = n + Math.imul(R2, pe) | 0, n = n + Math.imul(I, ce) | 0, d = d + Math.imul(I, pe) | 0, l = l + Math.imul(g, ve) | 0, n = n + Math.imul(g, be) | 0, n = n + Math.imul(_3, ve) | 0, d = d + Math.imul(_3, be) | 0;
        var Ve = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ve >>> 26) | 0, Ve &= 67108863, l = Math.imul(G, Q), n = Math.imul(G, ee), n = n + Math.imul(Y, Q) | 0, d = Math.imul(Y, ee), l = l + Math.imul(V, te) | 0, n = n + Math.imul(V, re) | 0, n = n + Math.imul($, te) | 0, d = d + Math.imul($, re) | 0, l = l + Math.imul(j, ie) | 0, n = n + Math.imul(j, ne) | 0, n = n + Math.imul(Z, ie) | 0, d = d + Math.imul(Z, ne) | 0, l = l + Math.imul(W, fe) | 0, n = n + Math.imul(W, ae) | 0, n = n + Math.imul(K, fe) | 0, d = d + Math.imul(K, ae) | 0, l = l + Math.imul(z2, oe) | 0, n = n + Math.imul(z2, se) | 0, n = n + Math.imul(H, oe) | 0, d = d + Math.imul(H, se) | 0, l = l + Math.imul(F, he) | 0, n = n + Math.imul(F, ue) | 0, n = n + Math.imul(U, he) | 0, d = d + Math.imul(U, ue) | 0, l = l + Math.imul(C2, le) | 0, n = n + Math.imul(C2, de) | 0, n = n + Math.imul(O, le) | 0, d = d + Math.imul(O, de) | 0, l = l + Math.imul(k, ce) | 0, n = n + Math.imul(k, pe) | 0, n = n + Math.imul(D2, ce) | 0, d = d + Math.imul(D2, pe) | 0, l = l + Math.imul(R2, ve) | 0, n = n + Math.imul(R2, be) | 0, n = n + Math.imul(I, ve) | 0, d = d + Math.imul(I, be) | 0;
        var $e = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + ($e >>> 26) | 0, $e &= 67108863, l = Math.imul(G, te), n = Math.imul(G, re), n = n + Math.imul(Y, te) | 0, d = Math.imul(Y, re), l = l + Math.imul(V, ie) | 0, n = n + Math.imul(V, ne) | 0, n = n + Math.imul($, ie) | 0, d = d + Math.imul($, ne) | 0, l = l + Math.imul(j, fe) | 0, n = n + Math.imul(j, ae) | 0, n = n + Math.imul(Z, fe) | 0, d = d + Math.imul(Z, ae) | 0, l = l + Math.imul(W, oe) | 0, n = n + Math.imul(W, se) | 0, n = n + Math.imul(K, oe) | 0, d = d + Math.imul(K, se) | 0, l = l + Math.imul(z2, he) | 0, n = n + Math.imul(z2, ue) | 0, n = n + Math.imul(H, he) | 0, d = d + Math.imul(H, ue) | 0, l = l + Math.imul(F, le) | 0, n = n + Math.imul(F, de) | 0, n = n + Math.imul(U, le) | 0, d = d + Math.imul(U, de) | 0, l = l + Math.imul(C2, ce) | 0, n = n + Math.imul(C2, pe) | 0, n = n + Math.imul(O, ce) | 0, d = d + Math.imul(O, pe) | 0, l = l + Math.imul(k, ve) | 0, n = n + Math.imul(k, be) | 0, n = n + Math.imul(D2, ve) | 0, d = d + Math.imul(D2, be) | 0;
        var Ge = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ge >>> 26) | 0, Ge &= 67108863, l = Math.imul(G, ie), n = Math.imul(G, ne), n = n + Math.imul(Y, ie) | 0, d = Math.imul(Y, ne), l = l + Math.imul(V, fe) | 0, n = n + Math.imul(V, ae) | 0, n = n + Math.imul($, fe) | 0, d = d + Math.imul($, ae) | 0, l = l + Math.imul(j, oe) | 0, n = n + Math.imul(j, se) | 0, n = n + Math.imul(Z, oe) | 0, d = d + Math.imul(Z, se) | 0, l = l + Math.imul(W, he) | 0, n = n + Math.imul(W, ue) | 0, n = n + Math.imul(K, he) | 0, d = d + Math.imul(K, ue) | 0, l = l + Math.imul(z2, le) | 0, n = n + Math.imul(z2, de) | 0, n = n + Math.imul(H, le) | 0, d = d + Math.imul(H, de) | 0, l = l + Math.imul(F, ce) | 0, n = n + Math.imul(F, pe) | 0, n = n + Math.imul(U, ce) | 0, d = d + Math.imul(U, pe) | 0, l = l + Math.imul(C2, ve) | 0, n = n + Math.imul(C2, be) | 0, n = n + Math.imul(O, ve) | 0, d = d + Math.imul(O, be) | 0;
        var Ye = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ye >>> 26) | 0, Ye &= 67108863, l = Math.imul(G, fe), n = Math.imul(G, ae), n = n + Math.imul(Y, fe) | 0, d = Math.imul(Y, ae), l = l + Math.imul(V, oe) | 0, n = n + Math.imul(V, se) | 0, n = n + Math.imul($, oe) | 0, d = d + Math.imul($, se) | 0, l = l + Math.imul(j, he) | 0, n = n + Math.imul(j, ue) | 0, n = n + Math.imul(Z, he) | 0, d = d + Math.imul(Z, ue) | 0, l = l + Math.imul(W, le) | 0, n = n + Math.imul(W, de) | 0, n = n + Math.imul(K, le) | 0, d = d + Math.imul(K, de) | 0, l = l + Math.imul(z2, ce) | 0, n = n + Math.imul(z2, pe) | 0, n = n + Math.imul(H, ce) | 0, d = d + Math.imul(H, pe) | 0, l = l + Math.imul(F, ve) | 0, n = n + Math.imul(F, be) | 0, n = n + Math.imul(U, ve) | 0, d = d + Math.imul(U, be) | 0;
        var Xe = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Xe >>> 26) | 0, Xe &= 67108863, l = Math.imul(G, oe), n = Math.imul(G, se), n = n + Math.imul(Y, oe) | 0, d = Math.imul(Y, se), l = l + Math.imul(V, he) | 0, n = n + Math.imul(V, ue) | 0, n = n + Math.imul($, he) | 0, d = d + Math.imul($, ue) | 0, l = l + Math.imul(j, le) | 0, n = n + Math.imul(j, de) | 0, n = n + Math.imul(Z, le) | 0, d = d + Math.imul(Z, de) | 0, l = l + Math.imul(W, ce) | 0, n = n + Math.imul(W, pe) | 0, n = n + Math.imul(K, ce) | 0, d = d + Math.imul(K, pe) | 0, l = l + Math.imul(z2, ve) | 0, n = n + Math.imul(z2, be) | 0, n = n + Math.imul(H, ve) | 0, d = d + Math.imul(H, be) | 0;
        var Je = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Je >>> 26) | 0, Je &= 67108863, l = Math.imul(G, he), n = Math.imul(G, ue), n = n + Math.imul(Y, he) | 0, d = Math.imul(Y, ue), l = l + Math.imul(V, le) | 0, n = n + Math.imul(V, de) | 0, n = n + Math.imul($, le) | 0, d = d + Math.imul($, de) | 0, l = l + Math.imul(j, ce) | 0, n = n + Math.imul(j, pe) | 0, n = n + Math.imul(Z, ce) | 0, d = d + Math.imul(Z, pe) | 0, l = l + Math.imul(W, ve) | 0, n = n + Math.imul(W, be) | 0, n = n + Math.imul(K, ve) | 0, d = d + Math.imul(K, be) | 0;
        var Qe = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Qe >>> 26) | 0, Qe &= 67108863, l = Math.imul(G, le), n = Math.imul(G, de), n = n + Math.imul(Y, le) | 0, d = Math.imul(Y, de), l = l + Math.imul(V, ce) | 0, n = n + Math.imul(V, pe) | 0, n = n + Math.imul($, ce) | 0, d = d + Math.imul($, pe) | 0, l = l + Math.imul(j, ve) | 0, n = n + Math.imul(j, be) | 0, n = n + Math.imul(Z, ve) | 0, d = d + Math.imul(Z, be) | 0;
        var et = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (et >>> 26) | 0, et &= 67108863, l = Math.imul(G, ce), n = Math.imul(G, pe), n = n + Math.imul(Y, ce) | 0, d = Math.imul(Y, pe), l = l + Math.imul(V, ve) | 0, n = n + Math.imul(V, be) | 0, n = n + Math.imul($, ve) | 0, d = d + Math.imul($, be) | 0;
        var tt = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (tt >>> 26) | 0, tt &= 67108863, l = Math.imul(G, ve), n = Math.imul(G, be), n = n + Math.imul(Y, ve) | 0, d = Math.imul(Y, be);
        var rt = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        return b3 = (d + (n >>> 13) | 0) + (rt >>> 26) | 0, rt &= 67108863, c[0] = ft, c[1] = Be, c[2] = qe, c[3] = ze, c[4] = He, c[5] = We, c[6] = Ke, c[7] = je, c[8] = Ze, c[9] = Ve, c[10] = $e, c[11] = Ge, c[12] = Ye, c[13] = Xe, c[14] = Je, c[15] = Qe, c[16] = et, c[17] = tt, c[18] = rt, b3 !== 0 && (c[19] = b3, h2.length++), h2;
      };
      Math.imul || (L2 = q2);
      function ge(v, i, a) {
        a.negative = i.negative ^ v.negative, a.length = v.length + i.length;
        for (var h2 = 0, s = 0, u = 0;u < a.length - 1; u++) {
          var c = s;
          s = 0;
          for (var b3 = h2 & 67108863, l = Math.min(u, i.length - 1), n = Math.max(0, u - v.length + 1);n <= l; n++) {
            var d = u - n, w = v.words[d] | 0, g = i.words[n] | 0, _3 = w * g, A2 = _3 & 67108863;
            c = c + (_3 / 67108864 | 0) | 0, A2 = A2 + b3 | 0, b3 = A2 & 67108863, c = c + (A2 >>> 26) | 0, s += c >>> 26, c &= 67108863;
          }
          a.words[u] = b3, h2 = c, c = s;
        }
        return h2 !== 0 ? a.words[u] = h2 : a.length--, a.strip();
      }
      function _e(v, i, a) {
        var h2 = new N;
        return h2.mulp(v, i, a);
      }
      f.prototype.mulTo = function(i, a) {
        var h2, s = this.length + i.length;
        return this.length === 10 && i.length === 10 ? h2 = L2(this, i, a) : s < 63 ? h2 = q2(this, i, a) : s < 1024 ? h2 = ge(this, i, a) : h2 = _e(this, i, a), h2;
      };
      function N(v, i) {
        this.x = v, this.y = i;
      }
      N.prototype.makeRBT = function(i) {
        for (var a = new Array(i), h2 = f.prototype._countBits(i) - 1, s = 0;s < i; s++)
          a[s] = this.revBin(s, h2, i);
        return a;
      }, N.prototype.revBin = function(i, a, h2) {
        if (i === 0 || i === h2 - 1)
          return i;
        for (var s = 0, u = 0;u < a; u++)
          s |= (i & 1) << a - u - 1, i >>= 1;
        return s;
      }, N.prototype.permute = function(i, a, h2, s, u, c) {
        for (var b3 = 0;b3 < c; b3++)
          s[b3] = a[i[b3]], u[b3] = h2[i[b3]];
      }, N.prototype.transform = function(i, a, h2, s, u, c) {
        this.permute(c, i, a, h2, s, u);
        for (var b3 = 1;b3 < u; b3 <<= 1)
          for (var l = b3 << 1, n = Math.cos(2 * Math.PI / l), d = Math.sin(2 * Math.PI / l), w = 0;w < u; w += l)
            for (var g = n, _3 = d, A2 = 0;A2 < b3; A2++) {
              var R2 = h2[w + A2], I = s[w + A2], Me = h2[w + A2 + b3], k = s[w + A2 + b3], D2 = g * Me - _3 * k;
              k = g * k + _3 * Me, Me = D2, h2[w + A2] = R2 + Me, s[w + A2] = I + k, h2[w + A2 + b3] = R2 - Me, s[w + A2 + b3] = I - k, A2 !== l && (D2 = n * g - d * _3, _3 = n * _3 + d * g, g = D2);
            }
      }, N.prototype.guessLen13b = function(i, a) {
        var h2 = Math.max(a, i) | 1, s = h2 & 1, u = 0;
        for (h2 = h2 / 2 | 0;h2; h2 = h2 >>> 1)
          u++;
        return 1 << u + 1 + s;
      }, N.prototype.conjugate = function(i, a, h2) {
        if (!(h2 <= 1))
          for (var s = 0;s < h2 / 2; s++) {
            var u = i[s];
            i[s] = i[h2 - s - 1], i[h2 - s - 1] = u, u = a[s], a[s] = -a[h2 - s - 1], a[h2 - s - 1] = -u;
          }
      }, N.prototype.normalize13b = function(i, a) {
        for (var h2 = 0, s = 0;s < a / 2; s++) {
          var u = Math.round(i[2 * s + 1] / a) * 8192 + Math.round(i[2 * s] / a) + h2;
          i[s] = u & 67108863, u < 67108864 ? h2 = 0 : h2 = u / 67108864 | 0;
        }
        return i;
      }, N.prototype.convert13b = function(i, a, h2, s) {
        for (var u = 0, c = 0;c < a; c++)
          u = u + (i[c] | 0), h2[2 * c] = u & 8191, u = u >>> 13, h2[2 * c + 1] = u & 8191, u = u >>> 13;
        for (c = 2 * a;c < s; ++c)
          h2[c] = 0;
        r(u === 0), r((u & -8192) === 0);
      }, N.prototype.stub = function(i) {
        for (var a = new Array(i), h2 = 0;h2 < i; h2++)
          a[h2] = 0;
        return a;
      }, N.prototype.mulp = function(i, a, h2) {
        var s = 2 * this.guessLen13b(i.length, a.length), u = this.makeRBT(s), c = this.stub(s), b3 = new Array(s), l = new Array(s), n = new Array(s), d = new Array(s), w = new Array(s), g = new Array(s), _3 = h2.words;
        _3.length = s, this.convert13b(i.words, i.length, b3, s), this.convert13b(a.words, a.length, d, s), this.transform(b3, c, l, n, s, u), this.transform(d, c, w, g, s, u);
        for (var A2 = 0;A2 < s; A2++) {
          var R2 = l[A2] * w[A2] - n[A2] * g[A2];
          n[A2] = l[A2] * g[A2] + n[A2] * w[A2], l[A2] = R2;
        }
        return this.conjugate(l, n, s), this.transform(l, n, _3, c, s, u), this.conjugate(_3, c, s), this.normalize13b(_3, s), h2.negative = i.negative ^ a.negative, h2.length = i.length + a.length, h2.strip();
      }, f.prototype.mul = function(i) {
        var a = new f(null);
        return a.words = new Array(this.length + i.length), this.mulTo(i, a);
      }, f.prototype.mulf = function(i) {
        var a = new f(null);
        return a.words = new Array(this.length + i.length), _e(this, i, a);
      }, f.prototype.imul = function(i) {
        return this.clone().mulTo(i, this);
      }, f.prototype.imuln = function(i) {
        r(typeof i == "number"), r(i < 67108864);
        for (var a = 0, h2 = 0;h2 < this.length; h2++) {
          var s = (this.words[h2] | 0) * i, u = (s & 67108863) + (a & 67108863);
          a >>= 26, a += s / 67108864 | 0, a += u >>> 26, this.words[h2] = u & 67108863;
        }
        return a !== 0 && (this.words[h2] = a, this.length++), this;
      }, f.prototype.muln = function(i) {
        return this.clone().imuln(i);
      }, f.prototype.sqr = function() {
        return this.mul(this);
      }, f.prototype.isqr = function() {
        return this.imul(this.clone());
      }, f.prototype.pow = function(i) {
        var a = B(i);
        if (a.length === 0)
          return new f(1);
        for (var h2 = this, s = 0;s < a.length && a[s] === 0; s++, h2 = h2.sqr())
          ;
        if (++s < a.length)
          for (var u = h2.sqr();s < a.length; s++, u = u.sqr())
            a[s] !== 0 && (h2 = h2.mul(u));
        return h2;
      }, f.prototype.iushln = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26, s = 67108863 >>> 26 - a << 26 - a, u;
        if (a !== 0) {
          var c = 0;
          for (u = 0;u < this.length; u++) {
            var b3 = this.words[u] & s, l = (this.words[u] | 0) - b3 << a;
            this.words[u] = l | c, c = b3 >>> 26 - a;
          }
          c && (this.words[u] = c, this.length++);
        }
        if (h2 !== 0) {
          for (u = this.length - 1;u >= 0; u--)
            this.words[u + h2] = this.words[u];
          for (u = 0;u < h2; u++)
            this.words[u] = 0;
          this.length += h2;
        }
        return this.strip();
      }, f.prototype.ishln = function(i) {
        return r(this.negative === 0), this.iushln(i);
      }, f.prototype.iushrn = function(i, a, h2) {
        r(typeof i == "number" && i >= 0);
        var s;
        a ? s = (a - a % 26) / 26 : s = 0;
        var u = i % 26, c = Math.min((i - u) / 26, this.length), b3 = 67108863 ^ 67108863 >>> u << u, l = h2;
        if (s -= c, s = Math.max(0, s), l) {
          for (var n = 0;n < c; n++)
            l.words[n] = this.words[n];
          l.length = c;
        }
        if (c !== 0)
          if (this.length > c)
            for (this.length -= c, n = 0;n < this.length; n++)
              this.words[n] = this.words[n + c];
          else
            this.words[0] = 0, this.length = 1;
        var d = 0;
        for (n = this.length - 1;n >= 0 && (d !== 0 || n >= s); n--) {
          var w = this.words[n] | 0;
          this.words[n] = d << 26 - u | w >>> u, d = w & b3;
        }
        return l && d !== 0 && (l.words[l.length++] = d), this.length === 0 && (this.words[0] = 0, this.length = 1), this.strip();
      }, f.prototype.ishrn = function(i, a, h2) {
        return r(this.negative === 0), this.iushrn(i, a, h2);
      }, f.prototype.shln = function(i) {
        return this.clone().ishln(i);
      }, f.prototype.ushln = function(i) {
        return this.clone().iushln(i);
      }, f.prototype.shrn = function(i) {
        return this.clone().ishrn(i);
      }, f.prototype.ushrn = function(i) {
        return this.clone().iushrn(i);
      }, f.prototype.testn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26, s = 1 << a;
        if (this.length <= h2)
          return false;
        var u = this.words[h2];
        return !!(u & s);
      }, f.prototype.imaskn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26;
        if (r(this.negative === 0, "imaskn works only with positive numbers"), this.length <= h2)
          return this;
        if (a !== 0 && h2++, this.length = Math.min(h2, this.length), a !== 0) {
          var s = 67108863 ^ 67108863 >>> a << a;
          this.words[this.length - 1] &= s;
        }
        return this.strip();
      }, f.prototype.maskn = function(i) {
        return this.clone().imaskn(i);
      }, f.prototype.iaddn = function(i) {
        return r(typeof i == "number"), r(i < 67108864), i < 0 ? this.isubn(-i) : this.negative !== 0 ? this.length === 1 && (this.words[0] | 0) < i ? (this.words[0] = i - (this.words[0] | 0), this.negative = 0, this) : (this.negative = 0, this.isubn(i), this.negative = 1, this) : this._iaddn(i);
      }, f.prototype._iaddn = function(i) {
        this.words[0] += i;
        for (var a = 0;a < this.length && this.words[a] >= 67108864; a++)
          this.words[a] -= 67108864, a === this.length - 1 ? this.words[a + 1] = 1 : this.words[a + 1]++;
        return this.length = Math.max(this.length, a + 1), this;
      }, f.prototype.isubn = function(i) {
        if (r(typeof i == "number"), r(i < 67108864), i < 0)
          return this.iaddn(-i);
        if (this.negative !== 0)
          return this.negative = 0, this.iaddn(i), this.negative = 1, this;
        if (this.words[0] -= i, this.length === 1 && this.words[0] < 0)
          this.words[0] = -this.words[0], this.negative = 1;
        else
          for (var a = 0;a < this.length && this.words[a] < 0; a++)
            this.words[a] += 67108864, this.words[a + 1] -= 1;
        return this.strip();
      }, f.prototype.addn = function(i) {
        return this.clone().iaddn(i);
      }, f.prototype.subn = function(i) {
        return this.clone().isubn(i);
      }, f.prototype.iabs = function() {
        return this.negative = 0, this;
      }, f.prototype.abs = function() {
        return this.clone().iabs();
      }, f.prototype._ishlnsubmul = function(i, a, h2) {
        var s = i.length + h2, u;
        this._expand(s);
        var c, b3 = 0;
        for (u = 0;u < i.length; u++) {
          c = (this.words[u + h2] | 0) + b3;
          var l = (i.words[u] | 0) * a;
          c -= l & 67108863, b3 = (c >> 26) - (l / 67108864 | 0), this.words[u + h2] = c & 67108863;
        }
        for (;u < this.length - h2; u++)
          c = (this.words[u + h2] | 0) + b3, b3 = c >> 26, this.words[u + h2] = c & 67108863;
        if (b3 === 0)
          return this.strip();
        for (r(b3 === -1), b3 = 0, u = 0;u < this.length; u++)
          c = -(this.words[u] | 0) + b3, b3 = c >> 26, this.words[u] = c & 67108863;
        return this.negative = 1, this.strip();
      }, f.prototype._wordDiv = function(i, a) {
        var h2 = this.length - i.length, s = this.clone(), u = i, c = u.words[u.length - 1] | 0, b3 = this._countBits(c);
        h2 = 26 - b3, h2 !== 0 && (u = u.ushln(h2), s.iushln(h2), c = u.words[u.length - 1] | 0);
        var l = s.length - u.length, n;
        if (a !== "mod") {
          n = new f(null), n.length = l + 1, n.words = new Array(n.length);
          for (var d = 0;d < n.length; d++)
            n.words[d] = 0;
        }
        var w = s.clone()._ishlnsubmul(u, 1, l);
        w.negative === 0 && (s = w, n && (n.words[l] = 1));
        for (var g = l - 1;g >= 0; g--) {
          var _3 = (s.words[u.length + g] | 0) * 67108864 + (s.words[u.length + g - 1] | 0);
          for (_3 = Math.min(_3 / c | 0, 67108863), s._ishlnsubmul(u, _3, g);s.negative !== 0; )
            _3--, s.negative = 0, s._ishlnsubmul(u, 1, g), s.isZero() || (s.negative ^= 1);
          n && (n.words[g] = _3);
        }
        return n && n.strip(), s.strip(), a !== "div" && h2 !== 0 && s.iushrn(h2), { div: n || null, mod: s };
      }, f.prototype.divmod = function(i, a, h2) {
        if (r(!i.isZero()), this.isZero())
          return { div: new f(0), mod: new f(0) };
        var s, u, c;
        return this.negative !== 0 && i.negative === 0 ? (c = this.neg().divmod(i, a), a !== "mod" && (s = c.div.neg()), a !== "div" && (u = c.mod.neg(), h2 && u.negative !== 0 && u.iadd(i)), { div: s, mod: u }) : this.negative === 0 && i.negative !== 0 ? (c = this.divmod(i.neg(), a), a !== "mod" && (s = c.div.neg()), { div: s, mod: c.mod }) : (this.negative & i.negative) !== 0 ? (c = this.neg().divmod(i.neg(), a), a !== "div" && (u = c.mod.neg(), h2 && u.negative !== 0 && u.isub(i)), { div: c.div, mod: u }) : i.length > this.length || this.cmp(i) < 0 ? { div: new f(0), mod: this } : i.length === 1 ? a === "div" ? { div: this.divn(i.words[0]), mod: null } : a === "mod" ? { div: null, mod: new f(this.modn(i.words[0])) } : { div: this.divn(i.words[0]), mod: new f(this.modn(i.words[0])) } : this._wordDiv(i, a);
      }, f.prototype.div = function(i) {
        return this.divmod(i, "div", false).div;
      }, f.prototype.mod = function(i) {
        return this.divmod(i, "mod", false).mod;
      }, f.prototype.umod = function(i) {
        return this.divmod(i, "mod", true).mod;
      }, f.prototype.divRound = function(i) {
        var a = this.divmod(i);
        if (a.mod.isZero())
          return a.div;
        var h2 = a.div.negative !== 0 ? a.mod.isub(i) : a.mod, s = i.ushrn(1), u = i.andln(1), c = h2.cmp(s);
        return c < 0 || u === 1 && c === 0 ? a.div : a.div.negative !== 0 ? a.div.isubn(1) : a.div.iaddn(1);
      }, f.prototype.modn = function(i) {
        r(i <= 67108863);
        for (var a = (1 << 26) % i, h2 = 0, s = this.length - 1;s >= 0; s--)
          h2 = (a * h2 + (this.words[s] | 0)) % i;
        return h2;
      }, f.prototype.idivn = function(i) {
        r(i <= 67108863);
        for (var a = 0, h2 = this.length - 1;h2 >= 0; h2--) {
          var s = (this.words[h2] | 0) + a * 67108864;
          this.words[h2] = s / i | 0, a = s % i;
        }
        return this.strip();
      }, f.prototype.divn = function(i) {
        return this.clone().idivn(i);
      }, f.prototype.egcd = function(i) {
        r(i.negative === 0), r(!i.isZero());
        var a = this, h2 = i.clone();
        a.negative !== 0 ? a = a.umod(i) : a = a.clone();
        for (var s = new f(1), u = new f(0), c = new f(0), b3 = new f(1), l = 0;a.isEven() && h2.isEven(); )
          a.iushrn(1), h2.iushrn(1), ++l;
        for (var n = h2.clone(), d = a.clone();!a.isZero(); ) {
          for (var w = 0, g = 1;(a.words[0] & g) === 0 && w < 26; ++w, g <<= 1)
            ;
          if (w > 0)
            for (a.iushrn(w);w-- > 0; )
              (s.isOdd() || u.isOdd()) && (s.iadd(n), u.isub(d)), s.iushrn(1), u.iushrn(1);
          for (var _3 = 0, A2 = 1;(h2.words[0] & A2) === 0 && _3 < 26; ++_3, A2 <<= 1)
            ;
          if (_3 > 0)
            for (h2.iushrn(_3);_3-- > 0; )
              (c.isOdd() || b3.isOdd()) && (c.iadd(n), b3.isub(d)), c.iushrn(1), b3.iushrn(1);
          a.cmp(h2) >= 0 ? (a.isub(h2), s.isub(c), u.isub(b3)) : (h2.isub(a), c.isub(s), b3.isub(u));
        }
        return { a: c, b: b3, gcd: h2.iushln(l) };
      }, f.prototype._invmp = function(i) {
        r(i.negative === 0), r(!i.isZero());
        var a = this, h2 = i.clone();
        a.negative !== 0 ? a = a.umod(i) : a = a.clone();
        for (var s = new f(1), u = new f(0), c = h2.clone();a.cmpn(1) > 0 && h2.cmpn(1) > 0; ) {
          for (var b3 = 0, l = 1;(a.words[0] & l) === 0 && b3 < 26; ++b3, l <<= 1)
            ;
          if (b3 > 0)
            for (a.iushrn(b3);b3-- > 0; )
              s.isOdd() && s.iadd(c), s.iushrn(1);
          for (var n = 0, d = 1;(h2.words[0] & d) === 0 && n < 26; ++n, d <<= 1)
            ;
          if (n > 0)
            for (h2.iushrn(n);n-- > 0; )
              u.isOdd() && u.iadd(c), u.iushrn(1);
          a.cmp(h2) >= 0 ? (a.isub(h2), s.isub(u)) : (h2.isub(a), u.isub(s));
        }
        var w;
        return a.cmpn(1) === 0 ? w = s : w = u, w.cmpn(0) < 0 && w.iadd(i), w;
      }, f.prototype.gcd = function(i) {
        if (this.isZero())
          return i.abs();
        if (i.isZero())
          return this.abs();
        var a = this.clone(), h2 = i.clone();
        a.negative = 0, h2.negative = 0;
        for (var s = 0;a.isEven() && h2.isEven(); s++)
          a.iushrn(1), h2.iushrn(1);
        do {
          for (;a.isEven(); )
            a.iushrn(1);
          for (;h2.isEven(); )
            h2.iushrn(1);
          var u = a.cmp(h2);
          if (u < 0) {
            var c = a;
            a = h2, h2 = c;
          } else if (u === 0 || h2.cmpn(1) === 0)
            break;
          a.isub(h2);
        } while (true);
        return h2.iushln(s);
      }, f.prototype.invm = function(i) {
        return this.egcd(i).a.umod(i);
      }, f.prototype.isEven = function() {
        return (this.words[0] & 1) === 0;
      }, f.prototype.isOdd = function() {
        return (this.words[0] & 1) === 1;
      }, f.prototype.andln = function(i) {
        return this.words[0] & i;
      }, f.prototype.bincn = function(i) {
        r(typeof i == "number");
        var a = i % 26, h2 = (i - a) / 26, s = 1 << a;
        if (this.length <= h2)
          return this._expand(h2 + 1), this.words[h2] |= s, this;
        for (var u = s, c = h2;u !== 0 && c < this.length; c++) {
          var b3 = this.words[c] | 0;
          b3 += u, u = b3 >>> 26, b3 &= 67108863, this.words[c] = b3;
        }
        return u !== 0 && (this.words[c] = u, this.length++), this;
      }, f.prototype.isZero = function() {
        return this.length === 1 && this.words[0] === 0;
      }, f.prototype.cmpn = function(i) {
        var a = i < 0;
        if (this.negative !== 0 && !a)
          return -1;
        if (this.negative === 0 && a)
          return 1;
        this.strip();
        var h2;
        if (this.length > 1)
          h2 = 1;
        else {
          a && (i = -i), r(i <= 67108863, "Number is too big");
          var s = this.words[0] | 0;
          h2 = s === i ? 0 : s < i ? -1 : 1;
        }
        return this.negative !== 0 ? -h2 | 0 : h2;
      }, f.prototype.cmp = function(i) {
        if (this.negative !== 0 && i.negative === 0)
          return -1;
        if (this.negative === 0 && i.negative !== 0)
          return 1;
        var a = this.ucmp(i);
        return this.negative !== 0 ? -a | 0 : a;
      }, f.prototype.ucmp = function(i) {
        if (this.length > i.length)
          return 1;
        if (this.length < i.length)
          return -1;
        for (var a = 0, h2 = this.length - 1;h2 >= 0; h2--) {
          var s = this.words[h2] | 0, u = i.words[h2] | 0;
          if (s !== u) {
            s < u ? a = -1 : s > u && (a = 1);
            break;
          }
        }
        return a;
      }, f.prototype.gtn = function(i) {
        return this.cmpn(i) === 1;
      }, f.prototype.gt = function(i) {
        return this.cmp(i) === 1;
      }, f.prototype.gten = function(i) {
        return this.cmpn(i) >= 0;
      }, f.prototype.gte = function(i) {
        return this.cmp(i) >= 0;
      }, f.prototype.ltn = function(i) {
        return this.cmpn(i) === -1;
      }, f.prototype.lt = function(i) {
        return this.cmp(i) === -1;
      }, f.prototype.lten = function(i) {
        return this.cmpn(i) <= 0;
      }, f.prototype.lte = function(i) {
        return this.cmp(i) <= 0;
      }, f.prototype.eqn = function(i) {
        return this.cmpn(i) === 0;
      }, f.prototype.eq = function(i) {
        return this.cmp(i) === 0;
      }, f.red = function(i) {
        return new P(i);
      }, f.prototype.toRed = function(i) {
        return r(!this.red, "Already a number in reduction context"), r(this.negative === 0, "red works only with positives"), i.convertTo(this)._forceRed(i);
      }, f.prototype.fromRed = function() {
        return r(this.red, "fromRed works only with numbers in reduction context"), this.red.convertFrom(this);
      }, f.prototype._forceRed = function(i) {
        return this.red = i, this;
      }, f.prototype.forceRed = function(i) {
        return r(!this.red, "Already a number in reduction context"), this._forceRed(i);
      }, f.prototype.redAdd = function(i) {
        return r(this.red, "redAdd works only with red numbers"), this.red.add(this, i);
      }, f.prototype.redIAdd = function(i) {
        return r(this.red, "redIAdd works only with red numbers"), this.red.iadd(this, i);
      }, f.prototype.redSub = function(i) {
        return r(this.red, "redSub works only with red numbers"), this.red.sub(this, i);
      }, f.prototype.redISub = function(i) {
        return r(this.red, "redISub works only with red numbers"), this.red.isub(this, i);
      }, f.prototype.redShl = function(i) {
        return r(this.red, "redShl works only with red numbers"), this.red.shl(this, i);
      }, f.prototype.redMul = function(i) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, i), this.red.mul(this, i);
      }, f.prototype.redIMul = function(i) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, i), this.red.imul(this, i);
      }, f.prototype.redSqr = function() {
        return r(this.red, "redSqr works only with red numbers"), this.red._verify1(this), this.red.sqr(this);
      }, f.prototype.redISqr = function() {
        return r(this.red, "redISqr works only with red numbers"), this.red._verify1(this), this.red.isqr(this);
      }, f.prototype.redSqrt = function() {
        return r(this.red, "redSqrt works only with red numbers"), this.red._verify1(this), this.red.sqrt(this);
      }, f.prototype.redInvm = function() {
        return r(this.red, "redInvm works only with red numbers"), this.red._verify1(this), this.red.invm(this);
      }, f.prototype.redNeg = function() {
        return r(this.red, "redNeg works only with red numbers"), this.red._verify1(this), this.red.neg(this);
      }, f.prototype.redPow = function(i) {
        return r(this.red && !i.red, "redPow(normalNum)"), this.red._verify1(this), this.red.pow(this, i);
      };
      var we = { k256: null, p224: null, p192: null, p25519: null };
      function ye(v, i) {
        this.name = v, this.p = new f(i, 16), this.n = this.p.bitLength(), this.k = new f(1).iushln(this.n).isub(this.p), this.tmp = this._tmp();
      }
      ye.prototype._tmp = function() {
        var i = new f(null);
        return i.words = new Array(Math.ceil(this.n / 13)), i;
      }, ye.prototype.ireduce = function(i) {
        var a = i, h2;
        do
          this.split(a, this.tmp), a = this.imulK(a), a = a.iadd(this.tmp), h2 = a.bitLength();
        while (h2 > this.n);
        var s = h2 < this.n ? -1 : a.ucmp(this.p);
        return s === 0 ? (a.words[0] = 0, a.length = 1) : s > 0 ? a.isub(this.p) : a.strip !== undefined ? a.strip() : a._strip(), a;
      }, ye.prototype.split = function(i, a) {
        i.iushrn(this.n, 0, a);
      }, ye.prototype.imulK = function(i) {
        return i.imul(this.k);
      };
      function xe() {
        ye.call(this, "k256", "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f");
      }
      o(xe, ye), xe.prototype.split = function(i, a) {
        for (var h2 = 4194303, s = Math.min(i.length, 9), u = 0;u < s; u++)
          a.words[u] = i.words[u];
        if (a.length = s, i.length <= 9) {
          i.words[0] = 0, i.length = 1;
          return;
        }
        var c = i.words[9];
        for (a.words[a.length++] = c & h2, u = 10;u < i.length; u++) {
          var b3 = i.words[u] | 0;
          i.words[u - 10] = (b3 & h2) << 4 | c >>> 22, c = b3;
        }
        c >>>= 22, i.words[u - 10] = c, c === 0 && i.length > 10 ? i.length -= 10 : i.length -= 9;
      }, xe.prototype.imulK = function(i) {
        i.words[i.length] = 0, i.words[i.length + 1] = 0, i.length += 2;
        for (var a = 0, h2 = 0;h2 < i.length; h2++) {
          var s = i.words[h2] | 0;
          a += s * 977, i.words[h2] = a & 67108863, a = s * 64 + (a / 67108864 | 0);
        }
        return i.words[i.length - 1] === 0 && (i.length--, i.words[i.length - 1] === 0 && i.length--), i;
      };
      function Re() {
        ye.call(this, "p224", "ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001");
      }
      o(Re, ye);
      function Ee() {
        ye.call(this, "p192", "ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff");
      }
      o(Ee, ye);
      function Ae() {
        ye.call(this, "25519", "7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed");
      }
      o(Ae, ye), Ae.prototype.imulK = function(i) {
        for (var a = 0, h2 = 0;h2 < i.length; h2++) {
          var s = (i.words[h2] | 0) * 19 + a, u = s & 67108863;
          s >>>= 26, i.words[h2] = u, a = s;
        }
        return a !== 0 && (i.words[i.length++] = a), i;
      }, f._prime = function(i) {
        if (we[i])
          return we[i];
        var a;
        if (i === "k256")
          a = new xe;
        else if (i === "p224")
          a = new Re;
        else if (i === "p192")
          a = new Ee;
        else if (i === "p25519")
          a = new Ae;
        else
          throw new Error("Unknown prime " + i);
        return we[i] = a, a;
      };
      function P(v) {
        if (typeof v == "string") {
          var i = f._prime(v);
          this.m = i.p, this.prime = i;
        } else
          r(v.gtn(1), "modulus must be greater than 1"), this.m = v, this.prime = null;
      }
      P.prototype._verify1 = function(i) {
        r(i.negative === 0, "red works only with positives"), r(i.red, "red works only with red numbers");
      }, P.prototype._verify2 = function(i, a) {
        r((i.negative | a.negative) === 0, "red works only with positives"), r(i.red && i.red === a.red, "red works only with red numbers");
      }, P.prototype.imod = function(i) {
        return this.prime ? this.prime.ireduce(i)._forceRed(this) : i.umod(this.m)._forceRed(this);
      }, P.prototype.neg = function(i) {
        return i.isZero() ? i.clone() : this.m.sub(i)._forceRed(this);
      }, P.prototype.add = function(i, a) {
        this._verify2(i, a);
        var h2 = i.add(a);
        return h2.cmp(this.m) >= 0 && h2.isub(this.m), h2._forceRed(this);
      }, P.prototype.iadd = function(i, a) {
        this._verify2(i, a);
        var h2 = i.iadd(a);
        return h2.cmp(this.m) >= 0 && h2.isub(this.m), h2;
      }, P.prototype.sub = function(i, a) {
        this._verify2(i, a);
        var h2 = i.sub(a);
        return h2.cmpn(0) < 0 && h2.iadd(this.m), h2._forceRed(this);
      }, P.prototype.isub = function(i, a) {
        this._verify2(i, a);
        var h2 = i.isub(a);
        return h2.cmpn(0) < 0 && h2.iadd(this.m), h2;
      }, P.prototype.shl = function(i, a) {
        return this._verify1(i), this.imod(i.ushln(a));
      }, P.prototype.imul = function(i, a) {
        return this._verify2(i, a), this.imod(i.imul(a));
      }, P.prototype.mul = function(i, a) {
        return this._verify2(i, a), this.imod(i.mul(a));
      }, P.prototype.isqr = function(i) {
        return this.imul(i, i.clone());
      }, P.prototype.sqr = function(i) {
        return this.mul(i, i);
      }, P.prototype.sqrt = function(i) {
        if (i.isZero())
          return i.clone();
        var a = this.m.andln(3);
        if (r(a % 2 === 1), a === 3) {
          var h2 = this.m.add(new f(1)).iushrn(2);
          return this.pow(i, h2);
        }
        for (var s = this.m.subn(1), u = 0;!s.isZero() && s.andln(1) === 0; )
          u++, s.iushrn(1);
        r(!s.isZero());
        var c = new f(1).toRed(this), b3 = c.redNeg(), l = this.m.subn(1).iushrn(1), n = this.m.bitLength();
        for (n = new f(2 * n * n).toRed(this);this.pow(n, l).cmp(b3) !== 0; )
          n.redIAdd(b3);
        for (var d = this.pow(n, s), w = this.pow(i, s.addn(1).iushrn(1)), g = this.pow(i, s), _3 = u;g.cmp(c) !== 0; ) {
          for (var A2 = g, R2 = 0;A2.cmp(c) !== 0; R2++)
            A2 = A2.redSqr();
          r(R2 < _3);
          var I = this.pow(d, new f(1).iushln(_3 - R2 - 1));
          w = w.redMul(I), d = I.redSqr(), g = g.redMul(d), _3 = R2;
        }
        return w;
      }, P.prototype.invm = function(i) {
        var a = i._invmp(this.m);
        return a.negative !== 0 ? (a.negative = 0, this.imod(a).redNeg()) : this.imod(a);
      }, P.prototype.pow = function(i, a) {
        if (a.isZero())
          return new f(1).toRed(this);
        if (a.cmpn(1) === 0)
          return i.clone();
        var h2 = 4, s = new Array(1 << h2);
        s[0] = new f(1).toRed(this), s[1] = i;
        for (var u = 2;u < s.length; u++)
          s[u] = this.mul(s[u - 1], i);
        var c = s[0], b3 = 0, l = 0, n = a.bitLength() % 26;
        for (n === 0 && (n = 26), u = a.length - 1;u >= 0; u--) {
          for (var d = a.words[u], w = n - 1;w >= 0; w--) {
            var g = d >> w & 1;
            if (c !== s[0] && (c = this.sqr(c)), g === 0 && b3 === 0) {
              l = 0;
              continue;
            }
            b3 <<= 1, b3 |= g, l++, !(l !== h2 && (u !== 0 || w !== 0)) && (c = this.mul(c, s[b3]), l = 0, b3 = 0);
          }
          n = 26;
        }
        return c;
      }, P.prototype.convertTo = function(i) {
        var a = i.umod(this.m);
        return a === i ? a.clone() : a;
      }, P.prototype.convertFrom = function(i) {
        var a = i.clone();
        return a.red = null, a;
      }, f.mont = function(i) {
        return new Se(i);
      };
      function Se(v) {
        P.call(this, v), this.shift = this.m.bitLength(), this.shift % 26 !== 0 && (this.shift += 26 - this.shift % 26), this.r = new f(1).iushln(this.shift), this.r2 = this.imod(this.r.sqr()), this.rinv = this.r._invmp(this.m), this.minv = this.rinv.mul(this.r).isubn(1).div(this.m), this.minv = this.minv.umod(this.r), this.minv = this.r.sub(this.minv);
      }
      o(Se, P), Se.prototype.convertTo = function(i) {
        return this.imod(i.ushln(this.shift));
      }, Se.prototype.convertFrom = function(i) {
        var a = this.imod(i.mul(this.rinv));
        return a.red = null, a;
      }, Se.prototype.imul = function(i, a) {
        if (i.isZero() || a.isZero())
          return i.words[0] = 0, i.length = 1, i;
        var h2 = i.imul(a), s = h2.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), u = h2.isub(s).iushrn(this.shift), c = u;
        return u.cmp(this.m) >= 0 ? c = u.isub(this.m) : u.cmpn(0) < 0 && (c = u.iadd(this.m)), c._forceRed(this);
      }, Se.prototype.mul = function(i, a) {
        if (i.isZero() || a.isZero())
          return new f(0)._forceRed(this);
        var h2 = i.mul(a), s = h2.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), u = h2.isub(s).iushrn(this.shift), c = u;
        return u.cmp(this.m) >= 0 ? c = u.isub(this.m) : u.cmpn(0) < 0 && (c = u.iadd(this.m)), c._forceRed(this);
      }, Se.prototype.invm = function(i) {
        var a = this.imod(i._invmp(this.m).mul(this.r2));
        return a._forceRed(this);
      };
    })(typeof ed > "u" || ed, ky);
  });
  h0 = T2((Yk, Ly) => {
    var s0 = Ut(), Ff = s0.Buffer, Er = {}, Ar;
    for (Ar in s0)
      !s0.hasOwnProperty(Ar) || Ar === "SlowBuffer" || Ar === "Buffer" || (Er[Ar] = s0[Ar]);
    var Uf = Er.Buffer = {};
    for (Ar in Ff)
      !Ff.hasOwnProperty(Ar) || Ar === "allocUnsafe" || Ar === "allocUnsafeSlow" || (Uf[Ar] = Ff[Ar]);
    Er.Buffer.prototype = Ff.prototype;
    (!Uf.from || Uf.from === Uint8Array.from) && (Uf.from = function(t, e, r) {
      if (typeof t == "number")
        throw new TypeError('The "value" argument must not be of type number. Received type ' + typeof t);
      if (t && typeof t.length > "u")
        throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type " + typeof t);
      return Ff(t, e, r);
    });
    Uf.alloc || (Uf.alloc = function(t, e, r) {
      if (typeof t != "number")
        throw new TypeError('The "size" argument must be of type number. Received type ' + typeof t);
      if (t < 0 || t >= 2 * (1 << 30))
        throw new RangeError('The value "' + t + '" is invalid for option "size"');
      var o = Ff(t);
      return !e || e.length === 0 ? o.fill(0) : typeof r == "string" ? o.fill(e, r) : o.fill(e), o;
    });
    if (!Er.kStringMaxLength)
      try {
        Er.kStringMaxLength = process.binding("buffer").kStringMaxLength;
      } catch {
      }
    Er.constants || (Er.constants = { MAX_LENGTH: Er.kMaxLength }, Er.kStringMaxLength && (Er.constants.MAX_STRING_LENGTH = Er.kStringMaxLength));
    Ly.exports = Er;
  });
  u0 = T2((Ny) => {
    var aB = Ie();
    function Rr(t) {
      this._reporterState = { obj: null, path: [], options: t || {}, errors: [] };
    }
    Ny.Reporter = Rr;
    Rr.prototype.isError = function(e) {
      return e instanceof zf;
    };
    Rr.prototype.save = function() {
      let e = this._reporterState;
      return { obj: e.obj, pathLen: e.path.length };
    };
    Rr.prototype.restore = function(e) {
      let r = this._reporterState;
      r.obj = e.obj, r.path = r.path.slice(0, e.pathLen);
    };
    Rr.prototype.enterKey = function(e) {
      return this._reporterState.path.push(e);
    };
    Rr.prototype.exitKey = function(e) {
      let r = this._reporterState;
      r.path = r.path.slice(0, e - 1);
    };
    Rr.prototype.leaveKey = function(e, r, o) {
      let f = this._reporterState;
      this.exitKey(e), f.obj !== null && (f.obj[r] = o);
    };
    Rr.prototype.path = function() {
      return this._reporterState.path.join("/");
    };
    Rr.prototype.enterObject = function() {
      let e = this._reporterState, r = e.obj;
      return e.obj = {}, r;
    };
    Rr.prototype.leaveObject = function(e) {
      let r = this._reporterState, o = r.obj;
      return r.obj = e, o;
    };
    Rr.prototype.error = function(e) {
      let r, o = this._reporterState, f = e instanceof zf;
      if (f ? r = e : r = new zf(o.path.map(function(p) {
        return "[" + JSON.stringify(p) + "]";
      }).join(""), e.message || e, e.stack), !o.options.partial)
        throw r;
      return f || o.errors.push(r), r;
    };
    Rr.prototype.wrapResult = function(e) {
      let r = this._reporterState;
      return r.options.partial ? { result: this.isError(e) ? null : e, errors: r.errors } : e;
    };
    function zf(t, e) {
      this.path = t, this.rethrow(e);
    }
    aB(zf, Error);
    zf.prototype.rethrow = function(e) {
      if (this.message = e + " at: " + (this.path || "(shallow)"), Error.captureStackTrace && Error.captureStackTrace(this, zf), !this.stack)
        try {
          throw new Error(this.message);
        } catch (r) {
          this.stack = r.stack;
        }
      return this;
    };
  });
  Kf = T2((rd) => {
    var oB = Ie(), l0 = u0().Reporter, Hf = h0().Buffer;
    function Br(t, e) {
      if (l0.call(this, e), !Hf.isBuffer(t)) {
        this.error("Input not Buffer");
        return;
      }
      this.base = t, this.offset = 0, this.length = t.length;
    }
    oB(Br, l0);
    rd.DecoderBuffer = Br;
    Br.isDecoderBuffer = function(e) {
      return e instanceof Br ? true : typeof e == "object" && Hf.isBuffer(e.base) && e.constructor.name === "DecoderBuffer" && typeof e.offset == "number" && typeof e.length == "number" && typeof e.save == "function" && typeof e.restore == "function" && typeof e.isEmpty == "function" && typeof e.readUInt8 == "function" && typeof e.skip == "function" && typeof e.raw == "function";
    };
    Br.prototype.save = function() {
      return { offset: this.offset, reporter: l0.prototype.save.call(this) };
    };
    Br.prototype.restore = function(e) {
      let r = new Br(this.base);
      return r.offset = e.offset, r.length = this.offset, this.offset = e.offset, l0.prototype.restore.call(this, e.reporter), r;
    };
    Br.prototype.isEmpty = function() {
      return this.offset === this.length;
    };
    Br.prototype.readUInt8 = function(e) {
      return this.offset + 1 <= this.length ? this.base.readUInt8(this.offset++, true) : this.error(e || "DecoderBuffer overrun");
    };
    Br.prototype.skip = function(e, r) {
      if (!(this.offset + e <= this.length))
        return this.error(r || "DecoderBuffer overrun");
      let o = new Br(this.base);
      return o._reporterState = this._reporterState, o.offset = this.offset, o.length = this.offset + e, this.offset += e, o;
    };
    Br.prototype.raw = function(e) {
      return this.base.slice(e ? e.offset : this.offset, this.length);
    };
    function Wf(t, e) {
      if (Array.isArray(t))
        this.length = 0, this.value = t.map(function(r) {
          return Wf.isEncoderBuffer(r) || (r = new Wf(r, e)), this.length += r.length, r;
        }, this);
      else if (typeof t == "number") {
        if (!(0 <= t && t <= 255))
          return e.error("non-byte EncoderBuffer value");
        this.value = t, this.length = 1;
      } else if (typeof t == "string")
        this.value = t, this.length = Hf.byteLength(t);
      else if (Hf.isBuffer(t))
        this.value = t, this.length = t.length;
      else
        return e.error("Unsupported type: " + typeof t);
    }
    rd.EncoderBuffer = Wf;
    Wf.isEncoderBuffer = function(e) {
      return e instanceof Wf ? true : typeof e == "object" && e.constructor.name === "EncoderBuffer" && typeof e.length == "number" && typeof e.join == "function";
    };
    Wf.prototype.join = function(e, r) {
      return e || (e = Hf.alloc(this.length)), r || (r = 0), this.length === 0 || (Array.isArray(this.value) ? this.value.forEach(function(o) {
        o.join(e, r), r += o.length;
      }) : (typeof this.value == "number" ? e[r] = this.value : typeof this.value == "string" ? e.write(this.value, r) : Hf.isBuffer(this.value) && this.value.copy(e, r), r += this.length)), e;
    };
  });
  d0 = T2((Qk, Py) => {
    var sB = u0().Reporter, hB = Kf().EncoderBuffer, uB = Kf().DecoderBuffer, Qt = ar(), Dy = ["seq", "seqof", "set", "setof", "objid", "bool", "gentime", "utctime", "null_", "enum", "int", "objDesc", "bitstr", "bmpstr", "charstr", "genstr", "graphstr", "ia5str", "iso646str", "numstr", "octstr", "printstr", "t61str", "unistr", "utf8str", "videostr"], lB = ["key", "obj", "use", "optional", "explicit", "implicit", "def", "choice", "any", "contains"].concat(Dy), dB = ["_peekTag", "_decodeTag", "_use", "_decodeStr", "_decodeObjid", "_decodeTime", "_decodeNull", "_decodeInt", "_decodeBool", "_decodeList", "_encodeComposite", "_encodeStr", "_encodeObjid", "_encodeTime", "_encodeNull", "_encodeInt", "_encodeBool"];
    function Ue(t, e, r) {
      let o = {};
      this._baseState = o, o.name = r, o.enc = t, o.parent = e || null, o.children = null, o.tag = null, o.args = null, o.reverseArgs = null, o.choice = null, o.optional = false, o.any = false, o.obj = false, o.use = null, o.useDecoder = null, o.key = null, o.default = null, o.explicit = null, o.implicit = null, o.contains = null, o.parent || (o.children = [], this._wrap());
    }
    Py.exports = Ue;
    var cB = ["enc", "parent", "children", "tag", "args", "reverseArgs", "choice", "optional", "any", "obj", "use", "alteredUse", "key", "default", "explicit", "implicit", "contains"];
    Ue.prototype.clone = function() {
      let e = this._baseState, r = {};
      cB.forEach(function(f) {
        r[f] = e[f];
      });
      let o = new this.constructor(r.parent);
      return o._baseState = r, o;
    };
    Ue.prototype._wrap = function() {
      let e = this._baseState;
      lB.forEach(function(r) {
        this[r] = function() {
          let f = new this.constructor(this);
          return e.children.push(f), f[r].apply(f, arguments);
        };
      }, this);
    };
    Ue.prototype._init = function(e) {
      let r = this._baseState;
      Qt(r.parent === null), e.call(this), r.children = r.children.filter(function(o) {
        return o._baseState.parent === this;
      }, this), Qt.equal(r.children.length, 1, "Root node can have only one child");
    };
    Ue.prototype._useArgs = function(e) {
      let r = this._baseState, o = e.filter(function(f) {
        return f instanceof this.constructor;
      }, this);
      e = e.filter(function(f) {
        return !(f instanceof this.constructor);
      }, this), o.length !== 0 && (Qt(r.children === null), r.children = o, o.forEach(function(f) {
        f._baseState.parent = this;
      }, this)), e.length !== 0 && (Qt(r.args === null), r.args = e, r.reverseArgs = e.map(function(f) {
        if (typeof f != "object" || f.constructor !== Object)
          return f;
        let p = {};
        return Object.keys(f).forEach(function(m2) {
          m2 == (m2 | 0) && (m2 |= 0);
          let y3 = f[m2];
          p[y3] = m2;
        }), p;
      }));
    };
    dB.forEach(function(t) {
      Ue.prototype[t] = function() {
        let r = this._baseState;
        throw new Error(t + " not implemented for encoding: " + r.enc);
      };
    });
    Dy.forEach(function(t) {
      Ue.prototype[t] = function() {
        let r = this._baseState, o = Array.prototype.slice.call(arguments);
        return Qt(r.tag === null), r.tag = t, this._useArgs(o), this;
      };
    });
    Ue.prototype.use = function(e) {
      Qt(e);
      let r = this._baseState;
      return Qt(r.use === null), r.use = e, this;
    };
    Ue.prototype.optional = function() {
      let e = this._baseState;
      return e.optional = true, this;
    };
    Ue.prototype.def = function(e) {
      let r = this._baseState;
      return Qt(r.default === null), r.default = e, r.optional = true, this;
    };
    Ue.prototype.explicit = function(e) {
      let r = this._baseState;
      return Qt(r.explicit === null && r.implicit === null), r.explicit = e, this;
    };
    Ue.prototype.implicit = function(e) {
      let r = this._baseState;
      return Qt(r.explicit === null && r.implicit === null), r.implicit = e, this;
    };
    Ue.prototype.obj = function() {
      let e = this._baseState, r = Array.prototype.slice.call(arguments);
      return e.obj = true, r.length !== 0 && this._useArgs(r), this;
    };
    Ue.prototype.key = function(e) {
      let r = this._baseState;
      return Qt(r.key === null), r.key = e, this;
    };
    Ue.prototype.any = function() {
      let e = this._baseState;
      return e.any = true, this;
    };
    Ue.prototype.choice = function(e) {
      let r = this._baseState;
      return Qt(r.choice === null), r.choice = e, this._useArgs(Object.keys(e).map(function(o) {
        return e[o];
      })), this;
    };
    Ue.prototype.contains = function(e) {
      let r = this._baseState;
      return Qt(r.use === null), r.contains = e, this;
    };
    Ue.prototype._decode = function(e, r) {
      let o = this._baseState;
      if (o.parent === null)
        return e.wrapResult(o.children[0]._decode(e, r));
      let f = o.default, p = true, m2 = null;
      if (o.key !== null && (m2 = e.enterKey(o.key)), o.optional) {
        let M = null;
        if (o.explicit !== null ? M = o.explicit : o.implicit !== null ? M = o.implicit : o.tag !== null && (M = o.tag), M === null && !o.any) {
          let x = e.save();
          try {
            o.choice === null ? this._decodeGeneric(o.tag, e, r) : this._decodeChoice(e, r), p = true;
          } catch {
            p = false;
          }
          e.restore(x);
        } else if (p = this._peekTag(e, M, o.any), e.isError(p))
          return p;
      }
      let y3;
      if (o.obj && p && (y3 = e.enterObject()), p) {
        if (o.explicit !== null) {
          let x = this._decodeTag(e, o.explicit);
          if (e.isError(x))
            return x;
          e = x;
        }
        let M = e.offset;
        if (o.use === null && o.choice === null) {
          let x;
          o.any && (x = e.save());
          let S = this._decodeTag(e, o.implicit !== null ? o.implicit : o.tag, o.any);
          if (e.isError(S))
            return S;
          o.any ? f = e.raw(x) : e = S;
        }
        if (r && r.track && o.tag !== null && r.track(e.path(), M, e.length, "tagged"), r && r.track && o.tag !== null && r.track(e.path(), e.offset, e.length, "content"), o.any || (o.choice === null ? f = this._decodeGeneric(o.tag, e, r) : f = this._decodeChoice(e, r)), e.isError(f))
          return f;
        if (!o.any && o.choice === null && o.children !== null && o.children.forEach(function(S) {
          S._decode(e, r);
        }), o.contains && (o.tag === "octstr" || o.tag === "bitstr")) {
          let x = new uB(f);
          f = this._getUse(o.contains, e._reporterState.obj)._decode(x, r);
        }
      }
      return o.obj && p && (f = e.leaveObject(y3)), o.key !== null && (f !== null || p === true) ? e.leaveKey(m2, o.key, f) : m2 !== null && e.exitKey(m2), f;
    };
    Ue.prototype._decodeGeneric = function(e, r, o) {
      let f = this._baseState;
      return e === "seq" || e === "set" ? null : e === "seqof" || e === "setof" ? this._decodeList(r, e, f.args[0], o) : /str$/.test(e) ? this._decodeStr(r, e, o) : e === "objid" && f.args ? this._decodeObjid(r, f.args[0], f.args[1], o) : e === "objid" ? this._decodeObjid(r, null, null, o) : e === "gentime" || e === "utctime" ? this._decodeTime(r, e, o) : e === "null_" ? this._decodeNull(r, o) : e === "bool" ? this._decodeBool(r, o) : e === "objDesc" ? this._decodeStr(r, e, o) : e === "int" || e === "enum" ? this._decodeInt(r, f.args && f.args[0], o) : f.use !== null ? this._getUse(f.use, r._reporterState.obj)._decode(r, o) : r.error("unknown tag: " + e);
    };
    Ue.prototype._getUse = function(e, r) {
      let o = this._baseState;
      return o.useDecoder = this._use(e, r), Qt(o.useDecoder._baseState.parent === null), o.useDecoder = o.useDecoder._baseState.children[0], o.implicit !== o.useDecoder._baseState.implicit && (o.useDecoder = o.useDecoder.clone(), o.useDecoder._baseState.implicit = o.implicit), o.useDecoder;
    };
    Ue.prototype._decodeChoice = function(e, r) {
      let o = this._baseState, f = null, p = false;
      return Object.keys(o.choice).some(function(m2) {
        let y3 = e.save(), M = o.choice[m2];
        try {
          let x = M._decode(e, r);
          if (e.isError(x))
            return false;
          f = { type: m2, value: x }, p = true;
        } catch {
          return e.restore(y3), false;
        }
        return true;
      }, this), p ? f : e.error("Choice not matched");
    };
    Ue.prototype._createEncoderBuffer = function(e) {
      return new hB(e, this.reporter);
    };
    Ue.prototype._encode = function(e, r, o) {
      let f = this._baseState;
      if (f.default !== null && f.default === e)
        return;
      let p = this._encodeValue(e, r, o);
      if (p !== undefined && !this._skipDefault(p, r, o))
        return p;
    };
    Ue.prototype._encodeValue = function(e, r, o) {
      let f = this._baseState;
      if (f.parent === null)
        return f.children[0]._encode(e, r || new sB);
      let p = null;
      if (this.reporter = r, f.optional && e === undefined)
        if (f.default !== null)
          e = f.default;
        else
          return;
      let m2 = null, y3 = false;
      if (f.any)
        p = this._createEncoderBuffer(e);
      else if (f.choice)
        p = this._encodeChoice(e, r);
      else if (f.contains)
        m2 = this._getUse(f.contains, o)._encode(e, r), y3 = true;
      else if (f.children)
        m2 = f.children.map(function(M) {
          if (M._baseState.tag === "null_")
            return M._encode(null, r, e);
          if (M._baseState.key === null)
            return r.error("Child should have a key");
          let x = r.enterKey(M._baseState.key);
          if (typeof e != "object")
            return r.error("Child expected, but input is not object");
          let S = M._encode(e[M._baseState.key], r, e);
          return r.leaveKey(x), S;
        }, this).filter(function(M) {
          return M;
        }), m2 = this._createEncoderBuffer(m2);
      else if (f.tag === "seqof" || f.tag === "setof") {
        if (!(f.args && f.args.length === 1))
          return r.error("Too many args for : " + f.tag);
        if (!Array.isArray(e))
          return r.error("seqof/setof, but data is not Array");
        let M = this.clone();
        M._baseState.implicit = null, m2 = this._createEncoderBuffer(e.map(function(x) {
          let S = this._baseState;
          return this._getUse(S.args[0], e)._encode(x, r);
        }, M));
      } else
        f.use !== null ? p = this._getUse(f.use, o)._encode(e, r) : (m2 = this._encodePrimitive(f.tag, e), y3 = true);
      if (!f.any && f.choice === null) {
        let M = f.implicit !== null ? f.implicit : f.tag, x = f.implicit === null ? "universal" : "context";
        M === null ? f.use === null && r.error("Tag could be omitted only for .use()") : f.use === null && (p = this._encodeComposite(M, y3, x, m2));
      }
      return f.explicit !== null && (p = this._encodeComposite(f.explicit, false, "context", p)), p;
    };
    Ue.prototype._encodeChoice = function(e, r) {
      let o = this._baseState, f = o.choice[e.type];
      return f || Qt(false, e.type + " not found in " + JSON.stringify(Object.keys(o.choice))), f._encode(e.value, r);
    };
    Ue.prototype._encodePrimitive = function(e, r) {
      let o = this._baseState;
      if (/str$/.test(e))
        return this._encodeStr(r, e);
      if (e === "objid" && o.args)
        return this._encodeObjid(r, o.reverseArgs[0], o.args[1]);
      if (e === "objid")
        return this._encodeObjid(r, null, null);
      if (e === "gentime" || e === "utctime")
        return this._encodeTime(r, e);
      if (e === "null_")
        return this._encodeNull();
      if (e === "int" || e === "enum")
        return this._encodeInt(r, o.args && o.reverseArgs[0]);
      if (e === "bool")
        return this._encodeBool(r);
      if (e === "objDesc")
        return this._encodeStr(r, e);
      throw new Error("Unsupported tag: " + e);
    };
    Ue.prototype._isNumstr = function(e) {
      return /^[0-9 ]*$/.test(e);
    };
    Ue.prototype._isPrintstr = function(e) {
      return /^[A-Za-z0-9 '()+,-./:=?]*$/.test(e);
    };
  });
  c0 = T2((Wn) => {
    function Cy(t) {
      let e = {};
      return Object.keys(t).forEach(function(r) {
        (r | 0) == r && (r = r | 0);
        let o = t[r];
        e[o] = r;
      }), e;
    }
    Wn.tagClass = { 0: "universal", 1: "application", 2: "context", 3: "private" };
    Wn.tagClassByName = Cy(Wn.tagClass);
    Wn.tag = { 0: "end", 1: "bool", 2: "int", 3: "bitstr", 4: "octstr", 5: "null_", 6: "objid", 7: "objDesc", 8: "external", 9: "real", 10: "enum", 11: "embed", 12: "utf8str", 13: "relativeOid", 16: "seq", 17: "set", 18: "numstr", 19: "printstr", 20: "t61str", 21: "videostr", 22: "ia5str", 23: "utctime", 24: "gentime", 25: "graphstr", 26: "iso646str", 27: "genstr", 28: "unistr", 29: "charstr", 30: "bmpstr" };
    Wn.tagByName = Cy(Wn.tag);
  });
  nd = T2((tL, Uy) => {
    var pB = Ie(), Ii = h0().Buffer, Oy = d0(), id = c0();
    function Fy(t) {
      this.enc = "der", this.name = t.name, this.entity = t, this.tree = new Ur, this.tree._init(t.body);
    }
    Uy.exports = Fy;
    Fy.prototype.encode = function(e, r) {
      return this.tree._encode(e, r).join();
    };
    function Ur(t) {
      Oy.call(this, "der", t);
    }
    pB(Ur, Oy);
    Ur.prototype._encodeComposite = function(e, r, o, f) {
      let p = vB(e, r, o, this.reporter);
      if (f.length < 128) {
        let M = Ii.alloc(2);
        return M[0] = p, M[1] = f.length, this._createEncoderBuffer([M, f]);
      }
      let m2 = 1;
      for (let M = f.length;M >= 256; M >>= 8)
        m2++;
      let y3 = Ii.alloc(1 + 1 + m2);
      y3[0] = p, y3[1] = 128 | m2;
      for (let M = 1 + m2, x = f.length;x > 0; M--, x >>= 8)
        y3[M] = x & 255;
      return this._createEncoderBuffer([y3, f]);
    };
    Ur.prototype._encodeStr = function(e, r) {
      if (r === "bitstr")
        return this._createEncoderBuffer([e.unused | 0, e.data]);
      if (r === "bmpstr") {
        let o = Ii.alloc(e.length * 2);
        for (let f = 0;f < e.length; f++)
          o.writeUInt16BE(e.charCodeAt(f), f * 2);
        return this._createEncoderBuffer(o);
      } else
        return r === "numstr" ? this._isNumstr(e) ? this._createEncoderBuffer(e) : this.reporter.error("Encoding of string type: numstr supports only digits and space") : r === "printstr" ? this._isPrintstr(e) ? this._createEncoderBuffer(e) : this.reporter.error("Encoding of string type: printstr supports only latin upper and lower case letters, digits, space, apostrophe, left and rigth parenthesis, plus sign, comma, hyphen, dot, slash, colon, equal sign, question mark") : /str$/.test(r) ? this._createEncoderBuffer(e) : r === "objDesc" ? this._createEncoderBuffer(e) : this.reporter.error("Encoding of string type: " + r + " unsupported");
    };
    Ur.prototype._encodeObjid = function(e, r, o) {
      if (typeof e == "string") {
        if (!r)
          return this.reporter.error("string objid given, but no values map found");
        if (!r.hasOwnProperty(e))
          return this.reporter.error("objid not found in values map");
        e = r[e].split(/[\s.]+/g);
        for (let y3 = 0;y3 < e.length; y3++)
          e[y3] |= 0;
      } else if (Array.isArray(e)) {
        e = e.slice();
        for (let y3 = 0;y3 < e.length; y3++)
          e[y3] |= 0;
      }
      if (!Array.isArray(e))
        return this.reporter.error("objid() should be either array or string, got: " + JSON.stringify(e));
      if (!o) {
        if (e[1] >= 40)
          return this.reporter.error("Second objid identifier OOB");
        e.splice(0, 2, e[0] * 40 + e[1]);
      }
      let f = 0;
      for (let y3 = 0;y3 < e.length; y3++) {
        let M = e[y3];
        for (f++;M >= 128; M >>= 7)
          f++;
      }
      let p = Ii.alloc(f), m2 = p.length - 1;
      for (let y3 = e.length - 1;y3 >= 0; y3--) {
        let M = e[y3];
        for (p[m2--] = M & 127;(M >>= 7) > 0; )
          p[m2--] = 128 | M & 127;
      }
      return this._createEncoderBuffer(p);
    };
    function qr(t) {
      return t < 10 ? "0" + t : t;
    }
    Ur.prototype._encodeTime = function(e, r) {
      let o, f = new Date(e);
      return r === "gentime" ? o = [qr(f.getUTCFullYear()), qr(f.getUTCMonth() + 1), qr(f.getUTCDate()), qr(f.getUTCHours()), qr(f.getUTCMinutes()), qr(f.getUTCSeconds()), "Z"].join("") : r === "utctime" ? o = [qr(f.getUTCFullYear() % 100), qr(f.getUTCMonth() + 1), qr(f.getUTCDate()), qr(f.getUTCHours()), qr(f.getUTCMinutes()), qr(f.getUTCSeconds()), "Z"].join("") : this.reporter.error("Encoding " + r + " time is not supported yet"), this._encodeStr(o, "octstr");
    };
    Ur.prototype._encodeNull = function() {
      return this._createEncoderBuffer("");
    };
    Ur.prototype._encodeInt = function(e, r) {
      if (typeof e == "string") {
        if (!r)
          return this.reporter.error("String int or enum given, but no values map");
        if (!r.hasOwnProperty(e))
          return this.reporter.error("Values map doesn't contain: " + JSON.stringify(e));
        e = r[e];
      }
      if (typeof e != "number" && !Ii.isBuffer(e)) {
        let p = e.toArray();
        !e.sign && p[0] & 128 && p.unshift(0), e = Ii.from(p);
      }
      if (Ii.isBuffer(e)) {
        let p = e.length;
        e.length === 0 && p++;
        let m2 = Ii.alloc(p);
        return e.copy(m2), e.length === 0 && (m2[0] = 0), this._createEncoderBuffer(m2);
      }
      if (e < 128)
        return this._createEncoderBuffer(e);
      if (e < 256)
        return this._createEncoderBuffer([0, e]);
      let o = 1;
      for (let p = e;p >= 256; p >>= 8)
        o++;
      let f = new Array(o);
      for (let p = f.length - 1;p >= 0; p--)
        f[p] = e & 255, e >>= 8;
      return f[0] & 128 && f.unshift(0), this._createEncoderBuffer(Ii.from(f));
    };
    Ur.prototype._encodeBool = function(e) {
      return this._createEncoderBuffer(e ? 255 : 0);
    };
    Ur.prototype._use = function(e, r) {
      return typeof e == "function" && (e = e(r)), e._getEncoder("der").tree;
    };
    Ur.prototype._skipDefault = function(e, r, o) {
      let f = this._baseState, p;
      if (f.default === null)
        return false;
      let m2 = e.join();
      if (f.defaultBuffer === undefined && (f.defaultBuffer = this._encodeValue(f.default, r, o).join()), m2.length !== f.defaultBuffer.length)
        return false;
      for (p = 0;p < m2.length; p++)
        if (m2[p] !== f.defaultBuffer[p])
          return false;
      return true;
    };
    function vB(t, e, r, o) {
      let f;
      if (t === "seqof" ? t = "seq" : t === "setof" && (t = "set"), id.tagByName.hasOwnProperty(t))
        f = id.tagByName[t];
      else if (typeof t == "number" && (t | 0) === t)
        f = t;
      else
        return o.error("Unknown tag: " + t);
      return f >= 31 ? o.error("Multi-octet tag encoding unsupported") : (e || (f |= 32), f |= id.tagClassByName[r || "universal"] << 6, f);
    }
  });
  Hy = T2((rL, zy) => {
    var bB = Ie(), fd = nd();
    function ad(t) {
      fd.call(this, t), this.enc = "pem";
    }
    bB(ad, fd);
    zy.exports = ad;
    ad.prototype.encode = function(e, r) {
      let f = fd.prototype.encode.call(this, e).toString("base64"), p = ["-----BEGIN " + r.label + "-----"];
      for (let m2 = 0;m2 < f.length; m2 += 64)
        p.push(f.slice(m2, m2 + 64));
      return p.push("-----END " + r.label + "-----"), p.join(`
`);
    };
  });
  od = T2((Ky) => {
    var Wy = Ky;
    Wy.der = nd();
    Wy.pem = Hy();
  });
  hd = T2((nL, Yy) => {
    var mB = Ie(), gB = td(), jy = Kf().DecoderBuffer, Vy = d0(), Zy = c0();
    function $y(t) {
      this.enc = "der", this.name = t.name, this.entity = t, this.tree = new sr, this.tree._init(t.body);
    }
    Yy.exports = $y;
    $y.prototype.decode = function(e, r) {
      return jy.isDecoderBuffer(e) || (e = new jy(e, r)), this.tree._decode(e, r);
    };
    function sr(t) {
      Vy.call(this, "der", t);
    }
    mB(sr, Vy);
    sr.prototype._peekTag = function(e, r, o) {
      if (e.isEmpty())
        return false;
      let f = e.save(), p = sd(e, 'Failed to peek tag: "' + r + '"');
      return e.isError(p) ? p : (e.restore(f), p.tag === r || p.tagStr === r || p.tagStr + "of" === r || o);
    };
    sr.prototype._decodeTag = function(e, r, o) {
      let f = sd(e, 'Failed to decode tag of "' + r + '"');
      if (e.isError(f))
        return f;
      let p = Gy(e, f.primitive, 'Failed to get length of "' + r + '"');
      if (e.isError(p))
        return p;
      if (!o && f.tag !== r && f.tagStr !== r && f.tagStr + "of" !== r)
        return e.error('Failed to match tag: "' + r + '"');
      if (f.primitive || p !== null)
        return e.skip(p, 'Failed to match body of: "' + r + '"');
      let m2 = e.save(), y3 = this._skipUntilEnd(e, 'Failed to skip indefinite length body: "' + this.tag + '"');
      return e.isError(y3) ? y3 : (p = e.offset - m2.offset, e.restore(m2), e.skip(p, 'Failed to match body of: "' + r + '"'));
    };
    sr.prototype._skipUntilEnd = function(e, r) {
      for (;; ) {
        let o = sd(e, r);
        if (e.isError(o))
          return o;
        let f = Gy(e, o.primitive, r);
        if (e.isError(f))
          return f;
        let p;
        if (o.primitive || f !== null ? p = e.skip(f) : p = this._skipUntilEnd(e, r), e.isError(p))
          return p;
        if (o.tagStr === "end")
          break;
      }
    };
    sr.prototype._decodeList = function(e, r, o, f) {
      let p = [];
      for (;!e.isEmpty(); ) {
        let m2 = this._peekTag(e, "end");
        if (e.isError(m2))
          return m2;
        let y3 = o.decode(e, "der", f);
        if (e.isError(y3) && m2)
          break;
        p.push(y3);
      }
      return p;
    };
    sr.prototype._decodeStr = function(e, r) {
      if (r === "bitstr") {
        let o = e.readUInt8();
        return e.isError(o) ? o : { unused: o, data: e.raw() };
      } else if (r === "bmpstr") {
        let o = e.raw();
        if (o.length % 2 === 1)
          return e.error("Decoding of string type: bmpstr length mismatch");
        let f = "";
        for (let p = 0;p < o.length / 2; p++)
          f += String.fromCharCode(o.readUInt16BE(p * 2));
        return f;
      } else if (r === "numstr") {
        let o = e.raw().toString("ascii");
        return this._isNumstr(o) ? o : e.error("Decoding of string type: numstr unsupported characters");
      } else {
        if (r === "octstr")
          return e.raw();
        if (r === "objDesc")
          return e.raw();
        if (r === "printstr") {
          let o = e.raw().toString("ascii");
          return this._isPrintstr(o) ? o : e.error("Decoding of string type: printstr unsupported characters");
        } else
          return /str$/.test(r) ? e.raw().toString() : e.error("Decoding of string type: " + r + " unsupported");
      }
    };
    sr.prototype._decodeObjid = function(e, r, o) {
      let f, p = [], m2 = 0, y3 = 0;
      for (;!e.isEmpty(); )
        y3 = e.readUInt8(), m2 <<= 7, m2 |= y3 & 127, (y3 & 128) === 0 && (p.push(m2), m2 = 0);
      y3 & 128 && p.push(m2);
      let M = p[0] / 40 | 0, x = p[0] % 40;
      if (o ? f = p : f = [M, x].concat(p.slice(1)), r) {
        let S = r[f.join(" ")];
        S === undefined && (S = r[f.join(".")]), S !== undefined && (f = S);
      }
      return f;
    };
    sr.prototype._decodeTime = function(e, r) {
      let o = e.raw().toString(), f, p, m2, y3, M, x;
      if (r === "gentime")
        f = o.slice(0, 4) | 0, p = o.slice(4, 6) | 0, m2 = o.slice(6, 8) | 0, y3 = o.slice(8, 10) | 0, M = o.slice(10, 12) | 0, x = o.slice(12, 14) | 0;
      else if (r === "utctime")
        f = o.slice(0, 2) | 0, p = o.slice(2, 4) | 0, m2 = o.slice(4, 6) | 0, y3 = o.slice(6, 8) | 0, M = o.slice(8, 10) | 0, x = o.slice(10, 12) | 0, f < 70 ? f = 2000 + f : f = 1900 + f;
      else
        return e.error("Decoding " + r + " time is not supported yet");
      return Date.UTC(f, p - 1, m2, y3, M, x, 0);
    };
    sr.prototype._decodeNull = function() {
      return null;
    };
    sr.prototype._decodeBool = function(e) {
      let r = e.readUInt8();
      return e.isError(r) ? r : r !== 0;
    };
    sr.prototype._decodeInt = function(e, r) {
      let o = e.raw(), f = new gB(o);
      return r && (f = r[f.toString(10)] || f), f;
    };
    sr.prototype._use = function(e, r) {
      return typeof e == "function" && (e = e(r)), e._getDecoder("der").tree;
    };
    function sd(t, e) {
      let r = t.readUInt8(e);
      if (t.isError(r))
        return r;
      let o = Zy.tagClass[r >> 6], f = (r & 32) === 0;
      if ((r & 31) === 31) {
        let m2 = r;
        for (r = 0;(m2 & 128) === 128; ) {
          if (m2 = t.readUInt8(e), t.isError(m2))
            return m2;
          r <<= 7, r |= m2 & 127;
        }
      } else
        r &= 31;
      let p = Zy.tag[r];
      return { cls: o, primitive: f, tag: r, tagStr: p };
    }
    function Gy(t, e, r) {
      let o = t.readUInt8(r);
      if (t.isError(o))
        return o;
      if (!e && o === 128)
        return null;
      if ((o & 128) === 0)
        return o;
      let f = o & 127;
      if (f > 4)
        return t.error("length octect is too long");
      o = 0;
      for (let p = 0;p < f; p++) {
        o <<= 8;
        let m2 = t.readUInt8(r);
        if (t.isError(m2))
          return m2;
        o |= m2;
      }
      return o;
    }
  });
  Jy = T2((fL, Xy) => {
    var yB = Ie(), wB = h0().Buffer, ud = hd();
    function ld(t) {
      ud.call(this, t), this.enc = "pem";
    }
    yB(ld, ud);
    Xy.exports = ld;
    ld.prototype.decode = function(e, r) {
      let o = e.toString().split(/[\r\n]+/g), f = r.label.toUpperCase(), p = /^-----(BEGIN|END) ([^-]+)-----$/, m2 = -1, y3 = -1;
      for (let S = 0;S < o.length; S++) {
        let E2 = o[S].match(p);
        if (E2 !== null && E2[2] === f)
          if (m2 === -1) {
            if (E2[1] !== "BEGIN")
              break;
            m2 = S;
          } else {
            if (E2[1] !== "END")
              break;
            y3 = S;
            break;
          }
      }
      if (m2 === -1 || y3 === -1)
        throw new Error("PEM section not found for: " + f);
      let M = o.slice(m2 + 1, y3).join("");
      M.replace(/[^a-z0-9+/=]+/gi, "");
      let x = wB.from(M, "base64");
      return ud.prototype.decode.call(this, x, r);
    };
  });
  dd = T2((e3) => {
    var Qy = e3;
    Qy.der = hd();
    Qy.pem = Jy();
  });
  r3 = T2((t3) => {
    var MB = od(), _B = dd(), xB = Ie(), SB = t3;
    SB.define = function(e, r) {
      return new jf(e, r);
    };
    function jf(t, e) {
      this.name = t, this.body = e, this.decoders = {}, this.encoders = {};
    }
    jf.prototype._createNamed = function(e) {
      let r = this.name;
      function o(f) {
        this._initNamed(f, r);
      }
      return xB(o, e), o.prototype._initNamed = function(p, m2) {
        e.call(this, p, m2);
      }, new o(this);
    };
    jf.prototype._getDecoder = function(e) {
      return e = e || "der", this.decoders.hasOwnProperty(e) || (this.decoders[e] = this._createNamed(_B[e])), this.decoders[e];
    };
    jf.prototype.decode = function(e, r, o) {
      return this._getDecoder(r).decode(e, o);
    };
    jf.prototype._getEncoder = function(e) {
      return e = e || "der", this.encoders.hasOwnProperty(e) || (this.encoders[e] = this._createNamed(MB[e])), this.encoders[e];
    };
    jf.prototype.encode = function(e, r, o) {
      return this._getEncoder(r).encode(e, o);
    };
  });
  n3 = T2((i3) => {
    var p0 = i3;
    p0.Reporter = u0().Reporter;
    p0.DecoderBuffer = Kf().DecoderBuffer;
    p0.EncoderBuffer = Kf().EncoderBuffer;
    p0.Node = d0();
  });
  o3 = T2((a3) => {
    var f3 = a3;
    f3._reverse = function(e) {
      let r = {};
      return Object.keys(e).forEach(function(o) {
        (o | 0) == o && (o = o | 0);
        let f = e[o];
        r[f] = o;
      }), r;
    };
    f3.der = c0();
  });
  cd = T2((s3) => {
    var Zf = s3;
    Zf.bignum = td();
    Zf.define = r3().define;
    Zf.base = n3();
    Zf.constants = o3();
    Zf.decoders = dd();
    Zf.encoders = od();
  });
  d3 = T2((lL, l3) => {
    var zr = cd(), h3 = zr.define("Time", function() {
      this.choice({ utcTime: this.utctime(), generalTime: this.gentime() });
    }), EB = zr.define("AttributeTypeValue", function() {
      this.seq().obj(this.key("type").objid(), this.key("value").any());
    }), pd = zr.define("AlgorithmIdentifier", function() {
      this.seq().obj(this.key("algorithm").objid(), this.key("parameters").optional(), this.key("curve").objid().optional());
    }), AB = zr.define("SubjectPublicKeyInfo", function() {
      this.seq().obj(this.key("algorithm").use(pd), this.key("subjectPublicKey").bitstr());
    }), RB = zr.define("RelativeDistinguishedName", function() {
      this.setof(EB);
    }), BB = zr.define("RDNSequence", function() {
      this.seqof(RB);
    }), u3 = zr.define("Name", function() {
      this.choice({ rdnSequence: this.use(BB) });
    }), qB = zr.define("Validity", function() {
      this.seq().obj(this.key("notBefore").use(h3), this.key("notAfter").use(h3));
    }), IB = zr.define("Extension", function() {
      this.seq().obj(this.key("extnID").objid(), this.key("critical").bool().def(false), this.key("extnValue").octstr());
    }), TB = zr.define("TBSCertificate", function() {
      this.seq().obj(this.key("version").explicit(0).int().optional(), this.key("serialNumber").int(), this.key("signature").use(pd), this.key("issuer").use(u3), this.key("validity").use(qB), this.key("subject").use(u3), this.key("subjectPublicKeyInfo").use(AB), this.key("issuerUniqueID").implicit(1).bitstr().optional(), this.key("subjectUniqueID").implicit(2).bitstr().optional(), this.key("extensions").explicit(3).seqof(IB).optional());
    }), kB = zr.define("X509Certificate", function() {
      this.seq().obj(this.key("tbsCertificate").use(TB), this.key("signatureAlgorithm").use(pd), this.key("signatureValue").bitstr());
    });
    l3.exports = kB;
  });
  p3 = T2((Wr) => {
    var Hr = cd();
    Wr.certificate = d3();
    var LB = Hr.define("RSAPrivateKey", function() {
      this.seq().obj(this.key("version").int(), this.key("modulus").int(), this.key("publicExponent").int(), this.key("privateExponent").int(), this.key("prime1").int(), this.key("prime2").int(), this.key("exponent1").int(), this.key("exponent2").int(), this.key("coefficient").int());
    });
    Wr.RSAPrivateKey = LB;
    var NB = Hr.define("RSAPublicKey", function() {
      this.seq().obj(this.key("modulus").int(), this.key("publicExponent").int());
    });
    Wr.RSAPublicKey = NB;
    var DB = Hr.define("SubjectPublicKeyInfo", function() {
      this.seq().obj(this.key("algorithm").use(c3), this.key("subjectPublicKey").bitstr());
    });
    Wr.PublicKey = DB;
    var c3 = Hr.define("AlgorithmIdentifier", function() {
      this.seq().obj(this.key("algorithm").objid(), this.key("none").null_().optional(), this.key("curve").objid().optional(), this.key("params").seq().obj(this.key("p").int(), this.key("q").int(), this.key("g").int()).optional());
    }), PB = Hr.define("PrivateKeyInfo", function() {
      this.seq().obj(this.key("version").int(), this.key("algorithm").use(c3), this.key("subjectPrivateKey").octstr());
    });
    Wr.PrivateKey = PB;
    var CB = Hr.define("EncryptedPrivateKeyInfo", function() {
      this.seq().obj(this.key("algorithm").seq().obj(this.key("id").objid(), this.key("decrypt").seq().obj(this.key("kde").seq().obj(this.key("id").objid(), this.key("kdeparams").seq().obj(this.key("salt").octstr(), this.key("iters").int())), this.key("cipher").seq().obj(this.key("algo").objid(), this.key("iv").octstr()))), this.key("subjectPrivateKey").octstr());
    });
    Wr.EncryptedPrivateKey = CB;
    var OB = Hr.define("DSAPrivateKey", function() {
      this.seq().obj(this.key("version").int(), this.key("p").int(), this.key("q").int(), this.key("g").int(), this.key("pub_key").int(), this.key("priv_key").int());
    });
    Wr.DSAPrivateKey = OB;
    Wr.DSAparam = Hr.define("DSAparam", function() {
      this.int();
    });
    var FB = Hr.define("ECPrivateKey", function() {
      this.seq().obj(this.key("version").int(), this.key("privateKey").octstr(), this.key("parameters").optional().explicit(0).use(UB), this.key("publicKey").optional().explicit(1).bitstr());
    });
    Wr.ECPrivateKey = FB;
    var UB = Hr.define("ECParameters", function() {
      this.choice({ namedCurve: this.objid() });
    });
    Wr.signature = Hr.define("signature", function() {
      this.seq().obj(this.key("r").int(), this.key("s").int());
    });
  });
  v3 = T2((cL, zB) => {
    zB.exports = { "2.16.840.1.101.3.4.1.1": "aes-128-ecb", "2.16.840.1.101.3.4.1.2": "aes-128-cbc", "2.16.840.1.101.3.4.1.3": "aes-128-ofb", "2.16.840.1.101.3.4.1.4": "aes-128-cfb", "2.16.840.1.101.3.4.1.21": "aes-192-ecb", "2.16.840.1.101.3.4.1.22": "aes-192-cbc", "2.16.840.1.101.3.4.1.23": "aes-192-ofb", "2.16.840.1.101.3.4.1.24": "aes-192-cfb", "2.16.840.1.101.3.4.1.41": "aes-256-ecb", "2.16.840.1.101.3.4.1.42": "aes-256-cbc", "2.16.840.1.101.3.4.1.43": "aes-256-ofb", "2.16.840.1.101.3.4.1.44": "aes-256-cfb" };
  });
  m3 = T2((pL, b3) => {
    var HB = /Proc-Type: 4,ENCRYPTED[\n\r]+DEK-Info: AES-((?:128)|(?:192)|(?:256))-CBC,([0-9A-H]+)[\n\r]+([0-9A-z\n\r+/=]+)[\n\r]+/m, WB = /^-----BEGIN ((?:.*? KEY)|CERTIFICATE)-----/m, KB = /^-----BEGIN ((?:.*? KEY)|CERTIFICATE)-----([0-9A-z\n\r+/=]+)-----END \1-----$/m, jB = Ba(), ZB = Es(), v0 = Te().Buffer;
    b3.exports = function(t, e) {
      var r = t.toString(), o = r.match(HB), f;
      if (o) {
        var m2 = "aes" + o[1], y3 = v0.from(o[2], "hex"), M = v0.from(o[3].replace(/[\r\n]/g, ""), "base64"), x = jB(e, y3.slice(0, 8), parseInt(o[1], 10)).key, S = [], E2 = ZB.createDecipheriv(m2, x, y3);
        S.push(E2.update(M)), S.push(E2.final()), f = v0.concat(S);
      } else {
        var p = r.match(KB);
        f = v0.from(p[2].replace(/[\r\n]/g, ""), "base64");
      }
      var B = r.match(WB)[1];
      return { tag: B, data: f };
    };
  });
  Ha = T2((vL, y3) => {
    var fr = p3(), VB = v3(), $B = m3(), GB = Es(), YB = Iu(), vd = Te().Buffer;
    y3.exports = g3;
    function g3(t) {
      var e;
      typeof t == "object" && !vd.isBuffer(t) && (e = t.passphrase, t = t.key), typeof t == "string" && (t = vd.from(t));
      var r = $B(t, e), o = r.tag, f = r.data, p, m2;
      switch (o) {
        case "CERTIFICATE":
          m2 = fr.certificate.decode(f, "der").tbsCertificate.subjectPublicKeyInfo;
        case "PUBLIC KEY":
          switch (m2 || (m2 = fr.PublicKey.decode(f, "der")), p = m2.algorithm.algorithm.join("."), p) {
            case "1.2.840.113549.1.1.1":
              return fr.RSAPublicKey.decode(m2.subjectPublicKey.data, "der");
            case "1.2.840.10045.2.1":
              return m2.subjectPrivateKey = m2.subjectPublicKey, { type: "ec", data: m2 };
            case "1.2.840.10040.4.1":
              return m2.algorithm.params.pub_key = fr.DSAparam.decode(m2.subjectPublicKey.data, "der"), { type: "dsa", data: m2.algorithm.params };
            default:
              throw new Error("unknown key id " + p);
          }
        case "ENCRYPTED PRIVATE KEY":
          f = fr.EncryptedPrivateKey.decode(f, "der"), f = XB(f, e);
        case "PRIVATE KEY":
          switch (m2 = fr.PrivateKey.decode(f, "der"), p = m2.algorithm.algorithm.join("."), p) {
            case "1.2.840.113549.1.1.1":
              return fr.RSAPrivateKey.decode(m2.subjectPrivateKey, "der");
            case "1.2.840.10045.2.1":
              return { curve: m2.algorithm.curve, privateKey: fr.ECPrivateKey.decode(m2.subjectPrivateKey, "der").privateKey };
            case "1.2.840.10040.4.1":
              return m2.algorithm.params.priv_key = fr.DSAparam.decode(m2.subjectPrivateKey, "der"), { type: "dsa", params: m2.algorithm.params };
            default:
              throw new Error("unknown key id " + p);
          }
        case "RSA PUBLIC KEY":
          return fr.RSAPublicKey.decode(f, "der");
        case "RSA PRIVATE KEY":
          return fr.RSAPrivateKey.decode(f, "der");
        case "DSA PRIVATE KEY":
          return { type: "dsa", params: fr.DSAPrivateKey.decode(f, "der") };
        case "EC PRIVATE KEY":
          return f = fr.ECPrivateKey.decode(f, "der"), { curve: f.parameters.value, privateKey: f.privateKey };
        default:
          throw new Error("unknown key type " + o);
      }
    }
    g3.signature = fr.signature;
    function XB(t, e) {
      var r = t.algorithm.decrypt.kde.kdeparams.salt, o = parseInt(t.algorithm.decrypt.kde.kdeparams.iters.toString(), 10), f = VB[t.algorithm.decrypt.cipher.algo.join(".")], p = t.algorithm.decrypt.cipher.iv, m2 = t.subjectPrivateKey, y4 = parseInt(f.split("-")[1], 10) / 8, M = YB.pbkdf2Sync(e, r, o, y4, "sha1"), x = GB.createDecipheriv(f, M, p), S = [];
      return S.push(x.update(m2)), S.push(x.final()), vd.concat(S);
    }
  });
  bd = T2((bL, JB) => {
    JB.exports = { "1.3.132.0.10": "secp256k1", "1.3.132.0.33": "p224", "1.2.840.10045.3.1.1": "p192", "1.2.840.10045.3.1.7": "p256", "1.3.132.0.34": "p384", "1.3.132.0.35": "p521" };
  });
  _3 = T2((mL, m0) => {
    var Yt = Te().Buffer, Kn = wu(), QB = Ks(), eq = o0().ec, b0 = Ws(), tq = Ha(), rq = bd();
    function iq(t, e, r, o, f) {
      var p = tq(e);
      if (p.curve) {
        if (o !== "ecdsa" && o !== "ecdsa/rsa")
          throw new Error("wrong private key type");
        return nq(t, p);
      } else if (p.type === "dsa") {
        if (o !== "dsa")
          throw new Error("wrong private key type");
        return fq(t, p, r);
      } else if (o !== "rsa" && o !== "ecdsa/rsa")
        throw new Error("wrong private key type");
      t = Yt.concat([f, t]);
      for (var m2 = p.modulus.byteLength(), y3 = [0, 1];t.length + y3.length + 1 < m2; )
        y3.push(255);
      y3.push(0);
      for (var M = -1;++M < t.length; )
        y3.push(t[M]);
      var x = QB(y3, p);
      return x;
    }
    function nq(t, e) {
      var r = rq[e.curve.join(".")];
      if (!r)
        throw new Error("unknown curve " + e.curve.join("."));
      var o = new eq(r), f = o.keyFromPrivate(e.privateKey), p = f.sign(t);
      return Yt.from(p.toDER());
    }
    function fq(t, e, r) {
      for (var o = e.params.priv_key, f = e.params.p, p = e.params.q, m2 = e.params.g, y3 = new b0(0), M, x = md(t, p).mod(p), S = false, E2 = w3(o, p, t, r);S === false; )
        M = M3(p, E2, r), y3 = sq(m2, M, f, p), S = M.invm(p).imul(x.add(o.mul(y3))).mod(p), S.cmpn(0) === 0 && (S = false, y3 = new b0(0));
      return aq(y3, S);
    }
    function aq(t, e) {
      t = t.toArray(), e = e.toArray(), t[0] & 128 && (t = [0].concat(t)), e[0] & 128 && (e = [0].concat(e));
      var r = t.length + e.length + 4, o = [48, r, 2, t.length];
      return o = o.concat(t, [2, e.length], e), Yt.from(o);
    }
    function w3(t, e, r, o) {
      if (t = Yt.from(t.toArray()), t.length < e.byteLength()) {
        var f = Yt.alloc(e.byteLength() - t.length);
        t = Yt.concat([f, t]);
      }
      var p = r.length, m2 = oq(r, e), y3 = Yt.alloc(p);
      y3.fill(1);
      var M = Yt.alloc(p);
      return M = Kn(o, M).update(y3).update(Yt.from([0])).update(t).update(m2).digest(), y3 = Kn(o, M).update(y3).digest(), M = Kn(o, M).update(y3).update(Yt.from([1])).update(t).update(m2).digest(), y3 = Kn(o, M).update(y3).digest(), { k: M, v: y3 };
    }
    function md(t, e) {
      var r = new b0(t), o = (t.length << 3) - e.bitLength();
      return o > 0 && r.ishrn(o), r;
    }
    function oq(t, e) {
      t = md(t, e), t = t.mod(e);
      var r = Yt.from(t.toArray());
      if (r.length < e.byteLength()) {
        var o = Yt.alloc(e.byteLength() - r.length);
        r = Yt.concat([o, r]);
      }
      return r;
    }
    function M3(t, e, r) {
      var o, f;
      do {
        for (o = Yt.alloc(0);o.length * 8 < t.bitLength(); )
          e.v = Kn(r, e.k).update(e.v).digest(), o = Yt.concat([o, e.v]);
        f = md(o, t), e.k = Kn(r, e.k).update(e.v).update(Yt.from([0])).digest(), e.v = Kn(r, e.k).update(e.v).digest();
      } while (f.cmp(t) !== -1);
      return f;
    }
    function sq(t, e, r, o) {
      return t.toRed(b0.mont(r)).redPow(e).fromRed().mod(o);
    }
    m0.exports = iq;
    m0.exports.getKey = w3;
    m0.exports.makeKey = M3;
  });
  A3 = T2((gL, E3) => {
    var gd = Te().Buffer, Wa = Ws(), hq = o0().ec, S3 = Ha(), uq = bd();
    function lq(t, e, r, o, f) {
      var p = S3(r);
      if (p.type === "ec") {
        if (o !== "ecdsa" && o !== "ecdsa/rsa")
          throw new Error("wrong public key type");
        return dq(t, e, p);
      } else if (p.type === "dsa") {
        if (o !== "dsa")
          throw new Error("wrong public key type");
        return cq(t, e, p);
      } else if (o !== "rsa" && o !== "ecdsa/rsa")
        throw new Error("wrong public key type");
      e = gd.concat([f, e]);
      for (var m2 = p.modulus.byteLength(), y3 = [1], M = 0;e.length + y3.length + 2 < m2; )
        y3.push(255), M++;
      y3.push(0);
      for (var x = -1;++x < e.length; )
        y3.push(e[x]);
      y3 = gd.from(y3);
      var S = Wa.mont(p.modulus);
      t = new Wa(t).toRed(S), t = t.redPow(new Wa(p.publicExponent)), t = gd.from(t.fromRed().toArray());
      var E2 = M < 8 ? 1 : 0;
      for (m2 = Math.min(t.length, y3.length), t.length !== y3.length && (E2 = 1), x = -1;++x < m2; )
        E2 |= t[x] ^ y3[x];
      return E2 === 0;
    }
    function dq(t, e, r) {
      var o = uq[r.data.algorithm.curve.join(".")];
      if (!o)
        throw new Error("unknown curve " + r.data.algorithm.curve.join("."));
      var f = new hq(o), p = r.data.subjectPrivateKey.data;
      return f.verify(e, t, p);
    }
    function cq(t, e, r) {
      var o = r.data.p, f = r.data.q, p = r.data.g, m2 = r.data.pub_key, y3 = S3.signature.decode(t, "der"), M = y3.s, x = y3.r;
      x3(M, f), x3(x, f);
      var S = Wa.mont(o), E2 = M.invm(f), B = p.toRed(S).redPow(new Wa(e).mul(E2).mod(f)).fromRed().mul(m2.toRed(S).redPow(x.mul(E2).mod(f)).fromRed()).mod(o).mod(f);
      return B.cmp(x) === 0;
    }
    function x3(t, e) {
      if (t.cmpn(0) <= 0)
        throw new Error("invalid sig");
      if (t.cmp(e) >= e)
        throw new Error("invalid sig");
    }
    E3.exports = lq;
  });
  k3 = T2((yL, T3) => {
    var g0 = Te().Buffer, q3 = bf(), y0 = i2(), I3 = Ie(), pq = _3(), vq = A3(), jn = Mu();
    Object.keys(jn).forEach(function(t) {
      jn[t].id = g0.from(jn[t].id, "hex"), jn[t.toLowerCase()] = jn[t];
    });
    function Ka(t) {
      y0.Writable.call(this);
      var e = jn[t];
      if (!e)
        throw new Error("Unknown message digest");
      this._hashType = e.hash, this._hash = q3(e.hash), this._tag = e.id, this._signType = e.sign;
    }
    I3(Ka, y0.Writable);
    Ka.prototype._write = function(e, r, o) {
      this._hash.update(e), o();
    };
    Ka.prototype.update = function(e, r) {
      return typeof e == "string" && (e = g0.from(e, r)), this._hash.update(e), this;
    };
    Ka.prototype.sign = function(e, r) {
      this.end();
      var o = this._hash.digest(), f = pq(o, e, this._hashType, this._signType, this._tag);
      return r ? f.toString(r) : f;
    };
    function ja(t) {
      y0.Writable.call(this);
      var e = jn[t];
      if (!e)
        throw new Error("Unknown message digest");
      this._hash = q3(e.hash), this._tag = e.id, this._signType = e.sign;
    }
    I3(ja, y0.Writable);
    ja.prototype._write = function(e, r, o) {
      this._hash.update(e), o();
    };
    ja.prototype.update = function(e, r) {
      return typeof e == "string" && (e = g0.from(e, r)), this._hash.update(e), this;
    };
    ja.prototype.verify = function(e, r, o) {
      typeof r == "string" && (r = g0.from(r, o)), this.end();
      var f = this._hash.digest();
      return vq(r, f, e, this._signType, this._tag);
    };
    function R3(t) {
      return new Ka(t);
    }
    function B3(t) {
      return new ja(t);
    }
    T3.exports = { Sign: R3, Verify: B3, createSign: R3, createVerify: B3 };
  });
  N3 = T2((L3, yd) => {
    (function(t, e) {
      function r(v, i) {
        if (!v)
          throw new Error(i || "Assertion failed");
      }
      function o(v, i) {
        v.super_ = i;
        var a = function() {
        };
        a.prototype = i.prototype, v.prototype = new a, v.prototype.constructor = v;
      }
      function f(v, i, a) {
        if (f.isBN(v))
          return v;
        this.negative = 0, this.words = null, this.length = 0, this.red = null, v !== null && ((i === "le" || i === "be") && (a = i, i = 10), this._init(v || 0, i || 10, a || "be"));
      }
      typeof t == "object" ? t.exports = f : e.BN = f, f.BN = f, f.wordSize = 26;
      var p;
      try {
        typeof window < "u" && typeof window.Buffer < "u" ? p = window.Buffer : p = ji().Buffer;
      } catch {
      }
      f.isBN = function(i) {
        return i instanceof f ? true : i !== null && typeof i == "object" && i.constructor.wordSize === f.wordSize && Array.isArray(i.words);
      }, f.max = function(i, a) {
        return i.cmp(a) > 0 ? i : a;
      }, f.min = function(i, a) {
        return i.cmp(a) < 0 ? i : a;
      }, f.prototype._init = function(i, a, h2) {
        if (typeof i == "number")
          return this._initNumber(i, a, h2);
        if (typeof i == "object")
          return this._initArray(i, a, h2);
        a === "hex" && (a = 16), r(a === (a | 0) && a >= 2 && a <= 36), i = i.toString().replace(/\s+/g, "");
        var s = 0;
        i[0] === "-" && (s++, this.negative = 1), s < i.length && (a === 16 ? this._parseHex(i, s, h2) : (this._parseBase(i, a, s), h2 === "le" && this._initArray(this.toArray(), a, h2)));
      }, f.prototype._initNumber = function(i, a, h2) {
        i < 0 && (this.negative = 1, i = -i), i < 67108864 ? (this.words = [i & 67108863], this.length = 1) : i < 4503599627370496 ? (this.words = [i & 67108863, i / 67108864 & 67108863], this.length = 2) : (r(i < 9007199254740992), this.words = [i & 67108863, i / 67108864 & 67108863, 1], this.length = 3), h2 === "le" && this._initArray(this.toArray(), a, h2);
      }, f.prototype._initArray = function(i, a, h2) {
        if (r(typeof i.length == "number"), i.length <= 0)
          return this.words = [0], this.length = 1, this;
        this.length = Math.ceil(i.length / 3), this.words = new Array(this.length);
        for (var s = 0;s < this.length; s++)
          this.words[s] = 0;
        var u, c, b3 = 0;
        if (h2 === "be")
          for (s = i.length - 1, u = 0;s >= 0; s -= 3)
            c = i[s] | i[s - 1] << 8 | i[s - 2] << 16, this.words[u] |= c << b3 & 67108863, this.words[u + 1] = c >>> 26 - b3 & 67108863, b3 += 24, b3 >= 26 && (b3 -= 26, u++);
        else if (h2 === "le")
          for (s = 0, u = 0;s < i.length; s += 3)
            c = i[s] | i[s + 1] << 8 | i[s + 2] << 16, this.words[u] |= c << b3 & 67108863, this.words[u + 1] = c >>> 26 - b3 & 67108863, b3 += 24, b3 >= 26 && (b3 -= 26, u++);
        return this.strip();
      };
      function m2(v, i) {
        var a = v.charCodeAt(i);
        return a >= 65 && a <= 70 ? a - 55 : a >= 97 && a <= 102 ? a - 87 : a - 48 & 15;
      }
      function y3(v, i, a) {
        var h2 = m2(v, a);
        return a - 1 >= i && (h2 |= m2(v, a - 1) << 4), h2;
      }
      f.prototype._parseHex = function(i, a, h2) {
        this.length = Math.ceil((i.length - a) / 6), this.words = new Array(this.length);
        for (var s = 0;s < this.length; s++)
          this.words[s] = 0;
        var u = 0, c = 0, b3;
        if (h2 === "be")
          for (s = i.length - 1;s >= a; s -= 2)
            b3 = y3(i, a, s) << u, this.words[c] |= b3 & 67108863, u >= 18 ? (u -= 18, c += 1, this.words[c] |= b3 >>> 26) : u += 8;
        else {
          var l = i.length - a;
          for (s = l % 2 === 0 ? a + 1 : a;s < i.length; s += 2)
            b3 = y3(i, a, s) << u, this.words[c] |= b3 & 67108863, u >= 18 ? (u -= 18, c += 1, this.words[c] |= b3 >>> 26) : u += 8;
        }
        this.strip();
      };
      function M(v, i, a, h2) {
        for (var s = 0, u = Math.min(v.length, a), c = i;c < u; c++) {
          var b3 = v.charCodeAt(c) - 48;
          s *= h2, b3 >= 49 ? s += b3 - 49 + 10 : b3 >= 17 ? s += b3 - 17 + 10 : s += b3;
        }
        return s;
      }
      f.prototype._parseBase = function(i, a, h2) {
        this.words = [0], this.length = 1;
        for (var s = 0, u = 1;u <= 67108863; u *= a)
          s++;
        s--, u = u / a | 0;
        for (var c = i.length - h2, b3 = c % s, l = Math.min(c, c - b3) + h2, n = 0, d = h2;d < l; d += s)
          n = M(i, d, d + s, a), this.imuln(u), this.words[0] + n < 67108864 ? this.words[0] += n : this._iaddn(n);
        if (b3 !== 0) {
          var w = 1;
          for (n = M(i, d, i.length, a), d = 0;d < b3; d++)
            w *= a;
          this.imuln(w), this.words[0] + n < 67108864 ? this.words[0] += n : this._iaddn(n);
        }
        this.strip();
      }, f.prototype.copy = function(i) {
        i.words = new Array(this.length);
        for (var a = 0;a < this.length; a++)
          i.words[a] = this.words[a];
        i.length = this.length, i.negative = this.negative, i.red = this.red;
      }, f.prototype.clone = function() {
        var i = new f(null);
        return this.copy(i), i;
      }, f.prototype._expand = function(i) {
        for (;this.length < i; )
          this.words[this.length++] = 0;
        return this;
      }, f.prototype.strip = function() {
        for (;this.length > 1 && this.words[this.length - 1] === 0; )
          this.length--;
        return this._normSign();
      }, f.prototype._normSign = function() {
        return this.length === 1 && this.words[0] === 0 && (this.negative = 0), this;
      }, f.prototype.inspect = function() {
        return (this.red ? "<BN-R: " : "<BN: ") + this.toString(16) + ">";
      };
      var x = ["", "0", "00", "000", "0000", "00000", "000000", "0000000", "00000000", "000000000", "0000000000", "00000000000", "000000000000", "0000000000000", "00000000000000", "000000000000000", "0000000000000000", "00000000000000000", "000000000000000000", "0000000000000000000", "00000000000000000000", "000000000000000000000", "0000000000000000000000", "00000000000000000000000", "000000000000000000000000", "0000000000000000000000000"], S = [0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5], E2 = [0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 1e7, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176];
      f.prototype.toString = function(i, a) {
        i = i || 10, a = a | 0 || 1;
        var h2;
        if (i === 16 || i === "hex") {
          h2 = "";
          for (var s = 0, u = 0, c = 0;c < this.length; c++) {
            var b3 = this.words[c], l = ((b3 << s | u) & 16777215).toString(16);
            u = b3 >>> 24 - s & 16777215, u !== 0 || c !== this.length - 1 ? h2 = x[6 - l.length] + l + h2 : h2 = l + h2, s += 2, s >= 26 && (s -= 26, c--);
          }
          for (u !== 0 && (h2 = u.toString(16) + h2);h2.length % a !== 0; )
            h2 = "0" + h2;
          return this.negative !== 0 && (h2 = "-" + h2), h2;
        }
        if (i === (i | 0) && i >= 2 && i <= 36) {
          var n = S[i], d = E2[i];
          h2 = "";
          var w = this.clone();
          for (w.negative = 0;!w.isZero(); ) {
            var g = w.modn(d).toString(i);
            w = w.idivn(d), w.isZero() ? h2 = g + h2 : h2 = x[n - g.length] + g + h2;
          }
          for (this.isZero() && (h2 = "0" + h2);h2.length % a !== 0; )
            h2 = "0" + h2;
          return this.negative !== 0 && (h2 = "-" + h2), h2;
        }
        r(false, "Base should be between 2 and 36");
      }, f.prototype.toNumber = function() {
        var i = this.words[0];
        return this.length === 2 ? i += this.words[1] * 67108864 : this.length === 3 && this.words[2] === 1 ? i += 4503599627370496 + this.words[1] * 67108864 : this.length > 2 && r(false, "Number can only safely store up to 53 bits"), this.negative !== 0 ? -i : i;
      }, f.prototype.toJSON = function() {
        return this.toString(16);
      }, f.prototype.toBuffer = function(i, a) {
        return r(typeof p < "u"), this.toArrayLike(p, i, a);
      }, f.prototype.toArray = function(i, a) {
        return this.toArrayLike(Array, i, a);
      }, f.prototype.toArrayLike = function(i, a, h2) {
        var s = this.byteLength(), u = h2 || Math.max(1, s);
        r(s <= u, "byte array longer than desired length"), r(u > 0, "Requested array length <= 0"), this.strip();
        var c = a === "le", b3 = new i(u), l, n, d = this.clone();
        if (c) {
          for (n = 0;!d.isZero(); n++)
            l = d.andln(255), d.iushrn(8), b3[n] = l;
          for (;n < u; n++)
            b3[n] = 0;
        } else {
          for (n = 0;n < u - s; n++)
            b3[n] = 0;
          for (n = 0;!d.isZero(); n++)
            l = d.andln(255), d.iushrn(8), b3[u - n - 1] = l;
        }
        return b3;
      }, Math.clz32 ? f.prototype._countBits = function(i) {
        return 32 - Math.clz32(i);
      } : f.prototype._countBits = function(i) {
        var a = i, h2 = 0;
        return a >= 4096 && (h2 += 13, a >>>= 13), a >= 64 && (h2 += 7, a >>>= 7), a >= 8 && (h2 += 4, a >>>= 4), a >= 2 && (h2 += 2, a >>>= 2), h2 + a;
      }, f.prototype._zeroBits = function(i) {
        if (i === 0)
          return 26;
        var a = i, h2 = 0;
        return (a & 8191) === 0 && (h2 += 13, a >>>= 13), (a & 127) === 0 && (h2 += 7, a >>>= 7), (a & 15) === 0 && (h2 += 4, a >>>= 4), (a & 3) === 0 && (h2 += 2, a >>>= 2), (a & 1) === 0 && h2++, h2;
      }, f.prototype.bitLength = function() {
        var i = this.words[this.length - 1], a = this._countBits(i);
        return (this.length - 1) * 26 + a;
      };
      function B(v) {
        for (var i = new Array(v.bitLength()), a = 0;a < i.length; a++) {
          var h2 = a / 26 | 0, s = a % 26;
          i[a] = (v.words[h2] & 1 << s) >>> s;
        }
        return i;
      }
      f.prototype.zeroBits = function() {
        if (this.isZero())
          return 0;
        for (var i = 0, a = 0;a < this.length; a++) {
          var h2 = this._zeroBits(this.words[a]);
          if (i += h2, h2 !== 26)
            break;
        }
        return i;
      }, f.prototype.byteLength = function() {
        return Math.ceil(this.bitLength() / 8);
      }, f.prototype.toTwos = function(i) {
        return this.negative !== 0 ? this.abs().inotn(i).iaddn(1) : this.clone();
      }, f.prototype.fromTwos = function(i) {
        return this.testn(i - 1) ? this.notn(i).iaddn(1).ineg() : this.clone();
      }, f.prototype.isNeg = function() {
        return this.negative !== 0;
      }, f.prototype.neg = function() {
        return this.clone().ineg();
      }, f.prototype.ineg = function() {
        return this.isZero() || (this.negative ^= 1), this;
      }, f.prototype.iuor = function(i) {
        for (;this.length < i.length; )
          this.words[this.length++] = 0;
        for (var a = 0;a < i.length; a++)
          this.words[a] = this.words[a] | i.words[a];
        return this.strip();
      }, f.prototype.ior = function(i) {
        return r((this.negative | i.negative) === 0), this.iuor(i);
      }, f.prototype.or = function(i) {
        return this.length > i.length ? this.clone().ior(i) : i.clone().ior(this);
      }, f.prototype.uor = function(i) {
        return this.length > i.length ? this.clone().iuor(i) : i.clone().iuor(this);
      }, f.prototype.iuand = function(i) {
        var a;
        this.length > i.length ? a = i : a = this;
        for (var h2 = 0;h2 < a.length; h2++)
          this.words[h2] = this.words[h2] & i.words[h2];
        return this.length = a.length, this.strip();
      }, f.prototype.iand = function(i) {
        return r((this.negative | i.negative) === 0), this.iuand(i);
      }, f.prototype.and = function(i) {
        return this.length > i.length ? this.clone().iand(i) : i.clone().iand(this);
      }, f.prototype.uand = function(i) {
        return this.length > i.length ? this.clone().iuand(i) : i.clone().iuand(this);
      }, f.prototype.iuxor = function(i) {
        var a, h2;
        this.length > i.length ? (a = this, h2 = i) : (a = i, h2 = this);
        for (var s = 0;s < h2.length; s++)
          this.words[s] = a.words[s] ^ h2.words[s];
        if (this !== a)
          for (;s < a.length; s++)
            this.words[s] = a.words[s];
        return this.length = a.length, this.strip();
      }, f.prototype.ixor = function(i) {
        return r((this.negative | i.negative) === 0), this.iuxor(i);
      }, f.prototype.xor = function(i) {
        return this.length > i.length ? this.clone().ixor(i) : i.clone().ixor(this);
      }, f.prototype.uxor = function(i) {
        return this.length > i.length ? this.clone().iuxor(i) : i.clone().iuxor(this);
      }, f.prototype.inotn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = Math.ceil(i / 26) | 0, h2 = i % 26;
        this._expand(a), h2 > 0 && a--;
        for (var s = 0;s < a; s++)
          this.words[s] = ~this.words[s] & 67108863;
        return h2 > 0 && (this.words[s] = ~this.words[s] & 67108863 >> 26 - h2), this.strip();
      }, f.prototype.notn = function(i) {
        return this.clone().inotn(i);
      }, f.prototype.setn = function(i, a) {
        r(typeof i == "number" && i >= 0);
        var h2 = i / 26 | 0, s = i % 26;
        return this._expand(h2 + 1), a ? this.words[h2] = this.words[h2] | 1 << s : this.words[h2] = this.words[h2] & ~(1 << s), this.strip();
      }, f.prototype.iadd = function(i) {
        var a;
        if (this.negative !== 0 && i.negative === 0)
          return this.negative = 0, a = this.isub(i), this.negative ^= 1, this._normSign();
        if (this.negative === 0 && i.negative !== 0)
          return i.negative = 0, a = this.isub(i), i.negative = 1, a._normSign();
        var h2, s;
        this.length > i.length ? (h2 = this, s = i) : (h2 = i, s = this);
        for (var u = 0, c = 0;c < s.length; c++)
          a = (h2.words[c] | 0) + (s.words[c] | 0) + u, this.words[c] = a & 67108863, u = a >>> 26;
        for (;u !== 0 && c < h2.length; c++)
          a = (h2.words[c] | 0) + u, this.words[c] = a & 67108863, u = a >>> 26;
        if (this.length = h2.length, u !== 0)
          this.words[this.length] = u, this.length++;
        else if (h2 !== this)
          for (;c < h2.length; c++)
            this.words[c] = h2.words[c];
        return this;
      }, f.prototype.add = function(i) {
        var a;
        return i.negative !== 0 && this.negative === 0 ? (i.negative = 0, a = this.sub(i), i.negative ^= 1, a) : i.negative === 0 && this.negative !== 0 ? (this.negative = 0, a = i.sub(this), this.negative = 1, a) : this.length > i.length ? this.clone().iadd(i) : i.clone().iadd(this);
      }, f.prototype.isub = function(i) {
        if (i.negative !== 0) {
          i.negative = 0;
          var a = this.iadd(i);
          return i.negative = 1, a._normSign();
        } else if (this.negative !== 0)
          return this.negative = 0, this.iadd(i), this.negative = 1, this._normSign();
        var h2 = this.cmp(i);
        if (h2 === 0)
          return this.negative = 0, this.length = 1, this.words[0] = 0, this;
        var s, u;
        h2 > 0 ? (s = this, u = i) : (s = i, u = this);
        for (var c = 0, b3 = 0;b3 < u.length; b3++)
          a = (s.words[b3] | 0) - (u.words[b3] | 0) + c, c = a >> 26, this.words[b3] = a & 67108863;
        for (;c !== 0 && b3 < s.length; b3++)
          a = (s.words[b3] | 0) + c, c = a >> 26, this.words[b3] = a & 67108863;
        if (c === 0 && b3 < s.length && s !== this)
          for (;b3 < s.length; b3++)
            this.words[b3] = s.words[b3];
        return this.length = Math.max(this.length, b3), s !== this && (this.negative = 1), this.strip();
      }, f.prototype.sub = function(i) {
        return this.clone().isub(i);
      };
      function q2(v, i, a) {
        a.negative = i.negative ^ v.negative;
        var h2 = v.length + i.length | 0;
        a.length = h2, h2 = h2 - 1 | 0;
        var s = v.words[0] | 0, u = i.words[0] | 0, c = s * u, b3 = c & 67108863, l = c / 67108864 | 0;
        a.words[0] = b3;
        for (var n = 1;n < h2; n++) {
          for (var d = l >>> 26, w = l & 67108863, g = Math.min(n, i.length - 1), _4 = Math.max(0, n - v.length + 1);_4 <= g; _4++) {
            var A2 = n - _4 | 0;
            s = v.words[A2] | 0, u = i.words[_4] | 0, c = s * u + w, d += c / 67108864 | 0, w = c & 67108863;
          }
          a.words[n] = w | 0, l = d | 0;
        }
        return l !== 0 ? a.words[n] = l | 0 : a.length--, a.strip();
      }
      var L2 = function(i, a, h2) {
        var s = i.words, u = a.words, c = h2.words, b3 = 0, l, n, d, w = s[0] | 0, g = w & 8191, _4 = w >>> 13, A2 = s[1] | 0, R2 = A2 & 8191, I = A2 >>> 13, Me = s[2] | 0, k = Me & 8191, D2 = Me >>> 13, nt = s[3] | 0, C2 = nt & 8191, O = nt >>> 13, vt = s[4] | 0, F = vt & 8191, U = vt >>> 13, bt = s[5] | 0, z2 = bt & 8191, H = bt >>> 13, mt = s[6] | 0, W = mt & 8191, K = mt >>> 13, gt = s[7] | 0, j = gt & 8191, Z = gt >>> 13, yt = s[8] | 0, V = yt & 8191, $ = yt >>> 13, wt = s[9] | 0, G = wt & 8191, Y = wt >>> 13, Mt = u[0] | 0, X = Mt & 8191, J = Mt >>> 13, _t = u[1] | 0, Q = _t & 8191, ee = _t >>> 13, xt = u[2] | 0, te = xt & 8191, re = xt >>> 13, St = u[3] | 0, ie = St & 8191, ne = St >>> 13, Et = u[4] | 0, fe = Et & 8191, ae = Et >>> 13, At = u[5] | 0, oe = At & 8191, se = At >>> 13, Rt = u[6] | 0, he = Rt & 8191, ue = Rt >>> 13, Bt = u[7] | 0, le = Bt & 8191, de = Bt >>> 13, qt = u[8] | 0, ce = qt & 8191, pe = qt >>> 13, It = u[9] | 0, ve = It & 8191, be = It >>> 13;
        h2.negative = i.negative ^ a.negative, h2.length = 19, l = Math.imul(g, X), n = Math.imul(g, J), n = n + Math.imul(_4, X) | 0, d = Math.imul(_4, J);
        var ft = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (ft >>> 26) | 0, ft &= 67108863, l = Math.imul(R2, X), n = Math.imul(R2, J), n = n + Math.imul(I, X) | 0, d = Math.imul(I, J), l = l + Math.imul(g, Q) | 0, n = n + Math.imul(g, ee) | 0, n = n + Math.imul(_4, Q) | 0, d = d + Math.imul(_4, ee) | 0;
        var Be = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Be >>> 26) | 0, Be &= 67108863, l = Math.imul(k, X), n = Math.imul(k, J), n = n + Math.imul(D2, X) | 0, d = Math.imul(D2, J), l = l + Math.imul(R2, Q) | 0, n = n + Math.imul(R2, ee) | 0, n = n + Math.imul(I, Q) | 0, d = d + Math.imul(I, ee) | 0, l = l + Math.imul(g, te) | 0, n = n + Math.imul(g, re) | 0, n = n + Math.imul(_4, te) | 0, d = d + Math.imul(_4, re) | 0;
        var qe = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (qe >>> 26) | 0, qe &= 67108863, l = Math.imul(C2, X), n = Math.imul(C2, J), n = n + Math.imul(O, X) | 0, d = Math.imul(O, J), l = l + Math.imul(k, Q) | 0, n = n + Math.imul(k, ee) | 0, n = n + Math.imul(D2, Q) | 0, d = d + Math.imul(D2, ee) | 0, l = l + Math.imul(R2, te) | 0, n = n + Math.imul(R2, re) | 0, n = n + Math.imul(I, te) | 0, d = d + Math.imul(I, re) | 0, l = l + Math.imul(g, ie) | 0, n = n + Math.imul(g, ne) | 0, n = n + Math.imul(_4, ie) | 0, d = d + Math.imul(_4, ne) | 0;
        var ze = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (ze >>> 26) | 0, ze &= 67108863, l = Math.imul(F, X), n = Math.imul(F, J), n = n + Math.imul(U, X) | 0, d = Math.imul(U, J), l = l + Math.imul(C2, Q) | 0, n = n + Math.imul(C2, ee) | 0, n = n + Math.imul(O, Q) | 0, d = d + Math.imul(O, ee) | 0, l = l + Math.imul(k, te) | 0, n = n + Math.imul(k, re) | 0, n = n + Math.imul(D2, te) | 0, d = d + Math.imul(D2, re) | 0, l = l + Math.imul(R2, ie) | 0, n = n + Math.imul(R2, ne) | 0, n = n + Math.imul(I, ie) | 0, d = d + Math.imul(I, ne) | 0, l = l + Math.imul(g, fe) | 0, n = n + Math.imul(g, ae) | 0, n = n + Math.imul(_4, fe) | 0, d = d + Math.imul(_4, ae) | 0;
        var He = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (He >>> 26) | 0, He &= 67108863, l = Math.imul(z2, X), n = Math.imul(z2, J), n = n + Math.imul(H, X) | 0, d = Math.imul(H, J), l = l + Math.imul(F, Q) | 0, n = n + Math.imul(F, ee) | 0, n = n + Math.imul(U, Q) | 0, d = d + Math.imul(U, ee) | 0, l = l + Math.imul(C2, te) | 0, n = n + Math.imul(C2, re) | 0, n = n + Math.imul(O, te) | 0, d = d + Math.imul(O, re) | 0, l = l + Math.imul(k, ie) | 0, n = n + Math.imul(k, ne) | 0, n = n + Math.imul(D2, ie) | 0, d = d + Math.imul(D2, ne) | 0, l = l + Math.imul(R2, fe) | 0, n = n + Math.imul(R2, ae) | 0, n = n + Math.imul(I, fe) | 0, d = d + Math.imul(I, ae) | 0, l = l + Math.imul(g, oe) | 0, n = n + Math.imul(g, se) | 0, n = n + Math.imul(_4, oe) | 0, d = d + Math.imul(_4, se) | 0;
        var We = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (We >>> 26) | 0, We &= 67108863, l = Math.imul(W, X), n = Math.imul(W, J), n = n + Math.imul(K, X) | 0, d = Math.imul(K, J), l = l + Math.imul(z2, Q) | 0, n = n + Math.imul(z2, ee) | 0, n = n + Math.imul(H, Q) | 0, d = d + Math.imul(H, ee) | 0, l = l + Math.imul(F, te) | 0, n = n + Math.imul(F, re) | 0, n = n + Math.imul(U, te) | 0, d = d + Math.imul(U, re) | 0, l = l + Math.imul(C2, ie) | 0, n = n + Math.imul(C2, ne) | 0, n = n + Math.imul(O, ie) | 0, d = d + Math.imul(O, ne) | 0, l = l + Math.imul(k, fe) | 0, n = n + Math.imul(k, ae) | 0, n = n + Math.imul(D2, fe) | 0, d = d + Math.imul(D2, ae) | 0, l = l + Math.imul(R2, oe) | 0, n = n + Math.imul(R2, se) | 0, n = n + Math.imul(I, oe) | 0, d = d + Math.imul(I, se) | 0, l = l + Math.imul(g, he) | 0, n = n + Math.imul(g, ue) | 0, n = n + Math.imul(_4, he) | 0, d = d + Math.imul(_4, ue) | 0;
        var Ke = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ke >>> 26) | 0, Ke &= 67108863, l = Math.imul(j, X), n = Math.imul(j, J), n = n + Math.imul(Z, X) | 0, d = Math.imul(Z, J), l = l + Math.imul(W, Q) | 0, n = n + Math.imul(W, ee) | 0, n = n + Math.imul(K, Q) | 0, d = d + Math.imul(K, ee) | 0, l = l + Math.imul(z2, te) | 0, n = n + Math.imul(z2, re) | 0, n = n + Math.imul(H, te) | 0, d = d + Math.imul(H, re) | 0, l = l + Math.imul(F, ie) | 0, n = n + Math.imul(F, ne) | 0, n = n + Math.imul(U, ie) | 0, d = d + Math.imul(U, ne) | 0, l = l + Math.imul(C2, fe) | 0, n = n + Math.imul(C2, ae) | 0, n = n + Math.imul(O, fe) | 0, d = d + Math.imul(O, ae) | 0, l = l + Math.imul(k, oe) | 0, n = n + Math.imul(k, se) | 0, n = n + Math.imul(D2, oe) | 0, d = d + Math.imul(D2, se) | 0, l = l + Math.imul(R2, he) | 0, n = n + Math.imul(R2, ue) | 0, n = n + Math.imul(I, he) | 0, d = d + Math.imul(I, ue) | 0, l = l + Math.imul(g, le) | 0, n = n + Math.imul(g, de) | 0, n = n + Math.imul(_4, le) | 0, d = d + Math.imul(_4, de) | 0;
        var je = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (je >>> 26) | 0, je &= 67108863, l = Math.imul(V, X), n = Math.imul(V, J), n = n + Math.imul($, X) | 0, d = Math.imul($, J), l = l + Math.imul(j, Q) | 0, n = n + Math.imul(j, ee) | 0, n = n + Math.imul(Z, Q) | 0, d = d + Math.imul(Z, ee) | 0, l = l + Math.imul(W, te) | 0, n = n + Math.imul(W, re) | 0, n = n + Math.imul(K, te) | 0, d = d + Math.imul(K, re) | 0, l = l + Math.imul(z2, ie) | 0, n = n + Math.imul(z2, ne) | 0, n = n + Math.imul(H, ie) | 0, d = d + Math.imul(H, ne) | 0, l = l + Math.imul(F, fe) | 0, n = n + Math.imul(F, ae) | 0, n = n + Math.imul(U, fe) | 0, d = d + Math.imul(U, ae) | 0, l = l + Math.imul(C2, oe) | 0, n = n + Math.imul(C2, se) | 0, n = n + Math.imul(O, oe) | 0, d = d + Math.imul(O, se) | 0, l = l + Math.imul(k, he) | 0, n = n + Math.imul(k, ue) | 0, n = n + Math.imul(D2, he) | 0, d = d + Math.imul(D2, ue) | 0, l = l + Math.imul(R2, le) | 0, n = n + Math.imul(R2, de) | 0, n = n + Math.imul(I, le) | 0, d = d + Math.imul(I, de) | 0, l = l + Math.imul(g, ce) | 0, n = n + Math.imul(g, pe) | 0, n = n + Math.imul(_4, ce) | 0, d = d + Math.imul(_4, pe) | 0;
        var Ze = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ze >>> 26) | 0, Ze &= 67108863, l = Math.imul(G, X), n = Math.imul(G, J), n = n + Math.imul(Y, X) | 0, d = Math.imul(Y, J), l = l + Math.imul(V, Q) | 0, n = n + Math.imul(V, ee) | 0, n = n + Math.imul($, Q) | 0, d = d + Math.imul($, ee) | 0, l = l + Math.imul(j, te) | 0, n = n + Math.imul(j, re) | 0, n = n + Math.imul(Z, te) | 0, d = d + Math.imul(Z, re) | 0, l = l + Math.imul(W, ie) | 0, n = n + Math.imul(W, ne) | 0, n = n + Math.imul(K, ie) | 0, d = d + Math.imul(K, ne) | 0, l = l + Math.imul(z2, fe) | 0, n = n + Math.imul(z2, ae) | 0, n = n + Math.imul(H, fe) | 0, d = d + Math.imul(H, ae) | 0, l = l + Math.imul(F, oe) | 0, n = n + Math.imul(F, se) | 0, n = n + Math.imul(U, oe) | 0, d = d + Math.imul(U, se) | 0, l = l + Math.imul(C2, he) | 0, n = n + Math.imul(C2, ue) | 0, n = n + Math.imul(O, he) | 0, d = d + Math.imul(O, ue) | 0, l = l + Math.imul(k, le) | 0, n = n + Math.imul(k, de) | 0, n = n + Math.imul(D2, le) | 0, d = d + Math.imul(D2, de) | 0, l = l + Math.imul(R2, ce) | 0, n = n + Math.imul(R2, pe) | 0, n = n + Math.imul(I, ce) | 0, d = d + Math.imul(I, pe) | 0, l = l + Math.imul(g, ve) | 0, n = n + Math.imul(g, be) | 0, n = n + Math.imul(_4, ve) | 0, d = d + Math.imul(_4, be) | 0;
        var Ve = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ve >>> 26) | 0, Ve &= 67108863, l = Math.imul(G, Q), n = Math.imul(G, ee), n = n + Math.imul(Y, Q) | 0, d = Math.imul(Y, ee), l = l + Math.imul(V, te) | 0, n = n + Math.imul(V, re) | 0, n = n + Math.imul($, te) | 0, d = d + Math.imul($, re) | 0, l = l + Math.imul(j, ie) | 0, n = n + Math.imul(j, ne) | 0, n = n + Math.imul(Z, ie) | 0, d = d + Math.imul(Z, ne) | 0, l = l + Math.imul(W, fe) | 0, n = n + Math.imul(W, ae) | 0, n = n + Math.imul(K, fe) | 0, d = d + Math.imul(K, ae) | 0, l = l + Math.imul(z2, oe) | 0, n = n + Math.imul(z2, se) | 0, n = n + Math.imul(H, oe) | 0, d = d + Math.imul(H, se) | 0, l = l + Math.imul(F, he) | 0, n = n + Math.imul(F, ue) | 0, n = n + Math.imul(U, he) | 0, d = d + Math.imul(U, ue) | 0, l = l + Math.imul(C2, le) | 0, n = n + Math.imul(C2, de) | 0, n = n + Math.imul(O, le) | 0, d = d + Math.imul(O, de) | 0, l = l + Math.imul(k, ce) | 0, n = n + Math.imul(k, pe) | 0, n = n + Math.imul(D2, ce) | 0, d = d + Math.imul(D2, pe) | 0, l = l + Math.imul(R2, ve) | 0, n = n + Math.imul(R2, be) | 0, n = n + Math.imul(I, ve) | 0, d = d + Math.imul(I, be) | 0;
        var $e = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + ($e >>> 26) | 0, $e &= 67108863, l = Math.imul(G, te), n = Math.imul(G, re), n = n + Math.imul(Y, te) | 0, d = Math.imul(Y, re), l = l + Math.imul(V, ie) | 0, n = n + Math.imul(V, ne) | 0, n = n + Math.imul($, ie) | 0, d = d + Math.imul($, ne) | 0, l = l + Math.imul(j, fe) | 0, n = n + Math.imul(j, ae) | 0, n = n + Math.imul(Z, fe) | 0, d = d + Math.imul(Z, ae) | 0, l = l + Math.imul(W, oe) | 0, n = n + Math.imul(W, se) | 0, n = n + Math.imul(K, oe) | 0, d = d + Math.imul(K, se) | 0, l = l + Math.imul(z2, he) | 0, n = n + Math.imul(z2, ue) | 0, n = n + Math.imul(H, he) | 0, d = d + Math.imul(H, ue) | 0, l = l + Math.imul(F, le) | 0, n = n + Math.imul(F, de) | 0, n = n + Math.imul(U, le) | 0, d = d + Math.imul(U, de) | 0, l = l + Math.imul(C2, ce) | 0, n = n + Math.imul(C2, pe) | 0, n = n + Math.imul(O, ce) | 0, d = d + Math.imul(O, pe) | 0, l = l + Math.imul(k, ve) | 0, n = n + Math.imul(k, be) | 0, n = n + Math.imul(D2, ve) | 0, d = d + Math.imul(D2, be) | 0;
        var Ge = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ge >>> 26) | 0, Ge &= 67108863, l = Math.imul(G, ie), n = Math.imul(G, ne), n = n + Math.imul(Y, ie) | 0, d = Math.imul(Y, ne), l = l + Math.imul(V, fe) | 0, n = n + Math.imul(V, ae) | 0, n = n + Math.imul($, fe) | 0, d = d + Math.imul($, ae) | 0, l = l + Math.imul(j, oe) | 0, n = n + Math.imul(j, se) | 0, n = n + Math.imul(Z, oe) | 0, d = d + Math.imul(Z, se) | 0, l = l + Math.imul(W, he) | 0, n = n + Math.imul(W, ue) | 0, n = n + Math.imul(K, he) | 0, d = d + Math.imul(K, ue) | 0, l = l + Math.imul(z2, le) | 0, n = n + Math.imul(z2, de) | 0, n = n + Math.imul(H, le) | 0, d = d + Math.imul(H, de) | 0, l = l + Math.imul(F, ce) | 0, n = n + Math.imul(F, pe) | 0, n = n + Math.imul(U, ce) | 0, d = d + Math.imul(U, pe) | 0, l = l + Math.imul(C2, ve) | 0, n = n + Math.imul(C2, be) | 0, n = n + Math.imul(O, ve) | 0, d = d + Math.imul(O, be) | 0;
        var Ye = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ye >>> 26) | 0, Ye &= 67108863, l = Math.imul(G, fe), n = Math.imul(G, ae), n = n + Math.imul(Y, fe) | 0, d = Math.imul(Y, ae), l = l + Math.imul(V, oe) | 0, n = n + Math.imul(V, se) | 0, n = n + Math.imul($, oe) | 0, d = d + Math.imul($, se) | 0, l = l + Math.imul(j, he) | 0, n = n + Math.imul(j, ue) | 0, n = n + Math.imul(Z, he) | 0, d = d + Math.imul(Z, ue) | 0, l = l + Math.imul(W, le) | 0, n = n + Math.imul(W, de) | 0, n = n + Math.imul(K, le) | 0, d = d + Math.imul(K, de) | 0, l = l + Math.imul(z2, ce) | 0, n = n + Math.imul(z2, pe) | 0, n = n + Math.imul(H, ce) | 0, d = d + Math.imul(H, pe) | 0, l = l + Math.imul(F, ve) | 0, n = n + Math.imul(F, be) | 0, n = n + Math.imul(U, ve) | 0, d = d + Math.imul(U, be) | 0;
        var Xe = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Xe >>> 26) | 0, Xe &= 67108863, l = Math.imul(G, oe), n = Math.imul(G, se), n = n + Math.imul(Y, oe) | 0, d = Math.imul(Y, se), l = l + Math.imul(V, he) | 0, n = n + Math.imul(V, ue) | 0, n = n + Math.imul($, he) | 0, d = d + Math.imul($, ue) | 0, l = l + Math.imul(j, le) | 0, n = n + Math.imul(j, de) | 0, n = n + Math.imul(Z, le) | 0, d = d + Math.imul(Z, de) | 0, l = l + Math.imul(W, ce) | 0, n = n + Math.imul(W, pe) | 0, n = n + Math.imul(K, ce) | 0, d = d + Math.imul(K, pe) | 0, l = l + Math.imul(z2, ve) | 0, n = n + Math.imul(z2, be) | 0, n = n + Math.imul(H, ve) | 0, d = d + Math.imul(H, be) | 0;
        var Je = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Je >>> 26) | 0, Je &= 67108863, l = Math.imul(G, he), n = Math.imul(G, ue), n = n + Math.imul(Y, he) | 0, d = Math.imul(Y, ue), l = l + Math.imul(V, le) | 0, n = n + Math.imul(V, de) | 0, n = n + Math.imul($, le) | 0, d = d + Math.imul($, de) | 0, l = l + Math.imul(j, ce) | 0, n = n + Math.imul(j, pe) | 0, n = n + Math.imul(Z, ce) | 0, d = d + Math.imul(Z, pe) | 0, l = l + Math.imul(W, ve) | 0, n = n + Math.imul(W, be) | 0, n = n + Math.imul(K, ve) | 0, d = d + Math.imul(K, be) | 0;
        var Qe = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Qe >>> 26) | 0, Qe &= 67108863, l = Math.imul(G, le), n = Math.imul(G, de), n = n + Math.imul(Y, le) | 0, d = Math.imul(Y, de), l = l + Math.imul(V, ce) | 0, n = n + Math.imul(V, pe) | 0, n = n + Math.imul($, ce) | 0, d = d + Math.imul($, pe) | 0, l = l + Math.imul(j, ve) | 0, n = n + Math.imul(j, be) | 0, n = n + Math.imul(Z, ve) | 0, d = d + Math.imul(Z, be) | 0;
        var et = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (et >>> 26) | 0, et &= 67108863, l = Math.imul(G, ce), n = Math.imul(G, pe), n = n + Math.imul(Y, ce) | 0, d = Math.imul(Y, pe), l = l + Math.imul(V, ve) | 0, n = n + Math.imul(V, be) | 0, n = n + Math.imul($, ve) | 0, d = d + Math.imul($, be) | 0;
        var tt = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (tt >>> 26) | 0, tt &= 67108863, l = Math.imul(G, ve), n = Math.imul(G, be), n = n + Math.imul(Y, ve) | 0, d = Math.imul(Y, be);
        var rt = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        return b3 = (d + (n >>> 13) | 0) + (rt >>> 26) | 0, rt &= 67108863, c[0] = ft, c[1] = Be, c[2] = qe, c[3] = ze, c[4] = He, c[5] = We, c[6] = Ke, c[7] = je, c[8] = Ze, c[9] = Ve, c[10] = $e, c[11] = Ge, c[12] = Ye, c[13] = Xe, c[14] = Je, c[15] = Qe, c[16] = et, c[17] = tt, c[18] = rt, b3 !== 0 && (c[19] = b3, h2.length++), h2;
      };
      Math.imul || (L2 = q2);
      function ge(v, i, a) {
        a.negative = i.negative ^ v.negative, a.length = v.length + i.length;
        for (var h2 = 0, s = 0, u = 0;u < a.length - 1; u++) {
          var c = s;
          s = 0;
          for (var b3 = h2 & 67108863, l = Math.min(u, i.length - 1), n = Math.max(0, u - v.length + 1);n <= l; n++) {
            var d = u - n, w = v.words[d] | 0, g = i.words[n] | 0, _4 = w * g, A2 = _4 & 67108863;
            c = c + (_4 / 67108864 | 0) | 0, A2 = A2 + b3 | 0, b3 = A2 & 67108863, c = c + (A2 >>> 26) | 0, s += c >>> 26, c &= 67108863;
          }
          a.words[u] = b3, h2 = c, c = s;
        }
        return h2 !== 0 ? a.words[u] = h2 : a.length--, a.strip();
      }
      function _e(v, i, a) {
        var h2 = new N;
        return h2.mulp(v, i, a);
      }
      f.prototype.mulTo = function(i, a) {
        var h2, s = this.length + i.length;
        return this.length === 10 && i.length === 10 ? h2 = L2(this, i, a) : s < 63 ? h2 = q2(this, i, a) : s < 1024 ? h2 = ge(this, i, a) : h2 = _e(this, i, a), h2;
      };
      function N(v, i) {
        this.x = v, this.y = i;
      }
      N.prototype.makeRBT = function(i) {
        for (var a = new Array(i), h2 = f.prototype._countBits(i) - 1, s = 0;s < i; s++)
          a[s] = this.revBin(s, h2, i);
        return a;
      }, N.prototype.revBin = function(i, a, h2) {
        if (i === 0 || i === h2 - 1)
          return i;
        for (var s = 0, u = 0;u < a; u++)
          s |= (i & 1) << a - u - 1, i >>= 1;
        return s;
      }, N.prototype.permute = function(i, a, h2, s, u, c) {
        for (var b3 = 0;b3 < c; b3++)
          s[b3] = a[i[b3]], u[b3] = h2[i[b3]];
      }, N.prototype.transform = function(i, a, h2, s, u, c) {
        this.permute(c, i, a, h2, s, u);
        for (var b3 = 1;b3 < u; b3 <<= 1)
          for (var l = b3 << 1, n = Math.cos(2 * Math.PI / l), d = Math.sin(2 * Math.PI / l), w = 0;w < u; w += l)
            for (var g = n, _4 = d, A2 = 0;A2 < b3; A2++) {
              var R2 = h2[w + A2], I = s[w + A2], Me = h2[w + A2 + b3], k = s[w + A2 + b3], D2 = g * Me - _4 * k;
              k = g * k + _4 * Me, Me = D2, h2[w + A2] = R2 + Me, s[w + A2] = I + k, h2[w + A2 + b3] = R2 - Me, s[w + A2 + b3] = I - k, A2 !== l && (D2 = n * g - d * _4, _4 = n * _4 + d * g, g = D2);
            }
      }, N.prototype.guessLen13b = function(i, a) {
        var h2 = Math.max(a, i) | 1, s = h2 & 1, u = 0;
        for (h2 = h2 / 2 | 0;h2; h2 = h2 >>> 1)
          u++;
        return 1 << u + 1 + s;
      }, N.prototype.conjugate = function(i, a, h2) {
        if (!(h2 <= 1))
          for (var s = 0;s < h2 / 2; s++) {
            var u = i[s];
            i[s] = i[h2 - s - 1], i[h2 - s - 1] = u, u = a[s], a[s] = -a[h2 - s - 1], a[h2 - s - 1] = -u;
          }
      }, N.prototype.normalize13b = function(i, a) {
        for (var h2 = 0, s = 0;s < a / 2; s++) {
          var u = Math.round(i[2 * s + 1] / a) * 8192 + Math.round(i[2 * s] / a) + h2;
          i[s] = u & 67108863, u < 67108864 ? h2 = 0 : h2 = u / 67108864 | 0;
        }
        return i;
      }, N.prototype.convert13b = function(i, a, h2, s) {
        for (var u = 0, c = 0;c < a; c++)
          u = u + (i[c] | 0), h2[2 * c] = u & 8191, u = u >>> 13, h2[2 * c + 1] = u & 8191, u = u >>> 13;
        for (c = 2 * a;c < s; ++c)
          h2[c] = 0;
        r(u === 0), r((u & -8192) === 0);
      }, N.prototype.stub = function(i) {
        for (var a = new Array(i), h2 = 0;h2 < i; h2++)
          a[h2] = 0;
        return a;
      }, N.prototype.mulp = function(i, a, h2) {
        var s = 2 * this.guessLen13b(i.length, a.length), u = this.makeRBT(s), c = this.stub(s), b3 = new Array(s), l = new Array(s), n = new Array(s), d = new Array(s), w = new Array(s), g = new Array(s), _4 = h2.words;
        _4.length = s, this.convert13b(i.words, i.length, b3, s), this.convert13b(a.words, a.length, d, s), this.transform(b3, c, l, n, s, u), this.transform(d, c, w, g, s, u);
        for (var A2 = 0;A2 < s; A2++) {
          var R2 = l[A2] * w[A2] - n[A2] * g[A2];
          n[A2] = l[A2] * g[A2] + n[A2] * w[A2], l[A2] = R2;
        }
        return this.conjugate(l, n, s), this.transform(l, n, _4, c, s, u), this.conjugate(_4, c, s), this.normalize13b(_4, s), h2.negative = i.negative ^ a.negative, h2.length = i.length + a.length, h2.strip();
      }, f.prototype.mul = function(i) {
        var a = new f(null);
        return a.words = new Array(this.length + i.length), this.mulTo(i, a);
      }, f.prototype.mulf = function(i) {
        var a = new f(null);
        return a.words = new Array(this.length + i.length), _e(this, i, a);
      }, f.prototype.imul = function(i) {
        return this.clone().mulTo(i, this);
      }, f.prototype.imuln = function(i) {
        r(typeof i == "number"), r(i < 67108864);
        for (var a = 0, h2 = 0;h2 < this.length; h2++) {
          var s = (this.words[h2] | 0) * i, u = (s & 67108863) + (a & 67108863);
          a >>= 26, a += s / 67108864 | 0, a += u >>> 26, this.words[h2] = u & 67108863;
        }
        return a !== 0 && (this.words[h2] = a, this.length++), this;
      }, f.prototype.muln = function(i) {
        return this.clone().imuln(i);
      }, f.prototype.sqr = function() {
        return this.mul(this);
      }, f.prototype.isqr = function() {
        return this.imul(this.clone());
      }, f.prototype.pow = function(i) {
        var a = B(i);
        if (a.length === 0)
          return new f(1);
        for (var h2 = this, s = 0;s < a.length && a[s] === 0; s++, h2 = h2.sqr())
          ;
        if (++s < a.length)
          for (var u = h2.sqr();s < a.length; s++, u = u.sqr())
            a[s] !== 0 && (h2 = h2.mul(u));
        return h2;
      }, f.prototype.iushln = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26, s = 67108863 >>> 26 - a << 26 - a, u;
        if (a !== 0) {
          var c = 0;
          for (u = 0;u < this.length; u++) {
            var b3 = this.words[u] & s, l = (this.words[u] | 0) - b3 << a;
            this.words[u] = l | c, c = b3 >>> 26 - a;
          }
          c && (this.words[u] = c, this.length++);
        }
        if (h2 !== 0) {
          for (u = this.length - 1;u >= 0; u--)
            this.words[u + h2] = this.words[u];
          for (u = 0;u < h2; u++)
            this.words[u] = 0;
          this.length += h2;
        }
        return this.strip();
      }, f.prototype.ishln = function(i) {
        return r(this.negative === 0), this.iushln(i);
      }, f.prototype.iushrn = function(i, a, h2) {
        r(typeof i == "number" && i >= 0);
        var s;
        a ? s = (a - a % 26) / 26 : s = 0;
        var u = i % 26, c = Math.min((i - u) / 26, this.length), b3 = 67108863 ^ 67108863 >>> u << u, l = h2;
        if (s -= c, s = Math.max(0, s), l) {
          for (var n = 0;n < c; n++)
            l.words[n] = this.words[n];
          l.length = c;
        }
        if (c !== 0)
          if (this.length > c)
            for (this.length -= c, n = 0;n < this.length; n++)
              this.words[n] = this.words[n + c];
          else
            this.words[0] = 0, this.length = 1;
        var d = 0;
        for (n = this.length - 1;n >= 0 && (d !== 0 || n >= s); n--) {
          var w = this.words[n] | 0;
          this.words[n] = d << 26 - u | w >>> u, d = w & b3;
        }
        return l && d !== 0 && (l.words[l.length++] = d), this.length === 0 && (this.words[0] = 0, this.length = 1), this.strip();
      }, f.prototype.ishrn = function(i, a, h2) {
        return r(this.negative === 0), this.iushrn(i, a, h2);
      }, f.prototype.shln = function(i) {
        return this.clone().ishln(i);
      }, f.prototype.ushln = function(i) {
        return this.clone().iushln(i);
      }, f.prototype.shrn = function(i) {
        return this.clone().ishrn(i);
      }, f.prototype.ushrn = function(i) {
        return this.clone().iushrn(i);
      }, f.prototype.testn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26, s = 1 << a;
        if (this.length <= h2)
          return false;
        var u = this.words[h2];
        return !!(u & s);
      }, f.prototype.imaskn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26;
        if (r(this.negative === 0, "imaskn works only with positive numbers"), this.length <= h2)
          return this;
        if (a !== 0 && h2++, this.length = Math.min(h2, this.length), a !== 0) {
          var s = 67108863 ^ 67108863 >>> a << a;
          this.words[this.length - 1] &= s;
        }
        return this.strip();
      }, f.prototype.maskn = function(i) {
        return this.clone().imaskn(i);
      }, f.prototype.iaddn = function(i) {
        return r(typeof i == "number"), r(i < 67108864), i < 0 ? this.isubn(-i) : this.negative !== 0 ? this.length === 1 && (this.words[0] | 0) < i ? (this.words[0] = i - (this.words[0] | 0), this.negative = 0, this) : (this.negative = 0, this.isubn(i), this.negative = 1, this) : this._iaddn(i);
      }, f.prototype._iaddn = function(i) {
        this.words[0] += i;
        for (var a = 0;a < this.length && this.words[a] >= 67108864; a++)
          this.words[a] -= 67108864, a === this.length - 1 ? this.words[a + 1] = 1 : this.words[a + 1]++;
        return this.length = Math.max(this.length, a + 1), this;
      }, f.prototype.isubn = function(i) {
        if (r(typeof i == "number"), r(i < 67108864), i < 0)
          return this.iaddn(-i);
        if (this.negative !== 0)
          return this.negative = 0, this.iaddn(i), this.negative = 1, this;
        if (this.words[0] -= i, this.length === 1 && this.words[0] < 0)
          this.words[0] = -this.words[0], this.negative = 1;
        else
          for (var a = 0;a < this.length && this.words[a] < 0; a++)
            this.words[a] += 67108864, this.words[a + 1] -= 1;
        return this.strip();
      }, f.prototype.addn = function(i) {
        return this.clone().iaddn(i);
      }, f.prototype.subn = function(i) {
        return this.clone().isubn(i);
      }, f.prototype.iabs = function() {
        return this.negative = 0, this;
      }, f.prototype.abs = function() {
        return this.clone().iabs();
      }, f.prototype._ishlnsubmul = function(i, a, h2) {
        var s = i.length + h2, u;
        this._expand(s);
        var c, b3 = 0;
        for (u = 0;u < i.length; u++) {
          c = (this.words[u + h2] | 0) + b3;
          var l = (i.words[u] | 0) * a;
          c -= l & 67108863, b3 = (c >> 26) - (l / 67108864 | 0), this.words[u + h2] = c & 67108863;
        }
        for (;u < this.length - h2; u++)
          c = (this.words[u + h2] | 0) + b3, b3 = c >> 26, this.words[u + h2] = c & 67108863;
        if (b3 === 0)
          return this.strip();
        for (r(b3 === -1), b3 = 0, u = 0;u < this.length; u++)
          c = -(this.words[u] | 0) + b3, b3 = c >> 26, this.words[u] = c & 67108863;
        return this.negative = 1, this.strip();
      }, f.prototype._wordDiv = function(i, a) {
        var h2 = this.length - i.length, s = this.clone(), u = i, c = u.words[u.length - 1] | 0, b3 = this._countBits(c);
        h2 = 26 - b3, h2 !== 0 && (u = u.ushln(h2), s.iushln(h2), c = u.words[u.length - 1] | 0);
        var l = s.length - u.length, n;
        if (a !== "mod") {
          n = new f(null), n.length = l + 1, n.words = new Array(n.length);
          for (var d = 0;d < n.length; d++)
            n.words[d] = 0;
        }
        var w = s.clone()._ishlnsubmul(u, 1, l);
        w.negative === 0 && (s = w, n && (n.words[l] = 1));
        for (var g = l - 1;g >= 0; g--) {
          var _4 = (s.words[u.length + g] | 0) * 67108864 + (s.words[u.length + g - 1] | 0);
          for (_4 = Math.min(_4 / c | 0, 67108863), s._ishlnsubmul(u, _4, g);s.negative !== 0; )
            _4--, s.negative = 0, s._ishlnsubmul(u, 1, g), s.isZero() || (s.negative ^= 1);
          n && (n.words[g] = _4);
        }
        return n && n.strip(), s.strip(), a !== "div" && h2 !== 0 && s.iushrn(h2), { div: n || null, mod: s };
      }, f.prototype.divmod = function(i, a, h2) {
        if (r(!i.isZero()), this.isZero())
          return { div: new f(0), mod: new f(0) };
        var s, u, c;
        return this.negative !== 0 && i.negative === 0 ? (c = this.neg().divmod(i, a), a !== "mod" && (s = c.div.neg()), a !== "div" && (u = c.mod.neg(), h2 && u.negative !== 0 && u.iadd(i)), { div: s, mod: u }) : this.negative === 0 && i.negative !== 0 ? (c = this.divmod(i.neg(), a), a !== "mod" && (s = c.div.neg()), { div: s, mod: c.mod }) : (this.negative & i.negative) !== 0 ? (c = this.neg().divmod(i.neg(), a), a !== "div" && (u = c.mod.neg(), h2 && u.negative !== 0 && u.isub(i)), { div: c.div, mod: u }) : i.length > this.length || this.cmp(i) < 0 ? { div: new f(0), mod: this } : i.length === 1 ? a === "div" ? { div: this.divn(i.words[0]), mod: null } : a === "mod" ? { div: null, mod: new f(this.modn(i.words[0])) } : { div: this.divn(i.words[0]), mod: new f(this.modn(i.words[0])) } : this._wordDiv(i, a);
      }, f.prototype.div = function(i) {
        return this.divmod(i, "div", false).div;
      }, f.prototype.mod = function(i) {
        return this.divmod(i, "mod", false).mod;
      }, f.prototype.umod = function(i) {
        return this.divmod(i, "mod", true).mod;
      }, f.prototype.divRound = function(i) {
        var a = this.divmod(i);
        if (a.mod.isZero())
          return a.div;
        var h2 = a.div.negative !== 0 ? a.mod.isub(i) : a.mod, s = i.ushrn(1), u = i.andln(1), c = h2.cmp(s);
        return c < 0 || u === 1 && c === 0 ? a.div : a.div.negative !== 0 ? a.div.isubn(1) : a.div.iaddn(1);
      }, f.prototype.modn = function(i) {
        r(i <= 67108863);
        for (var a = (1 << 26) % i, h2 = 0, s = this.length - 1;s >= 0; s--)
          h2 = (a * h2 + (this.words[s] | 0)) % i;
        return h2;
      }, f.prototype.idivn = function(i) {
        r(i <= 67108863);
        for (var a = 0, h2 = this.length - 1;h2 >= 0; h2--) {
          var s = (this.words[h2] | 0) + a * 67108864;
          this.words[h2] = s / i | 0, a = s % i;
        }
        return this.strip();
      }, f.prototype.divn = function(i) {
        return this.clone().idivn(i);
      }, f.prototype.egcd = function(i) {
        r(i.negative === 0), r(!i.isZero());
        var a = this, h2 = i.clone();
        a.negative !== 0 ? a = a.umod(i) : a = a.clone();
        for (var s = new f(1), u = new f(0), c = new f(0), b3 = new f(1), l = 0;a.isEven() && h2.isEven(); )
          a.iushrn(1), h2.iushrn(1), ++l;
        for (var n = h2.clone(), d = a.clone();!a.isZero(); ) {
          for (var w = 0, g = 1;(a.words[0] & g) === 0 && w < 26; ++w, g <<= 1)
            ;
          if (w > 0)
            for (a.iushrn(w);w-- > 0; )
              (s.isOdd() || u.isOdd()) && (s.iadd(n), u.isub(d)), s.iushrn(1), u.iushrn(1);
          for (var _4 = 0, A2 = 1;(h2.words[0] & A2) === 0 && _4 < 26; ++_4, A2 <<= 1)
            ;
          if (_4 > 0)
            for (h2.iushrn(_4);_4-- > 0; )
              (c.isOdd() || b3.isOdd()) && (c.iadd(n), b3.isub(d)), c.iushrn(1), b3.iushrn(1);
          a.cmp(h2) >= 0 ? (a.isub(h2), s.isub(c), u.isub(b3)) : (h2.isub(a), c.isub(s), b3.isub(u));
        }
        return { a: c, b: b3, gcd: h2.iushln(l) };
      }, f.prototype._invmp = function(i) {
        r(i.negative === 0), r(!i.isZero());
        var a = this, h2 = i.clone();
        a.negative !== 0 ? a = a.umod(i) : a = a.clone();
        for (var s = new f(1), u = new f(0), c = h2.clone();a.cmpn(1) > 0 && h2.cmpn(1) > 0; ) {
          for (var b3 = 0, l = 1;(a.words[0] & l) === 0 && b3 < 26; ++b3, l <<= 1)
            ;
          if (b3 > 0)
            for (a.iushrn(b3);b3-- > 0; )
              s.isOdd() && s.iadd(c), s.iushrn(1);
          for (var n = 0, d = 1;(h2.words[0] & d) === 0 && n < 26; ++n, d <<= 1)
            ;
          if (n > 0)
            for (h2.iushrn(n);n-- > 0; )
              u.isOdd() && u.iadd(c), u.iushrn(1);
          a.cmp(h2) >= 0 ? (a.isub(h2), s.isub(u)) : (h2.isub(a), u.isub(s));
        }
        var w;
        return a.cmpn(1) === 0 ? w = s : w = u, w.cmpn(0) < 0 && w.iadd(i), w;
      }, f.prototype.gcd = function(i) {
        if (this.isZero())
          return i.abs();
        if (i.isZero())
          return this.abs();
        var a = this.clone(), h2 = i.clone();
        a.negative = 0, h2.negative = 0;
        for (var s = 0;a.isEven() && h2.isEven(); s++)
          a.iushrn(1), h2.iushrn(1);
        do {
          for (;a.isEven(); )
            a.iushrn(1);
          for (;h2.isEven(); )
            h2.iushrn(1);
          var u = a.cmp(h2);
          if (u < 0) {
            var c = a;
            a = h2, h2 = c;
          } else if (u === 0 || h2.cmpn(1) === 0)
            break;
          a.isub(h2);
        } while (true);
        return h2.iushln(s);
      }, f.prototype.invm = function(i) {
        return this.egcd(i).a.umod(i);
      }, f.prototype.isEven = function() {
        return (this.words[0] & 1) === 0;
      }, f.prototype.isOdd = function() {
        return (this.words[0] & 1) === 1;
      }, f.prototype.andln = function(i) {
        return this.words[0] & i;
      }, f.prototype.bincn = function(i) {
        r(typeof i == "number");
        var a = i % 26, h2 = (i - a) / 26, s = 1 << a;
        if (this.length <= h2)
          return this._expand(h2 + 1), this.words[h2] |= s, this;
        for (var u = s, c = h2;u !== 0 && c < this.length; c++) {
          var b3 = this.words[c] | 0;
          b3 += u, u = b3 >>> 26, b3 &= 67108863, this.words[c] = b3;
        }
        return u !== 0 && (this.words[c] = u, this.length++), this;
      }, f.prototype.isZero = function() {
        return this.length === 1 && this.words[0] === 0;
      }, f.prototype.cmpn = function(i) {
        var a = i < 0;
        if (this.negative !== 0 && !a)
          return -1;
        if (this.negative === 0 && a)
          return 1;
        this.strip();
        var h2;
        if (this.length > 1)
          h2 = 1;
        else {
          a && (i = -i), r(i <= 67108863, "Number is too big");
          var s = this.words[0] | 0;
          h2 = s === i ? 0 : s < i ? -1 : 1;
        }
        return this.negative !== 0 ? -h2 | 0 : h2;
      }, f.prototype.cmp = function(i) {
        if (this.negative !== 0 && i.negative === 0)
          return -1;
        if (this.negative === 0 && i.negative !== 0)
          return 1;
        var a = this.ucmp(i);
        return this.negative !== 0 ? -a | 0 : a;
      }, f.prototype.ucmp = function(i) {
        if (this.length > i.length)
          return 1;
        if (this.length < i.length)
          return -1;
        for (var a = 0, h2 = this.length - 1;h2 >= 0; h2--) {
          var s = this.words[h2] | 0, u = i.words[h2] | 0;
          if (s !== u) {
            s < u ? a = -1 : s > u && (a = 1);
            break;
          }
        }
        return a;
      }, f.prototype.gtn = function(i) {
        return this.cmpn(i) === 1;
      }, f.prototype.gt = function(i) {
        return this.cmp(i) === 1;
      }, f.prototype.gten = function(i) {
        return this.cmpn(i) >= 0;
      }, f.prototype.gte = function(i) {
        return this.cmp(i) >= 0;
      }, f.prototype.ltn = function(i) {
        return this.cmpn(i) === -1;
      }, f.prototype.lt = function(i) {
        return this.cmp(i) === -1;
      }, f.prototype.lten = function(i) {
        return this.cmpn(i) <= 0;
      }, f.prototype.lte = function(i) {
        return this.cmp(i) <= 0;
      }, f.prototype.eqn = function(i) {
        return this.cmpn(i) === 0;
      }, f.prototype.eq = function(i) {
        return this.cmp(i) === 0;
      }, f.red = function(i) {
        return new P(i);
      }, f.prototype.toRed = function(i) {
        return r(!this.red, "Already a number in reduction context"), r(this.negative === 0, "red works only with positives"), i.convertTo(this)._forceRed(i);
      }, f.prototype.fromRed = function() {
        return r(this.red, "fromRed works only with numbers in reduction context"), this.red.convertFrom(this);
      }, f.prototype._forceRed = function(i) {
        return this.red = i, this;
      }, f.prototype.forceRed = function(i) {
        return r(!this.red, "Already a number in reduction context"), this._forceRed(i);
      }, f.prototype.redAdd = function(i) {
        return r(this.red, "redAdd works only with red numbers"), this.red.add(this, i);
      }, f.prototype.redIAdd = function(i) {
        return r(this.red, "redIAdd works only with red numbers"), this.red.iadd(this, i);
      }, f.prototype.redSub = function(i) {
        return r(this.red, "redSub works only with red numbers"), this.red.sub(this, i);
      }, f.prototype.redISub = function(i) {
        return r(this.red, "redISub works only with red numbers"), this.red.isub(this, i);
      }, f.prototype.redShl = function(i) {
        return r(this.red, "redShl works only with red numbers"), this.red.shl(this, i);
      }, f.prototype.redMul = function(i) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, i), this.red.mul(this, i);
      }, f.prototype.redIMul = function(i) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, i), this.red.imul(this, i);
      }, f.prototype.redSqr = function() {
        return r(this.red, "redSqr works only with red numbers"), this.red._verify1(this), this.red.sqr(this);
      }, f.prototype.redISqr = function() {
        return r(this.red, "redISqr works only with red numbers"), this.red._verify1(this), this.red.isqr(this);
      }, f.prototype.redSqrt = function() {
        return r(this.red, "redSqrt works only with red numbers"), this.red._verify1(this), this.red.sqrt(this);
      }, f.prototype.redInvm = function() {
        return r(this.red, "redInvm works only with red numbers"), this.red._verify1(this), this.red.invm(this);
      }, f.prototype.redNeg = function() {
        return r(this.red, "redNeg works only with red numbers"), this.red._verify1(this), this.red.neg(this);
      }, f.prototype.redPow = function(i) {
        return r(this.red && !i.red, "redPow(normalNum)"), this.red._verify1(this), this.red.pow(this, i);
      };
      var we = { k256: null, p224: null, p192: null, p25519: null };
      function ye(v, i) {
        this.name = v, this.p = new f(i, 16), this.n = this.p.bitLength(), this.k = new f(1).iushln(this.n).isub(this.p), this.tmp = this._tmp();
      }
      ye.prototype._tmp = function() {
        var i = new f(null);
        return i.words = new Array(Math.ceil(this.n / 13)), i;
      }, ye.prototype.ireduce = function(i) {
        var a = i, h2;
        do
          this.split(a, this.tmp), a = this.imulK(a), a = a.iadd(this.tmp), h2 = a.bitLength();
        while (h2 > this.n);
        var s = h2 < this.n ? -1 : a.ucmp(this.p);
        return s === 0 ? (a.words[0] = 0, a.length = 1) : s > 0 ? a.isub(this.p) : a.strip !== undefined ? a.strip() : a._strip(), a;
      }, ye.prototype.split = function(i, a) {
        i.iushrn(this.n, 0, a);
      }, ye.prototype.imulK = function(i) {
        return i.imul(this.k);
      };
      function xe() {
        ye.call(this, "k256", "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f");
      }
      o(xe, ye), xe.prototype.split = function(i, a) {
        for (var h2 = 4194303, s = Math.min(i.length, 9), u = 0;u < s; u++)
          a.words[u] = i.words[u];
        if (a.length = s, i.length <= 9) {
          i.words[0] = 0, i.length = 1;
          return;
        }
        var c = i.words[9];
        for (a.words[a.length++] = c & h2, u = 10;u < i.length; u++) {
          var b3 = i.words[u] | 0;
          i.words[u - 10] = (b3 & h2) << 4 | c >>> 22, c = b3;
        }
        c >>>= 22, i.words[u - 10] = c, c === 0 && i.length > 10 ? i.length -= 10 : i.length -= 9;
      }, xe.prototype.imulK = function(i) {
        i.words[i.length] = 0, i.words[i.length + 1] = 0, i.length += 2;
        for (var a = 0, h2 = 0;h2 < i.length; h2++) {
          var s = i.words[h2] | 0;
          a += s * 977, i.words[h2] = a & 67108863, a = s * 64 + (a / 67108864 | 0);
        }
        return i.words[i.length - 1] === 0 && (i.length--, i.words[i.length - 1] === 0 && i.length--), i;
      };
      function Re() {
        ye.call(this, "p224", "ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001");
      }
      o(Re, ye);
      function Ee() {
        ye.call(this, "p192", "ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff");
      }
      o(Ee, ye);
      function Ae() {
        ye.call(this, "25519", "7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed");
      }
      o(Ae, ye), Ae.prototype.imulK = function(i) {
        for (var a = 0, h2 = 0;h2 < i.length; h2++) {
          var s = (i.words[h2] | 0) * 19 + a, u = s & 67108863;
          s >>>= 26, i.words[h2] = u, a = s;
        }
        return a !== 0 && (i.words[i.length++] = a), i;
      }, f._prime = function(i) {
        if (we[i])
          return we[i];
        var a;
        if (i === "k256")
          a = new xe;
        else if (i === "p224")
          a = new Re;
        else if (i === "p192")
          a = new Ee;
        else if (i === "p25519")
          a = new Ae;
        else
          throw new Error("Unknown prime " + i);
        return we[i] = a, a;
      };
      function P(v) {
        if (typeof v == "string") {
          var i = f._prime(v);
          this.m = i.p, this.prime = i;
        } else
          r(v.gtn(1), "modulus must be greater than 1"), this.m = v, this.prime = null;
      }
      P.prototype._verify1 = function(i) {
        r(i.negative === 0, "red works only with positives"), r(i.red, "red works only with red numbers");
      }, P.prototype._verify2 = function(i, a) {
        r((i.negative | a.negative) === 0, "red works only with positives"), r(i.red && i.red === a.red, "red works only with red numbers");
      }, P.prototype.imod = function(i) {
        return this.prime ? this.prime.ireduce(i)._forceRed(this) : i.umod(this.m)._forceRed(this);
      }, P.prototype.neg = function(i) {
        return i.isZero() ? i.clone() : this.m.sub(i)._forceRed(this);
      }, P.prototype.add = function(i, a) {
        this._verify2(i, a);
        var h2 = i.add(a);
        return h2.cmp(this.m) >= 0 && h2.isub(this.m), h2._forceRed(this);
      }, P.prototype.iadd = function(i, a) {
        this._verify2(i, a);
        var h2 = i.iadd(a);
        return h2.cmp(this.m) >= 0 && h2.isub(this.m), h2;
      }, P.prototype.sub = function(i, a) {
        this._verify2(i, a);
        var h2 = i.sub(a);
        return h2.cmpn(0) < 0 && h2.iadd(this.m), h2._forceRed(this);
      }, P.prototype.isub = function(i, a) {
        this._verify2(i, a);
        var h2 = i.isub(a);
        return h2.cmpn(0) < 0 && h2.iadd(this.m), h2;
      }, P.prototype.shl = function(i, a) {
        return this._verify1(i), this.imod(i.ushln(a));
      }, P.prototype.imul = function(i, a) {
        return this._verify2(i, a), this.imod(i.imul(a));
      }, P.prototype.mul = function(i, a) {
        return this._verify2(i, a), this.imod(i.mul(a));
      }, P.prototype.isqr = function(i) {
        return this.imul(i, i.clone());
      }, P.prototype.sqr = function(i) {
        return this.mul(i, i);
      }, P.prototype.sqrt = function(i) {
        if (i.isZero())
          return i.clone();
        var a = this.m.andln(3);
        if (r(a % 2 === 1), a === 3) {
          var h2 = this.m.add(new f(1)).iushrn(2);
          return this.pow(i, h2);
        }
        for (var s = this.m.subn(1), u = 0;!s.isZero() && s.andln(1) === 0; )
          u++, s.iushrn(1);
        r(!s.isZero());
        var c = new f(1).toRed(this), b3 = c.redNeg(), l = this.m.subn(1).iushrn(1), n = this.m.bitLength();
        for (n = new f(2 * n * n).toRed(this);this.pow(n, l).cmp(b3) !== 0; )
          n.redIAdd(b3);
        for (var d = this.pow(n, s), w = this.pow(i, s.addn(1).iushrn(1)), g = this.pow(i, s), _4 = u;g.cmp(c) !== 0; ) {
          for (var A2 = g, R2 = 0;A2.cmp(c) !== 0; R2++)
            A2 = A2.redSqr();
          r(R2 < _4);
          var I = this.pow(d, new f(1).iushln(_4 - R2 - 1));
          w = w.redMul(I), d = I.redSqr(), g = g.redMul(d), _4 = R2;
        }
        return w;
      }, P.prototype.invm = function(i) {
        var a = i._invmp(this.m);
        return a.negative !== 0 ? (a.negative = 0, this.imod(a).redNeg()) : this.imod(a);
      }, P.prototype.pow = function(i, a) {
        if (a.isZero())
          return new f(1).toRed(this);
        if (a.cmpn(1) === 0)
          return i.clone();
        var h2 = 4, s = new Array(1 << h2);
        s[0] = new f(1).toRed(this), s[1] = i;
        for (var u = 2;u < s.length; u++)
          s[u] = this.mul(s[u - 1], i);
        var c = s[0], b3 = 0, l = 0, n = a.bitLength() % 26;
        for (n === 0 && (n = 26), u = a.length - 1;u >= 0; u--) {
          for (var d = a.words[u], w = n - 1;w >= 0; w--) {
            var g = d >> w & 1;
            if (c !== s[0] && (c = this.sqr(c)), g === 0 && b3 === 0) {
              l = 0;
              continue;
            }
            b3 <<= 1, b3 |= g, l++, !(l !== h2 && (u !== 0 || w !== 0)) && (c = this.mul(c, s[b3]), l = 0, b3 = 0);
          }
          n = 26;
        }
        return c;
      }, P.prototype.convertTo = function(i) {
        var a = i.umod(this.m);
        return a === i ? a.clone() : a;
      }, P.prototype.convertFrom = function(i) {
        var a = i.clone();
        return a.red = null, a;
      }, f.mont = function(i) {
        return new Se(i);
      };
      function Se(v) {
        P.call(this, v), this.shift = this.m.bitLength(), this.shift % 26 !== 0 && (this.shift += 26 - this.shift % 26), this.r = new f(1).iushln(this.shift), this.r2 = this.imod(this.r.sqr()), this.rinv = this.r._invmp(this.m), this.minv = this.rinv.mul(this.r).isubn(1).div(this.m), this.minv = this.minv.umod(this.r), this.minv = this.r.sub(this.minv);
      }
      o(Se, P), Se.prototype.convertTo = function(i) {
        return this.imod(i.ushln(this.shift));
      }, Se.prototype.convertFrom = function(i) {
        var a = this.imod(i.mul(this.rinv));
        return a.red = null, a;
      }, Se.prototype.imul = function(i, a) {
        if (i.isZero() || a.isZero())
          return i.words[0] = 0, i.length = 1, i;
        var h2 = i.imul(a), s = h2.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), u = h2.isub(s).iushrn(this.shift), c = u;
        return u.cmp(this.m) >= 0 ? c = u.isub(this.m) : u.cmpn(0) < 0 && (c = u.iadd(this.m)), c._forceRed(this);
      }, Se.prototype.mul = function(i, a) {
        if (i.isZero() || a.isZero())
          return new f(0)._forceRed(this);
        var h2 = i.mul(a), s = h2.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), u = h2.isub(s).iushrn(this.shift), c = u;
        return u.cmp(this.m) >= 0 ? c = u.isub(this.m) : u.cmpn(0) < 0 && (c = u.iadd(this.m)), c._forceRed(this);
      }, Se.prototype.invm = function(i) {
        var a = this.imod(i._invmp(this.m).mul(this.r2));
        return a._forceRed(this);
      };
    })(typeof yd > "u" || yd, L3);
  });
  P3 = T2((wL, D3) => {
    var bq = o0(), mq = N3();
    D3.exports = function(e) {
      return new Zn(e);
    };
    var hr = { secp256k1: { name: "secp256k1", byteLength: 32 }, secp224r1: { name: "p224", byteLength: 28 }, prime256v1: { name: "p256", byteLength: 32 }, prime192v1: { name: "p192", byteLength: 24 }, ed25519: { name: "ed25519", byteLength: 32 }, secp384r1: { name: "p384", byteLength: 48 }, secp521r1: { name: "p521", byteLength: 66 } };
    hr.p224 = hr.secp224r1;
    hr.p256 = hr.secp256r1 = hr.prime256v1;
    hr.p192 = hr.secp192r1 = hr.prime192v1;
    hr.p384 = hr.secp384r1;
    hr.p521 = hr.secp521r1;
    function Zn(t) {
      this.curveType = hr[t], this.curveType || (this.curveType = { name: t }), this.curve = new bq.ec(this.curveType.name), this.keys = undefined;
    }
    Zn.prototype.generateKeys = function(t, e) {
      return this.keys = this.curve.genKeyPair(), this.getPublicKey(t, e);
    };
    Zn.prototype.computeSecret = function(t, e, r) {
      e = e || "utf8", Buffer.isBuffer(t) || (t = new Buffer(t, e));
      var o = this.curve.keyFromPublic(t).getPublic(), f = o.mul(this.keys.getPrivate()).getX();
      return wd(f, r, this.curveType.byteLength);
    };
    Zn.prototype.getPublicKey = function(t, e) {
      var r = this.keys.getPublic(e === "compressed", true);
      return e === "hybrid" && (r[r.length - 1] % 2 ? r[0] = 7 : r[0] = 6), wd(r, t);
    };
    Zn.prototype.getPrivateKey = function(t) {
      return wd(this.keys.getPrivate(), t);
    };
    Zn.prototype.setPublicKey = function(t, e) {
      return e = e || "utf8", Buffer.isBuffer(t) || (t = new Buffer(t, e)), this.keys._importPublic(t), this;
    };
    Zn.prototype.setPrivateKey = function(t, e) {
      e = e || "utf8", Buffer.isBuffer(t) || (t = new Buffer(t, e));
      var r = new mq(t);
      return r = r.toString(16), this.keys = this.curve.genKeyPair(), this.keys._importPrivate(r), this;
    };
    function wd(t, e, r) {
      Array.isArray(t) || (t = t.toArray());
      var o = new Buffer(t);
      if (r && o.length < r) {
        var f = new Buffer(r - o.length);
        f.fill(0), o = Buffer.concat([f, o]);
      }
      return e ? o.toString(e) : o;
    }
  });
  _d = T2((ML, C3) => {
    var gq = bf(), Md = Te().Buffer;
    C3.exports = function(t, e) {
      for (var r = Md.alloc(0), o = 0, f;r.length < e; )
        f = yq(o++), r = Md.concat([r, gq("sha1").update(t).update(f).digest()]);
      return r.slice(0, e);
    };
    function yq(t) {
      var e = Md.allocUnsafe(4);
      return e.writeUInt32BE(t, 0), e;
    }
  });
  xd = T2((_L, O3) => {
    O3.exports = function(e, r) {
      for (var o = e.length, f = -1;++f < o; )
        e[f] ^= r[f];
      return e;
    };
  });
  w0 = T2((F3, Sd) => {
    (function(t, e) {
      function r(v, i) {
        if (!v)
          throw new Error(i || "Assertion failed");
      }
      function o(v, i) {
        v.super_ = i;
        var a = function() {
        };
        a.prototype = i.prototype, v.prototype = new a, v.prototype.constructor = v;
      }
      function f(v, i, a) {
        if (f.isBN(v))
          return v;
        this.negative = 0, this.words = null, this.length = 0, this.red = null, v !== null && ((i === "le" || i === "be") && (a = i, i = 10), this._init(v || 0, i || 10, a || "be"));
      }
      typeof t == "object" ? t.exports = f : e.BN = f, f.BN = f, f.wordSize = 26;
      var p;
      try {
        typeof window < "u" && typeof window.Buffer < "u" ? p = window.Buffer : p = ji().Buffer;
      } catch {
      }
      f.isBN = function(i) {
        return i instanceof f ? true : i !== null && typeof i == "object" && i.constructor.wordSize === f.wordSize && Array.isArray(i.words);
      }, f.max = function(i, a) {
        return i.cmp(a) > 0 ? i : a;
      }, f.min = function(i, a) {
        return i.cmp(a) < 0 ? i : a;
      }, f.prototype._init = function(i, a, h2) {
        if (typeof i == "number")
          return this._initNumber(i, a, h2);
        if (typeof i == "object")
          return this._initArray(i, a, h2);
        a === "hex" && (a = 16), r(a === (a | 0) && a >= 2 && a <= 36), i = i.toString().replace(/\s+/g, "");
        var s = 0;
        i[0] === "-" && (s++, this.negative = 1), s < i.length && (a === 16 ? this._parseHex(i, s, h2) : (this._parseBase(i, a, s), h2 === "le" && this._initArray(this.toArray(), a, h2)));
      }, f.prototype._initNumber = function(i, a, h2) {
        i < 0 && (this.negative = 1, i = -i), i < 67108864 ? (this.words = [i & 67108863], this.length = 1) : i < 4503599627370496 ? (this.words = [i & 67108863, i / 67108864 & 67108863], this.length = 2) : (r(i < 9007199254740992), this.words = [i & 67108863, i / 67108864 & 67108863, 1], this.length = 3), h2 === "le" && this._initArray(this.toArray(), a, h2);
      }, f.prototype._initArray = function(i, a, h2) {
        if (r(typeof i.length == "number"), i.length <= 0)
          return this.words = [0], this.length = 1, this;
        this.length = Math.ceil(i.length / 3), this.words = new Array(this.length);
        for (var s = 0;s < this.length; s++)
          this.words[s] = 0;
        var u, c, b3 = 0;
        if (h2 === "be")
          for (s = i.length - 1, u = 0;s >= 0; s -= 3)
            c = i[s] | i[s - 1] << 8 | i[s - 2] << 16, this.words[u] |= c << b3 & 67108863, this.words[u + 1] = c >>> 26 - b3 & 67108863, b3 += 24, b3 >= 26 && (b3 -= 26, u++);
        else if (h2 === "le")
          for (s = 0, u = 0;s < i.length; s += 3)
            c = i[s] | i[s + 1] << 8 | i[s + 2] << 16, this.words[u] |= c << b3 & 67108863, this.words[u + 1] = c >>> 26 - b3 & 67108863, b3 += 24, b3 >= 26 && (b3 -= 26, u++);
        return this.strip();
      };
      function m2(v, i) {
        var a = v.charCodeAt(i);
        return a >= 65 && a <= 70 ? a - 55 : a >= 97 && a <= 102 ? a - 87 : a - 48 & 15;
      }
      function y3(v, i, a) {
        var h2 = m2(v, a);
        return a - 1 >= i && (h2 |= m2(v, a - 1) << 4), h2;
      }
      f.prototype._parseHex = function(i, a, h2) {
        this.length = Math.ceil((i.length - a) / 6), this.words = new Array(this.length);
        for (var s = 0;s < this.length; s++)
          this.words[s] = 0;
        var u = 0, c = 0, b3;
        if (h2 === "be")
          for (s = i.length - 1;s >= a; s -= 2)
            b3 = y3(i, a, s) << u, this.words[c] |= b3 & 67108863, u >= 18 ? (u -= 18, c += 1, this.words[c] |= b3 >>> 26) : u += 8;
        else {
          var l = i.length - a;
          for (s = l % 2 === 0 ? a + 1 : a;s < i.length; s += 2)
            b3 = y3(i, a, s) << u, this.words[c] |= b3 & 67108863, u >= 18 ? (u -= 18, c += 1, this.words[c] |= b3 >>> 26) : u += 8;
        }
        this.strip();
      };
      function M(v, i, a, h2) {
        for (var s = 0, u = Math.min(v.length, a), c = i;c < u; c++) {
          var b3 = v.charCodeAt(c) - 48;
          s *= h2, b3 >= 49 ? s += b3 - 49 + 10 : b3 >= 17 ? s += b3 - 17 + 10 : s += b3;
        }
        return s;
      }
      f.prototype._parseBase = function(i, a, h2) {
        this.words = [0], this.length = 1;
        for (var s = 0, u = 1;u <= 67108863; u *= a)
          s++;
        s--, u = u / a | 0;
        for (var c = i.length - h2, b3 = c % s, l = Math.min(c, c - b3) + h2, n = 0, d = h2;d < l; d += s)
          n = M(i, d, d + s, a), this.imuln(u), this.words[0] + n < 67108864 ? this.words[0] += n : this._iaddn(n);
        if (b3 !== 0) {
          var w = 1;
          for (n = M(i, d, i.length, a), d = 0;d < b3; d++)
            w *= a;
          this.imuln(w), this.words[0] + n < 67108864 ? this.words[0] += n : this._iaddn(n);
        }
        this.strip();
      }, f.prototype.copy = function(i) {
        i.words = new Array(this.length);
        for (var a = 0;a < this.length; a++)
          i.words[a] = this.words[a];
        i.length = this.length, i.negative = this.negative, i.red = this.red;
      }, f.prototype.clone = function() {
        var i = new f(null);
        return this.copy(i), i;
      }, f.prototype._expand = function(i) {
        for (;this.length < i; )
          this.words[this.length++] = 0;
        return this;
      }, f.prototype.strip = function() {
        for (;this.length > 1 && this.words[this.length - 1] === 0; )
          this.length--;
        return this._normSign();
      }, f.prototype._normSign = function() {
        return this.length === 1 && this.words[0] === 0 && (this.negative = 0), this;
      }, f.prototype.inspect = function() {
        return (this.red ? "<BN-R: " : "<BN: ") + this.toString(16) + ">";
      };
      var x = ["", "0", "00", "000", "0000", "00000", "000000", "0000000", "00000000", "000000000", "0000000000", "00000000000", "000000000000", "0000000000000", "00000000000000", "000000000000000", "0000000000000000", "00000000000000000", "000000000000000000", "0000000000000000000", "00000000000000000000", "000000000000000000000", "0000000000000000000000", "00000000000000000000000", "000000000000000000000000", "0000000000000000000000000"], S = [0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5], E2 = [0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 1e7, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176];
      f.prototype.toString = function(i, a) {
        i = i || 10, a = a | 0 || 1;
        var h2;
        if (i === 16 || i === "hex") {
          h2 = "";
          for (var s = 0, u = 0, c = 0;c < this.length; c++) {
            var b3 = this.words[c], l = ((b3 << s | u) & 16777215).toString(16);
            u = b3 >>> 24 - s & 16777215, u !== 0 || c !== this.length - 1 ? h2 = x[6 - l.length] + l + h2 : h2 = l + h2, s += 2, s >= 26 && (s -= 26, c--);
          }
          for (u !== 0 && (h2 = u.toString(16) + h2);h2.length % a !== 0; )
            h2 = "0" + h2;
          return this.negative !== 0 && (h2 = "-" + h2), h2;
        }
        if (i === (i | 0) && i >= 2 && i <= 36) {
          var n = S[i], d = E2[i];
          h2 = "";
          var w = this.clone();
          for (w.negative = 0;!w.isZero(); ) {
            var g = w.modn(d).toString(i);
            w = w.idivn(d), w.isZero() ? h2 = g + h2 : h2 = x[n - g.length] + g + h2;
          }
          for (this.isZero() && (h2 = "0" + h2);h2.length % a !== 0; )
            h2 = "0" + h2;
          return this.negative !== 0 && (h2 = "-" + h2), h2;
        }
        r(false, "Base should be between 2 and 36");
      }, f.prototype.toNumber = function() {
        var i = this.words[0];
        return this.length === 2 ? i += this.words[1] * 67108864 : this.length === 3 && this.words[2] === 1 ? i += 4503599627370496 + this.words[1] * 67108864 : this.length > 2 && r(false, "Number can only safely store up to 53 bits"), this.negative !== 0 ? -i : i;
      }, f.prototype.toJSON = function() {
        return this.toString(16);
      }, f.prototype.toBuffer = function(i, a) {
        return r(typeof p < "u"), this.toArrayLike(p, i, a);
      }, f.prototype.toArray = function(i, a) {
        return this.toArrayLike(Array, i, a);
      }, f.prototype.toArrayLike = function(i, a, h2) {
        var s = this.byteLength(), u = h2 || Math.max(1, s);
        r(s <= u, "byte array longer than desired length"), r(u > 0, "Requested array length <= 0"), this.strip();
        var c = a === "le", b3 = new i(u), l, n, d = this.clone();
        if (c) {
          for (n = 0;!d.isZero(); n++)
            l = d.andln(255), d.iushrn(8), b3[n] = l;
          for (;n < u; n++)
            b3[n] = 0;
        } else {
          for (n = 0;n < u - s; n++)
            b3[n] = 0;
          for (n = 0;!d.isZero(); n++)
            l = d.andln(255), d.iushrn(8), b3[u - n - 1] = l;
        }
        return b3;
      }, Math.clz32 ? f.prototype._countBits = function(i) {
        return 32 - Math.clz32(i);
      } : f.prototype._countBits = function(i) {
        var a = i, h2 = 0;
        return a >= 4096 && (h2 += 13, a >>>= 13), a >= 64 && (h2 += 7, a >>>= 7), a >= 8 && (h2 += 4, a >>>= 4), a >= 2 && (h2 += 2, a >>>= 2), h2 + a;
      }, f.prototype._zeroBits = function(i) {
        if (i === 0)
          return 26;
        var a = i, h2 = 0;
        return (a & 8191) === 0 && (h2 += 13, a >>>= 13), (a & 127) === 0 && (h2 += 7, a >>>= 7), (a & 15) === 0 && (h2 += 4, a >>>= 4), (a & 3) === 0 && (h2 += 2, a >>>= 2), (a & 1) === 0 && h2++, h2;
      }, f.prototype.bitLength = function() {
        var i = this.words[this.length - 1], a = this._countBits(i);
        return (this.length - 1) * 26 + a;
      };
      function B(v) {
        for (var i = new Array(v.bitLength()), a = 0;a < i.length; a++) {
          var h2 = a / 26 | 0, s = a % 26;
          i[a] = (v.words[h2] & 1 << s) >>> s;
        }
        return i;
      }
      f.prototype.zeroBits = function() {
        if (this.isZero())
          return 0;
        for (var i = 0, a = 0;a < this.length; a++) {
          var h2 = this._zeroBits(this.words[a]);
          if (i += h2, h2 !== 26)
            break;
        }
        return i;
      }, f.prototype.byteLength = function() {
        return Math.ceil(this.bitLength() / 8);
      }, f.prototype.toTwos = function(i) {
        return this.negative !== 0 ? this.abs().inotn(i).iaddn(1) : this.clone();
      }, f.prototype.fromTwos = function(i) {
        return this.testn(i - 1) ? this.notn(i).iaddn(1).ineg() : this.clone();
      }, f.prototype.isNeg = function() {
        return this.negative !== 0;
      }, f.prototype.neg = function() {
        return this.clone().ineg();
      }, f.prototype.ineg = function() {
        return this.isZero() || (this.negative ^= 1), this;
      }, f.prototype.iuor = function(i) {
        for (;this.length < i.length; )
          this.words[this.length++] = 0;
        for (var a = 0;a < i.length; a++)
          this.words[a] = this.words[a] | i.words[a];
        return this.strip();
      }, f.prototype.ior = function(i) {
        return r((this.negative | i.negative) === 0), this.iuor(i);
      }, f.prototype.or = function(i) {
        return this.length > i.length ? this.clone().ior(i) : i.clone().ior(this);
      }, f.prototype.uor = function(i) {
        return this.length > i.length ? this.clone().iuor(i) : i.clone().iuor(this);
      }, f.prototype.iuand = function(i) {
        var a;
        this.length > i.length ? a = i : a = this;
        for (var h2 = 0;h2 < a.length; h2++)
          this.words[h2] = this.words[h2] & i.words[h2];
        return this.length = a.length, this.strip();
      }, f.prototype.iand = function(i) {
        return r((this.negative | i.negative) === 0), this.iuand(i);
      }, f.prototype.and = function(i) {
        return this.length > i.length ? this.clone().iand(i) : i.clone().iand(this);
      }, f.prototype.uand = function(i) {
        return this.length > i.length ? this.clone().iuand(i) : i.clone().iuand(this);
      }, f.prototype.iuxor = function(i) {
        var a, h2;
        this.length > i.length ? (a = this, h2 = i) : (a = i, h2 = this);
        for (var s = 0;s < h2.length; s++)
          this.words[s] = a.words[s] ^ h2.words[s];
        if (this !== a)
          for (;s < a.length; s++)
            this.words[s] = a.words[s];
        return this.length = a.length, this.strip();
      }, f.prototype.ixor = function(i) {
        return r((this.negative | i.negative) === 0), this.iuxor(i);
      }, f.prototype.xor = function(i) {
        return this.length > i.length ? this.clone().ixor(i) : i.clone().ixor(this);
      }, f.prototype.uxor = function(i) {
        return this.length > i.length ? this.clone().iuxor(i) : i.clone().iuxor(this);
      }, f.prototype.inotn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = Math.ceil(i / 26) | 0, h2 = i % 26;
        this._expand(a), h2 > 0 && a--;
        for (var s = 0;s < a; s++)
          this.words[s] = ~this.words[s] & 67108863;
        return h2 > 0 && (this.words[s] = ~this.words[s] & 67108863 >> 26 - h2), this.strip();
      }, f.prototype.notn = function(i) {
        return this.clone().inotn(i);
      }, f.prototype.setn = function(i, a) {
        r(typeof i == "number" && i >= 0);
        var h2 = i / 26 | 0, s = i % 26;
        return this._expand(h2 + 1), a ? this.words[h2] = this.words[h2] | 1 << s : this.words[h2] = this.words[h2] & ~(1 << s), this.strip();
      }, f.prototype.iadd = function(i) {
        var a;
        if (this.negative !== 0 && i.negative === 0)
          return this.negative = 0, a = this.isub(i), this.negative ^= 1, this._normSign();
        if (this.negative === 0 && i.negative !== 0)
          return i.negative = 0, a = this.isub(i), i.negative = 1, a._normSign();
        var h2, s;
        this.length > i.length ? (h2 = this, s = i) : (h2 = i, s = this);
        for (var u = 0, c = 0;c < s.length; c++)
          a = (h2.words[c] | 0) + (s.words[c] | 0) + u, this.words[c] = a & 67108863, u = a >>> 26;
        for (;u !== 0 && c < h2.length; c++)
          a = (h2.words[c] | 0) + u, this.words[c] = a & 67108863, u = a >>> 26;
        if (this.length = h2.length, u !== 0)
          this.words[this.length] = u, this.length++;
        else if (h2 !== this)
          for (;c < h2.length; c++)
            this.words[c] = h2.words[c];
        return this;
      }, f.prototype.add = function(i) {
        var a;
        return i.negative !== 0 && this.negative === 0 ? (i.negative = 0, a = this.sub(i), i.negative ^= 1, a) : i.negative === 0 && this.negative !== 0 ? (this.negative = 0, a = i.sub(this), this.negative = 1, a) : this.length > i.length ? this.clone().iadd(i) : i.clone().iadd(this);
      }, f.prototype.isub = function(i) {
        if (i.negative !== 0) {
          i.negative = 0;
          var a = this.iadd(i);
          return i.negative = 1, a._normSign();
        } else if (this.negative !== 0)
          return this.negative = 0, this.iadd(i), this.negative = 1, this._normSign();
        var h2 = this.cmp(i);
        if (h2 === 0)
          return this.negative = 0, this.length = 1, this.words[0] = 0, this;
        var s, u;
        h2 > 0 ? (s = this, u = i) : (s = i, u = this);
        for (var c = 0, b3 = 0;b3 < u.length; b3++)
          a = (s.words[b3] | 0) - (u.words[b3] | 0) + c, c = a >> 26, this.words[b3] = a & 67108863;
        for (;c !== 0 && b3 < s.length; b3++)
          a = (s.words[b3] | 0) + c, c = a >> 26, this.words[b3] = a & 67108863;
        if (c === 0 && b3 < s.length && s !== this)
          for (;b3 < s.length; b3++)
            this.words[b3] = s.words[b3];
        return this.length = Math.max(this.length, b3), s !== this && (this.negative = 1), this.strip();
      }, f.prototype.sub = function(i) {
        return this.clone().isub(i);
      };
      function q2(v, i, a) {
        a.negative = i.negative ^ v.negative;
        var h2 = v.length + i.length | 0;
        a.length = h2, h2 = h2 - 1 | 0;
        var s = v.words[0] | 0, u = i.words[0] | 0, c = s * u, b3 = c & 67108863, l = c / 67108864 | 0;
        a.words[0] = b3;
        for (var n = 1;n < h2; n++) {
          for (var d = l >>> 26, w = l & 67108863, g = Math.min(n, i.length - 1), _4 = Math.max(0, n - v.length + 1);_4 <= g; _4++) {
            var A2 = n - _4 | 0;
            s = v.words[A2] | 0, u = i.words[_4] | 0, c = s * u + w, d += c / 67108864 | 0, w = c & 67108863;
          }
          a.words[n] = w | 0, l = d | 0;
        }
        return l !== 0 ? a.words[n] = l | 0 : a.length--, a.strip();
      }
      var L2 = function(i, a, h2) {
        var s = i.words, u = a.words, c = h2.words, b3 = 0, l, n, d, w = s[0] | 0, g = w & 8191, _4 = w >>> 13, A2 = s[1] | 0, R2 = A2 & 8191, I = A2 >>> 13, Me = s[2] | 0, k = Me & 8191, D2 = Me >>> 13, nt = s[3] | 0, C2 = nt & 8191, O = nt >>> 13, vt = s[4] | 0, F = vt & 8191, U = vt >>> 13, bt = s[5] | 0, z2 = bt & 8191, H = bt >>> 13, mt = s[6] | 0, W = mt & 8191, K = mt >>> 13, gt = s[7] | 0, j = gt & 8191, Z = gt >>> 13, yt = s[8] | 0, V = yt & 8191, $ = yt >>> 13, wt = s[9] | 0, G = wt & 8191, Y = wt >>> 13, Mt = u[0] | 0, X = Mt & 8191, J = Mt >>> 13, _t = u[1] | 0, Q = _t & 8191, ee = _t >>> 13, xt = u[2] | 0, te = xt & 8191, re = xt >>> 13, St = u[3] | 0, ie = St & 8191, ne = St >>> 13, Et = u[4] | 0, fe = Et & 8191, ae = Et >>> 13, At = u[5] | 0, oe = At & 8191, se = At >>> 13, Rt = u[6] | 0, he = Rt & 8191, ue = Rt >>> 13, Bt = u[7] | 0, le = Bt & 8191, de = Bt >>> 13, qt = u[8] | 0, ce = qt & 8191, pe = qt >>> 13, It = u[9] | 0, ve = It & 8191, be = It >>> 13;
        h2.negative = i.negative ^ a.negative, h2.length = 19, l = Math.imul(g, X), n = Math.imul(g, J), n = n + Math.imul(_4, X) | 0, d = Math.imul(_4, J);
        var ft = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (ft >>> 26) | 0, ft &= 67108863, l = Math.imul(R2, X), n = Math.imul(R2, J), n = n + Math.imul(I, X) | 0, d = Math.imul(I, J), l = l + Math.imul(g, Q) | 0, n = n + Math.imul(g, ee) | 0, n = n + Math.imul(_4, Q) | 0, d = d + Math.imul(_4, ee) | 0;
        var Be = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Be >>> 26) | 0, Be &= 67108863, l = Math.imul(k, X), n = Math.imul(k, J), n = n + Math.imul(D2, X) | 0, d = Math.imul(D2, J), l = l + Math.imul(R2, Q) | 0, n = n + Math.imul(R2, ee) | 0, n = n + Math.imul(I, Q) | 0, d = d + Math.imul(I, ee) | 0, l = l + Math.imul(g, te) | 0, n = n + Math.imul(g, re) | 0, n = n + Math.imul(_4, te) | 0, d = d + Math.imul(_4, re) | 0;
        var qe = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (qe >>> 26) | 0, qe &= 67108863, l = Math.imul(C2, X), n = Math.imul(C2, J), n = n + Math.imul(O, X) | 0, d = Math.imul(O, J), l = l + Math.imul(k, Q) | 0, n = n + Math.imul(k, ee) | 0, n = n + Math.imul(D2, Q) | 0, d = d + Math.imul(D2, ee) | 0, l = l + Math.imul(R2, te) | 0, n = n + Math.imul(R2, re) | 0, n = n + Math.imul(I, te) | 0, d = d + Math.imul(I, re) | 0, l = l + Math.imul(g, ie) | 0, n = n + Math.imul(g, ne) | 0, n = n + Math.imul(_4, ie) | 0, d = d + Math.imul(_4, ne) | 0;
        var ze = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (ze >>> 26) | 0, ze &= 67108863, l = Math.imul(F, X), n = Math.imul(F, J), n = n + Math.imul(U, X) | 0, d = Math.imul(U, J), l = l + Math.imul(C2, Q) | 0, n = n + Math.imul(C2, ee) | 0, n = n + Math.imul(O, Q) | 0, d = d + Math.imul(O, ee) | 0, l = l + Math.imul(k, te) | 0, n = n + Math.imul(k, re) | 0, n = n + Math.imul(D2, te) | 0, d = d + Math.imul(D2, re) | 0, l = l + Math.imul(R2, ie) | 0, n = n + Math.imul(R2, ne) | 0, n = n + Math.imul(I, ie) | 0, d = d + Math.imul(I, ne) | 0, l = l + Math.imul(g, fe) | 0, n = n + Math.imul(g, ae) | 0, n = n + Math.imul(_4, fe) | 0, d = d + Math.imul(_4, ae) | 0;
        var He = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (He >>> 26) | 0, He &= 67108863, l = Math.imul(z2, X), n = Math.imul(z2, J), n = n + Math.imul(H, X) | 0, d = Math.imul(H, J), l = l + Math.imul(F, Q) | 0, n = n + Math.imul(F, ee) | 0, n = n + Math.imul(U, Q) | 0, d = d + Math.imul(U, ee) | 0, l = l + Math.imul(C2, te) | 0, n = n + Math.imul(C2, re) | 0, n = n + Math.imul(O, te) | 0, d = d + Math.imul(O, re) | 0, l = l + Math.imul(k, ie) | 0, n = n + Math.imul(k, ne) | 0, n = n + Math.imul(D2, ie) | 0, d = d + Math.imul(D2, ne) | 0, l = l + Math.imul(R2, fe) | 0, n = n + Math.imul(R2, ae) | 0, n = n + Math.imul(I, fe) | 0, d = d + Math.imul(I, ae) | 0, l = l + Math.imul(g, oe) | 0, n = n + Math.imul(g, se) | 0, n = n + Math.imul(_4, oe) | 0, d = d + Math.imul(_4, se) | 0;
        var We = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (We >>> 26) | 0, We &= 67108863, l = Math.imul(W, X), n = Math.imul(W, J), n = n + Math.imul(K, X) | 0, d = Math.imul(K, J), l = l + Math.imul(z2, Q) | 0, n = n + Math.imul(z2, ee) | 0, n = n + Math.imul(H, Q) | 0, d = d + Math.imul(H, ee) | 0, l = l + Math.imul(F, te) | 0, n = n + Math.imul(F, re) | 0, n = n + Math.imul(U, te) | 0, d = d + Math.imul(U, re) | 0, l = l + Math.imul(C2, ie) | 0, n = n + Math.imul(C2, ne) | 0, n = n + Math.imul(O, ie) | 0, d = d + Math.imul(O, ne) | 0, l = l + Math.imul(k, fe) | 0, n = n + Math.imul(k, ae) | 0, n = n + Math.imul(D2, fe) | 0, d = d + Math.imul(D2, ae) | 0, l = l + Math.imul(R2, oe) | 0, n = n + Math.imul(R2, se) | 0, n = n + Math.imul(I, oe) | 0, d = d + Math.imul(I, se) | 0, l = l + Math.imul(g, he) | 0, n = n + Math.imul(g, ue) | 0, n = n + Math.imul(_4, he) | 0, d = d + Math.imul(_4, ue) | 0;
        var Ke = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ke >>> 26) | 0, Ke &= 67108863, l = Math.imul(j, X), n = Math.imul(j, J), n = n + Math.imul(Z, X) | 0, d = Math.imul(Z, J), l = l + Math.imul(W, Q) | 0, n = n + Math.imul(W, ee) | 0, n = n + Math.imul(K, Q) | 0, d = d + Math.imul(K, ee) | 0, l = l + Math.imul(z2, te) | 0, n = n + Math.imul(z2, re) | 0, n = n + Math.imul(H, te) | 0, d = d + Math.imul(H, re) | 0, l = l + Math.imul(F, ie) | 0, n = n + Math.imul(F, ne) | 0, n = n + Math.imul(U, ie) | 0, d = d + Math.imul(U, ne) | 0, l = l + Math.imul(C2, fe) | 0, n = n + Math.imul(C2, ae) | 0, n = n + Math.imul(O, fe) | 0, d = d + Math.imul(O, ae) | 0, l = l + Math.imul(k, oe) | 0, n = n + Math.imul(k, se) | 0, n = n + Math.imul(D2, oe) | 0, d = d + Math.imul(D2, se) | 0, l = l + Math.imul(R2, he) | 0, n = n + Math.imul(R2, ue) | 0, n = n + Math.imul(I, he) | 0, d = d + Math.imul(I, ue) | 0, l = l + Math.imul(g, le) | 0, n = n + Math.imul(g, de) | 0, n = n + Math.imul(_4, le) | 0, d = d + Math.imul(_4, de) | 0;
        var je = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (je >>> 26) | 0, je &= 67108863, l = Math.imul(V, X), n = Math.imul(V, J), n = n + Math.imul($, X) | 0, d = Math.imul($, J), l = l + Math.imul(j, Q) | 0, n = n + Math.imul(j, ee) | 0, n = n + Math.imul(Z, Q) | 0, d = d + Math.imul(Z, ee) | 0, l = l + Math.imul(W, te) | 0, n = n + Math.imul(W, re) | 0, n = n + Math.imul(K, te) | 0, d = d + Math.imul(K, re) | 0, l = l + Math.imul(z2, ie) | 0, n = n + Math.imul(z2, ne) | 0, n = n + Math.imul(H, ie) | 0, d = d + Math.imul(H, ne) | 0, l = l + Math.imul(F, fe) | 0, n = n + Math.imul(F, ae) | 0, n = n + Math.imul(U, fe) | 0, d = d + Math.imul(U, ae) | 0, l = l + Math.imul(C2, oe) | 0, n = n + Math.imul(C2, se) | 0, n = n + Math.imul(O, oe) | 0, d = d + Math.imul(O, se) | 0, l = l + Math.imul(k, he) | 0, n = n + Math.imul(k, ue) | 0, n = n + Math.imul(D2, he) | 0, d = d + Math.imul(D2, ue) | 0, l = l + Math.imul(R2, le) | 0, n = n + Math.imul(R2, de) | 0, n = n + Math.imul(I, le) | 0, d = d + Math.imul(I, de) | 0, l = l + Math.imul(g, ce) | 0, n = n + Math.imul(g, pe) | 0, n = n + Math.imul(_4, ce) | 0, d = d + Math.imul(_4, pe) | 0;
        var Ze = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ze >>> 26) | 0, Ze &= 67108863, l = Math.imul(G, X), n = Math.imul(G, J), n = n + Math.imul(Y, X) | 0, d = Math.imul(Y, J), l = l + Math.imul(V, Q) | 0, n = n + Math.imul(V, ee) | 0, n = n + Math.imul($, Q) | 0, d = d + Math.imul($, ee) | 0, l = l + Math.imul(j, te) | 0, n = n + Math.imul(j, re) | 0, n = n + Math.imul(Z, te) | 0, d = d + Math.imul(Z, re) | 0, l = l + Math.imul(W, ie) | 0, n = n + Math.imul(W, ne) | 0, n = n + Math.imul(K, ie) | 0, d = d + Math.imul(K, ne) | 0, l = l + Math.imul(z2, fe) | 0, n = n + Math.imul(z2, ae) | 0, n = n + Math.imul(H, fe) | 0, d = d + Math.imul(H, ae) | 0, l = l + Math.imul(F, oe) | 0, n = n + Math.imul(F, se) | 0, n = n + Math.imul(U, oe) | 0, d = d + Math.imul(U, se) | 0, l = l + Math.imul(C2, he) | 0, n = n + Math.imul(C2, ue) | 0, n = n + Math.imul(O, he) | 0, d = d + Math.imul(O, ue) | 0, l = l + Math.imul(k, le) | 0, n = n + Math.imul(k, de) | 0, n = n + Math.imul(D2, le) | 0, d = d + Math.imul(D2, de) | 0, l = l + Math.imul(R2, ce) | 0, n = n + Math.imul(R2, pe) | 0, n = n + Math.imul(I, ce) | 0, d = d + Math.imul(I, pe) | 0, l = l + Math.imul(g, ve) | 0, n = n + Math.imul(g, be) | 0, n = n + Math.imul(_4, ve) | 0, d = d + Math.imul(_4, be) | 0;
        var Ve = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ve >>> 26) | 0, Ve &= 67108863, l = Math.imul(G, Q), n = Math.imul(G, ee), n = n + Math.imul(Y, Q) | 0, d = Math.imul(Y, ee), l = l + Math.imul(V, te) | 0, n = n + Math.imul(V, re) | 0, n = n + Math.imul($, te) | 0, d = d + Math.imul($, re) | 0, l = l + Math.imul(j, ie) | 0, n = n + Math.imul(j, ne) | 0, n = n + Math.imul(Z, ie) | 0, d = d + Math.imul(Z, ne) | 0, l = l + Math.imul(W, fe) | 0, n = n + Math.imul(W, ae) | 0, n = n + Math.imul(K, fe) | 0, d = d + Math.imul(K, ae) | 0, l = l + Math.imul(z2, oe) | 0, n = n + Math.imul(z2, se) | 0, n = n + Math.imul(H, oe) | 0, d = d + Math.imul(H, se) | 0, l = l + Math.imul(F, he) | 0, n = n + Math.imul(F, ue) | 0, n = n + Math.imul(U, he) | 0, d = d + Math.imul(U, ue) | 0, l = l + Math.imul(C2, le) | 0, n = n + Math.imul(C2, de) | 0, n = n + Math.imul(O, le) | 0, d = d + Math.imul(O, de) | 0, l = l + Math.imul(k, ce) | 0, n = n + Math.imul(k, pe) | 0, n = n + Math.imul(D2, ce) | 0, d = d + Math.imul(D2, pe) | 0, l = l + Math.imul(R2, ve) | 0, n = n + Math.imul(R2, be) | 0, n = n + Math.imul(I, ve) | 0, d = d + Math.imul(I, be) | 0;
        var $e = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + ($e >>> 26) | 0, $e &= 67108863, l = Math.imul(G, te), n = Math.imul(G, re), n = n + Math.imul(Y, te) | 0, d = Math.imul(Y, re), l = l + Math.imul(V, ie) | 0, n = n + Math.imul(V, ne) | 0, n = n + Math.imul($, ie) | 0, d = d + Math.imul($, ne) | 0, l = l + Math.imul(j, fe) | 0, n = n + Math.imul(j, ae) | 0, n = n + Math.imul(Z, fe) | 0, d = d + Math.imul(Z, ae) | 0, l = l + Math.imul(W, oe) | 0, n = n + Math.imul(W, se) | 0, n = n + Math.imul(K, oe) | 0, d = d + Math.imul(K, se) | 0, l = l + Math.imul(z2, he) | 0, n = n + Math.imul(z2, ue) | 0, n = n + Math.imul(H, he) | 0, d = d + Math.imul(H, ue) | 0, l = l + Math.imul(F, le) | 0, n = n + Math.imul(F, de) | 0, n = n + Math.imul(U, le) | 0, d = d + Math.imul(U, de) | 0, l = l + Math.imul(C2, ce) | 0, n = n + Math.imul(C2, pe) | 0, n = n + Math.imul(O, ce) | 0, d = d + Math.imul(O, pe) | 0, l = l + Math.imul(k, ve) | 0, n = n + Math.imul(k, be) | 0, n = n + Math.imul(D2, ve) | 0, d = d + Math.imul(D2, be) | 0;
        var Ge = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ge >>> 26) | 0, Ge &= 67108863, l = Math.imul(G, ie), n = Math.imul(G, ne), n = n + Math.imul(Y, ie) | 0, d = Math.imul(Y, ne), l = l + Math.imul(V, fe) | 0, n = n + Math.imul(V, ae) | 0, n = n + Math.imul($, fe) | 0, d = d + Math.imul($, ae) | 0, l = l + Math.imul(j, oe) | 0, n = n + Math.imul(j, se) | 0, n = n + Math.imul(Z, oe) | 0, d = d + Math.imul(Z, se) | 0, l = l + Math.imul(W, he) | 0, n = n + Math.imul(W, ue) | 0, n = n + Math.imul(K, he) | 0, d = d + Math.imul(K, ue) | 0, l = l + Math.imul(z2, le) | 0, n = n + Math.imul(z2, de) | 0, n = n + Math.imul(H, le) | 0, d = d + Math.imul(H, de) | 0, l = l + Math.imul(F, ce) | 0, n = n + Math.imul(F, pe) | 0, n = n + Math.imul(U, ce) | 0, d = d + Math.imul(U, pe) | 0, l = l + Math.imul(C2, ve) | 0, n = n + Math.imul(C2, be) | 0, n = n + Math.imul(O, ve) | 0, d = d + Math.imul(O, be) | 0;
        var Ye = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Ye >>> 26) | 0, Ye &= 67108863, l = Math.imul(G, fe), n = Math.imul(G, ae), n = n + Math.imul(Y, fe) | 0, d = Math.imul(Y, ae), l = l + Math.imul(V, oe) | 0, n = n + Math.imul(V, se) | 0, n = n + Math.imul($, oe) | 0, d = d + Math.imul($, se) | 0, l = l + Math.imul(j, he) | 0, n = n + Math.imul(j, ue) | 0, n = n + Math.imul(Z, he) | 0, d = d + Math.imul(Z, ue) | 0, l = l + Math.imul(W, le) | 0, n = n + Math.imul(W, de) | 0, n = n + Math.imul(K, le) | 0, d = d + Math.imul(K, de) | 0, l = l + Math.imul(z2, ce) | 0, n = n + Math.imul(z2, pe) | 0, n = n + Math.imul(H, ce) | 0, d = d + Math.imul(H, pe) | 0, l = l + Math.imul(F, ve) | 0, n = n + Math.imul(F, be) | 0, n = n + Math.imul(U, ve) | 0, d = d + Math.imul(U, be) | 0;
        var Xe = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Xe >>> 26) | 0, Xe &= 67108863, l = Math.imul(G, oe), n = Math.imul(G, se), n = n + Math.imul(Y, oe) | 0, d = Math.imul(Y, se), l = l + Math.imul(V, he) | 0, n = n + Math.imul(V, ue) | 0, n = n + Math.imul($, he) | 0, d = d + Math.imul($, ue) | 0, l = l + Math.imul(j, le) | 0, n = n + Math.imul(j, de) | 0, n = n + Math.imul(Z, le) | 0, d = d + Math.imul(Z, de) | 0, l = l + Math.imul(W, ce) | 0, n = n + Math.imul(W, pe) | 0, n = n + Math.imul(K, ce) | 0, d = d + Math.imul(K, pe) | 0, l = l + Math.imul(z2, ve) | 0, n = n + Math.imul(z2, be) | 0, n = n + Math.imul(H, ve) | 0, d = d + Math.imul(H, be) | 0;
        var Je = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Je >>> 26) | 0, Je &= 67108863, l = Math.imul(G, he), n = Math.imul(G, ue), n = n + Math.imul(Y, he) | 0, d = Math.imul(Y, ue), l = l + Math.imul(V, le) | 0, n = n + Math.imul(V, de) | 0, n = n + Math.imul($, le) | 0, d = d + Math.imul($, de) | 0, l = l + Math.imul(j, ce) | 0, n = n + Math.imul(j, pe) | 0, n = n + Math.imul(Z, ce) | 0, d = d + Math.imul(Z, pe) | 0, l = l + Math.imul(W, ve) | 0, n = n + Math.imul(W, be) | 0, n = n + Math.imul(K, ve) | 0, d = d + Math.imul(K, be) | 0;
        var Qe = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (Qe >>> 26) | 0, Qe &= 67108863, l = Math.imul(G, le), n = Math.imul(G, de), n = n + Math.imul(Y, le) | 0, d = Math.imul(Y, de), l = l + Math.imul(V, ce) | 0, n = n + Math.imul(V, pe) | 0, n = n + Math.imul($, ce) | 0, d = d + Math.imul($, pe) | 0, l = l + Math.imul(j, ve) | 0, n = n + Math.imul(j, be) | 0, n = n + Math.imul(Z, ve) | 0, d = d + Math.imul(Z, be) | 0;
        var et = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (et >>> 26) | 0, et &= 67108863, l = Math.imul(G, ce), n = Math.imul(G, pe), n = n + Math.imul(Y, ce) | 0, d = Math.imul(Y, pe), l = l + Math.imul(V, ve) | 0, n = n + Math.imul(V, be) | 0, n = n + Math.imul($, ve) | 0, d = d + Math.imul($, be) | 0;
        var tt = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        b3 = (d + (n >>> 13) | 0) + (tt >>> 26) | 0, tt &= 67108863, l = Math.imul(G, ve), n = Math.imul(G, be), n = n + Math.imul(Y, ve) | 0, d = Math.imul(Y, be);
        var rt = (b3 + l | 0) + ((n & 8191) << 13) | 0;
        return b3 = (d + (n >>> 13) | 0) + (rt >>> 26) | 0, rt &= 67108863, c[0] = ft, c[1] = Be, c[2] = qe, c[3] = ze, c[4] = He, c[5] = We, c[6] = Ke, c[7] = je, c[8] = Ze, c[9] = Ve, c[10] = $e, c[11] = Ge, c[12] = Ye, c[13] = Xe, c[14] = Je, c[15] = Qe, c[16] = et, c[17] = tt, c[18] = rt, b3 !== 0 && (c[19] = b3, h2.length++), h2;
      };
      Math.imul || (L2 = q2);
      function ge(v, i, a) {
        a.negative = i.negative ^ v.negative, a.length = v.length + i.length;
        for (var h2 = 0, s = 0, u = 0;u < a.length - 1; u++) {
          var c = s;
          s = 0;
          for (var b3 = h2 & 67108863, l = Math.min(u, i.length - 1), n = Math.max(0, u - v.length + 1);n <= l; n++) {
            var d = u - n, w = v.words[d] | 0, g = i.words[n] | 0, _4 = w * g, A2 = _4 & 67108863;
            c = c + (_4 / 67108864 | 0) | 0, A2 = A2 + b3 | 0, b3 = A2 & 67108863, c = c + (A2 >>> 26) | 0, s += c >>> 26, c &= 67108863;
          }
          a.words[u] = b3, h2 = c, c = s;
        }
        return h2 !== 0 ? a.words[u] = h2 : a.length--, a.strip();
      }
      function _e(v, i, a) {
        var h2 = new N;
        return h2.mulp(v, i, a);
      }
      f.prototype.mulTo = function(i, a) {
        var h2, s = this.length + i.length;
        return this.length === 10 && i.length === 10 ? h2 = L2(this, i, a) : s < 63 ? h2 = q2(this, i, a) : s < 1024 ? h2 = ge(this, i, a) : h2 = _e(this, i, a), h2;
      };
      function N(v, i) {
        this.x = v, this.y = i;
      }
      N.prototype.makeRBT = function(i) {
        for (var a = new Array(i), h2 = f.prototype._countBits(i) - 1, s = 0;s < i; s++)
          a[s] = this.revBin(s, h2, i);
        return a;
      }, N.prototype.revBin = function(i, a, h2) {
        if (i === 0 || i === h2 - 1)
          return i;
        for (var s = 0, u = 0;u < a; u++)
          s |= (i & 1) << a - u - 1, i >>= 1;
        return s;
      }, N.prototype.permute = function(i, a, h2, s, u, c) {
        for (var b3 = 0;b3 < c; b3++)
          s[b3] = a[i[b3]], u[b3] = h2[i[b3]];
      }, N.prototype.transform = function(i, a, h2, s, u, c) {
        this.permute(c, i, a, h2, s, u);
        for (var b3 = 1;b3 < u; b3 <<= 1)
          for (var l = b3 << 1, n = Math.cos(2 * Math.PI / l), d = Math.sin(2 * Math.PI / l), w = 0;w < u; w += l)
            for (var g = n, _4 = d, A2 = 0;A2 < b3; A2++) {
              var R2 = h2[w + A2], I = s[w + A2], Me = h2[w + A2 + b3], k = s[w + A2 + b3], D2 = g * Me - _4 * k;
              k = g * k + _4 * Me, Me = D2, h2[w + A2] = R2 + Me, s[w + A2] = I + k, h2[w + A2 + b3] = R2 - Me, s[w + A2 + b3] = I - k, A2 !== l && (D2 = n * g - d * _4, _4 = n * _4 + d * g, g = D2);
            }
      }, N.prototype.guessLen13b = function(i, a) {
        var h2 = Math.max(a, i) | 1, s = h2 & 1, u = 0;
        for (h2 = h2 / 2 | 0;h2; h2 = h2 >>> 1)
          u++;
        return 1 << u + 1 + s;
      }, N.prototype.conjugate = function(i, a, h2) {
        if (!(h2 <= 1))
          for (var s = 0;s < h2 / 2; s++) {
            var u = i[s];
            i[s] = i[h2 - s - 1], i[h2 - s - 1] = u, u = a[s], a[s] = -a[h2 - s - 1], a[h2 - s - 1] = -u;
          }
      }, N.prototype.normalize13b = function(i, a) {
        for (var h2 = 0, s = 0;s < a / 2; s++) {
          var u = Math.round(i[2 * s + 1] / a) * 8192 + Math.round(i[2 * s] / a) + h2;
          i[s] = u & 67108863, u < 67108864 ? h2 = 0 : h2 = u / 67108864 | 0;
        }
        return i;
      }, N.prototype.convert13b = function(i, a, h2, s) {
        for (var u = 0, c = 0;c < a; c++)
          u = u + (i[c] | 0), h2[2 * c] = u & 8191, u = u >>> 13, h2[2 * c + 1] = u & 8191, u = u >>> 13;
        for (c = 2 * a;c < s; ++c)
          h2[c] = 0;
        r(u === 0), r((u & -8192) === 0);
      }, N.prototype.stub = function(i) {
        for (var a = new Array(i), h2 = 0;h2 < i; h2++)
          a[h2] = 0;
        return a;
      }, N.prototype.mulp = function(i, a, h2) {
        var s = 2 * this.guessLen13b(i.length, a.length), u = this.makeRBT(s), c = this.stub(s), b3 = new Array(s), l = new Array(s), n = new Array(s), d = new Array(s), w = new Array(s), g = new Array(s), _4 = h2.words;
        _4.length = s, this.convert13b(i.words, i.length, b3, s), this.convert13b(a.words, a.length, d, s), this.transform(b3, c, l, n, s, u), this.transform(d, c, w, g, s, u);
        for (var A2 = 0;A2 < s; A2++) {
          var R2 = l[A2] * w[A2] - n[A2] * g[A2];
          n[A2] = l[A2] * g[A2] + n[A2] * w[A2], l[A2] = R2;
        }
        return this.conjugate(l, n, s), this.transform(l, n, _4, c, s, u), this.conjugate(_4, c, s), this.normalize13b(_4, s), h2.negative = i.negative ^ a.negative, h2.length = i.length + a.length, h2.strip();
      }, f.prototype.mul = function(i) {
        var a = new f(null);
        return a.words = new Array(this.length + i.length), this.mulTo(i, a);
      }, f.prototype.mulf = function(i) {
        var a = new f(null);
        return a.words = new Array(this.length + i.length), _e(this, i, a);
      }, f.prototype.imul = function(i) {
        return this.clone().mulTo(i, this);
      }, f.prototype.imuln = function(i) {
        r(typeof i == "number"), r(i < 67108864);
        for (var a = 0, h2 = 0;h2 < this.length; h2++) {
          var s = (this.words[h2] | 0) * i, u = (s & 67108863) + (a & 67108863);
          a >>= 26, a += s / 67108864 | 0, a += u >>> 26, this.words[h2] = u & 67108863;
        }
        return a !== 0 && (this.words[h2] = a, this.length++), this;
      }, f.prototype.muln = function(i) {
        return this.clone().imuln(i);
      }, f.prototype.sqr = function() {
        return this.mul(this);
      }, f.prototype.isqr = function() {
        return this.imul(this.clone());
      }, f.prototype.pow = function(i) {
        var a = B(i);
        if (a.length === 0)
          return new f(1);
        for (var h2 = this, s = 0;s < a.length && a[s] === 0; s++, h2 = h2.sqr())
          ;
        if (++s < a.length)
          for (var u = h2.sqr();s < a.length; s++, u = u.sqr())
            a[s] !== 0 && (h2 = h2.mul(u));
        return h2;
      }, f.prototype.iushln = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26, s = 67108863 >>> 26 - a << 26 - a, u;
        if (a !== 0) {
          var c = 0;
          for (u = 0;u < this.length; u++) {
            var b3 = this.words[u] & s, l = (this.words[u] | 0) - b3 << a;
            this.words[u] = l | c, c = b3 >>> 26 - a;
          }
          c && (this.words[u] = c, this.length++);
        }
        if (h2 !== 0) {
          for (u = this.length - 1;u >= 0; u--)
            this.words[u + h2] = this.words[u];
          for (u = 0;u < h2; u++)
            this.words[u] = 0;
          this.length += h2;
        }
        return this.strip();
      }, f.prototype.ishln = function(i) {
        return r(this.negative === 0), this.iushln(i);
      }, f.prototype.iushrn = function(i, a, h2) {
        r(typeof i == "number" && i >= 0);
        var s;
        a ? s = (a - a % 26) / 26 : s = 0;
        var u = i % 26, c = Math.min((i - u) / 26, this.length), b3 = 67108863 ^ 67108863 >>> u << u, l = h2;
        if (s -= c, s = Math.max(0, s), l) {
          for (var n = 0;n < c; n++)
            l.words[n] = this.words[n];
          l.length = c;
        }
        if (c !== 0)
          if (this.length > c)
            for (this.length -= c, n = 0;n < this.length; n++)
              this.words[n] = this.words[n + c];
          else
            this.words[0] = 0, this.length = 1;
        var d = 0;
        for (n = this.length - 1;n >= 0 && (d !== 0 || n >= s); n--) {
          var w = this.words[n] | 0;
          this.words[n] = d << 26 - u | w >>> u, d = w & b3;
        }
        return l && d !== 0 && (l.words[l.length++] = d), this.length === 0 && (this.words[0] = 0, this.length = 1), this.strip();
      }, f.prototype.ishrn = function(i, a, h2) {
        return r(this.negative === 0), this.iushrn(i, a, h2);
      }, f.prototype.shln = function(i) {
        return this.clone().ishln(i);
      }, f.prototype.ushln = function(i) {
        return this.clone().iushln(i);
      }, f.prototype.shrn = function(i) {
        return this.clone().ishrn(i);
      }, f.prototype.ushrn = function(i) {
        return this.clone().iushrn(i);
      }, f.prototype.testn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26, s = 1 << a;
        if (this.length <= h2)
          return false;
        var u = this.words[h2];
        return !!(u & s);
      }, f.prototype.imaskn = function(i) {
        r(typeof i == "number" && i >= 0);
        var a = i % 26, h2 = (i - a) / 26;
        if (r(this.negative === 0, "imaskn works only with positive numbers"), this.length <= h2)
          return this;
        if (a !== 0 && h2++, this.length = Math.min(h2, this.length), a !== 0) {
          var s = 67108863 ^ 67108863 >>> a << a;
          this.words[this.length - 1] &= s;
        }
        return this.strip();
      }, f.prototype.maskn = function(i) {
        return this.clone().imaskn(i);
      }, f.prototype.iaddn = function(i) {
        return r(typeof i == "number"), r(i < 67108864), i < 0 ? this.isubn(-i) : this.negative !== 0 ? this.length === 1 && (this.words[0] | 0) < i ? (this.words[0] = i - (this.words[0] | 0), this.negative = 0, this) : (this.negative = 0, this.isubn(i), this.negative = 1, this) : this._iaddn(i);
      }, f.prototype._iaddn = function(i) {
        this.words[0] += i;
        for (var a = 0;a < this.length && this.words[a] >= 67108864; a++)
          this.words[a] -= 67108864, a === this.length - 1 ? this.words[a + 1] = 1 : this.words[a + 1]++;
        return this.length = Math.max(this.length, a + 1), this;
      }, f.prototype.isubn = function(i) {
        if (r(typeof i == "number"), r(i < 67108864), i < 0)
          return this.iaddn(-i);
        if (this.negative !== 0)
          return this.negative = 0, this.iaddn(i), this.negative = 1, this;
        if (this.words[0] -= i, this.length === 1 && this.words[0] < 0)
          this.words[0] = -this.words[0], this.negative = 1;
        else
          for (var a = 0;a < this.length && this.words[a] < 0; a++)
            this.words[a] += 67108864, this.words[a + 1] -= 1;
        return this.strip();
      }, f.prototype.addn = function(i) {
        return this.clone().iaddn(i);
      }, f.prototype.subn = function(i) {
        return this.clone().isubn(i);
      }, f.prototype.iabs = function() {
        return this.negative = 0, this;
      }, f.prototype.abs = function() {
        return this.clone().iabs();
      }, f.prototype._ishlnsubmul = function(i, a, h2) {
        var s = i.length + h2, u;
        this._expand(s);
        var c, b3 = 0;
        for (u = 0;u < i.length; u++) {
          c = (this.words[u + h2] | 0) + b3;
          var l = (i.words[u] | 0) * a;
          c -= l & 67108863, b3 = (c >> 26) - (l / 67108864 | 0), this.words[u + h2] = c & 67108863;
        }
        for (;u < this.length - h2; u++)
          c = (this.words[u + h2] | 0) + b3, b3 = c >> 26, this.words[u + h2] = c & 67108863;
        if (b3 === 0)
          return this.strip();
        for (r(b3 === -1), b3 = 0, u = 0;u < this.length; u++)
          c = -(this.words[u] | 0) + b3, b3 = c >> 26, this.words[u] = c & 67108863;
        return this.negative = 1, this.strip();
      }, f.prototype._wordDiv = function(i, a) {
        var h2 = this.length - i.length, s = this.clone(), u = i, c = u.words[u.length - 1] | 0, b3 = this._countBits(c);
        h2 = 26 - b3, h2 !== 0 && (u = u.ushln(h2), s.iushln(h2), c = u.words[u.length - 1] | 0);
        var l = s.length - u.length, n;
        if (a !== "mod") {
          n = new f(null), n.length = l + 1, n.words = new Array(n.length);
          for (var d = 0;d < n.length; d++)
            n.words[d] = 0;
        }
        var w = s.clone()._ishlnsubmul(u, 1, l);
        w.negative === 0 && (s = w, n && (n.words[l] = 1));
        for (var g = l - 1;g >= 0; g--) {
          var _4 = (s.words[u.length + g] | 0) * 67108864 + (s.words[u.length + g - 1] | 0);
          for (_4 = Math.min(_4 / c | 0, 67108863), s._ishlnsubmul(u, _4, g);s.negative !== 0; )
            _4--, s.negative = 0, s._ishlnsubmul(u, 1, g), s.isZero() || (s.negative ^= 1);
          n && (n.words[g] = _4);
        }
        return n && n.strip(), s.strip(), a !== "div" && h2 !== 0 && s.iushrn(h2), { div: n || null, mod: s };
      }, f.prototype.divmod = function(i, a, h2) {
        if (r(!i.isZero()), this.isZero())
          return { div: new f(0), mod: new f(0) };
        var s, u, c;
        return this.negative !== 0 && i.negative === 0 ? (c = this.neg().divmod(i, a), a !== "mod" && (s = c.div.neg()), a !== "div" && (u = c.mod.neg(), h2 && u.negative !== 0 && u.iadd(i)), { div: s, mod: u }) : this.negative === 0 && i.negative !== 0 ? (c = this.divmod(i.neg(), a), a !== "mod" && (s = c.div.neg()), { div: s, mod: c.mod }) : (this.negative & i.negative) !== 0 ? (c = this.neg().divmod(i.neg(), a), a !== "div" && (u = c.mod.neg(), h2 && u.negative !== 0 && u.isub(i)), { div: c.div, mod: u }) : i.length > this.length || this.cmp(i) < 0 ? { div: new f(0), mod: this } : i.length === 1 ? a === "div" ? { div: this.divn(i.words[0]), mod: null } : a === "mod" ? { div: null, mod: new f(this.modn(i.words[0])) } : { div: this.divn(i.words[0]), mod: new f(this.modn(i.words[0])) } : this._wordDiv(i, a);
      }, f.prototype.div = function(i) {
        return this.divmod(i, "div", false).div;
      }, f.prototype.mod = function(i) {
        return this.divmod(i, "mod", false).mod;
      }, f.prototype.umod = function(i) {
        return this.divmod(i, "mod", true).mod;
      }, f.prototype.divRound = function(i) {
        var a = this.divmod(i);
        if (a.mod.isZero())
          return a.div;
        var h2 = a.div.negative !== 0 ? a.mod.isub(i) : a.mod, s = i.ushrn(1), u = i.andln(1), c = h2.cmp(s);
        return c < 0 || u === 1 && c === 0 ? a.div : a.div.negative !== 0 ? a.div.isubn(1) : a.div.iaddn(1);
      }, f.prototype.modn = function(i) {
        r(i <= 67108863);
        for (var a = (1 << 26) % i, h2 = 0, s = this.length - 1;s >= 0; s--)
          h2 = (a * h2 + (this.words[s] | 0)) % i;
        return h2;
      }, f.prototype.idivn = function(i) {
        r(i <= 67108863);
        for (var a = 0, h2 = this.length - 1;h2 >= 0; h2--) {
          var s = (this.words[h2] | 0) + a * 67108864;
          this.words[h2] = s / i | 0, a = s % i;
        }
        return this.strip();
      }, f.prototype.divn = function(i) {
        return this.clone().idivn(i);
      }, f.prototype.egcd = function(i) {
        r(i.negative === 0), r(!i.isZero());
        var a = this, h2 = i.clone();
        a.negative !== 0 ? a = a.umod(i) : a = a.clone();
        for (var s = new f(1), u = new f(0), c = new f(0), b3 = new f(1), l = 0;a.isEven() && h2.isEven(); )
          a.iushrn(1), h2.iushrn(1), ++l;
        for (var n = h2.clone(), d = a.clone();!a.isZero(); ) {
          for (var w = 0, g = 1;(a.words[0] & g) === 0 && w < 26; ++w, g <<= 1)
            ;
          if (w > 0)
            for (a.iushrn(w);w-- > 0; )
              (s.isOdd() || u.isOdd()) && (s.iadd(n), u.isub(d)), s.iushrn(1), u.iushrn(1);
          for (var _4 = 0, A2 = 1;(h2.words[0] & A2) === 0 && _4 < 26; ++_4, A2 <<= 1)
            ;
          if (_4 > 0)
            for (h2.iushrn(_4);_4-- > 0; )
              (c.isOdd() || b3.isOdd()) && (c.iadd(n), b3.isub(d)), c.iushrn(1), b3.iushrn(1);
          a.cmp(h2) >= 0 ? (a.isub(h2), s.isub(c), u.isub(b3)) : (h2.isub(a), c.isub(s), b3.isub(u));
        }
        return { a: c, b: b3, gcd: h2.iushln(l) };
      }, f.prototype._invmp = function(i) {
        r(i.negative === 0), r(!i.isZero());
        var a = this, h2 = i.clone();
        a.negative !== 0 ? a = a.umod(i) : a = a.clone();
        for (var s = new f(1), u = new f(0), c = h2.clone();a.cmpn(1) > 0 && h2.cmpn(1) > 0; ) {
          for (var b3 = 0, l = 1;(a.words[0] & l) === 0 && b3 < 26; ++b3, l <<= 1)
            ;
          if (b3 > 0)
            for (a.iushrn(b3);b3-- > 0; )
              s.isOdd() && s.iadd(c), s.iushrn(1);
          for (var n = 0, d = 1;(h2.words[0] & d) === 0 && n < 26; ++n, d <<= 1)
            ;
          if (n > 0)
            for (h2.iushrn(n);n-- > 0; )
              u.isOdd() && u.iadd(c), u.iushrn(1);
          a.cmp(h2) >= 0 ? (a.isub(h2), s.isub(u)) : (h2.isub(a), u.isub(s));
        }
        var w;
        return a.cmpn(1) === 0 ? w = s : w = u, w.cmpn(0) < 0 && w.iadd(i), w;
      }, f.prototype.gcd = function(i) {
        if (this.isZero())
          return i.abs();
        if (i.isZero())
          return this.abs();
        var a = this.clone(), h2 = i.clone();
        a.negative = 0, h2.negative = 0;
        for (var s = 0;a.isEven() && h2.isEven(); s++)
          a.iushrn(1), h2.iushrn(1);
        do {
          for (;a.isEven(); )
            a.iushrn(1);
          for (;h2.isEven(); )
            h2.iushrn(1);
          var u = a.cmp(h2);
          if (u < 0) {
            var c = a;
            a = h2, h2 = c;
          } else if (u === 0 || h2.cmpn(1) === 0)
            break;
          a.isub(h2);
        } while (true);
        return h2.iushln(s);
      }, f.prototype.invm = function(i) {
        return this.egcd(i).a.umod(i);
      }, f.prototype.isEven = function() {
        return (this.words[0] & 1) === 0;
      }, f.prototype.isOdd = function() {
        return (this.words[0] & 1) === 1;
      }, f.prototype.andln = function(i) {
        return this.words[0] & i;
      }, f.prototype.bincn = function(i) {
        r(typeof i == "number");
        var a = i % 26, h2 = (i - a) / 26, s = 1 << a;
        if (this.length <= h2)
          return this._expand(h2 + 1), this.words[h2] |= s, this;
        for (var u = s, c = h2;u !== 0 && c < this.length; c++) {
          var b3 = this.words[c] | 0;
          b3 += u, u = b3 >>> 26, b3 &= 67108863, this.words[c] = b3;
        }
        return u !== 0 && (this.words[c] = u, this.length++), this;
      }, f.prototype.isZero = function() {
        return this.length === 1 && this.words[0] === 0;
      }, f.prototype.cmpn = function(i) {
        var a = i < 0;
        if (this.negative !== 0 && !a)
          return -1;
        if (this.negative === 0 && a)
          return 1;
        this.strip();
        var h2;
        if (this.length > 1)
          h2 = 1;
        else {
          a && (i = -i), r(i <= 67108863, "Number is too big");
          var s = this.words[0] | 0;
          h2 = s === i ? 0 : s < i ? -1 : 1;
        }
        return this.negative !== 0 ? -h2 | 0 : h2;
      }, f.prototype.cmp = function(i) {
        if (this.negative !== 0 && i.negative === 0)
          return -1;
        if (this.negative === 0 && i.negative !== 0)
          return 1;
        var a = this.ucmp(i);
        return this.negative !== 0 ? -a | 0 : a;
      }, f.prototype.ucmp = function(i) {
        if (this.length > i.length)
          return 1;
        if (this.length < i.length)
          return -1;
        for (var a = 0, h2 = this.length - 1;h2 >= 0; h2--) {
          var s = this.words[h2] | 0, u = i.words[h2] | 0;
          if (s !== u) {
            s < u ? a = -1 : s > u && (a = 1);
            break;
          }
        }
        return a;
      }, f.prototype.gtn = function(i) {
        return this.cmpn(i) === 1;
      }, f.prototype.gt = function(i) {
        return this.cmp(i) === 1;
      }, f.prototype.gten = function(i) {
        return this.cmpn(i) >= 0;
      }, f.prototype.gte = function(i) {
        return this.cmp(i) >= 0;
      }, f.prototype.ltn = function(i) {
        return this.cmpn(i) === -1;
      }, f.prototype.lt = function(i) {
        return this.cmp(i) === -1;
      }, f.prototype.lten = function(i) {
        return this.cmpn(i) <= 0;
      }, f.prototype.lte = function(i) {
        return this.cmp(i) <= 0;
      }, f.prototype.eqn = function(i) {
        return this.cmpn(i) === 0;
      }, f.prototype.eq = function(i) {
        return this.cmp(i) === 0;
      }, f.red = function(i) {
        return new P(i);
      }, f.prototype.toRed = function(i) {
        return r(!this.red, "Already a number in reduction context"), r(this.negative === 0, "red works only with positives"), i.convertTo(this)._forceRed(i);
      }, f.prototype.fromRed = function() {
        return r(this.red, "fromRed works only with numbers in reduction context"), this.red.convertFrom(this);
      }, f.prototype._forceRed = function(i) {
        return this.red = i, this;
      }, f.prototype.forceRed = function(i) {
        return r(!this.red, "Already a number in reduction context"), this._forceRed(i);
      }, f.prototype.redAdd = function(i) {
        return r(this.red, "redAdd works only with red numbers"), this.red.add(this, i);
      }, f.prototype.redIAdd = function(i) {
        return r(this.red, "redIAdd works only with red numbers"), this.red.iadd(this, i);
      }, f.prototype.redSub = function(i) {
        return r(this.red, "redSub works only with red numbers"), this.red.sub(this, i);
      }, f.prototype.redISub = function(i) {
        return r(this.red, "redISub works only with red numbers"), this.red.isub(this, i);
      }, f.prototype.redShl = function(i) {
        return r(this.red, "redShl works only with red numbers"), this.red.shl(this, i);
      }, f.prototype.redMul = function(i) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, i), this.red.mul(this, i);
      }, f.prototype.redIMul = function(i) {
        return r(this.red, "redMul works only with red numbers"), this.red._verify2(this, i), this.red.imul(this, i);
      }, f.prototype.redSqr = function() {
        return r(this.red, "redSqr works only with red numbers"), this.red._verify1(this), this.red.sqr(this);
      }, f.prototype.redISqr = function() {
        return r(this.red, "redISqr works only with red numbers"), this.red._verify1(this), this.red.isqr(this);
      }, f.prototype.redSqrt = function() {
        return r(this.red, "redSqrt works only with red numbers"), this.red._verify1(this), this.red.sqrt(this);
      }, f.prototype.redInvm = function() {
        return r(this.red, "redInvm works only with red numbers"), this.red._verify1(this), this.red.invm(this);
      }, f.prototype.redNeg = function() {
        return r(this.red, "redNeg works only with red numbers"), this.red._verify1(this), this.red.neg(this);
      }, f.prototype.redPow = function(i) {
        return r(this.red && !i.red, "redPow(normalNum)"), this.red._verify1(this), this.red.pow(this, i);
      };
      var we = { k256: null, p224: null, p192: null, p25519: null };
      function ye(v, i) {
        this.name = v, this.p = new f(i, 16), this.n = this.p.bitLength(), this.k = new f(1).iushln(this.n).isub(this.p), this.tmp = this._tmp();
      }
      ye.prototype._tmp = function() {
        var i = new f(null);
        return i.words = new Array(Math.ceil(this.n / 13)), i;
      }, ye.prototype.ireduce = function(i) {
        var a = i, h2;
        do
          this.split(a, this.tmp), a = this.imulK(a), a = a.iadd(this.tmp), h2 = a.bitLength();
        while (h2 > this.n);
        var s = h2 < this.n ? -1 : a.ucmp(this.p);
        return s === 0 ? (a.words[0] = 0, a.length = 1) : s > 0 ? a.isub(this.p) : a.strip !== undefined ? a.strip() : a._strip(), a;
      }, ye.prototype.split = function(i, a) {
        i.iushrn(this.n, 0, a);
      }, ye.prototype.imulK = function(i) {
        return i.imul(this.k);
      };
      function xe() {
        ye.call(this, "k256", "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f");
      }
      o(xe, ye), xe.prototype.split = function(i, a) {
        for (var h2 = 4194303, s = Math.min(i.length, 9), u = 0;u < s; u++)
          a.words[u] = i.words[u];
        if (a.length = s, i.length <= 9) {
          i.words[0] = 0, i.length = 1;
          return;
        }
        var c = i.words[9];
        for (a.words[a.length++] = c & h2, u = 10;u < i.length; u++) {
          var b3 = i.words[u] | 0;
          i.words[u - 10] = (b3 & h2) << 4 | c >>> 22, c = b3;
        }
        c >>>= 22, i.words[u - 10] = c, c === 0 && i.length > 10 ? i.length -= 10 : i.length -= 9;
      }, xe.prototype.imulK = function(i) {
        i.words[i.length] = 0, i.words[i.length + 1] = 0, i.length += 2;
        for (var a = 0, h2 = 0;h2 < i.length; h2++) {
          var s = i.words[h2] | 0;
          a += s * 977, i.words[h2] = a & 67108863, a = s * 64 + (a / 67108864 | 0);
        }
        return i.words[i.length - 1] === 0 && (i.length--, i.words[i.length - 1] === 0 && i.length--), i;
      };
      function Re() {
        ye.call(this, "p224", "ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001");
      }
      o(Re, ye);
      function Ee() {
        ye.call(this, "p192", "ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff");
      }
      o(Ee, ye);
      function Ae() {
        ye.call(this, "25519", "7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed");
      }
      o(Ae, ye), Ae.prototype.imulK = function(i) {
        for (var a = 0, h2 = 0;h2 < i.length; h2++) {
          var s = (i.words[h2] | 0) * 19 + a, u = s & 67108863;
          s >>>= 26, i.words[h2] = u, a = s;
        }
        return a !== 0 && (i.words[i.length++] = a), i;
      }, f._prime = function(i) {
        if (we[i])
          return we[i];
        var a;
        if (i === "k256")
          a = new xe;
        else if (i === "p224")
          a = new Re;
        else if (i === "p192")
          a = new Ee;
        else if (i === "p25519")
          a = new Ae;
        else
          throw new Error("Unknown prime " + i);
        return we[i] = a, a;
      };
      function P(v) {
        if (typeof v == "string") {
          var i = f._prime(v);
          this.m = i.p, this.prime = i;
        } else
          r(v.gtn(1), "modulus must be greater than 1"), this.m = v, this.prime = null;
      }
      P.prototype._verify1 = function(i) {
        r(i.negative === 0, "red works only with positives"), r(i.red, "red works only with red numbers");
      }, P.prototype._verify2 = function(i, a) {
        r((i.negative | a.negative) === 0, "red works only with positives"), r(i.red && i.red === a.red, "red works only with red numbers");
      }, P.prototype.imod = function(i) {
        return this.prime ? this.prime.ireduce(i)._forceRed(this) : i.umod(this.m)._forceRed(this);
      }, P.prototype.neg = function(i) {
        return i.isZero() ? i.clone() : this.m.sub(i)._forceRed(this);
      }, P.prototype.add = function(i, a) {
        this._verify2(i, a);
        var h2 = i.add(a);
        return h2.cmp(this.m) >= 0 && h2.isub(this.m), h2._forceRed(this);
      }, P.prototype.iadd = function(i, a) {
        this._verify2(i, a);
        var h2 = i.iadd(a);
        return h2.cmp(this.m) >= 0 && h2.isub(this.m), h2;
      }, P.prototype.sub = function(i, a) {
        this._verify2(i, a);
        var h2 = i.sub(a);
        return h2.cmpn(0) < 0 && h2.iadd(this.m), h2._forceRed(this);
      }, P.prototype.isub = function(i, a) {
        this._verify2(i, a);
        var h2 = i.isub(a);
        return h2.cmpn(0) < 0 && h2.iadd(this.m), h2;
      }, P.prototype.shl = function(i, a) {
        return this._verify1(i), this.imod(i.ushln(a));
      }, P.prototype.imul = function(i, a) {
        return this._verify2(i, a), this.imod(i.imul(a));
      }, P.prototype.mul = function(i, a) {
        return this._verify2(i, a), this.imod(i.mul(a));
      }, P.prototype.isqr = function(i) {
        return this.imul(i, i.clone());
      }, P.prototype.sqr = function(i) {
        return this.mul(i, i);
      }, P.prototype.sqrt = function(i) {
        if (i.isZero())
          return i.clone();
        var a = this.m.andln(3);
        if (r(a % 2 === 1), a === 3) {
          var h2 = this.m.add(new f(1)).iushrn(2);
          return this.pow(i, h2);
        }
        for (var s = this.m.subn(1), u = 0;!s.isZero() && s.andln(1) === 0; )
          u++, s.iushrn(1);
        r(!s.isZero());
        var c = new f(1).toRed(this), b3 = c.redNeg(), l = this.m.subn(1).iushrn(1), n = this.m.bitLength();
        for (n = new f(2 * n * n).toRed(this);this.pow(n, l).cmp(b3) !== 0; )
          n.redIAdd(b3);
        for (var d = this.pow(n, s), w = this.pow(i, s.addn(1).iushrn(1)), g = this.pow(i, s), _4 = u;g.cmp(c) !== 0; ) {
          for (var A2 = g, R2 = 0;A2.cmp(c) !== 0; R2++)
            A2 = A2.redSqr();
          r(R2 < _4);
          var I = this.pow(d, new f(1).iushln(_4 - R2 - 1));
          w = w.redMul(I), d = I.redSqr(), g = g.redMul(d), _4 = R2;
        }
        return w;
      }, P.prototype.invm = function(i) {
        var a = i._invmp(this.m);
        return a.negative !== 0 ? (a.negative = 0, this.imod(a).redNeg()) : this.imod(a);
      }, P.prototype.pow = function(i, a) {
        if (a.isZero())
          return new f(1).toRed(this);
        if (a.cmpn(1) === 0)
          return i.clone();
        var h2 = 4, s = new Array(1 << h2);
        s[0] = new f(1).toRed(this), s[1] = i;
        for (var u = 2;u < s.length; u++)
          s[u] = this.mul(s[u - 1], i);
        var c = s[0], b3 = 0, l = 0, n = a.bitLength() % 26;
        for (n === 0 && (n = 26), u = a.length - 1;u >= 0; u--) {
          for (var d = a.words[u], w = n - 1;w >= 0; w--) {
            var g = d >> w & 1;
            if (c !== s[0] && (c = this.sqr(c)), g === 0 && b3 === 0) {
              l = 0;
              continue;
            }
            b3 <<= 1, b3 |= g, l++, !(l !== h2 && (u !== 0 || w !== 0)) && (c = this.mul(c, s[b3]), l = 0, b3 = 0);
          }
          n = 26;
        }
        return c;
      }, P.prototype.convertTo = function(i) {
        var a = i.umod(this.m);
        return a === i ? a.clone() : a;
      }, P.prototype.convertFrom = function(i) {
        var a = i.clone();
        return a.red = null, a;
      }, f.mont = function(i) {
        return new Se(i);
      };
      function Se(v) {
        P.call(this, v), this.shift = this.m.bitLength(), this.shift % 26 !== 0 && (this.shift += 26 - this.shift % 26), this.r = new f(1).iushln(this.shift), this.r2 = this.imod(this.r.sqr()), this.rinv = this.r._invmp(this.m), this.minv = this.rinv.mul(this.r).isubn(1).div(this.m), this.minv = this.minv.umod(this.r), this.minv = this.r.sub(this.minv);
      }
      o(Se, P), Se.prototype.convertTo = function(i) {
        return this.imod(i.ushln(this.shift));
      }, Se.prototype.convertFrom = function(i) {
        var a = this.imod(i.mul(this.rinv));
        return a.red = null, a;
      }, Se.prototype.imul = function(i, a) {
        if (i.isZero() || a.isZero())
          return i.words[0] = 0, i.length = 1, i;
        var h2 = i.imul(a), s = h2.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), u = h2.isub(s).iushrn(this.shift), c = u;
        return u.cmp(this.m) >= 0 ? c = u.isub(this.m) : u.cmpn(0) < 0 && (c = u.iadd(this.m)), c._forceRed(this);
      }, Se.prototype.mul = function(i, a) {
        if (i.isZero() || a.isZero())
          return new f(0)._forceRed(this);
        var h2 = i.mul(a), s = h2.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m), u = h2.isub(s).iushrn(this.shift), c = u;
        return u.cmp(this.m) >= 0 ? c = u.isub(this.m) : u.cmpn(0) < 0 && (c = u.iadd(this.m)), c._forceRed(this);
      }, Se.prototype.invm = function(i) {
        var a = this.imod(i._invmp(this.m).mul(this.r2));
        return a._forceRed(this);
      };
    })(typeof Sd > "u" || Sd, F3);
  });
  Ed = T2((xL, z3) => {
    var U3 = w0(), wq = Te().Buffer;
    function Mq(t, e) {
      return wq.from(t.toRed(U3.mont(e.modulus)).redPow(new U3(e.publicExponent)).fromRed().toArray());
    }
    z3.exports = Mq;
  });
  j3 = T2((SL, K3) => {
    var _q = Ha(), Ad = on(), xq = bf(), H3 = _d(), W3 = xd(), Rd = w0(), Sq = Ed(), Eq = Ks(), Kr = Te().Buffer;
    K3.exports = function(e, r, o) {
      var f;
      e.padding ? f = e.padding : o ? f = 1 : f = 4;
      var p = _q(e), m2;
      if (f === 4)
        m2 = Aq(p, r);
      else if (f === 1)
        m2 = Rq(p, r, o);
      else if (f === 3) {
        if (m2 = new Rd(r), m2.cmp(p.modulus) >= 0)
          throw new Error("data too long for modulus");
      } else
        throw new Error("unknown padding");
      return o ? Eq(m2, p) : Sq(m2, p);
    };
    function Aq(t, e) {
      var r = t.modulus.byteLength(), o = e.length, f = xq("sha1").update(Kr.alloc(0)).digest(), p = f.length, m2 = 2 * p;
      if (o > r - m2 - 2)
        throw new Error("message too long");
      var y3 = Kr.alloc(r - o - m2 - 2), M = r - p - 1, x = Ad(p), S = W3(Kr.concat([f, y3, Kr.alloc(1, 1), e], M), H3(x, M)), E2 = W3(x, H3(S, p));
      return new Rd(Kr.concat([Kr.alloc(1), E2, S], r));
    }
    function Rq(t, e, r) {
      var o = e.length, f = t.modulus.byteLength();
      if (o > f - 11)
        throw new Error("message too long");
      var p;
      return r ? p = Kr.alloc(f - o - 3, 255) : p = Bq(f - o - 3), new Rd(Kr.concat([Kr.from([0, r ? 1 : 2]), p, Kr.alloc(1), e], f));
    }
    function Bq(t) {
      for (var e = Kr.allocUnsafe(t), r = 0, o = Ad(t * 2), f = 0, p;r < t; )
        f === o.length && (o = Ad(t * 2), f = 0), p = o[f++], p && (e[r++] = p);
      return e;
    }
  });
  Y3 = T2((EL, G3) => {
    var qq = Ha(), Z3 = _d(), V3 = xd(), $3 = w0(), Iq = Ks(), Tq = bf(), kq = Ed(), Za = Te().Buffer;
    G3.exports = function(e, r, o) {
      var f;
      e.padding ? f = e.padding : o ? f = 1 : f = 4;
      var p = qq(e), m2 = p.modulus.byteLength();
      if (r.length > m2 || new $3(r).cmp(p.modulus) >= 0)
        throw new Error("decryption error");
      var y3;
      o ? y3 = kq(new $3(r), p) : y3 = Iq(r, p);
      var M = Za.alloc(m2 - y3.length);
      if (y3 = Za.concat([M, y3], m2), f === 4)
        return Lq(p, y3);
      if (f === 1)
        return Nq(p, y3, o);
      if (f === 3)
        return y3;
      throw new Error("unknown padding");
    };
    function Lq(t, e) {
      var r = t.modulus.byteLength(), o = Tq("sha1").update(Za.alloc(0)).digest(), f = o.length;
      if (e[0] !== 0)
        throw new Error("decryption error");
      var p = e.slice(1, f + 1), m2 = e.slice(f + 1), y3 = V3(p, Z3(m2, f)), M = V3(m2, Z3(y3, r - f - 1));
      if (Dq(o, M.slice(0, f)))
        throw new Error("decryption error");
      for (var x = f;M[x] === 0; )
        x++;
      if (M[x++] !== 1)
        throw new Error("decryption error");
      return M.slice(x);
    }
    function Nq(t, e, r) {
      for (var o = e.slice(0, 2), f = 2, p = 0;e[f++] !== 0; )
        if (f >= e.length) {
          p++;
          break;
        }
      var m2 = e.slice(2, f - 1);
      if ((o.toString("hex") !== "0002" && !r || o.toString("hex") !== "0001" && r) && p++, m2.length < 8 && p++, p)
        throw new Error("decryption error");
      return e.slice(f);
    }
    function Dq(t, e) {
      t = Za.from(t), e = Za.from(e);
      var r = 0, o = t.length;
      t.length !== e.length && (r++, o = Math.min(t.length, e.length));
      for (var f = -1;++f < o; )
        r += t[f] ^ e[f];
      return r;
    }
  });
  X3 = T2((Vn) => {
    Vn.publicEncrypt = j3();
    Vn.privateDecrypt = Y3();
    Vn.privateEncrypt = function(e, r) {
      return Vn.publicEncrypt(e, r, true);
    };
    Vn.publicDecrypt = function(e, r) {
      return Vn.privateDecrypt(e, r, true);
    };
  });
  ow = T2((Va) => {
    function J3() {
      throw new Error(`secure random number generation not supported by this browser
use chrome, FireFox or Internet Explorer 11`);
    }
    var ew = Te(), Q3 = on(), tw = ew.Buffer, rw = ew.kMaxLength, Bd = global.crypto || global.msCrypto, iw = Math.pow(2, 32) - 1;
    function nw(t, e) {
      if (typeof t != "number" || t !== t)
        throw new TypeError("offset must be a number");
      if (t > iw || t < 0)
        throw new TypeError("offset must be a uint32");
      if (t > rw || t > e)
        throw new RangeError("offset out of range");
    }
    function fw(t, e, r) {
      if (typeof t != "number" || t !== t)
        throw new TypeError("size must be a number");
      if (t > iw || t < 0)
        throw new TypeError("size must be a uint32");
      if (t + e > r || t > rw)
        throw new RangeError("buffer too small");
    }
    Bd && Bd.getRandomValues ? (Va.randomFill = Pq, Va.randomFillSync = Cq) : (Va.randomFill = J3, Va.randomFillSync = J3);
    function Pq(t, e, r, o) {
      if (!tw.isBuffer(t) && !(t instanceof global.Uint8Array))
        throw new TypeError('"buf" argument must be a Buffer or Uint8Array');
      if (typeof e == "function")
        o = e, e = 0, r = t.length;
      else if (typeof r == "function")
        o = r, r = t.length - e;
      else if (typeof o != "function")
        throw new TypeError('"cb" argument must be a function');
      return nw(e, t.length), fw(r, e, t.length), aw(t, e, r, o);
    }
    function aw(t, e, r, o) {
      if (true) {
        var f = t.buffer, p = new Uint8Array(f, e, r);
        if (Bd.getRandomValues(p), o) {
          process.nextTick(function() {
            o(null, t);
          });
          return;
        }
        return t;
      }
      if (o) {
        Q3(r, function(y3, M) {
          if (y3)
            return o(y3);
          M.copy(t, e), o(null, t);
        });
        return;
      }
      var m2 = Q3(r);
      return m2.copy(t, e), t;
    }
    function Cq(t, e, r) {
      if (typeof e > "u" && (e = 0), !tw.isBuffer(t) && !(t instanceof global.Uint8Array))
        throw new TypeError('"buf" argument must be a Buffer or Uint8Array');
      return nw(e, t.length), r === undefined && (r = t.length - e), fw(r, e, t.length), aw(t, e, r);
    }
  });
  qd = T2((ke) => {
    ke.randomBytes = ke.rng = ke.pseudoRandomBytes = ke.prng = on();
    ke.createHash = ke.Hash = bf();
    ke.createHmac = ke.Hmac = wu();
    var Oq = Eb(), Fq = Object.keys(Oq), Uq = ["sha1", "sha224", "sha256", "sha384", "sha512", "md5", "rmd160"].concat(Fq);
    ke.getHashes = function() {
      return Uq;
    };
    var sw = Iu();
    ke.pbkdf2 = sw.pbkdf2;
    ke.pbkdf2Sync = sw.pbkdf2Sync;
    var ui = Vm();
    ke.Cipher = ui.Cipher;
    ke.createCipher = ui.createCipher;
    ke.Cipheriv = ui.Cipheriv;
    ke.createCipheriv = ui.createCipheriv;
    ke.Decipher = ui.Decipher;
    ke.createDecipher = ui.createDecipher;
    ke.Decipheriv = ui.Decipheriv;
    ke.createDecipheriv = ui.createDecipheriv;
    ke.getCiphers = ui.getCiphers;
    ke.listCiphers = ui.listCiphers;
    var $a = hg();
    ke.DiffieHellmanGroup = $a.DiffieHellmanGroup;
    ke.createDiffieHellmanGroup = $a.createDiffieHellmanGroup;
    ke.getDiffieHellman = $a.getDiffieHellman;
    ke.createDiffieHellman = $a.createDiffieHellman;
    ke.DiffieHellman = $a.DiffieHellman;
    var M0 = k3();
    ke.createSign = M0.createSign;
    ke.Sign = M0.Sign;
    ke.createVerify = M0.createVerify;
    ke.Verify = M0.Verify;
    ke.createECDH = P3();
    var _0 = X3();
    ke.publicEncrypt = _0.publicEncrypt;
    ke.privateEncrypt = _0.privateEncrypt;
    ke.publicDecrypt = _0.publicDecrypt;
    ke.privateDecrypt = _0.privateDecrypt;
    var hw = ow();
    ke.randomFill = hw.randomFill;
    ke.randomFillSync = hw.randomFillSync;
    ke.createCredentials = function() {
      throw new Error(["sorry, createCredentials is not implemented yet", "we accept pull requests", "https://github.com/crypto-browserify/crypto-browserify"].join(`
`));
    };
    ke.constants = { DH_CHECK_P_NOT_SAFE_PRIME: 2, DH_CHECK_P_NOT_PRIME: 1, DH_UNABLE_TO_CHECK_GENERATOR: 4, DH_NOT_SUITABLE_GENERATOR: 8, NPN_ENABLED: 1, ALPN_ENABLED: 1, RSA_PKCS1_PADDING: 1, RSA_SSLV23_PADDING: 2, RSA_NO_PADDING: 3, RSA_PKCS1_OAEP_PADDING: 4, RSA_X931_PADDING: 5, RSA_PKCS1_PSS_PADDING: 6, POINT_CONVERSION_COMPRESSED: 2, POINT_CONVERSION_UNCOMPRESSED: 4, POINT_CONVERSION_HYBRID: 6 };
  });
  Xt = {};
  Ja(Xt, { DEFAULT_ENCODING: () => Ga, default: () => Wq, getCurves: () => dw, getRandomValues: () => uw, randomUUID: () => lw, scrypt: () => Td, scryptSync: () => Id, timingSafeEqual: () => x0, webcrypto: () => cw });
  ot(Xt, rn(qd()));
  zq = rn(qd());
  Ga = "buffer";
  uw = (t) => crypto.getRandomValues(t);
  lw = () => crypto.randomUUID();
  Hq = ["p192", "p224", "p256", "p384", "p521", "curve25519", "ed25519", "secp256k1", "secp224r1", "prime256v1", "prime192v1", "ed25519", "secp384r1", "secp521r1"];
  x0 = "timingSafeEqual" in crypto ? (t, e) => {
    let { byteLength: r } = t, { byteLength: o } = e;
    if (typeof r != "number" || typeof o != "number")
      throw new TypeError("Input must be an array buffer view");
    if (r !== o)
      throw new RangeError("Input buffers must have the same length");
    return crypto.timingSafeEqual(t, e);
  } : undefined;
  Id = "scryptSync" in crypto ? (t, e, r, o) => {
    let f = crypto.scryptSync(t, e, r, o);
    return Ga !== "buffer" ? new Buffer(f).toString(Ga) : new Buffer(f);
  } : undefined;
  Td = "scryptSync" in crypto ? function(t, e, r, o, f) {
    if (typeof o == "function" && (f = o, o = undefined), typeof f != "function") {
      var p = new TypeError("callback must be a function");
      throw p.code = "ERR_INVALID_CALLBACK", p;
    }
    try {
      let m2 = crypto.scryptSync(t, e, r, o);
      process.nextTick(f, null, Ga !== "buffer" ? new Buffer(m2).toString(Ga) : new Buffer(m2));
    } catch (m2) {
      throw m2;
    }
  } : undefined;
  x0 && (Object.defineProperty(x0, "name", { value: "::bunternal::" }), Object.defineProperty(Td, "name", { value: "::bunternal::" }), Object.defineProperty(Id, "name", { value: "::bunternal::" }));
  cw = crypto;
  Wq = { ...zq, getRandomValues: uw, randomUUID: lw, timingSafeEqual: x0, scryptSync: Id, scrypt: Td, webcrypto: cw, getCurves: dw };
  /*!
   * The buffer module from node.js, for the browser.
   *
   * @author   Feross Aboukhadijeh <https://feross.org>
   * @license  MIT
   */
  /*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> */
  /*! safe-buffer. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */
});

// src/piper.js
var __dirname = "/home/xubuntu/bin/vits-web/src", __filename = "/home/xubuntu/bin/vits-web/src/piper.js";
var createPiperPhonemize = (() => {
  var _scriptDir = typeof document !== "undefined" && document.currentScript ? document.currentScript.src : undefined;
  if (typeof __filename !== "undefined")
    _scriptDir = _scriptDir || __filename;
  return function(moduleArg = {}) {
    var Module = moduleArg;
    var readyPromiseResolve, readyPromiseReject;
    Module["ready"] = new Promise((resolve, reject) => {
      readyPromiseResolve = resolve;
      readyPromiseReject = reject;
    });
    if (!Module.expectedDataFileDownloads) {
      Module.expectedDataFileDownloads = 0;
    }
    Module.expectedDataFileDownloads++;
    (function() {
      if (Module["ENVIRONMENT_IS_PTHREAD"] || Module["$ww"])
        return;
      var loadPackage = function(metadata) {
        var PACKAGE_PATH = "";
        if (typeof window === "object") {
          PACKAGE_PATH = window["encodeURIComponent"](window.location.pathname.toString().substring(0, window.location.pathname.toString().lastIndexOf("/")) + "/");
        } else if (typeof process === "undefined" && typeof location !== "undefined") {
          PACKAGE_PATH = encodeURIComponent(location.pathname.toString().substring(0, location.pathname.toString().lastIndexOf("/")) + "/");
        }
        var PACKAGE_NAME = "piper_phonemize.data";
        var REMOTE_PACKAGE_BASE = "piper_phonemize.data";
        if (typeof Module["locateFilePackage"] === "function" && !Module["locateFile"]) {
          Module["locateFile"] = Module["locateFilePackage"];
          err("warning: you defined Module.locateFilePackage, that has been renamed to Module.locateFile (using your locateFilePackage for now)");
        }
        var REMOTE_PACKAGE_NAME = Module["locateFile"] ? Module["locateFile"](REMOTE_PACKAGE_BASE, "") : REMOTE_PACKAGE_BASE;
        var REMOTE_PACKAGE_SIZE = metadata["remote_package_size"];
        function fetchRemotePackage(packageName, packageSize, callback, errback) {
          if (typeof process === "object" && typeof process.versions === "object" && typeof process.versions.node === "string") {
            (()=>({})).readFile(packageName, function(err2, contents) {
              if (err2) {
                errback(err2);
              } else {
                callback(contents.buffer);
              }
            });
            return;
          }
          var xhr = new XMLHttpRequest;
          xhr.open("GET", packageName, true);
          xhr.responseType = "arraybuffer";
          xhr.onprogress = function(event) {
            var url = packageName;
            var size = packageSize;
            if (event.total)
              size = event.total;
            if (event.loaded) {
              if (!xhr.addedTotal) {
                xhr.addedTotal = true;
                if (!Module.dataFileDownloads)
                  Module.dataFileDownloads = {};
                Module.dataFileDownloads[url] = { loaded: event.loaded, total: size };
              } else {
                Module.dataFileDownloads[url].loaded = event.loaded;
              }
              var total = 0;
              var loaded = 0;
              var num = 0;
              for (var download in Module.dataFileDownloads) {
                var data = Module.dataFileDownloads[download];
                total += data.total;
                loaded += data.loaded;
                num++;
              }
              total = Math.ceil(total * Module.expectedDataFileDownloads / num);
              if (Module["setStatus"])
                Module["setStatus"](`Downloading data... (${loaded}/${total})`);
            } else if (!Module.dataFileDownloads) {
              if (Module["setStatus"])
                Module["setStatus"]("Downloading data...");
            }
          };
          xhr.onerror = function(event) {
            throw new Error("NetworkError for: " + packageName);
          };
          xhr.onload = function(event) {
            if (xhr.status == 200 || xhr.status == 304 || xhr.status == 206 || xhr.status == 0 && xhr.response) {
              var packageData = xhr.response;
              callback(packageData);
            } else {
              throw new Error(xhr.statusText + " : " + xhr.responseURL);
            }
          };
          xhr.send(null);
        }
        function handleError(error) {
          console.error("package error:", error);
        }
        var fetchedCallback = null;
        var fetched = Module["getPreloadedPackage"] ? Module["getPreloadedPackage"](REMOTE_PACKAGE_NAME, REMOTE_PACKAGE_SIZE) : null;
        if (!fetched)
          fetchRemotePackage(REMOTE_PACKAGE_NAME, REMOTE_PACKAGE_SIZE, function(data) {
            if (fetchedCallback) {
              fetchedCallback(data);
              fetchedCallback = null;
            } else {
              fetched = data;
            }
          }, handleError);
        function runWithFS() {
          function assert2(check, msg) {
            if (!check)
              throw msg + new Error().stack;
          }
          Module["FS_createPath"]("/", "espeak-ng-data", true, true);
          Module["FS_createPath"]("/espeak-ng-data", "lang", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "aav", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "art", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "azc", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "bat", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "bnt", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "ccs", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "cel", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "cus", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "dra", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "esx", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "gmq", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "gmw", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "grk", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "inc", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "ine", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "ira", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "iro", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "itc", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "jpx", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "map", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "miz", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "myn", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "poz", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "roa", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "sai", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "sem", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "sit", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "tai", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "trk", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "urj", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "zle", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "zls", true, true);
          Module["FS_createPath"]("/espeak-ng-data/lang", "zlw", true, true);
          Module["FS_createPath"]("/espeak-ng-data", "mbrola_ph", true, true);
          Module["FS_createPath"]("/espeak-ng-data", "voices", true, true);
          Module["FS_createPath"]("/espeak-ng-data/voices", "!v", true, true);
          Module["FS_createPath"]("/espeak-ng-data/voices", "mb", true, true);
          function DataRequest(start, end, audio) {
            this.start = start;
            this.end = end;
            this.audio = audio;
          }
          DataRequest.prototype = { requests: {}, open: function(mode, name) {
            this.name = name;
            this.requests[name] = this;
            Module["addRunDependency"](`fp ${this.name}`);
          }, send: function() {
          }, onload: function() {
            var byteArray = this.byteArray.subarray(this.start, this.end);
            this.finish(byteArray);
          }, finish: function(byteArray) {
            var that = this;
            Module["FS_createDataFile"](this.name, null, byteArray, true, true, true);
            Module["removeRunDependency"](`fp ${that.name}`);
            this.requests[this.name] = null;
          } };
          var files = metadata["files"];
          for (var i = 0;i < files.length; ++i) {
            new DataRequest(files[i]["start"], files[i]["end"], files[i]["audio"] || 0).open("GET", files[i]["filename"]);
          }
          function processPackageData(arrayBuffer) {
            assert2(arrayBuffer, "Loading data file failed.");
            assert2(arrayBuffer.constructor.name === ArrayBuffer.name, "bad input to processPackageData");
            var byteArray = new Uint8Array(arrayBuffer);
            DataRequest.prototype.byteArray = byteArray;
            var files2 = metadata["files"];
            for (var i3 = 0;i3 < files2.length; ++i3) {
              DataRequest.prototype.requests[files2[i3].filename].onload();
            }
            Module["removeRunDependency"]("datafile_piper_phonemize.data");
          }
          Module["addRunDependency"]("datafile_piper_phonemize.data");
          if (!Module.preloadResults)
            Module.preloadResults = {};
          Module.preloadResults[PACKAGE_NAME] = { fromCache: false };
          if (fetched) {
            processPackageData(fetched);
            fetched = null;
          } else {
            fetchedCallback = processPackageData;
          }
        }
        if (Module["calledRun"]) {
          runWithFS();
        } else {
          if (!Module["preRun"])
            Module["preRun"] = [];
          Module["preRun"].push(runWithFS);
        }
      };
      loadPackage({ files: [{ filename: "/espeak-ng-data/af_dict", start: 0, end: 121473 }, { filename: "/espeak-ng-data/am_dict", start: 121473, end: 185351 }, { filename: "/espeak-ng-data/an_dict", start: 185351, end: 192042 }, { filename: "/espeak-ng-data/ar_dict", start: 192042, end: 670207 }, { filename: "/espeak-ng-data/as_dict", start: 670207, end: 675212 }, { filename: "/espeak-ng-data/az_dict", start: 675212, end: 718985 }, { filename: "/espeak-ng-data/ba_dict", start: 718985, end: 721083 }, { filename: "/espeak-ng-data/be_dict", start: 721083, end: 723735 }, { filename: "/espeak-ng-data/bg_dict", start: 723735, end: 810786 }, { filename: "/espeak-ng-data/bn_dict", start: 810786, end: 900765 }, { filename: "/espeak-ng-data/bpy_dict", start: 900765, end: 905991 }, { filename: "/espeak-ng-data/bs_dict", start: 905991, end: 953059 }, { filename: "/espeak-ng-data/ca_dict", start: 953059, end: 998625 }, { filename: "/espeak-ng-data/chr_dict", start: 998625, end: 1001484 }, { filename: "/espeak-ng-data/cmn_dict", start: 1001484, end: 2567819 }, { filename: "/espeak-ng-data/cs_dict", start: 2567819, end: 2617464 }, { filename: "/espeak-ng-data/cv_dict", start: 2617464, end: 2618808 }, { filename: "/espeak-ng-data/cy_dict", start: 2618808, end: 2661938 }, { filename: "/espeak-ng-data/da_dict", start: 2661938, end: 2907225 }, { filename: "/espeak-ng-data/de_dict", start: 2907225, end: 2975501 }, { filename: "/espeak-ng-data/el_dict", start: 2975501, end: 3048342 }, { filename: "/espeak-ng-data/en_dict", start: 3048342, end: 3215286 }, { filename: "/espeak-ng-data/eo_dict", start: 3215286, end: 3219952 }, { filename: "/espeak-ng-data/es_dict", start: 3219952, end: 3269204 }, { filename: "/espeak-ng-data/et_dict", start: 3269204, end: 3313467 }, { filename: "/espeak-ng-data/eu_dict", start: 3313467, end: 3362308 }, { filename: "/espeak-ng-data/fa_dict", start: 3362308, end: 3655543 }, { filename: "/espeak-ng-data/fi_dict", start: 3655543, end: 3699471 }, { filename: "/espeak-ng-data/fr_dict", start: 3699471, end: 3763198 }, { filename: "/espeak-ng-data/ga_dict", start: 3763198, end: 3815871 }, { filename: "/espeak-ng-data/gd_dict", start: 3815871, end: 3864992 }, { filename: "/espeak-ng-data/gn_dict", start: 3864992, end: 3868240 }, { filename: "/espeak-ng-data/grc_dict", start: 3868240, end: 3871673 }, { filename: "/espeak-ng-data/gu_dict", start: 3871673, end: 3954153 }, { filename: "/espeak-ng-data/hak_dict", start: 3954153, end: 3957488 }, { filename: "/espeak-ng-data/haw_dict", start: 3957488, end: 3959931 }, { filename: "/espeak-ng-data/he_dict", start: 3959931, end: 3966894 }, { filename: "/espeak-ng-data/hi_dict", start: 3966894, end: 4059037 }, { filename: "/espeak-ng-data/hr_dict", start: 4059037, end: 4108425 }, { filename: "/espeak-ng-data/ht_dict", start: 4108425, end: 4110228 }, { filename: "/espeak-ng-data/hu_dict", start: 4110228, end: 4264013 }, { filename: "/espeak-ng-data/hy_dict", start: 4264013, end: 4326276 }, { filename: "/espeak-ng-data/ia_dict", start: 4326276, end: 4657551 }, { filename: "/espeak-ng-data/id_dict", start: 4657551, end: 4701009 }, { filename: "/espeak-ng-data/intonations", start: 4701009, end: 4703049 }, { filename: "/espeak-ng-data/io_dict", start: 4703049, end: 4705214 }, { filename: "/espeak-ng-data/is_dict", start: 4705214, end: 4749568 }, { filename: "/espeak-ng-data/it_dict", start: 4749568, end: 4902457 }, { filename: "/espeak-ng-data/ja_dict", start: 4902457, end: 4950109 }, { filename: "/espeak-ng-data/jbo_dict", start: 4950109, end: 4952352 }, { filename: "/espeak-ng-data/ka_dict", start: 4952352, end: 5040127 }, { filename: "/espeak-ng-data/kk_dict", start: 5040127, end: 5041986 }, { filename: "/espeak-ng-data/kl_dict", start: 5041986, end: 5044824 }, { filename: "/espeak-ng-data/kn_dict", start: 5044824, end: 5132652 }, { filename: "/espeak-ng-data/ko_dict", start: 5132652, end: 5180175 }, { filename: "/espeak-ng-data/kok_dict", start: 5180175, end: 5186569 }, { filename: "/espeak-ng-data/ku_dict", start: 5186569, end: 5188834 }, { filename: "/espeak-ng-data/ky_dict", start: 5188834, end: 5253811 }, { filename: "/espeak-ng-data/la_dict", start: 5253811, end: 5257617 }, { filename: "/espeak-ng-data/lang/aav/vi", start: 5257617, end: 5257728 }, { filename: "/espeak-ng-data/lang/aav/vi-VN-x-central", start: 5257728, end: 5257871 }, { filename: "/espeak-ng-data/lang/aav/vi-VN-x-south", start: 5257871, end: 5258013 }, { filename: "/espeak-ng-data/lang/art/eo", start: 5258013, end: 5258054 }, { filename: "/espeak-ng-data/lang/art/ia", start: 5258054, end: 5258083 }, { filename: "/espeak-ng-data/lang/art/io", start: 5258083, end: 5258133 }, { filename: "/espeak-ng-data/lang/art/jbo", start: 5258133, end: 5258202 }, { filename: "/espeak-ng-data/lang/art/lfn", start: 5258202, end: 5258337 }, { filename: "/espeak-ng-data/lang/art/piqd", start: 5258337, end: 5258393 }, { filename: "/espeak-ng-data/lang/art/py", start: 5258393, end: 5258533 }, { filename: "/espeak-ng-data/lang/art/qdb", start: 5258533, end: 5258590 }, { filename: "/espeak-ng-data/lang/art/qya", start: 5258590, end: 5258763 }, { filename: "/espeak-ng-data/lang/art/sjn", start: 5258763, end: 5258938 }, { filename: "/espeak-ng-data/lang/azc/nci", start: 5258938, end: 5259052 }, { filename: "/espeak-ng-data/lang/bat/lt", start: 5259052, end: 5259080 }, { filename: "/espeak-ng-data/lang/bat/ltg", start: 5259080, end: 5259392 }, { filename: "/espeak-ng-data/lang/bat/lv", start: 5259392, end: 5259621 }, { filename: "/espeak-ng-data/lang/bnt/sw", start: 5259621, end: 5259662 }, { filename: "/espeak-ng-data/lang/bnt/tn", start: 5259662, end: 5259704 }, { filename: "/espeak-ng-data/lang/ccs/ka", start: 5259704, end: 5259828 }, { filename: "/espeak-ng-data/lang/cel/cy", start: 5259828, end: 5259865 }, { filename: "/espeak-ng-data/lang/cel/ga", start: 5259865, end: 5259931 }, { filename: "/espeak-ng-data/lang/cel/gd", start: 5259931, end: 5259982 }, { filename: "/espeak-ng-data/lang/cus/om", start: 5259982, end: 5260021 }, { filename: "/espeak-ng-data/lang/dra/kn", start: 5260021, end: 5260076 }, { filename: "/espeak-ng-data/lang/dra/ml", start: 5260076, end: 5260133 }, { filename: "/espeak-ng-data/lang/dra/ta", start: 5260133, end: 5260184 }, { filename: "/espeak-ng-data/lang/dra/te", start: 5260184, end: 5260254 }, { filename: "/espeak-ng-data/lang/esx/kl", start: 5260254, end: 5260284 }, { filename: "/espeak-ng-data/lang/eu", start: 5260284, end: 5260338 }, { filename: "/espeak-ng-data/lang/gmq/da", start: 5260338, end: 5260381 }, { filename: "/espeak-ng-data/lang/gmq/is", start: 5260381, end: 5260408 }, { filename: "/espeak-ng-data/lang/gmq/nb", start: 5260408, end: 5260495 }, { filename: "/espeak-ng-data/lang/gmq/sv", start: 5260495, end: 5260520 }, { filename: "/espeak-ng-data/lang/gmw/af", start: 5260520, end: 5260643 }, { filename: "/espeak-ng-data/lang/gmw/de", start: 5260643, end: 5260685 }, { filename: "/espeak-ng-data/lang/gmw/en", start: 5260685, end: 5260825 }, { filename: "/espeak-ng-data/lang/gmw/en-029", start: 5260825, end: 5261160 }, { filename: "/espeak-ng-data/lang/gmw/en-GB-scotland", start: 5261160, end: 5261455 }, { filename: "/espeak-ng-data/lang/gmw/en-GB-x-gbclan", start: 5261455, end: 5261693 }, { filename: "/espeak-ng-data/lang/gmw/en-GB-x-gbcwmd", start: 5261693, end: 5261881 }, { filename: "/espeak-ng-data/lang/gmw/en-GB-x-rp", start: 5261881, end: 5262130 }, { filename: "/espeak-ng-data/lang/gmw/en-US", start: 5262130, end: 5262387 }, { filename: "/espeak-ng-data/lang/gmw/en-US-nyc", start: 5262387, end: 5262658 }, { filename: "/espeak-ng-data/lang/gmw/lb", start: 5262658, end: 5262689 }, { filename: "/espeak-ng-data/lang/gmw/nl", start: 5262689, end: 5262712 }, { filename: "/espeak-ng-data/lang/grk/el", start: 5262712, end: 5262735 }, { filename: "/espeak-ng-data/lang/grk/grc", start: 5262735, end: 5262834 }, { filename: "/espeak-ng-data/lang/inc/as", start: 5262834, end: 5262876 }, { filename: "/espeak-ng-data/lang/inc/bn", start: 5262876, end: 5262901 }, { filename: "/espeak-ng-data/lang/inc/bpy", start: 5262901, end: 5262940 }, { filename: "/espeak-ng-data/lang/inc/gu", start: 5262940, end: 5262982 }, { filename: "/espeak-ng-data/lang/inc/hi", start: 5262982, end: 5263005 }, { filename: "/espeak-ng-data/lang/inc/kok", start: 5263005, end: 5263031 }, { filename: "/espeak-ng-data/lang/inc/mr", start: 5263031, end: 5263072 }, { filename: "/espeak-ng-data/lang/inc/ne", start: 5263072, end: 5263109 }, { filename: "/espeak-ng-data/lang/inc/or", start: 5263109, end: 5263148 }, { filename: "/espeak-ng-data/lang/inc/pa", start: 5263148, end: 5263173 }, { filename: "/espeak-ng-data/lang/inc/sd", start: 5263173, end: 5263239 }, { filename: "/espeak-ng-data/lang/inc/si", start: 5263239, end: 5263294 }, { filename: "/espeak-ng-data/lang/inc/ur", start: 5263294, end: 5263388 }, { filename: "/espeak-ng-data/lang/ine/hy", start: 5263388, end: 5263449 }, { filename: "/espeak-ng-data/lang/ine/hyw", start: 5263449, end: 5263814 }, { filename: "/espeak-ng-data/lang/ine/sq", start: 5263814, end: 5263917 }, { filename: "/espeak-ng-data/lang/ira/fa", start: 5263917, end: 5264007 }, { filename: "/espeak-ng-data/lang/ira/fa-Latn", start: 5264007, end: 5264276 }, { filename: "/espeak-ng-data/lang/ira/ku", start: 5264276, end: 5264316 }, { filename: "/espeak-ng-data/lang/iro/chr", start: 5264316, end: 5264885 }, { filename: "/espeak-ng-data/lang/itc/la", start: 5264885, end: 5265182 }, { filename: "/espeak-ng-data/lang/jpx/ja", start: 5265182, end: 5265234 }, { filename: "/espeak-ng-data/lang/ko", start: 5265234, end: 5265285 }, { filename: "/espeak-ng-data/lang/map/haw", start: 5265285, end: 5265327 }, { filename: "/espeak-ng-data/lang/miz/mto", start: 5265327, end: 5265510 }, { filename: "/espeak-ng-data/lang/myn/quc", start: 5265510, end: 5265720 }, { filename: "/espeak-ng-data/lang/poz/id", start: 5265720, end: 5265854 }, { filename: "/espeak-ng-data/lang/poz/mi", start: 5265854, end: 5266221 }, { filename: "/espeak-ng-data/lang/poz/ms", start: 5266221, end: 5266651 }, { filename: "/espeak-ng-data/lang/qu", start: 5266651, end: 5266739 }, { filename: "/espeak-ng-data/lang/roa/an", start: 5266739, end: 5266766 }, { filename: "/espeak-ng-data/lang/roa/ca", start: 5266766, end: 5266791 }, { filename: "/espeak-ng-data/lang/roa/es", start: 5266791, end: 5266854 }, { filename: "/espeak-ng-data/lang/roa/es-419", start: 5266854, end: 5267021 }, { filename: "/espeak-ng-data/lang/roa/fr", start: 5267021, end: 5267100 }, { filename: "/espeak-ng-data/lang/roa/fr-BE", start: 5267100, end: 5267184 }, { filename: "/espeak-ng-data/lang/roa/fr-CH", start: 5267184, end: 5267270 }, { filename: "/espeak-ng-data/lang/roa/ht", start: 5267270, end: 5267410 }, { filename: "/espeak-ng-data/lang/roa/it", start: 5267410, end: 5267519 }, { filename: "/espeak-ng-data/lang/roa/pap", start: 5267519, end: 5267581 }, { filename: "/espeak-ng-data/lang/roa/pt", start: 5267581, end: 5267676 }, { filename: "/espeak-ng-data/lang/roa/pt-BR", start: 5267676, end: 5267785 }, { filename: "/espeak-ng-data/lang/roa/ro", start: 5267785, end: 5267811 }, { filename: "/espeak-ng-data/lang/sai/gn", start: 5267811, end: 5267858 }, { filename: "/espeak-ng-data/lang/sem/am", start: 5267858, end: 5267899 }, { filename: "/espeak-ng-data/lang/sem/ar", start: 5267899, end: 5267949 }, { filename: "/espeak-ng-data/lang/sem/he", start: 5267949, end: 5267989 }, { filename: "/espeak-ng-data/lang/sem/mt", start: 5267989, end: 5268030 }, { filename: "/espeak-ng-data/lang/sit/cmn", start: 5268030, end: 5268716 }, { filename: "/espeak-ng-data/lang/sit/cmn-Latn-pinyin", start: 5268716, end: 5268877 }, { filename: "/espeak-ng-data/lang/sit/hak", start: 5268877, end: 5269005 }, { filename: "/espeak-ng-data/lang/sit/my", start: 5269005, end: 5269061 }, { filename: "/espeak-ng-data/lang/sit/yue", start: 5269061, end: 5269255 }, { filename: "/espeak-ng-data/lang/sit/yue-Latn-jyutping", start: 5269255, end: 5269468 }, { filename: "/espeak-ng-data/lang/tai/shn", start: 5269468, end: 5269560 }, { filename: "/espeak-ng-data/lang/tai/th", start: 5269560, end: 5269597 }, { filename: "/espeak-ng-data/lang/trk/az", start: 5269597, end: 5269642 }, { filename: "/espeak-ng-data/lang/trk/ba", start: 5269642, end: 5269667 }, { filename: "/espeak-ng-data/lang/trk/cv", start: 5269667, end: 5269707 }, { filename: "/espeak-ng-data/lang/trk/kk", start: 5269707, end: 5269747 }, { filename: "/espeak-ng-data/lang/trk/ky", start: 5269747, end: 5269790 }, { filename: "/espeak-ng-data/lang/trk/nog", start: 5269790, end: 5269829 }, { filename: "/espeak-ng-data/lang/trk/tk", start: 5269829, end: 5269854 }, { filename: "/espeak-ng-data/lang/trk/tr", start: 5269854, end: 5269879 }, { filename: "/espeak-ng-data/lang/trk/tt", start: 5269879, end: 5269902 }, { filename: "/espeak-ng-data/lang/trk/ug", start: 5269902, end: 5269926 }, { filename: "/espeak-ng-data/lang/trk/uz", start: 5269926, end: 5269965 }, { filename: "/espeak-ng-data/lang/urj/et", start: 5269965, end: 5270202 }, { filename: "/espeak-ng-data/lang/urj/fi", start: 5270202, end: 5270439 }, { filename: "/espeak-ng-data/lang/urj/hu", start: 5270439, end: 5270512 }, { filename: "/espeak-ng-data/lang/urj/smj", start: 5270512, end: 5270557 }, { filename: "/espeak-ng-data/lang/zle/be", start: 5270557, end: 5270609 }, { filename: "/espeak-ng-data/lang/zle/ru", start: 5270609, end: 5270666 }, { filename: "/espeak-ng-data/lang/zle/ru-LV", start: 5270666, end: 5270946 }, { filename: "/espeak-ng-data/lang/zle/ru-cl", start: 5270946, end: 5271037 }, { filename: "/espeak-ng-data/lang/zle/uk", start: 5271037, end: 5271134 }, { filename: "/espeak-ng-data/lang/zls/bg", start: 5271134, end: 5271245 }, { filename: "/espeak-ng-data/lang/zls/bs", start: 5271245, end: 5271475 }, { filename: "/espeak-ng-data/lang/zls/hr", start: 5271475, end: 5271737 }, { filename: "/espeak-ng-data/lang/zls/mk", start: 5271737, end: 5271765 }, { filename: "/espeak-ng-data/lang/zls/sl", start: 5271765, end: 5271808 }, { filename: "/espeak-ng-data/lang/zls/sr", start: 5271808, end: 5272058 }, { filename: "/espeak-ng-data/lang/zlw/cs", start: 5272058, end: 5272081 }, { filename: "/espeak-ng-data/lang/zlw/pl", start: 5272081, end: 5272119 }, { filename: "/espeak-ng-data/lang/zlw/sk", start: 5272119, end: 5272143 }, { filename: "/espeak-ng-data/lb_dict", start: 5272143, end: 5960074 }, { filename: "/espeak-ng-data/lfn_dict", start: 5960074, end: 5962867 }, { filename: "/espeak-ng-data/lt_dict", start: 5962867, end: 6012757 }, { filename: "/espeak-ng-data/lv_dict", start: 6012757, end: 6079094 }, { filename: "/espeak-ng-data/mbrola_ph/af1_phtrans", start: 6079094, end: 6080730 }, { filename: "/espeak-ng-data/mbrola_ph/ar1_phtrans", start: 6080730, end: 6082342 }, { filename: "/espeak-ng-data/mbrola_ph/ar2_phtrans", start: 6082342, end: 6083954 }, { filename: "/espeak-ng-data/mbrola_ph/ca_phtrans", start: 6083954, end: 6085950 }, { filename: "/espeak-ng-data/mbrola_ph/cmn_phtrans", start: 6085950, end: 6087442 }, { filename: "/espeak-ng-data/mbrola_ph/cr1_phtrans", start: 6087442, end: 6089606 }, { filename: "/espeak-ng-data/mbrola_ph/cs_phtrans", start: 6089606, end: 6090186 }, { filename: "/espeak-ng-data/mbrola_ph/de2_phtrans", start: 6090186, end: 6091918 }, { filename: "/espeak-ng-data/mbrola_ph/de4_phtrans", start: 6091918, end: 6093722 }, { filename: "/espeak-ng-data/mbrola_ph/de6_phtrans", start: 6093722, end: 6095118 }, { filename: "/espeak-ng-data/mbrola_ph/de8_phtrans", start: 6095118, end: 6096274 }, { filename: "/espeak-ng-data/mbrola_ph/ee1_phtrans", start: 6096274, end: 6097718 }, { filename: "/espeak-ng-data/mbrola_ph/en1_phtrans", start: 6097718, end: 6098514 }, { filename: "/espeak-ng-data/mbrola_ph/es3_phtrans", start: 6098514, end: 6099574 }, { filename: "/espeak-ng-data/mbrola_ph/es4_phtrans", start: 6099574, end: 6100682 }, { filename: "/espeak-ng-data/mbrola_ph/es_phtrans", start: 6100682, end: 6102414 }, { filename: "/espeak-ng-data/mbrola_ph/fr_phtrans", start: 6102414, end: 6104386 }, { filename: "/espeak-ng-data/mbrola_ph/gr1_phtrans", start: 6104386, end: 6106598 }, { filename: "/espeak-ng-data/mbrola_ph/gr2_phtrans", start: 6106598, end: 6108810 }, { filename: "/espeak-ng-data/mbrola_ph/grc-de6_phtrans", start: 6108810, end: 6109294 }, { filename: "/espeak-ng-data/mbrola_ph/he_phtrans", start: 6109294, end: 6110042 }, { filename: "/espeak-ng-data/mbrola_ph/hn1_phtrans", start: 6110042, end: 6110574 }, { filename: "/espeak-ng-data/mbrola_ph/hu1_phtrans", start: 6110574, end: 6112018 }, { filename: "/espeak-ng-data/mbrola_ph/ic1_phtrans", start: 6112018, end: 6113150 }, { filename: "/espeak-ng-data/mbrola_ph/id1_phtrans", start: 6113150, end: 6114858 }, { filename: "/espeak-ng-data/mbrola_ph/in_phtrans", start: 6114858, end: 6116302 }, { filename: "/espeak-ng-data/mbrola_ph/ir1_phtrans", start: 6116302, end: 6122114 }, { filename: "/espeak-ng-data/mbrola_ph/it1_phtrans", start: 6122114, end: 6123438 }, { filename: "/espeak-ng-data/mbrola_ph/it3_phtrans", start: 6123438, end: 6124330 }, { filename: "/espeak-ng-data/mbrola_ph/jp_phtrans", start: 6124330, end: 6125366 }, { filename: "/espeak-ng-data/mbrola_ph/la1_phtrans", start: 6125366, end: 6126114 }, { filename: "/espeak-ng-data/mbrola_ph/lt_phtrans", start: 6126114, end: 6127174 }, { filename: "/espeak-ng-data/mbrola_ph/ma1_phtrans", start: 6127174, end: 6128114 }, { filename: "/espeak-ng-data/mbrola_ph/mx1_phtrans", start: 6128114, end: 6129918 }, { filename: "/espeak-ng-data/mbrola_ph/mx2_phtrans", start: 6129918, end: 6131746 }, { filename: "/espeak-ng-data/mbrola_ph/nl_phtrans", start: 6131746, end: 6133430 }, { filename: "/espeak-ng-data/mbrola_ph/nz1_phtrans", start: 6133430, end: 6134154 }, { filename: "/espeak-ng-data/mbrola_ph/pl1_phtrans", start: 6134154, end: 6135742 }, { filename: "/espeak-ng-data/mbrola_ph/pt1_phtrans", start: 6135742, end: 6137834 }, { filename: "/espeak-ng-data/mbrola_ph/ptbr4_phtrans", start: 6137834, end: 6140190 }, { filename: "/espeak-ng-data/mbrola_ph/ptbr_phtrans", start: 6140190, end: 6142714 }, { filename: "/espeak-ng-data/mbrola_ph/ro1_phtrans", start: 6142714, end: 6144878 }, { filename: "/espeak-ng-data/mbrola_ph/sv2_phtrans", start: 6144878, end: 6146466 }, { filename: "/espeak-ng-data/mbrola_ph/sv_phtrans", start: 6146466, end: 6148054 }, { filename: "/espeak-ng-data/mbrola_ph/tl1_phtrans", start: 6148054, end: 6148826 }, { filename: "/espeak-ng-data/mbrola_ph/tr1_phtrans", start: 6148826, end: 6149190 }, { filename: "/espeak-ng-data/mbrola_ph/us3_phtrans", start: 6149190, end: 6150346 }, { filename: "/espeak-ng-data/mbrola_ph/us_phtrans", start: 6150346, end: 6151574 }, { filename: "/espeak-ng-data/mbrola_ph/vz_phtrans", start: 6151574, end: 6153858 }, { filename: "/espeak-ng-data/mi_dict", start: 6153858, end: 6155204 }, { filename: "/espeak-ng-data/mk_dict", start: 6155204, end: 6219063 }, { filename: "/espeak-ng-data/ml_dict", start: 6219063, end: 6311408 }, { filename: "/espeak-ng-data/mr_dict", start: 6311408, end: 6398799 }, { filename: "/espeak-ng-data/ms_dict", start: 6398799, end: 6452340 }, { filename: "/espeak-ng-data/mt_dict", start: 6452340, end: 6456724 }, { filename: "/espeak-ng-data/mto_dict", start: 6456724, end: 6460684 }, { filename: "/espeak-ng-data/my_dict", start: 6460684, end: 6556632 }, { filename: "/espeak-ng-data/nci_dict", start: 6556632, end: 6558166 }, { filename: "/espeak-ng-data/ne_dict", start: 6558166, end: 6653543 }, { filename: "/espeak-ng-data/nl_dict", start: 6653543, end: 6719522 }, { filename: "/espeak-ng-data/no_dict", start: 6719522, end: 6723700 }, { filename: "/espeak-ng-data/nog_dict", start: 6723700, end: 6726994 }, { filename: "/espeak-ng-data/om_dict", start: 6726994, end: 6729296 }, { filename: "/espeak-ng-data/or_dict", start: 6729296, end: 6818542 }, { filename: "/espeak-ng-data/pa_dict", start: 6818542, end: 6898495 }, { filename: "/espeak-ng-data/pap_dict", start: 6898495, end: 6900623 }, { filename: "/espeak-ng-data/phondata", start: 6900623, end: 7451047 }, { filename: "/espeak-ng-data/phondata-manifest", start: 7451047, end: 7472868 }, { filename: "/espeak-ng-data/phonindex", start: 7472868, end: 7511942 }, { filename: "/espeak-ng-data/phontab", start: 7511942, end: 7567738 }, { filename: "/espeak-ng-data/piqd_dict", start: 7567738, end: 7569448 }, { filename: "/espeak-ng-data/pl_dict", start: 7569448, end: 7646178 }, { filename: "/espeak-ng-data/pt_dict", start: 7646178, end: 7713995 }, { filename: "/espeak-ng-data/py_dict", start: 7713995, end: 7716404 }, { filename: "/espeak-ng-data/qdb_dict", start: 7716404, end: 7719432 }, { filename: "/espeak-ng-data/qu_dict", start: 7719432, end: 7721351 }, { filename: "/espeak-ng-data/quc_dict", start: 7721351, end: 7722801 }, { filename: "/espeak-ng-data/qya_dict", start: 7722801, end: 7724740 }, { filename: "/espeak-ng-data/ro_dict", start: 7724740, end: 7793278 }, { filename: "/espeak-ng-data/ru_dict", start: 7793278, end: 16325670 }, { filename: "/espeak-ng-data/sd_dict", start: 16325670, end: 16385598 }, { filename: "/espeak-ng-data/shn_dict", start: 16385598, end: 16473770 }, { filename: "/espeak-ng-data/si_dict", start: 16473770, end: 16559154 }, { filename: "/espeak-ng-data/sjn_dict", start: 16559154, end: 16560937 }, { filename: "/espeak-ng-data/sk_dict", start: 16560937, end: 16610939 }, { filename: "/espeak-ng-data/sl_dict", start: 16610939, end: 16655986 }, { filename: "/espeak-ng-data/smj_dict", start: 16655986, end: 16691081 }, { filename: "/espeak-ng-data/sq_dict", start: 16691081, end: 16736084 }, { filename: "/espeak-ng-data/sr_dict", start: 16736084, end: 16782916 }, { filename: "/espeak-ng-data/sv_dict", start: 16782916, end: 16830752 }, { filename: "/espeak-ng-data/sw_dict", start: 16830752, end: 16878556 }, { filename: "/espeak-ng-data/ta_dict", start: 16878556, end: 17088109 }, { filename: "/espeak-ng-data/te_dict", start: 17088109, end: 17182946 }, { filename: "/espeak-ng-data/th_dict", start: 17182946, end: 17185247 }, { filename: "/espeak-ng-data/tk_dict", start: 17185247, end: 17206115 }, { filename: "/espeak-ng-data/tn_dict", start: 17206115, end: 17209187 }, { filename: "/espeak-ng-data/tr_dict", start: 17209187, end: 17255980 }, { filename: "/espeak-ng-data/tt_dict", start: 17255980, end: 17258101 }, { filename: "/espeak-ng-data/ug_dict", start: 17258101, end: 17260171 }, { filename: "/espeak-ng-data/uk_dict", start: 17260171, end: 17263663 }, { filename: "/espeak-ng-data/ur_dict", start: 17263663, end: 17397219 }, { filename: "/espeak-ng-data/uz_dict", start: 17397219, end: 17399759 }, { filename: "/espeak-ng-data/vi_dict", start: 17399759, end: 17452367 }, { filename: "/espeak-ng-data/voices/!v/Alex", start: 17452367, end: 17452495 }, { filename: "/espeak-ng-data/voices/!v/Alicia", start: 17452495, end: 17452969 }, { filename: "/espeak-ng-data/voices/!v/Andrea", start: 17452969, end: 17453326 }, { filename: "/espeak-ng-data/voices/!v/Andy", start: 17453326, end: 17453646 }, { filename: "/espeak-ng-data/voices/!v/Annie", start: 17453646, end: 17453961 }, { filename: "/espeak-ng-data/voices/!v/AnxiousAndy", start: 17453961, end: 17454322 }, { filename: "/espeak-ng-data/voices/!v/Demonic", start: 17454322, end: 17458180 }, { filename: "/espeak-ng-data/voices/!v/Denis", start: 17458180, end: 17458485 }, { filename: "/espeak-ng-data/voices/!v/Diogo", start: 17458485, end: 17458864 }, { filename: "/espeak-ng-data/voices/!v/Gene", start: 17458864, end: 17459145 }, { filename: "/espeak-ng-data/voices/!v/Gene2", start: 17459145, end: 17459428 }, { filename: "/espeak-ng-data/voices/!v/Henrique", start: 17459428, end: 17459809 }, { filename: "/espeak-ng-data/voices/!v/Hugo", start: 17459809, end: 17460187 }, { filename: "/espeak-ng-data/voices/!v/Jacky", start: 17460187, end: 17460454 }, { filename: "/espeak-ng-data/voices/!v/Lee", start: 17460454, end: 17460792 }, { filename: "/espeak-ng-data/voices/!v/Marco", start: 17460792, end: 17461259 }, { filename: "/espeak-ng-data/voices/!v/Mario", start: 17461259, end: 17461529 }, { filename: "/espeak-ng-data/voices/!v/Michael", start: 17461529, end: 17461799 }, { filename: "/espeak-ng-data/voices/!v/Mike", start: 17461799, end: 17461911 }, { filename: "/espeak-ng-data/voices/!v/Mr serious", start: 17461911, end: 17465104 }, { filename: "/espeak-ng-data/voices/!v/Nguyen", start: 17465104, end: 17465384 }, { filename: "/espeak-ng-data/voices/!v/Reed", start: 17465384, end: 17465586 }, { filename: "/espeak-ng-data/voices/!v/RicishayMax", start: 17465586, end: 17465819 }, { filename: "/espeak-ng-data/voices/!v/RicishayMax2", start: 17465819, end: 17466254 }, { filename: "/espeak-ng-data/voices/!v/RicishayMax3", start: 17466254, end: 17466689 }, { filename: "/espeak-ng-data/voices/!v/Storm", start: 17466689, end: 17467109 }, { filename: "/espeak-ng-data/voices/!v/Tweaky", start: 17467109, end: 17470298 }, { filename: "/espeak-ng-data/voices/!v/UniRobot", start: 17470298, end: 17470715 }, { filename: "/espeak-ng-data/voices/!v/adam", start: 17470715, end: 17470790 }, { filename: "/espeak-ng-data/voices/!v/anika", start: 17470790, end: 17471283 }, { filename: "/espeak-ng-data/voices/!v/anikaRobot", start: 17471283, end: 17471795 }, { filename: "/espeak-ng-data/voices/!v/announcer", start: 17471795, end: 17472095 }, { filename: "/espeak-ng-data/voices/!v/antonio", start: 17472095, end: 17472476 }, { filename: "/espeak-ng-data/voices/!v/aunty", start: 17472476, end: 17472834 }, { filename: "/espeak-ng-data/voices/!v/belinda", start: 17472834, end: 17473174 }, { filename: "/espeak-ng-data/voices/!v/benjamin", start: 17473174, end: 17473375 }, { filename: "/espeak-ng-data/voices/!v/boris", start: 17473375, end: 17473599 }, { filename: "/espeak-ng-data/voices/!v/caleb", start: 17473599, end: 17473656 }, { filename: "/espeak-ng-data/voices/!v/croak", start: 17473656, end: 17473749 }, { filename: "/espeak-ng-data/voices/!v/david", start: 17473749, end: 17473861 }, { filename: "/espeak-ng-data/voices/!v/ed", start: 17473861, end: 17474148 }, { filename: "/espeak-ng-data/voices/!v/edward", start: 17474148, end: 17474299 }, { filename: "/espeak-ng-data/voices/!v/edward2", start: 17474299, end: 17474451 }, { filename: "/espeak-ng-data/voices/!v/f1", start: 17474451, end: 17474775 }, { filename: "/espeak-ng-data/voices/!v/f2", start: 17474775, end: 17475132 }, { filename: "/espeak-ng-data/voices/!v/f3", start: 17475132, end: 17475507 }, { filename: "/espeak-ng-data/voices/!v/f4", start: 17475507, end: 17475857 }, { filename: "/espeak-ng-data/voices/!v/f5", start: 17475857, end: 17476289 }, { filename: "/espeak-ng-data/voices/!v/fast", start: 17476289, end: 17476438 }, { filename: "/espeak-ng-data/voices/!v/grandma", start: 17476438, end: 17476701 }, { filename: "/espeak-ng-data/voices/!v/grandpa", start: 17476701, end: 17476957 }, { filename: "/espeak-ng-data/voices/!v/gustave", start: 17476957, end: 17477210 }, { filename: "/espeak-ng-data/voices/!v/ian", start: 17477210, end: 17480378 }, { filename: "/espeak-ng-data/voices/!v/iven", start: 17480378, end: 17480639 }, { filename: "/espeak-ng-data/voices/!v/iven2", start: 17480639, end: 17480918 }, { filename: "/espeak-ng-data/voices/!v/iven3", start: 17480918, end: 17481180 }, { filename: "/espeak-ng-data/voices/!v/iven4", start: 17481180, end: 17481441 }, { filename: "/espeak-ng-data/voices/!v/john", start: 17481441, end: 17484627 }, { filename: "/espeak-ng-data/voices/!v/kaukovalta", start: 17484627, end: 17484988 }, { filename: "/espeak-ng-data/voices/!v/klatt", start: 17484988, end: 17485026 }, { filename: "/espeak-ng-data/voices/!v/klatt2", start: 17485026, end: 17485064 }, { filename: "/espeak-ng-data/voices/!v/klatt3", start: 17485064, end: 17485103 }, { filename: "/espeak-ng-data/voices/!v/klatt4", start: 17485103, end: 17485142 }, { filename: "/espeak-ng-data/voices/!v/klatt5", start: 17485142, end: 17485181 }, { filename: "/espeak-ng-data/voices/!v/klatt6", start: 17485181, end: 17485220 }, { filename: "/espeak-ng-data/voices/!v/linda", start: 17485220, end: 17485570 }, { filename: "/espeak-ng-data/voices/!v/m1", start: 17485570, end: 17485905 }, { filename: "/espeak-ng-data/voices/!v/m2", start: 17485905, end: 17486169 }, { filename: "/espeak-ng-data/voices/!v/m3", start: 17486169, end: 17486469 }, { filename: "/espeak-ng-data/voices/!v/m4", start: 17486469, end: 17486759 }, { filename: "/espeak-ng-data/voices/!v/m5", start: 17486759, end: 17487021 }, { filename: "/espeak-ng-data/voices/!v/m6", start: 17487021, end: 17487209 }, { filename: "/espeak-ng-data/voices/!v/m7", start: 17487209, end: 17487463 }, { filename: "/espeak-ng-data/voices/!v/m8", start: 17487463, end: 17487747 }, { filename: "/espeak-ng-data/voices/!v/marcelo", start: 17487747, end: 17487998 }, { filename: "/espeak-ng-data/voices/!v/max", start: 17487998, end: 17488223 }, { filename: "/espeak-ng-data/voices/!v/michel", start: 17488223, end: 17488627 }, { filename: "/espeak-ng-data/voices/!v/miguel", start: 17488627, end: 17489009 }, { filename: "/espeak-ng-data/voices/!v/mike2", start: 17489009, end: 17489197 }, { filename: "/espeak-ng-data/voices/!v/norbert", start: 17489197, end: 17492386 }, { filename: "/espeak-ng-data/voices/!v/pablo", start: 17492386, end: 17495528 }, { filename: "/espeak-ng-data/voices/!v/paul", start: 17495528, end: 17495812 }, { filename: "/espeak-ng-data/voices/!v/pedro", start: 17495812, end: 17496164 }, { filename: "/espeak-ng-data/voices/!v/quincy", start: 17496164, end: 17496518 }, { filename: "/espeak-ng-data/voices/!v/rob", start: 17496518, end: 17496783 }, { filename: "/espeak-ng-data/voices/!v/robert", start: 17496783, end: 17497057 }, { filename: "/espeak-ng-data/voices/!v/robosoft", start: 17497057, end: 17497508 }, { filename: "/espeak-ng-data/voices/!v/robosoft2", start: 17497508, end: 17497962 }, { filename: "/espeak-ng-data/voices/!v/robosoft3", start: 17497962, end: 17498417 }, { filename: "/espeak-ng-data/voices/!v/robosoft4", start: 17498417, end: 17498864 }, { filename: "/espeak-ng-data/voices/!v/robosoft5", start: 17498864, end: 17499309 }, { filename: "/espeak-ng-data/voices/!v/robosoft6", start: 17499309, end: 17499596 }, { filename: "/espeak-ng-data/voices/!v/robosoft7", start: 17499596, end: 17500006 }, { filename: "/espeak-ng-data/voices/!v/robosoft8", start: 17500006, end: 17500249 }, { filename: "/espeak-ng-data/voices/!v/sandro", start: 17500249, end: 17500779 }, { filename: "/espeak-ng-data/voices/!v/shelby", start: 17500779, end: 17501059 }, { filename: "/espeak-ng-data/voices/!v/steph", start: 17501059, end: 17501423 }, { filename: "/espeak-ng-data/voices/!v/steph2", start: 17501423, end: 17501790 }, { filename: "/espeak-ng-data/voices/!v/steph3", start: 17501790, end: 17502167 }, { filename: "/espeak-ng-data/voices/!v/travis", start: 17502167, end: 17502550 }, { filename: "/espeak-ng-data/voices/!v/victor", start: 17502550, end: 17502803 }, { filename: "/espeak-ng-data/voices/!v/whisper", start: 17502803, end: 17502989 }, { filename: "/espeak-ng-data/voices/!v/whisperf", start: 17502989, end: 17503381 }, { filename: "/espeak-ng-data/voices/!v/zac", start: 17503381, end: 17503656 }, { filename: "/espeak-ng-data/voices/mb/mb-af1", start: 17503656, end: 17503744 }, { filename: "/espeak-ng-data/voices/mb/mb-af1-en", start: 17503744, end: 17503827 }, { filename: "/espeak-ng-data/voices/mb/mb-ar1", start: 17503827, end: 17503911 }, { filename: "/espeak-ng-data/voices/mb/mb-ar2", start: 17503911, end: 17503995 }, { filename: "/espeak-ng-data/voices/mb/mb-br1", start: 17503995, end: 17504127 }, { filename: "/espeak-ng-data/voices/mb/mb-br2", start: 17504127, end: 17504263 }, { filename: "/espeak-ng-data/voices/mb/mb-br3", start: 17504263, end: 17504395 }, { filename: "/espeak-ng-data/voices/mb/mb-br4", start: 17504395, end: 17504531 }, { filename: "/espeak-ng-data/voices/mb/mb-ca1", start: 17504531, end: 17504636 }, { filename: "/espeak-ng-data/voices/mb/mb-ca2", start: 17504636, end: 17504741 }, { filename: "/espeak-ng-data/voices/mb/mb-cn1", start: 17504741, end: 17504833 }, { filename: "/espeak-ng-data/voices/mb/mb-cr1", start: 17504833, end: 17504944 }, { filename: "/espeak-ng-data/voices/mb/mb-cz1", start: 17504944, end: 17505014 }, { filename: "/espeak-ng-data/voices/mb/mb-cz2", start: 17505014, end: 17505096 }, { filename: "/espeak-ng-data/voices/mb/mb-de1", start: 17505096, end: 17505240 }, { filename: "/espeak-ng-data/voices/mb/mb-de1-en", start: 17505240, end: 17505336 }, { filename: "/espeak-ng-data/voices/mb/mb-de2", start: 17505336, end: 17505464 }, { filename: "/espeak-ng-data/voices/mb/mb-de2-en", start: 17505464, end: 17505544 }, { filename: "/espeak-ng-data/voices/mb/mb-de3", start: 17505544, end: 17505643 }, { filename: "/espeak-ng-data/voices/mb/mb-de3-en", start: 17505643, end: 17505739 }, { filename: "/espeak-ng-data/voices/mb/mb-de4", start: 17505739, end: 17505868 }, { filename: "/espeak-ng-data/voices/mb/mb-de4-en", start: 17505868, end: 17505949 }, { filename: "/espeak-ng-data/voices/mb/mb-de5", start: 17505949, end: 17506185 }, { filename: "/espeak-ng-data/voices/mb/mb-de5-en", start: 17506185, end: 17506275 }, { filename: "/espeak-ng-data/voices/mb/mb-de6", start: 17506275, end: 17506397 }, { filename: "/espeak-ng-data/voices/mb/mb-de6-en", start: 17506397, end: 17506471 }, { filename: "/espeak-ng-data/voices/mb/mb-de6-grc", start: 17506471, end: 17506554 }, { filename: "/espeak-ng-data/voices/mb/mb-de7", start: 17506554, end: 17506704 }, { filename: "/espeak-ng-data/voices/mb/mb-de8", start: 17506704, end: 17506775 }, { filename: "/espeak-ng-data/voices/mb/mb-ee1", start: 17506775, end: 17506872 }, { filename: "/espeak-ng-data/voices/mb/mb-en1", start: 17506872, end: 17507003 }, { filename: "/espeak-ng-data/voices/mb/mb-es1", start: 17507003, end: 17507117 }, { filename: "/espeak-ng-data/voices/mb/mb-es2", start: 17507117, end: 17507225 }, { filename: "/espeak-ng-data/voices/mb/mb-es3", start: 17507225, end: 17507329 }, { filename: "/espeak-ng-data/voices/mb/mb-es4", start: 17507329, end: 17507417 }, { filename: "/espeak-ng-data/voices/mb/mb-fr1", start: 17507417, end: 17507583 }, { filename: "/espeak-ng-data/voices/mb/mb-fr1-en", start: 17507583, end: 17507687 }, { filename: "/espeak-ng-data/voices/mb/mb-fr2", start: 17507687, end: 17507790 }, { filename: "/espeak-ng-data/voices/mb/mb-fr3", start: 17507790, end: 17507890 }, { filename: "/espeak-ng-data/voices/mb/mb-fr4", start: 17507890, end: 17508017 }, { filename: "/espeak-ng-data/voices/mb/mb-fr4-en", start: 17508017, end: 17508124 }, { filename: "/espeak-ng-data/voices/mb/mb-fr5", start: 17508124, end: 17508224 }, { filename: "/espeak-ng-data/voices/mb/mb-fr6", start: 17508224, end: 17508324 }, { filename: "/espeak-ng-data/voices/mb/mb-fr7", start: 17508324, end: 17508407 }, { filename: "/espeak-ng-data/voices/mb/mb-gr1", start: 17508407, end: 17508501 }, { filename: "/espeak-ng-data/voices/mb/mb-gr2", start: 17508501, end: 17508595 }, { filename: "/espeak-ng-data/voices/mb/mb-gr2-en", start: 17508595, end: 17508683 }, { filename: "/espeak-ng-data/voices/mb/mb-hb1", start: 17508683, end: 17508751 }, { filename: "/espeak-ng-data/voices/mb/mb-hb2", start: 17508751, end: 17508834 }, { filename: "/espeak-ng-data/voices/mb/mb-hu1", start: 17508834, end: 17508936 }, { filename: "/espeak-ng-data/voices/mb/mb-hu1-en", start: 17508936, end: 17509033 }, { filename: "/espeak-ng-data/voices/mb/mb-ic1", start: 17509033, end: 17509121 }, { filename: "/espeak-ng-data/voices/mb/mb-id1", start: 17509121, end: 17509222 }, { filename: "/espeak-ng-data/voices/mb/mb-in1", start: 17509222, end: 17509291 }, { filename: "/espeak-ng-data/voices/mb/mb-in2", start: 17509291, end: 17509376 }, { filename: "/espeak-ng-data/voices/mb/mb-ir1", start: 17509376, end: 17510129 }, { filename: "/espeak-ng-data/voices/mb/mb-it1", start: 17510129, end: 17510213 }, { filename: "/espeak-ng-data/voices/mb/mb-it2", start: 17510213, end: 17510300 }, { filename: "/espeak-ng-data/voices/mb/mb-it3", start: 17510300, end: 17510442 }, { filename: "/espeak-ng-data/voices/mb/mb-it4", start: 17510442, end: 17510587 }, { filename: "/espeak-ng-data/voices/mb/mb-jp1", start: 17510587, end: 17510658 }, { filename: "/espeak-ng-data/voices/mb/mb-jp2", start: 17510658, end: 17510759 }, { filename: "/espeak-ng-data/voices/mb/mb-jp3", start: 17510759, end: 17510846 }, { filename: "/espeak-ng-data/voices/mb/mb-la1", start: 17510846, end: 17510929 }, { filename: "/espeak-ng-data/voices/mb/mb-lt1", start: 17510929, end: 17511016 }, { filename: "/espeak-ng-data/voices/mb/mb-lt2", start: 17511016, end: 17511103 }, { filename: "/espeak-ng-data/voices/mb/mb-ma1", start: 17511103, end: 17511201 }, { filename: "/espeak-ng-data/voices/mb/mb-mx1", start: 17511201, end: 17511321 }, { filename: "/espeak-ng-data/voices/mb/mb-mx2", start: 17511321, end: 17511441 }, { filename: "/espeak-ng-data/voices/mb/mb-nl1", start: 17511441, end: 17511510 }, { filename: "/espeak-ng-data/voices/mb/mb-nl2", start: 17511510, end: 17511606 }, { filename: "/espeak-ng-data/voices/mb/mb-nl2-en", start: 17511606, end: 17511697 }, { filename: "/espeak-ng-data/voices/mb/mb-nl3", start: 17511697, end: 17511782 }, { filename: "/espeak-ng-data/voices/mb/mb-nz1", start: 17511782, end: 17511850 }, { filename: "/espeak-ng-data/voices/mb/mb-pl1", start: 17511850, end: 17511949 }, { filename: "/espeak-ng-data/voices/mb/mb-pl1-en", start: 17511949, end: 17512031 }, { filename: "/espeak-ng-data/voices/mb/mb-pt1", start: 17512031, end: 17512162 }, { filename: "/espeak-ng-data/voices/mb/mb-ro1", start: 17512162, end: 17512249 }, { filename: "/espeak-ng-data/voices/mb/mb-ro1-en", start: 17512249, end: 17512330 }, { filename: "/espeak-ng-data/voices/mb/mb-sw1", start: 17512330, end: 17512428 }, { filename: "/espeak-ng-data/voices/mb/mb-sw1-en", start: 17512428, end: 17512521 }, { filename: "/espeak-ng-data/voices/mb/mb-sw2", start: 17512521, end: 17512623 }, { filename: "/espeak-ng-data/voices/mb/mb-sw2-en", start: 17512623, end: 17512722 }, { filename: "/espeak-ng-data/voices/mb/mb-tl1", start: 17512722, end: 17512807 }, { filename: "/espeak-ng-data/voices/mb/mb-tr1", start: 17512807, end: 17512892 }, { filename: "/espeak-ng-data/voices/mb/mb-tr2", start: 17512892, end: 17513006 }, { filename: "/espeak-ng-data/voices/mb/mb-us1", start: 17513006, end: 17513176 }, { filename: "/espeak-ng-data/voices/mb/mb-us2", start: 17513176, end: 17513354 }, { filename: "/espeak-ng-data/voices/mb/mb-us3", start: 17513354, end: 17513534 }, { filename: "/espeak-ng-data/voices/mb/mb-vz1", start: 17513534, end: 17513678 }, { filename: "/espeak-ng-data/yue_dict", start: 17513678, end: 18077249 }], remote_package_size: 18077249 });
    })();
    var moduleOverrides = Object.assign({}, Module);
    var arguments_ = [];
    var thisProgram = "./this.program";
    var quit_ = (status, toThrow) => {
      throw toThrow;
    };
    var ENVIRONMENT_IS_WEB = typeof window == "object";
    var ENVIRONMENT_IS_WORKER = typeof importScripts == "function";
    var ENVIRONMENT_IS_NODE = typeof process == "object" && typeof process.versions == "object" && typeof process.versions.node == "string";
    var scriptDirectory = "";
    function locateFile(path) {
      if (Module["locateFile"]) {
        return Module["locateFile"](path, scriptDirectory);
      }
      return scriptDirectory + path;
    }
    var read_, readAsync, readBinary;
    if (ENVIRONMENT_IS_NODE) {
      var fs = (()=>({}));
      var nodePath = (init_path(), __toCommonJS(exports_path));
      if (ENVIRONMENT_IS_WORKER) {
        scriptDirectory = nodePath.dirname(scriptDirectory) + "/";
      } else {
        scriptDirectory = __dirname + "/";
      }
      read_ = (filename, binary) => {
        filename = isFileURI(filename) ? new URL(filename) : nodePath.normalize(filename);
        return fs.readFileSync(filename, binary ? undefined : "utf8");
      };
      readBinary = (filename) => {
        var ret = read_(filename, true);
        if (!ret.buffer) {
          ret = new Uint8Array(ret);
        }
        return ret;
      };
      readAsync = (filename, onload, onerror, binary = true) => {
        filename = isFileURI(filename) ? new URL(filename) : nodePath.normalize(filename);
        fs.readFile(filename, binary ? undefined : "utf8", (err2, data) => {
          if (err2)
            onerror(err2);
          else
            onload(binary ? data.buffer : data);
        });
      };
      if (!Module["thisProgram"] && process.argv.length > 1) {
        thisProgram = process.argv[1].replace(/\\/g, "/");
      }
      arguments_ = process.argv.slice(2);
      quit_ = (status, toThrow) => {
        process.exitCode = status;
        throw toThrow;
      };
      Module["inspect"] = () => "[Emscripten Module object]";
    } else if (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER) {
      if (ENVIRONMENT_IS_WORKER) {
        scriptDirectory = self.location.href;
      } else if (typeof document != "undefined" && document.currentScript) {
        scriptDirectory = document.currentScript.src;
      }
      if (_scriptDir) {
        scriptDirectory = _scriptDir;
      }
      if (scriptDirectory.indexOf("blob:") !== 0) {
        scriptDirectory = scriptDirectory.substr(0, scriptDirectory.replace(/[?#].*/, "").lastIndexOf("/") + 1);
      } else {
        scriptDirectory = "";
      }
      {
        read_ = (url) => {
          var xhr = new XMLHttpRequest;
          xhr.open("GET", url, false);
          xhr.send(null);
          return xhr.responseText;
        };
        if (ENVIRONMENT_IS_WORKER) {
          readBinary = (url) => {
            var xhr = new XMLHttpRequest;
            xhr.open("GET", url, false);
            xhr.responseType = "arraybuffer";
            xhr.send(null);
            return new Uint8Array(xhr.response);
          };
        }
        readAsync = (url, onload, onerror) => {
          var xhr = new XMLHttpRequest;
          xhr.open("GET", url, true);
          xhr.responseType = "arraybuffer";
          xhr.onload = () => {
            if (xhr.status == 200 || xhr.status == 0 && xhr.response) {
              onload(xhr.response);
              return;
            }
            onerror();
          };
          xhr.onerror = onerror;
          xhr.send(null);
        };
      }
    } else {
    }
    var out = Module["print"] || console.log.bind(console);
    var err = Module["printErr"] || console.error.bind(console);
    Object.assign(Module, moduleOverrides);
    moduleOverrides = null;
    if (Module["arguments"])
      arguments_ = Module["arguments"];
    if (Module["thisProgram"])
      thisProgram = Module["thisProgram"];
    if (Module["quit"])
      quit_ = Module["quit"];
    var wasmBinary;
    if (Module["wasmBinary"])
      wasmBinary = Module["wasmBinary"];
    if (typeof WebAssembly != "object") {
      abort("no native wasm support detected");
    }
    var wasmMemory;
    var ABORT = false;
    var EXITSTATUS;
    function assert(condition, text) {
      if (!condition) {
        abort(text);
      }
    }
    var HEAP8, HEAPU8, HEAP16, HEAPU16, HEAP32, HEAPU32, HEAPF32, HEAPF64;
    function updateMemoryViews() {
      var b3 = wasmMemory.buffer;
      Module["HEAP8"] = HEAP8 = new Int8Array(b3);
      Module["HEAP16"] = HEAP16 = new Int16Array(b3);
      Module["HEAPU8"] = HEAPU8 = new Uint8Array(b3);
      Module["HEAPU16"] = HEAPU16 = new Uint16Array(b3);
      Module["HEAP32"] = HEAP32 = new Int32Array(b3);
      Module["HEAPU32"] = HEAPU32 = new Uint32Array(b3);
      Module["HEAPF32"] = HEAPF32 = new Float32Array(b3);
      Module["HEAPF64"] = HEAPF64 = new Float64Array(b3);
    }
    var __ATPRERUN__ = [];
    var __ATINIT__ = [];
    var __ATMAIN__ = [];
    var __ATPOSTRUN__ = [];
    var runtimeInitialized = false;
    function preRun() {
      if (Module["preRun"]) {
        if (typeof Module["preRun"] == "function")
          Module["preRun"] = [Module["preRun"]];
        while (Module["preRun"].length) {
          addOnPreRun(Module["preRun"].shift());
        }
      }
      callRuntimeCallbacks(__ATPRERUN__);
    }
    function initRuntime() {
      runtimeInitialized = true;
      if (!Module["noFSInit"] && !FS.init.initialized)
        FS.init();
      FS.ignorePermissions = false;
      TTY.init();
      callRuntimeCallbacks(__ATINIT__);
    }
    function preMain() {
      callRuntimeCallbacks(__ATMAIN__);
    }
    function postRun() {
      if (Module["postRun"]) {
        if (typeof Module["postRun"] == "function")
          Module["postRun"] = [Module["postRun"]];
        while (Module["postRun"].length) {
          addOnPostRun(Module["postRun"].shift());
        }
      }
      callRuntimeCallbacks(__ATPOSTRUN__);
    }
    function addOnPreRun(cb) {
      __ATPRERUN__.unshift(cb);
    }
    function addOnInit(cb) {
      __ATINIT__.unshift(cb);
    }
    function addOnPostRun(cb) {
      __ATPOSTRUN__.unshift(cb);
    }
    var runDependencies = 0;
    var runDependencyWatcher = null;
    var dependenciesFulfilled = null;
    function getUniqueRunDependency(id) {
      return id;
    }
    function addRunDependency(id) {
      runDependencies++;
      if (Module["monitorRunDependencies"]) {
        Module["monitorRunDependencies"](runDependencies);
      }
    }
    function removeRunDependency(id) {
      runDependencies--;
      if (Module["monitorRunDependencies"]) {
        Module["monitorRunDependencies"](runDependencies);
      }
      if (runDependencies == 0) {
        if (runDependencyWatcher !== null) {
          clearInterval(runDependencyWatcher);
          runDependencyWatcher = null;
        }
        if (dependenciesFulfilled) {
          var callback = dependenciesFulfilled;
          dependenciesFulfilled = null;
          callback();
        }
      }
    }
    function abort(what) {
      if (Module["onAbort"]) {
        Module["onAbort"](what);
      }
      what = "Aborted(" + what + ")";
      err(what);
      ABORT = true;
      EXITSTATUS = 1;
      what += ". Build with -sASSERTIONS for more info.";
      var e = new WebAssembly.RuntimeError(what);
      readyPromiseReject(e);
      throw e;
    }
    var dataURIPrefix = "data:application/octet-stream;base64,";
    var isDataURI = (filename) => filename.startsWith(dataURIPrefix);
    var isFileURI = (filename) => filename.startsWith("file://");
    var wasmBinaryFile;
    wasmBinaryFile = "piper_phonemize.wasm";
    if (!isDataURI(wasmBinaryFile)) {
      wasmBinaryFile = locateFile(wasmBinaryFile);
    }
    function getBinarySync(file) {
      if (file == wasmBinaryFile && wasmBinary) {
        return new Uint8Array(wasmBinary);
      }
      if (readBinary) {
        return readBinary(file);
      }
      throw "both async and sync fetching of the wasm failed";
    }
    function getBinaryPromise(binaryFile) {
      if (!wasmBinary && (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER)) {
        if (typeof fetch == "function" && !isFileURI(binaryFile)) {
          return fetch(binaryFile, { credentials: "same-origin" }).then((response) => {
            if (!response["ok"]) {
              throw "failed to load wasm binary file at '" + binaryFile + "'";
            }
            return response["arrayBuffer"]();
          }).catch(() => getBinarySync(binaryFile));
        } else if (readAsync) {
          return new Promise((resolve, reject) => {
            readAsync(binaryFile, (response) => resolve(new Uint8Array(response)), reject);
          });
        }
      }
      return Promise.resolve().then(() => getBinarySync(binaryFile));
    }
    function instantiateArrayBuffer(binaryFile, imports, receiver) {
      return getBinaryPromise(binaryFile).then((binary) => WebAssembly.instantiate(binary, imports)).then((instance) => instance).then(receiver, (reason) => {
        err(`failed to asynchronously prepare wasm: ${reason}`);
        abort(reason);
      });
    }
    function instantiateAsync(binary, binaryFile, imports, callback) {
      if (!binary && typeof WebAssembly.instantiateStreaming == "function" && !isDataURI(binaryFile) && !isFileURI(binaryFile) && !ENVIRONMENT_IS_NODE && typeof fetch == "function") {
        return fetch(binaryFile, { credentials: "same-origin" }).then((response) => {
          var result = WebAssembly.instantiateStreaming(response, imports);
          return result.then(callback, function(reason) {
            err(`wasm streaming compile failed: ${reason}`);
            err("falling back to ArrayBuffer instantiation");
            return instantiateArrayBuffer(binaryFile, imports, callback);
          });
        });
      }
      return instantiateArrayBuffer(binaryFile, imports, callback);
    }
    function createWasm() {
      var info = { a: wasmImports };
      function receiveInstance(instance, module) {
        wasmExports = instance.exports;
        wasmMemory = wasmExports["w"];
        updateMemoryViews();
        addOnInit(wasmExports["x"]);
        removeRunDependency("wasm-instantiate");
        return wasmExports;
      }
      addRunDependency("wasm-instantiate");
      function receiveInstantiationResult(result) {
        receiveInstance(result["instance"]);
      }
      if (Module["instantiateWasm"]) {
        try {
          return Module["instantiateWasm"](info, receiveInstance);
        } catch (e) {
          err(`Module.instantiateWasm callback failed with error: ${e}`);
          readyPromiseReject(e);
        }
      }
      instantiateAsync(wasmBinary, wasmBinaryFile, info, receiveInstantiationResult).catch(readyPromiseReject);
      return {};
    }
    var tempDouble;
    var tempI64;
    function ExitStatus(status) {
      this.name = "ExitStatus";
      this.message = `Program terminated with exit(${status})`;
      this.status = status;
    }
    var callRuntimeCallbacks = (callbacks) => {
      while (callbacks.length > 0) {
        callbacks.shift()(Module);
      }
    };
    var noExitRuntime = Module["noExitRuntime"] || true;
    var UTF8Decoder = typeof TextDecoder != "undefined" ? new TextDecoder("utf8") : undefined;
    var UTF8ArrayToString = (heapOrArray, idx, maxBytesToRead) => {
      var endIdx = idx + maxBytesToRead;
      var endPtr = idx;
      while (heapOrArray[endPtr] && !(endPtr >= endIdx))
        ++endPtr;
      if (endPtr - idx > 16 && heapOrArray.buffer && UTF8Decoder) {
        return UTF8Decoder.decode(heapOrArray.subarray(idx, endPtr));
      }
      var str = "";
      while (idx < endPtr) {
        var u02 = heapOrArray[idx++];
        if (!(u02 & 128)) {
          str += String.fromCharCode(u02);
          continue;
        }
        var u1 = heapOrArray[idx++] & 63;
        if ((u02 & 224) == 192) {
          str += String.fromCharCode((u02 & 31) << 6 | u1);
          continue;
        }
        var u2 = heapOrArray[idx++] & 63;
        if ((u02 & 240) == 224) {
          u02 = (u02 & 15) << 12 | u1 << 6 | u2;
        } else {
          u02 = (u02 & 7) << 18 | u1 << 12 | u2 << 6 | heapOrArray[idx++] & 63;
        }
        if (u02 < 65536) {
          str += String.fromCharCode(u02);
        } else {
          var ch = u02 - 65536;
          str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023);
        }
      }
      return str;
    };
    var UTF8ToString = (ptr, maxBytesToRead) => ptr ? UTF8ArrayToString(HEAPU8, ptr, maxBytesToRead) : "";
    var ___assert_fail = (condition, filename, line, func) => {
      abort(`Assertion failed: ${UTF8ToString(condition)}, at: ` + [filename ? UTF8ToString(filename) : "unknown filename", line, func ? UTF8ToString(func) : "unknown function"]);
    };
    function ExceptionInfo(excPtr) {
      this.excPtr = excPtr;
      this.ptr = excPtr - 24;
      this.set_type = function(type) {
        HEAPU32[this.ptr + 4 >> 2] = type;
      };
      this.get_type = function() {
        return HEAPU32[this.ptr + 4 >> 2];
      };
      this.set_destructor = function(destructor) {
        HEAPU32[this.ptr + 8 >> 2] = destructor;
      };
      this.get_destructor = function() {
        return HEAPU32[this.ptr + 8 >> 2];
      };
      this.set_caught = function(caught) {
        caught = caught ? 1 : 0;
        HEAP8[this.ptr + 12 >> 0] = caught;
      };
      this.get_caught = function() {
        return HEAP8[this.ptr + 12 >> 0] != 0;
      };
      this.set_rethrown = function(rethrown) {
        rethrown = rethrown ? 1 : 0;
        HEAP8[this.ptr + 13 >> 0] = rethrown;
      };
      this.get_rethrown = function() {
        return HEAP8[this.ptr + 13 >> 0] != 0;
      };
      this.init = function(type, destructor) {
        this.set_adjusted_ptr(0);
        this.set_type(type);
        this.set_destructor(destructor);
      };
      this.set_adjusted_ptr = function(adjustedPtr) {
        HEAPU32[this.ptr + 16 >> 2] = adjustedPtr;
      };
      this.get_adjusted_ptr = function() {
        return HEAPU32[this.ptr + 16 >> 2];
      };
      this.get_exception_ptr = function() {
        var isPointer = ___cxa_is_pointer_type(this.get_type());
        if (isPointer) {
          return HEAPU32[this.excPtr >> 2];
        }
        var adjusted = this.get_adjusted_ptr();
        if (adjusted !== 0)
          return adjusted;
        return this.excPtr;
      };
    }
    var exceptionLast = 0;
    var uncaughtExceptionCount = 0;
    var ___cxa_throw = (ptr, type, destructor) => {
      var info = new ExceptionInfo(ptr);
      info.init(type, destructor);
      exceptionLast = ptr;
      uncaughtExceptionCount++;
      throw exceptionLast;
    };
    var setErrNo = (value) => {
      HEAP32[___errno_location() >> 2] = value;
      return value;
    };
    var PATH = { isAbs: (path) => path.charAt(0) === "/", splitPath: (filename) => {
      var splitPathRe = /^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;
      return splitPathRe.exec(filename).slice(1);
    }, normalizeArray: (parts, allowAboveRoot) => {
      var up = 0;
      for (var i = parts.length - 1;i >= 0; i--) {
        var last = parts[i];
        if (last === ".") {
          parts.splice(i, 1);
        } else if (last === "..") {
          parts.splice(i, 1);
          up++;
        } else if (up) {
          parts.splice(i, 1);
          up--;
        }
      }
      if (allowAboveRoot) {
        for (;up; up--) {
          parts.unshift("..");
        }
      }
      return parts;
    }, normalize: (path) => {
      var isAbsolute = PATH.isAbs(path), trailingSlash = path.substr(-1) === "/";
      path = PATH.normalizeArray(path.split("/").filter((p) => !!p), !isAbsolute).join("/");
      if (!path && !isAbsolute) {
        path = ".";
      }
      if (path && trailingSlash) {
        path += "/";
      }
      return (isAbsolute ? "/" : "") + path;
    }, dirname: (path) => {
      var result = PATH.splitPath(path), root = result[0], dir = result[1];
      if (!root && !dir) {
        return ".";
      }
      if (dir) {
        dir = dir.substr(0, dir.length - 1);
      }
      return root + dir;
    }, basename: (path) => {
      if (path === "/")
        return "/";
      path = PATH.normalize(path);
      path = path.replace(/\/$/, "");
      var lastSlash = path.lastIndexOf("/");
      if (lastSlash === -1)
        return path;
      return path.substr(lastSlash + 1);
    }, join: function() {
      var paths = Array.prototype.slice.call(arguments);
      return PATH.normalize(paths.join("/"));
    }, join2: (l, r) => PATH.normalize(l + "/" + r) };
    var initRandomFill = () => {
      if (typeof crypto == "object" && typeof crypto["getRandomValues"] == "function") {
        return (view) => crypto.getRandomValues(view);
      } else if (ENVIRONMENT_IS_NODE) {
        try {
          var crypto_module = (init_crypto(), __toCommonJS(exports_crypto));
          var randomFillSync = crypto_module["randomFillSync"];
          if (randomFillSync) {
            return (view) => crypto_module["randomFillSync"](view);
          }
          var randomBytes = crypto_module["randomBytes"];
          return (view) => (view.set(randomBytes(view.byteLength)), view);
        } catch (e) {
        }
      }
      abort("initRandomDevice");
    };
    var randomFill = (view) => (randomFill = initRandomFill())(view);
    var PATH_FS = { resolve: function() {
      var resolvedPath = "", resolvedAbsolute = false;
      for (var i = arguments.length - 1;i >= -1 && !resolvedAbsolute; i--) {
        var path = i >= 0 ? arguments[i] : FS.cwd();
        if (typeof path != "string") {
          throw new TypeError("Arguments to path.resolve must be strings");
        } else if (!path) {
          return "";
        }
        resolvedPath = path + "/" + resolvedPath;
        resolvedAbsolute = PATH.isAbs(path);
      }
      resolvedPath = PATH.normalizeArray(resolvedPath.split("/").filter((p) => !!p), !resolvedAbsolute).join("/");
      return (resolvedAbsolute ? "/" : "") + resolvedPath || ".";
    }, relative: (from, to) => {
      from = PATH_FS.resolve(from).substr(1);
      to = PATH_FS.resolve(to).substr(1);
      function trim(arr) {
        var start = 0;
        for (;start < arr.length; start++) {
          if (arr[start] !== "")
            break;
        }
        var end = arr.length - 1;
        for (;end >= 0; end--) {
          if (arr[end] !== "")
            break;
        }
        if (start > end)
          return [];
        return arr.slice(start, end - start + 1);
      }
      var fromParts = trim(from.split("/"));
      var toParts = trim(to.split("/"));
      var length = Math.min(fromParts.length, toParts.length);
      var samePartsLength = length;
      for (var i = 0;i < length; i++) {
        if (fromParts[i] !== toParts[i]) {
          samePartsLength = i;
          break;
        }
      }
      var outputParts = [];
      for (var i = samePartsLength;i < fromParts.length; i++) {
        outputParts.push("..");
      }
      outputParts = outputParts.concat(toParts.slice(samePartsLength));
      return outputParts.join("/");
    } };
    var FS_stdin_getChar_buffer = [];
    var lengthBytesUTF8 = (str) => {
      var len = 0;
      for (var i = 0;i < str.length; ++i) {
        var c = str.charCodeAt(i);
        if (c <= 127) {
          len++;
        } else if (c <= 2047) {
          len += 2;
        } else if (c >= 55296 && c <= 57343) {
          len += 4;
          ++i;
        } else {
          len += 3;
        }
      }
      return len;
    };
    var stringToUTF8Array = (str, heap, outIdx, maxBytesToWrite) => {
      if (!(maxBytesToWrite > 0))
        return 0;
      var startIdx = outIdx;
      var endIdx = outIdx + maxBytesToWrite - 1;
      for (var i = 0;i < str.length; ++i) {
        var u = str.charCodeAt(i);
        if (u >= 55296 && u <= 57343) {
          var u1 = str.charCodeAt(++i);
          u = 65536 + ((u & 1023) << 10) | u1 & 1023;
        }
        if (u <= 127) {
          if (outIdx >= endIdx)
            break;
          heap[outIdx++] = u;
        } else if (u <= 2047) {
          if (outIdx + 1 >= endIdx)
            break;
          heap[outIdx++] = 192 | u >> 6;
          heap[outIdx++] = 128 | u & 63;
        } else if (u <= 65535) {
          if (outIdx + 2 >= endIdx)
            break;
          heap[outIdx++] = 224 | u >> 12;
          heap[outIdx++] = 128 | u >> 6 & 63;
          heap[outIdx++] = 128 | u & 63;
        } else {
          if (outIdx + 3 >= endIdx)
            break;
          heap[outIdx++] = 240 | u >> 18;
          heap[outIdx++] = 128 | u >> 12 & 63;
          heap[outIdx++] = 128 | u >> 6 & 63;
          heap[outIdx++] = 128 | u & 63;
        }
      }
      heap[outIdx] = 0;
      return outIdx - startIdx;
    };
    function intArrayFromString(stringy, dontAddNull, length) {
      var len = length > 0 ? length : lengthBytesUTF8(stringy) + 1;
      var u8array = new Array(len);
      var numBytesWritten = stringToUTF8Array(stringy, u8array, 0, u8array.length);
      if (dontAddNull)
        u8array.length = numBytesWritten;
      return u8array;
    }
    var FS_stdin_getChar = () => {
      if (!FS_stdin_getChar_buffer.length) {
        var result = null;
        if (ENVIRONMENT_IS_NODE) {
          var BUFSIZE = 256;
          var buf = Buffer.alloc(BUFSIZE);
          var bytesRead = 0;
          var fd = process.stdin.fd;
          try {
            bytesRead = fs.readSync(fd, buf);
          } catch (e) {
            if (e.toString().includes("EOF"))
              bytesRead = 0;
            else
              throw e;
          }
          if (bytesRead > 0) {
            result = buf.slice(0, bytesRead).toString("utf-8");
          } else {
            result = null;
          }
        } else if (typeof window != "undefined" && typeof window.prompt == "function") {
          result = window.prompt("Input: ");
          if (result !== null) {
            result += "\n";
          }
        } else if (typeof readline == "function") {
          result = readline();
          if (result !== null) {
            result += "\n";
          }
        }
        if (!result) {
          return null;
        }
        FS_stdin_getChar_buffer = intArrayFromString(result, true);
      }
      return FS_stdin_getChar_buffer.shift();
    };
    var TTY = { ttys: [], init() {
    }, shutdown() {
    }, register(dev, ops) {
      TTY.ttys[dev] = { input: [], output: [], ops };
      FS.registerDevice(dev, TTY.stream_ops);
    }, stream_ops: { open(stream) {
      var tty = TTY.ttys[stream.node.rdev];
      if (!tty) {
        throw new FS.ErrnoError(43);
      }
      stream.tty = tty;
      stream.seekable = false;
    }, close(stream) {
      stream.tty.ops.fsync(stream.tty);
    }, fsync(stream) {
      stream.tty.ops.fsync(stream.tty);
    }, read(stream, buffer, offset, length, pos) {
      if (!stream.tty || !stream.tty.ops.get_char) {
        throw new FS.ErrnoError(60);
      }
      var bytesRead = 0;
      for (var i = 0;i < length; i++) {
        var result;
        try {
          result = stream.tty.ops.get_char(stream.tty);
        } catch (e) {
          throw new FS.ErrnoError(29);
        }
        if (result === undefined && bytesRead === 0) {
          throw new FS.ErrnoError(6);
        }
        if (result === null || result === undefined)
          break;
        bytesRead++;
        buffer[offset + i] = result;
      }
      if (bytesRead) {
        stream.node.timestamp = Date.now();
      }
      return bytesRead;
    }, write(stream, buffer, offset, length, pos) {
      if (!stream.tty || !stream.tty.ops.put_char) {
        throw new FS.ErrnoError(60);
      }
      try {
        for (var i = 0;i < length; i++) {
          stream.tty.ops.put_char(stream.tty, buffer[offset + i]);
        }
      } catch (e) {
        throw new FS.ErrnoError(29);
      }
      if (length) {
        stream.node.timestamp = Date.now();
      }
      return i;
    } }, default_tty_ops: { get_char(tty) {
      return FS_stdin_getChar();
    }, put_char(tty, val) {
      if (val === null || val === 10) {
        out(UTF8ArrayToString(tty.output, 0));
        tty.output = [];
      } else {
        if (val != 0)
          tty.output.push(val);
      }
    }, fsync(tty) {
      if (tty.output && tty.output.length > 0) {
        out(UTF8ArrayToString(tty.output, 0));
        tty.output = [];
      }
    }, ioctl_tcgets(tty) {
      return { c_iflag: 25856, c_oflag: 5, c_cflag: 191, c_lflag: 35387, c_cc: [3, 28, 127, 21, 4, 0, 1, 0, 17, 19, 26, 0, 18, 15, 23, 22, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0] };
    }, ioctl_tcsets(tty, optional_actions, data) {
      return 0;
    }, ioctl_tiocgwinsz(tty) {
      return [24, 80];
    } }, default_tty1_ops: { put_char(tty, val) {
      if (val === null || val === 10) {
        err(UTF8ArrayToString(tty.output, 0));
        tty.output = [];
      } else {
        if (val != 0)
          tty.output.push(val);
      }
    }, fsync(tty) {
      if (tty.output && tty.output.length > 0) {
        err(UTF8ArrayToString(tty.output, 0));
        tty.output = [];
      }
    } } };
    var mmapAlloc = (size) => {
      abort();
    };
    var MEMFS = { ops_table: null, mount(mount) {
      return MEMFS.createNode(null, "/", 16384 | 511, 0);
    }, createNode(parent, name, mode, dev) {
      if (FS.isBlkdev(mode) || FS.isFIFO(mode)) {
        throw new FS.ErrnoError(63);
      }
      if (!MEMFS.ops_table) {
        MEMFS.ops_table = { dir: { node: { getattr: MEMFS.node_ops.getattr, setattr: MEMFS.node_ops.setattr, lookup: MEMFS.node_ops.lookup, mknod: MEMFS.node_ops.mknod, rename: MEMFS.node_ops.rename, unlink: MEMFS.node_ops.unlink, rmdir: MEMFS.node_ops.rmdir, readdir: MEMFS.node_ops.readdir, symlink: MEMFS.node_ops.symlink }, stream: { llseek: MEMFS.stream_ops.llseek } }, file: { node: { getattr: MEMFS.node_ops.getattr, setattr: MEMFS.node_ops.setattr }, stream: { llseek: MEMFS.stream_ops.llseek, read: MEMFS.stream_ops.read, write: MEMFS.stream_ops.write, allocate: MEMFS.stream_ops.allocate, mmap: MEMFS.stream_ops.mmap, msync: MEMFS.stream_ops.msync } }, link: { node: { getattr: MEMFS.node_ops.getattr, setattr: MEMFS.node_ops.setattr, readlink: MEMFS.node_ops.readlink }, stream: {} }, chrdev: { node: { getattr: MEMFS.node_ops.getattr, setattr: MEMFS.node_ops.setattr }, stream: FS.chrdev_stream_ops } };
      }
      var node = FS.createNode(parent, name, mode, dev);
      if (FS.isDir(node.mode)) {
        node.node_ops = MEMFS.ops_table.dir.node;
        node.stream_ops = MEMFS.ops_table.dir.stream;
        node.contents = {};
      } else if (FS.isFile(node.mode)) {
        node.node_ops = MEMFS.ops_table.file.node;
        node.stream_ops = MEMFS.ops_table.file.stream;
        node.usedBytes = 0;
        node.contents = null;
      } else if (FS.isLink(node.mode)) {
        node.node_ops = MEMFS.ops_table.link.node;
        node.stream_ops = MEMFS.ops_table.link.stream;
      } else if (FS.isChrdev(node.mode)) {
        node.node_ops = MEMFS.ops_table.chrdev.node;
        node.stream_ops = MEMFS.ops_table.chrdev.stream;
      }
      node.timestamp = Date.now();
      if (parent) {
        parent.contents[name] = node;
        parent.timestamp = node.timestamp;
      }
      return node;
    }, getFileDataAsTypedArray(node) {
      if (!node.contents)
        return new Uint8Array(0);
      if (node.contents.subarray)
        return node.contents.subarray(0, node.usedBytes);
      return new Uint8Array(node.contents);
    }, expandFileStorage(node, newCapacity) {
      var prevCapacity = node.contents ? node.contents.length : 0;
      if (prevCapacity >= newCapacity)
        return;
      var CAPACITY_DOUBLING_MAX = 1024 * 1024;
      newCapacity = Math.max(newCapacity, prevCapacity * (prevCapacity < CAPACITY_DOUBLING_MAX ? 2 : 1.125) >>> 0);
      if (prevCapacity != 0)
        newCapacity = Math.max(newCapacity, 256);
      var oldContents = node.contents;
      node.contents = new Uint8Array(newCapacity);
      if (node.usedBytes > 0)
        node.contents.set(oldContents.subarray(0, node.usedBytes), 0);
    }, resizeFileStorage(node, newSize) {
      if (node.usedBytes == newSize)
        return;
      if (newSize == 0) {
        node.contents = null;
        node.usedBytes = 0;
      } else {
        var oldContents = node.contents;
        node.contents = new Uint8Array(newSize);
        if (oldContents) {
          node.contents.set(oldContents.subarray(0, Math.min(newSize, node.usedBytes)));
        }
        node.usedBytes = newSize;
      }
    }, node_ops: { getattr(node) {
      var attr = {};
      attr.dev = FS.isChrdev(node.mode) ? node.id : 1;
      attr.ino = node.id;
      attr.mode = node.mode;
      attr.nlink = 1;
      attr.uid = 0;
      attr.gid = 0;
      attr.rdev = node.rdev;
      if (FS.isDir(node.mode)) {
        attr.size = 4096;
      } else if (FS.isFile(node.mode)) {
        attr.size = node.usedBytes;
      } else if (FS.isLink(node.mode)) {
        attr.size = node.link.length;
      } else {
        attr.size = 0;
      }
      attr.atime = new Date(node.timestamp);
      attr.mtime = new Date(node.timestamp);
      attr.ctime = new Date(node.timestamp);
      attr.blksize = 4096;
      attr.blocks = Math.ceil(attr.size / attr.blksize);
      return attr;
    }, setattr(node, attr) {
      if (attr.mode !== undefined) {
        node.mode = attr.mode;
      }
      if (attr.timestamp !== undefined) {
        node.timestamp = attr.timestamp;
      }
      if (attr.size !== undefined) {
        MEMFS.resizeFileStorage(node, attr.size);
      }
    }, lookup(parent, name) {
      throw FS.genericErrors[44];
    }, mknod(parent, name, mode, dev) {
      return MEMFS.createNode(parent, name, mode, dev);
    }, rename(old_node, new_dir, new_name) {
      if (FS.isDir(old_node.mode)) {
        var new_node;
        try {
          new_node = FS.lookupNode(new_dir, new_name);
        } catch (e) {
        }
        if (new_node) {
          for (var i in new_node.contents) {
            throw new FS.ErrnoError(55);
          }
        }
      }
      delete old_node.parent.contents[old_node.name];
      old_node.parent.timestamp = Date.now();
      old_node.name = new_name;
      new_dir.contents[new_name] = old_node;
      new_dir.timestamp = old_node.parent.timestamp;
      old_node.parent = new_dir;
    }, unlink(parent, name) {
      delete parent.contents[name];
      parent.timestamp = Date.now();
    }, rmdir(parent, name) {
      var node = FS.lookupNode(parent, name);
      for (var i in node.contents) {
        throw new FS.ErrnoError(55);
      }
      delete parent.contents[name];
      parent.timestamp = Date.now();
    }, readdir(node) {
      var entries = [".", ".."];
      for (var key in node.contents) {
        if (!node.contents.hasOwnProperty(key)) {
          continue;
        }
        entries.push(key);
      }
      return entries;
    }, symlink(parent, newname, oldpath) {
      var node = MEMFS.createNode(parent, newname, 511 | 40960, 0);
      node.link = oldpath;
      return node;
    }, readlink(node) {
      if (!FS.isLink(node.mode)) {
        throw new FS.ErrnoError(28);
      }
      return node.link;
    } }, stream_ops: { read(stream, buffer, offset, length, position) {
      var contents = stream.node.contents;
      if (position >= stream.node.usedBytes)
        return 0;
      var size = Math.min(stream.node.usedBytes - position, length);
      if (size > 8 && contents.subarray) {
        buffer.set(contents.subarray(position, position + size), offset);
      } else {
        for (var i = 0;i < size; i++)
          buffer[offset + i] = contents[position + i];
      }
      return size;
    }, write(stream, buffer, offset, length, position, canOwn) {
      if (!length)
        return 0;
      var node = stream.node;
      node.timestamp = Date.now();
      if (buffer.subarray && (!node.contents || node.contents.subarray)) {
        if (canOwn) {
          node.contents = buffer.subarray(offset, offset + length);
          node.usedBytes = length;
          return length;
        } else if (node.usedBytes === 0 && position === 0) {
          node.contents = buffer.slice(offset, offset + length);
          node.usedBytes = length;
          return length;
        } else if (position + length <= node.usedBytes) {
          node.contents.set(buffer.subarray(offset, offset + length), position);
          return length;
        }
      }
      MEMFS.expandFileStorage(node, position + length);
      if (node.contents.subarray && buffer.subarray) {
        node.contents.set(buffer.subarray(offset, offset + length), position);
      } else {
        for (var i = 0;i < length; i++) {
          node.contents[position + i] = buffer[offset + i];
        }
      }
      node.usedBytes = Math.max(node.usedBytes, position + length);
      return length;
    }, llseek(stream, offset, whence) {
      var position = offset;
      if (whence === 1) {
        position += stream.position;
      } else if (whence === 2) {
        if (FS.isFile(stream.node.mode)) {
          position += stream.node.usedBytes;
        }
      }
      if (position < 0) {
        throw new FS.ErrnoError(28);
      }
      return position;
    }, allocate(stream, offset, length) {
      MEMFS.expandFileStorage(stream.node, offset + length);
      stream.node.usedBytes = Math.max(stream.node.usedBytes, offset + length);
    }, mmap(stream, length, position, prot, flags) {
      if (!FS.isFile(stream.node.mode)) {
        throw new FS.ErrnoError(43);
      }
      var ptr;
      var allocated;
      var contents = stream.node.contents;
      if (!(flags & 2) && contents.buffer === HEAP8.buffer) {
        allocated = false;
        ptr = contents.byteOffset;
      } else {
        if (position > 0 || position + length < contents.length) {
          if (contents.subarray) {
            contents = contents.subarray(position, position + length);
          } else {
            contents = Array.prototype.slice.call(contents, position, position + length);
          }
        }
        allocated = true;
        ptr = mmapAlloc(length);
        if (!ptr) {
          throw new FS.ErrnoError(48);
        }
        HEAP8.set(contents, ptr);
      }
      return { ptr, allocated };
    }, msync(stream, buffer, offset, length, mmapFlags) {
      MEMFS.stream_ops.write(stream, buffer, 0, length, offset, false);
      return 0;
    } } };
    var asyncLoad = (url, onload, onerror, noRunDep) => {
      var dep = !noRunDep ? getUniqueRunDependency(`al ${url}`) : "";
      readAsync(url, (arrayBuffer) => {
        assert(arrayBuffer, `Loading data file "${url}" failed (no arrayBuffer).`);
        onload(new Uint8Array(arrayBuffer));
        if (dep)
          removeRunDependency(dep);
      }, (event) => {
        if (onerror) {
          onerror();
        } else {
          throw `Loading data file "${url}" failed.`;
        }
      });
      if (dep)
        addRunDependency(dep);
    };
    var FS_createDataFile = (parent, name, fileData, canRead, canWrite, canOwn) => FS.createDataFile(parent, name, fileData, canRead, canWrite, canOwn);
    var preloadPlugins = Module["preloadPlugins"] || [];
    var FS_handledByPreloadPlugin = (byteArray, fullname, finish, onerror) => {
      if (typeof Browser != "undefined")
        Browser.init();
      var handled = false;
      preloadPlugins.forEach((plugin) => {
        if (handled)
          return;
        if (plugin["canHandle"](fullname)) {
          plugin["handle"](byteArray, fullname, finish, onerror);
          handled = true;
        }
      });
      return handled;
    };
    var FS_createPreloadedFile = (parent, name, url, canRead, canWrite, onload, onerror, dontCreateFile, canOwn, preFinish) => {
      var fullname = name ? PATH_FS.resolve(PATH.join2(parent, name)) : parent;
      var dep = getUniqueRunDependency(`cp ${fullname}`);
      function processData(byteArray) {
        function finish(byteArray2) {
          if (preFinish)
            preFinish();
          if (!dontCreateFile) {
            FS_createDataFile(parent, name, byteArray2, canRead, canWrite, canOwn);
          }
          if (onload)
            onload();
          removeRunDependency(dep);
        }
        if (FS_handledByPreloadPlugin(byteArray, fullname, finish, () => {
          if (onerror)
            onerror();
          removeRunDependency(dep);
        })) {
          return;
        }
        finish(byteArray);
      }
      addRunDependency(dep);
      if (typeof url == "string") {
        asyncLoad(url, (byteArray) => processData(byteArray), onerror);
      } else {
        processData(url);
      }
    };
    var FS_modeStringToFlags = (str) => {
      var flagModes = { r: 0, "r+": 2, w: 512 | 64 | 1, "w+": 512 | 64 | 2, a: 1024 | 64 | 1, "a+": 1024 | 64 | 2 };
      var flags = flagModes[str];
      if (typeof flags == "undefined") {
        throw new Error(`Unknown file open mode: ${str}`);
      }
      return flags;
    };
    var FS_getMode = (canRead, canWrite) => {
      var mode = 0;
      if (canRead)
        mode |= 292 | 73;
      if (canWrite)
        mode |= 146;
      return mode;
    };
    var FS = { root: null, mounts: [], devices: {}, streams: [], nextInode: 1, nameTable: null, currentPath: "/", initialized: false, ignorePermissions: true, ErrnoError: null, genericErrors: {}, filesystems: null, syncFSRequests: 0, lookupPath(path, opts = {}) {
      path = PATH_FS.resolve(path);
      if (!path)
        return { path: "", node: null };
      var defaults = { follow_mount: true, recurse_count: 0 };
      opts = Object.assign(defaults, opts);
      if (opts.recurse_count > 8) {
        throw new FS.ErrnoError(32);
      }
      var parts = path.split("/").filter((p) => !!p);
      var current = FS.root;
      var current_path = "/";
      for (var i = 0;i < parts.length; i++) {
        var islast = i === parts.length - 1;
        if (islast && opts.parent) {
          break;
        }
        current = FS.lookupNode(current, parts[i]);
        current_path = PATH.join2(current_path, parts[i]);
        if (FS.isMountpoint(current)) {
          if (!islast || islast && opts.follow_mount) {
            current = current.mounted.root;
          }
        }
        if (!islast || opts.follow) {
          var count = 0;
          while (FS.isLink(current.mode)) {
            var link = FS.readlink(current_path);
            current_path = PATH_FS.resolve(PATH.dirname(current_path), link);
            var lookup = FS.lookupPath(current_path, { recurse_count: opts.recurse_count + 1 });
            current = lookup.node;
            if (count++ > 40) {
              throw new FS.ErrnoError(32);
            }
          }
        }
      }
      return { path: current_path, node: current };
    }, getPath(node) {
      var path;
      while (true) {
        if (FS.isRoot(node)) {
          var mount = node.mount.mountpoint;
          if (!path)
            return mount;
          return mount[mount.length - 1] !== "/" ? `${mount}/${path}` : mount + path;
        }
        path = path ? `${node.name}/${path}` : node.name;
        node = node.parent;
      }
    }, hashName(parentid, name) {
      var hash = 0;
      for (var i = 0;i < name.length; i++) {
        hash = (hash << 5) - hash + name.charCodeAt(i) | 0;
      }
      return (parentid + hash >>> 0) % FS.nameTable.length;
    }, hashAddNode(node) {
      var hash = FS.hashName(node.parent.id, node.name);
      node.name_next = FS.nameTable[hash];
      FS.nameTable[hash] = node;
    }, hashRemoveNode(node) {
      var hash = FS.hashName(node.parent.id, node.name);
      if (FS.nameTable[hash] === node) {
        FS.nameTable[hash] = node.name_next;
      } else {
        var current = FS.nameTable[hash];
        while (current) {
          if (current.name_next === node) {
            current.name_next = node.name_next;
            break;
          }
          current = current.name_next;
        }
      }
    }, lookupNode(parent, name) {
      var errCode = FS.mayLookup(parent);
      if (errCode) {
        throw new FS.ErrnoError(errCode, parent);
      }
      var hash = FS.hashName(parent.id, name);
      for (var node = FS.nameTable[hash];node; node = node.name_next) {
        var nodeName = node.name;
        if (node.parent.id === parent.id && nodeName === name) {
          return node;
        }
      }
      return FS.lookup(parent, name);
    }, createNode(parent, name, mode, rdev) {
      var node = new FS.FSNode(parent, name, mode, rdev);
      FS.hashAddNode(node);
      return node;
    }, destroyNode(node) {
      FS.hashRemoveNode(node);
    }, isRoot(node) {
      return node === node.parent;
    }, isMountpoint(node) {
      return !!node.mounted;
    }, isFile(mode) {
      return (mode & 61440) === 32768;
    }, isDir(mode) {
      return (mode & 61440) === 16384;
    }, isLink(mode) {
      return (mode & 61440) === 40960;
    }, isChrdev(mode) {
      return (mode & 61440) === 8192;
    }, isBlkdev(mode) {
      return (mode & 61440) === 24576;
    }, isFIFO(mode) {
      return (mode & 61440) === 4096;
    }, isSocket(mode) {
      return (mode & 49152) === 49152;
    }, flagsToPermissionString(flag) {
      var perms = ["r", "w", "rw"][flag & 3];
      if (flag & 512) {
        perms += "w";
      }
      return perms;
    }, nodePermissions(node, perms) {
      if (FS.ignorePermissions) {
        return 0;
      }
      if (perms.includes("r") && !(node.mode & 292)) {
        return 2;
      } else if (perms.includes("w") && !(node.mode & 146)) {
        return 2;
      } else if (perms.includes("x") && !(node.mode & 73)) {
        return 2;
      }
      return 0;
    }, mayLookup(dir) {
      var errCode = FS.nodePermissions(dir, "x");
      if (errCode)
        return errCode;
      if (!dir.node_ops.lookup)
        return 2;
      return 0;
    }, mayCreate(dir, name) {
      try {
        var node = FS.lookupNode(dir, name);
        return 20;
      } catch (e) {
      }
      return FS.nodePermissions(dir, "wx");
    }, mayDelete(dir, name, isdir) {
      var node;
      try {
        node = FS.lookupNode(dir, name);
      } catch (e) {
        return e.errno;
      }
      var errCode = FS.nodePermissions(dir, "wx");
      if (errCode) {
        return errCode;
      }
      if (isdir) {
        if (!FS.isDir(node.mode)) {
          return 54;
        }
        if (FS.isRoot(node) || FS.getPath(node) === FS.cwd()) {
          return 10;
        }
      } else {
        if (FS.isDir(node.mode)) {
          return 31;
        }
      }
      return 0;
    }, mayOpen(node, flags) {
      if (!node) {
        return 44;
      }
      if (FS.isLink(node.mode)) {
        return 32;
      } else if (FS.isDir(node.mode)) {
        if (FS.flagsToPermissionString(flags) !== "r" || flags & 512) {
          return 31;
        }
      }
      return FS.nodePermissions(node, FS.flagsToPermissionString(flags));
    }, MAX_OPEN_FDS: 4096, nextfd() {
      for (var fd = 0;fd <= FS.MAX_OPEN_FDS; fd++) {
        if (!FS.streams[fd]) {
          return fd;
        }
      }
      throw new FS.ErrnoError(33);
    }, getStreamChecked(fd) {
      var stream = FS.getStream(fd);
      if (!stream) {
        throw new FS.ErrnoError(8);
      }
      return stream;
    }, getStream: (fd) => FS.streams[fd], createStream(stream, fd = -1) {
      if (!FS.FSStream) {
        FS.FSStream = function() {
          this.shared = {};
        };
        FS.FSStream.prototype = {};
        Object.defineProperties(FS.FSStream.prototype, { object: { get() {
          return this.node;
        }, set(val) {
          this.node = val;
        } }, isRead: { get() {
          return (this.flags & 2097155) !== 1;
        } }, isWrite: { get() {
          return (this.flags & 2097155) !== 0;
        } }, isAppend: { get() {
          return this.flags & 1024;
        } }, flags: { get() {
          return this.shared.flags;
        }, set(val) {
          this.shared.flags = val;
        } }, position: { get() {
          return this.shared.position;
        }, set(val) {
          this.shared.position = val;
        } } });
      }
      stream = Object.assign(new FS.FSStream, stream);
      if (fd == -1) {
        fd = FS.nextfd();
      }
      stream.fd = fd;
      FS.streams[fd] = stream;
      return stream;
    }, closeStream(fd) {
      FS.streams[fd] = null;
    }, chrdev_stream_ops: { open(stream) {
      var device = FS.getDevice(stream.node.rdev);
      stream.stream_ops = device.stream_ops;
      if (stream.stream_ops.open) {
        stream.stream_ops.open(stream);
      }
    }, llseek() {
      throw new FS.ErrnoError(70);
    } }, major: (dev) => dev >> 8, minor: (dev) => dev & 255, makedev: (ma, mi) => ma << 8 | mi, registerDevice(dev, ops) {
      FS.devices[dev] = { stream_ops: ops };
    }, getDevice: (dev) => FS.devices[dev], getMounts(mount) {
      var mounts = [];
      var check = [mount];
      while (check.length) {
        var m2 = check.pop();
        mounts.push(m2);
        check.push.apply(check, m2.mounts);
      }
      return mounts;
    }, syncfs(populate, callback) {
      if (typeof populate == "function") {
        callback = populate;
        populate = false;
      }
      FS.syncFSRequests++;
      if (FS.syncFSRequests > 1) {
        err(`warning: ${FS.syncFSRequests} FS.syncfs operations in flight at once, probably just doing extra work`);
      }
      var mounts = FS.getMounts(FS.root.mount);
      var completed = 0;
      function doCallback(errCode) {
        FS.syncFSRequests--;
        return callback(errCode);
      }
      function done(errCode) {
        if (errCode) {
          if (!done.errored) {
            done.errored = true;
            return doCallback(errCode);
          }
          return;
        }
        if (++completed >= mounts.length) {
          doCallback(null);
        }
      }
      mounts.forEach((mount) => {
        if (!mount.type.syncfs) {
          return done(null);
        }
        mount.type.syncfs(mount, populate, done);
      });
    }, mount(type, opts, mountpoint) {
      var root = mountpoint === "/";
      var pseudo = !mountpoint;
      var node;
      if (root && FS.root) {
        throw new FS.ErrnoError(10);
      } else if (!root && !pseudo) {
        var lookup = FS.lookupPath(mountpoint, { follow_mount: false });
        mountpoint = lookup.path;
        node = lookup.node;
        if (FS.isMountpoint(node)) {
          throw new FS.ErrnoError(10);
        }
        if (!FS.isDir(node.mode)) {
          throw new FS.ErrnoError(54);
        }
      }
      var mount = { type, opts, mountpoint, mounts: [] };
      var mountRoot = type.mount(mount);
      mountRoot.mount = mount;
      mount.root = mountRoot;
      if (root) {
        FS.root = mountRoot;
      } else if (node) {
        node.mounted = mount;
        if (node.mount) {
          node.mount.mounts.push(mount);
        }
      }
      return mountRoot;
    }, unmount(mountpoint) {
      var lookup = FS.lookupPath(mountpoint, { follow_mount: false });
      if (!FS.isMountpoint(lookup.node)) {
        throw new FS.ErrnoError(28);
      }
      var node = lookup.node;
      var mount = node.mounted;
      var mounts = FS.getMounts(mount);
      Object.keys(FS.nameTable).forEach((hash) => {
        var current = FS.nameTable[hash];
        while (current) {
          var next = current.name_next;
          if (mounts.includes(current.mount)) {
            FS.destroyNode(current);
          }
          current = next;
        }
      });
      node.mounted = null;
      var idx = node.mount.mounts.indexOf(mount);
      node.mount.mounts.splice(idx, 1);
    }, lookup(parent, name) {
      return parent.node_ops.lookup(parent, name);
    }, mknod(path, mode, dev) {
      var lookup = FS.lookupPath(path, { parent: true });
      var parent = lookup.node;
      var name = PATH.basename(path);
      if (!name || name === "." || name === "..") {
        throw new FS.ErrnoError(28);
      }
      var errCode = FS.mayCreate(parent, name);
      if (errCode) {
        throw new FS.ErrnoError(errCode);
      }
      if (!parent.node_ops.mknod) {
        throw new FS.ErrnoError(63);
      }
      return parent.node_ops.mknod(parent, name, mode, dev);
    }, create(path, mode) {
      mode = mode !== undefined ? mode : 438;
      mode &= 4095;
      mode |= 32768;
      return FS.mknod(path, mode, 0);
    }, mkdir(path, mode) {
      mode = mode !== undefined ? mode : 511;
      mode &= 511 | 512;
      mode |= 16384;
      return FS.mknod(path, mode, 0);
    }, mkdirTree(path, mode) {
      var dirs = path.split("/");
      var d = "";
      for (var i = 0;i < dirs.length; ++i) {
        if (!dirs[i])
          continue;
        d += "/" + dirs[i];
        try {
          FS.mkdir(d, mode);
        } catch (e) {
          if (e.errno != 20)
            throw e;
        }
      }
    }, mkdev(path, mode, dev) {
      if (typeof dev == "undefined") {
        dev = mode;
        mode = 438;
      }
      mode |= 8192;
      return FS.mknod(path, mode, dev);
    }, symlink(oldpath, newpath) {
      if (!PATH_FS.resolve(oldpath)) {
        throw new FS.ErrnoError(44);
      }
      var lookup = FS.lookupPath(newpath, { parent: true });
      var parent = lookup.node;
      if (!parent) {
        throw new FS.ErrnoError(44);
      }
      var newname = PATH.basename(newpath);
      var errCode = FS.mayCreate(parent, newname);
      if (errCode) {
        throw new FS.ErrnoError(errCode);
      }
      if (!parent.node_ops.symlink) {
        throw new FS.ErrnoError(63);
      }
      return parent.node_ops.symlink(parent, newname, oldpath);
    }, rename(old_path, new_path) {
      var old_dirname = PATH.dirname(old_path);
      var new_dirname = PATH.dirname(new_path);
      var old_name = PATH.basename(old_path);
      var new_name = PATH.basename(new_path);
      var lookup, old_dir, new_dir;
      lookup = FS.lookupPath(old_path, { parent: true });
      old_dir = lookup.node;
      lookup = FS.lookupPath(new_path, { parent: true });
      new_dir = lookup.node;
      if (!old_dir || !new_dir)
        throw new FS.ErrnoError(44);
      if (old_dir.mount !== new_dir.mount) {
        throw new FS.ErrnoError(75);
      }
      var old_node = FS.lookupNode(old_dir, old_name);
      var relative = PATH_FS.relative(old_path, new_dirname);
      if (relative.charAt(0) !== ".") {
        throw new FS.ErrnoError(28);
      }
      relative = PATH_FS.relative(new_path, old_dirname);
      if (relative.charAt(0) !== ".") {
        throw new FS.ErrnoError(55);
      }
      var new_node;
      try {
        new_node = FS.lookupNode(new_dir, new_name);
      } catch (e) {
      }
      if (old_node === new_node) {
        return;
      }
      var isdir = FS.isDir(old_node.mode);
      var errCode = FS.mayDelete(old_dir, old_name, isdir);
      if (errCode) {
        throw new FS.ErrnoError(errCode);
      }
      errCode = new_node ? FS.mayDelete(new_dir, new_name, isdir) : FS.mayCreate(new_dir, new_name);
      if (errCode) {
        throw new FS.ErrnoError(errCode);
      }
      if (!old_dir.node_ops.rename) {
        throw new FS.ErrnoError(63);
      }
      if (FS.isMountpoint(old_node) || new_node && FS.isMountpoint(new_node)) {
        throw new FS.ErrnoError(10);
      }
      if (new_dir !== old_dir) {
        errCode = FS.nodePermissions(old_dir, "w");
        if (errCode) {
          throw new FS.ErrnoError(errCode);
        }
      }
      FS.hashRemoveNode(old_node);
      try {
        old_dir.node_ops.rename(old_node, new_dir, new_name);
      } catch (e) {
        throw e;
      } finally {
        FS.hashAddNode(old_node);
      }
    }, rmdir(path) {
      var lookup = FS.lookupPath(path, { parent: true });
      var parent = lookup.node;
      var name = PATH.basename(path);
      var node = FS.lookupNode(parent, name);
      var errCode = FS.mayDelete(parent, name, true);
      if (errCode) {
        throw new FS.ErrnoError(errCode);
      }
      if (!parent.node_ops.rmdir) {
        throw new FS.ErrnoError(63);
      }
      if (FS.isMountpoint(node)) {
        throw new FS.ErrnoError(10);
      }
      parent.node_ops.rmdir(parent, name);
      FS.destroyNode(node);
    }, readdir(path) {
      var lookup = FS.lookupPath(path, { follow: true });
      var node = lookup.node;
      if (!node.node_ops.readdir) {
        throw new FS.ErrnoError(54);
      }
      return node.node_ops.readdir(node);
    }, unlink(path) {
      var lookup = FS.lookupPath(path, { parent: true });
      var parent = lookup.node;
      if (!parent) {
        throw new FS.ErrnoError(44);
      }
      var name = PATH.basename(path);
      var node = FS.lookupNode(parent, name);
      var errCode = FS.mayDelete(parent, name, false);
      if (errCode) {
        throw new FS.ErrnoError(errCode);
      }
      if (!parent.node_ops.unlink) {
        throw new FS.ErrnoError(63);
      }
      if (FS.isMountpoint(node)) {
        throw new FS.ErrnoError(10);
      }
      parent.node_ops.unlink(parent, name);
      FS.destroyNode(node);
    }, readlink(path) {
      var lookup = FS.lookupPath(path);
      var link = lookup.node;
      if (!link) {
        throw new FS.ErrnoError(44);
      }
      if (!link.node_ops.readlink) {
        throw new FS.ErrnoError(28);
      }
      return PATH_FS.resolve(FS.getPath(link.parent), link.node_ops.readlink(link));
    }, stat(path, dontFollow) {
      var lookup = FS.lookupPath(path, { follow: !dontFollow });
      var node = lookup.node;
      if (!node) {
        throw new FS.ErrnoError(44);
      }
      if (!node.node_ops.getattr) {
        throw new FS.ErrnoError(63);
      }
      return node.node_ops.getattr(node);
    }, lstat(path) {
      return FS.stat(path, true);
    }, chmod(path, mode, dontFollow) {
      var node;
      if (typeof path == "string") {
        var lookup = FS.lookupPath(path, { follow: !dontFollow });
        node = lookup.node;
      } else {
        node = path;
      }
      if (!node.node_ops.setattr) {
        throw new FS.ErrnoError(63);
      }
      node.node_ops.setattr(node, { mode: mode & 4095 | node.mode & ~4095, timestamp: Date.now() });
    }, lchmod(path, mode) {
      FS.chmod(path, mode, true);
    }, fchmod(fd, mode) {
      var stream = FS.getStreamChecked(fd);
      FS.chmod(stream.node, mode);
    }, chown(path, uid, gid, dontFollow) {
      var node;
      if (typeof path == "string") {
        var lookup = FS.lookupPath(path, { follow: !dontFollow });
        node = lookup.node;
      } else {
        node = path;
      }
      if (!node.node_ops.setattr) {
        throw new FS.ErrnoError(63);
      }
      node.node_ops.setattr(node, { timestamp: Date.now() });
    }, lchown(path, uid, gid) {
      FS.chown(path, uid, gid, true);
    }, fchown(fd, uid, gid) {
      var stream = FS.getStreamChecked(fd);
      FS.chown(stream.node, uid, gid);
    }, truncate(path, len) {
      if (len < 0) {
        throw new FS.ErrnoError(28);
      }
      var node;
      if (typeof path == "string") {
        var lookup = FS.lookupPath(path, { follow: true });
        node = lookup.node;
      } else {
        node = path;
      }
      if (!node.node_ops.setattr) {
        throw new FS.ErrnoError(63);
      }
      if (FS.isDir(node.mode)) {
        throw new FS.ErrnoError(31);
      }
      if (!FS.isFile(node.mode)) {
        throw new FS.ErrnoError(28);
      }
      var errCode = FS.nodePermissions(node, "w");
      if (errCode) {
        throw new FS.ErrnoError(errCode);
      }
      node.node_ops.setattr(node, { size: len, timestamp: Date.now() });
    }, ftruncate(fd, len) {
      var stream = FS.getStreamChecked(fd);
      if ((stream.flags & 2097155) === 0) {
        throw new FS.ErrnoError(28);
      }
      FS.truncate(stream.node, len);
    }, utime(path, atime, mtime) {
      var lookup = FS.lookupPath(path, { follow: true });
      var node = lookup.node;
      node.node_ops.setattr(node, { timestamp: Math.max(atime, mtime) });
    }, open(path, flags, mode) {
      if (path === "") {
        throw new FS.ErrnoError(44);
      }
      flags = typeof flags == "string" ? FS_modeStringToFlags(flags) : flags;
      mode = typeof mode == "undefined" ? 438 : mode;
      if (flags & 64) {
        mode = mode & 4095 | 32768;
      } else {
        mode = 0;
      }
      var node;
      if (typeof path == "object") {
        node = path;
      } else {
        path = PATH.normalize(path);
        try {
          var lookup = FS.lookupPath(path, { follow: !(flags & 131072) });
          node = lookup.node;
        } catch (e) {
        }
      }
      var created = false;
      if (flags & 64) {
        if (node) {
          if (flags & 128) {
            throw new FS.ErrnoError(20);
          }
        } else {
          node = FS.mknod(path, mode, 0);
          created = true;
        }
      }
      if (!node) {
        throw new FS.ErrnoError(44);
      }
      if (FS.isChrdev(node.mode)) {
        flags &= ~512;
      }
      if (flags & 65536 && !FS.isDir(node.mode)) {
        throw new FS.ErrnoError(54);
      }
      if (!created) {
        var errCode = FS.mayOpen(node, flags);
        if (errCode) {
          throw new FS.ErrnoError(errCode);
        }
      }
      if (flags & 512 && !created) {
        FS.truncate(node, 0);
      }
      flags &= ~(128 | 512 | 131072);
      var stream = FS.createStream({ node, path: FS.getPath(node), flags, seekable: true, position: 0, stream_ops: node.stream_ops, ungotten: [], error: false });
      if (stream.stream_ops.open) {
        stream.stream_ops.open(stream);
      }
      if (Module["logReadFiles"] && !(flags & 1)) {
        if (!FS.readFiles)
          FS.readFiles = {};
        if (!(path in FS.readFiles)) {
          FS.readFiles[path] = 1;
        }
      }
      return stream;
    }, close(stream) {
      if (FS.isClosed(stream)) {
        throw new FS.ErrnoError(8);
      }
      if (stream.getdents)
        stream.getdents = null;
      try {
        if (stream.stream_ops.close) {
          stream.stream_ops.close(stream);
        }
      } catch (e) {
        throw e;
      } finally {
        FS.closeStream(stream.fd);
      }
      stream.fd = null;
    }, isClosed(stream) {
      return stream.fd === null;
    }, llseek(stream, offset, whence) {
      if (FS.isClosed(stream)) {
        throw new FS.ErrnoError(8);
      }
      if (!stream.seekable || !stream.stream_ops.llseek) {
        throw new FS.ErrnoError(70);
      }
      if (whence != 0 && whence != 1 && whence != 2) {
        throw new FS.ErrnoError(28);
      }
      stream.position = stream.stream_ops.llseek(stream, offset, whence);
      stream.ungotten = [];
      return stream.position;
    }, read(stream, buffer, offset, length, position) {
      if (length < 0 || position < 0) {
        throw new FS.ErrnoError(28);
      }
      if (FS.isClosed(stream)) {
        throw new FS.ErrnoError(8);
      }
      if ((stream.flags & 2097155) === 1) {
        throw new FS.ErrnoError(8);
      }
      if (FS.isDir(stream.node.mode)) {
        throw new FS.ErrnoError(31);
      }
      if (!stream.stream_ops.read) {
        throw new FS.ErrnoError(28);
      }
      var seeking = typeof position != "undefined";
      if (!seeking) {
        position = stream.position;
      } else if (!stream.seekable) {
        throw new FS.ErrnoError(70);
      }
      var bytesRead = stream.stream_ops.read(stream, buffer, offset, length, position);
      if (!seeking)
        stream.position += bytesRead;
      return bytesRead;
    }, write(stream, buffer, offset, length, position, canOwn) {
      if (length < 0 || position < 0) {
        throw new FS.ErrnoError(28);
      }
      if (FS.isClosed(stream)) {
        throw new FS.ErrnoError(8);
      }
      if ((stream.flags & 2097155) === 0) {
        throw new FS.ErrnoError(8);
      }
      if (FS.isDir(stream.node.mode)) {
        throw new FS.ErrnoError(31);
      }
      if (!stream.stream_ops.write) {
        throw new FS.ErrnoError(28);
      }
      if (stream.seekable && stream.flags & 1024) {
        FS.llseek(stream, 0, 2);
      }
      var seeking = typeof position != "undefined";
      if (!seeking) {
        position = stream.position;
      } else if (!stream.seekable) {
        throw new FS.ErrnoError(70);
      }
      var bytesWritten = stream.stream_ops.write(stream, buffer, offset, length, position, canOwn);
      if (!seeking)
        stream.position += bytesWritten;
      return bytesWritten;
    }, allocate(stream, offset, length) {
      if (FS.isClosed(stream)) {
        throw new FS.ErrnoError(8);
      }
      if (offset < 0 || length <= 0) {
        throw new FS.ErrnoError(28);
      }
      if ((stream.flags & 2097155) === 0) {
        throw new FS.ErrnoError(8);
      }
      if (!FS.isFile(stream.node.mode) && !FS.isDir(stream.node.mode)) {
        throw new FS.ErrnoError(43);
      }
      if (!stream.stream_ops.allocate) {
        throw new FS.ErrnoError(138);
      }
      stream.stream_ops.allocate(stream, offset, length);
    }, mmap(stream, length, position, prot, flags) {
      if ((prot & 2) !== 0 && (flags & 2) === 0 && (stream.flags & 2097155) !== 2) {
        throw new FS.ErrnoError(2);
      }
      if ((stream.flags & 2097155) === 1) {
        throw new FS.ErrnoError(2);
      }
      if (!stream.stream_ops.mmap) {
        throw new FS.ErrnoError(43);
      }
      return stream.stream_ops.mmap(stream, length, position, prot, flags);
    }, msync(stream, buffer, offset, length, mmapFlags) {
      if (!stream.stream_ops.msync) {
        return 0;
      }
      return stream.stream_ops.msync(stream, buffer, offset, length, mmapFlags);
    }, munmap: (stream) => 0, ioctl(stream, cmd, arg) {
      if (!stream.stream_ops.ioctl) {
        throw new FS.ErrnoError(59);
      }
      return stream.stream_ops.ioctl(stream, cmd, arg);
    }, readFile(path, opts = {}) {
      opts.flags = opts.flags || 0;
      opts.encoding = opts.encoding || "binary";
      if (opts.encoding !== "utf8" && opts.encoding !== "binary") {
        throw new Error(`Invalid encoding type "${opts.encoding}"`);
      }
      var ret;
      var stream = FS.open(path, opts.flags);
      var stat = FS.stat(path);
      var length = stat.size;
      var buf = new Uint8Array(length);
      FS.read(stream, buf, 0, length, 0);
      if (opts.encoding === "utf8") {
        ret = UTF8ArrayToString(buf, 0);
      } else if (opts.encoding === "binary") {
        ret = buf;
      }
      FS.close(stream);
      return ret;
    }, writeFile(path, data, opts = {}) {
      opts.flags = opts.flags || 577;
      var stream = FS.open(path, opts.flags, opts.mode);
      if (typeof data == "string") {
        var buf = new Uint8Array(lengthBytesUTF8(data) + 1);
        var actualNumBytes = stringToUTF8Array(data, buf, 0, buf.length);
        FS.write(stream, buf, 0, actualNumBytes, undefined, opts.canOwn);
      } else if (ArrayBuffer.isView(data)) {
        FS.write(stream, data, 0, data.byteLength, undefined, opts.canOwn);
      } else {
        throw new Error("Unsupported data type");
      }
      FS.close(stream);
    }, cwd: () => FS.currentPath, chdir(path) {
      var lookup = FS.lookupPath(path, { follow: true });
      if (lookup.node === null) {
        throw new FS.ErrnoError(44);
      }
      if (!FS.isDir(lookup.node.mode)) {
        throw new FS.ErrnoError(54);
      }
      var errCode = FS.nodePermissions(lookup.node, "x");
      if (errCode) {
        throw new FS.ErrnoError(errCode);
      }
      FS.currentPath = lookup.path;
    }, createDefaultDirectories() {
      FS.mkdir("/tmp");
      FS.mkdir("/home");
      FS.mkdir("/home/web_user");
    }, createDefaultDevices() {
      FS.mkdir("/dev");
      FS.registerDevice(FS.makedev(1, 3), { read: () => 0, write: (stream, buffer, offset, length, pos) => length });
      FS.mkdev("/dev/null", FS.makedev(1, 3));
      TTY.register(FS.makedev(5, 0), TTY.default_tty_ops);
      TTY.register(FS.makedev(6, 0), TTY.default_tty1_ops);
      FS.mkdev("/dev/tty", FS.makedev(5, 0));
      FS.mkdev("/dev/tty1", FS.makedev(6, 0));
      var randomBuffer = new Uint8Array(1024), randomLeft = 0;
      var randomByte = () => {
        if (randomLeft === 0) {
          randomLeft = randomFill(randomBuffer).byteLength;
        }
        return randomBuffer[--randomLeft];
      };
      FS.createDevice("/dev", "random", randomByte);
      FS.createDevice("/dev", "urandom", randomByte);
      FS.mkdir("/dev/shm");
      FS.mkdir("/dev/shm/tmp");
    }, createSpecialDirectories() {
      FS.mkdir("/proc");
      var proc_self = FS.mkdir("/proc/self");
      FS.mkdir("/proc/self/fd");
      FS.mount({ mount() {
        var node = FS.createNode(proc_self, "fd", 16384 | 511, 73);
        node.node_ops = { lookup(parent, name) {
          var fd = +name;
          var stream = FS.getStreamChecked(fd);
          var ret = { parent: null, mount: { mountpoint: "fake" }, node_ops: { readlink: () => stream.path } };
          ret.parent = ret;
          return ret;
        } };
        return node;
      } }, {}, "/proc/self/fd");
    }, createStandardStreams() {
      if (Module["stdin"]) {
        FS.createDevice("/dev", "stdin", Module["stdin"]);
      } else {
        FS.symlink("/dev/tty", "/dev/stdin");
      }
      if (Module["stdout"]) {
        FS.createDevice("/dev", "stdout", null, Module["stdout"]);
      } else {
        FS.symlink("/dev/tty", "/dev/stdout");
      }
      if (Module["stderr"]) {
        FS.createDevice("/dev", "stderr", null, Module["stderr"]);
      } else {
        FS.symlink("/dev/tty1", "/dev/stderr");
      }
      var stdin = FS.open("/dev/stdin", 0);
      var stdout = FS.open("/dev/stdout", 1);
      var stderr = FS.open("/dev/stderr", 1);
    }, ensureErrnoError() {
      if (FS.ErrnoError)
        return;
      FS.ErrnoError = function ErrnoError(errno, node) {
        this.name = "ErrnoError";
        this.node = node;
        this.setErrno = function(errno2) {
          this.errno = errno2;
        };
        this.setErrno(errno);
        this.message = "FS error";
      };
      FS.ErrnoError.prototype = new Error;
      FS.ErrnoError.prototype.constructor = FS.ErrnoError;
      [44].forEach((code) => {
        FS.genericErrors[code] = new FS.ErrnoError(code);
        FS.genericErrors[code].stack = "<generic error, no stack>";
      });
    }, staticInit() {
      FS.ensureErrnoError();
      FS.nameTable = new Array(4096);
      FS.mount(MEMFS, {}, "/");
      FS.createDefaultDirectories();
      FS.createDefaultDevices();
      FS.createSpecialDirectories();
      FS.filesystems = { MEMFS };
    }, init(input, output, error) {
      FS.init.initialized = true;
      FS.ensureErrnoError();
      Module["stdin"] = input || Module["stdin"];
      Module["stdout"] = output || Module["stdout"];
      Module["stderr"] = error || Module["stderr"];
      FS.createStandardStreams();
    }, quit() {
      FS.init.initialized = false;
      for (var i = 0;i < FS.streams.length; i++) {
        var stream = FS.streams[i];
        if (!stream) {
          continue;
        }
        FS.close(stream);
      }
    }, findObject(path, dontResolveLastLink) {
      var ret = FS.analyzePath(path, dontResolveLastLink);
      if (!ret.exists) {
        return null;
      }
      return ret.object;
    }, analyzePath(path, dontResolveLastLink) {
      try {
        var lookup = FS.lookupPath(path, { follow: !dontResolveLastLink });
        path = lookup.path;
      } catch (e) {
      }
      var ret = { isRoot: false, exists: false, error: 0, name: null, path: null, object: null, parentExists: false, parentPath: null, parentObject: null };
      try {
        var lookup = FS.lookupPath(path, { parent: true });
        ret.parentExists = true;
        ret.parentPath = lookup.path;
        ret.parentObject = lookup.node;
        ret.name = PATH.basename(path);
        lookup = FS.lookupPath(path, { follow: !dontResolveLastLink });
        ret.exists = true;
        ret.path = lookup.path;
        ret.object = lookup.node;
        ret.name = lookup.node.name;
        ret.isRoot = lookup.path === "/";
      } catch (e) {
        ret.error = e.errno;
      }
      return ret;
    }, createPath(parent, path, canRead, canWrite) {
      parent = typeof parent == "string" ? parent : FS.getPath(parent);
      var parts = path.split("/").reverse();
      while (parts.length) {
        var part = parts.pop();
        if (!part)
          continue;
        var current = PATH.join2(parent, part);
        try {
          FS.mkdir(current);
        } catch (e) {
        }
        parent = current;
      }
      return current;
    }, createFile(parent, name, properties, canRead, canWrite) {
      var path = PATH.join2(typeof parent == "string" ? parent : FS.getPath(parent), name);
      var mode = FS_getMode(canRead, canWrite);
      return FS.create(path, mode);
    }, createDataFile(parent, name, data, canRead, canWrite, canOwn) {
      var path = name;
      if (parent) {
        parent = typeof parent == "string" ? parent : FS.getPath(parent);
        path = name ? PATH.join2(parent, name) : parent;
      }
      var mode = FS_getMode(canRead, canWrite);
      var node = FS.create(path, mode);
      if (data) {
        if (typeof data == "string") {
          var arr = new Array(data.length);
          for (var i = 0, len = data.length;i < len; ++i)
            arr[i] = data.charCodeAt(i);
          data = arr;
        }
        FS.chmod(node, mode | 146);
        var stream = FS.open(node, 577);
        FS.write(stream, data, 0, data.length, 0, canOwn);
        FS.close(stream);
        FS.chmod(node, mode);
      }
      return node;
    }, createDevice(parent, name, input, output) {
      var path = PATH.join2(typeof parent == "string" ? parent : FS.getPath(parent), name);
      var mode = FS_getMode(!!input, !!output);
      if (!FS.createDevice.major)
        FS.createDevice.major = 64;
      var dev = FS.makedev(FS.createDevice.major++, 0);
      FS.registerDevice(dev, { open(stream) {
        stream.seekable = false;
      }, close(stream) {
        if (output && output.buffer && output.buffer.length) {
          output(10);
        }
      }, read(stream, buffer, offset, length, pos) {
        var bytesRead = 0;
        for (var i = 0;i < length; i++) {
          var result;
          try {
            result = input();
          } catch (e) {
            throw new FS.ErrnoError(29);
          }
          if (result === undefined && bytesRead === 0) {
            throw new FS.ErrnoError(6);
          }
          if (result === null || result === undefined)
            break;
          bytesRead++;
          buffer[offset + i] = result;
        }
        if (bytesRead) {
          stream.node.timestamp = Date.now();
        }
        return bytesRead;
      }, write(stream, buffer, offset, length, pos) {
        for (var i = 0;i < length; i++) {
          try {
            output(buffer[offset + i]);
          } catch (e) {
            throw new FS.ErrnoError(29);
          }
        }
        if (length) {
          stream.node.timestamp = Date.now();
        }
        return i;
      } });
      return FS.mkdev(path, mode, dev);
    }, forceLoadFile(obj) {
      if (obj.isDevice || obj.isFolder || obj.link || obj.contents)
        return true;
      if (typeof XMLHttpRequest != "undefined") {
        throw new Error("Lazy loading should have been performed (contents set) in createLazyFile, but it was not. Lazy loading only works in web workers. Use --embed-file or --preload-file in emcc on the main thread.");
      } else if (read_) {
        try {
          obj.contents = intArrayFromString(read_(obj.url), true);
          obj.usedBytes = obj.contents.length;
        } catch (e) {
          throw new FS.ErrnoError(29);
        }
      } else {
        throw new Error("Cannot load without read() or XMLHttpRequest.");
      }
    }, createLazyFile(parent, name, url, canRead, canWrite) {
      function LazyUint8Array() {
        this.lengthKnown = false;
        this.chunks = [];
      }
      LazyUint8Array.prototype.get = function LazyUint8Array_get(idx) {
        if (idx > this.length - 1 || idx < 0) {
          return;
        }
        var chunkOffset = idx % this.chunkSize;
        var chunkNum = idx / this.chunkSize | 0;
        return this.getter(chunkNum)[chunkOffset];
      };
      LazyUint8Array.prototype.setDataGetter = function LazyUint8Array_setDataGetter(getter) {
        this.getter = getter;
      };
      LazyUint8Array.prototype.cacheLength = function LazyUint8Array_cacheLength() {
        var xhr = new XMLHttpRequest;
        xhr.open("HEAD", url, false);
        xhr.send(null);
        if (!(xhr.status >= 200 && xhr.status < 300 || xhr.status === 304))
          throw new Error("Couldn't load " + url + ". Status: " + xhr.status);
        var datalength = Number(xhr.getResponseHeader("Content-length"));
        var header;
        var hasByteServing = (header = xhr.getResponseHeader("Accept-Ranges")) && header === "bytes";
        var usesGzip = (header = xhr.getResponseHeader("Content-Encoding")) && header === "gzip";
        var chunkSize = 1024 * 1024;
        if (!hasByteServing)
          chunkSize = datalength;
        var doXHR = (from, to) => {
          if (from > to)
            throw new Error("invalid range (" + from + ", " + to + ") or no bytes requested!");
          if (to > datalength - 1)
            throw new Error("only " + datalength + " bytes available! programmer error!");
          var xhr2 = new XMLHttpRequest;
          xhr2.open("GET", url, false);
          if (datalength !== chunkSize)
            xhr2.setRequestHeader("Range", "bytes=" + from + "-" + to);
          xhr2.responseType = "arraybuffer";
          if (xhr2.overrideMimeType) {
            xhr2.overrideMimeType("text/plain; charset=x-user-defined");
          }
          xhr2.send(null);
          if (!(xhr2.status >= 200 && xhr2.status < 300 || xhr2.status === 304))
            throw new Error("Couldn't load " + url + ". Status: " + xhr2.status);
          if (xhr2.response !== undefined) {
            return new Uint8Array(xhr2.response || []);
          }
          return intArrayFromString(xhr2.responseText || "", true);
        };
        var lazyArray2 = this;
        lazyArray2.setDataGetter((chunkNum) => {
          var start = chunkNum * chunkSize;
          var end = (chunkNum + 1) * chunkSize - 1;
          end = Math.min(end, datalength - 1);
          if (typeof lazyArray2.chunks[chunkNum] == "undefined") {
            lazyArray2.chunks[chunkNum] = doXHR(start, end);
          }
          if (typeof lazyArray2.chunks[chunkNum] == "undefined")
            throw new Error("doXHR failed!");
          return lazyArray2.chunks[chunkNum];
        });
        if (usesGzip || !datalength) {
          chunkSize = datalength = 1;
          datalength = this.getter(0).length;
          chunkSize = datalength;
          out("LazyFiles on gzip forces download of the whole file when length is accessed");
        }
        this._length = datalength;
        this._chunkSize = chunkSize;
        this.lengthKnown = true;
      };
      if (typeof XMLHttpRequest != "undefined") {
        if (!ENVIRONMENT_IS_WORKER)
          throw "Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";
        var lazyArray = new LazyUint8Array;
        Object.defineProperties(lazyArray, { length: { get: function() {
          if (!this.lengthKnown) {
            this.cacheLength();
          }
          return this._length;
        } }, chunkSize: { get: function() {
          if (!this.lengthKnown) {
            this.cacheLength();
          }
          return this._chunkSize;
        } } });
        var properties = { isDevice: false, contents: lazyArray };
      } else {
        var properties = { isDevice: false, url };
      }
      var node = FS.createFile(parent, name, properties, canRead, canWrite);
      if (properties.contents) {
        node.contents = properties.contents;
      } else if (properties.url) {
        node.contents = null;
        node.url = properties.url;
      }
      Object.defineProperties(node, { usedBytes: { get: function() {
        return this.contents.length;
      } } });
      var stream_ops = {};
      var keys = Object.keys(node.stream_ops);
      keys.forEach((key) => {
        var fn = node.stream_ops[key];
        stream_ops[key] = function forceLoadLazyFile() {
          FS.forceLoadFile(node);
          return fn.apply(null, arguments);
        };
      });
      function writeChunks(stream, buffer, offset, length, position) {
        var contents = stream.node.contents;
        if (position >= contents.length)
          return 0;
        var size = Math.min(contents.length - position, length);
        if (contents.slice) {
          for (var i = 0;i < size; i++) {
            buffer[offset + i] = contents[position + i];
          }
        } else {
          for (var i = 0;i < size; i++) {
            buffer[offset + i] = contents.get(position + i);
          }
        }
        return size;
      }
      stream_ops.read = (stream, buffer, offset, length, position) => {
        FS.forceLoadFile(node);
        return writeChunks(stream, buffer, offset, length, position);
      };
      stream_ops.mmap = (stream, length, position, prot, flags) => {
        FS.forceLoadFile(node);
        var ptr = mmapAlloc(length);
        if (!ptr) {
          throw new FS.ErrnoError(48);
        }
        writeChunks(stream, HEAP8, ptr, length, position);
        return { ptr, allocated: true };
      };
      node.stream_ops = stream_ops;
      return node;
    } };
    var SYSCALLS = { DEFAULT_POLLMASK: 5, calculateAt(dirfd, path, allowEmpty) {
      if (PATH.isAbs(path)) {
        return path;
      }
      var dir;
      if (dirfd === -100) {
        dir = FS.cwd();
      } else {
        var dirstream = SYSCALLS.getStreamFromFD(dirfd);
        dir = dirstream.path;
      }
      if (path.length == 0) {
        if (!allowEmpty) {
          throw new FS.ErrnoError(44);
        }
        return dir;
      }
      return PATH.join2(dir, path);
    }, doStat(func, path, buf) {
      try {
        var stat = func(path);
      } catch (e) {
        if (e && e.node && PATH.normalize(path) !== PATH.normalize(FS.getPath(e.node))) {
          return -54;
        }
        throw e;
      }
      HEAP32[buf >> 2] = stat.dev;
      HEAP32[buf + 4 >> 2] = stat.mode;
      HEAPU32[buf + 8 >> 2] = stat.nlink;
      HEAP32[buf + 12 >> 2] = stat.uid;
      HEAP32[buf + 16 >> 2] = stat.gid;
      HEAP32[buf + 20 >> 2] = stat.rdev;
      tempI64 = [stat.size >>> 0, (tempDouble = stat.size, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 24 >> 2] = tempI64[0], HEAP32[buf + 28 >> 2] = tempI64[1];
      HEAP32[buf + 32 >> 2] = 4096;
      HEAP32[buf + 36 >> 2] = stat.blocks;
      var atime = stat.atime.getTime();
      var mtime = stat.mtime.getTime();
      var ctime = stat.ctime.getTime();
      tempI64 = [Math.floor(atime / 1000) >>> 0, (tempDouble = Math.floor(atime / 1000), +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 40 >> 2] = tempI64[0], HEAP32[buf + 44 >> 2] = tempI64[1];
      HEAPU32[buf + 48 >> 2] = atime % 1000 * 1000;
      tempI64 = [Math.floor(mtime / 1000) >>> 0, (tempDouble = Math.floor(mtime / 1000), +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 56 >> 2] = tempI64[0], HEAP32[buf + 60 >> 2] = tempI64[1];
      HEAPU32[buf + 64 >> 2] = mtime % 1000 * 1000;
      tempI64 = [Math.floor(ctime / 1000) >>> 0, (tempDouble = Math.floor(ctime / 1000), +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 72 >> 2] = tempI64[0], HEAP32[buf + 76 >> 2] = tempI64[1];
      HEAPU32[buf + 80 >> 2] = ctime % 1000 * 1000;
      tempI64 = [stat.ino >>> 0, (tempDouble = stat.ino, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 88 >> 2] = tempI64[0], HEAP32[buf + 92 >> 2] = tempI64[1];
      return 0;
    }, doMsync(addr, stream, len, flags, offset) {
      if (!FS.isFile(stream.node.mode)) {
        throw new FS.ErrnoError(43);
      }
      if (flags & 2) {
        return 0;
      }
      var buffer = HEAPU8.slice(addr, addr + len);
      FS.msync(stream, buffer, offset, len, flags);
    }, varargs: undefined, get() {
      var ret = HEAP32[+SYSCALLS.varargs >> 2];
      SYSCALLS.varargs += 4;
      return ret;
    }, getp() {
      return SYSCALLS.get();
    }, getStr(ptr) {
      var ret = UTF8ToString(ptr);
      return ret;
    }, getStreamFromFD(fd) {
      var stream = FS.getStreamChecked(fd);
      return stream;
    } };
    function ___syscall_fcntl64(fd, cmd, varargs) {
      SYSCALLS.varargs = varargs;
      try {
        var stream = SYSCALLS.getStreamFromFD(fd);
        switch (cmd) {
          case 0: {
            var arg = SYSCALLS.get();
            if (arg < 0) {
              return -28;
            }
            while (FS.streams[arg]) {
              arg++;
            }
            var newStream;
            newStream = FS.createStream(stream, arg);
            return newStream.fd;
          }
          case 1:
          case 2:
            return 0;
          case 3:
            return stream.flags;
          case 4: {
            var arg = SYSCALLS.get();
            stream.flags |= arg;
            return 0;
          }
          case 5: {
            var arg = SYSCALLS.getp();
            var offset = 0;
            HEAP16[arg + offset >> 1] = 2;
            return 0;
          }
          case 6:
          case 7:
            return 0;
          case 16:
          case 8:
            return -28;
          case 9:
            setErrNo(28);
            return -1;
          default: {
            return -28;
          }
        }
      } catch (e) {
        if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
          throw e;
        return -e.errno;
      }
    }
    var stringToUTF8 = (str, outPtr, maxBytesToWrite) => stringToUTF8Array(str, HEAPU8, outPtr, maxBytesToWrite);
    function ___syscall_getdents64(fd, dirp, count) {
      try {
        var stream = SYSCALLS.getStreamFromFD(fd);
        if (!stream.getdents) {
          stream.getdents = FS.readdir(stream.path);
        }
        var struct_size = 280;
        var pos = 0;
        var off = FS.llseek(stream, 0, 1);
        var idx = Math.floor(off / struct_size);
        while (idx < stream.getdents.length && pos + struct_size <= count) {
          var id;
          var type;
          var name = stream.getdents[idx];
          if (name === ".") {
            id = stream.node.id;
            type = 4;
          } else if (name === "..") {
            var lookup = FS.lookupPath(stream.path, { parent: true });
            id = lookup.node.id;
            type = 4;
          } else {
            var child = FS.lookupNode(stream.node, name);
            id = child.id;
            type = FS.isChrdev(child.mode) ? 2 : FS.isDir(child.mode) ? 4 : FS.isLink(child.mode) ? 10 : 8;
          }
          tempI64 = [id >>> 0, (tempDouble = id, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[dirp + pos >> 2] = tempI64[0], HEAP32[dirp + pos + 4 >> 2] = tempI64[1];
          tempI64 = [(idx + 1) * struct_size >>> 0, (tempDouble = (idx + 1) * struct_size, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[dirp + pos + 8 >> 2] = tempI64[0], HEAP32[dirp + pos + 12 >> 2] = tempI64[1];
          HEAP16[dirp + pos + 16 >> 1] = 280;
          HEAP8[dirp + pos + 18 >> 0] = type;
          stringToUTF8(name, dirp + pos + 19, 256);
          pos += struct_size;
          idx += 1;
        }
        FS.llseek(stream, idx * struct_size, 0);
        return pos;
      } catch (e) {
        if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
          throw e;
        return -e.errno;
      }
    }
    function ___syscall_ioctl(fd, op, varargs) {
      SYSCALLS.varargs = varargs;
      try {
        var stream = SYSCALLS.getStreamFromFD(fd);
        switch (op) {
          case 21509: {
            if (!stream.tty)
              return -59;
            return 0;
          }
          case 21505: {
            if (!stream.tty)
              return -59;
            if (stream.tty.ops.ioctl_tcgets) {
              var termios = stream.tty.ops.ioctl_tcgets(stream);
              var argp = SYSCALLS.getp();
              HEAP32[argp >> 2] = termios.c_iflag || 0;
              HEAP32[argp + 4 >> 2] = termios.c_oflag || 0;
              HEAP32[argp + 8 >> 2] = termios.c_cflag || 0;
              HEAP32[argp + 12 >> 2] = termios.c_lflag || 0;
              for (var i = 0;i < 32; i++) {
                HEAP8[argp + i + 17 >> 0] = termios.c_cc[i] || 0;
              }
              return 0;
            }
            return 0;
          }
          case 21510:
          case 21511:
          case 21512: {
            if (!stream.tty)
              return -59;
            return 0;
          }
          case 21506:
          case 21507:
          case 21508: {
            if (!stream.tty)
              return -59;
            if (stream.tty.ops.ioctl_tcsets) {
              var argp = SYSCALLS.getp();
              var c_iflag = HEAP32[argp >> 2];
              var c_oflag = HEAP32[argp + 4 >> 2];
              var c_cflag = HEAP32[argp + 8 >> 2];
              var c_lflag = HEAP32[argp + 12 >> 2];
              var c_cc = [];
              for (var i = 0;i < 32; i++) {
                c_cc.push(HEAP8[argp + i + 17 >> 0]);
              }
              return stream.tty.ops.ioctl_tcsets(stream.tty, op, { c_iflag, c_oflag, c_cflag, c_lflag, c_cc });
            }
            return 0;
          }
          case 21519: {
            if (!stream.tty)
              return -59;
            var argp = SYSCALLS.getp();
            HEAP32[argp >> 2] = 0;
            return 0;
          }
          case 21520: {
            if (!stream.tty)
              return -59;
            return -28;
          }
          case 21531: {
            var argp = SYSCALLS.getp();
            return FS.ioctl(stream, op, argp);
          }
          case 21523: {
            if (!stream.tty)
              return -59;
            if (stream.tty.ops.ioctl_tiocgwinsz) {
              var winsize = stream.tty.ops.ioctl_tiocgwinsz(stream.tty);
              var argp = SYSCALLS.getp();
              HEAP16[argp >> 1] = winsize[0];
              HEAP16[argp + 2 >> 1] = winsize[1];
            }
            return 0;
          }
          case 21524: {
            if (!stream.tty)
              return -59;
            return 0;
          }
          case 21515: {
            if (!stream.tty)
              return -59;
            return 0;
          }
          default:
            return -28;
        }
      } catch (e) {
        if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
          throw e;
        return -e.errno;
      }
    }
    function ___syscall_openat(dirfd, path, flags, varargs) {
      SYSCALLS.varargs = varargs;
      try {
        path = SYSCALLS.getStr(path);
        path = SYSCALLS.calculateAt(dirfd, path);
        var mode = varargs ? SYSCALLS.get() : 0;
        return FS.open(path, flags, mode).fd;
      } catch (e) {
        if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
          throw e;
        return -e.errno;
      }
    }
    function ___syscall_rmdir(path) {
      try {
        path = SYSCALLS.getStr(path);
        FS.rmdir(path);
        return 0;
      } catch (e) {
        if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
          throw e;
        return -e.errno;
      }
    }
    function ___syscall_stat64(path, buf) {
      try {
        path = SYSCALLS.getStr(path);
        return SYSCALLS.doStat(FS.stat, path, buf);
      } catch (e) {
        if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
          throw e;
        return -e.errno;
      }
    }
    function ___syscall_unlinkat(dirfd, path, flags) {
      try {
        path = SYSCALLS.getStr(path);
        path = SYSCALLS.calculateAt(dirfd, path);
        if (flags === 0) {
          FS.unlink(path);
        } else if (flags === 512) {
          FS.rmdir(path);
        } else {
          abort("Invalid flags passed to unlinkat");
        }
        return 0;
      } catch (e) {
        if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
          throw e;
        return -e.errno;
      }
    }
    var nowIsMonotonic = true;
    var __emscripten_get_now_is_monotonic = () => nowIsMonotonic;
    var _abort = () => {
      abort("");
    };
    var _emscripten_date_now = () => Date.now();
    var _emscripten_get_now;
    _emscripten_get_now = () => performance.now();
    var _emscripten_memcpy_js = (dest, src, num) => HEAPU8.copyWithin(dest, src, src + num);
    var abortOnCannotGrowMemory = (requestedSize) => {
      abort("OOM");
    };
    var _emscripten_resize_heap = (requestedSize) => {
      var oldSize = HEAPU8.length;
      requestedSize >>>= 0;
      abortOnCannotGrowMemory(requestedSize);
    };
    var ENV = {};
    var getExecutableName = () => thisProgram || "./this.program";
    var getEnvStrings = () => {
      if (!getEnvStrings.strings) {
        var lang = (typeof navigator == "object" && navigator.languages && navigator.languages[0] || "C").replace("-", "_") + ".UTF-8";
        var env = { USER: "web_user", LOGNAME: "web_user", PATH: "/", PWD: "/", HOME: "/home/web_user", LANG: lang, _: getExecutableName() };
        for (var x in ENV) {
          if (ENV[x] === undefined)
            delete env[x];
          else
            env[x] = ENV[x];
        }
        var strings = [];
        for (var x in env) {
          strings.push(`${x}=${env[x]}`);
        }
        getEnvStrings.strings = strings;
      }
      return getEnvStrings.strings;
    };
    var stringToAscii = (str, buffer) => {
      for (var i = 0;i < str.length; ++i) {
        HEAP8[buffer++ >> 0] = str.charCodeAt(i);
      }
      HEAP8[buffer >> 0] = 0;
    };
    var _environ_get = (__environ, environ_buf) => {
      var bufSize = 0;
      getEnvStrings().forEach((string, i) => {
        var ptr = environ_buf + bufSize;
        HEAPU32[__environ + i * 4 >> 2] = ptr;
        stringToAscii(string, ptr);
        bufSize += string.length + 1;
      });
      return 0;
    };
    var _environ_sizes_get = (penviron_count, penviron_buf_size) => {
      var strings = getEnvStrings();
      HEAPU32[penviron_count >> 2] = strings.length;
      var bufSize = 0;
      strings.forEach((string) => bufSize += string.length + 1);
      HEAPU32[penviron_buf_size >> 2] = bufSize;
      return 0;
    };
    var runtimeKeepaliveCounter = 0;
    var keepRuntimeAlive = () => noExitRuntime || runtimeKeepaliveCounter > 0;
    var _proc_exit = (code) => {
      EXITSTATUS = code;
      if (!keepRuntimeAlive()) {
        if (Module["onExit"])
          Module["onExit"](code);
        ABORT = true;
      }
      quit_(code, new ExitStatus(code));
    };
    var exitJS = (status, implicit) => {
      EXITSTATUS = status;
      _proc_exit(status);
    };
    var _exit = exitJS;
    function _fd_close(fd) {
      try {
        var stream = SYSCALLS.getStreamFromFD(fd);
        FS.close(stream);
        return 0;
      } catch (e) {
        if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
          throw e;
        return e.errno;
      }
    }
    var doReadv = (stream, iov, iovcnt, offset) => {
      var ret = 0;
      for (var i = 0;i < iovcnt; i++) {
        var ptr = HEAPU32[iov >> 2];
        var len = HEAPU32[iov + 4 >> 2];
        iov += 8;
        var curr = FS.read(stream, HEAP8, ptr, len, offset);
        if (curr < 0)
          return -1;
        ret += curr;
        if (curr < len)
          break;
        if (typeof offset !== "undefined") {
          offset += curr;
        }
      }
      return ret;
    };
    function _fd_read(fd, iov, iovcnt, pnum) {
      try {
        var stream = SYSCALLS.getStreamFromFD(fd);
        var num = doReadv(stream, iov, iovcnt);
        HEAPU32[pnum >> 2] = num;
        return 0;
      } catch (e) {
        if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
          throw e;
        return e.errno;
      }
    }
    var convertI32PairToI53Checked = (lo, hi) => hi + 2097152 >>> 0 < 4194305 - !!lo ? (lo >>> 0) + hi * 4294967296 : NaN;
    function _fd_seek(fd, offset_low, offset_high, whence, newOffset) {
      var offset = convertI32PairToI53Checked(offset_low, offset_high);
      try {
        if (isNaN(offset))
          return 61;
        var stream = SYSCALLS.getStreamFromFD(fd);
        FS.llseek(stream, offset, whence);
        tempI64 = [stream.position >>> 0, (tempDouble = stream.position, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[newOffset >> 2] = tempI64[0], HEAP32[newOffset + 4 >> 2] = tempI64[1];
        if (stream.getdents && offset === 0 && whence === 0)
          stream.getdents = null;
        return 0;
      } catch (e) {
        if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
          throw e;
        return e.errno;
      }
    }
    var doWritev = (stream, iov, iovcnt, offset) => {
      var ret = 0;
      for (var i = 0;i < iovcnt; i++) {
        var ptr = HEAPU32[iov >> 2];
        var len = HEAPU32[iov + 4 >> 2];
        iov += 8;
        var curr = FS.write(stream, HEAP8, ptr, len, offset);
        if (curr < 0)
          return -1;
        ret += curr;
        if (typeof offset !== "undefined") {
          offset += curr;
        }
      }
      return ret;
    };
    function _fd_write(fd, iov, iovcnt, pnum) {
      try {
        var stream = SYSCALLS.getStreamFromFD(fd);
        var num = doWritev(stream, iov, iovcnt);
        HEAPU32[pnum >> 2] = num;
        return 0;
      } catch (e) {
        if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
          throw e;
        return e.errno;
      }
    }
    var isLeapYear = (year) => year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0);
    var arraySum = (array, index) => {
      var sum = 0;
      for (var i = 0;i <= index; sum += array[i++]) {
      }
      return sum;
    };
    var MONTH_DAYS_LEAP = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
    var MONTH_DAYS_REGULAR = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
    var addDays = (date, days) => {
      var newDate = new Date(date.getTime());
      while (days > 0) {
        var leap = isLeapYear(newDate.getFullYear());
        var currentMonth = newDate.getMonth();
        var daysInCurrentMonth = (leap ? MONTH_DAYS_LEAP : MONTH_DAYS_REGULAR)[currentMonth];
        if (days > daysInCurrentMonth - newDate.getDate()) {
          days -= daysInCurrentMonth - newDate.getDate() + 1;
          newDate.setDate(1);
          if (currentMonth < 11) {
            newDate.setMonth(currentMonth + 1);
          } else {
            newDate.setMonth(0);
            newDate.setFullYear(newDate.getFullYear() + 1);
          }
        } else {
          newDate.setDate(newDate.getDate() + days);
          return newDate;
        }
      }
      return newDate;
    };
    var writeArrayToMemory = (array, buffer) => {
      HEAP8.set(array, buffer);
    };
    var _strftime = (s, maxsize, format, tm) => {
      var tm_zone = HEAPU32[tm + 40 >> 2];
      var date = { tm_sec: HEAP32[tm >> 2], tm_min: HEAP32[tm + 4 >> 2], tm_hour: HEAP32[tm + 8 >> 2], tm_mday: HEAP32[tm + 12 >> 2], tm_mon: HEAP32[tm + 16 >> 2], tm_year: HEAP32[tm + 20 >> 2], tm_wday: HEAP32[tm + 24 >> 2], tm_yday: HEAP32[tm + 28 >> 2], tm_isdst: HEAP32[tm + 32 >> 2], tm_gmtoff: HEAP32[tm + 36 >> 2], tm_zone: tm_zone ? UTF8ToString(tm_zone) : "" };
      var pattern = UTF8ToString(format);
      var EXPANSION_RULES_1 = { "%c": "%a %b %d %H:%M:%S %Y", "%D": "%m/%d/%y", "%F": "%Y-%m-%d", "%h": "%b", "%r": "%I:%M:%S %p", "%R": "%H:%M", "%T": "%H:%M:%S", "%x": "%m/%d/%y", "%X": "%H:%M:%S", "%Ec": "%c", "%EC": "%C", "%Ex": "%m/%d/%y", "%EX": "%H:%M:%S", "%Ey": "%y", "%EY": "%Y", "%Od": "%d", "%Oe": "%e", "%OH": "%H", "%OI": "%I", "%Om": "%m", "%OM": "%M", "%OS": "%S", "%Ou": "%u", "%OU": "%U", "%OV": "%V", "%Ow": "%w", "%OW": "%W", "%Oy": "%y" };
      for (var rule in EXPANSION_RULES_1) {
        pattern = pattern.replace(new RegExp(rule, "g"), EXPANSION_RULES_1[rule]);
      }
      var WEEKDAYS = ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"];
      var MONTHS = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"];
      function leadingSomething(value, digits, character) {
        var str = typeof value == "number" ? value.toString() : value || "";
        while (str.length < digits) {
          str = character[0] + str;
        }
        return str;
      }
      function leadingNulls(value, digits) {
        return leadingSomething(value, digits, "0");
      }
      function compareByDay(date1, date2) {
        function sgn(value) {
          return value < 0 ? -1 : value > 0 ? 1 : 0;
        }
        var compare;
        if ((compare = sgn(date1.getFullYear() - date2.getFullYear())) === 0) {
          if ((compare = sgn(date1.getMonth() - date2.getMonth())) === 0) {
            compare = sgn(date1.getDate() - date2.getDate());
          }
        }
        return compare;
      }
      function getFirstWeekStartDate(janFourth) {
        switch (janFourth.getDay()) {
          case 0:
            return new Date(janFourth.getFullYear() - 1, 11, 29);
          case 1:
            return janFourth;
          case 2:
            return new Date(janFourth.getFullYear(), 0, 3);
          case 3:
            return new Date(janFourth.getFullYear(), 0, 2);
          case 4:
            return new Date(janFourth.getFullYear(), 0, 1);
          case 5:
            return new Date(janFourth.getFullYear() - 1, 11, 31);
          case 6:
            return new Date(janFourth.getFullYear() - 1, 11, 30);
        }
      }
      function getWeekBasedYear(date2) {
        var thisDate = addDays(new Date(date2.tm_year + 1900, 0, 1), date2.tm_yday);
        var janFourthThisYear = new Date(thisDate.getFullYear(), 0, 4);
        var janFourthNextYear = new Date(thisDate.getFullYear() + 1, 0, 4);
        var firstWeekStartThisYear = getFirstWeekStartDate(janFourthThisYear);
        var firstWeekStartNextYear = getFirstWeekStartDate(janFourthNextYear);
        if (compareByDay(firstWeekStartThisYear, thisDate) <= 0) {
          if (compareByDay(firstWeekStartNextYear, thisDate) <= 0) {
            return thisDate.getFullYear() + 1;
          }
          return thisDate.getFullYear();
        }
        return thisDate.getFullYear() - 1;
      }
      var EXPANSION_RULES_2 = { "%a": (date2) => WEEKDAYS[date2.tm_wday].substring(0, 3), "%A": (date2) => WEEKDAYS[date2.tm_wday], "%b": (date2) => MONTHS[date2.tm_mon].substring(0, 3), "%B": (date2) => MONTHS[date2.tm_mon], "%C": (date2) => {
        var year = date2.tm_year + 1900;
        return leadingNulls(year / 100 | 0, 2);
      }, "%d": (date2) => leadingNulls(date2.tm_mday, 2), "%e": (date2) => leadingSomething(date2.tm_mday, 2, " "), "%g": (date2) => getWeekBasedYear(date2).toString().substring(2), "%G": (date2) => getWeekBasedYear(date2), "%H": (date2) => leadingNulls(date2.tm_hour, 2), "%I": (date2) => {
        var twelveHour = date2.tm_hour;
        if (twelveHour == 0)
          twelveHour = 12;
        else if (twelveHour > 12)
          twelveHour -= 12;
        return leadingNulls(twelveHour, 2);
      }, "%j": (date2) => leadingNulls(date2.tm_mday + arraySum(isLeapYear(date2.tm_year + 1900) ? MONTH_DAYS_LEAP : MONTH_DAYS_REGULAR, date2.tm_mon - 1), 3), "%m": (date2) => leadingNulls(date2.tm_mon + 1, 2), "%M": (date2) => leadingNulls(date2.tm_min, 2), "%n": () => "\n", "%p": (date2) => {
        if (date2.tm_hour >= 0 && date2.tm_hour < 12) {
          return "AM";
        }
        return "PM";
      }, "%S": (date2) => leadingNulls(date2.tm_sec, 2), "%t": () => "\t", "%u": (date2) => date2.tm_wday || 7, "%U": (date2) => {
        var days = date2.tm_yday + 7 - date2.tm_wday;
        return leadingNulls(Math.floor(days / 7), 2);
      }, "%V": (date2) => {
        var val = Math.floor((date2.tm_yday + 7 - (date2.tm_wday + 6) % 7) / 7);
        if ((date2.tm_wday + 371 - date2.tm_yday - 2) % 7 <= 2) {
          val++;
        }
        if (!val) {
          val = 52;
          var dec31 = (date2.tm_wday + 7 - date2.tm_yday - 1) % 7;
          if (dec31 == 4 || dec31 == 5 && isLeapYear(date2.tm_year % 400 - 1)) {
            val++;
          }
        } else if (val == 53) {
          var jan1 = (date2.tm_wday + 371 - date2.tm_yday) % 7;
          if (jan1 != 4 && (jan1 != 3 || !isLeapYear(date2.tm_year)))
            val = 1;
        }
        return leadingNulls(val, 2);
      }, "%w": (date2) => date2.tm_wday, "%W": (date2) => {
        var days = date2.tm_yday + 7 - (date2.tm_wday + 6) % 7;
        return leadingNulls(Math.floor(days / 7), 2);
      }, "%y": (date2) => (date2.tm_year + 1900).toString().substring(2), "%Y": (date2) => date2.tm_year + 1900, "%z": (date2) => {
        var off = date2.tm_gmtoff;
        var ahead = off >= 0;
        off = Math.abs(off) / 60;
        off = off / 60 * 100 + off % 60;
        return (ahead ? "+" : "-") + String("0000" + off).slice(-4);
      }, "%Z": (date2) => date2.tm_zone, "%%": () => "%" };
      pattern = pattern.replace(/%%/g, "\0\0");
      for (var rule in EXPANSION_RULES_2) {
        if (pattern.includes(rule)) {
          pattern = pattern.replace(new RegExp(rule, "g"), EXPANSION_RULES_2[rule](date));
        }
      }
      pattern = pattern.replace(/\0\0/g, "%");
      var bytes = intArrayFromString(pattern, false);
      if (bytes.length > maxsize) {
        return 0;
      }
      writeArrayToMemory(bytes, s);
      return bytes.length - 1;
    };
    var _strftime_l = (s, maxsize, format, tm, loc) => _strftime(s, maxsize, format, tm);
    var handleException = (e) => {
      if (e instanceof ExitStatus || e == "unwind") {
        return EXITSTATUS;
      }
      quit_(1, e);
    };
    var stringToUTF8OnStack = (str) => {
      var size = lengthBytesUTF8(str) + 1;
      var ret = stackAlloc(size);
      stringToUTF8(str, ret, size);
      return ret;
    };
    var FSNode = function(parent, name, mode, rdev) {
      if (!parent) {
        parent = this;
      }
      this.parent = parent;
      this.mount = parent.mount;
      this.mounted = null;
      this.id = FS.nextInode++;
      this.name = name;
      this.mode = mode;
      this.node_ops = {};
      this.stream_ops = {};
      this.rdev = rdev;
    };
    var readMode = 292 | 73;
    var writeMode = 146;
    Object.defineProperties(FSNode.prototype, { read: { get: function() {
      return (this.mode & readMode) === readMode;
    }, set: function(val) {
      val ? this.mode |= readMode : this.mode &= ~readMode;
    } }, write: { get: function() {
      return (this.mode & writeMode) === writeMode;
    }, set: function(val) {
      val ? this.mode |= writeMode : this.mode &= ~writeMode;
    } }, isFolder: { get: function() {
      return FS.isDir(this.mode);
    } }, isDevice: { get: function() {
      return FS.isChrdev(this.mode);
    } } });
    FS.FSNode = FSNode;
    FS.createPreloadedFile = FS_createPreloadedFile;
    FS.staticInit();
    Module["FS_createPath"] = FS.createPath;
    Module["FS_createDataFile"] = FS.createDataFile;
    Module["FS_createPreloadedFile"] = FS.createPreloadedFile;
    Module["FS_unlink"] = FS.unlink;
    Module["FS_createLazyFile"] = FS.createLazyFile;
    Module["FS_createDevice"] = FS.createDevice;
    var wasmImports = { a: ___assert_fail, b: ___cxa_throw, e: ___syscall_fcntl64, r: ___syscall_getdents64, v: ___syscall_ioctl, f: ___syscall_openat, p: ___syscall_rmdir, o: ___syscall_stat64, q: ___syscall_unlinkat, j: __emscripten_get_now_is_monotonic, h: _abort, g: _emscripten_date_now, k: _emscripten_memcpy_js, n: _emscripten_resize_heap, s: _environ_get, t: _environ_sizes_get, d: _exit, c: _fd_close, u: _fd_read, l: _fd_seek, i: _fd_write, m: _strftime_l };
    var wasmExports = createWasm();
    var ___wasm_call_ctors = () => (___wasm_call_ctors = wasmExports["x"])();
    var _main = Module["_main"] = (a0, a1) => (_main = Module["_main"] = wasmExports["y"])(a0, a1);
    var ___errno_location = () => (___errno_location = wasmExports["z"])();
    var _free = (a0) => (_free = wasmExports["free"])(a0);
    var _malloc = (a0) => (_malloc = wasmExports["malloc"])(a0);
    var stackAlloc = (a0) => (stackAlloc = wasmExports["B"])(a0);
    var ___cxa_is_pointer_type = (a0) => (___cxa_is_pointer_type = wasmExports["C"])(a0);
    Module["addRunDependency"] = addRunDependency;
    Module["removeRunDependency"] = removeRunDependency;
    Module["FS_createPath"] = FS.createPath;
    Module["FS_createLazyFile"] = FS.createLazyFile;
    Module["FS_createDevice"] = FS.createDevice;
    Module["callMain"] = callMain;
    Module["FS_createPreloadedFile"] = FS.createPreloadedFile;
    Module["FS"] = FS;
    Module["FS_createDataFile"] = FS.createDataFile;
    Module["FS_unlink"] = FS.unlink;
    var calledRun;
    dependenciesFulfilled = function runCaller() {
      if (!calledRun)
        run();
      if (!calledRun)
        dependenciesFulfilled = runCaller;
    };
    function callMain(args = []) {
      var entryFunction = _main;
      args.unshift(thisProgram);
      var argc = args.length;
      var argv = stackAlloc((argc + 1) * 4);
      var argv_ptr = argv;
      args.forEach((arg) => {
        HEAPU32[argv_ptr >> 2] = stringToUTF8OnStack(arg);
        argv_ptr += 4;
      });
      HEAPU32[argv_ptr >> 2] = 0;
      try {
        var ret = entryFunction(argc, argv);
        exitJS(ret, true);
        return ret;
      } catch (e) {
        return handleException(e);
      }
    }
    function run(args = arguments_) {
      if (runDependencies > 0) {
        return;
      }
      preRun();
      if (runDependencies > 0) {
        return;
      }
      function doRun() {
        if (calledRun)
          return;
        calledRun = true;
        Module["calledRun"] = true;
        if (ABORT)
          return;
        initRuntime();
        preMain();
        readyPromiseResolve(Module);
        if (Module["onRuntimeInitialized"])
          Module["onRuntimeInitialized"]();
        if (shouldRunNow)
          callMain(args);
        postRun();
      }
      if (Module["setStatus"]) {
        Module["setStatus"]("Running...");
        setTimeout(function() {
          setTimeout(function() {
            Module["setStatus"]("");
          }, 1);
          doRun();
        }, 1);
      } else {
        doRun();
      }
    }
    if (Module["preInit"]) {
      if (typeof Module["preInit"] == "function")
        Module["preInit"] = [Module["preInit"]];
      while (Module["preInit"].length > 0) {
        Module["preInit"].pop()();
      }
    }
    var shouldRunNow = false;
    if (Module["noInitialRun"])
      shouldRunNow = false;
    run();
    return moduleArg.ready;
  };
})();
export {
  createPiperPhonemize
};
');
+  const ort = await import(`data:text/javascript;base64,/*!
 * ONNX Runtime Web v1.18.0
 * Copyright (c) Microsoft Corporation. All rights reserved.
 * Licensed under the MIT License.
 */
var vd=Object.create;var Pn=Object.defineProperty;var _d=Object.getOwnPropertyDescriptor;var Od=Object.getOwnPropertyNames;var Id=Object.getPrototypeOf,Sd=Object.prototype.hasOwnProperty;var L=(a,t)=>()=>(a&&(t=a(a=0)),t);var me=(a,t)=>()=>(t||a((t={exports:{}}).exports,t),t.exports),Sr=(a,t)=>{for(var o in t)Pn(a,o,{get:t[o],enumerable:!0})},Va=(a,t,o,e)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of Od(t))!Sd.call(a,r)&&r!==o&&Pn(a,r,{get:()=>t[r],enumerable:!(e=_d(t,r))||e.enumerable});return a};var Ar=(a,t,o)=>(o=a!=null?vd(Id(a)):{},Va(t||!a||!a.__esModule?Pn(o,"default",{value:a,enumerable:!0}):o,a)),ar=a=>Va(Pn({},"__esModule",{value:!0}),a);var En,sr,Pr,Ad,Dn,Ln=L(()=>{"use strict";En=new Map,sr=[],Pr=(a,t,o)=>{if(t&&typeof t.init=="function"&&typeof t.createInferenceSessionHandler=="function"){let e=En.get(a);if(e===void 0)En.set(a,{backend:t,priority:o});else{if(e.priority>o)return;if(e.priority===o&&e.backend!==t)throw new Error(`cannot register backend "${a}" using priority ${o}`)}if(o>=0){let r=sr.indexOf(a);r!==-1&&sr.splice(r,1);for(let n=0;n<sr.length;n++)if(En.get(sr[n]).priority<=o){sr.splice(n,0,a);return}sr.push(a)}return}throw new TypeError("not a valid backend")},Ad=async a=>{let t=En.get(a);if(!t)return"backend not found.";if(t.initialized)return t.backend;if(t.aborted)return t.error;{let o=!!t.initPromise;try{return o||(t.initPromise=t.backend.init(a)),await t.initPromise,t.initialized=!0,t.backend}catch(e){return o||(t.error=`${e}`,t.aborted=!0),t.error}finally{delete t.initPromise}}},Dn=async a=>{let t=a.executionProviders||[],o=t.map(u=>typeof u=="string"?u:u.name),e=o.length===0?sr:o,r,n=[],s=new Set;for(let u of e){let l=await Ad(u);typeof l=="string"?n.push({name:u,err:l}):(r||(r=l),r===l&&s.add(u))}if(!r)throw new Error(`no available backend found. ERR: ${n.map(u=>`[${u.name}] ${u.err}`).join(", ")}`);for(let{name:u,err:l}of n)o.includes(u)&&console.warn(`removing requested execution provider "${u}" from session options because it is not available: ${l}`);let i=t.filter(u=>s.has(typeof u=="string"?u:u.name));return[r,new Proxy(a,{get:(u,l)=>l==="executionProviders"?i:Reflect.get(u,l)})]}});var Wa=L(()=>{"use strict";Ln()});var Ha,qa=L(()=>{"use strict";Ha="1.18.0"});var ja,ut,Vo=L(()=>{"use strict";qa();ja="warning",ut={wasm:{},webgl:{},webgpu:{},versions:{common:Ha},set logLevel(a){if(a!==void 0){if(typeof a!="string"||["verbose","info","warning","error","fatal"].indexOf(a)===-1)throw new Error(`Unsupported logging level: ${a}`);ja=a}},get logLevel(){return ja}};Object.defineProperty(ut,"logLevel",{enumerable:!0})});var Z,Ya=L(()=>{"use strict";Vo();Z=ut});var Xa,Ka,Ja=L(()=>{"use strict";Xa=(a,t)=>{let o=typeof document<"u"?document.createElement("canvas"):new OffscreenCanvas(1,1);o.width=a.dims[3],o.height=a.dims[2];let e=o.getContext("2d");if(e!=null){let r,n;t?.tensorLayout!==void 0&&t.tensorLayout==="NHWC"?(r=a.dims[2],n=a.dims[3]):(r=a.dims[3],n=a.dims[2]);let s=t?.format!==void 0?t.format:"RGB",i=t?.norm,u,l;i===void 0||i.mean===void 0?u=[255,255,255,255]:typeof i.mean=="number"?u=[i.mean,i.mean,i.mean,i.mean]:(u=[i.mean[0],i.mean[1],i.mean[2],0],i.mean[3]!==void 0&&(u[3]=i.mean[3])),i===void 0||i.bias===void 0?l=[0,0,0,0]:typeof i.bias=="number"?l=[i.bias,i.bias,i.bias,i.bias]:(l=[i.bias[0],i.bias[1],i.bias[2],0],i.bias[3]!==void 0&&(l[3]=i.bias[3]));let c=n*r,p=0,d=c,T=c*2,w=-1;s==="RGBA"?(p=0,d=c,T=c*2,w=c*3):s==="RGB"?(p=0,d=c,T=c*2):s==="RBG"&&(p=0,T=c,d=c*2);for(let v=0;v<n;v++)for(let S=0;S<r;S++){let A=(a.data[p++]-l[0])*u[0],C=(a.data[d++]-l[1])*u[1],F=(a.data[T++]-l[2])*u[2],J=w===-1?255:(a.data[w++]-l[3])*u[3];e.fillStyle="rgba("+A+","+C+","+F+","+J+")",e.fillRect(S,v,1,1)}if("toDataURL"in o)return o.toDataURL();throw new Error("toDataURL is not supported")}else throw new Error("Can not access image data")},Ka=(a,t)=>{let o=typeof document<"u"?document.createElement("canvas").getContext("2d"):new OffscreenCanvas(1,1).getContext("2d"),e;if(o!=null){let r,n,s;t?.tensorLayout!==void 0&&t.tensorLayout==="NHWC"?(r=a.dims[2],n=a.dims[1],s=a.dims[3]):(r=a.dims[3],n=a.dims[2],s=a.dims[1]);let i=t!==void 0&&t.format!==void 0?t.format:"RGB",u=t?.norm,l,c;u===void 0||u.mean===void 0?l=[255,255,255,255]:typeof u.mean=="number"?l=[u.mean,u.mean,u.mean,u.mean]:(l=[u.mean[0],u.mean[1],u.mean[2],255],u.mean[3]!==void 0&&(l[3]=u.mean[3])),u===void 0||u.bias===void 0?c=[0,0,0,0]:typeof u.bias=="number"?c=[u.bias,u.bias,u.bias,u.bias]:(c=[u.bias[0],u.bias[1],u.bias[2],0],u.bias[3]!==void 0&&(c[3]=u.bias[3]));let p=n*r;if(t!==void 0&&(t.format!==void 0&&s===4&&t.format!=="RGBA"||s===3&&t.format!=="RGB"&&t.format!=="BGR"))throw new Error("Tensor format doesn't match input tensor dims");let d=4,T=0,w=1,v=2,S=3,A=0,C=p,F=p*2,J=-1;i==="RGBA"?(A=0,C=p,F=p*2,J=p*3):i==="RGB"?(A=0,C=p,F=p*2):i==="RBG"&&(A=0,F=p,C=p*2),e=o.createImageData(r,n);for(let j=0;j<n*r;T+=d,w+=d,v+=d,S+=d,j++)e.data[T]=(a.data[A++]-c[0])*l[0],e.data[w]=(a.data[C++]-c[1])*l[1],e.data[v]=(a.data[F++]-c[2])*l[2],e.data[S]=J===-1?255:(a.data[J++]-c[3])*l[3]}else throw new Error("Can not access image data");return e}});var Wo,Za,Qa,es,ts,rs=L(()=>{"use strict";Cn();Wo=(a,t)=>{if(a===void 0)throw new Error("Image buffer must be defined");if(t.height===void 0||t.width===void 0)throw new Error("Image height and width must be defined");if(t.tensorLayout==="NHWC")throw new Error("NHWC Tensor layout is not supported yet");let{height:o,width:e}=t,r=t.norm??{mean:255,bias:0},n,s;typeof r.mean=="number"?n=[r.mean,r.mean,r.mean,r.mean]:n=[r.mean[0],r.mean[1],r.mean[2],r.mean[3]??255],typeof r.bias=="number"?s=[r.bias,r.bias,r.bias,r.bias]:s=[r.bias[0],r.bias[1],r.bias[2],r.bias[3]??0];let i=t.format!==void 0?t.format:"RGBA",u=t.tensorFormat!==void 0&&t.tensorFormat!==void 0?t.tensorFormat:"RGB",l=o*e,c=u==="RGBA"?new Float32Array(l*4):new Float32Array(l*3),p=4,d=0,T=1,w=2,v=3,S=0,A=l,C=l*2,F=-1;i==="RGB"&&(p=3,d=0,T=1,w=2,v=-1),u==="RGBA"?F=l*3:u==="RBG"?(S=0,C=l,A=l*2):u==="BGR"&&(C=0,A=l,S=l*2);for(let j=0;j<l;j++,d+=p,w+=p,T+=p,v+=p)c[S++]=(a[d]+s[0])/n[0],c[A++]=(a[T]+s[1])/n[1],c[C++]=(a[w]+s[2])/n[2],F!==-1&&v!==-1&&(c[F++]=(a[v]+s[3])/n[3]);return u==="RGBA"?new Je("float32",c,[1,4,o,e]):new Je("float32",c,[1,3,o,e])},Za=async(a,t)=>{let o=typeof HTMLImageElement<"u"&&a instanceof HTMLImageElement,e=typeof ImageData<"u"&&a instanceof ImageData,r=typeof ImageBitmap<"u"&&a instanceof ImageBitmap,n=typeof a=="string",s,i=t??{},u=()=>{if(typeof document<"u")return document.createElement("canvas");if(typeof OffscreenCanvas<"u")return new OffscreenCanvas(1,1);throw new Error("Canvas is not supported")},l=c=>c instanceof HTMLCanvasElement||c instanceof OffscreenCanvas?c.getContext("2d"):null;if(o){let c=u();c.width=a.width,c.height=a.height;let p=l(c);if(p!=null){let d=a.height,T=a.width;if(t!==void 0&&t.resizedHeight!==void 0&&t.resizedWidth!==void 0&&(d=t.resizedHeight,T=t.resizedWidth),t!==void 0){if(i=t,t.tensorFormat!==void 0)throw new Error("Image input config format must be RGBA for HTMLImageElement");i.tensorFormat="RGBA",i.height=d,i.width=T}else i.tensorFormat="RGBA",i.height=d,i.width=T;p.drawImage(a,0,0),s=p.getImageData(0,0,T,d).data}else throw new Error("Can not access image data")}else if(e){let c,p;if(t!==void 0&&t.resizedWidth!==void 0&&t.resizedHeight!==void 0?(c=t.resizedHeight,p=t.resizedWidth):(c=a.height,p=a.width),t!==void 0&&(i=t),i.format="RGBA",i.height=c,i.width=p,t!==void 0){let d=u();d.width=p,d.height=c;let T=l(d);if(T!=null)T.putImageData(a,0,0),s=T.getImageData(0,0,p,c).data;else throw new Error("Can not access image data")}else s=a.data}else if(r){if(t===void 0)throw new Error("Please provide image config with format for Imagebitmap");let c=u();c.width=a.width,c.height=a.height;let p=l(c);if(p!=null){let d=a.height,T=a.width;return p.drawImage(a,0,0,T,d),s=p.getImageData(0,0,T,d).data,i.height=d,i.width=T,Wo(s,i)}else throw new Error("Can not access image data")}else{if(n)return new Promise((c,p)=>{let d=u(),T=l(d);if(!a||!T)return p();let w=new Image;w.crossOrigin="Anonymous",w.src=a,w.onload=()=>{d.width=w.width,d.height=w.height,T.drawImage(w,0,0,d.width,d.height);let v=T.getImageData(0,0,d.width,d.height);i.height=d.height,i.width=d.width,c(Wo(v.data,i))}});throw new Error("Input data provided is not supported - aborted tensor creation")}if(s!==void 0)return Wo(s,i);throw new Error("Input data provided is not supported - aborted tensor creation")},Qa=(a,t)=>{let{width:o,height:e,download:r,dispose:n}=t,s=[1,e,o,4];return new Je({location:"texture",type:"float32",texture:a,dims:s,download:r,dispose:n})},es=(a,t)=>{let{dataType:o,dims:e,download:r,dispose:n}=t;return new Je({location:"gpu-buffer",type:o??"float32",gpuBuffer:a,dims:e,download:r,dispose:n})},ts=(a,t,o)=>new Je({location:"cpu-pinned",type:a,data:t,dims:o??[t.length]})});var ur,Qr,ns,os,is=L(()=>{"use strict";ur=new Map([["float32",Float32Array],["uint8",Uint8Array],["int8",Int8Array],["uint16",Uint16Array],["int16",Int16Array],["int32",Int32Array],["bool",Uint8Array],["float64",Float64Array],["uint32",Uint32Array]]),Qr=new Map([[Float32Array,"float32"],[Uint8Array,"uint8"],[Int8Array,"int8"],[Uint16Array,"uint16"],[Int16Array,"int16"],[Int32Array,"int32"],[Float64Array,"float64"],[Uint32Array,"uint32"]]),ns=!1,os=()=>{if(!ns){ns=!0;let a=typeof BigInt64Array<"u"&&BigInt64Array.from,t=typeof BigUint64Array<"u"&&BigUint64Array.from,o=typeof Float16Array<"u"&&Float16Array.from;a&&(ur.set("int64",BigInt64Array),Qr.set(BigInt64Array,"int64")),t&&(ur.set("uint64",BigUint64Array),Qr.set(BigUint64Array,"uint64")),o?(ur.set("float16",Float16Array),Qr.set(Float16Array,"float16")):ur.set("float16",Uint16Array)}}});var as,ss,us=L(()=>{"use strict";Cn();as=a=>{let t=1;for(let o=0;o<a.length;o++){let e=a[o];if(typeof e!="number"||!Number.isSafeInteger(e))throw new TypeError(`dims[${o}] must be an integer, got: ${e}`);if(e<0)throw new RangeError(`dims[${o}] must be a non-negative integer, got: ${e}`);t*=e}return t},ss=(a,t)=>{switch(a.location){case"cpu":return new Je(a.type,a.data,t);case"cpu-pinned":return new Je({location:"cpu-pinned",data:a.data,type:a.type,dims:t});case"texture":return new Je({location:"texture",texture:a.texture,type:a.type,dims:t});case"gpu-buffer":return new Je({location:"gpu-buffer",gpuBuffer:a.gpuBuffer,type:a.type,dims:t});default:throw new Error(`tensorReshape: tensor location ${a.location} is not supported`)}}});var Je,Cn=L(()=>{"use strict";Ja();rs();is();us();Je=class{constructor(t,o,e){os();let r,n;if(typeof t=="object"&&"location"in t)switch(this.dataLocation=t.location,r=t.type,n=t.dims,t.location){case"cpu-pinned":{let i=ur.get(r);if(!i)throw new TypeError(`unsupported type "${r}" to create tensor from pinned buffer`);if(!(t.data instanceof i))throw new TypeError(`buffer should be of type ${i.name}`);this.cpuData=t.data;break}case"texture":{if(r!=="float32")throw new TypeError(`unsupported type "${r}" to create tensor from texture`);this.gpuTextureData=t.texture,this.downloader=t.download,this.disposer=t.dispose;break}case"gpu-buffer":{if(r!=="float32"&&r!=="float16"&&r!=="int32"&&r!=="int64"&&r!=="uint32"&&r!=="uint8"&&r!=="bool")throw new TypeError(`unsupported type "${r}" to create tensor from gpu buffer`);this.gpuBufferData=t.gpuBuffer,this.downloader=t.download,this.disposer=t.dispose;break}default:throw new Error(`Tensor constructor: unsupported location '${this.dataLocation}'`)}else{let i,u;if(typeof t=="string")if(r=t,u=e,t==="string"){if(!Array.isArray(o))throw new TypeError("A string tensor's data must be a string array.");i=o}else{let l=ur.get(t);if(l===void 0)throw new TypeError(`Unsupported tensor type: ${t}.`);if(Array.isArray(o)){if(t==="float16"&&l===Uint16Array)throw new TypeError("Creating a float16 tensor from number array is not supported. Please use Uint16Array as data.");t==="uint64"||t==="int64"?i=l.from(o,BigInt):i=l.from(o)}else if(o instanceof l)i=o;else throw new TypeError(`A ${r} tensor's data must be type of ${l}`)}else if(u=o,Array.isArray(t)){if(t.length===0)throw new TypeError("Tensor type cannot be inferred from an empty array.");let l=typeof t[0];if(l==="string")r="string",i=t;else if(l==="boolean")r="bool",i=Uint8Array.from(t);else throw new TypeError(`Invalid element type of data array: ${l}.`)}else{let l=Qr.get(t.constructor);if(l===void 0)throw new TypeError(`Unsupported type for tensor data: ${t.constructor}.`);r=l,i=t}if(u===void 0)u=[i.length];else if(!Array.isArray(u))throw new TypeError("A tensor's dims must be a number array");n=u,this.cpuData=i,this.dataLocation="cpu"}let s=as(n);if(this.cpuData&&s!==this.cpuData.length)throw new Error(`Tensor's size(${s}) does not match data length(${this.cpuData.length}).`);this.type=r,this.dims=n,this.size=s}static async fromImage(t,o){return Za(t,o)}static fromTexture(t,o){return Qa(t,o)}static fromGpuBuffer(t,o){return es(t,o)}static fromPinnedBuffer(t,o,e){return ts(t,o,e)}toDataURL(t){return Xa(this,t)}toImageData(t){return Ka(this,t)}get data(){if(this.ensureValid(),!this.cpuData)throw new Error("The data is not on CPU. Use `getData()` to download GPU data to CPU, or use `texture` or `gpuBuffer` property to access the GPU data directly.");return this.cpuData}get location(){return this.dataLocation}get texture(){if(this.ensureValid(),!this.gpuTextureData)throw new Error("The data is not stored as a WebGL texture.");return this.gpuTextureData}get gpuBuffer(){if(this.ensureValid(),!this.gpuBufferData)throw new Error("The data is not stored as a WebGPU buffer.");return this.gpuBufferData}async getData(t){switch(this.ensureValid(),this.dataLocation){case"cpu":case"cpu-pinned":return this.data;case"texture":case"gpu-buffer":{if(!this.downloader)throw new Error("The current tensor is not created with a specified data downloader.");if(this.isDownloading)throw new Error("The current tensor is being downloaded.");try{this.isDownloading=!0;let o=await this.downloader();return this.downloader=void 0,this.dataLocation="cpu",this.cpuData=o,t&&this.disposer&&(this.disposer(),this.disposer=void 0),o}finally{this.isDownloading=!1}}default:throw new Error(`cannot get data from location: ${this.dataLocation}`)}}dispose(){if(this.isDownloading)throw new Error("The current tensor is being downloaded.");this.disposer&&(this.disposer(),this.disposer=void 0),this.cpuData=void 0,this.gpuTextureData=void 0,this.gpuBufferData=void 0,this.downloader=void 0,this.isDownloading=void 0,this.dataLocation="none"}ensureValid(){if(this.dataLocation==="none")throw new Error("The tensor is disposed.")}reshape(t){if(this.ensureValid(),this.downloader||this.disposer)throw new Error("Cannot reshape a tensor that owns GPU resource.");return ss(this,t)}}});var Me,Fn=L(()=>{"use strict";Cn();Me=Je});var ls,fs,lr,fr,Ho=L(()=>{"use strict";Vo();ls=(a,t)=>{(typeof ut.trace>"u"?!ut.wasm.trace:!ut.trace)||console.timeStamp(`${a}::ORT::${t}`)},fs=(a,t)=>{let o=new Error().stack?.split(/\r\n|\r|\n/g)||[],e=!1;for(let r=0;r<o.length;r++){if(e&&!o[r].includes("TRACE_FUNC")){let n=`FUNC_${a}::${o[r].trim().split(" ")[1]}`;t&&(n+=`::${t}`),ls("CPU",n);return}o[r].includes("TRACE_FUNC")&&(e=!0)}},lr=a=>{(typeof ut.trace>"u"?!ut.wasm.trace:!ut.trace)||fs("BEGIN",a)},fr=a=>{(typeof ut.trace>"u"?!ut.wasm.trace:!ut.trace)||fs("END",a)}});var $n,cs=L(()=>{"use strict";Ln();Fn();Ho();$n=class a{constructor(t){this.handler=t}async run(t,o,e){lr();let r={},n={};if(typeof t!="object"||t===null||t instanceof Me||Array.isArray(t))throw new TypeError("'feeds' must be an object that use input names as keys and OnnxValue as corresponding values.");let s=!0;if(typeof o=="object"){if(o===null)throw new TypeError("Unexpected argument[1]: cannot be null.");if(o instanceof Me)throw new TypeError("'fetches' cannot be a Tensor");if(Array.isArray(o)){if(o.length===0)throw new TypeError("'fetches' cannot be an empty array.");s=!1;for(let l of o){if(typeof l!="string")throw new TypeError("'fetches' must be a string array or an object.");if(this.outputNames.indexOf(l)===-1)throw new RangeError(`'fetches' contains invalid output name: ${l}.`);r[l]=null}if(typeof e=="object"&&e!==null)n=e;else if(typeof e<"u")throw new TypeError("'options' must be an object.")}else{let l=!1,c=Object.getOwnPropertyNames(o);for(let p of this.outputNames)if(c.indexOf(p)!==-1){let d=o[p];(d===null||d instanceof Me)&&(l=!0,s=!1,r[p]=d)}if(l){if(typeof e=="object"&&e!==null)n=e;else if(typeof e<"u")throw new TypeError("'options' must be an object.")}else n=o}}else if(typeof o<"u")throw new TypeError("Unexpected argument[1]: must be 'fetches' or 'options'.");for(let l of this.inputNames)if(typeof t[l]>"u")throw new Error(`input '${l}' is missing in 'feeds'.`);if(s)for(let l of this.outputNames)r[l]=null;let i=await this.handler.run(t,r,n),u={};for(let l in i)if(Object.hasOwnProperty.call(i,l)){let c=i[l];c instanceof Me?u[l]=c:u[l]=new Me(c.type,c.data,c.dims)}return fr(),u}async release(){return this.handler.dispose()}static async create(t,o,e,r){lr();let n,s={};if(typeof t=="string"){if(n=t,typeof o=="object"&&o!==null)s=o;else if(typeof o<"u")throw new TypeError("'options' must be an object.")}else if(t instanceof Uint8Array){if(n=t,typeof o=="object"&&o!==null)s=o;else if(typeof o<"u")throw new TypeError("'options' must be an object.")}else if(t instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&t instanceof SharedArrayBuffer){let c=t,p=0,d=t.byteLength;if(typeof o=="object"&&o!==null)s=o;else if(typeof o=="number"){if(p=o,!Number.isSafeInteger(p))throw new RangeError("'byteOffset' must be an integer.");if(p<0||p>=c.byteLength)throw new RangeError(`'byteOffset' is out of range [0, ${c.byteLength}).`);if(d=t.byteLength-p,typeof e=="number"){if(d=e,!Number.isSafeInteger(d))throw new RangeError("'byteLength' must be an integer.");if(d<=0||p+d>c.byteLength)throw new RangeError(`'byteLength' is out of range (0, ${c.byteLength-p}].`);if(typeof r=="object"&&r!==null)s=r;else if(typeof r<"u")throw new TypeError("'options' must be an object.")}else if(typeof e<"u")throw new TypeError("'byteLength' must be a number.")}else if(typeof o<"u")throw new TypeError("'options' must be an object.");n=new Uint8Array(c,p,d)}else throw new TypeError("Unexpected argument[0]: must be 'path' or 'buffer'.");let[i,u]=await Dn(s),l=await i.createInferenceSessionHandler(n,u);return fr(),new a(l)}startProfiling(){this.handler.startProfiling()}endProfiling(){this.handler.endProfiling()}get inputNames(){return this.handler.inputNames}get outputNames(){return this.handler.outputNames}}});var Pd,ps=L(()=>{"use strict";cs();Pd=$n});var ds=L(()=>{"use strict"});var hs=L(()=>{"use strict"});var ms=L(()=>{"use strict"});var bs=L(()=>{"use strict"});var Ed,kn,gs=L(()=>{"use strict";Ln();Fn();Ed="Training backend could not be resolved. Make sure you're using the correct configuration & WebAssembly files.",kn=class a{constructor(t,o,e){this.handler=t,this.hasOptimizerModel=o,this.hasEvalModel=e}get trainingInputNames(){return this.handler.inputNames}get trainingOutputNames(){return this.handler.outputNames}get evalInputNames(){if(this.hasEvalModel)return this.handler.evalInputNames;throw new Error("This training session has no evalModel loaded.")}get evalOutputNames(){if(this.hasEvalModel)return this.handler.evalOutputNames;throw new Error("This training session has no evalModel loaded.")}static async create(t,o){let e=t.evalModel||"",r=t.optimizerModel||"",n=o||{},[s,i]=await Dn(n);if(s.createTrainingSessionHandler){let u=await s.createTrainingSessionHandler(t.checkpointState,t.trainModel,e,r,i);return new a(u,!!t.optimizerModel,!!t.evalModel)}else throw new Error(Ed)}typeNarrowingForRunStep(t,o,e,r,n){let s={},i={};if(typeof e!="object"||e===null||e instanceof Me||Array.isArray(e))throw new TypeError("'feeds' must be an object that use input names as keys and OnnxValue as corresponding values.");let u=!0;if(typeof r=="object"){if(r===null)throw new TypeError("Unexpected argument[1]: cannot be null.");if(r instanceof Me)throw new TypeError("'fetches' cannot be a Tensor");if(Array.isArray(r)){if(r.length===0)throw new TypeError("'fetches' cannot be an empty array.");u=!1;for(let l of r){if(typeof l!="string")throw new TypeError("'fetches' must be a string array or an object.");if(o.indexOf(l)===-1)throw new RangeError(`'fetches' contains invalid output name: ${l}.`);s[l]=null}if(typeof n=="object"&&n!==null)i=n;else if(typeof n<"u")throw new TypeError("'options' must be an object.")}else{let l=!1,c=Object.getOwnPropertyNames(r);for(let p of o)if(c.indexOf(p)!==-1){let d=r[p];(d===null||d instanceof Me)&&(l=!0,u=!1,s[p]=d)}if(l){if(typeof n=="object"&&n!==null)i=n;else if(typeof n<"u")throw new TypeError("'options' must be an object.")}else i=r}}else if(typeof r<"u")throw new TypeError("Unexpected argument[1]: must be 'fetches' or 'options'.");for(let l of t)if(typeof e[l]>"u")throw new Error(`input '${l}' is missing in 'feeds'.`);if(u)for(let l of o)s[l]=null;return[s,i]}convertHandlerReturnTypeToMapOfTensors(t){let o={};for(let e in t)if(Object.hasOwnProperty.call(t,e)){let r=t[e];r instanceof Me?o[e]=r:o[e]=new Me(r.type,r.data,r.dims)}return o}async lazyResetGrad(){await this.handler.lazyResetGrad()}async runTrainStep(t,o,e){let[r,n]=this.typeNarrowingForRunStep(this.trainingInputNames,this.trainingOutputNames,t,o,e),s=await this.handler.runTrainStep(t,r,n);return this.convertHandlerReturnTypeToMapOfTensors(s)}async runOptimizerStep(t){if(this.hasOptimizerModel)await this.handler.runOptimizerStep(t||{});else throw new Error("This TrainingSession has no OptimizerModel loaded.")}async runEvalStep(t,o,e){if(this.hasEvalModel){let[r,n]=this.typeNarrowingForRunStep(this.evalInputNames,this.evalOutputNames,t,o,e),s=await this.handler.runEvalStep(t,r,n);return this.convertHandlerReturnTypeToMapOfTensors(s)}else throw new Error("This TrainingSession has no EvalModel loaded.")}async getParametersSize(t=!0){return this.handler.getParametersSize(t)}async loadParametersBuffer(t,o=!0){let e=await this.getParametersSize(o);if(t.length!==4*e)throw new Error("Size of the buffer passed into loadParametersBuffer must match the number of parameters in the model. Please use getParametersSize method to check.");return this.handler.loadParametersBuffer(t,o)}async getContiguousParameters(t=!0){return this.handler.getContiguousParameters(t)}async release(){return this.handler.dispose()}}});var Dd,ys=L(()=>{"use strict";gs();Dd=kn});var qo={};Sr(qo,{InferenceSession:()=>Pd,TRACE:()=>ls,TRACE_FUNC_BEGIN:()=>lr,TRACE_FUNC_END:()=>fr,Tensor:()=>Me,TrainingSession:()=>Dd,env:()=>Z,registerBackend:()=>Pr});var Ot=L(()=>{"use strict";Wa();Ya();ps();Fn();ds();hs();Ho();ms();bs();ys()});function Xt(a,t,o,e){if(t===void 0)return Cd(a);if(o===void 0)Bn(a,t,1);else if(typeof o=="number"&&e===void 0)Bn(a,t,o);else if(typeof o=="string"&&e===void 0)Bn(a,o,1,t);else if(typeof o=="string"&&typeof e=="number")Bn(a,o,e,t);else throw new TypeError("input is valid")}function Cd(a){return{verbose:Xt.verbose.bind(null,a),info:Xt.info.bind(null,a),warning:Xt.warning.bind(null,a),error:Xt.error.bind(null,a),fatal:Xt.fatal.bind(null,a)}}function Bn(a,t,o,e){let r=en[e||""]||en[""];xs[a]<xs[r.minimalSeverity]||(r.logDateTime&&(t=`${new Date().toISOString()}|${t}`),r.logSourceLocation,Ld[r.provider].log(a,t,e))}var jo,Yo,xs,Ld,ws,en,ce,Rn,Mn,Gn,Nn,lt=L(()=>{"use strict";jo=class{log(t,o,e){}},Yo=class{log(t,o,e){console.log(`${this.color(t)} ${e?"\x1B[35m"+e+"\x1B[0m ":""}${o}`)}color(t){switch(t){case"verbose":return"\x1B[34;40mv\x1B[0m";case"info":return"\x1B[32mi\x1B[0m";case"warning":return"\x1B[30;43mw\x1B[0m";case"error":return"\x1B[31;40me\x1B[0m";case"fatal":return"\x1B[101mf\x1B[0m";default:throw new Error(`unsupported severity: ${t}`)}}},xs={verbose:1e3,info:2e3,warning:4e3,error:5e3,fatal:6e3},Ld={none:new jo,console:new Yo},ws={provider:"console",minimalSeverity:"warning",logDateTime:!0,logSourceLocation:!1},en={"":ws};(u=>{function a(l,c){u("verbose",l,c)}u.verbose=a;function t(l,c){u("info",l,c)}u.info=t;function o(l,c){u("warning",l,c)}u.warning=o;function e(l,c){u("error",l,c)}u.error=e;function r(l,c){u("fatal",l,c)}u.fatal=r;function n(l){en={},s("",l||{})}u.reset=n;function s(l,c){if(l==="*")n(c);else{let p=en[l]||ws;en[l]={provider:c.provider||p.provider,minimalSeverity:c.minimalSeverity||p.minimalSeverity,logDateTime:c.logDateTime===void 0?p.logDateTime:c.logDateTime,logSourceLocation:c.logSourceLocation===void 0?p.logSourceLocation:c.logSourceLocation}}}u.set=s;function i(l){let c={};l.logLevel&&(c.minimalSeverity=l.logLevel),s("",c)}u.setWithEnv=i})(Xt||={});ce=Xt,Rn=class{constructor(t,o,e,r,n,s){this.category=t;this.name=o;this.startTime=e;this.endCallback=r;this.timer=n;this.ctx=s}async end(){return this.endCallback(this)}async checkTimer(){if(this.ctx===void 0||this.timer===void 0)throw new Error("No webgl timer found");return this.ctx.endTimer(),this.ctx.waitForQueryAndGetTime(this.timer)}},Mn=class{constructor(t,o,e,r){this.category=t;this.name=o;this.startTime=e;this.endTime=r}},Gn=class{constructor(t,o,e){this._started=!1;this._flushPointer=0;this._started=!1,this._maxNumberEvents=t===void 0?1e4:t,this._flushBatchSize=o===void 0?10:o,this._flushIntervalInMilliseconds=e===void 0?5e3:e}static create(t){return t===void 0?new this:new this(t.maxNumberEvents,t.flushBatchSize,t.flushIntervalInMilliseconds)}start(){this._started=!0,this._timingEvents=[],this._flushTime=Nn(),this._flushPointer=0}stop(){for(this._started=!1;this._flushPointer<this._timingEvents.length;this._flushPointer++)this.logOneEvent(this._timingEvents[this._flushPointer])}event(t,o,e,r){let n=this._started?this.begin(t,o,r):void 0,s=!1,i=e();if(i&&typeof i.then=="function")return s=!0,new Promise((u,l)=>{i.then(async c=>{n&&await n.end(),u(c)},async c=>{n&&await n.end(),l(c)})});if(!s&&n){let u=n.end();if(u&&typeof u.then=="function")return new Promise((l,c)=>{u.then(()=>{l(i)},p=>{c(p)})})}return i}begin(t,o,e){if(!this._started)throw new Error("profiler is not started yet");if(e===void 0){let r=Nn();return this.flush(r),new Rn(t,o,r,n=>this.endSync(n))}else{let r=e.beginTimer();return new Rn(t,o,0,async n=>this.end(n),r,e)}}async end(t){let o=await t.checkTimer();this._timingEvents.length<this._maxNumberEvents&&(this._timingEvents.push(new Mn(t.category,t.name,t.startTime,o)),this.flush(o))}endSync(t){let o=Nn();this._timingEvents.length<this._maxNumberEvents&&(this._timingEvents.push(new Mn(t.category,t.name,t.startTime,o)),this.flush(o))}logOneEvent(t){ce.verbose(`Profiler.${t.category}`,`${(t.endTime-t.startTime).toFixed(2)}ms on event '${t.name}' at ${t.endTime.toFixed(2)}`)}flush(t){if(this._timingEvents.length-this._flushPointer>=this._flushBatchSize||t-this._flushTime>=this._flushIntervalInMilliseconds){for(let o=this._flushPointer;this._flushPointer<o+this._flushBatchSize&&this._flushPointer<this._timingEvents.length;this._flushPointer++)this.logOneEvent(this._timingEvents[this._flushPointer]);this._flushTime=Nn()}}get started(){return this._started}},Nn=typeof performance<"u"&&performance.now?()=>performance.now():Date.now});function vs(a,t,o){for(let e of o){let r=e[0],n=e[1],s=e[2],i=e[3],u=e[4];if(a.opType===r){for(let l of t)if((l.domain===n||l.domain==="ai.onnx"&&n==="")&&Fd(l.version,s))return{opImpl:i,opInit:u}}}throw new TypeError(`cannot resolve operator '${a.opType}' with opsets: ${t.map(e=>`${e.domain||"ai.onnx"} v${e.version}`).join(", ")}`)}function Fd(a,t){if(t.endsWith("+")){let o=Number.parseInt(t.substring(0,t.length-1),10);return!isNaN(o)&&o<=a}else if(t.split("-").length===2){let o=t.split("-"),e=Number.parseInt(o[0],10),r=Number.parseInt(o[1],10);return!isNaN(e)&&!isNaN(r)&&e<=a&&a<=r}else return Number.parseInt(t,10)===a}var _s=L(()=>{"use strict"});var Os=me(Xo=>{"use strict";Xo.__esModule=!0;var $d=function(){function a(t){if(!t)throw new TypeError("Invalid argument; `value` has no value.");this.value=a.EMPTY,t&&a.isGuid(t)&&(this.value=t)}return a.isGuid=function(t){var o=t.toString();return t&&(t instanceof a||a.validator.test(o))},a.create=function(){return new a([a.gen(2),a.gen(1),a.gen(1),a.gen(1),a.gen(3)].join("-"))},a.createEmpty=function(){return new a("emptyguid")},a.parse=function(t){return new a(t)},a.raw=function(){return[a.gen(2),a.gen(1),a.gen(1),a.gen(1),a.gen(3)].join("-")},a.gen=function(t){for(var o="",e=0;e<t;e++)o+=((1+Math.random())*65536|0).toString(16).substring(1);return o},a.prototype.equals=function(t){return a.isGuid(t)&&this.value===t.toString()},a.prototype.isEmpty=function(){return this.value===a.EMPTY},a.prototype.toString=function(){return this.value},a.prototype.toJSON=function(){return{value:this.value}},a.validator=new RegExp("^[a-z0-9]{8}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{12}$","i"),a.EMPTY="00000000-0000-0000-0000-000000000000",a}();Xo.Guid=$d});function be(a,t,o){this.low=a|0,this.high=t|0,this.unsigned=!!o}function Xe(a){return(a&&a.__isLong__)===!0}function Is(a){var t=Math.clz32(a&-a);return a?31-t:t}function cr(a,t){var o,e,r;return t?(a>>>=0,(r=0<=a&&a<256)&&(e=As[a],e)?e:(o=le(a,0,!0),r&&(As[a]=o),o)):(a|=0,(r=-128<=a&&a<128)&&(e=Ss[a],e)?e:(o=le(a,a<0?-1:0,!1),r&&(Ss[a]=o),o))}function ct(a,t){if(isNaN(a))return t?zt:It;if(t){if(a<0)return zt;if(a>=Ls)return $s}else{if(a<=-Es)return nt;if(a+1>=Es)return Fs}return a<0?ct(-a,t).neg():le(a%Dr|0,a/Dr|0,t)}function le(a,t,o){return new be(a,t,o)}function Jo(a,t,o){if(a.length===0)throw Error("empty string");if(typeof t=="number"?(o=t,t=!1):t=!!t,a==="NaN"||a==="Infinity"||a==="+Infinity"||a==="-Infinity")return t?zt:It;if(o=o||10,o<2||36<o)throw RangeError("radix");var e;if((e=a.indexOf("-"))>0)throw Error("interior hyphen");if(e===0)return Jo(a.substring(1),t,o).neg();for(var r=ct(Un(o,8)),n=It,s=0;s<a.length;s+=8){var i=Math.min(8,a.length-s),u=parseInt(a.substring(s,s+i),o);if(i<8){var l=ct(Un(o,i));n=n.mul(l).add(ct(u))}else n=n.mul(r),n=n.add(ct(u))}return n.unsigned=t,n}function St(a,t){return typeof a=="number"?ct(a,t):typeof a=="string"?Jo(a,t):le(a.low,a.high,typeof t=="boolean"?t:a.unsigned)}var ft,Ss,As,Un,Ps,kd,Dr,Ls,Es,Ds,It,zt,Er,Cs,Ko,Fs,$s,nt,B,Vt,Zo=L(()=>{ft=null;try{ft=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{}be.prototype.__isLong__;Object.defineProperty(be.prototype,"__isLong__",{value:!0});be.isLong=Xe;Ss={},As={};be.fromInt=cr;be.fromNumber=ct;be.fromBits=le;Un=Math.pow;be.fromString=Jo;be.fromValue=St;Ps=65536,kd=1<<24,Dr=Ps*Ps,Ls=Dr*Dr,Es=Ls/2,Ds=cr(kd),It=cr(0);be.ZERO=It;zt=cr(0,!0);be.UZERO=zt;Er=cr(1);be.ONE=Er;Cs=cr(1,!0);be.UONE=Cs;Ko=cr(-1);be.NEG_ONE=Ko;Fs=le(-1,2147483647,!1);be.MAX_VALUE=Fs;$s=le(-1,-1,!0);be.MAX_UNSIGNED_VALUE=$s;nt=le(0,-2147483648,!1);be.MIN_VALUE=nt;B=be.prototype;B.toInt=function(){return this.unsigned?this.low>>>0:this.low};B.toNumber=function(){return this.unsigned?(this.high>>>0)*Dr+(this.low>>>0):this.high*Dr+(this.low>>>0)};B.toString=function(t){if(t=t||10,t<2||36<t)throw RangeError("radix");if(this.isZero())return"0";if(this.isNegative())if(this.eq(nt)){var o=ct(t),e=this.div(o),r=e.mul(o).sub(this);return e.toString(t)+r.toInt().toString(t)}else return"-"+this.neg().toString(t);for(var n=ct(Un(t,6),this.unsigned),s=this,i="";;){var u=s.div(n),l=s.sub(u.mul(n)).toInt()>>>0,c=l.toString(t);if(s=u,s.isZero())return c+i;for(;c.length<6;)c="0"+c;i=""+c+i}};B.getHighBits=function(){return this.high};B.getHighBitsUnsigned=function(){return this.high>>>0};B.getLowBits=function(){return this.low};B.getLowBitsUnsigned=function(){return this.low>>>0};B.getNumBitsAbs=function(){if(this.isNegative())return this.eq(nt)?64:this.neg().getNumBitsAbs();for(var t=this.high!=0?this.high:this.low,o=31;o>0&&!(t&1<<o);o--);return this.high!=0?o+33:o+1};B.isZero=function(){return this.high===0&&this.low===0};B.eqz=B.isZero;B.isNegative=function(){return!this.unsigned&&this.high<0};B.isPositive=function(){return this.unsigned||this.high>=0};B.isOdd=function(){return(this.low&1)===1};B.isEven=function(){return(this.low&1)===0};B.equals=function(t){return Xe(t)||(t=St(t)),this.unsigned!==t.unsigned&&this.high>>>31===1&&t.high>>>31===1?!1:this.high===t.high&&this.low===t.low};B.eq=B.equals;B.notEquals=function(t){return!this.eq(t)};B.neq=B.notEquals;B.ne=B.notEquals;B.lessThan=function(t){return this.comp(t)<0};B.lt=B.lessThan;B.lessThanOrEqual=function(t){return this.comp(t)<=0};B.lte=B.lessThanOrEqual;B.le=B.lessThanOrEqual;B.greaterThan=function(t){return this.comp(t)>0};B.gt=B.greaterThan;B.greaterThanOrEqual=function(t){return this.comp(t)>=0};B.gte=B.greaterThanOrEqual;B.ge=B.greaterThanOrEqual;B.compare=function(t){if(Xe(t)||(t=St(t)),this.eq(t))return 0;var o=this.isNegative(),e=t.isNegative();return o&&!e?-1:!o&&e?1:this.unsigned?t.high>>>0>this.high>>>0||t.high===this.high&&t.low>>>0>this.low>>>0?-1:1:this.sub(t).isNegative()?-1:1};B.comp=B.compare;B.negate=function(){return!this.unsigned&&this.eq(nt)?nt:this.not().add(Er)};B.neg=B.negate;B.add=function(t){Xe(t)||(t=St(t));var o=this.high>>>16,e=this.high&65535,r=this.low>>>16,n=this.low&65535,s=t.high>>>16,i=t.high&65535,u=t.low>>>16,l=t.low&65535,c=0,p=0,d=0,T=0;return T+=n+l,d+=T>>>16,T&=65535,d+=r+u,p+=d>>>16,d&=65535,p+=e+i,c+=p>>>16,p&=65535,c+=o+s,c&=65535,le(d<<16|T,c<<16|p,this.unsigned)};B.subtract=function(t){return Xe(t)||(t=St(t)),this.add(t.neg())};B.sub=B.subtract;B.multiply=function(t){if(this.isZero())return this;if(Xe(t)||(t=St(t)),ft){var o=ft.mul(this.low,this.high,t.low,t.high);return le(o,ft.get_high(),this.unsigned)}if(t.isZero())return this.unsigned?zt:It;if(this.eq(nt))return t.isOdd()?nt:It;if(t.eq(nt))return this.isOdd()?nt:It;if(this.isNegative())return t.isNegative()?this.neg().mul(t.neg()):this.neg().mul(t).neg();if(t.isNegative())return this.mul(t.neg()).neg();if(this.lt(Ds)&&t.lt(Ds))return ct(this.toNumber()*t.toNumber(),this.unsigned);var e=this.high>>>16,r=this.high&65535,n=this.low>>>16,s=this.low&65535,i=t.high>>>16,u=t.high&65535,l=t.low>>>16,c=t.low&65535,p=0,d=0,T=0,w=0;return w+=s*c,T+=w>>>16,w&=65535,T+=n*c,d+=T>>>16,T&=65535,T+=s*l,d+=T>>>16,T&=65535,d+=r*c,p+=d>>>16,d&=65535,d+=n*l,p+=d>>>16,d&=65535,d+=s*u,p+=d>>>16,d&=65535,p+=e*c+r*l+n*u+s*i,p&=65535,le(T<<16|w,p<<16|d,this.unsigned)};B.mul=B.multiply;B.divide=function(t){if(Xe(t)||(t=St(t)),t.isZero())throw Error("division by zero");if(ft){if(!this.unsigned&&this.high===-2147483648&&t.low===-1&&t.high===-1)return this;var o=(this.unsigned?ft.div_u:ft.div_s)(this.low,this.high,t.low,t.high);return le(o,ft.get_high(),this.unsigned)}if(this.isZero())return this.unsigned?zt:It;var e,r,n;if(this.unsigned){if(t.unsigned||(t=t.toUnsigned()),t.gt(this))return zt;if(t.gt(this.shru(1)))return Cs;n=zt}else{if(this.eq(nt)){if(t.eq(Er)||t.eq(Ko))return nt;if(t.eq(nt))return Er;var s=this.shr(1);return e=s.div(t).shl(1),e.eq(It)?t.isNegative()?Er:Ko:(r=this.sub(t.mul(e)),n=e.add(r.div(t)),n)}else if(t.eq(nt))return this.unsigned?zt:It;if(this.isNegative())return t.isNegative()?this.neg().div(t.neg()):this.neg().div(t).neg();if(t.isNegative())return this.div(t.neg()).neg();n=It}for(r=this;r.gte(t);){e=Math.max(1,Math.floor(r.toNumber()/t.toNumber()));for(var i=Math.ceil(Math.log(e)/Math.LN2),u=i<=48?1:Un(2,i-48),l=ct(e),c=l.mul(t);c.isNegative()||c.gt(r);)e-=u,l=ct(e,this.unsigned),c=l.mul(t);l.isZero()&&(l=Er),n=n.add(l),r=r.sub(c)}return n};B.div=B.divide;B.modulo=function(t){if(Xe(t)||(t=St(t)),ft){var o=(this.unsigned?ft.rem_u:ft.rem_s)(this.low,this.high,t.low,t.high);return le(o,ft.get_high(),this.unsigned)}return this.sub(this.div(t).mul(t))};B.mod=B.modulo;B.rem=B.modulo;B.not=function(){return le(~this.low,~this.high,this.unsigned)};B.countLeadingZeros=function(){return this.high?Math.clz32(this.high):Math.clz32(this.low)+32};B.clz=B.countLeadingZeros;B.countTrailingZeros=function(){return this.low?Is(this.low):Is(this.high)+32};B.ctz=B.countTrailingZeros;B.and=function(t){return Xe(t)||(t=St(t)),le(this.low&t.low,this.high&t.high,this.unsigned)};B.or=function(t){return Xe(t)||(t=St(t)),le(this.low|t.low,this.high|t.high,this.unsigned)};B.xor=function(t){return Xe(t)||(t=St(t)),le(this.low^t.low,this.high^t.high,this.unsigned)};B.shiftLeft=function(t){return Xe(t)&&(t=t.toInt()),(t&=63)===0?this:t<32?le(this.low<<t,this.high<<t|this.low>>>32-t,this.unsigned):le(0,this.low<<t-32,this.unsigned)};B.shl=B.shiftLeft;B.shiftRight=function(t){return Xe(t)&&(t=t.toInt()),(t&=63)===0?this:t<32?le(this.low>>>t|this.high<<32-t,this.high>>t,this.unsigned):le(this.high>>t-32,this.high>=0?0:-1,this.unsigned)};B.shr=B.shiftRight;B.shiftRightUnsigned=function(t){return Xe(t)&&(t=t.toInt()),(t&=63)===0?this:t<32?le(this.low>>>t|this.high<<32-t,this.high>>>t,this.unsigned):t===32?le(this.high,0,this.unsigned):le(this.high>>>t-32,0,this.unsigned)};B.shru=B.shiftRightUnsigned;B.shr_u=B.shiftRightUnsigned;B.rotateLeft=function(t){var o;return Xe(t)&&(t=t.toInt()),(t&=63)===0?this:t===32?le(this.high,this.low,this.unsigned):t<32?(o=32-t,le(this.low<<t|this.high>>>o,this.high<<t|this.low>>>o,this.unsigned)):(t-=32,o=32-t,le(this.high<<t|this.low>>>o,this.low<<t|this.high>>>o,this.unsigned))};B.rotl=B.rotateLeft;B.rotateRight=function(t){var o;return Xe(t)&&(t=t.toInt()),(t&=63)===0?this:t===32?le(this.high,this.low,this.unsigned):t<32?(o=32-t,le(this.high<<o|this.low>>>t,this.low<<o|this.high>>>t,this.unsigned)):(t-=32,o=32-t,le(this.low<<o|this.high>>>t,this.high<<o|this.low>>>t,this.unsigned))};B.rotr=B.rotateRight;B.toSigned=function(){return this.unsigned?le(this.low,this.high,!1):this};B.toUnsigned=function(){return this.unsigned?this:le(this.low,this.high,!0)};B.toBytes=function(t){return t?this.toBytesLE():this.toBytesBE()};B.toBytesLE=function(){var t=this.high,o=this.low;return[o&255,o>>>8&255,o>>>16&255,o>>>24,t&255,t>>>8&255,t>>>16&255,t>>>24]};B.toBytesBE=function(){var t=this.high,o=this.low;return[t>>>24,t>>>16&255,t>>>8&255,t&255,o>>>24,o>>>16&255,o>>>8&255,o&255]};be.fromBytes=function(t,o,e){return e?be.fromBytesLE(t,o):be.fromBytesBE(t,o)};be.fromBytesLE=function(t,o){return new be(t[0]|t[1]<<8|t[2]<<16|t[3]<<24,t[4]|t[5]<<8|t[6]<<16|t[7]<<24,o)};be.fromBytesBE=function(t,o){return new be(t[4]<<24|t[5]<<16|t[6]<<8|t[7],t[0]<<24|t[1]<<16|t[2]<<8|t[3],o)};Vt=be});var _,zn=L(()=>{_={};_.Offset;_.Table;_.SIZEOF_SHORT=2;_.SIZEOF_INT=4;_.FILE_IDENTIFIER_LENGTH=4;_.SIZE_PREFIX_LENGTH=4;_.Encoding={UTF8_BYTES:1,UTF16_STRING:2};_.int32=new Int32Array(2);_.float32=new Float32Array(_.int32.buffer);_.float64=new Float64Array(_.int32.buffer);_.isLittleEndian=new Uint16Array(new Uint8Array([1,0]).buffer)[0]===1;_.Long=function(a,t){this.low=a|0,this.high=t|0};_.Long.create=function(a,t){return a==0&&t==0?_.Long.ZERO:new _.Long(a,t)};_.Long.prototype.toFloat64=function(){return(this.low>>>0)+this.high*4294967296};_.Long.prototype.equals=function(a){return this.low==a.low&&this.high==a.high};_.Long.ZERO=new _.Long(0,0);_.Builder=function(a){if(a)var t=a;else var t=1024;this.bb=_.ByteBuffer.allocate(t),this.space=t,this.minalign=1,this.vtable=null,this.vtable_in_use=0,this.isNested=!1,this.object_start=0,this.vtables=[],this.vector_num_elems=0,this.force_defaults=!1};_.Builder.prototype.clear=function(){this.bb.clear(),this.space=this.bb.capacity(),this.minalign=1,this.vtable=null,this.vtable_in_use=0,this.isNested=!1,this.object_start=0,this.vtables=[],this.vector_num_elems=0,this.force_defaults=!1};_.Builder.prototype.forceDefaults=function(a){this.force_defaults=a};_.Builder.prototype.dataBuffer=function(){return this.bb};_.Builder.prototype.asUint8Array=function(){return this.bb.bytes().subarray(this.bb.position(),this.bb.position()+this.offset())};_.Builder.prototype.prep=function(a,t){a>this.minalign&&(this.minalign=a);for(var o=~(this.bb.capacity()-this.space+t)+1&a-1;this.space<o+a+t;){var e=this.bb.capacity();this.bb=_.Builder.growByteBuffer(this.bb),this.space+=this.bb.capacity()-e}this.pad(o)};_.Builder.prototype.pad=function(a){for(var t=0;t<a;t++)this.bb.writeInt8(--this.space,0)};_.Builder.prototype.writeInt8=function(a){this.bb.writeInt8(this.space-=1,a)};_.Builder.prototype.writeInt16=function(a){this.bb.writeInt16(this.space-=2,a)};_.Builder.prototype.writeInt32=function(a){this.bb.writeInt32(this.space-=4,a)};_.Builder.prototype.writeInt64=function(a){this.bb.writeInt64(this.space-=8,a)};_.Builder.prototype.writeFloat32=function(a){this.bb.writeFloat32(this.space-=4,a)};_.Builder.prototype.writeFloat64=function(a){this.bb.writeFloat64(this.space-=8,a)};_.Builder.prototype.addInt8=function(a){this.prep(1,0),this.writeInt8(a)};_.Builder.prototype.addInt16=function(a){this.prep(2,0),this.writeInt16(a)};_.Builder.prototype.addInt32=function(a){this.prep(4,0),this.writeInt32(a)};_.Builder.prototype.addInt64=function(a){this.prep(8,0),this.writeInt64(a)};_.Builder.prototype.addFloat32=function(a){this.prep(4,0),this.writeFloat32(a)};_.Builder.prototype.addFloat64=function(a){this.prep(8,0),this.writeFloat64(a)};_.Builder.prototype.addFieldInt8=function(a,t,o){(this.force_defaults||t!=o)&&(this.addInt8(t),this.slot(a))};_.Builder.prototype.addFieldInt16=function(a,t,o){(this.force_defaults||t!=o)&&(this.addInt16(t),this.slot(a))};_.Builder.prototype.addFieldInt32=function(a,t,o){(this.force_defaults||t!=o)&&(this.addInt32(t),this.slot(a))};_.Builder.prototype.addFieldInt64=function(a,t,o){(this.force_defaults||!t.equals(o))&&(this.addInt64(t),this.slot(a))};_.Builder.prototype.addFieldFloat32=function(a,t,o){(this.force_defaults||t!=o)&&(this.addFloat32(t),this.slot(a))};_.Builder.prototype.addFieldFloat64=function(a,t,o){(this.force_defaults||t!=o)&&(this.addFloat64(t),this.slot(a))};_.Builder.prototype.addFieldOffset=function(a,t,o){(this.force_defaults||t!=o)&&(this.addOffset(t),this.slot(a))};_.Builder.prototype.addFieldStruct=function(a,t,o){t!=o&&(this.nested(t),this.slot(a))};_.Builder.prototype.nested=function(a){if(a!=this.offset())throw new Error("FlatBuffers: struct must be serialized inline.")};_.Builder.prototype.notNested=function(){if(this.isNested)throw new Error("FlatBuffers: object serialization must not be nested.")};_.Builder.prototype.slot=function(a){this.vtable[a]=this.offset()};_.Builder.prototype.offset=function(){return this.bb.capacity()-this.space};_.Builder.growByteBuffer=function(a){var t=a.capacity();if(t&3221225472)throw new Error("FlatBuffers: cannot grow buffer beyond 2 gigabytes.");var o=t<<1,e=_.ByteBuffer.allocate(o);return e.setPosition(o-t),e.bytes().set(a.bytes(),o-t),e};_.Builder.prototype.addOffset=function(a){this.prep(_.SIZEOF_INT,0),this.writeInt32(this.offset()-a+_.SIZEOF_INT)};_.Builder.prototype.startObject=function(a){this.notNested(),this.vtable==null&&(this.vtable=[]),this.vtable_in_use=a;for(var t=0;t<a;t++)this.vtable[t]=0;this.isNested=!0,this.object_start=this.offset()};_.Builder.prototype.endObject=function(){if(this.vtable==null||!this.isNested)throw new Error("FlatBuffers: endObject called without startObject");this.addInt32(0);for(var a=this.offset(),t=this.vtable_in_use-1;t>=0&&this.vtable[t]==0;t--);for(var o=t+1;t>=0;t--)this.addInt16(this.vtable[t]!=0?a-this.vtable[t]:0);var e=2;this.addInt16(a-this.object_start);var r=(o+e)*_.SIZEOF_SHORT;this.addInt16(r);var n=0,s=this.space;e:for(t=0;t<this.vtables.length;t++){var i=this.bb.capacity()-this.vtables[t];if(r==this.bb.readInt16(i)){for(var u=_.SIZEOF_SHORT;u<r;u+=_.SIZEOF_SHORT)if(this.bb.readInt16(s+u)!=this.bb.readInt16(i+u))continue e;n=this.vtables[t];break}}return n?(this.space=this.bb.capacity()-a,this.bb.writeInt32(this.space,n-a)):(this.vtables.push(this.offset()),this.bb.writeInt32(this.bb.capacity()-a,this.offset()-a)),this.isNested=!1,a};_.Builder.prototype.finish=function(a,t,o){var e=o?_.SIZE_PREFIX_LENGTH:0;if(t){var r=t;if(this.prep(this.minalign,_.SIZEOF_INT+_.FILE_IDENTIFIER_LENGTH+e),r.length!=_.FILE_IDENTIFIER_LENGTH)throw new Error("FlatBuffers: file identifier must be length "+_.FILE_IDENTIFIER_LENGTH);for(var n=_.FILE_IDENTIFIER_LENGTH-1;n>=0;n--)this.writeInt8(r.charCodeAt(n))}this.prep(this.minalign,_.SIZEOF_INT+e),this.addOffset(a),e&&this.addInt32(this.bb.capacity()-this.space),this.bb.setPosition(this.space)};_.Builder.prototype.finishSizePrefixed=function(a,t){this.finish(a,t,!0)};_.Builder.prototype.requiredField=function(a,t){var o=this.bb.capacity()-a,e=o-this.bb.readInt32(o),r=this.bb.readInt16(e+t)!=0;if(!r)throw new Error("FlatBuffers: field "+t+" must be set")};_.Builder.prototype.startVector=function(a,t,o){this.notNested(),this.vector_num_elems=t,this.prep(_.SIZEOF_INT,a*t),this.prep(o,a*t)};_.Builder.prototype.endVector=function(){return this.writeInt32(this.vector_num_elems),this.offset()};_.Builder.prototype.createString=function(a){if(a instanceof Uint8Array)var t=a;else for(var t=[],o=0;o<a.length;){var e,r=a.charCodeAt(o++);if(r<55296||r>=56320)e=r;else{var n=a.charCodeAt(o++);e=(r<<10)+n+(65536-56623104-56320)}e<128?t.push(e):(e<2048?t.push(e>>6&31|192):(e<65536?t.push(e>>12&15|224):t.push(e>>18&7|240,e>>12&63|128),t.push(e>>6&63|128)),t.push(e&63|128))}this.addInt8(0),this.startVector(1,t.length,1),this.bb.setPosition(this.space-=t.length);for(var o=0,s=this.space,i=this.bb.bytes();o<t.length;o++)i[s++]=t[o];return this.endVector()};_.Builder.prototype.createLong=function(a,t){return _.Long.create(a,t)};_.ByteBuffer=function(a){this.bytes_=a,this.position_=0};_.ByteBuffer.allocate=function(a){return new _.ByteBuffer(new Uint8Array(a))};_.ByteBuffer.prototype.clear=function(){this.position_=0};_.ByteBuffer.prototype.bytes=function(){return this.bytes_};_.ByteBuffer.prototype.position=function(){return this.position_};_.ByteBuffer.prototype.setPosition=function(a){this.position_=a};_.ByteBuffer.prototype.capacity=function(){return this.bytes_.length};_.ByteBuffer.prototype.readInt8=function(a){return this.readUint8(a)<<24>>24};_.ByteBuffer.prototype.readUint8=function(a){return this.bytes_[a]};_.ByteBuffer.prototype.readInt16=function(a){return this.readUint16(a)<<16>>16};_.ByteBuffer.prototype.readUint16=function(a){return this.bytes_[a]|this.bytes_[a+1]<<8};_.ByteBuffer.prototype.readInt32=function(a){return this.bytes_[a]|this.bytes_[a+1]<<8|this.bytes_[a+2]<<16|this.bytes_[a+3]<<24};_.ByteBuffer.prototype.readUint32=function(a){return this.readInt32(a)>>>0};_.ByteBuffer.prototype.readInt64=function(a){return new _.Long(this.readInt32(a),this.readInt32(a+4))};_.ByteBuffer.prototype.readUint64=function(a){return new _.Long(this.readUint32(a),this.readUint32(a+4))};_.ByteBuffer.prototype.readFloat32=function(a){return _.int32[0]=this.readInt32(a),_.float32[0]};_.ByteBuffer.prototype.readFloat64=function(a){return _.int32[_.isLittleEndian?0:1]=this.readInt32(a),_.int32[_.isLittleEndian?1:0]=this.readInt32(a+4),_.float64[0]};_.ByteBuffer.prototype.writeInt8=function(a,t){this.bytes_[a]=t};_.ByteBuffer.prototype.writeUint8=function(a,t){this.bytes_[a]=t};_.ByteBuffer.prototype.writeInt16=function(a,t){this.bytes_[a]=t,this.bytes_[a+1]=t>>8};_.ByteBuffer.prototype.writeUint16=function(a,t){this.bytes_[a]=t,this.bytes_[a+1]=t>>8};_.ByteBuffer.prototype.writeInt32=function(a,t){this.bytes_[a]=t,this.bytes_[a+1]=t>>8,this.bytes_[a+2]=t>>16,this.bytes_[a+3]=t>>24};_.ByteBuffer.prototype.writeUint32=function(a,t){this.bytes_[a]=t,this.bytes_[a+1]=t>>8,this.bytes_[a+2]=t>>16,this.bytes_[a+3]=t>>24};_.ByteBuffer.prototype.writeInt64=function(a,t){this.writeInt32(a,t.low),this.writeInt32(a+4,t.high)};_.ByteBuffer.prototype.writeUint64=function(a,t){this.writeUint32(a,t.low),this.writeUint32(a+4,t.high)};_.ByteBuffer.prototype.writeFloat32=function(a,t){_.float32[0]=t,this.writeInt32(a,_.int32[0])};_.ByteBuffer.prototype.writeFloat64=function(a,t){_.float64[0]=t,this.writeInt32(a,_.int32[_.isLittleEndian?0:1]),this.writeInt32(a+4,_.int32[_.isLittleEndian?1:0])};_.ByteBuffer.prototype.getBufferIdentifier=function(){if(this.bytes_.length<this.position_+_.SIZEOF_INT+_.FILE_IDENTIFIER_LENGTH)throw new Error("FlatBuffers: ByteBuffer is too short to contain an identifier.");for(var a="",t=0;t<_.FILE_IDENTIFIER_LENGTH;t++)a+=String.fromCharCode(this.readInt8(this.position_+_.SIZEOF_INT+t));return a};_.ByteBuffer.prototype.__offset=function(a,t){var o=a-this.readInt32(a);return t<this.readInt16(o)?this.readInt16(o+t):0};_.ByteBuffer.prototype.__union=function(a,t){return a.bb_pos=t+this.readInt32(t),a.bb=this,a};_.ByteBuffer.prototype.__string=function(a,t){a+=this.readInt32(a);var o=this.readInt32(a),e="",r=0;if(a+=_.SIZEOF_INT,t===_.Encoding.UTF8_BYTES)return this.bytes_.subarray(a,a+o);for(;r<o;){var n,s=this.readUint8(a+r++);if(s<192)n=s;else{var i=this.readUint8(a+r++);if(s<224)n=(s&31)<<6|i&63;else{var u=this.readUint8(a+r++);if(s<240)n=(s&15)<<12|(i&63)<<6|u&63;else{var l=this.readUint8(a+r++);n=(s&7)<<18|(i&63)<<12|(u&63)<<6|l&63}}}n<65536?e+=String.fromCharCode(n):(n-=65536,e+=String.fromCharCode((n>>10)+55296,(n&1024-1)+56320))}return e};_.ByteBuffer.prototype.__indirect=function(a){return a+this.readInt32(a)};_.ByteBuffer.prototype.__vector=function(a){return a+this.readInt32(a)+_.SIZEOF_INT};_.ByteBuffer.prototype.__vector_len=function(a){return this.readInt32(a+this.readInt32(a))};_.ByteBuffer.prototype.__has_identifier=function(a){if(a.length!=_.FILE_IDENTIFIER_LENGTH)throw new Error("FlatBuffers: file identifier must be length "+_.FILE_IDENTIFIER_LENGTH);for(var t=0;t<_.FILE_IDENTIFIER_LENGTH;t++)if(a.charCodeAt(t)!=this.readInt8(this.position_+_.SIZEOF_INT+t))return!1;return!0};_.ByteBuffer.prototype.createLong=function(a,t){return _.Long.create(a,t)}});var V,tn=L(()=>{"use strict";zn();(t=>{let a;(e=>{let o;(n=>{let r;(F=>(F[F.UNDEFINED=0]="UNDEFINED",F[F.FLOAT=1]="FLOAT",F[F.INT=2]="INT",F[F.STRING=3]="STRING",F[F.TENSOR=4]="TENSOR",F[F.GRAPH=5]="GRAPH",F[F.FLOATS=6]="FLOATS",F[F.INTS=7]="INTS",F[F.STRINGS=8]="STRINGS",F[F.TENSORS=9]="TENSORS",F[F.GRAPHS=10]="GRAPHS",F[F.SPARSE_TENSOR=11]="SPARSE_TENSOR",F[F.SPARSE_TENSORS=12]="SPARSE_TENSORS"))(r=n.AttributeType||={})})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{let r;(l=>(l[l.UNKNOWN=0]="UNKNOWN",l[l.VALUE=1]="VALUE",l[l.PARAM=2]="PARAM"))(r=n.DimensionValueType||={})})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{let r;(Y=>(Y[Y.UNDEFINED=0]="UNDEFINED",Y[Y.FLOAT=1]="FLOAT",Y[Y.UINT8=2]="UINT8",Y[Y.INT8=3]="INT8",Y[Y.UINT16=4]="UINT16",Y[Y.INT16=5]="INT16",Y[Y.INT32=6]="INT32",Y[Y.INT64=7]="INT64",Y[Y.STRING=8]="STRING",Y[Y.BOOL=9]="BOOL",Y[Y.FLOAT16=10]="FLOAT16",Y[Y.DOUBLE=11]="DOUBLE",Y[Y.UINT32=12]="UINT32",Y[Y.UINT64=13]="UINT64",Y[Y.COMPLEX64=14]="COMPLEX64",Y[Y.COMPLEX128=15]="COMPLEX128",Y[Y.BFLOAT16=16]="BFLOAT16",Y[Y.FLOAT8E4M3FN=17]="FLOAT8E4M3FN",Y[Y.FLOAT8E4M3FNUZ=18]="FLOAT8E4M3FNUZ",Y[Y.FLOAT8E5M2=19]="FLOAT8E5M2",Y[Y.FLOAT8E5M2FNUZ=20]="FLOAT8E5M2FNUZ"))(r=n.TensorDataType||={})})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{let r;(u=>(u[u.Primitive=0]="Primitive",u[u.Fused=1]="Fused"))(r=n.NodeType||={})})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{let r;(c=>(c[c.NONE=0]="NONE",c[c.tensor_type=1]="tensor_type",c[c.sequence_type=2]="sequence_type",c[c.map_type=3]="map_type"))(r=n.TypeInfoValue||={})})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsShape(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsShape(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}dim(i,u){let l=this.bb.__offset(this.bb_pos,4);return l?(u||new t.experimental.fbs.Dimension).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}dimLength(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__vector_len(this.bb_pos+i):0}static startShape(i){i.startObject(1)}static addDim(i,u){i.addFieldOffset(0,u,0)}static createDimVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startDimVector(i,u){i.startVector(4,u,4)}static endShape(i){return i.endObject()}static createShape(i,u){return r.startShape(i),r.addDim(i,u),r.endShape(i)}}n.Shape=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsDimension(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsDimension(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}value(i){let u=this.bb.__offset(this.bb_pos,4);return u?(i||new t.experimental.fbs.DimensionValue).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}denotation(i){let u=this.bb.__offset(this.bb_pos,6);return u?this.bb.__string(this.bb_pos+u,i):null}static startDimension(i){i.startObject(2)}static addValue(i,u){i.addFieldOffset(0,u,0)}static addDenotation(i,u){i.addFieldOffset(1,u,0)}static endDimension(i){return i.endObject()}static createDimension(i,u,l){return r.startDimension(i),r.addValue(i,u),r.addDenotation(i,l),r.endDimension(i)}}n.Dimension=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsDimensionValue(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsDimensionValue(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}dimType(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.readInt8(this.bb_pos+i):0}dimValue(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.readInt64(this.bb_pos+i):this.bb.createLong(0,0)}dimParam(i){let u=this.bb.__offset(this.bb_pos,8);return u?this.bb.__string(this.bb_pos+u,i):null}static startDimensionValue(i){i.startObject(3)}static addDimType(i,u){i.addFieldInt8(0,u,0)}static addDimValue(i,u){i.addFieldInt64(1,u,i.createLong(0,0))}static addDimParam(i,u){i.addFieldOffset(2,u,0)}static endDimensionValue(i){return i.endObject()}static createDimensionValue(i,u,l,c){return r.startDimensionValue(i),r.addDimType(i,u),r.addDimValue(i,l),r.addDimParam(i,c),r.endDimensionValue(i)}}n.DimensionValue=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsTensorTypeAndShape(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsTensorTypeAndShape(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}elemType(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.readInt32(this.bb_pos+i):0}shape(i){let u=this.bb.__offset(this.bb_pos,6);return u?(i||new t.experimental.fbs.Shape).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}static startTensorTypeAndShape(i){i.startObject(2)}static addElemType(i,u){i.addFieldInt32(0,u,0)}static addShape(i,u){i.addFieldOffset(1,u,0)}static endTensorTypeAndShape(i){return i.endObject()}static createTensorTypeAndShape(i,u,l){return r.startTensorTypeAndShape(i),r.addElemType(i,u),r.addShape(i,l),r.endTensorTypeAndShape(i)}}n.TensorTypeAndShape=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsMapType(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsMapType(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}keyType(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.readInt32(this.bb_pos+i):0}valueType(i){let u=this.bb.__offset(this.bb_pos,6);return u?(i||new t.experimental.fbs.TypeInfo).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}static startMapType(i){i.startObject(2)}static addKeyType(i,u){i.addFieldInt32(0,u,0)}static addValueType(i,u){i.addFieldOffset(1,u,0)}static endMapType(i){return i.endObject()}static createMapType(i,u,l){return r.startMapType(i),r.addKeyType(i,u),r.addValueType(i,l),r.endMapType(i)}}n.MapType=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsSequenceType(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsSequenceType(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}elemType(i){let u=this.bb.__offset(this.bb_pos,4);return u?(i||new t.experimental.fbs.TypeInfo).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}static startSequenceType(i){i.startObject(1)}static addElemType(i,u){i.addFieldOffset(0,u,0)}static endSequenceType(i){return i.endObject()}static createSequenceType(i,u){return r.startSequenceType(i),r.addElemType(i,u),r.endSequenceType(i)}}n.SequenceType=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}nodeIndex(){return this.bb.readUint32(this.bb_pos)}srcArgIndex(){return this.bb.readInt32(this.bb_pos+4)}dstArgIndex(){return this.bb.readInt32(this.bb_pos+8)}static createEdgeEnd(i,u,l,c){return i.prep(4,12),i.writeInt32(c),i.writeInt32(l),i.writeInt32(u),i.offset()}}n.EdgeEnd=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsNodeEdge(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsNodeEdge(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}nodeIndex(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.readUint32(this.bb_pos+i):0}inputEdges(i,u){let l=this.bb.__offset(this.bb_pos,6);return l?(u||new t.experimental.fbs.EdgeEnd).__init(this.bb.__vector(this.bb_pos+l)+i*12,this.bb):null}inputEdgesLength(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__vector_len(this.bb_pos+i):0}outputEdges(i,u){let l=this.bb.__offset(this.bb_pos,8);return l?(u||new t.experimental.fbs.EdgeEnd).__init(this.bb.__vector(this.bb_pos+l)+i*12,this.bb):null}outputEdgesLength(){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.__vector_len(this.bb_pos+i):0}static startNodeEdge(i){i.startObject(3)}static addNodeIndex(i,u){i.addFieldInt32(0,u,0)}static addInputEdges(i,u){i.addFieldOffset(1,u,0)}static startInputEdgesVector(i,u){i.startVector(12,u,4)}static addOutputEdges(i,u){i.addFieldOffset(2,u,0)}static startOutputEdgesVector(i,u){i.startVector(12,u,4)}static endNodeEdge(i){return i.endObject()}static createNodeEdge(i,u,l,c){return r.startNodeEdge(i),r.addNodeIndex(i,u),r.addInputEdges(i,l),r.addOutputEdges(i,c),r.endNodeEdge(i)}}n.NodeEdge=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsNode(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsNode(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}name(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}docString(i){let u=this.bb.__offset(this.bb_pos,6);return u?this.bb.__string(this.bb_pos+u,i):null}domain(i){let u=this.bb.__offset(this.bb_pos,8);return u?this.bb.__string(this.bb_pos+u,i):null}sinceVersion(){let i=this.bb.__offset(this.bb_pos,10);return i?this.bb.readInt32(this.bb_pos+i):0}index(){let i=this.bb.__offset(this.bb_pos,12);return i?this.bb.readUint32(this.bb_pos+i):0}opType(i){let u=this.bb.__offset(this.bb_pos,14);return u?this.bb.__string(this.bb_pos+u,i):null}type(){let i=this.bb.__offset(this.bb_pos,16);return i?this.bb.readInt32(this.bb_pos+i):0}executionProviderType(i){let u=this.bb.__offset(this.bb_pos,18);return u?this.bb.__string(this.bb_pos+u,i):null}inputs(i,u){let l=this.bb.__offset(this.bb_pos,20);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}inputsLength(){let i=this.bb.__offset(this.bb_pos,20);return i?this.bb.__vector_len(this.bb_pos+i):0}outputs(i,u){let l=this.bb.__offset(this.bb_pos,22);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}outputsLength(){let i=this.bb.__offset(this.bb_pos,22);return i?this.bb.__vector_len(this.bb_pos+i):0}attributes(i,u){let l=this.bb.__offset(this.bb_pos,24);return l?(u||new t.experimental.fbs.Attribute).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}attributesLength(){let i=this.bb.__offset(this.bb_pos,24);return i?this.bb.__vector_len(this.bb_pos+i):0}inputArgCounts(i){let u=this.bb.__offset(this.bb_pos,26);return u?this.bb.readInt32(this.bb.__vector(this.bb_pos+u)+i*4):0}inputArgCountsLength(){let i=this.bb.__offset(this.bb_pos,26);return i?this.bb.__vector_len(this.bb_pos+i):0}inputArgCountsArray(){let i=this.bb.__offset(this.bb_pos,26);return i?new Int32Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+i),this.bb.__vector_len(this.bb_pos+i)):null}implicitInputs(i,u){let l=this.bb.__offset(this.bb_pos,28);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}implicitInputsLength(){let i=this.bb.__offset(this.bb_pos,28);return i?this.bb.__vector_len(this.bb_pos+i):0}static startNode(i){i.startObject(13)}static addName(i,u){i.addFieldOffset(0,u,0)}static addDocString(i,u){i.addFieldOffset(1,u,0)}static addDomain(i,u){i.addFieldOffset(2,u,0)}static addSinceVersion(i,u){i.addFieldInt32(3,u,0)}static addIndex(i,u){i.addFieldInt32(4,u,0)}static addOpType(i,u){i.addFieldOffset(5,u,0)}static addType(i,u){i.addFieldInt32(6,u,0)}static addExecutionProviderType(i,u){i.addFieldOffset(7,u,0)}static addInputs(i,u){i.addFieldOffset(8,u,0)}static createInputsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startInputsVector(i,u){i.startVector(4,u,4)}static addOutputs(i,u){i.addFieldOffset(9,u,0)}static createOutputsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startOutputsVector(i,u){i.startVector(4,u,4)}static addAttributes(i,u){i.addFieldOffset(10,u,0)}static createAttributesVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startAttributesVector(i,u){i.startVector(4,u,4)}static addInputArgCounts(i,u){i.addFieldOffset(11,u,0)}static createInputArgCountsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addInt32(u[l]);return i.endVector()}static startInputArgCountsVector(i,u){i.startVector(4,u,4)}static addImplicitInputs(i,u){i.addFieldOffset(12,u,0)}static createImplicitInputsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startImplicitInputsVector(i,u){i.startVector(4,u,4)}static endNode(i){return i.endObject()}static createNode(i,u,l,c,p,d,T,w,v,S,A,C,F,J){return r.startNode(i),r.addName(i,u),r.addDocString(i,l),r.addDomain(i,c),r.addSinceVersion(i,p),r.addIndex(i,d),r.addOpType(i,T),r.addType(i,w),r.addExecutionProviderType(i,v),r.addInputs(i,S),r.addOutputs(i,A),r.addAttributes(i,C),r.addInputArgCounts(i,F),r.addImplicitInputs(i,J),r.endNode(i)}}n.Node=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsValueInfo(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsValueInfo(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}name(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}docString(i){let u=this.bb.__offset(this.bb_pos,6);return u?this.bb.__string(this.bb_pos+u,i):null}type(i){let u=this.bb.__offset(this.bb_pos,8);return u?(i||new t.experimental.fbs.TypeInfo).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}static startValueInfo(i){i.startObject(3)}static addName(i,u){i.addFieldOffset(0,u,0)}static addDocString(i,u){i.addFieldOffset(1,u,0)}static addType(i,u){i.addFieldOffset(2,u,0)}static endValueInfo(i){return i.endObject()}static createValueInfo(i,u,l,c){return r.startValueInfo(i),r.addName(i,u),r.addDocString(i,l),r.addType(i,c),r.endValueInfo(i)}}n.ValueInfo=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsTypeInfo(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsTypeInfo(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}denotation(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}valueType(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.readUint8(this.bb_pos+i):0}value(i){let u=this.bb.__offset(this.bb_pos,8);return u?this.bb.__union(i,this.bb_pos+u):null}static startTypeInfo(i){i.startObject(3)}static addDenotation(i,u){i.addFieldOffset(0,u,0)}static addValueType(i,u){i.addFieldInt8(1,u,0)}static addValue(i,u){i.addFieldOffset(2,u,0)}static endTypeInfo(i){return i.endObject()}static createTypeInfo(i,u,l,c){return r.startTypeInfo(i),r.addDenotation(i,u),r.addValueType(i,l),r.addValue(i,c),r.endTypeInfo(i)}}n.TypeInfo=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsOperatorSetId(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsOperatorSetId(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}domain(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}version(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.readInt64(this.bb_pos+i):this.bb.createLong(0,0)}static startOperatorSetId(i){i.startObject(2)}static addDomain(i,u){i.addFieldOffset(0,u,0)}static addVersion(i,u){i.addFieldInt64(1,u,i.createLong(0,0))}static endOperatorSetId(i){return i.endObject()}static createOperatorSetId(i,u,l){return r.startOperatorSetId(i),r.addDomain(i,u),r.addVersion(i,l),r.endOperatorSetId(i)}}n.OperatorSetId=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsTensor(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsTensor(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}name(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}docString(i){let u=this.bb.__offset(this.bb_pos,6);return u?this.bb.__string(this.bb_pos+u,i):null}dims(i){let u=this.bb.__offset(this.bb_pos,8);return u?this.bb.readInt64(this.bb.__vector(this.bb_pos+u)+i*8):this.bb.createLong(0,0)}dimsLength(){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.__vector_len(this.bb_pos+i):0}dataType(){let i=this.bb.__offset(this.bb_pos,10);return i?this.bb.readInt32(this.bb_pos+i):0}rawData(i){let u=this.bb.__offset(this.bb_pos,12);return u?this.bb.readUint8(this.bb.__vector(this.bb_pos+u)+i):0}rawDataLength(){let i=this.bb.__offset(this.bb_pos,12);return i?this.bb.__vector_len(this.bb_pos+i):0}rawDataArray(){let i=this.bb.__offset(this.bb_pos,12);return i?new Uint8Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+i),this.bb.__vector_len(this.bb_pos+i)):null}stringData(i,u){let l=this.bb.__offset(this.bb_pos,14);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}stringDataLength(){let i=this.bb.__offset(this.bb_pos,14);return i?this.bb.__vector_len(this.bb_pos+i):0}static startTensor(i){i.startObject(6)}static addName(i,u){i.addFieldOffset(0,u,0)}static addDocString(i,u){i.addFieldOffset(1,u,0)}static addDims(i,u){i.addFieldOffset(2,u,0)}static createDimsVector(i,u){i.startVector(8,u.length,8);for(let l=u.length-1;l>=0;l--)i.addInt64(u[l]);return i.endVector()}static startDimsVector(i,u){i.startVector(8,u,8)}static addDataType(i,u){i.addFieldInt32(3,u,0)}static addRawData(i,u){i.addFieldOffset(4,u,0)}static createRawDataVector(i,u){i.startVector(1,u.length,1);for(let l=u.length-1;l>=0;l--)i.addInt8(u[l]);return i.endVector()}static startRawDataVector(i,u){i.startVector(1,u,1)}static addStringData(i,u){i.addFieldOffset(5,u,0)}static createStringDataVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startStringDataVector(i,u){i.startVector(4,u,4)}static endTensor(i){return i.endObject()}static createTensor(i,u,l,c,p,d,T){return r.startTensor(i),r.addName(i,u),r.addDocString(i,l),r.addDims(i,c),r.addDataType(i,p),r.addRawData(i,d),r.addStringData(i,T),r.endTensor(i)}}n.Tensor=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsSparseTensor(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsSparseTensor(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}values(i){let u=this.bb.__offset(this.bb_pos,4);return u?(i||new t.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}indices(i){let u=this.bb.__offset(this.bb_pos,6);return u?(i||new t.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}dims(i){let u=this.bb.__offset(this.bb_pos,8);return u?this.bb.readInt64(this.bb.__vector(this.bb_pos+u)+i*8):this.bb.createLong(0,0)}dimsLength(){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.__vector_len(this.bb_pos+i):0}static startSparseTensor(i){i.startObject(3)}static addValues(i,u){i.addFieldOffset(0,u,0)}static addIndices(i,u){i.addFieldOffset(1,u,0)}static addDims(i,u){i.addFieldOffset(2,u,0)}static createDimsVector(i,u){i.startVector(8,u.length,8);for(let l=u.length-1;l>=0;l--)i.addInt64(u[l]);return i.endVector()}static startDimsVector(i,u){i.startVector(8,u,8)}static endSparseTensor(i){return i.endObject()}static createSparseTensor(i,u,l,c){return r.startSparseTensor(i),r.addValues(i,u),r.addIndices(i,l),r.addDims(i,c),r.endSparseTensor(i)}}n.SparseTensor=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsAttribute(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsAttribute(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}name(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}docString(i){let u=this.bb.__offset(this.bb_pos,6);return u?this.bb.__string(this.bb_pos+u,i):null}type(){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.readInt32(this.bb_pos+i):0}f(){let i=this.bb.__offset(this.bb_pos,10);return i?this.bb.readFloat32(this.bb_pos+i):0}i(){let i=this.bb.__offset(this.bb_pos,12);return i?this.bb.readInt64(this.bb_pos+i):this.bb.createLong(0,0)}s(i){let u=this.bb.__offset(this.bb_pos,14);return u?this.bb.__string(this.bb_pos+u,i):null}t(i){let u=this.bb.__offset(this.bb_pos,16);return u?(i||new t.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}g(i){let u=this.bb.__offset(this.bb_pos,18);return u?(i||new t.experimental.fbs.Graph).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}floats(i){let u=this.bb.__offset(this.bb_pos,20);return u?this.bb.readFloat32(this.bb.__vector(this.bb_pos+u)+i*4):0}floatsLength(){let i=this.bb.__offset(this.bb_pos,20);return i?this.bb.__vector_len(this.bb_pos+i):0}floatsArray(){let i=this.bb.__offset(this.bb_pos,20);return i?new Float32Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+i),this.bb.__vector_len(this.bb_pos+i)):null}ints(i){let u=this.bb.__offset(this.bb_pos,22);return u?this.bb.readInt64(this.bb.__vector(this.bb_pos+u)+i*8):this.bb.createLong(0,0)}intsLength(){let i=this.bb.__offset(this.bb_pos,22);return i?this.bb.__vector_len(this.bb_pos+i):0}strings(i,u){let l=this.bb.__offset(this.bb_pos,24);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}stringsLength(){let i=this.bb.__offset(this.bb_pos,24);return i?this.bb.__vector_len(this.bb_pos+i):0}tensors(i,u){let l=this.bb.__offset(this.bb_pos,26);return l?(u||new t.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}tensorsLength(){let i=this.bb.__offset(this.bb_pos,26);return i?this.bb.__vector_len(this.bb_pos+i):0}graphs(i,u){let l=this.bb.__offset(this.bb_pos,28);return l?(u||new t.experimental.fbs.Graph).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}graphsLength(){let i=this.bb.__offset(this.bb_pos,28);return i?this.bb.__vector_len(this.bb_pos+i):0}static startAttribute(i){i.startObject(13)}static addName(i,u){i.addFieldOffset(0,u,0)}static addDocString(i,u){i.addFieldOffset(1,u,0)}static addType(i,u){i.addFieldInt32(2,u,0)}static addF(i,u){i.addFieldFloat32(3,u,0)}static addI(i,u){i.addFieldInt64(4,u,i.createLong(0,0))}static addS(i,u){i.addFieldOffset(5,u,0)}static addT(i,u){i.addFieldOffset(6,u,0)}static addG(i,u){i.addFieldOffset(7,u,0)}static addFloats(i,u){i.addFieldOffset(8,u,0)}static createFloatsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addFloat32(u[l]);return i.endVector()}static startFloatsVector(i,u){i.startVector(4,u,4)}static addInts(i,u){i.addFieldOffset(9,u,0)}static createIntsVector(i,u){i.startVector(8,u.length,8);for(let l=u.length-1;l>=0;l--)i.addInt64(u[l]);return i.endVector()}static startIntsVector(i,u){i.startVector(8,u,8)}static addStrings(i,u){i.addFieldOffset(10,u,0)}static createStringsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startStringsVector(i,u){i.startVector(4,u,4)}static addTensors(i,u){i.addFieldOffset(11,u,0)}static createTensorsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startTensorsVector(i,u){i.startVector(4,u,4)}static addGraphs(i,u){i.addFieldOffset(12,u,0)}static createGraphsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startGraphsVector(i,u){i.startVector(4,u,4)}static endAttribute(i){return i.endObject()}static createAttribute(i,u,l,c,p,d,T,w,v,S,A,C,F,J){return r.startAttribute(i),r.addName(i,u),r.addDocString(i,l),r.addType(i,c),r.addF(i,p),r.addI(i,d),r.addS(i,T),r.addT(i,w),r.addG(i,v),r.addFloats(i,S),r.addInts(i,A),r.addStrings(i,C),r.addTensors(i,F),r.addGraphs(i,J),r.endAttribute(i)}}n.Attribute=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsGraph(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsGraph(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}initializers(i,u){let l=this.bb.__offset(this.bb_pos,4);return l?(u||new t.experimental.fbs.Tensor).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}initializersLength(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__vector_len(this.bb_pos+i):0}nodeArgs(i,u){let l=this.bb.__offset(this.bb_pos,6);return l?(u||new t.experimental.fbs.ValueInfo).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}nodeArgsLength(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__vector_len(this.bb_pos+i):0}nodes(i,u){let l=this.bb.__offset(this.bb_pos,8);return l?(u||new t.experimental.fbs.Node).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}nodesLength(){let i=this.bb.__offset(this.bb_pos,8);return i?this.bb.__vector_len(this.bb_pos+i):0}maxNodeIndex(){let i=this.bb.__offset(this.bb_pos,10);return i?this.bb.readUint32(this.bb_pos+i):0}nodeEdges(i,u){let l=this.bb.__offset(this.bb_pos,12);return l?(u||new t.experimental.fbs.NodeEdge).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}nodeEdgesLength(){let i=this.bb.__offset(this.bb_pos,12);return i?this.bb.__vector_len(this.bb_pos+i):0}inputs(i,u){let l=this.bb.__offset(this.bb_pos,14);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}inputsLength(){let i=this.bb.__offset(this.bb_pos,14);return i?this.bb.__vector_len(this.bb_pos+i):0}outputs(i,u){let l=this.bb.__offset(this.bb_pos,16);return l?this.bb.__string(this.bb.__vector(this.bb_pos+l)+i*4,u):null}outputsLength(){let i=this.bb.__offset(this.bb_pos,16);return i?this.bb.__vector_len(this.bb_pos+i):0}sparseInitializers(i,u){let l=this.bb.__offset(this.bb_pos,18);return l?(u||new t.experimental.fbs.SparseTensor).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}sparseInitializersLength(){let i=this.bb.__offset(this.bb_pos,18);return i?this.bb.__vector_len(this.bb_pos+i):0}static startGraph(i){i.startObject(8)}static addInitializers(i,u){i.addFieldOffset(0,u,0)}static createInitializersVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startInitializersVector(i,u){i.startVector(4,u,4)}static addNodeArgs(i,u){i.addFieldOffset(1,u,0)}static createNodeArgsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startNodeArgsVector(i,u){i.startVector(4,u,4)}static addNodes(i,u){i.addFieldOffset(2,u,0)}static createNodesVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startNodesVector(i,u){i.startVector(4,u,4)}static addMaxNodeIndex(i,u){i.addFieldInt32(3,u,0)}static addNodeEdges(i,u){i.addFieldOffset(4,u,0)}static createNodeEdgesVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startNodeEdgesVector(i,u){i.startVector(4,u,4)}static addInputs(i,u){i.addFieldOffset(5,u,0)}static createInputsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startInputsVector(i,u){i.startVector(4,u,4)}static addOutputs(i,u){i.addFieldOffset(6,u,0)}static createOutputsVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startOutputsVector(i,u){i.startVector(4,u,4)}static addSparseInitializers(i,u){i.addFieldOffset(7,u,0)}static createSparseInitializersVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startSparseInitializersVector(i,u){i.startVector(4,u,4)}static endGraph(i){return i.endObject()}static createGraph(i,u,l,c,p,d,T,w,v){return r.startGraph(i),r.addInitializers(i,u),r.addNodeArgs(i,l),r.addNodes(i,c),r.addMaxNodeIndex(i,p),r.addNodeEdges(i,d),r.addInputs(i,T),r.addOutputs(i,w),r.addSparseInitializers(i,v),r.endGraph(i)}}n.Graph=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsModel(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsModel(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}irVersion(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.readInt64(this.bb_pos+i):this.bb.createLong(0,0)}opsetImport(i,u){let l=this.bb.__offset(this.bb_pos,6);return l?(u||new t.experimental.fbs.OperatorSetId).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}opsetImportLength(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__vector_len(this.bb_pos+i):0}producerName(i){let u=this.bb.__offset(this.bb_pos,8);return u?this.bb.__string(this.bb_pos+u,i):null}producerVersion(i){let u=this.bb.__offset(this.bb_pos,10);return u?this.bb.__string(this.bb_pos+u,i):null}domain(i){let u=this.bb.__offset(this.bb_pos,12);return u?this.bb.__string(this.bb_pos+u,i):null}modelVersion(){let i=this.bb.__offset(this.bb_pos,14);return i?this.bb.readInt64(this.bb_pos+i):this.bb.createLong(0,0)}docString(i){let u=this.bb.__offset(this.bb_pos,16);return u?this.bb.__string(this.bb_pos+u,i):null}graph(i){let u=this.bb.__offset(this.bb_pos,18);return u?(i||new t.experimental.fbs.Graph).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}graphDocString(i){let u=this.bb.__offset(this.bb_pos,20);return u?this.bb.__string(this.bb_pos+u,i):null}static startModel(i){i.startObject(9)}static addIrVersion(i,u){i.addFieldInt64(0,u,i.createLong(0,0))}static addOpsetImport(i,u){i.addFieldOffset(1,u,0)}static createOpsetImportVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startOpsetImportVector(i,u){i.startVector(4,u,4)}static addProducerName(i,u){i.addFieldOffset(2,u,0)}static addProducerVersion(i,u){i.addFieldOffset(3,u,0)}static addDomain(i,u){i.addFieldOffset(4,u,0)}static addModelVersion(i,u){i.addFieldInt64(5,u,i.createLong(0,0))}static addDocString(i,u){i.addFieldOffset(6,u,0)}static addGraph(i,u){i.addFieldOffset(7,u,0)}static addGraphDocString(i,u){i.addFieldOffset(8,u,0)}static endModel(i){return i.endObject()}static createModel(i,u,l,c,p,d,T,w,v,S){return r.startModel(i),r.addIrVersion(i,u),r.addOpsetImport(i,l),r.addProducerName(i,c),r.addProducerVersion(i,p),r.addDomain(i,d),r.addModelVersion(i,T),r.addDocString(i,w),r.addGraph(i,v),r.addGraphDocString(i,S),r.endModel(i)}}n.Model=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsKernelCreateInfos(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsKernelCreateInfos(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}nodeIndices(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.readUint32(this.bb.__vector(this.bb_pos+u)+i*4):0}nodeIndicesLength(){let i=this.bb.__offset(this.bb_pos,4);return i?this.bb.__vector_len(this.bb_pos+i):0}nodeIndicesArray(){let i=this.bb.__offset(this.bb_pos,4);return i?new Uint32Array(this.bb.bytes().buffer,this.bb.bytes().byteOffset+this.bb.__vector(this.bb_pos+i),this.bb.__vector_len(this.bb_pos+i)):null}kernelDefHashes(i){let u=this.bb.__offset(this.bb_pos,6);return u?this.bb.readUint64(this.bb.__vector(this.bb_pos+u)+i*8):this.bb.createLong(0,0)}kernelDefHashesLength(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__vector_len(this.bb_pos+i):0}static startKernelCreateInfos(i){i.startObject(2)}static addNodeIndices(i,u){i.addFieldOffset(0,u,0)}static createNodeIndicesVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addInt32(u[l]);return i.endVector()}static startNodeIndicesVector(i,u){i.startVector(4,u,4)}static addKernelDefHashes(i,u){i.addFieldOffset(1,u,0)}static createKernelDefHashesVector(i,u){i.startVector(8,u.length,8);for(let l=u.length-1;l>=0;l--)i.addInt64(u[l]);return i.endVector()}static startKernelDefHashesVector(i,u){i.startVector(8,u,8)}static endKernelCreateInfos(i){return i.endObject()}static createKernelCreateInfos(i,u,l){return r.startKernelCreateInfos(i),r.addNodeIndices(i,u),r.addKernelDefHashes(i,l),r.endKernelCreateInfos(i)}}n.KernelCreateInfos=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsSubGraphSessionState(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsSubGraphSessionState(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}graphId(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}sessionState(i){let u=this.bb.__offset(this.bb_pos,6);return u?(i||new t.experimental.fbs.SessionState).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}static startSubGraphSessionState(i){i.startObject(2)}static addGraphId(i,u){i.addFieldOffset(0,u,0)}static addSessionState(i,u){i.addFieldOffset(1,u,0)}static endSubGraphSessionState(i){let u=i.endObject();return i.requiredField(u,4),u}static createSubGraphSessionState(i,u,l){return r.startSubGraphSessionState(i),r.addGraphId(i,u),r.addSessionState(i,l),r.endSubGraphSessionState(i)}}n.SubGraphSessionState=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsSessionState(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsSessionState(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}kernels(i){let u=this.bb.__offset(this.bb_pos,4);return u?(i||new t.experimental.fbs.KernelCreateInfos).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}subGraphSessionStates(i,u){let l=this.bb.__offset(this.bb_pos,6);return l?(u||new t.experimental.fbs.SubGraphSessionState).__init(this.bb.__indirect(this.bb.__vector(this.bb_pos+l)+i*4),this.bb):null}subGraphSessionStatesLength(){let i=this.bb.__offset(this.bb_pos,6);return i?this.bb.__vector_len(this.bb_pos+i):0}static startSessionState(i){i.startObject(2)}static addKernels(i,u){i.addFieldOffset(0,u,0)}static addSubGraphSessionStates(i,u){i.addFieldOffset(1,u,0)}static createSubGraphSessionStatesVector(i,u){i.startVector(4,u.length,4);for(let l=u.length-1;l>=0;l--)i.addOffset(u[l]);return i.endVector()}static startSubGraphSessionStatesVector(i,u){i.startVector(4,u,4)}static endSessionState(i){return i.endObject()}static createSessionState(i,u,l){return r.startSessionState(i),r.addKernels(i,u),r.addSubGraphSessionStates(i,l),r.endSessionState(i)}}n.SessionState=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={});(t=>{let a;(e=>{let o;(n=>{class r{constructor(){this.bb=null;this.bb_pos=0}__init(i,u){return this.bb_pos=i,this.bb=u,this}static getRootAsInferenceSession(i,u){return(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static getSizePrefixedRootAsInferenceSession(i,u){return i.setPosition(i.position()+_.SIZE_PREFIX_LENGTH),(u||new r).__init(i.readInt32(i.position())+i.position(),i)}static bufferHasIdentifier(i){return i.__has_identifier("ORTM")}ortVersion(i){let u=this.bb.__offset(this.bb_pos,4);return u?this.bb.__string(this.bb_pos+u,i):null}model(i){let u=this.bb.__offset(this.bb_pos,6);return u?(i||new t.experimental.fbs.Model).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}sessionState(i){let u=this.bb.__offset(this.bb_pos,8);return u?(i||new t.experimental.fbs.SessionState).__init(this.bb.__indirect(this.bb_pos+u),this.bb):null}static startInferenceSession(i){i.startObject(3)}static addOrtVersion(i,u){i.addFieldOffset(0,u,0)}static addModel(i,u){i.addFieldOffset(1,u,0)}static addSessionState(i,u){i.addFieldOffset(2,u,0)}static endInferenceSession(i){return i.endObject()}static finishInferenceSessionBuffer(i,u){i.finish(u,"ORTM")}static finishSizePrefixedInferenceSessionBuffer(i,u){i.finish(u,"ORTM",!0)}static createInferenceSession(i,u,l,c){return r.startInferenceSession(i),r.addOrtVersion(i,u),r.addModel(i,l),r.addSessionState(i,c),r.endInferenceSession(i)}}n.InferenceSession=r})(o=e.fbs||={})})(a=t.experimental||={})})(V||={})});var Bs=me((vy,ks)=>{"use strict";ks.exports=Bd;function Bd(a,t){for(var o=new Array(arguments.length-1),e=0,r=2,n=!0;r<arguments.length;)o[e++]=arguments[r++];return new Promise(function(i,u){o[e]=function(c){if(n)if(n=!1,c)u(c);else{for(var p=new Array(arguments.length-1),d=0;d<p.length;)p[d++]=arguments[d];i.apply(null,p)}};try{a.apply(t||null,o)}catch(l){n&&(n=!1,u(l))}})}});var Gs=me(Ms=>{"use strict";var Vn=Ms;Vn.length=function(t){var o=t.length;if(!o)return 0;for(var e=0;--o%4>1&&t.charAt(o)==="=";)++e;return Math.ceil(t.length*3)/4-e};var Lr=new Array(64),Rs=new Array(123);for(At=0;At<64;)Rs[Lr[At]=At<26?At+65:At<52?At+71:At<62?At-4:At-59|43]=At++;var At;Vn.encode=function(t,o,e){for(var r=null,n=[],s=0,i=0,u;o<e;){var l=t[o++];switch(i){case 0:n[s++]=Lr[l>>2],u=(l&3)<<4,i=1;break;case 1:n[s++]=Lr[u|l>>4],u=(l&15)<<2,i=2;break;case 2:n[s++]=Lr[u|l>>6],n[s++]=Lr[l&63],i=0;break}s>8191&&((r||(r=[])).push(String.fromCharCode.apply(String,n)),s=0)}return i&&(n[s++]=Lr[u],n[s++]=61,i===1&&(n[s++]=61)),r?(s&&r.push(String.fromCharCode.apply(String,n.slice(0,s))),r.join("")):String.fromCharCode.apply(String,n.slice(0,s))};var Ns="invalid encoding";Vn.decode=function(t,o,e){for(var r=e,n=0,s,i=0;i<t.length;){var u=t.charCodeAt(i++);if(u===61&&n>1)break;if((u=Rs[u])===void 0)throw Error(Ns);switch(n){case 0:s=u,n=1;break;case 1:o[e++]=s<<2|(u&48)>>4,s=u,n=2;break;case 2:o[e++]=(s&15)<<4|(u&60)>>2,s=u,n=3;break;case 3:o[e++]=(s&3)<<6|u,n=0;break}}if(n===1)throw Error(Ns);return e-r};Vn.test=function(t){return/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(t)}});var zs=me((Oy,Us)=>{"use strict";Us.exports=Wn;function Wn(){this._listeners={}}Wn.prototype.on=function(t,o,e){return(this._listeners[t]||(this._listeners[t]=[])).push({fn:o,ctx:e||this}),this};Wn.prototype.off=function(t,o){if(t===void 0)this._listeners={};else if(o===void 0)this._listeners[t]=[];else for(var e=this._listeners[t],r=0;r<e.length;)e[r].fn===o?e.splice(r,1):++r;return this};Wn.prototype.emit=function(t){var o=this._listeners[t];if(o){for(var e=[],r=1;r<arguments.length;)e.push(arguments[r++]);for(r=0;r<o.length;)o[r].fn.apply(o[r++].ctx,e)}return this}});var Xs=me((Iy,Ys)=>{"use strict";Ys.exports=Vs(Vs);function Vs(a){return typeof Float32Array<"u"?function(){var t=new Float32Array([-0]),o=new Uint8Array(t.buffer),e=o[3]===128;function r(u,l,c){t[0]=u,l[c]=o[0],l[c+1]=o[1],l[c+2]=o[2],l[c+3]=o[3]}function n(u,l,c){t[0]=u,l[c]=o[3],l[c+1]=o[2],l[c+2]=o[1],l[c+3]=o[0]}a.writeFloatLE=e?r:n,a.writeFloatBE=e?n:r;function s(u,l){return o[0]=u[l],o[1]=u[l+1],o[2]=u[l+2],o[3]=u[l+3],t[0]}function i(u,l){return o[3]=u[l],o[2]=u[l+1],o[1]=u[l+2],o[0]=u[l+3],t[0]}a.readFloatLE=e?s:i,a.readFloatBE=e?i:s}():function(){function t(e,r,n,s){var i=r<0?1:0;if(i&&(r=-r),r===0)e(1/r>0?0:2147483648,n,s);else if(isNaN(r))e(2143289344,n,s);else if(r>34028234663852886e22)e((i<<31|2139095040)>>>0,n,s);else if(r<11754943508222875e-54)e((i<<31|Math.round(r/1401298464324817e-60))>>>0,n,s);else{var u=Math.floor(Math.log(r)/Math.LN2),l=Math.round(r*Math.pow(2,-u)*8388608)&8388607;e((i<<31|u+127<<23|l)>>>0,n,s)}}a.writeFloatLE=t.bind(null,Ws),a.writeFloatBE=t.bind(null,Hs);function o(e,r,n){var s=e(r,n),i=(s>>31)*2+1,u=s>>>23&255,l=s&8388607;return u===255?l?NaN:i*(1/0):u===0?i*1401298464324817e-60*l:i*Math.pow(2,u-150)*(l+8388608)}a.readFloatLE=o.bind(null,qs),a.readFloatBE=o.bind(null,js)}(),typeof Float64Array<"u"?function(){var t=new Float64Array([-0]),o=new Uint8Array(t.buffer),e=o[7]===128;function r(u,l,c){t[0]=u,l[c]=o[0],l[c+1]=o[1],l[c+2]=o[2],l[c+3]=o[3],l[c+4]=o[4],l[c+5]=o[5],l[c+6]=o[6],l[c+7]=o[7]}function n(u,l,c){t[0]=u,l[c]=o[7],l[c+1]=o[6],l[c+2]=o[5],l[c+3]=o[4],l[c+4]=o[3],l[c+5]=o[2],l[c+6]=o[1],l[c+7]=o[0]}a.writeDoubleLE=e?r:n,a.writeDoubleBE=e?n:r;function s(u,l){return o[0]=u[l],o[1]=u[l+1],o[2]=u[l+2],o[3]=u[l+3],o[4]=u[l+4],o[5]=u[l+5],o[6]=u[l+6],o[7]=u[l+7],t[0]}function i(u,l){return o[7]=u[l],o[6]=u[l+1],o[5]=u[l+2],o[4]=u[l+3],o[3]=u[l+4],o[2]=u[l+5],o[1]=u[l+6],o[0]=u[l+7],t[0]}a.readDoubleLE=e?s:i,a.readDoubleBE=e?i:s}():function(){function t(e,r,n,s,i,u){var l=s<0?1:0;if(l&&(s=-s),s===0)e(0,i,u+r),e(1/s>0?0:2147483648,i,u+n);else if(isNaN(s))e(0,i,u+r),e(2146959360,i,u+n);else if(s>17976931348623157e292)e(0,i,u+r),e((l<<31|2146435072)>>>0,i,u+n);else{var c;if(s<22250738585072014e-324)c=s/5e-324,e(c>>>0,i,u+r),e((l<<31|c/4294967296)>>>0,i,u+n);else{var p=Math.floor(Math.log(s)/Math.LN2);p===1024&&(p=1023),c=s*Math.pow(2,-p),e(c*4503599627370496>>>0,i,u+r),e((l<<31|p+1023<<20|c*1048576&1048575)>>>0,i,u+n)}}}a.writeDoubleLE=t.bind(null,Ws,0,4),a.writeDoubleBE=t.bind(null,Hs,4,0);function o(e,r,n,s,i){var u=e(s,i+r),l=e(s,i+n),c=(l>>31)*2+1,p=l>>>20&2047,d=4294967296*(l&1048575)+u;return p===2047?d?NaN:c*(1/0):p===0?c*5e-324*d:c*Math.pow(2,p-1075)*(d+4503599627370496)}a.readDoubleLE=o.bind(null,qs,0,4),a.readDoubleBE=o.bind(null,js,4,0)}(),a}function Ws(a,t,o){t[o]=a&255,t[o+1]=a>>>8&255,t[o+2]=a>>>16&255,t[o+3]=a>>>24}function Hs(a,t,o){t[o]=a>>>24,t[o+1]=a>>>16&255,t[o+2]=a>>>8&255,t[o+3]=a&255}function qs(a,t){return(a[t]|a[t+1]<<8|a[t+2]<<16|a[t+3]<<24)>>>0}function js(a,t){return(a[t]<<24|a[t+1]<<16|a[t+2]<<8|a[t+3])>>>0}});var Ks=me((exports,module)=>{"use strict";module.exports=inquire;function inquire(moduleName){try{var mod=eval("quire".replace(/^/,"re"))(moduleName);if(mod&&(mod.length||Object.keys(mod).length))return mod}catch(a){}return null}});var Zs=me(Js=>{"use strict";var Qo=Js;Qo.length=function(t){for(var o=0,e=0,r=0;r<t.length;++r)e=t.charCodeAt(r),e<128?o+=1:e<2048?o+=2:(e&64512)===55296&&(t.charCodeAt(r+1)&64512)===56320?(++r,o+=4):o+=3;return o};Qo.read=function(t,o,e){var r=e-o;if(r<1)return"";for(var n=null,s=[],i=0,u;o<e;)u=t[o++],u<128?s[i++]=u:u>191&&u<224?s[i++]=(u&31)<<6|t[o++]&63:u>239&&u<365?(u=((u&7)<<18|(t[o++]&63)<<12|(t[o++]&63)<<6|t[o++]&63)-65536,s[i++]=55296+(u>>10),s[i++]=56320+(u&1023)):s[i++]=(u&15)<<12|(t[o++]&63)<<6|t[o++]&63,i>8191&&((n||(n=[])).push(String.fromCharCode.apply(String,s)),i=0);return n?(i&&n.push(String.fromCharCode.apply(String,s.slice(0,i))),n.join("")):String.fromCharCode.apply(String,s.slice(0,i))};Qo.write=function(t,o,e){for(var r=e,n,s,i=0;i<t.length;++i)n=t.charCodeAt(i),n<128?o[e++]=n:n<2048?(o[e++]=n>>6|192,o[e++]=n&63|128):(n&64512)===55296&&((s=t.charCodeAt(i+1))&64512)===56320?(n=65536+((n&1023)<<10)+(s&1023),++i,o[e++]=n>>18|240,o[e++]=n>>12&63|128,o[e++]=n>>6&63|128,o[e++]=n&63|128):(o[e++]=n>>12|224,o[e++]=n>>6&63|128,o[e++]=n&63|128);return e-r}});var eu=me((Ay,Qs)=>{"use strict";Qs.exports=Nd;function Nd(a,t,o){var e=o||8192,r=e>>>1,n=null,s=e;return function(u){if(u<1||u>r)return a(u);s+u>e&&(n=a(e),s=0);var l=t.call(n,s,s+=u);return s&7&&(s=(s|7)+1),l}}});var ru=me((Py,tu)=>{"use strict";tu.exports=Ge;var rn=Jt();function Ge(a,t){this.lo=a>>>0,this.hi=t>>>0}var pr=Ge.zero=new Ge(0,0);pr.toNumber=function(){return 0};pr.zzEncode=pr.zzDecode=function(){return this};pr.length=function(){return 1};var Rd=Ge.zeroHash="\0\0\0\0\0\0\0\0";Ge.fromNumber=function(t){if(t===0)return pr;var o=t<0;o&&(t=-t);var e=t>>>0,r=(t-e)/4294967296>>>0;return o&&(r=~r>>>0,e=~e>>>0,++e>4294967295&&(e=0,++r>4294967295&&(r=0))),new Ge(e,r)};Ge.from=function(t){if(typeof t=="number")return Ge.fromNumber(t);if(rn.isString(t))if(rn.Long)t=rn.Long.fromString(t);else return Ge.fromNumber(parseInt(t,10));return t.low||t.high?new Ge(t.low>>>0,t.high>>>0):pr};Ge.prototype.toNumber=function(t){if(!t&&this.hi>>>31){var o=~this.lo+1>>>0,e=~this.hi>>>0;return o||(e=e+1>>>0),-(o+e*4294967296)}return this.lo+this.hi*4294967296};Ge.prototype.toLong=function(t){return rn.Long?new rn.Long(this.lo|0,this.hi|0,!!t):{low:this.lo|0,high:this.hi|0,unsigned:!!t}};var Kt=String.prototype.charCodeAt;Ge.fromHash=function(t){return t===Rd?pr:new Ge((Kt.call(t,0)|Kt.call(t,1)<<8|Kt.call(t,2)<<16|Kt.call(t,3)<<24)>>>0,(Kt.call(t,4)|Kt.call(t,5)<<8|Kt.call(t,6)<<16|Kt.call(t,7)<<24)>>>0)};Ge.prototype.toHash=function(){return String.fromCharCode(this.lo&255,this.lo>>>8&255,this.lo>>>16&255,this.lo>>>24,this.hi&255,this.hi>>>8&255,this.hi>>>16&255,this.hi>>>24)};Ge.prototype.zzEncode=function(){var t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this};Ge.prototype.zzDecode=function(){var t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this};Ge.prototype.length=function(){var t=this.lo,o=(this.lo>>>28|this.hi<<4)>>>0,e=this.hi>>>24;return e===0?o===0?t<16384?t<128?1:2:t<2097152?3:4:o<16384?o<128?5:6:o<2097152?7:8:e<128?9:10}});var Jt=me(ei=>{"use strict";var W=ei;W.asPromise=Bs();W.base64=Gs();W.EventEmitter=zs();W.float=Xs();W.inquire=Ks();W.utf8=Zs();W.pool=eu();W.LongBits=ru();W.isNode=!!(typeof global<"u"&&global&&global.process&&global.process.versions&&global.process.versions.node);W.global=W.isNode&&global||typeof window<"u"&&window||typeof self<"u"&&self||ei;W.emptyArray=Object.freeze?Object.freeze([]):[];W.emptyObject=Object.freeze?Object.freeze({}):{};W.isInteger=Number.isInteger||function(t){return typeof t=="number"&&isFinite(t)&&Math.floor(t)===t};W.isString=function(t){return typeof t=="string"||t instanceof String};W.isObject=function(t){return t&&typeof t=="object"};W.isset=W.isSet=function(t,o){var e=t[o];return e!=null&&t.hasOwnProperty(o)?typeof e!="object"||(Array.isArray(e)?e.length:Object.keys(e).length)>0:!1};W.Buffer=function(){try{var a=W.inquire("buffer").Buffer;return a.prototype.utf8Write?a:null}catch{return null}}();W._Buffer_from=null;W._Buffer_allocUnsafe=null;W.newBuffer=function(t){return typeof t=="number"?W.Buffer?W._Buffer_allocUnsafe(t):new W.Array(t):W.Buffer?W._Buffer_from(t):typeof Uint8Array>"u"?t:new Uint8Array(t)};W.Array=typeof Uint8Array<"u"?Uint8Array:Array;W.Long=W.global.dcodeIO&&W.global.dcodeIO.Long||W.global.Long||W.inquire("long");W.key2Re=/^true|false|0|1$/;W.key32Re=/^-?(?:0|[1-9][0-9]*)$/;W.key64Re=/^(?:[\\x00-\\xff]{8}|-?(?:0|[1-9][0-9]*))$/;W.longToHash=function(t){return t?W.LongBits.from(t).toHash():W.LongBits.zeroHash};W.longFromHash=function(t,o){var e=W.LongBits.fromHash(t);return W.Long?W.Long.fromBits(e.lo,e.hi,o):e.toNumber(!!o)};function nu(a,t,o){for(var e=Object.keys(t),r=0;r<e.length;++r)(a[e[r]]===void 0||!o)&&(a[e[r]]=t[e[r]]);return a}W.merge=nu;W.lcFirst=function(t){return t.charAt(0).toLowerCase()+t.substring(1)};function ou(a){function t(o,e){if(!(this instanceof t))return new t(o,e);Object.defineProperty(this,"message",{get:function(){return o}}),Error.captureStackTrace?Error.captureStackTrace(this,t):Object.defineProperty(this,"stack",{value:new Error().stack||""}),e&&nu(this,e)}return t.prototype=Object.create(Error.prototype,{constructor:{value:t,writable:!0,enumerable:!1,configurable:!0},name:{get:function(){return a},set:void 0,enumerable:!1,configurable:!0},toString:{value:function(){return this.name+": "+this.message},writable:!0,enumerable:!1,configurable:!0}}),t}W.newError=ou;W.ProtocolError=ou("ProtocolError");W.oneOfGetter=function(t){for(var o={},e=0;e<t.length;++e)o[t[e]]=1;return function(){for(var r=Object.keys(this),n=r.length-1;n>-1;--n)if(o[r[n]]===1&&this[r[n]]!==void 0&&this[r[n]]!==null)return r[n]}};W.oneOfSetter=function(t){return function(o){for(var e=0;e<t.length;++e)t[e]!==o&&delete this[t[e]]}};W.toJSONOptions={longs:String,enums:String,bytes:String,json:!0};W._configure=function(){var a=W.Buffer;if(!a){W._Buffer_from=W._Buffer_allocUnsafe=null;return}W._Buffer_from=a.from!==Uint8Array.from&&a.from||function(o,e){return new a(o,e)},W._Buffer_allocUnsafe=a.allocUnsafe||function(o){return new a(o)}}});var si=me((Dy,uu)=>{"use strict";uu.exports=se;var pt=Jt(),ti,Hn=pt.LongBits,iu=pt.base64,au=pt.utf8;function nn(a,t,o){this.fn=a,this.len=t,this.next=void 0,this.val=o}function ni(){}function Md(a){this.head=a.head,this.tail=a.tail,this.len=a.len,this.next=a.states}function se(){this.len=0,this.head=new nn(ni,0,0),this.tail=this.head,this.states=null}var su=function(){return pt.Buffer?function(){return(se.create=function(){return new ti})()}:function(){return new se}};se.create=su();se.alloc=function(t){return new pt.Array(t)};pt.Array!==Array&&(se.alloc=pt.pool(se.alloc,pt.Array.prototype.subarray));se.prototype._push=function(t,o,e){return this.tail=this.tail.next=new nn(t,o,e),this.len+=o,this};function oi(a,t,o){t[o]=a&255}function Gd(a,t,o){for(;a>127;)t[o++]=a&127|128,a>>>=7;t[o]=a}function ii(a,t){this.len=a,this.next=void 0,this.val=t}ii.prototype=Object.create(nn.prototype);ii.prototype.fn=Gd;se.prototype.uint32=function(t){return this.len+=(this.tail=this.tail.next=new ii((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this};se.prototype.int32=function(t){return t<0?this._push(ai,10,Hn.fromNumber(t)):this.uint32(t)};se.prototype.sint32=function(t){return this.uint32((t<<1^t>>31)>>>0)};function ai(a,t,o){for(;a.hi;)t[o++]=a.lo&127|128,a.lo=(a.lo>>>7|a.hi<<25)>>>0,a.hi>>>=7;for(;a.lo>127;)t[o++]=a.lo&127|128,a.lo=a.lo>>>7;t[o++]=a.lo}se.prototype.uint64=function(t){var o=Hn.from(t);return this._push(ai,o.length(),o)};se.prototype.int64=se.prototype.uint64;se.prototype.sint64=function(t){var o=Hn.from(t).zzEncode();return this._push(ai,o.length(),o)};se.prototype.bool=function(t){return this._push(oi,1,t?1:0)};function ri(a,t,o){t[o]=a&255,t[o+1]=a>>>8&255,t[o+2]=a>>>16&255,t[o+3]=a>>>24}se.prototype.fixed32=function(t){return this._push(ri,4,t>>>0)};se.prototype.sfixed32=se.prototype.fixed32;se.prototype.fixed64=function(t){var o=Hn.from(t);return this._push(ri,4,o.lo)._push(ri,4,o.hi)};se.prototype.sfixed64=se.prototype.fixed64;se.prototype.float=function(t){return this._push(pt.float.writeFloatLE,4,t)};se.prototype.double=function(t){return this._push(pt.float.writeDoubleLE,8,t)};var Ud=pt.Array.prototype.set?function(t,o,e){o.set(t,e)}:function(t,o,e){for(var r=0;r<t.length;++r)o[e+r]=t[r]};se.prototype.bytes=function(t){var o=t.length>>>0;if(!o)return this._push(oi,1,0);if(pt.isString(t)){var e=se.alloc(o=iu.length(t));iu.decode(t,e,0),t=e}return this.uint32(o)._push(Ud,o,t)};se.prototype.string=function(t){var o=au.length(t);return o?this.uint32(o)._push(au.write,o,t):this._push(oi,1,0)};se.prototype.fork=function(){return this.states=new Md(this),this.head=this.tail=new nn(ni,0,0),this.len=0,this};se.prototype.reset=function(){return this.states?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new nn(ni,0,0),this.len=0),this};se.prototype.ldelim=function(){var t=this.head,o=this.tail,e=this.len;return this.reset().uint32(e),e&&(this.tail.next=t.next,this.tail=o,this.len+=e),this};se.prototype.finish=function(){for(var t=this.head.next,o=this.constructor.alloc(this.len),e=0;t;)t.fn(t.val,o,e),e+=t.len,t=t.next;return o};se._configure=function(a){ti=a,se.create=su(),ti._configure()}});var cu=me((Ly,fu)=>{"use strict";fu.exports=kt;var lu=si();(kt.prototype=Object.create(lu.prototype)).constructor=kt;var Zt=Jt();function kt(){lu.call(this)}kt._configure=function(){kt.alloc=Zt._Buffer_allocUnsafe,kt.writeBytesBuffer=Zt.Buffer&&Zt.Buffer.prototype instanceof Uint8Array&&Zt.Buffer.prototype.set.name==="set"?function(t,o,e){o.set(t,e)}:function(t,o,e){if(t.copy)t.copy(o,e,0,t.length);else for(var r=0;r<t.length;)o[e++]=t[r++]}};kt.prototype.bytes=function(t){Zt.isString(t)&&(t=Zt._Buffer_from(t,"base64"));var o=t.length>>>0;return this.uint32(o),o&&this._push(kt.writeBytesBuffer,o,t),this};function zd(a,t,o){a.length<40?Zt.utf8.write(a,t,o):t.utf8Write?t.utf8Write(a,o):t.write(a,o)}kt.prototype.string=function(t){var o=Zt.Buffer.byteLength(t);return this.uint32(o),o&&this._push(zd,o,t),this};kt._configure()});var fi=me((Cy,bu)=>{"use strict";bu.exports=Ae;var Pt=Jt(),li,hu=Pt.LongBits,Vd=Pt.utf8;function Et(a,t){return RangeError("index out of range: "+a.pos+" + "+(t||1)+" > "+a.len)}function Ae(a){this.buf=a,this.pos=0,this.len=a.length}var pu=typeof Uint8Array<"u"?function(t){if(t instanceof Uint8Array||Array.isArray(t))return new Ae(t);throw Error("illegal buffer")}:function(t){if(Array.isArray(t))return new Ae(t);throw Error("illegal buffer")},mu=function(){return Pt.Buffer?function(o){return(Ae.create=function(r){return Pt.Buffer.isBuffer(r)?new li(r):pu(r)})(o)}:pu};Ae.create=mu();Ae.prototype._slice=Pt.Array.prototype.subarray||Pt.Array.prototype.slice;Ae.prototype.uint32=function(){var t=4294967295;return function(){if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Et(this,10);return t}}();Ae.prototype.int32=function(){return this.uint32()|0};Ae.prototype.sint32=function(){var t=this.uint32();return t>>>1^-(t&1)|0};function ui(){var a=new hu(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(a.lo=(a.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return a;if(a.lo=(a.lo|(this.buf[this.pos]&127)<<28)>>>0,a.hi=(a.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return a;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw Et(this);if(a.lo=(a.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return a}return a.lo=(a.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,a}if(this.len-this.pos>4){for(;t<5;++t)if(a.hi=(a.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return a}else for(;t<5;++t){if(this.pos>=this.len)throw Et(this);if(a.hi=(a.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return a}throw Error("invalid varint encoding")}Ae.prototype.bool=function(){return this.uint32()!==0};function qn(a,t){return(a[t-4]|a[t-3]<<8|a[t-2]<<16|a[t-1]<<24)>>>0}Ae.prototype.fixed32=function(){if(this.pos+4>this.len)throw Et(this,4);return qn(this.buf,this.pos+=4)};Ae.prototype.sfixed32=function(){if(this.pos+4>this.len)throw Et(this,4);return qn(this.buf,this.pos+=4)|0};function du(){if(this.pos+8>this.len)throw Et(this,8);return new hu(qn(this.buf,this.pos+=4),qn(this.buf,this.pos+=4))}Ae.prototype.float=function(){if(this.pos+4>this.len)throw Et(this,4);var t=Pt.float.readFloatLE(this.buf,this.pos);return this.pos+=4,t};Ae.prototype.double=function(){if(this.pos+8>this.len)throw Et(this,4);var t=Pt.float.readDoubleLE(this.buf,this.pos);return this.pos+=8,t};Ae.prototype.bytes=function(){var t=this.uint32(),o=this.pos,e=this.pos+t;if(e>this.len)throw Et(this,t);if(this.pos+=t,Array.isArray(this.buf))return this.buf.slice(o,e);if(o===e){var r=Pt.Buffer;return r?r.alloc(0):new this.buf.constructor(0)}return this._slice.call(this.buf,o,e)};Ae.prototype.string=function(){var t=this.bytes();return Vd.read(t,0,t.length)};Ae.prototype.skip=function(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Et(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Et(this);while(this.buf[this.pos++]&128);return this};Ae.prototype.skipType=function(a){switch(a){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(a=this.uint32()&7)!==4;)this.skipType(a);break;case 5:this.skip(4);break;default:throw Error("invalid wire type "+a+" at offset "+this.pos)}return this};Ae._configure=function(a){li=a,Ae.create=mu(),li._configure();var t=Pt.Long?"toLong":"toNumber";Pt.merge(Ae.prototype,{int64:function(){return ui.call(this)[t](!1)},uint64:function(){return ui.call(this)[t](!0)},sint64:function(){return ui.call(this).zzDecode()[t](!1)},fixed64:function(){return du.call(this)[t](!0)},sfixed64:function(){return du.call(this)[t](!1)}})}});var xu=me((Fy,Tu)=>{"use strict";Tu.exports=dr;var yu=fi();(dr.prototype=Object.create(yu.prototype)).constructor=dr;var gu=Jt();function dr(a){yu.call(this,a)}dr._configure=function(){gu.Buffer&&(dr.prototype._slice=gu.Buffer.prototype.slice)};dr.prototype.string=function(){var t=this.uint32();return this.buf.utf8Slice?this.buf.utf8Slice(this.pos,this.pos=Math.min(this.pos+t,this.len)):this.buf.toString("utf-8",this.pos,this.pos=Math.min(this.pos+t,this.len))};dr._configure()});var vu=me(($y,wu)=>{"use strict";wu.exports=on;var ci=Jt();(on.prototype=Object.create(ci.EventEmitter.prototype)).constructor=on;function on(a,t,o){if(typeof a!="function")throw TypeError("rpcImpl must be a function");ci.EventEmitter.call(this),this.rpcImpl=a,this.requestDelimited=!!t,this.responseDelimited=!!o}on.prototype.rpcCall=function a(t,o,e,r,n){if(!r)throw TypeError("request must be specified");var s=this;if(!n)return ci.asPromise(a,s,t,o,e,r);if(!s.rpcImpl){setTimeout(function(){n(Error("already ended"))},0);return}try{return s.rpcImpl(t,o[s.requestDelimited?"encodeDelimited":"encode"](r).finish(),function(u,l){if(u)return s.emit("error",u,t),n(u);if(l===null){s.end(!0);return}if(!(l instanceof e))try{l=e[s.responseDelimited?"decodeDelimited":"decode"](l)}catch(c){return s.emit("error",c,t),n(c)}return s.emit("data",l,t),n(null,l)})}catch(i){s.emit("error",i,t),setTimeout(function(){n(i)},0);return}};on.prototype.end=function(t){return this.rpcImpl&&(t||this.rpcImpl(null,null,null),this.rpcImpl=null,this.emit("end").off()),this}});var Ou=me(_u=>{"use strict";var Wd=_u;Wd.Service=vu()});var Su=me((By,Iu)=>{"use strict";Iu.exports={}});var Eu=me(Pu=>{"use strict";var ot=Pu;ot.build="minimal";ot.Writer=si();ot.BufferWriter=cu();ot.Reader=fi();ot.BufferReader=xu();ot.util=Jt();ot.rpc=Ou();ot.roots=Su();ot.configure=Au;function Au(){ot.util._configure(),ot.Writer._configure(ot.BufferWriter),ot.Reader._configure(ot.BufferReader)}Au()});var Lu=me((Ry,Du)=>{"use strict";Du.exports=Eu()});var Cr=me((My,Cu)=>{"use strict";var ge=Lu(),N=ge.Reader,Pe=ge.Writer,g=ge.util,h=ge.roots.default||(ge.roots.default={});h.onnx=function(){var a={};return a.Version=function(){var t={},o=Object.create(t);return o[t[0]="_START_VERSION"]=0,o[t[1]="IR_VERSION_2017_10_10"]=1,o[t[2]="IR_VERSION_2017_10_30"]=2,o[t[3]="IR_VERSION_2017_11_3"]=3,o[t[4]="IR_VERSION_2019_1_22"]=4,o[t[5]="IR_VERSION_2019_3_18"]=5,o[t[6]="IR_VERSION_2019_9_19"]=6,o[t[7]="IR_VERSION_2020_5_8"]=7,o[t[8]="IR_VERSION_2021_7_30"]=8,o[t[9]="IR_VERSION"]=9,o}(),a.AttributeProto=function(){function t(o){if(this.floats=[],this.ints=[],this.strings=[],this.tensors=[],this.graphs=[],this.sparseTensors=[],this.typeProtos=[],o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.name="",t.prototype.refAttrName="",t.prototype.docString="",t.prototype.type=0,t.prototype.f=0,t.prototype.i=g.Long?g.Long.fromBits(0,0,!1):0,t.prototype.s=g.newBuffer([]),t.prototype.t=null,t.prototype.g=null,t.prototype.sparseTensor=null,t.prototype.tp=null,t.prototype.floats=g.emptyArray,t.prototype.ints=g.emptyArray,t.prototype.strings=g.emptyArray,t.prototype.tensors=g.emptyArray,t.prototype.graphs=g.emptyArray,t.prototype.sparseTensors=g.emptyArray,t.prototype.typeProtos=g.emptyArray,t.create=function(e){return new t(e)},t.encode=function(e,r){if(r||(r=Pe.create()),e.name!=null&&Object.hasOwnProperty.call(e,"name")&&r.uint32(10).string(e.name),e.f!=null&&Object.hasOwnProperty.call(e,"f")&&r.uint32(21).float(e.f),e.i!=null&&Object.hasOwnProperty.call(e,"i")&&r.uint32(24).int64(e.i),e.s!=null&&Object.hasOwnProperty.call(e,"s")&&r.uint32(34).bytes(e.s),e.t!=null&&Object.hasOwnProperty.call(e,"t")&&h.onnx.TensorProto.encode(e.t,r.uint32(42).fork()).ldelim(),e.g!=null&&Object.hasOwnProperty.call(e,"g")&&h.onnx.GraphProto.encode(e.g,r.uint32(50).fork()).ldelim(),e.floats!=null&&e.floats.length){r.uint32(58).fork();for(var n=0;n<e.floats.length;++n)r.float(e.floats[n]);r.ldelim()}if(e.ints!=null&&e.ints.length){r.uint32(66).fork();for(var n=0;n<e.ints.length;++n)r.int64(e.ints[n]);r.ldelim()}if(e.strings!=null&&e.strings.length)for(var n=0;n<e.strings.length;++n)r.uint32(74).bytes(e.strings[n]);if(e.tensors!=null&&e.tensors.length)for(var n=0;n<e.tensors.length;++n)h.onnx.TensorProto.encode(e.tensors[n],r.uint32(82).fork()).ldelim();if(e.graphs!=null&&e.graphs.length)for(var n=0;n<e.graphs.length;++n)h.onnx.GraphProto.encode(e.graphs[n],r.uint32(90).fork()).ldelim();if(e.docString!=null&&Object.hasOwnProperty.call(e,"docString")&&r.uint32(106).string(e.docString),e.tp!=null&&Object.hasOwnProperty.call(e,"tp")&&h.onnx.TypeProto.encode(e.tp,r.uint32(114).fork()).ldelim(),e.typeProtos!=null&&e.typeProtos.length)for(var n=0;n<e.typeProtos.length;++n)h.onnx.TypeProto.encode(e.typeProtos[n],r.uint32(122).fork()).ldelim();if(e.type!=null&&Object.hasOwnProperty.call(e,"type")&&r.uint32(160).int32(e.type),e.refAttrName!=null&&Object.hasOwnProperty.call(e,"refAttrName")&&r.uint32(170).string(e.refAttrName),e.sparseTensor!=null&&Object.hasOwnProperty.call(e,"sparseTensor")&&h.onnx.SparseTensorProto.encode(e.sparseTensor,r.uint32(178).fork()).ldelim(),e.sparseTensors!=null&&e.sparseTensors.length)for(var n=0;n<e.sparseTensors.length;++n)h.onnx.SparseTensorProto.encode(e.sparseTensors[n],r.uint32(186).fork()).ldelim();return r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.AttributeProto;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{s.name=e.string();break}case 21:{s.refAttrName=e.string();break}case 13:{s.docString=e.string();break}case 20:{s.type=e.int32();break}case 2:{s.f=e.float();break}case 3:{s.i=e.int64();break}case 4:{s.s=e.bytes();break}case 5:{s.t=h.onnx.TensorProto.decode(e,e.uint32());break}case 6:{s.g=h.onnx.GraphProto.decode(e,e.uint32());break}case 22:{s.sparseTensor=h.onnx.SparseTensorProto.decode(e,e.uint32());break}case 14:{s.tp=h.onnx.TypeProto.decode(e,e.uint32());break}case 7:{if(s.floats&&s.floats.length||(s.floats=[]),(i&7)===2)for(var u=e.uint32()+e.pos;e.pos<u;)s.floats.push(e.float());else s.floats.push(e.float());break}case 8:{if(s.ints&&s.ints.length||(s.ints=[]),(i&7)===2)for(var u=e.uint32()+e.pos;e.pos<u;)s.ints.push(e.int64());else s.ints.push(e.int64());break}case 9:{s.strings&&s.strings.length||(s.strings=[]),s.strings.push(e.bytes());break}case 10:{s.tensors&&s.tensors.length||(s.tensors=[]),s.tensors.push(h.onnx.TensorProto.decode(e,e.uint32()));break}case 11:{s.graphs&&s.graphs.length||(s.graphs=[]),s.graphs.push(h.onnx.GraphProto.decode(e,e.uint32()));break}case 23:{s.sparseTensors&&s.sparseTensors.length||(s.sparseTensors=[]),s.sparseTensors.push(h.onnx.SparseTensorProto.decode(e,e.uint32()));break}case 15:{s.typeProtos&&s.typeProtos.length||(s.typeProtos=[]),s.typeProtos.push(h.onnx.TypeProto.decode(e,e.uint32()));break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.name!=null&&e.hasOwnProperty("name")&&!g.isString(e.name))return"name: string expected";if(e.refAttrName!=null&&e.hasOwnProperty("refAttrName")&&!g.isString(e.refAttrName))return"refAttrName: string expected";if(e.docString!=null&&e.hasOwnProperty("docString")&&!g.isString(e.docString))return"docString: string expected";if(e.type!=null&&e.hasOwnProperty("type"))switch(e.type){default:return"type: enum value expected";case 0:case 1:case 2:case 3:case 4:case 5:case 11:case 13:case 6:case 7:case 8:case 9:case 10:case 12:case 14:break}if(e.f!=null&&e.hasOwnProperty("f")&&typeof e.f!="number")return"f: number expected";if(e.i!=null&&e.hasOwnProperty("i")&&!g.isInteger(e.i)&&!(e.i&&g.isInteger(e.i.low)&&g.isInteger(e.i.high)))return"i: integer|Long expected";if(e.s!=null&&e.hasOwnProperty("s")&&!(e.s&&typeof e.s.length=="number"||g.isString(e.s)))return"s: buffer expected";if(e.t!=null&&e.hasOwnProperty("t")){var r=h.onnx.TensorProto.verify(e.t);if(r)return"t."+r}if(e.g!=null&&e.hasOwnProperty("g")){var r=h.onnx.GraphProto.verify(e.g);if(r)return"g."+r}if(e.sparseTensor!=null&&e.hasOwnProperty("sparseTensor")){var r=h.onnx.SparseTensorProto.verify(e.sparseTensor);if(r)return"sparseTensor."+r}if(e.tp!=null&&e.hasOwnProperty("tp")){var r=h.onnx.TypeProto.verify(e.tp);if(r)return"tp."+r}if(e.floats!=null&&e.hasOwnProperty("floats")){if(!Array.isArray(e.floats))return"floats: array expected";for(var n=0;n<e.floats.length;++n)if(typeof e.floats[n]!="number")return"floats: number[] expected"}if(e.ints!=null&&e.hasOwnProperty("ints")){if(!Array.isArray(e.ints))return"ints: array expected";for(var n=0;n<e.ints.length;++n)if(!g.isInteger(e.ints[n])&&!(e.ints[n]&&g.isInteger(e.ints[n].low)&&g.isInteger(e.ints[n].high)))return"ints: integer|Long[] expected"}if(e.strings!=null&&e.hasOwnProperty("strings")){if(!Array.isArray(e.strings))return"strings: array expected";for(var n=0;n<e.strings.length;++n)if(!(e.strings[n]&&typeof e.strings[n].length=="number"||g.isString(e.strings[n])))return"strings: buffer[] expected"}if(e.tensors!=null&&e.hasOwnProperty("tensors")){if(!Array.isArray(e.tensors))return"tensors: array expected";for(var n=0;n<e.tensors.length;++n){var r=h.onnx.TensorProto.verify(e.tensors[n]);if(r)return"tensors."+r}}if(e.graphs!=null&&e.hasOwnProperty("graphs")){if(!Array.isArray(e.graphs))return"graphs: array expected";for(var n=0;n<e.graphs.length;++n){var r=h.onnx.GraphProto.verify(e.graphs[n]);if(r)return"graphs."+r}}if(e.sparseTensors!=null&&e.hasOwnProperty("sparseTensors")){if(!Array.isArray(e.sparseTensors))return"sparseTensors: array expected";for(var n=0;n<e.sparseTensors.length;++n){var r=h.onnx.SparseTensorProto.verify(e.sparseTensors[n]);if(r)return"sparseTensors."+r}}if(e.typeProtos!=null&&e.hasOwnProperty("typeProtos")){if(!Array.isArray(e.typeProtos))return"typeProtos: array expected";for(var n=0;n<e.typeProtos.length;++n){var r=h.onnx.TypeProto.verify(e.typeProtos[n]);if(r)return"typeProtos."+r}}return null},t.fromObject=function(e){if(e instanceof h.onnx.AttributeProto)return e;var r=new h.onnx.AttributeProto;switch(e.name!=null&&(r.name=String(e.name)),e.refAttrName!=null&&(r.refAttrName=String(e.refAttrName)),e.docString!=null&&(r.docString=String(e.docString)),e.type){default:if(typeof e.type=="number"){r.type=e.type;break}break;case"UNDEFINED":case 0:r.type=0;break;case"FLOAT":case 1:r.type=1;break;case"INT":case 2:r.type=2;break;case"STRING":case 3:r.type=3;break;case"TENSOR":case 4:r.type=4;break;case"GRAPH":case 5:r.type=5;break;case"SPARSE_TENSOR":case 11:r.type=11;break;case"TYPE_PROTO":case 13:r.type=13;break;case"FLOATS":case 6:r.type=6;break;case"INTS":case 7:r.type=7;break;case"STRINGS":case 8:r.type=8;break;case"TENSORS":case 9:r.type=9;break;case"GRAPHS":case 10:r.type=10;break;case"SPARSE_TENSORS":case 12:r.type=12;break;case"TYPE_PROTOS":case 14:r.type=14;break}if(e.f!=null&&(r.f=Number(e.f)),e.i!=null&&(g.Long?(r.i=g.Long.fromValue(e.i)).unsigned=!1:typeof e.i=="string"?r.i=parseInt(e.i,10):typeof e.i=="number"?r.i=e.i:typeof e.i=="object"&&(r.i=new g.LongBits(e.i.low>>>0,e.i.high>>>0).toNumber())),e.s!=null&&(typeof e.s=="string"?g.base64.decode(e.s,r.s=g.newBuffer(g.base64.length(e.s)),0):e.s.length>=0&&(r.s=e.s)),e.t!=null){if(typeof e.t!="object")throw TypeError(".onnx.AttributeProto.t: object expected");r.t=h.onnx.TensorProto.fromObject(e.t)}if(e.g!=null){if(typeof e.g!="object")throw TypeError(".onnx.AttributeProto.g: object expected");r.g=h.onnx.GraphProto.fromObject(e.g)}if(e.sparseTensor!=null){if(typeof e.sparseTensor!="object")throw TypeError(".onnx.AttributeProto.sparseTensor: object expected");r.sparseTensor=h.onnx.SparseTensorProto.fromObject(e.sparseTensor)}if(e.tp!=null){if(typeof e.tp!="object")throw TypeError(".onnx.AttributeProto.tp: object expected");r.tp=h.onnx.TypeProto.fromObject(e.tp)}if(e.floats){if(!Array.isArray(e.floats))throw TypeError(".onnx.AttributeProto.floats: array expected");r.floats=[];for(var n=0;n<e.floats.length;++n)r.floats[n]=Number(e.floats[n])}if(e.ints){if(!Array.isArray(e.ints))throw TypeError(".onnx.AttributeProto.ints: array expected");r.ints=[];for(var n=0;n<e.ints.length;++n)g.Long?(r.ints[n]=g.Long.fromValue(e.ints[n])).unsigned=!1:typeof e.ints[n]=="string"?r.ints[n]=parseInt(e.ints[n],10):typeof e.ints[n]=="number"?r.ints[n]=e.ints[n]:typeof e.ints[n]=="object"&&(r.ints[n]=new g.LongBits(e.ints[n].low>>>0,e.ints[n].high>>>0).toNumber())}if(e.strings){if(!Array.isArray(e.strings))throw TypeError(".onnx.AttributeProto.strings: array expected");r.strings=[];for(var n=0;n<e.strings.length;++n)typeof e.strings[n]=="string"?g.base64.decode(e.strings[n],r.strings[n]=g.newBuffer(g.base64.length(e.strings[n])),0):e.strings[n].length>=0&&(r.strings[n]=e.strings[n])}if(e.tensors){if(!Array.isArray(e.tensors))throw TypeError(".onnx.AttributeProto.tensors: array expected");r.tensors=[];for(var n=0;n<e.tensors.length;++n){if(typeof e.tensors[n]!="object")throw TypeError(".onnx.AttributeProto.tensors: object expected");r.tensors[n]=h.onnx.TensorProto.fromObject(e.tensors[n])}}if(e.graphs){if(!Array.isArray(e.graphs))throw TypeError(".onnx.AttributeProto.graphs: array expected");r.graphs=[];for(var n=0;n<e.graphs.length;++n){if(typeof e.graphs[n]!="object")throw TypeError(".onnx.AttributeProto.graphs: object expected");r.graphs[n]=h.onnx.GraphProto.fromObject(e.graphs[n])}}if(e.sparseTensors){if(!Array.isArray(e.sparseTensors))throw TypeError(".onnx.AttributeProto.sparseTensors: array expected");r.sparseTensors=[];for(var n=0;n<e.sparseTensors.length;++n){if(typeof e.sparseTensors[n]!="object")throw TypeError(".onnx.AttributeProto.sparseTensors: object expected");r.sparseTensors[n]=h.onnx.SparseTensorProto.fromObject(e.sparseTensors[n])}}if(e.typeProtos){if(!Array.isArray(e.typeProtos))throw TypeError(".onnx.AttributeProto.typeProtos: array expected");r.typeProtos=[];for(var n=0;n<e.typeProtos.length;++n){if(typeof e.typeProtos[n]!="object")throw TypeError(".onnx.AttributeProto.typeProtos: object expected");r.typeProtos[n]=h.onnx.TypeProto.fromObject(e.typeProtos[n])}}return r},t.toObject=function(e,r){r||(r={});var n={};if((r.arrays||r.defaults)&&(n.floats=[],n.ints=[],n.strings=[],n.tensors=[],n.graphs=[],n.typeProtos=[],n.sparseTensors=[]),r.defaults){if(n.name="",n.f=0,g.Long){var s=new g.Long(0,0,!1);n.i=r.longs===String?s.toString():r.longs===Number?s.toNumber():s}else n.i=r.longs===String?"0":0;r.bytes===String?n.s="":(n.s=[],r.bytes!==Array&&(n.s=g.newBuffer(n.s))),n.t=null,n.g=null,n.docString="",n.tp=null,n.type=r.enums===String?"UNDEFINED":0,n.refAttrName="",n.sparseTensor=null}if(e.name!=null&&e.hasOwnProperty("name")&&(n.name=e.name),e.f!=null&&e.hasOwnProperty("f")&&(n.f=r.json&&!isFinite(e.f)?String(e.f):e.f),e.i!=null&&e.hasOwnProperty("i")&&(typeof e.i=="number"?n.i=r.longs===String?String(e.i):e.i:n.i=r.longs===String?g.Long.prototype.toString.call(e.i):r.longs===Number?new g.LongBits(e.i.low>>>0,e.i.high>>>0).toNumber():e.i),e.s!=null&&e.hasOwnProperty("s")&&(n.s=r.bytes===String?g.base64.encode(e.s,0,e.s.length):r.bytes===Array?Array.prototype.slice.call(e.s):e.s),e.t!=null&&e.hasOwnProperty("t")&&(n.t=h.onnx.TensorProto.toObject(e.t,r)),e.g!=null&&e.hasOwnProperty("g")&&(n.g=h.onnx.GraphProto.toObject(e.g,r)),e.floats&&e.floats.length){n.floats=[];for(var i=0;i<e.floats.length;++i)n.floats[i]=r.json&&!isFinite(e.floats[i])?String(e.floats[i]):e.floats[i]}if(e.ints&&e.ints.length){n.ints=[];for(var i=0;i<e.ints.length;++i)typeof e.ints[i]=="number"?n.ints[i]=r.longs===String?String(e.ints[i]):e.ints[i]:n.ints[i]=r.longs===String?g.Long.prototype.toString.call(e.ints[i]):r.longs===Number?new g.LongBits(e.ints[i].low>>>0,e.ints[i].high>>>0).toNumber():e.ints[i]}if(e.strings&&e.strings.length){n.strings=[];for(var i=0;i<e.strings.length;++i)n.strings[i]=r.bytes===String?g.base64.encode(e.strings[i],0,e.strings[i].length):r.bytes===Array?Array.prototype.slice.call(e.strings[i]):e.strings[i]}if(e.tensors&&e.tensors.length){n.tensors=[];for(var i=0;i<e.tensors.length;++i)n.tensors[i]=h.onnx.TensorProto.toObject(e.tensors[i],r)}if(e.graphs&&e.graphs.length){n.graphs=[];for(var i=0;i<e.graphs.length;++i)n.graphs[i]=h.onnx.GraphProto.toObject(e.graphs[i],r)}if(e.docString!=null&&e.hasOwnProperty("docString")&&(n.docString=e.docString),e.tp!=null&&e.hasOwnProperty("tp")&&(n.tp=h.onnx.TypeProto.toObject(e.tp,r)),e.typeProtos&&e.typeProtos.length){n.typeProtos=[];for(var i=0;i<e.typeProtos.length;++i)n.typeProtos[i]=h.onnx.TypeProto.toObject(e.typeProtos[i],r)}if(e.type!=null&&e.hasOwnProperty("type")&&(n.type=r.enums===String?h.onnx.AttributeProto.AttributeType[e.type]===void 0?e.type:h.onnx.AttributeProto.AttributeType[e.type]:e.type),e.refAttrName!=null&&e.hasOwnProperty("refAttrName")&&(n.refAttrName=e.refAttrName),e.sparseTensor!=null&&e.hasOwnProperty("sparseTensor")&&(n.sparseTensor=h.onnx.SparseTensorProto.toObject(e.sparseTensor,r)),e.sparseTensors&&e.sparseTensors.length){n.sparseTensors=[];for(var i=0;i<e.sparseTensors.length;++i)n.sparseTensors[i]=h.onnx.SparseTensorProto.toObject(e.sparseTensors[i],r)}return n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.AttributeProto"},t.AttributeType=function(){var o={},e=Object.create(o);return e[o[0]="UNDEFINED"]=0,e[o[1]="FLOAT"]=1,e[o[2]="INT"]=2,e[o[3]="STRING"]=3,e[o[4]="TENSOR"]=4,e[o[5]="GRAPH"]=5,e[o[11]="SPARSE_TENSOR"]=11,e[o[13]="TYPE_PROTO"]=13,e[o[6]="FLOATS"]=6,e[o[7]="INTS"]=7,e[o[8]="STRINGS"]=8,e[o[9]="TENSORS"]=9,e[o[10]="GRAPHS"]=10,e[o[12]="SPARSE_TENSORS"]=12,e[o[14]="TYPE_PROTOS"]=14,e}(),t}(),a.ValueInfoProto=function(){function t(o){if(o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.name="",t.prototype.type=null,t.prototype.docString="",t.create=function(e){return new t(e)},t.encode=function(e,r){return r||(r=Pe.create()),e.name!=null&&Object.hasOwnProperty.call(e,"name")&&r.uint32(10).string(e.name),e.type!=null&&Object.hasOwnProperty.call(e,"type")&&h.onnx.TypeProto.encode(e.type,r.uint32(18).fork()).ldelim(),e.docString!=null&&Object.hasOwnProperty.call(e,"docString")&&r.uint32(26).string(e.docString),r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.ValueInfoProto;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{s.name=e.string();break}case 2:{s.type=h.onnx.TypeProto.decode(e,e.uint32());break}case 3:{s.docString=e.string();break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.name!=null&&e.hasOwnProperty("name")&&!g.isString(e.name))return"name: string expected";if(e.type!=null&&e.hasOwnProperty("type")){var r=h.onnx.TypeProto.verify(e.type);if(r)return"type."+r}return e.docString!=null&&e.hasOwnProperty("docString")&&!g.isString(e.docString)?"docString: string expected":null},t.fromObject=function(e){if(e instanceof h.onnx.ValueInfoProto)return e;var r=new h.onnx.ValueInfoProto;if(e.name!=null&&(r.name=String(e.name)),e.type!=null){if(typeof e.type!="object")throw TypeError(".onnx.ValueInfoProto.type: object expected");r.type=h.onnx.TypeProto.fromObject(e.type)}return e.docString!=null&&(r.docString=String(e.docString)),r},t.toObject=function(e,r){r||(r={});var n={};return r.defaults&&(n.name="",n.type=null,n.docString=""),e.name!=null&&e.hasOwnProperty("name")&&(n.name=e.name),e.type!=null&&e.hasOwnProperty("type")&&(n.type=h.onnx.TypeProto.toObject(e.type,r)),e.docString!=null&&e.hasOwnProperty("docString")&&(n.docString=e.docString),n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.ValueInfoProto"},t}(),a.NodeProto=function(){function t(o){if(this.input=[],this.output=[],this.attribute=[],o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.input=g.emptyArray,t.prototype.output=g.emptyArray,t.prototype.name="",t.prototype.opType="",t.prototype.domain="",t.prototype.attribute=g.emptyArray,t.prototype.docString="",t.create=function(e){return new t(e)},t.encode=function(e,r){if(r||(r=Pe.create()),e.input!=null&&e.input.length)for(var n=0;n<e.input.length;++n)r.uint32(10).string(e.input[n]);if(e.output!=null&&e.output.length)for(var n=0;n<e.output.length;++n)r.uint32(18).string(e.output[n]);if(e.name!=null&&Object.hasOwnProperty.call(e,"name")&&r.uint32(26).string(e.name),e.opType!=null&&Object.hasOwnProperty.call(e,"opType")&&r.uint32(34).string(e.opType),e.attribute!=null&&e.attribute.length)for(var n=0;n<e.attribute.length;++n)h.onnx.AttributeProto.encode(e.attribute[n],r.uint32(42).fork()).ldelim();return e.docString!=null&&Object.hasOwnProperty.call(e,"docString")&&r.uint32(50).string(e.docString),e.domain!=null&&Object.hasOwnProperty.call(e,"domain")&&r.uint32(58).string(e.domain),r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.NodeProto;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{s.input&&s.input.length||(s.input=[]),s.input.push(e.string());break}case 2:{s.output&&s.output.length||(s.output=[]),s.output.push(e.string());break}case 3:{s.name=e.string();break}case 4:{s.opType=e.string();break}case 7:{s.domain=e.string();break}case 5:{s.attribute&&s.attribute.length||(s.attribute=[]),s.attribute.push(h.onnx.AttributeProto.decode(e,e.uint32()));break}case 6:{s.docString=e.string();break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.input!=null&&e.hasOwnProperty("input")){if(!Array.isArray(e.input))return"input: array expected";for(var r=0;r<e.input.length;++r)if(!g.isString(e.input[r]))return"input: string[] expected"}if(e.output!=null&&e.hasOwnProperty("output")){if(!Array.isArray(e.output))return"output: array expected";for(var r=0;r<e.output.length;++r)if(!g.isString(e.output[r]))return"output: string[] expected"}if(e.name!=null&&e.hasOwnProperty("name")&&!g.isString(e.name))return"name: string expected";if(e.opType!=null&&e.hasOwnProperty("opType")&&!g.isString(e.opType))return"opType: string expected";if(e.domain!=null&&e.hasOwnProperty("domain")&&!g.isString(e.domain))return"domain: string expected";if(e.attribute!=null&&e.hasOwnProperty("attribute")){if(!Array.isArray(e.attribute))return"attribute: array expected";for(var r=0;r<e.attribute.length;++r){var n=h.onnx.AttributeProto.verify(e.attribute[r]);if(n)return"attribute."+n}}return e.docString!=null&&e.hasOwnProperty("docString")&&!g.isString(e.docString)?"docString: string expected":null},t.fromObject=function(e){if(e instanceof h.onnx.NodeProto)return e;var r=new h.onnx.NodeProto;if(e.input){if(!Array.isArray(e.input))throw TypeError(".onnx.NodeProto.input: array expected");r.input=[];for(var n=0;n<e.input.length;++n)r.input[n]=String(e.input[n])}if(e.output){if(!Array.isArray(e.output))throw TypeError(".onnx.NodeProto.output: array expected");r.output=[];for(var n=0;n<e.output.length;++n)r.output[n]=String(e.output[n])}if(e.name!=null&&(r.name=String(e.name)),e.opType!=null&&(r.opType=String(e.opType)),e.domain!=null&&(r.domain=String(e.domain)),e.attribute){if(!Array.isArray(e.attribute))throw TypeError(".onnx.NodeProto.attribute: array expected");r.attribute=[];for(var n=0;n<e.attribute.length;++n){if(typeof e.attribute[n]!="object")throw TypeError(".onnx.NodeProto.attribute: object expected");r.attribute[n]=h.onnx.AttributeProto.fromObject(e.attribute[n])}}return e.docString!=null&&(r.docString=String(e.docString)),r},t.toObject=function(e,r){r||(r={});var n={};if((r.arrays||r.defaults)&&(n.input=[],n.output=[],n.attribute=[]),r.defaults&&(n.name="",n.opType="",n.docString="",n.domain=""),e.input&&e.input.length){n.input=[];for(var s=0;s<e.input.length;++s)n.input[s]=e.input[s]}if(e.output&&e.output.length){n.output=[];for(var s=0;s<e.output.length;++s)n.output[s]=e.output[s]}if(e.name!=null&&e.hasOwnProperty("name")&&(n.name=e.name),e.opType!=null&&e.hasOwnProperty("opType")&&(n.opType=e.opType),e.attribute&&e.attribute.length){n.attribute=[];for(var s=0;s<e.attribute.length;++s)n.attribute[s]=h.onnx.AttributeProto.toObject(e.attribute[s],r)}return e.docString!=null&&e.hasOwnProperty("docString")&&(n.docString=e.docString),e.domain!=null&&e.hasOwnProperty("domain")&&(n.domain=e.domain),n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.NodeProto"},t}(),a.TrainingInfoProto=function(){function t(o){if(this.initializationBinding=[],this.updateBinding=[],o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.initialization=null,t.prototype.algorithm=null,t.prototype.initializationBinding=g.emptyArray,t.prototype.updateBinding=g.emptyArray,t.create=function(e){return new t(e)},t.encode=function(e,r){if(r||(r=Pe.create()),e.initialization!=null&&Object.hasOwnProperty.call(e,"initialization")&&h.onnx.GraphProto.encode(e.initialization,r.uint32(10).fork()).ldelim(),e.algorithm!=null&&Object.hasOwnProperty.call(e,"algorithm")&&h.onnx.GraphProto.encode(e.algorithm,r.uint32(18).fork()).ldelim(),e.initializationBinding!=null&&e.initializationBinding.length)for(var n=0;n<e.initializationBinding.length;++n)h.onnx.StringStringEntryProto.encode(e.initializationBinding[n],r.uint32(26).fork()).ldelim();if(e.updateBinding!=null&&e.updateBinding.length)for(var n=0;n<e.updateBinding.length;++n)h.onnx.StringStringEntryProto.encode(e.updateBinding[n],r.uint32(34).fork()).ldelim();return r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.TrainingInfoProto;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{s.initialization=h.onnx.GraphProto.decode(e,e.uint32());break}case 2:{s.algorithm=h.onnx.GraphProto.decode(e,e.uint32());break}case 3:{s.initializationBinding&&s.initializationBinding.length||(s.initializationBinding=[]),s.initializationBinding.push(h.onnx.StringStringEntryProto.decode(e,e.uint32()));break}case 4:{s.updateBinding&&s.updateBinding.length||(s.updateBinding=[]),s.updateBinding.push(h.onnx.StringStringEntryProto.decode(e,e.uint32()));break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.initialization!=null&&e.hasOwnProperty("initialization")){var r=h.onnx.GraphProto.verify(e.initialization);if(r)return"initialization."+r}if(e.algorithm!=null&&e.hasOwnProperty("algorithm")){var r=h.onnx.GraphProto.verify(e.algorithm);if(r)return"algorithm."+r}if(e.initializationBinding!=null&&e.hasOwnProperty("initializationBinding")){if(!Array.isArray(e.initializationBinding))return"initializationBinding: array expected";for(var n=0;n<e.initializationBinding.length;++n){var r=h.onnx.StringStringEntryProto.verify(e.initializationBinding[n]);if(r)return"initializationBinding."+r}}if(e.updateBinding!=null&&e.hasOwnProperty("updateBinding")){if(!Array.isArray(e.updateBinding))return"updateBinding: array expected";for(var n=0;n<e.updateBinding.length;++n){var r=h.onnx.StringStringEntryProto.verify(e.updateBinding[n]);if(r)return"updateBinding."+r}}return null},t.fromObject=function(e){if(e instanceof h.onnx.TrainingInfoProto)return e;var r=new h.onnx.TrainingInfoProto;if(e.initialization!=null){if(typeof e.initialization!="object")throw TypeError(".onnx.TrainingInfoProto.initialization: object expected");r.initialization=h.onnx.GraphProto.fromObject(e.initialization)}if(e.algorithm!=null){if(typeof e.algorithm!="object")throw TypeError(".onnx.TrainingInfoProto.algorithm: object expected");r.algorithm=h.onnx.GraphProto.fromObject(e.algorithm)}if(e.initializationBinding){if(!Array.isArray(e.initializationBinding))throw TypeError(".onnx.TrainingInfoProto.initializationBinding: array expected");r.initializationBinding=[];for(var n=0;n<e.initializationBinding.length;++n){if(typeof e.initializationBinding[n]!="object")throw TypeError(".onnx.TrainingInfoProto.initializationBinding: object expected");r.initializationBinding[n]=h.onnx.StringStringEntryProto.fromObject(e.initializationBinding[n])}}if(e.updateBinding){if(!Array.isArray(e.updateBinding))throw TypeError(".onnx.TrainingInfoProto.updateBinding: array expected");r.updateBinding=[];for(var n=0;n<e.updateBinding.length;++n){if(typeof e.updateBinding[n]!="object")throw TypeError(".onnx.TrainingInfoProto.updateBinding: object expected");r.updateBinding[n]=h.onnx.StringStringEntryProto.fromObject(e.updateBinding[n])}}return r},t.toObject=function(e,r){r||(r={});var n={};if((r.arrays||r.defaults)&&(n.initializationBinding=[],n.updateBinding=[]),r.defaults&&(n.initialization=null,n.algorithm=null),e.initialization!=null&&e.hasOwnProperty("initialization")&&(n.initialization=h.onnx.GraphProto.toObject(e.initialization,r)),e.algorithm!=null&&e.hasOwnProperty("algorithm")&&(n.algorithm=h.onnx.GraphProto.toObject(e.algorithm,r)),e.initializationBinding&&e.initializationBinding.length){n.initializationBinding=[];for(var s=0;s<e.initializationBinding.length;++s)n.initializationBinding[s]=h.onnx.StringStringEntryProto.toObject(e.initializationBinding[s],r)}if(e.updateBinding&&e.updateBinding.length){n.updateBinding=[];for(var s=0;s<e.updateBinding.length;++s)n.updateBinding[s]=h.onnx.StringStringEntryProto.toObject(e.updateBinding[s],r)}return n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.TrainingInfoProto"},t}(),a.ModelProto=function(){function t(o){if(this.opsetImport=[],this.metadataProps=[],this.trainingInfo=[],this.functions=[],o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.irVersion=g.Long?g.Long.fromBits(0,0,!1):0,t.prototype.opsetImport=g.emptyArray,t.prototype.producerName="",t.prototype.producerVersion="",t.prototype.domain="",t.prototype.modelVersion=g.Long?g.Long.fromBits(0,0,!1):0,t.prototype.docString="",t.prototype.graph=null,t.prototype.metadataProps=g.emptyArray,t.prototype.trainingInfo=g.emptyArray,t.prototype.functions=g.emptyArray,t.create=function(e){return new t(e)},t.encode=function(e,r){if(r||(r=Pe.create()),e.irVersion!=null&&Object.hasOwnProperty.call(e,"irVersion")&&r.uint32(8).int64(e.irVersion),e.producerName!=null&&Object.hasOwnProperty.call(e,"producerName")&&r.uint32(18).string(e.producerName),e.producerVersion!=null&&Object.hasOwnProperty.call(e,"producerVersion")&&r.uint32(26).string(e.producerVersion),e.domain!=null&&Object.hasOwnProperty.call(e,"domain")&&r.uint32(34).string(e.domain),e.modelVersion!=null&&Object.hasOwnProperty.call(e,"modelVersion")&&r.uint32(40).int64(e.modelVersion),e.docString!=null&&Object.hasOwnProperty.call(e,"docString")&&r.uint32(50).string(e.docString),e.graph!=null&&Object.hasOwnProperty.call(e,"graph")&&h.onnx.GraphProto.encode(e.graph,r.uint32(58).fork()).ldelim(),e.opsetImport!=null&&e.opsetImport.length)for(var n=0;n<e.opsetImport.length;++n)h.onnx.OperatorSetIdProto.encode(e.opsetImport[n],r.uint32(66).fork()).ldelim();if(e.metadataProps!=null&&e.metadataProps.length)for(var n=0;n<e.metadataProps.length;++n)h.onnx.StringStringEntryProto.encode(e.metadataProps[n],r.uint32(114).fork()).ldelim();if(e.trainingInfo!=null&&e.trainingInfo.length)for(var n=0;n<e.trainingInfo.length;++n)h.onnx.TrainingInfoProto.encode(e.trainingInfo[n],r.uint32(162).fork()).ldelim();if(e.functions!=null&&e.functions.length)for(var n=0;n<e.functions.length;++n)h.onnx.FunctionProto.encode(e.functions[n],r.uint32(202).fork()).ldelim();return r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.ModelProto;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{s.irVersion=e.int64();break}case 8:{s.opsetImport&&s.opsetImport.length||(s.opsetImport=[]),s.opsetImport.push(h.onnx.OperatorSetIdProto.decode(e,e.uint32()));break}case 2:{s.producerName=e.string();break}case 3:{s.producerVersion=e.string();break}case 4:{s.domain=e.string();break}case 5:{s.modelVersion=e.int64();break}case 6:{s.docString=e.string();break}case 7:{s.graph=h.onnx.GraphProto.decode(e,e.uint32());break}case 14:{s.metadataProps&&s.metadataProps.length||(s.metadataProps=[]),s.metadataProps.push(h.onnx.StringStringEntryProto.decode(e,e.uint32()));break}case 20:{s.trainingInfo&&s.trainingInfo.length||(s.trainingInfo=[]),s.trainingInfo.push(h.onnx.TrainingInfoProto.decode(e,e.uint32()));break}case 25:{s.functions&&s.functions.length||(s.functions=[]),s.functions.push(h.onnx.FunctionProto.decode(e,e.uint32()));break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.irVersion!=null&&e.hasOwnProperty("irVersion")&&!g.isInteger(e.irVersion)&&!(e.irVersion&&g.isInteger(e.irVersion.low)&&g.isInteger(e.irVersion.high)))return"irVersion: integer|Long expected";if(e.opsetImport!=null&&e.hasOwnProperty("opsetImport")){if(!Array.isArray(e.opsetImport))return"opsetImport: array expected";for(var r=0;r<e.opsetImport.length;++r){var n=h.onnx.OperatorSetIdProto.verify(e.opsetImport[r]);if(n)return"opsetImport."+n}}if(e.producerName!=null&&e.hasOwnProperty("producerName")&&!g.isString(e.producerName))return"producerName: string expected";if(e.producerVersion!=null&&e.hasOwnProperty("producerVersion")&&!g.isString(e.producerVersion))return"producerVersion: string expected";if(e.domain!=null&&e.hasOwnProperty("domain")&&!g.isString(e.domain))return"domain: string expected";if(e.modelVersion!=null&&e.hasOwnProperty("modelVersion")&&!g.isInteger(e.modelVersion)&&!(e.modelVersion&&g.isInteger(e.modelVersion.low)&&g.isInteger(e.modelVersion.high)))return"modelVersion: integer|Long expected";if(e.docString!=null&&e.hasOwnProperty("docString")&&!g.isString(e.docString))return"docString: string expected";if(e.graph!=null&&e.hasOwnProperty("graph")){var n=h.onnx.GraphProto.verify(e.graph);if(n)return"graph."+n}if(e.metadataProps!=null&&e.hasOwnProperty("metadataProps")){if(!Array.isArray(e.metadataProps))return"metadataProps: array expected";for(var r=0;r<e.metadataProps.length;++r){var n=h.onnx.StringStringEntryProto.verify(e.metadataProps[r]);if(n)return"metadataProps."+n}}if(e.trainingInfo!=null&&e.hasOwnProperty("trainingInfo")){if(!Array.isArray(e.trainingInfo))return"trainingInfo: array expected";for(var r=0;r<e.trainingInfo.length;++r){var n=h.onnx.TrainingInfoProto.verify(e.trainingInfo[r]);if(n)return"trainingInfo."+n}}if(e.functions!=null&&e.hasOwnProperty("functions")){if(!Array.isArray(e.functions))return"functions: array expected";for(var r=0;r<e.functions.length;++r){var n=h.onnx.FunctionProto.verify(e.functions[r]);if(n)return"functions."+n}}return null},t.fromObject=function(e){if(e instanceof h.onnx.ModelProto)return e;var r=new h.onnx.ModelProto;if(e.irVersion!=null&&(g.Long?(r.irVersion=g.Long.fromValue(e.irVersion)).unsigned=!1:typeof e.irVersion=="string"?r.irVersion=parseInt(e.irVersion,10):typeof e.irVersion=="number"?r.irVersion=e.irVersion:typeof e.irVersion=="object"&&(r.irVersion=new g.LongBits(e.irVersion.low>>>0,e.irVersion.high>>>0).toNumber())),e.opsetImport){if(!Array.isArray(e.opsetImport))throw TypeError(".onnx.ModelProto.opsetImport: array expected");r.opsetImport=[];for(var n=0;n<e.opsetImport.length;++n){if(typeof e.opsetImport[n]!="object")throw TypeError(".onnx.ModelProto.opsetImport: object expected");r.opsetImport[n]=h.onnx.OperatorSetIdProto.fromObject(e.opsetImport[n])}}if(e.producerName!=null&&(r.producerName=String(e.producerName)),e.producerVersion!=null&&(r.producerVersion=String(e.producerVersion)),e.domain!=null&&(r.domain=String(e.domain)),e.modelVersion!=null&&(g.Long?(r.modelVersion=g.Long.fromValue(e.modelVersion)).unsigned=!1:typeof e.modelVersion=="string"?r.modelVersion=parseInt(e.modelVersion,10):typeof e.modelVersion=="number"?r.modelVersion=e.modelVersion:typeof e.modelVersion=="object"&&(r.modelVersion=new g.LongBits(e.modelVersion.low>>>0,e.modelVersion.high>>>0).toNumber())),e.docString!=null&&(r.docString=String(e.docString)),e.graph!=null){if(typeof e.graph!="object")throw TypeError(".onnx.ModelProto.graph: object expected");r.graph=h.onnx.GraphProto.fromObject(e.graph)}if(e.metadataProps){if(!Array.isArray(e.metadataProps))throw TypeError(".onnx.ModelProto.metadataProps: array expected");r.metadataProps=[];for(var n=0;n<e.metadataProps.length;++n){if(typeof e.metadataProps[n]!="object")throw TypeError(".onnx.ModelProto.metadataProps: object expected");r.metadataProps[n]=h.onnx.StringStringEntryProto.fromObject(e.metadataProps[n])}}if(e.trainingInfo){if(!Array.isArray(e.trainingInfo))throw TypeError(".onnx.ModelProto.trainingInfo: array expected");r.trainingInfo=[];for(var n=0;n<e.trainingInfo.length;++n){if(typeof e.trainingInfo[n]!="object")throw TypeError(".onnx.ModelProto.trainingInfo: object expected");r.trainingInfo[n]=h.onnx.TrainingInfoProto.fromObject(e.trainingInfo[n])}}if(e.functions){if(!Array.isArray(e.functions))throw TypeError(".onnx.ModelProto.functions: array expected");r.functions=[];for(var n=0;n<e.functions.length;++n){if(typeof e.functions[n]!="object")throw TypeError(".onnx.ModelProto.functions: object expected");r.functions[n]=h.onnx.FunctionProto.fromObject(e.functions[n])}}return r},t.toObject=function(e,r){r||(r={});var n={};if((r.arrays||r.defaults)&&(n.opsetImport=[],n.metadataProps=[],n.trainingInfo=[],n.functions=[]),r.defaults){if(g.Long){var s=new g.Long(0,0,!1);n.irVersion=r.longs===String?s.toString():r.longs===Number?s.toNumber():s}else n.irVersion=r.longs===String?"0":0;if(n.producerName="",n.producerVersion="",n.domain="",g.Long){var s=new g.Long(0,0,!1);n.modelVersion=r.longs===String?s.toString():r.longs===Number?s.toNumber():s}else n.modelVersion=r.longs===String?"0":0;n.docString="",n.graph=null}if(e.irVersion!=null&&e.hasOwnProperty("irVersion")&&(typeof e.irVersion=="number"?n.irVersion=r.longs===String?String(e.irVersion):e.irVersion:n.irVersion=r.longs===String?g.Long.prototype.toString.call(e.irVersion):r.longs===Number?new g.LongBits(e.irVersion.low>>>0,e.irVersion.high>>>0).toNumber():e.irVersion),e.producerName!=null&&e.hasOwnProperty("producerName")&&(n.producerName=e.producerName),e.producerVersion!=null&&e.hasOwnProperty("producerVersion")&&(n.producerVersion=e.producerVersion),e.domain!=null&&e.hasOwnProperty("domain")&&(n.domain=e.domain),e.modelVersion!=null&&e.hasOwnProperty("modelVersion")&&(typeof e.modelVersion=="number"?n.modelVersion=r.longs===String?String(e.modelVersion):e.modelVersion:n.modelVersion=r.longs===String?g.Long.prototype.toString.call(e.modelVersion):r.longs===Number?new g.LongBits(e.modelVersion.low>>>0,e.modelVersion.high>>>0).toNumber():e.modelVersion),e.docString!=null&&e.hasOwnProperty("docString")&&(n.docString=e.docString),e.graph!=null&&e.hasOwnProperty("graph")&&(n.graph=h.onnx.GraphProto.toObject(e.graph,r)),e.opsetImport&&e.opsetImport.length){n.opsetImport=[];for(var i=0;i<e.opsetImport.length;++i)n.opsetImport[i]=h.onnx.OperatorSetIdProto.toObject(e.opsetImport[i],r)}if(e.metadataProps&&e.metadataProps.length){n.metadataProps=[];for(var i=0;i<e.metadataProps.length;++i)n.metadataProps[i]=h.onnx.StringStringEntryProto.toObject(e.metadataProps[i],r)}if(e.trainingInfo&&e.trainingInfo.length){n.trainingInfo=[];for(var i=0;i<e.trainingInfo.length;++i)n.trainingInfo[i]=h.onnx.TrainingInfoProto.toObject(e.trainingInfo[i],r)}if(e.functions&&e.functions.length){n.functions=[];for(var i=0;i<e.functions.length;++i)n.functions[i]=h.onnx.FunctionProto.toObject(e.functions[i],r)}return n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.ModelProto"},t}(),a.StringStringEntryProto=function(){function t(o){if(o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.key="",t.prototype.value="",t.create=function(e){return new t(e)},t.encode=function(e,r){return r||(r=Pe.create()),e.key!=null&&Object.hasOwnProperty.call(e,"key")&&r.uint32(10).string(e.key),e.value!=null&&Object.hasOwnProperty.call(e,"value")&&r.uint32(18).string(e.value),r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.StringStringEntryProto;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{s.key=e.string();break}case 2:{s.value=e.string();break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){return typeof e!="object"||e===null?"object expected":e.key!=null&&e.hasOwnProperty("key")&&!g.isString(e.key)?"key: string expected":e.value!=null&&e.hasOwnProperty("value")&&!g.isString(e.value)?"value: string expected":null},t.fromObject=function(e){if(e instanceof h.onnx.StringStringEntryProto)return e;var r=new h.onnx.StringStringEntryProto;return e.key!=null&&(r.key=String(e.key)),e.value!=null&&(r.value=String(e.value)),r},t.toObject=function(e,r){r||(r={});var n={};return r.defaults&&(n.key="",n.value=""),e.key!=null&&e.hasOwnProperty("key")&&(n.key=e.key),e.value!=null&&e.hasOwnProperty("value")&&(n.value=e.value),n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.StringStringEntryProto"},t}(),a.TensorAnnotation=function(){function t(o){if(this.quantParameterTensorNames=[],o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.tensorName="",t.prototype.quantParameterTensorNames=g.emptyArray,t.create=function(e){return new t(e)},t.encode=function(e,r){if(r||(r=Pe.create()),e.tensorName!=null&&Object.hasOwnProperty.call(e,"tensorName")&&r.uint32(10).string(e.tensorName),e.quantParameterTensorNames!=null&&e.quantParameterTensorNames.length)for(var n=0;n<e.quantParameterTensorNames.length;++n)h.onnx.StringStringEntryProto.encode(e.quantParameterTensorNames[n],r.uint32(18).fork()).ldelim();return r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.TensorAnnotation;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{s.tensorName=e.string();break}case 2:{s.quantParameterTensorNames&&s.quantParameterTensorNames.length||(s.quantParameterTensorNames=[]),s.quantParameterTensorNames.push(h.onnx.StringStringEntryProto.decode(e,e.uint32()));break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.tensorName!=null&&e.hasOwnProperty("tensorName")&&!g.isString(e.tensorName))return"tensorName: string expected";if(e.quantParameterTensorNames!=null&&e.hasOwnProperty("quantParameterTensorNames")){if(!Array.isArray(e.quantParameterTensorNames))return"quantParameterTensorNames: array expected";for(var r=0;r<e.quantParameterTensorNames.length;++r){var n=h.onnx.StringStringEntryProto.verify(e.quantParameterTensorNames[r]);if(n)return"quantParameterTensorNames."+n}}return null},t.fromObject=function(e){if(e instanceof h.onnx.TensorAnnotation)return e;var r=new h.onnx.TensorAnnotation;if(e.tensorName!=null&&(r.tensorName=String(e.tensorName)),e.quantParameterTensorNames){if(!Array.isArray(e.quantParameterTensorNames))throw TypeError(".onnx.TensorAnnotation.quantParameterTensorNames: array expected");r.quantParameterTensorNames=[];for(var n=0;n<e.quantParameterTensorNames.length;++n){if(typeof e.quantParameterTensorNames[n]!="object")throw TypeError(".onnx.TensorAnnotation.quantParameterTensorNames: object expected");r.quantParameterTensorNames[n]=h.onnx.StringStringEntryProto.fromObject(e.quantParameterTensorNames[n])}}return r},t.toObject=function(e,r){r||(r={});var n={};if((r.arrays||r.defaults)&&(n.quantParameterTensorNames=[]),r.defaults&&(n.tensorName=""),e.tensorName!=null&&e.hasOwnProperty("tensorName")&&(n.tensorName=e.tensorName),e.quantParameterTensorNames&&e.quantParameterTensorNames.length){n.quantParameterTensorNames=[];for(var s=0;s<e.quantParameterTensorNames.length;++s)n.quantParameterTensorNames[s]=h.onnx.StringStringEntryProto.toObject(e.quantParameterTensorNames[s],r)}return n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.TensorAnnotation"},t}(),a.GraphProto=function(){function t(o){if(this.node=[],this.initializer=[],this.sparseInitializer=[],this.input=[],this.output=[],this.valueInfo=[],this.quantizationAnnotation=[],o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.node=g.emptyArray,t.prototype.name="",t.prototype.initializer=g.emptyArray,t.prototype.sparseInitializer=g.emptyArray,t.prototype.docString="",t.prototype.input=g.emptyArray,t.prototype.output=g.emptyArray,t.prototype.valueInfo=g.emptyArray,t.prototype.quantizationAnnotation=g.emptyArray,t.create=function(e){return new t(e)},t.encode=function(e,r){if(r||(r=Pe.create()),e.node!=null&&e.node.length)for(var n=0;n<e.node.length;++n)h.onnx.NodeProto.encode(e.node[n],r.uint32(10).fork()).ldelim();if(e.name!=null&&Object.hasOwnProperty.call(e,"name")&&r.uint32(18).string(e.name),e.initializer!=null&&e.initializer.length)for(var n=0;n<e.initializer.length;++n)h.onnx.TensorProto.encode(e.initializer[n],r.uint32(42).fork()).ldelim();if(e.docString!=null&&Object.hasOwnProperty.call(e,"docString")&&r.uint32(82).string(e.docString),e.input!=null&&e.input.length)for(var n=0;n<e.input.length;++n)h.onnx.ValueInfoProto.encode(e.input[n],r.uint32(90).fork()).ldelim();if(e.output!=null&&e.output.length)for(var n=0;n<e.output.length;++n)h.onnx.ValueInfoProto.encode(e.output[n],r.uint32(98).fork()).ldelim();if(e.valueInfo!=null&&e.valueInfo.length)for(var n=0;n<e.valueInfo.length;++n)h.onnx.ValueInfoProto.encode(e.valueInfo[n],r.uint32(106).fork()).ldelim();if(e.quantizationAnnotation!=null&&e.quantizationAnnotation.length)for(var n=0;n<e.quantizationAnnotation.length;++n)h.onnx.TensorAnnotation.encode(e.quantizationAnnotation[n],r.uint32(114).fork()).ldelim();if(e.sparseInitializer!=null&&e.sparseInitializer.length)for(var n=0;n<e.sparseInitializer.length;++n)h.onnx.SparseTensorProto.encode(e.sparseInitializer[n],r.uint32(122).fork()).ldelim();return r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.GraphProto;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{s.node&&s.node.length||(s.node=[]),s.node.push(h.onnx.NodeProto.decode(e,e.uint32()));break}case 2:{s.name=e.string();break}case 5:{s.initializer&&s.initializer.length||(s.initializer=[]),s.initializer.push(h.onnx.TensorProto.decode(e,e.uint32()));break}case 15:{s.sparseInitializer&&s.sparseInitializer.length||(s.sparseInitializer=[]),s.sparseInitializer.push(h.onnx.SparseTensorProto.decode(e,e.uint32()));break}case 10:{s.docString=e.string();break}case 11:{s.input&&s.input.length||(s.input=[]),s.input.push(h.onnx.ValueInfoProto.decode(e,e.uint32()));break}case 12:{s.output&&s.output.length||(s.output=[]),s.output.push(h.onnx.ValueInfoProto.decode(e,e.uint32()));break}case 13:{s.valueInfo&&s.valueInfo.length||(s.valueInfo=[]),s.valueInfo.push(h.onnx.ValueInfoProto.decode(e,e.uint32()));break}case 14:{s.quantizationAnnotation&&s.quantizationAnnotation.length||(s.quantizationAnnotation=[]),s.quantizationAnnotation.push(h.onnx.TensorAnnotation.decode(e,e.uint32()));break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.node!=null&&e.hasOwnProperty("node")){if(!Array.isArray(e.node))return"node: array expected";for(var r=0;r<e.node.length;++r){var n=h.onnx.NodeProto.verify(e.node[r]);if(n)return"node."+n}}if(e.name!=null&&e.hasOwnProperty("name")&&!g.isString(e.name))return"name: string expected";if(e.initializer!=null&&e.hasOwnProperty("initializer")){if(!Array.isArray(e.initializer))return"initializer: array expected";for(var r=0;r<e.initializer.length;++r){var n=h.onnx.TensorProto.verify(e.initializer[r]);if(n)return"initializer."+n}}if(e.sparseInitializer!=null&&e.hasOwnProperty("sparseInitializer")){if(!Array.isArray(e.sparseInitializer))return"sparseInitializer: array expected";for(var r=0;r<e.sparseInitializer.length;++r){var n=h.onnx.SparseTensorProto.verify(e.sparseInitializer[r]);if(n)return"sparseInitializer."+n}}if(e.docString!=null&&e.hasOwnProperty("docString")&&!g.isString(e.docString))return"docString: string expected";if(e.input!=null&&e.hasOwnProperty("input")){if(!Array.isArray(e.input))return"input: array expected";for(var r=0;r<e.input.length;++r){var n=h.onnx.ValueInfoProto.verify(e.input[r]);if(n)return"input."+n}}if(e.output!=null&&e.hasOwnProperty("output")){if(!Array.isArray(e.output))return"output: array expected";for(var r=0;r<e.output.length;++r){var n=h.onnx.ValueInfoProto.verify(e.output[r]);if(n)return"output."+n}}if(e.valueInfo!=null&&e.hasOwnProperty("valueInfo")){if(!Array.isArray(e.valueInfo))return"valueInfo: array expected";for(var r=0;r<e.valueInfo.length;++r){var n=h.onnx.ValueInfoProto.verify(e.valueInfo[r]);if(n)return"valueInfo."+n}}if(e.quantizationAnnotation!=null&&e.hasOwnProperty("quantizationAnnotation")){if(!Array.isArray(e.quantizationAnnotation))return"quantizationAnnotation: array expected";for(var r=0;r<e.quantizationAnnotation.length;++r){var n=h.onnx.TensorAnnotation.verify(e.quantizationAnnotation[r]);if(n)return"quantizationAnnotation."+n}}return null},t.fromObject=function(e){if(e instanceof h.onnx.GraphProto)return e;var r=new h.onnx.GraphProto;if(e.node){if(!Array.isArray(e.node))throw TypeError(".onnx.GraphProto.node: array expected");r.node=[];for(var n=0;n<e.node.length;++n){if(typeof e.node[n]!="object")throw TypeError(".onnx.GraphProto.node: object expected");r.node[n]=h.onnx.NodeProto.fromObject(e.node[n])}}if(e.name!=null&&(r.name=String(e.name)),e.initializer){if(!Array.isArray(e.initializer))throw TypeError(".onnx.GraphProto.initializer: array expected");r.initializer=[];for(var n=0;n<e.initializer.length;++n){if(typeof e.initializer[n]!="object")throw TypeError(".onnx.GraphProto.initializer: object expected");r.initializer[n]=h.onnx.TensorProto.fromObject(e.initializer[n])}}if(e.sparseInitializer){if(!Array.isArray(e.sparseInitializer))throw TypeError(".onnx.GraphProto.sparseInitializer: array expected");r.sparseInitializer=[];for(var n=0;n<e.sparseInitializer.length;++n){if(typeof e.sparseInitializer[n]!="object")throw TypeError(".onnx.GraphProto.sparseInitializer: object expected");r.sparseInitializer[n]=h.onnx.SparseTensorProto.fromObject(e.sparseInitializer[n])}}if(e.docString!=null&&(r.docString=String(e.docString)),e.input){if(!Array.isArray(e.input))throw TypeError(".onnx.GraphProto.input: array expected");r.input=[];for(var n=0;n<e.input.length;++n){if(typeof e.input[n]!="object")throw TypeError(".onnx.GraphProto.input: object expected");r.input[n]=h.onnx.ValueInfoProto.fromObject(e.input[n])}}if(e.output){if(!Array.isArray(e.output))throw TypeError(".onnx.GraphProto.output: array expected");r.output=[];for(var n=0;n<e.output.length;++n){if(typeof e.output[n]!="object")throw TypeError(".onnx.GraphProto.output: object expected");r.output[n]=h.onnx.ValueInfoProto.fromObject(e.output[n])}}if(e.valueInfo){if(!Array.isArray(e.valueInfo))throw TypeError(".onnx.GraphProto.valueInfo: array expected");r.valueInfo=[];for(var n=0;n<e.valueInfo.length;++n){if(typeof e.valueInfo[n]!="object")throw TypeError(".onnx.GraphProto.valueInfo: object expected");r.valueInfo[n]=h.onnx.ValueInfoProto.fromObject(e.valueInfo[n])}}if(e.quantizationAnnotation){if(!Array.isArray(e.quantizationAnnotation))throw TypeError(".onnx.GraphProto.quantizationAnnotation: array expected");r.quantizationAnnotation=[];for(var n=0;n<e.quantizationAnnotation.length;++n){if(typeof e.quantizationAnnotation[n]!="object")throw TypeError(".onnx.GraphProto.quantizationAnnotation: object expected");r.quantizationAnnotation[n]=h.onnx.TensorAnnotation.fromObject(e.quantizationAnnotation[n])}}return r},t.toObject=function(e,r){r||(r={});var n={};if((r.arrays||r.defaults)&&(n.node=[],n.initializer=[],n.input=[],n.output=[],n.valueInfo=[],n.quantizationAnnotation=[],n.sparseInitializer=[]),r.defaults&&(n.name="",n.docString=""),e.node&&e.node.length){n.node=[];for(var s=0;s<e.node.length;++s)n.node[s]=h.onnx.NodeProto.toObject(e.node[s],r)}if(e.name!=null&&e.hasOwnProperty("name")&&(n.name=e.name),e.initializer&&e.initializer.length){n.initializer=[];for(var s=0;s<e.initializer.length;++s)n.initializer[s]=h.onnx.TensorProto.toObject(e.initializer[s],r)}if(e.docString!=null&&e.hasOwnProperty("docString")&&(n.docString=e.docString),e.input&&e.input.length){n.input=[];for(var s=0;s<e.input.length;++s)n.input[s]=h.onnx.ValueInfoProto.toObject(e.input[s],r)}if(e.output&&e.output.length){n.output=[];for(var s=0;s<e.output.length;++s)n.output[s]=h.onnx.ValueInfoProto.toObject(e.output[s],r)}if(e.valueInfo&&e.valueInfo.length){n.valueInfo=[];for(var s=0;s<e.valueInfo.length;++s)n.valueInfo[s]=h.onnx.ValueInfoProto.toObject(e.valueInfo[s],r)}if(e.quantizationAnnotation&&e.quantizationAnnotation.length){n.quantizationAnnotation=[];for(var s=0;s<e.quantizationAnnotation.length;++s)n.quantizationAnnotation[s]=h.onnx.TensorAnnotation.toObject(e.quantizationAnnotation[s],r)}if(e.sparseInitializer&&e.sparseInitializer.length){n.sparseInitializer=[];for(var s=0;s<e.sparseInitializer.length;++s)n.sparseInitializer[s]=h.onnx.SparseTensorProto.toObject(e.sparseInitializer[s],r)}return n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.GraphProto"},t}(),a.TensorProto=function(){function t(o){if(this.dims=[],this.floatData=[],this.int32Data=[],this.stringData=[],this.int64Data=[],this.externalData=[],this.doubleData=[],this.uint64Data=[],o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.dims=g.emptyArray,t.prototype.dataType=0,t.prototype.segment=null,t.prototype.floatData=g.emptyArray,t.prototype.int32Data=g.emptyArray,t.prototype.stringData=g.emptyArray,t.prototype.int64Data=g.emptyArray,t.prototype.name="",t.prototype.docString="",t.prototype.rawData=g.newBuffer([]),t.prototype.externalData=g.emptyArray,t.prototype.dataLocation=0,t.prototype.doubleData=g.emptyArray,t.prototype.uint64Data=g.emptyArray,t.create=function(e){return new t(e)},t.encode=function(e,r){if(r||(r=Pe.create()),e.dims!=null&&e.dims.length){r.uint32(10).fork();for(var n=0;n<e.dims.length;++n)r.int64(e.dims[n]);r.ldelim()}if(e.dataType!=null&&Object.hasOwnProperty.call(e,"dataType")&&r.uint32(16).int32(e.dataType),e.segment!=null&&Object.hasOwnProperty.call(e,"segment")&&h.onnx.TensorProto.Segment.encode(e.segment,r.uint32(26).fork()).ldelim(),e.floatData!=null&&e.floatData.length){r.uint32(34).fork();for(var n=0;n<e.floatData.length;++n)r.float(e.floatData[n]);r.ldelim()}if(e.int32Data!=null&&e.int32Data.length){r.uint32(42).fork();for(var n=0;n<e.int32Data.length;++n)r.int32(e.int32Data[n]);r.ldelim()}if(e.stringData!=null&&e.stringData.length)for(var n=0;n<e.stringData.length;++n)r.uint32(50).bytes(e.stringData[n]);if(e.int64Data!=null&&e.int64Data.length){r.uint32(58).fork();for(var n=0;n<e.int64Data.length;++n)r.int64(e.int64Data[n]);r.ldelim()}if(e.name!=null&&Object.hasOwnProperty.call(e,"name")&&r.uint32(66).string(e.name),e.rawData!=null&&Object.hasOwnProperty.call(e,"rawData")&&r.uint32(74).bytes(e.rawData),e.doubleData!=null&&e.doubleData.length){r.uint32(82).fork();for(var n=0;n<e.doubleData.length;++n)r.double(e.doubleData[n]);r.ldelim()}if(e.uint64Data!=null&&e.uint64Data.length){r.uint32(90).fork();for(var n=0;n<e.uint64Data.length;++n)r.uint64(e.uint64Data[n]);r.ldelim()}if(e.docString!=null&&Object.hasOwnProperty.call(e,"docString")&&r.uint32(98).string(e.docString),e.externalData!=null&&e.externalData.length)for(var n=0;n<e.externalData.length;++n)h.onnx.StringStringEntryProto.encode(e.externalData[n],r.uint32(106).fork()).ldelim();return e.dataLocation!=null&&Object.hasOwnProperty.call(e,"dataLocation")&&r.uint32(112).int32(e.dataLocation),r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.TensorProto;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{if(s.dims&&s.dims.length||(s.dims=[]),(i&7)===2)for(var u=e.uint32()+e.pos;e.pos<u;)s.dims.push(e.int64());else s.dims.push(e.int64());break}case 2:{s.dataType=e.int32();break}case 3:{s.segment=h.onnx.TensorProto.Segment.decode(e,e.uint32());break}case 4:{if(s.floatData&&s.floatData.length||(s.floatData=[]),(i&7)===2)for(var u=e.uint32()+e.pos;e.pos<u;)s.floatData.push(e.float());else s.floatData.push(e.float());break}case 5:{if(s.int32Data&&s.int32Data.length||(s.int32Data=[]),(i&7)===2)for(var u=e.uint32()+e.pos;e.pos<u;)s.int32Data.push(e.int32());else s.int32Data.push(e.int32());break}case 6:{s.stringData&&s.stringData.length||(s.stringData=[]),s.stringData.push(e.bytes());break}case 7:{if(s.int64Data&&s.int64Data.length||(s.int64Data=[]),(i&7)===2)for(var u=e.uint32()+e.pos;e.pos<u;)s.int64Data.push(e.int64());else s.int64Data.push(e.int64());break}case 8:{s.name=e.string();break}case 12:{s.docString=e.string();break}case 9:{s.rawData=e.bytes();break}case 13:{s.externalData&&s.externalData.length||(s.externalData=[]),s.externalData.push(h.onnx.StringStringEntryProto.decode(e,e.uint32()));break}case 14:{s.dataLocation=e.int32();break}case 10:{if(s.doubleData&&s.doubleData.length||(s.doubleData=[]),(i&7)===2)for(var u=e.uint32()+e.pos;e.pos<u;)s.doubleData.push(e.double());else s.doubleData.push(e.double());break}case 11:{if(s.uint64Data&&s.uint64Data.length||(s.uint64Data=[]),(i&7)===2)for(var u=e.uint32()+e.pos;e.pos<u;)s.uint64Data.push(e.uint64());else s.uint64Data.push(e.uint64());break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.dims!=null&&e.hasOwnProperty("dims")){if(!Array.isArray(e.dims))return"dims: array expected";for(var r=0;r<e.dims.length;++r)if(!g.isInteger(e.dims[r])&&!(e.dims[r]&&g.isInteger(e.dims[r].low)&&g.isInteger(e.dims[r].high)))return"dims: integer|Long[] expected"}if(e.dataType!=null&&e.hasOwnProperty("dataType")&&!g.isInteger(e.dataType))return"dataType: integer expected";if(e.segment!=null&&e.hasOwnProperty("segment")){var n=h.onnx.TensorProto.Segment.verify(e.segment);if(n)return"segment."+n}if(e.floatData!=null&&e.hasOwnProperty("floatData")){if(!Array.isArray(e.floatData))return"floatData: array expected";for(var r=0;r<e.floatData.length;++r)if(typeof e.floatData[r]!="number")return"floatData: number[] expected"}if(e.int32Data!=null&&e.hasOwnProperty("int32Data")){if(!Array.isArray(e.int32Data))return"int32Data: array expected";for(var r=0;r<e.int32Data.length;++r)if(!g.isInteger(e.int32Data[r]))return"int32Data: integer[] expected"}if(e.stringData!=null&&e.hasOwnProperty("stringData")){if(!Array.isArray(e.stringData))return"stringData: array expected";for(var r=0;r<e.stringData.length;++r)if(!(e.stringData[r]&&typeof e.stringData[r].length=="number"||g.isString(e.stringData[r])))return"stringData: buffer[] expected"}if(e.int64Data!=null&&e.hasOwnProperty("int64Data")){if(!Array.isArray(e.int64Data))return"int64Data: array expected";for(var r=0;r<e.int64Data.length;++r)if(!g.isInteger(e.int64Data[r])&&!(e.int64Data[r]&&g.isInteger(e.int64Data[r].low)&&g.isInteger(e.int64Data[r].high)))return"int64Data: integer|Long[] expected"}if(e.name!=null&&e.hasOwnProperty("name")&&!g.isString(e.name))return"name: string expected";if(e.docString!=null&&e.hasOwnProperty("docString")&&!g.isString(e.docString))return"docString: string expected";if(e.rawData!=null&&e.hasOwnProperty("rawData")&&!(e.rawData&&typeof e.rawData.length=="number"||g.isString(e.rawData)))return"rawData: buffer expected";if(e.externalData!=null&&e.hasOwnProperty("externalData")){if(!Array.isArray(e.externalData))return"externalData: array expected";for(var r=0;r<e.externalData.length;++r){var n=h.onnx.StringStringEntryProto.verify(e.externalData[r]);if(n)return"externalData."+n}}if(e.dataLocation!=null&&e.hasOwnProperty("dataLocation"))switch(e.dataLocation){default:return"dataLocation: enum value expected";case 0:case 1:break}if(e.doubleData!=null&&e.hasOwnProperty("doubleData")){if(!Array.isArray(e.doubleData))return"doubleData: array expected";for(var r=0;r<e.doubleData.length;++r)if(typeof e.doubleData[r]!="number")return"doubleData: number[] expected"}if(e.uint64Data!=null&&e.hasOwnProperty("uint64Data")){if(!Array.isArray(e.uint64Data))return"uint64Data: array expected";for(var r=0;r<e.uint64Data.length;++r)if(!g.isInteger(e.uint64Data[r])&&!(e.uint64Data[r]&&g.isInteger(e.uint64Data[r].low)&&g.isInteger(e.uint64Data[r].high)))return"uint64Data: integer|Long[] expected"}return null},t.fromObject=function(e){if(e instanceof h.onnx.TensorProto)return e;var r=new h.onnx.TensorProto;if(e.dims){if(!Array.isArray(e.dims))throw TypeError(".onnx.TensorProto.dims: array expected");r.dims=[];for(var n=0;n<e.dims.length;++n)g.Long?(r.dims[n]=g.Long.fromValue(e.dims[n])).unsigned=!1:typeof e.dims[n]=="string"?r.dims[n]=parseInt(e.dims[n],10):typeof e.dims[n]=="number"?r.dims[n]=e.dims[n]:typeof e.dims[n]=="object"&&(r.dims[n]=new g.LongBits(e.dims[n].low>>>0,e.dims[n].high>>>0).toNumber())}if(e.dataType!=null&&(r.dataType=e.dataType|0),e.segment!=null){if(typeof e.segment!="object")throw TypeError(".onnx.TensorProto.segment: object expected");r.segment=h.onnx.TensorProto.Segment.fromObject(e.segment)}if(e.floatData){if(!Array.isArray(e.floatData))throw TypeError(".onnx.TensorProto.floatData: array expected");r.floatData=[];for(var n=0;n<e.floatData.length;++n)r.floatData[n]=Number(e.floatData[n])}if(e.int32Data){if(!Array.isArray(e.int32Data))throw TypeError(".onnx.TensorProto.int32Data: array expected");r.int32Data=[];for(var n=0;n<e.int32Data.length;++n)r.int32Data[n]=e.int32Data[n]|0}if(e.stringData){if(!Array.isArray(e.stringData))throw TypeError(".onnx.TensorProto.stringData: array expected");r.stringData=[];for(var n=0;n<e.stringData.length;++n)typeof e.stringData[n]=="string"?g.base64.decode(e.stringData[n],r.stringData[n]=g.newBuffer(g.base64.length(e.stringData[n])),0):e.stringData[n].length>=0&&(r.stringData[n]=e.stringData[n])}if(e.int64Data){if(!Array.isArray(e.int64Data))throw TypeError(".onnx.TensorProto.int64Data: array expected");r.int64Data=[];for(var n=0;n<e.int64Data.length;++n)g.Long?(r.int64Data[n]=g.Long.fromValue(e.int64Data[n])).unsigned=!1:typeof e.int64Data[n]=="string"?r.int64Data[n]=parseInt(e.int64Data[n],10):typeof e.int64Data[n]=="number"?r.int64Data[n]=e.int64Data[n]:typeof e.int64Data[n]=="object"&&(r.int64Data[n]=new g.LongBits(e.int64Data[n].low>>>0,e.int64Data[n].high>>>0).toNumber())}if(e.name!=null&&(r.name=String(e.name)),e.docString!=null&&(r.docString=String(e.docString)),e.rawData!=null&&(typeof e.rawData=="string"?g.base64.decode(e.rawData,r.rawData=g.newBuffer(g.base64.length(e.rawData)),0):e.rawData.length>=0&&(r.rawData=e.rawData)),e.externalData){if(!Array.isArray(e.externalData))throw TypeError(".onnx.TensorProto.externalData: array expected");r.externalData=[];for(var n=0;n<e.externalData.length;++n){if(typeof e.externalData[n]!="object")throw TypeError(".onnx.TensorProto.externalData: object expected");r.externalData[n]=h.onnx.StringStringEntryProto.fromObject(e.externalData[n])}}switch(e.dataLocation){default:if(typeof e.dataLocation=="number"){r.dataLocation=e.dataLocation;break}break;case"DEFAULT":case 0:r.dataLocation=0;break;case"EXTERNAL":case 1:r.dataLocation=1;break}if(e.doubleData){if(!Array.isArray(e.doubleData))throw TypeError(".onnx.TensorProto.doubleData: array expected");r.doubleData=[];for(var n=0;n<e.doubleData.length;++n)r.doubleData[n]=Number(e.doubleData[n])}if(e.uint64Data){if(!Array.isArray(e.uint64Data))throw TypeError(".onnx.TensorProto.uint64Data: array expected");r.uint64Data=[];for(var n=0;n<e.uint64Data.length;++n)g.Long?(r.uint64Data[n]=g.Long.fromValue(e.uint64Data[n])).unsigned=!0:typeof e.uint64Data[n]=="string"?r.uint64Data[n]=parseInt(e.uint64Data[n],10):typeof e.uint64Data[n]=="number"?r.uint64Data[n]=e.uint64Data[n]:typeof e.uint64Data[n]=="object"&&(r.uint64Data[n]=new g.LongBits(e.uint64Data[n].low>>>0,e.uint64Data[n].high>>>0).toNumber(!0))}return r},t.toObject=function(e,r){r||(r={});var n={};if((r.arrays||r.defaults)&&(n.dims=[],n.floatData=[],n.int32Data=[],n.stringData=[],n.int64Data=[],n.doubleData=[],n.uint64Data=[],n.externalData=[]),r.defaults&&(n.dataType=0,n.segment=null,n.name="",r.bytes===String?n.rawData="":(n.rawData=[],r.bytes!==Array&&(n.rawData=g.newBuffer(n.rawData))),n.docString="",n.dataLocation=r.enums===String?"DEFAULT":0),e.dims&&e.dims.length){n.dims=[];for(var s=0;s<e.dims.length;++s)typeof e.dims[s]=="number"?n.dims[s]=r.longs===String?String(e.dims[s]):e.dims[s]:n.dims[s]=r.longs===String?g.Long.prototype.toString.call(e.dims[s]):r.longs===Number?new g.LongBits(e.dims[s].low>>>0,e.dims[s].high>>>0).toNumber():e.dims[s]}if(e.dataType!=null&&e.hasOwnProperty("dataType")&&(n.dataType=e.dataType),e.segment!=null&&e.hasOwnProperty("segment")&&(n.segment=h.onnx.TensorProto.Segment.toObject(e.segment,r)),e.floatData&&e.floatData.length){n.floatData=[];for(var s=0;s<e.floatData.length;++s)n.floatData[s]=r.json&&!isFinite(e.floatData[s])?String(e.floatData[s]):e.floatData[s]}if(e.int32Data&&e.int32Data.length){n.int32Data=[];for(var s=0;s<e.int32Data.length;++s)n.int32Data[s]=e.int32Data[s]}if(e.stringData&&e.stringData.length){n.stringData=[];for(var s=0;s<e.stringData.length;++s)n.stringData[s]=r.bytes===String?g.base64.encode(e.stringData[s],0,e.stringData[s].length):r.bytes===Array?Array.prototype.slice.call(e.stringData[s]):e.stringData[s]}if(e.int64Data&&e.int64Data.length){n.int64Data=[];for(var s=0;s<e.int64Data.length;++s)typeof e.int64Data[s]=="number"?n.int64Data[s]=r.longs===String?String(e.int64Data[s]):e.int64Data[s]:n.int64Data[s]=r.longs===String?g.Long.prototype.toString.call(e.int64Data[s]):r.longs===Number?new g.LongBits(e.int64Data[s].low>>>0,e.int64Data[s].high>>>0).toNumber():e.int64Data[s]}if(e.name!=null&&e.hasOwnProperty("name")&&(n.name=e.name),e.rawData!=null&&e.hasOwnProperty("rawData")&&(n.rawData=r.bytes===String?g.base64.encode(e.rawData,0,e.rawData.length):r.bytes===Array?Array.prototype.slice.call(e.rawData):e.rawData),e.doubleData&&e.doubleData.length){n.doubleData=[];for(var s=0;s<e.doubleData.length;++s)n.doubleData[s]=r.json&&!isFinite(e.doubleData[s])?String(e.doubleData[s]):e.doubleData[s]}if(e.uint64Data&&e.uint64Data.length){n.uint64Data=[];for(var s=0;s<e.uint64Data.length;++s)typeof e.uint64Data[s]=="number"?n.uint64Data[s]=r.longs===String?String(e.uint64Data[s]):e.uint64Data[s]:n.uint64Data[s]=r.longs===String?g.Long.prototype.toString.call(e.uint64Data[s]):r.longs===Number?new g.LongBits(e.uint64Data[s].low>>>0,e.uint64Data[s].high>>>0).toNumber(!0):e.uint64Data[s]}if(e.docString!=null&&e.hasOwnProperty("docString")&&(n.docString=e.docString),e.externalData&&e.externalData.length){n.externalData=[];for(var s=0;s<e.externalData.length;++s)n.externalData[s]=h.onnx.StringStringEntryProto.toObject(e.externalData[s],r)}return e.dataLocation!=null&&e.hasOwnProperty("dataLocation")&&(n.dataLocation=r.enums===String?h.onnx.TensorProto.DataLocation[e.dataLocation]===void 0?e.dataLocation:h.onnx.TensorProto.DataLocation[e.dataLocation]:e.dataLocation),n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.TensorProto"},t.DataType=function(){var o={},e=Object.create(o);return e[o[0]="UNDEFINED"]=0,e[o[1]="FLOAT"]=1,e[o[2]="UINT8"]=2,e[o[3]="INT8"]=3,e[o[4]="UINT16"]=4,e[o[5]="INT16"]=5,e[o[6]="INT32"]=6,e[o[7]="INT64"]=7,e[o[8]="STRING"]=8,e[o[9]="BOOL"]=9,e[o[10]="FLOAT16"]=10,e[o[11]="DOUBLE"]=11,e[o[12]="UINT32"]=12,e[o[13]="UINT64"]=13,e[o[14]="COMPLEX64"]=14,e[o[15]="COMPLEX128"]=15,e[o[16]="BFLOAT16"]=16,e[o[17]="FLOAT8E4M3FN"]=17,e[o[18]="FLOAT8E4M3FNUZ"]=18,e[o[19]="FLOAT8E5M2"]=19,e[o[20]="FLOAT8E5M2FNUZ"]=20,e}(),t.Segment=function(){function o(e){if(e)for(var r=Object.keys(e),n=0;n<r.length;++n)e[r[n]]!=null&&(this[r[n]]=e[r[n]])}return o.prototype.begin=g.Long?g.Long.fromBits(0,0,!1):0,o.prototype.end=g.Long?g.Long.fromBits(0,0,!1):0,o.create=function(r){return new o(r)},o.encode=function(r,n){return n||(n=Pe.create()),r.begin!=null&&Object.hasOwnProperty.call(r,"begin")&&n.uint32(8).int64(r.begin),r.end!=null&&Object.hasOwnProperty.call(r,"end")&&n.uint32(16).int64(r.end),n},o.encodeDelimited=function(r,n){return this.encode(r,n).ldelim()},o.decode=function(r,n){r instanceof N||(r=N.create(r));for(var s=n===void 0?r.len:r.pos+n,i=new h.onnx.TensorProto.Segment;r.pos<s;){var u=r.uint32();switch(u>>>3){case 1:{i.begin=r.int64();break}case 2:{i.end=r.int64();break}default:r.skipType(u&7);break}}return i},o.decodeDelimited=function(r){return r instanceof N||(r=new N(r)),this.decode(r,r.uint32())},o.verify=function(r){return typeof r!="object"||r===null?"object expected":r.begin!=null&&r.hasOwnProperty("begin")&&!g.isInteger(r.begin)&&!(r.begin&&g.isInteger(r.begin.low)&&g.isInteger(r.begin.high))?"begin: integer|Long expected":r.end!=null&&r.hasOwnProperty("end")&&!g.isInteger(r.end)&&!(r.end&&g.isInteger(r.end.low)&&g.isInteger(r.end.high))?"end: integer|Long expected":null},o.fromObject=function(r){if(r instanceof h.onnx.TensorProto.Segment)return r;var n=new h.onnx.TensorProto.Segment;return r.begin!=null&&(g.Long?(n.begin=g.Long.fromValue(r.begin)).unsigned=!1:typeof r.begin=="string"?n.begin=parseInt(r.begin,10):typeof r.begin=="number"?n.begin=r.begin:typeof r.begin=="object"&&(n.begin=new g.LongBits(r.begin.low>>>0,r.begin.high>>>0).toNumber())),r.end!=null&&(g.Long?(n.end=g.Long.fromValue(r.end)).unsigned=!1:typeof r.end=="string"?n.end=parseInt(r.end,10):typeof r.end=="number"?n.end=r.end:typeof r.end=="object"&&(n.end=new g.LongBits(r.end.low>>>0,r.end.high>>>0).toNumber())),n},o.toObject=function(r,n){n||(n={});var s={};if(n.defaults){if(g.Long){var i=new g.Long(0,0,!1);s.begin=n.longs===String?i.toString():n.longs===Number?i.toNumber():i}else s.begin=n.longs===String?"0":0;if(g.Long){var i=new g.Long(0,0,!1);s.end=n.longs===String?i.toString():n.longs===Number?i.toNumber():i}else s.end=n.longs===String?"0":0}return r.begin!=null&&r.hasOwnProperty("begin")&&(typeof r.begin=="number"?s.begin=n.longs===String?String(r.begin):r.begin:s.begin=n.longs===String?g.Long.prototype.toString.call(r.begin):n.longs===Number?new g.LongBits(r.begin.low>>>0,r.begin.high>>>0).toNumber():r.begin),r.end!=null&&r.hasOwnProperty("end")&&(typeof r.end=="number"?s.end=n.longs===String?String(r.end):r.end:s.end=n.longs===String?g.Long.prototype.toString.call(r.end):n.longs===Number?new g.LongBits(r.end.low>>>0,r.end.high>>>0).toNumber():r.end),s},o.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},o.getTypeUrl=function(r){return r===void 0&&(r="type.googleapis.com"),r+"/onnx.TensorProto.Segment"},o}(),t.DataLocation=function(){var o={},e=Object.create(o);return e[o[0]="DEFAULT"]=0,e[o[1]="EXTERNAL"]=1,e}(),t}(),a.SparseTensorProto=function(){function t(o){if(this.dims=[],o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.values=null,t.prototype.indices=null,t.prototype.dims=g.emptyArray,t.create=function(e){return new t(e)},t.encode=function(e,r){if(r||(r=Pe.create()),e.values!=null&&Object.hasOwnProperty.call(e,"values")&&h.onnx.TensorProto.encode(e.values,r.uint32(10).fork()).ldelim(),e.indices!=null&&Object.hasOwnProperty.call(e,"indices")&&h.onnx.TensorProto.encode(e.indices,r.uint32(18).fork()).ldelim(),e.dims!=null&&e.dims.length){r.uint32(26).fork();for(var n=0;n<e.dims.length;++n)r.int64(e.dims[n]);r.ldelim()}return r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.SparseTensorProto;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{s.values=h.onnx.TensorProto.decode(e,e.uint32());break}case 2:{s.indices=h.onnx.TensorProto.decode(e,e.uint32());break}case 3:{if(s.dims&&s.dims.length||(s.dims=[]),(i&7)===2)for(var u=e.uint32()+e.pos;e.pos<u;)s.dims.push(e.int64());else s.dims.push(e.int64());break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.values!=null&&e.hasOwnProperty("values")){var r=h.onnx.TensorProto.verify(e.values);if(r)return"values."+r}if(e.indices!=null&&e.hasOwnProperty("indices")){var r=h.onnx.TensorProto.verify(e.indices);if(r)return"indices."+r}if(e.dims!=null&&e.hasOwnProperty("dims")){if(!Array.isArray(e.dims))return"dims: array expected";for(var n=0;n<e.dims.length;++n)if(!g.isInteger(e.dims[n])&&!(e.dims[n]&&g.isInteger(e.dims[n].low)&&g.isInteger(e.dims[n].high)))return"dims: integer|Long[] expected"}return null},t.fromObject=function(e){if(e instanceof h.onnx.SparseTensorProto)return e;var r=new h.onnx.SparseTensorProto;if(e.values!=null){if(typeof e.values!="object")throw TypeError(".onnx.SparseTensorProto.values: object expected");r.values=h.onnx.TensorProto.fromObject(e.values)}if(e.indices!=null){if(typeof e.indices!="object")throw TypeError(".onnx.SparseTensorProto.indices: object expected");r.indices=h.onnx.TensorProto.fromObject(e.indices)}if(e.dims){if(!Array.isArray(e.dims))throw TypeError(".onnx.SparseTensorProto.dims: array expected");r.dims=[];for(var n=0;n<e.dims.length;++n)g.Long?(r.dims[n]=g.Long.fromValue(e.dims[n])).unsigned=!1:typeof e.dims[n]=="string"?r.dims[n]=parseInt(e.dims[n],10):typeof e.dims[n]=="number"?r.dims[n]=e.dims[n]:typeof e.dims[n]=="object"&&(r.dims[n]=new g.LongBits(e.dims[n].low>>>0,e.dims[n].high>>>0).toNumber())}return r},t.toObject=function(e,r){r||(r={});var n={};if((r.arrays||r.defaults)&&(n.dims=[]),r.defaults&&(n.values=null,n.indices=null),e.values!=null&&e.hasOwnProperty("values")&&(n.values=h.onnx.TensorProto.toObject(e.values,r)),e.indices!=null&&e.hasOwnProperty("indices")&&(n.indices=h.onnx.TensorProto.toObject(e.indices,r)),e.dims&&e.dims.length){n.dims=[];for(var s=0;s<e.dims.length;++s)typeof e.dims[s]=="number"?n.dims[s]=r.longs===String?String(e.dims[s]):e.dims[s]:n.dims[s]=r.longs===String?g.Long.prototype.toString.call(e.dims[s]):r.longs===Number?new g.LongBits(e.dims[s].low>>>0,e.dims[s].high>>>0).toNumber():e.dims[s]}return n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.SparseTensorProto"},t}(),a.TensorShapeProto=function(){function t(o){if(this.dim=[],o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.dim=g.emptyArray,t.create=function(e){return new t(e)},t.encode=function(e,r){if(r||(r=Pe.create()),e.dim!=null&&e.dim.length)for(var n=0;n<e.dim.length;++n)h.onnx.TensorShapeProto.Dimension.encode(e.dim[n],r.uint32(10).fork()).ldelim();return r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.TensorShapeProto;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{s.dim&&s.dim.length||(s.dim=[]),s.dim.push(h.onnx.TensorShapeProto.Dimension.decode(e,e.uint32()));break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.dim!=null&&e.hasOwnProperty("dim")){if(!Array.isArray(e.dim))return"dim: array expected";for(var r=0;r<e.dim.length;++r){var n=h.onnx.TensorShapeProto.Dimension.verify(e.dim[r]);if(n)return"dim."+n}}return null},t.fromObject=function(e){if(e instanceof h.onnx.TensorShapeProto)return e;var r=new h.onnx.TensorShapeProto;if(e.dim){if(!Array.isArray(e.dim))throw TypeError(".onnx.TensorShapeProto.dim: array expected");r.dim=[];for(var n=0;n<e.dim.length;++n){if(typeof e.dim[n]!="object")throw TypeError(".onnx.TensorShapeProto.dim: object expected");r.dim[n]=h.onnx.TensorShapeProto.Dimension.fromObject(e.dim[n])}}return r},t.toObject=function(e,r){r||(r={});var n={};if((r.arrays||r.defaults)&&(n.dim=[]),e.dim&&e.dim.length){n.dim=[];for(var s=0;s<e.dim.length;++s)n.dim[s]=h.onnx.TensorShapeProto.Dimension.toObject(e.dim[s],r)}return n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.TensorShapeProto"},t.Dimension=function(){function o(r){if(r)for(var n=Object.keys(r),s=0;s<n.length;++s)r[n[s]]!=null&&(this[n[s]]=r[n[s]])}o.prototype.dimValue=null,o.prototype.dimParam=null,o.prototype.denotation="";var e;return Object.defineProperty(o.prototype,"value",{get:g.oneOfGetter(e=["dimValue","dimParam"]),set:g.oneOfSetter(e)}),o.create=function(n){return new o(n)},o.encode=function(n,s){return s||(s=Pe.create()),n.dimValue!=null&&Object.hasOwnProperty.call(n,"dimValue")&&s.uint32(8).int64(n.dimValue),n.dimParam!=null&&Object.hasOwnProperty.call(n,"dimParam")&&s.uint32(18).string(n.dimParam),n.denotation!=null&&Object.hasOwnProperty.call(n,"denotation")&&s.uint32(26).string(n.denotation),s},o.encodeDelimited=function(n,s){return this.encode(n,s).ldelim()},o.decode=function(n,s){n instanceof N||(n=N.create(n));for(var i=s===void 0?n.len:n.pos+s,u=new h.onnx.TensorShapeProto.Dimension;n.pos<i;){var l=n.uint32();switch(l>>>3){case 1:{u.dimValue=n.int64();break}case 2:{u.dimParam=n.string();break}case 3:{u.denotation=n.string();break}default:n.skipType(l&7);break}}return u},o.decodeDelimited=function(n){return n instanceof N||(n=new N(n)),this.decode(n,n.uint32())},o.verify=function(n){if(typeof n!="object"||n===null)return"object expected";var s={};if(n.dimValue!=null&&n.hasOwnProperty("dimValue")&&(s.value=1,!g.isInteger(n.dimValue)&&!(n.dimValue&&g.isInteger(n.dimValue.low)&&g.isInteger(n.dimValue.high))))return"dimValue: integer|Long expected";if(n.dimParam!=null&&n.hasOwnProperty("dimParam")){if(s.value===1)return"value: multiple values";if(s.value=1,!g.isString(n.dimParam))return"dimParam: string expected"}return n.denotation!=null&&n.hasOwnProperty("denotation")&&!g.isString(n.denotation)?"denotation: string expected":null},o.fromObject=function(n){if(n instanceof h.onnx.TensorShapeProto.Dimension)return n;var s=new h.onnx.TensorShapeProto.Dimension;return n.dimValue!=null&&(g.Long?(s.dimValue=g.Long.fromValue(n.dimValue)).unsigned=!1:typeof n.dimValue=="string"?s.dimValue=parseInt(n.dimValue,10):typeof n.dimValue=="number"?s.dimValue=n.dimValue:typeof n.dimValue=="object"&&(s.dimValue=new g.LongBits(n.dimValue.low>>>0,n.dimValue.high>>>0).toNumber())),n.dimParam!=null&&(s.dimParam=String(n.dimParam)),n.denotation!=null&&(s.denotation=String(n.denotation)),s},o.toObject=function(n,s){s||(s={});var i={};return s.defaults&&(i.denotation=""),n.dimValue!=null&&n.hasOwnProperty("dimValue")&&(typeof n.dimValue=="number"?i.dimValue=s.longs===String?String(n.dimValue):n.dimValue:i.dimValue=s.longs===String?g.Long.prototype.toString.call(n.dimValue):s.longs===Number?new g.LongBits(n.dimValue.low>>>0,n.dimValue.high>>>0).toNumber():n.dimValue,s.oneofs&&(i.value="dimValue")),n.dimParam!=null&&n.hasOwnProperty("dimParam")&&(i.dimParam=n.dimParam,s.oneofs&&(i.value="dimParam")),n.denotation!=null&&n.hasOwnProperty("denotation")&&(i.denotation=n.denotation),i},o.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},o.getTypeUrl=function(n){return n===void 0&&(n="type.googleapis.com"),n+"/onnx.TensorShapeProto.Dimension"},o}(),t}(),a.TypeProto=function(){function t(e){if(e)for(var r=Object.keys(e),n=0;n<r.length;++n)e[r[n]]!=null&&(this[r[n]]=e[r[n]])}t.prototype.tensorType=null,t.prototype.sequenceType=null,t.prototype.mapType=null,t.prototype.optionalType=null,t.prototype.sparseTensorType=null,t.prototype.denotation="";var o;return Object.defineProperty(t.prototype,"value",{get:g.oneOfGetter(o=["tensorType","sequenceType","mapType","optionalType","sparseTensorType"]),set:g.oneOfSetter(o)}),t.create=function(r){return new t(r)},t.encode=function(r,n){return n||(n=Pe.create()),r.tensorType!=null&&Object.hasOwnProperty.call(r,"tensorType")&&h.onnx.TypeProto.Tensor.encode(r.tensorType,n.uint32(10).fork()).ldelim(),r.sequenceType!=null&&Object.hasOwnProperty.call(r,"sequenceType")&&h.onnx.TypeProto.Sequence.encode(r.sequenceType,n.uint32(34).fork()).ldelim(),r.mapType!=null&&Object.hasOwnProperty.call(r,"mapType")&&h.onnx.TypeProto.Map.encode(r.mapType,n.uint32(42).fork()).ldelim(),r.denotation!=null&&Object.hasOwnProperty.call(r,"denotation")&&n.uint32(50).string(r.denotation),r.sparseTensorType!=null&&Object.hasOwnProperty.call(r,"sparseTensorType")&&h.onnx.TypeProto.SparseTensor.encode(r.sparseTensorType,n.uint32(66).fork()).ldelim(),r.optionalType!=null&&Object.hasOwnProperty.call(r,"optionalType")&&h.onnx.TypeProto.Optional.encode(r.optionalType,n.uint32(74).fork()).ldelim(),n},t.encodeDelimited=function(r,n){return this.encode(r,n).ldelim()},t.decode=function(r,n){r instanceof N||(r=N.create(r));for(var s=n===void 0?r.len:r.pos+n,i=new h.onnx.TypeProto;r.pos<s;){var u=r.uint32();switch(u>>>3){case 1:{i.tensorType=h.onnx.TypeProto.Tensor.decode(r,r.uint32());break}case 4:{i.sequenceType=h.onnx.TypeProto.Sequence.decode(r,r.uint32());break}case 5:{i.mapType=h.onnx.TypeProto.Map.decode(r,r.uint32());break}case 9:{i.optionalType=h.onnx.TypeProto.Optional.decode(r,r.uint32());break}case 8:{i.sparseTensorType=h.onnx.TypeProto.SparseTensor.decode(r,r.uint32());break}case 6:{i.denotation=r.string();break}default:r.skipType(u&7);break}}return i},t.decodeDelimited=function(r){return r instanceof N||(r=new N(r)),this.decode(r,r.uint32())},t.verify=function(r){if(typeof r!="object"||r===null)return"object expected";var n={};if(r.tensorType!=null&&r.hasOwnProperty("tensorType")){n.value=1;{var s=h.onnx.TypeProto.Tensor.verify(r.tensorType);if(s)return"tensorType."+s}}if(r.sequenceType!=null&&r.hasOwnProperty("sequenceType")){if(n.value===1)return"value: multiple values";n.value=1;{var s=h.onnx.TypeProto.Sequence.verify(r.sequenceType);if(s)return"sequenceType."+s}}if(r.mapType!=null&&r.hasOwnProperty("mapType")){if(n.value===1)return"value: multiple values";n.value=1;{var s=h.onnx.TypeProto.Map.verify(r.mapType);if(s)return"mapType."+s}}if(r.optionalType!=null&&r.hasOwnProperty("optionalType")){if(n.value===1)return"value: multiple values";n.value=1;{var s=h.onnx.TypeProto.Optional.verify(r.optionalType);if(s)return"optionalType."+s}}if(r.sparseTensorType!=null&&r.hasOwnProperty("sparseTensorType")){if(n.value===1)return"value: multiple values";n.value=1;{var s=h.onnx.TypeProto.SparseTensor.verify(r.sparseTensorType);if(s)return"sparseTensorType."+s}}return r.denotation!=null&&r.hasOwnProperty("denotation")&&!g.isString(r.denotation)?"denotation: string expected":null},t.fromObject=function(r){if(r instanceof h.onnx.TypeProto)return r;var n=new h.onnx.TypeProto;if(r.tensorType!=null){if(typeof r.tensorType!="object")throw TypeError(".onnx.TypeProto.tensorType: object expected");n.tensorType=h.onnx.TypeProto.Tensor.fromObject(r.tensorType)}if(r.sequenceType!=null){if(typeof r.sequenceType!="object")throw TypeError(".onnx.TypeProto.sequenceType: object expected");n.sequenceType=h.onnx.TypeProto.Sequence.fromObject(r.sequenceType)}if(r.mapType!=null){if(typeof r.mapType!="object")throw TypeError(".onnx.TypeProto.mapType: object expected");n.mapType=h.onnx.TypeProto.Map.fromObject(r.mapType)}if(r.optionalType!=null){if(typeof r.optionalType!="object")throw TypeError(".onnx.TypeProto.optionalType: object expected");n.optionalType=h.onnx.TypeProto.Optional.fromObject(r.optionalType)}if(r.sparseTensorType!=null){if(typeof r.sparseTensorType!="object")throw TypeError(".onnx.TypeProto.sparseTensorType: object expected");n.sparseTensorType=h.onnx.TypeProto.SparseTensor.fromObject(r.sparseTensorType)}return r.denotation!=null&&(n.denotation=String(r.denotation)),n},t.toObject=function(r,n){n||(n={});var s={};return n.defaults&&(s.denotation=""),r.tensorType!=null&&r.hasOwnProperty("tensorType")&&(s.tensorType=h.onnx.TypeProto.Tensor.toObject(r.tensorType,n),n.oneofs&&(s.value="tensorType")),r.sequenceType!=null&&r.hasOwnProperty("sequenceType")&&(s.sequenceType=h.onnx.TypeProto.Sequence.toObject(r.sequenceType,n),n.oneofs&&(s.value="sequenceType")),r.mapType!=null&&r.hasOwnProperty("mapType")&&(s.mapType=h.onnx.TypeProto.Map.toObject(r.mapType,n),n.oneofs&&(s.value="mapType")),r.denotation!=null&&r.hasOwnProperty("denotation")&&(s.denotation=r.denotation),r.sparseTensorType!=null&&r.hasOwnProperty("sparseTensorType")&&(s.sparseTensorType=h.onnx.TypeProto.SparseTensor.toObject(r.sparseTensorType,n),n.oneofs&&(s.value="sparseTensorType")),r.optionalType!=null&&r.hasOwnProperty("optionalType")&&(s.optionalType=h.onnx.TypeProto.Optional.toObject(r.optionalType,n),n.oneofs&&(s.value="optionalType")),s},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(r){return r===void 0&&(r="type.googleapis.com"),r+"/onnx.TypeProto"},t.Tensor=function(){function e(r){if(r)for(var n=Object.keys(r),s=0;s<n.length;++s)r[n[s]]!=null&&(this[n[s]]=r[n[s]])}return e.prototype.elemType=0,e.prototype.shape=null,e.create=function(n){return new e(n)},e.encode=function(n,s){return s||(s=Pe.create()),n.elemType!=null&&Object.hasOwnProperty.call(n,"elemType")&&s.uint32(8).int32(n.elemType),n.shape!=null&&Object.hasOwnProperty.call(n,"shape")&&h.onnx.TensorShapeProto.encode(n.shape,s.uint32(18).fork()).ldelim(),s},e.encodeDelimited=function(n,s){return this.encode(n,s).ldelim()},e.decode=function(n,s){n instanceof N||(n=N.create(n));for(var i=s===void 0?n.len:n.pos+s,u=new h.onnx.TypeProto.Tensor;n.pos<i;){var l=n.uint32();switch(l>>>3){case 1:{u.elemType=n.int32();break}case 2:{u.shape=h.onnx.TensorShapeProto.decode(n,n.uint32());break}default:n.skipType(l&7);break}}return u},e.decodeDelimited=function(n){return n instanceof N||(n=new N(n)),this.decode(n,n.uint32())},e.verify=function(n){if(typeof n!="object"||n===null)return"object expected";if(n.elemType!=null&&n.hasOwnProperty("elemType")&&!g.isInteger(n.elemType))return"elemType: integer expected";if(n.shape!=null&&n.hasOwnProperty("shape")){var s=h.onnx.TensorShapeProto.verify(n.shape);if(s)return"shape."+s}return null},e.fromObject=function(n){if(n instanceof h.onnx.TypeProto.Tensor)return n;var s=new h.onnx.TypeProto.Tensor;if(n.elemType!=null&&(s.elemType=n.elemType|0),n.shape!=null){if(typeof n.shape!="object")throw TypeError(".onnx.TypeProto.Tensor.shape: object expected");s.shape=h.onnx.TensorShapeProto.fromObject(n.shape)}return s},e.toObject=function(n,s){s||(s={});var i={};return s.defaults&&(i.elemType=0,i.shape=null),n.elemType!=null&&n.hasOwnProperty("elemType")&&(i.elemType=n.elemType),n.shape!=null&&n.hasOwnProperty("shape")&&(i.shape=h.onnx.TensorShapeProto.toObject(n.shape,s)),i},e.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},e.getTypeUrl=function(n){return n===void 0&&(n="type.googleapis.com"),n+"/onnx.TypeProto.Tensor"},e}(),t.Sequence=function(){function e(r){if(r)for(var n=Object.keys(r),s=0;s<n.length;++s)r[n[s]]!=null&&(this[n[s]]=r[n[s]])}return e.prototype.elemType=null,e.create=function(n){return new e(n)},e.encode=function(n,s){return s||(s=Pe.create()),n.elemType!=null&&Object.hasOwnProperty.call(n,"elemType")&&h.onnx.TypeProto.encode(n.elemType,s.uint32(10).fork()).ldelim(),s},e.encodeDelimited=function(n,s){return this.encode(n,s).ldelim()},e.decode=function(n,s){n instanceof N||(n=N.create(n));for(var i=s===void 0?n.len:n.pos+s,u=new h.onnx.TypeProto.Sequence;n.pos<i;){var l=n.uint32();switch(l>>>3){case 1:{u.elemType=h.onnx.TypeProto.decode(n,n.uint32());break}default:n.skipType(l&7);break}}return u},e.decodeDelimited=function(n){return n instanceof N||(n=new N(n)),this.decode(n,n.uint32())},e.verify=function(n){if(typeof n!="object"||n===null)return"object expected";if(n.elemType!=null&&n.hasOwnProperty("elemType")){var s=h.onnx.TypeProto.verify(n.elemType);if(s)return"elemType."+s}return null},e.fromObject=function(n){if(n instanceof h.onnx.TypeProto.Sequence)return n;var s=new h.onnx.TypeProto.Sequence;if(n.elemType!=null){if(typeof n.elemType!="object")throw TypeError(".onnx.TypeProto.Sequence.elemType: object expected");s.elemType=h.onnx.TypeProto.fromObject(n.elemType)}return s},e.toObject=function(n,s){s||(s={});var i={};return s.defaults&&(i.elemType=null),n.elemType!=null&&n.hasOwnProperty("elemType")&&(i.elemType=h.onnx.TypeProto.toObject(n.elemType,s)),i},e.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},e.getTypeUrl=function(n){return n===void 0&&(n="type.googleapis.com"),n+"/onnx.TypeProto.Sequence"},e}(),t.Map=function(){function e(r){if(r)for(var n=Object.keys(r),s=0;s<n.length;++s)r[n[s]]!=null&&(this[n[s]]=r[n[s]])}return e.prototype.keyType=0,e.prototype.valueType=null,e.create=function(n){return new e(n)},e.encode=function(n,s){return s||(s=Pe.create()),n.keyType!=null&&Object.hasOwnProperty.call(n,"keyType")&&s.uint32(8).int32(n.keyType),n.valueType!=null&&Object.hasOwnProperty.call(n,"valueType")&&h.onnx.TypeProto.encode(n.valueType,s.uint32(18).fork()).ldelim(),s},e.encodeDelimited=function(n,s){return this.encode(n,s).ldelim()},e.decode=function(n,s){n instanceof N||(n=N.create(n));for(var i=s===void 0?n.len:n.pos+s,u=new h.onnx.TypeProto.Map;n.pos<i;){var l=n.uint32();switch(l>>>3){case 1:{u.keyType=n.int32();break}case 2:{u.valueType=h.onnx.TypeProto.decode(n,n.uint32());break}default:n.skipType(l&7);break}}return u},e.decodeDelimited=function(n){return n instanceof N||(n=new N(n)),this.decode(n,n.uint32())},e.verify=function(n){if(typeof n!="object"||n===null)return"object expected";if(n.keyType!=null&&n.hasOwnProperty("keyType")&&!g.isInteger(n.keyType))return"keyType: integer expected";if(n.valueType!=null&&n.hasOwnProperty("valueType")){var s=h.onnx.TypeProto.verify(n.valueType);if(s)return"valueType."+s}return null},e.fromObject=function(n){if(n instanceof h.onnx.TypeProto.Map)return n;var s=new h.onnx.TypeProto.Map;if(n.keyType!=null&&(s.keyType=n.keyType|0),n.valueType!=null){if(typeof n.valueType!="object")throw TypeError(".onnx.TypeProto.Map.valueType: object expected");s.valueType=h.onnx.TypeProto.fromObject(n.valueType)}return s},e.toObject=function(n,s){s||(s={});var i={};return s.defaults&&(i.keyType=0,i.valueType=null),n.keyType!=null&&n.hasOwnProperty("keyType")&&(i.keyType=n.keyType),n.valueType!=null&&n.hasOwnProperty("valueType")&&(i.valueType=h.onnx.TypeProto.toObject(n.valueType,s)),i},e.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},e.getTypeUrl=function(n){return n===void 0&&(n="type.googleapis.com"),n+"/onnx.TypeProto.Map"},e}(),t.Optional=function(){function e(r){if(r)for(var n=Object.keys(r),s=0;s<n.length;++s)r[n[s]]!=null&&(this[n[s]]=r[n[s]])}return e.prototype.elemType=null,e.create=function(n){return new e(n)},e.encode=function(n,s){return s||(s=Pe.create()),n.elemType!=null&&Object.hasOwnProperty.call(n,"elemType")&&h.onnx.TypeProto.encode(n.elemType,s.uint32(10).fork()).ldelim(),s},e.encodeDelimited=function(n,s){return this.encode(n,s).ldelim()},e.decode=function(n,s){n instanceof N||(n=N.create(n));for(var i=s===void 0?n.len:n.pos+s,u=new h.onnx.TypeProto.Optional;n.pos<i;){var l=n.uint32();switch(l>>>3){case 1:{u.elemType=h.onnx.TypeProto.decode(n,n.uint32());break}default:n.skipType(l&7);break}}return u},e.decodeDelimited=function(n){return n instanceof N||(n=new N(n)),this.decode(n,n.uint32())},e.verify=function(n){if(typeof n!="object"||n===null)return"object expected";if(n.elemType!=null&&n.hasOwnProperty("elemType")){var s=h.onnx.TypeProto.verify(n.elemType);if(s)return"elemType."+s}return null},e.fromObject=function(n){if(n instanceof h.onnx.TypeProto.Optional)return n;var s=new h.onnx.TypeProto.Optional;if(n.elemType!=null){if(typeof n.elemType!="object")throw TypeError(".onnx.TypeProto.Optional.elemType: object expected");s.elemType=h.onnx.TypeProto.fromObject(n.elemType)}return s},e.toObject=function(n,s){s||(s={});var i={};return s.defaults&&(i.elemType=null),n.elemType!=null&&n.hasOwnProperty("elemType")&&(i.elemType=h.onnx.TypeProto.toObject(n.elemType,s)),i},e.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},e.getTypeUrl=function(n){return n===void 0&&(n="type.googleapis.com"),n+"/onnx.TypeProto.Optional"},e}(),t.SparseTensor=function(){function e(r){if(r)for(var n=Object.keys(r),s=0;s<n.length;++s)r[n[s]]!=null&&(this[n[s]]=r[n[s]])}return e.prototype.elemType=0,e.prototype.shape=null,e.create=function(n){return new e(n)},e.encode=function(n,s){return s||(s=Pe.create()),n.elemType!=null&&Object.hasOwnProperty.call(n,"elemType")&&s.uint32(8).int32(n.elemType),n.shape!=null&&Object.hasOwnProperty.call(n,"shape")&&h.onnx.TensorShapeProto.encode(n.shape,s.uint32(18).fork()).ldelim(),s},e.encodeDelimited=function(n,s){return this.encode(n,s).ldelim()},e.decode=function(n,s){n instanceof N||(n=N.create(n));for(var i=s===void 0?n.len:n.pos+s,u=new h.onnx.TypeProto.SparseTensor;n.pos<i;){var l=n.uint32();switch(l>>>3){case 1:{u.elemType=n.int32();break}case 2:{u.shape=h.onnx.TensorShapeProto.decode(n,n.uint32());break}default:n.skipType(l&7);break}}return u},e.decodeDelimited=function(n){return n instanceof N||(n=new N(n)),this.decode(n,n.uint32())},e.verify=function(n){if(typeof n!="object"||n===null)return"object expected";if(n.elemType!=null&&n.hasOwnProperty("elemType")&&!g.isInteger(n.elemType))return"elemType: integer expected";if(n.shape!=null&&n.hasOwnProperty("shape")){var s=h.onnx.TensorShapeProto.verify(n.shape);if(s)return"shape."+s}return null},e.fromObject=function(n){if(n instanceof h.onnx.TypeProto.SparseTensor)return n;var s=new h.onnx.TypeProto.SparseTensor;if(n.elemType!=null&&(s.elemType=n.elemType|0),n.shape!=null){if(typeof n.shape!="object")throw TypeError(".onnx.TypeProto.SparseTensor.shape: object expected");s.shape=h.onnx.TensorShapeProto.fromObject(n.shape)}return s},e.toObject=function(n,s){s||(s={});var i={};return s.defaults&&(i.elemType=0,i.shape=null),n.elemType!=null&&n.hasOwnProperty("elemType")&&(i.elemType=n.elemType),n.shape!=null&&n.hasOwnProperty("shape")&&(i.shape=h.onnx.TensorShapeProto.toObject(n.shape,s)),i},e.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},e.getTypeUrl=function(n){return n===void 0&&(n="type.googleapis.com"),n+"/onnx.TypeProto.SparseTensor"},e}(),t}(),a.OperatorSetIdProto=function(){function t(o){if(o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.domain="",t.prototype.version=g.Long?g.Long.fromBits(0,0,!1):0,t.create=function(e){return new t(e)},t.encode=function(e,r){return r||(r=Pe.create()),e.domain!=null&&Object.hasOwnProperty.call(e,"domain")&&r.uint32(10).string(e.domain),e.version!=null&&Object.hasOwnProperty.call(e,"version")&&r.uint32(16).int64(e.version),r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.OperatorSetIdProto;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{s.domain=e.string();break}case 2:{s.version=e.int64();break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){return typeof e!="object"||e===null?"object expected":e.domain!=null&&e.hasOwnProperty("domain")&&!g.isString(e.domain)?"domain: string expected":e.version!=null&&e.hasOwnProperty("version")&&!g.isInteger(e.version)&&!(e.version&&g.isInteger(e.version.low)&&g.isInteger(e.version.high))?"version: integer|Long expected":null},t.fromObject=function(e){if(e instanceof h.onnx.OperatorSetIdProto)return e;var r=new h.onnx.OperatorSetIdProto;return e.domain!=null&&(r.domain=String(e.domain)),e.version!=null&&(g.Long?(r.version=g.Long.fromValue(e.version)).unsigned=!1:typeof e.version=="string"?r.version=parseInt(e.version,10):typeof e.version=="number"?r.version=e.version:typeof e.version=="object"&&(r.version=new g.LongBits(e.version.low>>>0,e.version.high>>>0).toNumber())),r},t.toObject=function(e,r){r||(r={});var n={};if(r.defaults)if(n.domain="",g.Long){var s=new g.Long(0,0,!1);n.version=r.longs===String?s.toString():r.longs===Number?s.toNumber():s}else n.version=r.longs===String?"0":0;return e.domain!=null&&e.hasOwnProperty("domain")&&(n.domain=e.domain),e.version!=null&&e.hasOwnProperty("version")&&(typeof e.version=="number"?n.version=r.longs===String?String(e.version):e.version:n.version=r.longs===String?g.Long.prototype.toString.call(e.version):r.longs===Number?new g.LongBits(e.version.low>>>0,e.version.high>>>0).toNumber():e.version),n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.OperatorSetIdProto"},t}(),a.OperatorStatus=function(){var t={},o=Object.create(t);return o[t[0]="EXPERIMENTAL"]=0,o[t[1]="STABLE"]=1,o}(),a.FunctionProto=function(){function t(o){if(this.input=[],this.output=[],this.attribute=[],this.attributeProto=[],this.node=[],this.opsetImport=[],o)for(var e=Object.keys(o),r=0;r<e.length;++r)o[e[r]]!=null&&(this[e[r]]=o[e[r]])}return t.prototype.name="",t.prototype.input=g.emptyArray,t.prototype.output=g.emptyArray,t.prototype.attribute=g.emptyArray,t.prototype.attributeProto=g.emptyArray,t.prototype.node=g.emptyArray,t.prototype.docString="",t.prototype.opsetImport=g.emptyArray,t.prototype.domain="",t.create=function(e){return new t(e)},t.encode=function(e,r){if(r||(r=Pe.create()),e.name!=null&&Object.hasOwnProperty.call(e,"name")&&r.uint32(10).string(e.name),e.input!=null&&e.input.length)for(var n=0;n<e.input.length;++n)r.uint32(34).string(e.input[n]);if(e.output!=null&&e.output.length)for(var n=0;n<e.output.length;++n)r.uint32(42).string(e.output[n]);if(e.attribute!=null&&e.attribute.length)for(var n=0;n<e.attribute.length;++n)r.uint32(50).string(e.attribute[n]);if(e.node!=null&&e.node.length)for(var n=0;n<e.node.length;++n)h.onnx.NodeProto.encode(e.node[n],r.uint32(58).fork()).ldelim();if(e.docString!=null&&Object.hasOwnProperty.call(e,"docString")&&r.uint32(66).string(e.docString),e.opsetImport!=null&&e.opsetImport.length)for(var n=0;n<e.opsetImport.length;++n)h.onnx.OperatorSetIdProto.encode(e.opsetImport[n],r.uint32(74).fork()).ldelim();if(e.domain!=null&&Object.hasOwnProperty.call(e,"domain")&&r.uint32(82).string(e.domain),e.attributeProto!=null&&e.attributeProto.length)for(var n=0;n<e.attributeProto.length;++n)h.onnx.AttributeProto.encode(e.attributeProto[n],r.uint32(90).fork()).ldelim();return r},t.encodeDelimited=function(e,r){return this.encode(e,r).ldelim()},t.decode=function(e,r){e instanceof N||(e=N.create(e));for(var n=r===void 0?e.len:e.pos+r,s=new h.onnx.FunctionProto;e.pos<n;){var i=e.uint32();switch(i>>>3){case 1:{s.name=e.string();break}case 4:{s.input&&s.input.length||(s.input=[]),s.input.push(e.string());break}case 5:{s.output&&s.output.length||(s.output=[]),s.output.push(e.string());break}case 6:{s.attribute&&s.attribute.length||(s.attribute=[]),s.attribute.push(e.string());break}case 11:{s.attributeProto&&s.attributeProto.length||(s.attributeProto=[]),s.attributeProto.push(h.onnx.AttributeProto.decode(e,e.uint32()));break}case 7:{s.node&&s.node.length||(s.node=[]),s.node.push(h.onnx.NodeProto.decode(e,e.uint32()));break}case 8:{s.docString=e.string();break}case 9:{s.opsetImport&&s.opsetImport.length||(s.opsetImport=[]),s.opsetImport.push(h.onnx.OperatorSetIdProto.decode(e,e.uint32()));break}case 10:{s.domain=e.string();break}default:e.skipType(i&7);break}}return s},t.decodeDelimited=function(e){return e instanceof N||(e=new N(e)),this.decode(e,e.uint32())},t.verify=function(e){if(typeof e!="object"||e===null)return"object expected";if(e.name!=null&&e.hasOwnProperty("name")&&!g.isString(e.name))return"name: string expected";if(e.input!=null&&e.hasOwnProperty("input")){if(!Array.isArray(e.input))return"input: array expected";for(var r=0;r<e.input.length;++r)if(!g.isString(e.input[r]))return"input: string[] expected"}if(e.output!=null&&e.hasOwnProperty("output")){if(!Array.isArray(e.output))return"output: array expected";for(var r=0;r<e.output.length;++r)if(!g.isString(e.output[r]))return"output: string[] expected"}if(e.attribute!=null&&e.hasOwnProperty("attribute")){if(!Array.isArray(e.attribute))return"attribute: array expected";for(var r=0;r<e.attribute.length;++r)if(!g.isString(e.attribute[r]))return"attribute: string[] expected"}if(e.attributeProto!=null&&e.hasOwnProperty("attributeProto")){if(!Array.isArray(e.attributeProto))return"attributeProto: array expected";for(var r=0;r<e.attributeProto.length;++r){var n=h.onnx.AttributeProto.verify(e.attributeProto[r]);if(n)return"attributeProto."+n}}if(e.node!=null&&e.hasOwnProperty("node")){if(!Array.isArray(e.node))return"node: array expected";for(var r=0;r<e.node.length;++r){var n=h.onnx.NodeProto.verify(e.node[r]);if(n)return"node."+n}}if(e.docString!=null&&e.hasOwnProperty("docString")&&!g.isString(e.docString))return"docString: string expected";if(e.opsetImport!=null&&e.hasOwnProperty("opsetImport")){if(!Array.isArray(e.opsetImport))return"opsetImport: array expected";for(var r=0;r<e.opsetImport.length;++r){var n=h.onnx.OperatorSetIdProto.verify(e.opsetImport[r]);if(n)return"opsetImport."+n}}return e.domain!=null&&e.hasOwnProperty("domain")&&!g.isString(e.domain)?"domain: string expected":null},t.fromObject=function(e){if(e instanceof h.onnx.FunctionProto)return e;var r=new h.onnx.FunctionProto;if(e.name!=null&&(r.name=String(e.name)),e.input){if(!Array.isArray(e.input))throw TypeError(".onnx.FunctionProto.input: array expected");r.input=[];for(var n=0;n<e.input.length;++n)r.input[n]=String(e.input[n])}if(e.output){if(!Array.isArray(e.output))throw TypeError(".onnx.FunctionProto.output: array expected");r.output=[];for(var n=0;n<e.output.length;++n)r.output[n]=String(e.output[n])}if(e.attribute){if(!Array.isArray(e.attribute))throw TypeError(".onnx.FunctionProto.attribute: array expected");r.attribute=[];for(var n=0;n<e.attribute.length;++n)r.attribute[n]=String(e.attribute[n])}if(e.attributeProto){if(!Array.isArray(e.attributeProto))throw TypeError(".onnx.FunctionProto.attributeProto: array expected");r.attributeProto=[];for(var n=0;n<e.attributeProto.length;++n){if(typeof e.attributeProto[n]!="object")throw TypeError(".onnx.FunctionProto.attributeProto: object expected");r.attributeProto[n]=h.onnx.AttributeProto.fromObject(e.attributeProto[n])}}if(e.node){if(!Array.isArray(e.node))throw TypeError(".onnx.FunctionProto.node: array expected");r.node=[];for(var n=0;n<e.node.length;++n){if(typeof e.node[n]!="object")throw TypeError(".onnx.FunctionProto.node: object expected");r.node[n]=h.onnx.NodeProto.fromObject(e.node[n])}}if(e.docString!=null&&(r.docString=String(e.docString)),e.opsetImport){if(!Array.isArray(e.opsetImport))throw TypeError(".onnx.FunctionProto.opsetImport: array expected");r.opsetImport=[];for(var n=0;n<e.opsetImport.length;++n){if(typeof e.opsetImport[n]!="object")throw TypeError(".onnx.FunctionProto.opsetImport: object expected");r.opsetImport[n]=h.onnx.OperatorSetIdProto.fromObject(e.opsetImport[n])}}return e.domain!=null&&(r.domain=String(e.domain)),r},t.toObject=function(e,r){r||(r={});var n={};if((r.arrays||r.defaults)&&(n.input=[],n.output=[],n.attribute=[],n.node=[],n.opsetImport=[],n.attributeProto=[]),r.defaults&&(n.name="",n.docString="",n.domain=""),e.name!=null&&e.hasOwnProperty("name")&&(n.name=e.name),e.input&&e.input.length){n.input=[];for(var s=0;s<e.input.length;++s)n.input[s]=e.input[s]}if(e.output&&e.output.length){n.output=[];for(var s=0;s<e.output.length;++s)n.output[s]=e.output[s]}if(e.attribute&&e.attribute.length){n.attribute=[];for(var s=0;s<e.attribute.length;++s)n.attribute[s]=e.attribute[s]}if(e.node&&e.node.length){n.node=[];for(var s=0;s<e.node.length;++s)n.node[s]=h.onnx.NodeProto.toObject(e.node[s],r)}if(e.docString!=null&&e.hasOwnProperty("docString")&&(n.docString=e.docString),e.opsetImport&&e.opsetImport.length){n.opsetImport=[];for(var s=0;s<e.opsetImport.length;++s)n.opsetImport[s]=h.onnx.OperatorSetIdProto.toObject(e.opsetImport[s],r)}if(e.domain!=null&&e.hasOwnProperty("domain")&&(n.domain=e.domain),e.attributeProto&&e.attributeProto.length){n.attributeProto=[];for(var s=0;s<e.attributeProto.length;++s)n.attributeProto[s]=h.onnx.AttributeProto.toObject(e.attributeProto[s],r)}return n},t.prototype.toJSON=function(){return this.constructor.toObject(this,ge.util.toJSONOptions)},t.getTypeUrl=function(e){return e===void 0&&(e="type.googleapis.com"),e+"/onnx.FunctionProto"},t}(),a}();Cu.exports=h});function Fr(a,t){if(!a)throw new Error(typeof t=="string"?t:t())}function sn(a){return new TextDecoder().decode(a)}var ye,hr,pi,Ze,jn,We,it,U,an,mr,br,gr,fe=L(()=>{"use strict";zn();Zo();ye=Ar(Cr());yr();hr=class{static arraysEqual(t,o){if(t.length!==o.length)return!1;for(let e=0;e<t.length;e++)if(t[e]!==o[e])return!1;return!0}},pi=class{static preprocessInputShapes(t,o){let e=t.length===1?[1,t[0]]:t,r=o.length===1?[o[0],1]:o;return[e,r]}static postprocessOutputShape(t,o,e){o===1&&t.splice(t.length-2,1),e===1&&t.pop()}static calcMatMulShape(t,o){return t[1]!==o[0]?void 0:[t[0],o[1]]}},Ze=class a{static calcShape(t,o,e=!1){let r=t.length,n=o.length;if(r===0)return o;if(n===0)return t;let s=Math.max(t.length,o.length),i=new Array(s);if(e){if(r<2||n<2)return;let u=pi.calcMatMulShape([t[r-2],t[r-1]],[o[n-2],o[n-1]]);if(u===void 0)return;[i[s-2],i[s-1]]=u}for(let u=e?3:1;u<=s;u++){let l=r-u<0?1:t[r-u],c=n-u<0?1:o[n-u];if(l!==c&&l>1&&c>1)return;i[s-u]=Math.max(l,c)}return i}static index(t,o){let e=new Array(o.length);return a.fillIndex(t,o,e),e}static fillIndex(t,o,e){let r=t.length-o.length;for(let n=0;n<o.length;n++)e[n]=t[r+n]%o[n]}static calc(t,o,e,r,n){let s=a.calcShape(t.dims,o.dims);if(s){if(r&&!U.areEqual(s,t.dims))return;let i=U.size(s),u=r?t:new $e(s,n||t.type);if(s.length===0)u.set([],e(t.get([]),o.get([])));else{let l=new Array(s.length),c=new Array(t.dims.length),p=new Array(o.dims.length),d=0,T=0,w=!1,v=!1;t.dims.length===0&&(d=t.get([]),w=!0),o.dims.length===0&&(T=o.get([]),v=!0);let S;for(let A=0;A<i;A++){S=A;for(let C=s.length-1;C>=0;C--)l[C]=S%s[C],S=Math.floor(S/s[C]);w||(a.fillIndex(l,t.dims,c),d=t.get(c)),v||(a.fillIndex(l,o.dims,p),T=o.get(p)),u.set(l,e(d,T))}}return u}}static isValidBroadcast(t,o){let e=t.length,r=o.length;if(e>r)return!1;for(let n=1;n<=e;n++)if(t[e-n]!==1&&t[e-n]!==o[r-n])return!1;return!0}static getBroadcastDims(t,o){let e=t.length,r=[];for(let n=0;n<e;n++){let s=e-1-n,i=t[s]||1;(o[o.length-1-n]||1)>1&&i===1&&r.unshift(s)}return r}},jn=class{static getShapeOfGemmResult(t,o,e,r,n){if(t.length!==2||e.length!==2)throw new Error("shape need to be of size 2");let s,i,u;o?(s=t[1],i=t[0]):(s=t[0],i=t[1]);let l=-1;if(r?(u=e[0],l=1):(u=e[1],l=0),e[l]!==i)throw new Error("dimension mismatch");if(s<=0||u<=0||i<=0)throw new Error("invalid shape specified");if(n&&!Ze.isValidBroadcast(n,[s,u]))throw new Error("gemm: invalid bias shape for broadcast");return[s,u,i]}},We=class a{static tensorDataTypeFromProto(t){switch(t){case ye.onnx.TensorProto.DataType.INT8:return"int8";case ye.onnx.TensorProto.DataType.UINT8:return"uint8";case ye.onnx.TensorProto.DataType.BOOL:return"bool";case ye.onnx.TensorProto.DataType.INT16:return"int16";case ye.onnx.TensorProto.DataType.UINT16:return"uint16";case ye.onnx.TensorProto.DataType.INT32:return"int32";case ye.onnx.TensorProto.DataType.UINT32:return"uint32";case ye.onnx.TensorProto.DataType.FLOAT:return"float32";case ye.onnx.TensorProto.DataType.DOUBLE:return"float64";case ye.onnx.TensorProto.DataType.STRING:return"string";case ye.onnx.TensorProto.DataType.INT64:return"int32";case ye.onnx.TensorProto.DataType.UINT64:return"uint32";default:throw new Error(`unsupported data type: ${ye.onnx.TensorProto.DataType[t]}`)}}static tensorDataTypeStringToEnum(t){switch(t){case"int8":return ye.onnx.TensorProto.DataType.INT8;case"uint8":return ye.onnx.TensorProto.DataType.UINT8;case"bool":return ye.onnx.TensorProto.DataType.BOOL;case"int16":return ye.onnx.TensorProto.DataType.INT16;case"uint16":return ye.onnx.TensorProto.DataType.UINT16;case"int32":return ye.onnx.TensorProto.DataType.INT32;case"uint32":return ye.onnx.TensorProto.DataType.UINT32;case"float32":return ye.onnx.TensorProto.DataType.FLOAT;case"float64":return ye.onnx.TensorProto.DataType.DOUBLE;case"string":return ye.onnx.TensorProto.DataType.STRING;case"int64":return ye.onnx.TensorProto.DataType.INT64;case"uint64":return ye.onnx.TensorProto.DataType.UINT64;default:throw new Error(`unsupported data type: ${t}`)}}static tensorDimsFromProto(t){return t.map(o=>Vt.isLong(o)?o.toNumber():o)}static tensorValueTypeFromProto(t){return{tensorType:a.tensorDataTypeFromProto(t.elemType),shape:{dims:a.tensorDimsFromProto(t.shape.dim.map(o=>o.dimValue))}}}static tensorDimsFromORTFormat(t){let o=[];for(let e=0;e<t.dimsLength();e++)o.push(it.longToNumber(t.dims(e)));return o}static tensorAttributesFromORTFormat(t){let o=[];for(let e=0;e<t.attributesLength();e++)o.push(t.attributes(e));return o}},it=class{static longToNumber(t,o){return Vt.isLong(t)?t.toNumber():t instanceof _.Long?Vt.fromValue({low:t.low,high:t.high,unsigned:o??!1}).toNumber():t}static isLong(t){return Vt.isLong(t)||t instanceof _.Long}},U=class a{static size(t){return a.getSizeFromDimensionRange(t,0,t.length)}static sizeFromDimension(t,o){if(o<0||o>t.length)throw new Error(`invalid dimension of ${o} for sizeFromDimension as Tensor has ${t.length} dimensions.`);return a.getSizeFromDimensionRange(t,o,t.length)}static sizeToDimension(t,o){if(o<0||o>t.length)throw new Error(`invalid dimension of ${o} for sizeToDimension as Tensor has ${t.length} dimensions.`);return a.getSizeFromDimensionRange(t,0,o)}static getSizeFromDimensionRange(t,o,e){let r=1;for(let n=o;n<e;n++){if(t[n]<=0)throw new Error("cannot get valid size from specified dimension range. Most likely the range contains 0 or negative values in them.");r*=t[n]}return r}static computeStrides(t){let o=t.length;if(o===0)return[];if(o===1)return[1];let e=new Array(o);e[o-1]=1,e[o-2]=t[o-1];for(let r=o-3;r>=0;--r)e[r]=e[r+1]*t[r+1];return e}static transpose(t){return t.slice().reverse()}static indicesToOffset(t,o,e){e===void 0&&(e=t.length);let r=0;for(let n=0;n<e;++n)r+=o[n]*t[n];return r}static offsetToIndices(t,o){let e=o.length;if(e===0)return[];if(e===1)return[t*o[0]];let r=new Array(o.length);for(let n=0;n<r.length-1;++n)r[n]=Math.floor(t/o[n]),t-=r[n]*o[n];return r[r.length-1]=t,r}static normalizeAxis(t,o){if(t<-o&&t>=o)throw new Error("unsupported axis for this operation.");return t<0?t+o:t}static normalizeAxes(t,o){return t.map(e=>this.normalizeAxis(e,o))}static incrementIndex(t,o,e){if(o.length===0||t.length===0)throw new Error("Index incrementing unsupported for scalar Tensor");if(e===void 0)e=o.length;else if(e<=0||e>o.length)throw new Error("Incorrect axis to increment on");for(let r=e-1;r>=0&&(t[r]++,!(t[r]<o[r]));--r)t[r]=0}static calculateReshapedDims(t,o){if(o.length===0){if(t.length===0||a.size(t)===1)return[];throw new Error("cannot reshape to a scalar Tensor")}let e=o.length,r=new Array(e),n=-1,s=1;for(let u=0;u<e;u++){if(o[u]<-1)throw new Error("a dimension in shape hints cannot be less than -1");if(o[u]===-1){if(n!==-1)throw new Error("at most one dimension in shape hints can be -1");n=u}else{if(o[u]===0){if(u>=t.length)throw new Error("the dimension with value zero exceeds the dimension size of the input tensor");r[u]=t[u]}else r[u]=o[u];s*=r[u]}}let i=a.size(t);if(n!==-1){if(i%s!==0)throw new Error(`the input tensor cannot be reshaped to the requested shape. Input shape: [${t}] Output shape: [${o}]`);r[n]=i/s}else if(s!==i)throw new Error("reshapedDims and originalDims don't have matching sizes");return r}static sortBasedOnPerm(t,o){return o?o.map(e=>t[e]):t.slice().reverse()}static padShape(t,o){let e=t.length;return t.map((r,n)=>r+o[n]+o[n+e])}static areEqual(t,o){return t.length!==o.length?!1:t.every((e,r)=>e===o[r])}static validateDimsAndCalcSize(t){if(t.length>6)throw new TypeError("Only rank 0 to 6 is supported for tensor shape.");let o=1;for(let e of t){if(!Number.isInteger(e))throw new TypeError(`Invalid shape: ${e} is not an integer`);if(e<0||e>2147483647)throw new TypeError(`Invalid shape: length ${e} is not allowed`);o*=e}return o}static flattenShape(t,o){o<0&&(o+=t.length);let e=t.reduce((s,i)=>s*i,1),r=t.slice(o).reduce((s,i)=>s*i,1);return[e/r,r]}static squeezeShape(t,o){let e=new Array;o=a.normalizeAxes(o,t.length);for(let r=0;r<t.length;r++){let n=o.indexOf(r)>=0;if(n&&t[r]!==1)throw new Error("squeeze an axis of size different than 1");(o.length===0&&t[r]>1||o.length>0&&!n)&&e.push(t[r])}return e}static unsqueezeShape(t,o){let e=new Array(t.length+o.length);e.fill(0);for(let n=0;n<o.length;n++){let s=a.normalizeAxis(o[n],e.length);if(s>=e.length)throw new Error("'axes' has an out of range axis");if(e[s]!==0)throw new Error("'axes' has a duplicate axis");e[s]=1}let r=0;for(let n=0;n<e.length;n++)e[n]===0&&(e[n]=t[r++]);if(r!==t.length)throw new Error("the unsqueezed dimension could not be established");return e}},an=class a{static splitShape(t,o,e,r){if(e.length===0){if(!r)throw new Error("need to know number of outputs when the 'split' attribute is not specified");a.determineSplit(t[o],r,e)}let n=[],s=[0];for(let i=0;i<e.length;++i){i!==0&&s.push(s[i-1]+e[i-1]);let u=t.slice();u[o]=e[i],n.push(u)}return[n,s]}static determineSplit(t,o,e){if(t%o!==0)throw new Error("cannot split tensor to equal sized parts");for(let r=0;r<o;++r)e.push(t/o)}},mr=class a{static adjustPoolAttributes(t,o,e,r,n,s){if(!t&&e.length!==o.length-2)throw new Error("length of specified kernel shapes should be 2 less than length of input dimensions");if(t)for(let i=0;i<o.length-2;i++)i>=e.length?e.push(o[i+2]):e[i]=o[i+2];for(let i=0;i<e.length;i++)if(i<r.length){if(r[i]<0)throw new Error("strides should be greater than or equal to 1")}else r.push(1);for(let i=0;i<e.length;i++)if(i<n.length){if(n[i]<0)throw new Error("dilations should be greater than or equal to 1")}else n.push(1);for(let i=0;i<e.length*2;i++)if(i<s.length){if(s[i]<0)throw new Error("pad should be greater than or equal to 1")}else s.push(0);for(let i=0;i<e.length;i++){if(e[i]<=0)throw new Error("kernel shapes need to be greater than 0");if(s[i]>=e[i]||s[i+e.length]>=e[i])throw new Error("pads should be smaller than kernel")}}static adjustPadsBasedOnAutoPad(t,o,e,r,n,s){if(s){if(n.length!==2*(t.length-2))throw new Error("length of pads should be twice the length of data dimensions");if(o.length!==t.length-2)throw new Error("length of strides should be the length of data dimensions");if(r.length!==t.length-2)throw new Error("length of kernel shapes should be the length of data dimensions");for(let i=0;i<t.length-2;i++)a.adjustPadAndReturnShape(t[i+2],o[i],e[i],r[i],n,i,i+t.length-2,s)}}static computePoolOutputShape(t,o,e,r,n,s,i){if(o.length<=0)throw new Error("input shape must be of size greater than 0");let u=[o[0],o[1]];return a.computeShapeHelper(t,o,u,e,r,n,s,i),u}static computeConvOutputShape(t,o,e,r,n,s,i){if(t.length<=0||o.length<=0)throw new Error("invalid input tensor dims or invalid filter tensor dims");let u=[t[0],o[0]];return a.computeShapeHelper(!1,t,u,e,r,n,s,i),u}static computeShapeHelper(t,o,e,r,n,s,i,u){if(t)for(let l=0;l<o.length-2;l++)e.push(1);else for(let l=0;l<o.length-2;l++)e.push(a.adjustPadAndReturnShape(o[l+2],r[l],n[l],s[l],i,l,l+o.length-2,u))}static adjustPadAndReturnShape(t,o,e,r,n,s,i,u){let l=e*(r-1)+1;if(u&&u!=="NOTSET")switch(u){case"VALID":return n[s]=0,n[i]=0,Math.floor((t-l)/o+1);case"SAME_LOWER":case"SAME_UPPER":if(e!==1)throw new Error("Dilation not supported for SAME_UPPER or SAME_LOWER");{let p=((t+o-1)/o-1)*o+r-t;return n[s]=Math.floor(u==="SAME_LOWER"?(p+1)/2:p/2),n[i]=p-n[s],Math.floor((t+p-r)/o+1)}default:throw new Error("Unsupported AutoPad type")}else return Math.floor((t+n[s]+n[i]-l)/o+1)}},br=-34028234663852886e22,gr=34028234663852886e22});function Hd(a){switch(a){case"bool":case"int8":case"uint8":return 1;case"int16":case"uint16":return 2;case"int32":case"uint32":case"float32":return 4;case"float64":return 8;default:throw new Error(`cannot calculate sizeof() on type ${a}`)}}function Fu(a){switch(a){case ne.onnx.TensorProto.DataType.UINT8:case ne.onnx.TensorProto.DataType.INT8:case ne.onnx.TensorProto.DataType.BOOL:return 1;case ne.onnx.TensorProto.DataType.UINT16:case ne.onnx.TensorProto.DataType.INT16:return 2;case ne.onnx.TensorProto.DataType.FLOAT:case ne.onnx.TensorProto.DataType.INT32:case ne.onnx.TensorProto.DataType.UINT32:return 4;case ne.onnx.TensorProto.DataType.INT64:case ne.onnx.TensorProto.DataType.DOUBLE:case ne.onnx.TensorProto.DataType.UINT64:return 8;default:throw new Error(`cannot calculate sizeof() on type ${ne.onnx.TensorProto.DataType[a]}`)}}function qd(a,t){return new(Bu(t))(a)}function Bu(a){switch(a){case"bool":case"uint8":return Uint8Array;case"int8":return Int8Array;case"int16":return Int16Array;case"uint16":return Uint16Array;case"int32":return Int32Array;case"uint32":return Uint32Array;case"int64":return BigInt64Array;case"float32":return Float32Array;case"float64":return Float64Array;default:throw new Error("unspecified error")}}function hi(a,t){if(t===ne.onnx.TensorProto.DataType.INT64||t===di.TensorDataType.INT64){if(a.greaterThanOrEqual(2147483648)||a.lessThan(-2147483648))throw new TypeError("int64 is not supported")}else if(t===ne.onnx.TensorProto.DataType.UINT32||t===di.TensorDataType.UINT32||t===ne.onnx.TensorProto.DataType.UINT64||t===di.TensorDataType.UINT64){if(a.greaterThanOrEqual(4294967296)||a.lessThan(0))throw new TypeError("uint64 is not supported")}else throw new TypeError(`not a LONG type: ${ne.onnx.TensorProto.DataType[t]}`);return a.toNumber()}function $u(a,t,o){switch(t){case ne.onnx.TensorProto.DataType.BOOL:case ne.onnx.TensorProto.DataType.UINT8:return a.getUint8(o);case ne.onnx.TensorProto.DataType.INT8:return a.getInt8(o);case ne.onnx.TensorProto.DataType.UINT16:return a.getUint16(o,!0);case ne.onnx.TensorProto.DataType.INT16:return a.getInt16(o,!0);case ne.onnx.TensorProto.DataType.FLOAT:return a.getFloat32(o,!0);case ne.onnx.TensorProto.DataType.INT32:return a.getInt32(o,!0);case ne.onnx.TensorProto.DataType.UINT32:return a.getUint32(o,!0);case ne.onnx.TensorProto.DataType.INT64:return hi(Vt.fromBits(a.getUint32(o,!0),a.getUint32(o+4,!0),!1),t);case ne.onnx.TensorProto.DataType.DOUBLE:return a.getFloat64(o,!0);case ne.onnx.TensorProto.DataType.UINT64:return hi(Vt.fromBits(a.getUint32(o,!0),a.getUint32(o+4,!0),!0),t);default:throw new Error(`cannot read from DataView for type ${ne.onnx.TensorProto.DataType[t]}`)}}var ku,ne,di,$e,yr=L(()=>{"use strict";ku=Ar(Os());Zo();tn();ne=Ar(Cr());fe();di=V.experimental.fbs,$e=class a{constructor(t,o,e,r,n,s=ku.Guid.create()){this.dims=t;this.type=o;this.dataProvider=e;this.asyncDataProvider=r;this.cache=n;this.dataId=s;this.size=U.validateDimsAndCalcSize(t);let i=this.size,u=e===void 0&&r===void 0&&n===void 0;if(n!==void 0&&n.length!==i)throw new RangeError("Input dims doesn't match data length.");if(o==="string"){if(n!==void 0&&(!Array.isArray(n)||!n.every(l=>typeof l=="string")))throw new TypeError("cache should be a string array");u&&(this.cache=new Array(i))}else{if(n!==void 0){let l=Bu(o);if(!(n instanceof l))throw new TypeError(`cache should be type ${l.name}`)}if(u){let l=new ArrayBuffer(i*Hd(o));this.cache=qd(l,o)}}}get data(){if(this.cache===void 0){let t=this.dataProvider(this.dataId);if(t.length!==this.size)throw new Error("Length of data provided by the Data Provider is inconsistent with the dims of this Tensor.");this.cache=t}return this.cache}get stringData(){if(this.type!=="string")throw new TypeError("data type is not string");return this.data}get integerData(){switch(this.type){case"uint8":case"int8":case"uint16":case"int16":case"int32":case"uint32":case"bool":return this.data;default:throw new TypeError("data type is not integer (uint8, int8, uint16, int16, int32, uint32, bool)")}}get floatData(){switch(this.type){case"float32":case"float64":return this.data;default:throw new TypeError("data type is not float (float32, float64)")}}get numberData(){if(this.type!=="string")return this.data;throw new TypeError("type cannot be non-number (string)")}get(t){return this.data[U.indicesToOffset(t,this.strides)]}set(t,o){this.data[U.indicesToOffset(t,this.strides)]=o}async getData(){return this.cache===void 0&&(this.cache=await this.asyncDataProvider(this.dataId)),this.cache}get strides(){return this._strides||(this._strides=U.computeStrides(this.dims)),this._strides}static fromProto(t){if(!t)throw new Error("cannot construct Value from an empty tensor");let o=We.tensorDataTypeFromProto(t.dataType),e=We.tensorDimsFromProto(t.dims),r=new a(e,o);if(o==="string")t.stringData.forEach((n,s)=>{r.data[s]=sn(n)});else if(t.rawData&&typeof t.rawData.byteLength=="number"&&t.rawData.byteLength>0){let n=r.data,s=new DataView(t.rawData.buffer,t.rawData.byteOffset,t.rawData.byteLength),i=Fu(t.dataType),u=t.rawData.byteLength/i;if(t.rawData.byteLength%i!==0)throw new Error("invalid buffer length");if(n.length!==u)throw new Error("buffer length mismatch");for(let l=0;l<u;l++){let c=$u(s,t.dataType,l*i);n[l]=c}}else{let n;switch(t.dataType){case ne.onnx.TensorProto.DataType.FLOAT:n=t.floatData;break;case ne.onnx.TensorProto.DataType.INT32:case ne.onnx.TensorProto.DataType.INT16:case ne.onnx.TensorProto.DataType.UINT16:case ne.onnx.TensorProto.DataType.INT8:case ne.onnx.TensorProto.DataType.UINT8:case ne.onnx.TensorProto.DataType.BOOL:n=t.int32Data;break;case ne.onnx.TensorProto.DataType.INT64:n=t.int64Data;break;case ne.onnx.TensorProto.DataType.DOUBLE:n=t.doubleData;break;case ne.onnx.TensorProto.DataType.UINT32:case ne.onnx.TensorProto.DataType.UINT64:n=t.uint64Data;break;default:throw new Error("unspecific error")}if(n==null)throw new Error("failed to populate data from a tensorproto value");let s=r.data;if(s.length!==n.length)throw new Error("array length mismatch");for(let i=0;i<n.length;i++){let u=n[i];Vt.isLong(u)?s[i]=hi(u,t.dataType):s[i]=u}}return r}static fromData(t,o,e){return new a(o,e,void 0,void 0,t)}static fromOrtTensor(t){if(!t)throw new Error("cannot construct Value from an empty tensor");let o=We.tensorDimsFromORTFormat(t),e=We.tensorDataTypeFromProto(t.dataType()),r=new a(o,e);if(e==="string")for(let n=0;n<t.stringDataLength();n++)r.data[n]=t.stringData(n);else if(t.rawDataArray()&&typeof t.rawDataLength()=="number"&&t.rawDataLength()>0){let n=r.data,s=new DataView(t.rawDataArray().buffer,t.rawDataArray().byteOffset,t.rawDataLength()),i=Fu(t.dataType()),u=t.rawDataLength()/i;if(t.rawDataLength()%i!==0)throw new Error("invalid buffer length");if(n.length!==u)throw new Error("buffer length mismatch");for(let l=0;l<u;l++){let c=$u(s,t.dataType(),l*i);n[l]=c}}return r}}});function H(a){return a===1?jd:Yd}function Nu(a){let t=H(a);return`${t.version}
      precision highp float;
      ${t.attribute} vec3 position;
      ${t.attribute} vec2 textureCoord;

      ${t.varyingVertex} vec2 TexCoords;

      void main()
      {
          gl_Position = vec4(position, 1.0);
          TexCoords = textureCoord;
      }`}function Ru(a){let t=H(a);return`${t.version}
    precision highp float;
    precision highp int;
    precision highp sampler2D;
    ${t.varyingFrag} vec2 TexCoords;
    ${t.outputDeclaration}
    const vec2 halfCR = vec2(0.5, 0.5);

    // Custom vector types to handle higher dimenalities.
    struct ivec5
    {
      int x;
      int y;
      int z;
      int w;
      int u;
    };

    struct ivec6
    {
      int x;
      int y;
      int z;
      int w;
      int u;
      int v;
    };

    int imod(int x, int y) {
      return x - y * (x / y);
    }

    `}function Mu(a,t){let o=H(a);return`
  void main() {
    int indices[${t}];
    toVec(TexCoords, indices);
    vec4 result = vec4(process(indices));
    ${o.output} = result;
  }
  `}var jd,Yd,we=L(()=>{"use strict";jd={version:"",attribute:"attribute",varyingVertex:"varying",varyingFrag:"varying",texture2D:"texture2D",output:"gl_FragColor",outputDeclaration:""},Yd={version:"#version 300 es",attribute:"in",varyingVertex:"out",varyingFrag:"in",texture2D:"texture",output:"outputColor",outputDeclaration:"out vec4 outputColor;"}});var ae=L(()=>{"use strict"});async function mi(a,t=e=>0,o){return new Promise((e,r)=>{let n=0,s=()=>{if(a()){e();return}n++;let i=t(n);if(o!=null&&n>=o){r();return}setTimeout(s,i)};s()})}function Yn(a){return Fr(typeof a<"u"&&a.length!==0,()=>"empty string found for sampler name"),"get"+a.charAt(0).toUpperCase()+a.slice(1)}function Gu(a){return Fr(typeof a<"u"&&a.length!==0,()=>"empty string found for sampler name"),"get"+a.charAt(0).toUpperCase()+a.slice(1)+"AtOutCoords"}function $r(a,t){let o=JSON.parse(JSON.stringify(a));return o=t,o}function kr(a,t){return t.map(o=>a[o]).join(", ")}function Qe(a){if(a<=1)return"int";if(a===2)return"ivec2";if(a===3)return"ivec3";if(a===4)return"ivec4";if(a===5)return"ivec5";if(a===6)return"ivec6";throw Error(`GPU for rank ${a} is not yet supported`)}function Dt(a=6){return["x","y","z","w","u","v"].slice(0,a)}var Bt=L(()=>{"use strict";fe()});function Xd(a,t){return Dt(t).map(o=>`${a}.${o}`)}function Br(a,t){return t===1?[a]:Xd(a,t)}function Nt(){return`
    float getChannel(vec4 frag, int dim) {
      int modCoord = imod(dim, 2);
      return modCoord == 0 ? frag.r : frag.g;
    }

    float getChannel(vec4 frag, vec2 innerDims) {
      vec2 modCoord = mod(innerDims, 2.);
      return modCoord.x == 0. ?
        (modCoord.y == 0. ? frag.r : frag.g) :
        (modCoord.y == 0. ? frag.b : frag.a);
    }
  `}var Tr=L(()=>{"use strict";Bt()});function Jd(a,t,o){if(a===0)return"false";if(a===1)return`rc > ${t[0]}`;let e="";for(let r=a-2;r<a;r++)e+=`${o[r]} >= ${t[r-a+2]}`,r<a-1&&(e+="||");return e}function Zd(a,t){let o=a.length;if(o===0)return"getA(), 0, 0, 0";if(o===1)return`getA(rc),
            rc + 1 >= ${a[0]} ? 0. : getA(rc + 1),
            0, 0`;let e="r, c",r="r, cp1",n="rp1, c",s="rp1, cp1",i="";if(o>2)for(let u=0;u<o-2;++u)i=i+`${t[u]},`;return`getA(${i}${e}),
          rEdge ? 0. : getA(${i}${n}),
          cEdge ? 0. : getA(${i}${r}),
          rEdge || cEdge ? 0. : getA(${i}${s})`}function Qd(a,t,o,e){return a===0||a===1?"":`
    int r = ${t[a-2]};
    int c = ${t[a-1]};
    int rp1 = ${t[a-2]} + 1;
    int cp1 = ${t[a-1]} + 1;
    bool rEdge = rp1 >= ${e};
    bool cEdge = cp1 >= ${o};
    `}var Uu,Kd,zu,Vu=L(()=>{"use strict";we();ae();Bt();Tr();Uu={name:"pack",inputNames:["A"],inputTypes:[1]},Kd=(a,t)=>{let o=H(a.session.backend.glContext.version),e=t.dims,r=e.length,n=t.dims.length,s=Qe(n),i=Br("rc",n),u=Qd(n,i,e[e.length-2],e[e.length-1]),l;r===0?l=[1,1]:r===1?l=[e[0],1]:l=[e[n-1],e[n-2]];let c=Jd(n,l,i),p=Zd(e,i),d=`
        void main() {
          ${s} rc = getOutputCoords();

          if(${c}) {
            ${o.output} = vec4(0);
          } else {
            ${u}

            ${o.output} = vec4(${p});
          }
        }
      `;return{...Uu,hasMain:!0,output:{dims:t.dims,type:t.type,textureType:2},shaderSource:d}},zu=(a,t)=>({...Uu,get:()=>Kd(a,t)})});function bi(a){if(a.length===0)return[1,1,1];let t=1;for(let o=0;o<a.length-2;++o)t*=a[o];return[t,a.length>1?a[a.length-2]:1,a[a.length-1]]}function Hu(a,t){let o=!1;return a.length===0||t.length===0?o=!0:a.length<2||t.length<2?o=a[a.length-1]===t[t.length-1]:o=a[a.length-1]===t[t.length-1]&&a[a.length-2]===t[t.length-2],o}function rh(a){let t=U.computeStrides(a),o=["b","r","c"],e="index";return`
    ivec3 inputCoordsFromReshapedOutCoords(int index) {
      ${t.map((n,s)=>{let i=`int ${o[s]} = ${e} / ${n}`,u=s===t.length-1?`int ${o[s+1]} = ${e} - ${o[s]} * ${n}`:`index -= ${o[s]} * ${n}`;return`${i}; ${u};`}).join("")}
      return ivec3(b, r, c);
    }
  `}function nh(a){let t=U.computeStrides(a);return`
  int getFlattenedIndex(ivec3 coords) {
    // reverse y, z order
    return coords.x * ${t[0]} + coords.z * ${t[1]} + coords.y;
  }
`}var eh,th,Wu,qu=L(()=>{"use strict";fe();we();ae();Tr();eh=a=>({name:"Reshape (packed)",inputTypes:[2],inputNames:["A"],cacheHint:`${a}`}),th=(a,t,o,e)=>{let r=t.dims,n=e,s="";for(let l=0;l<4;l++){let c="";switch(l){case 0:c="outputCoords = rc;";break;case 1:c="outputCoords = ivec3(rc.x, rc.y+1, rc.z);";break;case 2:c="outputCoords = ivec3(rc.x, rc.y, rc.z+1);";break;case 3:c="outputCoords = ivec3(rc.x, rc.y+1, rc.z+1);";break;default:throw new Error}s+=`
        ${c}
        ${l>0?"if(outputCoords.y < rows && outputCoords.z < cols){":""}
          int flattenedIndex = getFlattenedIndex(outputCoords);

          ivec3 inputRC = inputCoordsFromReshapedOutCoords(flattenedIndex);
          vec2 innerDims = vec2(float(inputRC.y),float(inputRC.z));

          result[${l}] = getChannel(getA(inputRC.x, inputRC.y, inputRC.z), innerDims);

        ${l>0?"}":""}
      `}let i=H(a.session.backend.glContext.version),u=`
      ${rh(r)}
      ${nh(n)}
      ${Nt()}

      void main() {
        ivec3 rc = getOutputCoords();

        vec4 result = vec4(0.0);

        ivec3 outputCoords;
        int rows = ${n[2]};
        int cols = ${n[1]};

        ${s}
        ${i.output} = result;
      }
    `;return{...o,output:{dims:n,type:t.type,textureType:2},shaderSource:u,hasMain:!0}},Wu=(a,t,o)=>{let e=eh(o);return{...e,get:()=>th(a,t,e,o)}}});var gi,ju=L(()=>{"use strict";we();ae();gi=(a,t)=>{let o=t.shape,e=H(a.session.backend.glContext.version),r=`
    const float FLOAT_MAX = 1.70141184e38;
    const float FLOAT_MIN = 1.17549435e-38;

    bool isNaN(float val) {
      return (val < 1.0 || 0.0 < val || val == 0.0) ? false : true;
    }

    highp vec4 encodeAsUint8(highp float v) {
      if (isNaN(v)) {
        return vec4(255, 255, 255, 255);
      }

      highp float av = abs(v);

      if(av < FLOAT_MIN) {
        return vec4(0.0, 0.0, 0.0, 0.0);
      } else if(v > FLOAT_MAX) {
        return vec4(0.0, 0.0, 128.0, 127.0) / 255.0;
      } else if(v < -FLOAT_MAX) {
        return vec4(0.0, 0.0,  128.0, 255.0) / 255.0;
      }

      highp vec4 c = vec4(0,0,0,0);

      highp float e = floor(log2(av));
      highp float m = exp2(fract(log2(av))) - 1.0;

      c[2] = floor(128.0 * m);
      m -= c[2] / 128.0;
      c[1] = floor(32768.0 * m);
      m -= c[1] / 32768.0;
      c[0] = floor(8388608.0 * m);

      highp float ebias = e + 127.0;
      c[3] = floor(ebias / 2.0);
      ebias -= c[3] * 2.0;
      c[2] += floor(ebias) * 128.0;

      c[3] += 128.0 * step(0.0, -v);

      return c / 255.0;
    }

    void main() {
      float value = ${e.texture2D}(X,TexCoords).r;
      ${e.output} = encodeAsUint8(value);
    }`,n={name:"Uint8Encode",inputTypes:[0],inputNames:["X"],output:{dims:o,type:t.tensor.type,textureType:3},shaderSource:r,hasMain:!0};return a.executeProgram(n,[t.tensor])}});function ih(a,t){if(a===1)return"rc";let o="";for(let e=0;e<a;e++)o+=t[e],e<a-1&&(o+=",");return o}var Yu,oh,Xu,Ku=L(()=>{"use strict";we();ae();Bt();Tr();Yu={name:"unpack",inputNames:["A"],inputTypes:[2]},oh=(a,t)=>{let o=t.dims.length,e=Br("rc",o),r=e.slice(-2),n=Qe(o),s=Nt(),u=t.dims.length===0?"":ih(o,e),l=o<=1?"rc":`vec2(${r.join(",")})`,c=H(a.session.backend.glContext.version),p=`
    ${s}
    void main() {
      ${n} rc = getOutputCoords();

       // Sample the texture with the coords to get the rgba channel value.
       vec4 packedInput = getA(${u});

       ${c.output} = vec4(getChannel(packedInput, ${l}), 0, 0, 0);
     }
   `;return{...Yu,hasMain:!0,output:{dims:t.dims,type:t.type,textureType:0},shaderSource:p}},Xu=(a,t)=>({...Yu,get:()=>oh(a,t)})});var Xn,un,Kn,ln=L(()=>{"use strict";lt();Xn=class{constructor(t,o=1){if(o===1)this.internalFormat=t.R32F,this.format=t.RED,this.textureType=t.FLOAT,this.channelSize=o;else if(o===4)this.internalFormat=t.RGBA32F,this.format=t.RGBA,this.textureType=t.FLOAT,this.channelSize=o;else throw new Error(`Invalid number of channels: ${o}`)}encode(t,o){let e,r;return t.constructor!==Float32Array&&(ce.warning("Encoder","data was not of type Float32; creating new Float32Array"),r=new Float32Array(t)),o*this.channelSize>t.length?(ce.warning("Encoder","Source data too small. Allocating larger array"),r=t,e=this.allocate(o*this.channelSize),r.forEach((n,s)=>e[s]=n)):(r=t,e=r),e}allocate(t){return new Float32Array(t*4)}decode(t,o){return this.channelSize===1?t.filter((r,n)=>n%4===0).subarray(0,o):t.subarray(0,o)}},un=class{constructor(t,o=1,e){if(o!==1&&o!==4)throw new Error(`Invalid number of channels: ${o}`);this.internalFormat=t.RGBA,this.format=t.RGBA,this.channelSize=o,this.textureType=e||t.FLOAT}encode(t,o){let e=t;return this.channelSize===1&&(ce.verbose("Encoder","Exploding into a larger array"),e=this.allocate(o),t.forEach((r,n)=>e[n*4]=r)),e}allocate(t){return new Float32Array(t*4)}decode(t,o){return this.channelSize===1?t.filter((r,n)=>n%4===0).subarray(0,o):t.subarray(0,o)}},Kn=class{constructor(t,o=1){this.channelSize=4;if(o===1)this.internalFormat=t.ALPHA,this.format=t.ALPHA,this.textureType=t.UNSIGNED_BYTE,this.channelSize=o;else if(o===4)this.internalFormat=t.RGBA,this.format=t.RGBA,this.textureType=t.UNSIGNED_BYTE,this.channelSize=o;else throw new Error(`Invalid number of channels: ${o}`)}encode(t,o){return new Uint8Array(t.buffer,t.byteOffset,t.byteLength)}allocate(t){return new Uint8Array(t*this.channelSize)}decode(t,o){if(t instanceof Uint8Array)return t.subarray(0,o);throw new Error(`Invalid array type: ${t.constructor}`)}}});var fn,Ju,yi,Zu=L(()=>{"use strict";fe();ae();fn=(a,t,o)=>{let e=o===0||o===1?1:4,r=o===2,n=o===1||o===2,s=o===4?t.length-1:void 0,i=o===4?t.map((u,l)=>l===t.length-1?u*4:u):void 0;return yi(a,t,e,i,{isPacked:r,reverseWH:n,breakAxis:s})},Ju=(a,t,o)=>{let e=fn(a,t,o);return[e.width,e.height]},yi=(a,t,o=1,e,r)=>{let n=!!(r&&r.isPacked),[s,i]=a.computeTextureWH(n&&e||t,r),u=t.length,l=t.slice(0);if(u===0&&(l=[1]),o===1)e=t;else if(n){if(o!==4)throw new Error("a packed texture must be 4-channel");e=t,u>0&&(l[u-1]=Math.ceil(l[u-1]/2)),u>1&&(l[u-2]=Math.ceil(l[u-2]/2))}else if(!e)throw new Error("Unpacked shape is needed when using channels > 1");return{width:s,height:i,channels:o,isPacked:n,shape:l,strides:U.computeStrides(l),unpackedShape:e,reversedWH:r&&r.reverseWH}}});var sh,Jn,el=L(()=>{"use strict";lt();yr();fe();Vu();qu();ju();Ku();ln();Zu();ae();sh=(a,t)=>{let o=t.map(r=>`${r.unpackedShape.join(",")};${r.width}x${r.height}`).join("_"),e=a.name;return a.cacheHint&&(e+="["+a.cacheHint+"]"),e+=":"+o,e},Jn=class{constructor(t){this.session=t;this.packedTextureDataCache=new Map,this.unpackedTextureDataCache=new Map}calculateTextureWidthAndHeight(t,o){return Ju(this.session.layoutStrategy,t,o)}executeProgram(t,o){if(o.length<t.inputNames.length)throw new Error(`Input size mustn't be less than ${t.inputNames.length}.`);if(t.inputNames.length!==t.inputTypes.length)throw new Error("input names size does not match input types");let e=[];for(let l=0;l<t.inputNames.length;++l)e[l]=this.getOrCreateTextureData(o[l],t.inputTypes[l]);let r=sh(t,e),n=this.session.programManager.getArtifact(r),s=n?n.programInfo:typeof t.get=="function"?t.get():t,i=fn(this.session.layoutStrategy,s.output.dims,s.output.textureType),u=this.createTextureData(i,s.output.type);return n||(n=this.session.programManager.build(s,e,u),this.session.programManager.setArtifact(r,n)),this.runProgram(n,e,u),u}run(t,o){return this.executeProgram(t,o).tensor}runProgram(t,o,e){for(let r=0;r<o.length;++r)if(!!o[r].isPacked!=(t.programInfo.inputTypes[r]===2))throw new Error(`input[${r}] property packed inconsistent`);if(!!e.isPacked!=(t.programInfo.output.textureType===2))throw new Error("output property packed inconsistent");this.session.programManager.run(t,o,e)}getOrCreateTextureData(t,o){let e=this.getTextureData(t.dataId,o===2);if(!e&&(e=this.getTextureData(t.dataId,o!==2),e))return o===2?this.pack(e):this.unpack(e);if(!e){let r=fn(this.session.layoutStrategy,t.dims,o);if(o===4){let i=t.dims;if(i.length===4){let u=[i[0],Math.ceil(i[1]*i[2]*i[3]/4)],l=fn(this.session.layoutStrategy,u,o),c=t.numberData;if(i[1]*i[2]*i[3]%4!==0){let p=i[0],d=i[1]*i[2]*i[3],T=Math.ceil(d*1/4)*4,w=p*T;c=new Float32Array(w);for(let v=0;v<p;++v){let S=v*d,A=v*T+v%1*d;c.set(t.numberData.subarray(S,S+d),A)}}return this.createTextureData(l,t.type,c,t,1)}}if(o===2){let n=yi(this.session.layoutStrategy,t.dims,1,[],{reverseWH:!0}),s=this.createTextureData(n,t.type,t.numberData,t,1);e=this.pack(s)}else e=this.createTextureData(r,t.type,t.numberData,t,1)}return e}createTextureDataFromLayoutBindTensor(t,o,e,r){return this.createTextureData(t,o,e,r,1)}createTextureData(t,o,e,r,n){ce.verbose("InferenceHandler",`Creating TextureData: layout:[${JSON.stringify(t)}]`);let s=this.session.textureManager.createTextureFromLayout(o,t,e,n);return this.createTextureDataFromTexture(t,o,s,r)}reshapeUnpacked(t,o){let e=this.getOrCreateTextureData(t,0),r={channels:e.channels,height:e.height,width:e.width,shape:o.length!==0?o:[1],strides:U.computeStrides(o),unpackedShape:o};return this.createTextureDataFromTexture(r,t.type,e.texture).tensor}reshapePacked(t,o){let e=this.getOrCreateTextureData(t,2);if(Hu(t.dims,o)){let l={channels:e.channels,height:e.height,width:e.width,shape:o.length!==0?o:[1],strides:U.computeStrides(o),unpackedShape:o,isPacked:!0};return this.createTextureDataFromTexture(l,t.type,e.texture).tensor}let r=bi(t.dims),n=bi(o),s=this.reshapePacked(t,r),i=this.run(Wu(this,s,n),[s]);return this.reshapePacked(i,o)}cast(t,o){let e=this.getOrCreateTextureData(t,0);return this.createTextureDataFromTexture(e,o,e.texture).tensor}createTextureDataFromTexture(t,o,e,r,n){let s={...t,tensor:r||new $e(t.unpackedShape,o,i=>this.readTexture(s),async i=>this.readTextureAsync(s),void 0,n),texture:e};return this.setTextureData(s.tensor.dataId,s,t.isPacked),s}getTextureData(t,o=!1){return this.session.isInitializer(t)?this.session.getTextureData(t,o):o?this.packedTextureDataCache.get(t):this.unpackedTextureDataCache.get(t)}setTextureData(t,o,e=!1){this.session.isInitializer(t)?this.session.setTextureData(t,o,e):(e?this.packedTextureDataCache:this.unpackedTextureDataCache).set(t,o)}isTextureLayoutCached(t,o=!1){return!!this.getTextureData(t.dataId,o)}dispose(){this.session.textureManager.clearActiveTextures(),this.packedTextureDataCache.forEach(t=>this.session.textureManager.releaseTexture(t)),this.packedTextureDataCache=new Map,this.unpackedTextureDataCache.forEach(t=>this.session.textureManager.releaseTexture(t)),this.unpackedTextureDataCache=new Map}readTexture(t){return t.isPacked?this.readTexture(this.unpack(t)):this.session.backend.glContext.isFloat32DownloadSupported?this.session.textureManager.readTexture(t,t.tensor.type,t.channels):this.session.textureManager.readUint8TextureAsFloat(gi(this,t))}async readTextureAsync(t){return t.isPacked?this.readTextureAsync(this.unpack(t)):this.session.backend.glContext.isFloat32DownloadSupported?this.session.textureManager.readTextureAsync(t,t.tensor.type,t.channels):this.session.textureManager.readUint8TextureAsFloat(gi(this,t))}pack(t){return this.executeProgram(zu(this,t.tensor),[t.tensor])}unpack(t){return this.executeProgram(Xu(this,t.tensor),[t.tensor])}}});var Ti,Q,Ue=L(()=>{"use strict";Ti=class{constructor(t){Object.assign(this,t)}get cacheKey(){return this.key||(this.key=Object.getOwnPropertyNames(this).sort().map(t=>`${this[t]}`).join(";")),this.key}},Q=a=>new Ti(a)});var tl,rl,nl,uh,lh,ol=L(()=>{"use strict";Ue();we();ae();tl={name:"BatchNormalization",inputNames:["A","Scale","B","Mean","Variance"],inputTypes:[0,0,0,0,0]},rl=(a,t,o)=>(lh(t),[a.run({...tl,cacheHint:o.cacheKey,get:()=>uh(a,t,o)},t)]),nl=a=>{let t=a.attributes.getFloat("epsilon",1e-5),o=a.attributes.getFloat("momentum",.9),e=a.attributes.getInt("spatial",1);return Q({epsilon:t,momentum:o,spatial:e})},uh=(a,t,o)=>{let e=H(a.session.backend.glContext.version),r=t[0].dims.length,[n,s]=a.calculateTextureWidthAndHeight(t[1].dims,0),i=`
  float process(int[${r}] indices) {
    vec2 position = offsetToCoords(indices[1], ${n}, ${s});
    float scale = getColorAsFloat(${e.texture2D}(Scale, position));
    float mean = getColorAsFloat(${e.texture2D}(Mean, position));
    float variance = getColorAsFloat(${e.texture2D}(Variance, position));
    float b = getColorAsFloat(${e.texture2D}(B, position));

    return scale * ( (_A(indices) - mean) / sqrt(variance + float(${o.epsilon})) ) + b;
  }`;return{...tl,output:{dims:t[0].dims,type:t[0].type,textureType:0},shaderSource:i}},lh=a=>{if(!a||a.length!==5)throw new Error("BatchNormalization requires 5 inputs.");let t=a[0],o=a[1],e=a[2],r=a[3],n=a[4];if(t.dims.length<3||o.dims.length!==1||e.dims.length!==1||r.dims.length!==1||n.dims.length!==1)throw new Error("invalid input shape.");if(o.dims[0]!==t.dims[1]||e.dims[0]!==t.dims[1]||r.dims[0]!==t.dims[1]||n.dims[0]!==t.dims[1])throw new Error("invalid input shape.");if(t.type!=="float32"&&t.type!=="float64"||o.type!=="float32"&&o.type!=="float64"||e.type!=="float32"&&e.type!=="float64"||r.type!=="float32"&&r.type!=="float64"||n.type!=="float32"&&n.type!=="float64")throw new Error("invalid input tensor types.")}});var Zn,dt,R,cn,Qn,Wt=L(()=>{"use strict";Zn=class{constructor(t,o,e,r){this.glContext=t;this.programInfo=o;this.inputTextureLayouts=e;this.outputTextureLayout=r}},dt=class{constructor(t){this.context=t}},R=class{constructor(t,o){this.routineBody=t;this.dependencies=o}},cn=class{constructor(t,o,e){this.name=t;e?this.dependencies=e:this.dependencies=[],o&&(this.routineBody=o)}addDependency(t){t&&this.dependencies.push(t)}},Qn=class{static returnOrderedNodes(t){if(!t||t.length===0)return[];if(t.length===1)return t;let o=new Set,e=new Set,r=new Array;return this.createOrderedNodes(t,o,e,r),r}static createOrderedNodes(t,o,e,r){for(let n=0;n<t.length;++n)this.dfsTraverse(t[n],o,e,r)}static dfsTraverse(t,o,e,r){if(!t||e.has(t.name))return;if(o.has(t.name))throw new Error("Cyclic dependency detected. Can't topologically sort routines needed for shader.");o.add(t.name);let n=t.dependencies;if(n&&n.length>0)for(let s=0;s<n.length;++s)this.dfsTraverse(n[s],o,e,r);r.push(t),e.add(t.name),o.delete(t.name)}}});function ch(){let a="add_";return{body:`
  float ${a}(float a, float b) {
    return a + b;
  }
  vec4 ${a}(vec4 v1, vec4 v2) {
    return v1 + v2;
  }
  `,name:a,type:0}}function ph(){let a="div_";return{body:`
  float ${a}(float a, float b) {
    return a / b;
  }
  vec4 ${a}(vec4 v1, vec4 v2) {
    return v1 / v2;
  }
  `,name:a,type:0}}function dh(){let a="mul_";return{body:`
  float ${a}(float a, float b) {
    return a * b;
  }
  vec4 ${a}(vec4 v1, vec4 v2) {
    return v1 * v2;
  }
  `,name:a,type:0}}function hh(){let a="sub_";return{body:`
  float ${a}(float a, float b) {
    return a - b;
  }
  vec4 ${a}(vec4 v1, vec4 v2) {
    return v1 - v2;
  }
  `,name:a,type:0}}function mh(){let a="equal_";return{body:`
  float ${a}(float a, float b) {
    return float(a == b);
  }
  vec4 ${a}(vec4 v1, vec4 v2) {
    return vec4(equal(v1, v2));
  }
  `,name:a,type:0}}function bh(){let a="greater_";return{body:`
  float ${a}(float a, float b) {
    return float(a > b);
  }
  vec4 ${a}(vec4 v1, vec4 v2) {
    return vec4( v1.r > v2.r ,
      v1.g > v2.g,
      v1.b > v2.b,
      v1.a > v2.a );
  }
  `,name:a,type:0}}function gh(){let a="less_";return{body:`
  float ${a}(float a, float b) {
    return float(a < b);
  }
  vec4 ${a}(vec4 v1, vec4 v2) {
    return vec4( v1.r < v2.r ,
                v1.g < v2.g,
                v1.b < v2.b,
                v1.a < v2.a );
  }
  `,name:a,type:0}}function yh(){let a="and_";return{body:`
  float ${a}(float a, float b) {
    return float( bool(a) && bool(b) );
  }
  vec4 ${a}(vec4 v1, vec4 v2) {
    bvec4 b1 = bvec4(v1);
    bvec4 b2 = bvec4(v2);
    return vec4( b1.r && b2.r ,
                b1.g && b2.g,
                b1.b && b2.b,
                b1.a && b2.a );
  }
  `,name:a,type:0}}function Th(){let a="or_";return{body:`
  float ${a}(float a, float b) {
    return float( bool(a) || bool(b) );
  }
  vec4 ${a}(vec4 v1, vec4 v2) {
    bvec4 b1 = bvec4(v1);
    bvec4 b2 = bvec4(v2);
    return vec4( b1.r || b2.r ,
                b1.g || b2.g,
                b1.b || b2.b,
                b1.a || b2.a );
  }
  `,name:a,type:0}}function xh(){let a="xor_";return{body:`
  float ${a}(float a, float b) {
    return float( bool(a) ^^ bool(b) );
  }
  vec4 ${a}(vec4 v1, vec4 v2) {
    bvec4 b1 = bvec4(v1);
    bvec4 b2 = bvec4(v2);
    return vec4( b1.r ^^ b2.r ,
                b1.g ^^ b2.g,
                b1.b ^^ b2.b,
                b1.a ^^ b2.a );
  }
  `,name:a,type:0}}function wh(){return _h("pow")}function vh(){let a="prelu_";return{body:`
  float ${a}(float a, float b) {
    return a < 0.0 ? a * b: a;
  }
  vec4 ${a}(vec4 v1, vec4 v2) {
    return vec4(
      v1.r < 0.0 ? v1.r * v2.r: v1.r,
      v1.g < 0.0 ? v1.g * v2.g: v1.g,
      v1.b < 0.0 ? v1.b * v2.b: v1.b,
      v1.a < 0.0 ? v1.a * v2.a: v1.a
      );
  }
  `,name:a,type:0}}function _h(a){let t=`${a}_`;return{body:`
  float ${t}(float a, float b) {
    return ${a}(a, b);
  }
  vec4 ${t}(vec4 v1, vec4 v2) {
    return ${a}(v1, v2);
  }
  `,name:t,type:0}}var ht,Oh,il,al,sl,ul,ll,fl,cl,pl,dl,hl,ml,bl,gl=L(()=>{"use strict";fe();Wt();we();ae();ht=(a,t,o,e=t[0].type,r)=>{let n=a.session.pack?2:0;return{name:o.name,inputNames:["A","B"],inputTypes:[n,n],cacheHint:r,get:()=>Oh(a,t,o,e)}},Oh=(a,t,o,e=t[0].type)=>{let r=a.session.pack?2:0,n=!U.areEqual(t[0].dims,t[1].dims),s=t[0].dims,i=a.session.pack;if(n){let c=Ze.calcShape(t[0].dims,t[1].dims,!1);if(!c)throw new Error("Can't perform binary op on the given tensors");s=c;let p=s.length,d=t[0].dims.length!==0?t[0].dims.length:1,T=t[1].dims.length!==0?t[1].dims.length:1,w=t[0].dims.length!==0?"bcastIndices_A(indices, aindices);":"aindices[0] = 0;",v=t[1].dims.length!==0?"bcastIndices_B(indices, bindices);":"bindices[0] = 0;",S=H(a.session.backend.glContext.version),A=i?`
      ${o.body}
      void main() {
        vec4 a = getAAtOutCoords();
        vec4 b = getBAtOutCoords();
        vec4 result = ${o.name}(a, b);
        ${S.output} = result;
      }`:`
      ${o.body}
      float process(int indices[${p}]) {
        int aindices[${d}];
        int bindices[${T}];
        ${w}
        ${v}
        return ${o.name}(_A(aindices), _B(bindices));
      }`;return{name:o.name,inputNames:["A","B"],inputTypes:[r,r],output:{dims:s,type:e,textureType:r},shaderSource:A,hasMain:i}}let u=H(a.session.backend.glContext.version),l=`
    ${o.body}
    void main() {
      vec4 v1 = ${u.texture2D}(A, TexCoords);
      vec4 v2 = ${u.texture2D}(B, TexCoords);
      vec4 result = ${o.name}(v1, v2);
      ${u.output} = result;
    }
    `;return{name:o.name,inputNames:["A","B"],inputTypes:[r,r],output:{dims:t[0].dims,type:e,textureType:r},shaderSource:l,hasMain:!0}},il=(a,t)=>[a.run(ht(a,t,ch()),t)],al=(a,t)=>[a.run(ht(a,t,yh(),"bool"),t)],sl=(a,t)=>[a.run(ht(a,t,ph()),t)],ul=(a,t)=>[a.run(ht(a,t,mh(),"bool"),t)],ll=(a,t)=>[a.run(ht(a,t,bh(),"bool"),t)],fl=(a,t)=>[a.run(ht(a,t,gh(),"bool"),t)],cl=(a,t)=>[a.run(ht(a,t,dh()),t)],pl=(a,t)=>[a.run(ht(a,t,Th(),"bool"),t)],dl=(a,t)=>[a.run(ht(a,t,wh()),t)],hl=(a,t)=>[a.run(ht(a,t,vh()),t)],ml=(a,t)=>[a.run(ht(a,t,hh()),t)],bl=(a,t)=>[a.run(ht(a,t,xh(),"bool"),t)]});var yl,Tl,Sh,xl=L(()=>{"use strict";fe();yl=(a,t,o)=>(Sh(t),[a.cast(t[0],o)]),Tl=a=>We.tensorDataTypeFromProto(a.attributes.getInt("to")),Sh=a=>{if(!a||a.length!==1)throw new Error("Cast requires 1 input.");if(a[0].type==="string")throw new Error("Invalid input type.")}});var Ah,Ph,wl,eo,vl=L(()=>{"use strict";we();ae();Bt();Tr();Ah=(a,t)=>({name:"Concat (packed)",inputNames:Array.from({length:a},(o,e)=>`X${e}`),inputTypes:Array(a).fill(2),cacheHint:t}),Ph=(a,t,o,e)=>{let r=o[0].dims.slice();if(e>=r.length||e<-1*r.length)throw new Error("axis specified for concat doesn't match input dimensionality");e<0&&(e=r.length+e);let n=r.slice(0);for(let j=1;j<o.length;j++){let ie=o[j].dims.slice();for(let G=0;G<r.length;G++)if(G===e)n[e]+=ie[G];else if(r[G]!==ie[G])throw new Error("non concat dimensions must match")}let s=n.length,i=Br("coords",s),u=Qe(s),l=Nt(),c=o.map(j=>j.dims),p=Dt(s),d=new Array(c.length-1);d[0]=c[0][e];for(let j=1;j<d.length;j++)d[j]=d[j-1]+c[j][e];let T=p[e],w=p.slice(-2),v=p.join(),S=`if (${T} < ${d[0]}) {
        return getChannel(
            getX0(${v}), vec2(${w.join()}));
        }`;for(let j=1;j<d.length;j++){let ie=d[j-1];S+=`
            if (${T} < ${d[j]}  && ${T} >= ${d[j-1]}) {
              return getChannel(
                getX${j}(${eo(p,T,ie)}),
                vec2(${eo(w,T,ie)}));
            }`}let A=d.length,C=d[d.length-1];S+=`
            return getChannel(
              getX${A}(${eo(p,T,C)}),
              vec2(${eo(w,T,C)}));`;let F=H(a.session.backend.glContext.version),J=`
          ${l}
          float getValue(${p.map(j=>"int "+j)}) {
            ${S}
          }

          void main() {
            ${u} coords = getOutputCoords();
            int lastDim = coords.${p[s-1]};
            coords.${p[s-1]} = coords.${p[s-2]};
            coords.${p[s-2]} = lastDim;

            vec4 result = vec4(getValue(${i}), 0., 0., 0.);

            ${i[s-1]} = ${i[s-1]} + 1;
            if (${i[s-1]} < ${n[s-1]}) {
              result.g = getValue(${i});
            }

            ${i[s-2]} = ${i[s-2]} + 1;
            if (${i[s-2]} < ${n[s-2]}) {
              result.a = getValue(${i});
            }

            ${i[s-1]} = ${i[s-1]} - 1;
            if (${i[s-2]} < ${n[s-2]} &&
                ${i[s-1]} < ${n[s-1]}) {
              result.b = getValue(${i});
            }
            ${F.output} = result;
          }
        `;return{...t,output:{dims:n,type:o[0].type,textureType:2},shaderSource:J,hasMain:!0}},wl=(a,t,o)=>{let e=Ah(t.length,o.cacheKey);return{...e,get:()=>Ph(a,e,t,o.axis)}},eo=(a,t,o)=>{let e=a.indexOf(t);return a.map((n,s)=>s===e?`${n} - ${o}`:n).join()}});var _l,Eh,Dh,Lh,Ol,Ch,Fh,$h,Il,kh,Sl=L(()=>{"use strict";Ue();ae();vl();_l=(a,t,o)=>(kh(t),a.session.pack&&t[0].dims.length>1?[a.run(wl(a,t,o),t)]:[a.run(Lh(a,t,o),t)]),Eh=(a,t)=>({name:"Concat",inputNames:Array.from({length:a},(o,e)=>`X${e}`),inputTypes:Array(a).fill(0),cacheHint:t}),Dh=(a,t,o,e)=>{let r=o[0].dims.slice();if(e>=r.length||e<-1*r.length)throw new Error("axis specified for concat doesn't match input dimensionality");e<0&&(e=r.length+e);let n=r.slice(0);for(let T=1;T<o.length;T++){let w=o[T].dims.slice();for(let v=0;v<r.length;v++)if(v===e)n[e]+=w[v];else if(r[v]!==w[v])throw new Error("non concat dimensions must match")}let s=n.length,i=new Array(o.length),u=0;for(let T=0;T<i.length;++T)u+=o[T].dims[e],i[T]=u;let l="";o.length<5?l=Ol(i):l=Ch(i);let c=Fh(o.length,s),p=$h(i),d=`
        ${c}
        ${p}
        ${l}
        float process(int indices[${s}]) {
          int textureIndex = getTextureWhereDataResides (indices[${e}]);

          if(textureIndex != 0) {
            indices[${e}] = indices[${e}] - int(getSizeInConcatAxisValueFromIndex(textureIndex-int(1)));
          }

          return fetchDataFromCorrectTexture(textureIndex, indices);
        }`;return{...t,output:{dims:n,type:o[0].type,textureType:0},shaderSource:d}},Lh=(a,t,o)=>{let e=Eh(t.length,o.cacheKey);return{...e,get:()=>Dh(a,e,t,o.axis)}},Ol=a=>`int getTextureWhereDataResides(int index) {
      ${a.map((o,e)=>`if(index<${o}) {return ${e};}
`).join("")}
    }`,Ch=a=>Ol(a),Fh=(a,t)=>{let o=[`float fetchDataFromCorrectTexture(int textureIndex, int indices[${t}]) {`];for(let e=0;e<a;++e)e===0?o.push(`	if (textureIndex == ${e}) { return _X${e}(indices); }`):e===a-1?o.push(`	else { return _X${e}(indices); }`):o.push(`	else if (textureIndex == ${e}) { return _X${e}(indices); }`);return o.push("	}"),o.join(`
`)},$h=a=>{let t=["int getSizeInConcatAxisValueFromIndex(int index) {"];for(let o=0;o<a.length;++o)o===0?t.push(`	if (index == ${o}) { return ${a[o]}; }`):o===a.length-1?t.push(`	else { return ${a[o]}; }`):t.push(`	else if (index == ${o}) { return ${a[o]}; }`);return t.push("	}"),t.join(`
`)},Il=a=>Q({axis:a.attributes.getInt("axis")}),kh=a=>{if(!a||a.length<1)throw new Error("too few inputs");let t=a[0].type,o=a[0].dims.length;if(t==="string")throw new Error("string tensor is not supported yet");for(let e of a){if(e.type!==t)throw new Error("input tensors should be one type");if(e.dims.length!==o)throw new Error("input tensors should have the same shape")}}});function Bh(){return mt("abs")}function Nh(){return mt("acos")}function Rh(){return mt("asin")}function Mh(){return mt("atan")}function Gh(){return mt("ceil")}function Uh(){return mt("cos")}function zh(a){let t="elu";return{body:`
  const float alpha = float(${a});

  float ${t}_(float a) {
    return a >= 0.0 ? a: (exp(a) - 1.0) * alpha;
  }
  vec4 ${t}_(vec4 v) {
    return vec4(${t}_(v.x), ${t}_(v.y), ${t}_(v.z), ${t}_(v.w));
  }
  `,name:t,type:0}}function Vh(){return mt("exp")}function Wh(){return mt("floor")}function xi(a,t){let o="clip";return{body:`
  const float min = float(${a});
  const float max = float(${t});

  float ${o}_(float a) {
    return clamp(a, min, max);
  }
  vec4 ${o}_(vec4 v) {
    return clamp(v, min, max);
  }
  `,name:o,type:0}}function Hh(){let a="indentity";return{body:`
  float ${a}_(float a) {
    return a;
  }
  vec4 ${a}_(vec4 v) {
    return v;
  }
  `,name:a,type:0}}function qh(a){let t="leakyRelu";return{body:`
  const float alpha = float(${a});

  float ${t}_(float a) {
    return a < 0.0 ? a * alpha : a;
  }
  vec4 ${t}_(vec4 v) {
    return vec4(${t}_(v.x), ${t}_(v.y), ${t}_(v.z), ${t}_(v.w));
  }
  `,name:t,type:0}}function jh(){return mt("log")}function Yh(){let a="neg";return{body:`
  float ${a}_(float a) {
    return -a;
  }
  vec4 ${a}_(vec4 v) {
    return -v;
  }
  `,name:a,type:0}}function Xh(){let a="not";return{body:`
  float ${a}_(float a) {
    return float( ! bool(a) );
  }
  bool ${a}_(bool a) {
    return !a;
  }
  vec4 ${a}_(vec4 v) {
    return vec4(!bool(v.x), !bool(v.y), !bool(v.z), !bool(v.w));
  }
  bvec4 ${a}_(bvec4 v) {
    return bvec4(!v.x, !v.y, !v.z, !v.w);
  }
  `,name:a,type:0}}function Kh(){return mt("sin")}function wi(){let a="relu";return{body:`
  float ${a}_(float a) {
    return max( a, 0.0 );
  }
  vec4 ${a}_(vec4 v) {
    return max( v, 0.0 );
  }
  `,name:a,type:0}}function vi(){let a="sigmoid";return{body:`
  float ${a}_(float a) {
    return 1.0 / (1.0 + exp(-a));
  }
  vec4 ${a}_(vec4 v) {
    return 1.0 / (1.0 + exp(-v));
  }
  `,name:a,type:0}}function Jh(){return mt("sqrt")}function Zh(){return mt("tan")}function Qh(){let a="tanh";return{body:`
  float ${a}_(float a) {
    a = clamp(a, -10., 10.);
    a = exp(2.*a);
    return (a - 1.) / (a + 1.);
  }
  vec4 ${a}_(vec4 v) {
    v = clamp(v, -10., 10.);
    v = exp(2.*v);
    return (v - 1.) / (v + 1.);
  }
  `,name:a,type:0}}function mt(a){return{body:`
  float ${a}_(float a) {
    return ${a}(a);
  }
  vec4 ${a}_(vec4 v) {
    return ${a}(v);
  }
  `,name:a,type:0}}var em,Ee,Al,Pl,El,Dl,_i,Ll,Cl,tm,Fl,$l,kl,Bl,Nl,Rl,Oi,Ml,Gl,Ul,zl,Vl,Wl,Hl,ql,jl,Yl,Xl,Ii=L(()=>{"use strict";Ue();fe();Wt();we();ae();em=(a,t,o,e)=>{let r=a.session.pack?2:0,n=H(a.session.backend.glContext.version);return{...t,output:{dims:o.dims,type:o.type,textureType:r},shaderSource:`
     ${e.body}
     void main() {
       vec4 v = ${n.texture2D}(A, TexCoords);
       v = ${e.name}_(v);
       ${n.output} = v;
     }
     `,hasMain:!0}},Ee=(a,t,o,e)=>{let r=a.session.pack?2:0,n={name:o.name,inputTypes:[r],inputNames:["A"],cacheHint:e};return{...n,get:()=>em(a,n,t,o)}},Al=(a,t)=>[a.run(Ee(a,t[0],Bh()),t)],Pl=(a,t)=>[a.run(Ee(a,t[0],Nh()),t)],El=(a,t)=>[a.run(Ee(a,t[0],Rh()),t)],Dl=(a,t)=>[a.run(Ee(a,t[0],Mh()),t)],_i=(a,t,o)=>[a.run(Ee(a,t[0],xi(o.min,o.max),o.cacheKey),t)],Ll=a=>Q({min:a.attributes.getFloat("min",br),max:a.attributes.getFloat("max",gr)}),Cl=(a,t)=>{let o=tm(a,t);return _i(a,[t[0]],o)},tm=(a,t)=>{if(t.length>=3&&(!a.session.isInitializer(t[1].dataId)||!a.session.isInitializer(t[2].dataId)))throw new Error("dynamic clip attributes are not allowed");let o=t.length>=3?t[1].numberData[0]:br,e=t.length>=3?t[2].numberData[0]:gr;return Q({min:o,max:e})},Fl=(a,t)=>[a.run(Ee(a,t[0],Gh()),t)],$l=(a,t)=>[a.run(Ee(a,t[0],Uh()),t)],kl=(a,t,o)=>[a.run(Ee(a,t[0],zh(o.alpha),o.cacheKey),t)],Bl=a=>Q({alpha:a.attributes.getFloat("alpha",1)}),Nl=(a,t)=>[a.run(Ee(a,t[0],Vh()),t)],Rl=(a,t)=>[a.run(Ee(a,t[0],Wh()),t)],Oi=(a,t)=>[a.run(Ee(a,t[0],Hh()),t)],Ml=(a,t,o)=>[a.run(Ee(a,t[0],qh(o.alpha),o.cacheKey),t)],Gl=a=>Q({alpha:a.attributes.getFloat("alpha",.01)}),Ul=(a,t)=>[a.run(Ee(a,t[0],jh()),t)],zl=(a,t)=>[a.run(Ee(a,t[0],Yh()),t)],Vl=(a,t)=>[a.run(Ee(a,t[0],Xh()),t)],Wl=(a,t)=>[a.run(Ee(a,t[0],wi()),t)],Hl=(a,t)=>[a.run(Ee(a,t[0],vi()),t)],ql=(a,t)=>[a.run(Ee(a,t[0],Kh()),t)],jl=(a,t)=>[a.run(Ee(a,t[0],Jh()),t)],Yl=(a,t)=>[a.run(Ee(a,t[0],Zh()),t)],Xl=(a,t)=>[a.run(Ee(a,t[0],Qh()),t)]});function Rt(a){let t;switch(a.activation){case"Relu":t=wi();break;case"Sigmoid":t=vi();break;case"Clip":t=xi(a.clipMin,a.clipMax);break;default:return{activationFunction:"",applyActivation:""}}let o=t.name,e=t.body,r=`value = ${o}_(value);`;return{activationFunction:e,applyActivation:r}}var Nr,xr=L(()=>{"use strict";fe();Ii();Nr=a=>{let t=a.getString("activation","");if(t==="Clip"){let[o,e]=a.getFloats("activation_params",[br,gr]);return{activation:t,clipMax:e,clipMin:o,activationCacheKey:`${t}:${o},${e}`}}return{activation:t,activationCacheKey:t}}});var nm,om,Kl,Jl=L(()=>{"use strict";lt();we();ae();to();xr();nm=(a,t)=>({name:"GroupedConv",inputNames:a?["X","W","Bias"]:["X","W"],inputTypes:a?[0,0,0]:[0,0],cacheHint:t}),om=(a,t,o,e)=>{let n=t.length>2?"value += getBias(output_channel);":"",s=t[0].dims.slice(),i=t[1].dims.slice(),u=i[0]/e.group;ce.verbose("GroupedConv",`autpPad:${e.autoPad}, dilations:${e.dilations}, group:${e.group}, kernelShape:${e.kernelShape}, pads:${e.pads}, strides:${e.strides}`);let l=Rr(s,i,e.dilations,e.pads,e.strides),c=H(a.session.backend.glContext.version),{activationFunction:p,applyActivation:d}=Rt(e),T=`
  const ivec2 strides = ivec2(${e.strides[0]}, ${e.strides[1]});
  const ivec2 pads = ivec2(${e.pads[0]}, ${e.pads[1]});
  ${p}
  void main() {
    ivec4 coords = getOutputCoords();
    int batch = coords.x;
    int output_channel = coords.y;
    ivec2 xRCCorner = coords.zw * strides - pads;
    int group_id = output_channel / ${u};

    float value = 0.0;
    for (int wInChannel = 0; wInChannel < ${i[1]}; wInChannel++) {
      int input_channel = group_id * ${i[1]} + wInChannel;
      for (int wHeight = 0; wHeight < ${i[2]}; wHeight++) {
        int xHeight = xRCCorner.x + wHeight * ${e.dilations[0]};

        if (xHeight < 0 || xHeight >= ${s[2]}) {
          continue;
        }

        for (int wWidth = 0; wWidth < ${i[3]}; wWidth++) {
          int xWidth = xRCCorner.y + wWidth * ${e.dilations[1]};
          if (xWidth < 0 || xWidth >= ${s[3]}) {
            continue;
          }

          float xVal = getX(batch, input_channel, xWidth, xHeight);
          float wVal = getW(output_channel, wInChannel, wWidth, wHeight);
          value += xVal*wVal;
        }
      }
    }
    ${n}
    ${d}
    ${c.output} = vec4(value, .0, .0, .0);
  }
`;return{...o,output:{dims:l,type:t[0].type,textureType:0},shaderSource:T,hasMain:!0}},Kl=(a,t,o)=>{let e=nm(t.length>2,o.cacheKey);return{...e,get:()=>om(a,t,e,o)}}});var im,am,Zl,Ql=L(()=>{"use strict";we();ae();Tr();im=a=>({name:"Im2Col (packed)",inputNames:["A"],inputTypes:[2],cacheHint:a}),am=(a,t,o,e,r,n)=>{let s=o.dims,i=e.dims,u=2,l=3,c=r.length,p=[i[1]*i[2]*i[3],r[2]*r[3]],d=i[2]*i[3],T=Nt(),w=H(a.session.backend.glContext.version),v="";for(let A=0;A<=1;A++)for(let C=0;C<=1;C++)v+=`
            blockIndex = rc.x + ${C};
            pos = rc.y + ${A};

            if(blockIndex < ${p[1]} && pos < ${p[0]}) {
              offsetY = int(blockIndex / (${r[c-1]})) * ${n.strides[0]} -
                ${n.pads[0]};
              d0 = offsetY + ${n.dilations[0]} * (imod(pos, ${d}) / ${i[2]});

              if(d0 < ${s[u]} && d0 >= 0) {
                offsetX = imod(blockIndex, ${r[c-1]}) * ${n.strides[1]} -
                  ${n.pads[1]};
                d1 = offsetX + ${n.dilations[1]} * imod(imod(pos, ${d}), ${i[2]});

                if(d1 < ${s[l]} && d1 >= 0) {

                  ch = int(float(pos)/ ${d}.);
                    innerDims = vec2(d0, d1);
                    result[${A*2+C}] = getChannel(
                      getA(0, ch, int(innerDims.x),
                      int(innerDims.y)), innerDims);
                }
              }
            }

          `;let S=`
      ${T}

      void main() {
        ivec2 rc = getOutputCoords();
          vec4 result = vec4(0.0);
          int blockIndex, pos, offsetY, d0, offsetX, d1, ch;
          vec2 innerDims;
          ${v}
          ${w.output} = result;
      }
            `;return{...t,output:{dims:p,type:o.type,textureType:2},shaderSource:S,hasMain:!0}},Zl=(a,t,o,e,r)=>{let n=im(r.cacheKey);return{...n,get:()=>am(a,n,t,o,e,r)}}});function um(a,t,o){let e=t[0].dims,r=t[1].dims,n=Ze.calcShape(e,r,!0);if(!n)throw new Error("Can't use matmul on the given tensors");let s=Qe(n.length),i=Dt(),{activationFunction:u,applyActivation:l}=Rt(o),c=t.length>2,p=c?"value += getBiasForMatmul();":"",d=c?`${Ai(s,i,t[2].dims,n,!1)}`:"",T=n.length,w=e.length,v=r.length,S=e[e.length-1],A=`
    ${u}
    ${d}
    float process(int indices[${T}]) {
        int a[${w}];
        int b[${v}];
        bcastMatmulIndices_A(indices, a);
        bcastMatmulIndices_B(indices, b);

        float value;
        for (int k=0; k<${S}; ++k) {
            a[${w-1}] = k;
            b[${v-2}] = k;
            value += _A(a) * _B(b);
        }
        ${p}
        ${l}
        return value;
    }`;return{...a,output:{dims:n,type:t[0].type,textureType:0},shaderSource:A}}function Si(a,t){let o=sm(a.length>2,t.activationCacheKey);return{...o,get:()=>um(o,a,t)}}function Ai(a,t,o,e,r){let n="",s=o.length,i=e.length,u=i-s;i<2&&s>0?n="coords":n=o.map((v,S)=>`coords.${t[S+u]}`).join(", ");let c=Ze.getBroadcastDims(o,e).map(v=>`coords.${t[v+u]} = 0;`).join(`
`),d=U.size(o)===1,T="vec4(outputValue.xx, outputValue.yy)";return d&&(T="vec4(outputValue.x)"),r?`
vec4 getBiasForMatmul() {
  ${a} coords = getOutputCoords();
  ${c}
  vec4 outputValue = getBias(${n});
  return ${T};
}`:`
float getBiasForMatmul() {
  ${a} coords = getOutputCoords();
  ${c}
  return getBias(coords.x);
}`}var ef,tf,sm,lm,ro=L(()=>{"use strict";fe();ae();Bt();xr();Pi();ef=(a,t,o)=>(lm(t),a.session.pack?[a.run(no(a,t,o),t)]:[a.run(Si(t,o),t)]),tf=a=>Nr(a.attributes),sm=(a,t)=>({name:"MatMul",inputNames:a?["A","B","Bias"]:["A","B"],inputTypes:a?[0,0,0]:[0,0],cacheHint:t});lm=a=>{if(!a||a.length!==2)throw new Error("MatMul requires 2 inputs.");if(a[0].dims[a[0].dims.length-1]!==a[1].dims[a[1].dims.length-2])throw new Error("shared dimension does not match.");if(a[0].type!=="float32"&&a[0].type!=="float64"||a[1].type!=="float32"&&a[1].type!=="float64")throw new Error("inputs should be float type");if(a[0].type!==a[1].type)throw new Error("inputs types should match")}});function pm(a,t,o,e){let r=[],n=[],s=o[0].dims,i=o[1].dims,u=s.length,l=i.length,c=e.length,p=c-u,d=c-l;r=s.map((F,J)=>`coords.${t[J+p]}`),r[u-1]="i*2",r.join(", "),n=i.map((F,J)=>`coords.${t[J+d]}`),n[l-2]="i*2",n.join(", ");let T=Ze.getBroadcastDims(s,e),w=Ze.getBroadcastDims(i,e),v=T.map(F=>`coords.${t[F+p]} = 0;`).join(`
`),S=w.map(F=>`coords.${t[F+d]} = 0;`).join(`
`),A=`int lastDim = coords.${t[c-1]};
  coords.${t[c-1]} = coords.${t[c-2]};
  coords.${t[c-2]} = lastDim;`;return`
vec4 getAAtOutCoordsMatmul(int i) {
  ${a} coords = getOutputCoords();
  ${A}
  ${v}
  vec4 outputValue = getA(${r});
  return outputValue;
}

vec4 getBAtOutCoordsMatmul(int i) {
  ${a} coords = getOutputCoords();
  ${A}
  ${S}
  vec4 outputValue = getB(${n});
  return outputValue;
}`}function dm(a,t){let o="";for(let e=0;e<t-2;e++)o+=`rc.${a[e]}, `;return o+=`rc.${a[t-2]}, i*2`,o}function hm(a,t){let o="";for(let e=0;e<t-2;e++)o+=`rc.${a[e]}, `;return o+=`i*2, rc.${a[t-1]}`,o}var fm,cm,no,Pi=L(()=>{"use strict";fe();we();ae();Bt();xr();ro();fm=(a,t)=>({name:"MatMul (packed)",inputNames:a?["A","B","Bias"]:["A","B"],inputTypes:a?[2,2,2]:[2,2],cacheHint:t}),cm=(a,t,o,e)=>{let r=o.length>2,n=r?"value += getBiasForMatmul();":"",s=o[0].dims,i=o[1].dims,u=Ze.calcShape(s,i,!0),l=!U.areEqual(o[0].dims,o[1].dims);if(!u)throw new Error("Can't use matmul on the given tensors");let c=s[s.length-1],p=Math.ceil(c/2),d=s.length,T=i.length,w=H(a.session.backend.glContext.version),v=Qe(u.length),S=u.length,A=Dt(),{activationFunction:C,applyActivation:F}=Rt(e),J=r?`${Ai(v,A,o[2].dims,u,!0)}`:"",j=l?`${pm(v,A,o,u)}`:"",ie=l?"getAAtOutCoordsMatmul(i)":`getA(${dm(A,d)})`,G=l?"getBAtOutCoordsMatmul(i)":`getB(${hm(A,T)})`,Te=l?"":`${v} rc =
          getOutputCoords(); int lastDim = rc.${A[S-1]}; rc.${A[S-1]} =
          rc.${A[S-2]}; rc.${A[S-2]} = lastDim;
      `,He=`
            ${j}
            ${J}
            ${C}
            void main() {
              ${Te}

              vec4 value = vec4(0);
              for (int i = 0; i < ${p}; i++) {
                vec4 a = ${ie};
                vec4 b = ${G};

                value += (a.rrbb * b.rgrg);
                value += (a.ggaa * b.baba);
              }
              ${n}
              ${F}
              ${w.output} = value;
            }`;return{...t,output:{dims:u,type:o[0].type,textureType:2},shaderSource:He,hasMain:!0}},no=(a,t,o)=>{let e=fm(t.length>2,o.activationCacheKey);return{...e,get:()=>cm(a,e,t,o)}}});var rf,nf=L(()=>{"use strict";to();Ql();Pi();rf=(a,t,o)=>{let e=t[0].dims,r=t[1].dims,n=Rr(e,r,o.dilations,o.pads,o.strides),s=a.run(Zl(a,t[0],t[1],n,o),[t[0]]),i=a.reshapePacked(t[1],[r[0],r[1]*r[2]*r[3]]),u=t.length===3?[i,s,t[2]]:[i,s],l=a.run(no(a,u,o),u);return a.reshapePacked(l,n)}});var mm,bm,of,Ei,Di=L(()=>{"use strict";ae();mm=a=>({name:"Im2Col",inputNames:["X"],inputTypes:[0],cacheHint:a}),bm=(a,t,o,e,r,n)=>{let s=o.dims,i=e.dims,u=r.length,l=Ei(s,i,r,4),c=`
        const int XC = ${s[1]};
        const int XH = ${s[2]};
        const int XW = ${s[3]};
        const int KH = ${n.kernelShape[0]};
        const int KW = ${n.kernelShape[1]};
        const int dilationH = ${n.dilations[0]};
        const int dilationW = ${n.dilations[1]};
        const int strideH = ${n.strides[0]};
        const int strideW = ${n.strides[1]};
        const int padH = ${n.pads[0]};
        const int padW = ${n.pads[1]};
        const int KHKW = KH*KW;
        const int XCKHKW = XC * KHKW;
        const int outputChannels = 4;
        vec4 process(int indices[${u}]) {
          int b  = indices[0]; // batch size
          int oh = indices[1] * strideH - padH; //output height
          int ow = indices[2] * strideW - padW; //output width
          int p = indices[3] * outputChannels; //patch
          vec4 value = vec4(0.0);
          for(int i=0; i < outputChannels; ++i) {
            if(p < XCKHKW) {
              int patchC = p / KHKW;
              int patchH = (p - patchC*KHKW) / KW;
              int patchW = (p - patchC*KHKW) - patchH * KW;
              int xh2 = oh + patchH * dilationH;
              int xw2 = ow + patchW * dilationW;
              int x[${s.length}];
              x[0] = b;
              x[1] = patchC;
              x[2] = xh2;
              x[3] = xw2;
              if(xh2 >= 0 &&
                  xh2 < XH &&
                  xw2 >= 0 &&
                  xw2 < XW) {
                value[i] = _X(x);
              }
            }
            ++p;
          }
          return value;
        }
        `;return{...t,output:{dims:l,type:o.type,textureType:4},shaderSource:c}},of=(a,t,o,e,r)=>{let n=mm(r.cacheKey);return{...n,get:()=>bm(a,n,t,o,e,r)}},Ei=(a,t,o,e=4)=>[o[0],o[2],o[3],Math.ceil(a[1]*t[2]*t[3]/e)]});var gm,ym,af,sf=L(()=>{"use strict";fe();we();ae();xr();Di();gm=(a,t)=>({name:"ConvDotProduct",inputNames:a?["Im2Col","K","B"]:["Im2Col","K"],inputTypes:a?[0,4,0]:[0,4],cacheKey:t.activationCacheKey}),ym=(a,t,o,e,r)=>{let n=o[0].dims,s=o[1].dims,i=[s[0],Math.ceil(n[1]*s[2]*s[3]/4)],u=Ei(n,s,e),[l,c]=a.calculateTextureWidthAndHeight(i,4),p=U.computeStrides(u),[d,T]=a.calculateTextureWidthAndHeight(u,4),w=e.length,v=o.length<3?"0.0":"_B(b)",S=Math.ceil(n[1]*s[2]*s[3]/4),{activationFunction:A,applyActivation:C}=Rt(r),F=H(a.session.backend.glContext.version),J=`
${A}
float process(int indices[${w}]) {
  int b[1];
  b[0] = indices[1];
  int im2col[4];
  im2col[0] = indices[0];
  im2col[1] = indices[2];
  im2col[2] = indices[3];
  int im2colOffset = im2col[0] * ${p[0]} + im2col[1] * ${p[1]} + im2col[2] * ${p[2]};
  int kernelOffset = indices[1] * ${i[1]};
  float value = ${v};
  for (int i = 0; i < ${S}; ++i) {
    vec2 im2colCoords = offsetToCoords(im2colOffset, ${d}, ${T});
    vec2 kernelCoords = offsetToCoords(kernelOffset, ${l}, ${c});
    value += dot(${F.texture2D}(Im2Col, im2colCoords), ${F.texture2D}(K, kernelCoords));
    ++im2colOffset;
    ++kernelOffset;
  }
  ${C}
  return value;
}`;return{...t,output:{dims:e,type:o[0].type,textureType:0},shaderSource:J}},af=(a,t,o,e)=>{let r=gm(t.length>2,e);return{...r,get:()=>ym(a,r,t,o,e)}}});var Rr,Li,Tm,xm,wm,vm,Ci,_m,to=L(()=>{"use strict";Ue();fe();Jl();nf();sf();xr();Di();ro();Rr=(a,t,o,e,r)=>{let n=a[0],s=a.slice(2),i=s.length,u=t[0],c=t.slice(2).map((w,v)=>w+(w-1)*(o[v]-1)),d=s.map((w,v)=>w+e[v]+e[v+i]).map((w,v)=>Math.floor((w-c[v]+r[v])/r[v]));return[n,u].concat(...d)},Li=(a,t,o)=>(_m(t,o),Tm(a,t,o)),Tm=(a,t,o)=>{let e=vm(o,t),r=a.session.pack,n=e.kernelShape[0]===1&&e.kernelShape[1]===1;return e.group>1?[a.run(Kl(a,t,e),t)]:n&&r?[xm(a,t,e)]:r&&t[0].dims.length===4&&t[0].dims[0]===1&&!n?[rf(a,t,e)]:[wm(a,t,e)]},xm=(a,t,o)=>{let e=t[0].dims,r=t[1].dims,n=Rr(e,r,o.dilations,o.pads,o.strides),s=a.reshapeUnpacked(t[0],[e[1],e[2]*e[3]]),i=a.reshapeUnpacked(t[1],[r[0],r[1]]),u=t.length>2?[i,s,t[2]]:[i,s],l=a.run(Si(u,o),u);return a.reshapeUnpacked(l,n)},wm=(a,t,o)=>{let e=t[0].dims,r=t[1].dims,n=Rr(e,r,o.dilations,o.pads,o.strides),s=a.run(of(a,t[0],t[1],n,o),[t[0]]),i=t.length===3?[s,t[1],t[2]]:[s,t[1]];return a.run(af(a,t,n,o),i)},vm=(a,t)=>{let o=a.kernelShape.slice();if(a.kernelShape.length===0)for(let n=2;n<t[1].dims.length;++n)o.push(t[1].dims[n]);let e=a.pads.slice();mr.adjustPadsBasedOnAutoPad(t[0].dims,a.strides,a.dilations,o,e,a.autoPad);let r=Object.assign({},a);return Object.assign(r,{kernelShape:o,pads:e,cacheKey:a.cacheKey}),r},Ci=a=>{let t=a.attributes,o=Nr(t),e=t.getString("auto_pad","NOTSET"),r=t.getInts("dilations",[1,1]),n=t.getInt("group",1),s=t.getInts("kernel_shape",[]),i=t.getInts("pads",[0,0,0,0]),u=t.getInts("strides",[1,1]);return Q({autoPad:e,dilations:r,group:n,kernelShape:s,pads:i,strides:u,...o})},_m=(a,t)=>{if(!a||a.length!==2&&a.length!==3)throw new Error("Conv requires 2 or 3 inputs");if(a[0].dims.length!==4||a[1].dims.length!==4)throw new Error("currently only support 2-dimensional conv");let o=a[0].dims[1],e=a[1].dims[1]*t.group;if(o!==e)throw new Error("FILTER_IN_CHANNEL should be equal to DATA_CHANNEL");if(a.length===3&&(a[2].dims.length!==1||a[1].dims[0]!==a[2].dims[0]))throw new Error("invalid bias");let r=a[0].dims.length-2;if(t.dilations.length!==r)throw new Error(`dilations should be ${r}D`);if(t.strides.length!==r)throw new Error(`strides should be ${r}D`);if(t.pads.length!==r*2)throw new Error(`pads should be ${r*2}D`);if(t.kernelShape.length!==0&&t.kernelShape.length!==a[1].dims.length-2)throw new Error("invalid kernel shape");if(a[0].type!=="float32"||a[1].type!=="float32")throw new Error("Conv input(X,W) should be float tensor");if(a.length===3&&a[2].type!=="float32")throw new Error("Conv input(bias) should be float tensor")}});var Om,Im,Sm,uf,Am,Pm,Em,Dm,Lm,Cm,lf,Fm,ff=L(()=>{"use strict";Ue();we();ae();xr();Om=(a,t,o,e,r,n)=>(a-1)*t+o+(e-1)*r+1-n,Im=(a,t,o,e,r)=>{let n=Math.floor(a/2);t==="SAME_UPPER"?(o[e]=n,o[r]=a-n):t==="SAME_LOWER"&&(o[e]=a-n,o[r]=n)},Sm=(a,t,o,e,r,n,s,i)=>{let u=a.length-2,l=i.length===0;for(let c=0;c<u;++c){let p=l?a[c+2]*n[c]:i[c],d=Om(a[c+2],n[c],r[c],t[c],o[c],p);Im(d,e,r,c,c+u),l&&i.push(n[c]*(a[c+2]-1)+s[c]+(t[c]-1)*o[c]+1-r[c]-r[c+u])}},uf=(a,t,o)=>(Fm(t,o),Am(a,t,o)),Am=(a,t,o)=>{let e=Cm(o,t);return[Lm(a,t,e)]},Pm=(a,t)=>({name:"ConvTranspose",inputNames:a?["X","W","B"]:["X","W"],inputTypes:a?[0,0,0]:[0,0],cacheHint:t}),Em=(a,t,o,e)=>{let n=t.length>2?"getB(output_channel)":"0.0",s=t[0].dims,i=t[1].dims,u=i[1],l=i[0]/e.group,c=[t[0].dims[0],t[1].dims[1]*e.group,...e.outputShape],p=H(a.session.backend.glContext.version),{activationFunction:d,applyActivation:T}=Rt(e),w=`
  const ivec2 strides = ivec2(${e.strides[0]}, ${e.strides[1]});
  const ivec2 pads = ivec2(${e.pads[0]}, ${e.pads[1]});
  ${d}
  void main() {
    ivec4 coords = getOutputCoords();
    int batch = coords.x;
    int output_channel = coords.y;

    ivec2 loc = coords.zw + pads;

    int group_id = output_channel / ${u};
    int wOutChannel = output_channel - group_id * ${u};

    float value = ${n};
    for (int inChannelOffset = 0; inChannelOffset < ${l}; inChannelOffset++) {
      int input_channel = group_id * ${l} + inChannelOffset;
      for (int wWOff = 0; wWOff < ${i[2]}; wWOff++) {
        for (int wHOff = 0; wHOff < ${i[3]}; wHOff++) {
          ivec2 wOff = ivec2(wWOff * ${e.dilations[0]}, wHOff * ${e.dilations[1]});
          ivec2 wLoc = loc - wOff;
          ivec2 wLocIn = wLoc / strides;
          if (
            wLocIn * strides == wLoc &&
            wLocIn.x >= 0 && wLocIn.x < ${s[2]} &&
            wLocIn.y >= 0 && wLocIn.y < ${s[3]}
          ) {
            float xVal = getX(batch, input_channel, wLocIn.y, wLocIn.x);
            float wVal = getW(input_channel, wOutChannel, wHOff, wWOff);
            value += xVal * wVal;
          }
        }
      }
    }
    ${T}
    ${p.output} = vec4(value, .0, .0, .0);
  }
`;return{...o,output:{dims:c,type:t[0].type,textureType:0},shaderSource:w,hasMain:!0}},Dm=(a,t,o)=>{let e=Pm(t.length>2,o.cacheKey);return{...e,get:()=>Em(a,t,e,o)}},Lm=(a,t,o)=>a.run(Dm(a,t,o),t),Cm=(a,t)=>{let o=a.kernelShape.slice();if(a.kernelShape.length===0)for(let i=2;i<t[1].dims.length;++i)o.push(t[1].dims[i]);let e=a.pads.slice(),r=a.outputShape.slice(),n=t[0].dims;Sm(n,o,a.dilations,a.autoPad,e,a.strides,a.outputPadding,r);let s=Object.assign({},a);return Object.assign(s,{kernelShape:o,pads:e,outputShape:r,cacheKey:a.cacheKey}),s},lf=a=>{let t=a.attributes,o=Nr(t),e=t.getString("auto_pad","NOTSET"),r=t.getInts("dilations",[1,1]),n=t.getInt("group",1),s=t.getInts("kernel_shape",[]),i=t.getInts("output_padding",[0,0]),u=t.getInts("output_shape",[]),l=t.getInts("pads",[0,0,0,0]),c=t.getInts("strides",[1,1]);return Q({autoPad:e,dilations:r,group:n,kernelShape:s,outputPadding:i,outputShape:u,pads:l,strides:c,...o})},Fm=(a,t)=>{if(!a||a.length!==2&&a.length!==3)throw new Error("Conv requires 2 or 3 inputs");if(a[0].dims.length!==4||a[1].dims.length!==4)throw new Error("currently only support 2-dimensional conv");let o=a[0].dims[1],e=a[1].dims[0];if(o!==e)throw new Error("FILTER_IN_CHANNEL should be equal to DATA_CHANNEL");let r=a[1].dims[1]*t.group;if(a.length===3&&(a[2].dims.length!==1||a[2].dims[0]!==r))throw new Error("invalid bias");let n=a[0].dims.length-2;if(t.dilations.length!==n)throw new Error(`dilations should be ${n}D`);if(t.strides.length!==n)throw new Error(`strides should be ${n}D`);if(t.pads.length!==n*2)throw new Error(`pads should be ${n*2}D`);if(t.outputPadding.length!==n)throw new Error(`output_padding should be ${n}D`);if(t.kernelShape.length!==0&&t.kernelShape.length!==a[1].dims.length-2)throw new Error("invalid kernel shape");if(t.outputShape.length!==0&&t.outputShape.length!==a[0].dims.length-2)throw new Error("invalid output shape");if(a[0].type!=="float32"||a[1].type!=="float32")throw new Error("ConvTranspose input(X,W) should be float tensor");if(a.length===3&&a[2].type!=="float32")throw new Error("ConvTranspose input(bias) should be float tensor")}});var cf,wr,pf,$m,df,km,Bm,Nm,oo=L(()=>{"use strict";Ue();fe();ae();cf={name:"Transpose",inputNames:["A"],inputTypes:[0]},wr=(a,t,o)=>(Nm(t),[a.run({...cf,cacheHint:o.cacheKey,get:()=>$m(a,t[0],o.perm)},t)]),pf=a=>Q({perm:a.attributes.getInts("perm",[])}),$m=(a,t,o)=>{let e=t.dims;o=df(e,o);let r=km(e,o),n=e.length,s=`
      ${Bm("perm",o,n)}
      float process(int indices[${n}]) {
        int a[${n}];
        perm(a, indices);
        return _A(a);
      }`;return{...cf,output:{dims:r,type:t.type,textureType:0},shaderSource:s}},df=(a,t)=>(t&&t.length!==a.length&&(t=[...a.keys()].reverse()),t),km=(a,t)=>(t=df(a,t),U.sortBasedOnPerm(a,t)),Bm=(a,t,o)=>{let e=[];e.push(`void ${a}(out int a[${o}], int src[${o}]) {`);for(let r=0;r<o;++r)e.push(`	a[${t[r]}]=src[${r}];`);return e.push("	}"),e.join(`
`)},Nm=a=>{if(!a||a.length!==1)throw new Error("Transpose requires 1 input.");if(a[0].type!=="float32"&&a[0].type!=="float64")throw new Error("input should be float tensor")}});var hf,mf,Rm,bf=L(()=>{"use strict";oo();hf=(a,t,o)=>{Rm(t);let e=o.blocksize,r=e*e,n=o.mode==="DCR"?[0,3,4,1,5,2]:[0,1,4,2,5,3],s=o.mode==="DCR"?[t[0].dims[0],e,e,t[0].dims[1]/r,t[0].dims[2],t[0].dims[3]]:[t[0].dims[0],t[0].dims[1]/r,e,e,t[0].dims[2],t[0].dims[3]],i=a.reshapeUnpacked(t[0],s),u={perm:n,cacheKey:`${n}`},[l]=wr(a,[i],u),c=[t[0].dims[0],t[0].dims[1]/r,t[0].dims[2]*e,t[0].dims[3]*e];return[a.reshapeUnpacked(l,c)]},mf=a=>{let t=a.attributes.getInt("blocksize");if(t<1)throw new Error(`blocksize must be >= 1, but got : ${t} for DepthToSpace`);let o=a.attributes.getString("mode","DCR");if(o!=="DCR"&&o!=="CRD")throw new Error(`unrecognized mode: ${o} for DepthToSpace`);return{mode:o,blocksize:t}},Rm=a=>{if(a.length!==1)throw new Error(`DepthToSpace expect 1 inputs, but got ${a.length}`);if(a[0].type==="string"||a[0].dims.length!==4)throw new TypeError("DepthToSpace input should be a 4-D numeric tensor")}});var gf,yf,Mm,Tf=L(()=>{"use strict";fe();gf=(a,t,o)=>{Mm(t,o);let e=U.flattenShape(t[0].dims,o);return[a.reshapeUnpacked(t[0],e)]},yf=a=>a.attributes.getInt("axis",1),Mm=(a,t)=>{if(!a||a.length!==1)throw new Error("Flatten requires 1 input.");let o=a[0].dims.length;if(o===0)throw new Error("scalar tensor is not supported.");if(t<-o||t>o)throw new Error("Invalid axis");if(a[0].type==="string")throw new Error("string tensor is not supported.")}});var Qt,pn=L(()=>{"use strict";Qt=["float32","float64","int32","int16","int8","uint16","uint32","uint8"]});var xf,wf,Gm,Um,zm,Vm,vf=L(()=>{"use strict";Ue();pn();fe();ae();xf=(a,t,o)=>(Vm(t,o.axis),[a.run(zm(a,t,o),t)]),wf=a=>Q({axis:a.attributes.getInt("axis",0)}),Gm={name:"Gather",inputNames:["A","B"],inputTypes:[0,0]},Um=(a,t,o,e)=>{let r=o[0].dims.slice(),n=o[1].dims.slice(),s=new Array(r.length+n.length-1);e=U.normalizeAxis(e,r.length);let i=[];for(let d=0;d<s.length;d++)d<e?(s[d]=r[d],i.push(`inputIdx[${d}] = outputIdx[${d}];`)):d<e+n.length?(s[d]=n[d-e],i.push(`indexDataIdx[${d-e}] = outputIdx[${d}];`)):(s[d]=r[d-n.length+1],i.push(`inputIdx[${d-n.length+1}] = outputIdx[${d}];`));let u=s.length||1,l=r.length,c=n.length||1,p=`
      float process(int outputIdx[${u}]) {
        int inputIdx[${l}];
        int indexDataIdx[${c}];
        indexDataIdx[0] = 0;
        ${i.join(`
        `)}
        int idx = int(_B(indexDataIdx));
        inputIdx[${e}] = idx < 0 ? idx + ${r[e]} : idx;
        return _A(inputIdx);
      }`;return{...t,output:{dims:s,type:o[0].type,textureType:0},shaderSource:p}},zm=(a,t,o)=>{let e={...Gm,cacheHint:o.cacheKey};return{...e,get:()=>Um(a,e,t,o.axis)}},Vm=(a,t)=>{if(!a||a.length!==2)throw new Error("Gather requires 2 inputs.");let o=a[0].dims.length;if(o<1)throw new Error("Invalid input shape.");if(t<-o||t>o-1)throw new Error("Invalid axis.");if(Qt.indexOf(a[0].type)===-1)throw new Error("Invaid input type.");if(a[1].type!=="int32"&&a[1].type!=="int16")throw new Error("Invaid input type.")}});var Fi,_f,Of,If,Wm,Hm,qm,Sf=L(()=>{"use strict";Ue();fe();ae();Fi=(a,t,o)=>(qm(t,o),[a.run(Wm(t,o),t)]),_f=(a,t)=>{let o=a.attributes.getInt("transA",0)!==0,e=a.attributes.getInt("transB",0)!==0,r=a.attributes.getFloat("alpha",1),n=a.attributes.getFloat("beta",1);return Q({transA:o,transB:e,alpha:r,beta:n,isOptionalC:t})},Of=a=>_f(a,!1),If=a=>_f(a,!0),Wm=(a,t)=>{let o={name:"Gemm",inputNames:a.length===3?["A","B","C"]:["A","B"],inputTypes:a.length===3?[0,0,0]:[0,0],key:t.cacheKey};return{...o,get:()=>Hm(o,a,t)}},Hm=(a,t,o)=>{let e=t[0].dims.slice(),r=t[1].dims.slice(),[n,s]=jn.getShapeOfGemmResult(e,o.transA,r,o.transB,t.length===3?t[2].dims:void 0),i=[n,s];if(!i)throw new Error("Can't use gemm on the given tensors");let u=e[e.length-1],l="";o.transA&&(u=e[0]),o.transA&&o.transB?l="value += _A_T(a) * _B_T(b);":o.transA&&!o.transB?l="value += _A_T(a) * _B(b);":!o.transA&&o.transB?l="value += _A(a) * _B_T(b);":!o.transA&&!o.transB&&(l="value += _A(a) * _B(b);");let c=i.length,p=t.length===3?`int c[${t[2].dims.length}];`:"",d=t.length===3?"bcastIndices_C(indices, c);":"",T=t.length===3?"value += beta * _C(c);":"",w=`
      float process(int indices[${c}]) {
          int a[${c}];
          int b[${c}];
          ${p}

          copyVec(indices, a);
          copyVec(indices, b);
          ${d}

          float value = 0.0;
          for (int k=0; k<${u}; ++k) {
              a[${c-1}] = k;
              b[${c-2}] = k;
              ${l}
          }

          value = value * alpha;
          ${T}
          return value;
      }`;return{...a,output:{dims:i,type:t[0].type,textureType:0},variables:[{name:"alpha",type:"float",data:o.alpha},{name:"beta",type:"float",data:o.beta}],shaderSource:w}},qm=(a,t)=>{if(!a)throw new Error("Input is missing");if(t.isOptionalC&&(a.length<2||a.length>3))throw new Error("Invaid input shape.");if(!t.isOptionalC&&a.length!==3)throw new Error("Gemm requires 3 inputs");if(a.length===3&&a[2].dims.length!==1&&a[2].dims.length!==2)throw new Error("Invalid input shape of C");if(a[0].type!=="float32"&&a[0].type!=="float64"||a[1].type!=="float32"&&a[1].type!=="float64"||a.length===3&&a[2].type!=="float32"&&a[2].type!=="float64")throw new Error("Invalid input type.");if(a[0].type!==a[1].type||a.length===3&&a[0].type!==a[2].type)throw new Error("Input types are mismatched")}});var Af,Pf,jm,Ym,Xm,Km,Jm,Ef=L(()=>{"use strict";Ue();ae();Af=(a,t,o)=>(Jm(t),[a.run(Xm(a,t,o),t)]),Pf=a=>{let t=a.attributes.getFloat("scale"),o=a.attributes.getFloats("bias");return Q({scale:t,bias:o})},jm={name:"ImageScaler",inputNames:["X"],inputTypes:[0]},Ym=(a,t,o,e)=>{let r=o[0].dims.slice(),n=r.length,i=`
      ${Km(e.bias.length)}
      float process(int indices[${n}]) {
        return _X(indices) * scale + getBias(bias, indices[1]);
      }`;return{...t,output:{dims:r,type:o[0].type,textureType:0},variables:[{name:"bias",type:"float",arrayLength:e.bias.length,data:e.bias},{name:"scale",type:"float",data:e.scale}],shaderSource:i}},Xm=(a,t,o)=>{let e={...jm,cacheHint:o.cacheKey};return{...e,get:()=>Ym(a,e,t,o)}},Km=a=>{let t=[`float getBias(float bias[${a}], int channel) {`];for(let o=0;o<a;++o)o===0?t.push(`	if (channel == ${o}) { return bias[${o}]; }`):o===a-1?t.push(`	else { return bias[${o}]; }`):t.push(`	else if (channel == ${o}) { return bias[${o}]; }`);return t.push("	}"),t.join(`
`)},Jm=a=>{if(!a||a.length!==1)throw new Error("ImageScaler requires 1 input.");if(a[0].dims.length!==4)throw new Error("Invalid input shape.");if(a[0].type!=="float32"&&a[0].type!=="float64")throw new Error("Invalid input type.")}});var Lf,Cf,Df,Zm,Qm,eb,tb,rb,nb,Ff=L(()=>{"use strict";we();ae();Lf=(a,t,o)=>{nb(t);let e=a.run(Qm(t[0]),t);return[a.run(rb(a,t[0],o,e.dims),[t[0],e,t[1],t[2]])]},Cf=a=>a.attributes.getFloat("epsilon",1e-5),Df={name:"InstanceNormalization_MeanAndVariance",inputNames:["X"],inputTypes:[0]},Zm=(a,t)=>{let o=t.dims.slice(),e=o[1],r=o[2]*o[3],n=[o[0],e],s=`
      vec4 process(int[2] indices) {
        vec4 v = vec4(0.0);
        int a[4];
        a[0] = indices[0];
        a[1] = indices[1];
        float temp = 0.0;
        for(int a2=0; a2<${o[2]}; a2++) {
          a[2] = a2;
          for(int a3=0; a3<${o[3]}; a3++) {
            a[3] = a3;
            float x = _X(a);
            temp += x;
          }
        }
        float mean = temp / float(${r});
        temp = 0.0;
        for(int a2=0; a2<${o[2]}; a2++) {
          a[2] = a2;
          for(int a3=0; a3<${o[3]}; a3++) {
            a[3] = a3;
            float x = _X(a);
            temp += (x - mean) * (x - mean);
          }
        }
        v.r = mean;
        v.g = temp / float(${r});

        return v;
      }`;return{...a,output:{dims:n,type:t.type,textureType:4},shaderSource:s}},Qm=a=>({...Df,get:()=>Zm(Df,a)}),eb={name:"InstanceNormalization_ComputeOutput",inputNames:["X","MeanAndVariance","Scale","B"],inputTypes:[0,4,0,0]},tb=(a,t,o,e,r)=>{let n=H(a.session.backend.glContext.version),[s,i]=a.calculateTextureWidthAndHeight(r,4),[u,l]=[s/4,i],c=`
      vec4 get_MeanAndVariance(int[2] mv) {
        int offset = indicesToOffset_MeanAndVariance(mv);
        vec2 coords = offsetToCoords(offset, ${u}, ${l});
        return ${n.texture2D}(MeanAndVariance, coords);
      }

      float process(int[4] indices) {
        int mv[2];
        mv[0] = indices[0];
        mv[1] = indices[1];
        vec4 mean_and_variance = get_MeanAndVariance(mv);
        float mean = mean_and_variance.r;
        float variance = mean_and_variance.g;

        int sb[1];
        sb[0] = indices[1];
        float scale = _Scale(sb);
        float b = _B(sb);

        return scale * (_X(indices) - mean) / sqrt(variance + epsilon) + b;
      }`;return{...t,output:{dims:o.dims,type:o.type,textureType:0},variables:[{name:"epsilon",type:"float",data:e}],shaderSource:c}},rb=(a,t,o,e)=>{let r={...eb,cacheHint:`${o}`};return{...r,get:()=>tb(a,r,t,o,e)}},nb=a=>{if(!a||a.length!==3)throw new Error("InstanceNormalization requires 3 inputs.");let t=a[0],o=a[1],e=a[2];if(t.dims.length<3||o.dims.length!==1||e.dims.length!==1)throw new Error("Invalid input shape.");if(o.dims[0]!==t.dims[1]||e.dims[0]!==t.dims[1])throw new Error("Input shapes are mismatched.");if(t.type!=="float32"&&t.type!=="float64"||o.type!=="float32"&&o.type!=="float64"||e.type!=="float32"&&e.type!=="float64")throw new Error("Invalid input type.");if(a[0].dims.length!==4)throw new Error("Only support 4-D input shape.")}});function ob(a,t){let o=a[0].dims[1],e=a[0].dims.length,r=-Math.floor((t.size-1)/2),n=Math.ceil((t.size-1)/2),s=`float(${t.alpha}) / float(${t.size})`,i=`float(${t.bias})`,u=`float(${t.beta})`,l=`
    float process(int indices[${e}]) {
        int c = indices[1];
        float x = _X(indices);
        float square_sum = 0.0;

        for (int i = ${r}; i <= ${n}; i++) {
          int idx = c + i;
          if (c >= 0 && c < ${o}) {
            indices[1] = idx;
            float j = _X(indices);
            square_sum += j * j;
          }
        }
        return x / pow(${i} + ${s} * square_sum, ${u});
    }`;return{...Bf,cacheHint:t.cacheKey,output:{dims:a[0].dims,type:a[0].type,textureType:0},shaderSource:l}}function ib(a,t){return{...Bf,cacheHint:t.cacheKey,get:()=>ob(a,t)}}var $f,kf,Bf,ab,Nf=L(()=>{"use strict";Ue();ae();$f=(a,t,o)=>(ab(t),[a.run(ib(t,o),t)]),kf=a=>{let t=a.attributes.getFloat("alpha",1e-4),o=a.attributes.getFloat("beta",.75),e=a.attributes.getFloat("bias",1),r=a.attributes.getInt("size");return Q({alpha:t,beta:o,bias:e,size:r})},Bf={name:"LRN",inputNames:["X"],inputTypes:[0]};ab=a=>{if(!a||a.length!==1)throw new Error("LRN requires 1 input.");if(a[0].dims.length!==4)throw new Error('currently only support LRN for input with "NCHW" format');if(a[0].type!=="float32")throw new Error("input should be float type")}});var sb,$i,Rf,Mf,Gf,ub,lb,fb,cb,pb,db,hb,mb,Uf=L(()=>{"use strict";Ue();fe();we();ae();sb={name:"Pad",inputNames:["A"],inputTypes:[0]},$i=(a,t,o)=>(fb(t),[a.run({...sb,cacheHint:o.cacheKey,get:()=>lb(a,t[0],o)},t)]),Rf=a=>{let t=a.attributes.getString("mode","constant"),o=a.attributes.getFloat("value",0),e=a.attributes.getInts("pads");return Q({mode:t,value:o,pads:e})},Mf=(a,t,o)=>{cb(t);let e=ub(a,t,o);return $i(a,[t[0]],e)},Gf=a=>a.attributes.getString("mode","constant"),ub=(a,t,o)=>{if(!a.session.isInitializer(t[1].dataId)||t.length>=3&&!a.session.isInitializer(t[2].dataId))throw new Error("dynamic pad attributes are not allowed");let e=Array.from(t[1].integerData),r=t.length>=3?t[2].floatData[0]:0;return Q({mode:o,pads:e,value:r})},lb=(a,t,o)=>{let e=U.padShape(t.dims.slice(),o.pads),r=e.length,s=`
      ${pb(a,t,o)}
      float process(int[${r}] indices) {
          return padA(indices);
      }`;return{name:"Pad",inputNames:["A"],inputTypes:[0],output:{dims:e,type:t.type,textureType:0},shaderSource:s}},fb=a=>{if(!a||a.length!==1)throw new Error("Pad requires 1 input");if(a[0].type!=="float32"&&a[0].type!=="float64")throw new Error("Invalid input type.")},cb=a=>{if(!a||a.length!==2&&a.length!==3)throw new Error("Pad requires 2 or 3 inputs");if(a[1].type!=="int32")throw new Error("Invalid input type.");if(a.length>=3&&a[2].type==="string")throw new Error("Invalid input type.")},pb=(a,t,o)=>{let e=H(a.session.backend.glContext.version),[r,n]=a.calculateTextureWidthAndHeight(t.dims,0),s=U.computeStrides(t.dims);switch(o.mode){case"constant":return db(e,t.dims,s,r,n,o.pads,o.value);case"reflect":return hb(e,t.dims,s,r,n,o.pads);case"edge":return mb(e,t.dims,s,r,n,o.pads);default:throw new Error("Invalid mode")}},db=(a,t,o,e,r,n,s)=>{let i=t.length,u="";for(let l=i-1;l>=0;--l)u+=`
        k = m[${l}] - ${n[l]};
        if (k < 0)  return constant;
        if (k >= ${t[l]}) return constant;
        offset += k * ${o[l]};
        `;return`
      float padA(int m[${i}]) {
        const float constant = float(${s});
        int offset = 0;
        int k = 0;
        ${u}
        vec2 coords = offsetToCoords(offset, ${e}, ${r});
        float value = getColorAsFloat(${a.texture2D}(A, coords));
        return value;
      }
      `},hb=(a,t,o,e,r,n)=>{let s=t.length,i="";for(let u=s-1;u>=0;--u)i+=`
        k = m[${u}] - ${n[u]};
        if (k < 0) { k = -k; }
        {
          const int _2n_1 = ${2*(t[u]-1)};
          k = int( mod( float(k), float(_2n_1) ) ) ;
          if(k >= ${t[u]}) { k = _2n_1 - k; }
        }
        offset += k * ${o[u]};
        `;return`
      float padA(int m[${s}]) {
        int offset = 0;
        int k = 0;
        ${i}
        vec2 coords = offsetToCoords(offset, ${e}, ${r});
        float value = getColorAsFloat(${a.texture2D}(A, coords));
        return value;
      }
      `},mb=(a,t,o,e,r,n)=>{let s=t.length,i="";for(let u=s-1;u>=0;--u)i+=`
        k = m[${u}] - ${n[u]};
        if (k < 0)  k = 0;
        if (k >= ${t[u]}) k = ${t[u]-1};
        offset += k * ${o[u]};
      `;return`
      float padA(int m[${s}]) {
        int offset = 0;
        int k = 0;
        ${i}
        vec2 coords = offsetToCoords(offset, ${e}, ${r});
        float value = getColorAsFloat(${a.texture2D}(A, coords));
        return value;
      }
      `}});var Vf,Wf,Hf,qf,jf,Yf,Xf,Kf,Jf,bb,zf,Zf,ao,Qf,io,gb,ec=L(()=>{"use strict";Ue();fe();ae();Vf=(a,t,o)=>{ao(t);let e={name:"AveragePool",inputNames:["X"],inputTypes:[0],cacheHint:o.cacheKey};return[a.run({...e,get:()=>Hf(t,e,!1,o)},t)]},Wf=a=>{let t=a.attributes.getString("auto_pad","NOTSET"),o=a.attributes.getInt("ceil_mode",0),e=a.attributes.getInt("count_include_pad",0)!==0,r=a.attributes.getInts("kernel_shape"),n=a.attributes.getInts("strides",[]),s=a.attributes.getInts("pads",[]);if(o!==0)throw new Error("using ceil() in shape computation is not yet supported for AveragePool");return Q({autoPad:t,ceilMode:o,countIncludePad:e,kernelShape:r,strides:n,pads:s})},Hf=(a,t,o,e)=>{let[r,n]=Jf(a,e,o),s=U.size(r.kernelShape),i="value += _X(x);",u="";r.countIncludePad?u+=`value /= float(${s});`:u+=`value /= float(${s} - pad);`;let c=`
        ${Qf(a[0].dims,r,i,u,"0.0")}
      `;return{...t,output:{dims:n,type:a[0].type,textureType:0},shaderSource:c}},qf=(a,t,o)=>{ao(t);let e={name:"GlobalAveragePool",inputNames:["X"],inputTypes:[0],cacheHint:`${o.countIncludePad}`};return[a.run({...e,get:()=>Hf(t,e,!0,o)},t)]},jf=a=>{let t=a.attributes.getInt("count_include_pad",0)!==0;return Q({autoPad:"",ceilMode:0,countIncludePad:t,kernelShape:[],strides:[],pads:[]})},Yf=(a,t,o)=>{ao(t);let e={name:"MaxPool",inputNames:["X"],inputTypes:[0],cacheHint:o.cacheKey};return[a.run({...e,get:()=>Kf(t,e,!1,o)},t)]},Xf=a=>{let t=a.attributes.getString("auto_pad","NOTSET"),o=a.attributes.getInt("ceil_mode",0),e=a.attributes.getInts("kernel_shape"),r=a.attributes.getInts("strides",[]),n=a.attributes.getInts("pads",[]),s=a.attributes.getInt("storage_order",0),i=a.attributes.getInts("dilations",[]);if(s!==0)throw new Error("column major storage order is not yet supported for MaxPool");if(o!==0)throw new Error("using ceil() in shape computation is not yet supported for MaxPool");return Q({autoPad:t,ceilMode:o,countIncludePad:!1,kernelShape:e,strides:r,pads:n,storageOrder:s,dilations:i})},Kf=(a,t,o,e)=>{let[r,n]=Jf(a,e,o),s=`
      value = max(_X(x), value);
    `,i="",l=`
      ${Qf(a[0].dims,r,s,i,"-1e5")}
    `;return{...t,output:{dims:n,type:a[0].type,textureType:0},shaderSource:l}},Jf=(a,t,o)=>{let e=a[0].dims.slice(),r=Object.hasOwnProperty.call(t,"dilations"),n=t.kernelShape.slice(),s=t.strides.slice(),i=r?t.dilations.slice():[],u=t.pads.slice();mr.adjustPoolAttributes(o,e,n,s,i,u);let l=mr.computePoolOutputShape(o,e,s,i,n,u,t.autoPad),c=Object.assign({},t);return r?Object.assign(c,{kernelShape:n,strides:s,pads:u,dilations:i,cacheKey:t.cacheKey}):Object.assign(c,{kernelShape:n,strides:s,pads:u,cacheKey:t.cacheKey}),[c,l]},bb={autoPad:"",ceilMode:0,countIncludePad:!1,kernelShape:[],strides:[],pads:[],storageOrder:0,dilations:[],cacheKey:""},zf={name:"GlobalMaxPool",inputNames:["X"],inputTypes:[0]},Zf=(a,t)=>(ao(t),[a.run({...zf,get:()=>Kf(t,zf,!0,bb)},t)]),ao=a=>{if(!a||a.length!==1)throw new Error("Pool ops requires 1 input.");if(a[0].type!=="float32"&&a[0].type!=="float64")throw new Error("Invalid input type.")},Qf=(a,t,o,e,r)=>{let n=a.length;if(t.kernelShape.length<=2){let s=t.kernelShape[t.kernelShape.length-1],i=t.strides[t.strides.length-1],u=t.pads[t.pads.length/2-1],l=t.pads[t.pads.length-1],c=a[n-1],p="",d="",T="";if(u+l!==0?p=`
          for (int i = 0; i < ${s}; i++) {
            x[${n} - 1] = indices[${n} - 1] * ${i} - ${u} + i;
            if (x[${n} - 1] < 0 || x[${n} - 1] >= ${c}) {
              pad++;
              continue;
            }
            ${o}
          }`:p=`
          for (int i = 0; i < ${s}; i++) {
            x[${n} - 1] = indices[${n} - 1] * ${i} - ${u} + i;
            ${o}
          }`,t.kernelShape.length===2){let v=t.kernelShape[t.kernelShape.length-2],S=t.strides[t.strides.length-2],A=t.pads[t.pads.length/2-2],C=t.pads[t.pads.length-2],F=a[n-2];A+C!==0?d=`
            for (int j = 0; j < ${v}; j++) {
              x[${n} - 2] = indices[${n} - 2] * ${S} - ${A} + j;
              if (x[${n} - 2] < 0 || x[${n} - 2] >= ${F}) {
                pad+= ${s};
                continue;
              }
          `:d=`
            for (int j = 0; j < ${v}; j++) {
              x[${n} - 2] = indices[${n} - 2] * ${S} - ${A} + j;
            `,T=`
          }
        `}return`
        float process(int indices[${n}]) {
          int x[${n}];
          copyVec(indices, x);

          float value = ${r};
          int pad = 0;
          ${d}
          ${p}
          ${T}
          ${e}
          return value;
        }
      `}else{let s=U.size(t.kernelShape),i=U.computeStrides(t.kernelShape),u=i.length,l=t.pads.length,c=gb(u),p=io(a,"inputDims"),d=io(t.pads,"pads"),T=io(i,"kernelStrides"),w=io(t.strides,"strides"),v=t.pads.reduce((C,F)=>C+F),S="";return v?S=`
            if (x[j] >= inputDims[j] || x[j] < 0) {
              pad++;
              isPad = true;
              break;
            }
          }
          if (!isPad) {
            ${o}
          }`:S=`
          }
          ${o}
        `,`
        ${c}
        float process(int indices[${n}]) {
          int x[${n}];
          copyVec(indices, x);
          int offset[${u}];
          int pads[${l}];
          int inputDims[${n}];
          int kernelStrides[${u}];
          int strides[${u}];
          ${d}
          ${p}
          ${w}
          ${T}

          float value = ${r};
          int pad = 0;
          bool isPad = false;
          for (int i = 0; i < ${s}; i++) {
            offsetToIndices(i, kernelStrides, offset);
            isPad = false;
            for (int j = ${n} - ${u}; j < ${n}; j++) {
              x[j] = indices[j] * strides[j - ${n} + ${u}]
                + offset[j - ${n} + ${u}] - pads[j - 2];
              ${S}
          }
          ${e}

          return value;
        }
      `}},io=(a,t)=>{let o="";for(let e=0;e<a.length;e++)o+=`
      ${t}[${e}] = ${a[e]};
    `;return o},gb=a=>`
  void offsetToIndices(int offset, int[${a}] strides, out int[${a}] indices) {
    if (${a} == 0) {
      return;
    }
    for (int i = 0; i < ${a} - 1; ++i) {
      indices[i] = offset / strides[i];
      offset -= indices[i] * strides[i];
    }
    indices[${a} - 1] = offset;
  }`});var vr,er,yb,Tb,tc,rc,nc,oc,ic,ac,sc,uc=L(()=>{"use strict";Ue();pn();fe();ae();vr=(a,t,o,e,r)=>{Tb(t);let n={name:e,inputNames:["A"],inputTypes:[0]};return[a.run({...n,cacheHint:o.cacheKey,get:()=>yb(a,t,o,e,r,n)},t)]},er=a=>{let t=a.attributes.getInts("axes",[]),o=a.attributes.getInt("keepdims",1)===1;return Q({axes:t,keepDims:o})},yb=(a,t,o,e,r,n)=>{let s=[],i=t[0].dims.length||1,u=[],l=U.normalizeAxes(o.axes,t[0].dims.length),c=r(t,l),p=c[1];for(let w=0;w<t[0].dims.length;w++)l.indexOf(w)>=0||l.length===0?(o.keepDims&&s.push(1),p=`
          for(int j${w} = 0; j${w} < ${t[0].dims[w]}; j${w}++) {
            inputIdx[${w}] = j${w};
            ${p}
          }`):(u.push(`inputIdx[${w}] = outputIdx[${s.length}];`),s.push(t[0].dims[w]));let T=`
      float process(int outputIdx[${s.length||1}]) {
        float value;                 // final result
        int inputIdx[${i}];      // addressing input data
        ${u.join(`
`)}
        ${c[0]}       // init ops for reduce max/min
        ${p}
        ${c[2]}       // final computation for reduce mean
        return value;
      }`;return{...n,output:{dims:s,type:t[0].type,textureType:0},shaderSource:T}},Tb=a=>{if(!a||a.length!==1)throw new Error("Reduce op requires 1 input.");if(Qt.indexOf(a[0].type)===-1)throw new Error("Invalid input type.")},tc=(a,t,o)=>vr(a,t,o,"ReduceSum",()=>["value = 0.0;","value += _A(inputIdx);",""]),rc=(a,t,o)=>vr(a,t,o,"ReduceMean",(r,n)=>{let s=1;for(let i=0;i<r[0].dims.length;i++)(n.indexOf(i)>=0||n.length===0)&&(s*=r[0].dims[i]);return["value = 0.0;","value += _A(inputIdx);",`value /= ${s}.;`]}),nc=(a,t,o)=>vr(a,t,o,"ReduceMax",(r,n)=>{let s=[];for(let i=0;i<r[0].dims.length;i++)(n.indexOf(i)>=0||n.length===0)&&s.push(`inputIdx[${i}] = 0;`);return[`${s.join(`
`)}
value = _A(inputIdx);`,"value = max(value, _A(inputIdx));",""]}),oc=(a,t,o)=>vr(a,t,o,"ReduceMin",(r,n)=>{let s=[];for(let i=0;i<r[0].dims.length;i++)(n.indexOf(i)>=0||n.length===0)&&s.push(`inputIdx[${i}] = 0;`);return[`${s.join(`
`)}
value = _A(inputIdx);`,"value = min(value, _A(inputIdx));",""]}),ic=(a,t,o)=>vr(a,t,o,"ReduceProd",()=>["value = 1.0;","value *= _A(inputIdx);",""]),ac=(a,t,o)=>vr(a,t,o,"ReduceLogSum",()=>["value = 0.0;","value += _A(inputIdx);","value = log(value);"]),sc=(a,t,o)=>vr(a,t,o,"ReduceLogSumSquare",()=>["float t; value = 0.0;","t = _A(inputIdx); value += t * t;",""])});var lc,fc=L(()=>{"use strict";fe();lc=(a,t)=>{let o=U.calculateReshapedDims(t[0].dims,t[1].integerData);return a.session.pack?[a.reshapePacked(t[0],o)]:[a.reshapeUnpacked(t[0],o)]}});var cc,ki,pc,dc,dn,xb,Bi,so,Ni=L(()=>{"use strict";Ue();we();ae();cc={name:"Upsample",inputNames:["X"],inputTypes:[0]},ki=(a,t,o)=>(Bi(t,o),[a.run({...cc,cacheHint:o.cacheKey,get:()=>xb(a,t,o)},t)]),pc=a=>dn(a,7),dc=a=>dn(a,9),dn=(a,t)=>{let o=t>=10,e=a.attributes.getString("mode","nearest");if(e!=="nearest"&&e!=="linear"&&(t<11||e!=="cubic"))throw new Error(`unrecognized mode: ${e}`);let r=[];t<9&&(r=a.attributes.getFloats("scales"),so(r,e,o));let n=a.attributes.getFloat("extrapolation_value",0),s=t>10?a.attributes.getString("coordinate_transformation_mode","half_pixel"):"asymmetric";if(["asymmetric","pytorch_half_pixel","tf_half_pixel_for_nn","align_corners","tf_crop_and_resize","half_pixel"].indexOf(s)===-1)throw new Error(`coordinate_transform_mode '${s}' is not supported`);let i=s==="tf_crop_and_resize",u=i,l=e==="nearest"&&t>=11?a.attributes.getString("nearest_mode","round_prefer_floor"):"";if(["round_prefer_floor","round_prefer_ceil","floor","ceil",""].indexOf(l)===-1)throw new Error(`nearest_mode '${l}' is not supported`);let c=a.attributes.getFloat("cubic_coeff_a",-.75),p=a.attributes.getInt("exclude_outside",0)!==0;if(p&&e!=="cubic")throw new Error("exclude_outside can be set to 1 only when mode is CUBIC.");let d=t<11?!0:e==="nearest"&&s==="asymmetric"&&l==="floor",T=0,w=0,v=0;return t>10?a.inputs.length>2?(T=1,w=2,v=3):(w=1,v=2):t===9&&(w=1),Q({opset:t,isResize:o,mode:e,scales:r,extrapolationValue:n,coordinateTransformMode:s,useExtrapolation:u,needRoiInput:i,nearestMode:l,cubicCoefficientA:c,excludeOutside:p,useNearest2xOptimization:d,roiInputIdx:T,scalesInputIdx:w,sizesInputIdx:v})},xb=(a,t,o)=>{let e=H(a.session.backend.glContext.version),[r,n]=a.calculateTextureWidthAndHeight(t[0].dims,0),s=t[0].dims.map((v,S)=>Math.floor(v*o.scales[S])),[i,u]=a.calculateTextureWidthAndHeight(s,0),l=s.length,c=new Array(l),p=new Array(l),d=`
      int output_pitches[${l}];
      int input_pitches[${l}];
      `;for(let v=l-1;v>=0;v--)c[v]=v===l-1?1:c[v+1]*s[v+1],p[v]=v===l-1?1:p[v+1]*t[0].dims[v+1],d+=`
        output_pitches[${v}] = ${c[v]};
        input_pitches[${v}] = ${p[v]};
        `;let T=`
      float getInputFloat(int index) {
        vec2 coords = offsetToCoords(index, ${r}, ${n});
        float value = getColorAsFloat(${e.texture2D}(X, coords));
        return value;
      }
      `,w=o.mode==="nearest"?`
    ${T}
    float process(int indices[${l}]) {
      int input_index = 0;
      int output_index = coordsToOffset(TexCoords, ${i}, ${u});

      ${d}

      int d, m;
      for (int dim = 0; dim < ${l}; ++dim) {
        d = output_index / output_pitches[dim];
        m = output_index - d * output_pitches[dim];
        output_index = m;

        if (scales[dim] != 1 && d > 0) {
          int d2 = d / scales[dim];
          m = d - d2 * scales[dim];
          d = d2;
        }
        input_index += input_pitches[dim] * d;
      }

      return getInputFloat(input_index);
    }`:l===4?`
    ${T}
    float process(int indices[4]) {
      int input_index = 0;
      int output_index = coordsToOffset(TexCoords, ${i}, ${u});

      ${d}

      int m;
      int index_of_dim0, index_of_dim1, index_of_dim2, index_of_dim3;
      index_of_dim0 = output_index / output_pitches[0];
      m = output_index - index_of_dim0 * output_pitches[0];
      index_of_dim1 = m / output_pitches[1];
      m = m - index_of_dim1 * output_pitches[1];
      index_of_dim2 = m / output_pitches[2];
      m = m - index_of_dim2 * output_pitches[2];
      index_of_dim3 = m;

      int index_of_input_dim2, index_of_input_dim3, x_offset, y_offset;
      index_of_input_dim2 = index_of_dim2 / scales[2];
      y_offset = index_of_dim2 - index_of_input_dim2 * scales[2];
      index_of_input_dim3 = index_of_dim3 / scales[3];
      x_offset = index_of_dim3 - index_of_input_dim3 * scales[3];

      input_index = index_of_dim0 * input_pitches[0] +
            index_of_dim1 * input_pitches[1] +
            index_of_input_dim2 * input_pitches[2] +
            index_of_input_dim3;

      float x00 = getInputFloat(input_index);
      float x10, x01, x11;

      bool end_of_dim2 = false;
      if (index_of_input_dim2 == (${t[0].dims[2]} - 1)) {
        // It's the end in dimension 2
        x01 = x00;
        end_of_dim2 = true;
      } else {
        x01 = getInputFloat(input_index + input_pitches[2]);
      }

      if (index_of_input_dim3 == (input_pitches[2] - 1)) {
        // It's the end in dimension 3
        x10 = x00;
        x11 = x01;
      }
      else {
        x10 = getInputFloat(input_index + 1);
        x11 = end_of_dim2 ? x10 : getInputFloat(input_index + input_pitches[2] + 1);
      }

      float y0 = x00 + float(y_offset) * (x01 - x00) / float(scales[2]);
      float y1 = x10 + float(y_offset) * (x11 - x10) / float(scales[2]);
      return y0 + float(x_offset) * (y1 - y0) / float(scales[3]);
    }`:`
    ${T}
    float process(int indices[2]) {
      int input_index = 0;
      int output_index = coordsToOffset(TexCoords, ${i}, ${u});

      ${d}

      int m;
      int index_of_dim0, index_of_dim1;
      index_of_dim0 = output_index / output_pitches[0];
      m = output_index - index_of_dim0 * output_pitches[0];
      index_of_dim1 = m;

      int index_of_input_dim0, index_of_input_dim1, x_offset, y_offset;
      index_of_input_dim0 = index_of_dim0 / scales[0];
      y_offset = index_of_dim0 - index_of_input_dim0 * scales[0];
      index_of_input_dim1 = index_of_dim1 / scales[1];
      x_offset = index_of_dim1 - index_of_input_dim1 * scales[1];

      input_index = index_of_input_dim0 * input_pitches[0] + index_of_input_dim1;

      float x00 = getInputFloat(input_index);
      float x10, x01, x11;

      bool end_of_dim0 = false;
      if (index_of_input_dim0 == (${t[0].dims[0]} - 1)) {
        // It's the end in dimension 0
        x01 = x00;
        end_of_dim0 = true;
      } else {
        x01 = getInputFloat(input_index + input_pitches[0]);
      }

      if (index_of_input_dim1 == (input_pitches[0] - 1)) {
        // It's the end in dimension 1
        x10 = x00;
        x11 = x01;
      }
      else {
        x10 = getInputFloat(input_index + 1);
        x11 = end_of_dim0 ? x10 : getInputFloat(input_index + input_pitches[0] + 1);
      }

      float y0 = x00 + float(y_offset) * (x01 - x00) / float(scales[0]);
      float y1 = x10 + float(y_offset) * (x11 - x10) / float(scales[0]);
      return y0 + float(x_offset) * (y1 - y0) / float(scales[1]);
    }`;return{...cc,output:{dims:s,type:t[0].type,textureType:0},shaderSource:w,variables:[{name:"scales",type:"int",arrayLength:o.scales.length,data:o.scales.map(v=>Math.ceil(v))}]}},Bi=(a,t)=>{if(!a||t.opset<9&&a.length!==1||t.opset>=9&&t.opset<11&&a.length!==2||t.opset>=11&&a.length<2)throw new Error("invalid inputs.");if(t.scales.length>0&&a[0].dims.length!==t.scales.length)throw new Error("Invalid input shape.");if(a[0].type==="string")throw new Error("Invalid input tensor types.")},so=(a,t,o)=>{if(o){for(let e of a)if(e<=0)throw new Error("Scale value should be greater than 0.")}else for(let e of a)if(e<1)throw new Error("Scale value should be greater than or equal to 1.");if((t==="linear"||t==="cubic")&&a.length!==2&&(a.length!==4||a[0]!==1||a[1]!==1))throw new Error(`'Linear' mode and 'Cubic' mode only support 2-D inputs ('Bilinear', 'Bicubic')         or 4-D inputs with the corresponding outermost 2 scale values being 1         in the ${o?"Resize":"Upsample"} opeartor.`)}});var Ri,Mi,hc,mc,wb,vb,_b,Ob,bc=L(()=>{"use strict";we();ae();Bt();Tr();Ni();Ri={name:"Resize",inputNames:["A"],inputTypes:[2]},Mi=(a,t,o)=>(Bi(t,o),[a.run({...Ri,cacheHint:o.cacheKey,get:()=>wb(a,t,o)},t)]),hc=a=>dn(a,10),mc=a=>dn(a,11),wb=(a,t,o)=>{let e=H(a.session.backend.glContext.version),[r,n]=vb(t,o);if(r.every(F=>F===1)&&o.coordinateTransformMode!=="tf_crop_and_resize")return{...Ri,output:{dims:n,type:t[0].type,textureType:2},hasMain:!0,shaderSource:`void main() {
                    vec4 v = ${e.texture2D}(X, TexCoords);
                    ${e.output} = v;
                }`};let i=n.length;if(i<2)throw new Error(`output dimension should be at least 2, but got ${i}`);let u=n[i-2],l=n[i-1],c=t[0].dims;if(i!==c.length)throw new Error(`output dimension should match input ${c.length}, but got ${i}`);let p=c[i-2],d=c[i-1],T=r[i-2],w=r[i-1],v="";if(o.mode!=="linear")throw new Error(`resize (packed) does not support mode: '${o.mode}'`);switch(o.coordinateTransformMode){case"asymmetric":v=`
                    vec4 getSourceFracIndex(ivec4 coords) {
                        return vec4(coords) / scaleWHWH;
                    }
                `;break;case"half_pixel":v=`
                    vec4 getSourceFracIndex(ivec4 coords) {
                        return (vec4(coords) + 0.5) / scaleWHWH - 0.5;
                    }
                `;break;case"pytorch_half_pixel":v=`
                    vec4 getSourceFracIndex(ivec4 coords) {
                        vec4 fcoords = vec4(coords);
                        return vec4(
                            ${l}.0 > 1.0 ? (fcoords.x + 0.5) / scaleWHWH.x - 0.5 : 0.0,
                            ${u}.0 > 1.0 ? (fcoords.y + 0.5) / scaleWHWH.y - 0.5 : 0.0,
                            ${l}.0 > 1.0 ? (fcoords.z + 0.5) / scaleWHWH.z - 0.5 : 0.0,
                            ${u}.0 > 1.0 ? (fcoords.w + 0.5) / scaleWHWH.w - 0.5 : 0.0
                          );
                    }
                `;break;case"align_corners":v=`
                    vec4 getSourceFracIndex(ivec4 coords) {
                        vec4 resized = vec4(${l}.0 - 1.0, ${u}.0 - 1.0, ${l}.0 - 1.0,
                            ${u}.0 - 1.0);
                        vec4 original = vec4(${d}.0 - 1.0, ${p}.0 - 1.0, ${d}.0 - 1.0,
                            ${p}.0 - 1.0);
                        vec4 new_scale = original / resized;
                        return vec4(coords) * new_scale;
                    }
                `;break;default:throw new Error(`resize (packed) does not support coordinateTransformMode:                                 '${o.coordinateTransformMode}'`)}let S=Qe(i),A=Nt(),C=`
            const vec2 inputWH = vec2(${p}.0, ${d}.0);
            const vec4 scaleWHWH = vec4(float(${T}), float(${w}), float(${T}), float(${w}));
            ${A}
            ${v}
            float getAValue(int x10, int r, int c, int d) {
                return getChannel(getA(x10, r, c, d), vec2(c, d));
            }
            void main() {
                ${S} rc = getOutputCoords();

                int batch = rc[0];
                int depth = rc[1];

                // retrieve the 4 coordinates that is used in the 4 packed output values.
                ivec4 coords = ivec4(rc.wz, rc.w + 1, rc.z + 1);

                // calculate the source index in fraction
                vec4 sourceFrac = getSourceFracIndex(coords);

                // get the lower and upper bound of the 4 values that will be packed into one texel.
                ivec4 x00 = ivec4(max(sourceFrac.xy, vec2(0.0)), min(inputWH - 1.0, ceil(sourceFrac.xy)));
                ivec4 x01 = ivec4(max(sourceFrac.xw, vec2(0.0)), min(inputWH - 1.0, ceil(sourceFrac.xw)));
                ivec4 x10 = ivec4(max(sourceFrac.zy, vec2(0.0)), min(inputWH - 1.0, ceil(sourceFrac.zy)));
                ivec4 x11 = ivec4(max(sourceFrac.zw, vec2(0.0)), min(inputWH - 1.0, ceil(sourceFrac.zw)));

                bool hasNextRow = rc.w < ${u-1};
                bool hasNextCol = rc.z < ${l-1};

                // pack x00, x01, x10, x11's top-left corner into one vec4 structure
                vec4 topLeft = vec4(
                    getAValue(batch, depth, x00.x, x00.y),
                    hasNextCol ? getAValue(batch, depth, x01.x, x01.y) : 0.0,
                    hasNextRow ? getAValue(batch, depth, x10.x, x10.y) : 0.0,
                    (hasNextRow && hasNextCol) ? getAValue(batch, depth, x11.x, x11.y) : 0.0);

                // pack x00, x01, x10, x11's top-right corner into one vec4 structure
                vec4 topRight = vec4(
                    getAValue(batch, depth, x00.x, x00.w),
                    hasNextCol ? getAValue(batch, depth, x01.x, x01.w) : 0.0,
                    hasNextRow ? getAValue(batch, depth, x10.x, x10.w) : 0.0,
                    (hasNextRow && hasNextCol) ? getAValue(batch, depth, x11.x, x11.w) : 0.0);

                // pack x00, x01, x10, x11's bottom-left corner into one vec4 structure
                vec4 bottomLeft = vec4(
                    getAValue(batch, depth, x00.z, x00.y),
                    hasNextCol ? getAValue(batch, depth, x01.z, x01.y) : 0.0,
                    hasNextRow ? getAValue(batch, depth, x10.z, x10.y) : 0.0,
                    (hasNextRow && hasNextCol) ? getAValue(batch, depth, x11.z, x11.y) : 0.0);

                // pack x00, x01, x10, x11's bottom-right corner into one vec4 structure
                vec4 bottomRight = vec4(
                    getAValue(batch, depth, x00.z, x00.w),
                    hasNextCol ? getAValue(batch, depth, x01.z, x01.w) : 0.0,
                    hasNextRow ? getAValue(batch, depth, x10.z, x10.w) : 0.0,
                    (hasNextRow && hasNextCol) ? getAValue(batch, depth, x11.z, x11.w) : 0.0);

                // calculate the interpolation fraction on u and v direction
                vec4 frac = vec4(sourceFrac) - floor(sourceFrac);
                vec4 clampFrac = clamp(frac, vec4(0.0), vec4(1.0));

                vec4 top = mix(topLeft, topRight, clampFrac.ywyw);
                vec4 bottom = mix(bottomLeft, bottomRight, clampFrac.ywyw);
                vec4 newValue = mix(top, bottom, clampFrac.xxzz);

                ${e.output} = vec4(newValue);
            }
        `;return{...Ri,output:{dims:n,type:t[0].type,textureType:2},hasMain:!0,shaderSource:C}},vb=(a,t)=>{let e=a[0].dims,r=t.scales,n;if(r.length===0){let i=a[t.scalesInputIdx];if(i&&i.size!==0){if(a[t.sizesInputIdx])throw new Error("Only one of scales or sizes must be provided as input.");r=_b(i,t.mode,t.isResize)}else{let u=a[t.sizesInputIdx];if(!u||u.size===0)throw new Error("Either scales or sizes MUST be provided as input.");n=Array.from(u.integerData),r=Ob(n,e,t.mode,t.isResize)}}else if(a[t.sizesInputIdx])throw new Error("Only one of scales or sizes must be provided as input.");let s=n||e.map((i,u)=>Math.floor(i*r[u]));return[r,s]},_b=(a,t,o)=>{let e=Array.from(a.floatData);return so(e,t,o),e},Ob=(a,t,o,e)=>{let r=t.length,n=new Array(r);for(let s=0,i=r;s<i;s++)if(t[s]===0){if(a[s]!==0)throw new Error("Input dim is zero but required output dim is non-zero.");n[s]=1}else n[s]=a[s]/t[s];return so(n,o,e),n}});var gc,Ib,yc=L(()=>{"use strict";yr();gc=(a,t)=>(Ib(t),[new $e([t[0].dims.length],"int32",void 0,void 0,new Int32Array(t[0].dims))]),Ib=a=>{if(!a||a.length!==1)throw new Error("Shape requires 1 input.")}});var Gi,Tc,xc,wc,Sb,vc,Ab,Pb,_c=L(()=>{"use strict";Ue();pn();fe();ae();Gi={name:"Slice",inputNames:["A"],inputTypes:[0]},Tc=(a,t,o)=>(Sb(t),[a.run({...Gi,cacheHint:o.cacheKey,get:()=>wc(a,t[0],o)},t)]),xc=a=>{let t=a.attributes.getInts("starts"),o=a.attributes.getInts("ends"),e=a.attributes.getInts("axes",[]);return Q({starts:t,ends:o,axes:e})},wc=(a,t,o)=>{let e=o.axes.length===0?t.dims.slice(0).map((p,d)=>d):o.axes,r=U.normalizeAxes(e,t.dims.length),n=o.starts.map((p,d)=>p>t.dims[r[d]]-1?t.dims[r[d]]:U.normalizeAxis(p,t.dims[r[d]])),s=o.ends.map((p,d)=>p>t.dims[r[d]]-1?t.dims[r[d]]:U.normalizeAxis(p,t.dims[r[d]])),i=t.dims.slice(),u=[];for(let p=0;p<r.length;p++)i[r[p]]=s[p]-n[p],n[p]>0&&u.push(`outputIdx[${r[p]}] += ${n[p]};`);let c=`
      float process(int outputIdx[${i.length}]) {
        ${u.join(`
      `)}
        return _A(outputIdx);
      }`;return{...Gi,output:{dims:i,type:t.type,textureType:0},shaderSource:c}},Sb=a=>{if(!a||a.length!==1)throw new Error("Slice requires 1 input.");if(Qt.indexOf(a[0].type)===-1)throw new Error("Invalid input type.")},vc=(a,t)=>{Pb(t);let o=Ab(a,t);return[a.run({...Gi,cacheHint:o.cacheKey,get:()=>wc(a,t[0],o)},[t[0]])]},Ab=(a,t)=>{if(!a.session.isInitializer(t[1].dataId)||!a.session.isInitializer(t[2].dataId)||t.length>=4&&!a.session.isInitializer(t[3].dataId)||t.length>=5&&!a.session.isInitializer(t[4].dataId))throw new Error("dynamic slice attributes are not allowed");if(t.length>=5&&t[4].integerData.some(s=>s!==1))throw new Error("currently non-1 steps is not supported for Slice");let o=Array.from(t[1].integerData),e=Array.from(t[2].integerData),r=t.length>=4?Array.from(t[3].integerData):[],n=`${r};${o};${e}`;return{starts:o,ends:e,axes:r,cacheKey:n}},Pb=a=>{if(!a||a.length<3||a.length>5)throw new Error("Invalid input number.");if(a[1].type!=="int32"||a[1].dims.length!==1)throw new Error("Invalid input type.");if(a[2].type!=="int32"||a[2].dims.length!==1)throw new Error("Invalid input type.");if(a.length>=4&&(a[3].type!=="int32"||a[3].dims.length!==1))throw new Error("Invalid input type.");if(a.length>=5&&(a[4].type!=="int32"||a[4].dims.length!==1))throw new Error("Invalid input type.")}});var Oc,Ic,Sc,Ac,Pc,Ec,Dc,Lc,Eb,Db,Lb,Cc,Fc=L(()=>{"use strict";Ue();fe();we();ae();oo();Oc={name:"SoftmaxComputeMax",inputNames:["A"],inputTypes:[0]},Ic={name:"SoftmaxComputeScale",inputNames:["A","Max"],inputTypes:[0,0]},Sc={name:"SoftMax",inputNames:["A","Max","Norm"],inputTypes:[0,0,0]},Ac=(a,t,o)=>{Cc(t);let e=t[0].dims.slice(),r=U.normalizeAxis(o.axis,e.length),n=U.sizeToDimension(e,r),s=U.sizeFromDimension(e,r);return Lc(a,t,o,n,s)},Pc=a=>Q({axis:a.attributes.getInt("axis",1)}),Ec=a=>Q({axis:a.attributes.getInt("axis",-1)}),Dc=(a,t,o)=>{Cc(t);let e=t[0].dims.slice(),r=U.normalizeAxis(o.axis,e.length),n=e.length,s=r!==n-1,i=[],u=[],l=[],c;s&&(u=Array.from({length:n}).map((w,v)=>v),u[r]=n-1,u[n-1]=r,u.map(w=>i.push(e[w])),c=Q({perm:u}),l=wr(a,t,c));let p=s?U.sizeToDimension(i,n-1):U.sizeToDimension(e,n-1),d=s?U.sizeFromDimension(i,n-1):U.sizeFromDimension(e,n-1),T=Lc(a,s?l:t,o,p,d);return s?wr(a,T,c):T},Lc=(a,t,o,e,r)=>{let n=Eb(a,t[0],e,r,[e]),s=a.run({...Oc,cacheHint:o.cacheKey,get:()=>n},t),i=Db(a,t[0],e,r,n.output.dims,[e]),u=a.run({...Ic,cacheHint:o.cacheKey,get:()=>i},[t[0],s]),l=Lb(a,t[0],e,r,n.output.dims,i.output.dims);return[a.run({...Sc,cacheHint:o.cacheKey,get:()=>l},[t[0],s,u])]},Eb=(a,t,o,e,r)=>{let[n,s]=a.calculateTextureWidthAndHeight(t.dims,0),i=r.length;if(o<1||e<1)throw new Error("Logical row count N and feature count D must be greater than or equal to 1");if(r.length!==1)throw new Error("Dimensionality of the output should be 1");if(r[0]!==o)throw new Error("Shape of the output should be equal to logical row count");let u=H(a.session.backend.glContext.version),l=`
      float process(int[${i}] indices) {
        int logical_row_start_offset = indices[0] * ${e};

        float max = getColorAsFloat(${u.texture2D}(A, offsetToCoords(logical_row_start_offset, ${n},
        ${s} )));
        for(int i=1; i<${e}; ++i)
        {
          float current = getColorAsFloat(${u.texture2D}(A, offsetToCoords(logical_row_start_offset + i,
            ${n}, ${s})));
          if(current > max)
          max = current;
        }

        return max;
      }`;return{...Oc,output:{dims:r,type:t.type,textureType:0},shaderSource:l}},Db=(a,t,o,e,r,n)=>{let[s,i]=a.calculateTextureWidthAndHeight(t.dims,0),u=n.length;if(o<1||e<1)throw new Error("Logical row count N and feature count D must be greater than or equal to 1");if(n.length!==1)throw new Error("Dimensionality of the output should be 1");if(n[0]!==o)throw new Error("Shape of the output should be equal to logical row count");if(r.length!==1)throw new Error("Dimensionality of the intermediate results should be 1");if(r[0]!==o)throw new Error("Shape of the intermediate results should be equal to logical row count");let l=H(a.session.backend.glContext.version),c=`
      float process(int[${u}] indices) {
        int logical_row_start_offset = indices[0] * ${e};

        float norm_factor = 0.0;
        float max = _Max(indices);
        for(int i=0; i<${e}; ++i)
        {
          norm_factor += exp(getColorAsFloat(${l.texture2D}(A, offsetToCoords(logical_row_start_offset + i,
            ${s}, ${i}))) - max);
        }

        return norm_factor;
      }`;return{...Ic,output:{dims:n,type:t.type,textureType:0},shaderSource:c}},Lb=(a,t,o,e,r,n)=>{let[s,i]=a.calculateTextureWidthAndHeight(t.dims,0),u=t.dims.length;if(o<1||e<1)throw new Error("Logical row count N and feature count D must be greater than or equal to 1");if(r.length!==1||n.length!==1)throw new Error("Dimensionality of the intermediate results should be 1");if(r[0]!==o||n[0]!==o)throw new Error("Shape of the intermediate results should be equal to logical row count");let l=`
      float process(int[${u}] indices) {

      // get offset of current logical tensor index from the 2-D texture coordinates (TexCoords)
      int offset = coordsToOffset(TexCoords, ${s}, ${i});

      //determine the logical row for this index
      int logical_row_index[1];
      logical_row_index[0] = offset / ${e};

      float norm_factor = _Norm(logical_row_index);

      // avoid possible division by 0
      // if norm_facor is 0, all elements are zero
      // if so, return 0
      if(norm_factor == 0.0)
        return 0.0;

      return exp(_A(indices) - _Max(logical_row_index)) / norm_factor;
    }`;return{...Sc,output:{dims:t.dims,type:t.type,textureType:0},shaderSource:l}},Cc=a=>{if(!a||a.length!==1)throw new Error("Softmax requires 1 input.");if(a[0].type!=="float32"&&a[0].type!=="float64")throw new Error("Invalid input type")}});var $c,kc,Bc,Cb,Fb,$b,Nc=L(()=>{"use strict";Ue();fe();ae();$c={name:"Split",inputNames:["A"],inputTypes:[0]},kc=(a,t,o)=>{$b(t);let e=U.normalizeAxis(o.axis,t[0].dims.length),r=Cb(a,t,e,o),n=[];for(let s=0;s<r;++s)n.push(a.run({...$c,cacheHint:`${o.cacheKey};${s}`,get:()=>Fb(a,t[0],o,e,s)},t));return n},Bc=a=>{let t=a.attributes.getInt("axis",0),o=a.attributes.getInts("split",[]),e=a.outputs.length;return Q({axis:t,split:o,numOutputs:e})},Cb=(a,t,o,e)=>{let[,r]=an.splitShape(t[0].dims,o,e.split,e.numOutputs);return r.length},Fb=(a,t,o,e,r)=>{let[n,s]=an.splitShape(t.dims,e,o.split,o.numOutputs),i=s[r],u=n[r],c=`
      float process(int indices[${u.length}]) {
        indices[${e}] += ${i};
        return _A(indices);
      }
    `;return{...$c,cacheHint:`${o.cacheKey}:${r}`,output:{dims:u,type:t.type,textureType:0},shaderSource:c}},$b=a=>{if(!a||a.length!==1)throw new Error("Split requires one input.");if(a[0].type!=="int8"&&a[0].type!=="uint8"&&a[0].type!=="int16"&&a[0].type!=="uint16"&&a[0].type!=="int32"&&a[0].type!=="uint32"&&a[0].type!=="float32"&&a[0].type!=="float64"&&a[0].type!=="bool")throw new Error("Invalid input type.")}});var Ui,Rc,Mc,kb,Bb,Gc=L(()=>{"use strict";fe();Ui=(a,t,o)=>{kb(t);let e=U.squeezeShape(t[0].dims,o);return[a.reshapeUnpacked(t[0],e)]},Rc=(a,t)=>(Bb(t),Ui(a,[t[0]],Array.from(t[1].integerData))),Mc=a=>a.attributes.getInts("axes"),kb=a=>{if(!a||a.length!==1)throw new Error("Squeeze requires 1 input.");if(a[0].type==="string")throw new Error("invalid input tensor types.")},Bb=a=>{if(!a||a.length!==2)throw new Error("Squeeze requires 2 inputs.");if(a[1].type!=="int32")throw new Error("Invalid input type.")}});var Uc,Nb,Rb,zc=L(()=>{"use strict";we();ae();Uc=(a,t)=>{Rb(t);let o={name:"Sum",inputNames:t.map((r,n)=>`X${n}`),inputTypes:new Array(t.length).fill(0)};return[a.run({...o,get:()=>Nb(a,t,o)},t)]},Nb=(a,t,o)=>{let e=H(a.session.backend.glContext.version),r=t[0].dims.slice(),s=`
      void main() {
        vec4 result = ${t.map((i,u)=>`${e.texture2D}(X${u},TexCoords)`).join(" + ")};
        ${e.output} = result;
      }
    `;return{...o,output:{dims:r,type:t[0].type,textureType:0},hasMain:!0,shaderSource:s}},Rb=a=>{if(!a||a.length===0)throw new Error("Sum requires inputs.");let t=a[0].dims.length;for(let o=1;o<a.length;o++){if(t!==a[o].dims.length)throw new Error("Input shapes are mismatched.");for(let e=0;e<t;e++)if(a[0].dims[e]!==a[o].dims[e])throw new Error("Input shapes are not matched.")}if(a[0].type!=="float32"&&a[0].type!=="float64")throw new Error("Invalid input type.");for(let o=1;o<a.length;o++)if(a[0].type!==a[o].type)throw new Error("Input types are not matched.")}});var Vc,Mb,Gb,Wc=L(()=>{"use strict";pn();ae();Vc=(a,t)=>{Gb(t);let o={name:"Tile",inputNames:["A"],inputTypes:[0]};return[a.run({...o,get:()=>Mb(a,t,o)},t)]},Mb=(a,t,o)=>{let e=t[0].dims.slice(),r=new Array(e.length),n=[];for(let u=0;u<e.length;u++)r[u]=e[u]*t[1].numberData[u],n.push(`inputIdx[${u}] = int(mod(float(outputIdx[${u}]), ${e[u]}.));`);let s=r.length,i=`
      float process(int outputIdx[${s}]) {
        int inputIdx[${s}];
        ${n.join(`
`)}
        return _A(inputIdx);
      }
    `;return{...o,output:{dims:r,type:t[0].type,textureType:0},shaderSource:i}},Gb=a=>{if(!a||a.length!==2)throw new Error("Tile requires 2 input.");if(a[1].dims.length!==1)throw new Error("The second input shape must 1 dimension.");if(a[1].dims[0]!==a[0].dims.length)throw new Error("Invalid input shape.");if(Qt.indexOf(a[0].type)===-1)throw new Error("Invalid input type.");if(a[1].type!=="int32"&&a[1].type!=="int16")throw new Error("Invalid repeat type.")}});var zi,Hc,qc,Ub,zb,jc=L(()=>{"use strict";fe();zi=(a,t,o)=>{Ub(t);let e=U.unsqueezeShape(t[0].dims,o);return[a.reshapeUnpacked(t[0],e)]},Hc=(a,t)=>(zb(t),zi(a,[t[0]],Array.from(t[1].integerData))),qc=a=>a.attributes.getInts("axes"),Ub=a=>{if(!a||a.length!==1)throw new Error("Unsqueeze requires 1 input.");if(a[0].type==="string")throw new Error("invalid input tensor types.")},zb=a=>{if(!a||a.length!==2)throw new Error("Unsqueeze requires 2 inputs.");if(a[1].type!=="int32")throw new Error("Invalid input type.")}});var Yc,Xc=L(()=>{"use strict";ol();gl();xl();Sl();to();ff();bf();Tf();vf();Sf();Ef();Ff();Nf();ro();Uf();ec();uc();fc();bc();yc();_c();Fc();Nc();Gc();zc();Wc();oo();Ii();jc();Ni();Yc=[["Abs","","6+",Al],["Acos","","7+",Pl],["Add","","7+",il],["And","","7+",al],["Asin","","7+",El],["Atan","","7+",Dl],["AveragePool","","7+",Vf,Wf],["BatchNormalization","","7+",rl,nl],["Cast","","6+",yl,Tl],["Ceil","","6+",Fl],["Clip","","6-10",_i,Ll],["Clip","","11+",Cl],["Concat","","4+",_l,Il],["Conv","","1+",Li,Ci],["ConvTranspose","","1+",uf,lf],["Cos","","7+",$l],["Div","","7+",sl],["Dropout","","7+",Oi],["DepthToSpace","","1+",hf,mf],["Equal","","7+",ul],["Elu","","6+",kl,Bl],["Exp","","6+",Nl],["Flatten","","1+",gf,yf],["Floor","","6+",Rl],["FusedConv","com.microsoft","1+",Li,Ci],["Gather","","1+",xf,wf],["Gemm","","7-10",Fi,Of],["Gemm","","11+",Fi,If],["GlobalAveragePool","","1+",qf,jf],["GlobalMaxPool","","1+",Zf],["Greater","","7+",ll],["Identity","","1+",Oi],["ImageScaler","","1+",Af,Pf],["InstanceNormalization","","6+",Lf,Cf],["LeakyRelu","","6+",Ml,Gl],["Less","","7+",fl],["LRN","","1+",$f,kf],["Log","","6+",Ul],["MatMul","","1+",ef,tf],["MaxPool","","1+",Yf,Xf],["Mul","","7+",cl],["Neg","","6+",zl],["Not","","1+",Vl],["Or","","7+",pl],["Pad","","2-10",$i,Rf],["Pad","","11+",Mf,Gf],["Pow","","7+",dl],["PRelu","","7+",hl],["ReduceLogSum","","1+",ac,er],["ReduceMax","","1+",nc,er],["ReduceMean","","1+",rc,er],["ReduceMin","","1+",oc,er],["ReduceProd","","1+",ic,er],["ReduceSum","","1-12",tc,er],["ReduceSumSquare","","1+",sc,er],["Relu","","6+",Wl],["Reshape","","5+",lc],["Resize","","10",Mi,hc],["Resize","","11+",Mi,mc],["Shape","","1+",gc],["Sigmoid","","6+",Hl],["Sin","","7+",ql],["Slice","","10+",vc],["Slice","","1-9",Tc,xc],["Softmax","","1-12",Ac,Pc],["Softmax","","13+",Dc,Ec],["Split","","2-12",kc,Bc],["Sqrt","","6+",jl],["Squeeze","","1-12",Ui,Mc],["Squeeze","","13+",Rc],["Sub","","7+",ml],["Sum","","6+",Uc],["Tan","","7+",Yl],["Tanh","","6+",Xl],["Tile","","6+",Vc],["Transpose","","1+",wr,pf],["Upsample","","7-8",ki,pc],["Upsample","","9",ki,dc],["Unsqueeze","","1-12",zi,qc],["Unsqueeze","","13+",Hc],["Xor","","7+",bl]]});function Jc(a){let t={},o;for(;(o=Kc.exec(a))!==null;){let e=o[3].split(",").map(r=>{let n=r.trim().split(" ");return n&&n.length===2?{type:n[0],name:n[1]}:null}).filter(r=>r!==null);t[o[2]]={params:e,body:o[4]}}for(let e in t){let r=Vb.replace("__FUNC__",e),n=new RegExp(r,"gm");for(;(o=n.exec(a))!==null;){let s=o[1],i=o[2],u=o[3].split(","),l=s?`${s} ${i};`:"",c=t[e].body,p="";t[e].params.forEach((T,w)=>{T&&(p+=`${T.type} ${T.name} = ${u[w]};
`)}),c=`${p}
 ${c}`,c=c.replace("return",`${i} = `);let d=`
      ${l}
      {
        ${c}
      }
      `;a=a.replace(o[0],d)}}return a=a.replace(Kc,""),a}var Kc,Vb,Zc=L(()=>{"use strict";Kc=/@inline[\s\n\r]+(\w+)[\s\n\r]+([0-9a-zA-Z_]+)\s*\(([^)]*)\)\s*{(([^}]|[\n\r])*)}/gm,Vb="(\\w+)?\\s+([_0-9a-zA-Z]+)\\s+=\\s+__FUNC__\\((.*)\\)\\s*;"});function Mr(a,t){let o=[],e=[],r=t!=null&&Array.isArray(t)&&t.length===0,n=t==null||r?null:Wb(t,a).sort(),s=0;for(let i=0;i<a.length;++i){if(n!=null){if(n[s]===i&&a[i]!==1)throw new Error(`Can't squeeze axis ${i} since its dim '${a[i]}' is not 1`);(n[s]==null||n[s]>i)&&a[i]===1&&(o.push(a[i]),e.push(i)),n[s]<=i&&s++}a[i]!==1&&(o.push(a[i]),e.push(i))}return{newShape:o,keptDims:e}}function Wb(a,t){let o=t.length;return a=a==null?t.map((e,r)=>r):[].concat(a),Fr(a.every(e=>e>=-o&&e<o),()=>`All values in axis param must be in range [-${o}, ${o}) but got axis ${a}`),Fr(a.every(Hb),()=>`All values in axis param must be integers but got axis ${a}`),a.map(e=>e<0?o+e:e)}function Hb(a){return a%1===0}function qb(a){if(a.length===0)return 1;let t=a[0];for(let o=1;o<a.length;o++)t*=a[o];return t}function Qc(a){let t=Math.ceil(Math.sqrt(a));return[t,Math.ceil(a/t)]}var uo,Vi=L(()=>{"use strict";lt();fe();uo=class{constructor(t){this.maxTextureSize=t}computeTextureWH(t,o){let e=this.computeTexture(t,o);return o&&o.isPacked&&(e[0]/=2,e[1]/=2),o&&o.reverseWH?[e[1],e[0]]:e}computeTexture(t,o){let e=o&&o.isPacked;if(t.length===0)return e?[2,2]:[1,1];let r=this.maxTextureSize;if(o&&o.breakAxis!==void 0){let i=o.breakAxis>=t.length?1:t.slice(o.breakAxis).reduce((l,c)=>l*c),u=o.breakAxis<=0?1:t.slice(0,o.breakAxis).reduce((l,c)=>l*c);if(i>r||u>r)ce.verbose("TextureLayout",`Given width/height preferences were unattainable: shape:${t}, breakAxis:${o.breakAxis}`);else return[i,u]}let n=t.slice(0);e&&(r=r*2,n=n.map((i,u)=>u>=n.length-2?n[u]%2===0?n[u]:n[u]+1:n[u]),n.length===1&&(n=[2,n[0]])),n.length!==2&&(n=Mr(n).newShape);let s=qb(n);return n.length<=1&&s<=r?[1,s]:n.length===2&&n[0]<=r&&n[1]<=r?n:n.length===3&&n[0]*n[1]<=r&&n[2]<=r?[n[0]*n[1],n[2]]:n.length===3&&n[0]<=r&&n[1]*n[2]<=r?[n[0],n[1]*n[2]]:n.length===4&&n[0]*n[1]*n[2]<=r&&n[3]<=r?[n[0]*n[1]*n[2],n[3]]:n.length===4&&n[0]<=r&&n[1]*n[2]*n[3]<=r?[n[0],n[1]*n[2]*n[3]]:e?Qc(s/4).map(i=>i*2):Qc(s)}}});var lo,ep=L(()=>{"use strict";fe();Wt();we();Vi();Bt();lo=class extends dt{constructor(o){super(o)}getFunctions(){return{...this.offsetToCoords(),...this.coordsToOffset(),...this.toVec(),...this.valueFrom(),...this.getCommonUtilFuncs(),...this.getInputsSamplingSnippets(),...this.getOutputSamplingSnippet()}}getCustomTypes(){return{}}offsetToCoords(){let o="offsetToCoords";return{offsetToCoords:new R(`
      vec2 ${o}(int offset, int width, int height) {
        int t = offset / width;
        int s = offset - t*width;
        vec2 coords = (vec2(s,t) + vec2(0.5,0.5)) / vec2(width, height);
        return coords;
      }
      `)}}coordsToOffset(){let o="coordsToOffset";return{coordsToOffset:new R(`
      int ${o}(vec2 coords, int width, int height) {
        float s = coords.s * float(width);
        float t = coords.t * float(height);
        int offset = int(t) * width + int(s);
        return offset;
      }
      `)}}getOutputSamplingSnippet(){let o=this.context.outputTextureLayout;return o.isPacked?this.getPackedOutputSamplingSnippet(o):this.getUnpackedOutputSamplingSnippet(o)}getPackedOutputSamplingSnippet(o){let e=o.unpackedShape,r=[o.width,o.height],n={},s="getOutputCoords";switch(e.length){case 0:n[s]=this.getOutputScalarCoords();break;case 1:n[s]=this.getOutputPacked1DCoords(e,r);break;case 2:n[s]=this.getOutputPacked2DCoords(e,r);break;case 3:n[s]=this.getOutputPacked3DCoords(e,r);break;default:n[s]=this.getOutputPackedNDCoords(e,r)}let u=`
      void setOutput(vec4 val) {
        ${H(this.context.glContext.version).output} = val;
      }
    `,l="floatTextureSetRGBA";return n[l]=new R(u),n}getUnpackedOutputSamplingSnippet(o){let e=o.unpackedShape,r=[o.width,o.height],n={},s="getOutputCoords";switch(e.length){case 0:n[s]=this.getOutputScalarCoords();break;case 1:n[s]=this.getOutputUnpacked1DCoords(e,r);break;case 2:n[s]=this.getOutputUnpacked2DCoords(e,r);break;case 3:n[s]=this.getOutputUnpacked3DCoords(e,r);break;case 4:n[s]=this.getOutputUnpacked4DCoords(e,r);break;case 5:n[s]=this.getOutputUnpacked5DCoords(e,r);break;case 6:n[s]=this.getOutputUnpacked6DCoords(e,r);break;default:throw new Error(`Unsupported output dimensionality: ${e.length}`)}let u=`
        void setOutput(float val) {
          ${H(this.context.glContext.version).output} = vec4(val, 0, 0, 0);
        }
    `,l="floatTextureSetR";return n[l]=new R(u),n}getOutputScalarCoords(){return new R(`
      int getOutputCoords() {
        return 0;
      }
    `)}getOutputPacked1DCoords(o,e){let r=e,n="";return r[0]===1?(n=`
          int getOutputCoords() {
            return 2 * int(TexCoords.y * ${r[1]}.0);
          }
        `,new R(n)):r[1]===1?(n=`
          int getOutputCoords() {
            return 2 * int(TexCoords.x * ${r[0]}.0);
          }
        `,new R(n)):(n=`
        int getOutputCoords() {
          ivec2 resTexRC = ivec2(TexCoords.xy *
                                 vec2(${r[0]}, ${r[1]}));
          return 2 * (resTexRC.y * ${r[0]} + resTexRC.x);
        }
      `,new R(n))}getOutputPacked2DCoords(o,e){let r="";if(hr.arraysEqual(o,e))return r=`
        ivec2 getOutputCoords() {
          return 2 * ivec2(TexCoords.xy * vec2(${e[0]}, ${e[1]}));
        }
      `,new R(r);let n=e,s=Math.ceil(o[1]/2);return r=`
        ivec2 getOutputCoords() {
          ivec2 resTexRC = ivec2(TexCoords.xy *
                                vec2(${n[0]}, ${n[1]}));

          int index = resTexRC.y * ${n[0]} + resTexRC.x;

          // reverse r and c order for packed texture
          int r = imod(index, ${s}) * 2;
          int c = 2 * (index / ${s});

          return ivec2(r, c);
        }
      `,new R(r)}getOutputPacked3DCoords(o,e){let r=[e[0],e[1]],n=Math.ceil(o[2]/2),s=n*Math.ceil(o[1]/2),i=`
        ivec3 getOutputCoords() {
          ivec2 resTexRC = ivec2(TexCoords.xy *
                                vec2(${r[0]}, ${r[1]}));
          int index = resTexRC.y * ${r[0]} + resTexRC.x;

          int b = index / ${s};
          index -= b * ${s};

          // reverse r and c order for packed texture
          int r = imod(index, ${n}) * 2;
          int c = 2 * (index / ${n});

          return ivec3(b, r, c);
        }
      `;return new R(i)}getOutputPackedNDCoords(o,e){let r=[e[0],e[1]],n=Math.ceil(o[o.length-1]/2),s=n*Math.ceil(o[o.length-2]/2),i=s,u="",l="b, r, c";for(let p=2;p<o.length-1;p++)i*=o[o.length-p-1],u=`
      int b${p} = index / ${i};
      index -= b${p} * ${i};
    `+u,l=`b${p}, `+l;let c=`
      ivec${o.length} getOutputCoords() {
        ivec2 resTexRC = ivec2(TexCoords.xy *
                              vec2(${r[0]}, ${r[1]}));
        int index = resTexRC.y * ${r[0]} + resTexRC.x;

        ${u}

        int b = index / ${s};
        index -= b * ${s};

        // reverse r and c order for packed texture
        int r = imod(index, ${n}) * 2;
        int c = 2 * (index / ${n});

        return ivec${o.length}(${l});
      }
    `;return new R(c)}getOutputUnpacked1DCoords(o,e){let r=`
        int getOutputCoords() {
          ivec2 resTexRC = ivec2(TexCoords.xy *
                                vec2(${e[0]}, ${e[1]}));
          return resTexRC.y * ${e[0]} + resTexRC.x;
        }
      `;return new R(r)}getOutputUnpacked2DCoords(o,e){let r=`
        ivec2 getOutputCoords() {
          ivec2 resTexRC = ivec2(TexCoords.xy *
                                vec2(${e[0]}, ${e[1]}));
          int index = resTexRC.y * ${e[0]} + resTexRC.x;
          int r = index / ${o[1]};
          int c = index - r * ${o[1]};
          return ivec2(r, c);
        }
      `;return new R(r)}getOutputUnpacked3DCoords(o,e){let r="",n=o.length,s=null;n<2&&(s=[]),s=new Array(n-1),s[n-2]=o[n-1];for(let l=n-3;l>=0;--l)s[l]=s[l+1]*o[l+1];let i=["r","c","d"],u=s.map((l,c)=>{let p=`int ${i[c]} = index / ${l}`,d=c===s.length-1?`int ${i[c+1]} = index - ${i[c]} * ${l}`:`index -= ${i[c]} * ${l}`;return`${p}; ${d};`}).join("");return r=`
        ivec3 getOutputCoords() {
          ivec2 resTexRC = ivec2(TexCoords.xy *
                                vec2(${e[0]}, ${e[1]}));
          int index = resTexRC.y * ${e[0]} + resTexRC.x;
          ${u}
          return ivec3(r, c, d);
        }
      `,new R(r)}getOutputUnpacked4DCoords(o,e){let r="",n=o.length,s=null;n<2&&(s=[]),s=new Array(n-1),s[n-2]=o[n-1];for(let l=n-3;l>=0;--l)s[l]=s[l+1]*o[l+1];let i=["r","c","d","d2"],u=s.map((l,c)=>{let p=`int ${i[c]} = index / ${l}`,d=c===s.length-1?`int ${i[c+1]} = index - ${i[c]} * ${l}`:`index -= ${i[c]} * ${l}`;return`${p}; ${d};`}).join("");return r=`
      ivec4 getOutputCoords() {
          ivec2 resTexRC = ivec2(TexCoords.xy *
                                vec2(${e[0]}, ${e[1]}));
          int index = resTexRC.y * ${e[0]} + resTexRC.x;
          ${u}
          return ivec4(r, c, d, d2);
        }
      `,new R(r)}getOutputUnpacked5DCoords(o,e){let r="",n=o.length,s=null;n<2&&(s=[]),s=new Array(n-1),s[n-2]=o[n-1];for(let l=n-3;l>=0;--l)s[l]=s[l+1]*o[l+1];let i=["r","c","d","d2","d3"],u=s.map((l,c)=>{let p=`int ${i[c]} = index / ${l}`,d=c===s.length-1?`int ${i[c+1]} = index - ${i[c]} * ${l}`:`index -= ${i[c]} * ${l}`;return`${p}; ${d};`}).join("");return r=`
      ivec5 getOutputCoords() {
          ivec2 resTexRC = ivec2(TexCoords.xy *
                                vec2(${e[0]}, ${e[1]}));
          int index = resTexRC.y * ${e[0]} + resTexRC.x;
          ${u}
          return ivec5(r, c, d, d2, d3);
        }
      `,new R(r)}getOutputUnpacked6DCoords(o,e){let r="",n=o.length,s=null;n<2&&(s=[]),s=new Array(n-1),s[n-2]=o[n-1];for(let l=n-3;l>=0;--l)s[l]=s[l+1]*o[l+1];let i=["r","c","d","d2","d3","d4"],u=s.map((l,c)=>{let p=`int ${i[c]} = index / ${l}`,d=c===s.length-1?`int ${i[c+1]} = index - ${i[c]} * ${l}`:`index -= ${i[c]} * ${l}`;return`${p}; ${d};`}).join("");return r=`
     ivec6 getOutputCoords() {
         ivec2 resTexRC = ivec2(TexCoords.xy *
                               vec2(${e[0]}, ${e[1]}));
         int index = resTexRC.y * ${e[0]} + resTexRC.x;
         ${u}
         return ivec6(r, c, d, d2, d3, d4);
       }
     `,new R(r)}getCommonUtilFuncs(){let o={},e="uvFromFlat";o[e]=new R(`
    vec2 uvFromFlat(int texNumR, int texNumC, int index) {
      int texC = index / texNumR;
      int texR = index - texC * texNumR;
      // TODO: swap texR, texC order in following function so row is corresponding to u and column is corresponding to
      //       v.
      return (vec2(texR, texC) + halfCR) / vec2(texNumR, texNumC);
    }
    `),e="packedUVfrom1D",o[e]=new R(`
      vec2 packedUVfrom1D(int texNumR, int texNumC, int index) {
        int texelIndex = index / 2;
        int texR = texelIndex / texNumC;
        int texC = texelIndex - texR * texNumC;
        return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);
      }
      `),e="packedUVfrom2D",o[e]=new R(`
      vec2 packedUVfrom2D(int texNumR, int texNumC, int texelsInLogicalRow, int row, int col) {
        int texelIndex = (row / 2) * texelsInLogicalRow + (col / 2);
        int texR = texelIndex / texNumC;
        int texC = texelIndex - texR * texNumC;
        return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);
      }
      `),e="packedUVfrom3D",o[e]=new R(`
      vec2 packedUVfrom3D(int texNumR, int texNumC,
          int texelsInBatch, int texelsInLogicalRow, int b,
          int row, int col) {
        int index = b * texelsInBatch + (row / 2) * texelsInLogicalRow + (col / 2);
        int texR = index / texNumC;
        int texC = index - texR * texNumC;
        return (vec2(texC, texR) + halfCR) / vec2(texNumC, texNumR);
      }
      `),e="sampleTexture";let r=H(this.context.glContext.version);return o[e]=new R(`
        float sampleTexture(sampler2D textureSampler, vec2 uv) {
            return ${r.texture2D}(textureSampler, uv).r;
        }`),o}getInputsSamplingSnippets(){let o={},e=this.context.outputTextureLayout;return this.context.programInfo.inputNames.forEach((r,n)=>{let s=this.context.inputTextureLayouts[n],i=Yn(r);s.isPacked?o[i]=this.getPackedSamplerFromInput(i,r,s):o[i]=this.getUnpackedSamplerFromInput(i,r,s);let u=Gu(r);s.unpackedShape.length<=e.unpackedShape.length&&(s.isPacked?o[u]=this.getPackedSamplerAtOutputCoords(u,s,e,r):o[u]=this.getUnpackedSamplerAtOutputCoords(u,s,e,r))}),o}getPackedSamplerAtOutputCoords(o,e,r,n){let s=e.unpackedShape,i=r.unpackedShape,l=Yn(n),c=s.length,p=i.length,d=Ze.getBroadcastDims(s,i),T=Qe(p),w=p-c,v,S=Dt();c===0?v="":p<2&&d.length>=1?v="coords = 0;":v=d.map(He=>`coords.${S[He+w]} = 0;`).join(`
`);let A="";p<2&&c>0?A="coords":A=s.map((He,Le)=>`coords.${S[Le+w]}`).join(", ");let C="return outputValue;",J=U.size(s)===1,ie=U.size(i)===1;if(c===1&&!J&&!ie)C=`
        return vec4(outputValue.xy, outputValue.xy);
      `;else if(J&&!ie)p===1?C=`
          return vec4(outputValue.x, outputValue.x, 0., 0.);
        `:C=`
          return vec4(outputValue.x);
        `;else if(d.length){let He=c-2,Le=c-1;d.indexOf(He)>-1&&d.indexOf(Le)>-1?C="return vec4(outputValue.x);":d.indexOf(He)>-1?C="return vec4(outputValue.x, outputValue.y, outputValue.x, outputValue.y);":d.indexOf(Le)>-1&&(C="return vec4(outputValue.xx, outputValue.zz);")}let G=`
        int lastDim = coords.${S[p-1]};
        coords.${S[p-1]} = coords.${S[p-2]};
        coords.${S[p-2]} = lastDim;
      `,Te=`
      vec4 ${o}() {
        ${T} coords = getOutputCoords();
        ${G}
        ${v}
        vec4 outputValue = ${l}(${A});
        ${C}
      }
    `;return new R(Te,["coordinates.getOutputCoords"])}getUnpackedSamplerAtOutputCoords(o,e,r,n){let s=[r.width,r.height],i=[e.width,e.height],u=e.unpackedShape.length,l=r.unpackedShape.length,c=e.unpackedShape,p=r.unpackedShape,d=Yn(n);if(u===l&&hr.arraysEqual(i,s)){let J=`
          float ${o}() {
            return sampleTexture(${n}, TexCoords);
          }
        `;return new R(J,["coordinates.sampleTexture"])}let T=Qe(l),w=Ze.getBroadcastDims(c,p),v=l-u,S,A=Dt();u===0?S="":l<2&&w.length>=1?S="coords = 0;":S=w.map(J=>`coords.${A[J+v]} = 0;`).join(`
`);let C="";l<2&&u>0?C="coords":C=e.unpackedShape.map((J,j)=>`coords.${A[j+v]}`).join(", ");let F=`
        float ${o}() {
          ${T} coords = getOutputCoords();
          ${S}
          return ${d}(${C});
        }
      `;return new R(F,["coordinates.getOutputCoords"])}getPackedSamplerFromInput(o,e,r){switch(r.unpackedShape.length){case 0:return this.getPackedSamplerScalar(o,e);case 1:return this.getPackedSampler1D(o,e,r);case 2:return this.getPackedSampler2D(o,e,r);case 3:return this.getPackedSampler3D(o,e,r);default:return this.getPackedSamplerND(o,e,r)}}getUnpackedSamplerFromInput(o,e,r){let n=r.unpackedShape;switch(n.length){case 0:return this.getUnpackedSamplerScalar(o,e,r);case 1:return this.getUnpackedSampler1D(o,e,r);case 2:return this.getUnpackedSampler2D(o,e,r);case 3:return this.getUnpackedSampler3D(o,e,r);case 4:return this.getUnpackedSampler4D(o,e,r);case 5:return this.getUnpackedSampler5D(o,e,r);case 6:return this.getUnpackedSampler6D(o,e,r);default:throw new Error(`Unsupported dimension ${n.length}-D`)}}getPackedSamplerScalar(o,e){let r=H(this.context.glContext.version),n=`
          vec4 ${o}() {
            return ${r.texture2D}(${e}, halfCR);
          }
        `;return new R(n)}getPackedSampler1D(o,e,r){let n=[r.width,r.height],s=[n[1],n[0]],i=H(this.context.glContext.version),l=`vec4 ${o}(int index) {
      vec2 uv = packedUVfrom1D(
      ${s[0]}, ${s[1]}, index);
      return ${i.texture2D}(${e}, uv);
    }`;return new R(l,["coordinates.packedUVfrom1D"])}getPackedSampler2D(o,e,r){let n=r.unpackedShape,s=[r.width,r.height],i=H(this.context.glContext.version),u=s[0],l=s[1];if(s!=null&&hr.arraysEqual(n,s)){let w=`vec4 ${o}(int row, int col) {
        vec2 uv = (vec2(col, row) + halfCR) / vec2(${l}.0, ${u}.0);
        return ${i.texture2D}(${e}, uv);
      }`;return new R(w)}let c=s,p=Math.ceil(n[1]/2),T=`vec4 ${o}(int row, int col) {
      vec2 uv = packedUVfrom2D(${c[1]}, ${c[0]}, ${p}, row, col);
      return ${i.texture2D}(${e}, uv);
    }`;return new R(T,["coordinates.packedUVfrom2D"])}getPackedSampler3D(o,e,r){let n=r.unpackedShape,s=[r.width,r.height],i=[s[0],s[1]],u=H(this.context.glContext.version);if(n[0]===1){let v=n.slice(1),S=[1,2],A=$r(n,v),C=["b","row","col"],F=JSON.parse(JSON.stringify(r));F.unpackedShape=A;let J=this.getPackedSamplerFromInput(o,e,F),ie=`${J.routineBody}
      vec4 ${o}(int b, int row, int col) {
        return ${o}(${kr(C,S)});
      } `;return new R(ie,J.dependencies)}let l=i[0],c=i[1],p=Math.ceil(n[2]/2),d=p*Math.ceil(n[1]/2),w=`vec4 ${o}(int b, int row, int col) {
      vec2 uv = packedUVfrom3D(
        ${c}, ${l}, ${d}, ${p}, b, row, col);
      return ${u.texture2D}(${e}, uv);}`;return new R(w,["coordinates.packedUVfrom3D"])}getPackedSamplerND(o,e,r){let n=r.unpackedShape,s=n.length,i=[r.width,r.height],u=H(this.context.glContext.version),l=[i[0],i[1]],c=l[1],p=l[0],d=Math.ceil(n[s-1]/2),T=d*Math.ceil(n[s-2]/2),w="int b, int row, int col",v=`b * ${T} + (row / 2) * ${d} + (col / 2)`;for(let C=2;C<s-1;C++)w=`int b${C}, `+w,T*=n[s-C-1],v=`b${C} * ${T} + `+v;let A=`vec4 ${o}(${w}) {
      int index = ${v};
      int texR = index / ${p};
      int texC = index - texR * ${p};
      vec2 uv = (vec2(texC, texR) + halfCR) / vec2(${p}, ${c});
      return ${u.texture2D}(${e}, uv);
    }`;return new R(A)}getUnpackedSamplerScalar(o,e,r){let[n,s]=[r.width,r.height];if(n===1&&s===1){let u=`
          float ${o}() {
            return sampleTexture(${e}, halfCR);
          }
        `;return new R(u,["coordinates.sampleTexture"])}let i=`
        float ${o}() {
          int offset_${e} = coordsToOffset(TexCoords, ${n}, ${s});
          vec2 uv = uvFromFlat(${n}, ${s}, offset_${e});
          return sampleTexture(${e}, uv);
        }
      `;return new R(i,["coordinates.uvFromFlat","coordinates.sampleTexture","coordinates.coordsToOffset"])}getUnpackedSampler1D(o,e,r){let n=r.width,s=r.height;if(s===1&&n===1){let u=`
        float ${o}(int index) {
          return sampleTexture(${e}, halfCR);
        }
      `;return new R(u,["coordinates.sampleTexture"])}if(s===1){let u=`
          float ${o}(int index) {
            vec2 uv = vec2((float(index) + 0.5) / ${n}.0, 0.5);
            return sampleTexture(${e}, uv);
          }
        `;return new R(u,["coordinates.sampleTexture"])}if(n===1){let u=`
          float ${o}(int index) {
            vec2 uv = vec2(0.5, (float(index) + 0.5) / ${s}.0);
            return sampleTexture(${e}, uv);
          }
        `;return new R(u,["coordinates.sampleTexture"])}let i=`
        float ${o}(int index) {
          vec2 uv = uvFromFlat(${n}, ${s}, index);
          return sampleTexture(${e}, uv);
        }
      `;return new R(i,["coordinates.uvFromFlat","coordinates.sampleTexture"])}getUnpackedSampler2D(o,e,r){let n=r.unpackedShape,s=[r.height,r.width];if(s!=null&&hr.arraysEqual(n,s)){let T=s[1],w=s[0],v=`
          float ${o}(int row, int col) {
            vec2 uv = (vec2(row, col) + halfCR) / vec2(${T}.0, ${w}.0);
            return sampleTexture(${e}, uv);
          }
        `;return new R(v,["coordinates.sampleTexture"])}let{newShape:i,keptDims:u}=Mr(n),l=i;if(l.length<n.length){let T=$r(n,l),w=JSON.parse(JSON.stringify(r));w.unpackedShape=T;let v=["col","row"],S=`
          ${this.getUnpackedSamplerFromInput(o,e,w).routineBody}
          float ${o}(int row, int col) {
            return ${o}(${kr(v,u)});
          }
        `;return new R(S,["coordinates.sampleTexture"])}let c=s[1],p=s[0];if(p===1){let T=`
          float ${o}(int row, int col) {
            int offset_${e} = coordsToOffset(TexCoords, ${c}, ${p});
            float index = dot(vec3(row, col, offset_${e}), vec3(${n[1]}, 1, 1));
            vec2 uv = vec2(0.5, (index + 0.5) / ${c}.0);
            return sampleTexture(${e}, uv);
          }
        `;return new R(T,["coordinates.sampleTexture","coordinates.coordsToOffset"])}if(c===1){let T=`
          float ${o}(int row, int col) {
            int offset_${e} = coordsToOffset(TexCoords, ${c}, ${p});
            float index = dot(vec3(row, col, offset_${e}), vec3(${n[1]}, 1, 1));
            vec2 uv = vec2((index + 0.5) / ${p}.0, 0.5);
            return sampleTexture(${e}, uv);
          }
        `;return new R(T,["coordinates.sampleTexture","coordinates.coordsToOffset"])}let d=`
        float ${o}(int row, int col) {
          int index = col * ${n[1]} + row;
          vec2 uv = uvFromFlat(${c}, ${p}, index);
          return sampleTexture(${e}, uv);
        }
      `;return new R(d,["coordinates.uvFromFlat","coordinates.sampleTexture","coordinates.coordsToOffset"])}getUnpackedSampler3D(o,e,r){let n=r.unpackedShape,s=n[1]*n[2],i=n[2],{newShape:u,keptDims:l}=Mr(n),c=u;if(c.length<n.length){let w=$r(n,c),v=["batch","col","row"],S=JSON.parse(JSON.stringify(r));S.unpackedShape=w;let A=this.getUnpackedSamplerFromInput(o,e,S),C=l.reverse(),F=`
          ${A.routineBody}
          float ${o}(int batch, int row, int col) {
            return ${o}(${kr(v,C)});
          }
        `;return new R(F,A.dependencies)}let p=r.width,d=r.height,T=`
          float ${o}(int depth, int row, int col) {
            // Explicitly use integer operations as dot() only works on floats.
            int index = depth * ${s} + col * ${i} + row;
            vec2 uv = uvFromFlat(${p}, ${d}, index);
            return sampleTexture(${e}, uv);
          }
      `;return new R(T,["coordinates.uvFromFlat","coordinates.sampleTexture","coordinates.coordsToOffset"])}getUnpackedSampler4D(o,e,r){let n=r.unpackedShape,s=n[3],i=n[2]*s,u=n[1]*i,l=r.width,c=r.height,p=`
        float ${o}(int row, int col, int depth, int depth2) {
          int index = row * ${u} + col * ${i} +
              depth2 * ${s} + depth;
          vec2 uv = uvFromFlat(${l}, ${c}, index);
          return sampleTexture(${e}, uv);
        }
      `;return new R(p,["coordinates.uvFromFlat","coordinates.sampleTexture"])}getUnpackedSampler5D(o,e,r){let n=r.unpackedShape,s=n[4],i=n[3]*s,u=n[2]*i,l=n[1]*u,{newShape:c,keptDims:p}=Mr(n);if(c.length<n.length){let v=$r(n,c),S=["row","col","depth","depth2","depth3"],A=JSON.parse(JSON.stringify(r));A.unpackedShape=v;let C=`
          ${this.getUnpackedSamplerFromInput(o,e,A).routineBody}
          float ${o}(int row, int col, int depth, int depth2, int depth3) {
            return ${o}(${kr(S,p)});
          }
        `;return new R(C,["coordinates.sampleTexture","coordinates.uvFromFlat"])}let d=r.width,T=r.height,w=`
        float ${o}(int row, int col, int depth, int depth2, int depth3) {
          int index = row * ${l} + col * ${u} + depth * ${i} +
          depth3 * ${s} + depth2;
          vec2 uv = uvFromFlat(${d}, ${T}, index);
          return sampleTexture(${e}, uv);
        }
      `;return new R(w,["coordinates.sampleTexture","coordinates.uvFromFlat"])}getUnpackedSampler6D(o,e,r){let n=r.unpackedShape,s=n[5],i=n[4]*s,u=n[3]*i,l=n[2]*u,c=n[1]*l,{newShape:p,keptDims:d}=Mr(n);if(p.length<n.length){let S=$r(n,p),A=["row","col","depth","depth2","depth3","depth4"],C=JSON.parse(JSON.stringify(r));C.unpackedShape=S;let F=`
            ${this.getUnpackedSamplerFromInput(o,e,C).routineBody}
            float ${o}(int row, int col, int depth,
              int depth2, int depth3, int depth4) {
              return ${o}(${kr(A,d)});
            }
          `;return new R(F,["coordinates.sampleTexture","coordinates.uvFromFlat"])}let T=r.width,w=r.height,v=`
          float ${o}(int row, int col, int depth,
            int depth2, int depth3, int depth4) {
            int index = row * ${c} + col * ${l} + depth * ${u} +
            depth2 * ${i} + depth3 * ${s} + depth4;
            vec2 uv = uvFromFlat(${T}, ${w}, index);
            return sampleTexture(${e}, uv);
          }
        `;return new R(v,["coordinates.uvFromFlat","coordinates.sampleTexture","coordinates.coordsToOffset"])}toVec(){let o=this.context.outputTextureLayout,e=o.shape.length,r=o.strides,n=o.width,s=o.height,i=[];for(let l=0;l<e-1;++l)i.push(`
        c[${l}] = offset / ${r[l]};`),i.push(`
        offset -= c[${l}] * ${r[l]};`);i.push(`
        c[${e-1}] = offset;`);let u=`
      void toVec(vec2 texCoords, out int c[${e}]) {
        int offset = coordsToOffset(texCoords, ${n}, ${s});
        ${i.join("")}
      }
      void toVec(int offset, out int c[${e}]) {
        ${i.join("")}
      }
    `;return{toVec:new R(u,["coordinates.coordsToOffset"])}}valueFrom(){let o={};return this.context.programInfo.inputNames.forEach((e,r)=>{let n=this.context.inputTextureLayouts[r],i=(n.unpackedShape.length>0?n.unpackedShape:n.shape).length,u=`_${e}`;o[u]=new R(this.getValueFromSingle(e,i,n.width,n.height,!1),[`shapeUtils.indicesToOffset${u}`,"coordinates.offsetToCoords","fragcolor.getColorAsFloat"]),u=u+"_T",o[u]=new R(this.getValueFromSingle(e,i,n.width,n.height,!0),[`shapeUtils.indicesToOffset${u}`,"coordinates.offsetToCoords","fragcolor.getColorAsFloat"])}),o}getValueFromSingle(o,e,r,n,s){let i=`_${o}`;s&&(i=i+"_T");let u=H(this.context.glContext.version);return`
        float ${i}(int m[${e}]) {
          int offset = indicesToOffset${i}(m);
          vec2 coords = offsetToCoords(offset, ${r}, ${n});
          float value = getColorAsFloat(${u.texture2D}(${o}, coords));
          return value;
        }
        `}getPackedValueFrom(o,e,r,n,s){let i=`_${o}_Pack`;s&&(i=i+"_T");let u=H(this.context.glContext.version);return`
        vec4 ${i}(int m[${e}]) {
          int offset = indicesToOffset_${o}(m);
          vec2 coords = offsetToCoords(offset, ${r}, ${n});
          return ${u.texture2D}(${o}, coords);
        }
        `}}});var fo,tp=L(()=>{"use strict";Wt();fo=class a extends dt{constructor(t){super(t)}getFunctions(){return{...this.encodeFloat32(),...this.decodeFloat32()}}getCustomTypes(){return{}}encodeFloat32(){return{encode:new R(`highp vec4 encode(highp float f) {
        return vec4(f, 0.0, 0.0, 0.0);
      }
        `)}}decodeFloat32(){return{decode:new R(`highp float decode(highp vec4 rgba) {
        return rgba.r;
      }
        `)}}encodeUint8(){let t=a.isLittleEndian()?"rgba.rgba=rgba.abgr;":"";return{encode:new R(`
      highp vec4 encode(highp float f) {
        highp float F = abs(f);
        highp float Sign = step(0.0,-f);
        highp float Exponent = floor(log2(F));
        highp float Mantissa = (exp2(- Exponent) * F);
        Exponent = floor(log2(F) + 127.0) + floor(log2(Mantissa));
        highp vec4 rgba;
        rgba[0] = 128.0 * Sign  + floor(Exponent*exp2(-1.0));
        rgba[1] = 128.0 * mod(Exponent,2.0) + mod(floor(Mantissa*128.0),128.0);
        rgba[2] = floor(mod(floor(Mantissa*exp2(23.0 -8.0)),exp2(8.0)));
        rgba[3] = floor(exp2(23.0)*mod(Mantissa,exp2(-15.0)));
        ${t}
        rgba = rgba / 255.0; // values need to be normalized to [0,1]
        return rgba;
    }
        `)}}decodeUint8(){let t=a.isLittleEndian()?"rgba.rgba=rgba.abgr;":"";return{decode:new R(`
        highp float decode(highp vec4 rgba) {
          rgba = rgba * 255.0; // values need to be de-normalized from [0,1] to [0,255]
          ${t}
          highp float Sign = 1.0 - step(128.0,rgba[0])*2.0;
          highp float Exponent = 2.0 * mod(rgba[0],128.0) + step(128.0,rgba[1]) - 127.0;
          highp float Mantissa = mod(rgba[1],128.0)*65536.0 + rgba[2]*256.0 +rgba[3] + float(0x800000);
          highp float Result =  Sign * exp2(Exponent) * (Mantissa * exp2(-23.0 ));
          return Result;
      }
        `)}}static isLittleEndian(){let t=new ArrayBuffer(4),o=new Uint32Array(t),e=new Uint8Array(t);if(o[0]=3735928559,e[0]===239)return!0;if(e[0]===222)return!1;throw new Error("unknown endianness")}}});var co,rp=L(()=>{"use strict";Wt();we();co=class extends dt{constructor(t){super(t)}getFunctions(){return{...this.setFragColor(),...this.getColorAsFloat()}}getCustomTypes(){return{}}setFragColor(){let t=H(this.context.glContext.version);return{setFragColor:new R(`
        void setFragColor(float value) {
            ${t.output} = encode(value);
        }
        `,["encoding.encode"])}}getColorAsFloat(){return{getColorAsFloat:new R(`
        float getColorAsFloat(vec4 color) {
            return decode(color);
        }
        `,["encoding.decode"])}}}});var po,np=L(()=>{"use strict";Wt();po=class a extends dt{constructor(t){super(t)}getFunctions(){return{...this.bcastIndex(),...this.bcastMatmulIndex(),...this.offsetToIndices(),...this.indicesToOffset(),...this.incrementIndices()}}getCustomTypes(){return{}}bcastIndex(){let t=this.context.outputTextureLayout.shape.length,o={};return this.context.programInfo.inputNames.forEach((e,r)=>{let n=this.context.inputTextureLayouts[r].unpackedShape;if(n.length<=t){let s=n.length,i=t-s,u=`bcastIndices_${e}`,l="";for(let p=0;p<s;++p)l+=`
          realIndices[${p}] = int( mod(float(bcastedIndices[${i+p}]), ${n[p]}.0) );
          `;let c=`
        void ${u} (int bcastedIndices[${t}], out int realIndices[${s}]) {
          ${l}
        }
        `;o[u]=new R(c)}}),o}bcastMatmulIndex(){let t=this.context.outputTextureLayout.shape.length,o={};return this.context.programInfo.inputNames.forEach((e,r)=>{let n=this.context.inputTextureLayouts[r].shape;if(!(n.length<2||n.length>t)){let s=n.length,i=t-s,u=`bcastMatmulIndices_${e}`,l="";for(let p=0;p<s-2;++p)l+=`
          realIndices[${p}] = int( mod(float(bcastedIndices[${i+p}]), ${n[p]}.0) );
          `;let c=`
        void ${u}(int bcastedIndices[${t}], out int realIndices[${s}]) {
          ${l}
          realIndices[${s-1}] = bcastedIndices[${t-1}];
          realIndices[${s-2}] = bcastedIndices[${t-2}];
        }
        `;o[u]=new R(c)}}),o}indicesToOffset(){let t={};return this.context.programInfo.inputNames.forEach((o,e)=>{let r=this.context.inputTextureLayouts[e].shape,n=this.context.inputTextureLayouts[e].strides,s=r.length,i=`indicesToOffset_${o}`;t[i]=new R(a.indexToOffsetSingle(i,s,n)),i=`indicesToOffset_${o}_T`,t[i]=new R(a.indexToOffsetSingle(i,s,n.slice().reverse()))}),t}static indexToOffsetSingle(t,o,e){let r="";for(let n=o-1;n>=0;--n)r+=`
        offset += indices[${n}] * ${e[n]};
        `;return`
      int ${t}(int indices[${o}]) {
        int offset = 0;
        ${r}
        return offset;
      }
      `}offsetToIndices(){let t={};return this.context.programInfo.inputNames.forEach((o,e)=>{let r=this.context.inputTextureLayouts[e].shape,n=this.context.inputTextureLayouts[e].strides,s=r.length,i=`offsetToIndices_${o}`;t[i]=new R(a.offsetToIndicesSingle(i,s,n)),i=`offsetToIndices_${o}_T`,t[i]=new R(a.offsetToIndicesSingle(i,s,n.slice().reverse()))}),t}static offsetToIndicesSingle(t,o,e){let r=[];for(let n=0;n<o-1;++n)r.push(`
      indices[${n}] = offset / ${e[n]};`),r.push(`
        offset -= indices[${n}] * ${e[n]};`);return r.push(`
      indices[${o-1}] = offset;`),`
      void ${t}(int offset, out int indices[${o}]) {
        ${r.join("")}
      }
      `}incrementIndices(){let t={};return this.context.programInfo.inputNames.forEach((o,e)=>{let r=this.context.inputTextureLayouts[e].shape,n=r.length,s=`incrementIndices_${o}`,i="";for(let l=0;l<n;++l)i+=`
        shape[${l}] = ${r[l]};`;let u=`
        void ${s}(int axis, out int indices[${n}]) {
          int shape[${n}];
          ${i};
          for(int i = ${n} -1 ; i >= 0; --i) {
            if(i > axis) continue;
            indices[i] += 1;
            if(indices[i] < shape[i]) {
              break;
            }
            indices[i] = 0;
          }
        }
        `;t[s]=new R(u)}),t}}});var ho,op=L(()=>{"use strict";Wt();ho=class extends dt{constructor(t){super(t)}getCustomTypes(){return{}}getFunctions(){return{...this.binaryVecFunctions(),...this.copyVec(),...this.setVecItem(),...this.getVecItem()}}binaryVecFunctions(){let o=this.context.outputTextureLayout.shape.length,e={add:"+=",sub:"-=",mul:"*=",div:"/="},r={};for(let n in e){let s=`${n}Vec`,i="";for(let l=0;l<o;++l)i+=`
          dest[${l}] ${e[n]} src[${l}];
          `;let u=`
        void ${s}(int src[${o}], out int dest[${o}]) {
          ${i}
        }
        `;r[s]=new R(u)}return r}copyVec(){let o=this.context.outputTextureLayout.shape.length,e="";for(let n=0;n<o;++n)e+=`
        dest[${n}] = src[${n}];
        `;let r=`
      void copyVec(int src[${o}], out int dest[${o}]) {
        ${e}
      }
      `;return{copyVec:new R(r)}}setVecItem(){let o=this.context.outputTextureLayout.shape.length,e=`
        if(index < 0)
            index =${o} + index;
        if (index == 0)
            m[0] = value;
        `;for(let n=1;n<o-1;++n)e+=`
        else if (index == ${n})
            m[${n}] = value;
            `;e+=`
        else
            m[${o-1}] = value;
        `;let r=`
      void setVecItem(out int m[${o}], int index, int value) {
        ${e}
      }
        `;return{setVecItem:new R(r)}}getVecItem(){let o=this.context.outputTextureLayout.shape.length,e=`
        if(index < 0)
            index = ${o} + index;
        if (index == 0)
            return m[0];
      `;for(let n=1;n<o-1;++n)e+=`
        else if (index == ${n})
            return m[${n}];
      `;e+=`
        else
            return m[${o-1}];
        `;let r=`
      int getVecItem(int m[${o}], int index) {
        ${e}
      }
    `;return{getVecItem:new R(r)}}}});var Wi,ip=L(()=>{"use strict";ep();tp();rp();np();op();Wi={encoding:fo,fragcolor:co,vec:ho,shapeUtils:po,coordinates:lo}});var mo,ap=L(()=>{"use strict";Wt();Zc();ip();we();mo=class{constructor(t,o,e,r){this.libs={};this.glslLibRoutineDependencyGraph={};this.context=new Zn(t,o,e,r),Object.keys(Wi).forEach(s=>{let i=new Wi[s](this.context);this.libs[s]=i});let n=this.glslLibRoutineDependencyGraph;for(let s in this.libs){let u=this.libs[s].getFunctions();for(let l in u){let c=s+"."+l,p;n[c]?(p=n[c],p.routineBody=u[l].routineBody):(p=new cn(c,u[l].routineBody),n[c]=p);let d=u[l].dependencies;if(d)for(let T=0;T<d.length;++T)if(n[d[T]])p.addDependency(n[d[T]]);else{let w=new cn(d[T]);n[d[T]]=w,p.addDependency(w)}}}}preprocess(){let t=this.context.programInfo,o=t.shaderSource;return this.context.programInfo.hasMain||(o=`${o}
      ${Mu(this.context.glContext.version,this.context.outputTextureLayout.shape.length)}`),o=Jc(o),`${Ru(this.context.glContext.version)}
    ${this.getUniforms(t.inputNames,t.variables)}
    ${this.getImports(o)}
    ${o}`}getImports(t){let o=this.selectGlslLibRoutinesToBeIncluded(t);if(o.length===0)return"";let e="";for(let r=0;r<o.length;++r)if(o[r].routineBody)e+=o[r].routineBody+`
`;else throw new Error(`Missing body for the Glsl Library routine: ${o[r].name}`);return e}selectGlslLibRoutinesToBeIncluded(t){let o=[];return Object.keys(this.glslLibRoutineDependencyGraph).forEach(e=>{let r=e.split(".")[1];t.indexOf(r)!==-1&&o.push(this.glslLibRoutineDependencyGraph[e])}),Qn.returnOrderedNodes(o)}getUniforms(t,o){let e=[];if(t)for(let r of t)e.push(`uniform sampler2D ${r};`);if(o)for(let r of o)e.push(`uniform ${r.type} ${r.name}${r.arrayLength?`[${r.arrayLength}]`:""};`);return e.join(`
`)}}});var bo,sp=L(()=>{"use strict";Ot();lt();ap();we();bo=class{constructor(t,o,e){this.profiler=t;this.glContext=o;this.textureLayoutStrategy=e;this.repo=new Map,this.attributesBound=!1}getArtifact(t){return this.repo.get(t)}setArtifact(t,o){this.repo.set(t,o)}run(t,o,e){this.profiler.event("op",`ProgramManager.run ${t.programInfo.name??"unknown kernel"}`,()=>{let r=this.glContext.gl,n=t.program;r.useProgram(n);try{this.bindOutput(e),this.attributesBound||this.bindAttributes(t.attribLocations),this.bindUniforms(t.uniformLocations,t.programInfo.variables??[],o)}catch(s){throw ce.error("ProgramManager",t.programInfo.shaderSource),s}this.profiler.event("backend","GlContext.draw()",()=>{this.glContext.draw()})},this.glContext)}dispose(){this.vertexShader&&this.glContext.deleteShader(this.vertexShader),this.repo.forEach(t=>this.glContext.deleteProgram(t.program))}build(t,o,e){return this.profiler.event("backend","ProgramManager.build",()=>{let r=new mo(this.glContext,t,o,e),n=r.preprocess(),s=this.compile(n);return{programInfo:t,program:s,uniformLocations:this.getUniformLocations(s,r.context.programInfo.inputNames,r.context.programInfo.variables),attribLocations:this.getAttribLocations(s)}})}compile(t){if(!this.vertexShader){ce.verbose("ProrgramManager","Compiling and caching Vertex shader for the first time");let r=Nu(this.glContext.version);this.vertexShader=this.glContext.compileShader(r,this.glContext.gl.VERTEX_SHADER)}Z.debug&&ce.verbose("ProrgramManager",`FragShader:
${t}
`);let o=this.glContext.compileShader(t,this.glContext.gl.FRAGMENT_SHADER),e=this.glContext.createProgram(this.vertexShader,o);return this.glContext.deleteShader(o),e}bindOutput(t){let o=t.width,e=t.height;ce.verbose("ProrgramManager",`Binding output texture to Framebuffer: w/h=${o}/${e}, shape=${t.shape}, type=${t.tensor.type}`),this.glContext.attachFramebuffer(t.texture,o,e)}bindAttributes(t){let o=t.position,e=t.textureCoord;this.glContext.setVertexAttributes(o,e),this.attributesBound=!0}bindUniforms(t,o,e){let r=this.glContext.gl,n=0;for(let{name:s,type:i,location:u,arrayLength:l}of t){let c=o.find(p=>p.name===s)?.data;if(i!=="sampler2D"&&!c)throw new Error(`variable '${s}' does not have data defined in program info`);switch(i){case"sampler2D":this.bindTexture(e[n],u,n),n++;break;case"float":l?r.uniform1fv(u,c):r.uniform1f(u,c);break;case"int":l?r.uniform1iv(u,c):r.uniform1i(u,c);break;default:throw new Error(`Uniform not implemented: ${i}`)}}}bindTexture(t,o,e){this.glContext.bindTextureToUniform(t.texture,e,o)}getAttribLocations(t){return{position:this.getAttribLocation(t,"position"),textureCoord:this.getAttribLocation(t,"textureCoord")}}getUniformLocations(t,o,e){let r=[];if(o)for(let n of o)r.push({name:n,type:"sampler2D",location:this.getUniformLocation(t,n)});if(e)for(let n of e)r.push({...n,location:this.getUniformLocation(t,n.name)});return r}getUniformLocation(t,o){let r=this.glContext.gl.getUniformLocation(t,o);if(r===null)throw new Error(`Uniform ${o} not found.`);return r}getAttribLocation(t,o){return this.glContext.gl.getAttribLocation(t,o)}}});var go,up=L(()=>{"use strict";lt();ln();go=class{constructor(t,o,e,r){this.glContext=t;this.layoutStrategy=o;this.profiler=e;this.config=r;this.pendingRead=new Map;r.reuseTextures&&(this.inUseTextures=new Map,this.idleTextures=new Map,this.textureLookup=new Map)}createTextureFromLayout(t,o,e,r){let n=this.toEncoderType(t),s=this.glContext.getEncoder(n,o.channels||1,r);if(o.isPacked&&r===1)throw new Error("not implemented");let i=o.width,u=o.height,l,c;if(this.config.reuseTextures){l=`${i}x${u}_${s.format}_${s.internalFormat}_${s.textureType}`,c=this.inUseTextures.get(l),c||(c=[],this.inUseTextures.set(l,c));let d=this.idleTextures.get(l);if(d&&d.length>0){let T=d.pop();return c.push(T),r===1&&this.glContext.updateTexture(T,i,u,s,this.toTextureData(t,e)),T}}ce.verbose("TextureManager",`Creating new texture of size ${o.width}x${o.height}`);let p=this.glContext.allocateTexture(i,u,s,this.toTextureData(t,e));return this.config.reuseTextures&&(c.push(p),this.textureLookup.set(p,l)),p}readTexture(t,o,e){return e||(e=1),this.profiler.event("backend","TextureManager.readTexture",()=>{let r=t.shape.reduce((s,i)=>s*i)*e,n=this.glContext.readTexture(t.texture,t.width,t.height,r,this.toEncoderType(o),e);return this.toTensorData(o,n)})}async readTextureAsync(t,o,e){let r=t.tensor.dataId;if(e||(e=1),this.pendingRead.has(r)){let n=this.pendingRead.get(r);return new Promise(s=>n?.push(s))}return this.profiler.event("backend","TextureManager.readTextureAsync",async()=>{this.pendingRead.set(r,[]);let n=t.shape.reduce((l,c)=>l*c)*e;await this.glContext.createAndWaitForFence();let s=this.glContext.readTexture(t.texture,t.width,t.height,n,this.toEncoderType(o),e),i=this.toTensorData(o,s),u=this.pendingRead.get(r);return this.pendingRead.delete(r),u?.forEach(l=>l(i)),i})}readUint8TextureAsFloat(t){return this.profiler.event("backend","TextureManager.readUint8TextureAsFloat",()=>{let o=t.shape.reduce((r,n)=>r*n),e=this.glContext.readTexture(t.texture,t.width,t.height,o*4,"byte",4);return new Float32Array(e.buffer,e.byteOffset,o)})}releaseTexture(t,o){let e;if(this.config.reuseTextures&&(e=this.textureLookup.get(t.texture),e)){o&&this.textureLookup.delete(e);let r=this.inUseTextures.get(e);if(r){let n=r.indexOf(t.texture);if(n!==-1){r.splice(n,1);let s=this.idleTextures.get(e);s||(s=[],this.idleTextures.set(e,s)),s.push(t.texture)}}}(!e||o)&&(ce.verbose("TextureManager",`Deleting texture of size ${t.width}x${t.height}`),this.glContext.deleteTexture(t.texture))}toTensorData(t,o){switch(t){case"int16":return o instanceof Int16Array?o:Int16Array.from(o);case"int32":return o instanceof Int32Array?o:Int32Array.from(o);case"int8":return o instanceof Int8Array?o:Int8Array.from(o);case"uint16":return o instanceof Uint16Array?o:Uint16Array.from(o);case"uint32":return o instanceof Uint32Array?o:Uint32Array.from(o);case"uint8":case"bool":return o instanceof Uint8Array?o:Uint8Array.from(o);case"float32":return o instanceof Float32Array?o:Float32Array.from(o);case"float64":return o instanceof Float64Array?o:Float64Array.from(o);default:throw new Error(`TensorData type ${t} is not supported`)}}toTextureData(t,o){if(o)return o instanceof Float32Array?o:new Float32Array(o)}toEncoderType(t){return"float"}clearActiveTextures(){this.glContext.clearActiveTextures()}}});var yo,lp=L(()=>{"use strict";lt();_s();el();Xc();sp();Vi();up();yo=class{constructor(t,o){this.backend=t;this.context=o;this.layoutStrategy=new uo(t.glContext.maxTextureSize),this.programManager=new bo(this.context.profiler,t.glContext,this.layoutStrategy),this.textureManager=new go(t.glContext,this.layoutStrategy,this.context.profiler,{reuseTextures:t.textureCacheMode==="full"}),this.packedTextureDataCache=new Map,this.unpackedTextureDataCache=new Map,this.pack=t.pack,this.pack2unpackMap=new Map,this.unpack2packMap=new Map}createInferenceHandler(){return new Jn(this)}onGraphInitialized(t){let o=t.getValues().filter(e=>e.from===-1&&e.tensor).map(e=>e.tensor.dataId);this.initializers=new Set(o)}isInitializer(t){return this.initializers?this.initializers.has(t):!1}addInitializer(t){this.initializers.add(t)}getTextureData(t,o){return o?this.packedTextureDataCache.get(t):this.unpackedTextureDataCache.get(t)}setTextureData(t,o,e=!1){ce.verbose("WebGLSessionHandler","Storing Texture data in cache"),e?this.packedTextureDataCache.set(t,o):this.unpackedTextureDataCache.set(t,o)}dispose(){this.programManager.dispose(),this.textureManager.clearActiveTextures(),this.packedTextureDataCache.forEach(t=>this.textureManager.releaseTexture(t,!0)),this.packedTextureDataCache=new Map,this.unpackedTextureDataCache.forEach(t=>this.textureManager.releaseTexture(t,!0)),this.unpackedTextureDataCache=new Map}resolve(t,o,e){let r=vs(t,o,Yc);return{impl:r.opImpl,context:r.opInit?r.opInit(t,e):t}}}});function jb(a){let t=0;for(;t<a.length&&a[t]();++t);return t-1}var hn,fp=L(()=>{"use strict";Ot();ln();ln();Bt();hn=class{constructor(t,o){this.frameBufferBound=!1;this.itemsToPoll=[];this.gl=t,this.version=o,this.getExtensions(),this.vertexbuffer=this.createVertexbuffer(),this.framebuffer=this.createFramebuffer(),this.queryVitalParameters()}allocateTexture(t,o,e,r){let n=this.gl,s=n.createTexture();n.bindTexture(n.TEXTURE_2D,s),n.texParameteri(n.TEXTURE_2D,n.TEXTURE_MIN_FILTER,n.NEAREST),n.texParameteri(n.TEXTURE_2D,n.TEXTURE_MAG_FILTER,n.NEAREST),n.texParameteri(n.TEXTURE_2D,n.TEXTURE_WRAP_S,n.CLAMP_TO_EDGE),n.texParameteri(n.TEXTURE_2D,n.TEXTURE_WRAP_T,n.CLAMP_TO_EDGE);let i=r?e.encode(r,t*o):null;return n.texImage2D(n.TEXTURE_2D,0,e.internalFormat,t,o,0,e.format,e.textureType,i),this.checkError(),s}updateTexture(t,o,e,r,n){let s=this.gl;s.bindTexture(s.TEXTURE_2D,t);let i=r.encode(n,o*e);s.texSubImage2D(s.TEXTURE_2D,0,0,0,o,e,r.format,r.textureType,i),this.checkError()}attachFramebuffer(t,o,e){let r=this.gl;r.bindTexture(r.TEXTURE_2D,t),r.bindFramebuffer(r.FRAMEBUFFER,this.framebuffer),r.framebufferTexture2D(r.FRAMEBUFFER,r.COLOR_ATTACHMENT0,r.TEXTURE_2D,t,0),this.checkError(),r.viewport(0,0,o,e),r.scissor(0,0,o,e)}readTexture(t,o,e,r,n,s){let i=this.gl;s||(s=1),this.frameBufferBound||this.attachFramebuffer(t,o,e);let u=this.getEncoder(n,s),l=u.allocate(o*e);return i.bindTexture(i.TEXTURE_2D,t),i.framebufferTexture2D(i.FRAMEBUFFER,i.COLOR_ATTACHMENT0,i.TEXTURE_2D,t,0),i.readPixels(0,0,o,e,i.RGBA,u.textureType,l),this.checkError(),u.decode(l,r)}isFramebufferReady(){return!0}getActiveTexture(){let t=this.gl;return`TEXTURE${t.getParameter(this.gl.ACTIVE_TEXTURE)-t.TEXTURE0}`}getTextureBinding(){return this.gl.getParameter(this.gl.TEXTURE_BINDING_2D)}getFramebufferBinding(){return this.gl.getParameter(this.gl.FRAMEBUFFER_BINDING)}setVertexAttributes(t,o){let e=this.gl;e.vertexAttribPointer(t,3,e.FLOAT,!1,20,0),e.enableVertexAttribArray(t),o!==-1&&(e.vertexAttribPointer(o,2,e.FLOAT,!1,20,12),e.enableVertexAttribArray(o)),this.checkError()}createProgram(t,o){let e=this.gl,r=e.createProgram();return e.attachShader(r,t),e.attachShader(r,o),e.linkProgram(r),r}compileShader(t,o){let e=this.gl,r=e.createShader(o);if(!r)throw new Error(`createShader() returned null with type ${o}`);if(e.shaderSource(r,t),e.compileShader(r),e.getShaderParameter(r,e.COMPILE_STATUS)===!1)throw new Error(`Failed to compile shader: ${e.getShaderInfoLog(r)}
Shader source:
${t}`);return r}deleteShader(t){this.gl.deleteShader(t)}bindTextureToUniform(t,o,e){let r=this.gl;r.activeTexture(r.TEXTURE0+o),this.checkError(),r.bindTexture(r.TEXTURE_2D,t),this.checkError(),r.uniform1i(e,o),this.checkError()}draw(){this.gl.drawArrays(this.gl.TRIANGLE_STRIP,0,4),this.checkError()}checkError(){if(Z.debug){let t=this.gl,o=t.getError(),e="";switch(o){case t.NO_ERROR:return;case t.INVALID_ENUM:e="INVALID_ENUM";break;case t.INVALID_VALUE:e="INVALID_VALUE";break;case t.INVALID_OPERATION:e="INVALID_OPERATION";break;case t.INVALID_FRAMEBUFFER_OPERATION:e="INVALID_FRAMEBUFFER_OPERATION";break;case t.OUT_OF_MEMORY:e="OUT_OF_MEMORY";break;case t.CONTEXT_LOST_WEBGL:e="CONTEXT_LOST_WEBGL";break;default:e=`Unknown WebGL Error: ${o.toString(16)}`}throw new Error(e)}}deleteTexture(t){this.gl.deleteTexture(t)}deleteProgram(t){this.gl.deleteProgram(t)}getEncoder(t,o,e=0){if(this.version===2)return new Xn(this.gl,o);switch(t){case"float":return e===1||this.isRenderFloat32Supported?new un(this.gl,o):new un(this.gl,o,this.textureHalfFloatExtension.HALF_FLOAT_OES);case"int":throw new Error("not implemented");case"byte":return new Kn(this.gl,o);default:throw new Error(`Invalid dataType: ${t}`)}}clearActiveTextures(){let t=this.gl;for(let o=0;o<this.maxTextureImageUnits;++o)t.activeTexture(t.TEXTURE0+o),t.bindTexture(t.TEXTURE_2D,null)}dispose(){if(this.disposed)return;let t=this.gl;t.bindFramebuffer(t.FRAMEBUFFER,null),t.deleteFramebuffer(this.framebuffer),t.bindBuffer(t.ARRAY_BUFFER,null),t.deleteBuffer(this.vertexbuffer),t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,null),t.finish(),this.disposed=!0}createDefaultGeometry(){return new Float32Array([-1,1,0,0,1,-1,-1,0,0,0,1,1,0,1,1,1,-1,0,1,0])}createVertexbuffer(){let t=this.gl,o=t.createBuffer();if(!o)throw new Error("createBuffer() returned null");let e=this.createDefaultGeometry();return t.bindBuffer(t.ARRAY_BUFFER,o),t.bufferData(t.ARRAY_BUFFER,e,t.STATIC_DRAW),this.checkError(),o}createFramebuffer(){let t=this.gl.createFramebuffer();if(!t)throw new Error("createFramebuffer returned null");return t}queryVitalParameters(){let t=this.gl;if(this.isFloatTextureAttachableToFrameBuffer=this.checkFloatTextureAttachableToFrameBuffer(),this.isRenderFloat32Supported=this.checkRenderFloat32(),this.isFloat32DownloadSupported=this.checkFloat32Download(),this.version===1&&!this.textureHalfFloatExtension&&!this.isRenderFloat32Supported)throw new Error("both float32 and float16 TextureType are not supported");this.isBlendSupported=!this.isRenderFloat32Supported||this.checkFloat32Blend(),this.maxTextureSize=t.getParameter(t.MAX_TEXTURE_SIZE),this.maxTextureImageUnits=t.getParameter(t.MAX_TEXTURE_IMAGE_UNITS),this.version}getExtensions(){this.version===2?(this.colorBufferFloatExtension=this.gl.getExtension("EXT_color_buffer_float"),this.disjointTimerQueryWebgl2Extension=this.gl.getExtension("EXT_disjoint_timer_query_webgl2")):(this.textureFloatExtension=this.gl.getExtension("OES_texture_float"),this.textureHalfFloatExtension=this.gl.getExtension("OES_texture_half_float"))}checkFloatTextureAttachableToFrameBuffer(){let t=this.gl,o=t.createTexture();t.bindTexture(t.TEXTURE_2D,o);let e=this.version===2?t.RGBA32F:t.RGBA;t.texImage2D(t.TEXTURE_2D,0,e,1,1,0,t.RGBA,t.FLOAT,null);let r=t.createFramebuffer();t.bindFramebuffer(t.FRAMEBUFFER,r),t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,o,0);let n=t.checkFramebufferStatus(t.FRAMEBUFFER)===t.FRAMEBUFFER_COMPLETE;return t.bindTexture(t.TEXTURE_2D,null),t.bindFramebuffer(t.FRAMEBUFFER,null),t.deleteTexture(o),t.deleteFramebuffer(r),n}checkRenderFloat32(){if(this.version===2){if(!this.colorBufferFloatExtension)return!1}else if(!this.textureFloatExtension)return!1;return this.isFloatTextureAttachableToFrameBuffer}checkFloat32Download(){if(this.version===2){if(!this.colorBufferFloatExtension)return!1}else if(!this.textureFloatExtension||!this.gl.getExtension("WEBGL_color_buffer_float"))return!1;return this.isFloatTextureAttachableToFrameBuffer}checkFloat32Blend(){let t=this.gl,o,e,r,n,s;try{o=t.createTexture(),e=t.createFramebuffer(),t.bindTexture(t.TEXTURE_2D,o);let i=this.version===2?t.RGBA32F:t.RGBA;return t.texImage2D(t.TEXTURE_2D,0,i,1,1,0,t.RGBA,t.FLOAT,null),t.bindFramebuffer(t.FRAMEBUFFER,e),t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0,t.TEXTURE_2D,o,0),t.enable(t.BLEND),r=t.createShader(t.VERTEX_SHADER),!r||(t.shaderSource(r,"void main(){}"),t.compileShader(r),n=t.createShader(t.FRAGMENT_SHADER),!n)||(t.shaderSource(n,"precision highp float;void main(){gl_FragColor=vec4(0.5);}"),t.compileShader(n),s=t.createProgram(),!s)?!1:(t.attachShader(s,r),t.attachShader(s,n),t.linkProgram(s),t.useProgram(s),t.drawArrays(t.POINTS,0,1),t.getError()===t.NO_ERROR)}finally{t.disable(t.BLEND),s&&t.deleteProgram(s),r&&t.deleteShader(r),n&&t.deleteShader(n),e&&(t.bindFramebuffer(t.FRAMEBUFFER,null),t.deleteFramebuffer(e)),o&&(t.bindTexture(t.TEXTURE_2D,null),t.deleteTexture(o))}}beginTimer(){if(this.version===2&&this.disjointTimerQueryWebgl2Extension){let t=this.gl,o=this.disjointTimerQueryWebgl2Extension,e=t.createQuery();return t.beginQuery(o.TIME_ELAPSED_EXT,e),e}else throw new Error("WebGL1 profiling currently not supported.")}endTimer(){if(this.version===2&&this.disjointTimerQueryWebgl2Extension){let t=this.gl,o=this.disjointTimerQueryWebgl2Extension;t.endQuery(o.TIME_ELAPSED_EXT);return}else throw new Error("WebGL1 profiling currently not supported")}isTimerResultAvailable(t){let o=!1,e=!1;if(this.version===2&&this.disjointTimerQueryWebgl2Extension){let r=this.gl,n=this.disjointTimerQueryWebgl2Extension;o=r.getQueryParameter(t,r.QUERY_RESULT_AVAILABLE),e=r.getParameter(n.GPU_DISJOINT_EXT)}else throw new Error("WebGL1 profiling currently not supported");return o&&!e}getTimerResult(t){let o=0;if(this.version===2){let e=this.gl;o=e.getQueryParameter(t,e.QUERY_RESULT),e.deleteQuery(t)}else throw new Error("WebGL1 profiling currently not supported");return o/1e6}async waitForQueryAndGetTime(t){return await mi(()=>this.isTimerResultAvailable(t)),this.getTimerResult(t)}async createAndWaitForFence(){let t=this.createFence(this.gl);return this.pollFence(t)}createFence(t){let o,e=t,r=e.fenceSync(e.SYNC_GPU_COMMANDS_COMPLETE,0);return t.flush(),r===null?o=()=>!0:o=()=>{let n=e.clientWaitSync(r,0,0);return n===e.ALREADY_SIGNALED||n===e.CONDITION_SATISFIED},{query:r,isFencePassed:o}}async pollFence(t){return new Promise(o=>{this.addItemToPoll(()=>t.isFencePassed(),()=>o())})}pollItems(){let t=jb(this.itemsToPoll.map(o=>o.isDoneFn));for(let o=0;o<=t;++o){let{resolveFn:e}=this.itemsToPoll[o];e()}this.itemsToPoll=this.itemsToPoll.slice(t+1)}async addItemToPoll(t,o){this.itemsToPoll.push({isDoneFn:t,resolveFn:o}),!(this.itemsToPoll.length>1)&&await mi(()=>(this.pollItems(),this.itemsToPoll.length===0))}}});function Hi(a){let t;if((!a||a==="webgl2")&&"webgl2"in Gr?t=Gr.webgl2:(!a||a==="webgl")&&"webgl"in Gr&&(t=Gr.webgl),!t)try{let e=Xb();t=cp(e,a)}catch{let r=Yb();t=cp(r,a)}a=a||t.version===1?"webgl":"webgl2";let o=t.gl;return Gr[a]=t,o.isContextLost()?(delete Gr[a],Hi(a)):(o.disable(o.DEPTH_TEST),o.disable(o.STENCIL_TEST),o.disable(o.BLEND),o.disable(o.DITHER),o.disable(o.POLYGON_OFFSET_FILL),o.disable(o.SAMPLE_COVERAGE),o.enable(o.SCISSOR_TEST),o.enable(o.CULL_FACE),o.cullFace(o.BACK),t)}function cp(a,t){let o={alpha:!1,depth:!1,antialias:!1,stencil:!1,preserveDrawingBuffer:!1,premultipliedAlpha:!1,failIfMajorPerformanceCaveat:!1},e,r=o;if((!t||t==="webgl2")&&(e=a.getContext("webgl2",r),e))try{return new hn(e,2)}catch(n){ce.warning("GlContextFactory",`failed to create WebGLContext using contextId 'webgl2'. Error: ${n}`)}if((!t||t==="webgl")&&(e=a.getContext("webgl",r)||a.getContext("experimental-webgl",r),e))try{return new hn(e,1)}catch(n){ce.warning("GlContextFactory",`failed to create WebGLContext using contextId 'webgl' or 'experimental-webgl'. Error: ${n}`)}throw new Error("WebGL is not supported")}function Yb(){if(typeof document>"u")throw new TypeError("failed to create canvas: document is not supported");let a=document.createElement("canvas");return a.width=1,a.height=1,a}function Xb(){if(typeof OffscreenCanvas>"u")throw new TypeError("failed to create offscreen canvas: OffscreenCanvas is not supported");return new OffscreenCanvas(1,1)}var Gr,pp=L(()=>{"use strict";lt();fp();Gr={}});var To,dp=L(()=>{"use strict";Ot();lt();lp();pp();To=class{get contextId(){return Z.webgl.contextId}set contextId(t){Z.webgl.contextId=t}get matmulMaxBatchSize(){return Z.webgl.matmulMaxBatchSize}set matmulMaxBatchSize(t){Z.webgl.matmulMaxBatchSize=t}get textureCacheMode(){return Z.webgl.textureCacheMode}set textureCacheMode(t){Z.webgl.textureCacheMode=t}get pack(){return Z.webgl.pack}set pack(t){Z.webgl.pack=t}get async(){return Z.webgl.async}set async(t){Z.webgl.async=t}initialize(){try{return this.glContext=Hi(this.contextId),typeof this.matmulMaxBatchSize!="number"&&(this.matmulMaxBatchSize=16),typeof this.textureCacheMode!="string"&&(this.textureCacheMode="full"),typeof this.pack!="boolean"&&(this.pack=!1),typeof this.async!="boolean"&&(this.async=!1),ce.setWithEnv(Z),Z.webgl.context||Object.defineProperty(Z.webgl,"context",{value:this.glContext.gl}),ce.verbose("WebGLBackend",`Created WebGLContext: ${typeof this.glContext} with matmulMaxBatchSize: ${this.matmulMaxBatchSize}; textureCacheMode: ${this.textureCacheMode}; pack: ${this.pack}; async: ${this.async}.`),!0}catch(t){return ce.warning("WebGLBackend",`Unable to initialize WebGLBackend. ${t}`),!1}}createSessionHandler(t){return new yo(this,t)}dispose(){this.glContext.dispose()}}});async function qi(a){if(a){let t=typeof a=="string"?[a]:a;for(let o of t){let e=hp.get(o);if(e)return e;let r=await Jb(o);if(r)return r}}else return qi(["webgl"]);throw new Error("no available backend to use")}async function Jb(a){let t=Kb;if(typeof t[a]<"u"&&Zb(t[a])){let o=t[a],e=o.initialize();if(typeof e=="object"&&"then"in e&&(e=await e),e)return hp.set(a,o),o}}function Zb(a){let t=a;return"initialize"in t&&typeof t.initialize=="function"&&"createSessionHandler"in t&&typeof t.createSessionHandler=="function"&&"dispose"in t&&typeof t.dispose=="function"}var hp,Kb,mp=L(()=>{"use strict";dp();hp=new Map,Kb={webgl:new To}});var ji,xo,bp=L(()=>{"use strict";lt();ji=class{constructor(t,o){this.op=t;this.node=o}},xo=class{constructor(t,o,e){this.graph=t;this.profiler=e;this.initialize(o)}initialize(t){this.profiler.event("session","ExecutionPlan.initialize",()=>{let o=this.graph.getNodes();if(o.length!==t.length)throw new Error("The size of nodes and OPs do not match.");this._ops=t.map((e,r)=>new ji(e,o[r])),this.reset(),this._starter=[],this._ops.forEach((e,r)=>{let n=!0;for(let s of e.node.inputs)if(!this._values[s]&&this.graph.getInputIndices().indexOf(s)===-1){n=!1;break}n&&this._starter.push(r)})})}reset(){this._values=this.graph.getValues().map(t=>t.tensor)}async execute(t,o){return this.profiler.event("session","ExecutionPlan.execute",async()=>{this.reset();let e=t.createInferenceHandler(),r=this.graph.getInputIndices();if(o.length!==r.length)throw new Error(`number of input tensors don't match the number of inputs to the model: actual: ${o.length} expected: ${r.length}`);o.forEach((c,p)=>{let d=r[p];this._values[d]=c});let n=this._starter.slice(0),s=this.graph.getValues(),i=this.graph.getNodes(),u=0;for(;u<n.length;){let c=n[u++],p=this._ops[c],d=p.node.inputs.map(S=>this._values[S]);if(d.indexOf(void 0)!==-1)throw new Error(`unresolved input detected: op: ${p.node}`);let T=d;ce.verbose("ExecPlan",`Runing op:${p.node.name} (${T.map((S,A)=>`'${p.node.inputs[A]}': ${S.type}[${S.dims.join(",")}]`).join(", ")})`);let w=await this.profiler.event("node",p.node.name,async()=>p.op.impl(e,T,p.op.context));if(w.length!==p.node.outputs.length)throw new Error("the size of output does not match model definition.");w.forEach((S,A)=>{let C=p.node.outputs[A];if(this._values[C])throw new Error(`output [${C}] already has value: op:${p.node.name}`);this._values[C]=S});let v=new Set;w.forEach((S,A)=>{let C=p.node.outputs[A];for(let F of s[C].to){let J=i[F],j=!0;for(let ie of J.inputs)if(!this._values[ie]){j=!1;break}j&&v.add(F)}}),n.push(...v)}let l=[];for(let c=0;c<this.graph.getOutputIndices().length;c++){let p=this.graph.getOutputIndices()[c],d=this._values[p];if(d===void 0)throw new Error(`required output [${p}] does not have value`);p===0?await d.getData():d.data,l.push(d)}return ce.verbose("ExecPlan","disposing of inferenceHandler"),e.dispose(),l})}}});var oe,bt,mn,gp=L(()=>{"use strict";tn();oe=Ar(Cr());yr();fe();bt=V.experimental.fbs,mn=class a{constructor(t){if(this._attributes=new Map,t!=null){for(let o of t)o instanceof oe.onnx.AttributeProto?this._attributes.set(o.name,[a.getValue(o),a.getType(o)]):o instanceof bt.Attribute&&this._attributes.set(o.name(),[a.getValue(o),a.getType(o)]);if(this._attributes.size<t.length)throw new Error("duplicated attribute names")}}set(t,o,e){this._attributes.set(t,[e,o])}delete(t){this._attributes.delete(t)}getFloat(t,o){return this.get(t,"float",o)}getInt(t,o){return this.get(t,"int",o)}getString(t,o){return this.get(t,"string",o)}getTensor(t,o){return this.get(t,"tensor",o)}getFloats(t,o){return this.get(t,"floats",o)}getInts(t,o){return this.get(t,"ints",o)}getStrings(t,o){return this.get(t,"strings",o)}getTensors(t,o){return this.get(t,"tensors",o)}get(t,o,e){let r=this._attributes.get(t);if(r===void 0){if(e!==void 0)return e;throw new Error(`required attribute not found: ${t}`)}if(r[1]!==o)throw new Error(`type mismatch: expected ${o} but got ${r[1]}`);return r[0]}static getType(t){let o=t instanceof oe.onnx.AttributeProto?t.type:t.type();switch(o){case oe.onnx.AttributeProto.AttributeType.FLOAT:return"float";case oe.onnx.AttributeProto.AttributeType.INT:return"int";case oe.onnx.AttributeProto.AttributeType.STRING:return"string";case oe.onnx.AttributeProto.AttributeType.TENSOR:return"tensor";case oe.onnx.AttributeProto.AttributeType.FLOATS:return"floats";case oe.onnx.AttributeProto.AttributeType.INTS:return"ints";case oe.onnx.AttributeProto.AttributeType.STRINGS:return"strings";case oe.onnx.AttributeProto.AttributeType.TENSORS:return"tensors";default:throw new Error(`attribute type is not supported yet: ${oe.onnx.AttributeProto.AttributeType[o]}`)}}static getValue(t){let o=t instanceof oe.onnx.AttributeProto?t.type:t.type();if(o===oe.onnx.AttributeProto.AttributeType.GRAPH||o===oe.onnx.AttributeProto.AttributeType.GRAPHS)throw new Error("graph attribute is not supported yet");let e=this.getValueNoCheck(t);if(o===oe.onnx.AttributeProto.AttributeType.INT&&it.isLong(e))return it.longToNumber(e);if(o===oe.onnx.AttributeProto.AttributeType.INTS){let r=e,n=new Array(r.length);for(let s=0;s<r.length;s++){let i=r[s];n[s]=it.longToNumber(i)}return n}if(o===oe.onnx.AttributeProto.AttributeType.TENSOR)return t instanceof oe.onnx.AttributeProto?$e.fromProto(e):$e.fromOrtTensor(e);if(o===oe.onnx.AttributeProto.AttributeType.TENSORS){if(t instanceof oe.onnx.AttributeProto)return e.map(n=>$e.fromProto(n));if(t instanceof bt.Attribute)return e.map(n=>$e.fromOrtTensor(n))}return o===oe.onnx.AttributeProto.AttributeType.STRING&&t instanceof oe.onnx.AttributeProto?sn(e):o===oe.onnx.AttributeProto.AttributeType.STRINGS&&t instanceof oe.onnx.AttributeProto?e.map(sn):e}static getValueNoCheck(t){return t instanceof oe.onnx.AttributeProto?this.getValueNoCheckFromOnnxFormat(t):this.getValueNoCheckFromOrtFormat(t)}static getValueNoCheckFromOnnxFormat(t){switch(t.type){case oe.onnx.AttributeProto.AttributeType.FLOAT:return t.f;case oe.onnx.AttributeProto.AttributeType.INT:return t.i;case oe.onnx.AttributeProto.AttributeType.STRING:return t.s;case oe.onnx.AttributeProto.AttributeType.TENSOR:return t.t;case oe.onnx.AttributeProto.AttributeType.GRAPH:return t.g;case oe.onnx.AttributeProto.AttributeType.FLOATS:return t.floats;case oe.onnx.AttributeProto.AttributeType.INTS:return t.ints;case oe.onnx.AttributeProto.AttributeType.STRINGS:return t.strings;case oe.onnx.AttributeProto.AttributeType.TENSORS:return t.tensors;case oe.onnx.AttributeProto.AttributeType.GRAPHS:return t.graphs;default:throw new Error(`unsupported attribute type: ${oe.onnx.AttributeProto.AttributeType[t.type]}`)}}static getValueNoCheckFromOrtFormat(t){switch(t.type()){case bt.AttributeType.FLOAT:return t.f();case bt.AttributeType.INT:return t.i();case bt.AttributeType.STRING:return t.s();case bt.AttributeType.TENSOR:return t.t();case bt.AttributeType.GRAPH:return t.g();case bt.AttributeType.FLOATS:return t.floatsArray();case bt.AttributeType.INTS:{let o=[];for(let e=0;e<t.intsLength();e++)o.push(t.ints(e));return o}case bt.AttributeType.STRINGS:{let o=[];for(let e=0;e<t.stringsLength();e++)o.push(t.strings(e));return o}case bt.AttributeType.TENSORS:{let o=[];for(let e=0;e<t.tensorsLength();e++)o.push(t.tensors(e));return o}default:throw new Error(`unsupported attribute type: ${bt.AttributeType[t.type()]}`)}}}});var Xi,wo,Ki,Mt,vo,Yi,yp=L(()=>{"use strict";gp();tn();Xi=Ar(Cr());yr();fe();wo=V.experimental.fbs,Ki={from:(a,t)=>new Yi(a,t)},Mt=class{constructor(t){this._from=void 0,this._to=[],this.tensor=void 0,this.type=void 0,t&&(this.type=We.tensorValueTypeFromProto(t.type.tensorType))}get from(){return this._from}get to(){return this._to}},vo=class{constructor(t,o){t instanceof Xi.onnx.NodeProto?(this.name=t.name,this.opType=t.opType,this.attributes=new mn(t.attribute)):t instanceof wo.Node&&(this.name=o??t.name(),this.opType=t.opType(),this.attributes=new mn(We.tensorAttributesFromORTFormat(t))),this.inputs=[],this.outputs=[],this.executeNode=!0}},Yi=class{constructor(t,o){if(!t)throw new TypeError("graph is empty");this.buildGraph(t),this.transformGraph(o),this.checkIsAcyclic()}getInputIndices(){return this._allInputIndices}getInputNames(){return this._allInputNames}getOutputIndices(){return this._allOutputIndices}getOutputNames(){return this._allOutputNames}getValues(){return this._allData}getNodes(){return this._nodes}buildGraph(t){if(t instanceof Xi.onnx.GraphProto)this.buildGraphFromOnnxFormat(t);else if(t instanceof wo.Graph)this.buildGraphFromOrtFormat(t);else throw new TypeError("Graph type is not supported.")}buildGraphFromOnnxFormat(t){let o=new Map;this._allData=[],this._allInputIndices=[],this._allInputNames=[],this._allOutputIndices=[],this._allOutputNames=[],this._nodes=[];let e=new Map;if(!t.input)throw new Error("missing information in graph: input");let r=[];for(let n of t.input){if(o.has(n.name))throw new Error(`duplicated input name: ${n.name}`);let s=this._allData.push(new Mt(n))-1;o.set(n.name,s),r.push(n.name)}if(!t.initializer)throw new Error("missing information in graph: initializer");for(let n of t.initializer){let s=o.get(n.name);if(s===void 0){let i=new Mt;i.type={shape:{dims:We.tensorDimsFromProto(n.dims)},tensorType:We.tensorDataTypeFromProto(n.dataType)},s=this._allData.push(i)-1,o.set(n.name,s)}this._allData[s]._from=-1,this._allData[s].tensor=$e.fromProto(n)}for(let n=0;n<this._allData.length;n++)this._allData[n].tensor||(this._allInputIndices.push(n),this._allInputNames.push(r[n]));if(!t.output)throw new Error("missing information in graph: output");for(let n of t.output){if(o.has(n.name))throw new Error(`duplicated output name: ${n.name}`);let s=this._allData.push(new Mt(n))-1;o.set(n.name,s),this._allOutputIndices.push(s),this._allOutputNames.push(n.name)}if(!t.node)throw new Error("missing information in graph: node");for(let n of t.node){if(!n.name)for(let i=0;;i++){let u=`unnamed_${n.opType}_${i}`;if(!e.has(u)){n.name=u;break}}if(e.has(n.name))throw new Error(`duplicated node name: ${n.name}`);let s=this._nodes.push(new vo(n))-1;e.set(n.name,s)}for(let n=0;n<this._nodes.length;n++){let s=this._nodes[n],i=t.node[n];if(!i.output)throw new Error(`missing output for node: ${i.name}`);for(let u of i.output){let l=o.get(u);if(typeof l>"u"&&(l=this._allData.push(new Mt)-1,o.set(u,l)),s.outputs.push(l),this._allData[l]._from!==void 0)throw new Error(`multiple nodes output to one data value: ${l}`);if(this._allData[l]._from=n,i.opType==="Constant"){if(!i.attribute||i.attribute.length!==1||!i.attribute[0].t)throw new Error("missing attributes or missing tensor value in attributes for this Constant operator");if(!i.output||i.output.length!==1)throw new Error("missing output or incorrect number of outputs for this Constant operator");s.outputs.pop(),s.executeNode=!1,this._allData[l]._from=-1,this._allData[l].tensor=$e.fromProto(i.attribute[0].t)}}}for(let n=0;n<this._nodes.length;n++){let s=this._nodes[n],i=t.node[n];if(!i.input)throw new Error(`missing input for node: ${i.name}`);for(let u of i.input){let l=o.get(u);if(typeof l>"u"){if(u===""&&(i.input.length===3||i.input.length===4)&&i.opType==="Resize")continue;throw new Error(`unrecognized input '${u}' for node: ${i.name}`)}s.inputs.push(l),this._allData[l]._to.push(n)}}return!0}buildGraphFromOrtFormat(t){let o=new Map;this._allData=[],this._allInputIndices=[],this._allInputNames=[],this._allOutputIndices=[],this._allOutputNames=[],this._nodes=[];let e=new Map,r=[];for(let n=0;n<t.inputsLength();n++){let s=t.inputs(n);if(o.has(s))throw new Error(`duplicated input name: ${s}`);for(let i=0;i<t.nodeArgsLength();i++)if(t.nodeArgs(i)?.name()===s){let u=new Mt;if(t.nodeArgs(i)?.type()?.valueType()!==wo.TypeInfoValue.tensor_type)throw new Error("Unexpected value type for the nodeArg.");let c=t.nodeArgs(i).type().value(new wo.TensorTypeAndShape),p=We.tensorDataTypeFromProto(c.elemType()),d=c.shape(),T=[];for(let v=0;v<d.dimLength();v++)T.push(it.longToNumber(d.dim(v).value().dimValue()));u.type={shape:{dims:T},tensorType:p};let w=this._allData.push(u)-1;o.set(s,w),r.push(s)}}for(let n=0;n<t.initializersLength();n++){let s=t.initializers(n),i=o.get(s.name());if(i===void 0){let u=new Mt,l=We.tensorDimsFromORTFormat(s),c=We.tensorDataTypeFromProto(s.dataType());u.type={shape:{dims:l},tensorType:c},i=this._allData.push(u)-1,o.set(s.name(),i)}this._allData[i]._from=-1,this._allData[i].tensor=$e.fromOrtTensor(s)}for(let n=0;n<this._allData.length;n++)this._allData[n].tensor||(this._allInputIndices.push(n),this._allInputNames.push(r[n]));for(let n=0;n<t.outputsLength();n++){let s=t.outputs(n);if(o.has(s))throw new Error(`duplicated output name: ${s}`);let i=this._allData.push(new Mt)-1;o.set(s,i),this._allOutputIndices.push(i),this._allOutputNames.push(s)}if(!t.nodes)throw new Error("missing information in graph: node");for(let n=0;n<t.nodesLength();n++){let s=t.nodes(n),i=s.name();if(!i)for(let l=0;i=`unnamed_${s.opType()}_${l}`,!!e.has(i);l++);if(e.has(i))throw new Error(`duplicated node name: ${i}`);let u=this._nodes.push(new vo(s,i))-1;e.set(i,u)}for(let n=0;n<this._nodes.length;n++){let s=this._nodes[n],i=t.nodes(n);if(i==null)throw new Error(`No node exists at index ${n}`);if(i?.outputsLength()===0)throw new Error(`missing output for node: ${i.name}`);for(let u=0;u<i?.outputsLength();u++){let l=i?.outputs(u),c=o.get(l);if(typeof c>"u"&&(c=this._allData.push(new Mt)-1,o.set(l,c)),s.outputs.push(c),this._allData[c]._from!==void 0)throw new Error(`multiple nodes output to one data value: ${c}`);if(this._allData[c]._from=n,i.opType()==="Constant"){if(i.attributesLength()!==1||!i.attributes(0).t())throw new Error("missing attributes or missing tensor value in attributes for this Constant operator");if(i.outputsLength()!==1)throw new Error("missing output or incorrect number of outputs for this Constant operator");s.outputs.pop(),s.executeNode=!1,this._allData[c]._from=-1,this._allData[c].tensor=$e.fromOrtTensor(i.attributes(0).t())}}}for(let n=0;n<this._nodes.length;n++){let s=this._nodes[n],i=t.nodes(n);if(i.inputsLength()===0)throw new Error(`missing input for node: ${i.name}`);for(let u=0;u<i.inputsLength();u++){let l=i.inputs(u),c=o.get(l);if(typeof c>"u")throw new Error(`unrecognized input '${l}' for node: ${i.name()}`);s.inputs.push(c),this._allData[c]._to.push(n)}}}checkIsAcyclic(){let t=new Set;this._allInputIndices.forEach(r=>{this._allData[r]._to.forEach(s=>{t.add(s)})});let o=Array.from(t),e=new Array(this._nodes.length).fill("white");for(;o.length>0;){let r=o.pop();e[r]==="gray"?e[r]="black":(o.push(r),e[r]="gray",this._nodes[r].outputs.forEach(n=>{let s=this._allData[n];if(typeof s.tensor<"u")throw new Error("node outputs should not be initialized");if(s._from!==r)throw new Error("from property of the Value object doesn't match index of Node being processed");s._to.forEach(i=>{if(e[i]==="gray")throw new Error("model graph is cyclic");e[i]==="white"&&o.push(i)})}))}}transformGraph(t){this.removeAllIdentityNodes(),this.removeAllDropoutNodes(),this.fuseConvActivationNodes(),t&&t.transformGraph(this),this.finalizeGraph()}finalizeGraph(){let t=0,o=new Array(this._nodes.length,0),e=0;for(let r=0;r<this._nodes.length;r++)o[r]=e,this._nodes[r].executeNode?(e!==r&&(this._nodes[e]=this._nodes[r]),e++):this._nodes[r].outputs.forEach(n=>{this._allData[n]._from=-2});this._nodes.splice(e,this._nodes.length-e);for(let r=0;r<this._allData.length;r++){let n=this._allData[r];n._from!==void 0&&n._from!==-1&&n._from!==-2&&(n._from=o[n._from]);for(let s=0;s<n._to.length;s++)if(n._to[s]>=0)n._to[s]=o[n._to[s]];else throw new Error("Trying to update a removed node")}t=0;for(let r=0;r<this._allData.length;r++){if(this._allData[r].from===-2&&this._allOutputIndices.indexOf(r+t)===-1){t++,this._allData.splice(r,1),r--;continue}if(t>0){let n=-1;this._allData[r].from!==void 0&&this._allData[r].from!==-1?(n=this._nodes[this._allData[r].from].outputs.indexOf(r+t),n!==-1&&(this._nodes[this._allData[r].from].outputs[n]=r)):(n=this._allInputIndices.indexOf(r+t),n!==-1&&(this._allInputIndices[n]=r)),this._allData[r].to.forEach(s=>{n=this._nodes[s].inputs.indexOf(r+t),n!==-1&&(this._nodes[s].inputs[n]=r)}),this._allData[r].to.length===0&&(n=this._allOutputIndices.indexOf(r+t),n!==-1&&(this._allOutputIndices[n]=r))}}}deleteNode(t){let o=this._nodes[t];if(o.outputs.length>1){for(let i=1;i<o.outputs.length;i++)if(this._allData[o.outputs[i]].to.length>0)throw new Error("Node deletion with more than one output connected to other nodes is not supported. ")}o.executeNode=!1;let e=o.inputs[0],r=o.outputs[0],n=this._allData[r].to;for(let i=0;i<o.inputs.length;i++){let u=this._allData[o.inputs[i]].to.indexOf(t);if(u===-1)throw new Error("The Value object doesn't have the current Node in it's 'to' property ");this._allData[o.inputs[i]].to.splice(u,1)}this._allData[r]._to=[];let s=this._allOutputIndices.indexOf(r);if(s!==-1&&(this._allOutputIndices[s]=e),n&&n.length>0)for(let i of n){let u=this._nodes[i].inputs.indexOf(r);if(u===-1)throw new Error("The Node object doesn't have the output Value in it's 'inputs' property ");this._nodes[i].inputs[u]=e,this._allData[e].to.push(i)}}removeAllDropoutNodes(){let t=0;for(let o of this._nodes){if(o.opType==="Dropout"){if(o.inputs.length!==1)throw new Error("Dropout nodes should only contain one input. ");if(o.outputs.length!==1&&o.outputs.length!==2)throw new Error("Dropout nodes should contain either 1 or 2 output(s)");if(o.outputs.length===2&&this._allData[o.outputs[1]]._to.length!==0)throw new Error("Dropout nodes's second output should not be referenced by other nodes");this.deleteNode(t)}t++}}removeAllIdentityNodes(){let t=0;for(let o of this._nodes)o.opType==="Identity"&&this.deleteNode(t),t++}isActivation(t){switch(t.opType){case"Relu":case"Sigmoid":case"Clip":return!0;default:return!1}}fuseConvActivationNodes(){for(let t of this._nodes)if(t.opType==="Conv"){let o=this._allData[t.outputs[0]]._to;if(o.length===1&&this.isActivation(this._nodes[o[0]])){let e=this._nodes[o[0]];if(e.opType==="Clip")if(e.inputs.length===1)try{t.attributes.set("activation_params","floats",[e.attributes.getFloat("min"),e.attributes.getFloat("max")])}catch{t.attributes.set("activation_params","floats",[br,gr])}else if(e.inputs.length>=3&&this._allData[e.inputs[1]].tensor!==void 0&&this._allData[e.inputs[2]].tensor!==void 0)t.attributes.set("activation_params","floats",[this._allData[e.inputs[1]].tensor.floatData[0],this._allData[e.inputs[2]].tensor.floatData[0]]);else continue;t.attributes.set("activation","string",e.opType),this.deleteNode(o[0])}}}}});var Tp,Qb,_o,xp=L(()=>{"use strict";zn();yp();tn();Tp=Ar(Cr());fe();Qb=V.experimental.fbs,_o=class{constructor(){}load(t,o,e){let r;if(!e)try{this.loadFromOnnxFormat(t,o);return}catch(n){if(e!==void 0)throw n;r=n}try{this.loadFromOrtFormat(t,o)}catch(n){throw e!==void 0?n:new Error(`Failed to load model as ONNX format: ${r}
as ORT format: ${n}`)}}loadFromOnnxFormat(t,o){let e=Tp.onnx.ModelProto.decode(t);if(it.longToNumber(e.irVersion)<3)throw new Error("only support ONNX model with IR_VERSION>=3");this._opsets=e.opsetImport.map(n=>({domain:n.domain,version:it.longToNumber(n.version)})),this._graph=Ki.from(e.graph,o)}loadFromOrtFormat(t,o){let e=new _.ByteBuffer(t),r=Qb.InferenceSession.getRootAsInferenceSession(e).model();if(it.longToNumber(r.irVersion())<3)throw new Error("only support ONNX model with IR_VERSION>=3");this._opsets=[];for(let s=0;s<r.opsetImportLength();s++){let i=r.opsetImport(s);this._opsets.push({domain:i?.domain(),version:it.longToNumber(i.version())})}this._graph=Ki.from(r.graph(),o)}get graph(){return this._graph}get opsets(){return this._opsets}}});var Oo,wp=L(()=>{"use strict";mp();bp();lt();xp();Oo=class{constructor(t={}){this._initialized=!1,this.backendHint=t.backendHint,this.profiler=Gn.create(t.profiler),this.context={profiler:this.profiler,graphInputTypes:[],graphInputDims:[]}}get inputNames(){return this._model.graph.getInputNames()}get outputNames(){return this._model.graph.getOutputNames()}startProfiling(){this.profiler.start()}endProfiling(){this.profiler.stop()}async loadModel(t,o,e){await this.profiler.event("session","Session.loadModel",async()=>{let r=await qi(this.backendHint);if(this.sessionHandler=r.createSessionHandler(this.context),this._model=new _o,typeof t=="string"){let n=t.endsWith(".ort");if(typeof process<"u"&&process.versions&&process.versions.node){let s=await(void 0)(t);this.initialize(s,n)}else{let i=await(await fetch(t)).arrayBuffer();this.initialize(new Uint8Array(i),n)}}else if(ArrayBuffer.isView(t))this.initialize(t);else{let n=new Uint8Array(t,o||0,e||t.byteLength);this.initialize(n)}})}initialize(t,o){if(this._initialized)throw new Error("already initialized");this.profiler.event("session","Session.initialize",()=>{let e=this.sessionHandler.transformGraph?this.sessionHandler:void 0;this._model.load(t,e,o),this.sessionHandler.onGraphInitialized&&this.sessionHandler.onGraphInitialized(this._model.graph),this.initializeOps(this._model.graph),this._executionPlan=new xo(this._model.graph,this._ops,this.profiler)}),this._initialized=!0}async run(t){if(!this._initialized)throw new Error("session not initialized yet");return this.profiler.event("session","Session.run",async()=>{let o=this.normalizeAndValidateInputs(t),e=await this._executionPlan.execute(this.sessionHandler,o);return this.createOutput(e)})}normalizeAndValidateInputs(t){let o=this._model.graph.getInputNames();if(Array.isArray(t)){if(t.length!==o.length)throw new Error(`incorrect input array length: expected ${o.length} but got ${t.length}`)}else{if(t.size!==o.length)throw new Error(`incorrect input map size: expected ${o.length} but got ${t.size}`);let e=new Array(t.size),r=0;for(let n=0;n<o.length;++n){let s=t.get(o[n]);if(!s)throw new Error(`missing input tensor for: '${name}'`);e[r++]=s}t=e}if(!this.context.graphInputTypes||this.context.graphInputTypes.length===0||!this.context.graphInputDims||this.context.graphInputDims.length===0){let e=this._model.graph.getInputIndices(),r=this._model.graph.getValues(),n=new Array(e.length);for(let s=0;s<e.length;++s){let i=r[e[s]];n[s]=i.type.shape.dims,this.context.graphInputTypes.push(i.type.tensorType),this.context.graphInputDims.push(t[s].dims)}this.validateInputTensorDims(n,t,!0)}else this.validateInputTensorDims(this.context.graphInputDims,t,!1);return this.validateInputTensorTypes(this.context.graphInputTypes,t),t}validateInputTensorTypes(t,o){for(let e=0;e<o.length;e++){let r=t[e],n=o[e].type;if(r!==n)throw new Error(`input tensor[${e}] check failed: expected type '${r}' but got ${n}`)}}validateInputTensorDims(t,o,e){for(let r=0;r<o.length;r++){let n=t[r],s=o[r].dims;if(!this.compareTensorDims(n,s,e))throw new Error(`input tensor[${r}] check failed: expected shape '[${n.join(",")}]' but got [${s.join(",")}]`)}}compareTensorDims(t,o,e){if(t.length!==o.length)return!1;for(let r=0;r<t.length;++r)if(t[r]!==o[r]&&(!e||t[r]!==0))return!1;return!0}createOutput(t){let o=this._model.graph.getOutputNames();if(t.length!==o.length)throw new Error("expected number of outputs do not match number of generated outputs");let e=new Map;for(let r=0;r<o.length;++r)e.set(o[r],t[r]);return e}initializeOps(t){let o=t.getNodes();this._ops=new Array(o.length);for(let e=0;e<o.length;e++)this._ops[e]=this.sessionHandler.resolve(o[e],this._model.opsets,t)}}});var Io,vp=L(()=>{"use strict";Ot();yr();Io=class{constructor(t){this.session=t;this.inputNames=this.session.inputNames,this.outputNames=this.session.outputNames}async dispose(){}async run(t,o,e){let r=new Map;for(let i in t)if(Object.hasOwnProperty.call(t,i)){let u=t[i];r.set(i,new $e(u.dims,u.type,void 0,void 0,u.data))}let n=await this.session.run(r),s={};return n.forEach((i,u)=>{s[u]=new Me(i.type,i.data,i.dims)}),s}startProfiling(){this.session.startProfiling()}endProfiling(){this.session.endProfiling()}}});var _p={};Sr(_p,{onnxjsBackend:()=>tg});var Ji,tg,Op=L(()=>{"use strict";wp();vp();Ji=class{async init(){}async createInferenceSessionHandler(t,o){let e=new Oo(o);return typeof t=="string"?await e.loadModel(t):await e.loadModel(t),new Io(e)}},tg=new Ji});var Zi={};Sr(Zi,{createReadStream:()=>Ip,readFile:()=>rg,readFileSync:()=>ng});var rg,ng,Ip,Qi=L(()=>{rg=void 0,ng=void 0,Ip=void 0});var ea={};Sr(ea,{join:()=>og});var og,ta=L(()=>{og=void 0});var Pp=me((Ap,ra)=>{"use strict";var Sp=(()=>{var a=typeof document<"u"?document.currentScript?.src:void 0;return typeof __filename<"u"&&(a||=__filename),function(t={}){var o=t,e,r,n=new Promise((m,x)=>{e=m,r=x}),s=Object.assign({},o),i="./this.program",u=typeof window=="object",l=typeof importScripts=="function",c=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",p="",d,T,w;if(c){var v=(Qi(),ar(Zi)),S=(ta(),ar(ea));p=l?S.dirname(p)+"/":__dirname+"/",d=(m,x)=>(m=Ke(m)?new URL(m):S.normalize(m),v.readFileSync(m,x?void 0:"utf8")),w=m=>(m=d(m,!0),m.buffer||(m=new Uint8Array(m)),m),T=(m,x,O,D=!0)=>{m=Ke(m)?new URL(m):S.normalize(m),v.readFile(m,D?void 0:"utf8",(M,q)=>{M?O(M):x(D?q.buffer:q)})},!o.thisProgram&&1<process.argv.length&&(i=process.argv[1].replace(/\\/g,"/")),process.argv.slice(2)}else(u||l)&&(l?p=self.location.href:typeof document<"u"&&document.currentScript&&(p=document.currentScript.src),a&&(p=a),p.startsWith("blob:")?p="":p=p.substr(0,p.replace(/[?#].*/,"").lastIndexOf("/")+1),d=m=>{var x=new XMLHttpRequest;return x.open("GET",m,!1),x.send(null),x.responseText},l&&(w=m=>{var x=new XMLHttpRequest;return x.open("GET",m,!1),x.responseType="arraybuffer",x.send(null),new Uint8Array(x.response)}),T=(m,x,O)=>{var D=new XMLHttpRequest;D.open("GET",m,!0),D.responseType="arraybuffer",D.onload=()=>{D.status==200||D.status==0&&D.response?x(D.response):O()},D.onerror=O,D.send(null)});var A=console.log.bind(console),C=console.error.bind(console);Object.assign(o,s),s=null;var F,J=!1,j,ie,G,Te,He;function Le(){var m=F.buffer;o.HEAP8=j=new Int8Array(m),o.HEAP16=new Int16Array(m),o.HEAPU8=ie=new Uint8Array(m),o.HEAPU16=new Uint16Array(m),o.HEAP32=G=new Int32Array(m),o.HEAPU32=Te=new Uint32Array(m),o.HEAPF32=new Float32Array(m),o.HEAPF64=He=new Float64Array(m)}var Y=[],Ne=[],Se=[],yt=0,et=null,ee=null;function qe(m){throw m="Aborted("+m+")",C(m),J=!0,m=new WebAssembly.RuntimeError(m+". Build with -sASSERTIONS for more info."),r(m),m}var Ht=m=>m.startsWith("data:application/octet-stream;base64,"),Ke=m=>m.startsWith("file://"),at;if(at="ort-wasm.wasm",!Ht(at)){var Re=at;at=o.locateFile?o.locateFile(Re,p):p+Re}function Ce(m){if(w)return w(m);throw"both async and sync fetching of the wasm failed"}function Hr(m){if(u||l){if(typeof fetch=="function"&&!Ke(m))return fetch(m,{credentials:"same-origin"}).then(x=>{if(!x.ok)throw`failed to load wasm binary file at '${m}'`;return x.arrayBuffer()}).catch(()=>Ce(m));if(T)return new Promise((x,O)=>{T(m,D=>x(new Uint8Array(D)),O)})}return Promise.resolve().then(()=>Ce(m))}function Tt(m,x,O){return Hr(m).then(D=>WebAssembly.instantiate(D,x)).then(O,D=>{C(`failed to asynchronously prepare wasm: ${D}`),qe(D)})}function qt(m,x){var O=at;return typeof WebAssembly.instantiateStreaming!="function"||Ht(O)||Ke(O)||c||typeof fetch!="function"?Tt(O,m,x):fetch(O,{credentials:"same-origin"}).then(D=>WebAssembly.instantiateStreaming(D,m).then(x,function(M){return C(`wasm streaming compile failed: ${M}`),C("falling back to ArrayBuffer instantiation"),Tt(O,m,x)}))}var xt,Lt={798088:(m,x,O,D)=>{if(typeof o>"u"||!o.ya)return 1;if(m=je(m>>>0),m.startsWith("./")&&(m=m.substring(2)),m=o.ya.get(m),!m)return 2;if(x>>>=0,O>>>=0,x+O>m.byteLength)return 3;try{return ie.set(m.subarray(x,x+O),D>>>0>>>0),0}catch{return 4}}};class wt{constructor(x){this.wa=x-24}}var tt=0,tr=0,ke=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,Be=(m,x,O)=>{x>>>=0;var D=x+O;for(O=x;m[O]&&!(O>=D);)++O;if(16<O-x&&m.buffer&&ke)return ke.decode(m.subarray(x,O));for(D="";x<O;){var M=m[x++];if(M&128){var q=m[x++]&63;if((M&224)==192)D+=String.fromCharCode((M&31)<<6|q);else{var re=m[x++]&63;M=(M&240)==224?(M&15)<<12|q<<6|re:(M&7)<<18|q<<12|re<<6|m[x++]&63,65536>M?D+=String.fromCharCode(M):(M-=65536,D+=String.fromCharCode(55296|M>>10,56320|M&1023))}}else D+=String.fromCharCode(M)}return D},je=(m,x)=>(m>>>=0)?Be(ie,m,x):"",vt=m=>{for(var x=0,O=0;O<m.length;++O){var D=m.charCodeAt(O);127>=D?x++:2047>=D?x+=2:55296<=D&&57343>=D?(x+=4,++O):x+=3}return x},_t=(m,x,O,D)=>{if(O>>>=0,!(0<D))return 0;var M=O;D=O+D-1;for(var q=0;q<m.length;++q){var re=m.charCodeAt(q);if(55296<=re&&57343>=re){var Fe=m.charCodeAt(++q);re=65536+((re&1023)<<10)|Fe&1023}if(127>=re){if(O>=D)break;x[O++>>>0]=re}else{if(2047>=re){if(O+1>=D)break;x[O++>>>0]=192|re>>6}else{if(65535>=re){if(O+2>=D)break;x[O++>>>0]=224|re>>12}else{if(O+3>=D)break;x[O++>>>0]=240|re>>18,x[O++>>>0]=128|re>>12&63}x[O++>>>0]=128|re>>6&63}x[O++>>>0]=128|re&63}}return x[O>>>0]=0,O-M},jt=m=>m%4===0&&(m%100!==0||m%400===0),qr=[0,31,60,91,121,152,182,213,244,274,305,335],Tn=[0,31,59,90,120,151,181,212,243,273,304,334],Ct=[],Or={},rr=()=>{if(!nr){var m={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",_:i||"./this.program"},x;for(x in Or)Or[x]===void 0?delete m[x]:m[x]=Or[x];var O=[];for(x in m)O.push(`${x}=${m[x]}`);nr=O}return nr},nr,xn=[null,[],[]],Gt=[31,29,31,30,31,30,31,31,30,31,30,31],wn=[31,28,31,30,31,30,31,31,30,31,30,31];function he(m){var x=Array(vt(m)+1);return _t(m,x,0,x.length),x}function jr(m,x,O,D){function M(P,pe,xe){for(P=typeof P=="number"?P.toString():P||"";P.length<pe;)P=xe[0]+P;return P}function q(P,pe){return M(P,pe,"0")}function re(P,pe){function xe(Zr){return 0>Zr?-1:0<Zr?1:0}var Ft;return(Ft=xe(P.getFullYear()-pe.getFullYear()))===0&&(Ft=xe(P.getMonth()-pe.getMonth()))===0&&(Ft=xe(P.getDate()-pe.getDate())),Ft}function Fe(P){switch(P.getDay()){case 0:return new Date(P.getFullYear()-1,11,29);case 1:return P;case 2:return new Date(P.getFullYear(),0,3);case 3:return new Date(P.getFullYear(),0,2);case 4:return new Date(P.getFullYear(),0,1);case 5:return new Date(P.getFullYear()-1,11,31);case 6:return new Date(P.getFullYear()-1,11,30)}}function st(P){var pe=P.sa;for(P=new Date(new Date(P.ta+1900,0,1).getTime());0<pe;){var xe=P.getMonth(),Ft=(jt(P.getFullYear())?Gt:wn)[xe];if(pe>Ft-P.getDate())pe-=Ft-P.getDate()+1,P.setDate(1),11>xe?P.setMonth(xe+1):(P.setMonth(0),P.setFullYear(P.getFullYear()+1));else{P.setDate(P.getDate()+pe);break}}return xe=new Date(P.getFullYear()+1,0,4),pe=Fe(new Date(P.getFullYear(),0,4)),xe=Fe(xe),0>=re(pe,P)?0>=re(xe,P)?P.getFullYear()+1:P.getFullYear():P.getFullYear()-1}m>>>=0,x>>>=0,O>>>=0,D>>>=0;var ze=Te[D+40>>>2>>>0];D={Ba:G[D>>>2>>>0],Aa:G[D+4>>>2>>>0],ua:G[D+8>>>2>>>0],xa:G[D+12>>>2>>>0],va:G[D+16>>>2>>>0],ta:G[D+20>>>2>>>0],na:G[D+24>>>2>>>0],sa:G[D+28>>>2>>>0],Da:G[D+32>>>2>>>0],za:G[D+36>>>2>>>0],Ca:ze?je(ze):""},O=je(O),ze={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var Ve in ze)O=O.replace(new RegExp(Ve,"g"),ze[Ve]);var Jr="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),Yt="January February March April May June July August September October November December".split(" ");ze={"%a":P=>Jr[P.na].substring(0,3),"%A":P=>Jr[P.na],"%b":P=>Yt[P.va].substring(0,3),"%B":P=>Yt[P.va],"%C":P=>q((P.ta+1900)/100|0,2),"%d":P=>q(P.xa,2),"%e":P=>M(P.xa,2," "),"%g":P=>st(P).toString().substring(2),"%G":st,"%H":P=>q(P.ua,2),"%I":P=>(P=P.ua,P==0?P=12:12<P&&(P-=12),q(P,2)),"%j":P=>{for(var pe=0,xe=0;xe<=P.va-1;pe+=(jt(P.ta+1900)?Gt:wn)[xe++]);return q(P.xa+pe,3)},"%m":P=>q(P.va+1,2),"%M":P=>q(P.Aa,2),"%n":()=>`
`,"%p":P=>0<=P.ua&&12>P.ua?"AM":"PM","%S":P=>q(P.Ba,2),"%t":()=>"	","%u":P=>P.na||7,"%U":P=>q(Math.floor((P.sa+7-P.na)/7),2),"%V":P=>{var pe=Math.floor((P.sa+7-(P.na+6)%7)/7);if(2>=(P.na+371-P.sa-2)%7&&pe++,pe)pe==53&&(xe=(P.na+371-P.sa)%7,xe==4||xe==3&&jt(P.ta)||(pe=1));else{pe=52;var xe=(P.na+7-P.sa-1)%7;(xe==4||xe==5&&jt(P.ta%400-1))&&pe++}return q(pe,2)},"%w":P=>P.na,"%W":P=>q(Math.floor((P.sa+7-(P.na+6)%7)/7),2),"%y":P=>(P.ta+1900).toString().substring(2),"%Y":P=>P.ta+1900,"%z":P=>{P=P.za;var pe=0<=P;return P=Math.abs(P)/60,(pe?"+":"-")+("0000"+(P/60*100+P%60)).slice(-4)},"%Z":P=>P.Ca,"%%":()=>"%"},O=O.replace(/%%/g,"\0\0");for(Ve in ze)O.includes(Ve)&&(O=O.replace(new RegExp(Ve,"g"),ze[Ve](D)));return O=O.replace(/\0\0/g,"%"),Ve=he(O),Ve.length>x?0:(j.set(Ve,m>>>0),Ve.length-1)}var Yr={a:function(m,x,O){m>>>=0;var D=new wt(m);throw Te[D.wa+16>>>2>>>0]=0,Te[D.wa+4>>>2>>>0]=x>>>0,Te[D.wa+8>>>2>>>0]=O>>>0,tt=m,tr++,tt},e:function(){return 0},H:function(){},x:function(){},z:function(){},J:function(){return 0},F:function(){},A:function(){},E:function(){},g:function(){},y:function(){},v:function(){},G:function(){},w:function(){},k:()=>1,I:function(m,x,O){return x>>>=0,ie.copyWithin(m>>>0>>>0,x>>>0,x+(O>>>0)>>>0)},n:function(m,x,O){m=x+2097152>>>0<4194305-!!m?(m>>>0)+4294967296*x:NaN,O>>>=0,m=new Date(1e3*m),G[O>>>2>>>0]=m.getUTCSeconds(),G[O+4>>>2>>>0]=m.getUTCMinutes(),G[O+8>>>2>>>0]=m.getUTCHours(),G[O+12>>>2>>>0]=m.getUTCDate(),G[O+16>>>2>>>0]=m.getUTCMonth(),G[O+20>>>2>>>0]=m.getUTCFullYear()-1900,G[O+24>>>2>>>0]=m.getUTCDay(),G[O+28>>>2>>>0]=(m.getTime()-Date.UTC(m.getUTCFullYear(),0,1,0,0,0,0))/864e5|0},o:function(m,x,O){m=x+2097152>>>0<4194305-!!m?(m>>>0)+4294967296*x:NaN,O>>>=0,m=new Date(1e3*m),G[O>>>2>>>0]=m.getSeconds(),G[O+4>>>2>>>0]=m.getMinutes(),G[O+8>>>2>>>0]=m.getHours(),G[O+12>>>2>>>0]=m.getDate(),G[O+16>>>2>>>0]=m.getMonth(),G[O+20>>>2>>>0]=m.getFullYear()-1900,G[O+24>>>2>>>0]=m.getDay(),G[O+28>>>2>>>0]=(jt(m.getFullYear())?qr:Tn)[m.getMonth()]+m.getDate()-1|0,G[O+36>>>2>>>0]=-(60*m.getTimezoneOffset()),x=new Date(m.getFullYear(),6,1).getTimezoneOffset();var D=new Date(m.getFullYear(),0,1).getTimezoneOffset();G[O+32>>>2>>>0]=(x!=D&&m.getTimezoneOffset()==Math.min(D,x))|0},p:function(m){m>>>=0;var x=new Date(G[m+20>>>2>>>0]+1900,G[m+16>>>2>>>0],G[m+12>>>2>>>0],G[m+8>>>2>>>0],G[m+4>>>2>>>0],G[m>>>2>>>0],0),O=G[m+32>>>2>>>0],D=x.getTimezoneOffset(),M=new Date(x.getFullYear(),6,1).getTimezoneOffset(),q=new Date(x.getFullYear(),0,1).getTimezoneOffset(),re=Math.min(q,M);return 0>O?G[m+32>>>2>>>0]=+(M!=q&&re==D):0<O!=(re==D)&&(M=Math.max(q,M),x.setTime(x.getTime()+6e4*((0<O?re:M)-D))),G[m+24>>>2>>>0]=x.getDay(),G[m+28>>>2>>>0]=(jt(x.getFullYear())?qr:Tn)[x.getMonth()]+x.getDate()-1|0,G[m>>>2>>>0]=x.getSeconds(),G[m+4>>>2>>>0]=x.getMinutes(),G[m+8>>>2>>>0]=x.getHours(),G[m+12>>>2>>>0]=x.getDate(),G[m+16>>>2>>>0]=x.getMonth(),G[m+20>>>2>>>0]=x.getYear(),m=x.getTime(),m=isNaN(m)?-1:m/1e3,Xr((xt=m,1<=+Math.abs(xt)?0<xt?+Math.floor(xt/4294967296)>>>0:~~+Math.ceil((xt-+(~~xt>>>0))/4294967296)>>>0:0)),m>>>0},l:function(){return-52},m:function(){},t:function(m,x,O,D){O>>>=0,D>>>=0;var M=new Date().getFullYear(),q=new Date(M,0,1),re=new Date(M,6,1);M=q.getTimezoneOffset();var Fe=re.getTimezoneOffset();Te[m>>>0>>>2>>>0]=60*Math.max(M,Fe),G[x>>>0>>>2>>>0]=+(M!=Fe),m=st=>st.toLocaleTimeString(void 0,{hour12:!1,timeZoneName:"short"}).split(" ")[1],q=m(q),re=m(re),Fe<M?(_t(q,ie,O,17),_t(re,ie,D,17)):(_t(q,ie,D,17),_t(re,ie,O,17))},d:()=>{qe("")},B:function(m,x,O){m>>>=0,x>>>=0,O>>>=0,Ct.length=0;for(var D;D=ie[x++>>>0];){var M=D!=105;M&=D!=112,O+=M&&O%8?4:0,Ct.push(D==112?Te[O>>>2>>>0]:D==105?G[O>>>2>>>0]:He[O>>>3>>>0]),O+=M?8:4}return Lt[m](...Ct)},h:()=>Date.now(),u:function(){return 4294901760},b:()=>performance.now(),s:function(m){m>>>=0;var x=ie.length;if(4294901760<m)return!1;for(var O=1;4>=O;O*=2){var D=x*(1+.2/O);D=Math.min(D,m+100663296);var M=Math;D=Math.max(m,D);e:{M=(M.min.call(M,4294901760,D+(65536-D%65536)%65536)-F.buffer.byteLength+65535)/65536;try{F.grow(M),Le();var q=1;break e}catch{}q=void 0}if(q)return!0}return!1},C:function(m,x){m>>>=0,x>>>=0;var O=0;return rr().forEach((D,M)=>{var q=x+O;for(M=Te[m+4*M>>>2>>>0]=q,q=0;q<D.length;++q)j[M++>>>0]=D.charCodeAt(q);j[M>>>0]=0,O+=D.length+1}),0},D:function(m,x){m>>>=0,x>>>=0;var O=rr();Te[m>>>2>>>0]=O.length;var D=0;return O.forEach(M=>D+=M.length+1),Te[x>>>2>>>0]=D,0},f:()=>52,j:function(){return 52},q:function(){return 70},i:function(m,x,O,D){x>>>=0,O>>>=0,D>>>=0;for(var M=0,q=0;q<O;q++){var re=Te[x>>>2>>>0],Fe=Te[x+4>>>2>>>0];x+=8;for(var st=0;st<Fe;st++){var ze=ie[re+st>>>0],Ve=xn[m];ze===0||ze===10?((m===1?A:C)(Be(Ve,0)),Ve.length=0):Ve.push(ze)}M+=Fe}return Te[D>>>2>>>0]=M,0},r:jr,c:function(m,x,O,D){return jr(m>>>0,x>>>0,O>>>0,D>>>0)}},te=function(){function m(O){return te=O.exports,te=_n(),F=te.K,Le(),Ne.unshift(te.L),yt--,yt==0&&(et!==null&&(clearInterval(et),et=null),ee&&(O=ee,ee=null,O())),te}var x={a:Yr};if(yt++,o.instantiateWasm)try{return o.instantiateWasm(x,m)}catch(O){C(`Module.instantiateWasm callback failed with error: ${O}`),r(O)}return qt(x,function(O){m(O.instance)}).catch(r),{}}();o._OrtInit=(m,x)=>(o._OrtInit=te.M)(m,x),o._OrtGetLastError=(m,x)=>(o._OrtGetLastError=te.N)(m,x),o._OrtCreateSessionOptions=(m,x,O,D,M,q,re,Fe,st,ze)=>(o._OrtCreateSessionOptions=te.O)(m,x,O,D,M,q,re,Fe,st,ze),o._OrtAppendExecutionProvider=(m,x)=>(o._OrtAppendExecutionProvider=te.P)(m,x),o._OrtAddFreeDimensionOverride=(m,x,O)=>(o._OrtAddFreeDimensionOverride=te.Q)(m,x,O),o._OrtAddSessionConfigEntry=(m,x,O)=>(o._OrtAddSessionConfigEntry=te.R)(m,x,O),o._OrtReleaseSessionOptions=m=>(o._OrtReleaseSessionOptions=te.S)(m),o._OrtCreateSession=(m,x,O)=>(o._OrtCreateSession=te.T)(m,x,O),o._OrtReleaseSession=m=>(o._OrtReleaseSession=te.U)(m),o._OrtGetInputOutputCount=(m,x,O)=>(o._OrtGetInputOutputCount=te.V)(m,x,O),o._OrtGetInputName=(m,x)=>(o._OrtGetInputName=te.W)(m,x),o._OrtGetOutputName=(m,x)=>(o._OrtGetOutputName=te.X)(m,x),o._OrtFree=m=>(o._OrtFree=te.Y)(m),o._OrtCreateTensor=(m,x,O,D,M,q)=>(o._OrtCreateTensor=te.Z)(m,x,O,D,M,q),o._OrtGetTensorData=(m,x,O,D,M)=>(o._OrtGetTensorData=te._)(m,x,O,D,M),o._OrtReleaseTensor=m=>(o._OrtReleaseTensor=te.$)(m),o._OrtCreateRunOptions=(m,x,O,D)=>(o._OrtCreateRunOptions=te.aa)(m,x,O,D),o._OrtAddRunConfigEntry=(m,x,O)=>(o._OrtAddRunConfigEntry=te.ba)(m,x,O),o._OrtReleaseRunOptions=m=>(o._OrtReleaseRunOptions=te.ca)(m),o._OrtCreateBinding=m=>(o._OrtCreateBinding=te.da)(m),o._OrtBindInput=(m,x,O)=>(o._OrtBindInput=te.ea)(m,x,O),o._OrtBindOutput=(m,x,O,D)=>(o._OrtBindOutput=te.fa)(m,x,O,D),o._OrtClearBoundOutputs=m=>(o._OrtClearBoundOutputs=te.ga)(m),o._OrtReleaseBinding=m=>(o._OrtReleaseBinding=te.ha)(m),o._OrtRunWithBinding=(m,x,O,D,M)=>(o._OrtRunWithBinding=te.ia)(m,x,O,D,M),o._OrtRun=(m,x,O,D,M,q,re,Fe)=>(o._OrtRun=te.ja)(m,x,O,D,M,q,re,Fe),o._OrtEndProfiling=m=>(o._OrtEndProfiling=te.ka)(m),o._malloc=m=>(o._malloc=te.la)(m),o._free=m=>(o._free=te.ma)(m);var Xr=m=>(Xr=te.oa)(m),vn=m=>(vn=te.pa)(m),X=m=>(X=te.qa)(m),or=()=>(or=te.ra)();function _n(){var m=te;m=Object.assign({},m);var x=O=>D=>O(D)>>>0;return m.la=x(m.la),m.qa=x(m.qa),m.ra=(O=>()=>O()>>>0)(m.ra),m}o.stackSave=()=>or(),o.stackRestore=m=>vn(m),o.stackAlloc=m=>X(m),o.UTF8ToString=je,o.stringToUTF8=(m,x,O)=>_t(m,ie,x,O),o.lengthBytesUTF8=vt;var Ut;ee=function m(){Ut||Kr(),Ut||(ee=m)};function Kr(){if(!(0<yt)){if(o.preRun)for(typeof o.preRun=="function"&&(o.preRun=[o.preRun]);o.preRun.length;){var m=o.preRun.shift();Y.unshift(m)}for(;0<Y.length;)Y.shift()(o);if(!(0<yt||Ut||(Ut=!0,o.calledRun=!0,J))){for(;0<Ne.length;)Ne.shift()(o);for(e(o);0<Se.length;)Se.shift()(o)}}}return Kr(),n}})();typeof Ap=="object"&&typeof ra=="object"?ra.exports=Sp:typeof define=="function"&&define.amd&&define([],()=>Sp)});var Ep=me(()=>{});var Dp=me(()=>{});var Lp={};Sr(Lp,{cpus:()=>ig});var ig,Cp=L(()=>{ig=void 0});var kp=me(($p,na)=>{"use strict";var Fp=(()=>{var a=typeof document<"u"?document.currentScript?.src:void 0;return typeof __filename<"u"&&(a||=__filename),function(t={}){function o(){return Se.buffer!=qe.buffer&&Ce(),qe}function e(){return Se.buffer!=qe.buffer&&Ce(),Ht}function r(){return Se.buffer!=qe.buffer&&Ce(),Ke}function n(){return Se.buffer!=qe.buffer&&Ce(),at}function s(){return Se.buffer!=qe.buffer&&Ce(),Re}var i=t,u,l,c=new Promise((f,b)=>{u=f,l=b}),p=Object.assign({},i),d="./this.program",T=(f,b)=>{throw b},w=typeof window=="object",v=typeof importScripts=="function",S=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",A=i.ENVIRONMENT_IS_PTHREAD||!1,C="";function F(f){return i.locateFile?i.locateFile(f,C):C+f}var J,j,ie;if(S){var G=(Qi(),ar(Zi)),Te=(ta(),ar(ea));C=v?Te.dirname(C)+"/":__dirname+"/",J=(f,b)=>(f=je(f)?new URL(f):Te.normalize(f),G.readFileSync(f,b?void 0:"utf8")),ie=f=>(f=J(f,!0),f.buffer||(f=new Uint8Array(f)),f),j=(f,b,y,I=!0)=>{f=je(f)?new URL(f):Te.normalize(f),G.readFile(f,I?void 0:"utf8",(k,$)=>{k?y(k):b(I?$.buffer:$)})},!i.thisProgram&&1<process.argv.length&&(d=process.argv[1].replace(/\\/g,"/")),process.argv.slice(2),T=(f,b)=>{throw process.exitCode=f,b},global.Worker=Ep().Worker}else(w||v)&&(v?C=self.location.href:typeof document<"u"&&document.currentScript&&(C=document.currentScript.src),typeof a<"u"&&a&&(C=a),C.startsWith("blob:")?C="":C=C.substr(0,C.replace(/[?#].*/,"").lastIndexOf("/")+1),S||(J=f=>{var b=new XMLHttpRequest;return b.open("GET",f,!1),b.send(null),b.responseText},v&&(ie=f=>{var b=new XMLHttpRequest;return b.open("GET",f,!1),b.responseType="arraybuffer",b.send(null),new Uint8Array(b.response)}),j=(f,b,y)=>{var I=new XMLHttpRequest;I.open("GET",f,!0),I.responseType="arraybuffer",I.onload=()=>{I.status==200||I.status==0&&I.response?b(I.response):y()},I.onerror=y,I.send(null)}));S&&typeof performance>"u"&&(global.performance=Dp().performance);var He=console.log.bind(console),Le=console.error.bind(console);S&&(He=(...f)=>G.writeSync(1,f.join(" ")+`
`),Le=(...f)=>G.writeSync(2,f.join(" ")+`
`));var Y=He,Ne=Le;Object.assign(i,p),p=null;var Se,yt,et=!1,ee,qe,Ht,Ke,at,Re;function Ce(){var f=Se.buffer;i.HEAP8=qe=new Int8Array(f),i.HEAP16=new Int16Array(f),i.HEAPU8=Ht=new Uint8Array(f),i.HEAPU16=new Uint16Array(f),i.HEAP32=Ke=new Int32Array(f),i.HEAPU32=at=new Uint32Array(f),i.HEAPF32=new Float32Array(f),i.HEAPF64=Re=new Float64Array(f)}var Hr=16777216;if(A)Se=i.wasmMemory;else if(i.wasmMemory)Se=i.wasmMemory;else if(Se=new WebAssembly.Memory({initial:Hr/65536,maximum:65536,shared:!0}),!(Se.buffer instanceof SharedArrayBuffer))throw Ne("requested a shared WebAssembly.Memory but the returned buffer is not a SharedArrayBuffer, indicating that while the browser has SharedArrayBuffer it does not have WebAssembly threads support - you may need to set a flag"),S&&Ne("(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and/or recent version)"),Error("bad memory");Ce(),Hr=Se.buffer.byteLength;var Tt=[],qt=[],xt=[],Lt=0,wt=null,tt=null;function tr(){if(Lt--,Lt==0&&(wt!==null&&(clearInterval(wt),wt=null),tt)){var f=tt;tt=null,f()}}function ke(f){throw f="Aborted("+f+")",Ne(f),et=!0,ee=1,f=new WebAssembly.RuntimeError(f+". Build with -sASSERTIONS for more info."),l(f),f}var Be=f=>f.startsWith("data:application/octet-stream;base64,"),je=f=>f.startsWith("file://"),vt;vt="ort-wasm-threaded.wasm",Be(vt)||(vt=F(vt));function _t(f){if(ie)return ie(f);throw"both async and sync fetching of the wasm failed"}function jt(f){if(w||v){if(typeof fetch=="function"&&!je(f))return fetch(f,{credentials:"same-origin"}).then(b=>{if(!b.ok)throw`failed to load wasm binary file at '${f}'`;return b.arrayBuffer()}).catch(()=>_t(f));if(j)return new Promise((b,y)=>{j(f,I=>b(new Uint8Array(I)),y)})}return Promise.resolve().then(()=>_t(f))}function qr(f,b,y){return jt(f).then(I=>WebAssembly.instantiate(I,b)).then(y,I=>{Ne(`failed to asynchronously prepare wasm: ${I}`),ke(I)})}function Tn(f,b){var y=vt;return typeof WebAssembly.instantiateStreaming!="function"||Be(y)||je(y)||S||typeof fetch!="function"?qr(y,f,b):fetch(y,{credentials:"same-origin"}).then(I=>WebAssembly.instantiateStreaming(I,f).then(b,function(k){return Ne(`wasm streaming compile failed: ${k}`),Ne("falling back to ArrayBuffer instantiation"),qr(y,f,b)}))}var Ct,Or={799444:(f,b,y,I)=>{if(typeof i>"u"||!i.bb)return 1;if(f=Fe(f>>>0),f.startsWith("./")&&(f=f.substring(2)),f=i.bb.get(f),!f)return 2;if(b>>>=0,y>>>=0,I>>>=0,b+y>f.byteLength)return 3;try{return e().set(f.subarray(b,b+y),I>>>0),0}catch{return 4}}};function rr(f){this.name="ExitStatus",this.message=`Program terminated with exit(${f})`,this.status=f}var nr=f=>{f.terminate(),f.onmessage=()=>{}},xn=f=>{X.Oa.length==0&&(Xr(),X.Xa(X.Oa[0]));var b=X.Oa.pop();if(!b)return 6;X.Pa.push(b),X.La[f.Na]=b,b.Na=f.Na;var y={cmd:"run",start_routine:f.gb,arg:f.cb,pthread_ptr:f.Na};return S&&b.unref(),b.postMessage(y,f.mb),0},Gt=0,wn=f=>{var b=zo();return f=f(),Sn(b),f},he=(f,b,...y)=>wn(()=>{for(var I=y.length,k=Uo(8*I),$=k>>>3,z=0;z<y.length;z++){var Oe=y[z];s()[$+z>>>0]=Oe}return ka(f,0,I,k,b)});function jr(f){if(A)return he(0,1,f);ee=f,0<Gt||(X.hb(),i.onExit?.(f),et=!0),T(f,new rr(f))}var Yr=f=>{if(ee=f,A)throw _n(f),"unwind";jr(f)};function te(){for(var f=i.numThreads;f--;)Xr();Tt.unshift(()=>{Lt++,vn(()=>tr())})}function Xr(){var f=F("ort-wasm-threaded.worker.js");f=new Worker(f),X.Oa.push(f)}function vn(f){A?f():Promise.all(X.Oa.map(X.Xa)).then(f)}var X={Oa:[],Pa:[],ab:[],La:{},Va(){A?(X.receiveObjectTransfer=X.fb,X.threadInitTLS=X.$a,X.setExitStatus=X.Za):te()},Za:f=>ee=f,pb:["$terminateWorker"],hb:()=>{for(var f of X.Pa)nr(f);for(f of X.Oa)nr(f);X.Oa=[],X.Pa=[],X.La=[]},Ya:f=>{var b=f.Na;delete X.La[b],X.Oa.push(f),X.Pa.splice(X.Pa.indexOf(f),1),f.Na=0,Mo(b)},fb(){},$a(){X.ab.forEach(f=>f())},Xa:f=>new Promise(b=>{f.onmessage=$=>{$=$.data;var z=$.cmd;if($.targetThread&&$.targetThread!=In()){var Oe=X.La[$.targetThread];Oe?Oe.postMessage($,$.transferList):Ne(`Internal error! Worker sent a message "${z}" to target pthread ${$.targetThread}, but that thread no longer exists!`)}else z==="checkMailbox"?On():z==="spawnThread"?xn($):z==="cleanupThread"?X.Ya(X.La[$.thread]):z==="killThread"?($=$.thread,z=X.La[$],delete X.La[$],nr(z),Mo($),X.Pa.splice(X.Pa.indexOf(z),1),z.Na=0):z==="cancelThread"?X.La[$.thread].postMessage({cmd:"cancel"}):z==="loaded"?(f.loaded=!0,S&&!f.Na&&f.unref(),b(f)):z==="alert"?alert(`Thread ${$.threadId}: ${$.text}`):$.target==="setimmediate"?f.postMessage($):z==="callHandler"?i[$.handler](...$.args):z&&Ne(`worker sent an unknown command ${z}`)},f.onerror=$=>{throw Ne(`worker sent an error! ${$.filename}:${$.lineno}: ${$.message}`),$},S&&(f.on("message",$=>f.onmessage({data:$})),f.on("error",$=>f.onerror($)));var y=[],I=["onExit"],k;for(k of I)i.hasOwnProperty(k)&&y.push(k);f.postMessage({cmd:"load",handlers:y,urlOrBlob:i.mainScriptUrlOrBlob||a,wasmMemory:Se,wasmModule:yt})})};i.PThread=X;var or=f=>{for(;0<f.length;)f.shift()(i)};i.establishStackSpace=()=>{var f=In(),b=n()[f+52>>>2>>>0];f=n()[f+56>>>2>>>0],Ra(b,b-f),Sn(b)};function _n(f){if(A)return he(1,0,f);Yr(f)}var Ut=[],Kr;i.invokeEntryPoint=(f,b)=>{Gt=0;var y=Ut[f];y||(f>=Ut.length&&(Ut.length=f+1),Ut[f]=y=Kr.get(f)),f=y(b),0<Gt?X.Za(f):Go(f)};class m{constructor(b){this.Ua=b-24}Va(b,y){n()[this.Ua+16>>>2>>>0]=0,n()[this.Ua+4>>>2>>>0]=b,n()[this.Ua+8>>>2>>>0]=y}}var x=0,O=0;function D(f,b,y,I){return A?he(2,1,f,b,y,I):M(f,b,y,I)}function M(f,b,y,I){if(f>>>=0,b>>>=0,y>>>=0,I>>>=0,typeof SharedArrayBuffer>"u")return Ne("Current environment does not support SharedArrayBuffer, pthreads are not available!"),6;var k=[];return A&&k.length===0?D(f,b,y,I):(f={gb:y,Na:f,cb:I,mb:k},A?(f.ob="spawnThread",postMessage(f,k),0):xn(f))}var q=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,re=(f,b,y)=>{b>>>=0;var I=b+y;for(y=b;f[y]&&!(y>=I);)++y;if(16<y-b&&f.buffer&&q)return q.decode(f.buffer instanceof SharedArrayBuffer?f.slice(b,y):f.subarray(b,y));for(I="";b<y;){var k=f[b++];if(k&128){var $=f[b++]&63;if((k&224)==192)I+=String.fromCharCode((k&31)<<6|$);else{var z=f[b++]&63;k=(k&240)==224?(k&15)<<12|$<<6|z:(k&7)<<18|$<<12|z<<6|f[b++]&63,65536>k?I+=String.fromCharCode(k):(k-=65536,I+=String.fromCharCode(55296|k>>10,56320|k&1023))}}else I+=String.fromCharCode(k)}return I},Fe=(f,b)=>(f>>>=0)?re(e(),f,b):"";function st(f,b,y){return A?he(3,1,f,b,y):0}function ze(f,b){if(A)return he(4,1,f,b)}var Ve=f=>{for(var b=0,y=0;y<f.length;++y){var I=f.charCodeAt(y);127>=I?b++:2047>=I?b+=2:55296<=I&&57343>=I?(b+=4,++y):b+=3}return b},Jr=(f,b,y,I)=>{if(y>>>=0,!(0<I))return 0;var k=y;I=y+I-1;for(var $=0;$<f.length;++$){var z=f.charCodeAt($);if(55296<=z&&57343>=z){var Oe=f.charCodeAt(++$);z=65536+((z&1023)<<10)|Oe&1023}if(127>=z){if(y>=I)break;b[y++>>>0]=z}else{if(2047>=z){if(y+1>=I)break;b[y++>>>0]=192|z>>6}else{if(65535>=z){if(y+2>=I)break;b[y++>>>0]=224|z>>12}else{if(y+3>=I)break;b[y++>>>0]=240|z>>18,b[y++>>>0]=128|z>>12&63}b[y++>>>0]=128|z>>6&63}b[y++>>>0]=128|z&63}}return b[y>>>0]=0,y-k},Yt=(f,b,y)=>Jr(f,e(),b,y);function P(f,b){if(A)return he(5,1,f,b)}function pe(f,b,y){if(A)return he(6,1,f,b,y)}function xe(f,b,y){return A?he(7,1,f,b,y):0}function Ft(f,b){if(A)return he(8,1,f,b)}function Zr(f,b,y){if(A)return he(9,1,f,b,y)}function ha(f,b,y,I){if(A)return he(10,1,f,b,y,I)}function ma(f,b,y,I){if(A)return he(11,1,f,b,y,I)}function ba(f,b,y,I){if(A)return he(12,1,f,b,y,I)}function ga(f){if(A)return he(13,1,f)}function ya(f,b){if(A)return he(14,1,f,b)}function Ta(f,b,y){if(A)return he(15,1,f,b,y)}function $o(f){f>>>=0,typeof Atomics.nb=="function"&&(Atomics.nb(r(),f>>>2,f).value.then(On),f+=128,Atomics.store(r(),f>>>2,1))}i.__emscripten_thread_mailbox_await=$o;var On=()=>{var f=In();if(f&&($o(f),f=Ba,!et))try{if(f(),!(0<Gt))try{A?Go(ee):Yr(ee)}catch(b){b instanceof rr||b=="unwind"||T(1,b)}}catch(b){b instanceof rr||b=="unwind"||T(1,b)}};i.checkMailbox=On;var ko=[],Ir=f=>f%4===0&&(f%100!==0||f%400===0),xa=[0,31,60,91,121,152,182,213,244,274,305,335],wa=[0,31,59,90,120,151,181,212,243,273,304,334];function va(f,b,y,I,k,$,z,Oe){return A?he(16,1,f,b,y,I,k,$,z,Oe):-52}function _a(f,b,y,I,k,$,z){if(A)return he(17,1,f,b,y,I,k,$,z)}var Bo=[],No={},Oa=()=>{if(!Ro){var f={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",_:d||"./this.program"},b;for(b in No)No[b]===void 0?delete f[b]:f[b]=No[b];var y=[];for(b in f)y.push(`${b}=${f[b]}`);Ro=y}return Ro},Ro;function Ia(f,b){if(A)return he(18,1,f,b);f>>>=0,b>>>=0;var y=0;return Oa().forEach((I,k)=>{var $=b+y;for(k=n()[f+4*k>>>2>>>0]=$,$=0;$<I.length;++$)o()[k++>>>0]=I.charCodeAt($);o()[k>>>0]=0,y+=I.length+1}),0}function Sa(f,b){if(A)return he(19,1,f,b);f>>>=0,b>>>=0;var y=Oa();n()[f>>>2>>>0]=y.length;var I=0;return y.forEach(k=>I+=k.length+1),n()[b>>>2>>>0]=I,0}function Aa(f){return A?he(20,1,f):52}function Pa(f,b,y,I){return A?he(21,1,f,b,y,I):52}function Ea(f,b,y,I,k){return A?he(22,1,f,b,y,I,k):70}var bd=[null,[],[]];function Da(f,b,y,I){if(A)return he(23,1,f,b,y,I);b>>>=0,y>>>=0,I>>>=0;for(var k=0,$=0;$<y;$++){var z=n()[b>>>2>>>0],Oe=n()[b+4>>>2>>>0];b+=8;for(var $t=0;$t<Oe;$t++){var Ye=e()[z+$t>>>0],rt=bd[f];Ye===0||Ye===10?((f===1?Y:Ne)(re(rt,0)),rt.length=0):rt.push(Ye)}k+=Oe}return n()[I>>>2>>>0]=k,0}var La=[31,29,31,30,31,30,31,31,30,31,30,31],Ca=[31,28,31,30,31,30,31,31,30,31,30,31];function gd(f){var b=Array(Ve(f)+1);return Jr(f,b,0,b.length),b}var yd=(f,b)=>{o().set(f,b>>>0)};function Fa(f,b,y,I){function k(E,de,Ie){for(E=typeof E=="number"?E.toString():E||"";E.length<de;)E=Ie[0]+E;return E}function $(E,de){return k(E,de,"0")}function z(E,de){function Ie(za){return 0>za?-1:0<za?1:0}var ir;return(ir=Ie(E.getFullYear()-de.getFullYear()))===0&&(ir=Ie(E.getMonth()-de.getMonth()))===0&&(ir=Ie(E.getDate()-de.getDate())),ir}function Oe(E){switch(E.getDay()){case 0:return new Date(E.getFullYear()-1,11,29);case 1:return E;case 2:return new Date(E.getFullYear(),0,3);case 3:return new Date(E.getFullYear(),0,2);case 4:return new Date(E.getFullYear(),0,1);case 5:return new Date(E.getFullYear()-1,11,31);case 6:return new Date(E.getFullYear()-1,11,30)}}function $t(E){var de=E.Qa;for(E=new Date(new Date(E.Ra+1900,0,1).getTime());0<de;){var Ie=E.getMonth(),ir=(Ir(E.getFullYear())?La:Ca)[Ie];if(de>ir-E.getDate())de-=ir-E.getDate()+1,E.setDate(1),11>Ie?E.setMonth(Ie+1):(E.setMonth(0),E.setFullYear(E.getFullYear()+1));else{E.setDate(E.getDate()+de);break}}return Ie=new Date(E.getFullYear()+1,0,4),de=Oe(new Date(E.getFullYear(),0,4)),Ie=Oe(Ie),0>=z(de,E)?0>=z(Ie,E)?E.getFullYear()+1:E.getFullYear():E.getFullYear()-1}f>>>=0,b>>>=0,y>>>=0,I>>>=0;var Ye=n()[I+40>>>2>>>0];I={kb:r()[I>>>2>>>0],jb:r()[I+4>>>2>>>0],Sa:r()[I+8>>>2>>>0],Wa:r()[I+12>>>2>>>0],Ta:r()[I+16>>>2>>>0],Ra:r()[I+20>>>2>>>0],Ma:r()[I+24>>>2>>>0],Qa:r()[I+28>>>2>>>0],qb:r()[I+32>>>2>>>0],ib:r()[I+36>>>2>>>0],lb:Ye?Fe(Ye):""},y=Fe(y),Ye={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var rt in Ye)y=y.replace(new RegExp(rt,"g"),Ye[rt]);var Ga="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),Ua="January February March April May June July August September October November December".split(" ");Ye={"%a":E=>Ga[E.Ma].substring(0,3),"%A":E=>Ga[E.Ma],"%b":E=>Ua[E.Ta].substring(0,3),"%B":E=>Ua[E.Ta],"%C":E=>$((E.Ra+1900)/100|0,2),"%d":E=>$(E.Wa,2),"%e":E=>k(E.Wa,2," "),"%g":E=>$t(E).toString().substring(2),"%G":$t,"%H":E=>$(E.Sa,2),"%I":E=>(E=E.Sa,E==0?E=12:12<E&&(E-=12),$(E,2)),"%j":E=>{for(var de=0,Ie=0;Ie<=E.Ta-1;de+=(Ir(E.Ra+1900)?La:Ca)[Ie++]);return $(E.Wa+de,3)},"%m":E=>$(E.Ta+1,2),"%M":E=>$(E.jb,2),"%n":()=>`
`,"%p":E=>0<=E.Sa&&12>E.Sa?"AM":"PM","%S":E=>$(E.kb,2),"%t":()=>"	","%u":E=>E.Ma||7,"%U":E=>$(Math.floor((E.Qa+7-E.Ma)/7),2),"%V":E=>{var de=Math.floor((E.Qa+7-(E.Ma+6)%7)/7);if(2>=(E.Ma+371-E.Qa-2)%7&&de++,de)de==53&&(Ie=(E.Ma+371-E.Qa)%7,Ie==4||Ie==3&&Ir(E.Ra)||(de=1));else{de=52;var Ie=(E.Ma+7-E.Qa-1)%7;(Ie==4||Ie==5&&Ir(E.Ra%400-1))&&de++}return $(de,2)},"%w":E=>E.Ma,"%W":E=>$(Math.floor((E.Qa+7-(E.Ma+6)%7)/7),2),"%y":E=>(E.Ra+1900).toString().substring(2),"%Y":E=>E.Ra+1900,"%z":E=>{E=E.ib;var de=0<=E;return E=Math.abs(E)/60,(de?"+":"-")+("0000"+(E/60*100+E%60)).slice(-4)},"%Z":E=>E.lb,"%%":()=>"%"},y=y.replace(/%%/g,"\0\0");for(rt in Ye)y.includes(rt)&&(y=y.replace(new RegExp(rt,"g"),Ye[rt](I)));return y=y.replace(/\0\0/g,"%"),rt=gd(y),rt.length>b?0:(yd(rt,f),rt.length-1)}X.Va();var Td=[jr,_n,D,st,ze,P,pe,xe,Ft,Zr,ha,ma,ba,ga,ya,Ta,va,_a,Ia,Sa,Aa,Pa,Ea,Da],xd={b:function(f,b,y){throw f>>>=0,new m(f).Va(b>>>0,y>>>0),x=f,O++,x},L:function(f){$a(f>>>0,!v,1,!w,131072,!1),X.$a()},j:function(f){f>>>=0,A?postMessage({cmd:"cleanupThread",thread:f}):X.Ya(X.La[f])},H:M,h:st,S:ze,D:P,F:pe,T:xe,Q:Ft,J:Zr,P:ha,n:ma,E:ba,B:ga,R:ya,C:Ta,p:()=>1,z:function(f,b){f>>>=0,f==b>>>0?setTimeout(On):A?postMessage({targetThread:f,cmd:"checkMailbox"}):(f=X.La[f])&&f.postMessage({cmd:"checkMailbox"})},I:function(f,b,y,I,k){b>>>=0,y>>>=0,ko.length=I,k=k>>>0>>>3;for(var $=0;$<I;$++)ko[$]=s()[k+$>>>0];return f=b?Or[b]:Td[f],X.eb=y,y=f(...ko),X.eb=0,y},K:$o,o:function(f){S&&X.La[f>>>0].ref()},s:function(f,b,y){f=b+2097152>>>0<4194305-!!f?(f>>>0)+4294967296*b:NaN,y>>>=0,f=new Date(1e3*f),r()[y>>>2>>>0]=f.getUTCSeconds(),r()[y+4>>>2>>>0]=f.getUTCMinutes(),r()[y+8>>>2>>>0]=f.getUTCHours(),r()[y+12>>>2>>>0]=f.getUTCDate(),r()[y+16>>>2>>>0]=f.getUTCMonth(),r()[y+20>>>2>>>0]=f.getUTCFullYear()-1900,r()[y+24>>>2>>>0]=f.getUTCDay(),f=(f.getTime()-Date.UTC(f.getUTCFullYear(),0,1,0,0,0,0))/864e5|0,r()[y+28>>>2>>>0]=f},t:function(f,b,y){f=b+2097152>>>0<4194305-!!f?(f>>>0)+4294967296*b:NaN,y>>>=0,f=new Date(1e3*f),r()[y>>>2>>>0]=f.getSeconds(),r()[y+4>>>2>>>0]=f.getMinutes(),r()[y+8>>>2>>>0]=f.getHours(),r()[y+12>>>2>>>0]=f.getDate(),r()[y+16>>>2>>>0]=f.getMonth(),r()[y+20>>>2>>>0]=f.getFullYear()-1900,r()[y+24>>>2>>>0]=f.getDay(),b=(Ir(f.getFullYear())?xa:wa)[f.getMonth()]+f.getDate()-1|0,r()[y+28>>>2>>>0]=b,r()[y+36>>>2>>>0]=-(60*f.getTimezoneOffset()),b=new Date(f.getFullYear(),6,1).getTimezoneOffset();var I=new Date(f.getFullYear(),0,1).getTimezoneOffset();f=(b!=I&&f.getTimezoneOffset()==Math.min(I,b))|0,r()[y+32>>>2>>>0]=f},u:function(f){f>>>=0;var b=new Date(r()[f+20>>>2>>>0]+1900,r()[f+16>>>2>>>0],r()[f+12>>>2>>>0],r()[f+8>>>2>>>0],r()[f+4>>>2>>>0],r()[f>>>2>>>0],0),y=r()[f+32>>>2>>>0],I=b.getTimezoneOffset(),k=new Date(b.getFullYear(),6,1).getTimezoneOffset(),$=new Date(b.getFullYear(),0,1).getTimezoneOffset(),z=Math.min($,k);return 0>y?r()[f+32>>>2>>>0]=+(k!=$&&z==I):0<y!=(z==I)&&(k=Math.max($,k),b.setTime(b.getTime()+6e4*((0<y?z:k)-I))),r()[f+24>>>2>>>0]=b.getDay(),y=(Ir(b.getFullYear())?xa:wa)[b.getMonth()]+b.getDate()-1|0,r()[f+28>>>2>>>0]=y,r()[f>>>2>>>0]=b.getSeconds(),r()[f+4>>>2>>>0]=b.getMinutes(),r()[f+8>>>2>>>0]=b.getHours(),r()[f+12>>>2>>>0]=b.getDate(),r()[f+16>>>2>>>0]=b.getMonth(),r()[f+20>>>2>>>0]=b.getYear(),f=b.getTime(),f=isNaN(f)?-1:f/1e3,Na((Ct=f,1<=+Math.abs(Ct)?0<Ct?+Math.floor(Ct/4294967296)>>>0:~~+Math.ceil((Ct-+(~~Ct>>>0))/4294967296)>>>0:0)),f>>>0},q:va,r:_a,y:function(f,b,y,I){f>>>=0,b>>>=0,y>>>=0,I>>>=0;var k=new Date().getFullYear(),$=new Date(k,0,1),z=new Date(k,6,1);k=$.getTimezoneOffset();var Oe=z.getTimezoneOffset(),$t=Math.max(k,Oe);n()[f>>>2>>>0]=60*$t,r()[b>>>2>>>0]=+(k!=Oe),f=Ye=>Ye.toLocaleTimeString(void 0,{hour12:!1,timeZoneName:"short"}).split(" ")[1],$=f($),z=f(z),Oe<k?(Yt($,y,17),Yt(z,I,17)):(Yt($,I,17),Yt(z,y,17))},c:()=>{ke("")},O:function(f,b,y){f>>>=0,b>>>=0,y>>>=0,Bo.length=0;for(var I;I=e()[b++>>>0];){var k=I!=105;k&=I!=112,y+=k&&y%8?4:0,Bo.push(I==112?n()[y>>>2>>>0]:I==105?r()[y>>>2>>>0]:s()[y>>>3>>>0]),y+=k?8:4}return Or[f](...Bo)},k:()=>{},i:()=>Date.now(),U:()=>{throw Gt+=1,"unwind"},A:function(){return 4294901760},e:()=>performance.timeOrigin+performance.now(),f:()=>S?(Cp(),ar(Lp)).cpus().length:navigator.hardwareConcurrency,x:function(f){f>>>=0;var b=e().length;if(f<=b||4294901760<f)return!1;for(var y=1;4>=y;y*=2){var I=b*(1+.2/y);I=Math.min(I,f+100663296);var k=Math;I=Math.max(f,I);e:{k=(k.min.call(k,4294901760,I+(65536-I%65536)%65536)-Se.buffer.byteLength+65535)/65536;try{Se.grow(k),Ce();var $=1;break e}catch{}$=void 0}if($)return!0}return!1},M:Ia,N:Sa,G:Yr,g:Aa,m:Pa,v:Ea,l:Da,a:Se||i.wasmMemory,w:Fa,d:function(f,b,y,I){return Fa(f>>>0,b>>>0,y>>>0,I>>>0)}},K=function(){function f(y,I){return K=y.exports,K=wd(),X.ab.push(K.ya),Kr=K.za,qt.unshift(K.V),yt=I,tr(),K}var b={a:xd};if(Lt++,i.instantiateWasm)try{return i.instantiateWasm(b,f)}catch(y){Ne(`Module.instantiateWasm callback failed with error: ${y}`),l(y)}return Tn(b,function(y){f(y.instance,y.module)}).catch(l),{}}();i._OrtInit=(f,b)=>(i._OrtInit=K.W)(f,b),i._OrtGetLastError=(f,b)=>(i._OrtGetLastError=K.X)(f,b),i._OrtCreateSessionOptions=(f,b,y,I,k,$,z,Oe,$t,Ye)=>(i._OrtCreateSessionOptions=K.Y)(f,b,y,I,k,$,z,Oe,$t,Ye),i._OrtAppendExecutionProvider=(f,b)=>(i._OrtAppendExecutionProvider=K.Z)(f,b),i._OrtAddFreeDimensionOverride=(f,b,y)=>(i._OrtAddFreeDimensionOverride=K._)(f,b,y),i._OrtAddSessionConfigEntry=(f,b,y)=>(i._OrtAddSessionConfigEntry=K.$)(f,b,y),i._OrtReleaseSessionOptions=f=>(i._OrtReleaseSessionOptions=K.aa)(f),i._OrtCreateSession=(f,b,y)=>(i._OrtCreateSession=K.ba)(f,b,y),i._OrtReleaseSession=f=>(i._OrtReleaseSession=K.ca)(f),i._OrtGetInputOutputCount=(f,b,y)=>(i._OrtGetInputOutputCount=K.da)(f,b,y),i._OrtGetInputName=(f,b)=>(i._OrtGetInputName=K.ea)(f,b),i._OrtGetOutputName=(f,b)=>(i._OrtGetOutputName=K.fa)(f,b),i._OrtFree=f=>(i._OrtFree=K.ga)(f),i._OrtCreateTensor=(f,b,y,I,k,$)=>(i._OrtCreateTensor=K.ha)(f,b,y,I,k,$),i._OrtGetTensorData=(f,b,y,I,k)=>(i._OrtGetTensorData=K.ia)(f,b,y,I,k),i._OrtReleaseTensor=f=>(i._OrtReleaseTensor=K.ja)(f),i._OrtCreateRunOptions=(f,b,y,I)=>(i._OrtCreateRunOptions=K.ka)(f,b,y,I),i._OrtAddRunConfigEntry=(f,b,y)=>(i._OrtAddRunConfigEntry=K.la)(f,b,y),i._OrtReleaseRunOptions=f=>(i._OrtReleaseRunOptions=K.ma)(f),i._OrtCreateBinding=f=>(i._OrtCreateBinding=K.na)(f),i._OrtBindInput=(f,b,y)=>(i._OrtBindInput=K.oa)(f,b,y),i._OrtBindOutput=(f,b,y,I)=>(i._OrtBindOutput=K.pa)(f,b,y,I),i._OrtClearBoundOutputs=f=>(i._OrtClearBoundOutputs=K.qa)(f),i._OrtReleaseBinding=f=>(i._OrtReleaseBinding=K.ra)(f),i._OrtRunWithBinding=(f,b,y,I,k)=>(i._OrtRunWithBinding=K.sa)(f,b,y,I,k),i._OrtRun=(f,b,y,I,k,$,z,Oe)=>(i._OrtRun=K.ta)(f,b,y,I,k,$,z,Oe),i._OrtEndProfiling=f=>(i._OrtEndProfiling=K.ua)(f);var In=i._pthread_self=()=>(In=i._pthread_self=K.va)();i._malloc=f=>(i._malloc=K.wa)(f),i._free=f=>(i._free=K.xa)(f),i.__emscripten_tls_init=()=>(i.__emscripten_tls_init=K.ya)();var $a=i.__emscripten_thread_init=(f,b,y,I,k,$)=>($a=i.__emscripten_thread_init=K.Aa)(f,b,y,I,k,$);i.__emscripten_thread_crashed=()=>(i.__emscripten_thread_crashed=K.Ba)();var ka=(f,b,y,I,k)=>(ka=K.Ca)(f,b,y,I,k),Mo=f=>(Mo=K.Da)(f),Go=i.__emscripten_thread_exit=f=>(Go=i.__emscripten_thread_exit=K.Ea)(f),Ba=()=>(Ba=K.Fa)(),Na=f=>(Na=K.Ga)(f),Ra=(f,b)=>(Ra=K.Ha)(f,b),Sn=f=>(Sn=K.Ia)(f),Uo=f=>(Uo=K.Ja)(f),zo=()=>(zo=K.Ka)();function wd(){var f=K;f=Object.assign({},f);var b=I=>()=>I()>>>0,y=I=>k=>I(k)>>>0;return f.va=b(f.va),f.wa=y(f.wa),f.emscripten_main_runtime_thread_id=b(f.emscripten_main_runtime_thread_id),f.Ja=y(f.Ja),f.Ka=b(f.Ka),f}i.wasmMemory=Se,i.stackSave=()=>zo(),i.stackRestore=f=>Sn(f),i.stackAlloc=f=>Uo(f),i.keepRuntimeAlive=()=>0<Gt,i.UTF8ToString=Fe,i.stringToUTF8=Yt,i.lengthBytesUTF8=Ve,i.ExitStatus=rr,i.PThread=X;var An;tt=function f(){An||Ma(),An||(tt=f)};function Ma(){if(!(0<Lt))if(A)u(i),A||or(qt),startWorker(i);else{if(i.preRun)for(typeof i.preRun=="function"&&(i.preRun=[i.preRun]);i.preRun.length;)Tt.unshift(i.preRun.shift());or(Tt),0<Lt||An||(An=!0,i.calledRun=!0,et||(A||or(qt),u(i),A||or(xt)))}}return Ma(),c}})();typeof $p=="object"&&typeof na=="object"?na.exports=Fp:typeof define=="function"&&define.amd&&define([],()=>Fp)});var Bp=me((aO,ag)=>{ag.exports='"use strict";var Module={},ENVIRONMENT_IS_NODE=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string";if(ENVIRONMENT_IS_NODE){var nodeWorkerThreads=require("worker_threads"),parentPort=nodeWorkerThreads.parentPort;parentPort.on("message",e=>onmessage({data:e}));var fs=require("fs"),vm=require("vm");Object.assign(global,{self:global,require,Module,location:{href:__filename},Worker:nodeWorkerThreads.Worker,importScripts:e=>vm.runInThisContext(fs.readFileSync(e,"utf8"),{filename:e}),postMessage:e=>parentPort.postMessage(e),performance:global.performance||{now:Date.now}})}var initializedJS=!1;function threadPrintErr(...e){var a=e.join(" ");if(ENVIRONMENT_IS_NODE){fs.writeSync(2,a+`\n`);return}console.error(a)}function threadAlert(...e){var a=e.join(" ");postMessage({cmd:"alert",text:a,threadId:Module._pthread_self()})}var err=threadPrintErr;self.alert=threadAlert,Module.instantiateWasm=(e,a)=>{var r=Module.wasmModule;Module.wasmModule=null;var t=new WebAssembly.Instance(r,e);return a(t)},self.onunhandledrejection=e=>{throw e.reason||e};function handleMessage(e){try{if(e.data.cmd==="load"){let r=[];self.onmessage=t=>r.push(t),self.startWorker=t=>{Module=t,postMessage({cmd:"loaded"});for(let s of r)handleMessage(s);self.onmessage=handleMessage},Module.wasmModule=e.data.wasmModule;for(const t of e.data.handlers)Module[t]=(...s)=>{postMessage({cmd:"callHandler",handler:t,args:s})};if(Module.wasmMemory=e.data.wasmMemory,Module.buffer=Module.wasmMemory.buffer,Module.ENVIRONMENT_IS_PTHREAD=!0,typeof e.data.urlOrBlob=="string")importScripts(e.data.urlOrBlob);else{var a=URL.createObjectURL(e.data.urlOrBlob);importScripts(a),URL.revokeObjectURL(a)}ortWasmThreaded(Module)}else if(e.data.cmd==="run"){Module.__emscripten_thread_init(e.data.pthread_ptr,0,0,1),Module.__emscripten_thread_mailbox_await(e.data.pthread_ptr),Module.establishStackSpace(),Module.PThread.receiveObjectTransfer(e.data),Module.PThread.threadInitTLS(),initializedJS||(initializedJS=!0);try{Module.invokeEntryPoint(e.data.start_routine,e.data.arg)}catch(r){if(r!="unwind")throw r}}else e.data.cmd==="cancel"?Module._pthread_self()&&Module.__emscripten_thread_exit(-1):e.data.target==="setimmediate"||(e.data.cmd==="checkMailbox"?initializedJS&&Module.checkMailbox():e.data.cmd&&(err(`worker.js received unknown command ${e.data.cmd}`),err(e.data)))}catch(r){throw Module.__emscripten_thread_crashed?.(),r}}self.onmessage=handleMessage;\n'});var Rp,sg,oa,ia,So,Np,ug,lg,fg,Mp,De,Ur=L(()=>{"use strict";Rp=Pp();sg=kp(),ia=!1,So=!1,Np=!1,ug=a=>{if(a===1)return!1;if(typeof SharedArrayBuffer>"u")return typeof self<"u"&&!self.crossOriginIsolated&&console.warn("env.wasm.numThreads is set to "+a+", but this will not work unless you enable crossOriginIsolated mode. See https://web.dev/cross-origin-isolation-guide/ for more info."),!1;typeof process<"u"&&process.versions&&process.versions.node&&console.warn("env.wasm.numThreads is set to "+a+", however, currently onnxruntime-web does not support multi-threads in Node.js. Please consider using onnxruntime-node for performance critical scenarios.");try{return typeof MessageChannel<"u"&&new MessageChannel().port1.postMessage(new SharedArrayBuffer(1)),WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,5,4,1,3,1,1,10,11,1,9,0,65,0,254,16,2,0,26,11]))}catch{return!1}},lg=()=>{try{return WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,10,30,1,28,0,65,0,253,15,253,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,253,186,1,26,11]))}catch{return!1}},fg=(a,t)=>a?t?"ort-wasm-simd-threaded.wasm":"ort-wasm-simd.wasm":t?"ort-wasm-threaded.wasm":"ort-wasm.wasm",Mp=async a=>{if(ia)return Promise.resolve();if(So)throw new Error("multiple calls to 'initializeWebAssembly()' detected.");if(Np)throw new Error("previous call to 'initializeWebAssembly()' failed.");So=!0;let t=a.initTimeout,o=a.numThreads,e=a.simd,r=ug(o),n=e&&lg(),s=a.wasmPaths,i=typeof s=="string"?s:void 0,u=fg(n,r),l=typeof s=="object"?s[u]:void 0,c=!1,p=[];if(t>0&&p.push(new Promise(d=>{setTimeout(()=>{c=!0,d()},t)})),p.push(new Promise((d,T)=>{let w=r?sg:Rp,v={locateFile:(S,A)=>r&&S.endsWith(".worker.js")&&typeof Blob<"u"?URL.createObjectURL(new Blob([Bp()],{type:"text/javascript"})):S.endsWith(".wasm")?l||(i??A)+u:A+S};if(r)if(v.numThreads=o,typeof Blob>"u")v.mainScriptUrlOrBlob=(void 0)(__dirname,"ort-wasm-threaded.js");else{let S=`var ortWasmThreaded=${w.toString()};`;v.mainScriptUrlOrBlob=new Blob([S],{type:"text/javascript"})}w(v).then(S=>{So=!1,ia=!0,oa=S,d()},S=>{So=!1,Np=!0,T(S)})})),await Promise.race(p),c)throw new Error(`WebAssembly backend initializing failed due to timeout: ${t}ms`)},De=()=>{if(ia&&oa)return oa;throw new Error("WebAssembly is not initialized yet.")}});var ve,bn,_e,Ao=L(()=>{"use strict";Ur();ve=(a,t)=>{let o=De(),e=o.lengthBytesUTF8(a)+1,r=o._malloc(e);return o.stringToUTF8(a,r,e),t.push(r),r},bn=(a,t,o,e)=>{if(typeof a=="object"&&a!==null){if(o.has(a))throw new Error("Circular reference in options");o.add(a)}Object.entries(a).forEach(([r,n])=>{let s=t?t+r:r;if(typeof n=="object")bn(n,s+".",o,e);else if(typeof n=="string"||typeof n=="number")e(s,n.toString());else if(typeof n=="boolean")e(s,n?"1":"0");else throw new Error(`Can't handle extra config type: ${typeof n}`)})},_e=a=>{let t=De(),o=t.stackSave();try{let e=t.stackAlloc(8);t._OrtGetLastError(e,e+4);let r=t.HEAP32[e/4],n=t.HEAPU32[e/4+1],s=n?t.UTF8ToString(n):"";throw new Error(`${a} ERROR_CODE: ${r}, ERROR_MESSAGE: ${s}`)}finally{t.stackRestore(o)}}});var Gp,Up=L(()=>{"use strict";Ur();Ao();Gp=a=>{let t=De(),o=0,e=[],r=a||{};try{if(a?.logSeverityLevel===void 0)r.logSeverityLevel=2;else if(typeof a.logSeverityLevel!="number"||!Number.isInteger(a.logSeverityLevel)||a.logSeverityLevel<0||a.logSeverityLevel>4)throw new Error(`log serverity level is not valid: ${a.logSeverityLevel}`);if(a?.logVerbosityLevel===void 0)r.logVerbosityLevel=0;else if(typeof a.logVerbosityLevel!="number"||!Number.isInteger(a.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${a.logVerbosityLevel}`);a?.terminate===void 0&&(r.terminate=!1);let n=0;return a?.tag!==void 0&&(n=ve(a.tag,e)),o=t._OrtCreateRunOptions(r.logSeverityLevel,r.logVerbosityLevel,!!r.terminate,n),o===0&&_e("Can't create run options."),a?.extra!==void 0&&bn(a.extra,"",new WeakSet,(s,i)=>{let u=ve(s,e),l=ve(i,e);t._OrtAddRunConfigEntry(o,u,l)!==0&&_e(`Can't set a run config entry: ${s} - ${i}.`)}),[o,e]}catch(n){throw o!==0&&t._OrtReleaseRunOptions(o),e.forEach(s=>t._free(s)),n}}});var cg,pg,dg,hg,zp,Vp=L(()=>{"use strict";Ur();Ao();cg=a=>{switch(a){case"disabled":return 0;case"basic":return 1;case"extended":return 2;case"all":return 99;default:throw new Error(`unsupported graph optimization level: ${a}`)}},pg=a=>{switch(a){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${a}`)}},dg=a=>{a.extra||(a.extra={}),a.extra.session||(a.extra.session={});let t=a.extra.session;t.use_ort_model_bytes_directly||(t.use_ort_model_bytes_directly="1"),a.executionProviders&&a.executionProviders.some(o=>(typeof o=="string"?o:o.name)==="webgpu")&&(a.enableMemPattern=!1)},hg=(a,t,o)=>{for(let e of t){let r=typeof e=="string"?e:e.name;switch(r){case"webnn":if(r="WEBNN",typeof e!="string"){let s=e;if(s?.deviceType){let i=ve("deviceType",o),u=ve(s.deviceType,o);De()._OrtAddSessionConfigEntry(a,i,u)!==0&&_e(`Can't set a session config entry: 'deviceType' - ${s.deviceType}.`)}if(s?.numThreads){let i=s.numThreads;(typeof i!="number"||!Number.isInteger(i)||i<0)&&(i=0);let u=ve("numThreads",o),l=ve(i.toString(),o);De()._OrtAddSessionConfigEntry(a,u,l)!==0&&_e(`Can't set a session config entry: 'numThreads' - ${s.numThreads}.`)}if(s?.powerPreference){let i=ve("powerPreference",o),u=ve(s.powerPreference,o);De()._OrtAddSessionConfigEntry(a,i,u)!==0&&_e(`Can't set a session config entry: 'powerPreference' - ${s.powerPreference}.`)}}break;case"webgpu":if(r="JS",typeof e!="string"){let s=e;if(s?.preferredLayout){if(s.preferredLayout!=="NCHW"&&s.preferredLayout!=="NHWC")throw new Error(`preferredLayout must be either 'NCHW' or 'NHWC': ${s.preferredLayout}`);let i=ve("preferredLayout",o),u=ve(s.preferredLayout,o);De()._OrtAddSessionConfigEntry(a,i,u)!==0&&_e(`Can't set a session config entry: 'preferredLayout' - ${s.preferredLayout}.`)}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${r}`)}let n=ve(r,o);De()._OrtAppendExecutionProvider(a,n)!==0&&_e(`Can't append execution provider: ${r}.`)}},zp=a=>{let t=De(),o=0,e=[],r=a||{};dg(r);try{let n=cg(r.graphOptimizationLevel??"all"),s=pg(r.executionMode??"sequential"),i=typeof r.logId=="string"?ve(r.logId,e):0,u=r.logSeverityLevel??2;if(!Number.isInteger(u)||u<0||u>4)throw new Error(`log serverity level is not valid: ${u}`);let l=r.logVerbosityLevel??0;if(!Number.isInteger(l)||l<0||l>4)throw new Error(`log verbosity level is not valid: ${l}`);let c=typeof r.optimizedModelFilePath=="string"?ve(r.optimizedModelFilePath,e):0;if(o=t._OrtCreateSessionOptions(n,!!r.enableCpuMemArena,!!r.enableMemPattern,s,!!r.enableProfiling,0,i,u,l,c),o===0&&_e("Can't create session options."),r.executionProviders&&hg(o,r.executionProviders,e),r.enableGraphCapture!==void 0){if(typeof r.enableGraphCapture!="boolean")throw new Error(`enableGraphCapture must be a boolean value: ${r.enableGraphCapture}`);let p=ve("enableGraphCapture",e),d=ve(r.enableGraphCapture.toString(),e);t._OrtAddSessionConfigEntry(o,p,d)!==0&&_e(`Can't set a session config entry: 'enableGraphCapture' - ${r.enableGraphCapture}.`)}if(r.freeDimensionOverrides)for(let[p,d]of Object.entries(r.freeDimensionOverrides)){if(typeof p!="string")throw new Error(`free dimension override name must be a string: ${p}`);if(typeof d!="number"||!Number.isInteger(d)||d<0)throw new Error(`free dimension override value must be a non-negative integer: ${d}`);let T=ve(p,e);t._OrtAddFreeDimensionOverride(o,T,d)!==0&&_e(`Can't set a free dimension override: ${p} - ${d}.`)}return r.extra!==void 0&&bn(r.extra,"",new WeakSet,(p,d)=>{let T=ve(p,e),w=ve(d,e);t._OrtAddSessionConfigEntry(o,T,w)!==0&&_e(`Can't set a session config entry: ${p} - ${d}.`)}),[o,e]}catch(n){throw o!==0&&t._OrtReleaseSessionOptions(o),e.forEach(s=>t._free(s)),n}}});var aa,Wp,sa,Hp,qp,Po,jp,ua=L(()=>{"use strict";aa=a=>{switch(a){case"int8":return 3;case"uint8":return 2;case"bool":return 9;case"int16":return 5;case"uint16":return 4;case"int32":return 6;case"uint32":return 12;case"float16":return 10;case"float32":return 1;case"float64":return 11;case"string":return 8;case"int64":return 7;case"uint64":return 13;default:throw new Error(`unsupported data type: ${a}`)}},Wp=a=>{switch(a){case 3:return"int8";case 2:return"uint8";case 9:return"bool";case 5:return"int16";case 4:return"uint16";case 6:return"int32";case 12:return"uint32";case 10:return"float16";case 1:return"float32";case 11:return"float64";case 8:return"string";case 7:return"int64";case 13:return"uint64";default:throw new Error(`unsupported data type: ${a}`)}},sa=a=>[void 0,4,1,1,2,2,4,8,void 0,1,2,8,4,8,void 0,void 0,void 0][a],Hp=a=>{switch(a){case"float16":return typeof Float16Array<"u"&&Float16Array.from?Float16Array:Uint16Array;case"float32":return Float32Array;case"uint8":return Uint8Array;case"int8":return Int8Array;case"uint16":return Uint16Array;case"int16":return Int16Array;case"int32":return Int32Array;case"bool":return Uint8Array;case"float64":return Float64Array;case"uint32":return Uint32Array;case"int64":return BigInt64Array;case"uint64":return BigUint64Array;default:throw new Error(`unsupported type: ${a}`)}},qp=a=>{switch(a){case"verbose":return 0;case"info":return 1;case"warning":return 2;case"error":return 3;case"fatal":return 4;default:throw new Error(`unsupported logging level: ${a}`)}},Po=a=>a==="float32"||a==="float16"||a==="int32"||a==="int64"||a==="uint32"||a==="uint8"||a==="bool",jp=a=>{switch(a){case"none":return 0;case"cpu":return 1;case"cpu-pinned":return 2;case"texture":return 3;case"gpu-buffer":return 4;default:throw new Error(`unsupported data location: ${a}`)}}});var gn,la=L(()=>{"use strict";gn=async a=>{if(typeof a=="string")if(typeof process<"u"&&process.versions&&process.versions.node)try{return new Uint8Array(await(void 0)(a))}catch(t){if(t.code==="ERR_FS_FILE_TOO_LARGE"){let o=(void 0)(a),e=[];for await(let r of o)e.push(r);return new Uint8Array(Buffer.concat(e))}throw t}else{let t=await fetch(a);if(!t.ok)throw new Error(`failed to load external data file: ${a}`);let o=t.headers.get("Content-Length"),e=o?parseInt(o,10):0;if(e<1073741824)return new Uint8Array(await t.arrayBuffer());{if(!t.body)throw new Error(`failed to load external data file: ${a}, no response body.`);let r=t.body.getReader(),n;try{n=new ArrayBuffer(e)}catch(i){if(i instanceof RangeError){let u=Math.ceil(e/65536);n=new WebAssembly.Memory({initial:u,maximum:u}).buffer}else throw i}let s=0;for(;;){let{done:i,value:u}=await r.read();if(i)break;let l=u.byteLength;new Uint8Array(n,s,l).set(u),s+=l}return new Uint8Array(n,0,e)}}else return a instanceof Blob?new Uint8Array(await a.arrayBuffer()):a instanceof Uint8Array?a:new Uint8Array(a)}});var mg,Xp,Kp,zr,bg,fa,Jp,Zp,Yp,Qp,ed,td,rd=L(()=>{"use strict";Up();Vp();ua();Ur();Ao();la();mg=(a,t)=>{De()._OrtInit(a,t)!==0&&_e("Can't initialize onnxruntime.")},Xp=async a=>{mg(a.wasm.numThreads,qp(a.logLevel))},Kp=async(a,t)=>{},zr=new Map,bg=a=>{let t=De(),o=t.stackSave();try{let e=t.stackAlloc(8);return t._OrtGetInputOutputCount(a,e,e+4)!==0&&_e("Can't get session input/output count."),[t.HEAP32[e/4],t.HEAP32[e/4+1]]}finally{t.stackRestore(o)}},fa=a=>{let t=De(),o=t._malloc(a.byteLength);if(o===0)throw new Error(`Can't create a session. failed to allocate a buffer of size ${a.byteLength}.`);return t.HEAPU8.set(a,o),[o,a.byteLength]},Jp=async(a,t)=>{let o,e,r=De();Array.isArray(a)?[o,e]=a:a.buffer===r.HEAPU8.buffer?[o,e]=[a.byteOffset,a.byteLength]:[o,e]=fa(a);let n=0,s=0,i=0,u=[],l=[],c=[];try{if([s,u]=zp(t),t?.externalData&&r.mountExternalData){let C=[];for(let F of t.externalData){let J=typeof F=="string"?F:F.path;C.push(gn(typeof F=="string"?F:F.data).then(j=>{r.mountExternalData(J,j)}))}await Promise.all(C)}n=await r._OrtCreateSession(o,e,s),n===0&&_e("Can't create a session.");let[p,d]=bg(n),T=!!t?.enableGraphCapture,w=[],v=[],S=[];for(let C=0;C<p;C++){let F=r._OrtGetInputName(n,C);F===0&&_e("Can't get an input name."),l.push(F),w.push(r.UTF8ToString(F))}for(let C=0;C<d;C++){let F=r._OrtGetOutputName(n,C);F===0&&_e("Can't get an output name."),c.push(F);let J=r.UTF8ToString(F);v.push(J)}let A=null;return zr.set(n,[n,l,c,A,T,!1]),[n,w,v]}catch(p){throw l.forEach(d=>r._OrtFree(d)),c.forEach(d=>r._OrtFree(d)),i!==0&&r._OrtReleaseBinding(i),n!==0&&r._OrtReleaseSession(n),p}finally{r._free(o),s!==0&&r._OrtReleaseSessionOptions(s),u.forEach(p=>r._free(p)),r.unmountExternalData?.()}},Zp=a=>{let t=De(),o=zr.get(a);if(!o)throw new Error(`cannot release session. invalid session id: ${a}`);let[e,r,n,s,i]=o;s&&(i&&t._OrtClearBoundOutputs(s.handle),t._OrtReleaseBinding(s.handle)),t.jsepOnReleaseSession?.(a),r.forEach(u=>t._OrtFree(u)),n.forEach(u=>t._OrtFree(u)),t._OrtReleaseSession(e),zr.delete(a)},Yp=(a,t,o,e,r,n=!1)=>{if(!a){t.push(0);return}let s=De(),i=a[0],u=a[1],l=a[3],c,p;if(i==="string"&&l==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");if(n&&l!=="gpu-buffer")throw new Error(`External buffer must be provided for input/output index ${r} when enableGraphCapture is true.`);if(l==="gpu-buffer"){let w=a[2].gpuBuffer,v=sa(aa(i));p=u.reduce((A,C)=>A*C,1)*v;let S=s.jsepRegisterBuffer;if(!S)throw new Error('Tensor location "gpu-buffer" is not supported without using WebGPU.');c=S(e,r,w,p)}else{let w=a[2];if(Array.isArray(w)){p=4*w.length,c=s._malloc(p),o.push(c);let v=c/4;for(let S=0;S<w.length;S++){if(typeof w[S]!="string")throw new TypeError(`tensor data at index ${S} is not a string`);s.HEAPU32[v++]=ve(w[S],o)}}else p=w.byteLength,c=s._malloc(p),o.push(c),s.HEAPU8.set(new Uint8Array(w.buffer,w.byteOffset,p),c)}let d=s.stackSave(),T=s.stackAlloc(4*u.length);try{let w=T/4;u.forEach(S=>s.HEAP32[w++]=S);let v=s._OrtCreateTensor(aa(i),c,p,T,u.length,jp(l));v===0&&_e(`Can't create tensor for input/output. session=${e}, index=${r}.`),t.push(v)}finally{s.stackRestore(d)}},Qp=async(a,t,o,e,r,n)=>{let s=De(),i=zr.get(a);if(!i)throw new Error(`cannot run inference. invalid session id: ${a}`);let u=i[0],l=i[1],c=i[2],p=i[3],d=i[4],T=i[5],w=t.length,v=e.length,S=0,A=[],C=[],F=[],J=[],j=s.stackSave(),ie=s.stackAlloc(w*4),G=s.stackAlloc(w*4),Te=s.stackAlloc(v*4),He=s.stackAlloc(v*4);try{[S,A]=Gp(n);for(let ee=0;ee<w;ee++)Yp(o[ee],C,J,a,t[ee],d);for(let ee=0;ee<v;ee++)Yp(r[ee],F,J,a,w+e[ee],d);let Le=ie/4,Y=G/4,Ne=Te/4,Se=He/4;for(let ee=0;ee<w;ee++)s.HEAPU32[Le++]=C[ee],s.HEAPU32[Y++]=l[t[ee]];for(let ee=0;ee<v;ee++)s.HEAPU32[Ne++]=F[ee],s.HEAPU32[Se++]=c[e[ee]];s.jsepOnRunStart?.(u);let yt;yt=await s._OrtRun(u,G,ie,w,He,v,Te,S),yt!==0&&_e("failed to call OrtRun().");let et=[];for(let ee=0;ee<v;ee++){let qe=s.HEAPU32[Te/4+ee];if(qe===F[ee]){et.push(r[ee]);continue}let Ht=s.stackSave(),Ke=s.stackAlloc(4*4),at=!1,Re,Ce=0;try{s._OrtGetTensorData(qe,Ke,Ke+4,Ke+8,Ke+12)!==0&&_e(`Can't access output tensor data on index ${ee}.`);let Tt=Ke/4,qt=s.HEAPU32[Tt++];Ce=s.HEAPU32[Tt++];let xt=s.HEAPU32[Tt++],Lt=s.HEAPU32[Tt++],wt=[];for(let ke=0;ke<Lt;ke++)wt.push(s.HEAPU32[xt/4+ke]);s._OrtFree(xt);let tt=wt.reduce((ke,Be)=>ke*Be,1);Re=Wp(qt);let tr=p?.outputPreferredLocations[e[ee]];if(Re==="string"){if(tr==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");let ke=[],Be=Ce/4;for(let je=0;je<tt;je++){let vt=s.HEAPU32[Be++],_t=je===tt-1?void 0:s.HEAPU32[Be]-vt;ke.push(s.UTF8ToString(vt,_t))}et.push([Re,wt,ke,"cpu"])}else if(tr==="gpu-buffer"&&tt>0){let ke=s.jsepGetBuffer;if(!ke)throw new Error('preferredLocation "gpu-buffer" is not supported without using WebGPU.');let Be=ke(Ce),je=sa(qt);if(je===void 0||!Po(Re))throw new Error(`Unsupported data type: ${Re}`);at=!0,et.push([Re,wt,{gpuBuffer:Be,download:s.jsepCreateDownloader(Be,tt*je,Re),dispose:()=>{s._OrtReleaseTensor(qe)}},"gpu-buffer"])}else{let ke=Hp(Re),Be=new ke(tt);new Uint8Array(Be.buffer,Be.byteOffset,Be.byteLength).set(s.HEAPU8.subarray(Ce,Ce+Be.byteLength)),et.push([Re,wt,Be,"cpu"])}}finally{s.stackRestore(Ht),Re==="string"&&Ce&&s._free(Ce),at||s._OrtReleaseTensor(qe)}}return p&&!d&&(s._OrtClearBoundOutputs(p.handle),zr.set(a,[u,l,c,p,d,!1])),et}finally{s.stackRestore(j),C.forEach(Le=>s._OrtReleaseTensor(Le)),F.forEach(Le=>s._OrtReleaseTensor(Le)),J.forEach(Le=>s._free(Le)),S!==0&&s._OrtReleaseRunOptions(S),A.forEach(Le=>s._free(Le))}},ed=a=>{let t=De(),o=zr.get(a);if(!o)throw new Error("invalid session id");let e=o[0],r=t._OrtEndProfiling(e);r===0&&_e("Can't get an profile file name."),t._OrtFree(r)},td=a=>{let t=[];for(let o of a){let e=o[2];!Array.isArray(e)&&"buffer"in e&&t.push(e.buffer)}return t}});var nd=me((IO,yg)=>{yg.exports='/*!\n * ONNX Runtime Web v1.18.0\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n"use strict";(()=>{var vt=Object.defineProperty;var qr=Object.getOwnPropertyDescriptor;var Vr=Object.getOwnPropertyNames;var Jr=Object.prototype.hasOwnProperty;var _t=(i,c)=>()=>(i&&(c=i(i=0)),c);var Ke=(i,c)=>()=>(c||i((c={exports:{}}).exports,c),c.exports),Et=(i,c)=>{for(var a in c)vt(i,a,{get:c[a],enumerable:!0})},Xr=(i,c,a,h)=>{if(c&&typeof c=="object"||typeof c=="function")for(let f of Vr(c))!Jr.call(i,f)&&f!==a&&vt(i,f,{get:()=>c[f],enumerable:!(h=qr(c,f))||h.enumerable});return i};var et=i=>Xr(vt({},"__esModule",{value:!0}),i);var St={};Et(St,{createReadStream:()=>lr,readFile:()=>Qr,readFileSync:()=>Zr});var Qr,Zr,lr,At=_t(()=>{Qr=void 0,Zr=void 0,lr=void 0});var Tt={};Et(Tt,{join:()=>Kr});var Kr,Mt=_t(()=>{Kr=void 0});var pr=Ke((dr,Ct)=>{"use strict";var cr=(()=>{var i=typeof document<"u"?document.currentScript?.src:void 0;return typeof __filename<"u"&&(i||=__filename),function(c={}){var a=c,h,f,w=new Promise((t,o)=>{h=t,f=o}),g=Object.assign({},a),s="./this.program",S=typeof window=="object",x=typeof importScripts=="function",H=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",A="",I,V,R;if(H){var B=(At(),et(St)),D=(Mt(),et(Tt));A=x?D.dirname(A)+"/":__dirname+"/",I=(t,o)=>(t=ce(t)?new URL(t):D.normalize(t),B.readFileSync(t,o?void 0:"utf8")),R=t=>(t=I(t,!0),t.buffer||(t=new Uint8Array(t)),t),V=(t,o,u,m=!0)=>{t=ce(t)?new URL(t):D.normalize(t),B.readFile(t,m?void 0:"utf8",(O,E)=>{O?u(O):o(m?E.buffer:E)})},!a.thisProgram&&1<process.argv.length&&(s=process.argv[1].replace(/\\\\/g,"/")),process.argv.slice(2)}else(S||x)&&(x?A=self.location.href:typeof document<"u"&&document.currentScript&&(A=document.currentScript.src),i&&(A=i),A.startsWith("blob:")?A="":A=A.substr(0,A.replace(/[?#].*/,"").lastIndexOf("/")+1),I=t=>{var o=new XMLHttpRequest;return o.open("GET",t,!1),o.send(null),o.responseText},x&&(R=t=>{var o=new XMLHttpRequest;return o.open("GET",t,!1),o.responseType="arraybuffer",o.send(null),new Uint8Array(o.response)}),V=(t,o,u)=>{var m=new XMLHttpRequest;m.open("GET",t,!0),m.responseType="arraybuffer",m.onload=()=>{m.status==200||m.status==0&&m.response?o(m.response):u()},m.onerror=u,m.send(null)});var T=console.log.bind(console),L=console.error.bind(console);Object.assign(a,g),g=null;var W,de=!1,pe,Z,_,J,Pe;function le(){var t=W.buffer;a.HEAP8=pe=new Int8Array(t),a.HEAP16=new Int16Array(t),a.HEAPU8=Z=new Uint8Array(t),a.HEAPU16=new Uint16Array(t),a.HEAP32=_=new Int32Array(t),a.HEAPU32=J=new Uint32Array(t),a.HEAPF32=new Float32Array(t),a.HEAPF64=Pe=new Float64Array(t)}var Ie=[],ne=[],X=[],we=0,me=null,F=null;function ie(t){throw t="Aborted("+t+")",L(t),de=!0,t=new WebAssembly.RuntimeError(t+". Build with -sASSERTIONS for more info."),f(t),t}var xe=t=>t.startsWith("data:application/octet-stream;base64,"),ce=t=>t.startsWith("file://"),be;if(be="ort-wasm.wasm",!xe(be)){var ae=be;be=a.locateFile?a.locateFile(ae,A):A+ae}function K(t){if(R)return R(t);throw"both async and sync fetching of the wasm failed"}function je(t){if(S||x){if(typeof fetch=="function"&&!ce(t))return fetch(t,{credentials:"same-origin"}).then(o=>{if(!o.ok)throw`failed to load wasm binary file at \'${t}\'`;return o.arrayBuffer()}).catch(()=>K(t));if(V)return new Promise((o,u)=>{V(t,m=>o(new Uint8Array(m)),u)})}return Promise.resolve().then(()=>K(t))}function Oe(t,o,u){return je(t).then(m=>WebAssembly.instantiate(m,o)).then(u,m=>{L(`failed to asynchronously prepare wasm: ${m}`),ie(m)})}function Ue(t,o){var u=be;return typeof WebAssembly.instantiateStreaming!="function"||xe(u)||ce(u)||H||typeof fetch!="function"?Oe(u,t,o):fetch(u,{credentials:"same-origin"}).then(m=>WebAssembly.instantiateStreaming(m,t).then(o,function(O){return L(`wasm streaming compile failed: ${O}`),L("falling back to ArrayBuffer instantiation"),Oe(u,t,o)}))}var ve,Ae={798088:(t,o,u,m)=>{if(typeof a>"u"||!a.ya)return 1;if(t=ue(t>>>0),t.startsWith("./")&&(t=t.substring(2)),t=a.ya.get(t),!t)return 2;if(o>>>=0,u>>>=0,o+u>t.byteLength)return 3;try{return Z.set(t.subarray(o,o+u),m>>>0>>>0),0}catch{return 4}}};class _e{constructor(o){this.wa=o-24}}var ge=0,Be=0,te=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,re=(t,o,u)=>{o>>>=0;var m=o+u;for(u=o;t[u]&&!(u>=m);)++u;if(16<u-o&&t.buffer&&te)return te.decode(t.subarray(o,u));for(m="";o<u;){var O=t[o++];if(O&128){var E=t[o++]&63;if((O&224)==192)m+=String.fromCharCode((O&31)<<6|E);else{var U=t[o++]&63;O=(O&240)==224?(O&15)<<12|E<<6|U:(O&7)<<18|E<<12|U<<6|t[o++]&63,65536>O?m+=String.fromCharCode(O):(O-=65536,m+=String.fromCharCode(55296|O>>10,56320|O&1023))}}else m+=String.fromCharCode(O)}return m},ue=(t,o)=>(t>>>=0)?re(Z,t,o):"",Ee=t=>{for(var o=0,u=0;u<t.length;++u){var m=t.charCodeAt(u);127>=m?o++:2047>=m?o+=2:55296<=m&&57343>=m?(o+=4,++u):o+=3}return o},Se=(t,o,u,m)=>{if(u>>>=0,!(0<m))return 0;var O=u;m=u+m-1;for(var E=0;E<t.length;++E){var U=t.charCodeAt(E);if(55296<=U&&57343>=U){var ee=t.charCodeAt(++E);U=65536+((U&1023)<<10)|ee&1023}if(127>=U){if(u>=m)break;o[u++>>>0]=U}else{if(2047>=U){if(u+1>=m)break;o[u++>>>0]=192|U>>6}else{if(65535>=U){if(u+2>=m)break;o[u++>>>0]=224|U>>12}else{if(u+3>=m)break;o[u++>>>0]=240|U>>18,o[u++>>>0]=128|U>>12&63}o[u++>>>0]=128|U>>6&63}o[u++>>>0]=128|U&63}}return o[u>>>0]=0,u-O},Le=t=>t%4===0&&(t%100!==0||t%400===0),ze=[0,31,60,91,121,152,182,213,244,274,305,335],rt=[0,31,59,90,120,151,181,212,243,273,304,334],Te=[],Ge={},ke=()=>{if(!We){var t={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",_:s||"./this.program"},o;for(o in Ge)Ge[o]===void 0?delete t[o]:t[o]=Ge[o];var u=[];for(o in t)u.push(`${o}=${t[o]}`);We=u}return We},We,nt=[null,[],[]],De=[31,29,31,30,31,30,31,31,30,31,30,31],at=[31,28,31,30,31,30,31,31,30,31,30,31];function G(t){var o=Array(Ee(t)+1);return Se(t,o,0,o.length),o}function qe(t,o,u,m){function O(d,k,$){for(d=typeof d=="number"?d.toString():d||"";d.length<k;)d=$[0]+d;return d}function E(d,k){return O(d,k,"0")}function U(d,k){function $(Ze){return 0>Ze?-1:0<Ze?1:0}var Me;return(Me=$(d.getFullYear()-k.getFullYear()))===0&&(Me=$(d.getMonth()-k.getMonth()))===0&&(Me=$(d.getDate()-k.getDate())),Me}function ee(d){switch(d.getDay()){case 0:return new Date(d.getFullYear()-1,11,29);case 1:return d;case 2:return new Date(d.getFullYear(),0,3);case 3:return new Date(d.getFullYear(),0,2);case 4:return new Date(d.getFullYear(),0,1);case 5:return new Date(d.getFullYear()-1,11,31);case 6:return new Date(d.getFullYear()-1,11,30)}}function ye(d){var k=d.sa;for(d=new Date(new Date(d.ta+1900,0,1).getTime());0<k;){var $=d.getMonth(),Me=(Le(d.getFullYear())?De:at)[$];if(k>Me-d.getDate())k-=Me-d.getDate()+1,d.setDate(1),11>$?d.setMonth($+1):(d.setMonth(0),d.setFullYear(d.getFullYear()+1));else{d.setDate(d.getDate()+k);break}}return $=new Date(d.getFullYear()+1,0,4),k=ee(new Date(d.getFullYear(),0,4)),$=ee($),0>=U(k,d)?0>=U($,d)?d.getFullYear()+1:d.getFullYear():d.getFullYear()-1}t>>>=0,o>>>=0,u>>>=0,m>>>=0;var oe=J[m+40>>>2>>>0];m={Ba:_[m>>>2>>>0],Aa:_[m+4>>>2>>>0],ua:_[m+8>>>2>>>0],xa:_[m+12>>>2>>>0],va:_[m+16>>>2>>>0],ta:_[m+20>>>2>>>0],na:_[m+24>>>2>>>0],sa:_[m+28>>>2>>>0],Da:_[m+32>>>2>>>0],za:_[m+36>>>2>>>0],Ca:oe?ue(oe):""},u=ue(u),oe={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var se in oe)u=u.replace(new RegExp(se,"g"),oe[se]);var Qe="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),Re="January February March April May June July August September October November December".split(" ");oe={"%a":d=>Qe[d.na].substring(0,3),"%A":d=>Qe[d.na],"%b":d=>Re[d.va].substring(0,3),"%B":d=>Re[d.va],"%C":d=>E((d.ta+1900)/100|0,2),"%d":d=>E(d.xa,2),"%e":d=>O(d.xa,2," "),"%g":d=>ye(d).toString().substring(2),"%G":ye,"%H":d=>E(d.ua,2),"%I":d=>(d=d.ua,d==0?d=12:12<d&&(d-=12),E(d,2)),"%j":d=>{for(var k=0,$=0;$<=d.va-1;k+=(Le(d.ta+1900)?De:at)[$++]);return E(d.xa+k,3)},"%m":d=>E(d.va+1,2),"%M":d=>E(d.Aa,2),"%n":()=>`\n`,"%p":d=>0<=d.ua&&12>d.ua?"AM":"PM","%S":d=>E(d.Ba,2),"%t":()=>"	","%u":d=>d.na||7,"%U":d=>E(Math.floor((d.sa+7-d.na)/7),2),"%V":d=>{var k=Math.floor((d.sa+7-(d.na+6)%7)/7);if(2>=(d.na+371-d.sa-2)%7&&k++,k)k==53&&($=(d.na+371-d.sa)%7,$==4||$==3&&Le(d.ta)||(k=1));else{k=52;var $=(d.na+7-d.sa-1)%7;($==4||$==5&&Le(d.ta%400-1))&&k++}return E(k,2)},"%w":d=>d.na,"%W":d=>E(Math.floor((d.sa+7-(d.na+6)%7)/7),2),"%y":d=>(d.ta+1900).toString().substring(2),"%Y":d=>d.ta+1900,"%z":d=>{d=d.za;var k=0<=d;return d=Math.abs(d)/60,(k?"+":"-")+("0000"+(d/60*100+d%60)).slice(-4)},"%Z":d=>d.Ca,"%%":()=>"%"},u=u.replace(/%%/g,"\\0\\0");for(se in oe)u.includes(se)&&(u=u.replace(new RegExp(se,"g"),oe[se](m)));return u=u.replace(/\\0\\0/g,"%"),se=G(u),se.length>o?0:(pe.set(se,t>>>0),se.length-1)}var Ve={a:function(t,o,u){t>>>=0;var m=new _e(t);throw J[m.wa+16>>>2>>>0]=0,J[m.wa+4>>>2>>>0]=o>>>0,J[m.wa+8>>>2>>>0]=u>>>0,ge=t,Be++,ge},e:function(){return 0},H:function(){},x:function(){},z:function(){},J:function(){return 0},F:function(){},A:function(){},E:function(){},g:function(){},y:function(){},v:function(){},G:function(){},w:function(){},k:()=>1,I:function(t,o,u){return o>>>=0,Z.copyWithin(t>>>0>>>0,o>>>0,o+(u>>>0)>>>0)},n:function(t,o,u){t=o+2097152>>>0<4194305-!!t?(t>>>0)+4294967296*o:NaN,u>>>=0,t=new Date(1e3*t),_[u>>>2>>>0]=t.getUTCSeconds(),_[u+4>>>2>>>0]=t.getUTCMinutes(),_[u+8>>>2>>>0]=t.getUTCHours(),_[u+12>>>2>>>0]=t.getUTCDate(),_[u+16>>>2>>>0]=t.getUTCMonth(),_[u+20>>>2>>>0]=t.getUTCFullYear()-1900,_[u+24>>>2>>>0]=t.getUTCDay(),_[u+28>>>2>>>0]=(t.getTime()-Date.UTC(t.getUTCFullYear(),0,1,0,0,0,0))/864e5|0},o:function(t,o,u){t=o+2097152>>>0<4194305-!!t?(t>>>0)+4294967296*o:NaN,u>>>=0,t=new Date(1e3*t),_[u>>>2>>>0]=t.getSeconds(),_[u+4>>>2>>>0]=t.getMinutes(),_[u+8>>>2>>>0]=t.getHours(),_[u+12>>>2>>>0]=t.getDate(),_[u+16>>>2>>>0]=t.getMonth(),_[u+20>>>2>>>0]=t.getFullYear()-1900,_[u+24>>>2>>>0]=t.getDay(),_[u+28>>>2>>>0]=(Le(t.getFullYear())?ze:rt)[t.getMonth()]+t.getDate()-1|0,_[u+36>>>2>>>0]=-(60*t.getTimezoneOffset()),o=new Date(t.getFullYear(),6,1).getTimezoneOffset();var m=new Date(t.getFullYear(),0,1).getTimezoneOffset();_[u+32>>>2>>>0]=(o!=m&&t.getTimezoneOffset()==Math.min(m,o))|0},p:function(t){t>>>=0;var o=new Date(_[t+20>>>2>>>0]+1900,_[t+16>>>2>>>0],_[t+12>>>2>>>0],_[t+8>>>2>>>0],_[t+4>>>2>>>0],_[t>>>2>>>0],0),u=_[t+32>>>2>>>0],m=o.getTimezoneOffset(),O=new Date(o.getFullYear(),6,1).getTimezoneOffset(),E=new Date(o.getFullYear(),0,1).getTimezoneOffset(),U=Math.min(E,O);return 0>u?_[t+32>>>2>>>0]=+(O!=E&&U==m):0<u!=(U==m)&&(O=Math.max(E,O),o.setTime(o.getTime()+6e4*((0<u?U:O)-m))),_[t+24>>>2>>>0]=o.getDay(),_[t+28>>>2>>>0]=(Le(o.getFullYear())?ze:rt)[o.getMonth()]+o.getDate()-1|0,_[t>>>2>>>0]=o.getSeconds(),_[t+4>>>2>>>0]=o.getMinutes(),_[t+8>>>2>>>0]=o.getHours(),_[t+12>>>2>>>0]=o.getDate(),_[t+16>>>2>>>0]=o.getMonth(),_[t+20>>>2>>>0]=o.getYear(),t=o.getTime(),t=isNaN(t)?-1:t/1e3,Je((ve=t,1<=+Math.abs(ve)?0<ve?+Math.floor(ve/4294967296)>>>0:~~+Math.ceil((ve-+(~~ve>>>0))/4294967296)>>>0:0)),t>>>0},l:function(){return-52},m:function(){},t:function(t,o,u,m){u>>>=0,m>>>=0;var O=new Date().getFullYear(),E=new Date(O,0,1),U=new Date(O,6,1);O=E.getTimezoneOffset();var ee=U.getTimezoneOffset();J[t>>>0>>>2>>>0]=60*Math.max(O,ee),_[o>>>0>>>2>>>0]=+(O!=ee),t=ye=>ye.toLocaleTimeString(void 0,{hour12:!1,timeZoneName:"short"}).split(" ")[1],E=t(E),U=t(U),ee<O?(Se(E,Z,u,17),Se(U,Z,m,17)):(Se(E,Z,m,17),Se(U,Z,u,17))},d:()=>{ie("")},B:function(t,o,u){t>>>=0,o>>>=0,u>>>=0,Te.length=0;for(var m;m=Z[o++>>>0];){var O=m!=105;O&=m!=112,u+=O&&u%8?4:0,Te.push(m==112?J[u>>>2>>>0]:m==105?_[u>>>2>>>0]:Pe[u>>>3>>>0]),u+=O?8:4}return Ae[t](...Te)},h:()=>Date.now(),u:function(){return 4294901760},b:()=>performance.now(),s:function(t){t>>>=0;var o=Z.length;if(4294901760<t)return!1;for(var u=1;4>=u;u*=2){var m=o*(1+.2/u);m=Math.min(m,t+100663296);var O=Math;m=Math.max(t,m);e:{O=(O.min.call(O,4294901760,m+(65536-m%65536)%65536)-W.buffer.byteLength+65535)/65536;try{W.grow(O),le();var E=1;break e}catch{}E=void 0}if(E)return!0}return!1},C:function(t,o){t>>>=0,o>>>=0;var u=0;return ke().forEach((m,O)=>{var E=o+u;for(O=J[t+4*O>>>2>>>0]=E,E=0;E<m.length;++E)pe[O++>>>0]=m.charCodeAt(E);pe[O>>>0]=0,u+=m.length+1}),0},D:function(t,o){t>>>=0,o>>>=0;var u=ke();J[t>>>2>>>0]=u.length;var m=0;return u.forEach(O=>m+=O.length+1),J[o>>>2>>>0]=m,0},f:()=>52,j:function(){return 52},q:function(){return 70},i:function(t,o,u,m){o>>>=0,u>>>=0,m>>>=0;for(var O=0,E=0;E<u;E++){var U=J[o>>>2>>>0],ee=J[o+4>>>2>>>0];o+=8;for(var ye=0;ye<ee;ye++){var oe=Z[U+ye>>>0],se=nt[t];oe===0||oe===10?((t===1?T:L)(re(se,0)),se.length=0):se.push(oe)}O+=ee}return J[m>>>2>>>0]=O,0},r:qe,c:function(t,o,u,m){return qe(t>>>0,o>>>0,u>>>0,m>>>0)}},P=function(){function t(u){return P=u.exports,P=st(),W=P.K,le(),ne.unshift(P.L),we--,we==0&&(me!==null&&(clearInterval(me),me=null),F&&(u=F,F=null,u())),P}var o={a:Ve};if(we++,a.instantiateWasm)try{return a.instantiateWasm(o,t)}catch(u){L(`Module.instantiateWasm callback failed with error: ${u}`),f(u)}return Ue(o,function(u){t(u.instance)}).catch(f),{}}();a._OrtInit=(t,o)=>(a._OrtInit=P.M)(t,o),a._OrtGetLastError=(t,o)=>(a._OrtGetLastError=P.N)(t,o),a._OrtCreateSessionOptions=(t,o,u,m,O,E,U,ee,ye,oe)=>(a._OrtCreateSessionOptions=P.O)(t,o,u,m,O,E,U,ee,ye,oe),a._OrtAppendExecutionProvider=(t,o)=>(a._OrtAppendExecutionProvider=P.P)(t,o),a._OrtAddFreeDimensionOverride=(t,o,u)=>(a._OrtAddFreeDimensionOverride=P.Q)(t,o,u),a._OrtAddSessionConfigEntry=(t,o,u)=>(a._OrtAddSessionConfigEntry=P.R)(t,o,u),a._OrtReleaseSessionOptions=t=>(a._OrtReleaseSessionOptions=P.S)(t),a._OrtCreateSession=(t,o,u)=>(a._OrtCreateSession=P.T)(t,o,u),a._OrtReleaseSession=t=>(a._OrtReleaseSession=P.U)(t),a._OrtGetInputOutputCount=(t,o,u)=>(a._OrtGetInputOutputCount=P.V)(t,o,u),a._OrtGetInputName=(t,o)=>(a._OrtGetInputName=P.W)(t,o),a._OrtGetOutputName=(t,o)=>(a._OrtGetOutputName=P.X)(t,o),a._OrtFree=t=>(a._OrtFree=P.Y)(t),a._OrtCreateTensor=(t,o,u,m,O,E)=>(a._OrtCreateTensor=P.Z)(t,o,u,m,O,E),a._OrtGetTensorData=(t,o,u,m,O)=>(a._OrtGetTensorData=P._)(t,o,u,m,O),a._OrtReleaseTensor=t=>(a._OrtReleaseTensor=P.$)(t),a._OrtCreateRunOptions=(t,o,u,m)=>(a._OrtCreateRunOptions=P.aa)(t,o,u,m),a._OrtAddRunConfigEntry=(t,o,u)=>(a._OrtAddRunConfigEntry=P.ba)(t,o,u),a._OrtReleaseRunOptions=t=>(a._OrtReleaseRunOptions=P.ca)(t),a._OrtCreateBinding=t=>(a._OrtCreateBinding=P.da)(t),a._OrtBindInput=(t,o,u)=>(a._OrtBindInput=P.ea)(t,o,u),a._OrtBindOutput=(t,o,u,m)=>(a._OrtBindOutput=P.fa)(t,o,u,m),a._OrtClearBoundOutputs=t=>(a._OrtClearBoundOutputs=P.ga)(t),a._OrtReleaseBinding=t=>(a._OrtReleaseBinding=P.ha)(t),a._OrtRunWithBinding=(t,o,u,m,O)=>(a._OrtRunWithBinding=P.ia)(t,o,u,m,O),a._OrtRun=(t,o,u,m,O,E,U,ee)=>(a._OrtRun=P.ja)(t,o,u,m,O,E,U,ee),a._OrtEndProfiling=t=>(a._OrtEndProfiling=P.ka)(t),a._malloc=t=>(a._malloc=P.la)(t),a._free=t=>(a._free=P.ma)(t);var Je=t=>(Je=P.oa)(t),ot=t=>(ot=P.pa)(t),M=t=>(M=P.qa)(t),Ne=()=>(Ne=P.ra)();function st(){var t=P;t=Object.assign({},t);var o=u=>m=>u(m)>>>0;return t.la=o(t.la),t.qa=o(t.qa),t.ra=(u=>()=>u()>>>0)(t.ra),t}a.stackSave=()=>Ne(),a.stackRestore=t=>ot(t),a.stackAlloc=t=>M(t),a.UTF8ToString=ue,a.stringToUTF8=(t,o,u)=>Se(t,Z,o,u),a.lengthBytesUTF8=Ee;var Fe;F=function t(){Fe||Xe(),Fe||(F=t)};function Xe(){if(!(0<we)){if(a.preRun)for(typeof a.preRun=="function"&&(a.preRun=[a.preRun]);a.preRun.length;){var t=a.preRun.shift();Ie.unshift(t)}for(;0<Ie.length;)Ie.shift()(a);if(!(0<we||Fe||(Fe=!0,a.calledRun=!0,de))){for(;0<ne.length;)ne.shift()(a);for(h(a);0<X.length;)X.shift()(a)}}}return Xe(),w}})();typeof dr=="object"&&typeof Ct=="object"?Ct.exports=cr:typeof define=="function"&&define.amd&&define([],()=>cr)});var mr=Ke(()=>{});var gr=Ke(()=>{});var hr={};Et(hr,{cpus:()=>en});var en,br=_t(()=>{en=void 0});var Or=Ke((wr,Dt)=>{"use strict";var yr=(()=>{var i=typeof document<"u"?document.currentScript?.src:void 0;return typeof __filename<"u"&&(i||=__filename),function(c={}){function a(){return X.buffer!=ie.buffer&&K(),ie}function h(){return X.buffer!=ie.buffer&&K(),xe}function f(){return X.buffer!=ie.buffer&&K(),ce}function w(){return X.buffer!=ie.buffer&&K(),be}function g(){return X.buffer!=ie.buffer&&K(),ae}var s=c,S,x,H=new Promise((e,r)=>{S=e,x=r}),A=Object.assign({},s),I="./this.program",V=(e,r)=>{throw r},R=typeof window=="object",B=typeof importScripts=="function",D=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",T=s.ENVIRONMENT_IS_PTHREAD||!1,L="";function W(e){return s.locateFile?s.locateFile(e,L):L+e}var de,pe,Z;if(D){var _=(At(),et(St)),J=(Mt(),et(Tt));L=B?J.dirname(L)+"/":__dirname+"/",de=(e,r)=>(e=ue(e)?new URL(e):J.normalize(e),_.readFileSync(e,r?void 0:"utf8")),Z=e=>(e=de(e,!0),e.buffer||(e=new Uint8Array(e)),e),pe=(e,r,n,l=!0)=>{e=ue(e)?new URL(e):J.normalize(e),_.readFile(e,l?void 0:"utf8",(y,b)=>{y?n(y):r(l?b.buffer:b)})},!s.thisProgram&&1<process.argv.length&&(I=process.argv[1].replace(/\\\\/g,"/")),process.argv.slice(2),V=(e,r)=>{throw process.exitCode=e,r},global.Worker=mr().Worker}else(R||B)&&(B?L=self.location.href:typeof document<"u"&&document.currentScript&&(L=document.currentScript.src),typeof i<"u"&&i&&(L=i),L.startsWith("blob:")?L="":L=L.substr(0,L.replace(/[?#].*/,"").lastIndexOf("/")+1),D||(de=e=>{var r=new XMLHttpRequest;return r.open("GET",e,!1),r.send(null),r.responseText},B&&(Z=e=>{var r=new XMLHttpRequest;return r.open("GET",e,!1),r.responseType="arraybuffer",r.send(null),new Uint8Array(r.response)}),pe=(e,r,n)=>{var l=new XMLHttpRequest;l.open("GET",e,!0),l.responseType="arraybuffer",l.onload=()=>{l.status==200||l.status==0&&l.response?r(l.response):n()},l.onerror=n,l.send(null)}));D&&typeof performance>"u"&&(global.performance=gr().performance);var Pe=console.log.bind(console),le=console.error.bind(console);D&&(Pe=(...e)=>_.writeSync(1,e.join(" ")+`\n`),le=(...e)=>_.writeSync(2,e.join(" ")+`\n`));var Ie=Pe,ne=le;Object.assign(s,A),A=null;var X,we,me=!1,F,ie,xe,ce,be,ae;function K(){var e=X.buffer;s.HEAP8=ie=new Int8Array(e),s.HEAP16=new Int16Array(e),s.HEAPU8=xe=new Uint8Array(e),s.HEAPU16=new Uint16Array(e),s.HEAP32=ce=new Int32Array(e),s.HEAPU32=be=new Uint32Array(e),s.HEAPF32=new Float32Array(e),s.HEAPF64=ae=new Float64Array(e)}var je=16777216;if(T)X=s.wasmMemory;else if(s.wasmMemory)X=s.wasmMemory;else if(X=new WebAssembly.Memory({initial:je/65536,maximum:65536,shared:!0}),!(X.buffer instanceof SharedArrayBuffer))throw ne("requested a shared WebAssembly.Memory but the returned buffer is not a SharedArrayBuffer, indicating that while the browser has SharedArrayBuffer it does not have WebAssembly threads support - you may need to set a flag"),D&&ne("(on node you may need: --experimental-wasm-threads --experimental-wasm-bulk-memory and/or recent version)"),Error("bad memory");K(),je=X.buffer.byteLength;var Oe=[],Ue=[],ve=[],Ae=0,_e=null,ge=null;function Be(){if(Ae--,Ae==0&&(_e!==null&&(clearInterval(_e),_e=null),ge)){var e=ge;ge=null,e()}}function te(e){throw e="Aborted("+e+")",ne(e),me=!0,F=1,e=new WebAssembly.RuntimeError(e+". Build with -sASSERTIONS for more info."),x(e),e}var re=e=>e.startsWith("data:application/octet-stream;base64,"),ue=e=>e.startsWith("file://"),Ee;Ee="ort-wasm-threaded.wasm",re(Ee)||(Ee=W(Ee));function Se(e){if(Z)return Z(e);throw"both async and sync fetching of the wasm failed"}function Le(e){if(R||B){if(typeof fetch=="function"&&!ue(e))return fetch(e,{credentials:"same-origin"}).then(r=>{if(!r.ok)throw`failed to load wasm binary file at \'${e}\'`;return r.arrayBuffer()}).catch(()=>Se(e));if(pe)return new Promise((r,n)=>{pe(e,l=>r(new Uint8Array(l)),n)})}return Promise.resolve().then(()=>Se(e))}function ze(e,r,n){return Le(e).then(l=>WebAssembly.instantiate(l,r)).then(n,l=>{ne(`failed to asynchronously prepare wasm: ${l}`),te(l)})}function rt(e,r){var n=Ee;return typeof WebAssembly.instantiateStreaming!="function"||re(n)||ue(n)||D||typeof fetch!="function"?ze(n,e,r):fetch(n,{credentials:"same-origin"}).then(l=>WebAssembly.instantiateStreaming(l,e).then(r,function(y){return ne(`wasm streaming compile failed: ${y}`),ne("falling back to ArrayBuffer instantiation"),ze(n,e,r)}))}var Te,Ge={799444:(e,r,n,l)=>{if(typeof s>"u"||!s.bb)return 1;if(e=ee(e>>>0),e.startsWith("./")&&(e=e.substring(2)),e=s.bb.get(e),!e)return 2;if(r>>>=0,n>>>=0,l>>>=0,r+n>e.byteLength)return 3;try{return h().set(e.subarray(r,r+n),l>>>0),0}catch{return 4}}};function ke(e){this.name="ExitStatus",this.message=`Program terminated with exit(${e})`,this.status=e}var We=e=>{e.terminate(),e.onmessage=()=>{}},nt=e=>{M.Oa.length==0&&(Je(),M.Xa(M.Oa[0]));var r=M.Oa.pop();if(!r)return 6;M.Pa.push(r),M.La[e.Na]=r,r.Na=e.Na;var n={cmd:"run",start_routine:e.gb,arg:e.cb,pthread_ptr:e.Na};return D&&r.unref(),r.postMessage(n,e.mb),0},De=0,at=e=>{var r=Ot();return e=e(),ft(r),e},G=(e,r,...n)=>at(()=>{for(var l=n.length,y=wt(8*l),b=y>>>3,v=0;v<n.length;v++){var z=n[v];g()[b+v>>>0]=z}return rr(e,0,l,y,r)});function qe(e){if(T)return G(0,1,e);F=e,0<De||(M.hb(),s.onExit?.(e),me=!0),V(e,new ke(e))}var Ve=e=>{if(F=e,T)throw st(e),"unwind";qe(e)};function P(){for(var e=s.numThreads;e--;)Je();Oe.unshift(()=>{Ae++,ot(()=>Be())})}function Je(){var e=W("ort-wasm-threaded.worker.js");e=new Worker(e),M.Oa.push(e)}function ot(e){T?e():Promise.all(M.Oa.map(M.Xa)).then(e)}var M={Oa:[],Pa:[],ab:[],La:{},Va(){T?(M.receiveObjectTransfer=M.fb,M.threadInitTLS=M.$a,M.setExitStatus=M.Za):P()},Za:e=>F=e,pb:["$terminateWorker"],hb:()=>{for(var e of M.Pa)We(e);for(e of M.Oa)We(e);M.Oa=[],M.Pa=[],M.La=[]},Ya:e=>{var r=e.Na;delete M.La[r],M.Oa.push(e),M.Pa.splice(M.Pa.indexOf(e),1),e.Na=0,bt(r)},fb(){},$a(){M.ab.forEach(e=>e())},Xa:e=>new Promise(r=>{e.onmessage=b=>{b=b.data;var v=b.cmd;if(b.targetThread&&b.targetThread!=ut()){var z=M.La[b.targetThread];z?z.postMessage(b,b.transferList):ne(`Internal error! Worker sent a message "${v}" to target pthread ${b.targetThread}, but that thread no longer exists!`)}else v==="checkMailbox"?it():v==="spawnThread"?nt(b):v==="cleanupThread"?M.Ya(M.La[b.thread]):v==="killThread"?(b=b.thread,v=M.La[b],delete M.La[b],We(v),bt(b),M.Pa.splice(M.Pa.indexOf(v),1),v.Na=0):v==="cancelThread"?M.La[b.thread].postMessage({cmd:"cancel"}):v==="loaded"?(e.loaded=!0,D&&!e.Na&&e.unref(),r(e)):v==="alert"?alert(`Thread ${b.threadId}: ${b.text}`):b.target==="setimmediate"?e.postMessage(b):v==="callHandler"?s[b.handler](...b.args):v&&ne(`worker sent an unknown command ${v}`)},e.onerror=b=>{throw ne(`worker sent an error! ${b.filename}:${b.lineno}: ${b.message}`),b},D&&(e.on("message",b=>e.onmessage({data:b})),e.on("error",b=>e.onerror(b)));var n=[],l=["onExit"],y;for(y of l)s.hasOwnProperty(y)&&n.push(y);e.postMessage({cmd:"load",handlers:n,urlOrBlob:s.mainScriptUrlOrBlob||i,wasmMemory:X,wasmModule:we})})};s.PThread=M;var Ne=e=>{for(;0<e.length;)e.shift()(s)};s.establishStackSpace=()=>{var e=ut(),r=w()[e+52>>>2>>>0];e=w()[e+56>>>2>>>0],or(r,r-e),ft(r)};function st(e){if(T)return G(1,0,e);Ve(e)}var Fe=[],Xe;s.invokeEntryPoint=(e,r)=>{De=0;var n=Fe[e];n||(e>=Fe.length&&(Fe.length=e+1),Fe[e]=n=Xe.get(e)),e=n(r),0<De?M.Za(e):yt(e)};class t{constructor(r){this.Ua=r-24}Va(r,n){w()[this.Ua+16>>>2>>>0]=0,w()[this.Ua+4>>>2>>>0]=r,w()[this.Ua+8>>>2>>>0]=n}}var o=0,u=0;function m(e,r,n,l){return T?G(2,1,e,r,n,l):O(e,r,n,l)}function O(e,r,n,l){if(e>>>=0,r>>>=0,n>>>=0,l>>>=0,typeof SharedArrayBuffer>"u")return ne("Current environment does not support SharedArrayBuffer, pthreads are not available!"),6;var y=[];return T&&y.length===0?m(e,r,n,l):(e={gb:n,Na:e,cb:l,mb:y},T?(e.ob="spawnThread",postMessage(e,y),0):nt(e))}var E=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0,U=(e,r,n)=>{r>>>=0;var l=r+n;for(n=r;e[n]&&!(n>=l);)++n;if(16<n-r&&e.buffer&&E)return E.decode(e.buffer instanceof SharedArrayBuffer?e.slice(r,n):e.subarray(r,n));for(l="";r<n;){var y=e[r++];if(y&128){var b=e[r++]&63;if((y&224)==192)l+=String.fromCharCode((y&31)<<6|b);else{var v=e[r++]&63;y=(y&240)==224?(y&15)<<12|b<<6|v:(y&7)<<18|b<<12|v<<6|e[r++]&63,65536>y?l+=String.fromCharCode(y):(y-=65536,l+=String.fromCharCode(55296|y>>10,56320|y&1023))}}else l+=String.fromCharCode(y)}return l},ee=(e,r)=>(e>>>=0)?U(h(),e,r):"";function ye(e,r,n){return T?G(3,1,e,r,n):0}function oe(e,r){if(T)return G(4,1,e,r)}var se=e=>{for(var r=0,n=0;n<e.length;++n){var l=e.charCodeAt(n);127>=l?r++:2047>=l?r+=2:55296<=l&&57343>=l?(r+=4,++n):r+=3}return r},Qe=(e,r,n,l)=>{if(n>>>=0,!(0<l))return 0;var y=n;l=n+l-1;for(var b=0;b<e.length;++b){var v=e.charCodeAt(b);if(55296<=v&&57343>=v){var z=e.charCodeAt(++b);v=65536+((v&1023)<<10)|z&1023}if(127>=v){if(n>=l)break;r[n++>>>0]=v}else{if(2047>=v){if(n+1>=l)break;r[n++>>>0]=192|v>>6}else{if(65535>=v){if(n+2>=l)break;r[n++>>>0]=224|v>>12}else{if(n+3>=l)break;r[n++>>>0]=240|v>>18,r[n++>>>0]=128|v>>12&63}r[n++>>>0]=128|v>>6&63}r[n++>>>0]=128|v&63}}return r[n>>>0]=0,n-y},Re=(e,r,n)=>Qe(e,h(),r,n);function d(e,r){if(T)return G(5,1,e,r)}function k(e,r,n){if(T)return G(6,1,e,r,n)}function $(e,r,n){return T?G(7,1,e,r,n):0}function Me(e,r){if(T)return G(8,1,e,r)}function Ze(e,r,n){if(T)return G(9,1,e,r,n)}function Rt(e,r,n,l){if(T)return G(10,1,e,r,n,l)}function It(e,r,n,l){if(T)return G(11,1,e,r,n,l)}function Bt(e,r,n,l){if(T)return G(12,1,e,r,n,l)}function kt(e){if(T)return G(13,1,e)}function Wt(e,r){if(T)return G(14,1,e,r)}function Nt(e,r,n){if(T)return G(15,1,e,r,n)}function dt(e){e>>>=0,typeof Atomics.nb=="function"&&(Atomics.nb(f(),e>>>2,e).value.then(it),e+=128,Atomics.store(f(),e>>>2,1))}s.__emscripten_thread_mailbox_await=dt;var it=()=>{var e=ut();if(e&&(dt(e),e=nr,!me))try{if(e(),!(0<De))try{T?yt(F):Ve(F)}catch(r){r instanceof ke||r=="unwind"||V(1,r)}}catch(r){r instanceof ke||r=="unwind"||V(1,r)}};s.checkMailbox=it;var pt=[],$e=e=>e%4===0&&(e%100!==0||e%400===0),Ht=[0,31,60,91,121,152,182,213,244,274,305,335],Gt=[0,31,59,90,120,151,181,212,243,273,304,334];function $t(e,r,n,l,y,b,v,z){return T?G(16,1,e,r,n,l,y,b,v,z):-52}function Yt(e,r,n,l,y,b,v){if(T)return G(17,1,e,r,n,l,y,b,v)}var mt=[],gt={},jt=()=>{if(!ht){var e={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",_:I||"./this.program"},r;for(r in gt)gt[r]===void 0?delete e[r]:e[r]=gt[r];var n=[];for(r in e)n.push(`${r}=${e[r]}`);ht=n}return ht},ht;function zt(e,r){if(T)return G(18,1,e,r);e>>>=0,r>>>=0;var n=0;return jt().forEach((l,y)=>{var b=r+n;for(y=w()[e+4*y>>>2>>>0]=b,b=0;b<l.length;++b)a()[y++>>>0]=l.charCodeAt(b);a()[y>>>0]=0,n+=l.length+1}),0}function qt(e,r){if(T)return G(19,1,e,r);e>>>=0,r>>>=0;var n=jt();w()[e>>>2>>>0]=n.length;var l=0;return n.forEach(y=>l+=y.length+1),w()[r>>>2>>>0]=l,0}function Vt(e){return T?G(20,1,e):52}function Jt(e,r,n,l){return T?G(21,1,e,r,n,l):52}function Xt(e,r,n,l,y){return T?G(22,1,e,r,n,l,y):70}var Hr=[null,[],[]];function Qt(e,r,n,l){if(T)return G(23,1,e,r,n,l);r>>>=0,n>>>=0,l>>>=0;for(var y=0,b=0;b<n;b++){var v=w()[r>>>2>>>0],z=w()[r+4>>>2>>>0];r+=8;for(var Ce=0;Ce<z;Ce++){var fe=h()[v+Ce>>>0],he=Hr[e];fe===0||fe===10?((e===1?Ie:ne)(U(he,0)),he.length=0):he.push(fe)}y+=z}return w()[l>>>2>>>0]=y,0}var Zt=[31,29,31,30,31,30,31,31,30,31,30,31],Kt=[31,28,31,30,31,30,31,31,30,31,30,31];function Gr(e){var r=Array(se(e)+1);return Qe(e,r,0,r.length),r}var $r=(e,r)=>{a().set(e,r>>>0)};function er(e,r,n,l){function y(p,N,q){for(p=typeof p=="number"?p.toString():p||"";p.length<N;)p=q[0]+p;return p}function b(p,N){return y(p,N,"0")}function v(p,N){function q(fr){return 0>fr?-1:0<fr?1:0}var He;return(He=q(p.getFullYear()-N.getFullYear()))===0&&(He=q(p.getMonth()-N.getMonth()))===0&&(He=q(p.getDate()-N.getDate())),He}function z(p){switch(p.getDay()){case 0:return new Date(p.getFullYear()-1,11,29);case 1:return p;case 2:return new Date(p.getFullYear(),0,3);case 3:return new Date(p.getFullYear(),0,2);case 4:return new Date(p.getFullYear(),0,1);case 5:return new Date(p.getFullYear()-1,11,31);case 6:return new Date(p.getFullYear()-1,11,30)}}function Ce(p){var N=p.Qa;for(p=new Date(new Date(p.Ra+1900,0,1).getTime());0<N;){var q=p.getMonth(),He=($e(p.getFullYear())?Zt:Kt)[q];if(N>He-p.getDate())N-=He-p.getDate()+1,p.setDate(1),11>q?p.setMonth(q+1):(p.setMonth(0),p.setFullYear(p.getFullYear()+1));else{p.setDate(p.getDate()+N);break}}return q=new Date(p.getFullYear()+1,0,4),N=z(new Date(p.getFullYear(),0,4)),q=z(q),0>=v(N,p)?0>=v(q,p)?p.getFullYear()+1:p.getFullYear():p.getFullYear()-1}e>>>=0,r>>>=0,n>>>=0,l>>>=0;var fe=w()[l+40>>>2>>>0];l={kb:f()[l>>>2>>>0],jb:f()[l+4>>>2>>>0],Sa:f()[l+8>>>2>>>0],Wa:f()[l+12>>>2>>>0],Ta:f()[l+16>>>2>>>0],Ra:f()[l+20>>>2>>>0],Ma:f()[l+24>>>2>>>0],Qa:f()[l+28>>>2>>>0],qb:f()[l+32>>>2>>>0],ib:f()[l+36>>>2>>>0],lb:fe?ee(fe):""},n=ee(n),fe={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var he in fe)n=n.replace(new RegExp(he,"g"),fe[he]);var ir="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" "),ur="January February March April May June July August September October November December".split(" ");fe={"%a":p=>ir[p.Ma].substring(0,3),"%A":p=>ir[p.Ma],"%b":p=>ur[p.Ta].substring(0,3),"%B":p=>ur[p.Ta],"%C":p=>b((p.Ra+1900)/100|0,2),"%d":p=>b(p.Wa,2),"%e":p=>y(p.Wa,2," "),"%g":p=>Ce(p).toString().substring(2),"%G":Ce,"%H":p=>b(p.Sa,2),"%I":p=>(p=p.Sa,p==0?p=12:12<p&&(p-=12),b(p,2)),"%j":p=>{for(var N=0,q=0;q<=p.Ta-1;N+=($e(p.Ra+1900)?Zt:Kt)[q++]);return b(p.Wa+N,3)},"%m":p=>b(p.Ta+1,2),"%M":p=>b(p.jb,2),"%n":()=>`\n`,"%p":p=>0<=p.Sa&&12>p.Sa?"AM":"PM","%S":p=>b(p.kb,2),"%t":()=>"	","%u":p=>p.Ma||7,"%U":p=>b(Math.floor((p.Qa+7-p.Ma)/7),2),"%V":p=>{var N=Math.floor((p.Qa+7-(p.Ma+6)%7)/7);if(2>=(p.Ma+371-p.Qa-2)%7&&N++,N)N==53&&(q=(p.Ma+371-p.Qa)%7,q==4||q==3&&$e(p.Ra)||(N=1));else{N=52;var q=(p.Ma+7-p.Qa-1)%7;(q==4||q==5&&$e(p.Ra%400-1))&&N++}return b(N,2)},"%w":p=>p.Ma,"%W":p=>b(Math.floor((p.Qa+7-(p.Ma+6)%7)/7),2),"%y":p=>(p.Ra+1900).toString().substring(2),"%Y":p=>p.Ra+1900,"%z":p=>{p=p.ib;var N=0<=p;return p=Math.abs(p)/60,(N?"+":"-")+("0000"+(p/60*100+p%60)).slice(-4)},"%Z":p=>p.lb,"%%":()=>"%"},n=n.replace(/%%/g,"\\0\\0");for(he in fe)n.includes(he)&&(n=n.replace(new RegExp(he,"g"),fe[he](l)));return n=n.replace(/\\0\\0/g,"%"),he=Gr(n),he.length>r?0:($r(he,e),he.length-1)}M.Va();var Yr=[qe,st,m,ye,oe,d,k,$,Me,Ze,Rt,It,Bt,kt,Wt,Nt,$t,Yt,zt,qt,Vt,Jt,Xt,Qt],jr={b:function(e,r,n){throw e>>>=0,new t(e).Va(r>>>0,n>>>0),o=e,u++,o},L:function(e){tr(e>>>0,!B,1,!R,131072,!1),M.$a()},j:function(e){e>>>=0,T?postMessage({cmd:"cleanupThread",thread:e}):M.Ya(M.La[e])},H:O,h:ye,S:oe,D:d,F:k,T:$,Q:Me,J:Ze,P:Rt,n:It,E:Bt,B:kt,R:Wt,C:Nt,p:()=>1,z:function(e,r){e>>>=0,e==r>>>0?setTimeout(it):T?postMessage({targetThread:e,cmd:"checkMailbox"}):(e=M.La[e])&&e.postMessage({cmd:"checkMailbox"})},I:function(e,r,n,l,y){r>>>=0,n>>>=0,pt.length=l,y=y>>>0>>>3;for(var b=0;b<l;b++)pt[b]=g()[y+b>>>0];return e=r?Ge[r]:Yr[e],M.eb=n,n=e(...pt),M.eb=0,n},K:dt,o:function(e){D&&M.La[e>>>0].ref()},s:function(e,r,n){e=r+2097152>>>0<4194305-!!e?(e>>>0)+4294967296*r:NaN,n>>>=0,e=new Date(1e3*e),f()[n>>>2>>>0]=e.getUTCSeconds(),f()[n+4>>>2>>>0]=e.getUTCMinutes(),f()[n+8>>>2>>>0]=e.getUTCHours(),f()[n+12>>>2>>>0]=e.getUTCDate(),f()[n+16>>>2>>>0]=e.getUTCMonth(),f()[n+20>>>2>>>0]=e.getUTCFullYear()-1900,f()[n+24>>>2>>>0]=e.getUTCDay(),e=(e.getTime()-Date.UTC(e.getUTCFullYear(),0,1,0,0,0,0))/864e5|0,f()[n+28>>>2>>>0]=e},t:function(e,r,n){e=r+2097152>>>0<4194305-!!e?(e>>>0)+4294967296*r:NaN,n>>>=0,e=new Date(1e3*e),f()[n>>>2>>>0]=e.getSeconds(),f()[n+4>>>2>>>0]=e.getMinutes(),f()[n+8>>>2>>>0]=e.getHours(),f()[n+12>>>2>>>0]=e.getDate(),f()[n+16>>>2>>>0]=e.getMonth(),f()[n+20>>>2>>>0]=e.getFullYear()-1900,f()[n+24>>>2>>>0]=e.getDay(),r=($e(e.getFullYear())?Ht:Gt)[e.getMonth()]+e.getDate()-1|0,f()[n+28>>>2>>>0]=r,f()[n+36>>>2>>>0]=-(60*e.getTimezoneOffset()),r=new Date(e.getFullYear(),6,1).getTimezoneOffset();var l=new Date(e.getFullYear(),0,1).getTimezoneOffset();e=(r!=l&&e.getTimezoneOffset()==Math.min(l,r))|0,f()[n+32>>>2>>>0]=e},u:function(e){e>>>=0;var r=new Date(f()[e+20>>>2>>>0]+1900,f()[e+16>>>2>>>0],f()[e+12>>>2>>>0],f()[e+8>>>2>>>0],f()[e+4>>>2>>>0],f()[e>>>2>>>0],0),n=f()[e+32>>>2>>>0],l=r.getTimezoneOffset(),y=new Date(r.getFullYear(),6,1).getTimezoneOffset(),b=new Date(r.getFullYear(),0,1).getTimezoneOffset(),v=Math.min(b,y);return 0>n?f()[e+32>>>2>>>0]=+(y!=b&&v==l):0<n!=(v==l)&&(y=Math.max(b,y),r.setTime(r.getTime()+6e4*((0<n?v:y)-l))),f()[e+24>>>2>>>0]=r.getDay(),n=($e(r.getFullYear())?Ht:Gt)[r.getMonth()]+r.getDate()-1|0,f()[e+28>>>2>>>0]=n,f()[e>>>2>>>0]=r.getSeconds(),f()[e+4>>>2>>>0]=r.getMinutes(),f()[e+8>>>2>>>0]=r.getHours(),f()[e+12>>>2>>>0]=r.getDate(),f()[e+16>>>2>>>0]=r.getMonth(),f()[e+20>>>2>>>0]=r.getYear(),e=r.getTime(),e=isNaN(e)?-1:e/1e3,ar((Te=e,1<=+Math.abs(Te)?0<Te?+Math.floor(Te/4294967296)>>>0:~~+Math.ceil((Te-+(~~Te>>>0))/4294967296)>>>0:0)),e>>>0},q:$t,r:Yt,y:function(e,r,n,l){e>>>=0,r>>>=0,n>>>=0,l>>>=0;var y=new Date().getFullYear(),b=new Date(y,0,1),v=new Date(y,6,1);y=b.getTimezoneOffset();var z=v.getTimezoneOffset(),Ce=Math.max(y,z);w()[e>>>2>>>0]=60*Ce,f()[r>>>2>>>0]=+(y!=z),e=fe=>fe.toLocaleTimeString(void 0,{hour12:!1,timeZoneName:"short"}).split(" ")[1],b=e(b),v=e(v),z<y?(Re(b,n,17),Re(v,l,17)):(Re(b,l,17),Re(v,n,17))},c:()=>{te("")},O:function(e,r,n){e>>>=0,r>>>=0,n>>>=0,mt.length=0;for(var l;l=h()[r++>>>0];){var y=l!=105;y&=l!=112,n+=y&&n%8?4:0,mt.push(l==112?w()[n>>>2>>>0]:l==105?f()[n>>>2>>>0]:g()[n>>>3>>>0]),n+=y?8:4}return Ge[e](...mt)},k:()=>{},i:()=>Date.now(),U:()=>{throw De+=1,"unwind"},A:function(){return 4294901760},e:()=>performance.timeOrigin+performance.now(),f:()=>D?(br(),et(hr)).cpus().length:navigator.hardwareConcurrency,x:function(e){e>>>=0;var r=h().length;if(e<=r||4294901760<e)return!1;for(var n=1;4>=n;n*=2){var l=r*(1+.2/n);l=Math.min(l,e+100663296);var y=Math;l=Math.max(e,l);e:{y=(y.min.call(y,4294901760,l+(65536-l%65536)%65536)-X.buffer.byteLength+65535)/65536;try{X.grow(y),K();var b=1;break e}catch{}b=void 0}if(b)return!0}return!1},M:zt,N:qt,G:Ve,g:Vt,m:Jt,v:Xt,l:Qt,a:X||s.wasmMemory,w:er,d:function(e,r,n,l){return er(e>>>0,r>>>0,n>>>0,l>>>0)}},C=function(){function e(n,l){return C=n.exports,C=zr(),M.ab.push(C.ya),Xe=C.za,Ue.unshift(C.V),we=l,Be(),C}var r={a:jr};if(Ae++,s.instantiateWasm)try{return s.instantiateWasm(r,e)}catch(n){ne(`Module.instantiateWasm callback failed with error: ${n}`),x(n)}return rt(r,function(n){e(n.instance,n.module)}).catch(x),{}}();s._OrtInit=(e,r)=>(s._OrtInit=C.W)(e,r),s._OrtGetLastError=(e,r)=>(s._OrtGetLastError=C.X)(e,r),s._OrtCreateSessionOptions=(e,r,n,l,y,b,v,z,Ce,fe)=>(s._OrtCreateSessionOptions=C.Y)(e,r,n,l,y,b,v,z,Ce,fe),s._OrtAppendExecutionProvider=(e,r)=>(s._OrtAppendExecutionProvider=C.Z)(e,r),s._OrtAddFreeDimensionOverride=(e,r,n)=>(s._OrtAddFreeDimensionOverride=C._)(e,r,n),s._OrtAddSessionConfigEntry=(e,r,n)=>(s._OrtAddSessionConfigEntry=C.$)(e,r,n),s._OrtReleaseSessionOptions=e=>(s._OrtReleaseSessionOptions=C.aa)(e),s._OrtCreateSession=(e,r,n)=>(s._OrtCreateSession=C.ba)(e,r,n),s._OrtReleaseSession=e=>(s._OrtReleaseSession=C.ca)(e),s._OrtGetInputOutputCount=(e,r,n)=>(s._OrtGetInputOutputCount=C.da)(e,r,n),s._OrtGetInputName=(e,r)=>(s._OrtGetInputName=C.ea)(e,r),s._OrtGetOutputName=(e,r)=>(s._OrtGetOutputName=C.fa)(e,r),s._OrtFree=e=>(s._OrtFree=C.ga)(e),s._OrtCreateTensor=(e,r,n,l,y,b)=>(s._OrtCreateTensor=C.ha)(e,r,n,l,y,b),s._OrtGetTensorData=(e,r,n,l,y)=>(s._OrtGetTensorData=C.ia)(e,r,n,l,y),s._OrtReleaseTensor=e=>(s._OrtReleaseTensor=C.ja)(e),s._OrtCreateRunOptions=(e,r,n,l)=>(s._OrtCreateRunOptions=C.ka)(e,r,n,l),s._OrtAddRunConfigEntry=(e,r,n)=>(s._OrtAddRunConfigEntry=C.la)(e,r,n),s._OrtReleaseRunOptions=e=>(s._OrtReleaseRunOptions=C.ma)(e),s._OrtCreateBinding=e=>(s._OrtCreateBinding=C.na)(e),s._OrtBindInput=(e,r,n)=>(s._OrtBindInput=C.oa)(e,r,n),s._OrtBindOutput=(e,r,n,l)=>(s._OrtBindOutput=C.pa)(e,r,n,l),s._OrtClearBoundOutputs=e=>(s._OrtClearBoundOutputs=C.qa)(e),s._OrtReleaseBinding=e=>(s._OrtReleaseBinding=C.ra)(e),s._OrtRunWithBinding=(e,r,n,l,y)=>(s._OrtRunWithBinding=C.sa)(e,r,n,l,y),s._OrtRun=(e,r,n,l,y,b,v,z)=>(s._OrtRun=C.ta)(e,r,n,l,y,b,v,z),s._OrtEndProfiling=e=>(s._OrtEndProfiling=C.ua)(e);var ut=s._pthread_self=()=>(ut=s._pthread_self=C.va)();s._malloc=e=>(s._malloc=C.wa)(e),s._free=e=>(s._free=C.xa)(e),s.__emscripten_tls_init=()=>(s.__emscripten_tls_init=C.ya)();var tr=s.__emscripten_thread_init=(e,r,n,l,y,b)=>(tr=s.__emscripten_thread_init=C.Aa)(e,r,n,l,y,b);s.__emscripten_thread_crashed=()=>(s.__emscripten_thread_crashed=C.Ba)();var rr=(e,r,n,l,y)=>(rr=C.Ca)(e,r,n,l,y),bt=e=>(bt=C.Da)(e),yt=s.__emscripten_thread_exit=e=>(yt=s.__emscripten_thread_exit=C.Ea)(e),nr=()=>(nr=C.Fa)(),ar=e=>(ar=C.Ga)(e),or=(e,r)=>(or=C.Ha)(e,r),ft=e=>(ft=C.Ia)(e),wt=e=>(wt=C.Ja)(e),Ot=()=>(Ot=C.Ka)();function zr(){var e=C;e=Object.assign({},e);var r=l=>()=>l()>>>0,n=l=>y=>l(y)>>>0;return e.va=r(e.va),e.wa=n(e.wa),e.emscripten_main_runtime_thread_id=r(e.emscripten_main_runtime_thread_id),e.Ja=n(e.Ja),e.Ka=r(e.Ka),e}s.wasmMemory=X,s.stackSave=()=>Ot(),s.stackRestore=e=>ft(e),s.stackAlloc=e=>wt(e),s.keepRuntimeAlive=()=>0<De,s.UTF8ToString=ee,s.stringToUTF8=Re,s.lengthBytesUTF8=se,s.ExitStatus=ke,s.PThread=M;var lt;ge=function e(){lt||sr(),lt||(ge=e)};function sr(){if(!(0<Ae))if(T)S(s),T||Ne(Ue),startWorker(s);else{if(s.preRun)for(typeof s.preRun=="function"&&(s.preRun=[s.preRun]);s.preRun.length;)Oe.unshift(s.preRun.shift());Ne(Oe),0<Ae||lt||(lt=!0,s.calledRun=!0,me||(T||Ne(Ue),S(s),T||Ne(ve)))}}return sr(),H}})();typeof wr=="object"&&typeof Dt=="object"?Dt.exports=yr:typeof define=="function"&&define.amd&&define([],()=>yr)});var vr=Ke((yn,tn)=>{tn.exports=\'"use strict";var Module={},ENVIRONMENT_IS_NODE=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string";if(ENVIRONMENT_IS_NODE){var nodeWorkerThreads=require("worker_threads"),parentPort=nodeWorkerThreads.parentPort;parentPort.on("message",e=>onmessage({data:e}));var fs=require("fs"),vm=require("vm");Object.assign(global,{self:global,require,Module,location:{href:__filename},Worker:nodeWorkerThreads.Worker,importScripts:e=>vm.runInThisContext(fs.readFileSync(e,"utf8"),{filename:e}),postMessage:e=>parentPort.postMessage(e),performance:global.performance||{now:Date.now}})}var initializedJS=!1;function threadPrintErr(...e){var a=e.join(" ");if(ENVIRONMENT_IS_NODE){fs.writeSync(2,a+`\\n`);return}console.error(a)}function threadAlert(...e){var a=e.join(" ");postMessage({cmd:"alert",text:a,threadId:Module._pthread_self()})}var err=threadPrintErr;self.alert=threadAlert,Module.instantiateWasm=(e,a)=>{var r=Module.wasmModule;Module.wasmModule=null;var t=new WebAssembly.Instance(r,e);return a(t)},self.onunhandledrejection=e=>{throw e.reason||e};function handleMessage(e){try{if(e.data.cmd==="load"){let r=[];self.onmessage=t=>r.push(t),self.startWorker=t=>{Module=t,postMessage({cmd:"loaded"});for(let s of r)handleMessage(s);self.onmessage=handleMessage},Module.wasmModule=e.data.wasmModule;for(const t of e.data.handlers)Module[t]=(...s)=>{postMessage({cmd:"callHandler",handler:t,args:s})};if(Module.wasmMemory=e.data.wasmMemory,Module.buffer=Module.wasmMemory.buffer,Module.ENVIRONMENT_IS_PTHREAD=!0,typeof e.data.urlOrBlob=="string")importScripts(e.data.urlOrBlob);else{var a=URL.createObjectURL(e.data.urlOrBlob);importScripts(a),URL.revokeObjectURL(a)}ortWasmThreaded(Module)}else if(e.data.cmd==="run"){Module.__emscripten_thread_init(e.data.pthread_ptr,0,0,1),Module.__emscripten_thread_mailbox_await(e.data.pthread_ptr),Module.establishStackSpace(),Module.PThread.receiveObjectTransfer(e.data),Module.PThread.threadInitTLS(),initializedJS||(initializedJS=!0);try{Module.invokeEntryPoint(e.data.start_routine,e.data.arg)}catch(r){if(r!="unwind")throw r}}else e.data.cmd==="cancel"?Module._pthread_self()&&Module.__emscripten_thread_exit(-1):e.data.target==="setimmediate"||(e.data.cmd==="checkMailbox"?initializedJS&&Module.checkMailbox():e.data.cmd&&(err(`worker.js received unknown command ${e.data.cmd}`),err(e.data)))}catch(r){throw Module.__emscripten_thread_crashed?.(),r}}self.onmessage=handleMessage;\\n\'});var Er;Er=pr();var rn=Or(),Ft,Pt=!1,ct=!1,_r=!1,nn=i=>{if(i===1)return!1;if(typeof SharedArrayBuffer>"u")return typeof self<"u"&&!self.crossOriginIsolated&&console.warn("env.wasm.numThreads is set to "+i+", but this will not work unless you enable crossOriginIsolated mode. See https://web.dev/cross-origin-isolation-guide/ for more info."),!1;typeof process<"u"&&process.versions&&process.versions.node&&console.warn("env.wasm.numThreads is set to "+i+", however, currently onnxruntime-web does not support multi-threads in Node.js. Please consider using onnxruntime-node for performance critical scenarios.");try{return typeof MessageChannel<"u"&&new MessageChannel().port1.postMessage(new SharedArrayBuffer(1)),WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,5,4,1,3,1,1,10,11,1,9,0,65,0,254,16,2,0,26,11]))}catch{return!1}},an=()=>{try{return WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,10,30,1,28,0,65,0,253,15,253,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,253,186,1,26,11]))}catch{return!1}},on=(i,c)=>i?c?"ort-wasm-simd-threaded.wasm":"ort-wasm-simd.wasm":c?"ort-wasm-threaded.wasm":"ort-wasm.wasm",Sr=async i=>{if(Pt)return Promise.resolve();if(ct)throw new Error("multiple calls to \'initializeWebAssembly()\' detected.");if(_r)throw new Error("previous call to \'initializeWebAssembly()\' failed.");ct=!0;let c=i.initTimeout,a=i.numThreads,h=i.simd,f=nn(a),w=h&&an(),g=i.wasmPaths,s=typeof g=="string"?g:void 0,S=on(w,f),x=typeof g=="object"?g[S]:void 0,H=!1,A=[];if(c>0&&A.push(new Promise(I=>{setTimeout(()=>{H=!0,I()},c)})),A.push(new Promise((I,V)=>{let R=f?rn:Er,B={locateFile:(D,T)=>f&&D.endsWith(".worker.js")&&typeof Blob<"u"?URL.createObjectURL(new Blob([vr()],{type:"text/javascript"})):D.endsWith(".wasm")?x||(s??T)+S:T+D};if(f)if(B.numThreads=a,typeof Blob>"u")B.mainScriptUrlOrBlob=(void 0)(__dirname,"ort-wasm-threaded.js");else{let D=`var ortWasmThreaded=${R.toString()};`;B.mainScriptUrlOrBlob=new Blob([D],{type:"text/javascript"})}R(B).then(D=>{ct=!1,Pt=!0,Ft=D,I()},D=>{ct=!1,_r=!0,V(D)})})),await Promise.race(A),H)throw new Error(`WebAssembly backend initializing failed due to timeout: ${c}ms`)},Q=()=>{if(Pt&&Ft)return Ft;throw new Error("WebAssembly is not initialized yet.")};var Y=(i,c)=>{let a=Q(),h=a.lengthBytesUTF8(i)+1,f=a._malloc(h);return a.stringToUTF8(i,f,h),c.push(f),f},tt=(i,c,a,h)=>{if(typeof i=="object"&&i!==null){if(a.has(i))throw new Error("Circular reference in options");a.add(i)}Object.entries(i).forEach(([f,w])=>{let g=c?c+f:f;if(typeof w=="object")tt(w,g+".",a,h);else if(typeof w=="string"||typeof w=="number")h(g,w.toString());else if(typeof w=="boolean")h(g,w?"1":"0");else throw new Error(`Can\'t handle extra config type: ${typeof w}`)})},j=i=>{let c=Q(),a=c.stackSave();try{let h=c.stackAlloc(8);c._OrtGetLastError(h,h+4);let f=c.HEAP32[h/4],w=c.HEAPU32[h/4+1],g=w?c.UTF8ToString(w):"";throw new Error(`${i} ERROR_CODE: ${f}, ERROR_MESSAGE: ${g}`)}finally{c.stackRestore(a)}};var Ar=i=>{let c=Q(),a=0,h=[],f=i||{};try{if(i?.logSeverityLevel===void 0)f.logSeverityLevel=2;else if(typeof i.logSeverityLevel!="number"||!Number.isInteger(i.logSeverityLevel)||i.logSeverityLevel<0||i.logSeverityLevel>4)throw new Error(`log serverity level is not valid: ${i.logSeverityLevel}`);if(i?.logVerbosityLevel===void 0)f.logVerbosityLevel=0;else if(typeof i.logVerbosityLevel!="number"||!Number.isInteger(i.logVerbosityLevel))throw new Error(`log verbosity level is not valid: ${i.logVerbosityLevel}`);i?.terminate===void 0&&(f.terminate=!1);let w=0;return i?.tag!==void 0&&(w=Y(i.tag,h)),a=c._OrtCreateRunOptions(f.logSeverityLevel,f.logVerbosityLevel,!!f.terminate,w),a===0&&j("Can\'t create run options."),i?.extra!==void 0&&tt(i.extra,"",new WeakSet,(g,s)=>{let S=Y(g,h),x=Y(s,h);c._OrtAddRunConfigEntry(a,S,x)!==0&&j(`Can\'t set a run config entry: ${g} - ${s}.`)}),[a,h]}catch(w){throw a!==0&&c._OrtReleaseRunOptions(a),h.forEach(g=>c._free(g)),w}};var sn=i=>{switch(i){case"disabled":return 0;case"basic":return 1;case"extended":return 2;case"all":return 99;default:throw new Error(`unsupported graph optimization level: ${i}`)}},un=i=>{switch(i){case"sequential":return 0;case"parallel":return 1;default:throw new Error(`unsupported execution mode: ${i}`)}},fn=i=>{i.extra||(i.extra={}),i.extra.session||(i.extra.session={});let c=i.extra.session;c.use_ort_model_bytes_directly||(c.use_ort_model_bytes_directly="1"),i.executionProviders&&i.executionProviders.some(a=>(typeof a=="string"?a:a.name)==="webgpu")&&(i.enableMemPattern=!1)},ln=(i,c,a)=>{for(let h of c){let f=typeof h=="string"?h:h.name;switch(f){case"webnn":if(f="WEBNN",typeof h!="string"){let g=h;if(g?.deviceType){let s=Y("deviceType",a),S=Y(g.deviceType,a);Q()._OrtAddSessionConfigEntry(i,s,S)!==0&&j(`Can\'t set a session config entry: \'deviceType\' - ${g.deviceType}.`)}if(g?.numThreads){let s=g.numThreads;(typeof s!="number"||!Number.isInteger(s)||s<0)&&(s=0);let S=Y("numThreads",a),x=Y(s.toString(),a);Q()._OrtAddSessionConfigEntry(i,S,x)!==0&&j(`Can\'t set a session config entry: \'numThreads\' - ${g.numThreads}.`)}if(g?.powerPreference){let s=Y("powerPreference",a),S=Y(g.powerPreference,a);Q()._OrtAddSessionConfigEntry(i,s,S)!==0&&j(`Can\'t set a session config entry: \'powerPreference\' - ${g.powerPreference}.`)}}break;case"webgpu":if(f="JS",typeof h!="string"){let g=h;if(g?.preferredLayout){if(g.preferredLayout!=="NCHW"&&g.preferredLayout!=="NHWC")throw new Error(`preferredLayout must be either \'NCHW\' or \'NHWC\': ${g.preferredLayout}`);let s=Y("preferredLayout",a),S=Y(g.preferredLayout,a);Q()._OrtAddSessionConfigEntry(i,s,S)!==0&&j(`Can\'t set a session config entry: \'preferredLayout\' - ${g.preferredLayout}.`)}}break;case"wasm":case"cpu":continue;default:throw new Error(`not supported execution provider: ${f}`)}let w=Y(f,a);Q()._OrtAppendExecutionProvider(i,w)!==0&&j(`Can\'t append execution provider: ${f}.`)}},Tr=i=>{let c=Q(),a=0,h=[],f=i||{};fn(f);try{let w=sn(f.graphOptimizationLevel??"all"),g=un(f.executionMode??"sequential"),s=typeof f.logId=="string"?Y(f.logId,h):0,S=f.logSeverityLevel??2;if(!Number.isInteger(S)||S<0||S>4)throw new Error(`log serverity level is not valid: ${S}`);let x=f.logVerbosityLevel??0;if(!Number.isInteger(x)||x<0||x>4)throw new Error(`log verbosity level is not valid: ${x}`);let H=typeof f.optimizedModelFilePath=="string"?Y(f.optimizedModelFilePath,h):0;if(a=c._OrtCreateSessionOptions(w,!!f.enableCpuMemArena,!!f.enableMemPattern,g,!!f.enableProfiling,0,s,S,x,H),a===0&&j("Can\'t create session options."),f.executionProviders&&ln(a,f.executionProviders,h),f.enableGraphCapture!==void 0){if(typeof f.enableGraphCapture!="boolean")throw new Error(`enableGraphCapture must be a boolean value: ${f.enableGraphCapture}`);let A=Y("enableGraphCapture",h),I=Y(f.enableGraphCapture.toString(),h);c._OrtAddSessionConfigEntry(a,A,I)!==0&&j(`Can\'t set a session config entry: \'enableGraphCapture\' - ${f.enableGraphCapture}.`)}if(f.freeDimensionOverrides)for(let[A,I]of Object.entries(f.freeDimensionOverrides)){if(typeof A!="string")throw new Error(`free dimension override name must be a string: ${A}`);if(typeof I!="number"||!Number.isInteger(I)||I<0)throw new Error(`free dimension override value must be a non-negative integer: ${I}`);let V=Y(A,h);c._OrtAddFreeDimensionOverride(a,V,I)!==0&&j(`Can\'t set a free dimension override: ${A} - ${I}.`)}return f.extra!==void 0&&tt(f.extra,"",new WeakSet,(A,I)=>{let V=Y(A,h),R=Y(I,h);c._OrtAddSessionConfigEntry(a,V,R)!==0&&j(`Can\'t set a session config entry: ${A} - ${I}.`)}),[a,h]}catch(w){throw a!==0&&c._OrtReleaseSessionOptions(a),h.forEach(g=>c._free(g)),w}};var xt=i=>{switch(i){case"int8":return 3;case"uint8":return 2;case"bool":return 9;case"int16":return 5;case"uint16":return 4;case"int32":return 6;case"uint32":return 12;case"float16":return 10;case"float32":return 1;case"float64":return 11;case"string":return 8;case"int64":return 7;case"uint64":return 13;default:throw new Error(`unsupported data type: ${i}`)}},Mr=i=>{switch(i){case 3:return"int8";case 2:return"uint8";case 9:return"bool";case 5:return"int16";case 4:return"uint16";case 6:return"int32";case 12:return"uint32";case 10:return"float16";case 1:return"float32";case 11:return"float64";case 8:return"string";case 7:return"int64";case 13:return"uint64";default:throw new Error(`unsupported data type: ${i}`)}},Ut=i=>[void 0,4,1,1,2,2,4,8,void 0,1,2,8,4,8,void 0,void 0,void 0][i],Cr=i=>{switch(i){case"float16":return typeof Float16Array<"u"&&Float16Array.from?Float16Array:Uint16Array;case"float32":return Float32Array;case"uint8":return Uint8Array;case"int8":return Int8Array;case"uint16":return Uint16Array;case"int16":return Int16Array;case"int32":return Int32Array;case"bool":return Uint8Array;case"float64":return Float64Array;case"uint32":return Uint32Array;case"int64":return BigInt64Array;case"uint64":return BigUint64Array;default:throw new Error(`unsupported type: ${i}`)}},Dr=i=>{switch(i){case"verbose":return 0;case"info":return 1;case"warning":return 2;case"error":return 3;case"fatal":return 4;default:throw new Error(`unsupported logging level: ${i}`)}},Fr=i=>i==="float32"||i==="float16"||i==="int32"||i==="int64"||i==="uint32"||i==="uint8"||i==="bool",Pr=i=>{switch(i){case"none":return 0;case"cpu":return 1;case"cpu-pinned":return 2;case"texture":return 3;case"gpu-buffer":return 4;default:throw new Error(`unsupported data location: ${i}`)}};var xr=async i=>{if(typeof i=="string")if(typeof process<"u"&&process.versions&&process.versions.node)try{return new Uint8Array(await(void 0)(i))}catch(c){if(c.code==="ERR_FS_FILE_TOO_LARGE"){let a=(void 0)(i),h=[];for await(let f of a)h.push(f);return new Uint8Array(Buffer.concat(h))}throw c}else{let c=await fetch(i);if(!c.ok)throw new Error(`failed to load external data file: ${i}`);let a=c.headers.get("Content-Length"),h=a?parseInt(a,10):0;if(h<1073741824)return new Uint8Array(await c.arrayBuffer());{if(!c.body)throw new Error(`failed to load external data file: ${i}, no response body.`);let f=c.body.getReader(),w;try{w=new ArrayBuffer(h)}catch(s){if(s instanceof RangeError){let S=Math.ceil(h/65536);w=new WebAssembly.Memory({initial:S,maximum:S}).buffer}else throw s}let g=0;for(;;){let{done:s,value:S}=await f.read();if(s)break;let x=S.byteLength;new Uint8Array(w,g,x).set(S),g+=x}return new Uint8Array(w,0,h)}}else return i instanceof Blob?new Uint8Array(await i.arrayBuffer()):i instanceof Uint8Array?i:new Uint8Array(i)};var cn=(i,c)=>{Q()._OrtInit(i,c)!==0&&j("Can\'t initialize onnxruntime.")},Lr=async i=>{cn(i.wasm.numThreads,Dr(i.logLevel))},Rr=async(i,c)=>{},Ye=new Map,dn=i=>{let c=Q(),a=c.stackSave();try{let h=c.stackAlloc(8);return c._OrtGetInputOutputCount(i,h,h+4)!==0&&j("Can\'t get session input/output count."),[c.HEAP32[h/4],c.HEAP32[h/4+1]]}finally{c.stackRestore(a)}},Lt=i=>{let c=Q(),a=c._malloc(i.byteLength);if(a===0)throw new Error(`Can\'t create a session. failed to allocate a buffer of size ${i.byteLength}.`);return c.HEAPU8.set(i,a),[a,i.byteLength]},Ir=async(i,c)=>{let a,h,f=Q();Array.isArray(i)?[a,h]=i:i.buffer===f.HEAPU8.buffer?[a,h]=[i.byteOffset,i.byteLength]:[a,h]=Lt(i);let w=0,g=0,s=0,S=[],x=[],H=[];try{if([g,S]=Tr(c),c?.externalData&&f.mountExternalData){let L=[];for(let W of c.externalData){let de=typeof W=="string"?W:W.path;L.push(xr(typeof W=="string"?W:W.data).then(pe=>{f.mountExternalData(de,pe)}))}await Promise.all(L)}w=await f._OrtCreateSession(a,h,g),w===0&&j("Can\'t create a session.");let[A,I]=dn(w),V=!!c?.enableGraphCapture,R=[],B=[],D=[];for(let L=0;L<A;L++){let W=f._OrtGetInputName(w,L);W===0&&j("Can\'t get an input name."),x.push(W),R.push(f.UTF8ToString(W))}for(let L=0;L<I;L++){let W=f._OrtGetOutputName(w,L);W===0&&j("Can\'t get an output name."),H.push(W);let de=f.UTF8ToString(W);B.push(de)}let T=null;return Ye.set(w,[w,x,H,T,V,!1]),[w,R,B]}catch(A){throw x.forEach(I=>f._OrtFree(I)),H.forEach(I=>f._OrtFree(I)),s!==0&&f._OrtReleaseBinding(s),w!==0&&f._OrtReleaseSession(w),A}finally{f._free(a),g!==0&&f._OrtReleaseSessionOptions(g),S.forEach(A=>f._free(A)),f.unmountExternalData?.()}},Br=i=>{let c=Q(),a=Ye.get(i);if(!a)throw new Error(`cannot release session. invalid session id: ${i}`);let[h,f,w,g,s]=a;g&&(s&&c._OrtClearBoundOutputs(g.handle),c._OrtReleaseBinding(g.handle)),c.jsepOnReleaseSession?.(i),f.forEach(S=>c._OrtFree(S)),w.forEach(S=>c._OrtFree(S)),c._OrtReleaseSession(h),Ye.delete(i)},Ur=(i,c,a,h,f,w=!1)=>{if(!i){c.push(0);return}let g=Q(),s=i[0],S=i[1],x=i[3],H,A;if(s==="string"&&x==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");if(w&&x!=="gpu-buffer")throw new Error(`External buffer must be provided for input/output index ${f} when enableGraphCapture is true.`);if(x==="gpu-buffer"){let R=i[2].gpuBuffer,B=Ut(xt(s));A=S.reduce((T,L)=>T*L,1)*B;let D=g.jsepRegisterBuffer;if(!D)throw new Error(\'Tensor location "gpu-buffer" is not supported without using WebGPU.\');H=D(h,f,R,A)}else{let R=i[2];if(Array.isArray(R)){A=4*R.length,H=g._malloc(A),a.push(H);let B=H/4;for(let D=0;D<R.length;D++){if(typeof R[D]!="string")throw new TypeError(`tensor data at index ${D} is not a string`);g.HEAPU32[B++]=Y(R[D],a)}}else A=R.byteLength,H=g._malloc(A),a.push(H),g.HEAPU8.set(new Uint8Array(R.buffer,R.byteOffset,A),H)}let I=g.stackSave(),V=g.stackAlloc(4*S.length);try{let R=V/4;S.forEach(D=>g.HEAP32[R++]=D);let B=g._OrtCreateTensor(xt(s),H,A,V,S.length,Pr(x));B===0&&j(`Can\'t create tensor for input/output. session=${h}, index=${f}.`),c.push(B)}finally{g.stackRestore(I)}},kr=async(i,c,a,h,f,w)=>{let g=Q(),s=Ye.get(i);if(!s)throw new Error(`cannot run inference. invalid session id: ${i}`);let S=s[0],x=s[1],H=s[2],A=s[3],I=s[4],V=s[5],R=c.length,B=h.length,D=0,T=[],L=[],W=[],de=[],pe=g.stackSave(),Z=g.stackAlloc(R*4),_=g.stackAlloc(R*4),J=g.stackAlloc(B*4),Pe=g.stackAlloc(B*4);try{[D,T]=Ar(w);for(let F=0;F<R;F++)Ur(a[F],L,de,i,c[F],I);for(let F=0;F<B;F++)Ur(f[F],W,de,i,R+h[F],I);let le=Z/4,Ie=_/4,ne=J/4,X=Pe/4;for(let F=0;F<R;F++)g.HEAPU32[le++]=L[F],g.HEAPU32[Ie++]=x[c[F]];for(let F=0;F<B;F++)g.HEAPU32[ne++]=W[F],g.HEAPU32[X++]=H[h[F]];g.jsepOnRunStart?.(S);let we;we=await g._OrtRun(S,_,Z,R,Pe,B,J,D),we!==0&&j("failed to call OrtRun().");let me=[];for(let F=0;F<B;F++){let ie=g.HEAPU32[J/4+F];if(ie===W[F]){me.push(f[F]);continue}let xe=g.stackSave(),ce=g.stackAlloc(4*4),be=!1,ae,K=0;try{g._OrtGetTensorData(ie,ce,ce+4,ce+8,ce+12)!==0&&j(`Can\'t access output tensor data on index ${F}.`);let Oe=ce/4,Ue=g.HEAPU32[Oe++];K=g.HEAPU32[Oe++];let ve=g.HEAPU32[Oe++],Ae=g.HEAPU32[Oe++],_e=[];for(let te=0;te<Ae;te++)_e.push(g.HEAPU32[ve/4+te]);g._OrtFree(ve);let ge=_e.reduce((te,re)=>te*re,1);ae=Mr(Ue);let Be=A?.outputPreferredLocations[h[F]];if(ae==="string"){if(Be==="gpu-buffer")throw new Error("String tensor is not supported on GPU.");let te=[],re=K/4;for(let ue=0;ue<ge;ue++){let Ee=g.HEAPU32[re++],Se=ue===ge-1?void 0:g.HEAPU32[re]-Ee;te.push(g.UTF8ToString(Ee,Se))}me.push([ae,_e,te,"cpu"])}else if(Be==="gpu-buffer"&&ge>0){let te=g.jsepGetBuffer;if(!te)throw new Error(\'preferredLocation "gpu-buffer" is not supported without using WebGPU.\');let re=te(K),ue=Ut(Ue);if(ue===void 0||!Fr(ae))throw new Error(`Unsupported data type: ${ae}`);be=!0,me.push([ae,_e,{gpuBuffer:re,download:g.jsepCreateDownloader(re,ge*ue,ae),dispose:()=>{g._OrtReleaseTensor(ie)}},"gpu-buffer"])}else{let te=Cr(ae),re=new te(ge);new Uint8Array(re.buffer,re.byteOffset,re.byteLength).set(g.HEAPU8.subarray(K,K+re.byteLength)),me.push([ae,_e,re,"cpu"])}}finally{g.stackRestore(xe),ae==="string"&&K&&g._free(K),be||g._OrtReleaseTensor(ie)}}return A&&!I&&(g._OrtClearBoundOutputs(A.handle),Ye.set(i,[S,x,H,A,I,!1])),me}finally{g.stackRestore(pe),L.forEach(le=>g._OrtReleaseTensor(le)),W.forEach(le=>g._OrtReleaseTensor(le)),de.forEach(le=>g._free(le)),D!==0&&g._OrtReleaseRunOptions(D),T.forEach(le=>g._free(le))}},Wr=i=>{let c=Q(),a=Ye.get(i);if(!a)throw new Error("invalid session id");let h=a[0],f=c._OrtEndProfiling(h);f===0&&j("Can\'t get an profile file name."),c._OrtFree(f)},Nr=i=>{let c=[];for(let a of i){let h=a[2];!Array.isArray(h)&&"buffer"in h&&c.push(h.buffer)}return c};self.onmessage=i=>{let{type:c,in:a}=i.data;try{switch(c){case"init-wasm":Sr(a.wasm).then(()=>{Lr(a).then(()=>{postMessage({type:c})},h=>{postMessage({type:c,err:h})})},h=>{postMessage({type:c,err:h})});break;case"init-ep":{let{epName:h,env:f}=a;Rr(f,h).then(()=>{postMessage({type:c})},w=>{postMessage({type:c,err:w})});break}case"copy-from":{let{buffer:h}=a,f=Lt(h);postMessage({type:c,out:f});break}case"create":{let{model:h,options:f}=a;Ir(h,f).then(w=>{postMessage({type:c,out:w})},w=>{postMessage({type:c,err:w})});break}case"release":Br(a),postMessage({type:c});break;case"run":{let{sessionId:h,inputIndices:f,inputs:w,outputIndices:g,options:s}=a;kr(h,f,w,g,new Array(g.length).fill(null),s).then(S=>{S.some(x=>x[3]!=="cpu")?postMessage({type:c,err:"Proxy does not support non-cpu tensor location."}):postMessage({type:c,out:S},Nr([...w,...S]))},S=>{postMessage({type:c,err:S})});break}case"end-profiling":Wr(a),postMessage({type:c});break;default:}}catch(h){postMessage({type:c,err:h})}};})();\n'});var _r,gt,yn,Do,Lo,ca,pa,Vr,Wr,Tg,Eo,od,id,ad,sd,ud,ld,fd,da=L(()=>{"use strict";Ot();rd();Ur();_r=()=>!!Z.wasm.proxy&&typeof document<"u",yn=!1,Do=!1,Lo=!1,pa=new Map,Vr=(a,t)=>{let o=pa.get(a);o?o.push(t):pa.set(a,[t])},Wr=()=>{if(yn||!Do||Lo||!gt)throw new Error("worker not ready")},Tg=a=>{switch(a.data.type){case"init-wasm":yn=!1,a.data.err?(Lo=!0,ca[1](a.data.err)):(Do=!0,ca[0]());break;case"init-ep":case"copy-from":case"create":case"release":case"run":case"end-profiling":{let t=pa.get(a.data.type);a.data.err?t.shift()[1](a.data.err):t.shift()[0](a.data.out);break}default:}},Eo=typeof document<"u"?document?.currentScript?.src:void 0,od=async()=>{if(!Do){if(yn)throw new Error("multiple calls to 'initWasm()' detected.");if(Lo)throw new Error("previous call to 'initWasm()' failed.");if(yn=!0,_r())return Z.wasm.wasmPaths===void 0&&Eo&&Eo.indexOf("blob:")!==0&&(Z.wasm.wasmPaths=Eo.substr(0,+Eo.lastIndexOf("/")+1)),new Promise((a,t)=>{gt?.terminate();let o=URL.createObjectURL(new Blob([nd()],{type:"text/javascript"}));gt=new Worker(o,{name:"ort-wasm-proxy-worker"}),gt.onerror=r=>t(r),gt.onmessage=Tg,URL.revokeObjectURL(o),ca=[a,t];let e={type:"init-wasm",in:Z};gt.postMessage(e)});try{await Mp(Z.wasm),await Xp(Z),Do=!0}catch(a){throw Lo=!0,a}finally{yn=!1}}},id=async a=>{if(_r())return Wr(),new Promise((t,o)=>{Vr("init-ep",[t,o]);let e={type:"init-ep",in:{epName:a,env:Z}};gt.postMessage(e)});await Kp(Z,a)},ad=async a=>_r()?(Wr(),new Promise((t,o)=>{Vr("copy-from",[t,o]);let e={type:"copy-from",in:{buffer:a}};gt.postMessage(e,[a.buffer])})):fa(a),sd=async(a,t)=>{if(_r()){if(t?.preferredOutputLocation)throw new Error('session option "preferredOutputLocation" is not supported for proxy.');return Wr(),new Promise((o,e)=>{Vr("create",[o,e]);let r={type:"create",in:{model:a,options:{...t}}},n=[];a instanceof Uint8Array&&n.push(a.buffer),gt.postMessage(r,n)})}else return Jp(a,t)},ud=async a=>{if(_r())return Wr(),new Promise((t,o)=>{Vr("release",[t,o]);let e={type:"release",in:a};gt.postMessage(e)});Zp(a)},ld=async(a,t,o,e,r,n)=>{if(_r()){if(o.some(s=>s[3]!=="cpu"))throw new Error("input tensor on GPU is not supported for proxy.");if(r.some(s=>s))throw new Error("pre-allocated output tensor is not supported for proxy.");return Wr(),new Promise((s,i)=>{Vr("run",[s,i]);let u=o,l={type:"run",in:{sessionId:a,inputIndices:t,inputs:u,outputIndices:e,options:n}};gt.postMessage(l,td(u))})}else return Qp(a,t,o,e,r,n)},fd=async a=>{if(_r())return Wr(),new Promise((t,o)=>{Vr("end-profiling",[t,o]);let e={type:"end-profiling",in:a};gt.postMessage(e)});ed(a)}});var cd,xg,Co,pd=L(()=>{"use strict";Ot();da();ua();la();cd=(a,t)=>{switch(a.location){case"cpu":return[a.type,a.dims,a.data,"cpu"];case"gpu-buffer":return[a.type,a.dims,{gpuBuffer:a.gpuBuffer},"gpu-buffer"];default:throw new Error(`invalid data location: ${a.location} for ${t()}`)}},xg=a=>{switch(a[3]){case"cpu":return new Me(a[0],a[2],a[1]);case"gpu-buffer":{let t=a[0];if(!Po(t))throw new Error(`not supported data type: ${t} for deserializing GPU tensor`);let{gpuBuffer:o,download:e,dispose:r}=a[2];return Me.fromGpuBuffer(o,{dataType:t,dims:a[1],download:e,dispose:r})}default:throw new Error(`invalid data location: ${a[3]}`)}},Co=class{async fetchModelAndCopyToWasmMemory(t){return ad(await gn(t))}async loadModel(t,o){lr();let e;typeof t=="string"?typeof process<"u"&&process.versions&&process.versions.node?e=await gn(t):e=await this.fetchModelAndCopyToWasmMemory(t):e=t,[this.sessionId,this.inputNames,this.outputNames]=await sd(e,o),fr()}async dispose(){return ud(this.sessionId)}async run(t,o,e){lr();let r=[],n=[];Object.entries(t).forEach(d=>{let T=d[0],w=d[1],v=this.inputNames.indexOf(T);if(v===-1)throw new Error(`invalid input '${T}'`);r.push(w),n.push(v)});let s=[],i=[];Object.entries(o).forEach(d=>{let T=d[0],w=d[1],v=this.outputNames.indexOf(T);if(v===-1)throw new Error(`invalid output '${T}'`);s.push(w),i.push(v)});let u=r.map((d,T)=>cd(d,()=>`input "${this.inputNames[n[T]]}"`)),l=s.map((d,T)=>d?cd(d,()=>`output "${this.outputNames[i[T]]}"`):null),c=await ld(this.sessionId,n,u,i,l,e),p={};for(let d=0;d<c.length;d++)p[this.outputNames[i[d]]]=s[d]??xg(c[d]);return fr(),p}startProfiling(){}endProfiling(){fd(this.sessionId)}}});var wg,Fo,dd=L(()=>{"use strict";Ot();da();pd();wg=()=>{if((typeof Z.wasm.initTimeout!="number"||Z.wasm.initTimeout<0)&&(Z.wasm.initTimeout=0),typeof Z.wasm.simd!="boolean"&&(Z.wasm.simd=!0),typeof Z.wasm.proxy!="boolean"&&(Z.wasm.proxy=!1),typeof Z.wasm.trace!="boolean"&&(Z.wasm.trace=!1),typeof Z.wasm.numThreads!="number"||!Number.isInteger(Z.wasm.numThreads)||Z.wasm.numThreads<=0){(typeof self<"u"&&!self.crossOriginIsolated||typeof process<"u"&&process.versions&&process.versions.node)&&(Z.wasm.numThreads=1);let a=typeof navigator>"u"?(void 0)().length:navigator.hardwareConcurrency;Z.wasm.numThreads=Math.min(4,Math.ceil((a||1)/2))}},Fo=class{async init(t){wg(),await od(),await id(t)}async createInferenceSessionHandler(t,o){let e=new Co;return await e.loadModel(t,o),Promise.resolve(e)}}});var hd={};Sr(hd,{wasmBackend:()=>vg});var vg,md=L(()=>{"use strict";dd();vg=new Fo});Ot();Ot();Ot();var Ts="1.18.0";var jO=qo;{let a=(Op(),ar(_p)).onnxjsBackend;Pr("webgl",a,-10)}{let a=(md(),ar(hd)).wasmBackend;Pr("cpu",a,10),Pr("wasm",a,10)}Object.defineProperty(Z.versions,"web",{value:Ts,enumerable:!0});export{Pd as InferenceSession,ls as TRACE,lr as TRACE_FUNC_BEGIN,fr as TRACE_FUNC_END,Me as Tensor,Dd as TrainingSession,jO as default,Z as env,Pr as registerBackend};
/*! Bundled license information:

long/index.js:
  (**
   * @license
   * Copyright 2009 The Closure Library Authors
   * Copyright 2020 Daniel Wirtz / The long.js Authors.
   *
   * Licensed under the Apache License, Version 2.0 (the "License");
   * you may not use this file except in compliance with the License.
   * You may obtain a copy of the License at
   *
   *     http://www.apache.org/licenses/LICENSE-2.0
   *
   * Unless required by applicable law or agreed to in writing, software
   * distributed under the License is distributed on an "AS IS" BASIS,
   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   * See the License for the specific language governing permissions and
   * limitations under the License.
   *
   * SPDX-License-Identifier: Apache-2.0
   *)
*/
//# sourceMappingURL=ort.min.js.map
`);
+  const path = PATH_MAP[config.voiceId];
+  const input = JSON.stringify([{
+    text: config.text.trim()
+  }]);
+  const piperPhonemizeWasm = (await createBlobUrl(`${WASM_BASE}.wasm`)).url;
+  const piperPhonemizeData = (await createBlobUrl(`${WASM_BASE}.data`)).url;
+  ort.env.wasm.numThreads = navigator.hardwareConcurrency;
+  ort.env.wasm.wasmPaths = ONNX_BASE;
+  const modelConfigBlob = (await createBlobUrl(`${HF_BASE}/${path}.json`)).blob;
+  const modelConfig = JSON.parse(await modelConfigBlob.text());
+  const phonemeIds = await new Promise(async (resolve) => {
+    const module = await createPiperPhonemize({
+      print: (data) => {
+        resolve(JSON.parse(data).phoneme_ids);
+      }
+      ,
+      printErr: (message) => {
+        throw new Error(message);
+      }
+      ,
+      locateFile: (url) => {
+        if (url.endsWith(".wasm"))
+          return piperPhonemizeWasm;
+        if (url.endsWith(".data"))
+          return piperPhonemizeData;
+        return url;
+      }
+    });
+    module.callMain(["-l", modelConfig.espeak.voice, "--input", input, "--espeak_data", "/espeak-ng-data"]);
+  }
+  );
+  const sampleRate = modelConfig.audio.sample_rate;
+  const noiseScale = modelConfig.inference.noise_scale;
+  const lengthScale = modelConfig.inference.length_scale;
+  const noiseW = modelConfig.inference.noise_w;
+  const modelBlob = (await createBlobUrl(`${HF_BASE}/${path}`, callback)).url;
+  const session = await ort.InferenceSession.create(modelBlob);
+  const feeds = {
+    input: new ort.Tensor("int64",phonemeIds,[1, phonemeIds.length]),
+    input_lengths: new ort.Tensor("int64",[phonemeIds.length]),
+    scales: new ort.Tensor("float32",[noiseScale, lengthScale, noiseW])
+  };
+  if (Object.keys(modelConfig.speaker_id_map).length) {
+    Object.assign(feeds, {
+      sid: new ort.Tensor("int64",[0])
+    });
+  }
+  const {output: {data: pcm}} = await session.run(feeds);
+  return new Blob([pcm2wav(pcm, 1, sampleRate)],{
+    type: "audio/x-wav"
+  });
+}
+async function createBlobUrl(url, callback) {
+  let blob = await readBlob(url);
+  if (!blob) {
+    blob = await fetchBlob(url, callback);
+    await writeBlob(url, blob);
+  }
+  return {
+    url: URL.createObjectURL(blob),
+    blob
+  };
+}
+// export { predict as predict };
+async function download(voiceId, callback) {
+  const path = PATH_MAP[voiceId];
+  const urls = [`${HF_BASE}/${path}`, `${HF_BASE}/${path}.json`];
+  await Promise.all(urls.map(async (url) => {
+    writeBlob(url, await fetchBlob(url, url.endsWith('.onnx') ? callback : undefined));
+  }
+  ));
+}
+async function remove(voiceId) {
+  const path = PATH_MAP[voiceId];
+  const urls = [`${HF_BASE}/${path}`, `${HF_BASE}/${path}.json`];
+  await Promise.all(urls.map( (url) => removeBlob(url)));
+}
+async function stored() {
+  const root = await navigator.storage.getDirectory();
+  const dir = await root.getDirectoryHandle('piper', {
+    create: true
+  });
+  const result = [];
+  for await(const name of dir.keys()) {
+    const key = name.split('.')[0];
+    if (name.endsWith('.onnx') && key in PATH_MAP) {
+      result.push(key);
+    }
+  }
+  return result;
+}
+async function flush() {
+  try {
+    const root = await navigator.storage.getDirectory();
+    const dir = await root.getDirectoryHandle('piper');
+    await dir.remove({
+      recursive: true
+    });
+  } catch (e) {
+    console.error(e);
+  }
+}
+//export { download as download };
+//export { remove as remove };
+//export { stored as stored };
+//export { flush as flush };
+async function voices() {
+  const res = await fetch(`${HF_BASE}/voices.json`);
+  if (!res.ok) {
+    throw new Error('Could not retrieve voices file from huggingface');
+  }
+  return Object.values(await res.json());
+}
+//export { voices as voices };
+await download('en_US-hfc_female-medium', (progress) => {
+  console.log(`Downloading ${progress.url} - ${Math.round(progress.loaded * 100 / progress.total)}%`);
+}
+);
+
+var wav = await predict({
+  text: "Text to speech in the browser is amazing!",
+  voiceId: 'en_US-hfc_female-medium',
+});
+
+console.log(wav);
+
+var audio = new Audio(URL.createObjectURL(wav));
+
+audio.controls = true;
+audio.autoplay = true;
+
+document.body.appendChild(audio);