Repository: mgreminger/EngineeringPaper.xyz Branch: main Commit: 7d3bb8bcdf26 Files: 228 Total size: 19.7 MB Directory structure: gitextract_l2a2pt1h/ ├── .dev.vars ├── .gitattributes ├── .github/ │ ├── pull_request_template.md │ └── workflows/ │ └── playwright.yml ├── .gitignore ├── .node-version ├── CONTRIBUTING.md ├── LICENSE ├── README.md ├── index.html ├── notebooks/ │ ├── HA_parameters.csv │ ├── HA_parameters_order.csv │ ├── coolprop_options.ipynb │ ├── coolprop_predifined_mixtures.ipynb │ ├── latex_unicode_equivalents.ipynb │ ├── predefined_mixtures.json │ ├── propsSI_fluids.csv │ ├── propsSI_mixtures.csv │ ├── propsSI_parameters.csv │ ├── propsSI_parameters_order.csv │ ├── reserved_ids.ipynb │ ├── reserved_ids_no_sympy.ipynb │ └── sympy_test.ipynb ├── package.json ├── playwright.config.mjs ├── public/ │ ├── .well-known/ │ │ └── assetlinks.json │ ├── _routes.json │ ├── dimensional_analysis.py │ ├── iframe_test.html │ ├── jedi_code_analysis.py │ ├── manifest.json │ ├── pyodide/ │ │ ├── contourpy-1.3.1-cp313-cp313-pyodide_2025_0_wasm32.whl │ │ ├── coolprop-7.2.0-cp313-cp313-pyodide_2025_0_wasm32.whl │ │ ├── cycler-0.12.1-cp313-none-any.whl │ │ ├── drawsvg-2.4.1-cp313-none-any.whl │ │ ├── fonttools-4.56.0-cp313-none-any.whl │ │ ├── jedi-0.19.2-cp313-none-any.whl │ │ ├── jinja2-3.1.6-cp313-none-any.whl │ │ ├── joblib-1.4.2-cp313-none-any.whl │ │ ├── kiwisolver-1.4.8-cp313-cp313-pyodide_2025_0_wasm32.whl │ │ ├── markupsafe-3.0.2-cp313-cp313-pyodide_2025_0_wasm32.whl │ │ ├── matplotlib-3.8.4-cp313-cp313-pyodide_2025_0_wasm32.whl │ │ ├── mpmath-1.3.0-cp313-none-any.whl │ │ ├── nlopt-2.9.1-cp313-cp313-pyodide_2025_0_wasm32.whl │ │ ├── numpy-2.2.5-cp313-cp313-pyodide_2025_0_wasm32.whl │ │ ├── packaging-24.2-cp313-none-any.whl │ │ ├── pandas-2.3.3-cp313-cp313-pyodide_2025_0_wasm32.whl │ │ ├── parso-0.8.4-cp313-none-any.whl │ │ ├── pillow-11.3.0-cp313-cp313-pyodide_2025_0_wasm32.whl │ │ ├── pyodide-lock.json │ │ ├── pyodide.asm.js │ │ ├── pyodide.asm.wasm │ │ ├── pyodide.js │ │ ├── pyparsing-3.2.1-cp313-none-any.whl │ │ ├── python_dateutil-2.9.0.post0-cp313-none-any.whl │ │ ├── pytz-2025.2-cp313-none-any.whl │ │ ├── rich-13.9.4-cp313-none-any.whl │ │ ├── scikit_learn-1.7.0-cp313-cp313-pyodide_2025_0_wasm32.whl │ │ ├── scipy-1.14.1-cp313-cp313-pyodide_2025_0_wasm32.whl │ │ ├── six-1.17.0-cp313-none-any.whl │ │ ├── sympy-1.13.3-cp313-none-any.whl │ │ └── threadpoolctl-3.5.0-cp313-none-any.whl │ └── robots.txt ├── scripts/ │ ├── generate-parser.js │ ├── get_pyodide_files.py │ └── setupTypeScript.js ├── src/ │ ├── App.svelte │ ├── BaseUnitsConfigDialog.svelte │ ├── ButtonBar.svelte │ ├── Cell.svelte │ ├── CellList.svelte │ ├── CodeCell.svelte │ ├── CodeEditor.svelte │ ├── CustomMatrixModal.svelte │ ├── DataTableCell.svelte │ ├── DataTableInput.svelte │ ├── DeletedCell.svelte │ ├── DocumentTitle.svelte │ ├── DocumentationCell.svelte │ ├── DocumentationField.svelte │ ├── DownloadDocumentModal.svelte │ ├── DropOverlay.svelte │ ├── FluidCell.svelte │ ├── GenerateCodeDialog.svelte │ ├── IconButton.svelte │ ├── InsertCell.svelte │ ├── InsertSheetModal.svelte │ ├── KeyboardButton.svelte │ ├── KeyboardShortcuts.svelte │ ├── MathCell.svelte │ ├── MathCellConfigDialog.svelte │ ├── MathField.svelte │ ├── NumberFormatOptionsDialog.svelte │ ├── PiecewiseCell.svelte │ ├── Plot.svelte │ ├── PlotCell.svelte │ ├── RequestPersistentStorage.svelte │ ├── SetDefaultConfigDialog.svelte │ ├── SystemCell.svelte │ ├── TableCell.svelte │ ├── Terms.svelte │ ├── TextBox.svelte │ ├── TextButton.svelte │ ├── TextCheckbox.svelte │ ├── UnitsDocumentation.svelte │ ├── UpdateAvailable.svelte │ ├── Updates.svelte │ ├── VirtualKeyboard.svelte │ ├── carbon-theme.scss │ ├── cells/ │ │ ├── BaseCell.ts │ │ ├── Cells.ts │ │ ├── CodeCell.svelte.ts │ │ ├── DataTableCell.svelte.ts │ │ ├── DeletedCell.ts │ │ ├── DocumentationCell.svelte.ts │ │ ├── FluidCell.svelte.ts │ │ ├── InsertCell.ts │ │ ├── MathCell.svelte.ts │ │ ├── MathField.svelte.ts │ │ ├── PiecewiseCell.svelte.ts │ │ ├── PlotCell.svelte.ts │ │ ├── SystemCell.svelte.ts │ │ └── TableCell.svelte.ts │ ├── constants.ts │ ├── customPlotButtonIcons.ts │ ├── database/ │ │ ├── _worker.ts │ │ ├── scripts/ │ │ │ ├── initialize.sql │ │ │ ├── sheets_used_for_tests.json │ │ │ └── transfer_sheets.js │ │ ├── tsconfig.json │ │ ├── types.ts │ │ └── utility.ts │ ├── fluidConstants.ts │ ├── global.css │ ├── global.d.ts │ ├── jediWorker.ts │ ├── jediWrapper.ts │ ├── keyboard/ │ │ └── Keyboard.svelte.ts │ ├── main.js │ ├── parser/ │ │ ├── LatexIdFragments.g4 │ │ ├── LatexLexer.g4 │ │ ├── LatexLexer.ts │ │ ├── LatexParser.g4 │ │ ├── LatexParser.ts │ │ ├── LatexParserVisitor.ts │ │ ├── LatexToSympy.ts │ │ ├── constants.ts │ │ ├── parserWorker.ts │ │ ├── parserWrapper.ts │ │ ├── types.ts │ │ └── utility.ts │ ├── pyodide-info.json │ ├── pyodideWorker.ts │ ├── resultTypes.ts │ ├── sheet/ │ │ └── Sheet.ts │ ├── stores.svelte.ts │ ├── types.ts │ └── utility.ts ├── svelte.config.js ├── tests/ │ ├── seed-data.json │ ├── spreadsheets/ │ │ ├── bottle_data.csv │ │ ├── headers_and_units.csv │ │ ├── headers_and_units.xlsx │ │ ├── headers_no_units.xlsx │ │ ├── interpolation_autosort.csv │ │ ├── interpolation_repeated_input.csv │ │ ├── multivariable_interpolation_no_units.xlsx │ │ ├── multivariable_interpolation_units_large_scale.xlsx │ │ ├── multivariable_interpolation_units_small_scale.xlsx │ │ ├── no_headers.xlsx │ │ ├── plane_interpolation_no_units.csv │ │ ├── plane_interpolation_with_units_large_scale.csv │ │ ├── plane_interpolation_with_units_small_scale.csv │ │ └── polyfit_symbolic.xlsx │ ├── test_advanced_assignments.spec.mjs │ ├── test_advanced_var_names.spec.mjs │ ├── test_basic.spec.mjs │ ├── test_calc.spec.mjs │ ├── test_checkpoints.spec.mjs │ ├── test_code_cell.spec.mjs │ ├── test_code_cell_rendering.spec.mjs │ ├── test_complex.spec.mjs │ ├── test_context_menu.spec.mjs │ ├── test_csv_export_reference_data_table_format.csv │ ├── test_custom_base_units.spec.mjs │ ├── test_data_table.spec.mjs │ ├── test_database.spec.mjs │ ├── test_ep_custom_units.spec.mjs │ ├── test_file_save_open.spec.mjs │ ├── test_fluid_properties.spec.mjs │ ├── test_functions.spec.mjs │ ├── test_generated_code.spec.mjs │ ├── test_iframe.spec.mjs │ ├── test_insert_sheet.spec.mjs │ ├── test_keyboard_shortcuts.spec.mjs │ ├── test_latex_scientific_notation.spec.mjs │ ├── test_matrix_addition.spec.mjs │ ├── test_matrix_calc.spec.mjs │ ├── test_matrix_determinant.spec.mjs │ ├── test_matrix_functions.spec.mjs │ ├── test_matrix_indexing_and_assembling.spec.mjs │ ├── test_matrix_inverse.spec.mjs │ ├── test_matrix_keyboard.spec.mjs │ ├── test_matrix_multiplication.spec.mjs │ ├── test_matrix_transpose.spec.mjs │ ├── test_md_export.epxyz │ ├── test_md_export_reference.md │ ├── test_md_export_reference_centered.md │ ├── test_md_export_reference_data_table_format.md │ ├── test_number_format.spec.mjs │ ├── test_parse_id_bug.spec.mjs │ ├── test_piecewise_cell.spec.mjs │ ├── test_plotting.spec.mjs │ ├── test_sheet.epxyz │ ├── test_sheet_long_calculation.epxyz │ ├── test_sheet_parsing_error.epxyz │ ├── test_sheet_slow_simplify.epxyz │ ├── test_sheet_with_results.epxyz │ ├── test_sheet_with_wrong_result.epxyz │ ├── test_single_char_scripts.spec.mjs │ ├── test_sum_and_prod.spec.mjs │ ├── test_symbolic_expression_error_handling.spec.mjs │ ├── test_syntax_error_messages.spec.mjs │ ├── test_system_solve.spec.mjs │ ├── test_table_cell.spec.mjs │ └── utility.mjs ├── tsconfig.json └── vite.config.js ================================================ FILE CONTENTS ================================================ ================================================ FILE: .dev.vars ================================================ DOCGEN_API=http://127.0.0.1:8000 DEV=1 ================================================ FILE: .gitattributes ================================================ tests/** linguist-vendored public/pyodide/** linguist-vendored ================================================ FILE: .github/pull_request_template.md ================================================ ### Related Issue Read the [contributing guide](https://github.com/mgreminger/EngineeringPaper.xyz/blob/main/CONTRIBUTING.md#contributing) before submitting a pull request. Outside pull requests must be proceeded by creating a [GitHub issue](https://github.com/mgreminger/EngineeringPaper.xyz/issues) to discuss the proposed changes. Please indicate the issue number that this pull request relates to here: ### Description of Pull Request Describe your pull request here: ### DCO Signoff By creating this pull request, I agree that any code that I have submitted, or will submit, to this pull request, satisfies this [Developer Certificate of Origin](https://developercertificate.org/). Additionally, all other contributers to this pull request implicitly agree that their contributions satisfy the [Developer Certificate of Origin](https://developercertificate.org/) by the act of contributing to this pull request. ================================================ FILE: .github/workflows/playwright.yml ================================================ name: Playwright Tests on: push: branches: [ main, master ] pull_request: branches: [ main, master ] jobs: test: timeout-minutes: 60 runs-on: ubuntu-24.04 strategy: fail-fast: false matrix: shardIndex: [1, 2, 3, 4] shardTotal: [4] steps: - uses: actions/checkout@v3 - uses: actions/setup-node@v3 with: node-version: '22.x' cache: 'npm' - name: Install dependencies run: npm ci - name: Build site run: npm run build - name: Seed KV Stores run: npm run test:seed - name: Install Playwright run: npx playwright install chromium firefox --with-deps - name: Run Playwright tests run: npm run test -- --shard=${{ matrix.shardIndex }}/${{ matrix.shardTotal }} --reporter=blob - uses: actions/upload-artifact@v4 if: always() with: name: screenshots-${{ matrix.shardIndex }} path: tests/images/*.png retention-days: 10 - uses: actions/upload-artifact@v4 if: always() with: name: blob-report-${{ matrix.shardIndex }} path: blob-report/ retention-days: 5 merge-reports: if: always() needs: [test] runs-on: ubuntu-24.04 steps: - uses: actions/checkout@v3 - uses: actions/setup-node@v3 with: node-version: '22.x' cache: 'npm' - name: Install dependencies run: npm ci # --- SCREENSHOT MERGING --- - name: Download all screenshots uses: actions/download-artifact@v4 with: pattern: screenshots-* path: combined-screenshots merge-multiple: true - name: Upload unified screenshots artifact uses: actions/upload-artifact@v4 with: name: all-screenshots path: combined-screenshots retention-days: 10 # --- HTML REPORT MERGING --- - name: Download all blob reports uses: actions/download-artifact@v4 with: pattern: blob-report-* path: all-blob-reports merge-multiple: true # Playwright compiles the blobs into a unified HTML report - name: Merge into HTML Report run: npx playwright merge-reports --reporter=html ./all-blob-reports - name: Upload unified HTML report uses: actions/upload-artifact@v4 if: always() with: name: playwright-report path: playwright-report/ retention-days: 10 ================================================ FILE: .gitignore ================================================ .DS_store node_modules public/build public/fonts .antlr *.tokens *.interp .ipynb_checkpoints dist .vscode/settings.json tests/images/*screenshot*.png tests/images/*_diff.png test-results/ playwright-report/ public/_worker.js src/database/_worker.js src/database/utility.js .wrangler/ public/parser/parserWorker.js public/pyodideWorker.js public/jediWorker.js wrangler.toml public/serviceworker.js public/serviceworker.js.map *.csv# ================================================ FILE: .node-version ================================================ 22 ================================================ FILE: CONTRIBUTING.md ================================================ ## Get the Word Out The easiest way to contribute to EngineeringPaper.xyz is to get the word out. A large and vibrant user community are critical to justify continued efforts to develop this open source software. The easiest ways to contribute are to like and subscribe to the official [YouTube channel](https://www.youtube.com/channel/UCaFxwEznNUfJagZ1Xi6Rh2A), participate in the official [Reddit Community](https://www.reddit.com/r/EngineeringPaperXYZ/), or rate the app in the [Windows store](https://apps.microsoft.com/store/detail/engineeringpaperxyz/9N1W74WC2X2M). User generated tutorials or videos are also welcome. ## Reporting Bugs or Requesting Features To report issues or bugs, or to request new features, file a [GitHub issue](https://github.com/mgreminger/EngineeringPaper.xyz/issues) or use the [official EngineeringPaper.xyz subreddit](https://www.reddit.com/r/EngineeringPaperXYZ/). If you prefer email, bugs or feature requests can be submitted to [support@EngineeringpPaper.xyz](mailto:support@engineeringpaper.xyz). ## Contributing Since the [live EngineeringPaper.xyz](https://engineeringpaper.xyz) site is deployed from this repository's main branch, careful consideration is required before adding new features. Becuase of this, a [GitHub issue](https://github.com/mgreminger/EngineeringPaper.xyz/issues) must be created to discuss a potential new feature before an external pull request will be considered. Keep the following in mind when considering the implementation of new features: * All features must work in Chrome, Safari, and Firefox * All features must be usable on both desktop and mobile * All features must format properly when printing a sheet using the browser's file print command * All existing tests must pass (sometimes updates to old tests will be needed, depending on the feature) and any new features will most likely need new tests * Ease of use and robustness of EngineeringPaper.xyz are top priorities, any new feature that makes EngineeringPaper.xyz more complicated to use will require careful consideration and may not be accepted * It must always be possible to read old sheets created in previous versions of EngineeringPaper.xyz (on rare occasions, users may need to update their sheets but there can be no data loss) * New features that require large javascript dependencies will most likely not be accepted (EngineeringPaper.xyz is already large because of its dependency on Pyodide, every effort will be made to limit bundle size growth) Because of the limitations inherent to a repository tied to a running site, you may want to consider hosting your own fork of EngineeringPaper.xyz if you want to run experimental features that are not accepted to the main EngineeringPaper.xyz repository. EngineeringPaper.xyz can be easily deployed as a Coudflare Pages project (including the database back-end through the Pages Functions capability). It can be deployed using Cloudflare's free tier. Any contributors to this repository must confirm that their contributions satisfy the [Developer Certificate of Origin](https://developercertificate.org/). ## Setting up a Development Environment See these instructions covering [setting up an EngineeringPaper.xyz development environment](https://github.com/mgreminger/EngineeringPaper.xyz#build-instructions). ================================================ FILE: LICENSE ================================================ Copyright 2020-25 Michael Greminger Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ================================================ FILE: README.md ================================================ # [![EngineeringPaper.xyz](https://user-images.githubusercontent.com/6439649/212795699-7cc908e1-00a4-44ed-a034-695f056ee84a.png)](https://engineeringpaper.xyz) EngineeringPaper.xyz is a web app for engineering calculations that handles unit conversion/checking automatically and also supports plotting, solving systems of equations, and documenting your calculations (see the [official blog](https://blog.engineeringpaper.xyz) for many examples). It's easy to share your calculations by creating a [shareable link](https://engineeringpaper.xyz/oMbWLXMZ6ChQ3g3ZxRbJQD) that anyone can open and build off of. Additionaly, you can save and open your files locally if you prefer not to save to the cloud. EngineeringPaper.xyz runs on Mac, Windows, Linux, and ChromeOS and works on all of the major browsers. Additionally, EngineeringPaper.xyz is designed to run well on Android and iOS devices. [Launch EngineeringPaper.xyz](https://EngineeringPaper.xyz) in your browser to try it out. ![platforms_cropped](https://user-images.githubusercontent.com/6439649/212774749-caab6190-7a45-4f04-a31c-ffdb6b6e4b96.png) All calculations are run on your own device using the [Pyodide project](https://pyodide.org) to run Python in your browser. The [SymPy](https://www.sympy.org) Python symbolic math library is used to handle all calculations. Microsoft Store Link for EngineeringPaper.xyz App [![join_reddit_banner](https://github.com/mgreminger/EngineeringPaper.xyz/assets/6439649/311af86c-b358-47d4-9995-329e7e973d2e)](https://www.reddit.com/r/EngineeringPaperXYZ/) ## Learning to Use EngineeringPaper.yxz There are many ways to learn EngineeringPaper.xyz. The built-in [editable tutorial](https://engineeringpaper.xyz/CUsUSuwHkHzNyButyCHEng) or this [tutorial video](https://youtu.be/r7EZQVhcr5Q) are good places to start. For other resources, including many video tutorials and example sheets, see the [learning EngineeringPaper.xyz](https://blog.engineeringpaper.xyz/engineeringpaperxyz-tutorial) blog post. To get your questions answered, or to share calculations you have created using EngineeringPaper.xyz, join the official [EngineeringPaper.xyz subreddit](https://www.reddit.com/r/EngineeringPaperXYZ/). ## Dependencies EngineeringPaper.xyz would not be possible without the many powerful open source projects that it depends on. Here's a partial list of the projects that EngineeringPaper.xyz builds off of: * [Pyodide](https://pyodide.org), puts all of the power of Python in your browser using WebAssembly * [SymPy](https://www.sympy.org), Python symbolic math library (this is the core computation engine for EngineeringPaper.xyz) * [CoolProp](http://www.coolprop.org/), for thermodynamic fluid properties * [MathLive](https://cortexjs.io/mathlive/), math editor component * [Plotly](https://plotly.com/), used for plotting * [Quill Editor](https://quilljs.com/), rich text editor used for documentation cells * [Svelte](https://svelte.dev/), the javascript front-end framework that EngineeringPaper.xyz is based on * [Math.js](https://mathjs.org/), used for unit parsing * [ANTLR](https://www.antlr.org/), parser generator used to parse the math cells ## Build Instructions These instructions are only needed to create a development environment for EngineeringPaper.xyz. To run the app, simply go to [EngineeringPaper.xyz](https://engineeringpaper.xyz). See the [contributing guide](https://github.com/mgreminger/EngineeringPaper.xyz/blob/main/CONTRIBUTING.md#contributing) for information on making contributions to EngineeringPaper.xyz. [Node.js](https://nodejs.org) is used for EngineeringPaper.xyz development. If you don't already have node installed, the easiest way to get it installed is to use the [Volta](https://volta.sh/) node installer. Node version 20 or newer is required. First, [fork and clone](https://docs.github.com/en/get-started/quickstart/fork-a-repo) this repository. Then, in the cloned project folder, use the following commands to start a local dev server (commands tested on Linux, MacOS, and on Windows using WSL2): ``` bash # Install dependencies npm install # Run local dev server with live reload (point browser to localhost:8788) npm run dev ``` To build the production version of the site and run the test suite, run the following commands (if the dev server is still running after running the above commands, close it using Ctrl-C before running these commands). Note that after running `npm run build`, the contents of the `public` folder can be hosted as a static site on a web server. ``` bash # Build the production version of the site npm run build # run local server npm run preview # Install playwright browsers (only needs to be done once each time browsers need to be updated) # Additional installation of dependencies may be required, follow instructions npx playwright install # Setup local database needed for test suite npm run test:seed # Run test suite npm run test ``` ================================================ FILE: index.html ================================================ EngineeringPaper.xyz ================================================ FILE: notebooks/HA_parameters.csv ================================================ haParameter,idName,units,input,output,description C,C,J/kg/K,FALSE,TRUE,Mixture specific heat per unit dry air H,H,J/kg,TRUE,TRUE,Mixture enthalpy per mass dry air P,P,Pa,TRUE,FALSE,Pressure R,Rh,,TRUE,TRUE,"Relative humidity in [0, 1]" S,S,J/kg/K,TRUE,TRUE,Mixture entropy per mass dry air T,T,K,TRUE,TRUE,Dry-Bulb Temperature Tdp,Tdp,K,TRUE,TRUE,Dew-Point Temperature B,Twb,K,TRUE,TRUE,Wet-Bulb Temperature Visc,V,Pa*s,FALSE,TRUE,Mixture viscosity Vda,Vda,m^3/kg,TRUE,TRUE,Mixture volume per mass dry air W,W,,TRUE,TRUE,Humidity Ratio (kg water/kg dry air) Cha,Cha,J/kg/K,FALSE,TRUE,Mixture specific heat per unit humid air CV,Cv,J/kg/K,FALSE,TRUE,Mixture specific heat at constant volume per unit dry air Cvha,Cvha,J/kg/K,FALSE,TRUE,Mixture specific heat at constant volume per unit humid air Hha,Hha,J/kg,TRUE,TRUE,Mixture enthalpy per mass humid air K,K,W/m/K,FALSE,TRUE,Mixture thermal conductivity P_w,Pw,Pa,TRUE,TRUE,Partial pressure of water vapor Sha,Sha,J/kg/K,TRUE,TRUE,Mixture entropy per mass humid air Vha,Vha,m^3/kg,TRUE,TRUE,Mixture volume per mass humid air psi_w,Y,,TRUE,TRUE,Water mole fraction (mol water/mol humid air) Z,Z,,TRUE,FALSE,Compressibility factor (Z=pv/(RT)) ================================================ FILE: notebooks/HA_parameters_order.csv ================================================ C,Quick Access H,Quick Access P,Quick Access R,Quick Access S,Quick Access T,Quick Access Tdp,Quick Access B,Quick Access Visc,Quick Access Vda,Quick Access W,Quick Access C,All Cha,All CV,All Cvha,All H,All Hha,All K,All P,All P_w,All R,All S,All Sha,All T,All Tdp,All B,All Visc,All Vda,All Vha,All W,All psi_w,All Z,All ================================================ FILE: notebooks/coolprop_options.ipynb ================================================ { "cells": [ { "cell_type": "code", "execution_count": 1, "id": "0a4de3ff", "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "7.2.0\n" ] } ], "source": [ "import csv\n", "\n", "from CoolProp.CoolProp import get_global_param_string, FluidsList, get_phase_index\n", "from CoolProp import __version__\n", "\n", "print(__version__)" ] }, { "cell_type": "code", "execution_count": 2, "id": "5e466ee8", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "['Isopentane',\n", " 'Neon',\n", " 'Fluorine',\n", " 'R11',\n", " 'R125',\n", " 'cis-2-Butene',\n", " 'R13I1',\n", " 'trans-2-Butene',\n", " 'Ethylene',\n", " 'Acetone',\n", " 'MethylPalmitate',\n", " 'DimethylEther',\n", " 'R152A',\n", " 'Hydrogen',\n", " 'ParaHydrogen',\n", " 'R22',\n", " 'CycloHexane',\n", " 'R1233zd(E)',\n", " 'Isohexane',\n", " 'R236EA',\n", " 'CarbonMonoxide',\n", " 'R12',\n", " 'SES36',\n", " 'MD3M',\n", " 'Dichloroethane',\n", " 'Argon',\n", " 'R115',\n", " 'm-Xylene',\n", " 'n-Nonane',\n", " 'R13',\n", " 'R14',\n", " 'R114',\n", " 'n-Propane',\n", " 'n-Dodecane',\n", " 'n-Decane',\n", " 'MethylStearate',\n", " 'R410A',\n", " 'R236FA',\n", " 'n-Undecane',\n", " 'Xenon',\n", " 'R113',\n", " 'n-Butane',\n", " 'HeavyWater',\n", " 'Toluene',\n", " 'RC318',\n", " 'EthyleneOxide',\n", " 'Helium',\n", " 'n-Heptane',\n", " 'R1243zf',\n", " 'Ammonia',\n", " 'CycloPropane',\n", " 'MD4M',\n", " 'Water',\n", " 'R218',\n", " 'D6',\n", " 'R142b',\n", " 'MDM',\n", " 'CarbonylSulfide',\n", " 'HFE143m',\n", " 'MethylOleate',\n", " 'ParaDeuterium',\n", " 'Ethanol',\n", " 'R134a',\n", " 'Oxygen',\n", " 'HydrogenSulfide',\n", " 'o-Xylene',\n", " 'Nitrogen',\n", " 'HydrogenChloride',\n", " 'R1234yf',\n", " 'CarbonDioxide',\n", " 'DimethylCarbonate',\n", " 'R1234ze(E)',\n", " 'R507A',\n", " 'MethylLinolenate',\n", " 'Propylene',\n", " 'R41',\n", " 'OrthoHydrogen',\n", " 'Novec649',\n", " 'R404A',\n", " 'Methanol',\n", " 'Krypton',\n", " 'D5',\n", " 'R407C',\n", " 'D4',\n", " 'R245ca',\n", " 'R32',\n", " 'R161',\n", " 'MD2M',\n", " 'R21',\n", " 'NitrousOxide',\n", " 'n-Hexane',\n", " 'R123',\n", " 'OrthoDeuterium',\n", " 'Methane',\n", " 'n-Octane',\n", " 'Cyclopentane',\n", " 'SulfurDioxide',\n", " 'R143a',\n", " '1-Butene',\n", " 'R116',\n", " 'IsoButane',\n", " 'R23',\n", " 'MethylLinoleate',\n", " 'R365MFC',\n", " 'Benzene',\n", " 'Deuterium',\n", " 'R227EA',\n", " 'IsoButene',\n", " 'DiethylEther',\n", " 'R245fa',\n", " 'R1336mzz(E)',\n", " 'R1234ze(Z)',\n", " 'n-Pentane',\n", " 'Propyne',\n", " 'Ethane',\n", " 'R124',\n", " 'Air',\n", " 'Neopentane',\n", " 'R141b',\n", " 'EthylBenzene',\n", " 'MM',\n", " 'p-Xylene',\n", " 'SulfurHexafluoride',\n", " 'R40']" ] }, "execution_count": 2, "metadata": {}, "output_type": "execute_result" } ], "source": [ "FluidsList()" ] }, { "cell_type": "code", "execution_count": 3, "id": "4399f245", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "124" ] }, "execution_count": 3, "metadata": {}, "output_type": "execute_result" } ], "source": [ "len(FluidsList())" ] }, { "cell_type": "markdown", "id": "1b6a1f5d", "metadata": {}, "source": [ "[Phase Index Definitions](https://github.com/CoolProp/CoolProp/blob/f6eb03742f9430f8dbf9e5a950b2d914b9edc0d1/include/DataStructures.h#L176)" ] }, { "cell_type": "code", "execution_count": 4, "id": "19d04e16", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "8" ] }, "execution_count": 4, "metadata": {}, "output_type": "execute_result" } ], "source": [ "get_phase_index(\"phase_not_imposed\")" ] }, { "cell_type": "code", "execution_count": 5, "id": "5129a61a", "metadata": {}, "outputs": [], "source": [ "bool_dict = {\"True\": \"true\", \"TRUE\": \"true\", \"FALSE\": \"false\", \"False\": \"false\", \"null\": \"null\"}\n", "\n", "file_name = '../src/fluidConstants.ts'\n", "\n", "with open(file_name, 'w') as f:\n", "\n", " f.write(\"export const FLUID_PROPS_PARAMETERS = new Map([\\n\")\n", " with open('propsSI_parameters.csv') as csvfile:\n", " reader = csv.reader(csvfile)\n", " for i,row in enumerate(reader):\n", " if i == 0:\n", " header = row\n", " else:\n", " f.write(\" [\\n\")\n", " f.write(f' \"{row[0]}\",\\n')\n", " f.write(\" {\\n\")\n", " for j,name in enumerate(header):\n", " if j >= 1:\n", " value = row[j]\n", " if value in bool_dict:\n", " f.write(f' {name}: {bool_dict[value]},\\n')\n", " else:\n", " f.write(f' {name}: \"{value}\",\\n')\n", "\n", " f.write(\" }\\n\")\n", " f.write(\" ],\\n\")\n", " f.write(\"]);\\n\\n\\n\")\n", " \n", " f.write(\"export const FLUID_PROPS_PARAMETERS_ORDER = [\\n\")\n", " with open('propsSI_parameters_order.csv') as csvfile:\n", " reader = csv.reader(csvfile)\n", " for row in reader:\n", " row_values = '\"' + '\", \"'.join(row) + '\"'\n", " f.write(f\" [{row_values}],\\n\")\n", " \n", " f.write(\" ];\\n\\n\\n\")\n", " \n", " " ] }, { "cell_type": "code", "execution_count": 6, "id": "17ad8ae6", "metadata": { "scrolled": true }, "outputs": [], "source": [ "with open(file_name, 'a') as f:\n", " f.write(\"export const FLUIDS = new Map([\\n\")\n", " with open('propsSI_fluids.csv') as csvfile:\n", " reader = csv.reader(csvfile)\n", " for i,row in enumerate(reader):\n", " if i == 0:\n", " header = row\n", " else:\n", " f.write(\" [\\n\")\n", " f.write(f' \"{row[0]}\",\\n')\n", " f.write(\" {\\n\")\n", " for j,name in enumerate(header):\n", " if j >= 1:\n", " value = row[j]\n", " if value in bool_dict:\n", " f.write(f' {name}: {bool_dict[value]},\\n')\n", " elif name in ('minConcentration', 'maxConcentration'):\n", " f.write(f' {name}: {value},\\n')\n", " else:\n", " f.write(f' {name}: \"{value}\",\\n')\n", "\n", " f.write(\" }\\n\")\n", " f.write(\" ],\\n\")\n", " f.write(\"]);\\n\\n\\n\")" ] }, { "cell_type": "code", "execution_count": 7, "id": "900b5b7e", "metadata": {}, "outputs": [], "source": [ "with open(file_name, 'a') as f:\n", " f.write(\"export const FLUID_HA_PROPS_PARAMETERS = new Map([\\n\")\n", " with open('HA_parameters.csv') as csvfile:\n", " reader = csv.reader(csvfile)\n", " for i,row in enumerate(reader):\n", " if i == 0:\n", " header = row\n", " else:\n", " f.write(\" [\\n\")\n", " f.write(f' \"{row[0]}\",\\n')\n", " f.write(\" {\\n\")\n", " for j,name in enumerate(header):\n", " if j >= 1:\n", " value = row[j]\n", " if value in bool_dict:\n", " f.write(f' {name}: {bool_dict[value]},\\n')\n", " else:\n", " f.write(f' {name}: \"{value}\",\\n')\n", "\n", " f.write(\" }\\n\")\n", " f.write(\" ],\\n\")\n", " f.write(\"]);\\n\")\n", " \n", " f.write(\"export const FLUID_HA_PROPS_PARAMETERS_ORDER = [\\n\")\n", " with open('HA_parameters_order.csv') as csvfile:\n", " reader = csv.reader(csvfile)\n", " for row in reader:\n", " row_values = '\"' + '\", \"'.join(row) + '\"'\n", " f.write(f\" [{row_values}],\\n\")\n", " \n", " f.write(\" ];\\n\\n\\n\")" ] } ], "metadata": { "kernelspec": { "display_name": "Python 3 (ipykernel)", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.12.7" } }, "nbformat": 4, "nbformat_minor": 5 } ================================================ FILE: notebooks/coolprop_predifined_mixtures.ipynb ================================================ { "cells": [ { "cell_type": "code", "execution_count": 1, "id": "f2cf27a2", "metadata": {}, "outputs": [], "source": [ "import json\n", "import csv" ] }, { "cell_type": "code", "execution_count": 2, "id": "859eed4a", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "[{'fluids': ['NITROGEN', 'ARGON', 'OXYGEN'],\n", " 'mole_fractions': [0.7812, 0.0092, 0.2096],\n", " 'name': 'Air'},\n", " {'fluids': ['METHANE',\n", " 'NITROGEN',\n", " 'CO2',\n", " 'ETHANE',\n", " 'PROPANE',\n", " 'ISOBUTAN',\n", " 'BUTANE',\n", " 'IPENTANE',\n", " 'PENTANE',\n", " 'HEXANE'],\n", " 'mole_fractions': [0.906724,\n", " 0.031284,\n", " 0.004676,\n", " 0.045279,\n", " 0.00828,\n", " 0.001037,\n", " 0.001563,\n", " 0.000321,\n", " 0.000443,\n", " 0.000393],\n", " 'name': 'Amarillo'},\n", " {'fluids': ['METHANE',\n", " 'NITROGEN',\n", " 'CO2',\n", " 'ETHANE',\n", " 'PROPANE',\n", " 'ISOBUTAN',\n", " 'BUTANE',\n", " 'IPENTANE',\n", " 'PENTANE'],\n", " 'mole_fractions': [0.859063,\n", " 0.010068,\n", " 0.014954,\n", " 0.084919,\n", " 0.023015,\n", " 0.003486,\n", " 0.003506,\n", " 0.000509,\n", " 0.00048],\n", " 'name': 'Ekofisk'},\n", " {'fluids': ['METHANE',\n", " 'NITROGEN',\n", " 'CO2',\n", " 'ETHANE',\n", " 'PROPANE',\n", " 'ISOBUTAN',\n", " 'BUTANE',\n", " 'IPENTANE',\n", " 'PENTANE',\n", " 'HEXANE'],\n", " 'mole_fractions': [0.965222,\n", " 0.002595,\n", " 0.005956,\n", " 0.018186,\n", " 0.004596,\n", " 0.000977,\n", " 0.001007,\n", " 0.000473,\n", " 0.000324,\n", " 0.000664],\n", " 'name': 'GulfCoast'},\n", " {'fluids': ['METHANE',\n", " 'NITROGEN',\n", " 'CO2',\n", " 'ETHANE',\n", " 'PROPANE',\n", " 'ISOBUTAN',\n", " 'BUTANE'],\n", " 'mole_fractions': [0.81212,\n", " 0.05702,\n", " 0.07585,\n", " 0.04303,\n", " 0.00895,\n", " 0.00151,\n", " 0.00152],\n", " 'name': 'HighCO2'},\n", " {'fluids': ['METHANE',\n", " 'NITROGEN',\n", " 'CO2',\n", " 'ETHANE',\n", " 'PROPANE',\n", " 'ISOBUTAN',\n", " 'BUTANE'],\n", " 'mole_fractions': [0.81441,\n", " 0.13465,\n", " 0.00985,\n", " 0.033,\n", " 0.00605,\n", " 0.001,\n", " 0.00104],\n", " 'name': 'HighN2'},\n", " {'fluids': ['METHANE',\n", " 'NITROGEN',\n", " 'CO2',\n", " 'ETHANE',\n", " 'PROPANE',\n", " 'ISOBUTAN',\n", " 'BUTANE',\n", " 'IPENTANE',\n", " 'PENTANE',\n", " 'HEXANE'],\n", " 'mole_fractions': [0.95123,\n", " 0.00089,\n", " 0.02555,\n", " 0.01835,\n", " 0.00238,\n", " 0.0004,\n", " 0.00016,\n", " 0.00014,\n", " 0.00011,\n", " 0.00079],\n", " 'name': 'NaturalGasSample'},\n", " {'fluids': ['R22', 'R152A', 'R124'],\n", " 'mole_fractions': [0.578854210704231, 0.185871453986601, 0.235274335309169],\n", " 'name': 'R401A'},\n", " {'fluids': ['R22', 'R152A', 'R124'],\n", " 'mole_fractions': [0.654924685341436, 0.154607382276918, 0.190467932381646],\n", " 'name': 'R401B'},\n", " {'fluids': ['R22', 'R152A', 'R124'],\n", " 'mole_fractions': [0.385591186504412, 0.229445970225924, 0.384962843269664],\n", " 'name': 'R401C'},\n", " {'fluids': ['R125', 'PROPANE', 'R22'],\n", " 'mole_fractions': [0.507659889396724, 0.0460590346231213, 0.446281075980154],\n", " 'name': 'R402A'},\n", " {'fluids': ['R125', 'PROPANE', 'R22'],\n", " 'mole_fractions': [0.299858744498276, 0.0429562491180057, 0.657185006383719],\n", " 'name': 'R402B'},\n", " {'fluids': ['PROPANE', 'R22', 'R218'],\n", " 'mole_fractions': [0.104301635230068, 0.797852142841926, 0.0978462219280052],\n", " 'name': 'R403A'},\n", " {'fluids': ['PROPANE', 'R22', 'R218'],\n", " 'mole_fractions': [0.117083478399255, 0.668734422027154, 0.214182099573591],\n", " 'name': 'R403B'},\n", " {'fluids': ['R125', 'R134A', 'R143A'],\n", " 'mole_fractions': [0.357816784026318, 0.0382639950410712, 0.603919220932611],\n", " 'name': 'R404A'},\n", " {'fluids': ['R22', 'R152A', 'R142B', 'RC318'],\n", " 'mole_fractions': [0.582397185883849,\n", " 0.118598940913682,\n", " 0.0612463586573,\n", " 0.237757514545169],\n", " 'name': 'R405A'},\n", " {'fluids': ['R22', 'ISOBUTAN', 'R142B'],\n", " 'mole_fractions': [0.571559096367276, 0.0618403319459979, 0.366600571686726],\n", " 'name': 'R406A'},\n", " {'fluids': ['R32', 'R125', 'R134A'],\n", " 'mole_fractions': [0.346419854360797, 0.300315552114308, 0.353264593524896],\n", " 'name': 'R407A'},\n", " {'fluids': ['R32', 'R125', 'R134A'],\n", " 'mole_fractions': [0.197865007175653, 0.600360468492644, 0.201774524331703],\n", " 'name': 'R407B'},\n", " {'fluids': ['R32', 'R125', 'R134A'],\n", " 'mole_fractions': [0.381109419953993, 0.179558888662016, 0.439331691383991],\n", " 'name': 'R407C'},\n", " {'fluids': ['R32', 'R125', 'R134A'],\n", " 'mole_fractions': [0.262268077791873, 0.113681680758968, 0.624050241449159],\n", " 'name': 'R407D'},\n", " {'fluids': ['R32', 'R125', 'R134A'],\n", " 'mole_fractions': [0.402611526984881, 0.104708637358978, 0.492679835656141],\n", " 'name': 'R407E'},\n", " {'fluids': ['R32', 'R125', 'R134A'],\n", " 'mole_fractions': [0.473194694453358, 0.205109095413331, 0.321696210133311],\n", " 'name': 'R407F'},\n", " {'fluids': ['R125', 'R143A', 'R22'],\n", " 'mole_fractions': [0.0507496395780536, 0.476277681499092, 0.472972678922854],\n", " 'name': 'R408A'},\n", " {'fluids': ['R22', 'R124', 'R142B'],\n", " 'mole_fractions': [0.676088021274302, 0.178481953421098, 0.1454300253046],\n", " 'name': 'R409A'},\n", " {'fluids': ['R22', 'R124', 'R142B'],\n", " 'mole_fractions': [0.726713817097545, 0.177089324155708, 0.0961968587467468],\n", " 'name': 'R409B'},\n", " {'fluids': ['R32', 'R125'],\n", " 'mole_fractions': [0.697614699375863, 0.302385300624138],\n", " 'name': 'R410A'},\n", " {'fluids': ['R32', 'R125'],\n", " 'mole_fractions': [0.653688938033229, 0.346311061966771],\n", " 'name': 'R410B'},\n", " {'fluids': ['PROPYLEN', 'R22', 'R152A'],\n", " 'mole_fractions': [0.0293595987641706, 0.833472654512905, 0.137167746722925],\n", " 'name': 'R411A'},\n", " {'fluids': ['PROPYLEN', 'R22', 'R152A'],\n", " 'mole_fractions': [0.0592216130255444,\n", " 0.903048917855743,\n", " 0.0377294691187131],\n", " 'name': 'R411B'},\n", " {'fluids': ['R22', 'R218', 'R142B'],\n", " 'mole_fractions': [0.746189416536491, 0.0245117299030133, 0.229298853560496],\n", " 'name': 'R412A'},\n", " {'fluids': ['R218', 'R134A', 'ISOBUTAN'],\n", " 'mole_fractions': [0.0497604388838132,\n", " 0.896582929746185,\n", " 0.0536566313700015],\n", " 'name': 'R413A'},\n", " {'fluids': ['R22', 'R124', 'ISOBUTAN', 'R142B'],\n", " 'mole_fractions': [0.571718248653786,\n", " 0.202422623615037,\n", " 0.0667091242374272,\n", " 0.159150003493749],\n", " 'name': 'R414A'},\n", " {'fluids': ['R22', 'R124', 'ISOBUTAN', 'R142B'],\n", " 'mole_fractions': [0.58743911052603,\n", " 0.29030851296569,\n", " 0.0262178745861124,\n", " 0.0960345019221677],\n", " 'name': 'R414B'},\n", " {'fluids': ['R22', 'R152A'],\n", " 'mole_fractions': [0.776780159383737, 0.223219840616263],\n", " 'name': 'R415A'},\n", " {'fluids': ['R22', 'R152A'],\n", " 'mole_fractions': [0.202949716550675, 0.797050283449325],\n", " 'name': 'R415B'},\n", " {'fluids': ['R134A', 'R124', 'BUTANE'],\n", " 'mole_fractions': [0.647182715864291, 0.323933072881677, 0.0288842112540324],\n", " 'name': 'R416A'},\n", " {'fluids': ['R125', 'R134A', 'BUTANE'],\n", " 'mole_fractions': [0.414456113615123, 0.523100248809492, 0.0624436375753851],\n", " 'name': 'R417A'},\n", " {'fluids': ['PROPANE', 'R22', 'R152A'],\n", " 'mole_fractions': [0.0287766462758765,\n", " 0.939204558675462,\n", " 0.0320187950486611],\n", " 'name': 'R418A'},\n", " {'fluids': ['R125', 'R134A', 'DME'],\n", " 'mole_fractions': [0.701459965531065, 0.203604819551495, 0.0949352149174398],\n", " 'name': 'R419A'},\n", " {'fluids': ['R134A', 'R142B'],\n", " 'mole_fractions': [0.878387913267685, 0.121612086732315],\n", " 'name': 'R420A'},\n", " {'fluids': ['R125', 'R134A'],\n", " 'mole_fractions': [0.540011717389644, 0.459988282610356],\n", " 'name': 'R421A'},\n", " {'fluids': ['R125', 'R134A'],\n", " 'mole_fractions': [0.828099498512419, 0.171900501487581],\n", " 'name': 'R421B'},\n", " {'fluids': ['R125', 'R134A', 'ISOBUTAN'],\n", " 'mole_fractions': [0.805501067600345, 0.128043250123554, 0.0664556822761011],\n", " 'name': 'R422A'},\n", " {'fluids': ['R125', 'R134A', 'ISOBUTAN'],\n", " 'mole_fractions': [0.497287395965083, 0.446700400155301, 0.0560122038796163],\n", " 'name': 'R422B'},\n", " {'fluids': ['R125', 'R134A', 'ISOBUTAN'],\n", " 'mole_fractions': [0.774757115908852, 0.166711388687975, 0.0585314954031729],\n", " 'name': 'R422C'},\n", " {'fluids': ['R125', 'R134A', 'ISOBUTAN'],\n", " 'mole_fractions': [0.596291711495645, 0.339399053279791, 0.064309235224564],\n", " 'name': 'R422D'},\n", " {'fluids': ['R134A', 'R227EA'],\n", " 'mole_fractions': [0.648115324820034, 0.351884675179966],\n", " 'name': 'R423A'},\n", " {'fluids': ['R125', 'R134A', 'ISOBUTAN', 'BUTANE', 'IPENTANE'],\n", " 'mole_fractions': [0.45615402931289,\n", " 0.49939050863627,\n", " 0.0167872396578164,\n", " 0.0186524885086849,\n", " 0.00901573388433862],\n", " 'name': 'R424A'},\n", " {'fluids': ['R32', 'R134A', 'R227EA'],\n", " 'mole_fractions': [0.321134464075019, 0.615130603145805, 0.0637349327791751],\n", " 'name': 'R425A'},\n", " {'fluids': ['R125', 'R134A', 'BUTANE', 'IPENTANE'],\n", " 'mole_fractions': [0.0431546741714159,\n", " 0.925684310853531,\n", " 0.0227152573734822,\n", " 0.00844575760157109],\n", " 'name': 'R426A'},\n", " {'fluids': ['R32', 'R125', 'R143A', 'R134A'],\n", " 'mole_fractions': [0.260775797534104,\n", " 0.188391404795509,\n", " 0.107618901019853,\n", " 0.443213896650535],\n", " 'name': 'R427A'},\n", " {'fluids': ['R125', 'R143A', 'PROPANE', 'ISOBUTAN'],\n", " 'mole_fractions': [0.694325251072399,\n", " 0.255893190962662,\n", " 0.0146310583647717,\n", " 0.0351504996001673],\n", " 'name': 'R428A'},\n", " {'fluids': ['DME', 'R152A', 'ISOBUTAN'],\n", " 'mole_fractions': [0.66113457206158, 0.0768533364747054, 0.262012091463714],\n", " 'name': 'R429A'},\n", " {'fluids': ['R152A', 'ISOBUTAN'],\n", " 'mole_fractions': [0.735906531919507, 0.264093468080493],\n", " 'name': 'R430A'},\n", " {'fluids': ['PROPANE', 'R152A'],\n", " 'mole_fractions': [0.785742532365466, 0.214257467634534],\n", " 'name': 'R431A'},\n", " {'fluids': ['PROPYLEN', 'DME'],\n", " 'mole_fractions': [0.814097241703795, 0.185902758296205],\n", " 'name': 'R432A'},\n", " {'fluids': ['PROPYLEN', 'PROPANE'],\n", " 'mole_fractions': [0.309917763130151, 0.690082236869849],\n", " 'name': 'R433A'},\n", " {'fluids': ['R125', 'R143A', 'R134A', 'ISOBUTAN'],\n", " 'mole_fractions': [0.556782765664377,\n", " 0.226468961005242,\n", " 0.165810098372986,\n", " 0.0509381749573948],\n", " 'name': 'R434A'},\n", " {'fluids': ['DME', 'R152A'],\n", " 'mole_fractions': [0.85152261670421, 0.14847738329579],\n", " 'name': 'R435A'},\n", " {'fluids': ['PROPANE', 'ISOBUTAN'],\n", " 'mole_fractions': [0.62652773298942, 0.37347226701058],\n", " 'name': 'R436A'},\n", " {'fluids': ['PROPANE', 'ISOBUTAN'],\n", " 'mole_fractions': [0.588127503607667, 0.411872496392333],\n", " 'name': 'R436B'},\n", " {'fluids': ['R125', 'R134A', 'BUTANE', 'PENTANE'],\n", " 'mole_fractions': [0.168496314343733,\n", " 0.797898667324292,\n", " 0.0249804624362383,\n", " 0.00862455589573693],\n", " 'name': 'R437A'},\n", " {'fluids': ['R32', 'R125', 'R134A', 'BUTANE', 'IPENTANE'],\n", " 'mole_fractions': [0.161915681788051,\n", " 0.371558801739542,\n", " 0.42929872424902,\n", " 0.0289854872298073,\n", " 0.00824130499357989],\n", " 'name': 'R438A'},\n", " {'fluids': ['ETHANE', 'PROPANE', 'ISOBUTAN', 'BUTANE'],\n", " 'mole_fractions': [0.049800395690461,\n", " 0.600310262208399,\n", " 0.0498654644324665,\n", " 0.300023877668674],\n", " 'name': 'R441A'},\n", " {'fluids': ['R32', 'R125', 'R134A', 'R152A', 'R227EA'],\n", " 'mole_fractions': [0.487220106766942,\n", " 0.211188495005419,\n", " 0.240409765511042,\n", " 0.0371371957951017,\n", " 0.0240444369214954],\n", " 'name': 'R442A'},\n", " {'fluids': ['PROPYLEN', 'PROPANE', 'ISOBUTAN'],\n", " 'mole_fractions': [0.568232931233387, 0.394367661677695, 0.0373994070889183],\n", " 'name': 'R443A'},\n", " {'fluids': ['R32', 'R152A', 'R1234ZE'],\n", " 'mole_fractions': [0.223042202171548, 0.0731981570161227, 0.703759640812329],\n", " 'name': 'R444A'},\n", " {'fluids': ['R12', 'R152A'],\n", " 'mole_fractions': [0.606101741397223, 0.393898258602777],\n", " 'name': 'R500'},\n", " {'fluids': ['R22', 'R12'],\n", " 'mole_fractions': [0.807509678166191, 0.192490321833809],\n", " 'name': 'R501'},\n", " {'fluids': ['R22', 'R115'],\n", " 'mole_fractions': [0.629994467193889, 0.370005532806111],\n", " 'name': 'R502'},\n", " {'fluids': ['R23', 'R13'],\n", " 'mole_fractions': [0.49970034990839, 0.50029965009161],\n", " 'name': 'R503'},\n", " {'fluids': ['R32', 'R115'],\n", " 'mole_fractions': [0.734239632563771, 0.265760367436229],\n", " 'name': 'R504'},\n", " {'fluids': ['R125', 'R143A'],\n", " 'mole_fractions': [0.411839711774438, 0.588160288225562],\n", " 'name': 'R507A'},\n", " {'fluids': ['R23', 'R116'],\n", " 'mole_fractions': [0.557576966356198, 0.442423033643802],\n", " 'name': 'R508A'},\n", " {'fluids': ['R23', 'R116'],\n", " 'mole_fractions': [0.626751006700703, 0.373248993299297],\n", " 'name': 'R508B'},\n", " {'fluids': ['R22', 'R218'],\n", " 'mole_fractions': [0.630790210153023, 0.369209789846977],\n", " 'name': 'R509A'},\n", " {'fluids': ['DME', 'ISOBUTAN'],\n", " 'mole_fractions': [0.902458936722509, 0.0975410632774913],\n", " 'name': 'R510A'},\n", " {'fluids': ['R134A', 'R152A'],\n", " 'mole_fractions': [0.0329487458964343, 0.967051254103566],\n", " 'name': 'R512A'},\n", " {'fluids': ['METHANE',\n", " 'NITROGEN',\n", " 'CO2',\n", " 'ETHANE',\n", " 'PROPANE',\n", " 'ISOBUTAN',\n", " 'BUTANE',\n", " 'IPENTANE',\n", " 'PENTANE',\n", " 'HEXANE'],\n", " 'mole_fractions': [0.965222,\n", " 0.002595,\n", " 0.005956,\n", " 0.018186,\n", " 0.004596,\n", " 0.000977,\n", " 0.001007,\n", " 0.000473,\n", " 0.000324,\n", " 0.000664],\n", " 'name': 'GulfCoastGas(NIST1)'},\n", " {'fluids': ['METHANE',\n", " 'NITROGEN',\n", " 'CO2',\n", " 'ETHANE',\n", " 'PROPANE',\n", " 'ISOBUTAN',\n", " 'BUTANE',\n", " 'IPENTANE',\n", " 'PENTANE',\n", " 'HEXANE'],\n", " 'mole_fractions': [0.95123,\n", " 0.00089,\n", " 0.02555,\n", " 0.01835,\n", " 0.00238,\n", " 0.0004,\n", " 0.00016,\n", " 0.00014,\n", " 0.00011,\n", " 0.00079],\n", " 'name': 'TypicalNaturalGas'},\n", " {'fluids': ['R125', 'R134A', 'BUTANE'],\n", " 'mole_fractions': [0.744566872257699, 0.202885026732296, 0.052548101010005],\n", " 'name': 'R417B'},\n", " {'fluids': ['R125', 'R134A', 'BUTANE'],\n", " 'mole_fractions': [0.168533780311387, 0.801126056234188, 0.0303401634544254],\n", " 'name': 'R417C'},\n", " {'fluids': ['R125', 'R134A', 'DME'],\n", " 'mole_fractions': [0.425134881380361, 0.494935410459673, 0.0799297081599657],\n", " 'name': 'R419B'},\n", " {'fluids': ['R125', 'R134A', 'ISOBUTAN'],\n", " 'mole_fractions': [0.528211539833383, 0.421012248071509, 0.0507762120951078],\n", " 'name': 'R422E'},\n", " {'fluids': ['DME', 'R152A', 'ISOBUTAN'],\n", " 'mole_fractions': [0.66113457206158, 0.0768533364747054, 0.262012091463714],\n", " 'name': 'R429A'},\n", " {'fluids': ['R152A', 'ISOBUTAN'],\n", " 'mole_fractions': [0.735906531919507, 0.264093468080493],\n", " 'name': 'R430A'},\n", " {'fluids': ['PROPANE', 'R152A'],\n", " 'mole_fractions': [0.785742532365466, 0.214257467634534],\n", " 'name': 'R431A'},\n", " {'fluids': ['PROPYLEN', 'DME'],\n", " 'mole_fractions': [0.814097241703795, 0.185902758296205],\n", " 'name': 'R432A'},\n", " {'fluids': ['PROPYLEN', 'PROPANE'],\n", " 'mole_fractions': [0.309917763130151, 0.690082236869849],\n", " 'name': 'R433A'},\n", " {'fluids': ['PROPYLEN', 'PROPANE'],\n", " 'mole_fractions': [0.0522701063955236, 0.947729893604476],\n", " 'name': 'R433B'},\n", " {'fluids': ['PROPYLEN', 'PROPANE'],\n", " 'mole_fractions': [0.25887610544032, 0.74112389455968],\n", " 'name': 'R433C'},\n", " {'fluids': ['R125', 'R143A', 'R134A', 'ISOBUTAN'],\n", " 'mole_fractions': [0.556782765664377,\n", " 0.226468961005242,\n", " 0.165810098372986,\n", " 0.0509381749573948],\n", " 'name': 'R434A'},\n", " {'fluids': ['R32', 'R125', 'R134A', 'BUTANE', 'IPENTANE'],\n", " 'mole_fractions': [0.161915681788051,\n", " 0.371558801739542,\n", " 0.42929872424902,\n", " 0.0289854872298073,\n", " 0.00824130499357989],\n", " 'name': 'R438A'},\n", " {'fluids': ['R32', 'R125', 'ISOBUTAN'],\n", " 'mole_fractions': [0.684390813603997, 0.278854127894844, 0.0367550585011589],\n", " 'name': 'R439A'},\n", " {'fluids': ['PROPANE', 'R134A', 'R152A'],\n", " 'mole_fractions': [0.00901134733203068,\n", " 0.0103852633851142,\n", " 0.980603389282855],\n", " 'name': 'R440A'},\n", " {'fluids': ['R32', 'R152A', 'R1234ZE'],\n", " 'mole_fractions': [0.580409174767712, 0.11015659826248, 0.309434226969808],\n", " 'name': 'R444B'},\n", " {'fluids': ['CO2', 'R134A', 'R1234ZE'],\n", " 'mole_fractions': [0.14056672736859, 0.0909466670967859, 0.768486605534624],\n", " 'name': 'R445A'},\n", " {'fluids': ['R32', 'R1234ZE', 'BUTANE'],\n", " 'mole_fractions': [0.810347789312053, 0.157652541387366, 0.0319996693005808],\n", " 'name': 'R446A'},\n", " {'fluids': ['R32', 'R125', 'R1234ZE'],\n", " 'mole_fractions': [0.824059115538506, 0.0183849541922025, 0.157555930269292],\n", " 'name': 'R447A'},\n", " {'fluids': ['R32', 'R125', 'R1234YF', 'R134A', 'R1234ZE'],\n", " 'mole_fractions': [0.431218201988559,\n", " 0.186914131481992,\n", " 0.151319256485899,\n", " 0.177586673617217,\n", " 0.0529617364263329],\n", " 'name': 'R448A'},\n", " {'fluids': ['R32', 'R125', 'R1234YF', 'R134A'],\n", " 'mole_fractions': [0.407364566995509,\n", " 0.179481207732065,\n", " 0.193480840388364,\n", " 0.219673384884062],\n", " 'name': 'R449A'},\n", " {'fluids': ['R32', 'R125', 'R1234YF', 'R134A'],\n", " 'mole_fractions': [0.418353331871839,\n", " 0.174861426767915,\n", " 0.175699749729428,\n", " 0.231085491630818],\n", " 'name': 'R449B'},\n", " {'fluids': ['R134A', 'R1234ZE'],\n", " 'mole_fractions': [0.447322067369848, 0.552677932630152],\n", " 'name': 'R450A'},\n", " {'fluids': ['R1234YF', 'R134A'],\n", " 'mole_fractions': [0.887346670041529, 0.112653329958471],\n", " 'name': 'R451A'},\n", " {'fluids': ['R1234YF', 'R134A'],\n", " 'mole_fractions': [0.876445928959364, 0.123554071040636],\n", " 'name': 'R451B'},\n", " {'fluids': ['R32', 'R125', 'R1234YF'],\n", " 'mole_fractions': [0.218864360337465, 0.508837870465814, 0.272297769196721],\n", " 'name': 'R452A'},\n", " {'fluids': ['R32', 'R125', 'R134A', 'R227EA', 'BUTANE', 'IPENTANE'],\n", " 'mole_fractions': [0.341295928327855,\n", " 0.147936968933237,\n", " 0.468112901696291,\n", " 0.0261066945175942,\n", " 0.0091646080754323,\n", " 0.00738289844959133],\n", " 'name': 'R453A'},\n", " {'fluids': ['R32', 'R1234YF'],\n", " 'mole_fractions': [0.541359992223361, 0.458640007776639],\n", " 'name': 'R454A'},\n", " {'fluids': ['R32', 'R1234YF'],\n", " 'mole_fractions': [0.829247912869081, 0.170752087130919],\n", " 'name': 'R454B'},\n", " {'fluids': ['PROPANE', 'DME'],\n", " 'mole_fractions': [0.952038489443906, 0.0479615105560936],\n", " 'name': 'R511A'},\n", " {'fluids': ['R1234YF', 'R134A'],\n", " 'mole_fractions': [0.532425755929735, 0.467574244070265],\n", " 'name': 'R513A'}]" ] }, "execution_count": 2, "metadata": {}, "output_type": "execute_result" } ], "source": [ "data = json.load(open('predefined_mixtures.json'))\n", "data" ] }, { "cell_type": "code", "execution_count": 3, "id": "50f7229b", "metadata": {}, "outputs": [], "source": [ "with open('propsSI_mixtures.csv', 'w') as csvfile:\n", " csvwriter = csv.writer(csvfile)\n", " \n", " csvwriter.writerow(['propsName', 'menuName', 'idName', 'category', 'basic', 'incompressibleMixture',\n", " 'minConcentration', 'maxConcentration', 'longDescription'])\n", " \n", " for mixture in data:\n", " components = zip(mixture['fluids'], mixture['mole_fractions'])\n", " long_description = \"Mole Fractions - \" + \", \".join([f\"{name}: {frac}\" for name, frac in components])\n", " csvwriter.writerow([f\"{mixture['name']}.mix\", mixture['name'], f\"{mixture['name']}Mixture\", \n", " \"Predefined Compressible Mixture\", \"FALSE\", \"FALSE\", \"null\", \"null\", long_description])\n", " " ] }, { "cell_type": "code", "execution_count": null, "id": "3ecd1bfb", "metadata": {}, "outputs": [], "source": [] } ], "metadata": { "kernelspec": { "display_name": "Python 3 (ipykernel)", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.11.4" } }, "nbformat": 4, "nbformat_minor": 5 } ================================================ FILE: notebooks/latex_unicode_equivalents.ipynb ================================================ { "cells": [ { "cell_type": "code", "execution_count": 1, "id": "d191eaea-3b3a-4dbe-a30f-f7ff2426fcfb", "metadata": {}, "outputs": [], "source": [ "current_symbols = ['alpha', 'beta', 'gamma', 'delta', 'epsilon', 'zeta',\n", " 'eta', 'theta', 'iota', 'kappa', 'lambda', 'mu', 'nu',\n", " 'xi', 'pi', 'rho', 'sigma', 'tau', 'upsilon', 'phi', 'chi',\n", " 'psi', 'omega', 'Gamma', 'Delta', 'Theta', 'Lambda',\n", " 'Xi', 'Pi', 'Sigma', 'Upsilon', 'Phi', 'Psi', 'Omega']\n", "\n", "current_symbols = [ f'\\\\{symbol}' for symbol in current_symbols]\n", "\n", "# Extracted from: https://github.com/mgreminger/mathlive/blob/c33f8cc965dfea9c56aabb0e89784cf8bfab8e7f/src/latex-commands/symbols.ts\n", "symbols = [\n", " ['\\\\forall', 0x2200],\n", " ['\\\\exists', 0x2203],\n", " ['\\\\nexists', 0x2204, 'mord', 'ams'],\n", " ['\\\\mid', 0x2223, 'mrel'],\n", " ['\\\\top', 0x22a4],\n", " ['\\\\bot', 0x22a5],\n", " ['\\\\#', 0x0023],\n", " ['\\\\&', 0x0026],\n", " ['\\\\parallelogram', 0x25b1],\n", " ['\\\\spadesuit', 0x2660],\n", " ['\\\\heartsuit', 0x2661],\n", " ['\\\\diamondsuit', 0x2662],\n", " ['\\\\clubsuit', 0x2663],\n", " ['\\\\flat', 0x266d],\n", " ['\\\\natural', 0x266e],\n", " ['\\\\sharp', 0x266f],\n", " ['\\\\backslash', 0x005c],\n", " ['\\\\nabla', 0x2207],\n", " ['\\\\partial', 0x2202],\n", " ['\\\\ell', 0x2113],\n", " ['\\\\hbar', 0x210f],\n", " ['\\\\pounds', 0x00a3],\n", " ['\\\\euro', 0x20ac], \n", " ['\\\\rightarrow', 0x2192],\n", " ['\\\\to', 0x2192],\n", " ['\\\\leftarrow', 0x2190],\n", " ['\\\\gets', 0x2190],\n", " ['\\\\Rightarrow', 0x21d2],\n", " ['\\\\Leftarrow', 0x21d0],\n", " ['\\\\longrightarrow', 0x27f6],\n", " ['\\\\longleftarrow', 0x27f5],\n", " ['\\\\Longrightarrow', 0x27f9],\n", " ['\\\\implies', 0x27f9],\n", " ['\\\\Longleftarrow', 0x27f8],\n", " ['\\\\impliedby', 0x27f8],\n", " ['\\\\longleftrightarrow', 0x27f7],\n", " ['\\\\biconditional', 0x27f7],\n", " ['\\\\Longleftrightarrow', 0x27fa],\n", " ['\\\\mapsto', 0x21a6],\n", " ['\\\\longmapsto', 0x27fc],\n", " ['\\\\uparrow', 0x2191],\n", " ['\\\\downarrow', 0x2193],\n", " ['\\\\Uparrow', 0x21d1],\n", " ['\\\\Downarrow', 0x21d3],\n", " ['\\\\updownarrow', 0x2195],\n", " ['\\\\Updownarrow', 0x21d5],\n", " ['\\\\hookrightarrow', 0x21aa],\n", " ['\\\\hookleftarrow', 0x21a9],\n", " ['\\\\rightharpoonup', 0x21c0],\n", " ['\\\\leftharpoonup', 0x21bc],\n", " ['\\\\rightharpoondown', 0x21c1],\n", " ['\\\\leftharpoondown', 0x21bd],\n", " ['\\\\searrow', 0x2198],\n", " ['\\\\nearrow', 0x2197],\n", " ['\\\\swarrow', 0x2199],\n", " ['\\\\nwarrow', 0x2196],\n", " ['\\\\originalof', 0x22b6],\n", " ['\\\\laplace', 0x22b6],\n", " ['\\\\imageof', 0x22b7],\n", " ['\\\\Laplace', 0x22b7],\n", " ['\\\\mapsfrom', 0x21a4, 'mrel'],\n", " ['\\\\Mapsfrom', 0x2906, 'mrel'],\n", " ['\\\\MapsTo', 0x2907, 'mrel'],\n", " ['\\\\Yup', 0x2144, 'mord'],\n", " ['\\\\lightning', 0x21af, 'mrel'],\n", " ['\\\\leftarrowtriangle', 0x21fd, 'mrel'],\n", " ['\\\\rightarrowtriangle', 0x21fe, 'mrel'],\n", " ['\\\\leftrightarrowtriangle', 0x21ff, 'mrel'],\n", " ['\\\\boxdot', 0x22a1, 'mbin'],\n", " ['\\\\bigtriangleup', 0x25b3, 'mbin'],\n", " ['\\\\bigtriangledown', 0x25bd, 'mbin'],\n", " ['\\\\boxbar', 0x25eb, 'mbin'],\n", " ['\\\\Lbag', 0x27c5, 'mopen'],\n", " ['\\\\Rbag', 0x27c6, 'mclose'],\n", " ['\\\\llbracket', 0x27e6, 'mopen'],\n", " ['\\\\rrbracket', 0x27e7, 'mclose'],\n", " ['\\\\longmapsfrom', 0x27fb, 'mrel'],\n", " ['\\\\Longmapsfrom', 0x27fd, 'mrel'],\n", " ['\\\\Longmapsto', 0x27fe, 'mrel'],\n", " ['\\\\boxslash', 0x29c4, 'mbin'],\n", " ['\\\\boxbslash', 0x29c5, 'mbin'],\n", " ['\\\\boxast', 0x29c6, 'mbin'],\n", " ['\\\\boxcircle', 0x29c7, 'mbin'],\n", " ['\\\\boxbox', 0x29c8, 'mbin'],\n", " ['\\\\fatsemi', 0x2a1f, 'mop'],\n", " ['\\\\leftslice', 0x2aa6, 'mrel'],\n", " ['\\\\rightslice', 0x2aa7, 'mrel'],\n", " ['\\\\interleave', 0x2af4, 'mbin'],\n", " ['\\\\biginterleave', 0x2afc, 'mop'],\n", " ['\\\\sslash', 0x2afd, 'mbin'],\n", " ['\\\\talloblong', 0x2afe, 'mbin'],\n", " ['\\\\lbrace', 0x007b, 'mopen'],\n", " ['\\\\rbrace', 0x007d, 'mclose'],\n", " ['\\\\lparen', 0x0028, 'mopen'],\n", " ['\\\\rparen', 0x0029, 'mclose'],\n", " ['\\\\langle', 0x27e8, 'mopen'],\n", " ['\\\\rangle', 0x27e9, 'mclose'],\n", " ['\\\\lfloor', 0x230a, 'mopen'],\n", " ['\\\\rfloor', 0x230b, 'mclose'],\n", " ['\\\\lceil', 0x2308, 'mopen'],\n", " ['\\\\rceil', 0x2309, 'mclose'],\n", " ['\\\\vert', 0x2223],\n", " ['\\\\lvert', 0x2223, 'mopen'],\n", " ['\\\\rvert', 0x2223, 'mclose'],\n", " ['\\\\|', 0x2225],\n", " ['\\\\Vert', 0x2225],\n", " ['\\\\mVert', 0x2225],\n", " ['\\\\lVert', 0x2225, 'mopen'],\n", " ['\\\\rVert', 0x2225, 'mclose'],\n", " ['\\\\lbrack', 0x005b, 'mopen'],\n", " ['\\\\rbrack', 0x005d, 'mclose'],\n", " ['\\\\{', 0x007b, 'mopen'],\n", " ['\\\\}', 0x007d, 'mclose'],\n", " ['(', 0x0028, 'mopen'],\n", " [')', 0x029, 'mclose'],\n", " ['[', 0x005b, 'mopen'],\n", " [']', 0x005d, 'mclose'],\n", " ['\\\\ulcorner', 0x250c, 'mopen', 'ams'],\n", " ['\\\\urcorner', 0x2510, 'mclose', 'ams'],\n", " ['\\\\llcorner', 0x2514, 'mopen', 'ams'],\n", " ['\\\\lrcorner', 0x2518, 'mclose', 'ams'],\n", " ['\\\\lgroup', 0x27ee, 'mopen'],\n", " ['\\\\rgroup', 0x27ef, 'mclose'],\n", " ['\\\\lmoustache', 0x23b0, 'mopen'],\n", " ['\\\\rmoustache', 0x23b1, 'mclose'],\n", " ['\\\\dashrightarrow', 0x21e2],\n", " ['\\\\dashleftarrow', 0x21e0],\n", " ['\\\\Rrightarrow', 0x21db],\n", " ['\\\\Lleftarrow', 0x21da],\n", " ['\\\\leftrightarrows', 0x21c6],\n", " ['\\\\rightleftarrows', 0x21c4],\n", " ['\\\\curvearrowright', 0x21b7],\n", " ['\\\\curvearrowleft', 0x21b6],\n", " ['\\\\rightrightarrows', 0x21c9],\n", " ['\\\\leftleftarrows', 0x21c7],\n", " ['\\\\upuparrows', 0x21c8],\n", " ['\\\\downdownarrows', 0x21ca],\n", " ['\\\\vartriangle', 0x25b3],\n", " ['\\\\triangleq', 0x225c],\n", " ['\\\\vartriangleleft', 0x22b2],\n", " ['\\\\trianglelefteq', 0x22b4],\n", " ['\\\\ntriangleleft', 0x22ea],\n", " ['\\\\ntrianglelefteq', 0x22ec],\n", " ['\\\\vartriangleright', 0x22b3],\n", " ['\\\\trianglerighteq', 0x22b5],\n", " ['\\\\ntriangleright', 0x22eb],\n", " ['\\\\ntrianglerighteq', 0x22ed],\n", " ['\\\\blacktriangleleft', 0x25c0],\n", " ['\\\\blacktriangleright', 0x25b6],\n", " ['\\\\leftarrowtail', 0x21a2],\n", " ['\\\\rightarrowtail', 0x21a3],\n", " ['\\\\looparrowright', 0x21ac],\n", " ['\\\\looparrowleft', 0x21ab],\n", " ['\\\\twoheadleftarrow', 0x219e],\n", " ['\\\\twoheadrightarrow', 0x21a0],\n", " ['\\\\twoheadrightarrowtail', 0x2916],\n", " ['\\\\rightleftharpoons', 0x21cc],\n", " ['\\\\leftrightharpoons', 0x21cb],\n", " ['\\\\Rsh', 0x21b1],\n", " ['\\\\Lsh', 0x21b0],\n", " ['\\\\circlearrowright', 0x21bb],\n", " ['\\\\circlearrowleft', 0x21ba],\n", " ['\\\\restriction', 0x21be],\n", " ['\\\\upharpoonright', 0x21be],\n", " ['\\\\upharpoonleft', 0x21bf],\n", " ['\\\\downharpoonright', 0x21c2],\n", " ['\\\\downharpoonleft', 0x21c3],\n", " ['\\\\rightsquigarrow', 0x21dd],\n", " ['\\\\leadsto', 0x21dd],\n", " ['\\\\leftrightsquigarrow', 0x21ad],\n", " ['\\\\multimap', 0x22b8],\n", " ['\\\\nleftarrow', 0x219a],\n", " ['\\\\nrightarrow', 0x219b],\n", " ['\\\\nRightarrow', 0x21cf],\n", " ['\\\\nLeftarrow', 0x21cd],\n", " ['\\\\nleftrightarrow', 0x21ae],\n", " ['\\\\nLeftrightarrow', 0x21ce],\n", " ['\\\\nvrightarrow', 0x21f8],\n", " ['\\\\nvtwoheadrightarrow', 0x2900],\n", " ['\\\\nvrightarrowtail', 0x2914],\n", " ['\\\\nvtwoheadrightarrowtail', 0x2917],\n", " ['\\\\shortparallel', 0x2225],\n", " ['\\\\nless', 0x226e],\n", " ['\\\\nleqslant', 0xe010],\n", " ['\\\\lneq', 0x2a87],\n", " ['\\\\lneqq', 0x2268],\n", " ['\\\\nleqq', 0xe011],\n", " ['\\\\lvertneqq', 0xe00c],\n", " ['\\\\lnsim', 0x22e6],\n", " ['\\\\lnapprox', 0x2a89],\n", " ['\\\\nprec', 0x2280],\n", " ['\\\\npreceq', 0x22e0],\n", " ['\\\\precnsim', 0x22e8],\n", " ['\\\\precnapprox', 0x2ab9],\n", " ['\\\\nsim', 0x2241],\n", " ['\\\\nshortmid', 0xe006],\n", " ['\\\\nmid', 0x2224],\n", " ['\\\\nvdash', 0x22ac],\n", " ['\\\\nvDash', 0x22ad],\n", " ['\\\\ngtr', 0x226f],\n", " ['\\\\ngeqslant', 0xe00f],\n", " ['\\\\ngeqq', 0xe00e],\n", " ['\\\\gneq', 0x2a88],\n", " ['\\\\gneqq', 0x2269],\n", " ['\\\\gvertneqq', 0xe00d],\n", " ['\\\\gnsim', 0x22e7],\n", " ['\\\\gnapprox', 0x2a8a],\n", " ['\\\\nsucc', 0x2281],\n", " ['\\\\nsucceq', 0x22e1],\n", " ['\\\\succnsim', 0x22e9],\n", " ['\\\\succnapprox', 0x2aba],\n", " ['\\\\ncong', 0x2246],\n", " ['\\\\nshortparallel', 0xe007],\n", " ['\\\\nparallel', 0x2226],\n", " ['\\\\nVDash', 0x22af],\n", " ['\\\\nsupseteqq', 0xe018],\n", " ['\\\\supsetneq', 0x228b],\n", " ['\\\\varsupsetneq', 0xe01b],\n", " ['\\\\supsetneqq', 0x2acc],\n", " ['\\\\varsupsetneqq', 0xe019],\n", " ['\\\\nVdash', 0x22ae],\n", " ['\\\\precneqq', 0x2ab5],\n", " ['\\\\succneqq', 0x2ab6],\n", " ['\\\\nsubseteqq', 0xe016],\n", " ['\\\\leqslant', 0x2a7d],\n", " ['\\\\geqslant', 0x2a7e],\n", " ['\\\\gtrsim', 0x2273],\n", " ['\\\\approxeq', 0x224a],\n", " ['\\\\thickapprox', 0x2248],\n", " ['\\\\lessapprox', 0x2a85],\n", " ['\\\\gtrapprox', 0x2a86],\n", " ['\\\\precapprox', 0x2ab7],\n", " ['\\\\succapprox', 0x2ab8],\n", " ['\\\\thicksim', 0x223c],\n", " ['\\\\succsim', 0x227f],\n", " ['\\\\precsim', 0x227e],\n", " ['\\\\backsim', 0x223d],\n", " ['\\\\eqsim', 0x2242],\n", " ['\\\\backsimeq', 0x22cd],\n", " ['\\\\lesssim', 0x2272],\n", " ['\\\\nleq', 0x2270],\n", " ['\\\\ngeq', 0x2271],\n", " ['\\\\smallsmile', 0x2323],\n", " ['\\\\smallfrown', 0x2322],\n", " ['\\\\leqq', 0x2266],\n", " ['\\\\eqslantless', 0x2a95],\n", " ['\\\\lll', 0x22d8],\n", " ['\\\\lessgtr', 0x2276],\n", " ['\\\\lesseqgtr', 0x22da],\n", " ['\\\\lesseqqgtr', 0x2a8b],\n", " ['\\\\risingdotseq', 0x2253],\n", " ['\\\\fallingdotseq', 0x2252],\n", " ['\\\\subseteqq', 0x2ac5],\n", " ['\\\\Subset', 0x22d0],\n", " ['\\\\sqsubset', 0x228f],\n", " ['\\\\preccurlyeq', 0x227c],\n", " ['\\\\curlyeqprec', 0x22de],\n", " ['\\\\vDash', 0x22a8],\n", " ['\\\\Vvdash', 0x22aa],\n", " ['\\\\bumpeq', 0x224f],\n", " ['\\\\Bumpeq', 0x224e],\n", " ['\\\\geqq', 0x2267],\n", " ['\\\\eqslantgtr', 0x2a96],\n", " ['\\\\ggg', 0x22d9],\n", " ['\\\\gtrless', 0x2277],\n", " ['\\\\gtreqless', 0x22db],\n", " ['\\\\gtreqqless', 0x2a8c],\n", " ['\\\\supseteqq', 0x2ac6],\n", " ['\\\\Supset', 0x22d1],\n", " ['\\\\sqsupset', 0x2290],\n", " ['\\\\succcurlyeq', 0x227d],\n", " ['\\\\curlyeqsucc', 0x22df],\n", " ['\\\\Vdash', 0x22a9],\n", " ['\\\\shortmid', 0x2223],\n", " ['\\\\between', 0x226c],\n", " ['\\\\pitchfork', 0x22d4],\n", " ['\\\\varpropto', 0x221d],\n", " ['\\\\backepsilon', 0x220d],\n", " ['\\\\llless', 0x22d8],\n", " ['\\\\gggtr', 0x22d9],\n", " ['\\\\doteqdot', 0x2251],\n", " ['\\\\Doteq', 0x2251],\n", " ['\\\\eqcirc', 0x2256],\n", " ['\\\\circeq', 0x2257],\n", " ['\\\\therefore', 0x2234],\n", " ['\\\\because', 0x2235],\n", " ['+', 0x002b],\n", " ['-', 0x2212],\n", " ['\\u2212', 0x2212],\n", " ['\\\\pm', 0x00b1],\n", " ['\\\\mp', 0x2213],\n", " ['*', 0x2217],\n", " ['\\\\times', 0x00d7],\n", " ['\\\\div', 0x00f7],\n", " ['\\\\divides', 0x2223],\n", " ['\\\\cdot', 0x22c5],\n", " ['\\\\cap', 0x2229],\n", " ['\\\\cup', 0x222a],\n", " ['\\\\setminus', 0x2216],\n", " ['\\\\land', 0x2227],\n", " ['\\\\wedge', 0x2227],\n", " ['\\\\lor', 0x2228],\n", " ['\\\\vee', 0x2228],\n", " ['\\\\circ', 0x2218],\n", " ['\\\\bigcirc', 0x25ef],\n", " ['\\\\bullet', 0x2219],\n", " ['\\\\oplus', 0x2295],\n", " ['\\\\ominus', 0x2296],\n", " ['\\\\otimes', 0x2297],\n", " ['\\\\odot', 0x2299],\n", " ['\\\\oslash', 0x2298],\n", " ['\\\\bigtriangleup', 0x25b3],\n", " ['\\\\bigtriangledown', 0x25bd],\n", " ['\\\\triangleleft', 0x25c3],\n", " ['\\\\triangleright', 0x25b9],\n", " ['\\\\And', 0x0026],\n", " ['\\\\dagger', 0x2020],\n", " ['\\\\dag', 0x2020],\n", " ['\\\\ddag', 0x2021],\n", " ['\\\\ddagger', 0x2021],\n", " ['\\\\ast', 0x2217],\n", " ['\\\\star', 0x22c6],\n", " ['\\\\bigstar', 0x2605],\n", " ['\\\\diamond', 0x22c4],\n", " ['\\\\lhd', 0x22b2],\n", " ['\\\\rhd', 0x22b3],\n", " ['\\\\lessdot', 0x22d6],\n", " ['\\\\gtrdot', 0x22d7],\n", " ['\\\\ltimes', 0x22c9],\n", " ['\\\\rtimes', 0x22ca],\n", " ['\\\\leftthreetimes', 0x22cb],\n", " ['\\\\rightthreetimes', 0x22cc],\n", " ['\\\\intercal', 0x22ba],\n", " ['\\\\dotplus', 0x2214],\n", " ['\\\\doublebarwedge', 0x2a5e],\n", " ['\\\\divideontimes', 0x22c7],\n", " ['\\\\centerdot', 0x22c5],\n", " ['\\\\smallsetminus', 0x2216],\n", " ['\\\\barwedge', 0x22bc],\n", " ['\\\\veebar', 0x22bb],\n", " ['\\\\nor', 0x22bb],\n", " ['\\\\curlywedge', 0x22cf],\n", " ['\\\\curlyvee', 0x22ce],\n", " ['\\\\boxminus', 0x229f],\n", " ['\\\\boxplus', 0x229e],\n", " ['\\\\boxtimes', 0x22a0],\n", " ['\\\\boxdot', 0x22a1],\n", " ['\\\\circleddash', 0x229d],\n", " ['\\\\circledast', 0x229b],\n", " ['\\\\circledcirc', 0x229a],\n", " ['\\\\unlhd', 0x22b4],\n", " ['\\\\unrhd', 0x22b5],\n", " ['\\\\surd', 0x221a],\n", " ['\\\\S', 0x00a7],\n", " ['\\\\infty', 0x221e],\n", " ['\\\\prime', 0x2032],\n", " ['\\\\doubleprime', 0x2033],\n", " ['\\\\angle', 0x2220],\n", " ['`', 0x2018],\n", " ['\\\\$', 0x0024],\n", " ['\\\\%', 0x0025],\n", "# ['\\\\_', 0x005f],\n", " ['\\\\alpha', 0x03b1],\n", " ['\\\\beta', 0x03b2],\n", " ['\\\\gamma', 0x03b3],\n", " ['\\\\delta', 0x03b4],\n", " ['\\\\epsilon', 0x03f5],\n", " ['\\\\varepsilon', 0x03b5],\n", " ['\\\\zeta', 0x03b6],\n", " ['\\\\eta', 0x03b7],\n", " ['\\\\theta', 0x03b8],\n", " ['\\\\vartheta', 0x03d1],\n", " ['\\\\iota', 0x03b9],\n", " ['\\\\kappa', 0x03ba],\n", " ['\\\\varkappa', 0x03f0, 'mord', 'ams'],\n", " ['\\\\lambda', 0x03bb],\n", " ['\\\\mu', 0x03bc],\n", " ['\\\\nu', 0x03bd],\n", " ['\\\\xi', 0x03be],\n", " ['\\\\omicron', 0x006f],\n", " ['\\\\pi', 0x03c0],\n", " ['\\\\varpi', 0x03d6],\n", " ['\\\\rho', 0x03c1],\n", " ['\\\\varrho', 0x03f1],\n", " ['\\\\sigma', 0x03c3],\n", " ['\\\\varsigma', 0x03c2],\n", " ['\\\\tau', 0x03c4],\n", " ['\\\\phi', 0x03d5],\n", " ['\\\\varphi', 0x03c6],\n", " ['\\\\upsilon', 0x03c5],\n", " ['\\\\chi', 0x03c7],\n", " ['\\\\psi', 0x03c8],\n", " ['\\\\omega', 0x03c9],\n", " ['\\\\Gamma', 0x0393],\n", " ['\\\\Delta', 0x0394],\n", " ['\\\\Theta', 0x0398],\n", " ['\\\\Lambda', 0x039b],\n", " ['\\\\Xi', 0x039e],\n", " ['\\\\Pi', 0x03a0],\n", " ['\\\\Sigma', 0x03a3],\n", " ['\\\\Upsilon', 0x03a5],\n", " ['\\\\Phi', 0x03a6],\n", " ['\\\\Psi', 0x03a8],\n", " ['\\\\Omega', 0x03a9],\n", " ['\\\\digamma', 0x03dd, 'mord', 'ams'],\n", " ['\\\\varkappa', 0x03f0, 'mord', 'ams'],\n", " ['\\\\coppa', 0x03d9, 'mord', 'ams'],\n", " ['\\\\koppa', 0x03d9, 'mord', 'ams'],\n", " ['\\\\Coppa', 0x03d8, 'mord', 'ams'],\n", " ['\\\\Koppa', 0x03d8, 'mord', 'ams'],\n", " ['\\\\sampi', 0x03e1, 'mord', 'ams'],\n", " ['\\\\Sampi', 0x03e0, 'mord', 'ams'],\n", " ['\\\\emptyset', 0x2205],\n", " ['=', 0x003d],\n", " ['<', 0x003c],\n", " ['\\\\lt', 0x003c],\n", " ['>', 0x003e],\n", " ['\\\\gt', 0x003e],\n", " ['\\\\le', 0x2264],\n", " ['\\\\leq', 0x2264],\n", " ['\\\\ge', 0x2265],\n", " ['\\\\geq', 0x2265],\n", " ['\\\\ll', 0x226a],\n", " ['\\\\gg', 0x226b],\n", " ['\\\\coloneq', 0x2254],\n", " ['\\\\coloneqq', 0x2254],\n", " ['\\\\colonequals', 0x2254],\n", " ['\\\\measeq', 0x225d],\n", " ['\\\\eqdef', 0x225e],\n", " ['\\\\questeq', 0x225f],\n", " [':', 0x003a],\n", " ['\\\\cong', 0x2245],\n", " ['\\\\equiv', 0x2261],\n", " ['\\\\prec', 0x227a],\n", " ['\\\\preceq', 0x2aaf],\n", " ['\\\\succ', 0x227b],\n", " ['\\\\succeq', 0x2ab0],\n", " ['\\\\perp', 0x27c2],\n", " ['\\\\propto', 0x221d],\n", " ['\\\\Colon', 0x2237],\n", " ['\\\\smile', 0x2323],\n", " ['\\\\frown', 0x2322],\n", " ['\\\\sim', 0x223c],\n", " ['\\\\doteq', 0x2250],\n", " ['\\\\bowtie', 0x22c8],\n", " ['\\\\Join', 0x22c8],\n", " ['\\\\asymp', 0x224d],\n", " ['\\\\sqsubseteq', 0x2291],\n", " ['\\\\sqsupseteq', 0x2292],\n", " ['\\\\approx', 0x2248],\n", " ['\\\\~', 0x007e],\n", " ['\\\\leftrightarrow', 0x2194],\n", " ['\\\\Leftrightarrow', 0x21d4],\n", " ['\\\\models', 0x22a8],\n", " ['\\\\vdash', 0x22a2],\n", " ['\\\\dashv', 0x22a3],\n", " ['\\\\roundimplies', 0x2970],\n", " ['\\\\in', 0x2208],\n", " ['\\\\notin', 0x2209],\n", " ['\\\\ni', 0x220b],\n", " ['\\\\owns', 0x220b],\n", " ['\\\\subset', 0x2282],\n", " ['\\\\supset', 0x2283],\n", " ['\\\\subseteq', 0x2286],\n", " ['\\\\supseteq', 0x2287],\n", " ['\\\\differencedelta', 0x2206],\n", " ['\\\\mvert', 0x2223],\n", " ['\\\\parallel', 0x2225],\n", " ['\\\\simeq', 0x2243],\n", " ['\\\\lnot', 0x00ac],\n", " ['\\\\neg', 0x00ac],\n", " ['\\\\triangle', 0x25b3],\n", " ['\\\\subsetneq', 0x228a],\n", " ['\\\\varsubsetneq', 0xe01a],\n", " ['\\\\subsetneqq', 0x2acb],\n", " ['\\\\varsubsetneqq', 0xe017],\n", " ['\\\\nsubset', 0x2284],\n", " ['\\\\nsupset', 0x2285],\n", " ['\\\\nsubseteq', 0x2288],\n", " ['\\\\nsupseteq', 0x2289],\n", " ['\\\\wp', 0x2118],\n", " ['\\\\aleph', 0x2135],\n", " ['\\\\blacktriangle', 0x25b2],\n", " ['\\\\hslash', 0x210f],\n", " ['\\\\Finv', 0x2132],\n", " ['\\\\Game', 0x2141],\n", " ['\\\\eth', 0x00f0],\n", " ['\\\\mho', 0x2127],\n", " ['\\\\Bbbk', 0x006b],\n", " ['\\\\yen', 0x00a5],\n", " ['\\\\square', 0x25a1],\n", " ['\\\\Box', 0x25a1],\n", " ['\\\\blacksquare', 0x25a0],\n", " ['\\\\circledS', 0x24c8],\n", " ['\\\\circledR', 0x00ae],\n", " ['\\\\triangledown', 0x25bd],\n", " ['\\\\blacktriangledown', 0x25bc],\n", " ['\\\\checkmark', 0x2713],\n", " ['\\\\diagup', 0x2571],\n", " ['\\\\measuredangle', 0x2221],\n", " ['\\\\sphericalangle', 0x2222],\n", " ['\\\\backprime', 0x2035],\n", " ['\\\\backdoubleprime', 0x2036],\n", " ['\\\\Diamond', 0x25ca],\n", " ['\\\\lozenge', 0x25ca],\n", " ['\\\\blacklozenge', 0x29eb],\n", " ['\\\\varnothing', 0x2205],\n", " ['\\\\complement', 0x2201],\n", " ['\\\\maltese', 0x2720],\n", " ['\\\\beth', 0x2136],\n", " ['\\\\daleth', 0x2138],\n", " ['\\\\gimel', 0x2137],\n", " ['\\\\ ', 0x00a0],\n", " ['~', 0x00a0],\n", " ['\\\\colon', 0x003a],\n", " ['\\\\cdotp', 0x22c5],\n", " ['\\\\vdots', 0x22ee, 'mord'],\n", " ['\\\\ldotp', 0x002e],\n", " [',', 0x002c],\n", " [';', 0x003b],\n", " ['\\\\cdots', 0x22ef],\n", " ['\\\\ddots', 0x22f1],\n", " ['\\\\ldots', 0x2026],\n", " ['\\\\mathellipsis', 0x2026],\n", " ['\\\\/', 0x002f],\n", " ['|', 0x2223, 'mord'],\n", " ['\\\\imath', 0x0131],\n", " ['\\\\jmath', 0x0237],\n", " ['\\\\degree', 0x00b0],\n", " [\"'\", 0x2032],\n", " ['\"', 0x201d],]" ] }, { "cell_type": "code", "execution_count": 2, "id": "5b7b0a52-c870-4735-be92-4103e9231f8b", "metadata": {}, "outputs": [], "source": [ "def test_chr(hex_chr):\n", " try:\n", " exec(f\"a{chr(hex_chr)}=1\")\n", " except Exception as e:\n", " return False\n", " return True\n" ] }, { "cell_type": "code", "execution_count": 3, "id": "83037db7-17bf-4504-8b43-775787efd549", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "True" ] }, "execution_count": 3, "metadata": {}, "output_type": "execute_result" } ], "source": [ "test_chr(0x03b1)" ] }, { "cell_type": "code", "execution_count": 4, "id": "e43a1958-44e0-49ca-b1f2-7d2a5f2a15e2", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "False" ] }, "execution_count": 4, "metadata": {}, "output_type": "execute_result" } ], "source": [ "test_chr(0x2032)" ] }, { "cell_type": "code", "execution_count": 5, "id": "33ae9d7e-6cbf-4c1e-a84e-58fb1c8df144", "metadata": {}, "outputs": [], "source": [ "valid_symbols = []\n", "\n", "for entry in symbols:\n", " if test_chr(entry[1]):\n", " valid_symbols.append((entry[0], chr(entry[1])))\n" ] }, { "cell_type": "code", "execution_count": 6, "id": "5097d429-bec5-4e39-88e8-52d4e7ae0ecb", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "[('\\\\ell', 'ℓ'),\n", " ('\\\\hbar', 'ℏ'),\n", " ('\\\\alpha', 'α'),\n", " ('\\\\beta', 'β'),\n", " ('\\\\gamma', 'γ'),\n", " ('\\\\delta', 'δ'),\n", " ('\\\\epsilon', 'ϵ'),\n", " ('\\\\varepsilon', 'ε'),\n", " ('\\\\zeta', 'ζ'),\n", " ('\\\\eta', 'η'),\n", " ('\\\\theta', 'θ'),\n", " ('\\\\vartheta', 'ϑ'),\n", " ('\\\\iota', 'ι'),\n", " ('\\\\kappa', 'κ'),\n", " ('\\\\varkappa', 'ϰ'),\n", " ('\\\\lambda', 'λ'),\n", " ('\\\\mu', 'μ'),\n", " ('\\\\nu', 'ν'),\n", " ('\\\\xi', 'ξ'),\n", " ('\\\\omicron', 'o'),\n", " ('\\\\pi', 'π'),\n", " ('\\\\varpi', 'ϖ'),\n", " ('\\\\rho', 'ρ'),\n", " ('\\\\varrho', 'ϱ'),\n", " ('\\\\sigma', 'σ'),\n", " ('\\\\varsigma', 'ς'),\n", " ('\\\\tau', 'τ'),\n", " ('\\\\phi', 'ϕ'),\n", " ('\\\\varphi', 'φ'),\n", " ('\\\\upsilon', 'υ'),\n", " ('\\\\chi', 'χ'),\n", " ('\\\\psi', 'ψ'),\n", " ('\\\\omega', 'ω'),\n", " ('\\\\Gamma', 'Γ'),\n", " ('\\\\Delta', 'Δ'),\n", " ('\\\\Theta', 'Θ'),\n", " ('\\\\Lambda', 'Λ'),\n", " ('\\\\Xi', 'Ξ'),\n", " ('\\\\Pi', 'Π'),\n", " ('\\\\Sigma', 'Σ'),\n", " ('\\\\Upsilon', 'Υ'),\n", " ('\\\\Phi', 'Φ'),\n", " ('\\\\Psi', 'Ψ'),\n", " ('\\\\Omega', 'Ω'),\n", " ('\\\\digamma', 'ϝ'),\n", " ('\\\\varkappa', 'ϰ'),\n", " ('\\\\coppa', 'ϙ'),\n", " ('\\\\koppa', 'ϙ'),\n", " ('\\\\Coppa', 'Ϙ'),\n", " ('\\\\Koppa', 'Ϙ'),\n", " ('\\\\sampi', 'ϡ'),\n", " ('\\\\Sampi', 'Ϡ'),\n", " ('\\\\wp', '℘'),\n", " ('\\\\aleph', 'ℵ'),\n", " ('\\\\hslash', 'ℏ'),\n", " ('\\\\Finv', 'Ⅎ'),\n", " ('\\\\eth', 'ð'),\n", " ('\\\\Bbbk', 'k'),\n", " ('\\\\beth', 'ℶ'),\n", " ('\\\\daleth', 'ℸ'),\n", " ('\\\\gimel', 'ℷ'),\n", " ('\\\\imath', 'ı'),\n", " ('\\\\jmath', 'ȷ')]" ] }, "execution_count": 6, "metadata": {}, "output_type": "execute_result" } ], "source": [ "valid_symbols" ] }, { "cell_type": "code", "execution_count": 7, "id": "8eb3920a-55b4-41c0-8419-997afcd8a5b4", "metadata": {}, "outputs": [], "source": [ "current_symbols_set = set(current_symbols)\n", "new_symbols_set = set(( entry[0] for entry in valid_symbols ))" ] }, { "cell_type": "code", "execution_count": 8, "id": "1b256545-3413-4132-b336-e8b1c1e4593b", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "set()" ] }, "execution_count": 8, "metadata": {}, "output_type": "execute_result" } ], "source": [ "current_symbols_set - new_symbols_set" ] }, { "cell_type": "code", "execution_count": 9, "id": "1e24b867-5915-43ef-a7fc-4cef4cd4e465", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "{'\\\\Bbbk',\n", " '\\\\Coppa',\n", " '\\\\Finv',\n", " '\\\\Koppa',\n", " '\\\\Sampi',\n", " '\\\\aleph',\n", " '\\\\beth',\n", " '\\\\coppa',\n", " '\\\\daleth',\n", " '\\\\digamma',\n", " '\\\\ell',\n", " '\\\\eth',\n", " '\\\\gimel',\n", " '\\\\hbar',\n", " '\\\\hslash',\n", " '\\\\imath',\n", " '\\\\jmath',\n", " '\\\\koppa',\n", " '\\\\omicron',\n", " '\\\\sampi',\n", " '\\\\varepsilon',\n", " '\\\\varkappa',\n", " '\\\\varphi',\n", " '\\\\varpi',\n", " '\\\\varrho',\n", " '\\\\varsigma',\n", " '\\\\vartheta',\n", " '\\\\wp'}" ] }, "execution_count": 9, "metadata": {}, "output_type": "execute_result" } ], "source": [ "new_symbols_set - current_symbols_set" ] }, { "cell_type": "code", "execution_count": 10, "id": "c967aa63-dc84-4e27-af82-212e5eef8c88", "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "export const LATEX_TO_UNICODE = new Map([\n", " [\"\\\\ell\", \"ℓ\"],\n", " [\"\\\\hbar\", \"ℏ\"],\n", " [\"\\\\alpha\", \"α\"],\n", " [\"\\\\beta\", \"β\"],\n", " [\"\\\\gamma\", \"γ\"],\n", " [\"\\\\delta\", \"δ\"],\n", " [\"\\\\epsilon\", \"ϵ\"],\n", " [\"\\\\varepsilon\", \"ε\"],\n", " [\"\\\\zeta\", \"ζ\"],\n", " [\"\\\\eta\", \"η\"],\n", " [\"\\\\theta\", \"θ\"],\n", " [\"\\\\vartheta\", \"ϑ\"],\n", " [\"\\\\iota\", \"ι\"],\n", " [\"\\\\kappa\", \"κ\"],\n", " [\"\\\\varkappa\", \"ϰ\"],\n", " [\"\\\\lambda\", \"λ\"],\n", " [\"\\\\mu\", \"μ\"],\n", " [\"\\\\nu\", \"ν\"],\n", " [\"\\\\xi\", \"ξ\"],\n", " [\"\\\\omicron\", \"o\"],\n", " [\"\\\\pi\", \"π\"],\n", " [\"\\\\varpi\", \"ϖ\"],\n", " [\"\\\\rho\", \"ρ\"],\n", " [\"\\\\varrho\", \"ϱ\"],\n", " [\"\\\\sigma\", \"σ\"],\n", " [\"\\\\varsigma\", \"ς\"],\n", " [\"\\\\tau\", \"τ\"],\n", " [\"\\\\phi\", \"ϕ\"],\n", " [\"\\\\varphi\", \"φ\"],\n", " [\"\\\\upsilon\", \"υ\"],\n", " [\"\\\\chi\", \"χ\"],\n", " [\"\\\\psi\", \"ψ\"],\n", " [\"\\\\omega\", \"ω\"],\n", " [\"\\\\Gamma\", \"Γ\"],\n", " [\"\\\\Delta\", \"Δ\"],\n", " [\"\\\\Theta\", \"Θ\"],\n", " [\"\\\\Lambda\", \"Λ\"],\n", " [\"\\\\Xi\", \"Ξ\"],\n", " [\"\\\\Pi\", \"Π\"],\n", " [\"\\\\Sigma\", \"Σ\"],\n", " [\"\\\\Upsilon\", \"Υ\"],\n", " [\"\\\\Phi\", \"Φ\"],\n", " [\"\\\\Psi\", \"Ψ\"],\n", " [\"\\\\Omega\", \"Ω\"],\n", " [\"\\\\digamma\", \"ϝ\"],\n", " [\"\\\\varkappa\", \"ϰ\"],\n", " [\"\\\\coppa\", \"ϙ\"],\n", " [\"\\\\koppa\", \"ϙ\"],\n", " [\"\\\\Coppa\", \"Ϙ\"],\n", " [\"\\\\Koppa\", \"Ϙ\"],\n", " [\"\\\\sampi\", \"ϡ\"],\n", " [\"\\\\Sampi\", \"Ϡ\"],\n", " [\"\\\\wp\", \"℘\"],\n", " [\"\\\\aleph\", \"ℵ\"],\n", " [\"\\\\hslash\", \"ℏ\"],\n", " [\"\\\\Finv\", \"Ⅎ\"],\n", " [\"\\\\eth\", \"ð\"],\n", " [\"\\\\Bbbk\", \"k\"],\n", " [\"\\\\beth\", \"ℶ\"],\n", " [\"\\\\daleth\", \"ℸ\"],\n", " [\"\\\\gimel\", \"ℷ\"],\n", " [\"\\\\imath\", \"ı\"],\n", " [\"\\\\jmath\", \"ȷ\"]\n", "]);\n", "\n" ] } ], "source": [ "js_code = f\"\"\"export const LATEX_TO_UNICODE = new Map([\n", "{',\\n'.join([f' [\"\\\\{value[0]}\", \"{value[1]}\"]' for value in valid_symbols])}\n", "]);\n", "\"\"\"\n", "\n", "print(js_code)" ] }, { "cell_type": "markdown", "id": "a76ca2d2-0c08-4212-98b8-7663e6cf67f2", "metadata": {}, "source": [ "\n", "```\n", "GREEK_CHAR: '\\\\' ('alpha' | 'beta' | 'gamma' | 'delta' | 'epsilon' | 'zeta' |\n", " 'eta' | 'theta' | 'iota' | 'kappa' | 'lambda' | 'mu' | 'nu' |\n", " 'xi' | 'pi' | 'rho' | 'sigma' | 'tau' | 'upsilon' | 'phi' | 'chi' |\n", " 'psi' | 'omega' | 'Gamma' | 'Delta' | 'Theta' | 'Lambda' |\n", " 'Xi' | 'Pi' | 'Sigma' | 'Upsilon' | 'Phi' | 'Psi' | 'Omega');\n", "```" ] }, { "cell_type": "code", "execution_count": 11, "id": "cca21f1b-a163-4e09-b8da-0230199d0ef1", "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "LATEX_SYMBOLS: '\\\\' ('ell' | 'hbar' | 'alpha' | 'beta' | 'gamma' | 'delta' | 'epsilon' | 'varepsilon' | 'zeta' | 'eta' | 'theta' | 'vartheta' | 'iota' | 'kappa' | 'varkappa' | 'lambda' | 'mu' | 'nu' | 'xi' | 'omicron' | 'pi' | 'varpi' | 'rho' | 'varrho' | 'sigma' | 'varsigma' | 'tau' | 'phi' | 'varphi' | 'upsilon' | 'chi' | 'psi' | 'omega' | 'Gamma' | 'Delta' | 'Theta' | 'Lambda' | 'Xi' | 'Pi' | 'Sigma' | 'Upsilon' | 'Phi' | 'Psi' | 'Omega' | 'digamma' | 'varkappa' | 'coppa' | 'koppa' | 'Coppa' | 'Koppa' | 'sampi' | 'Sampi' | 'wp' | 'aleph' | 'hslash' | 'Finv' | 'eth' | 'Bbbk' | 'beth' | 'daleth' | 'gimel' | 'imath' | 'jmath' );\n" ] } ], "source": [ "lexer_rule = f\"\"\"LATEX_SYMBOLS: '\\\\\\\\' ({\" | \".join([f\"'{value[0][1:]}'\" for value in valid_symbols])} );\"\"\"\n", "\n", "print(lexer_rule)" ] } ], "metadata": { "kernelspec": { "display_name": "Python 3 (ipykernel)", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.12.7" } }, "nbformat": 4, "nbformat_minor": 5 } ================================================ FILE: notebooks/predefined_mixtures.json ================================================ [ { "fluids": [ "NITROGEN", "ARGON", "OXYGEN" ], "mole_fractions": [ 0.7812, 0.0092, 0.2096 ], "name": "Air" }, { "fluids": [ "METHANE", "NITROGEN", "CO2", "ETHANE", "PROPANE", "ISOBUTAN", "BUTANE", "IPENTANE", "PENTANE", "HEXANE" ], "mole_fractions": [ 0.906724, 0.031284, 0.004676, 0.045279, 0.00828, 0.001037, 0.001563, 0.000321, 0.000443, 0.000393 ], "name": "Amarillo" }, { "fluids": [ "METHANE", "NITROGEN", "CO2", "ETHANE", "PROPANE", "ISOBUTAN", "BUTANE", "IPENTANE", "PENTANE" ], "mole_fractions": [ 0.859063, 0.010068, 0.014954, 0.084919, 0.023015, 0.003486, 0.003506, 0.000509, 0.00048 ], "name": "Ekofisk" }, { "fluids": [ "METHANE", "NITROGEN", "CO2", "ETHANE", "PROPANE", "ISOBUTAN", "BUTANE", "IPENTANE", "PENTANE", "HEXANE" ], "mole_fractions": [ 0.965222, 0.002595, 0.005956, 0.018186, 0.004596, 0.000977, 0.001007, 0.000473, 0.000324, 0.000664 ], "name": "GulfCoast" }, { "fluids": [ "METHANE", "NITROGEN", "CO2", "ETHANE", "PROPANE", "ISOBUTAN", "BUTANE" ], "mole_fractions": [ 0.81212, 0.05702, 0.07585, 0.04303, 0.00895, 0.00151, 0.00152 ], "name": "HighCO2" }, { "fluids": [ "METHANE", "NITROGEN", "CO2", "ETHANE", "PROPANE", "ISOBUTAN", "BUTANE" ], "mole_fractions": [ 0.81441, 0.13465, 0.00985, 0.033, 0.00605, 0.001, 0.00104 ], "name": "HighN2" }, { "fluids": [ "METHANE", "NITROGEN", "CO2", "ETHANE", "PROPANE", "ISOBUTAN", "BUTANE", "IPENTANE", "PENTANE", "HEXANE" ], "mole_fractions": [ 0.95123, 0.00089, 0.02555, 0.01835, 0.00238, 0.0004, 0.00016, 0.00014, 0.00011, 0.00079 ], "name": "NaturalGasSample" }, { "fluids": [ "R22", "R152A", "R124" ], "mole_fractions": [ 0.578854210704231, 0.185871453986601, 0.235274335309169 ], "name": "R401A" }, { "fluids": [ "R22", "R152A", "R124" ], "mole_fractions": [ 0.654924685341436, 0.154607382276918, 0.190467932381646 ], "name": "R401B" }, { "fluids": [ "R22", "R152A", "R124" ], "mole_fractions": [ 0.385591186504412, 0.229445970225924, 0.384962843269664 ], "name": "R401C" }, { "fluids": [ "R125", "PROPANE", "R22" ], "mole_fractions": [ 0.507659889396724, 0.0460590346231213, 0.446281075980154 ], "name": "R402A" }, { "fluids": [ "R125", "PROPANE", "R22" ], "mole_fractions": [ 0.299858744498276, 0.0429562491180057, 0.657185006383719 ], "name": "R402B" }, { "fluids": [ "PROPANE", "R22", "R218" ], "mole_fractions": [ 0.104301635230068, 0.797852142841926, 0.0978462219280052 ], "name": "R403A" }, { "fluids": [ "PROPANE", "R22", "R218" ], "mole_fractions": [ 0.117083478399255, 0.668734422027154, 0.214182099573591 ], "name": "R403B" }, { "fluids": [ "R125", "R134A", "R143A" ], "mole_fractions": [ 0.357816784026318, 0.0382639950410712, 0.603919220932611 ], "name": "R404A" }, { "fluids": [ "R22", "R152A", "R142B", "RC318" ], "mole_fractions": [ 0.582397185883849, 0.118598940913682, 0.0612463586573, 0.237757514545169 ], "name": "R405A" }, { "fluids": [ "R22", "ISOBUTAN", "R142B" ], "mole_fractions": [ 0.571559096367276, 0.0618403319459979, 0.366600571686726 ], "name": "R406A" }, { "fluids": [ "R32", "R125", "R134A" ], "mole_fractions": [ 0.346419854360797, 0.300315552114308, 0.353264593524896 ], "name": "R407A" }, { "fluids": [ "R32", "R125", "R134A" ], "mole_fractions": [ 0.197865007175653, 0.600360468492644, 0.201774524331703 ], "name": "R407B" }, { "fluids": [ "R32", "R125", "R134A" ], "mole_fractions": [ 0.381109419953993, 0.179558888662016, 0.439331691383991 ], "name": "R407C" }, { "fluids": [ "R32", "R125", "R134A" ], "mole_fractions": [ 0.262268077791873, 0.113681680758968, 0.624050241449159 ], "name": "R407D" }, { "fluids": [ "R32", "R125", "R134A" ], "mole_fractions": [ 0.402611526984881, 0.104708637358978, 0.492679835656141 ], "name": "R407E" }, { "fluids": [ "R32", "R125", "R134A" ], "mole_fractions": [ 0.473194694453358, 0.205109095413331, 0.321696210133311 ], "name": "R407F" }, { "fluids": [ "R125", "R143A", "R22" ], "mole_fractions": [ 0.0507496395780536, 0.476277681499092, 0.472972678922854 ], "name": "R408A" }, { "fluids": [ "R22", "R124", "R142B" ], "mole_fractions": [ 0.676088021274302, 0.178481953421098, 0.1454300253046 ], "name": "R409A" }, { "fluids": [ "R22", "R124", "R142B" ], "mole_fractions": [ 0.726713817097545, 0.177089324155708, 0.0961968587467468 ], "name": "R409B" }, { "fluids": [ "R32", "R125" ], "mole_fractions": [ 0.697614699375863, 0.302385300624138 ], "name": "R410A" }, { "fluids": [ "R32", "R125" ], "mole_fractions": [ 0.653688938033229, 0.346311061966771 ], "name": "R410B" }, { "fluids": [ "PROPYLEN", "R22", "R152A" ], "mole_fractions": [ 0.0293595987641706, 0.833472654512905, 0.137167746722925 ], "name": "R411A" }, { "fluids": [ "PROPYLEN", "R22", "R152A" ], "mole_fractions": [ 0.0592216130255444, 0.903048917855743, 0.0377294691187131 ], "name": "R411B" }, { "fluids": [ "R22", "R218", "R142B" ], "mole_fractions": [ 0.746189416536491, 0.0245117299030133, 0.229298853560496 ], "name": "R412A" }, { "fluids": [ "R218", "R134A", "ISOBUTAN" ], "mole_fractions": [ 0.0497604388838132, 0.896582929746185, 0.0536566313700015 ], "name": "R413A" }, { "fluids": [ "R22", "R124", "ISOBUTAN", "R142B" ], "mole_fractions": [ 0.571718248653786, 0.202422623615037, 0.0667091242374272, 0.159150003493749 ], "name": "R414A" }, { "fluids": [ "R22", "R124", "ISOBUTAN", "R142B" ], "mole_fractions": [ 0.58743911052603, 0.29030851296569, 0.0262178745861124, 0.0960345019221677 ], "name": "R414B" }, { "fluids": [ "R22", "R152A" ], "mole_fractions": [ 0.776780159383737, 0.223219840616263 ], "name": "R415A" }, { "fluids": [ "R22", "R152A" ], "mole_fractions": [ 0.202949716550675, 0.797050283449325 ], "name": "R415B" }, { "fluids": [ "R134A", "R124", "BUTANE" ], "mole_fractions": [ 0.647182715864291, 0.323933072881677, 0.0288842112540324 ], "name": "R416A" }, { "fluids": [ "R125", "R134A", "BUTANE" ], "mole_fractions": [ 0.414456113615123, 0.523100248809492, 0.0624436375753851 ], "name": "R417A" }, { "fluids": [ "PROPANE", "R22", "R152A" ], "mole_fractions": [ 0.0287766462758765, 0.939204558675462, 0.0320187950486611 ], "name": "R418A" }, { "fluids": [ "R125", "R134A", "DME" ], "mole_fractions": [ 0.701459965531065, 0.203604819551495, 0.0949352149174398 ], "name": "R419A" }, { "fluids": [ "R134A", "R142B" ], "mole_fractions": [ 0.878387913267685, 0.121612086732315 ], "name": "R420A" }, { "fluids": [ "R125", "R134A" ], "mole_fractions": [ 0.540011717389644, 0.459988282610356 ], "name": "R421A" }, { "fluids": [ "R125", "R134A" ], "mole_fractions": [ 0.828099498512419, 0.171900501487581 ], "name": "R421B" }, { "fluids": [ "R125", "R134A", "ISOBUTAN" ], "mole_fractions": [ 0.805501067600345, 0.128043250123554, 0.0664556822761011 ], "name": "R422A" }, { "fluids": [ "R125", "R134A", "ISOBUTAN" ], "mole_fractions": [ 0.497287395965083, 0.446700400155301, 0.0560122038796163 ], "name": "R422B" }, { "fluids": [ "R125", "R134A", "ISOBUTAN" ], "mole_fractions": [ 0.774757115908852, 0.166711388687975, 0.0585314954031729 ], "name": "R422C" }, { "fluids": [ "R125", "R134A", "ISOBUTAN" ], "mole_fractions": [ 0.596291711495645, 0.339399053279791, 0.064309235224564 ], "name": "R422D" }, { "fluids": [ "R134A", "R227EA" ], "mole_fractions": [ 0.648115324820034, 0.351884675179966 ], "name": "R423A" }, { "fluids": [ "R125", "R134A", "ISOBUTAN", "BUTANE", "IPENTANE" ], "mole_fractions": [ 0.45615402931289, 0.49939050863627, 0.0167872396578164, 0.0186524885086849, 0.00901573388433862 ], "name": "R424A" }, { "fluids": [ "R32", "R134A", "R227EA" ], "mole_fractions": [ 0.321134464075019, 0.615130603145805, 0.0637349327791751 ], "name": "R425A" }, { "fluids": [ "R125", "R134A", "BUTANE", "IPENTANE" ], "mole_fractions": [ 0.0431546741714159, 0.925684310853531, 0.0227152573734822, 0.00844575760157109 ], "name": "R426A" }, { "fluids": [ "R32", "R125", "R143A", "R134A" ], "mole_fractions": [ 0.260775797534104, 0.188391404795509, 0.107618901019853, 0.443213896650535 ], "name": "R427A" }, { "fluids": [ "R125", "R143A", "PROPANE", "ISOBUTAN" ], "mole_fractions": [ 0.694325251072399, 0.255893190962662, 0.0146310583647717, 0.0351504996001673 ], "name": "R428A" }, { "fluids": [ "DME", "R152A", "ISOBUTAN" ], "mole_fractions": [ 0.66113457206158, 0.0768533364747054, 0.262012091463714 ], "name": "R429A" }, { "fluids": [ "R152A", "ISOBUTAN" ], "mole_fractions": [ 0.735906531919507, 0.264093468080493 ], "name": "R430A" }, { "fluids": [ "PROPANE", "R152A" ], "mole_fractions": [ 0.785742532365466, 0.214257467634534 ], "name": "R431A" }, { "fluids": [ "PROPYLEN", "DME" ], "mole_fractions": [ 0.814097241703795, 0.185902758296205 ], "name": "R432A" }, { "fluids": [ "PROPYLEN", "PROPANE" ], "mole_fractions": [ 0.309917763130151, 0.690082236869849 ], "name": "R433A" }, { "fluids": [ "R125", "R143A", "R134A", "ISOBUTAN" ], "mole_fractions": [ 0.556782765664377, 0.226468961005242, 0.165810098372986, 0.0509381749573948 ], "name": "R434A" }, { "fluids": [ "DME", "R152A" ], "mole_fractions": [ 0.85152261670421, 0.14847738329579 ], "name": "R435A" }, { "fluids": [ "PROPANE", "ISOBUTAN" ], "mole_fractions": [ 0.62652773298942, 0.37347226701058 ], "name": "R436A" }, { "fluids": [ "PROPANE", "ISOBUTAN" ], "mole_fractions": [ 0.588127503607667, 0.411872496392333 ], "name": "R436B" }, { "fluids": [ "R125", "R134A", "BUTANE", "PENTANE" ], "mole_fractions": [ 0.168496314343733, 0.797898667324292, 0.0249804624362383, 0.00862455589573693 ], "name": "R437A" }, { "fluids": [ "R32", "R125", "R134A", "BUTANE", "IPENTANE" ], "mole_fractions": [ 0.161915681788051, 0.371558801739542, 0.42929872424902, 0.0289854872298073, 0.00824130499357989 ], "name": "R438A" }, { "fluids": [ "ETHANE", "PROPANE", "ISOBUTAN", "BUTANE" ], "mole_fractions": [ 0.049800395690461, 0.600310262208399, 0.0498654644324665, 0.300023877668674 ], "name": "R441A" }, { "fluids": [ "R32", "R125", "R134A", "R152A", "R227EA" ], "mole_fractions": [ 0.487220106766942, 0.211188495005419, 0.240409765511042, 0.0371371957951017, 0.0240444369214954 ], "name": "R442A" }, { "fluids": [ "PROPYLEN", "PROPANE", "ISOBUTAN" ], "mole_fractions": [ 0.568232931233387, 0.394367661677695, 0.0373994070889183 ], "name": "R443A" }, { "fluids": [ "R32", "R152A", "R1234ZE" ], "mole_fractions": [ 0.223042202171548, 0.0731981570161227, 0.703759640812329 ], "name": "R444A" }, { "fluids": [ "R12", "R152A" ], "mole_fractions": [ 0.606101741397223, 0.393898258602777 ], "name": "R500" }, { "fluids": [ "R22", "R12" ], "mole_fractions": [ 0.807509678166191, 0.192490321833809 ], "name": "R501" }, { "fluids": [ "R22", "R115" ], "mole_fractions": [ 0.629994467193889, 0.370005532806111 ], "name": "R502" }, { "fluids": [ "R23", "R13" ], "mole_fractions": [ 0.49970034990839, 0.50029965009161 ], "name": "R503" }, { "fluids": [ "R32", "R115" ], "mole_fractions": [ 0.734239632563771, 0.265760367436229 ], "name": "R504" }, { "fluids": [ "R125", "R143A" ], "mole_fractions": [ 0.411839711774438, 0.588160288225562 ], "name": "R507A" }, { "fluids": [ "R23", "R116" ], "mole_fractions": [ 0.557576966356198, 0.442423033643802 ], "name": "R508A" }, { "fluids": [ "R23", "R116" ], "mole_fractions": [ 0.626751006700703, 0.373248993299297 ], "name": "R508B" }, { "fluids": [ "R22", "R218" ], "mole_fractions": [ 0.630790210153023, 0.369209789846977 ], "name": "R509A" }, { "fluids": [ "DME", "ISOBUTAN" ], "mole_fractions": [ 0.902458936722509, 0.0975410632774913 ], "name": "R510A" }, { "fluids": [ "R134A", "R152A" ], "mole_fractions": [ 0.0329487458964343, 0.967051254103566 ], "name": "R512A" }, { "fluids": [ "METHANE", "NITROGEN", "CO2", "ETHANE", "PROPANE", "ISOBUTAN", "BUTANE", "IPENTANE", "PENTANE", "HEXANE" ], "mole_fractions": [ 0.965222, 0.002595, 0.005956, 0.018186, 0.004596, 0.000977, 0.001007, 0.000473, 0.000324, 0.000664 ], "name": "GulfCoastGas(NIST1)" }, { "fluids": [ "METHANE", "NITROGEN", "CO2", "ETHANE", "PROPANE", "ISOBUTAN", "BUTANE", "IPENTANE", "PENTANE", "HEXANE" ], "mole_fractions": [ 0.95123, 0.00089, 0.02555, 0.01835, 0.00238, 0.0004, 0.00016, 0.00014, 0.00011, 0.00079 ], "name": "TypicalNaturalGas" }, { "fluids": [ "R125", "R134A", "BUTANE" ], "mole_fractions": [ 0.744566872257699, 0.202885026732296, 0.052548101010005 ], "name": "R417B" }, { "fluids": [ "R125", "R134A", "BUTANE" ], "mole_fractions": [ 0.168533780311387, 0.801126056234188, 0.0303401634544254 ], "name": "R417C" }, { "fluids": [ "R125", "R134A", "DME" ], "mole_fractions": [ 0.425134881380361, 0.494935410459673, 0.0799297081599657 ], "name": "R419B" }, { "fluids": [ "R125", "R134A", "ISOBUTAN" ], "mole_fractions": [ 0.528211539833383, 0.421012248071509, 0.0507762120951078 ], "name": "R422E" }, { "fluids": [ "DME", "R152A", "ISOBUTAN" ], "mole_fractions": [ 0.66113457206158, 0.0768533364747054, 0.262012091463714 ], "name": "R429A" }, { "fluids": [ "R152A", "ISOBUTAN" ], "mole_fractions": [ 0.735906531919507, 0.264093468080493 ], "name": "R430A" }, { "fluids": [ "PROPANE", "R152A" ], "mole_fractions": [ 0.785742532365466, 0.214257467634534 ], "name": "R431A" }, { "fluids": [ "PROPYLEN", "DME" ], "mole_fractions": [ 0.814097241703795, 0.185902758296205 ], "name": "R432A" }, { "fluids": [ "PROPYLEN", "PROPANE" ], "mole_fractions": [ 0.309917763130151, 0.690082236869849 ], "name": "R433A" }, { "fluids": [ "PROPYLEN", "PROPANE" ], "mole_fractions": [ 0.0522701063955236, 0.947729893604476 ], "name": "R433B" }, { "fluids": [ "PROPYLEN", "PROPANE" ], "mole_fractions": [ 0.25887610544032, 0.74112389455968 ], "name": "R433C" }, { "fluids": [ "R125", "R143A", "R134A", "ISOBUTAN" ], "mole_fractions": [ 0.556782765664377, 0.226468961005242, 0.165810098372986, 0.0509381749573948 ], "name": "R434A" }, { "fluids": [ "R32", "R125", "R134A", "BUTANE", "IPENTANE" ], "mole_fractions": [ 0.161915681788051, 0.371558801739542, 0.42929872424902, 0.0289854872298073, 0.00824130499357989 ], "name": "R438A" }, { "fluids": [ "R32", "R125", "ISOBUTAN" ], "mole_fractions": [ 0.684390813603997, 0.278854127894844, 0.0367550585011589 ], "name": "R439A" }, { "fluids": [ "PROPANE", "R134A", "R152A" ], "mole_fractions": [ 0.00901134733203068, 0.0103852633851142, 0.980603389282855 ], "name": "R440A" }, { "fluids": [ "R32", "R152A", "R1234ZE" ], "mole_fractions": [ 0.580409174767712, 0.11015659826248, 0.309434226969808 ], "name": "R444B" }, { "fluids": [ "CO2", "R134A", "R1234ZE" ], "mole_fractions": [ 0.14056672736859, 0.0909466670967859, 0.768486605534624 ], "name": "R445A" }, { "fluids": [ "R32", "R1234ZE", "BUTANE" ], "mole_fractions": [ 0.810347789312053, 0.157652541387366, 0.0319996693005808 ], "name": "R446A" }, { "fluids": [ "R32", "R125", "R1234ZE" ], "mole_fractions": [ 0.824059115538506, 0.0183849541922025, 0.157555930269292 ], "name": "R447A" }, { "fluids": [ "R32", "R125", "R1234YF", "R134A", "R1234ZE" ], "mole_fractions": [ 0.431218201988559, 0.186914131481992, 0.151319256485899, 0.177586673617217, 0.0529617364263329 ], "name": "R448A" }, { "fluids": [ "R32", "R125", "R1234YF", "R134A" ], "mole_fractions": [ 0.407364566995509, 0.179481207732065, 0.193480840388364, 0.219673384884062 ], "name": "R449A" }, { "fluids": [ "R32", "R125", "R1234YF", "R134A" ], "mole_fractions": [ 0.418353331871839, 0.174861426767915, 0.175699749729428, 0.231085491630818 ], "name": "R449B" }, { "fluids": [ "R134A", "R1234ZE" ], "mole_fractions": [ 0.447322067369848, 0.552677932630152 ], "name": "R450A" }, { "fluids": [ "R1234YF", "R134A" ], "mole_fractions": [ 0.887346670041529, 0.112653329958471 ], "name": "R451A" }, { "fluids": [ "R1234YF", "R134A" ], "mole_fractions": [ 0.876445928959364, 0.123554071040636 ], "name": "R451B" }, { "fluids": [ "R32", "R125", "R1234YF" ], "mole_fractions": [ 0.218864360337465, 0.508837870465814, 0.272297769196721 ], "name": "R452A" }, { "fluids": [ "R32", "R125", "R134A", "R227EA", "BUTANE", "IPENTANE" ], "mole_fractions": [ 0.341295928327855, 0.147936968933237, 0.468112901696291, 0.0261066945175942, 0.0091646080754323, 0.00738289844959133 ], "name": "R453A" }, { "fluids": [ "R32", "R1234YF" ], "mole_fractions": [ 0.541359992223361, 0.458640007776639 ], "name": "R454A" }, { "fluids": [ "R32", "R1234YF" ], "mole_fractions": [ 0.829247912869081, 0.170752087130919 ], "name": "R454B" }, { "fluids": [ "PROPANE", "DME" ], "mole_fractions": [ 0.952038489443906, 0.0479615105560936 ], "name": "R511A" }, { "fluids": [ "R1234YF", "R134A" ], "mole_fractions": [ 0.532425755929735, 0.467574244070265 ], "name": "R513A" } ] ================================================ FILE: notebooks/propsSI_fluids.csv ================================================ propsName,menuName,idName,order,category,basic,compressibleMixtureComponent,incompressible,incompressibleMixture,minConcentration,maxConcentration,longDescription Air,Dry Air,Air,1,"Air, Humid Air, and Water",TRUE,TRUE,FALSE,FALSE,null,null, HumidAir,Humid Air (Psychrometrics),HumidAir,1,"Air, Humid Air, and Water",TRUE,FALSE,FALSE,FALSE,null,null, Water,Water (IAPWS-95),Water,1,"Air, Humid Air, and Water",TRUE,TRUE,FALSE,FALSE,null,null, 1-Butene,1-Butene,But1ene,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Acetone,Acetone,Acetone,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Ammonia,Ammonia,Ammonia,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Argon,Argon,Argon,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Benzene,Benzene,Benzene,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, CarbonDioxide,Carbon Dioxide,CarbonDioxide,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, CarbonMonoxide,Carbon Monoxide,CarbonMonoxide,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, CarbonylSulfide,Carbonyl Sulfide,CarbonylSulfide,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, cis-2-Butene,cis-2-Butene,cis2Butene,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, CycloHexane,Cyclohexane,Cyclohexane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Cyclopentane,Cyclopentane,Cyclopentane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, CycloPropane,Cyclopropane,Cyclopropane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, D4,D4,D4,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, D5,D5,D5,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, D6,D6,D6,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Deuterium,Deuterium,Deuterium,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Dichloroethane,Dichloroethane,Dichloroethane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, DiethylEther,Diethyl Ether,DiethylEther,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, DimethylCarbonate,Dimethyl Carbonate,DimethylCarbonate,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, DimethylEther,Dimethyl Ether,DimethylEther,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Ethane,Ethane,Ethane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Ethanol,Ethanol,Ethanol,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, EthylBenzene,Ethylbenzene,Ethylbenzene,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Ethylene,Ethylene,Ethylene,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, EthyleneOxide,Ethylene Oxide,EthyleneOxide,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Fluorine,Fluorine,Fluorine,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, HeavyWater,Heavy Water,HeavyWater,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Helium,Helium,Helium,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, HFE143m,HFE-143m,HFE143m,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Hydrogen,Hydrogen,Hydrogen,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, HydrogenChloride,Hydrogen Chloride,HydrogenChloride,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, HydrogenSulfide,Hydrogen Sulfide,HydrogenSulfide,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, IsoButane,Isobutane,Isobutane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, IsoButene,Isobutene,Isobutene,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Isohexane,Isohexane,Isohexane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Isopentane,Isopentane,Isopentane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Krypton,Krypton,Krypton,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, m-Xylene,m-Xylene,mXylene,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, MD2M,MD2M (Decamethyltetrasiloxane),MD2M,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, MD3M,MD3M (Dodecamethylpentasiloxane),MD3M,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, MD4M,MD4M (Tetradecamethylhexasiloxane),MD4M,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, MDM,MDM (Octamethyltrisiloxane),MDM,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Methane,Methane,Methane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Methanol,Methanol,Methanol,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, MethylLinoleate,Methyl Linoleate,MethylLinoleate,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, MethylLinolenate,Methyl Linolenate,MethylLinolenate,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, MethylOleate,Methyl Oleate,MethylOleate,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, MethylPalmitate,Methyl Palmitate,MethylPalmitate,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, MethylStearate,Methyl Stearate,MethylStearate,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, MM,MM (Hexamethyldisiloxane),MM,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, n-Butane,n-Butane,nButane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, n-Decane,n-Decane,nDecane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, n-Dodecane,n-Dodecane,nDodecane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, n-Heptane,n-Heptane,nHeptane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, n-Hexane,n-Hexane,nHexane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, n-Nonane,n-Nonane,nNonane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, n-Octane,n-Octane,nOctane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, n-Pentane,n-Pentane,nPentane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, n-Propane,n-Propane,nPropane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, n-Undecane,n-Undecane,nUndecane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Neon,Neon,Neon,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Neopentane,Neopentane,Neopentane,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Nitrogen,Nitrogen,Nitrogen,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, NitrousOxide,Nitrous Oxide,NitrousOxide,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Novec649,Novec 649,Novec649,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, o-Xylene,o-Xylene,oXylene,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, OrthoDeuterium,Orthodeuterium,OrthoDeuterium,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, OrthoHydrogen,Orthohydrogen,OrthoHydrogen,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Oxygen,Oxygen,Oxygen,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, p-Xylene,p-Xylene,pXylene,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, ParaDeuterium,Paradeuterium,ParaDeuterium,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, ParaHydrogen,Parahydrogen,ParaHydrogen,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Propylene,Propylene,Propylene,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Propyne,Propyne,Propyne,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R11,R11,R11,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R113,R113,R113,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R114,R114,R114,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R115,R115,R115,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R116,R116,R116,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R12,R12,R12,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R123,R123,R123,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R1233zd(E),R1233zd(E),R1233zdE,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R1234yf,R1234yf,R1234yf,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R1234ze(E),R1234ze(E),R1234zeE,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R1234ze(Z),R1234ze(Z),R1234zeZ,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R124,R124,R124,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R1243zf,R1243zf,R1243zf,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R125,R125,R125,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R1336mzz(E),R1336mzz(E),R1336MZZE,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R13,R13,R13,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R134a,R134a,R134a,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R13I1,R13I1,R13I1,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R14,R14,R14,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R141b,R141b,R141b,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R142b,R142b,R142b,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R143a,R143a,R143a,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R152A,R152A,R152A,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R161,R161,R161,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R21,R21,R21,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R218,R218,R218,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R22,R22,R22,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R227EA,R227EA,R227EA,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R23,R23,R23,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R236EA,R236EA,R236EA,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R236FA,R236FA,R236FA,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R245ca,R245ca,R245ca,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R245fa,R245fa,R245fa,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R32,R32,R32,2,Pure and Pseudo-Pure Fluids,TRUE,TRUE,FALSE,FALSE,null,null, R365MFC,R365MFC,R365MFC,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R40,R40,R40,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R404A,R404A,R404A,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R407C,R407C,R407C,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R41,R41,R41,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R410A,R410A,R410A,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, R507A,R507A,R507A,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, RC318,RC318,RC318,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, SES36,SES36,SES36,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, SulfurDioxide,Sulfur Dioxide,SulfurDioxide,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, SulfurHexafluoride,Sulfur Hexafluoride,SulfurHexafluoride,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, Toluene,Toluene,Toluene,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, trans-2-Butene,trans-2-Butene,trans2Butene,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, IF97::Water,Water (IAPWS-IF97),Water,2,Pure and Pseudo-Pure Fluids,TRUE,FALSE,FALSE,FALSE,null,null, Xenon,Xenon,Xenon,2,Pure and Pseudo-Pure Fluids,FALSE,TRUE,FALSE,FALSE,null,null, INCOMP::Acetone,"Acetone, liquid phase at 10 bar",Acetone,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::Air,"Air, gaseous phase at 1 atm (101325 Pa)",Air,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::AS10,"Aspen Temper -10, Potassium acetate/formate",AS10,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::AS20,"Aspen Temper -20, Potassium acetate/formate",AS20,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::AS30,"Aspen Temper -30, Potassium acetate/formate",AS30,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::AS40,"Aspen Temper -40, Potassium acetate/formate",AS40,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::AS55,"Aspen Temper -55, Potassium acetate/formate",AS55,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::TCO,Citrus oil terpene - d-Limonene,TCO,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::DEB,Diethylbenzene mixture - Dowtherm J,DEB,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::DowJ2,"Dowtherm J, Diethylbenzene mixture",DowJ2,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::DowQ2,"Dowtherm Q, Diphenylethane/alkylated aromatics",DowQ2,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::DowJ,DowthermJ,DowJ,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::DowQ,DowthermQ,DowQ,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HC10,Dynalene HC10,HC10,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HC20,Dynalene HC20,HC20,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HC30,Dynalene HC30,HC30,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HC40,Dynalene HC40,HC40,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HC50,Dynalene HC50,HC50,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::DSF,Dynalene SF,DSF,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::Ethanol,"Ethanol, liquid phase at 10 bar",Ethanol,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::FoodAsh,Food ash model from the 2006 ASHRAE Handbook,FoodAsh,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::FoodCarbohydrate,Food carbohydrate model from the 2006 ASHRAE Handbook,FoodCarbohydrate,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::FoodFat,Food fat model from the 2006 ASHRAE Handbook,FoodFat,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::FoodFiber,Food fiber model from the 2006 ASHRAE Handbook,FoodFiber,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::FoodIce,Food ice model from the 2006 ASHRAE Handbook,FoodIce,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::FoodProtein,Food protein model from the 2006 ASHRAE Handbook,FoodProtein,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::FoodWater,Food water model from the 2006 ASHRAE Handbook,FoodWater,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::Hexane,"Hexane, liquid phase at 10 bar",Hexane,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HFE2,"HFE-7100, Hydrofluoroether",HFE2,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HY20,"HYCOOL 20, Potassium formate",HY20,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HY30,"HyCool 30, Potassium formate",HY30,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HY40,"HyCool 40, Potassium formate",HY40,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HY45,"HyCool 45, Potassium formate",HY45,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HY50,"HyCool 50, Potassium formate",HY50,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HCB,Hydrocarbon blend - Dynalene MV,HCB,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HCM,Hydrocarbon mixture - Gilotherm D12,HCM,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::HFE,Hydrofluoroether - HFE-7100 3M Novec,HFE,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::LiqNa,LiqNa,LiqNa,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::NaK,"Nitrate salt, 0.6 NaNO3 and 0.4 KNO3",NaK,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::PCL,"Paracryol, Aliphatic Hydrocarbon",PCL,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::PCR,Paratherm CR,PCR,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::PGLT,Paratherm GLT,PGLT,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::PHE,Paratherm HE,PHE,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::PHR,Paratherm HR,PHR,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::PLR,Paratherm LR,PLR,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::PMR,Paratherm MR,PMR,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::PNF,Paratherm NF,PNF,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::PNF2,"Paratherm NF, Hydrotreated mineral oil",PNF2,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::PBB,Pirobloc HTF-BASIC,PBB,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::PMS1,Polydimethylsiloxan 1 - Baysilone KT3,PMS1,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::PMS2,Polydimethylsiloxan 2 - Syltherm XLT,PMS2,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::S800,Syltherm 800,S800,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::XLT2,"Syltherm XLT, Polydimethylsiloxan",XLT2,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::XLT,SylthermXLT,XLT,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::SAB,Synthetic alkyl benzene - Marlotherm X,SAB,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::TX22,Texatherm22,TX22,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::T66,Therminol66,T66,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::T72,Therminol72,T72,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::TD12,TherminolD12,TD12,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::TVP1,TherminolVP1,TVP1,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::TVP1869,Thermogen VP 1869,TVP1869,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::TY10,"Tyfoxit 1.10, Potassium Acetate",TY10,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::TY15,"Tyfoxit 1.15, Potassium Acetate",TY15,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::TY20,"Tyfoxit 1.20, Potassium Acetate",TY20,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::TY24,"Tyfoxit 1.24, Potassium Acetate",TY24,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::Water,"Water, fit of EOS from 1 bar to 100 bar",Water,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::NBS,"Water, NBS",NBS,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::ZS10,"Zitrec S10, Potassium formate/Sodium propionate",ZS10,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::ZS25,"Zitrec S25, Potassium formate/Sodium propionate",ZS25,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::ZS40,"Zitrec S40, Potassium formate/Sodium propionate",ZS40,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::ZS45,"Zitrec S45, Potassium formate/Sodium propionate",ZS45,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::ZS55,"Zitrec S55, Potassium formate/Sodium propionate",ZS55,3,Incompressible Fluids,FALSE,FALSE,TRUE,FALSE,null,null, INCOMP::MAM,Ammonia (NH3) - aq,MAM,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.3,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.3 (all water=0.0, no water=1.0)" INCOMP::MAM2,"Ammonia, Melinder",MAM2,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.08,0.24,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.08 - 0.24 (all water=0.0, no water=1.0)" INCOMP::MCA,Calcium Chloride (CaCl2) - aq,MCA,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.3,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.3 (all water=0.0, no water=1.0)" INCOMP::MCA2,"Calcium Chloride, Melinder",MCA2,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.09,0.29,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.09 - 0.29 (all water=0.0, no water=1.0)" INCOMP::VCA,"Calcium Cloride, VDI",VCA,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.15,0.3,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.15 - 0.3 (all water=0.0, no water=1.0)" INCOMP::MEA2,"Ethanol, Melinder",MEA2,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.11,0.6,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.11 - 0.6 (all water=0.0, no water=1.0)" INCOMP::MEA,Ethyl Alcohol (Ethanol) - aq,MEA,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.6,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.6 (all water=0.0, no water=1.0)" INCOMP::MEG,Ethylene Glycol - aq,MEG,4,Incompressible Mass-Based Aqueous Solutions,TRUE,FALSE,TRUE,TRUE,0,0.6,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.6 (all water=0.0, no water=1.0)" INCOMP::MEG2,"Ethylene Glycol, Melinder",MEG2,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.56,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.56 (all water=0.0, no water=1.0)" INCOMP::FRE,"Freezium, Potassium Formate",FRE,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.19,0.5,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.19 - 0.5 (all water=0.0, no water=1.0)" INCOMP::MGL,Glycerol - aq,MGL,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.6,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.6 (all water=0.0, no water=1.0)" INCOMP::MGL2,"Glycerol, Melinder",MGL2,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.2,0.63,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.2 - 0.63 (all water=0.0, no water=1.0)" INCOMP::IceEA,Ice slurry with Ethanol,IceEA,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.05,0.35,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.05 - 0.35 (all water=0.0, no water=1.0)" INCOMP::IceNA,Ice slurry with NaCl,IceNA,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.05,0.35,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.05 - 0.35 (all water=0.0, no water=1.0)" INCOMP::IcePG,Ice slurry with Propylene Glycol,IcePG,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.05,0.35,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.05 - 0.35 (all water=0.0, no water=1.0)" INCOMP::MLI,Lithium Chloride (LiCl) - aq,MLI,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.24,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.24 (all water=0.0, no water=1.0)" INCOMP::LiBr,Lithium-bromide solution - aq,LiBr,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.75,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.75 (all water=0.0, no water=1.0)" INCOMP::MMG2,"Magnesium Chloride, Melinder",MMG2,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.21,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.21 (all water=0.0, no water=1.0)" INCOMP::VMG,"Magnesium Chloride, VDI",VMG,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.07,0.21,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.07 - 0.21 (all water=0.0, no water=1.0)" INCOMP::MMA2,"Methanol, Melinder",MMA2,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.08,0.47,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.08 - 0.47 (all water=0.0, no water=1.0)" INCOMP::VMA,"Methanol, VDI",VMA,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.1,0.9,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.1 - 0.9 (all water=0.0, no water=1.0)" INCOMP::MMA,Methyl Alcohol (Methanol) - aq,MMA,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.6,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.6 (all water=0.0, no water=1.0)" INCOMP::MMG,MgCl2 - aq,MMG,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.3,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.3 (all water=0.0, no water=1.0)" INCOMP::MKA,Potassium Acetate (CH3CO2K) - aq,MKA,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.45,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.45 (all water=0.0, no water=1.0)" INCOMP::MKA2,"Potassium Acetate, Melinder",MKA2,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.11,0.41,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.11 - 0.41 (all water=0.0, no water=1.0)" INCOMP::MKC,Potassium Carbonate (K2CO3) - aq,MKC,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.4,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.4 (all water=0.0, no water=1.0)" INCOMP::MKC2,"Potassium Carbonate, Melinder",MKC2,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.39,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.39 (all water=0.0, no water=1.0)" INCOMP::VKC,"Potassium Carbonate, VDI",VKC,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.13,0.39,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.13 - 0.39 (all water=0.0, no water=1.0)" INCOMP::MKF,Potassium Formate (CHKO2) - aq,MKF,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.48,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.48 (all water=0.0, no water=1.0)" INCOMP::MPG,Propylene Glycol - aq,MPG,4,Incompressible Mass-Based Aqueous Solutions,TRUE,FALSE,TRUE,TRUE,0,0.6,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.6 (all water=0.0, no water=1.0)" INCOMP::MPG2,"Propylene Glycol, Melinder",MPG2,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.15,0.57,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.15 - 0.57 (all water=0.0, no water=1.0)" INCOMP::MITSW,"Seawater, MIT",MITSW,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.12,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.12 (all water=0.0, no water=1.0)" INCOMP::MNA,Sodium Chloride (NaCl) - aq,MNA,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.23,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.23 (all water=0.0, no water=1.0)" INCOMP::MNA2,"Sodium Chloride, Melinder",MNA2,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,0.23,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.23 (all water=0.0, no water=1.0)" INCOMP::VNA,"Sodium Chloride, VDI",VNA,4,Incompressible Mass-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.07,0.23,"Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.07 - 0.23 (all water=0.0, no water=1.0)" INCOMP::AKF,"Antifrogen KF, Potassium Formate",AKF,5,Incompressible Volume-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.4,1,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.4 - 1 (all water=0.0, no water=1.0)" INCOMP::AL,"Antifrogen L, Propylene Glycol",AL,5,Incompressible Volume-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.1,0.6,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.1 - 0.6 (all water=0.0, no water=1.0)" INCOMP::AN,"Antifrogen N, Ethylene Glycol",AN,5,Incompressible Volume-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.1,0.6,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.1 - 0.6 (all water=0.0, no water=1.0)" INCOMP::AEG,"Ethylene Glycol, ASHRAE",AEG,5,Incompressible Volume-Based Aqueous Solutions,TRUE,FALSE,TRUE,TRUE,0.1,0.6,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.1 - 0.6 (all water=0.0, no water=1.0)" INCOMP::GKN,"Glykosol N, Ethylene Glycol",GKN,5,Incompressible Volume-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.1,0.6,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.1 - 0.6 (all water=0.0, no water=1.0)" INCOMP::PK2,"Pekasol 2000, K acetate/formate",PK2,5,Incompressible Volume-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.3,1,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.3 - 1 (all water=0.0, no water=1.0)" INCOMP::PKL,"Pekasol L, Propylene Glycol",PKL,5,Incompressible Volume-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.1,0.6,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.1 - 0.6 (all water=0.0, no water=1.0)" INCOMP::APG,"Propylene Glycol, ASHRAE",APG,5,Incompressible Volume-Based Aqueous Solutions,TRUE,FALSE,TRUE,TRUE,0.1,0.6,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.1 - 0.6 (all water=0.0, no water=1.0)" INCOMP::ZAC,"Zitrec AC, Corrosion Inhibitor",ZAC,5,Incompressible Volume-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.06,0.5,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.06 - 0.5 (all water=0.0, no water=1.0)" INCOMP::ZFC,"Zitrec FC, Propylene Glycol",ZFC,5,Incompressible Volume-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.3,0.6,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.3 - 0.6 (all water=0.0, no water=1.0)" INCOMP::ZLC,"Zitrec LC, Propylene Glycol",ZLC,5,Incompressible Volume-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.3,0.7,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.3 - 0.7 (all water=0.0, no water=1.0)" INCOMP::ZM,"Zitrec M, Ethylene Glycol",ZM,5,Incompressible Volume-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0,1,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0 - 1 (all water=0.0, no water=1.0)" INCOMP::ZMC,"Zitrec MC, Ethylene Glycol",ZMC,5,Incompressible Volume-Based Aqueous Solutions,FALSE,FALSE,TRUE,TRUE,0.3,0.7,"Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.3 - 0.7 (all water=0.0, no water=1.0)" CustomMixture,Mixture (User Defined),Mixture,6,User Defined Mixture of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null, Air.mix,Air,AirMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - NITROGEN: 0.7812, ARGON: 0.0092, OXYGEN: 0.2096" Amarillo.mix,Amarillo,AmarilloMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.906724, NITROGEN: 0.031284, CO2: 0.004676, ETHANE: 0.045279, PROPANE: 0.00828, ISOBUTAN: 0.001037, BUTANE: 0.001563, IPENTANE: 0.000321, PENTANE: 0.000443, HEXANE: 0.000393" Ekofisk.mix,Ekofisk,EkofiskMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.859063, NITROGEN: 0.010068, CO2: 0.014954, ETHANE: 0.084919, PROPANE: 0.023015, ISOBUTAN: 0.003486, BUTANE: 0.003506, IPENTANE: 0.000509, PENTANE: 0.00048" GulfCoast.mix,Gulf Coast,GulfCoastMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.965222, NITROGEN: 0.002595, CO2: 0.005956, ETHANE: 0.018186, PROPANE: 0.004596, ISOBUTAN: 0.000977, BUTANE: 0.001007, IPENTANE: 0.000473, PENTANE: 0.000324, HEXANE: 0.000664" GulfCoastGas(NIST1).mix,Gulf Coast Gas (NIST1),GulfCoastGasMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.965222, NITROGEN: 0.002595, CO2: 0.005956, ETHANE: 0.018186, PROPANE: 0.004596, ISOBUTAN: 0.000977, BUTANE: 0.001007, IPENTANE: 0.000473, PENTANE: 0.000324, HEXANE: 0.000664" HighCO2.mix,High CO2,HighCO2Mixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.81212, NITROGEN: 0.05702, CO2: 0.07585, ETHANE: 0.04303, PROPANE: 0.00895, ISOBUTAN: 0.00151, BUTANE: 0.00152" HighN2.mix,High N2,HighN2Mixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.81441, NITROGEN: 0.13465, CO2: 0.00985, ETHANE: 0.033, PROPANE: 0.00605, ISOBUTAN: 0.001, BUTANE: 0.00104" NaturalGasSample.mix,Natural Gas Sample,NaturalGasSampleMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.95123, NITROGEN: 0.00089, CO2: 0.02555, ETHANE: 0.01835, PROPANE: 0.00238, ISOBUTAN: 0.0004, BUTANE: 0.00016, IPENTANE: 0.00014, PENTANE: 0.00011, HEXANE: 0.00079" TypicalNaturalGas.mix,"Natural Gas, Typical",TypicalNaturalGasMixture,7,Predefined Mixtures of Pure Fluids,TRUE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.95123, NITROGEN: 0.00089, CO2: 0.02555, ETHANE: 0.01835, PROPANE: 0.00238, ISOBUTAN: 0.0004, BUTANE: 0.00016, IPENTANE: 0.00014, PENTANE: 0.00011, HEXANE: 0.00079" R401A.mix,R401A,R401AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.578854210704231, R152A: 0.185871453986601, R124: 0.235274335309169" R401B.mix,R401B,R401BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.654924685341436, R152A: 0.154607382276918, R124: 0.190467932381646" R401C.mix,R401C,R401CMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.385591186504412, R152A: 0.229445970225924, R124: 0.384962843269664" R402A.mix,R402A,R402AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.507659889396724, PROPANE: 0.0460590346231213, R22: 0.446281075980154" R402B.mix,R402B,R402BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.299858744498276, PROPANE: 0.0429562491180057, R22: 0.657185006383719" R403A.mix,R403A,R403AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.104301635230068, R22: 0.797852142841926, R218: 0.0978462219280052" R403B.mix,R403B,R403BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.117083478399255, R22: 0.668734422027154, R218: 0.214182099573591" R404A.mix,R404A,R404AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.357816784026318, R134A: 0.0382639950410712, R143A: 0.603919220932611" R405A.mix,R405A,R405AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.582397185883849, R152A: 0.118598940913682, R142B: 0.0612463586573, RC318: 0.237757514545169" R406A.mix,R406A,R406AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.571559096367276, ISOBUTAN: 0.0618403319459979, R142B: 0.366600571686726" R407A.mix,R407A,R407AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.346419854360797, R125: 0.300315552114308, R134A: 0.353264593524896" R407B.mix,R407B,R407BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.197865007175653, R125: 0.600360468492644, R134A: 0.201774524331703" R407C.mix,R407C,R407CMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.381109419953993, R125: 0.179558888662016, R134A: 0.439331691383991" R407D.mix,R407D,R407DMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.262268077791873, R125: 0.113681680758968, R134A: 0.624050241449159" R407E.mix,R407E,R407EMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.402611526984881, R125: 0.104708637358978, R134A: 0.492679835656141" R407F.mix,R407F,R407FMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.473194694453358, R125: 0.205109095413331, R134A: 0.321696210133311" R408A.mix,R408A,R408AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.0507496395780536, R143A: 0.476277681499092, R22: 0.472972678922854" R409A.mix,R409A,R409AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.676088021274302, R124: 0.178481953421098, R142B: 0.1454300253046" R409B.mix,R409B,R409BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.726713817097545, R124: 0.177089324155708, R142B: 0.0961968587467468" R410A.mix,R410A,R410AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.697614699375863, R125: 0.302385300624138" R410B.mix,R410B,R410BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.653688938033229, R125: 0.346311061966771" R411A.mix,R411A,R411AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.0293595987641706, R22: 0.833472654512905, R152A: 0.137167746722925" R411B.mix,R411B,R411BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.0592216130255444, R22: 0.903048917855743, R152A: 0.0377294691187131" R412A.mix,R412A,R412AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.746189416536491, R218: 0.0245117299030133, R142B: 0.229298853560496" R413A.mix,R413A,R413AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R218: 0.0497604388838132, R134A: 0.896582929746185, ISOBUTAN: 0.0536566313700015" R414A.mix,R414A,R414AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.571718248653786, R124: 0.202422623615037, ISOBUTAN: 0.0667091242374272, R142B: 0.159150003493749" R414B.mix,R414B,R414BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.58743911052603, R124: 0.29030851296569, ISOBUTAN: 0.0262178745861124, R142B: 0.0960345019221677" R415A.mix,R415A,R415AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.776780159383737, R152A: 0.223219840616263" R415B.mix,R415B,R415BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.202949716550675, R152A: 0.797050283449325" R416A.mix,R416A,R416AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R134A: 0.647182715864291, R124: 0.323933072881677, BUTANE: 0.0288842112540324" R417A.mix,R417A,R417AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.414456113615123, R134A: 0.523100248809492, BUTANE: 0.0624436375753851" R417B.mix,R417B,R417BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.744566872257699, R134A: 0.202885026732296, BUTANE: 0.052548101010005" R417C.mix,R417C,R417CMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.168533780311387, R134A: 0.801126056234188, BUTANE: 0.0303401634544254" R418A.mix,R418A,R418AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.0287766462758765, R22: 0.939204558675462, R152A: 0.0320187950486611" R419A.mix,R419A,R419AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.701459965531065, R134A: 0.203604819551495, DME: 0.0949352149174398" R419B.mix,R419B,R419BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.425134881380361, R134A: 0.494935410459673, DME: 0.0799297081599657" R420A.mix,R420A,R420AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R134A: 0.878387913267685, R142B: 0.121612086732315" R421A.mix,R421A,R421AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.540011717389644, R134A: 0.459988282610356" R421B.mix,R421B,R421BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.828099498512419, R134A: 0.171900501487581" R422A.mix,R422A,R422AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.805501067600345, R134A: 0.128043250123554, ISOBUTAN: 0.0664556822761011" R422B.mix,R422B,R422BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.497287395965083, R134A: 0.446700400155301, ISOBUTAN: 0.0560122038796163" R422C.mix,R422C,R422CMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.774757115908852, R134A: 0.166711388687975, ISOBUTAN: 0.0585314954031729" R422D.mix,R422D,R422DMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.596291711495645, R134A: 0.339399053279791, ISOBUTAN: 0.064309235224564" R422E.mix,R422E,R422EMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.528211539833383, R134A: 0.421012248071509, ISOBUTAN: 0.0507762120951078" R423A.mix,R423A,R423AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R134A: 0.648115324820034, R227EA: 0.351884675179966" R424A.mix,R424A,R424AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.45615402931289, R134A: 0.49939050863627, ISOBUTAN: 0.0167872396578164, BUTANE: 0.0186524885086849, IPENTANE: 0.00901573388433862" R425A.mix,R425A,R425AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.321134464075019, R134A: 0.615130603145805, R227EA: 0.0637349327791751" R426A.mix,R426A,R426AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.0431546741714159, R134A: 0.925684310853531, BUTANE: 0.0227152573734822, IPENTANE: 0.00844575760157109" R427A.mix,R427A,R427AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.260775797534104, R125: 0.188391404795509, R143A: 0.107618901019853, R134A: 0.443213896650535" R428A.mix,R428A,R428AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.694325251072399, R143A: 0.255893190962662, PROPANE: 0.0146310583647717, ISOBUTAN: 0.0351504996001673" R429A.mix,R429A,R429AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - DME: 0.66113457206158, R152A: 0.0768533364747054, ISOBUTAN: 0.262012091463714" R429A.mix,R429A,R429AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - DME: 0.66113457206158, R152A: 0.0768533364747054, ISOBUTAN: 0.262012091463714" R430A.mix,R430A,R430AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R152A: 0.735906531919507, ISOBUTAN: 0.264093468080493" R430A.mix,R430A,R430AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R152A: 0.735906531919507, ISOBUTAN: 0.264093468080493" R431A.mix,R431A,R431AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.785742532365466, R152A: 0.214257467634534" R431A.mix,R431A,R431AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.785742532365466, R152A: 0.214257467634534" R432A.mix,R432A,R432AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.814097241703795, DME: 0.185902758296205" R432A.mix,R432A,R432AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.814097241703795, DME: 0.185902758296205" R433A.mix,R433A,R433AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.309917763130151, PROPANE: 0.690082236869849" R433A.mix,R433A,R433AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.309917763130151, PROPANE: 0.690082236869849" R433B.mix,R433B,R433BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.0522701063955236, PROPANE: 0.947729893604476" R433C.mix,R433C,R433CMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.25887610544032, PROPANE: 0.74112389455968" R434A.mix,R434A,R434AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.556782765664377, R143A: 0.226468961005242, R134A: 0.165810098372986, ISOBUTAN: 0.0509381749573948" R434A.mix,R434A,R434AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.556782765664377, R143A: 0.226468961005242, R134A: 0.165810098372986, ISOBUTAN: 0.0509381749573948" R435A.mix,R435A,R435AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - DME: 0.85152261670421, R152A: 0.14847738329579" R436A.mix,R436A,R436AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.62652773298942, ISOBUTAN: 0.37347226701058" R436B.mix,R436B,R436BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.588127503607667, ISOBUTAN: 0.411872496392333" R437A.mix,R437A,R437AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.168496314343733, R134A: 0.797898667324292, BUTANE: 0.0249804624362383, PENTANE: 0.00862455589573693" R438A.mix,R438A,R438AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.161915681788051, R125: 0.371558801739542, R134A: 0.42929872424902, BUTANE: 0.0289854872298073, IPENTANE: 0.00824130499357989" R438A.mix,R438A,R438AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.161915681788051, R125: 0.371558801739542, R134A: 0.42929872424902, BUTANE: 0.0289854872298073, IPENTANE: 0.00824130499357989" R439A.mix,R439A,R439AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.684390813603997, R125: 0.278854127894844, ISOBUTAN: 0.0367550585011589" R440A.mix,R440A,R440AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.00901134733203068, R134A: 0.0103852633851142, R152A: 0.980603389282855" R441A.mix,R441A,R441AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - ETHANE: 0.049800395690461, PROPANE: 0.600310262208399, ISOBUTAN: 0.0498654644324665, BUTANE: 0.300023877668674" R442A.mix,R442A,R442AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.487220106766942, R125: 0.211188495005419, R134A: 0.240409765511042, R152A: 0.0371371957951017, R227EA: 0.0240444369214954" R443A.mix,R443A,R443AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.568232931233387, PROPANE: 0.394367661677695, ISOBUTAN: 0.0373994070889183" R444A.mix,R444A,R444AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.223042202171548, R152A: 0.0731981570161227, R1234ZE: 0.703759640812329" R444B.mix,R444B,R444BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.580409174767712, R152A: 0.11015659826248, R1234ZE: 0.309434226969808" R445A.mix,R445A,R445AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - CO2: 0.14056672736859, R134A: 0.0909466670967859, R1234ZE: 0.768486605534624" R446A.mix,R446A,R446AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.810347789312053, R1234ZE: 0.157652541387366, BUTANE: 0.0319996693005808" R447A.mix,R447A,R447AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.824059115538506, R125: 0.0183849541922025, R1234ZE: 0.157555930269292" R448A.mix,R448A,R448AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.431218201988559, R125: 0.186914131481992, R1234YF: 0.151319256485899, R134A: 0.177586673617217, R1234ZE: 0.0529617364263329" R449A.mix,R449A,R449AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.407364566995509, R125: 0.179481207732065, R1234YF: 0.193480840388364, R134A: 0.219673384884062" R449B.mix,R449B,R449BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.418353331871839, R125: 0.174861426767915, R1234YF: 0.175699749729428, R134A: 0.231085491630818" R450A.mix,R450A,R450AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R134A: 0.447322067369848, R1234ZE: 0.552677932630152" R451A.mix,R451A,R451AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R1234YF: 0.887346670041529, R134A: 0.112653329958471" R451B.mix,R451B,R451BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R1234YF: 0.876445928959364, R134A: 0.123554071040636" R452A.mix,R452A,R452AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.218864360337465, R125: 0.508837870465814, R1234YF: 0.272297769196721" R453A.mix,R453A,R453AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.341295928327855, R125: 0.147936968933237, R134A: 0.468112901696291, R227EA: 0.0261066945175942, BUTANE: 0.0091646080754323, IPENTANE: 0.00738289844959133" R454A.mix,R454A,R454AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.541359992223361, R1234YF: 0.458640007776639" R454B.mix,R454B,R454BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.829247912869081, R1234YF: 0.170752087130919" R500.mix,R500,R500Mixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R12: 0.606101741397223, R152A: 0.393898258602777" R501.mix,R501,R501Mixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.807509678166191, R12: 0.192490321833809" R502.mix,R502,R502Mixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.629994467193889, R115: 0.370005532806111" R503.mix,R503,R503Mixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R23: 0.49970034990839, R13: 0.50029965009161" R504.mix,R504,R504Mixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.734239632563771, R115: 0.265760367436229" R507A.mix,R507A,R507AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.411839711774438, R143A: 0.588160288225562" R508A.mix,R508A,R508AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R23: 0.557576966356198, R116: 0.442423033643802" R508B.mix,R508B,R508BMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R23: 0.626751006700703, R116: 0.373248993299297" R509A.mix,R509A,R509AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.630790210153023, R218: 0.369209789846977" R510A.mix,R510A,R510AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - DME: 0.902458936722509, ISOBUTAN: 0.0975410632774913" R511A.mix,R511A,R511AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.952038489443906, DME: 0.0479615105560936" R512A.mix,R512A,R512AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R134A: 0.0329487458964343, R152A: 0.967051254103566" R513A.mix,R513A,R513AMixture,7,Predefined Mixtures of Pure Fluids,FALSE,FALSE,FALSE,FALSE,null,null,"Mole Fractions - R1234YF: 0.532425755929735, R134A: 0.467574244070265" ================================================ FILE: notebooks/propsSI_mixtures.csv ================================================ propsName,menuName,idName,category,basic,incompressibleMixture,minConcentration,maxConcentration,longDescription Air.mix,Air,AirMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - NITROGEN: 0.7812, ARGON: 0.0092, OXYGEN: 0.2096" Amarillo.mix,Amarillo,AmarilloMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.906724, NITROGEN: 0.031284, CO2: 0.004676, ETHANE: 0.045279, PROPANE: 0.00828, ISOBUTAN: 0.001037, BUTANE: 0.001563, IPENTANE: 0.000321, PENTANE: 0.000443, HEXANE: 0.000393" Ekofisk.mix,Ekofisk,EkofiskMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.859063, NITROGEN: 0.010068, CO2: 0.014954, ETHANE: 0.084919, PROPANE: 0.023015, ISOBUTAN: 0.003486, BUTANE: 0.003506, IPENTANE: 0.000509, PENTANE: 0.00048" GulfCoast.mix,GulfCoast,GulfCoastMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.965222, NITROGEN: 0.002595, CO2: 0.005956, ETHANE: 0.018186, PROPANE: 0.004596, ISOBUTAN: 0.000977, BUTANE: 0.001007, IPENTANE: 0.000473, PENTANE: 0.000324, HEXANE: 0.000664" HighCO2.mix,HighCO2,HighCO2Mixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.81212, NITROGEN: 0.05702, CO2: 0.07585, ETHANE: 0.04303, PROPANE: 0.00895, ISOBUTAN: 0.00151, BUTANE: 0.00152" HighN2.mix,HighN2,HighN2Mixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.81441, NITROGEN: 0.13465, CO2: 0.00985, ETHANE: 0.033, PROPANE: 0.00605, ISOBUTAN: 0.001, BUTANE: 0.00104" NaturalGasSample.mix,NaturalGasSample,NaturalGasSampleMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.95123, NITROGEN: 0.00089, CO2: 0.02555, ETHANE: 0.01835, PROPANE: 0.00238, ISOBUTAN: 0.0004, BUTANE: 0.00016, IPENTANE: 0.00014, PENTANE: 0.00011, HEXANE: 0.00079" R401A.mix,R401A,R401AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.578854210704231, R152A: 0.185871453986601, R124: 0.235274335309169" R401B.mix,R401B,R401BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.654924685341436, R152A: 0.154607382276918, R124: 0.190467932381646" R401C.mix,R401C,R401CMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.385591186504412, R152A: 0.229445970225924, R124: 0.384962843269664" R402A.mix,R402A,R402AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.507659889396724, PROPANE: 0.0460590346231213, R22: 0.446281075980154" R402B.mix,R402B,R402BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.299858744498276, PROPANE: 0.0429562491180057, R22: 0.657185006383719" R403A.mix,R403A,R403AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.104301635230068, R22: 0.797852142841926, R218: 0.0978462219280052" R403B.mix,R403B,R403BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.117083478399255, R22: 0.668734422027154, R218: 0.214182099573591" R404A.mix,R404A,R404AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.357816784026318, R134A: 0.0382639950410712, R143A: 0.603919220932611" R405A.mix,R405A,R405AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.582397185883849, R152A: 0.118598940913682, R142B: 0.0612463586573, RC318: 0.237757514545169" R406A.mix,R406A,R406AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.571559096367276, ISOBUTAN: 0.0618403319459979, R142B: 0.366600571686726" R407A.mix,R407A,R407AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.346419854360797, R125: 0.300315552114308, R134A: 0.353264593524896" R407B.mix,R407B,R407BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.197865007175653, R125: 0.600360468492644, R134A: 0.201774524331703" R407C.mix,R407C,R407CMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.381109419953993, R125: 0.179558888662016, R134A: 0.439331691383991" R407D.mix,R407D,R407DMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.262268077791873, R125: 0.113681680758968, R134A: 0.624050241449159" R407E.mix,R407E,R407EMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.402611526984881, R125: 0.104708637358978, R134A: 0.492679835656141" R407F.mix,R407F,R407FMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.473194694453358, R125: 0.205109095413331, R134A: 0.321696210133311" R408A.mix,R408A,R408AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.0507496395780536, R143A: 0.476277681499092, R22: 0.472972678922854" R409A.mix,R409A,R409AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.676088021274302, R124: 0.178481953421098, R142B: 0.1454300253046" R409B.mix,R409B,R409BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.726713817097545, R124: 0.177089324155708, R142B: 0.0961968587467468" R410A.mix,R410A,R410AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.697614699375863, R125: 0.302385300624138" R410B.mix,R410B,R410BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.653688938033229, R125: 0.346311061966771" R411A.mix,R411A,R411AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.0293595987641706, R22: 0.833472654512905, R152A: 0.137167746722925" R411B.mix,R411B,R411BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.0592216130255444, R22: 0.903048917855743, R152A: 0.0377294691187131" R412A.mix,R412A,R412AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.746189416536491, R218: 0.0245117299030133, R142B: 0.229298853560496" R413A.mix,R413A,R413AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R218: 0.0497604388838132, R134A: 0.896582929746185, ISOBUTAN: 0.0536566313700015" R414A.mix,R414A,R414AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.571718248653786, R124: 0.202422623615037, ISOBUTAN: 0.0667091242374272, R142B: 0.159150003493749" R414B.mix,R414B,R414BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.58743911052603, R124: 0.29030851296569, ISOBUTAN: 0.0262178745861124, R142B: 0.0960345019221677" R415A.mix,R415A,R415AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.776780159383737, R152A: 0.223219840616263" R415B.mix,R415B,R415BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.202949716550675, R152A: 0.797050283449325" R416A.mix,R416A,R416AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R134A: 0.647182715864291, R124: 0.323933072881677, BUTANE: 0.0288842112540324" R417A.mix,R417A,R417AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.414456113615123, R134A: 0.523100248809492, BUTANE: 0.0624436375753851" R418A.mix,R418A,R418AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.0287766462758765, R22: 0.939204558675462, R152A: 0.0320187950486611" R419A.mix,R419A,R419AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.701459965531065, R134A: 0.203604819551495, DME: 0.0949352149174398" R420A.mix,R420A,R420AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R134A: 0.878387913267685, R142B: 0.121612086732315" R421A.mix,R421A,R421AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.540011717389644, R134A: 0.459988282610356" R421B.mix,R421B,R421BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.828099498512419, R134A: 0.171900501487581" R422A.mix,R422A,R422AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.805501067600345, R134A: 0.128043250123554, ISOBUTAN: 0.0664556822761011" R422B.mix,R422B,R422BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.497287395965083, R134A: 0.446700400155301, ISOBUTAN: 0.0560122038796163" R422C.mix,R422C,R422CMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.774757115908852, R134A: 0.166711388687975, ISOBUTAN: 0.0585314954031729" R422D.mix,R422D,R422DMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.596291711495645, R134A: 0.339399053279791, ISOBUTAN: 0.064309235224564" R423A.mix,R423A,R423AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R134A: 0.648115324820034, R227EA: 0.351884675179966" R424A.mix,R424A,R424AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.45615402931289, R134A: 0.49939050863627, ISOBUTAN: 0.0167872396578164, BUTANE: 0.0186524885086849, IPENTANE: 0.00901573388433862" R425A.mix,R425A,R425AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.321134464075019, R134A: 0.615130603145805, R227EA: 0.0637349327791751" R426A.mix,R426A,R426AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.0431546741714159, R134A: 0.925684310853531, BUTANE: 0.0227152573734822, IPENTANE: 0.00844575760157109" R427A.mix,R427A,R427AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.260775797534104, R125: 0.188391404795509, R143A: 0.107618901019853, R134A: 0.443213896650535" R428A.mix,R428A,R428AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.694325251072399, R143A: 0.255893190962662, PROPANE: 0.0146310583647717, ISOBUTAN: 0.0351504996001673" R429A.mix,R429A,R429AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - DME: 0.66113457206158, R152A: 0.0768533364747054, ISOBUTAN: 0.262012091463714" R430A.mix,R430A,R430AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R152A: 0.735906531919507, ISOBUTAN: 0.264093468080493" R431A.mix,R431A,R431AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.785742532365466, R152A: 0.214257467634534" R432A.mix,R432A,R432AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.814097241703795, DME: 0.185902758296205" R433A.mix,R433A,R433AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.309917763130151, PROPANE: 0.690082236869849" R434A.mix,R434A,R434AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.556782765664377, R143A: 0.226468961005242, R134A: 0.165810098372986, ISOBUTAN: 0.0509381749573948" R435A.mix,R435A,R435AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - DME: 0.85152261670421, R152A: 0.14847738329579" R436A.mix,R436A,R436AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.62652773298942, ISOBUTAN: 0.37347226701058" R436B.mix,R436B,R436BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.588127503607667, ISOBUTAN: 0.411872496392333" R437A.mix,R437A,R437AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.168496314343733, R134A: 0.797898667324292, BUTANE: 0.0249804624362383, PENTANE: 0.00862455589573693" R438A.mix,R438A,R438AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.161915681788051, R125: 0.371558801739542, R134A: 0.42929872424902, BUTANE: 0.0289854872298073, IPENTANE: 0.00824130499357989" R441A.mix,R441A,R441AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - ETHANE: 0.049800395690461, PROPANE: 0.600310262208399, ISOBUTAN: 0.0498654644324665, BUTANE: 0.300023877668674" R442A.mix,R442A,R442AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.487220106766942, R125: 0.211188495005419, R134A: 0.240409765511042, R152A: 0.0371371957951017, R227EA: 0.0240444369214954" R443A.mix,R443A,R443AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.568232931233387, PROPANE: 0.394367661677695, ISOBUTAN: 0.0373994070889183" R444A.mix,R444A,R444AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.223042202171548, R152A: 0.0731981570161227, R1234ZE: 0.703759640812329" R500.mix,R500,R500Mixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R12: 0.606101741397223, R152A: 0.393898258602777" R501.mix,R501,R501Mixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.807509678166191, R12: 0.192490321833809" R502.mix,R502,R502Mixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.629994467193889, R115: 0.370005532806111" R503.mix,R503,R503Mixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R23: 0.49970034990839, R13: 0.50029965009161" R504.mix,R504,R504Mixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.734239632563771, R115: 0.265760367436229" R507A.mix,R507A,R507AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.411839711774438, R143A: 0.588160288225562" R508A.mix,R508A,R508AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R23: 0.557576966356198, R116: 0.442423033643802" R508B.mix,R508B,R508BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R23: 0.626751006700703, R116: 0.373248993299297" R509A.mix,R509A,R509AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R22: 0.630790210153023, R218: 0.369209789846977" R510A.mix,R510A,R510AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - DME: 0.902458936722509, ISOBUTAN: 0.0975410632774913" R512A.mix,R512A,R512AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R134A: 0.0329487458964343, R152A: 0.967051254103566" GulfCoastGas(NIST1).mix,GulfCoastGas(NIST1),GulfCoastGas(NIST1)Mixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.965222, NITROGEN: 0.002595, CO2: 0.005956, ETHANE: 0.018186, PROPANE: 0.004596, ISOBUTAN: 0.000977, BUTANE: 0.001007, IPENTANE: 0.000473, PENTANE: 0.000324, HEXANE: 0.000664" TypicalNaturalGas.mix,TypicalNaturalGas,TypicalNaturalGasMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - METHANE: 0.95123, NITROGEN: 0.00089, CO2: 0.02555, ETHANE: 0.01835, PROPANE: 0.00238, ISOBUTAN: 0.0004, BUTANE: 0.00016, IPENTANE: 0.00014, PENTANE: 0.00011, HEXANE: 0.00079" R417B.mix,R417B,R417BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.744566872257699, R134A: 0.202885026732296, BUTANE: 0.052548101010005" R417C.mix,R417C,R417CMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.168533780311387, R134A: 0.801126056234188, BUTANE: 0.0303401634544254" R419B.mix,R419B,R419BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.425134881380361, R134A: 0.494935410459673, DME: 0.0799297081599657" R422E.mix,R422E,R422EMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.528211539833383, R134A: 0.421012248071509, ISOBUTAN: 0.0507762120951078" R429A.mix,R429A,R429AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - DME: 0.66113457206158, R152A: 0.0768533364747054, ISOBUTAN: 0.262012091463714" R430A.mix,R430A,R430AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R152A: 0.735906531919507, ISOBUTAN: 0.264093468080493" R431A.mix,R431A,R431AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.785742532365466, R152A: 0.214257467634534" R432A.mix,R432A,R432AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.814097241703795, DME: 0.185902758296205" R433A.mix,R433A,R433AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.309917763130151, PROPANE: 0.690082236869849" R433B.mix,R433B,R433BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.0522701063955236, PROPANE: 0.947729893604476" R433C.mix,R433C,R433CMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPYLEN: 0.25887610544032, PROPANE: 0.74112389455968" R434A.mix,R434A,R434AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R125: 0.556782765664377, R143A: 0.226468961005242, R134A: 0.165810098372986, ISOBUTAN: 0.0509381749573948" R438A.mix,R438A,R438AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.161915681788051, R125: 0.371558801739542, R134A: 0.42929872424902, BUTANE: 0.0289854872298073, IPENTANE: 0.00824130499357989" R439A.mix,R439A,R439AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.684390813603997, R125: 0.278854127894844, ISOBUTAN: 0.0367550585011589" R440A.mix,R440A,R440AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.00901134733203068, R134A: 0.0103852633851142, R152A: 0.980603389282855" R444B.mix,R444B,R444BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.580409174767712, R152A: 0.11015659826248, R1234ZE: 0.309434226969808" R445A.mix,R445A,R445AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - CO2: 0.14056672736859, R134A: 0.0909466670967859, R1234ZE: 0.768486605534624" R446A.mix,R446A,R446AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.810347789312053, R1234ZE: 0.157652541387366, BUTANE: 0.0319996693005808" R447A.mix,R447A,R447AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.824059115538506, R125: 0.0183849541922025, R1234ZE: 0.157555930269292" R448A.mix,R448A,R448AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.431218201988559, R125: 0.186914131481992, R1234YF: 0.151319256485899, R134A: 0.177586673617217, R1234ZE: 0.0529617364263329" R449A.mix,R449A,R449AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.407364566995509, R125: 0.179481207732065, R1234YF: 0.193480840388364, R134A: 0.219673384884062" R449B.mix,R449B,R449BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.418353331871839, R125: 0.174861426767915, R1234YF: 0.175699749729428, R134A: 0.231085491630818" R450A.mix,R450A,R450AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R134A: 0.447322067369848, R1234ZE: 0.552677932630152" R451A.mix,R451A,R451AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R1234YF: 0.887346670041529, R134A: 0.112653329958471" R451B.mix,R451B,R451BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R1234YF: 0.876445928959364, R134A: 0.123554071040636" R452A.mix,R452A,R452AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.218864360337465, R125: 0.508837870465814, R1234YF: 0.272297769196721" R453A.mix,R453A,R453AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.341295928327855, R125: 0.147936968933237, R134A: 0.468112901696291, R227EA: 0.0261066945175942, BUTANE: 0.0091646080754323, IPENTANE: 0.00738289844959133" R454A.mix,R454A,R454AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.541359992223361, R1234YF: 0.458640007776639" R454B.mix,R454B,R454BMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R32: 0.829247912869081, R1234YF: 0.170752087130919" R511A.mix,R511A,R511AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - PROPANE: 0.952038489443906, DME: 0.0479615105560936" R513A.mix,R513A,R513AMixture,Predefined Compressible Mixture,FALSE,FALSE,null,null,"Mole Fractions - R1234YF: 0.532425755929735, R134A: 0.467574244070265" ================================================ FILE: notebooks/propsSI_parameters.csv ================================================ propsParameter,idName,units,input,output,trivial,incompressibleInput,incompressibleOutput,description C,C,J/kg/K,FALSE,TRUE,FALSE,FALSE,TRUE,Mass specific constant pressure specific heat D,D,kg/m^3,TRUE,TRUE,FALSE,TRUE,TRUE,Mass density H,H,J/kg,TRUE,TRUE,FALSE,TRUE,TRUE,Mass specific enthalpy P,P,Pa,TRUE,TRUE,FALSE,TRUE,TRUE,Pressure Q,Q,mol/mol,TRUE,TRUE,FALSE,FALSE,FALSE,Molar vapor quality S,S,J/kg/K,TRUE,TRUE,FALSE,TRUE,TRUE,Mass specific entropy T,T,K,TRUE,TRUE,FALSE,TRUE,TRUE,Temperature V,V,Pa s,FALSE,TRUE,FALSE,FALSE,TRUE,Viscosity ACENTRIC,Acentric,,FALSE,TRUE,TRUE,FALSE,FALSE,Acentric factor ALPHA0,Alpha0,,FALSE,TRUE,FALSE,FALSE,FALSE,Ideal Helmholtz energy ALPHAR,AlphaR,,FALSE,TRUE,FALSE,FALSE,FALSE,Residual Helmholtz energy BVIRIAL,BVirial,,FALSE,TRUE,FALSE,FALSE,FALSE,Second virial coefficient CONDUCTIVITY,Conductivity,W/m/K,FALSE,TRUE,FALSE,FALSE,TRUE,Thermal conductivity CP0MASS,Cp0Mass,J/kg/K,FALSE,TRUE,FALSE,FALSE,FALSE,Ideal gas mass specific constant pressure specific heat CP0MOLAR,Cp0Molar,J/mol/K,FALSE,TRUE,FALSE,FALSE,FALSE,Ideal gas molar specific constant pressure specific heat CPMOLAR,CpMolar,J/mol/K,FALSE,TRUE,FALSE,FALSE,FALSE,Molar specific constant pressure specific heat CVIRIAL,CVirial,,FALSE,TRUE,FALSE,FALSE,FALSE,Third virial coefficient CVMASS,CvMass,J/kg/K,FALSE,TRUE,FALSE,FALSE,FALSE,Mass specific constant volume specific heat CVMOLAR,CvMolar,J/mol/K,FALSE,TRUE,FALSE,FALSE,FALSE,Molar specific constant volume specific heat D2ALPHA0_DDELTA2_CONSTTAU,D2Alpha0DDelta2,,FALSE,TRUE,FALSE,FALSE,FALSE,Second derivative of ideal Helmholtz energy with delta D3ALPHA0_DDELTA3_CONSTTAU,D3Alpha0DDelta3,,FALSE,TRUE,FALSE,FALSE,FALSE,Third derivative of ideal Helmholtz energy with delta DALPHA0_DDELTA_CONSTTAU,DAlpha0DDelta,,FALSE,TRUE,FALSE,FALSE,FALSE,Derivative of ideal Helmholtz energy with delta DALPHA0_DTAU_CONSTDELTA,DAlpha0DTau,,FALSE,TRUE,FALSE,FALSE,FALSE,Derivative of ideal Helmholtz energy with tau DALPHAR_DDELTA_CONSTTAU,DAlphaRDDelta,,FALSE,TRUE,FALSE,FALSE,FALSE,Derivative of residual Helmholtz energy with delta DALPHAR_DTAU_CONSTDELTA,DAlphaRDTau,,FALSE,TRUE,FALSE,FALSE,FALSE,Derivative of residual Helmholtz energy with tau DBVIRIAL_DT,DBVirialDT,,FALSE,TRUE,FALSE,FALSE,FALSE,Derivative of second virial coefficient with respect to T DCVIRIAL_DT,DCVirialDT,,FALSE,TRUE,FALSE,FALSE,FALSE,Derivative of third virial coefficient with respect to T DELTA,Delta,,TRUE,TRUE,FALSE,FALSE,FALSE,Reduced density (rho/rhoc) DIPOLE_MOMENT,DipoleMoment,C m,FALSE,TRUE,TRUE,FALSE,FALSE,Dipole moment DMOLAR,DMolar,mol/m^3,TRUE,TRUE,FALSE,FALSE,FALSE,Molar density FH,FH,,FALSE,TRUE,TRUE,FALSE,FALSE,Flammability hazard FRACTION_MAX,FractionMax,,FALSE,TRUE,TRUE,FALSE,FALSE,"Fraction (mole, mass, volume) maximum value for incompressible solutions" FRACTION_MIN,FractionMin,,FALSE,TRUE,TRUE,FALSE,FALSE,"Fraction (mole, mass, volume) minimum value for incompressible solutions" FUNDAMENTAL_DERIVATIVE_OF_GAS_DYNAMICS,FundDerivGasDyn,,FALSE,TRUE,FALSE,FALSE,FALSE,Fundamental derivative of gas dynamics GAS_CONSTANT,GasConstant,J/mol/K,FALSE,TRUE,TRUE,FALSE,FALSE,Molar gas constant G,GMass,J/kg,FALSE,TRUE,FALSE,FALSE,FALSE,Mass specific Gibbs energy GMOLAR,GMolar,J/mol,FALSE,TRUE,FALSE,FALSE,FALSE,Molar specific Gibbs energy GMOLAR_RESIDUAL,GMolarResidual,J/mol/K,FALSE,TRUE,FALSE,FALSE,FALSE,Residual molar Gibbs energy GWP100,GWP100,,FALSE,TRUE,TRUE,FALSE,FALSE,100-year global warming potential GWP20,GWP20,,FALSE,TRUE,TRUE,FALSE,FALSE,20-year global warming potential GWP500,GWP500,,FALSE,TRUE,TRUE,FALSE,FALSE,500-year global warming potential HELMHOLTZMASS,HelmholtzMass,J/kg,FALSE,TRUE,FALSE,FALSE,FALSE,Mass specific Helmholtz energy HELMHOLTZMOLAR,HelmholtzMolar,J/mol,FALSE,TRUE,FALSE,FALSE,FALSE,Molar specific Helmholtz energy HH,HH,,FALSE,TRUE,TRUE,FALSE,FALSE,Health hazard HMOLAR,HMolar,J/mol,TRUE,TRUE,FALSE,FALSE,FALSE,Molar specific enthalpy HMOLAR_RESIDUAL,HMolarResidual,J/mol/K,FALSE,TRUE,FALSE,FALSE,FALSE,Residual molar enthalpy ISENTROPIC_EXPANSION_COEFFICIENT,IsentropicExpansionCoefficient,,FALSE,TRUE,FALSE,FALSE,FALSE,Isentropic expansion coefficient ISOBARIC_EXPANSION_COEFFICIENT,IsobaricExpansionCoefficient,1/K,FALSE,TRUE,FALSE,FALSE,FALSE,Isobaric expansion coefficient ISOTHERMAL_COMPRESSIBILITY,IsothermalCompressibility,1/Pa,FALSE,TRUE,FALSE,FALSE,FALSE,Isothermal compressibility M,MolarMass,kg/mol,FALSE,TRUE,TRUE,FALSE,FALSE,Molar mass ODP,ODP,,FALSE,TRUE,TRUE,FALSE,FALSE,Ozone depletion potential PCRIT,PCrit,Pa,FALSE,TRUE,TRUE,FALSE,FALSE,Pressure at the critical point PH,PH,,FALSE,TRUE,TRUE,FALSE,FALSE,Physical hazard PHASE,Phase,,FALSE,TRUE,FALSE,FALSE,FALSE,Fluid phase index (display as symbolic to get text version) PIP,PIP,,FALSE,TRUE,FALSE,FALSE,FALSE,Phase identification parameter PMAX,PMax,Pa,FALSE,TRUE,TRUE,FALSE,FALSE,Maximum pressure limit PMIN,PMin,Pa,FALSE,TRUE,TRUE,FALSE,FALSE,Minimum pressure limit PRANDTL,Prandtl,,FALSE,TRUE,FALSE,FALSE,FALSE,Prandtl number P_REDUCING,PReducing,Pa,FALSE,TRUE,TRUE,FALSE,FALSE,Pressure at the reducing point PTRIPLE,PTriplePoint,Pa,FALSE,TRUE,TRUE,FALSE,FALSE,Pressure at the triple point (pure only) RHOCRIT,RhoCrit,kg/m^3,FALSE,TRUE,TRUE,FALSE,FALSE,Mass density at critical point RHOMASS_REDUCING,RhoMassReducing,kg/m^3,FALSE,TRUE,TRUE,FALSE,FALSE,Mass density at reducing point RHOMOLAR_CRITICAL,RhoMolarCritical,mol/m^3,FALSE,TRUE,TRUE,FALSE,FALSE,Molar density at critical point RHOMOLAR_REDUCING,RhoMolarReducing,mol/m^3,FALSE,TRUE,TRUE,FALSE,FALSE,Molar density at reducing point SMOLAR,SMolar,J/mol/K,TRUE,TRUE,FALSE,FALSE,FALSE,Molar specific entropy SMOLAR_RESIDUAL,SMolarResidual,J/mol/K,FALSE,TRUE,FALSE,FALSE,FALSE,"Residual molar entropy (sr/R = s(T,rho) - s^0(T,rho))" A,SoundSpeed,m/s,FALSE,TRUE,FALSE,FALSE,FALSE,Speed of sound I,SurfaceTension,N/m,FALSE,TRUE,FALSE,FALSE,FALSE,Surface tension TAU,Tau,,TRUE,TRUE,FALSE,FALSE,FALSE,Reciprocal reduced temperature (Tc/T) TCRIT,TCritical,K,FALSE,TRUE,TRUE,FALSE,FALSE,Temperature at the critical point T_FREEZE,TFreeze,K,FALSE,TRUE,TRUE,FALSE,FALSE,Freezing temperature for incompressible solutions TMAX,TMax,K,FALSE,TRUE,TRUE,FALSE,TRUE,Maximum temperature limit TMIN,TMin,K,FALSE,TRUE,TRUE,FALSE,TRUE,Minimum temperature limit T_REDUCING,TReducing,K,FALSE,TRUE,TRUE,FALSE,FALSE,Temperature at the reducing point TTRIPLE,TTriplePoint,K,FALSE,TRUE,TRUE,FALSE,FALSE,Temperature at the triple point U,U,J/kg,TRUE,TRUE,FALSE,FALSE,TRUE,Mass specific internal energy UMOLAR,UMolar,J/mol,TRUE,TRUE,FALSE,FALSE,FALSE,Molar specific internal energy Z,Z,,FALSE,TRUE,FALSE,FALSE,FALSE,Compressibility factor ================================================ FILE: notebooks/propsSI_parameters_order.csv ================================================ C,Quick Access D,Quick Access H,Quick Access P,Quick Access Q,Quick Access S,Quick Access T,Quick Access V,Quick Access ACENTRIC,All ALPHA0,All ALPHAR,All BVIRIAL,All C,All CONDUCTIVITY,All CP0MASS,All CP0MOLAR,All CPMOLAR,All CVIRIAL,All CVMASS,All CVMOLAR,All D,All D2ALPHA0_DDELTA2_CONSTTAU,All D3ALPHA0_DDELTA3_CONSTTAU,All DALPHA0_DDELTA_CONSTTAU,All DALPHA0_DTAU_CONSTDELTA,All DALPHAR_DDELTA_CONSTTAU,All DALPHAR_DTAU_CONSTDELTA,All DBVIRIAL_DT,All DCVIRIAL_DT,All DELTA,All DIPOLE_MOMENT,All DMOLAR,All FH,All FRACTION_MAX,All FRACTION_MIN,All FUNDAMENTAL_DERIVATIVE_OF_GAS_DYNAMICS,All GAS_CONSTANT,All G,All GMOLAR,All GMOLAR_RESIDUAL,All GWP100,All GWP20,All GWP500,All H,All HELMHOLTZMASS,All HELMHOLTZMOLAR,All HH,All HMOLAR,All HMOLAR_RESIDUAL,All ISENTROPIC_EXPANSION_COEFFICIENT,All ISOBARIC_EXPANSION_COEFFICIENT,All ISOTHERMAL_COMPRESSIBILITY,All M,All ODP,All P,All PCRIT,All PH,All PHASE,All PIP,All PMAX,All PMIN,All PRANDTL,All P_REDUCING,All PTRIPLE,All Q,All RHOCRIT,All RHOMASS_REDUCING,All RHOMOLAR_CRITICAL,All RHOMOLAR_REDUCING,All S,All SMOLAR,All SMOLAR_RESIDUAL,All A,All I,All T,All TAU,All TCRIT,All T_FREEZE,All TMAX,All TMIN,All T_REDUCING,All TTRIPLE,All U,All UMOLAR,All V,All Z,All ================================================ FILE: notebooks/reserved_ids.ipynb ================================================ { "cells": [ { "cell_type": "code", "execution_count": 1, "id": "8aeab359-4296-4706-8dfb-bfaca083fc10", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'1.13.3'" ] }, "execution_count": 1, "metadata": {}, "output_type": "execute_result" } ], "source": [ "from sympy import *\n", "\n", "# check sympy version, must match version used by EngineeringPaper.xyz\n", "__version__" ] }, { "cell_type": "code", "execution_count": 2, "id": "fe5a40c3-b7f8-4421-b29d-552438fb32e3", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "1104" ] }, "execution_count": 2, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# add sympy symbols\n", "reserved = set(dir())\n", "\n", "# add python reserved keywords\n", "import keyword\n", "reserved.update(keyword.kwlist)\n", "\n", "# add python builtin functions\n", "import builtins\n", "reserved.update(dir(builtins))\n", "\n", "# remove symbols that begin with underscore, also remove pi since pi maps one-to-one\n", "reserved = {value for value in reserved if not value.startswith('_') and value != 'pi'}\n", "\n", "len(reserved)" ] }, { "cell_type": "code", "execution_count": 3, "id": "1488c105-287e-441c-8af1-4f28bd8a5d8c", "metadata": {}, "outputs": [], "source": [ "# defining current set to see what has changed\n", "current_reserved = set([\n", " \"Rationals\",\n", " \"assemble_partfrac_list\",\n", " \"FiniteSet\",\n", " \"input\",\n", " \"stationary_points\",\n", " \"assoc_legendre\",\n", " \"sinc\",\n", " \"chebyshevt_poly\",\n", " \"nth_power_roots_poly\",\n", " \"GMPYRationalField\",\n", " \"ComputationFailed\",\n", " \"QQ_I\",\n", " \"lucas\",\n", " \"StopIteration\",\n", " \"Warning\",\n", " \"bin\",\n", " \"acsc\",\n", " \"fourier_series\",\n", " \"cartes\",\n", " \"is_amicable\",\n", " \"adjoint\",\n", " \"substitution\",\n", " \"compositepi\",\n", " \"assoc_laguerre\",\n", " \"expand_power_base\",\n", " \"sturm\",\n", " \"if\",\n", " \"bernoulli\",\n", " \"aiter\",\n", " \"from\",\n", " \"collect\",\n", " \"asin\",\n", " \"Set\",\n", " \"cosh\",\n", " \"pass\",\n", " \"SyntaxError\",\n", " \"super\",\n", " \"mersenne_prime_exponent\",\n", " \"ascii\",\n", " \"hadamard_product\",\n", " \"GeometryError\",\n", " \"FiniteField\",\n", " \"import\",\n", " \"nonlinsolve\",\n", " \"count_ops\",\n", " \"LessThan\",\n", " \"PermissionError\",\n", " \"KeyError\",\n", " \"ZeroDivisionError\",\n", " \"genocchi\",\n", " \"ImmutableSparseMatrix\",\n", " \"assuming\",\n", " \"abs\",\n", " \"release\",\n", " \"oo\",\n", " \"ff\",\n", " \"ExtraneousFactors\",\n", " \"solve_linear\",\n", " \"to_cnf\",\n", " \"sqrt_mod_iter\",\n", " \"Lt\",\n", " \"linear_eq_to_matrix\",\n", " \"wronskian\",\n", " \"ConnectionAbortedError\",\n", " \"ReferenceError\",\n", " \"Tuple\",\n", " \"Implies\",\n", " \"print_maple_code\",\n", " \"print_ccode\",\n", " \"randMatrix\",\n", " \"nfloat\",\n", " \"inverse_laplace_transform\",\n", " \"invert\",\n", " \"NonSquareMatrixError\",\n", " \"ModuleNotFoundError\",\n", " \"solve_poly_inequality\",\n", " \"Polygon\",\n", " \"field_isomorphism\",\n", " \"reduce_abs_inequalities\",\n", " \"csc\",\n", " \"symarray\",\n", " \"Subs\",\n", " \"Dummy\",\n", " \"Contains\",\n", " \"OperationNotSupported\",\n", " \"cofactors\",\n", " \"intersection\",\n", " \"satisfiable\",\n", " \"inverse_hankel_transform\",\n", " \"chr\",\n", " \"SOPform\",\n", " \"license\",\n", " \"round\",\n", " \"sqf_norm\",\n", " \"viete\",\n", " \"erf2inv\",\n", " \"tensordiagonal\",\n", " \"Indexed\",\n", " \"bessely\",\n", " \"isprime\",\n", " \"Rem\",\n", " \"ChildProcessError\",\n", " \"Gt\",\n", " \"subresultants\",\n", " \"Naturals0\",\n", " \"igrlex\",\n", " \"Trace\",\n", " \"polylog\",\n", " \"Basic\",\n", " \"FunctionMatrix\",\n", " \"LeviCivita\",\n", " \"Expr\",\n", " \"ilex\",\n", " \"UnicodeWarning\",\n", " \"mathieusprime\",\n", " \"piecewise_exclusive\",\n", " \"Mod\",\n", " \"hermite\",\n", " \"diagonalize_vector\",\n", " \"FallingFactorial\",\n", " \"MutableDenseMatrix\",\n", " \"None\",\n", " \"async\",\n", " \"interpolating_spline\",\n", " \"Transpose\",\n", " \"pager_print\",\n", " \"AttributeError\",\n", " \"coth\",\n", " \"lcm\",\n", " \"solve_poly_system\",\n", " \"take\",\n", " \"Line\",\n", " \"Symbol\",\n", " \"raise\",\n", " \"TypeError\",\n", " \"denom\",\n", " \"rsolve\",\n", " \"lowergamma\",\n", " \"Atom\",\n", " \"Nor\",\n", " \"fps\",\n", " \"gcd\",\n", " \"get_contraction_structure\",\n", " \"polys\",\n", " \"GeneratorsNeeded\",\n", " \"construct_domain\",\n", " \"motzkin\",\n", " \"Line3D\",\n", " \"else\",\n", " \"atan2\",\n", " \"MellinTransform\",\n", " \"pdiv\",\n", " \"BasePolynomialError\",\n", " \"help\",\n", " \"staticmethod\",\n", " \"check_assumptions\",\n", " \"igcd\",\n", " \"ccode\",\n", " \"factorial\",\n", " \"fft\",\n", " \"Union\",\n", " \"piecewise_fold\",\n", " \"MultivariatePolynomialError\",\n", " \"horner\",\n", " \"primitive_root\",\n", " \"elliptic_k\",\n", " \"rsolve_poly\",\n", " \"break\",\n", " \"BaseException\",\n", " \"OverflowError\",\n", " \"cyclotomic_poly\",\n", " \"Ynm\",\n", " \"reshape\",\n", " \"sstr\",\n", " \"GMPYIntegerRing\",\n", " \"plot_parametric\",\n", " \"SystemError\",\n", " \"CoercionFailed\",\n", " \"IntegerRing\",\n", " \"acsch\",\n", " \"algebras\",\n", " \"lerchphi\",\n", " \"ord0\",\n", " \"residue\",\n", " \"solve_linear_system_LU\",\n", " \"Eq\",\n", " \"cbrt\",\n", " \"ConnectionError\",\n", " \"print_mathml\",\n", " \"Curve\",\n", " \"besselsimp\",\n", " \"factor\",\n", " \"public\",\n", " \"in\",\n", " \"real_root\",\n", " \"inverse_mobius_transform\",\n", " \"itermonomials\",\n", " \"dotprint\",\n", " \"erfc\",\n", " \"false\",\n", " \"DiracDelta\",\n", " \"EmptySequence\",\n", " \"integer_nthroot\",\n", " \"default_sort_key\",\n", " \"grevlex\",\n", " \"mathieucprime\",\n", " \"Inverse\",\n", " \"intt\",\n", " \"nthroot_mod\",\n", " \"solve_univariate_inequality\",\n", " \"RefinementFailed\",\n", " \"globals\",\n", " \"exec\",\n", " \"bytes\",\n", " \"primitive\",\n", " \"print_python\",\n", " \"checkpdesol\",\n", " \"BrokenPipeError\",\n", " \"RootOf\",\n", " \"sin\",\n", " \"zeta\",\n", " \"type\",\n", " \"sqf_list\",\n", " \"EPath\",\n", " \"jacobi_normalized\",\n", " \"numbered_symbols\",\n", " \"n_order\",\n", " \"CosineTransform\",\n", " \"Array\",\n", " \"Si\",\n", " \"airybi\",\n", " \"gegenbauer\",\n", " \"half_gcdex\",\n", " \"per\",\n", " \"blockcut\",\n", " \"def\",\n", " \"acosh\",\n", " \"SparseMatrix\",\n", " \"acos\",\n", " \"bool\",\n", " \"PythonFiniteField\",\n", " \"PolynomialRing\",\n", " \"pde_separate\",\n", " \"dict_merge\",\n", " \"geometry\",\n", " \"bspline_basis_set\",\n", " \"mathieuc\",\n", " \"E\",\n", " \"compose\",\n", " \"expand_trig\",\n", " \"Limit\",\n", " \"Not\",\n", " \"reduce_abs_inequality\",\n", " \"Triangle\",\n", " \"setattr\",\n", " \"checkodesol\",\n", " \"finite_diff_weights\",\n", " \"Range\",\n", " \"FlagError\",\n", " \"arity\",\n", " \"idiff\",\n", " \"sequence\",\n", " \"fresnels\",\n", " \"erfinv\",\n", " \"binomial_coefficients_list\",\n", " \"IndexedBase\",\n", " \"class\",\n", " \"hn2\",\n", " \"parsing\",\n", " \"frozenset\",\n", " \"gff\",\n", " \"TimeoutError\",\n", " \"LC\",\n", " \"simplify\",\n", " \"strategies\",\n", " \"var\",\n", " \"Ci\",\n", " \"continued_fraction_reduce\",\n", " \"derive_by_array\",\n", " \"UserWarning\",\n", " \"ProductSet\",\n", " \"multiplicity\",\n", " \"solve_undetermined_coeffs\",\n", " \"Segment2D\",\n", " \"sine_transform\",\n", " \"Add\",\n", " \"copyright\",\n", " \"set\",\n", " \"covering_product\",\n", " \"map\",\n", " \"Catalan\",\n", " \"acoth\",\n", " \"polygamma\",\n", " \"functions\",\n", " \"timed\",\n", " \"lambdify\",\n", " \"subsets\",\n", " \"Derivative\",\n", " \"continued_fraction_iterator\",\n", " \"try\",\n", " \"BytesWarning\",\n", " \"sorted\",\n", " \"PolynomialDivisionFailed\",\n", " \"AppliedPredicate\",\n", " \"GF\",\n", " \"inv_quick\",\n", " \"SeqMul\",\n", " \"vring\",\n", " \"object\",\n", " \"QQ_gmpy\",\n", " \"print_fcode\",\n", " \"is_strictly_increasing\",\n", " \"print_tree\",\n", " \"cse\",\n", " \"powdenest\",\n", " \"airyai\",\n", " \"min\",\n", " \"Li\",\n", " \"NumberSymbol\",\n", " \"PythonIntegerRing\",\n", " \"cot\",\n", " \"expand_multinomial\",\n", " \"mathematica_code\",\n", " \"rem\",\n", " \"ImportWarning\",\n", " \"FutureWarning\",\n", " \"hex\",\n", " \"MutableSparseMatrix\",\n", " \"expand_func\",\n", " \"is_zero_dimensional\",\n", " \"AssertionError\",\n", " \"Rel\",\n", " \"Integral\",\n", " \"WildFunction\",\n", " \"trace\",\n", " \"diag\",\n", " \"dict\",\n", " \"imageset\",\n", " \"NotInvertible\",\n", " \"sec\",\n", " \"DeferredVector\",\n", " \"FF_python\",\n", " \"ZZ_python\",\n", " \"LookupError\",\n", " \"NotAlgebraic\",\n", " \"Matrix\",\n", " \"asec\",\n", " \"discriminant\",\n", " \"is_perfect\",\n", " \"is_nthpow_residue\",\n", " \"GroebnerBasis\",\n", " \"gcd_terms\",\n", " \"plot_implicit\",\n", " \"print_gtk\",\n", " \"GeneratorsError\",\n", " \"assumptions\",\n", " \"quadratic_residues\",\n", " \"DeprecationWarning\",\n", " \"len\",\n", " \"failing_assumptions\",\n", " \"jacobi_symbol\",\n", " \"MatrixPermute\",\n", " \"ord\",\n", " \"vectorize\",\n", " \"symbols\",\n", " \"xring\",\n", " \"TribonacciConstant\",\n", " \"matrix_symbols\",\n", " \"floor\",\n", " \"Sieve\",\n", " \"multipledispatch\",\n", " \"EulerGamma\",\n", " \"tensor\",\n", " \"preorder_traversal\",\n", " \"NameError\",\n", " \"topological_sort\",\n", " \"pde_separate_mul\",\n", " \"polarify\",\n", " \"PermutationMatrix\",\n", " \"quo\",\n", " \"BlockingIOError\",\n", " \"init_printing\",\n", " \"textplot\",\n", " \"DotProduct\",\n", " \"Le\",\n", " \"ImageSet\",\n", " \"Naturals\",\n", " \"SeqFormula\",\n", " \"Q\",\n", " \"glsl_code\",\n", " \"plot\",\n", " \"Ray\",\n", " \"SeqPer\",\n", " \"elif\",\n", " \"OSError\",\n", " \"Ray3D\",\n", " \"apply_finite_diff\",\n", " \"det\",\n", " \"principal_branch\",\n", " \"tensorproduct\",\n", " \"InterruptedError\",\n", " \"chebyshevt\",\n", " \"randprime\",\n", " \"is_deficient\",\n", " \"is_convex\",\n", " \"NotReversible\",\n", " \"I\",\n", " \"is_primitive_root\",\n", " \"Max\",\n", " \"convex_hull\",\n", " \"parallel_poly_from_expr\",\n", " \"legendre_poly\",\n", " \"simplify_logic\",\n", " \"integrate\",\n", " \"perfect_power\",\n", " \"solve_triangulated\",\n", " \"npartitions\",\n", " \"UnevaluatedExpr\",\n", " \"Intersection\",\n", " \"jn\",\n", " \"gamma\",\n", " \"det_quick\",\n", " \"is_strictly_decreasing\",\n", " \"solve_linear_system\",\n", " \"Poly\",\n", " \"del\",\n", " \"Ray2D\",\n", " \"AssumptionsContext\",\n", " \"ITE\",\n", " \"Integer\",\n", " \"SingularityFunction\",\n", " \"prime\",\n", " \"primefactors\",\n", " \"format\",\n", " \"DenseNDimArray\",\n", " \"airybiprime\",\n", " \"collect_const\",\n", " \"EOFError\",\n", " \"resultant\",\n", " \"HeuristicGCDFailed\",\n", " \"BlockDiagMatrix\",\n", " \"O\",\n", " \"homogeneous_order\",\n", " \"issubclass\",\n", " \"pquo\",\n", " \"mobius\",\n", " \"factorial2\",\n", " \"trigamma\",\n", " \"python\",\n", " \"ceiling\",\n", " \"StrictLessThan\",\n", " \"hankel2\",\n", " \"Options\",\n", " \"log\",\n", " \"pde_separate_add\",\n", " \"DiagonalOf\",\n", " \"binomial\",\n", " \"to_dnf\",\n", " \"atan\",\n", " \"rust_code\",\n", " \"And\",\n", " \"centroid\",\n", " \"trigsimp\",\n", " \"str\",\n", " \"In\",\n", " \"ResourceWarning\",\n", " \"bell\",\n", " \"SeqAdd\",\n", " \"Number\",\n", " \"summation\",\n", " \"AlgebraicField\",\n", " \"RisingFactorial\",\n", " \"stieltjes\",\n", " \"all\",\n", " \"GMPYFiniteField\",\n", " \"is_quad_residue\",\n", " \"minpoly\",\n", " \"diophantine\",\n", " \"apart_list\",\n", " \"asech\",\n", " \"bool_map\",\n", " \"interpolating_poly\",\n", " \"digamma\",\n", " \"linsolve\",\n", " \"exptrigsimp\",\n", " \"EnvironmentError\",\n", " \"composite\",\n", " \"jscode\",\n", " \"EXRAW\",\n", " \"enumerate\",\n", " \"divisor_sigma\",\n", " \"doctest\",\n", " \"minimal_polynomial\",\n", " \"HadamardPower\",\n", " \"Ordinal\",\n", " \"solveset\",\n", " \"SparseNDimArray\",\n", " \"elliptic_pi\",\n", " \"igrevlex\",\n", " \"AtomicExpr\",\n", " \"classify_pde\",\n", " \"sech\",\n", " \"PendingDeprecationWarning\",\n", " \"MatrixBase\",\n", " \"div\",\n", " \"laguerre_poly\",\n", " \"partition\",\n", " \"complex\",\n", " \"as\",\n", " \"Circle\",\n", " \"Segment\",\n", " \"are_similar\",\n", " \"hermite_poly\",\n", " \"is_mersenne_prime\",\n", " \"PoleError\",\n", " \"print\",\n", " \"InverseLaplaceTransform\",\n", " \"integer_log\",\n", " \"gruntz\",\n", " \"ArithmeticError\",\n", " \"plot_backends\",\n", " \"periodic_argument\",\n", " \"unflatten\",\n", " \"capture\",\n", " \"dsolve\",\n", " \"laplace_transform\",\n", " \"list2numpy\",\n", " \"locals\",\n", " \"not\",\n", " \"primerange\",\n", " \"FunctionClass\",\n", " \"Integers\",\n", " \"cosine_transform\",\n", " \"FloatingPointError\",\n", " \"limit\",\n", " \"InverseCosineTransform\",\n", " \"QQ_python\",\n", " \"arg\",\n", " \"lex\",\n", " \"yn\",\n", " \"InverseFourierTransform\",\n", " \"getattr\",\n", " \"variations\",\n", " \"ImmutableSparseNDimArray\",\n", " \"difference_delta\",\n", " \"srepr\",\n", " \"EvaluationFailed\",\n", " \"line_integrate\",\n", " \"range\",\n", " \"csch\",\n", " \"Unequality\",\n", " \"OneMatrix\",\n", " \"S\",\n", " \"SymmetricDifference\",\n", " \"KroneckerProduct\",\n", " \"ExpressionDomain\",\n", " \"PurePoly\",\n", " \"Domain\",\n", " \"fwht\",\n", " \"ImmutableMatrix\",\n", " \"rcode\",\n", " \"apart\",\n", " \"and\",\n", " \"source\",\n", " \"FileExistsError\",\n", " \"ValueError\",\n", " \"get_ipython\",\n", " \"ZZ_gmpy\",\n", " \"grlex\",\n", " \"pprint_try_use_unicode\",\n", " \"epath\",\n", " \"Mul\",\n", " \"InverseSineTransform\",\n", " \"RootSum\",\n", " \"expand\",\n", " \"random_poly\",\n", " \"Determinant\",\n", " \"LM\",\n", " \"ode_order\",\n", " \"delattr\",\n", " \"int\",\n", " \"prefixes\",\n", " \"mellin_transform\",\n", " \"group\",\n", " \"Ellipsis\",\n", " \"euler\",\n", " \"Shi\",\n", " \"MatMul\",\n", " \"MatrixSlice\",\n", " \"rot_axis3\",\n", " \"nsolve\",\n", " \"nonlocal\",\n", " \"expand_complex\",\n", " \"Adjoint\",\n", " \"im\",\n", " \"seterr\",\n", " \"for\",\n", " \"ordered\",\n", " \"ZZ_I\",\n", " \"IOError\",\n", " \"ZeroMatrix\",\n", " \"EncodingWarning\",\n", " \"divmod\",\n", " \"pprint\",\n", " \"global\",\n", " \"hyperexpand\",\n", " \"erf\",\n", " \"UnivariatePolynomialError\",\n", " \"degree\",\n", " \"prem\",\n", " \"print_rcode\",\n", " \"runfile\",\n", " \"expand_power_exp\",\n", " \"Id\",\n", " \"combsimp\",\n", " \"Float\",\n", " \"dirichlet_eta\",\n", " \"vars\",\n", " \"groebner\",\n", " \"powsimp\",\n", " \"primorial\",\n", " \"totient\",\n", " \"register_handler\",\n", " \"fcode\",\n", " \"hn1\",\n", " \"jn_zeros\",\n", " \"OptionError\",\n", " \"sympify\",\n", " \"exp_polar\",\n", " \"eval\",\n", " \"sstrrepr\",\n", " \"PolificationFailed\",\n", " \"subfactorial\",\n", " \"polar_lift\",\n", " \"Plane\",\n", " \"rot_axis1\",\n", " \"continue\",\n", " \"inverse_sine_transform\",\n", " \"isolate\",\n", " \"PythonRational\",\n", " \"pexquo\",\n", " \"exp\",\n", " \"total_degree\",\n", " \"Eijk\",\n", " \"meijerg\",\n", " \"atanh\",\n", " \"factor_list\",\n", " \"FileNotFoundError\",\n", " \"latex\",\n", " \"hankel1\",\n", " \"FF_gmpy\",\n", " \"series\",\n", " \"continued_fraction\",\n", " \"continued_fraction_convergents\",\n", " \"test\",\n", " \"ratsimpmodprime\",\n", " \"Pow\",\n", " \"SystemExit\",\n", " \"elliptic_f\",\n", " \"prod\",\n", " \"Idx\",\n", " \"StrPrinter\",\n", " \"degree_list\",\n", " \"OmegaPower\",\n", " \"parse_expr\",\n", " \"matrix2numpy\",\n", " \"posify\",\n", " \"ZZ\",\n", " \"maple_code\",\n", " \"Predicate\",\n", " \"threaded\",\n", " \"print_latex\",\n", " \"GeneratorExit\",\n", " \"Monomial\",\n", " \"property\",\n", " \"separatevars\",\n", " \"Equivalent\",\n", " \"ImportError\",\n", " \"maximum\",\n", " \"repr\",\n", " \"solve\",\n", " \"Complement\",\n", " \"zeros\",\n", " \"rotations\",\n", " \"carmichael\",\n", " \"cycle_length\",\n", " \"decompogen\",\n", " \"pollard_rho\",\n", " \"Lambda\",\n", " \"ImmutableDenseNDimArray\",\n", " \"ShapeError\",\n", " \"mobius_transform\",\n", " \"rad\",\n", " \"frac\",\n", " \"abundance\",\n", " \"MatAdd\",\n", " \"FractionField\",\n", " \"Min\",\n", " \"betainc_regularized\",\n", " \"inverse_cosine_transform\",\n", " \"sqrt\",\n", " \"differentiate_finite\",\n", " \"sqrtdenest\",\n", " \"unpolarify\",\n", " \"pretty\",\n", " \"Point3D\",\n", " \"conjugate\",\n", " \"MatrixExpr\",\n", " \"content\",\n", " \"chebyshevt_root\",\n", " \"ilcm\",\n", " \"comp\",\n", " \"ask\",\n", " \"Out\",\n", " \"factor_terms\",\n", " \"fraction\",\n", " \"PrecisionExhausted\",\n", " \"beta\",\n", " \"discrete_log\",\n", " \"UnboundLocalError\",\n", " \"cancel\",\n", " \"HomomorphismFailed\",\n", " \"while\",\n", " \"ConnectionResetError\",\n", " \"approximants\",\n", " \"print_jscode\",\n", " \"egyptian_fraction\",\n", " \"lcm_list\",\n", " \"julia_code\",\n", " \"ln\",\n", " \"prime_valuation\",\n", " \"RR\",\n", " \"IndentationError\",\n", " \"zip\",\n", " \"reduced_totient\",\n", " \"terms_gcd\",\n", " \"postorder_traversal\",\n", " \"oct\",\n", " \"RealField\",\n", " \"cacheit\",\n", " \"minimum\",\n", " \"transpose\",\n", " \"mathml\",\n", " \"Identity\",\n", " \"logcombine\",\n", " \"ntheory\",\n", " \"EX\",\n", " \"RecursionError\",\n", " \"DisjointUnion\",\n", " \"symmetrize\",\n", " \"RealNumber\",\n", " \"nan\",\n", " \"Parabola\",\n", " \"ConnectionRefusedError\",\n", " \"pycode\",\n", " \"ratsimp\",\n", " \"loggamma\",\n", " \"tuple\",\n", " \"RuntimeError\",\n", " \"hankel_transform\",\n", " \"intersecting_product\",\n", " \"periodicity\",\n", " \"root\",\n", " \"jacobi\",\n", " \"multinomial_coefficients\",\n", " \"sfield\",\n", " \"credits\",\n", " \"jordan_cell\",\n", " \"matrix_multiply_elementwise\",\n", " \"asinh\",\n", " \"permutedims\",\n", " \"Ge\",\n", " \"MutableSparseNDimArray\",\n", " \"binomial_coefficients\",\n", " \"sqf\",\n", " \"rational_interpolate\",\n", " \"primepi\",\n", " \"factor_nc\",\n", " \"expint\",\n", " \"ConditionSet\",\n", " \"Ynm_c\",\n", " \"utilities\",\n", " \"remove_handler\",\n", " \"InverseMellinTransform\",\n", " \"divisor_count\",\n", " \"expand_log\",\n", " \"Interval\",\n", " \"inverse_mellin_transform\",\n", " \"singularityintegrate\",\n", " \"FourierTransform\",\n", " \"UnicodeTranslateError\",\n", " \"compile\",\n", " \"IsomorphismFailed\",\n", " \"pprint_use_unicode\",\n", " \"radsimp\",\n", " \"prevprime\",\n", " \"fu\",\n", " \"rsolve_ratio\",\n", " \"GoldenRatio\",\n", " \"refine\",\n", " \"monic\",\n", " \"numer\",\n", " \"PolynomialError\",\n", " \"flatten\",\n", " \"factorrat\",\n", " \"lambda\",\n", " \"xthreaded\",\n", " \"execfile\",\n", " \"LaplaceTransform\",\n", " \"Permanent\",\n", " \"AlgebraicNumber\",\n", " \"reduce_inequalities\",\n", " \"Rational\",\n", " \"airyaiprime\",\n", " \"erfi\",\n", " \"uppergamma\",\n", " \"interactive\",\n", " \"chebyshevu\",\n", " \"eye\",\n", " \"symmetric_poly\",\n", " \"init_session\",\n", " \"real_roots\",\n", " \"expand_mul\",\n", " \"quadratic_congruence\",\n", " \"RuntimeWarning\",\n", " \"bytearray\",\n", " \"multiline_latex\",\n", " \"or\",\n", " \"TabError\",\n", " \"primenu\",\n", " \"factorint\",\n", " \"casoratian\",\n", " \"filldedent\",\n", " \"StopAsyncIteration\",\n", " \"is_decreasing\",\n", " \"NotADirectoryError\",\n", " \"nsimplify\",\n", " \"interpolate\",\n", " \"limit_seq\",\n", " \"continued_fraction_periodic\",\n", " \"MutableDenseNDimArray\",\n", " \"Segment3D\",\n", " \"ones\",\n", " \"ImmutableDenseMatrix\",\n", " \"proper_divisor_count\",\n", " \"besselj\",\n", " \"octave_code\",\n", " \"signsimp\",\n", " \"swinnerton_dyer_poly\",\n", " \"max\",\n", " \"proper_divisors\",\n", " \"shape\",\n", " \"xfield\",\n", " \"slice\",\n", " \"TableForm\",\n", " \"sqf_part\",\n", " \"E1\",\n", " \"ifwht\",\n", " \"Nand\",\n", " \"cxxcode\",\n", " \"SyntaxWarning\",\n", " \"InverseHankelTransform\",\n", " \"display\",\n", " \"chebyshevu_poly\",\n", " \"nextprime\",\n", " \"block_collapse\",\n", " \"sieve\",\n", " \"exit\",\n", " \"trailing\",\n", " \"except\",\n", " \"harmonic\",\n", " \"ComplexRootOf\",\n", " \"Ne\",\n", " \"poly\",\n", " \"besselk\",\n", " \"sinh\",\n", " \"Order\",\n", " \"plotting\",\n", " \"banded\",\n", " \"return\",\n", " \"is_increasing\",\n", " \"together\",\n", " \"count_roots\",\n", " \"HadamardProduct\",\n", " \"Point2D\",\n", " \"primeomega\",\n", " \"Line2D\",\n", " \"hash\",\n", " \"ring\",\n", " \"concrete\",\n", " \"FF\",\n", " \"pow\",\n", " \"KroneckerDelta\",\n", " \"deg\",\n", " \"elliptic_e\",\n", " \"discrete\",\n", " \"IndexError\",\n", " \"ComplexField\",\n", " \"anext\",\n", " \"UnificationFailed\",\n", " \"BlockMatrix\",\n", " \"checksol\",\n", " \"jacobi_poly\",\n", " \"Xor\",\n", " \"erf2\",\n", " \"gammasimp\",\n", " \"StrictGreaterThan\",\n", " \"reduced\",\n", " \"vfield\",\n", " \"any\",\n", " \"inverse_fourier_transform\",\n", " \"nroots\",\n", " \"pollard_pm1\",\n", " \"callable\",\n", " \"euler_equations\",\n", " \"cos\",\n", " \"Heaviside\",\n", " \"convolution\",\n", " \"MatPow\",\n", " \"open\",\n", " \"tensorcontraction\",\n", " \"tribonacci\",\n", " \"classmethod\",\n", " \"EmptySet\",\n", " \"field\",\n", " \"list\",\n", " \"diff\",\n", " \"rootof\",\n", " \"pdsolve\",\n", " \"UniversalSet\",\n", " \"Ellipse\",\n", " \"evaluate\",\n", " \"Reals\",\n", " \"gff_list\",\n", " \"primitive_element\",\n", " \"float\",\n", " \"yield\",\n", " \"sign\",\n", " \"chebyshevu_root\",\n", " \"breakpoint\",\n", " \"finally\",\n", " \"Product\",\n", " \"MatrixSymbol\",\n", " \"intervals\",\n", " \"decompose\",\n", " \"poly_from_expr\",\n", " \"RationalField\",\n", " \"legendre_symbol\",\n", " \"Wild\",\n", " \"is_abundant\",\n", " \"multigamma\",\n", " \"interactive_traversal\",\n", " \"appellf1\",\n", " \"trunc\",\n", " \"SympifyError\",\n", " \"True\",\n", " \"Piecewise\",\n", " \"product\",\n", " \"zoo\",\n", " \"ExactQuotientFailed\",\n", " \"riemann_xi\",\n", " \"bottom_up\",\n", " \"memoryview\",\n", " \"to_nnf\",\n", " \"LambertW\",\n", " \"rsolve_hyper\",\n", " \"CRootOf\",\n", " \"AccumBounds\",\n", " \"postfixes\",\n", " \"unbranched_argument\",\n", " \"fourier_transform\",\n", " \"await\",\n", " \"prime_decomp\",\n", " \"Dict\",\n", " \"marcumq\",\n", " \"Ei\",\n", " \"hessian\",\n", " \"LT\",\n", " \"iter\",\n", " \"bspline_basis\",\n", " \"get_indices\",\n", " \"laguerre\",\n", " \"mod_inverse\",\n", " \"ComplexRegion\",\n", " \"Complexes\",\n", " \"classify_ode\",\n", " \"legendre\",\n", " \"rf\",\n", " \"UnicodeEncodeError\",\n", " \"SineTransform\",\n", " \"isinstance\",\n", " \"PowerSet\",\n", " \"fibonacci\",\n", " \"reversed\",\n", " \"farthest_points\",\n", " \"next\",\n", " \"Sum\",\n", " \"preview\",\n", " \"refine_root\",\n", " \"HankelTransform\",\n", " \"singularities\",\n", " \"erfcinv\",\n", " \"exquo\",\n", " \"with\",\n", " \"NotImplemented\",\n", " \"IsADirectoryError\",\n", " \"kronecker_product\",\n", " \"MemoryError\",\n", " \"true\",\n", " \"printing\",\n", " \"hasattr\",\n", " \"MutableMatrix\",\n", " \"fresnelc\",\n", " \"acot\",\n", " \"gcdex\",\n", " \"has_variety\",\n", " \"ntt\",\n", " \"hypersimp\",\n", " \"is_monotonic\",\n", " \"has_dups\",\n", " \"print_glsl\",\n", " \"assert\",\n", " \"Function\",\n", " \"gcd_list\",\n", " \"catalan\",\n", " \"Znm\",\n", " \"RegularPolygon\",\n", " \"external\",\n", " \"kroneckersimp\",\n", " \"Quaternion\",\n", " \"Exception\",\n", " \"re\",\n", " \"betainc\",\n", " \"NDimArray\",\n", " \"tanh\",\n", " \"Abs\",\n", " \"rcollect\",\n", " \"pretty_print\",\n", " \"DomainError\",\n", " \"use\",\n", " \"rot_axis2\",\n", " \"UnicodeError\",\n", " \"DiagMatrix\",\n", " \"tan\",\n", " \"NotImplementedError\",\n", " \"UnicodeDecodeError\",\n", " \"evalf\",\n", " \"GreaterThan\",\n", " \"POSform\",\n", " \"not_empty_in\",\n", " \"ProcessLookupError\",\n", " \"sring\",\n", " \"sift\",\n", " \"False\",\n", " \"sum\",\n", " \"FU\",\n", " \"QQ\",\n", " \"ground_roots\",\n", " \"is\",\n", " \"GramSchmidt\",\n", " \"ifft\",\n", " \"Or\",\n", " \"calculus\",\n", " \"roots\",\n", " \"CC\",\n", " \"round_two\",\n", " \"quit\",\n", " \"hypersimilar\",\n", " \"DiagonalMatrix\",\n", " \"id\",\n", " \"mathieus\",\n", " \"KeyboardInterrupt\",\n", " \"Chi\",\n", " \"divisors\",\n", " \"solve_rational_inequalities\",\n", " \"Equality\",\n", " \"sqrt_mod\",\n", " \"dir\",\n", " \"Point\",\n", " \"hyper\",\n", " \"closest_points\",\n", " \"N\",\n", " \"BufferError\",\n", " \"memoize_property\",\n", " \"li\",\n", " \"to_number_field\",\n", " \"filter\",\n", " \"besseli\",\n", " \"BaseExceptionGroup\",\n", " \"ExceptionGroup\"\n", "])" ] }, { "cell_type": "code", "execution_count": 4, "id": "0d7b7a5a-e288-41a4-bfce-8172f1671905", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "1090" ] }, "execution_count": 4, "metadata": {}, "output_type": "execute_result" } ], "source": [ "len(current_reserved)" ] }, { "cell_type": "code", "execution_count": 5, "id": "a3d7c1c6-6ea4-496a-b199-a77acd54fa44", "metadata": {}, "outputs": [], "source": [ "intersection = set(reserved) & set(current_reserved) " ] }, { "cell_type": "code", "execution_count": 6, "id": "08eb1215-f5ec-4f77-8397-d6475e2d9c8a", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "1089" ] }, "execution_count": 6, "metadata": {}, "output_type": "execute_result" } ], "source": [ "len(intersection)" ] }, { "cell_type": "code", "execution_count": 7, "id": "aede6574-ac2a-4940-bf3d-37f6274b3b5f", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "{'source'}" ] }, "execution_count": 7, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# check id's that have been removed\n", "set(current_reserved) - set(reserved)" ] }, { "cell_type": "code", "execution_count": 8, "id": "63c03e84-b962-4d1f-a09f-34294f4fd0ed", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "{'all_roots',\n", " 'andre',\n", " 'galois_group',\n", " 'hermite_prob',\n", " 'hermite_prob_poly',\n", " 'is_carmichael',\n", " 'kronecker_symbol',\n", " 'laplace_correspondence',\n", " 'laplace_initial_conds',\n", " 'num_digits',\n", " 'rot_ccw_axis1',\n", " 'rot_ccw_axis2',\n", " 'rot_ccw_axis3',\n", " 'rot_givens',\n", " 'smtlib_code'}" ] }, "execution_count": 8, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# check id's that have been added\n", "set(reserved) - set(current_reserved)" ] }, { "cell_type": "code", "execution_count": 9, "id": "e70db174-fa8a-471d-aa68-bc015e22796c", "metadata": {}, "outputs": [], "source": [ "def to_javascript(reserved):\n", " output = \"export const RESERVED = new Set([\\n\"\n", " \n", " for symbol in reserved:\n", " output += f' \"{symbol}\",\\n'\n", " \n", " output += \"]);\"\n", " \n", " return output\n", " " ] }, { "cell_type": "code", "execution_count": 10, "id": "7e8d236f-15d1-444f-a65b-ec70e3bcf8a8", "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "export const RESERVED = new Set([\n", " \"MatMul\",\n", " \"plot\",\n", " \"PowerSet\",\n", " \"terms_gcd\",\n", " \"dotprint\",\n", " \"cacheit\",\n", " \"GramSchmidt\",\n", " \"UnevaluatedExpr\",\n", " \"composite\",\n", " \"has_dups\",\n", " \"mathieucprime\",\n", " \"hermite_prob\",\n", " \"ComplexField\",\n", " \"MatPow\",\n", " \"hessian\",\n", " \"hn1\",\n", " \"jn_zeros\",\n", " \"solve_univariate_inequality\",\n", " \"credits\",\n", " \"vars\",\n", " \"Contains\",\n", " \"real_roots\",\n", " \"assemble_partfrac_list\",\n", " \"Complexes\",\n", " \"vring\",\n", " \"epath\",\n", " \"numer\",\n", " \"gff\",\n", " \"line_integrate\",\n", " \"lucas\",\n", " \"Curve\",\n", " \"Ellipse\",\n", " \"reduce_abs_inequality\",\n", " \"intt\",\n", " \"factorrat\",\n", " \"capture\",\n", " \"cancel\",\n", " \"Point2D\",\n", " \"gammasimp\",\n", " \"polar_lift\",\n", " \"chebyshevt_root\",\n", " \"EXRAW\",\n", " \"SystemExit\",\n", " \"Rational\",\n", " \"together\",\n", " \"ValueError\",\n", " \"ode_order\",\n", " \"DiagonalOf\",\n", " \"return\",\n", " \"getattr\",\n", " \"limit\",\n", " \"minimum\",\n", " \"NumberSymbol\",\n", " \"decompogen\",\n", " \"lowergamma\",\n", " \"ImageSet\",\n", " \"floor\",\n", " \"ground_roots\",\n", " \"assoc_legendre\",\n", " \"multiplicity\",\n", " \"PythonIntegerRing\",\n", " \"nfloat\",\n", " \"rsolve_ratio\",\n", " \"jacobi_normalized\",\n", " \"tensorcontraction\",\n", " \"finally\",\n", " \"from\",\n", " \"sqf_list\",\n", " \"FourierTransform\",\n", " \"inverse_cosine_transform\",\n", " \"adjoint\",\n", " \"Sieve\",\n", " \"GeneratorExit\",\n", " \"bool\",\n", " \"print\",\n", " \"bytearray\",\n", " \"farthest_points\",\n", " \"kroneckersimp\",\n", " \"denom\",\n", " \"setattr\",\n", " \"And\",\n", " \"break\",\n", " \"unpolarify\",\n", " \"filter\",\n", " \"reversed\",\n", " \"sin\",\n", " \"limit_seq\",\n", " \"RootSum\",\n", " \"closest_points\",\n", " \"pollard_rho\",\n", " \"Domain\",\n", " \"rcode\",\n", " \"cyclotomic_poly\",\n", " \"stieltjes\",\n", " \"root\",\n", " \"HadamardPower\",\n", " \"maximum\",\n", " \"NonSquareMatrixError\",\n", " \"Nand\",\n", " \"is\",\n", " \"EnvironmentError\",\n", " \"SingularityFunction\",\n", " \"rsolve_poly\",\n", " \"Order\",\n", " \"FU\",\n", " \"QQ\",\n", " \"chebyshevu\",\n", " \"numbered_symbols\",\n", " \"ImmutableSparseMatrix\",\n", " \"stationary_points\",\n", " \"trace\",\n", " \"is_strictly_decreasing\",\n", " \"rot_axis1\",\n", " \"multigamma\",\n", " \"rational_interpolate\",\n", " \"Ei\",\n", " \"KeyboardInterrupt\",\n", " \"Ci\",\n", " \"Reals\",\n", " \"signsimp\",\n", " \"is_zero_dimensional\",\n", " \"singularities\",\n", " \"loggamma\",\n", " \"filldedent\",\n", " \"for\",\n", " \"UnboundLocalError\",\n", " \"idiff\",\n", " \"Catalan\",\n", " \"InterruptedError\",\n", " \"apply_finite_diff\",\n", " \"GeometryError\",\n", " \"FractionField\",\n", " \"blockcut\",\n", " \"OperationNotSupported\",\n", " \"approximants\",\n", " \"GeneratorsNeeded\",\n", " \"deg\",\n", " \"print_fcode\",\n", " \"quit\",\n", " \"TimeoutError\",\n", " \"Wild\",\n", " \"periodic_argument\",\n", " \"ProcessLookupError\",\n", " \"Array\",\n", " \"besselj\",\n", " \"sign\",\n", " \"inverse_mellin_transform\",\n", " \"airyaiprime\",\n", " \"Eq\",\n", " \"Circle\",\n", " \"factor\",\n", " \"matrix2numpy\",\n", " \"tensor\",\n", " \"unflatten\",\n", " \"julia_code\",\n", " \"cbrt\",\n", " \"jacobi\",\n", " \"ComplexRegion\",\n", " \"pretty\",\n", " \"ring\",\n", " \"MatrixBase\",\n", " \"permutedims\",\n", " \"refine\",\n", " \"mathieusprime\",\n", " \"FutureWarning\",\n", " \"mersenne_prime_exponent\",\n", " \"GeneratorsError\",\n", " \"Le\",\n", " \"OneMatrix\",\n", " \"subsets\",\n", " \"memoize_property\",\n", " \"GMPYRationalField\",\n", " \"parse_expr\",\n", " \"FileNotFoundError\",\n", " \"has_variety\",\n", " \"DenseNDimArray\",\n", " \"class\",\n", " \"sqrt_mod_iter\",\n", " \"pager_print\",\n", " \"mathieuc\",\n", " \"prime_valuation\",\n", " \"factor_list\",\n", " \"hadamard_product\",\n", " \"mobius_transform\",\n", " \"sech\",\n", " \"threaded\",\n", " \"hex\",\n", " \"MatrixPermute\",\n", " \"acsch\",\n", " \"airybi\",\n", " \"combsimp\",\n", " \"continued_fraction\",\n", " \"harmonic\",\n", " \"in\",\n", " \"NDimArray\",\n", " \"is_perfect\",\n", " \"utilities\",\n", " \"Segment\",\n", " \"interpolating_spline\",\n", " \"SparseMatrix\",\n", " \"Matrix\",\n", " \"MatrixExpr\",\n", " \"E\",\n", " \"Or\",\n", " \"Ynm\",\n", " \"shape\",\n", " \"poly\",\n", " \"solveset\",\n", " \"differentiate_finite\",\n", " \"print_rcode\",\n", " \"classmethod\",\n", " \"AttributeError\",\n", " \"runfile\",\n", " \"GMPYIntegerRing\",\n", " \"polarify\",\n", " \"fwht\",\n", " \"sqrt_mod\",\n", " \"nonlocal\",\n", " \"MatrixSlice\",\n", " \"series\",\n", " \"concrete\",\n", " \"display\",\n", " \"locals\",\n", " \"is_quad_residue\",\n", " \"refine_root\",\n", " \"LM\",\n", " \"binomial\",\n", " \"pdiv\",\n", " \"Abs\",\n", " \"jscode\",\n", " \"solve_undetermined_coeffs\",\n", " \"def\",\n", " \"Unequality\",\n", " \"WildFunction\",\n", " \"coth\",\n", " \"and\",\n", " \"chebyshevt_poly\",\n", " \"PermissionError\",\n", " \"check_assumptions\",\n", " \"anext\",\n", " \"dict\",\n", " \"intersection\",\n", " \"type\",\n", " \"fresnels\",\n", " \"trigamma\",\n", " \"Quaternion\",\n", " \"rotations\",\n", " \"Subs\",\n", " \"ChildProcessError\",\n", " \"compile\",\n", " \"UnivariatePolynomialError\",\n", " \"expand_power_exp\",\n", " \"xfield\",\n", " \"exit\",\n", " \"BlockMatrix\",\n", " \"minimal_polynomial\",\n", " \"imageset\",\n", " \"InverseLaplaceTransform\",\n", " \"Idx\",\n", " \"release\",\n", " \"Integers\",\n", " \"set\",\n", " \"Atom\",\n", " \"Basic\",\n", " \"Min\",\n", " \"Not\",\n", " \"RationalField\",\n", " \"Rem\",\n", " \"Predicate\",\n", " \"print_jscode\",\n", " \"reduced_totient\",\n", " \"sieve\",\n", " \"to_nnf\",\n", " \"SeqMul\",\n", " \"im\",\n", " \"Integer\",\n", " \"Parabola\",\n", " \"UnicodeEncodeError\",\n", " \"quadratic_residues\",\n", " \"laplace_transform\",\n", " \"banded\",\n", " \"gcd_terms\",\n", " \"poly_from_expr\",\n", " \"rust_code\",\n", " \"sqf\",\n", " \"Set\",\n", " \"decompose\",\n", " \"frac\",\n", " \"all\",\n", " \"fresnelc\",\n", " \"UniversalSet\",\n", " \"Polygon\",\n", " \"betainc\",\n", " \"centroid\",\n", " \"ImportError\",\n", " \"help\",\n", " \"default_sort_key\",\n", " \"legendre_poly\",\n", " \"SystemError\",\n", " \"register_handler\",\n", " \"cxxcode\",\n", " \"invert\",\n", " \"real_root\",\n", " \"hyper\",\n", " \"pollard_pm1\",\n", " \"TabError\",\n", " \"airybiprime\",\n", " \"satisfiable\",\n", " \"prod\",\n", " \"get_indices\",\n", " \"inv_quick\",\n", " \"piecewise_fold\",\n", " \"Point3D\",\n", " \"open\",\n", " \"LC\",\n", " \"per\",\n", " \"Ray3D\",\n", " \"periodicity\",\n", " \"expand_func\",\n", " \"frozenset\",\n", " \"polys\",\n", " \"Segment2D\",\n", " \"Heaviside\",\n", " \"residue\",\n", " \"ImmutableDenseMatrix\",\n", " \"ArithmeticError\",\n", " \"separatevars\",\n", " \"CoercionFailed\",\n", " \"horner\",\n", " \"ImportWarning\",\n", " \"range\",\n", " \"S\",\n", " \"hankel1\",\n", " \"topological_sort\",\n", " \"smtlib_code\",\n", " \"take\",\n", " \"uppergamma\",\n", " \"Line\",\n", " \"singularityintegrate\",\n", " \"Float\",\n", " \"ascii\",\n", " \"log\",\n", " \"interactive_traversal\",\n", " \"li\",\n", " \"unbranched_argument\",\n", " \"Transpose\",\n", " \"degree\",\n", " \"det\",\n", " \"QQ_gmpy\",\n", " \"finite_diff_weights\",\n", " \"lambdify\",\n", " \"acsc\",\n", " \"posify\",\n", " \"powdenest\",\n", " \"rot_ccw_axis1\",\n", " \"ExpressionDomain\",\n", " \"symbols\",\n", " \"import\",\n", " \"Ge\",\n", " \"fraction\",\n", " \"RR\",\n", " \"mathieus\",\n", " \"csc\",\n", " \"randprime\",\n", " \"simplify\",\n", " \"is_strictly_increasing\",\n", " \"is_mersenne_prime\",\n", " \"SymmetricDifference\",\n", " \"ImmutableMatrix\",\n", " \"LessThan\",\n", " \"init_printing\",\n", " \"min\",\n", " \"discriminant\",\n", " \"sorted\",\n", " \"isolate\",\n", " \"comp\",\n", " \"asinh\",\n", " \"interactive\",\n", " \"linear_eq_to_matrix\",\n", " \"Range\",\n", " \"chebyshevu_poly\",\n", " \"reduced\",\n", " \"round_two\",\n", " \"block_collapse\",\n", " \"ConnectionError\",\n", " \"Complement\",\n", " \"pprint_try_use_unicode\",\n", " \"besselk\",\n", " \"mellin_transform\",\n", " \"Equality\",\n", " \"CRootOf\",\n", " \"ITE\",\n", " \"IndexError\",\n", " \"RuntimeWarning\",\n", " \"Warning\",\n", " \"geometry\",\n", " \"arity\",\n", " \"lex\",\n", " \"variations\",\n", " \"GroebnerBasis\",\n", " \"as\",\n", " \"assoc_laguerre\",\n", " \"ordered\",\n", " \"postfixes\",\n", " \"pde_separate_mul\",\n", " \"ceiling\",\n", " \"await\",\n", " \"continued_fraction_periodic\",\n", " \"perfect_power\",\n", " \"primitive\",\n", " \"RegularPolygon\",\n", " \"expand_log\",\n", " \"multiline_latex\",\n", " \"atan2\",\n", " \"eye\",\n", " \"ReferenceError\",\n", " \"IntegerRing\",\n", " \"O\",\n", " \"hyperexpand\",\n", " \"eval\",\n", " \"fcode\",\n", " \"dirichlet_eta\",\n", " \"cosh\",\n", " \"elliptic_k\",\n", " \"del\",\n", " \"False\",\n", " \"grlex\",\n", " \"MutableDenseNDimArray\",\n", " \"EOFError\",\n", " \"jn\",\n", " \"DiracDelta\",\n", " \"StrictGreaterThan\",\n", " \"jordan_cell\",\n", " \"seterr\",\n", " \"to_dnf\",\n", " \"staticmethod\",\n", " \"checkpdesol\",\n", " \"zeros\",\n", " \"isinstance\",\n", " \"cofactors\",\n", " \"trunc\",\n", " \"divisors\",\n", " \"PolificationFailed\",\n", " \"Plane\",\n", " \"linsolve\",\n", " \"matrix_symbols\",\n", " \"bool_map\",\n", " \"gamma\",\n", " \"hn2\",\n", " \"reshape\",\n", " \"property\",\n", " \"gcdex\",\n", " \"textplot\",\n", " \"tensordiagonal\",\n", " \"groebner\",\n", " \"input\",\n", " \"true\",\n", " \"homogeneous_order\",\n", " \"copyright\",\n", " \"pexquo\",\n", " \"inverse_laplace_transform\",\n", " \"primepi\",\n", " \"discrete\",\n", " \"Naturals0\",\n", " \"collect\",\n", " \"RefinementFailed\",\n", " \"intersecting_product\",\n", " \"factorint\",\n", " \"IsADirectoryError\",\n", " \"hasattr\",\n", " \"AccumBounds\",\n", " \"EvaluationFailed\",\n", " \"gcd_list\",\n", " \"gruntz\",\n", " \"Q\",\n", " \"primitive_root\",\n", " \"sfield\",\n", " \"postorder_traversal\",\n", " \"catalan\",\n", " \"evaluate\",\n", " \"OSError\",\n", " \"NotImplemented\",\n", " \"Gt\",\n", " \"laplace_initial_conds\",\n", " \"lcm\",\n", " \"pprint\",\n", " \"inverse_sine_transform\",\n", " \"Sum\",\n", " \"mobius\",\n", " \"tuple\",\n", " \"EmptySet\",\n", " \"ConditionSet\",\n", " \"Ordinal\",\n", " \"fps\",\n", " \"ZZ\",\n", " \"Ellipsis\",\n", " \"MemoryError\",\n", " \"SOPform\",\n", " \"FiniteField\",\n", " \"PermutationMatrix\",\n", " \"elliptic_pi\",\n", " \"elliptic_f\",\n", " \"factor_terms\",\n", " \"total_degree\",\n", " \"AssertionError\",\n", " \"acos\",\n", " \"assuming\",\n", " \"Function\",\n", " \"SeqAdd\",\n", " \"oo\",\n", " \"primerange\",\n", " \"tan\",\n", " \"timed\",\n", " \"OverflowError\",\n", " \"sstr\",\n", " \"asec\",\n", " \"Piecewise\",\n", " \"tensorproduct\",\n", " \"reduce_abs_inequalities\",\n", " \"matrix_multiply_elementwise\",\n", " \"randMatrix\",\n", " \"id\",\n", " \"QQ_I\",\n", " \"grevlex\",\n", " \"roots\",\n", " \"ExactQuotientFailed\",\n", " \"UnicodeTranslateError\",\n", " \"hash\",\n", " \"plot_backends\",\n", " \"are_similar\",\n", " \"inverse_hankel_transform\",\n", " \"gcd\",\n", " \"FallingFactorial\",\n", " \"Identity\",\n", " \"memoryview\",\n", " \"monic\",\n", " \"FloatingPointError\",\n", " \"sring\",\n", " \"rot_givens\",\n", " \"KroneckerDelta\",\n", " \"var\",\n", " \"count_ops\",\n", " \"casoratian\",\n", " \"NotAlgebraic\",\n", " \"dsolve\",\n", " \"ord0\",\n", " \"is_increasing\",\n", " \"continue\",\n", " \"prime\",\n", " \"subresultants\",\n", " \"QQ_python\",\n", " \"AppliedPredicate\",\n", " \"AlgebraicNumber\",\n", " \"erf\",\n", " \"InverseMellinTransform\",\n", " \"UnificationFailed\",\n", " \"ModuleNotFoundError\",\n", " \"compositepi\",\n", " \"DiagonalMatrix\",\n", " \"OmegaPower\",\n", " \"powsimp\",\n", " \"LookupError\",\n", " \"exp_polar\",\n", " \"Determinant\",\n", " \"IndexedBase\",\n", " \"get_ipython\",\n", " \"is_abundant\",\n", " \"num_digits\",\n", " \"strategies\",\n", " \"ZZ_gmpy\",\n", " \"expand_complex\",\n", " \"fourier_series\",\n", " \"calculus\",\n", " \"div\",\n", " \"bytes\",\n", " \"SineTransform\",\n", " \"ff\",\n", " \"IndentationError\",\n", " \"print_gtk\",\n", " \"digamma\",\n", " \"MutableDenseMatrix\",\n", " \"motzkin\",\n", " \"assumptions\",\n", " \"ShapeError\",\n", " \"covering_product\",\n", " \"Product\",\n", " \"MatAdd\",\n", " \"wronskian\",\n", " \"DiagMatrix\",\n", " \"xthreaded\",\n", " \"dict_merge\",\n", " \"IOError\",\n", " \"classify_ode\",\n", " \"product\",\n", " \"convex_hull\",\n", " \"primitive_element\",\n", " \"RealField\",\n", " \"bernoulli\",\n", " \"discrete_log\",\n", " \"integer_log\",\n", " \"difference_delta\",\n", " \"sequence\",\n", " \"solve_linear\",\n", " \"Number\",\n", " \"Xor\",\n", " \"chebyshevu_root\",\n", " \"pquo\",\n", " \"erf2\",\n", " \"async\",\n", " \"content\",\n", " \"hermite_prob_poly\",\n", " \"gff_list\",\n", " \"TypeError\",\n", " \"KeyError\",\n", " \"Interval\",\n", " \"AlgebraicField\",\n", " \"Lt\",\n", " \"erfinv\",\n", " \"preorder_traversal\",\n", " \"not_empty_in\",\n", " \"compose\",\n", " \"solve_poly_inequality\",\n", " \"CC\",\n", " \"mod_inverse\",\n", " \"srepr\",\n", " \"solve_triangulated\",\n", " \"PrecisionExhausted\",\n", " \"Naturals\",\n", " \"evalf\",\n", " \"BaseException\",\n", " \"FlagError\",\n", " \"aiter\",\n", " \"exec\",\n", " \"chebyshevt\",\n", " \"chr\",\n", " \"print_latex\",\n", " \"airyai\",\n", " \"BlockingIOError\",\n", " \"I\",\n", " \"acot\",\n", " \"sturm\",\n", " \"to_number_field\",\n", " \"Expr\",\n", " \"HeuristicGCDFailed\",\n", " \"diophantine\",\n", " \"hypersimilar\",\n", " \"GoldenRatio\",\n", " \"resultant\",\n", " \"LeviCivita\",\n", " \"genocchi\",\n", " \"prefixes\",\n", " \"except\",\n", " \"Adjoint\",\n", " \"PolynomialRing\",\n", " \"convolution\",\n", " \"arg\",\n", " \"get_contraction_structure\",\n", " \"FF_gmpy\",\n", " \"half_gcdex\",\n", " \"marcumq\",\n", " \"InverseCosineTransform\",\n", " \"fft\",\n", " \"ProductSet\",\n", " \"to_cnf\",\n", " \"Mod\",\n", " \"Ray\",\n", " \"igrevlex\",\n", " \"zoo\",\n", " \"piecewise_exclusive\",\n", " \"primefactors\",\n", " \"fu\",\n", " \"rcollect\",\n", " \"TribonacciConstant\",\n", " \"ExtraneousFactors\",\n", " \"GreaterThan\",\n", " \"SparseNDimArray\",\n", " \"factorial\",\n", " \"StrPrinter\",\n", " \"expand\",\n", " \"PurePoly\",\n", " \"elif\",\n", " \"Line2D\",\n", " \"SympifyError\",\n", " \"NotReversible\",\n", " \"ilex\",\n", " \"galois_group\",\n", " \"proper_divisor_count\",\n", " \"DomainError\",\n", " \"BytesWarning\",\n", " \"ntheory\",\n", " \"HankelTransform\",\n", " \"cot\",\n", " \"checksol\",\n", " \"expand_power_base\",\n", " \"failing_assumptions\",\n", " \"latex\",\n", " \"solve_linear_system\",\n", " \"trailing\",\n", " \"float\",\n", " \"Eijk\",\n", " \"all_roots\",\n", " \"ntt\",\n", " \"issubclass\",\n", " \"HomomorphismFailed\",\n", " \"Lambda\",\n", " \"is_monotonic\",\n", " \"proper_divisors\",\n", " \"breakpoint\",\n", " \"subfactorial\",\n", " \"euler_equations\",\n", " \"logcombine\",\n", " \"while\",\n", " \"legendre_symbol\",\n", " \"EulerGamma\",\n", " \"elliptic_e\",\n", " \"plotting\",\n", " \"substitution\",\n", " \"sympify\",\n", " \"nsimplify\",\n", " \"atanh\",\n", " \"hermite_poly\",\n", " \"euler\",\n", " \"In\",\n", " \"Monomial\",\n", " \"functions\",\n", " \"FunctionMatrix\",\n", " \"UserWarning\",\n", " \"symarray\",\n", " \"count_roots\",\n", " \"diagonalize_vector\",\n", " \"Rationals\",\n", " \"false\",\n", " \"cse\",\n", " \"prem\",\n", " \"DotProduct\",\n", " \"len\",\n", " \"ask\",\n", " \"riemann_xi\",\n", " \"Implies\",\n", " \"raise\",\n", " \"map\",\n", " \"Si\",\n", " \"fourier_transform\",\n", " \"plot_parametric\",\n", " \"NameError\",\n", " \"super\",\n", " \"tanh\",\n", " \"field\",\n", " \"hypersimp\",\n", " \"SeqPer\",\n", " \"legendre\",\n", " \"pow\",\n", " \"algebras\",\n", " \"isprime\",\n", " \"not\",\n", " \"solve_linear_system_LU\",\n", " \"FiniteSet\",\n", " \"laguerre_poly\",\n", " \"Limit\",\n", " \"igcd\",\n", " \"RootOf\",\n", " \"Poly\",\n", " \"Rel\",\n", " \"csch\",\n", " \"yield\",\n", " \"max\",\n", " \"True\",\n", " \"factor_nc\",\n", " \"EmptySequence\",\n", " \"inverse_mobius_transform\",\n", " \"rot_axis2\",\n", " \"rot_ccw_axis3\",\n", " \"any\",\n", " \"with\",\n", " \"GF\",\n", " \"exptrigsimp\",\n", " \"erfi\",\n", " \"pretty_print\",\n", " \"continued_fraction_convergents\",\n", " \"init_session\",\n", " \"parsing\",\n", " \"rem\",\n", " \"RecursionError\",\n", " \"DeferredVector\",\n", " \"multinomial_coefficients\",\n", " \"radsimp\",\n", " \"hankel_transform\",\n", " \"n_order\",\n", " \"str\",\n", " \"transpose\",\n", " \"plot_implicit\",\n", " \"Symbol\",\n", " \"mathml\",\n", " \"ifwht\",\n", " \"if\",\n", " \"diff\",\n", " \"PythonFiniteField\",\n", " \"ifft\",\n", " \"Point\",\n", " \"factorial2\",\n", " \"is_carmichael\",\n", " \"Indexed\",\n", " \"EPath\",\n", " \"degree_list\",\n", " \"nan\",\n", " \"sqrtdenest\",\n", " \"sift\",\n", " \"Nor\",\n", " \"SyntaxWarning\",\n", " \"rsolve_hyper\",\n", " \"InverseSineTransform\",\n", " \"BrokenPipeError\",\n", " \"swinnerton_dyer_poly\",\n", " \"abs\",\n", " \"beta\",\n", " \"parallel_poly_from_expr\",\n", " \"besseli\",\n", " \"use\",\n", " \"Equivalent\",\n", " \"checkodesol\",\n", " \"prime_decomp\",\n", " \"betainc_regularized\",\n", " \"sinc\",\n", " \"ratsimp\",\n", " \"object\",\n", " \"Shi\",\n", " \"Options\",\n", " \"field_isomorphism\",\n", " \"bspline_basis\",\n", " \"zip\",\n", " \"InverseFourierTransform\",\n", " \"CosineTransform\",\n", " \"bottom_up\",\n", " \"andre\",\n", " \"DisjointUnion\",\n", " \"collect_const\",\n", " \"enumerate\",\n", " \"Line3D\",\n", " \"is_decreasing\",\n", " \"BlockDiagMatrix\",\n", " \"MellinTransform\",\n", " \"solve\",\n", " \"int\",\n", " \"ConnectionResetError\",\n", " \"rot_axis3\",\n", " \"NotImplementedError\",\n", " \"next\",\n", " \"globals\",\n", " \"printing\",\n", " \"bessely\",\n", " \"N\",\n", " \"sstrrepr\",\n", " \"Permanent\",\n", " \"sum\",\n", " \"binomial_coefficients_list\",\n", " \"jacobi_poly\",\n", " \"nthroot_mod\",\n", " \"PolynomialError\",\n", " \"expand_mul\",\n", " \"delattr\",\n", " \"ln\",\n", " \"integer_nthroot\",\n", " \"Ynm_c\",\n", " \"sqrt\",\n", " \"zeta\",\n", " \"assert\",\n", " \"python\",\n", " \"classify_pde\",\n", " \"interpolating_poly\",\n", " \"rot_ccw_axis2\",\n", " \"EX\",\n", " \"ComplexRootOf\",\n", " \"MultivariatePolynomialError\",\n", " \"flatten\",\n", " \"print_python\",\n", " \"cosine_transform\",\n", " \"ResourceWarning\",\n", " \"multipledispatch\",\n", " \"None\",\n", " \"apart\",\n", " \"ZZ_I\",\n", " \"continued_fraction_reduce\",\n", " \"quadratic_congruence\",\n", " \"Ne\",\n", " \"license\",\n", " \"Chi\",\n", " \"sqf_part\",\n", " \"atan\",\n", " \"is_primitive_root\",\n", " \"print_tree\",\n", " \"Tuple\",\n", " \"StopAsyncIteration\",\n", " \"MutableSparseMatrix\",\n", " \"random_poly\",\n", " \"ccode\",\n", " \"trigsimp\",\n", " \"is_amicable\",\n", " \"lambda\",\n", " \"ZZ_python\",\n", " \"Add\",\n", " \"derive_by_array\",\n", " \"itermonomials\",\n", " \"Max\",\n", " \"abundance\",\n", " \"acoth\",\n", " \"FF_python\",\n", " \"nsolve\",\n", " \"principal_branch\",\n", " \"lerchphi\",\n", " \"ImmutableDenseNDimArray\",\n", " \"BasePolynomialError\",\n", " \"viete\",\n", " \"sec\",\n", " \"pycode\",\n", " \"expand_trig\",\n", " \"bell\",\n", " \"pprint_use_unicode\",\n", " \"sinh\",\n", " \"list\",\n", " \"SeqFormula\",\n", " \"cartes\",\n", " \"ZeroDivisionError\",\n", " \"dir\",\n", " \"Mul\",\n", " \"is_deficient\",\n", " \"re\",\n", " \"rsolve\",\n", " \"slice\",\n", " \"integrate\",\n", " \"E1\",\n", " \"Ray2D\",\n", " \"xring\",\n", " \"pass\",\n", " \"print_glsl\",\n", " \"primenu\",\n", " \"oct\",\n", " \"npartitions\",\n", " \"totient\",\n", " \"PolynomialDivisionFailed\",\n", " \"kronecker_product\",\n", " \"PoleError\",\n", " \"OptionError\",\n", " \"appellf1\",\n", " \"exp\",\n", " \"preview\",\n", " \"Triangle\",\n", " \"besselsimp\",\n", " \"Pow\",\n", " \"group\",\n", " \"quo\",\n", " \"NotADirectoryError\",\n", " \"round\",\n", " \"Id\",\n", " \"print_maple_code\",\n", " \"AtomicExpr\",\n", " \"divisor_sigma\",\n", " \"vfield\",\n", " \"GMPYFiniteField\",\n", " \"simplify_logic\",\n", " \"maple_code\",\n", " \"EncodingWarning\",\n", " \"erfc\",\n", " \"callable\",\n", " \"glsl_code\",\n", " \"ImmutableSparseNDimArray\",\n", " \"acosh\",\n", " \"ilcm\",\n", " \"rad\",\n", " \"MatrixSymbol\",\n", " \"exquo\",\n", " \"jacobi_symbol\",\n", " \"symmetric_poly\",\n", " \"cos\",\n", " \"kronecker_symbol\",\n", " \"minpoly\",\n", " \"LaplaceTransform\",\n", " \"KroneckerProduct\",\n", " \"erf2inv\",\n", " \"fibonacci\",\n", " \"primeomega\",\n", " \"solve_rational_inequalities\",\n", " \"BufferError\",\n", " \"DeprecationWarning\",\n", " \"intervals\",\n", " \"hankel2\",\n", " \"PendingDeprecationWarning\",\n", " \"execfile\",\n", " \"interpolate\",\n", " \"mathematica_code\",\n", " \"complex\",\n", " \"inverse_fourier_transform\",\n", " \"bspline_basis_set\",\n", " \"doctest\",\n", " \"vectorize\",\n", " \"UnicodeWarning\",\n", " \"conjugate\",\n", " \"TableForm\",\n", " \"hermite\",\n", " \"continued_fraction_iterator\",\n", " \"iter\",\n", " \"print_mathml\",\n", " \"bin\",\n", " \"MutableMatrix\",\n", " \"carmichael\",\n", " \"cycle_length\",\n", " \"Dummy\",\n", " \"is_nthpow_residue\",\n", " \"summation\",\n", " \"nextprime\",\n", " \"polygamma\",\n", " \"erfcinv\",\n", " \"try\",\n", " \"ratsimpmodprime\",\n", " \"Exception\",\n", " \"Segment3D\",\n", " \"Intersection\",\n", " \"HadamardProduct\",\n", " \"divisor_count\",\n", " \"meijerg\",\n", " \"polylog\",\n", " \"partition\",\n", " \"symmetrize\",\n", " \"remove_handler\",\n", " \"asech\",\n", " \"yn\",\n", " \"repr\",\n", " \"list2numpy\",\n", " \"StrictLessThan\",\n", " \"ComputationFailed\",\n", " \"sqf_norm\",\n", " \"is_convex\",\n", " \"InverseHankelTransform\",\n", " \"LambertW\",\n", " \"ConnectionRefusedError\",\n", " \"RuntimeError\",\n", " \"Out\",\n", " \"nonlinsolve\",\n", " \"sine_transform\",\n", " \"FileExistsError\",\n", " \"tribonacci\",\n", " \"construct_domain\",\n", " \"lcm_list\",\n", " \"solve_poly_system\",\n", " \"FunctionClass\",\n", " \"nroots\",\n", " \"MutableSparseNDimArray\",\n", " \"binomial_coefficients\",\n", " \"det_quick\",\n", " \"egyptian_fraction\",\n", " \"laguerre\",\n", " \"nth_power_roots_poly\",\n", " \"rf\",\n", " \"rootof\",\n", " \"asin\",\n", " \"ExceptionGroup\",\n", " \"print_ccode\",\n", " \"RealNumber\",\n", " \"test\",\n", " \"expint\",\n", " \"diag\",\n", " \"else\",\n", " \"PythonRational\",\n", " \"Inverse\",\n", " \"BaseExceptionGroup\",\n", " \"ones\",\n", " \"ConnectionAbortedError\",\n", " \"Trace\",\n", " \"SyntaxError\",\n", " \"octave_code\",\n", " \"IsomorphismFailed\",\n", " \"POSform\",\n", " \"pdsolve\",\n", " \"NotInvertible\",\n", " \"public\",\n", " \"Znm\",\n", " \"prevprime\",\n", " \"laplace_correspondence\",\n", " \"reduce_inequalities\",\n", " \"FF\",\n", " \"AssumptionsContext\",\n", " \"UnicodeDecodeError\",\n", " \"ord\",\n", " \"Integral\",\n", " \"Li\",\n", " \"igrlex\",\n", " \"primorial\",\n", " \"external\",\n", " \"or\",\n", " \"ZeroMatrix\",\n", " \"pde_separate_add\",\n", " \"StopIteration\",\n", " \"divmod\",\n", " \"RisingFactorial\",\n", " \"format\",\n", " \"Dict\",\n", " \"expand_multinomial\",\n", " \"Derivative\",\n", " \"LT\",\n", " \"Union\",\n", " \"gegenbauer\",\n", " \"pde_separate\",\n", " \"apart_list\",\n", " \"UnicodeError\",\n", " \"global\",\n", "]);\n" ] } ], "source": [ "js_code = to_javascript(reserved)\n", "\n", "print(js_code)" ] }, { "cell_type": "code", "execution_count": null, "id": "a835ac94-541d-41ee-a56d-39583fd4063b", "metadata": {}, "outputs": [], "source": [] } ], "metadata": { "kernelspec": { "display_name": "Python 3 (ipykernel)", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.12.7" } }, "nbformat": 4, "nbformat_minor": 5 } ================================================ FILE: notebooks/reserved_ids_no_sympy.ipynb ================================================ { "cells": [ { "cell_type": "code", "execution_count": 1, "id": "fe5a40c3-b7f8-4421-b29d-552438fb32e3", "metadata": {}, "outputs": [ { "data": { "text/plain": [ "178" ] }, "execution_count": 1, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# add python reserved keywords\n", "import keyword\n", "reserved = set(keyword.kwlist)\n", "\n", "# add python builtin functions\n", "import builtins\n", "reserved.update(dir(builtins))\n", "\n", "# remove symbols that begin with underscore, also remove pi since pi maps one-to-one\n", "reserved = {value for value in reserved if not value.startswith('_') and value != 'pi'}\n", "\n", "len(reserved)" ] }, { "cell_type": "code", "execution_count": 2, "id": "e70db174-fa8a-471d-aa68-bc015e22796c", "metadata": {}, "outputs": [], "source": [ "def to_javascript(reserved):\n", " output = \"export const PYTHON_RESERVED = new Set([\\n\"\n", " \n", " for symbol in reserved:\n", " output += f' \"{symbol}\",\\n'\n", " \n", " output += \"]);\"\n", " \n", " return output\n", " " ] }, { "cell_type": "code", "execution_count": 3, "id": "7e8d236f-15d1-444f-a65b-ec70e3bcf8a8", "metadata": { "scrolled": false }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "export const PYTHON_RESERVED = new Set([\n", " \"FileNotFoundError\",\n", " \"execfile\",\n", " \"exec\",\n", " \"ImportWarning\",\n", " \"class\",\n", " \"frozenset\",\n", " \"ModuleNotFoundError\",\n", " \"UnicodeDecodeError\",\n", " \"as\",\n", " \"delattr\",\n", " \"MemoryError\",\n", " \"ChildProcessError\",\n", " \"type\",\n", " \"BaseException\",\n", " \"KeyError\",\n", " \"slice\",\n", " \"ConnectionError\",\n", " \"Exception\",\n", " \"SyntaxWarning\",\n", " \"bin\",\n", " \"AttributeError\",\n", " \"return\",\n", " \"while\",\n", " \"EnvironmentError\",\n", " \"hex\",\n", " \"OverflowError\",\n", " \"IsADirectoryError\",\n", " \"UnicodeWarning\",\n", " \"staticmethod\",\n", " \"else\",\n", " \"runfile\",\n", " \"import\",\n", " \"max\",\n", " \"Warning\",\n", " \"GeneratorExit\",\n", " \"bytes\",\n", " \"bool\",\n", " \"print\",\n", " \"ReferenceError\",\n", " \"RuntimeWarning\",\n", " \"credits\",\n", " \"globals\",\n", " \"pow\",\n", " \"NotImplemented\",\n", " \"from\",\n", " \"range\",\n", " \"hash\",\n", " \"pass\",\n", " \"if\",\n", " \"def\",\n", " \"FileExistsError\",\n", " \"vars\",\n", " \"ProcessLookupError\",\n", " \"NameError\",\n", " \"chr\",\n", " \"SystemError\",\n", " \"SystemExit\",\n", " \"callable\",\n", " \"ConnectionAbortedError\",\n", " \"TabError\",\n", " \"ZeroDivisionError\",\n", " \"with\",\n", " \"yield\",\n", " \"iter\",\n", " \"InterruptedError\",\n", " \"NotImplementedError\",\n", " \"ImportError\",\n", " \"RuntimeError\",\n", " \"ConnectionRefusedError\",\n", " \"map\",\n", " \"tuple\",\n", " \"BlockingIOError\",\n", " \"False\",\n", " \"TimeoutError\",\n", " \"continue\",\n", " \"is\",\n", " \"id\",\n", " \"setattr\",\n", " \"elif\",\n", " \"ConnectionResetError\",\n", " \"del\",\n", " \"float\",\n", " \"ascii\",\n", " \"list\",\n", " \"TypeError\",\n", " \"break\",\n", " \"for\",\n", " \"True\",\n", " \"BrokenPipeError\",\n", " \"IOError\",\n", " \"copyright\",\n", " \"input\",\n", " \"super\",\n", " \"compile\",\n", " \"and\",\n", " \"eval\",\n", " \"any\",\n", " \"isinstance\",\n", " \"dir\",\n", " \"classmethod\",\n", " \"NotADirectoryError\",\n", " \"zip\",\n", " \"bytearray\",\n", " \"FloatingPointError\",\n", " \"or\",\n", " \"ord\",\n", " \"divmod\",\n", " \"finally\",\n", " \"BytesWarning\",\n", " \"IndentationError\",\n", " \"format\",\n", " \"dict\",\n", " \"min\",\n", " \"object\",\n", " \"property\",\n", " \"EOFError\",\n", " \"str\",\n", " \"PermissionError\",\n", " \"display\",\n", " \"nonlocal\",\n", " \"lambda\",\n", " \"len\",\n", " \"in\",\n", " \"memoryview\",\n", " \"None\",\n", " \"reversed\",\n", " \"UnicodeError\",\n", " \"AssertionError\",\n", " \"UnboundLocalError\",\n", " \"assert\",\n", " \"set\",\n", " \"async\",\n", " \"all\",\n", " \"int\",\n", " \"Ellipsis\",\n", " \"sum\",\n", " \"open\",\n", " \"help\",\n", " \"await\",\n", " \"BufferError\",\n", " \"IndexError\",\n", " \"repr\",\n", " \"try\",\n", " \"not\",\n", " \"PendingDeprecationWarning\",\n", " \"StopAsyncIteration\",\n", " \"complex\",\n", " \"sorted\",\n", " \"RecursionError\",\n", " \"round\",\n", " \"abs\",\n", " \"FutureWarning\",\n", " \"SyntaxError\",\n", " \"oct\",\n", " \"StopIteration\",\n", " \"except\",\n", " \"UserWarning\",\n", " \"filter\",\n", " \"issubclass\",\n", " \"locals\",\n", " \"getattr\",\n", " \"global\",\n", " \"hasattr\",\n", " \"UnicodeEncodeError\",\n", " \"KeyboardInterrupt\",\n", " \"ArithmeticError\",\n", " \"get_ipython\",\n", " \"raise\",\n", " \"enumerate\",\n", " \"OSError\",\n", " \"UnicodeTranslateError\",\n", " \"ValueError\",\n", " \"next\",\n", " \"ResourceWarning\",\n", " \"license\",\n", " \"breakpoint\",\n", " \"DeprecationWarning\",\n", " \"LookupError\",\n", "]);\n" ] } ], "source": [ "js_code = to_javascript(reserved)\n", "\n", "print(js_code)" ] } ], "metadata": { "kernelspec": { "display_name": "Python 3 (ipykernel)", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.9.13" } }, "nbformat": 4, "nbformat_minor": 5 } ================================================ FILE: notebooks/sympy_test.ipynb ================================================ { "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "![Test Case](./test_case_small.png)" ] }, { "cell_type": "code", "execution_count": 1, "metadata": {}, "outputs": [], "source": [ "statements = '[{\"type\":\"assignment\",\"name\":\"x\",\"sympy\":\"3*implicit_param_0_0\",\"implicitParams\":[{\"name\":\"implicit_param_0_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":0.0254,\"units_valid\":true}],\"params\":[\"implicit_param_0_0\"]},{\"type\":\"assignment\",\"name\":\"y\",\"sympy\":\"implicit_param_1_0\",\"implicitParams\":[{\"name\":\"implicit_param_1_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":0.1016,\"units_valid\":true}],\"params\":[\"implicit_param_1_0\"]},{\"type\":\"assignment\",\"name\":\"length\",\"sympy\":\"sqrt((x)**(2)+(y)**(2))\",\"implicitParams\":[],\"params\":[\"x\",\"y\"]},{\"type\":\"query\",\"sympy\":\"length\",\"units\":\"inch\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"units_valid\":true,\"implicitParams\":[],\"params\":[\"length\"]},{\"type\":\"assignment\",\"name\":\"velocity\",\"sympy\":\"(length)/(implicit_param_4_0)\",\"implicitParams\":[{\"name\":\"implicit_param_4_0\",\"dimensions\":[0,0,1,0,0,0,0,0,0],\"si_value\":10,\"units_valid\":true}],\"params\":[\"length\",\"implicit_param_4_0\"]},{\"type\":\"query\",\"sympy\":\"velocity\",\"units\":\"\",\"implicitParams\":[],\"params\":[\"velocity\"]},{\"type\":\"query\",\"sympy\":\"(implicit_param_6_0)/(implicit_param_6_1)\",\"units\":\"\",\"implicitParams\":[{\"name\":\"implicit_param_6_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":10000,\"units_valid\":true},{\"name\":\"implicit_param_6_1\",\"dimensions\":[0,0,1,0,0,0,0,0,0],\"si_value\":7200,\"units_valid\":true}],\"params\":[\"implicit_param_6_0\",\"implicit_param_6_1\"]}]'" ] }, { "cell_type": "code", "execution_count": 2, "metadata": {}, "outputs": [], "source": [ "import json\n", "\n", "import sympy\n", "\n", "from sympy.parsing.sympy_parser import parse_expr \n", "\n", "from sympy.physics.units.definitions.dimension_definitions import \\\n", " mass, length, time, current,\\\n", " temperature, luminous_intensity,\\\n", " amount_of_substance, angle, information\n", "\n", "from sympy.physics.units.systems.si import dimsys_SI\n", "\n", "from sympy.utilities.iterables import topological_sort\n", "\n", "# maps from mathjs dimensions object to sympy dimensions\n", "dim_map = {0:mass, 1:length, 2:time, 3:current, 4:temperature, 5:luminous_intensity,\n", " 6:amount_of_substance, 7:angle, 8:information}\n", "\n", "inv_dim_map = {str(value.name):key for key, value in dim_map.items()}\n", "\n", "# base units as defined by mathjs\n", "base_units = { (0, 0, 0, 0, 0, 0, 0, 0, 0) : '',\n", " (1, 0, 0, 0, 0, 0, 0, 0, 0) : 'kg',\n", " (0, 1, 0, 0, 0, 0, 0, 0, 0) : 'm',\n", " (0, 0, 1, 0, 0, 0, 0, 0, 0) : 'sec',\n", " (0, 0, 0, 1, 0, 0, 0, 0, 0) : 'ampere',\n", " (0, 0, 0, 0, 1, 0, 0, 0, 0) : 'kelvin',\n", " (0, 0, 0, 0, 0, 1, 0, 0, 0) : 'candela',\n", " (0, 0, 0, 0, 0, 0, 1, 0, 0) : 'mole',\n", " (1, 1, -2, 0, 0, 0, 0, 0, 0) : 'N',\n", " (0, 2, 0, 0, 0, 0, 0, 0, 0) : 'm^2',\n", " (0, 3, 0, 0, 0, 0, 0, 0, 0) : 'm^3',\n", " (1, 2, -2, 0, 0, 0, 0, 0, 0) : 'J',\n", " (1, 2, -3, 0, 0, 0, 0, 0, 0) : 'W',\n", " (1, -1, -2, 0, 0, 0, 0, 0, 0) : 'Pa',\n", " (0, 0, 1, 1, 0, 0, 0, 0, 0) : 'coulomb',\n", " (-1, -2, 4, 2, 0, 0, 0, 0, 0) : 'farad',\n", " (1, 2, -3, -1, 0, 0, 0, 0, 0) : 'V',\n", " (1, 2, -3, -2, 0, 0, 0, 0, 0) : 'ohm',\n", " (1, 2, -2, -2, 0, 0, 0, 0, 0) : 'henry',\n", " (-1, -2, 3, 2, 0, 0, 0, 0, 0) : 'siemens',\n", " (1, 2, -2, -1, 0, 0, 0, 0, 0) : 'weber',\n", " (1, 0, -2, -1, 0, 0, 0, 0, 0) : 'tesla',\n", " (0, 0, -1, 0, 0, 0, 0, 0, 0) : 'Hz',\n", " (0, 0, 0, 0, 0, 0, 0, 1, 0) : 'rad',\n", " (0, 0, 0, 0, 0, 0, 0, 0, 1) : 'bits' }\n", "\n", "\n", "# map the sympy dimensional dependences to mathjs dimensions\n", "def get_mathjs_units(dimensional_dependencies):\n", " mathjs_dims = [0] * 9\n", "\n", " all_units_recognized = True\n", " for name, exp in dimensional_dependencies.items():\n", " dim_index = inv_dim_map.get(name)\n", " if dim_index is None:\n", " # this will hapen if the user references a parameter in an equation that has not been defined\n", " # will eventually want to allow the user to specify the untis for an undefined parameter\n", " all_units_recognized = False\n", " break\n", " mathjs_dims[dim_index] += exp\n", "\n", " if all_units_recognized:\n", " mathjs_unit_name = base_units.get(tuple(mathjs_dims))\n", "\n", " if mathjs_unit_name is None:\n", " mathjs_unit_name = \"\"\n", " latex_num = \"\"\n", " latex_den = \"\"\n", " for i, exp in enumerate(mathjs_dims):\n", " if exp != 0:\n", " key = [0] * 9\n", " key[i] = 1\n", " name = base_units.get(tuple(key))\n", " if mathjs_unit_name == \"\":\n", " mathjs_unit_name = f\"{name}^{exp}\"\n", " else:\n", " mathjs_unit_name = f\"{mathjs_unit_name}*{name}^{exp}\"\n", "\n", " if exp > 0:\n", " if exp != 1:\n", " new_term = f\"{name}^{exp}\"\n", " else:\n", " new_term = name\n", " if latex_num == \"\":\n", " latex_num = new_term\n", " else:\n", " latex_num = f\"{latex_num}\\\\cdot{new_term}\"\n", " else:\n", " if exp != -1:\n", " new_term = f\"{name}^{-exp}\"\n", " else:\n", " new_term = name\n", " if latex_den == \"\":\n", " latex_den = new_term\n", " else:\n", " latex_den = f\"{latex_den}\\\\cdot{new_term}\"\n", "\n", " if latex_den != \"\":\n", " unit_latex = f\"\\\\left[\\\\frac{{{latex_num}}}{{{latex_den}}}\\\\right]\"\n", " elif latex_num != \"\":\n", " unit_latex = f\"\\\\left[{latex_num}\\\\right]\"\n", " else:\n", " unit_latex = \"\"\n", " else:\n", " if mathjs_unit_name == \"\":\n", " unit_latex = \"\"\n", " else:\n", " unit_latex = f\"\\\\left[{mathjs_unit_name}\\\\right]\"\n", "\n", " else:\n", " mathjs_unit_name = \"\"\n", " unit_latex = \"\"\n", "\n", " return mathjs_unit_name, unit_latex\n", "\n", "\n", "def get_dims(dimensions):\n", " dims = sympy.Mul(1, *[dim_map[int(i)]**value for i, value in enumerate(dimensions) if value != 0.0])\n", " return dims\n", "\n", "def dimensional_analysis(parameters, expression):\n", " # sub parameter dimensions\n", " parameter_subs = {param['name']:get_dims(param['dimensions']) for param in parameters}\n", " parameter_subs[sympy.pi] = 1\n", " # print(parameter_subs)\n", " positive_only_expression = parse_expr(str(expression).replace('-', '+'))\n", " final_expression = positive_only_expression.subs(parameter_subs)\n", "\n", " try:\n", " result, result_latex = get_mathjs_units(dimsys_SI.get_dimensional_dependencies(final_expression))\n", " except TypeError:\n", " result = \"Dimension Error\"\n", "\n", " return result\n", "\n", "class ParameterError(Exception):\n", " pass\n", "\n", "class DuplicateAssignment(Exception):\n", " pass\n", "\n", "class ReferenceCycle(Exception):\n", " pass\n", "\n", "class ParsingError(Exception):\n", " pass\n", "\n", "def is_number(s):\n", " try:\n", " float(s)\n", " return True\n", " except ValueError:\n", " return False\n" ] }, { "cell_type": "code", "execution_count": 3, "metadata": {}, "outputs": [], "source": [ "def get_sorted_statements(statements):\n", " defined_params = {}\n", " for i, statement in enumerate(statements):\n", " if statement[\"type\"] == \"assignment\":\n", " if statement[\"name\"] in defined_params:\n", " raise DuplicateAssignment\n", " else:\n", " defined_params[statement[\"name\"]] = i\n", " \n", " vertices = range(len(statements))\n", " edges = []\n", " \n", " for i, statement in enumerate(statements):\n", " for param in statement[\"params\"]:\n", " ref_index = defined_params.get(param)\n", " if ref_index is not None:\n", " edges.append( (ref_index, i) )\n", " \n", " try:\n", " sort_order = topological_sort((vertices,edges))\n", " except ValueError:\n", " print('Reference cycle detected')\n", " raise ReferenceCycle\n", " \n", " sorted_statements = []\n", " \n", " for i in sort_order:\n", " statement = statements[i]\n", " statement['index'] = i # original index, needed to place results in original order\n", " sorted_statements.append(statement)\n", " \n", " return sorted_statements" ] }, { "cell_type": "code", "execution_count": 4, "metadata": {}, "outputs": [], "source": [ "def get_all_parameters(statements):\n", " parameters = []\n", " for statement in statements:\n", " parameters.extend(statement[\"implicitParams\"])\n", " \n", " return parameters" ] }, { "cell_type": "code", "execution_count": 5, "metadata": {}, "outputs": [], "source": [ "def evaluate_statements(statements):\n", " \n", " parameters = get_all_parameters(statements)\n", " \n", " statements = get_sorted_statements(statements)\n", " \n", " for index, statement in enumerate(statements):\n", " try:\n", " statement['expression'] = parse_expr(statement['sympy'])\n", " except SyntaxError:\n", " print(f\"Parsing error for equation {statement['sympy']}\")\n", " raise ParsingError\n", "\n", "\n", " combined_expressions = []\n", " for i in range(len(statements)):\n", " if statements[i]['type'] == \"assignment\":\n", " combined_expressions.append(None)\n", " continue\n", " temp_statements = statements[0:i+1]\n", " # sub equations into each other in topological order if there are more than one\n", " for j, statement in enumerate(reversed(temp_statements)):\n", " if j == 0:\n", " final_expression = statement['expression']\n", " elif statement['type'] == \"assignment\":\n", " final_expression = final_expression.subs({statement['name'] : statement['expression']})\n", "\n", " combined_expressions.append(final_expression)\n", "\n", " # sub parameter values\n", " parameter_subs = {param['name']:float(param['si_value']) for param in parameters if param['si_value'] is not None}\n", " if len(parameter_subs) < len(parameters):\n", " raise ParameterError\n", "\n", " dims = []\n", " values = []\n", " for expression in combined_expressions:\n", " if expression is None:\n", " dims.append('')\n", " values.append('')\n", " else:\n", " dims.append(dimensional_analysis(parameters, expression))\n", " value = str(expression.subs(parameter_subs).evalf())\n", " values.append(value if is_number(value) else '')\n", "\n", " sorted_values = [None]*len(statements)\n", " sorted_dims = [None]*len(statements)\n", " \n", " for i, statement in enumerate(statements):\n", " sorted_values[statement['index']] = values[i]\n", " sorted_dims[statement['index']] = dims[i]\n", "\n", " return (sorted_values, sorted_dims)" ] }, { "cell_type": "code", "execution_count": 6, "metadata": {}, "outputs": [], "source": [ "def get_query_values(statements):\n", " error = None\n", " \n", " try:\n", " values, dims = evaluate_statements(json.loads(statements))\n", " except (DuplicateAssignment, ReferenceCycle, ParameterError, ParsingError) as e:\n", " error = e.__class__.__name__\n", " values = None\n", " dims = None\n", " \n", " return json.dumps({\"error\": error, \"values\": values, \"dims\": dims})" ] }, { "cell_type": "code", "execution_count": 7, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"\", \"\", \"\", \"0.127000000000000\", \"\", \"0.0127000000000000\", \"1.38888888888889\"], \"dims\": [\"\", \"\", \"\", \"m\", \"\", \"m^1*sec^-1\", \"m^1*sec^-1\"]}'" ] }, "execution_count": 7, "metadata": {}, "output_type": "execute_result" } ], "source": [ "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 8, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"\"], \"dims\": [\"Dimension Error\"]}'" ] }, "execution_count": 8, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# x+y=\n", "statements = '[{\"type\":\"query\",\"sympy\":\"x+y\",\"units\":\"\",\"implicitParams\":[],\"params\":[\"x\",\"y\"]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 9, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"\", \"\", \"0.00500000000000000\"], \"dims\": [\"\", \"\", \"m^1*sec^-1\"]}'" ] }, "execution_count": 9, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# x = 10 [mm]\n", "# y = 2 [s]\n", "# x/y = [hours]\n", "\n", "statements = '[{\"type\":\"assignment\",\"name\":\"x\",\"sympy\":\"implicit_param_0_0\",\"implicitParams\":[{\"name\":\"implicit_param_0_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":0.01,\"units_valid\":true}],\"params\":[\"implicit_param_0_0\"]},{\"type\":\"assignment\",\"name\":\"y\",\"sympy\":\"implicit_param_1_0\",\"implicitParams\":[{\"name\":\"implicit_param_1_0\",\"dimensions\":[0,0,1,0,0,0,0,0,0],\"si_value\":2,\"units_valid\":true}],\"params\":[\"implicit_param_1_0\"]},{\"type\":\"query\",\"sympy\":\"(x)/(y)\",\"units\":\"hours\",\"dimensions\":[0,0,1,0,0,0,0,0,0],\"units_valid\":true,\"implicitParams\":[],\"params\":[\"x\",\"y\"]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 10, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"0.127000000000000\", \"\", \"\"], \"dims\": [\"m^1*sec^-1\", \"\", \"\"]}'" ] }, "execution_count": 10, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# x/y =\n", "# x = 10 [inches]\n", "# y = 2 [s]\n", "\n", "statements = '[{\"type\":\"query\",\"sympy\":\"(x)/(y)\",\"units\":\"\",\"implicitParams\":[],\"params\":[\"x\",\"y\"]},{\"type\":\"assignment\",\"name\":\"x\",\"sympy\":\"implicit_param_1_0\",\"implicitParams\":[{\"name\":\"implicit_param_1_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":0.254,\"units_valid\":true}],\"params\":[\"implicit_param_1_0\"]},{\"type\":\"assignment\",\"name\":\"y\",\"sympy\":\"implicit_param_2_0\",\"implicitParams\":[{\"name\":\"implicit_param_2_0\",\"dimensions\":[0,0,1,0,0,0,0,0,0],\"si_value\":2,\"units_valid\":true}],\"params\":[\"implicit_param_2_0\"]}]'\n", "get_query_values(statements)\n" ] }, { "cell_type": "code", "execution_count": 11, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"3610.00000000000\"], \"dims\": [\"sec\"]}'" ] }, "execution_count": 11, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# 10[s] + 1[hour] = \n", "statements = '[{\"type\":\"query\",\"sympy\":\"implicit_param_0_0+implicit_param_0_1\",\"units\":\"\",\"implicitParams\":[{\"name\":\"implicit_param_0_0\",\"dimensions\":[0,0,1,0,0,0,0,0,0],\"si_value\":10,\"units_valid\":true},{\"name\":\"implicit_param_0_1\",\"dimensions\":[0,0,1,0,0,0,0,0,0],\"si_value\":3600,\"units_valid\":true}],\"params\":[\"implicit_param_0_0\",\"implicit_param_0_1\"]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 12, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"0.000650160000000000\"], \"dims\": [\"m^2\"]}'" ] }, "execution_count": 12, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# 1[mm]*5[mm] + 1[inch^2] =\n", "statements = '[{\"type\":\"query\",\"sympy\":\"implicit_param_0_0*implicit_param_0_1+implicit_param_0_2\",\"units\":\"\",\"implicitParams\":[{\"name\":\"implicit_param_0_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":0.001,\"units_valid\":true},{\"name\":\"implicit_param_0_1\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":0.005,\"units_valid\":true},{\"name\":\"implicit_param_0_2\",\"dimensions\":[0,2,0,0,0,0,0,0,0],\"si_value\":0.00064516,\"units_valid\":true}],\"params\":[\"implicit_param_0_0\",\"implicit_param_0_1\",\"implicit_param_0_2\"]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 13, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"0.0254050000000000\"], \"dims\": [\"Dimension Error\"]}'" ] }, "execution_count": 13, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# incompatable dimensions\n", "# 1[mm]*5[mm] + 1[inch] =\n", "statements = '[{\"type\":\"query\",\"sympy\":\"implicit_param_0_0*implicit_param_0_1+implicit_param_0_2\",\"units\":\"\",\"implicitParams\":[{\"name\":\"implicit_param_0_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":0.001,\"units_valid\":true},{\"name\":\"implicit_param_0_1\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":0.005,\"units_valid\":true},{\"name\":\"implicit_param_0_2\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":0.0254,\"units_valid\":true}],\"params\":[\"implicit_param_0_0\",\"implicit_param_0_1\",\"implicit_param_0_2\"]}]'\n", "get_query_values(statements)\n" ] }, { "cell_type": "code", "execution_count": 14, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"\"], \"dims\": [\"\"]}'" ] }, "execution_count": 14, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# x = 1[m]\n", "statements = '[{\"type\":\"assignment\",\"name\":\"x\",\"sympy\":\"implicit_param_0_0\",\"implicitParams\":[{\"name\":\"implicit_param_0_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":1,\"units_valid\":true}],\"params\":[\"implicit_param_0_0\"]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 15, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"\", \"\"], \"dims\": [\"\", \"\"]}'" ] }, "execution_count": 15, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# x = 1[m]\n", "# y =\n", "statements = '[{\"type\":\"assignment\",\"name\":\"x\",\"sympy\":\"implicit_param_0_0\",\"implicitParams\":[{\"name\":\"implicit_param_0_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":1,\"units_valid\":true}],\"params\":[\"implicit_param_0_0\"]},{\"type\":\"query\",\"sympy\":\"y\",\"units\":\"\",\"implicitParams\":[],\"params\":[\"y\"]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 16, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": \"DuplicateAssignment\", \"values\": null, \"dims\": null}'" ] }, "execution_count": 16, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# duplicate assignment\n", "# x = 1[m]\n", "# x = 2[m]\n", "statements = '[{\"type\":\"assignment\",\"name\":\"x\",\"sympy\":\"implicit_param_0_0\",\"implicitParams\":[{\"name\":\"implicit_param_0_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":1,\"units_valid\":true}],\"params\":[\"implicit_param_0_0\"]},{\"type\":\"assignment\",\"name\":\"x\",\"sympy\":\"implicit_param_1_0\",\"implicitParams\":[{\"name\":\"implicit_param_1_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":2,\"units_valid\":true}],\"params\":[\"implicit_param_1_0\"]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 17, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Reference cycle detected\n" ] }, { "data": { "text/plain": [ "'{\"error\": \"ReferenceCycle\", \"values\": null, \"dims\": null}'" ] }, "execution_count": 17, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# cyclical reference\n", "# x = y\n", "# y = x\n", "statements = '[{\"type\":\"assignment\",\"name\":\"x\",\"sympy\":\"y\",\"implicitParams\":[],\"params\":[\"y\"]},{\"type\":\"assignment\",\"name\":\"y\",\"sympy\":\"x\",\"implicitParams\":[],\"params\":[\"x\"]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 18, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"5.00000000000000\"], \"dims\": [\"\"]}'" ] }, "execution_count": 18, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# 5 =\n", "statements = '[{\"type\":\"query\",\"sympy\":\"5\",\"units\":\"\",\"implicitParams\":[],\"params\":[]}]'\n", "get_query_values(statements)\n" ] }, { "cell_type": "code", "execution_count": 19, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"5.00000000000000\", \"15.0000000000000\"], \"dims\": [\"\", \"\"]}'" ] }, "execution_count": 19, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# 5 =\n", "# 5 + 10 =\n", "statements = '[{\"type\":\"query\",\"sympy\":\"5\",\"units\":\"\",\"implicitParams\":[],\"params\":[]},{\"type\":\"query\",\"sympy\":\"5+10\",\"units\":\"\",\"implicitParams\":[],\"params\":[]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 20, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"\"], \"dims\": [\"\"]}'" ] }, "execution_count": 20, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# undefined value\n", "# x =\n", "statements = '[{\"type\":\"query\",\"sympy\":\"x\",\"units\":\"\",\"implicitParams\":[],\"params\":[\"x\"]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 21, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"3.14159265358979\"], \"dims\": [\"\"]}'" ] }, "execution_count": 21, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# pi =\n", "statements = '[{\"type\":\"query\",\"sympy\":\"pi\",\"units\":\"\",\"implicitParams\":[],\"params\":[]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 22, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"0.540302305868140\"], \"dims\": [\"Dimension Error\"]}'" ] }, "execution_count": 22, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# cos(1) =\n", "statements = '[{\"type\":\"query\",\"sympy\":\"cos(1)\",\"units\":\"\",\"implicitParams\":[],\"params\":[]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 23, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"\", \"3.00000000000000\", \"\", \"\", \"\"], \"dims\": [\"\", \"m\", \"\", \"\", \"\"]}'" ] }, "execution_count": 23, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# quadratic equation from test suite that fails for dimension error even that dimensions are consistant\n", "statements = '[{\"type\":\"assignment\",\"name\":\"x\",\"sympy\":\"((-(b))+sqrt((b)**(2)-4*a*c))/(2*a)\",\"implicitParams\":[],\"params\":[\"b\",\"b\",\"a\",\"c\",\"a\"]},{\"type\":\"query\",\"sympy\":\"x\",\"units\":\"m\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"units_valid\":true,\"implicitParams\":[],\"params\":[\"x\"]},{\"type\":\"assignment\",\"name\":\"a\",\"sympy\":\"1\",\"implicitParams\":[],\"params\":[]},{\"type\":\"assignment\",\"name\":\"b\",\"sympy\":\"(-(implicit_param_21_0))\",\"implicitParams\":[{\"name\":\"implicit_param_21_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":5,\"units_valid\":true}],\"params\":[\"implicit_param_21_0\"]},{\"type\":\"assignment\",\"name\":\"c\",\"sympy\":\"implicit_param_22_0\",\"implicitParams\":[{\"name\":\"implicit_param_22_0\",\"dimensions\":[0,2,0,0,0,0,0,0,0],\"si_value\":6,\"units_valid\":true}],\"params\":[\"implicit_param_22_0\"]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": 24, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "'{\"error\": null, \"values\": [\"0.00100000000000000\"], \"dims\": [\"m\"]}'" ] }, "execution_count": 24, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# 5[mm]-4[mm] =\n", "statements = '[{\"type\":\"query\",\"sympy\":\"implicit_param_6_0-implicit_param_6_1\",\"units\":\"\",\"implicitParams\":[{\"name\":\"implicit_param_6_0\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":0.005,\"units_valid\":true},{\"name\":\"implicit_param_6_1\",\"dimensions\":[0,1,0,0,0,0,0,0,0],\"si_value\":0.004,\"units_valid\":true}],\"params\":[\"implicit_param_6_0\",\"implicit_param_6_1\"]}]'\n", "get_query_values(statements)" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] } ], "metadata": { "kernelspec": { "display_name": "Python 3", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.8.5" } }, "nbformat": 4, "nbformat_minor": 4 } ================================================ FILE: package.json ================================================ { "name": "svelte-app", "type": "module", "version": "1.0.0", "scripts": { "dev": "npm run build:workers && vite dev", "build": "npm run build:workers && vite build && esbuild src/database/_worker.ts --bundle --format=esm --outfile=dist/_worker.js", "build:workers": "esbuild src/pyodideWorker.ts src/parser/parserWorker.ts src/jediWorker.ts --bundle --format=iife --outdir=public", "preview": "wrangler pages dev dist --kv SHEETS --local --compatibility-date=2026-03-26 --ip 127.0.0.1", "test:seed": "wrangler kv bulk put tests/seed-data.json --namespace-id SHEETS --local", "test": "playwright test" }, "devDependencies": { "@cloudflare/workers-types": "^4.20221111.1", "@playwright/test": "^1.58", "@sveltejs/vite-plugin-svelte": "^6.2.4", "@tsconfig/svelte": "^5.0.2", "@types/wicg-file-system-access": "^2020.9.5", "carbon-components-svelte": "^0.89.4", "carbon-icons-svelte": "^13.2.0", "carbon-preprocess-svelte": "^0.11.28", "node-fetch": "^2.6.1", "pixelmatch": "^5.2.1", "pngjs": "^4.0.1", "sass": "^1.98.0", "ssri": "^10.0.1", "svelte": "^5.55.1", "tslib": "^2.6.3", "typescript": "^5.5.2", "vite": "^7.3.1", "vite-plugin-pwa": "^1.2.0", "vite-plugin-static-copy": "^4.0.0", "wrangler": "^4.78.0" }, "dependencies": { "@codemirror/autocomplete": "^6.18.6", "@codemirror/commands": "^6.8.1", "@codemirror/lang-python": "^6.2.1", "@codemirror/language": "^6.11.0", "@codemirror/view": "^6.36.8", "@ibm/plex": "^6.4.1", "@mgreminger/quill-image-resize-module": "^1.2.0", "antlr4": "=4.12.0", "carbon-components": "^10.59.2", "codemirror": "^6.0.1", "dompurify": "^3.2.6", "idb-keyval": "^6.2.0", "marked": "^15.0.12", "mathjax": "^3.2.2", "mathjs": "^11.8.2", "mathlive": "github:mgreminger/mathlive#c37dc0627abd4daebd0774438973e0dd5215d2b6", "plotly.js-basic-dist": "github:mgreminger/plotly.js#dist-basic-for-ep", "quick-lru": "^6.1.1", "quill": "^2.0.3", "quill-delta-to-markdown": "github:mgreminger/quill-delta-to-markdown#cabc59504ade07cec4e8224ed982a6aeeb4a3668", "workbox-window": "^6.5.4", "xlsx": "https://cdn.sheetjs.com/xlsx-0.20.3/xlsx-0.20.3.tgz" } } ================================================ FILE: playwright.config.mjs ================================================ // @ts-check import { devices } from '@playwright/test'; /** * Read environment variables from file. * https://github.com/motdotla/dotenv */ // require('dotenv').config(); /** * @see https://playwright.dev/docs/test-configuration * @type {import('@playwright/test').PlaywrightTestConfig} */ const config = { testDir: './tests', /* Maximum time one test can run for. */ timeout: 4 * 60 * 1000, expect: { /** * Maximum time expect() should wait for the condition to be met. * For example in `await expect(locator).toHaveText();` */ timeout: 10000 }, /* Fail the build on CI if you accidentally left test.only in the source code. */ forbidOnly: !!process.env.CI, retries: process.env.CI ? 2 : 2, workers: process.env.CI ? 1 : 2, /* Reporter to use. See https://playwright.dev/docs/test-reporters */ reporter: process.env.CI ? 'github' : 'list', reportSlowTests: null, /* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */ use: { /* Maximum time each action such as `click()` can take. Defaults to 0 (no limit). */ actionTimeout: 120000, /* Base URL to use in actions like `await page.goto('/')`. */ baseURL: process.env.APP_URL ? process.env.APP_URL : 'http://127.0.0.1:8788', navigationTimeout: 120 * 1000, /* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */ trace: 'on-first-retry', }, /* Set projects for CI and local environments */ projects: process.env.CI ? projectFactory(['chromium', 'firefox']) : projectFactory(['chromium', 'firefox', 'webkit']), /* Folder for test artifacts such as screenshots, videos, traces, etc. */ outputDir: 'test-results/', /* Run your local dev server before starting the tests */ webServer: { command: 'npm run preview', url: 'http://127.0.0.1:8788', reuseExistingServer: !process.env.CI, timeout: 120 * 1000, }, }; export default config; // @ts-ignore function projectFactory(projectNames) { const allProjects = [ { name: 'chromium', use: { ...devices['Desktop Chrome'], }, }, { name: 'firefox', use: { ...devices['Desktop Firefox'], }, }, { name: 'webkit', use: { ...devices['Desktop Safari'], }, }, /* Test against mobile viewports. */ { name: 'Mobile Chrome', use: { ...devices['Pixel 5'], }, }, { name: 'Mobile Safari', use: { ...devices['iPhone 12'], }, }, /* Test against branded browsers. */ { name: 'Microsoft Edge', use: { channel: 'msedge', }, }, { name: 'Google Chrome', use: { channel: 'chrome', }, }, ] return allProjects.filter((project) => projectNames.includes(project.name)); } ================================================ FILE: public/.well-known/assetlinks.json ================================================ [{ "relation": ["delegate_permission/common.handle_all_urls"], "target" : { "namespace": "android_app", "package_name": "xyz.engineeringpaper.twa", "sha256_cert_fingerprints": ["09:5E:37:3B:DB:58:C9:92:72:51:83:E4:9D:B9:77:99:05:2F:25:32:CB:65:6A:E0:98:D4:0E:DE:D8:6F:5E:A6"] } } ] ================================================ FILE: public/_routes.json ================================================ { "version": 1, "include": ["/*"], "exclude": [ "/assets/*", "/mathlive/*", "/pyodide/*", "/images/*", "/mathjax/*", "/parser/*", "/print_logo.png", "/logo_dark.svg", "/pyodideWorker.js", "/jediWorker.js", "/jedi_code_analysis.py", "/serviceworker.js", "/dimensional_analysis.py", "/iframe_test.html", "/robots.txt", "/favicon.svg", "/favicon.ico", "/logo_with_background.png", "/manifest.json" ] } ================================================ FILE: public/dimensional_analysis.py ================================================ PROFILE=False if PROFILE: import cProfile import sys # must be at least 131 to load sympy, cpython is 3000 by default sys.setrecursionlimit(1000) import io from functools import lru_cache, partial, reduce import traceback import collections from json import loads, dumps import math from sympy import ( Float, Expr, cancel, Symbol, Add, Mul, latex, sympify, solve, nsolve, symbols, Function, Max, Min, Piecewise, And, StrictLessThan, LessThan, StrictGreaterThan, GreaterThan, log, asin, acos, atan, acsc, acot, asec, arg, re, im, conjugate, Abs, Integral, Derivative, Matrix, MatrixBase, Subs, Pow, Eq, floor, ceiling, sign, sqrt, factorial, summation, product, Rational, S, ones ) class ExprWithAssumptions(Expr): is_finite: bool is_integer: bool from sympy.printing.latex import modifier_dict from sympy.printing.numpy import NumPyPrinter from sympy.physics.units import Dimension from sympy.physics.units.definitions.dimension_definitions import ( mass, length, time, current, temperature, luminous_intensity, amount_of_substance, angle, information, ) dimensions = (mass, length, time, current, temperature, luminous_intensity, amount_of_substance, angle, information) dimension_symbols = set((dimension.name for dimension in dimensions)) from sympy.physics.units.systems.si import dimsys_SI, DimensionSystem from sympy.utilities.iterables import topological_sort from sympy.utilities.lambdify import lambdify from sympy.functions.elementary.trigonometric import TrigonometricFunction from sympy.printing.latex import LatexPrinter import mpmath import numbers from typing import TypedDict, Literal, cast, TypeGuard, Sequence, Any, Callable, NotRequired # clear the modifier_dict so that sympy doesn't change variable names that end if bar, prime, cal, etc. modifier_dict.clear(); # The following statement types are created in TypeScript and passed to Python as json class ImplicitParameter(TypedDict): name: str units: str dimensions: list[float] original_value: str si_value: str class BaseUserFunction(TypedDict): type: Literal["assignment"] name: str sympy: str params: list[str] isFunctionArgument: Literal[False] isFunction: Literal[True] functionParameters: list[str] index: int # added in Python, not pressent in json expression: Expr # added in Python, not pressent in json class UserFunction(BaseUserFunction): isRange: Literal[False] class UserFunctionRange(BaseUserFunction): isRange: Literal[True] freeParameter: str lowerLimitArgument: str lowerLimitInclusive: bool upperLimitArgument: str upperLimitInclusive: bool unitsQueryFunction: str class FunctionUnitsQuery(TypedDict): type: Literal["query"] sympy: str params: list[str] units: Literal[""] isFunctionArgument: Literal[False] isFunction: Literal[False] isUnitsQuery: Literal[True] isRange: Literal[False] isDataTableQuery: Literal[False] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[False] index: int # added in Python, not pressent in json expression: Expr # added in Python, not pressent in json class LocalSubstitution(TypedDict): type: Literal["localSub"] parameter: str argument: str isRange: Literal[False] function: str class LocalSubstitutionRange(TypedDict): type: Literal["localSub"] parameter: str argument: str isRange: Literal[True] function: str isLowerLimit: bool isInclusiveLimit: bool class FunctionArgumentAssignment(TypedDict): type: Literal["assignment"] name: str sympy: str params: list[str] isFunctionArgument: Literal[True] isFunction: Literal[False] index: int # added in Python, not pressent in json expression: Expr # added in Python, not pressent in json class FunctionArgumentQuery(TypedDict): type: Literal["query"] sympy: str params: list[str] name: str isFunctionArgument: Literal[True] isFunction: Literal[False] isUnitsQuery: Literal[False] isRange: Literal[False] isDataTableQuery: Literal[False] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[False] index: int # added in Python, not pressent in json expression: Expr # added in Python, not pressent in json class BlankStatement(TypedDict): type: Literal["blank"] params: list[str] # will be empty list variableNameMap: dict[str, str] # will be empty dict implicitParams: list[ImplicitParameter] # will be empty list isFromPlotCell: Literal[False] index: int # added in Python, not pressent in json class QueryAssignmentCommon(TypedDict): sympy: str implicitParams: list[ImplicitParameter] functions: list[UserFunction | UserFunctionRange | FunctionUnitsQuery] arguments: list[FunctionArgumentQuery | FunctionArgumentAssignment] localSubs: list[LocalSubstitution | LocalSubstitutionRange] params: list[str] variableNameMap: dict[str,str] index: int # added in Python, not pressent in json expression: Expr # added in Python, not pressent in json class AssignmentStatement(QueryAssignmentCommon): type: Literal["assignment"] name: str isFunctionArgument: Literal[False] isFunction: Literal[False] isFromPlotCell: Literal[False] isDataTableQuery: Literal[False] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[False] isRange: Literal[False] class SystemSolutionAssignmentStatement(AssignmentStatement): display: str displayName: str class BaseQueryStatement(QueryAssignmentCommon): type: Literal["query"] isFunctionArgument: Literal[False] isFunction: Literal[False] isUnitsQuery: Literal[False] isEqualityUnitsQuery: bool isScatterXValuesQueryStatement: Literal[False] isScatterYValuesQueryStatement: Literal[False] isFromPlotCell: bool units: str unitsLatex: str class SubQueryStatement(BaseQueryStatement): isRange: Literal[False] isDataTableQuery: Literal[False] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[False] isSubQuery: Literal[True] class QueryStatement(BaseQueryStatement): isRange: Literal[False] isDataTableQuery: Literal[False] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[False] isSubQuery: Literal[False] subQueries: list[SubQueryStatement] class DataTableQueryStatement(BaseQueryStatement): isRange: Literal[False] isDataTableQuery: Literal[True] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[False] isSubQuery: Literal[False] cellNum: int colId: int class RangeQueryStatement(BaseQueryStatement): isRange: Literal[True] isParametric: bool isDataTableQuery: Literal[False] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[False] isSubQuery: Literal[False] cellNum: int numPoints: int freeParameter: str lowerLimitArgument: str lowerLimitInclusive: bool upperLimitArgument: str upperLimitInclusive: bool logX: bool unitsQueryFunction: str inputUnits: str inputUnitsLatex: str outputName: str class ScatterXValuesQueryStatement(QueryAssignmentCommon): type: Literal["query"] isRange: Literal[False] isDataTableQuery: Literal[False] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[False] isFunctionArgument: Literal[False] isFunction: Literal[False] isUnitsQuery: Literal[False] isEqualityUnitsQuery: Literal[False] isScatterXValuesQueryStatement: Literal[True] isScatterYValuesQueryStatement: Literal[False] isFromPlotCell: bool isSubQuery: Literal[False] units: str equationIndex: int unitsLatex: str dimensions: list[float] class ScatterYValuesQueryStatement(QueryAssignmentCommon): type: Literal["query"] isRange: Literal[False] isDataTableQuery: Literal[False] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[False] isFunctionArgument: Literal[False] isFunction: Literal[False] isUnitsQuery: Literal[False] isEqualityUnitsQuery: Literal[False] isScatterXValuesQueryStatement: Literal[False] isScatterYValuesQueryStatement: Literal[True] isFromPlotCell: bool isSubQuery: Literal[False] units: str equationIndex: int unitsLatex: str dimensions: list[float] class ScatterQueryStatement(TypedDict): type: Literal["scatterQuery"] asLines: bool equationIndex: int cellNum: int isFromPlotCell: bool params: list[str] # will be empty list variableNameMap: dict[str, str] # will be empty dict functions: list[UserFunction | UserFunctionRange | FunctionUnitsQuery] arguments: list[FunctionArgumentQuery | FunctionArgumentAssignment] localSubs: list[LocalSubstitution | LocalSubstitutionRange] implicitParams: list[ImplicitParameter] xValuesQuery: ScatterXValuesQueryStatement yValuesQuery: ScatterYValuesQueryStatement xName: str yName: str units: str unitsLatex: str inputUnits: str inputUnitsLatex: str index: int # added in Python, not pressent in json class CodeFunctionRawQuery(BaseQueryStatement): isRange: Literal[False] isDataTableQuery: Literal[False] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[True] class CodeFunctionQueryStatement(BaseQueryStatement): isRange: Literal[False] isDataTableQuery: Literal[False] isCodeFunctionQuery: Literal[True] isCodeFunctionRawQuery: Literal[False] functionName: str parameterNames: list[str] parameterValues: list[str] parameterUnits: list[str] generateCode: bool codeFunctionRawQuery: CodeFunctionRawQuery class EqualityUnitsQueryStatement(QueryAssignmentCommon): type: Literal["query"] isRange: Literal[False] isDataTableQuery: Literal[False] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[False] isFunctionArgument: Literal[False] isFunction: Literal[False] isUnitsQuery: Literal[False] isEqualityUnitsQuery: Literal[True] isFromPlotCell: bool units: str equationIndex: int class EqualityStatement(QueryAssignmentCommon): type: Literal["equality"] isFunctionArgument: Literal[False] isFunction: Literal[False] isFromPlotCell: Literal[False] isRange: Literal[False] isDataTableQuery: Literal[False] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[False] equationIndex: int equalityUnitsQueries: list[EqualityUnitsQueryStatement] class GuessAssignmentStatement(AssignmentStatement): guess: str class BaseSystemDefinition(TypedDict): statements: list[EqualityStatement] variables: list[str] selectedSolution: int class ExactSystemDefinition(BaseSystemDefinition): numericalSolve: Literal[False] class NumericalSystemDefinition(BaseSystemDefinition): numericalSolve: Literal[True] guesses: list[str] guessStatements: list[GuessAssignmentStatement] class FluidFunction(TypedDict): name: str fluid: str output: str outputDims: list[float] input1: str input1Dims: list[float] input2: str input2Dims: list[float] input3: NotRequired[str] input3Dims: NotRequired[list[float]] class InterpolationFunction(TypedDict): type: Literal["polyfit"] | Literal["interpolation"] name: str numInputs: int inputValues: list[list[float]] outputValues: list[float] inputDims: list[list[float]] outputDims: list[float] order: int class GridInterpolationFunction(TypedDict): type: Literal["gridInterpolation"] name: str numInputs: int inputValues: list[list[float]] outputValues: list[list[float]] inputDims: list[list[float]] outputDims: list[float] order: int class CustomBaseUnits(TypedDict): mass: str length: str time: str current: str temperature: str luminous_intensity: str amount_of_substance: str force: str area: str volume: str energy: str power: str pressure: str charge: str capacitance: str electric_potential: str resistance: str inductance: str conductance: str magnetic_flux: str magnetic_flux_density: str angle: str information: str class CodeCellDimsAny(TypedDict): type: Literal["any"] class CodeCellDimsDummy(TypedDict): type: Literal["dummy"] class CodeCellDimsRender(TypedDict): type: Literal["render"] renderType: Literal["text"] | Literal["html"] | Literal["markdown"] class CodeCellDimsSpecific(TypedDict): type: Literal["specific"] dims: list[float] offset: float scaleFactor: float CodeCellDims = CodeCellDimsSpecific | CodeCellDimsAny | CodeCellDimsRender | CodeCellDimsDummy class ScalarCodeCellDims(TypedDict): type: Literal["scalar"] dims: CodeCellDims class MatrixCodeCellDims(TypedDict): type: Literal["matrix"] dims: list[list[CodeCellDimsSpecific | CodeCellDimsAny]] CodeCellInputOutputDims = ScalarCodeCellDims | MatrixCodeCellDims class CodeCellFunction(TypedDict): name: str code: str inputDims: list[CodeCellInputOutputDims] outputDims: CodeCellInputOutputDims sympyMode: bool # The following statement type is generated on the fly in the expand_with_sub_statements function # This type does not exist in the inbound json class LocalSubstitutionStatement(TypedDict): type: Literal["local_sub"] name: str params: list[str] function_subs: dict[str, dict[str, str]] index: int InputStatement = AssignmentStatement | QueryStatement | RangeQueryStatement | BlankStatement | \ CodeFunctionQueryStatement | ScatterQueryStatement | SubQueryStatement InputAndSystemStatement = InputStatement | EqualityUnitsQueryStatement | GuessAssignmentStatement | \ SystemSolutionAssignmentStatement Statement = InputStatement | UserFunction | UserFunctionRange | FunctionUnitsQuery | \ FunctionArgumentQuery | FunctionArgumentAssignment | \ SystemSolutionAssignmentStatement | LocalSubstitutionStatement | \ GuessAssignmentStatement | EqualityUnitsQueryStatement | CodeFunctionRawQuery | \ ScatterXValuesQueryStatement | ScatterYValuesQueryStatement SystemDefinition = ExactSystemDefinition | NumericalSystemDefinition class StatementsAndSystems(TypedDict): statements: list[InputStatement] systemDefinitions: list[SystemDefinition] fluidFunctions: list[FluidFunction] codeCellFunctions: list[CodeCellFunction] interpolationFunctions: list[InterpolationFunction | GridInterpolationFunction] customBaseUnits: NotRequired[CustomBaseUnits] simplifySymbolicExpressions: bool convertFloatsToFractions: bool def is_code_function_query_statement(statement: InputAndSystemStatement) -> TypeGuard[CodeFunctionQueryStatement]: return statement.get("isCodeFunctionQuery", False) # The following types are created in Python and are returned as json results to TypeScript class Result(TypedDict): value: str symbolicValue: str units: str unitsLatex: str customUnitsDefined: bool customUnits: str customUnitsLatex: str numeric: bool real: bool finite: bool generatedCode: NotRequired[str] isSubResult: bool subQueryName: str class FiniteImagResult(TypedDict): value: str symbolicValue: str realPart: str imagPart: str units: str unitsLatex: str customUnitsDefined: bool customUnits: str customUnitsLatex: str numeric: Literal[True] real: Literal[False] finite: Literal[True] generatedCode: NotRequired[str] isSubResult: bool subQueryName: str class MatrixResult(TypedDict): matrixResult: Literal[True] results: list[list[Result | FiniteImagResult]] generatedCode: NotRequired[str] isSubResult: bool subQueryName: str class PlotData(TypedDict): isParametric: bool numericOutput: bool numericInput: bool limitsUnitsMatch: bool input: list[float] output: list[float] inputReversed: bool negLogLimit: bool inputUnits: str inputUnitsLatex: str inputCustomUnitsDefined: bool inputCustomUnits: str inputCustomUnitsLatex: str inputName: str inputNameLatex: str outputUnits: str outputUnitsLatex: str outputCustomUnitsDefined: bool outputCustomUnits: str outputCustomUnitsLatex: str outputName: str outputNameLatex: str isScatter: bool asLines: NotRequired[bool] scatterErrorMessage: NotRequired[str] parametricErrorMessage: NotRequired[str] class PlotResult(TypedDict): plot: Literal[True] data: list[PlotData] class SystemResult(TypedDict): error: None | str solutions: dict[str, list[str]] selectedSolution: int class DataTableResult(TypedDict): dataTableResult: Literal[True] colData: dict[int, MatrixResult] class CodeCellError(TypedDict): message: str startLine: int | None endLine: int | None startCol: int | None endCol: int | None class CodeCellResult(TypedDict): stdout: str errors: list[CodeCellError] class RenderResult(TypedDict): renderResult: Literal[True] type: Literal["text"] | Literal["html"] | Literal["markdown"] value: str dimensionError: str def is_real_and_finite(result: Result | FiniteImagResult): return result["real"] and result["finite"] def is_not_matrix_result(result: Result | FiniteImagResult | MatrixResult) -> TypeGuard[Result | FiniteImagResult]: return not result.get("matrixResult", False) def is_matrix_result(result: Result | FiniteImagResult | MatrixResult | PlotResult | RenderResult) -> TypeGuard[MatrixResult]: return result.get("matrixResult", False) def is_matrix(expression: Expr | Matrix) -> TypeGuard[Matrix]: return isinstance(expression, MatrixBase) class Results(TypedDict): error: None | str results: list[Result | FiniteImagResult | MatrixResult | DataTableResult | RenderResult | list[PlotResult]] systemResults: list[SystemResult] codeCellResults: dict[str, CodeCellResult] # The following types are created in Python and don't exist in the TypeScript code class StatementPlotInfo(TypedDict): isFromPlotCell: bool cellNum: int class StatementDataTableInfo(TypedDict): isFromDataTableCell: bool cellNum: int colId: int class CombinedExpressionBlank(TypedDict): index: int isBlank: Literal[True] isRange: Literal[False] isScatter: Literal[False] isSubQuery: Literal[False] subQueryName: Literal[""] class CombinedExpressionNoRange(TypedDict): index: int name: str expression: Expr isBlank: Literal[False] isRange: Literal[False] isScatter: Literal[False] isCodeFunctionQuery: bool isCodeFunctionRawQuery: bool isFunctionArgument: bool isUnitsQuery: bool isEqualityUnitsQuery: bool isScatterXValuesQuery: bool isScatterYValuesQuery: bool equationIndex: int isSubQuery: bool subQueryName: str class CombinedExpressionRange(TypedDict): index: int name: str expression: Expr isBlank: Literal[False] isRange: Literal[True] isParametric: bool isScatter: Literal[False] isCodeFunctionQuery: Literal[False] isCodeFunctionRawQuery: Literal[False] isFunctionArgument: bool isUnitsQuery: bool isEqualityUnitsQuery: bool equationIndex: int numPoints: int freeParameter: str outputName: str lowerLimitArgument: str upperLimitArgument: str lowerLimitInclusive: bool upperLimitInclusive: bool logX: bool unitsQueryFunction: str isSubQuery: Literal[False] subQueryName: Literal[""] class CombinedExpressionScatter(TypedDict): index: int isBlank: Literal[False] isRange: Literal[False] isScatter: Literal[True] asLines: bool equationIndex: int xName: str yName: str isSubQuery: Literal[False] subQueryName: Literal[""] CombinedExpression = CombinedExpressionBlank | CombinedExpressionNoRange | CombinedExpressionRange | \ CombinedExpressionScatter class DimValues(TypedDict): args: list[Expr] result: Expr class CodeCellResultCollector(TypedDict): buffer: io.StringIO exceptions: list[Exception] # maps from mathjs dimensions object to sympy dimensions dim_map: dict[int, Dimension] = { 0: mass, 1: length, 2: time, 3: current, 4: temperature, 5: luminous_intensity, 6: amount_of_substance, 7: angle, 8: information, } inv_dim_map = {value: key for key, value in dim_map.items()} # base units as defined by mathjs def get_base_units(custom_base_units: CustomBaseUnits | None= None) -> dict[tuple[int | float, ...], str]: if custom_base_units is None: return { (0, 0, 0, 0, 0, 0, 0, 0, 0): "", (1, 0, 0, 0, 0, 0, 0, 0, 0): "kg", (0, 1, 0, 0, 0, 0, 0, 0, 0): "m", (0, 0, 1, 0, 0, 0, 0, 0, 0): "s", (0, 0, 0, 1, 0, 0, 0, 0, 0): "A", (0, 0, 0, 0, 1, 0, 0, 0, 0): "K", (0, 0, 0, 0, 0, 1, 0, 0, 0): "cd", (0, 0, 0, 0, 0, 0, 1, 0, 0): "mol", (1, 1, -2, 0, 0, 0, 0, 0, 0): "N", (0, 2, 0, 0, 0, 0, 0, 0, 0): "m^2", (0, 3, 0, 0, 0, 0, 0, 0, 0): "m^3", (1, 2, -2, 0, 0, 0, 0, 0, 0): "J", (1, 2, -3, 0, 0, 0, 0, 0, 0): "W", (1, -1, -2, 0, 0, 0, 0, 0, 0): "Pa", (0, 0, 1, 1, 0, 0, 0, 0, 0): "C", (-1, -2, 4, 2, 0, 0, 0, 0, 0): "F", (1, 2, -3, -1, 0, 0, 0, 0, 0): "V", (1, 2, -3, -2, 0, 0, 0, 0, 0): "ohm", (1, 2, -2, -2, 0, 0, 0, 0, 0): "H", (-1, -2, 3, 2, 0, 0, 0, 0, 0): "S", (1, 2, -2, -1, 0, 0, 0, 0, 0): "Wb", (1, 0, -2, -1, 0, 0, 0, 0, 0): "T", (0, 0, 0, 0, 0, 0, 0, 1, 0): "rad", (0, 0, 0, 0, 0, 0, 0, 0, 1): "b", } else: return { (0, 0, 0, 0, 0, 0, 0, 0, 0): "", (1, 0, 0, 0, 0, 0, 0, 0, 0): custom_base_units["mass"], (0, 1, 0, 0, 0, 0, 0, 0, 0): custom_base_units["length"], (0, 0, 1, 0, 0, 0, 0, 0, 0): custom_base_units["time"], (0, 0, 0, 1, 0, 0, 0, 0, 0): custom_base_units["current"], (0, 0, 0, 0, 1, 0, 0, 0, 0): custom_base_units["temperature"], (0, 0, 0, 0, 0, 1, 0, 0, 0): custom_base_units["luminous_intensity"], (0, 0, 0, 0, 0, 0, 1, 0, 0): custom_base_units["amount_of_substance"], (1, 1, -2, 0, 0, 0, 0, 0, 0): custom_base_units["force"], (0, 2, 0, 0, 0, 0, 0, 0, 0): custom_base_units["area"], (0, 3, 0, 0, 0, 0, 0, 0, 0): custom_base_units["volume"], (1, 2, -2, 0, 0, 0, 0, 0, 0): custom_base_units["energy"], (1, 2, -3, 0, 0, 0, 0, 0, 0): custom_base_units["power"], (1, -1, -2, 0, 0, 0, 0, 0, 0): custom_base_units["pressure"], (0, 0, 1, 1, 0, 0, 0, 0, 0): custom_base_units["charge"], (-1, -2, 4, 2, 0, 0, 0, 0, 0): custom_base_units["capacitance"], (1, 2, -3, -1, 0, 0, 0, 0, 0): custom_base_units["electric_potential"], (1, 2, -3, -2, 0, 0, 0, 0, 0): custom_base_units["resistance"], (1, 2, -2, -2, 0, 0, 0, 0, 0): custom_base_units["inductance"], (-1, -2, 3, 2, 0, 0, 0, 0, 0): custom_base_units["conductance"], (1, 2, -2, -1, 0, 0, 0, 0, 0): custom_base_units["magnetic_flux"], (1, 0, -2, -1, 0, 0, 0, 0, 0): custom_base_units["magnetic_flux_density"], (0, 0, 0, 0, 0, 0, 0, 1, 0): custom_base_units["angle"], (0, 0, 0, 0, 0, 0, 0, 0, 1): custom_base_units["information"], } # precision for sympy evalf calls to convert expressions to floating point values PRECISION = 64 # very large rationals are inefficient for exponential calculations LARGE_RATIONAL = 1000000 # num of digits to round to for unit exponents # this makes sure units with a very small difference are identified as the same EXP_NUM_DIGITS = 12 # threshold to consider floating point unit exponent as an int EXP_INT_THRESHOLD = 1e-12 EXP_EPSILON = sympify(EXP_INT_THRESHOLD) ZERO_PLACEHOLDER = "implicit_param__zero" def dims_equivalent(dims_list: Sequence[dict[Dimension,Expr]]) -> bool: keys = set() for dims in dims_list: keys = keys | set(dims.keys()) for key in keys: first_value = dims_list[0].get(key, S.Zero) if not all(Abs(first_value - dims.get(key, S.Zero)) < EXP_EPSILON for dims in dims_list[1:]): # type: ignore return False return True # Monkey patch of SymPy's get_dimensional_dependencies so that units that have a small # exponent difference (within EXP_NUM_DIGITS) are still considered equivalent for addition def custom_get_dimensional_dependencies_for_name(self, dimension): if isinstance(dimension, str): dimension = Dimension(Symbol(dimension)) elif not isinstance(dimension, Dimension): dimension = Dimension(dimension) if dimension.name.is_Symbol: # Dimensions not included in the dependencies are considered # as base dimensions: return dict(self.dimensional_dependencies.get(dimension, {dimension: S.One})) if dimension.name.is_number or dimension.name.is_NumberSymbol: return {} get_for_name = self._get_dimensional_dependencies_for_name if dimension.name.is_Mul: ret = collections.defaultdict(int) dicts = [get_for_name(i) for i in dimension.name.args] for d in dicts: for k, v in d.items(): ret[k] += v return {k: v for (k, v) in ret.items() if v != 0} if dimension.name.is_Add: dicts = [get_for_name(i) for i in dimension.name.args] if dims_equivalent(dicts): return dicts[0] raise TypeError("Only equivalent dimensions can be added or subtracted.") if dimension.name.is_Pow: dim_base = get_for_name(dimension.name.base) dim_exp = get_for_name(dimension.name.exp) if dim_exp == {} or dimension.name.exp.is_Symbol: return {k: v * dimension.name.exp for (k, v) in dim_base.items()} else: raise TypeError("The exponent for the power operator must be a Symbol or dimensionless.") if dimension.name.is_Function: args = (Dimension._from_dimensional_dependencies( # type: ignore get_for_name(arg)) for arg in dimension.name.args) result = dimension.name.func(*args) dicts = [get_for_name(i) for i in dimension.name.args] if isinstance(result, Dimension): return self.get_dimensional_dependencies(result) elif result.func == dimension.name.func: if isinstance(dimension.name, TrigonometricFunction): if dicts[0] in ({}, {Dimension('angle'): 1}): return {} else: raise TypeError("The input argument for the function {} must be dimensionless or have dimensions of angle.".format(dimension.func)) else: if all(item == {} for item in dicts): return {} else: raise TypeError("The input arguments for the function {} must be dimensionless.".format(dimension.func)) else: return get_for_name(result) raise TypeError("Type {} not implemented for get_dimensional_dependencies".format(type(dimension.name))) DimensionSystem._get_dimensional_dependencies_for_name = custom_get_dimensional_dependencies_for_name # type: ignore def round_exp(value: float) -> float | int: value = round(value, EXP_NUM_DIGITS) if abs(int(value) - value) < EXP_INT_THRESHOLD: value = int(value) return value # map the sympy dimensional dependences to mathjs dimensions def get_mathjs_units(dimensional_dependencies: dict[Dimension, float], custom_base_units: CustomBaseUnits | None = None ): base_units = get_base_units(custom_base_units) mathjs_dims: list[int | float] = [0] * 9 all_units_recognized = True for name, exp in dimensional_dependencies.items(): dim_index = inv_dim_map.get(name) if dim_index is None: # this will hapen if the user references a parameter in an equation that has not been defined # will eventually want to allow the user to specify the untis for an undefined parameter all_units_recognized = False break mathjs_dims[dim_index] += exp mathjs_dims = [round_exp(exp) for exp in mathjs_dims] if all_units_recognized: mathjs_unit_name = base_units.get(tuple(mathjs_dims)) if mathjs_unit_name is None: mathjs_unit_name = "" latex_num = "" latex_den = "" for i, exp in enumerate(mathjs_dims): if exp != 0: key = [0] * 9 key[i] = 1 name = base_units.get(tuple(key)) if mathjs_unit_name == "": mathjs_unit_name = f"{name}^{float(exp):g}" else: mathjs_unit_name = f"{mathjs_unit_name}*{name}^{float(exp):g}" if exp > 0: if exp != 1: new_term = f"{name}^{{{float(exp):g}}}" else: new_term = name if latex_num == "": latex_num = new_term else: latex_num = f"{latex_num}\\cdot {new_term}" else: if exp != -1: new_term = f"{name}^{{{-float(exp):g}}}" else: new_term = name if latex_den == "": latex_den = new_term else: latex_den = f"{latex_den}\\cdot {new_term}" if latex_den != "": if latex_num == "": latex_num = "1" unit_latex = f"\\left\\lbrack \\frac{{{latex_num}}}{{{latex_den}}}\\right\\rbrack " elif latex_num != "": unit_latex = f"\\left\\lbrack {latex_num}\\right\\rbrack " else: unit_latex = "" else: if mathjs_unit_name == "": unit_latex = "" else: # this is a base unit, may contain * for multiplication or / for division rendered_mathjs_unit = mathjs_unit_name rendered_mathjs_unit = rendered_mathjs_unit.replace("*", "\\cdot ") if '/' in rendered_mathjs_unit: parts = rendered_mathjs_unit.split('/') if len(parts) == 2: rendered_mathjs_unit = f"\\frac{{{parts[0]}}}{{{parts[1]}}}" unit_latex = f"\\left\\lbrack {rendered_mathjs_unit}\\right\\rbrack " else: mathjs_unit_name = "" unit_latex = "" return mathjs_unit_name, unit_latex def get_dims(dimensions: list[float]) -> Expr: dims = Mul( 1, *[ dim_map[int(i)] ** value for i, value in enumerate(dimensions) if value != 0.0 ], ) return dims # monkey patch of SymPy's LatexPrinter to use function names provided in symbol_names accepted_latex_functions = ['arcsin', 'arccos', 'arctan', 'sin', 'cos', 'tan', 'sinh', 'cosh', 'tanh', 'sqrt', 'ln', 'log', 'sec', 'csc', 'cot', 'coth', 're', 'im', 'frac', 'root', 'arg', ] def custom_hprint_Function(self, func: str) -> str: r''' Logic to decide how to render a function to latex - if it is a recognized latex name, use the appropriate latex command - if it is a single letter, excluding sub- and superscripts, just use that letter - if it is a longer name, then put \operatorname{} around it and be mindful of undercores in the name ''' func = self._settings['symbol_names'].get(Symbol(func), func) func = self._deal_with_super_sub(func) superscriptidx = func.find("^") subscriptidx = func.find("_") if func in accepted_latex_functions: name = r"\%s" % func elif len(func) == 1 or func.startswith('\\') or subscriptidx == 1 or superscriptidx == 1: name = func else: if superscriptidx > 0 and subscriptidx > 0: name = r"\operatorname{%s}%s" %( func[:min(subscriptidx,superscriptidx)], func[min(subscriptidx,superscriptidx):]) elif superscriptidx > 0: name = r"\operatorname{%s}%s" %( func[:superscriptidx], func[superscriptidx:]) elif subscriptidx > 0: name = r"\operatorname{%s}%s" %( func[:subscriptidx], func[subscriptidx:]) else: name = r"\operatorname{%s}" % func return name LatexPrinter._hprint_Function = custom_hprint_Function # type: ignore def custom_latex(expression: Expr, variable_name_map: dict[Symbol, str]) -> str: piecewise = Function('piecewise') new_expression = expression.replace(Piecewise, piecewise) try: result_latex = latex(new_expression, ln_notation=True, mul_symbol='dot', inv_trig_style='full', symbol_names=variable_name_map) except ValueError as e: result_latex = """ \\begin{split} &\\text{Error generating symbolic result.} \\\\ &\\text{Try disabling the "Preserve Symbolic Representation of Numbers" sheet setting.} \\end{split} """ return result_latex _range = Function("_range") def ensure_all_equivalent(*args, error_message: str | None = None): if args[0].is_zero: if all(arg.is_zero for arg in args): first_arg = S.Zero else: first_arg = S.One else: first_arg = args[0] if len(args) == 1: return first_arg if dims_equivalent([custom_get_dimensional_dependencies(arg) for arg in args]): return first_arg if error_message is None: raise TypeError('All input arguments to function need to have compatible units') else: raise TypeError(error_message) def ensure_all_unitless(*args, error_message: str | None = None): if all((dims_equivalent((custom_get_dimensional_dependencies(arg), {})) for arg in args)): return args[0] else: if error_message: raise TypeError(error_message) else: raise TypeError('Function requires unitless input') def ensure_dims_all_compatible_scalar_or_matrix(*args, func_name = ""): error_message = f"{func_name} function requires that all input values have the same units" if len(args) == 1 and is_matrix(args[0]): return ensure_all_equivalent(*args[0], error_message=error_message) else: return ensure_all_equivalent(*args, error_message=error_message) def ensure_dims_all_compatible_piecewise(*args): # Need to make sure first element in tuples passed to Piecewise all have compatible units # The second element of the tuples has already been checked by And, StrictLessThan, etc. return ensure_all_equivalent(*[arg[0] for arg in args], error_message="Units not consistent for piecewise cell") def ensure_unitless_in_angle_out(arg, func_name=""): if dims_equivalent((custom_get_dimensional_dependencies(arg), {})): return angle else: raise TypeError(f'Unitless input argument required for {func_name} function') def ensure_any_unit_in_angle_out(arg): # ensure input arg units make sense (will raise if inconsistent) custom_get_dimensional_dependencies(arg) return angle def ensure_any_unit_in_same_out(arg): # ensure input arg units make sense (will raise if inconsistent) custom_get_dimensional_dependencies(arg) return arg def ensure_inverse_dims(arg): if not is_matrix(arg): return arg**-1 else: rows = [] column_dims = {} for i in range(arg.rows): row = [] rows.append(row) for j in range(arg.cols): row.append(cast(Expr, arg[j,i])**-1) column_dims.setdefault(i, []).append(arg[j,i]) for _, values in column_dims.items(): ensure_all_equivalent(*values, error_message='Dimensions not consistent for matrix inverse') return Matrix(rows) def custom_transpose(arg): return arg.T def custom_determinant(arg): return arg.det() def custom_matmul(exp1: Expr, exp2: Expr): if is_matrix(exp1) and is_matrix(exp2) and \ (((exp1.rows == 3 and exp1.cols == 1) and (exp2.rows == 3 and exp2.cols == 1)) or \ ((exp1.rows == 1 and exp1.cols == 3) and (exp2.rows == 1 and exp2.cols == 3))): return exp1.cross(exp2) else: return Mul(exp1, exp2) def custom_multiply_dims(matmult: bool, *args: Expr): matrix_args: list[Matrix] = [] scalar_args: list[Expr] = [] processed_args: list[Matrix | Expr] = [] for arg in args: if is_matrix(arg): for i in range(arg.rows): for j in range(arg.cols): if arg[i,j].is_zero: # type: ignore arg[i,j] = S.One matrix_args.append(arg) processed_args.append(matrix_args[-1]) else: scalar_args.append(S.One if arg.is_zero else arg) processed_args.append(scalar_args[-1]) if len(matrix_args) > 0 and len(scalar_args) > 0: first_matrix = matrix_args[0] scalar = Mul(*scalar_args) new_rows = [] for i in range(first_matrix.rows): new_row = [] new_rows.append(new_row) for j in range(first_matrix.cols): new_row.append(Mul(scalar, first_matrix[i,j])) matrix_args[0] = Matrix(new_rows) processed_args = cast(list[Expr | Matrix], matrix_args) if matmult and len(processed_args) == 2 and is_matrix(processed_args[0]) and is_matrix(processed_args[1]) and \ (((processed_args[0].rows == 3 and processed_args[0].cols == 1) and (processed_args[1].rows == 3 and processed_args[1].cols == 1)) or \ ((processed_args[0].rows == 1 and processed_args[0].cols == 3) and (processed_args[1].rows == 1 and processed_args[1].cols == 3))): # cross product detected for matrix multiplication operator result = Matrix([Add(Mul(processed_args[0][1],processed_args[1][2]),Mul(processed_args[0][2],processed_args[1][1])), Add(Mul(processed_args[0][2],processed_args[1][0]),Mul(processed_args[0][0],processed_args[1][2])), Add(Mul(processed_args[0][0],processed_args[1][1]),Mul(processed_args[0][1],processed_args[1][0]))]) if processed_args[0].rows == 3: return result else: return result.T else: return Mul(*processed_args) def custom_min(*args: Expr): if len(args) == 1 and is_matrix(args[0]): return Min(*args[0]) else: return Min(*args) def custom_sum(*args: Expr): if len(args) == 1 and is_matrix(args[0]): return Add(*args[0]) else: return Add(*args) def custom_average(*args: Expr): if len(args) == 1 and is_matrix(args[0]): return Add(*args[0]) / sympify(len(args[0])) else: return Add(*args) / sympify(len(args)) def custom_stdev(population, *args: Expr): if len(args) == 1 and is_matrix(args[0]): values = args[0] else: values = args ddof = 0 if population else 1 count = len(values) if count < 2: raise ValueError('Must have at least 2 values to estimate standard deviation') mean = Add(*values) / sympify(count) return sqrt(Add( *( (value - mean)**2 for value in values ) ) / sympify(count - ddof)) def custom_count(*args: Expr): if len(args) == 1 and is_matrix(args[0]): return sympify(len(args[0])) else: raise TypeError('Count function requires a vector or matrix as input') def custom_max(*args: Expr): if len(args) == 1 and is_matrix(args[0]): return Max(*args[0]) else: return Max(*args) def custom_round(expression: Expr): return expression.round() def custom_range(*args: Expr): if not all( (arg.is_real and arg.is_finite and not isinstance(arg, Dimension) for arg in args ) ): # type: ignore raise TypeError('All range inputs must be unitless and must evaluate to real and finite values') start = cast(Expr, S.One) step = cast(Expr, S.One) if len(args) == 1: stop = args[0] elif len(args) == 2: start = args[0] stop = args[1] elif len(args) == 3: start = args[0] stop = args[1] step = args[2] else: raise ValueError('Too many arguments to range function') values: list[Expr] = [] current_value = start step_sign = sign(step) while(step_sign*current_value <= step_sign*stop): # type: ignore values.append(current_value) current_value = current_value + step # type: ignore if len(values) == 0: raise ValueError('Attempt to create empty range') return Matrix(values) def custom_range_dims(*args: Expr, dim_values: DimValues): return Matrix([ensure_all_equivalent(*args, error_message="All inputs to the range function must have the same units")]*len(cast(Matrix, dim_values["result"]))) class PlaceholderFunction(TypedDict): dim_func: Callable | Function sympy_func: Callable | Function dims_transform: (Callable | Function) | None dims_need_values: bool dummy_var_locations: list[int] def UniversalInverse(expression: Expr) -> Expr: return expression**-1 def prep_matrix_indices(expression: Expr, row_start: Expr, row_stop: Expr, row_stride: Expr, col_start: Expr, col_stop: Expr, col_stride: Expr): if not is_matrix(expression): raise MatrixIndexingError("Subscript indices may only be used on matrices") index_None_ = symbols('index_None_') end_matrix_index = symbols('end_matrix_index') num_rows, num_cols = expression.shape row_start = row_start.xreplace({end_matrix_index: num_rows}) row_stop = row_stop.xreplace({end_matrix_index: num_rows}) col_start = col_start.xreplace({end_matrix_index: num_cols}) col_stop = col_stop.xreplace({end_matrix_index: num_cols}) for subscript in cast(list[ExprWithAssumptions], (row_start, col_start)): if subscript is not index_None_ \ and not (isinstance(subscript, int)) \ and subscript.is_number \ and not (subscript.is_real and subscript.is_finite and subscript.is_integer and cast(int, subscript) > 0): raise MatrixIndexingError("Matrix indices must evaluate to a finite real integer and be greater than 0") for subscript in cast(list[ExprWithAssumptions], (row_stop, col_stop)): if subscript is not index_None_ \ and not (isinstance(subscript, int)) \ and not (subscript.is_number and subscript.is_real and subscript.is_finite and subscript.is_integer and cast(int, subscript) > 0): raise MatrixIndexingError("Matrix indices must evaluate to a finite real integer and be greater than 0") for subscript in cast(list[ExprWithAssumptions], (row_stride, col_stride)): if subscript is not index_None_ \ and not (isinstance(subscript, int)) \ and not (subscript.is_number and subscript.is_real and subscript.is_finite and subscript.is_integer and subscript != 0): raise MatrixIndexingError("Matrix index steps must evaluate to a non-zero finite real integer") if row_start is not index_None_: row_start = row_start - 1 # type: ignore else: row_start = None #type: ignore if row_stop is index_None_: row_stop = None #type: ignore if row_stride is index_None_: row_stride = None #type: ignore elif cast(int, row_stride) < 0: if row_stop is not None: if row_stop == 1: row_stop = None #type: ignore else: row_stop = row_stop - 2 #type: ignore if col_start is not index_None_: col_start = col_start - 1 # type: ignore else: col_start = None #type: ignore if col_stop is index_None_: col_stop = None #type: ignore if col_stride is index_None_: col_stride = None #type: ignore elif cast(int, col_stride) < 0: if col_stop is not None: if col_stop == 1: col_stop = None #type: ignore else: col_stop = col_stop - 2 #type: ignore return (cast(Expr, row_start), row_stop, row_stride, cast(Expr, col_start), col_stop, col_stride) def IndexMatrix(expression: Expr, row_start: Expr, row_stop: Expr, row_stride: Expr, col_start: Expr, col_stop: Expr, col_stride: Expr) -> Expr: row_start, row_stop, row_stride, col_start, col_stop, col_stride = \ prep_matrix_indices(expression, row_start, row_stop, row_stride, col_start, col_stop, col_stride) try: if row_start is not None and row_stop is None and row_stride is None and \ col_start is not None and col_stop is None and col_stride is None: result = cast(Expr, cast(Matrix, expression)[row_start, col_start]) elif row_start is not None and row_stop is None and row_stride is None: result = cast(Expr, cast(Matrix, expression)[row_start, col_start:col_stop:col_stride]) elif col_start is not None and col_stop is None and col_stride is None: result = cast(Expr, cast(Matrix, expression)[row_start:row_stop:row_stride, col_start]) else: result = cast(Expr, cast(Matrix, expression)[row_start:row_stop:row_stride, col_start:col_stop:col_stride]) except IndexError as e: raise MatrixIndexingError(str(e)) if is_matrix(result): if result.shape == (1,1): result = cast(Expr, result[0,0]) elif result.rows == 0 or result.cols == 0: raise MatrixIndexingError('Matrix index out of range') return result #type:ignore def IndexMatrix_dims(expression: Expr, row_start: Expr, row_stop: Expr, row_stride: Expr, col_start: Expr, col_stop: Expr, col_stride: Expr, dim_values: DimValues) -> Expr: if not dims_equivalent((custom_get_dimensional_dependencies(row_start), {})) or \ not dims_equivalent((custom_get_dimensional_dependencies(row_stop), {})) or \ not dims_equivalent((custom_get_dimensional_dependencies(row_stride), {})) or \ not dims_equivalent((custom_get_dimensional_dependencies(col_start), {})) or \ not dims_equivalent((custom_get_dimensional_dependencies(col_stop), {})) or \ not dims_equivalent((custom_get_dimensional_dependencies(col_stride), {})): raise TypeError('Matrix indexing value is not dimensionless') row_start, row_stop, row_stride, col_start, col_stop, col_stride = \ prep_matrix_indices(*dim_values["args"]) if row_start is not None and row_stop is None and row_stride is None and \ col_start is not None and col_stop is None and col_stride is None: result = cast(Expr, cast(Matrix, expression)[row_start, col_start]) elif row_start is not None and row_stop is None and row_stride is None: result = cast(Expr, cast(Matrix, expression)[row_start, col_start:col_stop:col_stride]) elif col_start is not None and col_stop is None and col_stride is None: result = cast(Expr, cast(Matrix, expression)[row_start:row_stop:row_stride, col_start]) else: result = cast(Expr, cast(Matrix, expression)[row_start:row_stop:row_stride, col_start:col_stop:col_stride]) if is_matrix(result) and result.shape == (1,1): result = cast(Expr, result[0,0]) return result #type:ignore def custom_numrows(expression: Expr): if is_matrix(expression): return sympify(expression.rows) else: raise TypeError('numrows function requires a matrix or vector input') def custom_numcols(expression: Expr): if is_matrix(expression): return sympify(expression.cols) else: raise TypeError('numcols function requires a matrix or vector input') def _factorial_imp_(arg1: float): if arg1.is_integer() and arg1 >= 0.0: return math.factorial(int(arg1)) else: raise ValueError("The factorial function can only be evaluated on a nonnegative integer") factorial._imp_ = staticmethod(_factorial_imp_) # type: ignore def custom_norm(expression: Matrix): return expression.norm() def custom_dot(exp1: Matrix, exp2: Matrix): return exp1.dot(exp2) def custom_derivative(operand: Expr, diff_var: Expr, order: int | None = None): if order is not None: return Derivative(operand, diff_var, order, evaluate=True) else: return Derivative(operand, diff_var, evaluate=True) def custom_derivative_dims(operand: Expr, diff_var: Expr, order: int | None = None): if order is None: order = 1 return operand / diff_var**order # type: ignore def custom_indefinite_integral(integrand: Expr, integral_var: Expr): return Integral(integrand, integral_var) def custom_indefinite_integral_dims(integrand: Expr, integral_var: Expr): return integrand * integral_var # type: ignore def custom_integral(integrand: Expr, lower_limit: Expr, upper_limit: Symbol, integral_var: Expr): return Integral(integrand, (integral_var, lower_limit, upper_limit)) def custom_integral_dims_transform(integrand: Expr, lower_limit: Expr, upper_limit: Symbol, integral_var: Expr): return Subs(integrand, integral_var, lower_limit), lower_limit, upper_limit def custom_integral_dims(integrand: Expr, lower_limit: Expr, upper_limit: Symbol): ensure_all_equivalent(lower_limit, upper_limit, error_message="Upper and lower integral limits must have the same dimensions") return integrand * lower_limit # type: ignore def custom_summation(operand: Expr, dummy_var: Symbol, start: Expr, end: Expr): for limit in cast(list[ExprWithAssumptions], (start, end)): if (limit.is_number and limit.is_finite) and not (limit.is_real and limit.is_integer): raise Exception("Summation upper and lower limits must evalute to an integer or infinity") return summation(operand, (dummy_var, start, end)) def custom_summation_dims(operand: Expr, dummy_var: Symbol, start: Expr, end: Expr, dim_values: DimValues): if not dims_equivalent((custom_get_dimensional_dependencies(start), {})) or \ not dims_equivalent((custom_get_dimensional_dependencies(end), {})): raise TypeError('Summation start and end values must be unitless') start_value = dim_values["args"][2] end_value = dim_values["args"][3] return summation(operand, (dummy_var, start_value, end_value)) def custom_product(operand: Expr, dummy_var: Symbol, start: Expr, end: Expr): for limit in cast(list[ExprWithAssumptions], (start, end)): if (limit.is_number and limit.is_finite) and not (limit.is_real and limit.is_integer): raise Exception("Product upper and lower limits must evalute to an integer or infinity") return product(operand, (dummy_var, start, end)) def custom_product_dims(operand: Expr, dummy_var: Symbol, start: Expr, end: Expr, dim_values: DimValues): if not dims_equivalent((custom_get_dimensional_dependencies(start), {})) or \ not dims_equivalent((custom_get_dimensional_dependencies(end), {})): raise TypeError('Product start and end values must be unitless') start_value = dim_values["args"][2] end_value = dim_values["args"][3] return product(operand, (dummy_var, start_value, end_value)) def custom_add_dims(*args: Expr): return Add(*[Abs(arg) for arg in args]) def custom_pow(base: Expr, exponent: Expr): large_rational = False for atom in (exponent.atoms(Rational) | base.atoms(Rational)): if abs(atom.q) > LARGE_RATIONAL: large_rational = True if large_rational: return Pow(base.evalf(PRECISION), exponent.evalf(PRECISION)) else: return Pow(base, exponent) def custom_pow_dims(base: Expr, exponent: Expr, dim_values: DimValues): if not dims_equivalent((custom_get_dimensional_dependencies(exponent), {})): raise TypeError('Exponent Not Dimensionless') return Pow(base.evalf(PRECISION), (dim_values["args"][1]).evalf(PRECISION)) def PropsSI_wrapper(fluid_function: FluidFunction): import CoolProp.CoolProp as cp class PropsSI_function(Function): is_real = True @staticmethod def _imp_(arg1, arg2): return cp.PropsSI(fluid_function["output"], fluid_function["input1"], float(arg1), fluid_function["input2"], float(arg2), fluid_function["fluid"]) def _eval_evalf(self, prec): if (len(self.args) != 2): raise TypeError(f'The fluid function {fluid_function["name"]} requires 2 input values, ({len(self.args)} given)') if (self.args[0].is_number and self.args[1].is_number): return sympify(cp.PropsSI(fluid_function["output"], fluid_function["input1"], float(cast(Expr, self.args[0])), fluid_function["input2"], float(cast(Expr, self.args[1])), fluid_function["fluid"])) def fdiff(self, argindex=1): delta = sympify(1e-8) upper_args = [arg if i != argindex-1 else arg + delta for i, arg in enumerate(self.args)] return (PropsSI_function(*upper_args) - PropsSI_function(*self.args)) / delta # type: ignore PropsSI_function.__name__ = fluid_function["name"] return PropsSI_function def fluid_dims(fluid_function: FluidFunction, input1, input2): ensure_all_equivalent(get_dims(fluid_function["input1Dims"]), input1, error_message=f"First input to fluid function {fluid_function['name'].removesuffix('_as_variable')} has the incorrect units") ensure_all_equivalent(get_dims(fluid_function["input2Dims"]), input2, error_message=f"Second input to fluid function {fluid_function['name'].removesuffix('_as_variable')} has the incorrect units") return get_dims(fluid_function["outputDims"]) class TextFloat(Float): def __new__(cls, value, text): return Float.__new__(cls, value) def __init__(self, value, text): self._ep_text = text def _latex(self, printer): return f"\\text{{{self._ep_text}}}" def PhaseSI_wrapper(fluid_function: FluidFunction): import CoolProp.CoolProp as cp class PhaseSI_function(Function): is_real = True @staticmethod def _imp_(arg1, arg2): return cp.PropsSI('PHASE', fluid_function["input1"], float(arg1), fluid_function["input2"], float(arg2), fluid_function["fluid"]) @classmethod def eval(cls, arg1, arg2): if arg1.is_number and arg2.is_number: phase_text = cp.PhaseSI(fluid_function["input1"], float(arg1), fluid_function["input2"], float(arg2), fluid_function["fluid"]) phase_index = cp.get_phase_index(f"phase_{phase_text}") return TextFloat(phase_index, phase_text) PhaseSI_function.__name__ = fluid_function["name"] return PhaseSI_function def HAPropsSI_wrapper(fluid_function: FluidFunction): import CoolProp.CoolProp as cp class HAPropsSI_function(Function): is_real = True @staticmethod def _imp_(arg1, arg2, arg3): return cp.HAPropsSI(fluid_function["output"], fluid_function["input1"], float(arg1), fluid_function["input2"], float(arg2), fluid_function.get("input3"), float(arg3)) def _eval_evalf(self, prec): if (len(self.args) != 3): raise TypeError(f'The fluid function {fluid_function["name"]} requires 3 input values ({len(self.args)} given)') if self.args[0].is_number and self.args[1].is_number and self.args[2].is_number: return sympify(cp.HAPropsSI(fluid_function["output"], fluid_function["input1"], float(cast(Expr, self.args[0])), fluid_function["input2"], float(cast(Expr, self.args[1])), fluid_function.get("input3"), float(cast(Expr, self.args[2])))) def fdiff(self, argindex=1): delta = sympify(1e-8) upper_args = [arg if i != argindex-1 else arg + delta for i, arg in enumerate(self.args)] return (HAPropsSI_function(*upper_args) - HAPropsSI_function(*self.args)) / delta # type: ignore HAPropsSI_function.__name__ = fluid_function["name"] return HAPropsSI_function def HA_fluid_dims(fluid_function: FluidFunction, input1, input2, input3): ensure_all_equivalent(get_dims(fluid_function["input1Dims"]), input1, error_message=f"First input to fluid function {fluid_function['name'].removesuffix('_as_variable')} has the incorrect units") ensure_all_equivalent(get_dims(fluid_function["input2Dims"]), input2, error_message=f"Second input to fluid function {fluid_function['name'].removesuffix('_as_variable')} has the incorrect units") ensure_all_equivalent(get_dims(fluid_function.get("input3Dims", [])), input3, error_message=f"Third input to fluid function {fluid_function['name'].removesuffix('_as_variable')} has the incorrect units") return get_dims(fluid_function["outputDims"]) def get_fluid_placeholder_map(fluid_functions: list[FluidFunction]) -> dict[Function, PlaceholderFunction]: new_map: dict[Function, PlaceholderFunction] = {} for fluid_function in fluid_functions: if fluid_function["fluid"] == "HumidAir": sympy_func = HAPropsSI_wrapper(fluid_function) dim_func = partial(lambda ff, input1, input2, input3 : HA_fluid_dims(ff, input1, input2, input3), fluid_function) elif fluid_function["output"] == "PHASE": sympy_func = PhaseSI_wrapper(fluid_function) dim_func = partial(lambda ff, input1, input2 : fluid_dims(ff, input1, input2), fluid_function) else: sympy_func = PropsSI_wrapper(fluid_function) dim_func = partial(lambda ff, input1, input2 : fluid_dims(ff, input1, input2), fluid_function) new_map[cast(Function, Function(fluid_function["name"]))] = {"dim_func": dim_func, "sympy_func": sympy_func, "dims_transform": None, "dims_need_values": False, "dummy_var_locations": []} return new_map def get_interpolation_wrapper(interpolation_function: InterpolationFunction): import numpy as np input_values = np.array(interpolation_function["inputValues"][0]) output_values = np.array(interpolation_function["outputValues"]) if not np.all(np.diff(input_values) > 0): # sort input values since they are not in ascending order sorted_indices = np.argsort(input_values) input_values = input_values[sorted_indices] output_values = output_values[sorted_indices] if not np.all(np.diff(input_values) > 0): raise ValueError('1D linear interpolation cannot be performed with repeated input values') class interpolation_wrapper(Function): is_real = True @staticmethod def _imp_(arg1): return np.interp(float(arg1), input_values, output_values) def _eval_evalf(self, prec): if (len(self.args) != 1): raise TypeError(f"The interpolation function {interpolation_function['name'].removesuffix('_as_variable')} requires 1 input value, ({len(self.args)} given)") if (self.args[0].is_number): float_input = float(cast(Expr, self.args[0])) if float_input < input_values[0] or float_input > input_values[-1]: raise Extrapolation(interpolation_function['name'].removesuffix('_as_variable')) return sympify(np.interp(float_input, input_values, output_values)) def fdiff(self, argindex=1): delta = sympify(1e-8) upper_args = [arg if i != argindex-1 else arg + delta for i, arg in enumerate(self.args)] return (interpolation_wrapper(*upper_args) - interpolation_wrapper(*self.args)) / delta # type: ignore interpolation_wrapper.__name__ = interpolation_function["name"] def interpolation_dims_wrapper(input): ensure_all_equivalent(get_dims(interpolation_function["inputDims"][0]), input, error_message=f"Incorrect units for interpolation function {interpolation_function['name'].removesuffix('_as_variable')}") return get_dims(interpolation_function["outputDims"]) return interpolation_wrapper, interpolation_dims_wrapper def get_multi_interpolation_wrapper(interpolation_function: InterpolationFunction): import numpy as np from scipy.interpolate import LinearNDInterpolator input_values = np.array(interpolation_function["inputValues"]).T output_values = np.array(interpolation_function["outputValues"]) num_inputs = input_values.shape[1] interp = LinearNDInterpolator(input_values, output_values, rescale=True) class multi_interpolation_wrapper(Function): is_real = True @staticmethod def _imp_(*args): float_args = [float(arg) for arg in args] return interp(*float_args) def _eval_evalf(self, prec): if (len(self.args) != num_inputs): raise TypeError(f"The interpolation function {interpolation_function['name'].removesuffix('_as_variable')} requires {num_inputs} input values, ({len(self.args)} given)") if (all(arg.is_number for arg in self.args)): float_inputs = [float(cast(Expr, arg)) for arg in self.args] result = float(interp(*float_inputs)) if np.isnan(result): raise Extrapolation(interpolation_function['name'].removesuffix('_as_variable')) else: return sympify(result) def fdiff(self, argindex=1): delta = sympify(1e-8) upper_args = [arg if i != argindex-1 else arg + delta for i, arg in enumerate(self.args)] return (multi_interpolation_wrapper(*upper_args) - multi_interpolation_wrapper(*self.args)) / delta # type: ignore multi_interpolation_wrapper.__name__ = interpolation_function["name"] def interpolation_dims_wrapper(*inputs): for i, dims in enumerate(interpolation_function["inputDims"]): ensure_all_equivalent(get_dims(dims), inputs[i], error_message=f"Incorrect units for input number {i+1} of interpolation function {interpolation_function['name'].removesuffix('_as_variable')}") return get_dims(interpolation_function["outputDims"]) return multi_interpolation_wrapper, interpolation_dims_wrapper def get_grid_interpolation_wrapper(interpolation_function: GridInterpolationFunction): import numpy as np from scipy.interpolate import interpn points = (np.array(interpolation_function["inputValues"][0]), np.array(interpolation_function["inputValues"][1])) values = np.array(interpolation_function["outputValues"]) num_inputs = interpolation_function["numInputs"] class grid_interpolation_wrapper(Function): is_real = True @staticmethod def _imp_(*args): return interpn(points, values, np.array([args], dtype=float))[0] def _eval_evalf(self, prec): if (len(self.args) != num_inputs): raise TypeError(f"The interpolation function {interpolation_function['name'].removesuffix('_as_variable')} requires {num_inputs} input values, ({len(self.args)} given)") if (all(arg.is_number for arg in self.args)): float_inputs = [float(cast(Expr, arg)) for arg in self.args] result = float(interpn(points, values, np.array([float_inputs]), bounds_error=False, fill_value=np.nan)[0]) if np.isnan(result): raise Extrapolation(interpolation_function['name'].removesuffix('_as_variable')) else: return sympify(result) def fdiff(self, argindex=1): delta = sympify(1e-8) upper_args = [arg if i != argindex-1 else arg + delta for i, arg in enumerate(self.args)] return (grid_interpolation_wrapper(*upper_args) - grid_interpolation_wrapper(*self.args)) / delta # type: ignore grid_interpolation_wrapper.__name__ = interpolation_function["name"] def interpolation_dims_wrapper(*inputs): for i, dims in enumerate(interpolation_function["inputDims"]): ensure_all_equivalent(get_dims(dims), inputs[i], error_message=f"Incorrect units for input number {i+1} of interpolation function {interpolation_function['name'].removesuffix('_as_variable')}") return get_dims(interpolation_function["outputDims"]) return grid_interpolation_wrapper, interpolation_dims_wrapper def get_polyfit_wrapper(polyfit_function: InterpolationFunction): import numpy as np fitted_poly = np.polynomial.Polynomial.fit(polyfit_function["inputValues"][0], polyfit_function["outputValues"], polyfit_function["order"]) coefficients = fitted_poly.convert() class polyfit_wrapper(Function): @classmethod def eval(cls, arg1: Expr): return Add(*(coef*arg1**power for power,coef in enumerate(coefficients))) # type: ignore polyfit_wrapper.__name__ = polyfit_function["name"] def polyfit_dims_wrapper(input): ensure_all_equivalent(get_dims(polyfit_function["inputDims"][0]), input, error_message=f"Incorrect units for polyfit function {polyfit_function['name'].removesuffix('_as_variable')}") return get_dims(polyfit_function["outputDims"]) return polyfit_wrapper, polyfit_dims_wrapper def get_multi_polyfit_wrapper(interpolation_function: InterpolationFunction): import numpy as np from sklearn.preprocessing import PolynomialFeatures from sklearn.linear_model import LinearRegression num_inputs = interpolation_function["numInputs"] input_values = np.array(interpolation_function["inputValues"]).T output_values = np.array(interpolation_function["outputValues"]) poly = PolynomialFeatures(degree=interpolation_function["order"]) input_values_transformed = poly.fit_transform(input_values) model = LinearRegression() model.fit(input_values_transformed, output_values) input_features = [f"x{i}__" for i in range(num_inputs)] input_symbols = [sympify(name) for name in input_features] feature_names = poly.get_feature_names_out(input_features) coefficients = [model.intercept_, *model.coef_[1:]] sympy_expression = sympify(coefficients[0]) # constant term for coef,feature in zip(coefficients[1:], feature_names[1:]): sympy_expression += coef * sympify(feature.replace(" ", "*").replace("^", "**")) class multi_polyfit_wrapper(Function): @classmethod def eval(cls, *args: Expr): if (len(args) != num_inputs): raise TypeError(f"The polyfit function {interpolation_function['name'].removesuffix('_as_variable')} requires {num_inputs} input values, ({len(args)} given)") subs = {input_symbol : arg for input_symbol, arg in zip(input_symbols, args) } return sympy_expression.xreplace(subs) multi_polyfit_wrapper.__name__ = interpolation_function["name"] def interpolation_dims_wrapper(*inputs): for i, dims in enumerate(interpolation_function["inputDims"]): ensure_all_equivalent(get_dims(dims), inputs[i], error_message=f"Incorrect units for input number {i+1} of interpolation function {interpolation_function['name'].removesuffix('_as_variable')}") return get_dims(interpolation_function["outputDims"]) return multi_polyfit_wrapper, interpolation_dims_wrapper def get_interpolation_placeholder_map(interpolation_functions: list[InterpolationFunction | GridInterpolationFunction]) -> dict[Function, PlaceholderFunction]: new_map: dict[Function, PlaceholderFunction] = {} for interpolation_function in interpolation_functions: match (interpolation_function["type"], interpolation_function["numInputs"]): case ("interpolation", 1): sympy_func, dim_func = get_interpolation_wrapper(cast(InterpolationFunction, interpolation_function)) case("interpolation", numInputs): sympy_func, dim_func = get_multi_interpolation_wrapper(cast(InterpolationFunction, interpolation_function)) case ("polyfit", 1): sympy_func, dim_func = get_polyfit_wrapper(cast(InterpolationFunction, interpolation_function)) case ("polyfit", numInputs): sympy_func, dim_func = get_multi_polyfit_wrapper(cast(InterpolationFunction, interpolation_function)) case ("gridInterpolation", numInputs): sympy_func, dim_func = get_grid_interpolation_wrapper(cast(GridInterpolationFunction, interpolation_function)) case _: continue new_map[cast(Function, Function(interpolation_function["name"]))] = {"dim_func": dim_func, "sympy_func": sympy_func, "dims_transform": None, "dims_need_values": False, "dummy_var_locations": []} return new_map data_table_id_wrapper = Function('_data_table_id_wrapper') data_table_calc_wrapper_prefix = '_data_table_calc_wrapper_' class DataTableSubs: def __init__(self): self.subs_stack: list[dict[Symbol, Expr]] = [] self._next_id = 0 self.shortest_col_stack: list[None | int] = [] def get_next_id(self): self._next_id += 1 return self._next_id-1 def wrap_code_cell_function(func: Callable, buffer: io.StringIO, exceptions: list[Exception], dims_function=False): def wrapped_func(*args, **kwargs): sys.stdout = buffer try: result = func(*args, **kwargs) except Exception as e: exceptions.append(e) if not dims_function: raise CodeCellException(f"{type(e).__name__}, {e}") else: raise finally: sys.stdout = sys.__stdout__ return result return wrapped_func def compile_code_cell_function(code_cell_function: CodeCellFunction, code_cell_result_store: dict[str, CodeCellResultCollector]) -> \ tuple[Callable, Callable | None, Callable | None, bool, bool]: import inspect name = code_cell_function["name"] code_func_globals = { "ensure_all_equivalent": partial(ensure_all_equivalent, error_message=f"{name.removesuffix('_as_variable')} dimension equivalence check has failed"), "ensure_all_unitless": partial(ensure_all_unitless, error_message=f"{name.removesuffix('_as_variable')} dimension unitless check has failed"), } exceptions: list[Exception] = [] buffer = io.StringIO() num_specification_inputs = len(code_cell_function["inputDims"]) code_cell_result_store[name] = { "buffer": buffer, "exceptions": exceptions } try: code_object = compile(code_cell_function["code"], name, "exec") sys.stdout = buffer exec(code_object, code_func_globals) sys.stdout = sys.__stdout__ code_func = code_func_globals.get("calculate", None) if not callable(code_func): raise ValueError('The code cell must define a function called "calculate"') code_func_parameters = inspect.signature(code_func).parameters zero_inputs = len(code_func_parameters) == 0 and \ len(code_cell_function["inputDims"]) == 1 and \ code_cell_function["inputDims"][0]["type"] == "scalar" and \ code_cell_function["inputDims"][0]["dims"]["type"] == "any" if len(code_func_parameters) != num_specification_inputs and not zero_inputs: raise ValueError(f'The number of inputs to the provided "calculate" function ({len(code_func_parameters)}) does not match the number of inputs in the function definition ({num_specification_inputs}).') if len(code_func_parameters) == 1 and next(iter(code_func_parameters.values())).kind == inspect.Parameter.VAR_POSITIONAL: variable_number_of_inputs = True else: variable_number_of_inputs = False raw_custom_dims_func = code_func_globals.get("custom_dims", None) custom_dims_transform_func = code_func_globals.get("dims_transform", None) if not callable(raw_custom_dims_func): custom_dims_func = None custom_dims_transform_func = None elif callable(custom_dims_transform_func): dims_transform_func_parameters = inspect.signature(custom_dims_transform_func).parameters if len(dims_transform_func_parameters) != num_specification_inputs: raise ValueError(f'The number of inputs to the provided "dims_transform" function ({len(dims_transform_func_parameters)}) does not match the number of inputs in the function definition ({num_specification_inputs}).') if variable_number_of_inputs and not (next(iter(dims_transform_func_parameters.values())).kind == inspect.Parameter.VAR_POSITIONAL): raise ValueError(f'The "dims_transform" function needs to have a variable number of inputs since the "calculate" function has a variable number of inputs.') dims_func_parameters = inspect.signature(raw_custom_dims_func).parameters if "dim_values" in dims_func_parameters: custom_dims_func = lambda *args, **kwargs: raw_custom_dims_func(*args, **kwargs) else: custom_dims_func = lambda *args, **kwargs: raw_custom_dims_func(*args) else: custom_dims_transform_func = None dims_func_parameters = inspect.signature(raw_custom_dims_func).parameters if "dim_values" in dims_func_parameters: num_dims_function_parameters = len(dims_func_parameters) - 1 custom_dims_func = lambda *args, **kwargs: raw_custom_dims_func(*args, **kwargs) else: num_dims_function_parameters = len(dims_func_parameters) custom_dims_func = lambda *args, **kwargs: raw_custom_dims_func(*args) if num_dims_function_parameters != num_specification_inputs: raise ValueError(f'The number of inputs to the provided "custom_dims" function ({num_dims_function_parameters}) does not match the number of inputs in the function definition ({num_specification_inputs}).') if variable_number_of_inputs and not (next(iter(dims_func_parameters.values())).kind == inspect.Parameter.VAR_POSITIONAL): raise ValueError(f'The "custom_dims" function needs to have a variable number of inputs since the "calculate" function has a variable number of inputs.') if custom_dims_func is not None: if not (code_cell_function["outputDims"]["type"] == "scalar" and code_cell_function["outputDims"]["dims"]["type"] == "any" and all(dims["type"] == "scalar" and (dims["dims"]["type"] == "any" or dims["dims"]["type"] == "dummy") for dims in code_cell_function["inputDims"])): raise TypeError(f"All inputs and outputs must be of scalar type [any] to use the custom_dims function for code cell funciton {name.removesuffix('_as_variable')}") except Exception as e: exceptions.append(e) raise code_func = wrap_code_cell_function(code_func, buffer, exceptions) if custom_dims_func is not None: custom_dims_func = wrap_code_cell_function(custom_dims_func, buffer, exceptions, dims_function=True) if custom_dims_transform_func is not None: custom_dims_transform_func = wrap_code_cell_function(custom_dims_transform_func, buffer, exceptions, dims_function=True) return code_func, custom_dims_func, custom_dims_transform_func, variable_number_of_inputs, zero_inputs def check_code_cell_input(input: Expr, input_num: int, dims: CodeCellInputOutputDims, name: str): if dims["type"] == "scalar": if dims["dims"]["type"] == "specific": if not is_matrix(input): ensure_all_equivalent(get_dims(dims["dims"]["dims"]), input, error_message=f"Incorrect units for input number {input_num+1} of code cell function {name.removesuffix('_as_variable')}") else: ensure_all_equivalent(get_dims(dims["dims"]["dims"]), *input, error_message=f"Incorrect units for input number {input_num+1} of code cell function {name.removesuffix('_as_variable')}") else: if not is_matrix(input): raise TypeError(f"Matrix or vector expected for input number {input_num+1} of code cell function {name.removesuffix('_as_variable')}") else: expected_shape = (len(dims["dims"]), len(dims["dims"][0])) if expected_shape == input.shape: for i, row in enumerate(dims["dims"]): for j, dim in enumerate(row): if dim["type"] == "specific": ensure_all_equivalent(get_dims(dim["dims"]), input[i,j], error_message=f"Incorrect units at (row={i+1}, col={j+j}) for input number {input_num+1} of code cell function {name.removesuffix('_as_variable')}") else: if expected_shape[1] == 1 and expected_shape[0] == input.rows: for i,row in enumerate(dims["dims"]): dim = row[0] if dim["type"] == "specific": ensure_all_equivalent(get_dims(dim["dims"]), *(cast(Matrix,input[i,:])), error_message=f"Incorrect units for input number {input_num+1} of code cell function {name.removesuffix('_as_variable')}") elif expected_shape[0] == 1 and expected_shape[1] == input.cols: for j,dim in enumerate(dims["dims"][0]): if dim["type"] == "specific": ensure_all_equivalent(get_dims(dim["dims"]), *(cast(Matrix,input[:,j])), error_message=f"Incorrect units for input number {input_num+1} of code cell function {name.removesuffix('_as_variable')}") else: raise TypeError(f"Incorrect matrix or vector size for input number {input_num+1} of code cell function {name.removesuffix('_as_variable')}") def code_cell_dims_check(*inputs: Expr, code_cell_function: CodeCellFunction, custom_dims_func: Callable | None, dim_values: DimValues): name = code_cell_function["name"] if custom_dims_func is not None: return custom_dims_func(*inputs, dim_values=dim_values) num_spec_dims = len(code_cell_function["inputDims"]) for i, input in enumerate(inputs): if num_spec_dims == 1: check_code_cell_input(input, i, code_cell_function["inputDims"][0], name) else: check_code_cell_input(input, i, code_cell_function["inputDims"][i], name) dims = code_cell_function["outputDims"] if dims["type"] == "scalar": if dims["dims"]["type"] == "specific": if not is_matrix(dim_values["result"]): return get_dims(dims["dims"]["dims"]) else: result = ones(*(dim_values["result"].shape)) result.fill(get_dims(dims["dims"]["dims"])) return result elif dims["dims"]["type"] == "any": raise TypeError(f"Return type of [any] only allowed when custom_dims function is defined, custom_dims is not defined for code cell function {name.removesuffix('_as_variable')}.") else: # render result, return unitless return S.One else: result = dim_values["result"] if not is_matrix(result): raise TypeError(f"Matrix or vector expected for the output of code cell function {name.removesuffix('_as_variable')}") else: expected_shape = (len(dims["dims"]), len(dims["dims"][0])) if expected_shape == result.shape: output_rows = [] for i, row in enumerate(dims["dims"]): current_output_row = [] output_rows.append(current_output_row) for j, dim in enumerate(row): if dim["type"] == "specific": current_output_row.append(get_dims(dim["dims"])) else: raise TypeError(f"Return type of [any], [text], [html], or [markdown] cannot be used within a matrix output specification, the code cell function {name.removesuffix('_as_variable')} triggered this error.") return Matrix(output_rows) else: if expected_shape[1] == 1 and expected_shape[0] == result.rows: output_rows = [] for i,row in enumerate(dims["dims"]): dim = row[0] if dim["type"] == "specific": current_output_row = [get_dims(dim["dims"])]*result.cols output_rows.append(current_output_row) else: raise TypeError(f"Return type of [any], [text], [html], or [markdown] cannot be used within a matrix output specification, the code cell function {name.removesuffix('_as_variable')} triggered this error.") return Matrix(output_rows) elif expected_shape[0] == 1 and expected_shape[1] == result.cols: output_cols = [] for j,dim in enumerate(dims["dims"][0]): if dim["type"] == "specific": current_output_col = [get_dims(dim["dims"])]*result.rows output_cols.append(current_output_col) else: raise TypeError(f"Return type of [any], [text], [html], or [markdown] cannot be used within a matrix output specification, the code cell function {name.removesuffix('_as_variable')} triggered this error.") return Matrix(output_cols).T else: raise TypeError(f"Incorrect matrix or vector size for output of code cell function {name.removesuffix('_as_variable')}") def convert_from_SI(dims: CodeCellDims, value): if dims["type"] == "any" or dims["type"] == "dummy": return value if dims["type"] == "render": raise CodeCellException("[text], [html], or [markdown] types not allowed for input argments of code cell") offset = dims["offset"] scale_factor = dims["scaleFactor"] if offset == 0.0 and scale_factor == 1.0: return value if offset == 0.0: return value/scale_factor if is_matrix(value): return (value/scale_factor) - ones(value.rows, value.cols)*offset else: return (value/scale_factor) - offset def convert_to_SI(dims: CodeCellDims, value): if dims["type"] == "any" or dims["type"] == "render" or dims["type"] == "dummy": return value offset = dims["offset"] scale_factor = dims["scaleFactor"] if offset == 0.0 and scale_factor == 1.0: return value if offset == 0.0: return value*scale_factor if is_matrix(value): return (value + ones(value.rows, value.cols)*offset) * scale_factor else: return (value + offset) * scale_factor def get_code_cell_sympy_mode_wrapper(code_cell_function: CodeCellFunction, code_cell_result_store: dict[str, CodeCellResultCollector]) -> tuple[Function, Callable | None, Callable | None]: name = code_cell_function["name"] code_func, custom_dims_func, custom_dims_transform_function, variable_number_of_inputs, zero_inputs = compile_code_cell_function(code_cell_function, code_cell_result_store) class code_cell_sympy_wrapper(Function): @classmethod def eval(cls, *args: Expr): args_list = list(args) if len(args) != len(code_cell_function["inputDims"]) and not variable_number_of_inputs and not (zero_inputs and len(args) == 0): raise CodeCellException(f'Number of input arguments provided to code function "{name.removesuffix('_as_variable')}" ({len(args)}) differs from the number of arguments specified in the code function definition ({len(code_cell_function["inputDims"])}).') for input_num, arg in enumerate(args_list): if variable_number_of_inputs and (input_num > 0): arg_dims = code_cell_function["inputDims"][0] else: arg_dims = code_cell_function["inputDims"][input_num] if arg_dims["type"] == "scalar": args_list[input_num] = cast(Expr, convert_from_SI(arg_dims["dims"], arg)) else: if not is_matrix(arg): raise CodeCellException(f"Matrix or vector expected for input number {input_num+1} of code cell function {name.removesuffix('_as_variable')}") else: new_arg = Matrix(arg) # ensure mutable expected_shape = (len(arg_dims["dims"]), len(arg_dims["dims"][0])) if expected_shape == new_arg.shape: for i, row in enumerate(arg_dims["dims"]): for j, dim in enumerate(row): new_arg[i,j] = convert_from_SI(dim, new_arg[i,j]) else: if expected_shape[1] == 1 and expected_shape[0] == new_arg.shape[0]: for i,row in enumerate(arg_dims["dims"]): dim = row[0] new_arg[i,:] = convert_from_SI(dim, new_arg[i,:]) elif expected_shape[0] == 1 and expected_shape[1] == new_arg.shape[1]: for j,dim in enumerate(arg_dims["dims"][0]): new_arg[:,j] = convert_from_SI(dim, new_arg[:,j]) else: raise CodeCellException(f"Incorrect matrix or vector size for input number {input_num+1} of code cell function {name.removesuffix('_as_variable')}") args_list[input_num] = cast(Expr, new_arg) result = code_func(*args_list) if isinstance(result, list | tuple): result = Matrix(result) if isinstance(result, str): if code_cell_function["outputDims"]["type"] == "scalar" and \ code_cell_function["outputDims"]["dims"]["type"] == "render": return RenderExpr(code_cell_function["outputDims"]["dims"]["renderType"], result) else: raise CodeCellException(f"The code cell function {name.removesuffix('_as_variable')} returns a string value where a numerical value is expected. Specify an output type of [text], [html], or [markdown] to render string output.") result_dims = code_cell_function["outputDims"] if not is_matrix(result): if result_dims["type"] == "scalar": return sympify(convert_to_SI(result_dims["dims"], result)) else: raise CodeCellException(f"The code cell function {name.removesuffix('_as_variable')} returns a scalar when a matrix output was specified") else: if result_dims["type"] == "scalar": result = convert_to_SI(result_dims["dims"], result) else: new_result = Matrix(result) # ensure mutable expected_shape = (len(result_dims["dims"]), len(result_dims["dims"][0])) if expected_shape == new_result.shape: for i, row in enumerate(result_dims["dims"]): for j, dim in enumerate(row): new_result[i,j] = convert_to_SI(dim, new_result[i,j]) else: if expected_shape[1] == 1 and expected_shape[0] == new_result.shape[0]: for i,row in enumerate(result_dims["dims"]): dim = row[0] new_result[i,:] = convert_to_SI(dim, new_result[i,:]) elif expected_shape[0] == 1 and expected_shape[1] == new_result.shape[1]: for j,dim in enumerate(result_dims["dims"][0]): new_result[:,j] = convert_to_SI(dim, new_result[:,j]) else: raise CodeCellException(f"Incorrect matrix or vector size for output of code cell function {name.removesuffix('_as_variable')}") result = new_result return result code_cell_sympy_wrapper.__name__ = code_cell_function["name"] return cast(Function, code_cell_sympy_wrapper), custom_dims_func, custom_dims_transform_function class RenderExpr(Expr): is_number = False #pyright: ignore def __new__(cls, render_type:Literal["text"] | Literal["html"] | Literal["markdown"], render_value: str): return super().__new__(cls) def __init__(self, render_type:Literal["text"] | Literal["html"] | Literal["markdown"], render_value: str): super().__init__() self.render_type = render_type self.render_value = render_value def get_code_cell_wrapper(code_cell_function: CodeCellFunction, code_cell_result_store: dict[str, CodeCellResultCollector]) -> tuple[Function, Callable | None]: import numpy as np name = code_cell_function["name"] code_func, custom_dims_func, custom_dims_transform, variable_number_of_inputs, zero_inputs = compile_code_cell_function(code_cell_function, code_cell_result_store) if custom_dims_transform is not None: raise CodeCellException('"dims_transform" function only allowed with "SymPy Mode" enabled') def implementation(*args): numeric_args = list(args) for input_num, numeric_arg in enumerate(numeric_args): if variable_number_of_inputs and (input_num > 0): arg_dims = code_cell_function["inputDims"][0] else: arg_dims = code_cell_function["inputDims"][input_num] if arg_dims["type"] == "scalar": numeric_args[input_num] = convert_from_SI(arg_dims["dims"], numeric_arg) else: if not isinstance(numeric_arg, np.ndarray): raise CodeCellException(f"Matrix or vector expected for input number {input_num+1} of code cell function {name.removesuffix('_as_variable')}") else: expected_shape = (len(arg_dims["dims"]), len(arg_dims["dims"][0])) if expected_shape == numeric_arg.shape: for i, row in enumerate(arg_dims["dims"]): for j, dim in enumerate(row): numeric_arg[i,j] = convert_from_SI(dim, numeric_arg[i,j]) else: if expected_shape[1] == 1 and expected_shape[0] == numeric_arg.shape[0]: for i,row in enumerate(arg_dims["dims"]): dim = row[0] numeric_arg[i,:] = convert_from_SI(dim, numeric_arg[i,:]) elif expected_shape[0] == 1 and expected_shape[1] == numeric_arg.shape[1]: for j,dim in enumerate(arg_dims["dims"][0]): numeric_arg[:,j] = convert_from_SI(dim, numeric_arg[:,j]) else: raise CodeCellException(f"Incorrect matrix or vector size for input number {input_num+1} of code cell function {name.removesuffix('_as_variable')}") result = code_func(*numeric_args) if isinstance(result, str): return result result_dims = code_cell_function["outputDims"] if isinstance(result, float) or isinstance(result, int) or isinstance(result, complex): if result_dims["type"] == "scalar": return convert_to_SI(result_dims["dims"], result) else: raise CodeCellException(f"The code cell function {name.removesuffix('_as_variable')} returns a scalar when a matrix output was specified") elif isinstance(result, list | tuple) or isinstance(result, np.ndarray): if isinstance(result, list | tuple): result = np.array(result) if len(result.shape) == 1: result = result.reshape(-1,1) # sympy defaults to column for 1D matrix input elif len(result.shape) != 2: raise CodeCellException(f"Output of code cell function {name.removesuffix('_as_variable')} must be scalar value or a 2D matrix.") if result_dims["type"] == "scalar": result = convert_to_SI(result_dims["dims"], result) else: expected_shape = (len(result_dims["dims"]), len(result_dims["dims"][0])) if expected_shape == result.shape: for i, row in enumerate(result_dims["dims"]): for j, dim in enumerate(row): result[i,j] = convert_to_SI(dim, result[i,j]) else: if expected_shape[1] == 1 and expected_shape[0] == result.shape[0]: for i,row in enumerate(result_dims["dims"]): dim = row[0] result[i,:] = convert_to_SI(dim, result[i,:]) elif expected_shape[0] == 1 and expected_shape[1] == result.shape[1]: for j,dim in enumerate(result_dims["dims"][0]): result[:,j] = convert_to_SI(dim, result[:,j]) else: raise CodeCellException(f"Incorrect matrix or vector size for output of code cell function {name.removesuffix('_as_variable')}") return result else: return result class code_cell_wrapper(Function): is_real = True @staticmethod def _imp_(*args): float_args = [] for arg in args: if isinstance(arg, mpmath.mpf): float_args.append(float(arg)) elif isinstance(arg, mpmath.matrix): float_args.append(np.array(arg.tolist(), dtype=float)) else: float_args.append(arg) if all((isinstance(arg, float) or isinstance(arg, np.ndarray)) for arg in float_args): return implementation(*float_args) @classmethod def eval(cls, *args: Expr): all_args_numeric = True numeric_args = [] for arg in args: if is_matrix(arg): all_args_numeric = all_args_numeric and all(cast(Expr, value).is_number for value in arg) if all_args_numeric: numeric_args.append(np.array(arg.tolist(), dtype=np.float64)) else: break else: all_args_numeric = all_args_numeric and arg.is_number if all_args_numeric: numeric_args.append(float(arg)) else: break if len(args) != len(code_cell_function["inputDims"]) and not variable_number_of_inputs and not (zero_inputs and len(args) == 0): raise CodeCellException(f'Number of input arguments provided to code function "{name.removesuffix('_as_variable')}" ({len(args)}) differs from the number of arguments specified in the code function definition ({len(code_cell_function["inputDims"])}).') if all_args_numeric: result = implementation(*numeric_args) if isinstance(result, float) or isinstance(result, int) or isinstance(result, complex): return sympify(result) elif isinstance(result, np.ndarray): return Matrix(result) elif isinstance(result, str): if code_cell_function["outputDims"]["type"] == "scalar" and \ code_cell_function["outputDims"]["dims"]["type"] == "render": return RenderExpr(code_cell_function["outputDims"]["dims"]["renderType"], result) else: raise CodeCellException(f"The code cell function {name.removesuffix('_as_variable')} returns a string value where a numerical value is expected. Specify an output type of [text], [html], or [markdown] to render string output.") else: raise CodeCellException(f"The code cell function {name.removesuffix('_as_variable')} must return a numeric or matrix value") def fdiff(self, argindex=1): delta = sympify(1e-8) upper_args = [arg if i != argindex-1 else arg + delta for i, arg in enumerate(self.args)] return (code_cell_wrapper(*upper_args) - code_cell_wrapper(*self.args)) / delta # type: ignore code_cell_wrapper.__name__ = code_cell_function["name"] return cast(Function, code_cell_wrapper), custom_dims_func def get_code_cell_placeholder_map(code_cell_functions: list[CodeCellFunction], code_cell_result_store: dict[str, CodeCellResultCollector]) -> dict[Function, PlaceholderFunction]: new_map: dict[Function, PlaceholderFunction] = {} for code_cell_function in code_cell_functions: sympy_mode = code_cell_function["sympyMode"] match sympy_mode: case True: sympy_func, custom_dims_func, custom_dims_transform = get_code_cell_sympy_mode_wrapper(code_cell_function, code_cell_result_store) case False: sympy_func, custom_dims_func = get_code_cell_wrapper(code_cell_function, code_cell_result_store) custom_dims_transform = None dummy_var_locations: list[int] = [] for i, input_dim in enumerate(code_cell_function["inputDims"]): if input_dim["type"] == "scalar" and input_dim["dims"]["type"] == "dummy": if i == 0: error = ValueError("The dummy variable type cannot be the applied to the first function argument") code_cell_result_store[code_cell_function["name"]]["exceptions"].append(error) raise error elif len(dummy_var_locations) > 0 and dummy_var_locations[-1] < (i-1): error = ValueError("Multiple dummy variables must be consecutive") code_cell_result_store[code_cell_function["name"]]["exceptions"].append(error) raise error dummy_var_locations.append(i) if len(dummy_var_locations) > 0 and not sympy_mode: error = ValueError("Dummy variable type may only be used with SymPy mode") code_cell_result_store[code_cell_function["name"]]["exceptions"].append(error) raise error new_map[cast(Function, Function(code_cell_function["name"]))] = {"dim_func": partial(code_cell_dims_check, code_cell_function=code_cell_function, custom_dims_func=custom_dims_func), "dims_transform": custom_dims_transform, "sympy_func": sympy_func, "dims_need_values": True, "dummy_var_locations": dummy_var_locations} return new_map global_placeholder_map: dict[Function, PlaceholderFunction] = { cast(Function, Function('_StrictLessThan')) : {"dim_func": partial(ensure_all_equivalent, error_message="Piecewise cell comparison dimensions must match"), "sympy_func": StrictLessThan, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_LessThan')) : {"dim_func": partial(ensure_all_equivalent, error_message="Piecewise cell comparison dimensions must match"), "sympy_func": LessThan, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_StrictGreaterThan')) : {"dim_func": partial(ensure_all_equivalent, error_message="Piecewise cell comparison dimensions must match"), "sympy_func": StrictGreaterThan, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_GreaterThan')) : {"dim_func": partial(ensure_all_equivalent, error_message="Piecewise cell comparison dimensions must match"), "sympy_func": GreaterThan, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_And')) : {"dim_func": partial(ensure_all_equivalent, error_message="Piecewise cell comparison dimensions must match"), "sympy_func": And, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_Piecewise')) : {"dim_func": ensure_dims_all_compatible_piecewise, "sympy_func": Piecewise, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_log')) : {"dim_func": partial(ensure_all_unitless, error_message="Unitless input and base required for log and ln functions"), "sympy_func": log, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_asin')) : {"dim_func": partial(ensure_unitless_in_angle_out, func_name="arcsin"), "sympy_func": asin, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_acos')) : {"dim_func": partial(ensure_unitless_in_angle_out, func_name="arccos"), "sympy_func": acos, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_atan')) : {"dim_func": partial(ensure_unitless_in_angle_out, func_name="arctan"), "sympy_func": atan, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_asec')) : {"dim_func": partial(ensure_unitless_in_angle_out, func_name="arcsec"), "sympy_func": asec, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_acsc')) : {"dim_func": partial(ensure_unitless_in_angle_out, func_name="arcscs"), "sympy_func": acsc, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_acot')) : {"dim_func": partial(ensure_unitless_in_angle_out, func_name="arccot"), "sympy_func": acot, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_arg')) : {"dim_func": ensure_any_unit_in_angle_out, "sympy_func": arg, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_re')) : {"dim_func": ensure_any_unit_in_same_out, "sympy_func": re, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_im')) : {"dim_func": ensure_any_unit_in_same_out, "sympy_func": im, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_conjugate')) : {"dim_func": ensure_any_unit_in_same_out, "sympy_func": conjugate, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_Max')) : {"dim_func": partial(ensure_dims_all_compatible_scalar_or_matrix, func_name="max"), "sympy_func": custom_max, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_Min')) : {"dim_func": partial(ensure_dims_all_compatible_scalar_or_matrix, func_name="min"), "sympy_func": custom_min, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_sum')) : {"dim_func": partial(ensure_dims_all_compatible_scalar_or_matrix, func_name="sum"), "sympy_func": custom_sum, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_average')) : {"dim_func": partial(ensure_dims_all_compatible_scalar_or_matrix, func_name="average"), "sympy_func": custom_average, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_stdev')) : {"dim_func": partial(ensure_dims_all_compatible_scalar_or_matrix, func_name="stdev"), "sympy_func": partial(custom_stdev, False), "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_stdevp')) : {"dim_func": partial(ensure_dims_all_compatible_scalar_or_matrix, func_name="stdevp"), "sympy_func": partial(custom_stdev, True), "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_count')) : {"dim_func": custom_count, "sympy_func": custom_count, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_Abs')) : {"dim_func": ensure_any_unit_in_same_out, "sympy_func": Abs, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_Inverse')) : {"dim_func": ensure_inverse_dims, "sympy_func": UniversalInverse, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_Transpose')) : {"dim_func": custom_transpose, "sympy_func": custom_transpose, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_Determinant')) : {"dim_func": custom_determinant, "sympy_func": custom_determinant, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_mat_multiply')) : {"dim_func": partial(custom_multiply_dims, True), "sympy_func": custom_matmul, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_multiply')) : {"dim_func": partial(custom_multiply_dims, False), "sympy_func": Mul, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_IndexMatrix')) : {"dim_func": IndexMatrix_dims, "sympy_func": IndexMatrix, "dims_need_values": True, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_Eq')) : {"dim_func": Eq, "sympy_func": Eq, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_norm')) : {"dim_func": custom_norm, "sympy_func": custom_norm, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_dot')) : {"dim_func": custom_dot, "sympy_func": custom_dot, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_ceil')) : {"dim_func": partial(ensure_all_unitless, error_message="Unitless input argument required for ceil function"), "sympy_func": ceiling, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_floor')) : {"dim_func": partial(ensure_all_unitless, error_message="Unitless input argument required for floor function"), "sympy_func": floor, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_round')) : {"dim_func": partial(ensure_all_unitless, error_message="Unitless input argument required for round function"), "sympy_func": custom_round, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_Derivative')) : {"dim_func": custom_derivative_dims, "sympy_func": custom_derivative, "dims_need_values": False, "dummy_var_locations": [1], "dims_transform": None}, cast(Function, Function('_IndefiniteIntegral')) : {"dim_func": custom_indefinite_integral_dims, "sympy_func": custom_indefinite_integral, "dims_need_values": False, "dummy_var_locations": [1], "dims_transform": None}, cast(Function, Function('_Integral')) : {"dim_func": custom_integral_dims, "sympy_func": custom_integral, "dims_need_values": False, "dummy_var_locations": [3], "dims_transform": custom_integral_dims_transform}, cast(Function, Function('_range')) : {"dim_func": custom_range_dims, "sympy_func": custom_range, "dims_need_values": True, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_factorial')) : {"dim_func": factorial, "sympy_func": factorial, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_add')) : {"dim_func": custom_add_dims, "sympy_func": Add, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_Pow')) : {"dim_func": custom_pow_dims, "sympy_func": custom_pow, "dims_need_values": True, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_summation')) : {"dim_func": custom_summation_dims, "sympy_func": custom_summation, "dims_need_values": True, "dummy_var_locations": [1], "dims_transform": None}, cast(Function, Function('_product')) : {"dim_func": custom_product_dims, "sympy_func": custom_product, "dims_need_values": True, "dummy_var_locations": [1], "dims_transform": None}, cast(Function, Function('_numrows')) : {"dim_func": custom_numrows, "sympy_func": custom_numrows, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, cast(Function, Function('_numcols')) : {"dim_func": custom_numcols, "sympy_func": custom_numcols, "dims_need_values": False, "dummy_var_locations": [], "dims_transform": None}, } global_placeholder_set = set(global_placeholder_map.keys()) global_placeholder_dummy_set: set[Function] = set() for key, value in global_placeholder_map.items(): if len(value["dummy_var_locations"]) > 0: global_placeholder_dummy_set.add(key) dummy_var_placeholder_set = (Function('_Derivative'), Function('_Integral')) placeholder_inverse_map = { value["sympy_func"]: key for key, value in reversed(global_placeholder_map.items()) } placeholder_inverse_set = set(placeholder_inverse_map.keys()) class TextSymbol(Symbol): def __new__(cls, text): return Symbol.__new__(cls, "error_placeholder") def __init__(self, text): self._ep_text = text def _latex(self, printer): return f"\\text{{{self._ep_text}}}" def replace_sympy_funcs_with_placeholder_funcs(expression: Expr) -> Expr: for key, value in placeholder_inverse_map.items(): if len(expression.atoms(key)) > 0: expression = cast(Expr, expression.replace(key, value)) return expression def numerical_mode_decorator(func): def wrapper(*args, **kwargs): numerical_mode = args[0] if not numerical_mode: return func(*args, **kwargs) else: result = func(*args, **kwargs) if not is_matrix(result[0]) and result[0].is_number and not result[0].is_integer: return (result[0].evalf(PRECISION), result[1], result[2]) else: return result return wrapper @numerical_mode_decorator def replace_placeholder_funcs(numerical_mode: bool, expr: Expr, error: Exception | None, needs_dims: bool, parameter_subs: dict[Symbol, Expr], parameter_dim_subs: dict[Symbol, Expr], placeholder_map: dict[Function, PlaceholderFunction], placeholder_set: set[Function], expression_cache: dict[tuple[str, bool], tuple[Expr, Expr | None, Exception | None]], data_table_subs: DataTableSubs | None) -> tuple[Expr, Expr | None, Exception | None]: if is_matrix(expr): rows = [] dim_rows = [] for i in range(expr.rows): row = [] rows.append(row) dim_row = [] dim_rows.append(dim_row) for j in range(expr.cols): value, dim_value, error = replace_placeholder_funcs(numerical_mode, cast(Expr, expr[i,j]), error, needs_dims, parameter_subs, parameter_dim_subs, placeholder_map, placeholder_set, expression_cache, data_table_subs) row.append(value) dim_row.append(dim_value) return ( cast(Expr, Matrix(rows)), cast(Expr, Matrix(dim_rows)) if needs_dims and not error else None, error ) elif isinstance(expr, Symbol) and expr in parameter_subs: return ( parameter_subs[expr], parameter_dim_subs[expr] if needs_dims and not error else None, error ) expr = cast(Expr,expr) if expr.func in placeholder_set: dummy_var_locations = placeholder_map[cast(Function, expr.func)]["dummy_var_locations"] if len(dummy_var_locations) == 0: processed_args = [] for arg in expr.args: processed_args.append(replace_placeholder_funcs(numerical_mode, cast(Expr, arg), error, needs_dims, parameter_subs, parameter_dim_subs, placeholder_map, placeholder_set, expression_cache, data_table_subs)) error = processed_args[-1][2] result = cast(Expr, cast(Callable, placeholder_map[cast(Function, expr.func)]["sympy_func"])(*(arg[0] for arg in processed_args))) if needs_dims and not error: try: if placeholder_map[cast(Function, expr.func)]["dims_need_values"]: dim_args = [arg[0] for arg in processed_args] if data_table_subs is not None and len(data_table_subs.subs_stack) > 0: for i, value in enumerate(dim_args): dim_args[i] = cast(Expr, value.subs({key: cast(Matrix, value)[0,0] for key, value in data_table_subs.subs_stack[-1].items()})) result_snapshot = cast(Expr, cast(Callable, placeholder_map[cast(Function, expr.func)]["sympy_func"])(*dim_args)) dim_result = cast(Expr, cast(Callable, placeholder_map[cast(Function, expr.func)]["dim_func"])(*(arg[1] for arg in processed_args), dim_values=DimValues(args=dim_args, result=result_snapshot))) else: dim_result = cast(Expr, cast(Callable, placeholder_map[cast(Function, expr.func)]["dim_func"])(*(arg[1] for arg in processed_args), dim_values=DimValues(args=dim_args, result=result))) else: dim_result = cast(Expr, cast(Callable, placeholder_map[cast(Function, expr.func)]["dim_func"])(*(arg[1] for arg in processed_args))) except Exception as e: error = e dim_result = None else: dim_result = None return (result, dim_result, error) else: temp_dummy_vars = expr.args[1].args[0:len(expr.args[1].args)//2] raw_dummy_vars = expr.args[1].args[len(expr.args[1].args)//2:] dummy_vars: list[Expr] = [] for dummy_var in raw_dummy_vars: processed_dummy_var, _, error = replace_placeholder_funcs(numerical_mode, cast(Expr, dummy_var), error, False, parameter_subs, parameter_dim_subs, placeholder_map, placeholder_set, expression_cache, data_table_subs) dummy_vars.append(processed_dummy_var) value_args = expr.args[0].args dim_args = expr.args[2].args value_processed_args = [] for arg in value_args: value_processed_args.append(replace_placeholder_funcs(numerical_mode, cast(Expr, arg), error, False, parameter_subs, parameter_dim_subs, placeholder_map, placeholder_set, expression_cache, data_table_subs)) error = value_processed_args[-1][2] dim_processed_args = [] for arg in dim_args: dim_processed_args.append(replace_placeholder_funcs(numerical_mode, cast(Expr, arg), error, needs_dims, parameter_subs, parameter_dim_subs, placeholder_map, placeholder_set, expression_cache, data_table_subs)) error = dim_processed_args[-1][2] result = cast(Expr, cast(Callable, placeholder_map[cast(Function, expr.func)]["sympy_func"])(*(arg[0] for arg in value_processed_args))).doit() result = cast(Expr, result.subs(dict(zip(temp_dummy_vars, dummy_vars)))) if needs_dims and not error: try: if placeholder_map[cast(Function, expr.func)]["dims_need_values"]: dim_args = [arg[0] for arg in value_processed_args] if data_table_subs is not None and len(data_table_subs.subs_stack) > 0: for i, value in enumerate(dim_args): dim_args[i] = cast(Expr, value.subs({key: cast(Matrix, value)[0,0] for key, value in data_table_subs.subs_stack[-1].items()})) result_snapshot = cast(Expr, cast(Callable, placeholder_map[cast(Function, expr.func)]["sympy_func"])(*dim_args)) dim_result = cast(Expr, cast(Callable, placeholder_map[cast(Function, expr.func)]["dim_func"])(*(arg[1] for arg in dim_processed_args), dim_values=DimValues(args=dim_args, result=result_snapshot))) else: dim_result = cast(Expr, cast(Callable, placeholder_map[cast(Function, expr.func)]["dim_func"])(*(arg[1] for arg in dim_processed_args), dim_values=DimValues(args=dim_args, result=result))) else: dim_result = cast(Expr, cast(Callable, placeholder_map[cast(Function, expr.func)]["dim_func"])(*(arg[1] for arg in dim_processed_args))) except Exception as e: error = e dim_result = None else: dim_result = None return (result, dim_result, error) elif len(expr.args) == 0: return ( expr, expr if needs_dims and not error else None, error ) elif data_table_subs is not None and expr.func.__name__.startswith(data_table_calc_wrapper_prefix): if len(expr.args[0].atoms(data_table_id_wrapper)) == 0: return replace_placeholder_funcs(numerical_mode, cast(Expr, expr.args[0]), error, needs_dims, parameter_subs, parameter_dim_subs, placeholder_map, placeholder_set, expression_cache, data_table_subs) if (str(expr), needs_dims) in expression_cache: result = expression_cache[(str(expr), needs_dims)] return (result[0], result[1], error or result[2]) data_table_subs.subs_stack.append({}) data_table_subs.shortest_col_stack.append(None) sub_expr, dim_sub_expr, sub_error = replace_placeholder_funcs(numerical_mode, cast(Expr, expr.args[0]), None, needs_dims, parameter_subs, parameter_dim_subs, placeholder_map, placeholder_set, expression_cache, data_table_subs) error = error or sub_error subs = data_table_subs.subs_stack.pop() shortest_col = data_table_subs.shortest_col_stack.pop() if shortest_col is None: raise ValueError('Shortest column undefined for data table calculation') try: result = [] new_func = lambdify(subs.keys(), sub_expr, modules=["math", "mpmath", "sympy"]) for i in range(shortest_col): result.append([new_func(*[float(cast(Expr, cast(Matrix, value)[i,0])) for value in subs.values()]), ]) except Exception as e: result = [TextSymbol(f"Data Table Calculation Error: {e}"),] cache_result = ( cast(Expr, Matrix(result)), cast(Expr, Matrix([dim_sub_expr,]*shortest_col)) if needs_dims and not sub_error else None, sub_error ) expression_cache[(str(expr), needs_dims)] = cache_result return (cache_result[0], cache_result[1], error) elif data_table_subs is not None and expr.func == data_table_id_wrapper: current_expr, dim_current_expr, error = replace_placeholder_funcs(numerical_mode, cast(Expr, expr.args[0]), error, needs_dims, parameter_subs, parameter_dim_subs, placeholder_map, placeholder_set, expression_cache, data_table_subs) new_var = Symbol(f"_data_table_var_{data_table_subs.get_next_id()}") if not is_matrix(current_expr) or (dim_current_expr is not None and not is_matrix(dim_current_expr)): raise EmptyColumnData(str(current_expr).replace("_as_variable", "")) if len(data_table_subs.subs_stack) > 0: data_table_subs.subs_stack[-1][new_var] = cast(Expr, current_expr) if data_table_subs.shortest_col_stack[-1] is None or current_expr.rows < data_table_subs.shortest_col_stack[-1]: data_table_subs.shortest_col_stack[-1] = current_expr.rows return ( new_var, cast(Expr, dim_current_expr[0,0]) if (needs_dims and dim_current_expr is not None) else None, error ) else: processed_args = [] for arg in expr.args: processed_args.append(replace_placeholder_funcs(numerical_mode, cast(Expr, arg), error, needs_dims, parameter_subs, parameter_dim_subs, placeholder_map, placeholder_set, expression_cache, data_table_subs)) error = processed_args[-1][2] result = cast(Expr, expr.func(*(arg[0] for arg in processed_args))) if needs_dims and not error: try: dim_result = cast(Expr, expr.func(*(arg[1] for arg in processed_args))) except Exception as e: error = e dim_result = None else: dim_result = None return ( result, dim_result, error ) def custom_get_dimensional_dependencies(expression: Expr | None): if expression is not None: expression = subs_wrapper(expression, {cast(Symbol, symbol): S.One for symbol in (expression.free_symbols - dimension_symbols)}) return cast(dict[Dimension, Expr], dimsys_SI.get_dimensional_dependencies(expression)) def dimensional_analysis(dimensional_analysis_expression: Expr | None, dim_sub_error: Exception | None, custom_base_units: CustomBaseUnits | None = None): custom_units_defined = False custom_units = "" custom_units_latex = "" try: if dim_sub_error is not None: raise dim_sub_error # Finally, evaluate dimensions for complete expression result, result_latex = get_mathjs_units( cast(dict[Dimension, float], custom_get_dimensional_dependencies(dimensional_analysis_expression),), None ) if custom_base_units is not None: custom_units, custom_units_latex = get_mathjs_units( cast(dict[Dimension, float], custom_get_dimensional_dependencies(dimensional_analysis_expression),), custom_base_units ) if custom_units != result: custom_units_defined = True except TypeError as e: result = f"Dimension Error: {e}" result_latex = result return result, result_latex, custom_units_defined, custom_units, custom_units_latex class ParameterError(Exception): pass class DuplicateAssignment(Exception): pass class ReferenceCycle(Exception): pass class ParsingError(Exception): pass class NoSolutionFound(Exception): pass class OverDeterminedSystem(Exception): pass class UnderDeterminedSystem(Exception): pass class EmptyColumnData(Exception): pass class Extrapolation(Exception): pass class MatrixIndexingError(Exception): pass class CodeCellException(Exception): pass def get_sorted_statements(statements: list[Statement], custom_definition_names: list[str]): defined_params: dict[str, int] = {} for i, statement in enumerate(statements): if statement["type"] == "assignment" or statement["type"] == "local_sub": if statement["name"] in defined_params: raise DuplicateAssignment(statement["name"].removesuffix("_as_variable")) else: defined_params[statement["name"]] = i if len(custom_definition_names) > 0: for i, name in enumerate(custom_definition_names): if name in defined_params or name in custom_definition_names[i+1:]: raise DuplicateAssignment(name.removesuffix("_as_variable")) vertices = range(len(statements)) edges: list[tuple[int, int]] = [] for i, statement in enumerate(statements): if statement["type"] != "equality" and statement["type"] != "scatterQuery": for param in statement["params"]: ref_index = defined_params.get(param) if ref_index is not None: edges.append((ref_index, i)) try: sort_order = topological_sort((vertices, edges)) except ValueError: raise ReferenceCycle sorted_statements: list[Statement] = [] for i in sort_order: statement = statements[i] sorted_statements.append(statement) return sorted_statements zero_place_holder: ImplicitParameter = { "dimensions": [0]*9, "original_value": "0", "si_value": "0", "name": ZERO_PLACEHOLDER, "units": "" } def get_all_implicit_parameters(statements: Sequence[InputAndSystemStatement | EqualityStatement]): parameters: list[ImplicitParameter] = [zero_place_holder,] for statement in statements: parameters.extend(statement["implicitParams"]) return parameters def combine_variable_name_maps(statements: Sequence[InputAndSystemStatement | EqualityStatement]): variable_name_map: dict[str, str] = {} for statement in statements: variable_name_map.update(statement["variableNameMap"]) return {Symbol(key): value for key,value in variable_name_map.items()} def expand_with_sub_statements(statements: list[InputAndSystemStatement]): new_statements: list[Statement] = list(statements) local_sub_statements: dict[str, LocalSubstitutionStatement] = {} for statement in statements: new_statements.extend(statement.get("functions", [])) new_statements.extend(statement.get("arguments", [])) for local_sub in statement.get("localSubs", []): combined_sub = local_sub_statements.setdefault(local_sub["parameter"], {"type": "local_sub", "name": local_sub["parameter"], "index": 0, # placeholder, will be set in sympy_statements "params": [], "function_subs": {}, }) combined_sub["params"].append(local_sub["argument"]) function_subs = combined_sub["function_subs"] current_sub = function_subs.setdefault(local_sub["function"], {}) current_sub[symbols(local_sub["parameter"])] = symbols(local_sub["argument"]) if is_code_function_query_statement(statement) and statement["generateCode"]: new_statements.append(statement["codeFunctionRawQuery"]) if statement["type"] == "scatterQuery": new_statements.append(statement["xValuesQuery"]) new_statements.append(statement["yValuesQuery"]) new_statements.extend(local_sub_statements.values()) return new_statements def get_parameter_subs(parameters: list[ImplicitParameter], convert_floats_to_fractions: bool): # sub parameter values parameter_subs: dict[Symbol, Expr] = { symbols(param["name"]): sympify(param["si_value"], rational=convert_floats_to_fractions) # pyright: ignore[reportArgumentType] for param in parameters if param["si_value"] is not None } if len(parameter_subs) < len(parameters): raise ParameterError return parameter_subs _dummy_func = Function('_dummy_func') _dummy_vars_func = Function('_dummy_vars_func') _dummy_dims_func = Function('_dummy_dims_func') def add_dummy_subs(expr: Expr, placeholder_map: dict[Function, PlaceholderFunction], placeholder_dummy_set: set[Function]) -> Expr: if is_matrix(expr): rows = [] for i in range(expr.rows): row = [] rows.append(row) for j in range(expr.cols): value = add_dummy_subs(cast(Expr, expr[i,j]), placeholder_map, placeholder_dummy_set) row.append(value) return cast(Expr, Matrix(rows)) if len(expr.args) == 0: return expr processed_args = [add_dummy_subs(cast(Expr, arg), placeholder_map, placeholder_dummy_set) for arg in expr.args] if expr.func not in placeholder_dummy_set: return expr.func(*processed_args) else: dummy_var_locations = placeholder_map[cast(Function, expr.func)]["dummy_var_locations"] if dummy_var_locations[-1] >= len(processed_args): raise ValueError(f"Missing dummy variable for function {expr.func.__name__.removesuffix('_as_variable')}") dummy_vars = [processed_args[dummy_var_location] for dummy_var_location in dummy_var_locations] if not all((dummy_var.is_symbol for dummy_var in dummy_vars)): raise ValueError(f"Only a variable name my be used in the dummy variable position for function {expr.func.__name__.removesuffix('_as_variable'),}") else: dummy_vars = cast(list[Symbol], dummy_vars) temp_dummy_vars = [Symbol(f"{dummy_var.name}_dummy_var") for dummy_var in dummy_vars] processed_dummy_args: list[Expr] = [] for i in range(dummy_var_locations[0]): processed_dummy_args.append(Subs(processed_args[i], dummy_vars, temp_dummy_vars)) processed_dummy_args.extend(temp_dummy_vars) processed_dummy_args.extend(processed_args[dummy_var_locations[-1]+1:]) #processed_dummy_args = processed_args processed_dummy_dims_args: list[Expr] = [] if placeholder_map[cast(Function, expr.func)]["dims_transform"] is not None: processed_dummy_dims_args = placeholder_map[cast(Function, expr.func)]["dims_transform"](*processed_args) # type: ignore else: processed_dummy_dims_args = processed_args return expr.func(_dummy_func(*processed_dummy_args), _dummy_vars_func(*temp_dummy_vars, *dummy_vars), _dummy_dims_func(*processed_dummy_dims_args)) def sympify_statements(statements: list[Statement] | list[EqualityStatement], placeholder_map: dict[Function, PlaceholderFunction], placeholder_dummy_set: set[Function], convert_floats_to_fractions=True): for i, statement in enumerate(statements): statement["index"] = i if statement["type"] != "local_sub" and statement["type"] != "blank" and \ statement["type"] != "scatterQuery": try: expression: Expr = sympify(statement["sympy"], rational=convert_floats_to_fractions) # pyright: ignore[reportArgumentType] except SyntaxError: print(f"Parsing error for equation {statement['sympy']}") raise ParsingError statement["expression"] = add_dummy_subs(expression, placeholder_map, placeholder_dummy_set) def remove_implicit(input_set: set[str]) -> set[str]: return {variable for variable in input_set if not variable.startswith("implicit_param__")} def solve_system(statements: list[EqualityStatement], variables: list[str], placeholder_map: dict[Function, PlaceholderFunction], placeholder_set: set[Function], placeholder_dummy_set: set[Function], convert_floats_to_fractions: bool): parameters = get_all_implicit_parameters(statements) parameter_subs = get_parameter_subs(parameters, convert_floats_to_fractions) variable_name_map = combine_variable_name_maps(statements) sympify_statements(statements, placeholder_map, placeholder_dummy_set, convert_floats_to_fractions=convert_floats_to_fractions) # give all of the statements an index so that they can be re-ordered for i, statement in enumerate(statements): statement["index"] = i # define system of equations for sympy.solve function # substitute in all exponents and placeholder functions system_implicit_params: list[ImplicitParameter] = [] system_variables: set[str] = set() system: list[Expr] = [] for statement in statements: system_variables.update(statement["params"]) system_implicit_params.extend(statement["implicitParams"]) equality, _, _ = replace_placeholder_funcs(not convert_floats_to_fractions, cast(Expr, statement["expression"]), None, False, {}, {}, placeholder_map, placeholder_set, {}, None) system.append(cast(Expr, equality.doit())) # remove implicit parameters before solving system_variables = remove_implicit(system_variables) solutions: list[dict[Symbol, Expr]] = [] solutions = solve(system, variables, dict=True) if len(solutions) == 0: if len(statements) > len(system_variables): raise OverDeterminedSystem else: raise NoSolutionFound new_statements: list[list[SystemSolutionAssignmentStatement]] = [] for solution in solutions: current_statements: list[SystemSolutionAssignmentStatement] = [] counter = 0 for symbol, expression in solution.items(): # latex rep to display to user display_expression = custom_latex(cast(Expr, expression.subs(parameter_subs)), variable_name_map) # replace some sympy functions with placeholders for dimensional analysis expression = replace_sympy_funcs_with_placeholder_funcs(expression) current_statements.append({ "index": 0, # placeholder, will be assigned later "type": "assignment", "name": symbol.name, "sympy": str(expression), "expression": expression, "implicitParams": system_implicit_params if counter == 0 else [], # only include for one variable in solution to prevent dups "params": [variable.name for variable in cast(list[Symbol], expression.free_symbols)], "variableNameMap": {key.name: value for key, value in variable_name_map.items()} if counter == 0 else {}, "isFunction": False, "isFunctionArgument": False, "isRange": False, "isDataTableQuery": False, "isCodeFunctionQuery": False, "isCodeFunctionRawQuery": False, "isFromPlotCell": False, "display": display_expression, "displayName": custom_latex(symbol, variable_name_map), "functions": [], "arguments": [], "localSubs": [] }) counter += 1 new_statements.append(current_statements) return new_statements def solve_system_numerical(statements: list[EqualityStatement], variables: list[str], guesses: list[str], guess_statements: list[GuessAssignmentStatement], placeholder_map: dict[Function, PlaceholderFunction], placeholder_set: set[Function], placeholder_dummy_set: set[Function], convert_floats_to_fractions: bool): parameters = get_all_implicit_parameters([*statements, *guess_statements]) parameter_subs = get_parameter_subs(parameters, convert_floats_to_fractions) variable_name_map = combine_variable_name_maps(guess_statements) sympify_statements(statements, placeholder_map, placeholder_dummy_set, convert_floats_to_fractions=convert_floats_to_fractions) # give all of the statements an index so that they can be re-ordered for i, statement in enumerate(statements): statement["index"] = i # define system of equations for sympy.solve function # substitute in all exponents, implicit params, and placeholder functions # add equalityUnitsQueries to new_statements that will be added to the whole sheet system_variables: set[str] = set() system: list[Expr] = [] new_statements: list[EqualityUnitsQueryStatement | GuessAssignmentStatement] = [] for statement in statements: system_variables.update(statement["params"]) equality, _, _ = replace_placeholder_funcs(not convert_floats_to_fractions, cast(Expr, statement["expression"]), None, False, parameter_subs, {}, placeholder_map, placeholder_set, {}, None) system.append(cast(Expr, equality.doit())) new_statements.extend(statement["equalityUnitsQueries"]) # remove implicit parameters before solving system_variables = remove_implicit(system_variables) solutions: list[dict[Symbol, float]] | list[Any] = [] try: solutions = cast(list[dict[Symbol, float]] | list[Any], nsolve(system, variables, guesses, dict=True)) except Exception as e: if (len(system_variables) > len(variables)) or (len(variables) > len(system)): raise UnderDeterminedSystem elif (len(system) > len(variables)) or (len(system) > len(system_variables)): raise OverDeterminedSystem else: raise e if len(solutions) == 0: if len(statements) > len(system_variables): raise OverDeterminedSystem else: raise NoSolutionFound display_solutions: dict[str, list[str]] = {} implicit_params_to_update: dict[str, float] = {} first_solution = solutions[0] if isinstance(first_solution, dict): for symbol, value in cast(dict[Symbol, float], first_solution).items(): display_solutions[custom_latex(sympify(symbol), variable_name_map)] = [f"{float(value):.12g}"] for guess_statement in guess_statements: if symbol == guess_statement["name"]: if guess_statement["sympy"].startswith("implicit_param__"): implicit_params_to_update[guess_statement["sympy"]] = value else: guess_statement["sympy"] = str(value) new_statements.append(guess_statement) break else: raise NoSolutionFound # update implicit parameters with solve solution (they currently hold the guess values) for parameter in parameters: if parameter["name"] in implicit_params_to_update: parameter["si_value"] = str(implicit_params_to_update[parameter["name"]]) # remove zero placeholder to prevent duplicates parameters = [parameter for parameter in parameters if parameter["name"] != ZERO_PLACEHOLDER] # can only have implicit params in one place or there will be duplicates for i, statement in enumerate(new_statements): if i == 0: statement["implicitParams"] = parameters else: statement["implicitParams"] = [] return [new_statements], display_solutions def get_range_result(range_result: CombinedExpressionRange, range_dependencies: dict[str, Result | FiniteImagResult | MatrixResult], num_points: int, variable_name_map: dict[Symbol, str]) -> PlotResult: # check that upper and lower limits of range input are real and finite # and that units match lower_limit_result = range_dependencies[range_result["lowerLimitArgument"]] lower_limit_inclusive = range_result["lowerLimitInclusive"] upper_limit_result = range_dependencies[range_result["upperLimitArgument"]] upper_limit_inclusive = range_result["upperLimitInclusive"] units_result = range_dependencies[range_result["unitsQueryFunction"]] log_x = range_result["logX"] if ( (not is_not_matrix_result(lower_limit_result)) or (not is_not_matrix_result(upper_limit_result)) ): return {"plot": True, "data": [{"isScatter": False, "numericOutput": False, "numericInput": False, "limitsUnitsMatch": True, "input": [], "output": [], "inputReversed": False, "inputUnits": "", "inputUnitsLatex": "", "negLogLimit": False, "inputCustomUnitsDefined": False, "inputCustomUnits": "", "inputCustomUnitsLatex": "", "inputName": "", "inputNameLatex": "", "outputUnits": "", "outputUnitsLatex": "", "outputCustomUnitsDefined": False, "outputCustomUnits": "", "outputCustomUnitsLatex": "", "outputName": "", "outputNameLatex": "", "isParametric": range_result["isParametric"]}] } if not is_not_matrix_result(units_result): return {"plot": True, "data": [{"isScatter": False, "numericOutput": False, "numericInput": True, "limitsUnitsMatch": True, "input": [], "output": [], "inputReversed": False, "inputUnits": "", "inputUnitsLatex": "", "negLogLimit": False, "inputCustomUnitsDefined": False, "inputCustomUnits": "", "inputCustomUnitsLatex": "", "inputName": "", "inputNameLatex": "", "outputUnits": "", "outputUnitsLatex": "", "outputCustomUnitsDefined": False, "outputCustomUnits": "", "outputCustomUnitsLatex": "", "outputName": "", "outputNameLatex": "", "isParametric": range_result["isParametric"]}] } if not all(map(lambda value: value["numeric"] and value["real"] and value["finite"], [lower_limit_result, upper_limit_result])): return {"plot": True, "data": [{"isScatter": False, "numericOutput": False, "numericInput": False, "limitsUnitsMatch": False, "input": [], "output": [], "inputReversed": False, "inputUnits": "", "inputUnitsLatex": "", "negLogLimit": False, "inputCustomUnitsDefined": False, "inputCustomUnits": "", "inputCustomUnitsLatex": "", "inputName": "", "inputNameLatex": "", "outputUnits": "", "outputUnitsLatex": "", "outputCustomUnitsDefined": False, "outputCustomUnits": "", "outputCustomUnitsLatex": "", "outputName": "", "outputNameLatex": "", "isParametric": range_result["isParametric"]}] } if lower_limit_result["units"] != upper_limit_result["units"]: return {"plot": True, "data": [{"isScatter": False, "numericOutput": False, "numericInput": True, "limitsUnitsMatch": False, "input": [], "output": [], "inputReversed": False, "inputUnits": "", "inputUnitsLatex": "", "negLogLimit": False, "inputCustomUnitsDefined": False, "inputCustomUnits": "", "inputCustomUnitsLatex": "", "inputName": "", "inputNameLatex": "", "outputUnits": "", "outputUnitsLatex": "", "outputCustomUnitsDefined": False, "outputCustomUnits": "", "outputCustomUnitsLatex": "", "outputName": "", "outputNameLatex": "", "isParametric": range_result["isParametric"]}] } lower_limit = float(lower_limit_result["value"]) upper_limit = float(upper_limit_result["value"]) neg_log_limit = False if log_x: if lower_limit <= 0.0 or upper_limit <= 0.0: neg_log_limit = True log_x = False else: lower_limit = math.log10(lower_limit) upper_limit = math.log10(upper_limit) input_reversed = True if lower_limit > upper_limit else False input_range = upper_limit - lower_limit if not lower_limit_inclusive: lower_limit = lower_limit + (input_range)*.025 if not upper_limit_inclusive: upper_limit = upper_limit - (input_range)*.025 input_values = [lower_limit,] delta = (upper_limit - lower_limit)/(num_points-1) for i in range(num_points-2): input_values.append(input_values[-1] + delta) input_values.append(upper_limit) if log_x: input_values = [10**value for value in input_values] lambda_error = False range_function = None try: range_function = lambdify(range_result["freeParameter"], range_result["expression"], modules=["math", "mpmath", "sympy"]) except Exception: lambda_error = True output_values: list[float] = [] if not lambda_error and range_function is not None: try: for input in input_values: output_values.append(float(range_function(input))) except Exception: lambda_error = True if lambda_error or len(output_values) == 0 or \ not all(map(lambda value: isinstance(value, numbers.Number) and not math.isinf(value), output_values)): return {"plot": True, "data": [{"isScatter": False, "numericOutput": False, "numericInput": True, "limitsUnitsMatch": True, "input": input_values, "output": [], "inputReversed": input_reversed, "inputUnits": "", "inputUnitsLatex": "", "negLogLimit": neg_log_limit, "inputCustomUnitsDefined": False, "inputCustomUnits": "", "inputCustomUnitsLatex": "", "inputName": range_result["freeParameter"].removesuffix('_as_variable'), "inputNameLatex": custom_latex(sympify(range_result["freeParameter"]), variable_name_map), "outputUnits": "", "outputUnitsLatex": "", "outputCustomUnitsDefined": False, "outputCustomUnits": "", "outputCustomUnitsLatex": "", "outputName": range_result["outputName"].removesuffix('_as_variable'), "outputNameLatex": custom_latex(sympify(range_result["outputName"]), variable_name_map), "isParametric": range_result["isParametric"] }] } return {"plot": True, "data": [{"isScatter": False, "numericOutput": True, "numericInput": True, "limitsUnitsMatch": True, "input": input_values, "output": output_values, "inputReversed": input_reversed, "inputUnits": lower_limit_result["units"], "inputUnitsLatex": lower_limit_result["unitsLatex"], "inputCustomUnitsDefined": lower_limit_result["customUnitsDefined"], "inputCustomUnits": lower_limit_result["customUnits"], "negLogLimit": neg_log_limit, "inputCustomUnitsLatex": lower_limit_result["customUnitsLatex"], "inputName": range_result["freeParameter"].removesuffix('_as_variable'), "inputNameLatex": custom_latex(sympify(range_result["freeParameter"]), variable_name_map), "outputUnits": units_result["units"], "outputUnitsLatex": units_result["unitsLatex"], "outputCustomUnitsDefined": units_result["customUnitsDefined"], "outputCustomUnits": units_result["customUnits"], "outputCustomUnitsLatex": units_result["customUnitsLatex"], "outputName": range_result["outputName"].removesuffix('_as_variable'), "outputNameLatex": custom_latex(sympify(range_result["outputName"]), variable_name_map), "isParametric": range_result["isParametric"]}] } def get_scatter_error_object(error_message: str) -> PlotResult: return {"plot": True, "data": [{"isScatter": True, "numericOutput": False, "numericInput": True, "limitsUnitsMatch": True, "input": [], "output": [], "inputReversed": False, "inputUnits": "", "inputUnitsLatex": "", "negLogLimit": False, "inputCustomUnitsDefined": False, "inputCustomUnits": "", "inputCustomUnitsLatex": "", "inputName": "", "inputNameLatex": "", "outputUnits": "", "outputUnitsLatex": "", "outputCustomUnitsDefined": False, "outputCustomUnits": "", "outputCustomUnitsLatex": "", "outputName": "", "outputNameLatex": "", "scatterErrorMessage": error_message, "isParametric": False}] } def get_scatter_plot_result(combined_scatter: CombinedExpressionScatter, scatter_x_values: Result | FiniteImagResult | MatrixResult, scatter_y_values: Result | FiniteImagResult | MatrixResult, scatter_id: int, variable_name_map: dict[Symbol, str]) -> PlotResult: x_name = combined_scatter["xName"] if x_name == "ScatterPlaceholderX": x_name = f"x{scatter_id}" y_name = combined_scatter["yName"] if y_name == "ScatterPlaceholderY": y_name = f"y{scatter_id}" if (is_not_matrix_result(scatter_x_values) and (is_matrix_result(scatter_y_values))) or \ (is_not_matrix_result(scatter_y_values) and (is_matrix_result(scatter_x_values))): return get_scatter_error_object("Both the x and y values need to be a scalar value or a vector") if (is_matrix_result(scatter_x_values)) and (is_matrix_result(scatter_y_values)): x_num_rows = len(scatter_x_values["results"]) x_num_cols = len(scatter_x_values["results"][0]) y_num_rows = len(scatter_y_values["results"]) y_num_cols = len(scatter_y_values["results"][0]) x_len = max(x_num_rows, x_num_cols) y_len = max(y_num_rows, y_num_cols) if (x_num_rows != 1 and x_num_cols != 1) or (y_num_rows != 1 and y_num_cols != 1) or \ (x_len != y_len): return get_scatter_error_object("Both the x and y values need to be either column or row vectors of the same size") x_values: list[float] = [] x_values_all_real_and_finite = True x_units_check: set[str] = set() x_units_latex = scatter_x_values["results"][0][0]["unitsLatex"] x_units_custom_units_defined = scatter_x_values["results"][0][0]["customUnitsDefined"] x_units_custom_units = scatter_x_values["results"][0][0]["customUnits"] x_units_custom_units_latex = scatter_x_values["results"][0][0]["customUnitsLatex"] for row in scatter_x_values["results"]: for col in row: x_units_check.add(col["units"]) if not is_real_and_finite(col): x_values_all_real_and_finite = False else: x_values.append(float(col["value"])) if not x_values_all_real_and_finite: return get_scatter_error_object("One or more x values does not evaluate to a finite real value") if len(x_units_check) > 1 or "Dimension Error" in x_units_check: return get_scatter_error_object("One or more of the x values has inconsistent units or a dimension error") y_values: list[float] = [] y_values_all_real_and_finite = True y_units_check: set[str] = set() y_units_latex = scatter_y_values["results"][0][0]["unitsLatex"] y_units_custom_units_defined = scatter_y_values["results"][0][0]["customUnitsDefined"] y_units_custom_units = scatter_y_values["results"][0][0]["customUnits"] y_units_custom_units_latex = scatter_y_values["results"][0][0]["customUnitsLatex"] for row in scatter_y_values["results"]: for col in row: y_units_check.add(col["units"]) y_units_latex = col["unitsLatex"] if not is_real_and_finite(col): y_values_all_real_and_finite = False else: y_values.append(float(col["value"])) if not y_values_all_real_and_finite: return get_scatter_error_object("One or more y values does not evaluate to a finite real value") if len(y_units_check) > 1 or "Dimension Error" in y_units_check: return get_scatter_error_object("One or more of the y values has inconsistent units or a dimension error") return {"plot": True, "data": [{"isScatter": True, "asLines": combined_scatter["asLines"], "numericOutput": True, "numericInput": True, "negLogLimit": False, "limitsUnitsMatch": True, "input": x_values, "output": y_values, "inputReversed": False, "inputUnits": next(iter(x_units_check)), "inputUnitsLatex": x_units_latex, "inputCustomUnitsDefined": x_units_custom_units_defined, "inputCustomUnits": x_units_custom_units, "inputCustomUnitsLatex": x_units_custom_units_latex, "inputName": x_name.removesuffix('_as_variable'), "inputNameLatex": custom_latex(sympify(x_name), variable_name_map), "outputUnits": next(iter(y_units_check)), "outputUnitsLatex": y_units_latex, "outputCustomUnitsDefined": y_units_custom_units_defined, "outputCustomUnits": y_units_custom_units, "outputCustomUnitsLatex": y_units_custom_units_latex, "outputName": y_name.removesuffix('_as_variable'), "outputNameLatex": custom_latex(sympify(y_name), variable_name_map), "isParametric": False }] } # Finally, handle case where both values are scalers if not is_real_and_finite(cast(Result | FiniteImagResult, scatter_x_values)): return get_scatter_error_object("x value does not evaluate to a finite real value") if "Dimension Error" in cast(Result, scatter_x_values)["units"]: return get_scatter_error_object("x value dimension error") x_values = [float(cast(Result, scatter_x_values)["value"])] x_units = cast(Result, scatter_x_values)["units"] x_units_latex = cast(Result, scatter_x_values)["unitsLatex"] x_units_custom_units_defined = cast(Result, scatter_x_values)["customUnitsDefined"] x_units_custom_units = cast(Result, scatter_x_values)["customUnits"] x_units_custom_units_latex = cast(Result, scatter_x_values)["customUnitsLatex"] if not is_real_and_finite(cast(Result | FiniteImagResult, scatter_y_values)): return get_scatter_error_object("y value does not evaluate to a finite real value") if "Dimension Error" in cast(Result, scatter_y_values)["units"]: return get_scatter_error_object("y value dimension error") y_values = [float(cast(Result, scatter_y_values)["value"])] y_units = cast(Result, scatter_y_values)["units"] y_units_latex = cast(Result, scatter_y_values)["unitsLatex"] y_units_custom_units_defined = cast(Result, scatter_y_values)["customUnitsDefined"] y_units_custom_units = cast(Result, scatter_y_values)["customUnits"] y_units_custom_units_latex = cast(Result, scatter_y_values)["customUnitsLatex"] return {"plot": True, "data": [{"isScatter": True, "asLines": combined_scatter["asLines"], "numericOutput": True, "numericInput": True, "negLogLimit": False, "limitsUnitsMatch": True, "input": x_values, "output": y_values, "inputReversed": False, "inputUnits": x_units, "inputUnitsLatex": x_units_latex, "inputCustomUnitsDefined": x_units_custom_units_defined, "inputCustomUnits": x_units_custom_units, "inputCustomUnitsLatex": x_units_custom_units_latex, "inputName": x_name.removesuffix('_as_variable'), "inputNameLatex": custom_latex(sympify(x_name), variable_name_map), "outputUnits": y_units, "outputUnitsLatex": y_units_latex, "outputCustomUnitsDefined": y_units_custom_units_defined, "outputCustomUnits": y_units_custom_units, "outputCustomUnitsLatex": y_units_custom_units_latex, "outputName": y_name.removesuffix('_as_variable'), "outputNameLatex": custom_latex(sympify(y_name), variable_name_map), "isParametric": False }] } def combine_plot_and_table_data_results(results: list[Result | FiniteImagResult | PlotResult | MatrixResult | RenderResult ], statement_plot_info: list[StatementPlotInfo], statement_data_table_info: list[StatementDataTableInfo]): final_results: list[Result | FiniteImagResult | list[PlotResult] | MatrixResult | DataTableResult | RenderResult] = [] plot_cell_id = "unassigned" data_table_cell_id = "unassigned" previous_plot_data: PlotData | Literal[None] = None parametric_counter = 1 for index, result in enumerate(results): if not statement_plot_info[index]["isFromPlotCell"] and not statement_data_table_info[index]["isFromDataTableCell"]: final_results.append(cast(Result | FiniteImagResult, result)) plot_cell_id = "unassigned" data_table_cell_id = "unassigned" previous_plot_data = None elif statement_plot_info[index]["cellNum"] == plot_cell_id: current_plot_data = cast(PlotResult, result)["data"][0] if previous_plot_data is not None and \ (current_plot_data["isParametric"] and previous_plot_data["isParametric"]): combine_parametric_plot_data_into_y(previous_plot_data, current_plot_data, parametric_counter) parametric_counter += 1 previous_plot_data = None else: cast(list[PlotResult], final_results[-1]).append(cast(PlotResult, result)) previous_plot_data = current_plot_data elif statement_data_table_info[index]["cellNum"] == data_table_cell_id: if is_matrix_result(result): cast(DataTableResult, final_results[-1])["colData"][statement_data_table_info[index]["colId"]] = result else: cast(DataTableResult, final_results[-1])["colData"][statement_data_table_info[index]["colId"]] = \ {"matrixResult": True, "results": [[cast( Result | FiniteImagResult, result)],], "isSubResult": False, "subQueryName": ""} elif statement_plot_info[index]["isFromPlotCell"]: final_results.append([cast(PlotResult, result),]) plot_cell_id = statement_plot_info[index]["cellNum"] data_table_cell_id = "undefined" previous_plot_data = cast(PlotResult, result)["data"][0] else: if is_matrix_result(result): final_results.append({"dataTableResult": True, "colData": {statement_data_table_info[index]["colId"]: result}}) else: final_results.append({ "dataTableResult": True, "colData": { statement_data_table_info[index]["colId"]: { "matrixResult": True, "results": [[cast( Result | FiniteImagResult, result)],], "isSubResult": False, "subQueryName": "" } } }) data_table_cell_id = statement_data_table_info[index]["cellNum"] plot_cell_id = "undefined" return final_results def combine_parametric_plot_data_into_y(y_plot_data: PlotData, x_plot_data: PlotData, counter: int): parametric_error = "" if not y_plot_data["numericInput"]: parametric_error = "Upper and/or lower limits do not evaluate to a number" elif not y_plot_data["limitsUnitsMatch"]: parametric_error = "Units of the upper and lower limits do not match" elif not x_plot_data["numericOutput"]: parametric_error = "Results of expression does not evaluate to finite and real numeric values" y_plot_data["numericInput"] = x_plot_data["numericOutput"] y_plot_data["input"] = x_plot_data["output"] y_plot_data["inputUnits"] = x_plot_data["outputUnits"] y_plot_data["inputUnitsLatex"] = x_plot_data["outputUnitsLatex"] y_plot_data["inputCustomUnitsDefined"] = x_plot_data["outputCustomUnitsDefined"] y_plot_data["inputCustomUnits"] = x_plot_data["outputCustomUnits"] y_plot_data["inputCustomUnitsLatex"] = x_plot_data["outputCustomUnitsLatex"] y_plot_data["inputName"] = x_plot_data["outputName"] y_plot_data["inputNameLatex"] = x_plot_data["outputNameLatex"] if y_plot_data["outputName"].startswith("ParametricPlaceholderY"): y_plot_data["outputName"] = f"y_{counter}({x_plot_data['inputName']})" y_plot_data["outputNameLatex"] = f"y_{{{counter}}} \\left({x_plot_data['inputNameLatex']} \\right)" if y_plot_data["inputName"].startswith("ParametricPlaceholderX"): y_plot_data["inputName"] = f"x_{counter}({x_plot_data['inputName']})" y_plot_data["inputNameLatex"] = f"x_{{{counter}}} \\left({x_plot_data['inputNameLatex']} \\right)" y_plot_data["parametricErrorMessage"] = parametric_error def subs_wrapper(expression: Expr, subs: dict[str, str] | dict[str, Expr | float] | dict[Symbol, Symbol]) -> Expr: if len(expression.atoms(Subs)) > 0: # must use slower subs when substituting parameters that may be in a integral or derivative # subs automatically delays substitution by wrapping integral or derivative in a subs function return cast(Expr, expression.subs(subs)) else: # can safely use much faster xreplace when there are no integrals or derivatives return cast(Expr, expression.xreplace(subs)) def get_evaluated_expression(expression: Expr, numerical_mode: bool, parameter_subs: dict[Symbol, Expr], dim_subs: dict[Symbol, Expr], placeholder_map: dict[Function, PlaceholderFunction], placeholder_set: set[Function], expression_cache: dict[tuple[str, bool], tuple[Expr, Expr | None, Exception | None]], variable_name_map: dict[Symbol, str]) -> tuple[ExprWithAssumptions, Expr | Matrix, Expr | None, Exception | None]: expression, dim_expression, error = replace_placeholder_funcs(numerical_mode, expression, None, True, parameter_subs, dim_subs, placeholder_map, placeholder_set, expression_cache, DataTableSubs()) evaluated_expression = cast(ExprWithAssumptions, expression.evalf(PRECISION)) return evaluated_expression, expression, dim_expression, error def get_result(evaluated_expression: ExprWithAssumptions, dimensional_analysis_expression: Expr | None, simplify_symbolic_expressions: bool, dim_sub_error: Exception | None, symbolic_expression: Expr, isRange: bool, custom_base_units: CustomBaseUnits | None, isSubQuery: bool, subQueryName: str, variable_name_map: dict[Symbol, str] ) -> Result | FiniteImagResult | RenderResult: custom_units_defined = False custom_units = "" custom_units_latex = "" if isRange: # a separate unitsQuery function is used for plots, no need to perform dimensional analysis before subs are made dim = "" dim_latex = "" else: dim, dim_latex, custom_units_defined, custom_units, custom_units_latex = dimensional_analysis(dimensional_analysis_expression, dim_sub_error, custom_base_units) if evaluated_expression.is_number: if evaluated_expression.is_real and evaluated_expression.is_finite: result = Result(value=str(evaluated_expression), symbolicValue=custom_latex(symbolic_expression, variable_name_map), numeric=True, units=dim, unitsLatex=dim_latex, real=True, finite=True, customUnitsDefined=custom_units_defined, customUnits=custom_units, customUnitsLatex=custom_units_latex, isSubResult=isSubQuery, subQueryName=subQueryName) elif not evaluated_expression.is_finite: result = Result(value=custom_latex(evaluated_expression, variable_name_map), symbolicValue=custom_latex(symbolic_expression, variable_name_map), numeric=True, units=dim, unitsLatex=dim_latex, real=cast(bool, evaluated_expression.is_real), finite=False, customUnitsDefined=custom_units_defined, customUnits=custom_units, customUnitsLatex=custom_units_latex, isSubResult=isSubQuery, subQueryName=subQueryName) else: result = FiniteImagResult(value=str(evaluated_expression).replace('I', 'i').replace('*', ''), symbolicValue=custom_latex(symbolic_expression, variable_name_map), numeric=True, units=dim, unitsLatex=dim_latex, real=False, realPart=str(re(evaluated_expression)), imagPart=str(im(evaluated_expression)), finite=evaluated_expression.is_finite, customUnitsDefined=custom_units_defined, customUnits=custom_units, customUnitsLatex=custom_units_latex, isSubResult=isSubQuery, subQueryName=subQueryName) elif hasattr(evaluated_expression, "render_type"): result = RenderResult(renderResult=True, type=getattr(evaluated_expression, "render_type"), value=getattr(evaluated_expression, "render_value", ""), dimensionError=dim if "Dimension Error" in dim else "") else: if simplify_symbolic_expressions: try: symbolic_expression = cancel(symbolic_expression) except ValueError as e: pass result = Result(value=custom_latex(evaluated_expression, variable_name_map), symbolicValue=custom_latex(symbolic_expression, variable_name_map), numeric=False, units="", unitsLatex="", real=False, finite=False, customUnitsDefined=False, customUnits="", customUnitsLatex="", isSubResult=isSubQuery, subQueryName=subQueryName) return result def get_hashable_matrix_units(matrix_result: MatrixResult) -> tuple[tuple[str, ...], ...]: rows: list[tuple[str, ...]] = [] for result_row in matrix_result["results"]: row = [] for result in result_row: row.append(result["units"]) rows.append(tuple(row)) return tuple(rows) def evaluate_statements(statements: list[InputAndSystemStatement], custom_base_units: CustomBaseUnits | None, simplify_symbolic_expressions: bool, convert_floats_to_fractions: bool, placeholder_map: dict[Function, PlaceholderFunction], placeholder_set: set[Function], placeholder_dummy_set: set[Function], custom_definition_names: list[str]) -> tuple[list[Result | FiniteImagResult | list[PlotResult] | MatrixResult | DataTableResult | RenderResult], dict[int,bool]]: num_statements = len(statements) if num_statements == 0: return [], {} statement_plot_info: list[StatementPlotInfo] = [{"isFromPlotCell": statement["isFromPlotCell"], "cellNum": statement.get("cellNum", -1)} for statement in statements] statement_data_table_info: list[StatementDataTableInfo] = [{"isFromDataTableCell": statement.get("isDataTableQuery", False), "cellNum": statement.get("cellNum", -1), "colId": statement.get("colId", -1)} for statement in statements] parameters = get_all_implicit_parameters(statements) variable_name_map = combine_variable_name_maps(statements) parameter_subs = get_parameter_subs(parameters, convert_floats_to_fractions) dimensional_analysis_subs: dict[Symbol, Expr] = { symbols(param["name"]): get_dims(param["dimensions"]) for param in parameters } expanded_statements: list[Statement] = expand_with_sub_statements(statements) sympify_statements(expanded_statements, placeholder_map, placeholder_dummy_set, convert_floats_to_fractions=convert_floats_to_fractions) expanded_statements = get_sorted_statements(expanded_statements, custom_definition_names) combined_expressions: list[CombinedExpression] = [] for i, statement in enumerate(expanded_statements): if statement["type"] == "local_sub" or statement["type"] == "blank": continue if statement["type"] == "assignment" and not statement.get("isFunction", False): combined_expressions.append({"index": statement["index"], "isBlank": True, "isRange": False, "isScatter": False, "isSubQuery": False, "subQueryName": ""}) continue if statement["type"] == "scatterQuery": combined_expressions.append({ "index": statement["index"], "equationIndex": statement["equationIndex"], "isBlank": False, "isRange": False, "isScatter": True, "asLines": statement["asLines"], "xName": statement["xName"], "yName": statement["yName"], "isSubQuery": False, "subQueryName": "" }) continue temp_statements = expanded_statements[0: i + 1] # sub equations into each other in topological order if there are more than one function_name = "" if statement["isFunction"] is True: is_function = True function_name = statement["name"] else: is_function = False final_expression = statement["expression"] for sub_statement in reversed(temp_statements[0:-1]): if (sub_statement["type"] == "assignment" or (is_function and sub_statement["type"] == "local_sub")): if sub_statement["type"] == "local_sub": if is_function: current_local_subs = sub_statement["function_subs"].get(function_name, {}) if len(current_local_subs) > 0: final_expression = subs_wrapper(final_expression, current_local_subs) else: if sub_statement["name"] in map(lambda x: str(x), final_expression.free_symbols): final_expression = subs_wrapper(final_expression, {symbols(sub_statement["name"]): sub_statement["expression"]}) if is_function: statement["expression"] = final_expression elif statement["type"] == "query": if statement["isRange"] is not True: current_combined_expression: CombinedExpression = {"index": statement["index"], "expression": final_expression, "isBlank": False, "isRange": False, "isScatter": False, "isCodeFunctionQuery": statement["isCodeFunctionQuery"] and statement.get("generateCode", False), "isCodeFunctionRawQuery": statement["isCodeFunctionRawQuery"], "isFunctionArgument": statement["isFunctionArgument"], "isUnitsQuery": statement.get("isUnitsQuery", False), "isEqualityUnitsQuery": statement.get("isEqualityUnitsQuery", False), "isScatterXValuesQuery": statement.get("isScatterXValuesQueryStatement", False), "isScatterYValuesQuery": statement.get("isScatterYValuesQueryStatement", False), "equationIndex": statement.get("equationIndex", 0), "name": "", "isSubQuery": statement.get("isSubQuery", False), "subQueryName": statement["sympy"] } else: current_combined_expression: CombinedExpression = {"index": statement["index"], "expression": final_expression, "isBlank": False, "isRange": True, "isParametric": statement.get("isParametric", False), "isScatter": False, "isCodeFunctionQuery": False, "isCodeFunctionRawQuery": False, "isFunctionArgument": statement["isFunctionArgument"], "isUnitsQuery": statement.get("isUnitsQuery", False), "isEqualityUnitsQuery": statement.get("isEqualityUnitsQuery", False), "equationIndex": statement.get("equationIndex", 0), "name": "", "numPoints": statement["numPoints"], "freeParameter": statement["freeParameter"], "outputName": statement["outputName"], "lowerLimitArgument": statement["lowerLimitArgument"], "upperLimitArgument": statement["upperLimitArgument"], "lowerLimitInclusive": statement["lowerLimitInclusive"], "upperLimitInclusive": statement["upperLimitInclusive"], "logX": statement["logX"], "unitsQueryFunction": statement["unitsQueryFunction"], "isSubQuery": False, "subQueryName": "" } if statement["isFunctionArgument"] is True: current_combined_expression["name"] = statement["name"] if current_combined_expression["isUnitsQuery"] or \ current_combined_expression["isCodeFunctionRawQuery"]: current_combined_expression["name"] = statement["sympy"] if current_combined_expression["isCodeFunctionQuery"]: current_combined_expression["name"] = statement.get("functionName", "") combined_expressions.append(current_combined_expression) range_dependencies: dict[str, Result | FiniteImagResult | MatrixResult] = {} range_results: dict[int, CombinedExpressionRange] = {} numerical_system_cell_units: dict[int, list[str | tuple[tuple[str, ...], ...]] ] = {} code_func_raw_results: dict[str, CombinedExpressionNoRange] = {} code_func_results: list[tuple[str, Result | FiniteImagResult | MatrixResult]] = [] scatter_combined_expressions: dict[int, CombinedExpressionScatter] = {} scatter_x_values: dict[int, Result | FiniteImagResult | MatrixResult] = {} scatter_y_values: dict[int, Result | FiniteImagResult | MatrixResult] = {} largest_index = max( [statement["index"] for statement in expanded_statements]) results: list[Result | FiniteImagResult | MatrixResult | PlotResult | RenderResult] = [{"value": "", "symbolicValue": "", "units": "", "unitsLatex": "", "numeric": False, "customUnitsDefined": False, "customUnits": "", "customUnitsLatex": "", "real": False, "finite": False, "isSubResult": False, "subQueryName": ""}]*(largest_index+1) expression_cache: dict[tuple[str, bool], tuple[Expr, Expr | None, Exception | None]] = {} for item in combined_expressions: index = item["index"] if item["isBlank"] is True: continue elif item["isScatter"] is True: scatter_combined_expressions[item["equationIndex"]] = item else: expression = cast(Expr, item["expression"].doit()) evaluated_expression, symbolic_expression, dimensional_analysis_expression, dim_sub_error = get_evaluated_expression(expression, not convert_floats_to_fractions, parameter_subs, dimensional_analysis_subs, placeholder_map, placeholder_set, expression_cache, variable_name_map) if not is_matrix(evaluated_expression): results[index] = get_result(evaluated_expression, dimensional_analysis_expression, simplify_symbolic_expressions, dim_sub_error, cast(Expr, symbolic_expression), item["isRange"], custom_base_units, item["isSubQuery"], item["subQueryName"], variable_name_map) elif is_matrix(evaluated_expression) and (dimensional_analysis_expression is None or \ is_matrix(dimensional_analysis_expression)) and is_matrix(symbolic_expression) : if dimensional_analysis_expression is not None and ( evaluated_expression.rows != dimensional_analysis_expression.rows and evaluated_expression.cols != dimensional_analysis_expression.cols ): Exception("Internal Error: Dimension matrix size does not match result matrix size. Report error to support@engineeringpaper.xyz") matrix_results = [] for i in range(evaluated_expression.rows): current_row = [] matrix_results.append(current_row) for j in range(evaluated_expression.cols): if dimensional_analysis_expression is None: current_dimensional_analysis_expression = None else: current_dimensional_analysis_expression = dimensional_analysis_expression[i,j] current_result = get_result(cast(ExprWithAssumptions, evaluated_expression[i,j]), cast(Expr, current_dimensional_analysis_expression), simplify_symbolic_expressions, dim_sub_error, cast(Expr, symbolic_expression[i,j]), item["isRange"], custom_base_units, item["isSubQuery"], item["subQueryName"], variable_name_map) current_row.append(current_result) results[index] = MatrixResult(matrixResult=True, results=matrix_results, isSubResult=item["isSubQuery"], subQueryName=item["subQueryName"]) else: raise Exception("Internal Error: Dimension or symbolic result not a Matrix for an evaluated expression that is a Matrix. Report error to support@engineeringpaper.xyz") if item["isRange"] is True: current_result = item current_result["expression"] = cast(Expr, evaluated_expression) range_results[index] = current_result elif item["isScatterXValuesQuery"]: scatter_x_values[item["equationIndex"]] = cast(Result | FiniteImagResult | MatrixResult, results[index]) elif item["isScatterYValuesQuery"]: scatter_y_values[item["equationIndex"]] = cast(Result | FiniteImagResult | MatrixResult, results[index]) if item["isFunctionArgument"] or item["isUnitsQuery"]: range_dependencies[item["name"]] = cast(Result | FiniteImagResult | MatrixResult, results[index]) if item["isCodeFunctionRawQuery"]: current_result = item current_result["expression"] = cast(Expr, evaluated_expression) code_func_raw_results[item["name"]] = cast(CombinedExpressionNoRange, current_result) if item["isCodeFunctionQuery"]: code_func_results.append(( item["name"], cast(Result | FiniteImagResult | MatrixResult, results[index]) )) if item["isEqualityUnitsQuery"]: units_list = numerical_system_cell_units.setdefault(item["equationIndex"], []) current_result = cast(Result | FiniteImagResult | MatrixResult, results[index]) if is_not_matrix_result(current_result): units_list.append(current_result["units"]) else: units_list.append(get_hashable_matrix_units(cast(MatrixResult, current_result))) numerical_system_cell_unit_errors: dict[int, bool] = {} for equation_index, units in numerical_system_cell_units.items(): # set should have length of 1 if there is no error (LHS and RHS are the same and there isn't an error) units = set(units) if len(units) == 1: if "Dimension Error" not in units: error = False else: error = True else: error = True numerical_system_cell_unit_errors[equation_index] = error results_with_ranges = results for index,range_result in range_results.items(): results_with_ranges[index] = get_range_result(range_result, range_dependencies, range_result["numPoints"], variable_name_map) scatter_id = 1 for equation_index, combined_scatter in scatter_combined_expressions.items(): results_with_ranges[combined_scatter["index"]] = get_scatter_plot_result(combined_scatter, scatter_x_values[equation_index], scatter_y_values[equation_index], scatter_id, variable_name_map) scatter_id += 1 for (name, result) in code_func_results: try: generatedCode = NumPyPrinter().doprint(code_func_raw_results[name]["expression"]) except Exception as err: generatedCode = f"# Error generating code: {type(err).__name__}, {err}" if not isinstance(generatedCode, str): generatedCode = f"# Error generating code, string not returned from NumPyPrinter call" result["generatedCode"] = generatedCode return combine_plot_and_table_data_results(results_with_ranges[:num_statements], statement_plot_info, statement_data_table_info), numerical_system_cell_unit_errors def get_query_values(statements: list[InputAndSystemStatement], custom_base_units: CustomBaseUnits | None, simplify_symbolic_expressions: bool, convert_floats_to_fractions: bool, placeholder_map: dict[Function, PlaceholderFunction], placeholder_set: set[Function], placeholder_dummy_set: set[Function], custom_definition_names: list[str]): error: None | str = None results: list[Result | FiniteImagResult | list[PlotResult] | MatrixResult | DataTableResult | RenderResult] = [] numerical_system_cell_errors: dict[int, bool] = {} try: results, numerical_system_cell_errors = evaluate_statements(statements, custom_base_units, simplify_symbolic_expressions, convert_floats_to_fractions, placeholder_map, placeholder_set, placeholder_dummy_set, custom_definition_names) except DuplicateAssignment as e: error = f"Duplicate assignment of variable {e}" except ReferenceCycle as e: error = "Circular reference detected" except (ParameterError, ParsingError) as e: error = e.__class__.__name__ except OverDeterminedSystem as e: error = "Cannot solve overdetermined system" except NoSolutionFound as e: error = "Unable to solve system of equations" except MemoryError: error = 'A MemoryError occurred while completing the calculation, try disabling the "Preserve Symbolic Representation of Numbers" sheet setting' except EmptyColumnData as e: error = f'Attempt to use empty column "{e}" in a data table calculation' except Extrapolation as e: error = f'Attempt to extrapolate with the interpolation function "{e}", check units since this error could be caused by missing or incorrect units for the inputs to the interpolation function' except MatrixIndexingError as e: error = f'Matrix indexing error, {e}' except CodeCellException as e: error = f'Code cell error, {e}' except Exception as e: print(f"Unhandled exception: {type(e).__name__}, {e}") error = f"Unhandled exception: {type(e).__name__}, {e}" traceback.print_exc() return error, results, numerical_system_cell_errors @lru_cache(maxsize=1024) def get_system_solution(statements, variables, convert_floats_to_fractions): statements = cast(list[EqualityStatement], loads(statements)) variables = cast(list[str], loads(variables)) error: None | str = None new_statements: list[list[SystemSolutionAssignmentStatement]] display_solutions: dict[str, list[str]] try: new_statements = solve_system(statements, variables, global_placeholder_map, global_placeholder_set, global_placeholder_dummy_set, convert_floats_to_fractions) except (ParameterError, ParsingError) as e: error = e.__class__.__name__ new_statements = [] except OverDeterminedSystem as e: error = "Cannot solve overdetermined system" new_statements = [] except NoSolutionFound as e: error = "Unable to solve system of equations" new_statements = [] except Exception as e: print(f"Unhandled exception: {type(e).__name__}, {e}") error = f"Unhandled exception: {type(e).__name__}, {e}" new_statements = [] traceback.print_exc() if error is None: num_solutions = len(new_statements) display_solutions = {} for index, solution in enumerate(new_statements): for statement in solution: current_var_solutions = display_solutions.setdefault(statement["displayName"], [""]*num_solutions) current_var_solutions[index] = statement["display"] else: display_solutions = {} return error, new_statements, display_solutions @lru_cache(maxsize=1024) def get_system_solution_numerical(statements, variables, guesses, guessStatements, fluid_definitions, interpolation_definitions, code_cell_definitions, convert_floats_to_fractions): statements = cast(list[EqualityStatement], loads(statements)) variables = cast(list[str], loads(variables)) guesses = cast(list[str], loads(guesses)) guess_statements = cast(list[GuessAssignmentStatement], loads(guessStatements)) fluid_definitions = cast(list[FluidFunction], loads(fluid_definitions)) interpolation_definitions = cast(list[InterpolationFunction | GridInterpolationFunction], loads(interpolation_definitions)) code_cell_definitions = cast(list[CodeCellFunction], loads(code_cell_definitions)) code_cell_result_store: dict[str, CodeCellResultCollector] = {} placeholder_map, placeholder_set, placeholder_dummy_set = get_custom_placeholder_map(fluid_definitions, interpolation_definitions, code_cell_definitions, code_cell_result_store) error = None new_statements: list[list[EqualityUnitsQueryStatement | GuessAssignmentStatement]] = [] display_solutions: dict[str, list[str]] = {} try: new_statements, display_solutions = solve_system_numerical(statements, variables, guesses, guess_statements, placeholder_map, placeholder_set, placeholder_dummy_set, convert_floats_to_fractions) except (ParameterError, ParsingError) as e: error = e.__class__.__name__ except OverDeterminedSystem as e: error = "Cannot solve overdetermined system, the number of equations should match the number of unknowns" except UnderDeterminedSystem as e: error = "Cannot solve underdetermined system, the number of equations should match the number of unknowns" except (NoSolutionFound, NotImplementedError) as e: error = "Unable to solve system of equations" except Exception as e: print(f"Solve error: {type(e).__name__}, {e}") error = f"Solve error: {type(e).__name__}, {e}" traceback.print_exc() return error, new_statements, display_solutions def collect_code_cell_results(code_cell_result_store: dict[str, CodeCellResultCollector]): result: dict[str, CodeCellResult] = {} for code_function, result_collection in code_cell_result_store.items(): stdout = result_collection["buffer"].getvalue() result_collection["buffer"].close() errors: list[CodeCellError] = [] for e in result_collection["exceptions"]: if isinstance(e, SyntaxError): startCol = e.offset - 1 if (e.offset is not None and e.offset > 0) else None endCol = e.end_offset - 1 if (e.end_offset is not None and e.end_offset > 0) else None startLine = e.lineno if (e.lineno is not None and e.lineno > 0) else None endLine = e.end_lineno if (e.end_lineno is not None and e.end_lineno > 0) else None errors.append(CodeCellError(message=str(e).replace("_as_variable", ""), startLine=startLine, endLine=endLine, startCol=startCol, endCol=endCol)) else: tb = traceback.extract_tb(e.__traceback__) internal_trace_found = False for trace in reversed(tb): if trace.filename == code_function: errors.append(CodeCellError(message=f'{type(e).__name__}: {str(e).replace("_as_variable", "")}', startLine=trace.lineno, endLine=trace.end_lineno, startCol=trace.colno, endCol=trace.end_colno)) internal_trace_found = True if not internal_trace_found: errors.append(CodeCellError(message=str(e).replace("_as_variable", ""), startLine=None, endLine=None, startCol=None, endCol=None)) result[code_function] = {"stdout": stdout, "errors": errors} return result def solve_sheet(statements_and_systems) -> str: statements_and_systems = cast(StatementsAndSystems, loads(statements_and_systems)) statements: list[InputAndSystemStatement] = cast(list[InputAndSystemStatement], statements_and_systems["statements"]) system_definitions = statements_and_systems["systemDefinitions"] fluid_definitions = statements_and_systems["fluidFunctions"] code_cell_definitions = statements_and_systems["codeCellFunctions"] interpolation_definitions = statements_and_systems["interpolationFunctions"] custom_base_units = statements_and_systems.get("customBaseUnits", None) simplify_symbolic_expressions = statements_and_systems["simplifySymbolicExpressions"] convert_floats_to_fractions = statements_and_systems["convertFloatsToFractions"] code_cell_result_store: dict[str, CodeCellResultCollector] = {} try: placeholder_map, placeholder_set, placeholder_dummy_set = get_custom_placeholder_map(fluid_definitions, interpolation_definitions, code_cell_definitions, code_cell_result_store) except Exception as e: error = str(e) return dumps(Results(error=error, results=[], systemResults=[], codeCellResults=collect_code_cell_results(code_cell_result_store))) custom_definition_names = [value["name"] for value in fluid_definitions] custom_definition_names.extend( (value["name"] for value in interpolation_definitions) ) custom_definition_names.extend( (value["name"] for value in code_cell_definitions) ) system_results: list[SystemResult] = [] equation_to_system_cell_map: dict[int,int] = {} # Solve any systems first for i, system_definition in enumerate(system_definitions): selected_solution = system_definition["selectedSolution"] system_error: None | str system_solutions: list[list[SystemSolutionAssignmentStatement]] | list[list[EqualityUnitsQueryStatement | GuessAssignmentStatement]] display_solutions: dict[str, list[str]] # converting arguments to json to allow lru_cache to work since lists and dicts are not hashable # without lru_cache, will be resolving all systems on every sheet update if system_definition["numericalSolve"] is False: (system_error, system_solutions, display_solutions) = get_system_solution(dumps(system_definition["statements"]), dumps(system_definition["variables"]), convert_floats_to_fractions) else: needed_fluid_definitions: dict[str, FluidFunction] = {} needed_interpolation_definitions: dict[str, InterpolationFunction | GridInterpolationFunction] = {} needed_code_cell_definitions: dict[str, CodeCellFunction] = {} for statement in system_definition["statements"]: equation_to_system_cell_map[statement["equationIndex"]] = i for fluid_definition in fluid_definitions: if fluid_definition["name"] in statement["sympy"]: needed_fluid_definitions[fluid_definition["name"]] = fluid_definition for interpolation_definition in interpolation_definitions: if interpolation_definition["name"] in statement["sympy"]: needed_interpolation_definitions[interpolation_definition["name"]] = interpolation_definition for code_cell_definition in code_cell_definitions: if code_cell_definition["name"] in statement["sympy"]: needed_code_cell_definitions[code_cell_definition["name"]] = code_cell_definition selected_solution = 0 (system_error, system_solutions, display_solutions) = get_system_solution_numerical(dumps(system_definition["statements"]), dumps(system_definition["variables"]), dumps(system_definition["guesses"]), dumps(system_definition["guessStatements"]), dumps(list(needed_fluid_definitions.values())), dumps(list(needed_interpolation_definitions.values())), dumps(list(needed_code_cell_definitions.values())), convert_floats_to_fractions) if system_error is None: if selected_solution > len(system_solutions) - 1: selected_solution = 0 statements.extend(system_solutions[selected_solution]) system_results.append({ "error": system_error, "solutions": display_solutions, "selectedSolution": selected_solution }) # now solve the sheet error: str | None results: list[Result | FiniteImagResult | list[PlotResult] | MatrixResult | DataTableResult | RenderResult] numerical_system_cell_errors: dict[int, bool] error, results, numerical_system_cell_errors = get_query_values(statements, custom_base_units, simplify_symbolic_expressions, convert_floats_to_fractions, placeholder_map, placeholder_set, placeholder_dummy_set, custom_definition_names) # If there was a numerical solve, check to make sure there were not unit mismatches # between the lhs and rhs of each equality in the system numerical_solve_units_error = False for equation_index, loop_error in numerical_system_cell_errors.items(): if loop_error and not system_results[equation_to_system_cell_map[equation_index]]["error"]: numerical_solve_units_error = True system_results[equation_to_system_cell_map[equation_index]]["error"] = "Units mismatch in system of equations" if not error and numerical_solve_units_error: error = "Units error in System Solve Cell" try: json_result = dumps(Results(error=error, results=results, systemResults=system_results, codeCellResults=collect_code_cell_results(code_cell_result_store))) except Exception as e: error = f"Error JSON serializing Python results: {e.__class__.__name__}" return dumps(Results(error=error, results=[], systemResults=[], codeCellResults=collect_code_cell_results(code_cell_result_store))) return json_result def get_custom_placeholder_map(fluid_definitions: list[FluidFunction], interpolation_definitions: list[InterpolationFunction | GridInterpolationFunction], code_cell_definitions: list[CodeCellFunction], code_cell_result_store: dict[str, CodeCellResultCollector]) -> \ tuple[dict[Function, PlaceholderFunction], set[Function], set[Function]]: try: fluid_placeholder_map = get_fluid_placeholder_map(fluid_definitions) except Exception as e: raise Exception(f"Error generating fluid cell function: {e}") try: interpolation_placeholder_map = get_interpolation_placeholder_map(interpolation_definitions) except Exception as e: raise Exception(f"Error generating interpolation or polyfit function: {e}") try: code_cell_placeholder_map = get_code_cell_placeholder_map(code_cell_definitions, code_cell_result_store) except Exception as e: traceback.print_exc() raise Exception(f"Error generating code cell function: {e}") placeholder_map = global_placeholder_map | fluid_placeholder_map | interpolation_placeholder_map | \ code_cell_placeholder_map placeholder_set = set(placeholder_map.keys()) placeholder_dummy_set: set[Function] = set() for key, value in placeholder_map.items(): if len(value["dummy_var_locations"]) > 0: placeholder_dummy_set.add(key) return placeholder_map, placeholder_set, placeholder_dummy_set class FuncContainer(object): pass if PROFILE: def solve_sheet_profile(input): values = {"input": input} cProfile.runctx('output = solve_sheet(input)', globals(), values, None, sort="cumtime") # type: ignore[possibly-undefined] return values["output"] py_funcs = FuncContainer() if PROFILE: py_funcs.solveSheet = solve_sheet_profile #pyright: ignore else: py_funcs.solveSheet = solve_sheet #pyright: ignore # pyodide returns last statement as an object that is assessable from javascript py_funcs #pyright: ignore ================================================ FILE: public/iframe_test.html ================================================ Document ================================================ FILE: public/jedi_code_analysis.py ================================================ from typing import cast, TypedDict import traceback import jedi import json class CodeContextRequest(TypedDict): code: str line: int col: int class AutocompleteSuggestion(TypedDict): label: str type: str detail: str prefixLength: int class CodeContextResult(TypedDict): autocompleteSuggestions: list[AutocompleteSuggestion] hoverText: str def get_code_context(request_json: str): try: code_context_request: CodeContextRequest = json.loads(request_json) script = jedi.Script(code_context_request["code"]) line = code_context_request["line"] col = code_context_request["col"] completions = script.complete(line, col, fuzzy=True) docs = script.help(line, col) inferences = script.infer(line, col) if len(docs) > 0: hover_text = "\n".join(([doc.docstring() for doc in docs])) else: hover_text = "" if hover_text == "" and len(inferences) > 0: hover_text = f"{inferences[0].type} of type {inferences[0].name}" autocomplete_suggestions: list[AutocompleteSuggestion] = [ { "label": comp.name_with_symbols, "type": comp.type, "detail": comp.description, "prefixLength": comp.get_completion_prefix_length(), } for comp in completions ] except Exception as e: print(f"Jedi Error: {type(e).__name__}, {e}") traceback.print_exc() return {"autocompleteSuggestions": [], "hoverText": ""} return json.dumps({ "autocompleteSuggestions": autocomplete_suggestions, "hoverText": hover_text, }) class FuncContainer(object): pass py_funcs = FuncContainer() py_funcs.get_code_context = get_code_context #pyright: ignore py_funcs # pyright: ignore ================================================ FILE: public/manifest.json ================================================ { "name": "EngineeringPaper.xyz", "short_name": "EPxyz.com", "categories": ["engineering", "productivity", "education"], "icons": [ { "src": "images/icon.svg", "type": "image/svg+xml", "sizes": "512x512", "purpose": "any" }, { "src": "images/icon-maskable.svg", "type": "image/svg+xml", "sizes": "512x512", "purpose": "maskable" }, { "src": "images/icon-192.png", "type": "image/png", "sizes": "192x192", "purpose": "any" }, { "src": "images/icon-512.png", "type": "image/png", "sizes": "512x512", "purpose": "any" }, { "src": "images/icon-maskable-192.png", "type": "image/png", "sizes": "192x192", "purpose": "maskable" }, { "src": "images/icon-maskable-512.png", "type": "image/png", "sizes": "512x512", "purpose":"maskable" } ], "id": "/", "start_url": "/", "display": "standalone", "background_color": "#000000", "theme_color": "#e61f00", "description": "EngineeringPaper.xyz is free and open source web app for creating shareable engineering calculations that checks/converts units, solves systems of equations, and plots.", "screenshots": [ { "src": "/images/desktop_screenshot.png", "type": "image/png", "sizes": "1572x1307", "form_factor": "wide" }, { "src": "/images/mobile_screenshot.png", "type": "image/png", "sizes": "1440x3120", "form_factor": "narrow" } ], "shortcuts" : [ { "name": "New Sheet", "url": "/", "description": "Open a new window with a blank sheet", "icons": [ { "src": "images/new-sheet-icon-192.png", "sizes": "192x192" }, { "src": "images/new-sheet-icon-96.png", "sizes": "96x96" } ] } ], "launch_handler": { "client_mode": "auto" }, "file_handlers": [ { "action": "/open_file", "name": "EngineeringPaper.xyz", "accept": { "application/json": [ ".epxyz" ] }, "icons": [ { "src": "images/sheet-icon-144.png", "sizes": "144x144" }, { "src": "images/sheet-icon-192.png", "sizes": "192x192" }, { "src": "images/sheet-icon-512.png", "sizes": "512x512" } ], "launch_type": "multiple-clients" } ] } ================================================ FILE: public/pyodide/pyodide-lock.json ================================================ {"info": {"abi_version": "2025_0", "arch": "wasm32", "platform": "emscripten_4_0_9", "python": "3.13.2", "version": "0.28.0.dev0"}, "packages": {"affine": {"depends": [], "file_name": "affine-2.4.0-py3-none-any.whl", "imports": ["affine"], "install_dir": "site", "name": "affine", "package_type": "package", "sha256": "131be00552026a0f9fa9ccf741bdeee5fcbd1b7532761bc0816b39735140e2b0", "unvendored_tests": true, "version": "2.4.0"}, "affine-tests": {"depends": ["affine"], "file_name": "affine-tests.tar", "imports": [], "install_dir": "site", "name": "affine-tests", "package_type": "package", "sha256": "550c271105cc6b33a8b9d29bd95bb13c2667b4286463d124eff1c8f77ecddf0e", "unvendored_tests": false, "version": "2.4.0"}, "aiohappyeyeballs": {"depends": [], "file_name": "aiohappyeyeballs-2.6.1-py3-none-any.whl", "imports": ["aiohappyeyeballs"], "install_dir": "site", "name": "aiohappyeyeballs", "package_type": "package", "sha256": "b8c78c6d23dea9d258b995363f70eaa03840def2c027ca42bda4875e8de657ef", "unvendored_tests": false, "version": "2.6.1"}, "aiohttp": {"depends": ["aiohappyeyeballs", "aiosignal", "async-timeout", "attrs", "charset-normalizer", "frozenlist", "multidict", "yarl"], "file_name": "aiohttp-3.11.13-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["aiohttp"], "install_dir": "site", "name": "aiohttp", "package_type": "package", "sha256": "1c62fa8fe9763120a2423b5c077327b999513ce5b80e1cbb0728d466bb18de08", "unvendored_tests": true, "version": "3.11.13"}, "aiohttp-tests": {"depends": ["aiohttp"], "file_name": "aiohttp-tests.tar", "imports": [], "install_dir": "site", "name": "aiohttp-tests", "package_type": "package", "sha256": "1ea4437cf425330444632b0612072c5edcd959984c5aaa7ceb982075124feb5a", "unvendored_tests": false, "version": "3.11.13"}, "aiosignal": {"depends": ["frozenlist"], "file_name": "aiosignal-1.3.2-py2.py3-none-any.whl", "imports": ["aiosignal"], "install_dir": "site", "name": "aiosignal", "package_type": "package", "sha256": "f6cf8e632efd670870c2ba7e477d7fc09c4e0890d5f62cae2168b67b1a6e9d8a", "unvendored_tests": false, "version": "1.3.2"}, "altair": {"depends": ["typing-extensions", "jinja2", "jsonschema", "packaging", "narwhals"], "file_name": "altair-6.0.0-py3-none-any.whl", "imports": ["altair"], "install_dir": "site", "name": "altair", "package_type": "package", "sha256": "352b116baddc402f86f71b823cf3dd0a7289d7ac381238dd75982d0fc1cacd78", "unvendored_tests": false, "version": "6.0.0"}, "annotated-types": {"depends": [], "file_name": "annotated_types-0.7.0-py3-none-any.whl", "imports": ["annotated_types"], "install_dir": "site", "name": "annotated-types", "package_type": "package", "sha256": "107c6d0a31af3ce347cad1990976cca76373de2ef51dfbffff84fe10cb7b2c19", "unvendored_tests": true, "version": "0.7.0"}, "annotated-types-tests": {"depends": ["annotated-types"], "file_name": "annotated-types-tests.tar", "imports": [], "install_dir": "site", "name": "annotated-types-tests", "package_type": "package", "sha256": "cae22ded0e13e7ad4207c2e30218a5cf58f9e9af5b02e90f711ecb62c9059892", "unvendored_tests": false, "version": "0.7.0"}, "anyio": {"depends": ["ssl", "sniffio", "typing-extensions"], "file_name": "anyio-4.9.0-py3-none-any.whl", "imports": ["anyio"], "install_dir": "site", "name": "anyio", "package_type": "package", "sha256": "9dee49af7541d8bf0b334adcf910aaeb878132648633fc3b91d1604ecb6b1c34", "unvendored_tests": false, "version": "4.9.0"}, "apsw": {"depends": [], "file_name": "apsw-3.50.4.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["apsw"], "install_dir": "site", "name": "apsw", "package_type": "package", "sha256": "7ac926974bcc51dbc93ff5e3ca0034ba109b6a652c9e54a1bd72f2eb05b3f130", "unvendored_tests": true, "version": "3.50.4.0"}, "apsw-tests": {"depends": ["apsw"], "file_name": "apsw-tests.tar", "imports": [], "install_dir": "site", "name": "apsw-tests", "package_type": "package", "sha256": "ebbc200492e1342d346aeba256550a38b1c8d489621f3811a528f46242e10c0e", "unvendored_tests": false, "version": "3.50.4.0"}, "argon2-cffi": {"depends": ["argon2-cffi-bindings"], "file_name": "argon2_cffi-23.1.0-py3-none-any.whl", "imports": ["argon2"], "install_dir": "site", "name": "argon2-cffi", "package_type": "package", "sha256": "09d9151a362d4766bc102fe9b4c1f130544ac55c3f7f7053252a493c602f4330", "unvendored_tests": false, "version": "23.1.0"}, "argon2-cffi-bindings": {"depends": ["cffi"], "file_name": "argon2_cffi_bindings-21.2.0-cp313-abi3-pyodide_2025_0_wasm32.whl", "imports": ["_argon2_cffi_bindings"], "install_dir": "site", "name": "argon2-cffi-bindings", "package_type": "package", "sha256": "5e0122b770d6105cf0f4faabdb6c44b33eb7a7a76583af8fbb94d68de48cfdfa", "unvendored_tests": false, "version": "21.2.0"}, "asciitree": {"depends": [], "file_name": "asciitree-0.3.3-py3-none-any.whl", "imports": ["asciitree"], "install_dir": "site", "name": "asciitree", "package_type": "package", "sha256": "d0f15820c8f1a4470cd7c9932ea9e8989bfe93cc837aa65ac5aa278d4c34b45e", "unvendored_tests": false, "version": "0.3.3"}, "astropy": {"depends": ["packaging", "numpy", "pyerfa", "pyyaml", "astropy_iers_data"], "file_name": "astropy-7.0.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["astropy"], "install_dir": "site", "name": "astropy", "package_type": "package", "sha256": "998c0e4d15f7baa007f1358b1806f46c37a23967387e3e8b426048819994fbca", "unvendored_tests": false, "version": "7.0.1"}, "astropy-iers-data": {"depends": [], "file_name": "astropy_iers_data-0.2025.3.10.0.29.26-py3-none-any.whl", "imports": ["astropy_iers_data"], "install_dir": "site", "name": "astropy_iers_data", "package_type": "package", "sha256": "cfa8d1ce15ccc2ba30c8c373c61a4ffcf1ca2116990150a735c4b1a55a4ccdb0", "unvendored_tests": true, "version": "0.2025.3.10.0.29.26"}, "astropy-iers-data-tests": {"depends": ["astropy_iers_data"], "file_name": "astropy-iers-data-tests.tar", "imports": [], "install_dir": "site", "name": "astropy_iers_data-tests", "package_type": "package", "sha256": "d996c6e07035b5909e04c2b9ccf8dc542b5db5176ddd109b8a51b3ae21291f41", "unvendored_tests": false, "version": "0.2025.3.10.0.29.26"}, "asttokens": {"depends": ["six"], "file_name": "asttokens-3.0.0-py3-none-any.whl", "imports": ["asttokens"], "install_dir": "site", "name": "asttokens", "package_type": "package", "sha256": "c43876aec4679221a3d063796a858278d88a4e3a036c192f0fd3e473a25a9410", "unvendored_tests": false, "version": "3.0.0"}, "async-timeout": {"depends": [], "file_name": "async_timeout-5.0.1-py3-none-any.whl", "imports": ["async_timeout"], "install_dir": "site", "name": "async-timeout", "package_type": "package", "sha256": "48f4163ed3a8b6ff000d3e334e8b4899ac9962e96236fa3156fc3a52dec4bf7a", "unvendored_tests": false, "version": "5.0.1"}, "atomicwrites": {"depends": [], "file_name": "atomicwrites-1.4.1-py2.py3-none-any.whl", "imports": ["atomicwrites"], "install_dir": "site", "name": "atomicwrites", "package_type": "package", "sha256": "3ff3c35fe0cb90741632773d53200125b666fb2c875ac67c016479bb8a52ca0d", "unvendored_tests": false, "version": "1.4.1"}, "attrs": {"depends": ["six"], "file_name": "attrs-25.2.0-py3-none-any.whl", "imports": ["attr", "attrs"], "install_dir": "site", "name": "attrs", "package_type": "package", "sha256": "0ca0ca2b0dbc02f198a7134fb09c26598dc50390439b318d6dfb63adaee97b25", "unvendored_tests": false, "version": "25.2.0"}, "audioop-lts": {"depends": [], "file_name": "audioop_lts-0.2.1-cp313-abi3-pyodide_2025_0_wasm32.whl", "imports": ["audioop"], "install_dir": "site", "name": "audioop-lts", "package_type": "package", "sha256": "9e6bfa4751f5fff5db006c808eb13acbd723f6776e1e7a83cacf3d4779a43975", "unvendored_tests": false, "version": "0.2.1"}, "autograd": {"depends": ["numpy", "future"], "file_name": "autograd-1.7.0-py3-none-any.whl", "imports": ["autograd"], "install_dir": "site", "name": "autograd", "package_type": "package", "sha256": "70300de9264d5c6e89164cab4de39749406a38dde1db1b70f25dda5c901b0990", "unvendored_tests": true, "version": "1.7.0"}, "autograd-tests": {"depends": ["autograd"], "file_name": "autograd-tests.tar", "imports": [], "install_dir": "site", "name": "autograd-tests", "package_type": "package", "sha256": "2e8b8c0119d4ea2d1d93ce4f04d5fe6413021a627df0bd2768943f994d35e1cf", "unvendored_tests": false, "version": "1.7.0"}, "awkward-cpp": {"depends": ["numpy"], "file_name": "awkward_cpp-47-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["awkward_cpp"], "install_dir": "site", "name": "awkward-cpp", "package_type": "package", "sha256": "25794edf577714c842893efdb3e23d0518c53ebbebe3f9da444b0813a7ab6063", "unvendored_tests": false, "version": "47"}, "b2d": {"depends": ["numpy", "pydantic", "setuptools", "annotated-types"], "file_name": "b2d-0.7.4-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["b2d"], "install_dir": "site", "name": "b2d", "package_type": "package", "sha256": "47709ef215b1ae596bbda3e2905a4182ddc95469daa78bfe1d362c8f3adef894", "unvendored_tests": false, "version": "0.7.4"}, "bcrypt": {"depends": [], "file_name": "bcrypt-4.3.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["bcrypt"], "install_dir": "site", "name": "bcrypt", "package_type": "package", "sha256": "dc7912bcfa6e66a1ecf93a51180cbff8ccce095ac742e2abad0684eb5b84b6a1", "unvendored_tests": false, "version": "4.3.0"}, "beautifulsoup4": {"depends": ["soupsieve", "typing-extensions"], "file_name": "beautifulsoup4-4.13.3-py3-none-any.whl", "imports": ["bs4"], "install_dir": "site", "name": "beautifulsoup4", "package_type": "package", "sha256": "3b401669e1cf50a15a6fc5de272009f581f8a16180a7e5596dbdafec97472b88", "unvendored_tests": true, "version": "4.13.3"}, "beautifulsoup4-tests": {"depends": ["beautifulsoup4"], "file_name": "beautifulsoup4-tests.tar", "imports": [], "install_dir": "site", "name": "beautifulsoup4-tests", "package_type": "package", "sha256": "d285c75aefab4bb8472c8baf3b66b6e06c185a3f25790b565fcd25b55e697e9d", "unvendored_tests": false, "version": "4.13.3"}, "bilby-cython": {"depends": ["numpy"], "file_name": "bilby_cython-0.5.3-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["bilby_cython"], "install_dir": "site", "name": "bilby.cython", "package_type": "package", "sha256": "1eeeec68f4fc30c67088496c0caac658145ba3a239f497b9affe21a6d5fb769f", "unvendored_tests": true, "version": "0.5.3"}, "bilby-cython-tests": {"depends": ["bilby.cython"], "file_name": "bilby-cython-tests.tar", "imports": [], "install_dir": "site", "name": "bilby.cython-tests", "package_type": "package", "sha256": "acbc16454028227bc9092a58920b863a92c72063d4f6b4d8429fbfdae4cb7f91", "unvendored_tests": false, "version": "0.5.3"}, "biopython": {"depends": ["numpy"], "file_name": "biopython-1.85-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["Bio", "BioSQL"], "install_dir": "site", "name": "biopython", "package_type": "package", "sha256": "a3826362af0a9382e3adb450ff633b3c0807bc77ddbe4bf55b1477d19bf46499", "unvendored_tests": false, "version": "1.85"}, "bitarray": {"depends": [], "file_name": "bitarray-3.8.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["bitarray"], "install_dir": "site", "name": "bitarray", "package_type": "package", "sha256": "8a8ae1f58878fc1ac0704e1688b1d24580eb3f7dfd6e442b29c3d10d9511c971", "unvendored_tests": true, "version": "3.8.0"}, "bitarray-tests": {"depends": ["bitarray"], "file_name": "bitarray-tests.tar", "imports": [], "install_dir": "site", "name": "bitarray-tests", "package_type": "package", "sha256": "a18fea12f1a946e0912c8fa3dd792f9e1f4ac36fb7826694db84791eb2875fd5", "unvendored_tests": false, "version": "3.8.0"}, "bitstring": {"depends": ["bitarray"], "file_name": "bitstring-4.3.1-py3-none-any.whl", "imports": ["bitstring"], "install_dir": "site", "name": "bitstring", "package_type": "package", "sha256": "428f9b321ba97820700d45548046ae922b110eede5cd7ae045863b9ded64d364", "unvendored_tests": false, "version": "4.3.1"}, "bleach": {"depends": ["webencodings", "packaging", "six"], "file_name": "bleach-6.2.0-py3-none-any.whl", "imports": ["bleach"], "install_dir": "site", "name": "bleach", "package_type": "package", "sha256": "f9fdb8ec80fb553ecd97f95bd86d7109694a06ac0182cfc0fd70707de2de7326", "unvendored_tests": false, "version": "6.2.0"}, "blosc2": {"depends": ["numpy", "msgpack", "requests", "ndindex", "platformdirs"], "file_name": "blosc2-3.5.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["blosc2"], "install_dir": "site", "name": "blosc2", "package_type": "package", "sha256": "c59b3a727ee6aadafc6c76b973e0e66a85a3403f1067de7b2082dc8c68a7b170", "unvendored_tests": false, "version": "3.5.1"}, "bokeh": {"depends": ["contourpy", "numpy", "jinja2", "pandas", "pillow", "python-dateutil", "six", "typing-extensions", "pyyaml", "xyzservices"], "file_name": "bokeh-3.6.3-py3-none-any.whl", "imports": ["bokeh"], "install_dir": "site", "name": "bokeh", "package_type": "package", "sha256": "bf281877079625b7fac7b9bb5113bcc8728dc78da2201b9e4c1da9adbdd9dbde", "unvendored_tests": false, "version": "3.6.3"}, "boost-histogram": {"depends": ["numpy"], "file_name": "boost_histogram-1.6.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["boost_histogram"], "install_dir": "site", "name": "boost-histogram", "package_type": "package", "sha256": "5baed26887645ad8f23fd92a698fdf6e821250c57bbb87343340a9a2e8fa804b", "unvendored_tests": false, "version": "1.6.1"}, "bottleneck": {"depends": ["numpy"], "file_name": "bottleneck-1.6.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["bottleneck"], "install_dir": "site", "name": "Bottleneck", "package_type": "package", "sha256": "4387e8bb7cf8f26b2c5c41bb0635fb05c87c65770d99f9a6ab1cb56cf4498fcb", "unvendored_tests": false, "version": "1.6.0"}, "brotli": {"depends": [], "file_name": "brotli-1.2.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["brotli"], "install_dir": "site", "name": "brotli", "package_type": "package", "sha256": "5ab0f27efecb1504448bed4e78bc617fe61bdb8d7eac33dcf611e3712324161c", "unvendored_tests": false, "version": "1.2.0"}, "cachetools": {"depends": [], "file_name": "cachetools-5.5.2-py3-none-any.whl", "imports": ["cachetools"], "install_dir": "site", "name": "cachetools", "package_type": "package", "sha256": "3bcb173d17fd7a7fb18ed5ad495f15aa9c29a44a4ccab69e1a6fb816991bb9ae", "unvendored_tests": false, "version": "5.5.2"}, "cartopy": {"depends": ["shapely", "pyshp", "pyproj", "libgeos", "matplotlib", "scipy"], "file_name": "cartopy-0.25.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["cartopy"], "install_dir": "site", "name": "Cartopy", "package_type": "package", "sha256": "ce3942e2ca66a40afcea2631d4da0f5c3a56ef02bbad4c02bf5873689b041a01", "unvendored_tests": true, "version": "0.25.0"}, "cartopy-tests": {"depends": ["Cartopy"], "file_name": "cartopy-tests.tar", "imports": [], "install_dir": "site", "name": "Cartopy-tests", "package_type": "package", "sha256": "bcea2c24e4f38555f8eddfcab8589249fc34c6660cbc56cb7bca065b8e269f20", "unvendored_tests": false, "version": "0.25.0"}, "casadi": {"depends": ["numpy"], "file_name": "casadi-3.7.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["casadi"], "install_dir": "site", "name": "casadi", "package_type": "package", "sha256": "d3df1dc9a41eb7b6854e9901fba2dee9f03ff38c3d820ad174c0410c780f5ad5", "unvendored_tests": false, "version": "3.7.0"}, "cbor-diag": {"depends": [], "file_name": "cbor_diag-1.0.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["cbor_diag"], "install_dir": "site", "name": "cbor-diag", "package_type": "package", "sha256": "bd3425bfa559ba2d37df1be401782f227fc2d5f66021eb0e7ecfbaa6bf55a405", "unvendored_tests": false, "version": "1.0.1"}, "certifi": {"depends": [], "file_name": "certifi-2026.1.4-py3-none-any.whl", "imports": ["certifi"], "install_dir": "site", "name": "certifi", "package_type": "package", "sha256": "f4a28d9afc3e7f15bed4437710794d5c439d7f3aab1310767eea26eae3be534d", "unvendored_tests": false, "version": "2026.1.4"}, "cffi": {"depends": ["pycparser"], "file_name": "cffi-1.17.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["cffi"], "install_dir": "site", "name": "cffi", "package_type": "package", "sha256": "a91747e5e4d982e7e7b2f158f2d06302c4205198ccec688e34b9c310e4417da7", "unvendored_tests": false, "version": "1.17.1"}, "cffi-example": {"depends": ["cffi"], "file_name": "cffi_example-0.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["cffi_example"], "install_dir": "site", "name": "cffi_example", "package_type": "package", "sha256": "41af9bb3bd71bfb466e1955a5d61ab20613b8940da70a84acb7069b20bd259c6", "unvendored_tests": false, "version": "0.1"}, "cftime": {"depends": ["numpy"], "file_name": "cftime-1.6.4.post1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["cftime"], "install_dir": "site", "name": "cftime", "package_type": "package", "sha256": "7f829cd958bb0451722e8ac1ec20cfe4094727dac1aa663dc906fb21d1f08fbe", "unvendored_tests": false, "version": "1.6.4.post1"}, "charset-normalizer": {"depends": [], "file_name": "charset_normalizer-3.4.4-py3-none-any.whl", "imports": ["charset_normalizer"], "install_dir": "site", "name": "charset-normalizer", "package_type": "package", "sha256": "3ad3f0d6ba052549bf375d0137b3a218bcf2914e8f08db7fa5436561404f3a36", "unvendored_tests": false, "version": "3.4.4"}, "clarabel": {"depends": ["numpy", "scipy"], "file_name": "clarabel-0.11.0-cp39-abi3-pyodide_2025_0_wasm32.whl", "imports": ["clarabel"], "install_dir": "site", "name": "clarabel", "package_type": "package", "sha256": "556e80e526244d1259c2fb7d7302bc758836a31f6b85d7c6960bb052d2b77489", "unvendored_tests": false, "version": "0.11.0"}, "click": {"depends": [], "file_name": "click-8.3.1-py3-none-any.whl", "imports": ["click"], "install_dir": "site", "name": "click", "package_type": "package", "sha256": "d3a6a60612e8940fc1396f5095d823520f14d65621adb5d8739b9b3f300276ae", "unvendored_tests": false, "version": "8.3.1"}, "cligj": {"depends": ["click"], "file_name": "cligj-0.7.2-py3-none-any.whl", "imports": ["cligj"], "install_dir": "site", "name": "cligj", "package_type": "package", "sha256": "8ee9b744c58c6c7d3fb57b645ad383ca991fdfa035d6b5367764835b4718f4cb", "unvendored_tests": false, "version": "0.7.2"}, "clingo": {"depends": ["cffi"], "file_name": "clingo-5.8.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["clingo"], "install_dir": "site", "name": "clingo", "package_type": "package", "sha256": "bebb57cec75510c9f0574e7a4c30d1211ac1504dd3fe88eb898b49f11c1e7764", "unvendored_tests": false, "version": "5.8.0"}, "cloudpickle": {"depends": [], "file_name": "cloudpickle-3.1.1-py3-none-any.whl", "imports": ["cloudpickle"], "install_dir": "site", "name": "cloudpickle", "package_type": "package", "sha256": "1713954092c0c77c38518705b822ac2a48055749b1131a8bc0c6bb8daddd5f83", "unvendored_tests": false, "version": "3.1.1"}, "cmyt": {"depends": ["colorspacious", "matplotlib", "more-itertools", "numpy"], "file_name": "cmyt-2.0.2-py3-none-any.whl", "imports": ["cmyt"], "install_dir": "site", "name": "cmyt", "package_type": "package", "sha256": "4e34b39e175f32ed104f7c31076a43bbc1f755da601be61c548d9bf9ccb162ff", "unvendored_tests": false, "version": "2.0.2"}, "cobs": {"depends": [], "file_name": "cobs-1.2.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["cobs"], "install_dir": "site", "name": "cobs", "package_type": "package", "sha256": "3fc5bb2065f467bf6ebe8781ba2d65e255157efd57ca17e2231a6bc78e62e3f5", "unvendored_tests": false, "version": "1.2.1"}, "colorspacious": {"depends": ["numpy"], "file_name": "colorspacious-1.1.2-py2.py3-none-any.whl", "imports": ["colorspacious"], "install_dir": "site", "name": "colorspacious", "package_type": "package", "sha256": "a4ffb391e744d4ee5a278da853f659462f5b7af554e1d3668cddcde5fbd178d2", "unvendored_tests": false, "version": "1.1.2"}, "contourpy": {"depends": ["numpy"], "file_name": "contourpy-1.3.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["contourpy"], "install_dir": "site", "name": "contourpy", "package_type": "package", "sha256": "9a4391fbfd75b156c1f79c0152b7520e18e87165270a20e0ab4ec4c8db5e52ad", "unvendored_tests": false, "version": "1.3.1"}, "coolprop": {"depends": ["numpy", "matplotlib"], "file_name": "coolprop-7.2.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["CoolProp"], "install_dir": "site", "name": "coolprop", "package_type": "package", "sha256": "a0369cfaba7282620cadfe72362c5e179f83a00f01eff23d8a660817d681be55", "unvendored_tests": true, "version": "7.2.0"}, "coolprop-tests": {"depends": ["coolprop"], "file_name": "coolprop-tests.tar", "imports": [], "install_dir": "site", "name": "coolprop-tests", "package_type": "package", "sha256": "fd85ea7b15f11987b66296922060c1a58a49b4fd9772c5d8394a95e2ebd44c95", "unvendored_tests": false, "version": "7.2.0"}, "coverage": {"depends": ["sqlite3"], "file_name": "coverage-7.6.12-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["coverage"], "install_dir": "site", "name": "coverage", "package_type": "package", "sha256": "f7177cc62824e11cb856dcb8b24d18f34fef616601bdb3c260cfb61e38625ebd", "unvendored_tests": false, "version": "7.6.12"}, "cramjam": {"depends": [], "file_name": "cramjam-2.10.0rc1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["cramjam"], "install_dir": "site", "name": "cramjam", "package_type": "package", "sha256": "6a771bba3165b2233a2b7e3b597513e6bf54053f57bc1df54d8bc565910e0797", "unvendored_tests": false, "version": "2.10.0rc1"}, "crc32c": {"depends": [], "file_name": "crc32c-2.7.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["crc32c"], "install_dir": "site", "name": "crc32c", "package_type": "package", "sha256": "2b2d2aa5c35772fc993405aec61cbea8cfd08f734358ee4bbd13c4ed30589c5f", "unvendored_tests": false, "version": "2.7.1"}, "cryptography": {"depends": ["libopenssl", "six", "cffi"], "file_name": "cryptography-46.0.3-cp313-abi3-pyodide_2025_0_wasm32.whl", "imports": ["cryptography"], "install_dir": "site", "name": "cryptography", "package_type": "package", "sha256": "8dcec3549f85ea9df0941f75339fa5539d3b4a87ea0a47ab1957fd30c3878419", "unvendored_tests": false, "version": "46.0.3"}, "css-inline": {"depends": [], "file_name": "css_inline-0.16.0-cp39-abi3-pyodide_2025_0_wasm32.whl", "imports": ["css_inline"], "install_dir": "site", "name": "css-inline", "package_type": "package", "sha256": "3dbb7ce8fcb79c0e2efbb8cd2f46513e0cf55715896d0cc781783f44262f101a", "unvendored_tests": false, "version": "0.16.0"}, "cssselect": {"depends": [], "file_name": "cssselect-1.3.0-py3-none-any.whl", "imports": ["cssselect"], "install_dir": "site", "name": "cssselect", "package_type": "package", "sha256": "964d7b801271db5a87ff4e4d15a759907d21c2171512a0c465fa479c9304f29b", "unvendored_tests": false, "version": "1.3.0"}, "cvxpy-base": {"depends": ["numpy", "scipy", "clarabel"], "file_name": "cvxpy_base-1.6.3-py3-none-any.whl", "imports": ["cvxpy"], "install_dir": "site", "name": "cvxpy-base", "package_type": "package", "sha256": "1af1f7116765a3f58b07435051f7b22472629f7ce0914bed40290e04dad13c48", "unvendored_tests": true, "version": "1.6.3"}, "cvxpy-base-tests": {"depends": ["cvxpy-base"], "file_name": "cvxpy-base-tests.tar", "imports": [], "install_dir": "site", "name": "cvxpy-base-tests", "package_type": "package", "sha256": "d8ee8b62799cc27f03f1db48667850094adad7ab73f2e7170018efdf2d5803ee", "unvendored_tests": false, "version": "1.6.3"}, "cycler": {"depends": ["six"], "file_name": "cycler-0.12.1-cp313-none-any.whl", "imports": ["cycler"], "install_dir": "site", "name": "cycler", "package_type": "package", "sha256": "44b431968570b803e0f31136b50852a89e7eb03d3f2b3fa40d63e6636d7375ce", "unvendored_tests": false, "version": "0.12.1"}, "cysignals": {"depends": [], "file_name": "cysignals-1.12.3-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["cysignals"], "install_dir": "site", "name": "cysignals", "package_type": "package", "sha256": "d23517d622583a2229ab97eb6cdfb8da76a07aa015da194794623a3d080467b3", "unvendored_tests": false, "version": "1.12.3"}, "cytoolz": {"depends": ["toolz"], "file_name": "cytoolz-1.0.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["cytoolz"], "install_dir": "site", "name": "cytoolz", "package_type": "package", "sha256": "dd3fa44718db38cdc637763c68f07e7e49953b6a85d8452afdd5f0b78be643f1", "unvendored_tests": true, "version": "1.0.1"}, "cytoolz-tests": {"depends": ["cytoolz"], "file_name": "cytoolz-tests.tar", "imports": [], "install_dir": "site", "name": "cytoolz-tests", "package_type": "package", "sha256": "7ad1424b1544a1f5a6fe188fae7f30022552f76ae1e8665d17d1fe9fd5d81dac", "unvendored_tests": false, "version": "1.0.1"}, "decorator": {"depends": [], "file_name": "decorator-5.2.1-py3-none-any.whl", "imports": ["decorator"], "install_dir": "site", "name": "decorator", "package_type": "package", "sha256": "875c482c775a71a793ed4392891abba2b762c0dfe951dccc6d2165bb5b422658", "unvendored_tests": false, "version": "5.2.1"}, "demes": {"depends": ["attrs", "ruamel.yaml"], "file_name": "demes-0.2.3-py3-none-any.whl", "imports": ["demes"], "install_dir": "site", "name": "demes", "package_type": "package", "sha256": "01d91bf39f3ead93e0131886865caf669dae1c14b0723ce55932982b528cbfba", "unvendored_tests": false, "version": "0.2.3"}, "deprecation": {"depends": ["packaging"], "file_name": "deprecation-2.1.0-py2.py3-none-any.whl", "imports": ["deprecation"], "install_dir": "site", "name": "deprecation", "package_type": "package", "sha256": "9352a446bcf40cb483d89dbee7f85dc67bb7707653706f8bd180366fe024f862", "unvendored_tests": false, "version": "2.1.0"}, "diskcache": {"depends": ["sqlite3"], "file_name": "diskcache-5.6.3-py3-none-any.whl", "imports": ["diskcache"], "install_dir": "site", "name": "diskcache", "package_type": "package", "sha256": "d4bcdb7580a6dc5370eb5f810c89232972f2a79ad8557ec15b12d2148078a401", "unvendored_tests": false, "version": "5.6.3"}, "distlib": {"depends": [], "file_name": "distlib-0.3.9-py2.py3-none-any.whl", "imports": ["distlib"], "install_dir": "site", "name": "distlib", "package_type": "package", "sha256": "8599aff281d7dd46ac4eb31a98107318281cacabcd83303b51c19ca4a2da3eb5", "unvendored_tests": false, "version": "0.3.9"}, "distro": {"depends": [], "file_name": "distro-1.9.0-py3-none-any.whl", "imports": ["distro"], "install_dir": "site", "name": "distro", "package_type": "package", "sha256": "997da1bf8f9ce720daa3c06cea7e1439a8a0407379293e01144e5a2da01bc3c6", "unvendored_tests": false, "version": "1.9.0"}, "docutils": {"depends": [], "file_name": "docutils-0.21.2-py3-none-any.whl", "imports": ["docutils"], "install_dir": "site", "name": "docutils", "package_type": "package", "sha256": "55e71ee1f74328917ab97904fd879960197db736e2e1ac44686cf1df781b13bd", "unvendored_tests": false, "version": "0.21.2"}, "donfig": {"depends": ["pyyaml"], "file_name": "donfig-0.8.1.post1-py3-none-any.whl", "imports": ["donfig"], "install_dir": "site", "name": "donfig", "package_type": "package", "sha256": "36064dc40199a88bfa3ea79f279cc4f66b850f6a5c2f1e6ebbf9569648e15884", "unvendored_tests": true, "version": "0.8.1.post1"}, "donfig-tests": {"depends": ["donfig"], "file_name": "donfig-tests.tar", "imports": [], "install_dir": "site", "name": "donfig-tests", "package_type": "package", "sha256": "27980fd72de84aaf45682097106445fe801a69180c5c7d1066f7b8dfb1742940", "unvendored_tests": false, "version": "0.8.1.post1"}, "drawsvg": {"depends": [], "file_name": "drawsvg-2.4.1-cp313-none-any.whl", "imports": ["drawsvg"], "install_dir": "site", "name": "drawsvg", "package_type": "package", "sha256": "bea3dd56f7b6c3ba781c9af633dfa55ac4172b6741be0022b76239bfb48ddc63", "unvendored_tests": false, "version": "2.4.1"}, "ewah-bool-utils": {"depends": ["numpy"], "file_name": "ewah_bool_utils-1.2.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["ewah_bool_utils"], "install_dir": "site", "name": "ewah_bool_utils", "package_type": "package", "sha256": "baa25345e54e978361653ced58224ec5e66533df54fa25e765523892afc804f9", "unvendored_tests": true, "version": "1.2.2"}, "ewah-bool-utils-tests": {"depends": ["ewah_bool_utils"], "file_name": "ewah-bool-utils-tests.tar", "imports": [], "install_dir": "site", "name": "ewah_bool_utils-tests", "package_type": "package", "sha256": "c5723fbb16afbb37fd805ebff71173c0200e3ae300afc725e54a88f8a6371ac7", "unvendored_tests": false, "version": "1.2.2"}, "exceptiongroup": {"depends": [], "file_name": "exceptiongroup-1.2.2-py3-none-any.whl", "imports": ["exceptiongroup"], "install_dir": "site", "name": "exceptiongroup", "package_type": "package", "sha256": "1e53eb509a0ec39aec35fd93ee2190899745967d7758de005318f3145e8b5b0d", "unvendored_tests": false, "version": "1.2.2"}, "executing": {"depends": [], "file_name": "executing-2.2.0-py2.py3-none-any.whl", "imports": ["executing"], "install_dir": "site", "name": "executing", "package_type": "package", "sha256": "c8e573008eea36616bd1821285b8f13b44ec77c35aa732bbe6d689a1b3932458", "unvendored_tests": false, "version": "2.2.0"}, "fastapi": {"depends": ["httpx", "jinja2", "pydantic", "starlette", "anyio"], "file_name": "fastapi-0.116.1-py3-none-any.whl", "imports": ["fastapi"], "install_dir": "site", "name": "fastapi", "package_type": "package", "sha256": "57b58f74bc39b4b10828cffe45d59eebfa18f30d5656f35c002f2f5f651c305f", "unvendored_tests": false, "version": "0.116.1"}, "fastcan": {"depends": ["scikit-learn"], "file_name": "fastcan-0.5.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["fastcan"], "install_dir": "site", "name": "fastcan", "package_type": "package", "sha256": "42911731bed3165fcb977bfa88c06db94eb0c5e6d0bcfb28504342476b4bd3f4", "unvendored_tests": true, "version": "0.5.0"}, "fastcan-tests": {"depends": ["fastcan"], "file_name": "fastcan-tests.tar", "imports": [], "install_dir": "site", "name": "fastcan-tests", "package_type": "package", "sha256": "c9dabf71fb41f66f38cdabd850adf8a1ed2c2ac880be96e0650de85e3208e7ee", "unvendored_tests": false, "version": "0.5.0"}, "fastparquet": {"depends": ["numpy", "cramjam", "pandas", "fsspec", "packaging"], "file_name": "fastparquet-2024.11.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["fastparquet"], "install_dir": "site", "name": "fastparquet", "package_type": "package", "sha256": "97e54ff7436c2b661f92fb2c648d5346cb94c6a14a90d96c08151b185a82e1b1", "unvendored_tests": false, "version": "2024.11.0"}, "fiona": {"depends": ["attrs", "certifi", "setuptools", "six", "click", "cligj"], "file_name": "fiona-1.9.5-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["fiona"], "install_dir": "site", "name": "fiona", "package_type": "package", "sha256": "e3c4b0f342b9d14f8f49474e18b2faeda31d2515eaff0f2a122afb9cef562876", "unvendored_tests": false, "version": "1.9.5"}, "fonttools": {"depends": [], "file_name": "fonttools-4.56.0-cp313-none-any.whl", "imports": ["fontTools"], "install_dir": "site", "name": "fonttools", "package_type": "package", "sha256": "1247b9710be637acf630acc4ee8cf15957b5815a89b1253fcc5239083e2ff359", "unvendored_tests": false, "version": "4.56.0"}, "freesasa": {"depends": [], "file_name": "freesasa-2.2.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["freesasa"], "install_dir": "site", "name": "freesasa", "package_type": "package", "sha256": "2d4158326beecd9958af7bc6a121cc7cae0d4a577a942a1f2d58f6d9931cb942", "unvendored_tests": false, "version": "2.2.1"}, "frozenlist": {"depends": [], "file_name": "frozenlist-1.6.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["frozenlist"], "install_dir": "site", "name": "frozenlist", "package_type": "package", "sha256": "8586c579bec9bea1be39e9814ffa65280b1f6aaf1bde4332eeedc5ba6fb6c59d", "unvendored_tests": false, "version": "1.6.0"}, "fsspec": {"depends": [], "file_name": "fsspec-2025.3.2-py3-none-any.whl", "imports": ["fsspec"], "install_dir": "site", "name": "fsspec", "package_type": "package", "sha256": "33f1825db178ed9df3bbf056f431ce0dc29f57489b8e265133d704d44f8d7deb", "unvendored_tests": true, "version": "2025.3.2"}, "fsspec-tests": {"depends": ["fsspec"], "file_name": "fsspec-tests.tar", "imports": [], "install_dir": "site", "name": "fsspec-tests", "package_type": "package", "sha256": "d8bca1f84b04961ddecd8410705e71c4475febf4f7c894acb2d0b34442a61821", "unvendored_tests": false, "version": "2025.3.2"}, "future": {"depends": [], "file_name": "future-1.0.0-py3-none-any.whl", "imports": ["future"], "install_dir": "site", "name": "future", "package_type": "package", "sha256": "00fb5bff96057f6cc8bf891d68b45c5c4a1e8f4ab6ed366651cfa7d8292d651a", "unvendored_tests": true, "version": "1.0.0"}, "future-tests": {"depends": ["future"], "file_name": "future-tests.tar", "imports": [], "install_dir": "site", "name": "future-tests", "package_type": "package", "sha256": "be42b72dd88321133f53666012cfee4fb22acc66a0e93d52f3bbaabc21edecca", "unvendored_tests": false, "version": "1.0.0"}, "galpy": {"depends": ["numpy", "scipy", "matplotlib", "astropy", "future", "setuptools"], "file_name": "galpy-1.10.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["galpy"], "install_dir": "site", "name": "galpy", "package_type": "package", "sha256": "ab453044b69f8161b518fd86c76f494e4d5876b936668e464db63cf2922ba6fc", "unvendored_tests": false, "version": "1.10.2"}, "geopandas": {"depends": ["shapely", "fiona", "pyproj", "packaging", "pandas"], "file_name": "geopandas-1.1.1-py3-none-any.whl", "imports": ["geopandas"], "install_dir": "site", "name": "geopandas", "package_type": "package", "sha256": "37a35570d7fa540595c490bb84b89ad83848b67d9c55eeb0442c7578197db6fc", "unvendored_tests": true, "version": "1.1.1"}, "geopandas-tests": {"depends": ["geopandas"], "file_name": "geopandas-tests.tar", "imports": [], "install_dir": "site", "name": "geopandas-tests", "package_type": "package", "sha256": "a4233e1555cd0a84d6712fc6934e8ec35c0c8740b9770f44ca927001e9ee4aeb", "unvendored_tests": false, "version": "1.1.1"}, "gmpy2": {"depends": [], "file_name": "gmpy2-2.1.5-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["gmpy2"], "install_dir": "site", "name": "gmpy2", "package_type": "package", "sha256": "0f4168b108079567f211ac6b3d3a22e500c29a2c620fbb7a3035d6a193f002da", "unvendored_tests": false, "version": "2.1.5"}, "google-crc32c": {"depends": [], "file_name": "google_crc32c-1.8.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["google_crc32c"], "install_dir": "site", "name": "google-crc32c", "package_type": "package", "sha256": "c469bebdea71acf327c5e35177dde836186649e50f08489898d167ffb3de3090", "unvendored_tests": false, "version": "1.8.0"}, "gsw": {"depends": ["numpy"], "file_name": "gsw-3.6.19-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["gsw"], "install_dir": "site", "name": "gsw", "package_type": "package", "sha256": "d57a2ba51ad05510862d315343eb9049143005e475f3b5093765d5e9dba7e7a2", "unvendored_tests": true, "version": "3.6.19"}, "gsw-tests": {"depends": ["gsw"], "file_name": "gsw-tests.tar", "imports": [], "install_dir": "site", "name": "gsw-tests", "package_type": "package", "sha256": "ebbecf095de3e2a21b221b1b858390de986587a1f1959be3702f25f0bbc36d32", "unvendored_tests": false, "version": "3.6.19"}, "h11": {"depends": [], "file_name": "h11-0.14.0-py3-none-any.whl", "imports": ["h11"], "install_dir": "site", "name": "h11", "package_type": "package", "sha256": "c1163b48048f27994e804188a4f2c9726d4e945eb181c2637d9ee78c379a226b", "unvendored_tests": true, "version": "0.14.0"}, "h11-tests": {"depends": ["h11"], "file_name": "h11-tests.tar", "imports": [], "install_dir": "site", "name": "h11-tests", "package_type": "package", "sha256": "2eb365f7d4bb226b3a2ac452047cafbb7682651c4f8d6ad583f840d21aacdf98", "unvendored_tests": false, "version": "0.14.0"}, "h3": {"depends": [], "file_name": "h3-4.2.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["h3"], "install_dir": "site", "name": "h3", "package_type": "package", "sha256": "1c0209c3e265140dd9716d58b242c606530a960538aefa02b00487269e82295e", "unvendored_tests": false, "version": "4.2.2"}, "h5py": {"depends": ["numpy", "pkgconfig", "libhdf5"], "file_name": "h5py-3.13.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["h5py"], "install_dir": "site", "name": "h5py", "package_type": "package", "sha256": "b8b01774b2a5bfa4fee0313a0fe51b689af065ccdb53feac87e0112c0b555a81", "unvendored_tests": true, "version": "3.13.0"}, "h5py-tests": {"depends": ["h5py"], "file_name": "h5py-tests.tar", "imports": [], "install_dir": "site", "name": "h5py-tests", "package_type": "package", "sha256": "6b4143ff0eb8ea781bed7cd73b969ff4f6cdee8e77b7b5117b9b9620cf4a1ab9", "unvendored_tests": false, "version": "3.13.0"}, "hashlib": {"depends": ["libopenssl"], "file_name": "hashlib-1.0.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["_hashlib"], "install_dir": "site", "name": "hashlib", "package_type": "cpython_module", "sha256": "206442f20d96c131210dfdbad25d5da877b795c873d6b6689a58a46031ed9aab", "unvendored_tests": false, "version": "1.0.0"}, "healpy": {"depends": ["numpy", "astropy"], "file_name": "healpy-1.19.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["healpy"], "install_dir": "site", "name": "healpy", "package_type": "package", "sha256": "f2f16fe5aa15d70c88b3bcddcddb40bb450a85f7f51c7fdc6a7aea281b63d413", "unvendored_tests": true, "version": "1.19.0"}, "healpy-tests": {"depends": ["healpy"], "file_name": "healpy-tests.tar", "imports": [], "install_dir": "site", "name": "healpy-tests", "package_type": "package", "sha256": "41852502e5cf88f1e25d885d3fcf48d4d623b31aa92f939c7b5fa25ff863fa95", "unvendored_tests": false, "version": "1.19.0"}, "highspy": {"depends": ["numpy"], "file_name": "highspy-1.11.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["highspy"], "install_dir": "site", "name": "highspy", "package_type": "package", "sha256": "9e0c64abc044e6cdf4d07d68b982f6e7e4b3bb1aec3596ce5e81f3798f207664", "unvendored_tests": false, "version": "1.11.0"}, "html5lib": {"depends": ["webencodings", "six"], "file_name": "html5lib-1.1-py2.py3-none-any.whl", "imports": ["html5lib"], "install_dir": "site", "name": "html5lib", "package_type": "package", "sha256": "0140d9b5d8c2cdec07bb3a513f99ea1082d169803a61dc388f7ab2de4104d948", "unvendored_tests": false, "version": "1.1"}, "httpcore": {"depends": ["certifi", "h11", "ssl"], "file_name": "httpcore-1.0.7-py3-none-any.whl", "imports": ["httpcore"], "install_dir": "site", "name": "httpcore", "package_type": "package", "sha256": "59660a6db0443006290fe5bf1eaae7c047ed2c7c13520ba0b3329fbbf8a6aa45", "unvendored_tests": false, "version": "1.0.7"}, "httpx": {"depends": [], "file_name": "httpx-0.28.1-py3-none-any.whl", "imports": ["httpx"], "install_dir": "site", "name": "httpx", "package_type": "package", "sha256": "3123bf6c7e7623667b39d31f8b2bf4eac925b49ea79dfdf520560db2e1cf87a9", "unvendored_tests": false, "version": "0.28.1"}, "idna": {"depends": [], "file_name": "idna-3.10-py3-none-any.whl", "imports": ["idna"], "install_dir": "site", "name": "idna", "package_type": "package", "sha256": "72da788d7a6d3e363535aba1be2658fd21bda5038f2eb0976ce6cb5186942bd6", "unvendored_tests": false, "version": "3.10"}, "igraph": {"depends": ["texttable"], "file_name": "igraph-0.11.8-cp39-abi3-pyodide_2025_0_wasm32.whl", "imports": ["igraph"], "install_dir": "site", "name": "igraph", "package_type": "package", "sha256": "06fcc32420c64dfd3349c172b6b1460f36487e3b47e937ee5e8da0cc1ffa7c86", "unvendored_tests": false, "version": "0.11.8"}, "imageio": {"depends": ["numpy", "pillow"], "file_name": "imageio-2.37.0-py3-none-any.whl", "imports": ["imageio"], "install_dir": "site", "name": "imageio", "package_type": "package", "sha256": "f9af831a6e7d9b55adbd9f1c2aa40667550ed09265ca1dc2636236ee53f945e0", "unvendored_tests": false, "version": "2.37.0"}, "imgui-bundle": {"depends": ["pydantic", "munch", "numpy"], "file_name": "imgui_bundle-1.92.4-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["imgui_bundle"], "install_dir": "site", "name": "imgui-bundle", "package_type": "package", "sha256": "2ac186d7a0f22b093c766bc5fba6e9e299d99fab8c290c4963181bea1a03ffe5", "unvendored_tests": true, "version": "1.92.4"}, "imgui-bundle-tests": {"depends": ["imgui-bundle"], "file_name": "imgui-bundle-tests.tar", "imports": [], "install_dir": "site", "name": "imgui-bundle-tests", "package_type": "package", "sha256": "18654d836f70b906a516f7e116f6c4789adf1e61a9d763ca8a59bafe149a544a", "unvendored_tests": false, "version": "1.92.4"}, "iminuit": {"depends": ["numpy"], "file_name": "iminuit-2.30.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["iminuit"], "install_dir": "site", "name": "iminuit", "package_type": "package", "sha256": "62b3b007d1cf6dbbecd5c054f8bef8562c224a4f127733d6fa571fa27957a243", "unvendored_tests": false, "version": "2.30.1"}, "iniconfig": {"depends": [], "file_name": "iniconfig-2.1.0-py3-none-any.whl", "imports": ["iniconfig"], "install_dir": "site", "name": "iniconfig", "package_type": "package", "sha256": "141afb191b247fa924232a589108b3391113d80e8b53902730e6d3efedac30cf", "unvendored_tests": false, "version": "2.1.0"}, "inspice": {"depends": ["numpy", "matplotlib", "pyyaml", "cffi", "diskcache", "h5py", "ply", "libngspice"], "file_name": "inspice-1.6.4.1-py3-none-any.whl", "imports": ["InSpice"], "install_dir": "site", "name": "inspice", "package_type": "package", "sha256": "c7cd694127cfe87b20cff5d29449745fd242fe7388f3ad6aa2705f3075349d9a", "unvendored_tests": false, "version": "1.6.4.1"}, "ipython": {"depends": ["asttokens", "decorator", "executing", "matplotlib-inline", "prompt_toolkit", "pure-eval", "pygments", "six", "stack-data", "traitlets", "sqlite3", "wcwidth"], "file_name": "ipython-9.0.2-py3-none-any.whl", "imports": ["IPython"], "install_dir": "site", "name": "ipython", "package_type": "package", "sha256": "1cd4500bf130562204ea0a029e2f98fc386ab79629c42f608429590d886c83d5", "unvendored_tests": true, "version": "9.0.2"}, "ipython-tests": {"depends": ["ipython"], "file_name": "ipython-tests.tar", "imports": [], "install_dir": "site", "name": "ipython-tests", "package_type": "package", "sha256": "27d4cd74a4711e6a84368b4e829714679a8884f3790f6b54bfe0446b5ae378fe", "unvendored_tests": false, "version": "9.0.2"}, "jedi": {"depends": ["parso"], "file_name": "jedi-0.19.2-cp313-none-any.whl", "imports": ["jedi"], "install_dir": "site", "name": "jedi", "package_type": "package", "sha256": "3cb28dff9acde97d48df8d95c6275f75d8d7ab31dc68be5659a6a2208a888951", "unvendored_tests": true, "version": "0.19.2"}, "jedi-tests": {"depends": ["jedi"], "file_name": "jedi-tests.tar", "imports": [], "install_dir": "site", "name": "jedi-tests", "package_type": "package", "sha256": "83220d4411c3f9353d9c01f4bddff48acb2daf1f9a5cbe86e9bc005932aed841", "unvendored_tests": false, "version": "0.19.2"}, "jinja2": {"depends": ["markupsafe"], "file_name": "jinja2-3.1.6-cp313-none-any.whl", "imports": ["jinja2"], "install_dir": "site", "name": "Jinja2", "package_type": "package", "sha256": "85abd11e5715ba821b630ba7e32909b7bb1c9ae170ee1f20ec0f90121f81bfb3", "unvendored_tests": false, "version": "3.1.6"}, "jiter": {"depends": [], "file_name": "jiter-0.9.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["jiter"], "install_dir": "site", "name": "jiter", "package_type": "package", "sha256": "69fc995fab57b81727062c7cfdd6922658ae8c320e29af3d3a4b8f227b984b4d", "unvendored_tests": false, "version": "0.9.0"}, "joblib": {"depends": [], "file_name": "joblib-1.4.2-cp313-none-any.whl", "imports": ["joblib"], "install_dir": "site", "name": "joblib", "package_type": "package", "sha256": "12fe0679dc94530b30fa88497e06c52fd6f15b091ba9602a1e58153ef49fd99d", "unvendored_tests": true, "version": "1.4.2"}, "joblib-tests": {"depends": ["joblib"], "file_name": "joblib-tests.tar", "imports": [], "install_dir": "site", "name": "joblib-tests", "package_type": "package", "sha256": "f99c9730662d553fb7c71d9905796b9a36bc18b753008f885bf614fd23a8a343", "unvendored_tests": false, "version": "1.4.2"}, "jsonpatch": {"depends": ["jsonpointer"], "file_name": "jsonpatch-1.33-py2.py3-none-any.whl", "imports": ["jsonpatch"], "install_dir": "site", "name": "jsonpatch", "package_type": "package", "sha256": "932997e42e9468342b8c8d359c8da92ee71eb82d3612c46a4793c67758ba1c31", "unvendored_tests": false, "version": "1.33"}, "jsonpointer": {"depends": [], "file_name": "jsonpointer-3.0.0-py2.py3-none-any.whl", "imports": ["jsonpointer"], "install_dir": "site", "name": "jsonpointer", "package_type": "package", "sha256": "0697364e01aac2f708c64f29c214105e21ea239c9a7e32ea71e4b37d192cee90", "unvendored_tests": false, "version": "3.0.0"}, "jsonschema": {"depends": ["attrs", "pyrsistent", "referencing", "jsonschema_specifications"], "file_name": "jsonschema-4.23.0-py3-none-any.whl", "imports": ["jsonschema"], "install_dir": "site", "name": "jsonschema", "package_type": "package", "sha256": "5178a630760e05b5ce4392fb885e0bdd24a9bc5939006b5a88a0a63d402f0b60", "unvendored_tests": true, "version": "4.23.0"}, "jsonschema-specifications": {"depends": ["referencing"], "file_name": "jsonschema_specifications-2024.10.1-py3-none-any.whl", "imports": ["jsonschema_specifications"], "install_dir": "site", "name": "jsonschema_specifications", "package_type": "package", "sha256": "40a4885255fc56c2fb671eb656a3be0501b1185a59aad6e67dde3cee0d2d916d", "unvendored_tests": true, "version": "2024.10.1"}, "jsonschema-specifications-tests": {"depends": ["jsonschema_specifications"], "file_name": "jsonschema-specifications-tests.tar", "imports": [], "install_dir": "site", "name": "jsonschema_specifications-tests", "package_type": "package", "sha256": "c46b7d5a07f445aed287f5a806bdf3cc030ed94c149581a353aacc213b1809bb", "unvendored_tests": false, "version": "2024.10.1"}, "jsonschema-tests": {"depends": ["jsonschema"], "file_name": "jsonschema-tests.tar", "imports": [], "install_dir": "site", "name": "jsonschema-tests", "package_type": "package", "sha256": "5558631e5cd8c27c5997349ed0ad5df44bd6d30b33b15397cef8a2a243cddb2d", "unvendored_tests": false, "version": "4.23.0"}, "kiwisolver": {"depends": [], "file_name": "kiwisolver-1.4.8-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["kiwisolver"], "install_dir": "site", "name": "kiwisolver", "package_type": "package", "sha256": "4adad9198def22bfc1f7e55c662f1fca957f726a6cb011b9b5235c12d3b54fdb", "unvendored_tests": false, "version": "1.4.8"}, "lakers-python": {"depends": [], "file_name": "lakers_python-0.6.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["lakers"], "install_dir": "site", "name": "lakers-python", "package_type": "package", "sha256": "60239e9e85ee953e9a9edb13a8810e89659c9d532444e4d55d32ed047170792e", "unvendored_tests": false, "version": "0.6.0"}, "lazy-loader": {"depends": [], "file_name": "lazy_loader-0.4-py3-none-any.whl", "imports": ["lazy_loader"], "install_dir": "site", "name": "lazy_loader", "package_type": "package", "sha256": "b46b6d7f9124873396e5e8ca0656adb11c8edf59934e93be8699d293a5ba9e7b", "unvendored_tests": true, "version": "0.4"}, "lazy-loader-tests": {"depends": ["lazy_loader"], "file_name": "lazy-loader-tests.tar", "imports": [], "install_dir": "site", "name": "lazy_loader-tests", "package_type": "package", "sha256": "4de49164cb79121e4c0701cf72ca50dfa70a1c25c226647be5d934acc6396653", "unvendored_tests": false, "version": "0.4"}, "lazy-object-proxy": {"depends": [], "file_name": "lazy_object_proxy-1.10.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["lazy_object_proxy"], "install_dir": "site", "name": "lazy-object-proxy", "package_type": "package", "sha256": "f78136e4bf7e17b01537752b392597bebf2b01807f79696421173e7f609225df", "unvendored_tests": false, "version": "1.10.0"}, "libcrc32c": {"depends": [], "file_name": "libcrc32c-1.1.0.zip", "imports": [], "install_dir": "dynlib", "name": "libcrc32c", "package_type": "shared_library", "sha256": "dd59006ba799fff18f02829338fedfe5d8eeba51bbd9ad9e712551ec93d5cc50", "unvendored_tests": false, "version": "1.1.0"}, "libcst": {"depends": ["pyyaml"], "file_name": "libcst-1.6.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["libcst"], "install_dir": "site", "name": "libcst", "package_type": "package", "sha256": "8ed555b5850c35e6c072f0965c5615df06e13a23a0dd60f192406080704ffe55", "unvendored_tests": true, "version": "1.6.0"}, "libcst-tests": {"depends": ["libcst"], "file_name": "libcst-tests.tar", "imports": [], "install_dir": "site", "name": "libcst-tests", "package_type": "package", "sha256": "bae8e946ce84316132a3e997c11d11336552371e897e885a683e06ec25ee8c11", "unvendored_tests": false, "version": "1.6.0"}, "libgdal": {"depends": ["libgeos"], "file_name": "libgdal-3.8.3.zip", "imports": [], "install_dir": "dynlib", "name": "libgdal", "package_type": "shared_library", "sha256": "c2e47d21f9ae47a12177c9f7d4aeaa8b7528fbf87a88d77778a159f910af459c", "unvendored_tests": false, "version": "3.8.3"}, "libgeos": {"depends": [], "file_name": "libgeos-3.12.1.zip", "imports": [], "install_dir": "dynlib", "name": "libgeos", "package_type": "shared_library", "sha256": "92899a5b7734ecef7dcf0f3f84cf73dbd48847f67c29d59555b6dc609940816b", "unvendored_tests": false, "version": "3.12.1"}, "libhdf5": {"depends": [], "file_name": "libhdf5-1.12.1.zip", "imports": [], "install_dir": "dynlib", "name": "libhdf5", "package_type": "shared_library", "sha256": "ea36748b4e800267ee2f237ebb1db8880a3a15344ee18333487befc936935fc5", "unvendored_tests": false, "version": "1.12.1"}, "libheif": {"depends": [], "file_name": "libheif-1.12.0.zip", "imports": [], "install_dir": "dynlib", "name": "libheif", "package_type": "shared_library", "sha256": "3bd6978820e070d61f5acc48cdc9fcf8e601477597117e7946d46de390bd283d", "unvendored_tests": false, "version": "1.12.0"}, "libmagic": {"depends": [], "file_name": "libmagic-5.42.zip", "imports": [], "install_dir": "dynlib", "name": "libmagic", "package_type": "shared_library", "sha256": "cae7434e74f870e730cd3584f94352adb2a61d6a0c6cfa2b97365a51b3978021", "unvendored_tests": false, "version": "5.42"}, "libngspice": {"depends": [], "file_name": "libngspice-44.2.zip", "imports": [], "install_dir": "dynlib", "name": "libngspice", "package_type": "shared_library", "sha256": "d6a0fe29032d30653f44b24553b4efdff65efee13cfd732ea47fb09525768d3f", "unvendored_tests": false, "version": "44.2"}, "libopenblas": {"depends": [], "file_name": "libopenblas-0.3.26.zip", "imports": [], "install_dir": "dynlib", "name": "libopenblas", "package_type": "shared_library", "sha256": "f8f5db65c9367ed7f057d0ee853d94ddb3c007968aa8138253461dad42537fa2", "unvendored_tests": false, "version": "0.3.26"}, "libopenssl": {"depends": [], "file_name": "libopenssl-1.1.1w.zip", "imports": [], "install_dir": "dynlib", "name": "libopenssl", "package_type": "shared_library", "sha256": "eaec7126f466a33ea4121fd230211bb01e9ad1c5748f3cd0b4b1c8677b4ac90a", "unvendored_tests": false, "version": "1.1.1w"}, "libproj": {"depends": [], "file_name": "libproj-9.6.2.zip", "imports": [], "install_dir": "dynlib", "name": "libproj", "package_type": "shared_library", "sha256": "8739c76e681f900923b900c9df0ef75cf421d39cabb54650c4b9ad19b6a76d85", "unvendored_tests": false, "version": "9.6.2"}, "libsuitesparse": {"depends": ["libopenblas"], "file_name": "libsuitesparse-5.11.0.zip", "imports": [], "install_dir": "dynlib", "name": "libsuitesparse", "package_type": "shared_library", "sha256": "8883746009a4fc5aa2b83cf109c37e5fb0c6e9db270b0ca4b4f87c762d831db9", "unvendored_tests": false, "version": "5.11.0"}, "libtaglib": {"depends": [], "file_name": "libtaglib-2.1.1.zip", "imports": [], "install_dir": "dynlib", "name": "libtaglib", "package_type": "shared_library", "sha256": "9783f638d2f124f9546a902b85186fc92b1b99b05e5e1853d938975df95bd075", "unvendored_tests": false, "version": "2.1.1"}, "lightgbm": {"depends": ["numpy", "scipy", "scikit-learn"], "file_name": "lightgbm-4.6.0-py3-none-pyodide_2025_0_wasm32.whl", "imports": ["lightgbm"], "install_dir": "site", "name": "lightgbm", "package_type": "package", "sha256": "75bb0670f69b252c19b3a546433c1fdd6ddb0a6234e2575b35bc655dec0f620b", "unvendored_tests": false, "version": "4.6.0"}, "logbook": {"depends": ["ssl"], "file_name": "logbook-1.8.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["logbook"], "install_dir": "site", "name": "logbook", "package_type": "package", "sha256": "2cb7f2954a26095d7217079692a39ec2754565945ab75e1ce0adfd5dbc1c37d2", "unvendored_tests": false, "version": "1.8.0"}, "lxml": {"depends": [], "file_name": "lxml-6.0.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["lxml"], "install_dir": "site", "name": "lxml", "package_type": "package", "sha256": "99b959a55eaeb41a2997fa022859892880c2b708af01ff336c34c7b125c80916", "unvendored_tests": false, "version": "6.0.2"}, "lz4": {"depends": [], "file_name": "lz4-4.4.5-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["lz4"], "install_dir": "site", "name": "lz4", "package_type": "package", "sha256": "2f3d8c272bc379a0722201073ba9912770d504bc6a2a576047b0b2d57bf69574", "unvendored_tests": false, "version": "4.4.5"}, "lzma": {"depends": [], "file_name": "lzma-1.0.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["lzma", "_lzma"], "install_dir": "site", "name": "lzma", "package_type": "cpython_module", "sha256": "2489604bcd9446eb1a40be1fcd8a989d0985499a0cb350fc6593aa626b27a05e", "unvendored_tests": false, "version": "1.0.0"}, "markupsafe": {"depends": [], "file_name": "markupsafe-3.0.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["markupsafe"], "install_dir": "site", "name": "MarkupSafe", "package_type": "package", "sha256": "67b04d480a9be0cc3c1edc43a99de1e2db2235ba80a355af96348142df2e83c4", "unvendored_tests": false, "version": "3.0.2"}, "matplotlib": {"depends": ["contourpy", "cycler", "fonttools", "kiwisolver", "numpy", "packaging", "pillow", "pyparsing", "python-dateutil", "pytz"], "file_name": "matplotlib-3.8.4-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pylab", "mpl_toolkits", "matplotlib"], "install_dir": "site", "name": "matplotlib", "package_type": "package", "sha256": "601aa41007520803974d7bb52f3738b736d2260285e6b71375b9356a5b8d9896", "unvendored_tests": true, "version": "3.8.4"}, "matplotlib-inline": {"depends": ["traitlets"], "file_name": "matplotlib_inline-0.2.1-py3-none-any.whl", "imports": ["matplotlib-inline"], "install_dir": "site", "name": "matplotlib-inline", "package_type": "package", "sha256": "aaeaba20ce1cb410ea322be58363ea043ce72e303bbb21126e0ca2de26f4d22d", "unvendored_tests": false, "version": "0.2.1"}, "matplotlib-tests": {"depends": ["matplotlib"], "file_name": "matplotlib-tests.tar", "imports": [], "install_dir": "site", "name": "matplotlib-tests", "package_type": "package", "sha256": "e369fa872c6634fb47cdd8c7529eaea15525d1b23e3fcfd5b94feec42184f10b", "unvendored_tests": false, "version": "3.8.4"}, "memory-allocator": {"depends": [], "file_name": "memory_allocator-0.1.4-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["memory_allocator"], "install_dir": "site", "name": "memory-allocator", "package_type": "package", "sha256": "04a7a7cec09e3410f9934f37de2e944adfc2af0a0d96ce4c87bcae42dcc225e8", "unvendored_tests": false, "version": "0.1.4"}, "micropip": {"depends": [], "file_name": "micropip-0.11.0-py3-none-any.whl", "imports": ["micropip"], "install_dir": "site", "name": "micropip", "package_type": "package", "sha256": "0ae422514e45d068b8159eb8ec3b2c3f4cbce2e664e26cb81735dbe4af2377a1", "unvendored_tests": false, "version": "0.11.0"}, "ml-dtypes": {"depends": ["numpy"], "file_name": "ml_dtypes-0.5.4-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["ml_dtypes"], "install_dir": "site", "name": "ml_dtypes", "package_type": "package", "sha256": "6f700837e66c1ba13199ebab7d8096472db10571e5b34a11343a2d636bcb696d", "unvendored_tests": false, "version": "0.5.4"}, "mmh3": {"depends": [], "file_name": "mmh3-5.1.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["mmh3"], "install_dir": "site", "name": "mmh3", "package_type": "package", "sha256": "9a2a114fee30ef9a762648472b81a3a982e491c1836b616c9bfbaeb5f47ec638", "unvendored_tests": false, "version": "5.1.0"}, "more-itertools": {"depends": [], "file_name": "more_itertools-10.6.0-py3-none-any.whl", "imports": ["more_itertools"], "install_dir": "site", "name": "more-itertools", "package_type": "package", "sha256": "14de567c4b1ec60c7a0a066ddfd72088f0b0da1f828f6d1f6d79015f3b9ad87a", "unvendored_tests": false, "version": "10.6.0"}, "mpmath": {"depends": [], "file_name": "mpmath-1.3.0-cp313-none-any.whl", "imports": ["mpmath"], "install_dir": "site", "name": "mpmath", "package_type": "package", "sha256": "de2506a39efe958867be2b55dffe163c2930570aff0998a17a28f3af51687ab0", "unvendored_tests": true, "version": "1.3.0"}, "mpmath-tests": {"depends": ["mpmath"], "file_name": "mpmath-tests.tar", "imports": [], "install_dir": "site", "name": "mpmath-tests", "package_type": "package", "sha256": "d8e5d23684f5f4b95da9804737329f431550a8f9c4da4691b25b5846b57726f9", "unvendored_tests": false, "version": "1.3.0"}, "msgpack": {"depends": [], "file_name": "msgpack-1.1.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["msgpack"], "install_dir": "site", "name": "msgpack", "package_type": "package", "sha256": "802f05c8e529672806576596d6c37f49a58656d316c32ca1c1f96f6bb70b00a3", "unvendored_tests": false, "version": "1.1.2"}, "msgspec": {"depends": [], "file_name": "msgspec-0.19.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["msgspec"], "install_dir": "site", "name": "msgspec", "package_type": "package", "sha256": "d7fffe4d004646d47c875dd3b5489d25c14591ee02594bf9e69a5186499e421a", "unvendored_tests": false, "version": "0.19.0"}, "msprime": {"depends": ["numpy", "newick", "tskit", "demes", "rpds-py"], "file_name": "msprime-1.3.3-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["msprime"], "install_dir": "site", "name": "msprime", "package_type": "package", "sha256": "6cc9d1702506a0ec23c0edf602c3f516c9f7c5c2056859cef8423d65024363e9", "unvendored_tests": false, "version": "1.3.3"}, "multidict": {"depends": [], "file_name": "multidict-6.7.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["multidict"], "install_dir": "site", "name": "multidict", "package_type": "package", "sha256": "c7db3ee26fddee527406fef580d21aadb79adde44b61bc14ddac4977d31ea393", "unvendored_tests": false, "version": "6.7.0"}, "munch": {"depends": ["setuptools", "six"], "file_name": "munch-4.0.0-py2.py3-none-any.whl", "imports": ["munch"], "install_dir": "site", "name": "munch", "package_type": "package", "sha256": "a52d9ba576b9e0ce29b711c4451bfd7040a8e5d33f41819c98b03ae555e5839f", "unvendored_tests": false, "version": "4.0.0"}, "mypy": {"depends": [], "file_name": "mypy-1.15.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["mypyc", "mypy"], "install_dir": "site", "name": "mypy", "package_type": "package", "sha256": "4fd93f836f74be201f5c783d4d54b8957cfe6ac422cbcdb8b35cdb6d60f096a4", "unvendored_tests": true, "version": "1.15.0"}, "mypy-tests": {"depends": ["mypy"], "file_name": "mypy-tests.tar", "imports": [], "install_dir": "site", "name": "mypy-tests", "package_type": "package", "sha256": "5de2ddc2a3b5b64aaf92d76c0222121793cf886526a23c881561d9dbc5ff18b1", "unvendored_tests": false, "version": "1.15.0"}, "narwhals": {"depends": [], "file_name": "narwhals-2.15.0-py3-none-any.whl", "imports": ["narwhals"], "install_dir": "site", "name": "narwhals", "package_type": "package", "sha256": "bef7de68cf772cbac41808a772e12e68468e4736d7d03ca6103d5833361fac8d", "unvendored_tests": false, "version": "2.15.0"}, "ndindex": {"depends": [], "file_name": "ndindex-1.9.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["ndindex"], "install_dir": "site", "name": "ndindex", "package_type": "package", "sha256": "35d5fd03c16827a337006eb391cae62250360e60f815d104ce6f44392d3bb508", "unvendored_tests": true, "version": "1.9.2"}, "ndindex-tests": {"depends": ["ndindex"], "file_name": "ndindex-tests.tar", "imports": [], "install_dir": "site", "name": "ndindex-tests", "package_type": "package", "sha256": "d549d918c71f2491dae952f15f26c5770dbe6e35598a31effc8c7faa2f67e6c7", "unvendored_tests": false, "version": "1.9.2"}, "netcdf4": {"depends": ["numpy", "packaging", "h5py", "cftime", "certifi", "libhdf5"], "file_name": "netcdf4-1.7.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["netCDF4"], "install_dir": "site", "name": "netcdf4", "package_type": "package", "sha256": "dc1a17b676477265f95bf219a056dd44faddce49efa23c53e631d33e1db684a7", "unvendored_tests": false, "version": "1.7.2"}, "networkx": {"depends": ["decorator", "setuptools", "matplotlib", "numpy"], "file_name": "networkx-3.4.2-py3-none-any.whl", "imports": ["networkx"], "install_dir": "site", "name": "networkx", "package_type": "package", "sha256": "a29f3036b00fa0fe1562a31feac086848f55f3c0a36e9bf76e89201be939e3ac", "unvendored_tests": true, "version": "3.4.2"}, "networkx-tests": {"depends": ["networkx"], "file_name": "networkx-tests.tar", "imports": [], "install_dir": "site", "name": "networkx-tests", "package_type": "package", "sha256": "fb9faecf96ece9717bb9292edfd3b574c71a22c7426dc0754118ba669db0a3e2", "unvendored_tests": false, "version": "3.4.2"}, "newick": {"depends": [], "file_name": "newick-1.9.0-py2.py3-none-any.whl", "imports": ["newick"], "install_dir": "site", "name": "newick", "package_type": "package", "sha256": "ab63c8d58dfb570b30db2f89eeffb08078472be0cf879ff204ba3bdd33842c46", "unvendored_tests": false, "version": "1.9.0"}, "nh3": {"depends": [], "file_name": "nh3-0.2.21-cp38-abi3-pyodide_2025_0_wasm32.whl", "imports": ["nh3"], "install_dir": "site", "name": "nh3", "package_type": "package", "sha256": "db3a9a2828e109400ce361c8e9f2deeb8f49b41d870cae19377a9c5ed1a19d88", "unvendored_tests": false, "version": "0.2.21"}, "nlopt": {"depends": ["numpy"], "file_name": "nlopt-2.9.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["nlopt"], "install_dir": "site", "name": "nlopt", "package_type": "package", "sha256": "63016ec96c03154c9c57f8627e732a1ae6e04a03f8a04be6d823919f86eac70f", "unvendored_tests": false, "version": "2.9.1"}, "nltk": {"depends": ["regex", "sqlite3"], "file_name": "nltk-3.9.1-py3-none-any.whl", "imports": ["nltk"], "install_dir": "site", "name": "nltk", "package_type": "package", "sha256": "17ed6948bd75a0cba27a7a99f08c9f348dbb376ae069022e8c3cec622904102a", "unvendored_tests": true, "version": "3.9.1"}, "nltk-tests": {"depends": ["nltk"], "file_name": "nltk-tests.tar", "imports": [], "install_dir": "site", "name": "nltk-tests", "package_type": "package", "sha256": "2e22290acde6cbceef7a0a6ed3728b627559ee768799fbb334b5831d8489cfc6", "unvendored_tests": false, "version": "3.9.1"}, "numcodecs": {"depends": ["numpy", "msgpack"], "file_name": "numcodecs-0.13.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["numcodecs"], "install_dir": "site", "name": "numcodecs", "package_type": "package", "sha256": "da29b4c22dad035a96f0edb9a4f49d92eb3d760112865947ac791e98bc7ddb82", "unvendored_tests": true, "version": "0.13.1"}, "numcodecs-tests": {"depends": ["numcodecs"], "file_name": "numcodecs-tests.tar", "imports": [], "install_dir": "site", "name": "numcodecs-tests", "package_type": "package", "sha256": "dedcd6ca0cd61b5bb0df95673ddbc91710623f83be7c918c7910b7c9959d01cd", "unvendored_tests": false, "version": "0.13.1"}, "numpy": {"depends": [], "file_name": "numpy-2.2.5-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["numpy"], "install_dir": "site", "name": "numpy", "package_type": "package", "sha256": "be1aee57f9855e51543bc342aa7a4eb881552887d7ddd6df58fce1f43360f8de", "unvendored_tests": false, "version": "2.2.5"}, "numpy-tests": {"depends": [], "file_name": "numpy_tests-2.2.5-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["numpy-tests"], "install_dir": "site", "name": "numpy-tests", "package_type": "package", "sha256": "9162518247787fb647890f2a4bc4af7b6b5c720aab43c9f8c20c5fad3b9fcc36", "unvendored_tests": false, "version": "2.2.5"}, "openai": {"depends": ["httpx", "pydantic", "typing-extensions", "distro", "anyio", "jiter"], "file_name": "openai-1.68.2-py3-none-any.whl", "imports": ["openai"], "install_dir": "site", "name": "openai", "package_type": "package", "sha256": "55485cde95b81742b2e3ae57f6a2f02dc51696e6fba0989299a6eabc7003c8da", "unvendored_tests": false, "version": "1.68.2"}, "opencv-python": {"depends": ["numpy"], "file_name": "opencv_python-4.11.0.86-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["cv2"], "install_dir": "site", "name": "opencv-python", "package_type": "package", "sha256": "a8b116def8c74b3ccf389b856b3ccb5cec5a2efc295ec17a15ea9cda1f88aa1e", "unvendored_tests": false, "version": "4.11.0.86"}, "optlang": {"depends": ["sympy", "six", "swiglpk"], "file_name": "optlang-1.8.3-py2.py3-none-any.whl", "imports": ["optlang"], "install_dir": "site", "name": "optlang", "package_type": "package", "sha256": "0efd4f2474919e5834f707540db8e0ba4cae9d7aa9a3bd6bb778092c1ad423f2", "unvendored_tests": true, "version": "1.8.3"}, "optlang-tests": {"depends": ["optlang"], "file_name": "optlang-tests.tar", "imports": [], "install_dir": "site", "name": "optlang-tests", "package_type": "package", "sha256": "0dae9b248d5c81bd590ee3ffad6d8b6d021b39cbbac7b5cb74541e1bebda4391", "unvendored_tests": false, "version": "1.8.3"}, "orjson": {"depends": [], "file_name": "orjson-3.10.16-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["orjson"], "install_dir": "site", "name": "orjson", "package_type": "package", "sha256": "4b815ae28eef5332e898e220ec3f7de4d0cb5067aa895db589bb05989bb2608b", "unvendored_tests": false, "version": "3.10.16"}, "packaging": {"depends": [], "file_name": "packaging-24.2-cp313-none-any.whl", "imports": ["packaging"], "install_dir": "site", "name": "packaging", "package_type": "package", "sha256": "b31c560f29c2a833594c6abc17a16941c94dc820e34bf25968df3df10491c62e", "unvendored_tests": false, "version": "24.2"}, "pandas": {"depends": ["numpy", "python-dateutil", "pytz"], "file_name": "pandas-2.3.3-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pandas"], "install_dir": "site", "name": "pandas", "package_type": "package", "sha256": "99859c36dcf18e00774b4168b9cdf7a3e40aa5cff19b1dcaf41cc6e99d5c81c9", "unvendored_tests": true, "version": "2.3.3"}, "pandas-tests": {"depends": ["pandas"], "file_name": "pandas-tests.tar", "imports": [], "install_dir": "site", "name": "pandas-tests", "package_type": "package", "sha256": "d5f994d07ff84875b87f135ff944fc0e970dd7e599b315c48642afeeba7e6731", "unvendored_tests": false, "version": "2.3.3"}, "parso": {"depends": [], "file_name": "parso-0.8.4-cp313-none-any.whl", "imports": ["parso"], "install_dir": "site", "name": "parso", "package_type": "package", "sha256": "36509dd8ff7541ab7830bcdcd108042f2fb470b334d8776e91675b3aa063b805", "unvendored_tests": false, "version": "0.8.4"}, "patsy": {"depends": ["numpy", "six"], "file_name": "patsy-1.0.1-py2.py3-none-any.whl", "imports": ["patsy"], "install_dir": "site", "name": "patsy", "package_type": "package", "sha256": "34d2156b3db04a1c565dad7072d3cff22e02c22b72a531e1d3ee3a9442e7f4e7", "unvendored_tests": true, "version": "1.0.1"}, "patsy-tests": {"depends": ["patsy"], "file_name": "patsy-tests.tar", "imports": [], "install_dir": "site", "name": "patsy-tests", "package_type": "package", "sha256": "b31f9b8a7d2212239c2a6b52547bc57af570586e785399e7de048c7f754a9a23", "unvendored_tests": false, "version": "1.0.1"}, "pcodec": {"depends": ["numpy"], "file_name": "pcodec-0.3.3-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pcodec"], "install_dir": "site", "name": "pcodec", "package_type": "package", "sha256": "a0e34ad928aacb5eec9204573725835efa1191c9995bb1b690e6d15b0100edf4", "unvendored_tests": false, "version": "0.3.3"}, "peewee": {"depends": ["sqlite3", "cffi"], "file_name": "peewee-3.17.9-py3-none-any.whl", "imports": ["peewee"], "install_dir": "site", "name": "peewee", "package_type": "package", "sha256": "540439a57875866a9880818f2ed5982d67220c11b94e154b18da736262ad49a9", "unvendored_tests": true, "version": "3.17.9"}, "peewee-tests": {"depends": ["peewee"], "file_name": "peewee-tests.tar", "imports": [], "install_dir": "site", "name": "peewee-tests", "package_type": "package", "sha256": "eded3f39bec30ef6a171068b23429c7967fdeacf36fcf758aaed8030068ed920", "unvendored_tests": false, "version": "3.17.9"}, "pi-heif": {"depends": ["cffi", "pillow", "libheif"], "file_name": "pi_heif-0.21.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pi_heif"], "install_dir": "site", "name": "pi-heif", "package_type": "package", "sha256": "6929ba48c15bbb914c2b52c76d7d8e6d909114dbef49fad7dc3fffa8def2549a", "unvendored_tests": false, "version": "0.21.0"}, "pillow": {"depends": [], "file_name": "pillow-11.3.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["PIL"], "install_dir": "site", "name": "Pillow", "package_type": "package", "sha256": "82dd784b55582729f7631b84dcaf2eded2fe78d216d33dd1680e59633cabee84", "unvendored_tests": false, "version": "11.3.0"}, "pillow-heif": {"depends": ["cffi", "pillow", "libheif"], "file_name": "pillow_heif-1.1.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pillow_heif"], "install_dir": "site", "name": "pillow-heif", "package_type": "package", "sha256": "3304a87c7ca9371c43725f67e070a7a143493d9cbdbb4c5203b6641a2c223ad6", "unvendored_tests": false, "version": "1.1.1"}, "pkgconfig": {"depends": [], "file_name": "pkgconfig-1.5.5-py3-none-any.whl", "imports": ["pkgconfig"], "install_dir": "site", "name": "pkgconfig", "package_type": "package", "sha256": "48f41d6739ec0941055e25efea42881b6970416fca506caf4b047eecde189e91", "unvendored_tests": false, "version": "1.5.5"}, "platformdirs": {"depends": [], "file_name": "platformdirs-4.3.6-py3-none-any.whl", "imports": ["platformdirs"], "install_dir": "site", "name": "platformdirs", "package_type": "package", "sha256": "909ec75bf144b5641ece53173061f820f8df7daf754cd4016d2c17c93018c118", "unvendored_tests": false, "version": "4.3.6"}, "pluggy": {"depends": [], "file_name": "pluggy-1.5.0-py3-none-any.whl", "imports": ["pluggy"], "install_dir": "site", "name": "pluggy", "package_type": "package", "sha256": "a5526e777aac76c926e884d8c5f8104a909e1243a2f3ecc6b9bb1b52fa46f7bd", "unvendored_tests": false, "version": "1.5.0"}, "ply": {"depends": [], "file_name": "ply-3.11-py2.py3-none-any.whl", "imports": ["ply"], "install_dir": "site", "name": "ply", "package_type": "package", "sha256": "00278ab037f4e6068af477e5fc3553f78e2c824aad9595160061058aa77a954f", "unvendored_tests": false, "version": "3.11"}, "pplpy": {"depends": ["gmpy2", "cysignals"], "file_name": "pplpy-0.8.10-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["ppl"], "install_dir": "site", "name": "pplpy", "package_type": "package", "sha256": "a400cd911dcaf95161588d31ff2eba7b7e73de92f9842b27b290918280a68216", "unvendored_tests": false, "version": "0.8.10"}, "primecountpy": {"depends": ["cysignals"], "file_name": "primecountpy-0.1.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["primecountpy"], "install_dir": "site", "name": "primecountpy", "package_type": "package", "sha256": "b1a52c5537f1e8162bf2cd2b8974aea86f2420890c2bd5b8fef2bfc3fc468f54", "unvendored_tests": false, "version": "0.1.1"}, "prompt-toolkit": {"depends": ["wcwidth"], "file_name": "prompt_toolkit-3.0.50-py3-none-any.whl", "imports": ["prompt_toolkit"], "install_dir": "site", "name": "prompt_toolkit", "package_type": "package", "sha256": "c850b8c5f71eeda05fc0237ec2ca75ce74d96baf398ec0f3af7b7b582b5eb4eb", "unvendored_tests": false, "version": "3.0.50"}, "propcache": {"depends": [], "file_name": "propcache-0.3.0-py3-none-any.whl", "imports": ["propcache"], "install_dir": "site", "name": "propcache", "package_type": "package", "sha256": "b6676a4e95b3e2e43515b4606c48c1f6f907c7e552caaea17140948c94817f1c", "unvendored_tests": false, "version": "0.3.0"}, "protobuf": {"depends": [], "file_name": "protobuf-6.31.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["google"], "install_dir": "site", "name": "protobuf", "package_type": "package", "sha256": "c37921bc1631dfac55b654563a45df630eb963c720e1092ffe6cd8a388f9ae5b", "unvendored_tests": false, "version": "6.31.1"}, "pure-eval": {"depends": [], "file_name": "pure_eval-0.2.3-py3-none-any.whl", "imports": ["pure_eval"], "install_dir": "site", "name": "pure-eval", "package_type": "package", "sha256": "4e68524914448c8b2d74da68820e3270789745dab658c25cf1e011203e51ee58", "unvendored_tests": false, "version": "0.2.3"}, "py": {"depends": [], "file_name": "py-1.11.0-py2.py3-none-any.whl", "imports": ["py"], "install_dir": "site", "name": "py", "package_type": "package", "sha256": "425c7054bd6b8ee8efb556b04c88889bf64e0e4a5a7c210b14adbffc26fc0783", "unvendored_tests": false, "version": "1.11.0"}, "pyarrow": {"depends": ["numpy", "pandas", "pyodide-unix-timezones"], "file_name": "pyarrow-22.0.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pyarrow"], "install_dir": "site", "name": "pyarrow", "package_type": "package", "sha256": "b5c6b7b7aa72627071f414bc19ff762012e1052ee0634a30cd7f2c57dd6d84ba", "unvendored_tests": false, "version": "22.0.0"}, "pycdfpp": {"depends": ["numpy", "pyyaml"], "file_name": "pycdfpp-0.8.5-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pycdfpp"], "install_dir": "site", "name": "pycdfpp", "package_type": "package", "sha256": "07ab0a2dd561fd99edf24b8a131fbac590ca7ba978345d33921917fcb341cfca", "unvendored_tests": false, "version": "0.8.5"}, "pyclipper": {"depends": [], "file_name": "pyclipper-1.3.0.post6-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pyclipper"], "install_dir": "site", "name": "pyclipper", "package_type": "package", "sha256": "7d7af1b80ac33383a87e21df5839bd9caf33500ea69cdaab50fa462e208b831b", "unvendored_tests": false, "version": "1.3.0.post6"}, "pycparser": {"depends": [], "file_name": "pycparser-2.22-py3-none-any.whl", "imports": ["pycparser"], "install_dir": "site", "name": "pycparser", "package_type": "package", "sha256": "778a41679914eee8499ce3d37a8d15d808d8972e70aa02eef13ac59649559aaa", "unvendored_tests": false, "version": "2.22"}, "pycryptodome": {"depends": [], "file_name": "pycryptodome-3.21.0-cp36-abi3-pyodide_2025_0_wasm32.whl", "imports": ["Crypto"], "install_dir": "site", "name": "pycryptodome", "package_type": "package", "sha256": "2d3bdd009cf49ec43e09ac3217b9fffd128a7d32dd3d2d112602b2d34e40174a", "unvendored_tests": true, "version": "3.21.0"}, "pycryptodome-tests": {"depends": ["pycryptodome"], "file_name": "pycryptodome-tests.tar", "imports": [], "install_dir": "site", "name": "pycryptodome-tests", "package_type": "package", "sha256": "61f21439f6956bbe2e339e6d4b437021b9250da64e04ba7ebaee0372fd534f94", "unvendored_tests": false, "version": "3.21.0"}, "pydantic": {"depends": ["typing-extensions", "pydantic_core", "annotated-types", "typing-inspection"], "file_name": "pydantic-2.12.5-py3-none-any.whl", "imports": ["pydantic"], "install_dir": "site", "name": "pydantic", "package_type": "package", "sha256": "a56b56d0a0942fbd5cf24a9c9195eb5bdfeceea17ddb3e1cd174db43be4e88dc", "unvendored_tests": false, "version": "2.12.5"}, "pydantic-core": {"depends": ["typing-extensions"], "file_name": "pydantic_core-2.41.5-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pydantic_core"], "install_dir": "site", "name": "pydantic_core", "package_type": "package", "sha256": "dd259177c9159a866334e2ac040aca973b8205cc884b3297cb5b2dc6bef8d629", "unvendored_tests": false, "version": "2.41.5"}, "pydecimal": {"depends": [], "file_name": "pydecimal-1.0.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["_pydecimal"], "install_dir": "site", "name": "pydecimal", "package_type": "cpython_module", "sha256": "de2ad05e281819096c73008eb8816b1ad5e7bc64a5539eabf2b131927a0e483a", "unvendored_tests": false, "version": "1.0.0"}, "pydoc-data": {"depends": [], "file_name": "pydoc_data-1.0.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pydoc_data"], "install_dir": "site", "name": "pydoc_data", "package_type": "cpython_module", "sha256": "d288a116e5592b16788b20dde1d75351129bbeeace4cf4c50b798df7fe535ef8", "unvendored_tests": false, "version": "1.0.0"}, "pyerfa": {"depends": ["numpy"], "file_name": "pyerfa-2.0.1.5-cp39-abi3-pyodide_2025_0_wasm32.whl", "imports": ["erfa"], "install_dir": "site", "name": "pyerfa", "package_type": "package", "sha256": "063e4a534e3ef00014683e8e5d896a3ebeb273d3a5cdd9f7a8c2ea6c30fca7c3", "unvendored_tests": true, "version": "2.0.1.5"}, "pyerfa-tests": {"depends": ["pyerfa"], "file_name": "pyerfa-tests.tar", "imports": [], "install_dir": "site", "name": "pyerfa-tests", "package_type": "package", "sha256": "8e9388e6240dadbb3493c9e238ae856413a4d0f79bb0747a4e2007ec0e805992", "unvendored_tests": false, "version": "2.0.1.5"}, "pygame-ce": {"depends": [], "file_name": "pygame_ce-2.5.6.dev2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pygame"], "install_dir": "site", "name": "pygame-ce", "package_type": "package", "sha256": "d7c52caf092288b6f813d8cf4c07edd98b47cc67385bc377147a8e5e12310872", "unvendored_tests": false, "version": "2.5.6.dev2"}, "pygments": {"depends": [], "file_name": "pygments-2.19.1-py3-none-any.whl", "imports": ["pygments"], "install_dir": "site", "name": "Pygments", "package_type": "package", "sha256": "1557c19a71c6c60b814ba3a921583ab97a15722fb21ba3ab73f2d6f477b49213", "unvendored_tests": false, "version": "2.19.1"}, "pyheif": {"depends": ["cffi"], "file_name": "pyheif-0.8.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pyheif"], "install_dir": "site", "name": "pyheif", "package_type": "package", "sha256": "a90413a3bcebf7c73a4a5a1317c6d8ca1b5e553936d2a15e04280f4303ea4d2c", "unvendored_tests": false, "version": "0.8.0"}, "pyiceberg": {"depends": ["click", "cachetools", "fsspec", "mmh3", "pydantic", "pyparsing", "requests", "rich", "sortedcontainers", "sqlalchemy", "strictyaml"], "file_name": "pyiceberg-0.10.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pyiceberg"], "install_dir": "site", "name": "pyiceberg", "package_type": "package", "sha256": "5f14f73c3cb98e1883931eea53e5de57609ed668f85382eb0b50b4a26aadbfdf", "unvendored_tests": false, "version": "0.10.0"}, "pyinstrument": {"depends": [], "file_name": "pyinstrument-5.0.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pyinstrument"], "install_dir": "site", "name": "pyinstrument", "package_type": "package", "sha256": "266504251136dd4c960e66c61f071d56abdbb363e3d91e68be26044356fd5185", "unvendored_tests": false, "version": "5.0.1"}, "pylimer-tools": {"depends": ["numpy"], "file_name": "pylimer_tools-0.3.13-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pylimer_tools"], "install_dir": "site", "name": "pylimer-tools", "package_type": "package", "sha256": "bf2eedb0103e6f958d7da4e666e25c396fc0ef588e3623d3a7c9fe07b5296216", "unvendored_tests": false, "version": "0.3.13"}, "pymupdf": {"depends": [], "file_name": "pymupdf-1.26.3-cp313-none-pyodide_2025_0_wasm32.whl", "imports": ["pymupdf", "fitz"], "install_dir": "site", "name": "PyMuPDF", "package_type": "package", "sha256": "271f7fb3c20b0ddd6f6618b01460ce207ce5370d5549c407837954f24a0ef8ec", "unvendored_tests": false, "version": "1.26.3"}, "pynacl": {"depends": ["cffi"], "file_name": "pynacl-1.5.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["nacl"], "install_dir": "site", "name": "pynacl", "package_type": "package", "sha256": "fb2518a6fee4b24c86b71f110387d3be534cdfce1682a8c3f2e91aa5f03ae7b7", "unvendored_tests": false, "version": "1.5.0"}, "pyodide-http": {"depends": [], "file_name": "pyodide_http-0.2.2-py3-none-any.whl", "imports": ["pyodide_http"], "install_dir": "site", "name": "pyodide-http", "package_type": "package", "sha256": "0cc0d07f3151e5deac22bbdbbf114642da983739ee394a3d31db5c7762c4c146", "unvendored_tests": false, "version": "0.2.2"}, "pyodide-unix-timezones": {"depends": [], "file_name": "pyodide_unix_timezones-1.0.0-py3-none-any.whl", "imports": ["unix_timezones"], "install_dir": "site", "name": "pyodide-unix-timezones", "package_type": "package", "sha256": "49469bacdf058914c325d8e49d1020c2803dd921d6c2d7a71a29ceea952fd438", "unvendored_tests": false, "version": "1.0.0"}, "pyparsing": {"depends": [], "file_name": "pyparsing-3.2.1-cp313-none-any.whl", "imports": ["pyparsing"], "install_dir": "site", "name": "pyparsing", "package_type": "package", "sha256": "27d7ec7b91d8287b6d903d90e2ad41c31a916a936fb620d87b6fb6573670f98a", "unvendored_tests": false, "version": "3.2.1"}, "pyproj": {"depends": ["certifi"], "file_name": "pyproj-3.7.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pyproj"], "install_dir": "site", "name": "pyproj", "package_type": "package", "sha256": "fd7af196bfb8d88c095293fa241498982cb39d7af15a3fc133ae533185d6d710", "unvendored_tests": false, "version": "3.7.2"}, "pyrodigal": {"depends": [], "file_name": "pyrodigal-3.7.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pyrodigal"], "install_dir": "site", "name": "pyrodigal", "package_type": "package", "sha256": "4c8351cc959cb64962bcbdd0de60de928ea8ff9c973f969e461e908d43784467", "unvendored_tests": true, "version": "3.7.0"}, "pyrodigal-tests": {"depends": ["pyrodigal"], "file_name": "pyrodigal-tests.tar", "imports": [], "install_dir": "site", "name": "pyrodigal-tests", "package_type": "package", "sha256": "38d1bac466a4a9a63a98d19470abe83c8c403285e2b5fa7d04f491d2746f3846", "unvendored_tests": false, "version": "3.7.0"}, "pyrsistent": {"depends": [], "file_name": "pyrsistent-0.20.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["_pyrsistent_version", "pyrsistent"], "install_dir": "site", "name": "pyrsistent", "package_type": "package", "sha256": "ea59641657ac5f69b04484e646eecdf3d09e4759163e2cdee876e18ae711ed4c", "unvendored_tests": false, "version": "0.20.0"}, "pysam": {"depends": [], "file_name": "pysam-0.23.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pysam"], "install_dir": "site", "name": "pysam", "package_type": "package", "sha256": "792be11ba2580824612c766f5ff973f21e1cd99a483d1d9fb749521cd2ceb214", "unvendored_tests": false, "version": "0.23.0"}, "pyshp": {"depends": [], "file_name": "pyshp-2.3.1-py2.py3-none-any.whl", "imports": ["shapefile"], "install_dir": "site", "name": "pyshp", "package_type": "package", "sha256": "36946c1f1fc24ddf6774182619192a3da96ec3bcb1245b62c7270b9c45099d31", "unvendored_tests": false, "version": "2.3.1"}, "pytaglib": {"depends": ["libtaglib"], "file_name": "pytaglib-3.0.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["taglib"], "install_dir": "site", "name": "pytaglib", "package_type": "package", "sha256": "cd1d71c16bf40edd342e7917060559451b57ddfd76317dadf3dc31e4e4c25098", "unvendored_tests": false, "version": "3.0.1"}, "pytest": {"depends": ["atomicwrites", "attrs", "more-itertools", "pluggy", "py", "setuptools", "six", "iniconfig", "exceptiongroup"], "file_name": "pytest-8.3.5-py3-none-any.whl", "imports": ["_pytest", "pytest"], "install_dir": "site", "name": "pytest", "package_type": "package", "sha256": "f648e340ac21fd1a19361d4083690f759533e3579a7d02645f31ca91c1b45d9b", "unvendored_tests": false, "version": "8.3.5"}, "pytest-asyncio": {"depends": ["pytest"], "file_name": "pytest_asyncio-0.25.3-py3-none-any.whl", "imports": ["pytest_asyncio"], "install_dir": "site", "name": "pytest-asyncio", "package_type": "package", "sha256": "12bb1ef200b7a8f6296f1c137a7639c588060c0afbeea4e236c827b75fd4b271", "unvendored_tests": false, "version": "0.25.3"}, "pytest-benchmark": {"depends": [], "file_name": "pytest_benchmark-4.0.0-py3-none-any.whl", "imports": ["pytest_benchmark"], "install_dir": "site", "name": "pytest-benchmark", "package_type": "package", "sha256": "6ddd836283cc63bb56de20e93e3f7326288cc9bc677f8f3f4b02fcad6216994f", "unvendored_tests": false, "version": "4.0.0"}, "pytest-httpx": {"depends": ["httpx", "pytest", "httpcore"], "file_name": "pytest_httpx-0.30.0-py3-none-any.whl", "imports": ["pytest_httpx"], "install_dir": "site", "name": "pytest_httpx", "package_type": "package", "sha256": "e4e50630f19692cb862c8e0a44fa4f806cb7cca86a57e65a1a4d05e4c0e9395f", "unvendored_tests": false, "version": "0.30.0"}, "python-calamine": {"depends": ["packaging"], "file_name": "python_calamine-0.5.3-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["python_calamine"], "install_dir": "site", "name": "python-calamine", "package_type": "package", "sha256": "5a1722bbac59c7a62250511267ac0709160145cb6b37af7352d6b1148d291b64", "unvendored_tests": false, "version": "0.5.3"}, "python-dateutil": {"depends": ["six"], "file_name": "python_dateutil-2.9.0.post0-cp313-none-any.whl", "imports": ["dateutil"], "install_dir": "site", "name": "python-dateutil", "package_type": "package", "sha256": "9d01485ccae7a6651df46d27b0d9a825be5df87001b01a50c1c95441a5059d2f", "unvendored_tests": false, "version": "2.9.0.post0"}, "python-flint": {"depends": [], "file_name": "python_flint-0.8.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["flint"], "install_dir": "site", "name": "python-flint", "package_type": "package", "sha256": "2615968edf0985813ff377a368d7f58a1be7d8ade2327c8914f4c1a193ce7bcf", "unvendored_tests": false, "version": "0.8.0"}, "python-magic": {"depends": ["libmagic"], "file_name": "python_magic-0.4.27-py2.py3-none-any.whl", "imports": ["magic"], "install_dir": "site", "name": "python-magic", "package_type": "package", "sha256": "40caa90926fe5249bc6d6ccf1c8d026d2366d384395650756eeb3223cffbcf82", "unvendored_tests": false, "version": "0.4.27"}, "python-sat": {"depends": ["six"], "file_name": "python_sat-1.8.dev26-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pysat"], "install_dir": "site", "name": "python-sat", "package_type": "package", "sha256": "6ba3b64402341ec89825f760f9f462c21bd1a69b38b052b6a1c0262f924df122", "unvendored_tests": false, "version": "1.8.dev26"}, "python-solvespace": {"depends": [], "file_name": "python_solvespace-3.0.8-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["python_solvespace"], "install_dir": "site", "name": "python-solvespace", "package_type": "package", "sha256": "a6d0c80bdc9aff71ef7a36fb88a15a72fc04ab589ff12eb997b2ad56738da21c", "unvendored_tests": false, "version": "3.0.8"}, "pytz": {"depends": [], "file_name": "pytz-2025.2-cp313-none-any.whl", "imports": ["pytz"], "install_dir": "site", "name": "pytz", "package_type": "package", "sha256": "05b9ce7e8c00b5181f138267b9e87eb7e7a931f210837d3eeedbcec985f9df8d", "unvendored_tests": false, "version": "2025.2"}, "pywavelets": {"depends": ["numpy"], "file_name": "pywavelets-1.8.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pywt"], "install_dir": "site", "name": "pywavelets", "package_type": "package", "sha256": "4e3df040f2927cd2ead32678cf40f323424519f084b9d5c4cf3ea1851e7bd2ba", "unvendored_tests": true, "version": "1.8.0"}, "pywavelets-tests": {"depends": ["pywavelets"], "file_name": "pywavelets-tests.tar", "imports": [], "install_dir": "site", "name": "pywavelets-tests", "package_type": "package", "sha256": "ac735e687c282003e049a48ba16b6ffb48a23ac3c45f04860f8d4eeecd7ecaa9", "unvendored_tests": false, "version": "1.8.0"}, "pyxel": {"depends": [], "file_name": "pyxel-1.9.10-cp37-abi3-pyodide_2025_0_wasm32.whl", "imports": ["pyxel"], "install_dir": "site", "name": "pyxel", "package_type": "package", "sha256": "a10c723c40f0f893f3da75fb230134af15150b818097e11d438d548d5ea2fd44", "unvendored_tests": false, "version": "1.9.10"}, "pyxirr": {"depends": [], "file_name": "pyxirr-0.10.6-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["pyxirr"], "install_dir": "site", "name": "pyxirr", "package_type": "package", "sha256": "0948e9ce6b751811d4b410f29ace3292bdf0db066acd9277645e9752ebca7935", "unvendored_tests": false, "version": "0.10.6"}, "pyyaml": {"depends": [], "file_name": "pyyaml-6.0.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["_yaml", "yaml"], "install_dir": "site", "name": "pyyaml", "package_type": "package", "sha256": "d0b3d100f3ebe90c0ea62f04d9ac2d3c38ca0023be5d240ef92c77b94c9495f8", "unvendored_tests": false, "version": "6.0.2"}, "rasterio": {"depends": ["numpy", "affine", "attrs", "certifi", "click", "cligj"], "file_name": "rasterio-1.4.3-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["rasterio"], "install_dir": "site", "name": "rasterio", "package_type": "package", "sha256": "3fa33927cc7a1ea9187aecebace9a82d0e91641e80886687d610fcdef563e310", "unvendored_tests": false, "version": "1.4.3"}, "rateslib": {"depends": ["numpy", "pandas", "matplotlib"], "file_name": "rateslib-2.5.1-cp310-abi3-pyodide_2025_0_wasm32.whl", "imports": ["rateslib"], "install_dir": "site", "name": "rateslib", "package_type": "package", "sha256": "bddc87fee2fecfcf1719d2183110d72c7523c1bd021780a82a54c44e6a1bfe87", "unvendored_tests": false, "version": "2.5.1"}, "rebound": {"depends": ["numpy"], "file_name": "rebound-4.4.7-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["rebound"], "install_dir": "site", "name": "rebound", "package_type": "package", "sha256": "6baac26fcc18f1f9fc3efc10282196e2413135392902e48d1edbaff0c464559c", "unvendored_tests": false, "version": "4.4.7"}, "reboundx": {"depends": ["rebound", "numpy"], "file_name": "reboundx-4.4.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["reboundx"], "install_dir": "site", "name": "reboundx", "package_type": "package", "sha256": "8e8542dbc7bc630a469d890601af41f923e8b4ab8b804368ee20eef32cad9b8c", "unvendored_tests": false, "version": "4.4.1"}, "referencing": {"depends": ["attrs", "rpds-py", "typing-extensions"], "file_name": "referencing-0.36.2-py3-none-any.whl", "imports": ["referencing"], "install_dir": "site", "name": "referencing", "package_type": "package", "sha256": "9fd72557776e4d4e1eb6f0d906c41c0dd71a8e6bce8d791e93a1ea6aba0602fc", "unvendored_tests": true, "version": "0.36.2"}, "referencing-tests": {"depends": ["referencing"], "file_name": "referencing-tests.tar", "imports": [], "install_dir": "site", "name": "referencing-tests", "package_type": "package", "sha256": "f34c6e81fb7dea8f9f731c965c6d2888aeb39c0c4a4ad59817966aba389b0887", "unvendored_tests": false, "version": "0.36.2"}, "regex": {"depends": [], "file_name": "regex-2024.11.6-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["regex"], "install_dir": "site", "name": "regex", "package_type": "package", "sha256": "0400d660e4f9f6359b7a98077bdc46b34b705b38f0f6c96a3053c8b5703caeed", "unvendored_tests": true, "version": "2024.11.6"}, "regex-tests": {"depends": ["regex"], "file_name": "regex-tests.tar", "imports": [], "install_dir": "site", "name": "regex-tests", "package_type": "package", "sha256": "1974108c86e92577fceac91ed1ef782a070d9b8243012446e97b193f79df1166", "unvendored_tests": false, "version": "2024.11.6"}, "requests": {"depends": ["charset-normalizer", "idna", "urllib3", "certifi"], "file_name": "requests-2.32.4-py3-none-any.whl", "imports": ["requests"], "install_dir": "site", "name": "requests", "package_type": "package", "sha256": "1e5c14010785e00a8d8bbb1874fd9382b2de21d6b81cbe07588c49f7a39393ef", "unvendored_tests": false, "version": "2.32.4"}, "retrying": {"depends": ["six"], "file_name": "retrying-1.3.4-py3-none-any.whl", "imports": ["retrying"], "install_dir": "site", "name": "retrying", "package_type": "package", "sha256": "6dcfceefc2f1f66713031db3c49737e742e9f3fe2becbb9de2d67c94d6c0dbc8", "unvendored_tests": false, "version": "1.3.4"}, "rich": {"depends": [], "file_name": "rich-13.9.4-cp313-none-any.whl", "imports": ["rich"], "install_dir": "site", "name": "rich", "package_type": "package", "sha256": "792e8ac74656180d0059bbf2c2b7ad8a46d94111f97589e554da217888e18a69", "unvendored_tests": false, "version": "13.9.4"}, "river": {"depends": ["numpy", "pandas", "scipy"], "file_name": "river-0.22.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["river"], "install_dir": "site", "name": "river", "package_type": "package", "sha256": "5cc5e34dbfe552936d05ce6b2c2895548d3e0a0ddc4f81c3411d565ee814ba1d", "unvendored_tests": true, "version": "0.22.0"}, "river-tests": {"depends": ["river"], "file_name": "river-tests.tar", "imports": [], "install_dir": "site", "name": "river-tests", "package_type": "package", "sha256": "5a8ed77f166bf3cc734357e7a46d62734b4a4f32ba1fff3b5bcd8b3b3be3d40e", "unvendored_tests": false, "version": "0.22.0"}, "robotraconteur": {"depends": ["numpy"], "file_name": "robotraconteur-1.2.7-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["RobotRaconteur"], "install_dir": "site", "name": "RobotRaconteur", "package_type": "package", "sha256": "c5db05398decbe001a3925aece63caebcc52f98ab9e01cc5da6dbe3c102f64a7", "unvendored_tests": false, "version": "1.2.7"}, "rpds-py": {"depends": [], "file_name": "rpds_py-0.30.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["rpds"], "install_dir": "site", "name": "rpds-py", "package_type": "package", "sha256": "8e7918c617cc077fcb0d110f9d9d6511466958f9c095810be1f72760a63bfc2f", "unvendored_tests": false, "version": "0.30.0"}, "ruamel-yaml": {"depends": [], "file_name": "ruamel.yaml-0.18.10-py3-none-any.whl", "imports": ["ruamel"], "install_dir": "site", "name": "ruamel.yaml", "package_type": "package", "sha256": "d998c5c7ebae7eec165a0611f587e4789a7d8b00e1440b569c0abf7613208bda", "unvendored_tests": false, "version": "0.18.10"}, "rustworkx": {"depends": [], "file_name": "rustworkx-0.17.1-cp39-abi3-pyodide_2025_0_wasm32.whl", "imports": ["rustworkx"], "install_dir": "site", "name": "rustworkx", "package_type": "package", "sha256": "78b2e4036cc324f834b556d1e68091dda66e7304adc924b484be76778cac71ac", "unvendored_tests": false, "version": "0.17.1"}, "scikit-image": {"depends": ["packaging", "numpy", "scipy", "networkx", "pillow", "imageio", "pywavelets", "lazy_loader"], "file_name": "scikit_image-0.25.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["skimage"], "install_dir": "site", "name": "scikit-image", "package_type": "package", "sha256": "351b08daac16153c6c9a4ae5c03ee57e622e426685f3aad27b7e3bd8731e5795", "unvendored_tests": true, "version": "0.25.2"}, "scikit-image-tests": {"depends": ["scikit-image"], "file_name": "scikit-image-tests.tar", "imports": [], "install_dir": "site", "name": "scikit-image-tests", "package_type": "package", "sha256": "faf95457c2f1eb47a7ff4027f0ba9fe0c93a4fa386797c956d9f432d6ad69aad", "unvendored_tests": false, "version": "0.25.2"}, "scikit-learn": {"depends": ["scipy", "joblib", "threadpoolctl"], "file_name": "scikit_learn-1.7.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["sklearn"], "install_dir": "site", "name": "scikit-learn", "package_type": "package", "sha256": "e9628fd21ebeb9d69d251e59eae9d02043e8e868ca5950547a535e846b5aef9c", "unvendored_tests": true, "version": "1.7.0"}, "scikit-learn-tests": {"depends": ["scikit-learn"], "file_name": "scikit-learn-tests.tar", "imports": [], "install_dir": "site", "name": "scikit-learn-tests", "package_type": "package", "sha256": "fdc657b4da1d4d1001a1f4fe6bdcf89552fa3c13a29d66dc766e208cdec3f89f", "unvendored_tests": false, "version": "1.7.0"}, "scipy": {"depends": ["numpy", "libopenblas"], "file_name": "scipy-1.14.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["scipy"], "install_dir": "site", "name": "scipy", "package_type": "package", "sha256": "1a930380bc8f7c4a77bf9b95e915cab97b15fd5c8806448829654024b9d17553", "unvendored_tests": true, "version": "1.14.1"}, "scipy-tests": {"depends": ["scipy"], "file_name": "scipy-tests.tar", "imports": [], "install_dir": "site", "name": "scipy-tests", "package_type": "package", "sha256": "0a079ec3481ab936db3e1e243ed4c68e08b797e31e46b76e112f72ef9ae2966a", "unvendored_tests": false, "version": "1.14.1"}, "screed": {"depends": [], "file_name": "screed-1.1.3-py2.py3-none-any.whl", "imports": ["bigtests", "screed"], "install_dir": "site", "name": "screed", "package_type": "package", "sha256": "3d1988cc70a893999774f244a17bfebca33ea7ec5fc4b7297147d36d4b9accca", "unvendored_tests": true, "version": "1.1.3"}, "screed-tests": {"depends": ["screed"], "file_name": "screed-tests.tar", "imports": [], "install_dir": "site", "name": "screed-tests", "package_type": "package", "sha256": "328b604d4feb15aa7470eaa32743cdc83f4f9b7f290fff9e1a8d54535e650685", "unvendored_tests": false, "version": "1.1.3"}, "setuptools": {"depends": ["pyparsing"], "file_name": "setuptools-76.0.0-py3-none-any.whl", "imports": ["_distutils_hack", "pkg_resources", "setuptools"], "install_dir": "site", "name": "setuptools", "package_type": "package", "sha256": "0ffe3d7fd6b219b68fd0c67a450a44e3a19e2d2d9e751e4333430af27c6d89e5", "unvendored_tests": true, "version": "76.0.0"}, "setuptools-tests": {"depends": ["setuptools"], "file_name": "setuptools-tests.tar", "imports": [], "install_dir": "site", "name": "setuptools-tests", "package_type": "package", "sha256": "7ab7cdf90ac2479ccbb79c44ec7fd7d5bd3957fa3ba23835db8ee36236937d15", "unvendored_tests": false, "version": "76.0.0"}, "shapely": {"depends": ["numpy"], "file_name": "shapely-2.0.7-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["shapely"], "install_dir": "site", "name": "shapely", "package_type": "package", "sha256": "3c14600713a254d407c92bccd2d8c679b23296ac1aacb69556cf1d5352d71f6c", "unvendored_tests": true, "version": "2.0.7"}, "shapely-tests": {"depends": ["shapely"], "file_name": "shapely-tests.tar", "imports": [], "install_dir": "site", "name": "shapely-tests", "package_type": "package", "sha256": "afab739c87044873a38c6f97b82389c21f8f12e2f02689dab750e107aaf9a441", "unvendored_tests": false, "version": "2.0.7"}, "simplejson": {"depends": [], "file_name": "simplejson-3.20.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["simplejson"], "install_dir": "site", "name": "simplejson", "package_type": "package", "sha256": "8e3741f95687da2574ca9c48e088035b1d52ff00cfb2956e30672993ecb8aeb6", "unvendored_tests": true, "version": "3.20.1"}, "simplejson-tests": {"depends": ["simplejson"], "file_name": "simplejson-tests.tar", "imports": [], "install_dir": "site", "name": "simplejson-tests", "package_type": "package", "sha256": "ecc18b83ce5779a6f33699ecd1fa3b1c7f336a5aab7d4bb6983cfc945c442f57", "unvendored_tests": false, "version": "3.20.1"}, "sisl": {"depends": ["pyparsing", "numpy", "scipy", "tqdm", "xarray", "pandas", "matplotlib"], "file_name": "sisl-0.16.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["sisl_toolbox", "sisl"], "install_dir": "site", "name": "sisl", "package_type": "package", "sha256": "b284861007e8912e67ed650789e50bb9585a335b0cbe183ee26dfb9c80a3b2fa", "unvendored_tests": true, "version": "0.16.2"}, "sisl-tests": {"depends": ["sisl"], "file_name": "sisl-tests.tar", "imports": [], "install_dir": "site", "name": "sisl-tests", "package_type": "package", "sha256": "4d31452b286130d79c0a81848136ed10f503497275f9b6822d711fb0f04ced5e", "unvendored_tests": false, "version": "0.16.2"}, "six": {"depends": [], "file_name": "six-1.17.0-cp313-none-any.whl", "imports": ["six"], "install_dir": "site", "name": "six", "package_type": "package", "sha256": "07827d0d7e2c2ef4105cee58ce2f0a31211702a4cd24614f9341dae069e9cc7c", "unvendored_tests": false, "version": "1.17.0"}, "smart-open": {"depends": ["wrapt"], "file_name": "smart_open-7.1.0-py3-none-any.whl", "imports": ["smart_open"], "install_dir": "site", "name": "smart-open", "package_type": "package", "sha256": "dc5beecb15b4857d05e4fab6382349e0545ed156df6cc255c3b785459ca77af3", "unvendored_tests": false, "version": "7.1.0"}, "sniffio": {"depends": [], "file_name": "sniffio-1.3.1-py3-none-any.whl", "imports": ["sniffio"], "install_dir": "site", "name": "sniffio", "package_type": "package", "sha256": "0077e1685d430cd50f6413af1ed209bb03c95da589ef4f1b8426d67c6b02cb4a", "unvendored_tests": true, "version": "1.3.1"}, "sniffio-tests": {"depends": ["sniffio"], "file_name": "sniffio-tests.tar", "imports": [], "install_dir": "site", "name": "sniffio-tests", "package_type": "package", "sha256": "240d53b95a77a72c309d4279c31f93a5be3ce0a15cb7c92a8f2ac1b9df346bfb", "unvendored_tests": false, "version": "1.3.1"}, "sortedcontainers": {"depends": [], "file_name": "sortedcontainers-2.4.0-py2.py3-none-any.whl", "imports": ["sortedcontainers"], "install_dir": "site", "name": "sortedcontainers", "package_type": "package", "sha256": "8f9018394f1e1c1c98c8744b94d224c990f5090747e2a4c42ac2ca13ae9435ac", "unvendored_tests": false, "version": "2.4.0"}, "soundfile": {"depends": ["cffi", "numpy"], "file_name": "soundfile-0.12.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["soundfile"], "install_dir": "site", "name": "soundfile", "package_type": "package", "sha256": "abe68fea5610c352dc5fb635f5f1af379f9a6c15bb7c0ede5dfe9c1313c65764", "unvendored_tests": false, "version": "0.12.1"}, "soupsieve": {"depends": [], "file_name": "soupsieve-2.6-py3-none-any.whl", "imports": ["soupsieve"], "install_dir": "site", "name": "soupsieve", "package_type": "package", "sha256": "7e7e36183777bcbc525ee458fa8c39853615b7a94d80c38b944e5824bdaf5a78", "unvendored_tests": false, "version": "2.6"}, "sourmash": {"depends": ["screed", "cffi", "deprecation", "cachetools", "numpy", "matplotlib", "scipy", "sqlite3", "bitstring"], "file_name": "sourmash-4.8.14-py3-none-pyodide_2025_0_wasm32.whl", "imports": ["sourmash"], "install_dir": "site", "name": "sourmash", "package_type": "package", "sha256": "72dab96fd65d0afa9137be9255f00804def5cdf2ce89fd0d04a01cc157cb91dc", "unvendored_tests": false, "version": "4.8.14"}, "soxr": {"depends": ["numpy"], "file_name": "soxr-0.5.0.post1-cp312-abi3-pyodide_2025_0_wasm32.whl", "imports": ["soxr"], "install_dir": "site", "name": "soxr", "package_type": "package", "sha256": "54ecac0c40457de53cf5683d47cddaa8aab607f14c5df7b64b8399d20a4b6470", "unvendored_tests": false, "version": "0.5.0.post1"}, "sparseqr": {"depends": ["pycparser", "cffi", "numpy", "scipy", "libsuitesparse"], "file_name": "sparseqr-1.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["sparseqr"], "install_dir": "site", "name": "sparseqr", "package_type": "package", "sha256": "6f89e5c0d9593244e7a08573f19173f370687135f983e2d7abc9ee7d52e1142e", "unvendored_tests": false, "version": "1.2"}, "sqlalchemy": {"depends": ["sqlite3", "typing-extensions"], "file_name": "sqlalchemy-2.0.39-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["sqlalchemy"], "install_dir": "site", "name": "sqlalchemy", "package_type": "package", "sha256": "165fe298a753acdaa860c8167ef39bf31ab590423d91f634d58181b2abcd85af", "unvendored_tests": true, "version": "2.0.39"}, "sqlalchemy-tests": {"depends": ["sqlalchemy"], "file_name": "sqlalchemy-tests.tar", "imports": [], "install_dir": "site", "name": "sqlalchemy-tests", "package_type": "package", "sha256": "31df12d9cc2a92e803a92320e1b27aa65cc56c8d4a59f66cf0fd70fe5a2be6c1", "unvendored_tests": false, "version": "2.0.39"}, "sqlite3": {"depends": [], "file_name": "sqlite3-1.0.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["sqlite3", "_sqlite3"], "install_dir": "site", "name": "sqlite3", "package_type": "cpython_module", "sha256": "aab7214b987a3803fca283a8221e4b9d3274abc05d0cf506ea1a2ae7e09e3bf0", "unvendored_tests": false, "version": "1.0.0"}, "ssl": {"depends": ["libopenssl"], "file_name": "ssl-1.0.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["ssl", "_ssl"], "install_dir": "site", "name": "ssl", "package_type": "cpython_module", "sha256": "23a3fe862983d6798a51a0a63ac55356891751084927a7bde979dc4d6d52e0b5", "unvendored_tests": false, "version": "1.0.0"}, "stack-data": {"depends": ["executing", "asttokens", "pure-eval"], "file_name": "stack_data-0.6.3-py3-none-any.whl", "imports": ["stack_data"], "install_dir": "site", "name": "stack-data", "package_type": "package", "sha256": "b31a4062c2fed35479587fad00b74a23e105acc51a42d68e76a9ab6ed134ac25", "unvendored_tests": false, "version": "0.6.3"}, "starlette": {"depends": [], "file_name": "starlette-0.47.2-py3-none-any.whl", "imports": ["starlette"], "install_dir": "site", "name": "starlette", "package_type": "package", "sha256": "8ae10ca3b4f3e2f58593bd18a8f58df0193aac10f1922dd6c8a0d4b7a95db470", "unvendored_tests": false, "version": "0.47.2"}, "statsmodels": {"depends": ["numpy", "scipy", "pandas", "patsy", "packaging"], "file_name": "statsmodels-0.14.4-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["statsmodels"], "install_dir": "site", "name": "statsmodels", "package_type": "package", "sha256": "0a6387e6e2b0774dc76abd05c3f9a17e0f45233574a9c9e5f0dbeaca3e5a1df6", "unvendored_tests": false, "version": "0.14.4"}, "strictyaml": {"depends": ["python-dateutil"], "file_name": "strictyaml-1.7.3-py3-none-any.whl", "imports": ["strictyaml"], "install_dir": "site", "name": "strictyaml", "package_type": "package", "sha256": "567ddc1f5cecbec407bd01e97e4fbc3a973e1fbf32fb80f83f25741184cbaa6a", "unvendored_tests": false, "version": "1.7.3"}, "svgwrite": {"depends": [], "file_name": "svgwrite-1.4.3-py3-none-any.whl", "imports": ["svgwrite"], "install_dir": "site", "name": "svgwrite", "package_type": "package", "sha256": "92cd1c63bb36ced6abb09edadcde53276cce95b9a8c65b2d7e5e45fb7a4cf79c", "unvendored_tests": false, "version": "1.4.3"}, "swiglpk": {"depends": [], "file_name": "swiglpk-5.0.12-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["swiglpk"], "install_dir": "site", "name": "swiglpk", "package_type": "package", "sha256": "3e4fef0f9ba61ecdea0f46ab70d191fc12537303a5526fbb1717c368d1bcca24", "unvendored_tests": false, "version": "5.0.12"}, "sympy": {"depends": ["mpmath"], "file_name": "sympy-1.13.3-cp313-none-any.whl", "imports": ["isympy", "sympy"], "install_dir": "site", "name": "sympy", "package_type": "package", "sha256": "bfcdbbfa4aadda961cbb483f16bfb28076e38b38ed7b785e4bb05be7b352cbdb", "unvendored_tests": true, "version": "1.13.3"}, "sympy-tests": {"depends": ["sympy"], "file_name": "sympy-tests.tar", "imports": [], "install_dir": "site", "name": "sympy-tests", "package_type": "package", "sha256": "4d596bf4fdfe9badeea05c0a6f2baa6d5a5f903b32988834d7654e4e88f9bc68", "unvendored_tests": false, "version": "1.13.3"}, "tblib": {"depends": [], "file_name": "tblib-3.0.0-py3-none-any.whl", "imports": ["tblib"], "install_dir": "site", "name": "tblib", "package_type": "package", "sha256": "1d575165bedd73188f1ba98acaadff02cc3b1631406373130596b00ba00013dd", "unvendored_tests": false, "version": "3.0.0"}, "termcolor": {"depends": [], "file_name": "termcolor-2.5.0-py3-none-any.whl", "imports": ["termcolor"], "install_dir": "site", "name": "termcolor", "package_type": "package", "sha256": "fd0dbfea276e782e04fcc39c1a2352ab49d59a0533edd4b9ef248d68d4b6a0c6", "unvendored_tests": false, "version": "2.5.0"}, "test": {"depends": [], "file_name": "test-1.0.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["test"], "install_dir": "site", "name": "test", "package_type": "cpython_module", "sha256": "a12dc1785efa8f2ec03fbc0388f76e066f2dfa78f1ffcce1d31167619a1c94c5", "unvendored_tests": false, "version": "1.0.0"}, "texttable": {"depends": [], "file_name": "texttable-1.7.0-py2.py3-none-any.whl", "imports": ["texttable"], "install_dir": "site", "name": "texttable", "package_type": "package", "sha256": "044ee958dd8ba0c7863f17af1d888f6296d69dc1248230becf8b016ca208fa31", "unvendored_tests": false, "version": "1.7.0"}, "texture2ddecoder": {"depends": [], "file_name": "texture2ddecoder-1.0.5-cp37-abi3-pyodide_2025_0_wasm32.whl", "imports": ["texture2ddecoder"], "install_dir": "site", "name": "texture2ddecoder", "package_type": "package", "sha256": "faf296ba14ffc078255809ecbc67592f40f8fff8d2a9bc0209e72da138d6ad88", "unvendored_tests": false, "version": "1.0.5"}, "threadpoolctl": {"depends": [], "file_name": "threadpoolctl-3.5.0-cp313-none-any.whl", "imports": ["threadpoolctl"], "install_dir": "site", "name": "threadpoolctl", "package_type": "package", "sha256": "b81cd75739d4217557389ea51abd61f9b7b45ec34bf03496bfb5f5f58af50ba4", "unvendored_tests": false, "version": "3.5.0"}, "tiktoken": {"depends": ["regex", "requests"], "file_name": "tiktoken-0.9.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["tiktoken", "tiktoken_ext"], "install_dir": "site", "name": "tiktoken", "package_type": "package", "sha256": "5d634abc439080560224fdf27d5fd94a5c4c0b8b7c9084fa1fb4305bc68aed4d", "unvendored_tests": false, "version": "0.9.0"}, "tomli": {"depends": [], "file_name": "tomli-2.2.1-py3-none-any.whl", "imports": ["tomli"], "install_dir": "site", "name": "tomli", "package_type": "package", "sha256": "6c3495c050cb288e13416c75511cb81aed241f5ebd40e637bd7ab02ede8069d4", "unvendored_tests": false, "version": "2.2.1"}, "tomli-w": {"depends": [], "file_name": "tomli_w-1.2.0-py3-none-any.whl", "imports": ["tomli_w"], "install_dir": "site", "name": "tomli-w", "package_type": "package", "sha256": "c68058a9596e616e6bbc2b8e6540b66973975b224f8d741d0b9ab170ce2ed23b", "unvendored_tests": false, "version": "1.2.0"}, "toolz": {"depends": [], "file_name": "toolz-1.0.0-py3-none-any.whl", "imports": ["tlz", "toolz"], "install_dir": "site", "name": "toolz", "package_type": "package", "sha256": "967d0d799a872dd03bc3247fa2e2da1e6451a5237f0d68963cc03e644c348e3e", "unvendored_tests": true, "version": "1.0.0"}, "toolz-tests": {"depends": ["toolz"], "file_name": "toolz-tests.tar", "imports": [], "install_dir": "site", "name": "toolz-tests", "package_type": "package", "sha256": "ed4e7ee95cda60c212d3db55dc531a0ec46aa6786fca9f56b777551666f053f6", "unvendored_tests": false, "version": "1.0.0"}, "tqdm": {"depends": [], "file_name": "tqdm-4.67.1-py3-none-any.whl", "imports": ["tqdm"], "install_dir": "site", "name": "tqdm", "package_type": "package", "sha256": "006b436ee31e705b222d855b36a78b3760adfb31d0be1fc75da70c8f4f0834e7", "unvendored_tests": false, "version": "4.67.1"}, "traitlets": {"depends": [], "file_name": "traitlets-5.14.3-py3-none-any.whl", "imports": ["traitlets"], "install_dir": "site", "name": "traitlets", "package_type": "package", "sha256": "81d9fb14245aedf572b78b15c33480c67e7c4070f9cfd7732bb85d702a875629", "unvendored_tests": true, "version": "5.14.3"}, "traitlets-tests": {"depends": ["traitlets"], "file_name": "traitlets-tests.tar", "imports": [], "install_dir": "site", "name": "traitlets-tests", "package_type": "package", "sha256": "a3197b5e3dfc8db00b0529032cdbf4e627a43a8f93560366062b11e0d8117f0c", "unvendored_tests": false, "version": "5.14.3"}, "traits": {"depends": [], "file_name": "traits-7.0.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["traits"], "install_dir": "site", "name": "traits", "package_type": "package", "sha256": "018e5d5a728367b6b00d3b8ec75721de8dde7ff34cc6c1ba004e5b55bce26315", "unvendored_tests": true, "version": "7.0.2"}, "traits-tests": {"depends": ["traits"], "file_name": "traits-tests.tar", "imports": [], "install_dir": "site", "name": "traits-tests", "package_type": "package", "sha256": "c6df8d68fb079caa60b654338fdf43e2f5aadcd351e811a1c81616e7ac26c4e8", "unvendored_tests": false, "version": "7.0.2"}, "tree-sitter": {"depends": [], "file_name": "tree_sitter-0.23.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["tree_sitter"], "install_dir": "site", "name": "tree-sitter", "package_type": "package", "sha256": "bfc7f18af606c82dbc48ad4e027df691c0093cb147c6147535a6c2c625cb1f65", "unvendored_tests": false, "version": "0.23.2"}, "tree-sitter-go": {"depends": ["tree-sitter"], "file_name": "tree_sitter_go-0.23.3-cp39-abi3-pyodide_2025_0_wasm32.whl", "imports": ["tree_sitter_go"], "install_dir": "site", "name": "tree-sitter-go", "package_type": "package", "sha256": "efd2b3c3e2e91520d7f901c5848ec3be9c31f2ed30aa0ec93a6434e906b6ce6f", "unvendored_tests": false, "version": "0.23.3"}, "tree-sitter-java": {"depends": ["tree-sitter"], "file_name": "tree_sitter_java-0.23.4-cp39-abi3-pyodide_2025_0_wasm32.whl", "imports": ["tree_sitter_java"], "install_dir": "site", "name": "tree-sitter-java", "package_type": "package", "sha256": "3cb99f96ef340f9b62d84f54dd087a47df357528bf18c99f58f6cc25ba3c5342", "unvendored_tests": false, "version": "0.23.4"}, "tree-sitter-python": {"depends": ["tree-sitter"], "file_name": "tree_sitter_python-0.23.4-cp39-abi3-pyodide_2025_0_wasm32.whl", "imports": ["tree_sitter_python"], "install_dir": "site", "name": "tree-sitter-python", "package_type": "package", "sha256": "4a92f239f1e83121f18908ec5f8d4047cfec71a6d828813fe6a9b7c1bcd735b0", "unvendored_tests": false, "version": "0.23.4"}, "tskit": {"depends": ["numpy", "jsonschema", "rpds-py"], "file_name": "tskit-1.0.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["tskit"], "install_dir": "site", "name": "tskit", "package_type": "package", "sha256": "f7e8a5c0b5171018bc7172e6b53f4184139afde97fa12350e580a42f7a544e3d", "unvendored_tests": false, "version": "1.0.0"}, "typing-extensions": {"depends": [], "file_name": "typing_extensions-4.15.0-py3-none-any.whl", "imports": ["typing_extensions"], "install_dir": "site", "name": "typing-extensions", "package_type": "package", "sha256": "b57583f623dd3df72e6ace8a4061c3e4f0683755165ef73b4cd44ac3df92ddb9", "unvendored_tests": false, "version": "4.15.0"}, "typing-inspection": {"depends": [], "file_name": "typing_inspection-0.4.2-py3-none-any.whl", "imports": ["typing_inspection"], "install_dir": "site", "name": "typing-inspection", "package_type": "package", "sha256": "5c4d0bade04cec6ac0d03c227c8bdb7c59218e4c6d759b5ac0cea5c34f6a72aa", "unvendored_tests": false, "version": "0.4.2"}, "tzdata": {"depends": [], "file_name": "tzdata-2025.3-py2.py3-none-any.whl", "imports": ["tzdata"], "install_dir": "site", "name": "tzdata", "package_type": "package", "sha256": "39db9ad12044be29b71e3ab24b905956fca75ae6fb25f9bc2062043c293d0f50", "unvendored_tests": false, "version": "2025.3"}, "ujson": {"depends": [], "file_name": "ujson-5.11.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["ujson"], "install_dir": "site", "name": "ujson", "package_type": "package", "sha256": "e9e8e11ebb2f314db428661fe635fe44af8bb9740f44847f3c60510e21b7b0c0", "unvendored_tests": false, "version": "5.11.0"}, "uncertainties": {"depends": ["future"], "file_name": "uncertainties-3.2.2-py3-none-any.whl", "imports": ["uncertainties"], "install_dir": "site", "name": "uncertainties", "package_type": "package", "sha256": "0abeeb1832fb157815a5c11b6b1fc83ed29304044df77959873fe621d3ffd6ed", "unvendored_tests": false, "version": "3.2.2"}, "unyt": {"depends": ["numpy", "packaging", "sympy"], "file_name": "unyt-3.0.3-py3-none-any.whl", "imports": ["unyt"], "install_dir": "site", "name": "unyt", "package_type": "package", "sha256": "ecf3b23f3cec33e7edd09477b267862274b06c7044341b2ae62c83422dad49e7", "unvendored_tests": true, "version": "3.0.3"}, "unyt-tests": {"depends": ["unyt"], "file_name": "unyt-tests.tar", "imports": [], "install_dir": "site", "name": "unyt-tests", "package_type": "package", "sha256": "8ab10030c32bd8f159dd871d290d0e41203197392cf25f5e98ba0e2b0e5d9d64", "unvendored_tests": false, "version": "3.0.3"}, "urllib3": {"depends": [], "file_name": "urllib3-2.5.0-py3-none-any.whl", "imports": ["urllib3"], "install_dir": "site", "name": "urllib3", "package_type": "package", "sha256": "ae930887b25087f9ba80e06d57b22c7c047c0d5db3fca3df6e932cdebbb77ad6", "unvendored_tests": false, "version": "2.5.0"}, "vega-datasets": {"depends": ["pandas"], "file_name": "vega_datasets-0.9.0-py3-none-any.whl", "imports": ["vega_datasets"], "install_dir": "site", "name": "vega-datasets", "package_type": "package", "sha256": "f6c66410b3fe2b8b65ad62c99ea7251eba29b352fd84c1aceec86c511a325f3c", "unvendored_tests": true, "version": "0.9.0"}, "vega-datasets-tests": {"depends": ["vega-datasets"], "file_name": "vega-datasets-tests.tar", "imports": [], "install_dir": "site", "name": "vega-datasets-tests", "package_type": "package", "sha256": "2d4c7ecccbb7bbb037a02da795d5c9a6ad9f0e655f2fce63d34b2c928c72b63d", "unvendored_tests": false, "version": "0.9.0"}, "vrplib": {"depends": ["numpy"], "file_name": "vrplib-2.0.1-py3-none-any.whl", "imports": ["vrplib"], "install_dir": "site", "name": "vrplib", "package_type": "package", "sha256": "1cbe88b6ffc6d7f25b4a7b1ed3bc363126cef615498dd4a1e689e89ebacd16b0", "unvendored_tests": false, "version": "2.0.1"}, "wcwidth": {"depends": [], "file_name": "wcwidth-0.2.13-py2.py3-none-any.whl", "imports": ["wcwidth"], "install_dir": "site", "name": "wcwidth", "package_type": "package", "sha256": "5aea2ced9398448b2807b68a484586aeb5c91cac95a634acf39e2300ad9847c8", "unvendored_tests": false, "version": "0.2.13"}, "webencodings": {"depends": [], "file_name": "webencodings-0.5.1-py2.py3-none-any.whl", "imports": ["webencodings"], "install_dir": "site", "name": "webencodings", "package_type": "package", "sha256": "a0a893e9e174cf99d91b2750287735a5273678c0bdb9acf9708b567207a5c14a", "unvendored_tests": false, "version": "0.5.1"}, "wordcloud": {"depends": ["matplotlib"], "file_name": "wordcloud-1.9.4-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["wordcloud"], "install_dir": "site", "name": "wordcloud", "package_type": "package", "sha256": "35b1a40bf00e29e8b14fa9a43047f4fbea82dabeddfa3cb0b517c1833b4f0836", "unvendored_tests": false, "version": "1.9.4"}, "wrapt": {"depends": [], "file_name": "wrapt-1.17.2-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["wrapt"], "install_dir": "site", "name": "wrapt", "package_type": "package", "sha256": "00dc226b5b1af067344049c90e4ac1805dc7dd8fb4bea71940a8e801b7f18706", "unvendored_tests": false, "version": "1.17.2"}, "xarray": {"depends": ["numpy", "packaging", "pandas"], "file_name": "xarray-2025.12.0-py3-none-any.whl", "imports": ["xarray"], "install_dir": "site", "name": "xarray", "package_type": "package", "sha256": "c2cfc5a4c2f4761799048730b953b12417c4ed5d112c71c0e8918636713c4b5b", "unvendored_tests": true, "version": "2025.12.0"}, "xarray-tests": {"depends": ["xarray"], "file_name": "xarray-tests.tar", "imports": [], "install_dir": "site", "name": "xarray-tests", "package_type": "package", "sha256": "d88594de4f27ca72812cdb4f237ff769b091d40481ef45d2f044050d04972bc3", "unvendored_tests": false, "version": "2025.12.0"}, "xgboost": {"depends": ["numpy", "scipy", "setuptools"], "file_name": "xgboost-2.1.4-py3-none-pyodide_2025_0_wasm32.whl", "imports": ["xgboost"], "install_dir": "site", "name": "xgboost", "package_type": "package", "sha256": "35e2a5898b84ee763b93144fc7906c7fe72c2a45b28833f57d0ae5a27742c93f", "unvendored_tests": false, "version": "2.1.4"}, "xlrd": {"depends": [], "file_name": "xlrd-2.0.1-py2.py3-none-any.whl", "imports": ["xlrd"], "install_dir": "site", "name": "xlrd", "package_type": "package", "sha256": "2872cbcef5a5df3a5cc547aaebdd0ffe5256c3e79d817f3be69574350faf1090", "unvendored_tests": false, "version": "2.0.1"}, "xxhash": {"depends": [], "file_name": "xxhash-3.5.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["xxhash"], "install_dir": "site", "name": "xxhash", "package_type": "package", "sha256": "2ce8ffb702fb7d67520de4c81c111a3475b2615cab0614969f44dd6aade3878a", "unvendored_tests": false, "version": "3.5.0"}, "xyzservices": {"depends": [], "file_name": "xyzservices-2025.1.0-py3-none-any.whl", "imports": ["xyzservices"], "install_dir": "site", "name": "xyzservices", "package_type": "package", "sha256": "26daed3f653ba211516d70b3634e74be7a86e801bee481840ebc6d4fa841cd0d", "unvendored_tests": true, "version": "2025.1.0"}, "xyzservices-tests": {"depends": ["xyzservices"], "file_name": "xyzservices-tests.tar", "imports": [], "install_dir": "site", "name": "xyzservices-tests", "package_type": "package", "sha256": "660c4cc829acd35aecab7aaa293e76fa0d8cb8ac9fdcb7c548a5ae44a1a26fd1", "unvendored_tests": false, "version": "2025.1.0"}, "yarl": {"depends": ["multidict", "idna", "propcache"], "file_name": "yarl-1.18.3-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["yarl"], "install_dir": "site", "name": "yarl", "package_type": "package", "sha256": "0ede8d5eb487bae5b75729d78829bd3d86ff08efa30c020fe71a3213e9df25ec", "unvendored_tests": false, "version": "1.18.3"}, "yt": {"depends": ["ewah_bool_utils", "numpy", "matplotlib", "sympy", "setuptools", "packaging", "unyt", "cmyt", "colorspacious", "tqdm", "tomli", "tomli-w"], "file_name": "yt-4.4.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["yt"], "install_dir": "site", "name": "yt", "package_type": "package", "sha256": "f9537bb9b17b74eb53bf97f4e9e7fa7a808d71ec3d45403e96c447eb623b6eef", "unvendored_tests": false, "version": "4.4.0"}, "zengl": {"depends": [], "file_name": "zengl-2.7.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["zengl", "_zengl"], "install_dir": "site", "name": "zengl", "package_type": "package", "sha256": "1ea96005955b706cc28057be6df05e3ef00e78e4a2683595cdfac56a68ebbe5e", "unvendored_tests": false, "version": "2.7.1"}, "zfpy": {"depends": ["numpy"], "file_name": "zfpy-1.0.1-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["zfpy"], "install_dir": "site", "name": "zfpy", "package_type": "package", "sha256": "a402cd384e7c32bb78c486fb7201a990a3b550b5fe57ab440b3fd8fc721249f1", "unvendored_tests": false, "version": "1.0.1"}, "zstandard": {"depends": ["cffi"], "file_name": "zstandard-0.23.0-cp313-cp313-pyodide_2025_0_wasm32.whl", "imports": ["zstandard"], "install_dir": "site", "name": "zstandard", "package_type": "package", "sha256": "c365a307b01175281bd2d0d56d0092c4f0c97cdc8273e029d01dc4cabbc77fa1", "unvendored_tests": false, "version": "0.23.0"}}} ================================================ FILE: public/pyodide/pyodide.asm.js ================================================ "use strict"; var _createPyodideModule = (() => { var _scriptName = typeof document != 'undefined' ? document.currentScript?.src : undefined; return ( async function(moduleArg = {}) { var moduleRtn; var Module=moduleArg;var readyPromiseResolve,readyPromiseReject;var readyPromise=new Promise((resolve,reject)=>{readyPromiseResolve=resolve;readyPromiseReject=reject});var ENVIRONMENT_IS_WEB=typeof window=="object";var ENVIRONMENT_IS_WORKER=typeof WorkerGlobalScope!="undefined";var ENVIRONMENT_IS_NODE=typeof process=="object"&&process.versions?.node&&process.type!="renderer";var ENVIRONMENT_IS_SHELL=!ENVIRONMENT_IS_WEB&&!ENVIRONMENT_IS_NODE&&!ENVIRONMENT_IS_WORKER;if(ENVIRONMENT_IS_NODE){}var arguments_=[];var thisProgram="./this.program";var quit_=(status,toThrow)=>{throw toThrow};if(typeof __filename!="undefined"){_scriptName=__filename}else if(ENVIRONMENT_IS_WORKER){_scriptName=self.location.href}var scriptDirectory="";function locateFile(path){if(Module["locateFile"]){return Module["locateFile"](path,scriptDirectory)}return scriptDirectory+path}var readAsync,readBinary;if(ENVIRONMENT_IS_NODE){var fs=require("fs");var nodePath=require("path");scriptDirectory=__dirname+"/";readBinary=filename=>{filename=isFileURI(filename)?new URL(filename):filename;var ret=fs.readFileSync(filename);return ret};readAsync=async(filename,binary=true)=>{filename=isFileURI(filename)?new URL(filename):filename;var ret=fs.readFileSync(filename,binary?undefined:"utf8");return ret};if(process.argv.length>1){thisProgram=process.argv[1].replace(/\\/g,"/")}arguments_=process.argv.slice(2);quit_=(status,toThrow)=>{process.exitCode=status;throw toThrow}}else if(ENVIRONMENT_IS_SHELL){readBinary=f=>{if(typeof readbuffer=="function"){return new Uint8Array(readbuffer(f))}let data=read(f,"binary");assert(typeof data=="object");return data};readAsync=async f=>readBinary(f);globalThis.clearTimeout??=id=>{};globalThis.setTimeout??=f=>f();arguments_=globalThis.arguments||globalThis.scriptArgs;if(typeof quit=="function"){quit_=(status,toThrow)=>{setTimeout(()=>{if(!(toThrow instanceof ExitStatus)){let toLog=toThrow;if(toThrow&&typeof toThrow=="object"&&toThrow.stack){toLog=[toThrow,toThrow.stack]}err(`exiting due to exception: ${toLog}`)}quit(status)});throw toThrow}}if(typeof print!="undefined"){globalThis.console??={};console.log=print;console.warn=console.error=globalThis.printErr??print}}else if(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER){try{scriptDirectory=new URL(".",_scriptName).href}catch{}{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=async url=>{if(isFileURI(url)){return new Promise((resolve,reject)=>{var xhr=new XMLHttpRequest;xhr.open("GET",url,true);xhr.responseType="arraybuffer";xhr.onload=()=>{if(xhr.status==200||xhr.status==0&&xhr.response){resolve(xhr.response);return}reject(xhr.status)};xhr.onerror=reject;xhr.send(null)})}var response=await fetch(url,{credentials:"same-origin"});if(response.ok){return response.arrayBuffer()}throw new Error(response.status+" : "+response.url)}}}else{}var out=console.log.bind(console);var err=console.error.bind(console);var dynamicLibraries=[];var wasmBinary;var wasmMemory;var ABORT=false;var EXITSTATUS;function assert(condition,text){if(!condition){abort(text)}}var HEAP,HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HEAPU32,HEAPF32,HEAP64,HEAPU64,HEAPF64;var runtimeInitialized=false;var runtimeExited=false;var isFileURI=filename=>filename.startsWith("file://");function updateMemoryViews(){var b=wasmMemory.buffer;Module["HEAP8"]=HEAP8=new Int8Array(b);Module["HEAP16"]=HEAP16=new Int16Array(b);Module["HEAPU8"]=HEAPU8=new Uint8Array(b);Module["HEAPU16"]=HEAPU16=new Uint16Array(b);Module["HEAP32"]=HEAP32=new Int32Array(b);Module["HEAPU32"]=HEAPU32=new Uint32Array(b);Module["HEAPF32"]=HEAPF32=new Float32Array(b);Module["HEAPF64"]=HEAPF64=new Float64Array(b);Module["HEAP64"]=HEAP64=new BigInt64Array(b);Module["HEAPU64"]=HEAPU64=new BigUint64Array(b)}function initMemory(){if(Module["wasmMemory"]){wasmMemory=Module["wasmMemory"]}else{var INITIAL_MEMORY=Module["INITIAL_MEMORY"]||20971520;wasmMemory=new WebAssembly.Memory({initial:INITIAL_MEMORY/65536,maximum:65536})}updateMemoryViews()}var __RELOC_FUNCS__=[];function preRun(){if(Module["preRun"]){if(typeof Module["preRun"]=="function")Module["preRun"]=[Module["preRun"]];while(Module["preRun"].length){addOnPreRun(Module["preRun"].shift())}}callRuntimeCallbacks(onPreRuns)}function initRuntime(){runtimeInitialized=true;callRuntimeCallbacks(__RELOC_FUNCS__);callRuntimeCallbacks(onInits);if(!Module["noFSInit"]&&!FS.initialized)FS.init();TTY.init();SOCKFS.root=FS.mount(SOCKFS,{},null);PIPEFS.root=FS.mount(PIPEFS,{},null);wasmExports["__wasm_call_ctors"]();callRuntimeCallbacks(onPostCtors);FS.ignorePermissions=false}function preMain(){callRuntimeCallbacks(onMains)}function exitRuntime(){___funcs_on_exit();callRuntimeCallbacks(onExits);FS.quit();TTY.shutdown();IDBFS.quit();runtimeExited=true}function postRun(){if(Module["postRun"]){if(typeof Module["postRun"]=="function")Module["postRun"]=[Module["postRun"]];while(Module["postRun"].length){addOnPostRun(Module["postRun"].shift())}}callRuntimeCallbacks(onPostRuns)}var runDependencies=0;var dependenciesFulfilled=null;function getUniqueRunDependency(id){return id}function addRunDependency(id){runDependencies++;Module["monitorRunDependencies"]?.(runDependencies)}function removeRunDependency(id){runDependencies--;Module["monitorRunDependencies"]?.(runDependencies);if(runDependencies==0){if(dependenciesFulfilled){var callback=dependenciesFulfilled;dependenciesFulfilled=null;callback()}}}function abort(what){Module["onAbort"]?.(what);what="Aborted("+what+")";err(what);ABORT=true;what+=". Build with -sASSERTIONS for more info.";if(runtimeInitialized){___trap()}var e=new WebAssembly.RuntimeError(what);readyPromiseReject(e);throw e}var wasmBinaryFile;function findWasmBinary(){return locateFile("pyodide.asm.wasm")}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"}async function getWasmBinary(binaryFile){if(!wasmBinary){try{var response=await readAsync(binaryFile);return new Uint8Array(response)}catch{}}return getBinarySync(binaryFile)}async function instantiateArrayBuffer(binaryFile,imports){try{var binary=await getWasmBinary(binaryFile);var instance=await WebAssembly.instantiate(binary,imports);return instance}catch(reason){err(`failed to asynchronously prepare wasm: ${reason}`);abort(reason)}}async function instantiateAsync(binary,binaryFile,imports){if(!binary&&typeof WebAssembly.instantiateStreaming=="function"&&!isFileURI(binaryFile)&&!ENVIRONMENT_IS_NODE&&!ENVIRONMENT_IS_SHELL){try{var response=fetch(binaryFile,{credentials:"same-origin"});var instantiationResult=await WebAssembly.instantiateStreaming(response,imports);return instantiationResult}catch(reason){err(`wasm streaming compile failed: ${reason}`);err("falling back to ArrayBuffer instantiation")}}return instantiateArrayBuffer(binaryFile,imports)}function getWasmImports(){return{env:wasmImports,wasi_snapshot_preview1:wasmImports,"GOT.mem":new Proxy(wasmImports,GOTHandler),"GOT.func":new Proxy(wasmImports,GOTHandler)}}async function createWasm(){function receiveInstance(instance,module){wasmExports=instance.exports;wasmExports=relocateExports(wasmExports,1024);var metadata=getDylinkMetadata(module);if(metadata.neededDynlibs){dynamicLibraries=metadata.neededDynlibs.concat(dynamicLibraries)}mergeLibSymbols(wasmExports,"main");LDSO.init();loadDylibs();wasmExports=applySignatureConversions(wasmExports);__RELOC_FUNCS__.push(wasmExports["__wasm_apply_data_relocs"]);removeRunDependency("wasm-instantiate");return wasmExports}addRunDependency("wasm-instantiate");function receiveInstantiationResult(result){return receiveInstance(result["instance"],result["module"])}var info=getWasmImports();if(Module["instantiateWasm"]){return new Promise((resolve,reject)=>{Module["instantiateWasm"](info,(mod,inst)=>{resolve(receiveInstance(mod,inst))})})}wasmBinaryFile??=findWasmBinary();try{var result=await instantiateAsync(wasmBinary,wasmBinaryFile,info);var exports=receiveInstantiationResult(result);return exports}catch(e){readyPromiseReject(e);return Promise.reject(e)}}class ExitStatus{name="ExitStatus";constructor(status){this.message=`Program terminated with exit(${status})`;this.status=status}}var GOT={};var currentModuleWeakSymbols=new Set([]);var GOTHandler={get(obj,symName){var rtn=GOT[symName];if(!rtn){rtn=GOT[symName]=new WebAssembly.Global({value:"i32",mutable:true})}if(!currentModuleWeakSymbols.has(symName)){rtn.required=true}return rtn}};var callRuntimeCallbacks=callbacks=>{while(callbacks.length>0){callbacks.shift()(Module)}};var onPostRuns=[];var addOnPostRun=cb=>onPostRuns.push(cb);var onPreRuns=[];var addOnPreRun=cb=>onPreRuns.push(cb);var UTF8Decoder=typeof TextDecoder!="undefined"?new TextDecoder:undefined;var UTF8ArrayToString=(heapOrArray,idx=0,maxBytesToRead=NaN)=>{idx>>>=0;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>10,56320|ch&1023)}}return str};var getDylinkMetadata=binary=>{var offset=0;var end=0;function getU8(){return binary[offset++]}function getLEB(){var ret=0;var mul=1;while(1){var byte=binary[offset++];ret+=(byte&127)*mul;mul*=128;if(!(byte&128))break}return ret}function getString(){var len=getLEB();offset+=len;return UTF8ArrayToString(binary,offset-len,len)}function getStringList(){var count=getLEB();var rtn=[];while(count--)rtn.push(getString());return rtn}function failIf(condition,message){if(condition)throw new Error(message)}if(binary instanceof WebAssembly.Module){var dylinkSection=WebAssembly.Module.customSections(binary,"dylink.0");failIf(dylinkSection.length===0,"need dylink section");binary=new Uint8Array(dylinkSection[0]);end=binary.length}else{var int32View=new Uint32Array(new Uint8Array(binary.subarray(0,24)).buffer);var magicNumberFound=int32View[0]==1836278016;failIf(!magicNumberFound,"need to see wasm magic number");failIf(binary[8]!==0,"need the dylink section to be first");offset=9;var section_size=getLEB();end=offset+section_size;var name=getString();failIf(name!=="dylink.0")}var customSection={neededDynlibs:[],tlsExports:new Set,weakImports:new Set,runtimePaths:[]};var WASM_DYLINK_MEM_INFO=1;var WASM_DYLINK_NEEDED=2;var WASM_DYLINK_EXPORT_INFO=3;var WASM_DYLINK_IMPORT_INFO=4;var WASM_DYLINK_RUNTIME_PATH=5;var WASM_SYMBOL_TLS=256;var WASM_SYMBOL_BINDING_MASK=3;var WASM_SYMBOL_BINDING_WEAK=1;while(offset>>0];case"i8":return HEAP8[ptr>>>0];case"i16":return HEAP16[ptr>>>1>>>0];case"i32":return HEAP32[ptr>>>2>>>0];case"i64":return HEAP64[ptr>>>3>>>0];case"float":return HEAPF32[ptr>>>2>>>0];case"double":return HEAPF64[ptr>>>3>>>0];case"*":return HEAPU32[ptr>>>2>>>0];default:abort(`invalid type for getValue: ${type}`)}}var newDSO=(name,handle,syms)=>{var dso={refcount:Infinity,name,exports:syms,global:true};LDSO.loadedLibsByName[name]=dso;if(handle!=undefined){LDSO.loadedLibsByHandle[handle]=dso}return dso};var LDSO={loadedLibsByName:{},loadedLibsByHandle:{},init(){newDSO("__main__",0,wasmImports)}};var ___heap_base=8810528;var alignMemory=(size,alignment)=>Math.ceil(size/alignment)*alignment;var getMemory=size=>{if(runtimeInitialized){return _calloc(size,1)}var ret=___heap_base;var end=ret+alignMemory(size,16);___heap_base=end;GOT["__heap_base"].value=end;return ret};var isInternalSym=symName=>["__cpp_exception","__c_longjmp","__wasm_apply_data_relocs","__dso_handle","__tls_size","__tls_align","__set_stack_limits","_emscripten_tls_init","__wasm_init_tls","__wasm_call_ctors","__start_em_asm","__stop_em_asm","__start_em_js","__stop_em_js"].includes(symName)||symName.startsWith("__em_js__");var uleb128Encode=(n,target)=>{if(n<128){target.push(n)}else{target.push(n%128|128,n>>7)}};var sigToWasmTypes=sig=>{var typeNames={i:"i32",j:"i64",f:"f32",d:"f64",e:"externref",p:"i32"};var type={parameters:[],results:sig[0]=="v"?[]:[typeNames[sig[0]]]};for(var i=1;i{var sigRet=sig.slice(0,1);var sigParam=sig.slice(1);var typeCodes={i:127,p:127,j:126,f:125,d:124,e:111};target.push(96);uleb128Encode(sigParam.length,target);for(var paramType of sigParam){target.push(typeCodes[paramType])}if(sigRet=="v"){target.push(0)}else{target.push(1,typeCodes[sigRet])}};var convertJsFunctionToWasm=(func,sig)=>{if(typeof WebAssembly.Function=="function"){return new WebAssembly.Function(sigToWasmTypes(sig),func)}var typeSectionBody=[1];generateFuncType(sig,typeSectionBody);var bytes=[0,97,115,109,1,0,0,0,1];uleb128Encode(typeSectionBody.length,bytes);bytes.push(...typeSectionBody);bytes.push(2,7,1,1,101,1,102,0,0,7,5,1,1,102,0,0);var module=new WebAssembly.Module(new Uint8Array(bytes));var instance=new WebAssembly.Instance(module,{e:{f:func}});var wrappedFunc=instance.exports["f"];return wrappedFunc};var wasmTableMirror=[];var wasmTable=new WebAssembly.Table({initial:6076,element:"anyfunc"});var getWasmTableEntry=funcPtr=>{var func=wasmTableMirror[funcPtr];if(!func){wasmTableMirror[funcPtr]=func=wasmTable.get(funcPtr)}return func};var updateTableMap=(offset,count)=>{if(functionsInTableMap){for(var i=offset;i{if(!functionsInTableMap){functionsInTableMap=new WeakMap;updateTableMap(0,wasmTable.length)}return functionsInTableMap.get(func)||0};var freeTableIndexes=[];var getEmptyTableSlot=()=>{if(freeTableIndexes.length){return freeTableIndexes.pop()}try{wasmTable.grow(1)}catch(err){if(!(err instanceof RangeError)){throw err}throw"Unable to grow wasm table. Set ALLOW_TABLE_GROWTH."}return wasmTable.length-1};var setWasmTableEntry=(idx,func)=>{wasmTable.set(idx,func);wasmTableMirror[idx]=wasmTable.get(idx)};var addFunction=(func,sig)=>{var rtn=getFunctionAddress(func);if(rtn){return rtn}var ret=getEmptyTableSlot();try{setWasmTableEntry(ret,func)}catch(err){if(!(err instanceof TypeError)){throw err}var wrapped=convertJsFunctionToWasm(func,sig);setWasmTableEntry(ret,wrapped)}functionsInTableMap.set(func,ret);return ret};var updateGOT=(exports,replace)=>{for(var symName in exports){if(isInternalSym(symName)){continue}var value=exports[symName];GOT[symName]||=new WebAssembly.Global({value:"i32",mutable:true});if(replace||GOT[symName].value==0){if(typeof value=="function"){GOT[symName].value=addFunction(value)}else if(typeof value=="number"){GOT[symName].value=value}else{err(`unhandled export type for '${symName}': ${typeof value}`)}}}};var relocateExports=(exports,memoryBase,replace)=>{var relocated={};for(var e in exports){var value=exports[e];if(typeof value=="object"){value=value.value}if(typeof value=="number"){value+=memoryBase}relocated[e]=value}updateGOT(relocated,replace);return relocated};var isSymbolDefined=symName=>{var existing=wasmImports[symName];if(!existing||existing.stub){return false}return true};var resolveGlobalSymbol=(symName,direct=false)=>{var sym;if(isSymbolDefined(symName)){sym=wasmImports[symName]}return{sym,name:symName}};var onPostCtors=[];var addOnPostCtor=cb=>onPostCtors.push(cb);var UTF8ToString=(ptr,maxBytesToRead)=>{ptr>>>=0;return ptr?UTF8ArrayToString(HEAPU8,ptr,maxBytesToRead):""};var loadWebAssemblyModule=(binary,flags,libName,localScope,handle)=>{var metadata=getDylinkMetadata(binary);currentModuleWeakSymbols=metadata.weakImports;function loadModule(){var memAlign=Math.pow(2,metadata.memoryAlign);var memoryBase=metadata.memorySize?alignMemory(getMemory(metadata.memorySize+memAlign),memAlign):0;var tableBase=metadata.tableSize?wasmTable.length:0;if(handle){HEAP8[handle+8>>>0]=1;HEAPU32[handle+12>>>2>>>0]=memoryBase;HEAP32[handle+16>>>2>>>0]=metadata.memorySize;HEAPU32[handle+20>>>2>>>0]=tableBase;HEAP32[handle+24>>>2>>>0]=metadata.tableSize}if(metadata.tableSize){wasmTable.grow(metadata.tableSize)}var moduleExports;function resolveSymbol(sym){var resolved=resolveGlobalSymbol(sym).sym;if(!resolved&&localScope){resolved=localScope[sym]}if(!resolved){resolved=moduleExports[sym]}return resolved}var proxyHandler={get(stubs,prop){switch(prop){case"__memory_base":return memoryBase;case"__table_base":return tableBase}if(prop in wasmImports&&!wasmImports[prop].stub){var res=wasmImports[prop];return res}if(!(prop in stubs)){var resolved;stubs[prop]=(...args)=>{resolved||=resolveSymbol(prop);if(!resolved){throw new Error(`Dynamic linking error: cannot resolve symbol ${prop}`)}return resolved(...args)}}return stubs[prop]}};var proxy=new Proxy({},proxyHandler);var info={"GOT.mem":new Proxy({},GOTHandler),"GOT.func":new Proxy({},GOTHandler),env:proxy,wasi_snapshot_preview1:proxy};function postInstantiation(module,instance){updateTableMap(tableBase,metadata.tableSize);moduleExports=relocateExports(instance.exports,memoryBase);if(!flags.allowUndefined){reportUndefinedSymbols()}function addEmAsm(addr,body){var args=[];var arity=0;for(;arity<16;arity++){if(body.indexOf("$"+arity)!=-1){args.push("$"+arity)}else{break}}args=args.join(",");var func=`(${args}) => { ${body} };`;ASM_CONSTS[start]=eval(func)}if("__start_em_asm"in moduleExports){var start=moduleExports["__start_em_asm"];var stop=moduleExports["__stop_em_asm"];while(start ${body};`;moduleExports[name]=eval(func)}for(var name in moduleExports){if(name.startsWith("__em_js__")){var start=moduleExports[name];var jsString=UTF8ToString(start);var parts=jsString.split("<::>");addEmJs(name.replace("__em_js__",""),parts[0],parts[1]);delete moduleExports[name]}}var applyRelocs=moduleExports["__wasm_apply_data_relocs"];if(applyRelocs){if(runtimeInitialized){applyRelocs()}else{__RELOC_FUNCS__.push(applyRelocs)}}var init=moduleExports["__wasm_call_ctors"];if(init){if(runtimeInitialized){init()}else{addOnPostCtor(init)}}return moduleExports}if(flags.loadAsync){return(async()=>{var instance;if(binary instanceof WebAssembly.Module){instance=new WebAssembly.Instance(binary,info)}else{({module:binary,instance}=await WebAssembly.instantiate(binary,info))}return postInstantiation(binary,instance)})()}var module=binary instanceof WebAssembly.Module?binary:new WebAssembly.Module(binary);var instance=new WebAssembly.Instance(module,info);return postInstantiation(module,instance)}flags={...flags,rpath:{parentLibPath:libName,paths:metadata.runtimePaths}};if(flags.loadAsync){return metadata.neededDynlibs.reduce((chain,needed)=>chain.then(()=>{needed=findLibraryFS(needed,flags.rpath)??needed;return loadDynamicLibrary(needed,flags,localScope)}),Promise.resolve()).then(loadModule)}metadata.neededDynlibs.forEach(needed=>{needed=findLibraryFS(needed,flags.rpath)??needed;return loadDynamicLibrary(needed,flags,localScope)});return loadModule()};var mergeLibSymbols=(exports,libName)=>{for(var[sym,exp]of Object.entries(exports)){const setImport=target=>{if(!isSymbolDefined(target)){wasmImports[target]=exp}};setImport(sym);const main_alias="__main_argc_argv";if(sym=="main"){setImport(main_alias)}if(sym==main_alias){setImport("main")}}};var asyncLoad=async url=>{var arrayBuffer=await readAsync(url);return new Uint8Array(arrayBuffer)};var preloadPlugins=[];var registerWasmPlugin=()=>{var wasmPlugin={promiseChainEnd:Promise.resolve(),canHandle:name=>!Module["noWasmDecoding"]&&name.endsWith(".so"),handle:(byteArray,name,onload,onerror)=>{wasmPlugin["promiseChainEnd"]=wasmPlugin["promiseChainEnd"].then(()=>loadWebAssemblyModule(byteArray,{loadAsync:true,nodelete:true},name,{})).then(exports=>{preloadedWasm[name]=exports;onload(byteArray)},error=>{err(`failed to instantiate wasm: ${name}: ${error}`);onerror()})}};preloadPlugins.push(wasmPlugin)};var preloadedWasm={};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.slice(-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.slice(0,-1)}return root+dir},basename:path=>path&&path.match(/([^\/]+|\/)\/*$/)[1],join:(...paths)=>PATH.normalize(paths.join("/")),join2:(l,r)=>PATH.normalize(l+"/"+r)};var replaceORIGIN=(parentLibName,rpath)=>{if(rpath.startsWith("$ORIGIN")){var origin=PATH.dirname(parentLibName);return rpath.replace("$ORIGIN",origin)}return rpath};var stackSave=()=>_emscripten_stack_get_current();var stackRestore=val=>__emscripten_stack_restore(val);var withStackSave=f=>{var stack=stackSave();var ret=f();stackRestore(stack);return ret};var stackAlloc=sz=>__emscripten_stack_alloc(sz);var lengthBytesUTF8=str=>{var len=0;for(var i=0;i=55296&&c<=57343){len+=4;++i}else{len+=3}}return len};var stringToUTF8Array=(str,heap,outIdx,maxBytesToWrite)=>{outIdx>>>=0;if(!(maxBytesToWrite>0))return 0;var startIdx=outIdx;var endIdx=outIdx+maxBytesToWrite-1;for(var i=0;i=55296&&u<=57343){var u1=str.charCodeAt(++i);u=65536+((u&1023)<<10)|u1&1023}if(u<=127){if(outIdx>=endIdx)break;heap[outIdx++>>>0]=u}else if(u<=2047){if(outIdx+1>=endIdx)break;heap[outIdx++>>>0]=192|u>>6;heap[outIdx++>>>0]=128|u&63}else if(u<=65535){if(outIdx+2>=endIdx)break;heap[outIdx++>>>0]=224|u>>12;heap[outIdx++>>>0]=128|u>>6&63;heap[outIdx++>>>0]=128|u&63}else{if(outIdx+3>=endIdx)break;heap[outIdx++>>>0]=240|u>>18;heap[outIdx++>>>0]=128|u>>12&63;heap[outIdx++>>>0]=128|u>>6&63;heap[outIdx++>>>0]=128|u&63}}heap[outIdx>>>0]=0;return outIdx-startIdx};var stringToUTF8=(str,outPtr,maxBytesToWrite)=>stringToUTF8Array(str,HEAPU8,outPtr,maxBytesToWrite);var stringToUTF8OnStack=str=>{var size=lengthBytesUTF8(str)+1;var ret=stackAlloc(size);stringToUTF8(str,ret,size);return ret};var base64Decode=b64=>{if(ENVIRONMENT_IS_NODE){var buf=Buffer.from(b64,"base64");return new Uint8Array(buf.buffer,buf.byteOffset,buf.length)}var b1,b2,i=0,j=0,bLength=b64.length;var output=new Uint8Array((bLength*3>>2)-(b64[bLength-2]=="=")-(b64[bLength-1]=="="));for(;i>4;output[j+1]=b1<<4|b2>>2;output[j+2]=b2<<6|base64ReverseLookup[b64.charCodeAt(i+3)]}return output};var initRandomFill=()=>{if(ENVIRONMENT_IS_NODE){var nodeCrypto=require("crypto");return view=>nodeCrypto.randomFillSync(view)}if(ENVIRONMENT_IS_SHELL){return view=>{if(!os.system){throw new Error("randomFill not supported on d8 unless --enable-os-system is passed")}const b64=os.system("sh",["-c",`head -c${view.byteLength} /dev/urandom | base64 --wrap=0`]);view.set(base64Decode(b64))}}return view=>crypto.getRandomValues(view)};var randomFill=view=>{(randomFill=initRandomFill())(view)};var PATH_FS={resolve:(...args)=>{var resolvedPath="",resolvedAbsolute=false;for(var i=args.length-1;i>=-1&&!resolvedAbsolute;i--){var path=i>=0?args[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).slice(1);to=PATH_FS.resolve(to).slice(1);function trim(arr){var start=0;for(;start=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{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,0,BUFSIZE)}catch(e){if(e.toString().includes("EOF"))bytesRead=0;else throw e}if(bytesRead>0){result=buf.slice(0,bytesRead).toString("utf-8")}}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){result+="\n"}}else{}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;i0){out(UTF8ArrayToString(tty.output));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));tty.output=[]}else{if(val!=0)tty.output.push(val)}},fsync(tty){if(tty.output?.length>0){err(UTF8ArrayToString(tty.output));tty.output=[]}}}};var zeroMemory=(ptr,size)=>HEAPU8.fill(0,ptr,ptr+size);var mmapAlloc=size=>{size=alignMemory(size,65536);var ptr=_emscripten_builtin_memalign(65536,size);if(ptr)zeroMemory(ptr,size);return ptr};var MEMFS={ops_table:null,mount(mount){return MEMFS.createNode(null,"/",16895,0)},createNode(parent,name,mode,dev){if(FS.isBlkdev(mode)||FS.isFIFO(mode)){throw new FS.ErrnoError(63)}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,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.atime=node.mtime=node.ctime=Date.now();if(parent){parent.contents[name]=node;parent.atime=parent.mtime=parent.ctime=node.atime}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>>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.atime);attr.mtime=new Date(node.mtime);attr.ctime=new Date(node.ctime);attr.blksize=4096;attr.blocks=Math.ceil(attr.size/attr.blksize);return attr},setattr(node,attr){for(const key of["mode","atime","mtime","ctime"]){if(attr[key]!=null){node[key]=attr[key]}}if(attr.size!==undefined){MEMFS.resizeFileStorage(node,attr.size)}},lookup(parent,name){throw MEMFS.doesNotExistError},mknod(parent,name,mode,dev){return MEMFS.createNode(parent,name,mode,dev)},rename(old_node,new_dir,new_name){var new_node;try{new_node=FS.lookupNode(new_dir,new_name)}catch(e){}if(new_node){if(FS.isDir(old_node.mode)){for(var i in new_node.contents){throw new FS.ErrnoError(55)}}FS.hashRemoveNode(new_node)}delete old_node.parent.contents[old_node.name];new_dir.contents[new_name]=old_node;old_node.name=new_name;new_dir.ctime=new_dir.mtime=old_node.parent.ctime=old_node.parent.mtime=Date.now()},unlink(parent,name){delete parent.contents[name];parent.ctime=parent.mtime=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.ctime=parent.mtime=Date.now()},readdir(node){return[".","..",...Object.keys(node.contents)]},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;i0||position+length>>0)}}return{ptr,allocated}},msync(stream,buffer,offset,length,mmapFlags){MEMFS.stream_ops.write(stream,buffer,0,length,offset,false);return 0}}};var FS_createDataFile=(...args)=>FS.createDataFile(...args);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(byteArray){preFinish?.();if(!dontCreateFile){FS_createDataFile(parent,name,byteArray,canRead,canWrite,canOwn)}onload?.();removeRunDependency(dep)}if(FS_handledByPreloadPlugin(byteArray,fullname,finish,()=>{onerror?.();removeRunDependency(dep)})){return}finish(byteArray)}addRunDependency(dep);if(typeof url=="string"){asyncLoad(url).then(processData,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 IDBFS={dbs:{},indexedDB:()=>{if(typeof indexedDB!="undefined")return indexedDB;var ret=null;if(typeof window=="object")ret=window.indexedDB||window.mozIndexedDB||window.webkitIndexedDB||window.msIndexedDB;return ret},DB_VERSION:21,DB_STORE_NAME:"FILE_DATA",queuePersist:mount=>{function onPersistComplete(){if(mount.idbPersistState==="again")startPersist();else mount.idbPersistState=0}function startPersist(){mount.idbPersistState="idb";IDBFS.syncfs(mount,false,onPersistComplete)}if(!mount.idbPersistState){mount.idbPersistState=setTimeout(startPersist,0)}else if(mount.idbPersistState==="idb"){mount.idbPersistState="again"}},mount:mount=>{var mnt=MEMFS.mount(mount);if(mount?.opts?.autoPersist){mnt.idbPersistState=0;var memfs_node_ops=mnt.node_ops;mnt.node_ops={...mnt.node_ops};mnt.node_ops.mknod=(parent,name,mode,dev)=>{var node=memfs_node_ops.mknod(parent,name,mode,dev);node.node_ops=mnt.node_ops;node.idbfs_mount=mnt.mount;node.memfs_stream_ops=node.stream_ops;node.stream_ops={...node.stream_ops};node.stream_ops.write=(stream,buffer,offset,length,position,canOwn)=>{stream.node.isModified=true;return node.memfs_stream_ops.write(stream,buffer,offset,length,position,canOwn)};node.stream_ops.close=stream=>{var n=stream.node;if(n.isModified){IDBFS.queuePersist(n.idbfs_mount);n.isModified=false}if(n.memfs_stream_ops.close)return n.memfs_stream_ops.close(stream)};return node};mnt.node_ops.mkdir=(...args)=>(IDBFS.queuePersist(mnt.mount),memfs_node_ops.mkdir(...args));mnt.node_ops.rmdir=(...args)=>(IDBFS.queuePersist(mnt.mount),memfs_node_ops.rmdir(...args));mnt.node_ops.symlink=(...args)=>(IDBFS.queuePersist(mnt.mount),memfs_node_ops.symlink(...args));mnt.node_ops.unlink=(...args)=>(IDBFS.queuePersist(mnt.mount),memfs_node_ops.unlink(...args));mnt.node_ops.rename=(...args)=>(IDBFS.queuePersist(mnt.mount),memfs_node_ops.rename(...args))}return mnt},syncfs:(mount,populate,callback)=>{IDBFS.getLocalSet(mount,(err,local)=>{if(err)return callback(err);IDBFS.getRemoteSet(mount,(err,remote)=>{if(err)return callback(err);var src=populate?remote:local;var dst=populate?local:remote;IDBFS.reconcile(src,dst,callback)})})},quit:()=>{Object.values(IDBFS.dbs).forEach(value=>value.close());IDBFS.dbs={}},getDB:(name,callback)=>{var db=IDBFS.dbs[name];if(db){return callback(null,db)}var req;try{req=IDBFS.indexedDB().open(name,IDBFS.DB_VERSION)}catch(e){return callback(e)}if(!req){return callback("Unable to connect to IndexedDB")}req.onupgradeneeded=e=>{var db=e.target.result;var transaction=e.target.transaction;var fileStore;if(db.objectStoreNames.contains(IDBFS.DB_STORE_NAME)){fileStore=transaction.objectStore(IDBFS.DB_STORE_NAME)}else{fileStore=db.createObjectStore(IDBFS.DB_STORE_NAME)}if(!fileStore.indexNames.contains("timestamp")){fileStore.createIndex("timestamp","timestamp",{unique:false})}};req.onsuccess=()=>{db=req.result;IDBFS.dbs[name]=db;callback(null,db)};req.onerror=e=>{callback(e.target.error);e.preventDefault()}},getLocalSet:(mount,callback)=>{var entries={};function isRealDir(p){return p!=="."&&p!==".."}function toAbsolute(root){return p=>PATH.join2(root,p)}var check=FS.readdir(mount.mountpoint).filter(isRealDir).map(toAbsolute(mount.mountpoint));while(check.length){var path=check.pop();var stat;try{stat=FS.stat(path)}catch(e){return callback(e)}if(FS.isDir(stat.mode)){check.push(...FS.readdir(path).filter(isRealDir).map(toAbsolute(path)))}entries[path]={timestamp:stat.mtime}}return callback(null,{type:"local",entries})},getRemoteSet:(mount,callback)=>{var entries={};IDBFS.getDB(mount.mountpoint,(err,db)=>{if(err)return callback(err);try{var transaction=db.transaction([IDBFS.DB_STORE_NAME],"readonly");transaction.onerror=e=>{callback(e.target.error);e.preventDefault()};var store=transaction.objectStore(IDBFS.DB_STORE_NAME);var index=store.index("timestamp");index.openKeyCursor().onsuccess=event=>{var cursor=event.target.result;if(!cursor){return callback(null,{type:"remote",db,entries})}entries[cursor.primaryKey]={timestamp:cursor.key};cursor.continue()}}catch(e){return callback(e)}})},loadLocalEntry:(path,callback)=>{var stat,node;try{var lookup=FS.lookupPath(path);node=lookup.node;stat=FS.stat(path)}catch(e){return callback(e)}if(FS.isDir(stat.mode)){return callback(null,{timestamp:stat.mtime,mode:stat.mode})}else if(FS.isFile(stat.mode)){node.contents=MEMFS.getFileDataAsTypedArray(node);return callback(null,{timestamp:stat.mtime,mode:stat.mode,contents:node.contents})}else{return callback(new Error("node type not supported"))}},storeLocalEntry:(path,entry,callback)=>{try{if(FS.isDir(entry["mode"])){FS.mkdirTree(path,entry["mode"])}else if(FS.isFile(entry["mode"])){FS.writeFile(path,entry["contents"],{canOwn:true})}else{return callback(new Error("node type not supported"))}FS.chmod(path,entry["mode"]);FS.utime(path,entry["timestamp"],entry["timestamp"])}catch(e){return callback(e)}callback(null)},removeLocalEntry:(path,callback)=>{try{var stat=FS.stat(path);if(FS.isDir(stat.mode)){FS.rmdir(path)}else if(FS.isFile(stat.mode)){FS.unlink(path)}}catch(e){return callback(e)}callback(null)},loadRemoteEntry:(store,path,callback)=>{var req=store.get(path);req.onsuccess=event=>callback(null,event.target.result);req.onerror=e=>{callback(e.target.error);e.preventDefault()}},storeRemoteEntry:(store,path,entry,callback)=>{try{var req=store.put(entry,path)}catch(e){callback(e);return}req.onsuccess=event=>callback();req.onerror=e=>{callback(e.target.error);e.preventDefault()}},removeRemoteEntry:(store,path,callback)=>{var req=store.delete(path);req.onsuccess=event=>callback();req.onerror=e=>{callback(e.target.error);e.preventDefault()}},reconcile:(src,dst,callback)=>{var total=0;var create=[];Object.keys(src.entries).forEach(key=>{var e=src.entries[key];var e2=dst.entries[key];if(!e2||e["timestamp"].getTime()!=e2["timestamp"].getTime()){create.push(key);total++}});var remove=[];Object.keys(dst.entries).forEach(key=>{if(!src.entries[key]){remove.push(key);total++}});if(!total){return callback(null)}var errored=false;var db=src.type==="remote"?src.db:dst.db;var transaction=db.transaction([IDBFS.DB_STORE_NAME],"readwrite");var store=transaction.objectStore(IDBFS.DB_STORE_NAME);function done(err){if(err&&!errored){errored=true;return callback(err)}}transaction.onerror=transaction.onabort=e=>{done(e.target.error);e.preventDefault()};transaction.oncomplete=e=>{if(!errored){callback(null)}};create.sort().forEach(path=>{if(dst.type==="local"){IDBFS.loadRemoteEntry(store,path,(err,entry)=>{if(err)return done(err);IDBFS.storeLocalEntry(path,entry,done)})}else{IDBFS.loadLocalEntry(path,(err,entry)=>{if(err)return done(err);IDBFS.storeRemoteEntry(store,path,entry,done)})}});remove.sort().reverse().forEach(path=>{if(dst.type==="local"){IDBFS.removeLocalEntry(path,done)}else{IDBFS.removeRemoteEntry(store,path,done)}})}};var ERRNO_CODES={EPERM:63,ENOENT:44,ESRCH:71,EINTR:27,EIO:29,ENXIO:60,E2BIG:1,ENOEXEC:45,EBADF:8,ECHILD:12,EAGAIN:6,EWOULDBLOCK:6,ENOMEM:48,EACCES:2,EFAULT:21,ENOTBLK:105,EBUSY:10,EEXIST:20,EXDEV:75,ENODEV:43,ENOTDIR:54,EISDIR:31,EINVAL:28,ENFILE:41,EMFILE:33,ENOTTY:59,ETXTBSY:74,EFBIG:22,ENOSPC:51,ESPIPE:70,EROFS:69,EMLINK:34,EPIPE:64,EDOM:18,ERANGE:68,ENOMSG:49,EIDRM:24,ECHRNG:106,EL2NSYNC:156,EL3HLT:107,EL3RST:108,ELNRNG:109,EUNATCH:110,ENOCSI:111,EL2HLT:112,EDEADLK:16,ENOLCK:46,EBADE:113,EBADR:114,EXFULL:115,ENOANO:104,EBADRQC:103,EBADSLT:102,EDEADLOCK:16,EBFONT:101,ENOSTR:100,ENODATA:116,ETIME:117,ENOSR:118,ENONET:119,ENOPKG:120,EREMOTE:121,ENOLINK:47,EADV:122,ESRMNT:123,ECOMM:124,EPROTO:65,EMULTIHOP:36,EDOTDOT:125,EBADMSG:9,ENOTUNIQ:126,EBADFD:127,EREMCHG:128,ELIBACC:129,ELIBBAD:130,ELIBSCN:131,ELIBMAX:132,ELIBEXEC:133,ENOSYS:52,ENOTEMPTY:55,ENAMETOOLONG:37,ELOOP:32,EOPNOTSUPP:138,EPFNOSUPPORT:139,ECONNRESET:15,ENOBUFS:42,EAFNOSUPPORT:5,EPROTOTYPE:67,ENOTSOCK:57,ENOPROTOOPT:50,ESHUTDOWN:140,ECONNREFUSED:14,EADDRINUSE:3,ECONNABORTED:13,ENETUNREACH:40,ENETDOWN:38,ETIMEDOUT:73,EHOSTDOWN:142,EHOSTUNREACH:23,EINPROGRESS:26,EALREADY:7,EDESTADDRREQ:17,EMSGSIZE:35,EPROTONOSUPPORT:66,ESOCKTNOSUPPORT:137,EADDRNOTAVAIL:4,ENETRESET:39,EISCONN:30,ENOTCONN:53,ETOOMANYREFS:141,EUSERS:136,EDQUOT:19,ESTALE:72,ENOTSUP:138,ENOMEDIUM:148,EILSEQ:25,EOVERFLOW:61,ECANCELED:11,ENOTRECOVERABLE:56,EOWNERDEAD:62,ESTRPIPE:135};var NODEFS={isWindows:false,staticInit(){NODEFS.isWindows=!!process.platform.match(/^win/);var flags=process.binding("constants")["fs"];NODEFS.flagsForNodeMap={1024:flags["O_APPEND"],64:flags["O_CREAT"],128:flags["O_EXCL"],256:flags["O_NOCTTY"],0:flags["O_RDONLY"],2:flags["O_RDWR"],4096:flags["O_SYNC"],512:flags["O_TRUNC"],1:flags["O_WRONLY"],131072:flags["O_NOFOLLOW"]}},convertNodeCode(e){var code=e.code;return ERRNO_CODES[code]},tryFSOperation(f){try{return f()}catch(e){if(!e.code)throw e;if(e.code==="UNKNOWN")throw new FS.ErrnoError(28);throw new FS.ErrnoError(NODEFS.convertNodeCode(e))}},mount(mount){return NODEFS.createNode(null,"/",NODEFS.getMode(mount.opts.root),0)},createNode(parent,name,mode,dev){if(!FS.isDir(mode)&&!FS.isFile(mode)&&!FS.isLink(mode)){throw new FS.ErrnoError(28)}var node=FS.createNode(parent,name,mode);node.node_ops=NODEFS.node_ops;node.stream_ops=NODEFS.stream_ops;return node},getMode(path){return NODEFS.tryFSOperation(()=>{var mode=fs.lstatSync(path).mode;if(NODEFS.isWindows){mode|=(mode&292)>>2}return mode})},realPath(node){var parts=[];while(node.parent!==node){parts.push(node.name);node=node.parent}parts.push(node.mount.opts.root);parts.reverse();return PATH.join(...parts)},flagsForNode(flags){flags&=~2097152;flags&=~2048;flags&=~32768;flags&=~524288;flags&=~65536;var newFlags=0;for(var k in NODEFS.flagsForNodeMap){if(flags&k){newFlags|=NODEFS.flagsForNodeMap[k];flags^=k}}if(flags){throw new FS.ErrnoError(28)}return newFlags},getattr(func,node){var stat=NODEFS.tryFSOperation(func);if(NODEFS.isWindows){if(!stat.blksize){stat.blksize=4096}if(!stat.blocks){stat.blocks=(stat.size+stat.blksize-1)/stat.blksize|0}stat.mode|=(stat.mode&292)>>2}return{dev:stat.dev,ino:node.id,mode:stat.mode,nlink:stat.nlink,uid:stat.uid,gid:stat.gid,rdev:stat.rdev,size:stat.size,atime:stat.atime,mtime:stat.mtime,ctime:stat.ctime,blksize:stat.blksize,blocks:stat.blocks}},setattr(arg,node,attr,chmod,utimes,truncate,stat){NODEFS.tryFSOperation(()=>{if(attr.mode!==undefined){var mode=attr.mode;if(NODEFS.isWindows){mode&=384}chmod(arg,mode);node.mode=attr.mode}if(typeof(attr.atime??attr.mtime)==="number"){var atime=new Date(attr.atime??stat(arg).atime);var mtime=new Date(attr.mtime??stat(arg).mtime);utimes(arg,atime,mtime)}if(attr.size!==undefined){truncate(arg,attr.size)}})},node_ops:{getattr(node){var path=NODEFS.realPath(node);return NODEFS.getattr(()=>fs.lstatSync(path),node)},setattr(node,attr){var path=NODEFS.realPath(node);if(attr.mode!=null&&attr.dontFollow){throw new FS.ErrnoError(52)}NODEFS.setattr(path,node,attr,fs.chmodSync,fs.utimesSync,fs.truncateSync,fs.lstatSync)},lookup(parent,name){var path=PATH.join2(NODEFS.realPath(parent),name);var mode=NODEFS.getMode(path);return NODEFS.createNode(parent,name,mode)},mknod(parent,name,mode,dev){var node=NODEFS.createNode(parent,name,mode,dev);var path=NODEFS.realPath(node);NODEFS.tryFSOperation(()=>{if(FS.isDir(node.mode)){fs.mkdirSync(path,node.mode)}else{fs.writeFileSync(path,"",{mode:node.mode})}});return node},rename(oldNode,newDir,newName){var oldPath=NODEFS.realPath(oldNode);var newPath=PATH.join2(NODEFS.realPath(newDir),newName);try{FS.unlink(newPath)}catch(e){}NODEFS.tryFSOperation(()=>fs.renameSync(oldPath,newPath));oldNode.name=newName},unlink(parent,name){var path=PATH.join2(NODEFS.realPath(parent),name);NODEFS.tryFSOperation(()=>fs.unlinkSync(path))},rmdir(parent,name){var path=PATH.join2(NODEFS.realPath(parent),name);NODEFS.tryFSOperation(()=>fs.rmdirSync(path))},readdir(node){var path=NODEFS.realPath(node);return NODEFS.tryFSOperation(()=>fs.readdirSync(path))},symlink(parent,newName,oldPath){var newPath=PATH.join2(NODEFS.realPath(parent),newName);NODEFS.tryFSOperation(()=>fs.symlinkSync(oldPath,newPath))},readlink(node){var path=NODEFS.realPath(node);return NODEFS.tryFSOperation(()=>fs.readlinkSync(path))},statfs(path){var stats=NODEFS.tryFSOperation(()=>fs.statfsSync(path));stats.frsize=stats.bsize;return stats}},stream_ops:{getattr(stream){return NODEFS.getattr(()=>fs.fstatSync(stream.nfd),stream.node)},setattr(stream,attr){NODEFS.setattr(stream.nfd,stream.node,attr,fs.fchmodSync,fs.futimesSync,fs.ftruncateSync,fs.fstatSync)},open(stream){var path=NODEFS.realPath(stream.node);NODEFS.tryFSOperation(()=>{stream.shared.refcount=1;stream.nfd=fs.openSync(path,NODEFS.flagsForNode(stream.flags))})},close(stream){NODEFS.tryFSOperation(()=>{if(stream.nfd&&--stream.shared.refcount===0){fs.closeSync(stream.nfd)}})},dup(stream){stream.shared.refcount++},read(stream,buffer,offset,length,position){return NODEFS.tryFSOperation(()=>fs.readSync(stream.nfd,new Int8Array(buffer.buffer,offset,length),0,length,position))},write(stream,buffer,offset,length,position){return NODEFS.tryFSOperation(()=>fs.writeSync(stream.nfd,new Int8Array(buffer.buffer,offset,length),0,length,position))},llseek(stream,offset,whence){var position=offset;if(whence===1){position+=stream.position}else if(whence===2){if(FS.isFile(stream.node.mode)){NODEFS.tryFSOperation(()=>{var stat=fs.fstatSync(stream.nfd);position+=stat.size})}}if(position<0){throw new FS.ErrnoError(28)}return position},mmap(stream,length,position,prot,flags){if(!FS.isFile(stream.node.mode)){throw new FS.ErrnoError(43)}var ptr=mmapAlloc(length);NODEFS.stream_ops.read(stream,HEAP8,ptr,length,position);return{ptr,allocated:true}},msync(stream,buffer,offset,length,mmapFlags){NODEFS.stream_ops.write(stream,buffer,0,length,offset,false);return 0}}};var WORKERFS={DIR_MODE:16895,FILE_MODE:33279,reader:null,mount(mount){assert(ENVIRONMENT_IS_WORKER);WORKERFS.reader??=new FileReaderSync;var root=WORKERFS.createNode(null,"/",WORKERFS.DIR_MODE,0);var createdParents={};function ensureParent(path){var parts=path.split("/");var parent=root;for(var i=0;i{WORKERFS.createNode(ensureParent(obj["name"]),base(obj["name"]),WORKERFS.FILE_MODE,0,obj["data"])});(mount.opts["packages"]||[]).forEach(pack=>{pack["metadata"].files.forEach(file=>{var name=file.filename.slice(1);WORKERFS.createNode(ensureParent(name),base(name),WORKERFS.FILE_MODE,0,pack["blob"].slice(file.start,file.end))})});return root},createNode(parent,name,mode,dev,contents,mtime){var node=FS.createNode(parent,name,mode);node.mode=mode;node.node_ops=WORKERFS.node_ops;node.stream_ops=WORKERFS.stream_ops;node.atime=node.mtime=node.ctime=(mtime||new Date).getTime();assert(WORKERFS.FILE_MODE!==WORKERFS.DIR_MODE);if(mode===WORKERFS.FILE_MODE){node.size=contents.size;node.contents=contents}else{node.size=4096;node.contents={}}if(parent){parent.contents[name]=node}return node},node_ops:{getattr(node){return{dev:1,ino:node.id,mode:node.mode,nlink:1,uid:0,gid:0,rdev:0,size:node.size,atime:new Date(node.atime),mtime:new Date(node.mtime),ctime:new Date(node.ctime),blksize:4096,blocks:Math.ceil(node.size/4096)}},setattr(node,attr){for(const key of["mode","atime","mtime","ctime"]){if(attr[key]!=null){node[key]=attr[key]}}},lookup(parent,name){throw new FS.ErrnoError(44)},mknod(parent,name,mode,dev){throw new FS.ErrnoError(63)},rename(oldNode,newDir,newName){throw new FS.ErrnoError(63)},unlink(parent,name){throw new FS.ErrnoError(63)},rmdir(parent,name){throw new FS.ErrnoError(63)},readdir(node){var entries=[".",".."];for(var key of Object.keys(node.contents)){entries.push(key)}return entries},symlink(parent,newName,oldPath){throw new FS.ErrnoError(63)}},stream_ops:{read(stream,buffer,offset,length,position){if(position>=stream.node.size)return 0;var chunk=stream.node.contents.slice(position,position+length);var ab=WORKERFS.reader.readAsArrayBuffer(chunk);buffer.set(new Uint8Array(ab),offset);return chunk.size},write(stream,buffer,offset,length,position){throw new FS.ErrnoError(29)},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.size}}if(position<0){throw new FS.ErrnoError(28)}return position}}};var PROXYFS={mount(mount){return PROXYFS.createNode(null,"/",mount.opts.fs.lstat(mount.opts.root).mode,0)},createNode(parent,name,mode,dev){if(!FS.isDir(mode)&&!FS.isFile(mode)&&!FS.isLink(mode)){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var node=FS.createNode(parent,name,mode);node.node_ops=PROXYFS.node_ops;node.stream_ops=PROXYFS.stream_ops;return node},realPath(node){var parts=[];while(node.parent!==node){parts.push(node.name);node=node.parent}parts.push(node.mount.opts.root);parts.reverse();return PATH.join(...parts)},node_ops:{getattr(node){var path=PROXYFS.realPath(node);var stat;try{stat=node.mount.opts.fs.lstat(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}return{dev:stat.dev,ino:stat.ino,mode:stat.mode,nlink:stat.nlink,uid:stat.uid,gid:stat.gid,rdev:stat.rdev,size:stat.size,atime:stat.atime,mtime:stat.mtime,ctime:stat.ctime,blksize:stat.blksize,blocks:stat.blocks}},setattr(node,attr){var path=PROXYFS.realPath(node);try{if(attr.mode!==undefined){node.mount.opts.fs.chmod(path,attr.mode);node.mode=attr.mode}if(attr.atime||attr.mtime){var atime=new Date(attr.atime||attr.mtime);var mtime=new Date(attr.mtime||attr.atime);node.mount.opts.fs.utime(path,atime,mtime)}if(attr.size!==undefined){node.mount.opts.fs.truncate(path,attr.size)}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}},lookup(parent,name){try{var path=PATH.join2(PROXYFS.realPath(parent),name);var mode=parent.mount.opts.fs.lstat(path).mode;var node=PROXYFS.createNode(parent,name,mode);return node}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}},mknod(parent,name,mode,dev){var node=PROXYFS.createNode(parent,name,mode,dev);var path=PROXYFS.realPath(node);try{if(FS.isDir(node.mode)){node.mount.opts.fs.mkdir(path,node.mode)}else{node.mount.opts.fs.writeFile(path,"",{mode:node.mode})}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}return node},rename(oldNode,newDir,newName){var oldPath=PROXYFS.realPath(oldNode);var newPath=PATH.join2(PROXYFS.realPath(newDir),newName);try{oldNode.mount.opts.fs.rename(oldPath,newPath);oldNode.name=newName}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}},unlink(parent,name){var path=PATH.join2(PROXYFS.realPath(parent),name);try{parent.mount.opts.fs.unlink(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}},rmdir(parent,name){var path=PATH.join2(PROXYFS.realPath(parent),name);try{parent.mount.opts.fs.rmdir(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}},readdir(node){var path=PROXYFS.realPath(node);try{return node.mount.opts.fs.readdir(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}},symlink(parent,newName,oldPath){var newPath=PATH.join2(PROXYFS.realPath(parent),newName);try{parent.mount.opts.fs.symlink(oldPath,newPath)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}},readlink(node){var path=PROXYFS.realPath(node);try{return node.mount.opts.fs.readlink(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}},stream_ops:{open(stream){var path=PROXYFS.realPath(stream.node);try{stream.nfd=stream.node.mount.opts.fs.open(path,stream.flags)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}},close(stream){try{stream.node.mount.opts.fs.close(stream.nfd)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}},read(stream,buffer,offset,length,position){try{return stream.node.mount.opts.fs.read(stream.nfd,buffer,offset,length,position)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}},write(stream,buffer,offset,length,position){try{return stream.node.mount.opts.fs.write(stream.nfd,buffer,offset,length,position)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}},llseek(stream,offset,whence){var position=offset;if(whence===1){position+=stream.position}else if(whence===2){if(FS.isFile(stream.node.mode)){try{var stat=stream.node.node_ops.getattr(stream.node);position+=stat.size}catch(e){throw new FS.ErrnoError(ERRNO_CODES[e.code])}}}if(position<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}return position}}};var LZ4={DIR_MODE:16895,FILE_MODE:33279,CHUNK_SIZE:-1,codec:null,init(){if(LZ4.codec)return;LZ4.codec=(()=>{var MiniLZ4=function(){var exports={};exports.uncompress=function(input,output,sIdx,eIdx){sIdx=sIdx||0;eIdx=eIdx||input.length-sIdx;for(var i=sIdx,n=eIdx,j=0;i>4;if(literals_length>0){var l=literals_length+240;while(l===255){l=input[i++];literals_length+=l}var end=i+literals_length;while(ij)return-(i-2);var match_length=token&15;var l=match_length+240;while(l===255){l=input[i++];match_length+=l}var pos=j-offset;var end=j+match_length+4;while(jmaxInputSize?0:isize+isize/255+16|0};exports.compress=function(src,dst,sIdx,eIdx){hashTable.set(empty);return compressBlock(src,dst,0,sIdx||0,eIdx||dst.length)};function compressBlock(src,dst,pos,sIdx,eIdx){var dpos=sIdx;var dlen=eIdx-sIdx;var anchor=0;if(src.length>=maxInputSize)throw new Error("input too large");if(src.length>mfLimit){var n=exports.compressBound(src.length);if(dlen>>hashShift;var ref=hashTable[hash]-1;hashTable[hash]=pos+1;if(ref<0||pos-ref>>>16>0||((src[ref+3]<<8|src[ref+2])!=sequenceHighBits||(src[ref+1]<<8|src[ref])!=sequenceLowBits)){step=findMatchAttempts++>>skipStrength;pos+=step;continue}findMatchAttempts=(1<=runMask){dst[dpos++]=(runMask<254;len-=255){dst[dpos++]=255}dst[dpos++]=len}else{dst[dpos++]=(literals_length<>8;if(match_length>=mlMask){match_length-=mlMask;while(match_length>=255){match_length-=255;dst[dpos++]=255}dst[dpos++]=match_length}anchor=pos}}if(anchor==0)return 0;literals_length=src.length-anchor;if(literals_length>=runMask){dst[dpos++]=runMask<254;ln-=255){dst[dpos++]=255}dst[dpos++]=ln}else{dst[dpos++]=literals_length<0){assert(compressedSize<=bound);compressed=compressed.subarray(0,compressedSize);compressedChunks.push(compressed);total+=compressedSize;successes.push(1);if(verify){var back=exports.uncompress(compressed,temp);assert(back===chunk.length,[back,chunk.length]);for(var i=0;i{var dir=PATH.dirname(file.filename);var name=PATH.basename(file.filename);FS.createPath("",dir,true,true);var parent=FS.analyzePath(dir).object;LZ4.createNode(parent,name,LZ4.FILE_MODE,0,{compressedData,start:file.start,end:file.end})});if(preloadPlugin){Browser.init();pack["metadata"].files.forEach(file=>{var handled=false;var fullname=file.filename;preloadPlugins.forEach(plugin=>{if(handled)return;if(plugin["canHandle"](fullname)){var dep=getUniqueRunDependency("fp "+fullname);addRunDependency(dep);var finish=()=>removeRunDependency(dep);var byteArray=FS.readFile(fullname);plugin["handle"](byteArray,fullname,finish,finish);handled=true}})})}},createNode(parent,name,mode,dev,contents,mtime){var node=FS.createNode(parent,name,mode);node.mode=mode;node.node_ops=LZ4.node_ops;node.stream_ops=LZ4.stream_ops;this.atime=this.mtime=this.ctime=(mtime||new Date).getTime();assert(LZ4.FILE_MODE!==LZ4.DIR_MODE);if(mode===LZ4.FILE_MODE){node.size=contents.end-contents.start;node.contents=contents}else{node.size=4096;node.contents={}}if(parent){parent.contents[name]=node}return node},node_ops:{getattr(node){return{dev:1,ino:node.id,mode:node.mode,nlink:1,uid:0,gid:0,rdev:0,size:node.size,atime:new Date(node.atime),mtime:new Date(node.mtime),ctime:new Date(node.ctime),blksize:4096,blocks:Math.ceil(node.size/4096)}},setattr(node,attr){for(const key of["mode","atime","mtime","ctime"]){if(attr[key]){node[key]=attr[key]}}},lookup(parent,name){throw new FS.ErrnoError(44)},mknod(parent,name,mode,dev){throw new FS.ErrnoError(63)},rename(oldNode,newDir,newName){throw new FS.ErrnoError(63)},unlink(parent,name){throw new FS.ErrnoError(63)},rmdir(parent,name){throw new FS.ErrnoError(63)},readdir(node){throw new FS.ErrnoError(63)},symlink(parent,newName,oldPath){throw new FS.ErrnoError(63)}},stream_ops:{read(stream,buffer,offset,length,position){length=Math.min(length,stream.node.size-position);if(length<=0)return 0;var contents=stream.node.contents;var compressedData=contents.compressedData;var written=0;while(written=0){currChunk=compressedData["cachedChunks"][found]}else{compressedData["cachedIndexes"].pop();compressedData["cachedIndexes"].unshift(chunkIndex);currChunk=compressedData["cachedChunks"].pop();compressedData["cachedChunks"].unshift(currChunk);if(compressedData["debug"]){out("decompressing chunk "+chunkIndex);Module["decompressedChunks"]=(Module["decompressedChunks"]||0)+1}var compressed=compressedData["data"].subarray(compressedStart,compressedStart+compressedSize);var originalSize=LZ4.codec.uncompress(compressed,currChunk);if(chunkIndex!!p);var current=FS.root;var current_path="/";for(var i=0;i>>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)}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){if(!FS.isDir(dir.mode))return 54;var errCode=FS.nodePermissions(dir,"x");if(errCode)return errCode;if(!dir.node_ops.lookup)return 2;return 0},mayCreate(dir,name){if(!FS.isDir(dir.mode)){return 54}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|64)){return 31}}return FS.nodePermissions(node,FS.flagsToPermissionString(flags))},checkOpExists(op,err){if(!op){throw new FS.ErrnoError(err)}return op},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){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},dupStream(origStream,fd=-1){var stream=FS.createStream(origStream,fd);stream.stream_ops?.dup?.(stream);return stream},doSetAttr(stream,node,attr){var setattr=stream?.stream_ops.setattr;var arg=setattr?stream:node;setattr??=node.node_ops.setattr;FS.checkOpExists(setattr,63);setattr(arg,attr)},chrdev_stream_ops:{open(stream){var device=FS.getDevice(stream.node.rdev);stream.stream_ops=device.stream_ops;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 m=check.pop();mounts.push(m);check.push(...m.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){throw new FS.ErrnoError(28)}if(name==="."||name===".."){throw new FS.ErrnoError(20)}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)},statfs(path){return FS.statfsNode(FS.lookupPath(path,{follow:true}).node)},statfsStream(stream){return FS.statfsNode(stream.node)},statfsNode(node){var rtn={bsize:4096,frsize:4096,blocks:1e6,bfree:5e5,bavail:5e5,files:FS.nextInode,ffree:FS.nextInode-1,fsid:42,flags:2,namelen:255};if(node.node_ops.statfs){Object.assign(rtn,node.node_ops.statfs(node.mount.opts.root))}return rtn},create(path,mode=438){mode&=4095;mode|=32768;return FS.mknod(path,mode,0)},mkdir(path,mode=511){mode&=511|512;mode|=16384;if(FS.trackingDelegate["onMakeDirectory"]){FS.trackingDelegate["onMakeDirectory"](path,mode)}return FS.mknod(path,mode,0)},mkdirTree(path,mode){var dirs=path.split("/");var d="";for(var dir of dirs){if(!dir)continue;if(d||PATH.isAbs(path))d+="/";d+=dir;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)}if(FS.trackingDelegate["onMakeSymlink"]){FS.trackingDelegate["onMakeSymlink"](oldpath,newpath)}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)}}if(FS.trackingDelegate["willMovePath"]){FS.trackingDelegate["willMovePath"](old_path,new_path)}FS.hashRemoveNode(old_node);try{old_dir.node_ops.rename(old_node,new_dir,new_name);old_node.parent=new_dir}catch(e){throw e}finally{FS.hashAddNode(old_node)}if(FS.trackingDelegate["onMovePath"]){FS.trackingDelegate["onMovePath"](old_path,new_path)}},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)}if(FS.trackingDelegate["willDeletePath"]){FS.trackingDelegate["willDeletePath"](path)}parent.node_ops.rmdir(parent,name);FS.destroyNode(node);if(FS.trackingDelegate["onDeletePath"]){FS.trackingDelegate["onDeletePath"](path)}},readdir(path){var lookup=FS.lookupPath(path,{follow:true});var node=lookup.node;var readdir=FS.checkOpExists(node.node_ops.readdir,54);return 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)}if(FS.trackingDelegate["willDeletePath"]){FS.trackingDelegate["willDeletePath"](path)}parent.node_ops.unlink(parent,name);FS.destroyNode(node);if(FS.trackingDelegate["onDeletePath"]){FS.trackingDelegate["onDeletePath"](path)}},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 link.node_ops.readlink(link)},stat(path,dontFollow){var lookup=FS.lookupPath(path,{follow:!dontFollow});var node=lookup.node;var getattr=FS.checkOpExists(node.node_ops.getattr,63);return getattr(node)},fstat(fd){var stream=FS.getStreamChecked(fd);var node=stream.node;var getattr=stream.stream_ops.getattr;var arg=getattr?stream:node;getattr??=node.node_ops.getattr;FS.checkOpExists(getattr,63);return getattr(arg)},lstat(path){return FS.stat(path,true)},doChmod(stream,node,mode,dontFollow){FS.doSetAttr(stream,node,{mode:mode&4095|node.mode&~4095,ctime:Date.now(),dontFollow})},chmod(path,mode,dontFollow){var node;if(typeof path=="string"){var lookup=FS.lookupPath(path,{follow:!dontFollow});node=lookup.node}else{node=path}FS.doChmod(null,node,mode,dontFollow)},lchmod(path,mode){FS.chmod(path,mode,true)},fchmod(fd,mode){var stream=FS.getStreamChecked(fd);FS.doChmod(stream,stream.node,mode,false)},doChown(stream,node,dontFollow){FS.doSetAttr(stream,node,{timestamp:Date.now(),dontFollow})},chown(path,uid,gid,dontFollow){var node;if(typeof path=="string"){var lookup=FS.lookupPath(path,{follow:!dontFollow});node=lookup.node}else{node=path}FS.doChown(null,node,dontFollow)},lchown(path,uid,gid){FS.chown(path,uid,gid,true)},fchown(fd,uid,gid){var stream=FS.getStreamChecked(fd);FS.doChown(stream,stream.node,false)},doTruncate(stream,node,len){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)}FS.doSetAttr(stream,node,{size:len,timestamp:Date.now()})},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}FS.doTruncate(null,node,len)},ftruncate(fd,len){var stream=FS.getStreamChecked(fd);if(len<0||(stream.flags&2097155)===0){throw new FS.ErrnoError(28)}FS.doTruncate(stream,stream.node,len)},utime(path,atime,mtime){var lookup=FS.lookupPath(path,{follow:true});var node=lookup.node;var setattr=FS.checkOpExists(node.node_ops.setattr,63);setattr(node,{atime,mtime})},open(path,flags,mode=438){if(path===""){throw new FS.ErrnoError(44)}flags=typeof flags=="string"?FS_modeStringToFlags(flags):flags;if(flags&64){mode=mode&4095|32768}else{mode=0}var node;var isDirPath;if(typeof path=="object"){node=path}else{isDirPath=path.endsWith("/");var lookup=FS.lookupPath(path,{follow:!(flags&131072),noent_okay:true});node=lookup.node;path=lookup.path}var created=false;if(flags&64){if(node){if(flags&128){throw new FS.ErrnoError(20)}}else if(isDirPath){throw new FS.ErrnoError(31)}else{node=FS.mknod(path,mode|511,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)}var trackingFlags=flags;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(created){FS.chmod(node,mode&511)}if(Module["logReadFiles"]&&!(flags&1)){if(!(path in FS.readFiles)){FS.readFiles[path]=1;dbg(`FS.trackingDelegate error on read file: ${path}`)}}if(FS.trackingDelegate["onOpenFile"]){FS.trackingDelegate["onOpenFile"](path,trackingFlags)}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;if(stream.path&&FS.trackingDelegate["onCloseFile"]){FS.trackingDelegate["onCloseFile"](stream.path)}},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=[];if(stream.path&&FS.trackingDelegate["onSeekFile"]){FS.trackingDelegate["onSeekFile"](stream.path,stream.position,whence)}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;if(stream.path&&FS.trackingDelegate["onReadFile"]){FS.trackingDelegate["onReadFile"](stream.path,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;if(stream.path&&FS.trackingDelegate["onWriteToFile"]){FS.trackingDelegate["onWriteToFile"](stream.path,bytesWritten)}return bytesWritten},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)}if(!length){throw new FS.ErrnoError(28)}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)},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)}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,llseek:()=>0});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){randomFill(randomBuffer);randomLeft=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",16895,73);node.stream_ops={llseek:MEMFS.stream_ops.llseek};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},id:fd+1};ret.parent=ret;return ret},readdir(){return Array.from(FS.streams.entries()).filter(([k,v])=>v).map(([k,v])=>k.toString())}};return node}},{},"/proc/self/fd")},createStandardStreams(input,output,error){if(input){FS.createDevice("/dev","stdin",input)}else{FS.symlink("/dev/tty","/dev/stdin")}if(output){FS.createDevice("/dev","stdout",null,output)}else{FS.symlink("/dev/tty","/dev/stdout")}if(error){FS.createDevice("/dev","stderr",null,error)}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)},staticInit(){FS.nameTable=new Array(4096);FS.mount(MEMFS,{},"/");FS.createDefaultDirectories();FS.createDefaultDevices();FS.createSpecialDirectories();FS.filesystems={MEMFS,IDBFS,NODEFS,WORKERFS,PROXYFS}},init(input,output,error){FS.initialized=true;input??=Module["stdin"];output??=Module["stdout"];error??=Module["stderr"];FS.createStandardStreams(input,output,error)},quit(){FS.initialized=false;_fflush(0);for(var stream of FS.streams){if(stream){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){if(e.errno!=20)throw 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;ithis.length-1||idx<0){return undefined}var chunkOffset=idx%this.chunkSize;var chunkNum=idx/this.chunkSize|0;return this.getter(chunkNum)[chunkOffset]}setDataGetter(getter){this.getter=getter}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 xhr=new XMLHttpRequest;xhr.open("GET",url,false);if(datalength!==chunkSize)xhr.setRequestHeader("Range","bytes="+from+"-"+to);xhr.responseType="arraybuffer";if(xhr.overrideMimeType){xhr.overrideMimeType("text/plain; charset=x-user-defined")}xhr.send(null);if(!(xhr.status>=200&&xhr.status<300||xhr.status===304))throw new Error("Couldn't load "+url+". Status: "+xhr.status);if(xhr.response!==undefined){return new Uint8Array(xhr.response||[])}return intArrayFromString(xhr.responseText||"",true)};var lazyArray=this;lazyArray.setDataGetter(chunkNum=>{var start=chunkNum*chunkSize;var end=(chunkNum+1)*chunkSize-1;end=Math.min(end,datalength-1);if(typeof lazyArray.chunks[chunkNum]=="undefined"){lazyArray.chunks[chunkNum]=doXHR(start,end)}if(typeof lazyArray.chunks[chunkNum]=="undefined")throw new Error("doXHR failed!");return lazyArray.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}get length(){if(!this.lengthKnown){this.cacheLength()}return this._length}get chunkSize(){if(!this.lengthKnown){this.cacheLength()}return this._chunkSize}}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;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]=(...args)=>{FS.forceLoadFile(node);return fn(...args)}});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{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 findLibraryFS=(libName,rpath)=>{if(!runtimeInitialized){return undefined}if(PATH.isAbs(libName)){try{FS.lookupPath(libName);return libName}catch(e){return undefined}}var rpathResolved=(rpath?.paths||[]).map(p=>replaceORIGIN(rpath?.parentLibPath,p));return withStackSave(()=>{var bufSize=2*255+2;var buf=stackAlloc(bufSize);var rpathC=stringToUTF8OnStack(rpathResolved.join(":"));var libNameC=stringToUTF8OnStack(libName);var resLibNameC=__emscripten_find_dylib(buf,rpathC,libNameC,bufSize);return resLibNameC?UTF8ToString(resLibNameC):undefined})};function loadDynamicLibrary(libName,flags={global:true,nodelete:true},localScope,handle){var dso=LDSO.loadedLibsByName[libName];if(dso){if(!flags.global){if(localScope){Object.assign(localScope,dso.exports)}}else if(!dso.global){dso.global=true;mergeLibSymbols(dso.exports,libName)}if(flags.nodelete&&dso.refcount!==Infinity){dso.refcount=Infinity}dso.refcount++;if(handle){LDSO.loadedLibsByHandle[handle]=dso}return flags.loadAsync?Promise.resolve(true):true}dso=newDSO(libName,handle,"loading");dso.refcount=flags.nodelete?Infinity:1;dso.global=flags.global;function loadLibData(){if(handle){var data=HEAPU32[handle+28>>>2>>>0];var dataSize=HEAPU32[handle+32>>>2>>>0];if(data&&dataSize){var libData=HEAP8.slice(data,data+dataSize);return flags.loadAsync?Promise.resolve(libData):libData}}var f=findLibraryFS(libName,flags.rpath);if(f){var libData=FS.readFile(f,{encoding:"binary"});return flags.loadAsync?Promise.resolve(libData):libData}var libFile=locateFile(libName);if(flags.loadAsync){return asyncLoad(libFile)}if(!readBinary){throw new Error(`${libFile}: file not found, and synchronous loading of external files is not available`)}return readBinary(libFile)}function getExports(){var preloaded=preloadedWasm[libName];if(preloaded){return flags.loadAsync?Promise.resolve(preloaded):preloaded}if(flags.loadAsync){return loadLibData().then(libData=>loadWebAssemblyModule(libData,flags,libName,localScope,handle))}return loadWebAssemblyModule(loadLibData(),flags,libName,localScope,handle)}function moduleLoaded(exports){if(dso.global){mergeLibSymbols(exports,libName)}else if(localScope){Object.assign(localScope,exports)}dso.exports=exports}if(flags.loadAsync){return getExports().then(exports=>{moduleLoaded(exports);return true})}moduleLoaded(getExports());return true}var reportUndefinedSymbols=()=>{for(var[symName,entry]of Object.entries(GOT)){if(entry.value==0){var value=resolveGlobalSymbol(symName,true).sym;if(!value&&!entry.required){continue}if(typeof value=="function"){entry.value=addFunction(value,value.sig)}else if(typeof value=="number"){entry.value=value}else{throw new Error(`bad export type for '${symName}': ${typeof value}`)}}}};var loadDylibs=()=>{if(!dynamicLibraries.length){reportUndefinedSymbols();return}addRunDependency("loadDylibs");dynamicLibraries.reduce((chain,lib)=>chain.then(()=>loadDynamicLibrary(lib,{loadAsync:true,global:true,nodelete:true,allowUndefined:true})),Promise.resolve()).then(()=>{reportUndefinedSymbols();removeRunDependency("loadDylibs")})};var noExitRuntime=false;function setValue(ptr,value,type="i8"){if(type.endsWith("*"))type="*";switch(type){case"i1":HEAP8[ptr>>>0]=value;break;case"i8":HEAP8[ptr>>>0]=value;break;case"i16":HEAP16[ptr>>>1>>>0]=value;break;case"i32":HEAP32[ptr>>>2>>>0]=value;break;case"i64":HEAP64[ptr>>>3>>>0]=BigInt(value);break;case"float":HEAPF32[ptr>>>2>>>0]=value;break;case"double":HEAPF64[ptr>>>3>>>0]=value;break;case"*":HEAPU32[ptr>>>2>>>0]=value;break;default:abort(`invalid type for setValue: ${type}`)}}var INT53_MAX=9007199254740992;var INT53_MIN=-9007199254740992;var bigintToI53Checked=num=>numINT53_MAX?NaN:Number(num);function ___assert_fail(condition,filename,line,func){condition>>>=0;filename>>>=0;func>>>=0;return abort(`Assertion failed: ${UTF8ToString(condition)}, at: `+[filename?UTF8ToString(filename):"unknown filename",line,func?UTF8ToString(func):"unknown function"])}___assert_fail.sig="vppip";var ___c_longjmp=new WebAssembly.Tag({parameters:["i32"]});function ___call_sighandler(fp,sig){fp>>>=0;return getWasmTableEntry(fp)(sig)}___call_sighandler.sig="vpi";var ___cpp_exception=new WebAssembly.Tag({parameters:["i32"]});var ___memory_base=new WebAssembly.Global({value:"i32",mutable:false},1024);var ___stack_high=8810528;var ___stack_low=3567648;var ___stack_pointer=new WebAssembly.Global({value:"i32",mutable:true},8810528);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 dir+"/"+path},writeStat(buf,stat){HEAP32[buf>>>2>>>0]=stat.dev;HEAP32[buf+4>>>2>>>0]=stat.mode;HEAPU32[buf+8>>>2>>>0]=stat.nlink;HEAP32[buf+12>>>2>>>0]=stat.uid;HEAP32[buf+16>>>2>>>0]=stat.gid;HEAP32[buf+20>>>2>>>0]=stat.rdev;HEAP64[buf+24>>>3>>>0]=BigInt(stat.size);HEAP32[buf+32>>>2>>>0]=4096;HEAP32[buf+36>>>2>>>0]=stat.blocks;var atime=stat.atime.getTime();var mtime=stat.mtime.getTime();var ctime=stat.ctime.getTime();HEAP64[buf+40>>>3>>>0]=BigInt(Math.floor(atime/1e3));HEAPU32[buf+48>>>2>>>0]=atime%1e3*1e3*1e3;HEAP64[buf+56>>>3>>>0]=BigInt(Math.floor(mtime/1e3));HEAPU32[buf+64>>>2>>>0]=mtime%1e3*1e3*1e3;HEAP64[buf+72>>>3>>>0]=BigInt(Math.floor(ctime/1e3));HEAPU32[buf+80>>>2>>>0]=ctime%1e3*1e3*1e3;HEAP64[buf+88>>>3>>>0]=BigInt(stat.ino);return 0},writeStatFs(buf,stats){HEAP32[buf+4>>>2>>>0]=stats.bsize;HEAP32[buf+40>>>2>>>0]=stats.bsize;HEAP32[buf+8>>>2>>>0]=stats.blocks;HEAP32[buf+12>>>2>>>0]=stats.bfree;HEAP32[buf+16>>>2>>>0]=stats.bavail;HEAP32[buf+20>>>2>>>0]=stats.files;HEAP32[buf+24>>>2>>>0]=stats.ffree;HEAP32[buf+28>>>2>>>0]=stats.fsid;HEAP32[buf+44>>>2>>>0]=stats.flags;HEAP32[buf+36>>>2>>>0]=stats.namelen},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)},getStreamFromFD(fd){var stream=FS.getStreamChecked(fd);return stream},varargs:undefined,getStr(ptr){var ret=UTF8ToString(ptr);return ret}};var ___syscall__newselect=function(nfds,readfds,writefds,exceptfds,timeout){readfds>>>=0;writefds>>>=0;exceptfds>>>=0;timeout>>>=0;try{var total=0;var srcReadLow=readfds?HEAP32[readfds>>>2>>>0]:0,srcReadHigh=readfds?HEAP32[readfds+4>>>2>>>0]:0;var srcWriteLow=writefds?HEAP32[writefds>>>2>>>0]:0,srcWriteHigh=writefds?HEAP32[writefds+4>>>2>>>0]:0;var srcExceptLow=exceptfds?HEAP32[exceptfds>>>2>>>0]:0,srcExceptHigh=exceptfds?HEAP32[exceptfds+4>>>2>>>0]:0;var dstReadLow=0,dstReadHigh=0;var dstWriteLow=0,dstWriteHigh=0;var dstExceptLow=0,dstExceptHigh=0;var allLow=(readfds?HEAP32[readfds>>>2>>>0]:0)|(writefds?HEAP32[writefds>>>2>>>0]:0)|(exceptfds?HEAP32[exceptfds>>>2>>>0]:0);var allHigh=(readfds?HEAP32[readfds+4>>>2>>>0]:0)|(writefds?HEAP32[writefds+4>>>2>>>0]:0)|(exceptfds?HEAP32[exceptfds+4>>>2>>>0]:0);var check=(fd,low,high,val)=>fd<32?low&val:high&val;for(var fd=0;fd>>2>>>0]:0,tv_usec=readfds?HEAP32[timeout+4>>>2>>>0]:0;timeoutInMillis=(tv_sec+tv_usec/1e6)*1e3}flags=stream.stream_ops.poll(stream,timeoutInMillis)}if(flags&1&&check(fd,srcReadLow,srcReadHigh,mask)){fd<32?dstReadLow=dstReadLow|mask:dstReadHigh=dstReadHigh|mask;total++}if(flags&4&&check(fd,srcWriteLow,srcWriteHigh,mask)){fd<32?dstWriteLow=dstWriteLow|mask:dstWriteHigh=dstWriteHigh|mask;total++}if(flags&2&&check(fd,srcExceptLow,srcExceptHigh,mask)){fd<32?dstExceptLow=dstExceptLow|mask:dstExceptHigh=dstExceptHigh|mask;total++}}if(readfds){HEAP32[readfds>>>2>>>0]=dstReadLow;HEAP32[readfds+4>>>2>>>0]=dstReadHigh}if(writefds){HEAP32[writefds>>>2>>>0]=dstWriteLow;HEAP32[writefds+4>>>2>>>0]=dstWriteHigh}if(exceptfds){HEAP32[exceptfds>>>2>>>0]=dstExceptLow;HEAP32[exceptfds+4>>>2>>>0]=dstExceptHigh}return total}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}};___syscall__newselect.sig="iipppp";var SOCKFS={websocketArgs:{},callbacks:{},on(event,callback){SOCKFS.callbacks[event]=callback},emit(event,param){SOCKFS.callbacks[event]?.(param)},mount(mount){SOCKFS.websocketArgs=Module["websocket"]||{};(Module["websocket"]??={})["on"]=SOCKFS.on;return FS.createNode(null,"/",16895,0)},createSocket(family,type,protocol){type&=~526336;var streaming=type==1;if(streaming&&protocol&&protocol!=6){throw new FS.ErrnoError(66)}var sock={family,type,protocol,server:null,error:null,peers:{},pending:[],recv_queue:[],sock_ops:SOCKFS.websocket_sock_ops};var name=SOCKFS.nextname();var node=FS.createNode(SOCKFS.root,name,49152,0);node.sock=sock;var stream=FS.createStream({path:name,node,flags:2,seekable:false,stream_ops:SOCKFS.stream_ops});sock.stream=stream;return sock},getSocket(fd){var stream=FS.getStream(fd);if(!stream||!FS.isSocket(stream.node.mode)){return null}return stream.node.sock},stream_ops:{poll(stream){var sock=stream.node.sock;return sock.sock_ops.poll(sock)},ioctl(stream,request,varargs){var sock=stream.node.sock;return sock.sock_ops.ioctl(sock,request,varargs)},read(stream,buffer,offset,length,position){var sock=stream.node.sock;var msg=sock.sock_ops.recvmsg(sock,length);if(!msg){return 0}buffer.set(msg.buffer,offset);return msg.buffer.length},write(stream,buffer,offset,length,position){var sock=stream.node.sock;return sock.sock_ops.sendmsg(sock,buffer,offset,length)},close(stream){var sock=stream.node.sock;sock.sock_ops.close(sock)}},nextname(){if(!SOCKFS.nextname.current){SOCKFS.nextname.current=0}return`socket[${SOCKFS.nextname.current++}]`},websocket_sock_ops:{createPeer(sock,addr,port){var ws;if(typeof addr=="object"){ws=addr;addr=null;port=null}if(ws){if(ws._socket){addr=ws._socket.remoteAddress;port=ws._socket.remotePort}else{var result=/ws[s]?:\/\/([^:]+):(\d+)/.exec(ws.url);if(!result){throw new Error("WebSocket URL must be in the format ws(s)://address:port")}addr=result[1];port=parseInt(result[2],10)}}else{try{var url="ws://".replace("#","//");var subProtocols="binary";var opts=undefined;if(SOCKFS.websocketArgs["url"]){url=SOCKFS.websocketArgs["url"]}if(SOCKFS.websocketArgs["subprotocol"]){subProtocols=SOCKFS.websocketArgs["subprotocol"]}else if(SOCKFS.websocketArgs["subprotocol"]===null){subProtocols="null"}if(url==="ws://"||url==="wss://"){var parts=addr.split("/");url=url+parts[0]+":"+port+"/"+parts.slice(1).join("/")}if(subProtocols!=="null"){subProtocols=subProtocols.replace(/^ +| +$/g,"").split(/ *, */);opts=subProtocols}var WebSocketConstructor;if(ENVIRONMENT_IS_NODE){WebSocketConstructor=require("ws")}else{WebSocketConstructor=WebSocket}ws=new WebSocketConstructor(url,opts);ws.binaryType="arraybuffer"}catch(e){throw new FS.ErrnoError(23)}}var peer={addr,port,socket:ws,msg_send_queue:[]};SOCKFS.websocket_sock_ops.addPeer(sock,peer);SOCKFS.websocket_sock_ops.handlePeerEvents(sock,peer);if(sock.type===2&&typeof sock.sport!="undefined"){peer.msg_send_queue.push(new Uint8Array([255,255,255,255,"p".charCodeAt(0),"o".charCodeAt(0),"r".charCodeAt(0),"t".charCodeAt(0),(sock.sport&65280)>>8,sock.sport&255]))}return peer},getPeer(sock,addr,port){return sock.peers[addr+":"+port]},addPeer(sock,peer){sock.peers[peer.addr+":"+peer.port]=peer},removePeer(sock,peer){delete sock.peers[peer.addr+":"+peer.port]},handlePeerEvents(sock,peer){var first=true;var handleOpen=function(){sock.connecting=false;SOCKFS.emit("open",sock.stream.fd);try{var queued=peer.msg_send_queue.shift();while(queued){peer.socket.send(queued);queued=peer.msg_send_queue.shift()}}catch(e){peer.socket.close()}};function handleMessage(data){if(typeof data=="string"){var encoder=new TextEncoder;data=encoder.encode(data)}else{assert(data.byteLength!==undefined);if(data.byteLength==0){return}data=new Uint8Array(data)}var wasfirst=first;first=false;if(wasfirst&&data.length===10&&data[0]===255&&data[1]===255&&data[2]===255&&data[3]===255&&data[4]==="p".charCodeAt(0)&&data[5]==="o".charCodeAt(0)&&data[6]==="r".charCodeAt(0)&&data[7]==="t".charCodeAt(0)){var newport=data[8]<<8|data[9];SOCKFS.websocket_sock_ops.removePeer(sock,peer);peer.port=newport;SOCKFS.websocket_sock_ops.addPeer(sock,peer);return}sock.recv_queue.push({addr:peer.addr,port:peer.port,data});SOCKFS.emit("message",sock.stream.fd)}if(ENVIRONMENT_IS_NODE){peer.socket.on("open",handleOpen);peer.socket.on("message",function(data,isBinary){if(!isBinary){return}handleMessage(new Uint8Array(data).buffer)});peer.socket.on("close",function(){SOCKFS.emit("close",sock.stream.fd)});peer.socket.on("error",function(error){sock.error=14;SOCKFS.emit("error",[sock.stream.fd,sock.error,"ECONNREFUSED: Connection refused"])})}else{peer.socket.onopen=handleOpen;peer.socket.onclose=function(){SOCKFS.emit("close",sock.stream.fd)};peer.socket.onmessage=function peer_socket_onmessage(event){handleMessage(event.data)};peer.socket.onerror=function(error){sock.error=14;SOCKFS.emit("error",[sock.stream.fd,sock.error,"ECONNREFUSED: Connection refused"])}}},poll(sock){if(sock.type===1&&sock.server){return sock.pending.length?64|1:0}var mask=0;var dest=sock.type===1?SOCKFS.websocket_sock_ops.getPeer(sock,sock.daddr,sock.dport):null;if(sock.recv_queue.length||!dest||dest&&dest.socket.readyState===dest.socket.CLOSING||dest&&dest.socket.readyState===dest.socket.CLOSED){mask|=64|1}if(!dest||dest&&dest.socket.readyState===dest.socket.OPEN){mask|=4}if(dest&&dest.socket.readyState===dest.socket.CLOSING||dest&&dest.socket.readyState===dest.socket.CLOSED){if(sock.connecting){mask|=4}else{mask|=16}}return mask},ioctl(sock,request,arg){switch(request){case 21531:var bytes=0;if(sock.recv_queue.length){bytes=sock.recv_queue[0].data.length}HEAP32[arg>>>2>>>0]=bytes;return 0;default:return 28}},close(sock){if(sock.server){try{sock.server.close()}catch(e){}sock.server=null}for(var peer of Object.values(sock.peers)){try{peer.socket.close()}catch(e){}SOCKFS.websocket_sock_ops.removePeer(sock,peer)}return 0},bind(sock,addr,port){if(typeof sock.saddr!="undefined"||typeof sock.sport!="undefined"){throw new FS.ErrnoError(28)}sock.saddr=addr;sock.sport=port;if(sock.type===2){if(sock.server){sock.server.close();sock.server=null}try{sock.sock_ops.listen(sock,0)}catch(e){if(!(e.name==="ErrnoError"))throw e;if(e.errno!==138)throw e}}},connect(sock,addr,port){if(sock.server){throw new FS.ErrnoError(138)}if(typeof sock.daddr!="undefined"&&typeof sock.dport!="undefined"){var dest=SOCKFS.websocket_sock_ops.getPeer(sock,sock.daddr,sock.dport);if(dest){if(dest.socket.readyState===dest.socket.CONNECTING){throw new FS.ErrnoError(7)}else{throw new FS.ErrnoError(30)}}}var peer=SOCKFS.websocket_sock_ops.createPeer(sock,addr,port);sock.daddr=peer.addr;sock.dport=peer.port;sock.connecting=true},listen(sock,backlog){if(!ENVIRONMENT_IS_NODE){throw new FS.ErrnoError(138)}if(sock.server){throw new FS.ErrnoError(28)}var WebSocketServer=require("ws").Server;var host=sock.saddr;sock.server=new WebSocketServer({host,port:sock.sport});SOCKFS.emit("listen",sock.stream.fd);sock.server.on("connection",function(ws){if(sock.type===1){var newsock=SOCKFS.createSocket(sock.family,sock.type,sock.protocol);var peer=SOCKFS.websocket_sock_ops.createPeer(newsock,ws);newsock.daddr=peer.addr;newsock.dport=peer.port;sock.pending.push(newsock);SOCKFS.emit("connection",newsock.stream.fd)}else{SOCKFS.websocket_sock_ops.createPeer(sock,ws);SOCKFS.emit("connection",sock.stream.fd)}});sock.server.on("close",function(){SOCKFS.emit("close",sock.stream.fd);sock.server=null});sock.server.on("error",function(error){sock.error=23;SOCKFS.emit("error",[sock.stream.fd,sock.error,"EHOSTUNREACH: Host is unreachable"])})},accept(listensock){if(!listensock.server||!listensock.pending.length){throw new FS.ErrnoError(28)}var newsock=listensock.pending.shift();newsock.stream.flags=listensock.stream.flags;return newsock},getname(sock,peer){var addr,port;if(peer){if(sock.daddr===undefined||sock.dport===undefined){throw new FS.ErrnoError(53)}addr=sock.daddr;port=sock.dport}else{addr=sock.saddr||0;port=sock.sport||0}return{addr,port}},sendmsg(sock,buffer,offset,length,addr,port){if(sock.type===2){if(addr===undefined||port===undefined){addr=sock.daddr;port=sock.dport}if(addr===undefined||port===undefined){throw new FS.ErrnoError(17)}}else{addr=sock.daddr;port=sock.dport}var dest=SOCKFS.websocket_sock_ops.getPeer(sock,addr,port);if(sock.type===1){if(!dest||dest.socket.readyState===dest.socket.CLOSING||dest.socket.readyState===dest.socket.CLOSED){throw new FS.ErrnoError(53)}}if(ArrayBuffer.isView(buffer)){offset+=buffer.byteOffset;buffer=buffer.buffer}var data=buffer.slice(offset,offset+length);if(!dest||dest.socket.readyState!==dest.socket.OPEN){if(sock.type===2){if(!dest||dest.socket.readyState===dest.socket.CLOSING||dest.socket.readyState===dest.socket.CLOSED){dest=SOCKFS.websocket_sock_ops.createPeer(sock,addr,port)}}dest.msg_send_queue.push(data);return length}try{dest.socket.send(data);return length}catch(e){throw new FS.ErrnoError(28)}},recvmsg(sock,length){if(sock.type===1&&sock.server){throw new FS.ErrnoError(53)}var queued=sock.recv_queue.shift();if(!queued){if(sock.type===1){var dest=SOCKFS.websocket_sock_ops.getPeer(sock,sock.daddr,sock.dport);if(!dest){throw new FS.ErrnoError(53)}if(dest.socket.readyState===dest.socket.CLOSING||dest.socket.readyState===dest.socket.CLOSED){return null}throw new FS.ErrnoError(6)}throw new FS.ErrnoError(6)}var queuedLength=queued.data.byteLength||queued.data.length;var queuedOffset=queued.data.byteOffset||0;var queuedBuffer=queued.data.buffer||queued.data;var bytesRead=Math.min(length,queuedLength);var res={buffer:new Uint8Array(queuedBuffer,queuedOffset,bytesRead),addr:queued.addr,port:queued.port};if(sock.type===1&&bytesRead{var socket=SOCKFS.getSocket(fd);if(!socket)throw new FS.ErrnoError(8);return socket};var inetPton4=str=>{var b=str.split(".");for(var i=0;i<4;i++){var tmp=Number(b[i]);if(isNaN(tmp))return null;b[i]=tmp}return(b[0]|b[1]<<8|b[2]<<16|b[3]<<24)>>>0};var inetPton6=str=>{var words;var w,offset,z,i;var valid6regx=/^((?=.*::)(?!.*::.+::)(::)?([\dA-F]{1,4}:(:|\b)|){5}|([\dA-F]{1,4}:){6})((([\dA-F]{1,4}((?!\3)::|:\b|$))|(?!\2\3)){2}|(((2[0-4]|1\d|[1-9])?\d|25[0-5])\.?\b){4})$/i;var parts=[];if(!valid6regx.test(str)){return null}if(str==="::"){return[0,0,0,0,0,0,0,0]}if(str.startsWith("::")){str=str.replace("::","Z:")}else{str=str.replace("::",":Z:")}if(str.indexOf(".")>0){str=str.replace(new RegExp("[.]","g"),":");words=str.split(":");words[words.length-4]=Number(words[words.length-4])+Number(words[words.length-3])*256;words[words.length-3]=Number(words[words.length-2])+Number(words[words.length-1])*256;words=words.slice(0,words.length-2)}else{words=str.split(":")}offset=0;z=0;for(w=0;w{switch(family){case 2:addr=inetPton4(addr);zeroMemory(sa,16);if(addrlen){HEAP32[addrlen>>>2>>>0]=16}HEAP16[sa>>>1>>>0]=family;HEAP32[sa+4>>>2>>>0]=addr;HEAP16[sa+2>>>1>>>0]=_htons(port);break;case 10:addr=inetPton6(addr);zeroMemory(sa,28);if(addrlen){HEAP32[addrlen>>>2>>>0]=28}HEAP32[sa>>>2>>>0]=family;HEAP32[sa+8>>>2>>>0]=addr[0];HEAP32[sa+12>>>2>>>0]=addr[1];HEAP32[sa+16>>>2>>>0]=addr[2];HEAP32[sa+20>>>2>>>0]=addr[3];HEAP16[sa+2>>>1>>>0]=_htons(port);break;default:return 5}return 0};var DNS={address_map:{id:1,addrs:{},names:{}},lookup_name(name){var res=inetPton4(name);if(res!==null){return name}res=inetPton6(name);if(res!==null){return name}var addr;if(DNS.address_map.addrs[name]){addr=DNS.address_map.addrs[name]}else{var id=DNS.address_map.id++;assert(id<65535,"exceeded max address mappings of 65535");addr="172.29."+(id&255)+"."+(id&65280);DNS.address_map.names[addr]=name;DNS.address_map.addrs[name]=addr}return addr},lookup_addr(addr){if(DNS.address_map.names[addr]){return DNS.address_map.names[addr]}return null}};function ___syscall_accept4(fd,addr,addrlen,flags,d1,d2){addr>>>=0;addrlen>>>=0;try{var sock=getSocketFromFD(fd);var newsock=sock.sock_ops.accept(sock);if(addr){var errno=writeSockaddr(addr,newsock.family,DNS.lookup_name(newsock.daddr),newsock.dport,addrlen)}return newsock.stream.fd}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_accept4.sig="iippiii";var inetNtop4=addr=>(addr&255)+"."+(addr>>8&255)+"."+(addr>>16&255)+"."+(addr>>24&255);var inetNtop6=ints=>{var str="";var word=0;var longest=0;var lastzero=0;var zstart=0;var len=0;var i=0;var parts=[ints[0]&65535,ints[0]>>16,ints[1]&65535,ints[1]>>16,ints[2]&65535,ints[2]>>16,ints[3]&65535,ints[3]>>16];var hasipv4=true;var v4part="";for(i=0;i<5;i++){if(parts[i]!==0){hasipv4=false;break}}if(hasipv4){v4part=inetNtop4(parts[6]|parts[7]<<16);if(parts[5]===-1){str="::ffff:";str+=v4part;return str}if(parts[5]===0){str="::";if(v4part==="0.0.0.0")v4part="";if(v4part==="0.0.0.1")v4part="1";str+=v4part;return str}}for(word=0;word<8;word++){if(parts[word]===0){if(word-lastzero>1){len=0}lastzero=word;len++}if(len>longest){longest=len;zstart=word-longest+1}}for(word=0;word<8;word++){if(longest>1){if(parts[word]===0&&word>=zstart&&word{var family=HEAP16[sa>>>1>>>0];var port=_ntohs(HEAPU16[sa+2>>>1>>>0]);var addr;switch(family){case 2:if(salen!==16){return{errno:28}}addr=HEAP32[sa+4>>>2>>>0];addr=inetNtop4(addr);break;case 10:if(salen!==28){return{errno:28}}addr=[HEAP32[sa+8>>>2>>>0],HEAP32[sa+12>>>2>>>0],HEAP32[sa+16>>>2>>>0],HEAP32[sa+20>>>2>>>0]];addr=inetNtop6(addr);break;default:return{errno:5}}return{family,addr,port}};var getSocketAddress=(addrp,addrlen)=>{var info=readSockaddr(addrp,addrlen);if(info.errno)throw new FS.ErrnoError(info.errno);info.addr=DNS.lookup_addr(info.addr)||info.addr;return info};function ___syscall_bind(fd,addr,addrlen,d1,d2,d3){addr>>>=0;addrlen>>>=0;try{var sock=getSocketFromFD(fd);var info=getSocketAddress(addr,addrlen);sock.sock_ops.bind(sock,info.addr,info.port);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_bind.sig="iippiii";function ___syscall_chdir(path){path>>>=0;try{path=SYSCALLS.getStr(path);FS.chdir(path);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_chdir.sig="ip";function ___syscall_chmod(path,mode){path>>>=0;try{path=SYSCALLS.getStr(path);FS.chmod(path,mode);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_chmod.sig="ipi";function ___syscall_connect(fd,addr,addrlen,d1,d2,d3){addr>>>=0;addrlen>>>=0;try{var sock=getSocketFromFD(fd);var info=getSocketAddress(addr,addrlen);sock.sock_ops.connect(sock,info.addr,info.port);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_connect.sig="iippiii";function ___syscall_dup(fd){try{var old=SYSCALLS.getStreamFromFD(fd);return FS.dupStream(old).fd}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_dup.sig="ii";function ___syscall_dup3(fd,newfd,flags){try{var old=SYSCALLS.getStreamFromFD(fd);if(old.fd===newfd)return-28;if(newfd<0||newfd>=FS.MAX_OPEN_FDS)return-8;var existing=FS.getStream(newfd);if(existing)FS.close(existing);return FS.dupStream(old,newfd).fd}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_dup3.sig="iiii";function ___syscall_faccessat(dirfd,path,amode,flags){path>>>=0;try{path=SYSCALLS.getStr(path);path=SYSCALLS.calculateAt(dirfd,path);if(amode&~7){return-28}var lookup=FS.lookupPath(path,{follow:true});var node=lookup.node;if(!node){return-44}var perms="";if(amode&4)perms+="r";if(amode&2)perms+="w";if(amode&1)perms+="x";if(perms&&FS.nodePermissions(node,perms)){return-2}return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_faccessat.sig="iipii";var ___syscall_fadvise64=(fd,offset,len,advice)=>0;___syscall_fadvise64.sig="iijji";function ___syscall_fallocate(fd,mode,offset,len){offset=bigintToI53Checked(offset);len=bigintToI53Checked(len);try{if(isNaN(offset)||isNaN(len))return-61;if(mode!=0){return-138}if(offset<0||len<0){return-28}var oldSize=FS.fstat(fd).size;var newSize=offset+len;if(newSize>oldSize){FS.ftruncate(fd,newSize)}return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_fallocate.sig="iiijj";function ___syscall_fchdir(fd){try{var stream=SYSCALLS.getStreamFromFD(fd);FS.chdir(stream.path);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_fchdir.sig="ii";function ___syscall_fchmod(fd,mode){try{FS.fchmod(fd,mode);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_fchmod.sig="iii";function ___syscall_fchmodat2(dirfd,path,mode,flags){path>>>=0;try{var nofollow=flags&256;path=SYSCALLS.getStr(path);path=SYSCALLS.calculateAt(dirfd,path);FS.chmod(path,mode,nofollow);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_fchmodat2.sig="iipii";function ___syscall_fchown32(fd,owner,group){try{FS.fchown(fd,owner,group);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_fchown32.sig="iiii";function ___syscall_fchownat(dirfd,path,owner,group,flags){path>>>=0;try{path=SYSCALLS.getStr(path);var nofollow=flags&256;flags=flags&~256;path=SYSCALLS.calculateAt(dirfd,path);(nofollow?FS.lchown:FS.chown)(path,owner,group);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_fchownat.sig="iipiii";var syscallGetVarargI=()=>{var ret=HEAP32[+SYSCALLS.varargs>>>2>>>0];SYSCALLS.varargs+=4;return ret};var syscallGetVarargP=syscallGetVarargI;function ___syscall_fcntl64(fd,cmd,varargs){varargs>>>=0;SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD(fd);switch(cmd){case 0:{var arg=syscallGetVarargI();if(arg<0){return-28}while(FS.streams[arg]){arg++}var newStream;newStream=FS.dupStream(stream,arg);return newStream.fd}case 1:case 2:return 0;case 3:return stream.flags;case 4:{var arg=syscallGetVarargI();stream.flags|=arg;return 0}case 12:{var arg=syscallGetVarargP();var offset=0;HEAP16[arg+offset>>>1>>>0]=2;return 0}case 13:case 14:return 0}return-28}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_fcntl64.sig="iiip";function ___syscall_fdatasync(fd){try{var stream=SYSCALLS.getStreamFromFD(fd);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_fdatasync.sig="ii";function ___syscall_fstat64(fd,buf){buf>>>=0;try{return SYSCALLS.writeStat(buf,FS.fstat(fd))}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_fstat64.sig="iip";function ___syscall_fstatfs64(fd,size,buf){size>>>=0;buf>>>=0;try{var stream=SYSCALLS.getStreamFromFD(fd);SYSCALLS.writeStatFs(buf,FS.statfsStream(stream));return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_fstatfs64.sig="iipp";function ___syscall_ftruncate64(fd,length){length=bigintToI53Checked(length);try{if(isNaN(length))return-61;FS.ftruncate(fd,length);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_ftruncate64.sig="iij";function ___syscall_getcwd(buf,size){buf>>>=0;size>>>=0;try{if(size===0)return-28;var cwd=FS.cwd();var cwdLengthInBytes=lengthBytesUTF8(cwd)+1;if(size>>=0;count>>>=0;try{var stream=SYSCALLS.getStreamFromFD(fd);stream.getdents||=FS.readdir(stream.path);var struct_size=280;var pos=0;var off=FS.llseek(stream,0,1);var startIdx=Math.floor(off/struct_size);var endIdx=Math.min(stream.getdents.length,startIdx+Math.floor(count/struct_size));for(var idx=startIdx;idx>>3>>>0]=BigInt(id);HEAP64[dirp+pos+8>>>3>>>0]=BigInt((idx+1)*struct_size);HEAP16[dirp+pos+16>>>1>>>0]=280;HEAP8[dirp+pos+18>>>0]=type;stringToUTF8(name,dirp+pos+19,256);pos+=struct_size}FS.llseek(stream,idx*struct_size,0);return pos}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_getdents64.sig="iipp";function ___syscall_getpeername(fd,addr,addrlen,d1,d2,d3){addr>>>=0;addrlen>>>=0;try{var sock=getSocketFromFD(fd);if(!sock.daddr){return-53}var errno=writeSockaddr(addr,sock.family,DNS.lookup_name(sock.daddr),sock.dport,addrlen);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_getpeername.sig="iippiii";function ___syscall_getsockname(fd,addr,addrlen,d1,d2,d3){addr>>>=0;addrlen>>>=0;try{var sock=getSocketFromFD(fd);var errno=writeSockaddr(addr,sock.family,DNS.lookup_name(sock.saddr||"0.0.0.0"),sock.sport,addrlen);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_getsockname.sig="iippiii";function ___syscall_getsockopt(fd,level,optname,optval,optlen,d1){optval>>>=0;optlen>>>=0;try{var sock=getSocketFromFD(fd);if(level===1){if(optname===4){HEAP32[optval>>>2>>>0]=sock.error;HEAP32[optlen>>>2>>>0]=4;sock.error=null;return 0}}return-50}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_getsockopt.sig="iiiippi";function ___syscall_ioctl(fd,op,varargs){varargs>>>=0;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=syscallGetVarargP();HEAP32[argp>>>2>>>0]=termios.c_iflag||0;HEAP32[argp+4>>>2>>>0]=termios.c_oflag||0;HEAP32[argp+8>>>2>>>0]=termios.c_cflag||0;HEAP32[argp+12>>>2>>>0]=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=syscallGetVarargP();var c_iflag=HEAP32[argp>>>2>>>0];var c_oflag=HEAP32[argp+4>>>2>>>0];var c_cflag=HEAP32[argp+8>>>2>>>0];var c_lflag=HEAP32[argp+12>>>2>>>0];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=syscallGetVarargP();HEAP32[argp>>>2>>>0]=0;return 0}case 21520:{if(!stream.tty)return-59;return-28}case 21531:{var argp=syscallGetVarargP();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=syscallGetVarargP();HEAP16[argp>>>1>>>0]=winsize[0];HEAP16[argp+2>>>1>>>0]=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}}___syscall_ioctl.sig="iiip";function ___syscall_listen(fd,backlog){try{var sock=getSocketFromFD(fd);sock.sock_ops.listen(sock,backlog);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_listen.sig="iiiiiii";function ___syscall_lstat64(path,buf){path>>>=0;buf>>>=0;try{path=SYSCALLS.getStr(path);return SYSCALLS.writeStat(buf,FS.lstat(path))}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_lstat64.sig="ipp";function ___syscall_mkdirat(dirfd,path,mode){path>>>=0;try{path=SYSCALLS.getStr(path);path=SYSCALLS.calculateAt(dirfd,path);FS.mkdir(path,mode,0);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_mkdirat.sig="iipi";function ___syscall_mknodat(dirfd,path,mode,dev){path>>>=0;try{path=SYSCALLS.getStr(path);path=SYSCALLS.calculateAt(dirfd,path);switch(mode&61440){case 32768:case 8192:case 24576:case 4096:case 49152:break;default:return-28}FS.mknod(path,mode,dev);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_mknodat.sig="iipii";function ___syscall_newfstatat(dirfd,path,buf,flags){path>>>=0;buf>>>=0;try{path=SYSCALLS.getStr(path);var nofollow=flags&256;var allowEmpty=flags&4096;flags=flags&~6400;path=SYSCALLS.calculateAt(dirfd,path,allowEmpty);return SYSCALLS.writeStat(buf,nofollow?FS.lstat(path):FS.stat(path))}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_newfstatat.sig="iippi";function ___syscall_openat(dirfd,path,flags,varargs){path>>>=0;varargs>>>=0;SYSCALLS.varargs=varargs;try{path=SYSCALLS.getStr(path);path=SYSCALLS.calculateAt(dirfd,path);var mode=varargs?syscallGetVarargI():0;return FS.open(path,flags,mode).fd}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_openat.sig="iipip";var PIPEFS={BUCKET_BUFFER_SIZE:8192,mount(mount){return FS.createNode(null,"/",16384|511,0)},createPipe(){var pipe={buckets:[],refcnt:2,timestamp:new Date};pipe.buckets.push({buffer:new Uint8Array(PIPEFS.BUCKET_BUFFER_SIZE),offset:0,roffset:0});var rName=PIPEFS.nextname();var wName=PIPEFS.nextname();var rNode=FS.createNode(PIPEFS.root,rName,4096,0);var wNode=FS.createNode(PIPEFS.root,wName,4096,0);rNode.pipe=pipe;wNode.pipe=pipe;var readableStream=FS.createStream({path:rName,node:rNode,flags:0,seekable:false,stream_ops:PIPEFS.stream_ops});rNode.stream=readableStream;var writableStream=FS.createStream({path:wName,node:wNode,flags:1,seekable:false,stream_ops:PIPEFS.stream_ops});wNode.stream=writableStream;return{readable_fd:readableStream.fd,writable_fd:writableStream.fd}},stream_ops:{getattr(stream){var node=stream.node;var timestamp=node.pipe.timestamp;return{dev:14,ino:node.id,mode:4480,nlink:1,uid:0,gid:0,rdev:0,size:0,atime:timestamp,mtime:timestamp,ctime:timestamp,blksize:4096,blocks:0}},poll(stream){var pipe=stream.node.pipe;if((stream.flags&2097155)===1){return 256|4}for(var bucket of pipe.buckets){if(bucket.offset-bucket.roffset>0){return 64|1}}return 0},dup(stream){stream.node.pipe.refcnt++},ioctl(stream,request,varargs){return 28},fsync(stream){return 28},read(stream,buffer,offset,length,position){var pipe=stream.node.pipe;var currentLength=0;for(var bucket of pipe.buckets){currentLength+=bucket.offset-bucket.roffset}var data=buffer.subarray(offset,offset+length);if(length<=0){return 0}if(currentLength==0){throw new FS.ErrnoError(6)}var toRead=Math.min(currentLength,length);var totalRead=toRead;var toRemove=0;for(var bucket of pipe.buckets){var bucketSize=bucket.offset-bucket.roffset;if(toRead<=bucketSize){var tmpSlice=bucket.buffer.subarray(bucket.roffset,bucket.offset);if(toRead=dataLen){currBucket.buffer.set(data,currBucket.offset);currBucket.offset+=dataLen;return dataLen}else if(freeBytesInCurrBuffer>0){currBucket.buffer.set(data.subarray(0,freeBytesInCurrBuffer),currBucket.offset);currBucket.offset+=freeBytesInCurrBuffer;data=data.subarray(freeBytesInCurrBuffer,data.byteLength)}var numBuckets=data.byteLength/PIPEFS.BUCKET_BUFFER_SIZE|0;var remElements=data.byteLength%PIPEFS.BUCKET_BUFFER_SIZE;for(var i=0;i0){var newBucket={buffer:new Uint8Array(PIPEFS.BUCKET_BUFFER_SIZE),offset:data.byteLength,roffset:0};pipe.buckets.push(newBucket);newBucket.buffer.set(data)}return dataLen},close(stream){var pipe=stream.node.pipe;pipe.refcnt--;if(pipe.refcnt===0){pipe.buckets=null}}},nextname(){if(!PIPEFS.nextname.current){PIPEFS.nextname.current=0}return"pipe["+PIPEFS.nextname.current+++"]"}};function ___syscall_pipe(fdPtr){fdPtr>>>=0;try{if(fdPtr==0){throw new FS.ErrnoError(21)}var res=PIPEFS.createPipe();HEAP32[fdPtr>>>2>>>0]=res.readable_fd;HEAP32[fdPtr+4>>>2>>>0]=res.writable_fd;return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_pipe.sig="ip";function ___syscall_poll(fds,nfds,timeout){fds>>>=0;try{var nonzero=0;for(var i=0;i>>2>>>0];var events=HEAP16[pollfd+4>>>1>>>0];var mask=32;var stream=FS.getStream(fd);if(stream){mask=SYSCALLS.DEFAULT_POLLMASK;if(stream.stream_ops.poll){mask=stream.stream_ops.poll(stream,-1)}}mask&=events|8|16;if(mask)nonzero++;HEAP16[pollfd+6>>>1>>>0]=mask}return nonzero}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_poll.sig="ipii";function ___syscall_readlinkat(dirfd,path,buf,bufsize){path>>>=0;buf>>>=0;bufsize>>>=0;try{path=SYSCALLS.getStr(path);path=SYSCALLS.calculateAt(dirfd,path);if(bufsize<=0)return-28;var ret=FS.readlink(path);var len=Math.min(bufsize,lengthBytesUTF8(ret));var endChar=HEAP8[buf+len>>>0];stringToUTF8(ret,buf,bufsize+1);HEAP8[buf+len>>>0]=endChar;return len}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_readlinkat.sig="iippp";function ___syscall_recvfrom(fd,buf,len,flags,addr,addrlen){buf>>>=0;len>>>=0;addr>>>=0;addrlen>>>=0;try{var sock=getSocketFromFD(fd);var msg=sock.sock_ops.recvmsg(sock,len);if(!msg)return 0;if(addr){var errno=writeSockaddr(addr,sock.family,DNS.lookup_name(msg.addr),msg.port,addrlen)}HEAPU8.set(msg.buffer,buf>>>0);return msg.buffer.byteLength}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_recvfrom.sig="iippipp";function ___syscall_recvmsg(fd,message,flags,d1,d2,d3){message>>>=0;try{var sock=getSocketFromFD(fd);var iov=HEAPU32[message+8>>>2>>>0];var num=HEAP32[message+12>>>2>>>0];var total=0;for(var i=0;i>>2>>>0]}var msg=sock.sock_ops.recvmsg(sock,total);if(!msg)return 0;var name=HEAPU32[message>>>2>>>0];if(name){var errno=writeSockaddr(name,sock.family,DNS.lookup_name(msg.addr),msg.port)}var bytesRead=0;var bytesRemaining=msg.buffer.byteLength;for(var i=0;bytesRemaining>0&&i>>2>>>0];var iovlen=HEAP32[iov+(8*i+4)>>>2>>>0];if(!iovlen){continue}var length=Math.min(iovlen,bytesRemaining);var buf=msg.buffer.subarray(bytesRead,bytesRead+length);HEAPU8.set(buf,iovbase+bytesRead>>>0);bytesRead+=length;bytesRemaining-=length}return bytesRead}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_recvmsg.sig="iipiiii";function ___syscall_renameat(olddirfd,oldpath,newdirfd,newpath){oldpath>>>=0;newpath>>>=0;try{oldpath=SYSCALLS.getStr(oldpath);newpath=SYSCALLS.getStr(newpath);oldpath=SYSCALLS.calculateAt(olddirfd,oldpath);newpath=SYSCALLS.calculateAt(newdirfd,newpath);FS.rename(oldpath,newpath);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_renameat.sig="iipip";function ___syscall_rmdir(path){path>>>=0;try{path=SYSCALLS.getStr(path);FS.rmdir(path);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_rmdir.sig="ip";function ___syscall_sendmsg(fd,message,flags,d1,d2,d3){message>>>=0;d1>>>=0;d2>>>=0;try{var sock=getSocketFromFD(fd);var iov=HEAPU32[message+8>>>2>>>0];var num=HEAP32[message+12>>>2>>>0];var addr,port;var name=HEAPU32[message>>>2>>>0];var namelen=HEAP32[message+4>>>2>>>0];if(name){var info=getSocketAddress(name,namelen);port=info.port;addr=info.addr}var total=0;for(var i=0;i>>2>>>0]}var view=new Uint8Array(total);var offset=0;for(var i=0;i>>2>>>0];var iovlen=HEAP32[iov+(8*i+4)>>>2>>>0];for(var j=0;j>>0]}}return sock.sock_ops.sendmsg(sock,view,0,total,addr,port)}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_sendmsg.sig="iipippi";function ___syscall_sendto(fd,message,length,flags,addr,addr_len){message>>>=0;length>>>=0;addr>>>=0;addr_len>>>=0;try{var sock=getSocketFromFD(fd);if(!addr){return FS.write(sock.stream,HEAP8,message,length)}var dest=getSocketAddress(addr,addr_len);return sock.sock_ops.sendmsg(sock,HEAP8,message,length,dest.addr,dest.port)}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_sendto.sig="iippipp";function ___syscall_socket(domain,type,protocol){try{var sock=SOCKFS.createSocket(domain,type,protocol);return sock.stream.fd}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_socket.sig="iiiiiii";function ___syscall_stat64(path,buf){path>>>=0;buf>>>=0;try{path=SYSCALLS.getStr(path);return SYSCALLS.writeStat(buf,FS.stat(path))}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_stat64.sig="ipp";function ___syscall_statfs64(path,size,buf){path>>>=0;size>>>=0;buf>>>=0;try{SYSCALLS.writeStatFs(buf,FS.statfs(SYSCALLS.getStr(path)));return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_statfs64.sig="ippp";function ___syscall_symlinkat(target,dirfd,linkpath){target>>>=0;linkpath>>>=0;try{target=SYSCALLS.getStr(target);linkpath=SYSCALLS.getStr(linkpath);linkpath=SYSCALLS.calculateAt(dirfd,linkpath);FS.symlink(target,linkpath);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_symlinkat.sig="ipip";function ___syscall_truncate64(path,length){path>>>=0;length=bigintToI53Checked(length);try{if(isNaN(length))return-61;path=SYSCALLS.getStr(path);FS.truncate(path,length);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_truncate64.sig="ipj";function ___syscall_unlinkat(dirfd,path,flags){path>>>=0;try{path=SYSCALLS.getStr(path);path=SYSCALLS.calculateAt(dirfd,path);if(!flags){FS.unlink(path)}else if(flags===512){FS.rmdir(path)}else{return-28}return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_unlinkat.sig="iipi";var readI53FromI64=ptr=>HEAPU32[ptr>>>2>>>0]+HEAP32[ptr+4>>>2>>>0]*4294967296;function ___syscall_utimensat(dirfd,path,times,flags){path>>>=0;times>>>=0;try{path=SYSCALLS.getStr(path);path=SYSCALLS.calculateAt(dirfd,path,true);var now=Date.now(),atime,mtime;if(!times){atime=now;mtime=now}else{var seconds=readI53FromI64(times);var nanoseconds=HEAP32[times+8>>>2>>>0];if(nanoseconds==1073741823){atime=now}else if(nanoseconds==1073741822){atime=null}else{atime=seconds*1e3+nanoseconds/(1e3*1e3)}times+=16;seconds=readI53FromI64(times);nanoseconds=HEAP32[times+8>>>2>>>0];if(nanoseconds==1073741823){mtime=now}else if(nanoseconds==1073741822){mtime=null}else{mtime=seconds*1e3+nanoseconds/(1e3*1e3)}}if((mtime??atime)!==null){FS.utime(path,atime,mtime)}return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}___syscall_utimensat.sig="iippi";var ___table_base=new WebAssembly.Global({value:"i32",mutable:false},1);var __abort_js=()=>abort("");__abort_js.sig="v";var dlSetError=msg=>{var sp=stackSave();var cmsg=stringToUTF8OnStack(msg);___dl_seterr(cmsg,0);stackRestore(sp)};var dlopenInternal=(handle,jsflags)=>{var filename=UTF8ToString(handle+36);var flags=HEAP32[handle+4>>>2>>>0];filename=PATH.normalize(filename);var searchpaths=[];var global=Boolean(flags&256);var localScope=global?null:{};var combinedFlags={global,nodelete:Boolean(flags&4096),loadAsync:jsflags.loadAsync};if(jsflags.loadAsync){return loadDynamicLibrary(filename,combinedFlags,localScope,handle)}try{return loadDynamicLibrary(filename,combinedFlags,localScope,handle)}catch(e){dlSetError(`Could not load dynamic lib: ${filename}\n${e}`);return 0}};function __dlopen_js(handle){handle>>>=0;return dlopenInternal(handle,{loadAsync:false})}__dlopen_js.sig="pp";function __dlsym_js(handle,symbol,symbolIndex){handle>>>=0;symbol>>>=0;symbolIndex>>>=0;symbol=UTF8ToString(symbol);var result;var newSymIndex;var lib=LDSO.loadedLibsByHandle[handle];if(!lib.exports.hasOwnProperty(symbol)||lib.exports[symbol].stub){dlSetError(`Tried to lookup unknown symbol "${symbol}" in dynamic lib: ${lib.name}`);return 0}newSymIndex=Object.keys(lib.exports).indexOf(symbol);result=lib.exports[symbol];if(typeof result=="function"){var addr=getFunctionAddress(result);if(addr){result=addr}else{result=addFunction(result,result.sig);HEAPU32[symbolIndex>>>2>>>0]=newSymIndex}}return result}__dlsym_js.sig="pppp";var handleException=e=>{if(e instanceof ExitStatus||e=="unwind"){return EXITSTATUS}quit_(1,e)};var runtimeKeepaliveCounter=0;var keepRuntimeAlive=()=>noExitRuntime||runtimeKeepaliveCounter>0;var _proc_exit=code=>{EXITSTATUS=code;if(!keepRuntimeAlive()){Module["onExit"]?.(code);ABORT=true}quit_(code,new ExitStatus(code))};_proc_exit.sig="vi";var exitJS=(status,implicit)=>{EXITSTATUS=status;if(!keepRuntimeAlive()){exitRuntime()}_proc_exit(status)};var _exit=exitJS;_exit.sig="vi";var maybeExit=()=>{if(runtimeExited){return}if(!keepRuntimeAlive()){try{_exit(EXITSTATUS)}catch(e){handleException(e)}}};var callUserCallback=func=>{if(runtimeExited||ABORT){return}try{func();maybeExit()}catch(e){handleException(e)}};var runtimeKeepalivePush=()=>{runtimeKeepaliveCounter+=1};runtimeKeepalivePush.sig="v";var runtimeKeepalivePop=()=>{runtimeKeepaliveCounter-=1};runtimeKeepalivePop.sig="v";function __emscripten_dlopen_js(handle,onsuccess,onerror,user_data){handle>>>=0;onsuccess>>>=0;onerror>>>=0;user_data>>>=0;function errorCallback(e){var filename=UTF8ToString(handle+36);dlSetError(`'Could not load dynamic lib: ${filename}\n${e}`);runtimeKeepalivePop();callUserCallback(()=>getWasmTableEntry(onerror)(handle,user_data))}function successCallback(){runtimeKeepalivePop();callUserCallback(()=>getWasmTableEntry(onsuccess)(handle,user_data))}runtimeKeepalivePush();var promise=dlopenInternal(handle,{loadAsync:true});if(promise){promise.then(successCallback,errorCallback)}else{errorCallback()}}__emscripten_dlopen_js.sig="vpppp";var getExecutableName=()=>thisProgram||"./this.program";function __emscripten_get_progname(str,len){str>>>=0;return stringToUTF8(getExecutableName(),str,len)}__emscripten_get_progname.sig="vpi";function __emscripten_lookup_name(name){name>>>=0;var nameString=UTF8ToString(name);return inetPton4(DNS.lookup_name(nameString))}__emscripten_lookup_name.sig="ip";var __emscripten_runtime_keepalive_clear=()=>{noExitRuntime=false;runtimeKeepaliveCounter=0};__emscripten_runtime_keepalive_clear.sig="v";function __emscripten_system(command){command>>>=0;if(ENVIRONMENT_IS_NODE){if(!command)return 1;var cmdstr=UTF8ToString(command);if(!cmdstr.length)return 0;var cp=require("child_process");var ret=cp.spawnSync(cmdstr,[],{shell:true,stdio:"inherit"});var _W_EXITCODE=(ret,sig)=>ret<<8|sig;if(ret.status===null){var signalToNumber=sig=>{switch(sig){case"SIGHUP":return 1;case"SIGQUIT":return 3;case"SIGFPE":return 8;case"SIGKILL":return 9;case"SIGALRM":return 14;case"SIGTERM":return 15;default:return 2}};return _W_EXITCODE(0,signalToNumber(ret.signal))}return _W_EXITCODE(ret.status,0)}if(!command)return 0;return-52}__emscripten_system.sig="ip";function __gmtime_js(time,tmPtr){time=bigintToI53Checked(time);tmPtr>>>=0;var date=new Date(time*1e3);HEAP32[tmPtr>>>2>>>0]=date.getUTCSeconds();HEAP32[tmPtr+4>>>2>>>0]=date.getUTCMinutes();HEAP32[tmPtr+8>>>2>>>0]=date.getUTCHours();HEAP32[tmPtr+12>>>2>>>0]=date.getUTCDate();HEAP32[tmPtr+16>>>2>>>0]=date.getUTCMonth();HEAP32[tmPtr+20>>>2>>>0]=date.getUTCFullYear()-1900;HEAP32[tmPtr+24>>>2>>>0]=date.getUTCDay();var start=Date.UTC(date.getUTCFullYear(),0,1,0,0,0,0);var yday=(date.getTime()-start)/(1e3*60*60*24)|0;HEAP32[tmPtr+28>>>2>>>0]=yday}__gmtime_js.sig="vjp";var isLeapYear=year=>year%4===0&&(year%100!==0||year%400===0);var MONTH_DAYS_LEAP_CUMULATIVE=[0,31,60,91,121,152,182,213,244,274,305,335];var MONTH_DAYS_REGULAR_CUMULATIVE=[0,31,59,90,120,151,181,212,243,273,304,334];var ydayFromDate=date=>{var leap=isLeapYear(date.getFullYear());var monthDaysCumulative=leap?MONTH_DAYS_LEAP_CUMULATIVE:MONTH_DAYS_REGULAR_CUMULATIVE;var yday=monthDaysCumulative[date.getMonth()]+date.getDate()-1;return yday};function __localtime_js(time,tmPtr){time=bigintToI53Checked(time);tmPtr>>>=0;var date=new Date(time*1e3);HEAP32[tmPtr>>>2>>>0]=date.getSeconds();HEAP32[tmPtr+4>>>2>>>0]=date.getMinutes();HEAP32[tmPtr+8>>>2>>>0]=date.getHours();HEAP32[tmPtr+12>>>2>>>0]=date.getDate();HEAP32[tmPtr+16>>>2>>>0]=date.getMonth();HEAP32[tmPtr+20>>>2>>>0]=date.getFullYear()-1900;HEAP32[tmPtr+24>>>2>>>0]=date.getDay();var yday=ydayFromDate(date)|0;HEAP32[tmPtr+28>>>2>>>0]=yday;HEAP32[tmPtr+36>>>2>>>0]=-(date.getTimezoneOffset()*60);var start=new Date(date.getFullYear(),0,1);var summerOffset=new Date(date.getFullYear(),6,1).getTimezoneOffset();var winterOffset=start.getTimezoneOffset();var dst=(summerOffset!=winterOffset&&date.getTimezoneOffset()==Math.min(winterOffset,summerOffset))|0;HEAP32[tmPtr+32>>>2>>>0]=dst}__localtime_js.sig="vjp";var __mktime_js=function(tmPtr){tmPtr>>>=0;var ret=(()=>{var date=new Date(HEAP32[tmPtr+20>>>2>>>0]+1900,HEAP32[tmPtr+16>>>2>>>0],HEAP32[tmPtr+12>>>2>>>0],HEAP32[tmPtr+8>>>2>>>0],HEAP32[tmPtr+4>>>2>>>0],HEAP32[tmPtr>>>2>>>0],0);var dst=HEAP32[tmPtr+32>>>2>>>0];var guessedOffset=date.getTimezoneOffset();var start=new Date(date.getFullYear(),0,1);var summerOffset=new Date(date.getFullYear(),6,1).getTimezoneOffset();var winterOffset=start.getTimezoneOffset();var dstOffset=Math.min(winterOffset,summerOffset);if(dst<0){HEAP32[tmPtr+32>>>2>>>0]=Number(summerOffset!=winterOffset&&dstOffset==guessedOffset)}else if(dst>0!=(dstOffset==guessedOffset)){var nonDstOffset=Math.max(winterOffset,summerOffset);var trueOffset=dst>0?dstOffset:nonDstOffset;date.setTime(date.getTime()+(trueOffset-guessedOffset)*6e4)}HEAP32[tmPtr+24>>>2>>>0]=date.getDay();var yday=ydayFromDate(date)|0;HEAP32[tmPtr+28>>>2>>>0]=yday;HEAP32[tmPtr>>>2>>>0]=date.getSeconds();HEAP32[tmPtr+4>>>2>>>0]=date.getMinutes();HEAP32[tmPtr+8>>>2>>>0]=date.getHours();HEAP32[tmPtr+12>>>2>>>0]=date.getDate();HEAP32[tmPtr+16>>>2>>>0]=date.getMonth();HEAP32[tmPtr+20>>>2>>>0]=date.getYear();var timeMs=date.getTime();if(isNaN(timeMs)){return-1}return timeMs/1e3})();return BigInt(ret)};__mktime_js.sig="jp";function __mmap_js(len,prot,flags,fd,offset,allocated,addr){len>>>=0;offset=bigintToI53Checked(offset);allocated>>>=0;addr>>>=0;try{var stream=SYSCALLS.getStreamFromFD(fd);var res=FS.mmap(stream,len,offset,prot,flags);var ptr=res.ptr;HEAP32[allocated>>>2>>>0]=res.allocated;HEAPU32[addr>>>2>>>0]=ptr;return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}__mmap_js.sig="ipiiijpp";function __msync_js(addr,len,prot,flags,fd,offset){addr>>>=0;len>>>=0;offset=bigintToI53Checked(offset);try{if(isNaN(offset))return-61;SYSCALLS.doMsync(addr,SYSCALLS.getStreamFromFD(fd),len,flags,offset);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}__msync_js.sig="ippiiij";function __munmap_js(addr,len,prot,flags,fd,offset){addr>>>=0;len>>>=0;offset=bigintToI53Checked(offset);try{var stream=SYSCALLS.getStreamFromFD(fd);if(prot&2){SYSCALLS.doMsync(addr,stream,len,flags,offset)}}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}__munmap_js.sig="ippiiij";var timers={};var _emscripten_get_now=()=>performance.now();_emscripten_get_now.sig="d";var __setitimer_js=(which,timeout_ms)=>{if(timers[which]){clearTimeout(timers[which].id);delete timers[which]}if(!timeout_ms)return 0;var id=setTimeout(()=>{delete timers[which];callUserCallback(()=>__emscripten_timeout(which,_emscripten_get_now()))},timeout_ms);timers[which]={id,timeout_ms};return 0};__setitimer_js.sig="iid";var __timegm_js=function(tmPtr){tmPtr>>>=0;var ret=(()=>{var time=Date.UTC(HEAP32[tmPtr+20>>>2>>>0]+1900,HEAP32[tmPtr+16>>>2>>>0],HEAP32[tmPtr+12>>>2>>>0],HEAP32[tmPtr+8>>>2>>>0],HEAP32[tmPtr+4>>>2>>>0],HEAP32[tmPtr>>>2>>>0],0);var date=new Date(time);HEAP32[tmPtr+24>>>2>>>0]=date.getUTCDay();var start=Date.UTC(date.getUTCFullYear(),0,1,0,0,0,0);var yday=(date.getTime()-start)/(1e3*60*60*24)|0;HEAP32[tmPtr+28>>>2>>>0]=yday;return date.getTime()/1e3})();return BigInt(ret)};__timegm_js.sig="jp";var __tzset_js=function(timezone,daylight,std_name,dst_name){timezone>>>=0;daylight>>>=0;std_name>>>=0;dst_name>>>=0;var currentYear=(new Date).getFullYear();var winter=new Date(currentYear,0,1);var summer=new Date(currentYear,6,1);var winterOffset=winter.getTimezoneOffset();var summerOffset=summer.getTimezoneOffset();var stdTimezoneOffset=Math.max(winterOffset,summerOffset);HEAPU32[timezone>>>2>>>0]=stdTimezoneOffset*60;HEAP32[daylight>>>2>>>0]=Number(winterOffset!=summerOffset);var extractZone=timezoneOffset=>{var sign=timezoneOffset>=0?"-":"+";var absOffset=Math.abs(timezoneOffset);var hours=String(Math.floor(absOffset/60)).padStart(2,"0");var minutes=String(absOffset%60).padStart(2,"0");return`UTC${sign}${hours}${minutes}`};var winterName=extractZone(winterOffset);var summerName=extractZone(summerOffset);if(summerOffset{if(ENVIRONMENT_IS_NODE){return 1}return 1e3};_emscripten_get_now_res.sig="d";var nowIsMonotonic=1;var checkWasiClock=clock_id=>clock_id>=0&&clock_id<=3;function _clock_res_get(clk_id,pres){pres>>>=0;if(!checkWasiClock(clk_id)){return 28}var nsec;if(clk_id===0){nsec=1e3*1e3}else if(nowIsMonotonic){nsec=_emscripten_get_now_res()}else{return 52}HEAP64[pres>>>3>>>0]=BigInt(nsec);return 0}_clock_res_get.sig="iip";var _emscripten_date_now=()=>Date.now();_emscripten_date_now.sig="d";function _clock_time_get(clk_id,ignored_precision,ptime){ignored_precision=bigintToI53Checked(ignored_precision);ptime>>>=0;if(!checkWasiClock(clk_id)){return 28}var now;if(clk_id===0){now=_emscripten_date_now()}else if(nowIsMonotonic){now=_emscripten_get_now()}else{return 52}var nsec=Math.round(now*1e3*1e3);HEAP64[ptime>>>3>>>0]=BigInt(nsec);return 0}_clock_time_get.sig="iijp";function _create_sentinel(...args){return wasmImports["create_sentinel"](...args)}_create_sentinel.stub=true;var readEmAsmArgsArray=[];var readEmAsmArgs=(sigPtr,buf)=>{readEmAsmArgsArray.length=0;var ch;while(ch=HEAPU8[sigPtr++>>>0]){var wide=ch!=105;wide&=ch!=112;buf+=wide&&buf%8?4:0;readEmAsmArgsArray.push(ch==112?HEAPU32[buf>>>2>>>0]:ch==106?HEAP64[buf>>>3>>>0]:ch==105?HEAP32[buf>>>2>>>0]:HEAPF64[buf>>>3>>>0]);buf+=wide?8:4}return readEmAsmArgsArray};var runEmAsmFunction=(code,sigPtr,argbuf)=>{var args=readEmAsmArgs(sigPtr,argbuf);return ASM_CONSTS[code](...args)};function _emscripten_asm_const_int(code,sigPtr,argbuf){code>>>=0;sigPtr>>>=0;argbuf>>>=0;return runEmAsmFunction(code,sigPtr,argbuf)}_emscripten_asm_const_int.sig="ippp";function _emscripten_console_error(str){str>>>=0;console.error(UTF8ToString(str))}_emscripten_console_error.sig="vp";function _emscripten_console_log(str){str>>>=0;console.log(UTF8ToString(str))}_emscripten_console_log.sig="vp";function _emscripten_console_trace(str){str>>>=0;console.trace(UTF8ToString(str))}_emscripten_console_trace.sig="vp";function _emscripten_console_warn(str){str>>>=0;console.warn(UTF8ToString(str))}_emscripten_console_warn.sig="vp";function _emscripten_err(str){str>>>=0;return err(UTF8ToString(str))}_emscripten_err.sig="vp";var getHeapMax=()=>4294901760;function _emscripten_get_heap_max(){return getHeapMax()}_emscripten_get_heap_max.sig="p";var GLctx;var webgl_enable_ANGLE_instanced_arrays=ctx=>{var ext=ctx.getExtension("ANGLE_instanced_arrays");if(ext){ctx["vertexAttribDivisor"]=(index,divisor)=>ext["vertexAttribDivisorANGLE"](index,divisor);ctx["drawArraysInstanced"]=(mode,first,count,primcount)=>ext["drawArraysInstancedANGLE"](mode,first,count,primcount);ctx["drawElementsInstanced"]=(mode,count,type,indices,primcount)=>ext["drawElementsInstancedANGLE"](mode,count,type,indices,primcount);return 1}};var webgl_enable_OES_vertex_array_object=ctx=>{var ext=ctx.getExtension("OES_vertex_array_object");if(ext){ctx["createVertexArray"]=()=>ext["createVertexArrayOES"]();ctx["deleteVertexArray"]=vao=>ext["deleteVertexArrayOES"](vao);ctx["bindVertexArray"]=vao=>ext["bindVertexArrayOES"](vao);ctx["isVertexArray"]=vao=>ext["isVertexArrayOES"](vao);return 1}};var webgl_enable_WEBGL_draw_buffers=ctx=>{var ext=ctx.getExtension("WEBGL_draw_buffers");if(ext){ctx["drawBuffers"]=(n,bufs)=>ext["drawBuffersWEBGL"](n,bufs);return 1}};var webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance=ctx=>!!(ctx.dibvbi=ctx.getExtension("WEBGL_draw_instanced_base_vertex_base_instance"));var webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance=ctx=>!!(ctx.mdibvbi=ctx.getExtension("WEBGL_multi_draw_instanced_base_vertex_base_instance"));var webgl_enable_EXT_polygon_offset_clamp=ctx=>!!(ctx.extPolygonOffsetClamp=ctx.getExtension("EXT_polygon_offset_clamp"));var webgl_enable_EXT_clip_control=ctx=>!!(ctx.extClipControl=ctx.getExtension("EXT_clip_control"));var webgl_enable_WEBGL_polygon_mode=ctx=>!!(ctx.webglPolygonMode=ctx.getExtension("WEBGL_polygon_mode"));var webgl_enable_WEBGL_multi_draw=ctx=>!!(ctx.multiDrawWebgl=ctx.getExtension("WEBGL_multi_draw"));var getEmscriptenSupportedExtensions=ctx=>{var supportedExtensions=["ANGLE_instanced_arrays","EXT_blend_minmax","EXT_disjoint_timer_query","EXT_frag_depth","EXT_shader_texture_lod","EXT_sRGB","OES_element_index_uint","OES_fbo_render_mipmap","OES_standard_derivatives","OES_texture_float","OES_texture_half_float","OES_texture_half_float_linear","OES_vertex_array_object","WEBGL_color_buffer_float","WEBGL_depth_texture","WEBGL_draw_buffers","EXT_color_buffer_float","EXT_conservative_depth","EXT_disjoint_timer_query_webgl2","EXT_texture_norm16","NV_shader_noperspective_interpolation","WEBGL_clip_cull_distance","EXT_clip_control","EXT_color_buffer_half_float","EXT_depth_clamp","EXT_float_blend","EXT_polygon_offset_clamp","EXT_texture_compression_bptc","EXT_texture_compression_rgtc","EXT_texture_filter_anisotropic","KHR_parallel_shader_compile","OES_texture_float_linear","WEBGL_blend_func_extended","WEBGL_compressed_texture_astc","WEBGL_compressed_texture_etc","WEBGL_compressed_texture_etc1","WEBGL_compressed_texture_s3tc","WEBGL_compressed_texture_s3tc_srgb","WEBGL_debug_renderer_info","WEBGL_debug_shaders","WEBGL_lose_context","WEBGL_multi_draw","WEBGL_polygon_mode"];return(ctx.getSupportedExtensions()||[]).filter(ext=>supportedExtensions.includes(ext))};var GL={counter:1,buffers:[],programs:[],framebuffers:[],renderbuffers:[],textures:[],shaders:[],vaos:[],contexts:[],offscreenCanvases:{},queries:[],samplers:[],transformFeedbacks:[],syncs:[],stringCache:{},stringiCache:{},unpackAlignment:4,unpackRowLength:0,recordError:errorCode=>{if(!GL.lastError){GL.lastError=errorCode}},getNewId:table=>{var ret=GL.counter++;for(var i=table.length;i{for(var i=0;i>>2>>>0]=id}},getSource:(shader,count,string,length)=>{var source="";for(var i=0;i>>2>>>0]:undefined;source+=UTF8ToString(HEAPU32[string+i*4>>>2>>>0],len)}return source},createContext:(canvas,webGLContextAttributes)=>{var ctx=webGLContextAttributes.majorVersion>1?canvas.getContext("webgl2",webGLContextAttributes):canvas.getContext("webgl",webGLContextAttributes);if(!ctx)return 0;var handle=GL.registerContext(ctx,webGLContextAttributes);return handle},registerContext:(ctx,webGLContextAttributes)=>{var handle=GL.getNewId(GL.contexts);var context={handle,attributes:webGLContextAttributes,version:webGLContextAttributes.majorVersion,GLctx:ctx};if(ctx.canvas)ctx.canvas.GLctxObject=context;GL.contexts[handle]=context;if(typeof webGLContextAttributes.enableExtensionsByDefault=="undefined"||webGLContextAttributes.enableExtensionsByDefault){GL.initExtensions(context)}return handle},makeContextCurrent:contextHandle=>{GL.currentContext=GL.contexts[contextHandle];Module["ctx"]=GLctx=GL.currentContext?.GLctx;return!(contextHandle&&!GLctx)},getContext:contextHandle=>GL.contexts[contextHandle],deleteContext:contextHandle=>{if(GL.currentContext===GL.contexts[contextHandle]){GL.currentContext=null}if(typeof JSEvents=="object"){JSEvents.removeAllHandlersOnTarget(GL.contexts[contextHandle].GLctx.canvas)}if(GL.contexts[contextHandle]?.GLctx.canvas){GL.contexts[contextHandle].GLctx.canvas.GLctxObject=undefined}GL.contexts[contextHandle]=null},initExtensions:context=>{context||=GL.currentContext;if(context.initExtensionsDone)return;context.initExtensionsDone=true;var GLctx=context.GLctx;webgl_enable_WEBGL_multi_draw(GLctx);webgl_enable_EXT_polygon_offset_clamp(GLctx);webgl_enable_EXT_clip_control(GLctx);webgl_enable_WEBGL_polygon_mode(GLctx);webgl_enable_ANGLE_instanced_arrays(GLctx);webgl_enable_OES_vertex_array_object(GLctx);webgl_enable_WEBGL_draw_buffers(GLctx);webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance(GLctx);webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance(GLctx);if(context.version>=2){GLctx.disjointTimerQueryExt=GLctx.getExtension("EXT_disjoint_timer_query_webgl2")}if(context.version<2||!GLctx.disjointTimerQueryExt){GLctx.disjointTimerQueryExt=GLctx.getExtension("EXT_disjoint_timer_query")}getEmscriptenSupportedExtensions(GLctx).forEach(ext=>{if(!ext.includes("lose_context")&&!ext.includes("debug")){GLctx.getExtension(ext)}})}};var _glActiveTexture=x0=>GLctx.activeTexture(x0);_glActiveTexture.sig="vi";var _emscripten_glActiveTexture=_glActiveTexture;_emscripten_glActiveTexture.sig="vi";var _glAttachShader=(program,shader)=>{GLctx.attachShader(GL.programs[program],GL.shaders[shader])};_glAttachShader.sig="vii";var _emscripten_glAttachShader=_glAttachShader;_emscripten_glAttachShader.sig="vii";var _glBeginQuery=(target,id)=>{GLctx.beginQuery(target,GL.queries[id])};_glBeginQuery.sig="vii";var _emscripten_glBeginQuery=_glBeginQuery;_emscripten_glBeginQuery.sig="vii";var _glBeginQueryEXT=(target,id)=>{GLctx.disjointTimerQueryExt["beginQueryEXT"](target,GL.queries[id])};_glBeginQueryEXT.sig="vii";var _emscripten_glBeginQueryEXT=_glBeginQueryEXT;var _glBeginTransformFeedback=x0=>GLctx.beginTransformFeedback(x0);_glBeginTransformFeedback.sig="vi";var _emscripten_glBeginTransformFeedback=_glBeginTransformFeedback;_emscripten_glBeginTransformFeedback.sig="vi";function _glBindAttribLocation(program,index,name){name>>>=0;GLctx.bindAttribLocation(GL.programs[program],index,UTF8ToString(name))}_glBindAttribLocation.sig="viip";var _emscripten_glBindAttribLocation=_glBindAttribLocation;_emscripten_glBindAttribLocation.sig="viip";var _glBindBuffer=(target,buffer)=>{if(target==35051){GLctx.currentPixelPackBufferBinding=buffer}else if(target==35052){GLctx.currentPixelUnpackBufferBinding=buffer}GLctx.bindBuffer(target,GL.buffers[buffer])};_glBindBuffer.sig="vii";var _emscripten_glBindBuffer=_glBindBuffer;_emscripten_glBindBuffer.sig="vii";var _glBindBufferBase=(target,index,buffer)=>{GLctx.bindBufferBase(target,index,GL.buffers[buffer])};_glBindBufferBase.sig="viii";var _emscripten_glBindBufferBase=_glBindBufferBase;_emscripten_glBindBufferBase.sig="viii";function _glBindBufferRange(target,index,buffer,offset,ptrsize){offset>>>=0;ptrsize>>>=0;GLctx.bindBufferRange(target,index,GL.buffers[buffer],offset,ptrsize)}_glBindBufferRange.sig="viiipp";var _emscripten_glBindBufferRange=_glBindBufferRange;_emscripten_glBindBufferRange.sig="viiipp";var _glBindFramebuffer=(target,framebuffer)=>{GLctx.bindFramebuffer(target,GL.framebuffers[framebuffer])};_glBindFramebuffer.sig="vii";var _emscripten_glBindFramebuffer=_glBindFramebuffer;_emscripten_glBindFramebuffer.sig="vii";var _glBindRenderbuffer=(target,renderbuffer)=>{GLctx.bindRenderbuffer(target,GL.renderbuffers[renderbuffer])};_glBindRenderbuffer.sig="vii";var _emscripten_glBindRenderbuffer=_glBindRenderbuffer;_emscripten_glBindRenderbuffer.sig="vii";var _glBindSampler=(unit,sampler)=>{GLctx.bindSampler(unit,GL.samplers[sampler])};_glBindSampler.sig="vii";var _emscripten_glBindSampler=_glBindSampler;_emscripten_glBindSampler.sig="vii";var _glBindTexture=(target,texture)=>{GLctx.bindTexture(target,GL.textures[texture])};_glBindTexture.sig="vii";var _emscripten_glBindTexture=_glBindTexture;_emscripten_glBindTexture.sig="vii";var _glBindTransformFeedback=(target,id)=>{GLctx.bindTransformFeedback(target,GL.transformFeedbacks[id])};_glBindTransformFeedback.sig="vii";var _emscripten_glBindTransformFeedback=_glBindTransformFeedback;_emscripten_glBindTransformFeedback.sig="vii";var _glBindVertexArray=vao=>{GLctx.bindVertexArray(GL.vaos[vao])};_glBindVertexArray.sig="vi";var _emscripten_glBindVertexArray=_glBindVertexArray;_emscripten_glBindVertexArray.sig="vi";var _glBindVertexArrayOES=_glBindVertexArray;_glBindVertexArrayOES.sig="vi";var _emscripten_glBindVertexArrayOES=_glBindVertexArrayOES;_emscripten_glBindVertexArrayOES.sig="vi";var _glBlendColor=(x0,x1,x2,x3)=>GLctx.blendColor(x0,x1,x2,x3);_glBlendColor.sig="vffff";var _emscripten_glBlendColor=_glBlendColor;_emscripten_glBlendColor.sig="vffff";var _glBlendEquation=x0=>GLctx.blendEquation(x0);_glBlendEquation.sig="vi";var _emscripten_glBlendEquation=_glBlendEquation;_emscripten_glBlendEquation.sig="vi";var _glBlendEquationSeparate=(x0,x1)=>GLctx.blendEquationSeparate(x0,x1);_glBlendEquationSeparate.sig="vii";var _emscripten_glBlendEquationSeparate=_glBlendEquationSeparate;_emscripten_glBlendEquationSeparate.sig="vii";var _glBlendFunc=(x0,x1)=>GLctx.blendFunc(x0,x1);_glBlendFunc.sig="vii";var _emscripten_glBlendFunc=_glBlendFunc;_emscripten_glBlendFunc.sig="vii";var _glBlendFuncSeparate=(x0,x1,x2,x3)=>GLctx.blendFuncSeparate(x0,x1,x2,x3);_glBlendFuncSeparate.sig="viiii";var _emscripten_glBlendFuncSeparate=_glBlendFuncSeparate;_emscripten_glBlendFuncSeparate.sig="viiii";var _glBlitFramebuffer=(x0,x1,x2,x3,x4,x5,x6,x7,x8,x9)=>GLctx.blitFramebuffer(x0,x1,x2,x3,x4,x5,x6,x7,x8,x9);_glBlitFramebuffer.sig="viiiiiiiiii";var _emscripten_glBlitFramebuffer=_glBlitFramebuffer;_emscripten_glBlitFramebuffer.sig="viiiiiiiiii";function _glBufferData(target,size,data,usage){size>>>=0;data>>>=0;GLctx.bufferData(target,data?HEAPU8.subarray(data>>>0,data+size>>>0):size,usage)}_glBufferData.sig="vippi";var _emscripten_glBufferData=_glBufferData;_emscripten_glBufferData.sig="vippi";function _glBufferSubData(target,offset,size,data){offset>>>=0;size>>>=0;data>>>=0;GLctx.bufferSubData(target,offset,HEAPU8.subarray(data>>>0,data+size>>>0))}_glBufferSubData.sig="vippp";var _emscripten_glBufferSubData=_glBufferSubData;_emscripten_glBufferSubData.sig="vippp";var _glCheckFramebufferStatus=x0=>GLctx.checkFramebufferStatus(x0);_glCheckFramebufferStatus.sig="ii";var _emscripten_glCheckFramebufferStatus=_glCheckFramebufferStatus;_emscripten_glCheckFramebufferStatus.sig="ii";var _glClear=x0=>GLctx.clear(x0);_glClear.sig="vi";var _emscripten_glClear=_glClear;_emscripten_glClear.sig="vi";var _glClearBufferfi=(x0,x1,x2,x3)=>GLctx.clearBufferfi(x0,x1,x2,x3);_glClearBufferfi.sig="viifi";var _emscripten_glClearBufferfi=_glClearBufferfi;_emscripten_glClearBufferfi.sig="viifi";function _glClearBufferfv(buffer,drawbuffer,value){value>>>=0;GLctx.clearBufferfv(buffer,drawbuffer,HEAPF32,value>>>2)}_glClearBufferfv.sig="viip";var _emscripten_glClearBufferfv=_glClearBufferfv;_emscripten_glClearBufferfv.sig="viip";function _glClearBufferiv(buffer,drawbuffer,value){value>>>=0;GLctx.clearBufferiv(buffer,drawbuffer,HEAP32,value>>>2)}_glClearBufferiv.sig="viip";var _emscripten_glClearBufferiv=_glClearBufferiv;_emscripten_glClearBufferiv.sig="viip";function _glClearBufferuiv(buffer,drawbuffer,value){value>>>=0;GLctx.clearBufferuiv(buffer,drawbuffer,HEAPU32,value>>>2)}_glClearBufferuiv.sig="viip";var _emscripten_glClearBufferuiv=_glClearBufferuiv;_emscripten_glClearBufferuiv.sig="viip";var _glClearColor=(x0,x1,x2,x3)=>GLctx.clearColor(x0,x1,x2,x3);_glClearColor.sig="vffff";var _emscripten_glClearColor=_glClearColor;_emscripten_glClearColor.sig="vffff";var _glClearDepthf=x0=>GLctx.clearDepth(x0);_glClearDepthf.sig="vf";var _emscripten_glClearDepthf=_glClearDepthf;_emscripten_glClearDepthf.sig="vf";var _glClearStencil=x0=>GLctx.clearStencil(x0);_glClearStencil.sig="vi";var _emscripten_glClearStencil=_glClearStencil;_emscripten_glClearStencil.sig="vi";function _glClientWaitSync(sync,flags,timeout){sync>>>=0;timeout=Number(timeout);return GLctx.clientWaitSync(GL.syncs[sync],flags,timeout)}_glClientWaitSync.sig="ipij";var _emscripten_glClientWaitSync=_glClientWaitSync;_emscripten_glClientWaitSync.sig="ipij";var _glClipControlEXT=(origin,depth)=>{GLctx.extClipControl["clipControlEXT"](origin,depth)};_glClipControlEXT.sig="vii";var _emscripten_glClipControlEXT=_glClipControlEXT;var _glColorMask=(red,green,blue,alpha)=>{GLctx.colorMask(!!red,!!green,!!blue,!!alpha)};_glColorMask.sig="viiii";var _emscripten_glColorMask=_glColorMask;_emscripten_glColorMask.sig="viiii";var _glCompileShader=shader=>{GLctx.compileShader(GL.shaders[shader])};_glCompileShader.sig="vi";var _emscripten_glCompileShader=_glCompileShader;_emscripten_glCompileShader.sig="vi";function _glCompressedTexImage2D(target,level,internalFormat,width,height,border,imageSize,data){data>>>=0;if(GL.currentContext.version>=2){if(GLctx.currentPixelUnpackBufferBinding||!imageSize){GLctx.compressedTexImage2D(target,level,internalFormat,width,height,border,imageSize,data);return}}GLctx.compressedTexImage2D(target,level,internalFormat,width,height,border,HEAPU8.subarray(data>>>0,data+imageSize>>>0))}_glCompressedTexImage2D.sig="viiiiiiip";var _emscripten_glCompressedTexImage2D=_glCompressedTexImage2D;_emscripten_glCompressedTexImage2D.sig="viiiiiiip";function _glCompressedTexImage3D(target,level,internalFormat,width,height,depth,border,imageSize,data){data>>>=0;if(GLctx.currentPixelUnpackBufferBinding){GLctx.compressedTexImage3D(target,level,internalFormat,width,height,depth,border,imageSize,data)}else{GLctx.compressedTexImage3D(target,level,internalFormat,width,height,depth,border,HEAPU8,data,imageSize)}}_glCompressedTexImage3D.sig="viiiiiiiip";var _emscripten_glCompressedTexImage3D=_glCompressedTexImage3D;_emscripten_glCompressedTexImage3D.sig="viiiiiiiip";function _glCompressedTexSubImage2D(target,level,xoffset,yoffset,width,height,format,imageSize,data){data>>>=0;if(GL.currentContext.version>=2){if(GLctx.currentPixelUnpackBufferBinding||!imageSize){GLctx.compressedTexSubImage2D(target,level,xoffset,yoffset,width,height,format,imageSize,data);return}}GLctx.compressedTexSubImage2D(target,level,xoffset,yoffset,width,height,format,HEAPU8.subarray(data>>>0,data+imageSize>>>0))}_glCompressedTexSubImage2D.sig="viiiiiiiip";var _emscripten_glCompressedTexSubImage2D=_glCompressedTexSubImage2D;_emscripten_glCompressedTexSubImage2D.sig="viiiiiiiip";function _glCompressedTexSubImage3D(target,level,xoffset,yoffset,zoffset,width,height,depth,format,imageSize,data){data>>>=0;if(GLctx.currentPixelUnpackBufferBinding){GLctx.compressedTexSubImage3D(target,level,xoffset,yoffset,zoffset,width,height,depth,format,imageSize,data)}else{GLctx.compressedTexSubImage3D(target,level,xoffset,yoffset,zoffset,width,height,depth,format,HEAPU8,data,imageSize)}}_glCompressedTexSubImage3D.sig="viiiiiiiiiip";var _emscripten_glCompressedTexSubImage3D=_glCompressedTexSubImage3D;_emscripten_glCompressedTexSubImage3D.sig="viiiiiiiiiip";function _glCopyBufferSubData(x0,x1,x2,x3,x4){x2>>>=0;x3>>>=0;x4>>>=0;return GLctx.copyBufferSubData(x0,x1,x2,x3,x4)}_glCopyBufferSubData.sig="viippp";var _emscripten_glCopyBufferSubData=_glCopyBufferSubData;_emscripten_glCopyBufferSubData.sig="viippp";var _glCopyTexImage2D=(x0,x1,x2,x3,x4,x5,x6,x7)=>GLctx.copyTexImage2D(x0,x1,x2,x3,x4,x5,x6,x7);_glCopyTexImage2D.sig="viiiiiiii";var _emscripten_glCopyTexImage2D=_glCopyTexImage2D;_emscripten_glCopyTexImage2D.sig="viiiiiiii";var _glCopyTexSubImage2D=(x0,x1,x2,x3,x4,x5,x6,x7)=>GLctx.copyTexSubImage2D(x0,x1,x2,x3,x4,x5,x6,x7);_glCopyTexSubImage2D.sig="viiiiiiii";var _emscripten_glCopyTexSubImage2D=_glCopyTexSubImage2D;_emscripten_glCopyTexSubImage2D.sig="viiiiiiii";var _glCopyTexSubImage3D=(x0,x1,x2,x3,x4,x5,x6,x7,x8)=>GLctx.copyTexSubImage3D(x0,x1,x2,x3,x4,x5,x6,x7,x8);_glCopyTexSubImage3D.sig="viiiiiiiii";var _emscripten_glCopyTexSubImage3D=_glCopyTexSubImage3D;_emscripten_glCopyTexSubImage3D.sig="viiiiiiiii";var _glCreateProgram=()=>{var id=GL.getNewId(GL.programs);var program=GLctx.createProgram();program.name=id;program.maxUniformLength=program.maxAttributeLength=program.maxUniformBlockNameLength=0;program.uniformIdCounter=1;GL.programs[id]=program;return id};_glCreateProgram.sig="i";var _emscripten_glCreateProgram=_glCreateProgram;_emscripten_glCreateProgram.sig="i";var _glCreateShader=shaderType=>{var id=GL.getNewId(GL.shaders);GL.shaders[id]=GLctx.createShader(shaderType);return id};_glCreateShader.sig="ii";var _emscripten_glCreateShader=_glCreateShader;_emscripten_glCreateShader.sig="ii";var _glCullFace=x0=>GLctx.cullFace(x0);_glCullFace.sig="vi";var _emscripten_glCullFace=_glCullFace;_emscripten_glCullFace.sig="vi";function _glDeleteBuffers(n,buffers){buffers>>>=0;for(var i=0;i>>2>>>0];var buffer=GL.buffers[id];if(!buffer)continue;GLctx.deleteBuffer(buffer);buffer.name=0;GL.buffers[id]=null;if(id==GLctx.currentPixelPackBufferBinding)GLctx.currentPixelPackBufferBinding=0;if(id==GLctx.currentPixelUnpackBufferBinding)GLctx.currentPixelUnpackBufferBinding=0}}_glDeleteBuffers.sig="vip";var _emscripten_glDeleteBuffers=_glDeleteBuffers;_emscripten_glDeleteBuffers.sig="vip";function _glDeleteFramebuffers(n,framebuffers){framebuffers>>>=0;for(var i=0;i>>2>>>0];var framebuffer=GL.framebuffers[id];if(!framebuffer)continue;GLctx.deleteFramebuffer(framebuffer);framebuffer.name=0;GL.framebuffers[id]=null}}_glDeleteFramebuffers.sig="vip";var _emscripten_glDeleteFramebuffers=_glDeleteFramebuffers;_emscripten_glDeleteFramebuffers.sig="vip";var _glDeleteProgram=id=>{if(!id)return;var program=GL.programs[id];if(!program){GL.recordError(1281);return}GLctx.deleteProgram(program);program.name=0;GL.programs[id]=null};_glDeleteProgram.sig="vi";var _emscripten_glDeleteProgram=_glDeleteProgram;_emscripten_glDeleteProgram.sig="vi";function _glDeleteQueries(n,ids){ids>>>=0;for(var i=0;i>>2>>>0];var query=GL.queries[id];if(!query)continue;GLctx.deleteQuery(query);GL.queries[id]=null}}_glDeleteQueries.sig="vip";var _emscripten_glDeleteQueries=_glDeleteQueries;_emscripten_glDeleteQueries.sig="vip";function _glDeleteQueriesEXT(n,ids){ids>>>=0;for(var i=0;i>>2>>>0];var query=GL.queries[id];if(!query)continue;GLctx.disjointTimerQueryExt["deleteQueryEXT"](query);GL.queries[id]=null}}_glDeleteQueriesEXT.sig="vip";var _emscripten_glDeleteQueriesEXT=_glDeleteQueriesEXT;function _glDeleteRenderbuffers(n,renderbuffers){renderbuffers>>>=0;for(var i=0;i>>2>>>0];var renderbuffer=GL.renderbuffers[id];if(!renderbuffer)continue;GLctx.deleteRenderbuffer(renderbuffer);renderbuffer.name=0;GL.renderbuffers[id]=null}}_glDeleteRenderbuffers.sig="vip";var _emscripten_glDeleteRenderbuffers=_glDeleteRenderbuffers;_emscripten_glDeleteRenderbuffers.sig="vip";function _glDeleteSamplers(n,samplers){samplers>>>=0;for(var i=0;i>>2>>>0];var sampler=GL.samplers[id];if(!sampler)continue;GLctx.deleteSampler(sampler);sampler.name=0;GL.samplers[id]=null}}_glDeleteSamplers.sig="vip";var _emscripten_glDeleteSamplers=_glDeleteSamplers;_emscripten_glDeleteSamplers.sig="vip";var _glDeleteShader=id=>{if(!id)return;var shader=GL.shaders[id];if(!shader){GL.recordError(1281);return}GLctx.deleteShader(shader);GL.shaders[id]=null};_glDeleteShader.sig="vi";var _emscripten_glDeleteShader=_glDeleteShader;_emscripten_glDeleteShader.sig="vi";function _glDeleteSync(id){id>>>=0;if(!id)return;var sync=GL.syncs[id];if(!sync){GL.recordError(1281);return}GLctx.deleteSync(sync);sync.name=0;GL.syncs[id]=null}_glDeleteSync.sig="vp";var _emscripten_glDeleteSync=_glDeleteSync;_emscripten_glDeleteSync.sig="vp";function _glDeleteTextures(n,textures){textures>>>=0;for(var i=0;i>>2>>>0];var texture=GL.textures[id];if(!texture)continue;GLctx.deleteTexture(texture);texture.name=0;GL.textures[id]=null}}_glDeleteTextures.sig="vip";var _emscripten_glDeleteTextures=_glDeleteTextures;_emscripten_glDeleteTextures.sig="vip";function _glDeleteTransformFeedbacks(n,ids){ids>>>=0;for(var i=0;i>>2>>>0];var transformFeedback=GL.transformFeedbacks[id];if(!transformFeedback)continue;GLctx.deleteTransformFeedback(transformFeedback);transformFeedback.name=0;GL.transformFeedbacks[id]=null}}_glDeleteTransformFeedbacks.sig="vip";var _emscripten_glDeleteTransformFeedbacks=_glDeleteTransformFeedbacks;_emscripten_glDeleteTransformFeedbacks.sig="vip";function _glDeleteVertexArrays(n,vaos){vaos>>>=0;for(var i=0;i>>2>>>0];GLctx.deleteVertexArray(GL.vaos[id]);GL.vaos[id]=null}}_glDeleteVertexArrays.sig="vip";var _emscripten_glDeleteVertexArrays=_glDeleteVertexArrays;_emscripten_glDeleteVertexArrays.sig="vip";var _glDeleteVertexArraysOES=_glDeleteVertexArrays;_glDeleteVertexArraysOES.sig="vip";var _emscripten_glDeleteVertexArraysOES=_glDeleteVertexArraysOES;_emscripten_glDeleteVertexArraysOES.sig="vip";var _glDepthFunc=x0=>GLctx.depthFunc(x0);_glDepthFunc.sig="vi";var _emscripten_glDepthFunc=_glDepthFunc;_emscripten_glDepthFunc.sig="vi";var _glDepthMask=flag=>{GLctx.depthMask(!!flag)};_glDepthMask.sig="vi";var _emscripten_glDepthMask=_glDepthMask;_emscripten_glDepthMask.sig="vi";var _glDepthRangef=(x0,x1)=>GLctx.depthRange(x0,x1);_glDepthRangef.sig="vff";var _emscripten_glDepthRangef=_glDepthRangef;_emscripten_glDepthRangef.sig="vff";var _glDetachShader=(program,shader)=>{GLctx.detachShader(GL.programs[program],GL.shaders[shader])};_glDetachShader.sig="vii";var _emscripten_glDetachShader=_glDetachShader;_emscripten_glDetachShader.sig="vii";var _glDisable=x0=>GLctx.disable(x0);_glDisable.sig="vi";var _emscripten_glDisable=_glDisable;_emscripten_glDisable.sig="vi";var _glDisableVertexAttribArray=index=>{GLctx.disableVertexAttribArray(index)};_glDisableVertexAttribArray.sig="vi";var _emscripten_glDisableVertexAttribArray=_glDisableVertexAttribArray;_emscripten_glDisableVertexAttribArray.sig="vi";var _glDrawArrays=(mode,first,count)=>{GLctx.drawArrays(mode,first,count)};_glDrawArrays.sig="viii";var _emscripten_glDrawArrays=_glDrawArrays;_emscripten_glDrawArrays.sig="viii";var _glDrawArraysInstanced=(mode,first,count,primcount)=>{GLctx.drawArraysInstanced(mode,first,count,primcount)};_glDrawArraysInstanced.sig="viiii";var _emscripten_glDrawArraysInstanced=_glDrawArraysInstanced;_emscripten_glDrawArraysInstanced.sig="viiii";var _glDrawArraysInstancedANGLE=_glDrawArraysInstanced;var _emscripten_glDrawArraysInstancedANGLE=_glDrawArraysInstancedANGLE;var _glDrawArraysInstancedARB=_glDrawArraysInstanced;var _emscripten_glDrawArraysInstancedARB=_glDrawArraysInstancedARB;var _glDrawArraysInstancedEXT=_glDrawArraysInstanced;var _emscripten_glDrawArraysInstancedEXT=_glDrawArraysInstancedEXT;var _glDrawArraysInstancedNV=_glDrawArraysInstanced;var _emscripten_glDrawArraysInstancedNV=_glDrawArraysInstancedNV;var tempFixedLengthArray=[];function _glDrawBuffers(n,bufs){bufs>>>=0;var bufArray=tempFixedLengthArray[n];for(var i=0;i>>2>>>0]}GLctx.drawBuffers(bufArray)}_glDrawBuffers.sig="vip";var _emscripten_glDrawBuffers=_glDrawBuffers;_emscripten_glDrawBuffers.sig="vip";var _glDrawBuffersEXT=_glDrawBuffers;var _emscripten_glDrawBuffersEXT=_glDrawBuffersEXT;var _glDrawBuffersWEBGL=_glDrawBuffers;var _emscripten_glDrawBuffersWEBGL=_glDrawBuffersWEBGL;function _glDrawElements(mode,count,type,indices){indices>>>=0;GLctx.drawElements(mode,count,type,indices)}_glDrawElements.sig="viiip";var _emscripten_glDrawElements=_glDrawElements;_emscripten_glDrawElements.sig="viiip";function _glDrawElementsInstanced(mode,count,type,indices,primcount){indices>>>=0;GLctx.drawElementsInstanced(mode,count,type,indices,primcount)}_glDrawElementsInstanced.sig="viiipi";var _emscripten_glDrawElementsInstanced=_glDrawElementsInstanced;_emscripten_glDrawElementsInstanced.sig="viiipi";var _glDrawElementsInstancedANGLE=_glDrawElementsInstanced;var _emscripten_glDrawElementsInstancedANGLE=_glDrawElementsInstancedANGLE;var _glDrawElementsInstancedARB=_glDrawElementsInstanced;var _emscripten_glDrawElementsInstancedARB=_glDrawElementsInstancedARB;var _glDrawElementsInstancedEXT=_glDrawElementsInstanced;var _emscripten_glDrawElementsInstancedEXT=_glDrawElementsInstancedEXT;var _glDrawElementsInstancedNV=_glDrawElementsInstanced;var _emscripten_glDrawElementsInstancedNV=_glDrawElementsInstancedNV;function _glDrawRangeElements(mode,start,end,count,type,indices){indices>>>=0;_glDrawElements(mode,count,type,indices)}_glDrawRangeElements.sig="viiiiip";var _emscripten_glDrawRangeElements=_glDrawRangeElements;_emscripten_glDrawRangeElements.sig="viiiiip";var _glEnable=x0=>GLctx.enable(x0);_glEnable.sig="vi";var _emscripten_glEnable=_glEnable;_emscripten_glEnable.sig="vi";var _glEnableVertexAttribArray=index=>{GLctx.enableVertexAttribArray(index)};_glEnableVertexAttribArray.sig="vi";var _emscripten_glEnableVertexAttribArray=_glEnableVertexAttribArray;_emscripten_glEnableVertexAttribArray.sig="vi";var _glEndQuery=x0=>GLctx.endQuery(x0);_glEndQuery.sig="vi";var _emscripten_glEndQuery=_glEndQuery;_emscripten_glEndQuery.sig="vi";var _glEndQueryEXT=target=>{GLctx.disjointTimerQueryExt["endQueryEXT"](target)};_glEndQueryEXT.sig="vi";var _emscripten_glEndQueryEXT=_glEndQueryEXT;var _glEndTransformFeedback=()=>GLctx.endTransformFeedback();_glEndTransformFeedback.sig="v";var _emscripten_glEndTransformFeedback=_glEndTransformFeedback;_emscripten_glEndTransformFeedback.sig="v";function _glFenceSync(condition,flags){var sync=GLctx.fenceSync(condition,flags);if(sync){var id=GL.getNewId(GL.syncs);sync.name=id;GL.syncs[id]=sync;return id}return 0}_glFenceSync.sig="pii";var _emscripten_glFenceSync=_glFenceSync;_emscripten_glFenceSync.sig="pii";var _glFinish=()=>GLctx.finish();_glFinish.sig="v";var _emscripten_glFinish=_glFinish;_emscripten_glFinish.sig="v";var _glFlush=()=>GLctx.flush();_glFlush.sig="v";var _emscripten_glFlush=_glFlush;_emscripten_glFlush.sig="v";var _glFramebufferRenderbuffer=(target,attachment,renderbuffertarget,renderbuffer)=>{GLctx.framebufferRenderbuffer(target,attachment,renderbuffertarget,GL.renderbuffers[renderbuffer])};_glFramebufferRenderbuffer.sig="viiii";var _emscripten_glFramebufferRenderbuffer=_glFramebufferRenderbuffer;_emscripten_glFramebufferRenderbuffer.sig="viiii";var _glFramebufferTexture2D=(target,attachment,textarget,texture,level)=>{GLctx.framebufferTexture2D(target,attachment,textarget,GL.textures[texture],level)};_glFramebufferTexture2D.sig="viiiii";var _emscripten_glFramebufferTexture2D=_glFramebufferTexture2D;_emscripten_glFramebufferTexture2D.sig="viiiii";var _glFramebufferTextureLayer=(target,attachment,texture,level,layer)=>{GLctx.framebufferTextureLayer(target,attachment,GL.textures[texture],level,layer)};_glFramebufferTextureLayer.sig="viiiii";var _emscripten_glFramebufferTextureLayer=_glFramebufferTextureLayer;_emscripten_glFramebufferTextureLayer.sig="viiiii";var _glFrontFace=x0=>GLctx.frontFace(x0);_glFrontFace.sig="vi";var _emscripten_glFrontFace=_glFrontFace;_emscripten_glFrontFace.sig="vi";function _glGenBuffers(n,buffers){buffers>>>=0;GL.genObject(n,buffers,"createBuffer",GL.buffers)}_glGenBuffers.sig="vip";var _emscripten_glGenBuffers=_glGenBuffers;_emscripten_glGenBuffers.sig="vip";function _glGenFramebuffers(n,ids){ids>>>=0;GL.genObject(n,ids,"createFramebuffer",GL.framebuffers)}_glGenFramebuffers.sig="vip";var _emscripten_glGenFramebuffers=_glGenFramebuffers;_emscripten_glGenFramebuffers.sig="vip";function _glGenQueries(n,ids){ids>>>=0;GL.genObject(n,ids,"createQuery",GL.queries)}_glGenQueries.sig="vip";var _emscripten_glGenQueries=_glGenQueries;_emscripten_glGenQueries.sig="vip";function _glGenQueriesEXT(n,ids){ids>>>=0;for(var i=0;i>>2>>>0]=0;return}var id=GL.getNewId(GL.queries);query.name=id;GL.queries[id]=query;HEAP32[ids+i*4>>>2>>>0]=id}}_glGenQueriesEXT.sig="vip";var _emscripten_glGenQueriesEXT=_glGenQueriesEXT;function _glGenRenderbuffers(n,renderbuffers){renderbuffers>>>=0;GL.genObject(n,renderbuffers,"createRenderbuffer",GL.renderbuffers)}_glGenRenderbuffers.sig="vip";var _emscripten_glGenRenderbuffers=_glGenRenderbuffers;_emscripten_glGenRenderbuffers.sig="vip";function _glGenSamplers(n,samplers){samplers>>>=0;GL.genObject(n,samplers,"createSampler",GL.samplers)}_glGenSamplers.sig="vip";var _emscripten_glGenSamplers=_glGenSamplers;_emscripten_glGenSamplers.sig="vip";function _glGenTextures(n,textures){textures>>>=0;GL.genObject(n,textures,"createTexture",GL.textures)}_glGenTextures.sig="vip";var _emscripten_glGenTextures=_glGenTextures;_emscripten_glGenTextures.sig="vip";function _glGenTransformFeedbacks(n,ids){ids>>>=0;GL.genObject(n,ids,"createTransformFeedback",GL.transformFeedbacks)}_glGenTransformFeedbacks.sig="vip";var _emscripten_glGenTransformFeedbacks=_glGenTransformFeedbacks;_emscripten_glGenTransformFeedbacks.sig="vip";function _glGenVertexArrays(n,arrays){arrays>>>=0;GL.genObject(n,arrays,"createVertexArray",GL.vaos)}_glGenVertexArrays.sig="vip";var _emscripten_glGenVertexArrays=_glGenVertexArrays;_emscripten_glGenVertexArrays.sig="vip";var _glGenVertexArraysOES=_glGenVertexArrays;_glGenVertexArraysOES.sig="vip";var _emscripten_glGenVertexArraysOES=_glGenVertexArraysOES;_emscripten_glGenVertexArraysOES.sig="vip";var _glGenerateMipmap=x0=>GLctx.generateMipmap(x0);_glGenerateMipmap.sig="vi";var _emscripten_glGenerateMipmap=_glGenerateMipmap;_emscripten_glGenerateMipmap.sig="vi";var __glGetActiveAttribOrUniform=(funcName,program,index,bufSize,length,size,type,name)=>{program=GL.programs[program];var info=GLctx[funcName](program,index);if(info){var numBytesWrittenExclNull=name&&stringToUTF8(info.name,name,bufSize);if(length)HEAP32[length>>>2>>>0]=numBytesWrittenExclNull;if(size)HEAP32[size>>>2>>>0]=info.size;if(type)HEAP32[type>>>2>>>0]=info.type}};function _glGetActiveAttrib(program,index,bufSize,length,size,type,name){length>>>=0;size>>>=0;type>>>=0;name>>>=0;return __glGetActiveAttribOrUniform("getActiveAttrib",program,index,bufSize,length,size,type,name)}_glGetActiveAttrib.sig="viiipppp";var _emscripten_glGetActiveAttrib=_glGetActiveAttrib;_emscripten_glGetActiveAttrib.sig="viiipppp";function _glGetActiveUniform(program,index,bufSize,length,size,type,name){length>>>=0;size>>>=0;type>>>=0;name>>>=0;return __glGetActiveAttribOrUniform("getActiveUniform",program,index,bufSize,length,size,type,name)}_glGetActiveUniform.sig="viiipppp";var _emscripten_glGetActiveUniform=_glGetActiveUniform;_emscripten_glGetActiveUniform.sig="viiipppp";function _glGetActiveUniformBlockName(program,uniformBlockIndex,bufSize,length,uniformBlockName){length>>>=0;uniformBlockName>>>=0;program=GL.programs[program];var result=GLctx.getActiveUniformBlockName(program,uniformBlockIndex);if(!result)return;if(uniformBlockName&&bufSize>0){var numBytesWrittenExclNull=stringToUTF8(result,uniformBlockName,bufSize);if(length)HEAP32[length>>>2>>>0]=numBytesWrittenExclNull}else{if(length)HEAP32[length>>>2>>>0]=0}}_glGetActiveUniformBlockName.sig="viiipp";var _emscripten_glGetActiveUniformBlockName=_glGetActiveUniformBlockName;_emscripten_glGetActiveUniformBlockName.sig="viiipp";function _glGetActiveUniformBlockiv(program,uniformBlockIndex,pname,params){params>>>=0;if(!params){GL.recordError(1281);return}program=GL.programs[program];if(pname==35393){var name=GLctx.getActiveUniformBlockName(program,uniformBlockIndex);HEAP32[params>>>2>>>0]=name.length+1;return}var result=GLctx.getActiveUniformBlockParameter(program,uniformBlockIndex,pname);if(result===null)return;if(pname==35395){for(var i=0;i>>2>>>0]=result[i]}}else{HEAP32[params>>>2>>>0]=result}}_glGetActiveUniformBlockiv.sig="viiip";var _emscripten_glGetActiveUniformBlockiv=_glGetActiveUniformBlockiv;_emscripten_glGetActiveUniformBlockiv.sig="viiip";function _glGetActiveUniformsiv(program,uniformCount,uniformIndices,pname,params){uniformIndices>>>=0;params>>>=0;if(!params){GL.recordError(1281);return}if(uniformCount>0&&uniformIndices==0){GL.recordError(1281);return}program=GL.programs[program];var ids=[];for(var i=0;i>>2>>>0])}var result=GLctx.getActiveUniforms(program,ids,pname);if(!result)return;var len=result.length;for(var i=0;i>>2>>>0]=result[i]}}_glGetActiveUniformsiv.sig="viipip";var _emscripten_glGetActiveUniformsiv=_glGetActiveUniformsiv;_emscripten_glGetActiveUniformsiv.sig="viipip";function _glGetAttachedShaders(program,maxCount,count,shaders){count>>>=0;shaders>>>=0;var result=GLctx.getAttachedShaders(GL.programs[program]);var len=result.length;if(len>maxCount){len=maxCount}HEAP32[count>>>2>>>0]=len;for(var i=0;i>>2>>>0]=id}}_glGetAttachedShaders.sig="viipp";var _emscripten_glGetAttachedShaders=_glGetAttachedShaders;_emscripten_glGetAttachedShaders.sig="viipp";function _glGetAttribLocation(program,name){name>>>=0;return GLctx.getAttribLocation(GL.programs[program],UTF8ToString(name))}_glGetAttribLocation.sig="iip";var _emscripten_glGetAttribLocation=_glGetAttribLocation;_emscripten_glGetAttribLocation.sig="iip";var writeI53ToI64=(ptr,num)=>{HEAPU32[ptr>>>2>>>0]=num;var lower=HEAPU32[ptr>>>2>>>0];HEAPU32[ptr+4>>>2>>>0]=(num-lower)/4294967296};var webglGetExtensions=()=>{var exts=getEmscriptenSupportedExtensions(GLctx);exts=exts.concat(exts.map(e=>"GL_"+e));return exts};var emscriptenWebGLGet=(name_,p,type)=>{if(!p){GL.recordError(1281);return}var ret=undefined;switch(name_){case 36346:ret=1;break;case 36344:if(type!=0&&type!=1){GL.recordError(1280)}return;case 34814:case 36345:ret=0;break;case 34466:var formats=GLctx.getParameter(34467);ret=formats?formats.length:0;break;case 33309:if(GL.currentContext.version<2){GL.recordError(1282);return}ret=webglGetExtensions().length;break;case 33307:case 33308:if(GL.currentContext.version<2){GL.recordError(1280);return}ret=name_==33307?3:0;break}if(ret===undefined){var result=GLctx.getParameter(name_);switch(typeof result){case"number":ret=result;break;case"boolean":ret=result?1:0;break;case"string":GL.recordError(1280);return;case"object":if(result===null){switch(name_){case 34964:case 35725:case 34965:case 36006:case 36007:case 32873:case 34229:case 36662:case 36663:case 35053:case 35055:case 36010:case 35097:case 35869:case 32874:case 36389:case 35983:case 35368:case 34068:{ret=0;break}default:{GL.recordError(1280);return}}}else if(result instanceof Float32Array||result instanceof Uint32Array||result instanceof Int32Array||result instanceof Array){for(var i=0;i>>2>>>0]=result[i];break;case 2:HEAPF32[p+i*4>>>2>>>0]=result[i];break;case 4:HEAP8[p+i>>>0]=result[i]?1:0;break}}return}else{try{ret=result.name|0}catch(e){GL.recordError(1280);err(`GL_INVALID_ENUM in glGet${type}v: Unknown object returned from WebGL getParameter(${name_})! (error: ${e})`);return}}break;default:GL.recordError(1280);err(`GL_INVALID_ENUM in glGet${type}v: Native code calling glGet${type}v(${name_}) and it returns ${result} of type ${typeof result}!`);return}}switch(type){case 1:writeI53ToI64(p,ret);break;case 0:HEAP32[p>>>2>>>0]=ret;break;case 2:HEAPF32[p>>>2>>>0]=ret;break;case 4:HEAP8[p>>>0]=ret?1:0;break}};function _glGetBooleanv(name_,p){p>>>=0;return emscriptenWebGLGet(name_,p,4)}_glGetBooleanv.sig="vip";var _emscripten_glGetBooleanv=_glGetBooleanv;_emscripten_glGetBooleanv.sig="vip";function _glGetBufferParameteri64v(target,value,data){data>>>=0;if(!data){GL.recordError(1281);return}writeI53ToI64(data,GLctx.getBufferParameter(target,value))}_glGetBufferParameteri64v.sig="viip";var _emscripten_glGetBufferParameteri64v=_glGetBufferParameteri64v;_emscripten_glGetBufferParameteri64v.sig="viip";function _glGetBufferParameteriv(target,value,data){data>>>=0;if(!data){GL.recordError(1281);return}HEAP32[data>>>2>>>0]=GLctx.getBufferParameter(target,value)}_glGetBufferParameteriv.sig="viip";var _emscripten_glGetBufferParameteriv=_glGetBufferParameteriv;_emscripten_glGetBufferParameteriv.sig="viip";var _glGetError=()=>{var error=GLctx.getError()||GL.lastError;GL.lastError=0;return error};_glGetError.sig="i";var _emscripten_glGetError=_glGetError;_emscripten_glGetError.sig="i";function _glGetFloatv(name_,p){p>>>=0;return emscriptenWebGLGet(name_,p,2)}_glGetFloatv.sig="vip";var _emscripten_glGetFloatv=_glGetFloatv;_emscripten_glGetFloatv.sig="vip";function _glGetFragDataLocation(program,name){name>>>=0;return GLctx.getFragDataLocation(GL.programs[program],UTF8ToString(name))}_glGetFragDataLocation.sig="iip";var _emscripten_glGetFragDataLocation=_glGetFragDataLocation;_emscripten_glGetFragDataLocation.sig="iip";function _glGetFramebufferAttachmentParameteriv(target,attachment,pname,params){params>>>=0;var result=GLctx.getFramebufferAttachmentParameter(target,attachment,pname);if(result instanceof WebGLRenderbuffer||result instanceof WebGLTexture){result=result.name|0}HEAP32[params>>>2>>>0]=result}_glGetFramebufferAttachmentParameteriv.sig="viiip";var _emscripten_glGetFramebufferAttachmentParameteriv=_glGetFramebufferAttachmentParameteriv;_emscripten_glGetFramebufferAttachmentParameteriv.sig="viiip";var emscriptenWebGLGetIndexed=(target,index,data,type)=>{if(!data){GL.recordError(1281);return}var result=GLctx.getIndexedParameter(target,index);var ret;switch(typeof result){case"boolean":ret=result?1:0;break;case"number":ret=result;break;case"object":if(result===null){switch(target){case 35983:case 35368:ret=0;break;default:{GL.recordError(1280);return}}}else if(result instanceof WebGLBuffer){ret=result.name|0}else{GL.recordError(1280);return}break;default:GL.recordError(1280);return}switch(type){case 1:writeI53ToI64(data,ret);break;case 0:HEAP32[data>>>2>>>0]=ret;break;case 2:HEAPF32[data>>>2>>>0]=ret;break;case 4:HEAP8[data>>>0]=ret?1:0;break;default:throw"internal emscriptenWebGLGetIndexed() error, bad type: "+type}};function _glGetInteger64i_v(target,index,data){data>>>=0;return emscriptenWebGLGetIndexed(target,index,data,1)}_glGetInteger64i_v.sig="viip";var _emscripten_glGetInteger64i_v=_glGetInteger64i_v;_emscripten_glGetInteger64i_v.sig="viip";function _glGetInteger64v(name_,p){p>>>=0;emscriptenWebGLGet(name_,p,1)}_glGetInteger64v.sig="vip";var _emscripten_glGetInteger64v=_glGetInteger64v;_emscripten_glGetInteger64v.sig="vip";function _glGetIntegeri_v(target,index,data){data>>>=0;return emscriptenWebGLGetIndexed(target,index,data,0)}_glGetIntegeri_v.sig="viip";var _emscripten_glGetIntegeri_v=_glGetIntegeri_v;_emscripten_glGetIntegeri_v.sig="viip";function _glGetIntegerv(name_,p){p>>>=0;return emscriptenWebGLGet(name_,p,0)}_glGetIntegerv.sig="vip";var _emscripten_glGetIntegerv=_glGetIntegerv;_emscripten_glGetIntegerv.sig="vip";function _glGetInternalformativ(target,internalformat,pname,bufSize,params){params>>>=0;if(bufSize<0){GL.recordError(1281);return}if(!params){GL.recordError(1281);return}var ret=GLctx.getInternalformatParameter(target,internalformat,pname);if(ret===null)return;for(var i=0;i>>2>>>0]=ret[i]}}_glGetInternalformativ.sig="viiiip";var _emscripten_glGetInternalformativ=_glGetInternalformativ;_emscripten_glGetInternalformativ.sig="viiiip";function _glGetProgramBinary(program,bufSize,length,binaryFormat,binary){length>>>=0;binaryFormat>>>=0;binary>>>=0;GL.recordError(1282)}_glGetProgramBinary.sig="viippp";var _emscripten_glGetProgramBinary=_glGetProgramBinary;_emscripten_glGetProgramBinary.sig="viippp";function _glGetProgramInfoLog(program,maxLength,length,infoLog){length>>>=0;infoLog>>>=0;var log=GLctx.getProgramInfoLog(GL.programs[program]);if(log===null)log="(unknown error)";var numBytesWrittenExclNull=maxLength>0&&infoLog?stringToUTF8(log,infoLog,maxLength):0;if(length)HEAP32[length>>>2>>>0]=numBytesWrittenExclNull}_glGetProgramInfoLog.sig="viipp";var _emscripten_glGetProgramInfoLog=_glGetProgramInfoLog;_emscripten_glGetProgramInfoLog.sig="viipp";function _glGetProgramiv(program,pname,p){p>>>=0;if(!p){GL.recordError(1281);return}if(program>=GL.counter){GL.recordError(1281);return}program=GL.programs[program];if(pname==35716){var log=GLctx.getProgramInfoLog(program);if(log===null)log="(unknown error)";HEAP32[p>>>2>>>0]=log.length+1}else if(pname==35719){if(!program.maxUniformLength){var numActiveUniforms=GLctx.getProgramParameter(program,35718);for(var i=0;i>>2>>>0]=program.maxUniformLength}else if(pname==35722){if(!program.maxAttributeLength){var numActiveAttributes=GLctx.getProgramParameter(program,35721);for(var i=0;i>>2>>>0]=program.maxAttributeLength}else if(pname==35381){if(!program.maxUniformBlockNameLength){var numActiveUniformBlocks=GLctx.getProgramParameter(program,35382);for(var i=0;i>>2>>>0]=program.maxUniformBlockNameLength}else{HEAP32[p>>>2>>>0]=GLctx.getProgramParameter(program,pname)}}_glGetProgramiv.sig="viip";var _emscripten_glGetProgramiv=_glGetProgramiv;_emscripten_glGetProgramiv.sig="viip";function _glGetQueryObjecti64vEXT(id,pname,params){params>>>=0;if(!params){GL.recordError(1281);return}var query=GL.queries[id];var param;if(GL.currentContext.version<2){param=GLctx.disjointTimerQueryExt["getQueryObjectEXT"](query,pname)}else{param=GLctx.getQueryParameter(query,pname)}var ret;if(typeof param=="boolean"){ret=param?1:0}else{ret=param}writeI53ToI64(params,ret)}_glGetQueryObjecti64vEXT.sig="viip";var _emscripten_glGetQueryObjecti64vEXT=_glGetQueryObjecti64vEXT;function _glGetQueryObjectivEXT(id,pname,params){params>>>=0;if(!params){GL.recordError(1281);return}var query=GL.queries[id];var param=GLctx.disjointTimerQueryExt["getQueryObjectEXT"](query,pname);var ret;if(typeof param=="boolean"){ret=param?1:0}else{ret=param}HEAP32[params>>>2>>>0]=ret}_glGetQueryObjectivEXT.sig="viip";var _emscripten_glGetQueryObjectivEXT=_glGetQueryObjectivEXT;var _glGetQueryObjectui64vEXT=_glGetQueryObjecti64vEXT;var _emscripten_glGetQueryObjectui64vEXT=_glGetQueryObjectui64vEXT;function _glGetQueryObjectuiv(id,pname,params){params>>>=0;if(!params){GL.recordError(1281);return}var query=GL.queries[id];var param=GLctx.getQueryParameter(query,pname);var ret;if(typeof param=="boolean"){ret=param?1:0}else{ret=param}HEAP32[params>>>2>>>0]=ret}_glGetQueryObjectuiv.sig="viip";var _emscripten_glGetQueryObjectuiv=_glGetQueryObjectuiv;_emscripten_glGetQueryObjectuiv.sig="viip";var _glGetQueryObjectuivEXT=_glGetQueryObjectivEXT;var _emscripten_glGetQueryObjectuivEXT=_glGetQueryObjectuivEXT;function _glGetQueryiv(target,pname,params){params>>>=0;if(!params){GL.recordError(1281);return}HEAP32[params>>>2>>>0]=GLctx.getQuery(target,pname)}_glGetQueryiv.sig="viip";var _emscripten_glGetQueryiv=_glGetQueryiv;_emscripten_glGetQueryiv.sig="viip";function _glGetQueryivEXT(target,pname,params){params>>>=0;if(!params){GL.recordError(1281);return}HEAP32[params>>>2>>>0]=GLctx.disjointTimerQueryExt["getQueryEXT"](target,pname)}_glGetQueryivEXT.sig="viip";var _emscripten_glGetQueryivEXT=_glGetQueryivEXT;function _glGetRenderbufferParameteriv(target,pname,params){params>>>=0;if(!params){GL.recordError(1281);return}HEAP32[params>>>2>>>0]=GLctx.getRenderbufferParameter(target,pname)}_glGetRenderbufferParameteriv.sig="viip";var _emscripten_glGetRenderbufferParameteriv=_glGetRenderbufferParameteriv;_emscripten_glGetRenderbufferParameteriv.sig="viip";function _glGetSamplerParameterfv(sampler,pname,params){params>>>=0;if(!params){GL.recordError(1281);return}HEAPF32[params>>>2>>>0]=GLctx.getSamplerParameter(GL.samplers[sampler],pname)}_glGetSamplerParameterfv.sig="viip";var _emscripten_glGetSamplerParameterfv=_glGetSamplerParameterfv;_emscripten_glGetSamplerParameterfv.sig="viip";function _glGetSamplerParameteriv(sampler,pname,params){params>>>=0;if(!params){GL.recordError(1281);return}HEAP32[params>>>2>>>0]=GLctx.getSamplerParameter(GL.samplers[sampler],pname)}_glGetSamplerParameteriv.sig="viip";var _emscripten_glGetSamplerParameteriv=_glGetSamplerParameteriv;_emscripten_glGetSamplerParameteriv.sig="viip";function _glGetShaderInfoLog(shader,maxLength,length,infoLog){length>>>=0;infoLog>>>=0;var log=GLctx.getShaderInfoLog(GL.shaders[shader]);if(log===null)log="(unknown error)";var numBytesWrittenExclNull=maxLength>0&&infoLog?stringToUTF8(log,infoLog,maxLength):0;if(length)HEAP32[length>>>2>>>0]=numBytesWrittenExclNull}_glGetShaderInfoLog.sig="viipp";var _emscripten_glGetShaderInfoLog=_glGetShaderInfoLog;_emscripten_glGetShaderInfoLog.sig="viipp";function _glGetShaderPrecisionFormat(shaderType,precisionType,range,precision){range>>>=0;precision>>>=0;var result=GLctx.getShaderPrecisionFormat(shaderType,precisionType);HEAP32[range>>>2>>>0]=result.rangeMin;HEAP32[range+4>>>2>>>0]=result.rangeMax;HEAP32[precision>>>2>>>0]=result.precision}_glGetShaderPrecisionFormat.sig="viipp";var _emscripten_glGetShaderPrecisionFormat=_glGetShaderPrecisionFormat;_emscripten_glGetShaderPrecisionFormat.sig="viipp";function _glGetShaderSource(shader,bufSize,length,source){length>>>=0;source>>>=0;var result=GLctx.getShaderSource(GL.shaders[shader]);if(!result)return;var numBytesWrittenExclNull=bufSize>0&&source?stringToUTF8(result,source,bufSize):0;if(length)HEAP32[length>>>2>>>0]=numBytesWrittenExclNull}_glGetShaderSource.sig="viipp";var _emscripten_glGetShaderSource=_glGetShaderSource;_emscripten_glGetShaderSource.sig="viipp";function _glGetShaderiv(shader,pname,p){p>>>=0;if(!p){GL.recordError(1281);return}if(pname==35716){var log=GLctx.getShaderInfoLog(GL.shaders[shader]);if(log===null)log="(unknown error)";var logLength=log?log.length+1:0;HEAP32[p>>>2>>>0]=logLength}else if(pname==35720){var source=GLctx.getShaderSource(GL.shaders[shader]);var sourceLength=source?source.length+1:0;HEAP32[p>>>2>>>0]=sourceLength}else{HEAP32[p>>>2>>>0]=GLctx.getShaderParameter(GL.shaders[shader],pname)}}_glGetShaderiv.sig="viip";var _emscripten_glGetShaderiv=_glGetShaderiv;_emscripten_glGetShaderiv.sig="viip";var stringToNewUTF8=str=>{var size=lengthBytesUTF8(str)+1;var ret=_malloc(size);if(ret)stringToUTF8(str,ret,size);return ret};function _glGetString(name_){var ret=GL.stringCache[name_];if(!ret){switch(name_){case 7939:ret=stringToNewUTF8(webglGetExtensions().join(" "));break;case 7936:case 7937:case 37445:case 37446:var s=GLctx.getParameter(name_);if(!s){GL.recordError(1280)}ret=s?stringToNewUTF8(s):0;break;case 7938:var webGLVersion=GLctx.getParameter(7938);var glVersion=`OpenGL ES 2.0 (${webGLVersion})`;if(GL.currentContext.version>=2)glVersion=`OpenGL ES 3.0 (${webGLVersion})`;ret=stringToNewUTF8(glVersion);break;case 35724:var glslVersion=GLctx.getParameter(35724);var ver_re=/^WebGL GLSL ES ([0-9]\.[0-9][0-9]?)(?:$| .*)/;var ver_num=glslVersion.match(ver_re);if(ver_num!==null){if(ver_num[1].length==3)ver_num[1]=ver_num[1]+"0";glslVersion=`OpenGL ES GLSL ES ${ver_num[1]} (${glslVersion})`}ret=stringToNewUTF8(glslVersion);break;default:GL.recordError(1280)}GL.stringCache[name_]=ret}return ret}_glGetString.sig="pi";var _emscripten_glGetString=_glGetString;_emscripten_glGetString.sig="pi";function _glGetStringi(name,index){if(GL.currentContext.version<2){GL.recordError(1282);return 0}var stringiCache=GL.stringiCache[name];if(stringiCache){if(index<0||index>=stringiCache.length){GL.recordError(1281);return 0}return stringiCache[index]}switch(name){case 7939:var exts=webglGetExtensions().map(stringToNewUTF8);stringiCache=GL.stringiCache[name]=exts;if(index<0||index>=stringiCache.length){GL.recordError(1281);return 0}return stringiCache[index];default:GL.recordError(1280);return 0}}_glGetStringi.sig="pii";var _emscripten_glGetStringi=_glGetStringi;_emscripten_glGetStringi.sig="pii";function _glGetSynciv(sync,pname,bufSize,length,values){sync>>>=0;length>>>=0;values>>>=0;if(bufSize<0){GL.recordError(1281);return}if(!values){GL.recordError(1281);return}var ret=GLctx.getSyncParameter(GL.syncs[sync],pname);if(ret!==null){HEAP32[values>>>2>>>0]=ret;if(length)HEAP32[length>>>2>>>0]=1}}_glGetSynciv.sig="vpiipp";var _emscripten_glGetSynciv=_glGetSynciv;_emscripten_glGetSynciv.sig="vpiipp";function _glGetTexParameterfv(target,pname,params){params>>>=0;if(!params){GL.recordError(1281);return}HEAPF32[params>>>2>>>0]=GLctx.getTexParameter(target,pname)}_glGetTexParameterfv.sig="viip";var _emscripten_glGetTexParameterfv=_glGetTexParameterfv;_emscripten_glGetTexParameterfv.sig="viip";function _glGetTexParameteriv(target,pname,params){params>>>=0;if(!params){GL.recordError(1281);return}HEAP32[params>>>2>>>0]=GLctx.getTexParameter(target,pname)}_glGetTexParameteriv.sig="viip";var _emscripten_glGetTexParameteriv=_glGetTexParameteriv;_emscripten_glGetTexParameteriv.sig="viip";function _glGetTransformFeedbackVarying(program,index,bufSize,length,size,type,name){length>>>=0;size>>>=0;type>>>=0;name>>>=0;program=GL.programs[program];var info=GLctx.getTransformFeedbackVarying(program,index);if(!info)return;if(name&&bufSize>0){var numBytesWrittenExclNull=stringToUTF8(info.name,name,bufSize);if(length)HEAP32[length>>>2>>>0]=numBytesWrittenExclNull}else{if(length)HEAP32[length>>>2>>>0]=0}if(size)HEAP32[size>>>2>>>0]=info.size;if(type)HEAP32[type>>>2>>>0]=info.type}_glGetTransformFeedbackVarying.sig="viiipppp";var _emscripten_glGetTransformFeedbackVarying=_glGetTransformFeedbackVarying;_emscripten_glGetTransformFeedbackVarying.sig="viiipppp";function _glGetUniformBlockIndex(program,uniformBlockName){uniformBlockName>>>=0;return GLctx.getUniformBlockIndex(GL.programs[program],UTF8ToString(uniformBlockName))}_glGetUniformBlockIndex.sig="iip";var _emscripten_glGetUniformBlockIndex=_glGetUniformBlockIndex;_emscripten_glGetUniformBlockIndex.sig="iip";function _glGetUniformIndices(program,uniformCount,uniformNames,uniformIndices){uniformNames>>>=0;uniformIndices>>>=0;if(!uniformIndices){GL.recordError(1281);return}if(uniformCount>0&&(uniformNames==0||uniformIndices==0)){GL.recordError(1281);return}program=GL.programs[program];var names=[];for(var i=0;i>>2>>>0]));var result=GLctx.getUniformIndices(program,names);if(!result)return;var len=result.length;for(var i=0;i>>2>>>0]=result[i]}}_glGetUniformIndices.sig="viipp";var _emscripten_glGetUniformIndices=_glGetUniformIndices;_emscripten_glGetUniformIndices.sig="viipp";var jstoi_q=str=>parseInt(str);var webglGetLeftBracePos=name=>name.slice(-1)=="]"&&name.lastIndexOf("[");var webglPrepareUniformLocationsBeforeFirstUse=program=>{var uniformLocsById=program.uniformLocsById,uniformSizeAndIdsByName=program.uniformSizeAndIdsByName,i,j;if(!uniformLocsById){program.uniformLocsById=uniformLocsById={};program.uniformArrayNamesById={};var numActiveUniforms=GLctx.getProgramParameter(program,35718);for(i=0;i0?nm.slice(0,lb):nm;var id=program.uniformIdCounter;program.uniformIdCounter+=sz;uniformSizeAndIdsByName[arrayName]=[sz,id];for(j=0;j>>=0;name=UTF8ToString(name);if(program=GL.programs[program]){webglPrepareUniformLocationsBeforeFirstUse(program);var uniformLocsById=program.uniformLocsById;var arrayIndex=0;var uniformBaseName=name;var leftBrace=webglGetLeftBracePos(name);if(leftBrace>0){arrayIndex=jstoi_q(name.slice(leftBrace+1))>>>0;uniformBaseName=name.slice(0,leftBrace)}var sizeAndId=program.uniformSizeAndIdsByName[uniformBaseName];if(sizeAndId&&arrayIndex{var p=GLctx.currentProgram;if(p){var webglLoc=p.uniformLocsById[location];if(typeof webglLoc=="number"){p.uniformLocsById[location]=webglLoc=GLctx.getUniformLocation(p,p.uniformArrayNamesById[location]+(webglLoc>0?`[${webglLoc}]`:""))}return webglLoc}else{GL.recordError(1282)}};var emscriptenWebGLGetUniform=(program,location,params,type)=>{if(!params){GL.recordError(1281);return}program=GL.programs[program];webglPrepareUniformLocationsBeforeFirstUse(program);var data=GLctx.getUniform(program,webglGetUniformLocation(location));if(typeof data=="number"||typeof data=="boolean"){switch(type){case 0:HEAP32[params>>>2>>>0]=data;break;case 2:HEAPF32[params>>>2>>>0]=data;break}}else{for(var i=0;i>>2>>>0]=data[i];break;case 2:HEAPF32[params+i*4>>>2>>>0]=data[i];break}}}};function _glGetUniformfv(program,location,params){params>>>=0;emscriptenWebGLGetUniform(program,location,params,2)}_glGetUniformfv.sig="viip";var _emscripten_glGetUniformfv=_glGetUniformfv;_emscripten_glGetUniformfv.sig="viip";function _glGetUniformiv(program,location,params){params>>>=0;emscriptenWebGLGetUniform(program,location,params,0)}_glGetUniformiv.sig="viip";var _emscripten_glGetUniformiv=_glGetUniformiv;_emscripten_glGetUniformiv.sig="viip";function _glGetUniformuiv(program,location,params){params>>>=0;return emscriptenWebGLGetUniform(program,location,params,0)}_glGetUniformuiv.sig="viip";var _emscripten_glGetUniformuiv=_glGetUniformuiv;_emscripten_glGetUniformuiv.sig="viip";var emscriptenWebGLGetVertexAttrib=(index,pname,params,type)=>{if(!params){GL.recordError(1281);return}var data=GLctx.getVertexAttrib(index,pname);if(pname==34975){HEAP32[params>>>2>>>0]=data&&data["name"]}else if(typeof data=="number"||typeof data=="boolean"){switch(type){case 0:HEAP32[params>>>2>>>0]=data;break;case 2:HEAPF32[params>>>2>>>0]=data;break;case 5:HEAP32[params>>>2>>>0]=Math.fround(data);break}}else{for(var i=0;i>>2>>>0]=data[i];break;case 2:HEAPF32[params+i*4>>>2>>>0]=data[i];break;case 5:HEAP32[params+i*4>>>2>>>0]=Math.fround(data[i]);break}}}};function _glGetVertexAttribIiv(index,pname,params){params>>>=0;emscriptenWebGLGetVertexAttrib(index,pname,params,0)}_glGetVertexAttribIiv.sig="viip";var _emscripten_glGetVertexAttribIiv=_glGetVertexAttribIiv;_emscripten_glGetVertexAttribIiv.sig="viip";var _glGetVertexAttribIuiv=_glGetVertexAttribIiv;_glGetVertexAttribIuiv.sig="viip";var _emscripten_glGetVertexAttribIuiv=_glGetVertexAttribIuiv;_emscripten_glGetVertexAttribIuiv.sig="viip";function _glGetVertexAttribPointerv(index,pname,pointer){pointer>>>=0;if(!pointer){GL.recordError(1281);return}HEAP32[pointer>>>2>>>0]=GLctx.getVertexAttribOffset(index,pname)}_glGetVertexAttribPointerv.sig="viip";var _emscripten_glGetVertexAttribPointerv=_glGetVertexAttribPointerv;_emscripten_glGetVertexAttribPointerv.sig="viip";function _glGetVertexAttribfv(index,pname,params){params>>>=0;emscriptenWebGLGetVertexAttrib(index,pname,params,2)}_glGetVertexAttribfv.sig="viip";var _emscripten_glGetVertexAttribfv=_glGetVertexAttribfv;_emscripten_glGetVertexAttribfv.sig="viip";function _glGetVertexAttribiv(index,pname,params){params>>>=0;emscriptenWebGLGetVertexAttrib(index,pname,params,5)}_glGetVertexAttribiv.sig="viip";var _emscripten_glGetVertexAttribiv=_glGetVertexAttribiv;_emscripten_glGetVertexAttribiv.sig="viip";var _glHint=(x0,x1)=>GLctx.hint(x0,x1);_glHint.sig="vii";var _emscripten_glHint=_glHint;_emscripten_glHint.sig="vii";function _glInvalidateFramebuffer(target,numAttachments,attachments){attachments>>>=0;var list=tempFixedLengthArray[numAttachments];for(var i=0;i>>2>>>0]}GLctx.invalidateFramebuffer(target,list)}_glInvalidateFramebuffer.sig="viip";var _emscripten_glInvalidateFramebuffer=_glInvalidateFramebuffer;_emscripten_glInvalidateFramebuffer.sig="viip";function _glInvalidateSubFramebuffer(target,numAttachments,attachments,x,y,width,height){attachments>>>=0;var list=tempFixedLengthArray[numAttachments];for(var i=0;i>>2>>>0]}GLctx.invalidateSubFramebuffer(target,list,x,y,width,height)}_glInvalidateSubFramebuffer.sig="viipiiii";var _emscripten_glInvalidateSubFramebuffer=_glInvalidateSubFramebuffer;_emscripten_glInvalidateSubFramebuffer.sig="viipiiii";var _glIsBuffer=buffer=>{var b=GL.buffers[buffer];if(!b)return 0;return GLctx.isBuffer(b)};_glIsBuffer.sig="ii";var _emscripten_glIsBuffer=_glIsBuffer;_emscripten_glIsBuffer.sig="ii";var _glIsEnabled=x0=>GLctx.isEnabled(x0);_glIsEnabled.sig="ii";var _emscripten_glIsEnabled=_glIsEnabled;_emscripten_glIsEnabled.sig="ii";var _glIsFramebuffer=framebuffer=>{var fb=GL.framebuffers[framebuffer];if(!fb)return 0;return GLctx.isFramebuffer(fb)};_glIsFramebuffer.sig="ii";var _emscripten_glIsFramebuffer=_glIsFramebuffer;_emscripten_glIsFramebuffer.sig="ii";var _glIsProgram=program=>{program=GL.programs[program];if(!program)return 0;return GLctx.isProgram(program)};_glIsProgram.sig="ii";var _emscripten_glIsProgram=_glIsProgram;_emscripten_glIsProgram.sig="ii";var _glIsQuery=id=>{var query=GL.queries[id];if(!query)return 0;return GLctx.isQuery(query)};_glIsQuery.sig="ii";var _emscripten_glIsQuery=_glIsQuery;_emscripten_glIsQuery.sig="ii";var _glIsQueryEXT=id=>{var query=GL.queries[id];if(!query)return 0;return GLctx.disjointTimerQueryExt["isQueryEXT"](query)};_glIsQueryEXT.sig="ii";var _emscripten_glIsQueryEXT=_glIsQueryEXT;var _glIsRenderbuffer=renderbuffer=>{var rb=GL.renderbuffers[renderbuffer];if(!rb)return 0;return GLctx.isRenderbuffer(rb)};_glIsRenderbuffer.sig="ii";var _emscripten_glIsRenderbuffer=_glIsRenderbuffer;_emscripten_glIsRenderbuffer.sig="ii";var _glIsSampler=id=>{var sampler=GL.samplers[id];if(!sampler)return 0;return GLctx.isSampler(sampler)};_glIsSampler.sig="ii";var _emscripten_glIsSampler=_glIsSampler;_emscripten_glIsSampler.sig="ii";var _glIsShader=shader=>{var s=GL.shaders[shader];if(!s)return 0;return GLctx.isShader(s)};_glIsShader.sig="ii";var _emscripten_glIsShader=_glIsShader;_emscripten_glIsShader.sig="ii";function _glIsSync(sync){sync>>>=0;return GLctx.isSync(GL.syncs[sync])}_glIsSync.sig="ip";var _emscripten_glIsSync=_glIsSync;_emscripten_glIsSync.sig="ip";var _glIsTexture=id=>{var texture=GL.textures[id];if(!texture)return 0;return GLctx.isTexture(texture)};_glIsTexture.sig="ii";var _emscripten_glIsTexture=_glIsTexture;_emscripten_glIsTexture.sig="ii";var _glIsTransformFeedback=id=>GLctx.isTransformFeedback(GL.transformFeedbacks[id]);_glIsTransformFeedback.sig="ii";var _emscripten_glIsTransformFeedback=_glIsTransformFeedback;_emscripten_glIsTransformFeedback.sig="ii";var _glIsVertexArray=array=>{var vao=GL.vaos[array];if(!vao)return 0;return GLctx.isVertexArray(vao)};_glIsVertexArray.sig="ii";var _emscripten_glIsVertexArray=_glIsVertexArray;_emscripten_glIsVertexArray.sig="ii";var _glIsVertexArrayOES=_glIsVertexArray;_glIsVertexArrayOES.sig="ii";var _emscripten_glIsVertexArrayOES=_glIsVertexArrayOES;_emscripten_glIsVertexArrayOES.sig="ii";var _glLineWidth=x0=>GLctx.lineWidth(x0);_glLineWidth.sig="vf";var _emscripten_glLineWidth=_glLineWidth;_emscripten_glLineWidth.sig="vf";var _glLinkProgram=program=>{program=GL.programs[program];GLctx.linkProgram(program);program.uniformLocsById=0;program.uniformSizeAndIdsByName={}};_glLinkProgram.sig="vi";var _emscripten_glLinkProgram=_glLinkProgram;_emscripten_glLinkProgram.sig="vi";var _glPauseTransformFeedback=()=>GLctx.pauseTransformFeedback();_glPauseTransformFeedback.sig="v";var _emscripten_glPauseTransformFeedback=_glPauseTransformFeedback;_emscripten_glPauseTransformFeedback.sig="v";var _glPixelStorei=(pname,param)=>{if(pname==3317){GL.unpackAlignment=param}else if(pname==3314){GL.unpackRowLength=param}GLctx.pixelStorei(pname,param)};_glPixelStorei.sig="vii";var _emscripten_glPixelStorei=_glPixelStorei;_emscripten_glPixelStorei.sig="vii";var _glPolygonModeWEBGL=(face,mode)=>{GLctx.webglPolygonMode["polygonModeWEBGL"](face,mode)};_glPolygonModeWEBGL.sig="vii";var _emscripten_glPolygonModeWEBGL=_glPolygonModeWEBGL;var _glPolygonOffset=(x0,x1)=>GLctx.polygonOffset(x0,x1);_glPolygonOffset.sig="vff";var _emscripten_glPolygonOffset=_glPolygonOffset;_emscripten_glPolygonOffset.sig="vff";var _glPolygonOffsetClampEXT=(factor,units,clamp)=>{GLctx.extPolygonOffsetClamp["polygonOffsetClampEXT"](factor,units,clamp)};_glPolygonOffsetClampEXT.sig="vfff";var _emscripten_glPolygonOffsetClampEXT=_glPolygonOffsetClampEXT;function _glProgramBinary(program,binaryFormat,binary,length){binary>>>=0;GL.recordError(1280)}_glProgramBinary.sig="viipi";var _emscripten_glProgramBinary=_glProgramBinary;_emscripten_glProgramBinary.sig="viipi";var _glProgramParameteri=(program,pname,value)=>{GL.recordError(1280)};_glProgramParameteri.sig="viii";var _emscripten_glProgramParameteri=_glProgramParameteri;_emscripten_glProgramParameteri.sig="viii";var _glQueryCounterEXT=(id,target)=>{GLctx.disjointTimerQueryExt["queryCounterEXT"](GL.queries[id],target)};_glQueryCounterEXT.sig="vii";var _emscripten_glQueryCounterEXT=_glQueryCounterEXT;var _glReadBuffer=x0=>GLctx.readBuffer(x0);_glReadBuffer.sig="vi";var _emscripten_glReadBuffer=_glReadBuffer;_emscripten_glReadBuffer.sig="vi";var computeUnpackAlignedImageSize=(width,height,sizePerPixel)=>{function roundedToNextMultipleOf(x,y){return x+y-1&-y}var plainRowSize=(GL.unpackRowLength||width)*sizePerPixel;var alignedRowSize=roundedToNextMultipleOf(plainRowSize,GL.unpackAlignment);return height*alignedRowSize};var colorChannelsInGlTextureFormat=format=>{var colorChannels={5:3,6:4,8:2,29502:3,29504:4,26917:2,26918:2,29846:3,29847:4};return colorChannels[format-6402]||1};var heapObjectForWebGLType=type=>{type-=5120;if(type==0)return HEAP8;if(type==1)return HEAPU8;if(type==2)return HEAP16;if(type==4)return HEAP32;if(type==6)return HEAPF32;if(type==5||type==28922||type==28520||type==30779||type==30782)return HEAPU32;return HEAPU16};var toTypedArrayIndex=(pointer,heap)=>pointer>>>31-Math.clz32(heap.BYTES_PER_ELEMENT);var emscriptenWebGLGetTexPixelData=(type,format,width,height,pixels,internalFormat)=>{var heap=heapObjectForWebGLType(type);var sizePerPixel=colorChannelsInGlTextureFormat(format)*heap.BYTES_PER_ELEMENT;var bytes=computeUnpackAlignedImageSize(width,height,sizePerPixel);return heap.subarray(toTypedArrayIndex(pixels,heap)>>>0,toTypedArrayIndex(pixels+bytes,heap)>>>0)};function _glReadPixels(x,y,width,height,format,type,pixels){pixels>>>=0;if(GL.currentContext.version>=2){if(GLctx.currentPixelPackBufferBinding){GLctx.readPixels(x,y,width,height,format,type,pixels);return}}var pixelData=emscriptenWebGLGetTexPixelData(type,format,width,height,pixels,format);if(!pixelData){GL.recordError(1280);return}GLctx.readPixels(x,y,width,height,format,type,pixelData)}_glReadPixels.sig="viiiiiip";var _emscripten_glReadPixels=_glReadPixels;_emscripten_glReadPixels.sig="viiiiiip";var _glReleaseShaderCompiler=()=>{};_glReleaseShaderCompiler.sig="v";var _emscripten_glReleaseShaderCompiler=_glReleaseShaderCompiler;_emscripten_glReleaseShaderCompiler.sig="v";var _glRenderbufferStorage=(x0,x1,x2,x3)=>GLctx.renderbufferStorage(x0,x1,x2,x3);_glRenderbufferStorage.sig="viiii";var _emscripten_glRenderbufferStorage=_glRenderbufferStorage;_emscripten_glRenderbufferStorage.sig="viiii";var _glRenderbufferStorageMultisample=(x0,x1,x2,x3,x4)=>GLctx.renderbufferStorageMultisample(x0,x1,x2,x3,x4);_glRenderbufferStorageMultisample.sig="viiiii";var _emscripten_glRenderbufferStorageMultisample=_glRenderbufferStorageMultisample;_emscripten_glRenderbufferStorageMultisample.sig="viiiii";var _glResumeTransformFeedback=()=>GLctx.resumeTransformFeedback();_glResumeTransformFeedback.sig="v";var _emscripten_glResumeTransformFeedback=_glResumeTransformFeedback;_emscripten_glResumeTransformFeedback.sig="v";var _glSampleCoverage=(value,invert)=>{GLctx.sampleCoverage(value,!!invert)};_glSampleCoverage.sig="vfi";var _emscripten_glSampleCoverage=_glSampleCoverage;_emscripten_glSampleCoverage.sig="vfi";var _glSamplerParameterf=(sampler,pname,param)=>{GLctx.samplerParameterf(GL.samplers[sampler],pname,param)};_glSamplerParameterf.sig="viif";var _emscripten_glSamplerParameterf=_glSamplerParameterf;_emscripten_glSamplerParameterf.sig="viif";function _glSamplerParameterfv(sampler,pname,params){params>>>=0;var param=HEAPF32[params>>>2>>>0];GLctx.samplerParameterf(GL.samplers[sampler],pname,param)}_glSamplerParameterfv.sig="viip";var _emscripten_glSamplerParameterfv=_glSamplerParameterfv;_emscripten_glSamplerParameterfv.sig="viip";var _glSamplerParameteri=(sampler,pname,param)=>{GLctx.samplerParameteri(GL.samplers[sampler],pname,param)};_glSamplerParameteri.sig="viii";var _emscripten_glSamplerParameteri=_glSamplerParameteri;_emscripten_glSamplerParameteri.sig="viii";function _glSamplerParameteriv(sampler,pname,params){params>>>=0;var param=HEAP32[params>>>2>>>0];GLctx.samplerParameteri(GL.samplers[sampler],pname,param)}_glSamplerParameteriv.sig="viip";var _emscripten_glSamplerParameteriv=_glSamplerParameteriv;_emscripten_glSamplerParameteriv.sig="viip";var _glScissor=(x0,x1,x2,x3)=>GLctx.scissor(x0,x1,x2,x3);_glScissor.sig="viiii";var _emscripten_glScissor=_glScissor;_emscripten_glScissor.sig="viiii";function _glShaderBinary(count,shaders,binaryformat,binary,length){shaders>>>=0;binary>>>=0;GL.recordError(1280)}_glShaderBinary.sig="vipipi";var _emscripten_glShaderBinary=_glShaderBinary;_emscripten_glShaderBinary.sig="vipipi";function _glShaderSource(shader,count,string,length){string>>>=0;length>>>=0;var source=GL.getSource(shader,count,string,length);GLctx.shaderSource(GL.shaders[shader],source)}_glShaderSource.sig="viipp";var _emscripten_glShaderSource=_glShaderSource;_emscripten_glShaderSource.sig="viipp";var _glStencilFunc=(x0,x1,x2)=>GLctx.stencilFunc(x0,x1,x2);_glStencilFunc.sig="viii";var _emscripten_glStencilFunc=_glStencilFunc;_emscripten_glStencilFunc.sig="viii";var _glStencilFuncSeparate=(x0,x1,x2,x3)=>GLctx.stencilFuncSeparate(x0,x1,x2,x3);_glStencilFuncSeparate.sig="viiii";var _emscripten_glStencilFuncSeparate=_glStencilFuncSeparate;_emscripten_glStencilFuncSeparate.sig="viiii";var _glStencilMask=x0=>GLctx.stencilMask(x0);_glStencilMask.sig="vi";var _emscripten_glStencilMask=_glStencilMask;_emscripten_glStencilMask.sig="vi";var _glStencilMaskSeparate=(x0,x1)=>GLctx.stencilMaskSeparate(x0,x1);_glStencilMaskSeparate.sig="vii";var _emscripten_glStencilMaskSeparate=_glStencilMaskSeparate;_emscripten_glStencilMaskSeparate.sig="vii";var _glStencilOp=(x0,x1,x2)=>GLctx.stencilOp(x0,x1,x2);_glStencilOp.sig="viii";var _emscripten_glStencilOp=_glStencilOp;_emscripten_glStencilOp.sig="viii";var _glStencilOpSeparate=(x0,x1,x2,x3)=>GLctx.stencilOpSeparate(x0,x1,x2,x3);_glStencilOpSeparate.sig="viiii";var _emscripten_glStencilOpSeparate=_glStencilOpSeparate;_emscripten_glStencilOpSeparate.sig="viiii";function _glTexImage2D(target,level,internalFormat,width,height,border,format,type,pixels){pixels>>>=0;if(GL.currentContext.version>=2){if(GLctx.currentPixelUnpackBufferBinding){GLctx.texImage2D(target,level,internalFormat,width,height,border,format,type,pixels);return}}var pixelData=pixels?emscriptenWebGLGetTexPixelData(type,format,width,height,pixels,internalFormat):null;GLctx.texImage2D(target,level,internalFormat,width,height,border,format,type,pixelData)}_glTexImage2D.sig="viiiiiiiip";var _emscripten_glTexImage2D=_glTexImage2D;_emscripten_glTexImage2D.sig="viiiiiiiip";function _glTexImage3D(target,level,internalFormat,width,height,depth,border,format,type,pixels){pixels>>>=0;if(GLctx.currentPixelUnpackBufferBinding){GLctx.texImage3D(target,level,internalFormat,width,height,depth,border,format,type,pixels)}else if(pixels){var heap=heapObjectForWebGLType(type);var pixelData=emscriptenWebGLGetTexPixelData(type,format,width,height*depth,pixels,internalFormat);GLctx.texImage3D(target,level,internalFormat,width,height,depth,border,format,type,pixelData)}else{GLctx.texImage3D(target,level,internalFormat,width,height,depth,border,format,type,null)}}_glTexImage3D.sig="viiiiiiiiip";var _emscripten_glTexImage3D=_glTexImage3D;_emscripten_glTexImage3D.sig="viiiiiiiiip";var _glTexParameterf=(x0,x1,x2)=>GLctx.texParameterf(x0,x1,x2);_glTexParameterf.sig="viif";var _emscripten_glTexParameterf=_glTexParameterf;_emscripten_glTexParameterf.sig="viif";function _glTexParameterfv(target,pname,params){params>>>=0;var param=HEAPF32[params>>>2>>>0];GLctx.texParameterf(target,pname,param)}_glTexParameterfv.sig="viip";var _emscripten_glTexParameterfv=_glTexParameterfv;_emscripten_glTexParameterfv.sig="viip";var _glTexParameteri=(x0,x1,x2)=>GLctx.texParameteri(x0,x1,x2);_glTexParameteri.sig="viii";var _emscripten_glTexParameteri=_glTexParameteri;_emscripten_glTexParameteri.sig="viii";function _glTexParameteriv(target,pname,params){params>>>=0;var param=HEAP32[params>>>2>>>0];GLctx.texParameteri(target,pname,param)}_glTexParameteriv.sig="viip";var _emscripten_glTexParameteriv=_glTexParameteriv;_emscripten_glTexParameteriv.sig="viip";var _glTexStorage2D=(x0,x1,x2,x3,x4)=>GLctx.texStorage2D(x0,x1,x2,x3,x4);_glTexStorage2D.sig="viiiii";var _emscripten_glTexStorage2D=_glTexStorage2D;_emscripten_glTexStorage2D.sig="viiiii";var _glTexStorage3D=(x0,x1,x2,x3,x4,x5)=>GLctx.texStorage3D(x0,x1,x2,x3,x4,x5);_glTexStorage3D.sig="viiiiii";var _emscripten_glTexStorage3D=_glTexStorage3D;_emscripten_glTexStorage3D.sig="viiiiii";function _glTexSubImage2D(target,level,xoffset,yoffset,width,height,format,type,pixels){pixels>>>=0;if(GL.currentContext.version>=2){if(GLctx.currentPixelUnpackBufferBinding){GLctx.texSubImage2D(target,level,xoffset,yoffset,width,height,format,type,pixels);return}}var pixelData=pixels?emscriptenWebGLGetTexPixelData(type,format,width,height,pixels,0):null;GLctx.texSubImage2D(target,level,xoffset,yoffset,width,height,format,type,pixelData)}_glTexSubImage2D.sig="viiiiiiiip";var _emscripten_glTexSubImage2D=_glTexSubImage2D;_emscripten_glTexSubImage2D.sig="viiiiiiiip";function _glTexSubImage3D(target,level,xoffset,yoffset,zoffset,width,height,depth,format,type,pixels){pixels>>>=0;if(GLctx.currentPixelUnpackBufferBinding){GLctx.texSubImage3D(target,level,xoffset,yoffset,zoffset,width,height,depth,format,type,pixels)}else if(pixels){var heap=heapObjectForWebGLType(type);GLctx.texSubImage3D(target,level,xoffset,yoffset,zoffset,width,height,depth,format,type,heap,toTypedArrayIndex(pixels,heap))}else{GLctx.texSubImage3D(target,level,xoffset,yoffset,zoffset,width,height,depth,format,type,null)}}_glTexSubImage3D.sig="viiiiiiiiiip";var _emscripten_glTexSubImage3D=_glTexSubImage3D;_emscripten_glTexSubImage3D.sig="viiiiiiiiiip";function _glTransformFeedbackVaryings(program,count,varyings,bufferMode){varyings>>>=0;program=GL.programs[program];var vars=[];for(var i=0;i>>2>>>0]));GLctx.transformFeedbackVaryings(program,vars,bufferMode)}_glTransformFeedbackVaryings.sig="viipi";var _emscripten_glTransformFeedbackVaryings=_glTransformFeedbackVaryings;_emscripten_glTransformFeedbackVaryings.sig="viipi";var _glUniform1f=(location,v0)=>{GLctx.uniform1f(webglGetUniformLocation(location),v0)};_glUniform1f.sig="vif";var _emscripten_glUniform1f=_glUniform1f;_emscripten_glUniform1f.sig="vif";var miniTempWebGLFloatBuffers=[];function _glUniform1fv(location,count,value){value>>>=0;if(count<=288){var view=miniTempWebGLFloatBuffers[count];for(var i=0;i>>2>>>0]}}else{var view=HEAPF32.subarray(value>>>2>>>0,value+count*4>>>2>>>0)}GLctx.uniform1fv(webglGetUniformLocation(location),view)}_glUniform1fv.sig="viip";var _emscripten_glUniform1fv=_glUniform1fv;_emscripten_glUniform1fv.sig="viip";var _glUniform1i=(location,v0)=>{GLctx.uniform1i(webglGetUniformLocation(location),v0)};_glUniform1i.sig="vii";var _emscripten_glUniform1i=_glUniform1i;_emscripten_glUniform1i.sig="vii";var miniTempWebGLIntBuffers=[];function _glUniform1iv(location,count,value){value>>>=0;if(count<=288){var view=miniTempWebGLIntBuffers[count];for(var i=0;i>>2>>>0]}}else{var view=HEAP32.subarray(value>>>2>>>0,value+count*4>>>2>>>0)}GLctx.uniform1iv(webglGetUniformLocation(location),view)}_glUniform1iv.sig="viip";var _emscripten_glUniform1iv=_glUniform1iv;_emscripten_glUniform1iv.sig="viip";var _glUniform1ui=(location,v0)=>{GLctx.uniform1ui(webglGetUniformLocation(location),v0)};_glUniform1ui.sig="vii";var _emscripten_glUniform1ui=_glUniform1ui;_emscripten_glUniform1ui.sig="vii";function _glUniform1uiv(location,count,value){value>>>=0;count&&GLctx.uniform1uiv(webglGetUniformLocation(location),HEAPU32,value>>>2,count)}_glUniform1uiv.sig="viip";var _emscripten_glUniform1uiv=_glUniform1uiv;_emscripten_glUniform1uiv.sig="viip";var _glUniform2f=(location,v0,v1)=>{GLctx.uniform2f(webglGetUniformLocation(location),v0,v1)};_glUniform2f.sig="viff";var _emscripten_glUniform2f=_glUniform2f;_emscripten_glUniform2f.sig="viff";function _glUniform2fv(location,count,value){value>>>=0;if(count<=144){count*=2;var view=miniTempWebGLFloatBuffers[count];for(var i=0;i>>2>>>0];view[i+1]=HEAPF32[value+(4*i+4)>>>2>>>0]}}else{var view=HEAPF32.subarray(value>>>2>>>0,value+count*8>>>2>>>0)}GLctx.uniform2fv(webglGetUniformLocation(location),view)}_glUniform2fv.sig="viip";var _emscripten_glUniform2fv=_glUniform2fv;_emscripten_glUniform2fv.sig="viip";var _glUniform2i=(location,v0,v1)=>{GLctx.uniform2i(webglGetUniformLocation(location),v0,v1)};_glUniform2i.sig="viii";var _emscripten_glUniform2i=_glUniform2i;_emscripten_glUniform2i.sig="viii";function _glUniform2iv(location,count,value){value>>>=0;if(count<=144){count*=2;var view=miniTempWebGLIntBuffers[count];for(var i=0;i>>2>>>0];view[i+1]=HEAP32[value+(4*i+4)>>>2>>>0]}}else{var view=HEAP32.subarray(value>>>2>>>0,value+count*8>>>2>>>0)}GLctx.uniform2iv(webglGetUniformLocation(location),view)}_glUniform2iv.sig="viip";var _emscripten_glUniform2iv=_glUniform2iv;_emscripten_glUniform2iv.sig="viip";var _glUniform2ui=(location,v0,v1)=>{GLctx.uniform2ui(webglGetUniformLocation(location),v0,v1)};_glUniform2ui.sig="viii";var _emscripten_glUniform2ui=_glUniform2ui;_emscripten_glUniform2ui.sig="viii";function _glUniform2uiv(location,count,value){value>>>=0;count&&GLctx.uniform2uiv(webglGetUniformLocation(location),HEAPU32,value>>>2,count*2)}_glUniform2uiv.sig="viip";var _emscripten_glUniform2uiv=_glUniform2uiv;_emscripten_glUniform2uiv.sig="viip";var _glUniform3f=(location,v0,v1,v2)=>{GLctx.uniform3f(webglGetUniformLocation(location),v0,v1,v2)};_glUniform3f.sig="vifff";var _emscripten_glUniform3f=_glUniform3f;_emscripten_glUniform3f.sig="vifff";function _glUniform3fv(location,count,value){value>>>=0;if(count<=96){count*=3;var view=miniTempWebGLFloatBuffers[count];for(var i=0;i>>2>>>0];view[i+1]=HEAPF32[value+(4*i+4)>>>2>>>0];view[i+2]=HEAPF32[value+(4*i+8)>>>2>>>0]}}else{var view=HEAPF32.subarray(value>>>2>>>0,value+count*12>>>2>>>0)}GLctx.uniform3fv(webglGetUniformLocation(location),view)}_glUniform3fv.sig="viip";var _emscripten_glUniform3fv=_glUniform3fv;_emscripten_glUniform3fv.sig="viip";var _glUniform3i=(location,v0,v1,v2)=>{GLctx.uniform3i(webglGetUniformLocation(location),v0,v1,v2)};_glUniform3i.sig="viiii";var _emscripten_glUniform3i=_glUniform3i;_emscripten_glUniform3i.sig="viiii";function _glUniform3iv(location,count,value){value>>>=0;if(count<=96){count*=3;var view=miniTempWebGLIntBuffers[count];for(var i=0;i>>2>>>0];view[i+1]=HEAP32[value+(4*i+4)>>>2>>>0];view[i+2]=HEAP32[value+(4*i+8)>>>2>>>0]}}else{var view=HEAP32.subarray(value>>>2>>>0,value+count*12>>>2>>>0)}GLctx.uniform3iv(webglGetUniformLocation(location),view)}_glUniform3iv.sig="viip";var _emscripten_glUniform3iv=_glUniform3iv;_emscripten_glUniform3iv.sig="viip";var _glUniform3ui=(location,v0,v1,v2)=>{GLctx.uniform3ui(webglGetUniformLocation(location),v0,v1,v2)};_glUniform3ui.sig="viiii";var _emscripten_glUniform3ui=_glUniform3ui;_emscripten_glUniform3ui.sig="viiii";function _glUniform3uiv(location,count,value){value>>>=0;count&&GLctx.uniform3uiv(webglGetUniformLocation(location),HEAPU32,value>>>2,count*3)}_glUniform3uiv.sig="viip";var _emscripten_glUniform3uiv=_glUniform3uiv;_emscripten_glUniform3uiv.sig="viip";var _glUniform4f=(location,v0,v1,v2,v3)=>{GLctx.uniform4f(webglGetUniformLocation(location),v0,v1,v2,v3)};_glUniform4f.sig="viffff";var _emscripten_glUniform4f=_glUniform4f;_emscripten_glUniform4f.sig="viffff";function _glUniform4fv(location,count,value){value>>>=0;if(count<=72){var view=miniTempWebGLFloatBuffers[4*count];var heap=HEAPF32;value=value>>>2;count*=4;for(var i=0;i>>0];view[i+1]=heap[dst+1>>>0];view[i+2]=heap[dst+2>>>0];view[i+3]=heap[dst+3>>>0]}}else{var view=HEAPF32.subarray(value>>>2>>>0,value+count*16>>>2>>>0)}GLctx.uniform4fv(webglGetUniformLocation(location),view)}_glUniform4fv.sig="viip";var _emscripten_glUniform4fv=_glUniform4fv;_emscripten_glUniform4fv.sig="viip";var _glUniform4i=(location,v0,v1,v2,v3)=>{GLctx.uniform4i(webglGetUniformLocation(location),v0,v1,v2,v3)};_glUniform4i.sig="viiiii";var _emscripten_glUniform4i=_glUniform4i;_emscripten_glUniform4i.sig="viiiii";function _glUniform4iv(location,count,value){value>>>=0;if(count<=72){count*=4;var view=miniTempWebGLIntBuffers[count];for(var i=0;i>>2>>>0];view[i+1]=HEAP32[value+(4*i+4)>>>2>>>0];view[i+2]=HEAP32[value+(4*i+8)>>>2>>>0];view[i+3]=HEAP32[value+(4*i+12)>>>2>>>0]}}else{var view=HEAP32.subarray(value>>>2>>>0,value+count*16>>>2>>>0)}GLctx.uniform4iv(webglGetUniformLocation(location),view)}_glUniform4iv.sig="viip";var _emscripten_glUniform4iv=_glUniform4iv;_emscripten_glUniform4iv.sig="viip";var _glUniform4ui=(location,v0,v1,v2,v3)=>{GLctx.uniform4ui(webglGetUniformLocation(location),v0,v1,v2,v3)};_glUniform4ui.sig="viiiii";var _emscripten_glUniform4ui=_glUniform4ui;_emscripten_glUniform4ui.sig="viiiii";function _glUniform4uiv(location,count,value){value>>>=0;count&&GLctx.uniform4uiv(webglGetUniformLocation(location),HEAPU32,value>>>2,count*4)}_glUniform4uiv.sig="viip";var _emscripten_glUniform4uiv=_glUniform4uiv;_emscripten_glUniform4uiv.sig="viip";var _glUniformBlockBinding=(program,uniformBlockIndex,uniformBlockBinding)=>{program=GL.programs[program];GLctx.uniformBlockBinding(program,uniformBlockIndex,uniformBlockBinding)};_glUniformBlockBinding.sig="viii";var _emscripten_glUniformBlockBinding=_glUniformBlockBinding;_emscripten_glUniformBlockBinding.sig="viii";function _glUniformMatrix2fv(location,count,transpose,value){value>>>=0;if(count<=72){count*=4;var view=miniTempWebGLFloatBuffers[count];for(var i=0;i>>2>>>0];view[i+1]=HEAPF32[value+(4*i+4)>>>2>>>0];view[i+2]=HEAPF32[value+(4*i+8)>>>2>>>0];view[i+3]=HEAPF32[value+(4*i+12)>>>2>>>0]}}else{var view=HEAPF32.subarray(value>>>2>>>0,value+count*16>>>2>>>0)}GLctx.uniformMatrix2fv(webglGetUniformLocation(location),!!transpose,view)}_glUniformMatrix2fv.sig="viiip";var _emscripten_glUniformMatrix2fv=_glUniformMatrix2fv;_emscripten_glUniformMatrix2fv.sig="viiip";function _glUniformMatrix2x3fv(location,count,transpose,value){value>>>=0;count&&GLctx.uniformMatrix2x3fv(webglGetUniformLocation(location),!!transpose,HEAPF32,value>>>2,count*6)}_glUniformMatrix2x3fv.sig="viiip";var _emscripten_glUniformMatrix2x3fv=_glUniformMatrix2x3fv;_emscripten_glUniformMatrix2x3fv.sig="viiip";function _glUniformMatrix2x4fv(location,count,transpose,value){value>>>=0;count&&GLctx.uniformMatrix2x4fv(webglGetUniformLocation(location),!!transpose,HEAPF32,value>>>2,count*8)}_glUniformMatrix2x4fv.sig="viiip";var _emscripten_glUniformMatrix2x4fv=_glUniformMatrix2x4fv;_emscripten_glUniformMatrix2x4fv.sig="viiip";function _glUniformMatrix3fv(location,count,transpose,value){value>>>=0;if(count<=32){count*=9;var view=miniTempWebGLFloatBuffers[count];for(var i=0;i>>2>>>0];view[i+1]=HEAPF32[value+(4*i+4)>>>2>>>0];view[i+2]=HEAPF32[value+(4*i+8)>>>2>>>0];view[i+3]=HEAPF32[value+(4*i+12)>>>2>>>0];view[i+4]=HEAPF32[value+(4*i+16)>>>2>>>0];view[i+5]=HEAPF32[value+(4*i+20)>>>2>>>0];view[i+6]=HEAPF32[value+(4*i+24)>>>2>>>0];view[i+7]=HEAPF32[value+(4*i+28)>>>2>>>0];view[i+8]=HEAPF32[value+(4*i+32)>>>2>>>0]}}else{var view=HEAPF32.subarray(value>>>2>>>0,value+count*36>>>2>>>0)}GLctx.uniformMatrix3fv(webglGetUniformLocation(location),!!transpose,view)}_glUniformMatrix3fv.sig="viiip";var _emscripten_glUniformMatrix3fv=_glUniformMatrix3fv;_emscripten_glUniformMatrix3fv.sig="viiip";function _glUniformMatrix3x2fv(location,count,transpose,value){value>>>=0;count&&GLctx.uniformMatrix3x2fv(webglGetUniformLocation(location),!!transpose,HEAPF32,value>>>2,count*6)}_glUniformMatrix3x2fv.sig="viiip";var _emscripten_glUniformMatrix3x2fv=_glUniformMatrix3x2fv;_emscripten_glUniformMatrix3x2fv.sig="viiip";function _glUniformMatrix3x4fv(location,count,transpose,value){value>>>=0;count&&GLctx.uniformMatrix3x4fv(webglGetUniformLocation(location),!!transpose,HEAPF32,value>>>2,count*12)}_glUniformMatrix3x4fv.sig="viiip";var _emscripten_glUniformMatrix3x4fv=_glUniformMatrix3x4fv;_emscripten_glUniformMatrix3x4fv.sig="viiip";function _glUniformMatrix4fv(location,count,transpose,value){value>>>=0;if(count<=18){var view=miniTempWebGLFloatBuffers[16*count];var heap=HEAPF32;value=value>>>2;count*=16;for(var i=0;i>>0];view[i+1]=heap[dst+1>>>0];view[i+2]=heap[dst+2>>>0];view[i+3]=heap[dst+3>>>0];view[i+4]=heap[dst+4>>>0];view[i+5]=heap[dst+5>>>0];view[i+6]=heap[dst+6>>>0];view[i+7]=heap[dst+7>>>0];view[i+8]=heap[dst+8>>>0];view[i+9]=heap[dst+9>>>0];view[i+10]=heap[dst+10>>>0];view[i+11]=heap[dst+11>>>0];view[i+12]=heap[dst+12>>>0];view[i+13]=heap[dst+13>>>0];view[i+14]=heap[dst+14>>>0];view[i+15]=heap[dst+15>>>0]}}else{var view=HEAPF32.subarray(value>>>2>>>0,value+count*64>>>2>>>0)}GLctx.uniformMatrix4fv(webglGetUniformLocation(location),!!transpose,view)}_glUniformMatrix4fv.sig="viiip";var _emscripten_glUniformMatrix4fv=_glUniformMatrix4fv;_emscripten_glUniformMatrix4fv.sig="viiip";function _glUniformMatrix4x2fv(location,count,transpose,value){value>>>=0;count&&GLctx.uniformMatrix4x2fv(webglGetUniformLocation(location),!!transpose,HEAPF32,value>>>2,count*8)}_glUniformMatrix4x2fv.sig="viiip";var _emscripten_glUniformMatrix4x2fv=_glUniformMatrix4x2fv;_emscripten_glUniformMatrix4x2fv.sig="viiip";function _glUniformMatrix4x3fv(location,count,transpose,value){value>>>=0;count&&GLctx.uniformMatrix4x3fv(webglGetUniformLocation(location),!!transpose,HEAPF32,value>>>2,count*12)}_glUniformMatrix4x3fv.sig="viiip";var _emscripten_glUniformMatrix4x3fv=_glUniformMatrix4x3fv;_emscripten_glUniformMatrix4x3fv.sig="viiip";var _glUseProgram=program=>{program=GL.programs[program];GLctx.useProgram(program);GLctx.currentProgram=program};_glUseProgram.sig="vi";var _emscripten_glUseProgram=_glUseProgram;_emscripten_glUseProgram.sig="vi";var _glValidateProgram=program=>{GLctx.validateProgram(GL.programs[program])};_glValidateProgram.sig="vi";var _emscripten_glValidateProgram=_glValidateProgram;_emscripten_glValidateProgram.sig="vi";var _glVertexAttrib1f=(x0,x1)=>GLctx.vertexAttrib1f(x0,x1);_glVertexAttrib1f.sig="vif";var _emscripten_glVertexAttrib1f=_glVertexAttrib1f;_emscripten_glVertexAttrib1f.sig="vif";function _glVertexAttrib1fv(index,v){v>>>=0;GLctx.vertexAttrib1f(index,HEAPF32[v>>>2])}_glVertexAttrib1fv.sig="vip";var _emscripten_glVertexAttrib1fv=_glVertexAttrib1fv;_emscripten_glVertexAttrib1fv.sig="vip";var _glVertexAttrib2f=(x0,x1,x2)=>GLctx.vertexAttrib2f(x0,x1,x2);_glVertexAttrib2f.sig="viff";var _emscripten_glVertexAttrib2f=_glVertexAttrib2f;_emscripten_glVertexAttrib2f.sig="viff";function _glVertexAttrib2fv(index,v){v>>>=0;GLctx.vertexAttrib2f(index,HEAPF32[v>>>2],HEAPF32[v+4>>>2])}_glVertexAttrib2fv.sig="vip";var _emscripten_glVertexAttrib2fv=_glVertexAttrib2fv;_emscripten_glVertexAttrib2fv.sig="vip";var _glVertexAttrib3f=(x0,x1,x2,x3)=>GLctx.vertexAttrib3f(x0,x1,x2,x3);_glVertexAttrib3f.sig="vifff";var _emscripten_glVertexAttrib3f=_glVertexAttrib3f;_emscripten_glVertexAttrib3f.sig="vifff";function _glVertexAttrib3fv(index,v){v>>>=0;GLctx.vertexAttrib3f(index,HEAPF32[v>>>2],HEAPF32[v+4>>>2],HEAPF32[v+8>>>2])}_glVertexAttrib3fv.sig="vip";var _emscripten_glVertexAttrib3fv=_glVertexAttrib3fv;_emscripten_glVertexAttrib3fv.sig="vip";var _glVertexAttrib4f=(x0,x1,x2,x3,x4)=>GLctx.vertexAttrib4f(x0,x1,x2,x3,x4);_glVertexAttrib4f.sig="viffff";var _emscripten_glVertexAttrib4f=_glVertexAttrib4f;_emscripten_glVertexAttrib4f.sig="viffff";function _glVertexAttrib4fv(index,v){v>>>=0;GLctx.vertexAttrib4f(index,HEAPF32[v>>>2],HEAPF32[v+4>>>2],HEAPF32[v+8>>>2],HEAPF32[v+12>>>2])}_glVertexAttrib4fv.sig="vip";var _emscripten_glVertexAttrib4fv=_glVertexAttrib4fv;_emscripten_glVertexAttrib4fv.sig="vip";var _glVertexAttribDivisor=(index,divisor)=>{GLctx.vertexAttribDivisor(index,divisor)};_glVertexAttribDivisor.sig="vii";var _emscripten_glVertexAttribDivisor=_glVertexAttribDivisor;_emscripten_glVertexAttribDivisor.sig="vii";var _glVertexAttribDivisorANGLE=_glVertexAttribDivisor;var _emscripten_glVertexAttribDivisorANGLE=_glVertexAttribDivisorANGLE;var _glVertexAttribDivisorARB=_glVertexAttribDivisor;var _emscripten_glVertexAttribDivisorARB=_glVertexAttribDivisorARB;var _glVertexAttribDivisorEXT=_glVertexAttribDivisor;var _emscripten_glVertexAttribDivisorEXT=_glVertexAttribDivisorEXT;var _glVertexAttribDivisorNV=_glVertexAttribDivisor;var _emscripten_glVertexAttribDivisorNV=_glVertexAttribDivisorNV;var _glVertexAttribI4i=(x0,x1,x2,x3,x4)=>GLctx.vertexAttribI4i(x0,x1,x2,x3,x4);_glVertexAttribI4i.sig="viiiii";var _emscripten_glVertexAttribI4i=_glVertexAttribI4i;_emscripten_glVertexAttribI4i.sig="viiiii";function _glVertexAttribI4iv(index,v){v>>>=0;GLctx.vertexAttribI4i(index,HEAP32[v>>>2],HEAP32[v+4>>>2],HEAP32[v+8>>>2],HEAP32[v+12>>>2])}_glVertexAttribI4iv.sig="vip";var _emscripten_glVertexAttribI4iv=_glVertexAttribI4iv;_emscripten_glVertexAttribI4iv.sig="vip";var _glVertexAttribI4ui=(x0,x1,x2,x3,x4)=>GLctx.vertexAttribI4ui(x0,x1,x2,x3,x4);_glVertexAttribI4ui.sig="viiiii";var _emscripten_glVertexAttribI4ui=_glVertexAttribI4ui;_emscripten_glVertexAttribI4ui.sig="viiiii";function _glVertexAttribI4uiv(index,v){v>>>=0;GLctx.vertexAttribI4ui(index,HEAPU32[v>>>2],HEAPU32[v+4>>>2],HEAPU32[v+8>>>2],HEAPU32[v+12>>>2])}_glVertexAttribI4uiv.sig="vip";var _emscripten_glVertexAttribI4uiv=_glVertexAttribI4uiv;_emscripten_glVertexAttribI4uiv.sig="vip";function _glVertexAttribIPointer(index,size,type,stride,ptr){ptr>>>=0;GLctx.vertexAttribIPointer(index,size,type,stride,ptr)}_glVertexAttribIPointer.sig="viiiip";var _emscripten_glVertexAttribIPointer=_glVertexAttribIPointer;_emscripten_glVertexAttribIPointer.sig="viiiip";function _glVertexAttribPointer(index,size,type,normalized,stride,ptr){ptr>>>=0;GLctx.vertexAttribPointer(index,size,type,!!normalized,stride,ptr)}_glVertexAttribPointer.sig="viiiiip";var _emscripten_glVertexAttribPointer=_glVertexAttribPointer;_emscripten_glVertexAttribPointer.sig="viiiiip";var _glViewport=(x0,x1,x2,x3)=>GLctx.viewport(x0,x1,x2,x3);_glViewport.sig="viiii";var _emscripten_glViewport=_glViewport;_emscripten_glViewport.sig="viiii";function _glWaitSync(sync,flags,timeout){sync>>>=0;timeout=Number(timeout);GLctx.waitSync(GL.syncs[sync],flags,timeout)}_glWaitSync.sig="vpij";var _emscripten_glWaitSync=_glWaitSync;_emscripten_glWaitSync.sig="vpij";function _emscripten_out(str){str>>>=0;return out(UTF8ToString(str))}_emscripten_out.sig="vp";class HandleAllocator{allocated=[undefined];freelist=[];get(id){return this.allocated[id]}has(id){return this.allocated[id]!==undefined}allocate(handle){var id=this.freelist.pop()||this.allocated.length;this.allocated[id]=handle;return id}free(id){this.allocated[id]=undefined;this.freelist.push(id)}}var promiseMap=new HandleAllocator;var makePromise=()=>{var promiseInfo={};promiseInfo.promise=new Promise((resolve,reject)=>{promiseInfo.reject=reject;promiseInfo.resolve=resolve});promiseInfo.id=promiseMap.allocate(promiseInfo);return promiseInfo};function _emscripten_promise_create(){return makePromise().id}_emscripten_promise_create.sig="p";function _emscripten_promise_destroy(id){id>>>=0;promiseMap.free(id)}_emscripten_promise_destroy.sig="vp";var getPromise=id=>promiseMap.get(id).promise;function _emscripten_promise_resolve(id,result,value){id>>>=0;value>>>=0;var info=promiseMap.get(id);switch(result){case 0:info.resolve(value);return;case 1:info.resolve(getPromise(value));return;case 2:info.resolve(getPromise(value));_emscripten_promise_destroy(value);return;case 3:info.reject(value);return}}_emscripten_promise_resolve.sig="vpip";var growMemory=size=>{var b=wasmMemory.buffer;var pages=(size-b.byteLength+65535)/65536|0;try{wasmMemory.grow(pages);updateMemoryViews();return 1}catch(e){}};function _emscripten_resize_heap(requestedSize){requestedSize>>>=0;var oldSize=HEAPU8.length;var maxHeapSize=getHeapMax();if(requestedSize>maxHeapSize){return false}for(var cutDown=1;cutDown<=4;cutDown*=2){var overGrownHeapSize=oldSize*(1+.2/cutDown);overGrownHeapSize=Math.min(overGrownHeapSize,requestedSize+100663296);var newSize=Math.min(maxHeapSize,alignMemory(Math.max(requestedSize,overGrownHeapSize),65536));var replacement=growMemory(newSize);if(replacement){return true}}return false}_emscripten_resize_heap.sig="ip";var _emscripten_runtime_keepalive_pop=runtimeKeepalivePop;_emscripten_runtime_keepalive_pop.sig="v";var _emscripten_runtime_keepalive_push=runtimeKeepalivePush;_emscripten_runtime_keepalive_push.sig="v";var ENV={};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};function _environ_get(__environ,environ_buf){__environ>>>=0;environ_buf>>>=0;var bufSize=0;var envp=0;for(var string of getEnvStrings()){var ptr=environ_buf+bufSize;HEAPU32[__environ+envp>>>2>>>0]=ptr;bufSize+=stringToUTF8(string,ptr,Infinity)+1;envp+=4}return 0}_environ_get.sig="ipp";function _environ_sizes_get(penviron_count,penviron_buf_size){penviron_count>>>=0;penviron_buf_size>>>=0;var strings=getEnvStrings();HEAPU32[penviron_count>>>2>>>0]=strings.length;var bufSize=0;for(var string of strings){bufSize+=lengthBytesUTF8(string)+1}HEAPU32[penviron_buf_size>>>2>>>0]=bufSize;return 0}_environ_sizes_get.sig="ipp";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}}_fd_close.sig="ii";function _fd_fdstat_get(fd,pbuf){pbuf>>>=0;try{var rightsBase=0;var rightsInheriting=0;var flags=0;{var stream=SYSCALLS.getStreamFromFD(fd);var type=stream.tty?2:FS.isDir(stream.mode)?3:FS.isLink(stream.mode)?7:4}HEAP8[pbuf>>>0]=type;HEAP16[pbuf+2>>>1>>>0]=flags;HEAP64[pbuf+8>>>3>>>0]=BigInt(rightsBase);HEAP64[pbuf+16>>>3>>>0]=BigInt(rightsInheriting);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return e.errno}}_fd_fdstat_get.sig="iip";var doReadv=(stream,iov,iovcnt,offset)=>{var ret=0;for(var i=0;i>>2>>>0];var len=HEAPU32[iov+4>>>2>>>0];iov+=8;var curr=FS.read(stream,HEAP8,ptr,len,offset);if(curr<0)return-1;ret+=curr;if(curr>>=0;iovcnt>>>=0;offset=bigintToI53Checked(offset);pnum>>>=0;try{if(isNaN(offset))return 61;var stream=SYSCALLS.getStreamFromFD(fd);var num=doReadv(stream,iov,iovcnt,offset);HEAPU32[pnum>>>2>>>0]=num;return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return e.errno}}_fd_pread.sig="iippjp";var doWritev=(stream,iov,iovcnt,offset)=>{var ret=0;for(var i=0;i>>2>>>0];var len=HEAPU32[iov+4>>>2>>>0];iov+=8;var curr=FS.write(stream,HEAP8,ptr,len,offset);if(curr<0)return-1;ret+=curr;if(curr>>=0;iovcnt>>>=0;offset=bigintToI53Checked(offset);pnum>>>=0;try{if(isNaN(offset))return 61;var stream=SYSCALLS.getStreamFromFD(fd);var num=doWritev(stream,iov,iovcnt,offset);HEAPU32[pnum>>>2>>>0]=num;return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return e.errno}}_fd_pwrite.sig="iippjp";function _fd_read(fd,iov,iovcnt,pnum){iov>>>=0;iovcnt>>>=0;pnum>>>=0;try{var stream=SYSCALLS.getStreamFromFD(fd);var num=doReadv(stream,iov,iovcnt);HEAPU32[pnum>>>2>>>0]=num;return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return e.errno}}_fd_read.sig="iippp";function _fd_seek(fd,offset,whence,newOffset){offset=bigintToI53Checked(offset);newOffset>>>=0;try{if(isNaN(offset))return 61;var stream=SYSCALLS.getStreamFromFD(fd);FS.llseek(stream,offset,whence);HEAP64[newOffset>>>3>>>0]=BigInt(stream.position);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}}_fd_seek.sig="iijip";function _fd_sync(fd){try{var stream=SYSCALLS.getStreamFromFD(fd);if(stream.stream_ops?.fsync){return stream.stream_ops.fsync(stream)}return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return e.errno}}_fd_sync.sig="ii";function _fd_write(fd,iov,iovcnt,pnum){iov>>>=0;iovcnt>>>=0;pnum>>>=0;try{var stream=SYSCALLS.getStreamFromFD(fd);var num=doWritev(stream,iov,iovcnt);HEAPU32[pnum>>>2>>>0]=num;return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return e.errno}}_fd_write.sig="iippp";function _getaddrinfo(node,service,hint,out){node>>>=0;service>>>=0;hint>>>=0;out>>>=0;var addrs=[];var canon=null;var addr=0;var port=0;var flags=0;var family=0;var type=0;var proto=0;var ai,last;function allocaddrinfo(family,type,proto,canon,addr,port){var sa,salen,ai;var errno;salen=family===10?28:16;addr=family===10?inetNtop6(addr):inetNtop4(addr);sa=_malloc(salen);errno=writeSockaddr(sa,family,addr,port);assert(!errno);ai=_malloc(32);HEAP32[ai+4>>>2>>>0]=family;HEAP32[ai+8>>>2>>>0]=type;HEAP32[ai+12>>>2>>>0]=proto;HEAPU32[ai+24>>>2>>>0]=canon;HEAPU32[ai+20>>>2>>>0]=sa;if(family===10){HEAP32[ai+16>>>2>>>0]=28}else{HEAP32[ai+16>>>2>>>0]=16}HEAP32[ai+28>>>2>>>0]=0;return ai}if(hint){flags=HEAP32[hint>>>2>>>0];family=HEAP32[hint+4>>>2>>>0];type=HEAP32[hint+8>>>2>>>0];proto=HEAP32[hint+12>>>2>>>0]}if(type&&!proto){proto=type===2?17:6}if(!type&&proto){type=proto===17?2:1}if(proto===0){proto=6}if(type===0){type=1}if(!node&&!service){return-2}if(flags&~(1|2|4|1024|8|16|32)){return-1}if(hint!==0&&HEAP32[hint>>>2>>>0]&2&&!node){return-1}if(flags&32){return-2}if(type!==0&&type!==1&&type!==2){return-7}if(family!==0&&family!==2&&family!==10){return-6}if(service){service=UTF8ToString(service);port=parseInt(service,10);if(isNaN(port)){if(flags&1024){return-2}return-8}}if(!node){if(family===0){family=2}if((flags&1)===0){if(family===2){addr=_htonl(2130706433)}else{addr=[0,0,0,_htonl(1)]}}ai=allocaddrinfo(family,type,proto,null,addr,port);HEAPU32[out>>>2>>>0]=ai;return 0}node=UTF8ToString(node);addr=inetPton4(node);if(addr!==null){if(family===0||family===2){family=2}else if(family===10&&flags&8){addr=[0,0,_htonl(65535),addr];family=10}else{return-2}}else{addr=inetPton6(node);if(addr!==null){if(family===0||family===10){family=10}else{return-2}}}if(addr!=null){ai=allocaddrinfo(family,type,proto,node,addr,port);HEAPU32[out>>>2>>>0]=ai;return 0}if(flags&4){return-2}node=DNS.lookup_name(node);addr=inetPton4(node);if(family===0){family=2}else if(family===10){addr=[0,0,_htonl(65535),addr]}ai=allocaddrinfo(family,type,proto,null,addr,port);HEAPU32[out>>>2>>>0]=ai;return 0}_getaddrinfo.sig="ipppp";function _getnameinfo(sa,salen,node,nodelen,serv,servlen,flags){sa>>>=0;node>>>=0;serv>>>=0;var info=readSockaddr(sa,salen);if(info.errno){return-6}var port=info.port;var addr=info.addr;var overflowed=false;if(node&&nodelen){var lookup;if(flags&1||!(lookup=DNS.lookup_addr(addr))){if(flags&8){return-2}}else{addr=lookup}var numBytesWrittenExclNull=stringToUTF8(addr,node,nodelen);if(numBytesWrittenExclNull+1>=nodelen){overflowed=true}}if(serv&&servlen){port=""+port;var numBytesWrittenExclNull=stringToUTF8(port,serv,servlen);if(numBytesWrittenExclNull+1>=servlen){overflowed=true}}if(overflowed){return-12}return 0}_getnameinfo.sig="ipipipii";var Protocols={list:[],map:{}};var stringToAscii=(str,buffer)=>{for(var i=0;i>>0]=str.charCodeAt(i)}HEAP8[buffer>>>0]=0};var _setprotoent=stayopen=>{function allocprotoent(name,proto,aliases){var nameBuf=_malloc(name.length+1);stringToAscii(name,nameBuf);var j=0;var length=aliases.length;var aliasListBuf=_malloc((length+1)*4);for(var i=0;i>>2>>>0]=aliasBuf}HEAPU32[aliasListBuf+j>>>2>>>0]=0;var pe=_malloc(12);HEAPU32[pe>>>2>>>0]=nameBuf;HEAPU32[pe+4>>>2>>>0]=aliasListBuf;HEAP32[pe+8>>>2>>>0]=proto;return pe}var list=Protocols.list;var map=Protocols.map;if(list.length===0){var entry=allocprotoent("tcp",6,["TCP"]);list.push(entry);map["tcp"]=map["6"]=entry;entry=allocprotoent("udp",17,["UDP"]);list.push(entry);map["udp"]=map["17"]=entry}_setprotoent.index=0};_setprotoent.sig="vi";function _getprotobyname(name){name>>>=0;name=UTF8ToString(name);_setprotoent(true);var result=Protocols.map[name];return result}_getprotobyname.sig="pp";function _is_sentinel(...args){return wasmImports["is_sentinel"](...args)}_is_sentinel.stub=true;function _random_get(buffer,size){buffer>>>=0;size>>>=0;try{randomFill(HEAPU8.subarray(buffer>>>0,buffer+size>>>0));return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return e.errno}}_random_get.sig="ipp";var _stackAlloc=stackAlloc;var _stackRestore=stackSave;var _stackSave=stackSave;var FS_createPath=(...args)=>FS.createPath(...args);var FS_unlink=(...args)=>FS.unlink(...args);var FS_createLazyFile=(...args)=>FS.createLazyFile(...args);var FS_createDevice=(...args)=>FS.createDevice(...args);var writeI53ToI64Clamped=(ptr,num)=>{if(num>0x8000000000000000){HEAPU32[ptr>>>2>>>0]=4294967295;HEAPU32[ptr+4>>>2>>>0]=2147483647}else if(num<-0x8000000000000000){HEAPU32[ptr>>>2>>>0]=0;HEAPU32[ptr+4>>>2>>>0]=2147483648}else{writeI53ToI64(ptr,num)}};var writeI53ToI64Signaling=(ptr,num)=>{if(num>0x8000000000000000||num<-0x8000000000000000){throw`RangeError: ${num}`}writeI53ToI64(ptr,num)};var writeI53ToU64Clamped=(ptr,num)=>{if(num>0x10000000000000000){HEAPU32[ptr>>>2>>>0]=4294967295;HEAPU32[ptr+4>>>2>>>0]=4294967295}else if(num<0){HEAPU32[ptr>>>2>>>0]=0;HEAPU32[ptr+4>>>2>>>0]=0}else{writeI53ToI64(ptr,num)}};var writeI53ToU64Signaling=(ptr,num)=>{if(num<0||num>0x10000000000000000){throw`RangeError: ${num}`}writeI53ToI64(ptr,num)};var readI53FromU64=ptr=>HEAPU32[ptr>>>2>>>0]+HEAPU32[ptr+4>>>2>>>0]*4294967296;var convertI32PairToI53=(lo,hi)=>(lo>>>0)+hi*4294967296;var convertI32PairToI53Checked=(lo,hi)=>hi+2097152>>>0<4194305-!!lo?(lo>>>0)+hi*4294967296:NaN;var convertU32PairToI53=(lo,hi)=>(lo>>>0)+(hi>>>0)*4294967296;var getTempRet0=val=>__emscripten_tempret_get();var setTempRet0=val=>__emscripten_tempret_set(val);var ptrToString=ptr=>"0x"+ptr.toString(16).padStart(8,"0");function _emscripten_notify_memory_growth(memoryIndex){memoryIndex>>>=0;updateMemoryViews()}_emscripten_notify_memory_growth.sig="vp";var strError=errno=>UTF8ToString(_strerror(errno));var _endprotoent=()=>{};_endprotoent.sig="v";function _getprotoent(number){if(_setprotoent.index===Protocols.list.length){return 0}var result=Protocols.list[_setprotoent.index++];return result}_getprotoent.sig="p";function _getprotobynumber(number){_setprotoent(true);var result=Protocols.map[number];return result}_getprotobynumber.sig="pi";var Sockets={BUFFER_SIZE:10240,MAX_BUFFER_SIZE:10485760,nextFd:1,fds:{},nextport:1,maxport:65535,peer:null,connections:{},portmap:{},localAddr:4261412874,addrPool:[33554442,50331658,67108874,83886090,100663306,117440522,134217738,150994954,167772170,184549386,201326602,218103818,234881034]};function _emscripten_run_script(ptr){ptr>>>=0;eval(UTF8ToString(ptr))}_emscripten_run_script.sig="vp";function _emscripten_run_script_int(ptr){ptr>>>=0;return eval(UTF8ToString(ptr))|0}_emscripten_run_script_int.sig="ip";function _emscripten_run_script_string(ptr){ptr>>>=0;var s=eval(UTF8ToString(ptr));if(s==null){return 0}s+="";var me=_emscripten_run_script_string;var len=lengthBytesUTF8(s);if(!me.bufferSize||me.bufferSizeMath.random();_emscripten_random.sig="f";var _emscripten_performance_now=()=>performance.now();_emscripten_performance_now.sig="d";var __emscripten_get_now_is_monotonic=()=>nowIsMonotonic;__emscripten_get_now_is_monotonic.sig="i";var warnOnce=text=>{warnOnce.shown||={};if(!warnOnce.shown[text]){warnOnce.shown[text]=1;if(ENVIRONMENT_IS_NODE)text="warning: "+text;err(text)}};var jsStackTrace=()=>(new Error).stack.toString();var getCallstack=flags=>{var callstack=jsStackTrace();var lines=callstack.split("\n");callstack="";var firefoxRe=new RegExp("\\s*(.*?)@(.*?):([0-9]+):([0-9]+)");var chromeRe=new RegExp("\\s*at (.*?) \\((.*):(.*):(.*)\\)");for(var line of lines){var symbolName="";var file="";var lineno=0;var column=0;var parts=chromeRe.exec(line);if(parts?.length==5){symbolName=parts[1];file=parts[2];lineno=parts[3];column=parts[4]}else{parts=firefoxRe.exec(line);if(parts?.length>=4){symbolName=parts[1];file=parts[2];lineno=parts[3];column=parts[4]|0}else{callstack+=line+"\n";continue}}if(symbolName=="_emscripten_log"||symbolName=="_emscripten_get_callstack"){callstack="";continue}if(flags&24){if(flags&64){file=file.substring(file.replace(/\\/g,"/").lastIndexOf("/")+1)}callstack+=` at ${symbolName} (${file}:${lineno}:${column})\n`}}callstack=callstack.replace(/\s+$/,"");return callstack};var emscriptenLog=(flags,str)=>{if(flags&24){str=str.replace(/\s+$/,"");str+=(str.length>0?"\n":"")+getCallstack(flags)}if(flags&1){if(flags&4){console.error(str)}else if(flags&2){console.warn(str)}else if(flags&512){console.info(str)}else if(flags&256){console.debug(str)}else{console.log(str)}}else if(flags&6){err(str)}else{out(str)}};var reallyNegative=x=>x<0||x===0&&1/x===-Infinity;var reSign=(value,bits)=>{if(value<=0){return value}var half=bits<=32?Math.abs(1<=half&&(bits<=32||value>half)){value=-2*half+value}return value};var unSign=(value,bits)=>{if(value>=0){return value}return bits<=32?2*Math.abs(1<{var end=ptr;while(HEAPU8[end>>>0])++end;return end-ptr};var formatString=(format,varargs)=>{var textIndex=format;var argIndex=varargs;function prepVararg(ptr,type){if(type==="double"||type==="i64"){if(ptr&7){ptr+=4}}else{}return ptr}function getNextArg(type){var ret;argIndex=prepVararg(argIndex,type);if(type==="double"){ret=HEAPF64[argIndex>>>3>>>0];argIndex+=8}else if(type=="i64"){ret=[HEAP32[argIndex>>>2>>>0],HEAP32[argIndex+4>>>2>>>0]];argIndex+=8}else{type="i32";ret=HEAP32[argIndex>>>2>>>0];argIndex+=4}return ret}var ret=[];var curr,next,currArg;while(1){var startTextIndex=textIndex;curr=HEAP8[textIndex>>>0];if(curr===0)break;next=HEAP8[textIndex+1>>>0];if(curr==37){var flagAlwaysSigned=false;var flagLeftAlign=false;var flagAlternative=false;var flagZeroPad=false;var flagPadSign=false;flagsLoop:while(1){switch(next){case 43:flagAlwaysSigned=true;break;case 45:flagLeftAlign=true;break;case 35:flagAlternative=true;break;case 48:if(flagZeroPad){break flagsLoop}else{flagZeroPad=true;break}case 32:flagPadSign=true;break;default:break flagsLoop}textIndex++;next=HEAP8[textIndex+1>>>0]}var width=0;if(next==42){width=getNextArg("i32");textIndex++;next=HEAP8[textIndex+1>>>0]}else{while(next>=48&&next<=57){width=width*10+(next-48);textIndex++;next=HEAP8[textIndex+1>>>0]}}var precisionSet=false,precision=-1;if(next==46){precision=0;precisionSet=true;textIndex++;next=HEAP8[textIndex+1>>>0];if(next==42){precision=getNextArg("i32");textIndex++}else{while(1){var precisionChr=HEAP8[textIndex+1>>>0];if(precisionChr<48||precisionChr>57)break;precision=precision*10+(precisionChr-48);textIndex++}}next=HEAP8[textIndex+1>>>0]}if(precision<0){precision=6;precisionSet=false}var argSize;switch(String.fromCharCode(next)){case"h":var nextNext=HEAP8[textIndex+2>>>0];if(nextNext==104){textIndex++;argSize=1}else{argSize=2}break;case"l":var nextNext=HEAP8[textIndex+2>>>0];if(nextNext==108){textIndex++;argSize=8}else{argSize=4}break;case"L":case"q":case"j":argSize=8;break;case"z":case"t":case"I":argSize=4;break;default:argSize=null}if(argSize)textIndex++;next=HEAP8[textIndex+1>>>0];switch(String.fromCharCode(next)){case"d":case"i":case"u":case"o":case"x":case"X":case"p":{var signed=next==100||next==105;argSize=argSize||4;currArg=getNextArg("i"+argSize*8);var argText;if(argSize==8){currArg=next==117?convertU32PairToI53(currArg[0],currArg[1]):convertI32PairToI53(currArg[0],currArg[1])}if(argSize<=4){var limit=Math.pow(256,argSize)-1;currArg=(signed?reSign:unSign)(currArg&limit,argSize*8)}var currAbsArg=Math.abs(currArg);var prefix="";if(next==100||next==105){argText=reSign(currArg,8*argSize).toString(10)}else if(next==117){argText=unSign(currArg,8*argSize).toString(10);currArg=Math.abs(currArg)}else if(next==111){argText=(flagAlternative?"0":"")+currAbsArg.toString(8)}else if(next==120||next==88){prefix=flagAlternative&&currArg!=0?"0x":"";if(currArg<0){currArg=-currArg;argText=(currAbsArg-1).toString(16);var buffer=[];for(var i=0;i=0){if(flagAlwaysSigned){prefix="+"+prefix}else if(flagPadSign){prefix=" "+prefix}}if(argText.charAt(0)=="-"){prefix="-"+prefix;argText=argText.slice(1)}while(prefix.length+argText.lengthret.push(chr.charCodeAt(0)));break}case"f":case"F":case"e":case"E":case"g":case"G":{currArg=getNextArg("double");var argText;if(isNaN(currArg)){argText="nan";flagZeroPad=false}else if(!isFinite(currArg)){argText=(currArg<0?"-":"")+"inf";flagZeroPad=false}else{var isGeneral=false;var effectivePrecision=Math.min(precision,20);if(next==103||next==71){isGeneral=true;precision=precision||1;var exponent=parseInt(currArg.toExponential(effectivePrecision).split("e")[1],10);if(precision>exponent&&exponent>=-4){next=(next==103?"f":"F").charCodeAt(0);precision-=exponent+1}else{next=(next==103?"e":"E").charCodeAt(0);precision--}effectivePrecision=Math.min(precision,20)}if(next==101||next==69){argText=currArg.toExponential(effectivePrecision);if(/[eE][-+]\d$/.test(argText)){argText=argText.slice(0,-1)+"0"+argText.slice(-1)}}else if(next==102||next==70){argText=currArg.toFixed(effectivePrecision);if(currArg===0&&reallyNegative(currArg)){argText="-"+argText}}var parts=argText.split("e");if(isGeneral&&!flagAlternative){while(parts[0].length>1&&parts[0].includes(".")&&(parts[0].slice(-1)=="0"||parts[0].slice(-1)==".")){parts[0]=parts[0].slice(0,-1)}}else{if(flagAlternative&&argText.indexOf(".")==-1)parts[0]+=".";while(precision>effectivePrecision++)parts[0]+="0"}argText=parts[0]+(parts.length>1?"e"+parts[1]:"");if(next==69)argText=argText.toUpperCase();if(currArg>=0){if(flagAlwaysSigned){argText="+"+argText}else if(flagPadSign){argText=" "+argText}}}while(argText.lengthret.push(chr.charCodeAt(0)));break}case"s":{var arg=getNextArg("i8*");var argLength=arg?strLen(arg):"(null)".length;if(precisionSet)argLength=Math.min(argLength,precision);if(!flagLeftAlign){while(argLength>>0])}}else{ret=ret.concat(intArrayFromString("(null)".slice(0,argLength),true))}if(flagLeftAlign){while(argLength0){ret.push(32)}if(!flagLeftAlign)ret.push(getNextArg("i8"));break}case"n":{var ptr=getNextArg("i32*");HEAP32[ptr>>>2>>>0]=ret.length;break}case"%":{ret.push(curr);break}default:{for(var i=startTextIndex;i>>0])}}}textIndex+=2}else{ret.push(curr);textIndex+=1}}return ret};function _emscripten_log(flags,format,varargs){format>>>=0;varargs>>>=0;var result=formatString(format,varargs);var str=UTF8ArrayToString(result);emscriptenLog(flags,str)}_emscripten_log.sig="vipp";function _emscripten_get_compiler_setting(name){name>>>=0;throw"You must build with -sRETAIN_COMPILER_SETTINGS for getCompilerSetting or emscripten_get_compiler_setting to work"}_emscripten_get_compiler_setting.sig="pp";var _emscripten_has_asyncify=()=>0;_emscripten_has_asyncify.sig="i";var _emscripten_debugger=()=>{debugger};_emscripten_debugger.sig="v";function _emscripten_print_double(x,to,max){to>>>=0;var str=x+"";if(to)return stringToUTF8(str,to,max);else return lengthBytesUTF8(str)}_emscripten_print_double.sig="idpi";function _emscripten_asm_const_double(code,sigPtr,argbuf){code>>>=0;sigPtr>>>=0;argbuf>>>=0;return runEmAsmFunction(code,sigPtr,argbuf)}_emscripten_asm_const_double.sig="dppp";function _emscripten_asm_const_ptr(code,sigPtr,argbuf){code>>>=0;sigPtr>>>=0;argbuf>>>=0;return runEmAsmFunction(code,sigPtr,argbuf)}_emscripten_asm_const_ptr.sig="pppp";var runMainThreadEmAsm=(emAsmAddr,sigPtr,argbuf,sync)=>{var args=readEmAsmArgs(sigPtr,argbuf);return ASM_CONSTS[emAsmAddr](...args)};function _emscripten_asm_const_int_sync_on_main_thread(emAsmAddr,sigPtr,argbuf){emAsmAddr>>>=0;sigPtr>>>=0;argbuf>>>=0;return runMainThreadEmAsm(emAsmAddr,sigPtr,argbuf,1)}_emscripten_asm_const_int_sync_on_main_thread.sig="ippp";function _emscripten_asm_const_ptr_sync_on_main_thread(emAsmAddr,sigPtr,argbuf){emAsmAddr>>>=0;sigPtr>>>=0;argbuf>>>=0;return runMainThreadEmAsm(emAsmAddr,sigPtr,argbuf,1)}_emscripten_asm_const_ptr_sync_on_main_thread.sig="pppp";var _emscripten_asm_const_double_sync_on_main_thread=_emscripten_asm_const_int_sync_on_main_thread;_emscripten_asm_const_double_sync_on_main_thread.sig="dppp";function _emscripten_asm_const_async_on_main_thread(emAsmAddr,sigPtr,argbuf){emAsmAddr>>>=0;sigPtr>>>=0;argbuf>>>=0;return runMainThreadEmAsm(emAsmAddr,sigPtr,argbuf,0)}_emscripten_asm_const_async_on_main_thread.sig="vppp";function __Unwind_Backtrace(func,arg){func>>>=0;arg>>>=0;var trace=getCallstack();var parts=trace.split("\n");for(var i=0;i>>=0;ipBefore>>>=0;return abort("Unwind_GetIPInfo")}__Unwind_GetIPInfo.sig="ppp";function __Unwind_FindEnclosingFunction(ip){ip>>>=0;return 0}__Unwind_FindEnclosingFunction.sig="pp";var listenOnce=(object,event,func)=>object.addEventListener(event,func,{once:true});var autoResumeAudioContext=(ctx,elements)=>{if(!elements){elements=[document,document.getElementById("canvas")]}["keydown","mousedown","touchstart"].forEach(event=>{elements.forEach(element=>{if(element){listenOnce(element,event,()=>{if(ctx.state==="suspended")ctx.resume()})}})})};var dynCall=(sig,ptr,args=[],promising=false)=>{var func=getWasmTableEntry(ptr);var rtn=func(...args);function convert(rtn){return sig[0]=="p"?rtn>>>0:rtn}return convert(rtn)};var getDynCaller=(sig,ptr,promising=false)=>(...args)=>dynCall(sig,ptr,args,promising);var _emscripten_exit_with_live_runtime=()=>{runtimeKeepalivePush();throw"unwind"};_emscripten_exit_with_live_runtime.sig="v";var _emscripten_force_exit=status=>{__emscripten_runtime_keepalive_clear();_exit(status)};_emscripten_force_exit.sig="vi";function _emscripten_outn(str,len){str>>>=0;len>>>=0;return out(UTF8ToString(str,len))}_emscripten_outn.sig="vpp";function _emscripten_errn(str,len){str>>>=0;len>>>=0;return err(UTF8ToString(str,len))}_emscripten_errn.sig="vpp";var _emscripten_throw_number=number=>{throw number};_emscripten_throw_number.sig="vd";function _emscripten_throw_string(str){str>>>=0;throw UTF8ToString(str)}_emscripten_throw_string.sig="vp";var _emscripten_runtime_keepalive_check=keepRuntimeAlive;_emscripten_runtime_keepalive_check.sig="i";var asmjsMangle=x=>{if(x=="__main_argc_argv"){x="main"}return x.startsWith("dynCall_")?x:"_"+x};var ___global_base=1024;function __emscripten_fs_load_embedded_files(ptr){ptr>>>=0;do{var name_addr=HEAPU32[ptr>>>2>>>0];ptr+=4;var len=HEAPU32[ptr>>>2>>>0];ptr+=4;var content=HEAPU32[ptr>>>2>>>0];ptr+=4;var name=UTF8ToString(name_addr);FS.createPath("/",PATH.dirname(name),true,true);FS.createDataFile(name,null,HEAP8.subarray(content>>>0,content+len>>>0),true,true,true)}while(HEAPU32[ptr>>>2>>>0])}__emscripten_fs_load_embedded_files.sig="vp";var POINTER_SIZE=4;function getNativeTypeSize(type){switch(type){case"i1":case"i8":case"u8":return 1;case"i16":case"u16":return 2;case"i32":case"u32":return 4;case"i64":case"u64":return 8;case"float":return 4;case"double":return 8;default:{if(type.endsWith("*")){return POINTER_SIZE}if(type[0]==="i"){const bits=Number(type.slice(1));assert(bits%8===0,`getNativeTypeSize invalid bits ${bits}, ${type} type`);return bits/8}return 0}}}var onInits=[];var addOnInit=cb=>onInits.push(cb);var onMains=[];var addOnPreMain=cb=>onMains.push(cb);var onExits=[];var addOnExit=cb=>onExits.push(cb);var STACK_SIZE=5242880;var STACK_ALIGN=16;var ASSERTIONS=0;var getCFunc=ident=>{var func=Module["_"+ident];return func};var writeArrayToMemory=(array,buffer)=>{HEAP8.set(array,buffer>>>0)};var ccall=(ident,returnType,argTypes,args,opts)=>{var toC={string:str=>{var ret=0;if(str!==null&&str!==undefined&&str!==0){ret=stringToUTF8OnStack(str)}return ret},array:arr=>{var ret=stackAlloc(arr.length);writeArrayToMemory(arr,ret);return ret}};function convertReturnValue(ret){if(returnType==="string"){return UTF8ToString(ret)}if(returnType==="boolean")return Boolean(ret);return ret}var func=getCFunc(ident);var cArgs=[];var stack=0;if(args){for(var i=0;i{var numericArgs=!argTypes||argTypes.every(type=>type==="number"||type==="boolean");var numericRet=returnType!=="string";if(numericRet&&numericArgs&&!opts){return getCFunc(ident)}return(...args)=>ccall(ident,returnType,argTypes,args,opts)};var removeFunction=index=>{functionsInTableMap.delete(getWasmTableEntry(index));setWasmTableEntry(index,null);freeTableIndexes.push(index)};var _emscripten_math_cbrt=Math.cbrt;_emscripten_math_cbrt.sig="dd";var _emscripten_math_pow=Math.pow;_emscripten_math_pow.sig="ddd";var _emscripten_math_random=Math.random;_emscripten_math_random.sig="d";var _emscripten_math_sign=Math.sign;_emscripten_math_sign.sig="dd";var _emscripten_math_sqrt=Math.sqrt;_emscripten_math_sqrt.sig="dd";var _emscripten_math_exp=Math.exp;_emscripten_math_exp.sig="dd";var _emscripten_math_expm1=Math.expm1;_emscripten_math_expm1.sig="dd";var _emscripten_math_fmod=(x,y)=>x%y;_emscripten_math_fmod.sig="ddd";var _emscripten_math_log=Math.log;_emscripten_math_log.sig="dd";var _emscripten_math_log1p=Math.log1p;_emscripten_math_log1p.sig="dd";var _emscripten_math_log10=Math.log10;_emscripten_math_log10.sig="dd";var _emscripten_math_log2=Math.log2;_emscripten_math_log2.sig="dd";var _emscripten_math_round=Math.round;_emscripten_math_round.sig="dd";var _emscripten_math_acos=Math.acos;_emscripten_math_acos.sig="dd";var _emscripten_math_acosh=Math.acosh;_emscripten_math_acosh.sig="dd";var _emscripten_math_asin=Math.asin;_emscripten_math_asin.sig="dd";var _emscripten_math_asinh=Math.asinh;_emscripten_math_asinh.sig="dd";var _emscripten_math_atan=Math.atan;_emscripten_math_atan.sig="dd";var _emscripten_math_atanh=Math.atanh;_emscripten_math_atanh.sig="dd";var _emscripten_math_atan2=Math.atan2;_emscripten_math_atan2.sig="ddd";var _emscripten_math_cos=Math.cos;_emscripten_math_cos.sig="dd";var _emscripten_math_cosh=Math.cosh;_emscripten_math_cosh.sig="dd";function _emscripten_math_hypot(count,varargs){varargs>>>=0;var args=[];for(var i=0;i>>3>>>0])}return Math.hypot(...args)}_emscripten_math_hypot.sig="dip";var _emscripten_math_sin=Math.sin;_emscripten_math_sin.sig="dd";var _emscripten_math_sinh=Math.sinh;_emscripten_math_sinh.sig="dd";var _emscripten_math_tan=Math.tan;_emscripten_math_tan.sig="dd";var _emscripten_math_tanh=Math.tanh;_emscripten_math_tanh.sig="dd";var intArrayToString=array=>{var ret=[];for(var i=0;i255){chr&=255}ret.push(String.fromCharCode(chr))}return ret.join("")};var AsciiToString=ptr=>{ptr>>>=0;var str="";while(1){var ch=HEAPU8[ptr++>>>0];if(!ch)return str;str+=String.fromCharCode(ch)}};var UTF16Decoder=typeof TextDecoder!="undefined"?new TextDecoder("utf-16le"):undefined;var UTF16ToString=(ptr,maxBytesToRead)=>{var idx=ptr>>>1;var maxIdx=idx+maxBytesToRead/2;var endIdx=idx;while(!(endIdx>=maxIdx)&&HEAPU16[endIdx>>>0])++endIdx;if(endIdx-idx>16&&UTF16Decoder)return UTF16Decoder.decode(HEAPU16.subarray(idx>>>0,endIdx>>>0));var str="";for(var i=idx;!(i>=maxIdx);++i){var codeUnit=HEAPU16[i>>>0];if(codeUnit==0)break;str+=String.fromCharCode(codeUnit)}return str};var stringToUTF16=(str,outPtr,maxBytesToWrite)=>{maxBytesToWrite??=2147483647;if(maxBytesToWrite<2)return 0;maxBytesToWrite-=2;var startPtr=outPtr;var numCharsToWrite=maxBytesToWrite>>1>>>0]=codeUnit;outPtr+=2}HEAP16[outPtr>>>1>>>0]=0;return outPtr-startPtr};var lengthBytesUTF16=str=>str.length*2;var UTF32ToString=(ptr,maxBytesToRead)=>{var i=0;var str="";while(!(i>=maxBytesToRead/4)){var utf32=HEAP32[ptr+i*4>>>2>>>0];if(utf32==0)break;++i;if(utf32>=65536){var ch=utf32-65536;str+=String.fromCharCode(55296|ch>>10,56320|ch&1023)}else{str+=String.fromCharCode(utf32)}}return str};var stringToUTF32=(str,outPtr,maxBytesToWrite)=>{outPtr>>>=0;maxBytesToWrite??=2147483647;if(maxBytesToWrite<4)return 0;var startPtr=outPtr;var endPtr=startPtr+maxBytesToWrite-4;for(var i=0;i=55296&&codeUnit<=57343){var trailSurrogate=str.charCodeAt(++i);codeUnit=65536+((codeUnit&1023)<<10)|trailSurrogate&1023}HEAP32[outPtr>>>2>>>0]=codeUnit;outPtr+=4;if(outPtr+4>endPtr)break}HEAP32[outPtr>>>2>>>0]=0;return outPtr-startPtr};var lengthBytesUTF32=str=>{var len=0;for(var i=0;i=55296&&codeUnit<=57343)++i;len+=4}return len};var JSEvents={memcpy(target,src,size){HEAP8.set(HEAP8.subarray(src>>>0,src+size>>>0),target>>>0)},removeAllEventListeners(){while(JSEvents.eventHandlers.length){JSEvents._removeHandler(JSEvents.eventHandlers.length-1)}JSEvents.deferredCalls=[]},registerRemoveEventListeners(){if(!JSEvents.removeEventListenersRegistered){addOnExit(JSEvents.removeAllEventListeners);JSEvents.removeEventListenersRegistered=true}},inEventHandler:0,deferredCalls:[],deferCall(targetFunction,precedence,argsList){function arraysHaveEqualContent(arrA,arrB){if(arrA.length!=arrB.length)return false;for(var i in arrA){if(arrA[i]!=arrB[i])return false}return true}for(var call of JSEvents.deferredCalls){if(call.targetFunction==targetFunction&&arraysHaveEqualContent(call.argsList,argsList)){return}}JSEvents.deferredCalls.push({targetFunction,precedence,argsList});JSEvents.deferredCalls.sort((x,y)=>x.precedencecall.targetFunction!=targetFunction)},canPerformEventHandlerRequests(){if(navigator.userActivation){return navigator.userActivation.isActive}return JSEvents.inEventHandler&&JSEvents.currentEventHandler.allowsDeferredCalls},runDeferredCalls(){if(!JSEvents.canPerformEventHandlerRequests()){return}var deferredCalls=JSEvents.deferredCalls;JSEvents.deferredCalls=[];for(var call of deferredCalls){call.targetFunction(...call.argsList)}},eventHandlers:[],removeAllHandlersOnTarget:(target,eventTypeString)=>{for(var i=0;icString>2?UTF8ToString(cString):cString;var specialHTMLTargets=[0,typeof document!="undefined"?document:0,typeof window!="undefined"?window:0];var findEventTarget=target=>{target=maybeCStringToJsString(target);var domElement=specialHTMLTargets[target]||(typeof document!="undefined"?document.querySelector(target):null);return domElement};var registerKeyEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.keyEvent||=_malloc(160);var keyEventHandlerFunc=e=>{var keyEventData=JSEvents.keyEvent;HEAPF64[keyEventData>>>3>>>0]=e.timeStamp;var idx=keyEventData>>>2;HEAP32[idx+2>>>0]=e.location;HEAP8[keyEventData+12>>>0]=e.ctrlKey;HEAP8[keyEventData+13>>>0]=e.shiftKey;HEAP8[keyEventData+14>>>0]=e.altKey;HEAP8[keyEventData+15>>>0]=e.metaKey;HEAP8[keyEventData+16>>>0]=e.repeat;HEAP32[idx+5>>>0]=e.charCode;HEAP32[idx+6>>>0]=e.keyCode;HEAP32[idx+7>>>0]=e.which;stringToUTF8(e.key||"",keyEventData+32,32);stringToUTF8(e.code||"",keyEventData+64,32);stringToUTF8(e.char||"",keyEventData+96,32);stringToUTF8(e.locale||"",keyEventData+128,32);if(getWasmTableEntry(callbackfunc)(eventTypeId,keyEventData,userData))e.preventDefault()};var eventHandler={target:findEventTarget(target),eventTypeString,callbackfunc,handlerFunc:keyEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};var findCanvasEventTarget=findEventTarget;function _emscripten_set_keypress_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerKeyEventCallback(target,userData,useCapture,callbackfunc,1,"keypress",targetThread)}_emscripten_set_keypress_callback_on_thread.sig="ippipp";function _emscripten_set_keydown_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerKeyEventCallback(target,userData,useCapture,callbackfunc,2,"keydown",targetThread)}_emscripten_set_keydown_callback_on_thread.sig="ippipp";function _emscripten_set_keyup_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerKeyEventCallback(target,userData,useCapture,callbackfunc,3,"keyup",targetThread)}_emscripten_set_keyup_callback_on_thread.sig="ippipp";var getBoundingClientRect=e=>specialHTMLTargets.indexOf(e)<0?e.getBoundingClientRect():{left:0,top:0};var fillMouseEventData=(eventStruct,e,target)=>{HEAPF64[eventStruct>>>3>>>0]=e.timeStamp;var idx=eventStruct>>>2;HEAP32[idx+2>>>0]=e.screenX;HEAP32[idx+3>>>0]=e.screenY;HEAP32[idx+4>>>0]=e.clientX;HEAP32[idx+5>>>0]=e.clientY;HEAP8[eventStruct+24>>>0]=e.ctrlKey;HEAP8[eventStruct+25>>>0]=e.shiftKey;HEAP8[eventStruct+26>>>0]=e.altKey;HEAP8[eventStruct+27>>>0]=e.metaKey;HEAP16[idx*2+14>>>0]=e.button;HEAP16[idx*2+15>>>0]=e.buttons;HEAP32[idx+8>>>0]=e["movementX"];HEAP32[idx+9>>>0]=e["movementY"];var rect=getBoundingClientRect(target);HEAP32[idx+10>>>0]=e.clientX-(rect.left|0);HEAP32[idx+11>>>0]=e.clientY-(rect.top|0)};var registerMouseEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.mouseEvent||=_malloc(64);target=findEventTarget(target);var mouseEventHandlerFunc=(e=event)=>{fillMouseEventData(JSEvents.mouseEvent,e,target);if(getWasmTableEntry(callbackfunc)(eventTypeId,JSEvents.mouseEvent,userData))e.preventDefault()};var eventHandler={target,allowsDeferredCalls:eventTypeString!="mousemove"&&eventTypeString!="mouseenter"&&eventTypeString!="mouseleave",eventTypeString,callbackfunc,handlerFunc:mouseEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_click_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerMouseEventCallback(target,userData,useCapture,callbackfunc,4,"click",targetThread)}_emscripten_set_click_callback_on_thread.sig="ippipp";function _emscripten_set_mousedown_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerMouseEventCallback(target,userData,useCapture,callbackfunc,5,"mousedown",targetThread)}_emscripten_set_mousedown_callback_on_thread.sig="ippipp";function _emscripten_set_mouseup_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerMouseEventCallback(target,userData,useCapture,callbackfunc,6,"mouseup",targetThread)}_emscripten_set_mouseup_callback_on_thread.sig="ippipp";function _emscripten_set_dblclick_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerMouseEventCallback(target,userData,useCapture,callbackfunc,7,"dblclick",targetThread)}_emscripten_set_dblclick_callback_on_thread.sig="ippipp";function _emscripten_set_mousemove_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerMouseEventCallback(target,userData,useCapture,callbackfunc,8,"mousemove",targetThread)}_emscripten_set_mousemove_callback_on_thread.sig="ippipp";function _emscripten_set_mouseenter_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerMouseEventCallback(target,userData,useCapture,callbackfunc,33,"mouseenter",targetThread)}_emscripten_set_mouseenter_callback_on_thread.sig="ippipp";function _emscripten_set_mouseleave_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerMouseEventCallback(target,userData,useCapture,callbackfunc,34,"mouseleave",targetThread)}_emscripten_set_mouseleave_callback_on_thread.sig="ippipp";function _emscripten_set_mouseover_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerMouseEventCallback(target,userData,useCapture,callbackfunc,35,"mouseover",targetThread)}_emscripten_set_mouseover_callback_on_thread.sig="ippipp";function _emscripten_set_mouseout_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerMouseEventCallback(target,userData,useCapture,callbackfunc,36,"mouseout",targetThread)}_emscripten_set_mouseout_callback_on_thread.sig="ippipp";function _emscripten_get_mouse_status(mouseState){mouseState>>>=0;if(!JSEvents.mouseEvent)return-7;JSEvents.memcpy(mouseState,JSEvents.mouseEvent,64);return 0}_emscripten_get_mouse_status.sig="ip";var registerWheelEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.wheelEvent||=_malloc(96);var wheelHandlerFunc=(e=event)=>{var wheelEvent=JSEvents.wheelEvent;fillMouseEventData(wheelEvent,e,target);HEAPF64[wheelEvent+64>>>3>>>0]=e["deltaX"];HEAPF64[wheelEvent+72>>>3>>>0]=e["deltaY"];HEAPF64[wheelEvent+80>>>3>>>0]=e["deltaZ"];HEAP32[wheelEvent+88>>>2>>>0]=e["deltaMode"];if(getWasmTableEntry(callbackfunc)(eventTypeId,wheelEvent,userData))e.preventDefault()};var eventHandler={target,allowsDeferredCalls:true,eventTypeString,callbackfunc,handlerFunc:wheelHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_wheel_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;target=findEventTarget(target);if(!target)return-4;if(typeof target.onwheel!="undefined"){return registerWheelEventCallback(target,userData,useCapture,callbackfunc,9,"wheel",targetThread)}else{return-1}}_emscripten_set_wheel_callback_on_thread.sig="ippipp";var registerUiEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.uiEvent||=_malloc(36);target=findEventTarget(target);var uiEventHandlerFunc=(e=event)=>{if(e.target!=target){return}var b=document.body;if(!b){return}var uiEvent=JSEvents.uiEvent;HEAP32[uiEvent>>>2>>>0]=0;HEAP32[uiEvent+4>>>2>>>0]=b.clientWidth;HEAP32[uiEvent+8>>>2>>>0]=b.clientHeight;HEAP32[uiEvent+12>>>2>>>0]=innerWidth;HEAP32[uiEvent+16>>>2>>>0]=innerHeight;HEAP32[uiEvent+20>>>2>>>0]=outerWidth;HEAP32[uiEvent+24>>>2>>>0]=outerHeight;HEAP32[uiEvent+28>>>2>>>0]=pageXOffset|0;HEAP32[uiEvent+32>>>2>>>0]=pageYOffset|0;if(getWasmTableEntry(callbackfunc)(eventTypeId,uiEvent,userData))e.preventDefault()};var eventHandler={target,eventTypeString,callbackfunc,handlerFunc:uiEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_resize_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerUiEventCallback(target,userData,useCapture,callbackfunc,10,"resize",targetThread)}_emscripten_set_resize_callback_on_thread.sig="ippipp";function _emscripten_set_scroll_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerUiEventCallback(target,userData,useCapture,callbackfunc,11,"scroll",targetThread)}_emscripten_set_scroll_callback_on_thread.sig="ippipp";var registerFocusEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.focusEvent||=_malloc(256);var focusEventHandlerFunc=(e=event)=>{var nodeName=JSEvents.getNodeNameForTarget(e.target);var id=e.target.id?e.target.id:"";var focusEvent=JSEvents.focusEvent;stringToUTF8(nodeName,focusEvent+0,128);stringToUTF8(id,focusEvent+128,128);if(getWasmTableEntry(callbackfunc)(eventTypeId,focusEvent,userData))e.preventDefault()};var eventHandler={target:findEventTarget(target),eventTypeString,callbackfunc,handlerFunc:focusEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_blur_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerFocusEventCallback(target,userData,useCapture,callbackfunc,12,"blur",targetThread)}_emscripten_set_blur_callback_on_thread.sig="ippipp";function _emscripten_set_focus_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerFocusEventCallback(target,userData,useCapture,callbackfunc,13,"focus",targetThread)}_emscripten_set_focus_callback_on_thread.sig="ippipp";function _emscripten_set_focusin_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerFocusEventCallback(target,userData,useCapture,callbackfunc,14,"focusin",targetThread)}_emscripten_set_focusin_callback_on_thread.sig="ippipp";function _emscripten_set_focusout_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerFocusEventCallback(target,userData,useCapture,callbackfunc,15,"focusout",targetThread)}_emscripten_set_focusout_callback_on_thread.sig="ippipp";var fillDeviceOrientationEventData=(eventStruct,e,target)=>{HEAPF64[eventStruct>>>3>>>0]=e.alpha;HEAPF64[eventStruct+8>>>3>>>0]=e.beta;HEAPF64[eventStruct+16>>>3>>>0]=e.gamma;HEAP8[eventStruct+24>>>0]=e.absolute};var registerDeviceOrientationEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.deviceOrientationEvent||=_malloc(32);var deviceOrientationEventHandlerFunc=(e=event)=>{fillDeviceOrientationEventData(JSEvents.deviceOrientationEvent,e,target);if(getWasmTableEntry(callbackfunc)(eventTypeId,JSEvents.deviceOrientationEvent,userData))e.preventDefault()};var eventHandler={target:findEventTarget(target),eventTypeString,callbackfunc,handlerFunc:deviceOrientationEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_deviceorientation_callback_on_thread(userData,useCapture,callbackfunc,targetThread){userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerDeviceOrientationEventCallback(2,userData,useCapture,callbackfunc,16,"deviceorientation",targetThread)}_emscripten_set_deviceorientation_callback_on_thread.sig="ipipp";function _emscripten_get_deviceorientation_status(orientationState){orientationState>>>=0;if(!JSEvents.deviceOrientationEvent)return-7;JSEvents.memcpy(orientationState,JSEvents.deviceOrientationEvent,32);return 0}_emscripten_get_deviceorientation_status.sig="ip";var fillDeviceMotionEventData=(eventStruct,e,target)=>{var supportedFields=0;var a=e["acceleration"];supportedFields|=a&&1;var ag=e["accelerationIncludingGravity"];supportedFields|=ag&&2;var rr=e["rotationRate"];supportedFields|=rr&&4;a=a||{};ag=ag||{};rr=rr||{};HEAPF64[eventStruct>>>3>>>0]=a["x"];HEAPF64[eventStruct+8>>>3>>>0]=a["y"];HEAPF64[eventStruct+16>>>3>>>0]=a["z"];HEAPF64[eventStruct+24>>>3>>>0]=ag["x"];HEAPF64[eventStruct+32>>>3>>>0]=ag["y"];HEAPF64[eventStruct+40>>>3>>>0]=ag["z"];HEAPF64[eventStruct+48>>>3>>>0]=rr["alpha"];HEAPF64[eventStruct+56>>>3>>>0]=rr["beta"];HEAPF64[eventStruct+64>>>3>>>0]=rr["gamma"]};var registerDeviceMotionEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.deviceMotionEvent||=_malloc(80);var deviceMotionEventHandlerFunc=(e=event)=>{fillDeviceMotionEventData(JSEvents.deviceMotionEvent,e,target);if(getWasmTableEntry(callbackfunc)(eventTypeId,JSEvents.deviceMotionEvent,userData))e.preventDefault()};var eventHandler={target:findEventTarget(target),eventTypeString,callbackfunc,handlerFunc:deviceMotionEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_devicemotion_callback_on_thread(userData,useCapture,callbackfunc,targetThread){userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerDeviceMotionEventCallback(2,userData,useCapture,callbackfunc,17,"devicemotion",targetThread)}_emscripten_set_devicemotion_callback_on_thread.sig="ipipp";function _emscripten_get_devicemotion_status(motionState){motionState>>>=0;if(!JSEvents.deviceMotionEvent)return-7;JSEvents.memcpy(motionState,JSEvents.deviceMotionEvent,80);return 0}_emscripten_get_devicemotion_status.sig="ip";var screenOrientation=()=>{if(!window.screen)return undefined;return screen.orientation||screen["mozOrientation"]||screen["webkitOrientation"]};var fillOrientationChangeEventData=eventStruct=>{var orientationsType1=["portrait-primary","portrait-secondary","landscape-primary","landscape-secondary"];var orientationsType2=["portrait","portrait","landscape","landscape"];var orientationIndex=0;var orientationAngle=0;var screenOrientObj=screenOrientation();if(typeof screenOrientObj==="object"){orientationIndex=orientationsType1.indexOf(screenOrientObj.type);if(orientationIndex<0){orientationIndex=orientationsType2.indexOf(screenOrientObj.type)}if(orientationIndex>=0){orientationIndex=1<>>2>>>0]=orientationIndex;HEAP32[eventStruct+4>>>2>>>0]=orientationAngle};var registerOrientationChangeEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.orientationChangeEvent||=_malloc(8);var orientationChangeEventHandlerFunc=(e=event)=>{var orientationChangeEvent=JSEvents.orientationChangeEvent;fillOrientationChangeEventData(orientationChangeEvent);if(getWasmTableEntry(callbackfunc)(eventTypeId,orientationChangeEvent,userData))e.preventDefault()};var eventHandler={target,eventTypeString,callbackfunc,handlerFunc:orientationChangeEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_orientationchange_callback_on_thread(userData,useCapture,callbackfunc,targetThread){userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;if(!window.screen||!screen.orientation)return-1;return registerOrientationChangeEventCallback(screen.orientation,userData,useCapture,callbackfunc,18,"change",targetThread)}_emscripten_set_orientationchange_callback_on_thread.sig="ipipp";function _emscripten_get_orientation_status(orientationChangeEvent){orientationChangeEvent>>>=0;if(!screenOrientation()&&typeof orientation=="undefined")return-1;fillOrientationChangeEventData(orientationChangeEvent);return 0}_emscripten_get_orientation_status.sig="ip";var _emscripten_lock_orientation=allowedOrientations=>{var orientations=[];if(allowedOrientations&1)orientations.push("portrait-primary");if(allowedOrientations&2)orientations.push("portrait-secondary");if(allowedOrientations&4)orientations.push("landscape-primary");if(allowedOrientations&8)orientations.push("landscape-secondary");var succeeded;if(screen.lockOrientation){succeeded=screen.lockOrientation(orientations)}else if(screen.mozLockOrientation){succeeded=screen.mozLockOrientation(orientations)}else if(screen.webkitLockOrientation){succeeded=screen.webkitLockOrientation(orientations)}else{return-1}if(succeeded){return 0}return-6};_emscripten_lock_orientation.sig="ii";var _emscripten_unlock_orientation=()=>{if(screen.unlockOrientation){screen.unlockOrientation()}else if(screen.mozUnlockOrientation){screen.mozUnlockOrientation()}else if(screen.webkitUnlockOrientation){screen.webkitUnlockOrientation()}else{return-1}return 0};_emscripten_unlock_orientation.sig="i";var fillFullscreenChangeEventData=eventStruct=>{var fullscreenElement=document.fullscreenElement||document.mozFullScreenElement||document.webkitFullscreenElement||document.msFullscreenElement;var isFullscreen=!!fullscreenElement;HEAP8[eventStruct>>>0]=isFullscreen;HEAP8[eventStruct+1>>>0]=JSEvents.fullscreenEnabled();var reportedElement=isFullscreen?fullscreenElement:JSEvents.previousFullscreenElement;var nodeName=JSEvents.getNodeNameForTarget(reportedElement);var id=reportedElement?.id||"";stringToUTF8(nodeName,eventStruct+2,128);stringToUTF8(id,eventStruct+130,128);HEAP32[eventStruct+260>>>2>>>0]=reportedElement?reportedElement.clientWidth:0;HEAP32[eventStruct+264>>>2>>>0]=reportedElement?reportedElement.clientHeight:0;HEAP32[eventStruct+268>>>2>>>0]=screen.width;HEAP32[eventStruct+272>>>2>>>0]=screen.height;if(isFullscreen){JSEvents.previousFullscreenElement=fullscreenElement}};var registerFullscreenChangeEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.fullscreenChangeEvent||=_malloc(276);var fullscreenChangeEventhandlerFunc=(e=event)=>{var fullscreenChangeEvent=JSEvents.fullscreenChangeEvent;fillFullscreenChangeEventData(fullscreenChangeEvent);if(getWasmTableEntry(callbackfunc)(eventTypeId,fullscreenChangeEvent,userData))e.preventDefault()};var eventHandler={target,eventTypeString,callbackfunc,handlerFunc:fullscreenChangeEventhandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_fullscreenchange_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;if(!JSEvents.fullscreenEnabled())return-1;target=findEventTarget(target);if(!target)return-4;registerFullscreenChangeEventCallback(target,userData,useCapture,callbackfunc,19,"webkitfullscreenchange",targetThread);return registerFullscreenChangeEventCallback(target,userData,useCapture,callbackfunc,19,"fullscreenchange",targetThread)}_emscripten_set_fullscreenchange_callback_on_thread.sig="ippipp";function _emscripten_get_fullscreen_status(fullscreenStatus){fullscreenStatus>>>=0;if(!JSEvents.fullscreenEnabled())return-1;fillFullscreenChangeEventData(fullscreenStatus);return 0}_emscripten_get_fullscreen_status.sig="ip";function _emscripten_get_canvas_element_size(target,width,height){target>>>=0;width>>>=0;height>>>=0;var canvas=findCanvasEventTarget(target);if(!canvas)return-4;HEAP32[width>>>2>>>0]=canvas.width;HEAP32[height>>>2>>>0]=canvas.height}_emscripten_get_canvas_element_size.sig="ippp";var getCanvasElementSize=target=>{var sp=stackSave();var w=stackAlloc(8);var h=w+4;var targetInt=stringToUTF8OnStack(target.id);var ret=_emscripten_get_canvas_element_size(targetInt,w,h);var size=[HEAP32[w>>>2>>>0],HEAP32[h>>>2>>>0]];stackRestore(sp);return size};function _emscripten_set_canvas_element_size(target,width,height){target>>>=0;var canvas=findCanvasEventTarget(target);if(!canvas)return-4;canvas.width=width;canvas.height=height;return 0}_emscripten_set_canvas_element_size.sig="ipii";var setCanvasElementSize=(target,width,height)=>{if(!target.controlTransferredOffscreen){target.width=width;target.height=height}else{var sp=stackSave();var targetInt=stringToUTF8OnStack(target.id);_emscripten_set_canvas_element_size(targetInt,width,height);stackRestore(sp)}};var currentFullscreenStrategy={};var registerRestoreOldStyle=canvas=>{var canvasSize=getCanvasElementSize(canvas);var oldWidth=canvasSize[0];var oldHeight=canvasSize[1];var oldCssWidth=canvas.style.width;var oldCssHeight=canvas.style.height;var oldBackgroundColor=canvas.style.backgroundColor;var oldDocumentBackgroundColor=document.body.style.backgroundColor;var oldPaddingLeft=canvas.style.paddingLeft;var oldPaddingRight=canvas.style.paddingRight;var oldPaddingTop=canvas.style.paddingTop;var oldPaddingBottom=canvas.style.paddingBottom;var oldMarginLeft=canvas.style.marginLeft;var oldMarginRight=canvas.style.marginRight;var oldMarginTop=canvas.style.marginTop;var oldMarginBottom=canvas.style.marginBottom;var oldDocumentBodyMargin=document.body.style.margin;var oldDocumentOverflow=document.documentElement.style.overflow;var oldDocumentScroll=document.body.scroll;var oldImageRendering=canvas.style.imageRendering;function restoreOldStyle(){var fullscreenElement=document.fullscreenElement||document.webkitFullscreenElement;if(!fullscreenElement){document.removeEventListener("fullscreenchange",restoreOldStyle);document.removeEventListener("webkitfullscreenchange",restoreOldStyle);setCanvasElementSize(canvas,oldWidth,oldHeight);canvas.style.width=oldCssWidth;canvas.style.height=oldCssHeight;canvas.style.backgroundColor=oldBackgroundColor;if(!oldDocumentBackgroundColor)document.body.style.backgroundColor="white";document.body.style.backgroundColor=oldDocumentBackgroundColor;canvas.style.paddingLeft=oldPaddingLeft;canvas.style.paddingRight=oldPaddingRight;canvas.style.paddingTop=oldPaddingTop;canvas.style.paddingBottom=oldPaddingBottom;canvas.style.marginLeft=oldMarginLeft;canvas.style.marginRight=oldMarginRight;canvas.style.marginTop=oldMarginTop;canvas.style.marginBottom=oldMarginBottom;document.body.style.margin=oldDocumentBodyMargin;document.documentElement.style.overflow=oldDocumentOverflow;document.body.scroll=oldDocumentScroll;canvas.style.imageRendering=oldImageRendering;if(canvas.GLctxObject)canvas.GLctxObject.GLctx.viewport(0,0,oldWidth,oldHeight);if(currentFullscreenStrategy.canvasResizedCallback){getWasmTableEntry(currentFullscreenStrategy.canvasResizedCallback)(37,0,currentFullscreenStrategy.canvasResizedCallbackUserData)}}}document.addEventListener("fullscreenchange",restoreOldStyle);document.addEventListener("webkitfullscreenchange",restoreOldStyle);return restoreOldStyle};var setLetterbox=(element,topBottom,leftRight)=>{element.style.paddingLeft=element.style.paddingRight=leftRight+"px";element.style.paddingTop=element.style.paddingBottom=topBottom+"px"};var JSEvents_resizeCanvasForFullscreen=(target,strategy)=>{var restoreOldStyle=registerRestoreOldStyle(target);var cssWidth=strategy.softFullscreen?innerWidth:screen.width;var cssHeight=strategy.softFullscreen?innerHeight:screen.height;var rect=getBoundingClientRect(target);var windowedCssWidth=rect.width;var windowedCssHeight=rect.height;var canvasSize=getCanvasElementSize(target);var windowedRttWidth=canvasSize[0];var windowedRttHeight=canvasSize[1];if(strategy.scaleMode==3){setLetterbox(target,(cssHeight-windowedCssHeight)/2,(cssWidth-windowedCssWidth)/2);cssWidth=windowedCssWidth;cssHeight=windowedCssHeight}else if(strategy.scaleMode==2){if(cssWidth*windowedRttHeight{if(strategy.scaleMode!=0||strategy.canvasResolutionScaleMode!=0){JSEvents_resizeCanvasForFullscreen(target,strategy)}if(target.requestFullscreen){target.requestFullscreen()}else if(target.webkitRequestFullscreen){target.webkitRequestFullscreen(Element.ALLOW_KEYBOARD_INPUT)}else{return JSEvents.fullscreenEnabled()?-3:-1}currentFullscreenStrategy=strategy;if(strategy.canvasResizedCallback){getWasmTableEntry(strategy.canvasResizedCallback)(37,0,strategy.canvasResizedCallbackUserData)}return 0};var hideEverythingExceptGivenElement=onlyVisibleElement=>{var child=onlyVisibleElement;var parent=child.parentNode;var hiddenElements=[];while(child!=document.body){var children=parent.children;for(var currChild of children){if(currChild!=child){hiddenElements.push({node:currChild,displayState:currChild.style.display});currChild.style.display="none"}}child=parent;parent=parent.parentNode}return hiddenElements};var restoreHiddenElements=hiddenElements=>{for(var elem of hiddenElements){elem.node.style.display=elem.displayState}};var restoreOldWindowedStyle=null;var softFullscreenResizeWebGLRenderTarget=()=>{var dpr=devicePixelRatio;var inHiDPIFullscreenMode=currentFullscreenStrategy.canvasResolutionScaleMode==2;var inAspectRatioFixedFullscreenMode=currentFullscreenStrategy.scaleMode==2;var inPixelPerfectFullscreenMode=currentFullscreenStrategy.canvasResolutionScaleMode!=0;var inCenteredWithoutScalingFullscreenMode=currentFullscreenStrategy.scaleMode==3;var screenWidth=inHiDPIFullscreenMode?Math.round(innerWidth*dpr):innerWidth;var screenHeight=inHiDPIFullscreenMode?Math.round(innerHeight*dpr):innerHeight;var w=screenWidth;var h=screenHeight;var canvas=currentFullscreenStrategy.target;var canvasSize=getCanvasElementSize(canvas);var x=canvasSize[0];var y=canvasSize[1];var topMargin;if(inAspectRatioFixedFullscreenMode){if(w*yx*h)w=h*x/y|0;topMargin=(screenHeight-h)/2|0}if(inPixelPerfectFullscreenMode){setCanvasElementSize(canvas,w,h);if(canvas.GLctxObject)canvas.GLctxObject.GLctx.viewport(0,0,w,h)}if(inHiDPIFullscreenMode){topMargin/=dpr;w/=dpr;h/=dpr;w=Math.round(w*1e4)/1e4;h=Math.round(h*1e4)/1e4;topMargin=Math.round(topMargin*1e4)/1e4}if(inCenteredWithoutScalingFullscreenMode){var t=(innerHeight-jstoi_q(canvas.style.height))/2;var b=(innerWidth-jstoi_q(canvas.style.width))/2;setLetterbox(canvas,t,b)}else{canvas.style.width=w+"px";canvas.style.height=h+"px";var b=(innerWidth-w)/2;setLetterbox(canvas,topMargin,b)}if(!inCenteredWithoutScalingFullscreenMode&¤tFullscreenStrategy.canvasResizedCallback){getWasmTableEntry(currentFullscreenStrategy.canvasResizedCallback)(37,0,currentFullscreenStrategy.canvasResizedCallbackUserData)}};var doRequestFullscreen=(target,strategy)=>{if(!JSEvents.fullscreenEnabled())return-1;target=findEventTarget(target);if(!target)return-4;if(!target.requestFullscreen&&!target.webkitRequestFullscreen){return-3}if(!JSEvents.canPerformEventHandlerRequests()){if(strategy.deferUntilInEventHandler){JSEvents.deferCall(JSEvents_requestFullscreen,1,[target,strategy]);return 1}return-2}return JSEvents_requestFullscreen(target,strategy)};function _emscripten_request_fullscreen(target,deferUntilInEventHandler){target>>>=0;var strategy={scaleMode:0,canvasResolutionScaleMode:0,filteringMode:0,deferUntilInEventHandler,canvasResizedCallbackTargetThread:2};return doRequestFullscreen(target,strategy)}_emscripten_request_fullscreen.sig="ipi";function _emscripten_request_fullscreen_strategy(target,deferUntilInEventHandler,fullscreenStrategy){target>>>=0;fullscreenStrategy>>>=0;var strategy={scaleMode:HEAP32[fullscreenStrategy>>>2>>>0],canvasResolutionScaleMode:HEAP32[fullscreenStrategy+4>>>2>>>0],filteringMode:HEAP32[fullscreenStrategy+8>>>2>>>0],deferUntilInEventHandler,canvasResizedCallback:HEAP32[fullscreenStrategy+12>>>2>>>0],canvasResizedCallbackUserData:HEAP32[fullscreenStrategy+16>>>2>>>0]};return doRequestFullscreen(target,strategy)}_emscripten_request_fullscreen_strategy.sig="ipip";function _emscripten_enter_soft_fullscreen(target,fullscreenStrategy){target>>>=0;fullscreenStrategy>>>=0;target=findEventTarget(target);if(!target)return-4;var strategy={scaleMode:HEAP32[fullscreenStrategy>>>2>>>0],canvasResolutionScaleMode:HEAP32[fullscreenStrategy+4>>>2>>>0],filteringMode:HEAP32[fullscreenStrategy+8>>>2>>>0],canvasResizedCallback:HEAP32[fullscreenStrategy+12>>>2>>>0],canvasResizedCallbackUserData:HEAP32[fullscreenStrategy+16>>>2>>>0],target,softFullscreen:true};var restoreOldStyle=JSEvents_resizeCanvasForFullscreen(target,strategy);document.documentElement.style.overflow="hidden";document.body.scroll="no";document.body.style.margin="0px";var hiddenElements=hideEverythingExceptGivenElement(target);function restoreWindowedState(){restoreOldStyle();restoreHiddenElements(hiddenElements);removeEventListener("resize",softFullscreenResizeWebGLRenderTarget);if(strategy.canvasResizedCallback){getWasmTableEntry(strategy.canvasResizedCallback)(37,0,strategy.canvasResizedCallbackUserData)}currentFullscreenStrategy=0}restoreOldWindowedStyle=restoreWindowedState;currentFullscreenStrategy=strategy;addEventListener("resize",softFullscreenResizeWebGLRenderTarget);if(strategy.canvasResizedCallback){getWasmTableEntry(strategy.canvasResizedCallback)(37,0,strategy.canvasResizedCallbackUserData)}return 0}_emscripten_enter_soft_fullscreen.sig="ipp";var _emscripten_exit_soft_fullscreen=()=>{restoreOldWindowedStyle?.();restoreOldWindowedStyle=null;return 0};_emscripten_exit_soft_fullscreen.sig="i";var _emscripten_exit_fullscreen=()=>{if(!JSEvents.fullscreenEnabled())return-1;JSEvents.removeDeferredCalls(JSEvents_requestFullscreen);var d=specialHTMLTargets[1];if(d.exitFullscreen){d.fullscreenElement&&d.exitFullscreen()}else if(d.webkitExitFullscreen){d.webkitFullscreenElement&&d.webkitExitFullscreen()}else{return-1}return 0};_emscripten_exit_fullscreen.sig="i";var fillPointerlockChangeEventData=eventStruct=>{var pointerLockElement=document.pointerLockElement||document.mozPointerLockElement||document.webkitPointerLockElement||document.msPointerLockElement;var isPointerlocked=!!pointerLockElement;HEAP8[eventStruct>>>0]=isPointerlocked;var nodeName=JSEvents.getNodeNameForTarget(pointerLockElement);var id=pointerLockElement?.id||"";stringToUTF8(nodeName,eventStruct+1,128);stringToUTF8(id,eventStruct+129,128)};var registerPointerlockChangeEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.pointerlockChangeEvent||=_malloc(257);var pointerlockChangeEventHandlerFunc=(e=event)=>{var pointerlockChangeEvent=JSEvents.pointerlockChangeEvent;fillPointerlockChangeEventData(pointerlockChangeEvent);if(getWasmTableEntry(callbackfunc)(eventTypeId,pointerlockChangeEvent,userData))e.preventDefault()};var eventHandler={target,eventTypeString,callbackfunc,handlerFunc:pointerlockChangeEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_pointerlockchange_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;if(!document||!document.body||!document.body.requestPointerLock&&!document.body.mozRequestPointerLock&&!document.body.webkitRequestPointerLock&&!document.body.msRequestPointerLock){return-1}target=findEventTarget(target);if(!target)return-4;registerPointerlockChangeEventCallback(target,userData,useCapture,callbackfunc,20,"mozpointerlockchange",targetThread);registerPointerlockChangeEventCallback(target,userData,useCapture,callbackfunc,20,"webkitpointerlockchange",targetThread);registerPointerlockChangeEventCallback(target,userData,useCapture,callbackfunc,20,"mspointerlockchange",targetThread);return registerPointerlockChangeEventCallback(target,userData,useCapture,callbackfunc,20,"pointerlockchange",targetThread)}_emscripten_set_pointerlockchange_callback_on_thread.sig="ippipp";var registerPointerlockErrorEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{var pointerlockErrorEventHandlerFunc=(e=event)=>{if(getWasmTableEntry(callbackfunc)(eventTypeId,0,userData))e.preventDefault()};var eventHandler={target,eventTypeString,callbackfunc,handlerFunc:pointerlockErrorEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_pointerlockerror_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;if(!document||!document.body.requestPointerLock&&!document.body.mozRequestPointerLock&&!document.body.webkitRequestPointerLock&&!document.body.msRequestPointerLock){return-1}target=findEventTarget(target);if(!target)return-4;registerPointerlockErrorEventCallback(target,userData,useCapture,callbackfunc,38,"mozpointerlockerror",targetThread);registerPointerlockErrorEventCallback(target,userData,useCapture,callbackfunc,38,"webkitpointerlockerror",targetThread);registerPointerlockErrorEventCallback(target,userData,useCapture,callbackfunc,38,"mspointerlockerror",targetThread);return registerPointerlockErrorEventCallback(target,userData,useCapture,callbackfunc,38,"pointerlockerror",targetThread)}_emscripten_set_pointerlockerror_callback_on_thread.sig="ippipp";function _emscripten_get_pointerlock_status(pointerlockStatus){pointerlockStatus>>>=0;if(pointerlockStatus)fillPointerlockChangeEventData(pointerlockStatus);if(!document.body||!document.body.requestPointerLock&&!document.body.mozRequestPointerLock&&!document.body.webkitRequestPointerLock&&!document.body.msRequestPointerLock){return-1}return 0}_emscripten_get_pointerlock_status.sig="ip";var requestPointerLock=target=>{if(target.requestPointerLock){target.requestPointerLock()}else{if(document.body.requestPointerLock){return-3}return-1}return 0};function _emscripten_request_pointerlock(target,deferUntilInEventHandler){target>>>=0;target=findEventTarget(target);if(!target)return-4;if(!target.requestPointerLock){return-1}if(!JSEvents.canPerformEventHandlerRequests()){if(deferUntilInEventHandler){JSEvents.deferCall(requestPointerLock,2,[target]);return 1}return-2}return requestPointerLock(target)}_emscripten_request_pointerlock.sig="ipi";var _emscripten_exit_pointerlock=()=>{JSEvents.removeDeferredCalls(requestPointerLock);if(document.exitPointerLock){document.exitPointerLock()}else{return-1}return 0};_emscripten_exit_pointerlock.sig="i";var _emscripten_vibrate=msecs=>{if(!navigator.vibrate)return-1;navigator.vibrate(msecs);return 0};_emscripten_vibrate.sig="ii";function _emscripten_vibrate_pattern(msecsArray,numEntries){msecsArray>>>=0;if(!navigator.vibrate)return-1;var vibrateList=[];for(var i=0;i>>2>>>0];vibrateList.push(msecs)}navigator.vibrate(vibrateList);return 0}_emscripten_vibrate_pattern.sig="ipi";var fillVisibilityChangeEventData=eventStruct=>{var visibilityStates=["hidden","visible","prerender","unloaded"];var visibilityState=visibilityStates.indexOf(document.visibilityState);HEAP8[eventStruct>>>0]=document.hidden;HEAP32[eventStruct+4>>>2>>>0]=visibilityState};var registerVisibilityChangeEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.visibilityChangeEvent||=_malloc(8);var visibilityChangeEventHandlerFunc=(e=event)=>{var visibilityChangeEvent=JSEvents.visibilityChangeEvent;fillVisibilityChangeEventData(visibilityChangeEvent);if(getWasmTableEntry(callbackfunc)(eventTypeId,visibilityChangeEvent,userData))e.preventDefault()};var eventHandler={target,eventTypeString,callbackfunc,handlerFunc:visibilityChangeEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_visibilitychange_callback_on_thread(userData,useCapture,callbackfunc,targetThread){userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;if(!specialHTMLTargets[1]){return-4}return registerVisibilityChangeEventCallback(specialHTMLTargets[1],userData,useCapture,callbackfunc,21,"visibilitychange",targetThread)}_emscripten_set_visibilitychange_callback_on_thread.sig="ipipp";function _emscripten_get_visibility_status(visibilityStatus){visibilityStatus>>>=0;if(typeof document.visibilityState=="undefined"&&typeof document.hidden=="undefined"){return-1}fillVisibilityChangeEventData(visibilityStatus);return 0}_emscripten_get_visibility_status.sig="ip";var registerTouchEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.touchEvent||=_malloc(1552);target=findEventTarget(target);var touchEventHandlerFunc=e=>{var t,touches={},et=e.touches;for(let t of et){t.isChanged=t.onTarget=0;touches[t.identifier]=t}for(let t of e.changedTouches){t.isChanged=1;touches[t.identifier]=t}for(let t of e.targetTouches){touches[t.identifier].onTarget=1}var touchEvent=JSEvents.touchEvent;HEAPF64[touchEvent>>>3>>>0]=e.timeStamp;HEAP8[touchEvent+12>>>0]=e.ctrlKey;HEAP8[touchEvent+13>>>0]=e.shiftKey;HEAP8[touchEvent+14>>>0]=e.altKey;HEAP8[touchEvent+15>>>0]=e.metaKey;var idx=touchEvent+16;var targetRect=getBoundingClientRect(target);var numTouches=0;for(let t of Object.values(touches)){var idx32=idx>>>2;HEAP32[idx32+0>>>0]=t.identifier;HEAP32[idx32+1>>>0]=t.screenX;HEAP32[idx32+2>>>0]=t.screenY;HEAP32[idx32+3>>>0]=t.clientX;HEAP32[idx32+4>>>0]=t.clientY;HEAP32[idx32+5>>>0]=t.pageX;HEAP32[idx32+6>>>0]=t.pageY;HEAP8[idx+28>>>0]=t.isChanged;HEAP8[idx+29>>>0]=t.onTarget;HEAP32[idx32+8>>>0]=t.clientX-(targetRect.left|0);HEAP32[idx32+9>>>0]=t.clientY-(targetRect.top|0);idx+=48;if(++numTouches>31){break}}HEAP32[touchEvent+8>>>2>>>0]=numTouches;if(getWasmTableEntry(callbackfunc)(eventTypeId,touchEvent,userData))e.preventDefault()};var eventHandler={target,allowsDeferredCalls:eventTypeString=="touchstart"||eventTypeString=="touchend",eventTypeString,callbackfunc,handlerFunc:touchEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_touchstart_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerTouchEventCallback(target,userData,useCapture,callbackfunc,22,"touchstart",targetThread)}_emscripten_set_touchstart_callback_on_thread.sig="ippipp";function _emscripten_set_touchend_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerTouchEventCallback(target,userData,useCapture,callbackfunc,23,"touchend",targetThread)}_emscripten_set_touchend_callback_on_thread.sig="ippipp";function _emscripten_set_touchmove_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerTouchEventCallback(target,userData,useCapture,callbackfunc,24,"touchmove",targetThread)}_emscripten_set_touchmove_callback_on_thread.sig="ippipp";function _emscripten_set_touchcancel_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;return registerTouchEventCallback(target,userData,useCapture,callbackfunc,25,"touchcancel",targetThread)}_emscripten_set_touchcancel_callback_on_thread.sig="ippipp";var fillGamepadEventData=(eventStruct,e)=>{HEAPF64[eventStruct>>>3>>>0]=e.timestamp;for(var i=0;i>>3>>>0]=e.axes[i]}for(var i=0;i>>3>>>0]=e.buttons[i].value}else{HEAPF64[eventStruct+i*8+528>>>3>>>0]=e.buttons[i]}}for(var i=0;i>>0]=e.buttons[i].pressed}else{HEAP8[eventStruct+i+1040>>>0]=e.buttons[i]==1}}HEAP8[eventStruct+1104>>>0]=e.connected;HEAP32[eventStruct+1108>>>2>>>0]=e.index;HEAP32[eventStruct+8>>>2>>>0]=e.axes.length;HEAP32[eventStruct+12>>>2>>>0]=e.buttons.length;stringToUTF8(e.id,eventStruct+1112,64);stringToUTF8(e.mapping,eventStruct+1176,64)};var registerGamepadEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.gamepadEvent||=_malloc(1240);var gamepadEventHandlerFunc=(e=event)=>{var gamepadEvent=JSEvents.gamepadEvent;fillGamepadEventData(gamepadEvent,e["gamepad"]);if(getWasmTableEntry(callbackfunc)(eventTypeId,gamepadEvent,userData))e.preventDefault()};var eventHandler={target:findEventTarget(target),allowsDeferredCalls:true,eventTypeString,callbackfunc,handlerFunc:gamepadEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};var _emscripten_sample_gamepad_data=()=>{try{if(navigator.getGamepads)return(JSEvents.lastGamepadState=navigator.getGamepads())?0:-1}catch(e){navigator.getGamepads=null}return-1};_emscripten_sample_gamepad_data.sig="i";function _emscripten_set_gamepadconnected_callback_on_thread(userData,useCapture,callbackfunc,targetThread){userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;if(_emscripten_sample_gamepad_data())return-1;return registerGamepadEventCallback(2,userData,useCapture,callbackfunc,26,"gamepadconnected",targetThread)}_emscripten_set_gamepadconnected_callback_on_thread.sig="ipipp";function _emscripten_set_gamepaddisconnected_callback_on_thread(userData,useCapture,callbackfunc,targetThread){userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;if(_emscripten_sample_gamepad_data())return-1;return registerGamepadEventCallback(2,userData,useCapture,callbackfunc,27,"gamepaddisconnected",targetThread)}_emscripten_set_gamepaddisconnected_callback_on_thread.sig="ipipp";var _emscripten_get_num_gamepads=()=>JSEvents.lastGamepadState.length;_emscripten_get_num_gamepads.sig="i";function _emscripten_get_gamepad_status(index,gamepadState){gamepadState>>>=0;if(index<0||index>=JSEvents.lastGamepadState.length)return-5;if(!JSEvents.lastGamepadState[index])return-7;fillGamepadEventData(gamepadState,JSEvents.lastGamepadState[index]);return 0}_emscripten_get_gamepad_status.sig="iip";var registerBeforeUnloadEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString)=>{var beforeUnloadEventHandlerFunc=(e=event)=>{var confirmationMessage=getWasmTableEntry(callbackfunc)(eventTypeId,0,userData);if(confirmationMessage){confirmationMessage=UTF8ToString(confirmationMessage)}if(confirmationMessage){e.preventDefault();e.returnValue=confirmationMessage;return confirmationMessage}};var eventHandler={target:findEventTarget(target),eventTypeString,callbackfunc,handlerFunc:beforeUnloadEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_beforeunload_callback_on_thread(userData,callbackfunc,targetThread){userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;if(typeof onbeforeunload=="undefined")return-1;if(targetThread!==1)return-5;return registerBeforeUnloadEventCallback(2,userData,true,callbackfunc,28,"beforeunload")}_emscripten_set_beforeunload_callback_on_thread.sig="ippp";var fillBatteryEventData=(eventStruct,e)=>{HEAPF64[eventStruct>>>3>>>0]=e.chargingTime;HEAPF64[eventStruct+8>>>3>>>0]=e.dischargingTime;HEAPF64[eventStruct+16>>>3>>>0]=e.level;HEAP8[eventStruct+24>>>0]=e.charging};var battery=()=>navigator.battery||navigator.mozBattery||navigator.webkitBattery;var registerBatteryEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{JSEvents.batteryEvent||=_malloc(32);var batteryEventHandlerFunc=(e=event)=>{var batteryEvent=JSEvents.batteryEvent;fillBatteryEventData(batteryEvent,battery());if(getWasmTableEntry(callbackfunc)(eventTypeId,batteryEvent,userData))e.preventDefault()};var eventHandler={target:findEventTarget(target),eventTypeString,callbackfunc,handlerFunc:batteryEventHandlerFunc,useCapture};return JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_batterychargingchange_callback_on_thread(userData,callbackfunc,targetThread){userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;if(!battery())return-1;return registerBatteryEventCallback(battery(),userData,true,callbackfunc,29,"chargingchange",targetThread)}_emscripten_set_batterychargingchange_callback_on_thread.sig="ippp";function _emscripten_set_batterylevelchange_callback_on_thread(userData,callbackfunc,targetThread){userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;if(!battery())return-1;return registerBatteryEventCallback(battery(),userData,true,callbackfunc,30,"levelchange",targetThread)}_emscripten_set_batterylevelchange_callback_on_thread.sig="ippp";function _emscripten_get_battery_status(batteryState){batteryState>>>=0;if(!battery())return-1;fillBatteryEventData(batteryState,battery());return 0}_emscripten_get_battery_status.sig="ip";function _emscripten_set_element_css_size(target,width,height){target>>>=0;target=findEventTarget(target);if(!target)return-4;target.style.width=width+"px";target.style.height=height+"px";return 0}_emscripten_set_element_css_size.sig="ipdd";function _emscripten_get_element_css_size(target,width,height){target>>>=0;width>>>=0;height>>>=0;target=findEventTarget(target);if(!target)return-4;var rect=getBoundingClientRect(target);HEAPF64[width>>>3>>>0]=rect.width;HEAPF64[height>>>3>>>0]=rect.height;return 0}_emscripten_get_element_css_size.sig="ippp";var _emscripten_html5_remove_all_event_listeners=()=>JSEvents.removeAllEventListeners();_emscripten_html5_remove_all_event_listeners.sig="v";var _emscripten_request_animation_frame=function(cb,userData){cb>>>=0;userData>>>=0;return requestAnimationFrame(timeStamp=>getWasmTableEntry(cb)(timeStamp,userData))};_emscripten_request_animation_frame.sig="ipp";var _emscripten_cancel_animation_frame=id=>cancelAnimationFrame(id);_emscripten_cancel_animation_frame.sig="vi";function _emscripten_request_animation_frame_loop(cb,userData){cb>>>=0;userData>>>=0;function tick(timeStamp){if(getWasmTableEntry(cb)(timeStamp,userData)){requestAnimationFrame(tick)}}return requestAnimationFrame(tick)}_emscripten_request_animation_frame_loop.sig="vpp";var _emscripten_get_device_pixel_ratio=()=>typeof devicePixelRatio=="number"&&devicePixelRatio||1;_emscripten_get_device_pixel_ratio.sig="d";function _emscripten_get_callstack(flags,str,maxbytes){str>>>=0;var callstack=getCallstack(flags);if(!str||maxbytes<=0){return lengthBytesUTF8(callstack)+1}var bytesWrittenExcludingNull=stringToUTF8(callstack,str,maxbytes);return bytesWrittenExcludingNull+1}_emscripten_get_callstack.sig="iipi";var convertFrameToPC=frame=>{abort("Cannot use convertFrameToPC (needed by __builtin_return_address) without -sUSE_OFFSET_CONVERTER");return 0};function _emscripten_return_address(level){var callstack=jsStackTrace().split("\n");if(callstack[0]=="Error"){callstack.shift()}var caller=callstack[level+3];return convertFrameToPC(caller)}_emscripten_return_address.sig="pi";var UNWIND_CACHE={};var saveInUnwindCache=callstack=>{callstack.forEach(frame=>{var pc=convertFrameToPC(frame);if(pc){UNWIND_CACHE[pc]=frame}})};function _emscripten_stack_snapshot(){var callstack=jsStackTrace().split("\n");if(callstack[0]=="Error"){callstack.shift()}saveInUnwindCache(callstack);UNWIND_CACHE.last_addr=convertFrameToPC(callstack[3]);UNWIND_CACHE.last_stack=callstack;return UNWIND_CACHE.last_addr}_emscripten_stack_snapshot.sig="p";function _emscripten_stack_unwind_buffer(addr,buffer,count){addr>>>=0;buffer>>>=0;var stack;if(UNWIND_CACHE.last_addr==addr){stack=UNWIND_CACHE.last_stack}else{stack=jsStackTrace().split("\n");if(stack[0]=="Error"){stack.shift()}saveInUnwindCache(stack)}var offset=3;while(stack[offset]&&convertFrameToPC(stack[offset])!=addr){++offset}for(var i=0;i>>2>>>0]=convertFrameToPC(stack[i+offset])}return i}_emscripten_stack_unwind_buffer.sig="ippi";function _emscripten_pc_get_function(pc){pc>>>=0;abort("Cannot use emscripten_pc_get_function without -sUSE_OFFSET_CONVERTER");return 0}_emscripten_pc_get_function.sig="pp";var convertPCtoSourceLocation=pc=>{if(UNWIND_CACHE.last_get_source_pc==pc)return UNWIND_CACHE.last_source;var match;var source;if(!source){var frame=UNWIND_CACHE[pc];if(!frame)return null;if(match=/\((.*):(\d+):(\d+)\)$/.exec(frame)){source={file:match[1],line:match[2],column:match[3]}}else if(match=/@(.*):(\d+):(\d+)/.exec(frame)){source={file:match[1],line:match[2],column:match[3]}}}UNWIND_CACHE.last_get_source_pc=pc;UNWIND_CACHE.last_source=source;return source};function _emscripten_pc_get_file(pc){pc>>>=0;var result=convertPCtoSourceLocation(pc);if(!result)return 0;if(_emscripten_pc_get_file.ret)_free(_emscripten_pc_get_file.ret);_emscripten_pc_get_file.ret=stringToNewUTF8(result.file);return _emscripten_pc_get_file.ret}_emscripten_pc_get_file.sig="pp";function _emscripten_pc_get_line(pc){pc>>>=0;var result=convertPCtoSourceLocation(pc);return result?result.line:0}_emscripten_pc_get_line.sig="ip";function _emscripten_pc_get_column(pc){pc>>>=0;var result=convertPCtoSourceLocation(pc);return result?result.column||0:0}_emscripten_pc_get_column.sig="ip";var wasiRightsToMuslOFlags=rights=>{if(rights&2&&rights&64){return 2}if(rights&2){return 0}if(rights&64){return 1}throw new FS.ErrnoError(28)};var wasiOFlagsToMuslOFlags=oflags=>{var musl_oflags=0;if(oflags&1){musl_oflags|=64}if(oflags&8){musl_oflags|=512}if(oflags&2){musl_oflags|=65536}if(oflags&4){musl_oflags|=128}return musl_oflags};var _emscripten_unwind_to_js_event_loop=()=>{throw"unwind"};_emscripten_unwind_to_js_event_loop.sig="v";var safeSetTimeout=(func,timeout)=>{runtimeKeepalivePush();return setTimeout(()=>{runtimeKeepalivePop();callUserCallback(func)},timeout)};var setImmediateWrapped=func=>{setImmediateWrapped.mapping||=[];var id=setImmediateWrapped.mapping.length;setImmediateWrapped.mapping[id]=setImmediate(()=>{setImmediateWrapped.mapping[id]=undefined;func()});return id};var _emscripten_set_main_loop_timing=(mode,value)=>{MainLoop.timingMode=mode;MainLoop.timingValue=value;if(!MainLoop.func){return 1}if(!MainLoop.running){runtimeKeepalivePush();MainLoop.running=true}if(mode==0){MainLoop.scheduler=function MainLoop_scheduler_setTimeout(){var timeUntilNextTick=Math.max(0,MainLoop.tickStartTime+value-_emscripten_get_now())|0;setTimeout(MainLoop.runner,timeUntilNextTick)};MainLoop.method="timeout"}else if(mode==1){MainLoop.scheduler=function MainLoop_scheduler_rAF(){MainLoop.requestAnimationFrame(MainLoop.runner)};MainLoop.method="rAF"}else if(mode==2){if(typeof MainLoop.setImmediate=="undefined"){if(typeof setImmediate=="undefined"){var setImmediates=[];var emscriptenMainLoopMessageId="setimmediate";var MainLoop_setImmediate_messageHandler=event=>{if(event.data===emscriptenMainLoopMessageId||event.data.target===emscriptenMainLoopMessageId){event.stopPropagation();setImmediates.shift()()}};addEventListener("message",MainLoop_setImmediate_messageHandler,true);MainLoop.setImmediate=func=>{setImmediates.push(func);if(ENVIRONMENT_IS_WORKER){Module["setImmediates"]??=[];Module["setImmediates"].push(func);postMessage({target:emscriptenMainLoopMessageId})}else postMessage(emscriptenMainLoopMessageId,"*")}}else{MainLoop.setImmediate=setImmediate}}MainLoop.scheduler=function MainLoop_scheduler_setImmediate(){MainLoop.setImmediate(MainLoop.runner)};MainLoop.method="immediate"}return 0};_emscripten_set_main_loop_timing.sig="iii";var setMainLoop=(iterFunc,fps,simulateInfiniteLoop,arg,noSetTiming)=>{MainLoop.func=iterFunc;MainLoop.arg=arg;var thisMainLoopId=MainLoop.currentlyRunningMainloop;function checkIsRunning(){if(thisMainLoopId0){var start=Date.now();var blocker=MainLoop.queue.shift();blocker.func(blocker.arg);if(MainLoop.remainingBlockers){var remaining=MainLoop.remainingBlockers;var next=remaining%1==0?remaining-1:Math.floor(remaining);if(blocker.counted){MainLoop.remainingBlockers=next}else{next=next+.5;MainLoop.remainingBlockers=(8*remaining+next)/9}}MainLoop.updateStatus();if(!checkIsRunning())return;setTimeout(MainLoop.runner,0);return}if(!checkIsRunning())return;MainLoop.currentFrameNumber=MainLoop.currentFrameNumber+1|0;if(MainLoop.timingMode==1&&MainLoop.timingValue>1&&MainLoop.currentFrameNumber%MainLoop.timingValue!=0){MainLoop.scheduler();return}else if(MainLoop.timingMode==0){MainLoop.tickStartTime=_emscripten_get_now()}MainLoop.runIter(iterFunc);if(!checkIsRunning())return;MainLoop.scheduler()};if(!noSetTiming){if(fps>0){_emscripten_set_main_loop_timing(0,1e3/fps)}else{_emscripten_set_main_loop_timing(1,1)}MainLoop.scheduler()}if(simulateInfiniteLoop){throw"unwind"}};var MainLoop={running:false,scheduler:null,method:"",currentlyRunningMainloop:0,func:null,arg:0,timingMode:0,timingValue:0,currentFrameNumber:0,queue:[],preMainLoop:[],postMainLoop:[],pause(){MainLoop.scheduler=null;MainLoop.currentlyRunningMainloop++},resume(){MainLoop.currentlyRunningMainloop++;var timingMode=MainLoop.timingMode;var timingValue=MainLoop.timingValue;var func=MainLoop.func;MainLoop.func=null;setMainLoop(func,0,false,MainLoop.arg,true);_emscripten_set_main_loop_timing(timingMode,timingValue);MainLoop.scheduler()},updateStatus(){if(Module["setStatus"]){var message=Module["statusMessage"]||"Please wait...";var remaining=MainLoop.remainingBlockers??0;var expected=MainLoop.expectedBlockers??0;if(remaining){if(remaining=MainLoop.nextRAF){MainLoop.nextRAF+=1e3/60}}var delay=Math.max(MainLoop.nextRAF-now,0);setTimeout(func,delay)},requestAnimationFrame(func){if(typeof requestAnimationFrame=="function"){requestAnimationFrame(func);return}var RAF=MainLoop.fakeRequestAnimationFrame;RAF(func)}};var safeRequestAnimationFrame=func=>{runtimeKeepalivePush();return MainLoop.requestAnimationFrame(()=>{runtimeKeepalivePop();callUserCallback(func)})};var clearImmediateWrapped=id=>{clearImmediate(setImmediateWrapped.mapping[id]);setImmediateWrapped.mapping[id]=undefined};var emClearImmediate;var emSetImmediate;var emClearImmediate_deps=["$emSetImmediate"];var _emscripten_set_immediate=function(cb,userData){cb>>>=0;userData>>>=0;runtimeKeepalivePush();return emSetImmediate(()=>{runtimeKeepalivePop();callUserCallback(()=>getWasmTableEntry(cb)(userData))})};_emscripten_set_immediate.sig="ipp";var _emscripten_clear_immediate=id=>{runtimeKeepalivePop();emClearImmediate(id)};_emscripten_clear_immediate.sig="vi";var _emscripten_set_immediate_loop=function(cb,userData){cb>>>=0;userData>>>=0;function tick(){callUserCallback(()=>{if(getWasmTableEntry(cb)(userData)){emSetImmediate(tick)}else{runtimeKeepalivePop()}})}runtimeKeepalivePush();emSetImmediate(tick)};_emscripten_set_immediate_loop.sig="vpp";var _emscripten_set_timeout=function(cb,msecs,userData){cb>>>=0;userData>>>=0;return safeSetTimeout(()=>getWasmTableEntry(cb)(userData),msecs)};_emscripten_set_timeout.sig="ipdp";var _emscripten_clear_timeout=clearTimeout;_emscripten_clear_timeout.sig="vi";var _emscripten_set_timeout_loop=function(cb,msecs,userData){cb>>>=0;userData>>>=0;function tick(){var t=_emscripten_get_now();var n=t+msecs;runtimeKeepalivePop();callUserCallback(()=>{if(getWasmTableEntry(cb)(t,userData)){runtimeKeepalivePush();var remaining=n-_emscripten_get_now();remaining=Math.max(0,remaining);setTimeout(tick,remaining)}})}runtimeKeepalivePush();return setTimeout(tick,0)};_emscripten_set_timeout_loop.sig="vpdp";var _emscripten_set_interval=function(cb,msecs,userData){cb>>>=0;userData>>>=0;runtimeKeepalivePush();return setInterval(()=>{callUserCallback(()=>getWasmTableEntry(cb)(userData))},msecs)};_emscripten_set_interval.sig="ipdp";var _emscripten_clear_interval=id=>{runtimeKeepalivePop();clearInterval(id)};_emscripten_clear_interval.sig="vi";var _emscripten_async_call=function(func,arg,millis){func>>>=0;arg>>>=0;var wrapper=()=>getWasmTableEntry(func)(arg);if(millis>=0||ENVIRONMENT_IS_NODE){safeSetTimeout(wrapper,millis)}else{safeRequestAnimationFrame(wrapper)}};_emscripten_async_call.sig="vppi";var registerPostMainLoop=f=>{typeof MainLoop!="undefined"&&MainLoop.postMainLoop.push(f)};var registerPreMainLoop=f=>{typeof MainLoop!="undefined"&&MainLoop.preMainLoop.push(f)};function _emscripten_get_main_loop_timing(mode,value){mode>>>=0;value>>>=0;if(mode)HEAP32[mode>>>2>>>0]=MainLoop.timingMode;if(value)HEAP32[value>>>2>>>0]=MainLoop.timingValue}_emscripten_get_main_loop_timing.sig="vpp";function _emscripten_set_main_loop(func,fps,simulateInfiniteLoop){func>>>=0;var iterFunc=getWasmTableEntry(func);setMainLoop(iterFunc,fps,simulateInfiniteLoop)}_emscripten_set_main_loop.sig="vpii";var _emscripten_set_main_loop_arg=function(func,arg,fps,simulateInfiniteLoop){func>>>=0;arg>>>=0;var iterFunc=()=>getWasmTableEntry(func)(arg);setMainLoop(iterFunc,fps,simulateInfiniteLoop,arg)};_emscripten_set_main_loop_arg.sig="vppii";var _emscripten_cancel_main_loop=()=>{MainLoop.pause();MainLoop.func=null};_emscripten_cancel_main_loop.sig="v";var _emscripten_pause_main_loop=()=>MainLoop.pause();_emscripten_pause_main_loop.sig="v";var _emscripten_resume_main_loop=()=>MainLoop.resume();_emscripten_resume_main_loop.sig="v";var __emscripten_push_main_loop_blocker=function(func,arg,name){func>>>=0;arg>>>=0;name>>>=0;MainLoop.queue.push({func:()=>{getWasmTableEntry(func)(arg)},name:UTF8ToString(name),counted:true});MainLoop.updateStatus()};__emscripten_push_main_loop_blocker.sig="vppp";var __emscripten_push_uncounted_main_loop_blocker=function(func,arg,name){func>>>=0;arg>>>=0;name>>>=0;MainLoop.queue.push({func:()=>{getWasmTableEntry(func)(arg)},name:UTF8ToString(name),counted:false});MainLoop.updateStatus()};__emscripten_push_uncounted_main_loop_blocker.sig="vppp";var _emscripten_set_main_loop_expected_blockers=num=>{MainLoop.expectedBlockers=num;MainLoop.remainingBlockers=num;MainLoop.updateStatus()};_emscripten_set_main_loop_expected_blockers.sig="vi";var idsToPromises=(idBuf,size)=>{var promises=[];for(var i=0;i>>2>>>0];promises[i]=getPromise(id)}return promises};var makePromiseCallback=(callback,userData)=>value=>{runtimeKeepalivePop();var stack=stackSave();var resultPtr=stackAlloc(POINTER_SIZE);HEAPU32[resultPtr>>>2>>>0]=0;try{var result=getWasmTableEntry(callback)(resultPtr,userData,value);var resultVal=HEAPU32[resultPtr>>>2>>>0]}catch(e){if(typeof e!="number"){throw 0}throw e}finally{stackRestore(stack)}switch(result){case 0:return resultVal;case 1:return getPromise(resultVal);case 2:var ret=getPromise(resultVal);_emscripten_promise_destroy(resultVal);return ret;case 3:throw resultVal}};function _emscripten_promise_then(id,onFulfilled,onRejected,userData){id>>>=0;onFulfilled>>>=0;onRejected>>>=0;userData>>>=0;runtimeKeepalivePush();var promise=getPromise(id);var newId=promiseMap.allocate({promise:promise.then(makePromiseCallback(onFulfilled,userData),makePromiseCallback(onRejected,userData))});return newId}_emscripten_promise_then.sig="ppppp";var _emscripten_promise_all=function(idBuf,resultBuf,size){idBuf>>>=0;resultBuf>>>=0;size>>>=0;var promises=idsToPromises(idBuf,size);var id=promiseMap.allocate({promise:Promise.all(promises).then(results=>{if(resultBuf){for(var i=0;i>>2>>>0]=result}}return resultBuf})});return id};_emscripten_promise_all.sig="pppp";var setPromiseResult=(ptr,fulfill,value)=>{var result=fulfill?0:3;HEAP32[ptr>>>2>>>0]=result;HEAPU32[ptr+4>>>2>>>0]=value};var _emscripten_promise_all_settled=function(idBuf,resultBuf,size){idBuf>>>=0;resultBuf>>>=0;size>>>=0;var promises=idsToPromises(idBuf,size);var id=promiseMap.allocate({promise:Promise.allSettled(promises).then(results=>{if(resultBuf){var offset=resultBuf;for(var i=0;i>>=0;errorBuf>>>=0;size>>>=0;var promises=idsToPromises(idBuf,size);var id=promiseMap.allocate({promise:Promise.any(promises).catch(err=>{if(errorBuf){for(var i=0;i>>2>>>0]=err.errors[i]}}throw errorBuf})});return id};_emscripten_promise_any.sig="pppp";function _emscripten_promise_race(idBuf,size){idBuf>>>=0;size>>>=0;var promises=idsToPromises(idBuf,size);var id=promiseMap.allocate({promise:Promise.race(promises)});return id}_emscripten_promise_race.sig="ppp";function _emscripten_promise_await(returnValuePtr,id){returnValuePtr>>>=0;id>>>=0;abort("emscripten_promise_await is only available with ASYNCIFY")}_emscripten_promise_await.sig="vpp";var getExceptionMessageCommon=ptr=>{var sp=stackSave();var type_addr_addr=stackAlloc(4);var message_addr_addr=stackAlloc(4);___get_exception_message(ptr,type_addr_addr,message_addr_addr);var type_addr=HEAPU32[type_addr_addr>>>2>>>0];var message_addr=HEAPU32[message_addr_addr>>>2>>>0];var type=UTF8ToString(type_addr);_free(type_addr);var message;if(message_addr){message=UTF8ToString(message_addr);_free(message_addr)}stackRestore(sp);return[type,message]};var getCppExceptionTag=()=>___cpp_exception;var getCppExceptionThrownObjectFromWebAssemblyException=ex=>{var unwind_header=ex.getArg(getCppExceptionTag(),0);return ___thrown_object_from_unwind_exception(unwind_header)};var incrementExceptionRefcount=ex=>{var ptr=getCppExceptionThrownObjectFromWebAssemblyException(ex);___cxa_increment_exception_refcount(ptr)};var decrementExceptionRefcount=ex=>{var ptr=getCppExceptionThrownObjectFromWebAssemblyException(ex);___cxa_decrement_exception_refcount(ptr)};var getExceptionMessage=ex=>{var ptr=getCppExceptionThrownObjectFromWebAssemblyException(ex);return getExceptionMessageCommon(ptr)};var Browser={useWebGL:false,isFullscreen:false,pointerLock:false,moduleContextCreatedCallbacks:[],workers:[],preloadedImages:{},preloadedAudios:{},getCanvas:()=>Module["canvas"],init(){if(Browser.initted)return;Browser.initted=true;var imagePlugin={};imagePlugin["canHandle"]=function imagePlugin_canHandle(name){return!Module["noImageDecoding"]&&/\.(jpg|jpeg|png|bmp|webp)$/i.test(name)};imagePlugin["handle"]=function imagePlugin_handle(byteArray,name,onload,onerror){var b=new Blob([byteArray],{type:Browser.getMimetype(name)});if(b.size!==byteArray.length){b=new Blob([new Uint8Array(byteArray).buffer],{type:Browser.getMimetype(name)})}var url=URL.createObjectURL(b);var img=new Image;img.onload=()=>{var canvas=document.createElement("canvas");canvas.width=img.width;canvas.height=img.height;var ctx=canvas.getContext("2d");ctx.drawImage(img,0,0);Browser.preloadedImages[name]=canvas;URL.revokeObjectURL(url);onload?.(byteArray)};img.onerror=event=>{err(`Image ${url} could not be decoded`);onerror?.()};img.src=url};preloadPlugins.push(imagePlugin);var audioPlugin={};audioPlugin["canHandle"]=function audioPlugin_canHandle(name){return!Module["noAudioDecoding"]&&name.slice(-4)in{".ogg":1,".wav":1,".mp3":1}};audioPlugin["handle"]=function audioPlugin_handle(byteArray,name,onload,onerror){var done=false;function finish(audio){if(done)return;done=true;Browser.preloadedAudios[name]=audio;onload?.(byteArray)}function fail(){if(done)return;done=true;Browser.preloadedAudios[name]=new Audio;onerror?.()}var b=new Blob([byteArray],{type:Browser.getMimetype(name)});var url=URL.createObjectURL(b);var audio=new Audio;audio.addEventListener("canplaythrough",()=>finish(audio),false);audio.onerror=function audio_onerror(event){if(done)return;err(`warning: browser could not fully decode audio ${name}, trying slower base64 approach`);function encode64(data){var BASE="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";var PAD="=";var ret="";var leftchar=0;var leftbits=0;for(var i=0;i=6){var curr=leftchar>>leftbits-6&63;leftbits-=6;ret+=BASE[curr]}}if(leftbits==2){ret+=BASE[(leftchar&3)<<4];ret+=PAD+PAD}else if(leftbits==4){ret+=BASE[(leftchar&15)<<2];ret+=PAD}return ret}audio.src="data:audio/x-"+name.slice(-3)+";base64,"+encode64(byteArray);finish(audio)};audio.src=url;safeSetTimeout(()=>{finish(audio)},1e4)};preloadPlugins.push(audioPlugin);function pointerLockChange(){var canvas=Browser.getCanvas();Browser.pointerLock=document["pointerLockElement"]===canvas||document["mozPointerLockElement"]===canvas||document["webkitPointerLockElement"]===canvas||document["msPointerLockElement"]===canvas}var canvas=Browser.getCanvas();if(canvas){canvas.requestPointerLock=canvas["requestPointerLock"]||canvas["mozRequestPointerLock"]||canvas["webkitRequestPointerLock"]||canvas["msRequestPointerLock"]||(()=>{});canvas.exitPointerLock=document["exitPointerLock"]||document["mozExitPointerLock"]||document["webkitExitPointerLock"]||document["msExitPointerLock"]||(()=>{});canvas.exitPointerLock=canvas.exitPointerLock.bind(document);document.addEventListener("pointerlockchange",pointerLockChange,false);document.addEventListener("mozpointerlockchange",pointerLockChange,false);document.addEventListener("webkitpointerlockchange",pointerLockChange,false);document.addEventListener("mspointerlockchange",pointerLockChange,false);if(Module["elementPointerLock"]){canvas.addEventListener("click",ev=>{if(!Browser.pointerLock&&Browser.getCanvas().requestPointerLock){Browser.getCanvas().requestPointerLock();ev.preventDefault()}},false)}}},createContext(canvas,useWebGL,setInModule,webGLContextAttributes){if(useWebGL&&Module["ctx"]&&canvas==Browser.getCanvas())return Module["ctx"];var ctx;var contextHandle;if(useWebGL){var contextAttributes={antialias:false,alpha:false,majorVersion:typeof WebGL2RenderingContext!="undefined"?2:1};if(webGLContextAttributes){for(var attribute in webGLContextAttributes){contextAttributes[attribute]=webGLContextAttributes[attribute]}}if(typeof GL!="undefined"){contextHandle=GL.createContext(canvas,contextAttributes);if(contextHandle){ctx=GL.getContext(contextHandle).GLctx}}}else{ctx=canvas.getContext("2d")}if(!ctx)return null;if(setInModule){Module["ctx"]=ctx;if(useWebGL)GL.makeContextCurrent(contextHandle);Browser.useWebGL=useWebGL;Browser.moduleContextCreatedCallbacks.forEach(callback=>callback());Browser.init()}return ctx},fullscreenHandlersInstalled:false,lockPointer:undefined,resizeCanvas:undefined,requestFullscreen(lockPointer,resizeCanvas){Browser.lockPointer=lockPointer;Browser.resizeCanvas=resizeCanvas;if(typeof Browser.lockPointer=="undefined")Browser.lockPointer=true;if(typeof Browser.resizeCanvas=="undefined")Browser.resizeCanvas=false;var canvas=Browser.getCanvas();function fullscreenChange(){Browser.isFullscreen=false;var canvasContainer=canvas.parentNode;if((document["fullscreenElement"]||document["mozFullScreenElement"]||document["msFullscreenElement"]||document["webkitFullscreenElement"]||document["webkitCurrentFullScreenElement"])===canvasContainer){canvas.exitFullscreen=Browser.exitFullscreen;if(Browser.lockPointer)canvas.requestPointerLock();Browser.isFullscreen=true;if(Browser.resizeCanvas){Browser.setFullscreenCanvasSize()}else{Browser.updateCanvasDimensions(canvas)}}else{canvasContainer.parentNode.insertBefore(canvas,canvasContainer);canvasContainer.parentNode.removeChild(canvasContainer);if(Browser.resizeCanvas){Browser.setWindowedCanvasSize()}else{Browser.updateCanvasDimensions(canvas)}}Module["onFullScreen"]?.(Browser.isFullscreen);Module["onFullscreen"]?.(Browser.isFullscreen)}if(!Browser.fullscreenHandlersInstalled){Browser.fullscreenHandlersInstalled=true;document.addEventListener("fullscreenchange",fullscreenChange,false);document.addEventListener("mozfullscreenchange",fullscreenChange,false);document.addEventListener("webkitfullscreenchange",fullscreenChange,false);document.addEventListener("MSFullscreenChange",fullscreenChange,false)}var canvasContainer=document.createElement("div");canvas.parentNode.insertBefore(canvasContainer,canvas);canvasContainer.appendChild(canvas);canvasContainer.requestFullscreen=canvasContainer["requestFullscreen"]||canvasContainer["mozRequestFullScreen"]||canvasContainer["msRequestFullscreen"]||(canvasContainer["webkitRequestFullscreen"]?()=>canvasContainer["webkitRequestFullscreen"](Element["ALLOW_KEYBOARD_INPUT"]):null)||(canvasContainer["webkitRequestFullScreen"]?()=>canvasContainer["webkitRequestFullScreen"](Element["ALLOW_KEYBOARD_INPUT"]):null);canvasContainer.requestFullscreen()},exitFullscreen(){if(!Browser.isFullscreen){return false}var CFS=document["exitFullscreen"]||document["cancelFullScreen"]||document["mozCancelFullScreen"]||document["msExitFullscreen"]||document["webkitCancelFullScreen"]||(()=>{});CFS.apply(document,[]);return true},safeSetTimeout(func,timeout){return safeSetTimeout(func,timeout)},getMimetype(name){return{jpg:"image/jpeg",jpeg:"image/jpeg",png:"image/png",bmp:"image/bmp",ogg:"audio/ogg",wav:"audio/wav",mp3:"audio/mpeg"}[name.slice(name.lastIndexOf(".")+1)]},getUserMedia(func){window.getUserMedia||=navigator["getUserMedia"]||navigator["mozGetUserMedia"];window.getUserMedia(func)},getMovementX(event){return event["movementX"]||event["mozMovementX"]||event["webkitMovementX"]||0},getMovementY(event){return event["movementY"]||event["mozMovementY"]||event["webkitMovementY"]||0},getMouseWheelDelta(event){var delta=0;switch(event.type){case"DOMMouseScroll":delta=event.detail/3;break;case"mousewheel":delta=event.wheelDelta/120;break;case"wheel":delta=event.deltaY;switch(event.deltaMode){case 0:delta/=100;break;case 1:delta/=3;break;case 2:delta*=80;break;default:throw"unrecognized mouse wheel delta mode: "+event.deltaMode}break;default:throw"unrecognized mouse wheel event: "+event.type}return delta},mouseX:0,mouseY:0,mouseMovementX:0,mouseMovementY:0,touches:{},lastTouches:{},calculateMouseCoords(pageX,pageY){var canvas=Browser.getCanvas();var rect=canvas.getBoundingClientRect();var scrollX=typeof window.scrollX!="undefined"?window.scrollX:window.pageXOffset;var scrollY=typeof window.scrollY!="undefined"?window.scrollY:window.pageYOffset;var adjustedX=pageX-(scrollX+rect.left);var adjustedY=pageY-(scrollY+rect.top);adjustedX=adjustedX*(canvas.width/rect.width);adjustedY=adjustedY*(canvas.height/rect.height);return{x:adjustedX,y:adjustedY}},setMouseCoords(pageX,pageY){const{x,y}=Browser.calculateMouseCoords(pageX,pageY);Browser.mouseMovementX=x-Browser.mouseX;Browser.mouseMovementY=y-Browser.mouseY;Browser.mouseX=x;Browser.mouseY=y},calculateMouseEvent(event){if(Browser.pointerLock){if(event.type!="mousemove"&&"mozMovementX"in event){Browser.mouseMovementX=Browser.mouseMovementY=0}else{Browser.mouseMovementX=Browser.getMovementX(event);Browser.mouseMovementY=Browser.getMovementY(event)}Browser.mouseX+=Browser.mouseMovementX;Browser.mouseY+=Browser.mouseMovementY}else{if(event.type==="touchstart"||event.type==="touchend"||event.type==="touchmove"){var touch=event.touch;if(touch===undefined){return}var coords=Browser.calculateMouseCoords(touch.pageX,touch.pageY);if(event.type==="touchstart"){Browser.lastTouches[touch.identifier]=coords;Browser.touches[touch.identifier]=coords}else if(event.type==="touchend"||event.type==="touchmove"){var last=Browser.touches[touch.identifier];last||=coords;Browser.lastTouches[touch.identifier]=last;Browser.touches[touch.identifier]=coords}return}Browser.setMouseCoords(event.pageX,event.pageY)}},resizeListeners:[],updateResizeListeners(){var canvas=Browser.getCanvas();Browser.resizeListeners.forEach(listener=>listener(canvas.width,canvas.height))},setCanvasSize(width,height,noUpdates){var canvas=Browser.getCanvas();Browser.updateCanvasDimensions(canvas,width,height);if(!noUpdates)Browser.updateResizeListeners()},windowedWidth:0,windowedHeight:0,setFullscreenCanvasSize(){if(typeof SDL!="undefined"){var flags=HEAPU32[SDL.screen>>>2>>>0];flags=flags|8388608;HEAP32[SDL.screen>>>2>>>0]=flags}Browser.updateCanvasDimensions(Browser.getCanvas());Browser.updateResizeListeners()},setWindowedCanvasSize(){if(typeof SDL!="undefined"){var flags=HEAPU32[SDL.screen>>>2>>>0];flags=flags&~8388608;HEAP32[SDL.screen>>>2>>>0]=flags}Browser.updateCanvasDimensions(Browser.getCanvas());Browser.updateResizeListeners()},updateCanvasDimensions(canvas,wNative,hNative){if(wNative&&hNative){canvas.widthNative=wNative;canvas.heightNative=hNative}else{wNative=canvas.widthNative;hNative=canvas.heightNative}var w=wNative;var h=hNative;if(Module["forcedAspectRatio"]>0){if(w/h>>=0;onload>>>=0;onerror>>>=0;runtimeKeepalivePush();var _file=UTF8ToString(file);var data=FS.analyzePath(_file);if(!data.exists)return-1;FS.createPreloadedFile(PATH.dirname(_file),PATH.basename(_file),new Uint8Array(data.object.contents),true,true,()=>{runtimeKeepalivePop();if(onload)getWasmTableEntry(onload)(file)},()=>{runtimeKeepalivePop();if(onerror)getWasmTableEntry(onerror)(file)},true);return 0};_emscripten_run_preload_plugins.sig="ippp";var Browser_asyncPrepareDataCounter=0;var _emscripten_run_preload_plugins_data=function(data,size,suffix,arg,onload,onerror){data>>>=0;suffix>>>=0;arg>>>=0;onload>>>=0;onerror>>>=0;runtimeKeepalivePush();var _suffix=UTF8ToString(suffix);var name="prepare_data_"+Browser_asyncPrepareDataCounter+++"."+_suffix;var cname=stringToNewUTF8(name);FS.createPreloadedFile("/",name,HEAPU8.subarray(data>>>0,data+size>>>0),true,true,()=>{runtimeKeepalivePop();if(onload)getWasmTableEntry(onload)(arg,cname)},()=>{runtimeKeepalivePop();if(onerror)getWasmTableEntry(onerror)(arg)},true)};_emscripten_run_preload_plugins_data.sig="vpipppp";var _emscripten_async_run_script=function(script,millis){script>>>=0;safeSetTimeout(()=>_emscripten_run_script(script),millis)};_emscripten_async_run_script.sig="vpi";var _emscripten_async_load_script=async function(url,onload,onerror){url>>>=0;onload>>>=0;onerror>>>=0;url=UTF8ToString(url);runtimeKeepalivePush();var loadDone=()=>{runtimeKeepalivePop();if(onload){var onloadCallback=()=>callUserCallback(getWasmTableEntry(onload));if(runDependencies>0){dependenciesFulfilled=onloadCallback}else{onloadCallback()}}};var loadError=()=>{runtimeKeepalivePop();if(onerror){callUserCallback(getWasmTableEntry(onerror))}};if(ENVIRONMENT_IS_NODE){try{var data=await readAsync(url,false);eval(data);loadDone()}catch(e){err(e);loadError()}return}var script=document.createElement("script");script.onload=loadDone;script.onerror=loadError;script.src=url;document.body.appendChild(script)};_emscripten_async_load_script.sig="vppp";function _emscripten_get_window_title(){var buflen=256;if(!_emscripten_get_window_title.buffer){_emscripten_get_window_title.buffer=_malloc(buflen)}stringToUTF8(document.title,_emscripten_get_window_title.buffer,buflen);return _emscripten_get_window_title.buffer}_emscripten_get_window_title.sig="p";function _emscripten_set_window_title(title){title>>>=0;return document.title=UTF8ToString(title)}_emscripten_set_window_title.sig="vp";function _emscripten_get_screen_size(width,height){width>>>=0;height>>>=0;HEAP32[width>>>2>>>0]=screen.width;HEAP32[height>>>2>>>0]=screen.height}_emscripten_get_screen_size.sig="vpp";var _emscripten_hide_mouse=()=>{var styleSheet=document.styleSheets[0];var rules=styleSheet.cssRules;for(var i=0;iBrowser.setCanvasSize(width,height);_emscripten_set_canvas_size.sig="vii";function _emscripten_get_canvas_size(width,height,isFullscreen){width>>>=0;height>>>=0;isFullscreen>>>=0;var canvas=Browser.getCanvas();HEAP32[width>>>2>>>0]=canvas.width;HEAP32[height>>>2>>>0]=canvas.height;HEAP32[isFullscreen>>>2>>>0]=Browser.isFullscreen?1:0}_emscripten_get_canvas_size.sig="vppp";function _emscripten_create_worker(url){url>>>=0;url=UTF8ToString(url);var id=Browser.workers.length;var info={worker:new Worker(url),callbacks:[],awaited:0,buffer:0,bufferSize:0};info.worker.onmessage=function info_worker_onmessage(msg){if(ABORT)return;var info=Browser.workers[id];if(!info)return;var callbackId=msg.data["callbackId"];var callbackInfo=info.callbacks[callbackId];if(!callbackInfo)return;if(msg.data["finalResponse"]){info.awaited--;info.callbacks[callbackId]=null;runtimeKeepalivePop()}var data=msg.data["data"];if(data){if(!data.byteLength)data=new Uint8Array(data);if(!info.buffer||info.bufferSize>>0);callbackInfo.func(info.buffer,data.length,callbackInfo.arg)}else{callbackInfo.func(0,0,callbackInfo.arg)}};Browser.workers.push(info);return id}_emscripten_create_worker.sig="ip";var _emscripten_destroy_worker=id=>{var info=Browser.workers[id];info.worker.terminate();if(info.buffer)_free(info.buffer);Browser.workers[id]=null};_emscripten_destroy_worker.sig="vi";function _emscripten_call_worker(id,funcName,data,size,callback,arg){funcName>>>=0;data>>>=0;callback>>>=0;arg>>>=0;funcName=UTF8ToString(funcName);var info=Browser.workers[id];var callbackId=-1;if(callback){runtimeKeepalivePush();callbackId=info.callbacks.length;info.callbacks.push({func:getWasmTableEntry(callback),arg});info.awaited++}var transferObject={funcName,callbackId,data:data?new Uint8Array(HEAPU8.subarray(data>>>0,data+size>>>0)):0};if(data){info.worker.postMessage(transferObject,[transferObject.data.buffer])}else{info.worker.postMessage(transferObject)}}_emscripten_call_worker.sig="vippipp";var _emscripten_get_worker_queue_size=id=>{var info=Browser.workers[id];if(!info)return-1;return info.awaited};_emscripten_get_worker_queue_size.sig="ii";var getPreloadedImageData=(path,w,h)=>{path=PATH_FS.resolve(path);var canvas=Browser.preloadedImages[path];if(!canvas)return 0;var ctx=canvas.getContext("2d");var image=ctx.getImageData(0,0,canvas.width,canvas.height);var buf=_malloc(canvas.width*canvas.height*4);HEAPU8.set(image.data,buf>>>0);HEAP32[w>>>2>>>0]=canvas.width;HEAP32[h>>>2>>>0]=canvas.height;return buf};function _emscripten_get_preloaded_image_data(path,w,h){path>>>=0;w>>>=0;h>>>=0;return getPreloadedImageData(UTF8ToString(path),w,h)}_emscripten_get_preloaded_image_data.sig="pppp";var getPreloadedImageData__data=["$PATH_FS","malloc"];function _emscripten_get_preloaded_image_data_from_FILE(file,w,h){file>>>=0;w>>>=0;h>>>=0;var fd=_fileno(file);var stream=FS.getStream(fd);if(stream){return getPreloadedImageData(stream.path,w,h)}return 0}_emscripten_get_preloaded_image_data_from_FILE.sig="pppp";var wget={wgetRequests:{},nextWgetRequestHandle:0,getNextWgetRequestHandle(){var handle=wget.nextWgetRequestHandle;wget.nextWgetRequestHandle++;return handle}};var FS_mkdirTree=(path,mode)=>FS.mkdirTree(path,mode);var _emscripten_async_wget=function(url,file,onload,onerror){url>>>=0;file>>>=0;onload>>>=0;onerror>>>=0;runtimeKeepalivePush();var _url=UTF8ToString(url);var _file=UTF8ToString(file);_file=PATH_FS.resolve(_file);function doCallback(callback){if(callback){runtimeKeepalivePop();callUserCallback(()=>{var sp=stackSave();getWasmTableEntry(callback)(stringToUTF8OnStack(_file));stackRestore(sp)})}}var destinationDirectory=PATH.dirname(_file);FS_createPreloadedFile(destinationDirectory,PATH.basename(_file),_url,true,true,()=>doCallback(onload),()=>doCallback(onerror),false,false,()=>{try{FS_unlink(_file)}catch(e){}FS_mkdirTree(destinationDirectory)})};_emscripten_async_wget.sig="vpppp";var _emscripten_async_wget_data=async function(url,userdata,onload,onerror){url>>>=0;userdata>>>=0;onload>>>=0;onerror>>>=0;runtimeKeepalivePush();try{var byteArray=await asyncLoad(UTF8ToString(url));runtimeKeepalivePop();callUserCallback(()=>{var buffer=_malloc(byteArray.length);HEAPU8.set(byteArray,buffer>>>0);getWasmTableEntry(onload)(userdata,buffer,byteArray.length);_free(buffer)})}catch(e){if(onerror){runtimeKeepalivePop();callUserCallback(()=>{getWasmTableEntry(onerror)(userdata)})}}};_emscripten_async_wget_data.sig="vpppp";var _emscripten_async_wget2=function(url,file,request,param,userdata,onload,onerror,onprogress){url>>>=0;file>>>=0;request>>>=0;param>>>=0;userdata>>>=0;onload>>>=0;onerror>>>=0;onprogress>>>=0;runtimeKeepalivePush();var _url=UTF8ToString(url);var _file=UTF8ToString(file);_file=PATH_FS.resolve(_file);var _request=UTF8ToString(request);var _param=UTF8ToString(param);var index=_file.lastIndexOf("/");var http=new XMLHttpRequest;http.open(_request,_url,true);http.responseType="arraybuffer";var handle=wget.getNextWgetRequestHandle();var destinationDirectory=PATH.dirname(_file);http.onload=e=>{runtimeKeepalivePop();if(http.status>=200&&http.status<300){try{FS.unlink(_file)}catch(e){}FS.mkdirTree(destinationDirectory);FS.createDataFile(_file.slice(0,index),_file.slice(index+1),new Uint8Array(http.response),true,true,false);if(onload){var sp=stackSave();getWasmTableEntry(onload)(handle,userdata,stringToUTF8OnStack(_file));stackRestore(sp)}}else{if(onerror)getWasmTableEntry(onerror)(handle,userdata,http.status)}delete wget.wgetRequests[handle]};http.onerror=e=>{runtimeKeepalivePop();if(onerror)getWasmTableEntry(onerror)(handle,userdata,http.status);delete wget.wgetRequests[handle]};http.onprogress=e=>{if(e.lengthComputable||e.lengthComputable===undefined&&e.total!=0){var percentComplete=e.loaded/e.total*100;if(onprogress)getWasmTableEntry(onprogress)(handle,userdata,percentComplete)}};http.onabort=e=>{runtimeKeepalivePop();delete wget.wgetRequests[handle]};if(_request=="POST"){http.setRequestHeader("Content-type","application/x-www-form-urlencoded");http.send(_param)}else{http.send(null)}wget.wgetRequests[handle]=http;return handle};_emscripten_async_wget2.sig="ipppppppp";function _emscripten_async_wget2_data(url,request,param,userdata,free,onload,onerror,onprogress){url>>>=0;request>>>=0;param>>>=0;userdata>>>=0;onload>>>=0;onerror>>>=0;onprogress>>>=0;var _url=UTF8ToString(url);var _request=UTF8ToString(request);var _param=UTF8ToString(param);var http=new XMLHttpRequest;http.open(_request,_url,true);http.responseType="arraybuffer";var handle=wget.getNextWgetRequestHandle();function onerrorjs(){if(onerror){var sp=stackSave();var statusText=0;if(http.statusText){statusText=stringToUTF8OnStack(http.statusText)}getWasmTableEntry(onerror)(handle,userdata,http.status,statusText);stackRestore(sp)}}http.onload=e=>{if(http.status>=200&&http.status<300||http.status===0&&_url.slice(0,4).toLowerCase()!="http"){var byteArray=new Uint8Array(http.response);var buffer=_malloc(byteArray.length);HEAPU8.set(byteArray,buffer>>>0);if(onload)getWasmTableEntry(onload)(handle,userdata,buffer,byteArray.length);if(free)_free(buffer)}else{onerrorjs()}delete wget.wgetRequests[handle]};http.onerror=e=>{onerrorjs();delete wget.wgetRequests[handle]};http.onprogress=e=>{if(onprogress)getWasmTableEntry(onprogress)(handle,userdata,e.loaded,e.lengthComputable||e.lengthComputable===undefined?e.total:0)};http.onabort=e=>{delete wget.wgetRequests[handle]};if(_request=="POST"){http.setRequestHeader("Content-type","application/x-www-form-urlencoded");http.send(_param)}else{http.send(null)}wget.wgetRequests[handle]=http;return handle}_emscripten_async_wget2_data.sig="ippppippp";var _emscripten_async_wget2_abort=handle=>{var http=wget.wgetRequests[handle];http?.abort()};_emscripten_async_wget2_abort.sig="vi";function ___asctime_r(tmPtr,buf){tmPtr>>>=0;buf>>>=0;var date={tm_sec:HEAP32[tmPtr>>>2>>>0],tm_min:HEAP32[tmPtr+4>>>2>>>0],tm_hour:HEAP32[tmPtr+8>>>2>>>0],tm_mday:HEAP32[tmPtr+12>>>2>>>0],tm_mon:HEAP32[tmPtr+16>>>2>>>0],tm_year:HEAP32[tmPtr+20>>>2>>>0],tm_wday:HEAP32[tmPtr+24>>>2>>>0]};var days=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"];var months=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"];var s=days[date.tm_wday]+" "+months[date.tm_mon]+(date.tm_mday<10?" ":" ")+date.tm_mday+(date.tm_hour<10?" 0":" ")+date.tm_hour+(date.tm_min<10?":0":":")+date.tm_min+(date.tm_sec<10?":0":":")+date.tm_sec+" "+(1900+date.tm_year)+"\n";stringToUTF8(s,buf,26);return buf}___asctime_r.sig="ppp";var MONTH_DAYS_REGULAR=[31,28,31,30,31,30,31,31,30,31,30,31];var MONTH_DAYS_LEAP=[31,29,31,30,31,30,31,31,30,31,30,31];var arraySum=(array,index)=>{var sum=0;for(var i=0;i<=index;sum+=array[i++]){}return sum};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};function _strptime(buf,format,tm){buf>>>=0;format>>>=0;tm>>>=0;var pattern=UTF8ToString(format);var SPECIAL_CHARS="\\!@#$^&*()+=-[]/{}|:<>?,.";for(var i=0,ii=SPECIAL_CHARS.length;iEQUIVALENT_MATCHERS[c]||m).replace(/%(.)/g,(_,c)=>{let pat=DATE_PATTERNS[c];if(pat){capture.push(c);return`(${pat})`}else{return c}}).replace(/\s+/g,"\\s*");var matches=new RegExp("^"+pattern_out,"i").exec(UTF8ToString(buf));function initDate(){function fixup(value,min,max){return typeof value!="number"||isNaN(value)?min:value>=min?value<=max?value:max:min}return{year:fixup(HEAP32[tm+20>>>2>>>0]+1900,1970,9999),month:fixup(HEAP32[tm+16>>>2>>>0],0,11),day:fixup(HEAP32[tm+12>>>2>>>0],1,31),hour:fixup(HEAP32[tm+8>>>2>>>0],0,23),min:fixup(HEAP32[tm+4>>>2>>>0],0,59),sec:fixup(HEAP32[tm>>>2>>>0],0,59),gmtoff:0}}if(matches){var date=initDate();var value;var getMatch=symbol=>{var pos=capture.indexOf(symbol);if(pos>=0){return matches[pos+1]}return};if(value=getMatch("S")){date.sec=Number(value)}if(value=getMatch("M")){date.min=Number(value)}if(value=getMatch("H")){date.hour=Number(value)}else if(value=getMatch("I")){var hour=Number(value);if(value=getMatch("p")){hour+=value.toUpperCase()[0]==="P"?12:0}date.hour=hour}if(value=getMatch("Y")){date.year=Number(value)}else if(value=getMatch("y")){var year=Number(value);if(value=getMatch("C")){year+=Number(value)*100}else{year+=year<69?2e3:1900}date.year=year}if(value=getMatch("m")){date.month=Number(value)-1}else if(value=getMatch("b")){date.month=MONTH_NUMBERS[value.substring(0,3).toUpperCase()]||0}if(value=getMatch("d")){date.day=Number(value)}else if(value=getMatch("j")){var day=Number(value);var leapYear=isLeapYear(date.year);for(var month=0;month<12;++month){var daysUntilMonth=arraySum(leapYear?MONTH_DAYS_LEAP:MONTH_DAYS_REGULAR,month-1);if(day<=daysUntilMonth+(leapYear?MONTH_DAYS_LEAP:MONTH_DAYS_REGULAR)[month]){date.day=day-daysUntilMonth}}}else if(value=getMatch("a")){var weekDay=value.substring(0,3).toUpperCase();if(value=getMatch("U")){var weekDayNumber=DAY_NUMBERS_SUN_FIRST[weekDay];var weekNumber=Number(value);var janFirst=new Date(date.year,0,1);var endDate;if(janFirst.getDay()===0){endDate=addDays(janFirst,weekDayNumber+7*(weekNumber-1))}else{endDate=addDays(janFirst,7-janFirst.getDay()+weekDayNumber+7*(weekNumber-1))}date.day=endDate.getDate();date.month=endDate.getMonth()}else if(value=getMatch("W")){var weekDayNumber=DAY_NUMBERS_MON_FIRST[weekDay];var weekNumber=Number(value);var janFirst=new Date(date.year,0,1);var endDate;if(janFirst.getDay()===1){endDate=addDays(janFirst,weekDayNumber+7*(weekNumber-1))}else{endDate=addDays(janFirst,7-janFirst.getDay()+1+weekDayNumber+7*(weekNumber-1))}date.day=endDate.getDate();date.month=endDate.getMonth()}}if(value=getMatch("z")){if(value.toLowerCase()==="z"){date.gmtoff=0}else{var match=value.match(/^((?:\-|\+)\d\d):?(\d\d)?/);date.gmtoff=match[1]*3600;if(match[2]){date.gmtoff+=date.gmtoff>0?match[2]*60:-match[2]*60}}}var fullDate=new Date(date.year,date.month,date.day,date.hour,date.min,date.sec,0);HEAP32[tm>>>2>>>0]=fullDate.getSeconds();HEAP32[tm+4>>>2>>>0]=fullDate.getMinutes();HEAP32[tm+8>>>2>>>0]=fullDate.getHours();HEAP32[tm+12>>>2>>>0]=fullDate.getDate();HEAP32[tm+16>>>2>>>0]=fullDate.getMonth();HEAP32[tm+20>>>2>>>0]=fullDate.getFullYear()-1900;HEAP32[tm+24>>>2>>>0]=fullDate.getDay();HEAP32[tm+28>>>2>>>0]=arraySum(isLeapYear(fullDate.getFullYear())?MONTH_DAYS_LEAP:MONTH_DAYS_REGULAR,fullDate.getMonth()-1)+fullDate.getDate()-1;HEAP32[tm+32>>>2>>>0]=0;HEAP32[tm+36>>>2>>>0]=date.gmtoff;return buf+intArrayFromString(matches[0]).length-1}return 0}_strptime.sig="pppp";function _strptime_l(buf,format,tm,locale){buf>>>=0;format>>>=0;tm>>>=0;locale>>>=0;return _strptime(buf,format,tm)}_strptime_l.sig="ppppp";function __dlsym_catchup_js(handle,symbolIndex){handle>>>=0;var lib=LDSO.loadedLibsByHandle[handle];var symDict=lib.exports;var symName=Object.keys(symDict)[symbolIndex];var sym=symDict[symName];var result=addFunction(sym,sym.sig);return result}__dlsym_catchup_js.sig="ppi";var FS_readFile=(...args)=>FS.readFile(...args);var FS_root=(...args)=>FS.root(...args);var FS_mounts=(...args)=>FS.mounts(...args);var FS_devices=(...args)=>FS.devices(...args);var FS_streams=(...args)=>FS.streams(...args);var FS_nextInode=(...args)=>FS.nextInode(...args);var FS_nameTable=(...args)=>FS.nameTable(...args);var FS_currentPath=(...args)=>FS.currentPath(...args);var FS_initialized=(...args)=>FS.initialized(...args);var FS_ignorePermissions=(...args)=>FS.ignorePermissions(...args);var FS_trackingDelegate=(...args)=>FS.trackingDelegate(...args);var FS_filesystems=(...args)=>FS.filesystems(...args);var FS_syncFSRequests=(...args)=>FS.syncFSRequests(...args);var FS_readFiles=(...args)=>FS.readFiles(...args);var FS_lookupPath=(...args)=>FS.lookupPath(...args);var FS_getPath=(...args)=>FS.getPath(...args);var FS_hashName=(...args)=>FS.hashName(...args);var FS_hashAddNode=(...args)=>FS.hashAddNode(...args);var FS_hashRemoveNode=(...args)=>FS.hashRemoveNode(...args);var FS_lookupNode=(...args)=>FS.lookupNode(...args);var FS_createNode=(...args)=>FS.createNode(...args);var FS_destroyNode=(...args)=>FS.destroyNode(...args);var FS_isRoot=(...args)=>FS.isRoot(...args);var FS_isMountpoint=(...args)=>FS.isMountpoint(...args);var FS_isFile=(...args)=>FS.isFile(...args);var FS_isDir=(...args)=>FS.isDir(...args);var FS_isLink=(...args)=>FS.isLink(...args);var FS_isChrdev=(...args)=>FS.isChrdev(...args);var FS_isBlkdev=(...args)=>FS.isBlkdev(...args);var FS_isFIFO=(...args)=>FS.isFIFO(...args);var FS_isSocket=(...args)=>FS.isSocket(...args);var FS_flagsToPermissionString=(...args)=>FS.flagsToPermissionString(...args);var FS_nodePermissions=(...args)=>FS.nodePermissions(...args);var FS_mayLookup=(...args)=>FS.mayLookup(...args);var FS_mayCreate=(...args)=>FS.mayCreate(...args);var FS_mayDelete=(...args)=>FS.mayDelete(...args);var FS_mayOpen=(...args)=>FS.mayOpen(...args);var FS_checkOpExists=(...args)=>FS.checkOpExists(...args);var FS_nextfd=(...args)=>FS.nextfd(...args);var FS_getStreamChecked=(...args)=>FS.getStreamChecked(...args);var FS_getStream=(...args)=>FS.getStream(...args);var FS_createStream=(...args)=>FS.createStream(...args);var FS_closeStream=(...args)=>FS.closeStream(...args);var FS_dupStream=(...args)=>FS.dupStream(...args);var FS_doSetAttr=(...args)=>FS.doSetAttr(...args);var FS_chrdev_stream_ops=(...args)=>FS.chrdev_stream_ops(...args);var FS_major=(...args)=>FS.major(...args);var FS_minor=(...args)=>FS.minor(...args);var FS_makedev=(...args)=>FS.makedev(...args);var FS_registerDevice=(...args)=>FS.registerDevice(...args);var FS_getDevice=(...args)=>FS.getDevice(...args);var FS_getMounts=(...args)=>FS.getMounts(...args);var FS_syncfs=(...args)=>FS.syncfs(...args);var FS_mount=(...args)=>FS.mount(...args);var FS_unmount=(...args)=>FS.unmount(...args);var FS_lookup=(...args)=>FS.lookup(...args);var FS_mknod=(...args)=>FS.mknod(...args);var FS_statfs=(...args)=>FS.statfs(...args);var FS_statfsStream=(...args)=>FS.statfsStream(...args);var FS_statfsNode=(...args)=>FS.statfsNode(...args);var FS_create=(...args)=>FS.create(...args);var FS_mkdir=(...args)=>FS.mkdir(...args);var FS_mkdev=(...args)=>FS.mkdev(...args);var FS_symlink=(...args)=>FS.symlink(...args);var FS_rename=(...args)=>FS.rename(...args);var FS_rmdir=(...args)=>FS.rmdir(...args);var FS_readdir=(...args)=>FS.readdir(...args);var FS_readlink=(...args)=>FS.readlink(...args);var FS_stat=(...args)=>FS.stat(...args);var FS_fstat=(...args)=>FS.fstat(...args);var FS_lstat=(...args)=>FS.lstat(...args);var FS_doChmod=(...args)=>FS.doChmod(...args);var FS_chmod=(...args)=>FS.chmod(...args);var FS_lchmod=(...args)=>FS.lchmod(...args);var FS_fchmod=(...args)=>FS.fchmod(...args);var FS_doChown=(...args)=>FS.doChown(...args);var FS_chown=(...args)=>FS.chown(...args);var FS_lchown=(...args)=>FS.lchown(...args);var FS_fchown=(...args)=>FS.fchown(...args);var FS_doTruncate=(...args)=>FS.doTruncate(...args);var FS_truncate=(...args)=>FS.truncate(...args);var FS_ftruncate=(...args)=>FS.ftruncate(...args);var FS_utime=(...args)=>FS.utime(...args);var FS_open=(...args)=>FS.open(...args);var FS_close=(...args)=>FS.close(...args);var FS_isClosed=(...args)=>FS.isClosed(...args);var FS_llseek=(...args)=>FS.llseek(...args);var FS_read=(...args)=>FS.read(...args);var FS_write=(...args)=>FS.write(...args);var FS_mmap=(...args)=>FS.mmap(...args);var FS_msync=(...args)=>FS.msync(...args);var FS_ioctl=(...args)=>FS.ioctl(...args);var FS_writeFile=(...args)=>FS.writeFile(...args);var FS_cwd=(...args)=>FS.cwd(...args);var FS_chdir=(...args)=>FS.chdir(...args);var FS_createDefaultDirectories=(...args)=>FS.createDefaultDirectories(...args);var FS_createDefaultDevices=(...args)=>FS.createDefaultDevices(...args);var FS_createSpecialDirectories=(...args)=>FS.createSpecialDirectories(...args);var FS_createStandardStreams=(...args)=>FS.createStandardStreams(...args);var FS_staticInit=(...args)=>FS.staticInit(...args);var FS_init=(...args)=>FS.init(...args);var FS_quit=(...args)=>FS.quit(...args);var FS_findObject=(...args)=>FS.findObject(...args);var FS_analyzePath=(...args)=>FS.analyzePath(...args);var FS_createFile=(...args)=>FS.createFile(...args);var FS_forceLoadFile=(...args)=>FS.forceLoadFile(...args);var _setNetworkCallback=(event,userData,callback)=>{function _callback(data){callUserCallback(()=>{if(event==="error"){withStackSave(()=>{var msg=stringToUTF8OnStack(data[2]);getWasmTableEntry(callback)(data[0],data[1],msg,userData)})}else{getWasmTableEntry(callback)(data,userData)}})}runtimeKeepalivePush();SOCKFS.on(event,callback?_callback:null)};function _emscripten_set_socket_error_callback(userData,callback){userData>>>=0;callback>>>=0;return _setNetworkCallback("error",userData,callback)}_emscripten_set_socket_error_callback.sig="vpp";function _emscripten_set_socket_open_callback(userData,callback){userData>>>=0;callback>>>=0;return _setNetworkCallback("open",userData,callback)}_emscripten_set_socket_open_callback.sig="vpp";function _emscripten_set_socket_listen_callback(userData,callback){userData>>>=0;callback>>>=0;return _setNetworkCallback("listen",userData,callback)}_emscripten_set_socket_listen_callback.sig="vpp";function _emscripten_set_socket_connection_callback(userData,callback){userData>>>=0;callback>>>=0;return _setNetworkCallback("connection",userData,callback)}_emscripten_set_socket_connection_callback.sig="vpp";function _emscripten_set_socket_message_callback(userData,callback){userData>>>=0;callback>>>=0;return _setNetworkCallback("message",userData,callback)}_emscripten_set_socket_message_callback.sig="vpp";function _emscripten_set_socket_close_callback(userData,callback){userData>>>=0;callback>>>=0;return _setNetworkCallback("close",userData,callback)}_emscripten_set_socket_close_callback.sig="vpp";function _emscripten_webgl_enable_ANGLE_instanced_arrays(ctx){ctx>>>=0;return webgl_enable_ANGLE_instanced_arrays(GL.contexts[ctx].GLctx)}_emscripten_webgl_enable_ANGLE_instanced_arrays.sig="ip";function _emscripten_webgl_enable_OES_vertex_array_object(ctx){ctx>>>=0;return webgl_enable_OES_vertex_array_object(GL.contexts[ctx].GLctx)}_emscripten_webgl_enable_OES_vertex_array_object.sig="ip";function _emscripten_webgl_enable_WEBGL_draw_buffers(ctx){ctx>>>=0;return webgl_enable_WEBGL_draw_buffers(GL.contexts[ctx].GLctx)}_emscripten_webgl_enable_WEBGL_draw_buffers.sig="ip";function _emscripten_webgl_enable_WEBGL_multi_draw(ctx){ctx>>>=0;return webgl_enable_WEBGL_multi_draw(GL.contexts[ctx].GLctx)}_emscripten_webgl_enable_WEBGL_multi_draw.sig="ip";function _emscripten_webgl_enable_EXT_polygon_offset_clamp(ctx){ctx>>>=0;return webgl_enable_EXT_polygon_offset_clamp(GL.contexts[ctx].GLctx)}_emscripten_webgl_enable_EXT_polygon_offset_clamp.sig="ip";function _emscripten_webgl_enable_EXT_clip_control(ctx){ctx>>>=0;return webgl_enable_EXT_clip_control(GL.contexts[ctx].GLctx)}_emscripten_webgl_enable_EXT_clip_control.sig="ip";function _emscripten_webgl_enable_WEBGL_polygon_mode(ctx){ctx>>>=0;return webgl_enable_WEBGL_polygon_mode(GL.contexts[ctx].GLctx)}_emscripten_webgl_enable_WEBGL_polygon_mode.sig="ip";function _glVertexPointer(size,type,stride,ptr){ptr>>>=0;throw"Legacy GL function (glVertexPointer) called. If you want legacy GL emulation, you need to compile with -sLEGACY_GL_EMULATION to enable legacy GL emulation."}_glVertexPointer.sig="viiip";var _glMatrixMode=()=>{throw"Legacy GL function (glMatrixMode) called. If you want legacy GL emulation, you need to compile with -sLEGACY_GL_EMULATION to enable legacy GL emulation."};_glMatrixMode.sig="vi";var _glBegin=()=>{throw"Legacy GL function (glBegin) called. If you want legacy GL emulation, you need to compile with -sLEGACY_GL_EMULATION to enable legacy GL emulation."};_glBegin.sig="vi";var _glLoadIdentity=()=>{throw"Legacy GL function (glLoadIdentity) called. If you want legacy GL emulation, you need to compile with -sLEGACY_GL_EMULATION to enable legacy GL emulation."};_glLoadIdentity.sig="v";function _glMultiDrawArraysWEBGL(mode,firsts,counts,drawcount){firsts>>>=0;counts>>>=0;GLctx.multiDrawWebgl["multiDrawArraysWEBGL"](mode,HEAP32,firsts>>>2,HEAP32,counts>>>2,drawcount)}_glMultiDrawArraysWEBGL.sig="vippi";var _glMultiDrawArrays=_glMultiDrawArraysWEBGL;_glMultiDrawArrays.sig="vippi";var _glMultiDrawArraysANGLE=_glMultiDrawArraysWEBGL;function _glMultiDrawArraysInstancedWEBGL(mode,firsts,counts,instanceCounts,drawcount){firsts>>>=0;counts>>>=0;instanceCounts>>>=0;GLctx.multiDrawWebgl["multiDrawArraysInstancedWEBGL"](mode,HEAP32,firsts>>>2,HEAP32,counts>>>2,HEAP32,instanceCounts>>>2,drawcount)}_glMultiDrawArraysInstancedWEBGL.sig="vipppi";var _glMultiDrawArraysInstancedANGLE=_glMultiDrawArraysInstancedWEBGL;function _glMultiDrawElementsWEBGL(mode,counts,type,offsets,drawcount){counts>>>=0;offsets>>>=0;GLctx.multiDrawWebgl["multiDrawElementsWEBGL"](mode,HEAP32,counts>>>2,type,HEAP32,offsets>>>2,drawcount)}_glMultiDrawElementsWEBGL.sig="vipipi";var _glMultiDrawElements=_glMultiDrawElementsWEBGL;_glMultiDrawElements.sig="vipipi";var _glMultiDrawElementsANGLE=_glMultiDrawElementsWEBGL;function _glMultiDrawElementsInstancedWEBGL(mode,counts,type,offsets,instanceCounts,drawcount){counts>>>=0;offsets>>>=0;instanceCounts>>>=0;GLctx.multiDrawWebgl["multiDrawElementsInstancedWEBGL"](mode,HEAP32,counts>>>2,type,HEAP32,offsets>>>2,HEAP32,instanceCounts>>>2,drawcount)}_glMultiDrawElementsInstancedWEBGL.sig="vipippi";var _glMultiDrawElementsInstancedANGLE=_glMultiDrawElementsInstancedWEBGL;var _glClearDepth=x0=>GLctx.clearDepth(x0);_glClearDepth.sig="vd";var _glDepthRange=(x0,x1)=>GLctx.depthRange(x0,x1);_glDepthRange.sig="vdd";var _emscripten_glVertexPointer=_glVertexPointer;_emscripten_glVertexPointer.sig="viiip";var _emscripten_glMatrixMode=_glMatrixMode;_emscripten_glMatrixMode.sig="vi";var _emscripten_glBegin=_glBegin;_emscripten_glBegin.sig="vi";var _emscripten_glLoadIdentity=_glLoadIdentity;_emscripten_glLoadIdentity.sig="v";var _emscripten_glMultiDrawArrays=_glMultiDrawArrays;_emscripten_glMultiDrawArrays.sig="vippi";var _emscripten_glMultiDrawArraysANGLE=_glMultiDrawArraysANGLE;var _emscripten_glMultiDrawArraysWEBGL=_glMultiDrawArraysWEBGL;var _emscripten_glMultiDrawArraysInstancedANGLE=_glMultiDrawArraysInstancedANGLE;var _emscripten_glMultiDrawArraysInstancedWEBGL=_glMultiDrawArraysInstancedWEBGL;var _emscripten_glMultiDrawElements=_glMultiDrawElements;_emscripten_glMultiDrawElements.sig="vipipi";var _emscripten_glMultiDrawElementsANGLE=_glMultiDrawElementsANGLE;var _emscripten_glMultiDrawElementsWEBGL=_glMultiDrawElementsWEBGL;var _emscripten_glMultiDrawElementsInstancedANGLE=_glMultiDrawElementsInstancedANGLE;var _emscripten_glMultiDrawElementsInstancedWEBGL=_glMultiDrawElementsInstancedWEBGL;var _emscripten_glClearDepth=_glClearDepth;_emscripten_glClearDepth.sig="vd";var _emscripten_glDepthRange=_glDepthRange;_emscripten_glDepthRange.sig="vdd";function _glGetBufferSubData(target,offset,size,data){offset>>>=0;size>>>=0;data>>>=0;if(!data){GL.recordError(1281);return}size&&GLctx.getBufferSubData(target,offset,HEAPU8.subarray(data>>>0,data+size>>>0))}_glGetBufferSubData.sig="vippp";var _glDrawArraysInstancedBaseInstanceWEBGL=(mode,first,count,instanceCount,baseInstance)=>{GLctx.dibvbi["drawArraysInstancedBaseInstanceWEBGL"](mode,first,count,instanceCount,baseInstance)};_glDrawArraysInstancedBaseInstanceWEBGL.sig="viiiii";var _glDrawArraysInstancedBaseInstance=_glDrawArraysInstancedBaseInstanceWEBGL;_glDrawArraysInstancedBaseInstance.sig="viiiii";var _glDrawArraysInstancedBaseInstanceANGLE=_glDrawArraysInstancedBaseInstanceWEBGL;var _glDrawElementsInstancedBaseVertexBaseInstanceWEBGL=(mode,count,type,offset,instanceCount,baseVertex,baseinstance)=>{GLctx.dibvbi["drawElementsInstancedBaseVertexBaseInstanceWEBGL"](mode,count,type,offset,instanceCount,baseVertex,baseinstance)};_glDrawElementsInstancedBaseVertexBaseInstanceWEBGL.sig="viiiiiii";var _glDrawElementsInstancedBaseVertexBaseInstanceANGLE=_glDrawElementsInstancedBaseVertexBaseInstanceWEBGL;function _emscripten_webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance(ctx){ctx>>>=0;return webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance(GL.contexts[ctx].GLctx)}_emscripten_webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance.sig="ip";var _glMultiDrawArraysInstancedBaseInstanceWEBGL=(mode,firsts,counts,instanceCounts,baseInstances,drawCount)=>{GLctx.mdibvbi["multiDrawArraysInstancedBaseInstanceWEBGL"](mode,HEAP32,firsts>>>2,HEAP32,counts>>>2,HEAP32,instanceCounts>>>2,HEAPU32,baseInstances>>>2,drawCount)};_glMultiDrawArraysInstancedBaseInstanceWEBGL.sig="viiiiii";var _glMultiDrawArraysInstancedBaseInstanceANGLE=_glMultiDrawArraysInstancedBaseInstanceWEBGL;var _glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL=(mode,counts,type,offsets,instanceCounts,baseVertices,baseInstances,drawCount)=>{GLctx.mdibvbi["multiDrawElementsInstancedBaseVertexBaseInstanceWEBGL"](mode,HEAP32,counts>>>2,type,HEAP32,offsets>>>2,HEAP32,instanceCounts>>>2,HEAP32,baseVertices>>>2,HEAPU32,baseInstances>>>2,drawCount)};_glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL.sig="viiiiiiii";var _glMultiDrawElementsInstancedBaseVertexBaseInstanceANGLE=_glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL;function _emscripten_webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance(ctx){ctx>>>=0;return webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance(GL.contexts[ctx].GLctx)}_emscripten_webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance.sig="ip";var _emscripten_glGetBufferSubData=_glGetBufferSubData;_emscripten_glGetBufferSubData.sig="vippp";var _emscripten_glDrawArraysInstancedBaseInstanceWEBGL=_glDrawArraysInstancedBaseInstanceWEBGL;var _emscripten_glDrawArraysInstancedBaseInstance=_glDrawArraysInstancedBaseInstance;_emscripten_glDrawArraysInstancedBaseInstance.sig="viiiii";var _emscripten_glDrawArraysInstancedBaseInstanceANGLE=_glDrawArraysInstancedBaseInstanceANGLE;var _emscripten_glDrawElementsInstancedBaseVertexBaseInstanceWEBGL=_glDrawElementsInstancedBaseVertexBaseInstanceWEBGL;var _emscripten_glDrawElementsInstancedBaseVertexBaseInstanceANGLE=_glDrawElementsInstancedBaseVertexBaseInstanceANGLE;var _emscripten_glMultiDrawArraysInstancedBaseInstanceWEBGL=_glMultiDrawArraysInstancedBaseInstanceWEBGL;var _emscripten_glMultiDrawArraysInstancedBaseInstanceANGLE=_glMultiDrawArraysInstancedBaseInstanceANGLE;var _emscripten_glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL=_glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL;var _emscripten_glMultiDrawElementsInstancedBaseVertexBaseInstanceANGLE=_glMultiDrawElementsInstancedBaseVertexBaseInstanceANGLE;var ALLOC_NORMAL=0;var ALLOC_STACK=1;var allocate=(slab,allocator)=>{var ret;if(allocator==ALLOC_STACK){ret=stackAlloc(slab.length)}else{ret=_malloc(slab.length)}if(!slab.subarray&&!slab.slice){slab=new Uint8Array(slab)}HEAPU8.set(slab,ret>>>0);return ret};var writeStringToMemory=(string,buffer,dontAddNull)=>{warnOnce("writeStringToMemory is deprecated and should not be called! Use stringToUTF8() instead!");var lastChar,end;if(dontAddNull){end=buffer+lengthBytesUTF8(string);lastChar=HEAP8[end>>>0]}stringToUTF8(string,buffer,Infinity);if(dontAddNull)HEAP8[end>>>0]=lastChar};var writeAsciiToMemory=(str,buffer,dontAddNull)=>{for(var i=0;i>>0]=str.charCodeAt(i)}if(!dontAddNull)HEAP8[buffer>>>0]=0};var allocateUTF8=stringToNewUTF8;var allocateUTF8OnStack=stringToUTF8OnStack;var demangle=func=>{demangle.recursionGuard=(demangle.recursionGuard|0)+1;if(demangle.recursionGuard>1)return func;return withStackSave(()=>{try{var s=func;if(s.startsWith("__Z"))s=s.slice(1);var buf=stringToUTF8OnStack(s);var status=stackAlloc(4);var ret=___cxa_demangle(buf,0,0,status);if(HEAP32[status>>>2>>>0]===0&&ret){return UTF8ToString(ret)}}catch(e){}finally{_free(ret);if(demangle.recursionGuard<2)--demangle.recursionGuard}return func})};var stackTrace=()=>{var js=jsStackTrace();if(Module["extraStackTrace"])js+="\n"+Module["extraStackTrace"]();return js};var print=out;var printErr=err;var jstoi_s=Number;var _emscripten_is_main_browser_thread=()=>!ENVIRONMENT_IS_WORKER;var webSockets=new HandleAllocator;var WS={socketEvent:null,getSocket(socketId){if(!webSockets.has(socketId)){return 0}return webSockets.get(socketId)},getSocketEvent(socketId){this.socketEvent||=_malloc(520);HEAPU32[this.socketEvent>>>2>>>0]=socketId;return this.socketEvent}};function _emscripten_websocket_get_ready_state(socketId,readyState){readyState>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}HEAP16[readyState>>>1>>>0]=socket.readyState;return 0}_emscripten_websocket_get_ready_state.sig="iip";function _emscripten_websocket_get_buffered_amount(socketId,bufferedAmount){bufferedAmount>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}HEAPU32[bufferedAmount>>>2>>>0]=socket.bufferedAmount;return 0}_emscripten_websocket_get_buffered_amount.sig="iip";function _emscripten_websocket_get_extensions(socketId,extensions,extensionsLength){extensions>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}if(!extensions)return-5;stringToUTF8(socket.extensions,extensions,extensionsLength);return 0}_emscripten_websocket_get_extensions.sig="iipi";function _emscripten_websocket_get_extensions_length(socketId,extensionsLength){extensionsLength>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}if(!extensionsLength)return-5;HEAP32[extensionsLength>>>2>>>0]=lengthBytesUTF8(socket.extensions)+1;return 0}_emscripten_websocket_get_extensions_length.sig="iip";function _emscripten_websocket_get_protocol(socketId,protocol,protocolLength){protocol>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}if(!protocol)return-5;stringToUTF8(socket.protocol,protocol,protocolLength);return 0}_emscripten_websocket_get_protocol.sig="iipi";function _emscripten_websocket_get_protocol_length(socketId,protocolLength){protocolLength>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}if(!protocolLength)return-5;HEAP32[protocolLength>>>2>>>0]=lengthBytesUTF8(socket.protocol)+1;return 0}_emscripten_websocket_get_protocol_length.sig="iip";function _emscripten_websocket_get_url(socketId,url,urlLength){url>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}if(!url)return-5;stringToUTF8(socket.url,url,urlLength);return 0}_emscripten_websocket_get_url.sig="iipi";function _emscripten_websocket_get_url_length(socketId,urlLength){urlLength>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}if(!urlLength)return-5;HEAP32[urlLength>>>2>>>0]=lengthBytesUTF8(socket.url)+1;return 0}_emscripten_websocket_get_url_length.sig="iip";function _emscripten_websocket_set_onopen_callback_on_thread(socketId,userData,callbackFunc,thread){userData>>>=0;callbackFunc>>>=0;thread>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}socket.onopen=function(e){var eventPtr=WS.getSocketEvent(socketId);getWasmTableEntry(callbackFunc)(0,eventPtr,userData)};return 0}_emscripten_websocket_set_onopen_callback_on_thread.sig="iippp";function _emscripten_websocket_set_onerror_callback_on_thread(socketId,userData,callbackFunc,thread){userData>>>=0;callbackFunc>>>=0;thread>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}socket.onerror=function(e){var eventPtr=WS.getSocketEvent(socketId);getWasmTableEntry(callbackFunc)(0,eventPtr,userData)};return 0}_emscripten_websocket_set_onerror_callback_on_thread.sig="iippp";function _emscripten_websocket_set_onclose_callback_on_thread(socketId,userData,callbackFunc,thread){userData>>>=0;callbackFunc>>>=0;thread>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}socket.onclose=function(e){var eventPtr=WS.getSocketEvent(socketId);HEAP8[eventPtr+4>>>0]=e.wasClean,HEAP16[eventPtr+6>>>1>>>0]=e.code,stringToUTF8(e.reason,eventPtr+8,512);getWasmTableEntry(callbackFunc)(0,eventPtr,userData)};return 0}_emscripten_websocket_set_onclose_callback_on_thread.sig="iippp";function _emscripten_websocket_set_onmessage_callback_on_thread(socketId,userData,callbackFunc,thread){userData>>>=0;callbackFunc>>>=0;thread>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}socket.onmessage=function(e){var isText=typeof e.data=="string";if(isText){var buf=stringToNewUTF8(e.data);var len=lengthBytesUTF8(e.data)+1}else{var len=e.data.byteLength;var buf=_malloc(len);HEAP8.set(new Uint8Array(e.data),buf>>>0)}var eventPtr=WS.getSocketEvent(socketId);HEAPU32[eventPtr+4>>>2>>>0]=buf,HEAP32[eventPtr+8>>>2>>>0]=len,HEAP8[eventPtr+12>>>0]=isText,getWasmTableEntry(callbackFunc)(0,eventPtr,userData);_free(buf)};return 0}_emscripten_websocket_set_onmessage_callback_on_thread.sig="iippp";function _emscripten_websocket_new(createAttributes){createAttributes>>>=0;if(typeof WebSocket=="undefined"){return-1}if(!createAttributes){return-5}var url=UTF8ToString(HEAPU32[createAttributes>>>2>>>0]);var protocols=HEAPU32[createAttributes+4>>>2>>>0];var socket=protocols?new WebSocket(url,UTF8ToString(protocols).split(",")):new WebSocket(url);socket.binaryType="arraybuffer";var socketId=webSockets.allocate(socket);return socketId}_emscripten_websocket_new.sig="ip";function _emscripten_websocket_send_utf8_text(socketId,textData){textData>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}var str=UTF8ToString(textData);socket.send(str);return 0}_emscripten_websocket_send_utf8_text.sig="iip";function _emscripten_websocket_send_binary(socketId,binaryData,dataLength){binaryData>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}socket.send(HEAPU8.subarray(binaryData>>>0,binaryData+dataLength>>>0));return 0}_emscripten_websocket_send_binary.sig="iipi";function _emscripten_websocket_close(socketId,code,reason){reason>>>=0;var socket=WS.getSocket(socketId);if(!socket){return-3}var reasonStr=reason?UTF8ToString(reason):undefined;if(reason)socket.close(code||undefined,UTF8ToString(reason));else if(code)socket.close(code);else socket.close();return 0}_emscripten_websocket_close.sig="iiip";var _emscripten_websocket_delete=socketId=>{var socket=WS.getSocket(socketId);if(!socket){return-3}socket.onopen=socket.onerror=socket.onclose=socket.onmessage=null;webSockets.free(socketId);return 0};_emscripten_websocket_delete.sig="ii";var _emscripten_websocket_is_supported=()=>typeof WebSocket!="undefined";_emscripten_websocket_is_supported.sig="i";var _emscripten_websocket_deinitialize=()=>{for(var i in WS.sockets){var socket=WS.sockets[i];if(socket){socket.close();_emscripten_websocket_delete(i)}}WS.sockets=[]};_emscripten_websocket_deinitialize.sig="v";var writeGLArray=(arr,dst,dstLength,heapType)=>{var len=arr.length;var writeLength=dstLength>>2;for(var i=0;i>>0]=arr[i]}return len};var webglPowerPreferences=["default","low-power","high-performance"];function _emscripten_webgl_do_create_context(target,attributes){target>>>=0;attributes>>>=0;var attr32=attributes>>>2;var powerPreference=HEAP32[attr32+(8>>2)>>>0];var contextAttributes={alpha:!!HEAP8[attributes+0>>>0],depth:!!HEAP8[attributes+1>>>0],stencil:!!HEAP8[attributes+2>>>0],antialias:!!HEAP8[attributes+3>>>0],premultipliedAlpha:!!HEAP8[attributes+4>>>0],preserveDrawingBuffer:!!HEAP8[attributes+5>>>0],powerPreference:webglPowerPreferences[powerPreference],failIfMajorPerformanceCaveat:!!HEAP8[attributes+12>>>0],majorVersion:HEAP32[attr32+(16>>2)>>>0],minorVersion:HEAP32[attr32+(20>>2)>>>0],enableExtensionsByDefault:HEAP8[attributes+24>>>0],explicitSwapControl:HEAP8[attributes+25>>>0],proxyContextToMainThread:HEAP32[attr32+(28>>2)>>>0],renderViaOffscreenBackBuffer:HEAP8[attributes+32>>>0]};var canvas=findCanvasEventTarget(target);if(!canvas){return 0}if(contextAttributes.explicitSwapControl){return 0}var contextHandle=GL.createContext(canvas,contextAttributes);return contextHandle}_emscripten_webgl_do_create_context.sig="ppp";var _emscripten_webgl_create_context=_emscripten_webgl_do_create_context;_emscripten_webgl_create_context.sig="ppp";function _emscripten_webgl_do_get_current_context(){return GL.currentContext?GL.currentContext.handle:0}_emscripten_webgl_do_get_current_context.sig="p";var _emscripten_webgl_get_current_context=_emscripten_webgl_do_get_current_context;_emscripten_webgl_get_current_context.sig="p";var _emscripten_webgl_do_commit_frame=()=>{if(!GL.currentContext||!GL.currentContext.GLctx){return-3}if(!GL.currentContext.attributes.explicitSwapControl){return-3}return 0};_emscripten_webgl_do_commit_frame.sig="i";var _emscripten_webgl_commit_frame=_emscripten_webgl_do_commit_frame;_emscripten_webgl_commit_frame.sig="i";function _emscripten_webgl_make_context_current(contextHandle){contextHandle>>>=0;var success=GL.makeContextCurrent(contextHandle);return success?0:-5}_emscripten_webgl_make_context_current.sig="ip";function _emscripten_webgl_get_drawing_buffer_size(contextHandle,width,height){contextHandle>>>=0;width>>>=0;height>>>=0;var GLContext=GL.getContext(contextHandle);if(!GLContext||!GLContext.GLctx||!width||!height){return-5}HEAP32[width>>>2>>>0]=GLContext.GLctx.drawingBufferWidth;HEAP32[height>>>2>>>0]=GLContext.GLctx.drawingBufferHeight;return 0}_emscripten_webgl_get_drawing_buffer_size.sig="ippp";function _emscripten_webgl_get_context_attributes(c,a){c>>>=0;a>>>=0;if(!a)return-5;c=GL.contexts[c];if(!c)return-3;var t=c.GLctx;if(!t)return-3;t=t.getContextAttributes();HEAP8[a>>>0]=t.alpha;HEAP8[a+1>>>0]=t.depth;HEAP8[a+2>>>0]=t.stencil;HEAP8[a+3>>>0]=t.antialias;HEAP8[a+4>>>0]=t.premultipliedAlpha;HEAP8[a+5>>>0]=t.preserveDrawingBuffer;var power=t["powerPreference"]&&webglPowerPreferences.indexOf(t["powerPreference"]);HEAP32[a+8>>>2>>>0]=power;HEAP8[a+12>>>0]=t.failIfMajorPerformanceCaveat;HEAP32[a+16>>>2>>>0]=c.version;HEAP32[a+20>>>2>>>0]=0;HEAP8[a+24>>>0]=c.attributes.enableExtensionsByDefault;return 0}_emscripten_webgl_get_context_attributes.sig="ipp";function _emscripten_webgl_destroy_context(contextHandle){contextHandle>>>=0;if(GL.currentContext==contextHandle)GL.currentContext=0;GL.deleteContext(contextHandle)}_emscripten_webgl_destroy_context.sig="ip";function _emscripten_webgl_enable_extension(contextHandle,extension){contextHandle>>>=0;extension>>>=0;var context=GL.getContext(contextHandle);var extString=UTF8ToString(extension);if(extString.startsWith("GL_"))extString=extString.slice(3);if(extString=="ANGLE_instanced_arrays")webgl_enable_ANGLE_instanced_arrays(GLctx);if(extString=="OES_vertex_array_object")webgl_enable_OES_vertex_array_object(GLctx);if(extString=="WEBGL_draw_buffers")webgl_enable_WEBGL_draw_buffers(GLctx);if(extString=="WEBGL_draw_instanced_base_vertex_base_instance")webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance(GLctx);if(extString=="WEBGL_multi_draw_instanced_base_vertex_base_instance")webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance(GLctx);if(extString=="WEBGL_multi_draw")webgl_enable_WEBGL_multi_draw(GLctx);if(extString=="EXT_polygon_offset_clamp")webgl_enable_EXT_polygon_offset_clamp(GLctx);if(extString=="EXT_clip_control")webgl_enable_EXT_clip_control(GLctx);if(extString=="WEBGL_polygon_mode")webgl_enable_WEBGL_polygon_mode(GLctx);var ext=context.GLctx.getExtension(extString);return!!ext}_emscripten_webgl_enable_extension.sig="ipp";var _emscripten_supports_offscreencanvas=()=>0;_emscripten_supports_offscreencanvas.sig="i";var registerWebGlEventCallback=(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread)=>{var webGlEventHandlerFunc=(e=event)=>{if(getWasmTableEntry(callbackfunc)(eventTypeId,0,userData))e.preventDefault()};var eventHandler={target:findEventTarget(target),eventTypeString,callbackfunc,handlerFunc:webGlEventHandlerFunc,useCapture};JSEvents.registerOrRemoveHandler(eventHandler)};function _emscripten_set_webglcontextlost_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;registerWebGlEventCallback(target,userData,useCapture,callbackfunc,31,"webglcontextlost",targetThread);return 0}_emscripten_set_webglcontextlost_callback_on_thread.sig="ippipp";function _emscripten_set_webglcontextrestored_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target>>>=0;userData>>>=0;callbackfunc>>>=0;targetThread>>>=0;registerWebGlEventCallback(target,userData,useCapture,callbackfunc,32,"webglcontextrestored",targetThread);return 0}_emscripten_set_webglcontextrestored_callback_on_thread.sig="ippipp";function _emscripten_is_webgl_context_lost(contextHandle){contextHandle>>>=0;return!GL.contexts[contextHandle]||GL.contexts[contextHandle].GLctx.isContextLost()}_emscripten_is_webgl_context_lost.sig="ip";function _emscripten_webgl_get_supported_extensions(){return stringToNewUTF8(GLctx.getSupportedExtensions().join(" "))}_emscripten_webgl_get_supported_extensions.sig="p";var _emscripten_webgl_get_program_parameter_d=(program,param)=>GLctx.getProgramParameter(GL.programs[program],param);_emscripten_webgl_get_program_parameter_d.sig="dii";function _emscripten_webgl_get_program_info_log_utf8(program){return stringToNewUTF8(GLctx.getProgramInfoLog(GL.programs[program]))}_emscripten_webgl_get_program_info_log_utf8.sig="pi";var _emscripten_webgl_get_shader_parameter_d=(shader,param)=>GLctx.getShaderParameter(GL.shaders[shader],param);_emscripten_webgl_get_shader_parameter_d.sig="dii";function _emscripten_webgl_get_shader_info_log_utf8(shader){return stringToNewUTF8(GLctx.getShaderInfoLog(GL.shaders[shader]))}_emscripten_webgl_get_shader_info_log_utf8.sig="pi";function _emscripten_webgl_get_shader_source_utf8(shader){return stringToNewUTF8(GLctx.getShaderSource(GL.shaders[shader]))}_emscripten_webgl_get_shader_source_utf8.sig="pi";var _emscripten_webgl_get_vertex_attrib_d=(index,param)=>GLctx.getVertexAttrib(index,param);_emscripten_webgl_get_vertex_attrib_d.sig="dii";var _emscripten_webgl_get_vertex_attrib_o=(index,param)=>{var obj=GLctx.getVertexAttrib(index,param);return obj?.name};_emscripten_webgl_get_vertex_attrib_o.sig="iii";function _emscripten_webgl_get_vertex_attrib_v(index,param,dst,dstLength,dstType){dst>>>=0;return writeGLArray(GLctx.getVertexAttrib(index,param),dst,dstLength,dstType)}_emscripten_webgl_get_vertex_attrib_v.sig="iiipii";var _emscripten_webgl_get_uniform_d=(program,location)=>GLctx.getUniform(GL.programs[program],webglGetUniformLocation(location));_emscripten_webgl_get_uniform_d.sig="dii";function _emscripten_webgl_get_uniform_v(program,location,dst,dstLength,dstType){dst>>>=0;return writeGLArray(GLctx.getUniform(GL.programs[program],webglGetUniformLocation(location)),dst,dstLength,dstType)}_emscripten_webgl_get_uniform_v.sig="iiipii";function _emscripten_webgl_get_parameter_v(param,dst,dstLength,dstType){dst>>>=0;return writeGLArray(GLctx.getParameter(param),dst,dstLength,dstType)}_emscripten_webgl_get_parameter_v.sig="iipii";var _emscripten_webgl_get_parameter_d=param=>GLctx.getParameter(param);_emscripten_webgl_get_parameter_d.sig="di";var _emscripten_webgl_get_parameter_o=param=>{var obj=GLctx.getParameter(param);return obj?.name};_emscripten_webgl_get_parameter_o.sig="ii";function _emscripten_webgl_get_parameter_utf8(param){return stringToNewUTF8(GLctx.getParameter(param))}_emscripten_webgl_get_parameter_utf8.sig="pi";function _emscripten_webgl_get_parameter_i64v(param,dst){dst>>>=0;return writeI53ToI64(dst,GLctx.getParameter(param))}_emscripten_webgl_get_parameter_i64v.sig="vip";var EGL={errorCode:12288,defaultDisplayInitialized:false,currentContext:0,currentReadSurface:0,currentDrawSurface:0,contextAttributes:{alpha:false,depth:false,stencil:false,antialias:false},stringCache:{},setErrorCode(code){EGL.errorCode=code},chooseConfig(display,attribList,config,config_size,numConfigs){if(display!=62e3){EGL.setErrorCode(12296);return 0}if(attribList){for(;;){var param=HEAP32[attribList>>>2>>>0];if(param==12321){var alphaSize=HEAP32[attribList+4>>>2>>>0];EGL.contextAttributes.alpha=alphaSize>0}else if(param==12325){var depthSize=HEAP32[attribList+4>>>2>>>0];EGL.contextAttributes.depth=depthSize>0}else if(param==12326){var stencilSize=HEAP32[attribList+4>>>2>>>0];EGL.contextAttributes.stencil=stencilSize>0}else if(param==12337){var samples=HEAP32[attribList+4>>>2>>>0];EGL.contextAttributes.antialias=samples>0}else if(param==12338){var samples=HEAP32[attribList+4>>>2>>>0];EGL.contextAttributes.antialias=samples==1}else if(param==12544){var requestedPriority=HEAP32[attribList+4>>>2>>>0];EGL.contextAttributes.lowLatency=requestedPriority!=12547}else if(param==12344){break}attribList+=8}}if((!config||!config_size)&&!numConfigs){EGL.setErrorCode(12300);return 0}if(numConfigs){HEAP32[numConfigs>>>2>>>0]=1}if(config&&config_size>0){HEAPU32[config>>>2>>>0]=62002}EGL.setErrorCode(12288);return 1}};function _eglGetDisplay(nativeDisplayType){nativeDisplayType>>>=0;EGL.setErrorCode(12288);if(nativeDisplayType!=0&&nativeDisplayType!=1){return 0}return 62e3}_eglGetDisplay.sig="pp";function _eglInitialize(display,majorVersion,minorVersion){display>>>=0;majorVersion>>>=0;minorVersion>>>=0;if(display!=62e3){EGL.setErrorCode(12296);return 0}if(majorVersion){HEAP32[majorVersion>>>2>>>0]=1}if(minorVersion){HEAP32[minorVersion>>>2>>>0]=4}EGL.defaultDisplayInitialized=true;EGL.setErrorCode(12288);return 1}_eglInitialize.sig="ippp";function _eglTerminate(display){display>>>=0;if(display!=62e3){EGL.setErrorCode(12296);return 0}EGL.currentContext=0;EGL.currentReadSurface=0;EGL.currentDrawSurface=0;EGL.defaultDisplayInitialized=false;EGL.setErrorCode(12288);return 1}_eglTerminate.sig="ip";function _eglGetConfigs(display,configs,config_size,numConfigs){display>>>=0;configs>>>=0;numConfigs>>>=0;return EGL.chooseConfig(display,0,configs,config_size,numConfigs)}_eglGetConfigs.sig="ippip";function _eglChooseConfig(display,attrib_list,configs,config_size,numConfigs){display>>>=0;attrib_list>>>=0;configs>>>=0;numConfigs>>>=0;return EGL.chooseConfig(display,attrib_list,configs,config_size,numConfigs)}_eglChooseConfig.sig="ipppip";function _eglGetConfigAttrib(display,config,attribute,value){display>>>=0;config>>>=0;value>>>=0;if(display!=62e3){EGL.setErrorCode(12296);return 0}if(config!=62002){EGL.setErrorCode(12293);return 0}if(!value){EGL.setErrorCode(12300);return 0}EGL.setErrorCode(12288);switch(attribute){case 12320:HEAP32[value>>>2>>>0]=EGL.contextAttributes.alpha?32:24;return 1;case 12321:HEAP32[value>>>2>>>0]=EGL.contextAttributes.alpha?8:0;return 1;case 12322:HEAP32[value>>>2>>>0]=8;return 1;case 12323:HEAP32[value>>>2>>>0]=8;return 1;case 12324:HEAP32[value>>>2>>>0]=8;return 1;case 12325:HEAP32[value>>>2>>>0]=EGL.contextAttributes.depth?24:0;return 1;case 12326:HEAP32[value>>>2>>>0]=EGL.contextAttributes.stencil?8:0;return 1;case 12327:HEAP32[value>>>2>>>0]=12344;return 1;case 12328:HEAP32[value>>>2>>>0]=62002;return 1;case 12329:HEAP32[value>>>2>>>0]=0;return 1;case 12330:HEAP32[value>>>2>>>0]=4096;return 1;case 12331:HEAP32[value>>>2>>>0]=16777216;return 1;case 12332:HEAP32[value>>>2>>>0]=4096;return 1;case 12333:HEAP32[value>>>2>>>0]=0;return 1;case 12334:HEAP32[value>>>2>>>0]=0;return 1;case 12335:HEAP32[value>>>2>>>0]=12344;return 1;case 12337:HEAP32[value>>>2>>>0]=EGL.contextAttributes.antialias?4:0;return 1;case 12338:HEAP32[value>>>2>>>0]=EGL.contextAttributes.antialias?1:0;return 1;case 12339:HEAP32[value>>>2>>>0]=4;return 1;case 12340:HEAP32[value>>>2>>>0]=12344;return 1;case 12341:case 12342:case 12343:HEAP32[value>>>2>>>0]=-1;return 1;case 12345:case 12346:HEAP32[value>>>2>>>0]=0;return 1;case 12347:HEAP32[value>>>2>>>0]=0;return 1;case 12348:HEAP32[value>>>2>>>0]=1;return 1;case 12349:case 12350:HEAP32[value>>>2>>>0]=0;return 1;case 12351:HEAP32[value>>>2>>>0]=12430;return 1;case 12352:HEAP32[value>>>2>>>0]=4;return 1;case 12354:HEAP32[value>>>2>>>0]=0;return 1;default:EGL.setErrorCode(12292);return 0}}_eglGetConfigAttrib.sig="ippip";function _eglCreateWindowSurface(display,config,win,attrib_list){display>>>=0;config>>>=0;attrib_list>>>=0;if(display!=62e3){EGL.setErrorCode(12296);return 0}if(config!=62002){EGL.setErrorCode(12293);return 0}EGL.setErrorCode(12288);return 62006}_eglCreateWindowSurface.sig="pppip";function _eglDestroySurface(display,surface){display>>>=0;surface>>>=0;if(display!=62e3){EGL.setErrorCode(12296);return 0}if(surface!=62006){EGL.setErrorCode(12301);return 1}if(EGL.currentReadSurface==surface){EGL.currentReadSurface=0}if(EGL.currentDrawSurface==surface){EGL.currentDrawSurface=0}EGL.setErrorCode(12288);return 1}_eglDestroySurface.sig="ipp";function _eglCreateContext(display,config,hmm,contextAttribs){display>>>=0;config>>>=0;hmm>>>=0;contextAttribs>>>=0;if(display!=62e3){EGL.setErrorCode(12296);return 0}var glesContextVersion=1;for(;;){var param=HEAP32[contextAttribs>>>2>>>0];if(param==12440){glesContextVersion=HEAP32[contextAttribs+4>>>2>>>0]}else if(param==12344){break}else{EGL.setErrorCode(12292);return 0}contextAttribs+=8}if(glesContextVersion<2||glesContextVersion>3){EGL.setErrorCode(12293);return 0}EGL.contextAttributes.majorVersion=glesContextVersion-1;EGL.contextAttributes.minorVersion=0;EGL.context=GL.createContext(Browser.getCanvas(),EGL.contextAttributes);if(EGL.context!=0){EGL.setErrorCode(12288);GL.makeContextCurrent(EGL.context);Browser.useWebGL=true;Browser.moduleContextCreatedCallbacks.forEach(callback=>callback());GL.makeContextCurrent(null);return 62004}else{EGL.setErrorCode(12297);return 0}}_eglCreateContext.sig="ppppp";function _eglDestroyContext(display,context){display>>>=0;context>>>=0;if(display!=62e3){EGL.setErrorCode(12296);return 0}if(context!=62004){EGL.setErrorCode(12294);return 0}GL.deleteContext(EGL.context);EGL.setErrorCode(12288);if(EGL.currentContext==context){EGL.currentContext=0}return 1}_eglDestroyContext.sig="ipp";function _eglQuerySurface(display,surface,attribute,value){display>>>=0;surface>>>=0;value>>>=0;if(display!=62e3){EGL.setErrorCode(12296);return 0}if(surface!=62006){EGL.setErrorCode(12301);return 0}if(!value){EGL.setErrorCode(12300);return 0}EGL.setErrorCode(12288);switch(attribute){case 12328:HEAP32[value>>>2>>>0]=62002;return 1;case 12376:return 1;case 12375:HEAP32[value>>>2>>>0]=Browser.getCanvas().width;return 1;case 12374:HEAP32[value>>>2>>>0]=Browser.getCanvas().height;return 1;case 12432:HEAP32[value>>>2>>>0]=-1;return 1;case 12433:HEAP32[value>>>2>>>0]=-1;return 1;case 12434:HEAP32[value>>>2>>>0]=-1;return 1;case 12422:HEAP32[value>>>2>>>0]=12420;return 1;case 12441:HEAP32[value>>>2>>>0]=12442;return 1;case 12435:HEAP32[value>>>2>>>0]=12437;return 1;case 12416:case 12417:case 12418:case 12419:return 1;default:EGL.setErrorCode(12292);return 0}}_eglQuerySurface.sig="ippip";function _eglQueryContext(display,context,attribute,value){display>>>=0;context>>>=0;value>>>=0;if(display!=62e3){EGL.setErrorCode(12296);return 0}if(context!=62004){EGL.setErrorCode(12294);return 0}if(!value){EGL.setErrorCode(12300);return 0}EGL.setErrorCode(12288);switch(attribute){case 12328:HEAP32[value>>>2>>>0]=62002;return 1;case 12439:HEAP32[value>>>2>>>0]=12448;return 1;case 12440:HEAP32[value>>>2>>>0]=EGL.contextAttributes.majorVersion+1;return 1;case 12422:HEAP32[value>>>2>>>0]=12420;return 1;default:EGL.setErrorCode(12292);return 0}}_eglQueryContext.sig="ippip";var _eglGetError=()=>EGL.errorCode;_eglGetError.sig="i";function _eglQueryString(display,name){display>>>=0;if(display!=62e3){EGL.setErrorCode(12296);return 0}EGL.setErrorCode(12288);if(EGL.stringCache[name])return EGL.stringCache[name];var ret;switch(name){case 12371:ret=stringToNewUTF8("Emscripten");break;case 12372:ret=stringToNewUTF8("1.4 Emscripten EGL");break;case 12373:ret=stringToNewUTF8("");break;case 12429:ret=stringToNewUTF8("OpenGL_ES");break;default:EGL.setErrorCode(12300);return 0}EGL.stringCache[name]=ret;return ret}_eglQueryString.sig="ppi";var _eglBindAPI=api=>{if(api==12448){EGL.setErrorCode(12288);return 1}EGL.setErrorCode(12300);return 0};_eglBindAPI.sig="ii";var _eglQueryAPI=()=>{EGL.setErrorCode(12288);return 12448};_eglQueryAPI.sig="i";var _eglWaitClient=()=>{EGL.setErrorCode(12288);return 1};_eglWaitClient.sig="i";var _eglWaitNative=nativeEngineId=>{EGL.setErrorCode(12288);return 1};_eglWaitNative.sig="ii";var _eglWaitGL=_eglWaitClient;_eglWaitGL.sig="i";function _eglSwapInterval(display,interval){display>>>=0;if(display!=62e3){EGL.setErrorCode(12296);return 0}if(interval==0)_emscripten_set_main_loop_timing(0,0);else _emscripten_set_main_loop_timing(1,interval);EGL.setErrorCode(12288);return 1}_eglSwapInterval.sig="ipi";function _eglMakeCurrent(display,draw,read,context){display>>>=0;draw>>>=0;read>>>=0;context>>>=0;if(display!=62e3){EGL.setErrorCode(12296);return 0}if(context!=0&&context!=62004){EGL.setErrorCode(12294);return 0}if(read!=0&&read!=62006||draw!=0&&draw!=62006){EGL.setErrorCode(12301);return 0}GL.makeContextCurrent(context?EGL.context:null);EGL.currentContext=context;EGL.currentDrawSurface=draw;EGL.currentReadSurface=read;EGL.setErrorCode(12288);return 1}_eglMakeCurrent.sig="ipppp";function _eglGetCurrentContext(){return EGL.currentContext}_eglGetCurrentContext.sig="p";function _eglGetCurrentSurface(readdraw){if(readdraw==12378){return EGL.currentReadSurface}else if(readdraw==12377){return EGL.currentDrawSurface}else{EGL.setErrorCode(12300);return 0}}_eglGetCurrentSurface.sig="pi";function _eglGetCurrentDisplay(){return EGL.currentContext?62e3:0}_eglGetCurrentDisplay.sig="p";function _eglSwapBuffers(dpy,surface){dpy>>>=0;surface>>>=0;if(!EGL.defaultDisplayInitialized){EGL.setErrorCode(12289)}else if(!GLctx){EGL.setErrorCode(12290)}else if(GLctx.isContextLost()){EGL.setErrorCode(12302)}else{EGL.setErrorCode(12288);return 1}return 0}_eglSwapBuffers.sig="ipp";var _eglReleaseThread=()=>{EGL.currentContext=0;EGL.currentReadSurface=0;EGL.currentDrawSurface=0;EGL.setErrorCode(12288);return 1};_eglReleaseThread.sig="i";var _SDL_GetTicks=()=>Date.now()-SDL.startTime|0;_SDL_GetTicks.sig="i";function _SDL_LockSurface(surf){surf>>>=0;var surfData=SDL.surfaces[surf];surfData.locked++;if(surfData.locked>1)return 0;if(!surfData.buffer){surfData.buffer=_malloc(surfData.width*surfData.height*4);HEAPU32[surf+20>>>2>>>0]=surfData.buffer}HEAPU32[surf+20>>>2>>>0]=surfData.buffer;if(surf==SDL.screen&&Module.screenIsReadOnly&&surfData.image)return 0;if(SDL.defaults.discardOnLock){if(!surfData.image){surfData.image=surfData.ctx.createImageData(surfData.width,surfData.height)}if(!SDL.defaults.opaqueFrontBuffer)return}else{surfData.image=surfData.ctx.getImageData(0,0,surfData.width,surfData.height)}if(surf==SDL.screen&&SDL.defaults.opaqueFrontBuffer){var data=surfData.image.data;var num=data.length;for(var i=0;i>>0)}}return 0}_SDL_LockSurface.sig="ip";var SDL={defaults:{width:320,height:200,copyOnLock:true,discardOnLock:false,opaqueFrontBuffer:true},version:null,surfaces:{},canvasPool:[],events:[],fonts:[null],audios:[null],rwops:[null],music:{audio:null,volume:1},mixerFrequency:22050,mixerFormat:32784,mixerNumChannels:2,mixerChunkSize:1024,channelMinimumNumber:0,GL:false,glAttributes:{0:3,1:3,2:2,3:0,4:0,5:1,6:16,7:0,8:0,9:0,10:0,11:0,12:0,13:0,14:0,15:1,16:0,17:0,18:0},keyboardState:null,keyboardMap:{},canRequestFullscreen:false,isRequestingFullscreen:false,textInput:false,unicode:false,ttfContext:null,audio:null,startTime:null,initFlags:0,buttonState:0,modState:0,DOMButtons:[0,0,0],DOMEventToSDLEvent:{},TOUCH_DEFAULT_ID:0,eventHandler:null,eventHandlerContext:null,eventHandlerTemp:0,keyCodes:{16:1249,17:1248,18:1250,20:1081,33:1099,34:1102,35:1101,36:1098,37:1104,38:1106,39:1103,40:1105,44:316,45:1097,46:127,91:1251,93:1125,96:1122,97:1113,98:1114,99:1115,100:1116,101:1117,102:1118,103:1119,104:1120,105:1121,106:1109,107:1111,109:1110,110:1123,111:1108,112:1082,113:1083,114:1084,115:1085,116:1086,117:1087,118:1088,119:1089,120:1090,121:1091,122:1092,123:1093,124:1128,125:1129,126:1130,127:1131,128:1132,129:1133,130:1134,131:1135,132:1136,133:1137,134:1138,135:1139,144:1107,160:94,161:33,162:34,163:35,164:36,165:37,166:38,167:95,168:40,169:41,170:42,171:43,172:124,173:45,174:123,175:125,176:126,181:127,182:129,183:128,188:44,190:46,191:47,192:96,219:91,220:92,221:93,222:39,224:1251},scanCodes:{8:42,9:43,13:40,27:41,32:44,35:204,39:53,44:54,46:55,47:56,48:39,49:30,50:31,51:32,52:33,53:34,54:35,55:36,56:37,57:38,58:203,59:51,61:46,91:47,92:49,93:48,96:52,97:4,98:5,99:6,100:7,101:8,102:9,103:10,104:11,105:12,106:13,107:14,108:15,109:16,110:17,111:18,112:19,113:20,114:21,115:22,116:23,117:24,118:25,119:26,120:27,121:28,122:29,127:76,305:224,308:226,316:70},loadRect(rect){return{x:HEAP32[rect>>>2>>>0],y:HEAP32[rect+4>>>2>>>0],w:HEAP32[rect+8>>>2>>>0],h:HEAP32[rect+12>>>2>>>0]}},updateRect(rect,r){HEAP32[rect>>>2>>>0]=r.x;HEAP32[rect+4>>>2>>>0]=r.y;HEAP32[rect+8>>>2>>>0]=r.w;HEAP32[rect+12>>>2>>>0]=r.h},intersectionOfRects(first,second){var leftX=Math.max(first.x,second.x);var leftY=Math.max(first.y,second.y);var rightX=Math.min(first.x+first.w,second.x+second.w);var rightY=Math.min(first.y+first.h,second.y+second.h);return{x:leftX,y:leftY,w:Math.max(leftX,rightX)-leftX,h:Math.max(leftY,rightY)-leftY}},checkPixelFormat(fmt){},loadColorToCSSRGB(color){var rgba=HEAP32[color>>>2>>>0];return"rgb("+(rgba&255)+","+(rgba>>8&255)+","+(rgba>>16&255)+")"},loadColorToCSSRGBA(color){var rgba=HEAP32[color>>>2>>>0];return"rgba("+(rgba&255)+","+(rgba>>8&255)+","+(rgba>>16&255)+","+(rgba>>24&255)/255+")"},translateColorToCSSRGBA:rgba=>"rgba("+(rgba&255)+","+(rgba>>8&255)+","+(rgba>>16&255)+","+(rgba>>>24)/255+")",translateRGBAToCSSRGBA:(r,g,b,a)=>"rgba("+(r&255)+","+(g&255)+","+(b&255)+","+(a&255)/255+")",translateRGBAToColor:(r,g,b,a)=>r|g<<8|b<<16|a<<24,makeSurface(width,height,flags,usePageCanvas,source,rmask,gmask,bmask,amask){var is_SDL_HWSURFACE=flags&134217729;var is_SDL_HWPALETTE=flags&2097152;var is_SDL_OPENGL=flags&67108864;var surf=_malloc(60);var pixelFormat=_malloc(44);var bpp=is_SDL_HWPALETTE?1:4;var buffer=0;if(!is_SDL_HWSURFACE&&!is_SDL_OPENGL){buffer=_malloc(width*height*4)}HEAP32[surf>>>2>>>0]=flags;HEAPU32[surf+4>>>2>>>0]=pixelFormat;HEAP32[surf+8>>>2>>>0]=width;HEAP32[surf+12>>>2>>>0]=height;HEAP32[surf+16>>>2>>>0]=width*bpp;HEAPU32[surf+20>>>2>>>0]=buffer;var canvas=Browser.getCanvas();HEAP32[surf+36>>>2>>>0]=0;HEAP32[surf+40>>>2>>>0]=0;HEAP32[surf+44>>>2>>>0]=canvas.width;HEAP32[surf+48>>>2>>>0]=canvas.height;HEAP32[surf+56>>>2>>>0]=1;HEAP32[pixelFormat>>>2>>>0]=-2042224636;HEAP32[pixelFormat+4>>>2>>>0]=0;HEAP8[pixelFormat+8>>>0]=bpp*8;HEAP8[pixelFormat+9>>>0]=bpp;HEAP32[pixelFormat+12>>>2>>>0]=rmask||255;HEAP32[pixelFormat+16>>>2>>>0]=gmask||65280;HEAP32[pixelFormat+20>>>2>>>0]=bmask||16711680;HEAP32[pixelFormat+24>>>2>>>0]=amask||4278190080;SDL.GL=SDL.GL||is_SDL_OPENGL;if(!usePageCanvas){if(SDL.canvasPool.length>0){canvas=SDL.canvasPool.pop()}else{canvas=document.createElement("canvas")}canvas.width=width;canvas.height=height}var webGLContextAttributes={antialias:SDL.glAttributes[13]!=0&&SDL.glAttributes[14]>1,depth:SDL.glAttributes[6]>0,stencil:SDL.glAttributes[7]>0,alpha:SDL.glAttributes[3]>0};var ctx=Browser.createContext(canvas,is_SDL_OPENGL,usePageCanvas,webGLContextAttributes);SDL.surfaces[surf]={width,height,canvas,ctx,surf,buffer,pixelFormat,alpha:255,flags,locked:0,usePageCanvas,source,isFlagSet:flag=>flags&flag};return surf},copyIndexedColorData(surfData,rX,rY,rW,rH){if(!surfData.colors){return}var canvas=Browser.getCanvas();var fullWidth=canvas.width;var fullHeight=canvas.height;var startX=rX||0;var startY=rY||0;var endX=(rW||fullWidth-startX)+startX;var endY=(rH||fullHeight-startY)+startY;var buffer=surfData.buffer;if(!surfData.image.data32){surfData.image.data32=new Uint32Array(surfData.image.data.buffer)}var data32=surfData.image.data32;var colors32=surfData.colors32;for(var y=startY;y>>0]]}}},freeSurface(surf){var refcountPointer=surf+56;var refcount=HEAP32[refcountPointer>>>2>>>0];if(refcount>1){HEAP32[refcountPointer>>>2>>>0]=refcount-1;return}var info=SDL.surfaces[surf];if(!info.usePageCanvas&&info.canvas)SDL.canvasPool.push(info.canvas);if(info.buffer)_free(info.buffer);_free(info.pixelFormat);_free(surf);SDL.surfaces[surf]=null;if(surf===SDL.screen){SDL.screen=null}},blitSurface(src,srcrect,dst,dstrect,scale){var srcData=SDL.surfaces[src];var dstData=SDL.surfaces[dst];var sr,dr;if(srcrect){sr=SDL.loadRect(srcrect)}else{sr={x:0,y:0,w:srcData.width,h:srcData.height}}if(dstrect){dr=SDL.loadRect(dstrect)}else{dr={x:0,y:0,w:srcData.width,h:srcData.height}}if(dstData.clipRect){var widthScale=!scale||sr.w===0?1:sr.w/dr.w;var heightScale=!scale||sr.h===0?1:sr.h/dr.h;dr=SDL.intersectionOfRects(dstData.clipRect,dr);sr.w=dr.w*widthScale;sr.h=dr.h*heightScale;if(dstrect){SDL.updateRect(dstrect,dr)}}var blitw,blith;if(scale){blitw=dr.w;blith=dr.h}else{blitw=sr.w;blith=sr.h}if(sr.w===0||sr.h===0||blitw===0||blith===0){return 0}var oldAlpha=dstData.ctx.globalAlpha;dstData.ctx.globalAlpha=srcData.alpha/255;dstData.ctx.drawImage(srcData.canvas,sr.x,sr.y,sr.w,sr.h,dr.x,dr.y,blitw,blith);dstData.ctx.globalAlpha=oldAlpha;if(dst!=SDL.screen){warnOnce("WARNING: copying canvas data to memory for compatibility");_SDL_LockSurface(dst);dstData.locked--}return 0},downFingers:{},savedKeydown:null,receiveEvent(event){function unpressAllPressedKeys(){for(var keyCode of Object.values(SDL.keyboardMap)){SDL.events.push({type:"keyup",keyCode})}}switch(event.type){case"touchstart":case"touchmove":{event.preventDefault();var touches=[];if(event.type==="touchstart"){for(var touch of event.touches){if(SDL.downFingers[touch.identifier]!=true){SDL.downFingers[touch.identifier]=true;touches.push(touch)}}}else{touches=event.touches}var firstTouch=touches[0];if(firstTouch){if(event.type=="touchstart"){SDL.DOMButtons[0]=1}var mouseEventType;switch(event.type){case"touchstart":mouseEventType="mousedown";break;case"touchmove":mouseEventType="mousemove";break}var mouseEvent={type:mouseEventType,button:0,pageX:firstTouch.clientX,pageY:firstTouch.clientY};SDL.events.push(mouseEvent)}for(var touch of touches){SDL.events.push({type:event.type,touch})}break}case"touchend":{event.preventDefault();for(var touch of event.changedTouches){if(SDL.downFingers[touch.identifier]===true){delete SDL.downFingers[touch.identifier]}}var mouseEvent={type:"mouseup",button:0,pageX:event.changedTouches[0].clientX,pageY:event.changedTouches[0].clientY};SDL.DOMButtons[0]=0;SDL.events.push(mouseEvent);for(var touch of event.changedTouches){SDL.events.push({type:"touchend",touch})}break}case"DOMMouseScroll":case"mousewheel":case"wheel":var delta=-Browser.getMouseWheelDelta(event);delta=delta==0?0:delta>0?Math.max(delta,1):Math.min(delta,-1);var button=(delta>0?4:5)-1;SDL.events.push({type:"mousedown",button,pageX:event.pageX,pageY:event.pageY});SDL.events.push({type:"mouseup",button,pageX:event.pageX,pageY:event.pageY});SDL.events.push({type:"wheel",deltaX:0,deltaY:delta});event.preventDefault();break;case"mousemove":if(SDL.DOMButtons[0]===1){SDL.events.push({type:"touchmove",touch:{identifier:0,deviceID:-1,pageX:event.pageX,pageY:event.pageY}})}if(Browser.pointerLock){if("mozMovementX"in event){event["movementX"]=event["mozMovementX"];event["movementY"]=event["mozMovementY"]}if(event["movementX"]==0&&event["movementY"]==0){event.preventDefault();return}}case"keydown":case"keyup":case"keypress":case"mousedown":case"mouseup":if(event.type!=="keydown"||!SDL.unicode&&!SDL.textInput||(event.key=="Backspace"||event.key=="Tab")){event.preventDefault()}if(event.type=="mousedown"){SDL.DOMButtons[event.button]=1;SDL.events.push({type:"touchstart",touch:{identifier:0,deviceID:-1,pageX:event.pageX,pageY:event.pageY}})}else if(event.type=="mouseup"){if(!SDL.DOMButtons[event.button]){return}SDL.events.push({type:"touchend",touch:{identifier:0,deviceID:-1,pageX:event.pageX,pageY:event.pageY}});SDL.DOMButtons[event.button]=0}if(event.type==="keydown"||event.type==="mousedown"){SDL.canRequestFullscreen=true}else if(event.type==="keyup"||event.type==="mouseup"){if(SDL.isRequestingFullscreen){Module["requestFullscreen"](true,true);SDL.isRequestingFullscreen=false}SDL.canRequestFullscreen=false}if(event.type==="keypress"&&SDL.savedKeydown){SDL.savedKeydown.keypressCharCode=event.charCode;SDL.savedKeydown=null}else if(event.type==="keydown"){SDL.savedKeydown=event}if(event.type!=="keypress"||SDL.textInput){SDL.events.push(event)}break;case"mouseout":for(var i=0;i<3;i++){if(SDL.DOMButtons[i]){SDL.events.push({type:"mouseup",button:i,pageX:event.pageX,pageY:event.pageY});SDL.DOMButtons[i]=0}}event.preventDefault();break;case"focus":SDL.events.push(event);event.preventDefault();break;case"blur":SDL.events.push(event);unpressAllPressedKeys();event.preventDefault();break;case"visibilitychange":SDL.events.push({type:"visibilitychange",visible:!document.hidden});unpressAllPressedKeys();event.preventDefault();break;case"unload":if(MainLoop.runner){SDL.events.push(event);MainLoop.runner()}return;case"resize":SDL.events.push(event);if(event.preventDefault){event.preventDefault()}break}if(SDL.events.length>=1e4){err("SDL event queue full, dropping events");SDL.events=SDL.events.slice(0,1e4)}SDL.flushEventsToHandler();return},lookupKeyCodeForEvent(event){var code=event.keyCode;if(code>=65&&code<=90){code+=32}else{code=SDL.keyCodes[code]||(code<128?code:0);if(event.location===2&&code>=(224|1<<10)&&code<=(227|1<<10)){code+=4}}return code},handleEvent(event){if(event.handled)return;event.handled=true;switch(event.type){case"touchstart":case"touchend":case"touchmove":{Browser.calculateMouseEvent(event);break}case"keydown":case"keyup":{var down=event.type==="keydown";var code=SDL.lookupKeyCodeForEvent(event);if(!code)return;HEAP8[SDL.keyboardState+code>>>0]=down;SDL.modState=(HEAP8[SDL.keyboardState+1248>>>0]?64:0)|(HEAP8[SDL.keyboardState+1249>>>0]?1:0)|(HEAP8[SDL.keyboardState+1250>>>0]?256:0)|(HEAP8[SDL.keyboardState+1252>>>0]?128:0)|(HEAP8[SDL.keyboardState+1253>>>0]?2:0)|(HEAP8[SDL.keyboardState+1254>>>0]?512:0);if(down){SDL.keyboardMap[code]=event.keyCode}else{delete SDL.keyboardMap[code]}break}case"mousedown":case"mouseup":if(event.type=="mousedown"){SDL.buttonState|=1<0){if(SDL.makeCEvent(SDL.events.shift(),ptr)!==false)return 1}return 0}return SDL.events.length>0},makeCEvent(event,ptr){if(typeof event=="number"){_memcpy(ptr,event,28);_free(event);return}SDL.handleEvent(event);switch(event.type){case"keydown":case"keyup":{var down=event.type==="keydown";var key=SDL.lookupKeyCodeForEvent(event);if(!key)return false;var scan;if(key>=1024){scan=key-1024}else{scan=SDL.scanCodes[key]||key}HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];HEAP8[ptr+8>>>0]=down?1:0;HEAP8[ptr+9>>>0]=0;HEAP32[ptr+12>>>2>>>0]=scan;HEAP32[ptr+16>>>2>>>0]=key;HEAP16[ptr+20>>>1>>>0]=SDL.modState;HEAP32[ptr+24>>>2>>>0]=event.keypressCharCode||key;break}case"keypress":{HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];var cStr=intArrayFromString(String.fromCharCode(event.charCode));for(var i=0;i>>0]=cStr[i]}break}case"mousedown":case"mouseup":case"mousemove":{if(event.type!="mousemove"){var down=event.type==="mousedown";HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];HEAP32[ptr+4>>>2>>>0]=0;HEAP32[ptr+8>>>2>>>0]=0;HEAP32[ptr+12>>>2>>>0]=0;HEAP8[ptr+16>>>0]=event.button+1;HEAP8[ptr+17>>>0]=down?1:0;HEAP32[ptr+20>>>2>>>0]=Browser.mouseX;HEAP32[ptr+24>>>2>>>0]=Browser.mouseY}else{HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];HEAP32[ptr+4>>>2>>>0]=0;HEAP32[ptr+8>>>2>>>0]=0;HEAP32[ptr+12>>>2>>>0]=0;HEAP32[ptr+16>>>2>>>0]=SDL.buttonState;HEAP32[ptr+20>>>2>>>0]=Browser.mouseX;HEAP32[ptr+24>>>2>>>0]=Browser.mouseY;HEAP32[ptr+28>>>2>>>0]=Browser.mouseMovementX;HEAP32[ptr+32>>>2>>>0]=Browser.mouseMovementY}break}case"wheel":{HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];HEAP32[ptr+16>>>2>>>0]=event.deltaX;HEAP32[ptr+20>>>2>>>0]=event.deltaY;break}case"touchstart":case"touchend":case"touchmove":{var touch=event.touch;if(!Browser.touches[touch.identifier])break;var canvas=Browser.getCanvas();var x=Browser.touches[touch.identifier].x/canvas.width;var y=Browser.touches[touch.identifier].y/canvas.height;var lx=Browser.lastTouches[touch.identifier].x/canvas.width;var ly=Browser.lastTouches[touch.identifier].y/canvas.height;var dx=x-lx;var dy=y-ly;if(touch["deviceID"]===undefined)touch.deviceID=SDL.TOUCH_DEFAULT_ID;if(dx===0&&dy===0&&event.type==="touchmove")return false;HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];HEAP32[ptr+4>>>2>>>0]=_SDL_GetTicks();HEAP64[ptr+8>>>3>>>0]=BigInt(touch.deviceID);HEAP64[ptr+16>>>3>>>0]=BigInt(touch.identifier);HEAPF32[ptr+24>>>2>>>0]=x;HEAPF32[ptr+28>>>2>>>0]=y;HEAPF32[ptr+32>>>2>>>0]=dx;HEAPF32[ptr+36>>>2>>>0]=dy;if(touch.force!==undefined){HEAPF32[ptr+40>>>2>>>0]=touch.force}else{HEAPF32[ptr+40>>>2>>>0]=event.type=="touchend"?0:1}break}case"unload":{HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];break}case"resize":{HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];HEAP32[ptr+4>>>2>>>0]=event.w;HEAP32[ptr+8>>>2>>>0]=event.h;break}case"joystick_button_up":case"joystick_button_down":{var state=event.type==="joystick_button_up"?0:1;HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];HEAP8[ptr+4>>>0]=event.index;HEAP8[ptr+5>>>0]=event.button;HEAP8[ptr+6>>>0]=state;break}case"joystick_axis_motion":{HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];HEAP8[ptr+4>>>0]=event.index;HEAP8[ptr+5>>>0]=event.axis;HEAP32[ptr+8>>>2>>>0]=SDL.joystickAxisValueConversion(event.value);break}case"focus":{HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];HEAP32[ptr+4>>>2>>>0]=0;HEAP8[ptr+8>>>0]=12;break}case"blur":{HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];HEAP32[ptr+4>>>2>>>0]=0;HEAP8[ptr+8>>>0]=13;break}case"visibilitychange":{var visibilityEventID=event.visible?1:2;HEAP32[ptr>>>2>>>0]=SDL.DOMEventToSDLEvent[event.type];HEAP32[ptr+4>>>2>>>0]=0;HEAP8[ptr+8>>>0]=visibilityEventID;break}default:throw"Unhandled SDL event: "+event.type}},makeFontString(height,fontName){if(fontName.charAt(0)!="'"&&fontName.charAt(0)!='"'){fontName='"'+fontName+'"'}return height+"px "+fontName+", serif"},estimateTextWidth(fontData,text){var h=fontData.size;var fontString=SDL.makeFontString(h,fontData.name);var tempCtx=SDL.ttfContext;tempCtx.font=fontString;var ret=tempCtx.measureText(text).width|0;return ret},allocateChannels(num){if(SDL.numChannels>=num&&num!=0)return;SDL.numChannels=num;SDL.channels=[];for(var i=0;i{if(!audio.paused)SDL.playWebAudio(audio)});return}audio.webAudioNode=SDL.audioContext["createBufferSource"]();audio.webAudioNode["buffer"]=webAudio.decodedBuffer;audio.webAudioNode["loop"]=audio.loop;audio.webAudioNode["onended"]=audio["onended"];audio.webAudioPannerNode=SDL.audioContext["createPanner"]();audio.webAudioPannerNode["setPosition"](0,0,-.5);audio.webAudioPannerNode["panningModel"]="equalpower";audio.webAudioGainNode=SDL.audioContext["createGain"]();audio.webAudioGainNode["gain"]["value"]=audio.volume;audio.webAudioNode["connect"](audio.webAudioPannerNode);audio.webAudioPannerNode["connect"](audio.webAudioGainNode);audio.webAudioGainNode["connect"](SDL.audioContext["destination"]);audio.webAudioNode["start"](0,audio.currentPosition);audio.startTime=SDL.audioContext["currentTime"]-audio.currentPosition}catch(e){err(`playWebAudio failed: ${e}`)}},pauseWebAudio(audio){if(!audio)return;if(audio.webAudioNode){try{audio.currentPosition=(SDL.audioContext["currentTime"]-audio.startTime)%audio.resource.webAudio.decodedBuffer.duration;audio.webAudioNode["onended"]=undefined;audio.webAudioNode.stop(0);audio.webAudioNode=undefined}catch(e){err(`pauseWebAudio failed: ${e}`)}}audio.paused=true},openAudioContext(){if(!SDL.audioContext){if(typeof AudioContext!="undefined"){SDL.audioContext=new AudioContext}else if(typeof webkitAudioContext!="undefined"){SDL.audioContext=new webkitAudioContext}}},webAudioAvailable:()=>!!SDL.audioContext,fillWebAudioBufferFromHeap(heapPtr,sizeSamplesPerChannel,dstAudioBuffer){var audio=SDL.audio;var numChannels=audio.channels;for(var c=0;c>>1>>>0]/32768}}else if(audio.format==8){for(var j=0;j>>0];channelData[j]=(v>=0?v-128:v+128)/128}}else if(audio.format==33056){for(var j=0;j>>2>>>0]}}else{throw"Invalid SDL audio format "+audio.format+"!"}}},joystickEventState:1,lastJoystickState:{},joystickNamePool:{},recordJoystickState(joystick,state){var buttons=[];for(var button of state.buttons){buttons.push(SDL.getJoystickButtonState(button))}SDL.lastJoystickState[joystick]={buttons,axes:state.axes.slice(0),timestamp:state.timestamp,index:state.index,id:state.id}},getJoystickButtonState(button){if(typeof button=="object"){return button["pressed"]}return button>0},queryJoysticks(){for(var joystick in SDL.lastJoystickState){var state=SDL.getGamepad(joystick-1);var prevState=SDL.lastJoystickState[joystick];if(typeof state=="undefined")return;if(state===null)return;if(typeof state.timestamp!="number"||state.timestamp!=prevState.timestamp||!state.timestamp){var i;for(i=0;ideviceIndex&&deviceIndex>=0){return gamepads[deviceIndex]}return null}};function _SDL_Linked_Version(){if(SDL.version===null){SDL.version=_malloc(3);HEAP8[SDL.version>>>0]=1;HEAP8[SDL.version+1>>>0]=3;HEAP8[SDL.version+2>>>0]=0}return SDL.version}_SDL_Linked_Version.sig="p";var _SDL_Init=initFlags=>{SDL.startTime=Date.now();SDL.initFlags=initFlags;if(!Module["doNotCaptureKeyboard"]){var keyboardListeningElement=Module["keyboardListeningElement"]||document;keyboardListeningElement.addEventListener("keydown",SDL.receiveEvent);keyboardListeningElement.addEventListener("keyup",SDL.receiveEvent);keyboardListeningElement.addEventListener("keypress",SDL.receiveEvent);window.addEventListener("focus",SDL.receiveEvent);window.addEventListener("blur",SDL.receiveEvent);document.addEventListener("visibilitychange",SDL.receiveEvent)}window.addEventListener("unload",SDL.receiveEvent);SDL.keyboardState=_calloc(65536,1);SDL.DOMEventToSDLEvent["keydown"]=768;SDL.DOMEventToSDLEvent["keyup"]=769;SDL.DOMEventToSDLEvent["keypress"]=771;SDL.DOMEventToSDLEvent["mousedown"]=1025;SDL.DOMEventToSDLEvent["mouseup"]=1026;SDL.DOMEventToSDLEvent["mousemove"]=1024;SDL.DOMEventToSDLEvent["wheel"]=1027;SDL.DOMEventToSDLEvent["touchstart"]=1792;SDL.DOMEventToSDLEvent["touchend"]=1793;SDL.DOMEventToSDLEvent["touchmove"]=1794;SDL.DOMEventToSDLEvent["unload"]=256;SDL.DOMEventToSDLEvent["resize"]=28673;SDL.DOMEventToSDLEvent["visibilitychange"]=512;SDL.DOMEventToSDLEvent["focus"]=512;SDL.DOMEventToSDLEvent["blur"]=512;SDL.DOMEventToSDLEvent["joystick_axis_motion"]=1536;SDL.DOMEventToSDLEvent["joystick_button_down"]=1539;SDL.DOMEventToSDLEvent["joystick_button_up"]=1540;return 0};_SDL_Init.sig="ii";var _SDL_WasInit=flags=>{if(SDL.startTime===null){_SDL_Init(0)}return 1};_SDL_WasInit.sig="ii";function _SDL_GetVideoInfo(){var ret=_calloc(20,1);var canvas=Browser.getCanvas();HEAP32[ret+12>>>2>>>0]=canvas.width;HEAP32[ret+16>>>2>>>0]=canvas.height;return ret}_SDL_GetVideoInfo.sig="p";function _SDL_ListModes(format,flags){format>>>=0;return-1}_SDL_ListModes.sig="ppi";var _SDL_VideoModeOK=(width,height,depth,flags)=>depth;_SDL_VideoModeOK.sig="iiiii";function _SDL_VideoDriverName(buf,max_size){buf>>>=0;if(SDL.startTime===null){return 0}var driverName=[101,109,115,99,114,105,112,116,101,110,95,115,100,108,95,100,114,105,118,101,114];var index=0;var size=driverName.length;if(max_size<=size){size=max_size-1}while(index>>0]=value;index++}HEAP8[buf+index>>>0]=0;return buf}_SDL_VideoDriverName.sig="ppi";var _SDL_AudioDriverName=_SDL_VideoDriverName;_SDL_AudioDriverName.sig="ppi";var _SDL_SetVideoMode=function(width,height,depth,flags){var canvas=Browser.getCanvas();["touchstart","touchend","touchmove","mousedown","mouseup","mousemove","mousewheel","wheel","mouseout","DOMMouseScroll"].forEach(e=>canvas.addEventListener(e,SDL.receiveEvent,true));if(width==0&&height==0){width=canvas.width;height=canvas.height}if(!SDL.addedResizeListener){SDL.addedResizeListener=true;Browser.resizeListeners.push((w,h)=>{if(!SDL.settingVideoMode){SDL.receiveEvent({type:"resize",w,h})}})}SDL.settingVideoMode=true;Browser.setCanvasSize(width,height);SDL.settingVideoMode=false;if(SDL.screen){SDL.freeSurface(SDL.screen);assert(!SDL.screen)}if(SDL.GL)flags=flags|67108864;SDL.screen=SDL.makeSurface(width,height,flags,true,"screen");return SDL.screen};_SDL_SetVideoMode.sig="piiii";function _SDL_GetVideoSurface(){return SDL.screen}_SDL_GetVideoSurface.sig="p";var _SDL_AudioQuit=()=>{for(var i=0;iout("SDL_VideoQuit called (and ignored)");_SDL_VideoQuit.sig="v";var _SDL_QuitSubSystem=flags=>out("SDL_QuitSubSystem called (and ignored)");_SDL_QuitSubSystem.sig="vi";var _SDL_Quit=()=>{_SDL_AudioQuit();out("SDL_Quit called (and ignored)")};_SDL_Quit.sig="v";function _SDL_UnlockSurface(surf){surf>>>=0;assert(!SDL.GL);var surfData=SDL.surfaces[surf];if(!surfData.locked||--surfData.locked>0){return}if(surfData.isFlagSet(2097152)){SDL.copyIndexedColorData(surfData)}else if(!surfData.colors){var data=surfData.image.data;var buffer=surfData.buffer;assert(buffer%4==0,"Invalid buffer offset: "+buffer);var src=buffer>>>2;var dst=0;var isScreen=surf==SDL.screen;var num;if(typeof CanvasPixelArray!="undefined"&&data instanceof CanvasPixelArray){num=data.length;while(dst>>0];data[dst]=val&255;data[dst+1]=val>>8&255;data[dst+2]=val>>16&255;data[dst+3]=isScreen?255:val>>24&255;src++;dst+=4}}else{var data32=new Uint32Array(data.buffer);if(isScreen&&SDL.defaults.opaqueFrontBuffer){num=data32.length;data32.set(HEAP32.subarray(src>>>0,src+num>>>0));var data8=new Uint8Array(data.buffer);var i=3;var j=i+4*num;if(num%8==0){while(i>>0,src+data32.length>>>0))}}}else{var canvas=Browser.getCanvas();var width=canvas.width;var height=canvas.height;var s=surfData.buffer;var data=surfData.image.data;var colors=surfData.colors;for(var y=0;y>>0]*4;var start=base+x*4;data[start]=colors[val];data[start+1]=colors[val+1];data[start+2]=colors[val+2]}s+=width*3}}surfData.ctx.putImageData(surfData.image,0,0)}_SDL_UnlockSurface.sig="vp";function _SDL_Flip(surf){surf>>>=0}_SDL_Flip.sig="ip";function _SDL_UpdateRect(surf,x,y,w,h){surf>>>=0}_SDL_UpdateRect.sig="vpiiii";function _SDL_UpdateRects(surf,numrects,rects){surf>>>=0;rects>>>=0}_SDL_UpdateRects.sig="vpip";var _SDL_Delay=delay=>{if(!ENVIRONMENT_IS_WORKER)abort("SDL_Delay called on the main thread! Potential infinite loop, quitting. (consider building with async support like ASYNCIFY)");var now=Date.now();while(Date.now()-now>>=0;icon>>>=0;if(title){_emscripten_set_window_title(title)}icon&&=UTF8ToString(icon)}_SDL_WM_SetCaption.sig="vpp";var _SDL_EnableKeyRepeat=(delay,interval)=>{};_SDL_EnableKeyRepeat.sig="iii";function _SDL_GetKeyboardState(numKeys){numKeys>>>=0;if(numKeys){HEAP32[numKeys>>>2>>>0]=65536}return SDL.keyboardState}_SDL_GetKeyboardState.sig="pp";var _SDL_GetKeyState=()=>_SDL_GetKeyboardState(0);function _SDL_GetKeyName(key){var name="";if(key>=97&&key<=122||key>=48&&key<=57){name=String.fromCharCode(key)}var size=lengthBytesUTF8(name)+1;SDL.keyName=_realloc(SDL.keyName,size);stringToUTF8(name,SDL.keyName,size);return SDL.keyName}_SDL_GetKeyName.sig="pi";var _SDL_GetModState=()=>SDL.modState;_SDL_GetModState.sig="i";function _SDL_GetMouseState(x,y){x>>>=0;y>>>=0;if(x)HEAP32[x>>>2>>>0]=Browser.mouseX;if(y)HEAP32[y>>>2>>>0]=Browser.mouseY;return SDL.buttonState}_SDL_GetMouseState.sig="ipp";var _SDL_WarpMouse=(x,y)=>{};_SDL_WarpMouse.sig="vii";var _SDL_ShowCursor=toggle=>{switch(toggle){case 0:if(Browser.isFullscreen){Browser.getCanvas().requestPointerLock();return 0}return 1;case 1:Browser.getCanvas().exitPointerLock();return 1;case-1:return!Browser.pointerLock;default:err(`SDL_ShowCursor called with unknown toggle parameter value: ${toggle}`);break}};_SDL_ShowCursor.sig="ii";function _SDL_GetError(){SDL.errorMessage||=stringToNewUTF8("unknown SDL-emscripten error");return SDL.errorMessage}_SDL_GetError.sig="p";function _SDL_SetError(fmt,varargs){fmt>>>=0;varargs>>>=0}_SDL_SetError.sig="vpp";function _SDL_CreateRGBSurface(flags,width,height,depth,rmask,gmask,bmask,amask){return SDL.makeSurface(width,height,flags,false,"CreateRGBSurface",rmask,gmask,bmask,amask)}_SDL_CreateRGBSurface.sig="piiiiiiii";function _SDL_CreateRGBSurfaceFrom(pixels,width,height,depth,pitch,rmask,gmask,bmask,amask){pixels>>>=0;var surf=SDL.makeSurface(width,height,0,false,"CreateRGBSurfaceFrom",rmask,gmask,bmask,amask);if(depth!==32){err("TODO: Partially unimplemented SDL_CreateRGBSurfaceFrom called!");return surf}var data=SDL.surfaces[surf];var image=data.ctx.createImageData(width,height);var pitchOfDst=width*4;for(var row=0;row>>0]}}data.ctx.putImageData(image,0,0);return surf}_SDL_CreateRGBSurfaceFrom.sig="ppiiiiiiii";function _SDL_ConvertSurface(surf,format,flags){surf>>>=0;format>>>=0;if(format){SDL.checkPixelFormat(format)}var oldData=SDL.surfaces[surf];var ret=SDL.makeSurface(oldData.width,oldData.height,oldData.flags,false,"copy:"+oldData.source);var newData=SDL.surfaces[ret];newData.ctx.globalCompositeOperation="copy";newData.ctx.drawImage(oldData.canvas,0,0);newData.ctx.globalCompositeOperation=oldData.ctx.globalCompositeOperation;return ret}_SDL_ConvertSurface.sig="pppi";function _SDL_DisplayFormat(surf){surf>>>=0;return _SDL_ConvertSurface(surf,0,0)}_SDL_DisplayFormat.sig="pp";function _SDL_DisplayFormatAlpha(surf){surf>>>=0;return _SDL_ConvertSurface(surf,0,0)}_SDL_DisplayFormatAlpha.sig="pp";function _SDL_FreeSurface(surf){surf>>>=0;if(surf)SDL.freeSurface(surf)}_SDL_FreeSurface.sig="vp";function _SDL_UpperBlit(src,srcrect,dst,dstrect){src>>>=0;srcrect>>>=0;dst>>>=0;dstrect>>>=0;return SDL.blitSurface(src,srcrect,dst,dstrect,false)}_SDL_UpperBlit.sig="ipppp";function _SDL_UpperBlitScaled(src,srcrect,dst,dstrect){src>>>=0;srcrect>>>=0;dst>>>=0;dstrect>>>=0;return SDL.blitSurface(src,srcrect,dst,dstrect,true)}_SDL_UpperBlitScaled.sig="ipppp";var _SDL_LowerBlit=_SDL_UpperBlit;_SDL_LowerBlit.sig="ipppp";var _SDL_LowerBlitScaled=_SDL_UpperBlitScaled;_SDL_LowerBlitScaled.sig="ipppp";function _SDL_GetClipRect(surf,rect){surf>>>=0;rect>>>=0;assert(rect);var surfData=SDL.surfaces[surf];var r=surfData.clipRect||{x:0,y:0,w:surfData.width,h:surfData.height};SDL.updateRect(rect,r)}_SDL_GetClipRect.sig="vpp";function _SDL_SetClipRect(surf,rect){surf>>>=0;rect>>>=0;var surfData=SDL.surfaces[surf];if(rect){surfData.clipRect=SDL.intersectionOfRects({x:0,y:0,w:surfData.width,h:surfData.height},SDL.loadRect(rect))}else{delete surfData.clipRect}}_SDL_SetClipRect.sig="ipp";function _SDL_FillRect(surf,rect,color){surf>>>=0;rect>>>=0;var surfData=SDL.surfaces[surf];assert(!surfData.locked);if(surfData.isFlagSet(2097152)){color=surfData.colors32[color]}var r=rect?SDL.loadRect(rect):{x:0,y:0,w:surfData.width,h:surfData.height};if(surfData.clipRect){r=SDL.intersectionOfRects(surfData.clipRect,r);if(rect){SDL.updateRect(rect,r)}}surfData.ctx.save();surfData.ctx.fillStyle=SDL.translateColorToCSSRGBA(color);surfData.ctx.fillRect(r.x,r.y,r.w,r.h);surfData.ctx.restore();return 0}_SDL_FillRect.sig="ippi";function _zoomSurface(src,x,y,smooth){src>>>=0;var srcData=SDL.surfaces[src];var w=srcData.width*x;var h=srcData.height*y;var ret=SDL.makeSurface(Math.abs(w),Math.abs(h),srcData.flags,false,"zoomSurface");var dstData=SDL.surfaces[ret];if(x>=0&&y>=0){dstData.ctx.drawImage(srcData.canvas,0,0,w,h)}else{dstData.ctx.save();dstData.ctx.scale(x<0?-1:1,y<0?-1:1);dstData.ctx.drawImage(srcData.canvas,w<0?w:0,h<0?h:0,Math.abs(w),Math.abs(h));dstData.ctx.restore()}return ret}_zoomSurface.sig="ppddi";function _rotozoomSurface(src,angle,zoom,smooth){src>>>=0;if(angle%360===0){return _zoomSurface(src,zoom,zoom,smooth)}var srcData=SDL.surfaces[src];var w=srcData.width*zoom;var h=srcData.height*zoom;var diagonal=Math.ceil(Math.sqrt(Math.pow(w,2)+Math.pow(h,2)));var ret=SDL.makeSurface(diagonal,diagonal,srcData.flags,false,"rotozoomSurface");var dstData=SDL.surfaces[ret];dstData.ctx.translate(diagonal/2,diagonal/2);dstData.ctx.rotate(-angle*Math.PI/180);dstData.ctx.drawImage(srcData.canvas,-w/2,-h/2,w,h);return ret}_rotozoomSurface.sig="ppddi";function _SDL_SetAlpha(surf,flag,alpha){surf>>>=0;var surfData=SDL.surfaces[surf];surfData.alpha=alpha;if(!(flag&65536)){surfData.alpha=255}}_SDL_SetAlpha.sig="ipii";function _SDL_SetColorKey(surf,flag,key){surf>>>=0;warnOnce("SDL_SetColorKey is a no-op for performance reasons");return 0}_SDL_SetColorKey.sig="ipii";function _SDL_PollEvent(ptr){ptr>>>=0;return SDL.pollEvent(ptr)}_SDL_PollEvent.sig="ip";function _SDL_PushEvent(ptr){ptr>>>=0;var copy=_malloc(28);_memcpy(copy,ptr,28);SDL.events.push(copy);return 0}_SDL_PushEvent.sig="ip";function _SDL_PeepEvents(events,requestedEventCount,action,from,to){events>>>=0;switch(action){case 2:{assert(requestedEventCount==1);var index=0;var retrievedEventCount=0;while(indexSDL.events.forEach(SDL.handleEvent);_SDL_PumpEvents.sig="v";function _emscripten_SDL_SetEventHandler(handler,userdata){handler>>>=0;userdata>>>=0;SDL.eventHandler=handler;SDL.eventHandlerContext=userdata;SDL.eventHandlerTemp||=_malloc(28)}_emscripten_SDL_SetEventHandler.sig="vpp";function _SDL_SetColors(surf,colors,firstColor,nColors){surf>>>=0;colors>>>=0;var surfData=SDL.surfaces[surf];if(!surfData.colors){var buffer=new ArrayBuffer(256*4);surfData.colors=new Uint8Array(buffer);surfData.colors32=new Uint32Array(buffer)}for(var i=0;i>>0];surfData.colors[index+1]=HEAPU8[colors+(i*4+1)>>>0];surfData.colors[index+2]=HEAPU8[colors+(i*4+2)>>>0];surfData.colors[index+3]=255}return 1}_SDL_SetColors.sig="ippii";function _SDL_SetPalette(surf,flags,colors,firstColor,nColors){surf>>>=0;colors>>>=0;return _SDL_SetColors(surf,colors,firstColor,nColors)}_SDL_SetPalette.sig="ipipii";function _SDL_MapRGB(fmt,r,g,b){fmt>>>=0;SDL.checkPixelFormat(fmt);return r&255|(g&255)<<8|(b&255)<<16|4278190080}_SDL_MapRGB.sig="ipiii";function _SDL_MapRGBA(fmt,r,g,b,a){fmt>>>=0;SDL.checkPixelFormat(fmt);return r&255|(g&255)<<8|(b&255)<<16|(a&255)<<24}_SDL_MapRGBA.sig="ipiiii";function _SDL_GetRGB(pixel,fmt,r,g,b){fmt>>>=0;r>>>=0;g>>>=0;b>>>=0;SDL.checkPixelFormat(fmt);if(r){HEAP8[r>>>0]=pixel&255}if(g){HEAP8[g>>>0]=pixel>>8&255}if(b){HEAP8[b>>>0]=pixel>>16&255}}_SDL_GetRGB.sig="vipppp";function _SDL_GetRGBA(pixel,fmt,r,g,b,a){fmt>>>=0;r>>>=0;g>>>=0;b>>>=0;a>>>=0;SDL.checkPixelFormat(fmt);if(r){HEAP8[r>>>0]=pixel&255}if(g){HEAP8[g>>>0]=pixel>>8&255}if(b){HEAP8[b>>>0]=pixel>>16&255}if(a){HEAP8[a>>>0]=pixel>>24&255}}_SDL_GetRGBA.sig="vippppp";var _SDL_GetAppState=()=>{var state=0;if(Browser.pointerLock){state|=1}if(document.hasFocus()){state|=2}state|=4;return state};_SDL_GetAppState.sig="i";var _SDL_WM_GrabInput=()=>{};_SDL_WM_GrabInput.sig="ii";function _SDL_WM_ToggleFullScreen(surf){surf>>>=0;if(Browser.exitFullscreen()){return 1}if(!SDL.canRequestFullscreen){return 0}SDL.isRequestingFullscreen=true;return 1}_SDL_WM_ToggleFullScreen.sig="ip";var _IMG_Init=flags=>flags;_IMG_Init.sig="ii";function _SDL_FreeRW(rwopsID){rwopsID>>>=0;SDL.rwops[rwopsID]=null;while(SDL.rwops.length>0&&SDL.rwops[SDL.rwops.length-1]===null){SDL.rwops.pop()}}_SDL_FreeRW.sig="vp";var _IMG_Load_RW=function(rwopsID,freeSrc){rwopsID>>>=0;var sp=stackSave();try{var cleanup=()=>{stackRestore(sp);if(rwops&&freeSrc)_SDL_FreeRW(rwopsID)};var addCleanup=func=>{var old=cleanup;cleanup=()=>{old();func()}};var callStbImage=(func,params)=>{var x=stackAlloc(4);var y=stackAlloc(4);var comp=stackAlloc(4);var data=Module["_"+func](...params,x,y,comp,0);if(!data)return null;addCleanup(()=>Module["_stbi_image_free"](data));return{rawData:true,data,width:HEAP32[x>>>2>>>0],height:HEAP32[y>>>2>>>0],size:HEAP32[x>>>2>>>0]*HEAP32[y>>>2>>>0]*HEAP32[comp>>>2>>>0],bpp:HEAP32[comp>>>2>>>0]}};var rwops=SDL.rwops[rwopsID];if(rwops===undefined){return 0}var raw;var filename=rwops.filename;if(filename===undefined){warnOnce("Only file names that have been preloaded are supported for IMG_Load_RW. Consider using STB_IMAGE=1 if you want synchronous image decoding (see settings.js), or package files with --use-preload-plugins");return 0}if(!raw){filename=PATH_FS.resolve(filename);raw=Browser.preloadedImages[filename];if(!raw){if(raw===null)err("Trying to reuse preloaded image, but freePreloadedMediaOnUse is set!");warnOnce("Cannot find preloaded image "+filename);warnOnce("Cannot find preloaded image "+filename+". Consider using STB_IMAGE=1 if you want synchronous image decoding (see settings.js), or package files with --use-preload-plugins");return 0}else if(Module["freePreloadedMediaOnUse"]){Browser.preloadedImages[filename]=null}}var surf=SDL.makeSurface(raw.width,raw.height,0,false,"load:"+filename);var surfData=SDL.surfaces[surf];surfData.ctx.globalCompositeOperation="copy";if(!raw.rawData){surfData.ctx.drawImage(raw,0,0,raw.width,raw.height,0,0,raw.width,raw.height)}else{var imageData=surfData.ctx.getImageData(0,0,surfData.width,surfData.height);if(raw.bpp==4){imageData.data.set(HEAPU8.subarray(raw.data>>>0,raw.data+raw.size>>>0))}else if(raw.bpp==3){var pixels=raw.size/3;var data=imageData.data;var sourcePtr=raw.data;var destPtr=0;for(var i=0;i>>0];data[destPtr++]=HEAPU8[sourcePtr++>>>0];data[destPtr++]=HEAPU8[sourcePtr++>>>0];data[destPtr++]=255}}else if(raw.bpp==2){var pixels=raw.size;var data=imageData.data;var sourcePtr=raw.data;var destPtr=0;for(var i=0;i>>0];var alpha=HEAPU8[sourcePtr++>>>0];data[destPtr++]=gray;data[destPtr++]=gray;data[destPtr++]=gray;data[destPtr++]=alpha}}else if(raw.bpp==1){var pixels=raw.size;var data=imageData.data;var sourcePtr=raw.data;var destPtr=0;for(var i=0;i>>0];data[destPtr++]=value;data[destPtr++]=value;data[destPtr++]=value;data[destPtr++]=255}}else{err(`cannot handle bpp ${raw.bpp}`);return 0}surfData.ctx.putImageData(imageData,0,0)}surfData.ctx.globalCompositeOperation="source-over";_SDL_LockSurface(surf);surfData.locked--;if(SDL.GL){surfData.canvas=surfData.ctx=null}return surf}finally{cleanup()}};_IMG_Load_RW.sig="ppi";var _SDL_LoadBMP_RW=_IMG_Load_RW;_SDL_LoadBMP_RW.sig="ppi";function _SDL_RWFromFile(_name,mode){_name>>>=0;mode>>>=0;var id=SDL.rwops.length;var filename=UTF8ToString(_name);SDL.rwops.push({filename,mimetype:Browser.getMimetype(filename)});return id}_SDL_RWFromFile.sig="ppp";function _IMG_Load(filename){filename>>>=0;var rwops=_SDL_RWFromFile(filename,0);var result=_IMG_Load_RW(rwops,1);return result}_IMG_Load.sig="pp";var _IMG_Quit=()=>out("IMG_Quit called (and ignored)");_IMG_Quit.sig="v";function _SDL_OpenAudio(desired,obtained){desired>>>=0;obtained>>>=0;try{SDL.audio={freq:HEAPU32[desired>>>2>>>0],format:HEAPU16[desired+4>>>1>>>0],channels:HEAPU8[desired+6>>>0],samples:HEAPU16[desired+8>>>1>>>0],callback:HEAPU32[desired+16>>>2>>>0],userdata:HEAPU32[desired+20>>>2>>>0],paused:true,timer:null};if(SDL.audio.format==8){SDL.audio.silence=128}else if(SDL.audio.format==32784){SDL.audio.silence=0}else if(SDL.audio.format==33056){SDL.audio.silence=0}else{throw"Invalid SDL audio format "+SDL.audio.format+"!"}if(SDL.audio.freq<=0){throw"Unsupported sound frequency "+SDL.audio.freq+"!"}else if(SDL.audio.freq<=22050){SDL.audio.freq=22050}else if(SDL.audio.freq<=32e3){SDL.audio.freq=32e3}else if(SDL.audio.freq<=44100){SDL.audio.freq=44100}else if(SDL.audio.freq<=48e3){SDL.audio.freq=48e3}else if(SDL.audio.freq<=96e3){SDL.audio.freq=96e3}else{throw`Unsupported sound frequency ${SDL.audio.freq}!`}if(SDL.audio.channels==0){SDL.audio.channels=1}else if(SDL.audio.channels<0||SDL.audio.channels>32){throw`Unsupported number of audio channels for SDL audio: ${SDL.audio.channels}!`}else if(SDL.audio.channels!=1&&SDL.audio.channels!=2){out(`Warning: Using untested number of audio channels ${SDL.audio.channels}`)}if(SDL.audio.samples<128||SDL.audio.samples>524288){throw`Unsupported audio callback buffer size ${SDL.audio.samples}!`}else if((SDL.audio.samples&SDL.audio.samples-1)!=0){throw`Audio callback buffer size ${SDL.audio.samples} must be a power-of-two!`}var totalSamples=SDL.audio.samples*SDL.audio.channels;if(SDL.audio.format==8){SDL.audio.bytesPerSample=1}else if(SDL.audio.format==32784){SDL.audio.bytesPerSample=2}else if(SDL.audio.format==33056){SDL.audio.bytesPerSample=4}else{throw`Invalid SDL audio format ${SDL.audio.format}!`}SDL.audio.bufferSize=totalSamples*SDL.audio.bytesPerSample;SDL.audio.bufferDurationSecs=SDL.audio.bufferSize/SDL.audio.bytesPerSample/SDL.audio.channels/SDL.audio.freq;SDL.audio.bufferingDelay=50/1e3;SDL.audio.buffer=_malloc(SDL.audio.bufferSize);SDL.audio.numSimultaneouslyQueuedBuffers=Module["SDL_numSimultaneouslyQueuedBuffers"]||5;SDL.audio.queueNewAudioData=()=>{if(!SDL.audio)return;for(var i=0;i=SDL.audio.bufferingDelay+SDL.audio.bufferDurationSecs*SDL.audio.numSimultaneouslyQueuedBuffers)return;getWasmTableEntry(SDL.audio.callback)(SDL.audio.userdata,SDL.audio.buffer,SDL.audio.bufferSize);SDL.audio.pushAudio(SDL.audio.buffer,SDL.audio.bufferSize)}};SDL.audio.caller=()=>{if(!SDL.audio)return;--SDL.audio.numAudioTimersPending;SDL.audio.queueNewAudioData();var secsUntilNextPlayStart=SDL.audio.nextPlayTime-SDL.audioContext["currentTime"];var preemptBufferFeedSecs=SDL.audio.bufferDurationSecs/2;if(SDL.audio.numAudioTimersPending{try{if(SDL.audio.paused)return;var sizeSamples=sizeBytes/SDL.audio.bytesPerSample;var sizeSamplesPerChannel=sizeSamples/SDL.audio.channels;if(sizeSamplesPerChannel!=SDL.audio.samples){throw"Received mismatching audio buffer size!"}var source=SDL.audioContext["createBufferSource"]();var soundBuffer=SDL.audioContext["createBuffer"](SDL.audio.channels,sizeSamplesPerChannel,SDL.audio.freq);source["connect"](SDL.audioContext["destination"]);SDL.fillWebAudioBufferFromHeap(ptr,sizeSamplesPerChannel,soundBuffer);source["buffer"]=soundBuffer;var curtime=SDL.audioContext["currentTime"];var playtime=Math.max(curtime+SDL.audio.bufferingDelay,SDL.audio.nextPlayTime);if(typeof source["start"]!="undefined"){source["start"](playtime)}else if(typeof source["noteOn"]!="undefined"){source["noteOn"](playtime)}SDL.audio.nextPlayTime=playtime+SDL.audio.bufferDurationSecs}catch(e){err(`Web Audio API error playing back audio: ${e.toString()}`)}};if(obtained){HEAP32[obtained>>>2>>>0]=SDL.audio.freq;HEAP16[obtained+4>>>1>>>0]=SDL.audio.format;HEAP8[obtained+6>>>0]=SDL.audio.channels;HEAP8[obtained+7>>>0]=SDL.audio.silence;HEAP16[obtained+8>>>1>>>0]=SDL.audio.samples;HEAPU32[obtained+16>>>2>>>0]=SDL.audio.callback;HEAPU32[obtained+20>>>2>>>0]=SDL.audio.userdata}SDL.allocateChannels(32)}catch(e){err(`Initializing SDL audio threw an exception: "${e.toString()}"! Continuing without audio`);SDL.audio=null;SDL.allocateChannels(0);if(obtained){HEAP32[obtained>>>2>>>0]=0;HEAP16[obtained+4>>>1>>>0]=0;HEAP8[obtained+6>>>0]=0;HEAP8[obtained+7>>>0]=0;HEAP16[obtained+8>>>1>>>0]=0;HEAPU32[obtained+16>>>2>>>0]=0;HEAPU32[obtained+20>>>2>>>0]=0}}if(!SDL.audio){return-1}return 0}_SDL_OpenAudio.sig="ipp";var _SDL_PauseAudio=pauseOn=>{if(!SDL.audio){return}if(pauseOn){if(SDL.audio.timer!==undefined){clearTimeout(SDL.audio.timer);SDL.audio.numAudioTimersPending=0;SDL.audio.timer=undefined}}else if(!SDL.audio.timer){SDL.audio.numAudioTimersPending=1;SDL.audio.timer=safeSetTimeout(SDL.audio.caller,1)}SDL.audio.paused=pauseOn};_SDL_PauseAudio.sig="vi";var _SDL_CloseAudio=()=>{if(SDL.audio){if(SDL.audio.callbackRemover){SDL.audio.callbackRemover();SDL.audio.callbackRemover=null}_SDL_PauseAudio(1);_free(SDL.audio.buffer);SDL.audio=null;SDL.allocateChannels(0)}};_SDL_CloseAudio.sig="v";var _SDL_LockAudio=()=>{};_SDL_LockAudio.sig="v";var _SDL_UnlockAudio=()=>{};_SDL_UnlockAudio.sig="v";function _SDL_CreateMutex(){return 0}_SDL_CreateMutex.sig="p";function _SDL_mutexP(mutex){mutex>>>=0;return 0}_SDL_mutexP.sig="ip";function _SDL_mutexV(mutex){mutex>>>=0;return 0}_SDL_mutexV.sig="ip";function _SDL_DestroyMutex(mutex){mutex>>>=0}_SDL_DestroyMutex.sig="vp";function _SDL_CreateCond(){return 0}_SDL_CreateCond.sig="p";function _SDL_CondSignal(cond){cond>>>=0}_SDL_CondSignal.sig="ip";function _SDL_CondWait(cond,mutex){cond>>>=0;mutex>>>=0}_SDL_CondWait.sig="ipp";function _SDL_DestroyCond(cond){cond>>>=0}_SDL_DestroyCond.sig="vp";var _SDL_StartTextInput=()=>{SDL.textInput=true};_SDL_StartTextInput.sig="v";var _SDL_StopTextInput=()=>{SDL.textInput=false};_SDL_StopTextInput.sig="v";var _Mix_Init=flags=>{if(!flags)return 0;return 8};_Mix_Init.sig="ii";var _Mix_Quit=()=>{};_Mix_Quit.sig="v";var _Mix_OpenAudio=(frequency,format,channels,chunksize)=>{SDL.openAudioContext();autoResumeAudioContext(SDL.audioContext);SDL.allocateChannels(32);SDL.mixerFrequency=frequency;SDL.mixerFormat=format;SDL.mixerNumChannels=channels;SDL.mixerChunkSize=chunksize;return 0};_Mix_OpenAudio.sig="iiiii";var _Mix_CloseAudio=_SDL_CloseAudio;_Mix_CloseAudio.sig="v";var _Mix_AllocateChannels=num=>{SDL.allocateChannels(num);return num};_Mix_AllocateChannels.sig="ii";function _Mix_ChannelFinished(func){func>>>=0;SDL.channelFinished=func}_Mix_ChannelFinished.sig="vp";var _Mix_Volume=(channel,volume)=>{if(channel==-1){for(var i=0;i{left/=255;right/=255;SDL.setPannerPosition(SDL.channels[channel],right-left,0,.1);return 1};_Mix_SetPanning.sig="iiii";function _Mix_LoadWAV_RW(rwopsID,freesrc){rwopsID>>>=0;var rwops=SDL.rwops[rwopsID];if(rwops===undefined)return 0;var filename="";var audio;var webAudio;var bytes;if(rwops.filename!==undefined){filename=PATH_FS.resolve(rwops.filename);var raw=Browser.preloadedAudios[filename];if(!raw){if(raw===null)err("Trying to reuse preloaded audio, but freePreloadedMediaOnUse is set!");if(!Module["noAudioDecoding"])warnOnce("Cannot find preloaded audio "+filename);try{bytes=FS.readFile(filename)}catch(e){err(`Couldn't find file for: ${filename}`);return 0}}if(Module["freePreloadedMediaOnUse"]){Browser.preloadedAudios[filename]=null}audio=raw}else if(rwops.bytes!==undefined){if(SDL.webAudioAvailable()){bytes=HEAPU8.buffer.slice(rwops.bytes,rwops.bytes+rwops.count)}else{bytes=HEAPU8.subarray(rwops.bytes>>>0,rwops.bytes+rwops.count>>>0)}}else{return 0}var arrayBuffer=bytes?bytes.buffer||bytes:bytes;var canPlayWithWebAudio=Module["SDL_canPlayWithWebAudio"]===undefined||Module["SDL_canPlayWithWebAudio"](filename,arrayBuffer);if(bytes!==undefined&&SDL.webAudioAvailable()&&canPlayWithWebAudio){audio=undefined;webAudio={onDecodeComplete:[]};SDL.audioContext["decodeAudioData"](arrayBuffer,data=>{webAudio.decodedBuffer=data;webAudio.onDecodeComplete.forEach(e=>e());delete webAudio.onDecodeComplete})}else if(audio===undefined&&bytes){var blob=new Blob([bytes],{type:rwops.mimetype});var url=URL.createObjectURL(blob);audio=new Audio;audio.src=url;audio.mozAudioChannelType="content"}var id=SDL.audios.length;SDL.audios.push({source:filename,audio,webAudio});return id}_Mix_LoadWAV_RW.sig="ppi";function _Mix_LoadWAV(filename){filename>>>=0;var rwops=_SDL_RWFromFile(filename,0);var result=_Mix_LoadWAV_RW(rwops,0);_SDL_FreeRW(rwops);return result}_Mix_LoadWAV.sig="pp";function _Mix_QuickLoad_RAW(mem,len){mem>>>=0;var audio;var webAudio;var numSamples=len>>1;var buffer=new Float32Array(numSamples);for(var i=0;i>>1>>>0]/32768}if(SDL.webAudioAvailable()){webAudio={decodedBuffer:buffer}}else{audio=new Audio;audio.mozAudioChannelType="content";audio.numChannels=SDL.mixerNumChannels;audio.frequency=SDL.mixerFrequency}var id=SDL.audios.length;SDL.audios.push({source:"",audio,webAudio,buffer});return id}_Mix_QuickLoad_RAW.sig="ppi";function _Mix_FreeChunk(id){id>>>=0;SDL.audios[id]=null}_Mix_FreeChunk.sig="vp";var _Mix_ReserveChannels=num=>{SDL.channelMinimumNumber=num};_Mix_ReserveChannels.sig="ii";var _Mix_HaltChannel=channel=>{function halt(channel){var info=SDL.channels[channel];if(info.audio){info.audio.pause();info.audio=null}if(SDL.channelFinished){getWasmTableEntry(SDL.channelFinished)(channel)}}if(channel!=-1){halt(channel)}else{for(var i=0;i>>=0;assert(ticks==-1);var info=SDL.audios[id];if(!info)return-1;if(!info.audio&&!info.webAudio)return-1;if(channel==-1){for(var i=SDL.channelMinimumNumber;i0;_Mix_FadingChannel.sig="ii";var _Mix_HaltMusic=()=>{var audio=SDL.music.audio;if(audio){audio.src=audio.src;audio.currentPosition=0;audio.pause()}SDL.music.audio=null;if(SDL.hookMusicFinished){getWasmTableEntry(SDL.hookMusicFinished)()}return 0};_Mix_HaltMusic.sig="i";function _Mix_HookMusicFinished(func){func>>>=0;SDL.hookMusicFinished=func;if(SDL.music.audio){SDL.music.audio["onended"]=_Mix_HaltMusic}}_Mix_HookMusicFinished.sig="vp";var _Mix_VolumeMusic=volume=>SDL.setGetVolume(SDL.music,volume);_Mix_VolumeMusic.sig="ii";function _Mix_LoadMUS_RW(filename){filename>>>=0;return _Mix_LoadWAV_RW(filename,0)}_Mix_LoadMUS_RW.sig="pp";function _Mix_LoadMUS(filename){filename>>>=0;var rwops=_SDL_RWFromFile(filename,0);var result=_Mix_LoadMUS_RW(rwops);_SDL_FreeRW(rwops);return result}_Mix_LoadMUS.sig="pp";var _Mix_FreeMusic=_Mix_FreeChunk;_Mix_FreeMusic.sig="vp";function _Mix_PlayMusic(id,loops){id>>>=0;if(SDL.music.audio){if(!SDL.music.audio.paused)err(`Music is already playing. ${SDL.music.source}`);SDL.music.audio.pause()}var info=SDL.audios[id];var audio;if(info.webAudio){audio={resource:info,paused:false,currentPosition:0,play(){SDL.playWebAudio(this)},pause(){SDL.pauseWebAudio(this)}}}else if(info.audio){audio=info.audio}audio["onended"]=function(){if(SDL.music.audio===this||SDL.music.audio?.webAudioNode===this){_Mix_HaltMusic()}};audio.loop=loops!=0&&loops!=1;audio.volume=SDL.music.volume;SDL.music.audio=audio;audio.play();return 0}_Mix_PlayMusic.sig="ipi";var _Mix_PauseMusic=()=>{var audio=SDL.music.audio;audio?.pause()};_Mix_PauseMusic.sig="v";var _Mix_ResumeMusic=()=>{var audio=SDL.music.audio;audio?.play()};_Mix_ResumeMusic.sig="v";var _Mix_FadeInMusicPos=_Mix_PlayMusic;_Mix_FadeInMusicPos.sig="ipiid";var _Mix_FadeOutMusic=_Mix_HaltMusic;_Mix_FadeOutMusic.sig="ii";var _Mix_PlayingMusic=()=>SDL.music.audio&&!SDL.music.audio.paused;_Mix_PlayingMusic.sig="i";var _Mix_Playing=channel=>{if(channel===-1){var count=0;for(var i=0;i{if(channel===-1){for(var i=0;i{if(channel===-1){var pausedCount=0;for(var i=0;iSDL.music.audio?.paused?1:0;_Mix_PausedMusic.sig="i";var _Mix_Resume=channel=>{if(channel===-1){for(var i=0;i{try{var offscreenCanvas=new OffscreenCanvas(0,0);SDL.ttfContext=offscreenCanvas.getContext("2d");if(typeof SDL.ttfContext.measureText!="function"){throw"bad context"}}catch(ex){var canvas=document.createElement("canvas");SDL.ttfContext=canvas.getContext("2d")}return 0};_TTF_Init.sig="i";function _TTF_OpenFont(name,size){name>>>=0;name=PATH.normalize(UTF8ToString(name));var id=SDL.fonts.length;SDL.fonts.push({name,size});return id}_TTF_OpenFont.sig="ppi";function _TTF_CloseFont(font){font>>>=0;SDL.fonts[font]=null}_TTF_CloseFont.sig="vp";function _TTF_RenderText_Solid(font,text,color){font>>>=0;text>>>=0;color>>>=0;text=UTF8ToString(text)||" ";var fontData=SDL.fonts[font];var w=SDL.estimateTextWidth(fontData,text);var h=fontData.size;color=SDL.loadColorToCSSRGB(color);var fontString=SDL.makeFontString(h,fontData.name);var surf=SDL.makeSurface(w,h,0,false,"text:"+text);var surfData=SDL.surfaces[surf];surfData.ctx.save();surfData.ctx.fillStyle=color;surfData.ctx.font=fontString;surfData.ctx.textBaseline="bottom";surfData.ctx.fillText(text,0,h|0);surfData.ctx.restore();return surf}_TTF_RenderText_Solid.sig="pppp";var _TTF_RenderText_Blended=_TTF_RenderText_Solid;_TTF_RenderText_Blended.sig="pppp";var _TTF_RenderText_Shaded=_TTF_RenderText_Solid;_TTF_RenderText_Shaded.sig="ppppp";var _TTF_RenderUTF8_Solid=_TTF_RenderText_Solid;_TTF_RenderUTF8_Solid.sig="pppp";function _TTF_SizeText(font,text,w,h){font>>>=0;text>>>=0;w>>>=0;h>>>=0;var fontData=SDL.fonts[font];if(w){HEAP32[w>>>2>>>0]=SDL.estimateTextWidth(fontData,UTF8ToString(text))}if(h){HEAP32[h>>>2>>>0]=fontData.size}return 0}_TTF_SizeText.sig="ipppp";var _TTF_SizeUTF8=_TTF_SizeText;_TTF_SizeUTF8.sig="ipppp";function _TTF_GlyphMetrics(font,ch,minx,maxx,miny,maxy,advance){font>>>=0;minx>>>=0;maxx>>>=0;miny>>>=0;maxy>>>=0;advance>>>=0;var fontData=SDL.fonts[font];var width=SDL.estimateTextWidth(fontData,String.fromCharCode(ch));if(advance){HEAP32[advance>>>2>>>0]=width}if(minx){HEAP32[minx>>>2>>>0]=0}if(maxx){HEAP32[maxx>>>2>>>0]=width}if(miny){HEAP32[miny>>>2>>>0]=0}if(maxy){HEAP32[maxy>>>2>>>0]=fontData.size}}_TTF_GlyphMetrics.sig="ipippppp";function _TTF_FontAscent(font){font>>>=0;var fontData=SDL.fonts[font];return fontData.size*.98|0}_TTF_FontAscent.sig="ip";function _TTF_FontDescent(font){font>>>=0;var fontData=SDL.fonts[font];return fontData.size*.02|0}_TTF_FontDescent.sig="ip";function _TTF_FontHeight(font){font>>>=0;var fontData=SDL.fonts[font];return fontData.size}_TTF_FontHeight.sig="ip";var _TTF_FontLineSkip=_TTF_FontHeight;_TTF_FontLineSkip.sig="ip";var _TTF_Quit=()=>out("TTF_Quit called (and ignored)");_TTF_Quit.sig="v";var SDL_gfx={drawRectangle:(surf,x1,y1,x2,y2,action,cssColor)=>{x1=x1<<16>>16;y1=y1<<16>>16;x2=x2<<16>>16;y2=y2<<16>>16;var surfData=SDL.surfaces[surf];assert(!surfData.locked);var x=x1{x1=x1<<16>>16;y1=y1<<16>>16;x2=x2<<16>>16;y2=y2<<16>>16;var surfData=SDL.surfaces[surf];assert(!surfData.locked);surfData.ctx.save();surfData.ctx.strokeStyle=cssColor;surfData.ctx.beginPath();surfData.ctx.moveTo(x1,y1);surfData.ctx.lineTo(x2,y2);surfData.ctx.stroke();surfData.ctx.restore()},drawEllipse:(surf,x,y,rx,ry,action,cssColor)=>{x=x<<16>>16;y=y<<16>>16;rx=rx<<16>>16;ry=ry<<16>>16;var surfData=SDL.surfaces[surf];assert(!surfData.locked);surfData.ctx.save();surfData.ctx.beginPath();surfData.ctx.translate(x,y);surfData.ctx.scale(rx,ry);surfData.ctx.arc(0,0,1,0,2*Math.PI);surfData.ctx.restore();surfData.ctx.save();surfData.ctx[action+"Style"]=cssColor;surfData.ctx[action]();surfData.ctx.restore()},translateColorToCSSRGBA:rgba=>`rgba(${rgba>>>24},${rgba>>16&255},${rgba>>8&255},${rgba&255})`};function _boxColor(surf,x1,y1,x2,y2,color){surf>>>=0;return SDL_gfx.drawRectangle(surf,x1,y1,x2,y2,"fill",SDL_gfx.translateColorToCSSRGBA(color))}_boxColor.sig="ipiiiii";function _boxRGBA(surf,x1,y1,x2,y2,r,g,b,a){surf>>>=0;return SDL_gfx.drawRectangle(surf,x1,y1,x2,y2,"fill",SDL.translateRGBAToCSSRGBA(r,g,b,a))}_boxRGBA.sig="ipiiiiiiii";function _rectangleColor(surf,x1,y1,x2,y2,color){surf>>>=0;return SDL_gfx.drawRectangle(surf,x1,y1,x2,y2,"stroke",SDL_gfx.translateColorToCSSRGBA(color))}_rectangleColor.sig="ipiiiii";function _rectangleRGBA(surf,x1,y1,x2,y2,r,g,b,a){surf>>>=0;return SDL_gfx.drawRectangle(surf,x1,y1,x2,y2,"stroke",SDL.translateRGBAToCSSRGBA(r,g,b,a))}_rectangleRGBA.sig="ipiiiiiiii";function _ellipseColor(surf,x,y,rx,ry,color){surf>>>=0;return SDL_gfx.drawEllipse(surf,x,y,rx,ry,"stroke",SDL_gfx.translateColorToCSSRGBA(color))}_ellipseColor.sig="ipiiiii";function _ellipseRGBA(surf,x,y,rx,ry,r,g,b,a){surf>>>=0;return SDL_gfx.drawEllipse(surf,x,y,rx,ry,"stroke",SDL.translateRGBAToCSSRGBA(r,g,b,a))}_ellipseRGBA.sig="ipiiiiiiii";function _filledEllipseColor(surf,x,y,rx,ry,color){surf>>>=0;return SDL_gfx.drawEllipse(surf,x,y,rx,ry,"fill",SDL_gfx.translateColorToCSSRGBA(color))}_filledEllipseColor.sig="ipiiiii";function _filledEllipseRGBA(surf,x,y,rx,ry,r,g,b,a){surf>>>=0;return SDL_gfx.drawEllipse(surf,x,y,rx,ry,"fill",SDL.translateRGBAToCSSRGBA(r,g,b,a))}_filledEllipseRGBA.sig="ipiiiiiiii";function _lineColor(surf,x1,y1,x2,y2,color){surf>>>=0;return SDL_gfx.drawLine(surf,x1,y1,x2,y2,SDL_gfx.translateColorToCSSRGBA(color))}_lineColor.sig="ipiiiii";function _lineRGBA(surf,x1,y1,x2,y2,r,g,b,a){surf>>>=0;return SDL_gfx.drawLine(surf,x1,y1,x2,y2,SDL.translateRGBAToCSSRGBA(r,g,b,a))}_lineRGBA.sig="ipiiiiiiii";function _pixelRGBA(surf,x1,y1,r,g,b,a){surf>>>=0;return _boxRGBA(surf,x1,y1,x1,y1,r,g,b,a)}_pixelRGBA.sig="ipiiiiii";var _SDL_GL_SetAttribute=(attr,value)=>{if(!(attr in SDL.glAttributes)){abort("Unknown SDL GL attribute ("+attr+"). Please check if your SDL version is supported.")}SDL.glAttributes[attr]=value};_SDL_GL_SetAttribute.sig="iii";function _SDL_GL_GetAttribute(attr,value){value>>>=0;if(!(attr in SDL.glAttributes)){abort("Unknown SDL GL attribute ("+attr+"). Please check if your SDL version is supported.")}if(value)HEAP32[value>>>2>>>0]=SDL.glAttributes[attr];return 0}_SDL_GL_GetAttribute.sig="iip";var _SDL_GL_SwapBuffers=()=>Browser.doSwapBuffers?.();_SDL_GL_SwapBuffers.sig="v";function _SDL_GL_ExtensionSupported(extension){extension>>>=0;return GLctx?.getExtension(UTF8ToString(extension))?1:0}_SDL_GL_ExtensionSupported.sig="ip";function _SDL_DestroyWindow(window){window>>>=0}_SDL_DestroyWindow.sig="vp";function _SDL_DestroyRenderer(renderer){renderer>>>=0}_SDL_DestroyRenderer.sig="vp";function _SDL_GetWindowFlags(window){window>>>=0;if(Browser.isFullscreen){return 1}return 0}_SDL_GetWindowFlags.sig="ip";function _SDL_GL_SwapWindow(window){window>>>=0}_SDL_GL_SwapWindow.sig="vp";function _SDL_GL_MakeCurrent(window,context){window>>>=0;context>>>=0}_SDL_GL_MakeCurrent.sig="ipp";function _SDL_GL_DeleteContext(context){context>>>=0}_SDL_GL_DeleteContext.sig="vp";var _SDL_GL_GetSwapInterval=()=>{if(MainLoop.timingMode==1){return MainLoop.timingValue}else{return 0}};_SDL_GL_GetSwapInterval.sig="i";var _SDL_GL_SetSwapInterval=state=>_emscripten_set_main_loop_timing(1,state);_SDL_GL_SetSwapInterval.sig="ii";function _SDL_SetWindowTitle(window,title){window>>>=0;title>>>=0;if(title)document.title=UTF8ToString(title)}_SDL_SetWindowTitle.sig="vpp";function _SDL_GetWindowSize(window,width,height){window>>>=0;width>>>=0;height>>>=0;var canvas=Browser.getCanvas();if(width)HEAP32[width>>>2>>>0]=canvas.width;if(height)HEAP32[height>>>2>>>0]=canvas.height}_SDL_GetWindowSize.sig="vppp";function _SDL_LogSetOutputFunction(callback,userdata){callback>>>=0;userdata>>>=0}_SDL_LogSetOutputFunction.sig="vpp";function _SDL_SetWindowFullscreen(window,fullscreen){window>>>=0;if(Browser.isFullscreen){Browser.getCanvas().exitFullscreen();return 1}return 0}_SDL_SetWindowFullscreen.sig="ipi";var _SDL_ClearError=()=>{};_SDL_ClearError.sig="v";var _SDL_SetGamma=(r,g,b)=>-1;_SDL_SetGamma.sig="ifff";function _SDL_SetGammaRamp(redTable,greenTable,blueTable){redTable>>>=0;greenTable>>>=0;blueTable>>>=0;return-1}_SDL_SetGammaRamp.sig="ippp";var _SDL_NumJoysticks=()=>{var count=0;var gamepads=SDL.getGamepads();for(var gamepad of gamepads){if(gamepad!==undefined)count++}return count};_SDL_NumJoysticks.sig="i";function _SDL_JoystickName(deviceIndex){var gamepad=SDL.getGamepad(deviceIndex);if(gamepad){var name=gamepad.id;if(SDL.joystickNamePool.hasOwnProperty(name)){return SDL.joystickNamePool[name]}return SDL.joystickNamePool[name]=stringToNewUTF8(name)}return 0}_SDL_JoystickName.sig="pi";function _SDL_JoystickOpen(deviceIndex){var gamepad=SDL.getGamepad(deviceIndex);if(gamepad){var joystick=deviceIndex+1;SDL.recordJoystickState(joystick,gamepad);return joystick}return 0}_SDL_JoystickOpen.sig="pi";var _SDL_JoystickOpened=deviceIndex=>SDL.lastJoystickState.hasOwnProperty(deviceIndex+1)?1:0;_SDL_JoystickOpened.sig="ii";function _SDL_JoystickIndex(joystick){joystick>>>=0;return joystick-1}_SDL_JoystickIndex.sig="ip";function _SDL_JoystickNumAxes(joystick){joystick>>>=0;var gamepad=SDL.getGamepad(joystick-1);if(gamepad){return gamepad.axes.length}return 0}_SDL_JoystickNumAxes.sig="ip";function _SDL_JoystickNumBalls(joystick){joystick>>>=0;return 0}_SDL_JoystickNumBalls.sig="ip";function _SDL_JoystickNumHats(joystick){joystick>>>=0;return 0}_SDL_JoystickNumHats.sig="ip";function _SDL_JoystickNumButtons(joystick){joystick>>>=0;var gamepad=SDL.getGamepad(joystick-1);if(gamepad){return gamepad.buttons.length}return 0}_SDL_JoystickNumButtons.sig="ip";var _SDL_JoystickUpdate=()=>SDL.queryJoysticks();_SDL_JoystickUpdate.sig="v";var _SDL_JoystickEventState=state=>{if(state<0){return SDL.joystickEventState}return SDL.joystickEventState=state};_SDL_JoystickEventState.sig="ii";function _SDL_JoystickGetAxis(joystick,axis){joystick>>>=0;var gamepad=SDL.getGamepad(joystick-1);if(gamepad?.axes.length>axis){return SDL.joystickAxisValueConversion(gamepad.axes[axis])}return 0}_SDL_JoystickGetAxis.sig="ipi";function _SDL_JoystickGetHat(joystick,hat){joystick>>>=0;return 0}_SDL_JoystickGetHat.sig="ipi";function _SDL_JoystickGetBall(joystick,ball,dxptr,dyptr){joystick>>>=0;dxptr>>>=0;dyptr>>>=0;return-1}_SDL_JoystickGetBall.sig="ipipp";function _SDL_JoystickGetButton(joystick,button){joystick>>>=0;var gamepad=SDL.getGamepad(joystick-1);if(gamepad?.buttons.length>button){return SDL.getJoystickButtonState(gamepad.buttons[button])?1:0}return 0}_SDL_JoystickGetButton.sig="ipi";function _SDL_JoystickClose(joystick){joystick>>>=0;delete SDL.lastJoystickState[joystick]}_SDL_JoystickClose.sig="vp";var _SDL_InitSubSystem=flags=>0;_SDL_InitSubSystem.sig="ii";function _SDL_RWFromConstMem(mem,size){mem>>>=0;var id=SDL.rwops.length;SDL.rwops.push({bytes:mem,count:size});return id}_SDL_RWFromConstMem.sig="ppi";var _SDL_RWFromMem=_SDL_RWFromConstMem;_SDL_RWFromMem.sig="ppi";var _SDL_GetNumAudioDrivers=()=>1;_SDL_GetNumAudioDrivers.sig="i";function _SDL_GetCurrentAudioDriver(){return stringToNewUTF8("Emscripten Audio")}_SDL_GetCurrentAudioDriver.sig="p";var _SDL_GetScancodeFromKey=key=>SDL.scanCodes[key];_SDL_GetScancodeFromKey.sig="ii";function _SDL_GetAudioDriver(index){return _SDL_GetCurrentAudioDriver()}_SDL_GetAudioDriver.sig="pi";var _SDL_EnableUNICODE=on=>{var ret=SDL.unicode||0;SDL.unicode=on;return ret};_SDL_EnableUNICODE.sig="ii";var _SDL_AddTimer=function(interval,callback,param){callback>>>=0;param>>>=0;return safeSetTimeout(()=>getWasmTableEntry(callback)(interval,param),interval)};_SDL_AddTimer.sig="iipp";var _SDL_RemoveTimer=id=>{clearTimeout(id);return true};_SDL_RemoveTimer.sig="ii";function _SDL_CreateThread(fs,data,pfnBeginThread,pfnEndThread){fs>>>=0;data>>>=0;throw"SDL threads cannot be supported in the web platform because they assume shared state. See emscripten_create_worker etc. for a message-passing concurrency model that does let you run code in another thread."}_SDL_CreateThread.sig="ppp";function _SDL_WaitThread(thread,status){thread>>>=0;status>>>=0;throw"SDL_WaitThread"}_SDL_WaitThread.sig="vpp";function _SDL_GetThreadID(thread){thread>>>=0;throw"SDL_GetThreadID"}_SDL_GetThreadID.sig="pp";function _SDL_ThreadID(){return 0}_SDL_ThreadID.sig="p";function _SDL_AllocRW(){throw"SDL_AllocRW: TODO"}_SDL_AllocRW.sig="p";function _SDL_CondBroadcast(cond){cond>>>=0;throw"SDL_CondBroadcast: TODO"}_SDL_CondBroadcast.sig="ip";function _SDL_CondWaitTimeout(cond,mutex,ms){cond>>>=0;mutex>>>=0;throw"SDL_CondWaitTimeout: TODO"}_SDL_CondWaitTimeout.sig="ippi";var _SDL_WM_IconifyWindow=()=>{throw"SDL_WM_IconifyWindow TODO"};_SDL_WM_IconifyWindow.sig="i";function _Mix_SetPostMix(func,arg){func>>>=0;arg>>>=0;return warnOnce("Mix_SetPostMix: TODO")}_Mix_SetPostMix.sig="vpp";function _Mix_VolumeChunk(chunk,volume){chunk>>>=0;throw"Mix_VolumeChunk: TODO"}_Mix_VolumeChunk.sig="ipi";var _Mix_SetPosition=(channel,angle,distance)=>{throw"Mix_SetPosition: TODO"};_Mix_SetPosition.sig="iiii";function _Mix_QuerySpec(frequency,format,channels){frequency>>>=0;format>>>=0;channels>>>=0;throw"Mix_QuerySpec: TODO"}_Mix_QuerySpec.sig="ippp";function _Mix_FadeInChannelTimed(channel,chunk,loop,ms,ticks){chunk>>>=0;throw"Mix_FadeInChannelTimed"}_Mix_FadeInChannelTimed.sig="iipiii";var _Mix_FadeOutChannel=()=>{throw"Mix_FadeOutChannel"};_Mix_FadeOutChannel.sig="iii";function _Mix_Linked_Version(){throw"Mix_Linked_Version: TODO"}_Mix_Linked_Version.sig="p";function _SDL_SaveBMP_RW(surface,dst,freedst){surface>>>=0;dst>>>=0;throw"SDL_SaveBMP_RW: TODO"}_SDL_SaveBMP_RW.sig="ippi";function _SDL_WM_SetIcon(icon,mask){icon>>>=0;mask>>>=0}_SDL_WM_SetIcon.sig="vpp";var _SDL_HasRDTSC=()=>0;_SDL_HasRDTSC.sig="i";var _SDL_HasMMX=()=>0;_SDL_HasMMX.sig="i";var _SDL_HasMMXExt=()=>0;_SDL_HasMMXExt.sig="i";var _SDL_Has3DNow=()=>0;_SDL_Has3DNow.sig="i";var _SDL_Has3DNowExt=()=>0;_SDL_Has3DNowExt.sig="i";var _SDL_HasSSE=()=>0;_SDL_HasSSE.sig="i";var _SDL_HasSSE2=()=>0;_SDL_HasSSE2.sig="i";var _SDL_HasAltiVec=()=>0;_SDL_HasAltiVec.sig="i";registerWasmPlugin();FS.createPreloadedFile=FS_createPreloadedFile;FS.staticInit();for(var base64ReverseLookup=new Uint8Array(123),i=25;i>=0;--i){base64ReverseLookup[48+i]=52+i;base64ReverseLookup[65+i]=i;base64ReverseLookup[97+i]=26+i}base64ReverseLookup[43]=62;base64ReverseLookup[47]=63;MEMFS.doesNotExistError=new FS.ErrnoError(44);MEMFS.doesNotExistError.stack="";if(ENVIRONMENT_IS_NODE){NODEFS.staticInit()}for(let i=0;i<32;++i)tempFixedLengthArray.push(new Array(i));var miniTempWebGLFloatBuffersStorage=new Float32Array(288);for(var i=0;i<=288;++i){miniTempWebGLFloatBuffers[i]=miniTempWebGLFloatBuffersStorage.subarray(0,i)}var miniTempWebGLIntBuffersStorage=new Int32Array(288);for(var i=0;i<=288;++i){miniTempWebGLIntBuffers[i]=miniTempWebGLIntBuffersStorage.subarray(0,i)}Module["requestAnimationFrame"]=MainLoop.requestAnimationFrame;Module["pauseMainLoop"]=MainLoop.pause;Module["resumeMainLoop"]=MainLoop.resume;MainLoop.init();if(typeof setImmediate!="undefined"){emSetImmediate=setImmediateWrapped;emClearImmediate=clearImmediateWrapped}else if(typeof addEventListener=="function"){var __setImmediate_id_counter=0;var __setImmediate_queue=[];var __setImmediate_message_id="_si";var __setImmediate_cb=e=>{if(e.data===__setImmediate_message_id){e.stopPropagation();__setImmediate_queue.shift()();++__setImmediate_id_counter}};addEventListener("message",__setImmediate_cb,true);emSetImmediate=func=>{postMessage(__setImmediate_message_id,"*");return __setImmediate_id_counter+__setImmediate_queue.push(func)-1};emClearImmediate=id=>{var index=id-__setImmediate_id_counter;if(index>=0&&index<__setImmediate_queue.length)__setImmediate_queue[index]=()=>{}}}registerPostMainLoop(()=>SDL.audio?.queueNewAudioData?.());{initMemory();if(Module["preloadPlugins"])preloadPlugins=Module["preloadPlugins"];if(Module["noExitRuntime"])noExitRuntime=Module["noExitRuntime"];if(Module["print"])out=Module["print"];if(Module["printErr"])err=Module["printErr"];if(Module["dynamicLibraries"])dynamicLibraries=Module["dynamicLibraries"];if(Module["wasmBinary"])wasmBinary=Module["wasmBinary"];if(Module["arguments"])arguments_=Module["arguments"];if(Module["thisProgram"])thisProgram=Module["thisProgram"]}Module["addRunDependency"]=addRunDependency;Module["removeRunDependency"]=removeRunDependency;Module["ERRNO_CODES"]=ERRNO_CODES;Module["wasmTable"]=wasmTable;Module["FS_createPreloadedFile"]=FS_createPreloadedFile;Module["FS_unlink"]=FS_unlink;Module["FS_createPath"]=FS_createPath;Module["FS_createDevice"]=FS_createDevice;Module["FS_createDataFile"]=FS_createDataFile;Module["FS_createLazyFile"]=FS_createLazyFile;Module["LZ4"]=LZ4;Module["ExitStatus"]=ExitStatus;Module["GOTHandler"]=GOTHandler;Module["GOT"]=GOT;Module["currentModuleWeakSymbols"]=currentModuleWeakSymbols;Module["addOnPostRun"]=addOnPostRun;Module["onPostRuns"]=onPostRuns;Module["callRuntimeCallbacks"]=callRuntimeCallbacks;Module["addOnPreRun"]=addOnPreRun;Module["onPreRuns"]=onPreRuns;Module["getDylinkMetadata"]=getDylinkMetadata;Module["UTF8ArrayToString"]=UTF8ArrayToString;Module["UTF8Decoder"]=UTF8Decoder;Module["getValue"]=getValue;Module["loadDylibs"]=loadDylibs;Module["loadDynamicLibrary"]=loadDynamicLibrary;Module["LDSO"]=LDSO;Module["newDSO"]=newDSO;Module["loadWebAssemblyModule"]=loadWebAssemblyModule;Module["getMemory"]=getMemory;Module["___heap_base"]=___heap_base;Module["alignMemory"]=alignMemory;Module["relocateExports"]=relocateExports;Module["updateGOT"]=updateGOT;Module["isInternalSym"]=isInternalSym;Module["addFunction"]=addFunction;Module["convertJsFunctionToWasm"]=convertJsFunctionToWasm;Module["uleb128Encode"]=uleb128Encode;Module["sigToWasmTypes"]=sigToWasmTypes;Module["generateFuncType"]=generateFuncType;Module["getFunctionAddress"]=getFunctionAddress;Module["updateTableMap"]=updateTableMap;Module["getWasmTableEntry"]=getWasmTableEntry;Module["wasmTableMirror"]=wasmTableMirror;Module["wasmTable"]=wasmTable;Module["functionsInTableMap"]=functionsInTableMap;Module["getEmptyTableSlot"]=getEmptyTableSlot;Module["freeTableIndexes"]=freeTableIndexes;Module["setWasmTableEntry"]=setWasmTableEntry;Module["resolveGlobalSymbol"]=resolveGlobalSymbol;Module["isSymbolDefined"]=isSymbolDefined;Module["addOnPostCtor"]=addOnPostCtor;Module["onPostCtors"]=onPostCtors;Module["UTF8ToString"]=UTF8ToString;Module["mergeLibSymbols"]=mergeLibSymbols;Module["asyncLoad"]=asyncLoad;Module["preloadedWasm"]=preloadedWasm;Module["registerWasmPlugin"]=registerWasmPlugin;Module["preloadPlugins"]=preloadPlugins;Module["findLibraryFS"]=findLibraryFS;Module["replaceORIGIN"]=replaceORIGIN;Module["PATH"]=PATH;Module["withStackSave"]=withStackSave;Module["stackSave"]=stackSave;Module["stackRestore"]=stackRestore;Module["stackAlloc"]=stackAlloc;Module["lengthBytesUTF8"]=lengthBytesUTF8;Module["stringToUTF8OnStack"]=stringToUTF8OnStack;Module["stringToUTF8"]=stringToUTF8;Module["stringToUTF8Array"]=stringToUTF8Array;Module["FS"]=FS;Module["randomFill"]=randomFill;Module["initRandomFill"]=initRandomFill;Module["base64Decode"]=base64Decode;Module["PATH_FS"]=PATH_FS;Module["TTY"]=TTY;Module["FS_stdin_getChar"]=FS_stdin_getChar;Module["FS_stdin_getChar_buffer"]=FS_stdin_getChar_buffer;Module["intArrayFromString"]=intArrayFromString;Module["MEMFS"]=MEMFS;Module["mmapAlloc"]=mmapAlloc;Module["zeroMemory"]=zeroMemory;Module["FS_createPreloadedFile"]=FS_createPreloadedFile;Module["FS_createDataFile"]=FS_createDataFile;Module["FS_handledByPreloadPlugin"]=FS_handledByPreloadPlugin;Module["FS_modeStringToFlags"]=FS_modeStringToFlags;Module["FS_getMode"]=FS_getMode;Module["IDBFS"]=IDBFS;Module["NODEFS"]=NODEFS;Module["ERRNO_CODES"]=ERRNO_CODES;Module["WORKERFS"]=WORKERFS;Module["PROXYFS"]=PROXYFS;Module["LZ4"]=LZ4;Module["reportUndefinedSymbols"]=reportUndefinedSymbols;Module["noExitRuntime"]=noExitRuntime;Module["setValue"]=setValue;Module["___assert_fail"]=___assert_fail;Module["bigintToI53Checked"]=bigintToI53Checked;Module["INT53_MAX"]=INT53_MAX;Module["INT53_MIN"]=INT53_MIN;Module["___c_longjmp"]=___c_longjmp;Module["___call_sighandler"]=___call_sighandler;Module["___cpp_exception"]=___cpp_exception;Module["___memory_base"]=___memory_base;Module["___stack_high"]=___stack_high;Module["___stack_low"]=___stack_low;Module["___stack_pointer"]=___stack_pointer;Module["___syscall__newselect"]=___syscall__newselect;Module["SYSCALLS"]=SYSCALLS;Module["___syscall_accept4"]=___syscall_accept4;Module["getSocketFromFD"]=getSocketFromFD;Module["SOCKFS"]=SOCKFS;Module["writeSockaddr"]=writeSockaddr;Module["inetPton4"]=inetPton4;Module["inetPton6"]=inetPton6;Module["DNS"]=DNS;Module["___syscall_bind"]=___syscall_bind;Module["getSocketAddress"]=getSocketAddress;Module["readSockaddr"]=readSockaddr;Module["inetNtop4"]=inetNtop4;Module["inetNtop6"]=inetNtop6;Module["___syscall_chdir"]=___syscall_chdir;Module["___syscall_chmod"]=___syscall_chmod;Module["___syscall_connect"]=___syscall_connect;Module["___syscall_dup"]=___syscall_dup;Module["___syscall_dup3"]=___syscall_dup3;Module["___syscall_faccessat"]=___syscall_faccessat;Module["___syscall_fadvise64"]=___syscall_fadvise64;Module["___syscall_fallocate"]=___syscall_fallocate;Module["___syscall_fchdir"]=___syscall_fchdir;Module["___syscall_fchmod"]=___syscall_fchmod;Module["___syscall_fchmodat2"]=___syscall_fchmodat2;Module["___syscall_fchown32"]=___syscall_fchown32;Module["___syscall_fchownat"]=___syscall_fchownat;Module["___syscall_fcntl64"]=___syscall_fcntl64;Module["syscallGetVarargP"]=syscallGetVarargP;Module["syscallGetVarargI"]=syscallGetVarargI;Module["___syscall_fdatasync"]=___syscall_fdatasync;Module["___syscall_fstat64"]=___syscall_fstat64;Module["___syscall_fstatfs64"]=___syscall_fstatfs64;Module["___syscall_ftruncate64"]=___syscall_ftruncate64;Module["___syscall_getcwd"]=___syscall_getcwd;Module["___syscall_getdents64"]=___syscall_getdents64;Module["___syscall_getpeername"]=___syscall_getpeername;Module["___syscall_getsockname"]=___syscall_getsockname;Module["___syscall_getsockopt"]=___syscall_getsockopt;Module["___syscall_ioctl"]=___syscall_ioctl;Module["___syscall_listen"]=___syscall_listen;Module["___syscall_lstat64"]=___syscall_lstat64;Module["___syscall_mkdirat"]=___syscall_mkdirat;Module["___syscall_mknodat"]=___syscall_mknodat;Module["___syscall_newfstatat"]=___syscall_newfstatat;Module["___syscall_openat"]=___syscall_openat;Module["___syscall_pipe"]=___syscall_pipe;Module["PIPEFS"]=PIPEFS;Module["___syscall_poll"]=___syscall_poll;Module["___syscall_readlinkat"]=___syscall_readlinkat;Module["___syscall_recvfrom"]=___syscall_recvfrom;Module["___syscall_recvmsg"]=___syscall_recvmsg;Module["___syscall_renameat"]=___syscall_renameat;Module["___syscall_rmdir"]=___syscall_rmdir;Module["___syscall_sendmsg"]=___syscall_sendmsg;Module["___syscall_sendto"]=___syscall_sendto;Module["___syscall_socket"]=___syscall_socket;Module["___syscall_stat64"]=___syscall_stat64;Module["___syscall_statfs64"]=___syscall_statfs64;Module["___syscall_symlinkat"]=___syscall_symlinkat;Module["___syscall_truncate64"]=___syscall_truncate64;Module["___syscall_unlinkat"]=___syscall_unlinkat;Module["___syscall_utimensat"]=___syscall_utimensat;Module["readI53FromI64"]=readI53FromI64;Module["___table_base"]=___table_base;Module["__abort_js"]=__abort_js;Module["__dlopen_js"]=__dlopen_js;Module["dlopenInternal"]=dlopenInternal;Module["dlSetError"]=dlSetError;Module["__dlsym_js"]=__dlsym_js;Module["__emscripten_dlopen_js"]=__emscripten_dlopen_js;Module["callUserCallback"]=callUserCallback;Module["handleException"]=handleException;Module["maybeExit"]=maybeExit;Module["_exit"]=_exit;Module["exitJS"]=exitJS;Module["_proc_exit"]=_proc_exit;Module["keepRuntimeAlive"]=keepRuntimeAlive;Module["runtimeKeepaliveCounter"]=runtimeKeepaliveCounter;Module["runtimeKeepalivePush"]=runtimeKeepalivePush;Module["runtimeKeepalivePop"]=runtimeKeepalivePop;Module["__emscripten_get_progname"]=__emscripten_get_progname;Module["getExecutableName"]=getExecutableName;Module["__emscripten_lookup_name"]=__emscripten_lookup_name;Module["__emscripten_runtime_keepalive_clear"]=__emscripten_runtime_keepalive_clear;Module["__emscripten_system"]=__emscripten_system;Module["__gmtime_js"]=__gmtime_js;Module["__localtime_js"]=__localtime_js;Module["ydayFromDate"]=ydayFromDate;Module["isLeapYear"]=isLeapYear;Module["MONTH_DAYS_LEAP_CUMULATIVE"]=MONTH_DAYS_LEAP_CUMULATIVE;Module["MONTH_DAYS_REGULAR_CUMULATIVE"]=MONTH_DAYS_REGULAR_CUMULATIVE;Module["__mktime_js"]=__mktime_js;Module["__mmap_js"]=__mmap_js;Module["__msync_js"]=__msync_js;Module["__munmap_js"]=__munmap_js;Module["__setitimer_js"]=__setitimer_js;Module["timers"]=timers;Module["_emscripten_get_now"]=_emscripten_get_now;Module["__timegm_js"]=__timegm_js;Module["__tzset_js"]=__tzset_js;Module["_clock_res_get"]=_clock_res_get;Module["_emscripten_get_now_res"]=_emscripten_get_now_res;Module["nowIsMonotonic"]=nowIsMonotonic;Module["checkWasiClock"]=checkWasiClock;Module["_clock_time_get"]=_clock_time_get;Module["_emscripten_date_now"]=_emscripten_date_now;Module["_create_sentinel"]=_create_sentinel;Module["_emscripten_asm_const_int"]=_emscripten_asm_const_int;Module["runEmAsmFunction"]=runEmAsmFunction;Module["readEmAsmArgs"]=readEmAsmArgs;Module["readEmAsmArgsArray"]=readEmAsmArgsArray;Module["_emscripten_console_error"]=_emscripten_console_error;Module["_emscripten_console_log"]=_emscripten_console_log;Module["_emscripten_console_trace"]=_emscripten_console_trace;Module["_emscripten_console_warn"]=_emscripten_console_warn;Module["_emscripten_err"]=_emscripten_err;Module["_emscripten_get_heap_max"]=_emscripten_get_heap_max;Module["getHeapMax"]=getHeapMax;Module["_emscripten_glActiveTexture"]=_emscripten_glActiveTexture;Module["_glActiveTexture"]=_glActiveTexture;Module["GL"]=GL;Module["GLctx"]=GLctx;Module["webgl_enable_ANGLE_instanced_arrays"]=webgl_enable_ANGLE_instanced_arrays;Module["webgl_enable_OES_vertex_array_object"]=webgl_enable_OES_vertex_array_object;Module["webgl_enable_WEBGL_draw_buffers"]=webgl_enable_WEBGL_draw_buffers;Module["webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance"]=webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance;Module["webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance"]=webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance;Module["webgl_enable_EXT_polygon_offset_clamp"]=webgl_enable_EXT_polygon_offset_clamp;Module["webgl_enable_EXT_clip_control"]=webgl_enable_EXT_clip_control;Module["webgl_enable_WEBGL_polygon_mode"]=webgl_enable_WEBGL_polygon_mode;Module["webgl_enable_WEBGL_multi_draw"]=webgl_enable_WEBGL_multi_draw;Module["getEmscriptenSupportedExtensions"]=getEmscriptenSupportedExtensions;Module["_emscripten_glAttachShader"]=_emscripten_glAttachShader;Module["_glAttachShader"]=_glAttachShader;Module["_emscripten_glBeginQuery"]=_emscripten_glBeginQuery;Module["_glBeginQuery"]=_glBeginQuery;Module["_emscripten_glBeginQueryEXT"]=_emscripten_glBeginQueryEXT;Module["_glBeginQueryEXT"]=_glBeginQueryEXT;Module["_emscripten_glBeginTransformFeedback"]=_emscripten_glBeginTransformFeedback;Module["_glBeginTransformFeedback"]=_glBeginTransformFeedback;Module["_emscripten_glBindAttribLocation"]=_emscripten_glBindAttribLocation;Module["_glBindAttribLocation"]=_glBindAttribLocation;Module["_emscripten_glBindBuffer"]=_emscripten_glBindBuffer;Module["_glBindBuffer"]=_glBindBuffer;Module["_emscripten_glBindBufferBase"]=_emscripten_glBindBufferBase;Module["_glBindBufferBase"]=_glBindBufferBase;Module["_emscripten_glBindBufferRange"]=_emscripten_glBindBufferRange;Module["_glBindBufferRange"]=_glBindBufferRange;Module["_emscripten_glBindFramebuffer"]=_emscripten_glBindFramebuffer;Module["_glBindFramebuffer"]=_glBindFramebuffer;Module["_emscripten_glBindRenderbuffer"]=_emscripten_glBindRenderbuffer;Module["_glBindRenderbuffer"]=_glBindRenderbuffer;Module["_emscripten_glBindSampler"]=_emscripten_glBindSampler;Module["_glBindSampler"]=_glBindSampler;Module["_emscripten_glBindTexture"]=_emscripten_glBindTexture;Module["_glBindTexture"]=_glBindTexture;Module["_emscripten_glBindTransformFeedback"]=_emscripten_glBindTransformFeedback;Module["_glBindTransformFeedback"]=_glBindTransformFeedback;Module["_emscripten_glBindVertexArray"]=_emscripten_glBindVertexArray;Module["_glBindVertexArray"]=_glBindVertexArray;Module["_emscripten_glBindVertexArrayOES"]=_emscripten_glBindVertexArrayOES;Module["_glBindVertexArrayOES"]=_glBindVertexArrayOES;Module["_emscripten_glBlendColor"]=_emscripten_glBlendColor;Module["_glBlendColor"]=_glBlendColor;Module["_emscripten_glBlendEquation"]=_emscripten_glBlendEquation;Module["_glBlendEquation"]=_glBlendEquation;Module["_emscripten_glBlendEquationSeparate"]=_emscripten_glBlendEquationSeparate;Module["_glBlendEquationSeparate"]=_glBlendEquationSeparate;Module["_emscripten_glBlendFunc"]=_emscripten_glBlendFunc;Module["_glBlendFunc"]=_glBlendFunc;Module["_emscripten_glBlendFuncSeparate"]=_emscripten_glBlendFuncSeparate;Module["_glBlendFuncSeparate"]=_glBlendFuncSeparate;Module["_emscripten_glBlitFramebuffer"]=_emscripten_glBlitFramebuffer;Module["_glBlitFramebuffer"]=_glBlitFramebuffer;Module["_emscripten_glBufferData"]=_emscripten_glBufferData;Module["_glBufferData"]=_glBufferData;Module["_emscripten_glBufferSubData"]=_emscripten_glBufferSubData;Module["_glBufferSubData"]=_glBufferSubData;Module["_emscripten_glCheckFramebufferStatus"]=_emscripten_glCheckFramebufferStatus;Module["_glCheckFramebufferStatus"]=_glCheckFramebufferStatus;Module["_emscripten_glClear"]=_emscripten_glClear;Module["_glClear"]=_glClear;Module["_emscripten_glClearBufferfi"]=_emscripten_glClearBufferfi;Module["_glClearBufferfi"]=_glClearBufferfi;Module["_emscripten_glClearBufferfv"]=_emscripten_glClearBufferfv;Module["_glClearBufferfv"]=_glClearBufferfv;Module["_emscripten_glClearBufferiv"]=_emscripten_glClearBufferiv;Module["_glClearBufferiv"]=_glClearBufferiv;Module["_emscripten_glClearBufferuiv"]=_emscripten_glClearBufferuiv;Module["_glClearBufferuiv"]=_glClearBufferuiv;Module["_emscripten_glClearColor"]=_emscripten_glClearColor;Module["_glClearColor"]=_glClearColor;Module["_emscripten_glClearDepthf"]=_emscripten_glClearDepthf;Module["_glClearDepthf"]=_glClearDepthf;Module["_emscripten_glClearStencil"]=_emscripten_glClearStencil;Module["_glClearStencil"]=_glClearStencil;Module["_emscripten_glClientWaitSync"]=_emscripten_glClientWaitSync;Module["_glClientWaitSync"]=_glClientWaitSync;Module["_emscripten_glClipControlEXT"]=_emscripten_glClipControlEXT;Module["_glClipControlEXT"]=_glClipControlEXT;Module["_emscripten_glColorMask"]=_emscripten_glColorMask;Module["_glColorMask"]=_glColorMask;Module["_emscripten_glCompileShader"]=_emscripten_glCompileShader;Module["_glCompileShader"]=_glCompileShader;Module["_emscripten_glCompressedTexImage2D"]=_emscripten_glCompressedTexImage2D;Module["_glCompressedTexImage2D"]=_glCompressedTexImage2D;Module["_emscripten_glCompressedTexImage3D"]=_emscripten_glCompressedTexImage3D;Module["_glCompressedTexImage3D"]=_glCompressedTexImage3D;Module["_emscripten_glCompressedTexSubImage2D"]=_emscripten_glCompressedTexSubImage2D;Module["_glCompressedTexSubImage2D"]=_glCompressedTexSubImage2D;Module["_emscripten_glCompressedTexSubImage3D"]=_emscripten_glCompressedTexSubImage3D;Module["_glCompressedTexSubImage3D"]=_glCompressedTexSubImage3D;Module["_emscripten_glCopyBufferSubData"]=_emscripten_glCopyBufferSubData;Module["_glCopyBufferSubData"]=_glCopyBufferSubData;Module["_emscripten_glCopyTexImage2D"]=_emscripten_glCopyTexImage2D;Module["_glCopyTexImage2D"]=_glCopyTexImage2D;Module["_emscripten_glCopyTexSubImage2D"]=_emscripten_glCopyTexSubImage2D;Module["_glCopyTexSubImage2D"]=_glCopyTexSubImage2D;Module["_emscripten_glCopyTexSubImage3D"]=_emscripten_glCopyTexSubImage3D;Module["_glCopyTexSubImage3D"]=_glCopyTexSubImage3D;Module["_emscripten_glCreateProgram"]=_emscripten_glCreateProgram;Module["_glCreateProgram"]=_glCreateProgram;Module["_emscripten_glCreateShader"]=_emscripten_glCreateShader;Module["_glCreateShader"]=_glCreateShader;Module["_emscripten_glCullFace"]=_emscripten_glCullFace;Module["_glCullFace"]=_glCullFace;Module["_emscripten_glDeleteBuffers"]=_emscripten_glDeleteBuffers;Module["_glDeleteBuffers"]=_glDeleteBuffers;Module["_emscripten_glDeleteFramebuffers"]=_emscripten_glDeleteFramebuffers;Module["_glDeleteFramebuffers"]=_glDeleteFramebuffers;Module["_emscripten_glDeleteProgram"]=_emscripten_glDeleteProgram;Module["_glDeleteProgram"]=_glDeleteProgram;Module["_emscripten_glDeleteQueries"]=_emscripten_glDeleteQueries;Module["_glDeleteQueries"]=_glDeleteQueries;Module["_emscripten_glDeleteQueriesEXT"]=_emscripten_glDeleteQueriesEXT;Module["_glDeleteQueriesEXT"]=_glDeleteQueriesEXT;Module["_emscripten_glDeleteRenderbuffers"]=_emscripten_glDeleteRenderbuffers;Module["_glDeleteRenderbuffers"]=_glDeleteRenderbuffers;Module["_emscripten_glDeleteSamplers"]=_emscripten_glDeleteSamplers;Module["_glDeleteSamplers"]=_glDeleteSamplers;Module["_emscripten_glDeleteShader"]=_emscripten_glDeleteShader;Module["_glDeleteShader"]=_glDeleteShader;Module["_emscripten_glDeleteSync"]=_emscripten_glDeleteSync;Module["_glDeleteSync"]=_glDeleteSync;Module["_emscripten_glDeleteTextures"]=_emscripten_glDeleteTextures;Module["_glDeleteTextures"]=_glDeleteTextures;Module["_emscripten_glDeleteTransformFeedbacks"]=_emscripten_glDeleteTransformFeedbacks;Module["_glDeleteTransformFeedbacks"]=_glDeleteTransformFeedbacks;Module["_emscripten_glDeleteVertexArrays"]=_emscripten_glDeleteVertexArrays;Module["_glDeleteVertexArrays"]=_glDeleteVertexArrays;Module["_emscripten_glDeleteVertexArraysOES"]=_emscripten_glDeleteVertexArraysOES;Module["_glDeleteVertexArraysOES"]=_glDeleteVertexArraysOES;Module["_emscripten_glDepthFunc"]=_emscripten_glDepthFunc;Module["_glDepthFunc"]=_glDepthFunc;Module["_emscripten_glDepthMask"]=_emscripten_glDepthMask;Module["_glDepthMask"]=_glDepthMask;Module["_emscripten_glDepthRangef"]=_emscripten_glDepthRangef;Module["_glDepthRangef"]=_glDepthRangef;Module["_emscripten_glDetachShader"]=_emscripten_glDetachShader;Module["_glDetachShader"]=_glDetachShader;Module["_emscripten_glDisable"]=_emscripten_glDisable;Module["_glDisable"]=_glDisable;Module["_emscripten_glDisableVertexAttribArray"]=_emscripten_glDisableVertexAttribArray;Module["_glDisableVertexAttribArray"]=_glDisableVertexAttribArray;Module["_emscripten_glDrawArrays"]=_emscripten_glDrawArrays;Module["_glDrawArrays"]=_glDrawArrays;Module["_emscripten_glDrawArraysInstanced"]=_emscripten_glDrawArraysInstanced;Module["_glDrawArraysInstanced"]=_glDrawArraysInstanced;Module["_emscripten_glDrawArraysInstancedANGLE"]=_emscripten_glDrawArraysInstancedANGLE;Module["_glDrawArraysInstancedANGLE"]=_glDrawArraysInstancedANGLE;Module["_emscripten_glDrawArraysInstancedARB"]=_emscripten_glDrawArraysInstancedARB;Module["_glDrawArraysInstancedARB"]=_glDrawArraysInstancedARB;Module["_emscripten_glDrawArraysInstancedEXT"]=_emscripten_glDrawArraysInstancedEXT;Module["_glDrawArraysInstancedEXT"]=_glDrawArraysInstancedEXT;Module["_emscripten_glDrawArraysInstancedNV"]=_emscripten_glDrawArraysInstancedNV;Module["_glDrawArraysInstancedNV"]=_glDrawArraysInstancedNV;Module["_emscripten_glDrawBuffers"]=_emscripten_glDrawBuffers;Module["_glDrawBuffers"]=_glDrawBuffers;Module["tempFixedLengthArray"]=tempFixedLengthArray;Module["_emscripten_glDrawBuffersEXT"]=_emscripten_glDrawBuffersEXT;Module["_glDrawBuffersEXT"]=_glDrawBuffersEXT;Module["_emscripten_glDrawBuffersWEBGL"]=_emscripten_glDrawBuffersWEBGL;Module["_glDrawBuffersWEBGL"]=_glDrawBuffersWEBGL;Module["_emscripten_glDrawElements"]=_emscripten_glDrawElements;Module["_glDrawElements"]=_glDrawElements;Module["_emscripten_glDrawElementsInstanced"]=_emscripten_glDrawElementsInstanced;Module["_glDrawElementsInstanced"]=_glDrawElementsInstanced;Module["_emscripten_glDrawElementsInstancedANGLE"]=_emscripten_glDrawElementsInstancedANGLE;Module["_glDrawElementsInstancedANGLE"]=_glDrawElementsInstancedANGLE;Module["_emscripten_glDrawElementsInstancedARB"]=_emscripten_glDrawElementsInstancedARB;Module["_glDrawElementsInstancedARB"]=_glDrawElementsInstancedARB;Module["_emscripten_glDrawElementsInstancedEXT"]=_emscripten_glDrawElementsInstancedEXT;Module["_glDrawElementsInstancedEXT"]=_glDrawElementsInstancedEXT;Module["_emscripten_glDrawElementsInstancedNV"]=_emscripten_glDrawElementsInstancedNV;Module["_glDrawElementsInstancedNV"]=_glDrawElementsInstancedNV;Module["_emscripten_glDrawRangeElements"]=_emscripten_glDrawRangeElements;Module["_glDrawRangeElements"]=_glDrawRangeElements;Module["_emscripten_glEnable"]=_emscripten_glEnable;Module["_glEnable"]=_glEnable;Module["_emscripten_glEnableVertexAttribArray"]=_emscripten_glEnableVertexAttribArray;Module["_glEnableVertexAttribArray"]=_glEnableVertexAttribArray;Module["_emscripten_glEndQuery"]=_emscripten_glEndQuery;Module["_glEndQuery"]=_glEndQuery;Module["_emscripten_glEndQueryEXT"]=_emscripten_glEndQueryEXT;Module["_glEndQueryEXT"]=_glEndQueryEXT;Module["_emscripten_glEndTransformFeedback"]=_emscripten_glEndTransformFeedback;Module["_glEndTransformFeedback"]=_glEndTransformFeedback;Module["_emscripten_glFenceSync"]=_emscripten_glFenceSync;Module["_glFenceSync"]=_glFenceSync;Module["_emscripten_glFinish"]=_emscripten_glFinish;Module["_glFinish"]=_glFinish;Module["_emscripten_glFlush"]=_emscripten_glFlush;Module["_glFlush"]=_glFlush;Module["_emscripten_glFramebufferRenderbuffer"]=_emscripten_glFramebufferRenderbuffer;Module["_glFramebufferRenderbuffer"]=_glFramebufferRenderbuffer;Module["_emscripten_glFramebufferTexture2D"]=_emscripten_glFramebufferTexture2D;Module["_glFramebufferTexture2D"]=_glFramebufferTexture2D;Module["_emscripten_glFramebufferTextureLayer"]=_emscripten_glFramebufferTextureLayer;Module["_glFramebufferTextureLayer"]=_glFramebufferTextureLayer;Module["_emscripten_glFrontFace"]=_emscripten_glFrontFace;Module["_glFrontFace"]=_glFrontFace;Module["_emscripten_glGenBuffers"]=_emscripten_glGenBuffers;Module["_glGenBuffers"]=_glGenBuffers;Module["_emscripten_glGenFramebuffers"]=_emscripten_glGenFramebuffers;Module["_glGenFramebuffers"]=_glGenFramebuffers;Module["_emscripten_glGenQueries"]=_emscripten_glGenQueries;Module["_glGenQueries"]=_glGenQueries;Module["_emscripten_glGenQueriesEXT"]=_emscripten_glGenQueriesEXT;Module["_glGenQueriesEXT"]=_glGenQueriesEXT;Module["_emscripten_glGenRenderbuffers"]=_emscripten_glGenRenderbuffers;Module["_glGenRenderbuffers"]=_glGenRenderbuffers;Module["_emscripten_glGenSamplers"]=_emscripten_glGenSamplers;Module["_glGenSamplers"]=_glGenSamplers;Module["_emscripten_glGenTextures"]=_emscripten_glGenTextures;Module["_glGenTextures"]=_glGenTextures;Module["_emscripten_glGenTransformFeedbacks"]=_emscripten_glGenTransformFeedbacks;Module["_glGenTransformFeedbacks"]=_glGenTransformFeedbacks;Module["_emscripten_glGenVertexArrays"]=_emscripten_glGenVertexArrays;Module["_glGenVertexArrays"]=_glGenVertexArrays;Module["_emscripten_glGenVertexArraysOES"]=_emscripten_glGenVertexArraysOES;Module["_glGenVertexArraysOES"]=_glGenVertexArraysOES;Module["_emscripten_glGenerateMipmap"]=_emscripten_glGenerateMipmap;Module["_glGenerateMipmap"]=_glGenerateMipmap;Module["_emscripten_glGetActiveAttrib"]=_emscripten_glGetActiveAttrib;Module["_glGetActiveAttrib"]=_glGetActiveAttrib;Module["__glGetActiveAttribOrUniform"]=__glGetActiveAttribOrUniform;Module["_emscripten_glGetActiveUniform"]=_emscripten_glGetActiveUniform;Module["_glGetActiveUniform"]=_glGetActiveUniform;Module["_emscripten_glGetActiveUniformBlockName"]=_emscripten_glGetActiveUniformBlockName;Module["_glGetActiveUniformBlockName"]=_glGetActiveUniformBlockName;Module["_emscripten_glGetActiveUniformBlockiv"]=_emscripten_glGetActiveUniformBlockiv;Module["_glGetActiveUniformBlockiv"]=_glGetActiveUniformBlockiv;Module["_emscripten_glGetActiveUniformsiv"]=_emscripten_glGetActiveUniformsiv;Module["_glGetActiveUniformsiv"]=_glGetActiveUniformsiv;Module["_emscripten_glGetAttachedShaders"]=_emscripten_glGetAttachedShaders;Module["_glGetAttachedShaders"]=_glGetAttachedShaders;Module["_emscripten_glGetAttribLocation"]=_emscripten_glGetAttribLocation;Module["_glGetAttribLocation"]=_glGetAttribLocation;Module["_emscripten_glGetBooleanv"]=_emscripten_glGetBooleanv;Module["_glGetBooleanv"]=_glGetBooleanv;Module["emscriptenWebGLGet"]=emscriptenWebGLGet;Module["writeI53ToI64"]=writeI53ToI64;Module["webglGetExtensions"]=webglGetExtensions;Module["_emscripten_glGetBufferParameteri64v"]=_emscripten_glGetBufferParameteri64v;Module["_glGetBufferParameteri64v"]=_glGetBufferParameteri64v;Module["_emscripten_glGetBufferParameteriv"]=_emscripten_glGetBufferParameteriv;Module["_glGetBufferParameteriv"]=_glGetBufferParameteriv;Module["_emscripten_glGetError"]=_emscripten_glGetError;Module["_glGetError"]=_glGetError;Module["_emscripten_glGetFloatv"]=_emscripten_glGetFloatv;Module["_glGetFloatv"]=_glGetFloatv;Module["_emscripten_glGetFragDataLocation"]=_emscripten_glGetFragDataLocation;Module["_glGetFragDataLocation"]=_glGetFragDataLocation;Module["_emscripten_glGetFramebufferAttachmentParameteriv"]=_emscripten_glGetFramebufferAttachmentParameteriv;Module["_glGetFramebufferAttachmentParameteriv"]=_glGetFramebufferAttachmentParameteriv;Module["_emscripten_glGetInteger64i_v"]=_emscripten_glGetInteger64i_v;Module["_glGetInteger64i_v"]=_glGetInteger64i_v;Module["emscriptenWebGLGetIndexed"]=emscriptenWebGLGetIndexed;Module["_emscripten_glGetInteger64v"]=_emscripten_glGetInteger64v;Module["_glGetInteger64v"]=_glGetInteger64v;Module["_emscripten_glGetIntegeri_v"]=_emscripten_glGetIntegeri_v;Module["_glGetIntegeri_v"]=_glGetIntegeri_v;Module["_emscripten_glGetIntegerv"]=_emscripten_glGetIntegerv;Module["_glGetIntegerv"]=_glGetIntegerv;Module["_emscripten_glGetInternalformativ"]=_emscripten_glGetInternalformativ;Module["_glGetInternalformativ"]=_glGetInternalformativ;Module["_emscripten_glGetProgramBinary"]=_emscripten_glGetProgramBinary;Module["_glGetProgramBinary"]=_glGetProgramBinary;Module["_emscripten_glGetProgramInfoLog"]=_emscripten_glGetProgramInfoLog;Module["_glGetProgramInfoLog"]=_glGetProgramInfoLog;Module["_emscripten_glGetProgramiv"]=_emscripten_glGetProgramiv;Module["_glGetProgramiv"]=_glGetProgramiv;Module["_emscripten_glGetQueryObjecti64vEXT"]=_emscripten_glGetQueryObjecti64vEXT;Module["_glGetQueryObjecti64vEXT"]=_glGetQueryObjecti64vEXT;Module["_emscripten_glGetQueryObjectivEXT"]=_emscripten_glGetQueryObjectivEXT;Module["_glGetQueryObjectivEXT"]=_glGetQueryObjectivEXT;Module["_emscripten_glGetQueryObjectui64vEXT"]=_emscripten_glGetQueryObjectui64vEXT;Module["_glGetQueryObjectui64vEXT"]=_glGetQueryObjectui64vEXT;Module["_emscripten_glGetQueryObjectuiv"]=_emscripten_glGetQueryObjectuiv;Module["_glGetQueryObjectuiv"]=_glGetQueryObjectuiv;Module["_emscripten_glGetQueryObjectuivEXT"]=_emscripten_glGetQueryObjectuivEXT;Module["_glGetQueryObjectuivEXT"]=_glGetQueryObjectuivEXT;Module["_emscripten_glGetQueryiv"]=_emscripten_glGetQueryiv;Module["_glGetQueryiv"]=_glGetQueryiv;Module["_emscripten_glGetQueryivEXT"]=_emscripten_glGetQueryivEXT;Module["_glGetQueryivEXT"]=_glGetQueryivEXT;Module["_emscripten_glGetRenderbufferParameteriv"]=_emscripten_glGetRenderbufferParameteriv;Module["_glGetRenderbufferParameteriv"]=_glGetRenderbufferParameteriv;Module["_emscripten_glGetSamplerParameterfv"]=_emscripten_glGetSamplerParameterfv;Module["_glGetSamplerParameterfv"]=_glGetSamplerParameterfv;Module["_emscripten_glGetSamplerParameteriv"]=_emscripten_glGetSamplerParameteriv;Module["_glGetSamplerParameteriv"]=_glGetSamplerParameteriv;Module["_emscripten_glGetShaderInfoLog"]=_emscripten_glGetShaderInfoLog;Module["_glGetShaderInfoLog"]=_glGetShaderInfoLog;Module["_emscripten_glGetShaderPrecisionFormat"]=_emscripten_glGetShaderPrecisionFormat;Module["_glGetShaderPrecisionFormat"]=_glGetShaderPrecisionFormat;Module["_emscripten_glGetShaderSource"]=_emscripten_glGetShaderSource;Module["_glGetShaderSource"]=_glGetShaderSource;Module["_emscripten_glGetShaderiv"]=_emscripten_glGetShaderiv;Module["_glGetShaderiv"]=_glGetShaderiv;Module["_emscripten_glGetString"]=_emscripten_glGetString;Module["_glGetString"]=_glGetString;Module["stringToNewUTF8"]=stringToNewUTF8;Module["_emscripten_glGetStringi"]=_emscripten_glGetStringi;Module["_glGetStringi"]=_glGetStringi;Module["_emscripten_glGetSynciv"]=_emscripten_glGetSynciv;Module["_glGetSynciv"]=_glGetSynciv;Module["_emscripten_glGetTexParameterfv"]=_emscripten_glGetTexParameterfv;Module["_glGetTexParameterfv"]=_glGetTexParameterfv;Module["_emscripten_glGetTexParameteriv"]=_emscripten_glGetTexParameteriv;Module["_glGetTexParameteriv"]=_glGetTexParameteriv;Module["_emscripten_glGetTransformFeedbackVarying"]=_emscripten_glGetTransformFeedbackVarying;Module["_glGetTransformFeedbackVarying"]=_glGetTransformFeedbackVarying;Module["_emscripten_glGetUniformBlockIndex"]=_emscripten_glGetUniformBlockIndex;Module["_glGetUniformBlockIndex"]=_glGetUniformBlockIndex;Module["_emscripten_glGetUniformIndices"]=_emscripten_glGetUniformIndices;Module["_glGetUniformIndices"]=_glGetUniformIndices;Module["_emscripten_glGetUniformLocation"]=_emscripten_glGetUniformLocation;Module["_glGetUniformLocation"]=_glGetUniformLocation;Module["jstoi_q"]=jstoi_q;Module["webglPrepareUniformLocationsBeforeFirstUse"]=webglPrepareUniformLocationsBeforeFirstUse;Module["webglGetLeftBracePos"]=webglGetLeftBracePos;Module["_emscripten_glGetUniformfv"]=_emscripten_glGetUniformfv;Module["_glGetUniformfv"]=_glGetUniformfv;Module["emscriptenWebGLGetUniform"]=emscriptenWebGLGetUniform;Module["webglGetUniformLocation"]=webglGetUniformLocation;Module["_emscripten_glGetUniformiv"]=_emscripten_glGetUniformiv;Module["_glGetUniformiv"]=_glGetUniformiv;Module["_emscripten_glGetUniformuiv"]=_emscripten_glGetUniformuiv;Module["_glGetUniformuiv"]=_glGetUniformuiv;Module["_emscripten_glGetVertexAttribIiv"]=_emscripten_glGetVertexAttribIiv;Module["_glGetVertexAttribIiv"]=_glGetVertexAttribIiv;Module["emscriptenWebGLGetVertexAttrib"]=emscriptenWebGLGetVertexAttrib;Module["_emscripten_glGetVertexAttribIuiv"]=_emscripten_glGetVertexAttribIuiv;Module["_glGetVertexAttribIuiv"]=_glGetVertexAttribIuiv;Module["_emscripten_glGetVertexAttribPointerv"]=_emscripten_glGetVertexAttribPointerv;Module["_glGetVertexAttribPointerv"]=_glGetVertexAttribPointerv;Module["_emscripten_glGetVertexAttribfv"]=_emscripten_glGetVertexAttribfv;Module["_glGetVertexAttribfv"]=_glGetVertexAttribfv;Module["_emscripten_glGetVertexAttribiv"]=_emscripten_glGetVertexAttribiv;Module["_glGetVertexAttribiv"]=_glGetVertexAttribiv;Module["_emscripten_glHint"]=_emscripten_glHint;Module["_glHint"]=_glHint;Module["_emscripten_glInvalidateFramebuffer"]=_emscripten_glInvalidateFramebuffer;Module["_glInvalidateFramebuffer"]=_glInvalidateFramebuffer;Module["_emscripten_glInvalidateSubFramebuffer"]=_emscripten_glInvalidateSubFramebuffer;Module["_glInvalidateSubFramebuffer"]=_glInvalidateSubFramebuffer;Module["_emscripten_glIsBuffer"]=_emscripten_glIsBuffer;Module["_glIsBuffer"]=_glIsBuffer;Module["_emscripten_glIsEnabled"]=_emscripten_glIsEnabled;Module["_glIsEnabled"]=_glIsEnabled;Module["_emscripten_glIsFramebuffer"]=_emscripten_glIsFramebuffer;Module["_glIsFramebuffer"]=_glIsFramebuffer;Module["_emscripten_glIsProgram"]=_emscripten_glIsProgram;Module["_glIsProgram"]=_glIsProgram;Module["_emscripten_glIsQuery"]=_emscripten_glIsQuery;Module["_glIsQuery"]=_glIsQuery;Module["_emscripten_glIsQueryEXT"]=_emscripten_glIsQueryEXT;Module["_glIsQueryEXT"]=_glIsQueryEXT;Module["_emscripten_glIsRenderbuffer"]=_emscripten_glIsRenderbuffer;Module["_glIsRenderbuffer"]=_glIsRenderbuffer;Module["_emscripten_glIsSampler"]=_emscripten_glIsSampler;Module["_glIsSampler"]=_glIsSampler;Module["_emscripten_glIsShader"]=_emscripten_glIsShader;Module["_glIsShader"]=_glIsShader;Module["_emscripten_glIsSync"]=_emscripten_glIsSync;Module["_glIsSync"]=_glIsSync;Module["_emscripten_glIsTexture"]=_emscripten_glIsTexture;Module["_glIsTexture"]=_glIsTexture;Module["_emscripten_glIsTransformFeedback"]=_emscripten_glIsTransformFeedback;Module["_glIsTransformFeedback"]=_glIsTransformFeedback;Module["_emscripten_glIsVertexArray"]=_emscripten_glIsVertexArray;Module["_glIsVertexArray"]=_glIsVertexArray;Module["_emscripten_glIsVertexArrayOES"]=_emscripten_glIsVertexArrayOES;Module["_glIsVertexArrayOES"]=_glIsVertexArrayOES;Module["_emscripten_glLineWidth"]=_emscripten_glLineWidth;Module["_glLineWidth"]=_glLineWidth;Module["_emscripten_glLinkProgram"]=_emscripten_glLinkProgram;Module["_glLinkProgram"]=_glLinkProgram;Module["_emscripten_glPauseTransformFeedback"]=_emscripten_glPauseTransformFeedback;Module["_glPauseTransformFeedback"]=_glPauseTransformFeedback;Module["_emscripten_glPixelStorei"]=_emscripten_glPixelStorei;Module["_glPixelStorei"]=_glPixelStorei;Module["_emscripten_glPolygonModeWEBGL"]=_emscripten_glPolygonModeWEBGL;Module["_glPolygonModeWEBGL"]=_glPolygonModeWEBGL;Module["_emscripten_glPolygonOffset"]=_emscripten_glPolygonOffset;Module["_glPolygonOffset"]=_glPolygonOffset;Module["_emscripten_glPolygonOffsetClampEXT"]=_emscripten_glPolygonOffsetClampEXT;Module["_glPolygonOffsetClampEXT"]=_glPolygonOffsetClampEXT;Module["_emscripten_glProgramBinary"]=_emscripten_glProgramBinary;Module["_glProgramBinary"]=_glProgramBinary;Module["_emscripten_glProgramParameteri"]=_emscripten_glProgramParameteri;Module["_glProgramParameteri"]=_glProgramParameteri;Module["_emscripten_glQueryCounterEXT"]=_emscripten_glQueryCounterEXT;Module["_glQueryCounterEXT"]=_glQueryCounterEXT;Module["_emscripten_glReadBuffer"]=_emscripten_glReadBuffer;Module["_glReadBuffer"]=_glReadBuffer;Module["_emscripten_glReadPixels"]=_emscripten_glReadPixels;Module["_glReadPixels"]=_glReadPixels;Module["emscriptenWebGLGetTexPixelData"]=emscriptenWebGLGetTexPixelData;Module["computeUnpackAlignedImageSize"]=computeUnpackAlignedImageSize;Module["colorChannelsInGlTextureFormat"]=colorChannelsInGlTextureFormat;Module["heapObjectForWebGLType"]=heapObjectForWebGLType;Module["toTypedArrayIndex"]=toTypedArrayIndex;Module["_emscripten_glReleaseShaderCompiler"]=_emscripten_glReleaseShaderCompiler;Module["_glReleaseShaderCompiler"]=_glReleaseShaderCompiler;Module["_emscripten_glRenderbufferStorage"]=_emscripten_glRenderbufferStorage;Module["_glRenderbufferStorage"]=_glRenderbufferStorage;Module["_emscripten_glRenderbufferStorageMultisample"]=_emscripten_glRenderbufferStorageMultisample;Module["_glRenderbufferStorageMultisample"]=_glRenderbufferStorageMultisample;Module["_emscripten_glResumeTransformFeedback"]=_emscripten_glResumeTransformFeedback;Module["_glResumeTransformFeedback"]=_glResumeTransformFeedback;Module["_emscripten_glSampleCoverage"]=_emscripten_glSampleCoverage;Module["_glSampleCoverage"]=_glSampleCoverage;Module["_emscripten_glSamplerParameterf"]=_emscripten_glSamplerParameterf;Module["_glSamplerParameterf"]=_glSamplerParameterf;Module["_emscripten_glSamplerParameterfv"]=_emscripten_glSamplerParameterfv;Module["_glSamplerParameterfv"]=_glSamplerParameterfv;Module["_emscripten_glSamplerParameteri"]=_emscripten_glSamplerParameteri;Module["_glSamplerParameteri"]=_glSamplerParameteri;Module["_emscripten_glSamplerParameteriv"]=_emscripten_glSamplerParameteriv;Module["_glSamplerParameteriv"]=_glSamplerParameteriv;Module["_emscripten_glScissor"]=_emscripten_glScissor;Module["_glScissor"]=_glScissor;Module["_emscripten_glShaderBinary"]=_emscripten_glShaderBinary;Module["_glShaderBinary"]=_glShaderBinary;Module["_emscripten_glShaderSource"]=_emscripten_glShaderSource;Module["_glShaderSource"]=_glShaderSource;Module["_emscripten_glStencilFunc"]=_emscripten_glStencilFunc;Module["_glStencilFunc"]=_glStencilFunc;Module["_emscripten_glStencilFuncSeparate"]=_emscripten_glStencilFuncSeparate;Module["_glStencilFuncSeparate"]=_glStencilFuncSeparate;Module["_emscripten_glStencilMask"]=_emscripten_glStencilMask;Module["_glStencilMask"]=_glStencilMask;Module["_emscripten_glStencilMaskSeparate"]=_emscripten_glStencilMaskSeparate;Module["_glStencilMaskSeparate"]=_glStencilMaskSeparate;Module["_emscripten_glStencilOp"]=_emscripten_glStencilOp;Module["_glStencilOp"]=_glStencilOp;Module["_emscripten_glStencilOpSeparate"]=_emscripten_glStencilOpSeparate;Module["_glStencilOpSeparate"]=_glStencilOpSeparate;Module["_emscripten_glTexImage2D"]=_emscripten_glTexImage2D;Module["_glTexImage2D"]=_glTexImage2D;Module["_emscripten_glTexImage3D"]=_emscripten_glTexImage3D;Module["_glTexImage3D"]=_glTexImage3D;Module["_emscripten_glTexParameterf"]=_emscripten_glTexParameterf;Module["_glTexParameterf"]=_glTexParameterf;Module["_emscripten_glTexParameterfv"]=_emscripten_glTexParameterfv;Module["_glTexParameterfv"]=_glTexParameterfv;Module["_emscripten_glTexParameteri"]=_emscripten_glTexParameteri;Module["_glTexParameteri"]=_glTexParameteri;Module["_emscripten_glTexParameteriv"]=_emscripten_glTexParameteriv;Module["_glTexParameteriv"]=_glTexParameteriv;Module["_emscripten_glTexStorage2D"]=_emscripten_glTexStorage2D;Module["_glTexStorage2D"]=_glTexStorage2D;Module["_emscripten_glTexStorage3D"]=_emscripten_glTexStorage3D;Module["_glTexStorage3D"]=_glTexStorage3D;Module["_emscripten_glTexSubImage2D"]=_emscripten_glTexSubImage2D;Module["_glTexSubImage2D"]=_glTexSubImage2D;Module["_emscripten_glTexSubImage3D"]=_emscripten_glTexSubImage3D;Module["_glTexSubImage3D"]=_glTexSubImage3D;Module["_emscripten_glTransformFeedbackVaryings"]=_emscripten_glTransformFeedbackVaryings;Module["_glTransformFeedbackVaryings"]=_glTransformFeedbackVaryings;Module["_emscripten_glUniform1f"]=_emscripten_glUniform1f;Module["_glUniform1f"]=_glUniform1f;Module["_emscripten_glUniform1fv"]=_emscripten_glUniform1fv;Module["_glUniform1fv"]=_glUniform1fv;Module["miniTempWebGLFloatBuffers"]=miniTempWebGLFloatBuffers;Module["_emscripten_glUniform1i"]=_emscripten_glUniform1i;Module["_glUniform1i"]=_glUniform1i;Module["_emscripten_glUniform1iv"]=_emscripten_glUniform1iv;Module["_glUniform1iv"]=_glUniform1iv;Module["miniTempWebGLIntBuffers"]=miniTempWebGLIntBuffers;Module["_emscripten_glUniform1ui"]=_emscripten_glUniform1ui;Module["_glUniform1ui"]=_glUniform1ui;Module["_emscripten_glUniform1uiv"]=_emscripten_glUniform1uiv;Module["_glUniform1uiv"]=_glUniform1uiv;Module["_emscripten_glUniform2f"]=_emscripten_glUniform2f;Module["_glUniform2f"]=_glUniform2f;Module["_emscripten_glUniform2fv"]=_emscripten_glUniform2fv;Module["_glUniform2fv"]=_glUniform2fv;Module["_emscripten_glUniform2i"]=_emscripten_glUniform2i;Module["_glUniform2i"]=_glUniform2i;Module["_emscripten_glUniform2iv"]=_emscripten_glUniform2iv;Module["_glUniform2iv"]=_glUniform2iv;Module["_emscripten_glUniform2ui"]=_emscripten_glUniform2ui;Module["_glUniform2ui"]=_glUniform2ui;Module["_emscripten_glUniform2uiv"]=_emscripten_glUniform2uiv;Module["_glUniform2uiv"]=_glUniform2uiv;Module["_emscripten_glUniform3f"]=_emscripten_glUniform3f;Module["_glUniform3f"]=_glUniform3f;Module["_emscripten_glUniform3fv"]=_emscripten_glUniform3fv;Module["_glUniform3fv"]=_glUniform3fv;Module["_emscripten_glUniform3i"]=_emscripten_glUniform3i;Module["_glUniform3i"]=_glUniform3i;Module["_emscripten_glUniform3iv"]=_emscripten_glUniform3iv;Module["_glUniform3iv"]=_glUniform3iv;Module["_emscripten_glUniform3ui"]=_emscripten_glUniform3ui;Module["_glUniform3ui"]=_glUniform3ui;Module["_emscripten_glUniform3uiv"]=_emscripten_glUniform3uiv;Module["_glUniform3uiv"]=_glUniform3uiv;Module["_emscripten_glUniform4f"]=_emscripten_glUniform4f;Module["_glUniform4f"]=_glUniform4f;Module["_emscripten_glUniform4fv"]=_emscripten_glUniform4fv;Module["_glUniform4fv"]=_glUniform4fv;Module["_emscripten_glUniform4i"]=_emscripten_glUniform4i;Module["_glUniform4i"]=_glUniform4i;Module["_emscripten_glUniform4iv"]=_emscripten_glUniform4iv;Module["_glUniform4iv"]=_glUniform4iv;Module["_emscripten_glUniform4ui"]=_emscripten_glUniform4ui;Module["_glUniform4ui"]=_glUniform4ui;Module["_emscripten_glUniform4uiv"]=_emscripten_glUniform4uiv;Module["_glUniform4uiv"]=_glUniform4uiv;Module["_emscripten_glUniformBlockBinding"]=_emscripten_glUniformBlockBinding;Module["_glUniformBlockBinding"]=_glUniformBlockBinding;Module["_emscripten_glUniformMatrix2fv"]=_emscripten_glUniformMatrix2fv;Module["_glUniformMatrix2fv"]=_glUniformMatrix2fv;Module["_emscripten_glUniformMatrix2x3fv"]=_emscripten_glUniformMatrix2x3fv;Module["_glUniformMatrix2x3fv"]=_glUniformMatrix2x3fv;Module["_emscripten_glUniformMatrix2x4fv"]=_emscripten_glUniformMatrix2x4fv;Module["_glUniformMatrix2x4fv"]=_glUniformMatrix2x4fv;Module["_emscripten_glUniformMatrix3fv"]=_emscripten_glUniformMatrix3fv;Module["_glUniformMatrix3fv"]=_glUniformMatrix3fv;Module["_emscripten_glUniformMatrix3x2fv"]=_emscripten_glUniformMatrix3x2fv;Module["_glUniformMatrix3x2fv"]=_glUniformMatrix3x2fv;Module["_emscripten_glUniformMatrix3x4fv"]=_emscripten_glUniformMatrix3x4fv;Module["_glUniformMatrix3x4fv"]=_glUniformMatrix3x4fv;Module["_emscripten_glUniformMatrix4fv"]=_emscripten_glUniformMatrix4fv;Module["_glUniformMatrix4fv"]=_glUniformMatrix4fv;Module["_emscripten_glUniformMatrix4x2fv"]=_emscripten_glUniformMatrix4x2fv;Module["_glUniformMatrix4x2fv"]=_glUniformMatrix4x2fv;Module["_emscripten_glUniformMatrix4x3fv"]=_emscripten_glUniformMatrix4x3fv;Module["_glUniformMatrix4x3fv"]=_glUniformMatrix4x3fv;Module["_emscripten_glUseProgram"]=_emscripten_glUseProgram;Module["_glUseProgram"]=_glUseProgram;Module["_emscripten_glValidateProgram"]=_emscripten_glValidateProgram;Module["_glValidateProgram"]=_glValidateProgram;Module["_emscripten_glVertexAttrib1f"]=_emscripten_glVertexAttrib1f;Module["_glVertexAttrib1f"]=_glVertexAttrib1f;Module["_emscripten_glVertexAttrib1fv"]=_emscripten_glVertexAttrib1fv;Module["_glVertexAttrib1fv"]=_glVertexAttrib1fv;Module["_emscripten_glVertexAttrib2f"]=_emscripten_glVertexAttrib2f;Module["_glVertexAttrib2f"]=_glVertexAttrib2f;Module["_emscripten_glVertexAttrib2fv"]=_emscripten_glVertexAttrib2fv;Module["_glVertexAttrib2fv"]=_glVertexAttrib2fv;Module["_emscripten_glVertexAttrib3f"]=_emscripten_glVertexAttrib3f;Module["_glVertexAttrib3f"]=_glVertexAttrib3f;Module["_emscripten_glVertexAttrib3fv"]=_emscripten_glVertexAttrib3fv;Module["_glVertexAttrib3fv"]=_glVertexAttrib3fv;Module["_emscripten_glVertexAttrib4f"]=_emscripten_glVertexAttrib4f;Module["_glVertexAttrib4f"]=_glVertexAttrib4f;Module["_emscripten_glVertexAttrib4fv"]=_emscripten_glVertexAttrib4fv;Module["_glVertexAttrib4fv"]=_glVertexAttrib4fv;Module["_emscripten_glVertexAttribDivisor"]=_emscripten_glVertexAttribDivisor;Module["_glVertexAttribDivisor"]=_glVertexAttribDivisor;Module["_emscripten_glVertexAttribDivisorANGLE"]=_emscripten_glVertexAttribDivisorANGLE;Module["_glVertexAttribDivisorANGLE"]=_glVertexAttribDivisorANGLE;Module["_emscripten_glVertexAttribDivisorARB"]=_emscripten_glVertexAttribDivisorARB;Module["_glVertexAttribDivisorARB"]=_glVertexAttribDivisorARB;Module["_emscripten_glVertexAttribDivisorEXT"]=_emscripten_glVertexAttribDivisorEXT;Module["_glVertexAttribDivisorEXT"]=_glVertexAttribDivisorEXT;Module["_emscripten_glVertexAttribDivisorNV"]=_emscripten_glVertexAttribDivisorNV;Module["_glVertexAttribDivisorNV"]=_glVertexAttribDivisorNV;Module["_emscripten_glVertexAttribI4i"]=_emscripten_glVertexAttribI4i;Module["_glVertexAttribI4i"]=_glVertexAttribI4i;Module["_emscripten_glVertexAttribI4iv"]=_emscripten_glVertexAttribI4iv;Module["_glVertexAttribI4iv"]=_glVertexAttribI4iv;Module["_emscripten_glVertexAttribI4ui"]=_emscripten_glVertexAttribI4ui;Module["_glVertexAttribI4ui"]=_glVertexAttribI4ui;Module["_emscripten_glVertexAttribI4uiv"]=_emscripten_glVertexAttribI4uiv;Module["_glVertexAttribI4uiv"]=_glVertexAttribI4uiv;Module["_emscripten_glVertexAttribIPointer"]=_emscripten_glVertexAttribIPointer;Module["_glVertexAttribIPointer"]=_glVertexAttribIPointer;Module["_emscripten_glVertexAttribPointer"]=_emscripten_glVertexAttribPointer;Module["_glVertexAttribPointer"]=_glVertexAttribPointer;Module["_emscripten_glViewport"]=_emscripten_glViewport;Module["_glViewport"]=_glViewport;Module["_emscripten_glWaitSync"]=_emscripten_glWaitSync;Module["_glWaitSync"]=_glWaitSync;Module["_emscripten_out"]=_emscripten_out;Module["_emscripten_promise_create"]=_emscripten_promise_create;Module["makePromise"]=makePromise;Module["promiseMap"]=promiseMap;Module["HandleAllocator"]=HandleAllocator;Module["_emscripten_promise_destroy"]=_emscripten_promise_destroy;Module["_emscripten_promise_resolve"]=_emscripten_promise_resolve;Module["getPromise"]=getPromise;Module["_emscripten_resize_heap"]=_emscripten_resize_heap;Module["growMemory"]=growMemory;Module["_emscripten_runtime_keepalive_pop"]=_emscripten_runtime_keepalive_pop;Module["_emscripten_runtime_keepalive_push"]=_emscripten_runtime_keepalive_push;Module["_environ_get"]=_environ_get;Module["getEnvStrings"]=getEnvStrings;Module["ENV"]=ENV;Module["_environ_sizes_get"]=_environ_sizes_get;Module["_fd_close"]=_fd_close;Module["_fd_fdstat_get"]=_fd_fdstat_get;Module["_fd_pread"]=_fd_pread;Module["doReadv"]=doReadv;Module["_fd_pwrite"]=_fd_pwrite;Module["doWritev"]=doWritev;Module["_fd_read"]=_fd_read;Module["_fd_seek"]=_fd_seek;Module["_fd_sync"]=_fd_sync;Module["_fd_write"]=_fd_write;Module["_getaddrinfo"]=_getaddrinfo;Module["_getnameinfo"]=_getnameinfo;Module["_getprotobyname"]=_getprotobyname;Module["_setprotoent"]=_setprotoent;Module["Protocols"]=Protocols;Module["stringToAscii"]=stringToAscii;Module["_is_sentinel"]=_is_sentinel;Module["_random_get"]=_random_get;Module["_stackAlloc"]=_stackAlloc;Module["_stackRestore"]=_stackRestore;Module["_stackSave"]=_stackSave;Module["FS_createPath"]=FS_createPath;Module["FS_unlink"]=FS_unlink;Module["FS_createLazyFile"]=FS_createLazyFile;Module["FS_createDevice"]=FS_createDevice;Module["writeI53ToI64Clamped"]=writeI53ToI64Clamped;Module["writeI53ToI64Signaling"]=writeI53ToI64Signaling;Module["writeI53ToU64Clamped"]=writeI53ToU64Clamped;Module["writeI53ToU64Signaling"]=writeI53ToU64Signaling;Module["readI53FromU64"]=readI53FromU64;Module["convertI32PairToI53"]=convertI32PairToI53;Module["convertI32PairToI53Checked"]=convertI32PairToI53Checked;Module["convertU32PairToI53"]=convertU32PairToI53;Module["getTempRet0"]=getTempRet0;Module["setTempRet0"]=setTempRet0;Module["ptrToString"]=ptrToString;Module["_emscripten_notify_memory_growth"]=_emscripten_notify_memory_growth;Module["strError"]=strError;Module["_endprotoent"]=_endprotoent;Module["_getprotoent"]=_getprotoent;Module["_getprotobynumber"]=_getprotobynumber;Module["Sockets"]=Sockets;Module["_emscripten_run_script"]=_emscripten_run_script;Module["_emscripten_run_script_int"]=_emscripten_run_script_int;Module["_emscripten_run_script_string"]=_emscripten_run_script_string;Module["_emscripten_random"]=_emscripten_random;Module["_emscripten_performance_now"]=_emscripten_performance_now;Module["__emscripten_get_now_is_monotonic"]=__emscripten_get_now_is_monotonic;Module["warnOnce"]=warnOnce;Module["emscriptenLog"]=emscriptenLog;Module["getCallstack"]=getCallstack;Module["jsStackTrace"]=jsStackTrace;Module["_emscripten_log"]=_emscripten_log;Module["formatString"]=formatString;Module["reallyNegative"]=reallyNegative;Module["reSign"]=reSign;Module["unSign"]=unSign;Module["strLen"]=strLen;Module["_emscripten_get_compiler_setting"]=_emscripten_get_compiler_setting;Module["_emscripten_has_asyncify"]=_emscripten_has_asyncify;Module["_emscripten_debugger"]=_emscripten_debugger;Module["_emscripten_print_double"]=_emscripten_print_double;Module["_emscripten_asm_const_double"]=_emscripten_asm_const_double;Module["_emscripten_asm_const_ptr"]=_emscripten_asm_const_ptr;Module["runMainThreadEmAsm"]=runMainThreadEmAsm;Module["_emscripten_asm_const_int_sync_on_main_thread"]=_emscripten_asm_const_int_sync_on_main_thread;Module["_emscripten_asm_const_ptr_sync_on_main_thread"]=_emscripten_asm_const_ptr_sync_on_main_thread;Module["_emscripten_asm_const_double_sync_on_main_thread"]=_emscripten_asm_const_double_sync_on_main_thread;Module["_emscripten_asm_const_async_on_main_thread"]=_emscripten_asm_const_async_on_main_thread;Module["__Unwind_Backtrace"]=__Unwind_Backtrace;Module["__Unwind_GetIPInfo"]=__Unwind_GetIPInfo;Module["__Unwind_FindEnclosingFunction"]=__Unwind_FindEnclosingFunction;Module["listenOnce"]=listenOnce;Module["autoResumeAudioContext"]=autoResumeAudioContext;Module["getDynCaller"]=getDynCaller;Module["dynCall"]=dynCall;Module["_emscripten_exit_with_live_runtime"]=_emscripten_exit_with_live_runtime;Module["_emscripten_force_exit"]=_emscripten_force_exit;Module["_emscripten_outn"]=_emscripten_outn;Module["_emscripten_errn"]=_emscripten_errn;Module["_emscripten_throw_number"]=_emscripten_throw_number;Module["_emscripten_throw_string"]=_emscripten_throw_string;Module["_emscripten_runtime_keepalive_check"]=_emscripten_runtime_keepalive_check;Module["asmjsMangle"]=asmjsMangle;Module["___global_base"]=___global_base;Module["__emscripten_fs_load_embedded_files"]=__emscripten_fs_load_embedded_files;Module["getNativeTypeSize"]=getNativeTypeSize;Module["POINTER_SIZE"]=POINTER_SIZE;Module["onInits"]=onInits;Module["addOnInit"]=addOnInit;Module["onMains"]=onMains;Module["addOnPreMain"]=addOnPreMain;Module["onExits"]=onExits;Module["addOnExit"]=addOnExit;Module["STACK_SIZE"]=STACK_SIZE;Module["STACK_ALIGN"]=STACK_ALIGN;Module["ASSERTIONS"]=ASSERTIONS;Module["getCFunc"]=getCFunc;Module["ccall"]=ccall;Module["writeArrayToMemory"]=writeArrayToMemory;Module["cwrap"]=cwrap;Module["removeFunction"]=removeFunction;Module["_emscripten_math_cbrt"]=_emscripten_math_cbrt;Module["_emscripten_math_pow"]=_emscripten_math_pow;Module["_emscripten_math_random"]=_emscripten_math_random;Module["_emscripten_math_sign"]=_emscripten_math_sign;Module["_emscripten_math_sqrt"]=_emscripten_math_sqrt;Module["_emscripten_math_exp"]=_emscripten_math_exp;Module["_emscripten_math_expm1"]=_emscripten_math_expm1;Module["_emscripten_math_fmod"]=_emscripten_math_fmod;Module["_emscripten_math_log"]=_emscripten_math_log;Module["_emscripten_math_log1p"]=_emscripten_math_log1p;Module["_emscripten_math_log10"]=_emscripten_math_log10;Module["_emscripten_math_log2"]=_emscripten_math_log2;Module["_emscripten_math_round"]=_emscripten_math_round;Module["_emscripten_math_acos"]=_emscripten_math_acos;Module["_emscripten_math_acosh"]=_emscripten_math_acosh;Module["_emscripten_math_asin"]=_emscripten_math_asin;Module["_emscripten_math_asinh"]=_emscripten_math_asinh;Module["_emscripten_math_atan"]=_emscripten_math_atan;Module["_emscripten_math_atanh"]=_emscripten_math_atanh;Module["_emscripten_math_atan2"]=_emscripten_math_atan2;Module["_emscripten_math_cos"]=_emscripten_math_cos;Module["_emscripten_math_cosh"]=_emscripten_math_cosh;Module["_emscripten_math_hypot"]=_emscripten_math_hypot;Module["_emscripten_math_sin"]=_emscripten_math_sin;Module["_emscripten_math_sinh"]=_emscripten_math_sinh;Module["_emscripten_math_tan"]=_emscripten_math_tan;Module["_emscripten_math_tanh"]=_emscripten_math_tanh;Module["intArrayToString"]=intArrayToString;Module["AsciiToString"]=AsciiToString;Module["UTF16Decoder"]=UTF16Decoder;Module["UTF16ToString"]=UTF16ToString;Module["stringToUTF16"]=stringToUTF16;Module["lengthBytesUTF16"]=lengthBytesUTF16;Module["UTF32ToString"]=UTF32ToString;Module["stringToUTF32"]=stringToUTF32;Module["lengthBytesUTF32"]=lengthBytesUTF32;Module["JSEvents"]=JSEvents;Module["registerKeyEventCallback"]=registerKeyEventCallback;Module["findEventTarget"]=findEventTarget;Module["maybeCStringToJsString"]=maybeCStringToJsString;Module["specialHTMLTargets"]=specialHTMLTargets;Module["findCanvasEventTarget"]=findCanvasEventTarget;Module["_emscripten_set_keypress_callback_on_thread"]=_emscripten_set_keypress_callback_on_thread;Module["_emscripten_set_keydown_callback_on_thread"]=_emscripten_set_keydown_callback_on_thread;Module["_emscripten_set_keyup_callback_on_thread"]=_emscripten_set_keyup_callback_on_thread;Module["getBoundingClientRect"]=getBoundingClientRect;Module["fillMouseEventData"]=fillMouseEventData;Module["registerMouseEventCallback"]=registerMouseEventCallback;Module["_emscripten_set_click_callback_on_thread"]=_emscripten_set_click_callback_on_thread;Module["_emscripten_set_mousedown_callback_on_thread"]=_emscripten_set_mousedown_callback_on_thread;Module["_emscripten_set_mouseup_callback_on_thread"]=_emscripten_set_mouseup_callback_on_thread;Module["_emscripten_set_dblclick_callback_on_thread"]=_emscripten_set_dblclick_callback_on_thread;Module["_emscripten_set_mousemove_callback_on_thread"]=_emscripten_set_mousemove_callback_on_thread;Module["_emscripten_set_mouseenter_callback_on_thread"]=_emscripten_set_mouseenter_callback_on_thread;Module["_emscripten_set_mouseleave_callback_on_thread"]=_emscripten_set_mouseleave_callback_on_thread;Module["_emscripten_set_mouseover_callback_on_thread"]=_emscripten_set_mouseover_callback_on_thread;Module["_emscripten_set_mouseout_callback_on_thread"]=_emscripten_set_mouseout_callback_on_thread;Module["_emscripten_get_mouse_status"]=_emscripten_get_mouse_status;Module["registerWheelEventCallback"]=registerWheelEventCallback;Module["_emscripten_set_wheel_callback_on_thread"]=_emscripten_set_wheel_callback_on_thread;Module["registerUiEventCallback"]=registerUiEventCallback;Module["_emscripten_set_resize_callback_on_thread"]=_emscripten_set_resize_callback_on_thread;Module["_emscripten_set_scroll_callback_on_thread"]=_emscripten_set_scroll_callback_on_thread;Module["registerFocusEventCallback"]=registerFocusEventCallback;Module["_emscripten_set_blur_callback_on_thread"]=_emscripten_set_blur_callback_on_thread;Module["_emscripten_set_focus_callback_on_thread"]=_emscripten_set_focus_callback_on_thread;Module["_emscripten_set_focusin_callback_on_thread"]=_emscripten_set_focusin_callback_on_thread;Module["_emscripten_set_focusout_callback_on_thread"]=_emscripten_set_focusout_callback_on_thread;Module["fillDeviceOrientationEventData"]=fillDeviceOrientationEventData;Module["registerDeviceOrientationEventCallback"]=registerDeviceOrientationEventCallback;Module["_emscripten_set_deviceorientation_callback_on_thread"]=_emscripten_set_deviceorientation_callback_on_thread;Module["_emscripten_get_deviceorientation_status"]=_emscripten_get_deviceorientation_status;Module["fillDeviceMotionEventData"]=fillDeviceMotionEventData;Module["registerDeviceMotionEventCallback"]=registerDeviceMotionEventCallback;Module["_emscripten_set_devicemotion_callback_on_thread"]=_emscripten_set_devicemotion_callback_on_thread;Module["_emscripten_get_devicemotion_status"]=_emscripten_get_devicemotion_status;Module["screenOrientation"]=screenOrientation;Module["fillOrientationChangeEventData"]=fillOrientationChangeEventData;Module["registerOrientationChangeEventCallback"]=registerOrientationChangeEventCallback;Module["_emscripten_set_orientationchange_callback_on_thread"]=_emscripten_set_orientationchange_callback_on_thread;Module["_emscripten_get_orientation_status"]=_emscripten_get_orientation_status;Module["_emscripten_lock_orientation"]=_emscripten_lock_orientation;Module["_emscripten_unlock_orientation"]=_emscripten_unlock_orientation;Module["fillFullscreenChangeEventData"]=fillFullscreenChangeEventData;Module["registerFullscreenChangeEventCallback"]=registerFullscreenChangeEventCallback;Module["_emscripten_set_fullscreenchange_callback_on_thread"]=_emscripten_set_fullscreenchange_callback_on_thread;Module["_emscripten_get_fullscreen_status"]=_emscripten_get_fullscreen_status;Module["JSEvents_requestFullscreen"]=JSEvents_requestFullscreen;Module["JSEvents_resizeCanvasForFullscreen"]=JSEvents_resizeCanvasForFullscreen;Module["registerRestoreOldStyle"]=registerRestoreOldStyle;Module["getCanvasElementSize"]=getCanvasElementSize;Module["_emscripten_get_canvas_element_size"]=_emscripten_get_canvas_element_size;Module["setCanvasElementSize"]=setCanvasElementSize;Module["_emscripten_set_canvas_element_size"]=_emscripten_set_canvas_element_size;Module["currentFullscreenStrategy"]=currentFullscreenStrategy;Module["setLetterbox"]=setLetterbox;Module["hideEverythingExceptGivenElement"]=hideEverythingExceptGivenElement;Module["restoreHiddenElements"]=restoreHiddenElements;Module["restoreOldWindowedStyle"]=restoreOldWindowedStyle;Module["softFullscreenResizeWebGLRenderTarget"]=softFullscreenResizeWebGLRenderTarget;Module["doRequestFullscreen"]=doRequestFullscreen;Module["_emscripten_request_fullscreen"]=_emscripten_request_fullscreen;Module["_emscripten_request_fullscreen_strategy"]=_emscripten_request_fullscreen_strategy;Module["_emscripten_enter_soft_fullscreen"]=_emscripten_enter_soft_fullscreen;Module["_emscripten_exit_soft_fullscreen"]=_emscripten_exit_soft_fullscreen;Module["_emscripten_exit_fullscreen"]=_emscripten_exit_fullscreen;Module["fillPointerlockChangeEventData"]=fillPointerlockChangeEventData;Module["registerPointerlockChangeEventCallback"]=registerPointerlockChangeEventCallback;Module["_emscripten_set_pointerlockchange_callback_on_thread"]=_emscripten_set_pointerlockchange_callback_on_thread;Module["registerPointerlockErrorEventCallback"]=registerPointerlockErrorEventCallback;Module["_emscripten_set_pointerlockerror_callback_on_thread"]=_emscripten_set_pointerlockerror_callback_on_thread;Module["_emscripten_get_pointerlock_status"]=_emscripten_get_pointerlock_status;Module["requestPointerLock"]=requestPointerLock;Module["_emscripten_request_pointerlock"]=_emscripten_request_pointerlock;Module["_emscripten_exit_pointerlock"]=_emscripten_exit_pointerlock;Module["_emscripten_vibrate"]=_emscripten_vibrate;Module["_emscripten_vibrate_pattern"]=_emscripten_vibrate_pattern;Module["fillVisibilityChangeEventData"]=fillVisibilityChangeEventData;Module["registerVisibilityChangeEventCallback"]=registerVisibilityChangeEventCallback;Module["_emscripten_set_visibilitychange_callback_on_thread"]=_emscripten_set_visibilitychange_callback_on_thread;Module["_emscripten_get_visibility_status"]=_emscripten_get_visibility_status;Module["registerTouchEventCallback"]=registerTouchEventCallback;Module["_emscripten_set_touchstart_callback_on_thread"]=_emscripten_set_touchstart_callback_on_thread;Module["_emscripten_set_touchend_callback_on_thread"]=_emscripten_set_touchend_callback_on_thread;Module["_emscripten_set_touchmove_callback_on_thread"]=_emscripten_set_touchmove_callback_on_thread;Module["_emscripten_set_touchcancel_callback_on_thread"]=_emscripten_set_touchcancel_callback_on_thread;Module["fillGamepadEventData"]=fillGamepadEventData;Module["registerGamepadEventCallback"]=registerGamepadEventCallback;Module["_emscripten_set_gamepadconnected_callback_on_thread"]=_emscripten_set_gamepadconnected_callback_on_thread;Module["_emscripten_sample_gamepad_data"]=_emscripten_sample_gamepad_data;Module["_emscripten_set_gamepaddisconnected_callback_on_thread"]=_emscripten_set_gamepaddisconnected_callback_on_thread;Module["_emscripten_get_num_gamepads"]=_emscripten_get_num_gamepads;Module["_emscripten_get_gamepad_status"]=_emscripten_get_gamepad_status;Module["registerBeforeUnloadEventCallback"]=registerBeforeUnloadEventCallback;Module["_emscripten_set_beforeunload_callback_on_thread"]=_emscripten_set_beforeunload_callback_on_thread;Module["fillBatteryEventData"]=fillBatteryEventData;Module["battery"]=battery;Module["registerBatteryEventCallback"]=registerBatteryEventCallback;Module["_emscripten_set_batterychargingchange_callback_on_thread"]=_emscripten_set_batterychargingchange_callback_on_thread;Module["_emscripten_set_batterylevelchange_callback_on_thread"]=_emscripten_set_batterylevelchange_callback_on_thread;Module["_emscripten_get_battery_status"]=_emscripten_get_battery_status;Module["_emscripten_set_element_css_size"]=_emscripten_set_element_css_size;Module["_emscripten_get_element_css_size"]=_emscripten_get_element_css_size;Module["_emscripten_html5_remove_all_event_listeners"]=_emscripten_html5_remove_all_event_listeners;Module["_emscripten_request_animation_frame"]=_emscripten_request_animation_frame;Module["_emscripten_cancel_animation_frame"]=_emscripten_cancel_animation_frame;Module["_emscripten_request_animation_frame_loop"]=_emscripten_request_animation_frame_loop;Module["_emscripten_get_device_pixel_ratio"]=_emscripten_get_device_pixel_ratio;Module["_emscripten_get_callstack"]=_emscripten_get_callstack;Module["convertFrameToPC"]=convertFrameToPC;Module["_emscripten_return_address"]=_emscripten_return_address;Module["UNWIND_CACHE"]=UNWIND_CACHE;Module["_emscripten_stack_snapshot"]=_emscripten_stack_snapshot;Module["saveInUnwindCache"]=saveInUnwindCache;Module["_emscripten_stack_unwind_buffer"]=_emscripten_stack_unwind_buffer;Module["_emscripten_pc_get_function"]=_emscripten_pc_get_function;Module["convertPCtoSourceLocation"]=convertPCtoSourceLocation;Module["_emscripten_pc_get_file"]=_emscripten_pc_get_file;Module["_emscripten_pc_get_line"]=_emscripten_pc_get_line;Module["_emscripten_pc_get_column"]=_emscripten_pc_get_column;Module["wasiRightsToMuslOFlags"]=wasiRightsToMuslOFlags;Module["wasiOFlagsToMuslOFlags"]=wasiOFlagsToMuslOFlags;Module["_emscripten_unwind_to_js_event_loop"]=_emscripten_unwind_to_js_event_loop;Module["safeSetTimeout"]=safeSetTimeout;Module["setImmediateWrapped"]=setImmediateWrapped;Module["safeRequestAnimationFrame"]=safeRequestAnimationFrame;Module["MainLoop"]=MainLoop;Module["setMainLoop"]=setMainLoop;Module["_emscripten_set_main_loop_timing"]=_emscripten_set_main_loop_timing;Module["clearImmediateWrapped"]=clearImmediateWrapped;Module["emSetImmediate"]=emSetImmediate;Module["emClearImmediate"]=emClearImmediate;Module["emClearImmediate_deps"]=emClearImmediate_deps;Module["_emscripten_set_immediate"]=_emscripten_set_immediate;Module["_emscripten_clear_immediate"]=_emscripten_clear_immediate;Module["_emscripten_set_immediate_loop"]=_emscripten_set_immediate_loop;Module["_emscripten_set_timeout"]=_emscripten_set_timeout;Module["_emscripten_clear_timeout"]=_emscripten_clear_timeout;Module["_emscripten_set_timeout_loop"]=_emscripten_set_timeout_loop;Module["_emscripten_set_interval"]=_emscripten_set_interval;Module["_emscripten_clear_interval"]=_emscripten_clear_interval;Module["_emscripten_async_call"]=_emscripten_async_call;Module["registerPostMainLoop"]=registerPostMainLoop;Module["registerPreMainLoop"]=registerPreMainLoop;Module["_emscripten_get_main_loop_timing"]=_emscripten_get_main_loop_timing;Module["_emscripten_set_main_loop"]=_emscripten_set_main_loop;Module["_emscripten_set_main_loop_arg"]=_emscripten_set_main_loop_arg;Module["_emscripten_cancel_main_loop"]=_emscripten_cancel_main_loop;Module["_emscripten_pause_main_loop"]=_emscripten_pause_main_loop;Module["_emscripten_resume_main_loop"]=_emscripten_resume_main_loop;Module["__emscripten_push_main_loop_blocker"]=__emscripten_push_main_loop_blocker;Module["__emscripten_push_uncounted_main_loop_blocker"]=__emscripten_push_uncounted_main_loop_blocker;Module["_emscripten_set_main_loop_expected_blockers"]=_emscripten_set_main_loop_expected_blockers;Module["idsToPromises"]=idsToPromises;Module["makePromiseCallback"]=makePromiseCallback;Module["_emscripten_promise_then"]=_emscripten_promise_then;Module["_emscripten_promise_all"]=_emscripten_promise_all;Module["setPromiseResult"]=setPromiseResult;Module["_emscripten_promise_all_settled"]=_emscripten_promise_all_settled;Module["_emscripten_promise_any"]=_emscripten_promise_any;Module["_emscripten_promise_race"]=_emscripten_promise_race;Module["_emscripten_promise_await"]=_emscripten_promise_await;Module["getExceptionMessageCommon"]=getExceptionMessageCommon;Module["getCppExceptionTag"]=getCppExceptionTag;Module["getCppExceptionThrownObjectFromWebAssemblyException"]=getCppExceptionThrownObjectFromWebAssemblyException;Module["incrementExceptionRefcount"]=incrementExceptionRefcount;Module["decrementExceptionRefcount"]=decrementExceptionRefcount;Module["getExceptionMessage"]=getExceptionMessage;Module["Browser"]=Browser;Module["requestFullscreen"]=requestFullscreen;Module["setCanvasSize"]=setCanvasSize;Module["getUserMedia"]=getUserMedia;Module["createContext"]=createContext;Module["_emscripten_run_preload_plugins"]=_emscripten_run_preload_plugins;Module["Browser_asyncPrepareDataCounter"]=Browser_asyncPrepareDataCounter;Module["_emscripten_run_preload_plugins_data"]=_emscripten_run_preload_plugins_data;Module["_emscripten_async_run_script"]=_emscripten_async_run_script;Module["_emscripten_async_load_script"]=_emscripten_async_load_script;Module["_emscripten_get_window_title"]=_emscripten_get_window_title;Module["_emscripten_set_window_title"]=_emscripten_set_window_title;Module["_emscripten_get_screen_size"]=_emscripten_get_screen_size;Module["_emscripten_hide_mouse"]=_emscripten_hide_mouse;Module["_emscripten_set_canvas_size"]=_emscripten_set_canvas_size;Module["_emscripten_get_canvas_size"]=_emscripten_get_canvas_size;Module["_emscripten_create_worker"]=_emscripten_create_worker;Module["_emscripten_destroy_worker"]=_emscripten_destroy_worker;Module["_emscripten_call_worker"]=_emscripten_call_worker;Module["_emscripten_get_worker_queue_size"]=_emscripten_get_worker_queue_size;Module["_emscripten_get_preloaded_image_data"]=_emscripten_get_preloaded_image_data;Module["getPreloadedImageData"]=getPreloadedImageData;Module["getPreloadedImageData__data"]=getPreloadedImageData__data;Module["_emscripten_get_preloaded_image_data_from_FILE"]=_emscripten_get_preloaded_image_data_from_FILE;Module["wget"]=wget;Module["_emscripten_async_wget"]=_emscripten_async_wget;Module["FS_mkdirTree"]=FS_mkdirTree;Module["_emscripten_async_wget_data"]=_emscripten_async_wget_data;Module["_emscripten_async_wget2"]=_emscripten_async_wget2;Module["_emscripten_async_wget2_data"]=_emscripten_async_wget2_data;Module["_emscripten_async_wget2_abort"]=_emscripten_async_wget2_abort;Module["___asctime_r"]=___asctime_r;Module["MONTH_DAYS_REGULAR"]=MONTH_DAYS_REGULAR;Module["MONTH_DAYS_LEAP"]=MONTH_DAYS_LEAP;Module["arraySum"]=arraySum;Module["addDays"]=addDays;Module["_strptime"]=_strptime;Module["_strptime_l"]=_strptime_l;Module["__dlsym_catchup_js"]=__dlsym_catchup_js;Module["FS_readFile"]=FS_readFile;Module["FS_root"]=FS_root;Module["FS_mounts"]=FS_mounts;Module["FS_devices"]=FS_devices;Module["FS_streams"]=FS_streams;Module["FS_nextInode"]=FS_nextInode;Module["FS_nameTable"]=FS_nameTable;Module["FS_currentPath"]=FS_currentPath;Module["FS_initialized"]=FS_initialized;Module["FS_ignorePermissions"]=FS_ignorePermissions;Module["FS_trackingDelegate"]=FS_trackingDelegate;Module["FS_filesystems"]=FS_filesystems;Module["FS_syncFSRequests"]=FS_syncFSRequests;Module["FS_readFiles"]=FS_readFiles;Module["FS_lookupPath"]=FS_lookupPath;Module["FS_getPath"]=FS_getPath;Module["FS_hashName"]=FS_hashName;Module["FS_hashAddNode"]=FS_hashAddNode;Module["FS_hashRemoveNode"]=FS_hashRemoveNode;Module["FS_lookupNode"]=FS_lookupNode;Module["FS_createNode"]=FS_createNode;Module["FS_destroyNode"]=FS_destroyNode;Module["FS_isRoot"]=FS_isRoot;Module["FS_isMountpoint"]=FS_isMountpoint;Module["FS_isFile"]=FS_isFile;Module["FS_isDir"]=FS_isDir;Module["FS_isLink"]=FS_isLink;Module["FS_isChrdev"]=FS_isChrdev;Module["FS_isBlkdev"]=FS_isBlkdev;Module["FS_isFIFO"]=FS_isFIFO;Module["FS_isSocket"]=FS_isSocket;Module["FS_flagsToPermissionString"]=FS_flagsToPermissionString;Module["FS_nodePermissions"]=FS_nodePermissions;Module["FS_mayLookup"]=FS_mayLookup;Module["FS_mayCreate"]=FS_mayCreate;Module["FS_mayDelete"]=FS_mayDelete;Module["FS_mayOpen"]=FS_mayOpen;Module["FS_checkOpExists"]=FS_checkOpExists;Module["FS_nextfd"]=FS_nextfd;Module["FS_getStreamChecked"]=FS_getStreamChecked;Module["FS_getStream"]=FS_getStream;Module["FS_createStream"]=FS_createStream;Module["FS_closeStream"]=FS_closeStream;Module["FS_dupStream"]=FS_dupStream;Module["FS_doSetAttr"]=FS_doSetAttr;Module["FS_chrdev_stream_ops"]=FS_chrdev_stream_ops;Module["FS_major"]=FS_major;Module["FS_minor"]=FS_minor;Module["FS_makedev"]=FS_makedev;Module["FS_registerDevice"]=FS_registerDevice;Module["FS_getDevice"]=FS_getDevice;Module["FS_getMounts"]=FS_getMounts;Module["FS_syncfs"]=FS_syncfs;Module["FS_mount"]=FS_mount;Module["FS_unmount"]=FS_unmount;Module["FS_lookup"]=FS_lookup;Module["FS_mknod"]=FS_mknod;Module["FS_statfs"]=FS_statfs;Module["FS_statfsStream"]=FS_statfsStream;Module["FS_statfsNode"]=FS_statfsNode;Module["FS_create"]=FS_create;Module["FS_mkdir"]=FS_mkdir;Module["FS_mkdev"]=FS_mkdev;Module["FS_symlink"]=FS_symlink;Module["FS_rename"]=FS_rename;Module["FS_rmdir"]=FS_rmdir;Module["FS_readdir"]=FS_readdir;Module["FS_readlink"]=FS_readlink;Module["FS_stat"]=FS_stat;Module["FS_fstat"]=FS_fstat;Module["FS_lstat"]=FS_lstat;Module["FS_doChmod"]=FS_doChmod;Module["FS_chmod"]=FS_chmod;Module["FS_lchmod"]=FS_lchmod;Module["FS_fchmod"]=FS_fchmod;Module["FS_doChown"]=FS_doChown;Module["FS_chown"]=FS_chown;Module["FS_lchown"]=FS_lchown;Module["FS_fchown"]=FS_fchown;Module["FS_doTruncate"]=FS_doTruncate;Module["FS_truncate"]=FS_truncate;Module["FS_ftruncate"]=FS_ftruncate;Module["FS_utime"]=FS_utime;Module["FS_open"]=FS_open;Module["FS_close"]=FS_close;Module["FS_isClosed"]=FS_isClosed;Module["FS_llseek"]=FS_llseek;Module["FS_read"]=FS_read;Module["FS_write"]=FS_write;Module["FS_mmap"]=FS_mmap;Module["FS_msync"]=FS_msync;Module["FS_ioctl"]=FS_ioctl;Module["FS_writeFile"]=FS_writeFile;Module["FS_cwd"]=FS_cwd;Module["FS_chdir"]=FS_chdir;Module["FS_createDefaultDirectories"]=FS_createDefaultDirectories;Module["FS_createDefaultDevices"]=FS_createDefaultDevices;Module["FS_createSpecialDirectories"]=FS_createSpecialDirectories;Module["FS_createStandardStreams"]=FS_createStandardStreams;Module["FS_staticInit"]=FS_staticInit;Module["FS_init"]=FS_init;Module["FS_quit"]=FS_quit;Module["FS_findObject"]=FS_findObject;Module["FS_analyzePath"]=FS_analyzePath;Module["FS_createFile"]=FS_createFile;Module["FS_forceLoadFile"]=FS_forceLoadFile;Module["_setNetworkCallback"]=_setNetworkCallback;Module["_emscripten_set_socket_error_callback"]=_emscripten_set_socket_error_callback;Module["_emscripten_set_socket_open_callback"]=_emscripten_set_socket_open_callback;Module["_emscripten_set_socket_listen_callback"]=_emscripten_set_socket_listen_callback;Module["_emscripten_set_socket_connection_callback"]=_emscripten_set_socket_connection_callback;Module["_emscripten_set_socket_message_callback"]=_emscripten_set_socket_message_callback;Module["_emscripten_set_socket_close_callback"]=_emscripten_set_socket_close_callback;Module["_emscripten_webgl_enable_ANGLE_instanced_arrays"]=_emscripten_webgl_enable_ANGLE_instanced_arrays;Module["_emscripten_webgl_enable_OES_vertex_array_object"]=_emscripten_webgl_enable_OES_vertex_array_object;Module["_emscripten_webgl_enable_WEBGL_draw_buffers"]=_emscripten_webgl_enable_WEBGL_draw_buffers;Module["_emscripten_webgl_enable_WEBGL_multi_draw"]=_emscripten_webgl_enable_WEBGL_multi_draw;Module["_emscripten_webgl_enable_EXT_polygon_offset_clamp"]=_emscripten_webgl_enable_EXT_polygon_offset_clamp;Module["_emscripten_webgl_enable_EXT_clip_control"]=_emscripten_webgl_enable_EXT_clip_control;Module["_emscripten_webgl_enable_WEBGL_polygon_mode"]=_emscripten_webgl_enable_WEBGL_polygon_mode;Module["_glVertexPointer"]=_glVertexPointer;Module["_glMatrixMode"]=_glMatrixMode;Module["_glBegin"]=_glBegin;Module["_glLoadIdentity"]=_glLoadIdentity;Module["_glMultiDrawArrays"]=_glMultiDrawArrays;Module["_glMultiDrawArraysWEBGL"]=_glMultiDrawArraysWEBGL;Module["_glMultiDrawArraysANGLE"]=_glMultiDrawArraysANGLE;Module["_glMultiDrawArraysInstancedANGLE"]=_glMultiDrawArraysInstancedANGLE;Module["_glMultiDrawArraysInstancedWEBGL"]=_glMultiDrawArraysInstancedWEBGL;Module["_glMultiDrawElements"]=_glMultiDrawElements;Module["_glMultiDrawElementsWEBGL"]=_glMultiDrawElementsWEBGL;Module["_glMultiDrawElementsANGLE"]=_glMultiDrawElementsANGLE;Module["_glMultiDrawElementsInstancedANGLE"]=_glMultiDrawElementsInstancedANGLE;Module["_glMultiDrawElementsInstancedWEBGL"]=_glMultiDrawElementsInstancedWEBGL;Module["_glClearDepth"]=_glClearDepth;Module["_glDepthRange"]=_glDepthRange;Module["_emscripten_glVertexPointer"]=_emscripten_glVertexPointer;Module["_emscripten_glMatrixMode"]=_emscripten_glMatrixMode;Module["_emscripten_glBegin"]=_emscripten_glBegin;Module["_emscripten_glLoadIdentity"]=_emscripten_glLoadIdentity;Module["_emscripten_glMultiDrawArrays"]=_emscripten_glMultiDrawArrays;Module["_emscripten_glMultiDrawArraysANGLE"]=_emscripten_glMultiDrawArraysANGLE;Module["_emscripten_glMultiDrawArraysWEBGL"]=_emscripten_glMultiDrawArraysWEBGL;Module["_emscripten_glMultiDrawArraysInstancedANGLE"]=_emscripten_glMultiDrawArraysInstancedANGLE;Module["_emscripten_glMultiDrawArraysInstancedWEBGL"]=_emscripten_glMultiDrawArraysInstancedWEBGL;Module["_emscripten_glMultiDrawElements"]=_emscripten_glMultiDrawElements;Module["_emscripten_glMultiDrawElementsANGLE"]=_emscripten_glMultiDrawElementsANGLE;Module["_emscripten_glMultiDrawElementsWEBGL"]=_emscripten_glMultiDrawElementsWEBGL;Module["_emscripten_glMultiDrawElementsInstancedANGLE"]=_emscripten_glMultiDrawElementsInstancedANGLE;Module["_emscripten_glMultiDrawElementsInstancedWEBGL"]=_emscripten_glMultiDrawElementsInstancedWEBGL;Module["_emscripten_glClearDepth"]=_emscripten_glClearDepth;Module["_emscripten_glDepthRange"]=_emscripten_glDepthRange;Module["_glGetBufferSubData"]=_glGetBufferSubData;Module["_glDrawArraysInstancedBaseInstanceWEBGL"]=_glDrawArraysInstancedBaseInstanceWEBGL;Module["_glDrawArraysInstancedBaseInstance"]=_glDrawArraysInstancedBaseInstance;Module["_glDrawArraysInstancedBaseInstanceANGLE"]=_glDrawArraysInstancedBaseInstanceANGLE;Module["_glDrawElementsInstancedBaseVertexBaseInstanceWEBGL"]=_glDrawElementsInstancedBaseVertexBaseInstanceWEBGL;Module["_glDrawElementsInstancedBaseVertexBaseInstanceANGLE"]=_glDrawElementsInstancedBaseVertexBaseInstanceANGLE;Module["_emscripten_webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance"]=_emscripten_webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance;Module["_glMultiDrawArraysInstancedBaseInstanceWEBGL"]=_glMultiDrawArraysInstancedBaseInstanceWEBGL;Module["_glMultiDrawArraysInstancedBaseInstanceANGLE"]=_glMultiDrawArraysInstancedBaseInstanceANGLE;Module["_glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL"]=_glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL;Module["_glMultiDrawElementsInstancedBaseVertexBaseInstanceANGLE"]=_glMultiDrawElementsInstancedBaseVertexBaseInstanceANGLE;Module["_emscripten_webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance"]=_emscripten_webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance;Module["_emscripten_glGetBufferSubData"]=_emscripten_glGetBufferSubData;Module["_emscripten_glDrawArraysInstancedBaseInstanceWEBGL"]=_emscripten_glDrawArraysInstancedBaseInstanceWEBGL;Module["_emscripten_glDrawArraysInstancedBaseInstance"]=_emscripten_glDrawArraysInstancedBaseInstance;Module["_emscripten_glDrawArraysInstancedBaseInstanceANGLE"]=_emscripten_glDrawArraysInstancedBaseInstanceANGLE;Module["_emscripten_glDrawElementsInstancedBaseVertexBaseInstanceWEBGL"]=_emscripten_glDrawElementsInstancedBaseVertexBaseInstanceWEBGL;Module["_emscripten_glDrawElementsInstancedBaseVertexBaseInstanceANGLE"]=_emscripten_glDrawElementsInstancedBaseVertexBaseInstanceANGLE;Module["_emscripten_glMultiDrawArraysInstancedBaseInstanceWEBGL"]=_emscripten_glMultiDrawArraysInstancedBaseInstanceWEBGL;Module["_emscripten_glMultiDrawArraysInstancedBaseInstanceANGLE"]=_emscripten_glMultiDrawArraysInstancedBaseInstanceANGLE;Module["_emscripten_glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL"]=_emscripten_glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL;Module["_emscripten_glMultiDrawElementsInstancedBaseVertexBaseInstanceANGLE"]=_emscripten_glMultiDrawElementsInstancedBaseVertexBaseInstanceANGLE;Module["ALLOC_NORMAL"]=ALLOC_NORMAL;Module["ALLOC_STACK"]=ALLOC_STACK;Module["allocate"]=allocate;Module["writeStringToMemory"]=writeStringToMemory;Module["writeAsciiToMemory"]=writeAsciiToMemory;Module["allocateUTF8"]=allocateUTF8;Module["allocateUTF8OnStack"]=allocateUTF8OnStack;Module["demangle"]=demangle;Module["stackTrace"]=stackTrace;Module["print"]=print;Module["printErr"]=printErr;Module["jstoi_s"]=jstoi_s;Module["_emscripten_is_main_browser_thread"]=_emscripten_is_main_browser_thread;Module["webSockets"]=webSockets;Module["WS"]=WS;Module["_emscripten_websocket_get_ready_state"]=_emscripten_websocket_get_ready_state;Module["_emscripten_websocket_get_buffered_amount"]=_emscripten_websocket_get_buffered_amount;Module["_emscripten_websocket_get_extensions"]=_emscripten_websocket_get_extensions;Module["_emscripten_websocket_get_extensions_length"]=_emscripten_websocket_get_extensions_length;Module["_emscripten_websocket_get_protocol"]=_emscripten_websocket_get_protocol;Module["_emscripten_websocket_get_protocol_length"]=_emscripten_websocket_get_protocol_length;Module["_emscripten_websocket_get_url"]=_emscripten_websocket_get_url;Module["_emscripten_websocket_get_url_length"]=_emscripten_websocket_get_url_length;Module["_emscripten_websocket_set_onopen_callback_on_thread"]=_emscripten_websocket_set_onopen_callback_on_thread;Module["_emscripten_websocket_set_onerror_callback_on_thread"]=_emscripten_websocket_set_onerror_callback_on_thread;Module["_emscripten_websocket_set_onclose_callback_on_thread"]=_emscripten_websocket_set_onclose_callback_on_thread;Module["_emscripten_websocket_set_onmessage_callback_on_thread"]=_emscripten_websocket_set_onmessage_callback_on_thread;Module["_emscripten_websocket_new"]=_emscripten_websocket_new;Module["_emscripten_websocket_send_utf8_text"]=_emscripten_websocket_send_utf8_text;Module["_emscripten_websocket_send_binary"]=_emscripten_websocket_send_binary;Module["_emscripten_websocket_close"]=_emscripten_websocket_close;Module["_emscripten_websocket_delete"]=_emscripten_websocket_delete;Module["_emscripten_websocket_is_supported"]=_emscripten_websocket_is_supported;Module["_emscripten_websocket_deinitialize"]=_emscripten_websocket_deinitialize;Module["writeGLArray"]=writeGLArray;Module["webglPowerPreferences"]=webglPowerPreferences;Module["_emscripten_webgl_create_context"]=_emscripten_webgl_create_context;Module["_emscripten_webgl_do_create_context"]=_emscripten_webgl_do_create_context;Module["_emscripten_webgl_get_current_context"]=_emscripten_webgl_get_current_context;Module["_emscripten_webgl_do_get_current_context"]=_emscripten_webgl_do_get_current_context;Module["_emscripten_webgl_commit_frame"]=_emscripten_webgl_commit_frame;Module["_emscripten_webgl_do_commit_frame"]=_emscripten_webgl_do_commit_frame;Module["_emscripten_webgl_make_context_current"]=_emscripten_webgl_make_context_current;Module["_emscripten_webgl_get_drawing_buffer_size"]=_emscripten_webgl_get_drawing_buffer_size;Module["_emscripten_webgl_get_context_attributes"]=_emscripten_webgl_get_context_attributes;Module["_emscripten_webgl_destroy_context"]=_emscripten_webgl_destroy_context;Module["_emscripten_webgl_enable_extension"]=_emscripten_webgl_enable_extension;Module["_emscripten_supports_offscreencanvas"]=_emscripten_supports_offscreencanvas;Module["registerWebGlEventCallback"]=registerWebGlEventCallback;Module["_emscripten_set_webglcontextlost_callback_on_thread"]=_emscripten_set_webglcontextlost_callback_on_thread;Module["_emscripten_set_webglcontextrestored_callback_on_thread"]=_emscripten_set_webglcontextrestored_callback_on_thread;Module["_emscripten_is_webgl_context_lost"]=_emscripten_is_webgl_context_lost;Module["_emscripten_webgl_get_supported_extensions"]=_emscripten_webgl_get_supported_extensions;Module["_emscripten_webgl_get_program_parameter_d"]=_emscripten_webgl_get_program_parameter_d;Module["_emscripten_webgl_get_program_info_log_utf8"]=_emscripten_webgl_get_program_info_log_utf8;Module["_emscripten_webgl_get_shader_parameter_d"]=_emscripten_webgl_get_shader_parameter_d;Module["_emscripten_webgl_get_shader_info_log_utf8"]=_emscripten_webgl_get_shader_info_log_utf8;Module["_emscripten_webgl_get_shader_source_utf8"]=_emscripten_webgl_get_shader_source_utf8;Module["_emscripten_webgl_get_vertex_attrib_d"]=_emscripten_webgl_get_vertex_attrib_d;Module["_emscripten_webgl_get_vertex_attrib_o"]=_emscripten_webgl_get_vertex_attrib_o;Module["_emscripten_webgl_get_vertex_attrib_v"]=_emscripten_webgl_get_vertex_attrib_v;Module["_emscripten_webgl_get_uniform_d"]=_emscripten_webgl_get_uniform_d;Module["_emscripten_webgl_get_uniform_v"]=_emscripten_webgl_get_uniform_v;Module["_emscripten_webgl_get_parameter_v"]=_emscripten_webgl_get_parameter_v;Module["_emscripten_webgl_get_parameter_d"]=_emscripten_webgl_get_parameter_d;Module["_emscripten_webgl_get_parameter_o"]=_emscripten_webgl_get_parameter_o;Module["_emscripten_webgl_get_parameter_utf8"]=_emscripten_webgl_get_parameter_utf8;Module["_emscripten_webgl_get_parameter_i64v"]=_emscripten_webgl_get_parameter_i64v;Module["EGL"]=EGL;Module["_eglGetDisplay"]=_eglGetDisplay;Module["_eglInitialize"]=_eglInitialize;Module["_eglTerminate"]=_eglTerminate;Module["_eglGetConfigs"]=_eglGetConfigs;Module["_eglChooseConfig"]=_eglChooseConfig;Module["_eglGetConfigAttrib"]=_eglGetConfigAttrib;Module["_eglCreateWindowSurface"]=_eglCreateWindowSurface;Module["_eglDestroySurface"]=_eglDestroySurface;Module["_eglCreateContext"]=_eglCreateContext;Module["_eglDestroyContext"]=_eglDestroyContext;Module["_eglQuerySurface"]=_eglQuerySurface;Module["_eglQueryContext"]=_eglQueryContext;Module["_eglGetError"]=_eglGetError;Module["_eglQueryString"]=_eglQueryString;Module["_eglBindAPI"]=_eglBindAPI;Module["_eglQueryAPI"]=_eglQueryAPI;Module["_eglWaitClient"]=_eglWaitClient;Module["_eglWaitNative"]=_eglWaitNative;Module["_eglWaitGL"]=_eglWaitGL;Module["_eglSwapInterval"]=_eglSwapInterval;Module["_eglMakeCurrent"]=_eglMakeCurrent;Module["_eglGetCurrentContext"]=_eglGetCurrentContext;Module["_eglGetCurrentSurface"]=_eglGetCurrentSurface;Module["_eglGetCurrentDisplay"]=_eglGetCurrentDisplay;Module["_eglSwapBuffers"]=_eglSwapBuffers;Module["_eglReleaseThread"]=_eglReleaseThread;Module["SDL"]=SDL;Module["_SDL_GetTicks"]=_SDL_GetTicks;Module["_SDL_LockSurface"]=_SDL_LockSurface;Module["_SDL_Linked_Version"]=_SDL_Linked_Version;Module["_SDL_Init"]=_SDL_Init;Module["_SDL_WasInit"]=_SDL_WasInit;Module["_SDL_GetVideoInfo"]=_SDL_GetVideoInfo;Module["_SDL_ListModes"]=_SDL_ListModes;Module["_SDL_VideoModeOK"]=_SDL_VideoModeOK;Module["_SDL_AudioDriverName"]=_SDL_AudioDriverName;Module["_SDL_VideoDriverName"]=_SDL_VideoDriverName;Module["_SDL_SetVideoMode"]=_SDL_SetVideoMode;Module["_SDL_GetVideoSurface"]=_SDL_GetVideoSurface;Module["_SDL_AudioQuit"]=_SDL_AudioQuit;Module["_SDL_VideoQuit"]=_SDL_VideoQuit;Module["_SDL_QuitSubSystem"]=_SDL_QuitSubSystem;Module["_SDL_Quit"]=_SDL_Quit;Module["_SDL_UnlockSurface"]=_SDL_UnlockSurface;Module["_SDL_Flip"]=_SDL_Flip;Module["_SDL_UpdateRect"]=_SDL_UpdateRect;Module["_SDL_UpdateRects"]=_SDL_UpdateRects;Module["_SDL_Delay"]=_SDL_Delay;Module["_SDL_WM_SetCaption"]=_SDL_WM_SetCaption;Module["_SDL_EnableKeyRepeat"]=_SDL_EnableKeyRepeat;Module["_SDL_GetKeyboardState"]=_SDL_GetKeyboardState;Module["_SDL_GetKeyState"]=_SDL_GetKeyState;Module["_SDL_GetKeyName"]=_SDL_GetKeyName;Module["_SDL_GetModState"]=_SDL_GetModState;Module["_SDL_GetMouseState"]=_SDL_GetMouseState;Module["_SDL_WarpMouse"]=_SDL_WarpMouse;Module["_SDL_ShowCursor"]=_SDL_ShowCursor;Module["_SDL_GetError"]=_SDL_GetError;Module["_SDL_SetError"]=_SDL_SetError;Module["_SDL_CreateRGBSurface"]=_SDL_CreateRGBSurface;Module["_SDL_CreateRGBSurfaceFrom"]=_SDL_CreateRGBSurfaceFrom;Module["_SDL_ConvertSurface"]=_SDL_ConvertSurface;Module["_SDL_DisplayFormat"]=_SDL_DisplayFormat;Module["_SDL_DisplayFormatAlpha"]=_SDL_DisplayFormatAlpha;Module["_SDL_FreeSurface"]=_SDL_FreeSurface;Module["_SDL_UpperBlit"]=_SDL_UpperBlit;Module["_SDL_UpperBlitScaled"]=_SDL_UpperBlitScaled;Module["_SDL_LowerBlit"]=_SDL_LowerBlit;Module["_SDL_LowerBlitScaled"]=_SDL_LowerBlitScaled;Module["_SDL_GetClipRect"]=_SDL_GetClipRect;Module["_SDL_SetClipRect"]=_SDL_SetClipRect;Module["_SDL_FillRect"]=_SDL_FillRect;Module["_zoomSurface"]=_zoomSurface;Module["_rotozoomSurface"]=_rotozoomSurface;Module["_SDL_SetAlpha"]=_SDL_SetAlpha;Module["_SDL_SetColorKey"]=_SDL_SetColorKey;Module["_SDL_PollEvent"]=_SDL_PollEvent;Module["_SDL_PushEvent"]=_SDL_PushEvent;Module["_SDL_PeepEvents"]=_SDL_PeepEvents;Module["_SDL_PumpEvents"]=_SDL_PumpEvents;Module["_emscripten_SDL_SetEventHandler"]=_emscripten_SDL_SetEventHandler;Module["_SDL_SetColors"]=_SDL_SetColors;Module["_SDL_SetPalette"]=_SDL_SetPalette;Module["_SDL_MapRGB"]=_SDL_MapRGB;Module["_SDL_MapRGBA"]=_SDL_MapRGBA;Module["_SDL_GetRGB"]=_SDL_GetRGB;Module["_SDL_GetRGBA"]=_SDL_GetRGBA;Module["_SDL_GetAppState"]=_SDL_GetAppState;Module["_SDL_WM_GrabInput"]=_SDL_WM_GrabInput;Module["_SDL_WM_ToggleFullScreen"]=_SDL_WM_ToggleFullScreen;Module["_IMG_Init"]=_IMG_Init;Module["_IMG_Load_RW"]=_IMG_Load_RW;Module["_SDL_FreeRW"]=_SDL_FreeRW;Module["_SDL_LoadBMP_RW"]=_SDL_LoadBMP_RW;Module["_IMG_Load"]=_IMG_Load;Module["_SDL_RWFromFile"]=_SDL_RWFromFile;Module["_IMG_Quit"]=_IMG_Quit;Module["_SDL_OpenAudio"]=_SDL_OpenAudio;Module["_SDL_PauseAudio"]=_SDL_PauseAudio;Module["_SDL_CloseAudio"]=_SDL_CloseAudio;Module["_SDL_LockAudio"]=_SDL_LockAudio;Module["_SDL_UnlockAudio"]=_SDL_UnlockAudio;Module["_SDL_CreateMutex"]=_SDL_CreateMutex;Module["_SDL_mutexP"]=_SDL_mutexP;Module["_SDL_mutexV"]=_SDL_mutexV;Module["_SDL_DestroyMutex"]=_SDL_DestroyMutex;Module["_SDL_CreateCond"]=_SDL_CreateCond;Module["_SDL_CondSignal"]=_SDL_CondSignal;Module["_SDL_CondWait"]=_SDL_CondWait;Module["_SDL_DestroyCond"]=_SDL_DestroyCond;Module["_SDL_StartTextInput"]=_SDL_StartTextInput;Module["_SDL_StopTextInput"]=_SDL_StopTextInput;Module["_Mix_Init"]=_Mix_Init;Module["_Mix_Quit"]=_Mix_Quit;Module["_Mix_OpenAudio"]=_Mix_OpenAudio;Module["_Mix_CloseAudio"]=_Mix_CloseAudio;Module["_Mix_AllocateChannels"]=_Mix_AllocateChannels;Module["_Mix_ChannelFinished"]=_Mix_ChannelFinished;Module["_Mix_Volume"]=_Mix_Volume;Module["_Mix_SetPanning"]=_Mix_SetPanning;Module["_Mix_LoadWAV_RW"]=_Mix_LoadWAV_RW;Module["_Mix_LoadWAV"]=_Mix_LoadWAV;Module["_Mix_QuickLoad_RAW"]=_Mix_QuickLoad_RAW;Module["_Mix_FreeChunk"]=_Mix_FreeChunk;Module["_Mix_ReserveChannels"]=_Mix_ReserveChannels;Module["_Mix_PlayChannelTimed"]=_Mix_PlayChannelTimed;Module["_Mix_HaltChannel"]=_Mix_HaltChannel;Module["_Mix_FadingChannel"]=_Mix_FadingChannel;Module["_Mix_HookMusicFinished"]=_Mix_HookMusicFinished;Module["_Mix_HaltMusic"]=_Mix_HaltMusic;Module["_Mix_VolumeMusic"]=_Mix_VolumeMusic;Module["_Mix_LoadMUS_RW"]=_Mix_LoadMUS_RW;Module["_Mix_LoadMUS"]=_Mix_LoadMUS;Module["_Mix_FreeMusic"]=_Mix_FreeMusic;Module["_Mix_PlayMusic"]=_Mix_PlayMusic;Module["_Mix_PauseMusic"]=_Mix_PauseMusic;Module["_Mix_ResumeMusic"]=_Mix_ResumeMusic;Module["_Mix_FadeInMusicPos"]=_Mix_FadeInMusicPos;Module["_Mix_FadeOutMusic"]=_Mix_FadeOutMusic;Module["_Mix_PlayingMusic"]=_Mix_PlayingMusic;Module["_Mix_Playing"]=_Mix_Playing;Module["_Mix_Pause"]=_Mix_Pause;Module["_Mix_Paused"]=_Mix_Paused;Module["_Mix_PausedMusic"]=_Mix_PausedMusic;Module["_Mix_Resume"]=_Mix_Resume;Module["_TTF_Init"]=_TTF_Init;Module["_TTF_OpenFont"]=_TTF_OpenFont;Module["_TTF_CloseFont"]=_TTF_CloseFont;Module["_TTF_RenderText_Solid"]=_TTF_RenderText_Solid;Module["_TTF_RenderText_Blended"]=_TTF_RenderText_Blended;Module["_TTF_RenderText_Shaded"]=_TTF_RenderText_Shaded;Module["_TTF_RenderUTF8_Solid"]=_TTF_RenderUTF8_Solid;Module["_TTF_SizeUTF8"]=_TTF_SizeUTF8;Module["_TTF_SizeText"]=_TTF_SizeText;Module["_TTF_GlyphMetrics"]=_TTF_GlyphMetrics;Module["_TTF_FontAscent"]=_TTF_FontAscent;Module["_TTF_FontDescent"]=_TTF_FontDescent;Module["_TTF_FontHeight"]=_TTF_FontHeight;Module["_TTF_FontLineSkip"]=_TTF_FontLineSkip;Module["_TTF_Quit"]=_TTF_Quit;Module["SDL_gfx"]=SDL_gfx;Module["_boxColor"]=_boxColor;Module["_boxRGBA"]=_boxRGBA;Module["_rectangleColor"]=_rectangleColor;Module["_rectangleRGBA"]=_rectangleRGBA;Module["_ellipseColor"]=_ellipseColor;Module["_ellipseRGBA"]=_ellipseRGBA;Module["_filledEllipseColor"]=_filledEllipseColor;Module["_filledEllipseRGBA"]=_filledEllipseRGBA;Module["_lineColor"]=_lineColor;Module["_lineRGBA"]=_lineRGBA;Module["_pixelRGBA"]=_pixelRGBA;Module["_SDL_GL_SetAttribute"]=_SDL_GL_SetAttribute;Module["_SDL_GL_GetAttribute"]=_SDL_GL_GetAttribute;Module["_SDL_GL_SwapBuffers"]=_SDL_GL_SwapBuffers;Module["_SDL_GL_ExtensionSupported"]=_SDL_GL_ExtensionSupported;Module["_SDL_DestroyWindow"]=_SDL_DestroyWindow;Module["_SDL_DestroyRenderer"]=_SDL_DestroyRenderer;Module["_SDL_GetWindowFlags"]=_SDL_GetWindowFlags;Module["_SDL_GL_SwapWindow"]=_SDL_GL_SwapWindow;Module["_SDL_GL_MakeCurrent"]=_SDL_GL_MakeCurrent;Module["_SDL_GL_DeleteContext"]=_SDL_GL_DeleteContext;Module["_SDL_GL_GetSwapInterval"]=_SDL_GL_GetSwapInterval;Module["_SDL_GL_SetSwapInterval"]=_SDL_GL_SetSwapInterval;Module["_SDL_SetWindowTitle"]=_SDL_SetWindowTitle;Module["_SDL_GetWindowSize"]=_SDL_GetWindowSize;Module["_SDL_LogSetOutputFunction"]=_SDL_LogSetOutputFunction;Module["_SDL_SetWindowFullscreen"]=_SDL_SetWindowFullscreen;Module["_SDL_ClearError"]=_SDL_ClearError;Module["_SDL_SetGamma"]=_SDL_SetGamma;Module["_SDL_SetGammaRamp"]=_SDL_SetGammaRamp;Module["_SDL_NumJoysticks"]=_SDL_NumJoysticks;Module["_SDL_JoystickName"]=_SDL_JoystickName;Module["_SDL_JoystickOpen"]=_SDL_JoystickOpen;Module["_SDL_JoystickOpened"]=_SDL_JoystickOpened;Module["_SDL_JoystickIndex"]=_SDL_JoystickIndex;Module["_SDL_JoystickNumAxes"]=_SDL_JoystickNumAxes;Module["_SDL_JoystickNumBalls"]=_SDL_JoystickNumBalls;Module["_SDL_JoystickNumHats"]=_SDL_JoystickNumHats;Module["_SDL_JoystickNumButtons"]=_SDL_JoystickNumButtons;Module["_SDL_JoystickUpdate"]=_SDL_JoystickUpdate;Module["_SDL_JoystickEventState"]=_SDL_JoystickEventState;Module["_SDL_JoystickGetAxis"]=_SDL_JoystickGetAxis;Module["_SDL_JoystickGetHat"]=_SDL_JoystickGetHat;Module["_SDL_JoystickGetBall"]=_SDL_JoystickGetBall;Module["_SDL_JoystickGetButton"]=_SDL_JoystickGetButton;Module["_SDL_JoystickClose"]=_SDL_JoystickClose;Module["_SDL_InitSubSystem"]=_SDL_InitSubSystem;Module["_SDL_RWFromConstMem"]=_SDL_RWFromConstMem;Module["_SDL_RWFromMem"]=_SDL_RWFromMem;Module["_SDL_GetNumAudioDrivers"]=_SDL_GetNumAudioDrivers;Module["_SDL_GetCurrentAudioDriver"]=_SDL_GetCurrentAudioDriver;Module["_SDL_GetScancodeFromKey"]=_SDL_GetScancodeFromKey;Module["_SDL_GetAudioDriver"]=_SDL_GetAudioDriver;Module["_SDL_EnableUNICODE"]=_SDL_EnableUNICODE;Module["_SDL_AddTimer"]=_SDL_AddTimer;Module["_SDL_RemoveTimer"]=_SDL_RemoveTimer;Module["_SDL_CreateThread"]=_SDL_CreateThread;Module["_SDL_WaitThread"]=_SDL_WaitThread;Module["_SDL_GetThreadID"]=_SDL_GetThreadID;Module["_SDL_ThreadID"]=_SDL_ThreadID;Module["_SDL_AllocRW"]=_SDL_AllocRW;Module["_SDL_CondBroadcast"]=_SDL_CondBroadcast;Module["_SDL_CondWaitTimeout"]=_SDL_CondWaitTimeout;Module["_SDL_WM_IconifyWindow"]=_SDL_WM_IconifyWindow;Module["_Mix_SetPostMix"]=_Mix_SetPostMix;Module["_Mix_VolumeChunk"]=_Mix_VolumeChunk;Module["_Mix_SetPosition"]=_Mix_SetPosition;Module["_Mix_QuerySpec"]=_Mix_QuerySpec;Module["_Mix_FadeInChannelTimed"]=_Mix_FadeInChannelTimed;Module["_Mix_FadeOutChannel"]=_Mix_FadeOutChannel;Module["_Mix_Linked_Version"]=_Mix_Linked_Version;Module["_SDL_SaveBMP_RW"]=_SDL_SaveBMP_RW;Module["_SDL_WM_SetIcon"]=_SDL_WM_SetIcon;Module["_SDL_HasRDTSC"]=_SDL_HasRDTSC;Module["_SDL_HasMMX"]=_SDL_HasMMX;Module["_SDL_HasMMXExt"]=_SDL_HasMMXExt;Module["_SDL_Has3DNow"]=_SDL_Has3DNow;Module["_SDL_Has3DNowExt"]=_SDL_Has3DNowExt;Module["_SDL_HasSSE"]=_SDL_HasSSE;Module["_SDL_HasSSE2"]=_SDL_HasSSE2;Module["_SDL_HasAltiVec"]=_SDL_HasAltiVec;var ASM_CONSTS={3473994:()=>{throw new Error("intentionally triggered fatal error!")},3474051:()=>{wasmImports["open64"]=wasmImports["open"]},3474100:()=>jspiSupported};function console_error(msg){let jsmsg=UTF8ToString(msg);console.error(jsmsg)}function console_error_obj(obj){console.error(obj)}function new_error(type,msg,err){return new API.PythonError(UTF8ToString(type),msg,err)}new_error.sig="eiei";function fail_test(){API.fail_test=true}fail_test.sig="v";function capture_stderr(){API.capture_stderr()}capture_stderr.sig="v";function restore_stderr(){return API.restore_stderr()}restore_stderr.sig="e";function raw_call_js(func){func()}raw_call_js.sig="ve";function hiwire_invalid_ref_js(type,ref){API.fail_test=!!1;if(type===1&&!ref){if(_PyErr_Occurred()){const e=_wrap_exception();console.error("Pyodide internal error: Argument to hiwire_get is falsy. This was "+"probably because the Python error indicator was set when get_value was "+"called. The Python error that caused this was:",e);throw e}else{const msg="Pyodide internal error: Argument to hiwire_get is falsy (but error "+"indicator is not set).";console.error(msg);throw new Error(msg)}}const typestr={[1]:"get",[2]:"incref",[3]:"decref"}[type];const msg=`hiwire_${typestr} on invalid reference ${ref}. This is most likely due `+"to use after free. It may also be due to memory corruption.";console.error(msg);throw new Error(msg)}hiwire_invalid_ref_js.sig="vii";function set_pyodide_module(mod){API._pyodide=mod}set_pyodide_module.sig="ve";function js2python_immutable_js(value){try{let result=Module.js2python_convertImmutable(value);if(result!==undefined){return result}return 0}catch(e){Module.handle_js_error(e);return 0}errNoRet()}js2python_immutable_js.sig="ie";function js2python_js(value){try{let result=Module.js2python_convertImmutable(value);if(result!==undefined){return result}return _JsProxy_create(value)}catch(e){Module.handle_js_error(e);return 0}errNoRet()}js2python_js.sig="ie";function js2python_convert(v,depth,defaultConverter){try{return Module.js2python_convert(v,{depth,defaultConverter})}catch(e){Module.handle_js_error(e);return 0}errNoRet()}js2python_convert.sig="ieie";function isReservedWord(word){if(!Module.pythonReservedWords){Module.pythonReservedWords=new Set(["False","await","else","import","pass","None","break","except","in","raise","True","class","finally","is","return","and","continue","for","lambda","try","as","def","from","nonlocal","while","assert","del","global","not","with","async","elif","if","or","yield"])}return Module.pythonReservedWords.has(word)}function normalizeReservedWords(word){const noTrailing_=word.replace(/_*$/,"");if(!isReservedWord(noTrailing_)){return word}if(noTrailing_!==word){return word.slice(0,-1)}return word}function JsProxy_GetAttr_js(jsobj,ptrkey){try{const jskey=normalizeReservedWords(UTF8ToString(ptrkey));const result=jsobj[jskey];if(result===undefined&&!(jskey in jsobj)){return Module.error}return result}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsProxy_GetAttr_js.sig="eei";function JsProxy_SetAttr_js(jsobj,ptrkey,jsval){try{let jskey=normalizeReservedWords(UTF8ToString(ptrkey));jsobj[jskey]=jsval}catch(e){Module.handle_js_error(e);return-1}return 0}JsProxy_SetAttr_js.sig="ieie";function JsProxy_DelAttr_js(jsobj,ptrkey){try{let jskey=normalizeReservedWords(UTF8ToString(ptrkey));delete jsobj[jskey]}catch(e){Module.handle_js_error(e);return-1}return 0}JsProxy_DelAttr_js.sig="iei";function JsProxy_GetIter_js(obj){try{return obj[Symbol.iterator]()}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsProxy_GetIter_js.sig="ee";function handle_next_result_js(res,done,msg){try{let errmsg;if(typeof res!=="object"){errmsg=`Result should have type "object" not "${typeof res}"`}else if(typeof res.done==="undefined"){if(typeof res.then==="function"){errmsg=`Result was a promise, use anext() / asend() / athrow() instead.`}else{errmsg=`Result has no "done" field.`}}if(errmsg){HEAPU32[(msg>>2)+0>>>0]=stringToNewUTF8(errmsg);HEAPU32[(done>>2)+0>>>0]=-1}HEAPU32[(done>>2)+0>>>0]=res.done;return res.value}catch(e){Module.handle_js_error(e);return-1}return 0}handle_next_result_js.sig="eeii";function JsException_new_helper(name_ptr,message_ptr,stack_ptr){try{let name=UTF8ToString(name_ptr);let message=UTF8ToString(message_ptr);let stack=UTF8ToString(stack_ptr);return API.deserializeError(name,message,stack)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsException_new_helper.sig="eiii";function JsProxy_GetAsyncIter_js(obj){try{return obj[Symbol.asyncIterator]()}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsProxy_GetAsyncIter_js.sig="ee";function _agen_handle_result_js(p,msg,set_result,set_exception,closing){try{let errmsg;if(typeof p!=="object"){errmsg=`Result of anext() should be object not ${typeof p}`}else if(typeof p.then!=="function"){if(typeof p.done==="boolean"){errmsg=`Result of anext() was not a promise, use next() instead.`}else{errmsg=`Result of anext() was not a promise.`}}if(errmsg){HEAPU32[(msg>>2)+0>>>0]=stringToNewUTF8(errmsg);return-1}_Py_IncRef(set_result);_Py_IncRef(set_exception);p.then(({done,value})=>{__agen_handle_result_js_c(set_result,set_exception,done,value,closing)},err=>{__agen_handle_result_js_c(set_result,set_exception,-1,err,closing)}).finally(()=>{_Py_DecRef(set_result);_Py_DecRef(set_exception)});return 0}catch(e){Module.handle_js_error(e);return-1}return 0}_agen_handle_result_js.sig="ieiiii";function get_length_helper(val){try{let result;if(typeof val.size==="number"){result=val.size}else if(typeof val.length==="number"){result=val.length}else{return-2}if(result<0){return-3}if(result>2147483647){return-4}return result}catch(e){Module.handle_js_error(e);return-1}return 0}get_length_helper.sig="ie";function get_length_string(val){try{let result;if(typeof val.size==="number"){result=val.size}else if(typeof val.length==="number"){result=val.length}return stringToNewUTF8(" "+result.toString())}catch(e){Module.handle_js_error(e);return 0}errNoRet()}get_length_string.sig="ie";function destroy_jsarray_entries(array){for(let v of array){try{if(typeof v.destroy==="function"){v.destroy()}}catch(e){console.warn("Weird error:",e)}}}destroy_jsarray_entries.sig="ve";function JsArray_repeat_js(o,count){try{return Array.from({length:count},()=>o).flat()}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsArray_repeat_js.sig="eei";function JsArray_inplace_repeat_js(o,count){try{o.splice(0,o.length,...Array.from({length:count},()=>o).flat())}catch(e){Module.handle_js_error(e);return-1}return 0}JsArray_inplace_repeat_js.sig="iei";function JsArray_reversed_iterator(array){return new ReversedIterator(array)}class ReversedIterator{constructor(array){this._array=array;this._i=array.length-1}__length_hint__(){return this._array.length}[Symbol.toStringTag](){return"ReverseIterator"}next(){const i=this._i;const a=this._array;const done=i<0;const value=done?undefined:a[i];this._i--;return{done,value}}}JsArray_reversed_iterator.sig="ee";function JsArray_index_js(o,v,start,stop){try{for(let i=start;i{let c=s.charCodeAt(0);return c<48||c>57}).map(word=>isReservedWord(word.replace(/_*$/,""))?word+"_":word))}while(jsobj=Object.getPrototypeOf(jsobj));return result}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsProxy_Dir_js.sig="ee";function JsProxy_Bool_js(val){try{if(!val){return!!0}if(val.size===0){if(/HTML[A-Za-z]*Element/.test(getTypeTag(val))){return!!1}return!!0}if(val.length===0&&JsvArray_Check(val)){return!!0}if(val.byteLength===0){return!!0}return!!1}catch(e){return!!0}}JsProxy_Bool_js.sig="ie";function JsObjMap_GetIter_js(obj){try{return Module.iterObject(obj)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsObjMap_GetIter_js.sig="ee";function JsObjMap_length_js(obj){try{let length=0;for(let _ of Module.iterObject(obj)){length++}return length}catch(e){Module.handle_js_error(e);return-1}return 0}JsObjMap_length_js.sig="ie";function JsObjMap_subscript_js(obj,key){try{if(!Object.prototype.hasOwnProperty.call(obj,key)){return Module.error}return obj[key]}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsObjMap_subscript_js.sig="eee";function JsObjMap_ass_subscript_js(obj,key,value){try{if(value===Module.error){if(!Object.prototype.hasOwnProperty.call(obj,key)){return-1}delete obj[key]}else{obj[key]=value}return 0}catch(e){Module.handle_js_error(e);return-1}return 0}JsObjMap_ass_subscript_js.sig="ieee";function JsObjMap_contains_js(obj,key){try{return Object.prototype.hasOwnProperty.call(obj,key)}catch(e){Module.handle_js_error(e);return-1}return 0}JsObjMap_contains_js.sig="iee";function JsModule_GetAll_js(o){try{return Object.getOwnPropertyNames(o)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsModule_GetAll_js.sig="ee";function JsBuffer_DecodeString_js(buffer,encoding){try{let encoding_js;if(encoding){encoding_js=UTF8ToString(encoding)}const decoder=new TextDecoder(encoding_js,{fatal:!!1,ignoreBOM:!!1});let res;try{res=decoder.decode(buffer)}catch(e){if(e instanceof TypeError){return Module.error}throw e}return res}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsBuffer_DecodeString_js.sig="eei";function JsBuffer_get_info(jsobj,byteLength_ptr,format_ptr,size_ptr,checked_ptr){const[format_utf8,size,checked]=Module.get_buffer_datatype(jsobj);HEAPU32[(byteLength_ptr>>2)+0>>>0]=jsobj.byteLength;HEAPU32[(format_ptr>>2)+0>>>0]=format_utf8;HEAPU32[(size_ptr>>2)+0>>>0]=size;HEAPU8[checked_ptr+0>>>0]=checked}JsBuffer_get_info.sig="veiiii";function JsDoubleProxy_unwrap_js(id){try{return Module.PyProxy_getPtr(id)}catch(e){Module.handle_js_error(e);return 0}errNoRet()}JsDoubleProxy_unwrap_js.sig="ie";function JsProxy_to_weakref_js(pyproxy){try{return new WeakRef(pyproxy)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsProxy_to_weakref_js.sig="ee";function JsProxy_compute_typeflags(obj,is_py_json){try{let type_flags=0;if(API.isPyProxy(obj)&&!pyproxyIsAlive(obj)){return 0}const typeTag=getTypeTag(obj);function safeBool(cb){try{return cb()}catch(e){return!!0}}const isBufferView=safeBool(()=>ArrayBuffer.isView(obj));const isArray=safeBool(()=>Array.isArray(obj));const constructorName=safeBool(()=>obj.constructor.name)||"";if(typeof obj==="function"){type_flags|=1<<9}if(hasMethod(obj,"then")){type_flags|=1<<7}if(hasMethod(obj,Symbol.iterator)){type_flags|=1<<0}if(hasMethod(obj,Symbol.asyncIterator)){type_flags|=1<<15}if(hasMethod(obj,"next")&&(hasMethod(obj,Symbol.iterator)||!hasMethod(obj,Symbol.asyncIterator))){type_flags|=1<<1}if(hasMethod(obj,"next")&&(!hasMethod(obj,Symbol.iterator)||hasMethod(obj,Symbol.asyncIterator))){type_flags|=1<<18}if(hasProperty(obj,"size")||hasProperty(obj,"length")&&typeof obj!=="function"){type_flags|=1<<2}if(hasMethod(obj,"get")){type_flags|=1<<3}if(hasMethod(obj,"set")){type_flags|=1<<4}if(hasMethod(obj,"has")){type_flags|=1<<5}if(hasMethod(obj,"includes")){type_flags|=1<<6}if((isBufferView||typeTag==="[object ArrayBuffer]")&&!(type_flags&1<<9)){type_flags|=1<<8}if(API.isPyProxy(obj)){type_flags|=1<<13}if(isArray){type_flags|=1<<10}if(typeTag==="[object HTMLCollection]"||typeTag==="[object NodeList]"){type_flags|=1<<11}if(isBufferView&&typeTag!=="[object DataView]"){type_flags|=1<<12}if(typeTag==="[object Generator]"){type_flags|=1<<16}if(typeTag==="[object AsyncGenerator]"){type_flags|=1<<17}if(hasProperty(obj,"name")&&hasProperty(obj,"message")&&(hasProperty(obj,"stack")||constructorName==="DOMException")&&!(type_flags&(1<<9|1<<8))){type_flags|=1<<19}if(is_py_json&&type_flags&(1<<10|1<<11|1<<1)){type_flags|=1<<21}if(is_py_json&&!(type_flags&(1<<10|1<<12|1<<11|1<<8|1<<13|1<<1|1<<9|1<<19))){type_flags|=1<<20}return type_flags}catch(e){Module.handle_js_error(e);return-1}return 0}JsProxy_compute_typeflags.sig="iei";function is_comlink_proxy(obj){try{return!!(API.Comlink&&value[API.Comlink.createEndpoint])}catch(e){return!!0}}is_comlink_proxy.sig="ie";function can_run_sync_js(){return!!validSuspender.value}can_run_sync_js.sig="i";function my_dict_converter(){return Object.fromEntries}my_dict_converter.sig="e";function get_async_js_call_done_callback(proxies){try{return function(result){let msg="This borrowed proxy was automatically destroyed "+"at the end of an asynchronous function call. Try "+"using create_proxy or create_once_callable.";for(let px of proxies){Module.pyproxy_destroy(px,msg,!!0)}if(API.isPyProxy(result)){Module.pyproxy_destroy(result,msg,!!0)}}}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}get_async_js_call_done_callback.sig="ee";function wrap_generator(gen,proxies){try{proxies=new Set(proxies);const msg="This borrowed proxy was automatically destroyed "+"when a generator completed execution. Try "+"using create_proxy or create_once_callable.";function cleanup(){proxies.forEach(px=>Module.pyproxy_destroy(px,msg))}function wrap(funcname){return function(val){if(API.isPyProxy(val)){val=val.copy();proxies.add(val)}let res;try{res=gen[funcname](val)}catch(e){cleanup();throw e}if(res.done){proxies.delete(res.value);cleanup()}return res}}return{get[Symbol.toStringTag](){return"Generator"},[Symbol.iterator](){return this},next:wrap("next"),throw:wrap("throw"),return:wrap("return")}}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}wrap_generator.sig="eee";function wrap_async_generator(gen,proxies){try{proxies=new Set(proxies);const msg="This borrowed proxy was automatically destroyed "+"when an asynchronous generator completed execution. Try "+"using create_proxy or create_once_callable.";function cleanup(){proxies.forEach(px=>Module.pyproxy_destroy(px,msg))}function wrap(funcname){return async function(val){if(API.isPyProxy(val)){val=val.copy();proxies.add(val)}let res;try{res=await gen[funcname](val)}catch(e){cleanup();throw e}if(res.done){proxies.delete(res.value);cleanup()}return res}}return{get[Symbol.toStringTag](){return"AsyncGenerator"},[Symbol.asyncIterator](){return this},next:wrap("next"),throw:wrap("throw"),return:wrap("return")}}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}wrap_async_generator.sig="eee";function throw_no_gil(){throw new API.NoGilError("Attempted to use PyProxy when Python GIL not held")}throw_no_gil.sig="v";function pyproxy_Check(val){return API.isPyProxy(val)}pyproxy_Check.sig="ie";function pyproxy_AsPyObject(val){if(!API.isPyProxy(val)||!pyproxyIsAlive(val)){return 0}return Module.PyProxy_getPtr(val)}pyproxy_AsPyObject.sig="ie";function destroy_proxies(proxies,msg_ptr){let msg=undefined;if(msg_ptr){msg=_JsvString_FromId(msg_ptr)}for(let px of proxies){Module.pyproxy_destroy(px,msg,false)}}destroy_proxies.sig="vei";function gc_register_proxies(proxies){for(let px of proxies){Module.gc_register_proxy(Module.PyProxy_getAttrs(px).shared)}}gc_register_proxies.sig="ve";function destroy_proxy(px,msg_ptr){const{shared,props}=Module.PyProxy_getAttrsQuiet(px);if(!shared.ptr){return}if(props.roundtrip){return}let msg=undefined;if(msg_ptr){msg=_JsvString_FromId(msg_ptr)}Module.pyproxy_destroy(px,msg,false)}destroy_proxy.sig="vei";function proxy_cache_get(proxyCache,descr){const proxy=proxyCache.get(descr);if(!proxy){return Module.error}if(pyproxyIsAlive(proxy)){return proxy}else{proxyCache.delete(descr);return Module.error}}proxy_cache_get.sig="eei";function proxy_cache_set(proxyCache,descr,proxy){proxyCache.set(descr,proxy)}proxy_cache_set.sig="veie";function _pyproxyGen_make_result(done,value){return{done:!!done,value}}_pyproxyGen_make_result.sig="eie";function array_to_js(array,len){return Array.from(HEAP32.subarray(array/4>>>0,array/4+len>>>0))}array_to_js.sig="eii";function _pyproxy_get_buffer_result(start_ptr,smallest_ptr,largest_ptr,readonly,format,itemsize,shape,strides,view,c_contiguous,f_contiguous,sentinel){format=UTF8ToString(format);return{start_ptr,smallest_ptr,largest_ptr,readonly,format,itemsize,shape,strides,view,c_contiguous,f_contiguous}}_pyproxy_get_buffer_result.sig="eiiiiiieeiiii";function pyproxy_new_ex(ptrobj,capture_this,roundtrip,gcRegister,jsonAdaptor){try{return Module.pyproxy_new(ptrobj,{props:{captureThis:!!capture_this,roundtrip:!!roundtrip},gcRegister,jsonAdaptor})}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}pyproxy_new_ex.sig="eiiiii";function pyproxy_new(ptrobj){try{return Module.pyproxy_new(ptrobj)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}pyproxy_new.sig="ei";function create_once_callable(obj,may_syncify){try{_Py_IncRef(obj);let alreadyCalled=!!0;function wrapper(...args){if(alreadyCalled){throw new Error("OnceProxy can only be called once")}try{if(may_syncify){return Module.callPyObjectMaybePromising(obj,args)}else{return Module.callPyObject(obj,args)}}finally{wrapper.destroy()}}wrapper.destroy=function(){if(alreadyCalled){throw new Error("OnceProxy has already been destroyed")}alreadyCalled=!!1;Module.finalizationRegistry.unregister(wrapper);_Py_DecRef(obj)};Module.finalizationRegistry.register(wrapper,[obj,undefined],wrapper);return wrapper}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}create_once_callable.sig="eii";function create_promise_handles(handle_result,handle_exception,done_callback,js2py_converter){try{if(handle_result){_Py_IncRef(handle_result)}if(handle_exception){_Py_IncRef(handle_exception)}if(js2py_converter){_Py_IncRef(js2py_converter)}if(!done_callback){done_callback=x=>{}}let used=!!0;function checkUsed(){if(used){throw new Error("One of the promise handles has already been called.")}}function destroy(){checkUsed();used=!!1;if(handle_result){_Py_DecRef(handle_result)}if(handle_exception){_Py_DecRef(handle_exception)}if(js2py_converter){_Py_DecRef(js2py_converter)}}function onFulfilled(res){checkUsed();try{if(handle_result){return _create_promise_handles_result_helper(handle_result,js2py_converter,res)}}finally{done_callback(res);destroy()}}function onRejected(err){checkUsed();try{if(handle_exception){return Module.callPyObjectMaybePromising(handle_exception,[err])}}finally{done_callback(undefined);destroy()}}onFulfilled.destroy=destroy;onRejected.destroy=destroy;return[onFulfilled,onRejected]}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}create_promise_handles.sig="eiiei";function _python2js_buffer_inner(buf,itemsize,ndim,format,shape,strides,suboffsets){try{let converter=Module.get_converter(format,itemsize);return Module._python2js_buffer_recursive(buf,0,{ndim,format,itemsize,shape,strides,suboffsets,converter})}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}_python2js_buffer_inner.sig="eiiiiiii";function jslib_init_js(){try{HEAP32[_Jsr_undefined/4>>>0]=_hiwire_intern(undefined);HEAP32[_Jsr_true/4>>>0]=_hiwire_intern(true);HEAP32[_Jsr_false/4>>>0]=_hiwire_intern(false);HEAP32[_Jsr_error/4>>>0]=_hiwire_intern(_Jsv_GetNull());HEAP32[_Jsr_novalue/4>>>0]=_hiwire_intern({noValueMarker:1});Module.novalue=_hiwire_get(HEAP32[_Jsr_novalue/4>>>0]);Module.error=_hiwire_get(HEAP32[_Jsr_error/4>>>0]);Hiwire.num_keys=_hiwire_num_refs;return 0}catch(e){Module.handle_js_error(e);return-1}return 0}jslib_init_js.sig="i";function JsvNoValue_Check(v){return v===Module.novalue}JsvNoValue_Check.sig="ie";function JsvNum_fromInt(x){return x}JsvNum_fromInt.sig="ei";function JsvNum_fromDouble(val){return val}JsvNum_fromDouble.sig="ed";function JsvNum_fromDigits(digits,ndigits){let result=BigInt(0);for(let i=0;i>2)+i>>>0])<>2)+ndigits-1>>>0]&2147483648)<=arr.length){return Module.error}return arr.splice(idx,1)[0]}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvArray_Delete.sig="eei";function JsvArray_Push(arr,obj){return arr.push(obj)}JsvArray_Push.sig="iee";function JsvArray_Extend(arr,vals){arr.push(...vals)}JsvArray_Extend.sig="vee";function JsvArray_Insert(arr,idx,value){try{arr.splice(idx,0,value)}catch(e){Module.handle_js_error(e);return-1}return 0}JsvArray_Insert.sig="ieie";function JsvArray_ShallowCopy(arr){try{return"slice"in arr?arr.slice():Array.from(arr)}catch(e){Module.handle_js_error(e);return-1}return 0}JsvArray_ShallowCopy.sig="ee";function JsvArray_slice(obj,length,start,stop,step){try{let result;if(step===1){result=obj.slice(start,stop)}else{result=Array.from({length},(_,i)=>obj[start+i*step])}return result}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvArray_slice.sig="eeiiii";function JsvArray_slice_assign(obj,slicelength,start,stop,step,values_length,values){try{let jsvalues=[];for(let i=0;i>2)+i>>>0]);if(ref===Module.error){return-1}jsvalues.push(ref)}if(step===1){obj.splice(start,slicelength,...jsvalues)}else{if(values!==0){for(let i=0;i=0;i--){obj.splice(start+i*step,1)}}}}catch(e){Module.handle_js_error(e);return-1}return 0}JsvArray_slice_assign.sig="ieiiiiii";function JsvObject_New(){return{}}JsvObject_New.sig="e";function JsvObject_SetAttr(obj,attr,value){try{obj[attr]=value}catch(e){Module.handle_js_error(e);return-1}return 0}JsvObject_SetAttr.sig="ieee";function JsvObject_Entries(obj){try{return Object.entries(obj)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvObject_Entries.sig="ee";function JsvObject_Keys(obj){try{return Object.keys(obj)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvObject_Keys.sig="ee";function JsvObject_Values(obj){try{return Object.values(obj)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvObject_Values.sig="ee";function JsvObject_toString(obj){try{if(hasMethod(obj,"toString")){return obj.toString()}return Object.prototype.toString.call(obj)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvObject_toString.sig="ee";function JsvObject_CallMethod(obj,meth,args){try{return obj[meth](...args)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvObject_CallMethod.sig="eeee";function JsvObject_CallMethod_NoArgs(obj,meth){try{return obj[meth]()}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvObject_CallMethod_NoArgs.sig="eee";function JsvObject_CallMethod_OneArg(obj,meth,arg){try{return obj[meth](arg)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvObject_CallMethod_OneArg.sig="eeee";function JsvObject_CallMethod_TwoArgs(obj,meth,arg1,arg2){try{return obj[meth](arg1,arg2)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvObject_CallMethod_TwoArgs.sig="eeeee";function JsvFunction_Check(obj){try{return typeof obj==="function"}catch(e){return false}}JsvFunction_Check.sig="ie";function JsvFunction_CallBound(func,this_,args){try{return Function.prototype.apply.apply(func,[this_,args])}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvFunction_CallBound.sig="eeee";function JsvFunction_Call_OneArg(func,arg){try{return func(arg)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvFunction_Call_OneArg.sig="eee";function JsvFunction_Construct(func,args){try{return Reflect.construct(func,args)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvFunction_Construct.sig="eee";function JsvPromise_Check(obj){try{return isPromise(obj)}catch(e){return false}}JsvPromise_Check.sig="ie";function JsvPromise_Resolve(obj){try{return Promise.resolve(obj)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvPromise_Resolve.sig="ee";function jslib_init_buffers_js(){try{const dtypes_str=Array.from("bBhHiIqQfd").join(String.fromCharCode(0));const dtypes_ptr=stringToNewUTF8(dtypes_str);const dtypes_map=Object.fromEntries(Object.entries(dtypes_str).map(([idx,val])=>[val,dtypes_ptr+ +idx]));const buffer_datatype_map=new Map([["Int8Array",[dtypes_map["b"],1,true]],["Uint8Array",[dtypes_map["B"],1,true]],["Uint8ClampedArray",[dtypes_map["B"],1,true]],["Int16Array",[dtypes_map["h"],2,true]],["Uint16Array",[dtypes_map["H"],2,true]],["Int32Array",[dtypes_map["i"],4,true]],["Uint32Array",[dtypes_map["I"],4,true]],["Float32Array",[dtypes_map["f"],4,true]],["Float64Array",[dtypes_map["d"],8,true]],["BigInt64Array",[dtypes_map["q"],8,true]],["BigUint64Array",[dtypes_map["Q"],8,true]],["DataView",[dtypes_map["B"],1,false]],["ArrayBuffer",[dtypes_map["B"],1,false]]]);Module.get_buffer_datatype=function(jsobj){return buffer_datatype_map.get(jsobj.constructor.name)||[0,0,false]}}catch(e){Module.handle_js_error(e);return-1}return 0}jslib_init_buffers_js.sig="i";function JsvBuffer_assignToPtr(buf,ptr){try{Module.HEAPU8.set(bufferAsUint8Array(buf),ptr)}catch(e){Module.handle_js_error(e);return-1}return 0}JsvBuffer_assignToPtr.sig="iei";function JsvBuffer_assignFromPtr(buf,ptr){try{bufferAsUint8Array(buf).set(Module.HEAPU8.subarray(ptr,ptr+buf.byteLength))}catch(e){Module.handle_js_error(e);return-1}return 0}JsvBuffer_assignFromPtr.sig="iei";function JsvBuffer_readFromFile(buf,fd){try{let uint8_buf=bufferAsUint8Array(buf);let stream=Module.FS.streams[fd];Module.FS.read(stream,uint8_buf,0,uint8_buf.byteLength)}catch(e){Module.handle_js_error(e);return-1}return 0}JsvBuffer_readFromFile.sig="iei";function JsvBuffer_writeToFile(buf,fd){try{let uint8_buf=bufferAsUint8Array(buf);let stream=Module.FS.streams[fd];Module.FS.write(stream,uint8_buf,0,uint8_buf.byteLength)}catch(e){Module.handle_js_error(e);return-1}return 0}JsvBuffer_writeToFile.sig="iei";function JsvBuffer_intoFile(buf,fd){try{let uint8_buf=bufferAsUint8Array(buf);let stream=Module.FS.streams[fd];Module.FS.write(stream,uint8_buf,0,uint8_buf.byteLength,undefined,true)}catch(e){Module.handle_js_error(e);return-1}return 0}JsvBuffer_intoFile.sig="iei";function JsvGenerator_Check(obj){try{return getTypeTag(obj)==="[object Generator]"}catch(e){return false}}JsvGenerator_Check.sig="ie";function JsvAsyncGenerator_Check(obj){try{return getTypeTag(obj)==="[object AsyncGenerator]"}catch(e){return false}}JsvAsyncGenerator_Check.sig="ie";function JsvError_Throw(e){throw e}JsvError_Throw.sig="ve";function Jsv_less_than(a,b){try{return!!(ab)}catch(e){return false}}Jsv_greater_than.sig="iee";function Jsv_greater_than_equal(a,b){try{return!!(a>=b)}catch(e){return false}}Jsv_greater_than_equal.sig="iee";function JsvMap_New(){try{return new Map}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvMap_New.sig="e";function JsvLiteralMap_New(){try{return new API.LiteralMap}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvLiteralMap_New.sig="e";function JsvMap_Set(map,key,val){try{map.set(key,val)}catch(e){Module.handle_js_error(e);return-1}return 0}JsvMap_Set.sig="ieee";function JsvSet_New(){try{return new Set}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}JsvSet_New.sig="e";function JsvSet_Add(set,val){try{set.add(val)}catch(e){Module.handle_js_error(e);return-1}return 0}JsvSet_Add.sig="iee";function _python2js_addto_postprocess_list(list,parent,key,value){list.push([parent,key,value])}_python2js_addto_postprocess_list.sig="veeei";function _python2js_handle_postprocess_list(list,cache){for(const[parent,key,ptr]of list){let val=cache.get(ptr);if(parent.constructor.name==="LiteralMap"){parent.set(key,val)}else{parent[key]=val}}}_python2js_handle_postprocess_list.sig="vee";function _python2js_ucs1(ptr,len){try{let jsstr="";for(let i=0;i>>0])}return jsstr}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}_python2js_ucs1.sig="eii";function _python2js_ucs2(ptr,len){try{let jsstr="";for(let i=0;i>1)+i>>>0])}return jsstr}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}_python2js_ucs2.sig="eii";function _python2js_ucs4(ptr,len){try{let jsstr="";for(let i=0;i>2)+i>>>0])}return jsstr}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}_python2js_ucs4.sig="eii";function _python2js_add_to_cache(cache,pyparent,jsparent){try{cache.set(pyparent,jsparent)}catch(e){Module.handle_js_error(e);return-1}return 0}_python2js_add_to_cache.sig="ieie";function _python2js_cache_lookup(cache,pyparent){return cache.get(pyparent)||Module.error}_python2js_cache_lookup.sig="eei";function _JsObject_Set_js(obj,key,value){try{if(key in obj){return-2}obj[key]=value}catch(e){Module.handle_js_error(e);return-1}return 0}_JsObject_Set_js.sig="ieee";function _JsArray_PushEntry_helper(array,key,value){try{array.push([key,value])}catch(e){Module.handle_js_error(e);return-1}return 0}_JsArray_PushEntry_helper.sig="ieee";function _JsArray_PostProcess_helper(jscontext,array){try{return jscontext.dict_converter(array)}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}_JsArray_PostProcess_helper.sig="eee";function python2js__default_converter_js(jscontext,object){try{let proxy=Module.pyproxy_new(object);try{return jscontext.default_converter(proxy,jscontext.converter,jscontext.cacheConversion)}finally{proxy.destroy()}}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}python2js__default_converter_js.sig="eei";function python2js__eager_converter_js(jscontext,object){try{if(jscontext.eager_visited.has(object)){return Module.novalue}jscontext.eager_visited.add(object);const proxy=Module.pyproxy_new(object);try{return jscontext.eager_converter(proxy,jscontext.converter,jscontext.cacheConversion)}finally{proxy.destroy()}}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}python2js__eager_converter_js.sig="eei";function python2js_custom__create_jscontext(context,cache,dict_converter,default_converter,eager_converter){try{const jscontext={};if(dict_converter){jscontext.dict_converter=dict_converter}if(default_converter){jscontext.default_converter=default_converter;jscontext.cacheConversion=function(input,output){if(!API.isPyProxy(input)){throw new TypeError("The first argument to cacheConversion must be a PyProxy.")}const input_ptr=Module.PyProxy_getPtr(input);cache.set(input_ptr,output)}}if(eager_converter){jscontext.eager_converter=eager_converter;jscontext.eager_visited=new Set}if(default_converter||eager_converter){jscontext.converter=function(x){if(!API.isPyProxy(x)){return x}const ptr=Module.PyProxy_getPtr(x);let res;try{res=__python2js(context,ptr)}catch(e){API.fatal_error(e)}if(res===Module.error){_pythonexc2js()}return res}}return jscontext}catch(e){Module.handle_js_error(e);return Module.error}errNoRet()}python2js_custom__create_jscontext.sig="eieeee";function destroy_proxies_js(proxies_id){try{for(const proxy of proxies_id){proxy.destroy()}}catch(e){Module.handle_js_error(e);return-1}return 0}destroy_proxies_js.sig="ie";function pyodide_js_init(){"use strict";(()=>{var Dr=Object.create;var ze=Object.defineProperty;var Rr=Object.getOwnPropertyDescriptor;var Lr=Object.getOwnPropertyNames;var $r=Object.getPrototypeOf,Cr=Object.prototype.hasOwnProperty;var a=(t,e)=>ze(t,"name",{value:e,configurable:!0}),b=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,r)=>(typeof require<"u"?require:e)[r]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var Ur=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Lr(e))!Cr.call(t,o)&&o!==r&&ze(t,o,{get:()=>e[o],enumerable:!(n=Rr(e,o))||n.enumerable});return t};var E=(t,e,r)=>(r=t!=null?Dr($r(t)):{},Ur(e||!t||!t.__esModule?ze(r,"default",{value:t,enumerable:!0}):r,t));function Br(t){return!isNaN(parseFloat(t))&&isFinite(t)}a(Br,"_isNumber");function D(t){return t.charAt(0).toUpperCase()+t.substring(1)}a(D,"_capitalize");function Ge(t){return function(){return this[t]}}a(Ge,"_getter");var $=["isConstructor","isEval","isNative","isToplevel"],C=["columnNumber","lineNumber"],U=["fileName","functionName","source"],Hr=["args"],jr=["evalOrigin"],se=$.concat(C,U,Hr,jr);function v(t){if(t)for(var e=0;e-1&&(i=i.replace(/eval code/g,"eval").replace(/(\(eval at [^()]*)|(,.*$)/g,""));var s=i.replace(/^\s+/,"").replace(/\(eval code/g,"(").replace(/^.*?\s+/,""),l=s.match(/ (\(.+\)$)/);s=l?s.replace(l[0],""):s;var c=this.extractLocation(l?l[1]:s),u=l&&s||void 0,y=["eval",""].indexOf(c[0])>-1?void 0:c[0];return new le({functionName:u,fileName:y,lineNumber:c[1],columnNumber:c[2],source:i})},this)},"ErrorStackParser$$parseV8OrIE"),parseFFOrSafari:a(function(n){var o=n.stack.split(`\n`).filter(function(i){return!i.match(e)},this);return o.map(function(i){if(i.indexOf(" > eval")>-1&&(i=i.replace(/ line (\d+)(?: > eval line \d+)* > eval:\d+:\d+/g,":$1")),i.indexOf("@")===-1&&i.indexOf(":")===-1)return new le({functionName:i});var s=/((.*".+"[^@]*)?[^@]*)(?:@)/,l=i.match(s),c=l&&l[1]?l[1]:void 0,u=this.extractLocation(i.replace(s,""));return new le({functionName:c,fileName:u[0],lineNumber:u[1],columnNumber:u[2],source:i})},this)},"ErrorStackParser$$parseFFOrSafari")}}a(Wr,"ErrorStackParser");var zr=new Wr;var Ve=zr;function Mt(t){if(typeof t=="string")t=new Error(t);else if(t&&typeof t=="object"&&t.name==="ExitStatus"){let e=t.status;t=new z(t.message),t.status=e}else if(typeof t!="object"||t===null||typeof t.stack!="string"||typeof t.message!="string"){let e=API.getTypeTag(t),r=`A value of type ${typeof t} with tag ${e} was thrown as an error!`;try{r+=`\nString interpolation of the thrown value gives """${t}""".`}catch{r+=`\nString interpolation of the thrown value fails.`}try{r+=`\nThe thrown value's toString method returns """${t.toString()}""".`}catch{r+=`\nThe thrown value's toString method fails.`}t=new Error(r)}return t}a(Mt,"ensureCaughtObjectIsError");var Ke=class extends Error{static{a(this,"CppException")}constructor(e,r,n){let o=Module.getCppExceptionThrownObjectFromWebAssemblyException(n);r||(r=`The exception is an object of type ${e} at address ${o} which does not inherit from std::exception`),super(r),this.ty=e}get name(){return`${this.constructor.name} ${this.ty}`}},Gr=WebAssembly.Exception,Vr=a(t=>t instanceof Gr,"isWasmException");function Nt(t){let[e,r]=Module.getExceptionMessage(t);return new Ke(e,r,t)}a(Nt,"convertCppException");Tests.convertCppException=Nt;var Et=!1;API.fatal_error=function(t){if(t&&t.pyodide_fatal_error)return;if(Et){console.error("Recursive call to fatal_error. Inner error was:"),console.error(t);return}if(t instanceof G)throw t;typeof t=="number"||Vr(t)?t=Nt(t):t=Mt(t),t.pyodide_fatal_error=!0,Et=!0;let e=t instanceof z;e||(console.error("Pyodide has suffered a fatal error. Please report this to the Pyodide maintainers."),console.error("The cause of the fatal error was:"),API.inTestHoist?(console.error(t.toString()),console.error(t.stack)):console.error(t));try{e||_dump_traceback();let n=`Pyodide already ${e?"exited":"fatally failed"} and can no longer be used.`;for(let o of Reflect.ownKeys(API.public_api))typeof o=="string"&&o.startsWith("_")||o==="version"||Object.defineProperty(API.public_api,o,{enumerable:!0,configurable:!0,get:a(()=>{throw new Error(n)},"get")});API.on_fatal&&API.on_fatal(t)}catch(r){console.error("Another error occurred while handling the fatal error:"),console.error(r)}throw t};API.maybe_fatal_error=function(t){API._skip_unwind_fatal_error&&t==="unwind"||API.fatal_error(t)};var Je=[];API.capture_stderr=function(){Je=[],Module.FS.createDevice("/dev","capture_stderr",null,t=>Je.push(t)),Module.FS.closeStream(2),Module.FS.open("/dev/capture_stderr",1)};API.restore_stderr=function(){return Module.FS.closeStream(2),Module.FS.unlink("/dev/capture_stderr"),Module.FS.open("/dev/stderr",1),UTF8ArrayToString(new Uint8Array(Je))};API.fatal_loading_error=function(...t){let e=t.join(" ");if(_PyErr_Occurred()){API.capture_stderr(),_PyErr_Print();let r=API.restore_stderr();e+=`\n`+r}throw new ce(e)};function qe(t){if(!t)return!1;let e=t.fileName||"";if(e.includes("wasm-function"))return!0;if(!e.includes("pyodide.asm.js"))return!1;let r=t.functionName||"";return r.startsWith("Object.")&&(r=r.slice(7)),API.public_api&&r in API.public_api&&r!=="PythonError"?(t.functionName=r,!1):!0}a(qe,"isPyodideFrame");function kt(t){return qe(t)&&t.functionName==="new_error"}a(kt,"isErrorStart");Module.handle_js_error=function(t){if(t&&t.pyodide_fatal_error)throw t;if(t instanceof w)return;let e=!1;t instanceof R&&(e=_restore_sys_last_exception(t.__error_address));let r,n;try{r=Ve.parse(t)}catch{n=!0}if(n&&(t=Mt(t)),!e){let o=_JsProxy_create(t);_set_error(o),_Py_DecRef(o)}if(!n){if(kt(r[0])||kt(r[1]))for(;qe(r[0]);)r.shift();for(let o of r){if(qe(o))break;let i=stringToNewUTF8(o.functionName||"???"),s=stringToNewUTF8(o.fileName||"???.js");__PyTraceback_Add(i,s,o.lineNumber),_free(i),_free(s)}}};var R=class extends Error{static{a(this,"PythonError")}constructor(e,r,n){let o=Error.stackTraceLimit;Error.stackTraceLimit=1/0,super(r),Error.stackTraceLimit=o,this.type=e,this.__error_address=n}};API.PythonError=R;var w=class extends Error{static{a(this,"_PropagatePythonError")}constructor(){super("If you are seeing this message, an internal Pyodide error has occurred. Please report it to the Pyodide maintainers.")}};Module._PropagatePythonError=w;function Kr(t){Object.defineProperty(t.prototype,"name",{value:t.name})}a(Kr,"setName");var ce=class extends Error{static{a(this,"FatalPyodideError")}},z=class extends Error{static{a(this,"Exit")}},G=class extends Error{static{a(this,"NoGilError")}};[w,ce,z,R,G].forEach(Kr);API.NoGilError=G;API.errorConstructors=new Map([EvalError,RangeError,ReferenceError,SyntaxError,TypeError,URIError,globalThis.DOMException,globalThis.AssertionError,globalThis.SystemError].filter(t=>t).map(t=>[t.constructor.name,t]));API.deserializeError=function(t,e,r){let n=API.errorConstructors.get(t)||Error,o=new n(e);return API.errorConstructors.has(t)||(o.name=t),o.message=e,o.stack=r,o};function Jr(t){let e=0,r=[];for(let s of t){let l=s.codePointAt(0);r.push(l),e=l>e?l:e}let n=r.length,o=_PyUnicode_New(n,e);if(o===0)throw new w;let i=_PyUnicode_Data(o);if(e>65535)for(let s=0;s>2)+s>>>0]=r[s];else if(e>255)for(let s=0;s>1)+s>>>0]=r[s];else for(let s=0;s>>0]=r[s];return o}a(Jr,"js2python_string");function qr(t){let e=t,r=0;for(t<0&&(t=-t),t<<=BigInt(1);t;)r++,t>>=BigInt(32);let n=stackSave(),o=stackAlloc(r*4);t=e;for(let s=0;s>2)+s>>>0]=Number(t&BigInt(4294967295)),t>>=BigInt(32);let i=__PyLong_FromByteArray(o,r*4,!0,!0);return stackRestore(n),i}a(qr,"js2python_bigint");function V(t){let e=Yr(t);if(e===0)throw new w;return e}a(V,"js2python_convertImmutable");Module.js2python_convertImmutable=V;function Yr(t){let e=typeof t;if(e==="string")return Jr(t);if(e==="number")return Number.isSafeInteger(t)?_PyLong_FromDouble(t):_PyFloat_FromDouble(t);if(e==="bigint")return qr(t);if(t===void 0)return __js2python_none();if(t===null)return __js2python_null();if(t===!0)return __js2python_true();if(t===!1)return __js2python_false();if(API.isPyProxy(t)){let{props:r,shared:n}=Module.PyProxy_getAttrs(t);return r.roundtrip?_JsProxy_create(t):__js2python_pyproxy(n.ptr)}}a(Yr,"js2python_convertImmutableInner");function Qr(t,e){let r=_PyList_New(t.length);if(r===0)return 0;let n=0;try{e.cache.set(t,r);for(let o=0;oModule.pyproxy_new(ue(o,n)),"converter"),cacheConversion(o,i){if(API.isPyProxy(i))n.cache.set(o,Module.PyProxy_getPtr(i));else throw new Error("Second argument should be a PyProxy!")}};return ue(t,n)}a(en,"js2python_convert");Module.js2python_convert=en;Module.processBufferFormatString=function(t,e=""){if(t.length>2)throw new Error(`Expected format string to have length <= 2, got '${t}'.`+e);let r=t.slice(-1),n=t.slice(0,-1),o;switch(n){case"!":case">":o=!0;break;case"<":case"@":case"=":case"":o=!1;break;default:throw new Error(`Unrecognized alignment character ${n}.`+e)}let i;switch(r){case"b":i=Int8Array;break;case"s":case"p":case"c":case"B":case"?":i=Uint8Array;break;case"h":i=Int16Array;break;case"H":i=Uint16Array;break;case"i":case"l":case"n":i=Int32Array;break;case"I":case"L":case"N":case"P":i=Uint32Array;break;case"q":if(globalThis.BigInt64Array===void 0)throw new Error("BigInt64Array is not supported on this browser."+e);i=BigInt64Array;break;case"Q":if(globalThis.BigUint64Array===void 0)throw new Error("BigUint64Array is not supported on this browser."+e);i=BigUint64Array;break;case"f":i=Float32Array;break;case"d":i=Float64Array;break;case"e":throw new Error("Javascript has no Float16 support.");default:throw new Error(`Unrecognized format character '${r}'.`+e)}return[i,o]};Module.python2js_buffer_1d_contiguous=function(t,e,r){let n=e*r;return HEAP8.slice(t,t+n).buffer};Module.python2js_buffer_1d_noncontiguous=function(t,e,r,n,o){let i=o*n,s=new Uint8Array(i);for(let l=0;l=0&&(c=HEAPU32[(c>>2)+0>>>0]+r),s.set(HEAP8.subarray(c>>>0,c+o>>>0),l*o)}return s.buffer};Module._python2js_buffer_recursive=function(t,e,r){let{shape:n,strides:o,ndim:i,converter:s,itemsize:l,suboffsets:c}=r,u=HEAPU32[(n>>2)+e>>>0],y=HEAP32[(o>>2)+e>>>0],_=-1;if(i===0)return s(Module.python2js_buffer_1d_contiguous(t,l,1));if(c!==0&&(_=HEAP32[(c>>2)+e>>>0]),e===i-1){let f;return y===l&&_<0?f=Module.python2js_buffer_1d_contiguous(t,y,u):f=Module.python2js_buffer_1d_noncontiguous(t,y,_,u,l),s(f)}let m=[];for(let f=0;f=0&&(curptr=HEAPU32[(curptr>>2)+0>>>0]+_),m.push(Module._python2js_buffer_recursive(I,e+1,r))}return m};Module.get_converter=function(t,e){let r=UTF8ToString(t),[n,o]=Module.processBufferFormatString(r);switch(r.slice(-1)){case"s":let u=new TextDecoder("utf8",{ignoreBOM:!0});return y=>u.decode(y);case"?":return y=>Array.from(new Uint8Array(y),_=>!!_)}if(!o)return u=>new n(u);let s,l;switch(e){case 2:s="getUint16",l="setUint16";break;case 4:s="getUint32",l="setUint32";break;case 8:s="getFloat64",l="setFloat64";break;default:throw new Error(`Unexpected size ${e}`)}function c(u){let y=new DataView(u),_=y[s].bind(y),m=y[l].bind(y);for(let f=0;fnew n(c(u))};function tn(t){try{return t instanceof g}catch{return!1}}a(tn,"isPyProxy");API.isPyProxy=tn;globalThis.FinalizationRegistry?Module.finalizationRegistry=new FinalizationRegistry(({ptr:t,cache:e})=>{e&&(e.leaked=!0,Bt(e));try{_check_gil();let r=validSuspender.value;validSuspender.value=!1,_Py_DecRef(t),validSuspender.value=r}catch(r){API.fatal_error(r)}}):Module.finalizationRegistry={register(){},unregister(){}};var Ye=new Map;Module.pyproxy_alloc_map=Ye;var ct,ut;Module.enable_pyproxy_allocation_tracing=function(){ct=a(function(t){Ye.set(t,Error().stack)},"trace_pyproxy_alloc"),ut=a(function(t){Ye.delete(t)},"trace_pyproxy_dealloc")};Module.disable_pyproxy_allocation_tracing=function(){ct=a(function(t){},"trace_pyproxy_alloc"),ut=a(function(t){},"trace_pyproxy_dealloc")};Module.disable_pyproxy_allocation_tracing();var $t=Symbol("pyproxy.attrs");function rn(t,e){_check_gil();let r=validSuspender.value;validSuspender.value=!1;try{return _pyproxy_getflags(t,e)}finally{validSuspender.value=r}}a(rn,"pyproxy_getflags");function J(t,{flags:e,cache:r,props:n,shared:o,gcRegister:i,jsonAdaptor:s}={}){i===void 0&&(i=!0);let l=e!==void 0?e:rn(t,!!s);l===-1&&_pythonexc2js();let c=l&8192,u=l&32768,y=l&1<<17,_=Module.getPyProxyClass(l),m;l&256?(m=a(function(){},"target"),Object.setPrototypeOf(m,_.prototype),delete m.length,delete m.name,m.prototype=void 0):m=Object.create(_.prototype);let f=!!o;o||(r||(r={map:new Map,json_adaptor_map:new Map,refcnt:0}),r.refcnt++,o={ptr:t,cache:r,flags:l,promise:void 0,destroyed_msg:void 0,gcRegistered:!1},_Py_IncRef(t)),n=Object.assign({isBound:!1,captureThis:!1,boundArgs:[],roundtrip:!1},n);let I;u?I=M:c?I=fn:y?I=_n:I=P;let oe=new Proxy(m,I);!f&&i&&Ct(o),f||ct(oe);let ae={shared:o,props:n};return m[$t]=ae,oe}a(J,"pyproxy_new");Module.pyproxy_new=J;function Ct(t){let e=Object.assign({},t);t.gcRegistered=!0,Module.finalizationRegistry.register(t,e,t)}a(Ct,"gc_register_proxy");Module.gc_register_proxy=Ct;function Oe(t){return t[$t]}a(Oe,"_getAttrsQuiet");Module.PyProxy_getAttrsQuiet=Oe;function S(t){let e=Oe(t);if(!e.shared.ptr)throw new Error(e.shared.destroyed_msg);return e}a(S,"_getAttrs");Module.PyProxy_getAttrs=S;function p(t){return S(t).shared.ptr}a(p,"_getPtr");function h(t){return Object.getPrototypeOf(t).$$flags}a(h,"_getFlags");function Ut(t){return!!(h(t)&98304)}a(Ut,"isJsonAdaptor");function Ft(t,e,r){let{captureThis:n,boundArgs:o,boundThis:i,isBound:s}=S(t).props;return n?s?[i].concat(o,r):[e].concat(r):s?o.concat(r):r}a(Ft,"_adjustArgs");var Dt=new Map;Module.getPyProxyClass=function(t){let e=[[1,Qe],[2,B],[4,L],[8,k],[16,Ze],[32,tt],[2048,rt],[512,et],[1024,nt],[4096,ot],[64,st],[128,lt],[256,ke],[8192,at],[16384,it]],r=Dt.get(t);if(r)return r;let n={};for(let[l,c]of e)t&l&&Object.assign(n,Object.getOwnPropertyDescriptors(c.prototype));(t&8192||t&2)&&Object.assign(n,Object.getOwnPropertyDescriptors(Xe.prototype)),n.constructor=Object.getOwnPropertyDescriptor(g.prototype,"constructor"),Object.assign(n,Object.getOwnPropertyDescriptors({$$flags:t}));let o=t&256?jt:Ht,i=Object.create(o,n);function s(){}return a(s,"NewPyProxyClass"),s.prototype=i,Dt.set(t,s),s};Module.PyProxy_getPtr=p;var Rt="This borrowed attribute proxy was automatically destroyed in the process of destroying the proxy it was borrowed from. Try using the 'copy' method.";function Bt(t){if(t&&(t.refcnt--,!t.leaked&&t.refcnt===0)){for(let e of t.map.values())Module.pyproxy_destroy(e,Rt,!0);for(let e of t.json_adaptor_map.values())Module.pyproxy_destroy(e,Rt,!0)}}a(Bt,"pyproxy_decref_cache");function nn(t,e){if(e=e||"Object has already been destroyed",API.debug_ffi){let r=t.type,n;try{n=t.toString()}catch(o){if(o.pyodide_fatal_error)throw o}e+=`\nThe object was of type "${r}" and `,n?e+=`had repr "${n}"`:e+="an error was raised when trying to generate its repr"}else e+="\nFor more information about the cause of this error, use `pyodide.setDebug(true)`";return e}a(nn,"generateDestroyedMessage");Module.pyproxy_destroy=function(t,e,r){let{shared:n,props:o}=Oe(t);if(!n.ptr||!r&&o.roundtrip)return;n.destroyed_msg=nn(t,e);let i=n.ptr;n.ptr=0,n.gcRegistered&&Module.finalizationRegistry.unregister(n),Bt(n.cache);try{_check_gil();let s=validSuspender.value;validSuspender.value=!1,_Py_DecRef(i),ut(t),validSuspender.value=s}catch(s){API.fatal_error(s)}};function pe(t,e,r){let n=e.length,o=Object.keys(r),i=Object.values(r),s=o.length;e.push(...i);let l;try{_check_gil();let c=validSuspender.value;validSuspender.value=!1,l=__pyproxy_apply(t,e,n,o,s),validSuspender.value=c}catch(c){API.maybe_fatal_error(c);return}if(l===Module.error&&_pythonexc2js(),l&&l.type==="coroutine"&&l._ensure_future){_check_gil();let c=validSuspender.value;validSuspender.value=!1;let u=__iscoroutinefunction(t);validSuspender.value=c,u&&l._ensure_future()}return l}a(pe,"callPyObjectKwargs");async function de(t,e,r){if(!Module.jspiSupported)throw new Error("WebAssembly stack switching not supported in this JavaScript runtime");let n=e.length,o=Object.keys(r),i=Object.values(r),s=o.length;e.push(...i);let l=stackSave(),c=stackAlloc(4),u;try{_check_gil();let y=validSuspender.value;validSuspender.value=!1,u=await Module.promisingApply(t,e,n,o,s,c),validSuspender.value=y}catch(y){API.fatal_error(y)}if(u=u[0],u===Module.error){_PyErr_SetRaisedException(HEAPU32[c/4>>>0]);try{_pythonexc2js()}finally{stackRestore(l)}}if(u&&u.type==="coroutine"&&u._ensure_future){_check_gil();let y=validSuspender.value;validSuspender.value=!1;let _=__iscoroutinefunction(t);validSuspender.value=y,_&&u._ensure_future()}return u}a(de,"callPyObjectKwargsPromising");Module.callPyObjectMaybePromising=async function(t,e){return Module.jspiSupported?await de(t,e,{}):pe(t,e,{})};Module.callPyObject=function(t,e){return pe(t,e,{})};var g=class t{static{a(this,"PyProxy")}static[Symbol.hasInstance](e){return[t,Wt].some(r=>Function.prototype[Symbol.hasInstance].call(r,e))}constructor(){throw new TypeError("PyProxy is not a constructor")}get[Symbol.toStringTag](){return"PyProxy"}get type(){let e=p(this);return __pyproxy_type(e)}toString(){let e=p(this),r;try{_check_gil();let n=validSuspender.value;validSuspender.value=!1,r=__pyproxy_repr(e),validSuspender.value=n}catch(n){API.fatal_error(n)}return r===Module.error&&_pythonexc2js(),r}destroy(e={}){e=Object.assign({message:"",destroyRoundtrip:!0},e);let{message:r,destroyRoundtrip:n}=e;Module.pyproxy_destroy(this,r,n)}copy(){let e=S(this);return J(e.shared.ptr,{flags:h(this),cache:e.shared.cache,props:e.props})}toJs({depth:e=-1,pyproxies:r=void 0,create_pyproxies:n=!0,dict_converter:o=void 0,default_converter:i=void 0,eager_converter:s=void 0}={}){let l=p(this),c,u;n?r?u=r:u=[]:u=Module.error;try{_check_gil();let y=validSuspender.value;validSuspender.value=!1,c=_python2js_custom(l,e,u,o??Module.error,i??Module.error,s??Module.error),validSuspender.value=y}catch(y){API.fatal_error(y)}return c===Module.error&&_pythonexc2js(),c}},Ht=g.prototype;Tests.Function=Function;var jt=Object.create(Function.prototype,Object.getOwnPropertyDescriptors(Ht));function Wt(){}a(Wt,"PyProxyFunction");Wt.prototype=jt;var fe=class extends g{static{a(this,"PyProxyWithLength")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&1)}},Qe=class{static{a(this,"PyLengthMethods")}get length(){let e=p(this),r;try{_check_gil();let n=validSuspender.value;validSuspender.value=!1,r=_PyObject_Size(e),validSuspender.value=n}catch(n){API.fatal_error(n)}return r===-1&&_pythonexc2js(),r}},ge=class extends g{static{a(this,"PyProxyWithGet")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&2)}},Xe=class{static{a(this,"PyAsJsonAdaptorMethods")}asJsJson(){let{shared:e,props:r}=S(this),n=h(this);return n&8192?n|=65536:n|=32768,J(e.ptr,{shared:e,flags:n,props:r})}},B=class{static{a(this,"PyGetItemMethods")}get(e){let{shared:r}=S(this),n;try{_check_gil();let o=validSuspender.value;validSuspender.value=!1,n=__pyproxy_getitem(r.ptr,e,r.cache.json_adaptor_map,Ut(this)),validSuspender.value=o}catch(o){API.fatal_error(o)}if(n===Module.error)if(_PyErr_Occurred())_pythonexc2js();else return;return n}asJsJson(){throw new Error("Should not happen")}},_e=class extends g{static{a(this,"PyProxyWithSet")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&4)}},L=class{static{a(this,"PySetItemMethods")}set(e,r){let n=p(this),o;try{_check_gil();let i=validSuspender.value;validSuspender.value=!1,o=__pyproxy_setitem(n,e,r),validSuspender.value=i}catch(i){API.fatal_error(i)}o===-1&&_pythonexc2js()}delete(e){let r=p(this),n;try{_check_gil();let o=validSuspender.value;validSuspender.value=!1,n=__pyproxy_delitem(r,e),validSuspender.value=o}catch(o){API.fatal_error(o)}n===-1&&_pythonexc2js()}},me=class extends g{static{a(this,"PyProxyWithHas")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&8)}},k=class{static{a(this,"PyContainsMethods")}has(e){let r=p(this),n;try{_check_gil();let o=validSuspender.value;validSuspender.value=!1,n=__pyproxy_contains(r,e),validSuspender.value=o}catch(o){API.fatal_error(o)}return n===-1&&_pythonexc2js(),n===1}};function*on(t,e,r,n){let o=[];try{for(;;){_check_gil();let i=validSuspender.value;validSuspender.value=!1;let s=__pyproxy_iter_next(t,r,n);if(validSuspender.value=i,s===Module.error)break;yield s,!n&&API.isPyProxy(s)&&o.push(s)}}catch(i){API.fatal_error(i)}finally{Module.finalizationRegistry.unregister(e),_Py_DecRef(t)}try{o.forEach(i=>Module.pyproxy_destroy(i,"This borrowed proxy was automatically destroyed when an iterator was exhausted."))}catch{}_PyErr_Occurred()&&_pythonexc2js()}a(on,"iter_helper");var he=class extends g{static{a(this,"PyIterable")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&48)}},Ze=class{static{a(this,"PyIterableMethods")}[Symbol.iterator](){let{shared:e}=S(this),r={},n;try{_check_gil();let i=validSuspender.value;validSuspender.value=!1,n=_PyObject_GetIter(e.ptr),validSuspender.value=i}catch(i){API.fatal_error(i)}n===0&&_pythonexc2js();let o=on(n,r,e.cache.json_adaptor_map,Ut(this));return Module.finalizationRegistry.register(o,[n,void 0],r),o}};async function*an(t,e){try{for(;;){let r;try{_check_gil();let n=validSuspender.value;if(validSuspender.value=!1,r=__pyproxy_aiter_next(t),validSuspender.value=n,r===Module.error)break}catch(n){API.fatal_error(n)}try{yield await r}catch(n){if(n&&typeof n=="object"&&n.type==="StopAsyncIteration")return;throw n}finally{r.destroy()}}}finally{Module.finalizationRegistry.unregister(e),_Py_DecRef(t)}_PyErr_Occurred()&&_pythonexc2js()}a(an,"aiter_helper");var Pe=class extends g{static{a(this,"PyAsyncIterable")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&1536)}},et=class{static{a(this,"PyAsyncIterableMethods")}[Symbol.asyncIterator](){let e=p(this),r={},n;try{_check_gil();let i=validSuspender.value;validSuspender.value=!1,n=_PyObject_GetAIter(e),validSuspender.value=i}catch(i){API.fatal_error(i)}n===0&&_pythonexc2js();let o=an(n,r);return Module.finalizationRegistry.register(o,[n,void 0],r),o}},be=class extends g{static{a(this,"PyIterator")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&32)}},tt=class{static{a(this,"PyIteratorMethods")}[Symbol.iterator](){return this}next(e=void 0){let r,n;try{_check_gil();let o=validSuspender.value;validSuspender.value=!1,r=__pyproxyGen_Send(p(this),e),validSuspender.value=o}catch(o){API.fatal_error(o)}return r===Module.error&&_pythonexc2js(),r}},ve=class extends g{static{a(this,"PyGenerator")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&2048)}},rt=class{static{a(this,"PyGeneratorMethods")}throw(e){let r;try{_check_gil();let n=validSuspender.value;validSuspender.value=!1,r=__pyproxyGen_throw(p(this),e),validSuspender.value=n}catch(n){API.fatal_error(n)}return r===Module.error&&_pythonexc2js(),r}return(e){let r;try{_check_gil();let n=validSuspender.value;validSuspender.value=!1,r=__pyproxyGen_return(p(this),e),validSuspender.value=n}catch(n){API.fatal_error(n)}return r===Module.error&&_pythonexc2js(),r}},xe=class extends g{static{a(this,"PyAsyncIterator")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&1024)}},nt=class{static{a(this,"PyAsyncIteratorMethods")}[Symbol.asyncIterator](){return this}async next(e=void 0){let r;try{_check_gil();let o=validSuspender.value;validSuspender.value=!1,r=__pyproxyGen_asend(p(this),e),validSuspender.value=o}catch(o){API.fatal_error(o)}r===Module.error&&_pythonexc2js();let n;try{n=await r}catch(o){if(o&&typeof o=="object"&&o.type==="StopAsyncIteration")return{done:!0,value:n};throw o}finally{r.destroy()}return{done:!1,value:n}}},we=class extends g{static{a(this,"PyAsyncGenerator")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&4096)}},ot=class{static{a(this,"PyAsyncGeneratorMethods")}async throw(e){let r;try{_check_gil();let o=validSuspender.value;validSuspender.value=!1,r=__pyproxyGen_athrow(p(this),e),validSuspender.value=o}catch(o){API.fatal_error(o)}r===Module.error&&_pythonexc2js();let n;try{n=await r}catch(o){if(o&&typeof o=="object"){if(o.type==="StopAsyncIteration")return{done:!0,value:n};if(o.type==="GeneratorExit")return{done:!0,value:n}}throw o}finally{r.destroy()}return{done:!1,value:n}}async return(e){let r;try{_check_gil();let o=validSuspender.value;validSuspender.value=!1,r=__pyproxyGen_areturn(p(this)),validSuspender.value=o}catch(o){API.fatal_error(o)}r===Module.error&&_pythonexc2js();let n;try{n=await r}catch(o){if(o&&typeof o=="object"){if(o.type==="StopAsyncIteration")return{done:!0,value:n};if(o.type==="GeneratorExit")return{done:!0,value:e}}throw o}finally{r.destroy()}return{done:!1,value:n}}},Se=class extends g{static{a(this,"PySequence")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&8192)}};function sn(t,e){let r=t.toString(),n=e.toString();return r===n?0:r{this.insert(n,r)}),this.length}copyWithin(...e){return Array.prototype.copyWithin.apply(this,e),this}fill(...e){return Array.prototype.fill.apply(this,e),this}};function ln(t,e){let r=p(t),n;try{_check_gil();let o=validSuspender.value;validSuspender.value=!1,n=__pyproxy_hasattr(r,e),validSuspender.value=o}catch(o){API.fatal_error(o)}return n===-1&&_pythonexc2js(),n!==0}a(ln,"python_hasattr");function cn(t,e){let{shared:r}=S(t),n=r.cache.map,o;try{_check_gil();let i=validSuspender.value;validSuspender.value=!1,o=__pyproxy_getattr(r.ptr,e,n),validSuspender.value=i}catch(i){API.fatal_error(i)}if(o===Module.error){_PyErr_Occurred()&&_pythonexc2js();return}return o}a(cn,"python_getattr");function un(t,e,r){let n=p(t),o;try{_check_gil();let i=validSuspender.value;validSuspender.value=!1,o=__pyproxy_setattr(n,e,r),validSuspender.value=i}catch(i){API.fatal_error(i)}o===-1&&_pythonexc2js()}a(un,"python_setattr");function yn(t,e){let r=p(t),n;try{_check_gil();let o=validSuspender.value;validSuspender.value=!1,n=__pyproxy_delattr(r,e),validSuspender.value=o}catch(o){API.fatal_error(o)}n===-1&&_pythonexc2js()}a(yn,"python_delattr");function dn(t,e,r,n){let o=p(t),i;try{_check_gil();let s=validSuspender.value;validSuspender.value=!1,i=__pyproxy_slice_assign(o,e,r,n),validSuspender.value=s}catch(s){API.fatal_error(s)}return i===Module.error&&_pythonexc2js(),i}a(dn,"python_slice_assign");function Lt(t,e){let r=p(t),n;try{_check_gil();let o=validSuspender.value;validSuspender.value=!1,n=__pyproxy_pop(r,e),validSuspender.value=o}catch(o){API.fatal_error(o)}return n===Module.error&&_pythonexc2js(),n}a(Lt,"python_pop");var pn=new Set(["name","length","caller","arguments"]);function ye(t,e,r){return t instanceof Function?e in t&&!(pn.has(e)||r&&e==="prototype"):e in t}a(ye,"filteredHasKey");var P={isExtensible(){return!0},has(t,e){return ye(t,e,!1)?!0:typeof e=="symbol"?!1:(e.startsWith("$")&&(e=e.slice(1)),ln(t,e))},get(t,e){return typeof e=="symbol"||ye(t,e,!0)?Reflect.get(t,e):(e.startsWith("$")&&(e=e.slice(1)),cn(t,e))},set(t,e,r){let n=Object.getOwnPropertyDescriptor(t,e);return n&&!n.writable&&!n.set?!1:typeof e=="symbol"||ye(t,e,!0)?Reflect.set(t,e,r):(e.startsWith("$")&&(e=e.slice(1)),un(t,e,r),!0)},deleteProperty(t,e){let r=Object.getOwnPropertyDescriptor(t,e);return r&&!r.configurable?!1:typeof e=="symbol"||ye(t,e,!0)?Reflect.deleteProperty(t,e):(e.startsWith("$")&&(e=e.slice(1)),yn(t,e),!0)},ownKeys(t){let e=p(t),r;try{_check_gil();let n=validSuspender.value;validSuspender.value=!1,r=__pyproxy_ownKeys(e),validSuspender.value=n}catch(n){API.fatal_error(n)}return r===Module.error&&_pythonexc2js(),r.push(...Reflect.ownKeys(t)),r},apply(t,e,r){return t.apply(e,r)}};function K(t){return t&&typeof t=="object"&&t.constructor&&t.constructor.name==="PythonError"}a(K,"isPythonError");var fn={isExtensible(){return!0},has(t,e){return typeof e=="string"&&/^[0-9]+$/.test(e)?Number(e)n.toString())),e.push("length"),e}},gn=new Set(["copy","constructor","$$flags","toString","destroy"]),M={isExtensible(){return!0},has(t,e){return k.prototype.has.call(t,e)?!0:typeof e=="string"&&/^[0-9]+$/.test(e)?k.prototype.has.call(t,Number(e)):!1},get(t,e){if(typeof e=="symbol"||gn.has(e))return Reflect.get(...arguments);let r=B.prototype.get.call(t,e);return r!==void 0||k.prototype.has.call(t,e)?r:typeof e=="string"&&/^[0-9]+$/.test(e)?B.prototype.get.call(t,Number(e)):Reflect.get(...arguments)},set(t,e,r){if(typeof e=="symbol")return!1;!k.prototype.has.call(t,e)&&typeof e=="string"&&/^[0-9]+$/.test(e)&&(e=Number(e));try{return L.prototype.set.call(t,e,r),!0}catch(n){if(K(n)&&n.type==="KeyError")return!1;throw n}},deleteProperty(t,e){if(typeof e=="symbol")return!1;!k.prototype.has.call(t,e)&&typeof e=="string"&&/^[0-9]+$/.test(e)&&(e=Number(e));try{return L.prototype.delete.call(t,e),!0}catch(r){if(K(r)&&r.type==="KeyError")return!1;throw r}},getOwnPropertyDescriptor(t,e){return M.has(t,e)?{configurable:!0,enumerable:!0,value:M.get(t,e),writable:!0}:void 0},ownKeys(t){let e=new Set;return zt(t,e),Array.from(e)}};function zt(t,e){let r=P.get(t,"keys")();for(let n of r)typeof n=="string"?e.add(n):typeof n=="number"&&e.add(n.toString());r.destroy()}a(zt,"dictOwnKeysHelper");var _n={isExtensible(){return!0},has(t,e){return P.has(t,e)?!0:M.has(t,e)},get(t,e){let r=P.get(t,e);return r!==void 0||P.has(t,e)?r:M.get(t,e)},set(t,e,r){return P.has(t,e)?P.set(t,e,r):M.set(t,e,r)},deleteProperty(t,e){return P.has(t,e)?P.deleteProperty(t,e):M.deleteProperty(t,e)},getOwnPropertyDescriptor(t,e){return Reflect.getOwnPropertyDescriptor(t,e)??M.getOwnPropertyDescriptor(t,e)},ownKeys(t){let e=new Set(P.ownKeys(t));return zt(t,e),Array.from(e)}},Ie=class extends g{static{a(this,"PyAwaitable")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&64)}},st=class{static{a(this,"PyAwaitableMethods")}_ensure_future(){let{shared:e}=Oe(this);if(e.promise)return e.promise;let r=e.ptr;r||S(this);let n,o,i=new Promise((l,c)=>{n=l,o=c}),s;try{_check_gil();let l=validSuspender.value;validSuspender.value=!1,s=__pyproxy_ensure_future(r,n,o),validSuspender.value=l}catch(l){API.fatal_error(l)}return s===-1&&_pythonexc2js(),e.promise=i,this.destroy(),i}then(e,r){return this._ensure_future().then(e,r)}catch(e){return this._ensure_future().catch(e)}finally(e){return this._ensure_future().finally(e)}},Ee=class extends g{static{a(this,"PyCallable")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&256)}},ke=class{static{a(this,"PyCallableMethods")}apply(e,r){return r=function(...n){return n}.apply(void 0,r),r=Ft(this,e,r),Module.callPyObject(p(this),r)}call(e,...r){return r=Ft(this,e,r),Module.callPyObject(p(this),r)}callWithOptions({relaxed:e,kwargs:r,promising:n},...o){let i={};if(r){if(o.length===0)throw new TypeError("callWithOptions with 'kwargs: true' requires at least one argument (the key word argument object)");if(i=o.pop(),i.constructor!==void 0&&i.constructor.name!=="Object")throw new TypeError("kwargs argument is not an object")}let s=e?API.pyodide_code.relaxed_call:this;return e&&o.unshift(this),(n?de:pe)(p(s),o,i)}callKwargs(...e){if(e.length===0)throw new TypeError("callKwargs requires at least one argument (the key word argument object)");let r=e.pop();if(r.constructor!==void 0&&r.constructor.name!=="Object")throw new TypeError("kwargs argument is not an object");return pe(p(this),e,r)}callRelaxed(...e){return API.pyodide_code.relaxed_call(this,...e)}callKwargsRelaxed(...e){return API.pyodide_code.relaxed_call.callKwargs(this,...e)}callPromising(...e){return de(p(this),e,{})}callPromisingKwargs(...e){if(e.length===0)throw new TypeError("callKwargs requires at least one argument (the key word argument object)");let r=e.pop();if(r.constructor!==void 0&&r.constructor.name!=="Object")throw new TypeError("kwargs argument is not an object");return de(p(this),e,r)}bind(e,...r){let{shared:n,props:o}=S(this),{boundArgs:i,boundThis:s,isBound:l}=o,c=e;l&&(c=s);let u=i.concat(r);return o=Object.assign({},o,{boundArgs:u,isBound:!0,boundThis:c}),J(n.ptr,{shared:n,flags:h(this),props:o})}captureThis(){let{props:e,shared:r}=S(this);return e=Object.assign({},e,{captureThis:!0}),J(r.ptr,{shared:r,flags:h(this),props:e})}};ke.prototype.prototype=Function.prototype;var mn=new Map([["i8",Int8Array],["u8",Uint8Array],["u8clamped",Uint8ClampedArray],["i16",Int16Array],["u16",Uint16Array],["i32",Int32Array],["u32",Uint32Array],["i32",Int32Array],["u32",Uint32Array],["i64",globalThis.BigInt64Array],["u64",globalThis.BigUint64Array],["f32",Float32Array],["f64",Float64Array],["dataview",DataView]]),Me=class extends g{static{a(this,"PyBuffer")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&!!(h(e)&128)}},lt=class{static{a(this,"PyBufferMethods")}getBuffer(e){let r;if(e&&(r=mn.get(e),r===void 0))throw new Error(`Unknown type ${e}`);let n=p(this),o;try{_check_gil();let A=validSuspender.value;validSuspender.value=!1,o=__pyproxy_get_buffer(n),validSuspender.value=A}catch(A){API.fatal_error(A)}o===Module.error&&_pythonexc2js();let{start_ptr:i,smallest_ptr:s,largest_ptr:l,readonly:c,format:u,itemsize:y,shape:_,strides:m,view:f,c_contiguous:I,f_contiguous:oe}=o,ae=!1;try{let A=!1;r===void 0&&([r,A]=Module.processBufferFormatString(u," In this case, you can pass an explicit type argument."));let N=parseInt(r.name.replace(/[^0-9]/g,""))/8||1;if(A&&N>1)throw new Error("JavaScript has no native support for big endian buffers. In this case, you can pass an explicit type argument. For instance, `getBuffer('dataview')` will return a `DataView`which has native support for reading big endian data. Alternatively, toJs will automatically convert the buffer to little endian.");let ie=l-s;if(ie!==0&&(i%N!==0||s%N!==0||l%N!==0))throw new Error(`Buffer does not have valid alignment for a ${r.name}`);let Or=ie/N,Tr=(i-s)/N,We;ie===0?We=new r:We=new r(HEAPU32.buffer,s,Or);for(let Fr of m.keys())m[Fr]/=N;return ae=!0,Object.create(q.prototype,Object.getOwnPropertyDescriptors({offset:Tr,readonly:c,format:u,itemsize:y,ndim:_.length,nbytes:ie,shape:_,strides:m,data:We,c_contiguous:I,f_contiguous:oe,_view_ptr:f,_released:!1}))}finally{if(!ae)try{_check_gil();let A=validSuspender.value;validSuspender.value=!1,_PyBuffer_Release(f),_PyMem_Free(f),validSuspender.value=A}catch(A){API.fatal_error(A)}}}},Ne=class extends g{static{a(this,"PyDict")}static[Symbol.hasInstance](e){return API.isPyProxy(e)&&e.type==="dict"}},q=class{static{a(this,"PyBufferView")}constructor(){throw new TypeError("PyBufferView is not a constructor")}release(){if(!this._released){try{_check_gil();let e=validSuspender.value;validSuspender.value=!1,_PyBuffer_Release(this._view_ptr),_PyMem_Free(this._view_ptr),validSuspender.value=e}catch(e){API.fatal_error(e)}this._released=!0,this.data=Module.error}}};var Gt={PyProxy:g,PyProxyWithLength:fe,PyProxyWithGet:ge,PyProxyWithSet:_e,PyProxyWithHas:me,PyDict:Ne,PyIterable:he,PyAsyncIterable:Pe,PyIterator:be,PyAsyncIterator:xe,PyGenerator:ve,PyAsyncGenerator:we,PyAwaitable:Ie,PyCallable:Ee,PyBuffer:Me,PyBufferView:q,PythonError:R,PySequence:Se,PyMutableSequence:Ae};function Vt(t){t.id!=="canvas"&&console.warn("If you are using canvas element for SDL library, it should have id 'canvas' to work properly."),Module.canvas=t}a(Vt,"setCanvas2D");function Kt(){return Module.canvas}a(Kt,"getCanvas2D");function hn(t){Vt(t)}a(hn,"setCanvas3D");function Pn(){return Kt()}a(Pn,"getCanvas3D");var Jt={setCanvas2D:Vt,getCanvas2D:Kt,setCanvas3D:hn,getCanvas3D:Pn};var qt=new Map([["INSTALLER","pyodide.unpackArchive"]]);function bn(){if(typeof API<"u"&&API!==globalThis.API)return API.runtimeEnv;let t=typeof Bun<"u",e=typeof Deno<"u",r=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string"&&!process.browser,n=typeof navigator=="object"&&typeof navigator.userAgent=="string"&&navigator.userAgent.indexOf("Chrome")===-1&&navigator.userAgent.indexOf("Safari")>-1;return vn({IN_BUN:t,IN_DENO:e,IN_NODE:r,IN_SAFARI:n,IN_SHELL:typeof read=="function"&&typeof load=="function"})}a(bn,"getGlobalRuntimeEnv");var d=bn();function vn(t){let e=t.IN_NODE&&typeof module<"u"&&module.exports&&typeof b=="function"&&typeof __dirname=="string",r=t.IN_NODE&&!e,n=!t.IN_NODE&&!t.IN_DENO&&!t.IN_BUN,o=n&&typeof window<"u"&&typeof window.document<"u"&&typeof document.createElement=="function"&&"sessionStorage"in window&&typeof globalThis.importScripts!="function",i=n&&typeof globalThis.WorkerGlobalScope<"u"&&typeof globalThis.self<"u"&&globalThis.self instanceof globalThis.WorkerGlobalScope;return{...t,IN_BROWSER:n,IN_BROWSER_MAIN_THREAD:o,IN_BROWSER_WEB_WORKER:i,IN_NODE_COMMONJS:e,IN_NODE_ESM:r}}a(vn,"calculateDerivedFlags");function yt(){let t=a(()=>{},"_resolve"),e=a(()=>{},"_reject"),r=new Promise((n,o)=>{t=n,e=o});return r.resolve=t,r.reject=e,r}a(yt,"createResolvable");function Te(){let t=Promise.resolve();async function e(){let r=t,n;return t=new Promise(o=>n=o),await r,n}return a(e,"acquireLock"),e}a(Te,"createLock");var xn=/[-_.]+/g;function Yt(t){return t.replace(xn,"-").toLowerCase()}a(Yt,"canonicalizePackageName");var wn=/^.*?([^\/]*)\.whl$/;function Qt(t){let e=wn.exec(t);if(e){let r=e[1].toLowerCase().split("-");return{name:r[0],version:r[1],fileName:r.join("-")+".whl"}}}a(Qt,"uriToPackageData");function Xt(t){return btoa(t.match(/\w{2}/g).map(function(e){return String.fromCharCode(parseInt(e,16))}).join(""))}a(Xt,"base16ToBase64");var Zt,dt,er,Re,H;async function tr(){if(!d.IN_NODE||(Zt=(await import("node:url")).default,Re=await import("node:fs"),H=await import("node:fs/promises"),er=(await import("node:vm")).default,dt=await import("node:path"),nr=dt.sep,typeof b<"u"))return;let t=Re,e=await import("node:crypto"),r=await import("ws"),n=await import("node:child_process"),o={fs:t,crypto:e,ws:r,child_process:n};globalThis.require=function(i){return o[i]}}a(tr,"initNodeModules");function rr(t){return t.includes("://")||t.startsWith("/")}a(rr,"isAbsolute");function Sn(t,e){return dt.resolve(e||".",t)}a(Sn,"node_resolvePath");function An(t,e){return e===void 0&&(e=location),new URL(t,e).toString()}a(An,"browser_resolvePath");var Y;d.IN_NODE?Y=Sn:d.IN_SHELL?Y=a(t=>t,"resolvePath"):Y=An;var nr;d.IN_NODE||(nr="/");function In(t,e){return t.startsWith("file://")&&(t=t.slice(7)),t.includes("://")?{response:fetch(t)}:{binary:H.readFile(t).then(r=>new Uint8Array(r.buffer,r.byteOffset,r.byteLength))}}a(In,"node_getBinaryResponse");function En(t,e){if(t.startsWith("file://")&&(t=t.slice(7)),t.includes("://"))throw new Error("Shell cannot fetch urls");return{binary:Promise.resolve(new Uint8Array(readbuffer(t)))}}a(En,"shell_getBinaryResponse");function kn(t,e){let r=new URL(t,location);return{response:fetch(r,e?{integrity:e}:{})}}a(kn,"browser_getBinaryResponse");var De;d.IN_NODE?De=In:d.IN_SHELL?De=En:De=kn;async function Q(t,e){let{response:r,binary:n}=De(t,e);if(n)return n;let o=await r;if(!o.ok)throw new Error(`Failed to load '${t}': request failed.`);return new Uint8Array(await o.arrayBuffer())}a(Q,"loadBinaryFile");var Fe;if(d.IN_BROWSER_MAIN_THREAD)Fe=a(async t=>await import(t),"loadScript");else if(d.IN_BROWSER_WEB_WORKER)Fe=a(async t=>{try{globalThis.importScripts(t)}catch(e){if(e instanceof TypeError)await import(t);else throw e}},"loadScript");else if(d.IN_NODE)Fe=Mn;else if(d.IN_SHELL)Fe=load;else throw new Error("Cannot determine runtime environment");async function Mn(t){t.startsWith("file://")&&(t=t.slice(7)),t.includes("://")?er.runInThisContext(await(await fetch(t)).text()):await import(Zt.pathToFileURL(t).href)}a(Mn,"nodeLoadScript");async function or(t){if(d.IN_NODE&&t)try{await H.stat(t)}catch{await H.mkdir(t,{recursive:!0})}}a(or,"ensureDirNode");var X=class{constructor(e,r){this._lock=Te();this.#t=e,this.#e=r}static{a(this,"DynlibLoader")}#t;#e;async loadDynlib(e){let r=await this._lock();try{let n=this.#e.stackSave(),o=this.#e.stringToUTF8OnStack(e);try{let i=this.#e._emscripten_dlopen_promise(o,2);this.#e.stackRestore(n);let s=this.#e.getPromise(i);this.#e.promiseMap.free(i),await s}catch(i){let s=this.getDLError();throw new Error(`Failed to load dynamic library ${e}: ${s??i}`)}}catch(n){throw n&&n.message&&n.message.includes("need to see wasm magic number")?new Error(`Failed to load dynamic library ${e} $. We probably just tried to load a linux .so file or something.`):n}finally{r()}}getDLError(){let e=this.#e._dlerror();return e===0?void 0:this.#e.UTF8ToString(e,512).trim()}async loadDynlibsFromPackage(e,r){for(let n of r)await this.loadDynlib(n)}};if(typeof API<"u"&&typeof Module<"u"){let t=new X(API,Module);API.loadDynlib=t.loadDynlib.bind(t)}var Z=class{static{a(this,"Installer")}#t;#e;constructor(e,r){this.#t=e,this.#e=new X(e,r)}async install(e,r,n,o){let i=this.#t.package_loader.unpack_buffer.callKwargs({buffer:e,filename:r,extract_dir:n,metadata:o,calculate_dynlibs:!0});await this.#e.loadDynlibsFromPackage({file_name:r},i)}},ar;if(typeof API<"u"&&typeof Module<"u"){let t=new Z(API,Module);ar=t.install.bind(t),API.install=ar}function Nn(t,e,r){t();let n;try{n=r()}catch(o){throw e(),o}return n instanceof Promise?n.finally(()=>e()):(e(),n)}a(Nn,"withContext");function ir(t,e){return function(r){return function(...n){return Nn(t,e,()=>r.apply(this,n))}}}a(ir,"createContextWrapper");async function On(t){await tr();let e=await t,r=typeof e=="string"?JSON.parse(e):e;if(!r.packages)throw new Error("Loaded pyodide lock file does not contain the expected key 'packages'.");if(r.info.abi_version!==API.abiVersion)throw new Error(`Lock file ABI version doesn't match Pyodide ABI version.\n lockfile version: ${r.info.abi_version}\n pyodide version: ${API.abiVersion}`);API.lockfile=r,API.lockfile_info=r.info,API.lockfile_packages=r.packages,API.lockfile_unvendored_stdlibs_and_test=[],API._import_name_to_package_name=new Map;for(let i of Object.keys(API.lockfile_packages)){let s=API.lockfile_packages[i];for(let l of s.imports)API._import_name_to_package_name.set(l,i);s.package_type==="cpython_module"&&API.lockfile_unvendored_stdlibs_and_test.push(i)}API.lockfile_unvendored_stdlibs=API.lockfile_unvendored_stdlibs_and_test.filter(i=>i!=="test");let n=API.config.packages;API.config.fullStdLib&&(n=[...n,...API.lockfile_unvendored_stdlibs]),await te(n,{messageCallback(){}}),await API.bootstrapFinalizedPromise,API.flushPackageManagerBuffers(),API._pyodide._importhook.register_module_not_found_hook(API._import_name_to_package_name,API.lockfile_unvendored_stdlibs_and_test),API.package_loader.init_loaded_packages()}a(On,"initializePackageIndex");var Tn="default channel",Fn="pyodide.loadPackage",pt=class{constructor(e,r){this.cdnURL="";this.loadedPackages={};this._lock=Te();this.streamReady=!1;this.stdoutBuffer=[];this.stderrBuffer=[];this.defaultChannel=Tn;this.#t=e,this.#e=r,this.#r=new Z(e,r),d.IN_NODE?(this.installBaseUrl=this.#t.config.packageCacheDir??this.#t.config.packageBaseUrl,this.cdnURL=this.#t.config.cdnUrl):this.installBaseUrl=this.#t.config.packageBaseUrl,this.stdout=n=>{if(!this.streamReady){this.stdoutBuffer.push(n);return}let o=this.#e.stackSave();try{let i=this.#e.stringToUTF8OnStack(n);this.#e._print_stdout(i)}finally{this.#e.stackRestore(o)}},this.stderr=n=>{if(!this.streamReady){this.stderrBuffer.push(n);return}let o=this.#e.stackSave();try{let i=this.#e.stringToUTF8OnStack(n);this.#e._print_stderr(i)}finally{this.#e.stackRestore(o)}}}static{a(this,"PackageManager")}#t;#e;#r;async loadPackage(e,r={checkIntegrity:!0}){return this.setCallbacks(r.messageCallback,r.errorCallback)(this.loadPackageInner.bind(this))(e,r)}async loadPackageInner(e,r={checkIntegrity:!0}){let n=new Set,o=Rn(e),i=this.recursiveDependencies(o);for(let[u,{name:y,normalizedName:_,channel:m}]of i){let f=this.getLoadedPackageChannel(y);f&&(i.delete(_),f===m||m===this.defaultChannel?this.logStdout(`${y} already loaded from ${f}`):this.logStderr(`URI mismatch, attempting to load package ${y} from ${m} while it is already loaded from ${f}. To override a dependency, load the custom package first.`))}if(i.size===0)return this.logStdout("No new packages to load"),[];let s=Array.from(i.values(),({name:u})=>u).sort().join(", "),l=new Map,c=await this._lock();try{this.logStdout(`Loading ${s}`);for(let[u,y]of i){if(this.getLoadedPackageChannel(y.name)){i.delete(y.normalizedName);continue}y.installPromise=this.downloadAndInstall(y,i,n,l,r.checkIntegrity)}if(await Promise.all(Array.from(i.values()).map(({installPromise:u})=>u)),n.size>0){let u=Array.from(n,y=>y.name).sort().join(", ");this.logStdout(`Loaded ${u}`)}if(l.size>0){let u=Array.from(l.keys()).sort().join(", ");this.logStdout(`Failed to load ${u}`);for(let[y,_]of l)this.logStderr(`The following error occurred while loading ${y}:`),this.logStderr(_.message)}return await this.#t.bootstrapFinalizedPromise,this.#t.importlib.invalidate_caches(),Array.from(n,Dn)}finally{c()}}addPackageToLoad(e,r){let n=Yt(e);if(r.has(n))return;let o=this.#t.lockfile_packages[n];if(!o)throw new Error(`No known package with name '${e}'`);if(r.set(n,{name:o.name,normalizedName:n,channel:this.defaultChannel,depends:o.depends,installPromise:void 0,done:yt(),packageData:o}),!this.getLoadedPackageChannel(o.name))for(let i of o.depends)this.addPackageToLoad(i,r)}recursiveDependencies(e){let r=new Map;for(let n of e){let o=Qt(n);if(o===void 0){this.addPackageToLoad(n,r);continue}let{name:i,version:s,fileName:l}=o,c=n;if(r.has(i)&&r.get(i).channel!==c){this.logStderr(`Loading same package ${i} from ${c} and ${r.get(i).channel}`);continue}r.set(i,{name:i,normalizedName:i,channel:c,depends:[],installPromise:void 0,done:yt(),packageData:{name:i,version:s,file_name:l,install_dir:"site",sha256:"",package_type:"package",imports:[],depends:[]}})}return r}async downloadPackage(e,r=!0){await or(this.installBaseUrl);let n,o,i;if(e.channel===this.defaultChannel){if(!(e.normalizedName in this.#t.lockfile_packages))throw new Error(`Internal error: no entry for package named ${name}`);let l=this.#t.lockfile_packages[e.normalizedName];if(n=l.file_name,!rr(n)&&!this.installBaseUrl)throw new Error(`Lock file file_name for package "${e.name}" is relative path "${n}" but no packageBaseUrl provided to loadPyodide.`);o=Y(n,this.installBaseUrl),i="sha256-"+Xt(l.sha256)}else o=e.channel,i=void 0;r||(i=void 0);try{return await Q(o,i)}catch(l){if(!d.IN_NODE||e.channel!==this.defaultChannel||!n||n.startsWith("/"))throw l}this.logStdout(`Didn't find package ${n} locally, attempting to load from ${this.cdnURL}`);let s=await Q(this.cdnURL+n);return this.logStdout(`Package ${n} loaded from ${this.cdnURL}, caching the wheel in node_modules for future use.`),await H.writeFile(o,s),s}async installPackage(e,r){let n=this.#t.lockfile_packages[e.normalizedName];n||(n=e.packageData);let o=n.file_name,i=this.#t.package_loader.get_install_dir(n.install_dir);await this.#r.install(r,o,i,new Map([["INSTALLER",Fn],["PYODIDE_SOURCE",e.channel===this.defaultChannel?"pyodide":e.channel]]))}async downloadAndInstall(e,r,n,o,i=!0){if(ee[e.name]===void 0)try{let s=await this.downloadPackage(e,i),l=e.depends.map(c=>r.has(c)?r.get(c).done:Promise.resolve());await this.#t.bootstrapFinalizedPromise,await Promise.all(l),await this.installPackage(e,s),n.add(e.packageData),ee[e.name]=e.channel}catch(s){o.set(e.name,s)}finally{e.done.resolve()}}flushBuffers(){this.streamReady=!0;for(let e of this.stdoutBuffer)this.stdout(e);for(let e of this.stderrBuffer)this.stderr(e);this.stdoutBuffer=[],this.stderrBuffer=[]}getLoadedPackageChannel(e){let r=this.loadedPackages[e];return r===void 0?null:r}setCallbacks(e,r){let n=this.stdout,o=this.stderr;return ir(()=>{this.stdout=e||n,this.stderr=r||o},()=>{this.stdout=n,this.stderr=o})}logStdout(e){this.stdout(e)}logStderr(e){this.stderr(e)}};function Dn({name:t,version:e,file_name:r,package_type:n}){return{name:t,version:e,fileName:r,packageType:n}}a(Dn,"filterPackageData");function Rn(t){return typeof t.toJs=="function"&&(t=t.toJs()),Array.isArray(t)||(t=[t]),t}a(Rn,"toStringArray");var te,ee;if(typeof API<"u"&&typeof Module<"u"){let t=new pt(API,Module);te=t.loadPackage.bind(t),ee=t.loadedPackages,API.flushPackageManagerBuffers=t.flushBuffers.bind(t),API.lockFilePromise&&(API.packageIndexReady=On(API.lockFilePromise)),API.packageManager=t}var sr="0.29.3";var vt=d.IN_NODE?b("node:fs"):void 0,ur=d.IN_NODE?b("node:tty"):void 0;function yr(t){try{vt.fsyncSync(t)}catch(e){if(e?.code==="EINVAL"||(t===0||t===1||t===2)&&(e?.code==="ENOTSUP"||e?.code==="EBADF"||e?.code==="EPERM"))return;throw e}}a(yr,"nodeFsync");var dr=!1,$e={},x={};function gt(t){$e[x.stdin]=t}a(gt,"_setStdinOps");function Ln(t){$e[x.stdout]=t}a(Ln,"_setStdoutOps");function $n(t){$e[x.stderr]=t}a($n,"_setStderrOps");function Cn(t){return t&&typeof t=="object"&&"errno"in t}a(Cn,"isErrnoError");var Un=new Int32Array(new WebAssembly.Memory({shared:!0,initial:1,maximum:1}).buffer);function Bn(t){try{return Atomics.wait(Un,0,0,t),!0}catch{return!1}}a(Bn,"syncSleep");function Hn(t){for(;;)try{return t()}catch(e){if(e&&e.code==="EAGAIN"&&Bn(100))continue;throw e}}a(Hn,"handleEAGAIN");function lr(t,e,r){let n;try{n=Hn(e)}catch(o){throw o&&o.code&&Module.ERRNO_CODES[o.code]?new FS.ErrnoError(Module.ERRNO_CODES[o.code]):Cn(o)?o:(console.error("Error thrown in read:"),console.error(o),new FS.ErrnoError(29))}if(n===void 0)throw console.warn(`${r} returned undefined; a correct implementation must return a number`),new FS.ErrnoError(29);return n!==0&&(t.node.timestamp=Date.now()),n}a(lr,"readWriteHelper");var cr=a((t,e,r)=>API.typedArrayAsUint8Array(t).subarray(e,e+r),"prepareBuffer"),ft={open:a(function(t){let e=$e[t.node.rdev];if(!e)throw new FS.ErrnoError(43);t.devops=e,t.tty=t.devops.isatty?{ops:{}}:void 0,t.seekable=!1},"open"),close:a(function(t){t.stream_ops.fsync(t)},"close"),fsync:a(function(t){let e=t.devops;e.fsync&&e.fsync()},"fsync"),read:a(function(t,e,r,n,o){return e=cr(e,r,n),lr(t,()=>t.devops.read(e),"read")},"read"),write:a(function(t,e,r,n,o){return e=cr(e,r,n),lr(t,()=>t.devops.write(e),"write")},"write")};function Ce(){dr&&(FS.closeStream(0),FS.closeStream(1),FS.closeStream(2),FS.open("/dev/stdin",0),FS.open("/dev/stdout",1),FS.open("/dev/stderr",1))}a(Ce,"refreshStreams");API.initializeStreams=function(t,e,r){let n=FS.createDevice.major++;x.stdin=FS.makedev(n,0),x.stdout=FS.makedev(n,1),x.stderr=FS.makedev(n,2),FS.registerDevice(x.stdin,ft),FS.registerDevice(x.stdout,ft),FS.registerDevice(x.stderr,ft),FS.unlink("/dev/stdin"),FS.unlink("/dev/stdout"),FS.unlink("/dev/stderr"),FS.mkdev("/dev/stdin",x.stdin),FS.mkdev("/dev/stdout",x.stdout),FS.mkdev("/dev/stderr",x.stderr),re({stdin:t}),xt({batched:e}),wt({batched:r}),dr=!0,Ce()};function jn(){d.IN_NODE?re(new mt(process.stdin.fd)):re({stdin:a(()=>prompt(),"stdin")})}a(jn,"setDefaultStdin");function Wn(){gt(new _t),Ce()}a(Wn,"setStdinError");function re(t={}){let{stdin:e,error:r,isatty:n,autoEOF:o,read:i}=t,s=+!!e+ +!!r+ +!!i;if(s>1)throw new TypeError("At most one of stdin, read, and error must be provided.");if(!e&&o!==void 0)throw new TypeError("The 'autoEOF' option can only be used with the 'stdin' option");if(s===0){jn();return}r&&Wn(),e&&(o=o===void 0?!0:o,gt(new ht(e.bind(t),!!n,o))),i&>(t),Ce()}a(re,"setStdin");function pr(t,e,r){let{raw:n,isatty:o,batched:i,write:s}=t,l=+!!n+ +!!i+ +!!s;if(l===0&&(t=r(),({raw:n,isatty:o,batched:i,write:s}=t)),l>1)throw new TypeError("At most one of 'raw', 'batched', and 'write' must be passed");if(!n&&!s&&o)throw new TypeError("Cannot set 'isatty' to true unless 'raw' or 'write' is provided");n&&e(new Pt(n.bind(t),!!o)),i&&e(new bt(i.bind(t))),s&&e(t),Ce()}a(pr,"_setStdwrite");function zn(){return d.IN_NODE?new Le(process.stdout.fd):{batched:a(t=>console.log(t),"batched")}}a(zn,"_getStdoutDefaults");function Gn(){return d.IN_NODE?new Le(process.stderr.fd):{batched:a(t=>console.warn(t),"batched")}}a(Gn,"_getStderrDefaults");function xt(t={}){pr(t,Ln,zn)}a(xt,"setStdout");function wt(t={}){pr(t,$n,Gn)}a(wt,"setStderr");var Vn=globalThis.TextEncoder??function(){},Kn=new Vn,_t=class{static{a(this,"ErrorReader")}read(e){throw new FS.ErrnoError(29)}},mt=class{static{a(this,"NodeReader")}constructor(e){this.fd=e,this.isatty=ur.isatty(e)}read(e){try{return vt.readSync(this.fd,e)}catch(r){if(r.toString().includes("EOF"))return 0;throw r}}fsync(){yr(this.fd)}},ht=class{static{a(this,"LegacyReader")}constructor(e,r,n){this.infunc=e,this.isatty=r,this.autoEOF=n,this.index=0,this.saved=void 0,this.insertEOF=!1}_getInput(){if(this.saved)return this.saved;let e=this.infunc();if(typeof e=="number")return e;if(e!=null){if(ArrayBuffer.isView(e)){if(e.BYTES_PER_ELEMENT!==1)throw console.warn(`Expected BYTES_PER_ELEMENT to be 1, infunc gave ${e.constructor}`),new FS.ErrnoError(29);return e}if(typeof e=="string")return e.endsWith(`\n`)||(e+=`\n`),e;if(Object.prototype.toString.call(e)==="[object ArrayBuffer]")return new Uint8Array(e);throw console.warn("Expected result to be undefined, null, string, array buffer, or array buffer view"),new FS.ErrnoError(29)}}read(e){if(this.insertEOF)return this.insertEOF=!1,0;let r=0;for(;;){let n=this._getInput();if(typeof n=="number"){e[0]=n,e=e.subarray(1),r++;continue}let o;if(n&&n.length>0)if(typeof n=="string"){let{read:i,written:s}=Kn.encodeInto(n,e);this.saved=n.slice(i),r+=s,o=e[s-1],e=e.subarray(s)}else{let i;n.length>e.length?(e.set(n.subarray(0,e.length)),this.saved=n.subarray(e.length),i=e.length):(e.set(n),this.saved=void 0,i=n.length),r+=i,o=e[i-1],e=e.subarray(i)}if(!(n&&n.length>0)||this.autoEOF||e.length===0)return this.insertEOF=r>0&&this.autoEOF&&o!==10,r}}fsync(){}},Pt=class{static{a(this,"CharacterCodeWriter")}constructor(e,r){this.out=e,this.isatty=r}write(e){for(let r of e)this.out(r);return e.length}},bt=class{constructor(e){this.isatty=!1;this.out=e,this.output=[]}static{a(this,"StringWriter")}write(e){for(let r of e)r===10?(this.out(UTF8ArrayToString(new Uint8Array(this.output))),this.output=[]):r!==0&&this.output.push(r);return e.length}fsync(){this.output&&this.output.length>0&&(this.out(UTF8ArrayToString(new Uint8Array(this.output))),this.output=[])}},Le=class{static{a(this,"NodeWriter")}constructor(e){this.fd=e,this.isatty=ur.isatty(e)}write(e){return vt.writeSync(this.fd,e)}fsync(){yr(this.fd)}};var St="sched$"+Math.random().toString(36).slice(2)+"$",W={},fr=0,j=null,At=[],Jn=typeof globalThis.scheduler?.postTask=="function";function qn(){if(!d.IN_BROWSER_MAIN_THREAD)return;let t=a(e=>{if(typeof e.data=="string"&&e.data.indexOf(St)===0){let r=+e.data.slice(St.length),n=W[r];if(!n)return;try{n()}finally{delete W[r]}}},"onGlobalMessage");globalThis.addEventListener("message",t,!1)}a(qn,"installPostMessageHandler");qn();function Yn(){j||d.IN_SAFARI||d.IN_DENO||d.IN_NODE||typeof globalThis.MessageChannel=="function"&&(j=new MessageChannel,j.port1.onmessage=()=>{let t=At.length;for(let e=0;e({value:t,enumerable:!0,writable:!0,configurable:!0}),"getPropertyDescriptor"),_r=Symbol(),gr="prototype",ro={deleteProperty:a((t,e)=>t.has(e)?t.delete(e):delete t[e],"deleteProperty"),get(t,e,r){if(e===_r)return t;let n=t[e];return typeof n=="function"&&e!=="constructor"&&(n=n.bind(t)),n||=t.get(e),n},getOwnPropertyDescriptor(t,e){if(t.has(e))return to(t.get(e));if(e in t)return Zn(t,e)},has:a((t,e)=>t.has(e)||e in t,"has"),ownKeys:a(t=>[...t.keys(),...eo(t)].filter(e=>["string","symbol"].includes(typeof e)),"ownKeys"),set:a((t,e,r)=>(t.set(e,r),!0),"set")},no=new Proxy(class extends Map{static{a(this,"LiteralMap")}constructor(...e){return new Proxy(super(...e),ro)}},{get(t,e,...r){return e!==gr&&e in t[gr]?(n,...o)=>{let i=n[_r],s=i[e];return typeof s=="function"&&(s=s.apply(i,o)),s===i?n:s}:Xn(t,e,...r)}}),mr=no;var Be=new FinalizationRegistry(t=>void t());function oo(t){let e=new AbortController;for(let l of t)if(l.aborted)return e.abort(l.reason),e.signal;let r=new WeakRef(e),n=[],o=t.length;t.forEach(l=>{let c=new WeakRef(l);function u(){r.deref()?.abort(c.deref()?.reason)}a(u,"abort"),l.addEventListener("abort",u),n.push([c,u]),Be.register(l,()=>!--o&&i(),l)});function i(){n.forEach(([l,c])=>{let u=l.deref();u&&(u.removeEventListener("abort",c),Be.unregister(u));let y=r.deref();y&&(Be.unregister(y.signal),delete y.signal.__controller)})}a(i,"clear");let{signal:s}=e;return Be.register(s,i,s),s.addEventListener("abort",i),s.__controller=e,s}a(oo,"abortSignalAny");var hr=oo;API.getExpectedKeys=function(){return[null,API.config.jsglobals,API.public_api,API,Ue,API,{}]};var xr=Symbol("getAccessorList"),Pr=Symbol("getObject");function He(t,e=[]){return new Proxy(t,{get(r,n,o){if(n===xr)return e;if(n===Pr)return r;let i=Reflect.get(...arguments),s=Reflect.getOwnPropertyDescriptor(r,n);return s&&s.writable===!1&&!s.configurable||s&&s.set&&!s.get||!["object","function"].includes(typeof i)?i:He(i,[...e,n])},apply(r,n,o){return n=n?.[Pr]??n,Reflect.apply(r,n,o)},getPrototypeOf(){return He(Reflect.getPrototypeOf(...arguments),[...e,"[getProtoTypeOf]"])}})}a(He,"makeGlobalsProxy");var wr=1886286592,je=48;function ao(t,e){if(e.length!==8)throw new Error("Expected 256 bit buffer");for(let r=0;r<32;r++)e[r]=parseInt(t.slice(r*8,(r+1)*8),16)}a(ao,"encodeBuildId");function io(t){if(t.length!==8)throw new Error("Expected 256 bit buffer");return Array.from(t,e=>e.toString(16).padStart(8,"0")).join("")}a(io,"decodeBuildId");function br(t,e,r){if(e===r)return;if(typeof r=="function"&&typeof e!="function")throw console.warn(r,e),new Error(`Expected function at index ${t}`);let n=!1;try{n=JSON.stringify(e)===JSON.stringify(r)}catch(o){console.warn(o)}if(!n)throw console.warn(r,e),new Error(`Unexpected hiwire entry at index ${t}`)}a(br,"checkEntry");var ne=6;API.serializeHiwireState=function(t,e){e||(e=br);let r=[],n=API.getExpectedKeys();for(let s=0;svr(i,o)),e.hiwireKeys.forEach((o,i)=>{let s;if(!o)s=o;else if("path"in o)s=o.path.reduce((l,c)=>l[c],t)||null;else if("abortSignalAny"in o)s=API.abortSignalAny;else if("API"in o)s=API;else{if(!r)throw new Error("You must pass an appropriate deserializer as _snapshotDeserializer");s=r(o.serialized)}vr(n.length+i,s)}),e.immortalKeys.forEach(o=>Module.__hiwire_immortal_add(o))}a(Ar,"syncUpSnapshotLoad2");async function Ir(t,e){return new Promise((r,n)=>{t.FS.syncfs(e,o=>{o?n(o):r()})})}a(Ir,"syncfs");async function Er(t){return await Ir(t,!1)}a(Er,"syncLocalToRemote");async function kr(t){return await Ir(t,!0)}a(kr,"syncRemoteToLocal");API.loadBinaryFile=Q;API.rawRun=a(function(e){let r=Module.stringToNewUTF8(e);Module.API.capture_stderr();let n=_PyRun_SimpleString(r);_free(r);let o=Module.API.restore_stderr().trim();return[n,o]},"rawRun");API.runPythonInternal=function(t){return API._pyodide._base.eval_code(t,API.runPythonInternal_dict)};API.setPyProxyToStringMethod=function(t){Module.HEAP8[Module._compat_to_string_repr]=+t};API.setCompatToJsLiteralMap=function(t){Module.HEAP8[Module._compat_dict_to_literalmap]=+t};API.setCompatNullToNone=function(t){Module.HEAP8[Module._compat_null_to_none]=+t};API.saveState=()=>API.pyodide_py._state.save_state();API.restoreState=t=>API.pyodide_py._state.restore_state(t);API.scheduleCallback=Ue;typeof AbortSignal<"u"&&AbortSignal.any?API.abortSignalAny=AbortSignal.any:API.abortSignalAny=hr;API.LiteralMap=mr;function Mr(t){Module.FS.mkdirTree(t);let{node:e}=Module.FS.lookupPath(t,{follow_mount:!1});if(Module.FS.isMountpoint(e))throw new Error(`path '${t}' is already a file system mount point`);if(!Module.FS.isDir(e.mode))throw new Error(`path '${t}' points to a file not a directory`);for(let r in e.contents)throw new Error(`directory '${t}' is not empty`)}a(Mr,"ensureMountPathExists");var It=class{static{a(this,"PyodideAPI_")}static{this.version=sr}static{this.loadPackage=te}static{this.loadedPackages=ee}static{this.ffi=Gt}static{this.setStdin=re}static{this.setStdout=xt}static{this.setStderr=wt}static{this.globals={}}static{this.FS={}}static{this.PATH={}}static{this.canvas=Jt}static{this.ERRNO_CODES={}}static{this.pyodide_py={}}static async loadPackagesFromImports(e,r={checkIntegrity:!0}){let n=API.pyodide_code.find_imports(e),o;try{o=n.toJs()}finally{n.destroy()}if(o.length===0)return[];let i=API._import_name_to_package_name,s=new Set;for(let l of o)i.has(l)&&s.add(i.get(l));return s.size?await te(Array.from(s),r):[]}static runPython(e,r={}){return r.globals||(r.globals=API.globals),API.pyodide_code.eval_code.callKwargs(e,r)}static async runPythonAsync(e,r={}){return r.globals||(r.globals=API.globals),await API.pyodide_code.eval_code_async.callKwargs(e,r)}static registerJsModule(e,r){API.pyodide_ffi.register_js_module(e,r)}static unregisterJsModule(e){API.pyodide_ffi.unregister_js_module(e)}static toPy(e,{depth:r,defaultConverter:n}={depth:-1}){switch(typeof e){case"string":case"number":case"boolean":case"bigint":case"undefined":return e}if(!e||API.isPyProxy(e))return e;let o=0,i=0;try{o=Module.js2python_convert(e,{depth:r,defaultConverter:n})}catch(s){throw s instanceof Module._PropagatePythonError&&_pythonexc2js(),s}try{if(_JsProxy_Check(o))return e;i=_python2js(o),i===null&&_pythonexc2js()}finally{_Py_DecRef(o)}return i}static pyimport(e){return API.pyodide_base.pyimport_impl(e)}static unpackArchive(e,r,n={}){if(!ArrayBuffer.isView(e)&&API.getTypeTag(e)!=="[object ArrayBuffer]")throw new TypeError("Expected argument 'buffer' to be an ArrayBuffer or an ArrayBuffer view");API.typedArrayAsUint8Array(e);let o=n.extractDir;API.package_loader.unpack_buffer.callKwargs({buffer:e,format:r,extract_dir:o,metadata:qt})}static async mountNativeFS(e,r){if(r.constructor.name!=="FileSystemDirectoryHandle")throw new TypeError("Expected argument 'fileSystemHandle' to be a FileSystemDirectoryHandle");return Mr(e),Module.FS.mount(Module.FS.filesystems.NATIVEFS_ASYNC,{fileSystemHandle:r},e),await kr(Module),{syncfs:a(async()=>await Er(Module),"syncfs")}}static mountNodeFS(e,r){if(!d.IN_NODE)throw new Error("mountNodeFS only works in Node");Mr(e);let n;try{n=Re.lstatSync(r)}catch{throw new Error(`hostPath '${r}' does not exist`)}if(!n.isDirectory())throw new Error(`hostPath '${r}' is not a directory`);Module.FS.mount(Module.FS.filesystems.NODEFS,{root:r},e)}static registerComlink(e){API._Comlink=e}static setInterruptBuffer(e){Module.HEAP8[Module._Py_EMSCRIPTEN_SIGNAL_HANDLING]=+!!e,Module.Py_EmscriptenSignalBuffer=e}static checkInterrupt(){if(_PyGILState_Check()){__PyErr_CheckSignals()&&_pythonexc2js();return}else{let e=Module.Py_EmscriptenSignalBuffer;if(e&&e[0]===2)throw new Module.FS.ErrnoError(27)}}static setDebug(e){let r=!!API.debug_ffi;return API.debug_ffi=e,r}static makeMemorySnapshot({serializer:e}={}){if(!API.config._makeSnapshot)throw new Error("Can only use pyodide.makeMemorySnapshot if the _makeSnapshot option is passed to loadPyodide");return API.makeSnapshot(e)}static get lockfile(){return API.lockfile}static get lockfileBaseUrl(){return API.config.packageCacheDir??API.config.packageBaseUrl}};function so(){let t=Object.getOwnPropertyDescriptors(It);delete t.prototype;let e=Object.create({},t);return API.public_api=e,e.FS=Module.FS,e.PATH=Module.PATH,e.ERRNO_CODES=Module.ERRNO_CODES,e._module=Module,e._api=API,e}a(so,"makePublicAPI");function lo(t,e){return new Proxy(t,{get(r,n){return n==="get"?o=>{let i=r.get(o);return i===void 0&&(i=e.get(o)),i}:n==="has"?o=>r.has(o)||e.has(o):Reflect.get(r,n)}})}a(lo,"wrapPythonGlobals");var Nr;API.bootstrapFinalizedPromise=new Promise(t=>Nr=t);API.finalizeBootstrap=function(t,e){t&&Sr();let[r,n]=API.rawRun("import _pyodide_core");r&&API.fatal_loading_error(`Failed to import _pyodide_core\n`,n),API.runPythonInternal_dict=API._pyodide._base.eval_code("{}"),API.importlib=API.runPythonInternal("import importlib; importlib");let o=API.importlib.import_module;API.sys=o("sys"),API.os=o("os");let i=API.runPythonInternal("import __main__; __main__.__dict__"),s=API.runPythonInternal("import builtins; builtins.__dict__");API.globals=lo(i,s);let l=API._pyodide._importhook,c=so();API.config._makeSnapshot&&(API.config.jsglobals=He(API.config.jsglobals));let u=API.config.jsglobals;return t?Ar(u,t,e):(l.register_js_finder(),l.register_js_module("js",u),l.register_js_module("pyodide_js",c),l.register_windows_finder()),API.pyodide_py=o("pyodide"),API.pyodide_code=o("pyodide.code"),API.pyodide_ffi=o("pyodide.ffi"),API.package_loader=o("pyodide._package_loader"),API.pyodide_base=o("_pyodide._base"),API.sitepackages=API.package_loader.SITE_PACKAGES.__str__(),API.dsodir=API.package_loader.DSO_DIR.__str__(),API.defaultLdLibraryPath=[API.dsodir,API.sitepackages],API.os.environ.__setitem__("LD_LIBRARY_PATH",API.defaultLdLibraryPath.join(":")),c.pyodide_py=API.pyodide_py,c.globals=API.globals,Nr(),c}})()}var StackSwitching=(()=>{var __defProp=Object.defineProperty;var __getOwnPropDesc=Object.getOwnPropertyDescriptor;var __getOwnPropNames=Object.getOwnPropertyNames;var __hasOwnProp=Object.prototype.hasOwnProperty;var __export=(target,all)=>{for(var name in all)__defProp(target,name,{get:all[name],enumerable:true})};var __copyProps=(to,from,except,desc)=>{if(from&&typeof from==="object"||typeof from==="function"){for(let key of __getOwnPropNames(from))if(!__hasOwnProp.call(to,key)&&key!==except)__defProp(to,key,{get:()=>from[key],enumerable:!(desc=__getOwnPropDesc(from,key))||desc.enumerable})}return to};var __toCommonJS=mod=>__copyProps(__defProp({},"__esModule",{value:true}),mod);var stack_switching_exports={};__export(stack_switching_exports,{StackState:()=>StackState,createPromising:()=>createPromising,jspiSupported:()=>jspiSupported,newJspiSupported:()=>newJspiSupported,oldJspiSupported:()=>oldJspiSupported,promisingApply:()=>promisingApply,promisingRunMain:()=>promisingRunMain,suspenderGlobal:()=>suspenderGlobal,validSuspender:()=>validSuspender});var suspenderGlobal={value:null};var validSuspender={value:false};var promisingApplyHandler;function promisingApply(...args){validSuspender.value=true;Module.stackStop=stackSave();return promisingApplyHandler(...args)}var promisingRunMainHandler;function promisingRunMain(...args){validSuspender.value=true;Module.stackStop=stackSave();return promisingRunMainHandler(...args)}function createPromising(wasm_func){if(Module.newJspiSupported){const promisingFunc=WebAssembly.promising(wasm_func);async function wrapper(...args){const orig=validSuspender.value;validSuspender.value=true;try{return await promisingFunc(null,...args)}finally{validSuspender.value=orig}}return wrapper}const{parameters}=wasmFunctionType(wasm_func);parameters.shift();return new WebAssembly.Function({parameters,results:["externref"]},wasm_func,{promising:"first"})}function initSuspenders(){promisingApplyHandler=createPromising(wasmExports._pyproxy_apply_promising);if(wasmExports.run_main_promising){promisingRunMainHandler=createPromising(wasmExports.run_main_promising)}}var stackStates=[];var StackState=class{constructor(){this.start=stackSave();this.stop=Module.stackStop;this._copy=new Uint8Array(0);if(this.start!==this.stop){stackStates.push(this)}}restore(){let total=0;while(stackStates.length>0&&stackStates[stackStates.length-1].stop>>0,this.start+sz2>>>0);const c=new Uint8Array(sz2);c.set(this._copy);c.set(new_segment,sz1);this._copy=c;return sz2}_save(){return this._save_up_to(this.stop)}};var canConstructWasm=true;try{new WebAssembly.Module(new Uint8Array([0,97,115,109,1,0,0,0]))}catch(e){canConstructWasm=false}var newJspiSupported=canConstructWasm&&"Suspending"in WebAssembly;var oldJspiSupported=canConstructWasm&&"Suspender"in WebAssembly;var jspiSupported=newJspiSupported||oldJspiSupported;Module.newJspiSupported=newJspiSupported;Module.oldJspiSupported=oldJspiSupported;Module.jspiSupported=jspiSupported;if(jspiSupported){Module.preRun.push(initSuspenders)}return __toCommonJS(stack_switching_exports)})();const{StackState,createPromising,jspiSupported,newJspiSupported,oldJspiSupported,promisingApply,promisingRunMain,suspenderGlobal,validSuspender}=StackSwitching;Object.assign(Module,StackSwitching);const API=Module.API;const Hiwire={};const Tests={};API.tests=Tests;API.version="0.29.3";API.abiVersion="2025_0";Module.hiwire=Hiwire;function getTypeTag(x){try{return Object.prototype.toString.call(x)}catch(e){return""}}API.getTypeTag=getTypeTag;function hasProperty(obj,prop){try{while(obj){if(Object.hasOwn(obj,prop)){return true}obj=Object.getPrototypeOf(obj)}}catch(e){}return false}function hasMethod(obj,prop){try{return typeof obj[prop]==="function"}catch(e){return false}}const pyproxyIsAlive=px=>!!Module.PyProxy_getAttrsQuiet(px).shared.ptr;API.pyproxyIsAlive=pyproxyIsAlive;const errNoRet=()=>{throw new Error("Assertion error: control reached end of function without return")};function isPromise(obj){try{return typeof obj?.then==="function"}catch(e){return false}}API.isPromise=isPromise;function bufferAsUint8Array(arg){if(ArrayBuffer.isView(arg)){return new Uint8Array(arg.buffer,arg.byteOffset,arg.byteLength)}else{return new Uint8Array(arg)}}API.typedArrayAsUint8Array=bufferAsUint8Array;Module.iterObject=function*(object){for(let k in object){if(Object.hasOwn(object,k)){yield k}}};function wasmFunctionType(wasm_func){if(!WebAssembly.Function){throw new Error("No type reflection")}if(WebAssembly.Function.type){return WebAssembly.Function.type(wasm_func)}return wasm_func.type()}pyodide_js_init();pyodide_js_init.sig="v";function set_suspender(suspender){suspenderGlobal.value=suspender}set_suspender.sig="ve";function get_suspender(){return suspenderGlobal.value}get_suspender.sig="e";function syncifyHandler(x,y){return Module.error}async function inner(x,y){try{return await(x??y)}catch(e){if(e&&e.pyodide_fatal_error){throw e}Module.syncify_error=e;return Module.error}}if(newJspiSupported){syncifyHandler=new WebAssembly.Suspending(inner)}else if(oldJspiSupported){syncifyHandler=new WebAssembly.Function({parameters:["externref","externref"],results:["externref"]},inner,{suspending:"first"})}syncifyHandler.sig="eee";function JsvPromise_Syncify_handleError(){if(!Module.syncify_error){return}Module.handle_js_error(Module.syncify_error);delete Module.syncify_error}JsvPromise_Syncify_handleError.sig="v";function saveState(){if(!validSuspender.value){return Module.error}const stackState=new StackState;const threadState=_captureThreadState();return{threadState,stackState,suspender:suspenderGlobal.value}}saveState.sig="e";function restoreState(state){state.stackState.restore();_restoreThreadState(state.threadState);suspenderGlobal.value=state.suspender;validSuspender.value=true}restoreState.sig="ve";function _Py_emscripten_runtime(){var info;if(typeof navigator=="object"){info=navigator.userAgent}else if(typeof process=="object"){info="Node.js ".concat(process.version)}else{info="UNKNOWN"}var len=lengthBytesUTF8(info)+1;var res=_malloc(len);if(res)stringToUTF8(info,res,len);return res}_Py_emscripten_runtime.sig="i";function _Py_CheckEmscriptenSignals_Helper(){if(!Module.Py_EmscriptenSignalBuffer){return 0}try{let result=Module.Py_EmscriptenSignalBuffer[0];Module.Py_EmscriptenSignalBuffer[0]=0;return result}catch(e){return 0}}_Py_CheckEmscriptenSignals_Helper.sig="i";function _PyEM_GetCountArgsPtr(){return Module._PyEM_CountArgsPtr}_PyEM_GetCountArgsPtr.sig="i";function _PyEM_InitTrampoline_js(){const ptr=getPyEMCountArgsPtr();Module._PyEM_CountArgsPtr=ptr;const offset=HEAP32[__PyEM_EMSCRIPTEN_COUNT_ARGS_OFFSET/4>>>0];HEAP32[(__PyRuntime+offset)/4>>>0]=ptr}function getPyEMCountArgsPtr(){let isIOS=globalThis.navigator&&(/iPad|iPhone|iPod/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&typeof navigator.maxTouchPoints!=="undefined"&&navigator.maxTouchPoints>1);if(isIOS){return 0}const code=new Uint8Array([0,97,115,109,1,0,0,0,1,27,5,96,0,1,127,96,1,127,1,127,96,2,127,127,1,127,96,3,127,127,127,1,127,96,1,127,0,2,9,1,1,101,1,116,1,112,0,0,3,2,1,1,7,5,1,1,102,0,0,10,68,1,66,1,1,112,32,0,37,0,34,1,251,20,3,2,4,69,13,0,65,3,15,11,32,1,251,20,2,2,4,69,13,0,65,2,15,11,32,1,251,20,1,2,4,69,13,0,65,1,15,11,32,1,251,20,0,2,4,69,13,0,65,0,15,11,65,127,11]);try{const mod=new WebAssembly.Module(code);const inst=new WebAssembly.Instance(mod,{e:{t:wasmTable}});return addFunction(inst.exports.f)}catch(e){return 0}}_PyEM_InitTrampoline_js.sig="v";function _PyEM_TrampolineCall_JS(func,arg1,arg2,arg3){return wasmTable.get(func)(arg1,arg2,arg3)}_PyEM_TrampolineCall_JS.sig="iiiii";function unbox_small_structs(type_ptr){var type_id=HEAPU16[(type_ptr+6>>1)+0>>>0];while(type_id===13){var elements=HEAPU32[(type_ptr+8>>2)+0>>>0];var first_element=HEAPU32[(elements>>2)+0>>>0];if(first_element===0){type_id=0;break}else if(HEAPU32[(elements>>2)+1>>>0]===0){type_ptr=first_element;type_id=HEAPU16[(first_element+6>>1)+0>>>0]}else{break}}return[type_ptr,type_id]}function ffi_call_js(cif,fn,rvalue,avalue){var abi=HEAPU32[(cif>>2)+0>>>0];var nargs=HEAPU32[(cif>>2)+1>>>0];var nfixedargs=HEAPU32[(cif>>2)+6>>>0];var arg_types_ptr=HEAPU32[(cif>>2)+2>>>0];var rtype_unboxed=unbox_small_structs(HEAPU32[(cif>>2)+3>>>0]);var rtype_ptr=rtype_unboxed[0];var rtype_id=rtype_unboxed[1];var orig_stack_ptr=stackSave();var cur_stack_ptr=orig_stack_ptr;var args=[];var ret_by_arg=!!0;if(rtype_id===15){throw new Error("complex ret marshalling nyi")}if(rtype_id<0||rtype_id>15){throw new Error("Unexpected rtype "+rtype_id)}if(rtype_id===4||rtype_id===13){args.push(rvalue);ret_by_arg=!!1}for(var i=0;i>2)+i>>>0];var arg_unboxed=unbox_small_structs(HEAPU32[(arg_types_ptr>>2)+i>>>0]);var arg_type_ptr=arg_unboxed[0];var arg_type_id=arg_unboxed[1];switch(arg_type_id){case 1:case 10:case 9:case 14:args.push(HEAPU32[(arg_ptr>>2)+0>>>0]);break;case 2:args.push(HEAPF32[(arg_ptr>>2)+0>>>0]);break;case 3:args.push(HEAPF64[(arg_ptr>>3)+0>>>0]);break;case 5:args.push(HEAPU8[arg_ptr+0>>>0]);break;case 6:args.push(HEAP8[arg_ptr+0>>>0]);break;case 7:args.push(HEAPU16[(arg_ptr>>1)+0>>>0]);break;case 8:args.push(HEAP16[(arg_ptr>>1)+0>>>0]);break;case 11:case 12:args.push(HEAPU64[(arg_ptr>>3)+0>>>0]);break;case 4:args.push(HEAPU64[(arg_ptr>>3)+0>>>0]);args.push(HEAPU64[(arg_ptr>>3)+1>>>0]);break;case 13:var size=HEAPU32[(arg_type_ptr>>2)+0>>>0];var align=HEAPU16[(arg_type_ptr+4>>1)+0>>>0];cur_stack_ptr-=size,cur_stack_ptr&=~(align-1);HEAP8.subarray(cur_stack_ptr>>>0,cur_stack_ptr+size>>>0).set(HEAP8.subarray(arg_ptr>>>0,arg_ptr+size>>>0));args.push(cur_stack_ptr);break;case 15:throw new Error("complex marshalling nyi");default:throw new Error("Unexpected type "+arg_type_id)}}if(nfixedargs!=nargs){var struct_arg_info=[];for(var i=nargs-1;i>=nfixedargs;i--){var arg_ptr=HEAPU32[(avalue>>2)+i>>>0];var arg_unboxed=unbox_small_structs(HEAPU32[(arg_types_ptr>>2)+i>>>0]);var arg_type_ptr=arg_unboxed[0];var arg_type_id=arg_unboxed[1];switch(arg_type_id){case 5:case 6:cur_stack_ptr-=1,cur_stack_ptr&=~(1-1);HEAPU8[cur_stack_ptr+0>>>0]=HEAPU8[arg_ptr+0>>>0];break;case 7:case 8:cur_stack_ptr-=2,cur_stack_ptr&=~(2-1);HEAPU16[(cur_stack_ptr>>1)+0>>>0]=HEAPU16[(arg_ptr>>1)+0>>>0];break;case 1:case 9:case 10:case 14:case 2:cur_stack_ptr-=4,cur_stack_ptr&=~(4-1);HEAPU32[(cur_stack_ptr>>2)+0>>>0]=HEAPU32[(arg_ptr>>2)+0>>>0];break;case 3:case 11:case 12:cur_stack_ptr-=8,cur_stack_ptr&=~(8-1);HEAPU32[(cur_stack_ptr>>2)+0>>>0]=HEAPU32[(arg_ptr>>2)+0>>>0];HEAPU32[(cur_stack_ptr>>2)+1>>>0]=HEAPU32[(arg_ptr>>2)+1>>>0];break;case 4:cur_stack_ptr-=16,cur_stack_ptr&=~(8-1);HEAPU32[(cur_stack_ptr>>2)+0>>>0]=HEAPU32[(arg_ptr>>2)+0>>>0];HEAPU32[(cur_stack_ptr>>2)+1>>>0]=HEAPU32[(arg_ptr>>2)+1>>>0];HEAPU32[(cur_stack_ptr>>2)+2>>>0]=HEAPU32[(arg_ptr>>2)+2>>>0];HEAPU32[(cur_stack_ptr>>2)+3>>>0]=HEAPU32[(arg_ptr>>2)+3>>>0];break;case 13:cur_stack_ptr-=4,cur_stack_ptr&=~(4-1);struct_arg_info.push([cur_stack_ptr,arg_ptr,HEAPU32[(arg_type_ptr>>2)+0>>>0],HEAPU16[(arg_type_ptr+4>>1)+0>>>0]]);break;case 15:throw new Error("complex arg marshalling nyi");default:throw new Error("Unexpected argtype "+arg_type_id)}}args.push(cur_stack_ptr);for(var i=0;i>>0,cur_stack_ptr+size>>>0).set(HEAP8.subarray(arg_ptr>>>0,arg_ptr+size>>>0));HEAPU32[(arg_target>>2)+0>>>0]=cur_stack_ptr}}stackRestore(cur_stack_ptr);stackAlloc(0);var result=(0,getWasmTableEntry(fn).apply(null,args));stackRestore(orig_stack_ptr);if(ret_by_arg){return}switch(rtype_id){case 0:break;case 1:case 9:case 10:case 14:HEAPU32[(rvalue>>2)+0>>>0]=result;break;case 2:HEAPF32[(rvalue>>2)+0>>>0]=result;break;case 3:HEAPF64[(rvalue>>3)+0>>>0]=result;break;case 5:case 6:HEAPU8[rvalue+0>>>0]=result;break;case 7:case 8:HEAPU16[(rvalue>>1)+0>>>0]=result;break;case 11:case 12:HEAPU64[(rvalue>>3)+0>>>0]=result;break;case 15:throw new Error("complex ret marshalling nyi");default:throw new Error("Unexpected rtype "+rtype_id)}}ffi_call_js.sig="viiii";function ffi_closure_alloc_js(size,code){var closure=_malloc(size);var index=getEmptyTableSlot();HEAPU32[(code>>2)+0>>>0]=index;HEAPU32[(closure>>2)+0>>>0]=index;return closure}ffi_closure_alloc_js.sig="iii";function ffi_closure_free_js(closure){var index=HEAPU32[(closure>>2)+0>>>0];freeTableIndexes.push(index);_free(closure)}ffi_closure_free_js.sig="vi";function ffi_prep_closure_loc_js(closure,cif,fun,user_data,codeloc){var abi=HEAPU32[(cif>>2)+0>>>0];var nargs=HEAPU32[(cif>>2)+1>>>0];var nfixedargs=HEAPU32[(cif>>2)+6>>>0];var arg_types_ptr=HEAPU32[(cif>>2)+2>>>0];var rtype_unboxed=unbox_small_structs(HEAPU32[(cif>>2)+3>>>0]);var rtype_ptr=rtype_unboxed[0];var rtype_id=rtype_unboxed[1];var sig;var ret_by_arg=!!0;switch(rtype_id){case 0:sig="v";break;case 13:case 4:sig="vi";ret_by_arg=!!1;break;case 1:case 5:case 6:case 7:case 8:case 9:case 10:case 14:sig="i";break;case 2:sig="f";break;case 3:sig="d";break;case 11:case 12:sig="j";break;case 15:throw new Error("complex ret marshalling nyi");default:throw new Error("Unexpected rtype "+rtype_id)}var unboxed_arg_type_id_list=[];var unboxed_arg_type_info_list=[];for(var i=0;i>2)+i>>>0]);var arg_type_ptr=arg_unboxed[0];var arg_type_id=arg_unboxed[1];unboxed_arg_type_id_list.push(arg_type_id);unboxed_arg_type_info_list.push([HEAPU32[(arg_type_ptr>>2)+0>>>0],HEAPU16[(arg_type_ptr+4>>1)+0>>>0]])}for(var i=0;i>2)+carg_idx>>>0]=cur_ptr;HEAPU8[cur_ptr+0>>>0]=cur_arg;break;case 7:case 8:cur_ptr-=2,cur_ptr&=~(4-1);HEAPU32[(args_ptr>>2)+carg_idx>>>0]=cur_ptr;HEAPU16[(cur_ptr>>1)+0>>>0]=cur_arg;break;case 1:case 9:case 10:case 14:cur_ptr-=4,cur_ptr&=~(4-1);HEAPU32[(args_ptr>>2)+carg_idx>>>0]=cur_ptr;HEAPU32[(cur_ptr>>2)+0>>>0]=cur_arg;break;case 13:cur_ptr-=arg_size,cur_ptr&=~(arg_align-1);HEAP8.subarray(cur_ptr>>>0,cur_ptr+arg_size>>>0).set(HEAP8.subarray(cur_arg>>>0,cur_arg+arg_size>>>0));HEAPU32[(args_ptr>>2)+carg_idx>>>0]=cur_ptr;break;case 2:cur_ptr-=4,cur_ptr&=~(4-1);HEAPU32[(args_ptr>>2)+carg_idx>>>0]=cur_ptr;HEAPF32[(cur_ptr>>2)+0>>>0]=cur_arg;break;case 3:cur_ptr-=8,cur_ptr&=~(8-1);HEAPU32[(args_ptr>>2)+carg_idx>>>0]=cur_ptr;HEAPF64[(cur_ptr>>3)+0>>>0]=cur_arg;break;case 11:case 12:cur_ptr-=8,cur_ptr&=~(8-1);HEAPU32[(args_ptr>>2)+carg_idx>>>0]=cur_ptr;HEAPU64[(cur_ptr>>3)+0>>>0]=cur_arg;break;case 4:cur_ptr-=16,cur_ptr&=~(8-1);HEAPU32[(args_ptr>>2)+carg_idx>>>0]=cur_ptr;HEAPU64[(cur_ptr>>3)+0>>>0]=cur_arg;cur_arg=args[jsarg_idx++];HEAPU64[(cur_ptr>>3)+1>>>0]=cur_arg;break}}var varargs=args[args.length-1];for(;carg_idx>2)+0>>>0];cur_ptr-=arg_size,cur_ptr&=~(arg_align-1);HEAP8.subarray(cur_ptr>>>0,cur_ptr+arg_size>>>0).set(HEAP8.subarray(struct_ptr>>>0,struct_ptr+arg_size>>>0));HEAPU32[(args_ptr>>2)+carg_idx>>>0]=cur_ptr}else{HEAPU32[(args_ptr>>2)+carg_idx>>>0]=varargs}varargs+=4}stackRestore(cur_ptr);stackAlloc(0);0;getWasmTableEntry(HEAPU32[(closure>>2)+2>>>0])(HEAPU32[(closure>>2)+1>>>0],ret_ptr,args_ptr,HEAPU32[(closure>>2)+3>>>0]);stackRestore(orig_stack_ptr);if(!ret_by_arg){switch(sig[0]){case"i":return HEAPU32[(ret_ptr>>2)+0>>>0];case"j":return HEAPU64[(ret_ptr>>3)+0>>>0];case"d":return HEAPF64[(ret_ptr>>3)+0>>>0];case"f":return HEAPF32[(ret_ptr>>2)+0>>>0]}}}try{var wasm_trampoline=convertJsFunctionToWasm(trampoline,sig)}catch(e){return 1}setWasmTableEntry(codeloc,wasm_trampoline);HEAPU32[(closure>>2)+1>>>0]=cif;HEAPU32[(closure>>2)+2>>>0]=fun;HEAPU32[(closure>>2)+3>>>0]=user_data;return 0}ffi_prep_closure_loc_js.sig="iiiiii";function __hiwire_deduplicate_new(){return new Map}__hiwire_deduplicate_new.sig="e";function __hiwire_deduplicate_get(map,value){return map.get(value)}__hiwire_deduplicate_get.sig="iee";function __hiwire_deduplicate_set(map,value,ref){map.set(value,ref)}__hiwire_deduplicate_set.sig="veei";function __hiwire_deduplicate_delete(map,value){map.delete(value)}__hiwire_deduplicate_delete.sig="vee";var wasmImports={IMG_Init:_IMG_Init,IMG_Load:_IMG_Load,IMG_Load_RW:_IMG_Load_RW,IMG_Quit:_IMG_Quit,JsArray_count_js,JsArray_index_js,JsArray_inplace_repeat_js,JsArray_repeat_js,JsArray_reverse_js,JsArray_reversed_iterator,JsBuffer_DecodeString_js,JsBuffer_get_info,JsDoubleProxy_unwrap_js,JsException_new_helper,JsMap_GetIter_js,JsMap_clear_js,JsModule_GetAll_js,JsObjMap_GetIter_js,JsObjMap_ass_subscript_js,JsObjMap_contains_js,JsObjMap_length_js,JsObjMap_subscript_js,JsProxy_Bool_js,JsProxy_DelAttr_js,JsProxy_Dir_js,JsProxy_GetAsyncIter_js,JsProxy_GetAttr_js,JsProxy_GetIter_js,JsProxy_SetAttr_js,JsProxy_compute_typeflags,JsProxy_subscript_js,JsProxy_to_weakref_js,JsvArray_Check,JsvArray_Delete,JsvArray_Extend,JsvArray_Get,JsvArray_Insert,JsvArray_New,JsvArray_Push,JsvArray_Set,JsvArray_ShallowCopy,JsvArray_slice,JsvArray_slice_assign,JsvAsyncGenerator_Check,JsvBuffer_assignFromPtr,JsvBuffer_assignToPtr,JsvBuffer_intoFile,JsvBuffer_readFromFile,JsvBuffer_writeToFile,JsvError_Throw,JsvFunction_CallBound,JsvFunction_Call_OneArg,JsvFunction_Check,JsvFunction_Construct,JsvGenerator_Check,JsvLiteralMap_New,JsvMap_New,JsvMap_Set,JsvNoValue_Check,JsvNum_fromDigits,JsvNum_fromDouble,JsvNum_fromInt,JsvObject_CallMethod,JsvObject_CallMethod_NoArgs,JsvObject_CallMethod_OneArg,JsvObject_CallMethod_TwoArgs,JsvObject_Entries,JsvObject_Keys,JsvObject_New,JsvObject_SetAttr,JsvObject_Values,JsvObject_toString,JsvPromise_Check,JsvPromise_Resolve,JsvPromise_Syncify_handleError,JsvSet_Add,JsvSet_New,JsvUTF8ToString,Jsv_constructorName,Jsv_equal,Jsv_greater_than,Jsv_greater_than_equal,Jsv_less_than,Jsv_less_than_equal,Jsv_not_equal,Jsv_to_bool,Jsv_typeof,Mix_AllocateChannels:_Mix_AllocateChannels,Mix_ChannelFinished:_Mix_ChannelFinished,Mix_CloseAudio:_Mix_CloseAudio,Mix_FadeInChannelTimed:_Mix_FadeInChannelTimed,Mix_FadeInMusicPos:_Mix_FadeInMusicPos,Mix_FadeOutChannel:_Mix_FadeOutChannel,Mix_FadeOutMusic:_Mix_FadeOutMusic,Mix_FadingChannel:_Mix_FadingChannel,Mix_FreeChunk:_Mix_FreeChunk,Mix_FreeMusic:_Mix_FreeMusic,Mix_HaltChannel:_Mix_HaltChannel,Mix_HaltMusic:_Mix_HaltMusic,Mix_HookMusicFinished:_Mix_HookMusicFinished,Mix_Init:_Mix_Init,Mix_Linked_Version:_Mix_Linked_Version,Mix_LoadMUS:_Mix_LoadMUS,Mix_LoadMUS_RW:_Mix_LoadMUS_RW,Mix_LoadWAV:_Mix_LoadWAV,Mix_LoadWAV_RW:_Mix_LoadWAV_RW,Mix_OpenAudio:_Mix_OpenAudio,Mix_Pause:_Mix_Pause,Mix_PauseMusic:_Mix_PauseMusic,Mix_Paused:_Mix_Paused,Mix_PausedMusic:_Mix_PausedMusic,Mix_PlayChannelTimed:_Mix_PlayChannelTimed,Mix_PlayMusic:_Mix_PlayMusic,Mix_Playing:_Mix_Playing,Mix_PlayingMusic:_Mix_PlayingMusic,Mix_QuerySpec:_Mix_QuerySpec,Mix_QuickLoad_RAW:_Mix_QuickLoad_RAW,Mix_Quit:_Mix_Quit,Mix_ReserveChannels:_Mix_ReserveChannels,Mix_Resume:_Mix_Resume,Mix_ResumeMusic:_Mix_ResumeMusic,Mix_SetPanning:_Mix_SetPanning,Mix_SetPosition:_Mix_SetPosition,Mix_SetPostMix:_Mix_SetPostMix,Mix_Volume:_Mix_Volume,Mix_VolumeChunk:_Mix_VolumeChunk,Mix_VolumeMusic:_Mix_VolumeMusic,SDL_AddTimer:_SDL_AddTimer,SDL_AllocRW:_SDL_AllocRW,SDL_AudioDriverName:_SDL_AudioDriverName,SDL_AudioQuit:_SDL_AudioQuit,SDL_ClearError:_SDL_ClearError,SDL_CloseAudio:_SDL_CloseAudio,SDL_CondBroadcast:_SDL_CondBroadcast,SDL_CondSignal:_SDL_CondSignal,SDL_CondWait:_SDL_CondWait,SDL_CondWaitTimeout:_SDL_CondWaitTimeout,SDL_ConvertSurface:_SDL_ConvertSurface,SDL_CreateCond:_SDL_CreateCond,SDL_CreateMutex:_SDL_CreateMutex,SDL_CreateRGBSurface:_SDL_CreateRGBSurface,SDL_CreateRGBSurfaceFrom:_SDL_CreateRGBSurfaceFrom,SDL_CreateThread:_SDL_CreateThread,SDL_Delay:_SDL_Delay,SDL_DestroyCond:_SDL_DestroyCond,SDL_DestroyMutex:_SDL_DestroyMutex,SDL_DestroyRenderer:_SDL_DestroyRenderer,SDL_DestroyWindow:_SDL_DestroyWindow,SDL_DisplayFormat:_SDL_DisplayFormat,SDL_DisplayFormatAlpha:_SDL_DisplayFormatAlpha,SDL_EnableKeyRepeat:_SDL_EnableKeyRepeat,SDL_EnableUNICODE:_SDL_EnableUNICODE,SDL_FillRect:_SDL_FillRect,SDL_Flip:_SDL_Flip,SDL_FreeRW:_SDL_FreeRW,SDL_FreeSurface:_SDL_FreeSurface,SDL_GL_DeleteContext:_SDL_GL_DeleteContext,SDL_GL_ExtensionSupported:_SDL_GL_ExtensionSupported,SDL_GL_GetAttribute:_SDL_GL_GetAttribute,SDL_GL_GetSwapInterval:_SDL_GL_GetSwapInterval,SDL_GL_MakeCurrent:_SDL_GL_MakeCurrent,SDL_GL_SetAttribute:_SDL_GL_SetAttribute,SDL_GL_SetSwapInterval:_SDL_GL_SetSwapInterval,SDL_GL_SwapBuffers:_SDL_GL_SwapBuffers,SDL_GL_SwapWindow:_SDL_GL_SwapWindow,SDL_GetAppState:_SDL_GetAppState,SDL_GetAudioDriver:_SDL_GetAudioDriver,SDL_GetClipRect:_SDL_GetClipRect,SDL_GetCurrentAudioDriver:_SDL_GetCurrentAudioDriver,SDL_GetError:_SDL_GetError,SDL_GetKeyName:_SDL_GetKeyName,SDL_GetKeyState:_SDL_GetKeyState,SDL_GetKeyboardState:_SDL_GetKeyboardState,SDL_GetModState:_SDL_GetModState,SDL_GetMouseState:_SDL_GetMouseState,SDL_GetNumAudioDrivers:_SDL_GetNumAudioDrivers,SDL_GetRGB:_SDL_GetRGB,SDL_GetRGBA:_SDL_GetRGBA,SDL_GetScancodeFromKey:_SDL_GetScancodeFromKey,SDL_GetThreadID:_SDL_GetThreadID,SDL_GetTicks:_SDL_GetTicks,SDL_GetVideoInfo:_SDL_GetVideoInfo,SDL_GetVideoSurface:_SDL_GetVideoSurface,SDL_GetWindowFlags:_SDL_GetWindowFlags,SDL_GetWindowSize:_SDL_GetWindowSize,SDL_Has3DNow:_SDL_Has3DNow,SDL_Has3DNowExt:_SDL_Has3DNowExt,SDL_HasAltiVec:_SDL_HasAltiVec,SDL_HasMMX:_SDL_HasMMX,SDL_HasMMXExt:_SDL_HasMMXExt,SDL_HasRDTSC:_SDL_HasRDTSC,SDL_HasSSE:_SDL_HasSSE,SDL_HasSSE2:_SDL_HasSSE2,SDL_Init:_SDL_Init,SDL_InitSubSystem:_SDL_InitSubSystem,SDL_JoystickClose:_SDL_JoystickClose,SDL_JoystickEventState:_SDL_JoystickEventState,SDL_JoystickGetAxis:_SDL_JoystickGetAxis,SDL_JoystickGetBall:_SDL_JoystickGetBall,SDL_JoystickGetButton:_SDL_JoystickGetButton,SDL_JoystickGetHat:_SDL_JoystickGetHat,SDL_JoystickIndex:_SDL_JoystickIndex,SDL_JoystickName:_SDL_JoystickName,SDL_JoystickNumAxes:_SDL_JoystickNumAxes,SDL_JoystickNumBalls:_SDL_JoystickNumBalls,SDL_JoystickNumButtons:_SDL_JoystickNumButtons,SDL_JoystickNumHats:_SDL_JoystickNumHats,SDL_JoystickOpen:_SDL_JoystickOpen,SDL_JoystickOpened:_SDL_JoystickOpened,SDL_JoystickUpdate:_SDL_JoystickUpdate,SDL_Linked_Version:_SDL_Linked_Version,SDL_ListModes:_SDL_ListModes,SDL_LoadBMP_RW:_SDL_LoadBMP_RW,SDL_LockAudio:_SDL_LockAudio,SDL_LockSurface:_SDL_LockSurface,SDL_LogSetOutputFunction:_SDL_LogSetOutputFunction,SDL_LowerBlit:_SDL_LowerBlit,SDL_LowerBlitScaled:_SDL_LowerBlitScaled,SDL_MapRGB:_SDL_MapRGB,SDL_MapRGBA:_SDL_MapRGBA,SDL_NumJoysticks:_SDL_NumJoysticks,SDL_OpenAudio:_SDL_OpenAudio,SDL_PauseAudio:_SDL_PauseAudio,SDL_PeepEvents:_SDL_PeepEvents,SDL_PollEvent:_SDL_PollEvent,SDL_PumpEvents:_SDL_PumpEvents,SDL_PushEvent:_SDL_PushEvent,SDL_Quit:_SDL_Quit,SDL_QuitSubSystem:_SDL_QuitSubSystem,SDL_RWFromConstMem:_SDL_RWFromConstMem,SDL_RWFromFile:_SDL_RWFromFile,SDL_RWFromMem:_SDL_RWFromMem,SDL_RemoveTimer:_SDL_RemoveTimer,SDL_SaveBMP_RW:_SDL_SaveBMP_RW,SDL_SetAlpha:_SDL_SetAlpha,SDL_SetClipRect:_SDL_SetClipRect,SDL_SetColorKey:_SDL_SetColorKey,SDL_SetColors:_SDL_SetColors,SDL_SetError:_SDL_SetError,SDL_SetGamma:_SDL_SetGamma,SDL_SetGammaRamp:_SDL_SetGammaRamp,SDL_SetPalette:_SDL_SetPalette,SDL_SetVideoMode:_SDL_SetVideoMode,SDL_SetWindowFullscreen:_SDL_SetWindowFullscreen,SDL_SetWindowTitle:_SDL_SetWindowTitle,SDL_ShowCursor:_SDL_ShowCursor,SDL_StartTextInput:_SDL_StartTextInput,SDL_StopTextInput:_SDL_StopTextInput,SDL_ThreadID:_SDL_ThreadID,SDL_UnlockAudio:_SDL_UnlockAudio,SDL_UnlockSurface:_SDL_UnlockSurface,SDL_UpdateRect:_SDL_UpdateRect,SDL_UpdateRects:_SDL_UpdateRects,SDL_UpperBlit:_SDL_UpperBlit,SDL_UpperBlitScaled:_SDL_UpperBlitScaled,SDL_VideoDriverName:_SDL_VideoDriverName,SDL_VideoModeOK:_SDL_VideoModeOK,SDL_VideoQuit:_SDL_VideoQuit,SDL_WM_GrabInput:_SDL_WM_GrabInput,SDL_WM_IconifyWindow:_SDL_WM_IconifyWindow,SDL_WM_SetCaption:_SDL_WM_SetCaption,SDL_WM_SetIcon:_SDL_WM_SetIcon,SDL_WM_ToggleFullScreen:_SDL_WM_ToggleFullScreen,SDL_WaitThread:_SDL_WaitThread,SDL_WarpMouse:_SDL_WarpMouse,SDL_WasInit:_SDL_WasInit,SDL_mutexP:_SDL_mutexP,SDL_mutexV:_SDL_mutexV,TTF_CloseFont:_TTF_CloseFont,TTF_FontAscent:_TTF_FontAscent,TTF_FontDescent:_TTF_FontDescent,TTF_FontHeight:_TTF_FontHeight,TTF_FontLineSkip:_TTF_FontLineSkip,TTF_GlyphMetrics:_TTF_GlyphMetrics,TTF_Init:_TTF_Init,TTF_OpenFont:_TTF_OpenFont,TTF_Quit:_TTF_Quit,TTF_RenderText_Blended:_TTF_RenderText_Blended,TTF_RenderText_Shaded:_TTF_RenderText_Shaded,TTF_RenderText_Solid:_TTF_RenderText_Solid,TTF_RenderUTF8_Solid:_TTF_RenderUTF8_Solid,TTF_SizeText:_TTF_SizeText,TTF_SizeUTF8:_TTF_SizeUTF8,_JsArray_PostProcess_helper,_JsArray_PushEntry_helper,_JsObject_Set_js,_PyEM_GetCountArgsPtr,_PyEM_InitTrampoline_js,_PyEM_TrampolineCall_JS,_Py_CheckEmscriptenSignals_Helper,_Py_emscripten_runtime,_Unwind_Backtrace:__Unwind_Backtrace,_Unwind_FindEnclosingFunction:__Unwind_FindEnclosingFunction,_Unwind_GetIPInfo:__Unwind_GetIPInfo,__asctime_r:___asctime_r,__assert_fail:___assert_fail,__c_longjmp:___c_longjmp,__call_sighandler:___call_sighandler,__cpp_exception:___cpp_exception,__global_base:___global_base,__heap_base:___heap_base,__hiwire_deduplicate_delete,__hiwire_deduplicate_get,__hiwire_deduplicate_new,__hiwire_deduplicate_set,__indirect_function_table:wasmTable,__memory_base:___memory_base,__stack_high:___stack_high,__stack_low:___stack_low,__stack_pointer:___stack_pointer,__syscall__newselect:___syscall__newselect,__syscall_accept4:___syscall_accept4,__syscall_bind:___syscall_bind,__syscall_chdir:___syscall_chdir,__syscall_chmod:___syscall_chmod,__syscall_connect:___syscall_connect,__syscall_dup:___syscall_dup,__syscall_dup3:___syscall_dup3,__syscall_faccessat:___syscall_faccessat,__syscall_fadvise64:___syscall_fadvise64,__syscall_fallocate:___syscall_fallocate,__syscall_fchdir:___syscall_fchdir,__syscall_fchmod:___syscall_fchmod,__syscall_fchmodat2:___syscall_fchmodat2,__syscall_fchown32:___syscall_fchown32,__syscall_fchownat:___syscall_fchownat,__syscall_fcntl64:___syscall_fcntl64,__syscall_fdatasync:___syscall_fdatasync,__syscall_fstat64:___syscall_fstat64,__syscall_fstatfs64:___syscall_fstatfs64,__syscall_ftruncate64:___syscall_ftruncate64,__syscall_getcwd:___syscall_getcwd,__syscall_getdents64:___syscall_getdents64,__syscall_getpeername:___syscall_getpeername,__syscall_getsockname:___syscall_getsockname,__syscall_getsockopt:___syscall_getsockopt,__syscall_ioctl:___syscall_ioctl,__syscall_listen:___syscall_listen,__syscall_lstat64:___syscall_lstat64,__syscall_mkdirat:___syscall_mkdirat,__syscall_mknodat:___syscall_mknodat,__syscall_newfstatat:___syscall_newfstatat,__syscall_openat:___syscall_openat,__syscall_pipe:___syscall_pipe,__syscall_poll:___syscall_poll,__syscall_readlinkat:___syscall_readlinkat,__syscall_recvfrom:___syscall_recvfrom,__syscall_recvmsg:___syscall_recvmsg,__syscall_renameat:___syscall_renameat,__syscall_rmdir:___syscall_rmdir,__syscall_sendmsg:___syscall_sendmsg,__syscall_sendto:___syscall_sendto,__syscall_socket:___syscall_socket,__syscall_stat64:___syscall_stat64,__syscall_statfs64:___syscall_statfs64,__syscall_symlinkat:___syscall_symlinkat,__syscall_truncate64:___syscall_truncate64,__syscall_unlinkat:___syscall_unlinkat,__syscall_utimensat:___syscall_utimensat,__table_base:___table_base,_abort_js:__abort_js,_agen_handle_result_js,_dlopen_js:__dlopen_js,_dlsym_catchup_js:__dlsym_catchup_js,_dlsym_js:__dlsym_js,_emscripten_dlopen_js:__emscripten_dlopen_js,_emscripten_fs_load_embedded_files:__emscripten_fs_load_embedded_files,_emscripten_get_now_is_monotonic:__emscripten_get_now_is_monotonic,_emscripten_get_progname:__emscripten_get_progname,_emscripten_lookup_name:__emscripten_lookup_name,_emscripten_push_main_loop_blocker:__emscripten_push_main_loop_blocker,_emscripten_push_uncounted_main_loop_blocker:__emscripten_push_uncounted_main_loop_blocker,_emscripten_runtime_keepalive_clear:__emscripten_runtime_keepalive_clear,_emscripten_system:__emscripten_system,_glGetActiveAttribOrUniform:__glGetActiveAttribOrUniform,_gmtime_js:__gmtime_js,_localtime_js:__localtime_js,_mktime_js:__mktime_js,_mmap_js:__mmap_js,_msync_js:__msync_js,_munmap_js:__munmap_js,_pyproxyGen_make_result,_pyproxy_get_buffer_result,_python2js_add_to_cache,_python2js_addto_postprocess_list,_python2js_buffer_inner,_python2js_cache_lookup,_python2js_handle_postprocess_list,_python2js_ucs1,_python2js_ucs2,_python2js_ucs4,_setitimer_js:__setitimer_js,_timegm_js:__timegm_js,_tzset_js:__tzset_js,array_to_js,boxColor:_boxColor,boxRGBA:_boxRGBA,can_run_sync_js,capture_stderr,clock_res_get:_clock_res_get,clock_time_get:_clock_time_get,create_once_callable,create_promise_handles,create_sentinel:_create_sentinel,destroy_jsarray_entries,destroy_proxies,destroy_proxies_js,destroy_proxy,eglBindAPI:_eglBindAPI,eglChooseConfig:_eglChooseConfig,eglCreateContext:_eglCreateContext,eglCreateWindowSurface:_eglCreateWindowSurface,eglDestroyContext:_eglDestroyContext,eglDestroySurface:_eglDestroySurface,eglGetConfigAttrib:_eglGetConfigAttrib,eglGetConfigs:_eglGetConfigs,eglGetCurrentContext:_eglGetCurrentContext,eglGetCurrentDisplay:_eglGetCurrentDisplay,eglGetCurrentSurface:_eglGetCurrentSurface,eglGetDisplay:_eglGetDisplay,eglGetError:_eglGetError,eglInitialize:_eglInitialize,eglMakeCurrent:_eglMakeCurrent,eglQueryAPI:_eglQueryAPI,eglQueryContext:_eglQueryContext,eglQueryString:_eglQueryString,eglQuerySurface:_eglQuerySurface,eglReleaseThread:_eglReleaseThread,eglSwapBuffers:_eglSwapBuffers,eglSwapInterval:_eglSwapInterval,eglTerminate:_eglTerminate,eglWaitClient:_eglWaitClient,eglWaitGL:_eglWaitGL,eglWaitNative:_eglWaitNative,ellipseColor:_ellipseColor,ellipseRGBA:_ellipseRGBA,emscripten_SDL_SetEventHandler:_emscripten_SDL_SetEventHandler,emscripten_asm_const_async_on_main_thread:_emscripten_asm_const_async_on_main_thread,emscripten_asm_const_double:_emscripten_asm_const_double,emscripten_asm_const_double_sync_on_main_thread:_emscripten_asm_const_double_sync_on_main_thread,emscripten_asm_const_int:_emscripten_asm_const_int,emscripten_asm_const_int_sync_on_main_thread:_emscripten_asm_const_int_sync_on_main_thread,emscripten_asm_const_ptr:_emscripten_asm_const_ptr,emscripten_asm_const_ptr_sync_on_main_thread:_emscripten_asm_const_ptr_sync_on_main_thread,emscripten_async_call:_emscripten_async_call,emscripten_async_load_script:_emscripten_async_load_script,emscripten_async_run_script:_emscripten_async_run_script,emscripten_async_wget:_emscripten_async_wget,emscripten_async_wget2:_emscripten_async_wget2,emscripten_async_wget2_abort:_emscripten_async_wget2_abort,emscripten_async_wget2_data:_emscripten_async_wget2_data,emscripten_async_wget_data:_emscripten_async_wget_data,emscripten_call_worker:_emscripten_call_worker,emscripten_cancel_animation_frame:_emscripten_cancel_animation_frame,emscripten_cancel_main_loop:_emscripten_cancel_main_loop,emscripten_clear_immediate:_emscripten_clear_immediate,emscripten_clear_interval:_emscripten_clear_interval,emscripten_clear_timeout:_emscripten_clear_timeout,emscripten_console_error:_emscripten_console_error,emscripten_console_log:_emscripten_console_log,emscripten_console_trace:_emscripten_console_trace,emscripten_console_warn:_emscripten_console_warn,emscripten_create_worker:_emscripten_create_worker,emscripten_date_now:_emscripten_date_now,emscripten_debugger:_emscripten_debugger,emscripten_destroy_worker:_emscripten_destroy_worker,emscripten_enter_soft_fullscreen:_emscripten_enter_soft_fullscreen,emscripten_err:_emscripten_err,emscripten_errn:_emscripten_errn,emscripten_exit_fullscreen:_emscripten_exit_fullscreen,emscripten_exit_pointerlock:_emscripten_exit_pointerlock,emscripten_exit_soft_fullscreen:_emscripten_exit_soft_fullscreen,emscripten_exit_with_live_runtime:_emscripten_exit_with_live_runtime,emscripten_force_exit:_emscripten_force_exit,emscripten_get_battery_status:_emscripten_get_battery_status,emscripten_get_callstack:_emscripten_get_callstack,emscripten_get_canvas_element_size:_emscripten_get_canvas_element_size,emscripten_get_canvas_size:_emscripten_get_canvas_size,emscripten_get_compiler_setting:_emscripten_get_compiler_setting,emscripten_get_device_pixel_ratio:_emscripten_get_device_pixel_ratio,emscripten_get_devicemotion_status:_emscripten_get_devicemotion_status,emscripten_get_deviceorientation_status:_emscripten_get_deviceorientation_status,emscripten_get_element_css_size:_emscripten_get_element_css_size,emscripten_get_fullscreen_status:_emscripten_get_fullscreen_status,emscripten_get_gamepad_status:_emscripten_get_gamepad_status,emscripten_get_heap_max:_emscripten_get_heap_max,emscripten_get_main_loop_timing:_emscripten_get_main_loop_timing,emscripten_get_mouse_status:_emscripten_get_mouse_status,emscripten_get_now:_emscripten_get_now,emscripten_get_now_res:_emscripten_get_now_res,emscripten_get_num_gamepads:_emscripten_get_num_gamepads,emscripten_get_orientation_status:_emscripten_get_orientation_status,emscripten_get_pointerlock_status:_emscripten_get_pointerlock_status,emscripten_get_preloaded_image_data:_emscripten_get_preloaded_image_data,emscripten_get_preloaded_image_data_from_FILE:_emscripten_get_preloaded_image_data_from_FILE,emscripten_get_screen_size:_emscripten_get_screen_size,emscripten_get_visibility_status:_emscripten_get_visibility_status,emscripten_get_window_title:_emscripten_get_window_title,emscripten_get_worker_queue_size:_emscripten_get_worker_queue_size,emscripten_glActiveTexture:_emscripten_glActiveTexture,emscripten_glAttachShader:_emscripten_glAttachShader,emscripten_glBegin:_emscripten_glBegin,emscripten_glBeginQuery:_emscripten_glBeginQuery,emscripten_glBeginQueryEXT:_emscripten_glBeginQueryEXT,emscripten_glBeginTransformFeedback:_emscripten_glBeginTransformFeedback,emscripten_glBindAttribLocation:_emscripten_glBindAttribLocation,emscripten_glBindBuffer:_emscripten_glBindBuffer,emscripten_glBindBufferBase:_emscripten_glBindBufferBase,emscripten_glBindBufferRange:_emscripten_glBindBufferRange,emscripten_glBindFramebuffer:_emscripten_glBindFramebuffer,emscripten_glBindRenderbuffer:_emscripten_glBindRenderbuffer,emscripten_glBindSampler:_emscripten_glBindSampler,emscripten_glBindTexture:_emscripten_glBindTexture,emscripten_glBindTransformFeedback:_emscripten_glBindTransformFeedback,emscripten_glBindVertexArray:_emscripten_glBindVertexArray,emscripten_glBindVertexArrayOES:_emscripten_glBindVertexArrayOES,emscripten_glBlendColor:_emscripten_glBlendColor,emscripten_glBlendEquation:_emscripten_glBlendEquation,emscripten_glBlendEquationSeparate:_emscripten_glBlendEquationSeparate,emscripten_glBlendFunc:_emscripten_glBlendFunc,emscripten_glBlendFuncSeparate:_emscripten_glBlendFuncSeparate,emscripten_glBlitFramebuffer:_emscripten_glBlitFramebuffer,emscripten_glBufferData:_emscripten_glBufferData,emscripten_glBufferSubData:_emscripten_glBufferSubData,emscripten_glCheckFramebufferStatus:_emscripten_glCheckFramebufferStatus,emscripten_glClear:_emscripten_glClear,emscripten_glClearBufferfi:_emscripten_glClearBufferfi,emscripten_glClearBufferfv:_emscripten_glClearBufferfv,emscripten_glClearBufferiv:_emscripten_glClearBufferiv,emscripten_glClearBufferuiv:_emscripten_glClearBufferuiv,emscripten_glClearColor:_emscripten_glClearColor,emscripten_glClearDepth:_emscripten_glClearDepth,emscripten_glClearDepthf:_emscripten_glClearDepthf,emscripten_glClearStencil:_emscripten_glClearStencil,emscripten_glClientWaitSync:_emscripten_glClientWaitSync,emscripten_glClipControlEXT:_emscripten_glClipControlEXT,emscripten_glColorMask:_emscripten_glColorMask,emscripten_glCompileShader:_emscripten_glCompileShader,emscripten_glCompressedTexImage2D:_emscripten_glCompressedTexImage2D,emscripten_glCompressedTexImage3D:_emscripten_glCompressedTexImage3D,emscripten_glCompressedTexSubImage2D:_emscripten_glCompressedTexSubImage2D,emscripten_glCompressedTexSubImage3D:_emscripten_glCompressedTexSubImage3D,emscripten_glCopyBufferSubData:_emscripten_glCopyBufferSubData,emscripten_glCopyTexImage2D:_emscripten_glCopyTexImage2D,emscripten_glCopyTexSubImage2D:_emscripten_glCopyTexSubImage2D,emscripten_glCopyTexSubImage3D:_emscripten_glCopyTexSubImage3D,emscripten_glCreateProgram:_emscripten_glCreateProgram,emscripten_glCreateShader:_emscripten_glCreateShader,emscripten_glCullFace:_emscripten_glCullFace,emscripten_glDeleteBuffers:_emscripten_glDeleteBuffers,emscripten_glDeleteFramebuffers:_emscripten_glDeleteFramebuffers,emscripten_glDeleteProgram:_emscripten_glDeleteProgram,emscripten_glDeleteQueries:_emscripten_glDeleteQueries,emscripten_glDeleteQueriesEXT:_emscripten_glDeleteQueriesEXT,emscripten_glDeleteRenderbuffers:_emscripten_glDeleteRenderbuffers,emscripten_glDeleteSamplers:_emscripten_glDeleteSamplers,emscripten_glDeleteShader:_emscripten_glDeleteShader,emscripten_glDeleteSync:_emscripten_glDeleteSync,emscripten_glDeleteTextures:_emscripten_glDeleteTextures,emscripten_glDeleteTransformFeedbacks:_emscripten_glDeleteTransformFeedbacks,emscripten_glDeleteVertexArrays:_emscripten_glDeleteVertexArrays,emscripten_glDeleteVertexArraysOES:_emscripten_glDeleteVertexArraysOES,emscripten_glDepthFunc:_emscripten_glDepthFunc,emscripten_glDepthMask:_emscripten_glDepthMask,emscripten_glDepthRange:_emscripten_glDepthRange,emscripten_glDepthRangef:_emscripten_glDepthRangef,emscripten_glDetachShader:_emscripten_glDetachShader,emscripten_glDisable:_emscripten_glDisable,emscripten_glDisableVertexAttribArray:_emscripten_glDisableVertexAttribArray,emscripten_glDrawArrays:_emscripten_glDrawArrays,emscripten_glDrawArraysInstanced:_emscripten_glDrawArraysInstanced,emscripten_glDrawArraysInstancedANGLE:_emscripten_glDrawArraysInstancedANGLE,emscripten_glDrawArraysInstancedARB:_emscripten_glDrawArraysInstancedARB,emscripten_glDrawArraysInstancedBaseInstance:_emscripten_glDrawArraysInstancedBaseInstance,emscripten_glDrawArraysInstancedBaseInstanceANGLE:_emscripten_glDrawArraysInstancedBaseInstanceANGLE,emscripten_glDrawArraysInstancedBaseInstanceWEBGL:_emscripten_glDrawArraysInstancedBaseInstanceWEBGL,emscripten_glDrawArraysInstancedEXT:_emscripten_glDrawArraysInstancedEXT,emscripten_glDrawArraysInstancedNV:_emscripten_glDrawArraysInstancedNV,emscripten_glDrawBuffers:_emscripten_glDrawBuffers,emscripten_glDrawBuffersEXT:_emscripten_glDrawBuffersEXT,emscripten_glDrawBuffersWEBGL:_emscripten_glDrawBuffersWEBGL,emscripten_glDrawElements:_emscripten_glDrawElements,emscripten_glDrawElementsInstanced:_emscripten_glDrawElementsInstanced,emscripten_glDrawElementsInstancedANGLE:_emscripten_glDrawElementsInstancedANGLE,emscripten_glDrawElementsInstancedARB:_emscripten_glDrawElementsInstancedARB,emscripten_glDrawElementsInstancedBaseVertexBaseInstanceANGLE:_emscripten_glDrawElementsInstancedBaseVertexBaseInstanceANGLE,emscripten_glDrawElementsInstancedBaseVertexBaseInstanceWEBGL:_emscripten_glDrawElementsInstancedBaseVertexBaseInstanceWEBGL,emscripten_glDrawElementsInstancedEXT:_emscripten_glDrawElementsInstancedEXT,emscripten_glDrawElementsInstancedNV:_emscripten_glDrawElementsInstancedNV,emscripten_glDrawRangeElements:_emscripten_glDrawRangeElements,emscripten_glEnable:_emscripten_glEnable,emscripten_glEnableVertexAttribArray:_emscripten_glEnableVertexAttribArray,emscripten_glEndQuery:_emscripten_glEndQuery,emscripten_glEndQueryEXT:_emscripten_glEndQueryEXT,emscripten_glEndTransformFeedback:_emscripten_glEndTransformFeedback,emscripten_glFenceSync:_emscripten_glFenceSync,emscripten_glFinish:_emscripten_glFinish,emscripten_glFlush:_emscripten_glFlush,emscripten_glFramebufferRenderbuffer:_emscripten_glFramebufferRenderbuffer,emscripten_glFramebufferTexture2D:_emscripten_glFramebufferTexture2D,emscripten_glFramebufferTextureLayer:_emscripten_glFramebufferTextureLayer,emscripten_glFrontFace:_emscripten_glFrontFace,emscripten_glGenBuffers:_emscripten_glGenBuffers,emscripten_glGenFramebuffers:_emscripten_glGenFramebuffers,emscripten_glGenQueries:_emscripten_glGenQueries,emscripten_glGenQueriesEXT:_emscripten_glGenQueriesEXT,emscripten_glGenRenderbuffers:_emscripten_glGenRenderbuffers,emscripten_glGenSamplers:_emscripten_glGenSamplers,emscripten_glGenTextures:_emscripten_glGenTextures,emscripten_glGenTransformFeedbacks:_emscripten_glGenTransformFeedbacks,emscripten_glGenVertexArrays:_emscripten_glGenVertexArrays,emscripten_glGenVertexArraysOES:_emscripten_glGenVertexArraysOES,emscripten_glGenerateMipmap:_emscripten_glGenerateMipmap,emscripten_glGetActiveAttrib:_emscripten_glGetActiveAttrib,emscripten_glGetActiveUniform:_emscripten_glGetActiveUniform,emscripten_glGetActiveUniformBlockName:_emscripten_glGetActiveUniformBlockName,emscripten_glGetActiveUniformBlockiv:_emscripten_glGetActiveUniformBlockiv,emscripten_glGetActiveUniformsiv:_emscripten_glGetActiveUniformsiv,emscripten_glGetAttachedShaders:_emscripten_glGetAttachedShaders,emscripten_glGetAttribLocation:_emscripten_glGetAttribLocation,emscripten_glGetBooleanv:_emscripten_glGetBooleanv,emscripten_glGetBufferParameteri64v:_emscripten_glGetBufferParameteri64v,emscripten_glGetBufferParameteriv:_emscripten_glGetBufferParameteriv,emscripten_glGetBufferSubData:_emscripten_glGetBufferSubData,emscripten_glGetError:_emscripten_glGetError,emscripten_glGetFloatv:_emscripten_glGetFloatv,emscripten_glGetFragDataLocation:_emscripten_glGetFragDataLocation,emscripten_glGetFramebufferAttachmentParameteriv:_emscripten_glGetFramebufferAttachmentParameteriv,emscripten_glGetInteger64i_v:_emscripten_glGetInteger64i_v,emscripten_glGetInteger64v:_emscripten_glGetInteger64v,emscripten_glGetIntegeri_v:_emscripten_glGetIntegeri_v,emscripten_glGetIntegerv:_emscripten_glGetIntegerv,emscripten_glGetInternalformativ:_emscripten_glGetInternalformativ,emscripten_glGetProgramBinary:_emscripten_glGetProgramBinary,emscripten_glGetProgramInfoLog:_emscripten_glGetProgramInfoLog,emscripten_glGetProgramiv:_emscripten_glGetProgramiv,emscripten_glGetQueryObjecti64vEXT:_emscripten_glGetQueryObjecti64vEXT,emscripten_glGetQueryObjectivEXT:_emscripten_glGetQueryObjectivEXT,emscripten_glGetQueryObjectui64vEXT:_emscripten_glGetQueryObjectui64vEXT,emscripten_glGetQueryObjectuiv:_emscripten_glGetQueryObjectuiv,emscripten_glGetQueryObjectuivEXT:_emscripten_glGetQueryObjectuivEXT,emscripten_glGetQueryiv:_emscripten_glGetQueryiv,emscripten_glGetQueryivEXT:_emscripten_glGetQueryivEXT,emscripten_glGetRenderbufferParameteriv:_emscripten_glGetRenderbufferParameteriv,emscripten_glGetSamplerParameterfv:_emscripten_glGetSamplerParameterfv,emscripten_glGetSamplerParameteriv:_emscripten_glGetSamplerParameteriv,emscripten_glGetShaderInfoLog:_emscripten_glGetShaderInfoLog,emscripten_glGetShaderPrecisionFormat:_emscripten_glGetShaderPrecisionFormat,emscripten_glGetShaderSource:_emscripten_glGetShaderSource,emscripten_glGetShaderiv:_emscripten_glGetShaderiv,emscripten_glGetString:_emscripten_glGetString,emscripten_glGetStringi:_emscripten_glGetStringi,emscripten_glGetSynciv:_emscripten_glGetSynciv,emscripten_glGetTexParameterfv:_emscripten_glGetTexParameterfv,emscripten_glGetTexParameteriv:_emscripten_glGetTexParameteriv,emscripten_glGetTransformFeedbackVarying:_emscripten_glGetTransformFeedbackVarying,emscripten_glGetUniformBlockIndex:_emscripten_glGetUniformBlockIndex,emscripten_glGetUniformIndices:_emscripten_glGetUniformIndices,emscripten_glGetUniformLocation:_emscripten_glGetUniformLocation,emscripten_glGetUniformfv:_emscripten_glGetUniformfv,emscripten_glGetUniformiv:_emscripten_glGetUniformiv,emscripten_glGetUniformuiv:_emscripten_glGetUniformuiv,emscripten_glGetVertexAttribIiv:_emscripten_glGetVertexAttribIiv,emscripten_glGetVertexAttribIuiv:_emscripten_glGetVertexAttribIuiv,emscripten_glGetVertexAttribPointerv:_emscripten_glGetVertexAttribPointerv,emscripten_glGetVertexAttribfv:_emscripten_glGetVertexAttribfv,emscripten_glGetVertexAttribiv:_emscripten_glGetVertexAttribiv,emscripten_glHint:_emscripten_glHint,emscripten_glInvalidateFramebuffer:_emscripten_glInvalidateFramebuffer,emscripten_glInvalidateSubFramebuffer:_emscripten_glInvalidateSubFramebuffer,emscripten_glIsBuffer:_emscripten_glIsBuffer,emscripten_glIsEnabled:_emscripten_glIsEnabled,emscripten_glIsFramebuffer:_emscripten_glIsFramebuffer,emscripten_glIsProgram:_emscripten_glIsProgram,emscripten_glIsQuery:_emscripten_glIsQuery,emscripten_glIsQueryEXT:_emscripten_glIsQueryEXT,emscripten_glIsRenderbuffer:_emscripten_glIsRenderbuffer,emscripten_glIsSampler:_emscripten_glIsSampler,emscripten_glIsShader:_emscripten_glIsShader,emscripten_glIsSync:_emscripten_glIsSync,emscripten_glIsTexture:_emscripten_glIsTexture,emscripten_glIsTransformFeedback:_emscripten_glIsTransformFeedback,emscripten_glIsVertexArray:_emscripten_glIsVertexArray,emscripten_glIsVertexArrayOES:_emscripten_glIsVertexArrayOES,emscripten_glLineWidth:_emscripten_glLineWidth,emscripten_glLinkProgram:_emscripten_glLinkProgram,emscripten_glLoadIdentity:_emscripten_glLoadIdentity,emscripten_glMatrixMode:_emscripten_glMatrixMode,emscripten_glMultiDrawArrays:_emscripten_glMultiDrawArrays,emscripten_glMultiDrawArraysANGLE:_emscripten_glMultiDrawArraysANGLE,emscripten_glMultiDrawArraysInstancedANGLE:_emscripten_glMultiDrawArraysInstancedANGLE,emscripten_glMultiDrawArraysInstancedBaseInstanceANGLE:_emscripten_glMultiDrawArraysInstancedBaseInstanceANGLE,emscripten_glMultiDrawArraysInstancedBaseInstanceWEBGL:_emscripten_glMultiDrawArraysInstancedBaseInstanceWEBGL,emscripten_glMultiDrawArraysInstancedWEBGL:_emscripten_glMultiDrawArraysInstancedWEBGL,emscripten_glMultiDrawArraysWEBGL:_emscripten_glMultiDrawArraysWEBGL,emscripten_glMultiDrawElements:_emscripten_glMultiDrawElements,emscripten_glMultiDrawElementsANGLE:_emscripten_glMultiDrawElementsANGLE,emscripten_glMultiDrawElementsInstancedANGLE:_emscripten_glMultiDrawElementsInstancedANGLE,emscripten_glMultiDrawElementsInstancedBaseVertexBaseInstanceANGLE:_emscripten_glMultiDrawElementsInstancedBaseVertexBaseInstanceANGLE,emscripten_glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL:_emscripten_glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL,emscripten_glMultiDrawElementsInstancedWEBGL:_emscripten_glMultiDrawElementsInstancedWEBGL,emscripten_glMultiDrawElementsWEBGL:_emscripten_glMultiDrawElementsWEBGL,emscripten_glPauseTransformFeedback:_emscripten_glPauseTransformFeedback,emscripten_glPixelStorei:_emscripten_glPixelStorei,emscripten_glPolygonModeWEBGL:_emscripten_glPolygonModeWEBGL,emscripten_glPolygonOffset:_emscripten_glPolygonOffset,emscripten_glPolygonOffsetClampEXT:_emscripten_glPolygonOffsetClampEXT,emscripten_glProgramBinary:_emscripten_glProgramBinary,emscripten_glProgramParameteri:_emscripten_glProgramParameteri,emscripten_glQueryCounterEXT:_emscripten_glQueryCounterEXT,emscripten_glReadBuffer:_emscripten_glReadBuffer,emscripten_glReadPixels:_emscripten_glReadPixels,emscripten_glReleaseShaderCompiler:_emscripten_glReleaseShaderCompiler,emscripten_glRenderbufferStorage:_emscripten_glRenderbufferStorage,emscripten_glRenderbufferStorageMultisample:_emscripten_glRenderbufferStorageMultisample,emscripten_glResumeTransformFeedback:_emscripten_glResumeTransformFeedback,emscripten_glSampleCoverage:_emscripten_glSampleCoverage,emscripten_glSamplerParameterf:_emscripten_glSamplerParameterf,emscripten_glSamplerParameterfv:_emscripten_glSamplerParameterfv,emscripten_glSamplerParameteri:_emscripten_glSamplerParameteri,emscripten_glSamplerParameteriv:_emscripten_glSamplerParameteriv,emscripten_glScissor:_emscripten_glScissor,emscripten_glShaderBinary:_emscripten_glShaderBinary,emscripten_glShaderSource:_emscripten_glShaderSource,emscripten_glStencilFunc:_emscripten_glStencilFunc,emscripten_glStencilFuncSeparate:_emscripten_glStencilFuncSeparate,emscripten_glStencilMask:_emscripten_glStencilMask,emscripten_glStencilMaskSeparate:_emscripten_glStencilMaskSeparate,emscripten_glStencilOp:_emscripten_glStencilOp,emscripten_glStencilOpSeparate:_emscripten_glStencilOpSeparate,emscripten_glTexImage2D:_emscripten_glTexImage2D,emscripten_glTexImage3D:_emscripten_glTexImage3D,emscripten_glTexParameterf:_emscripten_glTexParameterf,emscripten_glTexParameterfv:_emscripten_glTexParameterfv,emscripten_glTexParameteri:_emscripten_glTexParameteri,emscripten_glTexParameteriv:_emscripten_glTexParameteriv,emscripten_glTexStorage2D:_emscripten_glTexStorage2D,emscripten_glTexStorage3D:_emscripten_glTexStorage3D,emscripten_glTexSubImage2D:_emscripten_glTexSubImage2D,emscripten_glTexSubImage3D:_emscripten_glTexSubImage3D,emscripten_glTransformFeedbackVaryings:_emscripten_glTransformFeedbackVaryings,emscripten_glUniform1f:_emscripten_glUniform1f,emscripten_glUniform1fv:_emscripten_glUniform1fv,emscripten_glUniform1i:_emscripten_glUniform1i,emscripten_glUniform1iv:_emscripten_glUniform1iv,emscripten_glUniform1ui:_emscripten_glUniform1ui,emscripten_glUniform1uiv:_emscripten_glUniform1uiv,emscripten_glUniform2f:_emscripten_glUniform2f,emscripten_glUniform2fv:_emscripten_glUniform2fv,emscripten_glUniform2i:_emscripten_glUniform2i,emscripten_glUniform2iv:_emscripten_glUniform2iv,emscripten_glUniform2ui:_emscripten_glUniform2ui,emscripten_glUniform2uiv:_emscripten_glUniform2uiv,emscripten_glUniform3f:_emscripten_glUniform3f,emscripten_glUniform3fv:_emscripten_glUniform3fv,emscripten_glUniform3i:_emscripten_glUniform3i,emscripten_glUniform3iv:_emscripten_glUniform3iv,emscripten_glUniform3ui:_emscripten_glUniform3ui,emscripten_glUniform3uiv:_emscripten_glUniform3uiv,emscripten_glUniform4f:_emscripten_glUniform4f,emscripten_glUniform4fv:_emscripten_glUniform4fv,emscripten_glUniform4i:_emscripten_glUniform4i,emscripten_glUniform4iv:_emscripten_glUniform4iv,emscripten_glUniform4ui:_emscripten_glUniform4ui,emscripten_glUniform4uiv:_emscripten_glUniform4uiv,emscripten_glUniformBlockBinding:_emscripten_glUniformBlockBinding,emscripten_glUniformMatrix2fv:_emscripten_glUniformMatrix2fv,emscripten_glUniformMatrix2x3fv:_emscripten_glUniformMatrix2x3fv,emscripten_glUniformMatrix2x4fv:_emscripten_glUniformMatrix2x4fv,emscripten_glUniformMatrix3fv:_emscripten_glUniformMatrix3fv,emscripten_glUniformMatrix3x2fv:_emscripten_glUniformMatrix3x2fv,emscripten_glUniformMatrix3x4fv:_emscripten_glUniformMatrix3x4fv,emscripten_glUniformMatrix4fv:_emscripten_glUniformMatrix4fv,emscripten_glUniformMatrix4x2fv:_emscripten_glUniformMatrix4x2fv,emscripten_glUniformMatrix4x3fv:_emscripten_glUniformMatrix4x3fv,emscripten_glUseProgram:_emscripten_glUseProgram,emscripten_glValidateProgram:_emscripten_glValidateProgram,emscripten_glVertexAttrib1f:_emscripten_glVertexAttrib1f,emscripten_glVertexAttrib1fv:_emscripten_glVertexAttrib1fv,emscripten_glVertexAttrib2f:_emscripten_glVertexAttrib2f,emscripten_glVertexAttrib2fv:_emscripten_glVertexAttrib2fv,emscripten_glVertexAttrib3f:_emscripten_glVertexAttrib3f,emscripten_glVertexAttrib3fv:_emscripten_glVertexAttrib3fv,emscripten_glVertexAttrib4f:_emscripten_glVertexAttrib4f,emscripten_glVertexAttrib4fv:_emscripten_glVertexAttrib4fv,emscripten_glVertexAttribDivisor:_emscripten_glVertexAttribDivisor,emscripten_glVertexAttribDivisorANGLE:_emscripten_glVertexAttribDivisorANGLE,emscripten_glVertexAttribDivisorARB:_emscripten_glVertexAttribDivisorARB,emscripten_glVertexAttribDivisorEXT:_emscripten_glVertexAttribDivisorEXT,emscripten_glVertexAttribDivisorNV:_emscripten_glVertexAttribDivisorNV,emscripten_glVertexAttribI4i:_emscripten_glVertexAttribI4i,emscripten_glVertexAttribI4iv:_emscripten_glVertexAttribI4iv,emscripten_glVertexAttribI4ui:_emscripten_glVertexAttribI4ui,emscripten_glVertexAttribI4uiv:_emscripten_glVertexAttribI4uiv,emscripten_glVertexAttribIPointer:_emscripten_glVertexAttribIPointer,emscripten_glVertexAttribPointer:_emscripten_glVertexAttribPointer,emscripten_glVertexPointer:_emscripten_glVertexPointer,emscripten_glViewport:_emscripten_glViewport,emscripten_glWaitSync:_emscripten_glWaitSync,emscripten_has_asyncify:_emscripten_has_asyncify,emscripten_hide_mouse:_emscripten_hide_mouse,emscripten_html5_remove_all_event_listeners:_emscripten_html5_remove_all_event_listeners,emscripten_is_main_browser_thread:_emscripten_is_main_browser_thread,emscripten_is_webgl_context_lost:_emscripten_is_webgl_context_lost,emscripten_lock_orientation:_emscripten_lock_orientation,emscripten_log:_emscripten_log,emscripten_math_acos:_emscripten_math_acos,emscripten_math_acosh:_emscripten_math_acosh,emscripten_math_asin:_emscripten_math_asin,emscripten_math_asinh:_emscripten_math_asinh,emscripten_math_atan:_emscripten_math_atan,emscripten_math_atan2:_emscripten_math_atan2,emscripten_math_atanh:_emscripten_math_atanh,emscripten_math_cbrt:_emscripten_math_cbrt,emscripten_math_cos:_emscripten_math_cos,emscripten_math_cosh:_emscripten_math_cosh,emscripten_math_exp:_emscripten_math_exp,emscripten_math_expm1:_emscripten_math_expm1,emscripten_math_fmod:_emscripten_math_fmod,emscripten_math_hypot:_emscripten_math_hypot,emscripten_math_log:_emscripten_math_log,emscripten_math_log10:_emscripten_math_log10,emscripten_math_log1p:_emscripten_math_log1p,emscripten_math_log2:_emscripten_math_log2,emscripten_math_pow:_emscripten_math_pow,emscripten_math_random:_emscripten_math_random,emscripten_math_round:_emscripten_math_round,emscripten_math_sign:_emscripten_math_sign,emscripten_math_sin:_emscripten_math_sin,emscripten_math_sinh:_emscripten_math_sinh,emscripten_math_sqrt:_emscripten_math_sqrt,emscripten_math_tan:_emscripten_math_tan,emscripten_math_tanh:_emscripten_math_tanh,emscripten_notify_memory_growth:_emscripten_notify_memory_growth,emscripten_out:_emscripten_out,emscripten_outn:_emscripten_outn,emscripten_pause_main_loop:_emscripten_pause_main_loop,emscripten_pc_get_column:_emscripten_pc_get_column,emscripten_pc_get_file:_emscripten_pc_get_file,emscripten_pc_get_function:_emscripten_pc_get_function,emscripten_pc_get_line:_emscripten_pc_get_line,emscripten_performance_now:_emscripten_performance_now,emscripten_print_double:_emscripten_print_double,emscripten_promise_all:_emscripten_promise_all,emscripten_promise_all_settled:_emscripten_promise_all_settled,emscripten_promise_any:_emscripten_promise_any,emscripten_promise_await:_emscripten_promise_await,emscripten_promise_create:_emscripten_promise_create,emscripten_promise_destroy:_emscripten_promise_destroy,emscripten_promise_race:_emscripten_promise_race,emscripten_promise_resolve:_emscripten_promise_resolve,emscripten_promise_then:_emscripten_promise_then,emscripten_random:_emscripten_random,emscripten_request_animation_frame:_emscripten_request_animation_frame,emscripten_request_animation_frame_loop:_emscripten_request_animation_frame_loop,emscripten_request_fullscreen:_emscripten_request_fullscreen,emscripten_request_fullscreen_strategy:_emscripten_request_fullscreen_strategy,emscripten_request_pointerlock:_emscripten_request_pointerlock,emscripten_resize_heap:_emscripten_resize_heap,emscripten_resume_main_loop:_emscripten_resume_main_loop,emscripten_return_address:_emscripten_return_address,emscripten_run_preload_plugins:_emscripten_run_preload_plugins,emscripten_run_preload_plugins_data:_emscripten_run_preload_plugins_data,emscripten_run_script:_emscripten_run_script,emscripten_run_script_int:_emscripten_run_script_int,emscripten_run_script_string:_emscripten_run_script_string,emscripten_runtime_keepalive_check:_emscripten_runtime_keepalive_check,emscripten_runtime_keepalive_pop:_emscripten_runtime_keepalive_pop,emscripten_runtime_keepalive_push:_emscripten_runtime_keepalive_push,emscripten_sample_gamepad_data:_emscripten_sample_gamepad_data,emscripten_set_batterychargingchange_callback_on_thread:_emscripten_set_batterychargingchange_callback_on_thread,emscripten_set_batterylevelchange_callback_on_thread:_emscripten_set_batterylevelchange_callback_on_thread,emscripten_set_beforeunload_callback_on_thread:_emscripten_set_beforeunload_callback_on_thread,emscripten_set_blur_callback_on_thread:_emscripten_set_blur_callback_on_thread,emscripten_set_canvas_element_size:_emscripten_set_canvas_element_size,emscripten_set_canvas_size:_emscripten_set_canvas_size,emscripten_set_click_callback_on_thread:_emscripten_set_click_callback_on_thread,emscripten_set_dblclick_callback_on_thread:_emscripten_set_dblclick_callback_on_thread,emscripten_set_devicemotion_callback_on_thread:_emscripten_set_devicemotion_callback_on_thread,emscripten_set_deviceorientation_callback_on_thread:_emscripten_set_deviceorientation_callback_on_thread,emscripten_set_element_css_size:_emscripten_set_element_css_size,emscripten_set_focus_callback_on_thread:_emscripten_set_focus_callback_on_thread,emscripten_set_focusin_callback_on_thread:_emscripten_set_focusin_callback_on_thread,emscripten_set_focusout_callback_on_thread:_emscripten_set_focusout_callback_on_thread,emscripten_set_fullscreenchange_callback_on_thread:_emscripten_set_fullscreenchange_callback_on_thread,emscripten_set_gamepadconnected_callback_on_thread:_emscripten_set_gamepadconnected_callback_on_thread,emscripten_set_gamepaddisconnected_callback_on_thread:_emscripten_set_gamepaddisconnected_callback_on_thread,emscripten_set_immediate:_emscripten_set_immediate,emscripten_set_immediate_loop:_emscripten_set_immediate_loop,emscripten_set_interval:_emscripten_set_interval,emscripten_set_keydown_callback_on_thread:_emscripten_set_keydown_callback_on_thread,emscripten_set_keypress_callback_on_thread:_emscripten_set_keypress_callback_on_thread,emscripten_set_keyup_callback_on_thread:_emscripten_set_keyup_callback_on_thread,emscripten_set_main_loop:_emscripten_set_main_loop,emscripten_set_main_loop_arg:_emscripten_set_main_loop_arg,emscripten_set_main_loop_expected_blockers:_emscripten_set_main_loop_expected_blockers,emscripten_set_main_loop_timing:_emscripten_set_main_loop_timing,emscripten_set_mousedown_callback_on_thread:_emscripten_set_mousedown_callback_on_thread,emscripten_set_mouseenter_callback_on_thread:_emscripten_set_mouseenter_callback_on_thread,emscripten_set_mouseleave_callback_on_thread:_emscripten_set_mouseleave_callback_on_thread,emscripten_set_mousemove_callback_on_thread:_emscripten_set_mousemove_callback_on_thread,emscripten_set_mouseout_callback_on_thread:_emscripten_set_mouseout_callback_on_thread,emscripten_set_mouseover_callback_on_thread:_emscripten_set_mouseover_callback_on_thread,emscripten_set_mouseup_callback_on_thread:_emscripten_set_mouseup_callback_on_thread,emscripten_set_orientationchange_callback_on_thread:_emscripten_set_orientationchange_callback_on_thread,emscripten_set_pointerlockchange_callback_on_thread:_emscripten_set_pointerlockchange_callback_on_thread,emscripten_set_pointerlockerror_callback_on_thread:_emscripten_set_pointerlockerror_callback_on_thread,emscripten_set_resize_callback_on_thread:_emscripten_set_resize_callback_on_thread,emscripten_set_scroll_callback_on_thread:_emscripten_set_scroll_callback_on_thread,emscripten_set_socket_close_callback:_emscripten_set_socket_close_callback,emscripten_set_socket_connection_callback:_emscripten_set_socket_connection_callback,emscripten_set_socket_error_callback:_emscripten_set_socket_error_callback,emscripten_set_socket_listen_callback:_emscripten_set_socket_listen_callback,emscripten_set_socket_message_callback:_emscripten_set_socket_message_callback,emscripten_set_socket_open_callback:_emscripten_set_socket_open_callback,emscripten_set_timeout:_emscripten_set_timeout,emscripten_set_timeout_loop:_emscripten_set_timeout_loop,emscripten_set_touchcancel_callback_on_thread:_emscripten_set_touchcancel_callback_on_thread,emscripten_set_touchend_callback_on_thread:_emscripten_set_touchend_callback_on_thread,emscripten_set_touchmove_callback_on_thread:_emscripten_set_touchmove_callback_on_thread,emscripten_set_touchstart_callback_on_thread:_emscripten_set_touchstart_callback_on_thread,emscripten_set_visibilitychange_callback_on_thread:_emscripten_set_visibilitychange_callback_on_thread,emscripten_set_webglcontextlost_callback_on_thread:_emscripten_set_webglcontextlost_callback_on_thread,emscripten_set_webglcontextrestored_callback_on_thread:_emscripten_set_webglcontextrestored_callback_on_thread,emscripten_set_wheel_callback_on_thread:_emscripten_set_wheel_callback_on_thread,emscripten_set_window_title:_emscripten_set_window_title,emscripten_stack_snapshot:_emscripten_stack_snapshot,emscripten_stack_unwind_buffer:_emscripten_stack_unwind_buffer,emscripten_supports_offscreencanvas:_emscripten_supports_offscreencanvas,emscripten_throw_number:_emscripten_throw_number,emscripten_throw_string:_emscripten_throw_string,emscripten_unlock_orientation:_emscripten_unlock_orientation,emscripten_unwind_to_js_event_loop:_emscripten_unwind_to_js_event_loop,emscripten_vibrate:_emscripten_vibrate,emscripten_vibrate_pattern:_emscripten_vibrate_pattern,emscripten_webgl_commit_frame:_emscripten_webgl_commit_frame,emscripten_webgl_create_context:_emscripten_webgl_create_context,emscripten_webgl_destroy_context:_emscripten_webgl_destroy_context,emscripten_webgl_do_commit_frame:_emscripten_webgl_do_commit_frame,emscripten_webgl_do_create_context:_emscripten_webgl_do_create_context,emscripten_webgl_do_get_current_context:_emscripten_webgl_do_get_current_context,emscripten_webgl_enable_ANGLE_instanced_arrays:_emscripten_webgl_enable_ANGLE_instanced_arrays,emscripten_webgl_enable_EXT_clip_control:_emscripten_webgl_enable_EXT_clip_control,emscripten_webgl_enable_EXT_polygon_offset_clamp:_emscripten_webgl_enable_EXT_polygon_offset_clamp,emscripten_webgl_enable_OES_vertex_array_object:_emscripten_webgl_enable_OES_vertex_array_object,emscripten_webgl_enable_WEBGL_draw_buffers:_emscripten_webgl_enable_WEBGL_draw_buffers,emscripten_webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance:_emscripten_webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance,emscripten_webgl_enable_WEBGL_multi_draw:_emscripten_webgl_enable_WEBGL_multi_draw,emscripten_webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance:_emscripten_webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance,emscripten_webgl_enable_WEBGL_polygon_mode:_emscripten_webgl_enable_WEBGL_polygon_mode,emscripten_webgl_enable_extension:_emscripten_webgl_enable_extension,emscripten_webgl_get_context_attributes:_emscripten_webgl_get_context_attributes,emscripten_webgl_get_current_context:_emscripten_webgl_get_current_context,emscripten_webgl_get_drawing_buffer_size:_emscripten_webgl_get_drawing_buffer_size,emscripten_webgl_get_parameter_d:_emscripten_webgl_get_parameter_d,emscripten_webgl_get_parameter_i64v:_emscripten_webgl_get_parameter_i64v,emscripten_webgl_get_parameter_o:_emscripten_webgl_get_parameter_o,emscripten_webgl_get_parameter_utf8:_emscripten_webgl_get_parameter_utf8,emscripten_webgl_get_parameter_v:_emscripten_webgl_get_parameter_v,emscripten_webgl_get_program_info_log_utf8:_emscripten_webgl_get_program_info_log_utf8,emscripten_webgl_get_program_parameter_d:_emscripten_webgl_get_program_parameter_d,emscripten_webgl_get_shader_info_log_utf8:_emscripten_webgl_get_shader_info_log_utf8,emscripten_webgl_get_shader_parameter_d:_emscripten_webgl_get_shader_parameter_d,emscripten_webgl_get_shader_source_utf8:_emscripten_webgl_get_shader_source_utf8,emscripten_webgl_get_supported_extensions:_emscripten_webgl_get_supported_extensions,emscripten_webgl_get_uniform_d:_emscripten_webgl_get_uniform_d,emscripten_webgl_get_uniform_v:_emscripten_webgl_get_uniform_v,emscripten_webgl_get_vertex_attrib_d:_emscripten_webgl_get_vertex_attrib_d,emscripten_webgl_get_vertex_attrib_o:_emscripten_webgl_get_vertex_attrib_o,emscripten_webgl_get_vertex_attrib_v:_emscripten_webgl_get_vertex_attrib_v,emscripten_webgl_make_context_current:_emscripten_webgl_make_context_current,emscripten_websocket_close:_emscripten_websocket_close,emscripten_websocket_deinitialize:_emscripten_websocket_deinitialize,emscripten_websocket_delete:_emscripten_websocket_delete,emscripten_websocket_get_buffered_amount:_emscripten_websocket_get_buffered_amount,emscripten_websocket_get_extensions:_emscripten_websocket_get_extensions,emscripten_websocket_get_extensions_length:_emscripten_websocket_get_extensions_length,emscripten_websocket_get_protocol:_emscripten_websocket_get_protocol,emscripten_websocket_get_protocol_length:_emscripten_websocket_get_protocol_length,emscripten_websocket_get_ready_state:_emscripten_websocket_get_ready_state,emscripten_websocket_get_url:_emscripten_websocket_get_url,emscripten_websocket_get_url_length:_emscripten_websocket_get_url_length,emscripten_websocket_is_supported:_emscripten_websocket_is_supported,emscripten_websocket_new:_emscripten_websocket_new,emscripten_websocket_send_binary:_emscripten_websocket_send_binary,emscripten_websocket_send_utf8_text:_emscripten_websocket_send_utf8_text,emscripten_websocket_set_onclose_callback_on_thread:_emscripten_websocket_set_onclose_callback_on_thread,emscripten_websocket_set_onerror_callback_on_thread:_emscripten_websocket_set_onerror_callback_on_thread,emscripten_websocket_set_onmessage_callback_on_thread:_emscripten_websocket_set_onmessage_callback_on_thread,emscripten_websocket_set_onopen_callback_on_thread:_emscripten_websocket_set_onopen_callback_on_thread,endprotoent:_endprotoent,environ_get:_environ_get,environ_sizes_get:_environ_sizes_get,exit:_exit,fail_test,fd_close:_fd_close,fd_fdstat_get:_fd_fdstat_get,fd_pread:_fd_pread,fd_pwrite:_fd_pwrite,fd_read:_fd_read,fd_seek:_fd_seek,fd_sync:_fd_sync,fd_write:_fd_write,ffi_call_js,ffi_closure_alloc_js,ffi_closure_free_js,ffi_prep_closure_loc_js,filledEllipseColor:_filledEllipseColor,filledEllipseRGBA:_filledEllipseRGBA,gc_register_proxies,get_async_js_call_done_callback,get_length_helper,get_length_string,get_suspender,getaddrinfo:_getaddrinfo,getnameinfo:_getnameinfo,getprotobyname:_getprotobyname,getprotobynumber:_getprotobynumber,getprotoent:_getprotoent,glActiveTexture:_glActiveTexture,glAttachShader:_glAttachShader,glBegin:_glBegin,glBeginQuery:_glBeginQuery,glBeginQueryEXT:_glBeginQueryEXT,glBeginTransformFeedback:_glBeginTransformFeedback,glBindAttribLocation:_glBindAttribLocation,glBindBuffer:_glBindBuffer,glBindBufferBase:_glBindBufferBase,glBindBufferRange:_glBindBufferRange,glBindFramebuffer:_glBindFramebuffer,glBindRenderbuffer:_glBindRenderbuffer,glBindSampler:_glBindSampler,glBindTexture:_glBindTexture,glBindTransformFeedback:_glBindTransformFeedback,glBindVertexArray:_glBindVertexArray,glBindVertexArrayOES:_glBindVertexArrayOES,glBlendColor:_glBlendColor,glBlendEquation:_glBlendEquation,glBlendEquationSeparate:_glBlendEquationSeparate,glBlendFunc:_glBlendFunc,glBlendFuncSeparate:_glBlendFuncSeparate,glBlitFramebuffer:_glBlitFramebuffer,glBufferData:_glBufferData,glBufferSubData:_glBufferSubData,glCheckFramebufferStatus:_glCheckFramebufferStatus,glClear:_glClear,glClearBufferfi:_glClearBufferfi,glClearBufferfv:_glClearBufferfv,glClearBufferiv:_glClearBufferiv,glClearBufferuiv:_glClearBufferuiv,glClearColor:_glClearColor,glClearDepth:_glClearDepth,glClearDepthf:_glClearDepthf,glClearStencil:_glClearStencil,glClientWaitSync:_glClientWaitSync,glClipControlEXT:_glClipControlEXT,glColorMask:_glColorMask,glCompileShader:_glCompileShader,glCompressedTexImage2D:_glCompressedTexImage2D,glCompressedTexImage3D:_glCompressedTexImage3D,glCompressedTexSubImage2D:_glCompressedTexSubImage2D,glCompressedTexSubImage3D:_glCompressedTexSubImage3D,glCopyBufferSubData:_glCopyBufferSubData,glCopyTexImage2D:_glCopyTexImage2D,glCopyTexSubImage2D:_glCopyTexSubImage2D,glCopyTexSubImage3D:_glCopyTexSubImage3D,glCreateProgram:_glCreateProgram,glCreateShader:_glCreateShader,glCullFace:_glCullFace,glDeleteBuffers:_glDeleteBuffers,glDeleteFramebuffers:_glDeleteFramebuffers,glDeleteProgram:_glDeleteProgram,glDeleteQueries:_glDeleteQueries,glDeleteQueriesEXT:_glDeleteQueriesEXT,glDeleteRenderbuffers:_glDeleteRenderbuffers,glDeleteSamplers:_glDeleteSamplers,glDeleteShader:_glDeleteShader,glDeleteSync:_glDeleteSync,glDeleteTextures:_glDeleteTextures,glDeleteTransformFeedbacks:_glDeleteTransformFeedbacks,glDeleteVertexArrays:_glDeleteVertexArrays,glDeleteVertexArraysOES:_glDeleteVertexArraysOES,glDepthFunc:_glDepthFunc,glDepthMask:_glDepthMask,glDepthRange:_glDepthRange,glDepthRangef:_glDepthRangef,glDetachShader:_glDetachShader,glDisable:_glDisable,glDisableVertexAttribArray:_glDisableVertexAttribArray,glDrawArrays:_glDrawArrays,glDrawArraysInstanced:_glDrawArraysInstanced,glDrawArraysInstancedANGLE:_glDrawArraysInstancedANGLE,glDrawArraysInstancedARB:_glDrawArraysInstancedARB,glDrawArraysInstancedBaseInstance:_glDrawArraysInstancedBaseInstance,glDrawArraysInstancedBaseInstanceANGLE:_glDrawArraysInstancedBaseInstanceANGLE,glDrawArraysInstancedBaseInstanceWEBGL:_glDrawArraysInstancedBaseInstanceWEBGL,glDrawArraysInstancedEXT:_glDrawArraysInstancedEXT,glDrawArraysInstancedNV:_glDrawArraysInstancedNV,glDrawBuffers:_glDrawBuffers,glDrawBuffersEXT:_glDrawBuffersEXT,glDrawBuffersWEBGL:_glDrawBuffersWEBGL,glDrawElements:_glDrawElements,glDrawElementsInstanced:_glDrawElementsInstanced,glDrawElementsInstancedANGLE:_glDrawElementsInstancedANGLE,glDrawElementsInstancedARB:_glDrawElementsInstancedARB,glDrawElementsInstancedBaseVertexBaseInstanceANGLE:_glDrawElementsInstancedBaseVertexBaseInstanceANGLE,glDrawElementsInstancedBaseVertexBaseInstanceWEBGL:_glDrawElementsInstancedBaseVertexBaseInstanceWEBGL,glDrawElementsInstancedEXT:_glDrawElementsInstancedEXT,glDrawElementsInstancedNV:_glDrawElementsInstancedNV,glDrawRangeElements:_glDrawRangeElements,glEnable:_glEnable,glEnableVertexAttribArray:_glEnableVertexAttribArray,glEndQuery:_glEndQuery,glEndQueryEXT:_glEndQueryEXT,glEndTransformFeedback:_glEndTransformFeedback,glFenceSync:_glFenceSync,glFinish:_glFinish,glFlush:_glFlush,glFramebufferRenderbuffer:_glFramebufferRenderbuffer,glFramebufferTexture2D:_glFramebufferTexture2D,glFramebufferTextureLayer:_glFramebufferTextureLayer,glFrontFace:_glFrontFace,glGenBuffers:_glGenBuffers,glGenFramebuffers:_glGenFramebuffers,glGenQueries:_glGenQueries,glGenQueriesEXT:_glGenQueriesEXT,glGenRenderbuffers:_glGenRenderbuffers,glGenSamplers:_glGenSamplers,glGenTextures:_glGenTextures,glGenTransformFeedbacks:_glGenTransformFeedbacks,glGenVertexArrays:_glGenVertexArrays,glGenVertexArraysOES:_glGenVertexArraysOES,glGenerateMipmap:_glGenerateMipmap,glGetActiveAttrib:_glGetActiveAttrib,glGetActiveUniform:_glGetActiveUniform,glGetActiveUniformBlockName:_glGetActiveUniformBlockName,glGetActiveUniformBlockiv:_glGetActiveUniformBlockiv,glGetActiveUniformsiv:_glGetActiveUniformsiv,glGetAttachedShaders:_glGetAttachedShaders,glGetAttribLocation:_glGetAttribLocation,glGetBooleanv:_glGetBooleanv,glGetBufferParameteri64v:_glGetBufferParameteri64v,glGetBufferParameteriv:_glGetBufferParameteriv,glGetBufferSubData:_glGetBufferSubData,glGetError:_glGetError,glGetFloatv:_glGetFloatv,glGetFragDataLocation:_glGetFragDataLocation,glGetFramebufferAttachmentParameteriv:_glGetFramebufferAttachmentParameteriv,glGetInteger64i_v:_glGetInteger64i_v,glGetInteger64v:_glGetInteger64v,glGetIntegeri_v:_glGetIntegeri_v,glGetIntegerv:_glGetIntegerv,glGetInternalformativ:_glGetInternalformativ,glGetProgramBinary:_glGetProgramBinary,glGetProgramInfoLog:_glGetProgramInfoLog,glGetProgramiv:_glGetProgramiv,glGetQueryObjecti64vEXT:_glGetQueryObjecti64vEXT,glGetQueryObjectivEXT:_glGetQueryObjectivEXT,glGetQueryObjectui64vEXT:_glGetQueryObjectui64vEXT,glGetQueryObjectuiv:_glGetQueryObjectuiv,glGetQueryObjectuivEXT:_glGetQueryObjectuivEXT,glGetQueryiv:_glGetQueryiv,glGetQueryivEXT:_glGetQueryivEXT,glGetRenderbufferParameteriv:_glGetRenderbufferParameteriv,glGetSamplerParameterfv:_glGetSamplerParameterfv,glGetSamplerParameteriv:_glGetSamplerParameteriv,glGetShaderInfoLog:_glGetShaderInfoLog,glGetShaderPrecisionFormat:_glGetShaderPrecisionFormat,glGetShaderSource:_glGetShaderSource,glGetShaderiv:_glGetShaderiv,glGetString:_glGetString,glGetStringi:_glGetStringi,glGetSynciv:_glGetSynciv,glGetTexParameterfv:_glGetTexParameterfv,glGetTexParameteriv:_glGetTexParameteriv,glGetTransformFeedbackVarying:_glGetTransformFeedbackVarying,glGetUniformBlockIndex:_glGetUniformBlockIndex,glGetUniformIndices:_glGetUniformIndices,glGetUniformLocation:_glGetUniformLocation,glGetUniformfv:_glGetUniformfv,glGetUniformiv:_glGetUniformiv,glGetUniformuiv:_glGetUniformuiv,glGetVertexAttribIiv:_glGetVertexAttribIiv,glGetVertexAttribIuiv:_glGetVertexAttribIuiv,glGetVertexAttribPointerv:_glGetVertexAttribPointerv,glGetVertexAttribfv:_glGetVertexAttribfv,glGetVertexAttribiv:_glGetVertexAttribiv,glHint:_glHint,glInvalidateFramebuffer:_glInvalidateFramebuffer,glInvalidateSubFramebuffer:_glInvalidateSubFramebuffer,glIsBuffer:_glIsBuffer,glIsEnabled:_glIsEnabled,glIsFramebuffer:_glIsFramebuffer,glIsProgram:_glIsProgram,glIsQuery:_glIsQuery,glIsQueryEXT:_glIsQueryEXT,glIsRenderbuffer:_glIsRenderbuffer,glIsSampler:_glIsSampler,glIsShader:_glIsShader,glIsSync:_glIsSync,glIsTexture:_glIsTexture,glIsTransformFeedback:_glIsTransformFeedback,glIsVertexArray:_glIsVertexArray,glIsVertexArrayOES:_glIsVertexArrayOES,glLineWidth:_glLineWidth,glLinkProgram:_glLinkProgram,glLoadIdentity:_glLoadIdentity,glMatrixMode:_glMatrixMode,glMultiDrawArrays:_glMultiDrawArrays,glMultiDrawArraysANGLE:_glMultiDrawArraysANGLE,glMultiDrawArraysInstancedANGLE:_glMultiDrawArraysInstancedANGLE,glMultiDrawArraysInstancedBaseInstanceANGLE:_glMultiDrawArraysInstancedBaseInstanceANGLE,glMultiDrawArraysInstancedBaseInstanceWEBGL:_glMultiDrawArraysInstancedBaseInstanceWEBGL,glMultiDrawArraysInstancedWEBGL:_glMultiDrawArraysInstancedWEBGL,glMultiDrawArraysWEBGL:_glMultiDrawArraysWEBGL,glMultiDrawElements:_glMultiDrawElements,glMultiDrawElementsANGLE:_glMultiDrawElementsANGLE,glMultiDrawElementsInstancedANGLE:_glMultiDrawElementsInstancedANGLE,glMultiDrawElementsInstancedBaseVertexBaseInstanceANGLE:_glMultiDrawElementsInstancedBaseVertexBaseInstanceANGLE,glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL:_glMultiDrawElementsInstancedBaseVertexBaseInstanceWEBGL,glMultiDrawElementsInstancedWEBGL:_glMultiDrawElementsInstancedWEBGL,glMultiDrawElementsWEBGL:_glMultiDrawElementsWEBGL,glPauseTransformFeedback:_glPauseTransformFeedback,glPixelStorei:_glPixelStorei,glPolygonModeWEBGL:_glPolygonModeWEBGL,glPolygonOffset:_glPolygonOffset,glPolygonOffsetClampEXT:_glPolygonOffsetClampEXT,glProgramBinary:_glProgramBinary,glProgramParameteri:_glProgramParameteri,glQueryCounterEXT:_glQueryCounterEXT,glReadBuffer:_glReadBuffer,glReadPixels:_glReadPixels,glReleaseShaderCompiler:_glReleaseShaderCompiler,glRenderbufferStorage:_glRenderbufferStorage,glRenderbufferStorageMultisample:_glRenderbufferStorageMultisample,glResumeTransformFeedback:_glResumeTransformFeedback,glSampleCoverage:_glSampleCoverage,glSamplerParameterf:_glSamplerParameterf,glSamplerParameterfv:_glSamplerParameterfv,glSamplerParameteri:_glSamplerParameteri,glSamplerParameteriv:_glSamplerParameteriv,glScissor:_glScissor,glShaderBinary:_glShaderBinary,glShaderSource:_glShaderSource,glStencilFunc:_glStencilFunc,glStencilFuncSeparate:_glStencilFuncSeparate,glStencilMask:_glStencilMask,glStencilMaskSeparate:_glStencilMaskSeparate,glStencilOp:_glStencilOp,glStencilOpSeparate:_glStencilOpSeparate,glTexImage2D:_glTexImage2D,glTexImage3D:_glTexImage3D,glTexParameterf:_glTexParameterf,glTexParameterfv:_glTexParameterfv,glTexParameteri:_glTexParameteri,glTexParameteriv:_glTexParameteriv,glTexStorage2D:_glTexStorage2D,glTexStorage3D:_glTexStorage3D,glTexSubImage2D:_glTexSubImage2D,glTexSubImage3D:_glTexSubImage3D,glTransformFeedbackVaryings:_glTransformFeedbackVaryings,glUniform1f:_glUniform1f,glUniform1fv:_glUniform1fv,glUniform1i:_glUniform1i,glUniform1iv:_glUniform1iv,glUniform1ui:_glUniform1ui,glUniform1uiv:_glUniform1uiv,glUniform2f:_glUniform2f,glUniform2fv:_glUniform2fv,glUniform2i:_glUniform2i,glUniform2iv:_glUniform2iv,glUniform2ui:_glUniform2ui,glUniform2uiv:_glUniform2uiv,glUniform3f:_glUniform3f,glUniform3fv:_glUniform3fv,glUniform3i:_glUniform3i,glUniform3iv:_glUniform3iv,glUniform3ui:_glUniform3ui,glUniform3uiv:_glUniform3uiv,glUniform4f:_glUniform4f,glUniform4fv:_glUniform4fv,glUniform4i:_glUniform4i,glUniform4iv:_glUniform4iv,glUniform4ui:_glUniform4ui,glUniform4uiv:_glUniform4uiv,glUniformBlockBinding:_glUniformBlockBinding,glUniformMatrix2fv:_glUniformMatrix2fv,glUniformMatrix2x3fv:_glUniformMatrix2x3fv,glUniformMatrix2x4fv:_glUniformMatrix2x4fv,glUniformMatrix3fv:_glUniformMatrix3fv,glUniformMatrix3x2fv:_glUniformMatrix3x2fv,glUniformMatrix3x4fv:_glUniformMatrix3x4fv,glUniformMatrix4fv:_glUniformMatrix4fv,glUniformMatrix4x2fv:_glUniformMatrix4x2fv,glUniformMatrix4x3fv:_glUniformMatrix4x3fv,glUseProgram:_glUseProgram,glValidateProgram:_glValidateProgram,glVertexAttrib1f:_glVertexAttrib1f,glVertexAttrib1fv:_glVertexAttrib1fv,glVertexAttrib2f:_glVertexAttrib2f,glVertexAttrib2fv:_glVertexAttrib2fv,glVertexAttrib3f:_glVertexAttrib3f,glVertexAttrib3fv:_glVertexAttrib3fv,glVertexAttrib4f:_glVertexAttrib4f,glVertexAttrib4fv:_glVertexAttrib4fv,glVertexAttribDivisor:_glVertexAttribDivisor,glVertexAttribDivisorANGLE:_glVertexAttribDivisorANGLE,glVertexAttribDivisorARB:_glVertexAttribDivisorARB,glVertexAttribDivisorEXT:_glVertexAttribDivisorEXT,glVertexAttribDivisorNV:_glVertexAttribDivisorNV,glVertexAttribI4i:_glVertexAttribI4i,glVertexAttribI4iv:_glVertexAttribI4iv,glVertexAttribI4ui:_glVertexAttribI4ui,glVertexAttribI4uiv:_glVertexAttribI4uiv,glVertexAttribIPointer:_glVertexAttribIPointer,glVertexAttribPointer:_glVertexAttribPointer,glVertexPointer:_glVertexPointer,glViewport:_glViewport,glWaitSync:_glWaitSync,handle_next_result_js,hiwire_invalid_ref_js,is_comlink_proxy,is_sentinel:_is_sentinel,js2python_convert,js2python_immutable_js,js2python_js,jslib_init_buffers_js,jslib_init_js,lineColor:_lineColor,lineRGBA:_lineRGBA,memory:wasmMemory,my_dict_converter,new_error,pixelRGBA:_pixelRGBA,proc_exit:_proc_exit,proxy_cache_get,proxy_cache_set,pyodide_js_init,pyproxy_AsPyObject,pyproxy_Check,pyproxy_new,pyproxy_new_ex,python2js__default_converter_js,python2js__eager_converter_js,python2js_custom__create_jscontext,random_get:_random_get,raw_call_js,rectangleColor:_rectangleColor,rectangleRGBA:_rectangleRGBA,restoreState,restore_stderr,rotozoomSurface:_rotozoomSurface,saveState,setNetworkCallback:_setNetworkCallback,set_pyodide_module,set_suspender,setprotoent:_setprotoent,stackAlloc:_stackAlloc,stackRestore:_stackRestore,stackSave:_stackSave,strptime:_strptime,strptime_l:_strptime_l,syncifyHandler,throw_no_gil,wrap_async_generator,wrap_generator,zoomSurface:_zoomSurface};var wasmExports=await createWasm();var ___wasm_call_ctors=wasmExports["__wasm_call_ctors"];var _set_method_docstring=Module["_set_method_docstring"]=wasmExports["set_method_docstring"];var _PyObject_GetAttrString=Module["_PyObject_GetAttrString"]=wasmExports["PyObject_GetAttrString"];var __PyUnicode_FromId=Module["__PyUnicode_FromId"]=wasmExports["_PyUnicode_FromId"];var _PyObject_VectorcallMethod=Module["_PyObject_VectorcallMethod"]=wasmExports["PyObject_VectorcallMethod"];var _PyUnicode_AsUTF8AndSize=Module["_PyUnicode_AsUTF8AndSize"]=wasmExports["PyUnicode_AsUTF8AndSize"];var _malloc=wasmExports["malloc"];var __Py_Dealloc=Module["__Py_Dealloc"]=wasmExports["_Py_Dealloc"];var _PyErr_Format=Module["_PyErr_Format"]=wasmExports["PyErr_Format"];var _add_methods_and_set_docstrings=Module["_add_methods_and_set_docstrings"]=wasmExports["add_methods_and_set_docstrings"];var _PyModule_AddFunctions=Module["_PyModule_AddFunctions"]=wasmExports["PyModule_AddFunctions"];var _docstring_init=Module["_docstring_init"]=wasmExports["docstring_init"];var _PyImport_ImportModule=Module["_PyImport_ImportModule"]=wasmExports["PyImport_ImportModule"];var _dump_traceback=Module["_dump_traceback"]=wasmExports["dump_traceback"];var _fileno=wasmExports["fileno"];var _PyGILState_GetThisThreadState=Module["_PyGILState_GetThisThreadState"]=wasmExports["PyGILState_GetThisThreadState"];var _set_error=Module["_set_error"]=wasmExports["set_error"];var _PyErr_SetObject=Module["_PyErr_SetObject"]=wasmExports["PyErr_SetObject"];var _restore_sys_last_exception=Module["_restore_sys_last_exception"]=wasmExports["restore_sys_last_exception"];var _PySys_GetObject=Module["_PySys_GetObject"]=wasmExports["PySys_GetObject"];var _PyErr_SetRaisedException=Module["_PyErr_SetRaisedException"]=wasmExports["PyErr_SetRaisedException"];var _wrap_exception=Module["_wrap_exception"]=wasmExports["wrap_exception"];var _PyErr_GetRaisedException=Module["_PyErr_GetRaisedException"]=wasmExports["PyErr_GetRaisedException"];var _PyErr_GivenExceptionMatches=Module["_PyErr_GivenExceptionMatches"]=wasmExports["PyErr_GivenExceptionMatches"];var _PyErr_Print=Module["_PyErr_Print"]=wasmExports["PyErr_Print"];var __PyObject_GetAttrId=Module["__PyObject_GetAttrId"]=wasmExports["_PyObject_GetAttrId"];var _PyUnicode_AsUTF8=Module["_PyUnicode_AsUTF8"]=wasmExports["PyUnicode_AsUTF8"];var _PySys_WriteStderr=Module["_PySys_WriteStderr"]=wasmExports["PySys_WriteStderr"];var _PyErr_DisplayException=Module["_PyErr_DisplayException"]=wasmExports["PyErr_DisplayException"];var _JsvString_FromId=Module["_JsvString_FromId"]=wasmExports["JsvString_FromId"];var _pythonexc2js=Module["_pythonexc2js"]=wasmExports["pythonexc2js"];var _trigger_fatal_error=Module["_trigger_fatal_error"]=wasmExports["trigger_fatal_error"];var _raw_call=Module["_raw_call"]=wasmExports["raw_call"];var _JsProxy_Val=Module["_JsProxy_Val"]=wasmExports["JsProxy_Val"];var _error_handling_init=Module["_error_handling_init"]=wasmExports["error_handling_init"];var _hiwire_invalid_ref=Module["_hiwire_invalid_ref"]=wasmExports["hiwire_invalid_ref"];var _init_pyodide_proxy=Module["_init_pyodide_proxy"]=wasmExports["init_pyodide_proxy"];var _python2js=Module["_python2js"]=wasmExports["python2js"];var _PyInit__pyodide_core=Module["_PyInit__pyodide_core"]=wasmExports["PyInit__pyodide_core"];var _PyErr_Occurred=Module["_PyErr_Occurred"]=wasmExports["PyErr_Occurred"];var __PyErr_FormatFromCause=Module["__PyErr_FormatFromCause"]=wasmExports["_PyErr_FormatFromCause"];var _PyModule_Create2=Module["_PyModule_Create2"]=wasmExports["PyModule_Create2"];var _PyImport_GetModuleDict=Module["_PyImport_GetModuleDict"]=wasmExports["PyImport_GetModuleDict"];var _PyDict_SetItemString=Module["_PyDict_SetItemString"]=wasmExports["PyDict_SetItemString"];var _jslib_init=Module["_jslib_init"]=wasmExports["jslib_init"];var _python2js_init=Module["_python2js_init"]=wasmExports["python2js_init"];var _jsproxy_init=Module["_jsproxy_init"]=wasmExports["jsproxy_init"];var _jsproxy_call_init=Module["_jsproxy_call_init"]=wasmExports["jsproxy_call_init"];var _pyproxy_init=Module["_pyproxy_init"]=wasmExports["pyproxy_init"];var _jsbind_init=Module["_jsbind_init"]=wasmExports["jsbind_init"];var _pyodide_export=Module["_pyodide_export"]=wasmExports["pyodide_export"];var _PyUnicode_Data=Module["_PyUnicode_Data"]=wasmExports["PyUnicode_Data"];var __js2python_none=Module["__js2python_none"]=wasmExports["_js2python_none"];var __js2python_null=Module["__js2python_null"]=wasmExports["_js2python_null"];var __js2python_true=Module["__js2python_true"]=wasmExports["_js2python_true"];var __js2python_false=Module["__js2python_false"]=wasmExports["_js2python_false"];var __js2python_pyproxy=Module["__js2python_pyproxy"]=wasmExports["_js2python_pyproxy"];var _js2python_immutable=Module["_js2python_immutable"]=wasmExports["js2python_immutable"];var _js2python=Module["_js2python"]=wasmExports["js2python"];var _JsProxy_getflags=Module["_JsProxy_getflags"]=wasmExports["JsProxy_getflags"];var _PyLong_AsLong=Module["_PyLong_AsLong"]=wasmExports["PyLong_AsLong"];var _JsProxy_is_py_json=Module["_JsProxy_is_py_json"]=wasmExports["JsProxy_is_py_json"];var _js2python_as_py_json=Module["_js2python_as_py_json"]=wasmExports["js2python_as_py_json"];var _hiwire_get=Module["_hiwire_get"]=wasmExports["hiwire_get"];var _JsProxy_create_with_type=Module["_JsProxy_create_with_type"]=wasmExports["JsProxy_create_with_type"];var _JsProxy_bind_sig=Module["_JsProxy_bind_sig"]=wasmExports["JsProxy_bind_sig"];var _JsRef_toVal=Module["_JsRef_toVal"]=wasmExports["JsRef_toVal"];var _PyErr_SetString=Module["_PyErr_SetString"]=wasmExports["PyErr_SetString"];var _JsProxy_create_with_this=Module["_JsProxy_create_with_this"]=wasmExports["JsProxy_create_with_this"];var _JsProxy_bind_class=Module["_JsProxy_bind_class"]=wasmExports["JsProxy_bind_class"];var _clear_method_call_singleton=Module["_clear_method_call_singleton"]=wasmExports["clear_method_call_singleton"];var _hiwire_decref=Module["_hiwire_decref"]=wasmExports["hiwire_decref"];var _JsProxy_GetMethod=Module["_JsProxy_GetMethod"]=wasmExports["JsProxy_GetMethod"];var __PyObject_GenericGetAttrWithDict=Module["__PyObject_GenericGetAttrWithDict"]=wasmExports["_PyObject_GenericGetAttrWithDict"];var _strcmp=Module["_strcmp"]=wasmExports["strcmp"];var _PyArg_ParseTuple=Module["_PyArg_ParseTuple"]=wasmExports["PyArg_ParseTuple"];var _Js2PyConverter_convert=Module["_Js2PyConverter_convert"]=wasmExports["Js2PyConverter_convert"];var _hiwire_new=Module["_hiwire_new"]=wasmExports["hiwire_new"];var _hiwire_incref=Module["_hiwire_incref"]=wasmExports["hiwire_incref"];var _JsProxy_GetAttr=Module["_JsProxy_GetAttr"]=wasmExports["JsProxy_GetAttr"];var _handle_next_result=Module["_handle_next_result"]=wasmExports["handle_next_result"];var _free=Module["_free"]=wasmExports["free"];var _JsProxy_create_objmap=Module["_JsProxy_create_objmap"]=wasmExports["JsProxy_create_objmap"];var _JsProxy_am_send=Module["_JsProxy_am_send"]=wasmExports["JsProxy_am_send"];var _python2js_track_proxies=Module["_python2js_track_proxies"]=wasmExports["python2js_track_proxies"];var _JsvObject_CallMethodId_OneArg=Module["_JsvObject_CallMethodId_OneArg"]=wasmExports["JsvObject_CallMethodId_OneArg"];var _JsProxy_IterNext=Module["_JsProxy_IterNext"]=wasmExports["JsProxy_IterNext"];var __PyGen_SetStopIterationValue=Module["__PyGen_SetStopIterationValue"]=wasmExports["_PyGen_SetStopIterationValue"];var _JsGenerator_send=Module["_JsGenerator_send"]=wasmExports["JsGenerator_send"];var _PyErr_SetNone=Module["_PyErr_SetNone"]=wasmExports["PyErr_SetNone"];var _JsException_js_error_getter=Module["_JsException_js_error_getter"]=wasmExports["JsException_js_error_getter"];var _process_throw_args=Module["_process_throw_args"]=wasmExports["process_throw_args"];var _PyErr_NormalizeException=Module["_PyErr_NormalizeException"]=wasmExports["PyErr_NormalizeException"];var _PyException_GetTraceback=Module["_PyException_GetTraceback"]=wasmExports["PyException_GetTraceback"];var _PyException_SetTraceback=Module["_PyException_SetTraceback"]=wasmExports["PyException_SetTraceback"];var _PyErr_Restore=Module["_PyErr_Restore"]=wasmExports["PyErr_Restore"];var _PyErr_ExceptionMatches=Module["_PyErr_ExceptionMatches"]=wasmExports["PyErr_ExceptionMatches"];var _PyErr_Clear=Module["_PyErr_Clear"]=wasmExports["PyErr_Clear"];var _JsvObject_CallMethodId_NoArgs=Module["_JsvObject_CallMethodId_NoArgs"]=wasmExports["JsvObject_CallMethodId_NoArgs"];var _PyErr_Fetch=Module["_PyErr_Fetch"]=wasmExports["PyErr_Fetch"];var __agen_handle_result_js_c=Module["__agen_handle_result_js_c"]=wasmExports["_agen_handle_result_js_c"];var _PyObject_CallOneArg=Module["_PyObject_CallOneArg"]=wasmExports["PyObject_CallOneArg"];var __agen_handle_result=Module["__agen_handle_result"]=wasmExports["_agen_handle_result"];var _JsArray_sq_item=Module["_JsArray_sq_item"]=wasmExports["JsArray_sq_item"];var _JsArray_sq_ass_item=Module["_JsArray_sq_ass_item"]=wasmExports["JsArray_sq_ass_item"];var _JsTypedArray_sq_ass_item=Module["_JsTypedArray_sq_ass_item"]=wasmExports["JsTypedArray_sq_ass_item"];var _JsMap_update=Module["_JsMap_update"]=wasmExports["JsMap_update"];var _wrap_promise=Module["_wrap_promise"]=wasmExports["wrap_promise"];var _PyTuple_GetItem=Module["_PyTuple_GetItem"]=wasmExports["PyTuple_GetItem"];var _JsvObject_CallMethodId=Module["_JsvObject_CallMethodId"]=wasmExports["JsvObject_CallMethodId"];var _JsModule_GetAll=Module["_JsModule_GetAll"]=wasmExports["JsModule_GetAll"];var _PyType_IsSubtype=Module["_PyType_IsSubtype"]=wasmExports["PyType_IsSubtype"];var _JsProxy_Check=Module["_JsProxy_Check"]=wasmExports["JsProxy_Check"];var _JsBuffer_CopyIntoMemoryView=Module["_JsBuffer_CopyIntoMemoryView"]=wasmExports["JsBuffer_CopyIntoMemoryView"];var _PyMem_Malloc=Module["_PyMem_Malloc"]=wasmExports["PyMem_Malloc"];var _PyMemoryView_FromObject=Module["_PyMemoryView_FromObject"]=wasmExports["PyMemoryView_FromObject"];var _JsBuffer_cinit=Module["_JsBuffer_cinit"]=wasmExports["JsBuffer_cinit"];var _hiwire_new_deduplicate=Module["_hiwire_new_deduplicate"]=wasmExports["hiwire_new_deduplicate"];var _JsRef_new=Module["_JsRef_new"]=wasmExports["JsRef_new"];var _PyTuple_Pack=Module["_PyTuple_Pack"]=wasmExports["PyTuple_Pack"];var _PyLong_FromLong=Module["_PyLong_FromLong"]=wasmExports["PyLong_FromLong"];var _PyDict_GetItemWithError=Module["_PyDict_GetItemWithError"]=wasmExports["PyDict_GetItemWithError"];var _PyObject_SelfIter=Module["_PyObject_SelfIter"]=wasmExports["PyObject_SelfIter"];var _PyVectorcall_Call=Module["_PyVectorcall_Call"]=wasmExports["PyVectorcall_Call"];var _PyErr_NoMemory=Module["_PyErr_NoMemory"]=wasmExports["PyErr_NoMemory"];var _PyType_FromSpecWithBases=Module["_PyType_FromSpecWithBases"]=wasmExports["PyType_FromSpecWithBases"];var _PyObject_SetAttr=Module["_PyObject_SetAttr"]=wasmExports["PyObject_SetAttr"];var _PyMem_Free=Module["_PyMem_Free"]=wasmExports["PyMem_Free"];var _PyDict_SetItem=Module["_PyDict_SetItem"]=wasmExports["PyDict_SetItem"];var _JsProxy_create=Module["_JsProxy_create"]=wasmExports["JsProxy_create"];var _JsProxy_init_docstrings=Module["_JsProxy_init_docstrings"]=wasmExports["JsProxy_init_docstrings"];var _run_sync_not_supported=Module["_run_sync_not_supported"]=wasmExports["run_sync_not_supported"];var _run_sync=Module["_run_sync"]=wasmExports["run_sync"];var _py_is_awaitable=Module["_py_is_awaitable"]=wasmExports["py_is_awaitable"];var _JsvPromise_Syncify=Module["_JsvPromise_Syncify"]=wasmExports["JsvPromise_Syncify"];var _can_run_sync=Module["_can_run_sync"]=wasmExports["can_run_sync"];var _PyDict_New=Module["_PyDict_New"]=wasmExports["PyDict_New"];var _PyObject_SetAttrString=Module["_PyObject_SetAttrString"]=wasmExports["PyObject_SetAttrString"];var _PyModule_AddObject=Module["_PyModule_AddObject"]=wasmExports["PyModule_AddObject"];var _PyType_Ready=Module["_PyType_Ready"]=wasmExports["PyType_Ready"];var _JsMethod_Vectorcall_impl=Module["_JsMethod_Vectorcall_impl"]=wasmExports["JsMethod_Vectorcall_impl"];var _JsvObject_CallMethodId_TwoArgs=Module["_JsvObject_CallMethodId_TwoArgs"]=wasmExports["JsvObject_CallMethodId_TwoArgs"];var _PyObject_Repr=Module["_PyObject_Repr"]=wasmExports["PyObject_Repr"];var _PyIndex_Check=Module["_PyIndex_Check"]=wasmExports["PyIndex_Check"];var _PyNumber_AsSsize_t=Module["_PyNumber_AsSsize_t"]=wasmExports["PyNumber_AsSsize_t"];var _PySlice_Unpack=Module["_PySlice_Unpack"]=wasmExports["PySlice_Unpack"];var _PySlice_AdjustIndices=Module["_PySlice_AdjustIndices"]=wasmExports["PySlice_AdjustIndices"];var _PySequence_Fast=Module["_PySequence_Fast"]=wasmExports["PySequence_Fast"];var _PyArg_ParseTupleAndKeywords=Module["_PyArg_ParseTupleAndKeywords"]=wasmExports["PyArg_ParseTupleAndKeywords"];var _PySet_New=Module["_PySet_New"]=wasmExports["PySet_New"];var __PySet_Update=Module["__PySet_Update"]=wasmExports["_PySet_Update"];var _PyUnicode_FromString=Module["_PyUnicode_FromString"]=wasmExports["PyUnicode_FromString"];var _PySet_Discard=Module["_PySet_Discard"]=wasmExports["PySet_Discard"];var _PyList_New=Module["_PyList_New"]=wasmExports["PyList_New"];var _PyList_Extend=Module["_PyList_Extend"]=wasmExports["PyList_Extend"];var _PyList_Sort=Module["_PyList_Sort"]=wasmExports["PyList_Sort"];var __PyArg_ParseStack=Module["__PyArg_ParseStack"]=wasmExports["_PyArg_ParseStack"];var _PyObject_GetIter=Module["_PyObject_GetIter"]=wasmExports["PyObject_GetIter"];var _PyObject_RichCompareBool=Module["_PyObject_RichCompareBool"]=wasmExports["PyObject_RichCompareBool"];var _PyErr_WarnEx=Module["_PyErr_WarnEx"]=wasmExports["PyErr_WarnEx"];var __PyArg_ParseStackAndKeywords=Module["__PyArg_ParseStackAndKeywords"]=wasmExports["_PyArg_ParseStackAndKeywords"];var _hiwire_pop=Module["_hiwire_pop"]=wasmExports["hiwire_pop"];var _puts=Module["_puts"]=wasmExports["puts"];var _PyObject_GenericSetAttr=Module["_PyObject_GenericSetAttr"]=wasmExports["PyObject_GenericSetAttr"];var __Py_HashBytes=Module["__Py_HashBytes"]=wasmExports["_Py_HashBytes"];var _JsMethod_Construct_impl=Module["_JsMethod_Construct_impl"]=wasmExports["JsMethod_Construct_impl"];var __PyArg_CheckPositional=Module["__PyArg_CheckPositional"]=wasmExports["_PyArg_CheckPositional"];var _PyNumber_Index=Module["_PyNumber_Index"]=wasmExports["PyNumber_Index"];var _PyLong_AsSsize_t=Module["_PyLong_AsSsize_t"]=wasmExports["PyLong_AsSsize_t"];var _PyLong_FromSsize_t=Module["_PyLong_FromSsize_t"]=wasmExports["PyLong_FromSsize_t"];var _PyObject_GetItem=Module["_PyObject_GetItem"]=wasmExports["PyObject_GetItem"];var _PyObject_DelItem=Module["_PyObject_DelItem"]=wasmExports["PyObject_DelItem"];var _PyObject_SetItem=Module["_PyObject_SetItem"]=wasmExports["PyObject_SetItem"];var _PyObject_GetBuffer=Module["_PyObject_GetBuffer"]=wasmExports["PyObject_GetBuffer"];var _PyBuffer_Release=Module["_PyBuffer_Release"]=wasmExports["PyBuffer_Release"];var _PyBytes_FromStringAndSize=Module["_PyBytes_FromStringAndSize"]=wasmExports["PyBytes_FromStringAndSize"];var _PyObject_Vectorcall=Module["_PyObject_Vectorcall"]=wasmExports["PyObject_Vectorcall"];var _Py_EnterRecursiveCall=Module["_Py_EnterRecursiveCall"]=wasmExports["Py_EnterRecursiveCall"];var _Py_LeaveRecursiveCall=Module["_Py_LeaveRecursiveCall"]=wasmExports["Py_LeaveRecursiveCall"];var _Py2JsConverter_convert=Module["_Py2JsConverter_convert"]=wasmExports["Py2JsConverter_convert"];var _PyUnicode_FromFormat=Module["_PyUnicode_FromFormat"]=wasmExports["PyUnicode_FromFormat"];var _PyType_GenericNew=Module["_PyType_GenericNew"]=wasmExports["PyType_GenericNew"];var _PyObject_IsInstance=Module["_PyObject_IsInstance"]=wasmExports["PyObject_IsInstance"];var _python2js_inner=Module["_python2js_inner"]=wasmExports["python2js_inner"];var _python2js_custom=Module["_python2js_custom"]=wasmExports["python2js_custom"];var _PyObject_GC_UnTrack=Module["_PyObject_GC_UnTrack"]=wasmExports["PyObject_GC_UnTrack"];var _check_gil=Module["_check_gil"]=wasmExports["check_gil"];var _PyGILState_Check=Module["_PyGILState_Check"]=wasmExports["PyGILState_Check"];var _PyGen_GetCode=Module["_PyGen_GetCode"]=wasmExports["PyGen_GetCode"];var _pyproxy_getflags=Module["_pyproxy_getflags"]=wasmExports["pyproxy_getflags"];var _PyObject_HasAttr=Module["_PyObject_HasAttr"]=wasmExports["PyObject_HasAttr"];var _PyObject_IsSubclass=Module["_PyObject_IsSubclass"]=wasmExports["PyObject_IsSubclass"];var __pyproxy_repr=Module["__pyproxy_repr"]=wasmExports["_pyproxy_repr"];var _PyObject_Str=Module["_PyObject_Str"]=wasmExports["PyObject_Str"];var __pyproxy_type=Module["__pyproxy_type"]=wasmExports["_pyproxy_type"];var __pyproxy_hasattr=Module["__pyproxy_hasattr"]=wasmExports["_pyproxy_hasattr"];var _python2js_json_adaptor=Module["_python2js_json_adaptor"]=wasmExports["python2js_json_adaptor"];var __pyproxy_getattr=Module["__pyproxy_getattr"]=wasmExports["_pyproxy_getattr"];var __PyObject_GetMethod=Module["__PyObject_GetMethod"]=wasmExports["_PyObject_GetMethod"];var __pyproxy_setattr=Module["__pyproxy_setattr"]=wasmExports["_pyproxy_setattr"];var __pyproxy_delattr=Module["__pyproxy_delattr"]=wasmExports["_pyproxy_delattr"];var _PyObject_DelAttr=Module["_PyObject_DelAttr"]=wasmExports["PyObject_DelAttr"];var __pyproxy_getitem=Module["__pyproxy_getitem"]=wasmExports["_pyproxy_getitem"];var __pyproxy_setitem=Module["__pyproxy_setitem"]=wasmExports["_pyproxy_setitem"];var __pyproxy_delitem=Module["__pyproxy_delitem"]=wasmExports["_pyproxy_delitem"];var __pyproxy_slice_assign=Module["__pyproxy_slice_assign"]=wasmExports["_pyproxy_slice_assign"];var _PySequence_Size=Module["_PySequence_Size"]=wasmExports["PySequence_Size"];var _PySequence_GetSlice=Module["_PySequence_GetSlice"]=wasmExports["PySequence_GetSlice"];var _PySequence_SetSlice=Module["_PySequence_SetSlice"]=wasmExports["PySequence_SetSlice"];var _python2js_with_depth=Module["_python2js_with_depth"]=wasmExports["python2js_with_depth"];var __pyproxy_pop=Module["__pyproxy_pop"]=wasmExports["_pyproxy_pop"];var __pyproxy_contains=Module["__pyproxy_contains"]=wasmExports["_pyproxy_contains"];var _PySequence_Contains=Module["_PySequence_Contains"]=wasmExports["PySequence_Contains"];var __pyproxy_ownKeys=Module["__pyproxy_ownKeys"]=wasmExports["_pyproxy_ownKeys"];var _PyObject_Dir=Module["_PyObject_Dir"]=wasmExports["PyObject_Dir"];var _PyList_Size=Module["_PyList_Size"]=wasmExports["PyList_Size"];var _PyList_GetItem=Module["_PyList_GetItem"]=wasmExports["PyList_GetItem"];var __pyproxy_apply=Module["__pyproxy_apply"]=wasmExports["_pyproxy_apply"];var _PyTuple_New=Module["_PyTuple_New"]=wasmExports["PyTuple_New"];var __pyproxy_apply_promising=Module["__pyproxy_apply_promising"]=wasmExports["_pyproxy_apply_promising"];var __iscoroutinefunction=Module["__iscoroutinefunction"]=wasmExports["_iscoroutinefunction"];var __pyproxy_iter_next=Module["__pyproxy_iter_next"]=wasmExports["_pyproxy_iter_next"];var _PyIter_Next=Module["_PyIter_Next"]=wasmExports["PyIter_Next"];var __pyproxyGen_Send=Module["__pyproxyGen_Send"]=wasmExports["_pyproxyGen_Send"];var _PyIter_Send=Module["_PyIter_Send"]=wasmExports["PyIter_Send"];var __pyproxyGen_return=Module["__pyproxyGen_return"]=wasmExports["_pyproxyGen_return"];var __PyGen_FetchStopIterationValue=Module["__PyGen_FetchStopIterationValue"]=wasmExports["_PyGen_FetchStopIterationValue"];var __pyproxyGen_throw=Module["__pyproxyGen_throw"]=wasmExports["_pyproxyGen_throw"];var __pyproxyGen_asend=Module["__pyproxyGen_asend"]=wasmExports["_pyproxyGen_asend"];var __pyproxyGen_areturn=Module["__pyproxyGen_areturn"]=wasmExports["_pyproxyGen_areturn"];var __pyproxyGen_athrow=Module["__pyproxyGen_athrow"]=wasmExports["_pyproxyGen_athrow"];var __pyproxy_aiter_next=Module["__pyproxy_aiter_next"]=wasmExports["_pyproxy_aiter_next"];var _FutureDoneCallback_call_resolve=Module["_FutureDoneCallback_call_resolve"]=wasmExports["FutureDoneCallback_call_resolve"];var _FutureDoneCallback_call_reject=Module["_FutureDoneCallback_call_reject"]=wasmExports["FutureDoneCallback_call_reject"];var _FutureDoneCallback_call=Module["_FutureDoneCallback_call"]=wasmExports["FutureDoneCallback_call"];var _PyArg_UnpackTuple=Module["_PyArg_UnpackTuple"]=wasmExports["PyArg_UnpackTuple"];var __pyproxy_ensure_future=Module["__pyproxy_ensure_future"]=wasmExports["_pyproxy_ensure_future"];var __pyproxy_get_buffer=Module["__pyproxy_get_buffer"]=wasmExports["_pyproxy_get_buffer"];var _PyBuffer_FillContiguousStrides=Module["_PyBuffer_FillContiguousStrides"]=wasmExports["PyBuffer_FillContiguousStrides"];var _PyBuffer_IsContiguous=Module["_PyBuffer_IsContiguous"]=wasmExports["PyBuffer_IsContiguous"];var _create_promise_handles_result_helper=Module["_create_promise_handles_result_helper"]=wasmExports["create_promise_handles_result_helper"];var __python2js_buffer=Module["__python2js_buffer"]=wasmExports["_python2js_buffer"];var _Jsv_GetNull=Module["_Jsv_GetNull"]=wasmExports["Jsv_GetNull"];var _jslib_init_buffers=Module["_jslib_init_buffers"]=wasmExports["jslib_init_buffers"];var _JsRef_pop=Module["_JsRef_pop"]=wasmExports["JsRef_pop"];var _JsrString_FromId=Module["_JsrString_FromId"]=wasmExports["JsrString_FromId"];var _hiwire_intern=Module["_hiwire_intern"]=wasmExports["hiwire_intern"];var __python2js=Module["__python2js"]=wasmExports["_python2js"];var _PySequence_GetItem=Module["_PySequence_GetItem"]=wasmExports["PySequence_GetItem"];var _PyObject_CheckBuffer=Module["_PyObject_CheckBuffer"]=wasmExports["PyObject_CheckBuffer"];var _PyFloat_AsDouble=Module["_PyFloat_AsDouble"]=wasmExports["PyFloat_AsDouble"];var _python2js__default_converter=Module["_python2js__default_converter"]=wasmExports["python2js__default_converter"];var _python2js__eager_converter=Module["_python2js__eager_converter"]=wasmExports["python2js__eager_converter"];var _PyLong_AsLongAndOverflow=Module["_PyLong_AsLongAndOverflow"]=wasmExports["PyLong_AsLongAndOverflow"];var __PyLong_NumBits=Module["__PyLong_NumBits"]=wasmExports["_PyLong_NumBits"];var __PyLong_AsByteArray=Module["__PyLong_AsByteArray"]=wasmExports["_PyLong_AsByteArray"];var _saveAsyncioState=Module["_saveAsyncioState"]=wasmExports["saveAsyncioState"];var _PyObject_Hash=Module["_PyObject_Hash"]=wasmExports["PyObject_Hash"];var __PyDict_GetItem_KnownHash=Module["__PyDict_GetItem_KnownHash"]=wasmExports["_PyDict_GetItem_KnownHash"];var _restoreAsyncioState=Module["_restoreAsyncioState"]=wasmExports["restoreAsyncioState"];var _captureThreadState=Module["_captureThreadState"]=wasmExports["captureThreadState"];var _PyInterpreterState_Get=Module["_PyInterpreterState_Get"]=wasmExports["PyInterpreterState_Get"];var _PyThreadState_New=Module["_PyThreadState_New"]=wasmExports["PyThreadState_New"];var _PyThreadState_Swap=Module["_PyThreadState_Swap"]=wasmExports["PyThreadState_Swap"];var _restoreThreadState=Module["_restoreThreadState"]=wasmExports["restoreThreadState"];var _PyThreadState_Delete=Module["_PyThreadState_Delete"]=wasmExports["PyThreadState_Delete"];var _print_stdout=Module["_print_stdout"]=wasmExports["print_stdout"];var _fiprintf=Module["_fiprintf"]=wasmExports["fiprintf"];var _print_stderr=Module["_print_stderr"]=wasmExports["print_stderr"];var _main=Module["_main"]=wasmExports["__main_argc_argv"];var _PyImport_AppendInittab=Module["_PyImport_AppendInittab"]=wasmExports["PyImport_AppendInittab"];var _PyPreConfig_InitPythonConfig=Module["_PyPreConfig_InitPythonConfig"]=wasmExports["PyPreConfig_InitPythonConfig"];var _Py_PreInitializeFromBytesArgs=Module["_Py_PreInitializeFromBytesArgs"]=wasmExports["Py_PreInitializeFromBytesArgs"];var _PyStatus_Exception=Module["_PyStatus_Exception"]=wasmExports["PyStatus_Exception"];var _PyConfig_InitPythonConfig=Module["_PyConfig_InitPythonConfig"]=wasmExports["PyConfig_InitPythonConfig"];var _PyConfig_SetBytesArgv=Module["_PyConfig_SetBytesArgv"]=wasmExports["PyConfig_SetBytesArgv"];var _PyConfig_SetBytesString=Module["_PyConfig_SetBytesString"]=wasmExports["PyConfig_SetBytesString"];var _Py_InitializeFromConfig=Module["_Py_InitializeFromConfig"]=wasmExports["Py_InitializeFromConfig"];var _PyConfig_Clear=Module["_PyConfig_Clear"]=wasmExports["PyConfig_Clear"];var _Py_ExitStatusException=Module["_Py_ExitStatusException"]=wasmExports["Py_ExitStatusException"];var _run_main=Module["_run_main"]=wasmExports["run_main"];var _run_main_promising=Module["_run_main_promising"]=wasmExports["run_main_promising"];var _Py_GetBuildInfo=Module["_Py_GetBuildInfo"]=wasmExports["Py_GetBuildInfo"];var _PyOS_snprintf=Module["_PyOS_snprintf"]=wasmExports["PyOS_snprintf"];var __PyToken_OneChar=Module["__PyToken_OneChar"]=wasmExports["_PyToken_OneChar"];var __PyToken_TwoChars=Module["__PyToken_TwoChars"]=wasmExports["_PyToken_TwoChars"];var __PyToken_ThreeChars=Module["__PyToken_ThreeChars"]=wasmExports["_PyToken_ThreeChars"];var _strlen=Module["_strlen"]=wasmExports["strlen"];var _PyUnicode_DecodeUTF8=Module["_PyUnicode_DecodeUTF8"]=wasmExports["PyUnicode_DecodeUTF8"];var __PyArena_Malloc=Module["__PyArena_Malloc"]=wasmExports["_PyArena_Malloc"];var _strncpy=Module["_strncpy"]=wasmExports["strncpy"];var _PyMem_Realloc=Module["_PyMem_Realloc"]=wasmExports["PyMem_Realloc"];var _PyMem_Calloc=Module["_PyMem_Calloc"]=wasmExports["PyMem_Calloc"];var _strncmp=Module["_strncmp"]=wasmExports["strncmp"];var __PyArena_AddPyObject=Module["__PyArena_AddPyObject"]=wasmExports["_PyArena_AddPyObject"];var _PyBytes_AsString=Module["_PyBytes_AsString"]=wasmExports["PyBytes_AsString"];var __PyImport_GetModuleAttrString=Module["__PyImport_GetModuleAttrString"]=wasmExports["_PyImport_GetModuleAttrString"];var _PyUnicode_InternFromString=Module["_PyUnicode_InternFromString"]=wasmExports["PyUnicode_InternFromString"];var __PyType_Name=Module["__PyType_Name"]=wasmExports["_PyType_Name"];var __PyUnicode_InternImmortal=Module["__PyUnicode_InternImmortal"]=wasmExports["_PyUnicode_InternImmortal"];var _PyBytes_AsStringAndSize=Module["_PyBytes_AsStringAndSize"]=wasmExports["PyBytes_AsStringAndSize"];var _strchr=Module["_strchr"]=wasmExports["strchr"];var _PyUnicode_CompareWithASCIIString=Module["_PyUnicode_CompareWithASCIIString"]=wasmExports["PyUnicode_CompareWithASCIIString"];var ___errno_location=Module["___errno_location"]=wasmExports["__errno_location"];var _PyOS_strtoul=Module["_PyOS_strtoul"]=wasmExports["PyOS_strtoul"];var _PyLong_FromString=Module["_PyLong_FromString"]=wasmExports["PyLong_FromString"];var _PyOS_strtol=Module["_PyOS_strtol"]=wasmExports["PyOS_strtol"];var _PyOS_string_to_double=Module["_PyOS_string_to_double"]=wasmExports["PyOS_string_to_double"];var _PyComplex_FromCComplex=Module["_PyComplex_FromCComplex"]=wasmExports["PyComplex_FromCComplex"];var _PyFloat_FromDouble=Module["_PyFloat_FromDouble"]=wasmExports["PyFloat_FromDouble"];var _Py_BuildValue=Module["_Py_BuildValue"]=wasmExports["Py_BuildValue"];var _PyUnicode_FromFormatV=Module["_PyUnicode_FromFormatV"]=wasmExports["PyUnicode_FromFormatV"];var __PyErr_ProgramDecodedTextObject=Module["__PyErr_ProgramDecodedTextObject"]=wasmExports["_PyErr_ProgramDecodedTextObject"];var _PyUnicode_FromStringAndSize=Module["_PyUnicode_FromStringAndSize"]=wasmExports["PyUnicode_FromStringAndSize"];var _PyBytes_FromString=Module["_PyBytes_FromString"]=wasmExports["PyBytes_FromString"];var _PyBytes_Concat=Module["_PyBytes_Concat"]=wasmExports["PyBytes_Concat"];var __PyUnicodeWriter_Init=Module["__PyUnicodeWriter_Init"]=wasmExports["_PyUnicodeWriter_Init"];var __PyUnicodeWriter_WriteStr=Module["__PyUnicodeWriter_WriteStr"]=wasmExports["_PyUnicodeWriter_WriteStr"];var __PyUnicodeWriter_Dealloc=Module["__PyUnicodeWriter_Dealloc"]=wasmExports["_PyUnicodeWriter_Dealloc"];var __PyUnicodeWriter_Finish=Module["__PyUnicodeWriter_Finish"]=wasmExports["_PyUnicodeWriter_Finish"];var _strpbrk=Module["_strpbrk"]=wasmExports["strpbrk"];var _PyUnicode_DecodeUTF8Stateful=Module["_PyUnicode_DecodeUTF8Stateful"]=wasmExports["PyUnicode_DecodeUTF8Stateful"];var _siprintf=Module["_siprintf"]=wasmExports["siprintf"];var __PyUnicode_DecodeUnicodeEscapeInternal=Module["__PyUnicode_DecodeUnicodeEscapeInternal"]=wasmExports["_PyUnicode_DecodeUnicodeEscapeInternal"];var __PyErr_BadInternalCall=Module["__PyErr_BadInternalCall"]=wasmExports["_PyErr_BadInternalCall"];var __PyBytes_DecodeEscape=Module["__PyBytes_DecodeEscape"]=wasmExports["_PyBytes_DecodeEscape"];var _PyErr_WarnExplicitObject=Module["_PyErr_WarnExplicitObject"]=wasmExports["PyErr_WarnExplicitObject"];var _PySys_Audit=Module["_PySys_Audit"]=wasmExports["PySys_Audit"];var _memchr=Module["_memchr"]=wasmExports["memchr"];var __Py_FatalErrorFunc=Module["__Py_FatalErrorFunc"]=wasmExports["_Py_FatalErrorFunc"];var _memcmp=Module["_memcmp"]=wasmExports["memcmp"];var __PyUnicode_ScanIdentifier=Module["__PyUnicode_ScanIdentifier"]=wasmExports["_PyUnicode_ScanIdentifier"];var _PyUnicode_Substring=Module["_PyUnicode_Substring"]=wasmExports["PyUnicode_Substring"];var _PyUnicode_AsUTF8String=Module["_PyUnicode_AsUTF8String"]=wasmExports["PyUnicode_AsUTF8String"];var __PyUnicode_IsPrintable=Module["__PyUnicode_IsPrintable"]=wasmExports["_PyUnicode_IsPrintable"];var _PyOS_Readline=Module["_PyOS_Readline"]=wasmExports["PyOS_Readline"];var _strcpy=Module["_strcpy"]=wasmExports["strcpy"];var _PyObject_CallNoArgs=Module["_PyObject_CallNoArgs"]=wasmExports["PyObject_CallNoArgs"];var __Py_UniversalNewlineFgetsWithSize=Module["__Py_UniversalNewlineFgetsWithSize"]=wasmExports["_Py_UniversalNewlineFgetsWithSize"];var _fopencookie=Module["_fopencookie"]=wasmExports["fopencookie"];var _fclose=Module["_fclose"]=wasmExports["fclose"];var _getc=Module["_getc"]=wasmExports["getc"];var _ungetc=Module["_ungetc"]=wasmExports["ungetc"];var _ftell=Module["_ftell"]=wasmExports["ftell"];var _lseek=Module["_lseek"]=wasmExports["lseek"];var _PyErr_SetFromErrnoWithFilename=Module["_PyErr_SetFromErrnoWithFilename"]=wasmExports["PyErr_SetFromErrnoWithFilename"];var _PyObject_CallFunction=Module["_PyObject_CallFunction"]=wasmExports["PyObject_CallFunction"];var _PyObject_GetAttr=Module["_PyObject_GetAttr"]=wasmExports["PyObject_GetAttr"];var __PyObject_MakeTpCall=Module["__PyObject_MakeTpCall"]=wasmExports["_PyObject_MakeTpCall"];var __Py_CheckFunctionResult=Module["__Py_CheckFunctionResult"]=wasmExports["_Py_CheckFunctionResult"];var _read=Module["_read"]=wasmExports["read"];var _PyUnicode_Decode=Module["_PyUnicode_Decode"]=wasmExports["PyUnicode_Decode"];var _strcspn=Module["_strcspn"]=wasmExports["strcspn"];var _fflush=wasmExports["fflush"];var _fputs=Module["_fputs"]=wasmExports["fputs"];var _PyMem_RawFree=Module["_PyMem_RawFree"]=wasmExports["PyMem_RawFree"];var _PyEval_RestoreThread=Module["_PyEval_RestoreThread"]=wasmExports["PyEval_RestoreThread"];var _PyEval_SaveThread=Module["_PyEval_SaveThread"]=wasmExports["PyEval_SaveThread"];var _PyMem_RawRealloc=Module["_PyMem_RawRealloc"]=wasmExports["PyMem_RawRealloc"];var _clearerr=Module["_clearerr"]=wasmExports["clearerr"];var _fgets=Module["_fgets"]=wasmExports["fgets"];var _feof=Module["_feof"]=wasmExports["feof"];var _PyErr_CheckSignals=Module["_PyErr_CheckSignals"]=wasmExports["PyErr_CheckSignals"];var _PyMutex_Lock=Module["_PyMutex_Lock"]=wasmExports["PyMutex_Lock"];var _isatty=Module["_isatty"]=wasmExports["isatty"];var _PyMutex_Unlock=Module["_PyMutex_Unlock"]=wasmExports["PyMutex_Unlock"];var _PyObject_Type=Module["_PyObject_Type"]=wasmExports["PyObject_Type"];var __PyErr_SetString=Module["__PyErr_SetString"]=wasmExports["_PyErr_SetString"];var _PyObject_Size=Module["_PyObject_Size"]=wasmExports["PyObject_Size"];var _PyMapping_Size=Module["_PyMapping_Size"]=wasmExports["PyMapping_Size"];var _PyObject_Length=Module["_PyObject_Length"]=wasmExports["PyObject_Length"];var _PyObject_LengthHint=Module["_PyObject_LengthHint"]=wasmExports["PyObject_LengthHint"];var __PyErr_ExceptionMatches=Module["__PyErr_ExceptionMatches"]=wasmExports["_PyErr_ExceptionMatches"];var __PyErr_Clear=Module["__PyErr_Clear"]=wasmExports["_PyErr_Clear"];var __PyObject_LookupSpecial=Module["__PyObject_LookupSpecial"]=wasmExports["_PyObject_LookupSpecial"];var _Py_GenericAlias=Module["_Py_GenericAlias"]=wasmExports["Py_GenericAlias"];var _PyObject_GetOptionalAttr=Module["_PyObject_GetOptionalAttr"]=wasmExports["PyObject_GetOptionalAttr"];var __PyNumber_Index=Module["__PyNumber_Index"]=wasmExports["_PyNumber_Index"];var __PyErr_Format=Module["__PyErr_Format"]=wasmExports["_PyErr_Format"];var _PyMapping_GetOptionalItem=Module["_PyMapping_GetOptionalItem"]=wasmExports["PyMapping_GetOptionalItem"];var _PyDict_GetItemRef=Module["_PyDict_GetItemRef"]=wasmExports["PyDict_GetItemRef"];var _PySequence_SetItem=Module["_PySequence_SetItem"]=wasmExports["PySequence_SetItem"];var _PySequence_DelItem=Module["_PySequence_DelItem"]=wasmExports["PySequence_DelItem"];var _PyObject_DelItemString=Module["_PyObject_DelItemString"]=wasmExports["PyObject_DelItemString"];var _PyObject_CheckReadBuffer=Module["_PyObject_CheckReadBuffer"]=wasmExports["PyObject_CheckReadBuffer"];var _PyObject_AsCharBuffer=Module["_PyObject_AsCharBuffer"]=wasmExports["PyObject_AsCharBuffer"];var _PyObject_AsReadBuffer=Module["_PyObject_AsReadBuffer"]=wasmExports["PyObject_AsReadBuffer"];var _PyObject_AsWriteBuffer=Module["_PyObject_AsWriteBuffer"]=wasmExports["PyObject_AsWriteBuffer"];var _PyBuffer_GetPointer=Module["_PyBuffer_GetPointer"]=wasmExports["PyBuffer_GetPointer"];var _PyBuffer_SizeFromFormat=Module["_PyBuffer_SizeFromFormat"]=wasmExports["PyBuffer_SizeFromFormat"];var _PyObject_CallFunctionObjArgs=Module["_PyObject_CallFunctionObjArgs"]=wasmExports["PyObject_CallFunctionObjArgs"];var _PyBuffer_FromContiguous=Module["_PyBuffer_FromContiguous"]=wasmExports["PyBuffer_FromContiguous"];var _PyObject_CopyData=Module["_PyObject_CopyData"]=wasmExports["PyObject_CopyData"];var _PyBuffer_FillInfo=Module["_PyBuffer_FillInfo"]=wasmExports["PyBuffer_FillInfo"];var __PyBuffer_ReleaseInInterpreter=Module["__PyBuffer_ReleaseInInterpreter"]=wasmExports["_PyBuffer_ReleaseInInterpreter"];var __PyBuffer_ReleaseInInterpreterAndRawFree=Module["__PyBuffer_ReleaseInInterpreterAndRawFree"]=wasmExports["_PyBuffer_ReleaseInInterpreterAndRawFree"];var _PyObject_Format=Module["_PyObject_Format"]=wasmExports["PyObject_Format"];var _PyUnicode_New=Module["_PyUnicode_New"]=wasmExports["PyUnicode_New"];var _PyNumber_Check=Module["_PyNumber_Check"]=wasmExports["PyNumber_Check"];var _PyNumber_Or=Module["_PyNumber_Or"]=wasmExports["PyNumber_Or"];var _PyNumber_Xor=Module["_PyNumber_Xor"]=wasmExports["PyNumber_Xor"];var _PyNumber_And=Module["_PyNumber_And"]=wasmExports["PyNumber_And"];var _PyNumber_Lshift=Module["_PyNumber_Lshift"]=wasmExports["PyNumber_Lshift"];var _PyNumber_Rshift=Module["_PyNumber_Rshift"]=wasmExports["PyNumber_Rshift"];var _PyNumber_Subtract=Module["_PyNumber_Subtract"]=wasmExports["PyNumber_Subtract"];var _PyNumber_Divmod=Module["_PyNumber_Divmod"]=wasmExports["PyNumber_Divmod"];var _PyNumber_Add=Module["_PyNumber_Add"]=wasmExports["PyNumber_Add"];var _PyNumber_Multiply=Module["_PyNumber_Multiply"]=wasmExports["PyNumber_Multiply"];var _PyNumber_MatrixMultiply=Module["_PyNumber_MatrixMultiply"]=wasmExports["PyNumber_MatrixMultiply"];var _PyNumber_FloorDivide=Module["_PyNumber_FloorDivide"]=wasmExports["PyNumber_FloorDivide"];var _PyNumber_TrueDivide=Module["_PyNumber_TrueDivide"]=wasmExports["PyNumber_TrueDivide"];var _PyNumber_Remainder=Module["_PyNumber_Remainder"]=wasmExports["PyNumber_Remainder"];var _PyNumber_Power=Module["_PyNumber_Power"]=wasmExports["PyNumber_Power"];var _PyNumber_InPlaceOr=Module["_PyNumber_InPlaceOr"]=wasmExports["PyNumber_InPlaceOr"];var _PyNumber_InPlaceXor=Module["_PyNumber_InPlaceXor"]=wasmExports["PyNumber_InPlaceXor"];var _PyNumber_InPlaceAnd=Module["_PyNumber_InPlaceAnd"]=wasmExports["PyNumber_InPlaceAnd"];var _PyNumber_InPlaceLshift=Module["_PyNumber_InPlaceLshift"]=wasmExports["PyNumber_InPlaceLshift"];var _PyNumber_InPlaceRshift=Module["_PyNumber_InPlaceRshift"]=wasmExports["PyNumber_InPlaceRshift"];var _PyNumber_InPlaceSubtract=Module["_PyNumber_InPlaceSubtract"]=wasmExports["PyNumber_InPlaceSubtract"];var _PyNumber_InPlaceMatrixMultiply=Module["_PyNumber_InPlaceMatrixMultiply"]=wasmExports["PyNumber_InPlaceMatrixMultiply"];var _PyNumber_InPlaceFloorDivide=Module["_PyNumber_InPlaceFloorDivide"]=wasmExports["PyNumber_InPlaceFloorDivide"];var _PyNumber_InPlaceTrueDivide=Module["_PyNumber_InPlaceTrueDivide"]=wasmExports["PyNumber_InPlaceTrueDivide"];var _PyNumber_InPlaceRemainder=Module["_PyNumber_InPlaceRemainder"]=wasmExports["PyNumber_InPlaceRemainder"];var _PyNumber_InPlaceAdd=Module["_PyNumber_InPlaceAdd"]=wasmExports["PyNumber_InPlaceAdd"];var _PyNumber_InPlaceMultiply=Module["_PyNumber_InPlaceMultiply"]=wasmExports["PyNumber_InPlaceMultiply"];var _PyNumber_InPlacePower=Module["_PyNumber_InPlacePower"]=wasmExports["PyNumber_InPlacePower"];var _PyNumber_Negative=Module["_PyNumber_Negative"]=wasmExports["PyNumber_Negative"];var _PyNumber_Positive=Module["_PyNumber_Positive"]=wasmExports["PyNumber_Positive"];var _PyNumber_Invert=Module["_PyNumber_Invert"]=wasmExports["PyNumber_Invert"];var _PyNumber_Absolute=Module["_PyNumber_Absolute"]=wasmExports["PyNumber_Absolute"];var _PyErr_WarnFormat=Module["_PyErr_WarnFormat"]=wasmExports["PyErr_WarnFormat"];var __PyLong_Copy=Module["__PyLong_Copy"]=wasmExports["_PyLong_Copy"];var _PyNumber_Long=Module["_PyNumber_Long"]=wasmExports["PyNumber_Long"];var _PyLong_FromUnicodeObject=Module["_PyLong_FromUnicodeObject"]=wasmExports["PyLong_FromUnicodeObject"];var _PyNumber_Float=Module["_PyNumber_Float"]=wasmExports["PyNumber_Float"];var _PyLong_AsDouble=Module["_PyLong_AsDouble"]=wasmExports["PyLong_AsDouble"];var _PyFloat_FromString=Module["_PyFloat_FromString"]=wasmExports["PyFloat_FromString"];var _PyNumber_ToBase=Module["_PyNumber_ToBase"]=wasmExports["PyNumber_ToBase"];var __PyLong_Format=Module["__PyLong_Format"]=wasmExports["_PyLong_Format"];var _PySequence_Check=Module["_PySequence_Check"]=wasmExports["PySequence_Check"];var _PySequence_Length=Module["_PySequence_Length"]=wasmExports["PySequence_Length"];var _PySequence_Concat=Module["_PySequence_Concat"]=wasmExports["PySequence_Concat"];var _PySequence_Repeat=Module["_PySequence_Repeat"]=wasmExports["PySequence_Repeat"];var _PySequence_InPlaceConcat=Module["_PySequence_InPlaceConcat"]=wasmExports["PySequence_InPlaceConcat"];var _PySequence_InPlaceRepeat=Module["_PySequence_InPlaceRepeat"]=wasmExports["PySequence_InPlaceRepeat"];var __PySlice_FromIndices=Module["__PySlice_FromIndices"]=wasmExports["_PySlice_FromIndices"];var _PySequence_DelSlice=Module["_PySequence_DelSlice"]=wasmExports["PySequence_DelSlice"];var _PySequence_Tuple=Module["_PySequence_Tuple"]=wasmExports["PySequence_Tuple"];var _PyList_AsTuple=Module["_PyList_AsTuple"]=wasmExports["PyList_AsTuple"];var __PyTuple_Resize=Module["__PyTuple_Resize"]=wasmExports["_PyTuple_Resize"];var _PySeqIter_New=Module["_PySeqIter_New"]=wasmExports["PySeqIter_New"];var _PySequence_List=Module["_PySequence_List"]=wasmExports["PySequence_List"];var __PyList_Extend=Module["__PyList_Extend"]=wasmExports["_PyList_Extend"];var _PySequence_Count=Module["_PySequence_Count"]=wasmExports["PySequence_Count"];var _PySequence_In=Module["_PySequence_In"]=wasmExports["PySequence_In"];var _PySequence_Index=Module["_PySequence_Index"]=wasmExports["PySequence_Index"];var _PyMapping_Check=Module["_PyMapping_Check"]=wasmExports["PyMapping_Check"];var _PyMapping_Length=Module["_PyMapping_Length"]=wasmExports["PyMapping_Length"];var _PyMapping_GetItemString=Module["_PyMapping_GetItemString"]=wasmExports["PyMapping_GetItemString"];var _PyMapping_GetOptionalItemString=Module["_PyMapping_GetOptionalItemString"]=wasmExports["PyMapping_GetOptionalItemString"];var _PyMapping_SetItemString=Module["_PyMapping_SetItemString"]=wasmExports["PyMapping_SetItemString"];var _PyMapping_HasKeyStringWithError=Module["_PyMapping_HasKeyStringWithError"]=wasmExports["PyMapping_HasKeyStringWithError"];var _PyMapping_HasKeyWithError=Module["_PyMapping_HasKeyWithError"]=wasmExports["PyMapping_HasKeyWithError"];var _PyMapping_HasKeyString=Module["_PyMapping_HasKeyString"]=wasmExports["PyMapping_HasKeyString"];var _PyErr_FormatUnraisable=Module["_PyErr_FormatUnraisable"]=wasmExports["PyErr_FormatUnraisable"];var _PyMapping_HasKey=Module["_PyMapping_HasKey"]=wasmExports["PyMapping_HasKey"];var _PyMapping_Keys=Module["_PyMapping_Keys"]=wasmExports["PyMapping_Keys"];var _PyDict_Keys=Module["_PyDict_Keys"]=wasmExports["PyDict_Keys"];var _PyMapping_Items=Module["_PyMapping_Items"]=wasmExports["PyMapping_Items"];var _PyDict_Items=Module["_PyDict_Items"]=wasmExports["PyDict_Items"];var _PyMapping_Values=Module["_PyMapping_Values"]=wasmExports["PyMapping_Values"];var _PyDict_Values=Module["_PyDict_Values"]=wasmExports["PyDict_Values"];var __Py_CheckRecursiveCall=Module["__Py_CheckRecursiveCall"]=wasmExports["_Py_CheckRecursiveCall"];var _PyObject_IsTrue=Module["_PyObject_IsTrue"]=wasmExports["PyObject_IsTrue"];var _PyIter_Check=Module["_PyIter_Check"]=wasmExports["PyIter_Check"];var _PyObject_GetAIter=Module["_PyObject_GetAIter"]=wasmExports["PyObject_GetAIter"];var _PyAIter_Check=Module["_PyAIter_Check"]=wasmExports["PyAIter_Check"];var _PyBool_FromLong=Module["_PyBool_FromLong"]=wasmExports["PyBool_FromLong"];var __PyArg_NoKeywords=Module["__PyArg_NoKeywords"]=wasmExports["_PyArg_NoKeywords"];var _memrchr=Module["_memrchr"]=wasmExports["memrchr"];var _PyByteArray_FromObject=Module["_PyByteArray_FromObject"]=wasmExports["PyByteArray_FromObject"];var _PyByteArray_FromStringAndSize=Module["_PyByteArray_FromStringAndSize"]=wasmExports["PyByteArray_FromStringAndSize"];var __PyObject_New=Module["__PyObject_New"]=wasmExports["_PyObject_New"];var _PyByteArray_Size=Module["_PyByteArray_Size"]=wasmExports["PyByteArray_Size"];var _PyByteArray_AsString=Module["_PyByteArray_AsString"]=wasmExports["PyByteArray_AsString"];var _PyByteArray_Resize=Module["_PyByteArray_Resize"]=wasmExports["PyByteArray_Resize"];var _PyByteArray_Concat=Module["_PyByteArray_Concat"]=wasmExports["PyByteArray_Concat"];var __Py_GetConfig=Module["__Py_GetConfig"]=wasmExports["_Py_GetConfig"];var __PyObject_GC_New=Module["__PyObject_GC_New"]=wasmExports["_PyObject_GC_New"];var __PyArg_UnpackKeywords=Module["__PyArg_UnpackKeywords"]=wasmExports["_PyArg_UnpackKeywords"];var __PyArg_BadArgument=Module["__PyArg_BadArgument"]=wasmExports["_PyArg_BadArgument"];var _PyUnicode_AsEncodedString=Module["_PyUnicode_AsEncodedString"]=wasmExports["PyUnicode_AsEncodedString"];var _PyBuffer_ToContiguous=Module["_PyBuffer_ToContiguous"]=wasmExports["PyBuffer_ToContiguous"];var _PyObject_GC_Del=Module["_PyObject_GC_Del"]=wasmExports["PyObject_GC_Del"];var __PyBytes_Repeat=Module["__PyBytes_Repeat"]=wasmExports["_PyBytes_Repeat"];var __PyObject_GetState=Module["__PyObject_GetState"]=wasmExports["_PyObject_GetState"];var _PyUnicode_DecodeLatin1=Module["_PyUnicode_DecodeLatin1"]=wasmExports["PyUnicode_DecodeLatin1"];var _PyLong_AsInt=Module["_PyLong_AsInt"]=wasmExports["PyLong_AsInt"];var _PyLong_FromSize_t=Module["_PyLong_FromSize_t"]=wasmExports["PyLong_FromSize_t"];var __PyEval_SliceIndex=Module["__PyEval_SliceIndex"]=wasmExports["_PyEval_SliceIndex"];var _PyUnicode_GetDefaultEncoding=Module["_PyUnicode_GetDefaultEncoding"]=wasmExports["PyUnicode_GetDefaultEncoding"];var _PyUnicode_FromEncodedObject=Module["_PyUnicode_FromEncodedObject"]=wasmExports["PyUnicode_FromEncodedObject"];var _PyList_Append=Module["_PyList_Append"]=wasmExports["PyList_Append"];var _PyList_Reverse=Module["_PyList_Reverse"]=wasmExports["PyList_Reverse"];var __PyEval_GetBuiltin=Module["__PyEval_GetBuiltin"]=wasmExports["_PyEval_GetBuiltin"];var _PyObject_GenericGetAttr=Module["_PyObject_GenericGetAttr"]=wasmExports["PyObject_GenericGetAttr"];var _PyType_GenericAlloc=Module["_PyType_GenericAlloc"]=wasmExports["PyType_GenericAlloc"];var _PyObject_Free=Module["_PyObject_Free"]=wasmExports["PyObject_Free"];var _PyObject_Malloc=Module["_PyObject_Malloc"]=wasmExports["PyObject_Malloc"];var __Py_NewReference=Module["__Py_NewReference"]=wasmExports["_Py_NewReference"];var _PyObject_Calloc=Module["_PyObject_Calloc"]=wasmExports["PyObject_Calloc"];var _PyBytes_FromFormatV=Module["_PyBytes_FromFormatV"]=wasmExports["PyBytes_FromFormatV"];var __PyBytesWriter_Resize=Module["__PyBytesWriter_Resize"]=wasmExports["_PyBytesWriter_Resize"];var __PyBytesWriter_Finish=Module["__PyBytesWriter_Finish"]=wasmExports["_PyBytesWriter_Finish"];var __PyBytesWriter_Init=Module["__PyBytesWriter_Init"]=wasmExports["_PyBytesWriter_Init"];var __PyBytesWriter_Alloc=Module["__PyBytesWriter_Alloc"]=wasmExports["_PyBytesWriter_Alloc"];var __PyBytesWriter_WriteBytes=Module["__PyBytesWriter_WriteBytes"]=wasmExports["_PyBytesWriter_WriteBytes"];var __PyBytes_Resize=Module["__PyBytes_Resize"]=wasmExports["_PyBytes_Resize"];var __PyBytesWriter_Dealloc=Module["__PyBytesWriter_Dealloc"]=wasmExports["_PyBytesWriter_Dealloc"];var _PyBytes_FromFormat=Module["_PyBytes_FromFormat"]=wasmExports["PyBytes_FromFormat"];var _PyObject_ASCII=Module["_PyObject_ASCII"]=wasmExports["PyObject_ASCII"];var _PyOS_double_to_string=Module["_PyOS_double_to_string"]=wasmExports["PyOS_double_to_string"];var __PyBytesWriter_Prepare=Module["__PyBytesWriter_Prepare"]=wasmExports["_PyBytesWriter_Prepare"];var _PyBytes_DecodeEscape=Module["_PyBytes_DecodeEscape"]=wasmExports["PyBytes_DecodeEscape"];var _PyBytes_Size=Module["_PyBytes_Size"]=wasmExports["PyBytes_Size"];var __PyBytes_Find=Module["__PyBytes_Find"]=wasmExports["_PyBytes_Find"];var __PyBytes_ReverseFind=Module["__PyBytes_ReverseFind"]=wasmExports["_PyBytes_ReverseFind"];var _PyBytes_Repr=Module["_PyBytes_Repr"]=wasmExports["PyBytes_Repr"];var __PyBytes_Join=Module["__PyBytes_Join"]=wasmExports["_PyBytes_Join"];var _PyBytes_FromObject=Module["_PyBytes_FromObject"]=wasmExports["PyBytes_FromObject"];var _PyErr_BadArgument=Module["_PyErr_BadArgument"]=wasmExports["PyErr_BadArgument"];var _PyObject_Realloc=Module["_PyObject_Realloc"]=wasmExports["PyObject_Realloc"];var __Py_NewReferenceNoTotal=Module["__Py_NewReferenceNoTotal"]=wasmExports["_Py_NewReferenceNoTotal"];var _PyBytes_ConcatAndDel=Module["_PyBytes_ConcatAndDel"]=wasmExports["PyBytes_ConcatAndDel"];var _PyVectorcall_Function=Module["_PyVectorcall_Function"]=wasmExports["PyVectorcall_Function"];var __PyDict_FromItems=Module["__PyDict_FromItems"]=wasmExports["_PyDict_FromItems"];var _PyDict_Next=Module["_PyDict_Next"]=wasmExports["PyDict_Next"];var _PyObject_VectorcallDict=Module["_PyObject_VectorcallDict"]=wasmExports["PyObject_VectorcallDict"];var _PyModule_GetNameObject=Module["_PyModule_GetNameObject"]=wasmExports["PyModule_GetNameObject"];var _PyCallable_Check=Module["_PyCallable_Check"]=wasmExports["PyCallable_Check"];var __PyStack_AsDict=Module["__PyStack_AsDict"]=wasmExports["_PyStack_AsDict"];var _PyObject_Call=Module["_PyObject_Call"]=wasmExports["PyObject_Call"];var _PyCFunction_Call=Module["_PyCFunction_Call"]=wasmExports["PyCFunction_Call"];var _PyEval_CallObjectWithKeywords=Module["_PyEval_CallObjectWithKeywords"]=wasmExports["PyEval_CallObjectWithKeywords"];var _PyObject_CallObject=Module["_PyObject_CallObject"]=wasmExports["PyObject_CallObject"];var _PyEval_CallFunction=Module["_PyEval_CallFunction"]=wasmExports["PyEval_CallFunction"];var __PyObject_CallFunction_SizeT=Module["__PyObject_CallFunction_SizeT"]=wasmExports["_PyObject_CallFunction_SizeT"];var _PyObject_CallMethod=Module["_PyObject_CallMethod"]=wasmExports["PyObject_CallMethod"];var _PyEval_CallMethod=Module["_PyEval_CallMethod"]=wasmExports["PyEval_CallMethod"];var __PyObject_CallMethod=Module["__PyObject_CallMethod"]=wasmExports["_PyObject_CallMethod"];var __PyObject_CallMethodId=Module["__PyObject_CallMethodId"]=wasmExports["_PyObject_CallMethodId"];var __PyObject_CallMethod_SizeT=Module["__PyObject_CallMethod_SizeT"]=wasmExports["_PyObject_CallMethod_SizeT"];var _PyObject_CallMethodObjArgs=Module["_PyObject_CallMethodObjArgs"]=wasmExports["PyObject_CallMethodObjArgs"];var _PyVectorcall_NARGS=Module["_PyVectorcall_NARGS"]=wasmExports["PyVectorcall_NARGS"];var _PyCapsule_New=Module["_PyCapsule_New"]=wasmExports["PyCapsule_New"];var _PyCapsule_IsValid=Module["_PyCapsule_IsValid"]=wasmExports["PyCapsule_IsValid"];var _PyCapsule_GetPointer=Module["_PyCapsule_GetPointer"]=wasmExports["PyCapsule_GetPointer"];var _PyCapsule_GetName=Module["_PyCapsule_GetName"]=wasmExports["PyCapsule_GetName"];var _PyCapsule_GetDestructor=Module["_PyCapsule_GetDestructor"]=wasmExports["PyCapsule_GetDestructor"];var _PyCapsule_GetContext=Module["_PyCapsule_GetContext"]=wasmExports["PyCapsule_GetContext"];var _PyCapsule_SetPointer=Module["_PyCapsule_SetPointer"]=wasmExports["PyCapsule_SetPointer"];var _PyCapsule_SetName=Module["_PyCapsule_SetName"]=wasmExports["PyCapsule_SetName"];var _PyCapsule_SetDestructor=Module["_PyCapsule_SetDestructor"]=wasmExports["PyCapsule_SetDestructor"];var _PyCapsule_SetContext=Module["_PyCapsule_SetContext"]=wasmExports["PyCapsule_SetContext"];var __PyCapsule_SetTraverse=Module["__PyCapsule_SetTraverse"]=wasmExports["_PyCapsule_SetTraverse"];var _PyCapsule_Import=Module["_PyCapsule_Import"]=wasmExports["PyCapsule_Import"];var _PyCell_New=Module["_PyCell_New"]=wasmExports["PyCell_New"];var _PyCell_Get=Module["_PyCell_Get"]=wasmExports["PyCell_Get"];var _PyCell_Set=Module["_PyCell_Set"]=wasmExports["PyCell_Set"];var _PyObject_RichCompare=Module["_PyObject_RichCompare"]=wasmExports["PyObject_RichCompare"];var _PyMethod_Function=Module["_PyMethod_Function"]=wasmExports["PyMethod_Function"];var _PyMethod_Self=Module["_PyMethod_Self"]=wasmExports["PyMethod_Self"];var _PyMethod_New=Module["_PyMethod_New"]=wasmExports["PyMethod_New"];var _PyObject_ClearWeakRefs=Module["_PyObject_ClearWeakRefs"]=wasmExports["PyObject_ClearWeakRefs"];var _PyObject_GenericHash=Module["_PyObject_GenericHash"]=wasmExports["PyObject_GenericHash"];var __PyType_GetDict=Module["__PyType_GetDict"]=wasmExports["_PyType_GetDict"];var __PyType_LookupRef=Module["__PyType_LookupRef"]=wasmExports["_PyType_LookupRef"];var _PyInstanceMethod_New=Module["_PyInstanceMethod_New"]=wasmExports["PyInstanceMethod_New"];var _PyInstanceMethod_Function=Module["_PyInstanceMethod_Function"]=wasmExports["PyInstanceMethod_Function"];var _PyCode_AddWatcher=Module["_PyCode_AddWatcher"]=wasmExports["PyCode_AddWatcher"];var _PyCode_ClearWatcher=Module["_PyCode_ClearWatcher"]=wasmExports["PyCode_ClearWatcher"];var __PyObject_NewVar=Module["__PyObject_NewVar"]=wasmExports["_PyObject_NewVar"];var __PyUnicode_InternMortal=Module["__PyUnicode_InternMortal"]=wasmExports["_PyUnicode_InternMortal"];var _PyUnstable_Code_NewWithPosOnlyArgs=Module["_PyUnstable_Code_NewWithPosOnlyArgs"]=wasmExports["PyUnstable_Code_NewWithPosOnlyArgs"];var _PyUnicode_Compare=Module["_PyUnicode_Compare"]=wasmExports["PyUnicode_Compare"];var _PyUnstable_Code_New=Module["_PyUnstable_Code_New"]=wasmExports["PyUnstable_Code_New"];var _PyCode_NewEmpty=Module["_PyCode_NewEmpty"]=wasmExports["PyCode_NewEmpty"];var _PyUnicode_DecodeFSDefault=Module["_PyUnicode_DecodeFSDefault"]=wasmExports["PyUnicode_DecodeFSDefault"];var _PyCode_Addr2Line=Module["_PyCode_Addr2Line"]=wasmExports["PyCode_Addr2Line"];var __PyCode_CheckLineNumber=Module["__PyCode_CheckLineNumber"]=wasmExports["_PyCode_CheckLineNumber"];var _PyCode_Addr2Location=Module["_PyCode_Addr2Location"]=wasmExports["PyCode_Addr2Location"];var _PyUnstable_Code_GetExtra=Module["_PyUnstable_Code_GetExtra"]=wasmExports["PyUnstable_Code_GetExtra"];var _PyUnstable_Code_SetExtra=Module["_PyUnstable_Code_SetExtra"]=wasmExports["PyUnstable_Code_SetExtra"];var _PyCode_GetVarnames=Module["_PyCode_GetVarnames"]=wasmExports["PyCode_GetVarnames"];var _PyCode_GetCellvars=Module["_PyCode_GetCellvars"]=wasmExports["PyCode_GetCellvars"];var _PyCode_GetFreevars=Module["_PyCode_GetFreevars"]=wasmExports["PyCode_GetFreevars"];var _PyCode_GetCode=Module["_PyCode_GetCode"]=wasmExports["PyCode_GetCode"];var __PyCode_ConstantKey=Module["__PyCode_ConstantKey"]=wasmExports["_PyCode_ConstantKey"];var _PyComplex_AsCComplex=Module["_PyComplex_AsCComplex"]=wasmExports["PyComplex_AsCComplex"];var __PySet_NextEntry=Module["__PySet_NextEntry"]=wasmExports["_PySet_NextEntry"];var _PyFrozenSet_New=Module["_PyFrozenSet_New"]=wasmExports["PyFrozenSet_New"];var _PyLong_FromVoidPtr=Module["_PyLong_FromVoidPtr"]=wasmExports["PyLong_FromVoidPtr"];var __PyUnicode_Copy=Module["__PyUnicode_Copy"]=wasmExports["_PyUnicode_Copy"];var __Py_c_sum=Module["__Py_c_sum"]=wasmExports["_Py_c_sum"];var __Py_c_diff=Module["__Py_c_diff"]=wasmExports["_Py_c_diff"];var __Py_c_neg=Module["__Py_c_neg"]=wasmExports["_Py_c_neg"];var __Py_c_prod=Module["__Py_c_prod"]=wasmExports["_Py_c_prod"];var __Py_c_quot=Module["__Py_c_quot"]=wasmExports["_Py_c_quot"];var __Py_c_pow=Module["__Py_c_pow"]=wasmExports["_Py_c_pow"];var _atan2=Module["_atan2"]=wasmExports["atan2"];var _hypot=Module["_hypot"]=wasmExports["hypot"];var _pow=Module["_pow"]=wasmExports["pow"];var _log=Module["_log"]=wasmExports["log"];var _exp=Module["_exp"]=wasmExports["exp"];var _sin=Module["_sin"]=wasmExports["sin"];var _cos=Module["_cos"]=wasmExports["cos"];var __Py_c_abs=Module["__Py_c_abs"]=wasmExports["_Py_c_abs"];var _PyComplex_FromDoubles=Module["_PyComplex_FromDoubles"]=wasmExports["PyComplex_FromDoubles"];var _PyComplex_RealAsDouble=Module["_PyComplex_RealAsDouble"]=wasmExports["PyComplex_RealAsDouble"];var _PyComplex_ImagAsDouble=Module["_PyComplex_ImagAsDouble"]=wasmExports["PyComplex_ImagAsDouble"];var __Py_HashDouble=Module["__Py_HashDouble"]=wasmExports["_Py_HashDouble"];var __PyUnicode_TransformDecimalAndSpaceToASCII=Module["__PyUnicode_TransformDecimalAndSpaceToASCII"]=wasmExports["_PyUnicode_TransformDecimalAndSpaceToASCII"];var _PyCMethod_New=Module["_PyCMethod_New"]=wasmExports["PyCMethod_New"];var _PyMember_GetOne=Module["_PyMember_GetOne"]=wasmExports["PyMember_GetOne"];var _PyMember_SetOne=Module["_PyMember_SetOne"]=wasmExports["PyMember_SetOne"];var _PyTuple_GetSlice=Module["_PyTuple_GetSlice"]=wasmExports["PyTuple_GetSlice"];var _PyDescr_NewMethod=Module["_PyDescr_NewMethod"]=wasmExports["PyDescr_NewMethod"];var __PyObject_FunctionStr=Module["__PyObject_FunctionStr"]=wasmExports["_PyObject_FunctionStr"];var _PyDescr_NewClassMethod=Module["_PyDescr_NewClassMethod"]=wasmExports["PyDescr_NewClassMethod"];var _PyDescr_NewMember=Module["_PyDescr_NewMember"]=wasmExports["PyDescr_NewMember"];var _PyDescr_NewGetSet=Module["_PyDescr_NewGetSet"]=wasmExports["PyDescr_NewGetSet"];var _PyDescr_NewWrapper=Module["_PyDescr_NewWrapper"]=wasmExports["PyDescr_NewWrapper"];var _PyDescr_IsData=Module["_PyDescr_IsData"]=wasmExports["PyDescr_IsData"];var _PyDictProxy_New=Module["_PyDictProxy_New"]=wasmExports["PyDictProxy_New"];var _PyThreadState_Get=Module["_PyThreadState_Get"]=wasmExports["PyThreadState_Get"];var __PyTrash_thread_deposit_object=Module["__PyTrash_thread_deposit_object"]=wasmExports["_PyTrash_thread_deposit_object"];var __PyTrash_thread_destroy_chain=Module["__PyTrash_thread_destroy_chain"]=wasmExports["_PyTrash_thread_destroy_chain"];var _Py_HashPointer=Module["_Py_HashPointer"]=wasmExports["Py_HashPointer"];var _PyWrapper_New=Module["_PyWrapper_New"]=wasmExports["PyWrapper_New"];var _PyType_GetQualName=Module["_PyType_GetQualName"]=wasmExports["PyType_GetQualName"];var _PyDict_Contains=Module["_PyDict_Contains"]=wasmExports["PyDict_Contains"];var __PyUnicode_EqualToASCIIString=Module["__PyUnicode_EqualToASCIIString"]=wasmExports["_PyUnicode_EqualToASCIIString"];var _PyException_GetCause=Module["_PyException_GetCause"]=wasmExports["PyException_GetCause"];var _PyException_SetCause=Module["_PyException_SetCause"]=wasmExports["PyException_SetCause"];var _PyException_GetContext=Module["_PyException_GetContext"]=wasmExports["PyException_GetContext"];var _PyException_SetContext=Module["_PyException_SetContext"]=wasmExports["PyException_SetContext"];var _PyException_GetArgs=Module["_PyException_GetArgs"]=wasmExports["PyException_GetArgs"];var _PyException_SetArgs=Module["_PyException_SetArgs"]=wasmExports["PyException_SetArgs"];var _PyExceptionClass_Name=Module["_PyExceptionClass_Name"]=wasmExports["PyExceptionClass_Name"];var _PyUnstable_Exc_PrepReraiseStar=Module["_PyUnstable_Exc_PrepReraiseStar"]=wasmExports["PyUnstable_Exc_PrepReraiseStar"];var _PyUnicodeEncodeError_GetEncoding=Module["_PyUnicodeEncodeError_GetEncoding"]=wasmExports["PyUnicodeEncodeError_GetEncoding"];var _PyUnicodeDecodeError_GetEncoding=Module["_PyUnicodeDecodeError_GetEncoding"]=wasmExports["PyUnicodeDecodeError_GetEncoding"];var _PyUnicodeEncodeError_GetObject=Module["_PyUnicodeEncodeError_GetObject"]=wasmExports["PyUnicodeEncodeError_GetObject"];var _PyUnicodeDecodeError_GetObject=Module["_PyUnicodeDecodeError_GetObject"]=wasmExports["PyUnicodeDecodeError_GetObject"];var _PyUnicodeTranslateError_GetObject=Module["_PyUnicodeTranslateError_GetObject"]=wasmExports["PyUnicodeTranslateError_GetObject"];var _PyUnicodeEncodeError_GetStart=Module["_PyUnicodeEncodeError_GetStart"]=wasmExports["PyUnicodeEncodeError_GetStart"];var _PyUnicodeDecodeError_GetStart=Module["_PyUnicodeDecodeError_GetStart"]=wasmExports["PyUnicodeDecodeError_GetStart"];var _PyUnicodeTranslateError_GetStart=Module["_PyUnicodeTranslateError_GetStart"]=wasmExports["PyUnicodeTranslateError_GetStart"];var _PyUnicodeEncodeError_SetStart=Module["_PyUnicodeEncodeError_SetStart"]=wasmExports["PyUnicodeEncodeError_SetStart"];var _PyUnicodeDecodeError_SetStart=Module["_PyUnicodeDecodeError_SetStart"]=wasmExports["PyUnicodeDecodeError_SetStart"];var _PyUnicodeTranslateError_SetStart=Module["_PyUnicodeTranslateError_SetStart"]=wasmExports["PyUnicodeTranslateError_SetStart"];var _PyUnicodeEncodeError_GetEnd=Module["_PyUnicodeEncodeError_GetEnd"]=wasmExports["PyUnicodeEncodeError_GetEnd"];var _PyUnicodeDecodeError_GetEnd=Module["_PyUnicodeDecodeError_GetEnd"]=wasmExports["PyUnicodeDecodeError_GetEnd"];var _PyUnicodeTranslateError_GetEnd=Module["_PyUnicodeTranslateError_GetEnd"]=wasmExports["PyUnicodeTranslateError_GetEnd"];var _PyUnicodeEncodeError_SetEnd=Module["_PyUnicodeEncodeError_SetEnd"]=wasmExports["PyUnicodeEncodeError_SetEnd"];var _PyUnicodeDecodeError_SetEnd=Module["_PyUnicodeDecodeError_SetEnd"]=wasmExports["PyUnicodeDecodeError_SetEnd"];var _PyUnicodeTranslateError_SetEnd=Module["_PyUnicodeTranslateError_SetEnd"]=wasmExports["PyUnicodeTranslateError_SetEnd"];var _PyUnicodeEncodeError_GetReason=Module["_PyUnicodeEncodeError_GetReason"]=wasmExports["PyUnicodeEncodeError_GetReason"];var _PyUnicodeDecodeError_GetReason=Module["_PyUnicodeDecodeError_GetReason"]=wasmExports["PyUnicodeDecodeError_GetReason"];var _PyUnicodeTranslateError_GetReason=Module["_PyUnicodeTranslateError_GetReason"]=wasmExports["PyUnicodeTranslateError_GetReason"];var _PyUnicodeEncodeError_SetReason=Module["_PyUnicodeEncodeError_SetReason"]=wasmExports["PyUnicodeEncodeError_SetReason"];var _PyUnicodeDecodeError_SetReason=Module["_PyUnicodeDecodeError_SetReason"]=wasmExports["PyUnicodeDecodeError_SetReason"];var _PyUnicodeTranslateError_SetReason=Module["_PyUnicodeTranslateError_SetReason"]=wasmExports["PyUnicodeTranslateError_SetReason"];var _PyUnicodeDecodeError_Create=Module["_PyUnicodeDecodeError_Create"]=wasmExports["PyUnicodeDecodeError_Create"];var _PyModule_GetDict=Module["_PyModule_GetDict"]=wasmExports["PyModule_GetDict"];var _PyErr_NewException=Module["_PyErr_NewException"]=wasmExports["PyErr_NewException"];var _PySet_Add=Module["_PySet_Add"]=wasmExports["PySet_Add"];var _PySet_Contains=Module["_PySet_Contains"]=wasmExports["PySet_Contains"];var _PyTuple_Size=Module["_PyTuple_Size"]=wasmExports["PyTuple_Size"];var _PyDict_Copy=Module["_PyDict_Copy"]=wasmExports["PyDict_Copy"];var _PyUnicode_ReadChar=Module["_PyUnicode_ReadChar"]=wasmExports["PyUnicode_ReadChar"];var _PyObject_GenericGetDict=Module["_PyObject_GenericGetDict"]=wasmExports["PyObject_GenericGetDict"];var _PyObject_GenericSetDict=Module["_PyObject_GenericSetDict"]=wasmExports["PyObject_GenericSetDict"];var _PyObject_HasAttrWithError=Module["_PyObject_HasAttrWithError"]=wasmExports["PyObject_HasAttrWithError"];var _PyList_SetSlice=Module["_PyList_SetSlice"]=wasmExports["PyList_SetSlice"];var __PyUnicodeWriter_WriteASCIIString=Module["__PyUnicodeWriter_WriteASCIIString"]=wasmExports["_PyUnicodeWriter_WriteASCIIString"];var _PyObject_GC_Track=Module["_PyObject_GC_Track"]=wasmExports["PyObject_GC_Track"];var __Py_union_type_or=Module["__Py_union_type_or"]=wasmExports["_Py_union_type_or"];var _PyErr_WriteUnraisable=Module["_PyErr_WriteUnraisable"]=wasmExports["PyErr_WriteUnraisable"];var __PyGen_yf=Module["__PyGen_yf"]=wasmExports["_PyGen_yf"];var _PyObject_CallFinalizerFromDealloc=Module["_PyObject_CallFinalizerFromDealloc"]=wasmExports["PyObject_CallFinalizerFromDealloc"];var __Py_MakeCoro=Module["__Py_MakeCoro"]=wasmExports["_Py_MakeCoro"];var __PyObject_GC_NewVar=Module["__PyObject_GC_NewVar"]=wasmExports["_PyObject_GC_NewVar"];var _PyUnstable_InterpreterFrame_GetLine=Module["_PyUnstable_InterpreterFrame_GetLine"]=wasmExports["PyUnstable_InterpreterFrame_GetLine"];var _PyGen_NewWithQualName=Module["_PyGen_NewWithQualName"]=wasmExports["PyGen_NewWithQualName"];var _PyGen_New=Module["_PyGen_New"]=wasmExports["PyGen_New"];var __PyCoro_GetAwaitableIter=Module["__PyCoro_GetAwaitableIter"]=wasmExports["_PyCoro_GetAwaitableIter"];var _PyCoro_New=Module["_PyCoro_New"]=wasmExports["PyCoro_New"];var _PyAsyncGen_New=Module["_PyAsyncGen_New"]=wasmExports["PyAsyncGen_New"];var __PyEval_EvalFrameDefault=Module["__PyEval_EvalFrameDefault"]=wasmExports["_PyEval_EvalFrameDefault"];var _PyFile_FromFd=Module["_PyFile_FromFd"]=wasmExports["PyFile_FromFd"];var _PyFile_GetLine=Module["_PyFile_GetLine"]=wasmExports["PyFile_GetLine"];var _PyFile_WriteObject=Module["_PyFile_WriteObject"]=wasmExports["PyFile_WriteObject"];var _PyFile_WriteString=Module["_PyFile_WriteString"]=wasmExports["PyFile_WriteString"];var _PyObject_AsFileDescriptor=Module["_PyObject_AsFileDescriptor"]=wasmExports["PyObject_AsFileDescriptor"];var __PyLong_FileDescriptor_Converter=Module["__PyLong_FileDescriptor_Converter"]=wasmExports["_PyLong_FileDescriptor_Converter"];var _flockfile=Module["_flockfile"]=wasmExports["flockfile"];var _getc_unlocked=Module["_getc_unlocked"]=wasmExports["getc_unlocked"];var _funlockfile=Module["_funlockfile"]=wasmExports["funlockfile"];var _Py_UniversalNewlineFgets=Module["_Py_UniversalNewlineFgets"]=wasmExports["Py_UniversalNewlineFgets"];var _PyFile_NewStdPrinter=Module["_PyFile_NewStdPrinter"]=wasmExports["PyFile_NewStdPrinter"];var _PyFile_SetOpenCodeHook=Module["_PyFile_SetOpenCodeHook"]=wasmExports["PyFile_SetOpenCodeHook"];var _Py_IsInitialized=Module["_Py_IsInitialized"]=wasmExports["Py_IsInitialized"];var _PyFile_OpenCodeObject=Module["_PyFile_OpenCodeObject"]=wasmExports["PyFile_OpenCodeObject"];var _PyFile_OpenCode=Module["_PyFile_OpenCode"]=wasmExports["PyFile_OpenCode"];var __PyUnicode_AsUTF8String=Module["__PyUnicode_AsUTF8String"]=wasmExports["_PyUnicode_AsUTF8String"];var __Py_write=Module["__Py_write"]=wasmExports["_Py_write"];var _PyFloat_GetMax=Module["_PyFloat_GetMax"]=wasmExports["PyFloat_GetMax"];var _PyFloat_GetMin=Module["_PyFloat_GetMin"]=wasmExports["PyFloat_GetMin"];var _PyFloat_GetInfo=Module["_PyFloat_GetInfo"]=wasmExports["PyFloat_GetInfo"];var _PyStructSequence_New=Module["_PyStructSequence_New"]=wasmExports["PyStructSequence_New"];var _PyStructSequence_SetItem=Module["_PyStructSequence_SetItem"]=wasmExports["PyStructSequence_SetItem"];var __PyFloat_ExactDealloc=Module["__PyFloat_ExactDealloc"]=wasmExports["_PyFloat_ExactDealloc"];var __PyLong_Sign=Module["__PyLong_Sign"]=wasmExports["_PyLong_Sign"];var _frexp=Module["_frexp"]=wasmExports["frexp"];var _modf=Module["_modf"]=wasmExports["modf"];var _PyLong_FromDouble=Module["_PyLong_FromDouble"]=wasmExports["PyLong_FromDouble"];var __PyLong_Lshift=Module["__PyLong_Lshift"]=wasmExports["_PyLong_Lshift"];var _PyFloat_Pack2=Module["_PyFloat_Pack2"]=wasmExports["PyFloat_Pack2"];var _ldexp=Module["_ldexp"]=wasmExports["ldexp"];var _PyFloat_Pack4=Module["_PyFloat_Pack4"]=wasmExports["PyFloat_Pack4"];var _PyFloat_Pack8=Module["_PyFloat_Pack8"]=wasmExports["PyFloat_Pack8"];var _PyFloat_Unpack2=Module["_PyFloat_Unpack2"]=wasmExports["PyFloat_Unpack2"];var _PyFloat_Unpack4=Module["_PyFloat_Unpack4"]=wasmExports["PyFloat_Unpack4"];var _PyFloat_Unpack8=Module["_PyFloat_Unpack8"]=wasmExports["PyFloat_Unpack8"];var _fmod=Module["_fmod"]=wasmExports["fmod"];var _PyErr_SetFromErrno=Module["_PyErr_SetFromErrno"]=wasmExports["PyErr_SetFromErrno"];var _round=Module["_round"]=wasmExports["round"];var _strtol=Module["_strtol"]=wasmExports["strtol"];var _Py_ReprEnter=Module["_Py_ReprEnter"]=wasmExports["Py_ReprEnter"];var _PyDict_Update=Module["_PyDict_Update"]=wasmExports["PyDict_Update"];var _Py_ReprLeave=Module["_Py_ReprLeave"]=wasmExports["Py_ReprLeave"];var _PyDict_Size=Module["_PyDict_Size"]=wasmExports["PyDict_Size"];var _PyFrame_GetLineNumber=Module["_PyFrame_GetLineNumber"]=wasmExports["PyFrame_GetLineNumber"];var _PyFrame_New=Module["_PyFrame_New"]=wasmExports["PyFrame_New"];var _PyFrame_GetVar=Module["_PyFrame_GetVar"]=wasmExports["PyFrame_GetVar"];var __PyUnicode_Equal=Module["__PyUnicode_Equal"]=wasmExports["_PyUnicode_Equal"];var _PyFrame_GetVarString=Module["_PyFrame_GetVarString"]=wasmExports["PyFrame_GetVarString"];var _PyFrame_FastToLocalsWithError=Module["_PyFrame_FastToLocalsWithError"]=wasmExports["PyFrame_FastToLocalsWithError"];var _PyFrame_FastToLocals=Module["_PyFrame_FastToLocals"]=wasmExports["PyFrame_FastToLocals"];var _PyFrame_LocalsToFast=Module["_PyFrame_LocalsToFast"]=wasmExports["PyFrame_LocalsToFast"];var __PyFrame_IsEntryFrame=Module["__PyFrame_IsEntryFrame"]=wasmExports["_PyFrame_IsEntryFrame"];var _PyFrame_GetCode=Module["_PyFrame_GetCode"]=wasmExports["PyFrame_GetCode"];var _PyFrame_GetBack=Module["_PyFrame_GetBack"]=wasmExports["PyFrame_GetBack"];var _PyFrame_GetLocals=Module["_PyFrame_GetLocals"]=wasmExports["PyFrame_GetLocals"];var _PyFrame_GetGlobals=Module["_PyFrame_GetGlobals"]=wasmExports["PyFrame_GetGlobals"];var _PyFrame_GetBuiltins=Module["_PyFrame_GetBuiltins"]=wasmExports["PyFrame_GetBuiltins"];var _PyFrame_GetLasti=Module["_PyFrame_GetLasti"]=wasmExports["PyFrame_GetLasti"];var _PyFrame_GetGenerator=Module["_PyFrame_GetGenerator"]=wasmExports["PyFrame_GetGenerator"];var __PyErr_SetKeyError=Module["__PyErr_SetKeyError"]=wasmExports["_PyErr_SetKeyError"];var _PyDict_DelItem=Module["_PyDict_DelItem"]=wasmExports["PyDict_DelItem"];var _PyDict_GetItem=Module["_PyDict_GetItem"]=wasmExports["PyDict_GetItem"];var _PyDict_Pop=Module["_PyDict_Pop"]=wasmExports["PyDict_Pop"];var _PyCompile_OpcodeStackEffect=Module["_PyCompile_OpcodeStackEffect"]=wasmExports["PyCompile_OpcodeStackEffect"];var _PyFunction_AddWatcher=Module["_PyFunction_AddWatcher"]=wasmExports["PyFunction_AddWatcher"];var _PyFunction_ClearWatcher=Module["_PyFunction_ClearWatcher"]=wasmExports["PyFunction_ClearWatcher"];var _PyFunction_NewWithQualName=Module["_PyFunction_NewWithQualName"]=wasmExports["PyFunction_NewWithQualName"];var __PyFunction_SetVersion=Module["__PyFunction_SetVersion"]=wasmExports["_PyFunction_SetVersion"];var _PyFunction_New=Module["_PyFunction_New"]=wasmExports["PyFunction_New"];var _PyFunction_GetCode=Module["_PyFunction_GetCode"]=wasmExports["PyFunction_GetCode"];var _PyFunction_GetGlobals=Module["_PyFunction_GetGlobals"]=wasmExports["PyFunction_GetGlobals"];var _PyFunction_GetModule=Module["_PyFunction_GetModule"]=wasmExports["PyFunction_GetModule"];var _PyFunction_GetDefaults=Module["_PyFunction_GetDefaults"]=wasmExports["PyFunction_GetDefaults"];var _PyFunction_SetDefaults=Module["_PyFunction_SetDefaults"]=wasmExports["PyFunction_SetDefaults"];var _PyFunction_SetVectorcall=Module["_PyFunction_SetVectorcall"]=wasmExports["PyFunction_SetVectorcall"];var _PyFunction_GetKwDefaults=Module["_PyFunction_GetKwDefaults"]=wasmExports["PyFunction_GetKwDefaults"];var _PyFunction_SetKwDefaults=Module["_PyFunction_SetKwDefaults"]=wasmExports["PyFunction_SetKwDefaults"];var _PyFunction_GetClosure=Module["_PyFunction_GetClosure"]=wasmExports["PyFunction_GetClosure"];var _PyFunction_SetClosure=Module["_PyFunction_SetClosure"]=wasmExports["PyFunction_SetClosure"];var _PyFunction_GetAnnotations=Module["_PyFunction_GetAnnotations"]=wasmExports["PyFunction_GetAnnotations"];var _PyFunction_SetAnnotations=Module["_PyFunction_SetAnnotations"]=wasmExports["PyFunction_SetAnnotations"];var _PyClassMethod_New=Module["_PyClassMethod_New"]=wasmExports["PyClassMethod_New"];var _PyStaticMethod_New=Module["_PyStaticMethod_New"]=wasmExports["PyStaticMethod_New"];var _PyCallIter_New=Module["_PyCallIter_New"]=wasmExports["PyCallIter_New"];var _PyList_GetItemRef=Module["_PyList_GetItemRef"]=wasmExports["PyList_GetItemRef"];var _PyList_SetItem=Module["_PyList_SetItem"]=wasmExports["PyList_SetItem"];var _PyList_Insert=Module["_PyList_Insert"]=wasmExports["PyList_Insert"];var __PyList_AppendTakeRefListResize=Module["__PyList_AppendTakeRefListResize"]=wasmExports["_PyList_AppendTakeRefListResize"];var _PyList_GetSlice=Module["_PyList_GetSlice"]=wasmExports["PyList_GetSlice"];var __PySet_NextEntryRef=Module["__PySet_NextEntryRef"]=wasmExports["_PySet_NextEntryRef"];var _PyList_Clear=Module["_PyList_Clear"]=wasmExports["PyList_Clear"];var __PyList_FromArraySteal=Module["__PyList_FromArraySteal"]=wasmExports["_PyList_FromArraySteal"];var __PyUnicodeWriter_WriteChar=Module["__PyUnicodeWriter_WriteChar"]=wasmExports["_PyUnicodeWriter_WriteChar"];var __PyEval_SliceIndexNotNone=Module["__PyEval_SliceIndexNotNone"]=wasmExports["_PyEval_SliceIndexNotNone"];var _PyObject_HashNotImplemented=Module["_PyObject_HashNotImplemented"]=wasmExports["PyObject_HashNotImplemented"];var __PyLong_New=Module["__PyLong_New"]=wasmExports["_PyLong_New"];var __PyLong_FromDigits=Module["__PyLong_FromDigits"]=wasmExports["_PyLong_FromDigits"];var _PyLong_FromUnsignedLong=Module["_PyLong_FromUnsignedLong"]=wasmExports["PyLong_FromUnsignedLong"];var _PyLong_FromUnsignedLongLong=Module["_PyLong_FromUnsignedLongLong"]=wasmExports["PyLong_FromUnsignedLongLong"];var _PyLong_AsUnsignedLong=Module["_PyLong_AsUnsignedLong"]=wasmExports["PyLong_AsUnsignedLong"];var _PyLong_AsSize_t=Module["_PyLong_AsSize_t"]=wasmExports["PyLong_AsSize_t"];var _PyLong_AsUnsignedLongMask=Module["_PyLong_AsUnsignedLongMask"]=wasmExports["PyLong_AsUnsignedLongMask"];var __PyLong_FromByteArray=Module["__PyLong_FromByteArray"]=wasmExports["_PyLong_FromByteArray"];var _PyLong_AsNativeBytes=Module["_PyLong_AsNativeBytes"]=wasmExports["PyLong_AsNativeBytes"];var _PyLong_FromNativeBytes=Module["_PyLong_FromNativeBytes"]=wasmExports["PyLong_FromNativeBytes"];var _PyLong_FromUnsignedNativeBytes=Module["_PyLong_FromUnsignedNativeBytes"]=wasmExports["PyLong_FromUnsignedNativeBytes"];var _PyLong_AsVoidPtr=Module["_PyLong_AsVoidPtr"]=wasmExports["PyLong_AsVoidPtr"];var _PyLong_FromLongLong=Module["_PyLong_FromLongLong"]=wasmExports["PyLong_FromLongLong"];var _PyLong_AsLongLong=Module["_PyLong_AsLongLong"]=wasmExports["PyLong_AsLongLong"];var _PyLong_AsUnsignedLongLong=Module["_PyLong_AsUnsignedLongLong"]=wasmExports["PyLong_AsUnsignedLongLong"];var _PyLong_AsUnsignedLongLongMask=Module["_PyLong_AsUnsignedLongLongMask"]=wasmExports["PyLong_AsUnsignedLongLongMask"];var _PyLong_AsLongLongAndOverflow=Module["_PyLong_AsLongLongAndOverflow"]=wasmExports["PyLong_AsLongLongAndOverflow"];var __PyLong_UnsignedShort_Converter=Module["__PyLong_UnsignedShort_Converter"]=wasmExports["_PyLong_UnsignedShort_Converter"];var __PyLong_UnsignedInt_Converter=Module["__PyLong_UnsignedInt_Converter"]=wasmExports["_PyLong_UnsignedInt_Converter"];var __PyLong_UnsignedLong_Converter=Module["__PyLong_UnsignedLong_Converter"]=wasmExports["_PyLong_UnsignedLong_Converter"];var __PyLong_UnsignedLongLong_Converter=Module["__PyLong_UnsignedLongLong_Converter"]=wasmExports["_PyLong_UnsignedLongLong_Converter"];var __PyLong_Size_t_Converter=Module["__PyLong_Size_t_Converter"]=wasmExports["_PyLong_Size_t_Converter"];var __PyUnicodeWriter_PrepareInternal=Module["__PyUnicodeWriter_PrepareInternal"]=wasmExports["_PyUnicodeWriter_PrepareInternal"];var __PyLong_Frexp=Module["__PyLong_Frexp"]=wasmExports["_PyLong_Frexp"];var __PyLong_Add=Module["__PyLong_Add"]=wasmExports["_PyLong_Add"];var __PyLong_Subtract=Module["__PyLong_Subtract"]=wasmExports["_PyLong_Subtract"];var __PyLong_Multiply=Module["__PyLong_Multiply"]=wasmExports["_PyLong_Multiply"];var __PyLong_Rshift=Module["__PyLong_Rshift"]=wasmExports["_PyLong_Rshift"];var __PyLong_GCD=Module["__PyLong_GCD"]=wasmExports["_PyLong_GCD"];var __PyLong_DivmodNear=Module["__PyLong_DivmodNear"]=wasmExports["_PyLong_DivmodNear"];var _PyLong_GetInfo=Module["_PyLong_GetInfo"]=wasmExports["PyLong_GetInfo"];var _PyUnstable_Long_IsCompact=Module["_PyUnstable_Long_IsCompact"]=wasmExports["PyUnstable_Long_IsCompact"];var _PyUnstable_Long_CompactValue=Module["_PyUnstable_Long_CompactValue"]=wasmExports["PyUnstable_Long_CompactValue"];var _PyObject_Bytes=Module["_PyObject_Bytes"]=wasmExports["PyObject_Bytes"];var __PyObject_AssertFailed=Module["__PyObject_AssertFailed"]=wasmExports["_PyObject_AssertFailed"];var _PyObject_IS_GC=Module["_PyObject_IS_GC"]=wasmExports["PyObject_IS_GC"];var __PyDict_NewPresized=Module["__PyDict_NewPresized"]=wasmExports["_PyDict_NewPresized"];var __PyDict_GetItemRef_KnownHash_LockHeld=Module["__PyDict_GetItemRef_KnownHash_LockHeld"]=wasmExports["_PyDict_GetItemRef_KnownHash_LockHeld"];var __PyDict_GetItemStringWithError=Module["__PyDict_GetItemStringWithError"]=wasmExports["_PyDict_GetItemStringWithError"];var __PyDict_LoadGlobal=Module["__PyDict_LoadGlobal"]=wasmExports["_PyDict_LoadGlobal"];var __PyDict_SetItem_Take2=Module["__PyDict_SetItem_Take2"]=wasmExports["_PyDict_SetItem_Take2"];var __PyDict_SetItem_KnownHash_LockHeld=Module["__PyDict_SetItem_KnownHash_LockHeld"]=wasmExports["_PyDict_SetItem_KnownHash_LockHeld"];var __PyDict_SetItem_KnownHash=Module["__PyDict_SetItem_KnownHash"]=wasmExports["_PyDict_SetItem_KnownHash"];var __PyDict_DelItem_KnownHash=Module["__PyDict_DelItem_KnownHash"]=wasmExports["_PyDict_DelItem_KnownHash"];var __PyDict_DelItemIf=Module["__PyDict_DelItemIf"]=wasmExports["_PyDict_DelItemIf"];var _PyDict_Clear=Module["_PyDict_Clear"]=wasmExports["PyDict_Clear"];var _PyDict_PopString=Module["_PyDict_PopString"]=wasmExports["PyDict_PopString"];var __PyDict_Pop=Module["__PyDict_Pop"]=wasmExports["_PyDict_Pop"];var _PyDict_MergeFromSeq2=Module["_PyDict_MergeFromSeq2"]=wasmExports["PyDict_MergeFromSeq2"];var _PyDict_Merge=Module["_PyDict_Merge"]=wasmExports["PyDict_Merge"];var __PyDict_MergeEx=Module["__PyDict_MergeEx"]=wasmExports["_PyDict_MergeEx"];var _PyDict_SetDefaultRef=Module["_PyDict_SetDefaultRef"]=wasmExports["PyDict_SetDefaultRef"];var _PyDict_SetDefault=Module["_PyDict_SetDefault"]=wasmExports["PyDict_SetDefault"];var __PyDict_SizeOf=Module["__PyDict_SizeOf"]=wasmExports["_PyDict_SizeOf"];var _PyDict_ContainsString=Module["_PyDict_ContainsString"]=wasmExports["PyDict_ContainsString"];var _PyDict_GetItemString=Module["_PyDict_GetItemString"]=wasmExports["PyDict_GetItemString"];var _PyDict_GetItemStringRef=Module["_PyDict_GetItemStringRef"]=wasmExports["PyDict_GetItemStringRef"];var _PyDict_DelItemString=Module["_PyDict_DelItemString"]=wasmExports["PyDict_DelItemString"];var _PyObject_VisitManagedDict=Module["_PyObject_VisitManagedDict"]=wasmExports["PyObject_VisitManagedDict"];var __PyObject_SetManagedDict=Module["__PyObject_SetManagedDict"]=wasmExports["_PyObject_SetManagedDict"];var _PyObject_ClearManagedDict=Module["_PyObject_ClearManagedDict"]=wasmExports["PyObject_ClearManagedDict"];var _PyDict_Watch=Module["_PyDict_Watch"]=wasmExports["PyDict_Watch"];var _PyDict_Unwatch=Module["_PyDict_Unwatch"]=wasmExports["PyDict_Unwatch"];var _PyDict_AddWatcher=Module["_PyDict_AddWatcher"]=wasmExports["PyDict_AddWatcher"];var _PyDict_ClearWatcher=Module["_PyDict_ClearWatcher"]=wasmExports["PyDict_ClearWatcher"];var _PyArg_ValidateKeywordArguments=Module["_PyArg_ValidateKeywordArguments"]=wasmExports["PyArg_ValidateKeywordArguments"];var _PyODict_New=Module["_PyODict_New"]=wasmExports["PyODict_New"];var _PyODict_SetItem=Module["_PyODict_SetItem"]=wasmExports["PyODict_SetItem"];var __PyErr_ChainExceptions1=Module["__PyErr_ChainExceptions1"]=wasmExports["_PyErr_ChainExceptions1"];var _PyODict_DelItem=Module["_PyODict_DelItem"]=wasmExports["PyODict_DelItem"];var _PyMemoryView_FromMemory=Module["_PyMemoryView_FromMemory"]=wasmExports["PyMemoryView_FromMemory"];var _PyMemoryView_FromBuffer=Module["_PyMemoryView_FromBuffer"]=wasmExports["PyMemoryView_FromBuffer"];var _PyMemoryView_GetContiguous=Module["_PyMemoryView_GetContiguous"]=wasmExports["PyMemoryView_GetContiguous"];var _PyUnicode_AsASCIIString=Module["_PyUnicode_AsASCIIString"]=wasmExports["PyUnicode_AsASCIIString"];var _PyCFunction_New=Module["_PyCFunction_New"]=wasmExports["PyCFunction_New"];var _PyCFunction_NewEx=Module["_PyCFunction_NewEx"]=wasmExports["PyCFunction_NewEx"];var _PyCFunction_GetFunction=Module["_PyCFunction_GetFunction"]=wasmExports["PyCFunction_GetFunction"];var _PyCFunction_GetSelf=Module["_PyCFunction_GetSelf"]=wasmExports["PyCFunction_GetSelf"];var _PyCFunction_GetFlags=Module["_PyCFunction_GetFlags"]=wasmExports["PyCFunction_GetFlags"];var _PyModuleDef_Init=Module["_PyModuleDef_Init"]=wasmExports["PyModuleDef_Init"];var _PyModule_NewObject=Module["_PyModule_NewObject"]=wasmExports["PyModule_NewObject"];var _PyModule_New=Module["_PyModule_New"]=wasmExports["PyModule_New"];var _PyModule_SetDocString=Module["_PyModule_SetDocString"]=wasmExports["PyModule_SetDocString"];var _PyModule_FromDefAndSpec2=Module["_PyModule_FromDefAndSpec2"]=wasmExports["PyModule_FromDefAndSpec2"];var _PyModule_ExecDef=Module["_PyModule_ExecDef"]=wasmExports["PyModule_ExecDef"];var _PyModule_GetName=Module["_PyModule_GetName"]=wasmExports["PyModule_GetName"];var _PyModule_GetFilenameObject=Module["_PyModule_GetFilenameObject"]=wasmExports["PyModule_GetFilenameObject"];var _PyModule_GetFilename=Module["_PyModule_GetFilename"]=wasmExports["PyModule_GetFilename"];var _PyModule_GetDef=Module["_PyModule_GetDef"]=wasmExports["PyModule_GetDef"];var _PyModule_GetState=Module["_PyModule_GetState"]=wasmExports["PyModule_GetState"];var _PyUnicode_AsWideChar=Module["_PyUnicode_AsWideChar"]=wasmExports["PyUnicode_AsWideChar"];var _wcsrchr=Module["_wcsrchr"]=wasmExports["wcsrchr"];var _wcscmp=Module["_wcscmp"]=wasmExports["wcscmp"];var _PySys_FormatStderr=Module["_PySys_FormatStderr"]=wasmExports["PySys_FormatStderr"];var _PyUnicode_Join=Module["_PyUnicode_Join"]=wasmExports["PyUnicode_Join"];var __PyNamespace_New=Module["__PyNamespace_New"]=wasmExports["_PyNamespace_New"];var __PyArg_NoPositional=Module["__PyArg_NoPositional"]=wasmExports["_PyArg_NoPositional"];var __PyUnicode_CheckConsistency=Module["__PyUnicode_CheckConsistency"]=wasmExports["_PyUnicode_CheckConsistency"];var __PyObject_IsFreed=Module["__PyObject_IsFreed"]=wasmExports["_PyObject_IsFreed"];var _fwrite=Module["_fwrite"]=wasmExports["fwrite"];var _fputc=Module["_fputc"]=wasmExports["fputc"];var __PyObject_Dump=Module["__PyObject_Dump"]=wasmExports["_PyObject_Dump"];var _Py_IncRef=Module["_Py_IncRef"]=wasmExports["Py_IncRef"];var _Py_DecRef=Module["_Py_DecRef"]=wasmExports["Py_DecRef"];var __Py_IncRef=Module["__Py_IncRef"]=wasmExports["_Py_IncRef"];var __Py_DecRef=Module["__Py_DecRef"]=wasmExports["_Py_DecRef"];var _PyObject_Init=Module["_PyObject_Init"]=wasmExports["PyObject_Init"];var _PyObject_InitVar=Module["_PyObject_InitVar"]=wasmExports["PyObject_InitVar"];var _PyObject_CallFinalizer=Module["_PyObject_CallFinalizer"]=wasmExports["PyObject_CallFinalizer"];var __Py_ResurrectReference=Module["__Py_ResurrectReference"]=wasmExports["_Py_ResurrectReference"];var _PyObject_Print=Module["_PyObject_Print"]=wasmExports["PyObject_Print"];var _ferror=Module["_ferror"]=wasmExports["ferror"];var __Py_BreakPoint=Module["__Py_BreakPoint"]=wasmExports["_Py_BreakPoint"];var _PyGILState_Ensure=Module["_PyGILState_Ensure"]=wasmExports["PyGILState_Ensure"];var _PyGILState_Release=Module["_PyGILState_Release"]=wasmExports["PyGILState_Release"];var _PyUnicode_DecodeASCII=Module["_PyUnicode_DecodeASCII"]=wasmExports["PyUnicode_DecodeASCII"];var _PyObject_HasAttrStringWithError=Module["_PyObject_HasAttrStringWithError"]=wasmExports["PyObject_HasAttrStringWithError"];var _PyObject_GetOptionalAttrString=Module["_PyObject_GetOptionalAttrString"]=wasmExports["PyObject_GetOptionalAttrString"];var _PyObject_HasAttrString=Module["_PyObject_HasAttrString"]=wasmExports["PyObject_HasAttrString"];var _PyObject_DelAttrString=Module["_PyObject_DelAttrString"]=wasmExports["PyObject_DelAttrString"];var __PyObject_GetDictPtr=Module["__PyObject_GetDictPtr"]=wasmExports["_PyObject_GetDictPtr"];var __PyObject_GenericSetAttrWithDict=Module["__PyObject_GenericSetAttrWithDict"]=wasmExports["_PyObject_GenericSetAttrWithDict"];var _PyObject_Not=Module["_PyObject_Not"]=wasmExports["PyObject_Not"];var _PyThreadState_GetDict=Module["_PyThreadState_GetDict"]=wasmExports["PyThreadState_GetDict"];var _PyObject_GET_WEAKREFS_LISTPTR=Module["_PyObject_GET_WEAKREFS_LISTPTR"]=wasmExports["PyObject_GET_WEAKREFS_LISTPTR"];var _Py_NewRef=Module["_Py_NewRef"]=wasmExports["Py_NewRef"];var _Py_XNewRef=Module["_Py_XNewRef"]=wasmExports["Py_XNewRef"];var _Py_Is=Module["_Py_Is"]=wasmExports["Py_Is"];var _Py_IsNone=Module["_Py_IsNone"]=wasmExports["Py_IsNone"];var _Py_IsTrue=Module["_Py_IsTrue"]=wasmExports["Py_IsTrue"];var _Py_IsFalse=Module["_Py_IsFalse"]=wasmExports["Py_IsFalse"];var __Py_SetRefcnt=Module["__Py_SetRefcnt"]=wasmExports["_Py_SetRefcnt"];var _PyRefTracer_SetTracer=Module["_PyRefTracer_SetTracer"]=wasmExports["PyRefTracer_SetTracer"];var _PyRefTracer_GetTracer=Module["_PyRefTracer_GetTracer"]=wasmExports["PyRefTracer_GetTracer"];var _Py_GetConstant=Module["_Py_GetConstant"]=wasmExports["Py_GetConstant"];var _Py_GetConstantBorrowed=Module["_Py_GetConstantBorrowed"]=wasmExports["Py_GetConstantBorrowed"];var _sleep=Module["_sleep"]=wasmExports["sleep"];var _abort=Module["_abort"]=wasmExports["abort"];var _getenv=Module["_getenv"]=wasmExports["getenv"];var _sbrk=Module["_sbrk"]=wasmExports["sbrk"];var _clock_gettime=Module["_clock_gettime"]=wasmExports["clock_gettime"];var _vsnprintf=Module["_vsnprintf"]=wasmExports["vsnprintf"];var _atexit=Module["_atexit"]=wasmExports["atexit"];var _strstr=Module["_strstr"]=wasmExports["strstr"];var _snprintf=Module["_snprintf"]=wasmExports["snprintf"];var _calloc=wasmExports["calloc"];var _realloc=wasmExports["realloc"];var __PyMem_GetCurrentAllocatorName=Module["__PyMem_GetCurrentAllocatorName"]=wasmExports["_PyMem_GetCurrentAllocatorName"];var _PyMem_SetupDebugHooks=Module["_PyMem_SetupDebugHooks"]=wasmExports["PyMem_SetupDebugHooks"];var _PyMem_GetAllocator=Module["_PyMem_GetAllocator"]=wasmExports["PyMem_GetAllocator"];var _PyMem_SetAllocator=Module["_PyMem_SetAllocator"]=wasmExports["PyMem_SetAllocator"];var _PyObject_GetArenaAllocator=Module["_PyObject_GetArenaAllocator"]=wasmExports["PyObject_GetArenaAllocator"];var _PyObject_SetArenaAllocator=Module["_PyObject_SetArenaAllocator"]=wasmExports["PyObject_SetArenaAllocator"];var _PyMem_RawMalloc=Module["_PyMem_RawMalloc"]=wasmExports["PyMem_RawMalloc"];var _PyMem_RawCalloc=Module["_PyMem_RawCalloc"]=wasmExports["PyMem_RawCalloc"];var _wcslen=Module["_wcslen"]=wasmExports["wcslen"];var __PyMem_Strdup=Module["__PyMem_Strdup"]=wasmExports["_PyMem_Strdup"];var _PyPickleBuffer_FromObject=Module["_PyPickleBuffer_FromObject"]=wasmExports["PyPickleBuffer_FromObject"];var _PyPickleBuffer_GetBuffer=Module["_PyPickleBuffer_GetBuffer"]=wasmExports["PyPickleBuffer_GetBuffer"];var _PyPickleBuffer_Release=Module["_PyPickleBuffer_Release"]=wasmExports["PyPickleBuffer_Release"];var __PySlice_GetLongIndices=Module["__PySlice_GetLongIndices"]=wasmExports["_PySlice_GetLongIndices"];var __PySet_Contains=Module["__PySet_Contains"]=wasmExports["_PySet_Contains"];var _PySet_Size=Module["_PySet_Size"]=wasmExports["PySet_Size"];var _PySet_Clear=Module["_PySet_Clear"]=wasmExports["PySet_Clear"];var _PySet_Pop=Module["_PySet_Pop"]=wasmExports["PySet_Pop"];var _PySlice_New=Module["_PySlice_New"]=wasmExports["PySlice_New"];var _PySlice_GetIndices=Module["_PySlice_GetIndices"]=wasmExports["PySlice_GetIndices"];var _PySlice_GetIndicesEx=Module["_PySlice_GetIndicesEx"]=wasmExports["PySlice_GetIndicesEx"];var _PyStructSequence_GetItem=Module["_PyStructSequence_GetItem"]=wasmExports["PyStructSequence_GetItem"];var _PyStructSequence_InitType2=Module["_PyStructSequence_InitType2"]=wasmExports["PyStructSequence_InitType2"];var _PyStructSequence_InitType=Module["_PyStructSequence_InitType"]=wasmExports["PyStructSequence_InitType"];var __PyStructSequence_NewType=Module["__PyStructSequence_NewType"]=wasmExports["_PyStructSequence_NewType"];var _PyStructSequence_NewType=Module["_PyStructSequence_NewType"]=wasmExports["PyStructSequence_NewType"];var _PyTuple_SetItem=Module["_PyTuple_SetItem"]=wasmExports["PyTuple_SetItem"];var __PyTuple_FromArraySteal=Module["__PyTuple_FromArraySteal"]=wasmExports["_PyTuple_FromArraySteal"];var __PyObject_GC_Resize=Module["__PyObject_GC_Resize"]=wasmExports["_PyObject_GC_Resize"];var _PyType_GetDict=Module["_PyType_GetDict"]=wasmExports["PyType_GetDict"];var _strrchr=Module["_strrchr"]=wasmExports["strrchr"];var _PyType_ClearCache=Module["_PyType_ClearCache"]=wasmExports["PyType_ClearCache"];var _PyType_AddWatcher=Module["_PyType_AddWatcher"]=wasmExports["PyType_AddWatcher"];var _PyType_ClearWatcher=Module["_PyType_ClearWatcher"]=wasmExports["PyType_ClearWatcher"];var _PyType_Watch=Module["_PyType_Watch"]=wasmExports["PyType_Watch"];var _PyType_Unwatch=Module["_PyType_Unwatch"]=wasmExports["PyType_Unwatch"];var _PyType_Modified=Module["_PyType_Modified"]=wasmExports["PyType_Modified"];var _PyUnstable_Type_AssignVersionTag=Module["_PyUnstable_Type_AssignVersionTag"]=wasmExports["PyUnstable_Type_AssignVersionTag"];var _PyType_GetFullyQualifiedName=Module["_PyType_GetFullyQualifiedName"]=wasmExports["PyType_GetFullyQualifiedName"];var _PyType_GetFlags=Module["_PyType_GetFlags"]=wasmExports["PyType_GetFlags"];var _PyType_SUPPORTS_WEAKREFS=Module["_PyType_SUPPORTS_WEAKREFS"]=wasmExports["PyType_SUPPORTS_WEAKREFS"];var _PyType_FromMetaclass=Module["_PyType_FromMetaclass"]=wasmExports["PyType_FromMetaclass"];var _PyType_FromModuleAndSpec=Module["_PyType_FromModuleAndSpec"]=wasmExports["PyType_FromModuleAndSpec"];var _PyType_FromSpec=Module["_PyType_FromSpec"]=wasmExports["PyType_FromSpec"];var _PyType_GetName=Module["_PyType_GetName"]=wasmExports["PyType_GetName"];var _PyType_GetModuleName=Module["_PyType_GetModuleName"]=wasmExports["PyType_GetModuleName"];var _PyType_GetSlot=Module["_PyType_GetSlot"]=wasmExports["PyType_GetSlot"];var _PyType_GetModule=Module["_PyType_GetModule"]=wasmExports["PyType_GetModule"];var _PyType_GetModuleState=Module["_PyType_GetModuleState"]=wasmExports["PyType_GetModuleState"];var _PyType_GetModuleByDef=Module["_PyType_GetModuleByDef"]=wasmExports["PyType_GetModuleByDef"];var __PyType_GetModuleByDef2=Module["__PyType_GetModuleByDef2"]=wasmExports["_PyType_GetModuleByDef2"];var _PyObject_GetTypeData=Module["_PyObject_GetTypeData"]=wasmExports["PyObject_GetTypeData"];var _PyType_GetTypeDataSize=Module["_PyType_GetTypeDataSize"]=wasmExports["PyType_GetTypeDataSize"];var _PyObject_GetItemData=Module["_PyObject_GetItemData"]=wasmExports["PyObject_GetItemData"];var __PyType_Lookup=Module["__PyType_Lookup"]=wasmExports["_PyType_Lookup"];var _PyUnicode_IsIdentifier=Module["_PyUnicode_IsIdentifier"]=wasmExports["PyUnicode_IsIdentifier"];var _PyEval_GetGlobals=Module["_PyEval_GetGlobals"]=wasmExports["PyEval_GetGlobals"];var __PyStaticType_InitForExtension=Module["__PyStaticType_InitForExtension"]=wasmExports["_PyStaticType_InitForExtension"];var __PySuper_Lookup=Module["__PySuper_Lookup"]=wasmExports["_PySuper_Lookup"];var _PyWeakref_NewRef=Module["_PyWeakref_NewRef"]=wasmExports["PyWeakref_NewRef"];var _PyImport_GetModule=Module["_PyImport_GetModule"]=wasmExports["PyImport_GetModule"];var _PyImport_Import=Module["_PyImport_Import"]=wasmExports["PyImport_Import"];var __PyArg_UnpackKeywordsWithVararg=Module["__PyArg_UnpackKeywordsWithVararg"]=wasmExports["_PyArg_UnpackKeywordsWithVararg"];var __Py_hashtable_len=Module["__Py_hashtable_len"]=wasmExports["_Py_hashtable_len"];var __Py_GetErrorHandler=Module["__Py_GetErrorHandler"]=wasmExports["_Py_GetErrorHandler"];var _PyUnicode_CopyCharacters=Module["_PyUnicode_CopyCharacters"]=wasmExports["PyUnicode_CopyCharacters"];var _PyUnicode_Resize=Module["_PyUnicode_Resize"]=wasmExports["PyUnicode_Resize"];var _PyUnicode_FromWideChar=Module["_PyUnicode_FromWideChar"]=wasmExports["PyUnicode_FromWideChar"];var _PyUnicode_FromKindAndData=Module["_PyUnicode_FromKindAndData"]=wasmExports["PyUnicode_FromKindAndData"];var _PyUnicode_AsUCS4=Module["_PyUnicode_AsUCS4"]=wasmExports["PyUnicode_AsUCS4"];var _PyUnicode_AsUCS4Copy=Module["_PyUnicode_AsUCS4Copy"]=wasmExports["PyUnicode_AsUCS4Copy"];var _PyUnicode_Fill=Module["_PyUnicode_Fill"]=wasmExports["PyUnicode_Fill"];var _PyUnicode_AsWideCharString=Module["_PyUnicode_AsWideCharString"]=wasmExports["PyUnicode_AsWideCharString"];var _PyUnicode_FromOrdinal=Module["_PyUnicode_FromOrdinal"]=wasmExports["PyUnicode_FromOrdinal"];var _PyUnicode_FromObject=Module["_PyUnicode_FromObject"]=wasmExports["PyUnicode_FromObject"];var _PyCodec_LookupError=Module["_PyCodec_LookupError"]=wasmExports["PyCodec_LookupError"];var _PyUnicode_DecodeUTF16Stateful=Module["_PyUnicode_DecodeUTF16Stateful"]=wasmExports["PyUnicode_DecodeUTF16Stateful"];var _PyUnicode_DecodeUTF32Stateful=Module["_PyUnicode_DecodeUTF32Stateful"]=wasmExports["PyUnicode_DecodeUTF32Stateful"];var _PyUnicode_DecodeUTF16=Module["_PyUnicode_DecodeUTF16"]=wasmExports["PyUnicode_DecodeUTF16"];var _PyUnicode_DecodeUTF32=Module["_PyUnicode_DecodeUTF32"]=wasmExports["PyUnicode_DecodeUTF32"];var _PyUnicode_AsDecodedObject=Module["_PyUnicode_AsDecodedObject"]=wasmExports["PyUnicode_AsDecodedObject"];var _PyCodec_Decode=Module["_PyCodec_Decode"]=wasmExports["PyCodec_Decode"];var _PyUnicode_AsDecodedUnicode=Module["_PyUnicode_AsDecodedUnicode"]=wasmExports["PyUnicode_AsDecodedUnicode"];var _PyUnicode_AsEncodedObject=Module["_PyUnicode_AsEncodedObject"]=wasmExports["PyUnicode_AsEncodedObject"];var _PyCodec_Encode=Module["_PyCodec_Encode"]=wasmExports["PyCodec_Encode"];var _PyUnicode_EncodeLocale=Module["_PyUnicode_EncodeLocale"]=wasmExports["PyUnicode_EncodeLocale"];var __Py_EncodeLocaleEx=Module["__Py_EncodeLocaleEx"]=wasmExports["_Py_EncodeLocaleEx"];var _PyCodec_StrictErrors=Module["_PyCodec_StrictErrors"]=wasmExports["PyCodec_StrictErrors"];var _PyUnicode_EncodeFSDefault=Module["_PyUnicode_EncodeFSDefault"]=wasmExports["PyUnicode_EncodeFSDefault"];var __PyUnicode_EncodeUTF16=Module["__PyUnicode_EncodeUTF16"]=wasmExports["_PyUnicode_EncodeUTF16"];var __PyUnicode_EncodeUTF32=Module["__PyUnicode_EncodeUTF32"]=wasmExports["_PyUnicode_EncodeUTF32"];var _PyUnicode_AsEncodedUnicode=Module["_PyUnicode_AsEncodedUnicode"]=wasmExports["PyUnicode_AsEncodedUnicode"];var _PyUnicode_DecodeLocaleAndSize=Module["_PyUnicode_DecodeLocaleAndSize"]=wasmExports["PyUnicode_DecodeLocaleAndSize"];var __Py_DecodeLocaleEx=Module["__Py_DecodeLocaleEx"]=wasmExports["_Py_DecodeLocaleEx"];var _PyUnicode_DecodeLocale=Module["_PyUnicode_DecodeLocale"]=wasmExports["PyUnicode_DecodeLocale"];var _PyUnicode_DecodeFSDefaultAndSize=Module["_PyUnicode_DecodeFSDefaultAndSize"]=wasmExports["PyUnicode_DecodeFSDefaultAndSize"];var _PyUnicode_FSConverter=Module["_PyUnicode_FSConverter"]=wasmExports["PyUnicode_FSConverter"];var _PyOS_FSPath=Module["_PyOS_FSPath"]=wasmExports["PyOS_FSPath"];var _PyUnicode_FSDecoder=Module["_PyUnicode_FSDecoder"]=wasmExports["PyUnicode_FSDecoder"];var _wmemchr=Module["_wmemchr"]=wasmExports["wmemchr"];var __PyUnicode_AsUTF8NoNUL=Module["__PyUnicode_AsUTF8NoNUL"]=wasmExports["_PyUnicode_AsUTF8NoNUL"];var _PyUnicode_GetSize=Module["_PyUnicode_GetSize"]=wasmExports["PyUnicode_GetSize"];var _PyUnicode_GetLength=Module["_PyUnicode_GetLength"]=wasmExports["PyUnicode_GetLength"];var _PyUnicode_WriteChar=Module["_PyUnicode_WriteChar"]=wasmExports["PyUnicode_WriteChar"];var _PyUnicode_DecodeUTF7=Module["_PyUnicode_DecodeUTF7"]=wasmExports["PyUnicode_DecodeUTF7"];var _PyUnicode_DecodeUTF7Stateful=Module["_PyUnicode_DecodeUTF7Stateful"]=wasmExports["PyUnicode_DecodeUTF7Stateful"];var _PyUnicode_AsUTF32String=Module["_PyUnicode_AsUTF32String"]=wasmExports["PyUnicode_AsUTF32String"];var _PyUnicode_AsUTF16String=Module["_PyUnicode_AsUTF16String"]=wasmExports["PyUnicode_AsUTF16String"];var _PyUnicode_DecodeUnicodeEscape=Module["_PyUnicode_DecodeUnicodeEscape"]=wasmExports["PyUnicode_DecodeUnicodeEscape"];var _PyUnicode_AsUnicodeEscapeString=Module["_PyUnicode_AsUnicodeEscapeString"]=wasmExports["PyUnicode_AsUnicodeEscapeString"];var _PyUnicode_DecodeRawUnicodeEscape=Module["_PyUnicode_DecodeRawUnicodeEscape"]=wasmExports["PyUnicode_DecodeRawUnicodeEscape"];var _PyUnicode_AsRawUnicodeEscapeString=Module["_PyUnicode_AsRawUnicodeEscapeString"]=wasmExports["PyUnicode_AsRawUnicodeEscapeString"];var _PyUnicode_AsLatin1String=Module["_PyUnicode_AsLatin1String"]=wasmExports["PyUnicode_AsLatin1String"];var __PyUnicodeWriter_PrepareKindInternal=Module["__PyUnicodeWriter_PrepareKindInternal"]=wasmExports["_PyUnicodeWriter_PrepareKindInternal"];var _PyUnicode_DecodeCharmap=Module["_PyUnicode_DecodeCharmap"]=wasmExports["PyUnicode_DecodeCharmap"];var _PyUnicode_BuildEncodingMap=Module["_PyUnicode_BuildEncodingMap"]=wasmExports["PyUnicode_BuildEncodingMap"];var _PyUnicode_AsCharmapString=Module["_PyUnicode_AsCharmapString"]=wasmExports["PyUnicode_AsCharmapString"];var _PyUnicode_Translate=Module["_PyUnicode_Translate"]=wasmExports["PyUnicode_Translate"];var __PyUnicode_IsWhitespace=Module["__PyUnicode_IsWhitespace"]=wasmExports["_PyUnicode_IsWhitespace"];var __PyUnicode_ToDecimalDigit=Module["__PyUnicode_ToDecimalDigit"]=wasmExports["_PyUnicode_ToDecimalDigit"];var _PyUnicode_Count=Module["_PyUnicode_Count"]=wasmExports["PyUnicode_Count"];var _PyUnicode_Find=Module["_PyUnicode_Find"]=wasmExports["PyUnicode_Find"];var _PyUnicode_FindChar=Module["_PyUnicode_FindChar"]=wasmExports["PyUnicode_FindChar"];var _PyUnicode_Tailmatch=Module["_PyUnicode_Tailmatch"]=wasmExports["PyUnicode_Tailmatch"];var __PyUnicode_JoinArray=Module["__PyUnicode_JoinArray"]=wasmExports["_PyUnicode_JoinArray"];var _PyUnicode_Splitlines=Module["_PyUnicode_Splitlines"]=wasmExports["PyUnicode_Splitlines"];var __PyUnicode_IsLinebreak=Module["__PyUnicode_IsLinebreak"]=wasmExports["_PyUnicode_IsLinebreak"];var _wmemcmp=Module["_wmemcmp"]=wasmExports["wmemcmp"];var _PyUnicode_EqualToUTF8=Module["_PyUnicode_EqualToUTF8"]=wasmExports["PyUnicode_EqualToUTF8"];var _PyUnicode_EqualToUTF8AndSize=Module["_PyUnicode_EqualToUTF8AndSize"]=wasmExports["PyUnicode_EqualToUTF8AndSize"];var _PyUnicode_RichCompare=Module["_PyUnicode_RichCompare"]=wasmExports["PyUnicode_RichCompare"];var _PyUnicode_Contains=Module["_PyUnicode_Contains"]=wasmExports["PyUnicode_Contains"];var _PyUnicode_Concat=Module["_PyUnicode_Concat"]=wasmExports["PyUnicode_Concat"];var _PyUnicode_Append=Module["_PyUnicode_Append"]=wasmExports["PyUnicode_Append"];var _PyUnicode_AppendAndDel=Module["_PyUnicode_AppendAndDel"]=wasmExports["PyUnicode_AppendAndDel"];var _PyUnicode_Replace=Module["_PyUnicode_Replace"]=wasmExports["PyUnicode_Replace"];var _PyUnicode_Split=Module["_PyUnicode_Split"]=wasmExports["PyUnicode_Split"];var _PyUnicode_Partition=Module["_PyUnicode_Partition"]=wasmExports["PyUnicode_Partition"];var _PyUnicode_RPartition=Module["_PyUnicode_RPartition"]=wasmExports["PyUnicode_RPartition"];var _PyUnicode_RSplit=Module["_PyUnicode_RSplit"]=wasmExports["PyUnicode_RSplit"];var __PyUnicodeWriter_WriteSubstring=Module["__PyUnicodeWriter_WriteSubstring"]=wasmExports["_PyUnicodeWriter_WriteSubstring"];var __PyUnicodeWriter_WriteLatin1String=Module["__PyUnicodeWriter_WriteLatin1String"]=wasmExports["_PyUnicodeWriter_WriteLatin1String"];var _PyUnicode_Format=Module["_PyUnicode_Format"]=wasmExports["PyUnicode_Format"];var __PyUnicode_ExactDealloc=Module["__PyUnicode_ExactDealloc"]=wasmExports["_PyUnicode_ExactDealloc"];var __Py_hashtable_new_full=Module["__Py_hashtable_new_full"]=wasmExports["_Py_hashtable_new_full"];var __Py_hashtable_get=Module["__Py_hashtable_get"]=wasmExports["_Py_hashtable_get"];var __Py_hashtable_set=Module["__Py_hashtable_set"]=wasmExports["_Py_hashtable_set"];var __PyUnicode_InternInPlace=Module["__PyUnicode_InternInPlace"]=wasmExports["_PyUnicode_InternInPlace"];var _PyUnicode_InternInPlace=Module["_PyUnicode_InternInPlace"]=wasmExports["PyUnicode_InternInPlace"];var _PyUnicode_InternImmortal=Module["_PyUnicode_InternImmortal"]=wasmExports["PyUnicode_InternImmortal"];var __Py_hashtable_destroy=Module["__Py_hashtable_destroy"]=wasmExports["_Py_hashtable_destroy"];var _PyInit__string=Module["_PyInit__string"]=wasmExports["PyInit__string"];var __PyUnicode_IsLowercase=Module["__PyUnicode_IsLowercase"]=wasmExports["_PyUnicode_IsLowercase"];var __PyUnicode_IsUppercase=Module["__PyUnicode_IsUppercase"]=wasmExports["_PyUnicode_IsUppercase"];var __PyUnicode_IsTitlecase=Module["__PyUnicode_IsTitlecase"]=wasmExports["_PyUnicode_IsTitlecase"];var __PyUnicode_IsDecimalDigit=Module["__PyUnicode_IsDecimalDigit"]=wasmExports["_PyUnicode_IsDecimalDigit"];var __PyUnicode_IsDigit=Module["__PyUnicode_IsDigit"]=wasmExports["_PyUnicode_IsDigit"];var __PyUnicode_IsNumeric=Module["__PyUnicode_IsNumeric"]=wasmExports["_PyUnicode_IsNumeric"];var __PyUnicode_IsAlpha=Module["__PyUnicode_IsAlpha"]=wasmExports["_PyUnicode_IsAlpha"];var __PyUnicode_ToNumeric=Module["__PyUnicode_ToNumeric"]=wasmExports["_PyUnicode_ToNumeric"];var __PyUnicode_ToTitlecase=Module["__PyUnicode_ToTitlecase"]=wasmExports["_PyUnicode_ToTitlecase"];var __PyUnicode_ToDigit=Module["__PyUnicode_ToDigit"]=wasmExports["_PyUnicode_ToDigit"];var __PyUnicode_ToUppercase=Module["__PyUnicode_ToUppercase"]=wasmExports["_PyUnicode_ToUppercase"];var __PyUnicode_ToLowercase=Module["__PyUnicode_ToLowercase"]=wasmExports["_PyUnicode_ToLowercase"];var __PyWeakref_ClearRef=Module["__PyWeakref_ClearRef"]=wasmExports["_PyWeakref_ClearRef"];var _PyWeakref_NewProxy=Module["_PyWeakref_NewProxy"]=wasmExports["PyWeakref_NewProxy"];var _PyWeakref_GetRef=Module["_PyWeakref_GetRef"]=wasmExports["PyWeakref_GetRef"];var _PyWeakref_GetObject=Module["_PyWeakref_GetObject"]=wasmExports["PyWeakref_GetObject"];var _PyUnstable_Object_ClearWeakRefsNoCallbacks=Module["_PyUnstable_Object_ClearWeakRefsNoCallbacks"]=wasmExports["PyUnstable_Object_ClearWeakRefsNoCallbacks"];var __PyWeakref_IsDead=Module["__PyWeakref_IsDead"]=wasmExports["_PyWeakref_IsDead"];var _PyErr_ResourceWarning=Module["_PyErr_ResourceWarning"]=wasmExports["PyErr_ResourceWarning"];var _PyErr_WarnExplicit=Module["_PyErr_WarnExplicit"]=wasmExports["PyErr_WarnExplicit"];var _PyErr_WarnExplicitFormat=Module["_PyErr_WarnExplicitFormat"]=wasmExports["PyErr_WarnExplicitFormat"];var __Py_IsInterpreterFinalizing=Module["__Py_IsInterpreterFinalizing"]=wasmExports["_Py_IsInterpreterFinalizing"];var __PyWarnings_Init=Module["__PyWarnings_Init"]=wasmExports["_PyWarnings_Init"];var _PyThreadState_GetFrame=Module["_PyThreadState_GetFrame"]=wasmExports["PyThreadState_GetFrame"];var __PySys_GetAttr=Module["__PySys_GetAttr"]=wasmExports["_PySys_GetAttr"];var __Py_DisplaySourceLine=Module["__Py_DisplaySourceLine"]=wasmExports["_Py_DisplaySourceLine"];var _PyModule_AddObjectRef=Module["_PyModule_AddObjectRef"]=wasmExports["PyModule_AddObjectRef"];var _PyInit__ast=Module["_PyInit__ast"]=wasmExports["PyInit__ast"];var __PyOnceFlag_CallOnceSlow=Module["__PyOnceFlag_CallOnceSlow"]=wasmExports["_PyOnceFlag_CallOnceSlow"];var _PyModule_AddIntConstant=Module["_PyModule_AddIntConstant"]=wasmExports["PyModule_AddIntConstant"];var _PyInit__tokenize=Module["_PyInit__tokenize"]=wasmExports["PyInit__tokenize"];var _PyModule_AddType=Module["_PyModule_AddType"]=wasmExports["PyModule_AddType"];var _PyErr_SyntaxLocationObject=Module["_PyErr_SyntaxLocationObject"]=wasmExports["PyErr_SyntaxLocationObject"];var _PyImport_ImportModuleLevelObject=Module["_PyImport_ImportModuleLevelObject"]=wasmExports["PyImport_ImportModuleLevelObject"];var _PyEval_MergeCompilerFlags=Module["_PyEval_MergeCompilerFlags"]=wasmExports["PyEval_MergeCompilerFlags"];var __PyArena_New=Module["__PyArena_New"]=wasmExports["_PyArena_New"];var __PyArena_Free=Module["__PyArena_Free"]=wasmExports["_PyArena_Free"];var __PyAST_Compile=Module["__PyAST_Compile"]=wasmExports["_PyAST_Compile"];var _Py_CompileStringObject=Module["_Py_CompileStringObject"]=wasmExports["Py_CompileStringObject"];var _PyEval_GetBuiltins=Module["_PyEval_GetBuiltins"]=wasmExports["PyEval_GetBuiltins"];var _PyEval_EvalCode=Module["_PyEval_EvalCode"]=wasmExports["PyEval_EvalCode"];var _PyRun_StringFlags=Module["_PyRun_StringFlags"]=wasmExports["PyRun_StringFlags"];var _PyEval_EvalCodeEx=Module["_PyEval_EvalCodeEx"]=wasmExports["PyEval_EvalCodeEx"];var _Py_GetRecursionLimit=Module["_Py_GetRecursionLimit"]=wasmExports["Py_GetRecursionLimit"];var _Py_SetRecursionLimit=Module["_Py_SetRecursionLimit"]=wasmExports["Py_SetRecursionLimit"];var __PyEval_MatchKeys=Module["__PyEval_MatchKeys"]=wasmExports["_PyEval_MatchKeys"];var __PyEval_MatchClass=Module["__PyEval_MatchClass"]=wasmExports["_PyEval_MatchClass"];var __PyEvalFramePushAndInit=Module["__PyEvalFramePushAndInit"]=wasmExports["_PyEvalFramePushAndInit"];var _PyEval_EvalFrame=Module["_PyEval_EvalFrame"]=wasmExports["PyEval_EvalFrame"];var _PyEval_EvalFrameEx=Module["_PyEval_EvalFrameEx"]=wasmExports["PyEval_EvalFrameEx"];var __PyEval_FrameClearAndPop=Module["__PyEval_FrameClearAndPop"]=wasmExports["_PyEval_FrameClearAndPop"];var _PyTraceBack_Here=Module["_PyTraceBack_Here"]=wasmExports["PyTraceBack_Here"];var __Py_HandlePending=Module["__Py_HandlePending"]=wasmExports["_Py_HandlePending"];var __PyEval_CheckExceptStarTypeValid=Module["__PyEval_CheckExceptStarTypeValid"]=wasmExports["_PyEval_CheckExceptStarTypeValid"];var __PyEval_ExceptionGroupMatch=Module["__PyEval_ExceptionGroupMatch"]=wasmExports["_PyEval_ExceptionGroupMatch"];var _PyErr_SetHandledException=Module["_PyErr_SetHandledException"]=wasmExports["PyErr_SetHandledException"];var __PyEval_FormatExcCheckArg=Module["__PyEval_FormatExcCheckArg"]=wasmExports["_PyEval_FormatExcCheckArg"];var __PyEval_FormatKwargsError=Module["__PyEval_FormatKwargsError"]=wasmExports["_PyEval_FormatKwargsError"];var __PyEval_FormatExcUnbound=Module["__PyEval_FormatExcUnbound"]=wasmExports["_PyEval_FormatExcUnbound"];var __PyThreadState_PopFrame=Module["__PyThreadState_PopFrame"]=wasmExports["_PyThreadState_PopFrame"];var __PyEval_UnpackIterable=Module["__PyEval_UnpackIterable"]=wasmExports["_PyEval_UnpackIterable"];var __PyEval_CheckExceptTypeValid=Module["__PyEval_CheckExceptTypeValid"]=wasmExports["_PyEval_CheckExceptTypeValid"];var __PyEval_MonitorRaise=Module["__PyEval_MonitorRaise"]=wasmExports["_PyEval_MonitorRaise"];var __PyEval_FormatAwaitableError=Module["__PyEval_FormatAwaitableError"]=wasmExports["_PyEval_FormatAwaitableError"];var _PyThreadState_EnterTracing=Module["_PyThreadState_EnterTracing"]=wasmExports["PyThreadState_EnterTracing"];var _PyThreadState_LeaveTracing=Module["_PyThreadState_LeaveTracing"]=wasmExports["PyThreadState_LeaveTracing"];var _PyEval_SetProfile=Module["_PyEval_SetProfile"]=wasmExports["PyEval_SetProfile"];var __PyEval_SetProfile=Module["__PyEval_SetProfile"]=wasmExports["_PyEval_SetProfile"];var _PyEval_SetProfileAllThreads=Module["_PyEval_SetProfileAllThreads"]=wasmExports["PyEval_SetProfileAllThreads"];var _PyInterpreterState_ThreadHead=Module["_PyInterpreterState_ThreadHead"]=wasmExports["PyInterpreterState_ThreadHead"];var _PyThreadState_Next=Module["_PyThreadState_Next"]=wasmExports["PyThreadState_Next"];var _PyEval_SetTrace=Module["_PyEval_SetTrace"]=wasmExports["PyEval_SetTrace"];var _PyEval_SetTraceAllThreads=Module["_PyEval_SetTraceAllThreads"]=wasmExports["PyEval_SetTraceAllThreads"];var _PyEval_GetFrame=Module["_PyEval_GetFrame"]=wasmExports["PyEval_GetFrame"];var _PyEval_GetLocals=Module["_PyEval_GetLocals"]=wasmExports["PyEval_GetLocals"];var _PyEval_GetFrameLocals=Module["_PyEval_GetFrameLocals"]=wasmExports["PyEval_GetFrameLocals"];var _PyEval_GetFrameGlobals=Module["_PyEval_GetFrameGlobals"]=wasmExports["PyEval_GetFrameGlobals"];var _PyEval_GetFrameBuiltins=Module["_PyEval_GetFrameBuiltins"]=wasmExports["PyEval_GetFrameBuiltins"];var _PyEval_GetFuncName=Module["_PyEval_GetFuncName"]=wasmExports["PyEval_GetFuncName"];var _PyEval_GetFuncDesc=Module["_PyEval_GetFuncDesc"]=wasmExports["PyEval_GetFuncDesc"];var _PyUnstable_Eval_RequestCodeExtraIndex=Module["_PyUnstable_Eval_RequestCodeExtraIndex"]=wasmExports["PyUnstable_Eval_RequestCodeExtraIndex"];var _PyCodec_Register=Module["_PyCodec_Register"]=wasmExports["PyCodec_Register"];var _PyCodec_Unregister=Module["_PyCodec_Unregister"]=wasmExports["PyCodec_Unregister"];var _PyCodec_KnownEncoding=Module["_PyCodec_KnownEncoding"]=wasmExports["PyCodec_KnownEncoding"];var _PyCodec_Encoder=Module["_PyCodec_Encoder"]=wasmExports["PyCodec_Encoder"];var _PyCodec_Decoder=Module["_PyCodec_Decoder"]=wasmExports["PyCodec_Decoder"];var _PyCodec_IncrementalEncoder=Module["_PyCodec_IncrementalEncoder"]=wasmExports["PyCodec_IncrementalEncoder"];var _PyCodec_IncrementalDecoder=Module["_PyCodec_IncrementalDecoder"]=wasmExports["PyCodec_IncrementalDecoder"];var _PyCodec_StreamReader=Module["_PyCodec_StreamReader"]=wasmExports["PyCodec_StreamReader"];var _PyCodec_StreamWriter=Module["_PyCodec_StreamWriter"]=wasmExports["PyCodec_StreamWriter"];var _PyCodec_RegisterError=Module["_PyCodec_RegisterError"]=wasmExports["PyCodec_RegisterError"];var _PyCodec_IgnoreErrors=Module["_PyCodec_IgnoreErrors"]=wasmExports["PyCodec_IgnoreErrors"];var _PyCodec_ReplaceErrors=Module["_PyCodec_ReplaceErrors"]=wasmExports["PyCodec_ReplaceErrors"];var _PyCodec_XMLCharRefReplaceErrors=Module["_PyCodec_XMLCharRefReplaceErrors"]=wasmExports["PyCodec_XMLCharRefReplaceErrors"];var _PyCodec_BackslashReplaceErrors=Module["_PyCodec_BackslashReplaceErrors"]=wasmExports["PyCodec_BackslashReplaceErrors"];var _PyCodec_NameReplaceErrors=Module["_PyCodec_NameReplaceErrors"]=wasmExports["PyCodec_NameReplaceErrors"];var _PyStatus_NoMemory=Module["_PyStatus_NoMemory"]=wasmExports["PyStatus_NoMemory"];var _PyStatus_Error=Module["_PyStatus_Error"]=wasmExports["PyStatus_Error"];var _PyStatus_Ok=Module["_PyStatus_Ok"]=wasmExports["PyStatus_Ok"];var _PyCompile_OpcodeStackEffectWithJump=Module["_PyCompile_OpcodeStackEffectWithJump"]=wasmExports["PyCompile_OpcodeStackEffectWithJump"];var __PyCompile_OpcodeIsValid=Module["__PyCompile_OpcodeIsValid"]=wasmExports["_PyCompile_OpcodeIsValid"];var __PyCompile_OpcodeHasArg=Module["__PyCompile_OpcodeHasArg"]=wasmExports["_PyCompile_OpcodeHasArg"];var __PyCompile_OpcodeHasConst=Module["__PyCompile_OpcodeHasConst"]=wasmExports["_PyCompile_OpcodeHasConst"];var __PyCompile_OpcodeHasName=Module["__PyCompile_OpcodeHasName"]=wasmExports["_PyCompile_OpcodeHasName"];var __PyCompile_OpcodeHasJump=Module["__PyCompile_OpcodeHasJump"]=wasmExports["_PyCompile_OpcodeHasJump"];var __PyCompile_OpcodeHasFree=Module["__PyCompile_OpcodeHasFree"]=wasmExports["_PyCompile_OpcodeHasFree"];var __PyCompile_OpcodeHasLocal=Module["__PyCompile_OpcodeHasLocal"]=wasmExports["_PyCompile_OpcodeHasLocal"];var __PyCompile_OpcodeHasExc=Module["__PyCompile_OpcodeHasExc"]=wasmExports["_PyCompile_OpcodeHasExc"];var __PyCompile_CleanDoc=Module["__PyCompile_CleanDoc"]=wasmExports["_PyCompile_CleanDoc"];var __PyCompile_CodeGen=Module["__PyCompile_CodeGen"]=wasmExports["_PyCompile_CodeGen"];var __PyCompile_OptimizeCfg=Module["__PyCompile_OptimizeCfg"]=wasmExports["_PyCompile_OptimizeCfg"];var __PyInstructionSequence_New=Module["__PyInstructionSequence_New"]=wasmExports["_PyInstructionSequence_New"];var __PyCompile_Assemble=Module["__PyCompile_Assemble"]=wasmExports["_PyCompile_Assemble"];var _PyCode_Optimize=Module["_PyCode_Optimize"]=wasmExports["PyCode_Optimize"];var _PyErr_ProgramTextObject=Module["_PyErr_ProgramTextObject"]=wasmExports["PyErr_ProgramTextObject"];var __PyContext_NewHamtForTests=Module["__PyContext_NewHamtForTests"]=wasmExports["_PyContext_NewHamtForTests"];var _PyContext_New=Module["_PyContext_New"]=wasmExports["PyContext_New"];var _PyContext_Copy=Module["_PyContext_Copy"]=wasmExports["PyContext_Copy"];var _PyContext_CopyCurrent=Module["_PyContext_CopyCurrent"]=wasmExports["PyContext_CopyCurrent"];var _PyContext_Enter=Module["_PyContext_Enter"]=wasmExports["PyContext_Enter"];var _PyContext_Exit=Module["_PyContext_Exit"]=wasmExports["PyContext_Exit"];var _PyContextVar_New=Module["_PyContextVar_New"]=wasmExports["PyContextVar_New"];var _PyContextVar_Get=Module["_PyContextVar_Get"]=wasmExports["PyContextVar_Get"];var _PyContextVar_Set=Module["_PyContextVar_Set"]=wasmExports["PyContextVar_Set"];var _PyContextVar_Reset=Module["_PyContextVar_Reset"]=wasmExports["PyContextVar_Reset"];var __PyCriticalSection_BeginSlow=Module["__PyCriticalSection_BeginSlow"]=wasmExports["_PyCriticalSection_BeginSlow"];var __PyCriticalSection2_BeginSlow=Module["__PyCriticalSection2_BeginSlow"]=wasmExports["_PyCriticalSection2_BeginSlow"];var __PyCriticalSection_SuspendAll=Module["__PyCriticalSection_SuspendAll"]=wasmExports["_PyCriticalSection_SuspendAll"];var __PyCriticalSection_Resume=Module["__PyCriticalSection_Resume"]=wasmExports["_PyCriticalSection_Resume"];var _PyCriticalSection_Begin=Module["_PyCriticalSection_Begin"]=wasmExports["PyCriticalSection_Begin"];var _PyCriticalSection_End=Module["_PyCriticalSection_End"]=wasmExports["PyCriticalSection_End"];var _PyCriticalSection2_Begin=Module["_PyCriticalSection2_Begin"]=wasmExports["PyCriticalSection2_Begin"];var _PyCriticalSection2_End=Module["_PyCriticalSection2_End"]=wasmExports["PyCriticalSection2_End"];var __PyEval_AddPendingCall=Module["__PyEval_AddPendingCall"]=wasmExports["_PyEval_AddPendingCall"];var __PyCrossInterpreterData_Lookup=Module["__PyCrossInterpreterData_Lookup"]=wasmExports["_PyCrossInterpreterData_Lookup"];var __PyCrossInterpreterData_RegisterClass=Module["__PyCrossInterpreterData_RegisterClass"]=wasmExports["_PyCrossInterpreterData_RegisterClass"];var __PyCrossInterpreterData_UnregisterClass=Module["__PyCrossInterpreterData_UnregisterClass"]=wasmExports["_PyCrossInterpreterData_UnregisterClass"];var __PyCrossInterpreterData_New=Module["__PyCrossInterpreterData_New"]=wasmExports["_PyCrossInterpreterData_New"];var __PyCrossInterpreterData_Free=Module["__PyCrossInterpreterData_Free"]=wasmExports["_PyCrossInterpreterData_Free"];var __PyCrossInterpreterData_Clear=Module["__PyCrossInterpreterData_Clear"]=wasmExports["_PyCrossInterpreterData_Clear"];var __PyCrossInterpreterData_Init=Module["__PyCrossInterpreterData_Init"]=wasmExports["_PyCrossInterpreterData_Init"];var _PyInterpreterState_GetID=Module["_PyInterpreterState_GetID"]=wasmExports["PyInterpreterState_GetID"];var __PyCrossInterpreterData_InitWithSize=Module["__PyCrossInterpreterData_InitWithSize"]=wasmExports["_PyCrossInterpreterData_InitWithSize"];var __PyObject_CheckCrossInterpreterData=Module["__PyObject_CheckCrossInterpreterData"]=wasmExports["_PyObject_CheckCrossInterpreterData"];var __PyObject_GetCrossInterpreterData=Module["__PyObject_GetCrossInterpreterData"]=wasmExports["_PyObject_GetCrossInterpreterData"];var __PyCrossInterpreterData_Release=Module["__PyCrossInterpreterData_Release"]=wasmExports["_PyCrossInterpreterData_Release"];var __PyCrossInterpreterData_NewObject=Module["__PyCrossInterpreterData_NewObject"]=wasmExports["_PyCrossInterpreterData_NewObject"];var __PyInterpreterState_LookUpID=Module["__PyInterpreterState_LookUpID"]=wasmExports["_PyInterpreterState_LookUpID"];var __PyCrossInterpreterData_ReleaseAndRawFree=Module["__PyCrossInterpreterData_ReleaseAndRawFree"]=wasmExports["_PyCrossInterpreterData_ReleaseAndRawFree"];var __PyXI_InitExcInfo=Module["__PyXI_InitExcInfo"]=wasmExports["_PyXI_InitExcInfo"];var __PyXI_FormatExcInfo=Module["__PyXI_FormatExcInfo"]=wasmExports["_PyXI_FormatExcInfo"];var __PyXI_ExcInfoAsObject=Module["__PyXI_ExcInfoAsObject"]=wasmExports["_PyXI_ExcInfoAsObject"];var __PyXI_ClearExcInfo=Module["__PyXI_ClearExcInfo"]=wasmExports["_PyXI_ClearExcInfo"];var __PyXI_ApplyError=Module["__PyXI_ApplyError"]=wasmExports["_PyXI_ApplyError"];var __PyXI_FreeNamespace=Module["__PyXI_FreeNamespace"]=wasmExports["_PyXI_FreeNamespace"];var __PyXI_NamespaceFromNames=Module["__PyXI_NamespaceFromNames"]=wasmExports["_PyXI_NamespaceFromNames"];var __PyXI_FillNamespaceFromDict=Module["__PyXI_FillNamespaceFromDict"]=wasmExports["_PyXI_FillNamespaceFromDict"];var __PyXI_ApplyNamespace=Module["__PyXI_ApplyNamespace"]=wasmExports["_PyXI_ApplyNamespace"];var __PyXI_ApplyCapturedException=Module["__PyXI_ApplyCapturedException"]=wasmExports["_PyXI_ApplyCapturedException"];var __PyXI_HasCapturedException=Module["__PyXI_HasCapturedException"]=wasmExports["_PyXI_HasCapturedException"];var __PyXI_Enter=Module["__PyXI_Enter"]=wasmExports["_PyXI_Enter"];var __PyThreadState_NewBound=Module["__PyThreadState_NewBound"]=wasmExports["_PyThreadState_NewBound"];var __PyInterpreterState_SetRunningMain=Module["__PyInterpreterState_SetRunningMain"]=wasmExports["_PyInterpreterState_SetRunningMain"];var _PyUnstable_InterpreterState_GetMainModule=Module["_PyUnstable_InterpreterState_GetMainModule"]=wasmExports["PyUnstable_InterpreterState_GetMainModule"];var __PyInterpreterState_SetNotRunningMain=Module["__PyInterpreterState_SetNotRunningMain"]=wasmExports["_PyInterpreterState_SetNotRunningMain"];var _PyThreadState_Clear=Module["_PyThreadState_Clear"]=wasmExports["PyThreadState_Clear"];var __PyXI_Exit=Module["__PyXI_Exit"]=wasmExports["_PyXI_Exit"];var _PyErr_PrintEx=Module["_PyErr_PrintEx"]=wasmExports["PyErr_PrintEx"];var __PyXI_NewInterpreter=Module["__PyXI_NewInterpreter"]=wasmExports["_PyXI_NewInterpreter"];var _Py_NewInterpreterFromConfig=Module["_Py_NewInterpreterFromConfig"]=wasmExports["Py_NewInterpreterFromConfig"];var __PyErr_SetFromPyStatus=Module["__PyErr_SetFromPyStatus"]=wasmExports["_PyErr_SetFromPyStatus"];var _PyThreadState_GetInterpreter=Module["_PyThreadState_GetInterpreter"]=wasmExports["PyThreadState_GetInterpreter"];var __PyXI_EndInterpreter=Module["__PyXI_EndInterpreter"]=wasmExports["_PyXI_EndInterpreter"];var __PyInterpreterState_IsReady=Module["__PyInterpreterState_IsReady"]=wasmExports["_PyInterpreterState_IsReady"];var _PyInterpreterState_Delete=Module["_PyInterpreterState_Delete"]=wasmExports["PyInterpreterState_Delete"];var _Py_EndInterpreter=Module["_Py_EndInterpreter"]=wasmExports["Py_EndInterpreter"];var __PyErr_SetLocaleString=Module["__PyErr_SetLocaleString"]=wasmExports["_PyErr_SetLocaleString"];var _PyErr_GetHandledException=Module["_PyErr_GetHandledException"]=wasmExports["PyErr_GetHandledException"];var _PyErr_GetExcInfo=Module["_PyErr_GetExcInfo"]=wasmExports["PyErr_GetExcInfo"];var _PyErr_SetExcInfo=Module["_PyErr_SetExcInfo"]=wasmExports["PyErr_SetExcInfo"];var _PyErr_SetFromErrnoWithFilenameObject=Module["_PyErr_SetFromErrnoWithFilenameObject"]=wasmExports["PyErr_SetFromErrnoWithFilenameObject"];var _PyErr_SetFromErrnoWithFilenameObjects=Module["_PyErr_SetFromErrnoWithFilenameObjects"]=wasmExports["PyErr_SetFromErrnoWithFilenameObjects"];var _strerror=wasmExports["strerror"];var _PyErr_SetImportErrorSubclass=Module["_PyErr_SetImportErrorSubclass"]=wasmExports["PyErr_SetImportErrorSubclass"];var _PyErr_SetImportError=Module["_PyErr_SetImportError"]=wasmExports["PyErr_SetImportError"];var _PyErr_BadInternalCall=Module["_PyErr_BadInternalCall"]=wasmExports["PyErr_BadInternalCall"];var _PyErr_FormatV=Module["_PyErr_FormatV"]=wasmExports["PyErr_FormatV"];var _PyErr_NewExceptionWithDoc=Module["_PyErr_NewExceptionWithDoc"]=wasmExports["PyErr_NewExceptionWithDoc"];var _PyTraceBack_Print=Module["_PyTraceBack_Print"]=wasmExports["PyTraceBack_Print"];var _PyErr_SyntaxLocation=Module["_PyErr_SyntaxLocation"]=wasmExports["PyErr_SyntaxLocation"];var _PyErr_SyntaxLocationEx=Module["_PyErr_SyntaxLocationEx"]=wasmExports["PyErr_SyntaxLocationEx"];var _PyErr_RangedSyntaxLocationObject=Module["_PyErr_RangedSyntaxLocationObject"]=wasmExports["PyErr_RangedSyntaxLocationObject"];var _PyErr_ProgramText=Module["_PyErr_ProgramText"]=wasmExports["PyErr_ProgramText"];var __Py_fopen_obj=Module["__Py_fopen_obj"]=wasmExports["_Py_fopen_obj"];var _PyUnstable_InterpreterFrame_GetCode=Module["_PyUnstable_InterpreterFrame_GetCode"]=wasmExports["PyUnstable_InterpreterFrame_GetCode"];var _PyUnstable_InterpreterFrame_GetLasti=Module["_PyUnstable_InterpreterFrame_GetLasti"]=wasmExports["PyUnstable_InterpreterFrame_GetLasti"];var _Py_FrozenMain=Module["_Py_FrozenMain"]=wasmExports["Py_FrozenMain"];var _Py_GETENV=Module["_Py_GETENV"]=wasmExports["Py_GETENV"];var _Py_GetVersion=Module["_Py_GetVersion"]=wasmExports["Py_GetVersion"];var _Py_GetCopyright=Module["_Py_GetCopyright"]=wasmExports["Py_GetCopyright"];var _PyImport_ImportFrozenModule=Module["_PyImport_ImportFrozenModule"]=wasmExports["PyImport_ImportFrozenModule"];var _PyRun_AnyFileExFlags=Module["_PyRun_AnyFileExFlags"]=wasmExports["PyRun_AnyFileExFlags"];var _Py_FinalizeEx=Module["_Py_FinalizeEx"]=wasmExports["Py_FinalizeEx"];var _PyGC_Enable=Module["_PyGC_Enable"]=wasmExports["PyGC_Enable"];var _PyGC_Disable=Module["_PyGC_Disable"]=wasmExports["PyGC_Disable"];var _PyGC_IsEnabled=Module["_PyGC_IsEnabled"]=wasmExports["PyGC_IsEnabled"];var _PyGC_Collect=Module["_PyGC_Collect"]=wasmExports["PyGC_Collect"];var _PyTime_PerfCounterRaw=Module["_PyTime_PerfCounterRaw"]=wasmExports["PyTime_PerfCounterRaw"];var _PyTime_AsSecondsDouble=Module["_PyTime_AsSecondsDouble"]=wasmExports["PyTime_AsSecondsDouble"];var _PyUnstable_Object_GC_NewWithExtraData=Module["_PyUnstable_Object_GC_NewWithExtraData"]=wasmExports["PyUnstable_Object_GC_NewWithExtraData"];var _PyObject_GC_IsTracked=Module["_PyObject_GC_IsTracked"]=wasmExports["PyObject_GC_IsTracked"];var _PyObject_GC_IsFinalized=Module["_PyObject_GC_IsFinalized"]=wasmExports["PyObject_GC_IsFinalized"];var _PyUnstable_GC_VisitObjects=Module["_PyUnstable_GC_VisitObjects"]=wasmExports["PyUnstable_GC_VisitObjects"];var _PyArg_Parse=Module["_PyArg_Parse"]=wasmExports["PyArg_Parse"];var __PyArg_Parse_SizeT=Module["__PyArg_Parse_SizeT"]=wasmExports["_PyArg_Parse_SizeT"];var __PyArg_ParseTuple_SizeT=Module["__PyArg_ParseTuple_SizeT"]=wasmExports["_PyArg_ParseTuple_SizeT"];var _PyArg_VaParse=Module["_PyArg_VaParse"]=wasmExports["PyArg_VaParse"];var __PyArg_VaParse_SizeT=Module["__PyArg_VaParse_SizeT"]=wasmExports["_PyArg_VaParse_SizeT"];var __PyArg_ParseTupleAndKeywords_SizeT=Module["__PyArg_ParseTupleAndKeywords_SizeT"]=wasmExports["_PyArg_ParseTupleAndKeywords_SizeT"];var _PyArg_VaParseTupleAndKeywords=Module["_PyArg_VaParseTupleAndKeywords"]=wasmExports["PyArg_VaParseTupleAndKeywords"];var __PyArg_VaParseTupleAndKeywords_SizeT=Module["__PyArg_VaParseTupleAndKeywords_SizeT"]=wasmExports["_PyArg_VaParseTupleAndKeywords_SizeT"];var __PyArg_ParseTupleAndKeywordsFast=Module["__PyArg_ParseTupleAndKeywordsFast"]=wasmExports["_PyArg_ParseTupleAndKeywordsFast"];var _Py_GetCompiler=Module["_Py_GetCompiler"]=wasmExports["Py_GetCompiler"];var _Py_GetPlatform=Module["_Py_GetPlatform"]=wasmExports["Py_GetPlatform"];var _PyEval_ThreadsInitialized=Module["_PyEval_ThreadsInitialized"]=wasmExports["PyEval_ThreadsInitialized"];var _PyThread_init_thread=Module["_PyThread_init_thread"]=wasmExports["PyThread_init_thread"];var _pthread_cond_destroy=Module["_pthread_cond_destroy"]=wasmExports["pthread_cond_destroy"];var _pthread_mutex_destroy=Module["_pthread_mutex_destroy"]=wasmExports["pthread_mutex_destroy"];var _PyEval_InitThreads=Module["_PyEval_InitThreads"]=wasmExports["PyEval_InitThreads"];var _PyEval_AcquireLock=Module["_PyEval_AcquireLock"]=wasmExports["PyEval_AcquireLock"];var _pthread_mutex_lock=Module["_pthread_mutex_lock"]=wasmExports["pthread_mutex_lock"];var _pthread_cond_timedwait=Module["_pthread_cond_timedwait"]=wasmExports["pthread_cond_timedwait"];var _pthread_mutex_unlock=Module["_pthread_mutex_unlock"]=wasmExports["pthread_mutex_unlock"];var _pthread_cond_signal=Module["_pthread_cond_signal"]=wasmExports["pthread_cond_signal"];var _PyThread_exit_thread=Module["_PyThread_exit_thread"]=wasmExports["PyThread_exit_thread"];var _PyThread_get_thread_ident=Module["_PyThread_get_thread_ident"]=wasmExports["PyThread_get_thread_ident"];var _PyEval_ReleaseLock=Module["_PyEval_ReleaseLock"]=wasmExports["PyEval_ReleaseLock"];var _pthread_cond_wait=Module["_pthread_cond_wait"]=wasmExports["pthread_cond_wait"];var _PyEval_AcquireThread=Module["_PyEval_AcquireThread"]=wasmExports["PyEval_AcquireThread"];var _PyEval_ReleaseThread=Module["_PyEval_ReleaseThread"]=wasmExports["PyEval_ReleaseThread"];var _Py_AddPendingCall=Module["_Py_AddPendingCall"]=wasmExports["Py_AddPendingCall"];var __PyEval_MakePendingCalls=Module["__PyEval_MakePendingCalls"]=wasmExports["_PyEval_MakePendingCalls"];var _Py_MakePendingCalls=Module["_Py_MakePendingCalls"]=wasmExports["Py_MakePendingCalls"];var _pthread_mutex_init=Module["_pthread_mutex_init"]=wasmExports["pthread_mutex_init"];var __Py_hashtable_hash_ptr=Module["__Py_hashtable_hash_ptr"]=wasmExports["_Py_hashtable_hash_ptr"];var __Py_hashtable_compare_direct=Module["__Py_hashtable_compare_direct"]=wasmExports["_Py_hashtable_compare_direct"];var __Py_hashtable_size=Module["__Py_hashtable_size"]=wasmExports["_Py_hashtable_size"];var __Py_hashtable_steal=Module["__Py_hashtable_steal"]=wasmExports["_Py_hashtable_steal"];var __Py_hashtable_foreach=Module["__Py_hashtable_foreach"]=wasmExports["_Py_hashtable_foreach"];var __Py_hashtable_new=Module["__Py_hashtable_new"]=wasmExports["_Py_hashtable_new"];var __Py_hashtable_clear=Module["__Py_hashtable_clear"]=wasmExports["_Py_hashtable_clear"];var __PyRecursiveMutex_Lock=Module["__PyRecursiveMutex_Lock"]=wasmExports["_PyRecursiveMutex_Lock"];var __PyRecursiveMutex_Unlock=Module["__PyRecursiveMutex_Unlock"]=wasmExports["_PyRecursiveMutex_Unlock"];var _PyThread_get_thread_ident_ex=Module["_PyThread_get_thread_ident_ex"]=wasmExports["PyThread_get_thread_ident_ex"];var __PyImport_SetModule=Module["__PyImport_SetModule"]=wasmExports["_PyImport_SetModule"];var _PyImport_AddModuleRef=Module["_PyImport_AddModuleRef"]=wasmExports["PyImport_AddModuleRef"];var _PyImport_AddModuleObject=Module["_PyImport_AddModuleObject"]=wasmExports["PyImport_AddModuleObject"];var _PyImport_AddModule=Module["_PyImport_AddModule"]=wasmExports["PyImport_AddModule"];var _PyState_FindModule=Module["_PyState_FindModule"]=wasmExports["PyState_FindModule"];var __PyState_AddModule=Module["__PyState_AddModule"]=wasmExports["_PyState_AddModule"];var _PyState_AddModule=Module["_PyState_AddModule"]=wasmExports["PyState_AddModule"];var _PyState_RemoveModule=Module["_PyState_RemoveModule"]=wasmExports["PyState_RemoveModule"];var __PyImport_ClearExtension=Module["__PyImport_ClearExtension"]=wasmExports["_PyImport_ClearExtension"];var _PyImport_ExtendInittab=Module["_PyImport_ExtendInittab"]=wasmExports["PyImport_ExtendInittab"];var _PyImport_GetMagicNumber=Module["_PyImport_GetMagicNumber"]=wasmExports["PyImport_GetMagicNumber"];var _PyImport_GetMagicTag=Module["_PyImport_GetMagicTag"]=wasmExports["PyImport_GetMagicTag"];var _PyImport_ExecCodeModule=Module["_PyImport_ExecCodeModule"]=wasmExports["PyImport_ExecCodeModule"];var _PyImport_ExecCodeModuleObject=Module["_PyImport_ExecCodeModuleObject"]=wasmExports["PyImport_ExecCodeModuleObject"];var _PyImport_ExecCodeModuleWithPathnames=Module["_PyImport_ExecCodeModuleWithPathnames"]=wasmExports["PyImport_ExecCodeModuleWithPathnames"];var _PyImport_ExecCodeModuleEx=Module["_PyImport_ExecCodeModuleEx"]=wasmExports["PyImport_ExecCodeModuleEx"];var _PyImport_ImportFrozenModuleObject=Module["_PyImport_ImportFrozenModuleObject"]=wasmExports["PyImport_ImportFrozenModuleObject"];var _PyMarshal_ReadObjectFromString=Module["_PyMarshal_ReadObjectFromString"]=wasmExports["PyMarshal_ReadObjectFromString"];var _PyImport_GetImporter=Module["_PyImport_GetImporter"]=wasmExports["PyImport_GetImporter"];var _PyImport_ImportModuleNoBlock=Module["_PyImport_ImportModuleNoBlock"]=wasmExports["PyImport_ImportModuleNoBlock"];var __PyTime_AsMicroseconds=Module["__PyTime_AsMicroseconds"]=wasmExports["_PyTime_AsMicroseconds"];var _PyImport_ImportModuleLevel=Module["_PyImport_ImportModuleLevel"]=wasmExports["PyImport_ImportModuleLevel"];var _PyImport_ReloadModule=Module["_PyImport_ReloadModule"]=wasmExports["PyImport_ReloadModule"];var __PyImport_GetModuleAttr=Module["__PyImport_GetModuleAttr"]=wasmExports["_PyImport_GetModuleAttr"];var _PyInit__imp=Module["_PyInit__imp"]=wasmExports["PyInit__imp"];var __PyRecursiveMutex_IsLockedByCurrentThread=Module["__PyRecursiveMutex_IsLockedByCurrentThread"]=wasmExports["_PyRecursiveMutex_IsLockedByCurrentThread"];var _PyModule_Add=Module["_PyModule_Add"]=wasmExports["PyModule_Add"];var _PyStatus_Exit=Module["_PyStatus_Exit"]=wasmExports["PyStatus_Exit"];var _PyStatus_IsError=Module["_PyStatus_IsError"]=wasmExports["PyStatus_IsError"];var _PyStatus_IsExit=Module["_PyStatus_IsExit"]=wasmExports["PyStatus_IsExit"];var _PyWideStringList_Insert=Module["_PyWideStringList_Insert"]=wasmExports["PyWideStringList_Insert"];var _PyWideStringList_Append=Module["_PyWideStringList_Append"]=wasmExports["PyWideStringList_Append"];var _Py_GetArgcArgv=Module["_Py_GetArgcArgv"]=wasmExports["Py_GetArgcArgv"];var __PyConfig_InitCompatConfig=Module["__PyConfig_InitCompatConfig"]=wasmExports["_PyConfig_InitCompatConfig"];var _PyConfig_InitIsolatedConfig=Module["_PyConfig_InitIsolatedConfig"]=wasmExports["PyConfig_InitIsolatedConfig"];var _PyConfig_SetString=Module["_PyConfig_SetString"]=wasmExports["PyConfig_SetString"];var _Py_DecodeLocale=Module["_Py_DecodeLocale"]=wasmExports["Py_DecodeLocale"];var __PyConfig_AsDict=Module["__PyConfig_AsDict"]=wasmExports["_PyConfig_AsDict"];var __PyConfig_FromDict=Module["__PyConfig_FromDict"]=wasmExports["_PyConfig_FromDict"];var _wcschr=Module["_wcschr"]=wasmExports["wcschr"];var _setvbuf=Module["_setvbuf"]=wasmExports["setvbuf"];var _PyConfig_SetArgv=Module["_PyConfig_SetArgv"]=wasmExports["PyConfig_SetArgv"];var _PyConfig_SetWideStringList=Module["_PyConfig_SetWideStringList"]=wasmExports["PyConfig_SetWideStringList"];var _putchar=Module["_putchar"]=wasmExports["putchar"];var _iprintf=Module["_iprintf"]=wasmExports["iprintf"];var _wcstok=Module["_wcstok"]=wasmExports["wcstok"];var _strtoul=Module["_strtoul"]=wasmExports["strtoul"];var _wcstol=Module["_wcstol"]=wasmExports["wcstol"];var _setlocale=Module["_setlocale"]=wasmExports["setlocale"];var _PyConfig_Read=Module["_PyConfig_Read"]=wasmExports["PyConfig_Read"];var __Py_GetConfigsAsDict=Module["__Py_GetConfigsAsDict"]=wasmExports["_Py_GetConfigsAsDict"];var __PyInterpreterConfig_AsDict=Module["__PyInterpreterConfig_AsDict"]=wasmExports["_PyInterpreterConfig_AsDict"];var __PyInterpreterConfig_InitFromDict=Module["__PyInterpreterConfig_InitFromDict"]=wasmExports["_PyInterpreterConfig_InitFromDict"];var __PyInterpreterConfig_UpdateFromDict=Module["__PyInterpreterConfig_UpdateFromDict"]=wasmExports["_PyInterpreterConfig_UpdateFromDict"];var __PyInterpreterConfig_InitFromState=Module["__PyInterpreterConfig_InitFromState"]=wasmExports["_PyInterpreterConfig_InitFromState"];var _PyMonitoring_EnterScope=Module["_PyMonitoring_EnterScope"]=wasmExports["PyMonitoring_EnterScope"];var _PyMonitoring_ExitScope=Module["_PyMonitoring_ExitScope"]=wasmExports["PyMonitoring_ExitScope"];var __PyMonitoring_FirePyStartEvent=Module["__PyMonitoring_FirePyStartEvent"]=wasmExports["_PyMonitoring_FirePyStartEvent"];var __PyMonitoring_FirePyResumeEvent=Module["__PyMonitoring_FirePyResumeEvent"]=wasmExports["_PyMonitoring_FirePyResumeEvent"];var __PyMonitoring_FirePyReturnEvent=Module["__PyMonitoring_FirePyReturnEvent"]=wasmExports["_PyMonitoring_FirePyReturnEvent"];var __PyMonitoring_FirePyYieldEvent=Module["__PyMonitoring_FirePyYieldEvent"]=wasmExports["_PyMonitoring_FirePyYieldEvent"];var __PyMonitoring_FireCallEvent=Module["__PyMonitoring_FireCallEvent"]=wasmExports["_PyMonitoring_FireCallEvent"];var __PyMonitoring_FireLineEvent=Module["__PyMonitoring_FireLineEvent"]=wasmExports["_PyMonitoring_FireLineEvent"];var __PyMonitoring_FireJumpEvent=Module["__PyMonitoring_FireJumpEvent"]=wasmExports["_PyMonitoring_FireJumpEvent"];var __PyMonitoring_FireBranchEvent=Module["__PyMonitoring_FireBranchEvent"]=wasmExports["_PyMonitoring_FireBranchEvent"];var __PyMonitoring_FireCReturnEvent=Module["__PyMonitoring_FireCReturnEvent"]=wasmExports["_PyMonitoring_FireCReturnEvent"];var __PyMonitoring_FirePyThrowEvent=Module["__PyMonitoring_FirePyThrowEvent"]=wasmExports["_PyMonitoring_FirePyThrowEvent"];var __PyMonitoring_FireRaiseEvent=Module["__PyMonitoring_FireRaiseEvent"]=wasmExports["_PyMonitoring_FireRaiseEvent"];var __PyMonitoring_FireCRaiseEvent=Module["__PyMonitoring_FireCRaiseEvent"]=wasmExports["_PyMonitoring_FireCRaiseEvent"];var __PyMonitoring_FireReraiseEvent=Module["__PyMonitoring_FireReraiseEvent"]=wasmExports["_PyMonitoring_FireReraiseEvent"];var __PyMonitoring_FireExceptionHandledEvent=Module["__PyMonitoring_FireExceptionHandledEvent"]=wasmExports["_PyMonitoring_FireExceptionHandledEvent"];var __PyMonitoring_FirePyUnwindEvent=Module["__PyMonitoring_FirePyUnwindEvent"]=wasmExports["_PyMonitoring_FirePyUnwindEvent"];var __PyMonitoring_FireStopIterationEvent=Module["__PyMonitoring_FireStopIterationEvent"]=wasmExports["_PyMonitoring_FireStopIterationEvent"];var __PyCompile_GetUnaryIntrinsicName=Module["__PyCompile_GetUnaryIntrinsicName"]=wasmExports["_PyCompile_GetUnaryIntrinsicName"];var __PyCompile_GetBinaryIntrinsicName=Module["__PyCompile_GetBinaryIntrinsicName"]=wasmExports["_PyCompile_GetBinaryIntrinsicName"];var _PyTime_MonotonicRaw=Module["_PyTime_MonotonicRaw"]=wasmExports["PyTime_MonotonicRaw"];var __PyParkingLot_Park=Module["__PyParkingLot_Park"]=wasmExports["_PyParkingLot_Park"];var __PyDeadline_Get=Module["__PyDeadline_Get"]=wasmExports["_PyDeadline_Get"];var __PyParkingLot_Unpark=Module["__PyParkingLot_Unpark"]=wasmExports["_PyParkingLot_Unpark"];var __PySemaphore_Init=Module["__PySemaphore_Init"]=wasmExports["_PySemaphore_Init"];var __PySemaphore_Wait=Module["__PySemaphore_Wait"]=wasmExports["_PySemaphore_Wait"];var __PySemaphore_Destroy=Module["__PySemaphore_Destroy"]=wasmExports["_PySemaphore_Destroy"];var __PySemaphore_Wakeup=Module["__PySemaphore_Wakeup"]=wasmExports["_PySemaphore_Wakeup"];var __PyEvent_IsSet=Module["__PyEvent_IsSet"]=wasmExports["_PyEvent_IsSet"];var __PyEvent_Notify=Module["__PyEvent_Notify"]=wasmExports["_PyEvent_Notify"];var __PyParkingLot_UnparkAll=Module["__PyParkingLot_UnparkAll"]=wasmExports["_PyParkingLot_UnparkAll"];var _PyEvent_Wait=Module["_PyEvent_Wait"]=wasmExports["PyEvent_Wait"];var _PyEvent_WaitTimed=Module["_PyEvent_WaitTimed"]=wasmExports["PyEvent_WaitTimed"];var __PyRWMutex_RLock=Module["__PyRWMutex_RLock"]=wasmExports["_PyRWMutex_RLock"];var __PyRWMutex_RUnlock=Module["__PyRWMutex_RUnlock"]=wasmExports["_PyRWMutex_RUnlock"];var __PyRWMutex_Lock=Module["__PyRWMutex_Lock"]=wasmExports["_PyRWMutex_Lock"];var __PyRWMutex_Unlock=Module["__PyRWMutex_Unlock"]=wasmExports["_PyRWMutex_Unlock"];var __PySeqLock_LockWrite=Module["__PySeqLock_LockWrite"]=wasmExports["_PySeqLock_LockWrite"];var _sched_yield=Module["_sched_yield"]=wasmExports["sched_yield"];var __PySeqLock_AbandonWrite=Module["__PySeqLock_AbandonWrite"]=wasmExports["_PySeqLock_AbandonWrite"];var __PySeqLock_UnlockWrite=Module["__PySeqLock_UnlockWrite"]=wasmExports["_PySeqLock_UnlockWrite"];var __PySeqLock_BeginRead=Module["__PySeqLock_BeginRead"]=wasmExports["_PySeqLock_BeginRead"];var __PySeqLock_EndRead=Module["__PySeqLock_EndRead"]=wasmExports["_PySeqLock_EndRead"];var __PySeqLock_AfterFork=Module["__PySeqLock_AfterFork"]=wasmExports["_PySeqLock_AfterFork"];var _PyMarshal_WriteLongToFile=Module["_PyMarshal_WriteLongToFile"]=wasmExports["PyMarshal_WriteLongToFile"];var _PyMarshal_WriteObjectToFile=Module["_PyMarshal_WriteObjectToFile"]=wasmExports["PyMarshal_WriteObjectToFile"];var _PyMarshal_ReadShortFromFile=Module["_PyMarshal_ReadShortFromFile"]=wasmExports["PyMarshal_ReadShortFromFile"];var _PyMarshal_ReadLongFromFile=Module["_PyMarshal_ReadLongFromFile"]=wasmExports["PyMarshal_ReadLongFromFile"];var _PyMarshal_ReadLastObjectFromFile=Module["_PyMarshal_ReadLastObjectFromFile"]=wasmExports["PyMarshal_ReadLastObjectFromFile"];var __Py_fstat_noraise=Module["__Py_fstat_noraise"]=wasmExports["_Py_fstat_noraise"];var _fread=Module["_fread"]=wasmExports["fread"];var _PyMarshal_ReadObjectFromFile=Module["_PyMarshal_ReadObjectFromFile"]=wasmExports["PyMarshal_ReadObjectFromFile"];var _PyMarshal_WriteObjectToString=Module["_PyMarshal_WriteObjectToString"]=wasmExports["PyMarshal_WriteObjectToString"];var _PyMarshal_Init=Module["_PyMarshal_Init"]=wasmExports["PyMarshal_Init"];var __Py_convert_optional_to_ssize_t=Module["__Py_convert_optional_to_ssize_t"]=wasmExports["_Py_convert_optional_to_ssize_t"];var __Py_BuildValue_SizeT=Module["__Py_BuildValue_SizeT"]=wasmExports["_Py_BuildValue_SizeT"];var _Py_VaBuildValue=Module["_Py_VaBuildValue"]=wasmExports["Py_VaBuildValue"];var __Py_VaBuildValue_SizeT=Module["__Py_VaBuildValue_SizeT"]=wasmExports["_Py_VaBuildValue_SizeT"];var _PyModule_AddStringConstant=Module["_PyModule_AddStringConstant"]=wasmExports["PyModule_AddStringConstant"];var _PyOS_vsnprintf=Module["_PyOS_vsnprintf"]=wasmExports["PyOS_vsnprintf"];var _pthread_cond_init=Module["_pthread_cond_init"]=wasmExports["pthread_cond_init"];var _PyTime_TimeRaw=Module["_PyTime_TimeRaw"]=wasmExports["PyTime_TimeRaw"];var __PyTime_AsTimespec_clamp=Module["__PyTime_AsTimespec_clamp"]=wasmExports["_PyTime_AsTimespec_clamp"];var __PyParkingLot_AfterFork=Module["__PyParkingLot_AfterFork"]=wasmExports["_PyParkingLot_AfterFork"];var __PyPathConfig_ClearGlobal=Module["__PyPathConfig_ClearGlobal"]=wasmExports["_PyPathConfig_ClearGlobal"];var _wcscpy=Module["_wcscpy"]=wasmExports["wcscpy"];var _Py_SetPath=Module["_Py_SetPath"]=wasmExports["Py_SetPath"];var _Py_SetPythonHome=Module["_Py_SetPythonHome"]=wasmExports["Py_SetPythonHome"];var _Py_SetProgramName=Module["_Py_SetProgramName"]=wasmExports["Py_SetProgramName"];var _Py_GetPath=Module["_Py_GetPath"]=wasmExports["Py_GetPath"];var _Py_GetPrefix=Module["_Py_GetPrefix"]=wasmExports["Py_GetPrefix"];var _Py_GetExecPrefix=Module["_Py_GetExecPrefix"]=wasmExports["Py_GetExecPrefix"];var _Py_GetProgramFullPath=Module["_Py_GetProgramFullPath"]=wasmExports["Py_GetProgramFullPath"];var _Py_GetPythonHome=Module["_Py_GetPythonHome"]=wasmExports["Py_GetPythonHome"];var _Py_GetProgramName=Module["_Py_GetProgramName"]=wasmExports["Py_GetProgramName"];var _wcsncpy=Module["_wcsncpy"]=wasmExports["wcsncpy"];var _wcsncmp=Module["_wcsncmp"]=wasmExports["wcsncmp"];var __PyPreConfig_InitCompatConfig=Module["__PyPreConfig_InitCompatConfig"]=wasmExports["_PyPreConfig_InitCompatConfig"];var _PyPreConfig_InitIsolatedConfig=Module["_PyPreConfig_InitIsolatedConfig"]=wasmExports["PyPreConfig_InitIsolatedConfig"];var __Py_SetLocaleFromEnv=Module["__Py_SetLocaleFromEnv"]=wasmExports["_Py_SetLocaleFromEnv"];var _PyHash_GetFuncDef=Module["_PyHash_GetFuncDef"]=wasmExports["PyHash_GetFuncDef"];var _Py_IsFinalizing=Module["_Py_IsFinalizing"]=wasmExports["Py_IsFinalizing"];var _nl_langinfo=Module["_nl_langinfo"]=wasmExports["nl_langinfo"];var _setenv=Module["_setenv"]=wasmExports["setenv"];var __PyInterpreterState_SetConfig=Module["__PyInterpreterState_SetConfig"]=wasmExports["_PyInterpreterState_SetConfig"];var _Py_PreInitializeFromArgs=Module["_Py_PreInitializeFromArgs"]=wasmExports["Py_PreInitializeFromArgs"];var _Py_PreInitialize=Module["_Py_PreInitialize"]=wasmExports["Py_PreInitialize"];var _Py_InitializeEx=Module["_Py_InitializeEx"]=wasmExports["Py_InitializeEx"];var _Py_FatalError=Module["_Py_FatalError"]=wasmExports["Py_FatalError"];var _Py_Initialize=Module["_Py_Initialize"]=wasmExports["Py_Initialize"];var __Py_InitializeMain=Module["__Py_InitializeMain"]=wasmExports["_Py_InitializeMain"];var __PyThreadState_New=Module["__PyThreadState_New"]=wasmExports["_PyThreadState_New"];var _Py_Finalize=Module["_Py_Finalize"]=wasmExports["Py_Finalize"];var _PyInterpreterState_New=Module["_PyInterpreterState_New"]=wasmExports["PyInterpreterState_New"];var _Py_NewInterpreter=Module["_Py_NewInterpreter"]=wasmExports["Py_NewInterpreter"];var __Py_write_noraise=Module["__Py_write_noraise"]=wasmExports["_Py_write_noraise"];var _vfprintf=Module["_vfprintf"]=wasmExports["vfprintf"];var __Py_FatalRefcountErrorFunc=Module["__Py_FatalRefcountErrorFunc"]=wasmExports["_Py_FatalRefcountErrorFunc"];var _Py_AtExit=Module["_Py_AtExit"]=wasmExports["Py_AtExit"];var _Py_Exit=Module["_Py_Exit"]=wasmExports["Py_Exit"];var _Py_FdIsInteractive=Module["_Py_FdIsInteractive"]=wasmExports["Py_FdIsInteractive"];var _PyOS_getsig=Module["_PyOS_getsig"]=wasmExports["PyOS_getsig"];var _signal=Module["_signal"]=wasmExports["signal"];var _PyOS_setsig=Module["_PyOS_setsig"]=wasmExports["PyOS_setsig"];var _siginterrupt=Module["_siginterrupt"]=wasmExports["siginterrupt"];var __PyInterpreterState_New=Module["__PyInterpreterState_New"]=wasmExports["_PyInterpreterState_New"];var _PySys_SetObject=Module["_PySys_SetObject"]=wasmExports["PySys_SetObject"];var __Py_IsValidFD=Module["__Py_IsValidFD"]=wasmExports["_Py_IsValidFD"];var _PyOS_mystrnicmp=Module["_PyOS_mystrnicmp"]=wasmExports["PyOS_mystrnicmp"];var __PyThreadState_GetCurrent=Module["__PyThreadState_GetCurrent"]=wasmExports["_PyThreadState_GetCurrent"];var _PyThread_tss_create=Module["_PyThread_tss_create"]=wasmExports["PyThread_tss_create"];var _PyThread_tss_is_created=Module["_PyThread_tss_is_created"]=wasmExports["PyThread_tss_is_created"];var _PyThread_tss_delete=Module["_PyThread_tss_delete"]=wasmExports["PyThread_tss_delete"];var _PyThread_tss_get=Module["_PyThread_tss_get"]=wasmExports["PyThread_tss_get"];var _PyThread_tss_set=Module["_PyThread_tss_set"]=wasmExports["PyThread_tss_set"];var _PyInterpreterState_Clear=Module["_PyInterpreterState_Clear"]=wasmExports["PyInterpreterState_Clear"];var _PyThread_free_lock=Module["_PyThread_free_lock"]=wasmExports["PyThread_free_lock"];var __PyInterpreterState_IsRunningMain=Module["__PyInterpreterState_IsRunningMain"]=wasmExports["_PyInterpreterState_IsRunningMain"];var __PyInterpreterState_FailIfRunningMain=Module["__PyInterpreterState_FailIfRunningMain"]=wasmExports["_PyInterpreterState_FailIfRunningMain"];var __PyInterpreterState_GetWhence=Module["__PyInterpreterState_GetWhence"]=wasmExports["_PyInterpreterState_GetWhence"];var _PyInterpreterState_GetDict=Module["_PyInterpreterState_GetDict"]=wasmExports["PyInterpreterState_GetDict"];var __PyInterpreterState_ObjectToID=Module["__PyInterpreterState_ObjectToID"]=wasmExports["_PyInterpreterState_ObjectToID"];var __PyInterpreterState_GetIDObject=Module["__PyInterpreterState_GetIDObject"]=wasmExports["_PyInterpreterState_GetIDObject"];var _PyThread_allocate_lock=Module["_PyThread_allocate_lock"]=wasmExports["PyThread_allocate_lock"];var __PyInterpreterState_IDInitref=Module["__PyInterpreterState_IDInitref"]=wasmExports["_PyInterpreterState_IDInitref"];var __PyInterpreterState_IDIncref=Module["__PyInterpreterState_IDIncref"]=wasmExports["_PyInterpreterState_IDIncref"];var _PyThread_acquire_lock=Module["_PyThread_acquire_lock"]=wasmExports["PyThread_acquire_lock"];var _PyThread_release_lock=Module["_PyThread_release_lock"]=wasmExports["PyThread_release_lock"];var __PyInterpreterState_IDDecref=Module["__PyInterpreterState_IDDecref"]=wasmExports["_PyInterpreterState_IDDecref"];var __PyInterpreterState_RequiresIDRef=Module["__PyInterpreterState_RequiresIDRef"]=wasmExports["_PyInterpreterState_RequiresIDRef"];var __PyInterpreterState_RequireIDRef=Module["__PyInterpreterState_RequireIDRef"]=wasmExports["_PyInterpreterState_RequireIDRef"];var __PyInterpreterState_LookUpIDObject=Module["__PyInterpreterState_LookUpIDObject"]=wasmExports["_PyInterpreterState_LookUpIDObject"];var __PyThreadState_Prealloc=Module["__PyThreadState_Prealloc"]=wasmExports["_PyThreadState_Prealloc"];var __PyThreadState_Init=Module["__PyThreadState_Init"]=wasmExports["_PyThreadState_Init"];var _PyThreadState_DeleteCurrent=Module["_PyThreadState_DeleteCurrent"]=wasmExports["PyThreadState_DeleteCurrent"];var __PyThreadState_GetDict=Module["__PyThreadState_GetDict"]=wasmExports["_PyThreadState_GetDict"];var _PyThreadState_GetID=Module["_PyThreadState_GetID"]=wasmExports["PyThreadState_GetID"];var _PyThreadState_SetAsyncExc=Module["_PyThreadState_SetAsyncExc"]=wasmExports["PyThreadState_SetAsyncExc"];var _PyThreadState_GetUnchecked=Module["_PyThreadState_GetUnchecked"]=wasmExports["PyThreadState_GetUnchecked"];var _PyInterpreterState_Head=Module["_PyInterpreterState_Head"]=wasmExports["PyInterpreterState_Head"];var _PyInterpreterState_Main=Module["_PyInterpreterState_Main"]=wasmExports["PyInterpreterState_Main"];var _PyInterpreterState_Next=Module["_PyInterpreterState_Next"]=wasmExports["PyInterpreterState_Next"];var __PyThread_CurrentFrames=Module["__PyThread_CurrentFrames"]=wasmExports["_PyThread_CurrentFrames"];var __PyInterpreterState_GetEvalFrameFunc=Module["__PyInterpreterState_GetEvalFrameFunc"]=wasmExports["_PyInterpreterState_GetEvalFrameFunc"];var __PyInterpreterState_SetEvalFrameFunc=Module["__PyInterpreterState_SetEvalFrameFunc"]=wasmExports["_PyInterpreterState_SetEvalFrameFunc"];var __PyInterpreterState_GetConfigCopy=Module["__PyInterpreterState_GetConfigCopy"]=wasmExports["_PyInterpreterState_GetConfigCopy"];var _rewind=Module["_rewind"]=wasmExports["rewind"];var _PyRun_InteractiveLoopFlags=Module["_PyRun_InteractiveLoopFlags"]=wasmExports["PyRun_InteractiveLoopFlags"];var _PyRun_InteractiveOneObject=Module["_PyRun_InteractiveOneObject"]=wasmExports["PyRun_InteractiveOneObject"];var _PyRun_InteractiveOneFlags=Module["_PyRun_InteractiveOneFlags"]=wasmExports["PyRun_InteractiveOneFlags"];var _PyRun_SimpleFileExFlags=Module["_PyRun_SimpleFileExFlags"]=wasmExports["PyRun_SimpleFileExFlags"];var _PyRun_SimpleStringFlags=Module["_PyRun_SimpleStringFlags"]=wasmExports["PyRun_SimpleStringFlags"];var _PyErr_Display=Module["_PyErr_Display"]=wasmExports["PyErr_Display"];var _PyRun_FileExFlags=Module["_PyRun_FileExFlags"]=wasmExports["PyRun_FileExFlags"];var _Py_CompileStringExFlags=Module["_Py_CompileStringExFlags"]=wasmExports["Py_CompileStringExFlags"];var _PyRun_AnyFile=Module["_PyRun_AnyFile"]=wasmExports["PyRun_AnyFile"];var _PyRun_AnyFileEx=Module["_PyRun_AnyFileEx"]=wasmExports["PyRun_AnyFileEx"];var _PyRun_AnyFileFlags=Module["_PyRun_AnyFileFlags"]=wasmExports["PyRun_AnyFileFlags"];var _PyRun_File=Module["_PyRun_File"]=wasmExports["PyRun_File"];var _PyRun_FileEx=Module["_PyRun_FileEx"]=wasmExports["PyRun_FileEx"];var _PyRun_FileFlags=Module["_PyRun_FileFlags"]=wasmExports["PyRun_FileFlags"];var _PyRun_SimpleFile=Module["_PyRun_SimpleFile"]=wasmExports["PyRun_SimpleFile"];var _PyRun_SimpleFileEx=Module["_PyRun_SimpleFileEx"]=wasmExports["PyRun_SimpleFileEx"];var _PyRun_String=Module["_PyRun_String"]=wasmExports["PyRun_String"];var _PyRun_SimpleString=Module["_PyRun_SimpleString"]=wasmExports["PyRun_SimpleString"];var _Py_CompileString=Module["_Py_CompileString"]=wasmExports["Py_CompileString"];var _Py_CompileStringFlags=Module["_Py_CompileStringFlags"]=wasmExports["Py_CompileStringFlags"];var _PyRun_InteractiveOne=Module["_PyRun_InteractiveOne"]=wasmExports["PyRun_InteractiveOne"];var _PyRun_InteractiveLoop=Module["_PyRun_InteractiveLoop"]=wasmExports["PyRun_InteractiveLoop"];var __PyLong_AsTime_t=Module["__PyLong_AsTime_t"]=wasmExports["_PyLong_AsTime_t"];var __PyLong_FromTime_t=Module["__PyLong_FromTime_t"]=wasmExports["_PyLong_FromTime_t"];var __PyTime_ObjectToTime_t=Module["__PyTime_ObjectToTime_t"]=wasmExports["_PyTime_ObjectToTime_t"];var __PyTime_ObjectToTimespec=Module["__PyTime_ObjectToTimespec"]=wasmExports["_PyTime_ObjectToTimespec"];var __PyTime_ObjectToTimeval=Module["__PyTime_ObjectToTimeval"]=wasmExports["_PyTime_ObjectToTimeval"];var __PyTime_FromSeconds=Module["__PyTime_FromSeconds"]=wasmExports["_PyTime_FromSeconds"];var __PyTime_FromLong=Module["__PyTime_FromLong"]=wasmExports["_PyTime_FromLong"];var __PyTime_FromSecondsObject=Module["__PyTime_FromSecondsObject"]=wasmExports["_PyTime_FromSecondsObject"];var __PyTime_FromMillisecondsObject=Module["__PyTime_FromMillisecondsObject"]=wasmExports["_PyTime_FromMillisecondsObject"];var __PyTime_AsLong=Module["__PyTime_AsLong"]=wasmExports["_PyTime_AsLong"];var __PyTime_AsMilliseconds=Module["__PyTime_AsMilliseconds"]=wasmExports["_PyTime_AsMilliseconds"];var __PyTime_AsTimeval=Module["__PyTime_AsTimeval"]=wasmExports["_PyTime_AsTimeval"];var __PyTime_AsTimeval_clamp=Module["__PyTime_AsTimeval_clamp"]=wasmExports["_PyTime_AsTimeval_clamp"];var __PyTime_AsTimevalTime_t=Module["__PyTime_AsTimevalTime_t"]=wasmExports["_PyTime_AsTimevalTime_t"];var __PyTime_AsTimespec=Module["__PyTime_AsTimespec"]=wasmExports["_PyTime_AsTimespec"];var _PyTime_Time=Module["_PyTime_Time"]=wasmExports["PyTime_Time"];var _clock_getres=Module["_clock_getres"]=wasmExports["clock_getres"];var _PyTime_Monotonic=Module["_PyTime_Monotonic"]=wasmExports["PyTime_Monotonic"];var __PyTime_MonotonicWithInfo=Module["__PyTime_MonotonicWithInfo"]=wasmExports["_PyTime_MonotonicWithInfo"];var _PyTime_PerfCounter=Module["_PyTime_PerfCounter"]=wasmExports["PyTime_PerfCounter"];var __PyTime_localtime=Module["__PyTime_localtime"]=wasmExports["_PyTime_localtime"];var _localtime_r=Module["_localtime_r"]=wasmExports["localtime_r"];var __PyTime_gmtime=Module["__PyTime_gmtime"]=wasmExports["_PyTime_gmtime"];var _gmtime_r=Module["_gmtime_r"]=wasmExports["gmtime_r"];var __PyDeadline_Init=Module["__PyDeadline_Init"]=wasmExports["_PyDeadline_Init"];var _getentropy=Module["_getentropy"]=wasmExports["getentropy"];var __Py_open=Module["__Py_open"]=wasmExports["_Py_open"];var _close=Module["_close"]=wasmExports["close"];var __Py_fstat=Module["__Py_fstat"]=wasmExports["_Py_fstat"];var __Py_open_noraise=Module["__Py_open_noraise"]=wasmExports["_Py_open_noraise"];var __PyOS_URandomNonblock=Module["__PyOS_URandomNonblock"]=wasmExports["_PyOS_URandomNonblock"];var _PySys_AuditTuple=Module["_PySys_AuditTuple"]=wasmExports["PySys_AuditTuple"];var _PySys_AddAuditHook=Module["_PySys_AddAuditHook"]=wasmExports["PySys_AddAuditHook"];var __PySys_GetSizeOf=Module["__PySys_GetSizeOf"]=wasmExports["_PySys_GetSizeOf"];var _PyUnstable_PerfMapState_Init=Module["_PyUnstable_PerfMapState_Init"]=wasmExports["PyUnstable_PerfMapState_Init"];var _getpid=Module["_getpid"]=wasmExports["getpid"];var _open=Module["_open"]=wasmExports["open"];var _fdopen=Module["_fdopen"]=wasmExports["fdopen"];var _PyUnstable_WritePerfMapEntry=Module["_PyUnstable_WritePerfMapEntry"]=wasmExports["PyUnstable_WritePerfMapEntry"];var _PyUnstable_PerfMapState_Fini=Module["_PyUnstable_PerfMapState_Fini"]=wasmExports["PyUnstable_PerfMapState_Fini"];var _PyUnstable_CopyPerfMapFile=Module["_PyUnstable_CopyPerfMapFile"]=wasmExports["PyUnstable_CopyPerfMapFile"];var _fopen=Module["_fopen"]=wasmExports["fopen"];var _PySys_ResetWarnOptions=Module["_PySys_ResetWarnOptions"]=wasmExports["PySys_ResetWarnOptions"];var _PySys_AddWarnOptionUnicode=Module["_PySys_AddWarnOptionUnicode"]=wasmExports["PySys_AddWarnOptionUnicode"];var _PySys_AddWarnOption=Module["_PySys_AddWarnOption"]=wasmExports["PySys_AddWarnOption"];var _PySys_HasWarnOptions=Module["_PySys_HasWarnOptions"]=wasmExports["PySys_HasWarnOptions"];var _PySys_AddXOption=Module["_PySys_AddXOption"]=wasmExports["PySys_AddXOption"];var _PySys_GetXOptions=Module["_PySys_GetXOptions"]=wasmExports["PySys_GetXOptions"];var _PyThread_GetInfo=Module["_PyThread_GetInfo"]=wasmExports["PyThread_GetInfo"];var _PySys_SetPath=Module["_PySys_SetPath"]=wasmExports["PySys_SetPath"];var _PySys_SetArgvEx=Module["_PySys_SetArgvEx"]=wasmExports["PySys_SetArgvEx"];var _PySys_SetArgv=Module["_PySys_SetArgv"]=wasmExports["PySys_SetArgv"];var _PySys_WriteStdout=Module["_PySys_WriteStdout"]=wasmExports["PySys_WriteStdout"];var _PySys_FormatStdout=Module["_PySys_FormatStdout"]=wasmExports["PySys_FormatStdout"];var _pthread_condattr_init=Module["_pthread_condattr_init"]=wasmExports["pthread_condattr_init"];var _pthread_condattr_setclock=Module["_pthread_condattr_setclock"]=wasmExports["pthread_condattr_setclock"];var _PyThread_start_joinable_thread=Module["_PyThread_start_joinable_thread"]=wasmExports["PyThread_start_joinable_thread"];var _pthread_attr_init=Module["_pthread_attr_init"]=wasmExports["pthread_attr_init"];var _pthread_attr_setstacksize=Module["_pthread_attr_setstacksize"]=wasmExports["pthread_attr_setstacksize"];var _pthread_attr_destroy=Module["_pthread_attr_destroy"]=wasmExports["pthread_attr_destroy"];var _pthread_create=Module["_pthread_create"]=wasmExports["pthread_create"];var _PyThread_start_new_thread=Module["_PyThread_start_new_thread"]=wasmExports["PyThread_start_new_thread"];var _pthread_detach=Module["_pthread_detach"]=wasmExports["pthread_detach"];var _PyThread_join_thread=Module["_PyThread_join_thread"]=wasmExports["PyThread_join_thread"];var _pthread_join=Module["_pthread_join"]=wasmExports["pthread_join"];var _PyThread_detach_thread=Module["_PyThread_detach_thread"]=wasmExports["PyThread_detach_thread"];var _pthread_self=Module["_pthread_self"]=wasmExports["pthread_self"];var _PyThread_acquire_lock_timed=Module["_PyThread_acquire_lock_timed"]=wasmExports["PyThread_acquire_lock_timed"];var _pthread_mutex_trylock=Module["_pthread_mutex_trylock"]=wasmExports["pthread_mutex_trylock"];var _PyThread_create_key=Module["_PyThread_create_key"]=wasmExports["PyThread_create_key"];var _pthread_key_create=Module["_pthread_key_create"]=wasmExports["pthread_key_create"];var _pthread_key_delete=Module["_pthread_key_delete"]=wasmExports["pthread_key_delete"];var _PyThread_delete_key=Module["_PyThread_delete_key"]=wasmExports["PyThread_delete_key"];var _PyThread_delete_key_value=Module["_PyThread_delete_key_value"]=wasmExports["PyThread_delete_key_value"];var _pthread_setspecific=Module["_pthread_setspecific"]=wasmExports["pthread_setspecific"];var _PyThread_set_key_value=Module["_PyThread_set_key_value"]=wasmExports["PyThread_set_key_value"];var _PyThread_get_key_value=Module["_PyThread_get_key_value"]=wasmExports["PyThread_get_key_value"];var _pthread_getspecific=Module["_pthread_getspecific"]=wasmExports["pthread_getspecific"];var _PyThread_ReInitTLS=Module["_PyThread_ReInitTLS"]=wasmExports["PyThread_ReInitTLS"];var _PyThread_get_stacksize=Module["_PyThread_get_stacksize"]=wasmExports["PyThread_get_stacksize"];var _PyThread_set_stacksize=Module["_PyThread_set_stacksize"]=wasmExports["PyThread_set_stacksize"];var _PyThread_ParseTimeoutArg=Module["_PyThread_ParseTimeoutArg"]=wasmExports["PyThread_ParseTimeoutArg"];var _PyThread_acquire_lock_timed_with_retries=Module["_PyThread_acquire_lock_timed_with_retries"]=wasmExports["PyThread_acquire_lock_timed_with_retries"];var _PyThread_tss_alloc=Module["_PyThread_tss_alloc"]=wasmExports["PyThread_tss_alloc"];var _PyThread_tss_free=Module["_PyThread_tss_free"]=wasmExports["PyThread_tss_free"];var _confstr=Module["_confstr"]=wasmExports["confstr"];var __PyTraceback_Add=Module["__PyTraceback_Add"]=wasmExports["_PyTraceback_Add"];var _PyTraceMalloc_Track=Module["_PyTraceMalloc_Track"]=wasmExports["PyTraceMalloc_Track"];var _PyTraceMalloc_Untrack=Module["_PyTraceMalloc_Untrack"]=wasmExports["PyTraceMalloc_Untrack"];var __PyTraceMalloc_GetTraceback=Module["__PyTraceMalloc_GetTraceback"]=wasmExports["_PyTraceMalloc_GetTraceback"];var _PyOS_mystricmp=Module["_PyOS_mystricmp"]=wasmExports["PyOS_mystricmp"];var __Py_strhex=Module["__Py_strhex"]=wasmExports["_Py_strhex"];var __Py_strhex_bytes_with_sep=Module["__Py_strhex_bytes_with_sep"]=wasmExports["_Py_strhex_bytes_with_sep"];var _localeconv=Module["_localeconv"]=wasmExports["localeconv"];var _mbstowcs=Module["_mbstowcs"]=wasmExports["mbstowcs"];var _mbrtowc=Module["_mbrtowc"]=wasmExports["mbrtowc"];var _Py_EncodeLocale=Module["_Py_EncodeLocale"]=wasmExports["Py_EncodeLocale"];var _fstat=Module["_fstat"]=wasmExports["fstat"];var _stat=Module["_stat"]=wasmExports["stat"];var __Py_stat=Module["__Py_stat"]=wasmExports["_Py_stat"];var _fcntl=Module["_fcntl"]=wasmExports["fcntl"];var __Py_set_inheritable=Module["__Py_set_inheritable"]=wasmExports["_Py_set_inheritable"];var __Py_set_inheritable_async_safe=Module["__Py_set_inheritable_async_safe"]=wasmExports["_Py_set_inheritable_async_safe"];var _wcstombs=Module["_wcstombs"]=wasmExports["wcstombs"];var _write=Module["_write"]=wasmExports["write"];var _readlink=Module["_readlink"]=wasmExports["readlink"];var _realpath=Module["_realpath"]=wasmExports["realpath"];var _getcwd=Module["_getcwd"]=wasmExports["getcwd"];var __Py_normpath=Module["__Py_normpath"]=wasmExports["_Py_normpath"];var __Py_dup=Module["__Py_dup"]=wasmExports["_Py_dup"];var __Py_closerange=Module["__Py_closerange"]=wasmExports["_Py_closerange"];var _sysconf=Module["_sysconf"]=wasmExports["sysconf"];var __Py_UTF8_Edit_Cost=Module["__Py_UTF8_Edit_Cost"]=wasmExports["_Py_UTF8_Edit_Cost"];var _PyUnstable_PerfTrampoline_CompileCode=Module["_PyUnstable_PerfTrampoline_CompileCode"]=wasmExports["PyUnstable_PerfTrampoline_CompileCode"];var _PyUnstable_PerfTrampoline_SetPersistAfterFork=Module["_PyUnstable_PerfTrampoline_SetPersistAfterFork"]=wasmExports["PyUnstable_PerfTrampoline_SetPersistAfterFork"];var _dlopen=Module["_dlopen"]=wasmExports["dlopen"];var _dlerror=Module["_dlerror"]=wasmExports["dlerror"];var _dlsym=Module["_dlsym"]=wasmExports["dlsym"];var _PyErr_SetInterruptEx=Module["_PyErr_SetInterruptEx"]=wasmExports["PyErr_SetInterruptEx"];var _PyInit__ctypes=Module["_PyInit__ctypes"]=wasmExports["PyInit__ctypes"];var _PyInit__posixsubprocess=Module["_PyInit__posixsubprocess"]=wasmExports["PyInit__posixsubprocess"];var _PyInit__bz2=Module["_PyInit__bz2"]=wasmExports["PyInit__bz2"];var _PyInit_zlib=Module["_PyInit_zlib"]=wasmExports["PyInit_zlib"];var _PyInit_array=Module["_PyInit_array"]=wasmExports["PyInit_array"];var _PyInit__asyncio=Module["_PyInit__asyncio"]=wasmExports["PyInit__asyncio"];var _PyInit__bisect=Module["_PyInit__bisect"]=wasmExports["PyInit__bisect"];var _PyInit__contextvars=Module["_PyInit__contextvars"]=wasmExports["PyInit__contextvars"];var _PyInit__csv=Module["_PyInit__csv"]=wasmExports["PyInit__csv"];var _PyInit__heapq=Module["_PyInit__heapq"]=wasmExports["PyInit__heapq"];var _PyInit__json=Module["_PyInit__json"]=wasmExports["PyInit__json"];var _PyInit__lsprof=Module["_PyInit__lsprof"]=wasmExports["PyInit__lsprof"];var _PyInit__opcode=Module["_PyInit__opcode"]=wasmExports["PyInit__opcode"];var _PyInit__pickle=Module["_PyInit__pickle"]=wasmExports["PyInit__pickle"];var _PyInit__queue=Module["_PyInit__queue"]=wasmExports["PyInit__queue"];var _PyInit__random=Module["_PyInit__random"]=wasmExports["PyInit__random"];var _PyInit__struct=Module["_PyInit__struct"]=wasmExports["PyInit__struct"];var _PyInit__zoneinfo=Module["_PyInit__zoneinfo"]=wasmExports["PyInit__zoneinfo"];var _PyInit_math=Module["_PyInit_math"]=wasmExports["PyInit_math"];var _PyInit_cmath=Module["_PyInit_cmath"]=wasmExports["PyInit_cmath"];var _PyInit__statistics=Module["_PyInit__statistics"]=wasmExports["PyInit__statistics"];var _PyInit__datetime=Module["_PyInit__datetime"]=wasmExports["PyInit__datetime"];var _PyInit__decimal=Module["_PyInit__decimal"]=wasmExports["PyInit__decimal"];var _PyInit_binascii=Module["_PyInit_binascii"]=wasmExports["PyInit_binascii"];var _PyInit__md5=Module["_PyInit__md5"]=wasmExports["PyInit__md5"];var _PyInit__sha1=Module["_PyInit__sha1"]=wasmExports["PyInit__sha1"];var _PyInit__sha2=Module["_PyInit__sha2"]=wasmExports["PyInit__sha2"];var _PyInit__sha3=Module["_PyInit__sha3"]=wasmExports["PyInit__sha3"];var _PyInit__blake2=Module["_PyInit__blake2"]=wasmExports["PyInit__blake2"];var _PyInit_pyexpat=Module["_PyInit_pyexpat"]=wasmExports["PyInit_pyexpat"];var _PyInit__elementtree=Module["_PyInit__elementtree"]=wasmExports["PyInit__elementtree"];var _PyInit__codecs_cn=Module["_PyInit__codecs_cn"]=wasmExports["PyInit__codecs_cn"];var _PyInit__codecs_hk=Module["_PyInit__codecs_hk"]=wasmExports["PyInit__codecs_hk"];var _PyInit__codecs_iso2022=Module["_PyInit__codecs_iso2022"]=wasmExports["PyInit__codecs_iso2022"];var _PyInit__codecs_jp=Module["_PyInit__codecs_jp"]=wasmExports["PyInit__codecs_jp"];var _PyInit__codecs_kr=Module["_PyInit__codecs_kr"]=wasmExports["PyInit__codecs_kr"];var _PyInit__codecs_tw=Module["_PyInit__codecs_tw"]=wasmExports["PyInit__codecs_tw"];var _PyInit__multibytecodec=Module["_PyInit__multibytecodec"]=wasmExports["PyInit__multibytecodec"];var _PyInit_unicodedata=Module["_PyInit_unicodedata"]=wasmExports["PyInit_unicodedata"];var _PyInit_mmap=Module["_PyInit_mmap"]=wasmExports["PyInit_mmap"];var _PyInit_select=Module["_PyInit_select"]=wasmExports["PyInit_select"];var _PyInit__socket=Module["_PyInit__socket"]=wasmExports["PyInit__socket"];var _PyInit_atexit=Module["_PyInit_atexit"]=wasmExports["PyInit_atexit"];var _PyInit_faulthandler=Module["_PyInit_faulthandler"]=wasmExports["PyInit_faulthandler"];var _PyInit_posix=Module["_PyInit_posix"]=wasmExports["PyInit_posix"];var _PyInit__signal=Module["_PyInit__signal"]=wasmExports["PyInit__signal"];var _PyInit__tracemalloc=Module["_PyInit__tracemalloc"]=wasmExports["PyInit__tracemalloc"];var _PyInit__suggestions=Module["_PyInit__suggestions"]=wasmExports["PyInit__suggestions"];var _PyInit__codecs=Module["_PyInit__codecs"]=wasmExports["PyInit__codecs"];var _PyInit__collections=Module["_PyInit__collections"]=wasmExports["PyInit__collections"];var _PyInit_errno=Module["_PyInit_errno"]=wasmExports["PyInit_errno"];var _PyInit__io=Module["_PyInit__io"]=wasmExports["PyInit__io"];var _PyInit_itertools=Module["_PyInit_itertools"]=wasmExports["PyInit_itertools"];var _PyInit__sre=Module["_PyInit__sre"]=wasmExports["PyInit__sre"];var _PyInit__sysconfig=Module["_PyInit__sysconfig"]=wasmExports["PyInit__sysconfig"];var _PyInit__thread=Module["_PyInit__thread"]=wasmExports["PyInit__thread"];var _PyInit_time=Module["_PyInit_time"]=wasmExports["PyInit_time"];var _PyInit__typing=Module["_PyInit__typing"]=wasmExports["PyInit__typing"];var _PyInit__weakref=Module["_PyInit__weakref"]=wasmExports["PyInit__weakref"];var _PyInit__abc=Module["_PyInit__abc"]=wasmExports["PyInit__abc"];var _PyInit__functools=Module["_PyInit__functools"]=wasmExports["PyInit__functools"];var _PyInit__locale=Module["_PyInit__locale"]=wasmExports["PyInit__locale"];var _PyInit__operator=Module["_PyInit__operator"]=wasmExports["PyInit__operator"];var _PyInit__stat=Module["_PyInit__stat"]=wasmExports["PyInit__stat"];var _PyInit__symtable=Module["_PyInit__symtable"]=wasmExports["PyInit__symtable"];var _PyInit_gc=Module["_PyInit_gc"]=wasmExports["PyInit_gc"];var _Py_RunMain=Module["_Py_RunMain"]=wasmExports["Py_RunMain"];var _perror=Module["_perror"]=wasmExports["perror"];var _kill=Module["_kill"]=wasmExports["kill"];var _Py_Main=Module["_Py_Main"]=wasmExports["Py_Main"];var _Py_BytesMain=Module["_Py_BytesMain"]=wasmExports["Py_BytesMain"];var _strcat=Module["_strcat"]=wasmExports["strcat"];var _memmove=Module["_memmove"]=wasmExports["memmove"];var _memset=Module["_memset"]=wasmExports["memset"];var _ffi_closure_alloc=Module["_ffi_closure_alloc"]=wasmExports["ffi_closure_alloc"];var _ffi_prep_cif=Module["_ffi_prep_cif"]=wasmExports["ffi_prep_cif"];var _ffi_prep_closure_loc=Module["_ffi_prep_closure_loc"]=wasmExports["ffi_prep_closure_loc"];var _ffi_closure_free=Module["_ffi_closure_free"]=wasmExports["ffi_closure_free"];var _ffi_prep_cif_var=Module["_ffi_prep_cif_var"]=wasmExports["ffi_prep_cif_var"];var _ffi_call=Module["_ffi_call"]=wasmExports["ffi_call"];var _dlclose=Module["_dlclose"]=wasmExports["dlclose"];var ___extenddftf2=Module["___extenddftf2"]=wasmExports["__extenddftf2"];var ___trunctfdf2=Module["___trunctfdf2"]=wasmExports["__trunctfdf2"];var __Py_Gid_Converter=Module["__Py_Gid_Converter"]=wasmExports["_Py_Gid_Converter"];var __Py_Uid_Converter=Module["__Py_Uid_Converter"]=wasmExports["_Py_Uid_Converter"];var _PyOS_BeforeFork=Module["_PyOS_BeforeFork"]=wasmExports["PyOS_BeforeFork"];var _PyOS_AfterFork_Parent=Module["_PyOS_AfterFork_Parent"]=wasmExports["PyOS_AfterFork_Parent"];var _fork=Module["_fork"]=wasmExports["fork"];var _PyOS_AfterFork_Child=Module["_PyOS_AfterFork_Child"]=wasmExports["PyOS_AfterFork_Child"];var __exit=Module["__exit"]=wasmExports["_exit"];var _dup=Module["_dup"]=wasmExports["dup"];var _dup2=Module["_dup2"]=wasmExports["dup2"];var _chdir=Module["_chdir"]=wasmExports["chdir"];var _umask=Module["_umask"]=wasmExports["umask"];var __Py_RestoreSignals=Module["__Py_RestoreSignals"]=wasmExports["_Py_RestoreSignals"];var _setsid=Module["_setsid"]=wasmExports["setsid"];var _setpgid=Module["_setpgid"]=wasmExports["setpgid"];var _setregid=Module["_setregid"]=wasmExports["setregid"];var _setreuid=Module["_setreuid"]=wasmExports["setreuid"];var _execve=Module["_execve"]=wasmExports["execve"];var _execv=Module["_execv"]=wasmExports["execv"];var _opendir=Module["_opendir"]=wasmExports["opendir"];var _dirfd=Module["_dirfd"]=wasmExports["dirfd"];var _readdir=Module["_readdir"]=wasmExports["readdir"];var _closedir=Module["_closedir"]=wasmExports["closedir"];var _BZ2_bzCompressEnd=Module["_BZ2_bzCompressEnd"]=wasmExports["BZ2_bzCompressEnd"];var _BZ2_bzCompressInit=Module["_BZ2_bzCompressInit"]=wasmExports["BZ2_bzCompressInit"];var _BZ2_bzCompress=Module["_BZ2_bzCompress"]=wasmExports["BZ2_bzCompress"];var _BZ2_bzDecompressEnd=Module["_BZ2_bzDecompressEnd"]=wasmExports["BZ2_bzDecompressEnd"];var _BZ2_bzDecompressInit=Module["_BZ2_bzDecompressInit"]=wasmExports["BZ2_bzDecompressInit"];var _BZ2_bzDecompress=Module["_BZ2_bzDecompress"]=wasmExports["BZ2_bzDecompress"];var _adler32=Module["_adler32"]=wasmExports["adler32"];var _deflateInit2_=Module["_deflateInit2_"]=wasmExports["deflateInit2_"];var _deflateEnd=Module["_deflateEnd"]=wasmExports["deflateEnd"];var _deflate=Module["_deflate"]=wasmExports["deflate"];var _deflateSetDictionary=Module["_deflateSetDictionary"]=wasmExports["deflateSetDictionary"];var _crc32=Module["_crc32"]=wasmExports["crc32"];var _inflateInit2_=Module["_inflateInit2_"]=wasmExports["inflateInit2_"];var _inflateEnd=Module["_inflateEnd"]=wasmExports["inflateEnd"];var _inflate=Module["_inflate"]=wasmExports["inflate"];var _inflateSetDictionary=Module["_inflateSetDictionary"]=wasmExports["inflateSetDictionary"];var _zlibVersion=Module["_zlibVersion"]=wasmExports["zlibVersion"];var _deflateCopy=Module["_deflateCopy"]=wasmExports["deflateCopy"];var _inflateCopy=Module["_inflateCopy"]=wasmExports["inflateCopy"];var _acos=Module["_acos"]=wasmExports["acos"];var _acosh=Module["_acosh"]=wasmExports["acosh"];var _asin=Module["_asin"]=wasmExports["asin"];var _asinh=Module["_asinh"]=wasmExports["asinh"];var _atan=Module["_atan"]=wasmExports["atan"];var _atanh=Module["_atanh"]=wasmExports["atanh"];var _cbrt=Module["_cbrt"]=wasmExports["cbrt"];var _copysign=Module["_copysign"]=wasmExports["copysign"];var _cosh=Module["_cosh"]=wasmExports["cosh"];var _erf=Module["_erf"]=wasmExports["erf"];var _erfc=Module["_erfc"]=wasmExports["erfc"];var _exp2=Module["_exp2"]=wasmExports["exp2"];var _expm1=Module["_expm1"]=wasmExports["expm1"];var _fabs=Module["_fabs"]=wasmExports["fabs"];var _fma=Module["_fma"]=wasmExports["fma"];var _sinh=Module["_sinh"]=wasmExports["sinh"];var _sqrt=Module["_sqrt"]=wasmExports["sqrt"];var _tan=Module["_tan"]=wasmExports["tan"];var _tanh=Module["_tanh"]=wasmExports["tanh"];var _nextafter=Module["_nextafter"]=wasmExports["nextafter"];var _log1p=Module["_log1p"]=wasmExports["log1p"];var _log10=Module["_log10"]=wasmExports["log10"];var _log2=Module["_log2"]=wasmExports["log2"];var _explicit_bzero=Module["_explicit_bzero"]=wasmExports["explicit_bzero"];var _strncat=Module["_strncat"]=wasmExports["strncat"];var _mmap=Module["_mmap"]=wasmExports["mmap"];var _munmap=Module["_munmap"]=wasmExports["munmap"];var _msync=Module["_msync"]=wasmExports["msync"];var _madvise=Module["_madvise"]=wasmExports["madvise"];var _ftruncate=Module["_ftruncate"]=wasmExports["ftruncate"];var _mremap=Module["_mremap"]=wasmExports["mremap"];var _poll=Module["_poll"]=wasmExports["poll"];var _select=Module["_select"]=wasmExports["select"];var _inet_ntop=Module["_inet_ntop"]=wasmExports["inet_ntop"];var _gethostbyname=Module["_gethostbyname"]=wasmExports["gethostbyname"];var _gethostbyaddr=Module["_gethostbyaddr"]=wasmExports["gethostbyaddr"];var _gethostname=Module["_gethostname"]=wasmExports["gethostname"];var _getservbyname=Module["_getservbyname"]=wasmExports["getservbyname"];var _ntohs=wasmExports["ntohs"];var _htons=wasmExports["htons"];var _getservbyport=Module["_getservbyport"]=wasmExports["getservbyport"];var _ntohl=Module["_ntohl"]=wasmExports["ntohl"];var _htonl=wasmExports["htonl"];var _inet_aton=Module["_inet_aton"]=wasmExports["inet_aton"];var _inet_ntoa=Module["_inet_ntoa"]=wasmExports["inet_ntoa"];var _inet_pton=Module["_inet_pton"]=wasmExports["inet_pton"];var _gai_strerror=Module["_gai_strerror"]=wasmExports["gai_strerror"];var _freeaddrinfo=Module["_freeaddrinfo"]=wasmExports["freeaddrinfo"];var _if_nameindex=Module["_if_nameindex"]=wasmExports["if_nameindex"];var _if_freenameindex=Module["_if_freenameindex"]=wasmExports["if_freenameindex"];var _if_nametoindex=Module["_if_nametoindex"]=wasmExports["if_nametoindex"];var _if_indextoname=Module["_if_indextoname"]=wasmExports["if_indextoname"];var ___h_errno_location=Module["___h_errno_location"]=wasmExports["__h_errno_location"];var _hstrerror=Module["_hstrerror"]=wasmExports["hstrerror"];var _getsockname=Module["_getsockname"]=wasmExports["getsockname"];var _socket=Module["_socket"]=wasmExports["socket"];var _getsockopt=Module["_getsockopt"]=wasmExports["getsockopt"];var _bind=Module["_bind"]=wasmExports["bind"];var _getpeername=Module["_getpeername"]=wasmExports["getpeername"];var _listen=Module["_listen"]=wasmExports["listen"];var _setsockopt=Module["_setsockopt"]=wasmExports["setsockopt"];var _accept4=Module["_accept4"]=wasmExports["accept4"];var _accept=Module["_accept"]=wasmExports["accept"];var _connect=Module["_connect"]=wasmExports["connect"];var _recv=Module["_recv"]=wasmExports["recv"];var _recvfrom=Module["_recvfrom"]=wasmExports["recvfrom"];var _send=Module["_send"]=wasmExports["send"];var _sendto=Module["_sendto"]=wasmExports["sendto"];var _recvmsg=Module["_recvmsg"]=wasmExports["recvmsg"];var _sendmsg=Module["_sendmsg"]=wasmExports["sendmsg"];var _PyUnstable_AtExit=Module["_PyUnstable_AtExit"]=wasmExports["PyUnstable_AtExit"];var _getrlimit=Module["_getrlimit"]=wasmExports["getrlimit"];var _setrlimit=Module["_setrlimit"]=wasmExports["setrlimit"];var _raise=Module["_raise"]=wasmExports["raise"];var _sigfillset=Module["_sigfillset"]=wasmExports["sigfillset"];var _pthread_sigmask=Module["_pthread_sigmask"]=wasmExports["pthread_sigmask"];var _PyOS_AfterFork=Module["_PyOS_AfterFork"]=wasmExports["PyOS_AfterFork"];var __PyLong_FromGid=Module["__PyLong_FromGid"]=wasmExports["_PyLong_FromGid"];var _sigemptyset=Module["_sigemptyset"]=wasmExports["sigemptyset"];var _sigaddset=Module["_sigaddset"]=wasmExports["sigaddset"];var _access=Module["_access"]=wasmExports["access"];var _ttyname_r=Module["_ttyname_r"]=wasmExports["ttyname_r"];var _fchdir=Module["_fchdir"]=wasmExports["fchdir"];var _fchmod=Module["_fchmod"]=wasmExports["fchmod"];var _fchmodat=Module["_fchmodat"]=wasmExports["fchmodat"];var _chmod=Module["_chmod"]=wasmExports["chmod"];var _fchown=Module["_fchown"]=wasmExports["fchown"];var _fchownat=Module["_fchownat"]=wasmExports["fchownat"];var _chown=Module["_chown"]=wasmExports["chown"];var _chroot=Module["_chroot"]=wasmExports["chroot"];var _ctermid=Module["_ctermid"]=wasmExports["ctermid"];var _fdopendir=Module["_fdopendir"]=wasmExports["fdopendir"];var _rewinddir=Module["_rewinddir"]=wasmExports["rewinddir"];var _mkdirat=Module["_mkdirat"]=wasmExports["mkdirat"];var _mkdir=Module["_mkdir"]=wasmExports["mkdir"];var _getpriority=Module["_getpriority"]=wasmExports["getpriority"];var _readlinkat=Module["_readlinkat"]=wasmExports["readlinkat"];var _unlinkat=Module["_unlinkat"]=wasmExports["unlinkat"];var _rmdir=Module["_rmdir"]=wasmExports["rmdir"];var _symlink=Module["_symlink"]=wasmExports["symlink"];var _system=Module["_system"]=wasmExports["system"];var _uname=Module["_uname"]=wasmExports["uname"];var _futimesat=Module["_futimesat"]=wasmExports["futimesat"];var _futimens=Module["_futimens"]=wasmExports["futimens"];var _times=Module["_times"]=wasmExports["times"];var _fexecve=Module["_fexecve"]=wasmExports["fexecve"];var _posix_openpt=Module["_posix_openpt"]=wasmExports["posix_openpt"];var _grantpt=Module["_grantpt"]=wasmExports["grantpt"];var _unlockpt=Module["_unlockpt"]=wasmExports["unlockpt"];var _ptsname_r=Module["_ptsname_r"]=wasmExports["ptsname_r"];var _login_tty=Module["_login_tty"]=wasmExports["login_tty"];var _getgid=Module["_getgid"]=wasmExports["getgid"];var _getpgrp=Module["_getpgrp"]=wasmExports["getpgrp"];var _getppid=Module["_getppid"]=wasmExports["getppid"];var _getuid=Module["_getuid"]=wasmExports["getuid"];var _getlogin=Module["_getlogin"]=wasmExports["getlogin"];var _killpg=Module["_killpg"]=wasmExports["killpg"];var _setuid=Module["_setuid"]=wasmExports["setuid"];var _setgid=Module["_setgid"]=wasmExports["setgid"];var _getpgid=Module["_getpgid"]=wasmExports["getpgid"];var _setpgrp=Module["_setpgrp"]=wasmExports["setpgrp"];var _wait=Module["_wait"]=wasmExports["wait"];var _wait3=Module["_wait3"]=wasmExports["wait3"];var _wait4=Module["_wait4"]=wasmExports["wait4"];var _waitid=Module["_waitid"]=wasmExports["waitid"];var _waitpid=Module["_waitpid"]=wasmExports["waitpid"];var _getsid=Module["_getsid"]=wasmExports["getsid"];var _tcgetpgrp=Module["_tcgetpgrp"]=wasmExports["tcgetpgrp"];var _tcsetpgrp=Module["_tcsetpgrp"]=wasmExports["tcsetpgrp"];var _openat=Module["_openat"]=wasmExports["openat"];var _dup3=Module["_dup3"]=wasmExports["dup3"];var _lockf=Module["_lockf"]=wasmExports["lockf"];var _readv=Module["_readv"]=wasmExports["readv"];var _pread=Module["_pread"]=wasmExports["pread"];var _writev=Module["_writev"]=wasmExports["writev"];var _pwrite=Module["_pwrite"]=wasmExports["pwrite"];var _pipe=Module["_pipe"]=wasmExports["pipe"];var _truncate=Module["_truncate"]=wasmExports["truncate"];var _posix_fadvise=Module["_posix_fadvise"]=wasmExports["posix_fadvise"];var _unsetenv=Module["_unsetenv"]=wasmExports["unsetenv"];var _fsync=Module["_fsync"]=wasmExports["fsync"];var _sync=Module["_sync"]=wasmExports["sync"];var _fdatasync=Module["_fdatasync"]=wasmExports["fdatasync"];var _fstatvfs=Module["_fstatvfs"]=wasmExports["fstatvfs"];var _statvfs=Module["_statvfs"]=wasmExports["statvfs"];var _fpathconf=Module["_fpathconf"]=wasmExports["fpathconf"];var _pathconf=Module["_pathconf"]=wasmExports["pathconf"];var _getloadavg=Module["_getloadavg"]=wasmExports["getloadavg"];var _lstat=Module["_lstat"]=wasmExports["lstat"];var _fstatat=Module["_fstatat"]=wasmExports["fstatat"];var _renameat=Module["_renameat"]=wasmExports["renameat"];var _rename=Module["_rename"]=wasmExports["rename"];var _unlink=Module["_unlink"]=wasmExports["unlink"];var _utimes=Module["_utimes"]=wasmExports["utimes"];var _qsort=Module["_qsort"]=wasmExports["qsort"];var _PySignal_SetWakeupFd=Module["_PySignal_SetWakeupFd"]=wasmExports["PySignal_SetWakeupFd"];var __PyErr_CheckSignals=Module["__PyErr_CheckSignals"]=wasmExports["_PyErr_CheckSignals"];var _PyErr_SetInterrupt=Module["_PyErr_SetInterrupt"]=wasmExports["PyErr_SetInterrupt"];var _PyOS_InterruptOccurred=Module["_PyOS_InterruptOccurred"]=wasmExports["PyOS_InterruptOccurred"];var __PyOS_IsMainThread=Module["__PyOS_IsMainThread"]=wasmExports["_PyOS_IsMainThread"];var _getitimer=Module["_getitimer"]=wasmExports["getitimer"];var _strsignal=Module["_strsignal"]=wasmExports["strsignal"];var _pause=Module["_pause"]=wasmExports["pause"];var _sigpending=Module["_sigpending"]=wasmExports["sigpending"];var _sigwait=Module["_sigwait"]=wasmExports["sigwait"];var _sigwaitinfo=Module["_sigwaitinfo"]=wasmExports["sigwaitinfo"];var _sigtimedwait=Module["_sigtimedwait"]=wasmExports["sigtimedwait"];var _sigismember=Module["_sigismember"]=wasmExports["sigismember"];var ___libc_current_sigrtmin=Module["___libc_current_sigrtmin"]=wasmExports["__libc_current_sigrtmin"];var ___libc_current_sigrtmax=Module["___libc_current_sigrtmax"]=wasmExports["__libc_current_sigrtmax"];var _isalnum=Module["_isalnum"]=wasmExports["isalnum"];var _tolower=Module["_tolower"]=wasmExports["tolower"];var _toupper=Module["_toupper"]=wasmExports["toupper"];var _clock_settime=Module["_clock_settime"]=wasmExports["clock_settime"];var _pthread_getcpuclockid=Module["_pthread_getcpuclockid"]=wasmExports["pthread_getcpuclockid"];var _clock_nanosleep=Module["_clock_nanosleep"]=wasmExports["clock_nanosleep"];var _time=Module["_time"]=wasmExports["time"];var _mktime=Module["_mktime"]=wasmExports["mktime"];var _wcsftime=Module["_wcsftime"]=wasmExports["wcsftime"];var _clock=Module["_clock"]=wasmExports["clock"];var _wcscoll=Module["_wcscoll"]=wasmExports["wcscoll"];var _wcsxfrm=Module["_wcsxfrm"]=wasmExports["wcsxfrm"];var _gettext=Module["_gettext"]=wasmExports["gettext"];var _dgettext=Module["_dgettext"]=wasmExports["dgettext"];var _dcgettext=Module["_dcgettext"]=wasmExports["dcgettext"];var _textdomain=Module["_textdomain"]=wasmExports["textdomain"];var _bindtextdomain=Module["_bindtextdomain"]=wasmExports["bindtextdomain"];var _bind_textdomain_codeset=Module["_bind_textdomain_codeset"]=wasmExports["bind_textdomain_codeset"];var _gettimeofday=Module["_gettimeofday"]=wasmExports["gettimeofday"];var ___small_fprintf=Module["___small_fprintf"]=wasmExports["__small_fprintf"];var __Py_Get_Getpath_CodeObject=Module["__Py_Get_Getpath_CodeObject"]=wasmExports["_Py_Get_Getpath_CodeObject"];var _ffi_prep_closure=Module["_ffi_prep_closure"]=wasmExports["ffi_prep_closure"];var _ffi_get_struct_offsets=Module["_ffi_get_struct_offsets"]=wasmExports["ffi_get_struct_offsets"];var _ffi_java_raw_size=Module["_ffi_java_raw_size"]=wasmExports["ffi_java_raw_size"];var _ffi_java_raw_to_ptrarray=Module["_ffi_java_raw_to_ptrarray"]=wasmExports["ffi_java_raw_to_ptrarray"];var _ffi_java_ptrarray_to_raw=Module["_ffi_java_ptrarray_to_raw"]=wasmExports["ffi_java_ptrarray_to_raw"];var _ffi_java_raw_call=Module["_ffi_java_raw_call"]=wasmExports["ffi_java_raw_call"];var _ffi_prep_java_raw_closure_loc=Module["_ffi_prep_java_raw_closure_loc"]=wasmExports["ffi_prep_java_raw_closure_loc"];var _ffi_prep_java_raw_closure=Module["_ffi_prep_java_raw_closure"]=wasmExports["ffi_prep_java_raw_closure"];var _ffi_tramp_is_supported=Module["_ffi_tramp_is_supported"]=wasmExports["ffi_tramp_is_supported"];var _ffi_tramp_alloc=Module["_ffi_tramp_alloc"]=wasmExports["ffi_tramp_alloc"];var _ffi_tramp_set_parms=Module["_ffi_tramp_set_parms"]=wasmExports["ffi_tramp_set_parms"];var _ffi_tramp_get_addr=Module["_ffi_tramp_get_addr"]=wasmExports["ffi_tramp_get_addr"];var _ffi_tramp_free=Module["_ffi_tramp_free"]=wasmExports["ffi_tramp_free"];var __hiwire_immortal_add=Module["__hiwire_immortal_add"]=wasmExports["_hiwire_immortal_add"];var __hiwire_immortal_get=Module["__hiwire_immortal_get"]=wasmExports["_hiwire_immortal_get"];var __hiwire_get=Module["__hiwire_get"]=wasmExports["_hiwire_get"];var __hiwire_set=Module["__hiwire_set"]=wasmExports["_hiwire_set"];var _hiwire_num_refs=Module["_hiwire_num_refs"]=wasmExports["hiwire_num_refs"];var __hiwire_slot_info=Module["__hiwire_slot_info"]=wasmExports["_hiwire_slot_info"];var __hiwire_delete=Module["__hiwire_delete"]=wasmExports["_hiwire_delete"];var __hiwire_immortal_table_init=Module["__hiwire_immortal_table_init"]=wasmExports["_hiwire_immortal_table_init"];var _emscripten_GetProcAddress=Module["_emscripten_GetProcAddress"]=wasmExports["emscripten_GetProcAddress"];var _emscripten_webgl1_get_proc_address=Module["_emscripten_webgl1_get_proc_address"]=wasmExports["emscripten_webgl1_get_proc_address"];var __webgl1_match_ext_proc_address_without_suffix=Module["__webgl1_match_ext_proc_address_without_suffix"]=wasmExports["_webgl1_match_ext_proc_address_without_suffix"];var _emscripten_webgl2_get_proc_address=Module["_emscripten_webgl2_get_proc_address"]=wasmExports["emscripten_webgl2_get_proc_address"];var __webgl2_match_ext_proc_address_without_suffix=Module["__webgl2_match_ext_proc_address_without_suffix"]=wasmExports["_webgl2_match_ext_proc_address_without_suffix"];var _emscripten_webgl_get_proc_address=Module["_emscripten_webgl_get_proc_address"]=wasmExports["emscripten_webgl_get_proc_address"];var _SDL_GL_GetProcAddress=Module["_SDL_GL_GetProcAddress"]=wasmExports["SDL_GL_GetProcAddress"];var _eglGetProcAddress=Module["_eglGetProcAddress"]=wasmExports["eglGetProcAddress"];var _glfwGetProcAddress=Module["_glfwGetProcAddress"]=wasmExports["glfwGetProcAddress"];var _emscripten_webgl_init_context_attributes=Module["_emscripten_webgl_init_context_attributes"]=wasmExports["emscripten_webgl_init_context_attributes"];var _emscripten_is_main_runtime_thread=Module["_emscripten_is_main_runtime_thread"]=wasmExports["emscripten_is_main_runtime_thread"];var _BZ2_blockSort=Module["_BZ2_blockSort"]=wasmExports["BZ2_blockSort"];var _BZ2_bz__AssertH__fail=Module["_BZ2_bz__AssertH__fail"]=wasmExports["BZ2_bz__AssertH__fail"];var _BZ2_bzlibVersion=Module["_BZ2_bzlibVersion"]=wasmExports["BZ2_bzlibVersion"];var _BZ2_compressBlock=Module["_BZ2_compressBlock"]=wasmExports["BZ2_compressBlock"];var _BZ2_indexIntoF=Module["_BZ2_indexIntoF"]=wasmExports["BZ2_indexIntoF"];var _BZ2_decompress=Module["_BZ2_decompress"]=wasmExports["BZ2_decompress"];var _BZ2_bzWriteOpen=Module["_BZ2_bzWriteOpen"]=wasmExports["BZ2_bzWriteOpen"];var _BZ2_bzWrite=Module["_BZ2_bzWrite"]=wasmExports["BZ2_bzWrite"];var _BZ2_bzWriteClose=Module["_BZ2_bzWriteClose"]=wasmExports["BZ2_bzWriteClose"];var _BZ2_bzWriteClose64=Module["_BZ2_bzWriteClose64"]=wasmExports["BZ2_bzWriteClose64"];var _BZ2_bzReadOpen=Module["_BZ2_bzReadOpen"]=wasmExports["BZ2_bzReadOpen"];var _BZ2_bzReadClose=Module["_BZ2_bzReadClose"]=wasmExports["BZ2_bzReadClose"];var _BZ2_bzRead=Module["_BZ2_bzRead"]=wasmExports["BZ2_bzRead"];var _fgetc=Module["_fgetc"]=wasmExports["fgetc"];var _BZ2_bzReadGetUnused=Module["_BZ2_bzReadGetUnused"]=wasmExports["BZ2_bzReadGetUnused"];var _BZ2_bzBuffToBuffCompress=Module["_BZ2_bzBuffToBuffCompress"]=wasmExports["BZ2_bzBuffToBuffCompress"];var _BZ2_bzBuffToBuffDecompress=Module["_BZ2_bzBuffToBuffDecompress"]=wasmExports["BZ2_bzBuffToBuffDecompress"];var _BZ2_bzopen=Module["_BZ2_bzopen"]=wasmExports["BZ2_bzopen"];var _BZ2_bzdopen=Module["_BZ2_bzdopen"]=wasmExports["BZ2_bzdopen"];var _BZ2_bzread=Module["_BZ2_bzread"]=wasmExports["BZ2_bzread"];var _BZ2_bzwrite=Module["_BZ2_bzwrite"]=wasmExports["BZ2_bzwrite"];var _BZ2_bzflush=Module["_BZ2_bzflush"]=wasmExports["BZ2_bzflush"];var _BZ2_bzclose=Module["_BZ2_bzclose"]=wasmExports["BZ2_bzclose"];var _BZ2_bzerror=Module["_BZ2_bzerror"]=wasmExports["BZ2_bzerror"];var _BZ2_bsInitWrite=Module["_BZ2_bsInitWrite"]=wasmExports["BZ2_bsInitWrite"];var _BZ2_hbMakeCodeLengths=Module["_BZ2_hbMakeCodeLengths"]=wasmExports["BZ2_hbMakeCodeLengths"];var _BZ2_hbAssignCodes=Module["_BZ2_hbAssignCodes"]=wasmExports["BZ2_hbAssignCodes"];var _BZ2_hbCreateDecodeTables=Module["_BZ2_hbCreateDecodeTables"]=wasmExports["BZ2_hbCreateDecodeTables"];var _adler32_z=Module["_adler32_z"]=wasmExports["adler32_z"];var _adler32_combine=Module["_adler32_combine"]=wasmExports["adler32_combine"];var _adler32_combine64=Module["_adler32_combine64"]=wasmExports["adler32_combine64"];var _compress2=Module["_compress2"]=wasmExports["compress2"];var _deflateInit_=Module["_deflateInit_"]=wasmExports["deflateInit_"];var _compress=Module["_compress"]=wasmExports["compress"];var _compressBound=Module["_compressBound"]=wasmExports["compressBound"];var _get_crc_table=Module["_get_crc_table"]=wasmExports["get_crc_table"];var _crc32_z=Module["_crc32_z"]=wasmExports["crc32_z"];var _crc32_combine64=Module["_crc32_combine64"]=wasmExports["crc32_combine64"];var _crc32_combine=Module["_crc32_combine"]=wasmExports["crc32_combine"];var _crc32_combine_gen64=Module["_crc32_combine_gen64"]=wasmExports["crc32_combine_gen64"];var _crc32_combine_gen=Module["_crc32_combine_gen"]=wasmExports["crc32_combine_gen"];var _crc32_combine_op=Module["_crc32_combine_op"]=wasmExports["crc32_combine_op"];var _zcalloc=Module["_zcalloc"]=wasmExports["zcalloc"];var _zcfree=Module["_zcfree"]=wasmExports["zcfree"];var _deflateReset=Module["_deflateReset"]=wasmExports["deflateReset"];var _deflateResetKeep=Module["_deflateResetKeep"]=wasmExports["deflateResetKeep"];var _deflateGetDictionary=Module["_deflateGetDictionary"]=wasmExports["deflateGetDictionary"];var __tr_init=Module["__tr_init"]=wasmExports["_tr_init"];var _deflateSetHeader=Module["_deflateSetHeader"]=wasmExports["deflateSetHeader"];var _deflatePending=Module["_deflatePending"]=wasmExports["deflatePending"];var _deflatePrime=Module["_deflatePrime"]=wasmExports["deflatePrime"];var __tr_flush_bits=Module["__tr_flush_bits"]=wasmExports["_tr_flush_bits"];var _deflateParams=Module["_deflateParams"]=wasmExports["deflateParams"];var __tr_align=Module["__tr_align"]=wasmExports["_tr_align"];var __tr_stored_block=Module["__tr_stored_block"]=wasmExports["_tr_stored_block"];var _deflateTune=Module["_deflateTune"]=wasmExports["deflateTune"];var _deflateBound=Module["_deflateBound"]=wasmExports["deflateBound"];var __tr_flush_block=Module["__tr_flush_block"]=wasmExports["_tr_flush_block"];var _gzclose=Module["_gzclose"]=wasmExports["gzclose"];var _gzclose_r=Module["_gzclose_r"]=wasmExports["gzclose_r"];var _gzclose_w=Module["_gzclose_w"]=wasmExports["gzclose_w"];var _gzopen=Module["_gzopen"]=wasmExports["gzopen"];var _gzopen64=Module["_gzopen64"]=wasmExports["gzopen64"];var _gzdopen=Module["_gzdopen"]=wasmExports["gzdopen"];var _gzbuffer=Module["_gzbuffer"]=wasmExports["gzbuffer"];var _gzrewind=Module["_gzrewind"]=wasmExports["gzrewind"];var _gzseek64=Module["_gzseek64"]=wasmExports["gzseek64"];var _gz_error=Module["_gz_error"]=wasmExports["gz_error"];var _gzseek=Module["_gzseek"]=wasmExports["gzseek"];var _gztell64=Module["_gztell64"]=wasmExports["gztell64"];var _gztell=Module["_gztell"]=wasmExports["gztell"];var _gzoffset64=Module["_gzoffset64"]=wasmExports["gzoffset64"];var _gzoffset=Module["_gzoffset"]=wasmExports["gzoffset"];var _gzeof=Module["_gzeof"]=wasmExports["gzeof"];var _gzerror=Module["_gzerror"]=wasmExports["gzerror"];var _gzclearerr=Module["_gzclearerr"]=wasmExports["gzclearerr"];var _gz_intmax=Module["_gz_intmax"]=wasmExports["gz_intmax"];var _gzread=Module["_gzread"]=wasmExports["gzread"];var _gzfread=Module["_gzfread"]=wasmExports["gzfread"];var _gzgetc=Module["_gzgetc"]=wasmExports["gzgetc"];var _gzgetc_=Module["_gzgetc_"]=wasmExports["gzgetc_"];var _gzungetc=Module["_gzungetc"]=wasmExports["gzungetc"];var _inflateReset=Module["_inflateReset"]=wasmExports["inflateReset"];var _gzgets=Module["_gzgets"]=wasmExports["gzgets"];var _gzdirect=Module["_gzdirect"]=wasmExports["gzdirect"];var _gzwrite=Module["_gzwrite"]=wasmExports["gzwrite"];var _gzfwrite=Module["_gzfwrite"]=wasmExports["gzfwrite"];var _gzputc=Module["_gzputc"]=wasmExports["gzputc"];var _gzputs=Module["_gzputs"]=wasmExports["gzputs"];var _gzvprintf=Module["_gzvprintf"]=wasmExports["gzvprintf"];var _gzprintf=Module["_gzprintf"]=wasmExports["gzprintf"];var _gzflush=Module["_gzflush"]=wasmExports["gzflush"];var _gzsetparams=Module["_gzsetparams"]=wasmExports["gzsetparams"];var _inflateBackInit_=Module["_inflateBackInit_"]=wasmExports["inflateBackInit_"];var _inflateBack=Module["_inflateBack"]=wasmExports["inflateBack"];var _inflate_table=Module["_inflate_table"]=wasmExports["inflate_table"];var _inflate_fast=Module["_inflate_fast"]=wasmExports["inflate_fast"];var _inflateBackEnd=Module["_inflateBackEnd"]=wasmExports["inflateBackEnd"];var _inflateResetKeep=Module["_inflateResetKeep"]=wasmExports["inflateResetKeep"];var _inflateReset2=Module["_inflateReset2"]=wasmExports["inflateReset2"];var _inflateInit_=Module["_inflateInit_"]=wasmExports["inflateInit_"];var _inflatePrime=Module["_inflatePrime"]=wasmExports["inflatePrime"];var _inflateGetDictionary=Module["_inflateGetDictionary"]=wasmExports["inflateGetDictionary"];var _inflateGetHeader=Module["_inflateGetHeader"]=wasmExports["inflateGetHeader"];var _inflateSync=Module["_inflateSync"]=wasmExports["inflateSync"];var _inflateSyncPoint=Module["_inflateSyncPoint"]=wasmExports["inflateSyncPoint"];var _inflateUndermine=Module["_inflateUndermine"]=wasmExports["inflateUndermine"];var _inflateValidate=Module["_inflateValidate"]=wasmExports["inflateValidate"];var _inflateMark=Module["_inflateMark"]=wasmExports["inflateMark"];var _inflateCodesUsed=Module["_inflateCodesUsed"]=wasmExports["inflateCodesUsed"];var __tr_tally=Module["__tr_tally"]=wasmExports["_tr_tally"];var _uncompress2=Module["_uncompress2"]=wasmExports["uncompress2"];var _uncompress=Module["_uncompress"]=wasmExports["uncompress"];var _zlibCompileFlags=Module["_zlibCompileFlags"]=wasmExports["zlibCompileFlags"];var _zError=Module["_zError"]=wasmExports["zError"];var _getdate=Module["_getdate"]=wasmExports["getdate"];var _stime=Module["_stime"]=wasmExports["stime"];var _clock_getcpuclockid=Module["_clock_getcpuclockid"]=wasmExports["clock_getcpuclockid"];var _getpwnam=Module["_getpwnam"]=wasmExports["getpwnam"];var _getpwuid=Module["_getpwuid"]=wasmExports["getpwuid"];var _getpwnam_r=Module["_getpwnam_r"]=wasmExports["getpwnam_r"];var _getpwuid_r=Module["_getpwuid_r"]=wasmExports["getpwuid_r"];var _setpwent=Module["_setpwent"]=wasmExports["setpwent"];var _endpwent=Module["_endpwent"]=wasmExports["endpwent"];var _getpwent=Module["_getpwent"]=wasmExports["getpwent"];var _getgrnam=Module["_getgrnam"]=wasmExports["getgrnam"];var _getgrgid=Module["_getgrgid"]=wasmExports["getgrgid"];var _getgrnam_r=Module["_getgrnam_r"]=wasmExports["getgrnam_r"];var _getgrgid_r=Module["_getgrgid_r"]=wasmExports["getgrgid_r"];var _getgrent=Module["_getgrent"]=wasmExports["getgrent"];var _endgrent=Module["_endgrent"]=wasmExports["endgrent"];var _setgrent=Module["_setgrent"]=wasmExports["setgrent"];var _flock=Module["_flock"]=wasmExports["flock"];var _vfork=Module["_vfork"]=wasmExports["vfork"];var _posix_spawn=Module["_posix_spawn"]=wasmExports["posix_spawn"];var _popen=Module["_popen"]=wasmExports["popen"];var _pclose=Module["_pclose"]=wasmExports["pclose"];var _setgroups=Module["_setgroups"]=wasmExports["setgroups"];var _sigaltstack=Module["_sigaltstack"]=wasmExports["sigaltstack"];var ___syscall_uname=Module["___syscall_uname"]=wasmExports["__syscall_uname"];var ___syscall_setpgid=Module["___syscall_setpgid"]=wasmExports["__syscall_setpgid"];var ___syscall_sync=Module["___syscall_sync"]=wasmExports["__syscall_sync"];var ___syscall_getsid=Module["___syscall_getsid"]=wasmExports["__syscall_getsid"];var ___syscall_getpgid=Module["___syscall_getpgid"]=wasmExports["__syscall_getpgid"];var ___syscall_getpid=Module["___syscall_getpid"]=wasmExports["__syscall_getpid"];var ___syscall_getppid=Module["___syscall_getppid"]=wasmExports["__syscall_getppid"];var ___syscall_linkat=Module["___syscall_linkat"]=wasmExports["__syscall_linkat"];var ___syscall_getgroups32=Module["___syscall_getgroups32"]=wasmExports["__syscall_getgroups32"];var ___syscall_setsid=Module["___syscall_setsid"]=wasmExports["__syscall_setsid"];var ___syscall_umask=Module["___syscall_umask"]=wasmExports["__syscall_umask"];var ___syscall_getrusage=Module["___syscall_getrusage"]=wasmExports["__syscall_getrusage"];var ___syscall_getpriority=Module["___syscall_getpriority"]=wasmExports["__syscall_getpriority"];var ___syscall_setpriority=Module["___syscall_setpriority"]=wasmExports["__syscall_setpriority"];var ___syscall_setdomainname=Module["___syscall_setdomainname"]=wasmExports["__syscall_setdomainname"];var ___syscall_getuid32=Module["___syscall_getuid32"]=wasmExports["__syscall_getuid32"];var ___syscall_getgid32=Module["___syscall_getgid32"]=wasmExports["__syscall_getgid32"];var ___syscall_geteuid32=Module["___syscall_geteuid32"]=wasmExports["__syscall_geteuid32"];var ___syscall_getegid32=Module["___syscall_getegid32"]=wasmExports["__syscall_getegid32"];var ___syscall_getresuid32=Module["___syscall_getresuid32"]=wasmExports["__syscall_getresuid32"];var ___syscall_getresgid32=Module["___syscall_getresgid32"]=wasmExports["__syscall_getresgid32"];var ___syscall_pause=Module["___syscall_pause"]=wasmExports["__syscall_pause"];var ___syscall_madvise=Module["___syscall_madvise"]=wasmExports["__syscall_madvise"];var ___syscall_mlock=Module["___syscall_mlock"]=wasmExports["__syscall_mlock"];var ___syscall_munlock=Module["___syscall_munlock"]=wasmExports["__syscall_munlock"];var ___syscall_mprotect=Module["___syscall_mprotect"]=wasmExports["__syscall_mprotect"];var ___syscall_mremap=Module["___syscall_mremap"]=wasmExports["__syscall_mremap"];var ___syscall_mlockall=Module["___syscall_mlockall"]=wasmExports["__syscall_mlockall"];var ___syscall_munlockall=Module["___syscall_munlockall"]=wasmExports["__syscall_munlockall"];var ___syscall_prlimit64=Module["___syscall_prlimit64"]=wasmExports["__syscall_prlimit64"];var _emscripten_stack_get_end=Module["_emscripten_stack_get_end"]=wasmExports["emscripten_stack_get_end"];var _emscripten_stack_get_base=Module["_emscripten_stack_get_base"]=wasmExports["emscripten_stack_get_base"];var ___syscall_setsockopt=Module["___syscall_setsockopt"]=wasmExports["__syscall_setsockopt"];var ___syscall_acct=Module["___syscall_acct"]=wasmExports["__syscall_acct"];var ___syscall_mincore=Module["___syscall_mincore"]=wasmExports["__syscall_mincore"];var ___syscall_pipe2=Module["___syscall_pipe2"]=wasmExports["__syscall_pipe2"];var ___syscall_pselect6=Module["___syscall_pselect6"]=wasmExports["__syscall_pselect6"];var ___syscall_recvmmsg=Module["___syscall_recvmmsg"]=wasmExports["__syscall_recvmmsg"];var ___syscall_sendmmsg=Module["___syscall_sendmmsg"]=wasmExports["__syscall_sendmmsg"];var ___syscall_shutdown=Module["___syscall_shutdown"]=wasmExports["__syscall_shutdown"];var ___syscall_socketpair=Module["___syscall_socketpair"]=wasmExports["__syscall_socketpair"];var ___syscall_wait4=Module["___syscall_wait4"]=wasmExports["__syscall_wait4"];var _cosf=Module["_cosf"]=wasmExports["cosf"];var _sinf=Module["_sinf"]=wasmExports["sinf"];var _expf=Module["_expf"]=wasmExports["expf"];var ___multf3=Module["___multf3"]=wasmExports["__multf3"];var ___addtf3=Module["___addtf3"]=wasmExports["__addtf3"];var ___subtf3=Module["___subtf3"]=wasmExports["__subtf3"];var ___ctype_b_loc=Module["___ctype_b_loc"]=wasmExports["__ctype_b_loc"];var ___ctype_get_mb_cur_max=Module["___ctype_get_mb_cur_max"]=wasmExports["__ctype_get_mb_cur_max"];var ___get_tp=Module["___get_tp"]=wasmExports["__get_tp"];var ___ctype_tolower_loc=Module["___ctype_tolower_loc"]=wasmExports["__ctype_tolower_loc"];var ___ctype_toupper_loc=Module["___ctype_toupper_loc"]=wasmExports["__ctype_toupper_loc"];var ___emscripten_environ_constructor=Module["___emscripten_environ_constructor"]=wasmExports["__emscripten_environ_constructor"];var _emscripten_builtin_malloc=Module["_emscripten_builtin_malloc"]=wasmExports["emscripten_builtin_malloc"];var ___flt_rounds=Module["___flt_rounds"]=wasmExports["__flt_rounds"];var _fegetround=Module["_fegetround"]=wasmExports["fegetround"];var ___fmodeflags=Module["___fmodeflags"]=wasmExports["__fmodeflags"];var ___fpclassify=Module["___fpclassify"]=wasmExports["__fpclassify"];var ___fpclassifyf=Module["___fpclassifyf"]=wasmExports["__fpclassifyf"];var ___fpclassifyl=Module["___fpclassifyl"]=wasmExports["__fpclassifyl"];var ___divtf3=Module["___divtf3"]=wasmExports["__divtf3"];var ___mo_lookup=Module["___mo_lookup"]=wasmExports["__mo_lookup"];var ___month_to_secs=Module["___month_to_secs"]=wasmExports["__month_to_secs"];var ___overflow=Module["___overflow"]=wasmExports["__overflow"];var _scalbn=Module["_scalbn"]=wasmExports["scalbn"];var _floor=Module["_floor"]=wasmExports["floor"];var ___lttf2=Module["___lttf2"]=wasmExports["__lttf2"];var ___fixtfdi=Module["___fixtfdi"]=wasmExports["__fixtfdi"];var ___gttf2=Module["___gttf2"]=wasmExports["__gttf2"];var ___fixtfsi=Module["___fixtfsi"]=wasmExports["__fixtfsi"];var ___floatsitf=Module["___floatsitf"]=wasmExports["__floatsitf"];var ___signbit=Module["___signbit"]=wasmExports["__signbit"];var ___signbitf=Module["___signbitf"]=wasmExports["__signbitf"];var ___signbitl=Module["___signbitl"]=wasmExports["__signbitl"];var _memcpy=wasmExports["memcpy"];var ___stack_chk_fail=Module["___stack_chk_fail"]=wasmExports["__stack_chk_fail"];var ___wasi_syscall_ret=Module["___wasi_syscall_ret"]=wasmExports["__wasi_syscall_ret"];var ___synccall=Module["___synccall"]=wasmExports["__synccall"];var _fabsl=Module["_fabsl"]=wasmExports["fabsl"];var ___getf2=Module["___getf2"]=wasmExports["__getf2"];var ___year_to_secs=Module["___year_to_secs"]=wasmExports["__year_to_secs"];var ___lock=Module["___lock"]=wasmExports["__lock"];var ___unlock=Module["___unlock"]=wasmExports["__unlock"];var _tzset=Module["_tzset"]=wasmExports["tzset"];var ___uflow=Module["___uflow"]=wasmExports["__uflow"];var ___fxstat=Module["___fxstat"]=wasmExports["__fxstat"];var ___fxstatat=Module["___fxstatat"]=wasmExports["__fxstatat"];var ___lxstat=Module["___lxstat"]=wasmExports["__lxstat"];var ___xstat=Module["___xstat"]=wasmExports["__xstat"];var ___xmknod=Module["___xmknod"]=wasmExports["__xmknod"];var _mknod=Module["_mknod"]=wasmExports["mknod"];var ___xmknodat=Module["___xmknodat"]=wasmExports["__xmknodat"];var _mknodat=Module["_mknodat"]=wasmExports["mknodat"];var __Exit=Module["__Exit"]=wasmExports["_Exit"];var _a64l=Module["_a64l"]=wasmExports["a64l"];var _l64a=Module["_l64a"]=wasmExports["l64a"];var _abs=Module["_abs"]=wasmExports["abs"];var _acct=Module["_acct"]=wasmExports["acct"];var _acosf=Module["_acosf"]=wasmExports["acosf"];var _sqrtf=Module["_sqrtf"]=wasmExports["sqrtf"];var _acoshf=Module["_acoshf"]=wasmExports["acoshf"];var _log1pf=Module["_log1pf"]=wasmExports["log1pf"];var _logf=Module["_logf"]=wasmExports["logf"];var _acoshl=Module["_acoshl"]=wasmExports["acoshl"];var _acosl=Module["_acosl"]=wasmExports["acosl"];var ___eqtf2=Module["___eqtf2"]=wasmExports["__eqtf2"];var ___netf2=Module["___netf2"]=wasmExports["__netf2"];var _sqrtl=Module["_sqrtl"]=wasmExports["sqrtl"];var _alarm=Module["_alarm"]=wasmExports["alarm"];var _setitimer=Module["_setitimer"]=wasmExports["setitimer"];var _aligned_alloc=Module["_aligned_alloc"]=wasmExports["aligned_alloc"];var _posix_memalign=Module["_posix_memalign"]=wasmExports["posix_memalign"];var _alphasort=Module["_alphasort"]=wasmExports["alphasort"];var _strcoll=Module["_strcoll"]=wasmExports["strcoll"];var _asctime=Module["_asctime"]=wasmExports["asctime"];var ___nl_langinfo_l=Module["___nl_langinfo_l"]=wasmExports["__nl_langinfo_l"];var _asctime_r=Module["_asctime_r"]=wasmExports["asctime_r"];var _asinf=Module["_asinf"]=wasmExports["asinf"];var _fabsf=Module["_fabsf"]=wasmExports["fabsf"];var _asinhf=Module["_asinhf"]=wasmExports["asinhf"];var _asinhl=Module["_asinhl"]=wasmExports["asinhl"];var _asinl=Module["_asinl"]=wasmExports["asinl"];var _asprintf=Module["_asprintf"]=wasmExports["asprintf"];var _vasprintf=Module["_vasprintf"]=wasmExports["vasprintf"];var _at_quick_exit=Module["_at_quick_exit"]=wasmExports["at_quick_exit"];var _atan2f=Module["_atan2f"]=wasmExports["atan2f"];var _atanf=Module["_atanf"]=wasmExports["atanf"];var _atan2l=Module["_atan2l"]=wasmExports["atan2l"];var _atanl=Module["_atanl"]=wasmExports["atanl"];var _atanhf=Module["_atanhf"]=wasmExports["atanhf"];var _atanhl=Module["_atanhl"]=wasmExports["atanhl"];var _log1pl=Module["_log1pl"]=wasmExports["log1pl"];var ___funcs_on_exit=wasmExports["__funcs_on_exit"];var ____cxa_finalize=Module["____cxa_finalize"]=wasmExports["___cxa_finalize"];var ____cxa_atexit=Module["____cxa_atexit"]=wasmExports["___cxa_atexit"];var ___libc_calloc=Module["___libc_calloc"]=wasmExports["__libc_calloc"];var ___atexit=Module["___atexit"]=wasmExports["__atexit"];var ___cxa_atexit=Module["___cxa_atexit"]=wasmExports["__cxa_atexit"];var ___cxa_finalize=Module["___cxa_finalize"]=wasmExports["__cxa_finalize"];var _atof=Module["_atof"]=wasmExports["atof"];var _strtod=Module["_strtod"]=wasmExports["strtod"];var _atoi=Module["_atoi"]=wasmExports["atoi"];var _atol=Module["_atol"]=wasmExports["atol"];var _atoll=Module["_atoll"]=wasmExports["atoll"];var _basename=Module["_basename"]=wasmExports["basename"];var ___xpg_basename=Module["___xpg_basename"]=wasmExports["__xpg_basename"];var _bcmp=Module["_bcmp"]=wasmExports["bcmp"];var _bcopy=Module["_bcopy"]=wasmExports["bcopy"];var _strcasecmp=Module["_strcasecmp"]=wasmExports["strcasecmp"];var _bsearch=Module["_bsearch"]=wasmExports["bsearch"];var _btowc=Module["_btowc"]=wasmExports["btowc"];var _bzero=Module["_bzero"]=wasmExports["bzero"];var _c16rtomb=Module["_c16rtomb"]=wasmExports["c16rtomb"];var _wcrtomb=Module["_wcrtomb"]=wasmExports["wcrtomb"];var _c32rtomb=Module["_c32rtomb"]=wasmExports["c32rtomb"];var _cabs=Module["_cabs"]=wasmExports["cabs"];var _cabsf=Module["_cabsf"]=wasmExports["cabsf"];var _hypotf=Module["_hypotf"]=wasmExports["hypotf"];var _cabsl=Module["_cabsl"]=wasmExports["cabsl"];var _hypotl=Module["_hypotl"]=wasmExports["hypotl"];var _cacos=Module["_cacos"]=wasmExports["cacos"];var _casin=Module["_casin"]=wasmExports["casin"];var _cacosf=Module["_cacosf"]=wasmExports["cacosf"];var _casinf=Module["_casinf"]=wasmExports["casinf"];var _cacosh=Module["_cacosh"]=wasmExports["cacosh"];var _cacoshf=Module["_cacoshf"]=wasmExports["cacoshf"];var _cacoshl=Module["_cacoshl"]=wasmExports["cacoshl"];var _cacosl=Module["_cacosl"]=wasmExports["cacosl"];var _casinl=Module["_casinl"]=wasmExports["casinl"];var _call_once=Module["_call_once"]=wasmExports["call_once"];var _carg=Module["_carg"]=wasmExports["carg"];var _cargf=Module["_cargf"]=wasmExports["cargf"];var _cargl=Module["_cargl"]=wasmExports["cargl"];var _csqrt=Module["_csqrt"]=wasmExports["csqrt"];var _clog=Module["_clog"]=wasmExports["clog"];var _csqrtf=Module["_csqrtf"]=wasmExports["csqrtf"];var _clogf=Module["_clogf"]=wasmExports["clogf"];var _casinh=Module["_casinh"]=wasmExports["casinh"];var _casinhf=Module["_casinhf"]=wasmExports["casinhf"];var _casinhl=Module["_casinhl"]=wasmExports["casinhl"];var _csqrtl=Module["_csqrtl"]=wasmExports["csqrtl"];var _clogl=Module["_clogl"]=wasmExports["clogl"];var _catan=Module["_catan"]=wasmExports["catan"];var _catanf=Module["_catanf"]=wasmExports["catanf"];var _catanh=Module["_catanh"]=wasmExports["catanh"];var _catanhf=Module["_catanhf"]=wasmExports["catanhf"];var _catanhl=Module["_catanhl"]=wasmExports["catanhl"];var _catanl=Module["_catanl"]=wasmExports["catanl"];var _logl=Module["_logl"]=wasmExports["logl"];var ___trunctfsf2=Module["___trunctfsf2"]=wasmExports["__trunctfsf2"];var ___extendsftf2=Module["___extendsftf2"]=wasmExports["__extendsftf2"];var _catclose=Module["_catclose"]=wasmExports["catclose"];var _catgets=Module["_catgets"]=wasmExports["catgets"];var _catopen=Module["_catopen"]=wasmExports["catopen"];var _cbrtf=Module["_cbrtf"]=wasmExports["cbrtf"];var _cbrtl=Module["_cbrtl"]=wasmExports["cbrtl"];var _ccos=Module["_ccos"]=wasmExports["ccos"];var _ccosh=Module["_ccosh"]=wasmExports["ccosh"];var _ccosf=Module["_ccosf"]=wasmExports["ccosf"];var _ccoshf=Module["_ccoshf"]=wasmExports["ccoshf"];var _coshf=Module["_coshf"]=wasmExports["coshf"];var _sinhf=Module["_sinhf"]=wasmExports["sinhf"];var _copysignf=Module["_copysignf"]=wasmExports["copysignf"];var _ccoshl=Module["_ccoshl"]=wasmExports["ccoshl"];var _ccosl=Module["_ccosl"]=wasmExports["ccosl"];var _ceil=Module["_ceil"]=wasmExports["ceil"];var _ceilf=Module["_ceilf"]=wasmExports["ceilf"];var _ceill=Module["_ceill"]=wasmExports["ceill"];var _cexp=Module["_cexp"]=wasmExports["cexp"];var _cexpf=Module["_cexpf"]=wasmExports["cexpf"];var _cexpl=Module["_cexpl"]=wasmExports["cexpl"];var _cfgetospeed=Module["_cfgetospeed"]=wasmExports["cfgetospeed"];var _cfgetispeed=Module["_cfgetispeed"]=wasmExports["cfgetispeed"];var _cfmakeraw=Module["_cfmakeraw"]=wasmExports["cfmakeraw"];var _cfsetospeed=Module["_cfsetospeed"]=wasmExports["cfsetospeed"];var _cfsetispeed=Module["_cfsetispeed"]=wasmExports["cfsetispeed"];var _cfsetspeed=Module["_cfsetspeed"]=wasmExports["cfsetspeed"];var _cimag=Module["_cimag"]=wasmExports["cimag"];var _cimagf=Module["_cimagf"]=wasmExports["cimagf"];var _cimagl=Module["_cimagl"]=wasmExports["cimagl"];var _clearenv=Module["_clearenv"]=wasmExports["clearenv"];var _clearerr_unlocked=Module["_clearerr_unlocked"]=wasmExports["clearerr_unlocked"];var ___wasi_timestamp_to_timespec=Module["___wasi_timestamp_to_timespec"]=wasmExports["__wasi_timestamp_to_timespec"];var _emscripten_thread_sleep=Module["_emscripten_thread_sleep"]=wasmExports["emscripten_thread_sleep"];var _cnd_broadcast=Module["_cnd_broadcast"]=wasmExports["cnd_broadcast"];var _cnd_destroy=Module["_cnd_destroy"]=wasmExports["cnd_destroy"];var _cnd_init=Module["_cnd_init"]=wasmExports["cnd_init"];var _cnd_signal=Module["_cnd_signal"]=wasmExports["cnd_signal"];var _cnd_timedwait=Module["_cnd_timedwait"]=wasmExports["cnd_timedwait"];var _cnd_wait=Module["_cnd_wait"]=wasmExports["cnd_wait"];var _conj=Module["_conj"]=wasmExports["conj"];var _conjf=Module["_conjf"]=wasmExports["conjf"];var _conjl=Module["_conjl"]=wasmExports["conjl"];var _copysignl=Module["_copysignl"]=wasmExports["copysignl"];var _expm1f=Module["_expm1f"]=wasmExports["expm1f"];var _coshl=Module["_coshl"]=wasmExports["coshl"];var _cosl=Module["_cosl"]=wasmExports["cosl"];var _cpow=Module["_cpow"]=wasmExports["cpow"];var ___muldc3=Module["___muldc3"]=wasmExports["__muldc3"];var _cpowf=Module["_cpowf"]=wasmExports["cpowf"];var ___mulsc3=Module["___mulsc3"]=wasmExports["__mulsc3"];var _cpowl=Module["_cpowl"]=wasmExports["cpowl"];var ___unordtf2=Module["___unordtf2"]=wasmExports["__unordtf2"];var ___multc3=Module["___multc3"]=wasmExports["__multc3"];var _cproj=Module["_cproj"]=wasmExports["cproj"];var _cprojf=Module["_cprojf"]=wasmExports["cprojf"];var _cprojl=Module["_cprojl"]=wasmExports["cprojl"];var _creal=Module["_creal"]=wasmExports["creal"];var _crealf=Module["_crealf"]=wasmExports["crealf"];var _creall=Module["_creall"]=wasmExports["creall"];var _creat=Module["_creat"]=wasmExports["creat"];var _crypt=Module["_crypt"]=wasmExports["crypt"];var ___crypt_blowfish=Module["___crypt_blowfish"]=wasmExports["__crypt_blowfish"];var ___crypt_des=Module["___crypt_des"]=wasmExports["__crypt_des"];var ___crypt_md5=Module["___crypt_md5"]=wasmExports["__crypt_md5"];var _strnlen=Module["_strnlen"]=wasmExports["strnlen"];var ___crypt_sha256=Module["___crypt_sha256"]=wasmExports["__crypt_sha256"];var ___crypt_sha512=Module["___crypt_sha512"]=wasmExports["__crypt_sha512"];var _crypt_r=Module["_crypt_r"]=wasmExports["crypt_r"];var _sprintf=Module["_sprintf"]=wasmExports["sprintf"];var _csin=Module["_csin"]=wasmExports["csin"];var _csinh=Module["_csinh"]=wasmExports["csinh"];var _csinf=Module["_csinf"]=wasmExports["csinf"];var _csinhf=Module["_csinhf"]=wasmExports["csinhf"];var _csinhl=Module["_csinhl"]=wasmExports["csinhl"];var _csinl=Module["_csinl"]=wasmExports["csinl"];var _ctan=Module["_ctan"]=wasmExports["ctan"];var _ctanh=Module["_ctanh"]=wasmExports["ctanh"];var _ctanf=Module["_ctanf"]=wasmExports["ctanf"];var _ctanhf=Module["_ctanhf"]=wasmExports["ctanhf"];var _tanf=Module["_tanf"]=wasmExports["tanf"];var _ctanhl=Module["_ctanhl"]=wasmExports["ctanhl"];var _ctanl=Module["_ctanl"]=wasmExports["ctanl"];var _ctime=Module["_ctime"]=wasmExports["ctime"];var _localtime=Module["_localtime"]=wasmExports["localtime"];var _ctime_r=Module["_ctime_r"]=wasmExports["ctime_r"];var _dcngettext=Module["_dcngettext"]=wasmExports["dcngettext"];var ___gettextdomain=Module["___gettextdomain"]=wasmExports["__gettextdomain"];var _dngettext=Module["_dngettext"]=wasmExports["dngettext"];var _difftime=Module["_difftime"]=wasmExports["difftime"];var _dirname=Module["_dirname"]=wasmExports["dirname"];var _div=Module["_div"]=wasmExports["div"];var _dladdr=Module["_dladdr"]=wasmExports["dladdr"];var ___libc_free=Module["___libc_free"]=wasmExports["__libc_free"];var ___libc_malloc=Module["___libc_malloc"]=wasmExports["__libc_malloc"];var ___dl_seterr=wasmExports["__dl_seterr"];var _dn_comp=Module["_dn_comp"]=wasmExports["dn_comp"];var _dn_expand=Module["_dn_expand"]=wasmExports["dn_expand"];var _dn_skipname=Module["_dn_skipname"]=wasmExports["dn_skipname"];var _dprintf=Module["_dprintf"]=wasmExports["dprintf"];var _vdprintf=Module["_vdprintf"]=wasmExports["vdprintf"];var _erand48=Module["_erand48"]=wasmExports["erand48"];var _drand48=Module["_drand48"]=wasmExports["drand48"];var ___wasi_fd_is_valid=Module["___wasi_fd_is_valid"]=wasmExports["__wasi_fd_is_valid"];var ___duplocale=Module["___duplocale"]=wasmExports["__duplocale"];var _duplocale=Module["_duplocale"]=wasmExports["duplocale"];var _new_dlevent=Module["_new_dlevent"]=wasmExports["new_dlevent"];var __emscripten_find_dylib=wasmExports["_emscripten_find_dylib"];var _strspn=Module["_strspn"]=wasmExports["strspn"];var _pthread_setcancelstate=Module["_pthread_setcancelstate"]=wasmExports["pthread_setcancelstate"];var _emscripten_dlopen=Module["_emscripten_dlopen"]=wasmExports["emscripten_dlopen"];var _emscripten_dlopen_promise=Module["_emscripten_dlopen_promise"]=wasmExports["emscripten_dlopen_promise"];var _ecvt=Module["_ecvt"]=wasmExports["ecvt"];var _emscripten_console_logf=Module["_emscripten_console_logf"]=wasmExports["emscripten_console_logf"];var _emscripten_console_errorf=Module["_emscripten_console_errorf"]=wasmExports["emscripten_console_errorf"];var _emscripten_console_warnf=Module["_emscripten_console_warnf"]=wasmExports["emscripten_console_warnf"];var _emscripten_console_tracef=Module["_emscripten_console_tracef"]=wasmExports["emscripten_console_tracef"];var _emscripten_outf=Module["_emscripten_outf"]=wasmExports["emscripten_outf"];var _emscripten_errf=Module["_emscripten_errf"]=wasmExports["emscripten_errf"];var _emscripten_fiber_init=Module["_emscripten_fiber_init"]=wasmExports["emscripten_fiber_init"];var _emscripten_fiber_init_from_current_context=Module["_emscripten_fiber_init_from_current_context"]=wasmExports["emscripten_fiber_init_from_current_context"];var _emscripten_get_heap_size=Module["_emscripten_get_heap_size"]=wasmExports["emscripten_get_heap_size"];var __emscripten_memcpy_bulkmem=Module["__emscripten_memcpy_bulkmem"]=wasmExports["_emscripten_memcpy_bulkmem"];var _emscripten_builtin_memcpy=Module["_emscripten_builtin_memcpy"]=wasmExports["emscripten_builtin_memcpy"];var ___memset=Module["___memset"]=wasmExports["__memset"];var _emscripten_builtin_memset=Module["_emscripten_builtin_memset"]=wasmExports["emscripten_builtin_memset"];var __emscripten_memset_bulkmem=Module["__emscripten_memset_bulkmem"]=wasmExports["_emscripten_memset_bulkmem"];var ___syscall_munmap=Module["___syscall_munmap"]=wasmExports["__syscall_munmap"];var _emscripten_builtin_free=Module["_emscripten_builtin_free"]=wasmExports["emscripten_builtin_free"];var ___syscall_msync=Module["___syscall_msync"]=wasmExports["__syscall_msync"];var ___syscall_mmap2=Module["___syscall_mmap2"]=wasmExports["__syscall_mmap2"];var _emscripten_builtin_memalign=wasmExports["emscripten_builtin_memalign"];var _emscripten_scan_stack=Module["_emscripten_scan_stack"]=wasmExports["emscripten_scan_stack"];var _emscripten_stack_get_current=Module["_emscripten_stack_get_current"]=wasmExports["emscripten_stack_get_current"];var ___time=Module["___time"]=wasmExports["__time"];var ___gettimeofday=Module["___gettimeofday"]=wasmExports["__gettimeofday"];var _dysize=Module["_dysize"]=wasmExports["dysize"];var _setkey=Module["_setkey"]=wasmExports["setkey"];var _encrypt=Module["_encrypt"]=wasmExports["encrypt"];var _sethostent=Module["_sethostent"]=wasmExports["sethostent"];var _gethostent=Module["_gethostent"]=wasmExports["gethostent"];var _getnetent=Module["_getnetent"]=wasmExports["getnetent"];var _endhostent=Module["_endhostent"]=wasmExports["endhostent"];var _setnetent=Module["_setnetent"]=wasmExports["setnetent"];var _endnetent=Module["_endnetent"]=wasmExports["endnetent"];var _erff=Module["_erff"]=wasmExports["erff"];var _erfcf=Module["_erfcf"]=wasmExports["erfcf"];var _erfl=Module["_erfl"]=wasmExports["erfl"];var _erfcl=Module["_erfcl"]=wasmExports["erfcl"];var _vwarn=Module["_vwarn"]=wasmExports["vwarn"];var _fprintf=Module["_fprintf"]=wasmExports["fprintf"];var _vwarnx=Module["_vwarnx"]=wasmExports["vwarnx"];var _putc=Module["_putc"]=wasmExports["putc"];var _verr=Module["_verr"]=wasmExports["verr"];var _verrx=Module["_verrx"]=wasmExports["verrx"];var _warn=Module["_warn"]=wasmExports["warn"];var _warnx=Module["_warnx"]=wasmExports["warnx"];var _err=Module["_err"]=wasmExports["err"];var _errx=Module["_errx"]=wasmExports["errx"];var _ether_aton_r=Module["_ether_aton_r"]=wasmExports["ether_aton_r"];var _ether_aton=Module["_ether_aton"]=wasmExports["ether_aton"];var _ether_ntoa_r=Module["_ether_ntoa_r"]=wasmExports["ether_ntoa_r"];var _ether_ntoa=Module["_ether_ntoa"]=wasmExports["ether_ntoa"];var _ether_line=Module["_ether_line"]=wasmExports["ether_line"];var _ether_ntohost=Module["_ether_ntohost"]=wasmExports["ether_ntohost"];var _ether_hostton=Module["_ether_hostton"]=wasmExports["ether_hostton"];var _euidaccess=Module["_euidaccess"]=wasmExports["euidaccess"];var _faccessat=Module["_faccessat"]=wasmExports["faccessat"];var _eaccess=Module["_eaccess"]=wasmExports["eaccess"];var _execl=Module["_execl"]=wasmExports["execl"];var _execle=Module["_execle"]=wasmExports["execle"];var _execlp=Module["_execlp"]=wasmExports["execlp"];var _execvp=Module["_execvp"]=wasmExports["execvp"];var _execvpe=Module["_execvpe"]=wasmExports["execvpe"];var _exp10=Module["_exp10"]=wasmExports["exp10"];var _pow10=Module["_pow10"]=wasmExports["pow10"];var _exp10f=Module["_exp10f"]=wasmExports["exp10f"];var _modff=Module["_modff"]=wasmExports["modff"];var _exp2f=Module["_exp2f"]=wasmExports["exp2f"];var _pow10f=Module["_pow10f"]=wasmExports["pow10f"];var _exp10l=Module["_exp10l"]=wasmExports["exp10l"];var _modfl=Module["_modfl"]=wasmExports["modfl"];var _exp2l=Module["_exp2l"]=wasmExports["exp2l"];var _powl=Module["_powl"]=wasmExports["powl"];var _pow10l=Module["_pow10l"]=wasmExports["pow10l"];var ___letf2=Module["___letf2"]=wasmExports["__letf2"];var _scalbnl=Module["_scalbnl"]=wasmExports["scalbnl"];var _expl=Module["_expl"]=wasmExports["expl"];var _expm1l=Module["_expm1l"]=wasmExports["expm1l"];var __flushlbf=Module["__flushlbf"]=wasmExports["_flushlbf"];var ___fsetlocking=Module["___fsetlocking"]=wasmExports["__fsetlocking"];var ___fwriting=Module["___fwriting"]=wasmExports["__fwriting"];var ___freading=Module["___freading"]=wasmExports["__freading"];var ___freadable=Module["___freadable"]=wasmExports["__freadable"];var ___fwritable=Module["___fwritable"]=wasmExports["__fwritable"];var ___flbf=Module["___flbf"]=wasmExports["__flbf"];var ___fbufsize=Module["___fbufsize"]=wasmExports["__fbufsize"];var ___fpending=Module["___fpending"]=wasmExports["__fpending"];var ___fpurge=Module["___fpurge"]=wasmExports["__fpurge"];var _fpurge=Module["_fpurge"]=wasmExports["fpurge"];var ___freadahead=Module["___freadahead"]=wasmExports["__freadahead"];var ___freadptr=Module["___freadptr"]=wasmExports["__freadptr"];var ___freadptrinc=Module["___freadptrinc"]=wasmExports["__freadptrinc"];var ___fseterr=Module["___fseterr"]=wasmExports["__fseterr"];var _fcvt=Module["_fcvt"]=wasmExports["fcvt"];var _fdim=Module["_fdim"]=wasmExports["fdim"];var _fdimf=Module["_fdimf"]=wasmExports["fdimf"];var _fdiml=Module["_fdiml"]=wasmExports["fdiml"];var _fegetexceptflag=Module["_fegetexceptflag"]=wasmExports["fegetexceptflag"];var _fetestexcept=Module["_fetestexcept"]=wasmExports["fetestexcept"];var _feholdexcept=Module["_feholdexcept"]=wasmExports["feholdexcept"];var _fegetenv=Module["_fegetenv"]=wasmExports["fegetenv"];var _feclearexcept=Module["_feclearexcept"]=wasmExports["feclearexcept"];var _feraiseexcept=Module["_feraiseexcept"]=wasmExports["feraiseexcept"];var ___fesetround=Module["___fesetround"]=wasmExports["__fesetround"];var _fesetenv=Module["_fesetenv"]=wasmExports["fesetenv"];var _feof_unlocked=Module["_feof_unlocked"]=wasmExports["feof_unlocked"];var __IO_feof_unlocked=Module["__IO_feof_unlocked"]=wasmExports["_IO_feof_unlocked"];var _ferror_unlocked=Module["_ferror_unlocked"]=wasmExports["ferror_unlocked"];var __IO_ferror_unlocked=Module["__IO_ferror_unlocked"]=wasmExports["_IO_ferror_unlocked"];var _fesetexceptflag=Module["_fesetexceptflag"]=wasmExports["fesetexceptflag"];var _fesetround=Module["_fesetround"]=wasmExports["fesetround"];var _feupdateenv=Module["_feupdateenv"]=wasmExports["feupdateenv"];var _fflush_unlocked=Module["_fflush_unlocked"]=wasmExports["fflush_unlocked"];var _ffs=Module["_ffs"]=wasmExports["ffs"];var _ffsl=Module["_ffsl"]=wasmExports["ffsl"];var _ffsll=Module["_ffsll"]=wasmExports["ffsll"];var _emscripten_futex_wake=Module["_emscripten_futex_wake"]=wasmExports["emscripten_futex_wake"];var _fgetln=Module["_fgetln"]=wasmExports["fgetln"];var _getline=Module["_getline"]=wasmExports["getline"];var _fgetpos=Module["_fgetpos"]=wasmExports["fgetpos"];var _fgets_unlocked=Module["_fgets_unlocked"]=wasmExports["fgets_unlocked"];var ___fgetwc_unlocked=Module["___fgetwc_unlocked"]=wasmExports["__fgetwc_unlocked"];var _fwide=Module["_fwide"]=wasmExports["fwide"];var _mbtowc=Module["_mbtowc"]=wasmExports["mbtowc"];var _fgetwc=Module["_fgetwc"]=wasmExports["fgetwc"];var _fgetwc_unlocked=Module["_fgetwc_unlocked"]=wasmExports["fgetwc_unlocked"];var _getwc_unlocked=Module["_getwc_unlocked"]=wasmExports["getwc_unlocked"];var _fgetws=Module["_fgetws"]=wasmExports["fgetws"];var _fgetws_unlocked=Module["_fgetws_unlocked"]=wasmExports["fgetws_unlocked"];var _fileno_unlocked=Module["_fileno_unlocked"]=wasmExports["fileno_unlocked"];var _finite=Module["_finite"]=wasmExports["finite"];var _finitef=Module["_finitef"]=wasmExports["finitef"];var ___floatunsitf=Module["___floatunsitf"]=wasmExports["__floatunsitf"];var _fmodl=Module["_fmodl"]=wasmExports["fmodl"];var _ftrylockfile=Module["_ftrylockfile"]=wasmExports["ftrylockfile"];var _floorf=Module["_floorf"]=wasmExports["floorf"];var _floorl=Module["_floorl"]=wasmExports["floorl"];var _fmaf=Module["_fmaf"]=wasmExports["fmaf"];var _fmal=Module["_fmal"]=wasmExports["fmal"];var _frexpl=Module["_frexpl"]=wasmExports["frexpl"];var _nextafterl=Module["_nextafterl"]=wasmExports["nextafterl"];var _ilogbl=Module["_ilogbl"]=wasmExports["ilogbl"];var _fmax=Module["_fmax"]=wasmExports["fmax"];var _fmaxf=Module["_fmaxf"]=wasmExports["fmaxf"];var _fmaxl=Module["_fmaxl"]=wasmExports["fmaxl"];var _fmemopen=Module["_fmemopen"]=wasmExports["fmemopen"];var _fmin=Module["_fmin"]=wasmExports["fmin"];var _fminf=Module["_fminf"]=wasmExports["fminf"];var _fminl=Module["_fminl"]=wasmExports["fminl"];var _fmodf=Module["_fmodf"]=wasmExports["fmodf"];var _fmtmsg=Module["_fmtmsg"]=wasmExports["fmtmsg"];var _fnmatch=Module["_fnmatch"]=wasmExports["fnmatch"];var _towupper=Module["_towupper"]=wasmExports["towupper"];var _towlower=Module["_towlower"]=wasmExports["towlower"];var _wctype=Module["_wctype"]=wasmExports["wctype"];var _iswctype=Module["_iswctype"]=wasmExports["iswctype"];var _forkpty=Module["_forkpty"]=wasmExports["forkpty"];var _openpty=Module["_openpty"]=wasmExports["openpty"];var _pipe2=Module["_pipe2"]=wasmExports["pipe2"];var _vfiprintf=Module["_vfiprintf"]=wasmExports["vfiprintf"];var ___small_vfprintf=Module["___small_vfprintf"]=wasmExports["__small_vfprintf"];var _fputs_unlocked=Module["_fputs_unlocked"]=wasmExports["fputs_unlocked"];var ___fputwc_unlocked=Module["___fputwc_unlocked"]=wasmExports["__fputwc_unlocked"];var _wctomb=Module["_wctomb"]=wasmExports["wctomb"];var _fputwc=Module["_fputwc"]=wasmExports["fputwc"];var _fputwc_unlocked=Module["_fputwc_unlocked"]=wasmExports["fputwc_unlocked"];var _putwc_unlocked=Module["_putwc_unlocked"]=wasmExports["putwc_unlocked"];var _fputws=Module["_fputws"]=wasmExports["fputws"];var _wcsrtombs=Module["_wcsrtombs"]=wasmExports["wcsrtombs"];var _fputws_unlocked=Module["_fputws_unlocked"]=wasmExports["fputws_unlocked"];var _fread_unlocked=Module["_fread_unlocked"]=wasmExports["fread_unlocked"];var _freelocale=Module["_freelocale"]=wasmExports["freelocale"];var ___freelocale=Module["___freelocale"]=wasmExports["__freelocale"];var _freopen=Module["_freopen"]=wasmExports["freopen"];var _frexpf=Module["_frexpf"]=wasmExports["frexpf"];var _fscanf=Module["_fscanf"]=wasmExports["fscanf"];var _vfscanf=Module["_vfscanf"]=wasmExports["vfscanf"];var ___isoc99_fscanf=Module["___isoc99_fscanf"]=wasmExports["__isoc99_fscanf"];var _fseek=Module["_fseek"]=wasmExports["fseek"];var _fseeko=Module["_fseeko"]=wasmExports["fseeko"];var _fsetpos=Module["_fsetpos"]=wasmExports["fsetpos"];var _ftello=Module["_ftello"]=wasmExports["ftello"];var _ftime=Module["_ftime"]=wasmExports["ftime"];var _utimensat=Module["_utimensat"]=wasmExports["utimensat"];var _fwprintf=Module["_fwprintf"]=wasmExports["fwprintf"];var _vfwprintf=Module["_vfwprintf"]=wasmExports["vfwprintf"];var _fwrite_unlocked=Module["_fwrite_unlocked"]=wasmExports["fwrite_unlocked"];var _fwscanf=Module["_fwscanf"]=wasmExports["fwscanf"];var _vfwscanf=Module["_vfwscanf"]=wasmExports["vfwscanf"];var ___isoc99_fwscanf=Module["___isoc99_fwscanf"]=wasmExports["__isoc99_fwscanf"];var _gcvt=Module["_gcvt"]=wasmExports["gcvt"];var _get_current_dir_name=Module["_get_current_dir_name"]=wasmExports["get_current_dir_name"];var _strdup=Module["_strdup"]=wasmExports["strdup"];var __IO_getc=Module["__IO_getc"]=wasmExports["_IO_getc"];var _fgetc_unlocked=Module["_fgetc_unlocked"]=wasmExports["fgetc_unlocked"];var __IO_getc_unlocked=Module["__IO_getc_unlocked"]=wasmExports["_IO_getc_unlocked"];var _getchar=Module["_getchar"]=wasmExports["getchar"];var _getchar_unlocked=Module["_getchar_unlocked"]=wasmExports["getchar_unlocked"];var _getdelim=Module["_getdelim"]=wasmExports["getdelim"];var ___getdelim=Module["___getdelim"]=wasmExports["__getdelim"];var _getdents=Module["_getdents"]=wasmExports["getdents"];var _getdomainname=Module["_getdomainname"]=wasmExports["getdomainname"];var _getegid=Module["_getegid"]=wasmExports["getegid"];var _geteuid=Module["_geteuid"]=wasmExports["geteuid"];var _getgroups=Module["_getgroups"]=wasmExports["getgroups"];var _gethostid=Module["_gethostid"]=wasmExports["gethostid"];var _freeifaddrs=Module["_freeifaddrs"]=wasmExports["freeifaddrs"];var _getifaddrs=Module["_getifaddrs"]=wasmExports["getifaddrs"];var ___getitimer=Module["___getitimer"]=wasmExports["__getitimer"];var _getlogin_r=Module["_getlogin_r"]=wasmExports["getlogin_r"];var _getopt=Module["_getopt"]=wasmExports["getopt"];var ___posix_getopt=Module["___posix_getopt"]=wasmExports["__posix_getopt"];var _getopt_long=Module["_getopt_long"]=wasmExports["getopt_long"];var _getopt_long_only=Module["_getopt_long_only"]=wasmExports["getopt_long_only"];var _mblen=Module["_mblen"]=wasmExports["mblen"];var _getpagesize=Module["_getpagesize"]=wasmExports["getpagesize"];var _getresgid=Module["_getresgid"]=wasmExports["getresgid"];var _getresuid=Module["_getresuid"]=wasmExports["getresuid"];var _getrusage=Module["_getrusage"]=wasmExports["getrusage"];var _gets=Module["_gets"]=wasmExports["gets"];var _getservbyname_r=Module["_getservbyname_r"]=wasmExports["getservbyname_r"];var _getservbyport_r=Module["_getservbyport_r"]=wasmExports["getservbyport_r"];var _getsubopt=Module["_getsubopt"]=wasmExports["getsubopt"];var _gettid=Module["_gettid"]=wasmExports["gettid"];var _getw=Module["_getw"]=wasmExports["getw"];var _getwc=Module["_getwc"]=wasmExports["getwc"];var _getwchar=Module["_getwchar"]=wasmExports["getwchar"];var _getwchar_unlocked=Module["_getwchar_unlocked"]=wasmExports["getwchar_unlocked"];var _glob=Module["_glob"]=wasmExports["glob"];var _globfree=Module["_globfree"]=wasmExports["globfree"];var _gmtime=Module["_gmtime"]=wasmExports["gmtime"];var _herror=Module["_herror"]=wasmExports["herror"];var _hcreate=Module["_hcreate"]=wasmExports["hcreate"];var _hdestroy=Module["_hdestroy"]=wasmExports["hdestroy"];var _hsearch=Module["_hsearch"]=wasmExports["hsearch"];var _hcreate_r=Module["_hcreate_r"]=wasmExports["hcreate_r"];var _hdestroy_r=Module["_hdestroy_r"]=wasmExports["hdestroy_r"];var _hsearch_r=Module["_hsearch_r"]=wasmExports["hsearch_r"];var _iconv_open=Module["_iconv_open"]=wasmExports["iconv_open"];var _iconv=Module["_iconv"]=wasmExports["iconv"];var _iconv_close=Module["_iconv_close"]=wasmExports["iconv_close"];var _ioctl=Module["_ioctl"]=wasmExports["ioctl"];var _ilogb=Module["_ilogb"]=wasmExports["ilogb"];var _ilogbf=Module["_ilogbf"]=wasmExports["ilogbf"];var _imaxabs=Module["_imaxabs"]=wasmExports["imaxabs"];var _imaxdiv=Module["_imaxdiv"]=wasmExports["imaxdiv"];var _index=Module["_index"]=wasmExports["index"];var _inet_addr=Module["_inet_addr"]=wasmExports["inet_addr"];var _inet_network=Module["_inet_network"]=wasmExports["inet_network"];var _inet_makeaddr=Module["_inet_makeaddr"]=wasmExports["inet_makeaddr"];var _inet_lnaof=Module["_inet_lnaof"]=wasmExports["inet_lnaof"];var _inet_netof=Module["_inet_netof"]=wasmExports["inet_netof"];var _insque=Module["_insque"]=wasmExports["insque"];var _remque=Module["_remque"]=wasmExports["remque"];var ___intscan=Module["___intscan"]=wasmExports["__intscan"];var ___multi3=Module["___multi3"]=wasmExports["__multi3"];var ___isalnum_l=Module["___isalnum_l"]=wasmExports["__isalnum_l"];var _isalnum_l=Module["_isalnum_l"]=wasmExports["isalnum_l"];var _isalpha=Module["_isalpha"]=wasmExports["isalpha"];var ___isalpha_l=Module["___isalpha_l"]=wasmExports["__isalpha_l"];var _isalpha_l=Module["_isalpha_l"]=wasmExports["isalpha_l"];var _isascii=Module["_isascii"]=wasmExports["isascii"];var _isblank=Module["_isblank"]=wasmExports["isblank"];var ___isblank_l=Module["___isblank_l"]=wasmExports["__isblank_l"];var _isblank_l=Module["_isblank_l"]=wasmExports["isblank_l"];var _iscntrl=Module["_iscntrl"]=wasmExports["iscntrl"];var ___iscntrl_l=Module["___iscntrl_l"]=wasmExports["__iscntrl_l"];var _iscntrl_l=Module["_iscntrl_l"]=wasmExports["iscntrl_l"];var _isdigit=Module["_isdigit"]=wasmExports["isdigit"];var ___isdigit_l=Module["___isdigit_l"]=wasmExports["__isdigit_l"];var _isdigit_l=Module["_isdigit_l"]=wasmExports["isdigit_l"];var _isgraph=Module["_isgraph"]=wasmExports["isgraph"];var ___isgraph_l=Module["___isgraph_l"]=wasmExports["__isgraph_l"];var _isgraph_l=Module["_isgraph_l"]=wasmExports["isgraph_l"];var _islower=Module["_islower"]=wasmExports["islower"];var ___islower_l=Module["___islower_l"]=wasmExports["__islower_l"];var _islower_l=Module["_islower_l"]=wasmExports["islower_l"];var _isprint=Module["_isprint"]=wasmExports["isprint"];var ___isprint_l=Module["___isprint_l"]=wasmExports["__isprint_l"];var _isprint_l=Module["_isprint_l"]=wasmExports["isprint_l"];var _ispunct=Module["_ispunct"]=wasmExports["ispunct"];var ___ispunct_l=Module["___ispunct_l"]=wasmExports["__ispunct_l"];var _ispunct_l=Module["_ispunct_l"]=wasmExports["ispunct_l"];var _issetugid=Module["_issetugid"]=wasmExports["issetugid"];var _isspace=Module["_isspace"]=wasmExports["isspace"];var ___isspace_l=Module["___isspace_l"]=wasmExports["__isspace_l"];var _isspace_l=Module["_isspace_l"]=wasmExports["isspace_l"];var _isupper=Module["_isupper"]=wasmExports["isupper"];var ___isupper_l=Module["___isupper_l"]=wasmExports["__isupper_l"];var _isupper_l=Module["_isupper_l"]=wasmExports["isupper_l"];var _iswalnum=Module["_iswalnum"]=wasmExports["iswalnum"];var _iswalpha=Module["_iswalpha"]=wasmExports["iswalpha"];var ___iswalnum_l=Module["___iswalnum_l"]=wasmExports["__iswalnum_l"];var _iswalnum_l=Module["_iswalnum_l"]=wasmExports["iswalnum_l"];var ___iswalpha_l=Module["___iswalpha_l"]=wasmExports["__iswalpha_l"];var _iswalpha_l=Module["_iswalpha_l"]=wasmExports["iswalpha_l"];var _iswblank=Module["_iswblank"]=wasmExports["iswblank"];var ___iswblank_l=Module["___iswblank_l"]=wasmExports["__iswblank_l"];var _iswblank_l=Module["_iswblank_l"]=wasmExports["iswblank_l"];var _iswcntrl=Module["_iswcntrl"]=wasmExports["iswcntrl"];var ___iswcntrl_l=Module["___iswcntrl_l"]=wasmExports["__iswcntrl_l"];var _iswcntrl_l=Module["_iswcntrl_l"]=wasmExports["iswcntrl_l"];var _iswgraph=Module["_iswgraph"]=wasmExports["iswgraph"];var _iswlower=Module["_iswlower"]=wasmExports["iswlower"];var _iswprint=Module["_iswprint"]=wasmExports["iswprint"];var _iswpunct=Module["_iswpunct"]=wasmExports["iswpunct"];var _iswspace=Module["_iswspace"]=wasmExports["iswspace"];var _iswupper=Module["_iswupper"]=wasmExports["iswupper"];var _iswxdigit=Module["_iswxdigit"]=wasmExports["iswxdigit"];var ___iswctype_l=Module["___iswctype_l"]=wasmExports["__iswctype_l"];var ___wctype_l=Module["___wctype_l"]=wasmExports["__wctype_l"];var _iswctype_l=Module["_iswctype_l"]=wasmExports["iswctype_l"];var _wctype_l=Module["_wctype_l"]=wasmExports["wctype_l"];var _iswdigit=Module["_iswdigit"]=wasmExports["iswdigit"];var ___iswdigit_l=Module["___iswdigit_l"]=wasmExports["__iswdigit_l"];var _iswdigit_l=Module["_iswdigit_l"]=wasmExports["iswdigit_l"];var ___iswgraph_l=Module["___iswgraph_l"]=wasmExports["__iswgraph_l"];var _iswgraph_l=Module["_iswgraph_l"]=wasmExports["iswgraph_l"];var ___iswlower_l=Module["___iswlower_l"]=wasmExports["__iswlower_l"];var _iswlower_l=Module["_iswlower_l"]=wasmExports["iswlower_l"];var ___iswprint_l=Module["___iswprint_l"]=wasmExports["__iswprint_l"];var _iswprint_l=Module["_iswprint_l"]=wasmExports["iswprint_l"];var ___iswpunct_l=Module["___iswpunct_l"]=wasmExports["__iswpunct_l"];var _iswpunct_l=Module["_iswpunct_l"]=wasmExports["iswpunct_l"];var ___iswspace_l=Module["___iswspace_l"]=wasmExports["__iswspace_l"];var _iswspace_l=Module["_iswspace_l"]=wasmExports["iswspace_l"];var ___iswupper_l=Module["___iswupper_l"]=wasmExports["__iswupper_l"];var _iswupper_l=Module["_iswupper_l"]=wasmExports["iswupper_l"];var ___iswxdigit_l=Module["___iswxdigit_l"]=wasmExports["__iswxdigit_l"];var _iswxdigit_l=Module["_iswxdigit_l"]=wasmExports["iswxdigit_l"];var _isxdigit=Module["_isxdigit"]=wasmExports["isxdigit"];var ___isxdigit_l=Module["___isxdigit_l"]=wasmExports["__isxdigit_l"];var _isxdigit_l=Module["_isxdigit_l"]=wasmExports["isxdigit_l"];var _j0=Module["_j0"]=wasmExports["j0"];var _y0=Module["_y0"]=wasmExports["y0"];var _j0f=Module["_j0f"]=wasmExports["j0f"];var _y0f=Module["_y0f"]=wasmExports["y0f"];var _j1=Module["_j1"]=wasmExports["j1"];var _y1=Module["_y1"]=wasmExports["y1"];var _j1f=Module["_j1f"]=wasmExports["j1f"];var _y1f=Module["_y1f"]=wasmExports["y1f"];var _jn=Module["_jn"]=wasmExports["jn"];var _yn=Module["_yn"]=wasmExports["yn"];var _jnf=Module["_jnf"]=wasmExports["jnf"];var _ynf=Module["_ynf"]=wasmExports["ynf"];var _labs=Module["_labs"]=wasmExports["labs"];var ___nl_langinfo=Module["___nl_langinfo"]=wasmExports["__nl_langinfo"];var _nl_langinfo_l=Module["_nl_langinfo_l"]=wasmExports["nl_langinfo_l"];var _lchmod=Module["_lchmod"]=wasmExports["lchmod"];var _lchown=Module["_lchown"]=wasmExports["lchown"];var _lcong48=Module["_lcong48"]=wasmExports["lcong48"];var _ldexpf=Module["_ldexpf"]=wasmExports["ldexpf"];var _scalbnf=Module["_scalbnf"]=wasmExports["scalbnf"];var _ldexpl=Module["_ldexpl"]=wasmExports["ldexpl"];var _ldiv=Module["_ldiv"]=wasmExports["ldiv"];var _get_nprocs_conf=Module["_get_nprocs_conf"]=wasmExports["get_nprocs_conf"];var _get_nprocs=Module["_get_nprocs"]=wasmExports["get_nprocs"];var _get_phys_pages=Module["_get_phys_pages"]=wasmExports["get_phys_pages"];var _get_avphys_pages=Module["_get_avphys_pages"]=wasmExports["get_avphys_pages"];var _lgamma=Module["_lgamma"]=wasmExports["lgamma"];var _lgamma_r=Module["_lgamma_r"]=wasmExports["lgamma_r"];var _lgammaf=Module["_lgammaf"]=wasmExports["lgammaf"];var _lgammaf_r=Module["_lgammaf_r"]=wasmExports["lgammaf_r"];var ___lgammal_r=Module["___lgammal_r"]=wasmExports["__lgammal_r"];var _lgammal=Module["_lgammal"]=wasmExports["lgammal"];var _lgammal_r=Module["_lgammal_r"]=wasmExports["lgammal_r"];var _emscripten_has_threading_support=Module["_emscripten_has_threading_support"]=wasmExports["emscripten_has_threading_support"];var _emscripten_num_logical_cores=Module["_emscripten_num_logical_cores"]=wasmExports["emscripten_num_logical_cores"];var _emscripten_futex_wait=Module["_emscripten_futex_wait"]=wasmExports["emscripten_futex_wait"];var _emscripten_main_thread_process_queued_calls=Module["_emscripten_main_thread_process_queued_calls"]=wasmExports["emscripten_main_thread_process_queued_calls"];var _emscripten_current_thread_process_queued_calls=Module["_emscripten_current_thread_process_queued_calls"]=wasmExports["emscripten_current_thread_process_queued_calls"];var __emscripten_yield=Module["__emscripten_yield"]=wasmExports["_emscripten_yield"];var __emscripten_check_timers=Module["__emscripten_check_timers"]=wasmExports["_emscripten_check_timers"];var _pthread_mutex_consistent=Module["_pthread_mutex_consistent"]=wasmExports["pthread_mutex_consistent"];var _pthread_barrier_init=Module["_pthread_barrier_init"]=wasmExports["pthread_barrier_init"];var _pthread_barrier_destroy=Module["_pthread_barrier_destroy"]=wasmExports["pthread_barrier_destroy"];var _pthread_barrier_wait=Module["_pthread_barrier_wait"]=wasmExports["pthread_barrier_wait"];var _pthread_cond_broadcast=Module["_pthread_cond_broadcast"]=wasmExports["pthread_cond_broadcast"];var _pthread_atfork=Module["_pthread_atfork"]=wasmExports["pthread_atfork"];var _pthread_cancel=Module["_pthread_cancel"]=wasmExports["pthread_cancel"];var _pthread_testcancel=Module["_pthread_testcancel"]=wasmExports["pthread_testcancel"];var ___pthread_detach=Module["___pthread_detach"]=wasmExports["__pthread_detach"];var _pthread_equal=Module["_pthread_equal"]=wasmExports["pthread_equal"];var _pthread_mutexattr_init=Module["_pthread_mutexattr_init"]=wasmExports["pthread_mutexattr_init"];var _pthread_mutexattr_setprotocol=Module["_pthread_mutexattr_setprotocol"]=wasmExports["pthread_mutexattr_setprotocol"];var _pthread_mutexattr_settype=Module["_pthread_mutexattr_settype"]=wasmExports["pthread_mutexattr_settype"];var _pthread_mutexattr_destroy=Module["_pthread_mutexattr_destroy"]=wasmExports["pthread_mutexattr_destroy"];var _pthread_mutexattr_setpshared=Module["_pthread_mutexattr_setpshared"]=wasmExports["pthread_mutexattr_setpshared"];var _pthread_condattr_destroy=Module["_pthread_condattr_destroy"]=wasmExports["pthread_condattr_destroy"];var _pthread_condattr_setpshared=Module["_pthread_condattr_setpshared"]=wasmExports["pthread_condattr_setpshared"];var _pthread_setcanceltype=Module["_pthread_setcanceltype"]=wasmExports["pthread_setcanceltype"];var _pthread_rwlock_init=Module["_pthread_rwlock_init"]=wasmExports["pthread_rwlock_init"];var _pthread_rwlock_destroy=Module["_pthread_rwlock_destroy"]=wasmExports["pthread_rwlock_destroy"];var _pthread_rwlock_rdlock=Module["_pthread_rwlock_rdlock"]=wasmExports["pthread_rwlock_rdlock"];var _pthread_rwlock_tryrdlock=Module["_pthread_rwlock_tryrdlock"]=wasmExports["pthread_rwlock_tryrdlock"];var _pthread_rwlock_timedrdlock=Module["_pthread_rwlock_timedrdlock"]=wasmExports["pthread_rwlock_timedrdlock"];var _pthread_rwlock_wrlock=Module["_pthread_rwlock_wrlock"]=wasmExports["pthread_rwlock_wrlock"];var _pthread_rwlock_trywrlock=Module["_pthread_rwlock_trywrlock"]=wasmExports["pthread_rwlock_trywrlock"];var _pthread_rwlock_timedwrlock=Module["_pthread_rwlock_timedwrlock"]=wasmExports["pthread_rwlock_timedwrlock"];var _pthread_rwlock_unlock=Module["_pthread_rwlock_unlock"]=wasmExports["pthread_rwlock_unlock"];var _pthread_rwlockattr_init=Module["_pthread_rwlockattr_init"]=wasmExports["pthread_rwlockattr_init"];var _pthread_rwlockattr_destroy=Module["_pthread_rwlockattr_destroy"]=wasmExports["pthread_rwlockattr_destroy"];var _pthread_rwlockattr_setpshared=Module["_pthread_rwlockattr_setpshared"]=wasmExports["pthread_rwlockattr_setpshared"];var _pthread_spin_init=Module["_pthread_spin_init"]=wasmExports["pthread_spin_init"];var _pthread_spin_destroy=Module["_pthread_spin_destroy"]=wasmExports["pthread_spin_destroy"];var _pthread_spin_lock=Module["_pthread_spin_lock"]=wasmExports["pthread_spin_lock"];var _pthread_spin_trylock=Module["_pthread_spin_trylock"]=wasmExports["pthread_spin_trylock"];var _pthread_spin_unlock=Module["_pthread_spin_unlock"]=wasmExports["pthread_spin_unlock"];var _sem_init=Module["_sem_init"]=wasmExports["sem_init"];var _sem_post=Module["_sem_post"]=wasmExports["sem_post"];var _sem_wait=Module["_sem_wait"]=wasmExports["sem_wait"];var _sem_trywait=Module["_sem_trywait"]=wasmExports["sem_trywait"];var _sem_destroy=Module["_sem_destroy"]=wasmExports["sem_destroy"];var _pthread_mutex_timedlock=Module["_pthread_mutex_timedlock"]=wasmExports["pthread_mutex_timedlock"];var _emscripten_builtin_pthread_create=Module["_emscripten_builtin_pthread_create"]=wasmExports["emscripten_builtin_pthread_create"];var _emscripten_builtin_pthread_join=Module["_emscripten_builtin_pthread_join"]=wasmExports["emscripten_builtin_pthread_join"];var _pthread_once=Module["_pthread_once"]=wasmExports["pthread_once"];var _emscripten_builtin_pthread_exit=Module["_emscripten_builtin_pthread_exit"]=wasmExports["emscripten_builtin_pthread_exit"];var _pthread_exit=Module["_pthread_exit"]=wasmExports["pthread_exit"];var _emscripten_builtin_pthread_detach=Module["_emscripten_builtin_pthread_detach"]=wasmExports["emscripten_builtin_pthread_detach"];var _thrd_detach=Module["_thrd_detach"]=wasmExports["thrd_detach"];var _link=Module["_link"]=wasmExports["link"];var _linkat=Module["_linkat"]=wasmExports["linkat"];var _llabs=Module["_llabs"]=wasmExports["llabs"];var _lldiv=Module["_lldiv"]=wasmExports["lldiv"];var _llrint=Module["_llrint"]=wasmExports["llrint"];var _rint=Module["_rint"]=wasmExports["rint"];var _llrintf=Module["_llrintf"]=wasmExports["llrintf"];var _rintf=Module["_rintf"]=wasmExports["rintf"];var _llrintl=Module["_llrintl"]=wasmExports["llrintl"];var _rintl=Module["_rintl"]=wasmExports["rintl"];var _llround=Module["_llround"]=wasmExports["llround"];var _llroundf=Module["_llroundf"]=wasmExports["llroundf"];var _roundf=Module["_roundf"]=wasmExports["roundf"];var _llroundl=Module["_llroundl"]=wasmExports["llroundl"];var _roundl=Module["_roundl"]=wasmExports["roundl"];var _log10f=Module["_log10f"]=wasmExports["log10f"];var _log10l=Module["_log10l"]=wasmExports["log10l"];var _log2f=Module["_log2f"]=wasmExports["log2f"];var _log2l=Module["_log2l"]=wasmExports["log2l"];var _logb=Module["_logb"]=wasmExports["logb"];var _logbf=Module["_logbf"]=wasmExports["logbf"];var _logbl=Module["_logbl"]=wasmExports["logbl"];var _strtoull=Module["_strtoull"]=wasmExports["strtoull"];var _nrand48=Module["_nrand48"]=wasmExports["nrand48"];var _lrand48=Module["_lrand48"]=wasmExports["lrand48"];var _lrint=Module["_lrint"]=wasmExports["lrint"];var _lrintf=Module["_lrintf"]=wasmExports["lrintf"];var _lrintl=Module["_lrintl"]=wasmExports["lrintl"];var _lround=Module["_lround"]=wasmExports["lround"];var _lroundf=Module["_lroundf"]=wasmExports["lroundf"];var _lroundl=Module["_lroundl"]=wasmExports["lroundl"];var _lsearch=Module["_lsearch"]=wasmExports["lsearch"];var _lfind=Module["_lfind"]=wasmExports["lfind"];var _mbrlen=Module["_mbrlen"]=wasmExports["mbrlen"];var _mbrtoc16=Module["_mbrtoc16"]=wasmExports["mbrtoc16"];var _mbrtoc32=Module["_mbrtoc32"]=wasmExports["mbrtoc32"];var _mbsinit=Module["_mbsinit"]=wasmExports["mbsinit"];var _mbsnrtowcs=Module["_mbsnrtowcs"]=wasmExports["mbsnrtowcs"];var _mbsrtowcs=Module["_mbsrtowcs"]=wasmExports["mbsrtowcs"];var _memccpy=Module["_memccpy"]=wasmExports["memccpy"];var _memmem=Module["_memmem"]=wasmExports["memmem"];var _mempcpy=Module["_mempcpy"]=wasmExports["mempcpy"];var _mincore=Module["_mincore"]=wasmExports["mincore"];var _mkdtemp=Module["_mkdtemp"]=wasmExports["mkdtemp"];var _mkfifo=Module["_mkfifo"]=wasmExports["mkfifo"];var _mkfifoat=Module["_mkfifoat"]=wasmExports["mkfifoat"];var _mkostemp=Module["_mkostemp"]=wasmExports["mkostemp"];var _mkostemps=Module["_mkostemps"]=wasmExports["mkostemps"];var _mkstemp=Module["_mkstemp"]=wasmExports["mkstemp"];var _mkstemps=Module["_mkstemps"]=wasmExports["mkstemps"];var _mktemp=Module["_mktemp"]=wasmExports["mktemp"];var _timegm=Module["_timegm"]=wasmExports["timegm"];var _mlock=Module["_mlock"]=wasmExports["mlock"];var _mlockall=Module["_mlockall"]=wasmExports["mlockall"];var _emscripten_builtin_mmap=Module["_emscripten_builtin_mmap"]=wasmExports["emscripten_builtin_mmap"];var _setmntent=Module["_setmntent"]=wasmExports["setmntent"];var _endmntent=Module["_endmntent"]=wasmExports["endmntent"];var _getmntent_r=Module["_getmntent_r"]=wasmExports["getmntent_r"];var _sscanf=Module["_sscanf"]=wasmExports["sscanf"];var _getmntent=Module["_getmntent"]=wasmExports["getmntent"];var _addmntent=Module["_addmntent"]=wasmExports["addmntent"];var _hasmntopt=Module["_hasmntopt"]=wasmExports["hasmntopt"];var _mprotect=Module["_mprotect"]=wasmExports["mprotect"];var _jrand48=Module["_jrand48"]=wasmExports["jrand48"];var _mrand48=Module["_mrand48"]=wasmExports["mrand48"];var _mtx_destroy=Module["_mtx_destroy"]=wasmExports["mtx_destroy"];var _mtx_init=Module["_mtx_init"]=wasmExports["mtx_init"];var _mtx_lock=Module["_mtx_lock"]=wasmExports["mtx_lock"];var _mtx_timedlock=Module["_mtx_timedlock"]=wasmExports["mtx_timedlock"];var _mtx_trylock=Module["_mtx_trylock"]=wasmExports["mtx_trylock"];var _mtx_unlock=Module["_mtx_unlock"]=wasmExports["mtx_unlock"];var _munlock=Module["_munlock"]=wasmExports["munlock"];var _munlockall=Module["_munlockall"]=wasmExports["munlockall"];var _emscripten_builtin_munmap=Module["_emscripten_builtin_munmap"]=wasmExports["emscripten_builtin_munmap"];var _nan=Module["_nan"]=wasmExports["nan"];var _nanf=Module["_nanf"]=wasmExports["nanf"];var _nanl=Module["_nanl"]=wasmExports["nanl"];var _nanosleep=Module["_nanosleep"]=wasmExports["nanosleep"];var _nearbyint=Module["_nearbyint"]=wasmExports["nearbyint"];var _nearbyintf=Module["_nearbyintf"]=wasmExports["nearbyintf"];var _nearbyintl=Module["_nearbyintl"]=wasmExports["nearbyintl"];var _getnetbyaddr=Module["_getnetbyaddr"]=wasmExports["getnetbyaddr"];var _getnetbyname=Module["_getnetbyname"]=wasmExports["getnetbyname"];var ___newlocale=Module["___newlocale"]=wasmExports["__newlocale"];var _newlocale=Module["_newlocale"]=wasmExports["newlocale"];var _nextafterf=Module["_nextafterf"]=wasmExports["nextafterf"];var _nexttoward=Module["_nexttoward"]=wasmExports["nexttoward"];var _nexttowardf=Module["_nexttowardf"]=wasmExports["nexttowardf"];var _nexttowardl=Module["_nexttowardl"]=wasmExports["nexttowardl"];var _nftw=Module["_nftw"]=wasmExports["nftw"];var _nice=Module["_nice"]=wasmExports["nice"];var _setpriority=Module["_setpriority"]=wasmExports["setpriority"];var _ns_get16=Module["_ns_get16"]=wasmExports["ns_get16"];var _ns_get32=Module["_ns_get32"]=wasmExports["ns_get32"];var _ns_put16=Module["_ns_put16"]=wasmExports["ns_put16"];var _ns_put32=Module["_ns_put32"]=wasmExports["ns_put32"];var _ns_skiprr=Module["_ns_skiprr"]=wasmExports["ns_skiprr"];var _ns_initparse=Module["_ns_initparse"]=wasmExports["ns_initparse"];var _ns_name_uncompress=Module["_ns_name_uncompress"]=wasmExports["ns_name_uncompress"];var _ns_parserr=Module["_ns_parserr"]=wasmExports["ns_parserr"];var _open_memstream=Module["_open_memstream"]=wasmExports["open_memstream"];var _open_wmemstream=Module["_open_wmemstream"]=wasmExports["open_wmemstream"];var _tcsetattr=Module["_tcsetattr"]=wasmExports["tcsetattr"];var _posix_close=Module["_posix_close"]=wasmExports["posix_close"];var _posix_fallocate=Module["_posix_fallocate"]=wasmExports["posix_fallocate"];var _posix_madvise=Module["_posix_madvise"]=wasmExports["posix_madvise"];var _posix_spawn_file_actions_addchdir_np=Module["_posix_spawn_file_actions_addchdir_np"]=wasmExports["posix_spawn_file_actions_addchdir_np"];var _posix_spawn_file_actions_addclose=Module["_posix_spawn_file_actions_addclose"]=wasmExports["posix_spawn_file_actions_addclose"];var _posix_spawn_file_actions_adddup2=Module["_posix_spawn_file_actions_adddup2"]=wasmExports["posix_spawn_file_actions_adddup2"];var _posix_spawn_file_actions_addfchdir_np=Module["_posix_spawn_file_actions_addfchdir_np"]=wasmExports["posix_spawn_file_actions_addfchdir_np"];var _posix_spawn_file_actions_addopen=Module["_posix_spawn_file_actions_addopen"]=wasmExports["posix_spawn_file_actions_addopen"];var _posix_spawn_file_actions_destroy=Module["_posix_spawn_file_actions_destroy"]=wasmExports["posix_spawn_file_actions_destroy"];var _posix_spawn_file_actions_init=Module["_posix_spawn_file_actions_init"]=wasmExports["posix_spawn_file_actions_init"];var _posix_spawnattr_destroy=Module["_posix_spawnattr_destroy"]=wasmExports["posix_spawnattr_destroy"];var _posix_spawnattr_getflags=Module["_posix_spawnattr_getflags"]=wasmExports["posix_spawnattr_getflags"];var _posix_spawnattr_getpgroup=Module["_posix_spawnattr_getpgroup"]=wasmExports["posix_spawnattr_getpgroup"];var _posix_spawnattr_getsigdefault=Module["_posix_spawnattr_getsigdefault"]=wasmExports["posix_spawnattr_getsigdefault"];var _posix_spawnattr_getsigmask=Module["_posix_spawnattr_getsigmask"]=wasmExports["posix_spawnattr_getsigmask"];var _posix_spawnattr_init=Module["_posix_spawnattr_init"]=wasmExports["posix_spawnattr_init"];var _posix_spawnattr_getschedparam=Module["_posix_spawnattr_getschedparam"]=wasmExports["posix_spawnattr_getschedparam"];var _posix_spawnattr_setschedparam=Module["_posix_spawnattr_setschedparam"]=wasmExports["posix_spawnattr_setschedparam"];var _posix_spawnattr_getschedpolicy=Module["_posix_spawnattr_getschedpolicy"]=wasmExports["posix_spawnattr_getschedpolicy"];var _posix_spawnattr_setschedpolicy=Module["_posix_spawnattr_setschedpolicy"]=wasmExports["posix_spawnattr_setschedpolicy"];var _posix_spawnattr_setflags=Module["_posix_spawnattr_setflags"]=wasmExports["posix_spawnattr_setflags"];var _posix_spawnattr_setpgroup=Module["_posix_spawnattr_setpgroup"]=wasmExports["posix_spawnattr_setpgroup"];var _posix_spawnattr_setsigdefault=Module["_posix_spawnattr_setsigdefault"]=wasmExports["posix_spawnattr_setsigdefault"];var _posix_spawnattr_setsigmask=Module["_posix_spawnattr_setsigmask"]=wasmExports["posix_spawnattr_setsigmask"];var _powf=Module["_powf"]=wasmExports["powf"];var _preadv=Module["_preadv"]=wasmExports["preadv"];var _printf=Module["_printf"]=wasmExports["printf"];var ___small_printf=Module["___small_printf"]=wasmExports["__small_printf"];var _em_proxying_queue_create=Module["_em_proxying_queue_create"]=wasmExports["em_proxying_queue_create"];var _em_proxying_queue_destroy=Module["_em_proxying_queue_destroy"]=wasmExports["em_proxying_queue_destroy"];var _emscripten_proxy_get_system_queue=Module["_emscripten_proxy_get_system_queue"]=wasmExports["emscripten_proxy_get_system_queue"];var _emscripten_proxy_execute_queue=Module["_emscripten_proxy_execute_queue"]=wasmExports["emscripten_proxy_execute_queue"];var _emscripten_proxy_finish=Module["_emscripten_proxy_finish"]=wasmExports["emscripten_proxy_finish"];var _emscripten_proxy_async=Module["_emscripten_proxy_async"]=wasmExports["emscripten_proxy_async"];var _emscripten_proxy_sync=Module["_emscripten_proxy_sync"]=wasmExports["emscripten_proxy_sync"];var _emscripten_proxy_sync_with_ctx=Module["_emscripten_proxy_sync_with_ctx"]=wasmExports["emscripten_proxy_sync_with_ctx"];var _pselect=Module["_pselect"]=wasmExports["pselect"];var _pthread_attr_getdetachstate=Module["_pthread_attr_getdetachstate"]=wasmExports["pthread_attr_getdetachstate"];var _pthread_attr_getguardsize=Module["_pthread_attr_getguardsize"]=wasmExports["pthread_attr_getguardsize"];var _pthread_attr_getinheritsched=Module["_pthread_attr_getinheritsched"]=wasmExports["pthread_attr_getinheritsched"];var _pthread_attr_getschedparam=Module["_pthread_attr_getschedparam"]=wasmExports["pthread_attr_getschedparam"];var _pthread_attr_getschedpolicy=Module["_pthread_attr_getschedpolicy"]=wasmExports["pthread_attr_getschedpolicy"];var _pthread_attr_getscope=Module["_pthread_attr_getscope"]=wasmExports["pthread_attr_getscope"];var _pthread_attr_getstack=Module["_pthread_attr_getstack"]=wasmExports["pthread_attr_getstack"];var _pthread_attr_getstacksize=Module["_pthread_attr_getstacksize"]=wasmExports["pthread_attr_getstacksize"];var _pthread_barrierattr_getpshared=Module["_pthread_barrierattr_getpshared"]=wasmExports["pthread_barrierattr_getpshared"];var _pthread_condattr_getclock=Module["_pthread_condattr_getclock"]=wasmExports["pthread_condattr_getclock"];var _pthread_condattr_getpshared=Module["_pthread_condattr_getpshared"]=wasmExports["pthread_condattr_getpshared"];var _pthread_mutexattr_getprotocol=Module["_pthread_mutexattr_getprotocol"]=wasmExports["pthread_mutexattr_getprotocol"];var _pthread_mutexattr_getpshared=Module["_pthread_mutexattr_getpshared"]=wasmExports["pthread_mutexattr_getpshared"];var _pthread_mutexattr_getrobust=Module["_pthread_mutexattr_getrobust"]=wasmExports["pthread_mutexattr_getrobust"];var _pthread_mutexattr_gettype=Module["_pthread_mutexattr_gettype"]=wasmExports["pthread_mutexattr_gettype"];var _pthread_rwlockattr_getpshared=Module["_pthread_rwlockattr_getpshared"]=wasmExports["pthread_rwlockattr_getpshared"];var _pthread_attr_setdetachstate=Module["_pthread_attr_setdetachstate"]=wasmExports["pthread_attr_setdetachstate"];var _pthread_attr_setguardsize=Module["_pthread_attr_setguardsize"]=wasmExports["pthread_attr_setguardsize"];var _pthread_attr_setinheritsched=Module["_pthread_attr_setinheritsched"]=wasmExports["pthread_attr_setinheritsched"];var _pthread_attr_setschedparam=Module["_pthread_attr_setschedparam"]=wasmExports["pthread_attr_setschedparam"];var _pthread_attr_setschedpolicy=Module["_pthread_attr_setschedpolicy"]=wasmExports["pthread_attr_setschedpolicy"];var _pthread_attr_setscope=Module["_pthread_attr_setscope"]=wasmExports["pthread_attr_setscope"];var _pthread_attr_setstack=Module["_pthread_attr_setstack"]=wasmExports["pthread_attr_setstack"];var __pthread_cleanup_push=Module["__pthread_cleanup_push"]=wasmExports["_pthread_cleanup_push"];var __pthread_cleanup_pop=Module["__pthread_cleanup_pop"]=wasmExports["_pthread_cleanup_pop"];var _pthread_getattr_np=Module["_pthread_getattr_np"]=wasmExports["pthread_getattr_np"];var _pthread_getconcurrency=Module["_pthread_getconcurrency"]=wasmExports["pthread_getconcurrency"];var _pthread_getschedparam=Module["_pthread_getschedparam"]=wasmExports["pthread_getschedparam"];var _thrd_current=Module["_thrd_current"]=wasmExports["thrd_current"];var _emscripten_main_runtime_thread_id=Module["_emscripten_main_runtime_thread_id"]=wasmExports["emscripten_main_runtime_thread_id"];var _pthread_setconcurrency=Module["_pthread_setconcurrency"]=wasmExports["pthread_setconcurrency"];var _pthread_setschedprio=Module["_pthread_setschedprio"]=wasmExports["pthread_setschedprio"];var ___sig_is_blocked=Module["___sig_is_blocked"]=wasmExports["__sig_is_blocked"];var _sigorset=Module["_sigorset"]=wasmExports["sigorset"];var _sigandset=Module["_sigandset"]=wasmExports["sigandset"];var _sigdelset=Module["_sigdelset"]=wasmExports["sigdelset"];var _ptsname=Module["_ptsname"]=wasmExports["ptsname"];var __IO_putc=Module["__IO_putc"]=wasmExports["_IO_putc"];var _putc_unlocked=Module["_putc_unlocked"]=wasmExports["putc_unlocked"];var _fputc_unlocked=Module["_fputc_unlocked"]=wasmExports["fputc_unlocked"];var __IO_putc_unlocked=Module["__IO_putc_unlocked"]=wasmExports["_IO_putc_unlocked"];var _putchar_unlocked=Module["_putchar_unlocked"]=wasmExports["putchar_unlocked"];var _putenv=Module["_putenv"]=wasmExports["putenv"];var _putw=Module["_putw"]=wasmExports["putw"];var _putwc=Module["_putwc"]=wasmExports["putwc"];var _putwchar=Module["_putwchar"]=wasmExports["putwchar"];var _putwchar_unlocked=Module["_putwchar_unlocked"]=wasmExports["putwchar_unlocked"];var _pwritev=Module["_pwritev"]=wasmExports["pwritev"];var _qsort_r=Module["_qsort_r"]=wasmExports["qsort_r"];var _quick_exit=Module["_quick_exit"]=wasmExports["quick_exit"];var _action_abort=Module["_action_abort"]=wasmExports["action_abort"];var _action_terminate=Module["_action_terminate"]=wasmExports["action_terminate"];var _srand=Module["_srand"]=wasmExports["srand"];var _rand=Module["_rand"]=wasmExports["rand"];var _rand_r=Module["_rand_r"]=wasmExports["rand_r"];var _srandom=Module["_srandom"]=wasmExports["srandom"];var _initstate=Module["_initstate"]=wasmExports["initstate"];var _setstate=Module["_setstate"]=wasmExports["setstate"];var _random=Module["_random"]=wasmExports["random"];var _readdir_r=Module["_readdir_r"]=wasmExports["readdir_r"];var _recvmmsg=Module["_recvmmsg"]=wasmExports["recvmmsg"];var _regcomp=Module["_regcomp"]=wasmExports["regcomp"];var _regfree=Module["_regfree"]=wasmExports["regfree"];var _regerror=Module["_regerror"]=wasmExports["regerror"];var _regexec=Module["_regexec"]=wasmExports["regexec"];var _remainder=Module["_remainder"]=wasmExports["remainder"];var _remquo=Module["_remquo"]=wasmExports["remquo"];var _drem=Module["_drem"]=wasmExports["drem"];var _remainderf=Module["_remainderf"]=wasmExports["remainderf"];var _remquof=Module["_remquof"]=wasmExports["remquof"];var _dremf=Module["_dremf"]=wasmExports["dremf"];var _remainderl=Module["_remainderl"]=wasmExports["remainderl"];var _remquol=Module["_remquol"]=wasmExports["remquol"];var _remove=Module["_remove"]=wasmExports["remove"];var _res_init=Module["_res_init"]=wasmExports["res_init"];var _res_mkquery=Module["_res_mkquery"]=wasmExports["res_mkquery"];var ___res_msend=Module["___res_msend"]=wasmExports["__res_msend"];var _res_send=Module["_res_send"]=wasmExports["res_send"];var ___res_state=Module["___res_state"]=wasmExports["__res_state"];var _rindex=Module["_rindex"]=wasmExports["rindex"];var _scalb=Module["_scalb"]=wasmExports["scalb"];var _scalbf=Module["_scalbf"]=wasmExports["scalbf"];var _scalbln=Module["_scalbln"]=wasmExports["scalbln"];var _scalblnf=Module["_scalblnf"]=wasmExports["scalblnf"];var _scalblnl=Module["_scalblnl"]=wasmExports["scalblnl"];var _scandir=Module["_scandir"]=wasmExports["scandir"];var _scanf=Module["_scanf"]=wasmExports["scanf"];var _vscanf=Module["_vscanf"]=wasmExports["vscanf"];var ___isoc99_scanf=Module["___isoc99_scanf"]=wasmExports["__isoc99_scanf"];var _secure_getenv=Module["_secure_getenv"]=wasmExports["secure_getenv"];var _seed48=Module["_seed48"]=wasmExports["seed48"];var _seekdir=Module["_seekdir"]=wasmExports["seekdir"];var _sendmmsg=Module["_sendmmsg"]=wasmExports["sendmmsg"];var _endservent=Module["_endservent"]=wasmExports["endservent"];var _setservent=Module["_setservent"]=wasmExports["setservent"];var _getservent=Module["_getservent"]=wasmExports["getservent"];var _setbuf=Module["_setbuf"]=wasmExports["setbuf"];var _setbuffer=Module["_setbuffer"]=wasmExports["setbuffer"];var _setdomainname=Module["_setdomainname"]=wasmExports["setdomainname"];var _setegid=Module["_setegid"]=wasmExports["setegid"];var _seteuid=Module["_seteuid"]=wasmExports["seteuid"];var __emscripten_timeout=wasmExports["_emscripten_timeout"];var _setlinebuf=Module["_setlinebuf"]=wasmExports["setlinebuf"];var _setresgid=Module["_setresgid"]=wasmExports["setresgid"];var _setresuid=Module["_setresuid"]=wasmExports["setresuid"];var _shm_open=Module["_shm_open"]=wasmExports["shm_open"];var _shm_unlink=Module["_shm_unlink"]=wasmExports["shm_unlink"];var _sigaction=Module["_sigaction"]=wasmExports["sigaction"];var _sigisemptyset=Module["_sigisemptyset"]=wasmExports["sigisemptyset"];var _bsd_signal=Module["_bsd_signal"]=wasmExports["bsd_signal"];var ___sysv_signal=Module["___sysv_signal"]=wasmExports["__sysv_signal"];var _significand=Module["_significand"]=wasmExports["significand"];var _significandf=Module["_significandf"]=wasmExports["significandf"];var _sigprocmask=Module["_sigprocmask"]=wasmExports["sigprocmask"];var _sincos=Module["_sincos"]=wasmExports["sincos"];var _sincosf=Module["_sincosf"]=wasmExports["sincosf"];var _sincosl=Module["_sincosl"]=wasmExports["sincosl"];var _sinhl=Module["_sinhl"]=wasmExports["sinhl"];var _sinl=Module["_sinl"]=wasmExports["sinl"];var _sockatmark=Module["_sockatmark"]=wasmExports["sockatmark"];var _vsprintf=Module["_vsprintf"]=wasmExports["vsprintf"];var _vsiprintf=Module["_vsiprintf"]=wasmExports["vsiprintf"];var ___small_sprintf=Module["___small_sprintf"]=wasmExports["__small_sprintf"];var ___small_vsprintf=Module["___small_vsprintf"]=wasmExports["__small_vsprintf"];var _srand48=Module["_srand48"]=wasmExports["srand48"];var _vsscanf=Module["_vsscanf"]=wasmExports["vsscanf"];var ___isoc99_sscanf=Module["___isoc99_sscanf"]=wasmExports["__isoc99_sscanf"];var _statfs=Module["_statfs"]=wasmExports["statfs"];var _fstatfs=Module["_fstatfs"]=wasmExports["fstatfs"];var _statx=Module["_statx"]=wasmExports["statx"];var _stpcpy=Module["_stpcpy"]=wasmExports["stpcpy"];var _stpncpy=Module["_stpncpy"]=wasmExports["stpncpy"];var ___strcasecmp_l=Module["___strcasecmp_l"]=wasmExports["__strcasecmp_l"];var _strcasecmp_l=Module["_strcasecmp_l"]=wasmExports["strcasecmp_l"];var _strcasestr=Module["_strcasestr"]=wasmExports["strcasestr"];var _strncasecmp=Module["_strncasecmp"]=wasmExports["strncasecmp"];var _strchrnul=Module["_strchrnul"]=wasmExports["strchrnul"];var ___strcoll_l=Module["___strcoll_l"]=wasmExports["__strcoll_l"];var _strcoll_l=Module["_strcoll_l"]=wasmExports["strcoll_l"];var ___strerror_l=Module["___strerror_l"]=wasmExports["__strerror_l"];var _strerror_l=Module["_strerror_l"]=wasmExports["strerror_l"];var _strerror_r=Module["_strerror_r"]=wasmExports["strerror_r"];var ___xpg_strerror_r=Module["___xpg_strerror_r"]=wasmExports["__xpg_strerror_r"];var _strfmon_l=Module["_strfmon_l"]=wasmExports["strfmon_l"];var _strfmon=Module["_strfmon"]=wasmExports["strfmon"];var _strftime=Module["_strftime"]=wasmExports["strftime"];var _strftime_l=Module["_strftime_l"]=wasmExports["strftime_l"];var _strlcat=Module["_strlcat"]=wasmExports["strlcat"];var _strlcpy=Module["_strlcpy"]=wasmExports["strlcpy"];var _strlwr=Module["_strlwr"]=wasmExports["strlwr"];var ___strncasecmp_l=Module["___strncasecmp_l"]=wasmExports["__strncasecmp_l"];var _strncasecmp_l=Module["_strncasecmp_l"]=wasmExports["strncasecmp_l"];var _strndup=Module["_strndup"]=wasmExports["strndup"];var _strsep=Module["_strsep"]=wasmExports["strsep"];var _strtof=Module["_strtof"]=wasmExports["strtof"];var _strtold=Module["_strtold"]=wasmExports["strtold"];var _strtof_l=Module["_strtof_l"]=wasmExports["strtof_l"];var _strtod_l=Module["_strtod_l"]=wasmExports["strtod_l"];var _strtold_l=Module["_strtold_l"]=wasmExports["strtold_l"];var ___strtof_l=Module["___strtof_l"]=wasmExports["__strtof_l"];var ___strtod_l=Module["___strtod_l"]=wasmExports["__strtod_l"];var ___strtold_l=Module["___strtold_l"]=wasmExports["__strtold_l"];var _strtok=Module["_strtok"]=wasmExports["strtok"];var _strtok_r=Module["_strtok_r"]=wasmExports["strtok_r"];var _strtoll=Module["_strtoll"]=wasmExports["strtoll"];var _strtoimax=Module["_strtoimax"]=wasmExports["strtoimax"];var _strtoumax=Module["_strtoumax"]=wasmExports["strtoumax"];var ___strtol_internal=Module["___strtol_internal"]=wasmExports["__strtol_internal"];var ___strtoul_internal=Module["___strtoul_internal"]=wasmExports["__strtoul_internal"];var ___strtoll_internal=Module["___strtoll_internal"]=wasmExports["__strtoll_internal"];var ___strtoull_internal=Module["___strtoull_internal"]=wasmExports["__strtoull_internal"];var ___strtoimax_internal=Module["___strtoimax_internal"]=wasmExports["__strtoimax_internal"];var ___strtoumax_internal=Module["___strtoumax_internal"]=wasmExports["__strtoumax_internal"];var _strtoull_l=Module["_strtoull_l"]=wasmExports["strtoull_l"];var _strtoll_l=Module["_strtoll_l"]=wasmExports["strtoll_l"];var _strtoul_l=Module["_strtoul_l"]=wasmExports["strtoul_l"];var _strtol_l=Module["_strtol_l"]=wasmExports["strtol_l"];var _strupr=Module["_strupr"]=wasmExports["strupr"];var _strverscmp=Module["_strverscmp"]=wasmExports["strverscmp"];var ___strxfrm_l=Module["___strxfrm_l"]=wasmExports["__strxfrm_l"];var _strxfrm=Module["_strxfrm"]=wasmExports["strxfrm"];var _strxfrm_l=Module["_strxfrm_l"]=wasmExports["strxfrm_l"];var _swab=Module["_swab"]=wasmExports["swab"];var _swprintf=Module["_swprintf"]=wasmExports["swprintf"];var _vswprintf=Module["_vswprintf"]=wasmExports["vswprintf"];var _swscanf=Module["_swscanf"]=wasmExports["swscanf"];var _vswscanf=Module["_vswscanf"]=wasmExports["vswscanf"];var ___isoc99_swscanf=Module["___isoc99_swscanf"]=wasmExports["__isoc99_swscanf"];var _symlinkat=Module["_symlinkat"]=wasmExports["symlinkat"];var _setlogmask=Module["_setlogmask"]=wasmExports["setlogmask"];var _closelog=Module["_closelog"]=wasmExports["closelog"];var _openlog=Module["_openlog"]=wasmExports["openlog"];var _syslog=Module["_syslog"]=wasmExports["syslog"];var _vsyslog=Module["_vsyslog"]=wasmExports["vsyslog"];var _tanhf=Module["_tanhf"]=wasmExports["tanhf"];var _tanhl=Module["_tanhl"]=wasmExports["tanhl"];var _tanl=Module["_tanl"]=wasmExports["tanl"];var _tcdrain=Module["_tcdrain"]=wasmExports["tcdrain"];var _tcflow=Module["_tcflow"]=wasmExports["tcflow"];var _tcflush=Module["_tcflush"]=wasmExports["tcflush"];var _tcgetattr=Module["_tcgetattr"]=wasmExports["tcgetattr"];var _tcgetsid=Module["_tcgetsid"]=wasmExports["tcgetsid"];var _tcgetwinsize=Module["_tcgetwinsize"]=wasmExports["tcgetwinsize"];var _tcsendbreak=Module["_tcsendbreak"]=wasmExports["tcsendbreak"];var _tcsetwinsize=Module["_tcsetwinsize"]=wasmExports["tcsetwinsize"];var _tdelete=Module["_tdelete"]=wasmExports["tdelete"];var _tdestroy=Module["_tdestroy"]=wasmExports["tdestroy"];var _telldir=Module["_telldir"]=wasmExports["telldir"];var _tempnam=Module["_tempnam"]=wasmExports["tempnam"];var _ngettext=Module["_ngettext"]=wasmExports["ngettext"];var _tfind=Module["_tfind"]=wasmExports["tfind"];var _tgamma=Module["_tgamma"]=wasmExports["tgamma"];var _tgammaf=Module["_tgammaf"]=wasmExports["tgammaf"];var _tgammal=Module["_tgammal"]=wasmExports["tgammal"];var _thrd_create=Module["_thrd_create"]=wasmExports["thrd_create"];var _thrd_exit=Module["_thrd_exit"]=wasmExports["thrd_exit"];var _thrd_join=Module["_thrd_join"]=wasmExports["thrd_join"];var _thrd_sleep=Module["_thrd_sleep"]=wasmExports["thrd_sleep"];var _thrd_yield=Module["_thrd_yield"]=wasmExports["thrd_yield"];var _emscripten_set_thread_name=Module["_emscripten_set_thread_name"]=wasmExports["emscripten_set_thread_name"];var _timespec_get=Module["_timespec_get"]=wasmExports["timespec_get"];var _tmpfile=Module["_tmpfile"]=wasmExports["tmpfile"];var _tmpnam=Module["_tmpnam"]=wasmExports["tmpnam"];var _toascii=Module["_toascii"]=wasmExports["toascii"];var ___tolower_l=Module["___tolower_l"]=wasmExports["__tolower_l"];var _tolower_l=Module["_tolower_l"]=wasmExports["tolower_l"];var ___toupper_l=Module["___toupper_l"]=wasmExports["__toupper_l"];var _toupper_l=Module["_toupper_l"]=wasmExports["toupper_l"];var ___towupper_l=Module["___towupper_l"]=wasmExports["__towupper_l"];var ___towlower_l=Module["___towlower_l"]=wasmExports["__towlower_l"];var _towupper_l=Module["_towupper_l"]=wasmExports["towupper_l"];var _towlower_l=Module["_towlower_l"]=wasmExports["towlower_l"];var _trunc=Module["_trunc"]=wasmExports["trunc"];var _truncf=Module["_truncf"]=wasmExports["truncf"];var _truncl=Module["_truncl"]=wasmExports["truncl"];var _tsearch=Module["_tsearch"]=wasmExports["tsearch"];var _tss_create=Module["_tss_create"]=wasmExports["tss_create"];var _tss_delete=Module["_tss_delete"]=wasmExports["tss_delete"];var _tss_set=Module["_tss_set"]=wasmExports["tss_set"];var _ttyname=Module["_ttyname"]=wasmExports["ttyname"];var _twalk=Module["_twalk"]=wasmExports["twalk"];var _ualarm=Module["_ualarm"]=wasmExports["ualarm"];var _ungetwc=Module["_ungetwc"]=wasmExports["ungetwc"];var ___uselocale=Module["___uselocale"]=wasmExports["__uselocale"];var _uselocale=Module["_uselocale"]=wasmExports["uselocale"];var _usleep=Module["_usleep"]=wasmExports["usleep"];var _utime=Module["_utime"]=wasmExports["utime"];var _versionsort=Module["_versionsort"]=wasmExports["versionsort"];var ___vfprintf_internal=Module["___vfprintf_internal"]=wasmExports["__vfprintf_internal"];var ___isoc99_vfscanf=Module["___isoc99_vfscanf"]=wasmExports["__isoc99_vfscanf"];var _wcsnlen=Module["_wcsnlen"]=wasmExports["wcsnlen"];var ___isoc99_vfwscanf=Module["___isoc99_vfwscanf"]=wasmExports["__isoc99_vfwscanf"];var _vprintf=Module["_vprintf"]=wasmExports["vprintf"];var ___isoc99_vscanf=Module["___isoc99_vscanf"]=wasmExports["__isoc99_vscanf"];var _vsniprintf=Module["_vsniprintf"]=wasmExports["vsniprintf"];var ___small_vsnprintf=Module["___small_vsnprintf"]=wasmExports["__small_vsnprintf"];var ___isoc99_vsscanf=Module["___isoc99_vsscanf"]=wasmExports["__isoc99_vsscanf"];var ___isoc99_vswscanf=Module["___isoc99_vswscanf"]=wasmExports["__isoc99_vswscanf"];var _vwprintf=Module["_vwprintf"]=wasmExports["vwprintf"];var _vwscanf=Module["_vwscanf"]=wasmExports["vwscanf"];var ___isoc99_vwscanf=Module["___isoc99_vwscanf"]=wasmExports["__isoc99_vwscanf"];var _wcpcpy=Module["_wcpcpy"]=wasmExports["wcpcpy"];var _wcpncpy=Module["_wcpncpy"]=wasmExports["wcpncpy"];var _wcscasecmp=Module["_wcscasecmp"]=wasmExports["wcscasecmp"];var _wcsncasecmp=Module["_wcsncasecmp"]=wasmExports["wcsncasecmp"];var _wcscasecmp_l=Module["_wcscasecmp_l"]=wasmExports["wcscasecmp_l"];var _wcscat=Module["_wcscat"]=wasmExports["wcscat"];var ___wcscoll_l=Module["___wcscoll_l"]=wasmExports["__wcscoll_l"];var _wcscoll_l=Module["_wcscoll_l"]=wasmExports["wcscoll_l"];var _wcscspn=Module["_wcscspn"]=wasmExports["wcscspn"];var _wcsdup=Module["_wcsdup"]=wasmExports["wcsdup"];var _wmemcpy=Module["_wmemcpy"]=wasmExports["wmemcpy"];var ___wcsftime_l=Module["___wcsftime_l"]=wasmExports["__wcsftime_l"];var _wcstoul=Module["_wcstoul"]=wasmExports["wcstoul"];var _wcsftime_l=Module["_wcsftime_l"]=wasmExports["wcsftime_l"];var _wcsncasecmp_l=Module["_wcsncasecmp_l"]=wasmExports["wcsncasecmp_l"];var _wcsncat=Module["_wcsncat"]=wasmExports["wcsncat"];var _wmemset=Module["_wmemset"]=wasmExports["wmemset"];var _wcsnrtombs=Module["_wcsnrtombs"]=wasmExports["wcsnrtombs"];var _wcspbrk=Module["_wcspbrk"]=wasmExports["wcspbrk"];var _wcsspn=Module["_wcsspn"]=wasmExports["wcsspn"];var _wcsstr=Module["_wcsstr"]=wasmExports["wcsstr"];var _wcstof=Module["_wcstof"]=wasmExports["wcstof"];var _wcstod=Module["_wcstod"]=wasmExports["wcstod"];var _wcstold=Module["_wcstold"]=wasmExports["wcstold"];var _wcstoull=Module["_wcstoull"]=wasmExports["wcstoull"];var _wcstoll=Module["_wcstoll"]=wasmExports["wcstoll"];var _wcstoimax=Module["_wcstoimax"]=wasmExports["wcstoimax"];var _wcstoumax=Module["_wcstoumax"]=wasmExports["wcstoumax"];var _wcswcs=Module["_wcswcs"]=wasmExports["wcswcs"];var _wcswidth=Module["_wcswidth"]=wasmExports["wcswidth"];var _wcwidth=Module["_wcwidth"]=wasmExports["wcwidth"];var ___wcsxfrm_l=Module["___wcsxfrm_l"]=wasmExports["__wcsxfrm_l"];var _wcsxfrm_l=Module["_wcsxfrm_l"]=wasmExports["wcsxfrm_l"];var _wctob=Module["_wctob"]=wasmExports["wctob"];var _wctrans=Module["_wctrans"]=wasmExports["wctrans"];var _towctrans=Module["_towctrans"]=wasmExports["towctrans"];var ___wctrans_l=Module["___wctrans_l"]=wasmExports["__wctrans_l"];var ___towctrans_l=Module["___towctrans_l"]=wasmExports["__towctrans_l"];var _wctrans_l=Module["_wctrans_l"]=wasmExports["wctrans_l"];var _towctrans_l=Module["_towctrans_l"]=wasmExports["towctrans_l"];var _wmemmove=Module["_wmemmove"]=wasmExports["wmemmove"];var _wprintf=Module["_wprintf"]=wasmExports["wprintf"];var _wscanf=Module["_wscanf"]=wasmExports["wscanf"];var ___isoc99_wscanf=Module["___isoc99_wscanf"]=wasmExports["__isoc99_wscanf"];var ___libc_realloc=Module["___libc_realloc"]=wasmExports["__libc_realloc"];var _realloc_in_place=Module["_realloc_in_place"]=wasmExports["realloc_in_place"];var _memalign=Module["_memalign"]=wasmExports["memalign"];var _valloc=Module["_valloc"]=wasmExports["valloc"];var _pvalloc=Module["_pvalloc"]=wasmExports["pvalloc"];var _mallinfo=Module["_mallinfo"]=wasmExports["mallinfo"];var _mallopt=Module["_mallopt"]=wasmExports["mallopt"];var _malloc_trim=Module["_malloc_trim"]=wasmExports["malloc_trim"];var _malloc_usable_size=Module["_malloc_usable_size"]=wasmExports["malloc_usable_size"];var _malloc_footprint=Module["_malloc_footprint"]=wasmExports["malloc_footprint"];var _malloc_max_footprint=Module["_malloc_max_footprint"]=wasmExports["malloc_max_footprint"];var _malloc_footprint_limit=Module["_malloc_footprint_limit"]=wasmExports["malloc_footprint_limit"];var _malloc_set_footprint_limit=Module["_malloc_set_footprint_limit"]=wasmExports["malloc_set_footprint_limit"];var _independent_calloc=Module["_independent_calloc"]=wasmExports["independent_calloc"];var _independent_comalloc=Module["_independent_comalloc"]=wasmExports["independent_comalloc"];var _bulk_free=Module["_bulk_free"]=wasmExports["bulk_free"];var _emscripten_builtin_realloc=Module["_emscripten_builtin_realloc"]=wasmExports["emscripten_builtin_realloc"];var _emscripten_builtin_calloc=Module["_emscripten_builtin_calloc"]=wasmExports["emscripten_builtin_calloc"];var _emscripten_get_sbrk_ptr=Module["_emscripten_get_sbrk_ptr"]=wasmExports["emscripten_get_sbrk_ptr"];var _brk=Module["_brk"]=wasmExports["brk"];var ___trap=wasmExports["__trap"];var ___absvdi2=Module["___absvdi2"]=wasmExports["__absvdi2"];var ___absvsi2=Module["___absvsi2"]=wasmExports["__absvsi2"];var ___absvti2=Module["___absvti2"]=wasmExports["__absvti2"];var ___adddf3=Module["___adddf3"]=wasmExports["__adddf3"];var ___fe_getround=Module["___fe_getround"]=wasmExports["__fe_getround"];var ___fe_raise_inexact=Module["___fe_raise_inexact"]=wasmExports["__fe_raise_inexact"];var ___addsf3=Module["___addsf3"]=wasmExports["__addsf3"];var ___ashlti3=Module["___ashlti3"]=wasmExports["__ashlti3"];var ___lshrti3=Module["___lshrti3"]=wasmExports["__lshrti3"];var ___addvdi3=Module["___addvdi3"]=wasmExports["__addvdi3"];var ___addvsi3=Module["___addvsi3"]=wasmExports["__addvsi3"];var ___addvti3=Module["___addvti3"]=wasmExports["__addvti3"];var ___ashldi3=Module["___ashldi3"]=wasmExports["__ashldi3"];var ___ashrdi3=Module["___ashrdi3"]=wasmExports["__ashrdi3"];var ___ashrti3=Module["___ashrti3"]=wasmExports["__ashrti3"];var ___atomic_is_lock_free=Module["___atomic_is_lock_free"]=wasmExports["__atomic_is_lock_free"];var ___atomic_load=Module["___atomic_load"]=wasmExports["__atomic_load"];var ___atomic_store=Module["___atomic_store"]=wasmExports["__atomic_store"];var ___atomic_compare_exchange=Module["___atomic_compare_exchange"]=wasmExports["__atomic_compare_exchange"];var ___atomic_exchange=Module["___atomic_exchange"]=wasmExports["__atomic_exchange"];var ___atomic_load_1=Module["___atomic_load_1"]=wasmExports["__atomic_load_1"];var ___atomic_load_2=Module["___atomic_load_2"]=wasmExports["__atomic_load_2"];var ___atomic_load_4=Module["___atomic_load_4"]=wasmExports["__atomic_load_4"];var ___atomic_load_8=Module["___atomic_load_8"]=wasmExports["__atomic_load_8"];var ___atomic_load_16=Module["___atomic_load_16"]=wasmExports["__atomic_load_16"];var ___atomic_store_1=Module["___atomic_store_1"]=wasmExports["__atomic_store_1"];var ___atomic_store_2=Module["___atomic_store_2"]=wasmExports["__atomic_store_2"];var ___atomic_store_4=Module["___atomic_store_4"]=wasmExports["__atomic_store_4"];var ___atomic_store_8=Module["___atomic_store_8"]=wasmExports["__atomic_store_8"];var ___atomic_store_16=Module["___atomic_store_16"]=wasmExports["__atomic_store_16"];var ___atomic_exchange_1=Module["___atomic_exchange_1"]=wasmExports["__atomic_exchange_1"];var ___atomic_exchange_2=Module["___atomic_exchange_2"]=wasmExports["__atomic_exchange_2"];var ___atomic_exchange_4=Module["___atomic_exchange_4"]=wasmExports["__atomic_exchange_4"];var ___atomic_exchange_8=Module["___atomic_exchange_8"]=wasmExports["__atomic_exchange_8"];var ___atomic_exchange_16=Module["___atomic_exchange_16"]=wasmExports["__atomic_exchange_16"];var ___atomic_compare_exchange_1=Module["___atomic_compare_exchange_1"]=wasmExports["__atomic_compare_exchange_1"];var ___atomic_compare_exchange_2=Module["___atomic_compare_exchange_2"]=wasmExports["__atomic_compare_exchange_2"];var ___atomic_compare_exchange_4=Module["___atomic_compare_exchange_4"]=wasmExports["__atomic_compare_exchange_4"];var ___atomic_compare_exchange_8=Module["___atomic_compare_exchange_8"]=wasmExports["__atomic_compare_exchange_8"];var ___atomic_compare_exchange_16=Module["___atomic_compare_exchange_16"]=wasmExports["__atomic_compare_exchange_16"];var ___atomic_fetch_add_1=Module["___atomic_fetch_add_1"]=wasmExports["__atomic_fetch_add_1"];var ___atomic_fetch_add_2=Module["___atomic_fetch_add_2"]=wasmExports["__atomic_fetch_add_2"];var ___atomic_fetch_add_4=Module["___atomic_fetch_add_4"]=wasmExports["__atomic_fetch_add_4"];var ___atomic_fetch_add_8=Module["___atomic_fetch_add_8"]=wasmExports["__atomic_fetch_add_8"];var ___atomic_fetch_add_16=Module["___atomic_fetch_add_16"]=wasmExports["__atomic_fetch_add_16"];var ___atomic_fetch_sub_1=Module["___atomic_fetch_sub_1"]=wasmExports["__atomic_fetch_sub_1"];var ___atomic_fetch_sub_2=Module["___atomic_fetch_sub_2"]=wasmExports["__atomic_fetch_sub_2"];var ___atomic_fetch_sub_4=Module["___atomic_fetch_sub_4"]=wasmExports["__atomic_fetch_sub_4"];var ___atomic_fetch_sub_8=Module["___atomic_fetch_sub_8"]=wasmExports["__atomic_fetch_sub_8"];var ___atomic_fetch_sub_16=Module["___atomic_fetch_sub_16"]=wasmExports["__atomic_fetch_sub_16"];var ___atomic_fetch_and_1=Module["___atomic_fetch_and_1"]=wasmExports["__atomic_fetch_and_1"];var ___atomic_fetch_and_2=Module["___atomic_fetch_and_2"]=wasmExports["__atomic_fetch_and_2"];var ___atomic_fetch_and_4=Module["___atomic_fetch_and_4"]=wasmExports["__atomic_fetch_and_4"];var ___atomic_fetch_and_8=Module["___atomic_fetch_and_8"]=wasmExports["__atomic_fetch_and_8"];var ___atomic_fetch_and_16=Module["___atomic_fetch_and_16"]=wasmExports["__atomic_fetch_and_16"];var ___atomic_fetch_or_1=Module["___atomic_fetch_or_1"]=wasmExports["__atomic_fetch_or_1"];var ___atomic_fetch_or_2=Module["___atomic_fetch_or_2"]=wasmExports["__atomic_fetch_or_2"];var ___atomic_fetch_or_4=Module["___atomic_fetch_or_4"]=wasmExports["__atomic_fetch_or_4"];var ___atomic_fetch_or_8=Module["___atomic_fetch_or_8"]=wasmExports["__atomic_fetch_or_8"];var ___atomic_fetch_or_16=Module["___atomic_fetch_or_16"]=wasmExports["__atomic_fetch_or_16"];var ___atomic_fetch_xor_1=Module["___atomic_fetch_xor_1"]=wasmExports["__atomic_fetch_xor_1"];var ___atomic_fetch_xor_2=Module["___atomic_fetch_xor_2"]=wasmExports["__atomic_fetch_xor_2"];var ___atomic_fetch_xor_4=Module["___atomic_fetch_xor_4"]=wasmExports["__atomic_fetch_xor_4"];var ___atomic_fetch_xor_8=Module["___atomic_fetch_xor_8"]=wasmExports["__atomic_fetch_xor_8"];var ___atomic_fetch_xor_16=Module["___atomic_fetch_xor_16"]=wasmExports["__atomic_fetch_xor_16"];var ___atomic_fetch_nand_1=Module["___atomic_fetch_nand_1"]=wasmExports["__atomic_fetch_nand_1"];var ___atomic_fetch_nand_2=Module["___atomic_fetch_nand_2"]=wasmExports["__atomic_fetch_nand_2"];var ___atomic_fetch_nand_4=Module["___atomic_fetch_nand_4"]=wasmExports["__atomic_fetch_nand_4"];var ___atomic_fetch_nand_8=Module["___atomic_fetch_nand_8"]=wasmExports["__atomic_fetch_nand_8"];var ___atomic_fetch_nand_16=Module["___atomic_fetch_nand_16"]=wasmExports["__atomic_fetch_nand_16"];var _atomic_flag_clear=Module["_atomic_flag_clear"]=wasmExports["atomic_flag_clear"];var _atomic_flag_clear_explicit=Module["_atomic_flag_clear_explicit"]=wasmExports["atomic_flag_clear_explicit"];var _atomic_flag_test_and_set=Module["_atomic_flag_test_and_set"]=wasmExports["atomic_flag_test_and_set"];var _atomic_flag_test_and_set_explicit=Module["_atomic_flag_test_and_set_explicit"]=wasmExports["atomic_flag_test_and_set_explicit"];var _atomic_signal_fence=Module["_atomic_signal_fence"]=wasmExports["atomic_signal_fence"];var _atomic_thread_fence=Module["_atomic_thread_fence"]=wasmExports["atomic_thread_fence"];var ___bswapdi2=Module["___bswapdi2"]=wasmExports["__bswapdi2"];var ___bswapsi2=Module["___bswapsi2"]=wasmExports["__bswapsi2"];var ___clear_cache=Module["___clear_cache"]=wasmExports["__clear_cache"];var ___clzdi2=Module["___clzdi2"]=wasmExports["__clzdi2"];var ___clzsi2=Module["___clzsi2"]=wasmExports["__clzsi2"];var ___clzti2=Module["___clzti2"]=wasmExports["__clzti2"];var ___cmpdi2=Module["___cmpdi2"]=wasmExports["__cmpdi2"];var ___cmpti2=Module["___cmpti2"]=wasmExports["__cmpti2"];var ___ledf2=Module["___ledf2"]=wasmExports["__ledf2"];var ___gedf2=Module["___gedf2"]=wasmExports["__gedf2"];var ___unorddf2=Module["___unorddf2"]=wasmExports["__unorddf2"];var ___eqdf2=Module["___eqdf2"]=wasmExports["__eqdf2"];var ___ltdf2=Module["___ltdf2"]=wasmExports["__ltdf2"];var ___nedf2=Module["___nedf2"]=wasmExports["__nedf2"];var ___gtdf2=Module["___gtdf2"]=wasmExports["__gtdf2"];var ___lesf2=Module["___lesf2"]=wasmExports["__lesf2"];var ___gesf2=Module["___gesf2"]=wasmExports["__gesf2"];var ___unordsf2=Module["___unordsf2"]=wasmExports["__unordsf2"];var ___eqsf2=Module["___eqsf2"]=wasmExports["__eqsf2"];var ___ltsf2=Module["___ltsf2"]=wasmExports["__ltsf2"];var ___nesf2=Module["___nesf2"]=wasmExports["__nesf2"];var ___gtsf2=Module["___gtsf2"]=wasmExports["__gtsf2"];var ___ctzdi2=Module["___ctzdi2"]=wasmExports["__ctzdi2"];var ___ctzsi2=Module["___ctzsi2"]=wasmExports["__ctzsi2"];var ___ctzti2=Module["___ctzti2"]=wasmExports["__ctzti2"];var ___divdc3=Module["___divdc3"]=wasmExports["__divdc3"];var ___divdf3=Module["___divdf3"]=wasmExports["__divdf3"];var ___divdi3=Module["___divdi3"]=wasmExports["__divdi3"];var ___udivmoddi4=Module["___udivmoddi4"]=wasmExports["__udivmoddi4"];var ___divmoddi4=Module["___divmoddi4"]=wasmExports["__divmoddi4"];var ___divmodsi4=Module["___divmodsi4"]=wasmExports["__divmodsi4"];var ___udivmodsi4=Module["___udivmodsi4"]=wasmExports["__udivmodsi4"];var ___divmodti4=Module["___divmodti4"]=wasmExports["__divmodti4"];var ___udivmodti4=Module["___udivmodti4"]=wasmExports["__udivmodti4"];var ___divsc3=Module["___divsc3"]=wasmExports["__divsc3"];var ___divsf3=Module["___divsf3"]=wasmExports["__divsf3"];var ___divsi3=Module["___divsi3"]=wasmExports["__divsi3"];var ___divtc3=Module["___divtc3"]=wasmExports["__divtc3"];var ___divti3=Module["___divti3"]=wasmExports["__divti3"];var _setThrew=Module["_setThrew"]=wasmExports["setThrew"];var ___wasm_setjmp=Module["___wasm_setjmp"]=wasmExports["__wasm_setjmp"];var ___wasm_setjmp_test=Module["___wasm_setjmp_test"]=wasmExports["__wasm_setjmp_test"];var ___wasm_longjmp=Module["___wasm_longjmp"]=wasmExports["__wasm_longjmp"];var __emscripten_tempret_set=wasmExports["_emscripten_tempret_set"];var __emscripten_tempret_get=wasmExports["_emscripten_tempret_get"];var ___get_temp_ret=Module["___get_temp_ret"]=wasmExports["__get_temp_ret"];var ___set_temp_ret=Module["___set_temp_ret"]=wasmExports["__set_temp_ret"];var _getTempRet0=Module["_getTempRet0"]=wasmExports["getTempRet0"];var _setTempRet0=Module["_setTempRet0"]=wasmExports["setTempRet0"];var ___emutls_get_address=Module["___emutls_get_address"]=wasmExports["__emutls_get_address"];var ___enable_execute_stack=Module["___enable_execute_stack"]=wasmExports["__enable_execute_stack"];var ___extendhfsf2=Module["___extendhfsf2"]=wasmExports["__extendhfsf2"];var ___gnu_h2f_ieee=Module["___gnu_h2f_ieee"]=wasmExports["__gnu_h2f_ieee"];var ___extendsfdf2=Module["___extendsfdf2"]=wasmExports["__extendsfdf2"];var ___ffsdi2=Module["___ffsdi2"]=wasmExports["__ffsdi2"];var ___ffssi2=Module["___ffssi2"]=wasmExports["__ffssi2"];var ___ffsti2=Module["___ffsti2"]=wasmExports["__ffsti2"];var ___fixdfdi=Module["___fixdfdi"]=wasmExports["__fixdfdi"];var ___fixunsdfdi=Module["___fixunsdfdi"]=wasmExports["__fixunsdfdi"];var ___fixdfsi=Module["___fixdfsi"]=wasmExports["__fixdfsi"];var ___fixdfti=Module["___fixdfti"]=wasmExports["__fixdfti"];var ___fixsfdi=Module["___fixsfdi"]=wasmExports["__fixsfdi"];var ___fixunssfdi=Module["___fixunssfdi"]=wasmExports["__fixunssfdi"];var ___fixsfsi=Module["___fixsfsi"]=wasmExports["__fixsfsi"];var ___fixsfti=Module["___fixsfti"]=wasmExports["__fixsfti"];var ___fixtfti=Module["___fixtfti"]=wasmExports["__fixtfti"];var ___fixunsdfsi=Module["___fixunsdfsi"]=wasmExports["__fixunsdfsi"];var ___fixunsdfti=Module["___fixunsdfti"]=wasmExports["__fixunsdfti"];var ___fixunssfsi=Module["___fixunssfsi"]=wasmExports["__fixunssfsi"];var ___fixunssfti=Module["___fixunssfti"]=wasmExports["__fixunssfti"];var ___fixunstfdi=Module["___fixunstfdi"]=wasmExports["__fixunstfdi"];var ___fixunstfsi=Module["___fixunstfsi"]=wasmExports["__fixunstfsi"];var ___fixunstfti=Module["___fixunstfti"]=wasmExports["__fixunstfti"];var ___floatdidf=Module["___floatdidf"]=wasmExports["__floatdidf"];var ___floatdisf=Module["___floatdisf"]=wasmExports["__floatdisf"];var ___floatditf=Module["___floatditf"]=wasmExports["__floatditf"];var ___floatsidf=Module["___floatsidf"]=wasmExports["__floatsidf"];var ___floatsisf=Module["___floatsisf"]=wasmExports["__floatsisf"];var ___floattidf=Module["___floattidf"]=wasmExports["__floattidf"];var ___floattisf=Module["___floattisf"]=wasmExports["__floattisf"];var ___floattitf=Module["___floattitf"]=wasmExports["__floattitf"];var ___floatundidf=Module["___floatundidf"]=wasmExports["__floatundidf"];var ___floatundisf=Module["___floatundisf"]=wasmExports["__floatundisf"];var ___floatunditf=Module["___floatunditf"]=wasmExports["__floatunditf"];var ___floatunsidf=Module["___floatunsidf"]=wasmExports["__floatunsidf"];var ___floatunsisf=Module["___floatunsisf"]=wasmExports["__floatunsisf"];var ___floatuntidf=Module["___floatuntidf"]=wasmExports["__floatuntidf"];var ___floatuntisf=Module["___floatuntisf"]=wasmExports["__floatuntisf"];var ___floatuntitf=Module["___floatuntitf"]=wasmExports["__floatuntitf"];var ___lshrdi3=Module["___lshrdi3"]=wasmExports["__lshrdi3"];var ___moddi3=Module["___moddi3"]=wasmExports["__moddi3"];var ___modsi3=Module["___modsi3"]=wasmExports["__modsi3"];var ___modti3=Module["___modti3"]=wasmExports["__modti3"];var ___muldf3=Module["___muldf3"]=wasmExports["__muldf3"];var ___muldi3=Module["___muldi3"]=wasmExports["__muldi3"];var ___mulodi4=Module["___mulodi4"]=wasmExports["__mulodi4"];var ___mulosi4=Module["___mulosi4"]=wasmExports["__mulosi4"];var ___muloti4=Module["___muloti4"]=wasmExports["__muloti4"];var ___udivti3=Module["___udivti3"]=wasmExports["__udivti3"];var ___mulsf3=Module["___mulsf3"]=wasmExports["__mulsf3"];var ___mulvdi3=Module["___mulvdi3"]=wasmExports["__mulvdi3"];var ___mulvsi3=Module["___mulvsi3"]=wasmExports["__mulvsi3"];var ___mulvti3=Module["___mulvti3"]=wasmExports["__mulvti3"];var ___negdf2=Module["___negdf2"]=wasmExports["__negdf2"];var ___negdi2=Module["___negdi2"]=wasmExports["__negdi2"];var ___negsf2=Module["___negsf2"]=wasmExports["__negsf2"];var ___negti2=Module["___negti2"]=wasmExports["__negti2"];var ___negvdi2=Module["___negvdi2"]=wasmExports["__negvdi2"];var ___negvsi2=Module["___negvsi2"]=wasmExports["__negvsi2"];var ___negvti2=Module["___negvti2"]=wasmExports["__negvti2"];var ___paritydi2=Module["___paritydi2"]=wasmExports["__paritydi2"];var ___paritysi2=Module["___paritysi2"]=wasmExports["__paritysi2"];var ___parityti2=Module["___parityti2"]=wasmExports["__parityti2"];var ___popcountdi2=Module["___popcountdi2"]=wasmExports["__popcountdi2"];var ___popcountsi2=Module["___popcountsi2"]=wasmExports["__popcountsi2"];var ___popcountti2=Module["___popcountti2"]=wasmExports["__popcountti2"];var ___powidf2=Module["___powidf2"]=wasmExports["__powidf2"];var ___powisf2=Module["___powisf2"]=wasmExports["__powisf2"];var ___powitf2=Module["___powitf2"]=wasmExports["__powitf2"];var _emscripten_stack_init=Module["_emscripten_stack_init"]=wasmExports["emscripten_stack_init"];var _emscripten_stack_set_limits=Module["_emscripten_stack_set_limits"]=wasmExports["emscripten_stack_set_limits"];var _emscripten_stack_get_free=Module["_emscripten_stack_get_free"]=wasmExports["emscripten_stack_get_free"];var __emscripten_stack_restore=wasmExports["_emscripten_stack_restore"];var __emscripten_stack_alloc=wasmExports["_emscripten_stack_alloc"];var ___subdf3=Module["___subdf3"]=wasmExports["__subdf3"];var ___subsf3=Module["___subsf3"]=wasmExports["__subsf3"];var ___subvdi3=Module["___subvdi3"]=wasmExports["__subvdi3"];var ___subvsi3=Module["___subvsi3"]=wasmExports["__subvsi3"];var ___subvti3=Module["___subvti3"]=wasmExports["__subvti3"];var ___truncdfhf2=Module["___truncdfhf2"]=wasmExports["__truncdfhf2"];var ___truncdfsf2=Module["___truncdfsf2"]=wasmExports["__truncdfsf2"];var ___truncsfhf2=Module["___truncsfhf2"]=wasmExports["__truncsfhf2"];var ___gnu_f2h_ieee=Module["___gnu_f2h_ieee"]=wasmExports["__gnu_f2h_ieee"];var ___ucmpdi2=Module["___ucmpdi2"]=wasmExports["__ucmpdi2"];var ___ucmpti2=Module["___ucmpti2"]=wasmExports["__ucmpti2"];var ___udivdi3=Module["___udivdi3"]=wasmExports["__udivdi3"];var ___udivsi3=Module["___udivsi3"]=wasmExports["__udivsi3"];var ___umoddi3=Module["___umoddi3"]=wasmExports["__umoddi3"];var ___umodsi3=Module["___umodsi3"]=wasmExports["__umodsi3"];var ___umodti3=Module["___umodti3"]=wasmExports["__umodti3"];var ___cxa_begin_catch=Module["___cxa_begin_catch"]=wasmExports["__cxa_begin_catch"];var ___cxa_rethrow=Module["___cxa_rethrow"]=wasmExports["__cxa_rethrow"];var ___cxa_end_catch=Module["___cxa_end_catch"]=wasmExports["__cxa_end_catch"];var ___cxa_allocate_exception=Module["___cxa_allocate_exception"]=wasmExports["__cxa_allocate_exception"];var ___cxa_free_exception=Module["___cxa_free_exception"]=wasmExports["__cxa_free_exception"];var ___cxa_throw=wasmExports["__cxa_throw"];var ___cxa_pure_virtual=Module["___cxa_pure_virtual"]=wasmExports["__cxa_pure_virtual"];var ___cxa_uncaught_exceptions=Module["___cxa_uncaught_exceptions"]=wasmExports["__cxa_uncaught_exceptions"];var ___cxa_decrement_exception_refcount=wasmExports["__cxa_decrement_exception_refcount"];var ___cxa_increment_exception_refcount=wasmExports["__cxa_increment_exception_refcount"];var ___cxa_current_primary_exception=Module["___cxa_current_primary_exception"]=wasmExports["__cxa_current_primary_exception"];var ___cxa_rethrow_primary_exception=Module["___cxa_rethrow_primary_exception"]=wasmExports["__cxa_rethrow_primary_exception"];var ___cxa_init_primary_exception=Module["___cxa_init_primary_exception"]=wasmExports["__cxa_init_primary_exception"];var ___dynamic_cast=Module["___dynamic_cast"]=wasmExports["__dynamic_cast"];var ___cxa_bad_cast=Module["___cxa_bad_cast"]=wasmExports["__cxa_bad_cast"];var ___cxa_bad_typeid=Module["___cxa_bad_typeid"]=wasmExports["__cxa_bad_typeid"];var ___cxa_throw_bad_array_new_length=Module["___cxa_throw_bad_array_new_length"]=wasmExports["__cxa_throw_bad_array_new_length"];var ___cxa_get_globals_fast=Module["___cxa_get_globals_fast"]=wasmExports["__cxa_get_globals_fast"];var ___cxa_demangle=wasmExports["__cxa_demangle"];var ___cxa_allocate_dependent_exception=Module["___cxa_allocate_dependent_exception"]=wasmExports["__cxa_allocate_dependent_exception"];var ___cxa_free_dependent_exception=Module["___cxa_free_dependent_exception"]=wasmExports["__cxa_free_dependent_exception"];var ___cxa_get_globals=Module["___cxa_get_globals"]=wasmExports["__cxa_get_globals"];var __Unwind_RaiseException=Module["__Unwind_RaiseException"]=wasmExports["_Unwind_RaiseException"];var ___cxa_get_exception_ptr=Module["___cxa_get_exception_ptr"]=wasmExports["__cxa_get_exception_ptr"];var __Unwind_DeleteException=Module["__Unwind_DeleteException"]=wasmExports["_Unwind_DeleteException"];var ___cxa_call_terminate=Module["___cxa_call_terminate"]=wasmExports["__cxa_call_terminate"];var ___cxa_current_exception_type=Module["___cxa_current_exception_type"]=wasmExports["__cxa_current_exception_type"];var ___cxa_uncaught_exception=Module["___cxa_uncaught_exception"]=wasmExports["__cxa_uncaught_exception"];var ___thrown_object_from_unwind_exception=wasmExports["__thrown_object_from_unwind_exception"];var ___get_exception_message=wasmExports["__get_exception_message"];var ___get_exception_terminate_message=Module["___get_exception_terminate_message"]=wasmExports["__get_exception_terminate_message"];var ___cxa_guard_acquire=Module["___cxa_guard_acquire"]=wasmExports["__cxa_guard_acquire"];var ___cxa_guard_release=Module["___cxa_guard_release"]=wasmExports["__cxa_guard_release"];var ___cxa_guard_abort=Module["___cxa_guard_abort"]=wasmExports["__cxa_guard_abort"];var ___gxx_personality_wasm0=Module["___gxx_personality_wasm0"]=wasmExports["__gxx_personality_wasm0"];var __Unwind_SetGR=Module["__Unwind_SetGR"]=wasmExports["_Unwind_SetGR"];var __Unwind_SetIP=Module["__Unwind_SetIP"]=wasmExports["_Unwind_SetIP"];var __Unwind_GetLanguageSpecificData=Module["__Unwind_GetLanguageSpecificData"]=wasmExports["_Unwind_GetLanguageSpecificData"];var __Unwind_GetIP=Module["__Unwind_GetIP"]=wasmExports["_Unwind_GetIP"];var __Unwind_GetRegionStart=Module["__Unwind_GetRegionStart"]=wasmExports["_Unwind_GetRegionStart"];var ___cxa_call_unexpected=Module["___cxa_call_unexpected"]=wasmExports["__cxa_call_unexpected"];var ___cxa_thread_atexit=Module["___cxa_thread_atexit"]=wasmExports["__cxa_thread_atexit"];var ___cxa_deleted_virtual=Module["___cxa_deleted_virtual"]=wasmExports["__cxa_deleted_virtual"];var __Unwind_CallPersonality=Module["__Unwind_CallPersonality"]=wasmExports["_Unwind_CallPersonality"];var _gethostbyaddr_r=Module["_gethostbyaddr_r"]=wasmExports["gethostbyaddr_r"];var _gethostbyname2=Module["_gethostbyname2"]=wasmExports["gethostbyname2"];var _gethostbyname2_r=Module["_gethostbyname2_r"]=wasmExports["gethostbyname2_r"];var _gethostbyname_r=Module["_gethostbyname_r"]=wasmExports["gethostbyname_r"];var _shutdown=Module["_shutdown"]=wasmExports["shutdown"];var _socketpair=Module["_socketpair"]=wasmExports["socketpair"];var ___wasm_apply_data_relocs=wasmExports["__wasm_apply_data_relocs"];var _py_docstring_mod=Module["_py_docstring_mod"]=3474304;var _PyExc_AttributeError=Module["_PyExc_AttributeError"]=2794608;var _stdout=Module["_stdout"]=3326440;var _PyExc_ModuleNotFoundError=Module["_PyExc_ModuleNotFoundError"]=2794512;var __Py_NoneStruct=Module["__Py_NoneStruct"]=2829304;var _internal_error=Module["_internal_error"]=3474312;var _conversion_error=Module["_conversion_error"]=3474316;var _PyExc_ImportError=Module["_PyExc_ImportError"]=2794508;var _pyodide_export_=Module["_pyodide_export_"]=2778088;var _pystate_keepalive_=Module["_pystate_keepalive_"]=2778092;var _pystate_keepalive=Module["_pystate_keepalive"]=3474508;var _compat_null_to_none=Module["_compat_null_to_none"]=3474324;var _py_jsnull=Module["_py_jsnull"]=3474456;var __Py_TrueStruct=Module["__Py_TrueStruct"]=2782932;var __Py_FalseStruct=Module["__Py_FalseStruct"]=2782948;var _Jsr_undefined=Module["_Jsr_undefined"]=3474436;var _jsbind=Module["_jsbind"]=3474380;var _Jsr_error=Module["_Jsr_error"]=3474432;var _PyExc_TypeError=Module["_PyExc_TypeError"]=2794476;var _PyExc_StopIteration=Module["_PyExc_StopIteration"]=2794484;var _PyTraceBack_Type=Module["_PyTraceBack_Type"]=3172300;var _PyExc_GeneratorExit=Module["_PyExc_GeneratorExit"]=2794488;var _PyExc_StopAsyncIteration=Module["_PyExc_StopAsyncIteration"]=2794480;var _PyExc_RuntimeError=Module["_PyExc_RuntimeError"]=2794584;var _PyExc_IndexError=Module["_PyExc_IndexError"]=2794836;var _PyExc_Exception=Module["_PyExc_Exception"]=2794472;var _PyExc_BaseException=Module["_PyExc_BaseException"]=2794468;var _methods=Module["_methods"]=2778896;var _PyExc_SystemError=Module["_PyExc_SystemError"]=2794880;var _PyExc_KeyError=Module["_PyExc_KeyError"]=2794840;var _PySlice_Type=Module["_PySlice_Type"]=2840400;var _PyLong_Type=Module["_PyLong_Type"]=2820548;var _PyBool_Type=Module["_PyBool_Type"]=2783108;var _PyExc_ValueError=Module["_PyExc_ValueError"]=2794500;var _PyExc_NotImplementedError=Module["_PyExc_NotImplementedError"]=2794596;var _PyBaseObject_Type=Module["_PyBaseObject_Type"]=2842440;var _PyExc_OverflowError=Module["_PyExc_OverflowError"]=2794872;var _PyList_Type=Module["_PyList_Type"]=2818960;var _PyTuple_Type=Module["_PyTuple_Type"]=2840912;var _PyExc_RuntimeWarning=Module["_PyExc_RuntimeWarning"]=2795124;var __Py_NotImplementedStruct=Module["__Py_NotImplementedStruct"]=2830080;var _default_signature=Module["_default_signature"]=3474388;var _no_default=Module["_no_default"]=3474384;var _PyCoro_Type=Module["_PyCoro_Type"]=2812480;var _PyGen_Type=Module["_PyGen_Type"]=2811952;var _PyDict_Type=Module["_PyDict_Type"]=2821568;var _compat_to_string_repr=Module["_compat_to_string_repr"]=3474404;var _PyMethod_Type=Module["_PyMethod_Type"]=2788264;var _PyFunction_Type=Module["_PyFunction_Type"]=2816820;var _py_buffer_len_offset=Module["_py_buffer_len_offset"]=2781544;var _py_buffer_shape_offset=Module["_py_buffer_shape_offset"]=2781548;var _Jsr_true=Module["_Jsr_true"]=3474440;var _Jsr_false=Module["_Jsr_false"]=3474444;var _Jsr_novalue=Module["_Jsr_novalue"]=3474448;var _PySet_Type=Module["_PySet_Type"]=2839024;var _PyFloat_Type=Module["_PyFloat_Type"]=2815052;var _compat_dict_to_literalmap=Module["_compat_dict_to_literalmap"]=3474452;var _threadstate_freelist_len=Module["_threadstate_freelist_len"]=3474504;var _threadstate_freelist=Module["_threadstate_freelist"]=3474464;var _stderr=Module["_stderr"]=3326136;var __PyParser_TokenNames=Module["__PyParser_TokenNames"]=2782224;var _PyExc_SyntaxError=Module["_PyExc_SyntaxError"]=2794612;var __PyExc_IncompleteInputError=Module["__PyExc_IncompleteInputError"]=2794624;var _PyExc_LookupError=Module["_PyExc_LookupError"]=2794832;var _PyExc_UnicodeDecodeError=Module["_PyExc_UnicodeDecodeError"]=2794852;var _PyExc_IndentationError=Module["_PyExc_IndentationError"]=2794616;var _PyExc_KeyboardInterrupt=Module["_PyExc_KeyboardInterrupt"]=2794504;var _PyExc_TabError=Module["_PyExc_TabError"]=2794620;var _PyExc_UnicodeError=Module["_PyExc_UnicodeError"]=2794844;var _stdin=Module["_stdin"]=3326288;var _PyExc_MemoryError=Module["_PyExc_MemoryError"]=2794888;var __PyRuntime=Module["__PyRuntime"]=2869536;var _PyComplex_Type=Module["_PyComplex_Type"]=2790556;var _PyUnicode_Type=Module["_PyUnicode_Type"]=2850192;var _PyBytes_Type=Module["_PyBytes_Type"]=2786480;var __Py_EllipsisObject=Module["__Py_EllipsisObject"]=2840256;var __Py_ctype_table=Module["__Py_ctype_table"]=477376;var _PyExc_DeprecationWarning=Module["_PyExc_DeprecationWarning"]=2795112;var _PyExc_SyntaxWarning=Module["_PyExc_SyntaxWarning"]=2795120;var __Py_ctype_tolower=Module["__Py_ctype_tolower"]=478400;var _PyExc_OSError=Module["_PyExc_OSError"]=2794516;var __PyOS_ReadlineTState=Module["__PyOS_ReadlineTState"]=3474580;var _PyOS_InputHook=Module["_PyOS_InputHook"]=3474584;var _PyOS_ReadlineFunctionPointer=Module["_PyOS_ReadlineFunctionPointer"]=3474588;var _PyType_Type=Module["_PyType_Type"]=2842048;var _PyExc_BufferError=Module["_PyExc_BufferError"]=2795100;var _PyCFunction_Type=Module["_PyCFunction_Type"]=2827960;var _PyByteArray_Type=Module["_PyByteArray_Type"]=2784400;var __PyByteArray_empty_string=Module["__PyByteArray_empty_string"]=3474593;var __PyUnion_Type=Module["__PyUnion_Type"]=2852728;var __Py_ctype_toupper=Module["__Py_ctype_toupper"]=478656;var _Py_hexdigits=Module["_Py_hexdigits"]=2858608;var _PyExc_BytesWarning=Module["_PyExc_BytesWarning"]=2795140;var _PyByteArrayIter_Type=Module["_PyByteArrayIter_Type"]=2784672;var __PyLong_DigitValue=Module["__PyLong_DigitValue"]=2819808;var _PyBytesIter_Type=Module["_PyBytesIter_Type"]=2786752;var _PyModule_Type=Module["_PyModule_Type"]=2828712;var _PyCapsule_Type=Module["_PyCapsule_Type"]=2787652;var _PyCell_Type=Module["_PyCell_Type"]=2787912;var _PyInstanceMethod_Type=Module["_PyInstanceMethod_Type"]=2788568;var _PyCode_Type=Module["_PyCode_Type"]=2789756;var _PyFrozenSet_Type=Module["_PyFrozenSet_Type"]=2839584;var _PyExc_ZeroDivisionError=Module["_PyExc_ZeroDivisionError"]=2794876;var _PyMethodDescr_Type=Module["_PyMethodDescr_Type"]=2791024;var _PyClassMethodDescr_Type=Module["_PyClassMethodDescr_Type"]=2791232;var _PyMemberDescr_Type=Module["_PyMemberDescr_Type"]=2791500;var _PyGetSetDescr_Type=Module["_PyGetSetDescr_Type"]=2791772;var _PyWrapperDescr_Type=Module["_PyWrapperDescr_Type"]=2792064;var _PyDictProxy_Type=Module["_PyDictProxy_Type"]=2793008;var _PyProperty_Type=Module["_PyProperty_Type"]=2793468;var _PyReversed_Type=Module["_PyReversed_Type"]=2794176;var _PyEnum_Type=Module["_PyEnum_Type"]=2793904;var _PyExc_BaseExceptionGroup=Module["_PyExc_BaseExceptionGroup"]=2794496;var _PyExc_UnicodeTranslateError=Module["_PyExc_UnicodeTranslateError"]=2794856;var _PyExc_BlockingIOError=Module["_PyExc_BlockingIOError"]=2794520;var _PyExc_BrokenPipeError=Module["_PyExc_BrokenPipeError"]=2794532;var _PyExc_ChildProcessError=Module["_PyExc_ChildProcessError"]=2794528;var _PyExc_ConnectionAbortedError=Module["_PyExc_ConnectionAbortedError"]=2794536;var _PyExc_ConnectionRefusedError=Module["_PyExc_ConnectionRefusedError"]=2794540;var _PyExc_ConnectionResetError=Module["_PyExc_ConnectionResetError"]=2794544;var _PyExc_FileExistsError=Module["_PyExc_FileExistsError"]=2794548;var _PyExc_FileNotFoundError=Module["_PyExc_FileNotFoundError"]=2794552;var _PyExc_IsADirectoryError=Module["_PyExc_IsADirectoryError"]=2794556;var _PyExc_NotADirectoryError=Module["_PyExc_NotADirectoryError"]=2794560;var _PyExc_InterruptedError=Module["_PyExc_InterruptedError"]=2794564;var _PyExc_PermissionError=Module["_PyExc_PermissionError"]=2794568;var _PyExc_ProcessLookupError=Module["_PyExc_ProcessLookupError"]=2794572;var _PyExc_TimeoutError=Module["_PyExc_TimeoutError"]=2794576;var _PyExc_EnvironmentError=Module["_PyExc_EnvironmentError"]=3474596;var _PyExc_IOError=Module["_PyExc_IOError"]=3474600;var _PyExc_SystemExit=Module["_PyExc_SystemExit"]=2794492;var _PyExc_ConnectionError=Module["_PyExc_ConnectionError"]=2794524;var _PyExc_EOFError=Module["_PyExc_EOFError"]=2794580;var _PyExc_RecursionError=Module["_PyExc_RecursionError"]=2794588;var _PyExc_PythonFinalizationError=Module["_PyExc_PythonFinalizationError"]=2794592;var _PyExc_NameError=Module["_PyExc_NameError"]=2794600;var _PyExc_UnboundLocalError=Module["_PyExc_UnboundLocalError"]=2794604;var _PyExc_UnicodeEncodeError=Module["_PyExc_UnicodeEncodeError"]=2794848;var _PyExc_AssertionError=Module["_PyExc_AssertionError"]=2794860;var _PyExc_ArithmeticError=Module["_PyExc_ArithmeticError"]=2794864;var _PyExc_FloatingPointError=Module["_PyExc_FloatingPointError"]=2794868;var _PyExc_ReferenceError=Module["_PyExc_ReferenceError"]=2794884;var _PyExc_Warning=Module["_PyExc_Warning"]=2795104;var _PyExc_UserWarning=Module["_PyExc_UserWarning"]=2795108;var _PyExc_PendingDeprecationWarning=Module["_PyExc_PendingDeprecationWarning"]=2795116;var _PyExc_FutureWarning=Module["_PyExc_FutureWarning"]=2795128;var _PyExc_ImportWarning=Module["_PyExc_ImportWarning"]=2795132;var _PyExc_UnicodeWarning=Module["_PyExc_UnicodeWarning"]=2795136;var _PyExc_EncodingWarning=Module["_PyExc_EncodingWarning"]=2795144;var _PyExc_ResourceWarning=Module["_PyExc_ResourceWarning"]=2795148;var _Py_GenericAliasType=Module["_Py_GenericAliasType"]=2811404;var _PyAsyncGen_Type=Module["_PyAsyncGen_Type"]=2813260;var __PyAsyncGenASend_Type=Module["__PyAsyncGenASend_Type"]=2813552;var _PyStdPrinter_Type=Module["_PyStdPrinter_Type"]=2814432;var __Py_SwappedOp=Module["__Py_SwappedOp"]=2829312;var _PyFrameLocalsProxy_Type=Module["_PyFrameLocalsProxy_Type"]=2815776;var _PyFrame_Type=Module["_PyFrame_Type"]=2816280;var _PyClassMethod_Type=Module["_PyClassMethod_Type"]=2817164;var _PyStaticMethod_Type=Module["_PyStaticMethod_Type"]=2817500;var _PySeqIter_Type=Module["_PySeqIter_Type"]=2817904;var _PyCallIter_Type=Module["_PyCallIter_Type"]=2818144;var _PyDictKeys_Type=Module["_PyDictKeys_Type"]=2823352;var _PyDictValues_Type=Module["_PyDictValues_Type"]=2823936;var _PyDictItems_Type=Module["_PyDictItems_Type"]=2823648;var _PyListIter_Type=Module["_PyListIter_Type"]=2819232;var _PyListRevIter_Type=Module["_PyListRevIter_Type"]=2819504;var _PyDictIterKey_Type=Module["_PyDictIterKey_Type"]=2821824;var _PyDictRevIterKey_Type=Module["_PyDictRevIterKey_Type"]=2822448;var _PyDictRevIterValue_Type=Module["_PyDictRevIterValue_Type"]=2822864;var _PyDictIterItem_Type=Module["_PyDictIterItem_Type"]=2822240;var _PyDictIterValue_Type=Module["_PyDictIterValue_Type"]=2822032;var _PyDictRevIterItem_Type=Module["_PyDictRevIterItem_Type"]=2822656;var _PyODict_Type=Module["_PyODict_Type"]=2824648;var _PyODictIter_Type=Module["_PyODictIter_Type"]=2824896;var _PyODictKeys_Type=Module["_PyODictKeys_Type"]=2825136;var _PyODictValues_Type=Module["_PyODictValues_Type"]=2825616;var _PyODictItems_Type=Module["_PyODictItems_Type"]=2825376;var _PyMemoryView_Type=Module["_PyMemoryView_Type"]=2827140;var _PyCMethod_Type=Module["_PyCMethod_Type"]=2828168;var _PyModuleDef_Type=Module["_PyModuleDef_Type"]=2828376;var __PyNone_Type=Module["__PyNone_Type"]=2829480;var __PyNotImplemented_Type=Module["__PyNotImplemented_Type"]=2829872;var _PyContextToken_Type=Module["_PyContextToken_Type"]=2859596;var _PyContextVar_Type=Module["_PyContextVar_Type"]=2859288;var _PyContext_Type=Module["_PyContext_Type"]=2858960;var _PyEllipsis_Type=Module["_PyEllipsis_Type"]=2840048;var _PyFilter_Type=Module["_PyFilter_Type"]=2856064;var _PyLongRangeIter_Type=Module["_PyLongRangeIter_Type"]=2838016;var _PyMap_Type=Module["_PyMap_Type"]=2856304;var _PyPickleBuffer_Type=Module["_PyPickleBuffer_Type"]=2836896;var _PyRangeIter_Type=Module["_PyRangeIter_Type"]=2837744;var _PyRange_Type=Module["_PyRange_Type"]=2837472;var _PySetIter_Type=Module["_PySetIter_Type"]=2838272;var _PySuper_Type=Module["_PySuper_Type"]=2842944;var _PyTupleIter_Type=Module["_PyTupleIter_Type"]=2841184;var _PyUnicodeIter_Type=Module["_PyUnicodeIter_Type"]=2850464;var _PyZip_Type=Module["_PyZip_Type"]=2856560;var __PyWeakref_CallableProxyType=Module["__PyWeakref_CallableProxyType"]=2853680;var __PyWeakref_ProxyType=Module["__PyWeakref_ProxyType"]=2853472;var __PyWeakref_RefType=Module["__PyWeakref_RefType"]=2853016;var __PySet_Dummy=Module["__PySet_Dummy"]=2839800;var _PyStructSequence_UnnamedField=Module["_PyStructSequence_UnnamedField"]=2840628;var __Py_ascii_whitespace=Module["__Py_ascii_whitespace"]=325408;var __PyIntrinsics_UnaryFunctions=Module["__PyIntrinsics_UnaryFunctions"]=2864528;var __PyIntrinsics_BinaryFunctions=Module["__PyIntrinsics_BinaryFunctions"]=2864624;var __PyEval_ConversionFuncs=Module["__PyEval_ConversionFuncs"]=2858592;var _Py_EMSCRIPTEN_SIGNAL_HANDLING=Module["_Py_EMSCRIPTEN_SIGNAL_HANDLING"]=3512276;var __PyEval_BinaryOps=Module["__PyEval_BinaryOps"]=2858480;var _PyExc_InterpreterError=Module["_PyExc_InterpreterError"]=2860024;var _PyExc_InterpreterNotFoundError=Module["_PyExc_InterpreterNotFoundError"]=2860028;var _PyUnstable_ExecutableKinds=Module["_PyUnstable_ExecutableKinds"]=2860512;var _Py_Version=Module["_Py_Version"]=460964;var _PyImport_Inittab=Module["_PyImport_Inittab"]=2862176;var __PyImport_FrozenBootstrap=Module["__PyImport_FrozenBootstrap"]=3321248;var _PyImport_FrozenModules=Module["_PyImport_FrozenModules"]=3521096;var __PyImport_FrozenStdlib=Module["__PyImport_FrozenStdlib"]=3321520;var __PyImport_FrozenTest=Module["__PyImport_FrozenTest"]=3321728;var _Py_IgnoreEnvironmentFlag=Module["_Py_IgnoreEnvironmentFlag"]=3511020;var _Py_IsolatedFlag=Module["_Py_IsolatedFlag"]=3511040;var _Py_BytesWarningFlag=Module["_Py_BytesWarningFlag"]=3511012;var _Py_InspectFlag=Module["_Py_InspectFlag"]=3511e3;var _Py_InteractiveFlag=Module["_Py_InteractiveFlag"]=3510996;var _Py_OptimizeFlag=Module["_Py_OptimizeFlag"]=3511004;var _Py_DebugFlag=Module["_Py_DebugFlag"]=3510984;var _Py_VerboseFlag=Module["_Py_VerboseFlag"]=3510988;var _Py_QuietFlag=Module["_Py_QuietFlag"]=3510992;var _Py_FrozenFlag=Module["_Py_FrozenFlag"]=3511016;var _Py_UnbufferedStdioFlag=Module["_Py_UnbufferedStdioFlag"]=3511032;var _Py_NoSiteFlag=Module["_Py_NoSiteFlag"]=3511008;var _Py_DontWriteBytecodeFlag=Module["_Py_DontWriteBytecodeFlag"]=3511024;var _Py_NoUserSiteDirectory=Module["_Py_NoUserSiteDirectory"]=3511028;var _Py_HashRandomizationFlag=Module["_Py_HashRandomizationFlag"]=3511036;var _Py_FileSystemDefaultEncoding=Module["_Py_FileSystemDefaultEncoding"]=3511144;var _Py_HasFileSystemDefaultEncoding=Module["_Py_HasFileSystemDefaultEncoding"]=3511148;var _Py_FileSystemDefaultEncodeErrors=Module["_Py_FileSystemDefaultEncodeErrors"]=3511152;var _Py_UTF8Mode=Module["_Py_UTF8Mode"]=3510980;var __Py_HashSecret=Module["__Py_HashSecret"]=3511160;var _PY_TIMEOUT_MAX=Module["_PY_TIMEOUT_MAX"]=492616;var __PyEM_EMSCRIPTEN_COUNT_ARGS_OFFSET=Module["__PyEM_EMSCRIPTEN_COUNT_ARGS_OFFSET"]=493560;var _ffi_type_pointer=Module["_ffi_type_pointer"]=2425108;var _ffi_type_void=Module["_ffi_type_void"]=2425e3;var _ffi_type_sint32=Module["_ffi_type_sint32"]=2425072;var _ffi_type_uint8=Module["_ffi_type_uint8"]=2425012;var _ffi_type_double=Module["_ffi_type_double"]=2425132;var _ffi_type_longdouble=Module["_ffi_type_longdouble"]=2425144;var _ffi_type_float=Module["_ffi_type_float"]=2425120;var _ffi_type_sint16=Module["_ffi_type_sint16"]=2425048;var _ffi_type_uint16=Module["_ffi_type_uint16"]=2425036;var _ffi_type_uint32=Module["_ffi_type_uint32"]=2425060;var _ffi_type_sint64=Module["_ffi_type_sint64"]=2425096;var _ffi_type_uint64=Module["_ffi_type_uint64"]=2425084;var _ffi_type_sint8=Module["_ffi_type_sint8"]=2425024;var _environ=Module["_environ"]=3521120;var __deduplicate_map=Module["__deduplicate_map"]=3521100;var _BZ2_crc32Table=Module["_BZ2_crc32Table"]=3321904;var _BZ2_rNums=Module["_BZ2_rNums"]=3322928;var _z_errmsg=Module["_z_errmsg"]=3325168;var __length_code=Module["__length_code"]=2435824;var __dist_code=Module["__dist_code"]=2435312;var _deflate_copyright=Module["_deflate_copyright"]=2430480;var _inflate_copyright=Module["_inflate_copyright"]=2435008;var ___environ=Module["___environ"]=3521120;var ____environ=Module["____environ"]=3521120;var __environ=Module["__environ"]=3521120;var ___stack_chk_guard=Module["___stack_chk_guard"]=3521132;var _daylight=Module["_daylight"]=3521140;var _timezone=Module["_timezone"]=3521136;var ___tzname=Module["___tzname"]=3521144;var ___timezone=Module["___timezone"]=3521136;var ___daylight=Module["___daylight"]=3521140;var _tzname=Module["_tzname"]=3521144;var ___progname=Module["___progname"]=3523072;var ___optreset=Module["___optreset"]=3522036;var _optind=Module["_optind"]=3325416;var ___optpos=Module["___optpos"]=3522040;var _optarg=Module["_optarg"]=3522044;var _optopt=Module["_optopt"]=3522048;var _opterr=Module["_opterr"]=3325420;var _optreset=Module["_optreset"]=3522036;var _h_errno=Module["_h_errno"]=3522172;var ___signgam=Module["___signgam"]=3537468;var __ns_flagdata=Module["__ns_flagdata"]=2623184;var ___progname_full=Module["___progname_full"]=3523076;var _program_invocation_short_name=Module["_program_invocation_short_name"]=3523072;var _program_invocation_name=Module["_program_invocation_name"]=3523076;var ___sig_pending=Module["___sig_pending"]=3527448;var ___sig_actions=Module["___sig_actions"]=3528368;var _signgam=Module["_signgam"]=3537468;var ___THREW__=Module["___THREW__"]=3544272;var ___threwValue=Module["___threwValue"]=3544276;var ___cxa_unexpected_handler=Module["___cxa_unexpected_handler"]=3336788;var ___cxa_terminate_handler=Module["___cxa_terminate_handler"]=3336784;var ___cxa_new_handler=Module["___cxa_new_handler"]=3567072;var ___wasm_lpad_context=Module["___wasm_lpad_context"]=3567616;var _in6addr_any=Module["_in6addr_any"]=2777900;var _in6addr_loopback=Module["_in6addr_loopback"]=2777916;function applySignatureConversions(wasmExports){wasmExports=Object.assign({},wasmExports);var makeWrapper_pp=f=>a0=>f(a0)>>>0;var makeWrapper_p=f=>()=>f()>>>0;var makeWrapper_pP=f=>a0=>f(a0)>>>0;var makeWrapper_ppp=f=>(a0,a1)=>f(a0,a1)>>>0;var makeWrapper_p_=f=>a0=>f(a0)>>>0;var makeWrapper_pppp=f=>(a0,a1,a2)=>f(a0,a1,a2)>>>0;var makeWrapper_ppppp=f=>(a0,a1,a2,a3)=>f(a0,a1,a2,a3)>>>0;wasmExports["malloc"]=makeWrapper_pp(wasmExports["malloc"]);wasmExports["__errno_location"]=makeWrapper_p(wasmExports["__errno_location"]);wasmExports["sbrk"]=makeWrapper_pP(wasmExports["sbrk"]);wasmExports["calloc"]=makeWrapper_ppp(wasmExports["calloc"]);wasmExports["strerror"]=makeWrapper_p_(wasmExports["strerror"]);wasmExports["pthread_self"]=makeWrapper_p(wasmExports["pthread_self"]);wasmExports["emscripten_stack_get_end"]=makeWrapper_p(wasmExports["emscripten_stack_get_end"]);wasmExports["emscripten_stack_get_base"]=makeWrapper_p(wasmExports["emscripten_stack_get_base"]);wasmExports["emscripten_builtin_malloc"]=makeWrapper_pp(wasmExports["emscripten_builtin_malloc"]);wasmExports["memcpy"]=makeWrapper_pppp(wasmExports["memcpy"]);wasmExports["_emscripten_find_dylib"]=makeWrapper_ppppp(wasmExports["_emscripten_find_dylib"]);wasmExports["emscripten_builtin_memalign"]=makeWrapper_ppp(wasmExports["emscripten_builtin_memalign"]);wasmExports["emscripten_stack_get_current"]=makeWrapper_p(wasmExports["emscripten_stack_get_current"]);wasmExports["emscripten_main_runtime_thread_id"]=makeWrapper_p(wasmExports["emscripten_main_runtime_thread_id"]);wasmExports["memalign"]=makeWrapper_ppp(wasmExports["memalign"]);wasmExports["emscripten_builtin_calloc"]=makeWrapper_ppp(wasmExports["emscripten_builtin_calloc"]);wasmExports["_emscripten_stack_alloc"]=makeWrapper_pp(wasmExports["_emscripten_stack_alloc"]);wasmExports["__cxa_get_exception_ptr"]=makeWrapper_pp(wasmExports["__cxa_get_exception_ptr"]);return wasmExports}function callMain(args=[]){var entryFunction=resolveGlobalSymbol("main").sym;if(!entryFunction)return;args.unshift(thisProgram);var argc=args.length;var argv=stackAlloc((argc+1)*4);var argv_ptr=argv;args.forEach(arg=>{HEAPU32[argv_ptr>>>2>>>0]=stringToUTF8OnStack(arg);argv_ptr+=4});HEAPU32[argv_ptr>>>2>>>0]=0;try{var ret=entryFunction(argc,argv);exitJS(ret,true);return ret}catch(e){return handleException(e)}}function run(args=arguments_){if(runDependencies>0){dependenciesFulfilled=run;return}preRun();if(runDependencies>0){dependenciesFulfilled=run;return}function doRun(){Module["calledRun"]=true;if(ABORT)return;initRuntime();preMain();readyPromiseResolve(Module);Module["onRuntimeInitialized"]?.();var noInitialRun=Module["noInitialRun"]||false;if(!noInitialRun)callMain(args);postRun()}if(Module["setStatus"]){Module["setStatus"]("Running...");setTimeout(()=>{setTimeout(()=>Module["setStatus"](""),1);doRun()},1)}else{doRun()}}function preInit(){if(Module["preInit"]){if(typeof Module["preInit"]=="function")Module["preInit"]=[Module["preInit"]];while(Module["preInit"].length>0){Module["preInit"].shift()()}}}preInit();run();moduleRtn=readyPromise; return moduleRtn; } ); })(); globalThis._createPyodideModule = _createPyodideModule; ================================================ FILE: public/pyodide/pyodide.js ================================================ "use strict";var loadPyodide=(()=>{var re=Object.create;var F=Object.defineProperty;var ie=Object.getOwnPropertyDescriptor;var oe=Object.getOwnPropertyNames;var ae=Object.getPrototypeOf,se=Object.prototype.hasOwnProperty;var o=(e,t)=>F(e,"name",{value:t,configurable:!0}),m=(e=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(e,{get:(t,n)=>(typeof require<"u"?require:t)[n]}):e)(function(e){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+e+'" is not supported')});var le=(e,t)=>{for(var n in t)F(e,n,{get:t[n],enumerable:!0})},$=(e,t,n,i)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of oe(t))!se.call(e,a)&&a!==n&&F(e,a,{get:()=>t[a],enumerable:!(i=ie(t,a))||i.enumerable});return e};var b=(e,t,n)=>(n=e!=null?re(ae(e)):{},$(t||!e||!e.__esModule?F(n,"default",{value:e,enumerable:!0}):n,e)),ce=e=>$(F({},"__esModule",{value:!0}),e);var H=(()=>{for(var e=new Uint8Array(128),t=0;t<64;t++)e[t<26?t+65:t<52?t+71:t<62?t-4:t*4-205]=t;return n=>{for(var i=n.length,a=new Uint8Array((i-(n[i-1]=="=")-(n[i-2]=="="))*3/4|0),r=0,s=0;r>4,a[s++]=c<<4|d>>2,a[s++]=d<<6|u}return a}})();var $e={};le($e,{loadPyodide:()=>B,version:()=>x});function de(e){return!isNaN(parseFloat(e))&&isFinite(e)}o(de,"_isNumber");function N(e){return e.charAt(0).toUpperCase()+e.substring(1)}o(N,"_capitalize");function T(e){return function(){return this[e]}}o(T,"_getter");var I=["isConstructor","isEval","isNative","isToplevel"],w=["columnNumber","lineNumber"],_=["fileName","functionName","source"],ue=["args"],fe=["evalOrigin"],D=I.concat(w,_,ue,fe);function y(e){if(e)for(var t=0;t-1&&(r=r.replace(/eval code/g,"eval").replace(/(\(eval at [^()]*)|(,.*$)/g,""));var s=r.replace(/^\s+/,"").replace(/\(eval code/g,"(").replace(/^.*?\s+/,""),l=s.match(/ (\(.+\)$)/);s=l?s.replace(l[0],""):s;var c=this.extractLocation(l?l[1]:s),d=l&&s||void 0,u=["eval",""].indexOf(c[0])>-1?void 0:c[0];return new L({functionName:d,fileName:u,lineNumber:c[1],columnNumber:c[2],source:r})},this)},"ErrorStackParser$$parseV8OrIE"),parseFFOrSafari:o(function(i){var a=i.stack.split(` `).filter(function(r){return!r.match(t)},this);return a.map(function(r){if(r.indexOf(" > eval")>-1&&(r=r.replace(/ line (\d+)(?: > eval line \d+)* > eval:\d+:\d+/g,":$1")),r.indexOf("@")===-1&&r.indexOf(":")===-1)return new L({functionName:r});var s=/((.*".+"[^@]*)?[^@]*)(?:@)/,l=r.match(s),c=l&&l[1]?l[1]:void 0,d=this.extractLocation(r.replace(s,""));return new L({functionName:c,fileName:d[0],lineNumber:d[1],columnNumber:d[2],source:r})},this)},"ErrorStackParser$$parseFFOrSafari")}}o(me,"ErrorStackParser");var pe=new me;var j=pe;function ye(){if(typeof API<"u"&&API!==globalThis.API)return API.runtimeEnv;let e=typeof Bun<"u",t=typeof Deno<"u",n=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string"&&!process.browser,i=typeof navigator=="object"&&typeof navigator.userAgent=="string"&&navigator.userAgent.indexOf("Chrome")===-1&&navigator.userAgent.indexOf("Safari")>-1;return ge({IN_BUN:e,IN_DENO:t,IN_NODE:n,IN_SAFARI:i,IN_SHELL:typeof read=="function"&&typeof load=="function"})}o(ye,"getGlobalRuntimeEnv");var f=ye();function ge(e){let t=e.IN_NODE&&typeof module<"u"&&module.exports&&typeof m=="function"&&typeof __dirname=="string",n=e.IN_NODE&&!t,i=!e.IN_NODE&&!e.IN_DENO&&!e.IN_BUN,a=i&&typeof window<"u"&&typeof window.document<"u"&&typeof document.createElement=="function"&&"sessionStorage"in window&&typeof globalThis.importScripts!="function",r=i&&typeof globalThis.WorkerGlobalScope<"u"&&typeof globalThis.self<"u"&&globalThis.self instanceof globalThis.WorkerGlobalScope;return{...e,IN_BROWSER:i,IN_BROWSER_MAIN_THREAD:a,IN_BROWSER_WEB_WORKER:r,IN_NODE_COMMONJS:t,IN_NODE_ESM:n}}o(ge,"calculateDerivedFlags");var z,C,J,V,U;async function W(){if(!f.IN_NODE||(z=(await import(/* webpackIgnore */"node:url")).default,V=await import(/* webpackIgnore */"node:fs"),U=await import(/* webpackIgnore */"node:fs/promises"),J=(await import(/* webpackIgnore */"node:vm")).default,C=await import(/* webpackIgnore */"node:path"),M=C.sep,typeof m<"u"))return;let e=V,t=await import(/* webpackIgnore */"node:crypto"),n=await import(/* webpackIgnore */"ws"),i=await import(/* webpackIgnore */"node:child_process"),a={fs:e,crypto:t,ws:n,child_process:i};globalThis.require=function(r){return a[r]}}o(W,"initNodeModules");function be(e,t){return C.resolve(t||".",e)}o(be,"node_resolvePath");function ve(e,t){return t===void 0&&(t=location),new URL(e,t).toString()}o(ve,"browser_resolvePath");var R;f.IN_NODE?R=be:f.IN_SHELL?R=o(e=>e,"resolvePath"):R=ve;var M;f.IN_NODE||(M="/");function Pe(e,t){return e.startsWith("file://")&&(e=e.slice(7)),e.includes("://")?{response:fetch(e)}:{binary:U.readFile(e).then(n=>new Uint8Array(n.buffer,n.byteOffset,n.byteLength))}}o(Pe,"node_getBinaryResponse");function Ee(e,t){if(e.startsWith("file://")&&(e=e.slice(7)),e.includes("://"))throw new Error("Shell cannot fetch urls");return{binary:Promise.resolve(new Uint8Array(readbuffer(e)))}}o(Ee,"shell_getBinaryResponse");function he(e,t){let n=new URL(e,location);return{response:fetch(n,t?{integrity:t}:{})}}o(he,"browser_getBinaryResponse");var A;f.IN_NODE?A=Pe:f.IN_SHELL?A=Ee:A=he;async function q(e,t){let{response:n,binary:i}=A(e,t);if(i)return i;let a=await n;if(!a.ok)throw new Error(`Failed to load '${e}': request failed.`);return new Uint8Array(await a.arrayBuffer())}o(q,"loadBinaryFile");var k;if(f.IN_BROWSER_MAIN_THREAD)k=o(async e=>await import(/* webpackIgnore */e),"loadScript");else if(f.IN_BROWSER_WEB_WORKER)k=o(async e=>{try{globalThis.importScripts(e)}catch(t){if(t instanceof TypeError)await import(/* webpackIgnore */e);else throw t}},"loadScript");else if(f.IN_NODE)k=Ne;else if(f.IN_SHELL)k=load;else throw new Error("Cannot determine runtime environment");async function Ne(e){e.startsWith("file://")&&(e=e.slice(7)),e.includes("://")?J.runInThisContext(await(await fetch(e)).text()):await import(/* webpackIgnore */z.pathToFileURL(e).href)}o(Ne,"nodeLoadScript");async function G(e){if(f.IN_NODE){await W();let t=await U.readFile(e,{encoding:"utf8"});return JSON.parse(t)}else if(f.IN_SHELL){let t=read(e);return JSON.parse(t)}else return await(await fetch(e)).json()}o(G,"loadLockFile");async function K(){if(f.IN_NODE_COMMONJS)return __dirname;let e;try{throw new Error}catch(i){e=i}let t=j.parse(e)[0].fileName;if(f.IN_NODE&&!t.startsWith("file://")&&(t=`file://${t}`),f.IN_NODE_ESM){let i=await import(/* webpackIgnore */"node:path");return(await import(/* webpackIgnore */"node:url")).fileURLToPath(i.dirname(t))}let n=t.lastIndexOf(M);if(n===-1)throw new Error("Could not extract indexURL path from pyodide module location. Please pass the indexURL explicitly to loadPyodide.");return t.slice(0,n)}o(K,"calculateDirname");function Y(e){return e.substring(0,e.lastIndexOf("/")+1)||globalThis.location?.toString()||"."}o(Y,"calculateInstallBaseUrl");function X(e){let t=e.FS,n=e.FS.filesystems.MEMFS,i=e.PATH,a={DIR_MODE:16895,FILE_MODE:33279,mount:o(function(r){if(!r.opts.fileSystemHandle)throw new Error("opts.fileSystemHandle is required");return n.mount.apply(null,arguments)},"mount"),syncfs:o(async(r,s,l)=>{try{let c=a.getLocalSet(r),d=await a.getRemoteSet(r),u=s?d:c,g=s?c:d;await a.reconcile(r,u,g),l(null)}catch(c){l(c)}},"syncfs"),getLocalSet:o(r=>{let s=Object.create(null);function l(u){return u!=="."&&u!==".."}o(l,"isRealDir");function c(u){return g=>i.join2(u,g)}o(c,"toAbsolute");let d=t.readdir(r.mountpoint).filter(l).map(c(r.mountpoint));for(;d.length;){let u=d.pop(),g=t.stat(u);t.isDir(g.mode)&&d.push.apply(d,t.readdir(u).filter(l).map(c(u))),s[u]={timestamp:g.mtime,mode:g.mode}}return{type:"local",entries:s}},"getLocalSet"),getRemoteSet:o(async r=>{let s=Object.create(null),l=await Se(r.opts.fileSystemHandle);for(let[c,d]of l)c!=="."&&(s[i.join2(r.mountpoint,c)]={timestamp:d.kind==="file"?new Date((await d.getFile()).lastModified):new Date,mode:d.kind==="file"?a.FILE_MODE:a.DIR_MODE});return{type:"remote",entries:s,handles:l}},"getRemoteSet"),loadLocalEntry:o(r=>{let l=t.lookupPath(r,{}).node,c=t.stat(r);if(t.isDir(c.mode))return{timestamp:c.mtime,mode:c.mode};if(t.isFile(c.mode))return l.contents=n.getFileDataAsTypedArray(l),{timestamp:c.mtime,mode:c.mode,contents:l.contents};throw new Error("node type not supported")},"loadLocalEntry"),storeLocalEntry:o((r,s)=>{if(t.isDir(s.mode))t.mkdirTree(r,s.mode);else if(t.isFile(s.mode))t.writeFile(r,s.contents,{canOwn:!0});else throw new Error("node type not supported");t.chmod(r,s.mode),t.utime(r,s.timestamp,s.timestamp)},"storeLocalEntry"),removeLocalEntry:o(r=>{var s=t.stat(r);t.isDir(s.mode)?t.rmdir(r):t.isFile(s.mode)&&t.unlink(r)},"removeLocalEntry"),loadRemoteEntry:o(async r=>{if(r.kind==="file"){let s=await r.getFile();return{contents:new Uint8Array(await s.arrayBuffer()),mode:a.FILE_MODE,timestamp:new Date(s.lastModified)}}else{if(r.kind==="directory")return{mode:a.DIR_MODE,timestamp:new Date};throw new Error("unknown kind: "+r.kind)}},"loadRemoteEntry"),storeRemoteEntry:o(async(r,s,l)=>{let c=r.get(i.dirname(s)),d=t.isFile(l.mode)?await c.getFileHandle(i.basename(s),{create:!0}):await c.getDirectoryHandle(i.basename(s),{create:!0});if(d.kind==="file"){let u=await d.createWritable();await u.write(l.contents),await u.close()}r.set(s,d)},"storeRemoteEntry"),removeRemoteEntry:o(async(r,s)=>{await r.get(i.dirname(s)).removeEntry(i.basename(s)),r.delete(s)},"removeRemoteEntry"),reconcile:o(async(r,s,l)=>{let c=0,d=[];Object.keys(s.entries).forEach(function(p){let v=s.entries[p],S=l.entries[p];(!S||t.isFile(v.mode)&&v.timestamp.getTime()>S.timestamp.getTime())&&(d.push(p),c++)}),d.sort();let u=[];if(Object.keys(l.entries).forEach(function(p){s.entries[p]||(u.push(p),c++)}),u.sort().reverse(),!c)return;let g=s.type==="remote"?s.handles:l.handles;for(let p of d){let v=i.normalize(p.replace(r.mountpoint,"/")).substring(1);if(l.type==="local"){let S=g.get(v),ne=await a.loadRemoteEntry(S);a.storeLocalEntry(p,ne)}else{let S=a.loadLocalEntry(p);await a.storeRemoteEntry(g,v,S)}}for(let p of u)if(l.type==="local")a.removeLocalEntry(p);else{let v=i.normalize(p.replace(r.mountpoint,"/")).substring(1);await a.removeRemoteEntry(g,v)}},"reconcile")};e.FS.filesystems.NATIVEFS_ASYNC=a}o(X,"initializeNativeFS");var Se=o(async e=>{let t=[];async function n(a){for await(let r of a.values())t.push(r),r.kind==="directory"&&await n(r)}o(n,"collect"),await n(e);let i=new Map;i.set(".",e);for(let a of t){let r=(await e.resolve(a)).join("/");i.set(r,a)}return i},"getFsHandles");var Q=H("AGFzbQEAAAABDANfAGAAAW9gAW8BfwMDAgECByECD2NyZWF0ZV9zZW50aW5lbAAAC2lzX3NlbnRpbmVsAAEKEwIHAPsBAPsbCwkAIAD7GvsUAAs=");var we=async function(){if(!(globalThis.navigator&&(/iPad|iPhone|iPod/.test(navigator.userAgent)||navigator.platform==="MacIntel"&&typeof navigator.maxTouchPoints<"u"&&navigator.maxTouchPoints>1)))try{let t=await WebAssembly.compile(Q);return await WebAssembly.instantiate(t)}catch(t){if(t instanceof WebAssembly.CompileError)return;throw t}}();async function Z(){let e=await we;if(e)return e.exports;let t=Symbol("error marker");return{create_sentinel:o(()=>t,"create_sentinel"),is_sentinel:o(n=>n===t,"is_sentinel")}}o(Z,"getSentinelImport");function ee(e){let t={config:e,runtimeEnv:f},n={noImageDecoding:!0,noAudioDecoding:!0,noWasmDecoding:!1,preRun:Oe(e),print:e.stdout,printErr:e.stderr,onExit(i){n.exitCode=i},thisProgram:e._sysExecutable,arguments:e.args,API:t,locateFile:o(i=>e.indexURL+i,"locateFile"),instantiateWasm:xe(e.indexURL)};return n}o(ee,"createSettings");function _e(e){return function(t){let n="/";try{t.FS.mkdirTree(e)}catch(i){console.error(`Error occurred while making a home directory '${e}':`),console.error(i),console.error(`Using '${n}' for a home directory instead`),e=n}t.FS.chdir(e)}}o(_e,"createHomeDirectory");function ke(e){return function(t){Object.assign(t.ENV,e)}}o(ke,"setEnvironment");function Re(e){return e?[async t=>{t.addRunDependency("fsInitHook");try{await e(t.FS,{sitePackages:t.API.sitePackages})}finally{t.removeRunDependency("fsInitHook")}}]:[]}o(Re,"callFsInitHook");function Ae(e){let t=e.HEAPU32[e._Py_Version>>>2],n=t>>>24&255,i=t>>>16&255,a=t>>>8&255;return[n,i,a]}o(Ae,"computeVersionTuple");function Fe(e){let t=q(e);return async n=>{n.API.pyVersionTuple=Ae(n);let[i,a]=n.API.pyVersionTuple;n.FS.mkdirTree("/lib"),n.API.sitePackages=`/lib/python${i}.${a}/site-packages`,n.FS.mkdirTree(n.API.sitePackages),n.addRunDependency("install-stdlib");try{let r=await t;n.FS.writeFile(`/lib/python${i}${a}.zip`,r)}catch(r){console.error("Error occurred while installing the standard library:"),console.error(r)}finally{n.removeRunDependency("install-stdlib")}}}o(Fe,"installStdlib");function Oe(e){let t;return e.stdLibURL!=null?t=e.stdLibURL:t=e.indexURL+"python_stdlib.zip",[Fe(t),_e(e.env.HOME),ke(e.env),X,...Re(e.fsInit)]}o(Oe,"getFileSystemInitializationFuncs");function xe(e){if(typeof WasmOffsetConverter<"u")return;let{binary:t,response:n}=A(e+"pyodide.asm.wasm"),i=Z();return function(a,r){return async function(){a.sentinel=await i;try{let s;n?s=await WebAssembly.instantiateStreaming(n,a):s=await WebAssembly.instantiate(await t,a);let{instance:l,module:c}=s;r(l,c)}catch(s){console.warn("wasm instantiation failed!"),console.warn(s)}}(),{}}}o(xe,"getInstantiateWasmFunc");var te="0.29.3";function O(e){return e===void 0||e.endsWith("/")?e:e+"/"}o(O,"withTrailingSlash");var x=te;async function De(e={}){if(await W(),e.lockFileContents&&e.lockFileURL)throw new Error("Can't pass both lockFileContents and lockFileURL");let t=e.indexURL||await K();if(t=O(R(t)),e.packageBaseUrl=O(e.packageBaseUrl),e.cdnUrl=O(e.packageBaseUrl??`https://cdn.jsdelivr.net/pyodide/v${x}/full/`),!e.lockFileContents){let a=e.lockFileURL??t+"pyodide-lock.json";e.lockFileContents=G(a),e.packageBaseUrl??=Y(a)}e.indexURL=t,e.packageCacheDir&&(e.packageCacheDir=O(R(e.packageCacheDir)));let n={fullStdLib:!1,jsglobals:globalThis,stdin:globalThis.prompt?()=>globalThis.prompt():void 0,args:[],env:{},packages:[],packageCacheDir:e.packageBaseUrl,enableRunUntilComplete:!0,checkAPIVersion:!0,BUILD_ID:"b7b7b0f46eb68e65c029c0dc739270e8a5d35251e9aab6014ee1c2f630e5d1d0"},i=Object.assign(n,e);return i.env.HOME??="/home/pyodide",i.env.PYTHONINSPECT??="1",i}o(De,"initializeConfiguration");function Le(e){let t=ee(e),n=t.API;return n.lockFilePromise=Promise.resolve(e.lockFileContents),t}o(Le,"createEmscriptenSettings");async function Te(e){if(typeof _createPyodideModule!="function"){let t=`${e.indexURL}pyodide.asm.js`;await k(t)}}o(Te,"loadWasmScript");async function Ce(e,t){if(!e._loadSnapshot)return;let n=await e._loadSnapshot,i=ArrayBuffer.isView(n)?n:new Uint8Array(n);return t.noInitialRun=!0,t.INITIAL_MEMORY=i.length,i}o(Ce,"prepareSnapshot");async function Ue(e){let t=await _createPyodideModule(e);if(e.exitCode!==void 0)throw new t.ExitStatus(e.exitCode);return t}o(Ue,"createPyodideModule");function We(e,t){let n=e.API;if(t.pyproxyToStringRepr&&n.setPyProxyToStringMethod(!0),t.convertNullToNone&&n.setCompatNullToNone(!0),t.toJsLiteralMap&&n.setCompatToJsLiteralMap(!0),n.version!==x&&t.checkAPIVersion)throw new Error(`Pyodide version does not match: '${x}' <==> '${n.version}'. If you updated the Pyodide version, make sure you also updated the 'indexURL' parameter passed to loadPyodide.`);e.locateFile=i=>{throw i.endsWith(".so")?new Error(`Failed to find dynamic library "${i}"`):new Error(`Unexpected call to locateFile("${i}")`)}}o(We,"configureAPI");function Me(e,t,n){let i=e.API,a;return t&&(a=i.restoreSnapshot(t)),i.finalizeBootstrap(a,n._snapshotDeserializer)}o(Me,"bootstrapPyodide");async function Be(e,t){let n=e._api;return n.sys.path.insert(0,""),n._pyodide.set_excepthook(),await n.packageIndexReady,n.initializeStreams(t.stdin,t.stdout,t.stderr),e}o(Be,"finalizeSetup");async function B(e={}){let t=await De(e),n=Le(t);await Te(t);let i=await Ce(t,n),a=await Ue(n);We(a,t);let r=Me(a,i,t);return await Be(r,t)}o(B,"loadPyodide");globalThis.loadPyodide=B;return ce($e);})(); try{Object.assign(exports,loadPyodide)}catch(_){} globalThis.loadPyodide=loadPyodide.loadPyodide; //# sourceMappingURL=pyodide.js.map ================================================ FILE: public/pyodide/scipy-1.14.1-cp313-cp313-pyodide_2025_0_wasm32.whl ================================================ [File too large to display: 14.1 MB] ================================================ FILE: public/robots.txt ================================================ User-agent: * Allow: / ================================================ FILE: scripts/generate-parser.js ================================================ import { promisify } from 'util'; import { exec } from 'child_process'; import packageInfo from '../package.json' with { type: 'json'}; async function generateParser() { const execPromise = promisify(exec); process.chdir('./src/parser'); // check antlr4 version let output try { output = await execPromise('antlr4', {shell: '/bin/bash'}); } catch(e) { console.error('Missing antlr4 executable'); process.exit(1); } const requiredVersion = packageInfo.dependencies.antlr4.match(/(\d+\.\d+\.\d+)/)[0] const installedVersion = output.stdout.match(/Version (\d+\.\d+\.\d+)/)[1]; if (requiredVersion !== installedVersion) { console.error(`Error: antlr4 version mismatch, required: ${requiredVersion}, installed: ${installedVersion}`); process.exit(1); } // generate lexer try { await execPromise('antlr4 -Dlanguage=TypeScript LatexLexer.g4', {shell: '/bin/bash'}); } catch(e) { console.error(`Error generating lexer: ${e}`); process.exit(1); } // generate parser try { await execPromise('antlr4 -Dlanguage=TypeScript -visitor -no-listener LatexParser.g4', {shell: '/bin/bash'}); await execPromise("sed -i '1i// @ts-nocheck' LatexParserVisitor.ts", {shell: '/bin/bash'}); await execPromise("sed -i '1i// @ts-nocheck' LatexParser.ts", {shell: '/bin/bash'}); } catch(e) { console.error(`Error generating parser visitor: ${e}`); process.exit(1); } } generateParser(); ================================================ FILE: scripts/get_pyodide_files.py ================================================ # /// script # requires-python = ">=3.12" # dependencies = [ # "pkginfo", # "packaging", # "pyodide-lock==0.1.2", # ] # /// pyodide_cli_version = "0.5.0" pyodide_build_version = "0.34.1" from pathlib import Path import json import shutil import os import subprocess import sys from pyodide_lock import PyodideLockSpec from pyodide_lock.utils import add_wheels_to_spec if len(sys.argv) != 3: print("Path to source pyodide files must be provided as the first argument and new version must be provided as second argument. No additional arguments may be supplied.") exit(1) source_dir = Path(sys.argv[1]) new_version = int(sys.argv[2]) script_dir = Path(os.path.dirname(os.path.realpath(__file__))) destination_dir = script_dir / "../public/pyodide" lockfile = destination_dir / "pyodide-lock.json" pyodide_info_file = script_dir / "../src/pyodide-info.json" # These are the high level packages that need to be exposed to EP and the user for code cells # All needed dependencies will be autmatically added seed_packages = [ "sympy", "numpy", "coolprop", "scipy", "matplotlib", "jedi", "scikit-learn", "drawsvg", "six", "pandas", "jinja2", "rich", "nlopt" ] packages_to_hide_from_ui = [ "six", "pylab", "mpl_toolkits", "isympy", "jedi" ] base_files = [ "pyodide-lock.json", "pyodide.asm.js", "pyodide.asm.wasm", "pyodide.js", "python_stdlib.zip", ] with open(source_dir / "pyodide-lock.json") as package_file: packages = json.load(package_file) python_version = packages["info"]["python"] pyodide_version = packages["info"]["version"] packages = packages["packages"] available_packages = {} # clear contents of destination directory if it exists if os.path.exists(destination_dir): shutil.rmtree(destination_dir) os.makedirs(destination_dir) # first, download any packages that are not bundled with pyodide (must be pure python) new_packages = [] for package in seed_packages: if not package in packages: print(f"**** {package} not in standard Pyodide distribution, downloading from PyPI") subprocess.run(['uvx', 'pip', 'download', '-d', destination_dir, package ]) new_packages.append(package) wheels_to_add = os.listdir(destination_dir) print("--------------Wheels added--------------------") for package in wheels_to_add: if "py3-none-any" not in package: raise Exception(f"Cannot add a wheel that is not pure Python, attempting to add {package}") print(package) print("----------------------------------------------") needed_packages = set(seed_packages) for package in seed_packages: if package in packages: needed_packages.update(packages[package]["depends"]) for import_name in packages[package]["imports"]: if import_name not in packages_to_hide_from_ui: available_packages[import_name] = { "pyodideName": package, "version": packages[package]["version"], } needed_files = set(base_files) for needed_package in needed_packages: if needed_package in packages: needed_files.add(packages[needed_package]["file_name"]) # copy required files from source to destination for file in needed_files: shutil.copy(source_dir / file, destination_dir) # add new wheels to lockfile lock_spec = PyodideLockSpec.from_json(lockfile) wheel_paths = [destination_dir / wheel for wheel in wheels_to_add] lock_spec = add_wheels_to_spec(lock_spec, wheel_paths) for package in new_packages: if package not in packages_to_hide_from_ui: available_packages[package] = { "pyodideName": package, "version": lock_spec.packages[package].version, } lock_spec.to_json(lockfile) with open(pyodide_info_file, 'r', encoding='utf-8') as file: pyodide_info = json.load(file) pyodide_info.append({ "releaseVersion": new_version, "latestPermalink": f"https://{new_version}.engineeringpaper.xyz/", "info": { "pythonVersion": python_version, "pyodideVersion": pyodide_version, "availablePackages": available_packages, } }) with open(pyodide_info_file, "w") as file: json.dump(pyodide_info, file, indent=2) print('Compiling packages...') env = os.environ.copy() env["SOURCE_DATE_EPOCH"] = "315532800" env["PYTHONHASHSEED"] = "0" subprocess.run( [ "uvx", "--from", f"pyodide-cli=={pyodide_cli_version}", "--with", f"pyodide-build=={pyodide_build_version}", "--python", python_version, "pyodide", "py-compile", "--silent", destination_dir, ], env=env ) print('...finished.') ================================================ FILE: scripts/setupTypeScript.js ================================================ // @ts-check /** This script modifies the project to support TS code in .svelte files like: As well as validating the code for CI. */ /** To work on this script: rm -rf test-template template && git clone sveltejs/template test-template && node scripts/setupTypeScript.js test-template */ const fs = require("fs") const path = require("path") const { argv } = require("process") const projectRoot = argv[2] || path.join(__dirname, "..") // Add deps to pkg.json const packageJSON = JSON.parse(fs.readFileSync(path.join(projectRoot, "package.json"), "utf8")) packageJSON.devDependencies = Object.assign(packageJSON.devDependencies, { "svelte-check": "^1.0.0", "svelte-preprocess": "^4.0.0", "@rollup/plugin-typescript": "^6.0.0", "typescript": "^3.9.3", "tslib": "^2.0.0", "@tsconfig/svelte": "^1.0.0" }) // Add script for checking packageJSON.scripts = Object.assign(packageJSON.scripts, { "validate": "svelte-check" }) // Write the package JSON fs.writeFileSync(path.join(projectRoot, "package.json"), JSON.stringify(packageJSON, null, " ")) // mv src/main.js to main.ts - note, we need to edit rollup.config.js for this too const beforeMainJSPath = path.join(projectRoot, "src", "main.js") const afterMainTSPath = path.join(projectRoot, "src", "main.ts") fs.renameSync(beforeMainJSPath, afterMainTSPath) // Switch the app.svelte file to use TS const appSveltePath = path.join(projectRoot, "src", "App.svelte") let appFile = fs.readFileSync(appSveltePath, "utf8") appFile = appFile.replace(" {#if fileDropActive} fileDropActive=false} on:drop={handleFileDrop} on:dragenter={e => fileDropActive=true} on:dragleave={e => fileDropActive=false} /> {/if}
e.preventDefault()} ondragenter={e => fileDropActive = !modalInfo.modalOpen} >
{#if serviceWorkerUpdateWaiting} {/if} window.history.back()} icon={ArrowLeft} /> window.history.forward()} icon={ArrowRight} /> window.print()} icon={Printer} />
{#if !inIframe} handleLinkPushState(e, '/') } /> handleLinkPushState(e, `/${tutorialHash}`) } />
{#if !usingDefaultConfig}
{/if}
{:else} window.open(window.location.href, "_blank")} icon={Launch} /> {/if}
{#if !inIframe} window.dispatchEvent(new Event('resize'))} > {#each exampleSheets as {path, title} (path)} handleLinkPushState(e, path)} >
{title}
{/each}
{#each prebuiltTables as {url, title} (url)} handleLinkPushState(e, `/${getSheetHash(new URL(url))}`)} >
{title}
{/each}
{#if appState.history.length > 0} {#each appState.history as {url, hash, creation} (hash+creation)} {#if hash === "file"}
{`Saved as File: ${url}`}
{(new Date(creation)).toLocaleString()}
{:else} handleLinkPushState(e, `/${hash}`)} /> {/if} {/each}
{/if} {#if appState.insertedSheets.length > 0} {#each appState.insertedSheets as {title, url, insertion}} {#if url === "file"}
{`File Inserted: ${title}`}
{(new Date(insertion)).toLocaleString()}
{:else} handleLinkPushState(e, `/${getSheetHash(new URL(url))}`)} >
{title}
{(new Date(insertion)).toLocaleString()}
{/if} {/each}
{/if} {#if recentSheets.size > 0} {#each [...recentSheets] as [key, value] (key)} {#if "url" in value} ("url" in value) ? handleLinkPushState(e, `/${getSheetHash(new URL(value.url))}`) : null} >
{value.title}
{(new Date(value.accessTime)).toLocaleString()}
{:else} ("fileHandle" in value) ? openSheetFromFileHandle(value.fileHandle) : null} >
{`File: ${value.fileName}`}
{(new Date(value.accessTime)).toLocaleString()}
{/if} {/each}
{/if} showTerms()} text="Terms and Conditions" /> modalInfo = { modalOpen: true, state: "bugReport", heading: "Bug Report" }} text="Bug Report" /> modalInfo = { modalOpen: true, state: "newVersion", heading: "Releases" }} text="Releases" /> showRequestPersistentStorage()} text="Enable Persistent Local Storage" /> modalInfo = { modalOpen: true, state: "tryEpxyz", heading: "Now Available at EPxyz.com" }} text=".xyz blocked? Try EPxyz.com" />
{/if}
appState.activeCell = -1} >
appState.activeCell = -1} >
{event.preventDefault(); ensureMathFieldVisible(event);} } >
{#if (termsAccepted < appState.termsVersion) && !inIframe} {:else} {#if noParsingErrors || appState.parsePending} {#if (inDebounce || appState.parsePending) && !pyodideNotAvailable && pyodideLoaded} {:else} {#await pyodidePromise} {#if !pyodideLoaded && !pyodideNotAvailable && !error} {:else if pyodideLoaded && !pyodideNotAvailable} {/if} {:catch promiseError} {/await} {/if} {#if error && !inDebounce} {/if} {#if pyodideNotAvailable} {/if} {:else} {/if} {/if} {#if !inIframe && showKeyboard} {/if} {#if modalInfo.modalOpen} {#if modalInfo.state === "sheetSettings"} modalInfo.modalOpen = false} on:click:button--secondary={() => {mathCellConfigDialog?.resetDefaults(); baseUnitsConfigDialog?.resetDefaults(); numberFormatOptionsDialog?.resetDefaults(); appState.config.simplifySymbolicExpressions = true; appState.config.convertFloatsToFractions = true;}} bind:open={modalInfo.modalOpen} preventCloseOnClickOutside={true} > {#if modalInfo.mathCell} {:else if modalInfo.dataTableCell} triggerSaveNeeded()} nullIfDefault={true} /> {:else} {triggerSaveNeeded(); mathCellChanged();}} /> {triggerSaveNeeded(); mathCellChanged();}} /> {/if} {:else if modalInfo.state === "customMatrix"} {:else if modalInfo.state === "downloadDocument"} saveSheetToFile(e.detail.saveAs)} downloadDocument={(e) => getDocument(e.detail)} /> {:else if modalInfo.state === "insertSheet"} {:else} (modalInfo.modalOpen = false)} on:open on:close on:submit={() => uploadSheet()} hasScrollingContent={["supportedUnits", "termsAndConditions", "newVersion", "keyboardShortcuts", "generateCode", "pyodideRuntimeWarning"].includes(modalInfo.state)} preventCloseOnClickOutside={!["supportedUnits", "bugReport", "tryEpxyz", "newVersion", "updateAvailable", "keyboardShortcuts"].includes(modalInfo.state)} > {#if modalInfo.state === "uploadSheet"}

Saving this document will create a private shareable link that can be used to access this document in the future. Anyone you share this link with will be able to access the document.

{:else if modalInfo.state === "uploadPending"} {:else if modalInfo.state === "success"}

Save this link in order to be able to access or share this sheet.


{:else if modalInfo.state === "retrieving"} {:else if modalInfo.state === "generatingDocument"} {:else if modalInfo.state === "opening"} {:else if modalInfo.state === "importingSpreadsheet"} {:else if modalInfo.state === "saving"} {:else if modalInfo.state === "restoring"} {:else if modalInfo.state === "bugReport"}

If you have discovered a bug in EngineeringPaper.xyz, please send a bug report to support@engineeringpaper.xyz. Please include a description of the problem. Additionally, it's best if you can include a link to the sheet that is experiencing the problem.

{:else if modalInfo.state === "tryEpxyz"}

Some environments indiscriminately block all .xyz domains. For example, some school districts block all .xyz domains for their school issued Chromebooks. Since it's important to us that all of the EngineeringPaper.xyz goodness is available to everyone, the full functionality of EngineeringPaper.xyz is now also available as a .com address at EPxyz.com. The functionality is the same between the two domains and sheets saved on one can be opened on the other. Shareable links are interchangeable as well. For example, https://engineeringpaper.xyz/fFjTsnFoSQMLwcvteVoNtL and https://epxyz.com/fFjTsnFoSQMLwcvteVoNtL point to the same sheet.

{:else if modalInfo.state === "supportedUnits"} {:else if modalInfo.state === "keyboardShortcuts"} {:else if modalInfo.state === "termsAndConditions"} {:else if modalInfo.state === "requestPersistentStorage"} {:else if modalInfo.state === "newVersion"} {:else if modalInfo.state === "updateAvailable"} {:else if modalInfo.state === "generateCode"} {:else if modalInfo.state === "pyodideRuntimeWarning"} {#if modalInfo.runtimeInfo.oldRuntime}

This sheet contains code cells and was created with an old Python runtime. Code cell calculations could change due to package version differences in this new runtime. The old and new runtime versions are listed below. If your code cells need to run in their original runtime, the most recent permalink that uses this sheet's Python runtime is: {modalInfo.runtimeInfo.safePermalink}


Check the results of your code cells with this new runtime. If everything looks good, save this sheet to remove this warning. The see this message again, reopen this sheet without saving it.


Original Python Environment
Python{modalInfo.runtimeInfo.oldPyodideInfo.pythonVersion}
Pyodide{modalInfo.runtimeInfo.oldPyodideInfo.pyodideVersion}

Original Python Modules
{#each Object.entries(modalInfo.runtimeInfo.oldPyodideInfo.availablePackages).sort((a, b) => a[0].toLowerCase().localeCompare(b[0].toLowerCase())) as [key, value]}
{key}{value.version}
{/each}
New Python Environment
Python{modalInfo.runtimeInfo.newPyodideInfo.pythonVersion}
Pyodide{modalInfo.runtimeInfo.newPyodideInfo.pyodideVersion}

New Python Modules
{#each Object.entries(modalInfo.runtimeInfo.newPyodideInfo.availablePackages).sort((a, b) => a[0].toLowerCase().localeCompare(b[0].toLowerCase())) as [key, value]}
{key}{value.version}
{/each}
{/if} {:else} {@html modalInfo.error} {/if}
{/if} {/if}
================================================ FILE: src/BaseUnitsConfigDialog.svelte ================================================
Unit System Shortcuts
{#each baseUnitSystems.keys() as name} {/each}
{#each baseUnitChoices as dimension (dimension.name)}
({id: value, text: value}))} on:select={update} />
{/each}
================================================ FILE: src/ButtonBar.svelte ================================================ {#if appState.onMobile && (!last || appState.inCellInsertMode) }
{:else if appState.onMobile}
{:else}

addCellWrapper('math', index)} id={last ? "add-math-cell" : `add-math-cell-${index}`} noTouch={!last} > addCellWrapper('documentation', index)} id={last ? "add-documentation-cell" : `add-documentation-cell-${index}`} noTouch={!last} > addCellWrapper('plot', index)} id={last ? "add-plot-cell" : `add-plot-cell-${index}`} noTouch={!last} > addCellWrapper('table', index)} id={last ? "add-table-cell" : `add-table-cell-${index}`} noTouch={!last} > addCellWrapper('dataTable', index)} id={last ? "add-data-table-cell" : `add-data-table-cell-${index}`} noTouch={!last} > addCellWrapper('piecewise', index)} id={last ? "add-piecewise-cell" : `add-piecewise-cell-${index}`} noTouch={!last} > addCellWrapper('system', index)} id={last ? "add-system-cell" : `add-system-cell-${index}`} noTouch={!last} > addCellWrapper('code', index)} id={last ? "add-code-cell" : `add-code-cell-${index}`} noTouch={!last} > addCellWrapper('fluid', index)} id={last ? "add-fluid-cell" : `add-fluid-cell-${index}`} noTouch={!last} > dispatchInsertSheet(index)} id={last ? "insert-sheet" : null} noTouch={!last} >
{/if} ================================================ FILE: src/Cell.svelte ================================================
moveUp(index)} title="Move Cell Up" > moveDown(index)} title="Move Cell Down" >
handleClickInCell(index)} onfocusin={() => handleClickInCell(index)} bind:this={contentDiv} > {#if cell instanceof MathCell} {:else if cell instanceof DocumentationCell} {:else if cell instanceof PlotCell} {:else if cell instanceof TableCell} {:else if cell instanceof DataTableCell} {:else if cell instanceof PiecewiseCell} {:else if cell instanceof SystemCell} {:else if cell instanceof FluidCell} {:else if cell instanceof CodeCell} {:else if cell instanceof DeletedCell} {:else if cell instanceof InsertCell} {/if}
{deleteCell(index); triggerSaveNeeded(); mathCellChanged();}} title="Delete Cell" >
================================================ FILE: src/CellList.svelte ================================================
    {#each appState.cells as cell, i (cell.id)}
  • {/each}
================================================ FILE: src/CodeCell.svelte ================================================
parseLatex(e.latex, codeCell.mathField)} enter={() => insertMathCellAfter({detail: {index: index}})} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={codeCell?.mathField} parsingError={codeCell.mathField.parsingError} parsePending={codeCell.mathField.parsePending} bind:this={codeCell.mathField.element} latex={codeCell.mathField.latex} /> {#if codeCell.mathField.parsingError} {codeCell.mathField.parsingErrorMessage} {:else} {/if}
Python Environment
Python{currentPyodideInfo.pythonVersion}
Pyodide{currentPyodideInfo.pyodideVersion}

Available Python Modules
{#each Object.entries(currentPyodideInfo.availablePackages).sort((a, b) => a[0].toLowerCase().localeCompare(b[0].toLowerCase())) as [key, value]}
{key}{value.version}
{/each}
insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathCellChanged={mathCellChanged} triggerSaveNeeded={triggerSaveNeeded} bind:this={codeEditor} /> {#if stdout}
{stdout}
{/if}
================================================ FILE: src/CodeEditor.svelte ================================================
================================================ FILE: src/CustomMatrixModal.svelte ================================================ (open = false)} on:open on:close on:submit={insertMatrix} hasScrollingContent={false} preventCloseOnClickOutside={true} >
================================================ FILE: src/DataTableCell.svelte ================================================
Import Spreadsheet Export CSV {copyButtonText} {#if numInputs >= 2} handleAddInterpolationFunction('interpolation')} > Add Interpolation handleAddInterpolationFunction('polyfit')} > Add Polyfit {/if}
{#if dataTableCell.parameterFields} {#each dataTableCell.parameterFields as mathField, j (mathField.id)}
parseParameterField(e.latex, j, mathField)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={mathField} parsingError={mathField.parsingError} parsePending={mathField.parsePending} bind:this={mathField.element} latex={mathField.latex} /> {#if mathField.parsingError} {#if !mathField.parsePending} {mathField.parsingErrorMessage} {/if} {:else if dataTableCell.columnErrors[j]} {dataTableCell.columnErrors[j]} {:else if j === 0}
Place variable names or column queries in this row
{:else}
{/if}
{/each} {/if} {#if dataTableCell.parameterUnitFields} {#each dataTableCell.parameterUnitFields as mathField, j (mathField.id)}
{#if dataTableCell.columnIsOutput[j]}
handleUpdateNumberFormat(j)} statusDot={Boolean(dataTableCell.columnFormatOptions[j])} >
{:else} parseUnitField(e.latex, j, mathField)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={mathField} parsingError={mathField.parsingError} parsePending={mathField.parsePending} bind:this={mathField.element} latex={mathField.latex} /> {#if mathField.parsingError } {#if !mathField.parsePending} {mathField.parsingErrorMessage} {/if} {:else if j === 0}
Place column specific units in this row (optional)
{:else}
{/if} {/if}
{/each} {/if} {#if numInterpolationDefs > 0} {#each dataTableCell.interpolationDefinitions as def, i} {#each dataTableCell.columnIsOutput as isOutput, j }
{#if j === 0}
parseInterpolationDefNameField(e.latex, i, def.nameField)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={def?.nameField} parsingError={def.nameField.parsingError} parsePending={def.nameField.parsePending} bind:this={def.nameField.element} latex={def.nameField.latex} /> {#if def.nameField.parsingError} {#if !def.nameField.parsePending} {def.nameField.parsingErrorMessage} {/if} {:else} def.nameField.element?.getMathField()?.executeCommand('copyToClipboard')} title="Copy function name to clipboard" id={`copy-interpolation-function-name-${index}-${i}`} > {/if} {#if def.type === "polyfit"} {:else if dataTableCell.interpolationFunctions[i]?.type === "gridInterpolation"}
2D grid data detected, using bilinear interpolation
{/if}
{/if} {#if !isOutput}
{#each def.inputs as inputIndex, k}
handleInputOutputChange(i)} >
{/each}
handleInputOutputChange(i)} >
{/if}
{/each}
handleDeleteInterpoloationDef(i)} title={`Delete ${def.type === "polyfit" ? "Polyfit" : "Interpolation"} Function`} id={`delete-interpolation-row-${index}-${i}`} >
{/each} {/if} {#if dataTableCell.columnData} {#each Array(numRows) as _, i } {#each Array(numColumns) as _, j } {@const nonNumeric = isNaN(Number(dataTableCell.columnData[j][i]))}
{#if dataTableCell.columnIsOutput[j]} {@const value = dataTableCell.columnData[j][i]} {#if !appState.resultsInvalid && value !== ""} {format(parseFloat(value), columnFormatOptions[j])} {/if} {:else} handleEnter(i)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} id={`data-table-input-${index}-${i}-${j}`} bind:textContent={dataTableCell.columnData[j][i]} input={() => parseDataField(j)} error={nonNumeric} > {#if nonNumeric} Data table must contain numeric values {:else}
{/if} {/if}
{/each} {/each} {/if} {#if numColumns > 1} {#each Array(numColumns) as _, j}
deleteColumn(j)} title="Delete Column" id={`delete-col-${index}-${j}`} >
{/each} {/if} {#if numRows > 1} {#each Array(numRows) as _, i}
deleteRow(i)} title="Delete Row" id={`delete-row-${index}-${i}`} >
{/each} {/if}
{#if numRows > 1}
{/if}
================================================ FILE: src/DataTableInput.svelte ================================================
================================================ FILE: src/DeletedCell.svelte ================================================

Deleting Cell

================================================ FILE: src/DocumentTitle.svelte ================================================

{appState.activeCell = -1; spellcheck = true}} onblur={() => spellcheck = false} contenteditable="true" bind:textContent={title} oninput={() => triggerSaveNeeded()} {spellcheck} >

================================================ FILE: src/DocumentationCell.svelte ================================================
{ documentationCell.documentationField.delta = e.detail.delta; triggerSaveNeeded(); }} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} />
================================================ FILE: src/DocumentationField.svelte ================================================
================================================ FILE: src/DownloadDocumentModal.svelte ================================================ (open = false)} on:open on:close on:submit={handleSave} hasScrollingContent={false} preventCloseOnClickOutside={false} >
{#if window.showSaveFilePicker}
Save As
{/if}
Markdown Options
================================================ FILE: src/DropOverlay.svelte ================================================
Drop File or
Link to Open
Hit Escape Key or Click to Dismiss
================================================ FILE: src/FluidCell.svelte ================================================
{#if FluidCell.FLUIDS.get(fluidConfig.fluid)?.incompressibleMixture}
{/if}
{#if FluidCell.FLUIDS.get(fluidConfig.fluid).longDescription}
{FluidCell.FLUIDS.get(fluidConfig.fluid).longDescription}
{/if} {#if fluidConfig.fluid === "CustomMixture"} {#each fluidConfig.customMixture as component, i}
{#if fluidConfig.customMixture.length > 2} deleteRow(i)} title="Delete Mixture Component" id={`delete-row-${index}-${i}`} > {/if} {#if i === fluidConfig.customMixture.length - 1} {/if}
{/each} {/if}
{#if fluidConfig.fluid === "HumidAir"} {/if}
parseLatex(e.latex, fluidCell.mathField)} enter={() => insertMathCellAfter({detail: {index: index}})} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={fluidCell?.mathField} parsingError={fluidCell.mathField.parsingError} parsePending={fluidCell.mathField.parsePending} bind:this={fluidCell.mathField.element} latex={fluidCell.mathField.latex} /> {#if fluidCell.error} {#if !fluidCell.mathField.parsingError || !fluidCell.mathField.parsePending}
{fluidCell.errorMessage}
{/if} {:else} fluidCell.mathField.element?.getMathField()?.executeCommand('copyToClipboard')} title={`Copy ${FluidCell.FLUID_PROPS_PARAMETERS.get(fluidCell.output)?.trivial ? "Constant" : "Function"} Name to Clipboard`} id={`copy-fluid-symbol-name-${index}`} > {/if}
The fluid models in EngineeringPaper.xyz are powered by the CoolProp library. For more information on these models, see the CoolProp documentation.
================================================ FILE: src/GenerateCodeDialog.svelte ================================================
Always test the generated code against known values, report issues or errors to support@engineeringpaper.xyz
{#await pyodidePromise} {:then promiseReturn} {#if generatedCode} {/if} {:catch promiseError} {/await} ================================================ FILE: src/IconButton.svelte ================================================ ================================================ FILE: src/InsertCell.svelte ================================================
{#if !appState.onMobile}

Press the number to the desired cell type or press Escape to cancel:

{/if}
================================================ FILE: src/InsertSheetModal.svelte ================================================ (open = false)} on:open on:close on:submit={handleSubmit} hasScrollingContent={true} preventCloseOnClickOutside={true} >
================================================ FILE: src/KeyboardButton.svelte ================================================ ================================================ FILE: src/KeyboardShortcuts.svelte ================================================
Global Shortcuts
{modifier} + S Save current sheet to local file
{modifier} + Shift + S Save current sheet to local file with a new filename instead of replacing existing file
{modifier} + L Save current sheet to database to get a shareable link
{modifier} + O Open sheet from local file (replaces currently loaded sheet)
{modifier} + Shift + N Load blank sheet (replaces currently loaded sheet)
{modifier} + Select cell above current cell
{modifier} + Select cell below current cell
{modifier} + D Delete current cell
Enter Insert Math Cell when in a Math Cell, or add row when in a Plot, Table, Piecewise Expression, or System Solve Cell
Shift + Enter Insert Math Cell
{modifier} + Enter then 1 Insert Math Cell
{modifier} + Enter then 2 Insert Documentation Cell
{modifier} + Enter then 3 Insert Plot Cell
{modifier} + Enter then 4 Insert Selector Table Cell
{modifier} + Enter then 5 Insert Data Table Cell
{modifier} + Enter then 6 Insert Piecewise Expression Cell
{modifier} + Enter then 7 Insert System Solve Cell
{modifier} + Enter then 8 Insert Code Cell
{modifier} + Enter then 9 Insert Fluid Properties Cell
{modifier} + Enter then 0 Insert Sheet
Esc Unselect all cells
{#if modifier === "Ctrl"} {:else} {/if}
Math Field Shortcuts
* Multiply
/ Divide
{modifier} + E Insert *10^ for scientific notation
< then = Insert less than or equal to symbol (≤)
> then = Insert greater than or equal to symbol (≥)
Type sqrt Insert square root
Type pi, e, or i Inserts the reserved variable π, Euler's number e, or imaginary unit i
Type the name of a lower case Greek letter Inserts a lower case Greek character (updates after leaving the current math field, start with a backslash \ to update immediately), recognizes alpha, beta, gamma, delta, epsilon, zeta, eta, theta, iota, kappa, lambda, mu, nu, xi, rho, sigma, tau, phi, chi, psi, and omega
Type the name of an upper case Greek character Inserts an upper case Greek character (updates after leaving the current math field, start with a backslash \ to update immediately), recognizes Gamma, Delta, Theta, Lambda, Xi, Pi, Sigma, Upsilon, Phi, Psi, and Omega
Tab Navigate to next location in equation, if available, otherwise navigate to next focusable element on page
^ Add exponent
_ Add subscript
@ or {modifier} + * Matrix multiply or cross product in the special case where both matrices are 3x1 or 1x3
{modifier} + ' Matrix Transpose
, , , or Navigate within math field
{modifier} + \ Toggle visibility of virtual keyboard
" Toggle comment mode in a math field
Type \int Inserts an integral
Type \der Inserts a derivative
Type \dder Inserts a double derivative
Type \tder Inserts a triple derivative
Type \sum Inserts summation notation
Type \prod Inserts product notation
{modifier} + Z Undo edit in current math field
{modifier} + Y{modifier} + Shift + ZRedo edit in current math field
Type \hat Add hat accent to variable name
Type \bar Add bar accent to variable name
Type \vec Add vector accent to variable name
Type \dot Add dot accent to variable name
Type \ddot Add double dot accent to variable name
' Add prime accent to variable name
{#if modifier === "Ctrl"} {:else} {/if}
Documentation Field Shortcuts
{modifier} + B Set selected text to Bold
{modifier} + I Set selected text to Italics
{modifier} + U Set selected text to Underline
{modifier} + K Insert link at selected text
{modifier} + E Insert formula at cursor location (uses LaTeX notation)
{modifier} + Z Undo edit in current documentation field
{modifier} + Y{modifier} + Shift + ZRedo edit in current documentation field
{#if modifier === "Ctrl"} {:else} {/if} {#if modifier === "Ctrl"} {:else} {/if}
Code Editor Shortcuts
{modifier} + / Toggle comment
Tab Increase Indent
Shift + Tab Decrease Indent
{modifier} + MOpt + Shift + MToggle tab key behaviour for code editor (tab to indent or tab to navigate page)
Ctrl + Space Show autocomplete menu
{modifier} + Z Undo edit in current code editor
{modifier} + Y{modifier} + Shift + ZRedo edit in current code editor
================================================ FILE: src/MathCell.svelte ================================================ parseLatex(e.latex, index)} enter={() => insertMathCellAfter({detail: {index: index}})} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={mathCell?.mathField} parsingError={mathCell.mathField.parsingError} parsePending={mathCell.mathField.parsePending} bind:this={mathCell.mathField.element} latex={mathCell.mathField.latex} /> {#if mathCell.mathField.parsingError} {#if !mathCell.mathField.parsePending} {mathCell.mathField.parsingErrorMessage} {/if} {#if result && !(result instanceof Array) && !renderResult} ================================================ FILE: src/MathCellConfigDialog.svelte ================================================
update(null, true)} /> update()} symbolicOutput={currentMathCellConfig.symbolicOutput} />
================================================ FILE: src/MathField.svelte ================================================ ================================================ FILE: src/NumberFormatOptionsDialog.svelte ================================================
================================================ FILE: src/PiecewiseCell.svelte ================================================
parseLatex(e.latex, piecewiseCell.parameterField)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={piecewiseCell?.parameterField} parsingError={piecewiseCell.parameterField.parsingError} parsePending={piecewiseCell.parameterField.parsePending} bind:this={piecewiseCell.parameterField.element} latex={piecewiseCell.parameterField.latex} /> {#if piecewiseCell.parameterField.parsingError && !piecewiseCell.parameterField.parsePending} {piecewiseCell.parameterField.parsingErrorMessage} {/if}
=
{#if piecewiseCell.expressionFields} {#each piecewiseCell.expressionFields as mathField, i (mathField.id)}
parseLatex(e.latex, mathField)} enter={() => handleEnter(i)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={mathField} parsingError={mathField.parsingError} parsePending={mathField.parsePending} bind:this={mathField.element} latex={mathField.latex} /> {#if mathField.parsingError && !mathField.parsePending} {mathField.parsingErrorMessage} {/if}
{#if i === numRows - 1}
otherwise
{/if} {#if i < piecewiseCell.conditionFields.length} {#each piecewiseCell.conditionFields as conditionMathField, ii (conditionMathField.id)} {#if i === ii}
if
parseLatex(e.latex, conditionMathField)} enter={() => handleEnter(i)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={conditionMathField} parsingError={conditionMathField.parsingError} parsePending={conditionMathField.parsePending} bind:this={conditionMathField.element} latex={conditionMathField.latex} /> {#if conditionMathField.parsingError && !conditionMathField.parsePending} {conditionMathField.parsingErrorMessage} {/if}
{#if numRows > 2 }
deleteRow(i)} title="Delete Row" id={`delete-row-${index}-${i}`} >
{/if} {/if} {/each} {/if} {/each} {/if}
================================================ FILE: src/Plot.svelte ================================================
================================================ FILE: src/PlotCell.svelte ================================================
log x log y 1:1 Ratio {copyButtonText}
{#if plotCell.mathFields} {#each plotCell.mathFields as mathField, i (mathField.id)}
parseLatex(e.latex, mathField)} enter={() => handleEnter(i)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={mathField} parsingError={mathField.parsingError} parsePending={mathField.parsePending} bind:this={mathField.element} latex={mathField.latex} /> {#if mathField.parsingError} {#if !mathField.parsePending} {mathField.parsingErrorMessage} {/if} {:else if mathField.latex && isPlotResult(appState.results[index]) && appState.results[index][i] && appState.results[index].length === plotRenderData.length} {@const plotData = appState.results[index][i].data[0]} {@const renderData = plotRenderData[i]} {#if plotData.scatterErrorMessage} {plotData.scatterErrorMessage} {:else if plotData.parametricErrorMessage} {plotData.parametricErrorMessage} {:else if !plotData.numericInput} X-axis limits of plot do not evaluate to a number {:else if !plotData.limitsUnitsMatch} Units of the x-axis upper and lower limits do not match {:else if !plotData.numericOutput} Results of expression does not evaluate to finite and real numeric values {:else if !unitsValid(renderData.displayInputUnits)} X-axis upper and/or lower limit dimension error{renderData.asciiInputUnits.startsWith("Dimension Error:") ? renderData.asciiInputUnits.slice(15) : ""} {:else if !unitsValid(renderData.displayOutputUnits)} Y-axis dimension error{renderData.asciiOutputUnits.startsWith("Dimension Error:") ? renderData.asciiOutputUnits.slice(15) : ""} {:else if renderData.unitsMismatch} { renderData.unitsMismatchReason ? renderData.unitsMismatchReason : "Units Mismatch" } {:else if plotData.negLogLimit} Lower and/or upper limit less than or equal to zero, not all points can be plotted with the log x option enabled {:else if plotData.inputReversed} Upper and lower limits of plot range are reversed {/if} {/if}
{#if numRows > 1 }
deleteRow(i)} title="Delete Row" id={`delete-row-${index}-${i}`} >
{/if} {/each}
{/if}
================================================ FILE: src/RequestPersistentStorage.svelte ================================================

EngineeringPaper.xyz uses your browser's local storage to store your default sheet config, your {numCheckpoints ?? ""} most recent autosave checkpoints, and your list of recently visited sheets. Your web browser will not automatically persist this local storage and may clear it at any time. Safari is particularly aggressive about freeing this storage and will automatically clear local storage for a site that has not been visited in the previous seven days.


Click the button below to request that your browser enables persistent local storage for the {hostName} domain. Your browser may popup a dialog that asks you to approve this request. Chrome and Edge may require you to bookmark {hostName} in order to enable persistent storage.


{#if persisted} Persistent local storage is currently enabled. {:else} Persistent local storage is currently disabled. {/if}


================================================ FILE: src/SetDefaultConfigDialog.svelte ================================================

{#if configsMatch} The current sheet config matches the user default config. {:else if !currentConfigIsDefaultConfig} The current sheet config differs from the user default config, the buttons below can be used to either save this sheet's config as the user default config or apply the user default config to this sheet. {:else} The current sheet is using the EngineeringPaper.xyz default config which is different than the user default config. The user default config can be applied to this sheet using the second button below. {/if}

================================================ FILE: src/SystemCell.svelte ================================================
System =
{#if systemCell.expressionFields} {#each systemCell.expressionFields as mathField, i (mathField.id)}
parseLatex(e.latex, mathField)} enter={() => handleEnter(i)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={mathField} parsingError={mathField.parsingError} parsePending={mathField.parsePending} bind:this={mathField.element} latex={mathField.latex} /> {#if mathField.parsingError && !mathField.parsePending} {mathField.parsingErrorMessage} {/if}
{#if numRows > 1 }
deleteRow(i)} title="Delete Row" id={`delete-row-${index}-${i}`} >
{/if} {/each} {/if}
{#if appState.system_results[index]} {#if appState.system_results[index].error}
{appState.system_results[index].error}
{:else}
Solution =
{#each Object.getOwnPropertyNames(appState.system_results[index].solutions) as var_name, i} {#each appState.system_results[index].solutions[var_name] as value, j} {#if j === 0}
0) { result += `${startDelimiter}\\text{${tableCell.rowLabels[row].label}} \\quad `; if (columnExpressions.length > 1) { result += ` \\begin{cases} `; for (const [col, expression] of columnExpressions.entries()) { result += expression; if (col < columnExpressions.length - 1) { result += " \\\\ "; } } result += " \\end{cases}"; } else { result += columnExpressions[0].replace('& = \\quad', '='); } result = result.trimEnd() + `${endDelimiter} \n\n`; } return result; } onMount(() => { if (tableCell.rowDeltas.length > 0) { tableCell.richTextInstance.setContents(tableCell.rowDeltas[tableCell.selectedRow]); } if (appState.activeCell === index) { focus(); } }); function focus() { if ( containerDiv && containerDiv.parentElement && !containerDiv.parentElement.contains(document.activeElement) ) { const mathElement: HTMLTextAreaElement = document.querySelector(`#grid-cell-${index}-0-0 math-field`); if (mathElement) { mathElement.focus(); } } } async function handleSelectedRowChange() { triggerSaveNeeded(true); await tableCell.parseTableStatements(); if (tableCell.rowDeltas.length > 0) { (tableCell.richTextInstance as any).setContents(tableCell.rowDeltas[tableCell.selectedRow]); } mathCellChanged(); } function addRowDocumentation() { tableCell.addRowDocumentation() appState.cells = appState.cells; } function deleteRowDocumentation() { tableCell.deleteRowDocumentation() appState.cells = appState.cells; } function highlightDiv(id: string) { const labelElement = document.querySelector(id) as HTMLDivElement | null; if (labelElement) { labelElement.focus(); const selection = window.getSelection(); const range = document.createRange(); range.selectNodeContents(labelElement); selection.removeAllRanges(); selection.addRange(range); } } async function addRow() { tableCell.addRow(); appState.cells = appState.cells; await tick(); highlightDiv(`#row-label-${index}-${numRows-1}`); } function addColumn() { tableCell.addColumn(); appState.cells[index] = appState.cells[index]; triggerSaveNeeded(); mathCellChanged(); } async function deleteRow(rowIndex: number) { triggerSaveNeeded(true); if (tableCell.deleteRow(rowIndex)) { await handleSelectedRowChange(); } else { await tableCell.parseTableStatements(); } appState.cells[index] = appState.cells[index]; mathCellChanged(); } async function deleteColumn(colIndex: number) { triggerSaveNeeded(true); tableCell.deleteColumn(colIndex); await tableCell.parseTableStatements(); appState.cells[index] = appState.cells[index]; mathCellChanged(); } function handleEnter(row: number) { if (!hideUnselected) { if (row == numRows-1) { addRow(); } else { highlightDiv(`#row-label-${index}-${row+1}`) } } } async function parseLatex(latex: string, column: number, mathField?: MathFieldClass) { triggerSaveNeeded(true); if (mathField !== undefined) { await mathField.parseLatex(latex); } else { await tableCell.parseUnitField(latex, column); } await tableCell.parseTableStatements(); appState.cells[index] = appState.cells[index]; mathCellChanged(); } $effect( () => { if (appState.activeCell === index) { focus(); } }); {#if tableCell.rowDeltas.length > 0}
{ tableCell.rowDeltas[tableCell.selectedRow] = e.detail.delta; triggerSaveNeeded(); }} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} />
{/if}
{#if tableCell.parameterFields} {#each tableCell.parameterFields as mathField, j (mathField.id)}
parseLatex(e.latex, j, mathField)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={mathField} parsingError={mathField.parsingError} parsePending={mathField.parsePending} bind:this={mathField.element} latex={mathField.latex} /> {#if mathField.parsingError && !mathField.parsePending} {mathField.parsingErrorMessage} {/if}
{/each} {/if} {#if tableCell.parameterUnitFields} {#each tableCell.parameterUnitFields as mathField, j (mathField.id)}
parseLatex(e.latex, j)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={mathField} parsingError={mathField.parsingError} parsePending={mathField.parsePending} bind:this={mathField.element} latex={mathField.latex} /> {#if mathField.parsingError && !mathField.parsePending} {mathField.parsingErrorMessage} {/if}
{/each} {/if} {#if tableCell.rhsFields} {#each tableCell.rhsFields as rowFields, i } {#if tableCell.rowLabels} {#if tableCell.rowLabels[i]} {#if !hideUnselected || i === tableCell.selectedRow}
handleEnter(i)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} id={`row-label-${index}-${i}`} bind:textContent={tableCell.rowLabels[i].label} oninput={() => triggerSaveNeeded()} >
{/if} {/if} {/if} {#each rowFields as mathField, j (mathField.id)} {#if !hideUnselected || i === tableCell.selectedRow}
parseLatex(e.latex, j, mathField)} enter={() => handleEnter(i)} shiftEnter={() => insertMathCellAfter({detail: {index: index}})} modifierEnter={() => insertInsertCellAfter({detail: {index: index}})} mathField={mathField} parsingError={mathField.parsingError} parsePending={mathField.parsePending} bind:this={mathField.element} latex={mathField.latex} /> {#if mathField.parsingError && !mathField.parsePending} {mathField.parsingErrorMessage} {/if}
{/if} {/each} {/each} {/if} {#if numColumns > 1 && !hideUnselected} {#each Array(numColumns) as _, j}
deleteColumn(j)} title="Delete Column" id={`delete-col-${index}-${j}`} >
{/each} {/if} {#if numRows > 1 && !hideUnselected} {#each Array(numRows) as _, i}
deleteRow(i)} title="Delete Row" id={`delete-row-${index}-${i}`} >
{/each} {/if} {#if !hideUnselected}
{/if}
{#if !hideUnselected} {/if}
{#if !hideUnselected} {#if tableCell.rowDeltas.length === 0} {:else} {/if} {/if} Place variable names in this row
{#if numRows > 1} {#if hideUnselected} tableCell.hideUnselected = false} > {:else} tableCell.hideUnselected = true} > {/if} {/if} Place column specific units in this row (optional)
================================================ FILE: src/Terms.svelte ================================================

Updated {versionDateString}


Welcome to EngineeringPaper.xyz! By using this software, you are agreeing to the following terms and conditions.


Introduction

EngineeringPaper.xyz strives to protect user privacy. This is free and open source software that does not require you to create an account to use. All of the calculations you perform on EngineeringPaper.xyz are performed on your own computer and nothing you enter into your sheets is sent to our servers unless you create a shareable link or export your sheet as a Microsoft Word .docx file or a PDF file. When you create a shareable link, we only store the minimum amount of information required to run the shareable link service (see details below). When you export your sheet as a .docx or a .pdf file, no information is retained on the EngineeringPaper.xyz servers (see details below). Using your browser's print functionality to save your sheet as a PDF file sends no data to the EngineeringPaper.xyz servers.


You have the option to save your full sheets to your local drive as .epxyz files. If you only save your sheets locally as .epxyz or Markdown files, none of your data is ever sent to our servers.


No Warranty and Limitation of Liability

THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.


Privacy

EngineeringPaper.xyz does not use cookies and does not track its users. The only time personal information is collected is when you use the "Get Shareable Link" feature of this site. When creating a shareable link, your IP address is stored in a database along with the contents of the sheet that is uploaded. The reason we collect the IP address for uploaded sheets is to protect this free shareable link service from abuse. When creating a shareable link, your data is stored on Cloudflare's global network. Cloudflare automatically attempts to locate data closest to the user to improve overall performance.


For technical reasons, it is necessary to send data to the EngineeringPaper.xyz servers to convert your sheets to .docx or .pdf files. No data is retained on the EngineeringPaper.xyz servers when creating .docx or .pdf files.


Saving your sheets locally as .epxyz or Markdown files avoids sending any of your data to our database. Additionally, sheets can be convert to a PDF file using the browser's print functionality without sending any data to the EngineeringPaper.xyz servers.


No Data Retention Guarantee for Shareable Links

Our goal is to store sheets using the shareable link feature for the life of the shareable link service. However, we provide no guarantee to the accessibility of shareable links in the future. We reserve the right to shut down the shareable link service at any time, and for any reason, without warning. We also reserve the right to delete any uploaded sheet at any time, and for any reason, without warning.


To ensure future access to your sheets, be sure to save them locally as .epxyz files (even if you have created a shareable link).


================================================ FILE: src/TextBox.svelte ================================================
================================================ FILE: src/TextButton.svelte ================================================ ================================================ FILE: src/TextCheckbox.svelte ================================================ ================================================ FILE: src/UnitsDocumentation.svelte ================================================

The following unit definintions are supported by EngineeringPaper.xyz (from Math.js documentation). Units may be used in their long or short forms (meter or m) and they may be used in their singular or plural forms (second or seconds).

Base Unit
Length meter (m), inch (in), foot (ft), yard (yd), mile (mi), link (li), rod (rd), chain (ch), angstrom, mil
Surface area m2, sqin, sqft, sqyd, sqmi, sqrd, sqch, sqmil, acre, hectare
Volume m3, litre (l, L, lt, liter), cc, cuin, cuft, cuyd, teaspoon, tablespoon
Liquid volume minim, fluiddram (fldr), fluidounce (floz), gill (gi), cup (cp), pint (pt), quart (qt), gallon (gal), beerbarrel (bbl), oilbarrel (obl), hogshead, drop (gtt)
Angles rad (radian), deg (degree), grad (gradian), cycle, arcsec (arcsecond), arcmin (arcminute)
Time second (s, secs, seconds), minute (min, mins, minutes), hour (h, hr, hrs, hours), day (days), week (weeks), month (months), year (years), decade (decades), century (centuries), millennium (millennia)
Frequency hertz (Hz)
Mass gram(g), tonne, ton, grain (gr), dram (dr), ounce (oz), poundmass (lbm, lb, lbs), hundredweight (cwt), stick, stone
Electric current ampere (A)
Temperature kelvin (K), celsius (degC), fahrenheit (degF), rankine (degR)
Amount of substance mole (mol)
Luminous intensity candela (cd)
Force newton (N), dyne (dyn), poundforce (lbf), kip, kilogramforce (kgf), gramforce (gf)
Energy joule (J), erg, Wh, BTU (Btu), electronvolt (eV)
Power watt (W), hp, tonrefrigeration (TR, RT, TOR, toncooling), boilerhp (BHP), MBH, MMBH
Pressure Pa, psi, atm, torr, bar, mmHg, mmH2O, cmH2O, inHg, inH2O, ftH2O, kpsi (ksi), Mpsi
Electricity and magnetism ampere (A), coulomb (C), watt (W), volt (V), ohm, farad (F), weber (Wb), tesla (T), henry (H), siemens (S), electronvolt (eV)
Viscosity (Dynamic and Kinematic) poise (P), reyn, ureyn, stokes (St)
Binary bits (b), bytes (B)

Supported Unit Prefixes

Name Abbreviation Value
deca da 1e1
hecto h 1e2
kilo k 1e3
mega M 1e6
giga G 1e9
tera T 1e12
peta P 1e15
exa E 1e18
zetta Z 1e21
yotta Y 1e24
Name Abbreviation Value
deci d 1e-1
centi c 1e-2
milli m 1e-3
micro u 1e-6
nano n 1e-9
pico p 1e-12
femto f 1e-15
atto a 1e-18
zepto z 1e-21
yocto y 1e-24

Supported Binary Unit Prefixes

For use with bits (b) or bytes (B)

Name Abbreviation Value
kibi Ki 1024
mebi Mi 1024^2
gibi Gi 1024^3
tebi Ti 1024^4
pebi Pi 1024^5
exi Ei 1024^6
zebi Zi 1024^7
yobi Yi 1024^8
Name Abbreviation Value
kilo k 1e3
mega M 1e6
giga G 1e9
tera T 1e12
peta P 1e15
exa E 1e18
zetta Z 1e21
yotta Y 1e24
================================================ FILE: src/UpdateAvailable.svelte ================================================

An update is available for EngineeringPaper.xyz. The next time you close all of your windows and tabs and reopen EngineeringPaper.xyz, you'll receive the update (note that refreshing the page is not sufficient to trigger the update). You will know that the update has been applied when this icon disappears. It is safe to continue working until you are ready to update.

================================================ FILE: src/Updates.svelte ================================================ April 14, 2026 (Permalink: 20260414.engineeringpaper.xyz)

Pyodide Update

The underlying Python runtime that EngineeringPaper.xyz depends on, Pyodide, has been updated. The main change is the inclusion of the latest version of the CoolProp library for fluid properties (v7.2.0), which adds the R1336mzz(E) refrigerant and includes numerous bug fixes. Potentially Breaking Change: For sheets that use code cells, there is a possibility that this change in Pyodide version will impact code cells that depend on old package versions. These sheets will notify users of the runtime change and will list the old and new package versions. Most of the time, sheets will work fine with the new versions and the message will disappear once the sheet is saved. If there are issues with the change in version for your code cells, the message will let you know the most recent permalink that has the old Python runtime version that will work with your code cells (re-open the sheet to see this message if it has been closed). Note that the Polars library is no longer available in this new Pyodide version, so code cells that use the Polars library will need to use the previous permalink version of EngineeringPaper.xyz.


March 13, 2026 (Permalink: 20260313.engineeringpaper.xyz)

Improved Log Plotting

The spacing for x-values is now logarithmic for log x plots. This produces evenly spaced points, which creates smooth log x plots without requiring a large number of points. Additionally, a warning is provided to the user if either the upper or lower limit for a log x plot is non-positive.


March 7, 2026 (Permalink: 20260307.engineeringpaper.xyz)

Multiplying by Zero No Longer Removes Units

Previously, multiplying a dimensioned number by zero resulted in the dimensions being lost as in the following:


{String.raw`\(0\cdot1\left\lbrack m\right\rbrack=0\)`}


This behavior, at times, led to subtle issues when an expression worked with non-zero values and starts to have dimension errors for zero values. The new behavior gives the following result:


{String.raw`\(0\cdot1\left\lbrack m\right\rbrack=0\left\lbrack m\right\rbrack \)`}


This new behavior is particularly useful when using scalar multiplication to apply units to all values in a vector when some of those values may be zero:


{String.raw`\(\begin{bmatrix}1\\ 0\\ 2\end{bmatrix}\cdot1\left\lbrack N\right\rbrack= \begin{bmatrix} 1\left\lbrack N\right\rbrack \\ 0\left\lbrack N\right\rbrack \\ 2\left\lbrack N\right\rbrack \end{bmatrix}\)`}


Potentially Breaking Change: Even though the numerical results remain unchanged with this update, there may be rare cases where dimension errors are introduced for sheets that relied on the old behavior. If you experience dimension errors after this update, look for locations where zero is multiplied by other values and add compatible units to correct the issue. You'll most likely need to add units to the zero value itself to cancel the units of the value being multiplied by zero.


February 24, 2026 (Permalink: 20260224.engineeringpaper.xyz)

Alternative Text for Images

The ability to set the alternative text (alt text) for images in documentation cells has been added to increase the accessibility of EngineeringPaper.xyz sheets. This alt text is included in Markdown and DOCX exports. Alt text is not currently supported in PDF exports, but is anticipated to be supported soon.


February 2, 2026 (Permalink: 20260205.engineeringpaper.xyz)

Data Table Improvements

Data table results now use the sheet settings for number formatting. Additionally, the number format can be customized for each data table column using the settings button at the top of each output column. Finally, data table export to documents (DOCX or PDF) has been improved.


December 29, 2025 (Permalink: 20251229.engineeringpaper.xyz)

Virtual Keyboard Toggle and General Performance Improvements

Since it's possible to use this app with just your keyboard, it can be distracting to have the virtual keyboard pop into and out of view as you're working. You can now hide the virtual keyboard by clicking the button on the bottom left of the screen. Click the button to get the keyboard back. You can also use the {modifier}-\ keyboard shortcut to toggle the visibility of the virtual keyboard. Note that a math field needs to have focus for the keyboard hide/show buttons to appear.


This release also includes general performance improvements. The caclulation performance for data tables has been improved. Additionally, the calculation speed for expressions that have nested {String.raw`\(\log()\)`} and/or {String.raw`\(\ln()\)`} function calls has been significantly improved.


October 12, 2025 (Permalink: 20251012.engineeringpaper.xyz)

Support for Dummy Variables in Python Code Cells

Certain types of functions require a variable that is local to that function that should not be substituted until after the function is evaluated. Examples include integration, differentiation, and summation. For integrals, this variable is the variable of integration. Previously it was not possible to use these dummy variables in custom Python functions making it impossible to define certain integral transformations including Laplace and Fourier transforms. It is now possible to use dummy variables in your custom Python functions. See the Custom Laplace Transform Tutorial to see an example of using dummy variables in Python code cells.


July 5, 2025 (Permalink: 20250705.engineeringpaper.xyz)

Word and PDF Export Improvements

Several improvements have been made to Word and PDF document exporting. Equations are now left justified by default. The previous behavior of centered equations is now an option. The paper size for exported documents can now be specified as either A4 or Letter. The size of scaled images is now carried through to the exported Word or PDF document. Previously, images always appeared at their original size in the exported document file. Finally, and most importantly, the PDF typesetting engine has been updated to use the amazing Typst typesetting library. This results in much faster PDF generation, support for international unicode fonts, emojis 😊➡️📄, and a more modern look for the PDF exports. Also, the Python Extensions Tutorial has been updated to show you how to get your Python code cell generated SVG images to show up in your exported Word and PDF documents (see the last Matplotlib example in the tutorial).


July 2, 2025 (Permalink: 20250702.engineeringpaper.xyz)

Python Code Cells

EngineeringPaper.xyz can now be extended with Python code cells! Access powerful Python libraries including NumPy, SciPy, scikit-learn, and SymPy within your EP sheets without any installations and it all runs locally on your own computer. Code cells are designed to be intuitive and easy to use without limiting what can be achieved. The text, HTML, and Markdown rendering capabilities enable adding variable driven visualizations and summaries to your EP sheets. See the Python Extensions Tutorial for details. There is also a video tutorial to help get you started. Enjoy!


May 21, 2025 (Permalink: 20250521.engineeringpaper.xyz)

New Matrix Slicing Notation

EngineeringPaper.xyz now supports matrix slicing notation to extract rows and/or columns from a matrix. For example {String.raw`\(A_{2,1:end}\)`} extracts the second row of the matrix. See the updated Matrices and Vectors Tutorial for details. Additionally, the updated tutorial shows how to combine vectors and matrices as rows, columns, or both.


May 16, 2025 (Permalink: 20250516.engineeringpaper.xyz)

New Variable Accents, International Variable Names, and Performance Improvements

Have you ever been forced to use inconvenient variable names such as {String.raw`\(DeltaF_{DoublePrime}\)`}, {String.raw`\(i_{hat}\)`}, or {String.raw`\(doubleDotx_{alpha}\)`} in EngineeringPaper.xyz? These variables can now be more conveniently expressed as {String.raw`\(\Delta F^{\prime\prime}\)`}, {String.raw`\(\hat{\imath}\)`}, and {String.raw`\(\ddot{x_{\alpha}}\)`} , respectively, since EngineeringPaper.xyz now supports variable name accents such as bar, vector, dot, double dot, and prime. These accents are available on the {String.raw`\(\hat{a}\mathrm{\smallint\Sigma}\)`} tab of the virtual keyboard. Previously, Greek characters could only be used by themselves as variable names. Greek characters can now appear anywhere, and in any combination, within a variable name or subscript. Finally, and most importantly, international character sets can now be used in variable names making all of the following valid EngineeringPaper.xyz expressions:


{String.raw`\(面积=长度\cdot宽度\)`}


{String.raw`\(Ε\mu\beta\alpha\deltaό\nu=Μή\kappaο\varsigma\cdot\Pi\lambdaά\tauο\varsigma\)`}


{String.raw`\(क्षेत्रफल=लंबाई\cdotचौड़ाई\)`}


{String.raw`\(면적=길이\cdot너비\)`}


{String.raw`\(พื้นที่=ความยาว\cdotความกว้าง\)`}


{String.raw`\(面積=長さ\cdot幅\)`}


EngineeringPaper.xyz now supports all of the Unicode character sets that are supported by Python for variable names. Unfortunately, right-to-left character sets are not well supported at this time. This is due to some issues with the underlying math editor used by EngineeringPaper.xyz. Hopefully this can be addressed at some point in the future.


This release also includes additional changes to offload the parsing of mathematical expressions to a different browser thread. This makes editing large or complex mathematical expressions much more responsive. This change also makes editing large data tables much less laggy, which enables users to work with data tables that have thousands of rows.


March 16, 2025 (Permalink: 20250316.engineeringpaper.xyz)

New Multivariable Interpolation and Polynomial Regression Features

Data tables now support multivariable interpolation and multivariable polynomial regression making it easy to perform bilinear interpolation of tabular data or to create response surfaces for design of experiments (DOE) data. See this multivariable interpolation tutorial video for details. Additionally, this update provides significant performance improvements for both calculations and load times through both code improvements and by upgrading the underlying Pyodide Python library.


March 8, 2025 (Permalink: 20250308.engineeringpaper.xyz)

Summation/Product Notation and Matrix Improvements

Summation and product notation have been added. Summation or product notation can be inserted using the virtual keyboard with the new {String.raw`\(\mathrm{\smallint\infty\Sigma}\)`} tab. Alternatively, they can be inserted by typing the \sum or \prod keyboard shortcuts. The numrows and numcols functions have been added to make it easy to use the summation or product notation to loop over matrices or vectors of arbitrary size (see the Matrices and Vectors Tutorial for an example).


Matrices can now be resized using the context menu (access the context menu using right click on Windows, Ctrl-left-click on Mac, and long press on touch screen devices) or by using the {String.raw`\(\begin{bmatrix}A\end{bmatrix}\)`} tab on the virtual keyboard.


Finally, to accommodate these new features, the virtual keyboard tabs have been updated. The Math tab has been renamed to {String.raw`\(123\)`}. The calculus functions have been moved to the new {String.raw`\(\mathrm{\smallint\infty\Sigma}\)`} tab. The statistics functions have been moved to the {String.raw`\(\operatorname{f}\left(x\right)\)`} tab and the Matrices tab has been renamed to {String.raw`\(\begin{bmatrix}A\end{bmatrix}\)`}.


February 16, 2025 (Permalink: 20250216.engineeringpaper.xyz)

New Documentation Cell Features

One of the more popular features of EngineeringPaper.xyz is the ability to document your calculations using documentation cells. This release adds frequently requested features to documentation cells. First, you are now able to add mathematical expressions to documentation cells using either the formula button in the toolbar or using the {modifier}-E keyboard shortcut. You enter your equations using LaTeX mathematial notation. Don't know LaTeX, no problem! You can simply copy the mathematical expression from one of the math fields in your EngineeringPaper.xyz and paste it into the formula field, it will be in LaTeX format since EP uses LaTeX as its native math format. Second, you're now able to set the text color and text highlight color in documentation fields. Finally, you can now resize images using the resize handles that appear when you click on images in your documentation fields.


This release has many behind the scenes changes that modernize the user interface libraries and code. Much effort has went into making sure that these changes do not introduce bugs, however, if you do notice a bug, please report the bug to support@engineeringpaper.xyz In the meantime, you may use the previous release's permalink (see below) until the bug is fixed.


January 21, 2025 (Permalink: 20250121.engineeringpaper.xyz)

Updated Dimension Handling System

The logic for dimension handling has been significantly revised and improved. The most significant benefit of this update is improved error messages for dimension errors. Instead of just getting the dreaded Dimension Error message, some context about the operation or function that lead to this error is included in the error message. This update also makes calculations faster in general, provides more robust handling of dimensions that are slightly different due to floating point rounding errors, and makes it easier to maintain and extend the dimension handling code in the future. This update is required to enable some significant new features that are coming your way!


Significant testing has gone into ensuring that this change does not introduce bugs. One change you may notice is that dimensions were sometimes lost in the past for dimensioned values that had zero magnitude. This should no longer happen but may lead to dimension errors for sheets that relied on the old behaviour. If you do notice a bug, please report the bug to support@engineeringpaper.xyz In the meantime, you may use the previous release's permalink (see below) until the bug is fixed.


January 16, 2025 (Permalink: 20250116.engineeringpaper.xyz)

New Release Permalinks

New releases of EngineeringPaper.xyz roll out on a continuous basis. Because of this, if you go to the main EngineeringPaper.xyz site, you always get the most recent version with all of the newest features and bug fixes. This is also true for the alternative mirror addresses: epxyz.com and EngineeringPaper.com. Most of the time, this is what you want. However, there may be cases where you may want to use a specific release. If you find the updates distracting, using one of the release permalinks will allow you to avoid updates until you're ready. Additionally, in the event that a new version introduces a bug that is impacting your sheet, going back to a previous permalink will allow you to open your .epxyz file and keep working. Of course, if this happens, please report the bug to support@engineeringpaper.xyz so that we can get it fixed. A lot of effort is put into ensuring that new versions don't introduce bugs. However, a bug is always possible and ensuring that you're able to work with your existing sheets is a top priority.


For this, and all future releases, a permalink will be listed after the release date in this dialog (for this release, the permalink is: 20250116.engineeringpaper.xyz). This dialog can be accessed by clicking on the "Releases" entry in the left menu. The release permalinks will also be available on the EngineeringPaper.xyz GitHub site.


As you might expect, the introduction of permalinks is in anticipation of new releases coming your way. In the short term, most of the changes are related to updates to the internal structure of EngineeringPaper.xyz. These updates are important to modernize and simplify the code that backs EngineeringPaper.xyz and will pave the way for exciting new features in the future. Stay tuned!


November 23, 2024

New Custom Default Sheet Settings Feature

You can now set your own custom default sheet settings (default units, default number formating, etc.). These defaults will be used whenever you create a new sheet and these settings can also be applied to existing sheets. All of this functionality is accessible through the "Set User Default" tab of the "Sheet Settings" dialog (available using the sheet settings button at the top toolbar).


November 2, 2024

Matrix Multiplication Improvements

The two multiplication symbols (the dot symbol obtained using the * key and the x symbol obtained using the @ key) can now be used interchangeably and will correctly apply either scalar or matrix multiplication as appropriate for the situation. Previously, the dot symbol would give unexpected results for some matrix multiplication situations. The only difference between the two symbols is that the x multiplication symbol will automatically perform a cross product when operating on compatible vectors (both 3x1 or both 1x3). This cross product behavior is unchanged from previous versions. This update also fixes some situations where the result of a matrix multiplication passed to a function would cause an error.


August 27, 2024

PDF Export Improvements

The reliability of PDF export has been greatly improved. Images that previously caused errors are now reproduced correctly in the generated PDF files. International fonts that previously caused errors no longer cause errors. However, some international fonts are still not rendered properly in the generated PDF. For full international font support, exporting to Word DOCX files or using the browser's print to PDF function are still your best options.


August 24, 2024

Scientific Notation Improvements

A frequent point of confusion was the lack of support for units immediately following a number expressed in scientific notation. Units now work as expected when used with scientific notation (see image below). Additionally, the {modifier}-E keyboard shortcut can be used to insert scientific notation and a new scientific notation button has been added to the virtual keyboard.


New scientific notation with units support: Math cell shown with scientific notation number with units


August 18, 2024

New Show Intermediate Results Feature

A new sheet setting has been added (available using the settings button at the sheet level or at the math cell level) that will automatically show intermediate results for a calculation. This feature is best shown with an example:


Result with Show Intermediate Results setting disabled (default): Math cell with Show Intermediate Results setting disabled


Result with Show Intermediate Results setting enabled: Math cell with Show Intermediate Results setting enabled


This feature is useful for debugging results with a dimension error since it will highlight if one of the input values is the source of the dimension error. Additionally, this feature is useful in an educational context where including intermediate results may make it easier to evaluate a student's work or it may make it easier for a student to follow along with an example problem.


August 13, 2024

Data Table Improvements

Spreadsheet files (Excel or CSV files) can now be dragged and dropped onto a EngineeringPaper.xyz page to automatically add a new data table cell to the current sheet. A new button, , has also been added to the lower right of the data table that makes it easy to remove empty rows.


August 8, 2024

Data Table Feature Added

EngineeringPaper.xyz can now do spreadsheets with Excel and CSV import! Additionally, the min and max functions have been updated to work with vectors and new functions geared towards working with data have been added (sum, average, stdev, stdevp, range, and count). See the data table tutorial for details.


June 20, 2024

Parametric Plotting Feature Added

Parametric plotting has been added to EngineeringPaper.xyz. See the parametric plotting tutorial for details.


June 11, 2024

Thermodynamic Fluid Properties and New Engineering Units

For those of you who perform thermodynamic and fluid calculations, this release is for you! Powered by the powerful CoolProp library, EngineeringPaper.xyz now provides built in thermodynamic properties for many fluids including air, water/steam, humid air (psychrometrics), numerous refrigerants, and common heat transfer solutions including propylene and ethylene glycols. See the thermodynamic fluids tutorial to get started!


This release also borrows from the strange and fascinating world of engineering units by adding the following new units: poise (P), reyn, ureyn, stokes (St), kpsi (ksi), Mpsi, inHg, ftH2O, inH2O, tonrefrigeration (TR), boilerhp (BHP), MBH, MMBH, and gramforce (gf).


May 13, 2024

Usability Improvements and Bug Fixes

This release includes the following usability improvements and bug fixes:

  • Vertical page jumps when editing, moving, or deleting cells has been eliminated improving visual stability and overall performance
  • Bug fixed where the sheet would hang when the last row of a table cell was selected and an earlier row was deleted
  • Reduced loading time and memory usage for large sheets
  • Improved performance when editing sheets with a large number of table cells or piecewise expression cells

April 18, 2024

Maximum Matrix Columns Limit Increased

The maximum number of columns allowed in a matrix has been increased to 50. The previous limit was 10. The number of rows allowed is unlimited, however, performance may become sluggish with large matrices.


April 6, 2024

Drag to Reorder Cells Improvements

Using the mouse or touch actions to drag and reorder cells has been improved and no longer has issues after repeated drag events.


April 4, 2024

Differentiation and Integration Improvements

Integration and differentiation now support piecewise functions. These updates will also fix situations that led to dimension errors when performing integration and differentiation on expressions that used certain builtin functions such as the min and max functions.


March 24, 2024

Differentiation and Integration Bug Fixes

Two bugs that occur in certain situations when performing substitutions with derivatives and integrals have been fixed. This fix also has the benefit of speeding up calculations for sheets that make use of derivatives or integrals.


March 21, 2024

Custom Right Click Context Menu Added

Math fields in EngineeringPaper.xyz now support a custom context menu for Cut/Copy/Paste, Undo/Redo, Select All, and Delete functionality. The context menu can be opened using the standard shortcuts for your system (right click on Windows, Ctrl-left-click on Mac, and long press on touch screen devices). Note that on iOS devices, the long press doesn't always work due to a bug in Safari. For these situations, a menu button ≡ has been added to the onscreen keyboard in order to ensure access to the context menu on all systems.


February 27, 2024

Save As Shortcut Added and Shareable Link Shortcut Changed

When using Chrome, or a Chrome based browser such as Edge, hitting {modifier}-S will automatically re-save the file using the same name, if it has already been saved. The {modifier}-Shift-S keyboard shortcut can now be used to perform a Save As operation to allow you to choose a different file name. Additionally, the Save Document menu now includes a Save As checkbox to serve the same purpose. The {modifier}-Shift-S keyboard shortcut was previously used to save your document as a shareable link. The {modifier}-L keyboard shortcut can now be used the create a shareable link.


February 26, 2024

File Saving Improvements

When using Chrome, or a Chrome based browser such as Edge, the file saving experience has been improved. Hitting {modifier}-S on the keyboard will prompt you to choose the file name and location for the first save. For future saves, the file will be automatically replaced when you hit {modifier}-S. If you would like to save the file as a different name, simply change the sheet title and you'll be prompted to choose a new file name the next time you hit {modifier}-S. Another option to save as a different file name without changing the sheet title is to disable the file saving permission using the browser's address bar. These options are covered in this EngineeringPaper.xyz File Management Tutorial Video. Unfortunately, Firefox and Safari don't currently support the File System Access API required to enable these advanced file management features.


January 20, 2024

LaTeX Export

In addition to the Microsoft Word and PDF export options, your sheet can now also be exported as a LaTeX document. Note that images and plots cannot be included when using the LaTeX export option.


January 10, 2024

Microsoft Word, PDF, and Markdown Export

You're now able to export your EngineeringPaper.xyz sheets as Microsoft Word, PDF, or Markdown files. Use the save icon on the top toolbar to access this exciting new feature. Since the Word and PDF conversions cannot be performed in the browser, data needs to be sent to the EngineeringPaper.xyz servers to complete the conversion process. However, no data is retained after the document conversion process is complete. The Markdown document export option does not require sending any data to the EngineeringPaper.xyz servers. Enjoy!


December 26, 2023

Now Also Available as EPxyz.com

Some environments indiscriminately block all .xyz domains. For example, some school districts block all .xyz domains for their school issued Chromebooks. Since it's important to us that all of the EngineeringPaper.xyz goodness is available to everyone, the full functionality of EngineeringPaper.xyz is now also available as a .com address at EPxyz.com. The functionality is the same between the two domains and sheets saved on one can be opened on the other. Shareable links are interchangeable as well. For example, https://engineeringpaper.xyz/fFjTsnFoSQMLwcvteVoNtL and https://epxyz.com/fFjTsnFoSQMLwcvteVoNtL point to the same sheet.


December 22, 2023

New Default Units Feature

The default base units used for results can now be set in the sheet settings dialog. To access the base unit settings, click on the sheet settings icon in the top menu bar and then click on the Default Units tab. The default units settings will be saved with the sheet.


As in the past, the default unit system for EngineeringPaper.xyz sheets is the SI unit system. The default unit symbols now all correspond to the official SI unit symbols (for example, the time unit now defaults to s rather than sec). However, all of the old unit symbols still work for user specified units.


Finally, the inverse time unit, 1/s, is no longer automatically converted to Hz since this behavior was confusing when the frequency unit should have been interpreted as rad/s. See this blog post for details on how to properly handle frequency units in EngineeringPaper.xyz.


November 13, 2023

New Scatter Plotting Feature

Scatter plots are now supported by EngineeringPaper.xyz. Scatter plotting leverages the recently added ability to define vectors. See the Scatter Plotting Tutorial for details.


October 31, 2023

New ceil, floor, and round Functions Have Been Added

Three new rounding functions have been added. ceil to round up, floor to round down, and round to round to the nearest integer. These new functions can be found on the f(x) tab of the virtual keyboard. Note that these functions require that the input parameter is unitless. An input with units would lead to unexpected results since all calculation are performed internally in base SI units. For example, calculating the floor of 1 [mm] would evaluate to zero since the floor would be calculated on 0.001 after the millimeter value is converted to meters for the internal calculation.


September 30, 2023

Improved Error Messages

The error messages for syntax errors have been improved for some common errors that can be difficult to detect by looking at the expression. Specifically, the error message will indicate if there is an empty subscript or superscript or if there is a missing multiplication symbol. Note that not all missing multiplication symbols are able to be detected, but many common situations are covered by the new error messages.


August 19, 2023

Matrices and Python Code Generation Features

This release adds matrix and vector support. Just like all of the capabilities in EngineeringPaper.xyz, matrix and vector support is designed to be intuitive and easy to use and you'll get a long way by exploring the new "Matrices" tab on the onscreen keyboard. You can also check out the new Matrices and Vectors Tutorial to see all of the details. And, of course, all of the matrix and vector functionally has full units support.


If you're finding the need to do more in depth numerical analysis with your EngineeringPaper.xyz calculations, the new automatic Python code generation feature is for you! Check out the details in the new Python Code Generation Tutorial. And, you guessed it, the Python code generation is units aware and will use whatever units you specify in your EngineeringPaper.xyz sheet!


July 2, 2023

Minor Updates

This is a minor release that includes the following usability improvements:

  • Math editor updates: hitting the ( key on a selection will enclose the selection in parenthesis, more consistent behavior when hitting the / key
  • In addition to the Escape key, clicking the left or right page margins, or top of page logo, unselects all cells
  • {modifier}-UpArrow now selects the last cell if no cells are selected (previously selected the first cell like {modifier}-DownArrow)
  • A EngineeringPaper.xyz link can be dragged and dropped onto page to open (similar to existing functionality for files)
  • If the drag and drop target becomes stuck, it can be clicked to clear (Escape key works as well)
  • The browser spell checker is only enabled for the currently selected cell (Safari does not support this feature)
  • The tutorial page has been updated for recent features and now points to the new and updated tutorial video

June 26, 2023

Plotting Improvements

Several plotting improvements have been rolled out. The main change is that the axis labels and legend labels have been updated to render as math so that subscripts, Greek characters, and units appear the same in plots as they appear in math fields. This makes plot labels much easier to read, especially when there are complex units. See the example below to see the different between the old style plots and the new style plots. Plots can now be saved as SVG files, in addition to PNG files, using the buttons that appear above the plots.


Old Plots: Old plot styling screenshot


New Plots: New plot styling screenshot


Additionally, the keyboard responsiveness of the app for large sheets with many plots has been improved. Finally, plots opened from the side menu now resize properly when the side menu is closed.


June 7, 2023

Custom Number Formatting

The formatting used for numerical output is now customizable, both at the sheet level and at the individual math cell level. The number formatting can be set by clicking on the settings icon at the top tool bar for sheet wide settings and at the right hand side of the math cell for math cell level settings. Math cell level settings will always take precedence over sheet level settings. When settings differ from the default settings, a green dot will appear on the settings icon. Examples of the notation options available are shown below.


Default notation: Default Number Formatting Screenshot


Fixed notation with one significant figure after the decimal point: Fixed Number Formatting Screenshot


Scientific notation with four significant figures: Scientific Number Formatting Screenshot


Engineering notation with four significant figures: Scientific Number Formatting Screenshot


Symbolic notation: Symbolic Number Formatting Screenshot


Additionally, the precision of the numerical computations has been increased to 64 significant figures. Note that some unit conversions occurs at standard floating point precision (this occurs when using non-SI units and when converting between radians and degrees). This issue will be addressed in future updates.


Many thanks to @JWock82 for submitting these feature suggestions as a GitHub issue.


May 11, 2023

Math Editor Change and Features for More Compact Sheets

Up until this time, EngineeringPaper.xyz has been using the MathQuill math editor component. This editor worked well but is no longer being actively supported and has some limitations that has limited what features can be implemented in EngineeringPaper.xyz. Specifically, MathQuill does not support vectors and matrices. To enable the future advancement of EngineeringPaper.xyz, the math editor has been updated to use the MathLive math editing component. MathLive is under active development and supports many advanced math constructs, such as vectors and matrices. You will notice differences in how the equations look in your existing sheets. In general, MathLive uses a more modern font set and renders equations more clearly. We have aimed to keep the editing experience as close to the same as possible. One change is the shortcut for the square root symbol. Simply type "sqrt(" to create the square root symbol. Alternatively, you can use the onscreen keyboard to insert a square root symbol.


Extensive testing has been done to ensure that your existing sheets will still work without needing any updates. If you do run into issues with your existing sheets, this is a bug and should be reported to support@engineeringpaper.xyz, submitted as an issue on the GitHub issues page, or reported on the Reddit community page. In the case that you are having a issue opening an existing sheet or working with the math editor, the previous version of EngineeringPaper.xyz will remain available at classic.engineeringpaper.xyz. Keep in mind that sheets created in this and later versions of EngineeringPaper.xyz will not open in classic.engineeringpaper.xyz


This switch to a new math editor would not be complete without adding some new features. In the past, sheets tended to use up a lot of vertical space since each new assignment, each query, and each comment needed its own cell. An assignment and query can now be combined into one statement as shown in the image below: Combined Assignment and Query Statement Screenshot Additionally, multiple assignments can be be made in a math cell by separating them by commas: Multiple Assignments in a Single Math Cell Screenshot Finally, comments can be added at any location within a math field by pressing the quotation mark key to toggle comment mode on and off. The Comment button on the ABC or abc panels of the onscreen keyboard may also be used to toggle comment mode. Comments may be added at any point within a math expression and will automatically be ignored (see example below). This is a capability directly enabled by switching to the MathLive math editor. Comments in a Math Field Screenshot To see these new features in action, checkout this example sheet. Many thanks to @JWock82 for submitting these feature suggestions as a GitHub issue.


April 6, 2023

Load Time and Calculation Speed Improvements

The version of Python that EngineeringPaper.xyz uses for calculations, via the Pyodide project, has been updated to Python 3.11. This update provides significant speed improvements for both calculations and initial Pyodide load time. The initial Pyodide load time is about half of what it was for the Python 3.10 version of EngineeringPaper.xyz. Enjoy!


April 5, 2023

Bug Fix Update

There were a few cases where valid variable names would cause an error since they were reserved names in Python or SymPy. This issue has been fixed.


March 10, 2023

Usability Improvements

Some improvements have been made to EngineeringPaper.xyz's handling of syntax errors. First of all, blank math cells are no longer considered a syntax error. Second, a syntax error in the current math field does not cause all of the results to disappear. Both of these changes allow users to maintain visibility to existing results as they enter new math expressions. Many thanks to @VanHulleOne for suggesting these usability improvements as GitHub issues.


As a community project, EngineeringPaper.xyz depends on feedback from its users. If you have a feature request or are experiencing a bug, there are multiple ways to report these issues. You can create an issue in EngineeringPaper.xyz's GitHub issues page, you can add a post to EngineeringPaper.xyz's Reddit community page, or you can send a email to support@engineeringpaper.xyz. Also, if you would like to share any of the sheets you are creating with EngineeringPaper.xyz, the Reddit community page is a great place to share and start a discussion.


February 13, 2023

EngineeringPaper.xyz Can Now be Installed on Desktop or Mobile Devices

EngineeringPaper.xyz is now a progressive web application (PWA). The biggest impact of this change is that EngineeringPaper.xyz will now work without an internet connection (offline functionality becomes available after the first time you load the page in your web browser). Another benefit of PWAs is that they can be installed as a native application on your computer or mobile device. The exact instructions will depend on your operating system and device type. See this NIOSH writeup on how to install a PWA for further details.


Another benefit of this change will be smoother rollouts of updates to EngineeringPaper.xyz. In the past, it was possible for various components of EngineeringPaper.xyz to become temporarily out of sync as updates were rolled out globally. EngineeringPaper.xyz will now only incorporate an update when all components are guaranteed to be in sync. This will eliminate the brief instability that occasionally occurred with previous updates. A green refresh icon will appear in the toolbar when an update is available. In order to apply the update, all tabs and windows of EngineeringPaper.xyz need to be closed. Using the refresh button is not sufficient to apply the update. It is safe to continue using the app while an update is pending.


January 16, 2023

Open Source Release and Local File Saving

To ensure that EngineeringPaper.xyz always remains free to use, it has now been released as open source software under the permissive MIT license. The source code can be found on the EngineeringPaper.xyz GitHub page . With this change, you can rest assured that EngineeringPaper.xyz will always be available and that your time invested in using this software will not be wasted. No other engineering calculation software can make this promise.


This release also adds a local file open and file save feature. The buttons for this new functionality are on the top toolbar. This allows you to save your sheets to your local drive. With this capability, along with the open source license of EngineeringPaper.xyz, you are assured that you will always have access to the calculations you create in EngineeringPaper.xyz. The {modifier}-S keyboard shortcut now saves your current sheet locally. To {modifier}-Shift-S keyboard shortcut is now used to create a shareable link (this was the previous behavior of the {modifier}-S shortcut). The {modifier}-O keyboard shortcut can be used to open a local file. Finally, the {modifier}-Shift-N key starts a new blank sheet. EngineeringPaper.xyz sheets have an .epxyz extension by default. Another way to open your saved sheets is to drag and drop them onto the EngineeringPaper.xyz window.


December 29, 2022

Printing Improvements

Many updates have been made to improve printing of EngineeringPaper.xyz sheets. Document flow issues have been fixed where items may have previously overlapped. All unnecessary user interface buttons and controls are now hidden when printing. Scroll bars no longer appear in printouts. Finally, plot sizing when printing has been improved.


Plots have been visually improved as well. The issue where the y-axis labels occasionally overlap the axis numbers has been fixed. Plot sizing has been improved on desktop and mobile. Finally, the plot legend is now placed horizontally below the plot for more efficient usage of screen space on desktop and mobile.


December 26, 2022

Autosave Checkpoints

EngineeringPaper.xyz now automatically saves checkpoints of your sheet to prevent loss of data in the event that you accidentally navigate away from an unsaved sheet, accidentally refresh your page, or your browser window crashes. If you accidentally navigate away from your sheet, simply use the browser's back button to get back to your unsaved sheet. These autosave checkpoints are saved locally to your computer and can only be accessed on the computer, and the browser, where they were generated. In order to share your sheets with others, and to ensure future access to your work, you will still need to manually save your sheet using the upload button on the top right of the page or using the {modifier}-S keyboard shortcut.


The checkpoints are saved every 10 seconds (only if there have been changes to your sheet). Because of this, you can use the browser's back button to undo recent changes you've made to your sheet.


These autosave checkpoints are saved in your browser's local storage. Keep in mind that some browsers (Safari in particular) can be fairly aggressive about cleaning up local storage so make sure to manually save any sheets that you need access to in the future. See the side menu on the left for the "Enable Persistent Local Storage" option to request that your browser persists the data stored by EngineeringPaper.xyz.


December 8, 2022

Improved iPhone and Android Support

The experience of using EngineeringPaper.xyz on iPhone and Android devices has been improved significantly. Specifically, the on-screen keyboard has been expanded to provide access to all controls and symbols required to edit math equations on mobile.


The improvements are not just for mobile users. The use of screen space has been improved on both mobile and desktop. The on-screen keyboard now includes quick access to commonly used units, eliminating the need to type them in. Finally, by placing the onscreen keyboard at the bottom of the screen, the issue of missed mouse clicks because of the on-screen keyboard appearing or disappearing has been eliminated.


November 15, 2022

New Complex Number Functions and Trig Function Updates

Potentially Breaking Change: The inverse trig functions (arctan, arcsin, and arccos) now return values with the units of angle (radians by default but can be converted to degrees). If you have sheets that relied on the previous behavior, where the inverse trig functions return unitless values, you can multiple those values by (1 [1/rad]) to return to the previous behavior.


New Features: The complex number support has been improved with EngineeringPaper.xyz with the addition of the real, imag, conj, and angle functions (see the Imag tab added to the onscreen keyboard to access these new functions). If you prefer to learn by example, check out this blog post that uses these new capabilities to analyze a voltage divider with reactive electrical components


Bug Fixes and Improvements: The error handling for plots has been overhauled to provide more helpful error messages to help in debugging common plotting issues.


November 2, 2022

Infinite Undo/Redo Feature Added for Math Fields

{modifier}-Z and {modifier}-Y can now be used to Undo/Redo edits in a math field. Note that the Undo/Redo funcitonality is local to the currently selected math or text field. When a sheet is saved and reloaded, the undo history will be lost.


October 28, 2022

New Keyboard Shortcuts

A comprehensive set of keyboard shortcuts have been added to EngineeringPaper.xyz that allow you to navigate your sheet, add and remove cells, and save your work, all without leaving your keyboard. See the new keyboard shortcuts button on toolbar at the top of the app or see this blog post. There's also a tutorial video.


October 17, 2022

Number of Plot Points Can Now be Specified

The number of points used for a plot defaults to 51. The number of points can now be specified by appending the plot function call with "with 500 points" to obtain a plot with 500 points, for example. This new feature is easiest shown by example, see bottom of the all new and improved plotting and function tutorial to see this new feature in action. This new feature is especially powerful when combined with the new "Copy Data" button to bring the plot data into Excel, Google Sheets, or Numbers.


October 13, 2022

Plotting Improvements

Many improvements have been made to plotting in EngineeringPaper.xyz. The biggest new feature is the "Copy Data" button that copies all of the plot data to the clipboard where you can then paste it into Excel, Google Sheets, or Numbers. Support for log scaling of the x and/or y axes has also been added. Finally, an insert plot cell button has been added to make it simpler to create a plot. See the plotting and function tutorial to try out these new features.


October 3, 2022

Numerical System Solving Capability Added to System Solve Cells

EngineeringPaper.xyz now supports numerically solving equations and systems of equations in situations where the symbolic solver may not be able to find an exact solution. See the updated equation solving tutorial sheet to see how to use this new capability. There is also a short numerical solver tutorial video available.


September 26, 2022

New System Solve Cell Type Added to EngineeringPaper.xyz

The way EngineeringPaper.xyz handles equation solving has been updated and improved by adding a System Solve Cell type. This change makes it possible to solve multiple systems of equations in a single sheet and makes it easier to choose a particular solution when there are multiple solutions. Existing sheets that make use of equation solving will need to be updated to use the new System Solve Cell. See this equation solving tutorial sheet to see how to update your sheets that make use of the new System Solve Cell type. This change will also make it easier to add numerical equation solving in future versions of EngineeringPaper.xyz.


September 19, 2022

New Piecewise Function Cell Type Added to EngineeringPaper.xyz

Piecewise functions can now easily be added to EngineeringPaper.xyz sheets. Check out this example sheet for an example of a Piecewise function used in a calculation.


June 17, 2022

New Insert Sheet Feature Added to EngineeringPaper.xyz

You can now easily insert other sheets and tables into your sheets to save typing. See this tutorial video for a demo of this new feature.


June 8, 2022

New Table Cell Type Added to EngineeringPaper.xyz

Table cells make it easy to compare multiple scenarios in a single sheet. For example, different materials or different boundary conditions can be defined in a table. See this tutorial video for a demo of this new feature.


September 9, 2021

Plotting and Function Notation Have Been Added to EngineeringPaper.xyz

Check out this example sheet to learn how to use these exciting new features. This plotting and function tutorial is also available through the example sheets list in the top left menu. Additionally, the Terms of Conditions text has been updated for clarity (also accessible from the top left menu).

================================================ FILE: src/VirtualKeyboard.svelte ================================================
{#each tabs as tab, i (tab)} {/each}
{#if content.type === "Keyboards"} {:else } {#each content.buttons as buttonRow}
button.size) .reduce((accum, value) => accum+' '+value)};`} > {#each buttonRow as button (button.id)} {#if "click" in button} {:else}
{/if} {/each}
{/each} {/if}
================================================ FILE: src/carbon-theme.scss ================================================ // 1. Disable Carbon's default CDN font fetching $css--font-face: false; $css--helpers: true; $css--body: true; $css--use-layer: true; $css--reset: true; $css--typography: true; $css--plex: false; // Double check to ensure remote plex is off // 2. Import the main Carbon styles @import "carbon-components/scss/globals/scss/styles.scss"; // @import "carbon-components-svelte/css/white.scss"; // 3. Import the local IBM Plex fonts @import "@ibm/plex/css/ibm-plex.css"; ================================================ FILE: src/cells/BaseCell.ts ================================================ import type { Delta } from "quill"; import type { MathCellConfig, FluidConfig, NumberFormatOptions } from "../sheet/Sheet"; export type CellTypes = "math" | "documentation" | "plot" | "table" | "piecewise" | "system" | "deleted" | "insert" | "fluid" | "dataTable" | "code"; export type DatabaseCell = DatabaseMathCell | DatabaseDocumentationCell | DatabasePlotCell | DatabaseTableCell | DatabasePiecewiseCell | DatabaseSystemCell | DatabaseFluidCell | DatabaseDataTableCell | DatabaseCodeCell; export type DatabaseMathCell = { type: "math", id: number, latex: string, config: MathCellConfig | null | undefined // config might be undefined for old database entries }; export type DatabasePlotCell = { type: "plot", id: number, latexs: string[], logX: boolean | undefined, // logX, logY, and squareAspectRatio might be undefined for old database entries logY: boolean | undefined, squareAspectRatio: boolean | undefined }; export type DatabaseDocumentationCell = { type: "documentation", id: number, json: Delta } export type DatabaseTableCell = { type: "table", id: number, rowLabels: string[], nextRowLabelId: number, parameterLatexs: string[], nextParameterId: number, parameterUnitLatexs: string[], rhsLatexs: string[][], selectedRow: number, hideUnselected: boolean, rowJsons: Delta[] } // Original interpolation definition // old files may contain this definition type DatabaseInterpolationDefinitionOld = { type: "interpolation" | "polyfit", nameLatex: string, input: number, output: number, order: number } type DatabaseInterpolationDefinition = { type: "interpolation" | "polyfit", nameLatex: string, numInputs: number, inputs: number[], output: number, order: number } type DatabaseDataTableFitDefinition = DatabaseInterpolationDefinitionOld | DatabaseInterpolationDefinition; export type DatabaseDataTableCell = { type: "dataTable", id: number, parameterLatexs: string[], nextParameterId: number, nextInterpolationDefId: number, nextPolyfitDefId: number, parameterUnitLatexs: string[], columnData: string[][], columnIds?: number[], // early versions of dataTable cells will not have this property columnFormatOptions?: (NumberFormatOptions | null)[], interpolationDefinitions: DatabaseDataTableFitDefinition[] } export type DatabasePiecewiseCell = { type: "piecewise", id: number, parameterLatex: string, expressionLatexs: string[], conditionLatexs: string[] } export type DatabaseSystemCell = { type: "system", id: number, parameterListLatex: string, expressionLatexs: string[], selectedSolution: number } export type DatabaseFluidCell = { type: "fluid", id: number, fluidConfig: FluidConfig, useSheetFluid: boolean, useFluidInName: boolean, output: string, input1: string, input2: string, input3: string, latex: string, } export type DatabaseCodeCell = { type: "code", id: number, nextFuncId: number, latex: string, code: string, sympyMode : boolean } export abstract class BaseCell { readonly type: CellTypes; id: number; static nextId = 0; abstract serialize(): DatabaseCell | null; get parsePending() { return false; } constructor(type: CellTypes, index?: number) { if (index !== undefined) { this.id = index; } else { this.id = BaseCell.nextId++; } this.type = type; } } ================================================ FILE: src/cells/Cells.ts ================================================ import type { BaseCell, DatabaseCell } from "./BaseCell"; import type { Config } from "../sheet/Sheet"; import MathCell from "./MathCell.svelte"; import PlotCell from "./PlotCell.svelte"; import TableCell from "./TableCell.svelte"; import DataTableCell from "./DataTableCell.svelte"; import DocumentationCell from "./DocumentationCell.svelte"; import PiecewiseCell from "./PiecewiseCell.svelte"; import SystemCell from "./SystemCell.svelte"; import FluidCell from "./FluidCell.svelte"; import CodeCell from "./CodeCell.svelte"; import type DeletedCell from "./DeletedCell"; import type InsertCell from "./InsertCell"; export type Cell = MathCell | PlotCell | TableCell | DocumentationCell | PiecewiseCell | SystemCell | DeletedCell | InsertCell | DataTableCell | CodeCell; export async function cellFactory(databaseCell: DatabaseCell, config: Config): Promise { switch(databaseCell.type) { case "math": return new MathCell(databaseCell); case "documentation": return new DocumentationCell(databaseCell); case "plot": await PlotCell.init(); return new PlotCell(databaseCell); case "table": return new TableCell(databaseCell); case "dataTable": await DataTableCell.init(); return new DataTableCell(databaseCell); case "piecewise": return new PiecewiseCell(databaseCell); case "system": return new SystemCell(databaseCell); case "fluid": await FluidCell.init(); return new FluidCell(config.fluidConfig, databaseCell); case "code": await CodeCell.init(); return new CodeCell(databaseCell); default: const _exhaustiveCheck: never = databaseCell; return _exhaustiveCheck; } } ================================================ FILE: src/cells/CodeCell.svelte.ts ================================================ import { loadMathJax } from "../utility"; import { BaseCell, type DatabaseCodeCell } from "./BaseCell"; import { MathField } from "./MathField.svelte"; import pyodideInfo from "../pyodide-info.json"; const currentPyodideInfo = pyodideInfo.slice(-1)[0].info; export type CodeCellDims = CodeCellDimsSpecific | CodeCellDimsAny | CodeCellDimsRender | CodeCellDimsDummy; export type CodeCellDimsSpecific = { type: "specific", dims: number[], offset: number, scaleFactor: number } export type CodeCellDimsAny = { type: "any" } export type CodeCellDimsDummy = { type: "dummy" } export type CodeCellDimsRender = { type: "render", renderType: "text" | "html" | "markdown" } export type ScalarCodeCellDims = { type: "scalar", dims: CodeCellDims, } export type MatrixCodeCellDims = { type: "matrix", dims: (CodeCellDimsSpecific | CodeCellDimsAny)[][], } export type CodeCellInputOutputDims = ScalarCodeCellDims | MatrixCodeCellDims; export type CodeCellFunction = { name: string, code: string, inputDims: CodeCellInputOutputDims[], outputDims: CodeCellInputOutputDims, sympyMode: boolean, neededPyodidePackages: string[] } const availableModulesRegExp = new RegExp(Object.keys(currentPyodideInfo.availablePackages).join("|"), "g"); export default class CodeCell extends BaseCell { //@ts-ignore static DOMPurify: typeof import('dompurify').default; static marked: typeof import('marked').marked; static nextFuncId = 1; code: string; sympyMode: boolean = $state(); mathField: MathField = $state(); neededPyodidePackages: Set = new Set(['numpy']); constructor (arg?: DatabaseCodeCell) { super("code", arg?.id); if (arg === undefined) { this.code = this.getInitialCode(); this.sympyMode = false; this.mathField = new MathField(this.getInitialLatex(), "code_func_def"); } else { if (arg.nextFuncId > CodeCell.nextFuncId) { CodeCell.nextFuncId = arg.nextFuncId; } this.code = arg.code; this.sympyMode = arg.sympyMode; this.mathField = new MathField(arg.latex, "code_func_def"); } } static async init() { let mathJaxPromise = null; if (!document.querySelector("#MathJax-script")) { mathJaxPromise = loadMathJax(); } let domPurifyPromise = null; if (!CodeCell.DOMPurify) { domPurifyPromise = import('dompurify'); } let markedPromise = null; if (!CodeCell.marked) { markedPromise = import('marked'); } if (mathJaxPromise) { await mathJaxPromise; } if (domPurifyPromise) { CodeCell.DOMPurify = (await domPurifyPromise).default; CodeCell.DOMPurify.addHook('afterSanitizeAttributes', function(node) { if (node.nodeName === 'use' && node.hasAttribute('xlink:href')) { // Allow internal references that begin with a hash if (!node.getAttribute('xlink:href').startsWith('#')) { node.removeAttribute('xlink:href'); } } }); } if (markedPromise) { CodeCell.marked = (await markedPromise).marked; } } serialize(): DatabaseCodeCell { return { type: "code", id: this.id, nextFuncId: CodeCell.nextFuncId, latex: this.mathField.latex, code: this.code, sympyMode: this.sympyMode }; } get parsePending() { return this.mathField.parsePending; } getNextFuncName() { return `CodeFunc${CodeCell.nextFuncId++}`; } getInitialLatex() { return String.raw`\mathrm{${this.getNextFuncName()}}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`; } getInitialCode() { return `def calculate(value): output = 2*value return output `; } getCodeCellFunction(): CodeCellFunction | null { if (!this.mathField.parsingError && this.mathField.statement.type === "codeCellFunction") { return { name: this.mathField.statement.name, code: this.code, inputDims: this.mathField.statement.inputDims, outputDims: this.mathField.statement.outputDims, sympyMode: this.sympyMode, neededPyodidePackages: [...this.neededPyodidePackages] } } else { return null; } } updateNeededPyodidePackages() { const packageMatches: string[] = this.code.match(availableModulesRegExp) || []; const pyodideNames = packageMatches.map(key => currentPyodideInfo.availablePackages[key].pyodideName); this.neededPyodidePackages = new Set(pyodideNames); this.neededPyodidePackages.add('numpy'); } } ================================================ FILE: src/cells/DataTableCell.svelte.ts ================================================ import { format } from "mathjs"; import { BaseCell, type DatabaseDataTableCell } from "./BaseCell"; import { MathField } from "./MathField.svelte"; import type { Statement, UnitsStatement } from "../parser/types"; import { arraysEqual, getArraySI } from "../utility"; import { convertLatexToAsciiMath } from "mathlive"; import type { NumberFormatOptions } from "../sheet/Sheet"; type XLSX = typeof import("xlsx"); type InterpolationDefinition = { type: "polyfit" | "interpolation", nameField: MathField, numInputs: number, inputs: number[], output: number, order: number }; export type InterpolationFunction = { type: "polyfit" | "interpolation", name: string, numInputs: number, inputValues: number[][], outputValues: number[], inputDims: number[][], outputDims: number[], order: number }; export type GridInterpolationFunction = { type: "gridInterpolation", name: string, numInputs: number, inputValues: number[][], outputValues: number[][], inputDims: number[][], outputDims: number[], order: number }; export default class DataTableCell extends BaseCell { static XLSX: XLSX; static nextParameterId = 1; static nextInterpolationDefId = 1; static nextPolyfitDefId = 1; static spreadsheetExtensions = ".csv,.xlsx,.ods,.xls"; nextColumnId = 0; parameterFields: MathField[] = $state(); combinedFields: MathField[]; parameterUnitFields: MathField[] = $state(); columnData: string[][] = $state(); columnIds: number[]; columnFormatOptions: (NumberFormatOptions | null)[] = $state(); columnIdLocationMap: Map; columnStatements: (Statement | null)[]; columnIdentifiers: (string | null)[]; columnErrors: string[] = $state(); columnIsOutput: boolean[] = $state(); columnOutputUnits: string[] = $state(); interpolationDefinitions: InterpolationDefinition[] = $state(); interpolationFunctions: (InterpolationFunction | GridInterpolationFunction)[] = $state(); columnParserTimeouts: Map void)[]}> = new Map(); inColumnParseDebouncer = false; constructor (arg?: DatabaseDataTableCell) { super("dataTable", arg?.id); if (arg === undefined) { this.parameterFields = [new MathField(DataTableCell.getNextColName(), 'data_table_expression'), new MathField(DataTableCell.getNextColName(), 'data_table_expression')]; this.combinedFields = [new MathField('', 'data_table_assign'), new MathField('', 'data_table_assign')]; this.parameterUnitFields = [new MathField('', 'units'), new MathField('', 'units')]; this.columnData = [['', ''], ['', '']]; this.columnIds = [this.getNextColId(), this.getNextColId()]; this.columnFormatOptions = [null, null]; this.columnStatements = [null, null]; this.columnIdentifiers = [null, null]; this.columnErrors = ['', '']; this.columnOutputUnits = ['', '']; this.columnIsOutput = [false, false]; this.interpolationDefinitions = []; this.interpolationFunctions = []; } else { this.parameterFields = arg.parameterLatexs.map((latex) => new MathField(latex, 'data_table_expression')); if (arg.nextParameterId > DataTableCell.nextParameterId) { DataTableCell.nextParameterId = arg.nextParameterId; } if (arg.nextInterpolationDefId > DataTableCell.nextInterpolationDefId) { DataTableCell.nextInterpolationDefId = arg.nextInterpolationDefId; } if (arg.nextPolyfitDefId > DataTableCell.nextPolyfitDefId) { DataTableCell.nextPolyfitDefId = arg.nextPolyfitDefId; } this.parameterUnitFields = arg.parameterUnitLatexs.map((latex) => new MathField(latex, 'units')); this.combinedFields = arg.parameterLatexs.map((latex) => new MathField('', 'data_table_assign')); this.columnData = arg.columnData; if (arg.columnIds) { this.columnIds = arg.columnIds; } else { // old versions of the file won't have this property, number them sequentially to match any results in the file this.columnIds = []; for (let i = 0; i < this.columnData.length; i++) { this.columnIds[i] = i; } } if (arg.columnFormatOptions) { this.columnFormatOptions = arg.columnFormatOptions; } else { this.columnFormatOptions = Array(this.columnData.length).fill(null); } this.columnStatements = Array(this.columnData.length).fill(null); this.columnIdentifiers = Array(this.columnData.length).fill(null); this.columnErrors = Array(this.columnData.length).fill(''); this.columnOutputUnits = Array(this.columnData.length).fill(''); this.columnIsOutput = Array(this.columnData.length).fill(false); this.interpolationDefinitions = []; for (const definition of arg.interpolationDefinitions) { if ("inputs" in definition) { this.interpolationDefinitions.push({ nameField: new MathField(definition.nameLatex, 'function_name'), numInputs: definition.numInputs, inputs: definition.inputs, output: definition.output, type: definition.type, order: definition.order }); } else { this.interpolationDefinitions.push({ nameField: new MathField(definition.nameLatex, 'function_name'), numInputs: 1, inputs: [definition.input,], output: definition.output, type: definition.type, order: definition.order }); } } this.interpolationFunctions = []; } this.columnIdLocationMap = new Map(); for (const [i, id] of this.columnIds.entries()) { this.columnIdLocationMap.set(id, i); } } static getNextColName() { return `Col${DataTableCell.nextParameterId++}` } static async init() { if (!this.XLSX) { this.XLSX = await import("xlsx"); } } getNextColId() { if (this.columnIds) { while(this.columnIds.includes(this.nextColumnId)) { this.nextColumnId++; } } return this.nextColumnId++; } serialize(): DatabaseDataTableCell { return { type: "dataTable", id: this.id, parameterLatexs: this.parameterFields.map((field) => field.latex), nextParameterId: DataTableCell.nextParameterId, nextInterpolationDefId: DataTableCell.nextInterpolationDefId, nextPolyfitDefId: DataTableCell.nextPolyfitDefId, parameterUnitLatexs: this.parameterUnitFields.map((parameter) => parameter.latex), columnData: this.columnData, columnIds: this.columnIds, columnFormatOptions: this.columnFormatOptions, interpolationDefinitions: this.interpolationDefinitions.map(definition => {return { nameLatex: definition.nameField.latex, type: definition.type, numInputs: definition.numInputs, inputs: definition.inputs, output: definition.output, order: definition.order } }), }; } get parsePending() { return this.parameterFields.reduce((accum, value) => accum || value.parsePending, false) || this.parameterUnitFields.reduce((accum, value) => accum || value.parsePending, false) || this.inColumnParseDebouncer; } isInterpolationCol(column: number) { const interpolationColSet = new Set(); for(const def of this.interpolationDefinitions) { for (const currentColumn of def.inputs) { interpolationColSet.add(currentColumn); } interpolationColSet.add(def.output); } return interpolationColSet.has(column); } debounceParseColumn(columnId: number, timeout = 300): Promise { this.inColumnParseDebouncer = true; return new Promise((resolve, reject) => { let resolvers: (() => void)[] = []; if (this.columnParserTimeouts.has(columnId)) { const pendingCalls = this.columnParserTimeouts.get(columnId); clearTimeout(pendingCalls.timeout); resolvers = pendingCalls.resolvers; } const newTimeout = setTimeout(async () => { const {timeout, resolvers} = this.columnParserTimeouts.get(columnId); this.columnParserTimeouts.delete(columnId); await this.parseColumn(columnId); for (const resolver of resolvers) { resolver(); } if (this.columnParserTimeouts.size === 0) { this.inColumnParseDebouncer = false; } }, timeout); resolvers.push(resolve); this.columnParserTimeouts.set(columnId, {timeout: newTimeout, resolvers}); }); } async parseColumn(columnId: number) { if (!this.columnIdLocationMap.has(columnId)) { return; } let column = this.columnIdLocationMap.get(columnId); const isInterpolationCol = this.isInterpolationCol(column); if (this.columnIsOutput[column]) { if (isInterpolationCol) { this.fixInterpolationCols(); } return; } this.columnErrors[column] = ""; let endIndex = this.columnData[column].findIndex(value => value.trim() === '' || isNaN(Number(value))); if (endIndex === -1) { endIndex = undefined; } let columnValues = this.columnData[column].slice(0, endIndex); if (columnValues.length > 0 && this.parameterUnitFields[column].statement && this.parameterUnitFields[column].statement.type !== "error") { let combinedLatex: string; if (this.parameterUnitFields[column].statement.type === "blank" || !arraysEqual([0,0,0,0,1,0,0,0,0], (this.parameterUnitFields[column].statement as UnitsStatement).dimensions)) { combinedLatex = String.raw`${this.parameterFields[column].latex} = \begin{bmatrix} ${columnValues.join(' \\\\ ')} \end{bmatrix}`; if (this.parameterUnitFields[column].statement.type !== "blank" ) { combinedLatex += String.raw` \cdot 1 ${this.parameterUnitFields[column].latex}`; } } else { // special handling of a pure temperature unit since scaling approach won't work columnValues = columnValues.map((value) => `${value} ${this.parameterUnitFields[column].latex}`); combinedLatex = String.raw`${this.parameterFields[column].latex} = \begin{bmatrix} ${columnValues.join(' \\\\ ')} \end{bmatrix}`; } let parsingError = false; let statement: Statement; await this.combinedFields[column].parseLatex(combinedLatex); // column location could of changed during parse if (!this.columnIdLocationMap.has(columnId)) { return; } column = this.columnIdLocationMap.get(columnId); statement = this.combinedFields[column].statement; parsingError = this.combinedFields[column].parsingError; this.columnStatements[column] = statement; if (parsingError) { this.columnErrors[column] = "Error parsing column data, check that all column number entries are either decimal numbers or integer numbers"; this.columnStatements[column] = null; } } else { this.columnStatements[column] = null; } if (isInterpolationCol) { this.setInterpolationFunctions(); } } addRow() { for(const column of this.columnData) { column.push(''); } } addColumn() { const newVarName = DataTableCell.getNextColName(); const newId = this.getNextColId(); this.columnIds = [...this.columnIds, newId]; this.columnFormatOptions = [...this.columnFormatOptions, null]; this.columnIdLocationMap.set(newId, this.columnIds.length - 1); this.parameterUnitFields = [...this.parameterUnitFields, new MathField('', 'units')]; this.parameterFields = [...this.parameterFields, new MathField(newVarName, 'data_table_expression')]; this.combinedFields = [...this.combinedFields, new MathField('', 'data_table_assign')]; this.columnData = [...this.columnData, Array(this.columnData[0].length).fill('')]; this.columnStatements = [...this.columnStatements, null]; this.columnIdentifiers = [...this.columnIdentifiers, null]; this.columnErrors = [...this.columnErrors, null]; this.columnOutputUnits = [...this.columnOutputUnits, null]; this.columnIsOutput = [...this.columnIsOutput, false]; } deleteRow(rowIndex: number) { for(const [i, column] of this.columnData.entries()) { this.columnData[i] = [...column.slice(0,rowIndex), ...column.slice(rowIndex+1)]; } } deleteColumn(colIndex: number) { this.columnIds = [...this.columnIds.slice(0,colIndex), ...this.columnIds.slice(colIndex+1)]; this.columnFormatOptions = [...this.columnFormatOptions.slice(0,colIndex), ...this.columnFormatOptions.slice(colIndex+1)]; this.columnIdLocationMap = new Map(); for (const [i, id] of this.columnIds.entries()) { this.columnIdLocationMap.set(id, i); } this.parameterUnitFields = [...this.parameterUnitFields.slice(0,colIndex), ...this.parameterUnitFields.slice(colIndex+1)]; this.parameterFields = [...this.parameterFields.slice(0,colIndex), ...this.parameterFields.slice(colIndex+1)]; this.combinedFields = [...this.combinedFields.slice(0,colIndex), ...this.combinedFields.slice(colIndex+1)]; this.columnData = [...this.columnData.slice(0,colIndex), ...this.columnData.slice(colIndex+1)]; this.columnStatements = [...this.columnStatements.slice(0,colIndex), ...this.columnStatements.slice(colIndex+1)]; this.columnIdentifiers = [...this.columnIdentifiers.slice(0,colIndex), ...this.columnIdentifiers.slice(colIndex+1)]; this.columnErrors = [...this.columnErrors.slice(0,colIndex), ...this.columnErrors.slice(colIndex+1)]; this.columnOutputUnits = [...this.columnOutputUnits.slice(0,colIndex), ...this.columnOutputUnits.slice(colIndex+1)]; this.columnIsOutput = [...this.columnIsOutput.slice(0,colIndex), ...this.columnIsOutput.slice(colIndex+1)]; } padColumns() { let paddingNeeded = false; let numRows = 0; for (const column of this.columnData) { if (column.length > numRows) { numRows = column.length; } } for (const column of this.columnData) { if (column.length < numRows) { paddingNeeded = true; column.push(...Array(numRows-column.length).fill('')); } } return paddingNeeded; } deleteEmptyRows() { this.padColumns(); // all columns need to be the same length let row = this.columnData[0].length - 1; while(row > 0 && this.columnData.map(col => col[row]).reduce((accum, value) => accum && (value.trim() === ""), true)) { this.deleteRow(row); row--; } } clearOutputColumns() { for (const [i, column] of this.columnData.entries()) { if (this.columnIsOutput[i]) { column.fill(''); } } } addInterpolationDefinition(type: "polyfit" | "interpolation", input: number, output: number) { let functionName: string; if (type === "polyfit") { functionName = `Polyfit${DataTableCell.nextPolyfitDefId++}`; } else { functionName = `Interp${DataTableCell.nextInterpolationDefId++}`; } this.interpolationDefinitions.push({ nameField: new MathField(functionName, 'function_name'), inputs: [input,], numInputs: 1, output, type, order: 1 }); } deleteInterpolationDefinition(index: number) { this.interpolationDefinitions = [...this.interpolationDefinitions.slice(0,index), ...this.interpolationDefinitions.slice(index+1)]; } fixInterpolationCols() { const dataCols = new Set(this.columnIsOutput.map((value, i) => value ? -1 : i).filter(value => value >= 0)); if (dataCols.size < 2) { // not enough cols to perform interpolation this.interpolationDefinitions = []; return; } for (const def of this.interpolationDefinitions) { if (dataCols.size < def.numInputs + 1) { def.numInputs = dataCols.size - 1; } def.inputs.length = def.numInputs; for (const [i, inputCol] of def.inputs.entries()) { let valid = true; if (def.inputs.slice(0,i).includes(inputCol)) { valid = false; } else if (!dataCols.has(inputCol)) { valid = false; } if (!valid) { for (const dataCol of dataCols) { if (!def.inputs.slice(0,i).includes(dataCol)) { def.inputs[i] = dataCol; break; } } } } if (!dataCols.has(def.output) || def.inputs.includes(def.output)) { for (const dataCol of dataCols) { if (!(def.inputs.includes(dataCol))) { def.output = dataCol; break; } } } } } setInterpolationFunctions() { this.interpolationFunctions = []; this.fixInterpolationCols(); definitionLoop: for(const [defIndex, def] of this.interpolationDefinitions.entries()) { if (def.nameField.statement?.type !== "parameter") { console.warn('Interpolation function name parsing error'); continue definitionLoop; } const endIndexInputs = []; for (const [i, input] of def.inputs.entries()) { endIndexInputs[i] = this.columnData[input].findIndex(value => value.trim() === '' || isNaN(Number(value))); if (endIndexInputs[i] === -1) { endIndexInputs[i] = this.columnData[input].length; } } let endIndexOutput = this.columnData[def.output].findIndex(value => value.trim() === '' || isNaN(Number(value))); if (endIndexOutput === -1) { endIndexOutput = this.columnData[def.output].length; } const endIndex = Math.min(...endIndexInputs, endIndexOutput); if (endIndex === 0) { console.warn('Zero length input for interpolation function'); continue definitionLoop; } const inputUnitsList: Statement[] = []; for (const input of def.inputs) { inputUnitsList.push(this.parameterUnitFields[input].statement); } let outputUnits: Statement = this.parameterUnitFields[def.output].statement; for (const [i, inputUnits] of inputUnitsList.entries()) { if (inputUnits?.type === "blank") { inputUnitsList[i] = { type: "units", dimensions: Array(9).fill(0), units: "", unitsValid: true, unitsLatex: "" } } } if (outputUnits?.type === "blank") { outputUnits = { type: "units", dimensions: Array(9).fill(0), units: "", unitsValid: true, unitsLatex: "" } } for (const inputUnits of inputUnitsList) { if (!(inputUnits?.type === "units" && inputUnits.unitsValid)) { console.warn('Attempt to define interpolation function with a units error'); continue definitionLoop; } } if (!(outputUnits?.type === "units" && outputUnits.unitsValid)) { console.warn('Attempt to define interpolation function with a units error'); continue definitionLoop; } const inputValuesList: string[][] = []; for (const input of def.inputs) { inputValuesList.push(this.columnData[input].slice(0, endIndex)); } let outputValues = this.columnData[def.output].slice(0, endIndex); let inputValuesSIList: number[][] = []; let outputValuesSI: number[]; try { for (const [i, inputValues] of inputValuesList.entries()) { inputValuesSIList.push(getArraySI(inputValues, (inputUnitsList[i] as UnitsStatement).units)); } outputValuesSI = getArraySI(outputValues, outputUnits.units); } catch (e) { console.warn('Error obtaining SI array for interpolation function'); continue definitionLoop; } this.interpolationFunctions[defIndex] = gridDetector({ type: def.type, name: def.nameField.statement.name, numInputs: def.numInputs, inputValues: inputValuesSIList, outputValues: outputValuesSI, inputDims: (inputUnitsList as UnitsStatement[]).map(inputUnits => inputUnits.dimensions), outputDims: outputUnits.dimensions, order: def.order }); } } selectAndLoadSpreadsheetFile(): Promise { return new Promise((resolve, reject) => { // no File System Access API, fall back to using input element const input = document.createElement("input"); input.type = "file"; input.accept = DataTableCell.spreadsheetExtensions; input.onchange = (event) => { this.loadFile(input.files[0]) .then(() => resolve()) .catch(error => reject(error)); }; input.oncancel = (event) => resolve(); input.click(); }); } loadFile(file: File): Promise { return new Promise((resolve, reject) => { if (file.size > 0) { const reader = new FileReader(); reader.onload = (event) => { try { this.populateTable(event); resolve(); } catch (e) { reject(e); } } reader.readAsArrayBuffer(file); } else { reject(new Error('Attempt to load empty file')); } }); } populateTable(fileReader: ProgressEvent){ const data = new Uint8Array(fileReader.target.result as ArrayBuffer); const workbook = DataTableCell.XLSX.read(data); const worksheet = workbook.Sheets[workbook.SheetNames[0]]; const inputRows = DataTableCell.XLSX.utils.sheet_to_json(worksheet, {header: 1}) as any[][]; if (inputRows.length < 1) { throw new Error('Imported spreadsheet must contain a least one row of numerical data'); } let longestRow = 0; for (const row of inputRows) { if (row.length > longestRow) { longestRow = row.length; } } if (longestRow === 0) { throw new Error('Imported spreadsheet must contain a least one column of data'); } let parameterNamesRow: string[]; let unitsRow: string[]; let dataRows: string[][]; if (inputRows[0].some(value => value !== undefined && isNaN(Number(value)))) { // parameter names in first row parameterNamesRow = inputRows[0].map(value => String(value ?? "")); if (inputRows.length < 2) { throw new Error("Imported spreadsheet must contain a least one row of numerical data"); } let secondRowContainsUnits = inputRows[1].some(value => value !== undefined && isNaN(Number(value))); if (secondRowContainsUnits) { unitsRow = inputRows[1].map(value => String(value ?? "")); dataRows = inputRows.slice(2); } else { unitsRow = Array(longestRow).fill(''); dataRows = inputRows.slice(1); } } else { // first row is numeric, need to add column parameter names dataRows = inputRows; parameterNamesRow = Array(longestRow).fill(0).map((value, j) => excelColName(j)); unitsRow = Array(longestRow).fill(''); } if (parameterNamesRow.length < 1) { throw new Error('Imported spreadsheet must contain a least one entry in the first row'); } const numRows = dataRows.length; if (numRows < 1) { throw new Error('Imported spreadsheet must contain a least one row of numerical data'); } this.parameterFields = []; this.parameterUnitFields = []; this.columnData = []; for (let col = 0; col < longestRow; col++) { let parameterName: string; if ((parameterNamesRow[col] ?? "").trim() === "") { parameterName = excelColName(col); } else { parameterName = parameterNamesRow[col]; } this.parameterFields.push(new MathField(parameterName , 'data_table_expression')) let units: string; units = unitsRow[col] ?? ''; if ( !( /.*\[.*\].*/.test(units) || /.*\\lbrack.*\\rbrack.*/.test(units) ) ) { if (units.trim() === "") { units = ""; } else { units = `[${units}]`; } } this.parameterUnitFields.push(new MathField(units, 'units')); this.columnData.push(Array(numRows).fill('')); } for (const [i,row] of dataRows.entries()) { for (const [j, value] of row.entries()) { this.columnData[j][i] = String(value ?? ""); } } this.combinedFields = Array(longestRow).fill(0).map((value) => new MathField('', 'data_table_assign')); this.columnStatements = Array(this.columnData.length).fill(null); this.columnIdentifiers = Array(this.columnData.length).fill(null); this.columnFormatOptions = Array(this.columnData.length).fill(null); this.columnErrors = Array(this.columnData.length).fill(''); this.columnOutputUnits = Array(this.columnData.length).fill(''); this.columnIsOutput = Array(this.columnData.length).fill(false); this.interpolationDefinitions = []; this.interpolationFunctions = []; this.columnIds = []; this.columnIdLocationMap = new Map(); for (let col = 0; col < this.columnData.length; col++) { this.columnIds[col] = this.getNextColId(); this.columnIdLocationMap.set(this.columnIds[col], col); } } async exportAsCSV(name: string) { this.padColumns(); // important that all columns are the same length const workbook = DataTableCell.XLSX.utils.book_new(); const sheet = DataTableCell.XLSX.utils.aoa_to_sheet(await this.getSheetRows()); DataTableCell.XLSX.utils.book_append_sheet(workbook, sheet, name); DataTableCell.XLSX.writeFile(workbook, `${name}.csv`); } async getSheetRows(forMarkdown = false, columnFormatOptions?: NumberFormatOptions[]): Promise { let headers = this.parameterFields.map(field => field.latex); if (forMarkdown) { headers = headers.map(header => `$${header.trim()}$`); } else { headers = headers.map(header => convertLatexToAsciiMath(header)); } let units = this.parameterUnitFields.map((field, j) => this.columnIsOutput[j] ? this.columnOutputUnits[j] : field.latex); const hasUnits = !units.every(value => value.trim() === ""); if (hasUnits) { if (forMarkdown) { units = units.map((currentUnits) => currentUnits.trim() !== "" ? `$${currentUnits.trim()}$` : ""); } else { const unitParser = new MathField('', 'units'); for (const [i, currentUnits] of units.entries()){ await unitParser.parseLatex(currentUnits); if (unitParser.statement.type === "units") { units[i] = `[${unitParser.statement.units}]`; } else { units[i] = currentUnits; } } } } const data: string[][] = Array(this.columnData[0].length).fill(0).map(_ => Array(this.columnData.length)); for (const [i, row] of data.entries()) { for(const [j, col] of this.columnData.entries()) { if (forMarkdown && col[i] !== '') { row[j] = format(parseFloat(col[i]), columnFormatOptions[j]); } else { row[j] = col[i]; } } } let sheetRows: string[][]; if (hasUnits) { sheetRows = [headers, units, ...data]; } else { sheetRows = [headers, ...data]; } return sheetRows; } async getClipboardData(): Promise { return (await this.getSheetRows()).map(value => value.join('\t')).join('\n'); } } function excelColName(index: number): string { if (index < 0) { throw new Error('Index cannot be negative'); } index = index + 1; let name = ''; while(index > 0) { const remainder = (index-1) % 26; name = String.fromCharCode(65 + remainder) + name; index = Math.floor((index-1)/26); } return name; } function gridDetector(inputFunction: InterpolationFunction): (InterpolationFunction | GridInterpolationFunction) { if (inputFunction.numInputs !== 2 || inputFunction.type !== "interpolation") { return inputFunction; } const x_unique = Array.from(new Set(inputFunction.inputValues[0])).sort(); const y_unique = Array.from(new Set(inputFunction.inputValues[1])).sort(); if (inputFunction.outputValues.length !== x_unique.length * y_unique.length) { return inputFunction; } const outputMap = new Map(); for (const [i, x_value] of inputFunction.inputValues[0].entries()) { const y_value = inputFunction.inputValues[1][i]; outputMap.set(JSON.stringify([x_value, y_value]), inputFunction.outputValues[i]); } if (outputMap.size !== inputFunction.outputValues.length) { return inputFunction; } const outputValues = []; for (const x of x_unique) { const row = []; for (const y of y_unique) { const outputValue = outputMap.get(JSON.stringify([x,y])); if (outputValue === undefined) { return inputFunction; } row.push(outputValue); } outputValues.push(row); } return { type: "gridInterpolation", name: inputFunction.name, numInputs: 2, inputValues: [x_unique, y_unique], outputValues: outputValues, inputDims: inputFunction.inputDims, outputDims: inputFunction.outputDims, order: inputFunction.order };; } ================================================ FILE: src/cells/DeletedCell.ts ================================================ import { BaseCell } from "./BaseCell"; import type { Cell } from "./Cells"; export default class DeletedCell extends BaseCell { deletedCell: Cell height: number constructor (deletedCell: Cell, height=0) { super("deleted"); this.deletedCell = deletedCell; this.height = height; } serialize() { return null } } ================================================ FILE: src/cells/DocumentationCell.svelte.ts ================================================ import { BaseCell, type DatabaseDocumentationCell } from "./BaseCell"; import Quill, { Delta } from "quill"; class DocumentationField { delta: Delta = $state(); richTextInstance: Quill | null = $state(null); constructor (delta?: Delta) { if (delta === undefined) { delta = new Delta(); } this.delta = delta; } } export default class DocumentationCell extends BaseCell { documentationField: DocumentationField = $state(); constructor (arg?: DatabaseDocumentationCell) { super("documentation", arg?.id); if (arg === undefined) { this.documentationField = new DocumentationField(); } else { this.documentationField = new DocumentationField(arg.json); } } serialize(): DatabaseDocumentationCell { return { type: "documentation", id: this.id, json: this.documentationField.delta }; } } ================================================ FILE: src/cells/FluidCell.svelte.ts ================================================ import { BaseCell, type DatabaseFluidCell } from "./BaseCell"; import { MathField } from "./MathField.svelte"; import { unit } from 'mathjs'; import { type FluidConfig, type Config, getDefaultFluidConfig } from "../sheet/Sheet"; import type { AssignmentStatement } from "../parser/types"; type FluidConstants = typeof import("../fluidConstants"); export type FluidFunction = { name: string, fluid: string, output: string, outputDims: number[], input1: string, input1Dims: number[], input2: string, input2Dims: number[], input3?: string, input3Dims?: number[], }; export default class FluidCell extends BaseCell { static FLUIDS: FluidConstants["FLUIDS"]; static FLUID_PROPS_PARAMETERS: FluidConstants["FLUID_PROPS_PARAMETERS"]; static FLUID_PROPS_PARAMETERS_ORDER: FluidConstants["FLUID_PROPS_PARAMETERS_ORDER"]; static FLUID_HA_PROPS_PARAMETERS: FluidConstants["FLUID_HA_PROPS_PARAMETERS"]; static FLUID_HA_PROPS_PARAMETERS_ORDER: FluidConstants["FLUID_HA_PROPS_PARAMETERS_ORDER"]; fluidConfig: FluidConfig = $state(); output: string = $state(); input1: string = $state(); input2: string = $state(); input3: string = $state(); useSheetFluid: boolean = $state(); useFluidInName: boolean = $state(); mathField: MathField = $state(); error: boolean = $state(); errorMessage: string = $state(); constructor (sheetFluidConfig: FluidConfig, arg?: DatabaseFluidCell) { super("fluid", arg?.id); if (arg === undefined) { this.fluidConfig = getDefaultFluidConfig(); this.useSheetFluid = false; this.useFluidInName = true; this.output = "D"; this.input1 = "T"; this.input2 = "P"; this.input3 = "W"; this.mathField = new MathField("", "function_name"); this.mathField.parseLatex(this.getSuggestedName(sheetFluidConfig)); } else { this.fluidConfig = getDefaultFluidConfig(); this.fluidConfig = arg.fluidConfig; this.useSheetFluid = arg.useSheetFluid; this.useFluidInName = arg.useFluidInName; this.output = arg.output; this.input1 = arg.input1; this.input2 = arg.input2; this.input3 = arg.input3; this.mathField = new MathField("", "function_name"); this.mathField.parseLatex(arg.latex); } this.errorCheck(sheetFluidConfig); } static async init() { if (!FluidCell.FLUIDS) { const fluidConstants = await import("../fluidConstants"); FluidCell.FLUIDS = fluidConstants.FLUIDS; FluidCell.FLUID_PROPS_PARAMETERS = fluidConstants.FLUID_PROPS_PARAMETERS; FluidCell.FLUID_PROPS_PARAMETERS_ORDER = fluidConstants.FLUID_PROPS_PARAMETERS_ORDER; FluidCell.FLUID_HA_PROPS_PARAMETERS = fluidConstants.FLUID_HA_PROPS_PARAMETERS; FluidCell.FLUID_HA_PROPS_PARAMETERS_ORDER = fluidConstants.FLUID_HA_PROPS_PARAMETERS_ORDER; } } serialize(): DatabaseFluidCell { return { type: "fluid", id: this.id, fluidConfig: this.fluidConfig, useSheetFluid: this.useSheetFluid, useFluidInName: this.useFluidInName, output: this.output, input1: this.input1, input2: this.input2, input3: this.input3, latex: this.mathField.latex, }; } get parsePending() { return this.mathField.parsePending; } getSuggestedName(sheetFluidConfig: FluidConfig) { const fluidConfig = this.useSheetFluid ? sheetFluidConfig : this.fluidConfig; let name: string; const fluidName = this.useFluidInName ? FluidCell.FLUIDS.get(fluidConfig.fluid).idName : ""; if (FluidCell.FLUID_PROPS_PARAMETERS.get(this.output)?.trivial) { name = fluidName; name += FluidCell.FLUID_PROPS_PARAMETERS.get(this.output)?.idName; } else if (fluidConfig.fluid === "HumidAir") { name = fluidName; name += FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.output)?.idName + "Given"; name += FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.input1)?.idName; name += FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.input2)?.idName; name += FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.input3)?.idName; } else { name = fluidName; name += FluidCell.FLUID_PROPS_PARAMETERS.get(this.output)?.idName + "Given"; name += FluidCell.FLUID_PROPS_PARAMETERS.get(this.input1)?.idName; name += FluidCell.FLUID_PROPS_PARAMETERS.get(this.input2)?.idName; } return name; } errorCheck(sheetFluidConfig: FluidConfig) { const fluidConfig = this.useSheetFluid ? sheetFluidConfig : this.fluidConfig; const errors: string[] = []; if (this.mathField.parsingError) { if (FluidCell.FLUID_PROPS_PARAMETERS.get(this.output)?.trivial) { errors.push("Invalid constant name"); } else { errors.push("Invalid function name"); } } if (!FluidCell.FLUIDS.has(fluidConfig.fluid)) { errors.push(`Unknown fluid ${fluidConfig.fluid}`); } else if (fluidConfig.fluid !== "HumidAir") { if (!FluidCell.FLUID_PROPS_PARAMETERS.has(this.output)) { errors.push(`Unknown output ${this.output}`); } else if (!FluidCell.FLUID_PROPS_PARAMETERS.get(this.output).output) { errors.push(`${FluidCell.FLUID_PROPS_PARAMETERS.get(this.output).idName} cannot be used as an output`); } else { const output = FluidCell.FLUID_PROPS_PARAMETERS.get(this.output); if (FluidCell.FLUIDS.get(fluidConfig.fluid).incompressible && output && !output.incompressibleOutput) { errors.push(`Output ${this.output} is not valid for incompressible fluid model`); } if (!output.trivial) { // 2 unique and valid inputs are required if (this.input1 === this.input2) { errors.push("Two unique inputs are required"); } if (this.input1 === this.output) { errors.push("Input 1 must differ from the output"); } if (this.input2 === this.output) { errors.push("Input 2 must differ from the output"); } if (!FluidCell.FLUID_PROPS_PARAMETERS.has(this.input1)) { errors.push(`Unknown input ${this.input1}`) } else if (!FluidCell.FLUID_PROPS_PARAMETERS.get(this.input1).input) { errors.push(`${FluidCell.FLUID_PROPS_PARAMETERS.get(this.input1).idName} cannot be used as an input`); } if (!FluidCell.FLUID_PROPS_PARAMETERS.has(this.input2)) { errors.push(`Unknown input ${this.input2}`) } else if (!FluidCell.FLUID_PROPS_PARAMETERS.get(this.input2).input) { errors.push(`${FluidCell.FLUID_PROPS_PARAMETERS.get(this.input2).idName} cannot be used as an input`); } if (FluidCell.FLUIDS.get(fluidConfig.fluid).incompressible) { if (!FluidCell.FLUID_PROPS_PARAMETERS.get(this.input1)?.incompressibleInput) { errors.push(`Input 1 ${this.input1} is not valid for incompressible fluid model`); } if (!FluidCell.FLUID_PROPS_PARAMETERS.get(this.input2)?.incompressibleInput) { errors.push(`Input 2 ${this.input2} is not valid for incompressible fluid model`); } } } } if (FluidCell.FLUIDS.get(fluidConfig.fluid).incompressibleMixture) { if (typeof fluidConfig.incompMixConc !== "number") { errors.push('Concentration must be a number'); } else if (fluidConfig.incompMixConc < FluidCell.FLUIDS.get(fluidConfig.fluid).minConcentration) { errors.push(`Concentration must be greater than or equal to ${FluidCell.FLUIDS.get(fluidConfig.fluid).minConcentration}`); } else if (fluidConfig.incompMixConc > FluidCell.FLUIDS.get(fluidConfig.fluid).maxConcentration) { errors.push(`Concentration must be less than or equal to ${FluidCell.FLUIDS.get(fluidConfig.fluid).maxConcentration}`); } } if (fluidConfig.fluid === 'CustomMixture') { const total = fluidConfig.customMixture.reduce( (accum, value) => accum + value.moleFraction, 0.0); if (Math.abs(total - 1.0) > 1.0e-6) { errors.push('All mole fractions must add up to 1.0 for a user defined mixture'); } if ((new Set(fluidConfig.customMixture.map(value => value.fluid))).size < fluidConfig.customMixture.length) { errors.push('Duplicate components are not allowed for user defined mixture'); } for (const {fluid, moleFraction} of fluidConfig.customMixture) { if (!FluidCell.FLUIDS.has(fluid)) { errors.push(`Unknown fluid ${fluid} in custom mixture`); } else if (!FluidCell.FLUIDS.get(fluid).compressibleMixtureComponent) { errors.push(`Invalid fluid ${fluid} in custom mixture`); } } } } else { if (!FluidCell.FLUID_HA_PROPS_PARAMETERS.has(this.output)) { errors.push(`Unknown output ${this.output}`); } else if (!FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.output).output) { errors.push(`${FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.output).idName} cannot be used as an output`); } else { const output = FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.output); // 3 unique and valid inputs are required if (this.input1 === this.input2 || this.input1 === this.input3 || this.input2 === this.input3) { errors.push("Three unique inputs are required"); } if (this.input1 === this.output) { errors.push("Input 1 must differ from the output"); } if (this.input2 === this.output) { errors.push("Input 2 must differ from the output"); } if (this.input3 === this.output) { errors.push("Input 3 must differ from the output"); } // one of the inputs must be pressure if (this.input1 !== "P" && this.input2 !== "P" && this.input3 !== "P") { errors.push("One of the inputs must be pressure for the HumidAir fluid model"); } if (!FluidCell.FLUID_HA_PROPS_PARAMETERS.has(this.input1)) { errors.push(`Unknown input ${this.input1}`) } else if (!FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.input1).input) { errors.push(`${FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.input1).idName} cannot be used as an input`); } if (!FluidCell.FLUID_HA_PROPS_PARAMETERS.has(this.input2)) { errors.push(`Unknown input ${this.input2}`) } else if (!FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.input2).input) { errors.push(`${FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.input2).idName} cannot be used as an input`); } if (!FluidCell.FLUID_HA_PROPS_PARAMETERS.has(this.input3)) { errors.push(`Unknown input ${this.input3}`) } else if (!FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.input3).input) { errors.push(`${FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.input3).idName} cannot be used as an input`); } } } this.errorMessage = errors.join(", "); this.error = Boolean(this.errorMessage); return this.error; } getFluidFunction(sheetFluidConfig: FluidConfig): {fluidFunction: FluidFunction | null, statement: AssignmentStatement | null} { const fluidConfig = this.useSheetFluid ? sheetFluidConfig : this.fluidConfig; if (this.error || this.mathField.statement?.type !== "parameter") { return {fluidFunction: null, statement: null}; } let fluidName: string; if (fluidConfig.fluid === "CustomMixture") { const mixtureDefinition = fluidConfig.customMixture.map(value => `${value.fluid}[${value.moleFraction}]`).join('&'); fluidName = `HEOS::${mixtureDefinition}`; } else if (FluidCell.FLUIDS.get(fluidConfig.fluid).incompressibleMixture) { fluidName = `${fluidConfig.fluid}[${fluidConfig.incompMixConc}]`; } else { fluidName = fluidConfig.fluid; } if (FluidCell.FLUID_PROPS_PARAMETERS.get(this.output)?.trivial) { const fluidFuncName = `_fluid_func_${this.id}`; return { fluidFunction: { name: fluidFuncName, fluid: fluidName, output: this.output, outputDims: unit(FluidCell.FLUID_PROPS_PARAMETERS.get(this.output).units).dimensions, input1: "", input1Dims: unit("").dimensions, input2: "", input2Dims: unit("").dimensions, }, statement: { type: "assignment", name: this.mathField.statement.name, sympy: `${fluidFuncName}(0,0)`, params: [], variableNameMap: this.mathField.statement.variableNameMap, isFunctionArgument: false, isFunction: false, implicitParams: [], functions: [], arguments: [], localSubs: [], isFromPlotCell: false, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false } }; } else if (fluidConfig.fluid === "HumidAir") { return { fluidFunction: { name: this.mathField.statement.name, fluid: fluidConfig.fluid, output: this.output, outputDims: unit(FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.output).units).dimensions, input1: this.input1, input1Dims: unit(FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.input1).units).dimensions, input2: this.input2, input2Dims: unit(FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.input2).units).dimensions, input3: this.input3, input3Dims: unit(FluidCell.FLUID_HA_PROPS_PARAMETERS.get(this.input3).units).dimensions, }, statement: null, }; } else { return { fluidFunction: { name: this.mathField.statement.name, fluid: fluidName, output: this.output, outputDims: unit(FluidCell.FLUID_PROPS_PARAMETERS.get(this.output).units).dimensions, input1: this.input1, input1Dims: unit(FluidCell.FLUID_PROPS_PARAMETERS.get(this.input1).units).dimensions, input2: this.input2, input2Dims: unit(FluidCell.FLUID_PROPS_PARAMETERS.get(this.input2).units).dimensions, }, statement: null, }; } } } ================================================ FILE: src/cells/InsertCell.ts ================================================ import { BaseCell } from "./BaseCell"; export default class InsertCell extends BaseCell { constructor () { super("insert"); } serialize() { return null } } ================================================ FILE: src/cells/MathCell.svelte.ts ================================================ import type { MathCellConfig } from "../sheet/Sheet"; import { BaseCell, type DatabaseMathCell } from "./BaseCell"; import { MathField } from "./MathField.svelte"; export default class MathCell extends BaseCell { mathField: MathField = $state(); config: MathCellConfig | null = $state(); constructor (arg?: DatabaseMathCell) { super("math", arg?.id); if (arg === undefined) { this.mathField = new MathField(""); this.config = null; } else { this.mathField = new MathField(arg.latex); if (arg.config) { this.config = arg.config; if (this.config.showIntermediateResults === undefined) { this.config.showIntermediateResults = false; } } else { this.config = null; } } } serialize(): DatabaseMathCell { return { type: "math", id: this.id, latex: this.mathField.latex, config: this.config }; } get parsePending() { return this.mathField.parsePending; } } ================================================ FILE: src/cells/MathField.svelte.ts ================================================ import type MathFieldElement from "../MathField.svelte"; import { LatexParserWrapper } from "../parser/parserWrapper"; import type { Statement, FieldTypes, DataTableInfo } from "../parser/types"; import type { ParsingResult } from "../parser/LatexToSympy"; import appState from "../stores.svelte"; function setParsePending(parsePending: boolean) { appState.parsePending = parsePending; } const parserWrapper = new LatexParserWrapper(setParsePending); export class MathField { latex: string = $state(); type: FieldTypes; id: number; static nextId = 0; parsePending = $state(true); parsingError = $state(true); parsingErrorMessage = $state("Invalid Syntax"); statement: Statement | null = $state(null); element: MathFieldElement | null = $state(null); pendingNewLatex = false; newLatex:string; parsingPromise: Promise; constructor (latex = "", type: FieldTypes ="math") { this.latex = latex; this.type = type; this.id = MathField.nextId++; }; async setPendingLatex(immediate = false): Promise { await this.parsingPromise; if (this.pendingNewLatex && this.element) { let startingPosition = this.element.getMathField().position; this.element.setLatex(this.newLatex, false); if (immediate) { if (startingPosition > this.element.getMathField().lastOffset) { startingPosition = this.element.getMathField().lastOffset; } this.element.getMathField().position = startingPosition; } this.pendingNewLatex = false; // needed to prevent the unlikely scenario where an immediateUpdate leads to an infinite loop } } async parseLatex(latex: string, dataTableInfo?: DataTableInfo) { this.latex = latex; this.parsePending = true; this.parsingPromise = parserWrapper.parseLatex(latex, this.id, this.type, dataTableInfo); const result = await this.parsingPromise; this.parsePending = false; this.pendingNewLatex = result.pendingNewLatex; this.newLatex = result.newLatex; this.parsingError = result.parsingError; this.parsingErrorMessage = result.parsingErrorMessage; this.statement = result.statement; if (result.immediateUpdate && this.element) { this.setPendingLatex(true); } } } ================================================ FILE: src/cells/PiecewiseCell.svelte.ts ================================================ import { BaseCell, type DatabasePiecewiseCell } from "./BaseCell"; import { MathField } from "./MathField.svelte"; import type { Statement } from "../parser/types"; export default class PiecewiseCell extends BaseCell { parameterField: MathField = $state(); expressionFields: MathField[] = $state(); conditionFields: MathField[] = $state(); piecewiseStatement: Statement | null; piecewiseParser = new MathField('', 'piecewise'); constructor (arg?: DatabasePiecewiseCell) { super("piecewise", arg?.id); if (arg === undefined) { this.parameterField = new MathField('', 'parameter'); this.expressionFields = [new MathField('', 'expression_no_blank'), new MathField('', 'expression_no_blank')]; this.conditionFields = [new MathField('', 'condition'), ]; this.piecewiseStatement = null; } else { this.parameterField = new MathField(arg.parameterLatex, 'parameter'); this.expressionFields = arg.expressionLatexs.map((latex) => new MathField(latex, "expression_no_blank")); this.conditionFields = arg.conditionLatexs.map((latex) => new MathField(latex, "condition")); this.piecewiseStatement = null; } } serialize(): DatabasePiecewiseCell { return { type: "piecewise", id: this.id, parameterLatex: this.parameterField.latex, expressionLatexs: this.expressionFields.map((field) => field.latex), conditionLatexs: this.conditionFields.map((field) => field.latex) }; } get parsePending() { return this.parameterField.parsePending || this.expressionFields.reduce((accum, value) => accum || value.parsePending, false) || this.conditionFields.reduce((accum, value) => accum || value.parsePending, false); } async parsePiecewiseStatement() { if (!(this.parameterField.parsingError || this.expressionFields.some(value => value.parsingError) || this.conditionFields.some(value => value.parsingError))) { let args = this.expressionFields .slice(0,-1) .map((exp, index) => `(${exp.latex},${this.conditionFields[index].latex}),`) .reduce((accum, value) => accum + value, ''); const latex = `${this.parameterField.latex} = piecewise( ${args}(${this.expressionFields.slice(-1)[0].latex}, 1>0) )`; await this.piecewiseParser.parseLatex(latex); this.piecewiseStatement = this.piecewiseParser.statement; } else { this.piecewiseStatement = null; } } addRow() { this.expressionFields = [...this.expressionFields.slice(0,-1), new MathField('', "expression_no_blank"), ...this.expressionFields.slice(-1) ]; this.conditionFields = [...this.conditionFields, new MathField('', "condition")]; } deleteRow(rowIndex: number) { this.expressionFields = [...this.expressionFields.slice(0,rowIndex), ...this.expressionFields.slice(rowIndex+1)]; this.conditionFields = [...this.conditionFields.slice(0,rowIndex), ...this.conditionFields.slice(rowIndex+1)]; } } ================================================ FILE: src/cells/PlotCell.svelte.ts ================================================ import { loadMathJax } from "../utility"; import { BaseCell, type DatabasePlotCell } from "./BaseCell"; import MathCell from "./MathCell.svelte"; import { MathField } from "./MathField.svelte"; type Plotly = typeof import("plotly.js-basic-dist"); export default class PlotCell extends BaseCell { static Plotly: Plotly; mathFields: MathField[] = $state(); logX: boolean = $state(); logY: boolean = $state(); squareAspectRatio: boolean = $state(); constructor (arg?: DatabasePlotCell | MathCell) { super("plot", arg?.id); if (arg === undefined) { this.mathFields = [new MathField("", "plot"), ]; this.logX = false; this.logY = false; this.squareAspectRatio = false; } else if (arg instanceof MathCell) { this.mathFields = [new MathField(arg.mathField.latex, "plot"), ]; this.logX = false; this.logY = false; this.squareAspectRatio = false; } else { // from database this.mathFields = arg.latexs.map((latex) => new MathField(latex, "plot")); this.logX = Boolean(arg.logX); this.logY = Boolean(arg.logY); this.squareAspectRatio = Boolean(arg.squareAspectRatio) // In older versions, database will have included an empty math field at end of list // Remove it if it exists, don't remove if it is the first entry if (this.mathFields.length > 1 && this.mathFields.slice(-1)[0].latex === "" ) { this.mathFields = this.mathFields.slice(0,-1); } } } static async init() { if (!this.Plotly) { if (!document.querySelector("#MathJax-script")) { await loadMathJax(); } this.Plotly = await import("plotly.js-basic-dist"); } } serialize(): DatabasePlotCell { return { type: "plot", id: this.id, latexs: this.mathFields.map((item) => item.latex), logX: this.logX, logY: this.logY, squareAspectRatio: this.squareAspectRatio }; } get parsePending() { return this.mathFields.reduce((accum, value) => accum || value.parsePending, false); } addRow() { this.mathFields = [...this.mathFields, new MathField('', "plot")]; } deleteRow(rowIndex: number) { this.mathFields = [...this.mathFields.slice(0,rowIndex), ...this.mathFields.slice(rowIndex+1)]; } } ================================================ FILE: src/cells/SystemCell.svelte.ts ================================================ import { BaseCell, type DatabaseSystemCell } from "./BaseCell"; import { MathField } from "./MathField.svelte"; import type { EqualityStatement, GuessAssignmentStatement } from "../parser/types"; export type SystemDefinition = ExactSystemDefinition | NumericalSystemDefinition; type ExactSystemDefinition = { statements: EqualityStatement[], variables: string[], numericalSolve: false, selectedSolution: number }; type NumericalSystemDefinition = Omit & { numericalSolve: true, guesses: string[], guessStatements: GuessAssignmentStatement[], }; export default class SystemCell extends BaseCell { parameterListField: MathField = $state(); expressionFields: MathField[] = $state(); selectedSolution: number = $state(); constructor (arg?: DatabaseSystemCell) { super("system", arg?.id); if (arg === undefined) { this.parameterListField = new MathField('', 'id_list'); this.expressionFields = [new MathField('', 'equality'), ]; this.selectedSolution = 0; } else { this.parameterListField = new MathField(arg.parameterListLatex, 'id_list'); this.expressionFields = arg.expressionLatexs.map((latex) => new MathField(latex, "equality")); this.selectedSolution = arg.selectedSolution; } } serialize(): DatabaseSystemCell { return { type: "system", id: this.id, parameterListLatex: this.parameterListField.latex, expressionLatexs: this.expressionFields.map((field) => field.latex), selectedSolution: this.selectedSolution }; } get parsePending() { return this.parameterListField.parsePending || this.expressionFields.reduce((accum, value) => accum || value.parsePending, false); } getSystemDefinition(): SystemDefinition | null { const statements: EqualityStatement[] = []; for (const expression of this.expressionFields) { if (expression.parsingError || expression.statement.type !== "equality") { return null; } else { statements.push(expression.statement); } } let system: SystemDefinition | null = null; if (this.parameterListField.parsingError) { return null; } else { const statement = this.parameterListField.statement; if (statement.type === "unknowns" && statement.numericalSolve === false) { system = { statements: statements, variables: statement.ids, numericalSolve: false, selectedSolution: this.selectedSolution } } else if (statement.type === "unknowns") { this.selectedSolution = 0; system = { statements: statements, variables: statement.ids, numericalSolve: true, selectedSolution: this.selectedSolution, guesses: statement.guesses, guessStatements: statement.statements } } } return system; } addRow() { this.expressionFields = [...this.expressionFields, new MathField('', "equality")]; } deleteRow(rowIndex: number) { this.expressionFields = [...this.expressionFields.slice(0,rowIndex), ...this.expressionFields.slice(rowIndex+1)]; } } ================================================ FILE: src/cells/TableCell.svelte.ts ================================================ import Quill, { Delta } from "quill"; import { BaseCell, type DatabaseTableCell } from "./BaseCell"; import { MathField } from "./MathField.svelte"; import type { Statement } from "../parser/types"; class TableRowLabelField { label: string = $state();; id: number; static nextId = 0; constructor (label = "") { this.label = label; this.id = TableRowLabelField.nextId++; } } export default class TableCell extends BaseCell { rowLabels: TableRowLabelField[] = $state(); nextRowLabelId: number; parameterFields: MathField[] = $state(); combinedFields: MathField[]; nextParameterId: number; parameterUnitFields: MathField[] = $state(); rhsFields: MathField[][] = $state(); selectedRow: number = $state(); hideUnselected: boolean = $state(); rowDeltas: Delta[] = $state(); richTextInstance: Quill | null = $state(); tableStatements: Statement[]; constructor (arg?: DatabaseTableCell) { super("table", arg?.id); if (arg === undefined) { this.rowLabels = [new TableRowLabelField("Option 1"), new TableRowLabelField("Option 2")]; this.nextRowLabelId = 3; this.parameterFields = [new MathField('Var1', 'parameter'), new MathField('Var2', 'parameter')]; this.nextParameterId = 3; this.combinedFields = [new MathField(), new MathField()]; this.parameterUnitFields = [new MathField('', 'units'), new MathField('', 'units')]; this.rhsFields = [[new MathField('', 'expression'), new MathField('', 'expression')], [new MathField('', 'expression'), new MathField('', 'expression')]]; this.selectedRow = 0; this.hideUnselected = false; this.rowDeltas = []; this.richTextInstance = null; this.tableStatements = []; } else { this.rowLabels = arg.rowLabels.map((label) => new TableRowLabelField(label)); this.nextRowLabelId = arg.nextRowLabelId; this.parameterFields = arg.parameterLatexs.map((latex) => new MathField(latex, 'parameter')); this.nextParameterId = arg.nextParameterId; this.combinedFields = arg.parameterLatexs.map((latex) => new MathField()); this.parameterUnitFields = arg.parameterUnitLatexs.map((latex) => new MathField(latex, 'units')); this.rhsFields = arg.rhsLatexs.map((row) => row.map((latex) => new MathField(latex, 'expression'))); this.selectedRow = arg.selectedRow; this.hideUnselected = arg.hideUnselected; this.rowDeltas = arg.rowJsons; this.richTextInstance = null; this.tableStatements = []; } } serialize(): DatabaseTableCell { return { type: "table", id: this.id, rowLabels: this.rowLabels.map((row) => row.label), nextRowLabelId: this.nextRowLabelId, parameterLatexs: this.parameterFields.map((field) => field.latex), nextParameterId: this.nextParameterId, parameterUnitLatexs: this.parameterUnitFields.map((parameter) => parameter.latex), rhsLatexs: this.rhsFields.map((row) => row.map((field) => field.latex)), selectedRow: this.selectedRow, hideUnselected: this.hideUnselected, rowJsons: this.rowDeltas }; } get parsePending() { return this.parameterFields.reduce((accum, value) => accum || value.parsePending, false) || this.parameterUnitFields.reduce((accum, value) => accum || value.parsePending, false) || this.rhsFields.reduce((accum, row) => accum || row.reduce((rowAccum, value) => rowAccum || value.parsePending, false), false); } async parseUnitField (latex: string, column: number) { await this.parameterUnitFields[column].parseLatex(latex); const columnType = latex.replaceAll(/\\:?/g,'').trim() === "" ? "expression" : "number"; // the presence or absence of units impacts the parsing of the rhs values so the current // column of rhs values needs to be parsed again for ( const row of this.rhsFields) { row[column].type = columnType; await row[column].parseLatex(row[column].latex); } } async parseTableStatements() { const rowIndex = this.selectedRow; const newTableStatements: Statement[] = []; if (!(this.parameterFields.some(value => value.parsingError) || this.parameterUnitFields.some(value => value.parsingError) || this.rhsFields.reduce((accum, row) => accum || row.some(value => value.parsingError), false))) { for (let colIndex = 0; colIndex < this.parameterFields.length; colIndex++) { let combinedLatex: string; if (this.rhsFields[rowIndex][colIndex].latex.replaceAll(/\\:?/g,'').trim() !== "") { combinedLatex = this.parameterFields[colIndex].latex + "=" + this.rhsFields[rowIndex][colIndex].latex + this.parameterUnitFields[colIndex].latex; await this.combinedFields[colIndex].parseLatex(combinedLatex); newTableStatements.push(this.combinedFields[colIndex].statement); } } } this.tableStatements = newTableStatements; } addRowDocumentation() { this.rowDeltas = Array.from({length: this.rowLabels.length}, () => new Delta()); } deleteRowDocumentation() { this.rowDeltas = []; } addRow() { const newRowId = this.nextRowLabelId++; this.rowLabels = [...this.rowLabels, new TableRowLabelField(`Option ${newRowId}`)]; if (this.rowDeltas.length > 0) { this.rowDeltas = [...this.rowDeltas, new Delta()]; } let columnType: "expression" | "number"; let newRhsRow: MathField[] = []; for (const unitField of this.parameterUnitFields) { columnType = unitField.latex.replaceAll(/\\:?/g,'').trim() === "" ? "expression" : "number"; newRhsRow.push(new MathField('', columnType)); } this.rhsFields = [...this.rhsFields, newRhsRow]; } addColumn() { const newVarId = this.nextParameterId++; this.parameterUnitFields = [...this.parameterUnitFields, new MathField('', 'units')]; const newVarName = `Var${newVarId}`; this.parameterFields = [...this.parameterFields, new MathField(newVarName, 'parameter')]; this.combinedFields = [...this.combinedFields, new MathField()]; this.rhsFields = this.rhsFields.map( row => [...row, new MathField('', 'expression')]); } deleteRow(rowIndex: number):boolean { this.rowLabels = [...this.rowLabels.slice(0,rowIndex), ...this.rowLabels.slice(rowIndex+1)]; if (this.rowDeltas.length > 0) { this.rowDeltas = [...this.rowDeltas.slice(0,rowIndex), ...this.rowDeltas.slice(rowIndex+1)]; } this.rhsFields = [...this.rhsFields.slice(0,rowIndex), ...this.rhsFields.slice(rowIndex+1)]; if (this.selectedRow >= rowIndex) { if (this.selectedRow !== 0) { this.selectedRow -= 1; return true } } return false } deleteColumn(colIndex: number) { this.parameterUnitFields = [...this.parameterUnitFields.slice(0,colIndex), ...this.parameterUnitFields.slice(colIndex+1)]; this.parameterFields = [...this.parameterFields.slice(0,colIndex), ...this.parameterFields.slice(colIndex+1)]; this.combinedFields = [...this.combinedFields.slice(0,colIndex), ...this.combinedFields.slice(colIndex+1)]; this.rhsFields = this.rhsFields.map( row => [...row.slice(0,colIndex), ...row.slice(colIndex+1)]); } } ================================================ FILE: src/constants.ts ================================================ export const INLINE_SHORTCUTS = { '*': '\\cdot', '@': '\\times', '<=': '\\le', '>=': '\\ge', '~': '\\approx', 'sqrt': '\\sqrt{#?}', 'log_': '\\log_{#?}(#?)', "''": '^{\\prime\\prime}', "'''": '^{\\prime\\prime\\prime}', '\\vec': '\\vec{#@}', '\\hat': '\\hat{#@}', '\\bar': '\\bar{#@}', '\\dot': '\\dot{#@}', '\\ddot': '\\ddot{#@}', '\\sqrt': '\\sqrt{#?}', '\\frac': '\\frac{#?}{#?}', '\\inf': '\\infty', '\\sum': '\\sum_{#?=#?}^{#?}\\left(#?\\right)', '\\prod': '\\prod_{#?=#?}^{#?}\\left(#?\\right)', '\\int': '\\int _{#?}^{#?}\\left(#?\\right)\\mathrm{d}\\left(#?\\right)', '\\der': '\\frac{\\mathrm{d}}{\\mathrm{d}\\left(#?\\right)}\\left(#?\\right)', '\\dder': '\\frac{\\mathrm{d}^{2}}{\\mathrm{d}\\left(#?\\right)^{2}}\\left(#?\\right)', '\\tder': '\\frac{\\mathrm{d}^{3}}{\\mathrm{d}\\left(#?\\right)^{3}}\\left(#?\\right)', '\\alpha': '\\alpha', '\\beta': '\\beta', '\\gamma': '\\gamma', '\\delta': '\\delta', '\\epsilon': '\\epsilon', '\\zeta': '\\zeta', '\\eta': '\\eta', '\\theta': '\\theta', '\\iota': '\\iota', '\\kappa': '\\kappa', '\\lambda': '\\lambda', '\\mu': '\\mu', '\\nu': '\\nu', '\\xi': '\\xi', '\\pi': '\\pi', '\\rho': '\\rho', '\\sigma': '\\sigma', '\\tau': '\\tau', '\\upsilon': '\\upsilon', '\\phi': '\\phi', '\\chi': '\\chi', '\\psi': '\\psi', '\\omega': '\\omega', '\\Gamma': '\\Gamma', '\\Delta': '\\Delta', '\\Theta': '\\Theta', '\\Lambda': '\\Lambda', '\\Xi': '\\Xi', '\\Pi': '\\Pi', '\\Sigma': '\\Sigma', '\\Upsilon': '\\Upsilon', '\\Phi': '\\Phi', '\\Psi': '\\Psi', '\\Omega': '\\Omega', }; export const MAX_MATRIX_COLS = 50; ================================================ FILE: src/customPlotButtonIcons.ts ================================================ export const pngIcon = { height: 16, width: 16, path: 'm 30.004302,24.268803 q -0.758967,0.368942 -1.575911,0.553413 -0.816944,0.184471 -1.686593,0.184471 -1.965936,0 -3.114928,-1.096285 -1.148992,-1.101557 -1.148992,-2.983163 0,-1.902689 1.170074,-2.993704 1.170075,-1.091015 3.204528,-1.091015 0.78532,0 1.502123,0.147577 0.722073,0.147577 1.359816,0.43746 v 1.628617 q -0.658826,-0.374213 -1.312381,-0.558684 -0.648284,-0.184471 -1.301839,-0.184471 -1.21224,0 -1.871065,0.679908 -0.653555,0.674637 -0.653555,1.934312 0,1.249133 0.632472,1.929041 0.632473,0.679909 1.797277,0.679909 0.316236,0 0.585037,-0.0369 0.274072,-0.04217 0.490166,-0.126494 v -1.528476 h -1.238592 v -1.359816 h 3.162363 z M 13.897333,16.984826 h 2.26636 l 2.861939,5.3971 v -5.3971 h 1.923771 v 7.869014 h -2.266361 l -2.861938,-5.3971 v 5.3971 h -1.923771 z m -7.9111791,0 h 3.3679169 q 1.5021222,0 2.3032542,0.669367 0.806403,0.664096 0.806403,1.897418 0,1.238592 -0.806403,1.907959 -0.801132,0.664096 -2.3032542,0.664096 H 8.015337 V 24.85384 H 5.9861539 Z m 2.0291831,1.470499 v 2.197842 h 1.122639 q 0.5903078,0 0.911815,-0.284612 0.321507,-0.289884 0.321507,-0.816944 0,-0.527061 -0.321507,-0.811673 Q 9.7282838,18.455325 9.137976,18.455325 Z M 22,14 V 10 A 0.9092,0.9092 0 0 0 21.7,9.3 l -7,-7 A 0.9087,0.9087 0 0 0 14,2 H 4 A 2.0059,2.0059 0 0 0 2,4 v 24 a 2,2 0 0 0 2,2 H 20 V 28 H 4 V 4 h 8 v 6 a 2.0059,2.0059 0 0 0 2,2 h 6 v 2 z M 14,10 V 4.4 l 5.6,5.6 z', transform: 'matrix(.5 0 0 .5 0 0)' }; export const svgIcon = { height: 16, width: 16, path: 'm 30.003472,24.470872 q -0.777459,0.377932 -1.614308,0.566898 -0.836849,0.188965 -1.727688,0.188965 -2.013836,0 -3.190823,-1.122997 -1.176987,-1.128395 -1.176987,-3.055847 0,-1.949047 1.198583,-3.066645 1.198584,-1.117598 3.282607,-1.117598 0.804454,0 1.538722,0.151172 0.739666,0.151173 1.392948,0.448119 v 1.668299 q -0.674878,-0.383331 -1.344357,-0.572297 -0.66408,-0.188966 -1.333559,-0.188966 -1.241776,0 -1.916653,0.696474 -0.669479,0.691075 -0.669479,1.981442 0,1.279569 0.647882,1.976043 0.647883,0.696474 1.841067,0.696474 0.323942,0 0.599292,-0.03779 0.280749,-0.04319 0.502109,-0.129577 v -1.565717 h -1.26877 v -1.392948 h 3.239414 z M 13.239505,17.009421 h 2.089422 l 2.138013,5.949724 2.132615,-5.949724 h 2.089422 l -2.98566,8.060743 h -2.478152 z m -1.392949,0.253755 v 1.706091 q -0.664079,-0.296946 -1.295765,-0.448119 -0.631686,-0.151173 -1.1931845,-0.151173 -0.7450652,0 -1.1014008,0.205163 -0.3563356,0.205163 -0.3563356,0.637085 0,0.323941 0.2375571,0.507508 0.242956,0.178168 0.8746418,0.307745 l 0.8854399,0.178167 q 1.3443571,0.269952 1.9112541,0.820652 0.566898,0.5507 0.566898,1.565717 0,1.333559 -0.793657,1.986841 -0.788257,0.647882 -2.4133633,0.647882 -0.7666614,0 -1.5387217,-0.145773 Q 6.8578586,24.935188 6.0857982,24.64904 v -1.754683 q 0.7720604,0.410326 1.4901305,0.620888 0.7234692,0.205163 1.3929481,0.205163 0.680277,0 1.0420112,-0.226759 0.361735,-0.226759 0.361735,-0.647883 0,-0.377932 -0.248355,-0.583095 Q 9.8813118,22.057509 9.1470446,21.895538 L 8.3425901,21.71737 Q 7.1332088,21.458217 6.5717103,20.891319 6.0156109,20.324422 6.0156109,19.363396 q 0,-1.203983 0.7774594,-1.851865 0.7774594,-0.647883 2.2351958,-0.647883 0.6640799,0 1.3659529,0.102581 0.701873,0.09718 1.452337,0.296947 z M 22,14 V 10 A 0.9092,0.9092 0 0 0 21.7,9.3 l -7,-7 A 0.9087,0.9087 0 0 0 14,2 H 4 A 2.0059,2.0059 0 0 0 2,4 v 24 a 2,2 0 0 0 2,2 H 20 V 28 H 4 V 4 h 8 v 6 a 2.0059,2.0059 0 0 0 2,2 h 6 v 2 z M 14,10 V 4.4 l 5.6,5.6 z', transform: 'matrix(.5 0 0 .5 0 0)' }; ================================================ FILE: src/database/_worker.ts ================================================ import { getHash, API_GET_PATH, API_SAVE_PATH } from "./utility"; import type { History, SheetPostBody } from "./types"; const documentPathRegEx = /^\/[a-zA-Z0-9]{22}$/; const checkpointPathRegEx = /^\/temp-checkpoint-[a-f0-9-]{36}$/; const maxSize = 2000000; // max length of byte string that represents sheet const cspHeaderValue = "default-src 'self'; style-src 'self' 'unsafe-inline'; img-src * data: blob:;"; // local dev mode requires some extra exceptions for live reload const devCspHeaderValue = cspHeaderValue + " script-src 'self' 'unsafe-inline'; connect-src 'self' ws://localhost:5173 wss://localhost:5173;"; const API_MANUAL_SAVE_PATH = "/documents/manual-save"; type Flag = "0" | "1" | 0 | 1 | undefined; interface Env { ASSETS: Fetcher; SHEETS: KVNamespace; DOCGEN_API: String; ENABLE_MANUAL_SAVE: Flag; MANUAL_SAVE_KEY: string | undefined; DEV: Flag; } interface DatabaseEntry { title: string; data: string; dataHash: string; creation: string; creationIp: string; history: History; } function checkFlag(flag: Flag): boolean { return flag !== undefined && (flag === 1 || flag === "1"); } export default { async fetch(request: Request, env: Env) { const url = new URL(request.url); const path = url.pathname; let response: Response; if (path.startsWith(API_SAVE_PATH) && request.method === "POST") { // Store sheet response = await postSheet({ origin: url.origin, requestHash: path.replace(API_SAVE_PATH, ''), requestBody: await request.json(), requestIp: request.headers.get("CF-Connecting-IP") || "", kv: env.SHEETS }); } else if (path.startsWith(API_GET_PATH) && request.method === "GET") { // Get method, return sheet response = await getSheet({ requestHash: path.replace(API_GET_PATH, ''), kv: env.SHEETS }); } else if (checkFlag(env.ENABLE_MANUAL_SAVE) && path.startsWith(API_MANUAL_SAVE_PATH) && env.MANUAL_SAVE_KEY !== undefined && request.method === "POST") { response = await manualSaveSheet({ requestBody: await request.json(), apiKey: env.MANUAL_SAVE_KEY, kv: env.SHEETS }); } else if ((documentPathRegEx.test(path) || checkpointPathRegEx.test(path)) && request.method === "GET") { const indexPage = new URL(request.url); indexPage.pathname = "/"; let mainPage = await env.ASSETS.fetch(new Request(indexPage.toString(), request)); const updatedHeaders = new Headers(mainPage.headers); updatedHeaders.set('Content-Security-Policy', checkFlag(env.DEV) ? devCspHeaderValue : cspHeaderValue); mainPage = new Response(mainPage.body, { status: mainPage.status, statusText: mainPage.statusText, headers: updatedHeaders }); response = new HTMLRewriter() .on('meta[name="robots"]', new IndexIfEmbedded()) .transform(mainPage); } else if ( (path === "/iframe_test.html" || path === "/iframe_test") && request.method === "GET" ) { // don't apply CSP headers to iframe test path (dynamic resizing won't work) response = await env.ASSETS.fetch(request); } else if (path.startsWith("/docgen/")) { // @ts-ignore response = await globalThis.fetch(`${env.DOCGEN_API}${path}`, request); } else { response = await env.ASSETS.fetch(request); if (response.headers.get("Content-Type")?.includes("text/html")) { const updatedHeaders = new Headers(response.headers); updatedHeaders.set('Content-Security-Policy', checkFlag(env.DEV) ? devCspHeaderValue : cspHeaderValue); response = new Response(response.body, { status: response.status, statusText: response.statusText, headers: updatedHeaders }); } } if (url.hostname !== "engineeringpaper.xyz" && !url.port && response.headers.get("Content-Type")?.includes("text/html")) { const canonicalUrl = new URL(url); canonicalUrl.hostname = "engineeringpaper.xyz"; response = new HTMLRewriter() .on('head', new AppendCanonical(canonicalUrl.toString())) .transform(response); } return response; } }; class IndexIfEmbedded { element(element: Element) { element.setAttribute("content", "noindex,indexifembedded"); } } class AppendCanonical { url: string; constructor(url: string) { this.url = url; } element(element: Element) { element.append(`\t\n`, {html: true}); } } async function checkIfAlreadyExists(previousSaveId: string, newData: string, kv: KVNamespace): Promise { const existingEntry = (await kv.get(previousSaveId, { type: "json" }) as DatabaseEntry | null); if (existingEntry) { if (existingEntry.data === newData) { return true; } else { return false; } } else { return false; } } const alphabet = "23456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"; // alphabet from shortuuid python package const idLength = 22; function getNewId(): string { const randomArray = crypto.getRandomValues(new BigUint64Array(idLength)); const alphabetLength = BigInt(alphabet.length); let id = ''; for (const randomNum of randomArray) { id += alphabet[Number(randomNum % alphabetLength)]; } if (id.length !== idLength) { throw new Error('Random id generation error'); } return id; } async function postSheet({ origin, requestHash, requestBody, requestIp, kv }: { origin: string, requestHash: string, requestBody: SheetPostBody, requestIp: string, kv: KVNamespace }): Promise { const data = requestBody.document; if (data.length > maxSize) { return new Response("Sheet too large for database, reduce size of images in documentation cells.", { status: 413 }); } const dataHash = await getHash(` ${data}`); if (dataHash !== requestHash) { return new Response("Document could not be saved.", { status: 404 }); } const dbEntry = { title: requestBody.title, data: data, dataHash: dataHash, creation: (new Date()).toISOString(), creationIp: requestIp, history: requestBody.history, }; let createNewDocument = true; let id = getNewId(); if (dbEntry.history[0] && dbEntry.history[0].hash !== 'file' && await checkIfAlreadyExists(dbEntry.history[0].hash, data, kv)) { // document already exists and hasn't been changed, no need to resave // use existing id createNewDocument = false; id = dbEntry.history[0].hash; } if (createNewDocument) { // update document history to include latest version dbEntry.history.unshift({ url: `${origin}/${id}`, hash: id, creation: dbEntry.creation }); // check for existing key with same id to make sure there isn't an id collision const alreadyExists = await kv.get(id); if (alreadyExists) { return new Response("Sheet id collision, save unsuccessful. Try to save your document again. If issue persists, contact support at support@engineeringpaper.xyz", { status: 404 }); } await kv.put(id, JSON.stringify(dbEntry)); } return new Response(JSON.stringify({ url: `${origin}/${id}`, hash: id, history: dbEntry.history })); } async function getSheet({ requestHash, kv } : { requestHash: string, kv: KVNamespace }): Promise { const document = await kv.get(requestHash, { type: "json", cacheTtl: 31557600 }) as DatabaseEntry; if (!document) { return new Response("Document not found", { status: 404 }); } else { const headers = new Headers(); headers.append("X-Robots-Tag", "noindex"); return new Response( JSON.stringify({ data: document.data, history: document.history, }), { headers: headers } ); } } interface ManualSaveBody { apiKey: string; id: string; title: string; creation: string; access: string; creationIp: string; dataHash: string; history: History; numReads: number; data: string; } async function manualSaveSheet({ requestBody, apiKey, kv }: { requestBody: ManualSaveBody, apiKey: string, kv: KVNamespace }): Promise { if (requestBody.apiKey === apiKey) { // now add actual sheet to KV store const dbEntry = { title: requestBody.title, data: requestBody.data, dataHash: requestBody.dataHash, creation: requestBody.creation, creationIp: requestBody.creationIp, history: requestBody.history, }; await kv.put(requestBody.id, JSON.stringify(dbEntry)); return new Response("Success"); } else { return new Response("Manual save failed", { status: 404 }); } } ================================================ FILE: src/database/scripts/initialize.sql ================================================ DROP TABLE IF EXISTS Sheets; DROP TABLE IF EXISTS NumReads; PRAGMA foreign_keys = ON; CREATE TABLE Sheets ( id TEXT PRIMARY KEY NOT NULL, title TEXT NOT NULL, dataHash TEXT NOT NULL, creation TEXT NOT NULL, creationIp TEXT NOT NULL ); CREATE TABLE NumReads ( id TEXT PRIMARY KEY NOT NULL, numReads INT DEFAULT 1, access TEXT NOT NULL ); ================================================ FILE: src/database/scripts/sheets_used_for_tests.json ================================================ [ [ "2kftdqNYyiaqAEyhXboNZF", "Database Consistency Test", "2022-06-14 15:47:35.455971", "2023-01-04 01:26:46.054019", "24.178.27.137", "5028df57d13f9821a2e0b2da6f57440306b7258c2b058605ebf8ab697dda420cebbb9cb2f3742bf54b3e677fc679e661a2483f97186b27f77db2d31e658f2cdf", [ { "url": "https://engineeringpaper.xyz/#2kftdqNYyiaqAEyhXboNZF", "hash": "2kftdqNYyiaqAEyhXboNZF", "creation": "2022-06-14T15:47:35.455971Z" }, { "url": "https://engineeringpaper.xyz/#QsPdmAWHQNwz9rxPrT3PYk", "hash": "QsPdmAWHQNwz9rxPrT3PYk", "creation": "2022-06-08T20:04:54.562675Z" }, { "url": "https://engineeringpaper.xyz/#d5DEM9teTxodvCTwENwErn", "hash": "d5DEM9teTxodvCTwENwErn", "creation": "2022-06-08T13:11:26.795400Z" }, { "url": "https://engineeringpaper.xyz/#bPX72mmrNjVsgZbos25Gkw", "hash": "bPX72mmrNjVsgZbos25Gkw", "creation": "2022-06-08T12:52:40.806473Z" }, { "url": "https://engineeringpaper.xyz/#WWDzaCSbmXrJp2PhyPEbTF", "hash": "WWDzaCSbmXrJp2PhyPEbTF", "creation": "2022-06-07T21:47:32.771678Z" } ], 1326 ], [ "DuGYz5Lu7tPdEJ27zAT8bg", "Calculating the Johnson-Euler Buckling Load for Columns in Compression", "2022-09-15 14:20:11.081278", "2023-01-04 01:30:45.364273", "24.178.27.137", "45c7066a6346b4a9017350b8301f8681b68ae895bb7f6574c7e4e01bcf08c89fb5a7ee7a1e04db500bc35599a2cdfa6fc8049abc58cf95bc8e33a61f5875e2dd", [ { "url": "https://engineeringpaper.xyz/#DuGYz5Lu7tPdEJ27zAT8bg", "hash": "DuGYz5Lu7tPdEJ27zAT8bg", "creation": "2022-09-15T14:20:11.081278Z" }, { "url": "https://engineeringpaper.xyz/#LCGvytfMLTUir59MFeRKJh", "hash": "LCGvytfMLTUir59MFeRKJh", "creation": "2022-09-15T14:17:16.644679Z" }, { "url": "https://engineeringpaper.xyz/#SRdiqShMDZVjDtXZ8f2pYm", "hash": "SRdiqShMDZVjDtXZ8f2pYm", "creation": "2022-06-30T02:51:23.156397Z" }, { "url": "https://engineeringpaper.xyz/#Sitq8xQdu6rv53W3q7BXzV", "hash": "Sitq8xQdu6rv53W3q7BXzV", "creation": "2022-06-30T02:50:30.762273Z" }, { "url": "https://engineeringpaper.xyz/#JFSZunaEuupWZpTXb55oji", "hash": "JFSZunaEuupWZpTXb55oji", "creation": "2022-06-30T02:41:19.367706Z" }, { "url": "https://engineeringpaper.xyz/#mjV9C7vrKavDffgdFgvcoo", "hash": "mjV9C7vrKavDffgdFgvcoo", "creation": "2022-06-30T01:31:06.958067Z" }, { "url": "https://engineeringpaper.xyz/#mkvs7eQiHRhfW5FnTRo2CT", "hash": "mkvs7eQiHRhfW5FnTRo2CT", "creation": "2022-06-29T20:43:16.476180Z" }, { "url": "https://engineeringpaper.xyz/#k4KScmS4GmaMZD732p3Aro", "hash": "k4KScmS4GmaMZD732p3Aro", "creation": "2022-06-29T16:06:08.144663Z" }, { "url": "https://engineeringpaper.xyz/#NVzyUCCsUoJZpLL9yg9jnM", "hash": "NVzyUCCsUoJZpLL9yg9jnM", "creation": "2022-06-29T03:21:34.733370Z" }, { "url": "https://engineeringpaper.xyz/#PYcYmn7waFjH97h8rMmwWu", "hash": "PYcYmn7waFjH97h8rMmwWu", "creation": "2022-06-29T02:48:15.581059Z" }, { "url": "https://engineeringpaper.xyz/#hfxk5YVJKaYhr6EXnzj6Zm", "hash": "hfxk5YVJKaYhr6EXnzj6Zm", "creation": "2022-06-29T02:42:37.193650Z" }, { "url": "https://engineeringpaper.xyz/#8mDGXubYvM65VAUbtcQfRq", "hash": "8mDGXubYvM65VAUbtcQfRq", "creation": "2022-06-29T02:22:44.627856Z" }, { "url": "https://engineeringpaper.xyz/#DhHNGwun2FciBktAw98dWK", "hash": "DhHNGwun2FciBktAw98dWK", "creation": "2022-06-28T21:01:11.088088Z" } ], 950 ], [ "PaFvsBhgoJdZEEwyBLPnD6", "Mechanical Properties of Selected Metals", "2022-06-07 21:04:43.889591", "2023-01-04 19:42:28.318231", "24.178.27.137", "3bc63ef963bd7d670dc266f78eba22bbe362993b3f393ec04921c94e5b7fe259e7b0caf804a3f83eb8f69e5e571cd2a54f09aa699342e9a5c12cc41f788661bd", [ { "url": "https://engineeringpaper.xyz/#PaFvsBhgoJdZEEwyBLPnD6", "hash": "PaFvsBhgoJdZEEwyBLPnD6", "creation": "2022-06-07T21:04:43.889591Z" }, { "url": "https://engineeringpaper.xyz/#atxKHN57RD8t5wzFA3Dxen", "hash": "atxKHN57RD8t5wzFA3Dxen", "creation": "2022-06-07T21:02:50.182033Z" }, { "url": "https://engineeringpaper.xyz/#BFcTw4EW3a799K2X2eYNyx", "hash": "BFcTw4EW3a799K2X2eYNyx", "creation": "2022-06-07T20:39:19.549172Z" }, { "url": "https://engineeringpaper.xyz/#gnZvqQagtSR7qaRLmzH7He", "hash": "gnZvqQagtSR7qaRLmzH7He", "creation": "2022-06-07T20:34:29.803698Z" } ], 1301 ] ] ================================================ FILE: src/database/scripts/transfer_sheets.js ================================================ import fs from "fs"; import fetch from "node-fetch"; const sheetsFile = process.argv[2]; const targetUrl = process.argv[3]; const targetApiKey = process.env.MANUAL_SAVE_KEY; const sourceUrl = "https://engineeringpaper.herokuapp.com"; const sheets = JSON.parse(fs.readFileSync(sheetsFile)); let count = 1; for (const sheet of sheets) { const id = sheet[0]; console.log(`${count++}: Sheet ${id}`); // get sheet from heroku let response = await fetch(`${sourceUrl}/documents/${id}`); if (!response.ok) { throw new Error(`Error retrieving ${id}`); } const data = (await response.json()).data; const dbObject = { apiKey: targetApiKey, id: id, title: sheet[1], creation: (new Date(sheet[2]+'Z')).toISOString(), access: (new Date(sheet[3]+'Z')).toISOString(), creationIp: sheet[4], dataHash: sheet[5], history: sheet[6], numReads: sheet[7], data: data, } // put sheet into cloudflare response = await fetch(`${targetUrl}/documents/manual-save`, { method: "POST", headers: new Headers({"Content-Type": "application/json"}), body: JSON.stringify(dbObject) }); if (!response.ok) { throw new Error(`Error saving ${id}`); } } ================================================ FILE: src/database/tsconfig.json ================================================ { "compilerOptions": { "target": "esnext", "strict": true, "module": "esnext", "lib": ["esnext"], "types": ["@cloudflare/workers-types"], }, } ================================================ FILE: src/database/types.ts ================================================ export interface HistoryItem { url: string; hash: string; creation: string; } export type History = HistoryItem[]; export interface SheetPostBody { title: string; document: string; history: History; } ================================================ FILE: src/database/utility.ts ================================================ export const API_SAVE_PATH = "/documents/save/"; export const API_GET_PATH = "/documents/get/"; const encoder = new TextEncoder(); export async function getHash(input: string) { const hash = await crypto.subtle.digest('SHA-512', encoder.encode(`${input}math`)); const hashArray = Array.from(new Uint8Array(hash)); return hashArray.map(b => b.toString(16).padStart(2, '0')).join(''); } ================================================ FILE: src/fluidConstants.ts ================================================ export const FLUID_PROPS_PARAMETERS = new Map([ [ "C", { idName: "C", units: "J/kg/K", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: true, description: "Mass specific constant pressure specific heat", } ], [ "D", { idName: "D", units: "kg/m^3", input: true, output: true, trivial: false, incompressibleInput: true, incompressibleOutput: true, description: "Mass density", } ], [ "H", { idName: "H", units: "J/kg", input: true, output: true, trivial: false, incompressibleInput: true, incompressibleOutput: true, description: "Mass specific enthalpy", } ], [ "P", { idName: "P", units: "Pa", input: true, output: true, trivial: false, incompressibleInput: true, incompressibleOutput: true, description: "Pressure", } ], [ "Q", { idName: "Q", units: "mol/mol", input: true, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Molar vapor quality", } ], [ "S", { idName: "S", units: "J/kg/K", input: true, output: true, trivial: false, incompressibleInput: true, incompressibleOutput: true, description: "Mass specific entropy", } ], [ "T", { idName: "T", units: "K", input: true, output: true, trivial: false, incompressibleInput: true, incompressibleOutput: true, description: "Temperature", } ], [ "V", { idName: "V", units: "Pa s", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: true, description: "Viscosity", } ], [ "ACENTRIC", { idName: "Acentric", units: "", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Acentric factor", } ], [ "ALPHA0", { idName: "Alpha0", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Ideal Helmholtz energy", } ], [ "ALPHAR", { idName: "AlphaR", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Residual Helmholtz energy", } ], [ "BVIRIAL", { idName: "BVirial", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Second virial coefficient", } ], [ "CONDUCTIVITY", { idName: "Conductivity", units: "W/m/K", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: true, description: "Thermal conductivity", } ], [ "CP0MASS", { idName: "Cp0Mass", units: "J/kg/K", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Ideal gas mass specific constant pressure specific heat", } ], [ "CP0MOLAR", { idName: "Cp0Molar", units: "J/mol/K", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Ideal gas molar specific constant pressure specific heat", } ], [ "CPMOLAR", { idName: "CpMolar", units: "J/mol/K", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Molar specific constant pressure specific heat", } ], [ "CVIRIAL", { idName: "CVirial", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Third virial coefficient", } ], [ "CVMASS", { idName: "CvMass", units: "J/kg/K", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Mass specific constant volume specific heat", } ], [ "CVMOLAR", { idName: "CvMolar", units: "J/mol/K", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Molar specific constant volume specific heat", } ], [ "D2ALPHA0_DDELTA2_CONSTTAU", { idName: "D2Alpha0DDelta2", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Second derivative of ideal Helmholtz energy with delta", } ], [ "D3ALPHA0_DDELTA3_CONSTTAU", { idName: "D3Alpha0DDelta3", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Third derivative of ideal Helmholtz energy with delta", } ], [ "DALPHA0_DDELTA_CONSTTAU", { idName: "DAlpha0DDelta", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Derivative of ideal Helmholtz energy with delta", } ], [ "DALPHA0_DTAU_CONSTDELTA", { idName: "DAlpha0DTau", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Derivative of ideal Helmholtz energy with tau", } ], [ "DALPHAR_DDELTA_CONSTTAU", { idName: "DAlphaRDDelta", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Derivative of residual Helmholtz energy with delta", } ], [ "DALPHAR_DTAU_CONSTDELTA", { idName: "DAlphaRDTau", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Derivative of residual Helmholtz energy with tau", } ], [ "DBVIRIAL_DT", { idName: "DBVirialDT", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Derivative of second virial coefficient with respect to T", } ], [ "DCVIRIAL_DT", { idName: "DCVirialDT", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Derivative of third virial coefficient with respect to T", } ], [ "DELTA", { idName: "Delta", units: "", input: true, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Reduced density (rho/rhoc)", } ], [ "DIPOLE_MOMENT", { idName: "DipoleMoment", units: "C m", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Dipole moment", } ], [ "DMOLAR", { idName: "DMolar", units: "mol/m^3", input: true, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Molar density", } ], [ "FH", { idName: "FH", units: "", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Flammability hazard", } ], [ "FRACTION_MAX", { idName: "FractionMax", units: "", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Fraction (mole, mass, volume) maximum value for incompressible solutions", } ], [ "FRACTION_MIN", { idName: "FractionMin", units: "", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Fraction (mole, mass, volume) minimum value for incompressible solutions", } ], [ "FUNDAMENTAL_DERIVATIVE_OF_GAS_DYNAMICS", { idName: "FundDerivGasDyn", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Fundamental derivative of gas dynamics", } ], [ "GAS_CONSTANT", { idName: "GasConstant", units: "J/mol/K", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Molar gas constant", } ], [ "G", { idName: "GMass", units: "J/kg", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Mass specific Gibbs energy", } ], [ "GMOLAR", { idName: "GMolar", units: "J/mol", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Molar specific Gibbs energy", } ], [ "GMOLAR_RESIDUAL", { idName: "GMolarResidual", units: "J/mol/K", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Residual molar Gibbs energy", } ], [ "GWP100", { idName: "GWP100", units: "", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "100-year global warming potential", } ], [ "GWP20", { idName: "GWP20", units: "", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "20-year global warming potential", } ], [ "GWP500", { idName: "GWP500", units: "", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "500-year global warming potential", } ], [ "HELMHOLTZMASS", { idName: "HelmholtzMass", units: "J/kg", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Mass specific Helmholtz energy", } ], [ "HELMHOLTZMOLAR", { idName: "HelmholtzMolar", units: "J/mol", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Molar specific Helmholtz energy", } ], [ "HH", { idName: "HH", units: "", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Health hazard", } ], [ "HMOLAR", { idName: "HMolar", units: "J/mol", input: true, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Molar specific enthalpy", } ], [ "HMOLAR_RESIDUAL", { idName: "HMolarResidual", units: "J/mol/K", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Residual molar enthalpy", } ], [ "ISENTROPIC_EXPANSION_COEFFICIENT", { idName: "IsentropicExpansionCoefficient", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Isentropic expansion coefficient", } ], [ "ISOBARIC_EXPANSION_COEFFICIENT", { idName: "IsobaricExpansionCoefficient", units: "1/K", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Isobaric expansion coefficient", } ], [ "ISOTHERMAL_COMPRESSIBILITY", { idName: "IsothermalCompressibility", units: "1/Pa", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Isothermal compressibility", } ], [ "M", { idName: "MolarMass", units: "kg/mol", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Molar mass", } ], [ "ODP", { idName: "ODP", units: "", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Ozone depletion potential", } ], [ "PCRIT", { idName: "PCrit", units: "Pa", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Pressure at the critical point", } ], [ "PH", { idName: "PH", units: "", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Physical hazard", } ], [ "PHASE", { idName: "Phase", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Fluid phase index (display as symbolic to get text version)", } ], [ "PIP", { idName: "PIP", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Phase identification parameter", } ], [ "PMAX", { idName: "PMax", units: "Pa", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Maximum pressure limit", } ], [ "PMIN", { idName: "PMin", units: "Pa", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Minimum pressure limit", } ], [ "PRANDTL", { idName: "Prandtl", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Prandtl number", } ], [ "P_REDUCING", { idName: "PReducing", units: "Pa", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Pressure at the reducing point", } ], [ "PTRIPLE", { idName: "PTriplePoint", units: "Pa", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Pressure at the triple point (pure only)", } ], [ "RHOCRIT", { idName: "RhoCrit", units: "kg/m^3", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Mass density at critical point", } ], [ "RHOMASS_REDUCING", { idName: "RhoMassReducing", units: "kg/m^3", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Mass density at reducing point", } ], [ "RHOMOLAR_CRITICAL", { idName: "RhoMolarCritical", units: "mol/m^3", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Molar density at critical point", } ], [ "RHOMOLAR_REDUCING", { idName: "RhoMolarReducing", units: "mol/m^3", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Molar density at reducing point", } ], [ "SMOLAR", { idName: "SMolar", units: "J/mol/K", input: true, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Molar specific entropy", } ], [ "SMOLAR_RESIDUAL", { idName: "SMolarResidual", units: "J/mol/K", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Residual molar entropy (sr/R = s(T,rho) - s^0(T,rho))", } ], [ "A", { idName: "SoundSpeed", units: "m/s", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Speed of sound", } ], [ "I", { idName: "SurfaceTension", units: "N/m", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Surface tension", } ], [ "TAU", { idName: "Tau", units: "", input: true, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Reciprocal reduced temperature (Tc/T)", } ], [ "TCRIT", { idName: "TCritical", units: "K", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Temperature at the critical point", } ], [ "T_FREEZE", { idName: "TFreeze", units: "K", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Freezing temperature for incompressible solutions", } ], [ "TMAX", { idName: "TMax", units: "K", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: true, description: "Maximum temperature limit", } ], [ "TMIN", { idName: "TMin", units: "K", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: true, description: "Minimum temperature limit", } ], [ "T_REDUCING", { idName: "TReducing", units: "K", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Temperature at the reducing point", } ], [ "TTRIPLE", { idName: "TTriplePoint", units: "K", input: false, output: true, trivial: true, incompressibleInput: false, incompressibleOutput: false, description: "Temperature at the triple point", } ], [ "U", { idName: "U", units: "J/kg", input: true, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: true, description: "Mass specific internal energy", } ], [ "UMOLAR", { idName: "UMolar", units: "J/mol", input: true, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Molar specific internal energy", } ], [ "Z", { idName: "Z", units: "", input: false, output: true, trivial: false, incompressibleInput: false, incompressibleOutput: false, description: "Compressibility factor", } ], ]); export const FLUID_PROPS_PARAMETERS_ORDER = [ ["C", "Quick Access"], ["D", "Quick Access"], ["H", "Quick Access"], ["P", "Quick Access"], ["Q", "Quick Access"], ["S", "Quick Access"], ["T", "Quick Access"], ["V", "Quick Access"], ["ACENTRIC", "All"], ["ALPHA0", "All"], ["ALPHAR", "All"], ["BVIRIAL", "All"], ["C", "All"], ["CONDUCTIVITY", "All"], ["CP0MASS", "All"], ["CP0MOLAR", "All"], ["CPMOLAR", "All"], ["CVIRIAL", "All"], ["CVMASS", "All"], ["CVMOLAR", "All"], ["D", "All"], ["D2ALPHA0_DDELTA2_CONSTTAU", "All"], ["D3ALPHA0_DDELTA3_CONSTTAU", "All"], ["DALPHA0_DDELTA_CONSTTAU", "All"], ["DALPHA0_DTAU_CONSTDELTA", "All"], ["DALPHAR_DDELTA_CONSTTAU", "All"], ["DALPHAR_DTAU_CONSTDELTA", "All"], ["DBVIRIAL_DT", "All"], ["DCVIRIAL_DT", "All"], ["DELTA", "All"], ["DIPOLE_MOMENT", "All"], ["DMOLAR", "All"], ["FH", "All"], ["FRACTION_MAX", "All"], ["FRACTION_MIN", "All"], ["FUNDAMENTAL_DERIVATIVE_OF_GAS_DYNAMICS", "All"], ["GAS_CONSTANT", "All"], ["G", "All"], ["GMOLAR", "All"], ["GMOLAR_RESIDUAL", "All"], ["GWP100", "All"], ["GWP20", "All"], ["GWP500", "All"], ["H", "All"], ["HELMHOLTZMASS", "All"], ["HELMHOLTZMOLAR", "All"], ["HH", "All"], ["HMOLAR", "All"], ["HMOLAR_RESIDUAL", "All"], ["ISENTROPIC_EXPANSION_COEFFICIENT", "All"], ["ISOBARIC_EXPANSION_COEFFICIENT", "All"], ["ISOTHERMAL_COMPRESSIBILITY", "All"], ["M", "All"], ["ODP", "All"], ["P", "All"], ["PCRIT", "All"], ["PH", "All"], ["PHASE", "All"], ["PIP", "All"], ["PMAX", "All"], ["PMIN", "All"], ["PRANDTL", "All"], ["P_REDUCING", "All"], ["PTRIPLE", "All"], ["Q", "All"], ["RHOCRIT", "All"], ["RHOMASS_REDUCING", "All"], ["RHOMOLAR_CRITICAL", "All"], ["RHOMOLAR_REDUCING", "All"], ["S", "All"], ["SMOLAR", "All"], ["SMOLAR_RESIDUAL", "All"], ["A", "All"], ["I", "All"], ["T", "All"], ["TAU", "All"], ["TCRIT", "All"], ["T_FREEZE", "All"], ["TMAX", "All"], ["TMIN", "All"], ["T_REDUCING", "All"], ["TTRIPLE", "All"], ["U", "All"], ["UMOLAR", "All"], ["V", "All"], ["Z", "All"], ]; export const FLUIDS = new Map([ [ "Air", { menuName: "Dry Air", idName: "Air", order: "1", category: "Air, Humid Air, and Water", basic: true, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "HumidAir", { menuName: "Humid Air (Psychrometrics)", idName: "HumidAir", order: "1", category: "Air, Humid Air, and Water", basic: true, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Water", { menuName: "Water (IAPWS-95)", idName: "Water", order: "1", category: "Air, Humid Air, and Water", basic: true, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "1-Butene", { menuName: "1-Butene", idName: "But1ene", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Acetone", { menuName: "Acetone", idName: "Acetone", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Ammonia", { menuName: "Ammonia", idName: "Ammonia", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Argon", { menuName: "Argon", idName: "Argon", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Benzene", { menuName: "Benzene", idName: "Benzene", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "CarbonDioxide", { menuName: "Carbon Dioxide", idName: "CarbonDioxide", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "CarbonMonoxide", { menuName: "Carbon Monoxide", idName: "CarbonMonoxide", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "CarbonylSulfide", { menuName: "Carbonyl Sulfide", idName: "CarbonylSulfide", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "cis-2-Butene", { menuName: "cis-2-Butene", idName: "cis2Butene", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "CycloHexane", { menuName: "Cyclohexane", idName: "Cyclohexane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Cyclopentane", { menuName: "Cyclopentane", idName: "Cyclopentane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "CycloPropane", { menuName: "Cyclopropane", idName: "Cyclopropane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "D4", { menuName: "D4", idName: "D4", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "D5", { menuName: "D5", idName: "D5", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "D6", { menuName: "D6", idName: "D6", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Deuterium", { menuName: "Deuterium", idName: "Deuterium", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Dichloroethane", { menuName: "Dichloroethane", idName: "Dichloroethane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "DiethylEther", { menuName: "Diethyl Ether", idName: "DiethylEther", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "DimethylCarbonate", { menuName: "Dimethyl Carbonate", idName: "DimethylCarbonate", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "DimethylEther", { menuName: "Dimethyl Ether", idName: "DimethylEther", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Ethane", { menuName: "Ethane", idName: "Ethane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Ethanol", { menuName: "Ethanol", idName: "Ethanol", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "EthylBenzene", { menuName: "Ethylbenzene", idName: "Ethylbenzene", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Ethylene", { menuName: "Ethylene", idName: "Ethylene", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "EthyleneOxide", { menuName: "Ethylene Oxide", idName: "EthyleneOxide", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Fluorine", { menuName: "Fluorine", idName: "Fluorine", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "HeavyWater", { menuName: "Heavy Water", idName: "HeavyWater", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Helium", { menuName: "Helium", idName: "Helium", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "HFE143m", { menuName: "HFE-143m", idName: "HFE143m", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Hydrogen", { menuName: "Hydrogen", idName: "Hydrogen", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "HydrogenChloride", { menuName: "Hydrogen Chloride", idName: "HydrogenChloride", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "HydrogenSulfide", { menuName: "Hydrogen Sulfide", idName: "HydrogenSulfide", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "IsoButane", { menuName: "Isobutane", idName: "Isobutane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "IsoButene", { menuName: "Isobutene", idName: "Isobutene", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Isohexane", { menuName: "Isohexane", idName: "Isohexane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Isopentane", { menuName: "Isopentane", idName: "Isopentane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Krypton", { menuName: "Krypton", idName: "Krypton", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "m-Xylene", { menuName: "m-Xylene", idName: "mXylene", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "MD2M", { menuName: "MD2M (Decamethyltetrasiloxane)", idName: "MD2M", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "MD3M", { menuName: "MD3M (Dodecamethylpentasiloxane)", idName: "MD3M", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "MD4M", { menuName: "MD4M (Tetradecamethylhexasiloxane)", idName: "MD4M", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "MDM", { menuName: "MDM (Octamethyltrisiloxane)", idName: "MDM", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Methane", { menuName: "Methane", idName: "Methane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Methanol", { menuName: "Methanol", idName: "Methanol", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "MethylLinoleate", { menuName: "Methyl Linoleate", idName: "MethylLinoleate", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "MethylLinolenate", { menuName: "Methyl Linolenate", idName: "MethylLinolenate", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "MethylOleate", { menuName: "Methyl Oleate", idName: "MethylOleate", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "MethylPalmitate", { menuName: "Methyl Palmitate", idName: "MethylPalmitate", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "MethylStearate", { menuName: "Methyl Stearate", idName: "MethylStearate", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "MM", { menuName: "MM (Hexamethyldisiloxane)", idName: "MM", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "n-Butane", { menuName: "n-Butane", idName: "nButane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "n-Decane", { menuName: "n-Decane", idName: "nDecane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "n-Dodecane", { menuName: "n-Dodecane", idName: "nDodecane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "n-Heptane", { menuName: "n-Heptane", idName: "nHeptane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "n-Hexane", { menuName: "n-Hexane", idName: "nHexane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "n-Nonane", { menuName: "n-Nonane", idName: "nNonane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "n-Octane", { menuName: "n-Octane", idName: "nOctane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "n-Pentane", { menuName: "n-Pentane", idName: "nPentane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "n-Propane", { menuName: "n-Propane", idName: "nPropane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "n-Undecane", { menuName: "n-Undecane", idName: "nUndecane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Neon", { menuName: "Neon", idName: "Neon", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Neopentane", { menuName: "Neopentane", idName: "Neopentane", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Nitrogen", { menuName: "Nitrogen", idName: "Nitrogen", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "NitrousOxide", { menuName: "Nitrous Oxide", idName: "NitrousOxide", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Novec649", { menuName: "Novec 649", idName: "Novec649", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "o-Xylene", { menuName: "o-Xylene", idName: "oXylene", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "OrthoDeuterium", { menuName: "Orthodeuterium", idName: "OrthoDeuterium", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "OrthoHydrogen", { menuName: "Orthohydrogen", idName: "OrthoHydrogen", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Oxygen", { menuName: "Oxygen", idName: "Oxygen", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "p-Xylene", { menuName: "p-Xylene", idName: "pXylene", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "ParaDeuterium", { menuName: "Paradeuterium", idName: "ParaDeuterium", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "ParaHydrogen", { menuName: "Parahydrogen", idName: "ParaHydrogen", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Propylene", { menuName: "Propylene", idName: "Propylene", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Propyne", { menuName: "Propyne", idName: "Propyne", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R11", { menuName: "R11", idName: "R11", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R113", { menuName: "R113", idName: "R113", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R114", { menuName: "R114", idName: "R114", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R115", { menuName: "R115", idName: "R115", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R116", { menuName: "R116", idName: "R116", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R12", { menuName: "R12", idName: "R12", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R123", { menuName: "R123", idName: "R123", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R1233zd(E)", { menuName: "R1233zd(E)", idName: "R1233zdE", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R1234yf", { menuName: "R1234yf", idName: "R1234yf", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R1234ze(E)", { menuName: "R1234ze(E)", idName: "R1234zeE", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R1234ze(Z)", { menuName: "R1234ze(Z)", idName: "R1234zeZ", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R124", { menuName: "R124", idName: "R124", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R1243zf", { menuName: "R1243zf", idName: "R1243zf", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R125", { menuName: "R125", idName: "R125", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R1336mzz(E)", { menuName: "R1336mzz(E)", idName: "R1336MZZE", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R13", { menuName: "R13", idName: "R13", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R134a", { menuName: "R134a", idName: "R134a", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R13I1", { menuName: "R13I1", idName: "R13I1", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R14", { menuName: "R14", idName: "R14", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R141b", { menuName: "R141b", idName: "R141b", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R142b", { menuName: "R142b", idName: "R142b", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R143a", { menuName: "R143a", idName: "R143a", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R152A", { menuName: "R152A", idName: "R152A", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R161", { menuName: "R161", idName: "R161", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R21", { menuName: "R21", idName: "R21", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R218", { menuName: "R218", idName: "R218", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R22", { menuName: "R22", idName: "R22", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R227EA", { menuName: "R227EA", idName: "R227EA", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R23", { menuName: "R23", idName: "R23", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R236EA", { menuName: "R236EA", idName: "R236EA", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R236FA", { menuName: "R236FA", idName: "R236FA", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R245ca", { menuName: "R245ca", idName: "R245ca", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R245fa", { menuName: "R245fa", idName: "R245fa", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R32", { menuName: "R32", idName: "R32", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: true, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R365MFC", { menuName: "R365MFC", idName: "R365MFC", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R40", { menuName: "R40", idName: "R40", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R404A", { menuName: "R404A", idName: "R404A", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R407C", { menuName: "R407C", idName: "R407C", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R41", { menuName: "R41", idName: "R41", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R410A", { menuName: "R410A", idName: "R410A", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "R507A", { menuName: "R507A", idName: "R507A", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "RC318", { menuName: "RC318", idName: "RC318", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "SES36", { menuName: "SES36", idName: "SES36", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "SulfurDioxide", { menuName: "Sulfur Dioxide", idName: "SulfurDioxide", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "SulfurHexafluoride", { menuName: "Sulfur Hexafluoride", idName: "SulfurHexafluoride", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Toluene", { menuName: "Toluene", idName: "Toluene", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "trans-2-Butene", { menuName: "trans-2-Butene", idName: "trans2Butene", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "IF97::Water", { menuName: "Water (IAPWS-IF97)", idName: "Water", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: true, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Xenon", { menuName: "Xenon", idName: "Xenon", order: "2", category: "Pure and Pseudo-Pure Fluids", basic: false, compressibleMixtureComponent: true, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::Acetone", { menuName: "Acetone, liquid phase at 10 bar", idName: "Acetone", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::Air", { menuName: "Air, gaseous phase at 1 atm (101325 Pa)", idName: "Air", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::AS10", { menuName: "Aspen Temper -10, Potassium acetate/formate", idName: "AS10", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::AS20", { menuName: "Aspen Temper -20, Potassium acetate/formate", idName: "AS20", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::AS30", { menuName: "Aspen Temper -30, Potassium acetate/formate", idName: "AS30", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::AS40", { menuName: "Aspen Temper -40, Potassium acetate/formate", idName: "AS40", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::AS55", { menuName: "Aspen Temper -55, Potassium acetate/formate", idName: "AS55", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::TCO", { menuName: "Citrus oil terpene - d-Limonene", idName: "TCO", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::DEB", { menuName: "Diethylbenzene mixture - Dowtherm J", idName: "DEB", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::DowJ2", { menuName: "Dowtherm J, Diethylbenzene mixture", idName: "DowJ2", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::DowQ2", { menuName: "Dowtherm Q, Diphenylethane/alkylated aromatics", idName: "DowQ2", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::DowJ", { menuName: "DowthermJ", idName: "DowJ", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::DowQ", { menuName: "DowthermQ", idName: "DowQ", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HC10", { menuName: "Dynalene HC10", idName: "HC10", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HC20", { menuName: "Dynalene HC20", idName: "HC20", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HC30", { menuName: "Dynalene HC30", idName: "HC30", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HC40", { menuName: "Dynalene HC40", idName: "HC40", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HC50", { menuName: "Dynalene HC50", idName: "HC50", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::DSF", { menuName: "Dynalene SF", idName: "DSF", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::Ethanol", { menuName: "Ethanol, liquid phase at 10 bar", idName: "Ethanol", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::FoodAsh", { menuName: "Food ash model from the 2006 ASHRAE Handbook", idName: "FoodAsh", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::FoodCarbohydrate", { menuName: "Food carbohydrate model from the 2006 ASHRAE Handbook", idName: "FoodCarbohydrate", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::FoodFat", { menuName: "Food fat model from the 2006 ASHRAE Handbook", idName: "FoodFat", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::FoodFiber", { menuName: "Food fiber model from the 2006 ASHRAE Handbook", idName: "FoodFiber", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::FoodIce", { menuName: "Food ice model from the 2006 ASHRAE Handbook", idName: "FoodIce", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::FoodProtein", { menuName: "Food protein model from the 2006 ASHRAE Handbook", idName: "FoodProtein", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::FoodWater", { menuName: "Food water model from the 2006 ASHRAE Handbook", idName: "FoodWater", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::Hexane", { menuName: "Hexane, liquid phase at 10 bar", idName: "Hexane", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HFE2", { menuName: "HFE-7100, Hydrofluoroether", idName: "HFE2", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HY20", { menuName: "HYCOOL 20, Potassium formate", idName: "HY20", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HY30", { menuName: "HyCool 30, Potassium formate", idName: "HY30", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HY40", { menuName: "HyCool 40, Potassium formate", idName: "HY40", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HY45", { menuName: "HyCool 45, Potassium formate", idName: "HY45", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HY50", { menuName: "HyCool 50, Potassium formate", idName: "HY50", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HCB", { menuName: "Hydrocarbon blend - Dynalene MV", idName: "HCB", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HCM", { menuName: "Hydrocarbon mixture - Gilotherm D12", idName: "HCM", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::HFE", { menuName: "Hydrofluoroether - HFE-7100 3M Novec", idName: "HFE", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::LiqNa", { menuName: "LiqNa", idName: "LiqNa", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::NaK", { menuName: "Nitrate salt, 0.6 NaNO3 and 0.4 KNO3", idName: "NaK", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::PCL", { menuName: "Paracryol, Aliphatic Hydrocarbon", idName: "PCL", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::PCR", { menuName: "Paratherm CR", idName: "PCR", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::PGLT", { menuName: "Paratherm GLT", idName: "PGLT", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::PHE", { menuName: "Paratherm HE", idName: "PHE", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::PHR", { menuName: "Paratherm HR", idName: "PHR", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::PLR", { menuName: "Paratherm LR", idName: "PLR", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::PMR", { menuName: "Paratherm MR", idName: "PMR", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::PNF", { menuName: "Paratherm NF", idName: "PNF", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::PNF2", { menuName: "Paratherm NF, Hydrotreated mineral oil", idName: "PNF2", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::PBB", { menuName: "Pirobloc HTF-BASIC", idName: "PBB", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::PMS1", { menuName: "Polydimethylsiloxan 1 - Baysilone KT3", idName: "PMS1", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::PMS2", { menuName: "Polydimethylsiloxan 2 - Syltherm XLT", idName: "PMS2", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::S800", { menuName: "Syltherm 800", idName: "S800", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::XLT2", { menuName: "Syltherm XLT, Polydimethylsiloxan", idName: "XLT2", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::XLT", { menuName: "SylthermXLT", idName: "XLT", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::SAB", { menuName: "Synthetic alkyl benzene - Marlotherm X", idName: "SAB", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::TX22", { menuName: "Texatherm22", idName: "TX22", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::T66", { menuName: "Therminol66", idName: "T66", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::T72", { menuName: "Therminol72", idName: "T72", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::TD12", { menuName: "TherminolD12", idName: "TD12", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::TVP1", { menuName: "TherminolVP1", idName: "TVP1", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::TVP1869", { menuName: "Thermogen VP 1869", idName: "TVP1869", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::TY10", { menuName: "Tyfoxit 1.10, Potassium Acetate", idName: "TY10", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::TY15", { menuName: "Tyfoxit 1.15, Potassium Acetate", idName: "TY15", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::TY20", { menuName: "Tyfoxit 1.20, Potassium Acetate", idName: "TY20", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::TY24", { menuName: "Tyfoxit 1.24, Potassium Acetate", idName: "TY24", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::Water", { menuName: "Water, fit of EOS from 1 bar to 100 bar", idName: "Water", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::NBS", { menuName: "Water, NBS", idName: "NBS", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::ZS10", { menuName: "Zitrec S10, Potassium formate/Sodium propionate", idName: "ZS10", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::ZS25", { menuName: "Zitrec S25, Potassium formate/Sodium propionate", idName: "ZS25", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::ZS40", { menuName: "Zitrec S40, Potassium formate/Sodium propionate", idName: "ZS40", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::ZS45", { menuName: "Zitrec S45, Potassium formate/Sodium propionate", idName: "ZS45", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::ZS55", { menuName: "Zitrec S55, Potassium formate/Sodium propionate", idName: "ZS55", order: "3", category: "Incompressible Fluids", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "INCOMP::MAM", { menuName: "Ammonia (NH3) - aq", idName: "MAM", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.3, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.3 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MAM2", { menuName: "Ammonia, Melinder", idName: "MAM2", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.08, maxConcentration: 0.24, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.08 - 0.24 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MCA", { menuName: "Calcium Chloride (CaCl2) - aq", idName: "MCA", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.3, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.3 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MCA2", { menuName: "Calcium Chloride, Melinder", idName: "MCA2", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.09, maxConcentration: 0.29, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.09 - 0.29 (all water=0.0, no water=1.0)", } ], [ "INCOMP::VCA", { menuName: "Calcium Cloride, VDI", idName: "VCA", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.15, maxConcentration: 0.3, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.15 - 0.3 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MEA2", { menuName: "Ethanol, Melinder", idName: "MEA2", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.11, maxConcentration: 0.6, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.11 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MEA", { menuName: "Ethyl Alcohol (Ethanol) - aq", idName: "MEA", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.6, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MEG", { menuName: "Ethylene Glycol - aq", idName: "MEG", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: true, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.6, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MEG2", { menuName: "Ethylene Glycol, Melinder", idName: "MEG2", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.56, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.56 (all water=0.0, no water=1.0)", } ], [ "INCOMP::FRE", { menuName: "Freezium, Potassium Formate", idName: "FRE", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.19, maxConcentration: 0.5, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.19 - 0.5 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MGL", { menuName: "Glycerol - aq", idName: "MGL", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.6, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MGL2", { menuName: "Glycerol, Melinder", idName: "MGL2", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.2, maxConcentration: 0.63, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.2 - 0.63 (all water=0.0, no water=1.0)", } ], [ "INCOMP::IceEA", { menuName: "Ice slurry with Ethanol", idName: "IceEA", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.05, maxConcentration: 0.35, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.05 - 0.35 (all water=0.0, no water=1.0)", } ], [ "INCOMP::IceNA", { menuName: "Ice slurry with NaCl", idName: "IceNA", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.05, maxConcentration: 0.35, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.05 - 0.35 (all water=0.0, no water=1.0)", } ], [ "INCOMP::IcePG", { menuName: "Ice slurry with Propylene Glycol", idName: "IcePG", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.05, maxConcentration: 0.35, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.05 - 0.35 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MLI", { menuName: "Lithium Chloride (LiCl) - aq", idName: "MLI", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.24, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.24 (all water=0.0, no water=1.0)", } ], [ "INCOMP::LiBr", { menuName: "Lithium-bromide solution - aq", idName: "LiBr", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.75, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.75 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MMG2", { menuName: "Magnesium Chloride, Melinder", idName: "MMG2", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.21, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.21 (all water=0.0, no water=1.0)", } ], [ "INCOMP::VMG", { menuName: "Magnesium Chloride, VDI", idName: "VMG", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.07, maxConcentration: 0.21, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.07 - 0.21 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MMA2", { menuName: "Methanol, Melinder", idName: "MMA2", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.08, maxConcentration: 0.47, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.08 - 0.47 (all water=0.0, no water=1.0)", } ], [ "INCOMP::VMA", { menuName: "Methanol, VDI", idName: "VMA", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.1, maxConcentration: 0.9, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.1 - 0.9 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MMA", { menuName: "Methyl Alcohol (Methanol) - aq", idName: "MMA", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.6, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MMG", { menuName: "MgCl2 - aq", idName: "MMG", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.3, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.3 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MKA", { menuName: "Potassium Acetate (CH3CO2K) - aq", idName: "MKA", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.45, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.45 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MKA2", { menuName: "Potassium Acetate, Melinder", idName: "MKA2", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.11, maxConcentration: 0.41, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.11 - 0.41 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MKC", { menuName: "Potassium Carbonate (K2CO3) - aq", idName: "MKC", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.4, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.4 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MKC2", { menuName: "Potassium Carbonate, Melinder", idName: "MKC2", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.39, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.39 (all water=0.0, no water=1.0)", } ], [ "INCOMP::VKC", { menuName: "Potassium Carbonate, VDI", idName: "VKC", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.13, maxConcentration: 0.39, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.13 - 0.39 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MKF", { menuName: "Potassium Formate (CHKO2) - aq", idName: "MKF", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.48, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.48 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MPG", { menuName: "Propylene Glycol - aq", idName: "MPG", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: true, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.6, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MPG2", { menuName: "Propylene Glycol, Melinder", idName: "MPG2", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.15, maxConcentration: 0.57, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.15 - 0.57 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MITSW", { menuName: "Seawater, MIT", idName: "MITSW", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.12, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.12 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MNA", { menuName: "Sodium Chloride (NaCl) - aq", idName: "MNA", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.23, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.23 (all water=0.0, no water=1.0)", } ], [ "INCOMP::MNA2", { menuName: "Sodium Chloride, Melinder", idName: "MNA2", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 0.23, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0 - 0.23 (all water=0.0, no water=1.0)", } ], [ "INCOMP::VNA", { menuName: "Sodium Chloride, VDI", idName: "VNA", order: "4", category: "Incompressible Mass-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.07, maxConcentration: 0.23, longDescription: "Incompressible Mass-Based Aqueous Solution, valid concentration range: 0.07 - 0.23 (all water=0.0, no water=1.0)", } ], [ "INCOMP::AKF", { menuName: "Antifrogen KF, Potassium Formate", idName: "AKF", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.4, maxConcentration: 1, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.4 - 1 (all water=0.0, no water=1.0)", } ], [ "INCOMP::AL", { menuName: "Antifrogen L, Propylene Glycol", idName: "AL", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.1, maxConcentration: 0.6, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.1 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::AN", { menuName: "Antifrogen N, Ethylene Glycol", idName: "AN", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.1, maxConcentration: 0.6, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.1 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::AEG", { menuName: "Ethylene Glycol, ASHRAE", idName: "AEG", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: true, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.1, maxConcentration: 0.6, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.1 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::GKN", { menuName: "Glykosol N, Ethylene Glycol", idName: "GKN", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.1, maxConcentration: 0.6, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.1 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::PK2", { menuName: "Pekasol 2000, K acetate/formate", idName: "PK2", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.3, maxConcentration: 1, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.3 - 1 (all water=0.0, no water=1.0)", } ], [ "INCOMP::PKL", { menuName: "Pekasol L, Propylene Glycol", idName: "PKL", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.1, maxConcentration: 0.6, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.1 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::APG", { menuName: "Propylene Glycol, ASHRAE", idName: "APG", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: true, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.1, maxConcentration: 0.6, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.1 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::ZAC", { menuName: "Zitrec AC, Corrosion Inhibitor", idName: "ZAC", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.06, maxConcentration: 0.5, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.06 - 0.5 (all water=0.0, no water=1.0)", } ], [ "INCOMP::ZFC", { menuName: "Zitrec FC, Propylene Glycol", idName: "ZFC", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.3, maxConcentration: 0.6, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.3 - 0.6 (all water=0.0, no water=1.0)", } ], [ "INCOMP::ZLC", { menuName: "Zitrec LC, Propylene Glycol", idName: "ZLC", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.3, maxConcentration: 0.7, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.3 - 0.7 (all water=0.0, no water=1.0)", } ], [ "INCOMP::ZM", { menuName: "Zitrec M, Ethylene Glycol", idName: "ZM", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0, maxConcentration: 1, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0 - 1 (all water=0.0, no water=1.0)", } ], [ "INCOMP::ZMC", { menuName: "Zitrec MC, Ethylene Glycol", idName: "ZMC", order: "5", category: "Incompressible Volume-Based Aqueous Solutions", basic: false, compressibleMixtureComponent: false, incompressible: true, incompressibleMixture: true, minConcentration: 0.3, maxConcentration: 0.7, longDescription: "Incompressible Volume-Based Aqueous Solution, valid concentration range: 0.3 - 0.7 (all water=0.0, no water=1.0)", } ], [ "CustomMixture", { menuName: "Mixture (User Defined)", idName: "Mixture", order: "6", category: "User Defined Mixture of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "", } ], [ "Air.mix", { menuName: "Air", idName: "AirMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - NITROGEN: 0.7812, ARGON: 0.0092, OXYGEN: 0.2096", } ], [ "Amarillo.mix", { menuName: "Amarillo", idName: "AmarilloMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - METHANE: 0.906724, NITROGEN: 0.031284, CO2: 0.004676, ETHANE: 0.045279, PROPANE: 0.00828, ISOBUTAN: 0.001037, BUTANE: 0.001563, IPENTANE: 0.000321, PENTANE: 0.000443, HEXANE: 0.000393", } ], [ "Ekofisk.mix", { menuName: "Ekofisk", idName: "EkofiskMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - METHANE: 0.859063, NITROGEN: 0.010068, CO2: 0.014954, ETHANE: 0.084919, PROPANE: 0.023015, ISOBUTAN: 0.003486, BUTANE: 0.003506, IPENTANE: 0.000509, PENTANE: 0.00048", } ], [ "GulfCoast.mix", { menuName: "Gulf Coast", idName: "GulfCoastMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - METHANE: 0.965222, NITROGEN: 0.002595, CO2: 0.005956, ETHANE: 0.018186, PROPANE: 0.004596, ISOBUTAN: 0.000977, BUTANE: 0.001007, IPENTANE: 0.000473, PENTANE: 0.000324, HEXANE: 0.000664", } ], [ "GulfCoastGas(NIST1).mix", { menuName: "Gulf Coast Gas (NIST1)", idName: "GulfCoastGasMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - METHANE: 0.965222, NITROGEN: 0.002595, CO2: 0.005956, ETHANE: 0.018186, PROPANE: 0.004596, ISOBUTAN: 0.000977, BUTANE: 0.001007, IPENTANE: 0.000473, PENTANE: 0.000324, HEXANE: 0.000664", } ], [ "HighCO2.mix", { menuName: "High CO2", idName: "HighCO2Mixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - METHANE: 0.81212, NITROGEN: 0.05702, CO2: 0.07585, ETHANE: 0.04303, PROPANE: 0.00895, ISOBUTAN: 0.00151, BUTANE: 0.00152", } ], [ "HighN2.mix", { menuName: "High N2", idName: "HighN2Mixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - METHANE: 0.81441, NITROGEN: 0.13465, CO2: 0.00985, ETHANE: 0.033, PROPANE: 0.00605, ISOBUTAN: 0.001, BUTANE: 0.00104", } ], [ "NaturalGasSample.mix", { menuName: "Natural Gas Sample", idName: "NaturalGasSampleMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - METHANE: 0.95123, NITROGEN: 0.00089, CO2: 0.02555, ETHANE: 0.01835, PROPANE: 0.00238, ISOBUTAN: 0.0004, BUTANE: 0.00016, IPENTANE: 0.00014, PENTANE: 0.00011, HEXANE: 0.00079", } ], [ "TypicalNaturalGas.mix", { menuName: "Natural Gas, Typical", idName: "TypicalNaturalGasMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: true, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - METHANE: 0.95123, NITROGEN: 0.00089, CO2: 0.02555, ETHANE: 0.01835, PROPANE: 0.00238, ISOBUTAN: 0.0004, BUTANE: 0.00016, IPENTANE: 0.00014, PENTANE: 0.00011, HEXANE: 0.00079", } ], [ "R401A.mix", { menuName: "R401A", idName: "R401AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.578854210704231, R152A: 0.185871453986601, R124: 0.235274335309169", } ], [ "R401B.mix", { menuName: "R401B", idName: "R401BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.654924685341436, R152A: 0.154607382276918, R124: 0.190467932381646", } ], [ "R401C.mix", { menuName: "R401C", idName: "R401CMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.385591186504412, R152A: 0.229445970225924, R124: 0.384962843269664", } ], [ "R402A.mix", { menuName: "R402A", idName: "R402AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.507659889396724, PROPANE: 0.0460590346231213, R22: 0.446281075980154", } ], [ "R402B.mix", { menuName: "R402B", idName: "R402BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.299858744498276, PROPANE: 0.0429562491180057, R22: 0.657185006383719", } ], [ "R403A.mix", { menuName: "R403A", idName: "R403AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPANE: 0.104301635230068, R22: 0.797852142841926, R218: 0.0978462219280052", } ], [ "R403B.mix", { menuName: "R403B", idName: "R403BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPANE: 0.117083478399255, R22: 0.668734422027154, R218: 0.214182099573591", } ], [ "R404A.mix", { menuName: "R404A", idName: "R404AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.357816784026318, R134A: 0.0382639950410712, R143A: 0.603919220932611", } ], [ "R405A.mix", { menuName: "R405A", idName: "R405AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.582397185883849, R152A: 0.118598940913682, R142B: 0.0612463586573, RC318: 0.237757514545169", } ], [ "R406A.mix", { menuName: "R406A", idName: "R406AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.571559096367276, ISOBUTAN: 0.0618403319459979, R142B: 0.366600571686726", } ], [ "R407A.mix", { menuName: "R407A", idName: "R407AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.346419854360797, R125: 0.300315552114308, R134A: 0.353264593524896", } ], [ "R407B.mix", { menuName: "R407B", idName: "R407BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.197865007175653, R125: 0.600360468492644, R134A: 0.201774524331703", } ], [ "R407C.mix", { menuName: "R407C", idName: "R407CMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.381109419953993, R125: 0.179558888662016, R134A: 0.439331691383991", } ], [ "R407D.mix", { menuName: "R407D", idName: "R407DMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.262268077791873, R125: 0.113681680758968, R134A: 0.624050241449159", } ], [ "R407E.mix", { menuName: "R407E", idName: "R407EMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.402611526984881, R125: 0.104708637358978, R134A: 0.492679835656141", } ], [ "R407F.mix", { menuName: "R407F", idName: "R407FMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.473194694453358, R125: 0.205109095413331, R134A: 0.321696210133311", } ], [ "R408A.mix", { menuName: "R408A", idName: "R408AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.0507496395780536, R143A: 0.476277681499092, R22: 0.472972678922854", } ], [ "R409A.mix", { menuName: "R409A", idName: "R409AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.676088021274302, R124: 0.178481953421098, R142B: 0.1454300253046", } ], [ "R409B.mix", { menuName: "R409B", idName: "R409BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.726713817097545, R124: 0.177089324155708, R142B: 0.0961968587467468", } ], [ "R410A.mix", { menuName: "R410A", idName: "R410AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.697614699375863, R125: 0.302385300624138", } ], [ "R410B.mix", { menuName: "R410B", idName: "R410BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.653688938033229, R125: 0.346311061966771", } ], [ "R411A.mix", { menuName: "R411A", idName: "R411AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPYLEN: 0.0293595987641706, R22: 0.833472654512905, R152A: 0.137167746722925", } ], [ "R411B.mix", { menuName: "R411B", idName: "R411BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPYLEN: 0.0592216130255444, R22: 0.903048917855743, R152A: 0.0377294691187131", } ], [ "R412A.mix", { menuName: "R412A", idName: "R412AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.746189416536491, R218: 0.0245117299030133, R142B: 0.229298853560496", } ], [ "R413A.mix", { menuName: "R413A", idName: "R413AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R218: 0.0497604388838132, R134A: 0.896582929746185, ISOBUTAN: 0.0536566313700015", } ], [ "R414A.mix", { menuName: "R414A", idName: "R414AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.571718248653786, R124: 0.202422623615037, ISOBUTAN: 0.0667091242374272, R142B: 0.159150003493749", } ], [ "R414B.mix", { menuName: "R414B", idName: "R414BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.58743911052603, R124: 0.29030851296569, ISOBUTAN: 0.0262178745861124, R142B: 0.0960345019221677", } ], [ "R415A.mix", { menuName: "R415A", idName: "R415AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.776780159383737, R152A: 0.223219840616263", } ], [ "R415B.mix", { menuName: "R415B", idName: "R415BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.202949716550675, R152A: 0.797050283449325", } ], [ "R416A.mix", { menuName: "R416A", idName: "R416AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R134A: 0.647182715864291, R124: 0.323933072881677, BUTANE: 0.0288842112540324", } ], [ "R417A.mix", { menuName: "R417A", idName: "R417AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.414456113615123, R134A: 0.523100248809492, BUTANE: 0.0624436375753851", } ], [ "R417B.mix", { menuName: "R417B", idName: "R417BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.744566872257699, R134A: 0.202885026732296, BUTANE: 0.052548101010005", } ], [ "R417C.mix", { menuName: "R417C", idName: "R417CMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.168533780311387, R134A: 0.801126056234188, BUTANE: 0.0303401634544254", } ], [ "R418A.mix", { menuName: "R418A", idName: "R418AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPANE: 0.0287766462758765, R22: 0.939204558675462, R152A: 0.0320187950486611", } ], [ "R419A.mix", { menuName: "R419A", idName: "R419AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.701459965531065, R134A: 0.203604819551495, DME: 0.0949352149174398", } ], [ "R419B.mix", { menuName: "R419B", idName: "R419BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.425134881380361, R134A: 0.494935410459673, DME: 0.0799297081599657", } ], [ "R420A.mix", { menuName: "R420A", idName: "R420AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R134A: 0.878387913267685, R142B: 0.121612086732315", } ], [ "R421A.mix", { menuName: "R421A", idName: "R421AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.540011717389644, R134A: 0.459988282610356", } ], [ "R421B.mix", { menuName: "R421B", idName: "R421BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.828099498512419, R134A: 0.171900501487581", } ], [ "R422A.mix", { menuName: "R422A", idName: "R422AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.805501067600345, R134A: 0.128043250123554, ISOBUTAN: 0.0664556822761011", } ], [ "R422B.mix", { menuName: "R422B", idName: "R422BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.497287395965083, R134A: 0.446700400155301, ISOBUTAN: 0.0560122038796163", } ], [ "R422C.mix", { menuName: "R422C", idName: "R422CMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.774757115908852, R134A: 0.166711388687975, ISOBUTAN: 0.0585314954031729", } ], [ "R422D.mix", { menuName: "R422D", idName: "R422DMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.596291711495645, R134A: 0.339399053279791, ISOBUTAN: 0.064309235224564", } ], [ "R422E.mix", { menuName: "R422E", idName: "R422EMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.528211539833383, R134A: 0.421012248071509, ISOBUTAN: 0.0507762120951078", } ], [ "R423A.mix", { menuName: "R423A", idName: "R423AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R134A: 0.648115324820034, R227EA: 0.351884675179966", } ], [ "R424A.mix", { menuName: "R424A", idName: "R424AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.45615402931289, R134A: 0.49939050863627, ISOBUTAN: 0.0167872396578164, BUTANE: 0.0186524885086849, IPENTANE: 0.00901573388433862", } ], [ "R425A.mix", { menuName: "R425A", idName: "R425AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.321134464075019, R134A: 0.615130603145805, R227EA: 0.0637349327791751", } ], [ "R426A.mix", { menuName: "R426A", idName: "R426AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.0431546741714159, R134A: 0.925684310853531, BUTANE: 0.0227152573734822, IPENTANE: 0.00844575760157109", } ], [ "R427A.mix", { menuName: "R427A", idName: "R427AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.260775797534104, R125: 0.188391404795509, R143A: 0.107618901019853, R134A: 0.443213896650535", } ], [ "R428A.mix", { menuName: "R428A", idName: "R428AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.694325251072399, R143A: 0.255893190962662, PROPANE: 0.0146310583647717, ISOBUTAN: 0.0351504996001673", } ], [ "R429A.mix", { menuName: "R429A", idName: "R429AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - DME: 0.66113457206158, R152A: 0.0768533364747054, ISOBUTAN: 0.262012091463714", } ], [ "R429A.mix", { menuName: "R429A", idName: "R429AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - DME: 0.66113457206158, R152A: 0.0768533364747054, ISOBUTAN: 0.262012091463714", } ], [ "R430A.mix", { menuName: "R430A", idName: "R430AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R152A: 0.735906531919507, ISOBUTAN: 0.264093468080493", } ], [ "R430A.mix", { menuName: "R430A", idName: "R430AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R152A: 0.735906531919507, ISOBUTAN: 0.264093468080493", } ], [ "R431A.mix", { menuName: "R431A", idName: "R431AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPANE: 0.785742532365466, R152A: 0.214257467634534", } ], [ "R431A.mix", { menuName: "R431A", idName: "R431AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPANE: 0.785742532365466, R152A: 0.214257467634534", } ], [ "R432A.mix", { menuName: "R432A", idName: "R432AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPYLEN: 0.814097241703795, DME: 0.185902758296205", } ], [ "R432A.mix", { menuName: "R432A", idName: "R432AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPYLEN: 0.814097241703795, DME: 0.185902758296205", } ], [ "R433A.mix", { menuName: "R433A", idName: "R433AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPYLEN: 0.309917763130151, PROPANE: 0.690082236869849", } ], [ "R433A.mix", { menuName: "R433A", idName: "R433AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPYLEN: 0.309917763130151, PROPANE: 0.690082236869849", } ], [ "R433B.mix", { menuName: "R433B", idName: "R433BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPYLEN: 0.0522701063955236, PROPANE: 0.947729893604476", } ], [ "R433C.mix", { menuName: "R433C", idName: "R433CMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPYLEN: 0.25887610544032, PROPANE: 0.74112389455968", } ], [ "R434A.mix", { menuName: "R434A", idName: "R434AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.556782765664377, R143A: 0.226468961005242, R134A: 0.165810098372986, ISOBUTAN: 0.0509381749573948", } ], [ "R434A.mix", { menuName: "R434A", idName: "R434AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.556782765664377, R143A: 0.226468961005242, R134A: 0.165810098372986, ISOBUTAN: 0.0509381749573948", } ], [ "R435A.mix", { menuName: "R435A", idName: "R435AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - DME: 0.85152261670421, R152A: 0.14847738329579", } ], [ "R436A.mix", { menuName: "R436A", idName: "R436AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPANE: 0.62652773298942, ISOBUTAN: 0.37347226701058", } ], [ "R436B.mix", { menuName: "R436B", idName: "R436BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPANE: 0.588127503607667, ISOBUTAN: 0.411872496392333", } ], [ "R437A.mix", { menuName: "R437A", idName: "R437AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.168496314343733, R134A: 0.797898667324292, BUTANE: 0.0249804624362383, PENTANE: 0.00862455589573693", } ], [ "R438A.mix", { menuName: "R438A", idName: "R438AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.161915681788051, R125: 0.371558801739542, R134A: 0.42929872424902, BUTANE: 0.0289854872298073, IPENTANE: 0.00824130499357989", } ], [ "R438A.mix", { menuName: "R438A", idName: "R438AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.161915681788051, R125: 0.371558801739542, R134A: 0.42929872424902, BUTANE: 0.0289854872298073, IPENTANE: 0.00824130499357989", } ], [ "R439A.mix", { menuName: "R439A", idName: "R439AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.684390813603997, R125: 0.278854127894844, ISOBUTAN: 0.0367550585011589", } ], [ "R440A.mix", { menuName: "R440A", idName: "R440AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPANE: 0.00901134733203068, R134A: 0.0103852633851142, R152A: 0.980603389282855", } ], [ "R441A.mix", { menuName: "R441A", idName: "R441AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - ETHANE: 0.049800395690461, PROPANE: 0.600310262208399, ISOBUTAN: 0.0498654644324665, BUTANE: 0.300023877668674", } ], [ "R442A.mix", { menuName: "R442A", idName: "R442AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.487220106766942, R125: 0.211188495005419, R134A: 0.240409765511042, R152A: 0.0371371957951017, R227EA: 0.0240444369214954", } ], [ "R443A.mix", { menuName: "R443A", idName: "R443AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPYLEN: 0.568232931233387, PROPANE: 0.394367661677695, ISOBUTAN: 0.0373994070889183", } ], [ "R444A.mix", { menuName: "R444A", idName: "R444AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.223042202171548, R152A: 0.0731981570161227, R1234ZE: 0.703759640812329", } ], [ "R444B.mix", { menuName: "R444B", idName: "R444BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.580409174767712, R152A: 0.11015659826248, R1234ZE: 0.309434226969808", } ], [ "R445A.mix", { menuName: "R445A", idName: "R445AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - CO2: 0.14056672736859, R134A: 0.0909466670967859, R1234ZE: 0.768486605534624", } ], [ "R446A.mix", { menuName: "R446A", idName: "R446AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.810347789312053, R1234ZE: 0.157652541387366, BUTANE: 0.0319996693005808", } ], [ "R447A.mix", { menuName: "R447A", idName: "R447AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.824059115538506, R125: 0.0183849541922025, R1234ZE: 0.157555930269292", } ], [ "R448A.mix", { menuName: "R448A", idName: "R448AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.431218201988559, R125: 0.186914131481992, R1234YF: 0.151319256485899, R134A: 0.177586673617217, R1234ZE: 0.0529617364263329", } ], [ "R449A.mix", { menuName: "R449A", idName: "R449AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.407364566995509, R125: 0.179481207732065, R1234YF: 0.193480840388364, R134A: 0.219673384884062", } ], [ "R449B.mix", { menuName: "R449B", idName: "R449BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.418353331871839, R125: 0.174861426767915, R1234YF: 0.175699749729428, R134A: 0.231085491630818", } ], [ "R450A.mix", { menuName: "R450A", idName: "R450AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R134A: 0.447322067369848, R1234ZE: 0.552677932630152", } ], [ "R451A.mix", { menuName: "R451A", idName: "R451AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R1234YF: 0.887346670041529, R134A: 0.112653329958471", } ], [ "R451B.mix", { menuName: "R451B", idName: "R451BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R1234YF: 0.876445928959364, R134A: 0.123554071040636", } ], [ "R452A.mix", { menuName: "R452A", idName: "R452AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.218864360337465, R125: 0.508837870465814, R1234YF: 0.272297769196721", } ], [ "R453A.mix", { menuName: "R453A", idName: "R453AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.341295928327855, R125: 0.147936968933237, R134A: 0.468112901696291, R227EA: 0.0261066945175942, BUTANE: 0.0091646080754323, IPENTANE: 0.00738289844959133", } ], [ "R454A.mix", { menuName: "R454A", idName: "R454AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.541359992223361, R1234YF: 0.458640007776639", } ], [ "R454B.mix", { menuName: "R454B", idName: "R454BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.829247912869081, R1234YF: 0.170752087130919", } ], [ "R500.mix", { menuName: "R500", idName: "R500Mixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R12: 0.606101741397223, R152A: 0.393898258602777", } ], [ "R501.mix", { menuName: "R501", idName: "R501Mixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.807509678166191, R12: 0.192490321833809", } ], [ "R502.mix", { menuName: "R502", idName: "R502Mixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.629994467193889, R115: 0.370005532806111", } ], [ "R503.mix", { menuName: "R503", idName: "R503Mixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R23: 0.49970034990839, R13: 0.50029965009161", } ], [ "R504.mix", { menuName: "R504", idName: "R504Mixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R32: 0.734239632563771, R115: 0.265760367436229", } ], [ "R507A.mix", { menuName: "R507A", idName: "R507AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R125: 0.411839711774438, R143A: 0.588160288225562", } ], [ "R508A.mix", { menuName: "R508A", idName: "R508AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R23: 0.557576966356198, R116: 0.442423033643802", } ], [ "R508B.mix", { menuName: "R508B", idName: "R508BMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R23: 0.626751006700703, R116: 0.373248993299297", } ], [ "R509A.mix", { menuName: "R509A", idName: "R509AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R22: 0.630790210153023, R218: 0.369209789846977", } ], [ "R510A.mix", { menuName: "R510A", idName: "R510AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - DME: 0.902458936722509, ISOBUTAN: 0.0975410632774913", } ], [ "R511A.mix", { menuName: "R511A", idName: "R511AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - PROPANE: 0.952038489443906, DME: 0.0479615105560936", } ], [ "R512A.mix", { menuName: "R512A", idName: "R512AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R134A: 0.0329487458964343, R152A: 0.967051254103566", } ], [ "R513A.mix", { menuName: "R513A", idName: "R513AMixture", order: "7", category: "Predefined Mixtures of Pure Fluids", basic: false, compressibleMixtureComponent: false, incompressible: false, incompressibleMixture: false, minConcentration: null, maxConcentration: null, longDescription: "Mole Fractions - R1234YF: 0.532425755929735, R134A: 0.467574244070265", } ], ]); export const FLUID_HA_PROPS_PARAMETERS = new Map([ [ "C", { idName: "C", units: "J/kg/K", input: false, output: true, description: "Mixture specific heat per unit dry air", } ], [ "H", { idName: "H", units: "J/kg", input: true, output: true, description: "Mixture enthalpy per mass dry air", } ], [ "P", { idName: "P", units: "Pa", input: true, output: false, description: "Pressure", } ], [ "R", { idName: "Rh", units: "", input: true, output: true, description: "Relative humidity in [0, 1]", } ], [ "S", { idName: "S", units: "J/kg/K", input: true, output: true, description: "Mixture entropy per mass dry air", } ], [ "T", { idName: "T", units: "K", input: true, output: true, description: "Dry-Bulb Temperature", } ], [ "Tdp", { idName: "Tdp", units: "K", input: true, output: true, description: "Dew-Point Temperature", } ], [ "B", { idName: "Twb", units: "K", input: true, output: true, description: "Wet-Bulb Temperature", } ], [ "Visc", { idName: "V", units: "Pa*s", input: false, output: true, description: "Mixture viscosity", } ], [ "Vda", { idName: "Vda", units: "m^3/kg", input: true, output: true, description: "Mixture volume per mass dry air", } ], [ "W", { idName: "W", units: "", input: true, output: true, description: "Humidity Ratio (kg water/kg dry air)", } ], [ "Cha", { idName: "Cha", units: "J/kg/K", input: false, output: true, description: "Mixture specific heat per unit humid air", } ], [ "CV", { idName: "Cv", units: "J/kg/K", input: false, output: true, description: "Mixture specific heat at constant volume per unit dry air", } ], [ "Cvha", { idName: "Cvha", units: "J/kg/K", input: false, output: true, description: "Mixture specific heat at constant volume per unit humid air", } ], [ "Hha", { idName: "Hha", units: "J/kg", input: true, output: true, description: "Mixture enthalpy per mass humid air", } ], [ "K", { idName: "K", units: "W/m/K", input: false, output: true, description: "Mixture thermal conductivity", } ], [ "P_w", { idName: "Pw", units: "Pa", input: true, output: true, description: "Partial pressure of water vapor", } ], [ "Sha", { idName: "Sha", units: "J/kg/K", input: true, output: true, description: "Mixture entropy per mass humid air", } ], [ "Vha", { idName: "Vha", units: "m^3/kg", input: true, output: true, description: "Mixture volume per mass humid air", } ], [ "psi_w", { idName: "Y", units: "", input: true, output: true, description: "Water mole fraction (mol water/mol humid air)", } ], [ "Z", { idName: "Z", units: "", input: true, output: false, description: "Compressibility factor (Z=pv/(RT))", } ], ]); export const FLUID_HA_PROPS_PARAMETERS_ORDER = [ ["C", "Quick Access"], ["H", "Quick Access"], ["P", "Quick Access"], ["R", "Quick Access"], ["S", "Quick Access"], ["T", "Quick Access"], ["Tdp", "Quick Access"], ["B", "Quick Access"], ["Visc", "Quick Access"], ["Vda", "Quick Access"], ["W", "Quick Access"], ["C", "All"], ["Cha", "All"], ["CV", "All"], ["Cvha", "All"], ["H", "All"], ["Hha", "All"], ["K", "All"], ["P", "All"], ["P_w", "All"], ["R", "All"], ["S", "All"], ["Sha", "All"], ["T", "All"], ["Tdp", "All"], ["B", "All"], ["Visc", "All"], ["Vda", "All"], ["Vha", "All"], ["W", "All"], ["psi_w", "All"], ["Z", "All"], ]; ================================================ FILE: src/global.css ================================================ body { position: fixed; inset: 0; overflow: hidden; color: #333; margin: 0; padding: 8px; box-sizing: border-box; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; } :focus { outline-color: Highlight; } @media print { html, body { position: static; height: fit-content; } } a { color: rgb(0,100,200); text-decoration: none; } a:hover { text-decoration: underline; } a:visited { color: rgb(0,80,160); } label { display: block; } input, button, select, textarea, div.editable { font-family: inherit; font-size: inherit; -webkit-padding: 0.4em 0; padding: 0.4em; box-sizing: border-box; border: 1px solid #ccc; border-radius: 2px; } input:disabled { color: #ccc; } button { color: #333; background-color: white; outline: none; } button:hover { background-color: #f4f4f4; } button:disabled { color: #999; } button:not(:disabled):active { background-color: #ddd; } button:focus { outline: 5px auto Highlight; } svg.error { fill: #da1e28 !important; } img { break-inside: avoid; } @media print { button { display: none; } } ================================================ FILE: src/global.d.ts ================================================ /// ================================================ FILE: src/jediWorker.ts ================================================ globalThis.importScripts('pyodide/pyodide.js'); let pyodide_ready = false; let py_funcs; let pyodide; let loadedPyodidePackages: Set = new Set(['jedi']); async function setup() { try { pyodide = await globalThis.loadPyodide({indexURL: 'pyodide/', packages: ['jedi']}); const response = await fetch("jedi_code_analysis.py"); const data = await response.text(); py_funcs = await pyodide.runPythonAsync(data); console.log('Jedi Python Ready'); pyodide_ready = true } catch(e) { console.error('Jedi Pyodide failed to load.'); console.log(e); } } const setupPromise = setup(); globalThis.onmessage = async function(e){ await setupPromise; if (!pyodide_ready) { console.log('Jedi Pyodide not available') return; } try { const neededPackages = (new Set(e.data.neededPyodidePackages as string[])).difference(loadedPyodidePackages) if (neededPackages.size > 0) { await pyodide.loadPackage([...neededPackages]); loadedPyodidePackages = loadedPyodidePackages.union(neededPackages); } const codeContextResult = JSON.parse(py_funcs.get_code_context(JSON.stringify(e.data.codeContextRequest))); globalThis.postMessage(codeContextResult); } catch (e) { console.warn(`Unhandled jedi code analysis exception: ${e}`) globalThis.postMessage({autocompleteSuggestions: [], hoverText: ''}) } } ================================================ FILE: src/jediWrapper.ts ================================================ export type CodeContextRequest = { code: string; line: number; col: number; }; export type AutocompleteSuggestion = { label: string; type: string; detail: string; prefixLength: number; }; export type CodeContextResult = { autocompleteSuggestions: AutocompleteSuggestion[]; hoverText: string; }; export class JediWrapper { resolvers: ((result: CodeContextResult) => void)[] = []; worker: Worker; constructor() { this.worker = new Worker("jediWorker.js"); this.worker.onmessage = (e) => { const resolver = this.resolvers.shift(); resolver(e.data as CodeContextResult); }; } getCodeContextResult(request: { codeContextRequest: CodeContextRequest; neededPyodidePackages: string[]; }): Promise { return new Promise((resolve, reject) => { this.resolvers.push(resolve); this.worker.postMessage(request); }); } } ================================================ FILE: src/keyboard/Keyboard.svelte.ts ================================================ import type {MathField} from '../cells/MathField.svelte'; import appState from '../stores.svelte'; import { inMatrix } from '../utility'; export type Keyboards = { type: "Keyboards", keyboards: Keyboard[] } export type Buttons = { type: "Buttons", buttons: (Button | Blank)[][] } type Keyboard = { tabText: string, content: Buttons | Keyboards }; type Commands = "insert" | "moveToNextChar" | "moveToPreviousChar" | "deleteBackward" | "toggleMode" | "typedText" | "customMatrix" | "showMenu" | "addRowBefore" | "addRowAfter" | "addColumnBefore" | "addColumnAfter" | "removeRow" | "removeColumn"; const matrixContextCommands: Set = new Set(["addRowBefore", "addRowAfter", "addColumnBefore", "addColumnAfter", "removeRow", "removeColumn"]) export class Button { static nextId = 0; type = "Button"; id: number; buttonText: string; content: string | undefined; command: Commands; size: string; fontSize: string; rawText: boolean; constructor({ buttonText, content, command = "insert", size = "1fr", fontSize = "", rawText = false }: { buttonText: string, content?: string, command?: Commands, size?: string, fontSize?: string, rawText?: boolean }) { if (content === undefined && (command === "insert" || command === "typedText") ) { content = buttonText; } this.id = Button.nextId++; this.buttonText = buttonText; this.content = content; this.command = command; this.size = size; this.fontSize = fontSize; this.rawText = rawText; } click(activeMathField: MathField): string | undefined { if (activeMathField && activeMathField.element) { if (appState.onMobile && navigator.vibrate) { navigator.vibrate(1); } const mathLiveField = activeMathField.element.getMathField(); if (this.command === "insert") { mathLiveField.executeCommand([this.command, this.content]); } else if (this.command === "typedText") { mathLiveField.executeCommand(['typedText', this.content, {focus: true, feedback: false, simulateKeystroke: true}]); } else if (this.command === "toggleMode") { if (mathLiveField.mode === 'text') { mathLiveField.executeCommand(['switchMode', 'math', '', '']); } else { mathLiveField.executeCommand(['switchMode', 'text', '', '']); } } else if (this.command === "customMatrix") { return("customMatrix"); } else if (this.command === "showMenu") { //@ts-ignore: 2554 mathLiveField.showMenu(); } else if (matrixContextCommands.has(this.command)) { if (inMatrix(mathLiveField)) { mathLiveField.executeCommand([this.command]); } } else { mathLiveField.executeCommand([this.command]); } } } } class Blank { type = "Blank"; size: string; id: number; constructor(size?: string) { this.id = Button.nextId++; if (size === undefined) { this.size = "1fr"; } else { this.size = size; } } } const unitsKeyboards: Keyboards = { type: "Keyboards", keyboards: [ { tabText: "Length", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack m\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack mm\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack cm\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack km\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack um\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack inch\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack feet\right\rbrack `, command: "insert" }), ], [ new Button({ buttonText: String.raw`\left\lbrack yard\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack mile\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack angstrom\right\rbrack `, command: "insert" }), new Blank(), new Blank(), new Blank(), new Blank(), ], ] } }, { tabText: "Force", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack N\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack kN\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack mN\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack lbf\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack kip\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack dyne\right\rbrack `, command: "insert" }), ], [ new Button({ buttonText: String.raw`\left\lbrack gf\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack kgf\right\rbrack `, command: "insert" }), new Blank(), new Blank(), new Blank(), new Blank(), ] ] } }, { tabText: "Mass", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack g\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack kg\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack tonne\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack lbm\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack ton\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack oz\right\rbrack `, command: "insert" }), ], ] } }, { tabText: "Time", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack sec\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack min\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack hours\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack days\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack weeks\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack years\right\rbrack `, command: "insert" }), ], ] } }, { tabText: "Area", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack m^{2}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack cm^{2}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack mm^{2}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack km^{2}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack hectare\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack in^{2}\right\rbrack `, command: "insert" }), ], [ new Button({ buttonText: String.raw`\left\lbrack feet^{2}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack yard^{2}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack mile^{2}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack acre\right\rbrack `, command: "insert" }), new Blank(), new Blank(), new Blank(), ], ] } }, { tabText: "Press", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack Pa\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack kPa\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack MPa\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack psi\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack kpsi\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack atm\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack bar\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack torr\right\rbrack `, command: "insert" }), ], [ new Button({ buttonText: String.raw`\left\lbrack mmHg\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack mmH2O\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack cmH2O\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack inHg\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack inH2O\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack ftH2O\right\rbrack `, command: "insert" }), ], ] } }, { tabText: "Vol", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack m^{3}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack cm^{3}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack mm^{3}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack km^{3}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack liter\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack ml\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack in^{3}\right\rbrack `, command: "insert" }), ], [ new Button({ buttonText: String.raw`\left\lbrack feet^{3}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack yard^{3}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack mile^{3}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack gallon\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack floz\right\rbrack `, command: "insert" }), new Blank(), new Blank() ], ] } }, { tabText: "Energy", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack J\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack mJ\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack kJ\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack MJ\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack Wh\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack kWh\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack eV\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack BTU\right\rbrack `, command: "insert" }), ], [ new Button({ buttonText: String.raw`\left\lbrack hp\cdot hr\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack N\cdot m\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack in\cdot lbf\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack foot\cdot lbf\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack erg\right\rbrack `, command: "insert" }), new Blank(), new Blank(), new Blank(), ], ] } }, { tabText: "Power", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack W\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack mW\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack kW\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack MW\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack hp\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{BTU}{min}\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack \frac{BTU}{hr}\right\rbrack `, command: "insert"}), ], [ new Button({ buttonText: String.raw`\left\lbrack \frac{erg}{sec}\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack \frac{dyne\cdot cm}{sec}\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack TR\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack BHP\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack MBH\right\rbrack`, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack MMBH\right\rbrack`, command: "insert"}), new Blank(), ], ] } }, { tabText: "Temp", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack K\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack degC\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack degF\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack degR\right\rbrack `, command: "insert" }), ], ] } }, { tabText: "Vel", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack \frac{m}{sec}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{km}{hour}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{mm}{min}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{m}{min}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{feet}{sec}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{miles}{hour}\right\rbrack `, command: "insert" }), ], [ new Button({ buttonText: String.raw`\left\lbrack \frac{inch}{min}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{feet}{min}\right\rbrack `, command: "insert" }), new Blank(), new Blank(), new Blank(), new Blank(), ], ] } }, { tabText: "Accel", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack \frac{m}{sec^{2}}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{cm}{sec^{2}}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{feet}{sec^{2}}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{in}{sec^{2}}\right\rbrack `, command: "insert" }), ], ] } }, { tabText: "Density", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack \frac{kg}{m^{3}}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{Mg}{m^{3}}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{g}{cm^{3}}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{lbm}{in^{3}}\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{lbm}{feet^{3}}\right\rbrack `, command: "insert" }), ], ] } }, { tabText: "Angle", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack deg\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack rad\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack grad\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack cycle\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack arcsec\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack arcmin\right\rbrack `, command: "insert" }), ], ] } }, { tabText: "Freq", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack Hz\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack kHz\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack MHz\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack GHz\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack \frac{cycles}{sec}\right\rbrack `, command: "insert" }), ], ] } }, { tabText: "Elec", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack A\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack mA\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack V\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack mV\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack kV\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack F\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack nF\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack pF\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack C\right\rbrack `, command: "insert"}), ], [ new Button({ buttonText: String.raw`\left\lbrack ohm\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack kohm\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack Mohm\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack H\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack nH\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack pH\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack Wb\right\rbrack `, command: "insert"}), new Button({ buttonText: String.raw`\left\lbrack T\right\rbrack `, command: "insert"}), ], ] } }, { tabText: "Visc", content: { type: "Buttons", buttons: [[ new Button({ buttonText: String.raw`\left\lbrack P\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack cP\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack Pa\cdot s\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack reyn\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack ureyn\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack St\right\rbrack `, command: "insert" }), ], [ new Button({ buttonText: String.raw`\left\lbrack cSt\right\rbrack `, command: "insert" }), new Button({ buttonText: String.raw`\left\lbrack\frac{m^2}{s}\right\rbrack `, command: "insert" }), new Blank(), new Blank(), new Blank(), new Blank(), ] ] } }, ] }; export const keyboards: Keyboards = { type: "Keyboards", keyboards: [ { tabText: String.raw`\(123\)`, content: { type: "Buttons", buttons: [[ new Button({ buttonText: '\\leftarrow', command: "moveToPreviousChar" }), new Button({ buttonText: '\\rightarrow', command: "moveToNextChar" }), new Blank('.25fr'), new Button({ buttonText: '7', content: '7', command: "typedText"}), new Button({ buttonText: '8', content: '8', command: "typedText" }), new Button({ buttonText: '9', content: '9', command: "typedText" }), new Button({ buttonText: '/', content: '\\frac{#@}{#?}' }), new Blank('0.25fr'), new Button({ buttonText: 'x', content: 'x', command: "typedText" }), new Button({ buttonText: 'y', content: 'y', command: "typedText" }), new Button({ buttonText: '⌫', command: 'deleteBackward' }), ], [ new Button({ buttonText: '(', content: '(', command: "typedText" }), new Button({ buttonText: ')', content: ')', command: "typedText" }), new Blank('0.25fr'), new Button({ buttonText: '4', content: '4', command: "typedText" }), new Button({ buttonText: '5', content: '5', command: "typedText" }), new Button({ buttonText: '6', content: '6', command: "typedText" }), new Button({ buttonText: '\\ast', content: '\\cdot' }), new Blank('0.25fr'), new Button({ buttonText: '\\pi', content: '\\pi' }), new Button({ buttonText: 'e', content: 'e', command: "typedText" }), new Button({ buttonText: 'i', content: 'i', command: "typedText" }), ], [ new Button({ buttonText: '\\le', content: '\\le' }), new Button({ buttonText: '\\ge', content: '\\ge' }), new Blank('0.25fr'), new Button({ buttonText: '1', content: '1', command: "typedText" }), new Button({ buttonText: '2', content: '2', command: "typedText" }), new Button({ buttonText: '3', content: '3', command: "typedText" }), new Button({ buttonText: '-', content: '-' }), new Blank('0.25fr'), new Button({ buttonText: '\\sqrt x', content: '\\sqrt{#0}' }), new Button({ buttonText: 'x^y', content: '#@^{#?}' }), new Button({ buttonText: '\\ln', content: '\\ln\\left(#0\\right)', command: "insert" }), ], [ new Button({ buttonText: '<', content: '<', command: "typedText" }), new Button({ buttonText: '>', content: '>', command: "typedText" }), new Blank('0.25fr'), new Button({ buttonText: '0', content: '0', command: "typedText" }), new Button({ buttonText: '.', content: '.', command: "typedText" }), new Button({ buttonText: '=', content: '=', command: "typedText" }), new Button({ buttonText: '+', content: '+', command: "typedText" }), new Blank('0.25fr'), new Button({ buttonText: '\\cdot 10^{\\mathrm{x}}', content: '#@\\cdot10^{#?}' }), new Button({ buttonText: 'x_a', content: '#@_{#?}' }), new Button({ buttonText: '\\approx', content: '\\approx' }) ]] } }, { tabText: String.raw`\(\operatorname{f}\left(x\right)\)`, content: { type: "Buttons", buttons: [[ new Button({ buttonText: '\\sin', content: '\\sin\\left(#0\\right)', command: "insert" }), new Button({ buttonText: '\\arcsin', content: '\\arcsin\\left(#0\\right)', command: "insert", size: '1.4fr' }), new Button({ buttonText: '\\sinh', content: '\\sinh\\left(#0\\right)', command: "insert", size: '1.2fr' }), new Button({ buttonText: '\\sec', content: '\\sec\\left(#0\\right)', command: "insert" }), new Blank('0.1fr'), new Button({ buttonText: '\\mathrm{real}', content: '\\mathrm{real}\\left(#0\\right)', command: "insert", size: '1.2fr' }), new Button({ buttonText: '\\left|x\\right|', content: '\\left|#0\\right|', command: "insert", size: '1.4fr' }), new Blank('0.1fr'), new Button({ buttonText: '\\mathrm{min}', content: '\\mathrm{min}\\left(#0\\right)', command: "insert", size: "1.3fr"}), new Button({ buttonText: '\\mathrm{max}', content: '\\mathrm{max}\\left(#0\\right)', command: "insert", size: "1.6fr"}), ], [ new Button({ buttonText: '\\cos', content: '\\cos\\left(#0\\right)', command: "insert" }), new Button({ buttonText: '\\arccos', content: '\\arccos\\left(#0\\right)', command: "insert", size: '1.4fr' }), new Button({ buttonText: '\\cosh', content: '\\cosh\\left(#0\\right)', command: "insert", size: '1.2fr' }), new Button({ buttonText: '\\csc', content: '\\csc\\left(#0\\right)', command: "insert" }), new Blank('0.1fr'), new Button({ buttonText: '\\mathrm{imag}', content: '\\mathrm{imag}\\left(#0\\right)', command: "insert", size: '1.2fr' }), new Button({ buttonText: '\\mathrm{round}', content: '\\mathrm{round}\\left(#0\\right)', command: "insert", size: '1.4fr'}), new Blank('0.1fr'), new Button({ buttonText: '\\mathrm{range}', content: '\\mathrm{range}\\left(#0\\right)', command: "insert", size: "1.3fr"}), new Button({ buttonText: '\\mathrm{count}', content: '\\mathrm{count}\\left(#0\\right)', command: "insert", size: "1.6fr"}), ], [ new Button({ buttonText: '\\tan', content: '\\tan\\left(#0\\right)', command: "insert" }), new Button({ buttonText: '\\arctan', content: '\\arctan\\left(#0\\right)', command: "insert", size: '1.4fr' }), new Button({ buttonText: '\\tanh', content: '\\tanh\\left(#0\\right)', command: "insert", size: '1.2fr' }), new Button({ buttonText: '\\cot', content: '\\cot\\left(#0\\right)', command: "insert" }), new Blank('0.1fr'), new Button({ buttonText: '\\mathrm{conj}', content: '\\mathrm{conj}\\left(#0\\right)', command: "insert", size: '1.2fr' }), new Button({ buttonText: '\\mathrm{ceil}', content: '\\mathrm{ceil}\\left(#0\\right)', command: "insert", size: '1.4fr' }), new Blank('0.1fr'), new Button({ buttonText: '\\mathrm{sum}', content: '\\mathrm{sum}\\left(#0\\right)', command: "insert", size: "1.3fr"}), new Button({ buttonText: '\\mathrm{average}', content: '\\mathrm{average}\\left(#0\\right)', command: "insert", size: "1.6fr"}), ], [ new Button({ buttonText: '\\ln', content: '\\ln\\left(#0\\right)', command: "insert" }), new Button({ buttonText: '\\log_{10}', content: '\\log\\left(#0\\right)', command: "insert", size: '1.4fr' }), new Button({ buttonText: '\\log_{b}', content: '\\log_{#?}\\left(#0\\right)', command: "insert", size: '1.2fr' }), new Button({ buttonText: 'n!', content: '#@!' }), new Blank('0.1fr'), new Button({ buttonText: '\\mathrm{angle}', content: '\\mathrm{angle}\\left(#0\\right)', command: "insert", size: '1.2fr' }), new Button({ buttonText: '\\mathrm{floor}', content: '\\mathrm{floor}\\left(#0\\right)', command: "insert", size: '1.4fr' }), new Blank('0.1fr'), new Button({ buttonText: '\\mathrm{stdev}', content: '\\mathrm{stdev}\\left(#0\\right)', command: "insert", size: "1.3fr"}), new Button({ buttonText: '\\mathrm{stdevp}', content: '\\mathrm{stdevp}\\left(#0\\right)', command: "insert", size: "1.6fr"}), ]] } }, { tabText: String.raw`\(\hat{a}\mathrm{\smallint\Sigma}\)`, content: { type: "Buttons", buttons: [[ new Button({ buttonText: "\\int", content: '\\int \\left(#0\\right)\\mathrm{d}\\left(#?\\right)', command: "insert", fontSize: '10pt' }), new Button({ buttonText: '\\int_a^b', content: '\\int _{#?}^{#?}\\left(#0\\right)\\mathrm{d}\\left(#?\\right)', command: "insert", fontSize: '10pt'}), new Blank('0.1fr'), new Button({ buttonText: '\\sum', content: '\\sum_{#?=#?}^{#?}\\left(#0\\right)', command: "insert", fontSize: '10pt' }), new Blank('0.1fr'), new Button({ buttonText: '\\vec{a}', content: '\\vec{#@}', command: "insert"}), new Button({ buttonText: '\\bar{a}', content: '\\bar{#@}', command: "insert"}), new Button({ buttonText: '\\hat{a}', content: '\\hat{#@}', command: "insert"}), new Button({ buttonText: '\\dot{a}', content: '\\dot{#@}', command: "insert"}), new Button({ buttonText: '\\ddot{a}', content: '\\ddot{#@}', command: "insert"}), ], [ new Button({ buttonText: '\\frac{\\mathrm{d}}{\\mathrm{d}x}', content: '\\frac{\\mathrm{d}}{\\mathrm{d}\\left(#?\\right)}\\left(#0\\right)', command: "insert", fontSize: '12pt' }), new Button({ buttonText: '\\frac{\\mathrm{d}^{2}}{\\mathrm{d}x^{2}}', content: '\\frac{\\mathrm{d}^{2}}{\\mathrm{d}\\left(#?\\right)^{2}}\\left(#0\\right)', command: "insert", fontSize: '12pt'}), new Blank('0.1fr'), new Button({ buttonText: '\\prod', content: '\\prod_{#?=#?}^{#?}\\left(#0\\right)', command: "insert", fontSize: '10pt' }), new Blank('0.1fr'), new Button({ buttonText: 'a^{\\prime}', content: "#@^{\\prime}", command: "insert"}), new Button({ buttonText: 'a^{\\prime\\prime}', content: "#@^{\\prime\\prime}", command: "insert"}), new Button({ buttonText: 'a^{\\prime\\prime\\prime}', content: "#@^{\\prime\\prime\\prime}", command: "insert"}), new Blank(), new Blank(), ], [ new Blank(), new Blank(), new Blank('0.1fr'), new Button({ buttonText: '\\infty' }), new Blank('0.1fr'), new Blank(), new Blank(), new Blank(), new Blank(), new Blank(), ], [ new Blank(), new Blank(), new Blank('0.1fr'), new Blank(), new Blank('0.1fr'), new Blank(), new Blank(), new Blank(), new Blank(), new Blank(), ]] } }, { tabText: String.raw`\(\begin{bmatrix}A\end{bmatrix}\)`, content: { type: "Buttons", buttons: [[ new Button({ buttonText: '\\mathrm{numrows}', content: '\\mathrm{numrows}\\left(#0\\right)', command: "insert", fontSize: '12px', size: "1.4fr"}), new Button({ buttonText: '\\mathrm{numcols}', content: '\\mathrm{numcols}\\left(#0\\right)', command: "insert", fontSize: '12px', size: "1.4fr"}), new Blank('.25fr'), new Button({ buttonText: 'M \\times N', command: "customMatrix", fontSize: '11px'}), new Button({ buttonText: '1 \\times 2', content: String.raw`\begin{bmatrix} \placeholder{} & \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Button({ buttonText: '1 \\times 3', content: String.raw`\begin{bmatrix} \placeholder{} & \placeholder{} & \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Button({ buttonText: '1 \\times 4', content: String.raw`\begin{bmatrix} \placeholder{} & \placeholder{} & \placeholder{} & \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Blank('0.25fr'), new Button({ buttonText: '\\ast', content: '\\cdot' }), new Button({ buttonText: 'A_{m,n}', content: '_{#?,#?}' }), new Button({ buttonText: '⌫', command: 'deleteBackward' }), ], [ new Button({ buttonText: '+\\text{Row}\\uparrow', command: "addRowBefore", fontSize: '12px', size: "1.4fr"}), new Button({ buttonText: '+\\text{Row}\\downarrow', command: "addRowAfter", fontSize: '12px', size: "1.4fr"}), new Blank('0.25fr'), new Button({ buttonText: '2 \\times 1', content: String.raw`\begin{bmatrix} \placeholder{} \\ \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Button({ buttonText: '2 \\times 2', content: String.raw`\begin{bmatrix} \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Button({ buttonText: '2 \\times 3', content: String.raw`\begin{bmatrix} \placeholder{} & \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} & \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Button({ buttonText: '2 \\times 4', content: String.raw`\begin{bmatrix} \placeholder{} & \placeholder{} & \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} & \placeholder{} & \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Blank('0.25fr'), new Button({ buttonText: '\\times', content: '\\times' }), new Button({ buttonText: '\\mathrm{dot}', content: '\\mathrm{dot}\\left(#0\\right)', command: "insert"}), new Button({ buttonText: 'A^{-1}', content: '^{-1}' }), ], [ new Button({ buttonText: '+\\text{Col}\\leftarrow', command: "addColumnBefore", fontSize: '12px', size: "1.4fr"}), new Button({ buttonText: '+\\text{Col}\\rightarrow', command: "addColumnAfter", fontSize: '12px', size: "1.4fr"}), new Blank('0.25fr'), new Button({ buttonText: '3 \\times 1', content: String.raw`\begin{bmatrix} \placeholder{} \\ \placeholder{} \\ \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Button({ buttonText: '3 \\times 2', content: String.raw`\begin{bmatrix} \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Button({ buttonText: '3 \\times 3', content: String.raw`\begin{bmatrix} \placeholder{} & \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} & \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Button({ buttonText: '3 \\times 4', content: String.raw`\begin{bmatrix} \placeholder{} & \placeholder{} & \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} & \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} & \placeholder{} & \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Blank('0.25fr'), new Button({ buttonText: '-', content: '-' }), new Button({ buttonText: '\\left\\Vert v \\right\\Vert', content: '\\left\\Vert#0\\right\\Vert', command: "insert" }), new Button({ buttonText: 'A^{\\mathrm{T}}', content: '^{\\mathrm{T}}'}), ], [ new Button({ buttonText: '\\text{Del Row}', command: "removeRow", fontSize: '12px', size: "1.4fr"}), new Button({ buttonText: '\\text{Del Col}', command: "removeColumn", fontSize: '12px', size: "1.4fr"}), new Blank('0.25fr'), new Button({ buttonText: '4 \\times 1', content: String.raw`\begin{bmatrix} \placeholder{} \\ \placeholder{} \\ \placeholder{} \\ \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Button({ buttonText: '4 \\times 2', content: String.raw`\begin{bmatrix} \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Button({ buttonText: '4 \\times 3', content: String.raw`\begin{bmatrix} \placeholder{} & \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} & \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Button({ buttonText: '4 \\times 4', content: String.raw`\begin{bmatrix} \placeholder{} & \placeholder{} & \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} & \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} & \placeholder{} & \placeholder{} \\ \placeholder{} & \placeholder{} & \placeholder{} & \placeholder{} \end{bmatrix}`, fontSize: '12px'}), new Blank('0.25fr'), new Button({ buttonText: '+', content: '+', command: "typedText" }), new Button({ buttonText: ':', content: ':', command: "typedText" }), new Button({ buttonText: '\\mathrm{det}', content: '\\mathrm{det}\\left(#0\\right)', command: "insert"}), ]] } }, { tabText: String.raw`\(ABC\)`, content: { type: "Buttons", buttons: [[ new Button({ buttonText: 'Q', command: "typedText" }), new Button({ buttonText: 'W', command: "typedText" }), new Button({ buttonText: 'E', command: "typedText" }), new Button({ buttonText: 'R', command: "typedText" }), new Button({ buttonText: 'T', command: "typedText" }), new Button({ buttonText: 'Y', command: "typedText" }), new Button({ buttonText: 'U', command: "typedText" }), new Button({ buttonText: 'I', command: "typedText" }), new Button({ buttonText: 'O', command: "typedText" }), new Button({ buttonText: 'P', command: "typedText" }), ], [ new Button({ buttonText: 'A', command: "typedText" }), new Button({ buttonText: 'S', command: "typedText" }), new Button({ buttonText: 'D', command: "typedText" }), new Button({ buttonText: 'F', command: "typedText" }), new Button({ buttonText: 'G', command: "typedText" }), new Button({ buttonText: 'H', command: "typedText" }), new Button({ buttonText: 'J', command: "typedText" }), new Button({ buttonText: 'K', command: "typedText" }), new Button({ buttonText: 'L', command: "typedText" }), new Button({ buttonText: '⌫', command: 'deleteBackward' }), ], [ new Button({ buttonText: '\\leftarrow', command: 'moveToPreviousChar' }), new Button({ buttonText: 'Z', command: "typedText" }), new Button({ buttonText: 'X', command: "typedText" }), new Button({ buttonText: 'C', command: "typedText" }), new Button({ buttonText: 'V', command: "typedText" }), new Button({ buttonText: 'B', command: "typedText" }), new Button({ buttonText: 'N', command: "typedText" }), new Button({ buttonText: 'M', command: "typedText" }), new Button({ buttonText: ',', command: "typedText" }), new Button({ buttonText: '\\rightarrow', command: 'moveToNextChar' }), ], [ new Button({ buttonText: '(', content: '(', command: "typedText" }), new Button({ buttonText: ')', content: ')', command: "typedText" }), new Button({ buttonText: '[', content: '[', command: "typedText" }), new Button({ buttonText: ']', content: ']', command: "typedText" }), new Button({ buttonText: 'Space', content: " ", command: 'typedText', size: '2fr', rawText: true}), new Button({ buttonText: 'Comment', command: 'toggleMode', size: '2fr', rawText: true}), new Button({ buttonText: '=', content: '=', command: "typedText" }), new Button({ buttonText: 'x_a', content: '#@_{#?}' }), ]] } }, { tabText: String.raw`\(abc\)`, content: { type: "Buttons", buttons: [[ new Button({ buttonText: 'q', command: "typedText" }), new Button({ buttonText: 'w', command: "typedText" }), new Button({ buttonText: 'e', command: "typedText" }), new Button({ buttonText: 'r', command: "typedText" }), new Button({ buttonText: 't', command: "typedText" }), new Button({ buttonText: 'y', command: "typedText" }), new Button({ buttonText: 'u', command: "typedText" }), new Button({ buttonText: 'i', command: "typedText" }), new Button({ buttonText: 'o', command: "typedText" }), new Button({ buttonText: 'p', command: "typedText" }), ], [ new Button({ buttonText: 'a', command: "typedText" }), new Button({ buttonText: 's', command: "typedText" }), new Button({ buttonText: 'd', command: "typedText" }), new Button({ buttonText: 'f', command: "typedText" }), new Button({ buttonText: 'g', command: "typedText" }), new Button({ buttonText: 'h', command: "typedText" }), new Button({ buttonText: 'j', command: "typedText" }), new Button({ buttonText: 'k', command: "typedText" }), new Button({ buttonText: 'l', command: "typedText" }), new Button({ buttonText: '⌫', command: 'deleteBackward' }), ], [ new Button({ buttonText: '\\leftarrow', command: 'moveToPreviousChar' }), new Button({ buttonText: 'z', command: "typedText" }), new Button({ buttonText: 'x', command: "typedText" }), new Button({ buttonText: 'c', command: "typedText" }), new Button({ buttonText: 'v', command: "typedText" }), new Button({ buttonText: 'b', command: "typedText" }), new Button({ buttonText: 'n', command: "typedText" }), new Button({ buttonText: 'm', command: "typedText" }), new Button({ buttonText: ',', command: "typedText" }), new Button({ buttonText: '\\rightarrow', command: 'moveToNextChar' }), ], [ new Button({ buttonText: '(', command: "typedText" }), new Button({ buttonText: ')', command: "typedText" }), new Button({ buttonText: '[', command: "typedText" }), new Button({ buttonText: ']', command: "typedText" }), new Button({ buttonText: 'Space', content: " ", command: 'typedText', size: '2fr', rawText: true}), new Button({ buttonText: 'Comment', command: 'toggleMode', size: '2fr', rawText: true}), new Button({ buttonText: '=', content: '=', command: "typedText" }), new Button({ buttonText: 'x_a', content: '#@_{#?}' }), ]] } }, { tabText: String.raw`\(\alpha\beta\gamma\)`, content: { type: "Buttons", buttons: [[ new Button({ buttonText: '\\alpha' }), new Button({ buttonText: '\\beta' }), new Button({ buttonText: '\\gamma' }), new Button({ buttonText: '\\delta' }), new Button({ buttonText: '\\epsilon' }), new Button({ buttonText: '\\zeta' }), new Button({ buttonText: '\\eta' }), new Button({ buttonText: '\\theta' }), new Button({ buttonText: '\\iota' }), new Button({ buttonText: '\\kappa' }), ], [ new Button({ buttonText: '\\lambda' }), new Button({ buttonText: '\\mu' }), new Button({ buttonText: '\\nu' }), new Button({ buttonText: '\\xi' }), new Button({ buttonText: '\\pi' }), new Button({ buttonText: '\\rho' }), new Button({ buttonText: '\\sigma' }), new Button({ buttonText: '\\tau' }), new Button({ buttonText: '\\phi' }), new Button({ buttonText: '⌫', command: 'deleteBackward' }), ], [ new Button({ buttonText: '\\leftarrow', command: 'moveToPreviousChar' }), new Button({ buttonText: '\\chi' }), new Button({ buttonText: '\\psi' }), new Button({ buttonText: '\\omega' }), new Button({ buttonText: '\\Gamma' }), new Button({ buttonText: '\\Delta' }), new Button({ buttonText: '\\Theta' }), new Button({ buttonText: '\\Lambda' }), new Button({ buttonText: '\\Xi' }), new Button({ buttonText: '\\rightarrow', command: 'moveToNextChar' }), ], [ new Button({ buttonText: '(', command: "typedText" }), new Button({ buttonText: ')', command: "typedText" }), new Button({ buttonText: '\\Pi' }), new Button({ buttonText: '\\Sigma' }), new Button({ buttonText: '\\Upsilon' }), new Button({ buttonText: '\\Phi' }), new Button({ buttonText: '\\Psi' }), new Button({ buttonText: '\\Omega' }), new Button({ buttonText: '=', content: '=', command: "typedText" }), new Button({ buttonText: 'x_a', content: '#@_{#?}' }), ]] } }, { tabText: "Units", content: unitsKeyboards } ] }; ================================================ FILE: src/main.js ================================================ import { mount } from 'svelte'; import './global.css'; import 'quill/dist/quill.snow.css'; import './carbon-theme.scss'; import App from './App.svelte'; const app = mount(App, { target: document.body, props: {} }); export default app; ================================================ FILE: src/parser/LatexIdFragments.g4 ================================================ lexer grammar LatexIdFragments; // https://github.com/antlr/grammars-v4/blob/master/python/python3_13/PythonLexer.g4 fragment ID_CONTINUE : ID_START | '\u{0030}' .. '\u{0039}' | '\u{00B7}' | '\u{0300}' .. '\u{036F}' | '\u{0387}' | '\u{0483}' .. '\u{0487}' | '\u{0591}' .. '\u{05BD}' | '\u{05BF}' | '\u{05C1}' .. '\u{05C2}' | '\u{05C4}' .. '\u{05C5}' | '\u{05C7}' | '\u{0610}' .. '\u{061A}' | '\u{064B}' .. '\u{0669}' | '\u{0670}' | '\u{06D6}' .. '\u{06DC}' | '\u{06DF}' .. '\u{06E4}' | '\u{06E7}' .. '\u{06E8}' | '\u{06EA}' .. '\u{06ED}' | '\u{06F0}' .. '\u{06F9}' | '\u{0711}' | '\u{0730}' .. '\u{074A}' | '\u{07A6}' .. '\u{07B0}' | '\u{07C0}' .. '\u{07C9}' | '\u{07EB}' .. '\u{07F3}' | '\u{07FD}' | '\u{0816}' .. '\u{0819}' | '\u{081B}' .. '\u{0823}' | '\u{0825}' .. '\u{0827}' | '\u{0829}' .. '\u{082D}' | '\u{0859}' .. '\u{085B}' | '\u{0898}' .. '\u{089F}' | '\u{08CA}' .. '\u{08E1}' | '\u{08E3}' .. '\u{0903}' | '\u{093A}' .. '\u{093C}' | '\u{093E}' .. '\u{094F}' | '\u{0951}' .. '\u{0957}' | '\u{0962}' .. '\u{0963}' | '\u{0966}' .. '\u{096F}' | '\u{0981}' .. '\u{0983}' | '\u{09BC}' | '\u{09BE}' .. '\u{09C4}' | '\u{09C7}' .. '\u{09C8}' | '\u{09CB}' .. '\u{09CD}' | '\u{09D7}' | '\u{09E2}' .. '\u{09E3}' | '\u{09E6}' .. '\u{09EF}' | '\u{09FE}' | '\u{0A01}' .. '\u{0A03}' | '\u{0A3C}' | '\u{0A3E}' .. '\u{0A42}' | '\u{0A47}' .. '\u{0A48}' | '\u{0A4B}' .. '\u{0A4D}' | '\u{0A51}' | '\u{0A66}' .. '\u{0A71}' | '\u{0A75}' | '\u{0A81}' .. '\u{0A83}' | '\u{0ABC}' | '\u{0ABE}' .. '\u{0AC5}' | '\u{0AC7}' .. '\u{0AC9}' | '\u{0ACB}' .. '\u{0ACD}' | '\u{0AE2}' .. '\u{0AE3}' | '\u{0AE6}' .. '\u{0AEF}' | '\u{0AFA}' .. '\u{0AFF}' | '\u{0B01}' .. '\u{0B03}' | '\u{0B3C}' | '\u{0B3E}' .. '\u{0B44}' | '\u{0B47}' .. '\u{0B48}' | '\u{0B4B}' .. '\u{0B4D}' | '\u{0B55}' .. '\u{0B57}' | '\u{0B62}' .. '\u{0B63}' | '\u{0B66}' .. '\u{0B6F}' | '\u{0B82}' | '\u{0BBE}' .. '\u{0BC2}' | '\u{0BC6}' .. '\u{0BC8}' | '\u{0BCA}' .. '\u{0BCD}' | '\u{0BD7}' | '\u{0BE6}' .. '\u{0BEF}' | '\u{0C00}' .. '\u{0C04}' | '\u{0C3C}' | '\u{0C3E}' .. '\u{0C44}' | '\u{0C46}' .. '\u{0C48}' | '\u{0C4A}' .. '\u{0C4D}' | '\u{0C55}' .. '\u{0C56}' | '\u{0C62}' .. '\u{0C63}' | '\u{0C66}' .. '\u{0C6F}' | '\u{0C81}' .. '\u{0C83}' | '\u{0CBC}' | '\u{0CBE}' .. '\u{0CC4}' | '\u{0CC6}' .. '\u{0CC8}' | '\u{0CCA}' .. '\u{0CCD}' | '\u{0CD5}' .. '\u{0CD6}' | '\u{0CE2}' .. '\u{0CE3}' | '\u{0CE6}' .. '\u{0CEF}' | '\u{0CF3}' | '\u{0D00}' .. '\u{0D03}' | '\u{0D3B}' .. '\u{0D3C}' | '\u{0D3E}' .. '\u{0D44}' | '\u{0D46}' .. '\u{0D48}' | '\u{0D4A}' .. '\u{0D4D}' | '\u{0D57}' | '\u{0D62}' .. '\u{0D63}' | '\u{0D66}' .. '\u{0D6F}' | '\u{0D81}' .. '\u{0D83}' | '\u{0DCA}' | '\u{0DCF}' .. '\u{0DD4}' | '\u{0DD6}' | '\u{0DD8}' .. '\u{0DDF}' | '\u{0DE6}' .. '\u{0DEF}' | '\u{0DF2}' .. '\u{0DF3}' | '\u{0E31}' | '\u{0E33}' .. '\u{0E3A}' | '\u{0E47}' .. '\u{0E4E}' | '\u{0E50}' .. '\u{0E59}' | '\u{0EB1}' | '\u{0EB3}' .. '\u{0EBC}' | '\u{0EC8}' .. '\u{0ECE}' | '\u{0ED0}' .. '\u{0ED9}' | '\u{0F18}' .. '\u{0F19}' | '\u{0F20}' .. '\u{0F29}' | '\u{0F35}' | '\u{0F37}' | '\u{0F39}' | '\u{0F3E}' .. '\u{0F3F}' | '\u{0F71}' .. '\u{0F84}' | '\u{0F86}' .. '\u{0F87}' | '\u{0F8D}' .. '\u{0F97}' | '\u{0F99}' .. '\u{0FBC}' | '\u{0FC6}' | '\u{102B}' .. '\u{103E}' | '\u{1040}' .. '\u{1049}' | '\u{1056}' .. '\u{1059}' | '\u{105E}' .. '\u{1060}' | '\u{1062}' .. '\u{1064}' | '\u{1067}' .. '\u{106D}' | '\u{1071}' .. '\u{1074}' | '\u{1082}' .. '\u{108D}' | '\u{108F}' .. '\u{109D}' | '\u{135D}' .. '\u{135F}' | '\u{1369}' .. '\u{1371}' | '\u{1712}' .. '\u{1715}' | '\u{1732}' .. '\u{1734}' | '\u{1752}' .. '\u{1753}' | '\u{1772}' .. '\u{1773}' | '\u{17B4}' .. '\u{17D3}' | '\u{17DD}' | '\u{17E0}' .. '\u{17E9}' | '\u{180B}' .. '\u{180D}' | '\u{180F}' .. '\u{1819}' | '\u{18A9}' | '\u{1920}' .. '\u{192B}' | '\u{1930}' .. '\u{193B}' | '\u{1946}' .. '\u{194F}' | '\u{19D0}' .. '\u{19DA}' | '\u{1A17}' .. '\u{1A1B}' | '\u{1A55}' .. '\u{1A5E}' | '\u{1A60}' .. '\u{1A7C}' | '\u{1A7F}' .. '\u{1A89}' | '\u{1A90}' .. '\u{1A99}' | '\u{1AB0}' .. '\u{1ABD}' | '\u{1ABF}' .. '\u{1ACE}' | '\u{1B00}' .. '\u{1B04}' | '\u{1B34}' .. '\u{1B44}' | '\u{1B50}' .. '\u{1B59}' | '\u{1B6B}' .. '\u{1B73}' | '\u{1B80}' .. '\u{1B82}' | '\u{1BA1}' .. '\u{1BAD}' | '\u{1BB0}' .. '\u{1BB9}' | '\u{1BE6}' .. '\u{1BF3}' | '\u{1C24}' .. '\u{1C37}' | '\u{1C40}' .. '\u{1C49}' | '\u{1C50}' .. '\u{1C59}' | '\u{1CD0}' .. '\u{1CD2}' | '\u{1CD4}' .. '\u{1CE8}' | '\u{1CED}' | '\u{1CF4}' | '\u{1CF7}' .. '\u{1CF9}' | '\u{1DC0}' .. '\u{1DFF}' | '\u{200C}' .. '\u{200D}' | '\u{203F}' .. '\u{2040}' | '\u{2054}' | '\u{20D0}' .. '\u{20DC}' | '\u{20E1}' | '\u{20E5}' .. '\u{20F0}' | '\u{2CEF}' .. '\u{2CF1}' | '\u{2D7F}' | '\u{2DE0}' .. '\u{2DFF}' | '\u{302A}' .. '\u{302F}' | '\u{3099}' .. '\u{309A}' | '\u{30FB}' | '\u{A620}' .. '\u{A629}' | '\u{A66F}' | '\u{A674}' .. '\u{A67D}' | '\u{A69E}' .. '\u{A69F}' | '\u{A6F0}' .. '\u{A6F1}' | '\u{A802}' | '\u{A806}' | '\u{A80B}' | '\u{A823}' .. '\u{A827}' | '\u{A82C}' | '\u{A880}' .. '\u{A881}' | '\u{A8B4}' .. '\u{A8C5}' | '\u{A8D0}' .. '\u{A8D9}' | '\u{A8E0}' .. '\u{A8F1}' | '\u{A8FF}' .. '\u{A909}' | '\u{A926}' .. '\u{A92D}' | '\u{A947}' .. '\u{A953}' | '\u{A980}' .. '\u{A983}' | '\u{A9B3}' .. '\u{A9C0}' | '\u{A9D0}' .. '\u{A9D9}' | '\u{A9E5}' | '\u{A9F0}' .. '\u{A9F9}' | '\u{AA29}' .. '\u{AA36}' | '\u{AA43}' | '\u{AA4C}' .. '\u{AA4D}' | '\u{AA50}' .. '\u{AA59}' | '\u{AA7B}' .. '\u{AA7D}' | '\u{AAB0}' | '\u{AAB2}' .. '\u{AAB4}' | '\u{AAB7}' .. '\u{AAB8}' | '\u{AABE}' .. '\u{AABF}' | '\u{AAC1}' | '\u{AAEB}' .. '\u{AAEF}' | '\u{AAF5}' .. '\u{AAF6}' | '\u{ABE3}' .. '\u{ABEA}' | '\u{ABEC}' .. '\u{ABED}' | '\u{ABF0}' .. '\u{ABF9}' | '\u{FB1E}' | '\u{FE00}' .. '\u{FE0F}' | '\u{FE20}' .. '\u{FE2F}' | '\u{FE33}' .. '\u{FE34}' | '\u{FE4D}' .. '\u{FE4F}' | '\u{FF10}' .. '\u{FF19}' | '\u{FF3F}' | '\u{FF65}' | '\u{FF9E}' .. '\u{FF9F}' | '\u{101FD}' | '\u{102E0}' | '\u{10376}' .. '\u{1037A}' | '\u{104A0}' .. '\u{104A9}' | '\u{10A01}' .. '\u{10A03}' | '\u{10A05}' .. '\u{10A06}' | '\u{10A0C}' .. '\u{10A0F}' | '\u{10A38}' .. '\u{10A3A}' | '\u{10A3F}' | '\u{10AE5}' .. '\u{10AE6}' | '\u{10D24}' .. '\u{10D27}' | '\u{10D30}' .. '\u{10D39}' | '\u{10EAB}' .. '\u{10EAC}' | '\u{10EFD}' .. '\u{10EFF}' | '\u{10F46}' .. '\u{10F50}' | '\u{10F82}' .. '\u{10F85}' | '\u{11000}' .. '\u{11002}' | '\u{11038}' .. '\u{11046}' | '\u{11066}' .. '\u{11070}' | '\u{11073}' .. '\u{11074}' | '\u{1107F}' .. '\u{11082}' | '\u{110B0}' .. '\u{110BA}' | '\u{110C2}' | '\u{110F0}' .. '\u{110F9}' | '\u{11100}' .. '\u{11102}' | '\u{11127}' .. '\u{11134}' | '\u{11136}' .. '\u{1113F}' | '\u{11145}' .. '\u{11146}' | '\u{11173}' | '\u{11180}' .. '\u{11182}' | '\u{111B3}' .. '\u{111C0}' | '\u{111C9}' .. '\u{111CC}' | '\u{111CE}' .. '\u{111D9}' | '\u{1122C}' .. '\u{11237}' | '\u{1123E}' | '\u{11241}' | '\u{112DF}' .. '\u{112EA}' | '\u{112F0}' .. '\u{112F9}' | '\u{11300}' .. '\u{11303}' | '\u{1133B}' .. '\u{1133C}' | '\u{1133E}' .. '\u{11344}' | '\u{11347}' .. '\u{11348}' | '\u{1134B}' .. '\u{1134D}' | '\u{11357}' | '\u{11362}' .. '\u{11363}' | '\u{11366}' .. '\u{1136C}' | '\u{11370}' .. '\u{11374}' | '\u{11435}' .. '\u{11446}' | '\u{11450}' .. '\u{11459}' | '\u{1145E}' | '\u{114B0}' .. '\u{114C3}' | '\u{114D0}' .. '\u{114D9}' | '\u{115AF}' .. '\u{115B5}' | '\u{115B8}' .. '\u{115C0}' | '\u{115DC}' .. '\u{115DD}' | '\u{11630}' .. '\u{11640}' | '\u{11650}' .. '\u{11659}' | '\u{116AB}' .. '\u{116B7}' | '\u{116C0}' .. '\u{116C9}' | '\u{1171D}' .. '\u{1172B}' | '\u{11730}' .. '\u{11739}' | '\u{1182C}' .. '\u{1183A}' | '\u{118E0}' .. '\u{118E9}' | '\u{11930}' .. '\u{11935}' | '\u{11937}' .. '\u{11938}' | '\u{1193B}' .. '\u{1193E}' | '\u{11940}' | '\u{11942}' .. '\u{11943}' | '\u{11950}' .. '\u{11959}' | '\u{119D1}' .. '\u{119D7}' | '\u{119DA}' .. '\u{119E0}' | '\u{119E4}' | '\u{11A01}' .. '\u{11A0A}' | '\u{11A33}' .. '\u{11A39}' | '\u{11A3B}' .. '\u{11A3E}' | '\u{11A47}' | '\u{11A51}' .. '\u{11A5B}' | '\u{11A8A}' .. '\u{11A99}' | '\u{11C2F}' .. '\u{11C36}' | '\u{11C38}' .. '\u{11C3F}' | '\u{11C50}' .. '\u{11C59}' | '\u{11C92}' .. '\u{11CA7}' | '\u{11CA9}' .. '\u{11CB6}' | '\u{11D31}' .. '\u{11D36}' | '\u{11D3A}' | '\u{11D3C}' .. '\u{11D3D}' | '\u{11D3F}' .. '\u{11D45}' | '\u{11D47}' | '\u{11D50}' .. '\u{11D59}' | '\u{11D8A}' .. '\u{11D8E}' | '\u{11D90}' .. '\u{11D91}' | '\u{11D93}' .. '\u{11D97}' | '\u{11DA0}' .. '\u{11DA9}' | '\u{11EF3}' .. '\u{11EF6}' | '\u{11F00}' .. '\u{11F01}' | '\u{11F03}' | '\u{11F34}' .. '\u{11F3A}' | '\u{11F3E}' .. '\u{11F42}' | '\u{11F50}' .. '\u{11F59}' | '\u{13440}' | '\u{13447}' .. '\u{13455}' | '\u{16A60}' .. '\u{16A69}' | '\u{16AC0}' .. '\u{16AC9}' | '\u{16AF0}' .. '\u{16AF4}' | '\u{16B30}' .. '\u{16B36}' | '\u{16B50}' .. '\u{16B59}' | '\u{16F4F}' | '\u{16F51}' .. '\u{16F87}' | '\u{16F8F}' .. '\u{16F92}' | '\u{16FE4}' | '\u{16FF0}' .. '\u{16FF1}' | '\u{1BC9D}' .. '\u{1BC9E}' | '\u{1CF00}' .. '\u{1CF2D}' | '\u{1CF30}' .. '\u{1CF46}' | '\u{1D165}' .. '\u{1D169}' | '\u{1D16D}' .. '\u{1D172}' | '\u{1D17B}' .. '\u{1D182}' | '\u{1D185}' .. '\u{1D18B}' | '\u{1D1AA}' .. '\u{1D1AD}' | '\u{1D242}' .. '\u{1D244}' | '\u{1D7CE}' .. '\u{1D7FF}' | '\u{1DA00}' .. '\u{1DA36}' | '\u{1DA3B}' .. '\u{1DA6C}' | '\u{1DA75}' | '\u{1DA84}' | '\u{1DA9B}' .. '\u{1DA9F}' | '\u{1DAA1}' .. '\u{1DAAF}' | '\u{1E000}' .. '\u{1E006}' | '\u{1E008}' .. '\u{1E018}' | '\u{1E01B}' .. '\u{1E021}' | '\u{1E023}' .. '\u{1E024}' | '\u{1E026}' .. '\u{1E02A}' | '\u{1E08F}' | '\u{1E130}' .. '\u{1E136}' | '\u{1E140}' .. '\u{1E149}' | '\u{1E2AE}' | '\u{1E2EC}' .. '\u{1E2F9}' | '\u{1E4EC}' .. '\u{1E4F9}' | '\u{1E8D0}' .. '\u{1E8D6}' | '\u{1E944}' .. '\u{1E94A}' | '\u{1E950}' .. '\u{1E959}' | '\u{1FBF0}' .. '\u{1FBF9}' | '\u{E0100}' .. '\u{E01EF}' ; fragment ID_START : '\u{0041}' .. '\u{005A}' | '\u{0061}' .. '\u{007A}' | '\u{00AA}' | '\u{00B5}' | '\u{00BA}' | '\u{00C0}' .. '\u{00D6}' | '\u{00D8}' .. '\u{00F6}' | '\u{00F8}' .. '\u{02C1}' | '\u{02C6}' .. '\u{02D1}' | '\u{02E0}' .. '\u{02E4}' | '\u{02EC}' | '\u{02EE}' | '\u{0370}' .. '\u{0374}' | '\u{0376}' .. '\u{0377}' | '\u{037B}' .. '\u{037D}' | '\u{037F}' | '\u{0386}' | '\u{0388}' .. '\u{038A}' | '\u{038C}' | '\u{038E}' .. '\u{03A1}' | '\u{03A3}' .. '\u{03F5}' | '\u{03F7}' .. '\u{0481}' | '\u{048A}' .. '\u{052F}' | '\u{0531}' .. '\u{0556}' | '\u{0559}' | '\u{0560}' .. '\u{0588}' | '\u{05D0}' .. '\u{05EA}' | '\u{05EF}' .. '\u{05F2}' | '\u{0620}' .. '\u{064A}' | '\u{066E}' .. '\u{066F}' | '\u{0671}' .. '\u{06D3}' | '\u{06D5}' | '\u{06E5}' .. '\u{06E6}' | '\u{06EE}' .. '\u{06EF}' | '\u{06FA}' .. '\u{06FC}' | '\u{06FF}' | '\u{0710}' | '\u{0712}' .. '\u{072F}' | '\u{074D}' .. '\u{07A5}' | '\u{07B1}' | '\u{07CA}' .. '\u{07EA}' | '\u{07F4}' .. '\u{07F5}' | '\u{07FA}' | '\u{0800}' .. '\u{0815}' | '\u{081A}' | '\u{0824}' | '\u{0828}' | '\u{0840}' .. '\u{0858}' | '\u{0860}' .. '\u{086A}' | '\u{0870}' .. '\u{0887}' | '\u{0889}' .. '\u{088E}' | '\u{08A0}' .. '\u{08C9}' | '\u{0904}' .. '\u{0939}' | '\u{093D}' | '\u{0950}' | '\u{0958}' .. '\u{0961}' | '\u{0971}' .. '\u{0980}' | '\u{0985}' .. '\u{098C}' | '\u{098F}' .. '\u{0990}' | '\u{0993}' .. '\u{09A8}' | '\u{09AA}' .. '\u{09B0}' | '\u{09B2}' | '\u{09B6}' .. '\u{09B9}' | '\u{09BD}' | '\u{09CE}' | '\u{09DC}' .. '\u{09DD}' | '\u{09DF}' .. '\u{09E1}' | '\u{09F0}' .. '\u{09F1}' | '\u{09FC}' | '\u{0A05}' .. '\u{0A0A}' | '\u{0A0F}' .. '\u{0A10}' | '\u{0A13}' .. '\u{0A28}' | '\u{0A2A}' .. '\u{0A30}' | '\u{0A32}' .. '\u{0A33}' | '\u{0A35}' .. '\u{0A36}' | '\u{0A38}' .. '\u{0A39}' | '\u{0A59}' .. '\u{0A5C}' | '\u{0A5E}' | '\u{0A72}' .. '\u{0A74}' | '\u{0A85}' .. '\u{0A8D}' | '\u{0A8F}' .. '\u{0A91}' | '\u{0A93}' .. '\u{0AA8}' | '\u{0AAA}' .. '\u{0AB0}' | '\u{0AB2}' .. '\u{0AB3}' | '\u{0AB5}' .. '\u{0AB9}' | '\u{0ABD}' | '\u{0AD0}' | '\u{0AE0}' .. '\u{0AE1}' | '\u{0AF9}' | '\u{0B05}' .. '\u{0B0C}' | '\u{0B0F}' .. '\u{0B10}' | '\u{0B13}' .. '\u{0B28}' | '\u{0B2A}' .. '\u{0B30}' | '\u{0B32}' .. '\u{0B33}' | '\u{0B35}' .. '\u{0B39}' | '\u{0B3D}' | '\u{0B5C}' .. '\u{0B5D}' | '\u{0B5F}' .. '\u{0B61}' | '\u{0B71}' | '\u{0B83}' | '\u{0B85}' .. '\u{0B8A}' | '\u{0B8E}' .. '\u{0B90}' | '\u{0B92}' .. '\u{0B95}' | '\u{0B99}' .. '\u{0B9A}' | '\u{0B9C}' | '\u{0B9E}' .. '\u{0B9F}' | '\u{0BA3}' .. '\u{0BA4}' | '\u{0BA8}' .. '\u{0BAA}' | '\u{0BAE}' .. '\u{0BB9}' | '\u{0BD0}' | '\u{0C05}' .. '\u{0C0C}' | '\u{0C0E}' .. '\u{0C10}' | '\u{0C12}' .. '\u{0C28}' | '\u{0C2A}' .. '\u{0C39}' | '\u{0C3D}' | '\u{0C58}' .. '\u{0C5A}' | '\u{0C5D}' | '\u{0C60}' .. '\u{0C61}' | '\u{0C80}' | '\u{0C85}' .. '\u{0C8C}' | '\u{0C8E}' .. '\u{0C90}' | '\u{0C92}' .. '\u{0CA8}' | '\u{0CAA}' .. '\u{0CB3}' | '\u{0CB5}' .. '\u{0CB9}' | '\u{0CBD}' | '\u{0CDD}' .. '\u{0CDE}' | '\u{0CE0}' .. '\u{0CE1}' | '\u{0CF1}' .. '\u{0CF2}' | '\u{0D04}' .. '\u{0D0C}' | '\u{0D0E}' .. '\u{0D10}' | '\u{0D12}' .. '\u{0D3A}' | '\u{0D3D}' | '\u{0D4E}' | '\u{0D54}' .. '\u{0D56}' | '\u{0D5F}' .. '\u{0D61}' | '\u{0D7A}' .. '\u{0D7F}' | '\u{0D85}' .. '\u{0D96}' | '\u{0D9A}' .. '\u{0DB1}' | '\u{0DB3}' .. '\u{0DBB}' | '\u{0DBD}' | '\u{0DC0}' .. '\u{0DC6}' | '\u{0E01}' .. '\u{0E30}' | '\u{0E32}' | '\u{0E40}' .. '\u{0E46}' | '\u{0E81}' .. '\u{0E82}' | '\u{0E84}' | '\u{0E86}' .. '\u{0E8A}' | '\u{0E8C}' .. '\u{0EA3}' | '\u{0EA5}' | '\u{0EA7}' .. '\u{0EB0}' | '\u{0EB2}' | '\u{0EBD}' | '\u{0EC0}' .. '\u{0EC4}' | '\u{0EC6}' | '\u{0EDC}' .. '\u{0EDF}' | '\u{0F00}' | '\u{0F40}' .. '\u{0F47}' | '\u{0F49}' .. '\u{0F6C}' | '\u{0F88}' .. '\u{0F8C}' | '\u{1000}' .. '\u{102A}' | '\u{103F}' | '\u{1050}' .. '\u{1055}' | '\u{105A}' .. '\u{105D}' | '\u{1061}' | '\u{1065}' .. '\u{1066}' | '\u{106E}' .. '\u{1070}' | '\u{1075}' .. '\u{1081}' | '\u{108E}' | '\u{10A0}' .. '\u{10C5}' | '\u{10C7}' | '\u{10CD}' | '\u{10D0}' .. '\u{10FA}' | '\u{10FC}' .. '\u{1248}' | '\u{124A}' .. '\u{124D}' | '\u{1250}' .. '\u{1256}' | '\u{1258}' | '\u{125A}' .. '\u{125D}' | '\u{1260}' .. '\u{1288}' | '\u{128A}' .. '\u{128D}' | '\u{1290}' .. '\u{12B0}' | '\u{12B2}' .. '\u{12B5}' | '\u{12B8}' .. '\u{12BE}' | '\u{12C0}' | '\u{12C2}' .. '\u{12C5}' | '\u{12C8}' .. '\u{12D6}' | '\u{12D8}' .. '\u{1310}' | '\u{1312}' .. '\u{1315}' | '\u{1318}' .. '\u{135A}' | '\u{1380}' .. '\u{138F}' | '\u{13A0}' .. '\u{13F5}' | '\u{13F8}' .. '\u{13FD}' | '\u{1401}' .. '\u{166C}' | '\u{166F}' .. '\u{167F}' | '\u{1681}' .. '\u{169A}' | '\u{16A0}' .. '\u{16EA}' | '\u{16EE}' .. '\u{16F8}' | '\u{1700}' .. '\u{1711}' | '\u{171F}' .. '\u{1731}' | '\u{1740}' .. '\u{1751}' | '\u{1760}' .. '\u{176C}' | '\u{176E}' .. '\u{1770}' | '\u{1780}' .. '\u{17B3}' | '\u{17D7}' | '\u{17DC}' | '\u{1820}' .. '\u{1878}' | '\u{1880}' .. '\u{18A8}' | '\u{18AA}' | '\u{18B0}' .. '\u{18F5}' | '\u{1900}' .. '\u{191E}' | '\u{1950}' .. '\u{196D}' | '\u{1970}' .. '\u{1974}' | '\u{1980}' .. '\u{19AB}' | '\u{19B0}' .. '\u{19C9}' | '\u{1A00}' .. '\u{1A16}' | '\u{1A20}' .. '\u{1A54}' | '\u{1AA7}' | '\u{1B05}' .. '\u{1B33}' | '\u{1B45}' .. '\u{1B4C}' | '\u{1B83}' .. '\u{1BA0}' | '\u{1BAE}' .. '\u{1BAF}' | '\u{1BBA}' .. '\u{1BE5}' | '\u{1C00}' .. '\u{1C23}' | '\u{1C4D}' .. '\u{1C4F}' | '\u{1C5A}' .. '\u{1C7D}' | '\u{1C80}' .. '\u{1C88}' | '\u{1C90}' .. '\u{1CBA}' | '\u{1CBD}' .. '\u{1CBF}' | '\u{1CE9}' .. '\u{1CEC}' | '\u{1CEE}' .. '\u{1CF3}' | '\u{1CF5}' .. '\u{1CF6}' | '\u{1CFA}' | '\u{1D00}' .. '\u{1DBF}' | '\u{1E00}' .. '\u{1F15}' | '\u{1F18}' .. '\u{1F1D}' | '\u{1F20}' .. '\u{1F45}' | '\u{1F48}' .. '\u{1F4D}' | '\u{1F50}' .. '\u{1F57}' | '\u{1F59}' | '\u{1F5B}' | '\u{1F5D}' | '\u{1F5F}' .. '\u{1F7D}' | '\u{1F80}' .. '\u{1FB4}' | '\u{1FB6}' .. '\u{1FBC}' | '\u{1FBE}' | '\u{1FC2}' .. '\u{1FC4}' | '\u{1FC6}' .. '\u{1FCC}' | '\u{1FD0}' .. '\u{1FD3}' | '\u{1FD6}' .. '\u{1FDB}' | '\u{1FE0}' .. '\u{1FEC}' | '\u{1FF2}' .. '\u{1FF4}' | '\u{1FF6}' .. '\u{1FFC}' | '\u{2071}' | '\u{207F}' | '\u{2090}' .. '\u{209C}' | '\u{2102}' | '\u{2107}' | '\u{210A}' .. '\u{2113}' | '\u{2115}' | '\u{2118}' .. '\u{211D}' | '\u{2124}' | '\u{2126}' | '\u{2128}' | '\u{212A}' .. '\u{2139}' | '\u{213C}' .. '\u{213F}' | '\u{2145}' .. '\u{2149}' | '\u{214E}' | '\u{2160}' .. '\u{2188}' | '\u{2C00}' .. '\u{2CE4}' | '\u{2CEB}' .. '\u{2CEE}' | '\u{2CF2}' .. '\u{2CF3}' | '\u{2D00}' .. '\u{2D25}' | '\u{2D27}' | '\u{2D2D}' | '\u{2D30}' .. '\u{2D67}' | '\u{2D6F}' | '\u{2D80}' .. '\u{2D96}' | '\u{2DA0}' .. '\u{2DA6}' | '\u{2DA8}' .. '\u{2DAE}' | '\u{2DB0}' .. '\u{2DB6}' | '\u{2DB8}' .. '\u{2DBE}' | '\u{2DC0}' .. '\u{2DC6}' | '\u{2DC8}' .. '\u{2DCE}' | '\u{2DD0}' .. '\u{2DD6}' | '\u{2DD8}' .. '\u{2DDE}' | '\u{3005}' .. '\u{3007}' | '\u{3021}' .. '\u{3029}' | '\u{3031}' .. '\u{3035}' | '\u{3038}' .. '\u{303C}' | '\u{3041}' .. '\u{3096}' | '\u{309D}' .. '\u{309F}' | '\u{30A1}' .. '\u{30FA}' | '\u{30FC}' .. '\u{30FF}' | '\u{3105}' .. '\u{312F}' | '\u{3131}' .. '\u{318E}' | '\u{31A0}' .. '\u{31BF}' | '\u{31F0}' .. '\u{31FF}' | '\u{3400}' .. '\u{4DBF}' | '\u{4E00}' .. '\u{A48C}' | '\u{A4D0}' .. '\u{A4FD}' | '\u{A500}' .. '\u{A60C}' | '\u{A610}' .. '\u{A61F}' | '\u{A62A}' .. '\u{A62B}' | '\u{A640}' .. '\u{A66E}' | '\u{A67F}' .. '\u{A69D}' | '\u{A6A0}' .. '\u{A6EF}' | '\u{A717}' .. '\u{A71F}' | '\u{A722}' .. '\u{A788}' | '\u{A78B}' .. '\u{A7CA}' | '\u{A7D0}' .. '\u{A7D1}' | '\u{A7D3}' | '\u{A7D5}' .. '\u{A7D9}' | '\u{A7F2}' .. '\u{A801}' | '\u{A803}' .. '\u{A805}' | '\u{A807}' .. '\u{A80A}' | '\u{A80C}' .. '\u{A822}' | '\u{A840}' .. '\u{A873}' | '\u{A882}' .. '\u{A8B3}' | '\u{A8F2}' .. '\u{A8F7}' | '\u{A8FB}' | '\u{A8FD}' .. '\u{A8FE}' | '\u{A90A}' .. '\u{A925}' | '\u{A930}' .. '\u{A946}' | '\u{A960}' .. '\u{A97C}' | '\u{A984}' .. '\u{A9B2}' | '\u{A9CF}' | '\u{A9E0}' .. '\u{A9E4}' | '\u{A9E6}' .. '\u{A9EF}' | '\u{A9FA}' .. '\u{A9FE}' | '\u{AA00}' .. '\u{AA28}' | '\u{AA40}' .. '\u{AA42}' | '\u{AA44}' .. '\u{AA4B}' | '\u{AA60}' .. '\u{AA76}' | '\u{AA7A}' | '\u{AA7E}' .. '\u{AAAF}' | '\u{AAB1}' | '\u{AAB5}' .. '\u{AAB6}' | '\u{AAB9}' .. '\u{AABD}' | '\u{AAC0}' | '\u{AAC2}' | '\u{AADB}' .. '\u{AADD}' | '\u{AAE0}' .. '\u{AAEA}' | '\u{AAF2}' .. '\u{AAF4}' | '\u{AB01}' .. '\u{AB06}' | '\u{AB09}' .. '\u{AB0E}' | '\u{AB11}' .. '\u{AB16}' | '\u{AB20}' .. '\u{AB26}' | '\u{AB28}' .. '\u{AB2E}' | '\u{AB30}' .. '\u{AB5A}' | '\u{AB5C}' .. '\u{AB69}' | '\u{AB70}' .. '\u{ABE2}' | '\u{AC00}' .. '\u{D7A3}' | '\u{D7B0}' .. '\u{D7C6}' | '\u{D7CB}' .. '\u{D7FB}' | '\u{F900}' .. '\u{FA6D}' | '\u{FA70}' .. '\u{FAD9}' | '\u{FB00}' .. '\u{FB06}' | '\u{FB13}' .. '\u{FB17}' | '\u{FB1D}' | '\u{FB1F}' .. '\u{FB28}' | '\u{FB2A}' .. '\u{FB36}' | '\u{FB38}' .. '\u{FB3C}' | '\u{FB3E}' | '\u{FB40}' .. '\u{FB41}' | '\u{FB43}' .. '\u{FB44}' | '\u{FB46}' .. '\u{FBB1}' | '\u{FBD3}' .. '\u{FC5D}' | '\u{FC64}' .. '\u{FD3D}' | '\u{FD50}' .. '\u{FD8F}' | '\u{FD92}' .. '\u{FDC7}' | '\u{FDF0}' .. '\u{FDF9}' | '\u{FE71}' | '\u{FE73}' | '\u{FE77}' | '\u{FE79}' | '\u{FE7B}' | '\u{FE7D}' | '\u{FE7F}' .. '\u{FEFC}' | '\u{FF21}' .. '\u{FF3A}' | '\u{FF41}' .. '\u{FF5A}' | '\u{FF66}' .. '\u{FF9D}' | '\u{FFA0}' .. '\u{FFBE}' | '\u{FFC2}' .. '\u{FFC7}' | '\u{FFCA}' .. '\u{FFCF}' | '\u{FFD2}' .. '\u{FFD7}' | '\u{FFDA}' .. '\u{FFDC}' | '\u{10000}' .. '\u{1000B}' | '\u{1000D}' .. '\u{10026}' | '\u{10028}' .. '\u{1003A}' | '\u{1003C}' .. '\u{1003D}' | '\u{1003F}' .. '\u{1004D}' | '\u{10050}' .. '\u{1005D}' | '\u{10080}' .. '\u{100FA}' | '\u{10140}' .. '\u{10174}' | '\u{10280}' .. '\u{1029C}' | '\u{102A0}' .. '\u{102D0}' | '\u{10300}' .. '\u{1031F}' | '\u{1032D}' .. '\u{1034A}' | '\u{10350}' .. '\u{10375}' | '\u{10380}' .. '\u{1039D}' | '\u{103A0}' .. '\u{103C3}' | '\u{103C8}' .. '\u{103CF}' | '\u{103D1}' .. '\u{103D5}' | '\u{10400}' .. '\u{1049D}' | '\u{104B0}' .. '\u{104D3}' | '\u{104D8}' .. '\u{104FB}' | '\u{10500}' .. '\u{10527}' | '\u{10530}' .. '\u{10563}' | '\u{10570}' .. '\u{1057A}' | '\u{1057C}' .. '\u{1058A}' | '\u{1058C}' .. '\u{10592}' | '\u{10594}' .. '\u{10595}' | '\u{10597}' .. '\u{105A1}' | '\u{105A3}' .. '\u{105B1}' | '\u{105B3}' .. '\u{105B9}' | '\u{105BB}' .. '\u{105BC}' | '\u{10600}' .. '\u{10736}' | '\u{10740}' .. '\u{10755}' | '\u{10760}' .. '\u{10767}' | '\u{10780}' .. '\u{10785}' | '\u{10787}' .. '\u{107B0}' | '\u{107B2}' .. '\u{107BA}' | '\u{10800}' .. '\u{10805}' | '\u{10808}' | '\u{1080A}' .. '\u{10835}' | '\u{10837}' .. '\u{10838}' | '\u{1083C}' | '\u{1083F}' .. '\u{10855}' | '\u{10860}' .. '\u{10876}' | '\u{10880}' .. '\u{1089E}' | '\u{108E0}' .. '\u{108F2}' | '\u{108F4}' .. '\u{108F5}' | '\u{10900}' .. '\u{10915}' | '\u{10920}' .. '\u{10939}' | '\u{10980}' .. '\u{109B7}' | '\u{109BE}' .. '\u{109BF}' | '\u{10A00}' | '\u{10A10}' .. '\u{10A13}' | '\u{10A15}' .. '\u{10A17}' | '\u{10A19}' .. '\u{10A35}' | '\u{10A60}' .. '\u{10A7C}' | '\u{10A80}' .. '\u{10A9C}' | '\u{10AC0}' .. '\u{10AC7}' | '\u{10AC9}' .. '\u{10AE4}' | '\u{10B00}' .. '\u{10B35}' | '\u{10B40}' .. '\u{10B55}' | '\u{10B60}' .. '\u{10B72}' | '\u{10B80}' .. '\u{10B91}' | '\u{10C00}' .. '\u{10C48}' | '\u{10C80}' .. '\u{10CB2}' | '\u{10CC0}' .. '\u{10CF2}' | '\u{10D00}' .. '\u{10D23}' | '\u{10E80}' .. '\u{10EA9}' | '\u{10EB0}' .. '\u{10EB1}' | '\u{10F00}' .. '\u{10F1C}' | '\u{10F27}' | '\u{10F30}' .. '\u{10F45}' | '\u{10F70}' .. '\u{10F81}' | '\u{10FB0}' .. '\u{10FC4}' | '\u{10FE0}' .. '\u{10FF6}' | '\u{11003}' .. '\u{11037}' | '\u{11071}' .. '\u{11072}' | '\u{11075}' | '\u{11083}' .. '\u{110AF}' | '\u{110D0}' .. '\u{110E8}' | '\u{11103}' .. '\u{11126}' | '\u{11144}' | '\u{11147}' | '\u{11150}' .. '\u{11172}' | '\u{11176}' | '\u{11183}' .. '\u{111B2}' | '\u{111C1}' .. '\u{111C4}' | '\u{111DA}' | '\u{111DC}' | '\u{11200}' .. '\u{11211}' | '\u{11213}' .. '\u{1122B}' | '\u{1123F}' .. '\u{11240}' | '\u{11280}' .. '\u{11286}' | '\u{11288}' | '\u{1128A}' .. '\u{1128D}' | '\u{1128F}' .. '\u{1129D}' | '\u{1129F}' .. '\u{112A8}' | '\u{112B0}' .. '\u{112DE}' | '\u{11305}' .. '\u{1130C}' | '\u{1130F}' .. '\u{11310}' | '\u{11313}' .. '\u{11328}' | '\u{1132A}' .. '\u{11330}' | '\u{11332}' .. '\u{11333}' | '\u{11335}' .. '\u{11339}' | '\u{1133D}' | '\u{11350}' | '\u{1135D}' .. '\u{11361}' | '\u{11400}' .. '\u{11434}' | '\u{11447}' .. '\u{1144A}' | '\u{1145F}' .. '\u{11461}' | '\u{11480}' .. '\u{114AF}' | '\u{114C4}' .. '\u{114C5}' | '\u{114C7}' | '\u{11580}' .. '\u{115AE}' | '\u{115D8}' .. '\u{115DB}' | '\u{11600}' .. '\u{1162F}' | '\u{11644}' | '\u{11680}' .. '\u{116AA}' | '\u{116B8}' | '\u{11700}' .. '\u{1171A}' | '\u{11740}' .. '\u{11746}' | '\u{11800}' .. '\u{1182B}' | '\u{118A0}' .. '\u{118DF}' | '\u{118FF}' .. '\u{11906}' | '\u{11909}' | '\u{1190C}' .. '\u{11913}' | '\u{11915}' .. '\u{11916}' | '\u{11918}' .. '\u{1192F}' | '\u{1193F}' | '\u{11941}' | '\u{119A0}' .. '\u{119A7}' | '\u{119AA}' .. '\u{119D0}' | '\u{119E1}' | '\u{119E3}' | '\u{11A00}' | '\u{11A0B}' .. '\u{11A32}' | '\u{11A3A}' | '\u{11A50}' | '\u{11A5C}' .. '\u{11A89}' | '\u{11A9D}' | '\u{11AB0}' .. '\u{11AF8}' | '\u{11C00}' .. '\u{11C08}' | '\u{11C0A}' .. '\u{11C2E}' | '\u{11C40}' | '\u{11C72}' .. '\u{11C8F}' | '\u{11D00}' .. '\u{11D06}' | '\u{11D08}' .. '\u{11D09}' | '\u{11D0B}' .. '\u{11D30}' | '\u{11D46}' | '\u{11D60}' .. '\u{11D65}' | '\u{11D67}' .. '\u{11D68}' | '\u{11D6A}' .. '\u{11D89}' | '\u{11D98}' | '\u{11EE0}' .. '\u{11EF2}' | '\u{11F02}' | '\u{11F04}' .. '\u{11F10}' | '\u{11F12}' .. '\u{11F33}' | '\u{11FB0}' | '\u{12000}' .. '\u{12399}' | '\u{12400}' .. '\u{1246E}' | '\u{12480}' .. '\u{12543}' | '\u{12F90}' .. '\u{12FF0}' | '\u{13000}' .. '\u{1342F}' | '\u{13441}' .. '\u{13446}' | '\u{14400}' .. '\u{14646}' | '\u{16800}' .. '\u{16A38}' | '\u{16A40}' .. '\u{16A5E}' | '\u{16A70}' .. '\u{16ABE}' | '\u{16AD0}' .. '\u{16AED}' | '\u{16B00}' .. '\u{16B2F}' | '\u{16B40}' .. '\u{16B43}' | '\u{16B63}' .. '\u{16B77}' | '\u{16B7D}' .. '\u{16B8F}' | '\u{16E40}' .. '\u{16E7F}' | '\u{16F00}' .. '\u{16F4A}' | '\u{16F50}' | '\u{16F93}' .. '\u{16F9F}' | '\u{16FE0}' .. '\u{16FE1}' | '\u{16FE3}' | '\u{17000}' .. '\u{187F7}' | '\u{18800}' .. '\u{18CD5}' | '\u{18D00}' .. '\u{18D08}' | '\u{1AFF0}' .. '\u{1AFF3}' | '\u{1AFF5}' .. '\u{1AFFB}' | '\u{1AFFD}' .. '\u{1AFFE}' | '\u{1B000}' .. '\u{1B122}' | '\u{1B132}' | '\u{1B150}' .. '\u{1B152}' | '\u{1B155}' | '\u{1B164}' .. '\u{1B167}' | '\u{1B170}' .. '\u{1B2FB}' | '\u{1BC00}' .. '\u{1BC6A}' | '\u{1BC70}' .. '\u{1BC7C}' | '\u{1BC80}' .. '\u{1BC88}' | '\u{1BC90}' .. '\u{1BC99}' | '\u{1D400}' .. '\u{1D454}' | '\u{1D456}' .. '\u{1D49C}' | '\u{1D49E}' .. '\u{1D49F}' | '\u{1D4A2}' | '\u{1D4A5}' .. '\u{1D4A6}' | '\u{1D4A9}' .. '\u{1D4AC}' | '\u{1D4AE}' .. '\u{1D4B9}' | '\u{1D4BB}' | '\u{1D4BD}' .. '\u{1D4C3}' | '\u{1D4C5}' .. '\u{1D505}' | '\u{1D507}' .. '\u{1D50A}' | '\u{1D50D}' .. '\u{1D514}' | '\u{1D516}' .. '\u{1D51C}' | '\u{1D51E}' .. '\u{1D539}' | '\u{1D53B}' .. '\u{1D53E}' | '\u{1D540}' .. '\u{1D544}' | '\u{1D546}' | '\u{1D54A}' .. '\u{1D550}' | '\u{1D552}' .. '\u{1D6A5}' | '\u{1D6A8}' .. '\u{1D6C0}' | '\u{1D6C2}' .. '\u{1D6DA}' | '\u{1D6DC}' .. '\u{1D6FA}' | '\u{1D6FC}' .. '\u{1D714}' | '\u{1D716}' .. '\u{1D734}' | '\u{1D736}' .. '\u{1D74E}' | '\u{1D750}' .. '\u{1D76E}' | '\u{1D770}' .. '\u{1D788}' | '\u{1D78A}' .. '\u{1D7A8}' | '\u{1D7AA}' .. '\u{1D7C2}' | '\u{1D7C4}' .. '\u{1D7CB}' | '\u{1DF00}' .. '\u{1DF1E}' | '\u{1DF25}' .. '\u{1DF2A}' | '\u{1E030}' .. '\u{1E06D}' | '\u{1E100}' .. '\u{1E12C}' | '\u{1E137}' .. '\u{1E13D}' | '\u{1E14E}' | '\u{1E290}' .. '\u{1E2AD}' | '\u{1E2C0}' .. '\u{1E2EB}' | '\u{1E4D0}' .. '\u{1E4EB}' | '\u{1E7E0}' .. '\u{1E7E6}' | '\u{1E7E8}' .. '\u{1E7EB}' | '\u{1E7ED}' .. '\u{1E7EE}' | '\u{1E7F0}' .. '\u{1E7FE}' | '\u{1E800}' .. '\u{1E8C4}' | '\u{1E900}' .. '\u{1E943}' | '\u{1E94B}' | '\u{1EE00}' .. '\u{1EE03}' | '\u{1EE05}' .. '\u{1EE1F}' | '\u{1EE21}' .. '\u{1EE22}' | '\u{1EE24}' | '\u{1EE27}' | '\u{1EE29}' .. '\u{1EE32}' | '\u{1EE34}' .. '\u{1EE37}' | '\u{1EE39}' | '\u{1EE3B}' | '\u{1EE42}' | '\u{1EE47}' | '\u{1EE49}' | '\u{1EE4B}' | '\u{1EE4D}' .. '\u{1EE4F}' | '\u{1EE51}' .. '\u{1EE52}' | '\u{1EE54}' | '\u{1EE57}' | '\u{1EE59}' | '\u{1EE5B}' | '\u{1EE5D}' | '\u{1EE5F}' | '\u{1EE61}' .. '\u{1EE62}' | '\u{1EE64}' | '\u{1EE67}' .. '\u{1EE6A}' | '\u{1EE6C}' .. '\u{1EE72}' | '\u{1EE74}' .. '\u{1EE77}' | '\u{1EE79}' .. '\u{1EE7C}' | '\u{1EE7E}' | '\u{1EE80}' .. '\u{1EE89}' | '\u{1EE8B}' .. '\u{1EE9B}' | '\u{1EEA1}' .. '\u{1EEA3}' | '\u{1EEA5}' .. '\u{1EEA9}' | '\u{1EEAB}' .. '\u{1EEBB}' | '\u{20000}' .. '\u{2A6DF}' | '\u{2A700}' .. '\u{2B739}' | '\u{2B740}' .. '\u{2B81D}' | '\u{2B820}' .. '\u{2CEA1}' | '\u{2CEB0}' .. '\u{2EBE0}' | '\u{2EBF0}' .. '\u{2EE5D}' | '\u{2F800}' .. '\u{2FA1D}' | '\u{30000}' .. '\u{3134A}' | '\u{31350}' .. '\u{323AF}' ; ================================================ FILE: src/parser/LatexLexer.g4 ================================================ lexer grammar LatexLexer; import LatexIdFragments; L_BRACKET: '[' -> mode(UNITS) ; ALT_L_BRACKET: '\\lbrack' -> mode(UNITS) ; COLON: ':' ; SEMICOLON: ';' ; L_BRACE: '{' ; R_BRACE: '}' ; L_PAREN: '(' ; R_PAREN: ')' ; VBAR: '|' ; DOUBLE_VBAR: '||' | '\\Vert' ; UNDERSCORE: '_' ; fragment UNDERSCORE_SINGLE_CHAR_NUMBER: '_' [0-9]; fragment UNDERSCORE_SINGLE_CHAR_ID: '_' ID_START; EXCLAMATION: '!' ; INFINITY: '\\infty' ; CMD_INT: '\\int' ; CMD_INT_UNDERSCORE: '\\int' [ ]* '_' ; CMD_INT_UNDERSCORE_SINGLE_CHAR_NUMBER: '\\int' [ ]* UNDERSCORE_SINGLE_CHAR_NUMBER ; CMD_INT_UNDERSCORE_SINGLE_CHAR_ID: '\\int' [ ]* UNDERSCORE_SINGLE_CHAR_ID ; CMD_SUM_UNDERSCORE: '\\sum' [ ]* '_' ; CMD_PROD_UNDERSCORE: '\\prod' [ ]* '_' ; CMD_MATHRM: '\\mathrm' ; CMD_FRAC: '\\frac' ; CMD_FRAC_INTS: '\\frac' [ ]* [0-9][0-9]; CMD_CDOT: '\\cdot' ; CMD_TIMES: '\\times' ; CMD_SQRT: '\\sqrt' ; CMD_SQRT_INT: '\\sqrt' [ ]* [0-9] ; CMD_SIM: '\\sim' ; CMD_APPROX: '\\approx' ; CMD_PLACEHOLDER: '\\placeholder' ; TRANSPOSE: '^{\\mathrm{T}}' ; BACKSLASH: '\\' ; AS_LINES: 'as' (' ' | '\\:')+ 'line' [s]? ; CMD_SIN: 'sin' ; CMD_COS: 'cos' ; CMD_TAN: 'tan' ; CMD_COT: 'cot' ; CMD_SEC: 'sec' ; CMD_CSC: 'csc' ; CMD_ARCSIN: 'arcsin' ; CMD_ARCCOS: 'arccos' ; CMD_ARCTAN: 'arctan' ; CMD_SINH: 'sinh' ; CMD_COSH: 'cosh' ; CMD_TANH: 'tanh' ; CMD_COTH: 'coth' ; CMD_LN: 'ln' ; CMD_LOG: 'log' ; CMD_SLASH_LOG_UNDERSCORE: '\\log' [ ]* '_' ; CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_NUMBER: '\\log' [ ]* UNDERSCORE_SINGLE_CHAR_NUMBER ; CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_ID: '\\log' [ ]* UNDERSCORE_SINGLE_CHAR_ID ; COMMENT: '\\text{' .*? '}' -> skip ; CMD_LEFT: '\\left' '.'? -> skip ; CMD_RIGHT: '\\right' '.'? -> skip ; DOUBLE_DOLLAR_SIGN: '$$' -> skip ; ADD: '+' ; SUB: '-' ; CARET: '^' ; EQ: '=' ; LT: '<'; GT: '>'; LTE: '\\le'; GTE: '\\ge'; COMMA: ','; DECIMAL_POINT: '.'; fragment DIGIT : [0-9]; CARET_SINGLE_CHAR_NUMBER: '^' DIGIT; CARET_SINGLE_CHAR_ID: '^' ID_START; NUMBER: DIGIT+ '.' DIGIT* EXP? | '.' DIGIT+ EXP? | DIGIT+ EXP? ; fragment IDENTIFIER : (ID_START | (LATEX_SYMBOLS [ ]*)) (ID_CONTINUE | (LATEX_SYMBOLS [ ]*))*; fragment EXP : ('E' | 'e' ) ('+' | '-')? DIGIT+ | ' '* ( CMD_CDOT | CMD_TIMES) ' '* '10' CARET ( DIGIT | ( L_BRACE ('+' | '-')? DIGIT+ R_BRACE) ); fragment LATEX_SYMBOLS: '\\' ('ell' | 'hbar' | 'alpha' | 'beta' | 'gamma' | 'delta' | 'epsilon' | 'varepsilon' | 'zeta' | 'eta' | 'theta' | 'vartheta' | 'iota' | 'kappa' | 'varkappa' | 'lambda' | 'mu' | 'nu' | 'xi' | 'omicron' | 'pi' | 'varpi' | 'rho' | 'varrho' | 'sigma' | 'varsigma' | 'tau' | 'phi' | 'varphi' | 'upsilon' | 'chi' | 'psi' | 'omega' | 'Gamma' | 'Delta' | 'Theta' | 'Lambda' | 'Xi' | 'Pi' | 'Sigma' | 'Upsilon' | 'Phi' | 'Psi' | 'Omega' | 'digamma' | 'varkappa' | 'coppa' | 'koppa' | 'Coppa' | 'Koppa' | 'sampi' | 'Sampi' | 'wp' | 'aleph' | 'hslash' | 'Finv' | 'eth' | 'Bbbk' | 'beth' | 'daleth' | 'gimel' | 'imath' | 'jmath' ); BEGIN_MATRIX: '\\begin{bmatrix}'; END_MATRIX: '\\end{bmatrix}'; AMPERSAND: '&'; DOUBLE_BACKSLASH: '\\\\'; UNDERSCORE_SUBSCRIPT: (([ ]* '_{' (ID_CONTINUE | (LATEX_SYMBOLS [ ]*))+ '}') | ([ ]* ('_' ID_CONTINUE) )); CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT: '^'ID_START UNDERSCORE_SUBSCRIPT; fragment ACCENT: '\\' ('hat' | 'bar' | 'vec' | 'dot' | 'ddot' | 'dddot'); PRIME_ACCENT: CARET L_BRACE ('\\prime' [ ]*)+ R_BRACE; ID: IDENTIFIER UNDERSCORE_SUBSCRIPT? | IDENTIFIER PRIME_ACCENT UNDERSCORE_SUBSCRIPT? | IDENTIFIER UNDERSCORE_SUBSCRIPT PRIME_ACCENT | ACCENT L_BRACE IDENTIFIER R_BRACE UNDERSCORE_SUBSCRIPT? | ACCENT L_BRACE IDENTIFIER UNDERSCORE_SUBSCRIPT R_BRACE; WS: [ \t\r\n]+ -> skip ; SLASH_SPACE: '\\ ' -> skip ; SLASH_COLON: '\\:' -> skip ; NBSP: '\u00A0' -> skip ; ERROR_CHAR : . ; mode UNITS; R_BRACKET: ']' -> mode(DEFAULT_MODE); ALT_R_BRACKET: '\\rbrack' -> mode(DEFAULT_MODE) ; U_CMD_FRAC: '\\frac' ; U_CMD_FRAC_INTS: '\\frac' [ ]* [0-9][0-9]; U_CMD_CDOT: '\\cdot' ; U_CMD_TIMES: '\\times' ; U_CMD_SQRT: '\\sqrt' ; U_COMMA: ','; U_CARET: '^' ; U_NAME: [a-zA-Z] [a-zA-Z0-9]* ; U_L_PAREN: '(' ; U_R_PAREN: ')' ; U_L_BRACE: '{' ; U_R_BRACE: '}' ; U_ONE: '1' ; U_NUMBER: '-'? U_DIGIT+ '.' U_DIGIT* | '-'? '.' U_DIGIT+ | '-'? U_DIGIT+ ; fragment U_DIGIT : [0-9]; U_CMD_LEFT: '\\left' -> skip ; U_CMD_RIGHT: '\\right' -> skip ; U_WS: [ \t\r\n]+ -> skip ; U_SLASH_SPACE: '\\ ' -> skip ; U_SLASH_COLON: '\\:' -> skip ; U_NBSP: '\u00A0' -> skip ; U_ERROR_CHAR : . ; ================================================ FILE: src/parser/LatexLexer.ts ================================================ // Generated from LatexLexer.g4 by ANTLR 4.12.0 // noinspection ES6UnusedImports,JSUnusedGlobalSymbols,JSUnusedLocalSymbols import { ATN, ATNDeserializer, CharStream, DecisionState, DFA, Lexer, LexerATNSimulator, RuleContext, PredictionContextCache, Token } from "antlr4"; export default class LatexLexer extends Lexer { public static readonly L_BRACKET = 1; public static readonly ALT_L_BRACKET = 2; public static readonly COLON = 3; public static readonly SEMICOLON = 4; public static readonly L_BRACE = 5; public static readonly R_BRACE = 6; public static readonly L_PAREN = 7; public static readonly R_PAREN = 8; public static readonly VBAR = 9; public static readonly DOUBLE_VBAR = 10; public static readonly UNDERSCORE = 11; public static readonly EXCLAMATION = 12; public static readonly INFINITY = 13; public static readonly CMD_INT = 14; public static readonly CMD_INT_UNDERSCORE = 15; public static readonly CMD_INT_UNDERSCORE_SINGLE_CHAR_NUMBER = 16; public static readonly CMD_INT_UNDERSCORE_SINGLE_CHAR_ID = 17; public static readonly CMD_SUM_UNDERSCORE = 18; public static readonly CMD_PROD_UNDERSCORE = 19; public static readonly CMD_MATHRM = 20; public static readonly CMD_FRAC = 21; public static readonly CMD_FRAC_INTS = 22; public static readonly CMD_CDOT = 23; public static readonly CMD_TIMES = 24; public static readonly CMD_SQRT = 25; public static readonly CMD_SQRT_INT = 26; public static readonly CMD_SIM = 27; public static readonly CMD_APPROX = 28; public static readonly CMD_PLACEHOLDER = 29; public static readonly TRANSPOSE = 30; public static readonly BACKSLASH = 31; public static readonly AS_LINES = 32; public static readonly CMD_SIN = 33; public static readonly CMD_COS = 34; public static readonly CMD_TAN = 35; public static readonly CMD_COT = 36; public static readonly CMD_SEC = 37; public static readonly CMD_CSC = 38; public static readonly CMD_ARCSIN = 39; public static readonly CMD_ARCCOS = 40; public static readonly CMD_ARCTAN = 41; public static readonly CMD_SINH = 42; public static readonly CMD_COSH = 43; public static readonly CMD_TANH = 44; public static readonly CMD_COTH = 45; public static readonly CMD_LN = 46; public static readonly CMD_LOG = 47; public static readonly CMD_SLASH_LOG_UNDERSCORE = 48; public static readonly CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_NUMBER = 49; public static readonly CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_ID = 50; public static readonly COMMENT = 51; public static readonly CMD_LEFT = 52; public static readonly CMD_RIGHT = 53; public static readonly DOUBLE_DOLLAR_SIGN = 54; public static readonly ADD = 55; public static readonly SUB = 56; public static readonly CARET = 57; public static readonly EQ = 58; public static readonly LT = 59; public static readonly GT = 60; public static readonly LTE = 61; public static readonly GTE = 62; public static readonly COMMA = 63; public static readonly DECIMAL_POINT = 64; public static readonly CARET_SINGLE_CHAR_NUMBER = 65; public static readonly CARET_SINGLE_CHAR_ID = 66; public static readonly NUMBER = 67; public static readonly BEGIN_MATRIX = 68; public static readonly END_MATRIX = 69; public static readonly AMPERSAND = 70; public static readonly DOUBLE_BACKSLASH = 71; public static readonly UNDERSCORE_SUBSCRIPT = 72; public static readonly CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT = 73; public static readonly PRIME_ACCENT = 74; public static readonly ID = 75; public static readonly WS = 76; public static readonly SLASH_SPACE = 77; public static readonly SLASH_COLON = 78; public static readonly NBSP = 79; public static readonly ERROR_CHAR = 80; public static readonly R_BRACKET = 81; public static readonly ALT_R_BRACKET = 82; public static readonly U_CMD_FRAC = 83; public static readonly U_CMD_FRAC_INTS = 84; public static readonly U_CMD_CDOT = 85; public static readonly U_CMD_TIMES = 86; public static readonly U_CMD_SQRT = 87; public static readonly U_COMMA = 88; public static readonly U_CARET = 89; public static readonly U_NAME = 90; public static readonly U_L_PAREN = 91; public static readonly U_R_PAREN = 92; public static readonly U_L_BRACE = 93; public static readonly U_R_BRACE = 94; public static readonly U_ONE = 95; public static readonly U_NUMBER = 96; public static readonly U_CMD_LEFT = 97; public static readonly U_CMD_RIGHT = 98; public static readonly U_WS = 99; public static readonly U_SLASH_SPACE = 100; public static readonly U_SLASH_COLON = 101; public static readonly U_NBSP = 102; public static readonly U_ERROR_CHAR = 103; public static readonly EOF = Token.EOF; public static readonly UNITS = 1; public static readonly channelNames: string[] = [ "DEFAULT_TOKEN_CHANNEL", "HIDDEN" ]; public static readonly literalNames: string[] = [ null, "'['", "'\\lbrack'", "':'", "';'", null, null, null, null, "'|'", null, "'_'", "'!'", "'\\infty'", "'\\int'", null, null, null, null, null, "'\\mathrm'", null, null, null, null, null, null, "'\\sim'", "'\\approx'", "'\\placeholder'", "'^{\\mathrm{T}}'", "'\\'", null, "'sin'", "'cos'", "'tan'", "'cot'", "'sec'", "'csc'", "'arcsin'", "'arccos'", "'arctan'", "'sinh'", "'cosh'", "'tanh'", "'coth'", "'ln'", "'log'", null, null, null, null, null, null, "'$$'", "'+'", "'-'", null, "'='", "'<'", "'>'", "'\\le'", "'\\ge'", null, "'.'", null, null, null, "'\\begin{bmatrix}'", "'\\end{bmatrix}'", "'&'", "'\\\\'", null, null, null, null, null, null, null, null, null, "']'", "'\\rbrack'", null, null, null, null, null, null, null, null, null, null, null, null, "'1'", null, "'\\left'", "'\\right'" ]; public static readonly symbolicNames: string[] = [ null, "L_BRACKET", "ALT_L_BRACKET", "COLON", "SEMICOLON", "L_BRACE", "R_BRACE", "L_PAREN", "R_PAREN", "VBAR", "DOUBLE_VBAR", "UNDERSCORE", "EXCLAMATION", "INFINITY", "CMD_INT", "CMD_INT_UNDERSCORE", "CMD_INT_UNDERSCORE_SINGLE_CHAR_NUMBER", "CMD_INT_UNDERSCORE_SINGLE_CHAR_ID", "CMD_SUM_UNDERSCORE", "CMD_PROD_UNDERSCORE", "CMD_MATHRM", "CMD_FRAC", "CMD_FRAC_INTS", "CMD_CDOT", "CMD_TIMES", "CMD_SQRT", "CMD_SQRT_INT", "CMD_SIM", "CMD_APPROX", "CMD_PLACEHOLDER", "TRANSPOSE", "BACKSLASH", "AS_LINES", "CMD_SIN", "CMD_COS", "CMD_TAN", "CMD_COT", "CMD_SEC", "CMD_CSC", "CMD_ARCSIN", "CMD_ARCCOS", "CMD_ARCTAN", "CMD_SINH", "CMD_COSH", "CMD_TANH", "CMD_COTH", "CMD_LN", "CMD_LOG", "CMD_SLASH_LOG_UNDERSCORE", "CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_NUMBER", "CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_ID", "COMMENT", "CMD_LEFT", "CMD_RIGHT", "DOUBLE_DOLLAR_SIGN", "ADD", "SUB", "CARET", "EQ", "LT", "GT", "LTE", "GTE", "COMMA", "DECIMAL_POINT", "CARET_SINGLE_CHAR_NUMBER", "CARET_SINGLE_CHAR_ID", "NUMBER", "BEGIN_MATRIX", "END_MATRIX", "AMPERSAND", "DOUBLE_BACKSLASH", "UNDERSCORE_SUBSCRIPT", "CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT", "PRIME_ACCENT", "ID", "WS", "SLASH_SPACE", "SLASH_COLON", "NBSP", "ERROR_CHAR", "R_BRACKET", "ALT_R_BRACKET", "U_CMD_FRAC", "U_CMD_FRAC_INTS", "U_CMD_CDOT", "U_CMD_TIMES", "U_CMD_SQRT", "U_COMMA", "U_CARET", "U_NAME", "U_L_PAREN", "U_R_PAREN", "U_L_BRACE", "U_R_BRACE", "U_ONE", "U_NUMBER", "U_CMD_LEFT", "U_CMD_RIGHT", "U_WS", "U_SLASH_SPACE", "U_SLASH_COLON", "U_NBSP", "U_ERROR_CHAR" ]; public static readonly modeNames: string[] = [ "DEFAULT_MODE", "UNITS", ]; public static readonly ruleNames: string[] = [ "L_BRACKET", "ALT_L_BRACKET", "COLON", "SEMICOLON", "L_BRACE", "R_BRACE", "L_PAREN", "R_PAREN", "VBAR", "DOUBLE_VBAR", "UNDERSCORE", "UNDERSCORE_SINGLE_CHAR_NUMBER", "UNDERSCORE_SINGLE_CHAR_ID", "EXCLAMATION", "INFINITY", "CMD_INT", "CMD_INT_UNDERSCORE", "CMD_INT_UNDERSCORE_SINGLE_CHAR_NUMBER", "CMD_INT_UNDERSCORE_SINGLE_CHAR_ID", "CMD_SUM_UNDERSCORE", "CMD_PROD_UNDERSCORE", "CMD_MATHRM", "CMD_FRAC", "CMD_FRAC_INTS", "CMD_CDOT", "CMD_TIMES", "CMD_SQRT", "CMD_SQRT_INT", "CMD_SIM", "CMD_APPROX", "CMD_PLACEHOLDER", "TRANSPOSE", "BACKSLASH", "AS_LINES", "CMD_SIN", "CMD_COS", "CMD_TAN", "CMD_COT", "CMD_SEC", "CMD_CSC", "CMD_ARCSIN", "CMD_ARCCOS", "CMD_ARCTAN", "CMD_SINH", "CMD_COSH", "CMD_TANH", "CMD_COTH", "CMD_LN", "CMD_LOG", "CMD_SLASH_LOG_UNDERSCORE", "CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_NUMBER", "CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_ID", "COMMENT", "CMD_LEFT", "CMD_RIGHT", "DOUBLE_DOLLAR_SIGN", "ADD", "SUB", "CARET", "EQ", "LT", "GT", "LTE", "GTE", "COMMA", "DECIMAL_POINT", "DIGIT", "CARET_SINGLE_CHAR_NUMBER", "CARET_SINGLE_CHAR_ID", "NUMBER", "IDENTIFIER", "EXP", "LATEX_SYMBOLS", "BEGIN_MATRIX", "END_MATRIX", "AMPERSAND", "DOUBLE_BACKSLASH", "UNDERSCORE_SUBSCRIPT", "CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT", "ACCENT", "PRIME_ACCENT", "ID", "WS", "SLASH_SPACE", "SLASH_COLON", "NBSP", "ERROR_CHAR", "ID_CONTINUE", "ID_START", "R_BRACKET", "ALT_R_BRACKET", "U_CMD_FRAC", "U_CMD_FRAC_INTS", "U_CMD_CDOT", "U_CMD_TIMES", "U_CMD_SQRT", "U_COMMA", "U_CARET", "U_NAME", "U_L_PAREN", "U_R_PAREN", "U_L_BRACE", "U_R_BRACE", "U_ONE", "U_NUMBER", "U_DIGIT", "U_CMD_LEFT", "U_CMD_RIGHT", "U_WS", "U_SLASH_SPACE", "U_SLASH_COLON", "U_NBSP", "U_ERROR_CHAR", ]; constructor(input: CharStream) { super(input); this._interp = new LexerATNSimulator(this, LatexLexer._ATN, LatexLexer.DecisionsToDFA, new PredictionContextCache()); } public get grammarFileName(): string { return "LatexLexer.g4"; } public get literalNames(): (string | null)[] { return LatexLexer.literalNames; } public get symbolicNames(): (string | null)[] { return LatexLexer.symbolicNames; } public get ruleNames(): string[] { return LatexLexer.ruleNames; } public get serializedATN(): number[] { return LatexLexer._serializedATN; } public get channelNames(): string[] { return LatexLexer.channelNames; } public get modeNames(): string[] { return LatexLexer.modeNames; } public static readonly _serializedATN: number[] = [4,0,103,1393,6,-1,6, -1,2,0,7,0,2,1,7,1,2,2,7,2,2,3,7,3,2,4,7,4,2,5,7,5,2,6,7,6,2,7,7,7,2,8, 7,8,2,9,7,9,2,10,7,10,2,11,7,11,2,12,7,12,2,13,7,13,2,14,7,14,2,15,7,15, 2,16,7,16,2,17,7,17,2,18,7,18,2,19,7,19,2,20,7,20,2,21,7,21,2,22,7,22,2, 23,7,23,2,24,7,24,2,25,7,25,2,26,7,26,2,27,7,27,2,28,7,28,2,29,7,29,2,30, 7,30,2,31,7,31,2,32,7,32,2,33,7,33,2,34,7,34,2,35,7,35,2,36,7,36,2,37,7, 37,2,38,7,38,2,39,7,39,2,40,7,40,2,41,7,41,2,42,7,42,2,43,7,43,2,44,7,44, 2,45,7,45,2,46,7,46,2,47,7,47,2,48,7,48,2,49,7,49,2,50,7,50,2,51,7,51,2, 52,7,52,2,53,7,53,2,54,7,54,2,55,7,55,2,56,7,56,2,57,7,57,2,58,7,58,2,59, 7,59,2,60,7,60,2,61,7,61,2,62,7,62,2,63,7,63,2,64,7,64,2,65,7,65,2,66,7, 66,2,67,7,67,2,68,7,68,2,69,7,69,2,70,7,70,2,71,7,71,2,72,7,72,2,73,7,73, 2,74,7,74,2,75,7,75,2,76,7,76,2,77,7,77,2,78,7,78,2,79,7,79,2,80,7,80,2, 81,7,81,2,82,7,82,2,83,7,83,2,84,7,84,2,85,7,85,2,86,7,86,2,87,7,87,2,88, 7,88,2,89,7,89,2,90,7,90,2,91,7,91,2,92,7,92,2,93,7,93,2,94,7,94,2,95,7, 95,2,96,7,96,2,97,7,97,2,98,7,98,2,99,7,99,2,100,7,100,2,101,7,101,2,102, 7,102,2,103,7,103,2,104,7,104,2,105,7,105,2,106,7,106,2,107,7,107,2,108, 7,108,2,109,7,109,2,110,7,110,2,111,7,111,2,112,7,112,1,0,1,0,1,0,1,0,1, 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,2,1,2,1,3,1,3,1,4,1,4,1,5,1,5,1, 6,1,6,1,7,1,7,1,8,1,8,1,9,1,9,1,9,1,9,1,9,1,9,1,9,3,9,264,8,9,1,10,1,10, 1,11,1,11,1,11,1,12,1,12,1,12,1,13,1,13,1,14,1,14,1,14,1,14,1,14,1,14,1, 14,1,15,1,15,1,15,1,15,1,15,1,16,1,16,1,16,1,16,1,16,1,16,5,16,294,8,16, 10,16,12,16,297,9,16,1,16,1,16,1,17,1,17,1,17,1,17,1,17,1,17,5,17,307,8, 17,10,17,12,17,310,9,17,1,17,1,17,1,18,1,18,1,18,1,18,1,18,1,18,5,18,320, 8,18,10,18,12,18,323,9,18,1,18,1,18,1,19,1,19,1,19,1,19,1,19,1,19,5,19, 333,8,19,10,19,12,19,336,9,19,1,19,1,19,1,20,1,20,1,20,1,20,1,20,1,20,1, 20,5,20,347,8,20,10,20,12,20,350,9,20,1,20,1,20,1,21,1,21,1,21,1,21,1,21, 1,21,1,21,1,21,1,22,1,22,1,22,1,22,1,22,1,22,1,23,1,23,1,23,1,23,1,23,1, 23,1,23,5,23,375,8,23,10,23,12,23,378,9,23,1,23,1,23,1,23,1,24,1,24,1,24, 1,24,1,24,1,24,1,25,1,25,1,25,1,25,1,25,1,25,1,25,1,26,1,26,1,26,1,26,1, 26,1,26,1,27,1,27,1,27,1,27,1,27,1,27,1,27,5,27,409,8,27,10,27,12,27,412, 9,27,1,27,1,27,1,28,1,28,1,28,1,28,1,28,1,29,1,29,1,29,1,29,1,29,1,29,1, 29,1,29,1,30,1,30,1,30,1,30,1,30,1,30,1,30,1,30,1,30,1,30,1,30,1,30,1,30, 1,31,1,31,1,31,1,31,1,31,1,31,1,31,1,31,1,31,1,31,1,31,1,31,1,31,1,31,1, 32,1,32,1,33,1,33,1,33,1,33,1,33,1,33,4,33,464,8,33,11,33,12,33,465,1,33, 1,33,1,33,1,33,1,33,1,33,3,33,474,8,33,1,34,1,34,1,34,1,34,1,35,1,35,1, 35,1,35,1,36,1,36,1,36,1,36,1,37,1,37,1,37,1,37,1,38,1,38,1,38,1,38,1,39, 1,39,1,39,1,39,1,40,1,40,1,40,1,40,1,40,1,40,1,40,1,41,1,41,1,41,1,41,1, 41,1,41,1,41,1,42,1,42,1,42,1,42,1,42,1,42,1,42,1,43,1,43,1,43,1,43,1,43, 1,44,1,44,1,44,1,44,1,44,1,45,1,45,1,45,1,45,1,45,1,46,1,46,1,46,1,46,1, 46,1,47,1,47,1,47,1,48,1,48,1,48,1,48,1,49,1,49,1,49,1,49,1,49,1,49,5,49, 554,8,49,10,49,12,49,557,9,49,1,49,1,49,1,50,1,50,1,50,1,50,1,50,1,50,5, 50,567,8,50,10,50,12,50,570,9,50,1,50,1,50,1,51,1,51,1,51,1,51,1,51,1,51, 5,51,580,8,51,10,51,12,51,583,9,51,1,51,1,51,1,52,1,52,1,52,1,52,1,52,1, 52,1,52,1,52,5,52,595,8,52,10,52,12,52,598,9,52,1,52,1,52,1,52,1,52,1,53, 1,53,1,53,1,53,1,53,1,53,1,53,3,53,611,8,53,1,53,1,53,1,54,1,54,1,54,1, 54,1,54,1,54,1,54,1,54,3,54,623,8,54,1,54,1,54,1,55,1,55,1,55,1,55,1,55, 1,56,1,56,1,57,1,57,1,58,1,58,1,59,1,59,1,60,1,60,1,61,1,61,1,62,1,62,1, 62,1,62,1,63,1,63,1,63,1,63,1,64,1,64,1,65,1,65,1,66,1,66,1,67,1,67,1,67, 1,68,1,68,1,68,1,69,4,69,665,8,69,11,69,12,69,666,1,69,1,69,5,69,671,8, 69,10,69,12,69,674,9,69,1,69,3,69,677,8,69,1,69,1,69,4,69,681,8,69,11,69, 12,69,682,1,69,3,69,686,8,69,1,69,4,69,689,8,69,11,69,12,69,690,1,69,3, 69,694,8,69,3,69,696,8,69,1,70,1,70,1,70,5,70,701,8,70,10,70,12,70,704, 9,70,3,70,706,8,70,1,70,1,70,1,70,5,70,711,8,70,10,70,12,70,714,9,70,5, 70,716,8,70,10,70,12,70,719,9,70,1,71,1,71,3,71,723,8,71,1,71,4,71,726, 8,71,11,71,12,71,727,1,71,5,71,731,8,71,10,71,12,71,734,9,71,1,71,1,71, 3,71,738,8,71,1,71,5,71,741,8,71,10,71,12,71,744,9,71,1,71,1,71,1,71,1, 71,1,71,1,71,1,71,3,71,753,8,71,1,71,4,71,756,8,71,11,71,12,71,757,1,71, 1,71,3,71,762,8,71,3,71,764,8,71,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72, 1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1, 72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72, 1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1, 72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72, 1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1, 72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72, 1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1, 72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72, 1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1, 72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72, 1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1, 72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72, 1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1, 72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72, 1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1, 72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72, 1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1, 72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72, 1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1, 72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72, 1,72,1,72,1,72,3,72,1067,8,72,1,73,1,73,1,73,1,73,1,73,1,73,1,73,1,73,1, 73,1,73,1,73,1,73,1,73,1,73,1,73,1,73,1,74,1,74,1,74,1,74,1,74,1,74,1,74, 1,74,1,74,1,74,1,74,1,74,1,74,1,74,1,75,1,75,1,76,1,76,1,76,1,77,5,77,1105, 8,77,10,77,12,77,1108,9,77,1,77,1,77,1,77,1,77,1,77,1,77,5,77,1116,8,77, 10,77,12,77,1119,9,77,4,77,1121,8,77,11,77,12,77,1122,1,77,1,77,1,77,5, 77,1128,8,77,10,77,12,77,1131,9,77,1,77,1,77,3,77,1135,8,77,1,78,1,78,1, 78,1,78,1,79,1,79,1,79,1,79,1,79,1,79,1,79,1,79,1,79,1,79,1,79,1,79,1,79, 1,79,1,79,1,79,1,79,1,79,1,79,1,79,1,79,1,79,3,79,1163,8,79,1,80,1,80,1, 80,1,80,1,80,1,80,1,80,1,80,1,80,1,80,5,80,1175,8,80,10,80,12,80,1178,9, 80,4,80,1180,8,80,11,80,12,80,1181,1,80,1,80,1,81,1,81,3,81,1188,8,81,1, 81,1,81,1,81,3,81,1193,8,81,1,81,1,81,1,81,1,81,1,81,1,81,1,81,1,81,1,81, 3,81,1204,8,81,1,81,1,81,1,81,1,81,1,81,1,81,3,81,1212,8,81,1,82,4,82,1215, 8,82,11,82,12,82,1216,1,82,1,82,1,83,1,83,1,83,1,83,1,83,1,84,1,84,1,84, 1,84,1,84,1,85,1,85,1,85,1,85,1,86,1,86,1,87,1,87,3,87,1239,8,87,1,88,1, 88,1,89,1,89,1,89,1,89,1,90,1,90,1,90,1,90,1,90,1,90,1,90,1,90,1,90,1,90, 1,91,1,91,1,91,1,91,1,91,1,91,1,92,1,92,1,92,1,92,1,92,1,92,1,92,5,92,1270, 8,92,10,92,12,92,1273,9,92,1,92,1,92,1,92,1,93,1,93,1,93,1,93,1,93,1,93, 1,94,1,94,1,94,1,94,1,94,1,94,1,94,1,95,1,95,1,95,1,95,1,95,1,95,1,96,1, 96,1,97,1,97,1,98,1,98,5,98,1303,8,98,10,98,12,98,1306,9,98,1,99,1,99,1, 100,1,100,1,101,1,101,1,102,1,102,1,103,1,103,1,104,3,104,1319,8,104,1, 104,4,104,1322,8,104,11,104,12,104,1323,1,104,1,104,5,104,1328,8,104,10, 104,12,104,1331,9,104,1,104,3,104,1334,8,104,1,104,1,104,4,104,1338,8,104, 11,104,12,104,1339,1,104,3,104,1343,8,104,1,104,4,104,1346,8,104,11,104, 12,104,1347,3,104,1350,8,104,1,105,1,105,1,106,1,106,1,106,1,106,1,106, 1,106,1,106,1,106,1,107,1,107,1,107,1,107,1,107,1,107,1,107,1,107,1,107, 1,108,4,108,1372,8,108,11,108,12,108,1373,1,108,1,108,1,109,1,109,1,109, 1,109,1,109,1,110,1,110,1,110,1,110,1,110,1,111,1,111,1,111,1,111,1,112, 1,112,1,596,0,113,2,1,4,2,6,3,8,4,10,5,12,6,14,7,16,8,18,9,20,10,22,11, 24,0,26,0,28,12,30,13,32,14,34,15,36,16,38,17,40,18,42,19,44,20,46,21,48, 22,50,23,52,24,54,25,56,26,58,27,60,28,62,29,64,30,66,31,68,32,70,33,72, 34,74,35,76,36,78,37,80,38,82,39,84,40,86,41,88,42,90,43,92,44,94,45,96, 46,98,47,100,48,102,49,104,50,106,51,108,52,110,53,112,54,114,55,116,56, 118,57,120,58,122,59,124,60,126,61,128,62,130,63,132,64,134,0,136,65,138, 66,140,67,142,0,144,0,146,0,148,68,150,69,152,70,154,71,156,72,158,73,160, 0,162,74,164,75,166,76,168,77,170,78,172,79,174,80,176,0,178,0,180,81,182, 82,184,83,186,84,188,85,190,86,192,87,194,88,196,89,198,90,200,91,202,92, 204,93,206,94,208,95,210,96,212,0,214,97,216,98,218,99,220,100,222,101, 224,102,226,103,2,0,1,10,1,0,48,57,1,0,32,32,1,0,115,115,2,0,69,69,101, 101,2,0,43,43,45,45,3,0,9,10,13,13,32,32,377,0,48,57,183,183,768,879,903, 903,1155,1159,1425,1469,1471,1471,1473,1474,1476,1477,1479,1479,1552,1562, 1611,1641,1648,1648,1750,1756,1759,1764,1767,1768,1770,1773,1776,1785,1809, 1809,1840,1866,1958,1968,1984,1993,2027,2035,2045,2045,2070,2073,2075,2083, 2085,2087,2089,2093,2137,2139,2200,2207,2250,2273,2275,2307,2362,2364,2366, 2383,2385,2391,2402,2403,2406,2415,2433,2435,2492,2492,2494,2500,2503,2504, 2507,2509,2519,2519,2530,2531,2534,2543,2558,2558,2561,2563,2620,2620,2622, 2626,2631,2632,2635,2637,2641,2641,2662,2673,2677,2677,2689,2691,2748,2748, 2750,2757,2759,2761,2763,2765,2786,2787,2790,2799,2810,2815,2817,2819,2876, 2876,2878,2884,2887,2888,2891,2893,2901,2903,2914,2915,2918,2927,2946,2946, 3006,3010,3014,3016,3018,3021,3031,3031,3046,3055,3072,3076,3132,3132,3134, 3140,3142,3144,3146,3149,3157,3158,3170,3171,3174,3183,3201,3203,3260,3260, 3262,3268,3270,3272,3274,3277,3285,3286,3298,3299,3302,3311,3315,3315,3328, 3331,3387,3388,3390,3396,3398,3400,3402,3405,3415,3415,3426,3427,3430,3439, 3457,3459,3530,3530,3535,3540,3542,3542,3544,3551,3558,3567,3570,3571,3633, 3633,3635,3642,3655,3662,3664,3673,3761,3761,3763,3772,3784,3790,3792,3801, 3864,3865,3872,3881,3893,3893,3895,3895,3897,3897,3902,3903,3953,3972,3974, 3975,3981,3991,3993,4028,4038,4038,4139,4158,4160,4169,4182,4185,4190,4192, 4194,4196,4199,4205,4209,4212,4226,4237,4239,4253,4957,4959,4969,4977,5906, 5909,5938,5940,5970,5971,6002,6003,6068,6099,6109,6109,6112,6121,6155,6157, 6159,6169,6313,6313,6432,6443,6448,6459,6470,6479,6608,6618,6679,6683,6741, 6750,6752,6780,6783,6793,6800,6809,6832,6845,6847,6862,6912,6916,6964,6980, 6992,7001,7019,7027,7040,7042,7073,7085,7088,7097,7142,7155,7204,7223,7232, 7241,7248,7257,7376,7378,7380,7400,7405,7405,7412,7412,7415,7417,7616,7679, 8204,8205,8255,8256,8276,8276,8400,8412,8417,8417,8421,8432,11503,11505, 11647,11647,11744,11775,12330,12335,12441,12442,12539,12539,42528,42537, 42607,42607,42612,42621,42654,42655,42736,42737,43010,43010,43014,43014, 43019,43019,43043,43047,43052,43052,43136,43137,43188,43205,43216,43225, 43232,43249,43263,43273,43302,43309,43335,43347,43392,43395,43443,43456, 43472,43481,43493,43493,43504,43513,43561,43574,43587,43587,43596,43597, 43600,43609,43643,43645,43696,43696,43698,43700,43703,43704,43710,43711, 43713,43713,43755,43759,43765,43766,44003,44010,44012,44013,44016,44025, 64286,64286,65024,65039,65056,65071,65075,65076,65101,65103,65296,65305, 65343,65343,65381,65381,65438,65439,66045,66045,66272,66272,66422,66426, 66720,66729,68097,68099,68101,68102,68108,68111,68152,68154,68159,68159, 68325,68326,68900,68903,68912,68921,69291,69292,69373,69375,69446,69456, 69506,69509,69632,69634,69688,69702,69734,69744,69747,69748,69759,69762, 69808,69818,69826,69826,69872,69881,69888,69890,69927,69940,69942,69951, 69957,69958,70003,70003,70016,70018,70067,70080,70089,70092,70094,70105, 70188,70199,70206,70206,70209,70209,70367,70378,70384,70393,70400,70403, 70459,70460,70462,70468,70471,70472,70475,70477,70487,70487,70498,70499, 70502,70508,70512,70516,70709,70726,70736,70745,70750,70750,70832,70851, 70864,70873,71087,71093,71096,71104,71132,71133,71216,71232,71248,71257, 71339,71351,71360,71369,71453,71467,71472,71481,71724,71738,71904,71913, 71984,71989,71991,71992,71995,71998,72000,72000,72002,72003,72016,72025, 72145,72151,72154,72160,72164,72164,72193,72202,72243,72249,72251,72254, 72263,72263,72273,72283,72330,72345,72751,72758,72760,72767,72784,72793, 72850,72871,72873,72886,73009,73014,73018,73018,73020,73021,73023,73029, 73031,73031,73040,73049,73098,73102,73104,73105,73107,73111,73120,73129, 73459,73462,73472,73473,73475,73475,73524,73530,73534,73538,73552,73561, 78912,78912,78919,78933,92768,92777,92864,92873,92912,92916,92976,92982, 93008,93017,94031,94031,94033,94087,94095,94098,94180,94180,94192,94193, 113821,113822,118528,118573,118576,118598,119141,119145,119149,119154,119163, 119170,119173,119179,119210,119213,119362,119364,120782,120831,121344,121398, 121403,121452,121461,121461,121476,121476,121499,121503,121505,121519,122880, 122886,122888,122904,122907,122913,122915,122916,122918,122922,123023,123023, 123184,123190,123200,123209,123566,123566,123628,123641,124140,124153,125136, 125142,125252,125258,125264,125273,130032,130041,917760,917999,667,0,65, 90,97,122,170,170,181,181,186,186,192,214,216,246,248,705,710,721,736,740, 748,748,750,750,880,884,886,887,891,893,895,895,902,902,904,906,908,908, 910,929,931,1013,1015,1153,1162,1327,1329,1366,1369,1369,1376,1416,1488, 1514,1519,1522,1568,1610,1646,1647,1649,1747,1749,1749,1765,1766,1774,1775, 1786,1788,1791,1791,1808,1808,1810,1839,1869,1957,1969,1969,1994,2026,2036, 2037,2042,2042,2048,2069,2074,2074,2084,2084,2088,2088,2112,2136,2144,2154, 2160,2183,2185,2190,2208,2249,2308,2361,2365,2365,2384,2384,2392,2401,2417, 2432,2437,2444,2447,2448,2451,2472,2474,2480,2482,2482,2486,2489,2493,2493, 2510,2510,2524,2525,2527,2529,2544,2545,2556,2556,2565,2570,2575,2576,2579, 2600,2602,2608,2610,2611,2613,2614,2616,2617,2649,2652,2654,2654,2674,2676, 2693,2701,2703,2705,2707,2728,2730,2736,2738,2739,2741,2745,2749,2749,2768, 2768,2784,2785,2809,2809,2821,2828,2831,2832,2835,2856,2858,2864,2866,2867, 2869,2873,2877,2877,2908,2909,2911,2913,2929,2929,2947,2947,2949,2954,2958, 2960,2962,2965,2969,2970,2972,2972,2974,2975,2979,2980,2984,2986,2990,3001, 3024,3024,3077,3084,3086,3088,3090,3112,3114,3129,3133,3133,3160,3162,3165, 3165,3168,3169,3200,3200,3205,3212,3214,3216,3218,3240,3242,3251,3253,3257, 3261,3261,3293,3294,3296,3297,3313,3314,3332,3340,3342,3344,3346,3386,3389, 3389,3406,3406,3412,3414,3423,3425,3450,3455,3461,3478,3482,3505,3507,3515, 3517,3517,3520,3526,3585,3632,3634,3634,3648,3654,3713,3714,3716,3716,3718, 3722,3724,3747,3749,3749,3751,3760,3762,3762,3773,3773,3776,3780,3782,3782, 3804,3807,3840,3840,3904,3911,3913,3948,3976,3980,4096,4138,4159,4159,4176, 4181,4186,4189,4193,4193,4197,4198,4206,4208,4213,4225,4238,4238,4256,4293, 4295,4295,4301,4301,4304,4346,4348,4680,4682,4685,4688,4694,4696,4696,4698, 4701,4704,4744,4746,4749,4752,4784,4786,4789,4792,4798,4800,4800,4802,4805, 4808,4822,4824,4880,4882,4885,4888,4954,4992,5007,5024,5109,5112,5117,5121, 5740,5743,5759,5761,5786,5792,5866,5870,5880,5888,5905,5919,5937,5952,5969, 5984,5996,5998,6000,6016,6067,6103,6103,6108,6108,6176,6264,6272,6312,6314, 6314,6320,6389,6400,6430,6480,6509,6512,6516,6528,6571,6576,6601,6656,6678, 6688,6740,6823,6823,6917,6963,6981,6988,7043,7072,7086,7087,7098,7141,7168, 7203,7245,7247,7258,7293,7296,7304,7312,7354,7357,7359,7401,7404,7406,7411, 7413,7414,7418,7418,7424,7615,7680,7957,7960,7965,7968,8005,8008,8013,8016, 8023,8025,8025,8027,8027,8029,8029,8031,8061,8064,8116,8118,8124,8126,8126, 8130,8132,8134,8140,8144,8147,8150,8155,8160,8172,8178,8180,8182,8188,8305, 8305,8319,8319,8336,8348,8450,8450,8455,8455,8458,8467,8469,8469,8472,8477, 8484,8484,8486,8486,8488,8488,8490,8505,8508,8511,8517,8521,8526,8526,8544, 8584,11264,11492,11499,11502,11506,11507,11520,11557,11559,11559,11565, 11565,11568,11623,11631,11631,11648,11670,11680,11686,11688,11694,11696, 11702,11704,11710,11712,11718,11720,11726,11728,11734,11736,11742,12293, 12295,12321,12329,12337,12341,12344,12348,12353,12438,12445,12447,12449, 12538,12540,12543,12549,12591,12593,12686,12704,12735,12784,12799,13312, 19903,19968,42124,42192,42237,42240,42508,42512,42527,42538,42539,42560, 42606,42623,42653,42656,42735,42775,42783,42786,42888,42891,42954,42960, 42961,42963,42963,42965,42969,42994,43009,43011,43013,43015,43018,43020, 43042,43072,43123,43138,43187,43250,43255,43259,43259,43261,43262,43274, 43301,43312,43334,43360,43388,43396,43442,43471,43471,43488,43492,43494, 43503,43514,43518,43520,43560,43584,43586,43588,43595,43616,43638,43642, 43642,43646,43695,43697,43697,43701,43702,43705,43709,43712,43712,43714, 43714,43739,43741,43744,43754,43762,43764,43777,43782,43785,43790,43793, 43798,43808,43814,43816,43822,43824,43866,43868,43881,43888,44002,44032, 55203,55216,55238,55243,55291,63744,64109,64112,64217,64256,64262,64275, 64279,64285,64285,64287,64296,64298,64310,64312,64316,64318,64318,64320, 64321,64323,64324,64326,64433,64467,64605,64612,64829,64848,64911,64914, 64967,65008,65017,65137,65137,65139,65139,65143,65143,65145,65145,65147, 65147,65149,65149,65151,65276,65313,65338,65345,65370,65382,65437,65440, 65470,65474,65479,65482,65487,65490,65495,65498,65500,65536,65547,65549, 65574,65576,65594,65596,65597,65599,65613,65616,65629,65664,65786,65856, 65908,66176,66204,66208,66256,66304,66335,66349,66378,66384,66421,66432, 66461,66464,66499,66504,66511,66513,66517,66560,66717,66736,66771,66776, 66811,66816,66855,66864,66915,66928,66938,66940,66954,66956,66962,66964, 66965,66967,66977,66979,66993,66995,67001,67003,67004,67072,67382,67392, 67413,67424,67431,67456,67461,67463,67504,67506,67514,67584,67589,67592, 67592,67594,67637,67639,67640,67644,67644,67647,67669,67680,67702,67712, 67742,67808,67826,67828,67829,67840,67861,67872,67897,67968,68023,68030, 68031,68096,68096,68112,68115,68117,68119,68121,68149,68192,68220,68224, 68252,68288,68295,68297,68324,68352,68405,68416,68437,68448,68466,68480, 68497,68608,68680,68736,68786,68800,68850,68864,68899,69248,69289,69296, 69297,69376,69404,69415,69415,69424,69445,69488,69505,69552,69572,69600, 69622,69635,69687,69745,69746,69749,69749,69763,69807,69840,69864,69891, 69926,69956,69956,69959,69959,69968,70002,70006,70006,70019,70066,70081, 70084,70106,70106,70108,70108,70144,70161,70163,70187,70207,70208,70272, 70278,70280,70280,70282,70285,70287,70301,70303,70312,70320,70366,70405, 70412,70415,70416,70419,70440,70442,70448,70450,70451,70453,70457,70461, 70461,70480,70480,70493,70497,70656,70708,70727,70730,70751,70753,70784, 70831,70852,70853,70855,70855,71040,71086,71128,71131,71168,71215,71236, 71236,71296,71338,71352,71352,71424,71450,71488,71494,71680,71723,71840, 71903,71935,71942,71945,71945,71948,71955,71957,71958,71960,71983,71999, 71999,72001,72001,72096,72103,72106,72144,72161,72161,72163,72163,72192, 72192,72203,72242,72250,72250,72272,72272,72284,72329,72349,72349,72368, 72440,72704,72712,72714,72750,72768,72768,72818,72847,72960,72966,72968, 72969,72971,73008,73030,73030,73056,73061,73063,73064,73066,73097,73112, 73112,73440,73458,73474,73474,73476,73488,73490,73523,73648,73648,73728, 74649,74752,74862,74880,75075,77712,77808,77824,78895,78913,78918,82944, 83526,92160,92728,92736,92766,92784,92862,92880,92909,92928,92975,92992, 92995,93027,93047,93053,93071,93760,93823,93952,94026,94032,94032,94099, 94111,94176,94177,94179,94179,94208,100343,100352,101589,101632,101640, 110576,110579,110581,110587,110589,110590,110592,110882,110898,110898,110928, 110930,110933,110933,110948,110951,110960,111355,113664,113770,113776,113788, 113792,113800,113808,113817,119808,119892,119894,119964,119966,119967,119970, 119970,119973,119974,119977,119980,119982,119993,119995,119995,119997,120003, 120005,120069,120071,120074,120077,120084,120086,120092,120094,120121,120123, 120126,120128,120132,120134,120134,120138,120144,120146,120485,120488,120512, 120514,120538,120540,120570,120572,120596,120598,120628,120630,120654,120656, 120686,120688,120712,120714,120744,120746,120770,120772,120779,122624,122654, 122661,122666,122928,122989,123136,123180,123191,123197,123214,123214,123536, 123565,123584,123627,124112,124139,124896,124902,124904,124907,124909,124910, 124912,124926,124928,125124,125184,125251,125259,125259,126464,126467,126469, 126495,126497,126498,126500,126500,126503,126503,126505,126514,126516,126519, 126521,126521,126523,126523,126530,126530,126535,126535,126537,126537,126539, 126539,126541,126543,126545,126546,126548,126548,126551,126551,126553,126553, 126555,126555,126557,126557,126559,126559,126561,126562,126564,126564,126567, 126570,126572,126578,126580,126583,126585,126588,126590,126590,126592,126601, 126603,126619,126625,126627,126629,126633,126635,126651,131072,173791,173824, 177977,177984,178205,178208,183969,183984,191456,191472,192093,194560,195101, 196608,201546,201552,205743,2,0,65,90,97,122,3,0,48,57,65,90,97,122,1517, 0,2,1,0,0,0,0,4,1,0,0,0,0,6,1,0,0,0,0,8,1,0,0,0,0,10,1,0,0,0,0,12,1,0,0, 0,0,14,1,0,0,0,0,16,1,0,0,0,0,18,1,0,0,0,0,20,1,0,0,0,0,22,1,0,0,0,0,28, 1,0,0,0,0,30,1,0,0,0,0,32,1,0,0,0,0,34,1,0,0,0,0,36,1,0,0,0,0,38,1,0,0, 0,0,40,1,0,0,0,0,42,1,0,0,0,0,44,1,0,0,0,0,46,1,0,0,0,0,48,1,0,0,0,0,50, 1,0,0,0,0,52,1,0,0,0,0,54,1,0,0,0,0,56,1,0,0,0,0,58,1,0,0,0,0,60,1,0,0, 0,0,62,1,0,0,0,0,64,1,0,0,0,0,66,1,0,0,0,0,68,1,0,0,0,0,70,1,0,0,0,0,72, 1,0,0,0,0,74,1,0,0,0,0,76,1,0,0,0,0,78,1,0,0,0,0,80,1,0,0,0,0,82,1,0,0, 0,0,84,1,0,0,0,0,86,1,0,0,0,0,88,1,0,0,0,0,90,1,0,0,0,0,92,1,0,0,0,0,94, 1,0,0,0,0,96,1,0,0,0,0,98,1,0,0,0,0,100,1,0,0,0,0,102,1,0,0,0,0,104,1,0, 0,0,0,106,1,0,0,0,0,108,1,0,0,0,0,110,1,0,0,0,0,112,1,0,0,0,0,114,1,0,0, 0,0,116,1,0,0,0,0,118,1,0,0,0,0,120,1,0,0,0,0,122,1,0,0,0,0,124,1,0,0,0, 0,126,1,0,0,0,0,128,1,0,0,0,0,130,1,0,0,0,0,132,1,0,0,0,0,136,1,0,0,0,0, 138,1,0,0,0,0,140,1,0,0,0,0,148,1,0,0,0,0,150,1,0,0,0,0,152,1,0,0,0,0,154, 1,0,0,0,0,156,1,0,0,0,0,158,1,0,0,0,0,162,1,0,0,0,0,164,1,0,0,0,0,166,1, 0,0,0,0,168,1,0,0,0,0,170,1,0,0,0,0,172,1,0,0,0,0,174,1,0,0,0,1,180,1,0, 0,0,1,182,1,0,0,0,1,184,1,0,0,0,1,186,1,0,0,0,1,188,1,0,0,0,1,190,1,0,0, 0,1,192,1,0,0,0,1,194,1,0,0,0,1,196,1,0,0,0,1,198,1,0,0,0,1,200,1,0,0,0, 1,202,1,0,0,0,1,204,1,0,0,0,1,206,1,0,0,0,1,208,1,0,0,0,1,210,1,0,0,0,1, 214,1,0,0,0,1,216,1,0,0,0,1,218,1,0,0,0,1,220,1,0,0,0,1,222,1,0,0,0,1,224, 1,0,0,0,1,226,1,0,0,0,2,228,1,0,0,0,4,232,1,0,0,0,6,242,1,0,0,0,8,244,1, 0,0,0,10,246,1,0,0,0,12,248,1,0,0,0,14,250,1,0,0,0,16,252,1,0,0,0,18,254, 1,0,0,0,20,263,1,0,0,0,22,265,1,0,0,0,24,267,1,0,0,0,26,270,1,0,0,0,28, 273,1,0,0,0,30,275,1,0,0,0,32,282,1,0,0,0,34,287,1,0,0,0,36,300,1,0,0,0, 38,313,1,0,0,0,40,326,1,0,0,0,42,339,1,0,0,0,44,353,1,0,0,0,46,361,1,0, 0,0,48,367,1,0,0,0,50,382,1,0,0,0,52,388,1,0,0,0,54,395,1,0,0,0,56,401, 1,0,0,0,58,415,1,0,0,0,60,420,1,0,0,0,62,428,1,0,0,0,64,441,1,0,0,0,66, 455,1,0,0,0,68,457,1,0,0,0,70,475,1,0,0,0,72,479,1,0,0,0,74,483,1,0,0,0, 76,487,1,0,0,0,78,491,1,0,0,0,80,495,1,0,0,0,82,499,1,0,0,0,84,506,1,0, 0,0,86,513,1,0,0,0,88,520,1,0,0,0,90,525,1,0,0,0,92,530,1,0,0,0,94,535, 1,0,0,0,96,540,1,0,0,0,98,543,1,0,0,0,100,547,1,0,0,0,102,560,1,0,0,0,104, 573,1,0,0,0,106,586,1,0,0,0,108,603,1,0,0,0,110,614,1,0,0,0,112,626,1,0, 0,0,114,631,1,0,0,0,116,633,1,0,0,0,118,635,1,0,0,0,120,637,1,0,0,0,122, 639,1,0,0,0,124,641,1,0,0,0,126,643,1,0,0,0,128,647,1,0,0,0,130,651,1,0, 0,0,132,653,1,0,0,0,134,655,1,0,0,0,136,657,1,0,0,0,138,660,1,0,0,0,140, 695,1,0,0,0,142,705,1,0,0,0,144,763,1,0,0,0,146,765,1,0,0,0,148,1068,1, 0,0,0,150,1084,1,0,0,0,152,1098,1,0,0,0,154,1100,1,0,0,0,156,1134,1,0,0, 0,158,1136,1,0,0,0,160,1140,1,0,0,0,162,1164,1,0,0,0,164,1211,1,0,0,0,166, 1214,1,0,0,0,168,1220,1,0,0,0,170,1225,1,0,0,0,172,1230,1,0,0,0,174,1234, 1,0,0,0,176,1238,1,0,0,0,178,1240,1,0,0,0,180,1242,1,0,0,0,182,1246,1,0, 0,0,184,1256,1,0,0,0,186,1262,1,0,0,0,188,1277,1,0,0,0,190,1283,1,0,0,0, 192,1290,1,0,0,0,194,1296,1,0,0,0,196,1298,1,0,0,0,198,1300,1,0,0,0,200, 1307,1,0,0,0,202,1309,1,0,0,0,204,1311,1,0,0,0,206,1313,1,0,0,0,208,1315, 1,0,0,0,210,1349,1,0,0,0,212,1351,1,0,0,0,214,1353,1,0,0,0,216,1361,1,0, 0,0,218,1371,1,0,0,0,220,1377,1,0,0,0,222,1382,1,0,0,0,224,1387,1,0,0,0, 226,1391,1,0,0,0,228,229,5,91,0,0,229,230,1,0,0,0,230,231,6,0,0,0,231,3, 1,0,0,0,232,233,5,92,0,0,233,234,5,108,0,0,234,235,5,98,0,0,235,236,5,114, 0,0,236,237,5,97,0,0,237,238,5,99,0,0,238,239,5,107,0,0,239,240,1,0,0,0, 240,241,6,1,0,0,241,5,1,0,0,0,242,243,5,58,0,0,243,7,1,0,0,0,244,245,5, 59,0,0,245,9,1,0,0,0,246,247,5,123,0,0,247,11,1,0,0,0,248,249,5,125,0,0, 249,13,1,0,0,0,250,251,5,40,0,0,251,15,1,0,0,0,252,253,5,41,0,0,253,17, 1,0,0,0,254,255,5,124,0,0,255,19,1,0,0,0,256,257,5,124,0,0,257,264,5,124, 0,0,258,259,5,92,0,0,259,260,5,86,0,0,260,261,5,101,0,0,261,262,5,114,0, 0,262,264,5,116,0,0,263,256,1,0,0,0,263,258,1,0,0,0,264,21,1,0,0,0,265, 266,5,95,0,0,266,23,1,0,0,0,267,268,5,95,0,0,268,269,7,0,0,0,269,25,1,0, 0,0,270,271,5,95,0,0,271,272,3,178,88,0,272,27,1,0,0,0,273,274,5,33,0,0, 274,29,1,0,0,0,275,276,5,92,0,0,276,277,5,105,0,0,277,278,5,110,0,0,278, 279,5,102,0,0,279,280,5,116,0,0,280,281,5,121,0,0,281,31,1,0,0,0,282,283, 5,92,0,0,283,284,5,105,0,0,284,285,5,110,0,0,285,286,5,116,0,0,286,33,1, 0,0,0,287,288,5,92,0,0,288,289,5,105,0,0,289,290,5,110,0,0,290,291,5,116, 0,0,291,295,1,0,0,0,292,294,7,1,0,0,293,292,1,0,0,0,294,297,1,0,0,0,295, 293,1,0,0,0,295,296,1,0,0,0,296,298,1,0,0,0,297,295,1,0,0,0,298,299,5,95, 0,0,299,35,1,0,0,0,300,301,5,92,0,0,301,302,5,105,0,0,302,303,5,110,0,0, 303,304,5,116,0,0,304,308,1,0,0,0,305,307,7,1,0,0,306,305,1,0,0,0,307,310, 1,0,0,0,308,306,1,0,0,0,308,309,1,0,0,0,309,311,1,0,0,0,310,308,1,0,0,0, 311,312,3,24,11,0,312,37,1,0,0,0,313,314,5,92,0,0,314,315,5,105,0,0,315, 316,5,110,0,0,316,317,5,116,0,0,317,321,1,0,0,0,318,320,7,1,0,0,319,318, 1,0,0,0,320,323,1,0,0,0,321,319,1,0,0,0,321,322,1,0,0,0,322,324,1,0,0,0, 323,321,1,0,0,0,324,325,3,26,12,0,325,39,1,0,0,0,326,327,5,92,0,0,327,328, 5,115,0,0,328,329,5,117,0,0,329,330,5,109,0,0,330,334,1,0,0,0,331,333,7, 1,0,0,332,331,1,0,0,0,333,336,1,0,0,0,334,332,1,0,0,0,334,335,1,0,0,0,335, 337,1,0,0,0,336,334,1,0,0,0,337,338,5,95,0,0,338,41,1,0,0,0,339,340,5,92, 0,0,340,341,5,112,0,0,341,342,5,114,0,0,342,343,5,111,0,0,343,344,5,100, 0,0,344,348,1,0,0,0,345,347,7,1,0,0,346,345,1,0,0,0,347,350,1,0,0,0,348, 346,1,0,0,0,348,349,1,0,0,0,349,351,1,0,0,0,350,348,1,0,0,0,351,352,5,95, 0,0,352,43,1,0,0,0,353,354,5,92,0,0,354,355,5,109,0,0,355,356,5,97,0,0, 356,357,5,116,0,0,357,358,5,104,0,0,358,359,5,114,0,0,359,360,5,109,0,0, 360,45,1,0,0,0,361,362,5,92,0,0,362,363,5,102,0,0,363,364,5,114,0,0,364, 365,5,97,0,0,365,366,5,99,0,0,366,47,1,0,0,0,367,368,5,92,0,0,368,369,5, 102,0,0,369,370,5,114,0,0,370,371,5,97,0,0,371,372,5,99,0,0,372,376,1,0, 0,0,373,375,7,1,0,0,374,373,1,0,0,0,375,378,1,0,0,0,376,374,1,0,0,0,376, 377,1,0,0,0,377,379,1,0,0,0,378,376,1,0,0,0,379,380,7,0,0,0,380,381,7,0, 0,0,381,49,1,0,0,0,382,383,5,92,0,0,383,384,5,99,0,0,384,385,5,100,0,0, 385,386,5,111,0,0,386,387,5,116,0,0,387,51,1,0,0,0,388,389,5,92,0,0,389, 390,5,116,0,0,390,391,5,105,0,0,391,392,5,109,0,0,392,393,5,101,0,0,393, 394,5,115,0,0,394,53,1,0,0,0,395,396,5,92,0,0,396,397,5,115,0,0,397,398, 5,113,0,0,398,399,5,114,0,0,399,400,5,116,0,0,400,55,1,0,0,0,401,402,5, 92,0,0,402,403,5,115,0,0,403,404,5,113,0,0,404,405,5,114,0,0,405,406,5, 116,0,0,406,410,1,0,0,0,407,409,7,1,0,0,408,407,1,0,0,0,409,412,1,0,0,0, 410,408,1,0,0,0,410,411,1,0,0,0,411,413,1,0,0,0,412,410,1,0,0,0,413,414, 7,0,0,0,414,57,1,0,0,0,415,416,5,92,0,0,416,417,5,115,0,0,417,418,5,105, 0,0,418,419,5,109,0,0,419,59,1,0,0,0,420,421,5,92,0,0,421,422,5,97,0,0, 422,423,5,112,0,0,423,424,5,112,0,0,424,425,5,114,0,0,425,426,5,111,0,0, 426,427,5,120,0,0,427,61,1,0,0,0,428,429,5,92,0,0,429,430,5,112,0,0,430, 431,5,108,0,0,431,432,5,97,0,0,432,433,5,99,0,0,433,434,5,101,0,0,434,435, 5,104,0,0,435,436,5,111,0,0,436,437,5,108,0,0,437,438,5,100,0,0,438,439, 5,101,0,0,439,440,5,114,0,0,440,63,1,0,0,0,441,442,5,94,0,0,442,443,5,123, 0,0,443,444,5,92,0,0,444,445,5,109,0,0,445,446,5,97,0,0,446,447,5,116,0, 0,447,448,5,104,0,0,448,449,5,114,0,0,449,450,5,109,0,0,450,451,5,123,0, 0,451,452,5,84,0,0,452,453,5,125,0,0,453,454,5,125,0,0,454,65,1,0,0,0,455, 456,5,92,0,0,456,67,1,0,0,0,457,458,5,97,0,0,458,459,5,115,0,0,459,463, 1,0,0,0,460,464,5,32,0,0,461,462,5,92,0,0,462,464,5,58,0,0,463,460,1,0, 0,0,463,461,1,0,0,0,464,465,1,0,0,0,465,463,1,0,0,0,465,466,1,0,0,0,466, 467,1,0,0,0,467,468,5,108,0,0,468,469,5,105,0,0,469,470,5,110,0,0,470,471, 5,101,0,0,471,473,1,0,0,0,472,474,7,2,0,0,473,472,1,0,0,0,473,474,1,0,0, 0,474,69,1,0,0,0,475,476,5,115,0,0,476,477,5,105,0,0,477,478,5,110,0,0, 478,71,1,0,0,0,479,480,5,99,0,0,480,481,5,111,0,0,481,482,5,115,0,0,482, 73,1,0,0,0,483,484,5,116,0,0,484,485,5,97,0,0,485,486,5,110,0,0,486,75, 1,0,0,0,487,488,5,99,0,0,488,489,5,111,0,0,489,490,5,116,0,0,490,77,1,0, 0,0,491,492,5,115,0,0,492,493,5,101,0,0,493,494,5,99,0,0,494,79,1,0,0,0, 495,496,5,99,0,0,496,497,5,115,0,0,497,498,5,99,0,0,498,81,1,0,0,0,499, 500,5,97,0,0,500,501,5,114,0,0,501,502,5,99,0,0,502,503,5,115,0,0,503,504, 5,105,0,0,504,505,5,110,0,0,505,83,1,0,0,0,506,507,5,97,0,0,507,508,5,114, 0,0,508,509,5,99,0,0,509,510,5,99,0,0,510,511,5,111,0,0,511,512,5,115,0, 0,512,85,1,0,0,0,513,514,5,97,0,0,514,515,5,114,0,0,515,516,5,99,0,0,516, 517,5,116,0,0,517,518,5,97,0,0,518,519,5,110,0,0,519,87,1,0,0,0,520,521, 5,115,0,0,521,522,5,105,0,0,522,523,5,110,0,0,523,524,5,104,0,0,524,89, 1,0,0,0,525,526,5,99,0,0,526,527,5,111,0,0,527,528,5,115,0,0,528,529,5, 104,0,0,529,91,1,0,0,0,530,531,5,116,0,0,531,532,5,97,0,0,532,533,5,110, 0,0,533,534,5,104,0,0,534,93,1,0,0,0,535,536,5,99,0,0,536,537,5,111,0,0, 537,538,5,116,0,0,538,539,5,104,0,0,539,95,1,0,0,0,540,541,5,108,0,0,541, 542,5,110,0,0,542,97,1,0,0,0,543,544,5,108,0,0,544,545,5,111,0,0,545,546, 5,103,0,0,546,99,1,0,0,0,547,548,5,92,0,0,548,549,5,108,0,0,549,550,5,111, 0,0,550,551,5,103,0,0,551,555,1,0,0,0,552,554,7,1,0,0,553,552,1,0,0,0,554, 557,1,0,0,0,555,553,1,0,0,0,555,556,1,0,0,0,556,558,1,0,0,0,557,555,1,0, 0,0,558,559,5,95,0,0,559,101,1,0,0,0,560,561,5,92,0,0,561,562,5,108,0,0, 562,563,5,111,0,0,563,564,5,103,0,0,564,568,1,0,0,0,565,567,7,1,0,0,566, 565,1,0,0,0,567,570,1,0,0,0,568,566,1,0,0,0,568,569,1,0,0,0,569,571,1,0, 0,0,570,568,1,0,0,0,571,572,3,24,11,0,572,103,1,0,0,0,573,574,5,92,0,0, 574,575,5,108,0,0,575,576,5,111,0,0,576,577,5,103,0,0,577,581,1,0,0,0,578, 580,7,1,0,0,579,578,1,0,0,0,580,583,1,0,0,0,581,579,1,0,0,0,581,582,1,0, 0,0,582,584,1,0,0,0,583,581,1,0,0,0,584,585,3,26,12,0,585,105,1,0,0,0,586, 587,5,92,0,0,587,588,5,116,0,0,588,589,5,101,0,0,589,590,5,120,0,0,590, 591,5,116,0,0,591,592,5,123,0,0,592,596,1,0,0,0,593,595,9,0,0,0,594,593, 1,0,0,0,595,598,1,0,0,0,596,597,1,0,0,0,596,594,1,0,0,0,597,599,1,0,0,0, 598,596,1,0,0,0,599,600,5,125,0,0,600,601,1,0,0,0,601,602,6,52,1,0,602, 107,1,0,0,0,603,604,5,92,0,0,604,605,5,108,0,0,605,606,5,101,0,0,606,607, 5,102,0,0,607,608,5,116,0,0,608,610,1,0,0,0,609,611,5,46,0,0,610,609,1, 0,0,0,610,611,1,0,0,0,611,612,1,0,0,0,612,613,6,53,1,0,613,109,1,0,0,0, 614,615,5,92,0,0,615,616,5,114,0,0,616,617,5,105,0,0,617,618,5,103,0,0, 618,619,5,104,0,0,619,620,5,116,0,0,620,622,1,0,0,0,621,623,5,46,0,0,622, 621,1,0,0,0,622,623,1,0,0,0,623,624,1,0,0,0,624,625,6,54,1,0,625,111,1, 0,0,0,626,627,5,36,0,0,627,628,5,36,0,0,628,629,1,0,0,0,629,630,6,55,1, 0,630,113,1,0,0,0,631,632,5,43,0,0,632,115,1,0,0,0,633,634,5,45,0,0,634, 117,1,0,0,0,635,636,5,94,0,0,636,119,1,0,0,0,637,638,5,61,0,0,638,121,1, 0,0,0,639,640,5,60,0,0,640,123,1,0,0,0,641,642,5,62,0,0,642,125,1,0,0,0, 643,644,5,92,0,0,644,645,5,108,0,0,645,646,5,101,0,0,646,127,1,0,0,0,647, 648,5,92,0,0,648,649,5,103,0,0,649,650,5,101,0,0,650,129,1,0,0,0,651,652, 5,44,0,0,652,131,1,0,0,0,653,654,5,46,0,0,654,133,1,0,0,0,655,656,7,0,0, 0,656,135,1,0,0,0,657,658,5,94,0,0,658,659,3,134,66,0,659,137,1,0,0,0,660, 661,5,94,0,0,661,662,3,178,88,0,662,139,1,0,0,0,663,665,3,134,66,0,664, 663,1,0,0,0,665,666,1,0,0,0,666,664,1,0,0,0,666,667,1,0,0,0,667,668,1,0, 0,0,668,672,5,46,0,0,669,671,3,134,66,0,670,669,1,0,0,0,671,674,1,0,0,0, 672,670,1,0,0,0,672,673,1,0,0,0,673,676,1,0,0,0,674,672,1,0,0,0,675,677, 3,144,71,0,676,675,1,0,0,0,676,677,1,0,0,0,677,696,1,0,0,0,678,680,5,46, 0,0,679,681,3,134,66,0,680,679,1,0,0,0,681,682,1,0,0,0,682,680,1,0,0,0, 682,683,1,0,0,0,683,685,1,0,0,0,684,686,3,144,71,0,685,684,1,0,0,0,685, 686,1,0,0,0,686,696,1,0,0,0,687,689,3,134,66,0,688,687,1,0,0,0,689,690, 1,0,0,0,690,688,1,0,0,0,690,691,1,0,0,0,691,693,1,0,0,0,692,694,3,144,71, 0,693,692,1,0,0,0,693,694,1,0,0,0,694,696,1,0,0,0,695,664,1,0,0,0,695,678, 1,0,0,0,695,688,1,0,0,0,696,141,1,0,0,0,697,706,3,178,88,0,698,702,3,146, 72,0,699,701,7,1,0,0,700,699,1,0,0,0,701,704,1,0,0,0,702,700,1,0,0,0,702, 703,1,0,0,0,703,706,1,0,0,0,704,702,1,0,0,0,705,697,1,0,0,0,705,698,1,0, 0,0,706,717,1,0,0,0,707,716,3,176,87,0,708,712,3,146,72,0,709,711,7,1,0, 0,710,709,1,0,0,0,711,714,1,0,0,0,712,710,1,0,0,0,712,713,1,0,0,0,713,716, 1,0,0,0,714,712,1,0,0,0,715,707,1,0,0,0,715,708,1,0,0,0,716,719,1,0,0,0, 717,715,1,0,0,0,717,718,1,0,0,0,718,143,1,0,0,0,719,717,1,0,0,0,720,722, 7,3,0,0,721,723,7,4,0,0,722,721,1,0,0,0,722,723,1,0,0,0,723,725,1,0,0,0, 724,726,3,134,66,0,725,724,1,0,0,0,726,727,1,0,0,0,727,725,1,0,0,0,727, 728,1,0,0,0,728,764,1,0,0,0,729,731,5,32,0,0,730,729,1,0,0,0,731,734,1, 0,0,0,732,730,1,0,0,0,732,733,1,0,0,0,733,737,1,0,0,0,734,732,1,0,0,0,735, 738,3,50,24,0,736,738,3,52,25,0,737,735,1,0,0,0,737,736,1,0,0,0,738,742, 1,0,0,0,739,741,5,32,0,0,740,739,1,0,0,0,741,744,1,0,0,0,742,740,1,0,0, 0,742,743,1,0,0,0,743,745,1,0,0,0,744,742,1,0,0,0,745,746,5,49,0,0,746, 747,5,48,0,0,747,748,1,0,0,0,748,761,3,118,58,0,749,762,3,134,66,0,750, 752,3,10,4,0,751,753,7,4,0,0,752,751,1,0,0,0,752,753,1,0,0,0,753,755,1, 0,0,0,754,756,3,134,66,0,755,754,1,0,0,0,756,757,1,0,0,0,757,755,1,0,0, 0,757,758,1,0,0,0,758,759,1,0,0,0,759,760,3,12,5,0,760,762,1,0,0,0,761, 749,1,0,0,0,761,750,1,0,0,0,762,764,1,0,0,0,763,720,1,0,0,0,763,732,1,0, 0,0,764,145,1,0,0,0,765,1066,5,92,0,0,766,767,5,101,0,0,767,768,5,108,0, 0,768,1067,5,108,0,0,769,770,5,104,0,0,770,771,5,98,0,0,771,772,5,97,0, 0,772,1067,5,114,0,0,773,774,5,97,0,0,774,775,5,108,0,0,775,776,5,112,0, 0,776,777,5,104,0,0,777,1067,5,97,0,0,778,779,5,98,0,0,779,780,5,101,0, 0,780,781,5,116,0,0,781,1067,5,97,0,0,782,783,5,103,0,0,783,784,5,97,0, 0,784,785,5,109,0,0,785,786,5,109,0,0,786,1067,5,97,0,0,787,788,5,100,0, 0,788,789,5,101,0,0,789,790,5,108,0,0,790,791,5,116,0,0,791,1067,5,97,0, 0,792,793,5,101,0,0,793,794,5,112,0,0,794,795,5,115,0,0,795,796,5,105,0, 0,796,797,5,108,0,0,797,798,5,111,0,0,798,1067,5,110,0,0,799,800,5,118, 0,0,800,801,5,97,0,0,801,802,5,114,0,0,802,803,5,101,0,0,803,804,5,112, 0,0,804,805,5,115,0,0,805,806,5,105,0,0,806,807,5,108,0,0,807,808,5,111, 0,0,808,1067,5,110,0,0,809,810,5,122,0,0,810,811,5,101,0,0,811,812,5,116, 0,0,812,1067,5,97,0,0,813,814,5,101,0,0,814,815,5,116,0,0,815,1067,5,97, 0,0,816,817,5,116,0,0,817,818,5,104,0,0,818,819,5,101,0,0,819,820,5,116, 0,0,820,1067,5,97,0,0,821,822,5,118,0,0,822,823,5,97,0,0,823,824,5,114, 0,0,824,825,5,116,0,0,825,826,5,104,0,0,826,827,5,101,0,0,827,828,5,116, 0,0,828,1067,5,97,0,0,829,830,5,105,0,0,830,831,5,111,0,0,831,832,5,116, 0,0,832,1067,5,97,0,0,833,834,5,107,0,0,834,835,5,97,0,0,835,836,5,112, 0,0,836,837,5,112,0,0,837,1067,5,97,0,0,838,839,5,118,0,0,839,840,5,97, 0,0,840,841,5,114,0,0,841,842,5,107,0,0,842,843,5,97,0,0,843,844,5,112, 0,0,844,845,5,112,0,0,845,1067,5,97,0,0,846,847,5,108,0,0,847,848,5,97, 0,0,848,849,5,109,0,0,849,850,5,98,0,0,850,851,5,100,0,0,851,1067,5,97, 0,0,852,853,5,109,0,0,853,1067,5,117,0,0,854,855,5,110,0,0,855,1067,5,117, 0,0,856,857,5,120,0,0,857,1067,5,105,0,0,858,859,5,111,0,0,859,860,5,109, 0,0,860,861,5,105,0,0,861,862,5,99,0,0,862,863,5,114,0,0,863,864,5,111, 0,0,864,1067,5,110,0,0,865,866,5,112,0,0,866,1067,5,105,0,0,867,868,5,118, 0,0,868,869,5,97,0,0,869,870,5,114,0,0,870,871,5,112,0,0,871,1067,5,105, 0,0,872,873,5,114,0,0,873,874,5,104,0,0,874,1067,5,111,0,0,875,876,5,118, 0,0,876,877,5,97,0,0,877,878,5,114,0,0,878,879,5,114,0,0,879,880,5,104, 0,0,880,1067,5,111,0,0,881,882,5,115,0,0,882,883,5,105,0,0,883,884,5,103, 0,0,884,885,5,109,0,0,885,1067,5,97,0,0,886,887,5,118,0,0,887,888,5,97, 0,0,888,889,5,114,0,0,889,890,5,115,0,0,890,891,5,105,0,0,891,892,5,103, 0,0,892,893,5,109,0,0,893,1067,5,97,0,0,894,895,5,116,0,0,895,896,5,97, 0,0,896,1067,5,117,0,0,897,898,5,112,0,0,898,899,5,104,0,0,899,1067,5,105, 0,0,900,901,5,118,0,0,901,902,5,97,0,0,902,903,5,114,0,0,903,904,5,112, 0,0,904,905,5,104,0,0,905,1067,5,105,0,0,906,907,5,117,0,0,907,908,5,112, 0,0,908,909,5,115,0,0,909,910,5,105,0,0,910,911,5,108,0,0,911,912,5,111, 0,0,912,1067,5,110,0,0,913,914,5,99,0,0,914,915,5,104,0,0,915,1067,5,105, 0,0,916,917,5,112,0,0,917,918,5,115,0,0,918,1067,5,105,0,0,919,920,5,111, 0,0,920,921,5,109,0,0,921,922,5,101,0,0,922,923,5,103,0,0,923,1067,5,97, 0,0,924,925,5,71,0,0,925,926,5,97,0,0,926,927,5,109,0,0,927,928,5,109,0, 0,928,1067,5,97,0,0,929,930,5,68,0,0,930,931,5,101,0,0,931,932,5,108,0, 0,932,933,5,116,0,0,933,1067,5,97,0,0,934,935,5,84,0,0,935,936,5,104,0, 0,936,937,5,101,0,0,937,938,5,116,0,0,938,1067,5,97,0,0,939,940,5,76,0, 0,940,941,5,97,0,0,941,942,5,109,0,0,942,943,5,98,0,0,943,944,5,100,0,0, 944,1067,5,97,0,0,945,946,5,88,0,0,946,1067,5,105,0,0,947,948,5,80,0,0, 948,1067,5,105,0,0,949,950,5,83,0,0,950,951,5,105,0,0,951,952,5,103,0,0, 952,953,5,109,0,0,953,1067,5,97,0,0,954,955,5,85,0,0,955,956,5,112,0,0, 956,957,5,115,0,0,957,958,5,105,0,0,958,959,5,108,0,0,959,960,5,111,0,0, 960,1067,5,110,0,0,961,962,5,80,0,0,962,963,5,104,0,0,963,1067,5,105,0, 0,964,965,5,80,0,0,965,966,5,115,0,0,966,1067,5,105,0,0,967,968,5,79,0, 0,968,969,5,109,0,0,969,970,5,101,0,0,970,971,5,103,0,0,971,1067,5,97,0, 0,972,973,5,100,0,0,973,974,5,105,0,0,974,975,5,103,0,0,975,976,5,97,0, 0,976,977,5,109,0,0,977,978,5,109,0,0,978,1067,5,97,0,0,979,980,5,118,0, 0,980,981,5,97,0,0,981,982,5,114,0,0,982,983,5,107,0,0,983,984,5,97,0,0, 984,985,5,112,0,0,985,986,5,112,0,0,986,1067,5,97,0,0,987,988,5,99,0,0, 988,989,5,111,0,0,989,990,5,112,0,0,990,991,5,112,0,0,991,1067,5,97,0,0, 992,993,5,107,0,0,993,994,5,111,0,0,994,995,5,112,0,0,995,996,5,112,0,0, 996,1067,5,97,0,0,997,998,5,67,0,0,998,999,5,111,0,0,999,1000,5,112,0,0, 1000,1001,5,112,0,0,1001,1067,5,97,0,0,1002,1003,5,75,0,0,1003,1004,5,111, 0,0,1004,1005,5,112,0,0,1005,1006,5,112,0,0,1006,1067,5,97,0,0,1007,1008, 5,115,0,0,1008,1009,5,97,0,0,1009,1010,5,109,0,0,1010,1011,5,112,0,0,1011, 1067,5,105,0,0,1012,1013,5,83,0,0,1013,1014,5,97,0,0,1014,1015,5,109,0, 0,1015,1016,5,112,0,0,1016,1067,5,105,0,0,1017,1018,5,119,0,0,1018,1067, 5,112,0,0,1019,1020,5,97,0,0,1020,1021,5,108,0,0,1021,1022,5,101,0,0,1022, 1023,5,112,0,0,1023,1067,5,104,0,0,1024,1025,5,104,0,0,1025,1026,5,115, 0,0,1026,1027,5,108,0,0,1027,1028,5,97,0,0,1028,1029,5,115,0,0,1029,1067, 5,104,0,0,1030,1031,5,70,0,0,1031,1032,5,105,0,0,1032,1033,5,110,0,0,1033, 1067,5,118,0,0,1034,1035,5,101,0,0,1035,1036,5,116,0,0,1036,1067,5,104, 0,0,1037,1038,5,66,0,0,1038,1039,5,98,0,0,1039,1040,5,98,0,0,1040,1067, 5,107,0,0,1041,1042,5,98,0,0,1042,1043,5,101,0,0,1043,1044,5,116,0,0,1044, 1067,5,104,0,0,1045,1046,5,100,0,0,1046,1047,5,97,0,0,1047,1048,5,108,0, 0,1048,1049,5,101,0,0,1049,1050,5,116,0,0,1050,1067,5,104,0,0,1051,1052, 5,103,0,0,1052,1053,5,105,0,0,1053,1054,5,109,0,0,1054,1055,5,101,0,0,1055, 1067,5,108,0,0,1056,1057,5,105,0,0,1057,1058,5,109,0,0,1058,1059,5,97,0, 0,1059,1060,5,116,0,0,1060,1067,5,104,0,0,1061,1062,5,106,0,0,1062,1063, 5,109,0,0,1063,1064,5,97,0,0,1064,1065,5,116,0,0,1065,1067,5,104,0,0,1066, 766,1,0,0,0,1066,769,1,0,0,0,1066,773,1,0,0,0,1066,778,1,0,0,0,1066,782, 1,0,0,0,1066,787,1,0,0,0,1066,792,1,0,0,0,1066,799,1,0,0,0,1066,809,1,0, 0,0,1066,813,1,0,0,0,1066,816,1,0,0,0,1066,821,1,0,0,0,1066,829,1,0,0,0, 1066,833,1,0,0,0,1066,838,1,0,0,0,1066,846,1,0,0,0,1066,852,1,0,0,0,1066, 854,1,0,0,0,1066,856,1,0,0,0,1066,858,1,0,0,0,1066,865,1,0,0,0,1066,867, 1,0,0,0,1066,872,1,0,0,0,1066,875,1,0,0,0,1066,881,1,0,0,0,1066,886,1,0, 0,0,1066,894,1,0,0,0,1066,897,1,0,0,0,1066,900,1,0,0,0,1066,906,1,0,0,0, 1066,913,1,0,0,0,1066,916,1,0,0,0,1066,919,1,0,0,0,1066,924,1,0,0,0,1066, 929,1,0,0,0,1066,934,1,0,0,0,1066,939,1,0,0,0,1066,945,1,0,0,0,1066,947, 1,0,0,0,1066,949,1,0,0,0,1066,954,1,0,0,0,1066,961,1,0,0,0,1066,964,1,0, 0,0,1066,967,1,0,0,0,1066,972,1,0,0,0,1066,979,1,0,0,0,1066,987,1,0,0,0, 1066,992,1,0,0,0,1066,997,1,0,0,0,1066,1002,1,0,0,0,1066,1007,1,0,0,0,1066, 1012,1,0,0,0,1066,1017,1,0,0,0,1066,1019,1,0,0,0,1066,1024,1,0,0,0,1066, 1030,1,0,0,0,1066,1034,1,0,0,0,1066,1037,1,0,0,0,1066,1041,1,0,0,0,1066, 1045,1,0,0,0,1066,1051,1,0,0,0,1066,1056,1,0,0,0,1066,1061,1,0,0,0,1067, 147,1,0,0,0,1068,1069,5,92,0,0,1069,1070,5,98,0,0,1070,1071,5,101,0,0,1071, 1072,5,103,0,0,1072,1073,5,105,0,0,1073,1074,5,110,0,0,1074,1075,5,123, 0,0,1075,1076,5,98,0,0,1076,1077,5,109,0,0,1077,1078,5,97,0,0,1078,1079, 5,116,0,0,1079,1080,5,114,0,0,1080,1081,5,105,0,0,1081,1082,5,120,0,0,1082, 1083,5,125,0,0,1083,149,1,0,0,0,1084,1085,5,92,0,0,1085,1086,5,101,0,0, 1086,1087,5,110,0,0,1087,1088,5,100,0,0,1088,1089,5,123,0,0,1089,1090,5, 98,0,0,1090,1091,5,109,0,0,1091,1092,5,97,0,0,1092,1093,5,116,0,0,1093, 1094,5,114,0,0,1094,1095,5,105,0,0,1095,1096,5,120,0,0,1096,1097,5,125, 0,0,1097,151,1,0,0,0,1098,1099,5,38,0,0,1099,153,1,0,0,0,1100,1101,5,92, 0,0,1101,1102,5,92,0,0,1102,155,1,0,0,0,1103,1105,7,1,0,0,1104,1103,1,0, 0,0,1105,1108,1,0,0,0,1106,1104,1,0,0,0,1106,1107,1,0,0,0,1107,1109,1,0, 0,0,1108,1106,1,0,0,0,1109,1110,5,95,0,0,1110,1111,5,123,0,0,1111,1120, 1,0,0,0,1112,1121,3,176,87,0,1113,1117,3,146,72,0,1114,1116,7,1,0,0,1115, 1114,1,0,0,0,1116,1119,1,0,0,0,1117,1115,1,0,0,0,1117,1118,1,0,0,0,1118, 1121,1,0,0,0,1119,1117,1,0,0,0,1120,1112,1,0,0,0,1120,1113,1,0,0,0,1121, 1122,1,0,0,0,1122,1120,1,0,0,0,1122,1123,1,0,0,0,1123,1124,1,0,0,0,1124, 1125,5,125,0,0,1125,1135,1,0,0,0,1126,1128,7,1,0,0,1127,1126,1,0,0,0,1128, 1131,1,0,0,0,1129,1127,1,0,0,0,1129,1130,1,0,0,0,1130,1132,1,0,0,0,1131, 1129,1,0,0,0,1132,1133,5,95,0,0,1133,1135,3,176,87,0,1134,1106,1,0,0,0, 1134,1129,1,0,0,0,1135,157,1,0,0,0,1136,1137,5,94,0,0,1137,1138,3,178,88, 0,1138,1139,3,156,77,0,1139,159,1,0,0,0,1140,1162,5,92,0,0,1141,1142,5, 104,0,0,1142,1143,5,97,0,0,1143,1163,5,116,0,0,1144,1145,5,98,0,0,1145, 1146,5,97,0,0,1146,1163,5,114,0,0,1147,1148,5,118,0,0,1148,1149,5,101,0, 0,1149,1163,5,99,0,0,1150,1151,5,100,0,0,1151,1152,5,111,0,0,1152,1163, 5,116,0,0,1153,1154,5,100,0,0,1154,1155,5,100,0,0,1155,1156,5,111,0,0,1156, 1163,5,116,0,0,1157,1158,5,100,0,0,1158,1159,5,100,0,0,1159,1160,5,100, 0,0,1160,1161,5,111,0,0,1161,1163,5,116,0,0,1162,1141,1,0,0,0,1162,1144, 1,0,0,0,1162,1147,1,0,0,0,1162,1150,1,0,0,0,1162,1153,1,0,0,0,1162,1157, 1,0,0,0,1163,161,1,0,0,0,1164,1165,3,118,58,0,1165,1179,3,10,4,0,1166,1167, 5,92,0,0,1167,1168,5,112,0,0,1168,1169,5,114,0,0,1169,1170,5,105,0,0,1170, 1171,5,109,0,0,1171,1172,5,101,0,0,1172,1176,1,0,0,0,1173,1175,7,1,0,0, 1174,1173,1,0,0,0,1175,1178,1,0,0,0,1176,1174,1,0,0,0,1176,1177,1,0,0,0, 1177,1180,1,0,0,0,1178,1176,1,0,0,0,1179,1166,1,0,0,0,1180,1181,1,0,0,0, 1181,1179,1,0,0,0,1181,1182,1,0,0,0,1182,1183,1,0,0,0,1183,1184,3,12,5, 0,1184,163,1,0,0,0,1185,1187,3,142,70,0,1186,1188,3,156,77,0,1187,1186, 1,0,0,0,1187,1188,1,0,0,0,1188,1212,1,0,0,0,1189,1190,3,142,70,0,1190,1192, 3,162,80,0,1191,1193,3,156,77,0,1192,1191,1,0,0,0,1192,1193,1,0,0,0,1193, 1212,1,0,0,0,1194,1195,3,142,70,0,1195,1196,3,156,77,0,1196,1197,3,162, 80,0,1197,1212,1,0,0,0,1198,1199,3,160,79,0,1199,1200,3,10,4,0,1200,1201, 3,142,70,0,1201,1203,3,12,5,0,1202,1204,3,156,77,0,1203,1202,1,0,0,0,1203, 1204,1,0,0,0,1204,1212,1,0,0,0,1205,1206,3,160,79,0,1206,1207,3,10,4,0, 1207,1208,3,142,70,0,1208,1209,3,156,77,0,1209,1210,3,12,5,0,1210,1212, 1,0,0,0,1211,1185,1,0,0,0,1211,1189,1,0,0,0,1211,1194,1,0,0,0,1211,1198, 1,0,0,0,1211,1205,1,0,0,0,1212,165,1,0,0,0,1213,1215,7,5,0,0,1214,1213, 1,0,0,0,1215,1216,1,0,0,0,1216,1214,1,0,0,0,1216,1217,1,0,0,0,1217,1218, 1,0,0,0,1218,1219,6,82,1,0,1219,167,1,0,0,0,1220,1221,5,92,0,0,1221,1222, 5,32,0,0,1222,1223,1,0,0,0,1223,1224,6,83,1,0,1224,169,1,0,0,0,1225,1226, 5,92,0,0,1226,1227,5,58,0,0,1227,1228,1,0,0,0,1228,1229,6,84,1,0,1229,171, 1,0,0,0,1230,1231,5,160,0,0,1231,1232,1,0,0,0,1232,1233,6,85,1,0,1233,173, 1,0,0,0,1234,1235,9,0,0,0,1235,175,1,0,0,0,1236,1239,3,178,88,0,1237,1239, 7,6,0,0,1238,1236,1,0,0,0,1238,1237,1,0,0,0,1239,177,1,0,0,0,1240,1241, 7,7,0,0,1241,179,1,0,0,0,1242,1243,5,93,0,0,1243,1244,1,0,0,0,1244,1245, 6,89,2,0,1245,181,1,0,0,0,1246,1247,5,92,0,0,1247,1248,5,114,0,0,1248,1249, 5,98,0,0,1249,1250,5,114,0,0,1250,1251,5,97,0,0,1251,1252,5,99,0,0,1252, 1253,5,107,0,0,1253,1254,1,0,0,0,1254,1255,6,90,2,0,1255,183,1,0,0,0,1256, 1257,5,92,0,0,1257,1258,5,102,0,0,1258,1259,5,114,0,0,1259,1260,5,97,0, 0,1260,1261,5,99,0,0,1261,185,1,0,0,0,1262,1263,5,92,0,0,1263,1264,5,102, 0,0,1264,1265,5,114,0,0,1265,1266,5,97,0,0,1266,1267,5,99,0,0,1267,1271, 1,0,0,0,1268,1270,7,1,0,0,1269,1268,1,0,0,0,1270,1273,1,0,0,0,1271,1269, 1,0,0,0,1271,1272,1,0,0,0,1272,1274,1,0,0,0,1273,1271,1,0,0,0,1274,1275, 7,0,0,0,1275,1276,7,0,0,0,1276,187,1,0,0,0,1277,1278,5,92,0,0,1278,1279, 5,99,0,0,1279,1280,5,100,0,0,1280,1281,5,111,0,0,1281,1282,5,116,0,0,1282, 189,1,0,0,0,1283,1284,5,92,0,0,1284,1285,5,116,0,0,1285,1286,5,105,0,0, 1286,1287,5,109,0,0,1287,1288,5,101,0,0,1288,1289,5,115,0,0,1289,191,1, 0,0,0,1290,1291,5,92,0,0,1291,1292,5,115,0,0,1292,1293,5,113,0,0,1293,1294, 5,114,0,0,1294,1295,5,116,0,0,1295,193,1,0,0,0,1296,1297,5,44,0,0,1297, 195,1,0,0,0,1298,1299,5,94,0,0,1299,197,1,0,0,0,1300,1304,7,8,0,0,1301, 1303,7,9,0,0,1302,1301,1,0,0,0,1303,1306,1,0,0,0,1304,1302,1,0,0,0,1304, 1305,1,0,0,0,1305,199,1,0,0,0,1306,1304,1,0,0,0,1307,1308,5,40,0,0,1308, 201,1,0,0,0,1309,1310,5,41,0,0,1310,203,1,0,0,0,1311,1312,5,123,0,0,1312, 205,1,0,0,0,1313,1314,5,125,0,0,1314,207,1,0,0,0,1315,1316,5,49,0,0,1316, 209,1,0,0,0,1317,1319,5,45,0,0,1318,1317,1,0,0,0,1318,1319,1,0,0,0,1319, 1321,1,0,0,0,1320,1322,3,212,105,0,1321,1320,1,0,0,0,1322,1323,1,0,0,0, 1323,1321,1,0,0,0,1323,1324,1,0,0,0,1324,1325,1,0,0,0,1325,1329,5,46,0, 0,1326,1328,3,212,105,0,1327,1326,1,0,0,0,1328,1331,1,0,0,0,1329,1327,1, 0,0,0,1329,1330,1,0,0,0,1330,1350,1,0,0,0,1331,1329,1,0,0,0,1332,1334,5, 45,0,0,1333,1332,1,0,0,0,1333,1334,1,0,0,0,1334,1335,1,0,0,0,1335,1337, 5,46,0,0,1336,1338,3,212,105,0,1337,1336,1,0,0,0,1338,1339,1,0,0,0,1339, 1337,1,0,0,0,1339,1340,1,0,0,0,1340,1350,1,0,0,0,1341,1343,5,45,0,0,1342, 1341,1,0,0,0,1342,1343,1,0,0,0,1343,1345,1,0,0,0,1344,1346,3,212,105,0, 1345,1344,1,0,0,0,1346,1347,1,0,0,0,1347,1345,1,0,0,0,1347,1348,1,0,0,0, 1348,1350,1,0,0,0,1349,1318,1,0,0,0,1349,1333,1,0,0,0,1349,1342,1,0,0,0, 1350,211,1,0,0,0,1351,1352,7,0,0,0,1352,213,1,0,0,0,1353,1354,5,92,0,0, 1354,1355,5,108,0,0,1355,1356,5,101,0,0,1356,1357,5,102,0,0,1357,1358,5, 116,0,0,1358,1359,1,0,0,0,1359,1360,6,106,1,0,1360,215,1,0,0,0,1361,1362, 5,92,0,0,1362,1363,5,114,0,0,1363,1364,5,105,0,0,1364,1365,5,103,0,0,1365, 1366,5,104,0,0,1366,1367,5,116,0,0,1367,1368,1,0,0,0,1368,1369,6,107,1, 0,1369,217,1,0,0,0,1370,1372,7,5,0,0,1371,1370,1,0,0,0,1372,1373,1,0,0, 0,1373,1371,1,0,0,0,1373,1374,1,0,0,0,1374,1375,1,0,0,0,1375,1376,6,108, 1,0,1376,219,1,0,0,0,1377,1378,5,92,0,0,1378,1379,5,32,0,0,1379,1380,1, 0,0,0,1380,1381,6,109,1,0,1381,221,1,0,0,0,1382,1383,5,92,0,0,1383,1384, 5,58,0,0,1384,1385,1,0,0,0,1385,1386,6,110,1,0,1386,223,1,0,0,0,1387,1388, 5,160,0,0,1388,1389,1,0,0,0,1389,1390,6,111,1,0,1390,225,1,0,0,0,1391,1392, 9,0,0,0,1392,227,1,0,0,0,68,0,1,263,295,308,321,334,348,376,410,463,465, 473,555,568,581,596,610,622,666,672,676,682,685,690,693,695,702,705,712, 715,717,722,727,732,737,742,752,757,761,763,1066,1106,1117,1120,1122,1129, 1134,1162,1176,1181,1187,1192,1203,1211,1216,1238,1271,1304,1318,1323,1329, 1333,1339,1342,1347,1349,1373,3,2,1,0,6,0,0,2,0,0]; private static __ATN: ATN; public static get _ATN(): ATN { if (!LatexLexer.__ATN) { LatexLexer.__ATN = new ATNDeserializer().deserialize(LatexLexer._serializedATN); } return LatexLexer.__ATN; } static DecisionsToDFA = LatexLexer._ATN.decisionToState.map( (ds: DecisionState, index: number) => new DFA(ds, index) ); } ================================================ FILE: src/parser/LatexParser.g4 ================================================ parser grammar LatexParser; options { tokenVocab=LatexLexer; } statement: (fix_mixed_id | assign | assign_list | assign_plus_query | query | equality | u_block | number | id | id_list | guess | guess_list | expr | condition | piecewise_assign | insert_matrix | scatter_plot_query | parametric_plot_query | code_func_def )? EOF; scatter_plot_query: (( L_PAREN expr COMMA expr R_PAREN ) | ( expr COMMA expr )) AS_LINES? EQ (( L_PAREN u_block COMMA u_block R_PAREN ) | ( u_block COMMA u_block ))?; parametric_plot_query: ( L_PAREN expr COMMA expr R_PAREN ) for_id=ID L_PAREN argument R_PAREN (points_id_0=ID num_points=number points_id_1=ID)? EQ (( L_PAREN u_block COMMA u_block R_PAREN ) | ( u_block COMMA u_block ))?; insert_matrix: .*? (u_insert_matrix .*?)+; fix_mixed_id: .*? ( ( (CMD_MATHRM L_BRACE id R_BRACE (id | PRIME_ACCENT)) | (id CMD_MATHRM L_BRACE id R_BRACE) ) .*?)+; unit_matrix_row: u_block (AMPERSAND u_block)*; code_cell_units: u_block | BEGIN_MATRIX unit_matrix_row (DOUBLE_BACKSLASH unit_matrix_row)* END_MATRIX; code_func_def: (CMD_MATHRM L_BRACE id R_BRACE | id) L_PAREN (input_units+=code_cell_units (COMMA input_units+=code_cell_units)*) R_PAREN EQ output_units=code_cell_units; id: ID ; number: SUB? NUMBER ; number_with_units: (number | id) u_block; assign: id EQ expr ; // recognize PI here so that error can be generated for assigning to pi assign_list: assign (COMMA assign)+; assign_plus_query: assign EQ (u_block)?; query: expr EQ (u_block)? ; equality: expr EQ expr ; piecewise_assign: id EQ id L_PAREN ( piecewise_arg (COMMA piecewise_arg)*) R_PAREN ; piecewise_arg: L_PAREN expr COMMA condition R_PAREN; trig_function: BACKSLASH? (CMD_SIN | CMD_COS | CMD_TAN | CMD_COT | CMD_SEC | CMD_CSC | CMD_ARCSIN | CMD_ARCCOS | CMD_ARCTAN | CMD_SINH | CMD_COSH | CMD_TANH | CMD_COTH) L_PAREN expr R_PAREN ; indefinite_integral_cmd: (CMD_INT | (CMD_INT_UNDERSCORE L_BRACE R_BRACE CARET L_BRACE R_BRACE)) L_PAREN expr R_PAREN (CMD_MATHRM L_BRACE id R_BRACE | id) L_PAREN id R_PAREN ; integral_cmd: ((CMD_INT_UNDERSCORE L_BRACE lower_lim_expr=expr R_BRACE) | (CMD_INT_UNDERSCORE_SINGLE_CHAR_NUMBER | CMD_INT_UNDERSCORE_SINGLE_CHAR_ID)) ((CARET L_BRACE upper_lim_expr=expr R_BRACE) | (CARET_SINGLE_CHAR_ID | CARET_SINGLE_CHAR_NUMBER)) L_PAREN integrand_expr=expr R_PAREN (CMD_MATHRM L_BRACE id R_BRACE | id) L_PAREN id R_PAREN ; sum_prod_cmd: ((CMD_SUM_UNDERSCORE | CMD_PROD_UNDERSCORE) L_BRACE id EQ start_expr=expr R_BRACE) ((CARET L_BRACE end_expr=expr R_BRACE) | (CARET_SINGLE_CHAR_ID | CARET_SINGLE_CHAR_NUMBER)) L_PAREN operand_expr=expr R_PAREN ; derivative_cmd: CMD_FRAC L_BRACE (MATHRM_0=CMD_MATHRM L_BRACE id R_BRACE | id) R_BRACE L_BRACE (MATHRM_1=CMD_MATHRM L_BRACE id R_BRACE | id) L_PAREN id R_PAREN R_BRACE L_PAREN expr R_PAREN; n_derivative_cmd: CMD_FRAC L_BRACE (MATHRM_0=CMD_MATHRM L_BRACE id R_BRACE | id) ((CARET L_BRACE exp1=number R_BRACE) | single_char_exp1=CARET_SINGLE_CHAR_NUMBER) R_BRACE L_BRACE (MATHRM_1=CMD_MATHRM L_BRACE id R_BRACE | id) L_PAREN id R_PAREN ((CARET L_BRACE exp2=number R_BRACE) | single_char_exp2=CARET_SINGLE_CHAR_NUMBER) R_BRACE L_PAREN expr R_PAREN; argument: (id EQ expr) | (expr lower=(LT | LTE) id upper=(LT | LTE) expr); condition: condition_single | condition_chain; id_list: id (COMMA id)+; guess: id (CMD_SIM | CMD_APPROX) (number | number_with_units) ; guess_list: guess (COMMA guess)+; condition_single: expr operator=(LT | LTE | GT | GTE ) expr; condition_chain: expr lower=(LT | LTE | GT | GTE ) expr upper=(LT | LTE | GT | GTE ) expr; matrix_row: expr (AMPERSAND expr)*; user_function: id L_PAREN (argument (COMMA argument)*) R_PAREN (points_id_0=ID num_points=number points_id_1=ID)? ; builtin_function: (CMD_MATHRM L_BRACE id R_BRACE | id) L_PAREN (expr (COMMA expr)*)? R_PAREN; index: direct=expr | (start=expr? COLON stop=expr?) | (start=expr? COLON stride=expr COLON stop=expr?) ; expr: id CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT #exponent | id (CARET_SINGLE_CHAR_ID | CARET_SINGLE_CHAR_NUMBER) UNDERSCORE_SUBSCRIPT #exponent | id CARET L_BRACE expr R_BRACE UNDERSCORE_SUBSCRIPT #exponent | expr (CARET_SINGLE_CHAR_ID | CARET_SINGLE_CHAR_NUMBER) #exponent | expr CARET L_BRACE expr R_BRACE #exponent | expr UNDERSCORE L_BRACE row=index COMMA col=index R_BRACE #matrixIndex | expr TRANSPOSE #transpose | expr EXCLAMATION #factorial | CMD_SQRT_INT #singleIntSqrt | CMD_SQRT L_BRACE expr R_BRACE #sqrt | BEGIN_MATRIX matrix_row (DOUBLE_BACKSLASH matrix_row)* END_MATRIX #matrix | trig_function #trigFunction | indefinite_integral_cmd #indefiniteIntegral | integral_cmd #integral | derivative_cmd #derivative | n_derivative_cmd #nDerivative | sum_prod_cmd #sumProd | BACKSLASH? CMD_LN L_PAREN expr R_PAREN #ln | BACKSLASH? CMD_LOG L_PAREN expr R_PAREN #log | CMD_SLASH_LOG_UNDERSCORE L_BRACE expr R_BRACE L_PAREN expr R_PAREN #baseLog | (CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_ID | CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_NUMBER) L_PAREN expr R_PAREN #baseLogSingleChar | DOUBLE_VBAR expr DOUBLE_VBAR #norm | VBAR expr VBAR #abs | number_with_units #numberWithUnitsExpr | number #numberExpr | SUB expr #unaryMinus | expr CMD_TIMES expr #matrixMultiply | expr CMD_CDOT expr #multiply | CMD_FRAC L_BRACE expr R_BRACE L_BRACE expr R_BRACE #divide | CMD_FRAC_INTS #divideInts | expr SUB expr #subtract | expr ADD expr #add | id #variable | user_function #userFunction | builtin_function #builtinFunction | INFINITY #infinityExpr | L_PAREN expr R_PAREN #subExpr | expr UNDERSCORE L_BRACE R_BRACE #emptySubscript | expr CARET L_BRACE R_BRACE #emptySuperscript | expr id #missingMultiplication | expr number #missingMultiplication | expr number_with_units #missingMultiplication | number expr #missingMultiplication | number_with_units expr #missingMultiplication | expr user_function #missingMultiplication | expr builtin_function #missingMultiplication | expr trig_function #missingMultiplication | expr indefinite_integral_cmd #missingMultiplication | expr integral_cmd #missingMultiplication | expr derivative_cmd #missingMultiplication | expr n_derivative_cmd #missingMultiplication | CMD_PLACEHOLDER (L_BRACE R_BRACE)? #emptyPlaceholder | (CMD_MATHRM L_BRACE expr R_BRACE)? (DECIMAL_POINT | number | EQ)? CMD_MATHRM L_BRACE expr R_BRACE (DECIMAL_POINT | number | EQ)? #removeOperatorFont ; u_block: (L_BRACKET | ALT_L_BRACKET) u_expr (R_BRACKET | ALT_R_BRACKET); u_insert_matrix: (L_BRACKET | ALT_L_BRACKET) numRows=(U_NUMBER | U_ONE) (U_COMMA | U_CMD_TIMES) numColumns=(U_NUMBER | U_ONE) (R_BRACKET | ALT_R_BRACKET) ; u_fraction: U_CMD_FRAC U_L_BRACE (U_NUMBER | U_ONE) U_R_BRACE U_L_BRACE U_NUMBER U_R_BRACE | U_CMD_FRAC_INTS; u_expr: u_expr U_CARET U_NUMBER #unitExponent | u_expr U_CARET U_L_BRACE U_NUMBER U_R_BRACE #unitExponent | u_expr U_CARET u_fraction #unitFractionalExponent | u_expr U_CARET U_L_BRACE u_fraction U_R_BRACE #unitFractionalExponent | U_CMD_SQRT U_L_BRACE expr U_R_BRACE #unitSqrt | u_expr U_CMD_CDOT u_expr #unitMultiply | U_CMD_FRAC U_L_BRACE (u_expr | U_ONE) U_R_BRACE U_L_BRACE u_expr U_R_BRACE #unitDivide | U_NAME #unitName | U_L_PAREN u_expr U_R_PAREN #unitSubExpr ; ================================================ FILE: src/parser/LatexParser.ts ================================================ // @ts-nocheck // Generated from LatexParser.g4 by ANTLR 4.12.0 // noinspection ES6UnusedImports,JSUnusedGlobalSymbols,JSUnusedLocalSymbols import { ATN, ATNDeserializer, DecisionState, DFA, FailedPredicateException, RecognitionException, NoViableAltException, BailErrorStrategy, Parser, ParserATNSimulator, RuleContext, ParserRuleContext, PredictionMode, PredictionContextCache, TerminalNode, RuleNode, Token, TokenStream, Interval, IntervalSet } from 'antlr4'; import LatexParserVisitor from "./LatexParserVisitor.js"; // for running tests with parameters, TODO: discuss strategy for typed parameters in CI // eslint-disable-next-line no-unused-vars type int = number; export default class LatexParser extends Parser { public static readonly L_BRACKET = 1; public static readonly ALT_L_BRACKET = 2; public static readonly COLON = 3; public static readonly SEMICOLON = 4; public static readonly L_BRACE = 5; public static readonly R_BRACE = 6; public static readonly L_PAREN = 7; public static readonly R_PAREN = 8; public static readonly VBAR = 9; public static readonly DOUBLE_VBAR = 10; public static readonly UNDERSCORE = 11; public static readonly EXCLAMATION = 12; public static readonly INFINITY = 13; public static readonly CMD_INT = 14; public static readonly CMD_INT_UNDERSCORE = 15; public static readonly CMD_INT_UNDERSCORE_SINGLE_CHAR_NUMBER = 16; public static readonly CMD_INT_UNDERSCORE_SINGLE_CHAR_ID = 17; public static readonly CMD_SUM_UNDERSCORE = 18; public static readonly CMD_PROD_UNDERSCORE = 19; public static readonly CMD_MATHRM = 20; public static readonly CMD_FRAC = 21; public static readonly CMD_FRAC_INTS = 22; public static readonly CMD_CDOT = 23; public static readonly CMD_TIMES = 24; public static readonly CMD_SQRT = 25; public static readonly CMD_SQRT_INT = 26; public static readonly CMD_SIM = 27; public static readonly CMD_APPROX = 28; public static readonly CMD_PLACEHOLDER = 29; public static readonly TRANSPOSE = 30; public static readonly BACKSLASH = 31; public static readonly AS_LINES = 32; public static readonly CMD_SIN = 33; public static readonly CMD_COS = 34; public static readonly CMD_TAN = 35; public static readonly CMD_COT = 36; public static readonly CMD_SEC = 37; public static readonly CMD_CSC = 38; public static readonly CMD_ARCSIN = 39; public static readonly CMD_ARCCOS = 40; public static readonly CMD_ARCTAN = 41; public static readonly CMD_SINH = 42; public static readonly CMD_COSH = 43; public static readonly CMD_TANH = 44; public static readonly CMD_COTH = 45; public static readonly CMD_LN = 46; public static readonly CMD_LOG = 47; public static readonly CMD_SLASH_LOG_UNDERSCORE = 48; public static readonly CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_NUMBER = 49; public static readonly CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_ID = 50; public static readonly COMMENT = 51; public static readonly CMD_LEFT = 52; public static readonly CMD_RIGHT = 53; public static readonly DOUBLE_DOLLAR_SIGN = 54; public static readonly ADD = 55; public static readonly SUB = 56; public static readonly CARET = 57; public static readonly EQ = 58; public static readonly LT = 59; public static readonly GT = 60; public static readonly LTE = 61; public static readonly GTE = 62; public static readonly COMMA = 63; public static readonly DECIMAL_POINT = 64; public static readonly CARET_SINGLE_CHAR_NUMBER = 65; public static readonly CARET_SINGLE_CHAR_ID = 66; public static readonly NUMBER = 67; public static readonly BEGIN_MATRIX = 68; public static readonly END_MATRIX = 69; public static readonly AMPERSAND = 70; public static readonly DOUBLE_BACKSLASH = 71; public static readonly UNDERSCORE_SUBSCRIPT = 72; public static readonly CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT = 73; public static readonly PRIME_ACCENT = 74; public static readonly ID = 75; public static readonly WS = 76; public static readonly SLASH_SPACE = 77; public static readonly SLASH_COLON = 78; public static readonly NBSP = 79; public static readonly ERROR_CHAR = 80; public static readonly R_BRACKET = 81; public static readonly ALT_R_BRACKET = 82; public static readonly U_CMD_FRAC = 83; public static readonly U_CMD_FRAC_INTS = 84; public static readonly U_CMD_CDOT = 85; public static readonly U_CMD_TIMES = 86; public static readonly U_CMD_SQRT = 87; public static readonly U_COMMA = 88; public static readonly U_CARET = 89; public static readonly U_NAME = 90; public static readonly U_L_PAREN = 91; public static readonly U_R_PAREN = 92; public static readonly U_L_BRACE = 93; public static readonly U_R_BRACE = 94; public static readonly U_ONE = 95; public static readonly U_NUMBER = 96; public static readonly U_CMD_LEFT = 97; public static readonly U_CMD_RIGHT = 98; public static readonly U_WS = 99; public static readonly U_SLASH_SPACE = 100; public static readonly U_SLASH_COLON = 101; public static readonly U_NBSP = 102; public static readonly U_ERROR_CHAR = 103; public static readonly EOF = Token.EOF; public static readonly RULE_statement = 0; public static readonly RULE_scatter_plot_query = 1; public static readonly RULE_parametric_plot_query = 2; public static readonly RULE_insert_matrix = 3; public static readonly RULE_fix_mixed_id = 4; public static readonly RULE_unit_matrix_row = 5; public static readonly RULE_code_cell_units = 6; public static readonly RULE_code_func_def = 7; public static readonly RULE_id = 8; public static readonly RULE_number = 9; public static readonly RULE_number_with_units = 10; public static readonly RULE_assign = 11; public static readonly RULE_assign_list = 12; public static readonly RULE_assign_plus_query = 13; public static readonly RULE_query = 14; public static readonly RULE_equality = 15; public static readonly RULE_piecewise_assign = 16; public static readonly RULE_piecewise_arg = 17; public static readonly RULE_trig_function = 18; public static readonly RULE_indefinite_integral_cmd = 19; public static readonly RULE_integral_cmd = 20; public static readonly RULE_sum_prod_cmd = 21; public static readonly RULE_derivative_cmd = 22; public static readonly RULE_n_derivative_cmd = 23; public static readonly RULE_argument = 24; public static readonly RULE_condition = 25; public static readonly RULE_id_list = 26; public static readonly RULE_guess = 27; public static readonly RULE_guess_list = 28; public static readonly RULE_condition_single = 29; public static readonly RULE_condition_chain = 30; public static readonly RULE_matrix_row = 31; public static readonly RULE_user_function = 32; public static readonly RULE_builtin_function = 33; public static readonly RULE_index = 34; public static readonly RULE_expr = 35; public static readonly RULE_u_block = 36; public static readonly RULE_u_insert_matrix = 37; public static readonly RULE_u_fraction = 38; public static readonly RULE_u_expr = 39; public static readonly literalNames: (string | null)[] = [ null, "'['", "'\\lbrack'", "':'", "';'", null, null, null, null, "'|'", null, "'_'", "'!'", "'\\infty'", "'\\int'", null, null, null, null, null, "'\\mathrm'", null, null, null, null, null, null, "'\\sim'", "'\\approx'", "'\\placeholder'", "'^{\\mathrm{T}}'", "'\\'", null, "'sin'", "'cos'", "'tan'", "'cot'", "'sec'", "'csc'", "'arcsin'", "'arccos'", "'arctan'", "'sinh'", "'cosh'", "'tanh'", "'coth'", "'ln'", "'log'", null, null, null, null, null, null, "'$$'", "'+'", "'-'", null, "'='", "'<'", "'>'", "'\\le'", "'\\ge'", null, "'.'", null, null, null, "'\\begin{bmatrix}'", "'\\end{bmatrix}'", "'&'", "'\\\\'", null, null, null, null, null, null, null, null, null, "']'", "'\\rbrack'", null, null, null, null, null, null, null, null, null, null, null, null, "'1'", null, "'\\left'", "'\\right'" ]; public static readonly symbolicNames: (string | null)[] = [ null, "L_BRACKET", "ALT_L_BRACKET", "COLON", "SEMICOLON", "L_BRACE", "R_BRACE", "L_PAREN", "R_PAREN", "VBAR", "DOUBLE_VBAR", "UNDERSCORE", "EXCLAMATION", "INFINITY", "CMD_INT", "CMD_INT_UNDERSCORE", "CMD_INT_UNDERSCORE_SINGLE_CHAR_NUMBER", "CMD_INT_UNDERSCORE_SINGLE_CHAR_ID", "CMD_SUM_UNDERSCORE", "CMD_PROD_UNDERSCORE", "CMD_MATHRM", "CMD_FRAC", "CMD_FRAC_INTS", "CMD_CDOT", "CMD_TIMES", "CMD_SQRT", "CMD_SQRT_INT", "CMD_SIM", "CMD_APPROX", "CMD_PLACEHOLDER", "TRANSPOSE", "BACKSLASH", "AS_LINES", "CMD_SIN", "CMD_COS", "CMD_TAN", "CMD_COT", "CMD_SEC", "CMD_CSC", "CMD_ARCSIN", "CMD_ARCCOS", "CMD_ARCTAN", "CMD_SINH", "CMD_COSH", "CMD_TANH", "CMD_COTH", "CMD_LN", "CMD_LOG", "CMD_SLASH_LOG_UNDERSCORE", "CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_NUMBER", "CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_ID", "COMMENT", "CMD_LEFT", "CMD_RIGHT", "DOUBLE_DOLLAR_SIGN", "ADD", "SUB", "CARET", "EQ", "LT", "GT", "LTE", "GTE", "COMMA", "DECIMAL_POINT", "CARET_SINGLE_CHAR_NUMBER", "CARET_SINGLE_CHAR_ID", "NUMBER", "BEGIN_MATRIX", "END_MATRIX", "AMPERSAND", "DOUBLE_BACKSLASH", "UNDERSCORE_SUBSCRIPT", "CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT", "PRIME_ACCENT", "ID", "WS", "SLASH_SPACE", "SLASH_COLON", "NBSP", "ERROR_CHAR", "R_BRACKET", "ALT_R_BRACKET", "U_CMD_FRAC", "U_CMD_FRAC_INTS", "U_CMD_CDOT", "U_CMD_TIMES", "U_CMD_SQRT", "U_COMMA", "U_CARET", "U_NAME", "U_L_PAREN", "U_R_PAREN", "U_L_BRACE", "U_R_BRACE", "U_ONE", "U_NUMBER", "U_CMD_LEFT", "U_CMD_RIGHT", "U_WS", "U_SLASH_SPACE", "U_SLASH_COLON", "U_NBSP", "U_ERROR_CHAR" ]; // tslint:disable:no-trailing-whitespace public static readonly ruleNames: string[] = [ "statement", "scatter_plot_query", "parametric_plot_query", "insert_matrix", "fix_mixed_id", "unit_matrix_row", "code_cell_units", "code_func_def", "id", "number", "number_with_units", "assign", "assign_list", "assign_plus_query", "query", "equality", "piecewise_assign", "piecewise_arg", "trig_function", "indefinite_integral_cmd", "integral_cmd", "sum_prod_cmd", "derivative_cmd", "n_derivative_cmd", "argument", "condition", "id_list", "guess", "guess_list", "condition_single", "condition_chain", "matrix_row", "user_function", "builtin_function", "index", "expr", "u_block", "u_insert_matrix", "u_fraction", "u_expr", ]; public get grammarFileName(): string { return "LatexParser.g4"; } public get literalNames(): (string | null)[] { return LatexParser.literalNames; } public get symbolicNames(): (string | null)[] { return LatexParser.symbolicNames; } public get ruleNames(): string[] { return LatexParser.ruleNames; } public get serializedATN(): number[] { return LatexParser._serializedATN; } protected createFailedPredicateException(predicate?: string, message?: string): FailedPredicateException { return new FailedPredicateException(this, predicate, message); } constructor(input: TokenStream) { super(input); this._interp = new ParserATNSimulator(this, LatexParser._ATN, LatexParser.DecisionsToDFA, new PredictionContextCache()); } // @RuleVersion(0) public statement(): StatementContext { let localctx: StatementContext = new StatementContext(this, this._ctx, this.state); this.enterRule(localctx, 0, LatexParser.RULE_statement); try { this.enterOuterAlt(localctx, 1); { this.state = 99; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 0, this._ctx) ) { case 1: { this.state = 80; this.fix_mixed_id(); } break; case 2: { this.state = 81; this.assign(); } break; case 3: { this.state = 82; this.assign_list(); } break; case 4: { this.state = 83; this.assign_plus_query(); } break; case 5: { this.state = 84; this.query(); } break; case 6: { this.state = 85; this.equality(); } break; case 7: { this.state = 86; this.u_block(); } break; case 8: { this.state = 87; this.number_(); } break; case 9: { this.state = 88; this.id(); } break; case 10: { this.state = 89; this.id_list(); } break; case 11: { this.state = 90; this.guess(); } break; case 12: { this.state = 91; this.guess_list(); } break; case 13: { this.state = 92; this.expr(0); } break; case 14: { this.state = 93; this.condition(); } break; case 15: { this.state = 94; this.piecewise_assign(); } break; case 16: { this.state = 95; this.insert_matrix(); } break; case 17: { this.state = 96; this.scatter_plot_query(); } break; case 18: { this.state = 97; this.parametric_plot_query(); } break; case 19: { this.state = 98; this.code_func_def(); } break; } this.state = 101; this.match(LatexParser.EOF); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public scatter_plot_query(): Scatter_plot_queryContext { let localctx: Scatter_plot_queryContext = new Scatter_plot_queryContext(this, this._ctx, this.state); this.enterRule(localctx, 2, LatexParser.RULE_scatter_plot_query); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 113; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 1, this._ctx) ) { case 1: { { this.state = 103; this.match(LatexParser.L_PAREN); this.state = 104; this.expr(0); this.state = 105; this.match(LatexParser.COMMA); this.state = 106; this.expr(0); this.state = 107; this.match(LatexParser.R_PAREN); } } break; case 2: { { this.state = 109; this.expr(0); this.state = 110; this.match(LatexParser.COMMA); this.state = 111; this.expr(0); } } break; } this.state = 116; this._errHandler.sync(this); _la = this._input.LA(1); if (_la===32) { { this.state = 115; this.match(LatexParser.AS_LINES); } } this.state = 118; this.match(LatexParser.EQ); this.state = 129; this._errHandler.sync(this); switch (this._input.LA(1)) { case 7: { { this.state = 119; this.match(LatexParser.L_PAREN); this.state = 120; this.u_block(); this.state = 121; this.match(LatexParser.COMMA); this.state = 122; this.u_block(); this.state = 123; this.match(LatexParser.R_PAREN); } } break; case 1: case 2: { { this.state = 125; this.u_block(); this.state = 126; this.match(LatexParser.COMMA); this.state = 127; this.u_block(); } } break; case -1: break; default: break; } } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public parametric_plot_query(): Parametric_plot_queryContext { let localctx: Parametric_plot_queryContext = new Parametric_plot_queryContext(this, this._ctx, this.state); this.enterRule(localctx, 4, LatexParser.RULE_parametric_plot_query); let _la: number; try { this.enterOuterAlt(localctx, 1); { { this.state = 131; this.match(LatexParser.L_PAREN); this.state = 132; this.expr(0); this.state = 133; this.match(LatexParser.COMMA); this.state = 134; this.expr(0); this.state = 135; this.match(LatexParser.R_PAREN); } this.state = 137; localctx._for_id = this.match(LatexParser.ID); this.state = 138; this.match(LatexParser.L_PAREN); this.state = 139; this.argument(); this.state = 140; this.match(LatexParser.R_PAREN); this.state = 145; this._errHandler.sync(this); _la = this._input.LA(1); if (_la===75) { { this.state = 141; localctx._points_id_0 = this.match(LatexParser.ID); this.state = 142; localctx._num_points = this.number_(); this.state = 143; localctx._points_id_1 = this.match(LatexParser.ID); } } this.state = 147; this.match(LatexParser.EQ); this.state = 158; this._errHandler.sync(this); switch (this._input.LA(1)) { case 7: { { this.state = 148; this.match(LatexParser.L_PAREN); this.state = 149; this.u_block(); this.state = 150; this.match(LatexParser.COMMA); this.state = 151; this.u_block(); this.state = 152; this.match(LatexParser.R_PAREN); } } break; case 1: case 2: { { this.state = 154; this.u_block(); this.state = 155; this.match(LatexParser.COMMA); this.state = 156; this.u_block(); } } break; case -1: break; default: break; } } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public insert_matrix(): Insert_matrixContext { let localctx: Insert_matrixContext = new Insert_matrixContext(this, this._ctx, this.state); this.enterRule(localctx, 6, LatexParser.RULE_insert_matrix); let _la: number; try { let _alt: number; this.enterOuterAlt(localctx, 1); { this.state = 163; this._errHandler.sync(this); _alt = this._interp.adaptivePredict(this._input, 6, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 160; this.matchWildcard(); } } } this.state = 165; this._errHandler.sync(this); _alt = this._interp.adaptivePredict(this._input, 6, this._ctx); } this.state = 173; this._errHandler.sync(this); _la = this._input.LA(1); do { { { this.state = 166; this.u_insert_matrix(); this.state = 170; this._errHandler.sync(this); _alt = this._interp.adaptivePredict(this._input, 7, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 167; this.matchWildcard(); } } } this.state = 172; this._errHandler.sync(this); _alt = this._interp.adaptivePredict(this._input, 7, this._ctx); } } } this.state = 175; this._errHandler.sync(this); _la = this._input.LA(1); } while (_la===1 || _la===2); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public fix_mixed_id(): Fix_mixed_idContext { let localctx: Fix_mixed_idContext = new Fix_mixed_idContext(this, this._ctx, this.state); this.enterRule(localctx, 8, LatexParser.RULE_fix_mixed_id); let _la: number; try { let _alt: number; this.enterOuterAlt(localctx, 1); { this.state = 180; this._errHandler.sync(this); _alt = this._interp.adaptivePredict(this._input, 9, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 177; this.matchWildcard(); } } } this.state = 182; this._errHandler.sync(this); _alt = this._interp.adaptivePredict(this._input, 9, this._ctx); } this.state = 205; this._errHandler.sync(this); _la = this._input.LA(1); do { { { this.state = 197; this._errHandler.sync(this); switch (this._input.LA(1)) { case 20: { { this.state = 183; this.match(LatexParser.CMD_MATHRM); this.state = 184; this.match(LatexParser.L_BRACE); this.state = 185; this.id(); this.state = 186; this.match(LatexParser.R_BRACE); this.state = 189; this._errHandler.sync(this); switch (this._input.LA(1)) { case 75: { this.state = 187; this.id(); } break; case 74: { this.state = 188; this.match(LatexParser.PRIME_ACCENT); } break; default: throw new NoViableAltException(this); } } } break; case 75: { { this.state = 191; this.id(); this.state = 192; this.match(LatexParser.CMD_MATHRM); this.state = 193; this.match(LatexParser.L_BRACE); this.state = 194; this.id(); this.state = 195; this.match(LatexParser.R_BRACE); } } break; default: throw new NoViableAltException(this); } this.state = 202; this._errHandler.sync(this); _alt = this._interp.adaptivePredict(this._input, 12, this._ctx); while (_alt !== 1 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1 + 1) { { { this.state = 199; this.matchWildcard(); } } } this.state = 204; this._errHandler.sync(this); _alt = this._interp.adaptivePredict(this._input, 12, this._ctx); } } } this.state = 207; this._errHandler.sync(this); _la = this._input.LA(1); } while (_la===20 || _la===75); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public unit_matrix_row(): Unit_matrix_rowContext { let localctx: Unit_matrix_rowContext = new Unit_matrix_rowContext(this, this._ctx, this.state); this.enterRule(localctx, 10, LatexParser.RULE_unit_matrix_row); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 209; this.u_block(); this.state = 214; this._errHandler.sync(this); _la = this._input.LA(1); while (_la===70) { { { this.state = 210; this.match(LatexParser.AMPERSAND); this.state = 211; this.u_block(); } } this.state = 216; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public code_cell_units(): Code_cell_unitsContext { let localctx: Code_cell_unitsContext = new Code_cell_unitsContext(this, this._ctx, this.state); this.enterRule(localctx, 12, LatexParser.RULE_code_cell_units); let _la: number; try { this.state = 229; this._errHandler.sync(this); switch (this._input.LA(1)) { case 1: case 2: this.enterOuterAlt(localctx, 1); { this.state = 217; this.u_block(); } break; case 68: this.enterOuterAlt(localctx, 2); { this.state = 218; this.match(LatexParser.BEGIN_MATRIX); this.state = 219; this.unit_matrix_row(); this.state = 224; this._errHandler.sync(this); _la = this._input.LA(1); while (_la===71) { { { this.state = 220; this.match(LatexParser.DOUBLE_BACKSLASH); this.state = 221; this.unit_matrix_row(); } } this.state = 226; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 227; this.match(LatexParser.END_MATRIX); } break; default: throw new NoViableAltException(this); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public code_func_def(): Code_func_defContext { let localctx: Code_func_defContext = new Code_func_defContext(this, this._ctx, this.state); this.enterRule(localctx, 14, LatexParser.RULE_code_func_def); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 237; this._errHandler.sync(this); switch (this._input.LA(1)) { case 20: { this.state = 231; this.match(LatexParser.CMD_MATHRM); this.state = 232; this.match(LatexParser.L_BRACE); this.state = 233; this.id(); this.state = 234; this.match(LatexParser.R_BRACE); } break; case 75: { this.state = 236; this.id(); } break; default: throw new NoViableAltException(this); } this.state = 239; this.match(LatexParser.L_PAREN); { this.state = 240; localctx._code_cell_units = this.code_cell_units(); localctx._input_units.push(localctx._code_cell_units); this.state = 245; this._errHandler.sync(this); _la = this._input.LA(1); while (_la===63) { { { this.state = 241; this.match(LatexParser.COMMA); this.state = 242; localctx._code_cell_units = this.code_cell_units(); localctx._input_units.push(localctx._code_cell_units); } } this.state = 247; this._errHandler.sync(this); _la = this._input.LA(1); } } this.state = 248; this.match(LatexParser.R_PAREN); this.state = 249; this.match(LatexParser.EQ); this.state = 250; localctx._output_units = this.code_cell_units(); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public id(): IdContext { let localctx: IdContext = new IdContext(this, this._ctx, this.state); this.enterRule(localctx, 16, LatexParser.RULE_id); try { this.enterOuterAlt(localctx, 1); { this.state = 252; this.match(LatexParser.ID); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public number_(): NumberContext { let localctx: NumberContext = new NumberContext(this, this._ctx, this.state); this.enterRule(localctx, 18, LatexParser.RULE_number); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 255; this._errHandler.sync(this); _la = this._input.LA(1); if (_la===56) { { this.state = 254; this.match(LatexParser.SUB); } } this.state = 257; this.match(LatexParser.NUMBER); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public number_with_units(): Number_with_unitsContext { let localctx: Number_with_unitsContext = new Number_with_unitsContext(this, this._ctx, this.state); this.enterRule(localctx, 20, LatexParser.RULE_number_with_units); try { this.enterOuterAlt(localctx, 1); { this.state = 261; this._errHandler.sync(this); switch (this._input.LA(1)) { case 56: case 67: { this.state = 259; this.number_(); } break; case 75: { this.state = 260; this.id(); } break; default: throw new NoViableAltException(this); } this.state = 263; this.u_block(); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public assign(): AssignContext { let localctx: AssignContext = new AssignContext(this, this._ctx, this.state); this.enterRule(localctx, 22, LatexParser.RULE_assign); try { this.enterOuterAlt(localctx, 1); { this.state = 265; this.id(); this.state = 266; this.match(LatexParser.EQ); this.state = 267; this.expr(0); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public assign_list(): Assign_listContext { let localctx: Assign_listContext = new Assign_listContext(this, this._ctx, this.state); this.enterRule(localctx, 24, LatexParser.RULE_assign_list); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 269; this.assign(); this.state = 272; this._errHandler.sync(this); _la = this._input.LA(1); do { { { this.state = 270; this.match(LatexParser.COMMA); this.state = 271; this.assign(); } } this.state = 274; this._errHandler.sync(this); _la = this._input.LA(1); } while (_la===63); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public assign_plus_query(): Assign_plus_queryContext { let localctx: Assign_plus_queryContext = new Assign_plus_queryContext(this, this._ctx, this.state); this.enterRule(localctx, 26, LatexParser.RULE_assign_plus_query); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 276; this.assign(); this.state = 277; this.match(LatexParser.EQ); this.state = 279; this._errHandler.sync(this); _la = this._input.LA(1); if (_la===1 || _la===2) { { this.state = 278; this.u_block(); } } } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public query(): QueryContext { let localctx: QueryContext = new QueryContext(this, this._ctx, this.state); this.enterRule(localctx, 28, LatexParser.RULE_query); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 281; this.expr(0); this.state = 282; this.match(LatexParser.EQ); this.state = 284; this._errHandler.sync(this); _la = this._input.LA(1); if (_la===1 || _la===2) { { this.state = 283; this.u_block(); } } } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public equality(): EqualityContext { let localctx: EqualityContext = new EqualityContext(this, this._ctx, this.state); this.enterRule(localctx, 30, LatexParser.RULE_equality); try { this.enterOuterAlt(localctx, 1); { this.state = 286; this.expr(0); this.state = 287; this.match(LatexParser.EQ); this.state = 288; this.expr(0); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public piecewise_assign(): Piecewise_assignContext { let localctx: Piecewise_assignContext = new Piecewise_assignContext(this, this._ctx, this.state); this.enterRule(localctx, 32, LatexParser.RULE_piecewise_assign); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 290; this.id(); this.state = 291; this.match(LatexParser.EQ); this.state = 292; this.id(); this.state = 293; this.match(LatexParser.L_PAREN); { this.state = 294; this.piecewise_arg(); this.state = 299; this._errHandler.sync(this); _la = this._input.LA(1); while (_la===63) { { { this.state = 295; this.match(LatexParser.COMMA); this.state = 296; this.piecewise_arg(); } } this.state = 301; this._errHandler.sync(this); _la = this._input.LA(1); } } this.state = 302; this.match(LatexParser.R_PAREN); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public piecewise_arg(): Piecewise_argContext { let localctx: Piecewise_argContext = new Piecewise_argContext(this, this._ctx, this.state); this.enterRule(localctx, 34, LatexParser.RULE_piecewise_arg); try { this.enterOuterAlt(localctx, 1); { this.state = 304; this.match(LatexParser.L_PAREN); this.state = 305; this.expr(0); this.state = 306; this.match(LatexParser.COMMA); this.state = 307; this.condition(); this.state = 308; this.match(LatexParser.R_PAREN); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public trig_function(): Trig_functionContext { let localctx: Trig_functionContext = new Trig_functionContext(this, this._ctx, this.state); this.enterRule(localctx, 36, LatexParser.RULE_trig_function); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 311; this._errHandler.sync(this); _la = this._input.LA(1); if (_la===31) { { this.state = 310; this.match(LatexParser.BACKSLASH); } } this.state = 313; _la = this._input.LA(1); if(!(((((_la - 33)) & ~0x1F) === 0 && ((1 << (_la - 33)) & 8191) !== 0))) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 314; this.match(LatexParser.L_PAREN); this.state = 315; this.expr(0); this.state = 316; this.match(LatexParser.R_PAREN); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public indefinite_integral_cmd(): Indefinite_integral_cmdContext { let localctx: Indefinite_integral_cmdContext = new Indefinite_integral_cmdContext(this, this._ctx, this.state); this.enterRule(localctx, 38, LatexParser.RULE_indefinite_integral_cmd); try { this.enterOuterAlt(localctx, 1); { this.state = 325; this._errHandler.sync(this); switch (this._input.LA(1)) { case 14: { this.state = 318; this.match(LatexParser.CMD_INT); } break; case 15: { { this.state = 319; this.match(LatexParser.CMD_INT_UNDERSCORE); this.state = 320; this.match(LatexParser.L_BRACE); this.state = 321; this.match(LatexParser.R_BRACE); this.state = 322; this.match(LatexParser.CARET); this.state = 323; this.match(LatexParser.L_BRACE); this.state = 324; this.match(LatexParser.R_BRACE); } } break; default: throw new NoViableAltException(this); } this.state = 327; this.match(LatexParser.L_PAREN); this.state = 328; this.expr(0); this.state = 329; this.match(LatexParser.R_PAREN); this.state = 336; this._errHandler.sync(this); switch (this._input.LA(1)) { case 20: { this.state = 330; this.match(LatexParser.CMD_MATHRM); this.state = 331; this.match(LatexParser.L_BRACE); this.state = 332; this.id(); this.state = 333; this.match(LatexParser.R_BRACE); } break; case 75: { this.state = 335; this.id(); } break; default: throw new NoViableAltException(this); } this.state = 338; this.match(LatexParser.L_PAREN); this.state = 339; this.id(); this.state = 340; this.match(LatexParser.R_PAREN); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public integral_cmd(): Integral_cmdContext { let localctx: Integral_cmdContext = new Integral_cmdContext(this, this._ctx, this.state); this.enterRule(localctx, 40, LatexParser.RULE_integral_cmd); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 348; this._errHandler.sync(this); switch (this._input.LA(1)) { case 15: { { this.state = 342; this.match(LatexParser.CMD_INT_UNDERSCORE); this.state = 343; this.match(LatexParser.L_BRACE); this.state = 344; localctx._lower_lim_expr = this.expr(0); this.state = 345; this.match(LatexParser.R_BRACE); } } break; case 16: case 17: { this.state = 347; _la = this._input.LA(1); if(!(_la===16 || _la===17)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } } break; default: throw new NoViableAltException(this); } this.state = 356; this._errHandler.sync(this); switch (this._input.LA(1)) { case 57: { { this.state = 350; this.match(LatexParser.CARET); this.state = 351; this.match(LatexParser.L_BRACE); this.state = 352; localctx._upper_lim_expr = this.expr(0); this.state = 353; this.match(LatexParser.R_BRACE); } } break; case 65: case 66: { this.state = 355; _la = this._input.LA(1); if(!(_la===65 || _la===66)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } } break; default: throw new NoViableAltException(this); } this.state = 358; this.match(LatexParser.L_PAREN); this.state = 359; localctx._integrand_expr = this.expr(0); this.state = 360; this.match(LatexParser.R_PAREN); this.state = 367; this._errHandler.sync(this); switch (this._input.LA(1)) { case 20: { this.state = 361; this.match(LatexParser.CMD_MATHRM); this.state = 362; this.match(LatexParser.L_BRACE); this.state = 363; this.id(); this.state = 364; this.match(LatexParser.R_BRACE); } break; case 75: { this.state = 366; this.id(); } break; default: throw new NoViableAltException(this); } this.state = 369; this.match(LatexParser.L_PAREN); this.state = 370; this.id(); this.state = 371; this.match(LatexParser.R_PAREN); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public sum_prod_cmd(): Sum_prod_cmdContext { let localctx: Sum_prod_cmdContext = new Sum_prod_cmdContext(this, this._ctx, this.state); this.enterRule(localctx, 42, LatexParser.RULE_sum_prod_cmd); let _la: number; try { this.enterOuterAlt(localctx, 1); { { this.state = 373; _la = this._input.LA(1); if(!(_la===18 || _la===19)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 374; this.match(LatexParser.L_BRACE); this.state = 375; this.id(); this.state = 376; this.match(LatexParser.EQ); this.state = 377; localctx._start_expr = this.expr(0); this.state = 378; this.match(LatexParser.R_BRACE); } this.state = 386; this._errHandler.sync(this); switch (this._input.LA(1)) { case 57: { { this.state = 380; this.match(LatexParser.CARET); this.state = 381; this.match(LatexParser.L_BRACE); this.state = 382; localctx._end_expr = this.expr(0); this.state = 383; this.match(LatexParser.R_BRACE); } } break; case 65: case 66: { this.state = 385; _la = this._input.LA(1); if(!(_la===65 || _la===66)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } } break; default: throw new NoViableAltException(this); } this.state = 388; this.match(LatexParser.L_PAREN); this.state = 389; localctx._operand_expr = this.expr(0); this.state = 390; this.match(LatexParser.R_PAREN); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public derivative_cmd(): Derivative_cmdContext { let localctx: Derivative_cmdContext = new Derivative_cmdContext(this, this._ctx, this.state); this.enterRule(localctx, 44, LatexParser.RULE_derivative_cmd); try { this.enterOuterAlt(localctx, 1); { this.state = 392; this.match(LatexParser.CMD_FRAC); this.state = 393; this.match(LatexParser.L_BRACE); this.state = 400; this._errHandler.sync(this); switch (this._input.LA(1)) { case 20: { this.state = 394; localctx._MATHRM_0 = this.match(LatexParser.CMD_MATHRM); this.state = 395; this.match(LatexParser.L_BRACE); this.state = 396; this.id(); this.state = 397; this.match(LatexParser.R_BRACE); } break; case 75: { this.state = 399; this.id(); } break; default: throw new NoViableAltException(this); } this.state = 402; this.match(LatexParser.R_BRACE); this.state = 403; this.match(LatexParser.L_BRACE); this.state = 410; this._errHandler.sync(this); switch (this._input.LA(1)) { case 20: { this.state = 404; localctx._MATHRM_1 = this.match(LatexParser.CMD_MATHRM); this.state = 405; this.match(LatexParser.L_BRACE); this.state = 406; this.id(); this.state = 407; this.match(LatexParser.R_BRACE); } break; case 75: { this.state = 409; this.id(); } break; default: throw new NoViableAltException(this); } this.state = 412; this.match(LatexParser.L_PAREN); this.state = 413; this.id(); this.state = 414; this.match(LatexParser.R_PAREN); this.state = 415; this.match(LatexParser.R_BRACE); this.state = 416; this.match(LatexParser.L_PAREN); this.state = 417; this.expr(0); this.state = 418; this.match(LatexParser.R_PAREN); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public n_derivative_cmd(): N_derivative_cmdContext { let localctx: N_derivative_cmdContext = new N_derivative_cmdContext(this, this._ctx, this.state); this.enterRule(localctx, 46, LatexParser.RULE_n_derivative_cmd); try { this.enterOuterAlt(localctx, 1); { this.state = 420; this.match(LatexParser.CMD_FRAC); this.state = 421; this.match(LatexParser.L_BRACE); this.state = 428; this._errHandler.sync(this); switch (this._input.LA(1)) { case 20: { this.state = 422; localctx._MATHRM_0 = this.match(LatexParser.CMD_MATHRM); this.state = 423; this.match(LatexParser.L_BRACE); this.state = 424; this.id(); this.state = 425; this.match(LatexParser.R_BRACE); } break; case 75: { this.state = 427; this.id(); } break; default: throw new NoViableAltException(this); } this.state = 436; this._errHandler.sync(this); switch (this._input.LA(1)) { case 57: { { this.state = 430; this.match(LatexParser.CARET); this.state = 431; this.match(LatexParser.L_BRACE); this.state = 432; localctx._exp1 = this.number_(); this.state = 433; this.match(LatexParser.R_BRACE); } } break; case 65: { this.state = 435; localctx._single_char_exp1 = this.match(LatexParser.CARET_SINGLE_CHAR_NUMBER); } break; default: throw new NoViableAltException(this); } this.state = 438; this.match(LatexParser.R_BRACE); this.state = 439; this.match(LatexParser.L_BRACE); this.state = 446; this._errHandler.sync(this); switch (this._input.LA(1)) { case 20: { this.state = 440; localctx._MATHRM_1 = this.match(LatexParser.CMD_MATHRM); this.state = 441; this.match(LatexParser.L_BRACE); this.state = 442; this.id(); this.state = 443; this.match(LatexParser.R_BRACE); } break; case 75: { this.state = 445; this.id(); } break; default: throw new NoViableAltException(this); } this.state = 448; this.match(LatexParser.L_PAREN); this.state = 449; this.id(); this.state = 450; this.match(LatexParser.R_PAREN); this.state = 457; this._errHandler.sync(this); switch (this._input.LA(1)) { case 57: { { this.state = 451; this.match(LatexParser.CARET); this.state = 452; this.match(LatexParser.L_BRACE); this.state = 453; localctx._exp2 = this.number_(); this.state = 454; this.match(LatexParser.R_BRACE); } } break; case 65: { this.state = 456; localctx._single_char_exp2 = this.match(LatexParser.CARET_SINGLE_CHAR_NUMBER); } break; default: throw new NoViableAltException(this); } this.state = 459; this.match(LatexParser.R_BRACE); this.state = 460; this.match(LatexParser.L_PAREN); this.state = 461; this.expr(0); this.state = 462; this.match(LatexParser.R_PAREN); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public argument(): ArgumentContext { let localctx: ArgumentContext = new ArgumentContext(this, this._ctx, this.state); this.enterRule(localctx, 48, LatexParser.RULE_argument); let _la: number; try { this.state = 474; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 38, this._ctx) ) { case 1: this.enterOuterAlt(localctx, 1); { { this.state = 464; this.id(); this.state = 465; this.match(LatexParser.EQ); this.state = 466; this.expr(0); } } break; case 2: this.enterOuterAlt(localctx, 2); { { this.state = 468; this.expr(0); this.state = 469; localctx._lower = this._input.LT(1); _la = this._input.LA(1); if(!(_la===59 || _la===61)) { localctx._lower = this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 470; this.id(); this.state = 471; localctx._upper = this._input.LT(1); _la = this._input.LA(1); if(!(_la===59 || _la===61)) { localctx._upper = this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 472; this.expr(0); } } break; } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public condition(): ConditionContext { let localctx: ConditionContext = new ConditionContext(this, this._ctx, this.state); this.enterRule(localctx, 50, LatexParser.RULE_condition); try { this.state = 478; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 39, this._ctx) ) { case 1: this.enterOuterAlt(localctx, 1); { this.state = 476; this.condition_single(); } break; case 2: this.enterOuterAlt(localctx, 2); { this.state = 477; this.condition_chain(); } break; } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public id_list(): Id_listContext { let localctx: Id_listContext = new Id_listContext(this, this._ctx, this.state); this.enterRule(localctx, 52, LatexParser.RULE_id_list); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 480; this.id(); this.state = 483; this._errHandler.sync(this); _la = this._input.LA(1); do { { { this.state = 481; this.match(LatexParser.COMMA); this.state = 482; this.id(); } } this.state = 485; this._errHandler.sync(this); _la = this._input.LA(1); } while (_la===63); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public guess(): GuessContext { let localctx: GuessContext = new GuessContext(this, this._ctx, this.state); this.enterRule(localctx, 54, LatexParser.RULE_guess); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 487; this.id(); this.state = 488; _la = this._input.LA(1); if(!(_la===27 || _la===28)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 491; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 41, this._ctx) ) { case 1: { this.state = 489; this.number_(); } break; case 2: { this.state = 490; this.number_with_units(); } break; } } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public guess_list(): Guess_listContext { let localctx: Guess_listContext = new Guess_listContext(this, this._ctx, this.state); this.enterRule(localctx, 56, LatexParser.RULE_guess_list); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 493; this.guess(); this.state = 496; this._errHandler.sync(this); _la = this._input.LA(1); do { { { this.state = 494; this.match(LatexParser.COMMA); this.state = 495; this.guess(); } } this.state = 498; this._errHandler.sync(this); _la = this._input.LA(1); } while (_la===63); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public condition_single(): Condition_singleContext { let localctx: Condition_singleContext = new Condition_singleContext(this, this._ctx, this.state); this.enterRule(localctx, 58, LatexParser.RULE_condition_single); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 500; this.expr(0); this.state = 501; localctx._operator = this._input.LT(1); _la = this._input.LA(1); if(!(((((_la - 59)) & ~0x1F) === 0 && ((1 << (_la - 59)) & 15) !== 0))) { localctx._operator = this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 502; this.expr(0); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public condition_chain(): Condition_chainContext { let localctx: Condition_chainContext = new Condition_chainContext(this, this._ctx, this.state); this.enterRule(localctx, 60, LatexParser.RULE_condition_chain); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 504; this.expr(0); this.state = 505; localctx._lower = this._input.LT(1); _la = this._input.LA(1); if(!(((((_la - 59)) & ~0x1F) === 0 && ((1 << (_la - 59)) & 15) !== 0))) { localctx._lower = this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 506; this.expr(0); this.state = 507; localctx._upper = this._input.LT(1); _la = this._input.LA(1); if(!(((((_la - 59)) & ~0x1F) === 0 && ((1 << (_la - 59)) & 15) !== 0))) { localctx._upper = this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 508; this.expr(0); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public matrix_row(): Matrix_rowContext { let localctx: Matrix_rowContext = new Matrix_rowContext(this, this._ctx, this.state); this.enterRule(localctx, 62, LatexParser.RULE_matrix_row); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 510; this.expr(0); this.state = 515; this._errHandler.sync(this); _la = this._input.LA(1); while (_la===70) { { { this.state = 511; this.match(LatexParser.AMPERSAND); this.state = 512; this.expr(0); } } this.state = 517; this._errHandler.sync(this); _la = this._input.LA(1); } } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public user_function(): User_functionContext { let localctx: User_functionContext = new User_functionContext(this, this._ctx, this.state); this.enterRule(localctx, 64, LatexParser.RULE_user_function); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 518; this.id(); this.state = 519; this.match(LatexParser.L_PAREN); { this.state = 520; this.argument(); this.state = 525; this._errHandler.sync(this); _la = this._input.LA(1); while (_la===63) { { { this.state = 521; this.match(LatexParser.COMMA); this.state = 522; this.argument(); } } this.state = 527; this._errHandler.sync(this); _la = this._input.LA(1); } } this.state = 528; this.match(LatexParser.R_PAREN); this.state = 533; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 45, this._ctx) ) { case 1: { this.state = 529; localctx._points_id_0 = this.match(LatexParser.ID); this.state = 530; localctx._num_points = this.number_(); this.state = 531; localctx._points_id_1 = this.match(LatexParser.ID); } break; } } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public builtin_function(): Builtin_functionContext { let localctx: Builtin_functionContext = new Builtin_functionContext(this, this._ctx, this.state); this.enterRule(localctx, 66, LatexParser.RULE_builtin_function); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 541; this._errHandler.sync(this); switch (this._input.LA(1)) { case 20: { this.state = 535; this.match(LatexParser.CMD_MATHRM); this.state = 536; this.match(LatexParser.L_BRACE); this.state = 537; this.id(); this.state = 538; this.match(LatexParser.R_BRACE); } break; case 75: { this.state = 540; this.id(); } break; default: throw new NoViableAltException(this); } this.state = 543; this.match(LatexParser.L_PAREN); this.state = 552; this._errHandler.sync(this); _la = this._input.LA(1); if ((((_la) & ~0x1F) === 0 && ((1 << _la) & 2793399936) !== 0) || ((((_la - 33)) & ~0x1F) === 0 && ((1 << (_la - 33)) & 2189688831) !== 0) || ((((_la - 67)) & ~0x1F) === 0 && ((1 << (_la - 67)) & 259) !== 0)) { { this.state = 544; this.expr(0); this.state = 549; this._errHandler.sync(this); _la = this._input.LA(1); while (_la===63) { { { this.state = 545; this.match(LatexParser.COMMA); this.state = 546; this.expr(0); } } this.state = 551; this._errHandler.sync(this); _la = this._input.LA(1); } } } this.state = 554; this.match(LatexParser.R_PAREN); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public index(): IndexContext { let localctx: IndexContext = new IndexContext(this, this._ctx, this.state); this.enterRule(localctx, 68, LatexParser.RULE_index); let _la: number; try { this.state = 573; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 53, this._ctx) ) { case 1: this.enterOuterAlt(localctx, 1); { this.state = 556; localctx._direct = this.expr(0); } break; case 2: this.enterOuterAlt(localctx, 2); { { this.state = 558; this._errHandler.sync(this); _la = this._input.LA(1); if ((((_la) & ~0x1F) === 0 && ((1 << _la) & 2793399936) !== 0) || ((((_la - 33)) & ~0x1F) === 0 && ((1 << (_la - 33)) & 2189688831) !== 0) || ((((_la - 67)) & ~0x1F) === 0 && ((1 << (_la - 67)) & 259) !== 0)) { { this.state = 557; localctx._start = this.expr(0); } } this.state = 560; this.match(LatexParser.COLON); this.state = 562; this._errHandler.sync(this); _la = this._input.LA(1); if ((((_la) & ~0x1F) === 0 && ((1 << _la) & 2793399936) !== 0) || ((((_la - 33)) & ~0x1F) === 0 && ((1 << (_la - 33)) & 2189688831) !== 0) || ((((_la - 67)) & ~0x1F) === 0 && ((1 << (_la - 67)) & 259) !== 0)) { { this.state = 561; localctx._stop = this.expr(0); } } } } break; case 3: this.enterOuterAlt(localctx, 3); { { this.state = 565; this._errHandler.sync(this); _la = this._input.LA(1); if ((((_la) & ~0x1F) === 0 && ((1 << _la) & 2793399936) !== 0) || ((((_la - 33)) & ~0x1F) === 0 && ((1 << (_la - 33)) & 2189688831) !== 0) || ((((_la - 67)) & ~0x1F) === 0 && ((1 << (_la - 67)) & 259) !== 0)) { { this.state = 564; localctx._start = this.expr(0); } } this.state = 567; this.match(LatexParser.COLON); this.state = 568; localctx._stride = this.expr(0); this.state = 569; this.match(LatexParser.COLON); this.state = 571; this._errHandler.sync(this); _la = this._input.LA(1); if ((((_la) & ~0x1F) === 0 && ((1 << _la) & 2793399936) !== 0) || ((((_la - 33)) & ~0x1F) === 0 && ((1 << (_la - 33)) & 2189688831) !== 0) || ((((_la - 67)) & ~0x1F) === 0 && ((1 << (_la - 67)) & 259) !== 0)) { { this.state = 570; localctx._stop = this.expr(0); } } } } break; } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } public expr(): ExprContext; public expr(_p: number): ExprContext; // @RuleVersion(0) public expr(_p?: number): ExprContext { if (_p === undefined) { _p = 0; } let _parentctx: ParserRuleContext = this._ctx; let _parentState: number = this.state; let localctx: ExprContext = new ExprContext(this, this._ctx, _parentState); let _prevctx: ExprContext = localctx; let _startState: number = 70; this.enterRecursionRule(localctx, 70, LatexParser.RULE_expr, _p); let _la: number; try { let _alt: number; this.enterOuterAlt(localctx, 1); { this.state = 703; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 61, this._ctx) ) { case 1: { localctx = new ExponentContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 576; this.id(); this.state = 577; this.match(LatexParser.CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT); } break; case 2: { localctx = new ExponentContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 579; this.id(); this.state = 580; _la = this._input.LA(1); if(!(_la===65 || _la===66)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 581; this.match(LatexParser.UNDERSCORE_SUBSCRIPT); } break; case 3: { localctx = new ExponentContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 583; this.id(); this.state = 584; this.match(LatexParser.CARET); this.state = 585; this.match(LatexParser.L_BRACE); this.state = 586; this.expr(0); this.state = 587; this.match(LatexParser.R_BRACE); this.state = 588; this.match(LatexParser.UNDERSCORE_SUBSCRIPT); } break; case 4: { localctx = new SingleIntSqrtContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 590; this.match(LatexParser.CMD_SQRT_INT); } break; case 5: { localctx = new SqrtContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 591; this.match(LatexParser.CMD_SQRT); this.state = 592; this.match(LatexParser.L_BRACE); this.state = 593; this.expr(0); this.state = 594; this.match(LatexParser.R_BRACE); } break; case 6: { localctx = new MatrixContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 596; this.match(LatexParser.BEGIN_MATRIX); this.state = 597; this.matrix_row(); this.state = 602; this._errHandler.sync(this); _la = this._input.LA(1); while (_la===71) { { { this.state = 598; this.match(LatexParser.DOUBLE_BACKSLASH); this.state = 599; this.matrix_row(); } } this.state = 604; this._errHandler.sync(this); _la = this._input.LA(1); } this.state = 605; this.match(LatexParser.END_MATRIX); } break; case 7: { localctx = new TrigFunctionContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 607; this.trig_function(); } break; case 8: { localctx = new IndefiniteIntegralContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 608; this.indefinite_integral_cmd(); } break; case 9: { localctx = new IntegralContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 609; this.integral_cmd(); } break; case 10: { localctx = new DerivativeContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 610; this.derivative_cmd(); } break; case 11: { localctx = new NDerivativeContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 611; this.n_derivative_cmd(); } break; case 12: { localctx = new SumProdContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 612; this.sum_prod_cmd(); } break; case 13: { localctx = new LnContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 614; this._errHandler.sync(this); _la = this._input.LA(1); if (_la===31) { { this.state = 613; this.match(LatexParser.BACKSLASH); } } this.state = 616; this.match(LatexParser.CMD_LN); this.state = 617; this.match(LatexParser.L_PAREN); this.state = 618; this.expr(0); this.state = 619; this.match(LatexParser.R_PAREN); } break; case 14: { localctx = new LogContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 622; this._errHandler.sync(this); _la = this._input.LA(1); if (_la===31) { { this.state = 621; this.match(LatexParser.BACKSLASH); } } this.state = 624; this.match(LatexParser.CMD_LOG); this.state = 625; this.match(LatexParser.L_PAREN); this.state = 626; this.expr(0); this.state = 627; this.match(LatexParser.R_PAREN); } break; case 15: { localctx = new BaseLogContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 629; this.match(LatexParser.CMD_SLASH_LOG_UNDERSCORE); this.state = 630; this.match(LatexParser.L_BRACE); this.state = 631; this.expr(0); this.state = 632; this.match(LatexParser.R_BRACE); this.state = 633; this.match(LatexParser.L_PAREN); this.state = 634; this.expr(0); this.state = 635; this.match(LatexParser.R_PAREN); } break; case 16: { localctx = new BaseLogSingleCharContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 637; _la = this._input.LA(1); if(!(_la===49 || _la===50)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 638; this.match(LatexParser.L_PAREN); this.state = 639; this.expr(0); this.state = 640; this.match(LatexParser.R_PAREN); } break; case 17: { localctx = new NormContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 642; this.match(LatexParser.DOUBLE_VBAR); this.state = 643; this.expr(0); this.state = 644; this.match(LatexParser.DOUBLE_VBAR); } break; case 18: { localctx = new AbsContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 646; this.match(LatexParser.VBAR); this.state = 647; this.expr(0); this.state = 648; this.match(LatexParser.VBAR); } break; case 19: { localctx = new NumberWithUnitsExprContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 650; this.number_with_units(); } break; case 20: { localctx = new NumberExprContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 651; this.number_(); } break; case 21: { localctx = new UnaryMinusContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 652; this.match(LatexParser.SUB); this.state = 653; this.expr(28); } break; case 22: { localctx = new DivideContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 654; this.match(LatexParser.CMD_FRAC); this.state = 655; this.match(LatexParser.L_BRACE); this.state = 656; this.expr(0); this.state = 657; this.match(LatexParser.R_BRACE); this.state = 658; this.match(LatexParser.L_BRACE); this.state = 659; this.expr(0); this.state = 660; this.match(LatexParser.R_BRACE); } break; case 23: { localctx = new DivideIntsContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 662; this.match(LatexParser.CMD_FRAC_INTS); } break; case 24: { localctx = new VariableContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 663; this.id(); } break; case 25: { localctx = new UserFunctionContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 664; this.user_function(); } break; case 26: { localctx = new BuiltinFunctionContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 665; this.builtin_function(); } break; case 27: { localctx = new InfinityExprContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 666; this.match(LatexParser.INFINITY); } break; case 28: { localctx = new SubExprContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 667; this.match(LatexParser.L_PAREN); this.state = 668; this.expr(0); this.state = 669; this.match(LatexParser.R_PAREN); } break; case 29: { localctx = new MissingMultiplicationContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 671; this.number_(); this.state = 672; this.expr(11); } break; case 30: { localctx = new MissingMultiplicationContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 674; this.number_with_units(); this.state = 675; this.expr(10); } break; case 31: { localctx = new EmptyPlaceholderContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 677; this.match(LatexParser.CMD_PLACEHOLDER); this.state = 680; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 57, this._ctx) ) { case 1: { this.state = 678; this.match(LatexParser.L_BRACE); this.state = 679; this.match(LatexParser.R_BRACE); } break; } } break; case 32: { localctx = new RemoveOperatorFontContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 687; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 58, this._ctx) ) { case 1: { this.state = 682; this.match(LatexParser.CMD_MATHRM); this.state = 683; this.match(LatexParser.L_BRACE); this.state = 684; this.expr(0); this.state = 685; this.match(LatexParser.R_BRACE); } break; } this.state = 692; this._errHandler.sync(this); switch (this._input.LA(1)) { case 64: { this.state = 689; this.match(LatexParser.DECIMAL_POINT); } break; case 56: case 67: { this.state = 690; this.number_(); } break; case 58: { this.state = 691; this.match(LatexParser.EQ); } break; case 20: break; default: break; } this.state = 694; this.match(LatexParser.CMD_MATHRM); this.state = 695; this.match(LatexParser.L_BRACE); this.state = 696; this.expr(0); this.state = 697; this.match(LatexParser.R_BRACE); this.state = 701; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 60, this._ctx) ) { case 1: { this.state = 698; this.match(LatexParser.DECIMAL_POINT); } break; case 2: { this.state = 699; this.number_(); } break; case 3: { this.state = 700; this.match(LatexParser.EQ); } break; } } break; } this._ctx.stop = this._input.LT(-1); this.state = 767; this._errHandler.sync(this); _alt = this._interp.adaptivePredict(this._input, 63, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { if (this._parseListeners != null) { this.triggerExitRuleEvent(); } _prevctx = localctx; { this.state = 765; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 62, this._ctx) ) { case 1: { localctx = new MatrixMultiplyContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 705; if (!(this.precpred(this._ctx, 27))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 27)"); } this.state = 706; this.match(LatexParser.CMD_TIMES); this.state = 707; this.expr(28); } break; case 2: { localctx = new MultiplyContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 708; if (!(this.precpred(this._ctx, 26))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 26)"); } this.state = 709; this.match(LatexParser.CMD_CDOT); this.state = 710; this.expr(27); } break; case 3: { localctx = new SubtractContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 711; if (!(this.precpred(this._ctx, 23))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 23)"); } this.state = 712; this.match(LatexParser.SUB); this.state = 713; this.expr(24); } break; case 4: { localctx = new AddContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 714; if (!(this.precpred(this._ctx, 22))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 22)"); } this.state = 715; this.match(LatexParser.ADD); this.state = 716; this.expr(23); } break; case 5: { localctx = new ExponentContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 717; if (!(this.precpred(this._ctx, 50))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 50)"); } this.state = 718; _la = this._input.LA(1); if(!(_la===65 || _la===66)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } } break; case 6: { localctx = new ExponentContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 719; if (!(this.precpred(this._ctx, 49))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 49)"); } this.state = 720; this.match(LatexParser.CARET); this.state = 721; this.match(LatexParser.L_BRACE); this.state = 722; this.expr(0); this.state = 723; this.match(LatexParser.R_BRACE); } break; case 7: { localctx = new MatrixIndexContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 725; if (!(this.precpred(this._ctx, 48))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 48)"); } this.state = 726; this.match(LatexParser.UNDERSCORE); this.state = 727; this.match(LatexParser.L_BRACE); this.state = 728; (localctx as MatrixIndexContext)._row = this.index(); this.state = 729; this.match(LatexParser.COMMA); this.state = 730; (localctx as MatrixIndexContext)._col = this.index(); this.state = 731; this.match(LatexParser.R_BRACE); } break; case 8: { localctx = new TransposeContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 733; if (!(this.precpred(this._ctx, 47))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 47)"); } this.state = 734; this.match(LatexParser.TRANSPOSE); } break; case 9: { localctx = new FactorialContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 735; if (!(this.precpred(this._ctx, 46))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 46)"); } this.state = 736; this.match(LatexParser.EXCLAMATION); } break; case 10: { localctx = new EmptySubscriptContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 737; if (!(this.precpred(this._ctx, 16))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 16)"); } this.state = 738; this.match(LatexParser.UNDERSCORE); this.state = 739; this.match(LatexParser.L_BRACE); this.state = 740; this.match(LatexParser.R_BRACE); } break; case 11: { localctx = new EmptySuperscriptContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 741; if (!(this.precpred(this._ctx, 15))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 15)"); } this.state = 742; this.match(LatexParser.CARET); this.state = 743; this.match(LatexParser.L_BRACE); this.state = 744; this.match(LatexParser.R_BRACE); } break; case 12: { localctx = new MissingMultiplicationContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 745; if (!(this.precpred(this._ctx, 14))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 14)"); } this.state = 746; this.id(); } break; case 13: { localctx = new MissingMultiplicationContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 747; if (!(this.precpred(this._ctx, 13))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 13)"); } this.state = 748; this.number_(); } break; case 14: { localctx = new MissingMultiplicationContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 749; if (!(this.precpred(this._ctx, 12))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 12)"); } this.state = 750; this.number_with_units(); } break; case 15: { localctx = new MissingMultiplicationContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 751; if (!(this.precpred(this._ctx, 9))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 9)"); } this.state = 752; this.user_function(); } break; case 16: { localctx = new MissingMultiplicationContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 753; if (!(this.precpred(this._ctx, 8))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 8)"); } this.state = 754; this.builtin_function(); } break; case 17: { localctx = new MissingMultiplicationContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 755; if (!(this.precpred(this._ctx, 7))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 7)"); } this.state = 756; this.trig_function(); } break; case 18: { localctx = new MissingMultiplicationContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 757; if (!(this.precpred(this._ctx, 6))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 6)"); } this.state = 758; this.indefinite_integral_cmd(); } break; case 19: { localctx = new MissingMultiplicationContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 759; if (!(this.precpred(this._ctx, 5))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 5)"); } this.state = 760; this.integral_cmd(); } break; case 20: { localctx = new MissingMultiplicationContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 761; if (!(this.precpred(this._ctx, 4))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 4)"); } this.state = 762; this.derivative_cmd(); } break; case 21: { localctx = new MissingMultiplicationContext(this, new ExprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_expr); this.state = 763; if (!(this.precpred(this._ctx, 3))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 3)"); } this.state = 764; this.n_derivative_cmd(); } break; } } } this.state = 769; this._errHandler.sync(this); _alt = this._interp.adaptivePredict(this._input, 63, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.unrollRecursionContexts(_parentctx); } return localctx; } // @RuleVersion(0) public u_block(): U_blockContext { let localctx: U_blockContext = new U_blockContext(this, this._ctx, this.state); this.enterRule(localctx, 72, LatexParser.RULE_u_block); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 770; _la = this._input.LA(1); if(!(_la===1 || _la===2)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 771; this.u_expr(0); this.state = 772; _la = this._input.LA(1); if(!(_la===81 || _la===82)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public u_insert_matrix(): U_insert_matrixContext { let localctx: U_insert_matrixContext = new U_insert_matrixContext(this, this._ctx, this.state); this.enterRule(localctx, 74, LatexParser.RULE_u_insert_matrix); let _la: number; try { this.enterOuterAlt(localctx, 1); { this.state = 774; _la = this._input.LA(1); if(!(_la===1 || _la===2)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 775; localctx._numRows = this._input.LT(1); _la = this._input.LA(1); if(!(_la===95 || _la===96)) { localctx._numRows = this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 776; _la = this._input.LA(1); if(!(_la===86 || _la===88)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 777; localctx._numColumns = this._input.LT(1); _la = this._input.LA(1); if(!(_la===95 || _la===96)) { localctx._numColumns = this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 778; _la = this._input.LA(1); if(!(_la===81 || _la===82)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } // @RuleVersion(0) public u_fraction(): U_fractionContext { let localctx: U_fractionContext = new U_fractionContext(this, this._ctx, this.state); this.enterRule(localctx, 76, LatexParser.RULE_u_fraction); let _la: number; try { this.state = 788; this._errHandler.sync(this); switch (this._input.LA(1)) { case 83: this.enterOuterAlt(localctx, 1); { this.state = 780; this.match(LatexParser.U_CMD_FRAC); this.state = 781; this.match(LatexParser.U_L_BRACE); this.state = 782; _la = this._input.LA(1); if(!(_la===95 || _la===96)) { this._errHandler.recoverInline(this); } else { this._errHandler.reportMatch(this); this.consume(); } this.state = 783; this.match(LatexParser.U_R_BRACE); this.state = 784; this.match(LatexParser.U_L_BRACE); this.state = 785; this.match(LatexParser.U_NUMBER); this.state = 786; this.match(LatexParser.U_R_BRACE); } break; case 84: this.enterOuterAlt(localctx, 2); { this.state = 787; this.match(LatexParser.U_CMD_FRAC_INTS); } break; default: throw new NoViableAltException(this); } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.exitRule(); } return localctx; } public u_expr(): U_exprContext; public u_expr(_p: number): U_exprContext; // @RuleVersion(0) public u_expr(_p?: number): U_exprContext { if (_p === undefined) { _p = 0; } let _parentctx: ParserRuleContext = this._ctx; let _parentState: number = this.state; let localctx: U_exprContext = new U_exprContext(this, this._ctx, _parentState); let _prevctx: U_exprContext = localctx; let _startState: number = 78; this.enterRecursionRule(localctx, 78, LatexParser.RULE_u_expr, _p); try { let _alt: number; this.enterOuterAlt(localctx, 1); { this.state = 812; this._errHandler.sync(this); switch (this._input.LA(1)) { case 87: { localctx = new UnitSqrtContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 791; this.match(LatexParser.U_CMD_SQRT); this.state = 792; this.match(LatexParser.U_L_BRACE); this.state = 793; this.expr(0); this.state = 794; this.match(LatexParser.U_R_BRACE); } break; case 83: { localctx = new UnitDivideContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 796; this.match(LatexParser.U_CMD_FRAC); this.state = 797; this.match(LatexParser.U_L_BRACE); this.state = 800; this._errHandler.sync(this); switch (this._input.LA(1)) { case 83: case 87: case 90: case 91: { this.state = 798; this.u_expr(0); } break; case 95: { this.state = 799; this.match(LatexParser.U_ONE); } break; default: throw new NoViableAltException(this); } this.state = 802; this.match(LatexParser.U_R_BRACE); this.state = 803; this.match(LatexParser.U_L_BRACE); this.state = 804; this.u_expr(0); this.state = 805; this.match(LatexParser.U_R_BRACE); } break; case 90: { localctx = new UnitNameContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 807; this.match(LatexParser.U_NAME); } break; case 91: { localctx = new UnitSubExprContext(this, localctx); this._ctx = localctx; _prevctx = localctx; this.state = 808; this.match(LatexParser.U_L_PAREN); this.state = 809; this.u_expr(0); this.state = 810; this.match(LatexParser.U_R_PAREN); } break; default: throw new NoViableAltException(this); } this._ctx.stop = this._input.LT(-1); this.state = 836; this._errHandler.sync(this); _alt = this._interp.adaptivePredict(this._input, 68, this._ctx); while (_alt !== 2 && _alt !== ATN.INVALID_ALT_NUMBER) { if (_alt === 1) { if (this._parseListeners != null) { this.triggerExitRuleEvent(); } _prevctx = localctx; { this.state = 834; this._errHandler.sync(this); switch ( this._interp.adaptivePredict(this._input, 67, this._ctx) ) { case 1: { localctx = new UnitMultiplyContext(this, new U_exprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_u_expr); this.state = 814; if (!(this.precpred(this._ctx, 4))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 4)"); } this.state = 815; this.match(LatexParser.U_CMD_CDOT); this.state = 816; this.u_expr(5); } break; case 2: { localctx = new UnitExponentContext(this, new U_exprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_u_expr); this.state = 817; if (!(this.precpred(this._ctx, 9))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 9)"); } this.state = 818; this.match(LatexParser.U_CARET); this.state = 819; this.match(LatexParser.U_NUMBER); } break; case 3: { localctx = new UnitExponentContext(this, new U_exprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_u_expr); this.state = 820; if (!(this.precpred(this._ctx, 8))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 8)"); } this.state = 821; this.match(LatexParser.U_CARET); this.state = 822; this.match(LatexParser.U_L_BRACE); this.state = 823; this.match(LatexParser.U_NUMBER); this.state = 824; this.match(LatexParser.U_R_BRACE); } break; case 4: { localctx = new UnitFractionalExponentContext(this, new U_exprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_u_expr); this.state = 825; if (!(this.precpred(this._ctx, 7))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 7)"); } this.state = 826; this.match(LatexParser.U_CARET); this.state = 827; this.u_fraction(); } break; case 5: { localctx = new UnitFractionalExponentContext(this, new U_exprContext(this, _parentctx, _parentState)); this.pushNewRecursionContext(localctx, _startState, LatexParser.RULE_u_expr); this.state = 828; if (!(this.precpred(this._ctx, 6))) { throw this.createFailedPredicateException("this.precpred(this._ctx, 6)"); } this.state = 829; this.match(LatexParser.U_CARET); this.state = 830; this.match(LatexParser.U_L_BRACE); this.state = 831; this.u_fraction(); this.state = 832; this.match(LatexParser.U_R_BRACE); } break; } } } this.state = 838; this._errHandler.sync(this); _alt = this._interp.adaptivePredict(this._input, 68, this._ctx); } } } catch (re) { if (re instanceof RecognitionException) { localctx.exception = re; this._errHandler.reportError(this, re); this._errHandler.recover(this, re); } else { throw re; } } finally { this.unrollRecursionContexts(_parentctx); } return localctx; } public sempred(localctx: RuleContext, ruleIndex: number, predIndex: number): boolean { switch (ruleIndex) { case 35: return this.expr_sempred(localctx as ExprContext, predIndex); case 39: return this.u_expr_sempred(localctx as U_exprContext, predIndex); } return true; } private expr_sempred(localctx: ExprContext, predIndex: number): boolean { switch (predIndex) { case 0: return this.precpred(this._ctx, 27); case 1: return this.precpred(this._ctx, 26); case 2: return this.precpred(this._ctx, 23); case 3: return this.precpred(this._ctx, 22); case 4: return this.precpred(this._ctx, 50); case 5: return this.precpred(this._ctx, 49); case 6: return this.precpred(this._ctx, 48); case 7: return this.precpred(this._ctx, 47); case 8: return this.precpred(this._ctx, 46); case 9: return this.precpred(this._ctx, 16); case 10: return this.precpred(this._ctx, 15); case 11: return this.precpred(this._ctx, 14); case 12: return this.precpred(this._ctx, 13); case 13: return this.precpred(this._ctx, 12); case 14: return this.precpred(this._ctx, 9); case 15: return this.precpred(this._ctx, 8); case 16: return this.precpred(this._ctx, 7); case 17: return this.precpred(this._ctx, 6); case 18: return this.precpred(this._ctx, 5); case 19: return this.precpred(this._ctx, 4); case 20: return this.precpred(this._ctx, 3); } return true; } private u_expr_sempred(localctx: U_exprContext, predIndex: number): boolean { switch (predIndex) { case 21: return this.precpred(this._ctx, 4); case 22: return this.precpred(this._ctx, 9); case 23: return this.precpred(this._ctx, 8); case 24: return this.precpred(this._ctx, 7); case 25: return this.precpred(this._ctx, 6); } return true; } public static readonly _serializedATN: number[] = [4,1,103,840,2,0,7,0, 2,1,7,1,2,2,7,2,2,3,7,3,2,4,7,4,2,5,7,5,2,6,7,6,2,7,7,7,2,8,7,8,2,9,7,9, 2,10,7,10,2,11,7,11,2,12,7,12,2,13,7,13,2,14,7,14,2,15,7,15,2,16,7,16,2, 17,7,17,2,18,7,18,2,19,7,19,2,20,7,20,2,21,7,21,2,22,7,22,2,23,7,23,2,24, 7,24,2,25,7,25,2,26,7,26,2,27,7,27,2,28,7,28,2,29,7,29,2,30,7,30,2,31,7, 31,2,32,7,32,2,33,7,33,2,34,7,34,2,35,7,35,2,36,7,36,2,37,7,37,2,38,7,38, 2,39,7,39,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1,0,1, 0,1,0,1,0,1,0,3,0,100,8,0,1,0,1,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, 1,3,1,114,8,1,1,1,3,1,117,8,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, 1,3,1,130,8,1,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,3, 2,146,8,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,3,2,159,8,2,1,3,5, 3,162,8,3,10,3,12,3,165,9,3,1,3,1,3,5,3,169,8,3,10,3,12,3,172,9,3,4,3,174, 8,3,11,3,12,3,175,1,4,5,4,179,8,4,10,4,12,4,182,9,4,1,4,1,4,1,4,1,4,1,4, 1,4,3,4,190,8,4,1,4,1,4,1,4,1,4,1,4,1,4,3,4,198,8,4,1,4,5,4,201,8,4,10, 4,12,4,204,9,4,4,4,206,8,4,11,4,12,4,207,1,5,1,5,1,5,5,5,213,8,5,10,5,12, 5,216,9,5,1,6,1,6,1,6,1,6,1,6,5,6,223,8,6,10,6,12,6,226,9,6,1,6,1,6,3,6, 230,8,6,1,7,1,7,1,7,1,7,1,7,1,7,3,7,238,8,7,1,7,1,7,1,7,1,7,5,7,244,8,7, 10,7,12,7,247,9,7,1,7,1,7,1,7,1,7,1,8,1,8,1,9,3,9,256,8,9,1,9,1,9,1,10, 1,10,3,10,262,8,10,1,10,1,10,1,11,1,11,1,11,1,11,1,12,1,12,1,12,4,12,273, 8,12,11,12,12,12,274,1,13,1,13,1,13,3,13,280,8,13,1,14,1,14,1,14,3,14,285, 8,14,1,15,1,15,1,15,1,15,1,16,1,16,1,16,1,16,1,16,1,16,1,16,5,16,298,8, 16,10,16,12,16,301,9,16,1,16,1,16,1,17,1,17,1,17,1,17,1,17,1,17,1,18,3, 18,312,8,18,1,18,1,18,1,18,1,18,1,18,1,19,1,19,1,19,1,19,1,19,1,19,1,19, 3,19,326,8,19,1,19,1,19,1,19,1,19,1,19,1,19,1,19,1,19,1,19,3,19,337,8,19, 1,19,1,19,1,19,1,19,1,20,1,20,1,20,1,20,1,20,1,20,3,20,349,8,20,1,20,1, 20,1,20,1,20,1,20,1,20,3,20,357,8,20,1,20,1,20,1,20,1,20,1,20,1,20,1,20, 1,20,1,20,3,20,368,8,20,1,20,1,20,1,20,1,20,1,21,1,21,1,21,1,21,1,21,1, 21,1,21,1,21,1,21,1,21,1,21,1,21,1,21,3,21,387,8,21,1,21,1,21,1,21,1,21, 1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,22,3,22,401,8,22,1,22,1,22,1,22,1, 22,1,22,1,22,1,22,1,22,3,22,411,8,22,1,22,1,22,1,22,1,22,1,22,1,22,1,22, 1,22,1,23,1,23,1,23,1,23,1,23,1,23,1,23,1,23,3,23,429,8,23,1,23,1,23,1, 23,1,23,1,23,1,23,3,23,437,8,23,1,23,1,23,1,23,1,23,1,23,1,23,1,23,1,23, 3,23,447,8,23,1,23,1,23,1,23,1,23,1,23,1,23,1,23,1,23,1,23,3,23,458,8,23, 1,23,1,23,1,23,1,23,1,23,1,24,1,24,1,24,1,24,1,24,1,24,1,24,1,24,1,24,1, 24,3,24,475,8,24,1,25,1,25,3,25,479,8,25,1,26,1,26,1,26,4,26,484,8,26,11, 26,12,26,485,1,27,1,27,1,27,1,27,3,27,492,8,27,1,28,1,28,1,28,4,28,497, 8,28,11,28,12,28,498,1,29,1,29,1,29,1,29,1,30,1,30,1,30,1,30,1,30,1,30, 1,31,1,31,1,31,5,31,514,8,31,10,31,12,31,517,9,31,1,32,1,32,1,32,1,32,1, 32,5,32,524,8,32,10,32,12,32,527,9,32,1,32,1,32,1,32,1,32,1,32,3,32,534, 8,32,1,33,1,33,1,33,1,33,1,33,1,33,3,33,542,8,33,1,33,1,33,1,33,1,33,5, 33,548,8,33,10,33,12,33,551,9,33,3,33,553,8,33,1,33,1,33,1,34,1,34,3,34, 559,8,34,1,34,1,34,3,34,563,8,34,1,34,3,34,566,8,34,1,34,1,34,1,34,1,34, 3,34,572,8,34,3,34,574,8,34,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35, 1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1, 35,1,35,5,35,601,8,35,10,35,12,35,604,9,35,1,35,1,35,1,35,1,35,1,35,1,35, 1,35,1,35,1,35,3,35,615,8,35,1,35,1,35,1,35,1,35,1,35,1,35,3,35,623,8,35, 1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1, 35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35, 1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1, 35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,3,35,681, 8,35,1,35,1,35,1,35,1,35,1,35,3,35,688,8,35,1,35,1,35,1,35,3,35,693,8,35, 1,35,1,35,1,35,1,35,1,35,1,35,1,35,3,35,702,8,35,3,35,704,8,35,1,35,1,35, 1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1, 35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35, 1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1, 35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35,1,35, 5,35,766,8,35,10,35,12,35,769,9,35,1,36,1,36,1,36,1,36,1,37,1,37,1,37,1, 37,1,37,1,37,1,38,1,38,1,38,1,38,1,38,1,38,1,38,1,38,3,38,789,8,38,1,39, 1,39,1,39,1,39,1,39,1,39,1,39,1,39,1,39,1,39,3,39,801,8,39,1,39,1,39,1, 39,1,39,1,39,1,39,1,39,1,39,1,39,1,39,3,39,813,8,39,1,39,1,39,1,39,1,39, 1,39,1,39,1,39,1,39,1,39,1,39,1,39,1,39,1,39,1,39,1,39,1,39,1,39,1,39,1, 39,1,39,5,39,835,8,39,10,39,12,39,838,9,39,1,39,4,163,170,180,202,2,70, 78,40,0,2,4,6,8,10,12,14,16,18,20,22,24,26,28,30,32,34,36,38,40,42,44,46, 48,50,52,54,56,58,60,62,64,66,68,70,72,74,76,78,0,12,1,0,33,45,1,0,16,17, 1,0,65,66,1,0,18,19,2,0,59,59,61,61,1,0,27,28,1,0,59,62,1,0,49,50,1,0,1, 2,1,0,81,82,1,0,95,96,2,0,86,86,88,88,947,0,99,1,0,0,0,2,113,1,0,0,0,4, 131,1,0,0,0,6,163,1,0,0,0,8,180,1,0,0,0,10,209,1,0,0,0,12,229,1,0,0,0,14, 237,1,0,0,0,16,252,1,0,0,0,18,255,1,0,0,0,20,261,1,0,0,0,22,265,1,0,0,0, 24,269,1,0,0,0,26,276,1,0,0,0,28,281,1,0,0,0,30,286,1,0,0,0,32,290,1,0, 0,0,34,304,1,0,0,0,36,311,1,0,0,0,38,325,1,0,0,0,40,348,1,0,0,0,42,373, 1,0,0,0,44,392,1,0,0,0,46,420,1,0,0,0,48,474,1,0,0,0,50,478,1,0,0,0,52, 480,1,0,0,0,54,487,1,0,0,0,56,493,1,0,0,0,58,500,1,0,0,0,60,504,1,0,0,0, 62,510,1,0,0,0,64,518,1,0,0,0,66,541,1,0,0,0,68,573,1,0,0,0,70,703,1,0, 0,0,72,770,1,0,0,0,74,774,1,0,0,0,76,788,1,0,0,0,78,812,1,0,0,0,80,100, 3,8,4,0,81,100,3,22,11,0,82,100,3,24,12,0,83,100,3,26,13,0,84,100,3,28, 14,0,85,100,3,30,15,0,86,100,3,72,36,0,87,100,3,18,9,0,88,100,3,16,8,0, 89,100,3,52,26,0,90,100,3,54,27,0,91,100,3,56,28,0,92,100,3,70,35,0,93, 100,3,50,25,0,94,100,3,32,16,0,95,100,3,6,3,0,96,100,3,2,1,0,97,100,3,4, 2,0,98,100,3,14,7,0,99,80,1,0,0,0,99,81,1,0,0,0,99,82,1,0,0,0,99,83,1,0, 0,0,99,84,1,0,0,0,99,85,1,0,0,0,99,86,1,0,0,0,99,87,1,0,0,0,99,88,1,0,0, 0,99,89,1,0,0,0,99,90,1,0,0,0,99,91,1,0,0,0,99,92,1,0,0,0,99,93,1,0,0,0, 99,94,1,0,0,0,99,95,1,0,0,0,99,96,1,0,0,0,99,97,1,0,0,0,99,98,1,0,0,0,99, 100,1,0,0,0,100,101,1,0,0,0,101,102,5,0,0,1,102,1,1,0,0,0,103,104,5,7,0, 0,104,105,3,70,35,0,105,106,5,63,0,0,106,107,3,70,35,0,107,108,5,8,0,0, 108,114,1,0,0,0,109,110,3,70,35,0,110,111,5,63,0,0,111,112,3,70,35,0,112, 114,1,0,0,0,113,103,1,0,0,0,113,109,1,0,0,0,114,116,1,0,0,0,115,117,5,32, 0,0,116,115,1,0,0,0,116,117,1,0,0,0,117,118,1,0,0,0,118,129,5,58,0,0,119, 120,5,7,0,0,120,121,3,72,36,0,121,122,5,63,0,0,122,123,3,72,36,0,123,124, 5,8,0,0,124,130,1,0,0,0,125,126,3,72,36,0,126,127,5,63,0,0,127,128,3,72, 36,0,128,130,1,0,0,0,129,119,1,0,0,0,129,125,1,0,0,0,129,130,1,0,0,0,130, 3,1,0,0,0,131,132,5,7,0,0,132,133,3,70,35,0,133,134,5,63,0,0,134,135,3, 70,35,0,135,136,5,8,0,0,136,137,1,0,0,0,137,138,5,75,0,0,138,139,5,7,0, 0,139,140,3,48,24,0,140,145,5,8,0,0,141,142,5,75,0,0,142,143,3,18,9,0,143, 144,5,75,0,0,144,146,1,0,0,0,145,141,1,0,0,0,145,146,1,0,0,0,146,147,1, 0,0,0,147,158,5,58,0,0,148,149,5,7,0,0,149,150,3,72,36,0,150,151,5,63,0, 0,151,152,3,72,36,0,152,153,5,8,0,0,153,159,1,0,0,0,154,155,3,72,36,0,155, 156,5,63,0,0,156,157,3,72,36,0,157,159,1,0,0,0,158,148,1,0,0,0,158,154, 1,0,0,0,158,159,1,0,0,0,159,5,1,0,0,0,160,162,9,0,0,0,161,160,1,0,0,0,162, 165,1,0,0,0,163,164,1,0,0,0,163,161,1,0,0,0,164,173,1,0,0,0,165,163,1,0, 0,0,166,170,3,74,37,0,167,169,9,0,0,0,168,167,1,0,0,0,169,172,1,0,0,0,170, 171,1,0,0,0,170,168,1,0,0,0,171,174,1,0,0,0,172,170,1,0,0,0,173,166,1,0, 0,0,174,175,1,0,0,0,175,173,1,0,0,0,175,176,1,0,0,0,176,7,1,0,0,0,177,179, 9,0,0,0,178,177,1,0,0,0,179,182,1,0,0,0,180,181,1,0,0,0,180,178,1,0,0,0, 181,205,1,0,0,0,182,180,1,0,0,0,183,184,5,20,0,0,184,185,5,5,0,0,185,186, 3,16,8,0,186,189,5,6,0,0,187,190,3,16,8,0,188,190,5,74,0,0,189,187,1,0, 0,0,189,188,1,0,0,0,190,198,1,0,0,0,191,192,3,16,8,0,192,193,5,20,0,0,193, 194,5,5,0,0,194,195,3,16,8,0,195,196,5,6,0,0,196,198,1,0,0,0,197,183,1, 0,0,0,197,191,1,0,0,0,198,202,1,0,0,0,199,201,9,0,0,0,200,199,1,0,0,0,201, 204,1,0,0,0,202,203,1,0,0,0,202,200,1,0,0,0,203,206,1,0,0,0,204,202,1,0, 0,0,205,197,1,0,0,0,206,207,1,0,0,0,207,205,1,0,0,0,207,208,1,0,0,0,208, 9,1,0,0,0,209,214,3,72,36,0,210,211,5,70,0,0,211,213,3,72,36,0,212,210, 1,0,0,0,213,216,1,0,0,0,214,212,1,0,0,0,214,215,1,0,0,0,215,11,1,0,0,0, 216,214,1,0,0,0,217,230,3,72,36,0,218,219,5,68,0,0,219,224,3,10,5,0,220, 221,5,71,0,0,221,223,3,10,5,0,222,220,1,0,0,0,223,226,1,0,0,0,224,222,1, 0,0,0,224,225,1,0,0,0,225,227,1,0,0,0,226,224,1,0,0,0,227,228,5,69,0,0, 228,230,1,0,0,0,229,217,1,0,0,0,229,218,1,0,0,0,230,13,1,0,0,0,231,232, 5,20,0,0,232,233,5,5,0,0,233,234,3,16,8,0,234,235,5,6,0,0,235,238,1,0,0, 0,236,238,3,16,8,0,237,231,1,0,0,0,237,236,1,0,0,0,238,239,1,0,0,0,239, 240,5,7,0,0,240,245,3,12,6,0,241,242,5,63,0,0,242,244,3,12,6,0,243,241, 1,0,0,0,244,247,1,0,0,0,245,243,1,0,0,0,245,246,1,0,0,0,246,248,1,0,0,0, 247,245,1,0,0,0,248,249,5,8,0,0,249,250,5,58,0,0,250,251,3,12,6,0,251,15, 1,0,0,0,252,253,5,75,0,0,253,17,1,0,0,0,254,256,5,56,0,0,255,254,1,0,0, 0,255,256,1,0,0,0,256,257,1,0,0,0,257,258,5,67,0,0,258,19,1,0,0,0,259,262, 3,18,9,0,260,262,3,16,8,0,261,259,1,0,0,0,261,260,1,0,0,0,262,263,1,0,0, 0,263,264,3,72,36,0,264,21,1,0,0,0,265,266,3,16,8,0,266,267,5,58,0,0,267, 268,3,70,35,0,268,23,1,0,0,0,269,272,3,22,11,0,270,271,5,63,0,0,271,273, 3,22,11,0,272,270,1,0,0,0,273,274,1,0,0,0,274,272,1,0,0,0,274,275,1,0,0, 0,275,25,1,0,0,0,276,277,3,22,11,0,277,279,5,58,0,0,278,280,3,72,36,0,279, 278,1,0,0,0,279,280,1,0,0,0,280,27,1,0,0,0,281,282,3,70,35,0,282,284,5, 58,0,0,283,285,3,72,36,0,284,283,1,0,0,0,284,285,1,0,0,0,285,29,1,0,0,0, 286,287,3,70,35,0,287,288,5,58,0,0,288,289,3,70,35,0,289,31,1,0,0,0,290, 291,3,16,8,0,291,292,5,58,0,0,292,293,3,16,8,0,293,294,5,7,0,0,294,299, 3,34,17,0,295,296,5,63,0,0,296,298,3,34,17,0,297,295,1,0,0,0,298,301,1, 0,0,0,299,297,1,0,0,0,299,300,1,0,0,0,300,302,1,0,0,0,301,299,1,0,0,0,302, 303,5,8,0,0,303,33,1,0,0,0,304,305,5,7,0,0,305,306,3,70,35,0,306,307,5, 63,0,0,307,308,3,50,25,0,308,309,5,8,0,0,309,35,1,0,0,0,310,312,5,31,0, 0,311,310,1,0,0,0,311,312,1,0,0,0,312,313,1,0,0,0,313,314,7,0,0,0,314,315, 5,7,0,0,315,316,3,70,35,0,316,317,5,8,0,0,317,37,1,0,0,0,318,326,5,14,0, 0,319,320,5,15,0,0,320,321,5,5,0,0,321,322,5,6,0,0,322,323,5,57,0,0,323, 324,5,5,0,0,324,326,5,6,0,0,325,318,1,0,0,0,325,319,1,0,0,0,326,327,1,0, 0,0,327,328,5,7,0,0,328,329,3,70,35,0,329,336,5,8,0,0,330,331,5,20,0,0, 331,332,5,5,0,0,332,333,3,16,8,0,333,334,5,6,0,0,334,337,1,0,0,0,335,337, 3,16,8,0,336,330,1,0,0,0,336,335,1,0,0,0,337,338,1,0,0,0,338,339,5,7,0, 0,339,340,3,16,8,0,340,341,5,8,0,0,341,39,1,0,0,0,342,343,5,15,0,0,343, 344,5,5,0,0,344,345,3,70,35,0,345,346,5,6,0,0,346,349,1,0,0,0,347,349,7, 1,0,0,348,342,1,0,0,0,348,347,1,0,0,0,349,356,1,0,0,0,350,351,5,57,0,0, 351,352,5,5,0,0,352,353,3,70,35,0,353,354,5,6,0,0,354,357,1,0,0,0,355,357, 7,2,0,0,356,350,1,0,0,0,356,355,1,0,0,0,357,358,1,0,0,0,358,359,5,7,0,0, 359,360,3,70,35,0,360,367,5,8,0,0,361,362,5,20,0,0,362,363,5,5,0,0,363, 364,3,16,8,0,364,365,5,6,0,0,365,368,1,0,0,0,366,368,3,16,8,0,367,361,1, 0,0,0,367,366,1,0,0,0,368,369,1,0,0,0,369,370,5,7,0,0,370,371,3,16,8,0, 371,372,5,8,0,0,372,41,1,0,0,0,373,374,7,3,0,0,374,375,5,5,0,0,375,376, 3,16,8,0,376,377,5,58,0,0,377,378,3,70,35,0,378,379,5,6,0,0,379,386,1,0, 0,0,380,381,5,57,0,0,381,382,5,5,0,0,382,383,3,70,35,0,383,384,5,6,0,0, 384,387,1,0,0,0,385,387,7,2,0,0,386,380,1,0,0,0,386,385,1,0,0,0,387,388, 1,0,0,0,388,389,5,7,0,0,389,390,3,70,35,0,390,391,5,8,0,0,391,43,1,0,0, 0,392,393,5,21,0,0,393,400,5,5,0,0,394,395,5,20,0,0,395,396,5,5,0,0,396, 397,3,16,8,0,397,398,5,6,0,0,398,401,1,0,0,0,399,401,3,16,8,0,400,394,1, 0,0,0,400,399,1,0,0,0,401,402,1,0,0,0,402,403,5,6,0,0,403,410,5,5,0,0,404, 405,5,20,0,0,405,406,5,5,0,0,406,407,3,16,8,0,407,408,5,6,0,0,408,411,1, 0,0,0,409,411,3,16,8,0,410,404,1,0,0,0,410,409,1,0,0,0,411,412,1,0,0,0, 412,413,5,7,0,0,413,414,3,16,8,0,414,415,5,8,0,0,415,416,5,6,0,0,416,417, 5,7,0,0,417,418,3,70,35,0,418,419,5,8,0,0,419,45,1,0,0,0,420,421,5,21,0, 0,421,428,5,5,0,0,422,423,5,20,0,0,423,424,5,5,0,0,424,425,3,16,8,0,425, 426,5,6,0,0,426,429,1,0,0,0,427,429,3,16,8,0,428,422,1,0,0,0,428,427,1, 0,0,0,429,436,1,0,0,0,430,431,5,57,0,0,431,432,5,5,0,0,432,433,3,18,9,0, 433,434,5,6,0,0,434,437,1,0,0,0,435,437,5,65,0,0,436,430,1,0,0,0,436,435, 1,0,0,0,437,438,1,0,0,0,438,439,5,6,0,0,439,446,5,5,0,0,440,441,5,20,0, 0,441,442,5,5,0,0,442,443,3,16,8,0,443,444,5,6,0,0,444,447,1,0,0,0,445, 447,3,16,8,0,446,440,1,0,0,0,446,445,1,0,0,0,447,448,1,0,0,0,448,449,5, 7,0,0,449,450,3,16,8,0,450,457,5,8,0,0,451,452,5,57,0,0,452,453,5,5,0,0, 453,454,3,18,9,0,454,455,5,6,0,0,455,458,1,0,0,0,456,458,5,65,0,0,457,451, 1,0,0,0,457,456,1,0,0,0,458,459,1,0,0,0,459,460,5,6,0,0,460,461,5,7,0,0, 461,462,3,70,35,0,462,463,5,8,0,0,463,47,1,0,0,0,464,465,3,16,8,0,465,466, 5,58,0,0,466,467,3,70,35,0,467,475,1,0,0,0,468,469,3,70,35,0,469,470,7, 4,0,0,470,471,3,16,8,0,471,472,7,4,0,0,472,473,3,70,35,0,473,475,1,0,0, 0,474,464,1,0,0,0,474,468,1,0,0,0,475,49,1,0,0,0,476,479,3,58,29,0,477, 479,3,60,30,0,478,476,1,0,0,0,478,477,1,0,0,0,479,51,1,0,0,0,480,483,3, 16,8,0,481,482,5,63,0,0,482,484,3,16,8,0,483,481,1,0,0,0,484,485,1,0,0, 0,485,483,1,0,0,0,485,486,1,0,0,0,486,53,1,0,0,0,487,488,3,16,8,0,488,491, 7,5,0,0,489,492,3,18,9,0,490,492,3,20,10,0,491,489,1,0,0,0,491,490,1,0, 0,0,492,55,1,0,0,0,493,496,3,54,27,0,494,495,5,63,0,0,495,497,3,54,27,0, 496,494,1,0,0,0,497,498,1,0,0,0,498,496,1,0,0,0,498,499,1,0,0,0,499,57, 1,0,0,0,500,501,3,70,35,0,501,502,7,6,0,0,502,503,3,70,35,0,503,59,1,0, 0,0,504,505,3,70,35,0,505,506,7,6,0,0,506,507,3,70,35,0,507,508,7,6,0,0, 508,509,3,70,35,0,509,61,1,0,0,0,510,515,3,70,35,0,511,512,5,70,0,0,512, 514,3,70,35,0,513,511,1,0,0,0,514,517,1,0,0,0,515,513,1,0,0,0,515,516,1, 0,0,0,516,63,1,0,0,0,517,515,1,0,0,0,518,519,3,16,8,0,519,520,5,7,0,0,520, 525,3,48,24,0,521,522,5,63,0,0,522,524,3,48,24,0,523,521,1,0,0,0,524,527, 1,0,0,0,525,523,1,0,0,0,525,526,1,0,0,0,526,528,1,0,0,0,527,525,1,0,0,0, 528,533,5,8,0,0,529,530,5,75,0,0,530,531,3,18,9,0,531,532,5,75,0,0,532, 534,1,0,0,0,533,529,1,0,0,0,533,534,1,0,0,0,534,65,1,0,0,0,535,536,5,20, 0,0,536,537,5,5,0,0,537,538,3,16,8,0,538,539,5,6,0,0,539,542,1,0,0,0,540, 542,3,16,8,0,541,535,1,0,0,0,541,540,1,0,0,0,542,543,1,0,0,0,543,552,5, 7,0,0,544,549,3,70,35,0,545,546,5,63,0,0,546,548,3,70,35,0,547,545,1,0, 0,0,548,551,1,0,0,0,549,547,1,0,0,0,549,550,1,0,0,0,550,553,1,0,0,0,551, 549,1,0,0,0,552,544,1,0,0,0,552,553,1,0,0,0,553,554,1,0,0,0,554,555,5,8, 0,0,555,67,1,0,0,0,556,574,3,70,35,0,557,559,3,70,35,0,558,557,1,0,0,0, 558,559,1,0,0,0,559,560,1,0,0,0,560,562,5,3,0,0,561,563,3,70,35,0,562,561, 1,0,0,0,562,563,1,0,0,0,563,574,1,0,0,0,564,566,3,70,35,0,565,564,1,0,0, 0,565,566,1,0,0,0,566,567,1,0,0,0,567,568,5,3,0,0,568,569,3,70,35,0,569, 571,5,3,0,0,570,572,3,70,35,0,571,570,1,0,0,0,571,572,1,0,0,0,572,574,1, 0,0,0,573,556,1,0,0,0,573,558,1,0,0,0,573,565,1,0,0,0,574,69,1,0,0,0,575, 576,6,35,-1,0,576,577,3,16,8,0,577,578,5,73,0,0,578,704,1,0,0,0,579,580, 3,16,8,0,580,581,7,2,0,0,581,582,5,72,0,0,582,704,1,0,0,0,583,584,3,16, 8,0,584,585,5,57,0,0,585,586,5,5,0,0,586,587,3,70,35,0,587,588,5,6,0,0, 588,589,5,72,0,0,589,704,1,0,0,0,590,704,5,26,0,0,591,592,5,25,0,0,592, 593,5,5,0,0,593,594,3,70,35,0,594,595,5,6,0,0,595,704,1,0,0,0,596,597,5, 68,0,0,597,602,3,62,31,0,598,599,5,71,0,0,599,601,3,62,31,0,600,598,1,0, 0,0,601,604,1,0,0,0,602,600,1,0,0,0,602,603,1,0,0,0,603,605,1,0,0,0,604, 602,1,0,0,0,605,606,5,69,0,0,606,704,1,0,0,0,607,704,3,36,18,0,608,704, 3,38,19,0,609,704,3,40,20,0,610,704,3,44,22,0,611,704,3,46,23,0,612,704, 3,42,21,0,613,615,5,31,0,0,614,613,1,0,0,0,614,615,1,0,0,0,615,616,1,0, 0,0,616,617,5,46,0,0,617,618,5,7,0,0,618,619,3,70,35,0,619,620,5,8,0,0, 620,704,1,0,0,0,621,623,5,31,0,0,622,621,1,0,0,0,622,623,1,0,0,0,623,624, 1,0,0,0,624,625,5,47,0,0,625,626,5,7,0,0,626,627,3,70,35,0,627,628,5,8, 0,0,628,704,1,0,0,0,629,630,5,48,0,0,630,631,5,5,0,0,631,632,3,70,35,0, 632,633,5,6,0,0,633,634,5,7,0,0,634,635,3,70,35,0,635,636,5,8,0,0,636,704, 1,0,0,0,637,638,7,7,0,0,638,639,5,7,0,0,639,640,3,70,35,0,640,641,5,8,0, 0,641,704,1,0,0,0,642,643,5,10,0,0,643,644,3,70,35,0,644,645,5,10,0,0,645, 704,1,0,0,0,646,647,5,9,0,0,647,648,3,70,35,0,648,649,5,9,0,0,649,704,1, 0,0,0,650,704,3,20,10,0,651,704,3,18,9,0,652,653,5,56,0,0,653,704,3,70, 35,28,654,655,5,21,0,0,655,656,5,5,0,0,656,657,3,70,35,0,657,658,5,6,0, 0,658,659,5,5,0,0,659,660,3,70,35,0,660,661,5,6,0,0,661,704,1,0,0,0,662, 704,5,22,0,0,663,704,3,16,8,0,664,704,3,64,32,0,665,704,3,66,33,0,666,704, 5,13,0,0,667,668,5,7,0,0,668,669,3,70,35,0,669,670,5,8,0,0,670,704,1,0, 0,0,671,672,3,18,9,0,672,673,3,70,35,11,673,704,1,0,0,0,674,675,3,20,10, 0,675,676,3,70,35,10,676,704,1,0,0,0,677,680,5,29,0,0,678,679,5,5,0,0,679, 681,5,6,0,0,680,678,1,0,0,0,680,681,1,0,0,0,681,704,1,0,0,0,682,683,5,20, 0,0,683,684,5,5,0,0,684,685,3,70,35,0,685,686,5,6,0,0,686,688,1,0,0,0,687, 682,1,0,0,0,687,688,1,0,0,0,688,692,1,0,0,0,689,693,5,64,0,0,690,693,3, 18,9,0,691,693,5,58,0,0,692,689,1,0,0,0,692,690,1,0,0,0,692,691,1,0,0,0, 692,693,1,0,0,0,693,694,1,0,0,0,694,695,5,20,0,0,695,696,5,5,0,0,696,697, 3,70,35,0,697,701,5,6,0,0,698,702,5,64,0,0,699,702,3,18,9,0,700,702,5,58, 0,0,701,698,1,0,0,0,701,699,1,0,0,0,701,700,1,0,0,0,701,702,1,0,0,0,702, 704,1,0,0,0,703,575,1,0,0,0,703,579,1,0,0,0,703,583,1,0,0,0,703,590,1,0, 0,0,703,591,1,0,0,0,703,596,1,0,0,0,703,607,1,0,0,0,703,608,1,0,0,0,703, 609,1,0,0,0,703,610,1,0,0,0,703,611,1,0,0,0,703,612,1,0,0,0,703,614,1,0, 0,0,703,622,1,0,0,0,703,629,1,0,0,0,703,637,1,0,0,0,703,642,1,0,0,0,703, 646,1,0,0,0,703,650,1,0,0,0,703,651,1,0,0,0,703,652,1,0,0,0,703,654,1,0, 0,0,703,662,1,0,0,0,703,663,1,0,0,0,703,664,1,0,0,0,703,665,1,0,0,0,703, 666,1,0,0,0,703,667,1,0,0,0,703,671,1,0,0,0,703,674,1,0,0,0,703,677,1,0, 0,0,703,687,1,0,0,0,704,767,1,0,0,0,705,706,10,27,0,0,706,707,5,24,0,0, 707,766,3,70,35,28,708,709,10,26,0,0,709,710,5,23,0,0,710,766,3,70,35,27, 711,712,10,23,0,0,712,713,5,56,0,0,713,766,3,70,35,24,714,715,10,22,0,0, 715,716,5,55,0,0,716,766,3,70,35,23,717,718,10,50,0,0,718,766,7,2,0,0,719, 720,10,49,0,0,720,721,5,57,0,0,721,722,5,5,0,0,722,723,3,70,35,0,723,724, 5,6,0,0,724,766,1,0,0,0,725,726,10,48,0,0,726,727,5,11,0,0,727,728,5,5, 0,0,728,729,3,68,34,0,729,730,5,63,0,0,730,731,3,68,34,0,731,732,5,6,0, 0,732,766,1,0,0,0,733,734,10,47,0,0,734,766,5,30,0,0,735,736,10,46,0,0, 736,766,5,12,0,0,737,738,10,16,0,0,738,739,5,11,0,0,739,740,5,5,0,0,740, 766,5,6,0,0,741,742,10,15,0,0,742,743,5,57,0,0,743,744,5,5,0,0,744,766, 5,6,0,0,745,746,10,14,0,0,746,766,3,16,8,0,747,748,10,13,0,0,748,766,3, 18,9,0,749,750,10,12,0,0,750,766,3,20,10,0,751,752,10,9,0,0,752,766,3,64, 32,0,753,754,10,8,0,0,754,766,3,66,33,0,755,756,10,7,0,0,756,766,3,36,18, 0,757,758,10,6,0,0,758,766,3,38,19,0,759,760,10,5,0,0,760,766,3,40,20,0, 761,762,10,4,0,0,762,766,3,44,22,0,763,764,10,3,0,0,764,766,3,46,23,0,765, 705,1,0,0,0,765,708,1,0,0,0,765,711,1,0,0,0,765,714,1,0,0,0,765,717,1,0, 0,0,765,719,1,0,0,0,765,725,1,0,0,0,765,733,1,0,0,0,765,735,1,0,0,0,765, 737,1,0,0,0,765,741,1,0,0,0,765,745,1,0,0,0,765,747,1,0,0,0,765,749,1,0, 0,0,765,751,1,0,0,0,765,753,1,0,0,0,765,755,1,0,0,0,765,757,1,0,0,0,765, 759,1,0,0,0,765,761,1,0,0,0,765,763,1,0,0,0,766,769,1,0,0,0,767,765,1,0, 0,0,767,768,1,0,0,0,768,71,1,0,0,0,769,767,1,0,0,0,770,771,7,8,0,0,771, 772,3,78,39,0,772,773,7,9,0,0,773,73,1,0,0,0,774,775,7,8,0,0,775,776,7, 10,0,0,776,777,7,11,0,0,777,778,7,10,0,0,778,779,7,9,0,0,779,75,1,0,0,0, 780,781,5,83,0,0,781,782,5,93,0,0,782,783,7,10,0,0,783,784,5,94,0,0,784, 785,5,93,0,0,785,786,5,96,0,0,786,789,5,94,0,0,787,789,5,84,0,0,788,780, 1,0,0,0,788,787,1,0,0,0,789,77,1,0,0,0,790,791,6,39,-1,0,791,792,5,87,0, 0,792,793,5,93,0,0,793,794,3,70,35,0,794,795,5,94,0,0,795,813,1,0,0,0,796, 797,5,83,0,0,797,800,5,93,0,0,798,801,3,78,39,0,799,801,5,95,0,0,800,798, 1,0,0,0,800,799,1,0,0,0,801,802,1,0,0,0,802,803,5,94,0,0,803,804,5,93,0, 0,804,805,3,78,39,0,805,806,5,94,0,0,806,813,1,0,0,0,807,813,5,90,0,0,808, 809,5,91,0,0,809,810,3,78,39,0,810,811,5,92,0,0,811,813,1,0,0,0,812,790, 1,0,0,0,812,796,1,0,0,0,812,807,1,0,0,0,812,808,1,0,0,0,813,836,1,0,0,0, 814,815,10,4,0,0,815,816,5,85,0,0,816,835,3,78,39,5,817,818,10,9,0,0,818, 819,5,89,0,0,819,835,5,96,0,0,820,821,10,8,0,0,821,822,5,89,0,0,822,823, 5,93,0,0,823,824,5,96,0,0,824,835,5,94,0,0,825,826,10,7,0,0,826,827,5,89, 0,0,827,835,3,76,38,0,828,829,10,6,0,0,829,830,5,89,0,0,830,831,5,93,0, 0,831,832,3,76,38,0,832,833,5,94,0,0,833,835,1,0,0,0,834,814,1,0,0,0,834, 817,1,0,0,0,834,820,1,0,0,0,834,825,1,0,0,0,834,828,1,0,0,0,835,838,1,0, 0,0,836,834,1,0,0,0,836,837,1,0,0,0,837,79,1,0,0,0,838,836,1,0,0,0,69,99, 113,116,129,145,158,163,170,175,180,189,197,202,207,214,224,229,237,245, 255,261,274,279,284,299,311,325,336,348,356,367,386,400,410,428,436,446, 457,474,478,485,491,498,515,525,533,541,549,552,558,562,565,571,573,602, 614,622,680,687,692,701,703,765,767,788,800,812,834,836]; private static __ATN: ATN; public static get _ATN(): ATN { if (!LatexParser.__ATN) { LatexParser.__ATN = new ATNDeserializer().deserialize(LatexParser._serializedATN); } return LatexParser.__ATN; } static DecisionsToDFA = LatexParser._ATN.decisionToState.map( (ds: DecisionState, index: number) => new DFA(ds, index) ); } export class StatementContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public EOF(): TerminalNode { return this.getToken(LatexParser.EOF, 0); } public fix_mixed_id(): Fix_mixed_idContext { return this.getTypedRuleContext(Fix_mixed_idContext, 0) as Fix_mixed_idContext; } public assign(): AssignContext { return this.getTypedRuleContext(AssignContext, 0) as AssignContext; } public assign_list(): Assign_listContext { return this.getTypedRuleContext(Assign_listContext, 0) as Assign_listContext; } public assign_plus_query(): Assign_plus_queryContext { return this.getTypedRuleContext(Assign_plus_queryContext, 0) as Assign_plus_queryContext; } public query(): QueryContext { return this.getTypedRuleContext(QueryContext, 0) as QueryContext; } public equality(): EqualityContext { return this.getTypedRuleContext(EqualityContext, 0) as EqualityContext; } public u_block(): U_blockContext { return this.getTypedRuleContext(U_blockContext, 0) as U_blockContext; } public number_(): NumberContext { return this.getTypedRuleContext(NumberContext, 0) as NumberContext; } public id(): IdContext { return this.getTypedRuleContext(IdContext, 0) as IdContext; } public id_list(): Id_listContext { return this.getTypedRuleContext(Id_listContext, 0) as Id_listContext; } public guess(): GuessContext { return this.getTypedRuleContext(GuessContext, 0) as GuessContext; } public guess_list(): Guess_listContext { return this.getTypedRuleContext(Guess_listContext, 0) as Guess_listContext; } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public condition(): ConditionContext { return this.getTypedRuleContext(ConditionContext, 0) as ConditionContext; } public piecewise_assign(): Piecewise_assignContext { return this.getTypedRuleContext(Piecewise_assignContext, 0) as Piecewise_assignContext; } public insert_matrix(): Insert_matrixContext { return this.getTypedRuleContext(Insert_matrixContext, 0) as Insert_matrixContext; } public scatter_plot_query(): Scatter_plot_queryContext { return this.getTypedRuleContext(Scatter_plot_queryContext, 0) as Scatter_plot_queryContext; } public parametric_plot_query(): Parametric_plot_queryContext { return this.getTypedRuleContext(Parametric_plot_queryContext, 0) as Parametric_plot_queryContext; } public code_func_def(): Code_func_defContext { return this.getTypedRuleContext(Code_func_defContext, 0) as Code_func_defContext; } public get ruleIndex(): number { return LatexParser.RULE_statement; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitStatement) { return visitor.visitStatement(this); } else { return visitor.visitChildren(this); } } } export class Scatter_plot_queryContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public EQ(): TerminalNode { return this.getToken(LatexParser.EQ, 0); } public AS_LINES(): TerminalNode { return this.getToken(LatexParser.AS_LINES, 0); } public L_PAREN_list(): TerminalNode[] { return this.getTokens(LatexParser.L_PAREN); } public L_PAREN(i: number): TerminalNode { return this.getToken(LatexParser.L_PAREN, i); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public COMMA_list(): TerminalNode[] { return this.getTokens(LatexParser.COMMA); } public COMMA(i: number): TerminalNode { return this.getToken(LatexParser.COMMA, i); } public R_PAREN_list(): TerminalNode[] { return this.getTokens(LatexParser.R_PAREN); } public R_PAREN(i: number): TerminalNode { return this.getToken(LatexParser.R_PAREN, i); } public u_block_list(): U_blockContext[] { return this.getTypedRuleContexts(U_blockContext) as U_blockContext[]; } public u_block(i: number): U_blockContext { return this.getTypedRuleContext(U_blockContext, i) as U_blockContext; } public get ruleIndex(): number { return LatexParser.RULE_scatter_plot_query; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitScatter_plot_query) { return visitor.visitScatter_plot_query(this); } else { return visitor.visitChildren(this); } } } export class Parametric_plot_queryContext extends ParserRuleContext { public _for_id!: Token; public _points_id_0!: Token; public _num_points!: NumberContext; public _points_id_1!: Token; constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public L_PAREN_list(): TerminalNode[] { return this.getTokens(LatexParser.L_PAREN); } public L_PAREN(i: number): TerminalNode { return this.getToken(LatexParser.L_PAREN, i); } public argument(): ArgumentContext { return this.getTypedRuleContext(ArgumentContext, 0) as ArgumentContext; } public R_PAREN_list(): TerminalNode[] { return this.getTokens(LatexParser.R_PAREN); } public R_PAREN(i: number): TerminalNode { return this.getToken(LatexParser.R_PAREN, i); } public EQ(): TerminalNode { return this.getToken(LatexParser.EQ, 0); } public ID_list(): TerminalNode[] { return this.getTokens(LatexParser.ID); } public ID(i: number): TerminalNode { return this.getToken(LatexParser.ID, i); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public COMMA_list(): TerminalNode[] { return this.getTokens(LatexParser.COMMA); } public COMMA(i: number): TerminalNode { return this.getToken(LatexParser.COMMA, i); } public number_(): NumberContext { return this.getTypedRuleContext(NumberContext, 0) as NumberContext; } public u_block_list(): U_blockContext[] { return this.getTypedRuleContexts(U_blockContext) as U_blockContext[]; } public u_block(i: number): U_blockContext { return this.getTypedRuleContext(U_blockContext, i) as U_blockContext; } public get ruleIndex(): number { return LatexParser.RULE_parametric_plot_query; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitParametric_plot_query) { return visitor.visitParametric_plot_query(this); } else { return visitor.visitChildren(this); } } } export class Insert_matrixContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public u_insert_matrix_list(): U_insert_matrixContext[] { return this.getTypedRuleContexts(U_insert_matrixContext) as U_insert_matrixContext[]; } public u_insert_matrix(i: number): U_insert_matrixContext { return this.getTypedRuleContext(U_insert_matrixContext, i) as U_insert_matrixContext; } public get ruleIndex(): number { return LatexParser.RULE_insert_matrix; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitInsert_matrix) { return visitor.visitInsert_matrix(this); } else { return visitor.visitChildren(this); } } } export class Fix_mixed_idContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public CMD_MATHRM_list(): TerminalNode[] { return this.getTokens(LatexParser.CMD_MATHRM); } public CMD_MATHRM(i: number): TerminalNode { return this.getToken(LatexParser.CMD_MATHRM, i); } public L_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.L_BRACE); } public L_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.L_BRACE, i); } public id_list(): IdContext[] { return this.getTypedRuleContexts(IdContext) as IdContext[]; } public id(i: number): IdContext { return this.getTypedRuleContext(IdContext, i) as IdContext; } public R_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.R_BRACE); } public R_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.R_BRACE, i); } public PRIME_ACCENT_list(): TerminalNode[] { return this.getTokens(LatexParser.PRIME_ACCENT); } public PRIME_ACCENT(i: number): TerminalNode { return this.getToken(LatexParser.PRIME_ACCENT, i); } public get ruleIndex(): number { return LatexParser.RULE_fix_mixed_id; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitFix_mixed_id) { return visitor.visitFix_mixed_id(this); } else { return visitor.visitChildren(this); } } } export class Unit_matrix_rowContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public u_block_list(): U_blockContext[] { return this.getTypedRuleContexts(U_blockContext) as U_blockContext[]; } public u_block(i: number): U_blockContext { return this.getTypedRuleContext(U_blockContext, i) as U_blockContext; } public AMPERSAND_list(): TerminalNode[] { return this.getTokens(LatexParser.AMPERSAND); } public AMPERSAND(i: number): TerminalNode { return this.getToken(LatexParser.AMPERSAND, i); } public get ruleIndex(): number { return LatexParser.RULE_unit_matrix_row; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitUnit_matrix_row) { return visitor.visitUnit_matrix_row(this); } else { return visitor.visitChildren(this); } } } export class Code_cell_unitsContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public u_block(): U_blockContext { return this.getTypedRuleContext(U_blockContext, 0) as U_blockContext; } public BEGIN_MATRIX(): TerminalNode { return this.getToken(LatexParser.BEGIN_MATRIX, 0); } public unit_matrix_row_list(): Unit_matrix_rowContext[] { return this.getTypedRuleContexts(Unit_matrix_rowContext) as Unit_matrix_rowContext[]; } public unit_matrix_row(i: number): Unit_matrix_rowContext { return this.getTypedRuleContext(Unit_matrix_rowContext, i) as Unit_matrix_rowContext; } public END_MATRIX(): TerminalNode { return this.getToken(LatexParser.END_MATRIX, 0); } public DOUBLE_BACKSLASH_list(): TerminalNode[] { return this.getTokens(LatexParser.DOUBLE_BACKSLASH); } public DOUBLE_BACKSLASH(i: number): TerminalNode { return this.getToken(LatexParser.DOUBLE_BACKSLASH, i); } public get ruleIndex(): number { return LatexParser.RULE_code_cell_units; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitCode_cell_units) { return visitor.visitCode_cell_units(this); } else { return visitor.visitChildren(this); } } } export class Code_func_defContext extends ParserRuleContext { public _code_cell_units!: Code_cell_unitsContext; public _input_units: Code_cell_unitsContext[] = []; public _output_units!: Code_cell_unitsContext; constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public L_PAREN(): TerminalNode { return this.getToken(LatexParser.L_PAREN, 0); } public R_PAREN(): TerminalNode { return this.getToken(LatexParser.R_PAREN, 0); } public EQ(): TerminalNode { return this.getToken(LatexParser.EQ, 0); } public code_cell_units_list(): Code_cell_unitsContext[] { return this.getTypedRuleContexts(Code_cell_unitsContext) as Code_cell_unitsContext[]; } public code_cell_units(i: number): Code_cell_unitsContext { return this.getTypedRuleContext(Code_cell_unitsContext, i) as Code_cell_unitsContext; } public CMD_MATHRM(): TerminalNode { return this.getToken(LatexParser.CMD_MATHRM, 0); } public L_BRACE(): TerminalNode { return this.getToken(LatexParser.L_BRACE, 0); } public id(): IdContext { return this.getTypedRuleContext(IdContext, 0) as IdContext; } public R_BRACE(): TerminalNode { return this.getToken(LatexParser.R_BRACE, 0); } public COMMA_list(): TerminalNode[] { return this.getTokens(LatexParser.COMMA); } public COMMA(i: number): TerminalNode { return this.getToken(LatexParser.COMMA, i); } public get ruleIndex(): number { return LatexParser.RULE_code_func_def; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitCode_func_def) { return visitor.visitCode_func_def(this); } else { return visitor.visitChildren(this); } } } export class IdContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public ID(): TerminalNode { return this.getToken(LatexParser.ID, 0); } public get ruleIndex(): number { return LatexParser.RULE_id; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitId) { return visitor.visitId(this); } else { return visitor.visitChildren(this); } } } export class NumberContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public NUMBER(): TerminalNode { return this.getToken(LatexParser.NUMBER, 0); } public SUB(): TerminalNode { return this.getToken(LatexParser.SUB, 0); } public get ruleIndex(): number { return LatexParser.RULE_number; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitNumber) { return visitor.visitNumber(this); } else { return visitor.visitChildren(this); } } } export class Number_with_unitsContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public u_block(): U_blockContext { return this.getTypedRuleContext(U_blockContext, 0) as U_blockContext; } public number_(): NumberContext { return this.getTypedRuleContext(NumberContext, 0) as NumberContext; } public id(): IdContext { return this.getTypedRuleContext(IdContext, 0) as IdContext; } public get ruleIndex(): number { return LatexParser.RULE_number_with_units; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitNumber_with_units) { return visitor.visitNumber_with_units(this); } else { return visitor.visitChildren(this); } } } export class AssignContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public id(): IdContext { return this.getTypedRuleContext(IdContext, 0) as IdContext; } public EQ(): TerminalNode { return this.getToken(LatexParser.EQ, 0); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public get ruleIndex(): number { return LatexParser.RULE_assign; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitAssign) { return visitor.visitAssign(this); } else { return visitor.visitChildren(this); } } } export class Assign_listContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public assign_list(): AssignContext[] { return this.getTypedRuleContexts(AssignContext) as AssignContext[]; } public assign(i: number): AssignContext { return this.getTypedRuleContext(AssignContext, i) as AssignContext; } public COMMA_list(): TerminalNode[] { return this.getTokens(LatexParser.COMMA); } public COMMA(i: number): TerminalNode { return this.getToken(LatexParser.COMMA, i); } public get ruleIndex(): number { return LatexParser.RULE_assign_list; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitAssign_list) { return visitor.visitAssign_list(this); } else { return visitor.visitChildren(this); } } } export class Assign_plus_queryContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public assign(): AssignContext { return this.getTypedRuleContext(AssignContext, 0) as AssignContext; } public EQ(): TerminalNode { return this.getToken(LatexParser.EQ, 0); } public u_block(): U_blockContext { return this.getTypedRuleContext(U_blockContext, 0) as U_blockContext; } public get ruleIndex(): number { return LatexParser.RULE_assign_plus_query; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitAssign_plus_query) { return visitor.visitAssign_plus_query(this); } else { return visitor.visitChildren(this); } } } export class QueryContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public EQ(): TerminalNode { return this.getToken(LatexParser.EQ, 0); } public u_block(): U_blockContext { return this.getTypedRuleContext(U_blockContext, 0) as U_blockContext; } public get ruleIndex(): number { return LatexParser.RULE_query; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitQuery) { return visitor.visitQuery(this); } else { return visitor.visitChildren(this); } } } export class EqualityContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public EQ(): TerminalNode { return this.getToken(LatexParser.EQ, 0); } public get ruleIndex(): number { return LatexParser.RULE_equality; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitEquality) { return visitor.visitEquality(this); } else { return visitor.visitChildren(this); } } } export class Piecewise_assignContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public id_list(): IdContext[] { return this.getTypedRuleContexts(IdContext) as IdContext[]; } public id(i: number): IdContext { return this.getTypedRuleContext(IdContext, i) as IdContext; } public EQ(): TerminalNode { return this.getToken(LatexParser.EQ, 0); } public L_PAREN(): TerminalNode { return this.getToken(LatexParser.L_PAREN, 0); } public R_PAREN(): TerminalNode { return this.getToken(LatexParser.R_PAREN, 0); } public piecewise_arg_list(): Piecewise_argContext[] { return this.getTypedRuleContexts(Piecewise_argContext) as Piecewise_argContext[]; } public piecewise_arg(i: number): Piecewise_argContext { return this.getTypedRuleContext(Piecewise_argContext, i) as Piecewise_argContext; } public COMMA_list(): TerminalNode[] { return this.getTokens(LatexParser.COMMA); } public COMMA(i: number): TerminalNode { return this.getToken(LatexParser.COMMA, i); } public get ruleIndex(): number { return LatexParser.RULE_piecewise_assign; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitPiecewise_assign) { return visitor.visitPiecewise_assign(this); } else { return visitor.visitChildren(this); } } } export class Piecewise_argContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public L_PAREN(): TerminalNode { return this.getToken(LatexParser.L_PAREN, 0); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public COMMA(): TerminalNode { return this.getToken(LatexParser.COMMA, 0); } public condition(): ConditionContext { return this.getTypedRuleContext(ConditionContext, 0) as ConditionContext; } public R_PAREN(): TerminalNode { return this.getToken(LatexParser.R_PAREN, 0); } public get ruleIndex(): number { return LatexParser.RULE_piecewise_arg; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitPiecewise_arg) { return visitor.visitPiecewise_arg(this); } else { return visitor.visitChildren(this); } } } export class Trig_functionContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public L_PAREN(): TerminalNode { return this.getToken(LatexParser.L_PAREN, 0); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public R_PAREN(): TerminalNode { return this.getToken(LatexParser.R_PAREN, 0); } public CMD_SIN(): TerminalNode { return this.getToken(LatexParser.CMD_SIN, 0); } public CMD_COS(): TerminalNode { return this.getToken(LatexParser.CMD_COS, 0); } public CMD_TAN(): TerminalNode { return this.getToken(LatexParser.CMD_TAN, 0); } public CMD_COT(): TerminalNode { return this.getToken(LatexParser.CMD_COT, 0); } public CMD_SEC(): TerminalNode { return this.getToken(LatexParser.CMD_SEC, 0); } public CMD_CSC(): TerminalNode { return this.getToken(LatexParser.CMD_CSC, 0); } public CMD_ARCSIN(): TerminalNode { return this.getToken(LatexParser.CMD_ARCSIN, 0); } public CMD_ARCCOS(): TerminalNode { return this.getToken(LatexParser.CMD_ARCCOS, 0); } public CMD_ARCTAN(): TerminalNode { return this.getToken(LatexParser.CMD_ARCTAN, 0); } public CMD_SINH(): TerminalNode { return this.getToken(LatexParser.CMD_SINH, 0); } public CMD_COSH(): TerminalNode { return this.getToken(LatexParser.CMD_COSH, 0); } public CMD_TANH(): TerminalNode { return this.getToken(LatexParser.CMD_TANH, 0); } public CMD_COTH(): TerminalNode { return this.getToken(LatexParser.CMD_COTH, 0); } public BACKSLASH(): TerminalNode { return this.getToken(LatexParser.BACKSLASH, 0); } public get ruleIndex(): number { return LatexParser.RULE_trig_function; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitTrig_function) { return visitor.visitTrig_function(this); } else { return visitor.visitChildren(this); } } } export class Indefinite_integral_cmdContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public L_PAREN_list(): TerminalNode[] { return this.getTokens(LatexParser.L_PAREN); } public L_PAREN(i: number): TerminalNode { return this.getToken(LatexParser.L_PAREN, i); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public R_PAREN_list(): TerminalNode[] { return this.getTokens(LatexParser.R_PAREN); } public R_PAREN(i: number): TerminalNode { return this.getToken(LatexParser.R_PAREN, i); } public id_list(): IdContext[] { return this.getTypedRuleContexts(IdContext) as IdContext[]; } public id(i: number): IdContext { return this.getTypedRuleContext(IdContext, i) as IdContext; } public CMD_INT(): TerminalNode { return this.getToken(LatexParser.CMD_INT, 0); } public CMD_MATHRM(): TerminalNode { return this.getToken(LatexParser.CMD_MATHRM, 0); } public L_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.L_BRACE); } public L_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.L_BRACE, i); } public R_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.R_BRACE); } public R_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.R_BRACE, i); } public CMD_INT_UNDERSCORE(): TerminalNode { return this.getToken(LatexParser.CMD_INT_UNDERSCORE, 0); } public CARET(): TerminalNode { return this.getToken(LatexParser.CARET, 0); } public get ruleIndex(): number { return LatexParser.RULE_indefinite_integral_cmd; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitIndefinite_integral_cmd) { return visitor.visitIndefinite_integral_cmd(this); } else { return visitor.visitChildren(this); } } } export class Integral_cmdContext extends ParserRuleContext { public _lower_lim_expr!: ExprContext; public _upper_lim_expr!: ExprContext; public _integrand_expr!: ExprContext; constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public L_PAREN_list(): TerminalNode[] { return this.getTokens(LatexParser.L_PAREN); } public L_PAREN(i: number): TerminalNode { return this.getToken(LatexParser.L_PAREN, i); } public R_PAREN_list(): TerminalNode[] { return this.getTokens(LatexParser.R_PAREN); } public R_PAREN(i: number): TerminalNode { return this.getToken(LatexParser.R_PAREN, i); } public id_list(): IdContext[] { return this.getTypedRuleContexts(IdContext) as IdContext[]; } public id(i: number): IdContext { return this.getTypedRuleContext(IdContext, i) as IdContext; } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public CMD_MATHRM(): TerminalNode { return this.getToken(LatexParser.CMD_MATHRM, 0); } public L_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.L_BRACE); } public L_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.L_BRACE, i); } public R_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.R_BRACE); } public R_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.R_BRACE, i); } public CMD_INT_UNDERSCORE_SINGLE_CHAR_NUMBER(): TerminalNode { return this.getToken(LatexParser.CMD_INT_UNDERSCORE_SINGLE_CHAR_NUMBER, 0); } public CMD_INT_UNDERSCORE_SINGLE_CHAR_ID(): TerminalNode { return this.getToken(LatexParser.CMD_INT_UNDERSCORE_SINGLE_CHAR_ID, 0); } public CARET_SINGLE_CHAR_ID(): TerminalNode { return this.getToken(LatexParser.CARET_SINGLE_CHAR_ID, 0); } public CARET_SINGLE_CHAR_NUMBER(): TerminalNode { return this.getToken(LatexParser.CARET_SINGLE_CHAR_NUMBER, 0); } public CMD_INT_UNDERSCORE(): TerminalNode { return this.getToken(LatexParser.CMD_INT_UNDERSCORE, 0); } public CARET(): TerminalNode { return this.getToken(LatexParser.CARET, 0); } public get ruleIndex(): number { return LatexParser.RULE_integral_cmd; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitIntegral_cmd) { return visitor.visitIntegral_cmd(this); } else { return visitor.visitChildren(this); } } } export class Sum_prod_cmdContext extends ParserRuleContext { public _start_expr!: ExprContext; public _end_expr!: ExprContext; public _operand_expr!: ExprContext; constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public L_PAREN(): TerminalNode { return this.getToken(LatexParser.L_PAREN, 0); } public R_PAREN(): TerminalNode { return this.getToken(LatexParser.R_PAREN, 0); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public L_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.L_BRACE); } public L_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.L_BRACE, i); } public id(): IdContext { return this.getTypedRuleContext(IdContext, 0) as IdContext; } public EQ(): TerminalNode { return this.getToken(LatexParser.EQ, 0); } public R_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.R_BRACE); } public R_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.R_BRACE, i); } public CMD_SUM_UNDERSCORE(): TerminalNode { return this.getToken(LatexParser.CMD_SUM_UNDERSCORE, 0); } public CMD_PROD_UNDERSCORE(): TerminalNode { return this.getToken(LatexParser.CMD_PROD_UNDERSCORE, 0); } public CARET_SINGLE_CHAR_ID(): TerminalNode { return this.getToken(LatexParser.CARET_SINGLE_CHAR_ID, 0); } public CARET_SINGLE_CHAR_NUMBER(): TerminalNode { return this.getToken(LatexParser.CARET_SINGLE_CHAR_NUMBER, 0); } public CARET(): TerminalNode { return this.getToken(LatexParser.CARET, 0); } public get ruleIndex(): number { return LatexParser.RULE_sum_prod_cmd; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitSum_prod_cmd) { return visitor.visitSum_prod_cmd(this); } else { return visitor.visitChildren(this); } } } export class Derivative_cmdContext extends ParserRuleContext { public _MATHRM_0!: Token; public _MATHRM_1!: Token; constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public CMD_FRAC(): TerminalNode { return this.getToken(LatexParser.CMD_FRAC, 0); } public L_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.L_BRACE); } public L_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.L_BRACE, i); } public R_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.R_BRACE); } public R_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.R_BRACE, i); } public L_PAREN_list(): TerminalNode[] { return this.getTokens(LatexParser.L_PAREN); } public L_PAREN(i: number): TerminalNode { return this.getToken(LatexParser.L_PAREN, i); } public id_list(): IdContext[] { return this.getTypedRuleContexts(IdContext) as IdContext[]; } public id(i: number): IdContext { return this.getTypedRuleContext(IdContext, i) as IdContext; } public R_PAREN_list(): TerminalNode[] { return this.getTokens(LatexParser.R_PAREN); } public R_PAREN(i: number): TerminalNode { return this.getToken(LatexParser.R_PAREN, i); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public CMD_MATHRM_list(): TerminalNode[] { return this.getTokens(LatexParser.CMD_MATHRM); } public CMD_MATHRM(i: number): TerminalNode { return this.getToken(LatexParser.CMD_MATHRM, i); } public get ruleIndex(): number { return LatexParser.RULE_derivative_cmd; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitDerivative_cmd) { return visitor.visitDerivative_cmd(this); } else { return visitor.visitChildren(this); } } } export class N_derivative_cmdContext extends ParserRuleContext { public _MATHRM_0!: Token; public _exp1!: NumberContext; public _single_char_exp1!: Token; public _MATHRM_1!: Token; public _exp2!: NumberContext; public _single_char_exp2!: Token; constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public CMD_FRAC(): TerminalNode { return this.getToken(LatexParser.CMD_FRAC, 0); } public L_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.L_BRACE); } public L_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.L_BRACE, i); } public R_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.R_BRACE); } public R_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.R_BRACE, i); } public L_PAREN_list(): TerminalNode[] { return this.getTokens(LatexParser.L_PAREN); } public L_PAREN(i: number): TerminalNode { return this.getToken(LatexParser.L_PAREN, i); } public id_list(): IdContext[] { return this.getTypedRuleContexts(IdContext) as IdContext[]; } public id(i: number): IdContext { return this.getTypedRuleContext(IdContext, i) as IdContext; } public R_PAREN_list(): TerminalNode[] { return this.getTokens(LatexParser.R_PAREN); } public R_PAREN(i: number): TerminalNode { return this.getToken(LatexParser.R_PAREN, i); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public CMD_MATHRM_list(): TerminalNode[] { return this.getTokens(LatexParser.CMD_MATHRM); } public CMD_MATHRM(i: number): TerminalNode { return this.getToken(LatexParser.CMD_MATHRM, i); } public CARET_SINGLE_CHAR_NUMBER_list(): TerminalNode[] { return this.getTokens(LatexParser.CARET_SINGLE_CHAR_NUMBER); } public CARET_SINGLE_CHAR_NUMBER(i: number): TerminalNode { return this.getToken(LatexParser.CARET_SINGLE_CHAR_NUMBER, i); } public CARET_list(): TerminalNode[] { return this.getTokens(LatexParser.CARET); } public CARET(i: number): TerminalNode { return this.getToken(LatexParser.CARET, i); } public number__list(): NumberContext[] { return this.getTypedRuleContexts(NumberContext) as NumberContext[]; } public number_(i: number): NumberContext { return this.getTypedRuleContext(NumberContext, i) as NumberContext; } public get ruleIndex(): number { return LatexParser.RULE_n_derivative_cmd; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitN_derivative_cmd) { return visitor.visitN_derivative_cmd(this); } else { return visitor.visitChildren(this); } } } export class ArgumentContext extends ParserRuleContext { public _lower!: Token; public _upper!: Token; constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public id(): IdContext { return this.getTypedRuleContext(IdContext, 0) as IdContext; } public EQ(): TerminalNode { return this.getToken(LatexParser.EQ, 0); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public LT_list(): TerminalNode[] { return this.getTokens(LatexParser.LT); } public LT(i: number): TerminalNode { return this.getToken(LatexParser.LT, i); } public LTE_list(): TerminalNode[] { return this.getTokens(LatexParser.LTE); } public LTE(i: number): TerminalNode { return this.getToken(LatexParser.LTE, i); } public get ruleIndex(): number { return LatexParser.RULE_argument; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitArgument) { return visitor.visitArgument(this); } else { return visitor.visitChildren(this); } } } export class ConditionContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public condition_single(): Condition_singleContext { return this.getTypedRuleContext(Condition_singleContext, 0) as Condition_singleContext; } public condition_chain(): Condition_chainContext { return this.getTypedRuleContext(Condition_chainContext, 0) as Condition_chainContext; } public get ruleIndex(): number { return LatexParser.RULE_condition; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitCondition) { return visitor.visitCondition(this); } else { return visitor.visitChildren(this); } } } export class Id_listContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public id_list(): IdContext[] { return this.getTypedRuleContexts(IdContext) as IdContext[]; } public id(i: number): IdContext { return this.getTypedRuleContext(IdContext, i) as IdContext; } public COMMA_list(): TerminalNode[] { return this.getTokens(LatexParser.COMMA); } public COMMA(i: number): TerminalNode { return this.getToken(LatexParser.COMMA, i); } public get ruleIndex(): number { return LatexParser.RULE_id_list; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitId_list) { return visitor.visitId_list(this); } else { return visitor.visitChildren(this); } } } export class GuessContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public id(): IdContext { return this.getTypedRuleContext(IdContext, 0) as IdContext; } public CMD_SIM(): TerminalNode { return this.getToken(LatexParser.CMD_SIM, 0); } public CMD_APPROX(): TerminalNode { return this.getToken(LatexParser.CMD_APPROX, 0); } public number_(): NumberContext { return this.getTypedRuleContext(NumberContext, 0) as NumberContext; } public number_with_units(): Number_with_unitsContext { return this.getTypedRuleContext(Number_with_unitsContext, 0) as Number_with_unitsContext; } public get ruleIndex(): number { return LatexParser.RULE_guess; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitGuess) { return visitor.visitGuess(this); } else { return visitor.visitChildren(this); } } } export class Guess_listContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public guess_list(): GuessContext[] { return this.getTypedRuleContexts(GuessContext) as GuessContext[]; } public guess(i: number): GuessContext { return this.getTypedRuleContext(GuessContext, i) as GuessContext; } public COMMA_list(): TerminalNode[] { return this.getTokens(LatexParser.COMMA); } public COMMA(i: number): TerminalNode { return this.getToken(LatexParser.COMMA, i); } public get ruleIndex(): number { return LatexParser.RULE_guess_list; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitGuess_list) { return visitor.visitGuess_list(this); } else { return visitor.visitChildren(this); } } } export class Condition_singleContext extends ParserRuleContext { public _operator!: Token; constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public LT(): TerminalNode { return this.getToken(LatexParser.LT, 0); } public LTE(): TerminalNode { return this.getToken(LatexParser.LTE, 0); } public GT(): TerminalNode { return this.getToken(LatexParser.GT, 0); } public GTE(): TerminalNode { return this.getToken(LatexParser.GTE, 0); } public get ruleIndex(): number { return LatexParser.RULE_condition_single; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitCondition_single) { return visitor.visitCondition_single(this); } else { return visitor.visitChildren(this); } } } export class Condition_chainContext extends ParserRuleContext { public _lower!: Token; public _upper!: Token; constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public LT_list(): TerminalNode[] { return this.getTokens(LatexParser.LT); } public LT(i: number): TerminalNode { return this.getToken(LatexParser.LT, i); } public LTE_list(): TerminalNode[] { return this.getTokens(LatexParser.LTE); } public LTE(i: number): TerminalNode { return this.getToken(LatexParser.LTE, i); } public GT_list(): TerminalNode[] { return this.getTokens(LatexParser.GT); } public GT(i: number): TerminalNode { return this.getToken(LatexParser.GT, i); } public GTE_list(): TerminalNode[] { return this.getTokens(LatexParser.GTE); } public GTE(i: number): TerminalNode { return this.getToken(LatexParser.GTE, i); } public get ruleIndex(): number { return LatexParser.RULE_condition_chain; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitCondition_chain) { return visitor.visitCondition_chain(this); } else { return visitor.visitChildren(this); } } } export class Matrix_rowContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public AMPERSAND_list(): TerminalNode[] { return this.getTokens(LatexParser.AMPERSAND); } public AMPERSAND(i: number): TerminalNode { return this.getToken(LatexParser.AMPERSAND, i); } public get ruleIndex(): number { return LatexParser.RULE_matrix_row; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitMatrix_row) { return visitor.visitMatrix_row(this); } else { return visitor.visitChildren(this); } } } export class User_functionContext extends ParserRuleContext { public _points_id_0!: Token; public _num_points!: NumberContext; public _points_id_1!: Token; constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public id(): IdContext { return this.getTypedRuleContext(IdContext, 0) as IdContext; } public L_PAREN(): TerminalNode { return this.getToken(LatexParser.L_PAREN, 0); } public R_PAREN(): TerminalNode { return this.getToken(LatexParser.R_PAREN, 0); } public argument_list(): ArgumentContext[] { return this.getTypedRuleContexts(ArgumentContext) as ArgumentContext[]; } public argument(i: number): ArgumentContext { return this.getTypedRuleContext(ArgumentContext, i) as ArgumentContext; } public ID_list(): TerminalNode[] { return this.getTokens(LatexParser.ID); } public ID(i: number): TerminalNode { return this.getToken(LatexParser.ID, i); } public number_(): NumberContext { return this.getTypedRuleContext(NumberContext, 0) as NumberContext; } public COMMA_list(): TerminalNode[] { return this.getTokens(LatexParser.COMMA); } public COMMA(i: number): TerminalNode { return this.getToken(LatexParser.COMMA, i); } public get ruleIndex(): number { return LatexParser.RULE_user_function; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitUser_function) { return visitor.visitUser_function(this); } else { return visitor.visitChildren(this); } } } export class Builtin_functionContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public L_PAREN(): TerminalNode { return this.getToken(LatexParser.L_PAREN, 0); } public R_PAREN(): TerminalNode { return this.getToken(LatexParser.R_PAREN, 0); } public CMD_MATHRM(): TerminalNode { return this.getToken(LatexParser.CMD_MATHRM, 0); } public L_BRACE(): TerminalNode { return this.getToken(LatexParser.L_BRACE, 0); } public id(): IdContext { return this.getTypedRuleContext(IdContext, 0) as IdContext; } public R_BRACE(): TerminalNode { return this.getToken(LatexParser.R_BRACE, 0); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public COMMA_list(): TerminalNode[] { return this.getTokens(LatexParser.COMMA); } public COMMA(i: number): TerminalNode { return this.getToken(LatexParser.COMMA, i); } public get ruleIndex(): number { return LatexParser.RULE_builtin_function; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitBuiltin_function) { return visitor.visitBuiltin_function(this); } else { return visitor.visitChildren(this); } } } export class IndexContext extends ParserRuleContext { public _direct!: ExprContext; public _start!: ExprContext; public _stop!: ExprContext; public _stride!: ExprContext; constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public COLON_list(): TerminalNode[] { return this.getTokens(LatexParser.COLON); } public COLON(i: number): TerminalNode { return this.getToken(LatexParser.COLON, i); } public get ruleIndex(): number { return LatexParser.RULE_index; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitIndex) { return visitor.visitIndex(this); } else { return visitor.visitChildren(this); } } } export class ExprContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public get ruleIndex(): number { return LatexParser.RULE_expr; } public copyFrom(ctx: ExprContext): void { super.copyFrom(ctx); } } export class LnContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public CMD_LN(): TerminalNode { return this.getToken(LatexParser.CMD_LN, 0); } public L_PAREN(): TerminalNode { return this.getToken(LatexParser.L_PAREN, 0); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public R_PAREN(): TerminalNode { return this.getToken(LatexParser.R_PAREN, 0); } public BACKSLASH(): TerminalNode { return this.getToken(LatexParser.BACKSLASH, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitLn) { return visitor.visitLn(this); } else { return visitor.visitChildren(this); } } } export class EmptySubscriptContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public UNDERSCORE(): TerminalNode { return this.getToken(LatexParser.UNDERSCORE, 0); } public L_BRACE(): TerminalNode { return this.getToken(LatexParser.L_BRACE, 0); } public R_BRACE(): TerminalNode { return this.getToken(LatexParser.R_BRACE, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitEmptySubscript) { return visitor.visitEmptySubscript(this); } else { return visitor.visitChildren(this); } } } export class LogContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public CMD_LOG(): TerminalNode { return this.getToken(LatexParser.CMD_LOG, 0); } public L_PAREN(): TerminalNode { return this.getToken(LatexParser.L_PAREN, 0); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public R_PAREN(): TerminalNode { return this.getToken(LatexParser.R_PAREN, 0); } public BACKSLASH(): TerminalNode { return this.getToken(LatexParser.BACKSLASH, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitLog) { return visitor.visitLog(this); } else { return visitor.visitChildren(this); } } } export class BuiltinFunctionContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public builtin_function(): Builtin_functionContext { return this.getTypedRuleContext(Builtin_functionContext, 0) as Builtin_functionContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitBuiltinFunction) { return visitor.visitBuiltinFunction(this); } else { return visitor.visitChildren(this); } } } export class NumberExprContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public number_(): NumberContext { return this.getTypedRuleContext(NumberContext, 0) as NumberContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitNumberExpr) { return visitor.visitNumberExpr(this); } else { return visitor.visitChildren(this); } } } export class RemoveOperatorFontContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public CMD_MATHRM_list(): TerminalNode[] { return this.getTokens(LatexParser.CMD_MATHRM); } public CMD_MATHRM(i: number): TerminalNode { return this.getToken(LatexParser.CMD_MATHRM, i); } public L_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.L_BRACE); } public L_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.L_BRACE, i); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public R_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.R_BRACE); } public R_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.R_BRACE, i); } public DECIMAL_POINT_list(): TerminalNode[] { return this.getTokens(LatexParser.DECIMAL_POINT); } public DECIMAL_POINT(i: number): TerminalNode { return this.getToken(LatexParser.DECIMAL_POINT, i); } public number__list(): NumberContext[] { return this.getTypedRuleContexts(NumberContext) as NumberContext[]; } public number_(i: number): NumberContext { return this.getTypedRuleContext(NumberContext, i) as NumberContext; } public EQ_list(): TerminalNode[] { return this.getTokens(LatexParser.EQ); } public EQ(i: number): TerminalNode { return this.getToken(LatexParser.EQ, i); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitRemoveOperatorFont) { return visitor.visitRemoveOperatorFont(this); } else { return visitor.visitChildren(this); } } } export class FactorialContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public EXCLAMATION(): TerminalNode { return this.getToken(LatexParser.EXCLAMATION, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitFactorial) { return visitor.visitFactorial(this); } else { return visitor.visitChildren(this); } } } export class DerivativeContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public derivative_cmd(): Derivative_cmdContext { return this.getTypedRuleContext(Derivative_cmdContext, 0) as Derivative_cmdContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitDerivative) { return visitor.visitDerivative(this); } else { return visitor.visitChildren(this); } } } export class UserFunctionContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public user_function(): User_functionContext { return this.getTypedRuleContext(User_functionContext, 0) as User_functionContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitUserFunction) { return visitor.visitUserFunction(this); } else { return visitor.visitChildren(this); } } } export class MatrixContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public BEGIN_MATRIX(): TerminalNode { return this.getToken(LatexParser.BEGIN_MATRIX, 0); } public matrix_row_list(): Matrix_rowContext[] { return this.getTypedRuleContexts(Matrix_rowContext) as Matrix_rowContext[]; } public matrix_row(i: number): Matrix_rowContext { return this.getTypedRuleContext(Matrix_rowContext, i) as Matrix_rowContext; } public END_MATRIX(): TerminalNode { return this.getToken(LatexParser.END_MATRIX, 0); } public DOUBLE_BACKSLASH_list(): TerminalNode[] { return this.getTokens(LatexParser.DOUBLE_BACKSLASH); } public DOUBLE_BACKSLASH(i: number): TerminalNode { return this.getToken(LatexParser.DOUBLE_BACKSLASH, i); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitMatrix) { return visitor.visitMatrix(this); } else { return visitor.visitChildren(this); } } } export class SubExprContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public L_PAREN(): TerminalNode { return this.getToken(LatexParser.L_PAREN, 0); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public R_PAREN(): TerminalNode { return this.getToken(LatexParser.R_PAREN, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitSubExpr) { return visitor.visitSubExpr(this); } else { return visitor.visitChildren(this); } } } export class NormContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public DOUBLE_VBAR_list(): TerminalNode[] { return this.getTokens(LatexParser.DOUBLE_VBAR); } public DOUBLE_VBAR(i: number): TerminalNode { return this.getToken(LatexParser.DOUBLE_VBAR, i); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitNorm) { return visitor.visitNorm(this); } else { return visitor.visitChildren(this); } } } export class EmptyPlaceholderContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public CMD_PLACEHOLDER(): TerminalNode { return this.getToken(LatexParser.CMD_PLACEHOLDER, 0); } public L_BRACE(): TerminalNode { return this.getToken(LatexParser.L_BRACE, 0); } public R_BRACE(): TerminalNode { return this.getToken(LatexParser.R_BRACE, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitEmptyPlaceholder) { return visitor.visitEmptyPlaceholder(this); } else { return visitor.visitChildren(this); } } } export class SqrtContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public CMD_SQRT(): TerminalNode { return this.getToken(LatexParser.CMD_SQRT, 0); } public L_BRACE(): TerminalNode { return this.getToken(LatexParser.L_BRACE, 0); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public R_BRACE(): TerminalNode { return this.getToken(LatexParser.R_BRACE, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitSqrt) { return visitor.visitSqrt(this); } else { return visitor.visitChildren(this); } } } export class MissingMultiplicationContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public number_(): NumberContext { return this.getTypedRuleContext(NumberContext, 0) as NumberContext; } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public number_with_units(): Number_with_unitsContext { return this.getTypedRuleContext(Number_with_unitsContext, 0) as Number_with_unitsContext; } public id(): IdContext { return this.getTypedRuleContext(IdContext, 0) as IdContext; } public user_function(): User_functionContext { return this.getTypedRuleContext(User_functionContext, 0) as User_functionContext; } public builtin_function(): Builtin_functionContext { return this.getTypedRuleContext(Builtin_functionContext, 0) as Builtin_functionContext; } public trig_function(): Trig_functionContext { return this.getTypedRuleContext(Trig_functionContext, 0) as Trig_functionContext; } public indefinite_integral_cmd(): Indefinite_integral_cmdContext { return this.getTypedRuleContext(Indefinite_integral_cmdContext, 0) as Indefinite_integral_cmdContext; } public integral_cmd(): Integral_cmdContext { return this.getTypedRuleContext(Integral_cmdContext, 0) as Integral_cmdContext; } public derivative_cmd(): Derivative_cmdContext { return this.getTypedRuleContext(Derivative_cmdContext, 0) as Derivative_cmdContext; } public n_derivative_cmd(): N_derivative_cmdContext { return this.getTypedRuleContext(N_derivative_cmdContext, 0) as N_derivative_cmdContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitMissingMultiplication) { return visitor.visitMissingMultiplication(this); } else { return visitor.visitChildren(this); } } } export class IntegralContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public integral_cmd(): Integral_cmdContext { return this.getTypedRuleContext(Integral_cmdContext, 0) as Integral_cmdContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitIntegral) { return visitor.visitIntegral(this); } else { return visitor.visitChildren(this); } } } export class IndefiniteIntegralContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public indefinite_integral_cmd(): Indefinite_integral_cmdContext { return this.getTypedRuleContext(Indefinite_integral_cmdContext, 0) as Indefinite_integral_cmdContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitIndefiniteIntegral) { return visitor.visitIndefiniteIntegral(this); } else { return visitor.visitChildren(this); } } } export class NumberWithUnitsExprContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public number_with_units(): Number_with_unitsContext { return this.getTypedRuleContext(Number_with_unitsContext, 0) as Number_with_unitsContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitNumberWithUnitsExpr) { return visitor.visitNumberWithUnitsExpr(this); } else { return visitor.visitChildren(this); } } } export class DivideContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public CMD_FRAC(): TerminalNode { return this.getToken(LatexParser.CMD_FRAC, 0); } public L_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.L_BRACE); } public L_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.L_BRACE, i); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public R_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.R_BRACE); } public R_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.R_BRACE, i); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitDivide) { return visitor.visitDivide(this); } else { return visitor.visitChildren(this); } } } export class MultiplyContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public CMD_CDOT(): TerminalNode { return this.getToken(LatexParser.CMD_CDOT, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitMultiply) { return visitor.visitMultiply(this); } else { return visitor.visitChildren(this); } } } export class BaseLogSingleCharContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public L_PAREN(): TerminalNode { return this.getToken(LatexParser.L_PAREN, 0); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public R_PAREN(): TerminalNode { return this.getToken(LatexParser.R_PAREN, 0); } public CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_ID(): TerminalNode { return this.getToken(LatexParser.CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_ID, 0); } public CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_NUMBER(): TerminalNode { return this.getToken(LatexParser.CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_NUMBER, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitBaseLogSingleChar) { return visitor.visitBaseLogSingleChar(this); } else { return visitor.visitChildren(this); } } } export class ExponentContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public id(): IdContext { return this.getTypedRuleContext(IdContext, 0) as IdContext; } public CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT(): TerminalNode { return this.getToken(LatexParser.CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT, 0); } public UNDERSCORE_SUBSCRIPT(): TerminalNode { return this.getToken(LatexParser.UNDERSCORE_SUBSCRIPT, 0); } public CARET_SINGLE_CHAR_ID(): TerminalNode { return this.getToken(LatexParser.CARET_SINGLE_CHAR_ID, 0); } public CARET_SINGLE_CHAR_NUMBER(): TerminalNode { return this.getToken(LatexParser.CARET_SINGLE_CHAR_NUMBER, 0); } public CARET(): TerminalNode { return this.getToken(LatexParser.CARET, 0); } public L_BRACE(): TerminalNode { return this.getToken(LatexParser.L_BRACE, 0); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public R_BRACE(): TerminalNode { return this.getToken(LatexParser.R_BRACE, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitExponent) { return visitor.visitExponent(this); } else { return visitor.visitChildren(this); } } } export class BaseLogContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public CMD_SLASH_LOG_UNDERSCORE(): TerminalNode { return this.getToken(LatexParser.CMD_SLASH_LOG_UNDERSCORE, 0); } public L_BRACE(): TerminalNode { return this.getToken(LatexParser.L_BRACE, 0); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public R_BRACE(): TerminalNode { return this.getToken(LatexParser.R_BRACE, 0); } public L_PAREN(): TerminalNode { return this.getToken(LatexParser.L_PAREN, 0); } public R_PAREN(): TerminalNode { return this.getToken(LatexParser.R_PAREN, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitBaseLog) { return visitor.visitBaseLog(this); } else { return visitor.visitChildren(this); } } } export class InfinityExprContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public INFINITY(): TerminalNode { return this.getToken(LatexParser.INFINITY, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitInfinityExpr) { return visitor.visitInfinityExpr(this); } else { return visitor.visitChildren(this); } } } export class AddContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public ADD(): TerminalNode { return this.getToken(LatexParser.ADD, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitAdd) { return visitor.visitAdd(this); } else { return visitor.visitChildren(this); } } } export class SingleIntSqrtContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public CMD_SQRT_INT(): TerminalNode { return this.getToken(LatexParser.CMD_SQRT_INT, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitSingleIntSqrt) { return visitor.visitSingleIntSqrt(this); } else { return visitor.visitChildren(this); } } } export class SubtractContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public SUB(): TerminalNode { return this.getToken(LatexParser.SUB, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitSubtract) { return visitor.visitSubtract(this); } else { return visitor.visitChildren(this); } } } export class DivideIntsContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public CMD_FRAC_INTS(): TerminalNode { return this.getToken(LatexParser.CMD_FRAC_INTS, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitDivideInts) { return visitor.visitDivideInts(this); } else { return visitor.visitChildren(this); } } } export class NDerivativeContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public n_derivative_cmd(): N_derivative_cmdContext { return this.getTypedRuleContext(N_derivative_cmdContext, 0) as N_derivative_cmdContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitNDerivative) { return visitor.visitNDerivative(this); } else { return visitor.visitChildren(this); } } } export class AbsContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public VBAR_list(): TerminalNode[] { return this.getTokens(LatexParser.VBAR); } public VBAR(i: number): TerminalNode { return this.getToken(LatexParser.VBAR, i); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitAbs) { return visitor.visitAbs(this); } else { return visitor.visitChildren(this); } } } export class MatrixMultiplyContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public expr_list(): ExprContext[] { return this.getTypedRuleContexts(ExprContext) as ExprContext[]; } public expr(i: number): ExprContext { return this.getTypedRuleContext(ExprContext, i) as ExprContext; } public CMD_TIMES(): TerminalNode { return this.getToken(LatexParser.CMD_TIMES, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitMatrixMultiply) { return visitor.visitMatrixMultiply(this); } else { return visitor.visitChildren(this); } } } export class UnaryMinusContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public SUB(): TerminalNode { return this.getToken(LatexParser.SUB, 0); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitUnaryMinus) { return visitor.visitUnaryMinus(this); } else { return visitor.visitChildren(this); } } } export class VariableContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public id(): IdContext { return this.getTypedRuleContext(IdContext, 0) as IdContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitVariable) { return visitor.visitVariable(this); } else { return visitor.visitChildren(this); } } } export class EmptySuperscriptContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public CARET(): TerminalNode { return this.getToken(LatexParser.CARET, 0); } public L_BRACE(): TerminalNode { return this.getToken(LatexParser.L_BRACE, 0); } public R_BRACE(): TerminalNode { return this.getToken(LatexParser.R_BRACE, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitEmptySuperscript) { return visitor.visitEmptySuperscript(this); } else { return visitor.visitChildren(this); } } } export class MatrixIndexContext extends ExprContext { public _row!: IndexContext; public _col!: IndexContext; constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public UNDERSCORE(): TerminalNode { return this.getToken(LatexParser.UNDERSCORE, 0); } public L_BRACE(): TerminalNode { return this.getToken(LatexParser.L_BRACE, 0); } public COMMA(): TerminalNode { return this.getToken(LatexParser.COMMA, 0); } public R_BRACE(): TerminalNode { return this.getToken(LatexParser.R_BRACE, 0); } public index_list(): IndexContext[] { return this.getTypedRuleContexts(IndexContext) as IndexContext[]; } public index(i: number): IndexContext { return this.getTypedRuleContext(IndexContext, i) as IndexContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitMatrixIndex) { return visitor.visitMatrixIndex(this); } else { return visitor.visitChildren(this); } } } export class SumProdContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public sum_prod_cmd(): Sum_prod_cmdContext { return this.getTypedRuleContext(Sum_prod_cmdContext, 0) as Sum_prod_cmdContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitSumProd) { return visitor.visitSumProd(this); } else { return visitor.visitChildren(this); } } } export class TransposeContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public TRANSPOSE(): TerminalNode { return this.getToken(LatexParser.TRANSPOSE, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitTranspose) { return visitor.visitTranspose(this); } else { return visitor.visitChildren(this); } } } export class TrigFunctionContext extends ExprContext { constructor(parser: LatexParser, ctx: ExprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public trig_function(): Trig_functionContext { return this.getTypedRuleContext(Trig_functionContext, 0) as Trig_functionContext; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitTrigFunction) { return visitor.visitTrigFunction(this); } else { return visitor.visitChildren(this); } } } export class U_blockContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public u_expr(): U_exprContext { return this.getTypedRuleContext(U_exprContext, 0) as U_exprContext; } public L_BRACKET(): TerminalNode { return this.getToken(LatexParser.L_BRACKET, 0); } public ALT_L_BRACKET(): TerminalNode { return this.getToken(LatexParser.ALT_L_BRACKET, 0); } public R_BRACKET(): TerminalNode { return this.getToken(LatexParser.R_BRACKET, 0); } public ALT_R_BRACKET(): TerminalNode { return this.getToken(LatexParser.ALT_R_BRACKET, 0); } public get ruleIndex(): number { return LatexParser.RULE_u_block; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitU_block) { return visitor.visitU_block(this); } else { return visitor.visitChildren(this); } } } export class U_insert_matrixContext extends ParserRuleContext { public _numRows!: Token; public _numColumns!: Token; constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public L_BRACKET(): TerminalNode { return this.getToken(LatexParser.L_BRACKET, 0); } public ALT_L_BRACKET(): TerminalNode { return this.getToken(LatexParser.ALT_L_BRACKET, 0); } public U_COMMA(): TerminalNode { return this.getToken(LatexParser.U_COMMA, 0); } public U_CMD_TIMES(): TerminalNode { return this.getToken(LatexParser.U_CMD_TIMES, 0); } public R_BRACKET(): TerminalNode { return this.getToken(LatexParser.R_BRACKET, 0); } public ALT_R_BRACKET(): TerminalNode { return this.getToken(LatexParser.ALT_R_BRACKET, 0); } public U_NUMBER_list(): TerminalNode[] { return this.getTokens(LatexParser.U_NUMBER); } public U_NUMBER(i: number): TerminalNode { return this.getToken(LatexParser.U_NUMBER, i); } public U_ONE_list(): TerminalNode[] { return this.getTokens(LatexParser.U_ONE); } public U_ONE(i: number): TerminalNode { return this.getToken(LatexParser.U_ONE, i); } public get ruleIndex(): number { return LatexParser.RULE_u_insert_matrix; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitU_insert_matrix) { return visitor.visitU_insert_matrix(this); } else { return visitor.visitChildren(this); } } } export class U_fractionContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public U_CMD_FRAC(): TerminalNode { return this.getToken(LatexParser.U_CMD_FRAC, 0); } public U_L_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.U_L_BRACE); } public U_L_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.U_L_BRACE, i); } public U_R_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.U_R_BRACE); } public U_R_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.U_R_BRACE, i); } public U_NUMBER_list(): TerminalNode[] { return this.getTokens(LatexParser.U_NUMBER); } public U_NUMBER(i: number): TerminalNode { return this.getToken(LatexParser.U_NUMBER, i); } public U_ONE(): TerminalNode { return this.getToken(LatexParser.U_ONE, 0); } public U_CMD_FRAC_INTS(): TerminalNode { return this.getToken(LatexParser.U_CMD_FRAC_INTS, 0); } public get ruleIndex(): number { return LatexParser.RULE_u_fraction; } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitU_fraction) { return visitor.visitU_fraction(this); } else { return visitor.visitChildren(this); } } } export class U_exprContext extends ParserRuleContext { constructor(parser?: LatexParser, parent?: ParserRuleContext, invokingState?: number) { super(parent, invokingState); this.parser = parser; } public get ruleIndex(): number { return LatexParser.RULE_u_expr; } public copyFrom(ctx: U_exprContext): void { super.copyFrom(ctx); } } export class UnitSubExprContext extends U_exprContext { constructor(parser: LatexParser, ctx: U_exprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public U_L_PAREN(): TerminalNode { return this.getToken(LatexParser.U_L_PAREN, 0); } public u_expr(): U_exprContext { return this.getTypedRuleContext(U_exprContext, 0) as U_exprContext; } public U_R_PAREN(): TerminalNode { return this.getToken(LatexParser.U_R_PAREN, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitUnitSubExpr) { return visitor.visitUnitSubExpr(this); } else { return visitor.visitChildren(this); } } } export class UnitExponentContext extends U_exprContext { constructor(parser: LatexParser, ctx: U_exprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public u_expr(): U_exprContext { return this.getTypedRuleContext(U_exprContext, 0) as U_exprContext; } public U_CARET(): TerminalNode { return this.getToken(LatexParser.U_CARET, 0); } public U_NUMBER(): TerminalNode { return this.getToken(LatexParser.U_NUMBER, 0); } public U_L_BRACE(): TerminalNode { return this.getToken(LatexParser.U_L_BRACE, 0); } public U_R_BRACE(): TerminalNode { return this.getToken(LatexParser.U_R_BRACE, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitUnitExponent) { return visitor.visitUnitExponent(this); } else { return visitor.visitChildren(this); } } } export class UnitDivideContext extends U_exprContext { constructor(parser: LatexParser, ctx: U_exprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public U_CMD_FRAC(): TerminalNode { return this.getToken(LatexParser.U_CMD_FRAC, 0); } public U_L_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.U_L_BRACE); } public U_L_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.U_L_BRACE, i); } public U_R_BRACE_list(): TerminalNode[] { return this.getTokens(LatexParser.U_R_BRACE); } public U_R_BRACE(i: number): TerminalNode { return this.getToken(LatexParser.U_R_BRACE, i); } public u_expr_list(): U_exprContext[] { return this.getTypedRuleContexts(U_exprContext) as U_exprContext[]; } public u_expr(i: number): U_exprContext { return this.getTypedRuleContext(U_exprContext, i) as U_exprContext; } public U_ONE(): TerminalNode { return this.getToken(LatexParser.U_ONE, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitUnitDivide) { return visitor.visitUnitDivide(this); } else { return visitor.visitChildren(this); } } } export class UnitMultiplyContext extends U_exprContext { constructor(parser: LatexParser, ctx: U_exprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public u_expr_list(): U_exprContext[] { return this.getTypedRuleContexts(U_exprContext) as U_exprContext[]; } public u_expr(i: number): U_exprContext { return this.getTypedRuleContext(U_exprContext, i) as U_exprContext; } public U_CMD_CDOT(): TerminalNode { return this.getToken(LatexParser.U_CMD_CDOT, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitUnitMultiply) { return visitor.visitUnitMultiply(this); } else { return visitor.visitChildren(this); } } } export class UnitNameContext extends U_exprContext { constructor(parser: LatexParser, ctx: U_exprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public U_NAME(): TerminalNode { return this.getToken(LatexParser.U_NAME, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitUnitName) { return visitor.visitUnitName(this); } else { return visitor.visitChildren(this); } } } export class UnitSqrtContext extends U_exprContext { constructor(parser: LatexParser, ctx: U_exprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public U_CMD_SQRT(): TerminalNode { return this.getToken(LatexParser.U_CMD_SQRT, 0); } public U_L_BRACE(): TerminalNode { return this.getToken(LatexParser.U_L_BRACE, 0); } public expr(): ExprContext { return this.getTypedRuleContext(ExprContext, 0) as ExprContext; } public U_R_BRACE(): TerminalNode { return this.getToken(LatexParser.U_R_BRACE, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitUnitSqrt) { return visitor.visitUnitSqrt(this); } else { return visitor.visitChildren(this); } } } export class UnitFractionalExponentContext extends U_exprContext { constructor(parser: LatexParser, ctx: U_exprContext) { super(parser, ctx.parentCtx, ctx.invokingState); super.copyFrom(ctx); } public u_expr(): U_exprContext { return this.getTypedRuleContext(U_exprContext, 0) as U_exprContext; } public U_CARET(): TerminalNode { return this.getToken(LatexParser.U_CARET, 0); } public u_fraction(): U_fractionContext { return this.getTypedRuleContext(U_fractionContext, 0) as U_fractionContext; } public U_L_BRACE(): TerminalNode { return this.getToken(LatexParser.U_L_BRACE, 0); } public U_R_BRACE(): TerminalNode { return this.getToken(LatexParser.U_R_BRACE, 0); } // @Override public accept(visitor: LatexParserVisitor): Result { if (visitor.visitUnitFractionalExponent) { return visitor.visitUnitFractionalExponent(this); } else { return visitor.visitChildren(this); } } } ================================================ FILE: src/parser/LatexParserVisitor.ts ================================================ // @ts-nocheck // Generated from LatexParser.g4 by ANTLR 4.12.0 import {ParseTreeVisitor} from 'antlr4'; import { StatementContext } from "./LatexParser"; import { Scatter_plot_queryContext } from "./LatexParser"; import { Parametric_plot_queryContext } from "./LatexParser"; import { Insert_matrixContext } from "./LatexParser"; import { Fix_mixed_idContext } from "./LatexParser"; import { Unit_matrix_rowContext } from "./LatexParser"; import { Code_cell_unitsContext } from "./LatexParser"; import { Code_func_defContext } from "./LatexParser"; import { IdContext } from "./LatexParser"; import { NumberContext } from "./LatexParser"; import { Number_with_unitsContext } from "./LatexParser"; import { AssignContext } from "./LatexParser"; import { Assign_listContext } from "./LatexParser"; import { Assign_plus_queryContext } from "./LatexParser"; import { QueryContext } from "./LatexParser"; import { EqualityContext } from "./LatexParser"; import { Piecewise_assignContext } from "./LatexParser"; import { Piecewise_argContext } from "./LatexParser"; import { Trig_functionContext } from "./LatexParser"; import { Indefinite_integral_cmdContext } from "./LatexParser"; import { Integral_cmdContext } from "./LatexParser"; import { Sum_prod_cmdContext } from "./LatexParser"; import { Derivative_cmdContext } from "./LatexParser"; import { N_derivative_cmdContext } from "./LatexParser"; import { ArgumentContext } from "./LatexParser"; import { ConditionContext } from "./LatexParser"; import { Id_listContext } from "./LatexParser"; import { GuessContext } from "./LatexParser"; import { Guess_listContext } from "./LatexParser"; import { Condition_singleContext } from "./LatexParser"; import { Condition_chainContext } from "./LatexParser"; import { Matrix_rowContext } from "./LatexParser"; import { User_functionContext } from "./LatexParser"; import { Builtin_functionContext } from "./LatexParser"; import { IndexContext } from "./LatexParser"; import { LnContext } from "./LatexParser"; import { EmptySubscriptContext } from "./LatexParser"; import { LogContext } from "./LatexParser"; import { BuiltinFunctionContext } from "./LatexParser"; import { NumberExprContext } from "./LatexParser"; import { RemoveOperatorFontContext } from "./LatexParser"; import { FactorialContext } from "./LatexParser"; import { DerivativeContext } from "./LatexParser"; import { UserFunctionContext } from "./LatexParser"; import { MatrixContext } from "./LatexParser"; import { SubExprContext } from "./LatexParser"; import { NormContext } from "./LatexParser"; import { EmptyPlaceholderContext } from "./LatexParser"; import { SqrtContext } from "./LatexParser"; import { MissingMultiplicationContext } from "./LatexParser"; import { IntegralContext } from "./LatexParser"; import { IndefiniteIntegralContext } from "./LatexParser"; import { NumberWithUnitsExprContext } from "./LatexParser"; import { DivideContext } from "./LatexParser"; import { MultiplyContext } from "./LatexParser"; import { BaseLogSingleCharContext } from "./LatexParser"; import { ExponentContext } from "./LatexParser"; import { BaseLogContext } from "./LatexParser"; import { InfinityExprContext } from "./LatexParser"; import { AddContext } from "./LatexParser"; import { SingleIntSqrtContext } from "./LatexParser"; import { SubtractContext } from "./LatexParser"; import { DivideIntsContext } from "./LatexParser"; import { NDerivativeContext } from "./LatexParser"; import { AbsContext } from "./LatexParser"; import { MatrixMultiplyContext } from "./LatexParser"; import { UnaryMinusContext } from "./LatexParser"; import { VariableContext } from "./LatexParser"; import { EmptySuperscriptContext } from "./LatexParser"; import { MatrixIndexContext } from "./LatexParser"; import { SumProdContext } from "./LatexParser"; import { TransposeContext } from "./LatexParser"; import { TrigFunctionContext } from "./LatexParser"; import { U_blockContext } from "./LatexParser"; import { U_insert_matrixContext } from "./LatexParser"; import { U_fractionContext } from "./LatexParser"; import { UnitSubExprContext } from "./LatexParser"; import { UnitExponentContext } from "./LatexParser"; import { UnitDivideContext } from "./LatexParser"; import { UnitMultiplyContext } from "./LatexParser"; import { UnitNameContext } from "./LatexParser"; import { UnitSqrtContext } from "./LatexParser"; import { UnitFractionalExponentContext } from "./LatexParser"; /** * This interface defines a complete generic visitor for a parse tree produced * by `LatexParser`. * * @param The return type of the visit operation. Use `void` for * operations with no return type. */ export default class LatexParserVisitor extends ParseTreeVisitor { /** * Visit a parse tree produced by `LatexParser.statement`. * @param ctx the parse tree * @return the visitor result */ visitStatement?: (ctx: StatementContext) => Result; /** * Visit a parse tree produced by `LatexParser.scatter_plot_query`. * @param ctx the parse tree * @return the visitor result */ visitScatter_plot_query?: (ctx: Scatter_plot_queryContext) => Result; /** * Visit a parse tree produced by `LatexParser.parametric_plot_query`. * @param ctx the parse tree * @return the visitor result */ visitParametric_plot_query?: (ctx: Parametric_plot_queryContext) => Result; /** * Visit a parse tree produced by `LatexParser.insert_matrix`. * @param ctx the parse tree * @return the visitor result */ visitInsert_matrix?: (ctx: Insert_matrixContext) => Result; /** * Visit a parse tree produced by `LatexParser.fix_mixed_id`. * @param ctx the parse tree * @return the visitor result */ visitFix_mixed_id?: (ctx: Fix_mixed_idContext) => Result; /** * Visit a parse tree produced by `LatexParser.unit_matrix_row`. * @param ctx the parse tree * @return the visitor result */ visitUnit_matrix_row?: (ctx: Unit_matrix_rowContext) => Result; /** * Visit a parse tree produced by `LatexParser.code_cell_units`. * @param ctx the parse tree * @return the visitor result */ visitCode_cell_units?: (ctx: Code_cell_unitsContext) => Result; /** * Visit a parse tree produced by `LatexParser.code_func_def`. * @param ctx the parse tree * @return the visitor result */ visitCode_func_def?: (ctx: Code_func_defContext) => Result; /** * Visit a parse tree produced by `LatexParser.id`. * @param ctx the parse tree * @return the visitor result */ visitId?: (ctx: IdContext) => Result; /** * Visit a parse tree produced by `LatexParser.number`. * @param ctx the parse tree * @return the visitor result */ visitNumber?: (ctx: NumberContext) => Result; /** * Visit a parse tree produced by `LatexParser.number_with_units`. * @param ctx the parse tree * @return the visitor result */ visitNumber_with_units?: (ctx: Number_with_unitsContext) => Result; /** * Visit a parse tree produced by `LatexParser.assign`. * @param ctx the parse tree * @return the visitor result */ visitAssign?: (ctx: AssignContext) => Result; /** * Visit a parse tree produced by `LatexParser.assign_list`. * @param ctx the parse tree * @return the visitor result */ visitAssign_list?: (ctx: Assign_listContext) => Result; /** * Visit a parse tree produced by `LatexParser.assign_plus_query`. * @param ctx the parse tree * @return the visitor result */ visitAssign_plus_query?: (ctx: Assign_plus_queryContext) => Result; /** * Visit a parse tree produced by `LatexParser.query`. * @param ctx the parse tree * @return the visitor result */ visitQuery?: (ctx: QueryContext) => Result; /** * Visit a parse tree produced by `LatexParser.equality`. * @param ctx the parse tree * @return the visitor result */ visitEquality?: (ctx: EqualityContext) => Result; /** * Visit a parse tree produced by `LatexParser.piecewise_assign`. * @param ctx the parse tree * @return the visitor result */ visitPiecewise_assign?: (ctx: Piecewise_assignContext) => Result; /** * Visit a parse tree produced by `LatexParser.piecewise_arg`. * @param ctx the parse tree * @return the visitor result */ visitPiecewise_arg?: (ctx: Piecewise_argContext) => Result; /** * Visit a parse tree produced by `LatexParser.trig_function`. * @param ctx the parse tree * @return the visitor result */ visitTrig_function?: (ctx: Trig_functionContext) => Result; /** * Visit a parse tree produced by `LatexParser.indefinite_integral_cmd`. * @param ctx the parse tree * @return the visitor result */ visitIndefinite_integral_cmd?: (ctx: Indefinite_integral_cmdContext) => Result; /** * Visit a parse tree produced by `LatexParser.integral_cmd`. * @param ctx the parse tree * @return the visitor result */ visitIntegral_cmd?: (ctx: Integral_cmdContext) => Result; /** * Visit a parse tree produced by `LatexParser.sum_prod_cmd`. * @param ctx the parse tree * @return the visitor result */ visitSum_prod_cmd?: (ctx: Sum_prod_cmdContext) => Result; /** * Visit a parse tree produced by `LatexParser.derivative_cmd`. * @param ctx the parse tree * @return the visitor result */ visitDerivative_cmd?: (ctx: Derivative_cmdContext) => Result; /** * Visit a parse tree produced by `LatexParser.n_derivative_cmd`. * @param ctx the parse tree * @return the visitor result */ visitN_derivative_cmd?: (ctx: N_derivative_cmdContext) => Result; /** * Visit a parse tree produced by `LatexParser.argument`. * @param ctx the parse tree * @return the visitor result */ visitArgument?: (ctx: ArgumentContext) => Result; /** * Visit a parse tree produced by `LatexParser.condition`. * @param ctx the parse tree * @return the visitor result */ visitCondition?: (ctx: ConditionContext) => Result; /** * Visit a parse tree produced by `LatexParser.id_list`. * @param ctx the parse tree * @return the visitor result */ visitId_list?: (ctx: Id_listContext) => Result; /** * Visit a parse tree produced by `LatexParser.guess`. * @param ctx the parse tree * @return the visitor result */ visitGuess?: (ctx: GuessContext) => Result; /** * Visit a parse tree produced by `LatexParser.guess_list`. * @param ctx the parse tree * @return the visitor result */ visitGuess_list?: (ctx: Guess_listContext) => Result; /** * Visit a parse tree produced by `LatexParser.condition_single`. * @param ctx the parse tree * @return the visitor result */ visitCondition_single?: (ctx: Condition_singleContext) => Result; /** * Visit a parse tree produced by `LatexParser.condition_chain`. * @param ctx the parse tree * @return the visitor result */ visitCondition_chain?: (ctx: Condition_chainContext) => Result; /** * Visit a parse tree produced by `LatexParser.matrix_row`. * @param ctx the parse tree * @return the visitor result */ visitMatrix_row?: (ctx: Matrix_rowContext) => Result; /** * Visit a parse tree produced by `LatexParser.user_function`. * @param ctx the parse tree * @return the visitor result */ visitUser_function?: (ctx: User_functionContext) => Result; /** * Visit a parse tree produced by `LatexParser.builtin_function`. * @param ctx the parse tree * @return the visitor result */ visitBuiltin_function?: (ctx: Builtin_functionContext) => Result; /** * Visit a parse tree produced by `LatexParser.index`. * @param ctx the parse tree * @return the visitor result */ visitIndex?: (ctx: IndexContext) => Result; /** * Visit a parse tree produced by the `ln` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitLn?: (ctx: LnContext) => Result; /** * Visit a parse tree produced by the `emptySubscript` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitEmptySubscript?: (ctx: EmptySubscriptContext) => Result; /** * Visit a parse tree produced by the `log` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitLog?: (ctx: LogContext) => Result; /** * Visit a parse tree produced by the `builtinFunction` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitBuiltinFunction?: (ctx: BuiltinFunctionContext) => Result; /** * Visit a parse tree produced by the `numberExpr` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitNumberExpr?: (ctx: NumberExprContext) => Result; /** * Visit a parse tree produced by the `removeOperatorFont` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitRemoveOperatorFont?: (ctx: RemoveOperatorFontContext) => Result; /** * Visit a parse tree produced by the `factorial` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitFactorial?: (ctx: FactorialContext) => Result; /** * Visit a parse tree produced by the `derivative` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitDerivative?: (ctx: DerivativeContext) => Result; /** * Visit a parse tree produced by the `userFunction` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitUserFunction?: (ctx: UserFunctionContext) => Result; /** * Visit a parse tree produced by the `matrix` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitMatrix?: (ctx: MatrixContext) => Result; /** * Visit a parse tree produced by the `subExpr` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitSubExpr?: (ctx: SubExprContext) => Result; /** * Visit a parse tree produced by the `norm` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitNorm?: (ctx: NormContext) => Result; /** * Visit a parse tree produced by the `emptyPlaceholder` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitEmptyPlaceholder?: (ctx: EmptyPlaceholderContext) => Result; /** * Visit a parse tree produced by the `sqrt` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitSqrt?: (ctx: SqrtContext) => Result; /** * Visit a parse tree produced by the `missingMultiplication` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitMissingMultiplication?: (ctx: MissingMultiplicationContext) => Result; /** * Visit a parse tree produced by the `integral` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitIntegral?: (ctx: IntegralContext) => Result; /** * Visit a parse tree produced by the `indefiniteIntegral` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitIndefiniteIntegral?: (ctx: IndefiniteIntegralContext) => Result; /** * Visit a parse tree produced by the `numberWithUnitsExpr` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitNumberWithUnitsExpr?: (ctx: NumberWithUnitsExprContext) => Result; /** * Visit a parse tree produced by the `divide` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitDivide?: (ctx: DivideContext) => Result; /** * Visit a parse tree produced by the `multiply` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitMultiply?: (ctx: MultiplyContext) => Result; /** * Visit a parse tree produced by the `baseLogSingleChar` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitBaseLogSingleChar?: (ctx: BaseLogSingleCharContext) => Result; /** * Visit a parse tree produced by the `exponent` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitExponent?: (ctx: ExponentContext) => Result; /** * Visit a parse tree produced by the `baseLog` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitBaseLog?: (ctx: BaseLogContext) => Result; /** * Visit a parse tree produced by the `infinityExpr` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitInfinityExpr?: (ctx: InfinityExprContext) => Result; /** * Visit a parse tree produced by the `add` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitAdd?: (ctx: AddContext) => Result; /** * Visit a parse tree produced by the `singleIntSqrt` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitSingleIntSqrt?: (ctx: SingleIntSqrtContext) => Result; /** * Visit a parse tree produced by the `subtract` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitSubtract?: (ctx: SubtractContext) => Result; /** * Visit a parse tree produced by the `divideInts` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitDivideInts?: (ctx: DivideIntsContext) => Result; /** * Visit a parse tree produced by the `nDerivative` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitNDerivative?: (ctx: NDerivativeContext) => Result; /** * Visit a parse tree produced by the `abs` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitAbs?: (ctx: AbsContext) => Result; /** * Visit a parse tree produced by the `matrixMultiply` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitMatrixMultiply?: (ctx: MatrixMultiplyContext) => Result; /** * Visit a parse tree produced by the `unaryMinus` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitUnaryMinus?: (ctx: UnaryMinusContext) => Result; /** * Visit a parse tree produced by the `variable` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitVariable?: (ctx: VariableContext) => Result; /** * Visit a parse tree produced by the `emptySuperscript` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitEmptySuperscript?: (ctx: EmptySuperscriptContext) => Result; /** * Visit a parse tree produced by the `matrixIndex` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitMatrixIndex?: (ctx: MatrixIndexContext) => Result; /** * Visit a parse tree produced by the `sumProd` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitSumProd?: (ctx: SumProdContext) => Result; /** * Visit a parse tree produced by the `transpose` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitTranspose?: (ctx: TransposeContext) => Result; /** * Visit a parse tree produced by the `trigFunction` * labeled alternative in `LatexParser.expr`. * @param ctx the parse tree * @return the visitor result */ visitTrigFunction?: (ctx: TrigFunctionContext) => Result; /** * Visit a parse tree produced by `LatexParser.u_block`. * @param ctx the parse tree * @return the visitor result */ visitU_block?: (ctx: U_blockContext) => Result; /** * Visit a parse tree produced by `LatexParser.u_insert_matrix`. * @param ctx the parse tree * @return the visitor result */ visitU_insert_matrix?: (ctx: U_insert_matrixContext) => Result; /** * Visit a parse tree produced by `LatexParser.u_fraction`. * @param ctx the parse tree * @return the visitor result */ visitU_fraction?: (ctx: U_fractionContext) => Result; /** * Visit a parse tree produced by the `unitSubExpr` * labeled alternative in `LatexParser.u_expr`. * @param ctx the parse tree * @return the visitor result */ visitUnitSubExpr?: (ctx: UnitSubExprContext) => Result; /** * Visit a parse tree produced by the `unitExponent` * labeled alternative in `LatexParser.u_expr`. * @param ctx the parse tree * @return the visitor result */ visitUnitExponent?: (ctx: UnitExponentContext) => Result; /** * Visit a parse tree produced by the `unitDivide` * labeled alternative in `LatexParser.u_expr`. * @param ctx the parse tree * @return the visitor result */ visitUnitDivide?: (ctx: UnitDivideContext) => Result; /** * Visit a parse tree produced by the `unitMultiply` * labeled alternative in `LatexParser.u_expr`. * @param ctx the parse tree * @return the visitor result */ visitUnitMultiply?: (ctx: UnitMultiplyContext) => Result; /** * Visit a parse tree produced by the `unitName` * labeled alternative in `LatexParser.u_expr`. * @param ctx the parse tree * @return the visitor result */ visitUnitName?: (ctx: UnitNameContext) => Result; /** * Visit a parse tree produced by the `unitSqrt` * labeled alternative in `LatexParser.u_expr`. * @param ctx the parse tree * @return the visitor result */ visitUnitSqrt?: (ctx: UnitSqrtContext) => Result; /** * Visit a parse tree produced by the `unitFractionalExponent` * labeled alternative in `LatexParser.u_expr`. * @param ctx the parse tree * @return the visitor result */ visitUnitFractionalExponent?: (ctx: UnitFractionalExponentContext) => Result; } ================================================ FILE: src/parser/LatexToSympy.ts ================================================ import { unit, bignumber, format, type Unit } from "mathjs"; import { ErrorListener, TerminalNode, CharStream, CommonTokenStream } from "antlr4"; import LatexParserVisitor from "./LatexParserVisitor"; import type { FieldTypes, Statement, QueryStatement, RangeQueryStatement, UserFunctionRange, AssignmentStatement, ImplicitParameter, UserFunction, FunctionArgumentQuery, FunctionArgumentAssignment, LocalSubstitution, LocalSubstitutionRange, GuessAssignmentStatement, FunctionUnitsQuery, SolveParametersWithGuesses, ErrorStatement, EqualityStatement, EqualityUnitsQueryStatement, SolveParameters, AssignmentList, InsertMatrix, CodeFunctionQueryStatement, CodeFunctionRawQuery, ScatterQueryStatement, ParametricRangeQueryStatement, ScatterXValuesQueryStatement, ScatterYValuesQueryStatement, DataTableInfo, DataTableQueryStatement, SubQueryStatement, CodeCellFunctionStatement, FixMixedId} from "./types"; import { type Insertion, type Replacement, applyEdits, createSubQuery, PYTHON_RESERVED, getBlankStatement } from "./utility"; import { GREEK_CHARS, UNASSIGNABLE, COMPARISON_MAP, UNITS_WITH_OFFSET, TYPE_PARSING_ERRORS, BUILTIN_FUNCTION_MAP, ZERO_PLACEHOLDER, LATEX_TO_UNICODE } from "./constants.js"; import { MAX_MATRIX_COLS } from "../constants"; import type { CodeCellDims, CodeCellDimsSpecific, CodeCellInputOutputDims, CodeCellDimsAny } from "../cells/CodeCell.svelte"; import LatexLexer from "../parser/LatexLexer.js"; import LatexParser, { Code_cell_unitsContext, Code_func_defContext, Fix_mixed_idContext, Unit_matrix_rowContext } from "../parser/LatexParser.js"; import { type GuessContext, type Guess_listContext, IdContext, type Id_listContext, type StatementContext, type QueryContext, AssignContext, type EqualityContext, type ExponentContext, type ArgumentContext, type Builtin_functionContext, type User_functionContext, type IndefiniteIntegralContext, type Indefinite_integral_cmdContext, type Integral_cmdContext, type IntegralContext, type DerivativeContext, type Derivative_cmdContext, type NDerivativeContext, type N_derivative_cmdContext, type Sum_prod_cmdContext, type SumProdContext, type TrigFunctionContext, type UnitExponentContext, type UnitFractionalExponentContext, type SqrtContext, type LnContext, type LogContext, type AbsContext, type UnaryMinusContext, type BaseLogContext, type UnitSqrtContext, type MultiplyContext, Number_with_unitsContext, type UnitMultiplyContext, type DivideContext, type UnitDivideContext, type AddContext, type SubtractContext, type VariableContext, type NumberContext, type NumberExprContext, type NumberWithUnitsExprContext, type SubExprContext, type UnitSubExprContext, type UnitNameContext, type U_blockContext, type Condition_singleContext, type Condition_chainContext, type ConditionContext, type Piecewise_argContext, type Piecewise_assignContext, type Insert_matrixContext, type BaseLogSingleCharContext, type DivideIntsContext, type Assign_listContext, type Assign_plus_queryContext, type SingleIntSqrtContext, type MatrixContext, type IndexContext, type MatrixMultiplyContext, type TransposeContext, type NormContext, type EmptySubscriptContext, type EmptySuperscriptContext, type MissingMultiplicationContext, type BuiltinFunctionContext, type UserFunctionContext, type EmptyPlaceholderContext, type Scatter_plot_queryContext, type Parametric_plot_queryContext, type RemoveOperatorFontContext, type FactorialContext, type InfinityExprContext, type MatrixIndexContext } from "./LatexParser"; import { getBlankMatrixLatex, getConversionFactor } from "../utility"; export type ParsingResult = { pendingNewLatex: boolean; newLatex: string; immediateUpdate: boolean; parsingError: boolean; parsingErrorMessage: string; statement: Statement | null; } export function parseLatex(latex: string, id: number, subId: number, type: FieldTypes, dataTableInfo?: DataTableInfo): ParsingResult { const result = { pendingNewLatex: false, newLatex: "", immediateUpdate: false, statement: null, parsingError: false, parsingErrorMessage: "", } const input = new CharStream(latex); const lexer = new LatexLexer(input); const tokens = new CommonTokenStream(lexer); const parser = new LatexParser(tokens); parser.removeErrorListeners(); // remove ConsoleErrorListener parser.addErrorListener(new LatexErrorListener()); parser.buildParseTrees = true; const tree = parser.statement(); //@ts-ignore let parsingError = Boolean(parser._syntaxErrors); if (!parsingError) { result.parsingError = false; result.parsingErrorMessage = ''; const visitor = new LatexToSympy(latex, id, subId, type, dataTableInfo); result.statement = visitor.visitStatement(tree); if (visitor.parsingError) { result.parsingError = true; result.parsingErrorMessage = visitor.parsingErrorMessage; } if (visitor.pendingEdits.length > 0) { try { result.newLatex = applyEdits(latex, visitor.pendingEdits); result.pendingNewLatex = true; result.immediateUpdate = visitor.immediateUpdate; } catch (e) { console.error(`Error auto updating latex: ${e}`); result.pendingNewLatex = false; // safe fallback } } if (result.statement.type === "insertMatrix") { result.statement = null; result.parsingError = true; // we're in an intermediate state, can't send to sympy just yet } } else { result.statement = null; result.parsingError = true; result.parsingErrorMessage = "Invalid Syntax"; } return result; } type UnitBlockData = { units: string; unitsLatex: string; unitsValid: boolean; dimensions: number[]; } function checkUnits(units: string) { let dimensions: number[]; let unitsValid: boolean; try { const unitsCheck = unit(units); dimensions = unitsCheck.dimensions; unitsValid = true; } catch (e) { unitsValid = false; } return { dimensions: dimensions, unitsValid: unitsValid } } export class LatexErrorListener extends ErrorListener { count = 0; constructor() { super(); this.count = 0; } syntaxError(recognizer, offendingSymbol, line, charPositionInLine, msg, e) { // const stack = recognizer.getRuleInvocationStack(); // stack.reverse(); // console.log("rule stack: "+stack); // console.log("line "+line+":"+charPositionInLine+" at "+ // offendingSymbol+": "+msg); this.count++; } } export class LatexToSympy extends LatexParserVisitor { sourceLatex: string; equationIndex: number; subIndex: number; type: FieldTypes; dataTableInfo: DataTableInfo; paramIndex = 0; assignmentIndex = 0; paramPrefix = "implicit_param__"; implicitParams: ImplicitParameter[] = []; params: string[] = []; variableNameMap: Record = {}; parsingError = false; private parsingErrorMessages = new Set(); subQueries: SubQueryStatement[] = []; subQueryReplacements: [string, Replacement][] = []; inQueryStatement = false; currentDummyVars: Set = new Set(); inMatrixIndex = false; reservedSuffix = "_as_variable"; dummySuffix = "_dummy_var"; greekChars = GREEK_CHARS; unassignable = UNASSIGNABLE; pendingEdits: (Insertion | Replacement)[] = []; immediateUpdate = false; rangeCount = 0; functions: (UserFunction | UserFunctionRange | FunctionUnitsQuery)[] = []; functionIndex = 0; functionPrefix = "function__"; rangeNumPoints = 51; arguments: (FunctionArgumentQuery | FunctionArgumentAssignment)[] = []; localSubs: (LocalSubstitution | LocalSubstitutionRange)[] = []; argumentIndex = 0; argumentPrefix = "argument__"; inputUnits = ""; inputUnitsLatex = ""; parsingDataTableAssign = false; constructor(sourceLatex: string, equationIndex: number, subIndex: number, type: FieldTypes = "math", dataTableInfo?: DataTableInfo ) { super(); this.sourceLatex = sourceLatex; this.equationIndex = equationIndex; this.subIndex = subIndex; this.type = type; this.dataTableInfo = dataTableInfo; } public get parsingErrorMessage(): string { return Array.from(this.parsingErrorMessages).join(", "); } insertTokenCommand(command: string, token: TerminalNode) { this.pendingEdits.push({ type: "insertion", location: token.symbol.start, text: "\\" + command + "{" }); this.pendingEdits.push({ type: "insertion", location: token.symbol.stop+1, text: "}" }); } addParsingErrorMessage(newErrorMessage: string) { this.parsingError = true; this.parsingErrorMessages.add(newErrorMessage); } mapVariableNames(name: string, latex?: string) { latex = latex ?? name; // remove any spaces (mathquill placed spaces before subscripts and // there are spaces after embedded Greek latex chars) name = name.replaceAll(' ', ''); let mappedName: string; if (name === "e") { if (this.currentDummyVars.has('E')) { mappedName = `E${this.dummySuffix}`; } else { mappedName = "E"; // always recognize lowercase e as Euler's number (E in sympy) } } else if (name === "i") { if (this.currentDummyVars.has('I')) { mappedName = `I${this.dummySuffix}`; } else { mappedName = "I"; // always recognize lowercase i sqrt(-1) (I in sympy) } } else if (name === "pi" || name === "π") { mappedName = "pi"; latex = "\\pi"; } else if (PYTHON_RESERVED.has(name)) { // need to ensure that reserved Python id's retain a trailing _ even if reservedSuffix is removed (used for code generation) mappedName = name + '_' + this.reservedSuffix; } else if (this.inMatrixIndex && name ==="end") { mappedName = 'end_matrix_index'; } else { mappedName = name + this.reservedSuffix; } this.variableNameMap[mappedName] = latex; return mappedName; } getNextParName() { return `${this.paramPrefix}${this.equationIndex}_${this.subIndex}_${this.paramIndex++}`; } getNextFunctionName() { return `${this.functionPrefix}${this.equationIndex}_${this.subIndex}_${this .functionIndex++}`; } getNextArgumentName() { return `${this.argumentPrefix}${this.equationIndex}_${this.subIndex}_${this .argumentIndex++}`; } addSubQuery(name: string) { this.subQueries.push(createSubQuery(name)); } visitId = (ctx: IdContext, separatedSubscript?: string): string => { let name: string; let latex: string; latex = name = ctx.ID().toString(); if (!name.startsWith('\\') && this.greekChars.has(name.split('_')[0].trim())) { // need to insert slash before variable that is a greek variable this.pendingEdits.push({ type: "insertion", location: ctx.ID().symbol.start, text: "\\" }); latex = name = "\\" + name; } if (separatedSubscript) { // a subscript appears after an exponent instead of before if (name.includes('_')) { // if there is more than one component of subscript, combine them by removing initial underscore name = name.replace('_', '') + separatedSubscript; latex = latex.replace('_', '') + separatedSubscript; } else { name = name + separatedSubscript; latex = latex + separatedSubscript; } } let primeSuffix = ""; for(const latexSymbol of new Set(name.match(/\\[a-zA-Z]+/g))) { const unicode = LATEX_TO_UNICODE.get(latexSymbol); if (latexSymbol === "\\prime") { for(const tmpMatch of name.match(/\\prime/g)) { primeSuffix += unicode; } name = name.replaceAll(latexSymbol, ""); } else if (!unicode) { this.addParsingErrorMessage(`Parsing error: missing latex symbol ${latexSymbol}. This is likely a bug, report to support@engineeringpaper.xyz`); } else { if ( ["\\hat", "\\bar", "\\vec", "\\dot", "\\ddot", "\\dddot"].includes(latexSymbol) ) { let accentedVar: undefined | string; if (name.startsWith(`${latexSymbol}{i}`)) { accentedVar = "i"; } else if (name.startsWith(`${latexSymbol}{j}`)) { accentedVar = "j"; } if ( accentedVar ) { this.pendingEdits.push( { type: "replacement", location: ctx.ID().symbol.start + latexSymbol.length + 1, deletionLength: 1, text: `\\${accentedVar}math` }); } } name = name.replaceAll(latexSymbol, unicode); } } name = name.replaceAll(/{|}|\^/g, '') + primeSuffix; if (this.type === "function_name" || this.type === "code_func_def") { if (BUILTIN_FUNCTION_MAP.has(name)) { this.addParsingErrorMessage(`Attempt to reassign built-in function name ${name}`) } else if (["e", "i", "pi", "π"].includes(name)) { this.addParsingErrorMessage(`${name} cannot be used as a function name`) } } name = this.mapVariableNames(name, latex); return name; } visitId_list = (ctx: Id_listContext): SolveParameters => { const ids: string[] = []; let i = 0; while (ctx.id(i)) { ids.push(this.visitId(ctx.id(i))); i++; } return {type: "unknowns", ids: ids, numericalSolve: false}; } visitGuess_list = (ctx: Guess_listContext): SolveParametersWithGuesses => { const statements: GuessAssignmentStatement[] = []; const ids: string[] = []; const guesses: string[] = []; let i = 0; while (ctx.guess(i)) { const newStatement = this.visitGuess(ctx.guess(i)); if (newStatement) { statements.push(newStatement); ids.push(newStatement.name); guesses.push(newStatement.guess); } i++; } // Only let the last statement have implicit params, or there will be duplicates // This is true since they are all in this same math field for (const [index, statement] of statements.entries()) { if (index < statements.length -1) { statement.implicitParams = []; } } return { type: "unknowns", ids: ids, numericalSolve: true, guesses: guesses, statements: statements }; } visitGuess = (ctx: GuessContext): GuessAssignmentStatement | null => { if (!ctx.id()) { //user is trying to assign to pi this.addParsingErrorMessage(`Attempt to reassign reserved value pi`); return null; } const name = this.visitId(ctx.id()); if (this.unassignable.has(name)) { //cannot reassign e, pi, or i this.addParsingErrorMessage(`Attempt to reassign reserved variable name ${name}`); } let sympyExpression: string; let guess: string; if (ctx.number_()) { sympyExpression = this.visitNumber(ctx.number_()); if (sympyExpression === ZERO_PLACEHOLDER) { sympyExpression = "0"; } guess = sympyExpression; } else { sympyExpression = this.visitNumber_with_units(ctx.number_with_units()); guess = this.implicitParams.slice(-1)[0].si_value; } const guessStatement: GuessAssignmentStatement = { type: "assignment", name: name, guess: guess, sympy: sympyExpression, implicitParams: this.implicitParams, params: this.params, variableNameMap: {[name]: this.variableNameMap[name]}, functions: this.functions, arguments: this.arguments, localSubs: this.localSubs, isFunctionArgument: false, isFunction: false, isFromPlotCell: false, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false }; return guessStatement; } visitStatement = (ctx: StatementContext): Statement => { if (ctx.assign()) { if (this.type === "math" || this.type === "data_table_expression" || this.type === "data_table_assign") { return this.visitAssign(ctx.assign()); } else if (this.type === "equality") { const sympy = this.visitAssign(ctx.assign()); if (this.functions.length > 0) { this.addParsingErrorMessage('Function syntax is not allowed in a System Solve Cell.') return {type: "error"}; } else { return sympy; } } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.assign_plus_query()) { if (this.type === "math" || this.type === "data_table_expression") { return this.visitAssign_plus_query(ctx.assign_plus_query()); } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.assign_list()) { if (this.type === "math") { return this.visitAssign_list(ctx.assign_list()); } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.query()) { if (this.type === "math" || this.type === "data_table_expression") { return this.visitQuery(ctx.query()); } else if (this.type === "plot") { const statement = this.visitQuery(ctx.query()); if (statement.type === "query" && statement.isRange) { return statement; } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.scatter_plot_query()) { if (this.type === "plot" || this.type === "math") { return this.visitScatter_plot_query(ctx.scatter_plot_query()); } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.parametric_plot_query()) { if (this.type === "plot" || this.type === "math") { return this.visitParametric_plot_query(ctx.parametric_plot_query()); } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.equality()) { if (this.type === "equality") { const sympy = this.visitEquality(ctx.equality()) if (this.functions.length > 0) { this.addParsingErrorMessage('Function syntax is not allowed in a System Solve Cell.') return {type: "error"}; } else { return sympy; } } else if (this.type === "math") { this.addParsingErrorMessage('Equality statements are no longer allowed in math cells, use a System Solve Cell instead.'); return {type: "error"}; } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.u_block()) { if (this.type === "units") { const unitBlockData = this.visit(ctx.u_block()) as UnitBlockData; return { type: "units", ...unitBlockData}; } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.expr()) { if (this.type === "expression" || this.type === "expression_no_blank") { return {type: "expression", sympy: this.visit(ctx.expr()) as string}; } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.number_()) { if (this.type === "number" || this.type === "expression" || this.type === "expression_no_blank") { let value = this.visitNumber(ctx.number_()); if (value === ZERO_PLACEHOLDER) { value = "0"; } return {type: "number", value: value}; } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.id()) { if (this.type === "parameter" || this.type === "function_name" || this.type === "expression" || this.type === "expression_no_blank" || this.type === "data_table_expression") { return {type: "parameter", name: this.visitId(ctx.id()), variableNameMap: this.variableNameMap }; } else if (this.type === "id_list") { return {type: "unknowns", ids: [this.visitId(ctx.id()),], numericalSolve: false}; } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.id_list()) { if (this.type === "id_list") { return this.visitId_list(ctx.id_list()); } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.guess_list()) { if (this.type === "id_list") { return this.visitGuess_list(ctx.guess_list()); } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.guess()) { if (this.type === "id_list") { const guessStatement = this.visitGuess(ctx.guess()); return { type: "unknowns", ids: [guessStatement.name], numericalSolve: true, guesses: [guessStatement.guess], statements: [guessStatement] }; } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.condition()) { if (this.type === "condition") { return {type: "condition", sympy: this.visitCondition(ctx.condition())}; } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.piecewise_assign()) { if (this.type === "piecewise") { return this.visitPiecewise_assign(ctx.piecewise_assign()); } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.code_func_def()) { if (this.type === "code_func_def") { return this.visitCode_func_def(ctx.code_func_def()); } else { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } } else if (ctx.insert_matrix()) { return this.visit(ctx.insert_matrix()) as (InsertMatrix | ErrorStatement) ; } else if (ctx.fix_mixed_id()) { return this.visit(ctx.fix_mixed_id()) as FixMixedId; } else { // this is a blank expression, check if this is okay or should generate an error if ( ["plot", "parameter", "function_name", "expression_no_blank", "condition", "equality", "id_list", "data_table_expression", "code_func_def"].includes(this.type) ) { this.addParsingErrorMessage(TYPE_PARSING_ERRORS[this.type]); return {type: "error"}; } else { // blank is fine, return blank object for statement return getBlankStatement(); } } } visitQuery = (ctx: QueryContext): QueryStatement | RangeQueryStatement | CodeFunctionQueryStatement | DataTableQueryStatement => { this.inQueryStatement = true; let sympy = this.visit(ctx.expr()) as string; this.inQueryStatement = false; const {units, unitsLatex, unitsValid, dimensions} = this.visitU_block(ctx.u_block()); const initialQuery: QueryStatement = { type: "query", implicitParams: this.implicitParams, params: this.params, variableNameMap: this.variableNameMap, functions: this.functions, arguments: this.arguments, localSubs: this.localSubs, units: units, unitsLatex: unitsLatex, isFunctionArgument: false, isFunction: false, isUnitsQuery: false, isEqualityUnitsQuery: false, isScatterXValuesQueryStatement: false, isScatterYValuesQueryStatement: false, isFromPlotCell: this.type === "plot", isSubQuery: false, sympy: sympy, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false, subQueries: this.subQueries, subQueryReplacements: this.subQueryReplacements }; let finalQuery: QueryStatement | DataTableQueryStatement | RangeQueryStatement | CodeFunctionQueryStatement= initialQuery; if (this.rangeCount > 1) { this.addParsingErrorMessage('Only one range may be specified for plotting.'); } else if (this.rangeCount === 1) { const rangeFunction = this.functions.filter(value => (value.isRange))[0] as UserFunctionRange; if (rangeFunction.name !== sympy) { this.addParsingErrorMessage(`Range may only be specified at top level function.`) } else { finalQuery = { ...initialQuery, isRange: true, isParametric: false, cellNum: -1, numPoints: this.rangeNumPoints, freeParameter: rangeFunction.freeParameter, lowerLimitArgument: rangeFunction.lowerLimitArgument, lowerLimitInclusive: rangeFunction.lowerLimitInclusive, upperLimitArgument: rangeFunction.upperLimitArgument, upperLimitInclusive: rangeFunction.upperLimitInclusive, logX: false, unitsQueryFunction: rangeFunction.unitsQueryFunction, inputUnits: this.inputUnits, inputUnitsLatex: this.inputUnitsLatex, outputName: rangeFunction.sympy, } } } else if (this.functions.length === 1 && (this.functions[0] as UserFunction).name === sympy && this.type !== "data_table_expression") { // check to see if this query is a valid CodeFunctionQueryStatement let isCodeFunctionQuery = true; const codeFunction = this.functions[0] as UserFunction; const parameterValues: string[] = []; const parameterUnits: string[] = []; const implicitParamsNames = new Set(this.implicitParams.map(implicitParam => implicitParam.name)); for (const parameter of codeFunction.functionParameters) { const localSub = this.localSubs.find(localSub => localSub.parameter === parameter) as LocalSubstitution; const argument = this.arguments.find(argument => argument.name === localSub.argument && argument.type === "assignment") as FunctionArgumentAssignment; if (!isNaN(Number(argument.sympy))) { parameterValues.push(argument.sympy); parameterUnits.push(""); } else if (implicitParamsNames.has(argument.sympy)) { const implicitParam = this.implicitParams.find(implicitParam => implicitParam.name === argument.sympy); parameterValues.push(implicitParam.original_value); parameterUnits.push(implicitParam.units); } else { isCodeFunctionQuery = false; } } if (isCodeFunctionQuery) { const codeFunctionName = codeFunction.sympy; const codeFunctionRawQuery: CodeFunctionRawQuery = { type: "query", implicitParams: [], params: [codeFunctionName,], variableNameMap: {}, functions: [], arguments: [], localSubs: [], units: units, unitsLatex: unitsLatex, isFunctionArgument: false, isFunction: false, isUnitsQuery: false, isEqualityUnitsQuery: false, isScatterXValuesQueryStatement: false, isScatterYValuesQueryStatement: false, isFromPlotCell: false, sympy: codeFunctionName, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: true }; finalQuery = { ...initialQuery, isCodeFunctionQuery: true, codeFunctionRawQuery: codeFunctionRawQuery, generateCode: false, functionName: codeFunctionName, parameterNames: codeFunction.functionParameters, parameterValues: parameterValues, parameterUnits: parameterUnits, }; } } if (this.type === "data_table_expression" && !finalQuery.isRange && !finalQuery.isCodeFunctionQuery) { finalQuery = { ...(finalQuery as QueryStatement), isDataTableQuery: true, cellNum: -1, colId: this.dataTableInfo?.colId ?? -1, sympy: `_data_table_calc_wrapper_${this.equationIndex}(${finalQuery.sympy})` }; } return finalQuery; } visitScatter_plot_query = (ctx: Scatter_plot_queryContext): ScatterQueryStatement => { let xName: string; let yName: string; let implicitParamsCursor = this.implicitParams.length; let paramsCursor = this.params.length; let functionsCursor = this.functions.length; let argumentsCursor = this.arguments.length; let localSubsCursor = this.localSubs.length; const xExpr = this.visit(ctx.expr(0)) as string; if (ctx.expr(0).children.length === 1 && ctx.expr(0).children[0] instanceof IdContext) { xName = xExpr; } else { xName = "ScatterPlaceholderX"; } const xValuesQuery: ScatterXValuesQueryStatement = { type: "query", equationIndex: this.equationIndex, implicitParams: this.implicitParams.slice(implicitParamsCursor), params: this.params.slice(paramsCursor), variableNameMap: this.variableNameMap, functions: this.functions.slice(functionsCursor), arguments: this.arguments.slice(argumentsCursor), localSubs: this.localSubs.slice(localSubsCursor), units: "", unitsLatex: "", isFunctionArgument: false, isFunction: false, isUnitsQuery: false, isEqualityUnitsQuery: false, isScatterXValuesQueryStatement: true, isScatterYValuesQueryStatement: false, isFromPlotCell: false, isSubQuery: false, sympy: xExpr, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false }; implicitParamsCursor = this.implicitParams.length; paramsCursor = this.params.length; functionsCursor = this.functions.length; argumentsCursor = this.arguments.length; localSubsCursor = this.localSubs.length; const yExpr = this.visit(ctx.expr(1)) as string; if (ctx.expr(1).children.length === 1 && ctx.expr(1).children[0] instanceof IdContext) { yName = yExpr; } else { yName = "ScatterPlaceholderY"; } const yValuesQuery: ScatterYValuesQueryStatement = { type: "query", equationIndex: this.equationIndex, implicitParams: this.implicitParams.slice(implicitParamsCursor), params: this.params.slice(paramsCursor), variableNameMap: this.variableNameMap, functions: this.functions.slice(functionsCursor), arguments: this.arguments.slice(argumentsCursor), localSubs: this.localSubs.slice(localSubsCursor), units: "", unitsLatex: "", isFunctionArgument: false, isFunction: false, isUnitsQuery: false, isEqualityUnitsQuery: false, isScatterXValuesQueryStatement: false, isScatterYValuesQueryStatement: true, isFromPlotCell: false, isSubQuery: false, sympy: yExpr, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false }; let inputUnits: UnitBlockData = {units: "", unitsLatex: "", unitsValid: false, dimensions: []}; let outputUnits: UnitBlockData = {units: "", unitsLatex: "", unitsValid: false, dimensions: []}; if (ctx.u_block(0)) { inputUnits = this.visitU_block(ctx.u_block(0)); outputUnits = this.visitU_block(ctx.u_block(1)); } if (this.rangeCount > 0) { this.addParsingErrorMessage('Range may not be specified for a scatter plot.'); } return { type: "scatterQuery", asLines: Boolean(ctx.AS_LINES()), params: [], variableNameMap: {}, functions: this.functions, arguments: this.arguments, localSubs: this.localSubs, implicitParams: this.implicitParams, equationIndex: this.equationIndex, cellNum: -1, isFromPlotCell: this.type === "plot", xValuesQuery: xValuesQuery, yValuesQuery: yValuesQuery, xName: xName, yName: yName, units: outputUnits.units, unitsLatex: outputUnits.unitsLatex, inputUnits: inputUnits.units, inputUnitsLatex: inputUnits.unitsLatex, }; } visitAssign = (ctx: AssignContext): AssignmentStatement | ErrorStatement | EqualityStatement | QueryStatement | DataTableQueryStatement => { if (this.type === "data_table_expression" && !this.parsingDataTableAssign) { this.parsingDataTableAssign = true; return this.visitAssign_plus_query(ctx); } const implicitParamsCursor = this.implicitParams.length; const paramsCursor = this.params.length; const functionsCursor = this.functions.length; const argumentsCursor = this.arguments.length; const localSubsCursor = this.localSubs.length; const name = this.visitId(ctx.id()); if (this.unassignable.has(name)) { //cannot reassign e, pi, or i this.addParsingErrorMessage(`Attempt to reassign reserved variable name ${name}`); } let sympyExpression = this.visit(ctx.expr()) as string; if (this.dataTableInfo) { sympyExpression = `_data_table_calc_wrapper_${this.equationIndex}(${sympyExpression})`; } if (this.rangeCount > 0) { this.addParsingErrorMessage('Ranges may not be used in assignments.'); } if (this.type === "equality") { this.params.push(name); return this.getEqualityStatement(name, sympyExpression); } else { return { type: "assignment", name: name, sympy: sympyExpression, implicitParams: this.implicitParams.slice(implicitParamsCursor), params: this.params.slice(paramsCursor), variableNameMap: this.variableNameMap, functions: this.functions.slice(functionsCursor), arguments: this.arguments.slice(argumentsCursor), localSubs: this.localSubs.slice(localSubsCursor), isFunctionArgument: false, isFunction: false, isFromPlotCell: false, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false }; } } visitAssign_plus_query = (ctx: Assign_plus_queryContext | AssignContext) : QueryStatement | DataTableQueryStatement | ErrorStatement => { const dataTableAssign = ctx instanceof AssignContext; let assignment: AssignmentStatement | ErrorStatement | EqualityStatement | QueryStatement | DataTableQueryStatement; if (dataTableAssign) { assignment = this.visitAssign(ctx); } else { this.inQueryStatement = true; assignment = this.visitAssign(ctx.assign()); this.inQueryStatement = false; } if (this.type === "data_table_expression" && !dataTableAssign && assignment.type === "query") { const {units, unitsLatex, unitsValid, dimensions} = this.visitU_block(ctx.u_block()); assignment.units = units; assignment.unitsLatex = unitsLatex; return assignment; } else if (assignment.type !== "assignment") { return {type: "error"}; } const {units, unitsLatex, unitsValid, dimensions} = this.visitU_block(dataTableAssign ? null : ctx.u_block()); if (this.type === "data_table_expression") { return { type: "query", implicitParams: [], params: [assignment.name], variableNameMap: {}, functions: [], arguments: [], localSubs: [], units: units, unitsLatex: unitsLatex, isFunctionArgument: false, isFunction: false, isUnitsQuery: false, isEqualityUnitsQuery: false, isScatterXValuesQueryStatement: false, isScatterYValuesQueryStatement: false, isFromPlotCell: false, isSubQuery: false, sympy: assignment.name, isRange: false, isDataTableQuery: true, cellNum: -1, colId: this.dataTableInfo?.colId ?? -1, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false, assignment: assignment }; } else { return { type: "query", implicitParams: [], params: [assignment.name], variableNameMap: {}, functions: [], arguments: [], localSubs: [], units: units, unitsLatex: unitsLatex, isFunctionArgument: false, isFunction: false, isUnitsQuery: false, isEqualityUnitsQuery: false, isScatterXValuesQueryStatement: false, isScatterYValuesQueryStatement: false, isFromPlotCell: false, isSubQuery: false, sympy: assignment.name, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false, assignment: assignment, subQueries: this.subQueries, subQueryReplacements: this.subQueryReplacements }; } } visitAssign_list = (ctx: Assign_listContext): AssignmentList => { const assignments: AssignmentStatement[] = []; let i = 0 while (ctx.assign(i)) { const newAssignment = this.visitAssign(ctx.assign(i)); if (newAssignment.type === "assignment") { assignments.push(newAssignment) } i++; } return { type: "assignmentList", assignments: assignments } } visitEquality = (ctx: EqualityContext): EqualityStatement => { const lhs = this.visit(ctx.expr(0)) as string; const rhs = this.visit(ctx.expr(1)) as string; return this.getEqualityStatement(lhs, rhs); } getEqualityStatement(lhs: string, rhs: string): EqualityStatement { if (this.rangeCount > 0) { this.addParsingErrorMessage('Ranges may not be used in System Solve Cells.'); } const rhsUnitsQuery: EqualityUnitsQueryStatement = { type: "query", isFunctionArgument: false, isFunction: false, isUnitsQuery: false, isEqualityUnitsQuery: true, isScatterXValuesQueryStatement: false, isScatterYValuesQueryStatement: false, equationIndex: this.equationIndex, isFromPlotCell: false, isSubQuery: false, sympy: rhs, functions: this.functions, arguments: this.arguments, localSubs: this.localSubs, units: "", implicitParams: [], // params covered by equality statement below params: this.params, variableNameMap: {}, // covered by equality statement below isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false } const lhsUnitsQuery = {...rhsUnitsQuery}; lhsUnitsQuery.sympy = lhs; return { type: "equality", sympy: `_Eq(${lhs},${rhs})`, implicitParams: this.implicitParams, params: this.params, variableNameMap: this.variableNameMap, functions: this.functions, arguments: this.arguments, localSubs: this.localSubs, isFunctionArgument: false, isFunction: false, equationIndex: this.equationIndex, isFromPlotCell: false, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false, equalityUnitsQueries: [lhsUnitsQuery, rhsUnitsQuery] }; } visitInfinityExpr = (ctx: InfinityExprContext) => { return "oo"; } visitExponent = (ctx: ExponentContext) => { let base: string; let cursor: number; let exponent: string if (ctx.id()) { if (!ctx.CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT()) { base = this.visitId(ctx.id(), ctx.UNDERSCORE_SUBSCRIPT().toString()); this.params.push(base); } else { base = this.visitId(ctx.id(), ctx.CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT().toString().slice(2)); this.params.push(base); } cursor = this.params.length; if (ctx.CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT()) { exponent = this.mapVariableNames(ctx.CARET_SINGLE_CHAR_ID_UNDERSCORE_SUBSCRIPT().toString()[1]); this.params.push(exponent); } else if (ctx.CARET_SINGLE_CHAR_ID()) { exponent = this.mapVariableNames(ctx.CARET_SINGLE_CHAR_ID().toString()[1]); this.params.push(exponent); } else if (ctx.CARET_SINGLE_CHAR_NUMBER()) { exponent = ctx.CARET_SINGLE_CHAR_NUMBER().toString()[1]; } else { exponent = this.visit(ctx.expr(0)) as string; } } else { if (ctx.expr(0).children[0] instanceof Number_with_unitsContext && (ctx.expr(0).children[0] as Number_with_unitsContext).number_()) { if ((ctx.expr(0).children[0] as Number_with_unitsContext).number_().NUMBER().toString().search(/\\cdot|\\times/) >= 0) { this.addParsingErrorMessage("Exponent cannot be applied directly to a number with units when using scientific notation, enclose the number with units in parenthesis and then add the exponent to eliminate this order of operations ambiguity. Correct example: (2*10^2[m])^3"); } } base = this.visit(ctx.expr(0)) as string; cursor = this.params.length; if (ctx.CARET_SINGLE_CHAR_ID()) { exponent = this.mapVariableNames(ctx.CARET_SINGLE_CHAR_ID().toString()[1]); this.params.push(exponent); if (this.inQueryStatement && !this.currentDummyVars.has(exponent)) { this.subQueryReplacements.push([exponent, { type: "replacement", location: ctx.CARET_SINGLE_CHAR_ID().symbol.start+1, deletionLength: 1, text: `{${exponent}}` }]); this.addSubQuery(exponent); } } else if (ctx.CARET_SINGLE_CHAR_NUMBER()) { exponent = ctx.CARET_SINGLE_CHAR_NUMBER().toString()[1]; } else { exponent = this.visit(ctx.expr(1)) as string; } } if (exponent === "-1") { return `_Inverse(${base})`; } return `_Pow(${base},${exponent})`; } _visitIndex = (ctx: IndexContext): {start: string, stop: string, stride: string} => { let start: string; let stop: string; let stride: string; if(ctx._direct) { this.inMatrixIndex = true; start = this.visit(ctx._direct) as string; this.inMatrixIndex = false; stop = 'index_None_'; stride = 'index_None_'; } else { if (ctx._stride) { stride = this.visit(ctx._stride) as string; } else { stride = 'index_None_'; } if (ctx._start) { this.inMatrixIndex = true; start = this.visit(ctx._start) as string; this.inMatrixIndex = false; } else { start = 'index_None_'; } if (ctx._stop) { this.inMatrixIndex = true; stop = this.visit(ctx._stop) as string; this.inMatrixIndex = false; } else { stop = 'index_None_'; } } return {start, stop, stride}; } visitMatrixIndex = (ctx: MatrixIndexContext): string => { const rowData = this._visitIndex(ctx._row); const colData = this._visitIndex(ctx._col); return `_IndexMatrix(${this.visit(ctx.expr())}, ${rowData.start}, ${rowData.stop}, ${rowData.stride}, ${colData.start}, ${colData.stop}, ${colData.stride})`; } visitArgument = (ctx: ArgumentContext): (LocalSubstitution | LocalSubstitutionRange)[] => { const newSubs: (LocalSubstitution | LocalSubstitutionRange)[] = []; const variableName = this.visitId(ctx.id()); const newArguments: (FunctionArgumentQuery | FunctionArgumentAssignment)[] = []; let inputUnitsParameter: ImplicitParameter; let i = 0; const initialParamCursor = this.params.length; while (ctx.expr(i)) { const argumentName = this.getNextArgumentName(); const paramCursor = this.params.length; const expression = this.visit(ctx.expr(i)) as string; newArguments.push({ type: "assignment", name: argumentName, sympy: expression, params: this.params.slice(paramCursor), isFunctionArgument: true, isFunction: false, }); newSubs.push({ type: "localSub", parameter: variableName, argument: argumentName, isRange: false, function: "" }); if (i === 0) { // If user specified number with units for lower limit, use that units choice for y-axis units // Otherwise, SI unit will be used if (this.implicitParams.slice(-1)[0]?.name === expression.replace(/-|\(|\)/g, "")){ inputUnitsParameter = this.implicitParams.slice(-1)[0]; } } i++; } if (newSubs.length === 1) { newSubs[0].isRange = false; this.arguments.push(newArguments[0]); } else { this.rangeCount++; newSubs[0] = { ...newSubs[0], isRange: true, isLowerLimit: true, isInclusiveLimit: ctx._lower.text === "<" ? false : true }; newSubs[1] = { ...newSubs[1], isRange: true, isLowerLimit: false, isInclusiveLimit: ctx._upper.text === "<" ? false : true }; const unitQueryArgument = {...newArguments[0]} // still an assignment, needed for unitsQueryFunction // need to copy since newArguments[0] type changed to query below // Since this assignment is only used for unit checking, the lower limit is used if (isNaN(Number(newArguments[0].sympy))) { unitQueryArgument.sympy = newArguments[0].sympy; } else { // numerical lower limit without units, replace with unitless implicit param to prevent cancelling unitQueryArgument.sympy = this.getUnitlessImplicitParam(newArguments[0].sympy); } unitQueryArgument.params = this.params.slice(initialParamCursor); this.arguments.push(unitQueryArgument); newArguments[0] = { ...newArguments[0], type: "query", isUnitsQuery: false, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false } newArguments[1] = { ...newArguments[1], type: "query", isUnitsQuery: false, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false }; this.arguments.push(...newArguments); if (inputUnitsParameter) { this.inputUnits = inputUnitsParameter.units; this.inputUnitsLatex = inputUnitsParameter.unitsLatex; } } return newSubs; } visitBuiltinFunction = (ctx: BuiltinFunctionContext) => { return this.visit(ctx.builtin_function()); } visitBuiltin_function = (ctx: Builtin_functionContext) => { const initialPendingEditsLength = this.pendingEdits.length; let functionName = this.visitId(ctx.id()); if (functionName === "pi") { this.addParsingErrorMessage("Missing multiplication symbol between pi and opening parenthesis") } const existingPendingEdit = this.pendingEdits.length > initialPendingEditsLength; let originalFunctionName = functionName; if (functionName.endsWith(this.reservedSuffix)) { originalFunctionName = functionName.replace(this.reservedSuffix, ""); } if (!ctx.CMD_MATHRM() && !existingPendingEdit) { this.insertTokenCommand('mathrm', ctx.id().children[0] as TerminalNode); } let argumentString = ""; let i = 0; while (ctx.expr(i)) { if (i > 0) { argumentString += ", "; } argumentString += this.visit(ctx.expr(i)); i++; } if (!BUILTIN_FUNCTION_MAP.has(originalFunctionName)) { return `${functionName}(${argumentString})`; } else { const functionPlaceholderName = BUILTIN_FUNCTION_MAP.get(originalFunctionName); return `${functionPlaceholderName}(${argumentString})`; } } visitUserFunction = (ctx: UserFunctionContext) => { return this.visit(ctx.user_function()); } visitUser_function = (ctx: User_functionContext) => { const functionName = this.getNextFunctionName(); const variableName = this.visitId(ctx.id()); const parameters: string[] = []; let functionLocalSubs: (LocalSubstitution | LocalSubstitutionRange)[] = []; let i = 0; while (ctx.argument(i)) { const newSubs = this.visitArgument(ctx.argument(i)); functionLocalSubs.push(...newSubs); parameters.push(newSubs[0].parameter); i++; } for (const localSub of functionLocalSubs) { localSub.function = functionName; } this.localSubs.push(...functionLocalSubs.filter((value): value is LocalSubstitution => !value.isRange)); if ((new Set(parameters)).size < parameters.length) { this.addParsingErrorMessage('Paremeter name repeated in function call.'); } const rangeParameters = functionLocalSubs.filter(value => value.isRange); const isRange = Boolean(rangeParameters.length === 2) let currentFunction: UserFunction | UserFunctionRange; if (!isRange) { if (ctx._points_id_0) { this.addParsingErrorMessage('Invalid syntax, cannot specify number of points for function without range parameter.'); return functionName; } else { currentFunction = { type: "assignment", name: functionName, sympy: variableName, params: [variableName], variableNameMap: {[variableName]: this.variableNameMap[variableName]}, isFunctionArgument: false, isFunction: true, isRange: false, functionParameters: parameters } } } else { const lowerLimitArg = (rangeParameters as LocalSubstitutionRange[]).filter(value => value.isLowerLimit)[0]; const upperLimitArg = (rangeParameters as LocalSubstitutionRange[]).filter(value => !value.isLowerLimit)[0]; currentFunction = { type: "assignment", name: functionName, sympy: variableName, params: [variableName], variableNameMap: {[variableName]: this.variableNameMap[variableName]}, isFunctionArgument: false, isFunction: true, functionParameters: parameters, isRange: true, freeParameter: lowerLimitArg.parameter, lowerLimitArgument: lowerLimitArg.argument, lowerLimitInclusive: lowerLimitArg.isInclusiveLimit, upperLimitArgument: upperLimitArg.argument, upperLimitInclusive: upperLimitArg.isInclusiveLimit, unitsQueryFunction: this.getNextFunctionName() }; // create a two new functions (one a query of the other) that will have all of the // local subs (including range lower limit), used to establish the output units of the range const unitsFunction: UserFunction = { type: "assignment", name: currentFunction.unitsQueryFunction, sympy: variableName, params: [variableName], variableNameMap: {}, isFunctionArgument: false, isFunction: true, isRange: false, functionParameters: parameters }; const unitsQuery: FunctionUnitsQuery = { type: "query", sympy: unitsFunction.name, params: [unitsFunction.name], isFunctionArgument: false, isFunction: false, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false, units: '', isUnitsQuery: true }; this.functions.push(unitsFunction, unitsQuery); const unitsFunctionLocalSubs: ( LocalSubstitution | LocalSubstitutionRange)[] = functionLocalSubs.filter((sub): sub is LocalSubstitution => !sub.isRange) .map(sub => { return {...sub}}); unitsFunctionLocalSubs.push(lowerLimitArg); unitsFunctionLocalSubs.forEach( sub => sub.function = unitsFunction.name); this.localSubs.push(...unitsFunctionLocalSubs); if (ctx._points_id_0) { if (! (ctx._points_id_0.text === "with" && ctx._points_id_1.text === "points")) { this.addParsingErrorMessage(`Unrecognized keyword combination ${ctx._points_id_0.text} and ${ctx._points_id_1.text}`); } const numPoints = parseFloat(this.visit(ctx._num_points) as string); if (!Number.isInteger(numPoints)) { this.addParsingErrorMessage('Number of range points must be an integer.'); } else if (numPoints < 2) { this.addParsingErrorMessage('Number of range points must be 2 or greater.'); } else { this.rangeNumPoints = numPoints; } } } this.functions.push(currentFunction); this.params.push(functionName); return functionName; } visitParametric_plot_query = (ctx: Parametric_plot_queryContext): ParametricRangeQueryStatement | ErrorStatement => { let numPoints = 100; if (ctx._for_id.text !== "for") { this.addParsingErrorMessage(`Unrecognized keyword: ${ctx._for_id.text}`); return {type: "error"}; } if (ctx._points_id_0) { if (! (ctx._points_id_0.text === "with" && ctx._points_id_1.text === "points")) { this.addParsingErrorMessage(`Unrecognized keyword combination ${ctx._points_id_0.text} and ${ctx._points_id_1.text}`); return {type: "error"}; } numPoints = parseFloat(this.visit(ctx._num_points) as string); if (!Number.isInteger(numPoints)) { this.addParsingErrorMessage('Number of range points must be an integer'); return {type: "error"}; } else if (numPoints < 2) { this.addParsingErrorMessage('Number of range points must be 2 or greater'); return {type: "error"}; } else { this.rangeNumPoints = numPoints; } } const argSubs = this.visitArgument(ctx.argument()); if (argSubs.length !== 2) { this.addParsingErrorMessage('Range must be provided for a parametric plot'); return {type: "error"}; } let userDefinedUnits = false; let xUnits: UnitBlockData; let yUnits: UnitBlockData; if (ctx.u_block(0)) { userDefinedUnits = true; xUnits = this.visitU_block(ctx.u_block(0)); yUnits = this.visitU_block(ctx.u_block(1)); } // Need to parse expressions here to detect parsing errors before constructing plot statements this.visit(ctx.expr(0)); this.visit(ctx.expr(1)); if (this.parsingErrorMessages.size > 0) { // error detected parsing one of the expressions or the argument return {type: "error"}; } if (this.rangeCount > 1) { this.addParsingErrorMessage('Range cannot be specified in the x or y expressions for a parametric plot'); return {type: "error"}; } const assignmentStatements: AssignmentStatement[] = []; let xVariable: string; if (ctx.expr(0).children.length === 1 && ctx.expr(0).children[0] instanceof IdContext) { xVariable = this.sourceLatex.slice( ctx.expr(0).start.column, ctx.expr(0).stop.column + ctx.expr(0).stop.text.length ); } else { xVariable = `ParametricPlaceholderX${this.equationIndex}`; const xAssignment = `${xVariable}=${this.sourceLatex.slice( ctx.expr(0).start.column, ctx.expr(0).stop.column + ctx.expr(0).stop.text.length )}`; const xAssignmentResult = parseLatex(xAssignment, this.equationIndex, 1, "math"); if ( xAssignmentResult.statement?.type === "assignment" && !xAssignmentResult.parsingError ) { assignmentStatements.push(xAssignmentResult.statement); } else { this.addParsingErrorMessage( "Internal error parsing parametric plot syntax, this is a bug. Report to support@engineeringpaper.xyz" ); return { type: "error" }; } } let yVariable: string; if (ctx.expr(1).children.length === 1 && ctx.expr(1).children[0] instanceof IdContext) { yVariable = this.sourceLatex.slice( ctx.expr(1).start.column, ctx.expr(1).stop.column + ctx.expr(1).stop.text.length ); } else { yVariable = `ParametricPlaceholderY${this.equationIndex}`; const yAssignment = `${yVariable}=${this.sourceLatex.slice( ctx.expr(1).start.column, ctx.expr(1).stop.column + ctx.expr(1).stop.text.length )}`; const yAssignmentResult = parseLatex(yAssignment, this.equationIndex, 2, "math"); if ( yAssignmentResult.statement?.type === "assignment" && !yAssignmentResult.parsingError ) { assignmentStatements.push(yAssignmentResult.statement); } else { this.addParsingErrorMessage( "Internal error parsing parametric plot assignment syntax, this is a bug. Report to support@engineeringpaper.xyz" ); return { type: "error" }; } } let xQuery = `${xVariable}(${this.sourceLatex.slice( ctx.argument().start.column, ctx.argument().stop.column + ctx.argument().stop.text.length )}) with ${numPoints} points =`; let yQuery = `${yVariable}(${this.sourceLatex.slice( ctx.argument().start.column, ctx.argument().stop.column + ctx.argument().stop.text.length )}) with ${numPoints} points =`; if (userDefinedUnits) { xQuery += xUnits.unitsLatex; yQuery += yUnits.unitsLatex; } const xQueryResult = parseLatex(xQuery, this.equationIndex, 3, "plot"); const yQueryResult = parseLatex(yQuery, this.equationIndex, 4, "plot"); if (!(xQueryResult.statement?.type === "query" && xQueryResult.statement?.isRange && !xQueryResult.parsingError && yQueryResult.statement?.type === "query" && yQueryResult.statement?.isRange && !yQueryResult.parsingError )) { this.addParsingErrorMessage('Internal error parsing parametric plot syntax, this is a bug. Report to support@engineeringpaper.xyz'); return {type: "error"}; } else { xQueryResult.statement.isParametric = true; yQueryResult.statement.isParametric = true; return { type: "parametricRange", assignmentStatements, rangeQueryStatements: [yQueryResult.statement, xQueryResult.statement] /* order is significant */ }; } } visitIndefiniteIntegral = (ctx: IndefiniteIntegralContext) => { const child = ctx.children[0] as Indefinite_integral_cmdContext; // check that differential symbol is d const diffSymbol = child.id(0).ID().getText(); if (diffSymbol !== "d") { this.addParsingErrorMessage(`Invalid differential symbol ${diffSymbol}`); return ''; } else { if (!child.CMD_MATHRM()) { this.insertTokenCommand('mathrm', child.id(0).children[0] as TerminalNode); } let variableOfIntegration = this.visitId(child.id(1)); this.params.push(variableOfIntegration); this.currentDummyVars.add(variableOfIntegration); let integrand = this.visit(child.expr()); this.currentDummyVars.delete(variableOfIntegration); if (variableOfIntegration === "E" || variableOfIntegration === "I") { const dummyVarName = `${variableOfIntegration}${this.dummySuffix}`; this.variableNameMap[dummyVarName] = this.variableNameMap[variableOfIntegration]; variableOfIntegration = dummyVarName; } this.variableNameMap[`${variableOfIntegration}${this.dummySuffix}`] = this.variableNameMap[variableOfIntegration]; return `_IndefiniteIntegral(${integrand}, ${variableOfIntegration})`; } } visitIntegral = (ctx: IntegralContext) => { const child = ctx.children[0] as Integral_cmdContext; // check that differential symbol is d const diffSymbol = child.id(0).ID().getText(); if (diffSymbol !== "d") { this.addParsingErrorMessage(`Invalid differential symbol ${diffSymbol}`); return ''; } else { if (!child.CMD_MATHRM()) { this.insertTokenCommand('mathrm', child.id(0).children[0] as TerminalNode); } let variableOfIntegration = this.visitId(child.id(1)); this.params.push(variableOfIntegration); let lowerLimit: string; let upperLimit: string; this.currentDummyVars.add(variableOfIntegration); let integrand: string = this.visit(child._integrand_expr) as string; this.currentDummyVars.delete(variableOfIntegration); if (child._lower_lim_expr) { lowerLimit = this.visit(child._lower_lim_expr) as string; } else if (child.CMD_INT_UNDERSCORE_SINGLE_CHAR_ID()) { lowerLimit = child.CMD_INT_UNDERSCORE_SINGLE_CHAR_ID().toString().slice(-1)[0]; lowerLimit = this.mapVariableNames(lowerLimit); this.params.push(lowerLimit); if (this.inQueryStatement && !this.currentDummyVars.has(lowerLimit)) { this.subQueryReplacements.push([lowerLimit, { type: "replacement", location: child.CMD_INT_UNDERSCORE_SINGLE_CHAR_ID().symbol.stop, deletionLength: 1, text: `{${lowerLimit}}` }]); this.addSubQuery(lowerLimit); } } else { lowerLimit = child.CMD_INT_UNDERSCORE_SINGLE_CHAR_NUMBER().toString().slice(-1)[0]; } if (child._upper_lim_expr) { upperLimit = this.visit(child._upper_lim_expr) as string; } else if (child.CARET_SINGLE_CHAR_ID()) { upperLimit = this.mapVariableNames(child.CARET_SINGLE_CHAR_ID().toString()[1]); this.params.push(upperLimit); if (this.inQueryStatement && !this.currentDummyVars.has(upperLimit)) { this.subQueryReplacements.push([upperLimit, { type: "replacement", location: child.CARET_SINGLE_CHAR_ID().symbol.start+1, deletionLength: 1, text: `{${upperLimit}}` }]); this.addSubQuery(upperLimit); } } else { upperLimit = child.CARET_SINGLE_CHAR_NUMBER().toString()[1]; } if (variableOfIntegration === "E" || variableOfIntegration === "I") { const dummyVarName = `${variableOfIntegration}${this.dummySuffix}`; this.variableNameMap[dummyVarName] = this.variableNameMap[variableOfIntegration]; variableOfIntegration = dummyVarName; } this.variableNameMap[`${variableOfIntegration}${this.dummySuffix}`] = this.variableNameMap[variableOfIntegration]; return `_Integral(${integrand}, ${lowerLimit}, ${upperLimit}, ${variableOfIntegration})`; } } visitDerivative = (ctx: DerivativeContext) => { const child = ctx.children[0] as Derivative_cmdContext; // check that both differential symbols are both d const diffSymbol1 = child.id(0).ID().getText(); const diffSymbol2 = child.id(1).ID().getText(); if (diffSymbol1 !== "d" || diffSymbol2 !== "d") { this.addParsingErrorMessage(`Invalid differential symbol combination ${diffSymbol1} and ${diffSymbol2}`); return ''; } else { if (!child._MATHRM_0) { this.insertTokenCommand('mathrm', child.id(0).children[0] as TerminalNode); } if (!child._MATHRM_1) { this.insertTokenCommand('mathrm', child.id(1).children[0] as TerminalNode); } let variableOfDifferentiation = this.visitId(child.id(2)); this.params.push(variableOfDifferentiation); this.currentDummyVars.add(variableOfDifferentiation); let operand = this.visit(child.expr()); this.currentDummyVars.delete(variableOfDifferentiation); if (variableOfDifferentiation === "E" || variableOfDifferentiation === "I") { const dummyVarName = `${variableOfDifferentiation}${this.dummySuffix}`; this.variableNameMap[dummyVarName] = this.variableNameMap[variableOfDifferentiation]; variableOfDifferentiation = dummyVarName; } this.variableNameMap[`${variableOfDifferentiation}${this.dummySuffix}`] = this.variableNameMap[variableOfDifferentiation]; return `_Derivative(${operand}, ${variableOfDifferentiation})`; } } visitNDerivative = (ctx: NDerivativeContext) => { const child = ctx.children[0] as N_derivative_cmdContext; let exp1: number; let exp2: number if (child._single_char_exp1 ) { exp1 = parseFloat(child._single_char_exp1.text[1]); } else { exp1 = parseFloat(this.visitNumber(child._exp1)); } if (child._single_char_exp2) { exp2 = parseFloat(child._single_char_exp2.text[1]); } else { exp2 = parseFloat(this.visitNumber(child._exp2)); } const diffSymbol1 = child.id(0).ID().getText(); const diffSymbol2 = child.id(1).ID().getText(); // check that both differential symbols are both d if (diffSymbol1 !== "d" || diffSymbol2 !== "d") { this.addParsingErrorMessage(`Invalid differential symbol combination ${diffSymbol1} and ${diffSymbol2}`); return ''; } else if (!Number.isInteger(exp1) || !Number.isInteger(exp1) || exp1 !== exp2) { this.addParsingErrorMessage(`Invalid differential order combination ${exp1} and ${exp2}`); return ''; } else if(exp1 <= 0) { this.addParsingErrorMessage(`Invalid differential order ${exp1}`); return ''; } else { if (!child._MATHRM_0) { this.insertTokenCommand('mathrm', child.id(0).children[0] as TerminalNode); } if (!child._MATHRM_1) { this.insertTokenCommand('mathrm', child.id(1).children[0] as TerminalNode); } let variableOfDifferentiation = this.visitId(child.id(2)); this.params.push(variableOfDifferentiation); this.currentDummyVars.add(variableOfDifferentiation); let operand = this.visit(child.expr()); this.currentDummyVars.delete(variableOfDifferentiation); if (variableOfDifferentiation === "E" || variableOfDifferentiation === "I") { const dummyVarName = `${variableOfDifferentiation}${this.dummySuffix}`; this.variableNameMap[dummyVarName] = this.variableNameMap[variableOfDifferentiation]; variableOfDifferentiation = dummyVarName; } this.variableNameMap[`${variableOfDifferentiation}${this.dummySuffix}`] = this.variableNameMap[variableOfDifferentiation]; return `_Derivative(${operand}, ${variableOfDifferentiation}, ${exp1})`; } } visitSumProd = (ctx: SumProdContext) => { const child = ctx.children[0] as Sum_prod_cmdContext; let dummyVariable = this.visitId(child.id()); this.currentDummyVars.add(dummyVariable); const operand: string = this.visit(child._operand_expr) as string; this.currentDummyVars.delete(dummyVariable); const start = this.visit(child._start_expr) as string; let end: string; if (child._end_expr) { end = this.visit(child._end_expr) as string; } else if (child.CARET_SINGLE_CHAR_ID()) { end = this.mapVariableNames(child.CARET_SINGLE_CHAR_ID().toString()[1]); this.params.push(end); if (this.inQueryStatement && !this.currentDummyVars.has(end)) { this.subQueryReplacements.push([end, { type: "replacement", location: child.CARET_SINGLE_CHAR_ID().symbol.start+1, deletionLength: 1, text: `{${end}}` }]); this.addSubQuery(end); } } else { end = child.CARET_SINGLE_CHAR_NUMBER().toString()[1]; } const functionName = child.CMD_SUM_UNDERSCORE() ? "_summation" : "_product"; if (dummyVariable === "E" || dummyVariable === "I") { const modifiedDummyVarName = `${dummyVariable}${this.dummySuffix}`; this.variableNameMap[modifiedDummyVarName] = this.variableNameMap[dummyVariable]; dummyVariable = modifiedDummyVarName; } this.variableNameMap[`${dummyVariable}${this.dummySuffix}`] = this.variableNameMap[dummyVariable]; return `${functionName}(${operand}, ${dummyVariable}, ${start}, ${end})`; } visitTrigFunction = (ctx: TrigFunctionContext) => { let trigFunctionName; if (ctx.trig_function().BACKSLASH()) { trigFunctionName = ctx.trig_function().children[1].toString(); } else { trigFunctionName = ctx.trig_function().children[0].toString(); this.pendingEdits.push({ type: "insertion", location: ctx.trig_function().start.column, text: "\\" }); } if (trigFunctionName.startsWith("arc")) { trigFunctionName = "_a" + trigFunctionName.slice(3); } return `${trigFunctionName}(${this.visit(ctx.trig_function().expr())})`; } visitTranspose = (ctx: TransposeContext) => { return `_Transpose(${this.visit(ctx.expr())})`; } visitFactorial = (ctx: FactorialContext) => { return `_factorial(${this.visit(ctx.expr())})`; } visitUnitExponent = (ctx: UnitExponentContext) => { return `${this.visit(ctx.u_expr())}^${ctx.U_NUMBER().toString()}`; } visitUnitFractionalExponent = (ctx: UnitFractionalExponentContext) => { let exponentValue: number; const u_fraction = ctx.u_fraction(); if (u_fraction.U_CMD_FRAC_INTS()) { const token = u_fraction.U_CMD_FRAC_INTS().getText(); exponentValue = parseInt(token.slice(-2)[0])/parseInt(token.slice(-1)[0]) }else if (u_fraction.U_ONE()) { exponentValue = 1/parseFloat(u_fraction.U_NUMBER(0).getText()); } else { exponentValue = parseFloat(u_fraction.U_NUMBER(0).getText())/parseFloat(u_fraction.U_NUMBER(1).getText()); } return `${this.visit(ctx.u_expr())}^${exponentValue}`; } visitSingleIntSqrt = (ctx: SingleIntSqrtContext) => { return `sqrt(${ctx.CMD_SQRT_INT().getText().slice(-1)[0]})`; } visitSqrt = (ctx: SqrtContext) => { return `sqrt(${this.visit(ctx.expr())})`; } visitMatrix = (ctx: MatrixContext) => { let sympy = "Matrix(["; let row = 0; while (ctx.matrix_row(row)) { sympy += "["; let col = 0; while (ctx.matrix_row(row).expr(col)) { sympy += this.visit(ctx.matrix_row(row).expr(col)) + ','; col++; } sympy += "],"; row++; } sympy += "])"; return sympy; } visitLn = (ctx: LnContext) => { if (!ctx.BACKSLASH()) { this.pendingEdits.push({ type: "insertion", location: ctx.CMD_LN().parentCtx.start.column, text: '\\' }) } return `_log(${this.visit(ctx.expr())})`; } visitLog = (ctx: LogContext) => { if (!ctx.BACKSLASH()) { this.pendingEdits.push({ type: "insertion", location: ctx.CMD_LOG().parentCtx.start.column, text: '\\' }) } return `_log(${this.visit(ctx.expr())},10)`; } visitAbs = (ctx: AbsContext) => { return `_Abs(${this.visit(ctx.expr())})`; } visitNorm = (ctx: NormContext) => { return `_norm(${this.visit(ctx.expr())})`; } visitUnaryMinus = (ctx: UnaryMinusContext) => { return `(-(${this.visit(ctx.expr())}))`; } visitBaseLog = (ctx: BaseLogContext) => { return `_log(${this.visit(ctx.expr(1))},${this.visit(ctx.expr(0))})`; } visitBaseLogSingleChar = (ctx: BaseLogSingleCharContext) => { let base: string; if (ctx.CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_NUMBER()) { base = ctx.CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_NUMBER().toString().slice(-1)[0]; } else { base = ctx.CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_ID().toString().slice(-1)[0] base = this.mapVariableNames(base); this.params.push(base); if (this.inQueryStatement && !this.currentDummyVars.has(base)) { this.subQueryReplacements.push([base, { type: "replacement", location: ctx.CMD_SLASH_LOG_UNDERSCORE_SINGLE_CHAR_ID().symbol.stop, deletionLength: 1, text: `{${base}}` }]); this.addSubQuery(base); } } return `_log(${this.visit(ctx.expr())},${base})`; } visitUnitSqrt = (ctx: UnitSqrtContext) => { return `${this.visit(ctx.expr())}^.5`; } visitMultiply = (ctx: MultiplyContext) => { return `_multiply(${this.visit(ctx.expr(0))}, ${this.visit(ctx.expr(1))})`; } visitMatrixMultiply = (ctx: MatrixMultiplyContext) => { return `_mat_multiply(${this.visit(ctx.expr(0))}, ${this.visit(ctx.expr(1))})`; } visitUnitMultiply = (ctx: UnitMultiplyContext) => { return `${this.visit(ctx.u_expr(0))}*${this.visit(ctx.u_expr(1))}`; } visitDivide = (ctx: DivideContext) => { return `(${this.visit(ctx.expr(0))})/(${this.visit(ctx.expr(1))})`; } visitDivideInts = (ctx: DivideIntsContext) => { const token = ctx.CMD_FRAC_INTS().getText(); return `${token.slice(-2)[0]}/${token.slice(-1)[0]}` } visitUnitDivide = (ctx: UnitDivideContext) => { if (ctx.U_ONE()) { // (in/in) represents unitless instead of 1 since mathjs cannot properly parse 1 return `(in/in)/(${this.visit(ctx.u_expr(0))})`; } else { return `(${this.visit(ctx.u_expr(0))})/(${this.visit(ctx.u_expr(1))})`; } } visitAdd = (ctx: AddContext) => { return `_add(${this.visit(ctx.expr(0))}, ${this.visit(ctx.expr(1))})`; } visitSubtract = (ctx: SubtractContext) => { return `_add(${this.visit(ctx.expr(0))}, -(${this.visit(ctx.expr(1))}))`; } visitVariable = (ctx: VariableContext) => { const name = this.visitId(ctx.id()); this.params.push(name); if (this.dataTableInfo && this.dataTableInfo.colVars.includes(name)) { return `_data_table_id_wrapper(${name})`; } else { if (this.inQueryStatement && !this.currentDummyVars.has(name)) { const idToken = ctx.id().children[0] as TerminalNode; this.subQueryReplacements.push([name, { type: "replacement", location: idToken.symbol.start, deletionLength: idToken.symbol.stop - idToken.symbol.start + 1, text: this.sourceLatex.slice(idToken.symbol.start, idToken.symbol.stop+1) }]); this.addSubQuery(name); } return name; } } visitNumber_with_units = (ctx: Number_with_unitsContext): string => { const newParamName = this.getNextParName(); let numWithUnits: Unit; let si_value: string; const unitBlockData = this.visit(ctx.u_block()) as UnitBlockData; let original_value: string; if(ctx.id()) { original_value = "1"; } else { original_value = this.visitNumber(ctx.number_()); } if (original_value === ZERO_PLACEHOLDER) { original_value = "0"; } if (unitBlockData.unitsValid) { try{ numWithUnits = unit( bignumber(original_value), unitBlockData.units ); if (UNITS_WITH_OFFSET.has(unitBlockData.units)) { // temps with offset need special handling si_value = format(numWithUnits.toNumeric('K')); if (ctx.id()) { this.addParsingErrorMessage('Only absolute temperature units may be applied directly to the pi symbol'); } } else { si_value = format(numWithUnits.value); } } catch(e) { this.addParsingErrorMessage(`Error parsing '${bignumber(original_value)} ${unitBlockData.units}'. This is an error that indicates a possible bug, report to support@engineeringpaper.xyz`) } } this.implicitParams.push({ name: newParamName, units: unitBlockData.units, unitsLatex: unitBlockData.unitsLatex, dimensions: unitBlockData.dimensions, original_value: original_value, si_value: si_value, }); this.params.push(newParamName); if (ctx.id()) { const id = this.visitId(ctx.id()); if (id !== "pi") { this.addParsingErrorMessage('Units cannot be applied directly to a variable name'); } return `(pi*${newParamName})`; } else { return newParamName; } } getUnitlessImplicitParam(valueString:string): string { const newParamName = this.getNextParName(); const units = 'm/m'; const mathjsUnits = unit(units); let param: ImplicitParameter = { name: newParamName, units: units, unitsLatex: "", dimensions: mathjsUnits.dimensions, original_value: valueString, si_value: valueString }; this.implicitParams.push(param); this.params.push(param.name); return newParamName; } visitNumber = (ctx: NumberContext): string => { const stringNumber = ctx.NUMBER().toString().replace(/ |{|}/g,'').replace(/\\cdot10\^|\\times10\^/g,'e'); if (this.type === "data_table_assign" && Number(stringNumber) === 0) { return ZERO_PLACEHOLDER; } if (!ctx.SUB()) { return stringNumber; } else { return `-${stringNumber}`; } } visitNumberExpr = (ctx: NumberExprContext) => { return this.visit(ctx.number_()); } visitNumberWithUnitsExpr = (ctx: NumberWithUnitsExprContext) => { return this.visit(ctx.number_with_units()); } visitSubExpr = (ctx: SubExprContext) => { return `(${this.visit(ctx.expr())})`; } visitUnitSubExpr = (ctx: UnitSubExprContext) => { return `(${this.visit(ctx.u_expr())})`; } visitUnitName = (ctx: UnitNameContext) => { return ctx.U_NAME().toString(); } visitU_block = (ctx: U_blockContext | null): UnitBlockData => { let units = ""; let unitsLatex = ""; let unitsValidReturn = false; let unitsDimensions: number[] = []; if(ctx) { units = this.visit(ctx.u_expr()) as string; unitsLatex = `\\left${this.sourceLatex.slice( ctx.start.column, ctx.stop.column + ctx.stop.text.length )}`; const { dimensions, unitsValid } = checkUnits(units); if (unitsValid) { unitsDimensions = dimensions; unitsValidReturn = true; } else { this.addParsingErrorMessage(`Unknown Dimension ${units}`); unitsValidReturn = false; } } return { units: units, unitsLatex: unitsLatex, unitsValid: unitsValidReturn, dimensions: unitsDimensions, } } visitCondition_single = (ctx: Condition_singleContext) => { return `${COMPARISON_MAP.get(ctx._operator.text)}(${this.visit(ctx.expr(0))}, ${this.visit(ctx.expr(1))})`; } visitCondition_chain = (ctx: Condition_chainContext) => { const exp0 = this.visit(ctx.expr(0)); const exp1 = this.visit(ctx.expr(1)); const exp2 = this.visit(ctx.expr(2)); const comparison1 = `${COMPARISON_MAP.get(ctx._lower.text)}(${exp0}, ${exp1})`; const comparison2 = `${COMPARISON_MAP.get(ctx._upper.text)}(${exp1}, ${exp2})`; return `_And(${comparison1}, ${comparison2})`; } visitCondition = (ctx: ConditionContext) => { if (ctx.condition_single()) { return this.visitCondition_single(ctx.condition_single()); } else { return this.visitCondition_chain(ctx.condition_chain()); } } visitPiecewise_arg = (ctx: Piecewise_argContext) => { return `(${this.visit(ctx.expr())}, ${this.visit(ctx.condition())})`; } visitPiecewise_assign = (ctx: Piecewise_assignContext): AssignmentStatement | ErrorStatement => { const name = this.visitId(ctx.id(0)); if (this.visit(ctx.id(1)) !== "piecewise") { this.addParsingErrorMessage("Internal Error: Expected 'piecewise' as function name"); } if (this.unassignable.has(name)) { //cannot reassign e, pi, or i this.addParsingErrorMessage(`Attempt to reassign reserved variable name ${name}`); } let args = "" let i = 0; while (ctx.piecewise_arg(i)) { if (i > 0) { args += ", "; } args += this.visit(ctx.piecewise_arg(i)); i++; } const sympyExpression = `_Piecewise(${args})`; if (this.rangeCount > 0) { this.addParsingErrorMessage('Ranges may not be used in piecewise epxressions.'); } return { type: "assignment", name: name, sympy: sympyExpression, implicitParams: this.implicitParams, params: this.params, variableNameMap: this.variableNameMap, functions: this.functions, arguments: this.arguments, localSubs: this.localSubs, isFunctionArgument: false, isFunction: false, isFromPlotCell: false, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false }; } visitInsert_matrix = (ctx: Insert_matrixContext): (InsertMatrix | ErrorStatement) => { let error = false; let i = 0; while (ctx.u_insert_matrix(i)) { const child = ctx.u_insert_matrix(i); i++; const numRows = parseFloat(child._numRows.text); const numColumns = parseFloat(child._numColumns.text); if (!Number.isInteger(numRows) || !Number.isInteger(numColumns)) { this.addParsingErrorMessage('The requested number of rows or columns for a matrix must be integer values'); error = true; continue; } if (numRows <= 0 || numColumns <= 0) { this.addParsingErrorMessage('The requested number of rows or columns for a matrix must be positive values'); error = true; continue; } if (numColumns > MAX_MATRIX_COLS) { this.addParsingErrorMessage(`Matrices are limited to ${MAX_MATRIX_COLS} columns. The number of rows is unlimited`); error = true; continue; } const blankMatrixLatex = getBlankMatrixLatex(numRows, numColumns); let startLocation: number; if (child.L_BRACKET()) { startLocation = child.L_BRACKET().symbol.start; } else { startLocation = child.ALT_L_BRACKET().symbol.start; } // check for a directly proceeding '\left' const leftLocation = this.sourceLatex.slice(0, startLocation).lastIndexOf("\\left"); if (this.sourceLatex.slice(leftLocation, startLocation).trim() === "\\left") { startLocation = leftLocation; } let endLocation: number; if (child.R_BRACKET()) { endLocation = child.R_BRACKET().symbol.stop; } else { endLocation = child.ALT_R_BRACKET().symbol.stop; } this.pendingEdits.push({ type:"replacement", location: startLocation, deletionLength: endLocation - startLocation + 1, text: blankMatrixLatex }); } if (error) { return {type: "error"}; } else { this.addParsingErrorMessage('Press enter to insert blank matrix'); return { type: "insertMatrix" }; } } _removeOperatorFont = (ctx: RemoveOperatorFontContext | Fix_mixed_idContext) => { this.addParsingErrorMessage("Expression combined with function name, press enter to fix automatically"); this.immediateUpdate = true; let i = 0; while (ctx.CMD_MATHRM(i)) { this.pendingEdits.push({ type:"replacement", location: ctx.CMD_MATHRM(i).symbol.start, deletionLength: ctx.L_BRACE(i).symbol.start - ctx.CMD_MATHRM(i).symbol.start + 1, text: "" }); this.pendingEdits.push({ type:"replacement", location: ctx.R_BRACE(i).symbol.start, deletionLength: 1, text: "" }); i++; } } visitRemoveOperatorFont = (ctx: RemoveOperatorFontContext): FixMixedId => { this._removeOperatorFont(ctx); return {type: "fixMixedId"}; } visitFix_mixed_id = (ctx: Fix_mixed_idContext): FixMixedId => { this._removeOperatorFont(ctx); return {type: "fixMixedId"}; } visitEmptySubscript = (ctx: EmptySubscriptContext): string => { this.addParsingErrorMessage("There is an empty subscript that is causing a syntax error"); this.pendingEdits.push({ type: "insertion", location: ctx.R_BRACE().symbol.start, text: "\\placeholder{}" }); return ''; } visitEmptySuperscript = (ctx: EmptySuperscriptContext): string => { this.addParsingErrorMessage("There is an empty superscript that is causing a syntax error"); this.pendingEdits.push({ type: "insertion", location: ctx.R_BRACE().symbol.start, text: "\\placeholder{}" }); return ''; } visitMissingMultiplication = (ctx: MissingMultiplicationContext): string => { this.addParsingErrorMessage("Missing multiplication symbol in expression"); // need to visit sub expressions in case there are any immediate fixes that need to be applied this.visit(ctx.expr()); return ''; } visitEmptyPlaceholder = (ctx: EmptyPlaceholderContext): string => { this.addParsingErrorMessage("Fill in empty placeholders (delete empty placeholders for unwanted subscripts or exponents)"); return ''; } visitU_block_for_code_cell = (ctx: U_blockContext): CodeCellDims => { const units = this.visit(ctx.u_expr()) as string; switch(units) { case "any": return { type: "any" } case "dummy": return { type: "dummy" } case "none": return { type: "specific", dims: [0, 0, 0, 0, 0, 0, 0, 0, 0], offset: 0, scaleFactor: 1 }; case "text": case "html": case "markdown": return { type: "render", renderType: units } } const { dimensions, unitsValid } = checkUnits(units); if (unitsValid) { const { offset, scaleFactor } = getConversionFactor(units) return { type: "specific", dims: dimensions, offset, scaleFactor }; } else { this.addParsingErrorMessage(`Unknown Dimension ${units}`); return { type: "specific", dims: [0, 0, 0, 0, 0, 0, 0, 0, 0], offset: 0, scaleFactor: 1 }; } } _visitUnit_matrix_row = (ctx: Unit_matrix_rowContext): (CodeCellDimsSpecific | CodeCellDimsAny)[] => { const rowDims: (CodeCellDimsSpecific | CodeCellDimsAny)[] = []; for(const u_block of ctx.u_block_list()) { const newEntry = this.visitU_block_for_code_cell(u_block); if (newEntry.type === "dummy" || newEntry.type === "render") { this.addParsingErrorMessage(`${newEntry.type} dimension type cannot be used within a matrix`); rowDims.push({type: "any"}); } else { rowDims.push(newEntry); } } return rowDims; } _visitCode_cell_units = (ctx: Code_cell_unitsContext): CodeCellInputOutputDims => { if (ctx.u_block()) { return { type: "scalar", dims: this.visitU_block_for_code_cell(ctx.u_block()) }; } else { const dimRows: (CodeCellDimsAny | CodeCellDimsSpecific)[][] = [] for (const row of ctx.unit_matrix_row_list()) { dimRows.push(this._visitUnit_matrix_row(row)); } return { type: "matrix", dims: dimRows } } } visitCode_func_def = (ctx: Code_func_defContext): CodeCellFunctionStatement => { const initialPendingEditsLength = this.pendingEdits.length; const name = this.visitId(ctx.id()); const outputDims = this._visitCode_cell_units(ctx._output_units); const inputDims: CodeCellInputOutputDims[] = []; for (const input of ctx._input_units) { inputDims.push(this._visitCode_cell_units(input)); } const existingPendingEdit = this.pendingEdits.length > initialPendingEditsLength; if (!ctx.CMD_MATHRM() && !existingPendingEdit) { this.insertTokenCommand('mathrm', ctx.id().children[0] as TerminalNode); } return { type: "codeCellFunction", name, latexName: this.variableNameMap[name], inputDims, outputDims } } } ================================================ FILE: src/parser/constants.ts ================================================ export const GREEK_CHARS = new Set(['alpha', 'beta', 'gamma', 'delta', 'epsilon', 'zeta', 'eta', 'theta', 'iota', 'kappa', 'lambda', 'mu', 'nu', 'xi', 'pi', 'rho', 'sigma', 'tau', 'upsilon', 'phi', 'chi', 'psi', 'omega', 'Gamma', 'Delta', 'Theta', 'Lambda', 'Xi', 'Pi', 'Sigma', 'Upsilon', 'Phi', 'Psi', 'Omega']); export const LATEX_TO_UNICODE = new Map([ // special accent commands (need to map to something that is not a valid variable) ["\\hat", "_hat_"], ["\\bar", "_bar_"], ["\\vec", "_vec_"], ["\\dot", "_dot_"], ["\\ddot", "_ddot_"], ["\\dddot", "_dddot_"], ["\\prime", "_prime_"], // the rest are latex commands that map to a specific unicode character ["\\ell", "ℓ"], ["\\hbar", "ℏ"], ["\\alpha", "α"], ["\\beta", "β"], ["\\gamma", "γ"], ["\\delta", "δ"], ["\\epsilon", "ϵ"], ["\\varepsilon", "ε"], ["\\zeta", "ζ"], ["\\eta", "η"], ["\\theta", "θ"], ["\\vartheta", "ϑ"], ["\\iota", "ι"], ["\\kappa", "κ"], ["\\varkappa", "ϰ"], ["\\lambda", "λ"], ["\\mu", "μ"], ["\\nu", "ν"], ["\\xi", "ξ"], ["\\omicron", "o"], ["\\pi", "π"], ["\\varpi", "ϖ"], ["\\rho", "ρ"], ["\\varrho", "ϱ"], ["\\sigma", "σ"], ["\\varsigma", "ς"], ["\\tau", "τ"], ["\\phi", "ϕ"], ["\\varphi", "φ"], ["\\upsilon", "υ"], ["\\chi", "χ"], ["\\psi", "ψ"], ["\\omega", "ω"], ["\\Gamma", "Γ"], ["\\Delta", "Δ"], ["\\Theta", "Θ"], ["\\Lambda", "Λ"], ["\\Xi", "Ξ"], ["\\Pi", "Π"], ["\\Sigma", "Σ"], ["\\Upsilon", "Υ"], ["\\Phi", "Φ"], ["\\Psi", "Ψ"], ["\\Omega", "Ω"], ["\\digamma", "ϝ"], ["\\varkappa", "ϰ"], ["\\coppa", "ϙ"], ["\\koppa", "ϙ"], ["\\Coppa", "Ϙ"], ["\\Koppa", "Ϙ"], ["\\sampi", "ϡ"], ["\\Sampi", "Ϡ"], ["\\wp", "℘"], ["\\aleph", "ℵ"], ["\\hslash", "ℏ"], ["\\Finv", "Ⅎ"], ["\\eth", "ð"], ["\\Bbbk", "k"], ["\\beth", "ℶ"], ["\\daleth", "ℸ"], ["\\gimel", "ℷ"], ["\\imath", "i"], ["\\jmath", "j"] ]); export const UNASSIGNABLE = new Set(["I", "E", "pi"]); export const ZERO_PLACEHOLDER = "implicit_param__zero"; export const BUILTIN_FUNCTION_MAP = new Map([ ['max', '_Max'], ['min', '_Min'], ['real', '_re'], ['imag', '_im'], ['conj', '_conjugate'], ['angle', '_arg'], ['inv', '_Inverse'], ['det', '_Determinant'], ['transpose', '_Transpose'], ['norm', '_norm'], ['dot', '_dot'], ['floor', '_floor'], ['ceil', '_ceil'], ['round', '_round'], ['range', '_range'], ['count', '_count'], ['sum', '_sum'], ['average', '_average'], ['stdev', '_stdev'], ['stdevp', '_stdevp'], ['numrows', '_numrows'], ['numcols', '_numcols'] ]); export const COMPARISON_MAP = new Map([ ["<", "_StrictLessThan"], ["\\le", "_LessThan"], [">", "_StrictGreaterThan"], ["\\ge", "_GreaterThan"] ]) export const UNITS_WITH_OFFSET = new Set(['degC', 'degF', 'celsius', 'fahrenheit']); export const TYPE_PARSING_ERRORS = { math: "This field must contain an assignment (e.g., x=y*z) or a query (e.g., x=). To delete an unwanted math cell, click the trash can on the right.", plot: "This field must contain a function query with an input parameter range using the format y(-10 ≤ x ≤ 10)=, a query with a pair of scalars or vectors separated by a comma using the format (a,b)=, or a query with a parametric expression using the format (sin(s), cos(s)) for (0 ≤ s ≤ 2*pi)=", parameter: "A variable name is required in this field.", function_name: "A function name is required in this field.", units: "This field may only contain units in square brackets or may be left blank to indicate no units.", expression: "This field may only contain a valid expression or number without an equals sign or it may be blank.", expression_no_blank: "This field may only contain a valid expression or number without an equals sign.", number: "This field may only contain a number since units are specified for this column.", condition: "This field may only contain a condition statement such as x>1. The expression corresponding to the first satisfied condition will be used.", piecewise: "Syntax Error", equality: "An equation is required in this field.", id_list: "A variable name, or a list of variable names separated by commas, is required in this field (x,y for example). If a numerical solve is required, the variables must be given initial guess values with a tilde (x~1, y~2, for example).", data_table_expression: "A variable name or an assignment is required in this field.", code_func_def: "A code cell function definition is required (e.g., MyFunction([any])=[none])." }; ================================================ FILE: src/parser/parserWorker.ts ================================================ import { parseLatex } from "./LatexToSympy"; import { createCustomUnits } from "../utility"; createCustomUnits(); self.onmessage = function(e) { self.postMessage(parseLatex(e.data.latex, e.data.id, 0, e.data.type, e.data.dataTableInfo)); } ================================================ FILE: src/parser/parserWrapper.ts ================================================ import type { FieldTypes, DataTableInfo } from "./types"; import type { ParsingResult } from "./LatexToSympy"; type ParseRequest = { latex: string, id: number, type: FieldTypes, dataTableInfo?: DataTableInfo }; export class LatexParserWrapper { worker: Worker; requestQueue: Map void)[]}> = new Map(); currentResolvers: ((input: ParsingResult) => void)[] = []; parsePending = false; setExternalParsePending: (parsePending: boolean) => void; constructor(setExternalParsePending: (parsePending: boolean) => void) { this.setExternalParsePending = setExternalParsePending; this.setExternalParsePending(false); this.worker = new Worker('parser/parserWorker.js'); this.worker.onmessage = (e) => { for (const resolver of this.currentResolvers) { resolver(e.data as ParsingResult); } this.currentResolvers = []; if (this.requestQueue.size === 0) { this.parsePending = false; this.setExternalParsePending(false); } else { const [key, value] = this.requestQueue.entries().next().value; this.currentResolvers = value.resolvers; this.requestQueue.delete(key); this.worker.postMessage(value.request); } }; } parseLatex(latex: string, id: number, type: FieldTypes, dataTableInfo?: DataTableInfo): Promise { const newRequest: ParseRequest = {latex, id, type, dataTableInfo}; return new Promise((resolve: (input: ParsingResult) => void, reject) => { if (!this.parsePending) { this.worker.postMessage(newRequest); this.currentResolvers = [resolve, ]; } else { if (this.requestQueue.has(id)) { const {request, resolvers} = this.requestQueue.get(id); resolvers.push(resolve); this.requestQueue.set(id, {request: newRequest, resolvers}); } else { this.requestQueue.set(id, {request: newRequest, resolvers: [resolve,]}) } } this.parsePending = true; this.setExternalParsePending(true); }); } } ================================================ FILE: src/parser/types.ts ================================================ import type { Replacement } from "./utility"; import type { CodeCellInputOutputDims } from "../cells/CodeCell.svelte"; export type FieldTypes = "math" | "plot" | "parameter" | "function_name" | "units" | "expression" | "number" | "condition" | "piecewise" | "expression_no_blank" | "equality" | "id_list" | "data_table_expression" | "data_table_assign" | "code_func_def"; export type ImplicitParameter = { name: string; units: string; unitsLatex: string; dimensions: number[]; original_value: string; si_value: string; }; export type Statement = AssignmentStatement | AssignmentList | QueryStatement | RangeQueryStatement | CodeFunctionQueryStatement | EqualityStatement | BlankStatement | UnitsStatement | ErrorStatement | SolveParameters | SolveParametersWithGuesses | ExpressionStatement | NumberStatement | ParameterStatement | ConditionStatement | InsertMatrix | ScatterQueryStatement | FixMixedId | ParametricRangeQueryStatement | DataTableQueryStatement | CodeCellFunctionStatement; export type InsertMatrix = { type: "insertMatrix"; } export type FixMixedId = { type: "fixMixedId"; } export type BlankStatement = { type: "blank"; params: []; variableNameMap: {}; implicitParams: []; isFromPlotCell: false; }; export type UnitsStatement = { type: "units"; units: string; unitsValid: boolean; unitsLatex: string; dimensions: number[]; }; export type ErrorStatement = { type: "error"; }; type ExpressionStatement = { type: "expression"; sympy: string; }; type NumberStatement = { type: "number"; value: string; }; type ParameterStatement = { type: "parameter"; name: string; variableNameMap: Record; }; type ConditionStatement = { type: "condition"; sympy: string; }; export type LocalSubstitution = { type: "localSub"; parameter: string; argument: string; isRange: false; function: string; }; export type LocalSubstitutionRange = Omit & { isRange: true; isLowerLimit: boolean; isInclusiveLimit: boolean; }; type BaseAssignmentStatement = { type: "assignment"; name: string; sympy: string; params: string[]; variableNameMap: Record; isFunctionArgument: false; isFunction: false; }; export type UserFunction = Omit & { isFunction: true; isRange: false; functionParameters: string[]; }; export type UserFunctionRange = Omit & { isRange: true; freeParameter: string; lowerLimitArgument: string; lowerLimitInclusive: boolean; upperLimitArgument: string; upperLimitInclusive: boolean; unitsQueryFunction: string; }; export type FunctionArgumentAssignment = Pick & { isFunctionArgument: true; isFunction: false; }; export type AssignmentStatement = BaseAssignmentStatement & { implicitParams: ImplicitParameter[]; functions: (UserFunction | UserFunctionRange | FunctionUnitsQuery)[]; arguments: (FunctionArgumentQuery | FunctionArgumentAssignment)[]; localSubs: (LocalSubstitution | LocalSubstitutionRange)[]; isFromPlotCell: false; isRange: false; isDataTableQuery: false; isCodeFunctionQuery: false; isCodeFunctionRawQuery: false; }; export type AssignmentList = { type: "assignmentList"; assignments: AssignmentStatement[]; } export type GuessAssignmentStatement = AssignmentStatement & { guess: string; }; export type SolveParameters = { type: "unknowns"; ids: string[]; numericalSolve: false; }; export type SolveParametersWithGuesses = Omit & { numericalSolve: true; guesses: string[]; statements: GuessAssignmentStatement[]; }; export type EqualityStatement = Omit & { type: "equality"; equationIndex: number; equalityUnitsQueries: EqualityUnitsQueryStatement[]; }; type BaseQueryStatement = { type: "query"; sympy: string; implicitParams: ImplicitParameter[]; params: string[]; variableNameMap: Record; functions: (UserFunction | UserFunctionRange | FunctionUnitsQuery)[]; arguments: (FunctionArgumentAssignment | FunctionArgumentQuery) []; localSubs: (LocalSubstitution | LocalSubstitutionRange)[]; isFunctionArgument: false; isFunction: false; isUnitsQuery: false; isEqualityUnitsQuery: boolean; isScatterXValuesQueryStatement: false; isScatterYValuesQueryStatement: false; isFromPlotCell: boolean; units: string; unitsLatex: string; assignment?: AssignmentStatement; }; export type QueryStatement = BaseQueryStatement & { isRange: false; isDataTableQuery: false; isCodeFunctionQuery: false; isCodeFunctionRawQuery: false; subQueries: SubQueryStatement[]; subQueryReplacements: [string, Replacement][]; isSubQuery: false; }; export type DataTableQueryStatement = BaseQueryStatement & { isRange: false; isDataTableQuery: true; isCodeFunctionQuery: false; isCodeFunctionRawQuery: false; isSubQuery: false; cellNum: number; colId: number; }; export type EqualityUnitsQueryStatement = Omit & { isEqualityUnitsQuery: true; isSubQuery: false; equationIndex: number; }; export type SubQueryStatement = Omit & { isSubQuery: true; }; export type RangeQueryStatement = BaseQueryStatement & { isRange: true; isDataTableQuery: false; isParametric: boolean; isCodeFunctionQuery: false; isCodeFunctionRawQuery: false; isSubQuery: false; cellNum: number; numPoints: number; freeParameter: string; lowerLimitArgument: string; lowerLimitInclusive: boolean; upperLimitArgument: string; upperLimitInclusive: boolean; logX: boolean; unitsQueryFunction: string; inputUnits: string; inputUnitsLatex: string; outputName: string; }; export type ParametricRangeQueryStatement = { type: "parametricRange"; assignmentStatements: AssignmentStatement[]; rangeQueryStatements: RangeQueryStatement[]; } export type ScatterXValuesQueryStatement = Omit & { isScatterXValuesQueryStatement: true; isSubQuery: false; equationIndex: number; } export type ScatterYValuesQueryStatement = Omit & { isScatterYValuesQueryStatement: true; isSubQuery: false; equationIndex: number; } export type ScatterQueryStatement = { type: "scatterQuery"; asLines: boolean; params: []; variableNameMap: {}; functions: (UserFunction | UserFunctionRange | FunctionUnitsQuery)[]; arguments: (FunctionArgumentAssignment | FunctionArgumentQuery) []; localSubs: (LocalSubstitution | LocalSubstitutionRange)[]; implicitParams: ImplicitParameter[]; equationIndex: number; cellNum: number; isFromPlotCell: boolean; xValuesQuery: ScatterXValuesQueryStatement; yValuesQuery: ScatterYValuesQueryStatement; xName: string; yName: string; units: string; unitsLatex: string; inputUnits: string; inputUnitsLatex: string; }; export type CodeFunctionQueryStatement = BaseQueryStatement & { isRange: false; isDataTableQuery: false; isCodeFunctionQuery: true; isCodeFunctionRawQuery: false; functionName: string; parameterNames: string[]; parameterValues: string[]; parameterUnits: string[]; generateCode: boolean; codeFunctionRawQuery: CodeFunctionRawQuery; }; export type CodeFunctionRawQuery = BaseQueryStatement & { isRange: false; isDataTableQuery: false; isCodeFunctionQuery: false; isCodeFunctionRawQuery: true; } export type FunctionArgumentQuery = Pick & { name: string; isFunctionArgument: true; isFunction: false; isUnitsQuery: false; isRange: false; isDataTableQuery: false; isCodeFunctionQuery: false; isCodeFunctionRawQuery: false; }; export type FunctionUnitsQuery = Pick & { units: ''; isFunctionArgument: false; isFunction: false; isUnitsQuery: true; isRange: false; isDataTableQuery: false; isCodeFunctionQuery: false; isCodeFunctionRawQuery: false; }; export type DataTableInfo = { colVars: string[]; cellNum: number; colId: number; }; export type CodeCellFunctionStatement = { type: "codeCellFunction", name: string, latexName: string, inputDims: CodeCellInputOutputDims[], outputDims: CodeCellInputOutputDims, }; ================================================ FILE: src/parser/utility.ts ================================================ import type { SubQueryStatement, BlankStatement } from "./types"; export const PYTHON_RESERVED = new Set([ "numpy", "False", "await", "else", "import", "pass", "None", "break", "except", "in", "raise", "True", "class", "finally", "is", "return", "and", "continue", "for", "lambda", "try", "as", "def", "from", "nonlocal", "while", "assert", "del", "global", "not", "with", "async", "elif", "if", "or", "yield", ]); export type Insertion = { type: "insertion"; location: number; text: string; }; export function isInsertion(edit: (Insertion | Replacement)): edit is Insertion { return edit.type === "insertion"; } export type Replacement = { type: "replacement"; location: number; deletionLength: number; text: string } export function isReplacement(edit: (Insertion | Replacement)): edit is Replacement { return edit.type === "replacement"; } export function applyEdits(source: string, pendingEdits: (Insertion | Replacement)[]): string { let newString: string = source; const insertions = pendingEdits.filter(isInsertion) .sort((a,b) => a.location - b.location); // check for insertion collisions const insertionLocations = new Set(insertions.map( (insertion) => insertion.location)); if (insertionLocations.size < insertions.length) { throw new Error("Insertion collision"); } const replacements = pendingEdits.filter(isReplacement) .sort((a,b) => a.location - b.location); // Perform replacements first, update insertion locations as necessary // Also, check for overlapping replacements and replacement insertion collisions let runningReplacementOffset = 0; let insertionCursor = 0; for (const [index, replacement] of replacements.entries()) { if (replacements[index+1]) { const nextLocation = replacements[index+1].location; if (nextLocation >= replacement.location && nextLocation < replacement.location + replacement.deletionLength) { throw new Error("Overlapping replacements"); } } newString = newString.slice(0, replacement.location + runningReplacementOffset) + replacement.text + newString.slice(replacement.location + runningReplacementOffset + replacement.deletionLength); const currentReplacementOffset = replacement.text.length - replacement.deletionLength; runningReplacementOffset += currentReplacementOffset let cursorMoved = false; for (const [insertionIndex, insertion] of insertions.slice(insertionCursor).entries()) { if (insertion.location >= replacement.location && insertion.location < replacement.location + replacement.deletionLength) { throw new Error("Replacement/Insertion collision"); } if (insertion.location >= replacement.location) { if (!cursorMoved) { insertionCursor = insertionIndex; cursorMoved = true; } insertion.location += currentReplacementOffset; } } } // finally, perform insertions in order const segments = []; let previousInsertLocation = 0; for (const insert of insertions) { segments.push(newString.slice(previousInsertLocation, insert.location) + insert.text); previousInsertLocation = insert.location; } segments.push(newString.slice(previousInsertLocation)); newString = segments.reduce( (accum, current) => accum+current, ''); return newString; } export function createSubQuery(name: string): SubQueryStatement { return { type: "query", implicitParams: [], params: [name], variableNameMap: {}, functions: [], arguments: [], localSubs: [], units: "", unitsLatex: "", isFunctionArgument: false, isFunction: false, isUnitsQuery: false, isEqualityUnitsQuery: false, isScatterXValuesQueryStatement: false, isScatterYValuesQueryStatement: false, isFromPlotCell: false, isSubQuery: true, sympy: name, isRange: false, isDataTableQuery: false, isCodeFunctionQuery: false, isCodeFunctionRawQuery: false }; } export function getBlankStatement(): BlankStatement { return { type: "blank", params: [], variableNameMap: {}, implicitParams: [], isFromPlotCell: false}; } ================================================ FILE: src/pyodide-info.json ================================================ [ { "releaseVersion": 0, "latestPermalink": "https://20260313.engineeringpaper.xyz/", "info": { "pythonVersion": "3.12.7", "pyodideVersion": "0.27.7", "availablePackages": { "sympy": { "pyodideName": "sympy", "version": "1.13.3" }, "numpy": { "pyodideName": "numpy", "version": "2.0.2" }, "CoolProp": { "pyodideName": "coolprop", "version": "6.6.0" }, "scipy": { "pyodideName": "scipy", "version": "1.14.1" }, "matplotlib": { "pyodideName": "matplotlib", "version": "3.8.4" }, "sklearn": { "pyodideName": "scikit-learn", "version": "1.6.1" }, "pandas": { "pyodideName": "pandas", "version": "2.2.3" }, "polars": { "pyodideName": "polars", "version": "1.18.0" }, "jinja2": { "pyodideName": "jinja2", "version": "3.1.3" }, "rich": { "pyodideName": "rich", "version": "13.7.1" }, "nlopt": { "pyodideName": "nlopt", "version": "2.9.1" }, "drawsvg": { "pyodideName": "drawsvg", "version": "2.4.0" } } } }, { "releaseVersion": 20260414, "latestPermalink": "https://20260414.engineeringpaper.xyz/", "info": { "pythonVersion": "3.13.2", "pyodideVersion": "0.29.3", "availablePackages": { "sympy": { "pyodideName": "sympy", "version": "1.13.3" }, "numpy": { "pyodideName": "numpy", "version": "2.2.5" }, "CoolProp": { "pyodideName": "coolprop", "version": "7.2.0" }, "scipy": { "pyodideName": "scipy", "version": "1.14.1" }, "matplotlib": { "pyodideName": "matplotlib", "version": "3.8.4" }, "sklearn": { "pyodideName": "scikit-learn", "version": "1.7.0" }, "pandas": { "pyodideName": "pandas", "version": "2.3.3" }, "jinja2": { "pyodideName": "jinja2", "version": "3.1.6" }, "rich": { "pyodideName": "rich", "version": "13.9.4" }, "nlopt": { "pyodideName": "nlopt", "version": "2.9.1" }, "drawsvg": { "pyodideName": "drawsvg", "version": "2.4.1" } } } } ] ================================================ FILE: src/pyodideWorker.ts ================================================ import QuickLRU from "quick-lru"; const cache = new QuickLRU({maxSize: 100}); globalThis.importScripts('pyodide/pyodide.js'); let pyodide_ready = false; let py_funcs; let recursionError = false; let pyodide; let loadedPyodidePackages: Set = new Set(['sympy']); async function setup() { try { pyodide = await globalThis.loadPyodide({indexURL: 'pyodide/', packages: ['sympy']}); const response = await fetch("dimensional_analysis.py"); const data = await response.text(); py_funcs = await pyodide.runPythonAsync(data); console.log('Python Ready'); pyodide_ready = true globalThis.postMessage("pyodide_loaded"); } catch(e) { console.error('Pyodide failed to load.'); console.log(e); globalThis.postMessage("pyodide_not_available"); } } const setupPromise = setup(); globalThis.onmessage = async function(e){ if (e.data.cmd === "sheet_solve") { await setupPromise; if (!pyodide_ready) { globalThis.postMessage("pyodide_not_available"); return; } if (recursionError) { globalThis.postMessage("max_recursion_exceeded"); return; } try { const neededPackages = (new Set(e.data.neededPyodidePackages as string[])).difference(loadedPyodidePackages) if (neededPackages.size > 0) { await pyodide.loadPackage([...neededPackages]); loadedPyodidePackages = loadedPyodidePackages.union(neededPackages); } const statementsAndSystems = JSON.stringify(e.data.data); let result: string; if (!cache.has(statementsAndSystems)) { result = py_funcs.solveSheet(statementsAndSystems) as string; cache.set(statementsAndSystems, result); } else { result = cache.get(statementsAndSystems) } globalThis.postMessage(JSON.parse(result)); } catch (e) { // recursion is instance of InternalError (not standard, so cannot use) in Firefox and RangeError in Chrome if (e instanceof RangeError) { recursionError = true; globalThis.postMessage("max_recursion_exceeded"); return; } else { globalThis.postMessage({error: `Unhandled exception occurred during Python call. ${e}`, results: []}) } } } } ================================================ FILE: src/resultTypes.ts ================================================ export type Result = { value: string; symbolicValue?: string; // some old database entries may not have this value units: string; unitsLatex: string; customUnitsDefined?: boolean; // some old database entries my not have this value customUnits?: string; // only defined if customUnitsDefined is true customUnitsLatex?: string; // only defined if customUnitsDefined is true numeric: boolean; real: boolean; finite: boolean; generatedCode?: string; isSubResult?: boolean; // some old database entries my not have sub query info subQueryName?: string; }; export type FiniteImagResult = Omit & { real: false; finite: true; numeric: true, realPart: string; imagPart: string; generatedCode?: string; isSubResult?: boolean; // some old database entries my not have sub query info subQueryName?: string; }; export function isFiniteImagResult(result: Result | FiniteImagResult | MatrixResult): result is FiniteImagResult { if (isMatrixResult(result)) { return false; } return result.numeric && !result.real && result.finite; } export type MatrixResult = { matrixResult: true; results: ((Result | FiniteImagResult)[])[]; generatedCode?: string; isSubResult?: boolean; // some old database entries my not have sub query info subQueryName?: string; }; export type DataTableResult = { dataTableResult: true; colData: {number: MatrixResult}; } export function isMatrixResult(result: Result | FiniteImagResult | MatrixResult | DataTableResult | RenderResult): result is MatrixResult { return "matrixResult" in result && result.matrixResult; } export function isDataTableResult(result: Result | FiniteImagResult | MatrixResult | DataTableResult | RenderResult | PlotResult[]): result is DataTableResult { return "dataTableResult" in result && result.dataTableResult; } export function isPlotResult(result: Result | FiniteImagResult | MatrixResult | DataTableResult | RenderResult | PlotResult[]): result is PlotResult[] { return result instanceof Array && result[0].plot; } export function isRenderResult(result: Result | FiniteImagResult | MatrixResult | DataTableResult | RenderResult | PlotResult[]): result is RenderResult { return "renderResult" in result && result.renderResult; } export function isMathCellResult(result: null | Result | FiniteImagResult | MatrixResult | DataTableResult | RenderResult | PlotResult[]): result is Result | FiniteImagResult | MatrixResult { return result && !(result instanceof Array) && !("dataTableResult" in result) && !("renderResult" in result) } export type PlotData = { numericOutput: boolean; numericInput: boolean; limitsUnitsMatch: boolean; input: number[]; output: number[]; inputReversed: boolean; negLogLimit?: boolean; // some old database entries my not have this value inputUnits: string; inputUnitsLatex: string; inputCustomUnitsDefined?: boolean; // some old database entries my not have this value inputCustomUnits?: string; // only defined if inputCustomUnitsDefined is true inputCustomUnitsLatex?: string; // only defined if inputCustomUnitsDefined is true inputName: string; inputNameLatex?: string; // old versions of saved results may not have this property outputUnits: string; outputUnitsLatex: string; outputCustomUnitsDefined?: boolean; // some old database entries my not have this value outputCustomUnits?: string; // only defined if outputCustomUnitsDefined is true outputCustomUnitsLatex?: string; // only defined if outputCustomUnitsDefined is true outputName: string; outputNameLatex?: string; // old versions of saved results may not have this property isScatter?: boolean; // old versions of saved results won't have this property asLines?: boolean; // optional, only used for scatter plots scatterErrorMessage?: string; // optional, only used for scatter plots parametricErrorMessage?: string; // optional, only used for parametric plots }; export type PlotResult = { plot: boolean; data: PlotData[]; }; export type SystemResult = { error: null | string; solutions: Record; selectedSolution: number; }; export type CodeCellError = { message: string; startLine: number | null; endLine: number | null; startCol: number | null; endCol: number | null; } export type CodeCellResult = { stdout: string; errors: CodeCellError[]; } export type RenderResult = { renderResult: true; type: "text" | "html" | "markdown"; value: string dimensionError: string } export type Results = { error: null | string; results: (Result | FiniteImagResult | MatrixResult | DataTableResult | RenderResult | PlotResult[])[]; systemResults: SystemResult[]; codeCellResults: Record; }; ================================================ FILE: src/sheet/Sheet.ts ================================================ import type { NumberFormat } from "xlsx"; import type { DatabaseCell } from "../cells/BaseCell" import type { Result, FiniteImagResult, PlotResult, MatrixResult, SystemResult, DataTableResult, CodeCellResult, RenderResult} from "../resultTypes"; export type Sheet = { version?: number; // early sheets did not have a version property config?: Config; // early sheets did not have a config property cells: DatabaseCell[]; title: string; results: (Result | FiniteImagResult | MatrixResult | DataTableResult | RenderResult | PlotResult[])[]; system_results: (SystemResult)[]; codeCellResults?: Record; // early sheets did not have this property sub_results?: [string, Result | FiniteImagResult | MatrixResult][]; // early sheets did not have this property nextId: number; sheetId: string; insertedSheets?: InsertedSheet[]; // early sheets did not have this property }; export type InsertedSheet = { title: string; url: string; insertion: Date; }; export type Config = { mathCellConfig: MathCellConfig; customBaseUnits?: CustomBaseUnits; // some early sheets won't have this property simplifySymbolicExpressions?: boolean; // some early sheets won't have this property convertFloatsToFractions?: boolean; // some early sheets won't have this property fluidConfig?: FluidConfig; // some early sheets won't have this property }; type Notation = "auto" | "fixed" | "exponential" | "engineering"; export type MathCellConfig = { symbolicOutput: boolean; showIntermediateResults?: boolean; // early configs may not have this property formatOptions: NumberFormatOptions; }; export type NumberFormatOptions = { notation: Notation; precision: number; lowerExp: number; upperExp: number; }; export type FluidConfig = { fluid: string; incompMixConc: number; customMixture: {fluid: string, moleFraction: number}[]; } export function getDefaultConfig(): Config { return { mathCellConfig: getDefaultMathCellConfig(), customBaseUnits: getDefaultBaseUnits(), simplifySymbolicExpressions: true, convertFloatsToFractions: true, fluidConfig: getDefaultFluidConfig() }; } export function getDefaultFluidConfig(): FluidConfig { return { fluid: "Water", incompMixConc: 0.5, customMixture: [{fluid: "R32", moleFraction: 0.697615}, {fluid: "R125", moleFraction: 0.302385}] } } function getDefaultMathCellConfig(): MathCellConfig { return { symbolicOutput: false, showIntermediateResults: false, formatOptions: getDefaultNumberFormatOptions() }; } function getDefaultNumberFormatOptions(): NumberFormatOptions { return { notation: "auto", precision: 15, lowerExp: -3, upperExp: 5, } } export const numberFormatLimits = { precisionUpper: 64, lowerExpLower: -12, lowerExpUpper: -2, upperExpLower: 2, upperExpUpper: 12 }; export function isDefaultMathConfig(config: MathCellConfig): boolean { return mathConfigsEqual(config, defaultConfig.mathCellConfig); } export function isDefaultNumberFormatOptions(options: NumberFormatOptions): boolean { return numberFormatOptionsEqual(options, defaultConfig.mathCellConfig.formatOptions); } export function mathConfigsEqual(config1: MathCellConfig, config2: MathCellConfig): boolean { return ( config1.symbolicOutput === config2.symbolicOutput && config1.showIntermediateResults === config2.showIntermediateResults && numberFormatOptionsEqual(config1.formatOptions, config2.formatOptions) ); } export function numberFormatOptionsEqual(config1: NumberFormatOptions, config2: NumberFormatOptions): boolean { return ( config1.notation === config2.notation && config1.precision === config2.precision && config1.lowerExp === config2.lowerExp && config1.upperExp === config2.upperExp ); } export function isDefaultConfig(config: Config): boolean { return configsEqual(config, defaultConfig); } export function configsEqual(config1: Config, config2: Config): boolean { return mathConfigsEqual(config1.mathCellConfig, config2.mathCellConfig) && baseUnitsEqual(config1.customBaseUnits, config2.customBaseUnits) && config1.simplifySymbolicExpressions === config2.simplifySymbolicExpressions && config1.convertFloatsToFractions === config2.convertFloatsToFractions; } export function copyMathConfig(input: MathCellConfig): MathCellConfig { if (input === null) { return null; } return { symbolicOutput: input.symbolicOutput, showIntermediateResults: input.showIntermediateResults, formatOptions: {...input.formatOptions} }; } export function getSafeMathConfig(config: MathCellConfig): MathCellConfig { const safeConfig = copyMathConfig(config); safeConfig.formatOptions = getSafeNumberFormatOptions(safeConfig.formatOptions); return safeConfig; } export function getSafeNumberFormatOptions(options: NumberFormatOptions): NumberFormatOptions { const safeOptions: NumberFormatOptions = {...options}; // clamp precision if (options.precision === null) { safeOptions.precision = defaultConfig.mathCellConfig.formatOptions.precision; } else if(options.precision > numberFormatLimits.precisionUpper) { safeOptions.precision = numberFormatLimits.precisionUpper; } else if(options.precision < (options.notation === "fixed" ? 0 : 1)) { safeOptions.precision = options.notation === "fixed" ? 0 : 1; } // clamp lowerExp if (options.lowerExp === null) { safeOptions.lowerExp = defaultConfig.mathCellConfig.formatOptions.lowerExp; } else if(options.lowerExp > numberFormatLimits.lowerExpUpper) { safeOptions.lowerExp = numberFormatLimits.lowerExpUpper; } else if(options.lowerExp < numberFormatLimits.lowerExpLower) { safeOptions.lowerExp = numberFormatLimits.lowerExpLower; } // clamp upperExp if (options.upperExp === null) { safeOptions.upperExp = defaultConfig.mathCellConfig.formatOptions.upperExp; } else if(options.upperExp > numberFormatLimits.upperExpUpper) { safeOptions.upperExp = numberFormatLimits.upperExpUpper; } else if(options.upperExp < numberFormatLimits.upperExpLower) { safeOptions.upperExp = numberFormatLimits.upperExpLower; } return safeOptions; } export type CustomBaseUnits = { mass: string; length: string; time: string; current: string; temperature: string; luminous_intensity: string; amount_of_substance: string; force: string; area: string; volume: string; energy: string; power: string; pressure: string; charge: string; capacitance: string; electric_potential: string; resistance: string; inductance: string; conductance: string; magnetic_flux: string; magnetic_flux_density: string; angle: string; information: string; } // the first choice in each list of choices will be used as the default export const baseUnitChoices: {name: string, label: string, choices: string[]}[] = [ {name: 'mass', label: 'Mass', choices: ['kg', 'g', 'mg', 'tonne', 'lbm', 'ton', 'oz'] }, {name: 'length', label: 'Length', choices: ['m', 'mm', 'cm', 'km', 'um', 'nm', 'angstrom', 'in', 'feet', 'yard', 'mile']}, {name: 'area', label: 'Area', choices: ['m^2', 'cm^2', 'mm^2', 'km^2', 'hectare', 'in^2', 'feet^2', 'yard^2', 'mile^2', 'acre']}, {name: 'volume', label: 'Volume', choices: ['m^3', 'cm^3', 'mm^3', 'km^3', 'liter', 'ml', 'in^3', 'feet^3', 'yard^3', 'mile^3', 'gallon', 'floz']}, {name: 'force', label: 'Force', choices: ['N', 'mN', 'kN', 'lbf', 'kip', 'dyne', 'gf', 'kgf']}, {name: 'pressure', label: 'Pressure', choices: ['Pa', 'kPa', 'MPa', 'GPa', 'psi', 'kpsi', 'Mpsi', 'atm', 'torr', 'bar', 'mmHg', 'mmH2O', 'cmH2O', 'inHg', 'inH2O', 'ftH2O']}, {name: 'energy', label: 'Energy (Torque)', choices: ['J', 'mJ', 'kJ', 'MJ', 'Wh', 'kWh', 'eV', 'BTU', 'hp*hr', 'N*m', 'N*mm', 'kN*m', 'in*lbf', 'foot*lbf', 'dyn*cm', 'erg']}, {name: 'power', label: 'Power', choices: ['W', 'mW', 'kW', 'MW', 'hp', 'BTU/min', 'BTU/sec', 'BTU/hr', 'MBH', 'MMBH', 'TR', 'BHP', 'erg/sec', 'dyne*cm/sec']}, {name: 'angle', label: 'Angle', choices: ['rad', 'deg', 'grad', 'cycle', 'arcsec', 'arcmin']}, {name: 'time', label: 'Time', choices: ['s', 'ms', 'us', 'ns', 'min', 'hour', 'day', 'week', 'month', 'year']}, {name: 'temperature', label: 'Temperature', choices: ['K', 'degC', 'degF', 'degR']}, {name: 'charge', label: 'Electric Charge', choices: ['C', 'mC', 'uC', 'nC', 'pC']}, {name: 'electric_potential', label: 'Electric Potential', choices: ['V', 'mV', 'kV', 'uV', 'MV']}, {name: 'current', label: 'Electric Current', choices: ['A', 'mA', 'uA', 'kA', 'MA']}, {name: 'resistance', label: 'Resistance', choices: ['ohm', 'mohm', 'kohm', 'Mohm', 'Gohm']}, {name: 'capacitance', label: 'Capacitance', choices: ['F', 'mF', 'uF', 'nF', 'pF']}, {name: 'inductance', label: 'Inductance', choices: ['H', 'mH', 'uH', 'nH', 'pH']}, {name: 'conductance', label: 'Conductance', choices: ['S', 'mS', 'kS', 'uS', 'MS']}, {name: 'magnetic_flux', label: 'Magnetic Flux', choices: ['Wb', 'mWb', 'uWb', 'nWb']}, {name: 'magnetic_flux_density', label: 'Magnetic Flux Density', choices: ['T', 'mT', 'uT', 'nT','pT']}, {name: 'luminous_intensity', label: 'Luminous Intensity', choices: ['cd', 'mcd', 'kcd']}, {name: 'amount_of_substance', label: 'Amount of Substance', choices: ['mol', 'kmol', 'mmol']}, {name: 'information', label: 'Information', choices: ['b', 'B', 'kB', 'MB', 'GB', 'TB', 'PB', 'kb', 'Mb', 'Gb', 'Tb', 'Pb']}, ]; export type BaseUnitSystemNames = "SI" | "mm-kg-sec" | "inch-lbm-sec"; export const baseUnitSystems = new Map([ [ "SI", { mass: "kg", length: "m", time: "s", current: "A", temperature: "K", luminous_intensity: "cd", amount_of_substance: "mol", force: "N", area: "m^2", volume: "m^3", energy: "J", power: "W", pressure: "Pa", charge: "C", capacitance: "F", electric_potential: "V", resistance: "ohm", inductance: "H", conductance: "S", magnetic_flux: "Wb", magnetic_flux_density: "T", angle: "rad", information: "b", }, ], [ "mm-kg-sec", { mass: "kg", length: "mm", time: "s", current: "A", temperature: "K", luminous_intensity: "cd", amount_of_substance: "mol", force: "N", area: "mm^2", volume: "mm^3", energy: "mJ", power: "mW", pressure: "MPa", charge: "C", capacitance: "F", electric_potential: "V", resistance: "ohm", inductance: "H", conductance: "S", magnetic_flux: "Wb", magnetic_flux_density: "T", angle: "rad", information: "b", }, ], [ "inch-lbm-sec", { mass: "lbm", length: "in", time: "s", current: "A", temperature: "degR", luminous_intensity: "cd", amount_of_substance: "mol", force: "lbf", area: "in^2", volume: "in^3", energy: "BTU", power: "hp", pressure: "psi", charge: "C", capacitance: "F", electric_potential: "V", resistance: "ohm", inductance: "H", conductance: "S", magnetic_flux: "Wb", magnetic_flux_density: "T", angle: "rad", information: "b", }, ], ]); export const defaultConfig = getDefaultConfig(); export function getDefaultBaseUnits(system: BaseUnitSystemNames = "SI"): CustomBaseUnits { return {...baseUnitSystems.get(system)}; } export function isDefaultBaseUnits(baseUnits: CustomBaseUnits, system: BaseUnitSystemNames = "SI"): boolean { const defaultBaseUnits = baseUnitSystems.get(system); return Object.entries(defaultBaseUnits).reduce((acum, [key, value]) => acum && value === baseUnits[key], true); } export function baseUnitsEqual(baseUnits1: CustomBaseUnits, baseUnits2: CustomBaseUnits): boolean { let result = true; for (const key in baseUnits1) { result = result && baseUnits1[key] === baseUnits2[key]; } return result; } export function normalizeConfig(config: Config | undefined): Config { if (!config) { return getDefaultConfig(); } config.customBaseUnits = config.customBaseUnits ?? getDefaultBaseUnits(); // customBaseUnits may not exist config.simplifySymbolicExpressions = config.simplifySymbolicExpressions ?? true; // simplifySymboicExpressions may not exist config.convertFloatsToFractions = config.convertFloatsToFractions ?? true; // convertFloatsToFractions may not exist config.fluidConfig = config.fluidConfig ?? getDefaultFluidConfig(); // fluidConfig may not exist config.mathCellConfig.showIntermediateResults = config.mathCellConfig.showIntermediateResults ?? false; // may not exist return config; } ================================================ FILE: src/stores.svelte.ts ================================================ import { SvelteMap } from 'svelte/reactivity'; import { get as idbGet } from 'idb-keyval'; import type { Cell } from './cells/Cells'; import { BaseCell, type CellTypes } from './cells/BaseCell'; import MathCell from './cells/MathCell.svelte'; import DocumentationCell from './cells/DocumentationCell.svelte'; import TableCell from './cells/TableCell.svelte'; import DataTableCell from './cells/DataTableCell.svelte'; import type {MathField} from './cells/MathField.svelte'; import PiecewiseCell from './cells/PiecewiseCell.svelte'; import SystemCell from './cells/SystemCell.svelte'; import FluidCell from './cells/FluidCell.svelte'; import CodeCell from './cells/CodeCell.svelte'; import PlotCell from './cells/PlotCell.svelte'; import DeletedCellClass from "./cells/DeletedCell"; import InsertCell from "./cells/InsertCell"; import type { History } from './database/types'; import type { Result, FiniteImagResult, PlotResult, MatrixResult, SystemResult, DataTableResult, CodeCellResult, RenderResult} from './resultTypes'; import { type Config, type InsertedSheet, type Sheet, getDefaultConfig, normalizeConfig } from './sheet/Sheet'; const defaultTitle = 'New Sheet'; type AppState = { currentVersion: number; termsVersion: number; unsavedChange: boolean; autosaveNeeded: boolean; config: Config; cells: Cell[]; title: string, results: (Result | FiniteImagResult | MatrixResult | DataTableResult | RenderResult | PlotResult[] | null)[]; system_results: SystemResult[] | null; codeCellResults: Record; sub_results: Map; resultsInvalid: boolean; sheetId: string; insertedSheets: InsertedSheet[]; history: History; prefersReducedMotion: boolean; activeCell: number; activeMathField: MathField | null; debug: boolean; modifierKey: "ctrlKey" | "metaKey"; onMobile: boolean; inCellInsertMode: boolean; parsePending: boolean; paperSize: "a4" | "letter"; exportCenteredEquations: false; } const appState: AppState = $state({ currentVersion: 20260414, termsVersion: 20240110, unsavedChange: false, autosaveNeeded: false, config: getDefaultConfig(), cells: [], title: defaultTitle, results: [], system_results: [], codeCellResults: {}, sub_results: new SvelteMap(), resultsInvalid: false, sheetId: '', insertedSheets: [], history: [], prefersReducedMotion: true, activeCell: -1, activeMathField: null, debug: false, modifierKey: /Mac|iPod|iPhone|iPad/.test(navigator.platform) ? "metaKey" : "ctrlKey", onMobile: navigator.userAgent.includes('Mobi'), inCellInsertMode: false, parsePending: false, paperSize: "letter", exportCenteredEquations: false }); export default appState; export async function addCell(type: CellTypes, index?: number) { if (index === undefined){ index = appState.cells.length; } let newCell: TableCell | MathCell | DocumentationCell | PiecewiseCell | SystemCell | PlotCell | InsertCell | FluidCell | DataTableCell; if (type === "math") { newCell = new MathCell; } else if (type === "documentation") { newCell = new DocumentationCell; } else if (type === "table") { newCell = new TableCell; } else if (type === "dataTable") { await DataTableCell.init(); newCell = new DataTableCell; } else if (type === "piecewise") { newCell = new PiecewiseCell; } else if (type === "system") { newCell = new SystemCell; } else if (type === "plot") { await PlotCell.init(); newCell = new PlotCell; } else if (type === "insert") { newCell = new InsertCell; } else if (type === "fluid") { await FluidCell.init(); newCell = new FluidCell(appState.config.fluidConfig); } else if (type === "code") { await CodeCell.init(); newCell = new CodeCell(); } else { throw new Error(`Attempt to insert uninsertable cell type ${type}`); } appState.cells.splice(index, 0, newCell); appState.results.splice(index, 0, null); appState.system_results.splice(index, 0, null); appState.activeCell = index; } export function clearResults() { appState.results = []; appState.system_results = []; appState.codeCellResults = {}; appState.sub_results = new SvelteMap(); } export function handleClickInCell(index: number) { if (appState.activeCell !== index && !appState.inCellInsertMode) appState.activeCell = index; } export function getSheetObject(includeResults=true): Sheet { return { version: appState.currentVersion, config: appState.config, cells: appState.cells.map(x => x.serialize()).filter(item => item !== null), title: appState.title, results: includeResults ? (appState.resultsInvalid ? [] : appState.results) : [], system_results: includeResults ? appState.system_results : [], codeCellResults: includeResults ? appState.codeCellResults : {}, sub_results: includeResults ? [...appState.sub_results.entries()] : [], nextId: BaseCell.nextId, sheetId: appState.sheetId, insertedSheets: appState.insertedSheets }; } export function getSheetJson() { const sheet = getSheetObject(); return ' ' + JSON.stringify(sheet); } export async function resetSheet() { let defaultConfig: Config; try { defaultConfig = normalizeConfig(await idbGet('defaultConfig')); } catch(e) { console.warn('Error retrieving default config for idb'); defaultConfig = getDefaultConfig(); } appState.config = defaultConfig; appState.cells = []; appState.title = defaultTitle; appState.results = []; appState.resultsInvalid = true; appState.system_results = []; appState.sub_results = new Map(); BaseCell.nextId = 0; DataTableCell.nextParameterId = 1; DataTableCell.nextInterpolationDefId = 1; DataTableCell.nextPolyfitDefId = 1; CodeCell.nextFuncId = 1; appState.history = []; appState.insertedSheets = []; appState.activeCell = 0; appState.sheetId = window.crypto.randomUUID(); } export function incrementActiveCell() { if (appState.activeCell !== -1) { if (appState.activeCell < appState.cells.length -1 ) { appState.activeCell = appState.activeCell+1; } } else if (appState.cells.length > 0) { appState.activeCell = 0; } } export function decrementActiveCell() { if (appState.activeCell !== -1) { if (appState.activeCell > 0 ) { appState.activeCell = appState.activeCell-1; } } else if (appState.cells.length > 0) { appState.activeCell = appState.cells.length-1; } } export function deleteCell(index: number, forceDelete=false) { let newCells: Cell[]; let newResults: (Result | FiniteImagResult | MatrixResult | DataTableResult | RenderResult | PlotResult[])[]; let newSystemResults: SystemResult[]; if (appState.cells[index].type !== "deleted" && appState.cells[index].type !== "insert" && !forceDelete) { const contentDiv = document.getElementById(`cell-${index}`); let height = 0; if (contentDiv) { height = contentDiv.getBoundingClientRect().height; } newCells = [...appState.cells.slice(0,index), new DeletedCellClass(appState.cells[index], height), ...appState.cells.slice(index+1)]; newResults = [...appState.results.slice(0,index), null, ...appState.results.slice(index+1)]; newSystemResults = [...appState.system_results.slice(0,index), null, ...appState.system_results.slice(index+1)]; } else { // user comfirming delete of an undo delete cell or a insert cell newCells = [...appState.cells.slice(0,index), ...appState.cells.slice(index+1)]; newResults = [...appState.results.slice(0,index), ...appState.results.slice(index+1)]; newSystemResults = [...appState.system_results.slice(0,index), ...appState.system_results.slice(index+1)]; } if (appState.activeCell >= newCells.length) { appState.activeCell = newCells.length-1; } appState.cells = newCells; appState.results = newResults; appState.system_results = newSystemResults; appState.resultsInvalid = true; } ================================================ FILE: src/types.ts ================================================ import type MathCell from "./cells/MathCell.svelte"; import type { SystemDefinition } from "./cells/SystemCell.svelte"; import type { FluidFunction } from "./cells/FluidCell.svelte"; import type { CodeCellFunction } from "./cells/CodeCell.svelte"; import type { Statement, SubQueryStatement } from "./parser/types"; import type { MathField } from "./cells/MathField.svelte"; import type { CustomBaseUnits, MathCellConfig } from "./sheet/Sheet"; import type { InterpolationFunction, GridInterpolationFunction } from "./cells/DataTableCell.svelte"; import type DataTableCell from "./cells/DataTableCell.svelte"; import type { RuntimeInfo } from "./utility"; export type ModalInfo = { state: "uploadSheet" | "uploadPending" | "success" | "error" | "requestPersistentStorage" | "retrieving" | "restoring" | "bugReport" | "tryEpxyz" | "supportedUnits" | "opening" | "saving" | "termsAndConditions" | "newVersion" | "insertSheet" | "keyboardShortcuts" | "updateAvailable" | "sheetSettings" | "generateCode" | "customMatrix" | "generatingDocument" | "downloadDocument" | "importingSpreadsheet" | "pyodideRuntimeWarning"; modalOpen: boolean; heading: string; url?: string; error?: string; insertionLocation?: number; mathCell?: MathCell; dataTableCell?: DataTableCell; dataTableColumnNumber?: number; setCellNumberConfig?: (input: MathCellConfig) => void; codeGenerationIndex?: number; targetMathField?: MathField; runtimeInfo?: RuntimeInfo; } export type RecentSheetUrl = { url: string; accessTime: Date; title: string; }; export type RecentSheetFile = { fileName: string; fileHandle: FileSystemFileHandle; accessTime: Date; title: string; } export type RecentSheets = Map; export type StatementsAndSystems = { statements: (Statement | SubQueryStatement)[]; systemDefinitions: SystemDefinition[]; fluidFunctions: FluidFunction[]; codeCellFunctions: CodeCellFunction[]; interpolationFunctions: (InterpolationFunction | GridInterpolationFunction)[]; customBaseUnits?: CustomBaseUnits; simplifySymbolicExpressions: boolean; convertFloatsToFractions: boolean; } ================================================ FILE: src/utility.ts ================================================ import { unit, bignumber, createUnit, type Unit, type BigNumber, type Fraction } from "mathjs"; import { UNITS_WITH_OFFSET } from "./parser/constants"; import type { MathfieldElement } from "mathlive"; import pyodideInfo from "./pyodide-info.json"; let customUnitsSet = false; export function createCustomUnits() { if (customUnitsSet) { // An error is generated if custom units are already set // Needed in dev mode to allow HMR return; } createUnit({ // absolute or dynamic viscosity poise: { prefixes: 'long', definition: '1 dyn*s/cm^2', }, P: { prefixes: 'short', definition: '1 dyn*s/cm^2', }, reyn: { prefixes: 'long', definition: '1 lbf*s*in^-2', aliases: ['reyns'] }, ureyn: { definition: '.000001 reyn', aliases: ['ureyns'] }, // kinematic viscosity stokes: { prefixes: 'long', definition: '1 cm^2/s', aliases: ['stoke'] }, St: { prefixes: 'short', definition: '1 cm^2/s' }, // pressure kpsi: { definition: '1000 lbf/in^2', aliases: ['ksi'] }, Mpsi: { definition: '1000000 lbf/in^2', }, inHg: { definition: '3386.38 Pa' // @ 0 degC }, ftH2O: { definition: '2988.98 Pa' // @ 4 degC }, inH2O: { definition: '249.082 Pa' // @ 4 degC }, // Energy Btu: { definition: '1 BTU' }, // power tonrefrigeration: { definition: '12000 BTU/hr', aliases: ['TR', 'RT', 'TOR', 'toncooling'] }, boilerhp: { definition: '33479 BTU/hr', aliases: ['BHP'] }, MBH: { definition: '1000 BTU/hr' }, MMBH: { definition: '1000000 BTU/hr' }, // force gramforce: { definition: '.001 kilogramforce', aliases: ['gf'] }, }); customUnitsSet = true; } export function convertUnits(value: string, startingUnits: string, userUnits: string) { if (startingUnits === "") { startingUnits = "in/in"; // only way to specify unitless for mathjs } if (userUnits === "") { userUnits = "in/in"; } let startingValuePlusUnits: Unit; try { startingValuePlusUnits = unit(bignumber(value), startingUnits); unit(userUnits); // just checking that it parses for later } catch(e) { console.warn(`Units not recognized, either ${startingUnits} or ${userUnits}`); return { value: null, unitsMismatch: true}; } // check that dimensions are compatible for the conversion let newValue: BigNumber; try { newValue = startingValuePlusUnits.toNumeric(userUnits) as BigNumber; } catch(e) { return { value: null, unitsMismatch: true}; } return {newValue: newValue, unitsMismatch: false } } export function arraysEqual(a: any[], b: any[]) { return a.length === b.length && a.every((item, i) => item === b[i]); } export function unitsEquivalent(units1: string, units2: string) { try { if (arraysEqual(unit(units1).dimensions, unit(units2).dimensions)) { return true; } else { return false; } } catch (e) { // One of the units not recognized by mathjs // Units cannot be used so mark them as not matching console.warn(`Units not recognized, either '${units1}' or '${units2}' caused the error`); return false; } } export function convertArrayUnits(values: number[], startingUnits: string, userUnits: string) { if (startingUnits === "") { startingUnits = 'in/in'; } return values.map(value => { return unit(value, startingUnits).toNumber(userUnits); }); } export function getConversionFactor(startingUnits: string) { const currentUnit = unit(1, startingUnits); let offset: number = 0; let scaleFactor: number; // @ts-ignore if (!currentUnit._isDerived() && currentUnit.units[0].unit.offset !== 0 ) { offset = currentUnit.units[0].unit.offset; scaleFactor = currentUnit.units[0].unit.value; } else { scaleFactor = currentUnit.value; } return { offset: offset, scaleFactor: scaleFactor } } export function getArraySI(values: string[], units: string): number[] { if (units.trim() === '') { // no units, no need to convert return values.map(value => Number(value)); } else if (UNITS_WITH_OFFSET.has(units)) { // need to handle temperature units differently return values.map(value => (unit(`${value} ${units}`).toNumeric('K') as number)); } else { return values.map(value => (unit(`${value} ${units}`).value as number)); } } export function unitsValid(units: string | undefined): boolean { return !units || !units.includes("Dimension Error"); } export function isVisible(element: HTMLElement, container: HTMLElement) { const { bottom, top } = element.getBoundingClientRect(); const { bottom: containerBottom, top: containerTop } = container.getBoundingClientRect(); return top >= containerTop && bottom <= containerBottom; } // Version must be integer of form YYYYMMDD // Assumes version date is in CST export function versionToDateString(version: number) { const versionString = version.toString(); return (new Date(`${versionString.slice(0,4)}-${versionString.slice(4,6)}-${versionString.slice(6)}T00:00:00.000-06:00`)).toLocaleDateString(); } export function debounce(func: Function, timeout = 300){ let timer: undefined | number; return (...args: any[]) => { clearTimeout(timer); timer = setTimeout(() => { func.apply(this, args); }, timeout); }; } export function sleep(timeout: number) { return new Promise((resolve) => setTimeout(resolve, timeout)); } export function getBlankMatrixLatex(numRows: number, numColumns: number): string { let blankMatrixLatex = "\\begin{bmatrix} "; for (let row = 0; row < numRows; row++) { for (let col = 0; col < numColumns; col++) { blankMatrixLatex += "\\placeholder{} "; if (col < numColumns -1) { blankMatrixLatex += "& " } } if (row < numRows -1) { blankMatrixLatex += String.raw`\\ ` } } blankMatrixLatex += " \\end{bmatrix}"; return blankMatrixLatex; } export function saveFileBlob(fileBlob: Blob, fileName: string) { const sheetDataUrl = URL.createObjectURL(fileBlob); const anchor = document.createElement("a"); anchor.href = sheetDataUrl; anchor.download = fileName; anchor.click(); // give download a chance to complete before deleting object url setTimeout( () => URL.revokeObjectURL(sheetDataUrl), 5000); } export function inMatrix(mf: MathfieldElement): boolean { // @ts-ignore const env = mf._mathfield.model.parentEnvironment?.environmentName ?? ''; return [ 'array', 'matrix', 'pmatrix', 'bmatrix', 'vmatrix', 'Bmatrix', ].includes(env); } export async function loadMathJax() { (window as any).MathJax = { startup: { ready: () => { (window as any).MathJax.startup.defaultReady(); }, pageReady: async () => {} // prevents the initial typeSetting of the page, must return a promise }, options: { skipHtmlTags: ['script', 'noscript', 'style', 'textarea', 'pre', 'code', 'annotation', 'annotation-xml'], }, tex: { inlineMath: [['$', '$'], ['\\(', '\\)']] } }; const mathJaxScript = document.createElement("script"); mathJaxScript.id = "MathJax-script"; mathJaxScript.src = "mathjax/tex-svg.js"; mathJaxScript.async = true; const loadPromise:Promise = new Promise((resolve, reject) => { mathJaxScript.onload = () => resolve(); }); document.head.appendChild(mathJaxScript); await loadPromise; if ((window as any).MathJax?.startup?.promise) { await (window as any).MathJax.startup.promise; } } type PyodideInfo = (typeof pyodideInfo)[number]["info"]; export type RuntimeInfo = | { oldRuntime: false } | { oldRuntime: true; newPyodideInfo: PyodideInfo; oldPyodideInfo: PyodideInfo; safePermalink: string; }; export function checkPyodideRuntime(fileVersion: number): RuntimeInfo { if (fileVersion < pyodideInfo.slice(-1)[0].releaseVersion) { let oldPyodideInfo: PyodideInfo; let safePermalink: string; for (let i = pyodideInfo.length - 2; i >= 0; i--) { if (fileVersion >= pyodideInfo[i].releaseVersion) { oldPyodideInfo = pyodideInfo[i].info; safePermalink = pyodideInfo[i].latestPermalink; break; } } return { oldRuntime: true, newPyodideInfo: pyodideInfo.slice(-1)[0].info, oldPyodideInfo, safePermalink } } else { return { oldRuntime: false } } } ================================================ FILE: svelte.config.js ================================================ import { vitePreprocess } from "@sveltejs/vite-plugin-svelte"; import { optimizeImports } from "carbon-preprocess-svelte"; export default { preprocess: [vitePreprocess(), optimizeImports()], }; ================================================ FILE: tests/seed-data.json ================================================ [ { "key": "2kftdqNYyiaqAEyhXboNZF", "value": "{\"title\":\"Database Consistency Test\",\"data\":\"{\\\"version\\\":20251012,\\\"config\\\":{\\\"mathCellConfig\\\":{\\\"symbolicOutput\\\":false,\\\"showIntermediateResults\\\":false,\\\"formatOptions\\\":{\\\"notation\\\":\\\"auto\\\",\\\"precision\\\":15,\\\"lowerExp\\\":-3,\\\"upperExp\\\":5}},\\\"customBaseUnits\\\":{\\\"mass\\\":\\\"kg\\\",\\\"length\\\":\\\"m\\\",\\\"time\\\":\\\"s\\\",\\\"current\\\":\\\"A\\\",\\\"temperature\\\":\\\"K\\\",\\\"luminous_intensity\\\":\\\"cd\\\",\\\"amount_of_substance\\\":\\\"mol\\\",\\\"force\\\":\\\"N\\\",\\\"area\\\":\\\"m^2\\\",\\\"volume\\\":\\\"m^3\\\",\\\"energy\\\":\\\"J\\\",\\\"power\\\":\\\"W\\\",\\\"pressure\\\":\\\"Pa\\\",\\\"charge\\\":\\\"C\\\",\\\"capacitance\\\":\\\"F\\\",\\\"electric_potential\\\":\\\"V\\\",\\\"resistance\\\":\\\"ohm\\\",\\\"inductance\\\":\\\"H\\\",\\\"conductance\\\":\\\"S\\\",\\\"magnetic_flux\\\":\\\"Wb\\\",\\\"magnetic_flux_density\\\":\\\"T\\\",\\\"angle\\\":\\\"rad\\\",\\\"information\\\":\\\"b\\\"},\\\"simplifySymbolicExpressions\\\":true,\\\"convertFloatsToFractions\\\":true,\\\"fluidConfig\\\":{\\\"fluid\\\":\\\"Water\\\",\\\"incompMixConc\\\":0.5,\\\"customMixture\\\":[{\\\"fluid\\\":\\\"R32\\\",\\\"moleFraction\\\":0.697615},{\\\"fluid\\\":\\\"R125\\\",\\\"moleFraction\\\":0.302385}]}},\\\"cells\\\":[{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":4,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Introduction\\\"},{\\\"attributes\\\":{\\\"header\\\":1},\\\"insert\\\":\\\"\\\\n\\\"},{\\\"insert\\\":\\\"This EngineeringPaper.xyz sheet shows how to calculated the maximum stress and displacement for a cantilever beam loaded by a vertical force at its end. The geometry of the beam is shown in the figure below. The beam has a rectangular cross section with height h and width b. The maximum stress in a cantilever with length much larger than its height is due to bending stress that occurs at the base of the beam. For a downward force, the maximum stress will be a tensile force at the top of the beam and a compressive stress at the bottom of the beam. For beam sections that are symmetric top to bottom, the maximum tensile and compressive stresses will have equal magnitude.\\\\n\\\"},{\\\"insert\\\":{\\\"image\\\":\\\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAA1oAAAHJCAYAAACcz0haAAAgAElEQVR4XuydB5gTxRvGv+SODgoWEFDAhgiCvSBgQywIUqX3XqWDVBHpXXrvvYMgUqQJKLa/KCiKqCACUgSp6iV3/3k3bm4vJLkkl+SyyTvPcw/KbXZnfjMb5p2vWZJUEzYSIAESIAESIAESIAESIAESIIGgEbBQaAWNJW9EAiRAAiRAAiRAAiRAAiRAAhoBCi0uBBIgARIgARIgARIgARIgARIIMgEKrSAD5e1IgARIgARIgARIgARIgARIgEKLa4AESIAESIAESIAESIAESIAEgkyAQivIQHk7EiABEiABEiABEiABEiABEqDQ4hogARIgARIgARIgARIgARIggSAToNAKMlDejgRIgARIgARIgARIgARIgAQotLgGSIAESIAESIAESIAESIAESCDIBCi0ggyUtyMBEiABEiABEiABEiABEiABCi2uARIgARIgARIgARIgARIgARIIMgEKrSAD5e1IgARIgARIgARIgARIgARIgEKLa4AESIAESIAESIAESIAESIAEgkyAQivIQHk7EiABEiABEiABEiABEiABEqDQ4hogARIgARIgARIgARIgARIggSAToNAKMlDejgRIgARIgARIgARIgARIgAQotLgGSIAESIAESIAESIAESIAESCDIBCi0ggyUtyMBEiABEiABEiABEiABEiABCi2uARIgARIgARIgARIgARIgARIIMgEKrSAD5e1IgARIgARIgARIgARIgARIgEKLa4AESIAESIAESIAESIAESIAEgkyAQivIQHk7EiABEiABEiABEiABEiABEqDQ4hogARIgARIgARIgARIgARIggSAToNAKMlDejgRIgARIgARIgARIgARIgAQotLgGSIAESIAESIAESIAESIAESCDIBCi0ggyUtyMBEiABEiABEiABEiABEiABCi2uARIgARIgARIgARIgARIgARIIMgEKrSAD5e1IgARIgARIgARIgARIgARIgEKLa4AESIAEQkRgxUd22ftNktx8o0jvJvEhekpk3vbfhCS58rfIDVlF4uIskdlJ9ooESIAESIAEQkiAQiuEcHlrEnBHoNlAm1y46PjNvQVFhrRNfQO+bpdd5q1Pct6uR2OrPH6/1XSA539gl7U7ksehDyCDQpA1s9qUZxe5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zSZPnpyhq3hnWJYOeicWQfMkKaGlioLKWr377rt2yimnRFj4XWgddNBBtmvXLicrV6dOnaDFmPlAAAIQgAAEIACBhAkMGzbMLr74YjvhhBPsgw8+SPg8vx6I0PJr5Lzvd1JCS4UulLWaOHGide/ePTI7iZM1a9bY559/bs2bN/f+rPN5WKZMGfvpp5+crFzt2rV95z8OQwACEIAABCAAgXQRQGiliyTjhJ0AQmvvHYDQCvu3AfOHAAQgAAEIQMAl8Morr9gll1xiJ554or3//vuBB0NGK/AhztkEkxJaKnShrNV7771nJ598csRpZYHWrl1rCxcutKOOOipnk0n1wqVKlbJffvnFycrVqlUr1WE4DwIQgAAEIAABCPieAELL9yFkAh4hgNDaGwiElkfuRtyAAAQgAAEIQCDnBF5++WXr16+fnXTSSTZp0qSc+5NpB8hoZZpweMdPSmipoqCyVvqm0zefa8oCrVu3zhYtWmTNmjXzHc0DDjjA8VlZuZo1a/rOfxyGAAQgAAEIQAAC6SIwdOhQ69+/v7N6SauYgm4IraBHOHfzS6vQ+uKLL6xp06a5m02KV3aFlsTiH8svmMoAACAASURBVP7whxRH4TQIQAACEIAABCDgfwIILf/HkBl4gwBCa28cXKH1+OOPmyorHnHEEVajRg1vRAgvIAABCEAAAhCAQBYJILSyCJtLBZpAUkJLpdu1PFAVaFSJxjV36aBfM1qVKlWybdu27RPoatWq2SGHHGKHHnqoNWjQwA4//HDn07BhQ6tSpUqgbwomBwEIQAACEIBAeAm89NJLNmDAAKeVj1r6BN1YOhj0COdufikJLTWvUxM717Svaf369bZ48WJr0qRJ7maT4pUnTJhg77zzjn399df2zTffOP201Fcrlmm+Bx98sCPADjvssH1EWIUKFVL0gtMgAAEIQAACEIBA7gkMGTLELr30UjvllFPs3Xffzb1DGfYAoZVhwCEePimhpdLtylpNnjzZunXrFsGmfU0bNmywJUuW2JFHHul7nD///LMjtiS8NKdly5bZt99+a999952tXr06rggTi3r16ln9+vWdjFjjxo0d8anliHl5eb5nwwQgAAEIQAACEAg2gRdffNEuu+wyO/XUU00vo4NuCK2gRzh380NoJcl+586d9uWXX9pXX33lfCTG9Fm1apXThyueSXjpoyxY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\\\"}},{\\\"attributes\\\":{\\\"header\\\":1},\\\"insert\\\":\\\"\\\\n\\\\n\\\"},{\\\"insert\\\":\\\"Select Beam Material\\\"},{\\\"attributes\\\":{\\\"header\\\":1},\\\"insert\\\":\\\"\\\\n\\\"}]}},{\\\"type\\\":\\\"table\\\",\\\"id\\\":5,\\\"rowLabels\\\":[\\\"Steel\\\",\\\"Aluminum\\\"],\\\"nextRowLabelId\\\":3,\\\"parameterLatexs\\\":[\\\"E\\\",\\\"\\\\\\\\rho\\\"],\\\"nextParameterId\\\":3,\\\"parameterUnitLatexs\\\":[\\\"\\\\\\\\left[GPa\\\\\\\\right]\\\",\\\"\\\\\\\\left[\\\\\\\\frac{kg}{m^{3}}\\\\\\\\right]\\\"],\\\"rhsLatexs\\\":[[\\\"206.8\\\",\\\"7800\\\"],[\\\"71.7\\\",\\\"2800\\\"]],\\\"selectedRow\\\":1,\\\"rowJsons\\\":[]},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":3,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Select Beam Section\\\"},{\\\"attributes\\\":{\\\"header\\\":1},\\\"insert\\\":\\\"\\\\n\\\"}]}},{\\\"type\\\":\\\"table\\\",\\\"id\\\":1,\\\"rowLabels\\\":[\\\"Filled Circle\\\",\\\"Hollow Circle\\\",\\\"Ellipse\\\",\\\"Rectangle\\\",\\\"Hollow Rectangle\\\"],\\\"nextRowLabelId\\\":6,\\\"parameterLatexs\\\":[\\\"I_{x}\\\",\\\"c\\\",\\\"r\\\",\\\"r_{1}\\\",\\\"r_{2}\\\",\\\"a\\\",\\\"b\\\",\\\"h\\\",\\\"b_{1}\\\",\\\"h_{1}\\\"],\\\"nextParameterId\\\":11,\\\"parameterUnitLatexs\\\":[\\\"\\\",\\\"\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\"],\\\"rhsLatexs\\\":[[\\\"\\\\\\\\frac{\\\\\\\\pi}{4}\\\\\\\\cdot r^{4}\\\",\\\"r\\\",\\\"37.5\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\"],[\\\"\\\\\\\\frac{\\\\\\\\pi}{4}\\\\\\\\cdot\\\\\\\\left(r_{2}^{4}-r_{1}^{4}\\\\\\\\right)\\\",\\\"r_{2}\\\",\\\"\\\",\\\"27.5\\\",\\\"37.5\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\"],[\\\"\\\\\\\\frac{\\\\\\\\pi}{4}\\\\\\\\cdot a\\\\\\\\cdot b^{3}\\\",\\\"b\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"27.5\\\",\\\"37.5\\\",\\\"\\\",\\\"\\\",\\\"\\\"],[\\\"\\\\\\\\frac{b\\\\\\\\cdot h^{3}}{12}\\\",\\\"\\\\\\\\frac{h}{2}\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"50\\\",\\\"75\\\",\\\"\\\",\\\"\\\"],[\\\"\\\\\\\\frac{b\\\\\\\\cdot h^{3}-b_{1}\\\\\\\\cdot h_{1}^{3}}{12}\\\",\\\"\\\\\\\\frac{h}{2}\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"50\\\",\\\"75\\\",\\\"30\\\",\\\"55\\\"]],\\\"selectedRow\\\":3,\\\"rowJsons\\\":[{\\\"ops\\\":[{\\\"attributes\\\":{\\\"alt\\\":\\\"Moment of area of a circle.svg\\\",\\\"height\\\":\\\"230\\\",\\\"width\\\":\\\"230\\\"},\\\"insert\\\":{\\\"image\\\":\\\"https://upload.wikimedia.org/wikipedia/commons/thumb/a/a7/Moment_of_area_of_a_circle.svg/230px-Moment_of_area_of_a_circle.svg.png\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]},{\\\"ops\\\":[{\\\"attributes\\\":{\\\"alt\\\":\\\"Moment of area of an annulus.svg\\\",\\\"height\\\":\\\"230\\\",\\\"width\\\":\\\"230\\\"},\\\"insert\\\":{\\\"image\\\":\\\"https://upload.wikimedia.org/wikipedia/commons/thumb/6/6e/Moment_of_area_of_an_annulus.svg/230px-Moment_of_area_of_an_annulus.svg.png\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]},{\\\"ops\\\":[{\\\"attributes\\\":{\\\"alt\\\":\\\"Moment of area of an ellipse.svg\\\",\\\"height\\\":\\\"230\\\",\\\"width\\\":\\\"230\\\"},\\\"insert\\\":{\\\"image\\\":\\\"https://upload.wikimedia.org/wikipedia/commons/thumb/c/c0/Moment_of_area_of_an_ellipse.svg/230px-Moment_of_area_of_an_ellipse.svg.png\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]},{\\\"ops\\\":[{\\\"insert\\\":{\\\"image\\\":\\\"data:image/png;base64,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\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]},{\\\"ops\\\":[{\\\"attributes\\\":{\\\"alt\\\":\\\"Moment of area of a hollow rectangle.svg\\\",\\\"height\\\":\\\"230\\\",\\\"width\\\":\\\"230\\\"},\\\"insert\\\":{\\\"image\\\":\\\"https://upload.wikimedia.org/wikipedia/commons/thumb/a/a2/Moment_of_area_of_a_hollow_rectangle.svg/230px-Moment_of_area_of_a_hollow_rectangle.svg.png\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]}]},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":2,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Source for beam section equations and images: \\\"},{\\\"attributes\\\":{\\\"link\\\":\\\"https://en.wikipedia.org/wiki/List_of_second_moments_of_area\\\"},\\\"insert\\\":\\\"https://en.wikipedia.org/wiki/List_of_second_moments_of_area\\\"},{\\\"insert\\\":\\\"\\\\n\\\"}]}},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":7,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Define the Other Beam Parameters\\\"},{\\\"attributes\\\":{\\\"header\\\":1},\\\"insert\\\":\\\"\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":6,\\\"latex\\\":\\\"l=500\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"config\\\":null},{\\\"type\\\":\\\"math\\\",\\\"id\\\":8,\\\"latex\\\":\\\"F=500\\\\\\\\left[N\\\\\\\\right]\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":9,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Define the Deflection and Stress Equations\\\"},{\\\"attributes\\\":{\\\"header\\\":1},\\\"insert\\\":\\\"\\\\n\\\"},{\\\"insert\\\":\\\"The maximum displacement of a cantilever beam loaded at its end is defined by [1]:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":10,\\\"latex\\\":\\\"y_{max}=-\\\\\\\\frac{F\\\\\\\\cdot l^{3}}{3\\\\\\\\cdot E\\\\\\\\cdot I_{x}}\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":12,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"where Ix is the area moment of inertia of the cross section about the x-axis as selected in the table above. The maximum displacement can now be queried:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":11,\\\"latex\\\":\\\"y_{max}=\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":13,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"The maximum bending stress in a beam section is given by:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":14,\\\"latex\\\":\\\"\\\\\\\\sigma_{max}=\\\\\\\\frac{M\\\\\\\\cdot c}{I_{x}}\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":15,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"where M is the bending moment at the section of interest and c is distance from the neutral axis of the beam to the top or bottom of the beam. The maximum moment occurs at the base of the beam and is defined by:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":16,\\\"latex\\\":\\\"M=l\\\\\\\\cdot F\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":17,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"where l is the length of the beam. Now that everything is defined, the maximum stress can be queried and converted to [MPa] units:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":18,\\\"latex\\\":\\\"\\\\\\\\sigma_{max}=\\\\\\\\left[MPa\\\\\\\\right]\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":20,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"These results can be compared to the results obtained from a finite element analysis using SolidWorks. The beam has the same dimensions, loading, and material as the rectangular cross-section and the aluminum table options above. The displacement plot is shown below. The maximum displacement magnitude obtained using finite element analysis is .175 [mm], which is close to the .165 [mm] obtained using the equations above.\\\\n\\\"},{\\\"insert\\\":{\\\"image\\\":\\\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABH0AAAJbCAYAAAB5M+ilAAAgAElEQVR4Xuy9CdguSVUm+N2tblXdW1W3Noql9gIKZLd1EEQFtcpibUBBbXUYHwcXENFWmUehXdoFFBUZbR2l3caZaRVbkVZklUURbVlkl71Yiq2qgNpv3XXyZH6RGZkZy3siTiz5/d/3cLl1/y/inPe852RkxvtHRuw6fvz4ydX2sxEMnDRmcpteU3LNXJUog7j81BPHnLvS9SjLjTlPsj7GHE5tjxHE1c1q3T3SSgN4sCDNhdsejjweV+cr3g5qwx9bPJZxTH6PhrFR6zTvD1h09kfG4pPROcF49MeC2fHHdFLKEFyv/timqAUhzgiZxs9H5+c4PJ4caDp0KTnWx2w+W+h9XsKyrI20nKJY8RqSHAtQdNt2OAO7du3CGxtbxvbvjEbDYEYRHzfuMDw2P7d9C39THPCkpW66iyWhMwNKE3+7tqJPcD6r6Vh6cl0NEQCQOm78Cij+AGAKra5YBoRSk3UgnaMmafmYSC5xqXOG5hZ7ImsngdjTIxLiBMuj3xlmx19lkg/fGKb0samY/J4s/Ew6sgXJ6DqUEeJqycdwDQVnZJYoqdikr29zRQmIkP5LOfJ+IZcbG1QsZ8xA55URayCSR1H3kLE8vLqg8GpH8p4DEbRtxGYgXvyQEwDCxRF22E2HDncOn+E+cG7Dffi5m6LILfxsRR9/jhbVYriR8W4oiwoyEmz5m/00ALlc1RbbVuyJLNZ1d8WjuVIC6yd6kt1P/ZI/8EvVUfz1ISMs6ITFxiYdU2A19YsFQms0Ng6pSVFsPuQEkdy1Zr6endPW4GLBJ8PusU9mfOXnLEngxmBirws3Q7JxpMUqk+t6MGLcS41rMuxtrSAM7FTxJz5uP7vhgkzNoo+KG8foZ8rdQudxu9Inls0C/bdiD056PTd9wozd+H3R1RWTbSm6TKz5JyH5xI2ZHOgUZgL53Io9vsvJ8H3uCTie2/Br3xwT7lkpkt3fpcQe5TmchzV+Z+A4K7E4pOLRixjDlDNGv+iTU+zZeaIPnmvOYInVGceifNt6MGI52Io+8jWQ2mK8+CE3+Q8XSfgsxceN++THhXOa8zWvcRw4Rpwpc8ut6BPLYOb+5hsXdhPJDLUqd0u74dvIqyeOMcKSdSnPift6kvc3cDm1PUYScZ03XSN6T8pxsCTNRT2rLQbBTyrG8rHZBSxWbXjFQ7+1eE7j9/DxT/j9cbSiF9bMcT9Mcz1huHjgMZvcW7+QCMl1u27Pi4nHVwgkHh6OhzTY0+HlxOZuWw9GPAdb0Ucu/7ksyYkfMiIAXyAJZarm17z4XKbkrfRrXirDFON2pU9ovWfoV3JSnSG8ZC6WeLM3kVFPHHN0pWtTlpsNFHxEJqaDCCIz0UXraOwXGSjk6kFGWJASe+J4F5pYewWfFqU3TbE5kpoQxeYmNo6OKJk600nHcflz1V+BeFNv/ocGdsEriTsNGc4RfwxiEDBryseFepNnNB1WNCZ/u3ow4vxLjW9+drYtpBnYycJPSrFE5YnvI0D0IWf8blApmczK1QwEoW20FX1wrrK3nN+08JtHdrCFHdZzg5d7UKwvpvVUxVmG6WtUnhc7Znlf2rTH4FabCsVdUdAkHXGRZjUCeY6deMtPSuVirSU2sZOQnPUEXPPR9WgWr5AK1tvE5kVqPEgxucOwAbmKEkh8GRn7N2HmIfT5G3+PcSR3D0fR8XDBVtGG7HZp8LJhODvUg9Ff0SnGA1k2t9ZQBuIn8jKqA18kQSOct4uPGfPNi4nP46gHv7szCLPoo7oIO3Mg2Yo+WK1lbTXcrPw3i6zAKnRWz41d/kGxtthiJ0yx5SPPR41iT2QdRU+u7f6l+Mfs4GMfZs9VfbnEHjy38TF1vqREn9hrPzyeOsSePnN4WVoKTiYe3TjGbRhwzDZnZLfHH4aQ49snNOPXJ8+rvbU8v6PKkILZ20mLVxZueax4RW9FH9ncl7QWL4DICAA8gSSOsfiYef55seF85hZ9esmHFxCPrEnrregTRZ9s5+3KHpzP8jf0KVb8Bm+Ksr54BpSxEz48q+OW6TiZ5yqdr3n0ui8DkjC6FiD2YBNn/DqSy5ncazYYJn+MmB1XqYwn136PTo2i2KbNUpOh2DEsPh8dv1LxjKb2zuTyMy8Vq/k+JzbiscZJXkx8zlhgtMY8XFwv8nGkxcuNz92+PFY//ynGA1kWt9ZCGQgXQnCRwoUto47QvDIkgxnlmueOj63twe8Gwa9hxc92Tx8oVbKNzDck/01CFsXyrJW/kU85i8tZffEM8ZWs0XS8mPOVzp+ZT7Gpzw4UezDxCB3b5ASfblLv8usfK+LrcL6Swu/VgNlZV4DFyLqUmgxhfPrjwez4a04qLn+t9VeJH1QWEaLMCh9e3vx1wCLT05iHjetZNpa0WLmxLV/sGe5hsnmSZXJrLYaBOCEkXnHgCSMxkdI+MfF4OQjC3PEwphJ+tqIPJ9Mb1HZ8E90O/L7U1vnQEZe3OmPqMrF5go89VznyUPfqnjbj/SWYgo9YMWQ6PsRjtE9CfWOR7Xs7JmyciIvJnD/M8yQirVOwONl0DPK9hiIljvg5xVD67SBVIycw4niw+HARCYnT1EZIjGS4xzkaj38MF0FNebi4LvB8o5bT4kVR4O3K4sX5lxrjcGa2LXMzECeG8EQKU2xh4kgIS7vaDYJzfcJ88QGmEH5sKLqY+BhDON+u9AlhLaLPVvDhkVf2Jq5jxW/orgjriWeOUnpyzsu0b6UE15r7YT5HHkw+tOl5SEB9Hzn88gKIAildT/Exy4tbUjGGx2bOH3u0mnQY/xO3Fh5HXzUCx6H7xhI8nnYU4TU3XNey1xiGhwcasxkyZM2vOR6yEJ+cnOVA08WQjmP3vS6MwRyYY5Bxn19kfY2t4TW0FXtS5qE+2+HCj4wAECaQhPCYT/gJiymMzzBfbv7swk8YRm62tqIPlzFm+5KrJphQq2qe9gEpJFT8xu6yXl9cvodRmbjzcmLHnIP/lGKPWkIRnxXZiaieXykhBBOPkGt5E8UeNSkLXo9jnbeEWIy/rmTqUbL2aomJdx3wRob4GG3XXxmxh8dVOrHExEo6rtPFkRYzMnb725TH6L/mtmKPP4+b2CJc9FFsxAkBKUQLW57iY8UqICymMB7DfIFxTJpl4+/48eP+EQuLYdtKY2Ar9oSVQ/kbeP/YGBbApFc98czDkZwghZAlz00dYo8ZReQwu+4eaaVJ02QNR7zBPvVYPnGHmD2nnMjE5q9iqWsmNjbXJAJneCgHdx+/xZTx+LMytJDIT2wsg/Dg500utrD7llSsWgZmISkfsmyYmePHkwNVh5WPDamOtPjTYEbiwtuUx+jPwVb0wfO5iS3DJ/RhYsWUw5TihfIVHmNYxsNi4vEZ5gOLZ4okF3/blT5YfuBWww3IfyOAjW5ow/I3axOxMnmrMzbbw6dMzGiZynOzFXv83BvWbwinXWLCLTs5yr2Pip9Qqdo3TSL83udVEp0zETFSJk/RsYhNzGVWLQ3ikf/qXo/saMO+nVQ9mkSfqe2Q+uQGhMeTA80YPY4NiTo9flm8SEz8NnVg9OdiK/rwc7tpPeIm9TyxooToo/akSSmU6HGF+eHxGOaDV7kK0eCLh5HnrcnSdqUPlzJ7+63gg3NZx81ax+u/cSPR1ReX9jhuDVEmdh8/abixrKvJE9Lot7eTNTQ+Otzfi0ym+2njyJd0HiQm26MrUSR3MkICT4TyA5fhfhyb36ul1JqODrnUX7/RNSojjkjVX3xuZOLhXwv8CoiP1VQe9vj5CP3lN22BxZQDSUqxpx2R+OQwe2BcMo0KN68DI5aLregjnPwFmisp+ii6cogYJP7k8BPnAxNWcuyvnHvFz1b0ERg8tmIPTmIdN+rZ4yIegKNlnbF1gO3YsIeWGILS8OKYrqYPacZnnYLPBFUCXqQm3L08FY1xMCBVd5gdP3DMjutKm0+q/V4N9rRO8/6gRadg5BstZMQRP59gLM7x0RdLX7mecRa1M7TzxxcmAGB2uXjLCT54PHg9cKO3tcexcTymjSMNZk58WNvyOPE8bEUfLKeb3CpO9CFmMKHCx2GcWOKz3n0fH6vfT3wcGJ+bJvxsRR9/bc1azG82+OAf4G4jupS/QZtolMlbnbF18ZYUe9z+Y8vaMF2VSacT2JRPUbFn7VmunmQm18Yrx8k1PxEyMcvGi2Hyx4rZcZWdvNijvGkSGeuCDItJLj+Y/xy5UeOs3xeHYCy+doSFzeI2YZN9Q9ukFkcX4pPbJyWaMZaUXHNyzmYoH0VcaFqtBXcV7ugnayv2CFO+MHNXXHrB6iPXfm6EWgkil19yl9VHP/759jv6b/qof5vCHNq7xYrLLzm/sXO9lal4scSfhMsuPn/1sU/cUPmKH0z0oWhzcKajSfmq11b08dev42bjH/QZ5jeyadqHn1DKZPJWZ2wdJyWFyTS82HOWxp/7Id6MJq6u5OKQm1xPr7D6VvYMCKUfsGNjjc+n8OoJrTwNkik0mMbEJJkfDIf/esTs+KmRig3H44+Nd+36Y3S1mMbPR4f7xzlSNlOiMePmY0TiTx9HGtxIbHib8hjxPEiNCzg725Y1MYCKPoRZF4GmMYy/s4sVPsEnl4BBq5Iuu/i81bWfvCF5OsIFGYboo6LAu7Dj3oo+bMrSdRhuMvhgnw5N3ZbL35Bnj7pihNUX2zy0kmIPoZHnqKzY008b1jCWIPZMMUtcAFhe8fERs4cilxW5YsUeKf7FTuhqL8wOVajYQx3x7JrzJjkBqiVHihWpesbt4NnAbaLXm95ufO3hqEJ8rWsYdgI3DAcz6ZmDazGwmqG0uGURl8fqryvJsU6Wva21nAyYRB/ln77TV/bYVvvMxSCz8oAIPnrs4WIJziCt+Mkh/BAifjy4gtO3xLvgJK1bmkynWPGzXeljSI39puIf7NmZ3qAO5W/GJjJlclZnbEO8pWtWnh933uT92SaqGsezJoG15RSQQgeEMRZpfqQm2a3wEEjbnJk6xR6JGMVel/HWGpAMAcGHxBGJvEvVYTyWgbd4WxwxA8jX+kKRwmUZGdsf6z5wZKFjXBqe4tBwMIV6Ss9s2loJjdt/T5a17LPmz8NW7PFxuLO+54g+xIxptc/SRZ96X/PiKzh8YQmv963og3Ml1lLqgVIM0MIM1ffg4L9JoxTXFxvysCkXv42nNLz4cafxO47SPaHxYzRy5p2EoxWp2qUVe/wCBo8HubzVKfhIxCcp+HikU6jY4mKSE0ek7s9x8QzXnYwdZBw3X+u+5Enim4yM/T+VD94o4ENu/x6PKRciTv5C4k4fB85pCH7ZPmWx+nOxFX1k8710ayGiD8Ws7/Uz3+dnLg+YVvmon9Hf+kft9zP9+cc+Md4HqNuX5/rmNa1xf9XO9vNpznKt9uELMgGiDwXH7waVsc2s9Gqf7UqfJh3mG4l/gIcyucGNyt6AXcTG5a7euIaYpSZAoeWZliN7/lL6ddlu1imEUjXqJ4d/jkfONjKRCeNDCqPUwzWGB4sVs+Uro/mKGMz73K7UGBEel4wwh/n3s4TZ8eWHvpdZtaR7wrD5Y+TbROJVbewCMw8Zxyd6z5vazIEoFBsSf3r8WM0hWPO0KYvXnw+pe1IeNrdecjDgE31ok+fpSVdqZY9/c+dBJrCJPhSjvqmzLvToIo8ScNCfkV1fW8VvLtGH/PGFn7YXqxRSvuqVQ/jZ0aLPVuxh1XrfuOzN14TZf0NGIq0vLnQiJxN/eY7SCxnG6pm4NbMZybHYCh+ZibQr11JiQZoJqGz8krHGjR/zFTHBFeesNdxqXDz0yxTcV8p6FILRQJznCBkzw2NTPcN4lIt7jMNkNwwhjz0snhxI0PsyL75x6/RxYHzGxCDbtwxefx6kxjlZtrbWamAgVvRxnealixWulT5THlTbqUCiVvboYs109Q99N22HtM+1r4/CwhN/eKJPmA9eNU4RSa722ZGiz1bs4RVg/8jnv/+FGQ7uJQOozMMEL+jSNZuGI3v+0vgzc658LUHsSXktSgog8ji3Yo93xBASL2OvPalJkFQ9xsazFXvs157MHdhd2bz85UCUUvTJh5/Hq3f0SdagLE5/PqTGu2QEZjQsNWYrQYM3ec8YKOgKEX0GEUFfuTMc52535V/pYzq6fSoQKY53rujTZwDMateszIqfMIFKD2xHiD5yAxGrJjamcdmbrolG/40YJb++2DrkGC45Hmx8YThQtnspwNkhjU/7g/qSxB68NvCcYHzzag2ziWDcVLGnzaTxWucxveZQ6xRcz84VQvlyhdWOnyXMDhaXnC10bB/qA0GYYlzoR2tH8P4soOjt4zNmISUSOwLJuljf+bFwBVrJYxcANTFRHqO/rraijz6m+fmKqZLpq1AxtnL05Yg+hEfF5zq+fY57V7MB9Pmj17ioje00rxKiD23m3MWXg/VQP3xwbQ9+N4gE88bO8c42WvTZij1QbVkblb/hmqDJ3FTqjG2I149PhgdXhfgxhNSXH3cav2Osuo8xIj8+Z9TeyTeHswmySGjGqwmyCTVqzcvlbvApZVPqfhCPR3jlhLPmgNyJ1KycOIfx648Ls+O/HqUndRguf3w6csymP1bzGBEsI4Y5ZI8jPK6CQWkd0/GdL5Z0MUgw3Nkoj9GfD+nxQY69dJbMefFzJYVoKeLPVvRRr4N1og99cgg/YT7CBJUwX9iVYH7NKwxnz//x48fzXalYnCKt5oPSRoYpwpUyUv4G6wpHJn91x+h60JGJHymYtBzZ40jr18xtCsEnPlPpxR7smudFIpc/OQHBP3HAY5SJzxwbjmJyBa87Bk/Lnf2R0UJdV8ERzJz4efb78tvIHxuGyR+bCTlmG495aCm3sTjHOx5PGF8cLNO2OLYQL/niSRtHSOzzPuUx+vOxk0SfcT783MhUgd2K5F4nKbDmEX3UUe/j07fQlT5KiEn5ele3N1AnVqQUSVQOw33wBZVwX/6Ks+/t0zLpN2BosXErfbZiD78Oyt9YjY+x/EAMPeqMbQxUagVCLGFpuconZCCTIlGxZ+1Qjj9Z0QPhY1KRQaUkFb/UQzSGx//gitnBKJvG5vdusQuJNX7rUrHlyVm+eDrWZa9DjGt/jHpFYDax2rSNAcoHD1mIT+7KjhyI5nGk4TxfLGnwh+Xb1qs8Rn8+pMY8WeZkrZnz4OdGFgVurcYVQCbhxyYGhb3epUSfz4+EAI7oQwxT++mJXFIbOet2cuYoXJDBBZVwH4y6Xjcd+8Ix6p4WLfrUMlnGU1dXy/I3VhcfMjeWmmOspX7TcGRZeyCTVvhCck9YIsFAE28Yqvgkc2liT95JNp57yetDSvSRGjtiY5Oa+NQSz1bsGa6LnGKPGquwesSvXc7o62uLYfNZmX6fP5Y0cXDjdrcvj9GfF6mxT5Y5WWtLjTGnsIAwTiKP/qGj2l0fau8+uWveu9sHaFjtU4PoYz7pa7NW/OQUfUbiTeBO0hsk+vgHaeTi3Altyt9QjdNRUerrjHE9pXCWar46TsORG38an/PSWaLYw5v4YJcLxndYzWG2EZw5V1TwYpWKUUrsUaeGWyRVhOy2TWxcUpMBKbFHIiZp0ZF3PeN1GZs7c5GM/es+cGRw+c0a8mLKgWiAyMPG4WBT4uDEvBV75NiStzSv9bw1Kh1RbeIPGl8I7mHz57AVIAqbpIhhO96dXk2S9GPjNc4HxmOg9oKWwqidjij01cbFij7D4LTsQSko8xGd0j3AhIKSz199MdYl9shMkEz5Li/4THM/mcqEFuk6gaO/4mz1ve2TrVgH+HXAuwZxu7YI5v7ibcpeY1J4SEhw1ySY5QllBgZBQ/GCjykm2LnW0M8xVpd+Owi6eZ6QXr42GDYsTuULs+lDNv1+vsKn98c1FdAej4nHVQCUWRccG8fbpsTBidnfNg3Xfr9DC39epARvDqrUbc28+7lIjUvKfugEWcp/iJ2lCz92wUexsWHCD6YRhZRC38e+xw/ufDGiz6YPSlGV4Ohc/iZqAyd3Q6k3Ru1RYqNX9/inBzlyZJ9cC9Ta2kS8JcsajXjDgZMV3LFMDtOIXHWtGBlfD9GrJryCD/nz5zE+f52PeDuIjRzx6OOz3x/nHo1xFOYTs81C2zcWESg5rln1FMYXE07gOMrxkj8O+ZrhxIu3LYvTn5edIfj4ecAzWk/LJQo/xB5X/Jm+5hWSgbgVMurErvHG0nMcG/aaV5usELbxPuZj3PX+fgDVij6SD/E4pZvXsuxN1MSn3A2lvtjm8c4xysWPVGs6juxxpPNpjjip2LN2KReT3MTZlv8UY2et8dcZqznH7Ct/A8UeVbOxeVtmPfbRI0N3BvGBXAjVakBE/Byyr6AAVOMufIwul0vHH02n14As31536u7ubbjZYk/+uvQSnrDBEsUfrvAjpT7Eij9IGvmxIVbHbcLj8IsoytOoJd6NFYzLLFrX1Yk+sQ+DLAY3sHGZmyZCpNyNpdYYMVxyPECsi7vbWWKPew8VJAPjiR5WIxy7Q9uUY2c8blmxC8PDK37Mpn9SJ7ZaYg3fsjbMXyTO/v7ufeXGE9Oaws3484bbcscpPZlLcQ1KxWpiwha/PwN4/Uxb8uNJicYcBx8jwsemxIHEGtYmDe8+LP68SI8TPkQ5vt/EmDi85RAbOHhcbflYZVSHcLGEE3nNK37CeEzF20aJPubB3j8Yc0prk9uWuVkijMrlsN4YOx5qqmF5rvx5lPfpfiCfI/JjRCqWN0H1WRxjSsGR9ERTFqOs2DMIES7eeXUgFW+ezZp7BnyFxxBZ8ggjfp7xvPlteelZj9m4T2fFQWagRr0bqRgto6j1nsVDifGst8LjSo3Ejh3HyIk/Xzxp8HNi5bUth9efk00TRwau/bHzsris1ujKiJqiyi3+pBIvxpzmE33Ib1hMPPEn9ebObvHHjbXYSh/piUpNF2ZOLOVulrYo5W4k9cXGfUiU48JXU+m5sqw3yBfiaBIrLvgIrYoY8mRAKMyVP+d8h36bvkocixJy9jRmnWHxYpbBNxe2eCgmnDad3f0x6xKxSU14/FjyxURsd3gwn0jF++Pj+8NsIuimbYa4dR9ybHDvk6b2OdCYccrznj8W+RhC6gzrUw6rPy9S4x/GRNpWY579sadFU4/1pYk/POGHJ1ZMsxImkITllhdXmA/Vix8Xn8e2B78bKzDzHj+ViT5bsYeVU2vjcjdKF365G0md8c1jN+OU48FXLXl4Si9gOKvKQKc2bfFR5P/eO8n2mxi3GANOkSPMJl6HmD2EB/OEEunpa5Pi3hEf91jwwRm3ROusRdx6bFxSkx0chz823Ja3ksRWQZEnHJc/RoUct+mL1fS9cM2CEHgx4VyB7r3NePi85rQGmxQLJ26sbTreff79eZEaB31IUn8/cOyPOTWWGu0vSfjhiSNxqgNfHAnPLi+ucD+qJz82PpclhJ8uLjvWbCt9Ujywx6d9ORbK3Rg5HMndUGqNt6Y6TseRPY/pfM7rzORLVOxpZ2yiv+8fBZGSK6k6lMU4nkxyRg5XW6lYdR/xcQtPnNeFbb7y8HFVIq54Gx3TmB1/bJgdpNrk6xPD5o9RocfsIbGa2szjx5GF+hz6YbHlRMTFFsLBpsUTwoG7D1YX8n6RO//SRZ+t2MOrmyWIPzxxhC9U6IzxhREe32NfcVi5nsNi42FM/ZqXTd5x1XEy0SfFgzo3qZvQvtwNEWFP5oGm7hiRCYwMDwjjshPXqcedJfb0Ey0u8bP2Y95S1rP0uCqJVfoBWTpWXIhwFYRZOAgeASoSe6SFB6n8xdeovNjD4wqvjvhY7WKPCTOOLHyQ5MWUA9E8Fh5GhIsycfDqEokjXRt5zrlY/TmSvqdxEYa234o9ocx1/WoWf3iij+KBJ1ZM2QsTSHg5CIuL50NvHRZTGI9hvnixuY9zH74VF32wgdw/2PLC3bzWGI+l4pbJX90xdtxKTVxiM5WWK38+0/qfcz1H5MeIcCwbR3qxB8PL5wazizDaXiXAtYLa8l1z/bQGN+i9jhFTW7EHYUlyzIyvUdm61OPHsJW+LsfXigkzHyFaBUO7VFzxkcx7YNg4nnIwascjHw8ndl7b8lhdv+Qqm0cek6a6Xjb+2Phj+9cs+qjYeCJJmFgx+IplFOm/hA2de0aQgPo2Gyn61DI5ZmWiwsblb4QuUmRuJHXH2MVvxigTP7fs0vFVx8qeKd8TKYVL17i9Zkwue8sVe+y1HUJzmkm1v97xTPptIXGfNI4HOArNB1SPfssycbXVAL6G5efJj8kfl2R9pvgtvT/GjtOQD2abY9l+fYYh5PhGxVtlMweiya1B1KWoMR7R+vBSBwwvfvla97qcNHATlWLs4CKMab90/DGxS/blCSuSnv22wrAtQ/zJIZIQw3F+cC5zvOalKmaKahzjrpXISp+t4OO/QJEW5W+ELpQyTxN1x9jFX4vgk5arOgSfaYyigs96/iVTuebJXIocYTb5UWF2oZGqbyRn03XthU0MpbCJHcWulZBnyuFNQqrYvI4tDTA8WM1itvxIJSc+OCYsRh09btsf87jFXNDjo+P65Io95nGV75XfQ5b3HMy6Y5SNh88n2qM8zk0XfMpdU2gNLKWdb1Pc0nFshZ/4DGQVfnCdKDgw92tejdB1/Phx9t1qK/IE52PUsfzND4mDXR5Go0uItZa6TstVnWLP+DFFpuZ2+ibNvVQiROdalmn/kq7RFNdePMbxSoloGtcGYgUfybqWEkYwrv0MYnaw+5aULcyOP7YpaswuEuu8jSmvfIR837yYciAyccOPy9+jTCxpxnh/tDEteDUS48nW1/UMVDaPMdEOvC43hpj4U/Wt/VUvvvATpzzEiSRolvK96hUfD85nidO8iHE9Rpbogw3W2wHHV9YYjz4rqb6XyV/dMY65M2OV4YGTpTSc+eNI49ccucnXgNCPFeJTMyNkkWSOJGKHHo+08CGb1zTxS8csI5IwrIkAACAASURBVEilEXtabNYCBipVsK43V+wZWJaqf8wOkL917jF70EhnaGS/TnGEob5RMTgHEnsMafjfxJjC68DUMw3vHIz+HEmNixxUsW3HvPpjjPW3U/vXKv7wRR+VQVysMOU8XizxV1J4bH7b0xbh8eA8jlri3djB2ExTjFbRBx+gt4MMmhGcU9SiVDu5HNYb45yrzRZ7VLyu32pJ1Y/fjuLajEao/tZm4q3NLaSsa2nhQxbrzhV7/FeQp+4NhWioLODiGZrE1rbUpAarMRwtZs9FlSYd42793DctMGx+p5gdCJJV7OlrVlAgRBBhsfk5QnyFtsEwcq2XjcmUb24Eudqn4Z+D3vUsVEceWdH0kJeHnRNnbW1zChGc2Pm44lSHcJGEFVXbOIevcB9hPIb7w/kzvuqlXu/CBuTt4ILTjT4sciymaCuTU6x+UuDHbUpPrnHP45Z5uKpL7OkfTkdURNaemMijgxpjSpkr6XqUxZqGBwwjVheYLeQqtQtbGJKJDymxR7tognBosKTEHmySiaOVzKGcrS5KzF6JWE01PRe9cGTINeJuI81VPKLBAoYtxGNOhs340sUWwodEjcj79W2sLj02pojAeMW35Ve+BnPFW4ufWlf8ED884SdMrJjmIYt4kcPJOjC+qzAei73qRaIPduPYDi7ooIPxiVpL1U4mn0uIVXpyHZORPHyZc5vHt/1heyIjxNDYP+vIVPH84SklV37b/Kj8NlG6577lbCMTaSx2OUxmwQdDYeB00tFyJaLJAIUHlzm507mUF6nxVCqH4AMMzHk7GkAFADXq/WI2WTDXjec1zEMW4tM+ztut5UQVgo/DQ5lYdITp6onDA962DF53nlKMHTgj4S07LsvXYHgEy+65GcJPmFgxzRxfJAnJfXPqlAxcyDnfVxi4EsLPrmPHfBs5bwcWqErgB0XUmnQ7mTyWuXGHc2HHK8MHF1ka/uyxpPFnjtrmS1TsUdMc0fRNEIraHnOF5QMHgNlDqjSt2OOfSOMx+20h8XZtxE7mMsCPEXxk8moWtHB2OLWL508mNiXM4H6RuDFsYT4x2whK1WbAMbUdhpDjW10/nD65UA2Y5DlvRw1O0MnapoktGVxQSJX273o2qiOP3IiHvC8TPzfemtvXeroXtuInTKiY5oMvkIRmtPbNncP4zMWfQucQfbYDClqadd98ZfJYd4zzTNUi9qTlzZ/btP7Nk8KYya73mlsb90futaQ1kJ0cmzxLrY7op3tiBNgnjhwGXW0lY5er53HOo+nUDLht+T1JxSj1W2wMT764TGJdbK1Kxci/9kOQ+wVafzZC/JrHe7+lHGhCsfnRaxISp3GytlitJnMfZDg/Zn/NSY2PQYREdFoq7oiQq+6KCSx5Q+BhChMrVES5RIvOX80rfsJ47HuFdWcVFrnQRB//IMmyvsGN89/AQsiUyecyYtUey2Zhy/DAzUBa3vwxpfVvfsBOKfbIxeOfMHFz7WqfSnyU5EPOVscEZs9fwzqvmE0kcyXEntyxyoqYGPf+GDE7SA7nK7SwXvZWGDZ/jGlqdorbLtTyEIaxhnHVjgRhDgR64RgRZ+XiMKGTjQ2JP7xNOaz+nC1VPFkq7vAqqrsnT2DJEwsPU5zasBV9pjkN4zMHj2vR55h/dMxTp9V7KXcD41Ajk84lxIphlOEDzQCGCbVmf9jPM7kw47TFOGY6kvd190grWgC1iD1xkyHZ+pLd7wXDxssoZhO5nsxCCA+NvZzsdnAP8bGWEHuweo6PTXFfIkY8h3nG5fl1G4YQuW6GNrwc5kA0x8/DiMZfJhYbujQxolzw2pXD6s/Z0sSTgUt/bLwsbVvHMZDvtSMUJ0/0UVbDxIq+d1x3MLSaV/rEiT85RB9C2Kz02Yo+y765ytwAyt2cwWt90izVCoowNOjqhmDr1o458zb1Za48gXpsTAhYsc7QU3Lmt82LzG8vpKZkJ879dBwKDWoErhZCYrfHiiEx+Jh0jL0OZHJcr4AnFV8rLwUnzVwrmD2eU8wmUrumNlvBx8VcGu55+Q/NLNovTYyod7xdWZz+nC1F9NmKPXjNlW2ZV5DwxcoXfuJUmzyiRV6O42PCOc31mtdW9DE90/vvF77rLcP3ciDL3px5VLmxynGCokrLnWP9QOZQswk+4hO7gaiUucJt44nDbcLV2jeUto3Zw2LHbCExmwUfDIVf7GlFiFkznnWpWKUmMBgePEbMni+X9YuUPOHTF6/t+zEPeBZC/XX9eDnMhWoeEw8nykm5eEwI08SIcoG3K4vTnzOp8RJnJKzlVvAJ461UL77QkhYpDw8uUNhQx4skfj54Mfnt+VrExcTjNIfwsxV9Jhkve7PylV//aIk2dLZbRqzIg6f/Ji9CWLZaqUfsmU5mYlc1uAtynWuxZKUXfPBrCK9R3KaPKIMkgcPwGQcmhGHOpOKv9WQu/kTangqpyQvGOS+fmE1/mUnFOB3LAM/+JusWUrGaHZYRe3h88WoDJhZsKM9/2XhMYcvHCJIb0KwcVn/epMeTAHrgLlvRB6aqqoa5hQlb8HwcPJHC7jd9OvixhWOKE37IL4/XeH/2WLeiT8NNuRsUtwj9NzTE4hLixTDK8FEPZ/WIPfaVPYKcr03JWUwvcmATobiIsNqHqrZvJGezM+m2Fxa/HEbhSbIWjjsyf9xSMUpPXCTzucwY9evJn8fp1ScV89juGIfywUeHjBX2NlhsuVEh41BI3GXicCHF+A+JVb5Peaz+/EmPnfIs6vdXfzwp/G9txjJQ1z4/fIGEJ1JM2UopWihf/JjCcxofD4/PlCt+dqToU/7GhBSfzGC/jFjnfJhxy3CCsF/iod6EK3f+tmKPuzokJ8fpaizdCqcU8cvVeL1iDyYW4iOT1MQF4x4bdzFbSIzjPCI9kDYYPixW6XwiYk/vEwlWoE0KvgRg9SYwfFyPvPxzrXPbp4mRiwJvXw6vP29SYybOBr/ldmUPn7Oae+QUJlw88HHwRAqb73ixxJ9dfmx+m/LxhPGZQvzZEaJPuRtReHFJbWW7lNhTTCaj2Pc/Q0SY9xvPnTe72CM81WhC90ePUptvZQ8h8uckLDK/XZSPFmXbWNYmao8XvxxGc8w8NBOOodU9uAepWKUnLn5cWIx+O3gNS8eIXw9YrHokknF3dt2CLR8hzns/0rOcsBrzwVh6yPM+5l4MaIShNDFGAHJ0LYsVq8EU44o0m1vRR5rR0vaWvOInTKjQGd+KPoqNcC7bnuHdZxfAxos+ZW9GoQMOdhPzWV9C7LWJPfgEwce+7Xt/bnPmzeTLIKWEBjvqJxvXGKWs7XG4mG1/Xk0kYrYR+tOIPfj1gMcvF/MwUfOLlgiHozl33yHmepCMVXrSIjX2SsZIooekPcwWXrt6FWG2wbqbVJtYPTPc8+MJ440BydiUj9PnsUwcLlTyMfo4CP++PFZ//qTHznC23D07Lv3xpPK/tZuCga3wk4JV3eYmr/ahOCWFn40VfcrfiDhlLjPILytm1+oBGT44GcAnt1yrqr0/ppz5033FTGqdbECrJbh8Llvskc/xcsQe2WtMeHWP4fKMvS6kci09YfHj8o9V/aiGN/Vc6PJ17I8zbIKF2eWOa117U67FKHZA4sWUA5EdLA+rLw9lY7Ghk43Rx0Hc9+Wx2nMoPXbGMeXvvTS8/oi2LToG8h417mKdJ5DILDHJseInN8fhMfE5lXzNa+NEn/I3IGSQk3nQWEascz7suGV4QTKgt0nLo+uBhIs0vr0p1gGhEP8bLfbEcSRXa1rW4iDNigrDGOYUs+2qc7s4EIRoK/YYyPYzGZ/HXjZaix3xY9vUAobRH2uPFG8aEIxwXTMRSHPFdA81xzBCprRGSZPKBSO6yo3tPLBDmrwgYPy5W5qIsjS8SJa2beoSfVQ+MPGHL1CY8h0ukHCqZ8Caw1+8Dz638T4baezYsWP+kZPDe8a25W42oUHKUr2E+N0YZflAs5KWN39Maf2PWXD52oo9OFexS67lci6/IoI3qfXXN88efNUaxQEcjcUPJFBiXqRyLP3gj+Pyx4nbwvIqHSt5xTD6Y01Tx1Nexjh07DhCjGtTK2muwpH4e2JY/XYmoz63Q9L2aWJMChm83lJgcP1CLcfVIxPTOOfLwS0T/U6xkleQQFjdPNFHRZ13VVW4ELMVfZA67dss6+YoM5AvKeadJ/a00w1nDZfIn3sSIVOXethCFmdcpuQOsx0WGWYbGfrsk0Okt6sNhpEXP2YTQZ5wBcQ6JM9Vi4AUnfhICSF4DrDc4vb8lEnFqHvi4cNixkUkf8zmFpr0DtVjqB+Ld4gGqJEsMM0aL68ojLIx2VCmiRXlJKxdfsz+3KUYX8LYcfeac+ePLQWOrc3UDMwn+OFigQxWTPQZhJQYr7lj5cUWE1mzcoav3WgOeZ0lXvNa3Eqf/DeYmIKQG8CXFHdtgk8e7ly/dYqpofC+Km4zMqHaFJ+ozHGlzB9mm88VZhfN7XIEH7m455Ph0QQfpc7UTqPTcdXCHuRibiUGMQEJw4XVNmYLpUwuRuWRhw+LOcw2ykGX6/b/oXrk2PW3TcmX3zvegocTscvLPWJRso18vJLo5rbK4PXncAmiz1bwSVub9VkfT/DjxAKZ6HBxhCdOmNDljBePK55Hmbh4/MZs7Fy96FPmphJaCP6bEWp5WXF3UdUm9vgxodkwtfPnOncOp/6WJfYMk6D0ky1frfYIggpELu/2VS5BwAydJK/ZnHH7rz5TsIZJy+xHPMs5Y+bkHMfljxe35UOYrp4xjP5YjSN9WDcHGXYexF2xr/lphxyIcokJZWLxXRU57ncoBk477JrjWETb+vO4LNHHHw/KzLbdEhio61UvXCDhCRO2TMiIJO484zHF14tcPDx+Q/1WK/qUu6GEFIHcoL2suDuuJCeOIezneVDvH82sEEvlzi32yNWmP9eh2Uu3kmU2hXHSEceVXP7TTY6xCUYYD1Lxux7Yg5AZOs1/xLMsFatptUfoVYTl1j+O8a4ZHG2KiRiWB15ueTzi8btyHYaQ43tom5KzMERcbFwvOdnlYkOeocJspu6F1VEKFP58phhrpCLZrvCRYnKpdupa8cMXSHjixDRLoWIFL9sdxjy+OmTxvni8hr7qVY3oU+4Gwiul9S06pJOzz5Lir03kycMd8qAhXhasmkm5sicNx1uxZ5zgdGIPlj9/jZsKErONXBvCKyC0cOyR8WLOESvCVHge8Hh3Uqw6n3JxT7MkXN/MQsHiwuuD6R5qjmGETGmNysZkQ5smVi43/PblcfvzuQzRxx8HPzvbHsthYKniD0+csOUjXiTxZ5ovaPltposnjFeu+FNE9Cl/0whNrMwgvdT4/bhl+EGz48eDWnK1c0wX84bbg8y5skdt0iwbai1ij6I0LDq5+kvHB4axjvgV1jA0hmu4MbQVe/g1jtUMMrYO7MvZ7Pxi9niVhNlE4jaLPSbcPIQhvtNwFYbE30s2BznY9ce0FX3COTL3dD2T1Zvz7Qof6TpYur0lb+5sFyguv+T8UWI++vHrjYmaij6XXTzu97FPmPuh7cjptO21n7xBvGguvei8kc2Pf2rs45ILx9+rxtN2g5FA8Qfslk30kb2Zi+fNY1DuRrJEHmpb2YM/9IfUCZbrEnk0+dSmVSHBzvusDWIscF3af9PNteRrn6Jm5XOeblKMXyN4plPF7xYxfZm2fF+l4NNmBRQs/HFj+SiV3zTXOhZzxzP6wW2iFqft5lzg6EJ9omKPsp8DkTsW2TyUj8cVrWys4TXC7Vketzuvta7w2Qo+3ErbKe3rWu1DrOOrY+YqgxJ8lNAz/fc0q0r4UeKMLvTQz6bCD/oz8jO0TXeEuxJ8dDGJfkb/VrGR6GMXeEx1Dqo3k67oip/kok/5m0Ts4CHz8LBUHuy4ZXjhZictj/6Y0vq3s2GfGPsxwxwnE3zSihuzKZaTkjC+5POeZlKsc4FhxvjAbMGV1k/KxQUfLZx5ZFisvHrixSzFI2YHjxezh8YqJ2zx65l6lIrbxM987MPRoXzP2/HymQMRfm8Lj3pULTJmEljh5SYBgECT5XEvU/BpR6QR9LLXW2D6t92SMVDXxs4UJib8mEWf6coeEn5sq306X7pAM5A8FXhMgg+1xoSgNMKPEnj00tB/RrHxRZ+WlaBqQ071Ehd9yt8YgrjSOskMyEvkIcXqiOhsyKTDA8PvJHc+bf7GSP24If7FxR47rpQ8pqxfOdylxR5+zcjF3j7+tiW508QeU8zQtWlphOXEn2vMDo40xW/aeRj9MevR8GzjPOjCk/LBQ8bxNW+Lx5UT1RgnjpHDRbl4UJRp4ka9h7Urj9n1TLG0nNePN6xKtr3CGFiq6KOiHfCbBB6f6EPfu17lUt/ZRB9C4ReI5Dk2CT6KEX21T5joM+cWrS2f8CMm+pS/KaCU2NrJDMRL5AHDLMMPmiUME2otPOd5cNgf2qVWK7iYkovRgDZD2WzFni670jzI1UWLzogxujw0A1LXilTc5QQQnNWaY1VjFoYRj1kfCzHbnPvMgENc2GTAwOMK440BZdYUx8bxkj8ODjr/+My1lqd9mlxxsPvzmmKc5SBE2o559MeE2Ny22TQG5IWJWIa4K35CRR9aCWTa2FkXc1DRx9WOVtBM/eh78nD2/EFEH+Kf2vFe7zJlDV/5M2pp6BYk+pS/EcSWsvygu0ROpCeJsVnJ92BUZiWKjR9THqQmsEaf4it7+ulZ7y7H9YD5CLvWMdtIxY/9y9n1iTzznCBo5a/BEmIPM3bh6yHFJASrG7zWMXtoxVAt4r5Rq5jJML+YbRRpe9VYx74whBzf47ZYbLlRDRgxfNz4y8WDIk0TN+o9rF15zK5ntaXlvH68YVWy7SXHQF17/HBFH+JBF358q3z09tKij2vDZxXXVLhxCTnTHHNEn2lfvghUUPQpfxMIubzkB9sl8oBhlucKyRiGDbFkauOPKa1/O277b4P9mLlsyMdokKbkYc/ClBYr5XkZJoFpbC9B8DGLPePpMbeCR3Nrz84tYCE2zcCWXrBLED5S1KN03DhGfuZw2950TxokqncGDCw2PmcMCN6mGEavGa1B2XhYSJcDtQ9LPl8sxpyNpccdDjK07cDfApOPBinQTq+zHEd5C0BOZGIzRB+dHNd+PtROCUM+0Yfa2vbvoe/018D0fyssplfATCt7UOEHFX3I/zS28Fe+AsSfSRd4pU/ZwT/m+pIdbJfKA4Zblis0axg21Nq0nTumtL7tmO1ij+ojl4s0MY7xpfEx5k9a7OmZlqO6MWn/jX9oBZv6YXzjgWH2kAjc8eOIDL60zo7f/yIguzaigs/aIO7d2RLLB49NzCYeQKpJF4aTF3ubHX4XkAx7zSdzqSHD4sqBxE0XhhOkXF3AnOYF28rHnieYcrh9z23l69mXgTF39eP1xZPie1d97Uzxp65j3LGVPlQZHe6Ur3ep+jOt4Al9Dcwn+kyPYycMqg9H9GkZmqQ2TPjBRR/F1/RUr5noU26Qlx5SZAfZpfKC4ZblypVJDI9kLTimh/nC7gMyxT+HIQRMcFI7ZMSAVgjuNOt4rYQDwH0gNdnhkLU59istfMlidccfnCVDx+hrZm0gGNOkHCQFECwnOHLMHlLf2iiQwih87eCxp74ek+1VBaQDTwGPL8B1UBMcr898HfH4UKavPQRBXBu5nHFxuJ7b6s//nLf6MXMzxGkvWUebLQaZJ/WlYsZFHxJ87mI9pcv1mpf+3TRO9/48QwWGij62Gkb29uGKPlPhJ0z0aa1wLr22rS789KKP5EXJRhTdQX5AXTYfvomnPF++FObhsy6BR+dExW9GKJwPzZyc5a3YY6/xnS72dMxMhY/o2tthYo+qL2ys9LOL2fGN3NPv09Q6htUfs2nM5UbIaz/mg4eQ54lXHyMmwhwJ9cJyy3GWg2UOnnlb+Zjj8HB7l8Pvz62kwM7lxdfezps/Lp/t2r8vVzMDM6XEEfncLO81LwnRR/Go8oiIPv6Tu4bszMWhG4wbSCP5LCf69CwhMEdtiNddR48eW+BoJA+5hgGLnUGtA4ZfnjcfZgyXz4rte388af3bcdv8jhH78UPMrM0IWZu4TDPJc8UlvZqFfKWpg0k2EyRA+iFSjge7CBhNA1TPPC/SccvZG64EzCYeN2YPGWEGn3I2O7+YPTxmPRrMNhK/qU1+sUehwOMK4y2UkWk/HCfqsWw8KEq8rjkW87aVzx2K35/jZYk+/nhQZmptV65W7IwsX/yxr+YoERuy4qcTfT7fJGWO3beh8/R7ihERfKgCbPv8mI6BN60IQmKzVZpJ+EH2BKL4wlf6KDRhK34WIvqkGzhrHLA4gzuGPx1/6R/0nPKA9UuMFw7TWNupXzPzQvnQzAhZ1IJML2jkmMSkqYP0QpgfNy/jfntYfXetzPHzENn9SYp+cnGnyzmGEWcXs8fLt7RNnj08dj0qng+Uj7S1j6DA4wrjDcHga4Nj9FkaZZTTuFjbNLHnCac8dn/N1ij6SP9yJk+247yUrxU//hICiR8V2qKuV70ItU8gMQk/U0EH3feH2pmEG509mzCECkFduxtak1QriGCj+0dEH1eb+PoMEH7qX+njvwmgl1D6B8IQJGF9sAE3DXc2xBimsHjnveyx5cXRITP5zCH4pMlwbYJPeJSytZBu4q/qG8PL4wOziVyX7vh5qCz+GiOOKxsB2bfJFTcLlNYYw8djFbPJQXwSXI2D2+Rh5MXPu45wzLUcyY5zF8Ybh5G8zwHl4kE5wXODWszfrnwM7jxvBZ/8NbH0eVP8xJrP+cnL7s/vVLjH7mvfCyFAhB/d0PT0LtuqH/r5tJ9pjx+9jUsUch3ZrtuYtkP289H7Tzd7nvZ3bQZNdmTqExd/Kl7pI3uTL38zg64nayMMvyxnXMQYRq7V/jHe2zGtf7v7qd/liT0WxAnLCctVHADMh7esmgYDDjmbY7+4XZwT3CbGgcsejmria9JR8tqRil96ooHjwlnFbSK5Ho+5UrZ5dvDY009K7CJ4GEpODoa2GH85Ec3jwDBy4i8bD4pUPm7Us1y7OmJwSP51AJwRboa1jLpFq6dS6lH4bTuZyTXmsnbRBxV4TNH6RJ9xH1yMMPvC+JZqxYtNxqtcXWJcVyL6pBsglz5YYfjT8ecqawxb7IXhegiItc3vj098hXOyNidsdU1AZzVHPjEfYVFitjk5Ty/2uHmvhYf5Js1jWYDD6ajkRh3n0ZaOX/66wGoUjxuzx82PfNy88QWPv69DfhcGKXY+krpVlwrkBGrEiJnXVL4Oy8bDiz7PvZOLidNePn8c73rbregTylyKfvXUhXx0cpPtObZNFn1UtDyBBBMkbFlOmSuTT15sMrUZHyPGcSHRJ90NfVMGKSyOdDyayhjDJHMBOF/yyBu2VxDRpAGp4Pvw04Q6tpojr5iPsGgx25zUpBN7MKyleTDIL5MfhSEkZXGcB7MdhnWtKaOXpxjSiB648OGPBKsjTs236LxjHdciHjM28Zv6T8OD8rIEsWeMNSQ/En3k8uCvfQm80jbk4pdGhtkrj9+fd+kVlxgz/lZj7vxx+C3W06J8XaTjIn6Sbcd28l51v961+8PYq1wu9nnCCCZI+LKdMmdj3x3efP4kfbm5ziT6pBsIN2VQwuJIx6PvYsPw+ay4vvfHlh7DHJ/JZ/RE1UdT48DPhs+I6fvaxJ64KOXrIZ3Y00/NoJChRn2C5Xiwx89D5KhNSKQBvEF2uNdIGtGDUGA5AuJeh4TZQ+NPFzcee9sSBQzyCZubNLSPkzjCUN9orfQjSrgjgZ6ydcirAQH40Sbk44+GxDJQD377lbUMsaeO65GVfNdtOsdAJwU20k6Kif3J+1cu+rw3XvRRtGPij4zoQz5T5MtcQrsy+pKMq6jok27kqOdmFTfiYHGk4xFBj2FELJna+GNL69+Oe+o3qdizNu5nI4TnfGIPlqu4KDEfXJ7STnz9k18+J7I8uOPnozPw76xxpoemObOH6xG3/06WU3QCz4tEFqP8Rs060RhWXvz+a4l77Y8Qjzor/HyEYRgwvspPMHk4OVzkYpqDydw2HQfx2BALdeB357tWwcc+Bi2nfo1P48uGj5S9tY2kmHDyQZWLPu/aij5IsWCCFmIJbyNXh5bT32RP70o/YtRxo8ITGD6wpufSFkUejn03+ziOY3q7V/cI50UzJ2y5oWBuMWVuMdtxUWI+ONlfntgjO+n1xx+XsaEMpURT2Rrwx8+ppn46DpMGN0yyuiXVpArPER4/n9ugzLWddPx8hCF+uz4YbzkRzWPBMIZyUDY2Duq0PHCQhLUtj9+f61TjUxhjQy8zd/54Yv2m7F++HlJGh9mWmnCf/PLKRZ935BZ9iH+Z1T5SOUIqooTo0zIlQ5WR88jXu9IPcps4EGExpec2z0P09NLC4sI4Qi5bfxuXrwEthtvvbd0ik9hTC4/a4xJMkd5QPg4ts8Kpxa6rMKfSPLgeqsMQallbG5ASe/BJMV5iKSYVWI5wdjF7eMxdy+WIXdj1xI3ffF9yC/6xPvz9sVzjteP3yG+BYeTaLRsTB22a+DkIZNqWj8Oe8xTjsgxrJmF2ObVr4qB8HUhlRs5O7KT75FdWLvq8tYToo/ITp2jE5oZTJaVEn56pOKoaM3MDTNEn/eC2aQMQFk96XssP9q4bPOcylGs7zY3k5NSGEqsHboxluMViiattzAeHrzSTXVyQCOMjJw9hCHsdoU+G5PUkF/9y8i8Xs359pIkfx8qvLtw2ZxzopaT2P7Zij5+7NHng14MfaZoWaeJPg9VltXwc/pxvRZ/0dVG+DtLHGOshVGA4+dDKRZ//KSf6DAIFqlCg7dzZC81NSE2UEn/kYhw4B0Uf/yAdQiQ+UQq1nr8fNpCm4xOJGMOIWHI+Wli/zOPfjm2TxZ4c3GI+4moc84HU6BiHnN25b8w2jxfMJp8HfezlIXL4YB6XmQAAIABJREFUcq7sGU+yEcSy94c0YkcfFUyiv6FcznWWa4jfH/sIMa85WlKTdnNesrhdo8BynRNR6LjGpb9sTBy0WI44Fsu2LR+P65dU9daFnbd6MTuf0JcJO+vFEzrpPvnwykWft5QUfSiF8cJPaG7CCij/aV46TrlYm82px3v65BsFyt94wlJv64XFk4/f/A/P+KQO40ouPy5/Q0aEc6OZE7bcEDO3mINTzEdctJgPvDZy/cZQ+oFQjgetwg2picuWmrl2f7tt8TxJxy9nL3RSjMcvizWt2IMLc3j8fCENHw+Glubrgo8yxPcy9u5Jk4dcDIflxdRL9nqUw8W1VE8cyxN93Nwtq6brqQNuBZdrz510n3zEA8qBBTzvfvN7gFZhTfBVMUsTfmivnXjMYax2vSTcr0WffIPWJg44WEz5ON4KPtqjvYX2ZGKPNvtNk/GxVaz2YoYZdILin/a7UKSJI+3JRP4JL78CZHnwT/j5CCdZXBsQE3waQ9GYeoj++GOuDDxXeES4TQT58uJPIzRMubILoXimEP7NbfAc50DjjgPHivBRPh4E5axalgl7FqpsLkOY9D8j5PolDRf9pog+ddQAl/062nMm3Ce/rnLR503pRJ9OnEDFEbSduwZgdwKlhMcm4GxiQiLORvQ5mvSWtomDDBZTUlq91YRh9JoBG7h+cwOaSNRM8WBGKJujtJxvltiTg6sUPjCbYXWF2cYvlEVt0qxRFsbenJeUEwjpSYB07jtBUorJMbe42TD/uH38WuhazvG47w9c+5ICShh3UojT5KBsTCHcpOEhBElcnzri8Oc/1ZgVyp70OB+KI7ZfHfmPjaJsf86E++SjKhd93lCL6NNKRCKJ5eRHwmEJ8UciRnHRZ5MHFyw2/41NouB0GxguSa91ijwmHnKIPWouIZt5C3JZJ8aiwOuJDwa3zanX9IIYhpvPRzc558TqauvnIdrV2oDYdZVA7JE+mQrPD59d3DanRjoc0rZxe3we0t7Pyoo9KjaMvzjuOFViaothDPVSNjYO6rQ8cJDEta0rDn/+t6JPXL6nvevKv2xspawhE++T31i56PO6tKKPyg0mjCxT9FFiFVIPUrUq4Sta9NnUQQWLy38Tk0p2/gc0o0drOBhfsmy4fA6ZSZAj58RXKsY0E7fwOpLhUbZOauEojBs5LuxiTxgyQ5VANY97k4t9JBcsRuzYzPh7eSNoEJTnJIMIyogUiw+/hhiuvU0xbF4zlgZlYgpBm5aHEERhfeqMw14HtYk9/UhmhFx/PdeZ/7BarrWXawJ+8qrKRZ/X1iT69BKRSKolhBEOEEzY4lj0t42JkSX6bPJAgsVWz2CP4fUXD9bCdbPGLKRoha3skctZWs79E5QUHJJNLK4wHjHb3MjSiz0Y7tKcuHkIQzfJRdViz/LqAKuruq4HHHNYxeH2w3gxjXFhSLn+u/Z4fDlRjWPBMXI4KBcPByUvR1zLZdqnyWdsLOZ6qFXwsddF/XVdZ/5j66fO/qYJ+MlrKhd9XpVH9OnlHEilkFnxQz4hd0LlVEL0GXjlBwGLPps8iGCx1THQY1j5hWDuUafYY7sZz9EK5awxI2TJQLMBdTpnM/9YPYUBwmxzanXAIW+bM0GrgY/Ego8WojtaBhei11HaTbqx+mLEvi5zzC56TdQierUjMgq6byfLhcm9uUb4SNmhMWPMiWgeS5o8lI2Jk7E08XMQyLetLybXs2SdtWLnsE68ehXVl3/5Gq/FolFgeGzdos+uV2xFH6n6KSn6hAhcXtFnkwcPLLayAzyGUap8lyPyWH5nJEXEYGftSL4Kyog9WD3FRYv54Kaqlgkun5sUfCxxk2Y+c/YaSfXbYTxX/Ghw28i1Ucv1oLDifMjyYONqLvjgCBH+3W2wGHMiMuPFcHL4KB8TilY+dtRz+nb1xLY8saeVsK2w66/venKfvs5r8GAUfR7/wBqgWTHs+ut3Z8WHCyMyq312ykqfKNFnJwwUWIx1DOoYVqnrtj6xxxb/GKlwrjRzwpa1RA2Wc+YY8xUXNeaDW7O1TG753MjyMal8Axw+wkkunAJngPUkgmmaesBzxecBt41fG6lEL/eEx4QP5yMFD3NE8/EVR4jzb5WaIGdQo3gwgAW5nNQTExB220QudtRjvnb1xDavi5RjlxTDZv7qrvF6ci6VhWXYMQoMT6xc9PmrWkUflfM48Sen6NMjLuFUu0RQ97uOHEl7ZHsNly02GJYd0DGMUmzWJ/JMI1N8uLMilLMkk1MVkemhRyqPfjtYXcXxiPnwYx1a5BHGMNx8bjC7KB9mkYOPyuEPqn+GR8geGv/4OpLlljPxY8S/hiyNtTObRvTiT4Jr4WM+zmL3Dm79udtjueZzJotSG2HFoYgbTBV6bxfLWXIYog7qicn1jFlvrbj5qxc3f/wWLbutsYaB0aT7yXWLPqu/eHfWfW9UgWzyih9+jGkuG5/4szGiD+9mV3bw5mGVLIx6xZ4pJ2akwnnTzAlb7idnevZy5h3zFRY1Zju0btNNavvpIRQ21GgUpCwvbh746Az5gMQZ3JNs/GnFnhS1kCb+9DzwcOP1kGfsswvEYUjDxi2Mw5yIzHFgODkclI+Jg5Z33YdYLtNHPq+xcczrYrvCJ5ZTe//68p8u1tott5Pub6lc9PnzMqIP5S638NP5zFs1eIzyuHyxLl704Q92ZR9S+HglimI5Yg9Fa3hckCBhbAOa8Ia6HUeQM+e4L/51gNsO4W25Yk9bs3w6LST5eYh2BdU+34scB8Qn3z9adTzTGA6eTRTpMBqmso/bxXiYRobb53DST937TrqfMKQh/rs+eIy5kQ0x4Ri5PJSLiYuUl6sQ6+X6pMtvSEzmmkg5poeg1PvY+au7vuvKe2wWNqf/rm+tXPT5s3KiD2UZF0Vk1BqfEJKi8vAYZb37Yl206IMNeHUM2hhW2eSvH0mtRkthsvmdSCUpyGA8oIe4zy/24DkMvw5wHxzOTL8J5PTH2mLYa+DGvmJhPsXFYp+10sKUFlYxnhHc6U7lwjCG1QJmG4l/NBVhigpc+6hgweckDR9zbvprAxIy+fy4evBj5PMYi5iPkeMxfzwcdNikPtRiPf3S5pgbp70mahV93PzVW+N15Z1bJ5vdftd/eFDdAf63d2Vf/TIlBBNFZEQf8u0TQ1IkDItR3rMr1kWJPtggV8cgjWGVTrbrhivtK9ye4sadKaE8ZpkMdE5y5hz3Fccj7geth3xc4dhxjnCbPD5MExQclcWXwYCY2JPkukpTG1jOwtjGbKO10LXLMTni4ca54dnl8TK0ngukOMJQn5p3tjN2h2iQafOQP55QQtLyEIpKpl+dsW1FH5ns+q3UmX8/7p3QYtd3Vi76/L/v6tNQQgzpRBiOoMNp664wlluhYuXFKuS05Xhuq1rRBxvQ6nv4wHBLJdUff14887hM/sUmni4ak0xKlcNxBDk5xn35a8NJX1x3g+k0E3pTDCl+c4fzjl7b84mrubpQe1bK2y8cj+I8B0muqzS1geUsrNAx2zxq+/wnNM4zjXPDsxvGi17FU3840lDfIaJ+DlTmeNLko1w83KyliZ+LIk37OmPz10YOMZvDOMajPy6OT4m2GG4JT1sboQzsflrdos/J/7u86KO45Qki8eLPThJ9Bo6HSq5G9OENZDt9IPbHz+MzdGjDRJ75ZNaPn4VIMydseQIjv9jDzyOfAb4PTnbSc4bh5/OiR4n5QHixiz1iog98PeCcyMU/YrUTpHAYCMF9G8wuzzlmkwWTGEjKA59jHid8+2H8mK5HPlKu76E9nvucqMzx4FgRPsrHg6BMM15zPadvL5tbKbyOXyvUCdhz36m35iulU6qQNsLO7u+uXPT5w0H0UYSXEEP0ZGPiT7zoQz5zx4rFlq709XiLiT7YwLUdeMdl4LqxpisYxDK2okdZEszr2pSgRUO4J1cHD5y2uuXWOxAqRNpg10c73Yr2h/viuPKLGxxrprYY7jB+MNvcCMyT+zCEFt/O6yHAU5LrqxaRA+cjZz1wq8rVHsON8xB+HYZGZRaN4xDzseTgkY/K3APDyvGWm20Otnlb+fjj8Ej3rjO+eY3UtrJnmgc3j/XWfJ35l67yZdvb/T0PrjqAk7//TiO+3GKIDgITRmREH/KbP9ZdBXyO00wxZxd98AGrzkEXxy99zS9H8HFnTiivSSajXc4OHjgVTl4KIQirMRkeMV8wHeuGy5vU6xHKc2LnQyaLDXppsYcIEb/GllkXOeuBe6W52mO4wysQsx8akWkSOdgKR83Hg8WZE5E9Bgwrh4M64kIQy8eOeM3bps4Ylyf4tLc3Z2nXWfd15j/vNbAEb7u/t3LR5yVb0Se/6KOEJjnhKuRayCr6YANWXYMthjmEel8fPw/lsHXYp/7NiIefPuNl91/t2rNrtWfvrtVtNx7rCfi973yfjwzj076fIb9ZJfA849X37Rvf/epPri5a7bZ2ftrq5tl3EuIPls+4qDEfft7MLZY5qVexyHMz5Aq7Vhi8G8rA8OjNMKg1TST2+B+0+XD5OeNfP3wfrjjSXyO8ei7Nh4mrMSbxa4dZZlj++TwyYTibYxg5HsvGw0GaYlzh+s/RXj7HsajtNVL7Kh9/zdRV//XlPrZ2Nrv/7u+vXPT5nX9tEmAXH8oIIqgYgrZz11iJGAnR4FcmDu6VlEz0wQapugZW/42AS29Ie9eNNMSeTB9XPieP6EaHT/v9+6x2N4LP7kbwMb2RZBV+hCagJO7cetvh2Sqen18dbAWe33l6t7rnQd98TitmPezRn27/TQLPM1/TCUL/5ar3t39TH/3zvNWtUa9+5bhWMB+htZJ+IovhDxtPMNsIN+7Jaju+IGaQNtB1wfMmx4MKwC56ISG62mBYefH3qMO6QSHlmAyl4gazC9HgaWQeTxKmxYgHizc3qjFUDCMnJ2Xj4SDV28rzEIpEtl/dcRl+zVA34DY5boh11v8CaJUt/IVb2/3Mh1QdwcnfekeDb6mij6JWRjQpJ/7I4OcWmpjogw1KdQ6o/hsBl1a0fZ0Cj+9hyozandtv/417r3Y1i2dOO2uvkRwl+jzz5Q9Y7dnXiUP05/jRk6tfv8q8FNHGsun1rO9+6b3a5o98yuesyTGt4Hn40+/Stn/Qt5zbPi3c45pPjfqHCD45rxXMF1qvqp1f3OBatLVP+YAmz41d/BIb+ZxiT5iXnDzkqQtznfp8y/MwGkmBCYcPoft7DD+/RjC7cdi73luxB2UxXU749YFiTtEuHQ8p0PJt1hmf67m1/vpJ+UzBz7DEmC7tdWsvloE9z6pb9Dnxm27RR8VfQhDB9vbRMyQjnpSIlaLgxxtXncGiD3YzqvcGgOGPI9cznBu/Lo3L5T9E7KEgv/kF92wFn127d63OvOs+Ky0k8gyCz6p9DYz+feL4avWibzQLPyaBR63EQV/RIkHoD57yodkKHgL6iqef3uN94JPOaf/7wscMwg9H9OHlNu7a4flC6zz9ih6FxI8/nB+/bZSPHm3fYWo7HOXapMGA4ferXMBd+8ZQNL6R58GaPMdryDBguGGy08N6kolqHA6cS57NcAA8PzB8raG5bsIRh2BAc5Qb1TyWdPkoHxuauXQcoAjSt6s3RsMdqF6w1nvzOIN11f4C6Ex/ASzYw54frlz0eXG9og+lnSeELF30aSPOVu1s0QcbjOoaQHU2Mfwp+Xf9liSlX79tnuCD5/jxP33Zancj+Jx3xbBB8rEjJ1annL5nte+03c3fu9u/b/jI4fYVsF17BsFnzym7V3tO6S6IlzzhA7Mg1OtZtuhMq3eoLfX7yEvvNup2xVM+MzOjiz705f0ed3Y7gbv0ide1bRHRh19zOLemuPn+fLWRT+whJBh+PkeYXR8X0+/t3PARTmxPDISKrrOINEPRGHvj6WsEyx8vIswmtybaKm47pbKP2+XxMavuuO4e4kyTx65LUrfTywxyBjUKKRRWHzzvHLN1xIYiTsMB6j19u7rj2wo+6Ssg3X0jB/atj2b+8h+/vGoaTrzo7Wt8brGh1OoXArcVftKUECz64Deiuh4gcNxpCHY9vpbHtn7ATjW5XFN6zXMuaUWfu91/WDVDAg+JOXv27V7t3d+8yqWJPX/+rGuNyeAIPE9/+ZXdHkKNgDR9JYuMTwWf3mHDxRVPHcSfqehz5dVntSlVbVyiD57fuGsG98Ot8QFXOh8DJswHjyvMJoeXsX+TfR5Cg++U1+PadjRG/YKhSbqcwRkhmO0wAJjtsPqQt20er+3owjhR9lLhN90Tla84xJw8cbjMjcocR5p81BEbJ3NpeOAgSNe23tjsdZJjn7JQxjE+67oGMMyhjGz75WBgz49XLvr8ihJ9WnnFSklJ0adFxgIgt1qG5VaooHixhjudiT7YgFPXIGkKH4sjnLiYB+1y2MaosQft+Fxf9eyLW8cXf+WwAfIn/uXW9mf/+JLPz6jkvp6lDKh+7//DC3rB585bT4zs7z+4e7W7eWVs+jnZNDt5/GQ7eT1wXvMKWvMf7c+af7/7ZV/om9/zkWe2P7vyOz/b/kwXfbC8xvOpwGD+Qmo8vdiDY4/jC/fj46nD4bIXh3Tw78Yc5kWOh776vHz4GLV9j2EN4yHVtdNhjsOE8IVxM84RYldvw/PBsT7nZ+orPYNjvFisuVGFYOTkYZTt0I7Z+2G5yg5L1GF9Mfprf7mijz820eQCxurLPwB622TGwJ7nVC76vBATfVRgJUQQnVRMENmKPsil2Is+2GBT1yCJYUZokGhj5qYmjDYsY+TyOVaiTwqBZ5q5t73o3HZVEb0uZvqcdnaz9Gf9oVVGe5p9pU804s7hm443Ik8X+/4z9qxOHDvZ7iXU/X1y9bE339J+d9nDz2gn/vSgc7/v+XwR0Ue+pvyTMYkrhGzg2MPrEPeBR+V6sA1HuvY/MWAZSXCwymw0MN3lZJQQtT0ODcsfDwBmk00xVXTbKZ39ENs8blTUKWPofNjF5DDEIflaI2E5ZDUOBzXpmTYfZWIKISctDyGI5PvUG6O9TpYr9vQjnnwiIy3WWweRge2w7nt/4t9VHfHxF7zNgM8vmpQSfzDRR4XkjwNNTs54cx3lvuvOO5vjkayfeh8Myg6OrhshWk752mG/TZXN9YHTh/17VKSc17N0dqZHpLuY+6dfOLvdNPrAufYNo0nUIYFHbRpNf9OHBJ7bbjzW/vexIydXR+84sTp2+MTqaPPnls8e7d3e4yEH2lVBD37WDa3oc/Mtd3iSGc5tjjrP9fCGxcLnCrPLvd7sIgcfocV3IrGn9UbCJDdkZ/taxA1eVGlqYzxpSOmDZ5vHTR9FWDdmdZnrJ4trDWkOPpnEzJrzMHK95Waci29on5aHcFwpetYb61b0SZFvm8166yAnC8v3tfd5lYs+vxAm+lBmcgoh00rAxR8Z4adErKnFH4voU++DQflBcTmCj4mrOfq4XJvEHbpQQwQejrhjui286blndaeENVfNoQtP6ZscuuiU1Zc+eWTo0owHtN/P6KQwWvXTiD/Hmw2mb24Enk+/+/bVCYMeev69Tm1X/jz0J77Y2nOLPnHc5qj1HIIPFkcYV5htzkOE4QpZ/ygMocE3ZC/MmzwfawWJdKQwSBD5mG0eAMwmBG/SqBYBrJdtQoJo+6TjaI4N++VDcCjOjvw4ebUmhZqPE/VcJh4Und4uHQchaNL2qT9Wc93keG6IYR7jtZ5rAsMbw8i2b04G9v7UV+R0x/Z1/Ofe6ujjF0xKiCEKMCb8+GNASCsbJyGUiUOPdS361DP4TRNRz2BYv9iDiTyjxyuk7vs2ttU71AA9Hl0ZixV4TMBf+yNntKLPBVee1n996w1HV3ubE8D2ntq98kUnht3W/GwXiT7NkfDtSWGN2ENtaGPpvc2f481iH3U613Qj54MX7GtX+Xzd829ufZhFn7jrKW3Np5+wKvKxOMK4wmyzyrtpbOcmDOXEv2bEbY/vLTcfXGZt7THcfD7IH2abE0mea4eHO4wb3jXK4ai3POuk4opDzMPC47KtGp4D4dZ8vD4AZePxoav3eY+LnN9ePtd8DP4e4/qpXezhjWt1XBvLqAN/pWxbDAzs/dnKRZ+fcYk+FIdfbIgRRK649ILVR679nLdkqJ3r89GPz/eE7drvWl1+yfmrj378eq8PV7uYGMnxZRefP/L/sU/M8bjaYAKXN8RRg0b0ad5jqfBTbiD001EO2zhRLhyG9QqsLIe8nkUOTEekpxB4TMH87fed3oo5Fz74QP/1de+8rRFzGtGHTgpr/uw/uKc/Kaw9MawZ2/rXvFrRpzs+nj6X/PvrVlPRZ++pu9uVPtf81m1tm7Ho468dVxLS1NX0oY1VBqzGPPxhXPF8oPD9k/kwtJr/tYGdLvZg+YtjG/OB1ga1G/DI257jwHzUxpGKw3DngWqfkw+sLcajHTfmRbYVD7PPd1yN+Kyn+F42/hQI420uI0bTdbycenJzXFccy6iH+LrfSRb2/Vzdos+xn/KJPipb8id7KSEHEX1MNUNCyOWX3KURdGyCz6r9nj4+0YcEH6RdiPijxBxd6KGfTf9N/m1tUrzqVVT0qWuw898IasE7xRE7kQwReEziDhVvLoHHNBgogcZ0Sphqf+ii/e0x7iRk0wXVHuverPhp/6xf+TrlQCf8kBj0npd3r3Gpz2Necvvo353oM/4ZenPLUU85fzOHxeO/zkz8YbZR5lU7s9gThtDie2LMbJvvUZaP2oRBPh/EviwnQz5zXUMY/jBu+oqP6+64wOxiz/hq416j4e1z8BmObtwTw8r1lizZXCDe9mni97rN2mAZMdprJtc4GJMUjOM6rgsMawwb276lGNj3i19ZyjXk99hz/wVqJ7niZ7pqJ1T0IeBkCxN9lDBkFq9Q0UeRxRF/pgIP2TCJPrbVP/rPJcWfIqJP+cHOP+iXx6hPOszXJ3cCqYs7JM6QYEGfEvvvgCMOq5lJ9FEG1BHxB87f121Epok+u5rTvuhn9GpY+4rX/m5l0L7Td69OP3vv6uLHX2fFESL6pK2t2ibwYVO+HBzxxFOgFA0XpGEqDBiyN5Hn5WQysUSPAsPtH5f7asKbBvBtFgMDDEFdpLkxOcV8QHAtjeyroZKmyoCGF2tudGPAPKzc/JSNDUGbNn4EQb42y4h1mSt8MG7ruh4wzPnqc+tJjoF9L6hc9PmJMqKPEnrQ17tMGVF9ba8+qVU+1HcQhuaijxJ8unb+18CoHSr6mAQfFYvrO18bide9sok+ZQc4bLAvi3Fe3tik1Bxb7fvvyA2vY0su4Ydafv6DzUlb2vWvLqL+Yl6LQfSa2L7mVa79B3evzr54/+qyJ3/aCJkj+qStr3wTVSwO7JrLM0H1C2HhaLUINCOO35fySh+yyTM5tE4v+KSqFcxuCC/pryMe9rjK5PkK4Yv62DmLQ8/Dw481J7pxLHysHC7KxYWiTBs/iiJPu+XEusmCzzBO5cm628tyaqIGtpaHYd8LKxd9npNf9NGzKCH6dCKMSczpXv2avwI2bqv28nHt6WMThnziz44WfcoPbv4HoPIY/Q+ErhUDIa9nkceS+++kGsZdos/9v/fzq9c8+2Cv1o7y3hCs/5v27Tl5ovlZ8/f0lS4dO4k+P/DK+6x+6avf7gwpXY3Zf8OegmMsDv8158KG+UCjcws+cUjngo/bHtPbujmzF0hMLeIGPzrZ+lB0peejnXbA4cINjfnG/YDlYvbS/xT7BUWML3tffqxx3MZGwcfL8Vg2NgRp2vgRBHnb1B+v41cU9YMHx9Q6rosF0Jn34thQb6f86v9SdWRHf+x/MvDJb+ocKvrY+inxRxd6zPv+dLHoQo9N9Jn+fPpvl/ATI/qY9gJSyep8+vPhSq74Sp96BjX/IF8P1i5FOh4b+gOn75/lM+T1LDJScv8dxojDbvqm5521OnDu3tX+A7R5T/chwUd9XvmMZqNnJfI0pLe8Twh3CT06IBJ9vv8V92l/9K6//EL/1YO+5dz2v1/wsLex8WMd0q/S0HFg14r/mjPFhtnGWBm3snMUhtSAQTMkJviIiz2m3+CG8Onug+UxjnnMBye2PGIPIcKxh3OE++BwZLxqRz9UfsORh+HhxZsb3WQ0Suo+qfGw5Ex68XIl4rK4kbpj9tdMzfv4YNz6Y8xRJBjWHEi2PnIwcMqLKhd9/iNH9CHGMKHBtwJGcS8t+pBdtWeQeqXLttnzdJNnk+iDCkEtMwZqYkUf0z4/irvY/X2iRJ/yAxlvQC+PF38IPN0g7lBvROD5o9WZo1U8myru2AbvN//ModVph/Y0f/a2r2jR557f9pm++fRELvUFKvR85KV3W13xlM4eiT4Pf3q3U/z088Ann9OLSb/0CPdKIP+NKM/EfYoDu2Z416Hygdn2MzO08HMUhlTDYDBg8MoBPWsrx8uATM6mPTTMBz8DmN0wynNMavj46+Joctca/XMr9uB1x68DxDa/VhCrkm3SxC2JUN7WMmK2106OcTGWdTfHdV0Xy6iH2Ixs+ysGTnnxQ6sm4+gP/3MEPrMAdM/L5ser2zZrDhF9XKd+TQUfCs4k+gyCDy0CmK/6UaQgoo/+6pfqp8SaENHHtcLHlKxQ8Ycl+tQzcPkH9HqwztM1xWYSeJRQc9GqEy1Mn018PStiJGq70iqfU5qTt0jwoVO4aFNm2qD5nt86iD4xPkjw0T9/8JQPWUUfanf/J5zd/ob/Vx75jkC3m7USgUiQvzbtHPlHCjAtKcUe8ZU9KqY8q8GwfOKZwOyBeZs1G+NI6YtvG+eozzC/SwBxGcRUJiqM2yzkeJFjWL1mJg3qiM2FOk3cXJ7ytl9WzKbrelPqqq44llUXea+ZTfS2/zfrFn2OPEte9NHz6FvxEyr6mESkqRhketWLsI0FH/qJW/Sx1eV002eJlT5cwWfMNbYKS/WBRJ/yA5Z/AC+PcV4iJkw2gccl7pDlrcAXuEH3AAAgAElEQVSD3Rre+JNnNa91NaJPc+oWiT90GhcdvX7FU/2iz6decWF7dPvdr/6k0dlU8FGNPvDqm6zg7nvNoVbkeNHV/4oF0LfajFUaetDy16ibI/+oAaQEEmQCPUG2AYyjJunrBstjICdNLJj9MF7S2MbGfjviMK5yxaK/+2ryGYaem7+uPS/mnMhia4DDR9m4fEh5OfJZW8b3y4t5Kn7XXVP854h64llebSzjmqsZ5f7f/qqa4a2OPOOfIvH5hQaX8JNC9HEFpDZ29gWtBB3X5s5TG7GiD3Kalws3d58fr+hTfsDyD97lMY5TovCECDwmcYes77RXtHwXp+37v/9PzUqf5qj1U8/qRJ/djeBDx6/Tpsz6K17T/h/4f+662tMIPodvPj76ivYCsok9aqPnA+ftW+8LNOwPpO/vc69Hndl+/xuPfxcYVlfzOeoa8+G/Bl2BYT5Aavpmfo7iUFMCBkx2WwFeILthfPAfjnE/WB4D+NAgYD5wzF1Lf61wLdra8/CHc8XzExOdXUQMR8/Hw483J7p5PHy8HE7KxiZT+5x462+bNt+S8ZtrZwmvcykWMK7ruEYwrJL53dqqgYH9v1O56PP9saIPsRwu/EiKPqZ802of254+Q3v+61222kKFn6nAEyv4KDycV71a0aeugWk+WP/IGx602t0cof2rXzNeLVEL7tNOm2+uTMlA9t+ZFtFW3Ikbst/804fa17pOObinE30aIYdW+9DH9IrX23/93Ob1r11du+aP6XPa2cOG0GqPIBKHWtGnKUJ6lYxO+TrR6EUnjtHfJ1cffsPNvanLvvqMdt75W9/8bk9wtU1Owx6c0l6Xdo7C0BpSMjFkeUwOKlR5bvLUDIY7PAOYfS7lebghVDj+cI706HF/XM5GXtp/KF8yyPl4eLGWQtnFxcPK5aJsbC60aePm8pS3/XJiX77gg19jdVwry6mNvNfMpns79b/WLfrc+fQ6RR+bGMQViTDRp6vCThy6flaSvtO7TDWsiz8mQSeV6KOwIKt+dh0+fKTg6Oh3/X1/cb/VrkbwIdHn9i8c63n+g+96f5FxQxd4nvHq+/YPevf4pk+utvvvFElJ6/Qzr7mo/ftjb7m1FX3oFS/az6cVc5rVPq0o3ZTbdLXPP/3i2avdjehz+jl7reBJ9DlJC4AaGyQM0eohqsfjR0+ubrvxaN+P2hy948Tq6OETqxs+fLj/+cVfebAVgl7yHe+d+KhxUto+VgUlMu0DTj6xxx19GDeK0sDehnzkq52UD9opaybHbzP4+OMqgO8PvZTnuLZiD8rdzhV7FEPp6hLPQe6Wy4t5fI3nGB8lc4LxHTe+SuHFsEp529qpjYFTf/9htUEa4Tn887fM8O362HsCMfNX/HDFHa7oQ4FQH3WSlyuwYUXQPI7pZs0mcchkW4k/aq8e1WZ6Ktf0e92W6wQvVzxqTyNbm0Kij39gpkHzu37vynZyTX9MH134efZrH7h68Teir89gtW1awaOv3vmdp5+6etA3n9P/du9hj/50a5he0Xrma+7b/vy3ru7Eqe0KHozzkFbqNK72mPT13fYL197ZrPAh0acRavY1fzeLdUyveNHrYHSRHLrwFKtrWilEfUk8IhGptdmuINrdCj+3fPbI6oaP3rk61og9JPpMP+ff+9RWNPrjZ/zb+qt8E3bs4cN/PbrygvngZtbPURxqDc/aUAqxR54bPy9cpqft+ZjxTPBth0SzbI7i88HhzC72KCt4djl+7W15NZIbnRk3DzPKUx2x5R/7UX7KtEuT65SxLHeFD5/rOq4ZPu6U+d/azs3AqX9Ut+hz5//2FkFK+KKPoHOnKZ8AMu7sjwPF7dvIGrUT0s4Xc2LRBx+Ap4PkU3/9nu1rN3Ty0mnN/iymjxJ9fuDl95+twPiNb+IJQCaB57tfeq/W7SOf8jmjf9v+O3SEty5A3OOaT4XkbttHY0Dtq6OOStfJ0Y9gf+CTmmPSmw/V0y2fO9oLNCTW0M+mr3j93Y+d0dbZ+fc8te13+xePta+D0ath+5q9gfY1f9/y2aPtajMSenY14pESfGivICUIvfevv2jM11l3P2V14sTJ1Z/9+Af773M8EGA+8OtTDw6zHVO+7lOnwlAb8EiLPRowMYxD1fR1HcOsqy+e1/DocB+cKNOLPAoNHz+fK74PDlfTtgO+qV8+8hgcXV889hLo5vHheDnc1BGbzFjBibvutmlynTJmex0tZZUPznkd1wyON2Xet7ZLM3DaHz+8NASn/8P/6z8K4vOLJSVFEArUJ4SMyfDHg5BXKmbf/j6JRB/eAGwaKJ/4i5e3r92cdQ/7Cgwiflh9sV6B0azq2NNoRMebN8FMwo/U/jskCJkECMJkEiEufMxW+EEulGmbD//p3VrhT/9Medf5pnb3e1x3TDq9DkirctrVYmq/HhJ+vq07yetvv/9AuwLoHg860Jv/zHtu7078albx7G1W9tB/t8e+N+3IDmFpX/Fa7xW0l9rt7/79npfPhR/aW4j2+3n5z3+EMaEJYWrogz148K5Rso7ZjcXueFCNM60RZPxPg3UmR01zZg8wovSiBpbbuOgwHyAlbTO7YMGxgrbl4Q/niucHRW9qZ6+rcPTheHhxl0A4jo2HF+WlfFwupGliRrkp1255ce8Uwaee62V5NVLuetp0z6f9f5WLPt8hKfpQNv1CSSkRRNUaT/jBYkLquFTcNvFHWPTBBmBkcHzsT13aij7nXdGtwKDPsTtPtCsv6HQm+nvf6XtWN370cDcZpxUYNElvRB+1AuN3H/+BWU7Ua1bo/jvU/nmrW/vXs6YnOflWntzv8Y0AQW/8NEFf+qTu9a/tp2Pg2r+8e79f003XHVnRSVn6x3ZqFs319CPYaT+fd/zZjX3XK68+q50P3nnridWR24+vHvyDNxgpV2IR7bmjPp/4l1tHbWn/nkON8EhiT7vyrBnbule8hs2faUUQrQzae+ru1btf9oWZr4c89dxWMPnFh75VPPXItTR2il2jU6B8P2ioGVYaGEI2sxDGDUUqy88Yh6ztSTXAIcMNZ4lPgz+9EKYC4eEP50m+jmzXYIZrDr381+1ycsyElqme+2qLhZesPy9HyWBkN7zMuJct+mCcx421UoWEYZXytrWzBAZO+5Ovrhrm4W9/cyJ8myb++ONBiKxJ+IkUffyDbuiAePWPXdxOsu/+gNNbTj/7PlqB0azioZUX6xUYJPCo123+/FnXzrjnnp719L+iPYS6Sb3plSybCOFbeXLlVWcZXy1CimVT27z39+7S79c03QfHdky6OiKdaurAuc2JWVR+zZ+TzetTdHKWesXqno/sjkin7+646ZhV9CFuTcIP/VyJPwcv2NcKPfQhpZjEH6qPVgRaC0C0EoiERhIi6aj4X3nU21eP+bHLRqmjvZ/o8/yHvU0spdi15b9GXYAwHyEhZZh4aqG7WQjgaN0loKeXrBxL7/l5xSPl2/ZSMmuQgyPlFIsH58cULeaDz9O4xxyj8huHPhwXL+4yKHkYQ7koExuCNk/8CJL8bZYX+7LFnpxjrlQ1La9GpCLf2rExcPpL6xZ97nhqKtFHMeIXS8oJIX5sQ145be3XQ6lY+2xoAJiij//BRGoA/IYf6k5jMq3C+MeXjFeEUDuuwKP6KFLe/wcXtALSscPzGPUju/u0tmJDc0R38+oOfXQRgn6mv+rTihBN2yu/67PbUbJh4K2/SsekN+JJI+qRUGL6KM6JN2qzu2l2+xfpmPRuv5f9zWtTxDO9OnW8OSadNkr+2D8OO9Jf+rAz2uPUSVCyrfQhvzbRR8d0/fokrtGFSweC0Z/1vlPqFbL9B3e3ryR+4NU3zcJS+w296y+H1UDt3k/N5/lfha0C4l9f/mvWxD/fD1barsl6GFKD34WKPep1pVTcE1OY7bBMYLaxOpm3GmNK6YtnO4wrFR/Plwx3eh3EoQ/Fg9Zhz1K4I4GeaXNUKgN+YtLG7fdfssVyYzcJu/XW2DTHGO91xYNhLlnNW9+5GTj9v1cu+nzLzhV9VC1gr3ttiujTR73yiD744Co98JHoYxJ3CHqswDMdAN72a50IcUrzupjpo4s+tLqI9gw60YgRd3yp2TiIxJ/mDx0TTsIDCREnGhGCVp5c+5ZOhLjs4We0m/ne73vmYlXuwUjKH4klD35KJ1hQ/HRkPfp5y8+d3fJ98Px91i4knhCHas8m9Xd7TPoNR1uf6rSso41QR8ek33b9cHz6PR58oM0F+YkRfWjV0Wt/uHn9ixQevcibf5MARR/1FeWdRCDCRR96zUwXf2ivIdOGzw98crcK6AUPn68C4l9X+DWryOf7QDPdVseosckXH7HF/8SQ43eenAD6Gmd38nbwc+M1ATbAchyXCcwHCLhv1mFKY3uMheejRq6m3JomgJOYuemIbJ+T40ioiWsurn5iY3P15+UoJZL8tpcb+7LFHt6zSB3XznJrJf91tdM8HnjZI6oO+fYn/UMmfH7RpNQqGEz0UTT540AILRVrHwUtVDh8+IhhBMUHVcmBb7rJMnf/HRUY53h0JUCQOHDgXLMIcepZ3Wa89Gk38F0f3U3/phOi6EMCA60qoZVC9PdNnz7S18CFX94JEC7xASmYmtr0x6RrR9Zf+Ghss+o3Pbc5Jr3h++yL9vchHThvb7tX0xc/0fFGK0LU6pmW8zXv7WlZTSpoD6Dr/vW2br8kw+ecy/avTj2TzmlvRJ9nmff0Ud3+4acOta8NnnGXIf/6/kKvema30XNb6+tLo11xNPGtRJ7Lv+aM0Qom06qfKeT7P6HbfPqFX/f2/ivs2sKvVRNPmI+QyhtwTX3EIdawsEeuAM8q3yEUWPvUKGTwuUlXO+3VNlxzotzPjfHj4HOle+X7CyXAfg0ODIfa5vfjxR3HMR/d0IOHk+upXFw+pGnj9nkv//0y4zfXU87XXyUzh+WgjmsIwyrJzk6zheRZZjIuzeyB//E10iZF7d3+hL8XtWc35s9PKSFkJ4o+lKe16OO/uHIMcLaTtf5odebKdjw6R+AxFeYbf7ITIM65eBAgTj9nbztpJ2Gh/9D+LXRs91rwoVOh6OQm2gOIVp988O9ubld4POYlt49O76L+tBk1iT5f9Vzzsd6Zrj6WG33/It9m1WT4AU9sVqs0RXLR465z+nnNsw/2r0RdcOVpbdubP3OkPzFrX7MZMnF/5y3Hu82SG37b49Ib3mnfHNpYmXinnF38+M7X9PSug414Q3wfurA5+Q0Qfd74E2euTmv24jlw/t72pC7ypR/t/orvbfaVslwitBrtu//sXq0AdNuNx1ann72nxWj6uMSf+15zqBV9fu2qdzB+w+y/bm3JSHs92yfs4YgnkUwMue0GehUXfNyTcNYFCjTGchzGDWYbAGlsUqvgE8aVCjEtZ1MiM4iuzPTi8cfxzIQ1ao5jDPFSLi4X2rQxh/CUt89y47fX0xJFHywPdVxDGNa8dbw53kJy7BcXcvJz4G/qFn1ue+zf93uVpufFn5sSwg9P9CGW/HEgXJaIVcfViD53Oq+wnIMbiT7fuhrEFwX0T1d39qdnIaRy2rz2R85oBQQlQFDfW5vXhNRR3eqkMDr+uxUfaBPfRogg4aFtsz7e+/iRE/3pXFMR4kDzGhOtFHrkL93MgVasrWnDat9m1V/2mE60uOzJ7hPKSEChV6AualY/qQ9tmrynOfZccUqiy6ln7Fmf7NVtoNydlkWve3VHpJM4RKdlXfTYT81EH7JFr9rd9X6NqASIPn//n85anXZob/NnTyv6UE7108H0RFBu7/2NZ60O39Q4WH/o9K4jtx5fnd5sLm36tBtQN38ONquZ6LVAIkqtGlL7+9zr6+nEse7nL37sO4Hch9wY074mgzxohqE20AEJMmHe0ox5tQkZNXEzzi9SR8AFAjXBch3GlQKA+YDgOhrNMSZbYceEyos/jmsmtL45D2Owl9COyfrliTsZ/CjDy43df43kHEOjktA9DoEfuCFoL6wZjjfM/mb28t+fJON2T6xlJu8uvAdfWbfoc+s1OUUfYsrPeSkxZKeJPzPRp+SAVkL0+dvv60SICx/SiRAkQHSrSRqBZy3skAChjoWnzYdJJOr3miHhpxEKaHUKTewvfeJ1IxGCfk6rTr7pv9wmOaYF2yJBp31tqvmjXk1TrzJ96L8135l0i2a8ptju+W2fWdHx6FQj9Oedfz4ck05CCAks1Mb1QY5Jp42QCR+NE91mycNrdZQrEoBI+KG8EL/6ptnkm0Sfs+5+Cuv1Ltq3iV4HI+GJbKt4VSzvePF5rdinuDPFqO/9REe4H77lRLfxNIk+DWGnn92IPrTvU7vnU7cJ9YdePwiBl331GS2Hv/mkdxnMhz3w5Lme7YJGGGp/+G67TK+QgBR6yaUXe3g5ZnKzDpvng8NV3odBXhxhXKnoeb44nOlt7fzFoQ/FM/TjxV8GLQ9jLCdlYnShzht/LH+y/Zcbu72ONlPs6UdU2QJgWltuvTADFWme/rknFOZcXPALElxfB1/9tdwuWdvfevWbMq70odD8HC9H9FGp8seEJDV33LvuuMO90gcBLdWmhOiDiBCHmr1n1BHdVLu02qdbedIJQCQU0EbOtCqIRAl9s1563auWz7t/5/xWtDDtg2M6oUytUGlPKGv+p04oU6IF/Vy9snTF19Ix6V27+zztc86QXSdmkehG+/vQiNReDPRaHQlta/GH/qMT5NZ/GoGOXsfTVyK9+lkHG9Fn32p/IwoRngvu071Gdrer5ptN0/5CZG9/I/iQ6EO5JRGP/OqveP3z82nz6cZXI9zYPsQhrTDSRSpqS3zd1qwUa4e+Bj/xpjahvv5Dh3tzdFIdiUT/17e9p/mZzAQhzYOK+YYug3jCLiTIxHnOyZHkWMDDHcYRzwcnugFPOh8DHp6PMK6UN54vDmd6W79YFhdFKC7Ob+7JRymUXXylchXOrkzPPHHLYJW2svzYTdd+2euIkyM+/+Vj42PmMLL8tksSG6dsp1gVdMbr6hZ9bvmGN/U05BEd/AJJHhz2a22nrPjZij7N6zr00Y+G18uiFSGa17OUAEF/q9U+9EPac0a9CkbiwSkH9rQiBL12VNPnX375nFa0aDc3tnxa4ae5v1I7tZKJBAt6tY0+tAJGX6lCexl96u3DCqZLHtqIFk3/+z/dfUqZ75j0z3/wjg6hGifont+u+hkGDn0FEB3fTn/ucu9TvZR/9n13rB7y7GFjZxJ9SKwj0Y5EIrVhNL3Kp4s+9AoY5Z1WIdk+SuxRG08rYZC4pNf/bvn80dWNH7tzveE3rQIaWzq/wU8/+6Pve583DluDtA8n7t/eiD6apRR7INthKcj18IPnOSwruP0QnvL9FpAXRxhXigGerxDe9D520SwuinBcWPyl0I3jwrCGc9H1rCPWFkk9UGJJjeq/fB7Gicx1v4kifdIZz0EdRYvjlWSpZlt5f2GTmwkJEeiM139dbtgsf7c86o2z9nlEl00Tf/zxIInJw32HZCv6eEQfIqkVIQwChDqquxeEGlGABAQ6bvycS09tX/WS/Khj0tVNiHNM+pt/5lAr5px5V/sx6e0rao1x2jen3T9nfWIW7UNzy2e7U8rolbCjd57ohYvj2uFvtIcOiUJf8aPDa1+2+CkWk9CmXjWjDZ/VczPFqy6KE+tj0um7E40WpU5Vo/wQ/vbPejPoVriiV9nW+wG1glUjVOmiD4k5+xuhjkQf2ptHxUx91Cter/vRbt8nEn1oU276HL75eLe3EAlG5PP0PasvferOwd968+l2RdL6dcHjDd73/Y15M296HY1i+5Mf/SA9orPLJu2Dif8mz0fsCBESZQI8al0Centyst6niZ05fgc81/wocdt83DlP5CJ0vFj4XOkM8HyFcDfy1g2NBshxUYThwmMvgW4eE443jI/+xhXTXahvnliFwCY0s3we5tfOVvBJWDBr08uvG2mO8v3CRho5x16s8HPmm+oWfW7+2rnoQ/zkER/8QkkeHPaK4K368ceD1F6umIuKPtMB9fTT82/kTMlwrTwhEaIXINon7XX6mjyrvVqoQOi1HFoVo1ZvhL7WRXvumE7L0nHSfz/wyXRa1mp14WP8K4pe/5wzu9fTGtHi3Eu7jbIJbyuQrEWLmz59tH3tSO1dREJFK4DQvkbNf1N/WqXykB/qVslMN6s+uzn9jGw+/Ke/hNT3ilbYkDh2xgWN2NHwRh/9mPRX/oB+TPqw8bFu/EHNcfH0ucc1zWbOzQbRXNGHMFC87UqfBgv1V6/uUcxUn7Tah7BQ/Pd40LD59Gffd3t30lcr6nSbP9NeULTyq+Ww3Xuo23habfjdvjbWfPTX/1Q8pzQrlYi/l/3shyH+8jyMZF5NkEjsScuVXxCDEupoxMfPn1zzfXCiKvOgiMXE58oUOeaLw5nRS//DqT+ZKPj4eHGXQtnFxcPK52LtJbSjaL88sYpCTmJs+TxshtjDv/7KjhWqGJdfP7GXVZl7dyxqqf74RHw88T/zHx4pBSGJnZsf8QanXTzuGHh+sSQPjnkMW9EnJq9aX9sAqob3A4VEH4L45p8+tDqjWQXTbiDcfHQBgv79ymc0E/4GKE3M2xvY5NUc+lmo0KMo4h6Tfv8nnN0+yF7yBPeKolf94IE2rrvdr3uVjT43Xnvnai8JO+u9cUiQoNg60acRLGhly/p4dF20UCLTVPQ5tTn5ijj5hl+9BaqW9sSs5ph0ehWOVszQyhr1OpXiwXTEOXGs+37gkzrh510v+wIk+jzoGdf3+Oio9nYT7mZlkBJ91MogEn26RK9WH3zdTe1/6iuT6LW//kP7PDU80modWg3UvoqmNp9er5ai+NRJcMTve//HfMXP37zwo17u0j6E+G/wYo9i7FUKfM9puDI9hHvTFtQAx8/nRgHCfYSE4K+nEKu2PmGxhHEX5is0WnvNhaEPxTH048VfCuV6CM/iPosTOHG8/MBmF9Nw+fHb62mJK3zaRynoEoEaJa9DDGtyGAUd5L13FwyU7RpZBXTWWx7Jtpuzw00Pe4PTXR6xpV7RR5GDiT/+OJDc5uE84etdrkHTPKyfXB04/dTsR7ZTMkiAoMk/bVTcvubTiADTI7unIodKIir0XPfKC9sVKaaP6Yh0auc7Jv2+13THpF/+LZ5j0g2vsCnRot1/Zn0C2YFGgKETqmiVChWg2tenPS2raaNW0lz8+PEJZW1MTfvH/C6+aTW9bkabItM+OiT6kC/iPOi4+Mee3T5RXPokNw9T7mmlT3f0+xBb/zpYe8LZcGqZ7XU0xePBC7p9n2iQ0Pcb6jYA71YBUZxq0+/TztqzesEj3oaMBW2btA8h/hu82KOYZshtM9xjGq78HMHJ9DTE8dfGkQosH1f8ayOcM76v0IpwTfg6m3FRhOLijkOlUK45yuo+qzNrAvGxI7wGltBzuTz462gr+qSvwOXWTyg347rbefHzeXNN0s/656/nG8zY46aHvh7ylkeI8IsmeXDMKcFEH9XPHwdCeupYk7ze5Vt6/uP/8ODVCx/xjln8pUQfWvFx2qG9zZ/uCPD2NZxmDPQdP44k8AN/fNdWPKDVHYdvajaVWX/USiKj4NP47l4dG07Mon/Qv9/1F1/obdzr6+mY9JOre/2Hzzqh2F5f01ernHm3U7QTytavKdFeOOuj09t9aWgPm4YfOiqdPu97xZdYq5uufdk9+tefvvSpI+2+QLTCRj8mnUSn6Wcqfn361Ret/vWlw75BV151Vv8qFpITvc0//cLZjejTCX0k/uiiz72+fTh+3rf59PUf7k7hGl2wrQjU/bB97Wt93DxxSXEfajaFfuGj3m6EnOemO9zofdcsl9dZ+5RiD2w7JIp8AgYv5/7JgR4tz3YIT9THXk+hFl39eDHx+Jr65fmKjdbPY1w0fHy8+HOjM8fDw8znpOtRR6wtknqghJIp0m/ZPLgE32UmGMtHHbFhWEXKtBIj+Z5vKglYFIZtgn7orXWLPl/6ippEH5USv2iSWhCZFgdP9MHjQIowVayioo9v4vgDf3m/flKtToSi4H/vO7vTikqJPm963lmtkEErT9SqF1qhoZ/ehCRp2uYdLz6vXTlD+8TQ6pnpZ3pM+inNZsC0QXC7PxAdk958SIyizYqP035BjWZEf3/kjTe3313+iDO6B73mz32/O/yYdLJ1w0ca0WINUQkVasUKFb7akJhEEfrvg82x6rR5MbpZ9ft+/4JW+Dh25/zmTmILCT/qtag2uLXwpXhoj4tfC2H0M/31qCu+7sy2/ZXf5Ra/bDl87Q8fbMWsg80pbbTS6wHfN7wCpvr4RJ/ffuq7V0/62XsOLigx6qpVFwb9u/lv2lBa7bH0lz/9oRmsPA8e5pt9kkevtVG37UDPkO2Qq3ddhFSKgdA4Xnk+eIB4tjmo9bZ5Hx55MfH4mjLA8xXKn+qX8boEofLij+MahORtxsPsNWdpsJNiDeUoX788OU8Zz2YJPrx8lL+WeHhT1kEO2/5fLORAsSk+phP0Q+/4hqpD+9JD/g7Cl0p4MDv3iz7ULy+m8anREGltIywWn70UsQaJPrbB0TVsP+33ruxOUVrvmTMNloSfUqLPP/zUoXayr0SfdhNj2si3ERlotc9nXnNRO/G7+9Wf9OVo9P0/P//sVuwhu7bPqc1rPuRnelrWbTcca0/SIr5I5KDNjmllDP258aN39uYu+ooDbf8H/sBcqNB9+kSLz/2b7Zj09f5F/aqVxirpGfQKWKPTnHf5qbP9j6axvvVXz23b0ilZ008rirV8727btBsiN3VCn9u/2HCw3juJ9sPRj4snTj7+T92+Opc+jMQvUolWq/v97+7j4k15aEWfRsAiIYuOfp/u56T60GuAdIqZvrfPn3zvR1df/FJ3bP0Tnnt5+7cS4tR/t/tAaReHbe+etA8d/km52GPXxFAKsac0V6yBwNEYiyMsM5jt2Ej8dRXrwQeQa4IAACAASURBVNQfiy2Mt6k/zFdslPaHcJkowvFh8ZdG2cWHYQ3nYu0l1oBI/zyxikBNamT5PGyW2MO/DsuOHcuvH87ltRV7OGxx26pJ+tnvrFv0+eKDtqIPJ7f8FT8bIvpgYo95AP/237h3O6mnzXtNn1KiD+3rQkLDKY0gceqZe9pVLGoPGxIc1Ca++klRSLGQQNDu79LETBv82j79hr908hPtr9MeL969DvSl6460YsH1zSqcY4dPNn/Gu0ff5T6ntauAvvI5wytfLmy+Y9Jf/azumHQloJBY2You65SqU7aUjwc/5dz+Qdt2fPw//mcSvrqVLQfPmx8Xr4s+7UbS2sbHtJn08eaI9VsbAYz+pvhb4av5Wx0hTwDu8ZBG+Gp4ePCzupPFuB86nY3y7xN9qFZoL54DTRxq8+k//NYPNaJPJz499jmN6GN5fjEJPXkeNvyTcrFHrrWhFCJPn1PIB7cCVHs/V6GWew8sslmNZ9DS1ld6rsI402momb9xzY1QJ61xvIJ59RPHNY7K3JKHNdRb2Rjjr4fQuOvqlyfXOWLeij05WPb52Jx6MkU6r7HNjteX7Tzfn/Peb8zjKNDLF+//OlbPFCtO5gAwoSQPljE6vuij+mMx+ZIhGbN1pY9pYAidzD35+Ve0+5mc1exh4vrQqolvXXVHiuufP13dufr5VSdISH/e+JNndUd2Nyt9aJWH2rxYnd70wdd2JzfRR50UhRyT/rofPaMVOu5yr9P6/odvOd7uHUOvEqmTnGhvG7XnTyv4tCdmDUelf/6Dd6z+3Y90+9dMN5OmfXhIoPmanxswuvih19hItCDxhfaxoULS9y362++nE8rMx6OTXX3TaoWFxDBVKxc+er5RNe2XRKuCzrlkyCtt3qzi/+In72yFLnrtS70Kp+eAjownweemTx9ZXfeO21oMUx7OvXx/uwroYc+bn4iF1AuJPpT7A7TSpxF/bCt96IQ3OqWMhEuT6KN8PfbHuxU/ZVb0KBTmSXmSaQtrkhqGIOWDSs6NMbE46uNoqmZicSBXn70N30cYb/0VE9edGaz9YTwrDANqHu9l0PIwMlMza14mximMvDHHcpau//J52DyxhzeGbq+ndFfH+PlP97P86yY9a1Iezn1/3aLPF76MJ/ooXiTFBzvXbqEkDwYzuk0Qf3rRxzUgmIdofOB+/E9f1oo+511xas8krdbQxQ8SAX77mn/LKvromyjf1KyqodUeaqUNCQ8k2uirfQj8/R7XHJPerEjxnRRFR7xT/3s8sBFS1p/Pvv+OtaDT7WGj75PTnppFe+esXy1TewuRuEArbMjfVOwgoYrwXfV/aseHO0YtEi1oHyElWtDm0qZ9i3Q/V1591uwUMXKht3nAE5tj09diEZ3spX/o1SkSfS5oViWpz83NK1KtsEUbQ9Nx6U3u72g2uVYrnNS+QTpHJOqo/YOmPJBYQ98/6pe7vY64n9f8UCP6NEKUS/QhwYxqg17Vazefbjb7phiI/xddM9+U3IQh3U13uBax1XhchibtJ5d+qBjsRMESkkLjSb9ahZdzfEzN/TBXnzA2YiC0ANp+vBxFuSJvMwNT/2FVEIuLy0MplF2cpXMWzzZuIW+sOK7cLTeHh80TfbDclB0zpvWKYc5d5VL+/M+EUp62duYMnPvBq6qm5QtXvjYKX3rhpV7hh4jjiz/1rPhpRR81+GFDMtZKr6hrfvySduJ/9wec3v/48x9qBBCaOJPIQQJAs6fLy37s42Kiz8f/qjspioQN0woU2zHpR2490a04afC0R3Y34eqrfUgEoef26ZHu0yvItIeOfloWCUKHLtzf+iJBjF6l6k6Oov19ute8aJULCSK0Koc+7/ub8UoW9Lh46kuiBYkopzeiD4lb+jHpU+whx6bf99GHWl4u++bxsemv+N7T29xf9OWD+PXJt93axtYKW80fEqFaHpr41QbH6jWv7tSwbnUUDTSX/PvxcfHEDe3vc81vdfvqhHzotTZ6tc8l+tCKJdpom9qR6KNwkb8XfZNZ9MnxUIFMxvlXrIVFgyHDFDYkBUOfpGJPepFHBYLlPi4zmI+4dHS916v/JEx5bPBiiuOvjSzeBMjK0sWebEQ5+SyZLzDRos3yxSsKW9zY5vCwUwWf7j5S02dzamrKar7nnJryWROW8z5ct+hz473iRB/iurTwkweDvap4wk9Fos/ttzeij/sxK/pauurZF7c29A1wdQGEJv+0781fP/eTIqLP+//ggl5EOHLbeB8c2jiZhIXRpyGgPRmqWcFDZJCIoFb8TEWfez7yzLbNld8Zf0z6GXft9rhp9/4h3YdEHxKq2j1wulU/JHgQP/T60f5GbJiupEGTo0QLOpa+XdG0PoJdbVZNdmxCmNrXR9/Umrh6538f9hK69zd0x6brx5yTTZ/4RW0OXUjHxXfCF/HQrvhZC1/0MxKGSPQhDkisevdfDeIXR/iycdWKPrRXT3NCmO31LhLNSIAjDLTCSt98eir65HmY8E/ExR6xILEn8qFO8yGGu0943t96YfmPixLzgY4Otnb5Hh758cTxpyLm+w3hdIzV5FMmGh42PPYS6Oax4Hh5PMweBmK6C/XNE6sQ2IRmNosH83WE/OImIcXRpvEc1TGO5B37o+llGMj7nMMAtuOanvexq6uO+cbLXxONL73oQxD9YkkeHHO6eKIPFguSlNh4d93WiD6pH3pMog/51IUfEkBe9XPXRYs+b/u17qQoWpVh+ujHpLeraRrx40Qj+NzxpWPdMeHNH5rY0ytV7alZ7clZq9W1b7mlNXfZw7tj0ulGfb/vcZ8U5Tsx6/oPN8ekU1nrdd2fktUJQO3qn+YPiR30ChIJJEr4IfvIZsrkQ4kWZ9xlXytwkYhCYhJ9DjevVk2Pj6ef0xHx7fHx682cu2PT6fh4+q47Rl6tgrr8a85o+bvP08ZHx/s4oBqgFTZEQndUfLfyqT8uvvnvdlXSep8jEl7oFSta8SP1edUPHliddmhvK/qQfTqynU5su9tVw2lt6oQ3Enxa7tYnjrWrwdaveOEPPzHI7RNx8UcqthAThiAVb7kfprE4wjhSFYP5CK2vfCJPeDw18zflvU6xpx3bWTSyGocWn7UfD2uo+7Ixhl8PofHW3S9PznNzMB0P6qi5UBb4OaojXj7uUIZS95vzuTmxpeYurf3zP1636HPDpfGij2IwVoTAMmEXf/L4t6PkiT9+EQvjI3ylVSP6NMdCJf7YRB/dLQkgr/vlT0eLPm/5+e60KNNJUcofrZihwVHfMJgKhzYMvu3G7phw2nOIToqiE6Nos2X1ubB5TYmEoAf/oP+kKJfgQZsF0343veKjRut1BZO40okgtG9Ms6qjwURxHb39RL+hsr6ZsnqQN73KRt/9yy+f066modeT9BOyyKYu+pCf/gSxRhQjTu5ojk6nDwkvSgSjv4/deWL16Xfe3nNzyUMPtjinGyH7hB/arLr9ULxUjevrgi4mmrirU9CID1r5ROIX5ZDEGYkPCTwfeuPNvehDx9Drnw++/ub2NUQSfNpX405dv363PnGNUvdrV2P7+vDx+ifiYhewwZDbdoBntpDEZ0wtI8/1AMTzE8AZXRZh3UDy/DUGGoKb8eMJJ4DvCw7D0tAu9oRHEYup68/joixaHtZQfsrGOEWdJ+ZQrtL328z4N0vsUVWA56qOawzHm77O4zxsxZ44/tL3vsunvim9kwgP11/06oje4655RBe/WJIHx5y2rejT3xEGcmiIuvqH5694qRb/9Tvet3rc8y5bveFFn4kSfegkLhIxzrl4fALYWXff15z+dHSUre4VorXAsV61QSLQ8SMnVrTR8KfopKjfnZ8URZtRk+DxVc/FTooiTLddf3T0apsuirzqmd1eN+0NaT2WK5FHB2x6jUnf0JhOFutsnFxd9LjxKhjCsK9ZLUOizxkX7Fu/PqXtW9QINYdv7jZS1oWw7hUret1ttbrlc0dXtzfiT3tsevvn5OrIrc0X68/dmv2aiBd10piO3SX6HLn9+OrGj945rOJrYqA46AJuV1Q1gpc6Or49Mn7NkcRrXcQ9rdpp/zR7A5Gg1O6p1O6t1O0vdPxIc3LYZ462/LUbj2uij3oNrUtgI/xY9vYJGV2RVSpij1KQ2CPkbUhhCC2WPvlEC/6DI583vo9QKvPxxp8oGG4kzDDz8WjGavLPrwZm0LYrhOWY1VgGoGYlb952UqziqRIzmDfnYrA9hrZiTy6mET+bU2NDXW1OTEgGl9PmLp+5pmqw19/9VWL48oot9Yk/PNFH0e6PA00Ql/8kK31sAxEJP/q+PhQUCT70efT/ccnq73/zc1Gij+mkqFs+35wU1UzYaRPjfc2rOzRxp5Urav8cJXSok6Jo/xh6fcl6UtT5zetRjbjxyF/CToqi14Lo1Sl6JYmEBfrox6TTRse2/e3aTaO1zxVP+czo39NTrL7sMYdaoeSyJ483U379c+jY9NWKVrDQK1nt61JrgYc2VCZO6PQyEm2U4NEKYs1m1u1rTOvXwL748TtXD35Wt8Jp6vvQRftbgearf+ZLxlolHg6ev3f16Xfd3tbAJ99+W/tveqWKeLmuWTGkRCtdANONSQg9uj1U9Lm5EbwI4//P3nvA+3FUh/57i676VbEqttzkBjYuSXi8kPLSgNCLcQkvCcnLB4NpCSnkEQwkhOSlEZKXT5KXv2k2YEs2zYBlwIRiShIIAQMGbFlusqxiybKa1a/+c2Z3dmdnZ3bOlJ2d3d/uh4vu/f2mnHPmzOzu12fO0B9iKxbpAz4EdmSnvLlBH/0LuPfXE65Bfdv6EtKBN+oDu8yxcmEffswesCztRVQz68fUZlBe72s2rdbVMdfJ3n65d7g3YWCGel8MKgontZnd25KyENhMXoPhqRRtV9dwerrYqPm6/bSD3Lcw/yGneYvb94Afq3bnlqghXm5724SpGfZ5J4xO/exl5fa4oc+OVf6gDxtBU/hgN/I4WBJGlkIDO/AD9XH66Gxloq9X6OO6uC6YP8cJ+tz2qvSkqFMuKU6KgoidNB9MCn7o9iY4JSo7NQte2FnEBgAfdlIUGFk8KQpe+AGMPPsf8SdF/dufLiH5Ysh2JLIlCdpOkzQX0ST7SFQRRP4wiAIJkUE22TMqn3T5kc+toS+Hd35kV170nF9KTxbjoRJ8CYmKoc/V56fRONQeBFZAhE1uGyIbQJvUNlk+IVKGHU1OT9siIIhFEYnQZw7REXIA/eLfprmPxIvagcCvOWAHgF9Ezm0/OJjMWzpBYcrmb8lt6hv08HIpoQ9EgWUnibEtZP/+50vSaCAaEZTBngz6+IA9IJdq/jTyCJU1imsbV0rms1Qv3Ypl9X04cGG+rtlrbN6XifHC2YyXykwne9vZ92liQ1VZtW39aGQuYxt2N5eyXMNMZtve2hqRVN4wOtraJly9/tlB7VcD8AnnV+3eB5rScwA+TVm2iXZX7nxOE816a3PH8s94a4tvyAQ+2AmAgyTNyyGXvk34g9XZDvoYvTDih9YV+qBPioIXepY0ONvKAxEtAEbgX0gCzU5o+v4n7U+Kgm1VLPEwPXqdwAIATLCVip6IJVzSZMr0VLH0RDG45i8lyZTJr2lunTTR9N2f20O/W/uzcLIY+ZL8jyVUvuMti5L9JNoJLoiw4aHPfV/dl4zDKV4EAi0gCZ5Z0mh6ihbYIjtFC2ROgQexDQFfAH546AOQCIARbIeTXWCHOQvTBMw0UoYAJuhj210F9Hnqq/3k58F7m3nJz7xmPo1MotFJRA8AQtck+5PHdu83aKz6YCg+/DbySiI0Wt+HpQQNrQtl44YDF+YvJeZ2M+/DwNXyou08MJrpZm67dh/uy/LKdHXTyGachZmCEgBVyF0YTQtmvmIrTru6htHR1jbh6vXTDnLfGh3Yw/yn3TmWSxGHGB4mlf550UMnQxOeLbDqsbihz/aTmoE+zIxYAGFndj34abZ/vdR28EevV13PWJ2NoE+TN2sV8AEl1yeHk3cmJOmx5tIlDKYnRZHtWQz40OPB4aQo2HUFp0eRf9lWMIiAocCGQBbbY9LpiVkEDsDJUOy0LAAsBx8vcuGIKlHwQ9b5YpsVSZ5M4M4Tj6XJlCHSpHSyGEm0zEfJ0GTKpP4FryxOFsPAsOnVcGx6llea2IKeHJZFvLBj06lNSE4bON3sB7emMAwTiQPgCRIvA/ShkUMZ/Nr6/YMUoMDfnYA+VxPoQ04aY1vSQGZT6IN5CPT6vIICMX56bGZ90L9c69YF0+/N9TC3n3kfplqkJwyGvOy6c5PRrk8Xq8j90U0LF3nSuvZ2aEdye3ltbNWOjqKkYXW2sVOzdfqtv7guxOFzriOKH7O49MXL7WqhpuoPsKcpy4Zod/We54boxrqPbYtvs66LqYgFEJi21GX0kCSMHFUJ24A+TAqdzlXoI1m7QyznPqAPKK0DP6WTojIr8QOUAyECgyC6ZTaJUAHIwUMUrKOyY75haxe0xefHgROzZBfAIbjyRNOQV4dLpgzfQZ4iODkLTheDpMrHDxcjtOr8uTTx8k/8XrHtS2cTaHPnJnJ8fH5qFvkAIFgW8QP2YaCGHR8PkUFnXVHOMaSyC7UDAWiwzY0mS86iiyCCCRJEA0xaflZxYhZ/VDrW1iHKfcYK+qRjU/cQ0sj8QsEeZjVLCYz6MB0hvd1MW1SVN3tAtLRV1rlZX7YahrMdL6GZbl2wY0m70mAEic5DDL+ZzelKhGi1uSLm8rrIMkq6utgpTN2wYx9GJ3E+hQbtTWuJH7N255poB7zcTVvQtP0B9phaLMbyq/dFDn2mm4U+bEx0AMLP2A3HufN21Nk8hz6ui+Tvf/limgvmr3/a9OjqdJFbMH+uNJ8PfIeN9IGyumPSb/9tLmKIra9wUhRsoyJGoMeEk61KAE4gYTNcmGgW0XkhugWieiAyBraKAfRhSaMBrjDoQ0+EyhJMw9HwlWTKkHAZ8ukgkikvOY0kUyYyP+Pt1WTKOvCz/UfCsemgEECfzDbsd/raQMzCct6s/ZnpZM3zHlbOXd4OEO3DoA8AMLhgu5p4gSwsYbSfRcFPK7e9en4p+bQ80kf/wt3I45HQaH0flhI0CnnYGOnt52c0baIjLO2WzRlfclfbCWczvm/7e0asdlSNUCFvLNu4zG1vb3Nffmsus2vP7egcXk9XOzVTv592kPtU32APe87Te0Y7c0y5Uscljt58lRL19xqLBocqLVjgSU88r4Ve8V1unb8BX9hDSR2IcOsi3ogfppdZ5I9eH4y9VDan0Mf15nz1xy/ItiMl5GSsIoKFncwlF7C8OvuCPtDXV966iLycz0q2fi89KQou/ph0yM0C/8GT6k3+T5Zf55LLT6L1dtxzKLnoteb5Ztgx6VMkSmg2gT4AbtiJWLB1Cvp8hMjHon8gyTRE0zDoU0qmnH1H4Q+BJQyyiMmU55LtU1D/F98lT6YM5cXT03i7QMLn9GYPxiG/MBiW5R9iEAzKYEEYzWtEjzpPI6bokfBwIhiBWdD+45uPpMek0+PhU2c/TrasRQl9SKLwhSun8uTTZeijv1k38jwiaVTdj4MEmUtgFhu7MuHAhfl652C3dIlp8ApnN6aEvT5uhrDv18X86nntpo2LTCY+1aaUhY7hxy683uF1dPOhJmv3zxb1/uT8EN3kYBi2jRu78PNLpwZObl0rbX4f/l7eprZ97vtJhyKHPnP7BH3Ak/SgpFnwVO/NbUAfahWJWcb2HzjktHq/4r3nlV7YRdUL8HMi+d0vkGggIsS7fv47pWKwWC9c4CfSBxr++jvSE7PmLipOiiodk07gh+xafs6cUi4dgBAAIGygD+TzmUW2MsEx8Tn0IbCHQg/SLuh8z+fTBMx0uxMpu4Dki+Hz6IjJlAEK0cggSTJlOsBkZ9hz/kWeTBm+h21WcFoW5Bi6/2v7KuAGIlkgykm1AwALenjbMjsw6MOinVI9k2T3Q92DPnweojSnTwrZ6h46nCaZzFmzBjWPot7uq809UOlhmTclNGNU7cdu1JqzFS9h+AdEe73s7Mi0te/X1XPkNnbTxlWmAfjUW7Cd0WnPR939yWcL/bTDaAAf/Ni1M8dUfoqX26en+2wr7DOQT8mHtuQWOPno86M2zSNTtwaVLxxwiRP+mEEf+jbvZXy8Q58r//7sPBEygATZ9Z7/eRf9+HWfujAHHvDCDzDl3b9UwB9f0AciS1jS4PTErPSkKDH/DIuSuejSpVS+B79xgACV9KhudoS7C/SBaCMANLCtC+SgkT4sOXIW0QJw5Z5/TcEPXHXJlNnJYrbJlKF9gGHzSKLo/Ph4sMuV5bw8YvSQDejh/SC3A7HFbLLVLc9VlJ0MBjfsvVsB/BSRPrEmdd5w1bxketUUTeQM43Dh1Wki512PlSOrGnkkkjSq7sdNgmYfosLBCns97Oxn35/5+h7yvyyb62VnP9EK5v2a27GoUZWZ9e9HGxfZ0rrm9mhXcnN5XWw0Srq62KmZumHHuhkd1K3KfSvkGtykxvixa3eOqWyAl79JK9q0rb7n2LQ21InHAqfMxA19tkz0FfowH4grz4859NHrYeLtPPxxivS59C/W0hw4i0+ZUvYP0Oeq9WT7F2FC9AjwbGsPRLxA3py//cUU/PiCPpBDBqJK6PHgcMx4dlLU2svVcOPClyylD9TbfvBEBfrw259MjAxlv/EXS+kx5zSJMw99CFiCY9vFS5pMOTtRiyVTZpFC8C9sYQP9Tn/JI1rRKAwjdoEtYBSGEWgBW8iwyZi1HUgKQJ/QT37c+7wy9IH+4WpSBhu5VXUA+iwip5zBiW4y6OP1kUjRWCORPaioIVdLhoM9TFL8w6DbyOH7cbFhzPbLLe6iYF43jD3VMov9u3mHu0nM7dGuxObyutholHR1sVOzdcOOebO6FK0PsKds6Xbnmjjq3fW5mv9cF5eJQ0203vVzSvKCqHXaMvbp4PKdfeaqSp/33r/NWI6zzliVqOrBd/x17/3ble2fdcbK0nebHlCXNRYyq7D29HIf9z1YnKrN2jzztBWl5mVlfEb+OECfE8kL334m2VJUPnnp8IHjdPsRbGuCSJd9245SuMCiXAD8sNw0LDnx3/7Cd7xBH4gsgYgS2UlRqi1e5z9/SZ7fBwNQTBwATnxa9KSpZA7ZagZRRFu+c6CSV4e1R5Mpy/bgQW4dcjMojppPk02D7cGuZ/7UwmTN87fUikVhGJygBdCHjAvYHsAR5BYSo31M9MOWhXxBi540i0YZQZ+XvGEntmo05SAKCsaSQR/+xDEQ8k9+/Bt+ZOVu/I1AHiZlz2CP+UOg2xOWeX827hEe9oCUdrp1wZ6VV4f8g1hgj53t6ajZOJi3OvZy24jQjq5hdbSxS5g6/bZDv2FPfvtHTyF0wSDO113fG2BPEAeJoJM1E3FDn4dnwkIfAD4b7ysAD7zLMkBjAn7q6pRhUBZQQMCODPwA8GkC8vCux4AP3w98xkMdBnzEz6rgx992Lwvoky5cz/6902kOGfg5+UKSGJlckJgYIk8A6kxCRA8BC7C9agy2NRHgAWXZ9ikoB8mLaRny8y/Pvxt1etcDnziZgo69W4/SPvlInE03rSbROgdppM8cAhfEk6JYRMnW29ck376pONIc2jn3mYvoi47vqBMGfQBCAaRRQR+mhyyZMk06nSVThkTN7NneZOsVg2Gzp8lpYgT6wHYqGAPQGU7QavqY9K5CH8hzBFFqbKveWT87nWy5k0SESZJP/7//+T37243keaAp4BPioSnto/mHRTtd7OSy68vOJUJvHXDXzc6m9oDJzq5prbKsMt3ttXGRK5MO3Tm6oLtQNS24+46NeGF1b0dHG7s0W6ffdqh7KQ/rb82Oosk6E5/e3fTBAfiE8OlY+jh11gtjEUUqx+ZjnySf+wEJtooy8OMD+sijf8hOFgn0YZ81nWcIAI8IlthnbLsXQB9V9E9j4AefyLm6aD3rd04rRa089M39pfEHsLDo5Kn8pCYwMsuXwxL5TpEtP7AF6v2XbayFPldee2YKjAjwOXa4KstckqtGvI7sn8m3kx0/doLmYkkBSnok+12f3p1XWfs/pul35/6aebhZndPz0Afm2F4S+TSP5D8CWe7/ujyZMj1RDFSU3CdMQA/IBVuSLrksPYlMdT167yGaY6nJ6Jvb3wCRPlM00gfAVZN92S5Csno89JmaO0HzPk3MSk9iE08cs4I+AWEP6NfsA1OqTLN9mDywykbU/CE2hD68pCGBj71u5naUjoafZpBTvtpZLNE9TAH8eAQ1nNS+eFmRw4MuFlb39vREGyRIwf7aQfOfV3qqOE6tsHMN48g4uTEthSyjv/eElGboq1kLnDYnbujz0OHuQR9+65YIitRbvqrgJwT0kQEf5nEi+JF5ogoG+QB1kkgfPJF+9htPo/KKx4Dz8Gfhqlm0DJAtGulDQBCNEMoAEIv2uenq+2uhz4vfdRqtB1u3ZFcOfYj4dPsYeSmfIdExh/Ycp30eOzxDc8sA8AEAdIJAH4APD/5HCqpO/8mF9Kjy83+ruufOZXmA4+EBdsBJYgB9Duw8lp0sNkkjbWR5dXwmUwboAxFPfFJpllcJIrBgux3cRAfoIx9lgD6wDY7Zj0IfLj8TO2b+Hy//Ls5NegV58ldV+kvIhzF8X/YPrfg+cEOvLxUOmuUjZ2we4woltcPblHpmxfRMDjdt9COKLWFul3YlN5cXawlZuVHS1cVOzdQNO9bN6KBudfSAD248251zdV6Akz+0H+n6K+zZTfl1+g3f8xY4bf6LojbIQ0/cwsnXXsQPbPvCRvowsCMDPFjoI4v8qYv44XPymGwHw0AfNgCyJM+BoE95kccsTCrow3s7RJHAVTIs8TH4G7Y7sS1ft/3xw0ros+8dK/KtZAuWpRBJvODELpCZjyaCl3W4Du87nhw+MJPMIVubdj90ODl68ASFQPt3pFvE95g4SAAAIABJREFU4Dr54vmNRKCI0Ofg7uMkrw45QYvAKxX08blaAPQB2FVACxKlkiXTHqCPu6Xh9K6dwuld0laz6YV/lMKXrPTHVXVoRWGcdv6LFWY9kgtsbgH7vkz8qd2HQHMdze0os4Z5vyY2FcvqfdWPVvYymtujPYnNZbW3S1qzPV1p7+1272o8b/X7bQf5IIeMtvQ2UJqGcOMYr9Pj5A9lTWw/7d7nsVIO5fxa4PTpuKHPg/t46MN0Dwt/ZHl+VKPAQx0z6JPmDmJ5fRj0EZM4w/ci/BHBTR3IEeV2gT6yPD9F++5jRCJ9CAGxfMDRQZ9rX35X8oJrziiID1u1wbrkdwZpoP8v/d02JfR57M0nUUC09LTZue4AcABkQHLiXfcfzj8XjwRnSaOPH5lJjh05kdzz+T0JbJESo2mWnjGbRv/85FuLLV8+lgGAPovJFjeQFyJ9Dj5OoA/J7wPb2lg+o6aTKUM+n+NEdwZ/GPQBWy1YPtlILiPRdrf/dra9awHZ3kUirS757e4lcpb5gxL6KJ6d9I9U+hIVORqFPKy3sA8vdg94FrazXPts14a2Xibs7Onvxdu+f1tLl2UX+7fzFBdZ0rr2dmhLYheZbe0VXlf7cbHVMd56/bWF2q/aWpdDeAFuPMPPOVPdcXqYttpUef1/cGiq56Hd9i1wxuIXty9EjQQP7PlEzbfuYEHWuHh6F5/YGcqrIm7E5M2qqB4VDIK2WTRR0Vb5pC4xsbMK2mDBjwn0YbbS5fkp29R+jMb27U+hj+v1yhvOLzUBwAeu5/7h6RR20ETELNqB/AvbrPj/kPf1a3cooc/231lCoc/K8+bmfezbfjQ9gYr8QGLio4dI/h5IFs2dFMa2jkHEDySLhi1M7HQuEfrMIzl2YLvXL/z1PldTlOp/9rXZ6V0Z9IGoI8hrQ6FPluwaKvhOIM2EoMemZ9uT6PHxcHIXy0kDtiLgp8n+mRwjA30ks6l+gtlPv3APQamMofrD92NvO36S4vtzXRqyXF2uzRjUt9fNzbb2/RooJy1alpvJ4aaNq0xFfXO7tC+5ucyu9gqrc3j9XO3TTP1+22F0InqYd+DGM+xcs/FcnB42LTdVR+VrTfXX/XZ9eqH967A/O55x0kv8NdZASw889nFEq2aWlB3JLoIdvlNMpI/stC6zI9u3ZZE+aa7eom5VNz7XDwb6iMexQ/tsC5gN9GHtyY9sVw2X2RhBK96gT50HsYggscxn3/0g/QgW9emFc6XQZ/MrF1FoBNBnzY+lp4RBziDYFkajeLLTv+YumkzzBUFADeQLyoAGPaUqO0UMgAf0dfqLt5QifSbgFCsS5fPL/3wAMRHMipSgD6l69OAMOV0sjVKi0Ae2oMHxdVdsNWvYorS41ezi14WLtuGhz0WvfdRC+jirlCJ9hDtXU7CHzZnmLRIW9jB9cA95fh4TcH25WjpmO4q6udk1jD1l4yGHPXSuuA6fp/pmtolDajOZfRgqrN7h9fNhI79t9NsGan8aonvCzjUbr+2Wb9b5mo32o1GnCS80fxX2a+szl8cNfe7fiYE+YJNmLVkHflTHs9dBH9koqreGlXXj8/2I27/4djG5fUyhjx3wYVKZjVEQ6MNEA/gDoEe2kKugD9Sl4IdcfMJo8aSwxadMUTBEARF3Shgk2k0BEYkIItE1kPsHooHu+lSxjcv0RCyT5YFCn2x718pzi0glaAOOl1+wYhY9kazpLV7Qn7jVLCT0+fzvpNu7AHitOGdObsKmj4o3GSubshT67Eqjw3A3L1wplSzNPgSFhxP2+tjZ0b4/c+9o66XCTEc7O4rWMOvT3JbqGlX5ux3d42c8bC0c0zja6mBSrz19TaRspmy/ddfPo7bW52ZGs9wqbmz1Ngohq6wPnPxtSVe5+ykF6ZYezdkzJk8ze0W2s8naVS+1qxio1qZtH1NupyqL0Ky1ROjD+mbHuevMoUsCLQKi8t/10EeW50cnD/veBPpgTvPC9Ysbq8ahD3bRM4U+vBEAAM1fRo7rghPCQG+APpAkmkYIkR8CeVi0D+SzAfAzf+lksub5W3C2NCwFW8do4mSSbwjy6Jz5UwuTLd99gp6UxXIOAeSBPDuQUwc+Azs1He0jbjVrGvpsvX2N1nI7Nh5KLnpNvJE/MJYXkyPvYXxOfvbmij4AfR7NoI9cWbfbHXb+aA1dWyAc7LHXx86O9v3ZWDScHf09KNvZlfUf1r681mrYk8tmM4Qe65jZxm0cXMU2k9W1t/px9Nm6qq329A2hXX0fo6H7EOGj9oJ215o67+ymb+rvRe3P+rASxOthVTvgXpXN7HfWyXFDn3u3xA99VBY3ifSpT/rcHPQB2WXgB5McWnaaF877cJ7sHfrYLtou0AcMsv3ugznwyUMuaNQPAJUT6ZHxGRBiET+QW+eCV/o9oh1kodAHgA+An+zkLAA7IvSBJNQpBMoGC8DPlc1t8xK3ml38+ma3d932qgx+CXZgOkOE0wzZVhc79IExvfClS/N5d8pzHs5/r0IfP7c723mEWxzKr8Vh+kr7xPflbkd8X2ZWq5YOD3vsdXO3q9k4utpWrK+3tR8N7eU2G5t2pTWT1d4mqjnjs0VMW+3pi5Gu2TKjofsAe9Re1O5ag/HubvroAH28eZYPByi9++JehHnfNK9R9eyz1lyKcffWyty7+aPISB8moptVZBE9mM9kyZ2x0Aef8HmM5PpZmZ/wxTTGJndWDaIt9Cn5Yt158krvqR8rb9DHfK6Wl4nphfOUiZzXJ4eTZ7xyBVWR3+IFf19wVQptbn/DgnT7IWmWyQL2mmEJo+H3Y+Q7kqwZria3dNFj0gF0YKEPJKAmEUlrL28O+IDO/FYzsNOoQ5+NN64mwK2YOWsvq9qfT/j91Bctob516guKCLEC+jje9rLqjq1obiL6F2bfdyHzdQEksLeCXX+2Woe3J5PUXE97m9IRcatua2CuXlkAXp7WRcukNLdR+5Kby+w6lOF0Dq+bq22aqd9vO+j9adjGpbdRM55n3mr3fHUAPubeBS9p5r7hpUb+PqyHGPoSaonOPj1y6DNxT1X4+76HMLGdVbBJnuu2ezHh6mAOr0Dd1i+WL4iVZ0e6iwYQc/tg8vnwbYjJnsX6smTQrD6UtYv6CQB9zBZq+WzXQZ93JguSr//J4mThqlnJ5v88QOEPAz7MSJ+5en76ckL+L/23PIRNgh7EbKFFAAjBEe5zl6TbukJGuXz2ddxJYpFAn6e+qp2tXZtuXi0dMhH88NDnKc9dTHMvgW+d+bJHaH2APld/5rzkHU/7BtYFyuV6CntASbN1gTeL+ROBfV92w8YWl/D92tjV3J6iVdrQs5BBDnzctbId+2o9M/vEIbmZzD5sFVbv8Pr5sJHfNvptA70/9RX44MdVbyO/HmffGl4n+z781lT/hwi//cTdmpGHxTDIhpFANpjj7DNeFvWgbbz/IyX5zAJKbCziZg4z+Wz60oCS8CrnSpiDH0/Qx36u4pYEHfR51jUnk0TM48mCZbMSevQ42TYlRsaIx7CD1VZfMC+55Leb3cZk4mKw5QkSGo8C9DGxi8+yNIKHbB2DE9wO7CLhXeTiAaEK+MAJbrC9DnIRgb/THxIp9t2PPZaLd/YvkKTi5IuzX54eAQjQ59UbzqNlv/eJtNxFLzuJ/vuOn/iPqlpBIE/abegHXrs1Arc+qPzDrk8bb0vlDNdfIaN9n262ZRLY929jZ76O+qHaj2au8pn6QxxShx/P8HqH19Hdl3y20G/99f4U+t7nc+x0beHGVm8jXT+hvsfpE0oak34KG3dXBxN9s+dKkypdMEwDEGjtGXFH+my6/6PSUTSDK2FJiJlsJk7Kl1XrFKZ/udw+wY92e5f5nLW72eigzzP/6ORk3uIJCksmyRHrk7PJfijSlSwHDn88+MyxE8mqp6SnZsVwUlTb0AeijCCXUYjtXbbTzqXenf+4nAIfSN4tCyGdu4R8yV00cof+kOgw8i9c80gZyDUEvjNDtgPeffuevMaZP7OQlnvyb2ynnwH0YVsP+XbzHEDER//06SQKKAjsaQ9MgO64tcJufRB9AteXiyeV64Z8iXDXrZs2Liyu9mM/mrn7hdkYxSG1mczuNmojhj+8jj7s5K+N0dBfPZ9CrtP+Rs2sJdwYx7HmYDTD6YNpKVSZqm27p4O5rVAelRdClTYXIlQNxDawOuRxZuTQ5z4F9GHmxQGOsNDHTDZXR5HrhrOLa9/q+j7gTw597BctP5NbB32e/daTkzkEVgD0mSAncAH0gTw4/IlXmNOi2gY/t7063WI1lwAsiES56LXhtjd97vVwbPosCn0AXKx6cnGEfNt28TFNvvEXS9PT2sjJbXOmy3CHtU+hTxbFA35Ek0qTOsdJQNATj6VRQZDnB6J+APgcO3wi2fKdA7l4pz19AYUbMH6wFUwFfaACywH0zp/8pg/1JG2oIyEa6rDUrNma4bZOmPXlqn27/wXPXFc32zJrmfframexfpywx94ufsbF1sr2ctv2mHuSawPG9dvT1VjURiqMhv4D7NE7T7trjl6+okT3fLbO/0w0705ZnDfBA3V3dDKSFPGWL8MDZ0QOfe73An2YJcPCH8SQGA2xvLBepzBylKUzhz7VMRrbu++gwXQ1KGpg9l/5u3OTW9+6Ofnlt52SLHpHFYJAIufn/PEpydT8cfKynUIf9gPwAqJ9ak+KInAFXuRjOCkqNPSBHEKXkCPH6y44Nn3m6ImotsEZuE9e9KtvW0yhD0C1uovBnhz6wMlqxKeOExvs236E/BwjsGcmOXow/YGIH3atJFFjAISWnJb28f7LNkojfeC7Jz9nMb0ZQjLxv/z5b9mopKgTPqLH/gHNbs2w78/GzOHtyUtpr6udbUUL2fdvY+uS5qUGZHL40dBNTnP7xCA1NvLOzTbl2uH0Nh8Tn3rG01a/7aD3pyGyh/mi3laxeG13fXa0InxQHtXdwTSbDoaRP6dHDn0e0EAfMA4eaugBiZmx60vj5XLtNb48P/bQh9mCHBqFhz6oJcDKyle865zktj9+OHnO209Jpv9EDn2e96drKPSBKJUB+uDNLDtJjMIOCsIKGNYH6PPFN01T6LPszDm5gSBaB05Rg3xQ8O/erUdpBA+v/8Ss8WRyioAf8gMQcd/2o7Q+5AES80QtItvjoP6TnjqPQsTrfmVj8prPPbmUQFzMAQRbx/7m2f+FHzRlyXYiUOzv63Zrhn1/tibOEr/bVneoZ6ernV0H2GM+UObj42dszCUV8EtwMcJ2aD4urhaNr35/baD3pQH28P6ot1cs3ttdny3buLt66D0B5U19NoDKRIjcP6zIaZFDnwcR0GcAP9QCtRMmHIAqxHADP7XQBzX19SuIpIS4XlzxN+eQ7TXk5Zzk6oEX8zlvSvOlwLXnbcvpSza8tFPos4Bsi8oiM+BfuGCLFybSp62TongTwAljEIkyZ1GY7V2jBH3gdLJxsrULknfDtf3ugynMIVAHgA78Drl+WJJn9jv//cTUOP0e4BBcsB3s7s+lOX0ueOESSr8P7T1OonfSPEC0DIk+Y/l/ZsgOsY1f4HIA/TTJAUSKvfv537aaK0Wl8NEo5vd1P2uGeb/2pm3r5cFex+7ZuDw69Q/PfrSz9we+ptkYxSG5mcx+7JS2Ek7/9nT0aS/7tvqtv96P2lqz7UfMvCZujPW2Mu+5uRo4nZrr367l0YnuQXlTNwfRbuh1tWqif06NHPps9g59wFh9jPjR69QG+KHWtuyYi/RBTXndNKh8r1sjfuXdKfCBcrNInh6APrMI4Bl/TXok9u5rltEXbTitC4APgB8WpQERKxDZwbZ4GQvXQgUGfSAnDOSeCZXT50v/e5raEOzLR/qE6r9pU0M+p2/ftIt2c+rTFuTdPfTN/fR3ADyQAHzhylnUf2juH+JYYwTwTNCIp3SL1ySx0RSxEfy7Z8sRCn1YgmdWDsrCVjDIAQQPoNAegEmIljpCtoNt/8HBvP9T/xvJAUTg0D9ceqeBCUYjoocZRLdGGBgOUTQ8POOFstfVz/ps3z/CtKgicvv70Q4lgLaQnY3a1cBOZq0pEAXC6d2ejggzBCgyGvqr/WmAPfkdM4C3+e+im/7bf+iDWsG7OXj+nVjWouTle03k0OdhJPRh6uL5gh6S+B4UvGw2Pev1abZ/vcym8IdAnydQc17fdVrCdm2AaB92FDu8cAP02fv25ckx8iI9SV/Gx0i0Txn60O1JkJeXaMAndMbK2kY5HvoAGF15br+SKatsCgmPxeudSQFnXMYCtmDRY9KJI9z50cek0Ie1P716Kt2rSn7g33SLWwaBCISDaCBIEg7gERKHw1Yvtg0OIoIgNxTAHwBEsL1r77YjyeMPH0nz/xyaSY6TxM/8teI8yAF0Irn2f30foWIXYI/bcmG7PiCMpyjSRcjjZuP81cBPM/aml0R/sPFvXbRMK3t/bFcDe7kdhjO9w7s2YFy/PV2NRW2kwmjoP9qwx2zNDj8HfTh2N/24nWcyH/bWtYHyom4Omk71Zr7n3v5PiRz6bDGEPsxgeMChhyW+BwEvm03PcR7lDpoEhz6+1oRF0/OSK5LZpdF4/K3L6Is1bPsCEMRys+T5WAjwgRfy2KEPQIlLLq9PpvzovYdo9Mglb9hp45FR1ZEBnuuS6ZKMG0hybkjQzV8qCLTp5tW0GJyWJbtY3p0LX7I0/xpAjOzauelQ+nE2h1MAlEKfCdj6RfMdEb8ivwP4gcig/Y8eo6CHRQXBFjCaV4oAIrju+tRupf0BMkEi5w/9zg8lZboEJFCPCFo/9LVeaDvKCrT1X4fd9OymrYsxUf/XUT+aYUdfX858nOLQwFxuvS3qS4TXO7yOrjbyU3809Nb7U1trt59RNGsFN+Z6m5n1GqY0TrcwsuB7GWAP3lZDyZIFyPvEyZFDn0cahz7MIuHgT7PQR69PmP7Vcw0Lf4wjfZpawGXQh6kHcACAwL/+7sJkevUsssVrIrnoNeGOOndd0gBK0G1r8JPBK4AL+XahLFqpi9AHA3gw9tswSSDQsSoEYsCHtSEDP3yy5fNfsIRux9q/I83Jw1+QmPnzb1yYZ6UHX+Ynav43WaegDfiOHQG/+JSpdFthBhrTHEFkGxgBkgCAvndLFfzMJsfGQ5TPTdfcU5KjrYdZ+7nr9rBp3y/Gc8QyXQJpvOxuNmYthbW1bHzq7e9HSxu/qNYxs1UckpvJ7MdOoaN72tHRl63c2um/7vp51Nb90W3k7Grjx1tvNzsJmquF1605GexaHoCPnd2GWswCq898WdTG2GYJfZhSZoAjHPgB+cxkMx0mvS7N9q+XVwd/0NCn6QV8gD5J1JE+MrgD7idG8OhdEldCBoGg5m/efHYp4kc8Xeu8Zy+meXYA2hzaQ8LEsguAD1yQ7BkmBX2wzO7t9FdSHkLGWP4eKAtgB5JuA+wRt4PRHEDkp4B5cvDzif9zb0nhNh5o7eeu24Omfb84HymXavdBzV5XNxszG9j3b2NrWR09bPOjqbu85raKQ3Jzud1tlbYQTv/2dPRlK7d2+q1/vR+1cW90Gy232rixDjf33LQpauP08tWb73bK9u62LtyYYMzUF2UxujZcZlXk0Ge7I/QB85nBDT0s8TkkZrKZ9qzXpdn+6+W1hj6h5z8K+vweifRZNYsmdL7w6u5E+rAh+tIfFsmUS5E+JE9MDCeLMTl9Re+YTiVdeRkIevWG82gS5e9/soi0Oevnpim8gYdIiKxae3l5WxicaKZ6j4Ek0Cz5M8izkPgbTfic5QFieaRYEmjI/wN5gAD+zCY5gH542+NJGfS09xBhPofdHjDN+9ONeN33esjg0jq2rrnObjZmcpn3i9XItJx6HPxoaipPtby9reLQwF5+V9uF0789HV1t5Kf+aOiv9qdRAj64sQ439/x4cNoKTjefPfpuq73nNd+a0PHANNr9QcNoGbTMysihzw4P0IcZFAc49KDE5wDhZHLtMc48P2jo0868L5akRdPzKzl92JDk27s6Dn1cXayJ+rECHoyuG6bIlrAj5S1hz3jliuSMZ6THpEPSZRn0gbb5CCH+tC+xX8i1VFpAsgTQ8CHd6kWSP9Oj30lfUyQHEOTw+atf/M+8mZDzyr4v1KOBckjs+8WMslimXdjjrqubrZk13OWwsT1fZ4A9rhbU1W9vjP34qE6/frwkYrQsl2lvXM1ldauh96MB9sjvb252D1+72z5d9dNu6zPAnvAzoNzjisihz6MD9PHoInHBHy302bPX7+ldOEtWt2IsXoSDPovISzUc297FSB+cbZopFXp7lhctpsxaocmhBQgELfzG+rOlp7sx8KOCPiwHUIngSJIAwUczx4hP0xxAY8mR/ceTj//5RjPhLUrbP5joH8brxLHv10LJwvj0t3b6dunXzdZM/bb0LkZM/19A/Wjq4iOuL9dxaNDeWIfTvz0d/fmXaUujo7Pcj0YJ8Mh8o378w809U7/Vle++Xw/QRzfGw/dmFlgWOfTZ5RH6MMvgomtGK+LHzDZmPqYrrYI/Y81Cn7pw3rLIGOjzhd+H7V0D9NENdmeidwyhjlJvcvKW6towUwVB4ilhX3v74mTRyWVh8hxAr52fnvRFXDl/uIHfyYlcfP4f6D8E6LEDH34eKMM+3LUb0eMOW7poc/U8qnth86OpblXTf2/vn3FoYC+/3jb1JcLp356OrjZyr99/3ev9aFShT19hj/s90n1OubfQP+BDnxFrDQMPsO6WG1pQW2CAPjrvCAd/cDBKJ2/d93pdmpdBLZ8IfxqCPnjYw0QdoI+d03UC8LjAnRqgo7WYpO6GEwQCHSxvCXveO9fQo9nhJC7THEChQI/dA5afO3v4l5UuAx8/NreDe9oZYVWgv8DH31hZGZarFH6O6V8NXHUS67ejo28t7Nrrt+76eTQAH5nf6O1m521ha3XXt/XRq2Et6ae3Wq/q7mD5MU6gVpZGHumzu4FIHzCtGdzQwxJfw2Uml02v9bo033+9zDz4aQD6mC2kb/nGT1Bp//GZP5Tm9GH5fKDMqEf6RA94bOGODdjxVGfD8SoE+o11ZDvYlVtp3p+LLzuJ+ueTnrU5zwP03GufoJ/BeGx/dI/NCoGqY39/9vMwad8/Sj1JoXZhj7u+XbV75fW89AGzix/tbH1DXs9+zOLQxl5+FzuG1b0dHV3s47duf/XX+9EAe2S+pLebXw9sprXu+3UxDt3XRRO80wcFm3HjRlpdEjn0ebwh6MOMiYMc4aAPyIWTydUd5DqF6Vstu0fo4x4a+bI/Pzs5+Pgxcjz2OD0B6bxnLkp2PvO+XPoS9PkDsr1rZbq9a/lZc/Iyq5+52XWkoqofff4dG7jjCdLUDpRpH5KZuOH4oWT9E+VIoKs/c16+teuU5zyci9AU9DG/P/t5iDTv12XaxPPAZae3H5uDBe36d7G9qq4cuvnT1J/M9jaLQxt7+V1sGFb3dnR0sY973dHQuS6SO6yPuY+YnxZw494P2+B09WPXZluJ5xnERc8hssfFes3UXRw59NnTMPQZ4E+88Mcw0scd8ohT7NI/Ozs5tKeAPrC9ZtZckgz3iRny+fHky/93W/La259cOzN33HMouei17R/hzkeGgMAQHaK7ehm9YwJfTMqCMU3KY/GqBji/Ym81mgfyAvmGPuYPU34eIs371Xl13ffxPGjZ6d1Fm+vGa4A9Ogv5+t7O51x79+OzWCna0RErXTPl+q2z3n9GNaKHeRNu/PV2bMY7/bSK09FPX2FaIXkZOzwk9bAn98wwphx6KVlgUeTQZ28g6DO68Cfe7V4K6CNfTppYIHXQ5/jREzQCiP4QIDQ5B47HhuOy038nyA+UiQX6gJNfdOlS6utgLz4yBD4TIc91yXRcy6VJFI8JgDEFNti2PYEdOgjIaEO6JWz/odK42Wzzsp9Pbk8q9v26uqocLri2iqnvrrObzXkZ3WXBaKwqowf3/jR1kbNc195mcWhjL7+rDcPp356OrjZyr99v3fU+NKrQp37c9XZz97zmW+inb/cY+LCXj+ZdY+hBYYGFkUOf/QP0CbDdK07wI0CfurDdZuc3n8j5if+zIo/0iQn6bLppdQ4G1l62tWIQdgQ4++KpLybwh9wx1zx/S142qq1bJoDHBNpggQ22zdBgRwd/hO83HCMQaJ8ZBLJ7kHJ7iLTr08e8bw/2+Hn+cbM7s2B79s8lKA0mL48fDX34StqGu63i0MhdD1ubhtO/PR1tbeOn3mjoXfdMGM7H/IyYv1ZGAfb4WYf92dxPS/FEGtvqo511tIC2lG33Qz2EBRZEDn0ODNAnAPRhjqJ+ocS+2iJcDl0kgz7tvpSBtKrTu7ZcvVga6QMRPmMk2gf+Zcdro7W2KLjpZgJ8hEsEPyL0ecpzF9OXlzNe+kheE6DPlcnsoqXJ9Nd1BByIVyNRQFjQgwU3vsthZoEhlJEOt2sbNfUpBNorh0BmLwpuN26zviwmhbJK++uJ2wOrm91Fs7Q3DkwSdXSPX039+JCbveLRyE0PW1uG1b8dHW1t46feaOg8wB6Vt4wK8HG7h/qZa35bKft0V+dx7Qo/AB+/LmPZ2vzIoc8TUUIfMLbuxcxyQCTVMK+aHntTNhVWDmLhPXsPRBGZq4I+fCJnfwNQbgkieNiWsX3bj9IveZAkAz4A0k/MJPSUJ7ge+dwaCnju/MiuvPFzfmkRBe6sDHyhgj4y3UQQZAWBsJAHBMAAHEwZTFsYT9fN/za/r+tbjAQ6SiDQnjIE2raj7tQvtxe3th5m2l5I3PV2s3uOWPw042G5U8O3aESUaGk3ju1qZCezhyHOmwirf/v6+rQdrq1+66z3n7bXd9woNVdqlGBPfPcyH+Max3+MctWkHvro57Fr/0N9vQXmRQ59DgaGPsximNe+tKzu5U4/BtgSeJmwLcrK6fUJIwex7ON7DgRfJWQ3zyWL52uPbHcxuar/EzUYAAAgAElEQVTu9/7fcgp8AOCI19wlE5XPoFz6k+4Jnr90kv47c5z8TX6OHzuR3P254oX+zJ9ZSMHPea/YTtsygT5Qnh+c9UI0kBICYUEPBuD4KIPxZt2cMIAslUGzrdtQvQ1HCAR6XIRAj1u7d3svI3E8RLnr72cJdJfD2gWEit2BPfY28zNm3izemjhhO7YfL1+WDt9Ov3XW+88AezA+p7cjppVYyvTH56vj0lXdamLvht1csUycTI65kUOfQy1Bn9GFP7oX3FBHygeGPnWLbRvQ55t/tTQZGx9L5kxX4Q5zTgp+yGoL5Wji6FljFPA8sesYLTJJkkvPENADn9EfklR687cO5EvQaU9fkOan4Ffsq4ocP0m2vUu1ZikXegJj1hN4IF7XTWkSQ/uAOLo2dJDHFqaAsrZ1fdfz2B6FQLsLCLRtBw4AhX14KTwxbL/qu7m9HH4f0O3l8PWkUtaHl8evpr7k7U/OHgrmWzFy2E7b0dGfv9m01G+d9f4zwB6M1+jtiGklljL98/n4nltMx7o+sofegUybHMo3bIE5kUOfwy1DH/oqp+cgmhc+v4OIk8e1z/bz+zQa6SPeQN742YvpqVtPPJYCE7j++fLv0X/bgD5f++PFFOZMr5qlHEk4NQwefiB3EIM+8C9ce7emW8H2P3o0OXpoJv05OJMcP1wswqvOn0tgUJLMWSgBSwB/Muiz6JYzkj0vur8iRx30kQktgiAKgXSQxvV73WzxCEhynVVt+u7Lpj1T2YTyr9ha3volQqB2HszaP+3CXm+/D0X2crjeMMT69ZFWfrX2J7u9/eLSyF4PH7YMY4t2dfRhJ/M2+q2z3m8G2FPnM3r7mXtcHDX65/c9Bj65av31xzhmhZ0UsyOHPkcigD5gWd2rY2p9FB2yGyhJLZxMrt21B38agz78DeSVHzo/PWKd/Miuf778uwT6LAi+vetL/3uaQp+TTi8SK0/OHqOJo6fmjSd7HjlKt2ulSaOTAvxMjSWTU+NEnyTZdf/h5OLX76RqiYmcl5w2m275ml6t2G+VQZ+5N5xKI4hymPSSB2h72uVcB2tIGxUINCeLBNLVrfu+blbYQBLdvDaFKHXtmbZlqo9p+6q1I7P/hoMkCuix8lawrdtxkUCuyxKr3/ZLgNvDqHYWoc3kJge6G2TBeuCDWj+QPfkqZm8/f2PoQxd7PXz0HmZk29fRl63M2um33vp51PZabzZafkvXj73edn6lCddaP31ef38MZ2H7nqReRz/srz/aWyuemrMihz7HIoE+9FUNzXTQBZ0dAS+TS1ftgB8v0Ed303jFvzyZwJUkmbtIvZdp3VX3BYU+n33d/GScAJ/VF8zLR23X/YcIfBlPJijUIT+zydYtkruHASuAPDTaJ4M+AIgmCPxZ87yHaRsi9Jm7ZJJu+Vp57lypZ4BN+OghFk0E/cBR9fsue7Deo3TghtXmgozWE4hwxdzZCfzLruvmaUCQb8hjClLoyqAwRYi2ZH3YyCOqgB0/Tn8KgXYdSq5cNidZtzOFQf4hULsPTLr1BL/M+nsw8icTXnp5SfXY+NPWVcZyfXvbxaGRvfy+7BjODu3r6stmZu30W2+1/4wy5OE9ZBSBzyj4fFd1rN/SFe5+YLaKDqWZBSYjhz7HI4I+zGY40BIO/NDXrka70zfeRP9G0Md2AX35u8+lx6vXbaMKDX0YoDn1aQvyleqhb+6nvzOwA3BnwUmzaJQPRATBANBTvgD8ZPAHooLoFjACd36woRyBAVBnzY+n7R/efzw/eh6iiKDO7oeO0GghdvR8AZRSmHT8yEw9+MFCA3XKIiobD4Dg7+sWEAhkA3pMQUjTwMaHPKZtyO572HFS9iX5IvvotoOHknWPukYCtQt5mMls15fC5H4ehtzl8PXwU9WHyeZHU19yKvCUtZDWFRtRqD1/CGeH9nRsZMjQjfZbb73/jDr0wY2/3o5oh4uoIE73iAQ2EKWrfo3ytD4PnDDGKHvU+IX+tdrAqQyKTkQOfWYG6IMazSagS7XjsBE/KOhjtsaUp+mlf3Y2jahZtnZOrusxAjPSLVQT+Vaqf3rWD4NG+sigDwjIwA/8DtuyANzQgSf/B7+zaByIPIEtWRARBLrMXjBB4c0Pbt2djJPPoezJF87Pdd5+90Falo8kYsfEM6hEQRKpC7CJRhORSCM4KWzfyx5QOygGKGigjxhFs/6JcoLo66bJ0fOyyxSINFneR9smET2B4U6puxo5bztwmECgg3nx+iigrsMe10eC8iCarXOoe4ZlITXsYQ361dxSTPEBzVko5wb8KJK10p4/hLNDezp6HSrjxvqtt9x/uvoibDy4iAq48Q83DxEieyuC091bd6001FVfr4/wifnu72eYQ864JoHQeOTQ58QAfVAOGwb6MFHCwJ8c+tjfCOqn6QuvWVvZRrVzE9lGlQEQCkLIz8d/90Gv0GfzrafQKJqTfzndesVfm25enf8Jx6tDtA87pevg4yTrcnaBnAyI5OCHjEsKggpAQ7d/kZ1r85fNoieB3fWp3bQFWRQRfA5wCLaGLVw5i24dg7bT08GyKCMaRZRGA82aAwBpLNl76QNyJ8VAH6hZB37qVj/S9/r95UiS6xZJIJAJMDEBNK7tuvYlszrW5lLZ1VE7pa6wemvKveK+cvTZ1u27WzptqNDOfq1p5qHHXR7U/QNZSA7iQj4MIQXNi7nbLw7t3PUwtZyqfPP2iEdXXzbDtdNvvYdtXDovGMVtXPlds/llRWf+QN+3f+iEraLSIco/7N8AxqKRbwA0dualti4Qpt79HwvTj0UvONDie8TUguLksVC0UkWvkw9ZKPSxfxDST9nn/cGZVDUZAKGRMwRuwLavT79lsxfo88P3r0y3YBHIcXg/CZPhrguu2pHwwCe/GZJiEFEDb8N8ncWnTCV3f56cpMTGAtQFQEN+mM1SGAR1sy1gRKeTzpidbP7PAyWdoS8+imgh0RnAEaufQx/YRpbl+oFIHwBiEEUEMOlxyele2pO5mJIO0Ef0zQoEWsxBICysgEaxZbHlXNuUzdumAQ9WN0Q56YLA1duwj0QBbS+igEDdR7algDLEZb/O8NLp1xwTXfzIZNKjqqw66sqvxj5kLdpwt18c2rnr4cuuzdsjHl192QzXTn/1HmCPzgNGGfaAbfrr++LIxxG9rPNH2fejBHyav8vZjIDHc6I6AH30iMHOhj5q4eBGWA1wMrlor9fHhwxjux8/gJx/yGKCzjLoA0VEAPLZP93iDH2+9bcnpZEzBHDA6VriRaN52EXUgUgauA7uOU5z8sB1LDtuHSALnNz14H+keX4oGcugD/xLIRG5IFEzS6T/3GufyJtXbR9jBR6991CRNocbaxb1k54YlsIr2PI1RcDP4pOn5BE/GDBhuMUrV4RAKOnFfbx+nxAJtNRgOxgCZtD+fZeTKYWxo230jkf5KxMf27agM4VA2woI1CQAsnvotFtz6pZdOznqWrT9rqybTC7/2tvKWq1nb8e4tLLXw5ctw9mjfV192cysnf7prfcZh/+SZ2bcyEvrx15vy8hVrBVPr3+XtZPdl7o3nvWwh+nYPb340ema9PrX7/p5cyJy6DNGIn1cdQyxcuAgRzhNcPLYWkavh4/+a6CPv2kK4IeP9BFNAtuoPv+XjzhDn3//syU0SmY+Sb6sumYvnCDAhpzIleXPoVFBpA6clnVg1zEKF2bI70cPzSRHD84kjz14hP5nEnrzlJiEBz18nzrok5Dj2re9cWkpaoiyDYgiIvLRHEJZRBH8TRNJEzlX/P1jVdUwsKJB6JMLlPns+r0CBDrJIhIIAzIwZVSOgLEZBvBgZMCUoYNfFtYX3Kms7qI82d+//qPyVjBbCOT+oOlv7XGXxXYBV9XrHuzxa0N/Y+syMn51spEknB3a19XGPu51+qv3ENmj8w782IebhzqZfX6P199nr222NUT4tGl93NNOjBLWy6R/DZfXPx459JnoCPRh1q2HHbajZO6PPqCLvle1Pj7656BPczc/VbQPU37bDw8mX3r3Vmfoc8c1iygoWbJmdm5X2KL1+MME3HBXegJXkZQ5TZ5MTssisGfv1iPJ1rueSI5nET+yAVKBHrHsV966KNm37WgJeMEpZVcmqXxbXrc4rQLBQpn52TYzFkkEX695P9liVndhAAbUt9nihYj0yUVTwI31ewQItByRE8gSlEjNhLFPSMCjgzughALM1PqBrk7le4nS2UcbyJit22K2Fcz9QdPPGuQuh35ZNi+hfij1o7W5RNga9vaMTzN7XbDW0pULZ5P2ddXZopnv+6e33meGyJ7sUarWVHo7NuOR4Vvt3xyos2GPcvjkLtptX+229Gpfw+KFLkAfpiVWp/CrWNEjDnaE0wQnj6vFmoE/BPrs9z4/ZTec57+pGu3zT5d9N7fK0iULnKDP59+4kEbCrDx3bt7m/p1H6TYvSJo8ixyTPkW2c0E0D9s2xaJ9oAw7NWuG5HE+/cVbaBssWoc1uIAkXgYY8z/+XANhsgp3vGVRMnfRBE3wDDJAfx+4YmMOfTa/alG+TUx0Dy3oEStgwIYN9IF+ZODHAcpUINAKAoEw7WHmNMYONoDHVj4d4NGBGtm6oaujgzsWumx4nGwFe7jYvghRQO4Plt6XHg8yuS7UrL48ose/xr7kLbcT49i6aOquj0vvUDfcyLevq6ut7Or3T2+9z4w67MGNud6Odh4XXy2cPeKT21airvq/0iM7Dn1GZabpXkWORR7pM3kfSeQsvpvYTsKA9XCwRTc6/gTGyePSX70uNv17hT4uNxxX6HPbq+bRLVCnXFIck/7wdw7QY9JZQmQ4Ln2KwB/I+cNOzUqjftKj16Hc5BzyPQEHp71wSwX6wHew1erZ/3gANYpffdtieirY3EWTUujDGnnolUXky6nXEqBEopCMF08M7PC5xUvlizogAUoLZdY/LkQCrcrsgZm7GL0bgCCYSBzt9iydfjpbtqEX6XPDrhQAXblmXrJucwqCtmw1TQht7OG1c85l7UFNZnShql68bH61RguFLuhux7g0dNcHbTpFwbD2aF9fV3uZ1++nznq/6eoLr/kIy2vgxl1vR1/ytN0Ozh5tS+mv/676vz4YrZs+202p3fxR9Qh/JHLoMwXQR/IupnslsbXWOWuLE7P5Nu7ZtFXbpFh34336OvCSefaZq5KN922Ttg/f8ZeqnFY4eJ2tMdpZZ5T7uff+qjz6MvpRMYE/VtCniZuLK/SR5dDhk0XD4MFWL4jySY9cZ8ekp0evs2PXp+ZNUDAEgOd7nyjnz8Fu64K+YGsXtDlvySRJwgzRRuSHgCWIFDp05UP1vtQU9IFebaJ9XLZ4WUSVrN8tQKDV3HYwHeTxEcVjCFu0cEeyuFYcwLDPykpjXF+QgK+vW2OE7zc8RiDQQ0UUUD0A8vNo0MQahFng1WUKvVSy+dHcTUqxtj87xqedP91sbR7OJu3ramsj+3r91FnvM1192bUf6XJN3Ljr7ehLnrbbwdmjbSn999/VeVAf5dM9v+2exH59Ufa4HD/0+SjgitQQEgV0rwCmFgRwgwE8YrsM+PB14TMd+Dn7zBQyyWAOAz7sO/FvU91UwIXBHB70wGfi39BfXRnlIImvcMhBM4I+Td5cmoA+vE0AAM1fDsekp04O/9JoH0iQTAEQHB8PET/pMemzCPSZt3QyOe1F6VYv7AXw6eLLTqLbTODkL9jeBdAHwBKAH7gOXaGBPqTMCQJ+jC8dEIEGOwB9KpFAjwkQ6OSaxNDiDHSFIZJFsdQFBmqJA1kHWEyjd1z00y0S2raFAtmfv/6tMizdslWSfNzYudMKTa5BliKBVFLZuvAwZG/PeLWz18neA8o1w9mmfV192cysnf7prfeZrr7kmo2svnT92OvtqO+hGyX6Nwdwdu/qPNBv6aJPODgjRFSqexL7NZ7sMfpQ5JE+c+7joA8zR4PwxwX6yGCRDvzooI8Ig+qignTeUgd9xMgeGfRRRf/IPpfnQUklxEb7VKBPWzcSV+gDSutOzNpxD0lMy+AmZ6H81wwGQTQQwJ/ZC8kPOSr9glfu0I17/j2T4cKXLs0/2/PIkTRnENleBnBJB33oItoX6EO9UTCf49/rdxUQ6Lo1WTJs1cLl2Jc2iqcOnBj3LYcoufWMYJHG5vzXWjm5AqKImrq3PkoSQj/ARwGZAaC21iP1hFdv3+rCw4+7PePS0l0f9NKOKBjONnHpjTCNhyL91FnvM119yfUw5LQJ3Ljr7ehLnrbbwdmjbSmb67+r86HioVKXjd+P45ewOd/Dthw79Jkrgz6SdyjdfxfG2sMW+qjar4M+DPhAXVWkj0/ok5uNM5YId3g96r5j5dRl9COigz9jj+32n8hZ7wjVZWPpkoVOiZyhzzroc8FVKbj5/O8skD5IsNOywGAzx0+QH/KwQf7lt3Tdu241zQcE19rL5PsK+eTPT33xUpoDaN+Oozn0GSf1dVu8BugjeFANaFi3U4gCOs0AAhkCDGmyaV5UIyijBilGkEwHbMTJWCujGjrVwi+dDNz3v/bvuCig+B5s5dE89KVEv+C1XsLdnnFp6a6PzyEJZ5u49PZpQ3Vb/dRZ7TNdfan17Q24cQ8393zrZ9sezi62rcdfr6vzo+vQZ/Rmmv1cOBh5pM88Cn3YpQAJEARhb4JSzSagD0QAyQAHQB/Y/sX+TQUpNJFF9agiffjcP9i8PyDTAH1Kwy9fOnxAH+jmy3+0KJm3eCJ5dOOh/Kh0Bnzg+8+8Jkv0TMQAIENf2kieHf465xez06TI12ddmcKdTTfLE1GJ8IeHPk957mLaNtykjxw4nuYOIkmj4e+6aB9r6AOC6rZ4NZ3MWbZKGEABYX6K8zX9ugZcrCORJfx13RkcBKqDPDoZxcUvBODRyVS3ItfVrdkCZxTZVNuHYDC+4azehm0Hkxs3laOA4nmgVUf0MM268BDkbs84tXTXy8fTTDjbxKGvD5vh2uivvvU+09UXWtyo4krhxj7c3MNJ3WwpnE2alSGG1lM7dG/sB+ATg/eEk+GJyKHP/BL0oW9VcuN4Aj+yRM42OX5ASFmeH/Z6wYMeFfSBNnjIUwd8eNBjsgUMysq3Z9UDIZBNlguoPDg4FKeK+AkY6aP+L+Wg0ElL3SN9oB1IoAzJk+EHjkmHnD0M3MD34jHszJin/fcFyQQBMrC1i/5L4Mnay2uAD4VGKRTaevsaCnLoDYn8350fLaIZACABXDp+9AQFPvADlxb6QKHYt3hhAI9sPTGFGSawhl+8SL11O8iWPu66fm0GgXQy8JVs4Yaou1E7nAC6OY6N3jGxIxZqVXTiPjCEUr/2lV2lsXr4EbOtYP5u6eVHNNkDdxceO91fFOLU0l0vV08Ja5f29XW1F75+v3XV+82oQx/c+OvtiPe4uEvi7BG3Dr6k6yLwGWCPr9HvVjsHIoc+CyrQR/aiRj5DPs7bjI5t9I+qHoNBLMlzGfqU9dOd3oUFQSq9WX0ZeNFt79J9X/SpezGU5/lpAPrUhS3LTQQ1lnmCPl9/x5JkLon0mbNwIoU+BOKcdYX6iLc7/2k5SeicJnUWI35AWjhynb9o5A79OZGXn0fKwHawmWOwLexEcvft5Nj17DrzZxbScjRZdAaU6ESCaB/FKV65BfsKfWTriwEQqU+krFilso/XbS8g0PVnC1vB2KChgYdIUWpADbrNmuWziegdrN09wp1cQ36ohPZvfeRQcuPGA3nRMABIDaa78Jrh/oIQp5buetk8kqjqhLNRXHr7tKG6rX7qXPdMFM6fwoygXS+4cR8dW+HsYWfrrtbqIhAteazSfeP163gli9uL90cOfRZKoY/kxUzCFVSowSaaxwT8yCJ8mBfw38mifnhvSWFQ+eh0EfJgoI8IjqAP/kQw+N0E+ugjfFQ+r4Y/sv49Qp/6SJ4SOJHI7gP6wNYueuoWgTBT8yey07hSmMNH+7Duv/EXS9Pj20k00Jxp+b4nCn2ylY9F6oyTOhC588RuQnrINQ5HrAP0IcDn2JETyZZvFy+rpz19AY0AguPaGfTRHdleWmibAD9dO8HLJEJFhaYl0GUd2V7EX9efQyCQZdRMfT0FDDKMhClgiRo21QIxG/CkOw1NBsrEe0cN3CmtigoAdesWsg3s7iYBkHzt6sIDj5+Xgzg19aObj4fDsPaJR28ftsO10R+dcb7SxRdY3Eialaofd5wtzXqMu3R/5oE/Oxc26Y4/SCXFhf34M5yHlrpjcQ/KemxiX+TQZ1oJfRQP9Abwx8SMWOiDBT701SOTtRrpA9u6+OPey0qJW75UemBy+4jQiH+NkkXy2AMfXkoc/DGEPtUlAHOTwiwcPqDPHW9ZlEzNG6cAh0IfODGLwBa4ZNE+X33bYgp9Fj1pSumnk3MINCJAZxzaIluzWF4eAEAAfvaTJM17tx1Njh2eSY4eJD+HZpIZ8jm7Vj5lLq0PJ4Gtf9X9yZXJ7No5UbHVAH0q201dIn2o8RXwY91WAQI9eUkxVlbARBhq1ZzERvCYwC+VvLZQS7W21LRXHiee/NTYBSH3r96+M2/APAJIvYZh1imTG1qTZTHrrr7/ODX2o5tee32JsPaJR2+9ZXyV6JfOen8ZZdiDH2u9HX35X2zt4G0Um+TNyNPFLV1gia5Dn9GdgX78eG/k0GeRFvowO9T8B2YPpsJAH10ZWYSRKJp8y1c99MHAHZUJTKAPfjuXzuB1UQRpXbrjqP70ruYgjyi+D+gD+XxmE9gztWCcwJ8M+hBYAy/5MujzxTdNU+iz7Mw5uTiwbWsWAUez5qZt7NlyhG7lYlE6AHsYTILonePHkuT0F2/J64s5gxadPEUjgBafMjVAHxU4oN6IBAGZ45ZKl+oq4AICJogwaB2JMGHX9ednAMgG/ojOrpTFIoIHa7dSn+p+lHat6acpuJOuUpxEkmTQtz5EooB+sD8vVIVA+jWsCw847i8D8WvprqPupqj7vh0bta+3zi7+vu+vrvW+M8qwh3kPbuzbmYP+PNyuJZxt7Nruaq3eAB8cAYpmmEZzBvo1/57Ioc9iW+jDzJQ9l+sxQ71dMUDHJeEzgz1MCpNIHxfoA/2pTgnjEzz7Az7CwNSYvQb6lKc+5qbksli4Qh+I8gEYMzWfwBoCfmCbVx6Vkx2TLm7x+tzrF1Dos/r8edREO+45SCKDxpPJLEIIooRg6xfN+QNJmElOHig/MYuUIfmC4PtJUh5eTE97YQp+eOgzh+QWgiifJadOUXnWv7o+0kdqvyYifUBQ0y1exA7SS/ZxHYhQ+aauDs9yasv6gz65vgQ2rHu4OGUKPr/+QkUUkGikrgOeWrs72BrshLGNooyM8336QQKA7ioAEHTx8CNFcmjZGuayZvl9TFC3hll762WJX0t3HV1HI7yN2tfZ1WZm9furr9p3BtiT+gh+7MPPQzMv9l8abxv/fcfaYn+3dNHZEKXZ45QqSlNphXo8cuizxBX6cM/vGPAjgzuYz3RQqG4goK4IfaB8AX4KyTHHuJuc3pX2s0qaO6hZ6CO+WFUtlEEf/X8NlxnX5yLhCn2+/OZpAmIA+Iwnsxek+XxoRE52YhbcRMRoHwA0pz5tQa7aQ98sXhhpRA9pY+HKWTnsGSMv/5C/h36XtQsRQfADUT/fu2V32UzEp6D+/JMm7aEPtGgKfnTHtkObptAH6sjADwb6yPzQAPJQo7YMfUT/Bwh0/UVLkl+/czf9V5Sx8rckSoWqZRM5ZApLROGV9YuCjUXvaCJ3KmPNy46OakoL3nr/E8kN3y/m9OYtHACSLWiRfObvJcDnCu3XOP50dJUrrI3i0dvVbub1+6O73mdGHfbgxlpvR3Mvi78Gzjbx69GEhF2EPWAHpSd3IMqns7PQVXAMrbB08t2RQ59l4xsrms3c+12JtnojqY4G5xvDJnkWIU/d1i1dBBDfligjgB/+UkX16E750rmHrL6Y30fVhurId12f6ffqcSPQZx+dOpgbkescqxPWFfrccQ1J4kygD+TgyaFPBmYA/qigD8ikAj/w3fTqqfTFnPzQqB+APlnED/zLon1mw5YyApvu+tTu5LnXplEht716frJwxaxk3tI08qgu0qfWtqbQBzrXgZ9Rhj78nEAAEGkKdq7eus1CFNCPLS1cXZh7SsiDkoObQQqIVJljiHZRgAfRTv0WPX1UkCx6p7J+GUIjJtOt9xEA9N0CAD3EASDcIhquFGYtrpemyZXazQ7uurn1X60d1lbx6e/bnhILhzVxgwrpFRlgD8b8ejtiWulamVGc+6Zj1NX5U/HoAfaYDn25fCxLhJ55SPV8LHLocxI60oepV2OI7CtLU7n5iWHtekAVVgMMLDNUT1K8qtPYrsdS6CNeQeYc18mykxYmV0iSHK9PDifvTIpoHJURIJ8PgJVJ8gPJnGmkTwZ9AM6wY9L5LV5sKxYPfcT2d246lH7EHDuDP/D3BGkXEjyz7V+QA2h61azkjEsfoVVue9U8EukzNUAfzn65fUNH+ogyyCAGJoJGtgYK9dY9WECgD/5EBoBMoYkKbshsiZApL2IJTfg5UP97u3BHlE0G2T5978Hkhjv35a7YNgByfxkIslo73X/cdXTqnqsczlbx6OzLdrh2+qe33me6+rKKG1F9KdyY6+2o76m7JXA26q5+PiTv6jzKPdss5MeHyazbiGo2RiVMjUmRXGBX5NBnmTH0kb1kCHbqAPzBgRbkIFvPvHJFnEy2ndVAn+BzLuuQ9bvcEfowkwDIWfPj82luHjhR68KrH1VaSwd9LrhqR/Kvv7swrw83bRb1A/Gc9G9I6UPsOkNy99DM2ORvgEw/95d7kw1XzSMQaIpu7wIIddPV8pw+WtsPkT7u27sCQh8ePKx7oBwF9MGnK6KAMDCG92QERGokggcjp4L7qHP4cIoxoRH6Kbf8Gcr48pu2l9aIpiGQv4d/7cphe6dwrudPRyt505gAACAASURBVGdRsgbC2So+3X3ZsL6d/umt95muvqT68gjcmOvt6EuemNrB2SYmiduVJbVXN31lgD4I3+nm0NYrpuADOyOHPsutoU8N/FE99yNcI3QRPWgJC37o62ljXZYbppE+QeeiAHvYYHuDPgS0wBHs85akoEUGfWDb1cWXci/fEo+DCB84kn373QfJYMD2MKA8aUH660z6C/03u9i2LvY3QJ9FZHvYvKWO0AcaNAU/Pd7eVZkgJZ8WZo4JPPAU6UPHX9IWTOobyTYjdn3wJ4kPYrZpIXRoBfD4gDsKW6lsWDv2lsCIH6tb73ki+fC3mokC8rfQBl2xje7H/nQ06lZTOJy94tTfpy3lbfVPb73PDMAH41d6O2Ja6VKZ/s2F5q3f1Vw+9H2AmafW1eOaB8GlCd5h8z5b6kF47Xg0cuizwhn6iA/umTU6EO3Dxi2mrV6V95pG3DcdnLGdiu1dzn3WTHLZV01AH9h6ddFrqpE+AH0gNw9Nwky2g6WJmMdLSZpBf4A+F79+J92mxcMd3jYi6OG/g0giCqAy6LP8rOJoeCi365n34f+7hm/oAwKo8vqoiKPPE7zEPgz/VidAdoA+/DqmihbJVwxupGVQRgF90lmX1r1xkxAF9FMn1ZxoVfTXKOBRQSjfgMcYZPH2VgiDHId0gVU4Offxp+8+kHz4P90BkPtLQPxPTO46Ot9xJA2Es1uc+jdhU3mb/dFf7zMD7MH4ld6OmFa6VqY/8yCc5bsKfEoernV3bYFgBg8qSdDOgplQ29GOtZdqy7RZYGVT0Ed4P2oseMWD8XCRNeE0wMnjrrgf6COZ2Li5XpRaftK0U04fZgoaXZNF+mCgz9RckmR5Lpz0pYY+0DZ/FHsd6BGB0lk/O52PEkQNQZ4huAAoTb5+Kx76QCUT8KOL9IH2TJM5D9CnPOPYeoCEDfmklq0jEAV0LxcF9LMEAFE4wXWJADK4LVRZm4j2SqLqQA2iPZV8Uohn2x7PhBBwRyqTpO9fuW5rPhiYLWDuLwC4VdT9NmDfgruO9n2ra4azW5z6N2FTeZv90V/tMwPkwfhTuDmHkSZ0mf7Mg3CWK9use/6Dgz7x6BVEkiCdhPNR2562Rw59VnmBPsw6NWCkA5E/sUT8xA19PEAecTL5gj4QlQPQZy7Z3gVHq8sifVjfX3zTdBbpU4Y+C5bNSviEzyYTn4c+OqA0QaCP0WUCfaBhHfhpE/pQoiFor4IKkrKNR/rwferAgSfow1OeGzceKBnnQz+/rPi7DjaJtpJBI4WdtYDHA4BSjpsO8OiAE7iTbJwQ9XKyVoJFnPklbVz5vvLcBQjk78E/3icnfzoarXw1hduxVXx28GXP+nb6p7fefwbog/EtvR0xrXS1TP/mRfMj0VXoI/V0pfvHMy8alaTRxpv3Rd89bIsc+qwOBX0yw4YCGjbjiJOtPxE/uEgfYULXz2+72d8G9AEH+erbFiezF47THEAAiSbJse+QjPmsKwyBTOZtDPrASV7p1jF1FFHnoA8FSRLnV0SulCagTZkaCNR36JMCILZikiggstWIXR/6JQkAqsAenmAU7bA2vAIeFURSAhcJ/tfBGZPoHV2/gq2kEVhaeYoCn/7+/uRD/7Y3H58HH95leO+xWzMNO3EqHudLTTi7xam/05AaVe6f/nrfGVXYgxtrvf2MHKxjhXE26phSAcXt6pYuMBEuwqdSMqB1y101OlMbbbw1kzl3vDVy6PMkr9BH+lZRtmHkET968BMO+uTWbKjLMvSpmcC4uY0rJc4oFfCBctgj21mbJpE+d7xlEcnlM5ZMzZ9I5i6eoNBnguQBgh/I4WMb7aNaMa5J9idXZsfS21mKtGwS7eM70gcUix76iG/03GjoXuSFqgV0Ucy+uogbSV9qUEU6ztuqgTXZVzf+iANAzyIASBMlowU8vN6WETfO27OU4EgDGWX1FDrIZcT4R/WOpdL3U9/dl3zoazoAZD37nR9GTBuI8+UmrP3itIHpSNqX75/+cv8ZVcjDPAM3zmHnnr3XNlMTZ6Nm+u5Dq12GPRWMUzsV2p8njUrQaOPd9/RHIoc+J4eGPtk7RkMcw5vDxLLVq0nwk0KflmAPU8wr9CFJmun2LoA45Oj0i16rPrIdoM/UvHECfcaT2QsG6FOaOarZOUCfwkxNQB+6OAqQQeyH+/7GH+wvDduHnrO82DWng1whAY9GFkxiZT7yKVdaooN6C1lWyyASyApmZe1/6jskAuire3JR0wig7jwtxfeC047t4rODt2ccVEP90V/tP6MMfPDj2878Qzlpw4XwNmpYkA4332XgY7alq4KHgo9aYzO1sYaDm6jRDrdEDn1OaQT6ZGSnzrLk2Th28MO/gslVCaeBPgLJ3I3Hdu4i0Ie7mti6pROrSeiz4pz0xKzVz9xcEeMrb11ET+6aTSJ9APywSB/4Fy7bLV4qfVmkj9O6OUT6UPPWRs3wy4oOfIjrlC5yhB/cCKBPLg6LArqrgEAfft5y4TQwSYylVN9CSRfokQ4UZzDWvU2OJH7Q+WAojfzYJM0lnyq1ibOZNlcRaebyv3s4N8aDD+/ULYutfR/fC47Timltx/jsYK0KumK/dNb7zSjDHnAK3Hjr7Yh2sI4VxNmnY0q1JG4XoU/XYA8bWm8z1ltDLTldS90+HDn0WdMY9GEGV4AR/tm9pbEx6TaWyB+f8GfsUQH6yA3id+aLN9IVy+Qnd4EsJtu7tt6+pnY8t/3wYHLJG9KXLYjygUigyTljBfQhfzPwA3l9fG/xGmnoIwIA07+FNWSAPiqgUkyBG0iuGXZ9+IUrtMfBY8BF3mAd8OLG1iq5sm57lg7kaaANGmQp+pHnAJLczaTAK7XgZe+KAwDF+VLj936DvcnHaQus9G7l+qm73o9GEfrgx1pvPzevi7c23kbx6hCbZF2cawP0ic2LuiHP5sihz6mNQx8N/OHfESIe0ligT25ND0FGHPRp8AafNa3qwRX6wDHtkIAZonYgeTJs2YLj2uF49DFyQhX8CzdxOCadQZ8vv3m6XAcifTLoA+BnnNSDOj6jfQD6XJHl9LH2c5+RPiCE6gQvlXPZbu8yhTxi+QH6VPP+1EAFEc7c8L3yNrAPv2RFES1lEdmCjuDRAho5+q9NrqyLxpJFAlnoiIZDvK9K+5ZMJu6jy/66HIUYIgoozpeaBu9BNQtunLawvkMYVeyX7nr/6eKLp9GASgqbj7Hejq4yxVrf3FaxahKPXF2M8GHWw2+DiGPOeJPCW0Px+GFISQboI1q7m5E/uAgbDyQG6Zw4eeobI9Bnr/fpbXrj9AF90pOyUugD/zLowwMcHvrccQ3Z2kVAEUT65HUY9CEgBOqtvdzuBC+Vyb1AH2jcJ/gZoI82Aqa8l4wb3bpoFx2QEdeJOigh9iPm/OGpuardvI30lxvu3JcrcsPLVpZOChOBUZOAxyq5MjaPjyxiyCZ6RwqZCj8o61ADeLQ+MZbc8o29yQf/9fG8cV8AyHRNRt6DPBXzfgtCyRW3TVAqOBXqj/56/xlgD8ZV9HbEtNKlMv2ZA/Favf/QJ55540USL43E648hJHso8kif04JF+jBra8AI+TocOjHzAD1oCSe5Xha9bl6hj+0NNBT0ufBqeVLnL/z+wmR61RTN66MqozelvsQAfQQb1YEPDmRUIAT5YNjeBUaoAqjKoqADRuT7G77NAaArCQCSrNO127SQkTdowCMDYJw/oCNwdPYRQBhVuwbkoeGOop0ieokPB8qMLZH1k/+xN7n+dncAZLsu61c0HyXCP2HGbQ8fNq1voz/6631nFGEPjL7ZGOvt2LxXhu/BzEbh5etDj10GPnQesUGonSJxzB9nKZwb6IPH+tHhwcihz+mxQR/xnc7PMHhrRQ9bugN+3KCPZtsW1uKu0Afbj6rcAH0kllH5cFvbu/gXaXGBqMgqeakW6ksT/KrK2CQexgIHZvrAkT4VuJH1f8N/FQDoxpevKhyjBobIjox3Ajz88En7zT7ERuBoIJIWnsnGHwOHkJFGSpjE9XHLvxEA9Nnd+XhgIoDifKlp78kyTnu43r3w9fujv96HRhX25O+oehNlRdEF8Y7WkZL9mQ/xGXw0YA+KCDU+OM4z2LmBxlXsXAcPRA59zhigj5VPxZTjRw+i5CoaQZ+mbpKtQ58/IJE+K4dIn4qLyMCPDPqIsET2N6aMQeSPMqKFKjFAn3wsEZE+vMn4XDof/s8CAEGZG38tg0CS7WWVHDwaIFM5lp4HeXUAjB9e73BI4vBosGQKojQ+ypqT2OKWr+9JrrtNDYCaWqet7pKVSuGeMOO2gx9r1rXSP/31vjOqsMdsrPV2bN47w/dgZqPw8vWpx67Pw5GI8BnNZSDINLs/cuhzZnDow8yuj4ixhRkhBjYm6JNbVG/SkmmU0CfkDTIW6DN7wXjy1FfLt4D5cKhObe9SgZsB+hSuUBv9wnmM9AVe8KhIIn1K8EZY4T78zb250Ot+Y7U8F5IUklSBSAUSUX8zBSeZOK4RNeL9qC5Ky7WvCoTj3Cn/TgKEFDJ94isEAG0oANADm2M7Cr69J8uQ9zAf9wffbfRHf70Pdf0l03bszcZYb0dbOWKuZ2ajmDWJX7beRPgwU0e+rctpRjtVjt8X25Twvsihz9rWoA8S/pDnXUOWEXS4uwx/cujT3o3xRLJi2SLlqVYmR7bbjvoXskifAfrUgAj+K9stXgaRPLS7mvJBI314IMHboW3ow9tIBpYk31fAiqBDHfTht4R9mOSbYde63+IAkASKRAd4TKN3pHZ0gzV5bRF01QGnkhxVMPSJOwgA+vRjedPhAVC7T5Ht3cNs7zzN1Ou+Hcz8aBSBD26MzezYjDe21yrORu3J17eeuw58YDxKMyZi4OM8s50b6Jv3+tVnUwegT/tQRSNB5OBH9VrIvRn4dSpka7pIKQp92rk5FqtO29Dni2+aThaunJXMJomch0gfzrNUc3KAPqmRRhj68Pp/+N8LALT+VU+qrnmhInjqcu/oABlCRkzunZJfgIuI0Tto4MTPQyECiuc9lcih9INPfOnx5AOfDA2A2nuSbOcehrwLByzWDzvg/KilB5eAoynvCj/GODu2rlADAuBt1EDnI9hkau9u+9tIAJ9uD1FnZta9kUOfs0ikT/vQh38olw+tDmDE4BB6GcNaWifP2I6d/o9s1w9EuvKwG/PK5e1G+gzQRzFiA/ThAIbEGH2FPrJtRjLIxUcXZb9/6OscAHrNyan9JHaq5gDCb2lK26wZD0mfUmBTM3615b23n7lZDXjCRkvJ7Prxf92dfOCWpgFQ2KfJ4aUu9Zn+2UHvRwPs0T9hdf0FHKOhrEz/5oOtJcLW6/KclK44fYvy0S+rYR2m5711AfqwIQiLJGQDr5dABzLadCecbHodfemgk6dB6FNdZVQ35AH6WAz3pEGd8ZqyEzXfDdAnbuij2wokBTWKqBEJwKmAlUpUScZ04HNJxMmHvrqn5Fw3vSGDQDy0wYCXUIDHNF9PXXlENE4Krxjw4Wwp3o0tt8yVwVXa6Mc+TyKAPr4rHxf7LWDtPkWO+std//TX+1OXXywN7tZ5UbMx1tvPRoau1DGzVVe06o6cXZybXYM9zBuMZrpR4e74W+ySbow80udsSU6fcFhCNXp6CXRAow2/wMmk182X7Dp5PEKf8upichNuG/p86Q+nkwUr0u1dy9bOKdl+9TM3+xqLxFsiZ5BogD7lcSnNKUnUCP+CbfV7hJE+kUOfHGqwKCCSc4ZdN73xlIxyyGCHYGuJngyWVLZP8WNbG2FUE1kkBTYCLJP0I4MsdcmpMdE72DarET7c9MjtkP7Cyn7sc7uT9380BUB6+NPu06PJ/cTbgh1hQ/2xg96fuvgi6eoy5uOrt6OrTLHVN7dRbBr0R54u5/HpNfQZvWUhqkl1T+TQ55yaRM7h8IQ4ZPqedUCjTSeol02vWxOyS/97uf32LnvIIyrXBvT5zNXzk1lzx5OnPGdxxdY7Nh5KJibHkuNHTyQXvdbfaV5RQh/QXhXtM0T6FL5RF21SAyVy8MG9bPOf5R2U2qiPxkGBBNawJAKn1L8s0kSABBUZa+tkpfmtSkwdrt4Hv1QAoJt/fw1nZxmsSD9rDfDUwTXMuJVkF+xDFRP1421Q9gU5KGJtVtvGwKCxrNDzf2tj3nEBgdp9ehxe8NIh6Y8d9P40irCHTTz8OOvtWHmw6ckHeBv1ROEI1egy7MnnGm/XiLdzSeXV+cToLg86ywT5/u7Ioc+5iNO7wmMKfY8xQx/mWLHBH1Eei0gff7CHGalN6APgZ9ac8WRyzlgyTkAPwB74d3xiLDl2ZCa5+HX+jkAeoI+w3opz3ODvysQq1ZVEcXAv1ylB4F+sMb9LFiRJJEldcmdp1Ea+Uqhf9GVbp1Q6KO0igpwKDOKhShUelPrj6iqhggb6FKQjST74xcdz5W/+wxQAlW2lgWB8ecSWK1TbnI9UdZT4lwhueB/jbVHRTbA137RkjKrjnhbCwCAGd1RjyQbhY7ftTt63vlj3HtjsD3xjn7iGF7vUUv2xA+4tZBSBj/kY42yJnWtdKGduoy5o1U0Z+5C0ma6tvPmVUyqOuWYkhVHhbvpg7FL/KHLoc96mj6LORNdjGN8joe9xAD/mNi+9FukjffxDHlHkVqHPvAz6zB6gT8WVVPNvOL0rNdUAfaqwQQaXpJEscpDzwS8UAOgjf3SqFM6ZRPygAE8taEEAnppoH6MtXDIQKdpTBngkfpgDnhofrZSR+PRHbyUA6MYC+jQNgIaXu77BnsrrVe0TyyhBH3NfH723OXMbmT8QDzXMLNCXOZrPpoijfIxnvHEFs7EfSuMsMEAfnJ3UpQb442pBvr4E+qhXihA33TagD2+Qf3vnkmQygz4//sYiyalPo0NbQ6SPYFGDyJ4SZOFffFmTQ6RPaiKVTSOO9BEBGtPhepJ0mF0ffdtphfMoImC8AR4JfMFE+9iV4eaEMEa+oncwET4Y2330U48l7/2wXwAU4v7iex1vur3+2ET/BtKXF0gTnzAfX70dTfrvQllzG3VBq27L2IctXTACONjDxqrduWfcu3GFbvtkrNL/MPJInydDpI/03alsUT16aXoE9BLEHPkT41Yvsr1rD10m2rzJtg19mnZb1v4AfQRLD9BHvvAK24H6vr1LBX2o3pktridJh3MA9CcpAKpE/Ki2Q5XKZq2INqYNpt8p4Q0mIsjX9iwpeJJHR/H2w0X42NuA2eYjn9yVvOd6ewDU5v0m1Hpv0k+/7KF/8xhgD8Y79HbEtNKlMv2aB12yvFrWvsAepmEXoI/xzDeu0A/fjFWLH6x9aayiUbmesuljVflq+IoevTStrl6CAf7gxmBs+6Mp9GnzGqCPhfV9nd4FXbeVyJm+YXO6G0AgZUQL/wZc176qX+XnkkWnZuuMTK9yNIUw5jVbhAbow/kJsdP1nykA0Mf+7PTCkAbQxifgkY5rBUAVA1yFSpkKufw8OSp/V8iNKcPPLTkwqtt+ppSTm1cAmW7+BAFAH9iRd1a3BWx4qUvN1E876B8lBtiDudfr7YhppUtl+jkfujQCaln7Mmcrs6oP27pGb6noxKS6K3Loc74M+jDLRgl/+gx9EIb36PWtQR/+Jr9qxaLkimS2VK31yeHknckCjyq319QQ6SOxfR3oqflugD5lEJIvGyqb5RBCES1CPq7dnsQDNA5oqAEGNCjCDP5viRwyaCOJeuL7vG5DAYA+/hcEADUcwWMCeLxvz5IByYrNBLuWAI0IkNKyGJ34CKL8OVMyXh8hR8Bf+/4qABpe6gbY096dt72ezfx+dN7gzOzS3vgNPZ/oBaCWzqxIoQ9qFUAVGry3LQt8P3Loc0Ed9EEwCD2CacLy+l5jjfbByaXXz4dVg0Mf2c1+gD4WQ9nHSB8eLIi/C38P0Mcj9NFFyIg3gYigTwGWxpLrPv1YPpE+8TdnpL+rYBcPOxRlMNCGERNMWUziZOX2LD6wRwPwrKJ3Su0X4Ig+W0r7ZgBJDY5u/ggBQO/dno/J/Q+FPwXMYmVtrEr/XnT1bx59iRIwdQrzsdbb0lSGWMub2yZWTfovV9fnrx3XaW8uonpGFeq/b8asYS+gj+wdjDN6GEQhjrK+VxxgCes9OJn0uvmQunHog7nBD9DHYigH6FM2Wmm+8G+pilVKFjVRB51ks1aIZClDhmq/jW3vkr2UK0ENMsKG2kJYhER9yd9tR/rIoA7I9IFPcgDo3Wdq8/RgoI0S8Eh8CQdvJGPB+WAhk8SfNaDONHoHuuUBjxE44udNLlfZd26+eWfy/107mgAIcw+0uAO0UMXsbaPrL4wmBrYfYzObmsgUW1l7G8WmSf/l6cvc7VKET34P1rnX6CwZOkvUfO/LSHYv4t+LPNLnqZhIHw30EV8xHAbLsKp+THCQxbBbD8Xr5dLr5UGExDv0sbmx9xn6PPK5NcmTnrWZjtWwvUvisqKfq2CMsAANkT4AZTJ7DtAnpU8iCMl85gO3FADoln9Yi9rO5BPwGJ2eZbE9TQneSgCpDJhOIKJ3aHUJ6MtnsQLw8I9bskcvAEDvyQBQn6N/bO6FPm7q/tvQP0D35SXR1na4sdbb0bb/mOvhbBOzBqMjW1+SNncN9jAPQ60QqEJ99tmyAZo0B+41vFrqu5FDnwux0AdBdnA2asIf9T0P8Kdqd2foY3dDL0/TVSsW9zKnz73rVidjJEny+MRYcmDnMWr9E1dt8eP9Q6RP2Y6l+S+JjBCgkTKBtAo6dSDSR7rAVV7aPUX6KCNNGIgqIIw8aTJSDhGCQLO8TvnvauhDJcqg0Ac+vqvkN5/857V5g0aAQwFDcFu4OBvxfqmAVrn8dRBGBmCyzxjgkUf/pIUwkUFpuWLcSnCn5slLBYHg8+c+6658PLoOgOzuhX5uB820gn+cHjXoYzfWeHs2M55hW7WzUVgZh95SC/QF9rDxNIM+8cxLu+1oo+LFqXViGC0dbrgz8iPbLzKFPszFJIrrbNGcd+p7jhX65OasVUGvn41tjaCP/U38RPLmLz2Nwo8x8rN/x1Eq69+9+L/ov32EPnf+03KiL/eSJIwOD38Wf/r05PHnP2A2fgP0KdtrgD6V3VjUQH2CPjLQZAh9qEmgTlbv/STxMLs+de1Z6a8iQAkBeHg9MoHUW+cyMSVAjD0QuW7PSu0kBzz8xMsfwMgvdXBHtbjxdZ7XYQBkf280W/bDlNY/Vo8a5GF2Nx9nvS3DjGnzvZjbpnmZhh7qLdA32JPPU+lNSmaLOOYnSgpUoT55fDyQR2dV8fW8t9CHGUJQuBk8obM6/4KjLttt8IPTEWOpfOiwR7bb39BPJL/9sUso7JEhWgA/MUOfrbevSVY/M92ehb2+8RdLk7Fx8tI0PpbMmZafh86gz7ybTk3GJ8eSiVnptJk5diLZ95IH9V0N0Kdso75AH36FUsCGyglVsggRcXEWoQIHPrTHl8vakgEYfn3itluV2s/HqQAKtHlOnnIkD1euAeiT9ps2/H6y7QiuT7/vbMnJY4K8JV1TA1Vy8AjjV4U4aQFMlI0sR5AS8HANyuFPNqAi3CIf89u+xEWoFupkX6qeS8t11U+v7JsXPOsHefddiACyvz/ql/qwJfRvFqMIfMzHV2/HsOPabG/m9mlWnqF1vQX6CnxAc/4/RqgtEcccRUmBKqQf826UKJTtmtrske87kUf6XGwb6cM7kIT0DPDHfIbhoJQ/yyojfexv4uVpetX7L6QRPir4ASZad9V90W3v2vDKeXT0LnrZSfTfk5+NBz9fe/tiCn2mV08pPQCgz+QHTsmBzwQBPwB/4Of4kRk9+BmgT9m2A/Qxj/RBQonc0Hz5HkIfFgH0vvUp/IHr1uvPSX9R2koCr6B4BdgJgEf8nutDBXist2cp2sYBmmKa1T2A8fcLDOBRASR+UrMyL4oQANnfH80fCpqtgX+sHkXYA7Y3G2u8PZsd17Ctm9korGxDb3IL9Hk+9wb6jNBycsJx41YTaxDuhbw6v2KHPpf4gD5M7S7BHyKrP3zi985S72v+pM6hj92E0a9Iv/lPF9CIl+lVs5QWagv6bLp5dbL2sq1SuRj0gS8vfOnS/D8dnPLch7Uj/cU3TVPos+zMOXlZuMHOmjueTM2boP8+9sDhdPsXAWIM+EC0z8TUWDJJfo6TFED7XvyAuq8B+pRtM0AfPPSpAImMayhARW7oEYE+OeQhq/D7biyOGd9ww7mZoTKLKMFXi4CHmwdG27Pg5ZabUcZAqOYG4tQuJ9MtN+9KPtDyCWB290ntLaPFAvp7eJ9fDusMbzbWeju2OMheuzazi9euh8Y8WqCP8xoHe5gR252ztb23K5pHL6tdYemXpqq2vf5gQNCoQx826uxx9NyznlTrU3ff+0jt92J9VflqOeH9PhPo3LWrS/3ds0nOAVwnwjmIfsQyG++rk8Ud/oxt27HHYM4ZFM2s9avvegoFGyedPpt+cpxsX5oi0GPWPPJD/t237WgrkT4AfPhLhD889IFy579gCV2dTntRfSLmz752PoVcAH1Wn59GC+245yCBOePJZAZ1AOxA9FOa4yhN9Aw/DPpQ8DObNED62/uiB+R+N0Cfsl0G6KOHPpIcMNSIGniRGxoLfRT98Ll0ik6z1qFtXo68Ly6SRiYnX078nukmyFOSg/bLQZqSjmR+cn+/98MFALrtJgaANIBHAWF4u8tOYVOeHsaNVyX3UPadMbBR3NmMYA15EjMqL3nYM5H7kwQAXRcQALX9oOn68FHUx9/D+/hSiLGj2Vjj7YnpO+YyZnaJWZNRl42s1T1z24o6KP1Qhbw7C6pXVCHvogVqMFXOVMVYfVYGgb4d+fauH2s40oc5kg5RAKTBAh++nKweAz5pubTnc89aTdovQxT4DC4e9AB48Q1+GMyp64cvw/zo7DNXJ2rwo7OofgproI/ptCx3eNk7mdo+cwAAIABJREFUzk3GCQBZfUEKP+Daed8hCjcmCQQBuAE/H3/jg163d22+lWybIjDl5F+uRuVsvHE12UIlNwwPfkToc96zF5Mb5QllZBBrkdU79WkL8k4e+ub+/PdxqvtYsmDFrBT6QO4fMtogE83tA1u8SBkAY5Nzxulne1/4QFXgAfqUbTJAHzX0kQEUsJ4Q2aPakpQbesShD2+v936wAECf+dh5hS/m4ImDVRJbF20Vjlu1P+fiinZNQEndg5YzsJE8kanaNJWZn+iyNj9FAND1BABB7p8zTl1O//V1xfqgaa4f/l4+SrDHfnzx9jQfq7hq2NsoLj0GafoHe9iYmkOf9uavtmdtga56cqEYRsWurjvwHPdfkUOfH/cJfZg7KnhEHabAQh8RDKmgT1GuHvoACOJhXVPQRwRJYj+yfkGuevDDv1CYrwUK6IOZkvrOXvqWNB+GDIBA9A/AD4A+X/ibrd6gz90fXEWBz+H9MyUBL7hqRyJG99ACRNUTpOiJmRPJ/GWz0v8CAv/VGj4jv3/vE4/l7Zz1c9P0s3N/dVut8jrwA5Uh3w+LOIDIIAp9MggE/0KkD9hm9oKJZM7C8erpXgP0KY9Bk9BHFc8pQBMqUM1n0pws4oLJFxLb0sCbipiV+vUgAgV9tKAIbCDvRxnpI2tTpmsOPiR2hsb573m7mkb6cH2XbMLJWXw+lrznuh25L372lidLYRpdUbkBUgIezo+b2J6VLXm5vN4ADPeE5gqQZA/yWDk/TQDQB7MIIBv409UHTfUNSX8vHyXII9rJbrz1NtU/HXWjhJ19uqHbKEnZ5zkunY3KKdru3NX2ri3QRa8dDdjDj8y3z7o06oFqBPrw7z+C9jLwYwt8WNN8/WpbRY98tA//u/i+5BP81LWF6QfK1G/zqjG2xvMy6NPMSiODPiAPH/mykOT6+eyfbnGGPt9690k0qog/CUvUfe6S4iStWSSKBgb94J7jycxxID9JMnfxJP0dTtCaOZ6epLXpjr15M2c8YyGFPk/5X9trzSqDPmKFnZsOpR9xL6oAf+DvPKkzbP0ikT5T8ydoTqT9L32waGaAPmWTdgn6yFZAEXLwcxoJbwbok00p3r7wOwd95BCnvI2Lj8LBQB8+M9x7PsABoFvJ1lZRFsm45nAn+w4LOGRwhJ8UTcOXUvuKt8OmZajT91cMEkD38+VWf1/v88ug7qnbfMz19tT12ZXvzW3TFc1GS84+z+/a2WhGgoI4BWr1QBUKIq6nTlKFMGr1ac35r8ihz080EenDe4zwjhMe+jBhxkpbvErbvYT/Ni2DMXy+HZPtXz6gD/SnijcowQPDmUqgz+OY+YhuVpy4l15TjfbhGwP48fm/fMQZ+vz7ny2hW6Xmn6ROGD138QSFOVCudFrW0RPJgV1HU7GINY4dOZEcOzSTHD04QxMus2vNT8yn9S96Tf32AR30gZO7dvwuSQ6dXWCzPAoC+BP8Tbd9EfAE8gILyo6AX/ZXu9JaA/Qp++QAfaoLBBIWGeX06XikT9PQh49muvZ9BQD63GefQv21cjKX4oFIBUtMgRA/SVwAjLZfDzl98vWQE1rbb80DJV/35QoA1KcHzcJs+Ft6n18KVQ8t5mOOtyf6QSmyguY2iUyBQZySBUZhXptznXbnMap3VKEuOPtowh42MiMPfZghFPAHE+UDTdSVq4/0KeZIWi7N6yPL8cPeCXRbrzAROqxXF+gjywXkE/44QR/Mg4IO+rz7Rf+VrF652Bn6fOWti+gL1eJTimPSl5w6lex+6EhphUyPRS+gD02eTH4AruzdeiTZsfEQhT0zBASJ1/Kz59BIoKe/eTdq1QX4w29tg0oAfOB65HXkWHciL705Z13RX2FXWra9jHWy5to91f4G6FO2yQB9BuiD2N7lFfqI29iIR5a2sHFbzq59TxEd+Lnbzy8/oHN/uYAZvlGXdkxBi+oFw0UGX7qI7Wwg279u4BJA3/egv/w/qJuC90Jmbwmj8DIomhjznCIfFjPbeh/aAA3a2yaAcEMX1hbo8zyvnZWVL+OZwyhJUIWs3SJAxdGGPczA34o80udpTUf6MEN0APowUQEIsWgeFbTBgh9X6CNGFdVDH4WxFbPdCPrYPiAA+BHhB8gDwAcuFfRZnxxO3pkUCZFVK9bn37gwi4RJkhVnz6XFIHIHTsyCbVxT2Ulh+x89Sk8Sg5w/xWlZJGFyllsIgAs7nUtM5Aw5eGZI3p+ffacEwEgEAwgFp5MtJAmbIT8PgCT+aPqHX7Uoyx8k10oKeviiA/QpG26APlFDn0oOmzy8iAyjLHpI3O5Gt2mlQ14GK+wD4Xt+HWxqe5cB9GFF4ZHoWg46fCYDQKaghXd+F7hi2y9/Vhd/X7BtD/Rx0cPGHrcRAHRjZwGQ2dtBn18CVc8F5s8rZjZV9dulz81t1CXtRlHW/iZrZqNpFuETz5w2g1Vd81097BmlteY/I4c+/60B6HPe2dVj2X+0MTuKnXs/Oy87vl13ahfMAH+RPqkcfNSPOMNoFBBsqSJfYKCPeNQ6tKeDRlCmrm2+DdkK4AP+1EKfUJPUFfrc9mo4Jj1JTrl4fm6nLd89UJwQlp0WBhCGHZEOxkujflhCaQJ/ZqdRP6e+YEsiQp+p+eM0GuhZ/1CcxFW3LN/xlkXJ3EUTybylkxT6QNvvv3xjJaJp8ysX5c1oQQ/f4QB9yuYfoE+z0KeyVSw1vzQhsQhDYHuiWN8E+tRCIU6IiCN9QH8Z1HgPBx02cBFATcATXZvq74tvZGXE+0RoeFP7MkC+xMgDAGhdNhbxR//gX2QG2IN5ecLbE9NazGVCPdPFbIO+yjYqcx0PfeKZ1wPw6eusk+s1itCndoQF6PMjeqx68d97VXWbgT7Fke58vyL0UcmEye1jGukj29IVHPqEfDhwhT6Y07Igwge2fkGUD82rkUEfdkQ6fD41b4JG58APf2oXGP+51z5htGpBpA8khgbww07igrePg1c+ZNSOsnAfoI+Y3cvgb2XSYnEp4du0/V2FVysgg1vFJH1VwQc3urLIFvY1MjeP0iaqtrX5eTglMNCnpp/eQJ9StBH7oxhH1fYuHvpIwQlp4r0cALqVACAMrFCVUfWhByT1gAfqV/rMPrCFStI2hYXPxRZ8UzoZoexvcvl/4gJA+JeYUXkBFO+P5s8teJv6uXG314q5bdqTdegZb4FRm+uVGYunQHijeiqJWl1QhTwJ1EAzfNSvqvlRW3u+GXmkz9MbiPTRulb2uAyRPgz6QB3xtY9vpznoU+1ZPOULA3dUOptAH+yWMSpxnbFyYeoL0UiftiekK/QBXVXJk9lJYQvINivwLmY0dtIX/SxL7MzgDGwJg6TPp78kC03TenO5AAAfaH/29ASFPhA9BG1DXwevGKCP0jcH6FM97pxfmzTwpnPQpw4k8boaRPpIbeBze1eD0IeHH+/jANCnJFvAdBBE933alwXgEdZC2oIE+mDgSsgyTGycXQolf6tVAGT+NtD6zdzwXumruP0zjLmNfckcqh1724SScOjHxALFePbfd3m74GCPbKU3sa7fskOEj197dqW1b0QOff57G9Ane5cxgT5QRQZ+/HxWvHCKCZ7Z3zjIIvdK1WlgPEwyAT7UfCjow780VmUb27rd7+ldZpMyXRJXr1wiTeSMzekDbehOzLrgqh3JF/6A5P7hrMb/V3ka/AP5frJj32cvGE9mL5xILnhlcQIPVrcvv3maRg3BlrA5BPywZNGwlQzyBnmJ9hkifcrDUZoMkggVcR6YRP0MkT6VvDvSE79MI30k0Ke6XQwmZjbUJeDCfSaDOsw7oE7L0IfP5wNiiQ+C7G9VdM77MwB0ixD9I3u8VYMUT4An6zRvjfwSCt5g+lG9JGDqquwPbd5Otn/dFCz/j/nL3KjBHjuQYW5X7D0/xnJ2NopRk0Gm0roW+cD+ybl/kixKliZLxpYlc5K5yRU/erGXAewS9EGtNKhCXkznuZFU8DrxI3dRz/aoNjdAH7mJIe8PH+XDl4JHdT8wp2i1vj019IEW+MTO8LcpoGkC+uSvNQ7wJzD0yRYLYbV40qow0Ofzv1Mkhc6PSYfFC+SBH2JIgDJwQhdE/xw/fMJ4WxcMyh3XLKLJo2fPT8HPAH0yVzWI5KE1asoP27s4+/AwRFxFeTtKcu3wdpYCl3yVEcZQ7JPCFVaGfVnUkW7vahr6SOQpycF9X/s5Lyc20kcCmlRwRwd92APWBzjo8HEFAErLNgR4hPs47SXril/SXQEL16zQoz1g8iEfkwsA0Ecayf+DfwsYNcgjOoLZSwXerhWH6+AHZrbpoIIjKnJX5vwfn/vHyZJkWbJ47KRkNsE+V/7oJU4jJp29yikdx1yvlSIOES3GZIA9WKP9R+SRPj89fm9FleMbv4tVz7ochT6Q3FkCLVTQBzoDeMNfqiTQ9uXSI93FC8APf5lu+RKTPYv1ZcmgWX+YvvSRP1VDNwR95Kua6mHEB/QBQ331bYvJiV1jye4HD+enhUGED7s++9o00TOAHSbLCXIil4isTfP3iI4C27sA+kwB9CH/QoQPAz/Qr5ctXkOkT9nssUb68EFHIuTgNVABEyhTgSNVqEKLqSBZDYyhIsgAjtigBNCUigSCPlUwxSlOZCjZwAX6ZA2Vc/QIthIhGhOF2qIYI9dIH7pmcb4Cv1/HAaCP3v6UdF0TF6Ls7zqoJGtb1owKmsjWdJ+ARZTFd9s6m+n6v9rL9i/zt4CuvAAqXNL6Y3OgYW5ba+Faqmhuk5YEHbq1tEC3TuTyCX3wwCeeea6VRFvA0k0aq4b4j0id06kxY9GGY4c+P9nW9i7R7Pz7UbNDomldQqGgBrxTtCqXvnNT8OMZ+qhnft2DiS/o8+U/Sk/Mmr8sPTELQMtZVxQETzyRizenK+hhbYEMk5DDZ85YCfpQ8EN+qAcB+HFN6DxAn/Js6Cv04fXSwJvWoA8CSvmK9GkU+pQietI/TKBPOVrIHfqoYI34+fUcALo5A0AizGGTxTs04RrEABRZGdt6vI4+2uAXFFM7Qd3XGAMguyflAfjoH4TqNx9g6sdfZoA98Y+Rq4RdnOtvP/ftZHPXci+RPjjoY7eOuo6NrL5WEm2BJqRyaTMVuE7sYR2q2vffI4/0eUYs0CcDK8yC7QIWRfhRJly7sqnnsB76lK3rCfpwJNhiUfMFfSDSBxIwz8lOzJokUT9rL5eHbQEA8gV6+OEA6DOLHM8+SZJBQ5QPnARGj4aHfEH03zTSaIA+8EYtOLLB361v75LBGH4Bk0T1VMEHp78uGqfUdmSRPnXQRxVFxCN0rr4up4819OHlQMEdJPTh/0uFpF0+eTwW4oiARlxS69r5IAeA1msAkPgwpwMyFTkkFXSwxBbO6No11cUV8NT194WbdyYfu7aIMC1OALO4OcID9wg+VdurbGdjl9ei0HXtbRNa0qE/Wwt0ec6/jUCfZcmKZNHYUuvtXbWzuPJlPHPeTG5b7whXbziZy87WA/QxsFs9azFoyLVoDdYRXrlce2qiPg7+jCWG0Ee+pLk+hPiCPl97++JkDkAfkjx5cmqcRPukiZPPulIOfpowPOTzmUWijAD2QLQPnAQmQp8nLvdwgtcQ6VMMX2Wu8m/iErDCAxTM77LZNEAfathKJEz+IXyZ/bByJVuTLyuwiNuexUOwWijENQ5NysYFPhwR6MPDiA9xAGgdAUA6cKL7vgI6sgoYkCODLJh6ujK678U1XgXMWDlMezo4xvcJAOjjGQC670GzQwG6/OJne2+1f5aI58XPVnddPXvb6Foevo/FAn2Y8+GgT3xzfoA+scykduX4t8gjfX4qpkgfNlTRwB/xpZB71Yw13Id/zdXIWAN9qstXUw8dPqAPjbAhgGX2wuzELBJVw45J57d4hVwKvvim6WThylkkofN48tRXP5pck+yXnlJmJZMv6EMij5SXynnICWeVS1ZW/Mzj39KX+1woD9CnBA80+orwgl8zVJEgogF5yKGoX5comVZR2VfXNg9ESn1L7Cjoagd9BGyugjpizhwe6nBASXo6l6iHR+hTRBtx4Iq3P5Wt0NE2p4/PyKAPZwDoBkn+HxvQId4LdG3ovofh0sEUTBtsWpkCLNd6Kvn5z3+7tP1LDYD68OJnek8zf7aI74XPVGdseXPbYFseysVigT7N+bee+zayuWsl3d41K5lKfuVHLy2Z+etPvjN5xg8vkpreDJrEswagJEEVisYjqSB1Ig/rknqsBuhj4cfI10qLlh2qCEIJry4ODTdWVRfxw0GfcJBH1NYH9LnjLSx5cnrUOuTPgZw+cAx7W9DnS384nSxY0QD0MQE+YGxyEpnyGqBPeZuZFOBEAH1kEEoGYPiBFnWRQBRaXAZ9xJWj0lba0QB9CoNXcvoIdvUJcWQPZLr2oQ6DP/D7hxTbv1DwRShkCllQfUgWLZt6GFika5cXxb69ouYbn/XDvEkWAdSnFz+TJxq7l4dOvUGZmCM/ZMKo0lC4kxawmfN10CQGIwD0WZGsotu7eOjzt+f+fXI0OUKA0Kpk7tj8CgyS3dNK+pSmfFzzHyUNqlDbI1gIOQAf+7H4euSRPj/dkUgf7vXEfjCcakre/fh3Jqe2m6mMhD7l6W33EGavgA/oAydmsSPSZ5FcOvS0LMihQ35Cb/FilsihzwIS6fMqj5E+A/SRb+PJXbCHkT4RQh9pfp2cBAERyn4YHMoXS0mkTx14UkYCZQMubt9ifsBHOLUR6RMh9GEP1rDi38ht/7reBABxtwsdANF9r3rQj7GeDPyo5ZR/I376JXL8+ye5/D+bHthufyPtWE3754xOvD1ZjYa9Tay6Gyq1aAEb4ANAZWWyOpkeW5JMEqTy8h9d2qIG8q7feu5bCfRZXYE+7zr375JjBPtYQZ+IgY8WVjEzRb9spQIOsMd9SsUPfT5aPJy7q+uvhXrG4q8fdEsKgfJ3mThP96oDPyTSZ7fNvQdtMkxBV+gDUT6QKJkek04AC+TTYcAH4A88SLUR7fOl/00ifZaTSJ82oU9dlA8MTlORPrK5In7m8PfIbe8KBX14UMJPXkmkz0hBHyl4Ih/yfJG3kQRE6SJxxIct3+X5Z0+xLx4AfUB3AphQWSWn7FnXJqIGA4DMgIz8rqSTzQTwYGQWy9zBAaA+wh97oBH92xLmMQdVxt5GqOaHQi1aoBhbe3/uMvT5m3Pfncwkx0mS55X4SB+pqezt19TwayXSFmhKMky7hXDK+1bU8mN0DFvma5FH+vzMpkihDxsm+a6qsINIe+sm9MnNKNuk8si23a1PZ1fo8+U3T9N8PvTELJI/h56YlZ2WBdCHXgB+AiZ0hi4H6CPMUQfII869Afpw65EYJSMunCLIQW3VUqy6qqgbfn3kgId061j+YSaoKiKI344mjQRi9Qv40lgiZyz0UUUXpUsQW4pKEyPU59kyqJVhPRcB9H4xAXQmrA3U4PsX794m4IjV5WXAyCOrx8uha091kok9LKo+w7C23sRt/+oLADIHGq0/mgR7yDS3TTDRho48WcDHf12FJMks0occVxIk0gcidH5y/OdzK6jy8bACPJjit3fx0Gfe2ILkyh+9JG9TOdO7Dn06sYSpoc+wLtlN/m5AH/FFwU7XRmp1KOJHt52qEfsgG5WeQdQH6MNOzKKnZRHgw0MfCn+yY9JDQp9//d2FyQQ5Mn4hyekDIKq17V19ifQRGUQp8kWcAXz4Bfedqo4IQXiAQX+X4VJJu7L2VZEgvMiIKJ5KEmdeRg/Qpxq1M0Cfco6ebMCAL0nATu4mPYA+vGsyAPRelgCae4jVQxI11MAAIDMgI78L6mBQ09E7Lnoyjf6wowDI/oWhE29KyMcuhV/2X0Un+/Spsg/Yw+zRFvQ5TjZm1UXo8OOlikb663P/lvyHjxnaDkCf/5+9N4H3o6gS/fve7LlZSQKEELZc/F1EQMfx/XV8b3ScIUFcxhUi6LznmxmUKAIKIihrQsLqNorOxBn9zKqizvhUIDeggEhURkUFci/ksu+LrNmTe/91qrq6T1ef2rqrf7/+3fQPY36/7lOnTp3uru7+5pxTB/QckjnMr8PFnbsA9jhdwk5CnTrbmwifqjx/S80jff6UR/oY3puqcoyv3tpE/EjD8++CdYY+idX4PbQT0Ed9GFy0cC65qtW3ou3RqmiG82ny31ey1QJgqXS2VLuM9Gm9/3Hn9iEFAfqAHZDeNa6gD7VyFwYQ+msjHynnE/nTQB/hWTzDKLCqzOpdbYE+yTGUlCo+WaqM9FGKV+cKT8f7k+0I2jTQJ41O+jaK/vmHwZfnpsoqol10wMQGcrBxNjAl+shrtPVh26+zwbbdpPcWlv71o7j+T52jfxrYo3+SKO6bkE8nja4qPRAS8qh2CuizH6vpM4dl5rcn0scUoUP5UUIfKOSMbQToA7OthEf3jg1FU6Pp0V4989n/90XvHXpHqi4zEdaTnDhZ5SRU5dlo0i2MM5nYzFfFjk0DfYr5LdeqC6AP/IO8JjApkBPCqElehdoFfUyTRyjos/7UGQywTIhmzJ/I6uhMiF5xkn5Z3DBu1Gu5/vSZLOWsgT4ZD/lAHg44UGtn6GOYJToY6WNMRysS6UOMpRD0UaOEcKQKPngYMGnbxA106V01hT403GEr/xFj5hO8R6SPlDXBB7lPffgKsT2UTvxweDUCQH8fAyAbXHGBJDZw5ANMaF20FbZ+XWyXtrVL9pwaRv/4vyDU+o0o6COCv2+Cdt8oa4MHqoQ90vzzGfTZO4Y+rHJldOLQe4wjg5W+5MeWlqVTpEbo4LQsqo0uGuny1pVcXEKfkbGN0TQGe3LQpwE+bThbxR3dNgM381axQ/HTLoj00YOKmiGMLgE/6itrsTOn2lb81axq6OMyaQSHPgsY9GHwp07QZ/4hUzNH8+mj7y1+dH1W7yqa3qW77qlIH0rWZZsPBKoK+thAEL+SicFQ7QzbGuiDIZ6kRhISpfuykThIDoMmDGPk8VFBlJyBUaSPH9yxQB8lgig5TRQgpEIfE2AIBWiqAEziEVF8sP7vIAD0FQIA4UkuBBiS+uy6wgGedoEcamwu2z5TAwDkcp9PzwXbq0bxW2PdWvr5pW7WN/a4eKAdsEfa4QN9XAonu4xPjdApCn0ua13B/s2kh4A+C1ikz3QR6ZObGuo3VzhZ5CTk4v3qZOzIhx2OLhhHdR4qrrm7oY98eC4+/uAtLa9gwftzUkjTqJohs9xIgkOfIpNEMOjzsRnRlJkToj6I9OkQ9LluRR9PMXv5MXNyzn5q07aoh0GY3TvHogkffczptMoJ+QAfaLwnQx8TVFLBgTrPZQBOjaEPMs0r0kcZv1d6lwpYMhExBNBhvs3AHFzImbIDgxN5XBrok0wFpgggHThS4YELYHKRAb1Y7rsMAl3F4I8dytDTX5GomyLpWardqn+wdXWFPuoYbmXpX9e2Of3L736/57xB+Pml2KNA06rTHmAzT5tPaYA++0SLopk9bMVaS6SPb1qWzptqhE456NPLoM/efPWuTWN3sTifmdFcnt6lQp82O9bjVHKyzEnIo9MKRE3Qp93ndQXD66jKBvoEdn8toY8cY/adZ1xCn3ATgpgZFy3cK0hNn8FTZkRTZ9UD+vCC0mw1MfjTwwpJyyXkG+iDJoOqI332IOhDFhMzRMSkhaHF8WigDzgh/hM7xJjeZYr0IaKLdKAGv7j7QhZKvtPQBx4kvxeDBxjblxQAZIMpdliUf5q2QRnbfptNdQVEpnGdX3H0j98zQBe8AZV8RvXzR8nOmuYd8UA7I3p0A7ygdUGS3sUqVxrTu3zTskJBH1000qWtyzmoktDnnrE7WcXOWV0DfbxmMS/hdp/OwjjyH1hqbXe7/VS8v5trnt71BlTI2QwpaoYwagl/uivixyvSJ9yDTXZmCQp9ZjPoM6/zkT61gD62KB+Y0xiQIj+6a71d6V0WIKRPl8KhLxrAlInicZHxjPQh9FeW3qVG3eCD6RCBQy+pjilQrDADRMS2PChCG00RPCEjfahCzdIH3OaUwpdO78pEGykRTbIrTZ+m6Bxpbhno46IfP+i59OUioz48qv96iAHQF5UC0HUEPOMREF1QEgAVv+/vOW8QxX1U/MWiadkeD7Qb9sgInf/Ze3T04Ni9maXN/aBPtoaOLUJH502RlpVG6Nj0uEAfWL3r7rE7WJzP7GhOzzwR6bMRCjnXd85wssxJqD3nra6XJsKnev93E/TBj8t5zzTQx3620NCHvyPZG7ddgoQ+4R5g3GbAUNBn3Uf7omlzJnYU+uAj+POL57IVvESkz6tPfyb6TPQSGdHkddR90rts0EcHfExna1HoQ539LpE4mhmpNtCHAkhFoQ8eVC5KR8IXBTbooA8V5YOPKwVlMvuJiczahoY+OTjkA31M8EgBLBkQJcfSJdCH/Fe3+JD7RPSUifQp0jbfJrsFfskt/4UigD6fA0BuETx2UETPpib/qi1cZcsCorLtVeBGjRz3sYGlfw0WSP9yfx5wu9973e9qKuzuk5oOoDHLwQPtT98Co0wROgB9ZHoX1Mc5cei92nH4pmXpFKkROi7Qh0pBu6R1GVtvbFI0L2I1fBj0GR77PYvzmcOhzzQGfY5roI/DOVlGRB/hw+8le870XcaJTm0b6OPkJn8hDUXpPFzRBwZ03rasmzPQJ+xF7z6DVAF9Jk/vjY740FP+J1WFLRroozi3gT7CIQnYQA5poI+I0vGAPmRNo7LQB/dfYaSPK/SxRfQUATcSHhRp6wN95NUPbb4fw4fPDR7GN9tAi20/nllcZctCl063t43Z5NeVjtE/7s8E7vf7Cm+xbVHt7pO2mNN0UoEH2h3dg4dgKpx8YetCnt4FNX1s0EctnGyDNS7QB2DN8XhpdaIRFY0Es8MlrUsZ8pkcze9hNX1YNZ9ugj7Os5uzYAUnrVFlaljunl1bm9vto3D93VRofWBEAAAgAElEQVT39K5N37WuT5N6o0bYwmBK563sDvDT88hjzwa45MupCAZ9PtIXTd9rIv8joc9j6xdHC49+KNzVXEJTaejjE+UDdtY50scEfDAIkf7GPMTYlgAnqj4qOscoo7+YyWXlx1ukjwZA6dKl+CFDbchIH5NODMGKQh8VpAE/IgAObMxtjzdkVxJLxyS2SwIkTtCsjnSfbfWuohBHB2jKgJsybeVlikPHbWODNhL+wPcrHQEQnoI7CXjKQh8Yh6v9IcecHivxbRUCQJvue6LgHa7cM0DBTtvarIE9bXV3WzvrJORRB2qK0PGHPu5pWTqHqxE6ftCnJzohjkYC6DM5mhLN61kQQ5/fQUWfWkf6eM9q3g3adZo30KddnoZ+uhX6SB/l33g6j1SS46cxpfMWjmvoE3ZmCwF9AO7AZ9PNL/D0roWHT89c408MbY1eecrT7bzuc3010Ae5pFugD1khmY1DhRYwNMO2PPggfFHX9K42QR+ymHSdoQ8FIhUg1ECfPNjAdw/8/f+h9K/LYwCkAgp1UnWFJmUBTTvbVwl4TLp/wdK/4HM9Ow52+BP2GaCjN2ZL5w3sqfPRKWdbnWCPHIkpQuei1kU80mdGzyxrpA9Oy3KJ0LFBHxmhY4M+KpiS0GdN6xKGfKYm0Gdo7Lesos9evJDzVIaBjtv4l+UOZgWtnWc5Z8EKjDSqbGBPuz0O/d1Y80ifN2oifaSvag199EbyPXWEP7rXyE6cm46RPtXOaGWhzzoW4cMLJ8crZkEdnV4WFdM7kZWfm8D+JR+WSd8x1lHoUxr4wNnRRPqIi7qdkT6dgD5UJBIRuYJnOK1PLO2cCjnXBPrYCkeTdZ5Qipgx0icTBSR+WCN9GuiTi1TxjfTRRRf9IAZAlyH400nAUxX0kTd917GBvO1u7KrLpGe1NvrH1nsnHmOq6bOBPdX4tVNas8ezvuexqXCyD/TxjdDRHZc1SlpWA30IT9X2dGqgTyfmm26APgk78Yqc6TxSSY6nl92dOAvwC4Lovw7eQ9CnM7MW3Ij336/cku0N9NGc0E16V+oYCqSoVyEJWywziwnQIP1ekT7dBH1yQCjegLa7pnfZIn2CQB8nuBMA+kg3xH/bUp108CPUdgwXfHW6tE1l8g+Zuv4ogKFGAf0QRf9cokT/6ABIFYCmrE48Q4eAMib446rfZhPs/yWL/rkBHYNN9z3eiaentvTZQJ62uLltnaTHszPPtq4D/Vzri9H/1/uGRPyno4OZpc1xLR4JfaCmDwD29w8dp+0mFPRZrUToFIc+a1hEz/RoLxbZM53V9Llr7HaW3DWfp3dBBNDxvJBzvT7OZ46zYLvH10Cfdnsc+hsP0EcPKeqALvQEpSbWxadd9n2oDrbF0Kf9MxZ+wCoDfa47uY9H8iSRPizaZ+JkJdKHefqID3e2qHPbI31swAdOyRDLtVMzA3VmG6NziAvYIN81kT66SBD1LqSLxsG+tUTsdCzSxwR9FPCRYm62I9eOWgI+K1cH6JPagGyD01eFSQ30SSJSykAffKlgALTGUP/HBwb5ABIfWWm3axvbHdhVjwkGmWyy7YP+b2MA6McxABpP8KeBPZ14Laq2z24BPuAFgD7bo20sbWthNK2njy3TPpJAHzUt66LWSrZ6l0jvskEf3wgd3RHxhT5qNJJM71rdWs1r+TTQp9pzP9WuBz78PmG76bTLzHHYTzdBH/6aYfm37ewhqgO66BboE7/E4XfBDp/vDPr8oS2XvmmCKQN9Ouw/5+5LQ59uTu1yAUMeUIhM40mOhObqoqJnVLsoGWo2tOlSgYYKBdSzxgJ0uPi4gT5Z8q0t+KwUSgY5XXqW9I9TepcKZ+SxcdqObeg+6FM02og/IMbnrAngCDlzpI+9PfXIKrbhtj+K4cNqBn9cgUgZObV/9RLupkggaburP/BYZZvLMulf3Rv907z4OD/CdIVgN8Ee6dDPtr4Q7Yx2sIXM9+XQ54GxTZmlzXFkjS/0wYWTbRE6ugO8urWGReJM47V4IELnOMPqXTA/rER1h0DniXE0kgp97hz7Davos6CWkT7eL0XeDaq+nIRBJrOaua+6Y/CTmtf0+TNW00f92F51UvmaQB9pEGFOzSwkqVqnbKwM+vhMKA30cZh89mToo1wdlUOfDNSxzCgkKIqPJ+ZPBAhKjnoDfTjUykXLgIOQ37TQR4mq4X7FPsX7neCOEEpq+pA2ENBH0yd+8NJBj6q34wdA375c2gqZrGYKFBWFPrp216DUo1UV1/+R12sowBNKj+3hXrff9p7isv+/WfTPT7o4+sfnOcXhLt2ItNkDdSzE7OuCK1ufj3Yx7COhz/1j92SWNi8KfXwjdHR2A/TBaVmu0EemoEnoc3HrYoaMZvLCzdPZfwB95rH4ptk9e9Uuvcs29+V85d3A9yzxlW+gj6/HQsqPb+hjoC0hneiqy0BPOgVW8qYr/9iNBNptYzDoU+bhqYE+Dmd3A31SRkKBlnRv6kydnG17Eehjgj8SIGAYgQ953aCPivxVYKWDKAkpgQHHf3JjVyY/nZxPpE8DfZwicWzROiYgY2sbAvq49E+BF9nuWgSALipZ/8cEeHxgTWg9NsATyjY8PdneZ+T+K2oe/VPmGcXhDt2ItNED4wH2SHdR0EcXobOytYqnd/X1zIxG2X8fGDpe63UcoQNpVUUjfS5W0rIo6IPniJVKCpoO+tzBoM/8mkEf21yndXbhhlVdNA30qcqzLnq7EfokKMfy79z0C5aLVyqSaaCPl2O9oE9VD00N9LEcM1/gA+psNX109Xx0YILrdJwNqItQ3ebzW5GtZaRPldCHglAKiAla08cB+pD1daqCPirUQaCIh+NUAH3oqCJLepcl0od6LrTBFN+onCqiijBoMIOZcpE+ZaEPBizXxQDoQkv0jw1umI6Zbtb2aWN6V7C9R/j0Y4JPNh8U2X9lzQBQVc8uXk9bjXBBD7AYQtvFUFBzHZpd0focwze7GQDZJ4IaPveODWeWNsewxhf6uEbomPyQQh9I75pOpne5QJ9VDFjNiGYlkT6/H/s1i27ah6d3TYomR8s3vrPjh6PwaVa4YVVDVuNus/2M5+upKo/66P1xzdO73kSkd+Hx6V4BaB+0O1aFsKIrwA96uVbfaX1OrpKyztCnykliPEGfx9YvjhYe/VDusJSq6eMLfWzAB6xrJ/QpC4GcoY/hSvKK7kGHz5boqkbBYGiG+iy0ehepm4iUYX2WgT7kqlmZO0D8A9ljhD46IMW3F4j0KQp9lGihJF1LmhHvz6dx9WjqB/lBH9m9DuyAGQ30SU+0kNBHapXwB35fEDD9S+p3BS+2d4Ii+4u0MdmNL/kyurGeX7H0rxs7mP5V5XNLyWevprmDB8ZTRI9uuP7QZxGL9JlhjfRxidBxOATRKiUtq1CkD5tQVg2sYsldsznkAXgE0GdvVscI0rvqAH1sc57RV6UauxwFPxkT8mnmRD9fFpFuoE8Rr5Vs0xXgR3n/wa+aJYfv2lwLfdo5MYwH6HPN307nPj/qPfOSsviLjnk4OQ6FoY8v8IEeG+gj/G4DPVhGK0vMJJaontzKVGAKBXByNtJAJ1fEmbC79tAn8Vm9oI+uTpAx0kdNPZPHV4n0aTf0MUETOGV8AJNvhJHQ3/lIH5MP1qH0r/Mc07/wjbSugMf2vlH1fukjWz+fbWP0TzufX1wftho5uwf2BMijeuHy1mf57An1bUSkz5C2hg4AmL2T9K7dxvQulwgd+xGBwszZCB0b9IGIHpyC9v6NkII2Fq1k0GdWNIdDn2kM+twx9iu+YlkdoI9t7rL6qbQCaw9eAg308XJXcOHxBn3UV5Wsw2oQ6WM2MPMqGPxgeyukwU+7vMihT6cfkLoF+oxcvZAf3iXvfSx3mCX0gR1HvnOvZP/+xwrw00AfxWXqGa6DLsTFrE/vwqE1hv5M0TlqfwEifYzpaJlxtxn6UBE0fPyaiCnYrG0T+xulW2VkXaEPBifyWOA+1WNnSu9CcMYP7lgifRroww92HrDkoY8riKL1pdewaxSQq9xgDIDOJeAPZYvPNjzzmN4FXCGSqz6dja7tfd5bfMeFbfg1i/65qaLon04/y3g//zUNxFyyBx+4y1tXch9Aehes3jUytjGztDmGLD7QxyVCx+X0A+iDI3T8oc9xvJuVAyshuWv8QR+fidPF4QFkGugTwIklVHQ79JFDd0vzaheusByQroj0wWPIvu+1y4s9Dz/aniXbTYerG6CPBD5yHCr4wdAHZA5/29xobDSKDnrHI7xJIehTJMoHOrNF+oRK7YK+qDPVBHSoNp7yezz0IQBZoUifBvpol4EvHOlDgKaq07tsETxyzjLJucIZLFcW+rj2yV8K0Q3EFeyY2kkd61H0z2cKpH/h+5ovCLG9K5TZX6at65hU/5ru8Tp7Pl8y+mcPZgUlXkk63XR81+jx9a4v9NknWsQjgnazNb/+ami5trtQ0AeWiccROrjGEHVdi0ifNAXt/Ruz0AdW75rKsNYdLL1rHxbpM6tnbsfTu2zzJenkQo18z45i8g30Kea3UK1uqHlNnz+31PSRfugq6JMYrT+K7QIrbudRA31yfvpWtD2CwNKqPw/+YFHUO6Eneu7hHdErTnoy093It1l0j+ZMweBHhT4Dy+Yw6CMebvqPf2zPgT4VQyAt3OBHTRPpo4sictpODIhqZ9gWPNJHiXahgpFyKWY4OkXXXo2yUSdRW6SPGgFDRejgmj6UHXWN9MmMJTtZ8zNP+sYD+hSFQTro4QpRKLkibauEPiHAjgv0wZM9BkDnaCKAXEBH6Age27tF2f3SB+3SQ93Poe8veACgBvZU/VRUjf49OaJH59HLWlewu2IvX8kKIn02jd2VWdocR9ZAyhakd7lAH5e0LJejrIM+uvkClmbHKWgS+lw0cBGr6LMXL+SsQp+JDPu8b+O7XMwJKmOb84ydlWocdBg5ZQ30qda/Nu3jFfrQXKVeKMWUy1UzS8U7q2JU1Tbu0ZE+d/3TPgz2MJ8z4LNzCwvLQR+AP2p0D9/NJvrR3ewvBnT65k/i9Xv4AyjfPhbd8f+eTbT0v3EWj/ZpfeBxf+hTVZQPWBcq0scF8PA3YmWKLPG7VtDHEf7UBvookEWfqkXMQlZQBMdZgSFVQx+lv5yfQ6Z31QD66CCRbbv6Uk9FzYSGPi42tRvsUOPGMxPef30cAXS2Af7EtwPigdv8SGh6V7C9R5Tdr54LlKW2PnQ+sz0I6/yltoP0r59q0r8a2OPi5TrJiLOpOW76Y1IV9MGwRrfqlsuZclHrokxaFkT6mOaIboE+PvMc6afSCly8X0xGB32a67CYP31bjXfok32tqxpTeHrfYk7NrBWDQy8vVdu3x0Kf/75yXtTD0qAgwmfSVDofatrclI5MnNLLZbc8u4sDH7jrwQQ6ua83GmMQCIDP6K6x6N5bXkzO0IP/ZGY0ymQP/+snG+iDr9sG+qTeoKJrNHDGCFUo/1JRM3i2xiAjsz0c9MmkSYnZLZ7k0q9k7R9bbSAeWZPqImFgWeiDj4MB+mRTwfI22QCIDn6E2i5PDcoOm20ubVOZ1GIXvXWGPtK2G1D616c8iz/b3gnK7Le1xdNBGcikHn+fxy9XG01yX0TRP/fc+7hP941sBz3QRPS4O//S1uUszmcCj/SBCJ67x+7ILG2uRvpA6hREBJ049B5jJ6a0LHfroujC1oWZCB2qpk+ij13MFw9czNO7ZDTSB3ghZ6Zn4EJW0Wc+r+kzhcX63DV2e5LeNSGa2PZIH9f5Seur0gp8joKfLAV9GuDj58My0g30KeO9km0dqYmjWEljPJq3Cfx0CPpkZ8v995sXHc9uA+qnyvSuDavmcugzA6J1NJ+psyZwwNPTy4JvJ4o/Eyb1cLjz0lM7eSuAPTu3jka7tom/n390R6Jt/z/q4/tf+dGnG+iDfdwt0IfMm2IDUaEMjM2wzSnSBwuNd+hjijjCoIqKLsqAGA30IWCXcyHnWDBJ15LHtoE+ROHm7MSJHzTHC/TBI8QA6CwFANme/8vst7WVNtrkbPtd9VC3y6p1346ifxr44/Eg2SbRBvIUd/QlrcsY8pjEVu9awEHJ8Njvkxo6aoTO6tYanjrlBn3yETpFrPSDPmPR6gFhowp9Lhi4gCV3LWigT5GD4NmmgT6eDgss3kCfwA71UedIcxzFfHouJ0u8b1ZhYxugj/5xEMjz4kU08AHvVQl9bv70bA595i5OYdPMfSZFk6f3Rs/ct50fPIA8AH0w8JkA4Gcy285sf/6RHdHjd21lwCebGiaP/PwlUzn0ee2nn/WDPkVTu7jRlvPOlNqF4YWqhoGv3Ic6I122hYI+ub7QBryv6PfQ0Mfkm7pCHxOgUYAIFYlERvoQOnNyZSJ9fKEPAZKs0AefahYQZQMgoSJ6TJEzcKhgv29fGATY9bc/0idUtJD0Dx6vOt/hvn4cRwB9ss3RPyb7sL1VQRhXvao/XZ6GXHX/XRP94+LOtsg0sKe8myX0md/Davqwaj4Y+sDS5rhwsoQ+AFROGHq3sXOZliVr6GA9PlZf0LogE6Fz/NA7882Ti9cMfWBZeliivYn08TkC/rIN9PH3WcgWDfQJ6U1PXY6kxFHMs/MS4t0LfcyQR3VJp6DPDR+fyaHP3i+bxk168YmdHObAn8nTeqNJ7M/W53fzlC5Z90cCH5CZOLmXtz/gbWJ1LrWQ88x9J/HaP29Y/Tzf77V6V1HoYwM+YEioej6gqwjgodqZIJCyzxg1E7qQcyegDwWoCIjBTyocfYIvrBxUSSNicDunmj41gT55KATjd4j0yUToxE6CbdqIHtGgFPRRjksDfYTf7dAoPYldYY6rnNo/dZfC22z7paUS/sDvMwNH/8g+TDDEFZRQ/sdTBvXdVberHO6jSBvVxt+w6J9bYvjWRP/YjmaI/c2qWyG8qOpY07qUr16VQp/f5WroQJsvtr4cvRS9yLDJQh5FY4M+aoROFdBnw2G/zbnkJ6M/4uldEI10cM+huf33sELVAH02svQuiAia1TOHp7edsNEMsUL5PsTcQ97QQhkYQE8DfQI4sYSK62u+etdfFFy9C7skfVWpGT5xNMdRrMRZ4NlU874Z2s4SkT701OmaNypbH9CBSJ9rTprOU7YWs/Qr+XnoVy8x4MNuPRzoQBpXbzRlBgM7DPoA7IEXZA6AGJAB4MPlWJ0fgEOL3/JwDvrAdojyWfblzbwLZ+hTFPhAJw30Sa+yotE9oEGFLOq1q4KQTJtYWBcJotWlgBlSJw1vyHo21DhcAA5vh41XxqODKLgd6idUpE8doE9qg5gP5CdX0wf5yAQS2gWDwM6ifbm0lX6wpXcVhT4hwI6tbzxO9Xs6vvxNHOv9SQwgzvCM/sFaQwCeIi81rm1c5VzHlPcovcXW75ea6B9XVxaSayJ6CrnNqRFAn8kMg8zrWRBH+gjoo0boSOizT5zeZYM+aoTOcipCx8HC81vnZ9KyZKTPZawW0f/qXeqgISty4+g10SE9A90NfWwTkrdXwjZooE9Yf/pqGy/QR30dUP0Q/xOps3sGDt0vIzt0z6PGtqq8Kizb6+SGNun1g+2t/v2iYYOM88A0gqAff6i+cjIjj+W0hQQ/BaCPXySPar3auiPQ52+nc7MOeE26HPyDt72Uc/TcA6bwaB6+qhr7AyAIoA+kewE0ggLQAIYmsr/v/EG6ahcoOnbtlow+J+hTBvhAbw30SX1eFPpk2hGXmk0vAYTy4AOdGipgMgKlLoI+GA7xO4ccMwImJjikpHfpavJwrfH1mXgV+1QHqQpE+jTQJztFZoFWdmanIFMIeAMWuIA0Hzk5qiKRPtTdUMIf0PuJgku/u75TuMrhI+faxlWO8l/uZuqxwbdfVbUEQE30j4fTNaIN7CnvQ5uG1a1LeOSLhD5DY7/NFE6WETpfaH0p2sxifdoNfc5j0AeKTMu0LJzeBSt1bY+28SXn2T+Rov+H3xP4f7AV/oYtO5j0vj3788gmGCdEBM3smd1dkT5lJyjbCRFgfwN9AjixhIrxBH34I7aBOrC3YSdPSTCjghob+KGUgy7cLvPbzZxoIAYyVUEfCXOwfhUyaWUqBD8e0KcY7LHNj52APnASyXQsDH7kyQUAqG/BpCTFg79/sv+DNC/YCCAok+rFIn6mzZ4QLTkuT+ikznEHfagLy2WbTUbdr/zWp3epgmiqsIEaPqvF8kWgD6UfbWugj/QvDa0y0AZEUNoWPyoY6vD98lil+sjzAoGjfLqWaGvdToIpBK5yOtJ9oFsXYQN9F42+0cETF6hSRVsxlgb6yBkHe+JGtPrXxzUAyHaPpPS6PGVVpRefuy52mGRcbSyi48tN9I/34Wkgj7fLSjeAOj1TWIwPhj5zWFlnWOVqKtsuoc/nW38XbY228PQuSJ2yRfqoETpFI31M0AeifbYwEAXXsQp9YEUuAXsE8IF7xDYmvX/PwRz6DI/9LknvAjDUNeldISat0meNWUEDfSp2sEV9A33yDlJBDUhQ21yOnBH6xO8MOj0S9sj9VUIfVTcFfXL9s/eG1hIWgVQR+CGgTzG4U/TBtI7QR47lybu3xi+cULiZreKFowPiE4uv7MVg0JQZE6IpMydEsxdOig56Zz6kzAp9Oh3lY7pQalLEmZuoAzi6ej7quCyAJgOtKbzt2j4U9KEglAKogqZ3qcpUGCY5Swa+xFcMhjVYLjkGBPSh5Hygj9oeH+89GPr4wp0ywEhAgM5DH5cxmO5TISJ9qLun3HZTDIBON0T/FL2Pur6HuMrhB6YibdQHrhA6xHlW7NMAINpvDeQpdj6FbAXQZyor2LxXz3z2/318KXO8tLmENUWgDy6cXBT6nNs6j625tQ+HUABrlg+9Sww/vhhXDaxiETw7OPSRkT0izkdAH/hbRvlAYWqIGOoE9Ck6d+SOdTBFIc+irK4G+lTnWxfNDfTJeykU9PHSo8QCgFUAfWTaF3yvAvqY0sasKWUJ9AGOkB0AMRyX0zEjw6DPM+QUZqrNE3LOqyP0ecVJT3InrT91BocM3BfwJ/b4WLxYF+yDuj2whLvcJtO6Nn1zIasHJCKCXnpql7hHniSKPpOfBvoIt6hntfI7GPTRwSMKsuAD1kCfFLzlgBCCOqGgDwmF4gOiQh15nBK72BcdpDKkd9GpZAg44tQzOGUzAEz0KXV0KtKnDPTxbcvnti6CPiYwI08hFxkx7uzHpZ2EP9ASAJDv/dRV3lXONGb9DUu/x7dfSlMIHZReWPr9Z03x58Q1DfQpcoaHbXNxazWv5SOhz51jv8nU0CkKfdQInTLQZ+9o3wTWZKHPWHTpwOU87QzSPERMj/z/FPrAvq1MalY0hxVunptAH5neBftP2PiesI51mJsLdVjV5FTIGLpRA30COrOAqgb65J3mBWsMPvfSY6EkNuiD6+34wKFS0IeNnbcfqRj6VAl5zv/Za8Wy56wQMqySBZ/L3nIb/7tT0Af6vuW8Obwg8ywWnTPGVtqCjwQ+8P26FXGhZzbJw9Lt8JFwB5+Tav2e3161gMMegD5SL5bPwZ92AB8woN0rd0GfFojjs18b0cKdizpyAjroiGjliRkjJPShAFMOpMR24sErMmUifXKpZw6RPvk2yEadbXw7gkLyJwl1LPBIB3XkIeUQJtuXexoXu27xGND3dHsKk/gwagB9bPBBB5+o7aGgj6tNfF7FE6TyG+9zlVN1mnTY+pem2cZD6bFtuzkGEKfVNPVLOSy5nyHef0LosNlJ7d8To38ayFPkTKm2TQp9FrA4mOkRQB8qQgcifbYxdLKAARhYvet9MuJGY54aoWOT143y3Na5PKVMRuhw6MMv2vTKXTmwMtoV7c5An4kM7UCUD/wHtXxejF5g8UILOfSBffeM3cHTu6CmT5XQJ/j8Elxh+POrgT7hfeqjsYE+tLcwsCmS2qVrQxVy5jV/HKAPRP1QYk6pWJqTogz0ydT5we9N6RuUz6mYk+156JF8pE/IOe3MH/5xvOx5T7R7Z17zN0+6NzqeZTRTn2+xG8WqKC22XGqkROObzp4VTZszMeqbz25LrC7PhEk9Uf/x2bo86lLsUo0KerD62y7fixd6nsrSvagPhj4zvnegAGKsTtBuFhD04nvu9x+mSwFn0NpAn9S3TmCoPPTRRyYpVzCR0sSNxYBDWt9t0CdxY2egDw1xdHDHAn3U4wSHqIPQxwZz5CljkrPBDDcwlNUCv0IAmuyrRRid1P3N5gPVDup3mW0S/oCOUy3pX773Z1958p7lf1ei732B9PiqMfkAon9uHefRPw3s8T1j2ie/ihVD7otm8tW6APrcwaAPLpx8QM8h3JhfjN7EiyZL6HNgz5LoTzYepTUUoA+O0AkGfTZCelf2ipLRPhDbIyN9IIVLpnhtZshnG/sPQ5+Devpztr/uriODOj7E3JczqBKlQYedi7zl96YusDusFzqnrYE+tO99V+9StfiAIi5rWZkLp3rhtz0dtLGmZsUGl4U+SVSR8u5kYVhOJ3wG+oSeE075t1dx+AGFj6HmDfXpJPT56bmzOfSZNofdmhj0gaXaZTFmgD1HvWdeYvJvv/NMbkUuajw/O38OHy+Me+Y+k+gHX5bmNfHr+0e9DDLxgtDsbw5+2B8AY97gxwX6mIAPWKk7m6h6Pjp5VQel0yZj2F+rSB8bNFIjWCifZXQQQAS3IWBDJnUJn2kKFKIKI+faUnAp0396jnhH+rhCH9UGBFNykTrctjTiJgfXkL/aBn2IPnWwhT+ExcdMBxxcttt0yNNiT4M+PsAJHwv1u+o/fJm5wCMffVL2pzGAAPjje0/2laduUCF06Mbt9FRSQqis7VeNo+LP4iWvrEdKHIymqZMHVrbgnzbZIu0K9IEaOrCUuwp9ZCFngD7qB0MgNUKnOPQ5L4E1vKbPxneS47pw4EIOGyToAVmI6NnN/nt97+lt8M4AACAASURBVJ9bfXHz6LrorKEzrXI+ApWc/ZUo9RmVXbaJ9LH7qEqJ9f3vrlJ9ad1Hb/qul47cuxdqLVfv0kbbxLJeaVmEderqXy4DsIGfMtBHXWod7JGwpgj0oVbySsYoy1G4DNoi0/MgEekTQC9X8aG1R3H4MWtfGn6ATKegzz3/sTB6YuNWDnymzmLF5hjwAfADz0j9yx9LVvc68l17CXew7fsf+7DVNTeeNYtDn3kHT01l2bvppGm90eTpvfzvZ998XxR9dT+W/iWgD8AeAD/cBvZnlKWavfDu+619cQEX4ANyIaGPDhDZgA7YYZPRwRRoatjX9vQuyhZiW/BIH1uUD/axAaIEhz6aSKUMrMHpXdQ46gp9MMAzRfp4QB9fGGSDO7ZIFaq9TaecgExtU5nUAhe9PlAGy7q2c5VTxxhP9bm5NzTg0b034O0S/oAxHyOif0K8e9RFh9vNLisVwna6355IRP88wXd369LvTXRPkbOq/W0A+sxki7QD5IFIn9+P/TpTOJmCO5SVPxu9ITpz+OPJriqgD0Cc9/FIn/xnzcAlPBJJpnQB9IE/z0XP8Eo/8IwGf8ul3NPaPxOiney/M4ZOD+78SuaISpSGHXoDfcL601fbngh9TD4yRei4Ru+4ymE7ykAf3Xhcavv4Qh8j8OHvdOIlJEikT5XQ5//+3REc+sw7KE3fmjilJ5rE4MdkBj+ef3RnR6DPyNULM8dz2wssFxnAy2S2/gC7N0GKF07resXb5/LQyAPfbijEHGscPIUVf2Y6Fh4+PenjDw9sT6EOgCX2kTV/oM4RyE9kfQP0SeATk3nhXffb55oQ0Md0JoVcuYs6a00QSNnXVuijQ9tqFA0eU1Hog/vKRenEp4AJqqhnCdZhSRvLR+2oTkczjRq95NBPZdBHGVelkT5thD42YKKDGQ30ycY0jAfogy9rDIBOcVj9i7pxhHhXCaHDflPLS1TXL3Xzy267aumdiUF1BUBp6kZ1nipy3Jo2dg9c1FrJCxwD9IHVre4Y+1Wmhs7Q2G85KoF/UZfYBIMTsWJWD6/386nhTyYdQnqXTKcC+OIS6XPrYb/NGXzt6HdZFaH9eC0eADpqWhZOyTpv4DwOeqCODyxDD/DhRYZ9wEYMfWC/HIMo8rwl+tRQarvda2aJSq+CSpWXHblo30CfMH4sqqWBPlnPdQP0kRbD3d81jUt3fvhAH6e+kkeS8vCnskifE9e8nNWpEUBj35cLAPLMfexfASaxNCoGfkRUS2/03VPvD1rT5+Fr9ucRNIuWPUQeDxX4SKGdW0aTNCso1nz3Dc8n7Q87Zg6HPvAvZ0vem635gzt5bP3i6DfffobjuAP+OK1F9OBtL3ExAXV6oxkL2A2P2Qh/QBaWfOfRPhD1wyJ+Jk1lEUHsD/jpuXfcb553qoQ+ZVK7wGqfqB4H+a6GPqZ3i5DQJweNJLGITyNdpJAaZYNnQGsbONb5fnJAySfSxxgJlO2PTPsrm96VAVrCGQJgZceZTR1L98ntoSFOp6CPHSq1P9LHB+yYooXEQ3L6aUdUj0ukDzXxQ7tb4vQvE/wJ8V4SQof55pXfW22fdsCTWpSXFdE/4v5fF/jTRPP4nmH1k7dBn40M+kClHAx9ZAqVBCcQKYOjfGCUGPpAhM4JQ/aUEwr6uHhMgh+I9tnJyjYD+IEVyf4QPZ2s6oWBFUAfOYZdrAT0vj2LokN6WklXZWv7VDqPVKrcxdt2mQb62H1UpUQDfbLe3dOgD4yegjllikOnLyHlIn4qgz7LLziM23jAa/LwgwOOOKrlx5c/Fgz6DP/rvjFMiaKtz8XLcTEbYEUuSOfqJVbJAsADf3bvyEIfSPn63X/+ITlzD/2zWRz8vOzEx8m5AtcAgvo/1Lhlw9n7TU6XdWZvh2AXj/yJIZmM9pnS1xtNYcWgn3/n/fT8FAL4gGbqWRi2dw30IaJTpMeI6Btx8SCXUt9DR/qMV+ijwiIES0jok4NS4jhkIoLgR1HoQ9iTBTPxcWcbc9tlCCWHO1Iu/Z5AH3Qsuwn6lAFGDfTJT8FF4ZDpncH2PoH3S/gDln20YPSPHJWtX/oGVG5rtX3a/sUB2+4Kg1K5q5b+LlHQKQDUAJ9y519dWl/Uuggq+mQiffaJI2sAntw1dnu8KhaAH4F5xP+LJdEhCkiN8oGxFYE+q1treMFl/vgXxxXBzfAvet/Ot0HdnbT/Cbxez3YWp3P20KcSd14wcEE0lUUsQdTSC9GzfFUvablI7kqXcgddEOXzht5jyMNRFP5UOrdUqjzMWdlAnzB+LKplPEEf3auQ9I2s6WPzlUtNH9PqXHw1Ls3Hqlvzjotr+qTjEd/KApo9DvqA00zgRzoYVs0IsXrXb744nwMfqI1DfabNTYvaQO0eWC0L0rqgfo58eOLRNwy+wGds91h0z09eSFQd/PqZ/J+DD/ugyPNXPzIdjNcAim8Kzz28g5R9eoTdVGVQQBw9wIs/s+98DADE+JLvLOqHpcHN3HtStHn5A3ldDfSJfRII+mTgD3EeWUFR3pw8+ECHUQdMQCQHR+QJk+2DjHLJtKfbOdX0MQEa2UcA6EOmmJngUXzNcE8AH6KOi2ukTwbuiB9ZAJUeCyfog65rU/RIuyKA5NkG/XUS+tihUXpduPiNz9HKjKhrZ+tb1VUU5lA22exUJ3Xb+4RuvwRALvDH1gd50yq5sbo+XYGNHICLvIuMmHxuv/ppFv0jav21D/6wV7rqHFrySDfNfT1wYetCVtFnL17IeSpDJXewmj44LesutpqXqIWTrYcja+eMRqPRJ4ZPi9QonetGv5foUdOyTKt+gT3p8uvZWjwQoZOCp15ew+eTQ2dkhgzQBwpTnzH08eiSgcsY0nkpAUUwAryUO9j+ut4/y7T/5ejNrP9dHCadM3S2rzu5fKWXR6XKCw0316iBPmH8WFRL3aHPsb2bckPbeXc+tdMGfMRdUENUCOfZVu8qA33U7jKQqAD0AX1qsWaXej7YDlt7qhi0bE/2hQ6Iu9eznqks0ge6oaAP7h7gx/WXPqqFPkewIFGXz89Xz01SyWA1LuoD0AcieuBuoK6WtfmZnbwJr6vDoBEAGDXFCyJ3xkbHounzJpIpXrgG0OFvm8v7efEJoVf9PDG0VWyCoyZvIPIIwu/4RRYe7HjQQxwBNO8KljomP67AB+SLLNUO7cpE+rg8N6syht9auJE4MnaMSScJB9DRKQJ9LDob6BOf5/I4ESCpMuiDAEw2ckcHd/TQJ7URLsj0nMlF+tQQ+hQFTDBKW1shk30Kptq4Ahrcp/q96L5OQh9XgCTPKNP7hO1dA/b/LE79An0fKRn9k7txOW6w2emohhBzuanIZq6yReSoST+Krlr668TmKgFQE+FT/AyqY0sT9AFAcs/YHSxWhkWiI+gjwYkpUsYEfaQfVPgD1+4aFu0D0TcYNIlqQgIzyZQymPe3RptJMPP5gb+LThs6hXcDEAg+0FpCH7AfdMFS7mphZxm5VGYlr+rmIHRTrOPJFNtEQZ/kHlOpc2rslDaaVnfo47p6lwn6pHfBovihjQfE00RP8fYNhDggvrZ2FPpceuxt0YH7zysd6QNLr/cwZ8zZn6VNGT5iWXSRSiWXSE9Wy3psRzS5j91WYR+DJCr02bs1jUUFjUXzDhFFqdXaPhj6DCyDGkBsZmX/w2lmY2ypdvg8dgqDQnJyZiAp/Q5RR3BTYVM2AKr4s/jraX2hZKMr9Cm6ahd05FrEGWRtAMdFJjT00emjn9mVlC/iUnKFRjoooJ6bCQCRpCAWIPuhZToW6ZODN8g+DFsyxx0BE9S+gT7piWGDLDqA4QJVqmgLljfQJ3/8kjmduB/pnrltz+K++yUAqgr+2Owx3IoddrnCGOrGEnKby80i29/tVz/Fon8e4GMMAX+aIs0Op0sXi1zQuoAld83n6V1TWKzPnSyyBxdOfmBsE0Mwm3lSlAQkApqIfxT9+PCp0cWt1dGf9b7F2Qs/H72RR+mcPXxWpo28pi9kNo2ymR2nZUnoI9OzdjANZw59wtrnmoFLOUQSSV2AeoTtGPpgmAQpYx8fOtWq1yRQ6dxUqfJSw04aN9AnjB+Lalnf/56iTdvS7uhN33HqZ0+FPtI5vkDFyallhOoOfWBsumgfAD7wCQF9fnzGTB4Ns6A/XSZ9++bdvBiyXCYdom4gXYoXTY7TwMQy6WLVLPi8+LiIzIEaQBjiwLaZbNl5ADH7HTGdR/z0zWe/EaCB77//r7QGUP8bRQ0gkN21bSy3StnDH5odt6fPABL0SFFX4APyRaFPmSgf6Nflmd0Giih4Ql6NWBD50+V5XSvTQJ98ipnwbS79KdkYH3cS+mjAFnAgDJBQWpboTN0fH18qfQufdzxETmOvtnaPaJCMjwRTCFzlfJHtUwdwoI/QcGdPhz4u45czgy36xrZfp6doO5Nd+O5ge9fQ7Q8R/WPrm76LuWx1uVFgPa7ytpuLepMyyetuEpSOrJ6rlv4iMd4XADURPS7nT/fLqNAHavjI9C6AJFCA+fzW+XygeDl0ACcAbmDFrktbl/OomzQiiF4iXdYAgmLLZw7ngY28zi9uXcx0s1Vn4+iiNC1LgBuI/JGRPC5HAFb1ksWbJzO0BbaLKB9Z5SeNIKJSxlz68JkrffVl5KubDEuZRTVu0ryCu9RJYQN9nNzUPqGC9KZgs+rGVXfoQ+Wdn3XNayIJfMAzZaHPtR/u4+lY8GfRkX3c2Y/+fku8OhjU+BFQBwBQTwx8QFbW74FIHwA/sFIWfIdl5OED6WDDgyLCBtK1QH7rc7s4+AGQAx8osjy6a4zXBYIooJGbUA2gP5nJoQ5EFkENIR71s/zB9GRg2x/64OzMyWEEPVhyT4A+ytVG1m1JfDJOoU/mXYOGJkEjfVRlGMaAr3UQhe9D9rlCH0rOB/qo7ZGNIi9SnCD5Gj0K3JHtVBjUpdDHN6LHBZiYZbJ7KaDl0oe8nLGsa7uictCnqS1lk25bXaEPvnW4RP9U907jCmykxb7gRtcOTwym765y6sSotksmlMT1t1/9OIv+uZf/tsOfpmZP5sFoHP+AOjzrWO2dvaIFSaSPCn3UJdJvGr0uWRb9tGGRQgWfla1VDOVsT5LAICGLSsuCbRA5dM5wWnyZmgfPY0u+q9BHpJVN4Ct0uUT5SNsuHljNgNQuDoxgKfdJ7L8X4qXcReSQiAOCz+lDHyt9xKubw4gbRmlrq1PQQJ/qfGvSvL7/vZ3p2LHXozdd7SRJRfrk7+K1QyP5sRU0sWAzJ98WEqor9PEpMlgW+oDjZFSObsUsSNmavWgyj/Lh9XHgfRCifeIl0mE7FEyGP5PZHwA/AH1Gd8XFleN0MIgMAsjz0tMMDMV3lV07IJJnNNq5dTT6w/3bk+O4+I/7OAyCFbg49GF9fuP4e0QqG112yO0caAfwAUtCR/r4Pr+PA+hjBFUOQCeNtCGgFgU84LjlQA0Ni2ggojo9PiVJ+KHuqwD6kFBI9qtAHXn1JLYWgz7ZqKN0jMaaPkqfUrZTkT5loI9vW/GykIc+NpBSJdhRX2BMfamy1O+iMq665Klre1Epux/fYHD0z4pKav/4AB5X2SJymYkWucB0Q6La2PS4779q6U8TO1QA1ET3uD0GjRcpADW7GEKZF+0dze7Zi6d3HdBziHF4sIIWRMuo6VmXtKBo8mbeVizxnhZ/xkukU8u7U3PLKmYbyMq0MpyWderQR70Pwfmsts9kbvm0aL+exdHI2FCc8AUgCSycyFchK1PLx3Uu9TYeN7BNxKWUh26cxz4+72ehrdlT9I1X6ENDkNqhkexpVsK8Ek2rOdXrAn3KTCJVQR/w+IO3vZQ4HtKz4AO1f8BvvXHBZv6dASAAMzIiCJZr3/zMLh4ZhOv/wHeQgfG+8OiO6Ml7tnHYM7ozfxdYcOhUHv0za+FkHkEEkKn/+Meiz7CVDPDn+ImiRpDzZ7xCHwsUqlWkj+Pzfd2hD1lLB5+IOYCkpFrxCypugCJr6JXBCPhEQh0LPNJBHWk37FeihahIHxruEMu4x2OsM/RxBSwuQKeYjB/0cY3KAdcXgUOmdi7RODZ/qvrlqeeiW9fWtN2kH1+uru8iqhysoAmf4vDHFcbgCYOaaHy3+YIbqn91MrfptO1X++ATknJ7F9tuv/oRFv1zN98n4U8DfZyfhMaF4OrWJRx0zGfQ5w/RUxzT4AgdmY4la/nAqlYQZQPLoeMoH+mMi1or+cpX6hLpuGaOS5SPXB7uvIHzk1o8sHw8/IGIHViZy/dz0cBFLG1tUTSjZxaPQMLQR0YQFYFJlB2uc6HvGLh8pcoLWWRolBqbu6911ThC+6Vafev7j6u2g5Laj970bScNuuB/0bh2SCQ/ppImlmzu5GMvIW5QOfTmVci5DNyhBzbG0rvmly7kTEX6qP09tYktkw7uUp7x+LtqvDoWT/lifyaz6BxI3drNonh4dFAcFcSXUmd/YJUvSBE74G2iMDN81BpAM/ZhNX8Y9IEC0BBpBOAHUsP6lz+WMU2FQLBTC4JCAh/TNesT5UPpcXkHsEAe9bzWAxRFkQ3IqPZS8lRMI25HtkGHVYUZNh8RKU2ZOVW3Xz2fKRupthRsyV0caG5B7y15UBSPWwd9El91Bvr4wR0L9FF9Kf2vgKh2RfroIolcwA0cNZCzAQ6qj3ybekEfH6gk/SCv3jLgpkxb1Y7MTSL+YXtGt+03jRH2SfgD3/UAyDZxY8tdbgS2yVHq003sLhO6TsZ2s7D16Xgj4DczGvzI0V219PrEcXePZJ8RqHOh2TZ+PHAuS6NawHAIFHK+f+zuDPSRsEbG7AAgkksknzV8Zs4JEO0DtXIELBLJWXiJdABCZw7ngU1u7ogf9i8cuJD3J9KypnLoUxTMrBxYydDWfgj6bOR6QSf8P+Asn5SxInNkkLPGdaIN0lkoJU3ETyhPuuhZ33+8i1jHZI7e9C1j37ZXING4dkgkP6aSJpZsHv74ZgzKWudqqxb6hAc8MP78bNkO6AOFma8/bUZKfOTg4MyGlbKYWfIkh5QsfjozwLLXgVM4BOI1gyT4YRFCUP8H6gBBOtjitzzM5TH0AWgEeqDoM0AigD6QGgYfiPaxfbTRQCGhj+kM8YE+oZ7rLe8S4xb64IEl8CA+QzBMwHMsBZXkSZXTgWCLss8r0kcLiqStTIDS7wp9qLHiPqlxUX7g71fpmEtDn4wNyJdo2OKdLt+nC5QJAWiKgBs5Gxdpa4I+ZcZM3SFwX64wx1VOXjKmPui7Fv2Pvd0OffB9KY3+eTnabLppuNwIXGTUh0ncxnST0MmpE4dOf5H2VBs+GRA+c5GNWPTPgwy+bYwa8GN7Sho/+wH67M3W64L0rvvGhjmskaAF4I2sdwOrWj0XPRPNYclgnxg+TesAKAwNr/jUEulUlA85x6EXAFhyHcAMpGWBXZ8Y0vdtOioY+oDcvTy9ayLTDDBpUmGYhPtsC49pSyehz+8G+oT2qEnfeIQ+6R3M9BzQTi879FXS1JLNHQwsKMINy1rnamsCfcJBHr8ZMQT0kW772QVzoucf2RHh2j4AfOCz7iOsyDPzCl8KPTZRrq5FhWvOPWAKT+/iAQzs/+Ry72JJd1EYGuDORPb3nT94NnPk5jJYNGUG7Gc37LhukA/0UU+DHASa7JASVnTVLui8ZtAnR50zZzf6EeydQHP5mN4fiGf6HFTBBzbRRdiv9qOJ9CFpPH7nsEQQOUEfxRYy0sdkXzK8+EvGPuEQ3lz1B9qW3S8bpG1yQLBLoI8JElAgwgcQUQ/CPjple99Inwb6ZGdvVxAErWx3TtN+W1v/FyNxQd669omk6YrBw+PvpolWilNzqG0bBUbyDzc0VMFyNj2++6nx+twMbLK0/quW/jDxfQOB1Kei8fP73Na5DPos5NAH4Mo9Y3cmkToY+kANH4juWdO6NLfUOvYGpIypS6SDXgA2sLw79cnMH8rLgBqhc8LGYstRgx6Z3gUIYmRsI4/wmcpS1SBlrGyUj8scGuSs8Zlsg3QYTglGP+He+cLZN140re9fXuuhHL3pm6R94ybCx/QY4nFkXEGKh8owotywrHWutnLoE+7i958NQ0Gfn547m4OYGXtP4pE48H3JcdmoGjUFS3qfKgAN6VnJu2MMfXjED/Msj9yJ07zg72mz2a2ZRfIc9M5HI2kHAKEE+sSFoCFVjErx8j0LyJQwDIJswId6jsZG7CnQR/vsT1w+vu8JcElSz/rqZBQy0scRFtE1d7DB6N2uE9CH6hNvo6AO9mtZ6JPpSygW4AmBK/X4Foj08YU4vvLSJSZw4xLpY5dJJdoFfXyieXwieVwhTVG5MuCmTFs8vbvdpXOTCQNA6f10xeARSKUN5lBPYLYJlbpJqW1M8IlfsMqt1dS+GJjJdoD7pMan2pT3caovlb396nuZ73/PdzXwx/dpqV7ysFqX+rl29Ds56IPTsuSqVjpgQ40QoofEelgQSTOFwyRY0v2c4bNz4ibgA8JqhM6JG4utTLRyYBWDPiK9C+DD3QxusX8eZfFDfUFW7AJb3ea2AOdE2zoKYKuiogE/4X2qalzf/77qOynRw9Gb/iPX2g34UPflEoZU3dSVhGjsKNm8utGVgT4PPPxMgOmruIpQ0Oemc2Zz+NI3j2VBs6LMAH50gMWlBtCT92zlBwyifOQHRxxAHSCAOL3s78ksqmfKjAm8aPMjv9nMon8YdIKVwOJIH1wQGgCbS4qX79mSiwaaZokG0p3NOuCju9Zdnvd9ZRT5QpE+uud9p3cNwmDdM3xycsRfkJwX9DHpd430yb1DZCEFmX6Fj6sDgHKN9MmPHdmi2JmL9DHu5xelcDb7izw3ikCfuE0+qijuir+DZf2ZGWMDfbij3CKDsrObDsqEADs2YIVtVr9LK4sCHkpfUXBju8Pa9mOPu8nqgISAEbeuFfXsVgweKS7EzMf022kCJvTZ2hXZr5t0fSZ7aqyq7zKTrOIvys/6/q9a+t3ENw0AUk6TLvhJQR8Xs2HFrk8Nf9JFlMtc3FrNa+QA9IFIGqgNpBZ+JucB4l+AJfSZ2TObw5qQ0Gc6Az5g4xlDpzuPzSToNrcF6aqNhCmQvbGa3GqbbXVa2LHUVdv6/hPqahq36+hN/56zj4I++Tch6mWuxkMtaW7J5tU5hhuWtc7V1h4/6BN+dggFfSDCBlbdmj6X/fsGr7sjlknXARYAPzjCB1w47+AUlNz5ozRlSykBJCZ7phugEqzQBRcLFH3uW8AykxlsgpQvuQQ8pHdh6KNGH1V1VhghkOns8InyyZ93Yjg+7wAO8pnJKGc72mB77lf70soTDvJ5D4gP6riHPsn7SvwFvb+Q0Id4v8lDJCakyOVBTNofeW64Qh/cjyv0waeb2l6aBXMDurB14KHq7dIE6Me3L2hLARy8PdWfam+gT3rgXWERPk66+4Htzmvbj/W6yVIwQk6g6UUg4Q/sWTH4KsX8ohOyrV2R/WobdXz45qCb7F22qz6ytSm2/zdX3xNtWPtr7u8G/lT1FBVeL6RebWcxN3ANwgpb4r/e6C963847A7gjizDD31DHB+SpCB2bdee1zudLpAP02bdnUfT+oeyKQu7QJxuhUwb67MtW7+rrmZnAoysGPhcM+FD3JpuPSu13m0hLdVFlYwl/wmV6VGltd+le339irQ0+etO/JfbpInzwHTH/Ulfr4aXGmd51HYZQsrlDDwVFuGG0dTabDdCnPTNaKOjzs/Pn8IgbgD5ytSy5TLrqVqjvI6EMpIEBIMJgBtK4HvntFg5zAOzISXFslPlEccuxa7eQRw0KR8/ej91yWbTPUR95quCRDdcsB4GmayKBfKAPdXa5bFNlLL/3KOhDvgOkkIOfEQguZM6Q3Hsa3c4pvUvzzpeNbol7JyKRQkEfW2SRFvpgH6lwBlwI25y24zQ91gAdn1ykD+qzLtDHBm5comnMMtm9vtDHpX95jrv4VH3wN+l30at7kXABOi4ylA3UrG+7G9v2Y512WR2IkJMPvf/WtQ/xblYMvhp1VwTQ4Aca3/bUzUSdzKhxqNtsMIayUW2jmUSTSTwzASmHXZ2g9L6/amn6AN8AoHDPTFVpuqh1EYvB2cXX1pLQR6zOJSr4pH/3MuAjVp2lVuqy2Qf9wGpZMkKn09Bn1cDFPL0LoM8o++/9G4+LvjDwpSAFnF3nUZvPvPbbJ1Ivde0WbiJ+qvP4+v73V6c8gOajN/1rPkqe0CtXCgzQZXtV2MiHozWB1Dj25iHGDaOts9mMoE9nZrAQ0AdSu2RhZUjxkqtlQcQPleJFQZ/eiexfXmDJdojMYdBn986x6FEGfqiPDvRg2QT6sLSvo1Z0Hvqo4yDrAgEIaqAPkTOkXF+6dwjlOiwU6UPqrhn0McElFUglMxACJqi9LdKngT72iBsXcFJVpE/uwTGeaIoAGmhapJ3L+E0vBaY+VZt0elwBj+4ua7v7lt2P53+brlyoXW41KjMUunXtg0l3KwZfgyZPE8ChYI1UgwGIbpsrQMGTtA0GFQU/xaCZGBkFe1Sb6bH+5uqNLPrnl1xLA388HqDbLCoKLW/mmAf+g0gfCX3kEu0Af2BuBblPD59TyMKLWlA4Oa2hUwb6qBE6RQyioE8RPaY29rktYI9t7Syg3ck9Oj+AJuonjJ/X938gjKKKtBy96V+M0Ce9g9kQQkUGllEbwOQAKsqMwN62HPR5uqNTVwjoc/OnZ0eTp4vVtKC2Tgb6sNGpKV4u0OeID6WgBlLBXEAPPlJ1hz7UWZWLBpoxNRWjroKi20zP9/j5Fh6BjbLKTtM7BX5XMH3XxTqaQA/xHmGMTsrYSQOd7HtWG6CPOu4c2IlfSah3EhzpQ0If/Rh1dXHk+48tsqiySB8STCFwJc/NRC7dxyMEkwer/JVWNPqmCnDjAkzMMtm91Nhc+pBeqhL6uICZUDIwHhdd1Lipudl2OBmMegAAIABJREFUk7btxzrtspqLPwMkiEmPABa3rr2fd71i8LWxCSrAoSZ4EzRR+w0lq+oxTfjUJKizS2cf1m/ygW9fQtdVS7/G/27gD3U1dX7bha0LWeLWaIx8ILpHRPoA9JFLtO9gcT7w+eTwGYUM9oY+mjf+ULDm4oHVPPJIRPrs5pE+oT/2uS1gj23tLKDdiar8Mu78vtX146rCV3461/f/lV+DNksfvemftdAnezeiXvLabKxvdyVNLtnc19pi8txI2lKb/SzSp/uhD18xixVOnsJSqQD8iOXV2QpbLNIHPlRdH98aQL5H5vrTZ7L0LrZmAqR31TDSx2U8OQg0E0Eg3TlHPb+qndlk0P6ugD7Ec30w6IMVKe8hWt9gEIGPE9VelZXHinjvI6NuuP5YGL2fZGXRfmmP3JR598nLaaGP2j4zTrYT7yf6sKZ3oTapDaneZNjYf6jPTkEfXzDkAlnqAH1CgCMXCBNKhj88E5Os7nna9pxddj82xaZLH+mDLnCukJgkNNtuXXtvYsKKwdcTbSl96jZios1FISkTTM5O6uajjkPXr9o/NX48gZr8Y+vDpS+73Vct/Wri9wYAuTz1tEcGCi1vY/8J3CP/H5CPgD6wdXP0YnRgT3+uFo+rhV7Qx/Cm30Afg8ftk6nr4eqAXGp87v7a1ePqgCuVLtf3/5/OG2GwYOnIN3J71TujEKC31npwJU0u2bw9ruFGFjtiXQ99IMoH0rImTWOraE2PoU+cpgXQB1K11BQvAD7QBqKCps0RkUET2dLruhpARY7ieIA+6rhzEGiWAoGo85B6xlYVU8/ysYwz9DH1o9NPvkNoLnnb8zV+1ofL0TAmlyie9N1JkgTkNAw0sC9z7xhKWxJkaBxNvK8YoY8iXxr6qGPE75ugnPJBYoOyH9sWG5ZAH9SGBkyWmj5Kn1LHeIU+efiSj/QpCmjgTNRBqKI6TVBL7c/lNyVTdpuuPb60bc/gtv1Sl5sccfEnD4DkpCknEfQgkrnoMvtvXbuJ/14x+KfKg0vmIs9PeNo0M51NNlvxpE3Z67Kf8pXtZqHry6ZLvTep/jKP4aqlX+IDauCP+gDSmd9QaBmOmIQ8E9nC6vAHUrt2RjuiRT0H8hQvNS3L1dqVLVGAWdbQ+cDQ8ZmmmbnACn2gAPOMpBaPqw1YbtxF+vhM0EUc1rY2DfwJ7er1/R8MrTKovqUjX8/pU+8uQoDeGtSY0MpKmlyyeejR0Pq4kcWOWNdDH17PR66YxYoy80ifGPrwJdUZ0FGXSb/p7FkJIIIVv2w1gIocxRs+PpMt4d7dkT62cecg0OwAEEg5jwtBH+rZGD+/q9dL5t1Ac8nbnuMV/V71fLA9uef+eIOyncxCc2kr1elkdX5i8t7QJ3ElMQbKDlvEUGIzGBPfkjLHDubBbF9URI8uesgIfRS9/JBl3rmETe2GPiYYAjbq4BNsL9K2SuhTBdjxgT6ukTmh5fBx0s25Nlhj2y/1usnlJoe4OT7hdZMW1RZvS7/fuvYernfF4JvQsNU+ZD+6Cdg2MasThGq3br+rXhe7fHT5yKq+0Y0t6/+rln4u8XcDgGxPOdXtX9W6mKGdHTy2R6R2CegD0T7T2IpbM3pm1QL6hII1qwfW8PSu6Qwe7WaFrD+wMQuhQnjabX4L0ZOio2MdhxxLPt2rSfUq5t/1/f+3WMM2tVo68k9JT/gOmHZPb22TeeW6KWh6wWblbC3amhtb7Mh1PfSBoW9YOZctk86ifeKl0jH0OfSEx3NuvfkzogaQTAeDiCAJflRAVPSY7AnQR/UNCYHU89LztzFiJrOUkvLeIH9Sz/Tq9ZKRIS4kmw5if22gj+b9LQ9wlHET72mVQZ+kr/gLeu/LQRt+7JiAFFV9j+CMH9xhkX7EmBOQY4I+RJ9VR/qYYA6+LtsJfVxsCgF2YHwhIoJMeqQPQwMe3buB7Z3BtN/WljofzPc1zaRRoKZPvjBx/iK7de3diTkrBo9GDzO5izuWs4EaPMGjycSaCmbTi3WpfcjfOmhD+VQnS+kqKqtv95urf8UKP/+E+7SBP0Wf9Mq1O7d1Hoc+AvlM5v8P9W5mR3OTpc07HenTTdDHNG+XO1KW1j6TcKWGlFdOVfpp4I+fX9f3/7VfgzZLLx35x4LIoM2GFumuIL0p2KyIheXakP/in6q0jWNcQB853Bs+weroLIRl0nujI0/Wr5iVqwEEkUEM/MgaQPBG0b/8sVIHZk+EPqrDchBoDosEGi/QR/d+IF9LqGdt6SAVcujeH/h2BEKQnDYCigIohH4n6KOMgYQ+JvsSH+VhDl1zp2bQB4OlQNDHFwbZQEqZaJ0ybdOH61SLzVZosydDnzLgpkxbPC+7vZu0F/pgMHTr2iFu7orBN8uZFJlfBuDoxiQnRxOUUSdQig7jyV1Dj8mbn04W90nZ6A6Rxqy1l3qiryxdnfi5AUClHv28GkNBZ/gA9JkSTeXg58XoeWNalmsHEEmECycXTe8KFaEDevaJFkXTevqiEza+23UYheTc5rlCqulGbe8woO2kqqbIcxkPr+//2zLNK2+7dGStcjeyoYLKTQrTQcFhFGwWxmYfLRbgoz41UKrHFfT58RkspWpfM/SBdLCJDPBAZJBaA4gXgGYpYdQy7z7HBWQBQM3adxKvG7SgP5v2tPDoh3zVjQv5HASaa4ZAzqld1PMxfgb3+k5c/hbAk3umZv15RfqY9DfQJ1svlkrfwsc3ZKRPB6CPDor4bpcuoUCMC5yB9qa2qf72Q59Q4AiPUf2u+g9PwEWjf8qAmzJtbbbnby6dgz4SAN269q7ErBWDb0MmmiCJvBEUhTLqjUKFTLqJ2gcY2Wy0QSDz2LKAx1VXegO9/epfsOifQe6IBv6057HrfFbbB2DPFJbUBQWct0QvjTvos+Hlv4tuHL2GQyiAPgf3HBq97q4jK3Nw2xlM2zuszHWxYjEg8l437sYa3pfr+08KrzSgxmUj/0DcUwN20AlVBclNwWadGCGxnLX+6U1nYG2hz7fYcpWrohlejnWFPkkNILbiF6R52WoAuRpx7Yf7ole+ey+j+JN3b4uO+og+Csm1r/EghyHQ8XvFYAxdgXsc9CHfKVD0S/psrl/KPnnOp9vl0qJUedSHCrN06VL8XETvF3nghWxR3o+oujhYXy69i4I68mLg72hpX4XSu4j3JGFD1p9Z3fk+bWDFF+L4ykuXlIU+9mig+kIfm+3qQ21RmEM9HLvqUo8TNa/bnrFt+7FOu6yRQKMLXTdRmACIDqLI7erfoo9b1/6eD2HF4DsV97hCGWmrahu1XSfTKVm9PQLwuIId9bjaj9NXlp6b+LsBQNU9cUGKF/unSoZ8+qIzhk+PbBE6rpaAHoiskTV0/mpoeaZpZi4w5O/4RvoA4KE+EvqAPQexVcnUT0gIZJ/nXL3oKNf2Dh3tKilGx/sIpU3Kl9656/s/XNLz1TZfNgKrOnYV7rA7pOBwCjaz21OFhCHSx3Ucexz0wcfh9i/N53WAAPoc9sEnSh8igD6wdDz/w+sLQeSQqBfEawaxP7t3jjXQR/H0yLcXRl8/ThT1lJ/j503Vgw0upJzi1LuKKmaT0V1Qpvcg3Id899f1IweXPG9nQQJdcoKWqTS9i3ofAI+T7xd5+0joQ+gkU8wUOWfoQ/jUCH0yYxE/8n2JA5ZAH3Rcuwn6lAFGNnCCHwrdIoOyFz/Wr/sOLYrss9lu06vul5a7AB0XGZM+7CXb+4Rtv4+uLETITVjKvGsDB3JypCYOtqxmMo+r+ymYAfDnt8lQVgy+Fw1LBz7UxyAbJKHs1W0rK+viu/TmYgY81PjxsdP5x3R8Ul/dfvVPWfTPNVxhA3+y81eoX7DSFitOEJ02fEow6APLwuPCyUWhz5qBS5IIHZe0rMsGrmD/ZLs1+ovev/RyD0Chs4c+5dVGJ+wzJ3Znh0GsdlCij/hJ7l9td7aD2R0WWd9/coctMHe/bOQryr281uaajXOlHYqWgs0666gG+mT9/+MzWUrVPixMdkZvdMSH7dE0LpFBPke4gT55b93/X4t4yhzAr+ce3hG94qQnM0IjVy8kXfz192Yh0PL5aioYfgM3XM020JM+V+tD59Tn80wb1LcL9MnYo4E+DjIdgz65d5XqoE8eCsF9Ku0v4wMMffBxcII7AaAP6tMFUPiCGF95OCuLRhu5tBUyWat8oY8JyoTY1y7o4wp4dM/Gtmfmsvvx7GjTlYc+6gRKTagm6GIDMjTgyUewpHoAgGxY+xs+rBWDEL2AdaiTMwVXpEdMEMgHGBWRVW0WdpdNzzIXzpa+MUEgk/+g9s8ZyenUACCfp0OzLECfc4c/w4VCRfqEhj4QofO+je9yGjQUf94ebWNnNCSs4f+H31C4WqxYBr/gP5D95FB6bjl1YhCyz3Nle1Dat73DwPZb1enhTxPxk3fe+v6PWD3aSYFlI1+O75udtCJQ3wXpTcFmgYwuqKaBPlnHdRr6SGv4MvJKpM+rPvZ0waNcr2aPrV/MDXKpS3TXP+3DgU8PAz47t4xmBgLwhwI+UE9pbDd7nWT3mL55E0UIKfvz1WNFgU/5Wb5gWvpDB3ZAwvSOktuvmQY6BX3wBa7YEBT6qMo070m5SBjuPwR9MGzJ+JbtIHTaIn3qAH1SG9AY0LDF+2a6D7420Ce9NEPAG9Cm82lR/apO6rfrtj0D+pjAirzYqYmjGugj4caGtb9KTrYVgx+Iv9NARZ8K5QuyZJcmeKIDSunEmI/eofxou/m4+Fd3fIoft9uv/gkDb9/njmjgT+bRpPQPG6xx7QD0yMLJJw69J9csM2/Fb+5qatavRn/GC0vLiCE1LUuXkgXRPlCbCPpQoQ8UrcbQZ5StV7aNSZ8zdLbr0KxyHWEwHenU6orAAg38cXHo+v5TXMQ6JrNs5Esd6ztoxyXITYmmQYfgpayboY+kwwctnh8dz0rYqZ9CNX18I3085b0OzjgUvuZvp/NRHfWeeUlC76JjHiZH+t9Xzot6WAT/lD5GfTSfaXPFPogCgpXT4Hze8uxuVkhbQJ+pMydEu3ex7wwCje6OolH2/b5bX+Rtbl2bRgwt39sBAOnAUGY7MQ3Y2hH7yQgU6QOqPw1kyeS3dS30QVAIfIDGoUuR4q4CjkK+z6T6Kov0IW0koE8i10AfOGSdiPRxhT4uYCaUDPYFnvq6O9KnntBH+FfYtmHtbfzXisH/k2xL96dy6TFxBSbKxKWto6MHNO7pWbgv1WYVJNn2q/czHYgybbf1EbHoH/Gv2g38wVd78e+hoM/q1pokLcsF+lwycFn0ht5jcobfOHot07OQ1waiavFAAwr+iGif7Rz6AOQR8T4Q3yOgD/wNv3cwmTOHPlHcYUTLjvGXjnUc1H0WZekgc/ffPWL8dl+v7z/VLtRBiWUjX+xg7wG6LklsSjYPMICCKjTQx2c8bavpowsBDAl9fvLJWdHMfdiKWWzJdkjvgqgUU0SKb2RQwcPUVc1k9M2S9+aXrJfQBwZ05DvTgtX7H5sHPxtWzeXQZ8b8SdrxQxreKIvsgVpHAH1k7SOoe7T56Z283c5to9HOraPRrm1j/PtLT4rt8Fn0yj4Gg8ai737s/kwfy/eJIZAN2ECrKqEPdSViUCCttkEf4l2iTKQPGWGDPUjYQ0bdcP8hqCO/ZtoT0IeSw3ri46KFPmp7fByVqJvs+5lomItYijtKtgeCPiaIoIMVZba3sy34sV3pXa5gR9iUfkwRV6os9buojKsuaantObnsftd+hJx2MlIny1itDpxIXS5gRZWhIEQqkwIU3A5qBInfG9b+IjkJVgzKpXNd7JDNfOFK2s5lefTUz9QNysVO6hjpdIU8Pjr/iD6+svRDid8bAIQmIs+vtggdV3US+gCsOWEov0Q6FemzcmBVtJNhGJmQtbRXLZ4uev/56I0c2IDsGUMfJ02CaJ+XWJyQjPSR6VwY+rB/6otOGwofFWGbM1196C3XsY69LQ3QoIn60Tlxff/pAfxbnYplI5+vTnmVmn3oBmFHyeZVjsyiW3mPQtK+YwoOfXzzO0NBHwA8Q+ufT6DP/CX2ZdIb6JOeOff8x0IGXbLnnQp+MPQBycPfOpdH5Bz0jkdyJ+zNn57Noc/cxWkUFwA5WC3tmfu2c/kx1lgWuE6KXTP4M3FyD4/sef7RHdEjv93CI33Uz/z+qRz4vPacZ3P71KXhl+/LIBD1TAwtM9uJy8f0XI7bI7kcIMEWJs/guEEskHuWVy50CnZI3S5t1faULdSYmJwR+ih9Z2WJMVB22OARtpXyA39Py/blDndElBn/cD3pd2N6l2KTlKUiXuRh0u0Lsb1q6JPXn90Cv4oCGj4foOvEBGyK7DMBOLVv9Vjhy9emx7etrm9bnz77TTblJs+ugz7yglUu3CT651Y+xBWDUFhTnSSJC14bxYMnRvG9PvV3cpO/MlbN5EYea90NT6cj78Pbr17HwNu3uN8b+JO/wmxbbBE6pva3HiaKnf/36C0MuLyQS8v6k41HJc0p6LNm4FKWarWVy1BpWTJWB+J04LOVpWWdPXSW1qSVAyujXdHuuHqPqOEzkS1QD+AH/gtdy0c1pGMMpmMd286u8PubFb7yPl3fT4PQ8N4vpnHZyOeKNex0K+IVzcWkgs1cVLdHJkBalzS0FPTxBTyUd8pCn+tOzq6YNXFqulIW1JIxrZilRga15+h1ppcHf8AKKrOImuceci+mDG9hS45LI35U6NNaOpu/qWEZGN31p81gwKcn2mcgTbt68Ymd0QQGc+DP5HiFs63P7xarm8V1fwD2TJjM/j2IgR+QA90H/qUASmrfM/aexKHPGy95wepQDIGWLzQBIGJq0D0DJ1dQ/AUzHOrdIievwBDY7wJuQIyawTLvPARoQfq9In0oQJOxFYhQ1gcZ2CJ3Eu8M2vQuEgrJPtL+culdCPqQkIpt1EUPGaGPGoUkj0GHoY8JsIC3fECSCzCqEvoUhUVFAJC8FE1tsf/wBFM36OPzbuEmSwEEecGbJkMVuqhtKCijk6EBjjgOAFvSqJ6U0uraiO0b1t6SHMYVgxBZ4GJPOmm7AR4XqOTjFzzRFmnnCnso3WH6+8pSWWepAUB4HjF9t0XoqG0l6MHbBfR5kdX02S+a1tNHL5GOABBefxtAzU6GamSZZTUtSxZiNkX5SFsuHbg82swsEWWbRToX+6c/Dn7g+6lDH3V1Syk5t7mvVBfZxm3vMKDt3qryg83dz/cof0TR+v5wRcm9D4dDg2UjVzpI1VDEk954itd3wJZXUx/DvaBPCMijGtdAH5/D5S8riykD8Nmx2aOYMhRUZrV1+iA9ix14WVAZauzc+QMRXdP/xlnJ9tYHHk+Mu+ak6Rz6LP6jvmTbQ79iN34AOgzmTJzC/rWHgZ3JLL0LoA9EBIG8jPrhMvCHFcMGAHTA2x7JQZ8JU9jDP4sGOuYrm72ckosCWoTrAXUp9HGERQl/0cmn7zg0yMHvIPydiYZLWuhjgkO6SB/KVhUKJe8nqT1+cMcS6WOCPgRo0sEWMNMHxOjkbTrkYTTJFQFGJujjYlMIsIN9Yvpu2+e7X/UpnnRcQJDpmdf2PFymrc3O/ORZR+iTLu9Op3ZJgKNCDnr7hrU382GvGIR/jc2DLHP9nWSyiV2ntteBFqodJZubZJV+XGCVTkY3wbvCIde+8RjE99uv/iEDb//GDWiif/JXndzyxdaXMxE6VFqW2vqy1hW8ELLPEum3jv44+sQwTkFhs0w80cAS7RDBI1fWotKyYN8WhnNMUT7SzgsHLuSpwDKtS0Kf3Qws6VLD9B4qvsc2zxbXbGjZkU4rGYmD0uxgjfetce6X9f2fdPBX50SWjVzeuc6L9uxBcDxEi1rTnnaaCJ8y4zNCnyogj+qpdkCfXTtGo1d+NL961o1nzYogYgTXAAL7XFamas8RL9fLrz4riikDWAHQQn1kMWW44QNk6WViW55jxZTjlKoprJgyRNSM7mKFlGFVLfbn3ltEMWX4HPS6mTxN6/C/Tgsry6icA14zI5F78LaXMt3PXjSZQx4JCHpj6AMpZjz6h+2bxCKCJrP6TBAZ9PvvZ9O4jl27pZRzfv/VBbyP//ibezN6lu8vilUnH90/3koBCmSo+0h9NDDhoolOA1Qx2aiBMV0Pfaj0LexrXaQP8qczDMJgKRD08YVBNpBSBtyUaStdjsO6bbZCmwb60FOW7fm3fdAnD0DoFa8yk1Q8KBUISBkXoKDKpJBHjcgJAX3Sws83Jgfk5EF4SHeBGpkJRzN2V/Cj+tHFV65+ddXtqs9mm3t/X1mariTVAKDsnCCgTxqh4wJ9QAMs8+6yRLooqNzDU7jOGsYvpvEsE/8lQY1M55JpWSJeZyLDNQBs3OqWQMrYdtafTOliT9wszmdS26J8sIdtcy09Q5fc2pFOS9pcuHl+sHsi/Fnf/6nCHmxHw2Ujl7ajmzB9eBIOT/EwNlahJWBKFzZPC33aAXzAkLLQp4iv5bLj0PaR322JFh2pvOiz7XUFPwBUXnXcvCQad7+lD2ld4FRMOYY6pmLKsGrWDlZMWRZUfuGxHUmfi17Vx0HQK0/JQjUK/MhGAID65jO6I9Nt2FUK0EdG/MC5LlPBJrLooIksqmf6XhOjg9/1aJHDnWtz22V78ciiqbPyK4t986QUAnEAZII+xDtSLuUoc7WhHxYwwyVNkTSUXgsscoI+6ngx/OA2xX809uXSqnB6FwXIsM3G/Vl/5OZDblcKyZzhTjyOTHQSGqPYrsA3uUnTpw2A6OBHqO3y1KDssNnm0jaVSS120RsC+oTQoY4RflMPpiG3FQU3tvcF2348TdhlbZOdKxSyAQI8iVCAR22f/g4DffLpYRvW3sBddfLgp9EEJye83MSHJ8HYxSZgJI+CKmPT6+JHrLuoPp92YfqD58vffue/WPTPN7jCPRX+qKlZt43+lKdDmdKycF0eeTQg2geWSB/lyY+yDHN2tSyZlsWBTRzlk5sT4gf/1QNrGBjaxtfZkpE+EKEjo3Vco3ykfecNnBendU1kyGcas3N3W6N8/OZBLB3wu30CDthZp1Xt2fBnff/ZnT4Axv6XjVxSa/u4cQXpTcFm9fFHRbAnuXM/8PDTEKjRsU+7oY9LDSBdZFDHnIQ6TpZNf7dYPQuO3f5vppdNv/kzrJgyuwIyxZT3nRS9+Hi6ApZLMeXH7twS7d5OnyTzDpnCiy6/7jPZSBwT9AG7n7xbFAvEF3YPOtnlSzj8DeAHUsFgCXdYlQ0+meXj2e9Fy/TwSz1uP7tgDoc+s5gvdB+IMvqXD2zK7F5+QAwHDe9GDfSJXZbMvOwLAZJycAg2FIU+BOxyhj6xoA/0yerOgyYbAAkFd0wAhM8N8aHAcjbb5AkPcnb9Zuhjb59eXpSN2BbqOx6j6bu6z0WvSxsXm3QyeGIpCoR0NurmNPttnrhQE2UYWOCJWwcmpAwFcEwwg4InoaCPhD26PqD2z3o+4pMHz0cTGeUX07h1Y7dtd9lvk/Gx1SYrD74JaNmOPzyj4MdwJM9PSPH7q8e8lf+9J8GfNa1LySXSddev3A5LqJ8znI8kENE+9iXSISLorOEzM90kcwN6GThv4PykFo9YYH0S/wMRnh8f8luSGqJ9djLbIMpnWjS9khW7bH5zmYtddRSSs0/AhdR2R6P8s4LJ7k6+k4bw5/r+z4RQU5mOZSMXV6a7tOKS1KZk89Lml1ZQNfS5/6GnOzoV1Qn68BWkWGpRp6GP67LpcHId8Q4Gf9gMufit2RW0ZDFliJ7Z+2Wibg0UU4aoGYii4alT0ydEW57dlSmmDDV0koLKUEyZfQ58u6aYMluNC6J83rAmX0zZBH1ecZJIBVt/Kiv4zLoYy5YaYsu4oxsEA0qQVgZvoDilK7N8/LsEANPBL/UivPFTszj0mXdQurIYLzDNVhYDv7zw2M4IahdBgWm8utg/n5hCoOUHoigg6EC++1PPt9KAzL4UFvDduedvJEzBEDwoXVvNOxwJXFQbqT4d+iEjfQg7bNAnvx98lPqMhGuukT6Z9xTxwwp98OFQ2yvH3gZW2gl9fPuSp0HV0McEhELsswEnGKcJNKn7sV/U+cS3L9zedvMtu9+nL5LOkpMTOWHFk5gOArhupwBD2tY/0kcXSaTaI/sVf29Yuy5x3cmDq5QJWn2spGyWPnIdtyqPJ2RfHUX6Vo8pdfPQ2SHaihc1tV28zbAPt/v7N7858fueAIBWtlaxRc+3Z2JzIE7nz3vfxv1wy+h6vg+gC8TtgOwnh+kisZe2RNFkOAI4LUtE54jVskbZf58YPk2dwtBcGM847K9VAxezmCC2AEfcVtbisa3YlVPONnx24Atc14JoX15YevlGeil4qm1V22xza/B+295h8BGUUGgfvF1CdF8XIGR4N48Gl5xbwlfVN102Ave0mn3U26qjeQWbOWpvo5jphIrNCDHWns5An/TyPmjxguh4Rv/Vz7fYzW1VlNaECeX6JNIHXvBZDRuAIJllwxn0kVAiVJ+ueiTswfK2ZdNf/pa5fBY86J3Z1KdrPySKKe/P0q/k56Ffb46BjlglCxdTBtgFTwu5YspQdJn5CKCSuoIW1AACIHPMVXQx5ZvOnhVNmzMxenrTtkjW98G+vW4Fsw14Dn/DTItF4/HDCmGqD2C/assr3i6Wj5eASufzdR/tS1LJ9n25iNx55r5trGB0XGQ6LjQN4EmsLCZWF+N+4QWmhdw/vuvuTBfLDxa68tADiSXPw5ggKFezKoOvcgUuJJpzz+cpHBFGZfsgI1WkMupZX47L1I9qW2K3OK9UOyqDPtiOzDuK+JGHO7rt+FiiMajHGEUoyTHVAfoUtQF8ZGsrZLKPaFSbEPAG26N+N+3zBTHUA6fLNhcZym55udkedMvux5OUTZcZ+hATUebC9oEEJogB+9T96W836GOP6KH7kH1n+9+w9lruxpNZZjXvAAAgAElEQVQHZUg8ZaM60ZrGKGV1PnVpq+ow2aQemzK2Cl004In7IQGPvR3W+bvvXR39/GtreV/jGf5AtA9AFPjo0rIk9IE5Fwo2nzOsTx25qHVRbol0gDWyFg/U8vlUppaPmCHSuSGFPrAdon2g/g4Ao8nRVA6fThuC1e/8PlcOfJ6ndM1niWt7LPQx3Qj83NnF0va7kF2i/sMfXHJ+rY1cNnJR/ezDt0MH6zzFHTR2WKTiCB85ujZBH/1l3G7o06nDCkAH6ubAMvIyvQoDEAr48HsEi4LpP14smw61iODB6Parn0mG0Tp6Nt8Gcoe+L7+8euFiynHUU5liyj89dzaHPn2sHg+AIxg7jOWR6/aPFh0jUtJUeAPb+FLwxAfDH7XdYcfM4X445D3muj+mItMS7ADUmTFvErOXvRpArSE2u/AoMAA/MfwBYAi+gT7v+tGz0a1r00LW7ztEiQJKrrb4C764NZDFuZ4PqDTBGGW/McqH1EWArKQ/SVhSG7L60X6THShCh3sIGAv53pPq00b6SJHcO5AO7ui2F4M+eKbTgYeqt/N5Iz7VfPtyaStkOg99XKGSC5gJJYP9h6cw3R3Q9oBbdr+LDamMdjJCk4xmkqDIrhYKVQl9MLjRASTbdmxfCpA2rP1h4qqTB2HJ2yJwRvWfiw7quLi0wzcenby0R79fm57FT3b86J3qyEKh7Jhz+yRnyEye4gfIfu3tyxK/j0cABKDGtES6XOrcFOUjHQTRPi9FL3A4I+vvyLQsiP45bVgPbDLgJ/5xwcAFsSZAPtM4dDp7yL9ILYY+03tmRMdvfAeemjr23Ta/VmZYxzqubESeiu0OsEt4dtkmcZgF1y2pIVRB4182UjMo5UlwPMXbdORLdGOJ8gk53jZAH/OluydAn9//vVgpCqJGdu/I+yNZQUueMzHEgSXTRxnM6ZvHih7zbew3pDux1KON1z2XnGFL/hSWTh+LBv7qicxZZy2mvICBjfj5lwcssP+DqBZeYJk960Kql4xu4cWU57Jiyu92L6Z864VzommsDdTikdAH0sEA/mx7ng0k/kj4ZQJfALVmsOLP4A8cFfS7//wD13LomxgoiqOFXnZiunw8dRnaVhebyWr98KXkuW9iX8TQB57zAfzAeCDSCcYGx/bOH4qaRv927p3RwQcsyHT7viVqLSAFhoB07rmeBibk3ODSFsOQTH/KdEK8X5CpVlwHnDTxUEn9xBgoOR/oo7ZXx4L3Z95jxA9rpA9qk44bjTOnI90H8p2CPr5wxwWYmGXaA31c7ETTZnLdmY4DCJn0UvqoNmW36drjycP24GvbrxsLNS92X6RPfPPKVpePJ1O8T04SrvKqXP73hrXf5y48efCLaAJUJ0/cL/Xdtj8zgRn6wXO4tNVHdzqJpoBH0clPNHp8prQuK+CJczVwykbyXYFBd3z/O9EvvzH+on9Wt2CJ9M2aJdIhNUukdkGhZlOUj7ymL2xdyNO4ZFqWhD47WXKYWstHnQdU8BMqQueKgc+xOXeUR/rUCfr4zY/0rFl4q+vkXbiDbmro7gx3yfDjV56WtR2sW7IyfOcBNS4bOS+gthKqXB2K7n4leqth0+y7BWWgp4usY6wA+vhdkuMd+vCVogAgMIgypS+/WhQcIQl9OHTh0SQM7DC4seUPbJ302J0AGaDOzFhc4+aBX6RLoB/4WpYGx+QO/5s02gT0OhVTTl6SISefARmAHMrzHkS7yFQwXEzZdHbddM5snj43fe4Etuw6e2zhqVGsDzaubS+kwAfrwPALlmnf/hJ7dIFl4lkbsA2gk4Recvn4e36S1hM6+PUzuR8O+2AWfql22vzy9Mi25PkWgx8JxiQMEyAPoNwkPs5PHXkL6RIMgd7XD1FACgyhnqcJEMLF1BlAfQ7XtHNauUu1gwQ5+NkfTVgUbMErd0ndNuhD7pczfhawJM5OfKDsz7wziR8U9KGjiiyRPkqfUoec/ahZULcvxPYy0Me3LfiRivSxgRQXICZ0p59OQR/T8cMXeRk5dazU5GG7m9r2S51ucrnJRF546KInJys8KRBtfEAEJZvaJdK7XFf80ukybTfVAJLtUns2rP2v5LCdPHiV4ofMBKTxizIxkgBLldFM1Lm2lG6xLUT9nRQC4WLN8ZjRCZdCHLFR/s7U5lAAD54EcvJM9hvvFdE/4yXy54LWBXxOlbV40kgdAX2gHs6Zw5+gpojctktal3GIJKAPJGdN5v9vivLJzxPigFzZStOyysAagD4ws8v0rrpE+qjOc5snnQ6DXaitndnNqYfE+HDKuiWr6+FOjRXLRmCVys59Bg7dLxra5B5AMNC/X8bYYaVtS9kvhVU5uV2V18mV9ZC5n/x7YGvJwmh4RGTshIY9ciwFoY+4MFf+8vUcaLz0pFgN6pI3/8LbR+Md+kC0C0CTmazose4zidUXgigeiCDh0IdF2MDf8HkBVtpi7t76PLvtbx2Ldm0XS6dvfzEFJwuPmM7hyKtPT9O+oK1XMWU4pPBHPrPFxZXhZVbAJgFfYLl4+NiWtL/507N5YWRYFh2gTy8DWRNZfSD44Cgf7BOAPgC1ZJSR9AFENm0GAAbmMYNgrLu2MT+wP0/dzQBN/IFUNvCjXOFL528b9IHIoxs+zgCSvOpiv/BIjvielMAD9pungLGhQWHoS479pfEayACgl8X1lvDVjWECH3CsToUhspfce5oykejaq/1gfdY2/ECIFpRsMh5CBo+DGqs6zsz7GftB+YHLZPtyhzsIcmb6qjf0cQUsLkCnmEy2lZw+8MkfGt6Abp1OHzhk0iPtLwNzXNuqdlATh+kR2Ofx2E02N5mgyYecpIj9WEeR78pFmIAMBirQ93TykfJqX77bcR0gObFhHer3vMyGtd/lZp08KKJRxGTl4gOTrDrJuujLHsci9XdSIJM/J3L7VGDDT2wN4CFhkPCWS7SPEEzl/3n5+Ej9Wt1aw0DN1mSJdLlalkzR2hy9GH16+BxqiiC3nds6N14iHdbLmsqQ0Q6ylo/aWJ0nrmh9NkiEzhUDn+Vd1R36SH+4zZfOh8Ms2NbOAtncNjXd6Zx1S9a0zUNFOlo24j6XFNGvbcNuJxLguEIfKY/BDMAU02+TzRLEFG3v6g99P3EZFvxIxZQC8IFP1f+Q4Qh9shfeWT/6Hxz2QAoMvJCrHx/4M96hDxQzBiiw14FpsWqAPBDJAn8/99AODjF4OhGLGuFRJAB/+Cpa7N992LY/PLAjeuT2zXz1KqoGztwDYNn0sej1F6QpX/KYwLLtAF/+cN92fTFleI6K06b4M5WympZcNSuzTDp7QpN1eaiLAOr5QGTT5D421hj6QLFkgCM66AP7cO0cDMB27xiNXmRw8Rk2Dg58GPhS7dy7NY374X+cJVK+TB8YC653JGVlqtngKfHKYuz0BpDEn935dyEJ2+R3SOly/eAH20MOVNLABtKi2841fXLP5DSM8Yr0oUAODDDzvkH3k4EtONKH0mmDPtTYHKAPHbmjgzsW6ENEZWWBkgBR7Yr0kbNtGehTpG2+TQN9+DxAXPiu23Ttscr2QR9XqKNOBPI3BYx8AYUOsog+wkMfc38ptKHk8LizhaM3rP02P4QnD349njRd/CCPugkUUb5WAY/hOFZRfwfd0KiIHH6OE6TWJ9rHtf2/ntjd0T/nts7LLZEOUTq72X9nDJ/u+ojB5a5ofY7F+rzAl0ifHvU5RflQ8w5AH5jl5kV7l0rLunzgSnYF93QN9JG+aCtyaGtnXqdTjYS7w0nrllxWI5/lTVk2clbb7YPoHvwxQR98F1MBD+goC32oSKHQ0T5au+NIHukLCXvk7zZCH/eL6dRvvpqDDEj1oT4Y+qy87fXiRZ49F519VD79pZ3QB170X/neeclDyKJlD1V64nNwwMYNvtr3MLFs+h8e2J6tlTOVpW3tFFE+AqQx8MH+hqgYmRIFK20B9IAVulToM53V+wHQ8abLXyTHAtBn2uwJPAVJrlQmC0PLBhRIwsujU3JHvlMskw6f/Y8VRZnlB6J8YDyTZwjgA2leEOkD0AfGB7DkuYd3sJo46dLxUBT5uYe3i9Wy4vpHaU0hEf20mwX7HPQOevn42ftN5ku9/6+VzzsdU7BxCrNvxt7gl95o55bRzKpt134YVhajVxSDDnxAjzQo8/BKWIkh0PsOi1eu0wEY2T4k9KHe21g/ZE0fWx0ebh8CQ2WhDxXJg32A9peGPhgsmaAP0acLlNFBF2q7jyw+pUx2hIY+ZcYMNpvscd3nKpdci8hZrpCmqFwZcFOmLXU+6CdH9eJH128mYkXdLn+XgT4qVME6U73hoI8thUvtXwd91FXCsFzEln3/VuLukwf/Lf6uQhkXIERPzHWuv2NLz8rdE+MTXa3nw+cHh304+uff/3d3Rv/A8u3pEumQkCVSs1zSstTrGqCPXC0L0rKWDxVbIv3yFhQsLx+hI6BPL4M+e/PVu+qa3qX60f2tSD+zeu1pe4de1tVIuN6OWrfk8hr5Km/KspFPts+++PYFETsS9ODv2BB8d4TtFDiR8nifSQ7rd9VX1jlkP/H7Ak7h4mOMU7pg7C9j39sEfdwvoJP/8VVJOstM9sKs+wD4Ofem14nVjuJ0JXiZB8DxmVen8Cc09IFiwNQS32AnhhtHvotBCzZsFViUPdi4valgMAAdvmw6+xtq1UCUT7JsOgMf0mewHwoG85WiGNy565psNA/4FKDPsf8glv1UPz87H4opT2BpVmIFLdC75Lh0lS8pP/JtFlqmXHG25eIPf6tYJl2CGKkLopsApMgoH94vOg+gzf0/fyldPp7BIBgnRDdJ6AWgTIIiCb9ketiBf5lfPn7yDJYaxqDP0V9Iax2ZjiXAsOlsZTHwDQdsrG8VhqnnzOJX9/HUsc+wgor3PfiU16liAz6qsgwAejkDQBhEULNk8l6AQAvI6aCRKk/IktFBhn5ycIiHwMTG2qCPcT+MIx0XWdeoLPQh3r1ERI/iT7lJ2WeL9NGBEfAOtc8GUsqAmzJt5amHa/rYbMVjTNunJ7ErsHGVU/uzwRrbfspmn21FwY3trmzbj6cJu2y7oY8EJHLiyQKTbJSNkCkHfVyXcVcnAgr4uGzLjmvD2n/nh+PkwW/Gk7IL7Ekn5ZCAJ6cLnRxV1N/h1yM+ATUQp0h6V0a3Mo7hdd+JfvOt7ir8DNE+Yol0wD0iOtw3ygfaXK6kZXUa+lw2cAVfNh6gD0Co4zb+JZ6eav3dPncGNL+tnQW0u+Oq6uS4HrZ6l4Cldf0sG3GrD1bKfpXgIGUU9KHEXSFNVdAH1+TxiQTK2YNeWlTok97l2wZ9nvK6Wv7mS0eJ+iUHT00OIbwwA5SAdCW5HDm8gEPkikxVkktdw8s9FOP99B8J8BMS+uDVnyjwo0a0vOLtAloc+HYRPVLFx7ZSFPQ5Z//J/OUSzguc4sS/86gf4V8eWcWEYIlw+FDROHgMADbA79PmTIimwApaAJmYLr4M/PIU/OhWzYK3UQyIVP/xpdUVGegf+p3EQApE8kCkj4Q+MnWL28ja3X1DHJXDxg3gZdZCtmoWgz2cFcSpXhgWQZoa+AHOqzt/IHyAPzZ/YNlbzpMwTEAfWWQa+0XK33jWLB4RNIWlqs1fkp73Z7Rudj5lfKEPVqymgZ3wijgKCM8WRaCPSk+cAE1smWukD6EzHzmUhUO2yKKM2cS4nSN9YsF8/R8xRgr6ZHXnQZQNgOjARajt8rwpApJwWzsYSiVsY44v98y1QrwDymnBSU7VqdNH9W1qq/oPG+MCh1xkbDpNNri2VScm+01ec/GLKyH+I7VSsrptFNxRdaoQBe9P9fpDH1NEj9qHCTrJfRIcmdrqYJZou2HtvySH5uTB7+X8WqT+Dj+f+QHOH4OO1t8hYZIYvk96FymvgiN0UVOA6Vt/2x2pX7DyFqRBTWTIZxpLzDp9+GPqpez0W43QKQp9LmtdESRCp5uhj+t87HRgXIXsE7arpj1crkpH6qnGuiVQuLy+n2UjfumiXiMxwB6pB0Mfk7gP9FFtpCCNqz7QFSaFLH1HkPap0AePv02RPn7Q539ffgR/Id/35fEy1Gwkzz60nQMFEb3CXvTZi/mu7QB9BLSAPwCG+Mt/LAcO+PSrbnGGPo9ct7+2howOWtgiVQ47Zg5/+DjkPe5VxL1OfiZsKxr89L2iEHHyDh0XBYZtAEBEbR8ZBcOigvaayCODFr8lm1JF2QURN5OnQ5QPq63DUpn4MWD+h2dDqKsD9Wso3/HVsqBwM/NN3/xJoqYN/I/9gRpOcnny/jfCUvHwBMcukA+ky6RDPR9I6ZIRShL6SAgI5w/0kUAfpgKWSRd+yMIvmR4HwIgvk87shwgiSFlb/NZisE7CsKlMB/hGnJviBUFG+zy2frH1UD/Jikhf9jZz4eYysEdnAIZAJxyhpoEpk4zyHpAFHMp0WxT6yC7V9ppIn8qgD7YD26KFO0LICn2Qm3LQRxm7DYCEgjt2KKNPmyrTVp6Ttkgflz5SXemZbmrnus/WN/RmgkTqfspO3TYf6GN7HC27H88fNl3akLwc8OFXTPyH+m7bn7kwYxNDQx+XoszYTlv/PlFClG/oNLANa7/Bx//hdbD8uzJ5aurv8HPTtTaPCkbqUn/HAQaJccanR24caL4gJlxTbaHvnFzv1K+qInSKQp9LW5cnETo8LWvoHXQhM8vT0qUDl/PopXnRgq6L9FGHZp9LLc7w2d3WznwMa2RNHli35Au1dtCykVPD2ecAeWRnUrSqyBw8KJdaQDp5nX1+drPACsI3OJ1LPQi1hD4nXHQ4H8gBf5xGGzx420s8+gLgBECfPlZnRhQmTl/geT0XVtcFXt4BCHAowF7i//6tw9HxcRgrdsC3ou3RqmhGNPwv+4qUH9Zu63PpilWy4C4JfABQ8GW+YTntiTGYEBDjd99Li/we+iaIVBmLDj0hBRbhrgShyQZ9+EpRn2ArRcFjH/Mr2EilrwAMgWXLAQRB1AlE/Ugf6Gz+1WfncUAH4CcpEq0UU5bLpMuVw0AX+JmDHvaZwtKmIH0MYA9fLp19v+9naf2gg143k9t1+F9nl4vnYz9pejRr38n8GMB58fCvN5PFk0H2qU1Z+CUckkZbyLQvCRABYs1ZNJnXOfL9wHLyEDUE8IhDH0g9YzAJfAXQ59FBAXw2XveciGDjACteWS1eYQ3s2MXqLF3+9tvI7quAPVRHGQB0JKSBEdBHB2UcIn3IqBt5ssbHiEwDw/V8pBw+pknbvL26SJ3MOSGdkbwrwckiNuYhjg7u6KFPakOqFw9bvPcqfbJNdYA+RW2A8dnaCpnskyjVxhXQ4D7V70X3tQv6uAIe3XO77Xm+7H48X9h0uUMfigzbtplAD55EKGCStrVH+qjwRu0X76f6VfvX1ewxtcU6TDV/UrkNa7+eHKoPX/ej+LuwXZfWlY3sSS9cXXqW0BWrViEKutB86+cII9MzzQRcEimlf5fUL5P9Rdt/96P1i/4B6AMOlatcFYU1aoROUT0Y+vC0LIA+SQElPMOYv18ycBlPWJvfw2r6sMLS3ZTeZRulfW61afDc3/YOPe1rxFl619/V2gvLRk4pb58CNNRl1aEDWcNHZR9+8IR+x3PR4ROt41IjSJVRnTi8SWTQtPrTpddVGYA+uro99YU+bBR45SOAPvgDRXXhBVqmLEnYI2vWyDQjAArfWH6PFvq8+wsHCVgBRY4h7Uf5SGAhNwPc2PaCABYAJ+AzjdVtgagVsey4WH585KYX+L5D/icAC3EPO+yDT5S/CDQabCtFrf+YAGhgCwAUCXjEilrx9ng8IOeaxrRh1Vx+HGawaJ3MymDMn6AbfAVpX+ArvGoYHCeovbT56Z3cpt07xvhqWbBEOvx56Qm2jHz8WfTKPu7vV57ydG70AH1mL5zMo5Ns0AcA1vWnC/iVOCMplBLf5WIqBvBJRgD9xefoAtamgwmRSAL6iNXFkrHHfpERSEe9ey8+/od+tTkpgi3hmA76tAv2UOPLpYG9KvZnEeijbRP3jICHM/ShdNrSxHRQRzqgE9DHYJMNmuiARKjtfB6Rl5Bykti2u7QVMp2HPq5QyQXMhJLB/sOu7zT0cXtHoMANjAJDDPlb/btT0KdMRA8eGwWLTNvKtM3qzaZf9UQ//9o/8lPnQ9deF/teSd0iAIt2eXR0QqrAh+9S4Y8DDMIFk/GtWtyz01s3/m3qC++jdKvbTOMwtxfGUe3/89Rjksu16iKaypSc+1lVWlZR6HNJ67JshA6HPspM5zDBAPSBGkXzehaMO+iTXAe2gxtqv4O/Q3XV6CnmgXVLvlysYZtaLRv5iH9P+VdwrQ6bqAuwAeU+6ViUMWWgj25wdG0f+XIjWhWt29M10Ed1TiZlCdJ1IKMI/lGc/R9EbMgixvD9e6c9oIU+b1uzmMMeSGfSfSBFBwAGL/obFwseZb83P71LRMbAsvJxpAqAi13bxqKnR0RUCXwAXsH+I0/2K8zrc8XIZdNn7jMpeoAVMIY+cZQOXymK30fTZcBV/QAgYpFo/zc7pHaxaBbp97mLpyTwTC6DDg8/cul0CdZk8WixahZbMYyBnxce2xE9+rstPNJH/czvn8p999pz8vV1QBZgFwBACX2ef3QHr/mEgSH2w7qPwopZ8YMZeoCU6WWyf1fopTtGyXLyLFoIInnUItN3X5+uAHbEO6Dg91j0+MatPNoMQ581x/wi00UngQ811kwU0B/NJFbhUqZm4h/kjZE+yrteJsKGivSxQR9yfzwyIqqG7wkJfdB4jJE+DfTJnvfxLzxDuEIZPqchba7tisqp/VG/i8q46pLDtT27l93v2o+Q6zboo0IZOYYy222remEApoNCrjpEexX6yGPx8699jX896UeD/G9dBI9LlAuW0Ub7kDBJWJODQ+hEDw2TyP48YJRoTwMek69g3703fye64/vC752CPyJCJ13avCisUSN0eFpWgY+EPkmETkYPPmnMytcMXMqQz9RxDX385tsCBwM3sd0cSqpvmpfzwLolXy2noOLWy0Y+7N6DjeAomlzEuwH6uBduBriRdQKGPqo/TGCnltAHhsZTvNgHv7zjIT8xvJX/lOlK8js4BgCNgBHCFTdc9igJfZ47d76o78JkARzoPknB33iFMFk4GtQDZIA3iqcY5AHYs4tFqeDP3gPTeJTKa85MU77crwR3SVgeHIopA/xQV4qS6WnDg/mlxgFuZFYcY8uki8ikMWs9m+tPg+Xie6J92BgB3vD0JAbAXnpyp6i7xKKiAHhseXZXvES6qL8kgY9M1YPjBatlwUct5AxpZgB93niJiJxSPyr0gWXawQ+65eMhMii3fnOstCzoATVqKuCLLGIJfCCXiYexwwdDn5cfK+o+HfyuNMRQt3pX3aAPPh4YAJ34xzICiIA+FMjhF3Csjb+rZKk2mVZlgz4YnEj9RaGPYo81vQv1TaeSoRRLHNEkh65AnyQgDTlcByWq2F5Gp29bGCIV6WOCMKJN+ikKbELoUG1x+U3JlN2ma4+vWdtzvW2/1OUmV2/ow/75Jp6EVDJtAzF4csGgBm+36XYBSb46dNAnHR/cT37xj2L1Kfj89ffXiS+BAI0Ngrj2xU2SNqmAxsHW4u1T5T79a2WRb3/wSRH90274EyotS43QKQp91rQuzaRlgZ7sfCIPOJ658t/3JOjjMrebvVVgr9skX0Bx06SIB9Yt+YcizdrWZtnISW59ORAcB5FcX67QBxr61ubBnbm29YkIygyGD572AJXGZYM6tv1uB80s1XP/Q36FnKU6AD8U9IGl2v/qMlbsOfbD6P/P3nkA3lVU+f/+0kMSkgApEEoKgihNsSwoKChCAgiySpMmEFTs2F0pVorY1rWBKLvrX9eVYgEi4FpQcUVXESkJkIQOoQUCKaT+58zMuffcuVNvee++9+aFH7/37p16Zu68ez+/7zkjY8NwlyX2nrsssXNcOcL+u+mSx7TQ57EPbsGBz9QXjE17sObZDSIeEHtQx52cACSAYojuFCaAhXDbeeyu1cleH3iSl6FCi82Z6xH8VWjfzxSBSx3GxTL4TlEMdoAqie4UBQob9eUKPq2DELq2Lnj7Zhz6bPuScTno8+DfVnLowwNvM/uAexMG24ZxQSUQBjceKWPZbH9YcZv04bATGHO1OvibK7Xm4u5doPRhSi2oE1Q+Y5gdxk4U28dDXbZt0kNAD2w5j3GkAGzBi6qITMG+YT6CAgxVPLog0zu9biK/qX3BscJfsxehDx2gHAB6+ebilOGZT6v0CYU+OpDkgj6F9rADKhTCdpP2mOIBhR3PYknlbANmyj1jijap0Ed3/6U8E6XDUea4L2DxATrl0hRv+31BDnS8DLyx5Qup21W/eh4Hyjam9NryTWeqx1WWrT2m7yz38wC9adEtBL7nVSCTXqCyaTpAQ9PQ8/mdstzxfHTlmACRCnFMMMiUjtali9tjakuxvKLSJw99qMvSzd8TAOiUKwX8Mbln0XN1u1z5KIts9fvk16cRszg0vxcMUi4qatdrP95Z16+mFDploc/ndz4/p9Ch5YTAn/NeeD7T+WyWbDG0Ffv/uOQtPbRlu2ldDT3uXodDS9Sk70glNbSzz4u4bo5QDLb1ddDi04pN86A3Hkm8uhwSKNkH3PikwYb5ptWDILnrtcUQeEoHcFxQx3Xey7iORKWhDy33YwtemQDsoa+3fm5X4a4Ei5BmIfrB2bfz5KYt2x86YxKHPjN2l65PLO2yhauFa5jchQrfi4d9UBAJ9xuhVhE7MgFcAMAEAX9V6APAAx76D/zXfEyiOgy75PJt0gDUKx5Zlzy/ckNhpyge94i+gIOR7dQhoDDY7++XC2gFr51eL7ZJ120tTotSA0iDfcC1jL5gq3gMts2BD+y0Jl2Y0OWLAzYW+wZ+/+MneUWUC8pQ6AO7kAGMAQAEQZhd26SHjP5oSscAACAASURBVME/vjWF94O78mnc0NTYT9yFjNkZVEpgX8jDt5PnZYh5tPC6p9MmzN6XKWNYuheeJOI+qdCnzQoflx1zAOgVDADpAA0UosIOPCZ/F+AQVfpUhT46JQ92jLcLaRBV6Mg28/aJgPL8pfTDqvRR4RZWZajTBHCg2jJwh+bzKQNNYqurDDAq5onQRx0b1famz/R6dN2f28678obUk/9LVTehj841Sly09UEfl/sVXSRs0McWpNlVRtYG8d2hh2X03om+v/myTP1z8o+vC1LZ+KhcSsEkckGUyk8mdFn3rHTOy7IKfdVcFCFtXfDJ5tU/dUEfnUKHdt/3vQ365Ne4bAD/uMutheJ/vfEaHssHoc+2Q7MKafa+Y3ffZvVFupA1PLjDjRYe3JqBy3DdnO+2us/zhn2l0L4N9xSv27ogj1pZCPSBvJCevlTXK/U8pLW5Z7nKw7oK6RZL6EMaY7MRQBz6cilHewb6mGY3uoHheVQGUUBkgj4PzGdwg71MAaMBmEzaVsSqgR2tsq29pVqFb/EtVEHwA1/ud1yTjz3jghZlr9rbLp7K2wUqGPWF29aL9oqzfKcxCSHgM99xDKGEDEKN7l9z9oNt0jclLzzRHnjatWsYBN8eN4UFeJb3tfAb7cgfklnb0MULVFOgsNps8vCg3bJU6LPqyfX57eOVbdLL2PvPF4IiTLQXAoPrXhT60LhPq55anz6NAySkO5Tdf3MGyHZ45Xg+f3adL3Yo6yfoQ+2lBoJ+6z9tboQlPB95VtFCH83zY1E5xBJZoRDUo4E62PC6oQ9WpZSbVpc+BxbbFAp2+LUvC9bBGBOgKQNusK4yeW3Qx9Vn2ke0IS3P1h7fc77pfOrXtbfKsbLgxnXP7jpPr2t3WvVCVS7unHzZBoX08EIPNUzwBevO0dkaoI+v+5Vavwn82I6byii2QQ99hB110CcHKdjA/uU/BQA68Yd59U+an0xeFYLQNCEwSOdeViY/wp2qbdXm11zsJsATqh667pzm1D91umXRwMnllT7nMaXP2DQWj6kcscaI/5/H1EGvHTaPLkFe7wcN+piM4l6vvcyZT9RIoSXaMSBZrpvz763u6UFLTsq1rym402oj+DQufWAxJ+4129Wi9DGZ46PXviJ1HYK4MuoL4E8I9IH8dKewCdNH8iJ57B94duRKFfGMyFU/6MbEfgMQAGXPDm8U8Wmaev35CwJCwJbq6ksNmMyVJRCLSO6WtZrF14HXCAZYsm3SxXbpD/wlc6FSIYSpLy7wA65vqjsi2hJuhFIgxPoDAAh2+hrNVDq7vd0v6DW4mIF711im7gElzeqn16fjwNVYcvt4nYuX7/j84VxQhA2xreHFXNC9RrKdumAHN3Rd46oe+GH34DAvn3t8fQIAiO9Q9jz7gd+rsvhPW++6GR+Pvc4Uiqt+hT6q7SgEOn4fqgLKgId+5y5+VWpdxlzQx+VOlluD02dMDRTKPTM6lD6aZ1Ux90k/yUehFqoP+oTCnSrgpkpenB80pk+noE8I2LFBJehDyPmsz8WVRXcf7bIvLaUsEFL74For3ff7OpCDpdILSV7X/JQJ8OA5PK/CHfW8Ck/o+ayO8kofHZxR66BpTOfy7maZZNCnfJMqCN2VVFv6Qx8+F9gA/9/3Bfw5/vsK/JGDT8GGl8uTcmFXzy+xgObiswEjL5ikXKTV2yoKdMGg+/90ebLo+noDP3dSoeNaN+D853c+L+eWJbZs17+yod2UfHrnTyfrkw0sEhe7z0r/D+/g33D+D87Ab/g+WZOsTj6+8KM+TRqYNO51u4QpGim0RDv6PMt1c/6j1T08aMmJuW/xVje2a40jzzCGNvQa8OF3N2Vj+viMw/t/9DKrAsMGfX6UPJ/sM38qr8YUMPrxe8QuXOqDIEIfHuRZuv2AwgagBbg0QXwa2wtgyZ5v2TL90p9x0AM+3eVpbvqUgBCwU5f6otAHth3H3bIQRggAwVzBWOwiukX6mqfzkqHpLx6bvPT9mcuXqXE26IPxbm54Hwv4zGZu+ldFmMXsiwFiMWGwbYBOGI8pRB2lQh/oF4A3vmOWhD7gTkVd2rwNLRP+5mNMjcLsveXM0WlWKBtAD9QDcYQ2gPsWKMLQfY3XnQWt3rB2Y6pgUl0AodBJbPczgEav+pRw+aLQp5ddu0JsnQNArxYqPOoqlYc1eVhiVQTxi1W2BN7qnj9NSh8KfbBK7bOohD65c+IDgk1tf2jb6DpTE/RxAZNQGITjqSvXVRfN6wIXTUGfOsCOq+3Qz6agjw8EUsfIdA267s1d52m57rQm6KMex4te/U3BUNn3unxloY8L0NDFywWdVGBjy6vrg90NzEfpQ8GHqvRRz/31B5nr17GXycDPZNLb1D7G7dEt+fVgRAE8ZAKWAjw0v3IBFdQ7wW0VBYbYRWTI5/ufz9fj+gXQp5MKHXX9uWmXv+cOudyy9rlzj1x6HKrP7/x5DnIQ8wj0g8iH/RFQgh84si5Zm3xo4ZmmpTAeVyzgXs8DTFZrYQH19nnS63b8f63u4cGL39rq9nWncQrC0RCdXoQ8qi0bgz5nfPclqdvNeOZGZHr91+lLjFu226APQAvYoSqLoipXL/mACJAC/1qPwAIgECg4AFxAYF81aDK2ER/8dz9SbJMOL59t0n/zUQAQQmW0xQ4CQgDoGQUuZnK3LNgCHXYRSwNPS9VJulsW68by+59P9nz3Ezy/CiEms3IBQOxzThZzxnaB/JZt3b4ZC578+N1rUnhGAxz/4gy6Tbo+BlMI6IG2PHLDds5rFrZAH7+VUADBDVcZtQ9s8Y4uadNfxHb+Yq8nlqxJYz4JVzpRPsI/DPqNwb4hDbzfwERWM48oBquGHddA5XPARc+mfULoMyjARx3MHADaTwCgUtBHjZmjQh8KdXglRcCbVk6hjxfcMUOfrC950p/rIwFCeNwFVkIhTmh6HCfI10TerHz6N11x1AZSOnmuU9DHF/CY7qld99pVz9Nr1lWWVpInLiz5g6Vpiaw8qaWtJL8LBlWFPiq8UdtDz9O+maCPWZ1jV/lgvTbYk/U1gz5F++EfYkKgD4URf/svAYCOuTSDPybo4lK18GtccyGb4u/k0iuAxKsuzQQ2uWfZ6vJxRauan/bn1xdUc/3yiaGjfh/rPocodDC/Cnzg+K82Xs0i8UxIJvMAzJslulg8AIb+ZdEncs2AIT9353O4+YXaZ3gO+rAtTaTaZyhZlayMKh+fQQ1I417zHYVVLiCgsX2Y9Lodf9jqXh28+NhWt68zjRsMyKPasjHoc9rX9ygoMNRdt6AxNujz2WR8AtBiJVO/ULUPhRbw4M8D85InnXSXMNJbCi7oTk468ENBy26HT+Zlw4/LNez698A26Umy9YsFgIDX8gee525MCHW46xZT9PBYRBCAmqXn5yWggF214BiqkVToA65SACFe98UMQtguENw5DAIoQx0ApGgQaJ2yBcoLBT3YBlD38BhAALr4TmtyJzUGd1DpBGnXr93EYxcB9IFXGeijUzKh+x9ANbQ5r4cH+xaKD3Srw/g+MCbQXjh3+9X5uE+QByAb7DKHr6X3C/e2QYU+dL5RAHTCaxgA4sOJBEamJM9zBXBCkuegTu4ZMIMvRveuCH3EnJQmLwN9XHlF+fmSdXls4KXpcxH6FL8N3PfvOpiDFya9MWob9Cmr6KF908Ei27EqefPlZt8fReClAz14n2M7l1OgyPuWW/47U/8cdXEx8HPuu0wBNHloIk7a1DpGtRCZhIX8OGU1aULqKuxUFtjWoPyOtj70t8uTe34V7vpVF/T5HFPa0MDJNrcsND+ojJ5n6pwNCdvNlH0ZHzTsyOJiQo7cvPFGrub52KKPaNN9dufPsfKe52WBGxeCHwF8BPRZz/59aOEHrPXEk/VawP194KivcgH19qeNpV2344/a2Ky0TQcvPrrV7au/cQrgoc8dmso0qetvUpdKbAz6nHQR27adAYbpu2Rbrj/z8No0zg4ACHC7ueoD9xmVPgB9OLRgAYQBWgBEgFcOWrBtwXW7g0E6FVyYtu12bZO+y8GT+I3O7Dc/bB0mDiHYbNn+ZUyBJF8cQrBjGF9oHKhbpMsZBnPGHbMgvg9AHww+vd0hD+aUPnAeAMTcb6/yni43fXoyD8AMMY049GF1lwEsvhVC8OY0gLYB+oAtRzH3K1Q7cUbAjrl2JNO1wQZ+MP3EGWyXMn5fLaAPutVBvaD8Ebu8DWPuf2ynMtil7KcC/ADoQcCjqztCn7xVcgDotZO0YT+M0IdCG1yQ02fMDkAf8jxrVfpY2uSCJqEgJjQ9mK1sG3zyijTdhz6+4Eh3bxoKhahd6Gz3KduU13Yc63DdV7vO+5Yj0vUa9FGhDF0w6LmQ465dvYpgpqj48S1DlBUEfQiMKUAfCmqU9zl1DDv398sFAHrzN5n6xwB46gqwrFX0KBOTpjECHhswUvtALq4Qly0v9ZFHO3TKot99xV/9U0aho96bgGInc8uakip0VFcs3T3Np3f+DHO3WqeNxQOghsbkgXQfXmR2y7pw54uSZ5MVCvSBUjLow1U+i2QsH99FTdfweKwRC5QaklKZGml+1wq9bscfd61un4oPXvwWn2Q9nMaCbZS/SfdwJ0s1vTHoAzt3AdTYbi8BQFCBIcCG2FkLQM7PPna/Ffr88TOTk7HMPQni8UAeKFMHLfDhf+c3TExWL89i4KAqSAt82OLEd85iv/mOWbBYsf/B71uvzLYnf8EBsE36puQFxz1qNbIXgGCBjfmuXRJAoPqFq1C46kfYZjSLfTOKgZrbf54pT0LVN6CSAogB9oNt1wV4YjebZFv4UrPGkqkM9CkDe7AJrmDVkA5cvvjtPwE/HLixAwDcwCbwG8ZiNLMTBAj/xJ6/N/Yywh73rMkBoAMyAJSPoUNW37LQRxdsmT7DyvNpvQTa5AGU7BPwJQ3YyeYPpiuCqLLAJRTu0PRV8kJPdGXZoUpnoI8v2DH1QT2OMzZCH921227owyKyweotf/iVqPzojuUWAUt6V9k+dYWWYYI+WZttYMcFfXRKIFRC47lbrxDw58iv/YL/bgR6KBddDkAZzunUNqXUQ5qFrVC/B8QJtYutrY/cenmy5Ea7+qeMQqesW5YOAoHaB0AMuxvi2hxbLB6bygeHFwM6A+YRSp/hyUgWtQjAzwb274OL3p9fkCIwcN9ctShFrcNVa2ENGMnCEdTarptzZQMNqK/IgxfbVXz11dSNkrJ7c9vdTjda1oY6G4U+0EHTlutwDgLkXnv2A0boc+AnZnBFCMAh+A1KFXg4n3PUIznb3fK1rcTOXeyhHYMP0wR0y244PorF11mzYkManBj+sgV10C274f09v1nBi5n96gn8pmiXk6ttkw5lmQAEnIP4NMN5jBlQwQgFCsS9UfvrO3Fu/BcGfZjdxkxk0If1mQcvZoADXuNYrJqtD/QPUO1bpy3dL945LgGlEwA2UDP57gJmK9MFfcB9cP8zt87+mA1fLPLBHm/oUiDAzuH275O3H51ceOjNhaoj8AmfCepW8CceyCAQvCiwodCn8AxqUfrogjznng8dO3fxdsgf+R7hoGhj1t8CsCKAqAkQ4wN0fNJAD3RAKjSvKKcIfcoCGtou2/uy53T3kLZxUuvBkXeVE5rOVA+9smz3vyH3xu609E5WB398z6uQRXNhGXf8omAF8uXdtsrv3EXboMIb3Wef9DSNLm6PTxme0EcOHgIbPm/YMfWzzqWLzyWZVgeB+DmW5B9XZq5fR3yFASBap6wvnZfKuTStZuKWASydjr9TCSZpgJFRqUQueMz2x2/oAz+XgT6gDgrdIv33G29IPrLoQ3Tk0vcAatYxtysahUfsuZUpdDYyF7ACsNGUdsHOX0ieY3of4cwlAjgD9BnJ/uVUPr6Ln7bF8WC3LeD+nvFsYW0FedbnmywA+ECRv5jzU9+Su5Ju7uLDu1JvfZVaBqTcqfqa1vKSOgp9qC1A+QPbeS/41ING6POGTzLow5UqAhKYlCo3nw/bpCc8ne7FoQ/c5DCFC27XDQAEwM7KJ8U26QCMYEctOLaOBVqG3bOekLuDbf8KplZi+SGWzu7vtG9X7oIQyxbqtkkXrYabBnywBHgFMApcwcBOL3mvCOwc8vrdWRO5cmUU22Y9hT6s3wBd4AVt2fM94eWGtIGmzUEf5vq12zv8tn73qQ/sru7yBsBn7rnb8jEGu4obZrxzlZ9hZ3ZQd8kd2l9y1JbJh3a+0VhlhD4+o2FPQyHQiQdNFolN0Een5MHi+bMTZlSCSafPoJ2FPjZAEApZdOltgIWvIdI2PnWVS1Mf9CkLi2zgJgTq1A1zfMuj42S6UgYP+uhco8TCUB/0cblf4UJkA0SQxr4jlznQswKz+CDrYZkN7OjOGcEOQiI56XJ5yUSE78XbfiJUKG+8SKh/+GllQUnnZVnooZanKcdH7VNn/J1cP3M2yS+m9LvfCHhofxQj6pROf/r23NTWdy1+JIE4ODRwsk8sHigAQY1ti3SMqQPABmL3fGLRx7XLD8QVWs3UPiIOj8A9Avlk0MdH5YOFn7vzufwtlCBUPiO5kohCI/WPCdqGtRUIaBsbD5axQFuHOJD5JAvm/KxM9zuWZ+7iN3asrmoVBVg+exSoVmWf5+4a9AG7QpBj+CKc/NkieIAt2w8+e1u+xTe4dgH84bFvpFIFXbwAbOAOTptvPco4XAL2sC8euVsWbpMO9cOOWiseZh7KAHsk8KF/dZrG4hIB8Hn5hzOXL9u80AEISP/8cxt4bJ1HbhMxeWBbdHhxwMPeI3iAurD+UJcuKA/gCiiFsmDKEEga7CegF9gAXrBFfCehz4J3jEvGT5FKn4rQB3bQoq9DP7ddMmHaSK6OAmD3yO2r0v6vYNu2o9ueLv4TgB58gRJrAwsy/YXD/6y/72jrt1KPLlQ5AHTwZM0W6hqog32tG/rkwFPxGyRzESu2yQRboKkhIMaU3lUGmsSWrgwwKubJjvi0qQ6wQ21ie+86F3petSm9xHwATxVwUyWvq535pUJV9/BvJJmESuDU4/jZpg6i+XXvVbhCy8zKrQ59fN2v1Pp91EGuPuD5YhsEBFBtLT7bwI4X9JETKFUGyclvgz6oDLr9ZwL+wOvQC4vqn7R95IJSIYgtTe4PJ6SdouPZ7DSBFZ/8IYDGVp5XXbkLTnTAV+l0xn/kH2pcu2WZ4vKAQsh3i/S17N7apPLBrpzDdt6CVxaAGRQ6Izm4gdeZi95He219D2qfVex+TSCf0fwHoJIOOkX4423WmLDFFlgw55oWty5J5i4+pEXtCwc7usYHlNKivne2KXzT4XsfeLyxx1iI6wMvVYFx/tw/JbCl+3rYxYo1AuDEuE9kuyNBHoA+8z4F0Afi0YidoBDUwH0SQp9ffWgCd8mZsuOY1HprV23gZYK6BXcMe/JetouA3DELy8HgynS3LChE3dEKlDYAaPb9zDNeIwQgCrb6BpcxAAgAIKAfADxAefPAX1daIUQZ0EMbBnAFAE8boc+EqSOZbdi4eEIfFe5gP0/8fztyd7XHFq1J1jLIM5a5sIGCSQRlHkqW3vRsrv+rlq9PVj4hVF342mLmaJ4eYRjuphahj9c0rzGRWIJm7zA1LfOkeUwBZII6kIooeXgmWMy0fzTXKH3UOD9YngX6mAJQ43EXALFBAnoutBwTVAkpE42uqztCn3zcI9VW9CJwQTVbWt9zkC7kC9udVgdtsDV1QR9f+EMvxDqgjw7aqHXQNKZzrl3CbGWYt36vCn1s6h6qhDGqhuRkUtWvNO8dVwsANO88DfxRgQ2ZnL7Qg2fRLFZl8oeAp9KuZOkCQOC3AVy5+vXu7+sfU/608bd8i/SdhsT9s/oygR9Q1GxkHctvkQ7YRrhWwf/hZQIutB5wGVvN/qFbltD5APYZye7M1yQfXfRhbdtMB8/a+awU+IxOxiTvX/Qer/xeEChk8fSqNSaKFqhmgQVzFlQroOHccxdnCsOGqyLFl8AymiwlSulcF1tWU/rcQkehSehD+w8ACOAPAB94vfM7AvpAEF2+tTfE7HmviNWz4pwp/NxI9vAOwYwhqDFsA86VOmx7c4A3GIz4uncxVQuDPtvslm2T/thdq3n6ERDDBrZCZ7+50ofsmoUBfHk6iKPDHv5htyx4qdAH2gC7Zh34r3l1iWl8b/oU7Dg2IhmzuQw+zWbpw/9YxePZAPSB4NJqHVVBD22LL/Sp073KZ67Ddu4Tpo0yQh8d4IHdswAQgioJ4hOlrn484PVQ8ujtqzmQg+MAfhD6wPw4Z5+b0mad/s09ktVPb+BugLg7GvymCigf6IMF5m7ofDof01gsUHw0zQGgQ7fIQx0oiUKfHKyR1RBglI/FA3lFhuJxkTeN6UO+XeqGPmXhjgss2MCNT153GvKwI01ty1PHOd8yXG2H5upgGJ2YNjhnS+ebL10/gq6GfGI3yMnSu9OaoI96PHfR0YtMea8lr/SC1bzXQaGy0McFaLAfPkBIBTa2vGofbC5gom8Z9CnaDEGNDuwYz1H4QN5rlUFkItqgD+a981oBfw7+jHT9IhOrDKDxgS4uaCKMKDrio8ih6UwqolyZqY1EJSHqIZ+69vj+9QyfrEq3SAdHqgOHHVFYGW7a+KsU2ICaJ93tSkmJW6TnY/Fk0AewzbpkLdtx64OFOnQHANQgMBLARwRg9gU2tExQDm2RTEkmDW3JdD5jkjs23ZIcLLeEv3fTPclxC//Zq03BEIjMc68KYqJogRossGDO9TWU0lwRcxe/oebCa0IxEfLUMi462IMFN6r0sbX+7RfvycEN3957DHuAZ+AHoM+zn57KHvDZ3yvY9+xIOMce9FPow2APAhw4D2of145ZsFsYKHV4kGcGh7i8icEf7uYFUAh2b2LwAEHA9oc9VAnIYPBkgBCgUAKoBfU9fGse+tQyspZCQG3EYRoDGxxugKIFlE4SflXZJr1s22Fnr82nj+KKHFBZ/fc7l+aKMm2P/o5L9uTpAJiBqx+P7ySDUoOrHLj3jWaADaAP7n4G/Ttn7wz60IpO/druqW1U6HPBIcXgzab+RvBTdiao+eyPphQAnfxGBoDg1RD0se7chfVq4gjVDXFMAMMFNuB8E3mze2c79PFpn+4+3BfsQF4TuHHVbcura1PIsRDo4wIxVc/Tq8tVVt69KHdhkYtMPZ5eCLKqMqCHllEV+vgAHFMdOpWOWZ1jjtdDy3cBH/t27Xyeygu5CvTJwRgFCKXzgr3xgT7YpoULMtevN5yrd/0qgBgNmDFCFw+YFKToQVuSi1+bP73Y84DHByYVoJerLvJl8aIf/pyDGBE7R79bloiqM9wL2Jy189lKAObMLQvKATcrUywf9VsZtm/fyJAUqHzAJQugD7Q1VOUD5QL02TKZmkwc2iKFPtOSbZLNhybx8n2hj+57SG238bN7MfQuKiaMFrBZYMGcX7baQHMXv76m9kXYU5MhayvGBnz4XVenlD66Hs3cbkohiPOKc6ckG1gwZXT7AnABCg+u9EFoIWPSwM3FXf8jXK5UFzLcIh7OwRbcEDcH/7LPFT9MNcSPwTbpcgt5vlX6BFYXK3/mmx4uNQgp9IEdx2TwaQARALieYbGDUOlTqvASmQCKTZzB1DWsPdBPVyDqElU4s1AFz9xztuWub9AWH8Dyru8xRRhzkQMbAkQDNzmYE/D5SRZ/Z93zTBEGc4SdQ+iDYPDsf9JDH2eDPRNE6ONpKO9k7ruyHAA6HBRAQHFFBf6KHrPSxxv60DpZ3b0OfVztB/vqdu4Sx7NXHfCmbJmdgj6+gMc0m12zvOp5erm5yupd6FNW0cNXipI/VfLm68y+O4owyua2ZTuXgy0c5oiZoAVIOEkQ+hjSalVCMu2i6wQAOvCsXxQDPmtATx0wyEv9QxaQAlzKXRwGwOPR9lDwZNop7KU/up7vYgWv/BbpebcsCHy8mqX83vqvpD2AwM/qC0DNevYPt0hHtyxQ6KxnyMZX5YPlns1gDWh8QJ0D4KeMygfKgnK2ItDnTqb0mSqhDyCtty58c6EvIQeiAijEWjFt0xZYMOdXTVdRqfy5iw/wzF8T1MHaopLH0+5+yVyAR1dK66APNhJi+rzx/O2ZAki4f+WgD4M2Ox4jvvBcu2VBmsfZLlw548BzIr/XEtu880DQEgRBXRBseTyLPTPziIf8LE9S4Y5ZoDzB4NOgJIKbhGceFtBny1mj0xxNb5sO6hpQOgH0AWXTHmfUt2OWahxT/J133bALT/q3/35StEVCH4zDZNst64xLAfpslGBHxHfCODxP3PM8D7ANUJAH/GbjxhVA0p1PdfEKHkxHhgh9ardoUIE5APSmLYOgjz7+D40LlMEkaFTBvauF0McFbnyAjD1N/qyuPp86cJDLwKKy5UOdoVBIl6fqMVN+OvFdoMZ1Xmdf84VFVTp8psukFEaox/GzLm8Z1U+I0kcFNrQtOtWOT3rXrl4ulZALQBUhUxH6ZHYrgB0CIWzngqFPWi6QHzHsKiCyKY4w8PNdN2TqnwM+nql/0vLIpA9RxdjAihd0SS+E7Iop1K8CHnJxOdNq+hXktibr2u1yUPusKyh0aCyeDUxxc9MR+6dj9NTiK5JHbhF2V+EPqH0Q+oBbFsbiWcm2Tv+XRZ8I+o5V3bKOWfimoPyYGNo0JZnG3btAMbRw099rhT5qo8iIl2pvmsl3sa1WS8zdZxZYMOc3re7R3MViLWn8hffJjVc0GBWUgTyqZVoNfT6bjOc7UQEoGDtpOHfP2uNdRWhhAz8QP+eXH5jA+w0GKzyowwGpAuK7ZkE6Vs9attNWaJydGz85kauEUJGS7jjGIATcS49jsEN9LVvEtk1/d3PbpjcFfRDwwBjh+9e+fzpzxxNKHHDZ2/Yl43LdNUEfTKTCn3dd9tK8qx8E55bQ5+kH1/Jz8BLQhwEh9jsN0g3qKjacGKL7cgAAIABJREFUJhevOpaICH3qsCIto/wdFgVAb/tnthubhLp43ad/3JcHSkGf9LksA0JlAzmXBTQ+oMQEN3yASb9AH91MitBHd732AvSxQRV+QWt+fI777uplgz6hZYiymoI+OiWQUelTBfqokEhOrbt/KUDE/h/J1D9egEazIAZBF5zaMhP9bi6ofZS6vNJC+QZAFASyyCWI+fa64hfOLdJB5fOnNx6kjWF0509EUFaEP+oW6QBZYJv2Dy86M/gLW1XoVIE+U5Pp3L0Loc+0ZEYyYYjtvluD0iekY+a7jMD7j8DkIW2MaXvbAgvm/K7VHZi7eL/a2lcHiKitMX1WUBO27QvoA+MMCptn2dbc1M0LgA++rns3AxDwBy3yhc+3SYfPZPEOBT1QPkCnPd8itv2G8iDODMYhQuUJuJEtv5/5bsO26VxVJFzLYKeoJrdNh+DJHJqB0ofVWUbpYwqwDP2FgNxrVjDh8BrmZiXjByH0Wfnk+mT1MxvSncRGjR2ezNlXADjY0UzdPl7dJp0HcEZXPxmfCF39lt//PA/uDLYcORZAWwZ90nLh/hrADwnoXPeaEMFPnRatfhcF8SnmzJyWNuqUo7YS73PPbZodvWSaNIgz5pEl5V3Heh/6lAND+VzK0inWP2U6+EAqNV8TZbjapjvfxDFTmdRsrqvAdR7LcqdD4EMnexuUPpnypvp27TogFAKJTOohXdweutDY63VCHwWq4L0FvV/RvVehjw4C8fsgMhF5TB/13kjzGS9wbb1y0uG5e34l4M9+Z8rAz7n6MLH47QVdyGRO3yqAJwQu5b63DTAn1zYljVdd1CbKRanm3/0nP+Hus7hFOrplwWc4fuOhr80trjogtujqbEeeY0eczhU+4JYFkOUDi96rrMx+H+uDPmcxZc/WKfRZtOnWVOnD7oYru3f59caeyr1eetaSK6i2Uj0rj8naYIEFc/7QhmYY2zB38auD29cEgAhuRJ9nqN/G9B5PGK83oA+LSQPxWuDBzaSK+cO5k3iAYNgxC+DDnKPy/s6geCk8kcgJVAb00LlHd+La/UgRaHb5fc9nO45B8GT20wvQxwZ4bNfb8Z/f1Qp9RqECiAEavgMbwC9mE1BGwQsAjgp9aH3v+8Feqavfc4+v5+kBCMEObxAEHMYclT4I1XCXtyahT+7GsM8XpM50r56bJAxOmgNAxyAA0m3jLhdEohBKPV1goVSgUW6LeHaesOScmeo8boMhfB7Kmn2ATrk0YdCnDnhD+2V77zoXeh4HUTcbqxxT26G7pmxXQMjV4U7bNuhTBCz1QR+XCxe/Har4Yysjr1YSD+0qYBOfbWDHB/SIQkQ5BeiD8IJMRG/oYwBRKUQibcd6F/86c/3a930a9U+uHfkFLP/sLD7pYAc9jn23pc2lV4GPpj1GpRBNi03XLMKm/BQ8veJnoPZZpd0iHY7/cd5BxrhJOZcy1o4V91+RvHYhU0Az5FM1Fo/qlnXswiN1S5bzGOwEZoY+Qwz6vMVZRqcSuNdNz5ZkdNIzQ0zWLxZYMOd/W92VuYv39m5f/SDCu+qBSdiMjYvABwzafuhzhnTvskAfcKsCVyrYMWv0eBHzBV4Y94fOHAQ0IaBn8Y+3TouY85Zi8Dx1+/XdjtiCBW7elACcwODTPJgz+xJYwYI54w5anQiqbFL6mOLvmHbQKnv1Hf+5F3P4xVVAHM4w0EOCciP0OX+ee9csKGvijNHc1Q9sCDGSYIc3HvdJlo+2Fb9ZAMGGgzkXbjjLGirmIxao57Yr3ZVGlkwB0KnHTdGGLwlR+rhcu8gzgVEBEwJfqkCfMnmLebIjLsBE+44DS8urAwiFlKG2pwq48clbBdxUyUuXEfdVpLp28VsCWQSlnOpx/KxzDdPlt7lHmc6JOqpDH1/3K9qnsvBHV4Z+2/dQ6JODHQp8MYIdD+hT2LlLXihWYAT1q2XDIbIo6Nq05EYBgF71bk3g53SRIGuMCmQMn+l3sBegURavskqjkLp8lEG7X3Mlj+uDKh9Q6IDS51cH71cEPvTbUtOfl//PVbnAyXW5ZVWBPmK3rslceXTXpn9wpQ+4d0GQ6jZBH9OtmHs99byJq60gz/oqJeupxlbqqV9m/YO0mnfBnD/5FdelVHMXv7JQczPgoUsdbHm1zdraPkf7Avr89hMTkzFs1y0IVsy3fmcgAFynYEv3qi8KfLAsFfyo0OdF8ybx3brQtQmVJ5C/jjaF9GnBO7KYSNCOH79rKc9eN9wJaVPZtKAmwvhO0JcLDxOg6LR/24P/njCNyZlZzB8fgFS2DbZ8Ocl4ExUMTJn13Gio0IeaLweAjs8AkBP64GoNHl5ybXUBEBsk0IEQHxAEffFJ52ob2kSXrlg+eSCTGUPAi66vav22fqnnQup25dXVW+VYWXDjmvmu83SOu9PqoA2WUBf00UEdqEMFK+ox8bk89Al14dK1CcoICdKslmHe+t0H+uggCip9XICFz10EMwokSuc1P48niwojG0wqA32wTUt/l6l/9n7ngiD3Li9AQy5cH5WNMVYPuZiMgIdcZFVVSK/4xdUsXPN6Dn1AoQPuWc8na5Lfv4HF8pHjKd5kDTO16+W/vjIXOPmcde9KM+l2/aLrBn2vKnTKQ5+zWRjnrTn0gX7dvem2noM+JhuFrbmOUtyLtk8zYpouW2DBnD93uQX26ucteXmr29dvjesm5FFt2Xroc927BLQAty2TexfE8wHXHg59GPCB7cBxm3Sd2geNcM+Ptk7j6zz32Dp+GOMA3f2D6Xy3q8ILbpQY0IFyH7lhu/TG6u+XP5km3en1E8VfwpjaZ9XyDdrg001NalXB86p3TNOCkqbqb7JcE/Q59Wu78x3YYMe1CH2aHIFOlV3vnY8N/kCPEACdesKUdFe/gmsXJFRcv8pCHxeI8YE50ByfdK66cEQhnQ2iiPo6D318wY6r7aq9dDOs7DHffNTWpivJNfNd52m57rR1Qh8X3EkvINnEJqCPC9DQNrjq1yt07C5gWL4J9mQ2yqBPURllAzvGczqwY4A+6bzwgT5KuUbYBOsDWWywnfy6k4uL7vy9NwkA9MrTCfyhddJyyUXso5wxQZi0TbQ8OStzf7hR2lGAQ0qfdeXSYz7KoJdef1Vui/TrX78vb5mtXTpbvOK3VzKokgVO/u6rZoty2M/9v8kHfjatRXA8Qh+bdaqdc6/PhvJLZ6zW3pjb3wIL5vzVP3EXUs5b8tIu1NrfVTYLdtB2fkozm6W7Bn2+sHC/5OsH3pkczf6moXvBlu2wM1QO+rCEuqDHfzhnEt/VCcAQ386bwZoRDPwgnNGVf+s3p3AXIVOcn7GTGWSSL4hH8zzbzQvK4zt8sf8gfhBAnY0b2DEWWwaOL7rhmTTPbBawGNJDvqZ259K5aOH26NiQW654Kgd9pu40Jm2jbav0Nl6eJ5wnlD5jmKsfVfpE6NPG0arSpmbuanzhD7T8tJOnph0obNcOZyoofVwgxgfmQBN06ZrIi4ZwQR8XeKHnTe/VfvUb9HHN7Krn6VXnKivvyiUnNS+gLpWPWpbNzYumzUCIW+kTouhR66B58ZxZnVM95o+oL3uAL9rDpuDxVfdQFY4WvmQXtFD6hAAjE9iB9UjCHX4Na97boNB9fxTw52WnLBCtI5PXB5YEqWxk/0uBI9I2W7tcyqDc+kds+rJfCrcs3Nr8P/aXsMYDQNFx/KffX5GLoXPpPsVyHvxdFvjZpP6BmD6o0AG3rLJKHwgIjeWAkumeTbdzpc/4oc17xr2Lrq2dfu9eyw0tKp2x0z3sr/oWzLml1R2at2TPVrevzY3rDNxBC1SHPKotuwJ9Tv/2nskatqvTjV971B/6QEwftoAB9AGFzdYHPsD7Aq5dECsGoA+oPBD6gNIHXjp3qpsv2IK7f42dWNxCHQ3EoQ8smKwYCDw8nCXdyCDOKrYjFd7UQDDiTQB9GPBZz3bheuhvK1P77vDK8fzGZ/3zGytDH1P8nVe/c1oueDLEtnmWKZZ2ecMkr2vm0TtXJxcd0W4ZIu0IQh+I6TPElD3o3nXqvzKlD3P34kofFtPp/Lnu+EBeBiqRKPcXuRL5Yxa0QHN3Ky74Ay2g7l/z3yYBUIuVPmVBEnmGsSp9KPAx5fEFNDS/+r7sORdwcpWra4erbbaZapq9rlld9TxdP1xl9S70KavoAevoIJHPsSp58+XXBn0MsEYHfXLAhUxcHfTJARSlDiO4YWVWgT68Gva/+/83c/3a66Si+gfvvehvk3tWbp1SFshQ5YwJ4ngpg6S9fdK+7Fd5hc5lr2GwxgB8crZQFqO9/5CHPpf8U7EcbM/qZVckyxcLu6vwh0IfcMs6buE/l7pFsUEfKPD4hUeVKjdmMlvAvf4reYMzROubLLBgzj9abZx5S3Zrdfva1LjOQh7a8/qBD7+LufeBxzt+qQP0Wf30eq6Eodt8j//kY8lWN8xOnjhwSZIqfdhW6+jeNW3nsbm58OgdqznkSKHPeBb2jsEevisU+w1gR6f2gZ2+ABpsPn2kcW5Bu0DJg+VhmZBhxSPCFWwF2yIeoM661exnzcZkI9tRCl/TXjSWAyEAMSFKHx3gYWOUa+fbLxbQDHawovZD6APnRNBkDJ4s1E8QNBkDHMMXPuTvVegD9+5feKMAVqd8dXc+TuOndB/6pPdeHb+q2rRM1tmW5gzpA3+gJzkAdCrbDl6uxW1y7xoE6FMWKsEYhkKh9Dr2uC/WzdBuQx+/q8bk3tVWpY/LJcumJFLdqDCta1cvV5kuAFUESkXoQ5RN5EJWIYpNKVOIsWODNeSC8IE+rnqxuFB1D4UZCH14WfCB/TxwswARLzne7PqVlkGuU5fKJq0D68rZgxYk3ptURPSc2g5fFdE+v/55snkyiSt7xiabJbdt+r+cQud7r84rdHJrmQKDKFR61R+vzCl0vv1yUY5OQUXzPfqnvOsXQJ/pMgAzKHTqhj4QyBn+oBChT533TPmy/L4LZJ6gxM21uddLXjDn9lZ3Yd6SF7e6fW1oXOdhTzOQR7Vld6DPtxj0eUYPfR774BbJ8ysYtGAxehBazH7VhOShW1dl0AIUNgwYbWDqmueeWMfVPRDTZzSDPhxqsPN8W3AQ67BFTFX7/OajTFLK7tW2nCVcndav3cjyi63eoRz4/fg9a8TOW0xBgsAHwALsPAW/n1i8JnnJe5/g+dVAzpO3H83VP+ACZttm3gfw2CY/flm/nUE0gDx9D33Ol4Gc5U5uKvSZwJQ+oPjqptJHHa+o/Klr+W7ubsQX/kBPKAA6fT4DQOQ+2gQWmjheV5k+7Rdp8jXqIFNZKOObr2w65VlHffZJJ2hdYEhXH1bimsVVz/vWI9K1G/psSoMom4AN9qEMDPLd1csEfcrE/DG5dzUDfQqwRk7MPGBhn+A/FTbBNS/hiwv6pFllel6Nb14EF9g2DfR68C8C/uxxjHD9ytWnTHgj8ME2kQJsYMYLHMm6bXWqKh017at+a4c+l8pYPK5y6H0GvN/35gz6gELn23vNyccFUtqugq3H/zI32Xzmacm8B4fl3LLKQp9zmHsXuHNtPjSJ70+2eNOdrFzh3hWhT/oV1Hdv2nz/2+RD/bWzF7Z6LOcteWGr29d045oce3vbOwN2bG3oCvTBBh3PYrSoSh8OfZ5l0AdUKlSpAuodVKoQ6LOSuVvBNuCwa9focRn0AViD26RT6HMdUw5B0N+td90stQsAHBH8mYET+D1aDAwHPvyH3R6z3/wcgz4j2Hl4D0qZmW96uAB9xjD3I1D5bDlLxCsCl7SqgMc2iOrC+tbPvLhoP43S54JDuucG5XtRX7RovzTp36+S8Ykk9EHl1x0Lnubj10bok96Tup7mfA0ysOmaN2AI/IFhyCmAGACqC8T4lOOTJveAROZNaF5RThH6uCAJPV8W2NRRBrVDej0q15FudtV9TNcO9XJ2zXLXeVP/issGvfnQwR/f8yqQgZp0oMR0XE2bKW/c8XxomRT8mI6b3Lh80tM0urg/rjJIv/gg6kCW3UVKp6Thc8oAWIywhkxEVPqoaY3ASAd25OTyBT26NiOIsgGmh/4vc/3a7ahqgZ9VSMK7gACKgCf1mvWCQaZyNIvZq3/3M6b0mZxT+tCtzb+z9+zidu2kHFN79vuLgD4Th7bgu4F966UZ9PFRLmGaA/9xVYQ+xcUzHokWsFrg2tl3tdpC85bs1Or21dW4QYY7Jht2FfrM3G5KIaZPCPTZ/Z2PJzd9ahIHPujOhEofVOioKh9U5Wz/8vGpTe7/83P8Pah/uJKHAYTxW43gCp8hmDXsPw6cJDgBmIRQCr4c77hmed6+LP0WO7BNN2Ucosvfc2+iumjVNalpOW2m6mX6S4EP5KfQZ9oLM1c/gD4A4sC9q21KH7Xf/TZGZca1Wh7fx95qtYgHE/+6KAA6rUYFkPL8kXYqFNz4wBN7mjDo4wt5Cg9VyrCZ2hRSvqsO9Tw2oW3Qx382GvcnINb1hTr8m1HmMwEeTFMGAOncq0R59UEflwsXbb8JDLmOm8ooKorEslIP9LHBmVqhDwUZ7H2ubDk7fKGPrs0+0Icqkh7+mwBALzrSP/Bzbjl3AB6vtB7wRetORRaYff/w02RiskUyeWgrtkn7WObe9dfc1uaXvGIOT63CHXpM/ZqCz/v/NQ9rvr6HKKcAtkjZBYDEzh10O5QjFDoAj85d9+7k7iWP5Nsk+3PTLn/Prd773LlH+lmn9JmezEjGDbENT6J7V85u8UPvW+Da2fe0uhPzluzY6vaFNC6CnRBrdSmmDzZRB33wHMb08e3O9e8Zz2L/sJguE5jKhrl+oeuVml8HfSANgh94P4HF+gE1EO7QAyofgD5DoPhhM0y4eTHwAwGkWeBgcC+7/efLk5sueSyB3bNu/alQpPBt5tkXcKfj5gQ8q/qatyvpIEAzj0+kqL6222tcrj23X/s0G4sM+mw1O9uhDBK2aZeyfhmbrkyItNKQx9/qLQ2BP1AbBUCnSABEW2EDOaEwB8stU6Ytb7Ed2REfEBUCZXyAFLS1TDq1j2o5uvNVj9lmp2vmVsmrm2Pm2a+CHEipgzbqcfzsAkE2AORyxxJ1VIM+Ie5XtE9q21zAyOT+Bcf1bQiFPjllhg2+wDly3qgMkhdBuq4hxFHzpuny5RbcweA0WRRsah2dK1k65zXtsLqesXofuSVT/+xyeKb+sUGSsvF3uDk0i5BR/UPXLAUyYZ7X/NEOfS5+Wd4tSwd41HZBmtfdkoc+/7aboRxsl1woVBXQvDuvyrllfWmnHZNnb892/UIABNkv2ukryYZkPdt9bFoydmhcssOQBE3s3PUbRTkQwwfcu5ZsWshhEkCfWUM7JRQQmdeseCZaoDcscO3spa1u6Lwls1rdPtq47kEdbEX3XbLqHKzWKX2wc01BHyjfBH6wbnD34i851nzSsf+BEgje8928WAxoVBMBaJq49UgOf+ClQh+qSvnwC2+sc/yMZfUDXDBBnzXM/Q9iQu1++BZOWy5btDoN+OxM3KEE/TA2HTKVpRrX43O9LQwFP1i7CoBcwKRO6OOqC9uoSxehj14to5t1NsClzsIqUCdkxrvT6qANvcnxVQL5wB38MtWpW/SKl2rQR6fKoW1wQScV2Njy6qCPadt30dcM+hRtZ1TLYD4EI7wgDWxxQJ88YMme+FVAZARGEiypSp9Q0CMMIdofCn3o9ydt56O3CgC00yFS/SPrIL+srlKuuDnZ2Im208+5680AeHQqm9f86SfMuWsr7t7FtOHJ7Zv+lgucDG5Z6TptKpf2U6Z5/a15hc6/vpiV4wA8Bbuycg9dlIc+X5hDFAIrrkhWPSxsDvDnCzt9OdnIsA9An82GxifbD8ng0eoiqPl848brko8t+ohHypgkWqD9Frh29n2tbuS8JTu0un3QuAh7mhmivoI+k2aM4sobm9IHzOiCPv91+pJk/zO3FtAHv83x/ox85ruDsdg9HAYxZRD83vl1E40jBcGhIfj0F4/s3DbpvQwYXNBH3f0NXLx40G0Z+wnGA+IuYcDnZi6h6qX28hhV732VEtyPtlVK983rC4QQAL2txvg/6QOBfEMtEgJ9XOCCxvTxKddWnu8533TkmYdbwQVmXOdVm9J54LKTqX5bmT7nXOWqc9V9ZdQJfXTgg9+2yR/Te5NKRqT3V/r4BGWmbbBBnzLxeqgtbcCnIehDYUCD0McIduCaI4uCDhjZztcFfbDeZbcJELHj3Lzrl039Y1PrGAEPuchUhYzNjYqe2/8veehzx6ZbcjF0vrGnv3sX7QO4ZdHAyV/dRcAatZ060EPTHHHPT3IKnfNmi3LYxrb8tR5tcPfcZP6ID7OubUyhD/RlGLuO2ZYq/P+vG3ZY8puNC5jOh8Xe5D/w/+HJOvbvw4vOVJew+DlaoGctcO3sB1vd9nlLtu1q+yLQ6Z75+wb63PBecO8axd27YOcsk3sXmvr3Z7NtMrcdVbA8AB+Iv3PihbvJL8nsT1H8r1LMdYx/ebI68DWauXGFBJ+O0KfahIfdynS7v4G7Hbjg9Rr0QWtE+FN2XrgfccuWXCafCwJR9c/JFeP/pHMH1iSlsT5whq9llrxZ+VnpunJdMEQHo7Bu2mxTOjWtbzpqH937qsd8AZKur+rccs1i13mTHfVz2AR9KIiBnLp0rmM29Q+WScGLekx8dkOfEEWPrl7aV7s6JwNYujr9j2VrfBF4FcCInDT8vkOFKuRcDjCQtFr4Qia8z3btvBq5QDihjwE+ORVJ5OJw1kVtQdqma+djt2euX7MPzNQ/RsCjgzjKAqGDJCEKIfU7fv//u4pF9JmSKn1U6PP13fVuWYU+yHbi8bl35KHPl3fesbj1PNqP/P7GEqrwy9yyIKYPgJtZQy9Il5OTt8uvSPPv+xX/JkH3LlAtCbSD6AcxTwZ94MiaZHXy8bv8VT7xPkm/osej7bHAtbMfbk9jNC2Zt2Sb2tvXfZBDu5Rfx2rvbI8UqBuTgYE+ut2z3njB9jz4L1eIsLg9577qpnQo3/rZF/P3CHnUMf7B2benh972ld29oM9GpgrayJQnnYQ+6T1LyBNDj0xoaOYpX9092+VNgT69sDuZztTxpqbsBGz/JFeBEAVAJ5VQAJHnpVLQxwcMtWG7dtpP23v1nPLMJtZ0zfTyOeaTxlS+7biujdp1IeCycF8JvQh9qih6wHj+cCaf1pbXN+aPqLsIfbJxsKphVOjjAVi0AIVMRB/o4wWb4Joi5NgH3ORiD+XaJC5QL1uQel3pn1goANDMAwzqH7ouUNtiHcpFGqTskXkLedjxA/52FYMkU/kuW+DedSdTx1CFzr/tmsEal3sWN6Ns+yELwb1rRhpD56IdM7csTCP/fslVOycsviHZd9gbCisMxuIR0GeIx99RXyfPEJXOf+B/+O8M+vxVIh8BewT+AW0P/BvB/7+e/Zs2tE1y4qKjA1Y3d9J4D+W2UUzRnAWunb2sucJrKHnekmlepUSQ42WmriYKHaP+gT7vk0qf8UzpwzSnV7zv3txAvPWyOTzmDrj8LLtzNVcDjZ00Itls8ggBfZhL0Ln7ZNAHMx/3aQF/4EVBj26UT7pot9w28xDwGeP+DGPbzF8wr/tbpMcvw65en5Uqj2MXaj73o29oiU2lhwcwCoBO9FQAQXtc4MamwnHlFeXnS9Dl8akDbUfT+ubzTUftoatPd973WK9AH79Z32vQx+aSZVMNmVzI4LgvsIEZogNGCKFM54t5moI+OjjTCPRRYFO6FpSAPikEkRegF2CiQAjWJlmvC/rgWoDwZ/vX6uGPUQWEdZHFQgdx0jXHExxB7B0b9PnXF5Vzyzr8buGWhQqdC2QsHnTLKrhnsfaeeO81yfNMdzN32Ju9vub+uPHXLP3q5LIZIrDz/Ify0Gfhpr8zZ69NUucjUI8KfUDls83Q9slJi47xqrPJRPH+qknrDlbZ185+vNUdPmTplJa0LypyfAciFO6Yyu156IMKnte8b7pw75LQZ+WT6/mWy6PHDWdwh/1dgQEf2HELQMzD/1jFd+caO3k4dweDcyPYuXP2LkIf3wHppXTxy62XRqvY1jh+vuPn9/jrW1rT6agKiAKgExQFkAmAhB6nsMMOVXoH+viAmbrS+MKi9EHQMYFcs9V13rceka7d0AceFfUxgWwQR3UrU2FQ1Xg9WF7IzmB58OOEPgpU4XMMQYfhnE4ZYwQoZNKi0scbGOnAjpx0Rvgi67MpgXi3KMwx9FcHWUKhD6Z/8q7M9WvbVwsARL9XTfBH992rtkvNS8tW0x5425XMuWsad+8amYxKAJRQpc9XXujnloXlonrnSBmLB6HP52btmMXfMZD+U+67niGYlRzx01g8qNChSh14v5Yhn+9s8/r0rw6nPfJL7gIGEAt277p70+0szVoSvQcVPkLlA39MmD60Ld/xqw3QJ10/fRfapm8IYvk9a4FrZz/V6rYfstS9CU6zHYiwx9e+dcEerK+r0AcaAdu2w+toJm6lL3X3Lp17FqSHLdLhddvVy3PQZ/qLxiZL/vBsMmrcsGSMBDvDGPB5csnzyfrnN3LIA0ofCPwMIAh33tKpfXwHp1fTRYjQmyMXx81n3Hr7Do4qgI5X1D/pTap84wN9fNLwhxRiWp3Sxw6J8uPim9Y3XbF9WX1lgI5PHrVO1fa0x6YZ55qJVc/b2pQfEXrDZYvPA7lc8XswjW8cH5peF1NHnHfH89GVY4M+JtcuUzk+wMgFoCgkkv3ig6xrp95Fis87BwTxgj4IjMhENkEfm2qmED8I1x4JhFx5tYBJtsk3bwH+eEIiE9xafo8AQNvsnYc/6verDgqZ4BCOG/2tc8866I4rGSJhf7Bk7l0AfRZtujUXOPmLLxBKn6Puuj7Zb9hB6WV8xmwImSxe31Li8MAxcMtC9y6dWxaPx6PCH/b5hAev5qAGoA+AGRGGOR+LB4HNmmRVctliWD2lAAAgAElEQVS0bPv2U5fdwJU8CH3O3mpWcvTjVxagzwjWU6av57F8tmM7fLUN+qRGLvEm3pOVMFofZrl29tOt7tUhSyc10L4IcsoYtW6o42pD16EPNhDhj6nBB3xo69R1CgDNjD02yyW9/RoBfUYxZc/Uncbkzj2xZA2DPOyLi8GdJ+5mO2gx969Rmw3jqiCEPrANO7h+RejjmjLxfC9ZIN6EqKPlerRu7+jO3mFq2ri3SgDEHyrkUR00sYEUU95invwR+XyXM1QeEuVtWPe5EDhE+6i+x1b2AvQJmbXutG2BPjr3KhiVuqCPj/uVqK/aj6mMolpJrMf+0CcHOBDceAAWI0CRF0GqKkRgkh4P3IkL1h+yAPmCGwRV6Vw1gBveLKW/dUEfta1PLxHwZ/orF1iDHhsDNyu2yK2vdOxwvWbH5i68gkGerQvQBxU6uEX60fdcx6HQVkNMRZOMSz41ayYvBXbPOmHp1XxnrJDXbzf+IvnetgwiKYvFKQ9dz7Q+z/H4Pbi/li4WzzoGhi6Z9rrcl8+pj2fQB7ZsP2vLmckJT1zNd+cS2h74PyCfUfzT+GRzrgj61Lr38KbfveRRsGBIN/o+bbx/680hvnb2s61u+CFLJ3i2L4IcT0Npk3Ua6Pi0tTXQR9fY+d/Yg+3StCEBw40cOywHfZ5+aG2ybtWG3PFZ+4iJ/CiL2SNi6bDAySx4Mu7mBIqex+5azdOA2xeogEYy+APHAfoMYzs/QeBmGtDZx4j9nCZ+6fTX6MbxxPHs7ZtLCoCO0yiAbCCIzmhdOhv08Sk3BMqUAUIh5UNfbXWo522zwwcO2WaVa8ZVyasbU/PKpap3IKVOqaMex88u9Y+uLFP8HFpmlq+a0ifE/UqtnwKgsjF/zG5kVaGPL2BBUMLnt4Qm6VzngAUpRFFhFARusHxZuLFeA6hyQR+1LQW1jQLCaH9VOGQsi4IvVgDCHyhryl569Y+q8KHriLFeYitMc8hdRehDFTrnzX4BD7R8/JJf8EDPWw5N4dDnrB1misubnTv5vgVMNbOGf1TdskCpQ2PpAMDhwGZGHtikawXU9ejPmMPVhkIsHlDnALSBMlYxMHTZVpnKB/Kf8sT1HOlsyRzWOPSZzNrIyjtm+VU8J7SEBWDgaaANWzLcBenOncC2pV93eZI8eylvhoA/tpdrJXVkj6e9LdCr94vdfti+ZtYqbxt3I+EhS8d1o9q+qrPbc6ysMVsNfaBTx5+3qzf0ATAEAZnTHwZxKPR5+gHm2rWWRQtgQAiADyh9RoxhwIfl4UGX2W9Y5AZR7eOaQL26+Lv6Fc/Le8eBv4/qXQNQAHRsQABo+cyAzw70vj93WVD3rgh98iuGDUCpa0sVqBMyO91pTfF8oMXUZQk/q799oI/O9YmWb3KNEmnCoY8N0OjqtblmueIJqcogWr596/cM+hTBmKpooW5bxnMG6KGDL3nA4oA+SrlG2MS6HgSJKIAC2IIXCYIXR70u6BMCibR9kv1B+624T6h/ttiTwZ/MZNlaSdtLbFFop+YcuGcdfs+VzA1raxZweTJXwNy16R+pe5fqlgWBk1Pos/3MnMrmrQ/8lIMa2xbpwl1riDlVrUq+Nz1zFVPFNW9bdh2HOmrgZYA1cAyAzXe2ZLF8lC+QU5YL6INqpLMmsjbKNMc/8zMOfUYzZDWS/fvG5vsW8qflPSNgkhv+pMNQ8o17pSxZcMw24Ba4ZpaAsG19HbJ0bFeb9oLZ072vb0hLX6Z1wTcdlqVLXzfI2XFWvu33LLUDbUjvSlN14FoPfUwdPPlLuxeUPi7os/w+gD4sng9zD4O0CH0AAiH0gfoi9NFbPYKfqpdb+/PHMe7tG0EKgI6xbAGPM5E8g6WTswgysiOdgj42mELP+UAXW3r5TFK4MHWzILQutdD+hD4uuANWsAEWer6M0scH0Kh1qPF6aOwdG9CxxQWywZ6s/2Wgj6+6RweJ+PyWF3kB+oQAI3Lhq8qhUHVP8Hbt8iKFemqHPjZoQ+p79v4s8PPE3RzqH7Q5+U23R4fu4BbpCzZekUIfACZ3b7othT6zh3bW3jA8sGlpctaMmeKcbP/JDy3gMAcj8Ni2SL942v5ZueqCLj8f+8RVPA1urU7dslYmzyb/Pnlevm0y3+lP/zqDPhNkG+mXDV1wdXU/m1cPRfDT/nvG2MKiBa6ZtbbVZjlkaT6Gbicbi7DF59rWpdUBI9902E+1jLphD9SDwIdCHBvU0aVvYlx6FvrojPG+H+6VfPXY/8ud+uBVL09GjhmWrHh0XbJhHdtAkn3RjITdupjCZ9RmQumD26qD4offn7I00cWr3HSL0KCc3dqeK45rb8IggEBHa+L/6O691Xvz7LMd+rhgiAm6+IId2lbbe/Wcrj8+MMenHN80Jpuq17trdrnO0/LcaU1Kn7pUPtAaFwyqqvTRARharwns6KCOXZ1TLd5PVl+2hhbbZgM7VaBPLi+ZjBjEmc9jhEIGCGTdWYvk15Xl2pWLV6nUa1MO6aCPl+007SzAKkyjsQmNQbTyQQGAxr8oi/2T9p29UQFPYXt02WexRfrzHPo8kSxL3jDsTcbbgJs33siUPOuZxmZNsuPQLsknt5kp0hJwctwjP9FukQ5uWbhVOlf5TJEqH8tiePKTwmUM3bJAhQRQaiP7d8mkAwp15xquwhylnWm7FcDDj4/9UlbU6jO91QBGw7XqhHtlblVzY2OYBfC7MswY18xaF5ahw6kPWTqywzUmSagSBxpoUgSpx23pVOVMJ9Q00HZdPaZjdDCi0qfi1Dzxwt2SSTNYgGe2SxfE63nu8XUcAo1gP+J3Bn04/GEuYYOydXtF0wZlj9AgyFw9lTiOLQ5XO2/qqPrnKM8A0FmP8n2y3c/rrFAH2KHPDLb36jmf9vjk8U1jSmc77jtzQmaWO20vQp8qih6wskml4zpuy+sb80fUEQR9CAgJdp9itakgh0MLMhF9oI+rXixOp/Rx5cXzjUAfne00NinYCNOY7Ic2lOdXPSTgz5gXLuBxd+BVADwm4s3SnnrfDTxoMrp3Ld20qLBbVhaTZxjDQ2uSaUPbJJuxmD6fnD6zEMH/xGUCImEAZnDFwuDJAH42sH8XbyVVPh4L+dHLr+CuWFAGxOIB8JO6ZakLlwv0uAAPlkd/9x300XUyHutHC1wzC9FvO3t3yFL87upc+yiYCXHvoi1ERY4vuPEFL3VbwaXoMal/fPtVpb1M6fOE4x7RfQtZpQFN5z3pC7uJrdzZtu0bN2xKvvimP/MqT7hgV75l+7gt2RcaC+Z8wbybm25KLN9ggQgN+nNqxHHVjWt311MKgN7i2AIeWq/brl0cz17dBDu2dqjt1H0um8a3LPXZyHSlu2aF67xvPSJdr0Af3+DPNvcxNXYOfPbZ1ctWpg+AKsKkTkEfo/KFTFrTdu08iaL8SdU6qiJHTro6oI8LEmG7vJQ+FaGPVWmE9pG2hLSrH8lcv5Ids9g/uWtdhSLy8zEPwtbqIqaPDvpg4GRQ2MAW6TOGZjLos1nyyakzRfFKueoW6SIODyCfESKWzxbFHbt05Wg30TL0IZd2Rd49K7UBVfCYFkH1eIQ+vpaK6VpmgWtmtaxBSnMOWdrd9lHoU8a1yheOqOl886F1aEyeEAVOCPShIxHaPvMomhVqHtCnu5Oj6haORuhzPoM+kyP06fbo6uqPsKCNo1Jvm+IY2+zp+4hfbUwoAHqz0QUs3xaPPxCXAkJ1gCOd1WzlovXKpKHPW3QUTCPnGtGq50190c+QNkOfMkGcfaCPeUctuwoILFgl5k8GrsSap4NQxR20cnFvJIThc07zXoUURmhBJq0J+thcpQpuWHJy+UIi2n5V6eOCPml6Cp5kf3Q2wbpskMik9AmFPrRtzy+TAGg2gT+6RVPa7piHAPpsw6DPpGTJpoVc6YMBlKlb1lqm4AGlzeShrQT02Wqm9tZY3SIdoA/8QKyfb07eT9Rqgje6RcQGesqod0K+siL0CbFWTNsiC1wzi7mMtPh1yFK2rXWNr1BwUwVu+Ma+scXU8QmwXAUYNQt9yrkc4nD3APSh31Lhs5RDH+beBUGbN65nSp8jpdKHQZ/NthDQB4I6R6VPuG2bzhHBQNMW7m75cXxt9ndhgHrHDgHQPxP4I1beIvSpA9Coq3odZbqgj+u87pmnjmM+32C20Q6ZCe609IZBB398z6vwAnrpiuND05hj8oTv3OWCPiYXLld7sI9lY/7kFUV1Qh8bnKkV+lDIwt7nypYXhy/0KcApcnHVDX1ckEhrP1jvsI9Kv/k1DOfkb950mZbWhefXPcbgzw4i4HP60gCUYx+9igduBugDuGfxpjs59KEBlCE/BE8en2yeQZ8tZxrhzdHLr+SoB4MvAyxaw3Q+35uoUfnogJQO9DQNeHRfZxH61PslH0vrmAWuntX5mDkhnTt0aT0xh0JhD7axKvTxUd3Y4ue44vyY2ufb7magTzXYg7bvEegTMp3zaU+6aFfh3pVCn7/wBMef92IOfDLoI2CQ/uW+lS7fwpizrAUiNChrufbni2MbMkb1rU9U/QMAKG7XLsahCjAy5acjPFjQx+ReBRapQ+nj634l6qv2oytDhUSyX4FKnxy4sMEXRf1jVL7IichVPun7bHKnwMNwrhCUGbISQOALbmhQZFM7dAGgC6odj3aq8EcFNbl6ZH909iMmK6itqN0Q+mD69Y8T169ti65fxy7TQx/qlgWxfEDpMyGZmEwa2lIofSbNzH9BKKAGtkgXsXjGZFukm1Q7dIGCNN0APLqvOwZ9dA938d4g5N4gpu2GBa6eNaYb1XrXeejS4pbyZQEOVqqqZ+C4Cc74whPaoSoKH9pGnzb5QB9bf8tBnyEW/Hkas9ky73H0TUjHdui+B10xfXyLdafrxmJdD/Rx963+FPU9yNXftnaW2I351U5L9H+r4liHjnH4ekIB0JHzpxa8ArAFtGS1lrrPhZRPn2XU97q2Vz1WBdxUyUtngnuUVXUP5NapdtTj+NmmDrIpbmh+UzqRprzSx6we0oMdXZuqxvwxqYIQkOjVUEa1DGui7Zwu3o4WWpDJ7YQ+BpWLF/RxwSl5IaJqhjdLKmZcu3gVoI+jLlv6UKVPaeiDQA5+PyUB0NaZAujYx8G9a0YyYWhiTumDblmg+fnG5H2T45f/nOl8JnHoM5ZBn7MmziwqfXQLgQ301Bl/J/TryCe9Afr4ZA1NE+8nQi0W09sscPWszVptoMPuXdXV9oVCnzqAD3TYF8bogA4arJzKKFPp2MCOL/SpAug6Cn3qnmU+CzVAH75717jhyRfemKl5jv88U/psJZU+bBevCw6xKX3qbnkvled+jOiF3vjMlV7oR2yjvwXimPvbKp+yeM0jAHoTgT/kOTLNHgJlTECojjJ82iafNwtGKqvqKQtuXCus67zuWc888qZ4PpCDAgn8rP42QZ8yrl20zqzcMOjjCsqs1kHBkHpOr9Dxi/ljcwETfRPrUY3QxwBn6oY+RgVP2id44xdvKBeriFyAPmCrduhD7Uf6YmpLyk8Q5Mg8VqUPhT54USL8mbYgOe7Jn6TuXRDPZ/GmO2TgZdg3axTbb2s92yL9ddy+Zzzzuwz6TJgpStMtojrQ0xb1ju9XUgeBj2+TqqSL9yJVrNd7ea+eNaHVjT7s3me72r4Q6OOb1iddCPRxwx2zu1UZsAMgZ87Macnie+tX+tDB7mnoY5q1F965b3rq9muWc/cugD5Td8okd7dc8VQyfkqEPl298o2VhzzmVO9B/EKubsNeLSGOfdjIzd5hSprhCAcAMj2TqMdt6cqWgY20KY107fA95guGdO1QLe5a7VznaXnutCbo46MAClX5QMtC1D8ivR/08QU0tA2qEgjPmdU51Vy/svqydaZoD63qREIU2zmTMsYL+hhUMtq8BCLkzjPz6dLza0jCDiMwgv6Ri80rPZncVSFRod3YZkvbVeiTqn9wrOSFiBCIhZAULwKJss/s4NOXJseNeHvyg/XfTs4e+VU284dkTB/DFukqzKGLFT2HgAd2zGLwhL/K7J6lLlSd/Nxn0KeTpvOtq5/vfaooIXztZ0v385mT6iimsTIOu/fpxsr2KdgH0EA5daezlSnqEsDFV3Fj6yuUoQIcF9RxnfexrStN30EfCnyg8yn0YTF9pr4gD30mTB3JgjkPT0Yypc+FhxaVPv28KLomxuCcNz8mxfEfnFng09M4H/JWogDocAaA6DOI+r6Jc+qV6wIxrvPYu9ByTflcx+s6T0elGvShf7lyAR6oNUTdQ9OXce8qq+jR1esbx6dK3nwdRehDlE0mqCJhAl5YvoBFC0TIBYg7d/FDCpzxgSkpbCL5dWWZ1D+YthHoQ2CWThlEQU0OmmFfNDZRYxDpbMZBj7wQvaEPy/DWlSO50ufL688WubeQrl8q4KEXNr5vu3uWz5eqKU2EPlWsF/N22QI/n7lFl1tgr/6we5/qavt8YuZAA+uBPnlFjg7o2I4hQAwFMrr0rjJc5+sYtL6DPid9cbdk3aoNfEcu/sOADvze9iXjcva65fInkwnTRqXQZ6s5+cBbH9nld2n6+LBXx1Rrexn6x6U49m0ft863L86Jos0pAHqjBgCRZ06e2QZWdM83WKPvOVcduvJMx8rCIlsd1IIuUOM6H1JWPn4P5KRwp43Qx6TOqXI820bdz3VLrcsFoIpQqSnoo1MCNQJ9CEzhEEROuiBlkAqY5EVqUwPl3MHIhVBVGVTID2uSA7Lx5iuALqf2IefhuFPpQ6HP2PuEUZ+7NLucNye7f+kAT6+pd0K+qiP0CbFWTNsyC/x8ZqaIblnTeHMOHZpWaNbQ0ts61tQQ6GNqFHW/ssfgKbpLAeShL13wZHS3oulCXa8A4oTkj9CnxBQ0QZ+VT61P1jyzIRkaniS7H26msE8sXpNsWMe2dn+T2OXL5xUfAn2s1H9pwsY95NGt/2w1qD0KmyP9YSUEQIdJ+IO98gU2daSDOm1gSdcmXZ6qx0z56Ui7VgbXeVNf9LPJ5t7VFuhjgyrQK51Sx+e4765eJiWSr0uZL/QhsX4UqMLnDUIIwznrDlcqwCATEZU+JoChK7fgSiYnV5AyqCT0yalzpF149Q77+Ch91DQ2AFUK+hBIhG0WvwU5S5U+CH02SsPC7zUEAPUz4NEtVBH69MfNwID24uc7COVzW1+H3fdYW5tmaJc5fk5IR7rt9hfS1qbS9p/ShwVuXrd6Y0HpA9Bn9dMbkmEjkpwCaMSoYfzYsBFDyXD2A69Q6GMbnEF86GtqsvZiufWPv+8jYC9aK7YZnwf6wRJU/QMAyARzbHDG95zuqnBBH5888tmyMBy+eU35aYGuK9p1HsvyS9dG6JMpb/zi+YRAH5MrF1jN5eYFaWwBml1lkH7xwVFVVeWgj07dk7ogKUoU6oqVgRsBHJzQxwab5KTzUdxoIRLLz4vXtMMaqwiymPqoQiXaflKX1n6y3E5Dn+NXjuLuXV8ae68wiAp9Bg324GIWoU8/3AIMbB9+ul27oc/hDzQNfeqBNLoJFMFNtcuq76CPyRynfm33ZDVT+nQa+tiGp34gUG0yxNzdsUBn54Hfo2F3LBFrLWuBzs6h8FZSAHSoBQDJZ7O0AhMosqXDzLa8an5dnjqOmeqhFrRdkSFXqzutr5IHWteJmD4Uuog664M+Lhcu7KML/NjOm8ooKorE9ekPfXLqFgW+WMGEA/oUtmuXE9Tl2lSAMyyfDT6ZwI0aH8ek1tGVrSp+XHlN6Z3Qx2BvzpQkWOJmk8AqrYccg/PcvYuk59d8Woh4r4U+CH5A6ROhT/iXTcwRLdBlC/x025ZDnwcB+jQHZnTmj7Cmy5NSVj8w0Ec19+nf3oMrfqjS54tH+Lt0dWL42v4g1wkbxDrIzXXHjeF+jOx4k2KFtVqgG2sMAqBDAmP/qLMxBOroZnKdx6qAmyp56WRwX63dhD6uGDwCilSDPiHuV6I+/Y8LGPm6f2WQJ4M+Kvixb3Ue6j6lQglV6VOAPgRwGPMqChqM6eNS3CAY0aqKcOKi0scBtug6pWtnCCSK0KfWr5BmCuNKH93Wxe5VrpkGxVKjBfwt8JNt2g19jnj4cW1nIpjxH+NeTTmw0KeXBqwbD2a9ZJ9BaWv35kG80ernOdateUXVP/MCARB/oCSD4gI4rvPkGbQw1D55y4Ib15XlOl8O+pjgjy8UKoKL/E5eKjTRARb1WFnoYwM0NrCjO1cl5o/dDcwH+hjBBYIROeltcEYLRHKABemKXrXiUuhQiOSCPlZFUsPQxwaJCjaCtcQBnXC9qV/pMzqZxty7vjh2aebeNehKHyPwCVvt+vk7O/at3Ra4clq7oc+Ry4rQJwKfds+puloXoU9dluxiOd16aOtil2PVDgt0dk6EPJrGoes3C9Qx1ygAmksCQJvAjk31owM4PuBGBUkmEORblg0k+Zwztcc0f9xXoSmeDwUgWLrLvUundlHLMSli9G5OYUofH0DjC310wMaWl/bLBnuydE1DHxVa8LmDCh0V+iiAA9N6KWgyZlRwdfIGRgCxyOQ2qplUFZLsh08764Y+eG2pbYXP/Ie0DT777NwFWY5fKaHPGAZ94AXAB3/WDqh7F4M+obvkqGtiHd9J1b6n3atxtfIHJXdnXZDqsuqVU9u9e9c/P65X+tTV/1hOey0QoU97x6bWlnX/S7DW7sTCarRAZ+dGvBmqceh6vijd3EMABPCn16GPa7ZXPU8ngKus3tuu3Qe86ACSDTb5Ahvfut0xgbI5rolhlNKCioGVbUoVB/TxUbkU4ucQqITQyCcocwqYaoA+ViURuRh0oCYHqLAvpE9q2U1Cn+nJjOSiMUvy0GfA4/lUhT5t/GLs7H1WGy3Q/jbVpXa5fMt2Q583PxmhT/tno72FQyUna4Q+vT7yDbQ/fjk1YNQ+LrL++eJ+fO1jc8auSQvM2j67cTo4IPgzecZNbemrzglVEOnqCgExrpnuOh9SV29CnyqKnirgxpbXN+aPgDxB0EenbpFqEqeSxgQtcoAlk6WYYIgNpmA8Hwp6QqBPCphkmwp10eMOpU9V6KOqgazlETCUBqOm7ZMXIip/fJU+J6wcw927BhH6vGPdY2xvvGHJN0Zulf/Oq0HpE79EowW6aYH/ntxu6HPU8gh9ujk/+N1FSWhTtd0R+lS14IDnr/+Bf8ANOmDdrz5/Qh6LB8y4fdRdCoAOcgAg8owbBH3KgiFdfS4YVNd533JEOpN7F1W/mNL5uHthXlvMH5MKR+QVgZxNUIWWX1TNFIMyq+kRIJnKcZXpA6CKyp9OQR8jQCETlAdyRogkjzuVPqqKSE46hEa8GEijK9egQOKHQ9LTcjzyqkCH1lVoq2x/VehD7Zju3EUXByoXkvY6YRWBPgO2Xfs71z2efHOk5uE4Qp8++uYezK78aGK7oc/Rz0ToU3ZmdgvWlG2vmi9Cn7osOeDlVH94H3ADDnj3q8+fCH8GZQohAHqDIfgzfc5Cm/gAHZ80urJNx2zHbe2i4+g7q/3StRn6VN25S+dmBZasEq8HyyxTRgauxNqmj2OkAycIUWzntDtipVBBCdJMJqIJ+rjUPTmwIydoKOjJgRcPcFMANRLO8Ood6qccyCLptWBMlts96APuXYtFLB94we/o3jUoX2exn31ogR9trqjXWtbHo1c80bIWtb85vQ570MIR+rR/rvVdC6s/4PedSWKHKlggfD75PSJXaFLM2gELUPXPgST4M3nGxefDQmvqBjymGeWaabbzrry0U35p2wR9NPFtcluoQ+9UkKM7ZovpY4q3YyrHHZ8nv0uZKX1eUVQn9LG5QxmhBbkgykKfXNkSkuDF5QJG6vl0rjrATVegj0WZpEI4dOVC89LPqdKHXphc3YMVwPskOXHV2GQqd++S0KdHdu66bMOLkpOH39HMKh+VPs3YNZbaMQv8cHy7oc+xz/Uv9OkXOGOfrOUDnEfo07FlIFZUxgLhD/Rlaol5ogUyC+jnnN9jdbRjdyyAAAjhj/qspbZq8KAPvUmwuWohEFF/1+HeZXKvEnUJ1y5bEGYX9PF1v2oK+qiKINmvQKWP6m7FoYJ0B7KqUWQamj7lPRywZMBBBzByEMcAPzCmjwv02NocCn3oeuyrfiqt9GkI+lz23JsLC+PJY37ck9AH3LLgpXXNqmP5j9CnDivGMrpogR9s1m7oc9yq7kOfwYAz6iQsD2vqms4R+tRlyVhOaywQQVFrhmKgG5I+ZA20FTrbear+eX2A+1f6cKw01wcOVVHrVMlLm+pGkp2GPiHwpir0Mbl2hSp9ysb8sW3bjuIOnT0sMMcGeuRk1YIbFVrgJPGBPjbQgxMMysG2GdrhitVTN/QpKInIxeC0EemLEaxBGjIeCLRClT7HrxiZvH7Y4cYF8eQRP85cvAbVvSsCn85+YcbaGrHAD8a2HPqszqDPYMIX32HvPqTxbalvugh9fC0V0/W9BSIs6vsh7rEOiqeXOC/LDRsFQK+zuH+R5+JCRU1CHxeocZ0vB31UxY4ALlnMGfys/jYpffQwI0yxI+oKU/q4AA3tl8tNTK/QKbqX6ZRINuAjbJa5d6muaCWhjwJnKIQo7PBFJrdT6eOCPtQzyaQq8lEk8QaLhtlAi7pLFk1vy2tTBhWUQmR9NbUl5V1K3xD60PNwzLRz10krxiZr2L8h9m8Y/8H/w7vh/B8cvWTYU0my9tIkGfulcgtfL+di0GfJfY9V7kH8g0tlE8YCKljg+6PbDX1OWPtkhd51O2v/gZhOWpRBnydD7i072bbszqDDtcbqBtcC8QF7cMe+7T2vb262eMlvaBAQACH88YE55Nk0bZVvPl1etWuuUXCdp+W509ri+UBJJiWQCnUwbRFg6EEPTW9S/4g0ftDHF9Do6lXrNwEbW96QuD926FNwkZKThipIXKoZ665UUpXD5wkqfQywRec2ZXThgpdtejAAACAASURBVOI00MfWHwp5eBNc0Iec10Ecp5ubvDjqUPrUBX2gz8c9OzzZwCI1D+fIJw99RiQjOPz59voLGgE+xi3SG1pzSxVbE/ThU6y+L8xSXYmZBtcC/zmy3dDnxPVloE+ELf0wo4fuf6i70MdvXXbf0vbDYMQ+9L4F/OZz7/cz9qD3LTCIN8VU/XOAQ/3jC3hM306ub62q5+uDPr6uX2VAT1XoU1bRUwXc2PKatpPXw6Ds+6CoEvICFxzWFCGJeKhFmCNmglapkgMsGQXyymuq1xf6mABTF6AP2rpgI9kX61hgf2W7aVkc0MkLEWGdSekDCU96FtQ+qznwQWWPwD/DGfIZwf//rfXnNwJ9zlj3RPKNlj+MJjVCn97/hu5cD5q6FxhU16H/GL5l5wavRE0nbgiFPhH4lDBzK7N0Hfp0wyr1PZi7btu70btYZ69aoL552asWiO3uZQtk87c31kUEQAB/qgCebkMfP2vblD5thD4ulyxbzCAVTmFaX2Bjgj4uAFUEP01BH52qphPQR1W9GGGTRQmESh8baNHt3OVbl00ZVBf0yYEfAoXgeLpzF4FblAwd89xwvsyD2gfcuYRjFwCf4cklI5b3zXbtsMMXvv5342+Sb42c6v5649BHBIouvvxWOnclMUW0QLMWuGyo3dDn5E3MhTS+esYCQzUyt4GEPnWPdHse1uOXYt1j20vltWce9pLVYlt7yQJhc9xvPaTqn/2J+qcKCKLPeyb7ulrnOo/l+qVrN/TZxB5+w+IAhUAfV9kuwOTrUuYLfYjbl6KG4fMmQN1TiHuj5iUT0Xu7dplHpzBSoY8L3GB/chCHlm+ri9pG2oXPeYN9cmoeXXo8hvnlBZTa21A251dpx8n44FiR8z7Q5/jnRifr2T8KfUYkIzn4uXgE+wu8Johzo1ukN/AFcOq6B1OcBTqmtcnzyXdGznDXZIU+7uy9kcJvxe6NvoS0ssYn15Bqu5D2e5u26EKt/lW+bShCH39r2VPWCWTqapOtnAh9OmHlwDrCHmwCC+9a8kH9ouuawUtX3J/zr7Q5YsYBssDM7TJf/Ncq7l/ymbBgjaj08XX7oqAmr5rxi+ejc6GC4QiJs+OTHtLYd+Qy16n0i08OnfLI7ralBS4KeOATUQIMI3whk9Yb+iggKle2nP1aVZFF3ZO2E6+eALClwpyy0EenjuLmcUEkmSYXl4iAI4RCWH6q9KELAyFHpz03KXk2eSZV+AAUAehz6YhnhHUU6ANbpG9i/7yUMi1Zq09b91AKfaBJ3tu7DwT0ackgxWY0ZoHvbmg39DlleH9Cn14DMI1NQEvBEfp0w+odqjM+vJM7zA7ZPFZTtECch3FW9KIFEABR+OOr/iHP2sau2zB4CCL3S9sGpY/OvQrM4xvE2QV9fNyvRH3VfkxlFBVFYu3zhz45wGGDLwpgcUGfws5dcoK6VC6FQNIIQEh+PsEd4MQX+pgUNbwKDVSix11Kn7ZAH7DF8StHsYDOG1K3rpHJqOQ7I54Wa0WfbNf+9nXLONgKiiMUoU8vflXGNisWuHR9u6HPqSPqgT4RsvTe1I/Qp/fGLLjF8aEbTeb3eBRs4JjBywJxHnqZKSZqmQWo+uc1Hlu/+642nYM+vjF7VEBB4YYOXujOY12m+Dk0TwZDqil9Qtyv1PppvB9TLKBQ969M0ZRBn6IayqiWIYBDCyo0gMXmipXu3GWAM74whZeDbQsAPYWduwLy0u8MH/WTLX0hv7xQO630AXucunJisjJ5TkbyGcGQz2gRz6ePoE/wbmER+LTsmy82p6wFvrO23dDntFHVoE+EPWVnRvfzRejT/THomRbEh/aQoYqAKcRadaSN87MOK8YybBZAAITwpyy4ca0OrvO0je60qsrHBHDKQB8V7phAkCkGj0gfDn1sQZlNYEcHdUKAkdoHmwsYiduTKovytikFfRT1D+cnJpUNThJ+HjMWFTM+MCUFN3VAH5eCiUChpqGPqqwqKI0IGFKDS3O7K+DItnOXGCjMkCRHrxrGnLpgz66RyWWjViZsJ3fxs/bSRnbvav3KzqDP0vtNQZz9Wh/vAfzsFFM1a4FL1rQb+pw+thr0adZ6sfQmLRChT5PWjWUXLBC/lOucFO7HvTpri2URC2hMH0djcGYIVf/s5xn7h1rHNVdc50PKyrsXIXjQ/Tad0wGbPMDQB2GmaeqAPr6ARlevL7Cx5dXFJLK5imEAYL39TNDHV91T2OFKhSk4SRD6GGBLKehjgE8FdzDFJYtnc0Efcl4HfWz2CVX6dBP6nLpqItu8fSVX+aTQp09cu0p9E9QAfUrVO+CZmrwnH1RFyMWrWg59NovQZ1Av+wh9BnXke7zfTX5R9bhpKjQ/5FGzQjUxa3kLeAyRR5Ly9cecBQsgAKLwxzUGVc/XB318Xb98gzWbYFBV6OOK50PP+4AbE6ypkjdfZvYdVWybF7gwKHg4N5EwxQotcoAlU5l45SWKlBwUInXr2mGK7YNpG4E+npCoANlkXwpjQcvD/kpbUntXVfqArY5dPTz54ZgNmcqnJPTptd29tF8jEfrEb9c+scC3nms39HnH+Ah9en+q0Xs3/95E6ONvq5iyDy0Q4VEnBtX1iNuJNsQ6Slug5uGrubjS3ao7I1X/7KtR/4SAmhAbudO2IYhzCPRxxdAxlWU7bnMH8wFGPkGiK0AfHbgwQB8dMNKqhqpCH4NyKEgZpMIpBZ44IRGZ3CZllLqrFl5nTrhVEvrkwA+BQnA83bmL2D7vAwYZZAtRBQUuXfCC3x7QBwAPvP648dc8UDJs/37xyOl1L2edLy9Cn87bPNbYiAW+uaLd0Oedm0foEz7w5SBLSD2dUMZF6BMyIjFt31ogwp9ODK378bQTrYh1lLBAA0PXQJElOtZMFhcAcvXddT59sPVqfi9AHxtUgU6WVfoUd9Sy79yl1uXrUlZsX5DSR4U+CnCBVgW7g/FMYoJ4b9cu82jBjpxrRvhiy4vtoGl80lM7VEmvs588Fqr06Tb0we3QYat3+LeGOYl9d+R2XitBexOx62f1ByrH9Glv/2LLBskC33ym5dBnYoQ+/vOxP2AP9jdCH/+RjymjBbwtECGSt6kaTuj7+NxwM2Lx9VqgA8NaVxUIgKj6x1W26zwa0y9dG6FPprwJD+LsUvpUcd0Cy0J+U5BmPG+qg/SLD47qFic+66AKHvdS0hAAYoQWMo0oF2RDGGMIDpAA0KQsa7wdOel8FDfausiktYGWQqwitJdHO3PubjYbkb7Y7M3FOKjIke+5KQnEonV2Qukzf93DbHaCxmc43/b92yOn1bu2dqw05WEqQp+OWT5W1KwFvr683dDnXZPbCH2ahys46p1Q1DQ7w8qXPvTgw0/63TeSOoIzlG9f+uVaoYiYNVqgfyxgufg6eV32j0E71ZM4Op2ydFvr2WHbrdKmvdri/hUyU/zStgn6aOLb5FQ8YKKy7l0uFy5d2SZ4EwqOiooiAQP8oU8OWChKH6saBScBwoiCqiY7oJbjC1+M27V7gJgUMKnQx9FH+ocT33Z2C/pgvSn0oRdmSo6AGpEfabt01y747OHeBcnevm4Zhz7fGJmtKW1d94rtMjzcRejTO0MYW2q1wL892W7o8+4tl1cewUEGJ5WN18UCSkGfLrY3uGq/m2J3sVG54bZRTNEnFqh40VTM3idG7MVuxJHr1KghANLBn5BR8EvbLejjgjcCilRT+oS4X9mgjwsYmdRFOkWQ7FcKfVTwo1f6qNCnADoMgMWoGkrTK9CHwBab4qig1gFeYQJMEmbY2pzOVRVOGfIWoE8oJFL7Se0nL/RUtWMoO+U1Slmq0qfT0Ocd6x5jw7Opx1Q+lr/kM+Bz7wNP1Lb8duZ+3W/1ra1TA1FQ59QeTZrza49ParL4ymW/d+rTlcuIBfSmBfoe+rRtWHy+JjrzhdU2y8T2RAvgnXjnLOFzPXauNbGm8hbozZHUqX9CeuJOS2+idfDH93wRXNgVOTrAoh4rC31sgMYGdnTnqsT8MbmAEReuVLVE6zbH5+FcwgRQFDCBabXuSXghccASBn2MYKcM9KGwREIX2kdbf2uHPtR+pC8me6d8SxkPBEX0PBzjKh/sI70wkRyp5/EzBHDGn7WXJsnYL5VfBluX0/Mhvmbo0zozxAYNlAW+uqzd0Od90yL0GagJSTrLoM9T7vvGWqzToWpqaWvzhfhYI8Kf5sch1tBSC/hcIDU2vcPV1djyWFS/WGCHbbfkXXmVY+cv2l/3vDWpfKAUql7Bz+pvvXtSPq9OBUPLN6lkRBp/pY8PoNHVq6vfrNBxB3q2wZ6srsy9y6z00SljfKGPqgzivAEBBU4ShD4hwIjAiRxQIuXTunL1mvJCO3hC0TCfPuqgj1VJRC4GFYQVwBi2wdKWjkMfT9eu9q93nqCHdiRCn/YPa2yhtwW+8ki7oc/7t47Qx3sw+yxhB6EP+cbvMyP2Q3c2up8e+qGbsQ/RAvVZoMvXTJerr8+OsaScBRD+wEEXAHLPgW65dkHr63Lv0sXX0ZWvA1RqDCG7OscOfPzj/2TAQq2fQS4VjMhbo9TViHxWIYkOmGgBCs4oA/RRgZGtTWkbCCDxBTe57dTJLWBt0IdAJBskKtQn+2IdC2lDNW9jSp+ehj4lQE+EPvGbr08t8OUH2w19PrBthD59OvWc3eow9HG2JybwsoD7Vt+rmA4mKqta6r2edtCosapoAZsFWnzxtLhprZpTLvWP2469CH2qKHpMMMgH2Jjy2raT15cbBH104ILDGiATYjoaIYnpXA6woMymWI4PfMEgzrQdIdAnBUyyTQXQYlMhGcBLGm+obuhDy0PbknZTWMaHh6TvxM5drVqc0iDlNbQqKn1qMGIsoi0W+NID7YY+Z24XoU9b5kqT7UhRPGHyEfo0afFYtsYC7seUqmYrC5h86m2+9T6tiGmiBfrEAj12QXWruTr1j19begX6mOL0mECM7/EQYKMr0wdAFcFPp6CPUamigT66tGWhj5cySEKrUOiTUyFpwItJ/VSL0idCH8sXS0U1j+0rK0KfPvlCj90AC3zxvnZDnw/uEKHPoO4+FqFPXKOiBYwW8HusahIymZrm17I4tNEC0QKtsUBNF+32MvbPPl6xf9oMfULi+bhcxVxKHhMkKrpfCRevMjF/MnAlvhP08ZB0Ch7OaAzqHjxX2E0L00vAkyvXA/r4Km50Sh9XXi1gou3UtVmFRFQBVCG9FlBZ7E0hlTpW6RhBfgKk4Hj/KX0ahDzqosygz30Phu3e1Y37rtZ8l8SGtNoCFy1tN/T58OwIfVo9gRpsXIQ+DRo3Fh0tUM0C5qfEtt7w1PRcW81sMXe0wABYYPsZIvAzvMwAqE3QRxPfJhf3B3riC3fUtK4t13Vlu0CRb1uKaqA6oY8NsBjPpZAEyUlxu/UgcEMAhw4+udzQ0u+FULc1Xb0GlzdVIYTtbBr6YPkp9KFfgjkyhKRIXrRwDnftgkMdj+nTQajjWo9LQB9XkfF8tEC3LHDh4nZDn4/MidCnW3Ojer3V1u0IfaqPQCwhWqBBC/Qe+JHPGw3aJBYdLRAtQC2AAKgIf7oFfVzAREAY/527TOX5ul/ZoI8LGGHdujJURZDsV6DSJwcsDFDDGMdGSZ+uvxywKNCHui/hV4sPiPGAL7xeRa2TghecrD51UQUTKdNaPvma1KlzePWacnWqq1ClT/uhT7WHhI6stBH6dMTMsZLOWOCCu9sNfT76ggh9OjMT6q6l+loeoU/dYxLLixYYEAukDxQ93t+oTurxAYzNTy1QVP80DX10QEQHR9RjVaGPTqVjAzsuYGPLq+ujfRewTOmjuniVCMpsgTNaaJEDLA7o4wJMCEs8oI9VkSTLoeCmLMSxurlpIFHBRqQvLkilnkf3rnRIJEjiKh/sYyWlz5fJaqb7Zqp+09+65TICn9YNSWxQNQucv6jd0OdjO3cX+uyw7VYad06/tQ3iG9734JPaAaKxDyGBKR1mtpVVbQaI3G1rD7/LeeiRp+IzTx2jq5TRVvebBroai4wWaLEFxPI2CNdjXMhbPA270LRM/TOd1F6EEOKkDg7pY9JkLliYT1dm3UofH0UPbY+t/jLxerCPNtiTwaHaoY/NpUk9h6ONSh+dEshTceParj1dW6mKRlM2b4ILMOlUSLh2O/LS9V2r9KH5yfdBx6CPCoXwM7p3cdcuCny6sGB0q0oOffQPcd1qUli98Zs3zF4+qf0AgE9J3Uhz3sKJ3ajWu86Pv/AZ77R1J0QQUuaat+XVnfMBRGXa4WOTtrUH2xyhj8/o9XmaQXgg7vMhjN3rKwtUu4mM17P/ZKhmaf96upkyr/7ZWgIeelPtAj4+cMeUxuQaJdK73btCFD20DTroY1fnFOMJhcb8ydILFSTNL/urqnbgsIQk2tgzDjijhRY42QzQp5QrGTQT2h4AbmjaOqCPVUlELmSdOkfn2sVNL/uklp0Ok3K+tNInQh/zEtjz0Kebq3usu40W+Pwd7YY+n3hR56FPqOpFN64u6KMCHB30qaMdPnPOVPf9CuDGjTmwTPW8T10haSL0CbFWTNuoBeLDaqPmjYVHC3TZAkXEEq/5zg7JdjL48z7zZ5CK2wR9qih6bNDHBXBseX1j/og6sjntAX106hYD6NFBCiP0ScuFwsRQO2GICTDJmVIG+qSAiTegGExaNKwIlHTKnbqhj8sdrQCC6FihPeXvenbuGlylz/0PBSp9KtL6itk7u2jH2nrOAp+7rd3Q55O7Ngx9NEIt+OMTXuf0ve/g0j9eqeuFrTz1XNV2+LS3be2hbY7Qx2cEY5qOWSA+BHbM1LGiaIEuWSB/yx2v+c4PA8IfqHmf+dvKBpjctCgQCX3vo/QxQRVaVxGguHf6QoBkKsdVpg+AKsKkpqCPCUIUYIoEKQL0COijUxGZVC4FSNQk9LEBKQJWdGAopyQqofSJ0Kfz6462Rqb0CYY+WFBFelMxe0sMGJvRNgt89tZ2Q5+zdm8Q+nh45pWFPrBO6PKGQBY6V1ztsIEm25xrqj11zPMIfeqwYiyj7ywQH0T7bkhjh6IFogUUCwAUyNQ/2xH441L/2OL46CBL8ZjbtasM9KkSrwcBTpkyMnAlvjv08ZB0ahkBZ/TuU3jOGrxYzesBfWzAwwV9XHm1gEm2yTdvqhAiblE2pZEpva4tNntTZVJU+nRouawCfTrUxFhNtECIBT59S7uhz9l7Ngh9PAzlgi1qES51ThOQxaYQcnWxifa46vQ9z6DP8hKwu0QW3xbFdNEC0QKpBSJ8ipMhWiBaoBMW2HabLdJq9pm/AwFAFL6EvjfH5KkP+rjcr0zwyOXy5VICqZBI1FMn9NFCCwl5jAClBuiTK1tCKT4hdKohg1qn7HbtCGXob5PSR4U9Xmoo2R8rRMI+K+53KhTCz6l7F701hve5DMJ+aMcEgzjDgQEP5Fxa6dOJhTHWES0QaIFP/bXd0Oecl/YO9EG1jc01rG7IYirPF1bV3Z7A6WdNXhL61NmEWFazFoiArln7DlbpEUIN1njH3g6mBRAA7TN/pjSAzk0LTpnct2zAROSrDn183a9oO1XQ4wJGtv6piiDZr0ClTw5cOABKwaVJSc9BifyfCCYtDqiAw1dxw/NCEQ7FDa+GJyymTe9ADGomI6ghZVrLV127SJ8rK30i9Gl+AYxKn+ZtHGvoqAXO/Uu7oc+5L6sf+lBXKDS2CeaGwBMoi5bTCfcuH+hj62+roc/Dj5ZR+nT0+qlUWXxIrWS+FmeOMKvFg9OqpsU1oFXDERvTQxbIq39my5brdsaywREBQ1RAVB76hOzopXOzgmO+wEjXL/suYJnSp+gCZwIjNqhhBTcqJMK5xQGLA/q4ABPCEw/oY4NCHYc+CqjJuauRvrgglXoePvMfaWP8zFU+0lbpyfRzNgaCnpG0UemTJAz4PBAaxNmxfsY7wx76gunTpp7z53ZDn0+9vH7oEzKUPtBHVfhg+Z2CPqb++KgSI/QJmQ0NpI0PfQ0YNRZpsUC87Wjj9IjrQBtHJbapVyyQqX92lE12qX98gjj7wCIfQANNMrlr0XNl4vUgvLHBnqwftUMfnZrHpJqpE/pQXkGAhc0tSqsqQgCCwEWjBnIFZeZFmJREqtKnbdBHhUL4GaHPgLt21Q19yCXQK0trbGefWeDsP7Ub+nz6lb0DfWxTw2c3sDIAxgdK2dpVpk4or2q9PpfRUL8rfXyM0O9p4sNuN0Y4gp9uWD3WqbdAXAPizKjLAnn1z04WAFQV+oQoelzQx67OMQOjkLg/Iq1Q2BT7rnU1QvUIAQMuVyrVHSyXXoU+BjVPELghwMUGX3jVGhjFm+BSFamgRvbDqIzyTF/oJ/bFBpEMdZdW+kToY156mNLnwYefqmtp0pZT/rsv3sM1OjB9XPgn/9hu6PPZvbsLfWDziLKw15RXd9xVT0hZodO1zvaE1m1LH6FPndaMZZWyQPkv5VLVxUypBeJNTZwM0QL9aoFOrKuZ+mdnCTrAmjb3r8zlqejeVUXRo6vXF9jY8vrG/EHgg7NJ486mgh0duDAoeDg3UZQuWiCSAyxQmGiPV16Tmofk15XlDLIs22SDXi6lj9V9TKP0MYIx2ReXO5p6npbHzUTsmgZxJrbP+4BBBjkviI3TQM4DrvRpGvr06/oe+9VeC3zi95u3t3GsZZ9/9Yqutg/uG3TXvek4bWxIXld5tvPqOVdZqkF16V1luM7XMWgR+tRhxVhGX1mgEw9LfWWwjnYmgqqOmjtWFi3gYYEZW9Odv3ZhOXwDOZugClRaRemDAMlUjq19ZWL+NAt9dMDEF/p459VAn5RV6M5ZIBYN6IxKnyAFEwErJqiEAIp+XzvhVlugD7h2wQt+R+jjscLEJNECvWOBj/+u3dDn7KOnF4w59uG7OmbgEHDjA1MwDVUhwzEXUHZBltDydG2lx6q2p44BitCnDivGMqIFGrZABFENG7ivi4+grK+Ht2WdQwC0z/wXS3CD4CUDPOWDOGNZOjVRlXg9WF6ZMki/+KVWDOCcbuWuKG8gNboNqaocPKfdEcsEXHgmMSG4mxkqh+TxtC7yWSQu7vCFO3fZ2uF028LmaNphVSFJu1jbRm2pSa9VFnnYmyp50C61K30i9BGTtAPuXS1bHmNzBsACH/ttu6HP+a/prtJnAKZAa7sYoU9rhyY2LFqgdywQoVTvjFVsabRAPRaww8S8+md3VqXNtcvlEmaKD+Ryv4Ke+rp5+QSCVtPkFUViHVShj/isi6ODx3XnbO5QRtUML1CMrjf0MbiA1QF90hligkoqvEI7kd9O9zEF/qigJge+ZLk2e6fQh5RLYRmexzFI3bvo5UDJEaqkSF9T1y4YqKj0qWc5iqVEC7TEAh/99YSWtETfjAv2f7bV7YuNa84CEfo0Z9tYcrTAwFkgwp+BG/LY4YG3gFtJlql/9uBQpLrSxyf+jw6+UGjjAka2ncVURRBMAgjiLH6LV96FzAoaAt2nXNDHuV07NM8HxOjgi29eITQSL5+6qBoI6zUoo3LuYxH69O4KFJU+vTt2seVGC3zkV+2GPhceEKHPoE7fjkKfIbwX6qC140NoB40dq4oWiBYItkBco4JNFjP0qAVmbD05bfne819qACQ6aGIDNCpgqTteDy3fvgtYBn2KLl7aGDw2lY2qglGUJwX3qBxgwcRFhVGQqkgHfVxtpu2sGfqosEsXz4czJh1kIn0xjUVqcgnhcm5dmUmz8lmZUelTcjFiwOehR5rduatky7qWLd4LdM30tVb84V+2G/p84fUR+tQ64D1U2NAjy5a7/0zXQx2KTc1bIH6JxBkRLRAtEC0weBZo+9qPAGjv+XtJ+KODNT6KHl/oUyZeD8IbG+zJFEG1Qx+D0kULbuqEPgrgCIk3lNuJixMY0TAb9Cq4ZJH0trydhj4UCkHdHPhgH3XuXep5/AwxfWIQ5wh9Bu9raSB6/MHr2g19vnhQhD4DMRE1nWTQ5+kIfQZ19K39bse0aPuDS5w60QLRAtEC0QLlLbDNdKr+eYUGANncrFwuXNAuuzqneswfN/QJis8jIYKPO1iuXBX6GGCLl9LHAX1s/QmGPqqCCTmKorbRuYjpoA9V5+SAE4IkC4ByKX0i9Cl/nRdycqXP8hoL7FZR7bhX7lbvY71FC5z5i3ZDny8dHKHPoM7bCH0GdeQHvt/Nf1FHYDXwkywaIFogWiDAAgiA9p7/Txr4AwWFbOPuE8DZVCZu2247ny8/W++LiiVjDB50Q7KAHn5K425U2JlLliHSQ8HC8F55Zfk0PRYXBInUdubaBI2R7TH01wZxykIftUzrWKC9SPtyLl7kfKr0oWoenOvcDtkY8LEgNk4DOQ94EOf+gD4BC1xMOhAW+MC141vdzy/Pe67V7TM3rvnnth41jHezI/TxNlVM2J8WaH4RifCnP2dO7FW0QLRAMxbI4M8+rIJQpU9+Ry27kgfab9qRy6Ui6gz00alqtK5SOcBSHfqoqhcKhGzgJBdkmcIdA+jxCcrMZxkCI09lUMFGyGEIpFGBFrIaWl8w9MnJgSTswbGBc3G7drFo9I3Sp5k1MJbauxZ4/9Xthj5fObRXoQ/5kuvd6dHVlkfo01Xzx8qjBXwt0DycsrUkgivfcYrpogWiBeqyQN7169WsWB/1jgsSmQI9l4n5kwWYdip9FOUNQhSdkgbP6ZQxRuBC7oe9t2s3wJQy27Xr2sy77KFmyrlkQRYLmPGBRFr3M1lu40qfCH38Ln8GfR5+tLvuXfG+xm+oYqowC7yv5dDnqz0NfcLGIqbOg7IIfeKMiBaIFuiSBboLsprudLyhbNrCsfxBskCm/tlPwh/XlutgnRBIFOo6llcUievdf7t2G/TRQgsJT2qFPgYXsDLQR21XurprFDpW17NOQB+T6xvWraiJUiilgKPSO3fB4MdAzl2HPoO0fsa+ds4CXE6T9QAAIABJREFU7/lpu5U+Xzs8TOkT72U7N3earqmj0KcbW7Y3bUC8cetEPbGOaIFogWiBzlugv+Fc5+3ZPzV242Ywr/7Z3wJ2bNDHBYxsaiFVESTqCYU+OXWLDb6QWDA8TIxJBcNvRmQ8n/S9OJYDTIZzuhhBNvjk2pXLBX0KkIgsM77qJ1UhVNgFjNqLAptuQx908RrwmD7dVvr0z0oce9ImC7z7qnZDn397Uxj0aZNt+7UtnbqXGnr0sbh7V79Oojb3q1MTvM02iG2LFogWiBaIFihvga2nTeKZ957/Og380UEfny3gQ9y/3Dt3IXDRujlJEGE6Z4xjo0ILNKEP9DG4mXlBnxA4lWtTHj5Z3daITWy2o/cQhdg8CihLy7HYm3plqaCsdqXPoEOfFrh2lV91Ys5oAbsF3nVlu6HP14+M0GdQ53CEPoM68i3pd4Q/LRmI2IxogWiBaIEetQDCHwGA3iABEIU+ZeL1oKuWbcv3BqFPQAygvKoGM2Y7dyH00ClobMohX8WNFk7xSsWEwnK83NZaAn2oiogrrOS1gWor7tqFfaRiSA6caAZpB0wDwCe6djHXrqcNq01UlvboMhybLS1wxuXthj7feHOEPoM6WSP0GdSRj/2uzQIRXNVmylhQtEC0QLRAJQtk6p+DWDk2YEOhUNXYP+DeBQ+rRbcwL9Bhc9uSqhWrOxhaDJU+JvclVQHjcBfzgkQSfBTUNghEbNBH53pWIT2vEvtEbYBlWspWlT4R+lS6DO2ZmdLnkWUm6EMmMxm3BlsTi44WqNUC7/zvdkOfbx4VoU+tA95DhUXo00ODFZsaLdCkBSK8atK6sexogWiBTlogr/45hAAZ1+5eIVu+i7KytbPoGmZU0niAHoQYhR2r1Lw5wJKpTFSFjVFxo1MVEUCia4dO3aPbrt03r85dy8t2GpBT6CeFQdJWOkil1pcDPwo4ikqfClezF/SpUP7AZ61HLRXvCctNpHf8qN3Q51tHR+hTbmR7PxeDPs/Uszr0vi1iD6wWiNMkTpBogRALxBumEGvFtNECzVkgU/8cRuAP1KcqfEJj/jQLfXQqIS24qRn6mOLbBG2/TuGKAbTotl+vAxJ1DPpQFy8yBql7l+oChrF80MVr+K7NTfo2lxyhT5tHJ7atogVO/8G4iiU0m/3i41Y2W0Fauvu5Md4nd2goZDUR+nTW3rG2nrWAe/Hq2a7FhkcLRAtECwyABaZPxcDPh+MtkAQ/ZWL+ZDuAiRtXdbt2cUznIoVgw3bOGuxYdWHSQB+TasUL3EjrBCmDVDc0Cnroe5vrGUtnU/foIJEXGJPlWpVDmrqdSp8q0GfAd+5yu3cNwIIUu9iXFpj//XZDn0uO7xT06eXhreeZr21Qa2jZ41Hp08vTshfa3rZJ3ws261wb61nYOtfeWFO0QLRAtEA1CyD8gVL2nn+kBDaq6gdBjlsNpIc+AgKFQh8dxDBuRY4ApQz0McAXXlcg9CkAJhweXXydhqGP1n4U+pjq14wVlJWCHwUccfcu/CH9zWdAQ8q0VOkToU+1izjmjhZoqQVO+892Q5/vnBChT0unjmezyj+3RejjaeKYrLoFIvypbsPmSii/iDTXplhytEC0QLRAsxbI1D9vVuCPDvroFUGh0IcqSJw7XBFIYVSqSOgjgkkLwFCIWUNUKToQlSsbAQgty1CuVpFEIIizLgJWeBUEpNjy5mxI2tY66EPVQOjWBe2N0KfZCzuWHi3QJQuc+u/thj6XnhShT5emRo3Vlntmi9CnxiGIRQ2mBSLMGsxxL9frcgt1ubpirmiBaIHM7cpui+lTJ6YJ9p5/tHyPKh/7LmAZ9Cm6eBldpAjgsKl7KBTSQpAcYHFAH0XlQiGLE/rYlEEKqElXOYPSp6AMIstiVUhUyE8AlnUsNMCpFqVPhD75C4/F83n0MdfOXXHdSq/NaIqes8Ap32s39Pnu2yL06blJVVODI/SpyZCxmGiBfrRABFr9OKqxT9EC0QI2CyAA2nv+sSyZazt3dAHS7QqWKVd0YMcIIQxwpm7oY1MO+SputKoi/sQqLGwDLQW3NQ14scY2MoCaXN0e0MfkzobQh57//+2dCcwtV13Av0+lfe/73nvdC1KUUtZaaoHSliKL0rIVCQIiEPbSIkrcIERcUONKNBQlwb0hCFEWlSUCKkgIEiQlgBuCSlgiaoTSQt9731uK1nvmzpl77twzc/aZc2Z+N2n67r1n/Z0zc2d+3/+cEZ/x5K6A8wfSJwAeWUsg8Pwb85Y+r78W6VPCPErRRqRPCqqUCQEIQMCRAILNERjJIZCYwEr+PKtX/iyXVW1Kn74IHtvoHqvHtdeSpWpH3545JhGzChSyXmblLX10y9YiSCKfSB+kT+IDSS2+kj5fH7DCkKqIzA2hN9e8z/uDvKXPG64vU/pwjRx+RCF9whlSAgQgAAEIQAACEyVw53PUpV/PXRNAqwtRNSJIgKif3NUIGWE0loDUZUM6aWISN+2lWKv0ZunTGd2jLtFS5Itsr9VTvxRpZIz0cZU+luk3IosseFddV5ZhrS3rWiFtxo1In4ADvSjpE9BPss6UwB1bz/29vKXPH/1gmdKnpAmVq6BC+pQ0i2grBCAAAQhAAAKjEZAC6Mrrn78udtaWgYVLH+vlYLVUWsqZcOnTjnoJkT5Wgknu+1OPqM2SN/WCup0+lfSRdTbLu9S9epQxWJqhleBr/s2Tu5YjjPQZ7dxFxcMQeM7v7gxTkWctb3wx0scTnVO2HMXP9pdv5pHtTqNI4mACOR4IwZ2iAAhAAAIQmA0BNfrnIdddW/d7fYlX3744rnvmdAoUjfTpilqxitZxkC+dEUl1m0zSRxUpjVxS8/YtVaskl2ys8mj1Wri0xVBfW2wifZA+kQ7thfT5n6+UsrzLrc9c27rxmmrqZ/923tLnTT+8lwg9yyETgY1SrDg/LaTPbYxSFJwUUg6B4aY8FwHlzApaCgEIQMCHgBRAD7nuhYvsK/HjKn10EmNjs2MZGaNdSrWMMjFKn769fRylz0ZdEqCmHb3L1nQSx1H6aPnV5erGohE5su7WErL29/J9tbxLjeZRxBuRPoYjaMLSx+fcQZ5xCKS8Nn/26zKXPi9JJX3GGUtzrcPd85nbMm4KpM+4/KkdAgMRSHfSS/njORAcqoEABCAQTGA9+ud67WbIa9EtffJFkQrViqHW+0ag1MJhuZn0Uka009pG3FR5dfKlo1ytYGpLH0Mf2xE5bTFUVd2K3mlHCHWKsbotXfyiS5+1AmsxJIWQWN4ll3gdv3Fra/9rgudbkQUgfYocNhptT+CZr81b+vzJj7pJH67x7cd+lTLdPZdPa2QepE8IPfJCAAIQcCKQ5w+BUxdInJiAiBThVTqBc88+VHXhimtr+VPf/LelT190z8bGz22BIiFVoscgfUyCSbZPuAp5muqQTX3fN2c4y7wm6dMZtSTb2YrOaT+uveqWoS2N6AqN9EH69B+2CJ/ST2u034LAM34zb+nz5h93kz4WXc4mCYKq/x4D6ZPNVKUhEIDAPAggfuYxzj69RPj4UMs5j5Q/l7/g+rWlV+3oFdNTvLTLk2JKn5UzSv+4dkWApZY+JsnW+C1NNFEli2rGUhw5P7mr7msV5TP3SB+kT86nKtoWicDTb8hb+rzlpdOVPlLyRxrKQovpvsdA+iyG1PUym1u2Qo8Dmg0BCEAAAhAYgYCUP6LqBz93IYAU8bH2746IHK0kaksfQ97mglhGvqhtGFL6tKNzFLGi3WzaUhJtiLFFvtGlj7xglNJn5ku7FvuIRjz60l+NEzkQcbhmUtQPvDpv6fPWl01b+uQyzXI8d2x/5ats5JzLBKEdGgKa3/T0P/OMBAQgAAEIQCANASmAHvwc/b4/OjnTKX0agbIKS9HugdMneuool9qt9O5FZIxIkoVI4WKoVxfp07t8TLkAMPazboNpOZpuiZ2M7AmO9EH6rA6iRaRPXOmT5vicR6n5XUnneJPsMxee9ht5S5+3vRzp4zOuJeQxHUNInxJGkTbOi4DFb7FFknkxo7cQgAAECiOgRv9c+qyVAOrcx6YtUNYEy1L6dAkMn8e16+RTl/RRt7OxqUuWnaP0UaODKh+mRCY1T+5S2K+vARMZ6okoZZpc1iX+T6RPYUcpzYWAG4Gnvmq/W4aBU//pTyJ9BkaeTXVIn2yGgoZAAALOBNS/+jpnJgMEyifgujzZqcdJC3dqyeQTn3PWcuPnBz1zc+PnzkgVC+mjk0Cd4ka6ilpW9EXIdD5+vW6TKe/asitFrBilkrqErVXXRjRUXa5rpA/SJ9HhRqRPIrAUmxOBp2Quff78Fcci4jL/CdoUfRKxMRRlILCQPofNIwZGCBRJgKld5LDRaAhAAAIzJSDlzwOfsdr4Oar06dj3Rz6uvfIoltJnIyJJjpnFUrLY0kcrt1Tp09HvJpJH+V4u7ZJOTX1PpE/AgbmQPostJQIK8MxqcSlokcSzcrLNjcCTfzXvSJ+3/3RM6ZPT6HYfxYin5TghfXKar7QlEQF+zhOBpVgIQAACEEhAQMofUfQlT1sKIFXISCGxjIyRX66EjUxrG3EjpY9TZJCyjKkSI23p0yeYVDFUyxltH1sCqi2LZGTQ4NJHvaxYWwMmOlP/JweJJ3ctZ8ZY0qc5WPoPVK4UE5zIZljk9/1y3tLnHT87Vemj/AB1zLu5y5/tm3OP9CG8fHPqFv7LVHjzC/sJg3ZhA0ZzIQABCKwRkALoku9X9v1ZEywG6WOQL0ubVLuKlsjpWsalW4YVW/p07m2kkUQyOqkRYzWfJkondqQP0sftKB1T+Li1lNTme2crRnO9+nzSL+2z4jNWone+8vhYVU+wXvMsz0k0bd98C8u7JjgL6ZINAfOxalNK9DSZNit6P+dZIKMbZ9z5a0AcjpRSEoFzzjrYNPfip6iPfV+F2bTlx4YMUSNs5L9Xzkj75K5GpPTllU2wFUwWkT6h0mctKkjT9sZvaaKJ1MglKY6qpV21IFuFNS2FWQVO9734bDKRPgG/X8deOs7SrpIOcNo6CQJP/IW8pc+7fh7pU8ZEsz/f2oolpE8ZI08rIRCXgP25JG69DqUV0ESH3pAUAvEIoLzisRy0pIgDd/aZSwF08ZNF9M+m9GkLDytxU7sLY3RPLT42BJMUIko5fcvL1AvVzn2ElLp06WW/dJE+o0sf+SMmpU+2T+5q/9qKiRr5F7iSPocHPdzyqSwyy3w6Rks0BL735/KWPn/xiz3SRzNVmb3TmeZIn+mMJT2BAASmTIBf3uXoRrxxnvJ0oW/zICDlz/2fdF3V4bY86ZQprYgc6WucIoPaETIppI/Szj5JtNHPmkXfHkXJI32ylD4j/ZAspM9iZUHYQTlS030aXVBTfbqXSZ48KT/hlXlLn3f/0riRPmK5cueG7sqQnnP28omW7deXb17fDP7cjnQyXzu9+LydR5cmdJK71iHSp2iH2g+kT+iokh8CEIDAkATyvM5JTwDZk54xNRRLQMof0YGLnnjdUv7U4qPZf6f6YHOzZ92Tu5zyyrrU8nvqkmVbRfrElj5qeZKP0laVm1y1JdtbzpO7RMsTROuEHB0xpI+sv6DfwIKaGjK6I+fNi/I1P5O39HnPr4wnfeT+dL1P8auHU0ifr7QEj8tId0mUIeSKFD6qxOmrV5c+xUFVSR+upVOgnX6ZLgff9GnQQwhAAAIQgMD4BKQAuvAJy+ifLtGzJnbqZjtFBnVE+vQt6VIF1JqY6hNSqsDSiBqtoKrT9S4vm5T0yfyKLKb0Gf8Qy7sFmU+FLniFNnujO4//qVOznh/v/bXhpY/6NEoBp1f61PR6I4IsCOvyd5YZeVmbTvB0faZ2JXmkz1cDNnLexhZZTLvpJrHdOGq6BNx7NpUfNfeekwMCEIAABIYk0Mifa+rIn77onw6Z0hkZ1KyNWt/D2EowmSRORzu7JJF2CZcqfbrKk31uRRM19ShMxGf5RfoUdEWB9Bny0KcuVwIRD6XHviJv6fOXrzrhSscifT9AVbbYyhzbdLrGdeUNKdMCQpWkTyy1o5fEeyl6hohA2r7l1iMRp7otEtJBICWBfKY0Ykw/zvmMUMp5SNkQiEuAv7PE5TmX0s6qN30W/b3f41YCaE2WJJY+bTHTtylz10bSY0kfWW8jfdQfsLU1YAJi/Z+ALf4d9cldBf9yLqTP4o/MG4dcwT2ay+mDfjoSeMzL85Y+f/3rdtIn1bEpnkJps6m7XTp9K52ifDrGV41OsolMksX0iSXf74xTUP7hwpAQ6WMkSQIIlEog1Sk7nAcyLJwhJUyTABG0uYzrNBXbmWccqADf9zGrfX/knj62y7J00TzNr83iHzabQZukj4skSh3pM670yfd33PpI7RA+1vlnmnACIz/LkXv0y/KWPu97tZ30cRo8h8l69kL63Gx4kp8oTkif9itEFkmJ1C5XV+ZKOC075hIh5Ct2XOpwGhslMdLHlxz5IFAMAYez8cB9Qv4MDJzqsiaA8MlleKYpfFS6Uv6Iz+5z9UIALf6vkzXie5t9fqpfmY5lVLqNpKNLn44lY11tl7+K7e/F++q/GpZ8X0X5yD7qIn1033tH+uT7m+11hC6kzy23Hm42F/cqY6aZJjYTZjGKV780b+nz/hsSSB/l/G8aZBvpI8toz3+b6J+uNFL2tCVPO70+/x3W4gfpY5oBfA8BCEAAAhCAAAQgMDgBKYDuddVi42cHcaOmtZI+Stk66aON2JESRrn6b8upDVklRVWPsEoufWQFcnnX8Ru3tva/pmdsJ3x7X0mfI4PPa3OFeTHnj2CljZi+vVf9RN7S529eE1/6qE+PlFQWD4rSAhJpu74zz4CtrSp/R6SQEEripfteJ5vkGUAVPX3SSAqjviikPjHVjiBS+0ukj83okwYCEIAABCAAAQhAIIhAI38e1bHvTxUOtKxiI0Km+lD/nXY5mEbi9C0v65NEG9E8dft6JVJNKlmkj5X0yUs6BE2evszZSp9kPS6o4LLmYAli7Ht+LG/p84Hfii99XCZ8FOnjIZT66lW/0wks2T/TsjSRTsol3ZFlJ4RcaMq0dsfx9q1fYyNnH7zkGYdACSf8cchQKwQgAAEIQCCcgLr064JH9j/2vdlcuZY+tvsCWUX6WEYGWUsftTwprpR2N32pl3ep7+M+ucvuAj18JPMo4Zb/elEeDaEVEHAi4HecPvJH8pY+H3ztpvTx66kTzCZxCdInOBKpT0r1RCn1SaUYY4T08Zuz5IJAdgQQYtkNCQ2CAAQUAuxZVN50OOP05cbPFzyiJ/pHCBRP6eMqiXTRO+VInxvKmwAxWkykTwyKlFEIgUe85JSsW/qh12mkTwyjYNlr8TTJ9pP8XKq3jdjRNacrbzvSJ0T6iHp19Zhkl+n7TrwO8JA+lpOUZBCAAARMBBBvJkLxvkcgxGNJSRAwEZDyR6Q7/7vWo3+aa856/532Mq/KB9VLw9TomeZzVRh1LR9TP1fSa5dw1fVt7PUj2ye+V9ok2yE3ba6LbzYeFp/HifSZr/RZrCowTbGiv+e3v+jhi9r4h/1Q3tLnw79zMmp/V9ve2xV75hmb0kfkFDJIlS2u4sRGmtiW2U5nU7bae9t6THnsiNapLOQP0seJKIkhAAEImAlwAWhmFJIC4RNCj7wQCCMgBdD5D11G/5ikT1vM6JZ2NQIoM+kj29pIH/XCujFH0iLV/5fWSG7iLN5XGzkjfcJmXt65+d3Pe3yGat3DXpy39HnnW+66geKsW78QAY+FdVjU0id91AggIYHar3aEkPq9LoJInorVdO09e/o2nFbzuUb/2NYj63AVSz4DppE+039UqQ8o8uRIwO4Ek2PLaRMEIAABCECgZAJS/nz7lXb7/sgNnU3Sx0USpY70QfoEztDF0q6pR/kEEppc9rnLr4e+KG/p85Hfjx3pM9QUtrvnG3L+2bVoKD7mehbS52hpbTb3ihQQgEBNgMObqQABCIxJgD8kjUl/iLrPOH23qebbrlg+9l0rY+rPo0uf1tKvtSVkmrbIX0XdkjM1ckku96qifMSrXqLWdFZG+ui+F58R6bO1VUmfo5bTkOsVS1AkG5CAq0S48rq8pc/f/WGp0ifloHefe1zH36eVQ535tr/2daSPzwCRZ7oEhjjAp0uPnkEAAhCAgC+B0pcunn7aUgDd7bLu6B+d9PGVRBv79gg307FErIk0kg5Hs89QFOkjr+Cl9Jn90i5b6eN71OSeb6hbutw5zKN9V1ybt/T56I1In/QzcRyJZDrTIH3Sjzw1QGASBJBhkxhGOlEQgdIFQEGoaWpkAo38efDqqV+iCnWzZPleGxmkiJs+SdSO1tmoY4xIH6TPajYtIn0Wf1yOPLvCiuNaJoyfXW7T7addKSWmuvwFeUufm17vJ304bsaYjXHlEdJnjDGkTggUTIATf8GDR9OLIIDsKWKYaKQFASl/RNK7PnAZ/WMV6RNb+qjlqW1oLTmTkT5qtBBP7rIY6K4kGUof2VSuZQLG1Trr/OTPZc/LW/p87A1+0qd97raeAiSMQEB/HLmew5A+EYaCIiAAAQhAAAIQgAAEuglIAfStD2jJHxmN07Esa225VnXn0bOEqxY6G8vFkD7jTM2Mpc84QPKo1fVmMY9W59iKzZvxS5+Tt/T5+Bv9pU+qEWA+piJb/2DWxSN9UnKmbAhAAAIQgAAEIACBhoAa/XOXS5SNnx2lj3YfIFX6dJVXp5HPmpdLzhq5JL+v/0+kT8DkRfoEwCOriUCOsuDSZ9/J1OxRv//4m/KTPimB5DhHUva3r+yipA8h72mmCQdEGq6UCgEIQAACEIBANwEpgO588VL+iFd7n56uSJ/U0keW30gf9Y/68sldVYOV/+R7nty1HEykD4f/zAg84Jl5S59P/vHtEUdkfsv3Sr5n3v76bS5P7+LRqxGPFIoyEij7ZFLyicE4NCSAAAQg4EiAP9w4AptR8tMOLZ/6de5F60/90u3/I8WQ7sldnd+pS8IUsaSmb0f6IH0iTMCF9FncZ3QWxHVSBMYUkRWBS56et/T5+zfHlD6p0Zd9H9hHZ4xzn4P0QfikntqU30Wg7IN+jAObuQQBCEAgJwIIn5xGI9+2SPkjWnjOhfWTv+rmtiWPTvqsRQXl8OQuEfFz8satrf035As9VcsMwketluukVINAuUMTuPhpeUuff3xrSdJHjl7Z94G5yJ+F9NmbLsmhj3Tqg8DoBKZ1OHMhOPqEmkUDEBJymPnjziwmfCGdPO3QTtXSs++nbPzcfqqXuiRskTY76XN8psJHDFwlffYSzjaudxLCpWhPAvfPXPr889viSZ9yr9Gnce5w5Y/08TyoyQYBCEAAAhCAAAQgkJaAlD9n3VfZ9FkKHjWap/5Mu9ePfDR73VTdvkHVhs7K9+J9tZ+PeMl9e2RX5Z4+7e/le7mnD9In7eSYZOll35C63ohObQgvemrekT6f+rN40ifl2JUxj8o6VpE+KWcsZUMAAhCAAAQgAAEIBBOQ8kcUdOa966VfNtJHjQ6SsqgWOfLJXdXbWvqo0UI8uStg2JJH+gS0jawjExj3ZjmlULjwyXlLn0+/vQzpE3uCphxz/7YOexxEkz6Ex/sPeYk58zx4SiRJmyEAAQhAAAIQcCEgBdAZ99zc92cj0gfp44I2XlqkTzyWlJQRgf4b9fs+KW/p85l3zFP6xJpA49//+oui7dsOs6dPrIlAORBwJTD+ycO1xaSHAASmRIA/2ExpNOfXl0MHl/v+nH7Bat+fjQ2ePZ7cJcpslnepS7iqL2rOTWiQfF9/J5Z2iZf4/8yXdy3uMYyT8uCB/cY0JIDAWARuO3zMqer7PPFbnNIPnfhf34X0GZq5rG/sez6kz1gjT70QUAiMfSJgMCAAgfkRQPjMb8yn2mMpf0T/Dp2/3PtHvDb27lE+k9+vLfGqv5e/yc3yLvWPq3I/n6oA5T/5Xu7nI94jfXqnHMJnqkfktPrlIn7u9YS8pc9n3317s+H9tEapnN6Mdc+H9ClnjtBSCECgh8BYJ1EGJU8CCI08x4VWQSA1ASmADt19c9+fxte0ngLW7OOD9Ik3PIvlXaZIHyl9tjlhx+NOSdEI3FGfGFykzwXX5C19PveebzjycVtOxLW4I17L5DG4Fi59eLzs5lxxOzgt5xrJIAABCEAAAhCAgCeB4a/XDh1cLRs6cLeFAKpbPtiTu0TEz8mZPrLdQviI4VClz96eeSmY5+RLnm1nZ7nMUEqC5BVSQXICQkT6SJ97PD5v6fP597pKn5SozfesMWRHyh6UUrbguJA+x8zES+kR7YRA9gQ43LIfIhoIAQh0EBj+xp2hgEAMAlIA7Qr5Uy/JUp/SxePaAykvJE/7ZRMdcfDAviqbuMFG+gSOAdmjEvCVPnd/bN7S54t/lZP0iTVk5nsr5FFE6UNkZqyJW0Y5HDxljBOtjEHA/GMSoxbKUAkgF5gPEIBAfAJS/uzcdfXUL7mnz9r+zIs31X4+4iX37ZHNkWvE2t/L93JPn1z381EFzf4b3CBr5I4owEbw6CpC+rjhJ/VwBFTpc/iI/WbO512dt/T50vumKH1izQv99f5U7nmjRPogfGJNtvLKmcqBUB55Wjw8AeRPeubInvSMqQECEFCXfu27y1IAre3PLKXP1J7ctZA2N910UzMBLr/88q2tLvHjGb3jMruQPi60SDskAV/pc5er8pY+//1+pE//POq+1i/9nnd7YS+5kxnyLEJdEGgRKP0kwoBCAAL5EuCPMvmODS3Lg4DcV+aUO69H/zRP7hLN3JA/0hLVfZDRQDk/rr0lfC677LKq8V2bKLtEN/iO5IFdlnf5siNfWgK+0ufcR+Utfb78gW/w9K7oU8esUnK410P6RB94CoQABMYgkMMJdYx+U+eSAHKDmQABCIQQkPLnTucu5c+UpY+I8NFtOnzk6PEQhM55kT7OyMgwEAE99A4/AAAPvElEQVRf6XPou/OWPrd9MH6kD9ffoZNyGGmE9AkdJ/JDAAIQgAAEIAABCEyCgJQ/VWfOum4V5SPer60Bk+/rbovv5H4+4qOx9/TRLM9Sl3bJwZIRP+rgDSV/kD6TOGQm2Yl16WMvQw894puz5nHbh+JLn9gdRiLZEHVfhob0seFKGghAAAIQgAAEIACBWRFoBNCZC/mTs/TRCB7d8izRn/aePg+/8oHNmH7oI5/YGN+UAgjpM6vDqajOekufh2cuff42f+kTOlGQRnqCSJ/QmUV+CEAAAhCAAAQgAIHJEmjkzxki8qfez6eRQIt/tJ/cJSJ+Tt7YvUlyCClLwdNVhRrJpIqhax790MHlD9InZCKQNyUBb+nzsMylz4enL33kvED+rB8h2Uof9meIcypjwsfhSCkQgAAEIACBKRPg2Xnm0T2wiJRpXqe9cPU491SPaw8UPOYe6VMMJYCQPr4jRL7UBFTp4xLtdvDKzKXPR/43IjrzXjQRKxu0qCneP28fOerz9C4uDQadeUGVTfeADMIyUOYpnjQGQkc1EIBAIgL8USURWG2xXC8NSXvIuqSw2DpYyx9RudzTx3U/H43cEcW53Gym6Pvjr76yKVa39Ovo3gnLavXXors7PL3LEiDJBibgLX2uyFz6fDSm9Ik1KNO7V83x/m8hfY5Pj3SsOUg5EEhKgENPhzfHE2XSaUDhyQlMT3IgEpJPGiqAgCWBRv6I9DsLASTET5/00QieseWOTVfjCaBVbbs7p1ZvxA323t6eTTOyTLOzs1O1S/dEtCwbTKOMBLylz+V5S5/DN8WTPvldr5d9X5WaJ9LHeNiTAAIQgIAkUPYPSl7jiLjIazxoDQQgEEpgTQDtv2Frq1DB08chpvxB+oTOOPKnIuAtfS7LXPp8LJ70icU+teywb2d51/gu7JA+9jOBlBCAAAQgAAEIQAACEOglIOVPCRE8IUMZKoB8pY+MrDFFB+nSic9M+VyZxIr0UUVDXxtEur6XjDjqSmeKSLJthysnmb7drrHbo+uHt/S5NHPp8/H8pI/g7yIvfOdd3Hx5CSIbfkifuDOA0iAAAQhAAAIQgAAEIDAbAr7yB+mzmiJShJgEiEkGqfl95E2MdpjauLzJX90097UzdXu62uotfR6UufT5RJ7SJ/RkaSM9QuvYzJ+X+DH1b1TpQ3B/6dPHNL34HgIQgAAEIACBoQlwfTU08TLqG+IWxUUAhUofQb0vasc2Iih09EIifVyjXkxCxVamtMuJ2Q6XNoq0OukzVHtspM/RvePWU+TAAzKXPp+cpvSxHiBNwnGEUaU+Q5rtnHd7MZGHrdG5iWSAQEQCnrPdM1vEhlMUBCAAgbgEnMWAc4a47aU0CECgHAKPu6r/yV97x05s7ez328hZLtHqW6plkyYWzVDpoy7H8o306RIntuWp+X0ihGxYmiJ6uoRVqvbYyin7p9RtbR34zm+yQTFamsP/gPSJBX9YWRR+J4r0iTXylAOBqREIPL8EZp8aTfqTGYHo/iJ6gZkBozkQgAAEPAn0CSA1osN2rx0bodOVpi2K1HRq99ptMQkmkddWsHRhDJEbodJHbZOpHeqYufTZRfq4tMdzWvZmU9vqJH0uzlv6HPkns/QZVmakGL18yxyW7fqdGNIn33lByyAAAQhAAAIQgAAEIDAJAm3505YAto9ub4sanaARwMTnXZJHAu3a7FnmV9N1SamQSJ8YcqNLpug2craRNC5yxiSIbPvnUucQB4O39Lkoc+nzqf9zwBf259thBYdDtwpLGosj0qewgae5EIAABCAAAQhAAAIQKJnA7s4+bWSMjfhRRY4uAqfve5MEspE8be65Sh/d/LCRNH0SSSeNbMoUbfEVO7blxzwevKXPd2Quff7FRfpIovHkz8ED+7cOHzlmHCqRru8ly+hKZ6rDth3GhnYkaLcrRntC5Q/Sx3c0yQcBCEAAAhCAAAQgAAEIOBNQpU87IsW0zKstdUTlMk87csckebqWbbk82r1P+rhE2/jIDVm+TQSPHCRTPSHSp6+/s5A+F2YufT7tI32cD28lw0oYHdhdipwjR83Sp9FNLd/UljU+8kYKGZOI8e21rvy+dqZoj04QLaTPiTB950uklW9O2yFkATzSuJmLmVdvzTxIAQEIQKAkAnP6dS5pXPrbyqhNZyxj9iSnKzLx5K6uqBEX6SP4hET2pJY+LuNnkjG6slLkcVkutro5N8+uUqWP2HS8epm7uLV7v8ylz2eGlj6Lza13961N3SNH7Z+Gtsq4hC/EkSqN2u/bx4gqP1yjb1yOXTWtTvB0fabmSyWhZB3be5lIH1+w5INALAIW5/JYVUUup9yWRwZBcRDIlEC+t+D5tizToaRZEIBANAI7LfFjs7RLVK6L3lEbpUqjsSN9XGClEDi6+k31uEb62PaxeOlj0dHde2cuff5tHOkjRY8QQH7SZymP2nnN5a1HGklh1CeLQpZRmSJ6VLGjpvWJWLKYjmtJto8dyyPSx7XhpIeAD4GQA9mnvrnkQTvNZaSn10+kx/qYbgNkepOcHkEgUwL79p1S7fMiX6YIH5muax8f8b3pqVsmCdRXRxfGMff0MQmcnKSPaIuuvaY+mL5PMb3VOptIH4uKdu+VufT59+Glj4rNLGm6IftJH315/e24o4ookq++5Wjt+0oX6aO2DOljcXCRBAKuBBA/rsTs0yN/7FmRcnwC+A2Ez/izkBZAYL4EhPSRIsBW+Ij0Y0ifMR/Z7ht54yNYusSMnKXtMl2FjE+bXOuIcUR5S5975i19jn52KX3Gul73lT5d+dpLx0TfbCKJ+tqx+k6/pEw3v+S9JdInxtFHGRCAwOAEEGSDI6fCAggQDVPAINFECEAgewJIn7Z43+7c58jnqVkum0irLTFJlna5LptIS6mk1mfKb2pPionuLX0uyFz6fM4x0qfHDvmIo9jSRzf2NnX0SSSdNLIpU7RlmU6/UXXXkjJxr0WkT4qjmDIhAAEIQAACEIAABCAAgVEJ+EqfURutqTzW8q7c+jXn9nhLn3tkLn0+7yh9LCaBeBJf+3V0r7VZc22IdhdS5GhrI2eTPJLRPDYRPLIdJkkTIn36oovsIojatJbLyVyWkVkMy0YS9vTxoUYeCEAAAhCAAAQgAAEIQMCbANLHGx0ZExNQpc+xYyetl0Ptnp/3wvGjX4gvfVyGQgiiDSFkKKDKo3niV58sCpE+Xc2xkU5+0ke/SbW+HSZFtp5LXbGB9HGZqaSFAAQgAAEIQAACEIAABIIJIH2CEVJAIgKq9Dl+fCF9LO+1d+6eufT5YqHSpx05FCiKXCN9bKdZeulj2xKRbn3SIn1c2JEWAhCAAAQgAAEIQAACEAgmgPQJRkgBiQi0pY9tNfvvlrn0+Y8ue2VptWxBdKTzjvTxkT4yj6ZrYplZyN49fRh8njJmikwKxF5lR/rEoEgZEIAABCAAAQhAAAIQgIA1AaSPNSoSDkzAW/qcl7n0+ZJJ7pi+DxuILunj+rlshS6fjVjqS9NeTib3IbIlk630OX78hG0fwkaZ3BDwIGAbTulRNFkgAAEIQMBAgCeVMUUgAIFUBE491e+R7ana41suGzn7kss3n6/0+dL+8/LtVEfLztv7z41v/OVAf05XuWMSOFabSGv67Vpu7z5EHZFEarWm/YAGifQpU/rEtqj+U7u4I5sGT44AYmxyQ0qHJkAAWTKBQRysC7GvaQZrOBVBQEPA/poa6cMEypWAr/TJtT+u7Yp1b2F/NhAtdEvt2qfs0tfdHarX24vNqYaqKzvWNGhqBJjKUxtR+gMBCNgSQBzYkiIdBCCQB4FTT71T1RBxg723t5dHozxaQaSPB7TMs8xd+oQMT6gw8r+b888Z0t9B8kYQREifQUaKSiAwdQITPtFOfejon4YAAoVpAQEIQCA1AaRPasKU70sA6eNLzj9fiCxyvwtxz+HfswFyarrT/gjpM8A4UAUE5kNgYifR+QwcPa0IIHuYCBCAAASGIoD0GYo09bgSQPq4EouTPkT8iBa434W454jT00SltLqjvkX6JGJOsRCAAAQgAAEIQAACEICAngDSh5mRKwGkT64j098uH2nkrn3cc+RAE+mTwyjQBghAAAIQgAAEIAABCMyIANJnRoNdWFdV6XPixEnv1vtICO/KyOhEwGds3HWPew6nTjgkRvo4wCIpBCAAAQhAAAIQgAAEIBBOAOkTzpAS0hCIJX1itc5HUMSqm3JWBFzHwU35uKV2HZfthb1MW4Nri0gPgUACrgdkYHVkhwAEIFAEAR4jX8Qw0UgIzIbAKaesnt41m07T0WII3FHfUJw4cXuCNo9z+809UoKh7CjShbX7bHDPgfQZbuypaWACLgfbwE2jOghAAAKDEkD4DIqbyiAAAQsCUvpYJCUJBEYjkEb6yO6437zHAME9UgyKdmW4sHafDfY5kD5240UqCBRJwOVEU2QHaTQEBiKANBkINNVAAAKzIoD4mdVwF9fZtMInJg77m3/fWrmn8CXXn8+Xq92Ir1IhfdKMH6VCAAIQgAAEIAABCEAAAhCYBAHfm9NJdH42nbBTCbY4mDO2pOzSufJce2Q7e/rYQSYVBCAAAQhAAAIQgAAEIAABCKQl4Hpzm7Y1lN5PIK4oUutiHrjPvS5mRPq4syQHBCAAAQhAAAIQgAAEIAABCBREAImQ42DFkUaMbf/YIn1ynPu0CQIQgAAEIAABCEAAAhCAAASiE0AQREcaWGAc8SMawdjqhwLpEzhFyQ4BCEAAAhCAAAQgAAEIQAAC8ySAaBhy3OMJItnqOYzfQvrcHp/ckONOXZkTYHplPkA0DwIQmB2B7dn1mA5DAAJzIcB151xGeor9nIN8GGfc4p0XSh0jpM84M49aJ08g3sll8qjoIASyJ4AkyX6IaCAEIACB7AlwbZj9EBXewFKFRH7Y4xyrOY3H9smTRPrkN9FoUZtATgcNo5MDgTgn4xx6kmcbkBx5jkv8Vm0z1PGhBpbI710gQLJDAAIGAlxDMUU2CfDb4zIr4h1DQ3FH+riML2khMACBoQ7+AbpCFRCYLAFkyWSHlo5BAAIQsCLA9ZoNpng3xza1kWYYAsx9F85hx0As1kgflzEjLQQGIhDrAB+ouVQDgdkQQPbMZqjpKAQgAAEjAa7XjIgWCcJuem1qIM04BJj/LtzDjoNQ1kgfl7EiLQQgUBSB0BOkqbMIABMhvocABCAAAQhAYEwCqa+Fxutb2E30eO2ed83TnY8xxjVsTvexRfrEGB/KgAAEIAABCEAAAhCAAAQgAIGt8m/sw26+mQJxCZQ/n+LyWJbmNkeRPinGgDIhAAEIQAACEIAABCAAAQhAICqBsgSA2415VFAzLays+ZFikPRz7v8BcEr/W7at30sAAAAASUVORK5CYII=\\\"}},{\\\"insert\\\":\\\"\\\\n\\\\nSimilarly, the maximum stress calculation can be compared to the SolidWorks results. The maximum stress obtained from SolidWorks is 6.5 [MPa] as shown below. Note that this is higher than the 5.3 [MPa] obtained using the beam equation. This is the result of the stress concentration that occurs at the based of the cantilever where it meets the fixed boundary condition. A littler further from the fixed boundary condition, the finite element values are close to the calculated values.\\\\n\\\"},{\\\"insert\\\":{\\\"image\\\":\\\"data:image/png;base64,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\\\"}},{\\\"insert\\\":\\\"\\\\n\\\\n[1] Norton, R. L. \\\\\\\"\\\"},{\\\"attributes\\\":{\\\"link\\\":\\\"https://www.pearson.com/us/higher-education/program/Norton-Machine-Design-5th-Edition/PGM275676.html\\\"},\\\"insert\\\":\\\"Machine design. A integrated approach, 5th Editi.\\\"},{\\\"insert\\\":\\\"\\\\\\\" (2013).\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":21,\\\"latex\\\":\\\"y=\\\\\\\\frac{F}{6\\\\\\\\cdot E\\\\\\\\cdot I_{x}}\\\\\\\\cdot\\\\\\\\left(x^{3}-3\\\\\\\\cdot l\\\\\\\\cdot x^{2}\\\\\\\\right)\\\",\\\"config\\\":null},{\\\"type\\\":\\\"plot\\\",\\\"id\\\":22,\\\"latexs\\\":[\\\"y\\\\\\\\left(0\\\\\\\\left[mm\\\\\\\\right]\\\\\\\\le x\\\\\\\\le l\\\\\\\\right)=\\\\\\\\left[mm\\\\\\\\right]\\\"],\\\"logX\\\":false,\\\"logY\\\":false,\\\"squareAspectRatio\\\":false}],\\\"title\\\":\\\"Database Consistency Test\\\",\\\"results\\\":[null,null,null,null,null,null,{\\\"value\\\":\\\"\\\",\\\"symbolicValue\\\":\\\"\\\",\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"numeric\\\":false,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"real\\\":false,\\\"finite\\\":false,\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"\\\"},{\\\"value\\\":\\\"\\\",\\\"symbolicValue\\\":\\\"\\\",\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"numeric\\\":false,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"real\\\":false,\\\"finite\\\":false,\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"\\\"},null,{\\\"value\\\":\\\"\\\",\\\"symbolicValue\\\":\\\"\\\",\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"numeric\\\":false,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"real\\\":false,\\\"finite\\\":false,\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"\\\"},null,{\\\"value\\\":\\\"-0.0001652977943075572085334986311276408905418668319644609742238752002\\\",\\\"symbolicValue\\\":\\\"- \\\\\\\\frac{16}{96795}\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"m\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"y_max_as_variable\\\"},null,{\\\"value\\\":\\\"\\\",\\\"symbolicValue\\\":\\\"\\\",\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"numeric\\\":false,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"real\\\":false,\\\"finite\\\":false,\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"\\\"},null,{\\\"value\\\":\\\"\\\",\\\"symbolicValue\\\":\\\"\\\",\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"numeric\\\":false,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"real\\\":false,\\\"finite\\\":false,\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"\\\"},null,{\\\"value\\\":\\\"5333333.333333333333333333333333333333333333333333333333333333333\\\",\\\"symbolicValue\\\":\\\"\\\\\\\\frac{16000000}{3}\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"Pa\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack Pa\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"Pa\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack Pa\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"\u03c3_max_as_variable\\\"},null,{\\\"value\\\":\\\"\\\",\\\"symbolicValue\\\":\\\"\\\",\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"numeric\\\":false,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"real\\\":false,\\\"finite\\\":false,\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"\\\"},[{\\\"plot\\\":true,\\\"data\\\":[{\\\"isScatter\\\":false,\\\"numericOutput\\\":true,\\\"numericInput\\\":true,\\\"limitsUnitsMatch\\\":true,\\\"input\\\":[0,0.01,0.02,0.03,0.04,0.05,0.060000000000000005,0.07,0.08,0.09,0.09999999999999999,0.10999999999999999,0.11999999999999998,0.12999999999999998,0.13999999999999999,0.15,0.16,0.17,0.18000000000000002,0.19000000000000003,0.20000000000000004,0.21000000000000005,0.22000000000000006,0.23000000000000007,0.24000000000000007,0.25000000000000006,0.26000000000000006,0.2700000000000001,0.2800000000000001,0.2900000000000001,0.3000000000000001,0.3100000000000001,0.3200000000000001,0.3300000000000001,0.34000000000000014,0.35000000000000014,0.36000000000000015,0.37000000000000016,0.38000000000000017,0.3900000000000002,0.4000000000000002,0.4100000000000002,0.4200000000000002,0.4300000000000002,0.4400000000000002,0.45000000000000023,0.46000000000000024,0.47000000000000025,0.48000000000000026,0.49000000000000027,0.5],\\\"output\\\":[0,-9.85174854073041e-8,-3.914251769202955e-7,-8.747559274755928e-7,-0.0000015445425900098147,-0.00000239681801745958,-0.000003427615062761507,-0.000004632966578852214,-0.00000600890541866832,-0.000007551464435146442,-0.000009256676481223202,-0.000011120574409835217,-0.000013139191073919105,-0.000015308559326411484,-0.000017624712020248977,-0.0000200836820083682,-0.000022681502143705772,-0.000025414205279198307,-0.000028277824267782427,-0.000031268391962394765,-0.00003438194121597191,-0.0000376145048814505,-0.00004096211581176715,-0.00004442080685985848,-0.00004798661087866111,-0.000051655560721111645,-0.00005542368924014673,-0.00005928702928870295,-0.00006324161371971696,-0.00006728347538612535,-0.00007140864714086476,-0.0000756131618368718,-0.00007989305232708306,-0.0000842443514644352,-0.00008866309210186483,-0.00009314530709230854,-0.00009768702928870298,-0.0001022842915439848,-0.00010693312671109054,-0.00011162956764295686,-0.00011636964719252037,-0.0001211493982127177,-0.00012596485355648542,-0.00013081204607676025,-0.0001356870086264787,-0.00014058577405857753,-0.0001455043752259932,-0.0001504388449816624,-0.00015538521617852174,-0.00016033952166950784,-0.0001652977943075572],\\\"inputReversed\\\":false,\\\"inputUnits\\\":\\\"m\\\",\\\"inputUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack \\\",\\\"inputCustomUnitsDefined\\\":false,\\\"inputCustomUnits\\\":\\\"m\\\",\\\"inputCustomUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack \\\",\\\"inputName\\\":\\\"x\\\",\\\"inputNameLatex\\\":\\\"x\\\",\\\"outputUnits\\\":\\\"m\\\",\\\"outputUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack \\\",\\\"outputCustomUnitsDefined\\\":false,\\\"outputCustomUnits\\\":\\\"m\\\",\\\"outputCustomUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack \\\",\\\"outputName\\\":\\\"y\\\",\\\"outputNameLatex\\\":\\\"y\\\",\\\"isParametric\\\":false}]}]],\\\"system_results\\\":[null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null],\\\"codeCellResults\\\":{},\\\"sub_results\\\":[],\\\"nextId\\\":24,\\\"sheetId\\\":\\\"{\\\\\\\"0\\\\\\\":228456294,\\\\\\\"1\\\\\\\":2090695981,\\\\\\\"2\\\\\\\":4291195441,\\\\\\\"3\\\\\\\":3693821582,\\\\\\\"4\\\\\\\":2989172876,\\\\\\\"5\\\\\\\":1841127001,\\\\\\\"6\\\\\\\":3157897485,\\\\\\\"7\\\\\\\":3586529369,\\\\\\\"8\\\\\\\":1008036957,\\\\\\\"9\\\\\\\":2372012744}\\\",\\\"insertedSheets\\\":[]}\",\"dataHash\":\"820990501bc66c5b366226e06136b99378c188075bbf4a5a0644a738736625425b0de40754c6ee31101491fbaa1a2c444a2efc2ad75df555b968273c11aad097\",\"creation\":\"2025-12-23T15:21:07.200Z\",\"creationIp\":\"127.0.0.1\",\"history\":[{\"url\":\"http://localhost:8788/EN4CzNzW9bMwdcd9zBATFj\",\"hash\":\"EN4CzNzW9bMwdcd9zBATFj\",\"creation\":\"2025-12-23T15:21:07.200Z\"},{\"url\":\"https://engineeringpaper.xyz/#2kftdqNYyiaqAEyhXboNZF\",\"hash\":\"2kftdqNYyiaqAEyhXboNZF\",\"creation\":\"2022-06-14T15:47:35.455971Z\"},{\"url\":\"https://engineeringpaper.xyz/#QsPdmAWHQNwz9rxPrT3PYk\",\"hash\":\"QsPdmAWHQNwz9rxPrT3PYk\",\"creation\":\"2022-06-08T20:04:54.562675Z\"},{\"url\":\"https://engineeringpaper.xyz/#d5DEM9teTxodvCTwENwErn\",\"hash\":\"d5DEM9teTxodvCTwENwErn\",\"creation\":\"2022-06-08T13:11:26.795400Z\"},{\"url\":\"https://engineeringpaper.xyz/#bPX72mmrNjVsgZbos25Gkw\",\"hash\":\"bPX72mmrNjVsgZbos25Gkw\",\"creation\":\"2022-06-08T12:52:40.806473Z\"},{\"url\":\"https://engineeringpaper.xyz/#WWDzaCSbmXrJp2PhyPEbTF\",\"hash\":\"WWDzaCSbmXrJp2PhyPEbTF\",\"creation\":\"2022-06-07T21:47:32.771678Z\"}]}" }, { "key": "DuGYz5Lu7tPdEJ27zAT8bg", "value": "{\"title\":\"Calculating the Johnson-Euler Buckling Load for Columns in Compression\",\"data\":\"{\\\"cells\\\":[{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":22,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Introduction\\\"},{\\\"attributes\\\":{\\\"header\\\":1},\\\"insert\\\":\\\"\\\\n\\\"},{\\\"insert\\\":\\\"Short columns loaded in compression fail due to yield stress and long columns loaded in compression fail due to buckling instability, commonly referred to as Euler buckling theory. A theoretical safe region can be defined by the area under the short column failure line and the Euler buckling line as shown in the figure below (adapted from a similar figure in Norton [1]). However, empirical data shows that there is a region near where theoretical lines meet where the columns will fail (see the red shaded area in the figure below). The Johnson line, combined with the Euler line, defines a safe region (shaded in green below) that avoids designs that fall within the empirical failure region. This sheet calculates the critical load for columns loaded in compression using the combined Johnson-Euler buckling failure criteria. \\\\n\\\"},{\\\"insert\\\":{\\\"image\\\":\\\"data:image/png;base64,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\\\"}},{\\\"insert\\\":\\\"\\\\nDefine the Length of the Column\\\"},{\\\"attributes\\\":{\\\"header\\\":1},\\\"insert\\\":\\\"\\\\n\\\"},{\\\"insert\\\":\\\"The length of the column is set by editing the following cell:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":23,\\\"latex\\\":\\\"l=3\\\\\\\\left[m\\\\\\\\right]\\\"},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":30,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Define the Column End Conditions\\\"},{\\\"attributes\\\":{\\\"header\\\":1},\\\"insert\\\":\\\"\\\\n\\\"},{\\\"insert\\\":\\\"The effective length of the column is required to calculate the slenderness ratio. The effective length depends on how the ends of the column are constrained. The figure below shows the end conditions that can be chosen from the table below.\\\\n\\\"},{\\\"insert\\\":{\\\"image\\\":\\\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAA8QAAAI3CAYAAABd3ZL0AAAACXBIWXMAAA7DAAAOwwHHb6hkAAAAGXRFWHRTb2Z0d2FyZQB3d3cuaW5rc2NhcGUub3Jnm+48GgAAIABJREFUeJzs3XdYk+f+BvA7QAKI7KEyRBFRwY2CigsBFVGPirgArdY6atG2x2211bau1nrUauuq67jqaN2zVeugTmrVilYQR9GKkz0C+f3hMb9iogZI8hByf66LP/LkHTdehjff932GRKFQKEBERERERERkZExEByAiIiIiIiISgQUxERERERERGSUWxERERERERGSUWBATERERERGRUWJBTEREREREREaJBTEREREREREZJRbEREREREREZJRYEBMREREREZFRYkFMRERERERERokFMRERERERERklFsRERERERERklFgQExERERERkVFiQUxERERERERGiQUxERERERERGSUWxERERERERGSUWBATERERERGRUWJBTEREREREREaJBTEREREREREZJRbEREREREREZJRYEBMREREREZFRYkFMRERERERERokFMRERERERERklFsRERERERERklFgQExERERERkVFiQUxERERERERGiQUxERERERERGSUWxERERERERGSUWBATERERERGRUWJBTEREREREREaJBTEREREREREZJRbEREREREREZJRYEBMREREREZFRYkFMRERERERERokFMRERERERERklFsRERERERERklMxEByAiqghOHD+OvLy8N27n4OAAB0dHODg4wNraWg/JiIiI6FWGvv027ty588btrK2tn1/DHRzg6uqKFi1aoHlAACQSiR5Ski5JFAqFQnQIIiJDVlRUhJmff46EhATs3rULhYWFGu1nbW2NNm3b4p133kG37t3fuP2DBw+QmZmpfF29enWYmfG+JhERUWnJ5XJcv3YN77//Pn7+6SeV92vVqgVXNzdcv3YNf//9d7H3fH19sXzFCgS2aPHac2zbtg179+5Vvh4/fjzq1KmjnV+AyowFMRGRFs2aORNTP/pIpf3LefPQtGlTXLlyBV8vWoRr164Vez8mNhbLV6yAVCp95bEHDBiAjRs3Kl8nJSXBy8tLe+GJiIiM1Olff0VQq1Yq7Tt27kRE165QKBT4buVKjHr3XcjlcuX7UqkUu3bvRmhY2CuPPXHi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DpU2Z2dnTqJDRGTkOIZYB346fBh//fWXSnuTJk0EpCEiIjJuCoUC27ZuVWlv0rSpgDRERFSe8AmxlhUWFuKrr75S+97Dhw/1nIaoYtq9ezcSExOVr4cNGwYbGxuBiYioPFu9alWxvxkv/PXXXygsLOTqD0RERowFsZasXbMGycnJ2LNnj9qZZwFg4oQJOH/+PHx8fPDW4MFwcXHRc0qiimHdunX4/vvvla+joqJYEBNRMadOnsTevXtx8eJF7FczuzQAXLl8Gc2bNUP79u0RGhqKLhERek5JRESisSDWEg8PD7i5uWk8TtjW1lbHiYiIiIyXu4cHevXqhV69emk0CV81V1c9pCIiovKGBbGWBHfoIDoCERER/U/16tVRvXp10TGIiKicY0FMRAbnww8/RFRUlPK1s7OzwDREREREZKhYEBORwQkMDERgYKDoGERERERk4LjsEhERERERERklFsRERERERERklFgQE5HBGTlyJNzc3JQ/f/31l+hIRERERGSAOIaYiAzO48ePkZqaqnwtl8sFpiEiIiIiQ8UnxERERERERGSU+ISYiAyOk5MT3N3dla/NzPinjIiIiIhKjt8iicjgLF68GIsXLxYdg4iIiIgMHLtMExERERERkVFiQUxERERERERGiV2micjg/Prrr7hz547ydUREBCpVqiQwEREREREZIhbERGRw5s+fj++//175OiUlBZ6engITEREREZEhYpdpIiIiIiIiMkosiImIiIiIiMgoscs0ERmcgQMHIjAwUPnawcFBYBoiIiIiMlQsiInI4ERERCAiIkJ0DCIiIiIycOwyTUREREREREaJBTEREREREREZJXaZJiKDM23aNBw+fFj5+ocffkCVKlUEJiIiIiIiQ8SCmIgMzrVr1xAfH698nZubKzANERERERkqdpkmIiIiIiIqhfz8fCgUCq0eMy8vT6vHo9djQUxEVA7cvXsXly5d0trx5HI5Dh48qLXjERERkXoDBgzAvXv3tHKsM2fO4JNPPtHKsUgzLIiJyOBs2rQJhYWFyh9PT0/RkcrMzc0Nffr0wZw5c1BUVFSmY6WkpKB9+/ZauzgTERGRejKZDDY2NmjatCnWr1+PwsLCUh3n8ePHmDx5MoKCghAYGKjllPQ6LIiJyOBIJBKYmJgofyoCiUSCnj17YuLEiWjcuDHWrl0LuVxeomOk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q6f1TERERERERLrAhpgqJScnIykpSW18ULX1wwCQlJSE9PR0tfGnu3TRSTYiIiIiIiJtY0NMlTRdHW7ZsiXatGmjNr7m55811hgzZozWcxEREREREekCG2KqFBUVpTam6erwjRs3sHLFCrXxwUFBeCE4WCfZiIiIiIiItI0NMQEAioqKcOjgQbXx6rdbys7OxqsjRqC4uFhl/KnOnREaFqbTjERERERERNrEhpgAAAcPHEBRUZHKmLm5ORo0aIA7d+7gzz//xC9r1+KZrl1x9swZleNeHTkSe/ftg4uLiz4jExERERERPREL0QHIMGiaLl1RUYFnunXTeLylpSUGDByISZMmof/zz+s6HhERERERkdaxISYAQNSePWpjUz75BM8//zwyMzORmZkJAHB1dUXz5s3xdJcuGu9NTEREREREZCzYEBOSLl5EcnKy2vhbb70FP39//QciIiIiIiLSA64hJkRquN2Sl5cXm2EiIiIiIqrT2BCTxvXDQUOGCEhCRERERESkP2yITVxOTg7i/vhDbbz67ZaIiIiIiIjqGjbEJm5vTAzKyspUxmxsbNC3Xz9BiYiIiIiIiPSDDbGJ0zRd+rm+fbmDNBERERER1XlsiE1YRUWFxtst9enTR0AaIiIiIiIi/WJDbMKOHztWeX/hqrp06SIgDRERERERkX7xPsR1hJWVFSoqKgAAlpaWNfqdH3/8UeO4s7Oz1nIREREREREZKjbEdURRUVGNjrt69SrSbt/Ghg0bsGP7do3HTJo0CdOmTUPLli3h4+tb4wabiIiIiIjImLAhNiFFRUVY98svAICGDRti+qefPvTYkydPIj4+HnO/+EJP6YiIiIiIiPSLDbEJsbW1xTfffis6BhERERERkUFgQ0xEZCIqKiqQm5tbo2NdXFygUCh0nIiIHkapVCInJ6dGxzo7O8PMjPukEtVVkiThwYMHNTrWyckJ5ubmOk5Ut7AhJiIyEZcvXcLMmTNx/NixGn2wurq6ws3NDS1btcKAAQPw1ttvc9M9Ij3566+/8MmUKYj74w/cu3fvsce7uLigfv36aNGyJfr374+3x4yBm5ubHpISka7duXMHE0NCEH/qFO7cufPY452dneHm5obmLVqgb9++GDN2LBo1aqSHpMZJIUmSJDoEERE9XseOHXH+/HkAgI2NTY0306suNzcXPQMCcOnSJZVx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XYcPH9b7mYGlpWWhI7/euHEDR48eVaU3atQIRkZGWuciHx8f5fvcM2fOqF4jBNTnp5MnT2Lt2rW4fPkyKleujN69e+ttT2ZmJlavXo2DBw8iOzsbrVu3xsiRI7Fr1y6Eh4cjKCgInp6eerclv6ysLGzdulVvfv369fWOuH316lUcP35cle7g4IB27drprLNz505s374d8fHxcHFxwZAhQ9C4cWOdZbOzs7F+/Xrs27cPycnJ8PLywsiRI+Hq6vrI7aLy49ixY3qnMTM3N1deNdQlNjZW53e+9evXh5WVldbUXF5eXsqAVfruDzp16qQ1EE9kZCTCwsIQHR0NOzs7dO/eHT179tQ5WFt2djbCwsKwf/9+ZGZmokWLFggMDMShQ4ewa9cujBo1qsgDXQJ58xvrU6dOnUKnX9LXp6+++ioOHz6sml8YyHtl8ZdfftH5qqanp6cypWN+zZo1Q0pKCqKiolR5L774IlxcXJS///rrL6xZswYxMTGwt7dHz549te5x8svKysJ3332HAwcOICsrC61atcLIkSOxb98+7N+/H0FBQc/Vt9ZUdBEREYiJidGZZ2RkVOiIywkJCTrHhPHw8ICDg4PWNTz/MXb58mWd0/y9/PLLWoNsRUVFYfXq1Th37hxsbGzQpUsX9OvXT+dYPLm5udiwYQN+/vlnpKamolmzZhg1ahROnz6NtWvXYtSoUWjatKn+jihgy5YtekdodnV11TtgJQCcOnUKFy9eVKV36NAB586d07ov6tixozKA5sGDBxEfH69Vx8rKSms0bhHBjh07sH37diQkJMDV1RVDhw7V++1zXFwcli9fjoiICNjY2MDf3x99+vTB7NmzYWVlhWHDhpXr+cjLZUBMREREREREVNrK/aBaRERERERERKWBATEREREREREZJAbEREREREREZJAYEBMREREREZFBYkBMREREREREBokBMRERERERERkkBsRERERERERkkBgQExERERERkUFiQExEREREREQGiQExERERERERGSQGxERERERERGSQGBATERERERGRQWJATERERERERAaJATEREREREREZJAbEREREREREZJAYEBMREREREZFBYkBMREREREREBokBMRERERERERkkBsRERERERERkkBgQExERERERkUFiQExEREREREQGiQExERERERERGSQGxERERERERGSQGBATERERERGRQWJATERERERERAaJATEREREREREZJAbEREREREREZJAYEBMREREREZFBYkBMREREREREBokBMRERERERERkkBsRERERERERkkBgQExERERERkUFiQExEREREREQGiQExERERERERGSQGxERERERERGSQ/g/ZuYpirCGsrwAAAABJRU5ErkJggg==\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]}},{\\\"type\\\":\\\"table\\\",\\\"id\\\":31,\\\"rowLabels\\\":[\\\"Pinned-Pinned\\\",\\\"Fixed-Free\\\",\\\"Fixed-Pinned\\\",\\\"Fixed-Fixed\\\"],\\\"nextRowLabelId\\\":5,\\\"parameterLatexs\\\":[\\\"l_{eff}\\\"],\\\"nextParameterId\\\":5,\\\"parameterUnitLatexs\\\":[\\\"\\\"],\\\"rhsLatexs\\\":[[\\\"l\\\"],[\\\"2\\\\\\\\cdot l\\\"],[\\\".707\\\\\\\\cdot l\\\"],[\\\".5\\\\\\\\cdot l\\\"]],\\\"selectedRow\\\":0,\\\"rowJsons\\\":[]},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":18,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Define the Cross-Section Properties\\\"},{\\\"attributes\\\":{\\\"header\\\":1},\\\"insert\\\":\\\"\\\\n\\\"},{\\\"insert\\\":\\\"\\\\nThe cross section properties of area moment of inertia and cross sectional area can be set by choosing the appropriate row from the table below. To change the section dimensions, edit the appropriate cells in the table. The minimum area moment of inertia is used for each section since the minimum will be limiting for buckling strength.\\\\n\\\\nSource for section equations and images: \\\"},{\\\"attributes\\\":{\\\"link\\\":\\\"https://en.wikipedia.org/wiki/List_of_second_moments_of_area\\\"},\\\"insert\\\":\\\"https://en.wikipedia.org/wiki/List_of_second_moments_of_area\\\"},{\\\"insert\\\":\\\"\\\\n\\\"}]}},{\\\"type\\\":\\\"table\\\",\\\"id\\\":16,\\\"rowLabels\\\":[\\\"Filled Circle\\\",\\\"Hollow Circle\\\",\\\"Ellipse\\\",\\\"Rectangle\\\",\\\"Hollow Rectangle\\\"],\\\"nextRowLabelId\\\":6,\\\"parameterLatexs\\\":[\\\"I_{min}\\\",\\\"A\\\",\\\"r\\\",\\\"r_{1}\\\",\\\"r_{2}\\\",\\\"a\\\",\\\"b\\\",\\\"h\\\",\\\"b_{1}\\\",\\\"h_{1}\\\"],\\\"nextParameterId\\\":6,\\\"parameterUnitLatexs\\\":[\\\"\\\",\\\"\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\",\\\"\\\\\\\\left[mm\\\\\\\\right]\\\"],\\\"rhsLatexs\\\":[[\\\"\\\\\\\\frac{\\\\\\\\pi}{4}\\\\\\\\cdot r^{4}\\\",\\\"\\\\\\\\pi\\\\\\\\cdot r^{2}\\\",\\\"25\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\"],[\\\"\\\\\\\\frac{\\\\\\\\pi}{4}\\\\\\\\cdot\\\\\\\\left(r_{2}^{4}-r_{1}^{4}\\\\\\\\right)\\\",\\\"\\\\\\\\pi\\\\\\\\cdot\\\\\\\\left(r_{2}^{2}-r_{1}^{2}\\\\\\\\right)\\\",\\\"\\\",\\\"15\\\",\\\"25\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\"],[\\\"\\\\\\\\mathrm{min}\\\\\\\\left(\\\\\\\\frac{\\\\\\\\pi}{4}\\\\\\\\cdot a\\\\\\\\cdot b^{3},\\\\\\\\ \\\\\\\\frac{\\\\\\\\pi}{4}\\\\\\\\cdot a^{3}\\\\\\\\cdot b\\\\\\\\right)\\\",\\\"\\\\\\\\pi\\\\\\\\cdot a\\\\\\\\cdot b\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"20\\\",\\\"10\\\",\\\"\\\",\\\"\\\",\\\"\\\"],[\\\"\\\\\\\\mathrm{min}\\\\\\\\left(\\\\\\\\frac{b\\\\\\\\cdot h^{3}}{12},\\\\\\\\ \\\\\\\\frac{b^{3}\\\\\\\\cdot h}{12}\\\\\\\\right)\\\",\\\"b\\\\\\\\cdot h\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"15\\\",\\\"25\\\",\\\"\\\",\\\"\\\"],[\\\"\\\\\\\\mathrm{min}\\\\\\\\left(\\\\\\\\frac{b\\\\\\\\cdot h^{3}-b_{1}\\\\\\\\cdot h_{1}^{3}}{12},\\\\\\\\frac{b^{3}\\\\\\\\cdot h-b_{1}^{3}\\\\\\\\cdot h_{1}}{12}\\\\\\\\right)\\\",\\\"b\\\\\\\\cdot h-b_{1}\\\\\\\\cdot h_{1}\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\",\\\"15\\\",\\\"25\\\",\\\"10\\\",\\\"20\\\"]],\\\"selectedRow\\\":0,\\\"rowJsons\\\":[{\\\"ops\\\":[{\\\"attributes\\\":{\\\"alt\\\":\\\"Moment of area of a circle.svg\\\",\\\"height\\\":\\\"230\\\",\\\"width\\\":\\\"230\\\"},\\\"insert\\\":{\\\"image\\\":\\\"https://upload.wikimedia.org/wikipedia/commons/thumb/a/a7/Moment_of_area_of_a_circle.svg/230px-Moment_of_area_of_a_circle.svg.png\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]},{\\\"ops\\\":[{\\\"attributes\\\":{\\\"alt\\\":\\\"Moment of area of an annulus.svg\\\",\\\"height\\\":\\\"230\\\",\\\"width\\\":\\\"230\\\"},\\\"insert\\\":{\\\"image\\\":\\\"https://upload.wikimedia.org/wikipedia/commons/thumb/6/6e/Moment_of_area_of_an_annulus.svg/230px-Moment_of_area_of_an_annulus.svg.png\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]},{\\\"ops\\\":[{\\\"attributes\\\":{\\\"alt\\\":\\\"Moment of area of an ellipse.svg\\\",\\\"height\\\":\\\"230\\\",\\\"width\\\":\\\"230\\\"},\\\"insert\\\":{\\\"image\\\":\\\"https://upload.wikimedia.org/wikipedia/commons/thumb/c/c0/Moment_of_area_of_an_ellipse.svg/230px-Moment_of_area_of_an_ellipse.svg.png\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]},{\\\"ops\\\":[{\\\"attributes\\\":{\\\"alt\\\":\\\"Moment of area of a rectangle through the centroid.svg\\\",\\\"height\\\":\\\"230\\\",\\\"width\\\":\\\"230\\\"},\\\"insert\\\":{\\\"image\\\":\\\"https://upload.wikimedia.org/wikipedia/commons/thumb/8/82/Moment_of_area_of_a_rectangle_through_the_centroid.svg/230px-Moment_of_area_of_a_rectangle_through_the_centroid.svg.png\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]},{\\\"ops\\\":[{\\\"attributes\\\":{\\\"alt\\\":\\\"Moment of area of a hollow rectangle.svg\\\",\\\"height\\\":\\\"230\\\",\\\"width\\\":\\\"230\\\"},\\\"insert\\\":{\\\"image\\\":\\\"https://upload.wikimedia.org/wikipedia/commons/thumb/a/a2/Moment_of_area_of_a_hollow_rectangle.svg/230px-Moment_of_area_of_a_hollow_rectangle.svg.png\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]}]},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":15,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Define the Material Properties\\\"},{\\\"attributes\\\":{\\\"header\\\":1},\\\"insert\\\":\\\"\\\\n\\\"},{\\\"insert\\\":\\\"For the combined Johnson-Euler buckling theory, the material's elastic modules and yield strength need to be defined. If the tensile and compressive yield strength differ, the compressive yield strength should be used. Choose the appropriate material from the table below. Rows may be added to the table to evaluate additional materials.\\\\n\\\\nMaterial Properties Source: Norton, R. L. \\\\\\\"\\\"},{\\\"attributes\\\":{\\\"link\\\":\\\"https://www.pearson.com/us/higher-education/program/Norton-Machine-Design-5th-Edition/PGM275676.html\\\"},\\\"insert\\\":\\\"Machine design. A integrated approach, 5th Editi.\\\"},{\\\"insert\\\":\\\"\\\\\\\" (2013).\\\\n\\\"}]}},{\\\"type\\\":\\\"table\\\",\\\"id\\\":19,\\\"rowLabels\\\":[\\\"6061 Aluminum Sheet Annealed\\\",\\\"7075 Aluminum Bar Annealed\\\",\\\"1010 Steel Hot Rolled\\\",\\\"4130 Steel Annealed @ 1450 deg. F\\\"],\\\"nextRowLabelId\\\":15,\\\"parameterLatexs\\\":[\\\"E\\\",\\\"S_{y}\\\"],\\\"nextParameterId\\\":15,\\\"parameterUnitLatexs\\\":[\\\"\\\\\\\\left[GPa\\\\\\\\right]\\\",\\\"\\\\\\\\left[MPa\\\\\\\\right]\\\"],\\\"rhsLatexs\\\":[[\\\"71.7\\\",\\\"55\\\"],[\\\"71.7\\\",\\\"103\\\"],[\\\"206.8\\\",\\\"179\\\"],[\\\"206.8\\\",\\\"359\\\"]],\\\"selectedRow\\\":0,\\\"rowJsons\\\":[]},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":11,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"The critical load in the Euler region is defined as a function of the column's slenderness ratio, Sr, using the following expression:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":4,\\\"latex\\\":\\\"P_{crEuler}=\\\\\\\\frac{\\\\\\\\pi^{2}\\\\\\\\cdot E\\\\\\\\cdot A}{S_{r}^{2}}\\\"},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":13,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"The critical load in the Johnson region is defined by:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":5,\\\"latex\\\":\\\"P_{crJohnson}=A\\\\\\\\cdot\\\\\\\\left(S_{y}-\\\\\\\\frac{1}{E}\\\\\\\\cdot\\\\\\\\left(\\\\\\\\frac{S_{y}\\\\\\\\cdot S_{r}}{2\\\\\\\\cdot\\\\\\\\pi}\\\\\\\\right)^{2}\\\\\\\\right)\\\"},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":37,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Since different equations define the two failure regions, a piecewise function needs to be created to represent the entire failure boundary. EngineeringPaper.xyz doesn't currently support piecewise functions, however, a step function can be approximated using the min and max functions that EngineeringPaper.xyz does support. A step function is approximated by the following expression:\\\\n\\\"}]}},{\\\"type\\\":\\\"piecewise\\\",\\\"id\\\":43,\\\"parameterLatex\\\":\\\"P_{cr}\\\",\\\"expressionLatexs\\\":[\\\"P_{crJohnson}\\\",\\\"P_{crEuler}\\\"],\\\"conditionLatexs\\\":[\\\"S_{r}<\\\\\\\\pi\\\\\\\\cdot\\\\\\\\sqrt{\\\\\\\\frac{2\\\\\\\\cdot E}{S_{y}}}\\\"]},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":40,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"The short column failure load can also be defined (used only for illustrative purposes in the plot below):\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":34,\\\"latex\\\":\\\"P_{crShortColumn}=S_{y}\\\\\\\\cdot A\\\"},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":33,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"The critical load versus slender ratio is plotted below. The Johnson, Euler, and short column critical load segments are also plotted over the composite critical load curve to show the transition from the Johnson region to the Euler region.\\\\n\\\"}]}},{\\\"type\\\":\\\"plot\\\",\\\"id\\\":9,\\\"latexs\\\":[\\\"P_{cr}\\\\\\\\left(1\\\\\\\\le S_{r}\\\\\\\\le400\\\\\\\\right)=\\\\\\\\left[kN\\\\\\\\right]\\\",\\\"P_{crJohnson}\\\\\\\\left(1\\\\\\\\le S_{r}\\\\\\\\le transition\\\\\\\\right)=\\\\\\\\left[kN\\\\\\\\right]\\\",\\\"P_{crEuler}\\\\\\\\left(110\\\\\\\\le S_{r}\\\\\\\\le400\\\\\\\\right)=\\\\\\\\left[kN\\\\\\\\right]\\\",\\\"P_{crShortColumn}\\\\\\\\left(1\\\\\\\\le S_{r}\\\\\\\\le130\\\\\\\\right)=\\\\\\\\left[kN\\\\\\\\right]\\\",\\\"\\\"]},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":32,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"To calculate the critical buckling load, the slenderness ratio needs to be calculated. The slenderness ratio is a function of the effective length of the beam and the radius of gyration, k. The radius of gyration depends on the column section properties and is calculated using the following expression:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":0,\\\"latex\\\":\\\"k=\\\\\\\\sqrt{\\\\\\\\frac{I_{min}}{A}}\\\"},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":41,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Finally, the predicted critical load is:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":21,\\\"latex\\\":\\\"P_{cr}\\\\\\\\left(S_{r}=\\\\\\\\frac{l_{eff}}{k}\\\\\\\\right)=\\\\\\\\left[kN\\\\\\\\right]\\\"},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":36,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"[1] Norton, R.L. \\\\\\\"\\\"},{\\\"attributes\\\":{\\\"link\\\":\\\"https://www.pearson.com/us/higher-education/program/Norton-Machine-Design-5th-Edition/PGM275676.html\\\"},\\\"insert\\\":\\\"Machine design, A integrated approach, 5th Editi.\\\"},{\\\"insert\\\":\\\"\\\\\\\" (2013).\\\\n\\\"}]}}],\\\"title\\\":\\\"Calculating the Johnson-Euler Buckling Load for Columns in Compression\\\",\\\"results\\\":[],\\\"nextId\\\":44,\\\"sheetId\\\":\\\"{\\\\\\\"0\\\\\\\":368695966,\\\\\\\"1\\\\\\\":950224055,\\\\\\\"2\\\\\\\":2080703910,\\\\\\\"3\\\\\\\":3403232427,\\\\\\\"4\\\\\\\":3952705192,\\\\\\\"5\\\\\\\":1051420742,\\\\\\\"6\\\\\\\":1459904282,\\\\\\\"7\\\\\\\":4161171343,\\\\\\\"8\\\\\\\":3486065579,\\\\\\\"9\\\\\\\":658742580}\\\",\\\"insertedSheets\\\":[{\\\"title\\\":\\\"Mechanical Properties of Selected Metals\\\",\\\"url\\\":\\\"https://engineeringpaper.xyz/PaFvsBhgoJdZEEwyBLPnD6\\\",\\\"insertion\\\":\\\"2022-06-29T02:22:21.378Z\\\"},{\\\"title\\\":\\\"Area Moment of Inertia for Selected Sections\\\",\\\"url\\\":\\\"https://engineeringpaper.xyz/bPX72mmrNjVsgZbos25Gkw\\\",\\\"insertion\\\":\\\"2022-06-29T02:11:43.527Z\\\"},{\\\"title\\\":\\\"Area Moment of Inertia for Selected Sections\\\",\\\"url\\\":\\\"https://engineeringpaper.xyz/bPX72mmrNjVsgZbos25Gkw\\\",\\\"insertion\\\":\\\"2022-06-29T02:08:49.591Z\\\"}]}\",\"dataHash\":\"45c7066a6346b4a9017350b8301f8681b68ae895bb7f6574c7e4e01bcf08c89fb5a7ee7a1e04db500bc35599a2cdfa6fc8049abc58cf95bc8e33a61f5875e2dd\",\"creation\":\"2022-09-15T14:20:11.081Z\",\"creationIp\":\"24.178.27.137\",\"history\":[{\"url\":\"https://engineeringpaper.xyz/#DuGYz5Lu7tPdEJ27zAT8bg\",\"hash\":\"DuGYz5Lu7tPdEJ27zAT8bg\",\"creation\":\"2022-09-15T14:20:11.081278Z\"},{\"url\":\"https://engineeringpaper.xyz/#LCGvytfMLTUir59MFeRKJh\",\"hash\":\"LCGvytfMLTUir59MFeRKJh\",\"creation\":\"2022-09-15T14:17:16.644679Z\"},{\"url\":\"https://engineeringpaper.xyz/#SRdiqShMDZVjDtXZ8f2pYm\",\"hash\":\"SRdiqShMDZVjDtXZ8f2pYm\",\"creation\":\"2022-06-30T02:51:23.156397Z\"},{\"url\":\"https://engineeringpaper.xyz/#Sitq8xQdu6rv53W3q7BXzV\",\"hash\":\"Sitq8xQdu6rv53W3q7BXzV\",\"creation\":\"2022-06-30T02:50:30.762273Z\"},{\"url\":\"https://engineeringpaper.xyz/#JFSZunaEuupWZpTXb55oji\",\"hash\":\"JFSZunaEuupWZpTXb55oji\",\"creation\":\"2022-06-30T02:41:19.367706Z\"},{\"url\":\"https://engineeringpaper.xyz/#mjV9C7vrKavDffgdFgvcoo\",\"hash\":\"mjV9C7vrKavDffgdFgvcoo\",\"creation\":\"2022-06-30T01:31:06.958067Z\"},{\"url\":\"https://engineeringpaper.xyz/#mkvs7eQiHRhfW5FnTRo2CT\",\"hash\":\"mkvs7eQiHRhfW5FnTRo2CT\",\"creation\":\"2022-06-29T20:43:16.476180Z\"},{\"url\":\"https://engineeringpaper.xyz/#k4KScmS4GmaMZD732p3Aro\",\"hash\":\"k4KScmS4GmaMZD732p3Aro\",\"creation\":\"2022-06-29T16:06:08.144663Z\"},{\"url\":\"https://engineeringpaper.xyz/#NVzyUCCsUoJZpLL9yg9jnM\",\"hash\":\"NVzyUCCsUoJZpLL9yg9jnM\",\"creation\":\"2022-06-29T03:21:34.733370Z\"},{\"url\":\"https://engineeringpaper.xyz/#PYcYmn7waFjH97h8rMmwWu\",\"hash\":\"PYcYmn7waFjH97h8rMmwWu\",\"creation\":\"2022-06-29T02:48:15.581059Z\"},{\"url\":\"https://engineeringpaper.xyz/#hfxk5YVJKaYhr6EXnzj6Zm\",\"hash\":\"hfxk5YVJKaYhr6EXnzj6Zm\",\"creation\":\"2022-06-29T02:42:37.193650Z\"},{\"url\":\"https://engineeringpaper.xyz/#8mDGXubYvM65VAUbtcQfRq\",\"hash\":\"8mDGXubYvM65VAUbtcQfRq\",\"creation\":\"2022-06-29T02:22:44.627856Z\"},{\"url\":\"https://engineeringpaper.xyz/#DhHNGwun2FciBktAw98dWK\",\"hash\":\"DhHNGwun2FciBktAw98dWK\",\"creation\":\"2022-06-28T21:01:11.088088Z\"}]}" }, { "key": "AqVAmzYYfKrQkGZ8BvUC7T", "value": "{\"title\":\"HW 6, Problems 12-50 and 12-51\",\"data\":\"{\\\"config\\\":{\\\"mathCellConfig\\\":{\\\"symbolicOutput\\\":false,\\\"formatOptions\\\":{\\\"notation\\\":\\\"auto\\\",\\\"precision\\\":15,\\\"lowerExp\\\":-3,\\\"upperExp\\\":5}},\\\"customBaseUnits\\\":{\\\"mass\\\":\\\"lbm\\\",\\\"length\\\":\\\"in\\\",\\\"time\\\":\\\"s\\\",\\\"current\\\":\\\"A\\\",\\\"temperature\\\":\\\"degR\\\",\\\"luminous_intensity\\\":\\\"cd\\\",\\\"amount_of_substance\\\":\\\"mol\\\",\\\"force\\\":\\\"lbf\\\",\\\"area\\\":\\\"in^2\\\",\\\"volume\\\":\\\"in^3\\\",\\\"energy\\\":\\\"BTU\\\",\\\"power\\\":\\\"hp\\\",\\\"pressure\\\":\\\"psi\\\",\\\"charge\\\":\\\"C\\\",\\\"capacitance\\\":\\\"F\\\",\\\"electric_potential\\\":\\\"V\\\",\\\"resistance\\\":\\\"ohm\\\",\\\"inductance\\\":\\\"H\\\",\\\"conductance\\\":\\\"S\\\",\\\"magnetic_flux\\\":\\\"Wb\\\",\\\"magnetic_flux_density\\\":\\\"T\\\",\\\"angle\\\":\\\"rad\\\",\\\"information\\\":\\\"b\\\"},\\\"simplifySymbolicExpressions\\\":true},\\\"cells\\\":[{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":1,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":{\\\"image\\\":\\\"data:image/png;base64,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\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":0,\\\"latex\\\":\\\"\\\\\\\\sigma_{b}=\\\\\\\\frac{W_{t}\\\\\\\\cdot p_{d}}{F\\\\\\\\cdot J}\\\\\\\\cdot\\\\\\\\frac{K_{a}\\\\\\\\cdot K_{m}}{K_{v}}\\\\\\\\cdot K_{S}\\\\\\\\cdot K_{B}\\\\\\\\cdot K_{I}=\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":3,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Given:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":2,\\\"latex\\\":\\\"K_{a}=1.0,\\\\\\\\:K_{m}=1.7,\\\\\\\\:F=2\\\\\\\\left\\\\\\\\lbrack in\\\\\\\\right\\\\\\\\rbrack,\\\\\\\\:W_{t}=2800\\\\\\\\left\\\\\\\\lbrack lbf\\\\\\\\right\\\\\\\\rbrack,\\\\\\\\:p_{d}=6\\\\\\\\left\\\\\\\\lbrack in^{-1}\\\\\\\\right\\\\\\\\rbrack,\\\\\\\\:K_{S}=1\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":5,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Assume HPSTC loading, get J value from Table 12-13:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":4,\\\"latex\\\":\\\"J=0.4\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":6,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Calculate pitch line velocity:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":7,\\\"latex\\\":\\\"v_{t}=1800\\\\\\\\left\\\\\\\\lbrack\\\\\\\\frac{cycles}{min}\\\\\\\\right\\\\\\\\rbrack\\\\\\\\cdot\\\\\\\\frac{\\\\\\\\pi\\\\\\\\cdot\\\\\\\\frac{21}{p_{d}}}{1\\\\\\\\left\\\\\\\\lbrack cycle\\\\\\\\right\\\\\\\\rbrack}=\\\\\\\\left\\\\\\\\lbrack\\\\\\\\frac{ft}{min}\\\\\\\\right\\\\\\\\rbrack\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":9,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Use Figure 12-22 to estimate K_v:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":8,\\\"latex\\\":\\\"K_{v}=.8\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":11,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Rim thickness factor is 1.0 for a solid disk gear and the idler factor is 1.0 for a pinion that is not an idler:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":12,\\\"latex\\\":\\\"K_{B}=1.0,\\\\\\\\:K_{I}=1.0\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":14,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Get the unmodified bending fatigue strength for the AISI 4140 Nitrided pinion material from Table 12-20 (range of values from 34-45 kpsi):\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":13,\\\"latex\\\":\\\"S_{fbPrime}=34000\\\\\\\\left\\\\\\\\lbrack psi\\\\\\\\right\\\\\\\\rbrack\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":16,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Since the number of cycles is unknown, solve for K_L assuming a factor of safety of 1:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":17,\\\"latex\\\":\\\"K_{L}=\\\\\\\\frac{\\\\\\\\sigma_{b}\\\\\\\\cdot K_{T}\\\\\\\\cdot K_{R}}{S_{fbPrime}}=\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":18,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Assume K_T=1 for unspecified temperature:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":15,\\\"latex\\\":\\\"K_{T}=1.0\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":20,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"K_R is 0.85 for 90% reliability from Table 12-19:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":19,\\\"latex\\\":\\\"K_{R}=0.85\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":22,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Finally, solve for the number of cycles N using the top curve from Figure 12-24:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":21,\\\"latex\\\":\\\"N=\\\\\\\\left(\\\\\\\\frac{K_{L}}{1.3558}\\\\\\\\right)^{\\\\\\\\frac{1}{-.0178}}=\\\",\\\"config\\\":null}],\\\"title\\\":\\\"HW 6, Problems 12-50 and 12-51\\\",\\\"results\\\":[],\\\"system_results\\\":[],\\\"nextId\\\":25,\\\"sheetId\\\":\\\"529e9c09-302a-4485-9179-15d278214374\\\",\\\"insertedSheets\\\":[]}\",\"dataHash\":\"20e526d514b4b650db9836f87bbe6858b243adb7ebe2693ad304f925921693b88212a98191e4894934ab944cc0e641fa3c324f606329bb46a8e233c6adaa54e2\",\"creation\":\"2024-04-25T15:38:34.549Z\",\"creationIp\":\"127.0.0.1\",\"history\":[{\"url\":\"http://localhost:8788/AqVAmzYYfKrQkGZ8BvUC7T\",\"hash\":\"AqVAmzYYfKrQkGZ8BvUC7T\",\"creation\":\"2024-04-25T15:38:34.549Z\"},{\"url\":\"HW 6, Problems 12-50 and 12-51\",\"hash\":\"file\",\"creation\":\"2024-04-23T15:07:54.085Z\"},{\"url\":\"HW 6, Problems 12-50 and 12-51\",\"hash\":\"file\",\"creation\":\"2024-04-23T14:53:47.942Z\"}]}" }, { "key": "7e84f956bd114cceb8cd0e", "value": "{\"title\":\"Test File Save/Open \u03b2\",\"data\":\"{\\\"cells\\\":[{\\\"type\\\":\\\"math\\\",\\\"id\\\":6,\\\"latex\\\":\\\"y\\\\\\\\left(x=10\\\\\\\\left[in\\\\\\\\right]\\\\\\\\right)+z+s+t=\\\\\\\\left[in\\\\\\\\right]\\\"},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":2,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Documentation text plus some symbols: \ud83d\udc4d\u03b1\\\\nAnd a picture:\\\\n\\\"},{\\\"insert\\\":{\\\"image\\\":\\\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAdIAAAE5CAYAAAAk46F3AAAgAElEQVR4XlydBYCV1fb291BDDMzQ3SCdEkpJiAEoKmCDgR1/W7GvgWJcFBsVxavXxkAQBFFRuru7uxligPme37PPi97veLkMZ8553/3uvfaKZz1r7bQd2zbnbty4MeTk5ISiGUVDscxiYd7cuWHLtq2hc5cuIU+ePOHY0WP6O39IL1ggHD6c7c8ezs4Ojz76WFi+dEVoeVbrsH//gXBg/76Qm5sbihXLCCtWLA81qlcPN/XvHzZsXB/WrFsdMjMyQ8lSpUKxopmhcpXK4fjx46FSpUqheFaWf86TJ284deqk7xnSQsibL6/GUzzs3LFL9z0UTpw4EebOmxd++eWXsGfPnlC4UKFw4mRuyJs3b8jR9xnXqdxTIU8a30/ztXJP5YY8efXv0y9dOOTqd7l+J01/5c2bFooUKRz2HzgQDh86rM+n+T39v8aVE5o0baTr5oZC6emhXr36oUHjhqFK5cp63gO+Z4kSJcPevXvCoEGDQuPGjcPrrw8Ja9etDb//9lvYuHFTqFy5Uli5alX48ssvfc8K5cuH7OwjIX/+ArpX3nDyxMlw6NChUFpzU65cOX/38OHDnkv9LxQqVDBkZGSEo0eP+v28mp+CevaTJ0/ouydCVvHiYcvmLaH35b1Cz4svCpP+mhzatmsTatSsGZYuWaLP5IZqVauF6TOmhfvuuz9kZmaFokUz9P1Tnjvmg3ulac7SNHe5msP4Yq6YSuaDzwWtDZ9J83MzpuPHj4Vjx45p/IdDv779QvfuF3iNT548GU7pvlyBcfLKmzef/0aOjuj5d+3eFSZPnRa2bt0amjZtGoYP/yQ0a9Y0PPXUU14L1jRfvnyWhzgXuZaBwoUKhIMHs8Nrr70WWrVqEapXr+bxNGnSxHKZjJdnya/v8719+w54rKzTjh07Qt269UOFChXCUY09efY8fv60kK513qvPf/HFF2Hb9p1+zhMnTnleihRODwULpvv5WrY8M9SpVzsc2HcwzJ41S2M6GLr3uCgUKlgwbN+2XfKbz2vGM6SnF/Qc5i+Q3/djzZFv7rdT45k6daruuS80b9ZM8lLZYzhy5EgoUbJ02Ldnb3jhhRfCxs2bQ5nSpUO7tm1Dx44d9ZkCoWTpcmHK5CnhlVdeDmXLlg0tWjQPJ3JOhF07t4Vrrr4iFM0sqj1wyntz7dq14cCBg2Hnrh3h94l/aS726TvlwwGN+8DBA9rnJ8Ldd90eOnToELZv3xaqVq0a5i+Yr/1aNFSqWDH8MnZcqFu/bsjKzPR8n9R1eRUpXDjs2Lkz7Nf4S5YqaZ3w0+ifNP5jYcCAhz3exYsXh3Hjf/V+6ty5k+ciW2t17NjxsHXL1pBRtIjndNfu3aFtmzbh9z8mhgm//qq9VUJjLB06d+qkda5umTwkXbB+3fqwbOkyy1rjRo3ChvXrvFfKlS/neVu7bp3n9vzzzgtnnFFbMvVs+Pqbr0PPSy8K9bX2CxYtDF06dw4tmp8ZVq5erfkbLJ21zLopPT1/yJc/XygsnZCj8e7cuSvk6lrsmX1793oMZ2rti2YUCbt27NXc7fNz8Kd8+bLSLafCxRddFLp0OTeM+O678OyzAyWnzTXmdaF48ZIhTXvowP6DmovDITOrdLik50Vaq6vD7j27da+dYcOGjWHGjFna5yGULFk8dL/w/FD3jLqe45IlSoWixUtYz7GuzPkerSf3LKx1QNa2btvmdakvXbVly+YwZco0z+0myc+O7dvDsRzt2aPHNV8nQ+kyZb1OeyQLZcqUCQcPZes+u6z/kNEjR7K95/IXKOA1P67vFtUcFS5UWHtqn2T+kORAe7JwEX0uRzMT9StzFPeV/sXC+N+n/O8CBdK9V9h/t912m/fXlKlTvJ5n1DlDY9wdJk+ZbJ2ck8M40fH5Qj7JDFdKiV3quilVldJT1hP6APOTF3uif7NP0nXPmrVqhlOah33792utjmoOjlp3oIsLFi4Q6tepF6am7nv7HbeFmtVr2C5NnTY1FMiXP2SVLBmGDfso/DxmnGxbVTSar5Gh/ZG2ZdP63A0bNtiI5tOHM2QE//j9d/0yI5x11lneZMeP5Vjps/FR5LzWrd8QBg58QUppZ6harWqcUE34CSlNDNwWbY4ihQuGW269NaxYviwskUIvXbqMjEVJTWAlGYd0C0avyy7zpkJZIvgIBLN99OgRK59S+s7q1Wv84CzkmLFjrbTi4ubXxGixmDBN0An98QtFpZ8xoF7YuJrxd/qZBY0TLiPr+wZd+1g4euSoBSZ//vy+H5PPYh86dFCbqogUQrvQpu3ZGlMpCzzfZ6OvXrM6vDDwxdC+XdswePDgsE6bfOKfE8N6zWurli1DIxnXyZMm2cDuk8DaSZBgIEBc46QMPsYIQYkGEgE+4iEzjqJFi4WGDRuETZs2he07tnstWKti2shHj0kI0guFFStXhia6z0svDQzPPvd8aNa0Wbjr7jvDZn1n48bNoWLFStqUJa1w3377vdC6dSsr+Thdqbn5hzCyFsnvooGNGwNDisPDGHllSNjTZTgmTPhdjtVD4eqrrvJc5Rw/IWUkQ6H/Tuhn5pl/8+Jnvr9aCmziX5NCAT3PHimRDXI6brjh+nDmmWfaSeFzrDHrwYvv8Ae5Yi4GD34tnHtul1BKMlVezglOWbbWkI2MTOXTHNvJkqzs2b3H19i6dYucvn0y2C2l1IqHYzKuHlPqeXnOgnqeNWvWhh9+/FHfl9GWk3NUigdlXzA9n52tYtofGH07YVJgW2U4V69cFarXrB5atmqta8jJ0315oYwtep67PN4fjIlNyu8KyGgmMuln1vPukjJbvXqVr7Vi+cow6KVBIb+ep4jmtmq1auHSSy7x+DOKZYU5s2eHxx9/LJSVE9agXl0rCk2b5vIGKd4SYa+cziNHDvp9HC720S/jJ0hm1oQGDepJTjd6v69bu9FjG/TS81IUNSQ3G70f98i4rVy10jLQTIYeQxqdUTlLEp0CGu8eGRgcs6JSKkuXLJNDcyhsluJm7z464JFwRt264c+Jf0pOJnjcnWQYuR7KmPHskbNQQINu2LBhmDR5chg58qdQRc42TmNW8axwRq0zQu3aNUNWVqYV30btLeRxjZyDXI2jcuWqoaYcR5yFRTLaNWvU0lwVCpu3bAkNGzQMF1xwvvfFN99+K8NaR7oqx07shRdcEM4/v6v02bowZMjbGvt0zWNNr9VRBRDoxeMaH4q/gBQy7yErd911Z2in/f7LL+Nl+NZ7z+PsIxuFNIdly5YJjZs0tXEZMeK71D4/Yec8X/48/gyOHgHBwQOHw7V9rwr9+l0rXZMd5s+fZ72aIeM0bfrUUFl798oretuwYVjq1GtgHXA0+2hYtnypdEFeyyBGlDnFISsq3bJXcr561epQq3atsGjhEs3rJOmukh4L40WHVKtezTrm8OHjfs7dGo+kNJw4JaOJcyAZZX4JPJAFDFSrVmdJJvaGcePGhEqVq/i+yIJlXN+Vqfsf3ZEELcgMn90vOcyUDPXr1y80atQwzJ07L4wdO0ZBU5YdyPXr11sushRgHdF+xqbky6NnS+2f3Nz/LxiyfooOfxJ8JDoNo8o6ly9XXuvRJGzbujmslK4sV66M5KtK2L2LfbY6vDb4lVBHRnz8uF/scNfVPlonWSokhwF5X7Z0ecgr+cSZGj16XBjz3fehjOxelgLPjZu2hrQ1q5bn4qEnhrSAvLFJUvpEjHUl/CgRlCIGJhF8NjqG9HkZUiLRChXKy0Ac1O9zNfFH7Qnky5tfQrwx3HzLLVIAeeVdjg9l5DGnazCV5HEThdSqWTtcdtklMXpJuRmJl4thQZDS9SBEx0kU9M7b74Sly5Zqkotb+eB9J3aA7yY2k2uyCWUuU16S1zYaVZYa4ZARZjws0N69u7Vg8mLSJJQZhawQmMD69eW9LlgY2sqr7t79QhuRbTu32+gRPc6bPz+8/NLLoYE+928ZURZwvqJmFMaChQtDN23U887rGuYoymdDbdq02R5TjjaFjYsEK3l+PFrGhSJHuUSDfszChZEgSsPA8swo6ZIlS8gI59gBiEosQ1FElTBj+ozQ/pz24cknn/SGnT1ztjdCvbr1ZHiPhkceeSQsXLhY0XXdsGvXTm9oXlH4oveYCOX//ltCqefHOCWGFG8Pz3HRwkXhwQcfCJdfcXn0XPUsBRVJ48qwtkmUyDMflQdM1D9j5owwbdoMKbYzwmoJbUU5LZdeeqmvHQ0MDkM+K2peOEqMsaBkdMGCBeELRfhXXH65lNwBGYRG2pxF48bXZ6JS0fxqrLy3XV4688mmQRm1bddBkWNhKY/jvrZlxY5CNGRcf8SIEZLV6lbcKBnkLecEnuyxUKtGde+PwopOy5WrEL7++msbns5dOmmvpEtBVbciYK5YK+aDF9ffrUgc53Xc+PHhjNq1Q61atYw67JbB2rdvv53SVatXen/cddddYfLkaeHFF18w8oCwE+nerfcrSybyFSgYlshwPP30UzZQFStVjJG8fJabb74plFXEcVARU/bhA56nnVIcjGnchN8kJ3O0z6uEVTKSOHCFZPznzl0gI31ReOihBxyxYjhOKXKZK/ll51SXEa8pZwG5TBxf5o1/SwRlDAs40sRg55UjO1/zyPrfcP31oXLV6uH770aEMWN+cdQLmoDSTCIp1gzjO17zkk9rgDFgznHUMKRnndVS48kW4pUlI5JtBwQj9t13I634up57bhg6dKh1E/u2vt4rpYj1z7/+suz3ljF6Tc7X60PeCWe1bm4dslcOQN9rr3HQsFnR29ChHyjiGK+5r6br5zcCl1dKHBkqKkdqnyLJzGKZ4Z5777R8/fXnn6FRw8YKEkpaF86ZMyfMmzffTivOVOuzWlkJf/Ptd3JCGstB2mkDhhrC0efZka8duzZqHP09T+s0Jxi3TRu3KJqcErLlyHdo3y507dJRSI70sfyzGjVq+xo4hjhl7Bn0Fc4ZeoK53LBpo/blQj8bMjZ12rTw1Zdfe++VEtLB2hYBVco5KudAcylHFqNFAJOtSPS4xkBEh7ywhvydKcORUaSojNEq36uQxh8jUXTI3w65HUNrkhjDICPoCmScNWndurUi9o4e97RpMx1ocW8CFO6Fo4Du5nvYnzTtGzvx0s8xOErp89NqnXdlSFPfSWwC3+d6xYqBzEgH1q/nKLJOnepyTE6Fr774Klxz7dVy9h5yRExAVqlKRTnGWzX/G/Rns9CBGXqAtFBGznq9enUkB1lCF78Kf4weG4rqvcrac2kL582WXj/lxS1UuFA4JM9rnuCcBg0aGDaJSvGElRoe0f4D+62cf1PU+u67Q0NRCRUbEGFgIlH0hPrAhzMUEl93/XXh8j6Xhw8++ECw0n4r+wx51cAPA6TQK8ujIeJDeaFw7FHoStyXCWext8s7I5rhO0MU1SH8RCAoDIwfhsVRpcaXWFUbUAl6YlARWoxJyo56Uh21SOCyFWVnS0CBHPh9UU16lsaPUUMxtJYHdu55XayU8faOSMCqCfZiHPfde5+UWYHw8UcfGf4C0hv6/tAwQhsHIcPzatu2jaLWNY5YEFw8Vx6SSBrhiBCEnkPPz5hRQPzM+Pgdxg8jgoFl7llsoNS8+fJYOLkWzwnkyHcZc4sWZ4YLL7wwNGjYKKxbs04R1hpDf1U03yjOZ559VvDddsN3CDfPHp2ZZDP8bUz/GZ16TKm5RIYzMzMMfWFMUe4dzjlH83nEc5fOePQ8bARejlA1wfz7yJHDYe78BY4eMAB16tSxskMGs6W8EiOK4fknWsH380kR4KgsW748dNT9du7cocitlR2OJArkc/kl04wXZxAIDMWGt8/8tGvX3mNBfpJo1AZVn+f9yYqKflRUVKdOXUfux3OiccdxwUMnHdFFRhPlxRptkUJ74cUXFQGWDBd26xaKKxLE0AHZRwWU6bExz3PnzgkDBdVaYWUfthLinkd0nyJFChoi3Lljoxyh58Mtt9waRo0aE4a88XooIUgPo8I6XXvNNTYURQSzzZNHD8xNZJ6piA0Yau3aVeGOO+6w8j6gCOCEHFzQpcMaz/ETx8PwTz4Li6Xg6wj2nKPv47WXLlXa679p0xYplyvD9dddLw8eJ5b3Noe5c+Y5gu14TkcZ5O3e64mzFx3YPHY4MKrMN79nf339zbf27AcOfF7PV9SQ+Zq1q41e8PtFixbJMNQwpP3DjyPD9GnT7RCAShQSjI8SbS9Htl3b9oqMlxqerqWIE8U7X47s3HkLFEHXEjqUGX788SfLWnHNw3HJ2S233uRx/Pe/X4RuSjuc27VreOftt8OHHw5VBFRGjkFlycfBULVKNStUoqXhwz+1XCJ3BbW/2HuWJzndOTixkoXKlSsaWasipUvEDtrGngMxwGAtX7bcxrBChSoylgUtTzkyODhUdsqI8OSgMO84DAfkPAH33nDjteHii3vK0V1geUPnbZdSP7T/UGip658nPbRn9z6hWUVCeTmeQLQ75Nhj1Ehj4CghZ8wrOtBOqe4HslZLTtuIb0eEwa8N0birau9XkiO91wZ99579jqZxqPj+iZM5ek5SZX/rSfYXSBpOKSmRgumFNdMYzBisRM2deqX0OPaOtAhygt5D/3fVGrDfcT7WSDexl0HnMF5OXZEC0qXypFIfGEXQTuaPuWe/MGanmVIWFf3Ji88mwVR0XElDYVcEgx84FHpe1C1UUyQ5c7rWaPkKoYhtwvPPPx+OCwEljVFCuqhm7RoyntM8hp07d4dfFQTmy1fAiA9OA44y9hE4evHi5bIBd4W0WTOm5mYUwfPL9SZE4eJZny3lz4b9OzooaKPGxgcP//fgf4effx6r0LyxlTouAgYUbxolykJiOMuWKS38/5rwuwzvesEnKHNyZigf4CgiPwQdAbQSRKHo3yiV2mfUUv7pgAzpLivh2fL2Pv3Pp4aYS2SVMF7PxNqA6qkR0mRCyZMSaZ7Q75hYww+4zMAAzDDvacGiUTqEyNmwZRYr5veATJsKHi0o4blABqlWzRrKl2230amknGcpKZ1Ro0aFxwY8Hj7+ZFjoqlzMVimbGTNn6s8sGwO80yPynBHOo3qmTClfBMoLCxRiSCK6Vol3jyFNjD3jAAngGYAg2dhEZ85XaJMRWeUvoFyODDYwD4aVyKZECUFnHTtp4csKWm4lwczvsWCwiun5yIUAjz8nAQJaQoFtEQRWRHIATJREqFEwY+4UgYzjjAIcjU4+ed5ZisDnK8JrF26+qb9yHHVsSHkxNuBIIlB+TqIzfrdNm3HKlKmKvFYr2q7sqB1PP4FagYeZK76TwDQJxEzu6IcffrCBa6N8GhsU+CqBnxIIOl3RWkRRYn6Ua2FISwuab9ashe4F5CpFkYpGGVeEqU6Fn376SVGpNlbJMt4Px5TeQFZL6Hl3y3EoqDzvVVdd6fzIIcl5VmYJwfl/hDfefNuQ0bWKcnBSDN/bPU6Tkh8Zzj67tcdx2+13CH6s4RwUSjSZ63379toxPevss8NFPXqEc+QojBr1c3hfzhnwFN8lD3y1cmoNtZkL6/pLFi8VOvS8nMtyWmOhFJKXJUsWhAfuv19O3Nkxr6e9iZzjVOCMffX1CEN95P+nTp3pMeBM44wVljODQr71lpvCddddJ8W9KyxbtswGAyeE1AYRZ37lEYHDkEuumaO9iBFl/g5JIRJ9bd26Tcp6V5jw2++K4OuFl18ZZNj65zFjQhs9I6kRHJaSklmiyLFK3ZCKyCqeKaf+kPPpaMfevXsbsVixYmnMV+se8A4Oyqhi0IgAlyuFtFzcjAL5CmoespwTBMqsLyi0RImsUEq6qJbmvLR00H8++TT859PPpM/Ik1WSYV8XWjRrHvpc0cfK8qeRo8NsReHIFsgFURwwoyOl1HoC7bY4s3n4adRPmuP9hgsxECjZqVOnS/8dsJyz70srt/3xx58YrmYP4rwXljE8oT2MHONA4mAe1t656urLFfVLNhSckKtlvkhNYFDJN7dvc7aNe3HpQMaydftWBxPkjtGhONzo7aOSefLbGFLyrpXknDQVNP/F51+FdxV5M150wQ7pV3Qo+iaP9mtEfpRGSaUmUEikX0BvvL7So2mK0q3DYsx5OhKMHAshO3asIscDfcHPPHfLli0cPGHY4dL8qjw4OVzQHXLEmyVXpKowlOzFBP1yMIGB1xyxz0HGbExTypIR8D5y8c+XAyiN13wZdJL+jc44eGCfA6MH7rtHuryMvndC6Y5xciay5SCfE8bLeC5apChZcweyVh8nX8ECOgn+BEad6xBYBs1V2uyZ02RIi9q4lRGuP03eFNBV2/ZtFd4ruiT3qA0CjIJgo+hQoM8/P9CfbShDSu4FpYWy4mdPrB6IPCieLHlQJuUvQSxADMARVWSM7tdGZ2Oy0Am+zyY86DxDwVC+YnnlQjY5GY43yPdHjhxpzwsPFwiJyTMcrIXCK0sMaRLNIRRM4ukcnw1BJCMxRow24yU/w/WAS4mEWeQ6Z9SzALSRU4FDMEu5KAw+eYWRUrRff/W1IQryV9zvt18nGK7r3auXopHKYcibb4kIMtmCjbgxh4ZEtaLAMWzYRInjdfMMGPOYlI8Gy7le/Y7ncHSt+yQ5QwQfVBaHIBo5EXnkQXO/Lp27GOoEkq5YqUqYOWOmoym+X65MeZEyyoffRIYaMuQNQ3iNGjXwZovXiQb+7wg1ko3++T4/ozyLZxWVHEyXUbkq3HTTTYrEiktOFGWx+QSN8crWehZQ9IUxzZFB4tl279npHCTQLjAf5IzEaPJ8KCzIHqw1z+41S72ISL///nv/q3nz5l67MoIwEW5eEUpWtC7Z4gVcioyRd18nwgfwd61adeSskR+NhpTxIkc4KkBjQJCbN291DpDvYiSQlVq1avjfxwQxXn55H5E1SpkMRFSOonjrrbfDXzJQ6fLWu57bKfTo0d3O6Z9/TjK56qEHH/R17n/gYSnwqs7DM09EX3j5ICFA7u3bt1deW1GEIE0M6VtvvWUnlGdiX5JfqiflQ1S7ffuOcPOtt4RyZcvJaNTznli8eF645567BZ+2ktI4IDt6wk7wEc0BynXML+PC9OnT5SReEP4reGvp8nlyTita8QHdMkaMy+OPPRL69O5lyJXnIOeOJ0+OsWPnjqGuInYc5tmz50nOKp12OJl38nbMN3t4t0heP2rvXnD+BeHBhx60cV4uROFXRSNNlbtqLtIPe2vkT6MMZ0KOk2qUcTnmnDBOw0Hdh1wqsgI8vmTpUjsqQKBA5UTy23dsi9ER8L7WMkbZwfJdUTqHSBnSUpnSZRVRTJLj847Wbo/mvKb2V65lg/2PLmEf/TVpiqHHUnKgCsrYEQAkuGLt2mfIWS1tR5K1ATFgnnC4ylcoZzksLSXN2KZNnyk5b+s5XLt2vUlJEYFKSzkfJyXDpZW3XhtqixTz4EP3CmpcKVncZyOG03xY+hcHplNHweLiXuD4goSwP8jVMTfsEyJHcowYH8bCfiJ3jJGuU6e2c8QjfxotiPtNjbucc7ZHj+ZYlpBhHC54BCgtAgBSCVwDw+58pfRNmiDWxMlOUkLEpgZ4U7hqNKTAqpmGbruIvNqiRTPp2NKG1X/9dZx1D0bR99T6EgxhzK1rzKUQuqnvl5CjtFJO0gFFlchVoiNRetGxj9wX0nV/Y2rA53GczJ9hdKEPZ2lPdO9xodc6n8mTwfIwe/YMf451W6V1whEkV8264AgRmJGK+UNwPsjkhRdc6D26Zs36CO2itPgySX2MIw9wpmAEIotogIDl8ktB6kHlxe/RRTCkJKwxpECc+RX6oshYQBQ80VFhGcM5s+c4b3auGGxAOtxry+aN8j7rKaf24N8GLgXh8dAoFKIpvImtW7aZmcskff3VVyYiEHGhLNjs0TuKkwWUYkOQAOiJt5KQi/QcVpqePHlO+i4eFsq0oIw+hqp2rdqC/drYA+eZW7Zo4aiDSIF7IMDbBSW++upgQ4qvv/6a4NOGYa0mHuVeIF966HtdX0FzO0Uwmhw++vhjE4zw4lHACHkUMCLoY4Z5ECS8+39CqPHnKBzeSClowxATkRqEH5MAFMXrWgk0jgPCn23bdip30yg8/PD92jj15Mmv1OLvMowuX8/KpFz5CspX/SxW4XMmMwGFbVUynjHau0ttiCQiZZy8mCfeA6bB4Rg1aqyIRg+H6/pdJ+NX0IbUzyTDycYg6gLSw2BAXMOBQKmPHTve+fguXTqb4ZgogcTpwZBiOIBfzdg7Dd+c9FwTzaBIicSABomCku9GCDgydsldMWbWcKMMAQaoiqJFohE+98+IFMcOxTdYiMshoQpVlddjXHwWOceLB0KFZNVSskB0C3TK78j7r1+3QbmpDY60C0oxpRcUEUfEjEnKc958041iTd8jZ3BUGPDo44aVUIKG0DTfOLJ45sDVOBU4dbCL31aU+1/tHYzJUec/84QrrrjSmxrlt1vRyh0ivxCVVZPRAdpdtmyxHJv+lmWiHwwpsNnRY0JI9J1RWvcZcq7ObtNW0fdoRTXbJPuCSxXtsY8yihZWJLlHa5kd/vX0Y04TkPufLCN3XDAxioccZ3nlh4EW//h9oqHGZmJfr9P8oU+AyVA4M4XS4KQiX3j63btdKDTq8bBQzNkR335vh5v1xzkeIQcGBIC1BdVBj5D7LCdDtU0RWZEMyB8ioUipk4NG9r8d8b1JMqwTEWDeNDlfgq9BHGByN23a2NHrQuXxr7zqCjOfyc126tRZ6YFlZotP/OPPcJ5IR5BPFi5abBZ5y1YtXQGwYMEiRbrLzPhGf7Ev9+3bpqi3opCNRq4qKK4IurbWA50IYzgSpfKKONfSxKNRo0eFbnJaMBxvv/OO9RZydBy4X3sfo4ojhx7YsWNP6NPnMo2vo8gvv1pv8NwYqY3rN4pU2MjwZHEZI3RAEeVu+Xn3rt2O/kkjWKal59AxyDjXQF8C28MEbiYH9C1qEUQAACAASURBVAfB4MM+Gm5jyn6tIsNSuFCGeB/zHG2y3+yMKGrdKgcBQplzjdKj/xP48W/vzb85FnyIAIbn2S/IuqLSXpdccrEdDpzShcrdblckDYkLtAeeDoQ3UJFjMur4zZ4POcnINKlDEAfymtga8fdPR7w8K8bezrsCOvZ8hKX/hnsjp0NOs9Qqc3Zpz26hW7cemqc0ybCY3tJHBHOHxSXAmQMdAFbHcab6ZKKMJ+mGSiJ+HVTkj+xxP9YwXRF02ro1K3Mhq/AipzV27C8eeD1tWgQ5RgLkBwoIZt0XTmpwS5VbgZ2K7S8ruAklgmFis/DAedIwbnlCESn0tevXhKaNmwmKukpe+Z/OQUxVKH/PPf+nie2ZiioJvSNZhugT+jWKHur+OnnF3Bv44/HHHpPHucOMPDwYoIZYRgCmjgEmaU6OESMjWFrCiTH+X4Ogf/9DCmI+4ITzFEQ2eGRAndnK4Z3V+ixvKLwpXk30Mws/Xp7UcAngo4894agEWIRc0isiHW3avEmR9n161r8cQaPcEG7nkzROBDNJ3icLjjHlPZS4o8DEgEF8gZhAZKr3EQ5+h5eVlIQk8LuZe2Ip4ikW0jpOnDhJ+cq2YZBIKg3qNzB7EmYsa7Z92w4TpSAOANPDmHv3vaH+HePNPiyYOBWBJkaf+yURo9l7+kNeFK99oyLZO+64PVzcs6eFESWXMG4jWYAoFBmCWAUsR85tg+C9sYomUAyNDWWR90ZB44XyeeBdngtPN4kamRp8jG/FvmT8lBIBeZaR40WkZnk1tEREL6KRFAkRGQZno8gXICaNRQ4hh4nD9k9vlu+wB8i7Pf2vZ70PSksJ4pUnBC/yXeTDgCKJHCHQsS9Y3+mKrpG36tUVTWkM0xTx4WDx81xFLQOff87lLX0uv8KbL6t4Mc8FpSHthACVFozcUCxGojPg2zJScDgIsONHjvxRhqul9tp+r9mVV17hcQDXE/U98cQT9o6LZhQTTFgwrJLiByWAkRrJaCci5V+GlLkAtkaREsWSq96k6Jv8Jw4Oe430Q+kyJVXCNUnR8dligw8SHFcxjFJUuUb513Iqm6H8h/kmMoKos0OlQuwdZIPxx0hAeT4x+HeK1FZHpLKZIr7NUY74asHiF1zQzcoU5i3RKLIA0x1HDKZxjvJ0XB9YF0PKemVKka9atVr7bbtTP2vWiFkpGWTvfClHG3IQeWqzWLXXgIaB2HfJyADTghbx71ViRLO36jeobwP0hcgjP/zwvfRbnlBBUSbKnigEcgqvvUI1IBHtUPQP6sN+JHohei2hAATGKfsTkg7KPl++NM2BjL3eb63ywL3aezCSKY/7TTA399uvtSxTrpSvH2VPkKaEe+XKFaGjjGifPr21jydKhtbGyFEpmoMKZoismjdv6v1Xt24dc1iA5Ikip02dIbmt4r2EXjNsLOQIvUs+EjY1URZRKQ7K50LVhg0bbn5HliJqnJWESMg68nzsaZwD9iBQc2ThxvSO9YM+F9+J0SBGmHQUTvbu3chEda3hZZ5PDBDrRw6Y14QJv1vnolt4LiA2V1/ouiCfpBn2C76nbKcw+k3/EahFUlFEn+Bs8NmEqc/7oBm8Ev0Yc9IirhkBxbk/Ejp2aCdyVz8bUhAW0hmzJJ8HD6liQNdcKsSjdUtIUZ3sEBJgoHsZL9cgtRjvKyOOISVhjZLDcx3988/Oy5SX5bVHqC/G8Fk5Ty0UBnKCGH/vv/+BPNDyFii8HhQkm4dJzptHHoEWMUOTsE6sukain8PGnKjatf37FRWIHXbP/92terIuNog8NgbNeVJN0jEJRjlBH0RhQEkYSpQFJIEjGiubHxjA5RApeMSbFvaYxgpcxu8wUCjdCEnG+kgWgolHqXAvjBsJdTzNGlKAjIVcb+8+feQANHGUsUMlJ9VVDsBCPPPMc2aodux0jqK9Afaw2OCff/aZPPd/CYIooU1cxJ/FOONZo/i2yeMnx8KGTyIrBJTNzPdPpYwHA0YwHZGmfgYSToxXhFNiHtUCY0FWTloCXloQBN/FmdksSL2bPP//+787QxXBzMtXrDC5CEHG40cBk8PBYSGSeEde8qBBr0qR19OYILxglCJDN4FwLAvePAhpmgkP5MRL6Rnvuvuu0FxlKxH2VCmPnYZYA5qMnfcSMhBsR+qB2VwYQ5hv5FepT3MULs8Sg+B1E9klcRyITFnXb8SSxXBA+sJjRllw7YSYZMMvmWXDANEQ7ayXLCIXEQ5ONxQYo+y4KfFOge/GKVfy/vvDHM2gzNm4Zq7reahJxJkisr5Q9X04f+wLlOeSpUvEfNxoD5Z5XSPnZdHiRSLbjHAuDadmpnLTt1/fP7QUzAe6g1LBWashFjCwGwYKhYoCq6hcEnP+yiuvhFn6HnVwuxUlUrd8uYwx0TDrCenqCfENyD0h+zgJWzZvUE1xD0PLrEcsHQINOO6Nv3KlmKTffC+inFjRkq/Zs+eawU3ODOcIBczfyOviJUtdxzngkYed7/to2FBfo9ell4X1YjaWkvOFEtq2dYfREAh1cA1YbyK/DYqikugAYg+o1RYZbhj754vVfkTIF7WtpEWIFiHm8Xt0UoP6DRXVNbMu4MV+Jc+L8iO6+/nnMconqxxD9//ss881vmJeU1CKs83E3eKIkf10QEZo7559nucWQpqAbxnz+Rd09Zx98OEHmpMRcgSPSbbKG8nYJyUOAlZN0RrGOJIWT3kPxbTDKY+ZaI7az6ZNGuu5LjWXYsqUSf58gfwFhRAsVZpFivuG6/z9d999N3z62Zcy6jJgEBslgGdKRmDnU2+6XU4JcDSOFGVDIHQZKsVhLXHW2yjX3lj17ESioCXsGYwpSNoR6W32Hk6ec3oKdMg787w8F/efMmW65q11aNW6jVC1N8w5oKY4cjHkxBo+zTWKwXolssAaoOuTVEtEriJClRhWR9Ay8ugQHJlLel7m0iR0L+s/WymyOKYNhpvZm8iZy+pslON+557wb0D3zN6npitlqLHlSYB0ms1L5C0bkIwVMqqvFy2r5yiSF5Xvlq0CDm+ntF3Lls1DB5EPKWP8/fc/jHItUQkXjwTHoLOQC9Z3k2B1eiKgD4j6QdjQOWYVr129IpcfgNHWKvoDaqNGrZCUJIbVLFLBK6dy8oQDstRsus8FM3326acmeByWB8s4KfqH6WUvgEYBysdRsLx2LbVqjUzrpn6HCV8j2AuoCA/NZR6CQwm38cYQALySLJEDDsgLpFD4lKjHCxfOF3X7K1+/qDYpxIfkhRBiQDDeQCZJAwaUR4yoIhuTCSTCIQ8W62OFmwuKRPlgrM9uc5aMYIaL0c/peI6hQXIx5H6IglE+t956m9mYg15+SVBbYysoNtVvyvXgtYyRI7JY0BC1o+R38GCqazMcl2JiIUwLT0XEzCXCRWT9T0H85zMweJR+hHH/2SghQq+GMv1+zAwU0wInDNX+/a93/tFNHlBOihrwVKFzI2xsWjw0IjrG8OzzLzlvChRGXpFrJnBu3CeRWMCL9xGmpTIe7UU0AqbHIEP+YFzJRnNON9kA3pjZhpenqAHB3Dkx59xAeT1gMXIRKKcIdafLkEYWNfLA9XJE04d5iyc/5I03VGrSOdTWBs2UUxDh54g+GNY1uUyNGCQ/OF0wxfGqURAYSGSCqCvKSiqnZiTjpBtnLFB5EE7QHsHB6ZIXlAebplGj+k554Iz1FLsSp4s5IepeJfiQHBnwFyQcYKoVii4m/zU5dFVkSL6S8oyvvvpGecpibj7QWBEoUQqODbAucojjRVSVpeJ7oEbqHynzaNGipZUPdcXXiLWLE0cODMTkgQfud1RfulRZcxVoyHCJ9jEw6t/7ACQBh6CAFO4SOc1jrMSINHfv2WW0B+gbqJiIzrXN5Ks1JghJd951q8piHgprxD4fO26cYNxGbkyCsgaao5g/KZOgfpWxEQkBkcEWRsmTQgGB+FklMBDcbhGhqeWZLTS3ubr3hvCekBHmLUcGHxgNQldCPkRWWVdeyC9Oy3KhY1UUgUG2+3j4cN+/nIwOcgcf46ByasgEihznYN78ucq1rbJx6C/oO6nfpXEDRC0iJRjN0wV7l1FEflIaO0nJEHHSwIDrUw5k7ojJgDRiUAmgDC+EHiK9Q4cPhlWaJ2SR6IwSEwIWxoSRAWViHSYp/QPTn3w9DVmuFtHogOpKR/882rnSnkJ5ntP6l9MebdKkkdcDmS4gJ+NKEaNAcMjPm9Sk/YhzzNzgFOHkIY9A9IyTseD8sqcoscHYN27UxDW43wpSn/DbH6mSLVCGojaiOI3ID99PiD/MJ45UjExT8Cm6wSm0hOGcTzWs68JFF18oFvLFdqhAS3AI4R5gFMkVIzvIewx2VPOtOT6ZG1nHOGPsEaOc3tugdTal0TimdFI04cDLGqecFuZnj+S5moKfBP1LUj4mHulzRKikHmF3I2f9rrsqZCkX+4vqSJeqDKaRmnycI92ZlCZSinbwkKJ6oSfMNaQy5gTnxJoRQ4pAwCydpxwID4yRyy/4AuE3FVkPeVxdT8hBURoyZMgQ4cg/yitqI490owU0KTWJChS27wkXrWNIYeM98fgT/hyKDAiHSARFxWIUKVzUeLpJIvo+Xgus2LxKguOBkwOlZOMtkXfwVoC0gEut0DU2vmeqNwXLjlBPo6P+GUHGgKIQEkOAV4tipDYsS15sVlZJe1BEEmeLjYU3A3MYI4SS26F86Pcqwv36i2/Ciy+9IMjsPI2xrOvLflC+DmPWvVv38OFHw8In2tCw0lhEJppSCTYgORYEGwkAJkkMTPTqUlFoKmKOXl9SYPy/+cokb51EUsx3yiGMUT1MZgkkHn+XczurK0od3xcHoXr1moKcJypnukLj7WbvPr/mprrKB5YrOnp0wGOGwEjE45FzL+Y3RnpxXg3bagNwL2CqewXT33PvPRb+2PklGlqEHTYi0Dzzg/JicwLBUrM1e/YsQTZbBZHWU/RwtiNMGgLwXZyHwkXS4w5JGdIjRw7ZK98hxfOSorRLLrnUzRsS48mYThtSwWDMPRAhjhYbAsIFsB7KDAa696LlFR0QKfo0vMBRJFdowoaMUpFU8TzyUrVqZXug5Jm6de8WnU07a8rZS14wKLAPiWJQBMi7lbvy0aslwzf2v033gdxxLNyohgnkunhR1gIJqFZN5Skh0OleNFugHO3+Bx5w5Mq+ZBMz71deeaVlE9QDNjs5R4xFKRlg1xtnH1A02kOdfc79HyeNUpYiUqY4s5SKULoFmQOHD4brH4p+Fqschc8wP0DaOA0o58Xy0m+7/ZZwc/+b9CyrwgdiEvdU3quqWMqkdXYr2ksUD2NE0cB6Zx/AKN0saN0Qnn43XeQbWPzLVCbCPFwlFjLy85OgY5omUC/YSd2bLlanLmBhIHlkIyHaoYsw9CARyBJGmnpNHJssdUMzIuZniOmK6tVq2BABz+Hw4DDwHYwPTjLriWMJTE1E/JEYttNUj125UnnJcOy6hB7heXAQ9hmFgOwX848oaGpy4SKQsmqhKBoi0Pff/yDEpUJooahnl0op6PiGzjhLDVEuUDQOm/lzleagDxkzTn5LMe1JIfBCXqlBp24zIULi+FOv31GoBozlVStXW7eCJlBZUF0pCfYqUTn10ES37FkQKWSRKJfPw/GgJKSdHGFSdHffc4/TABWFNOYXIoQTlDTgYSwJooRuwtnBaCYvByw43tqrhw/vd06UVBjkN2QJJGDlqhVa8w12btB5GEi+h2PIuODCMG6iP+B6crXInxmV3qwETPwYGbjIslxs/zph7JOHZ71xzEk54UTbSKcGCgpJAEUVCIESNemgDUT/Hc/pELZILhYIceyuvY2DSzqSWtLKVSpFPoMi3q1KK5yl+mDWHUSVPX46ImUjE3LzontJUtjOvxF+2oeRg8Qjeu6551xDQw5xo2AGIDJekR0boVQUQdGihWwAO3c6VznRO411WyErDxEbCqhdlj5LPVICAXIvlBdGlnzsfnkXGHNyt7TbKqa8aREpUwgeJgoxwdxbfxNyx8hWbK9Ue0AGlHTd4B4YeCaD+yet99icePfUMTURNNOr16XOFRzVM1PKwCIPfe99Mfj+ktG4R5PY2puGtokolJ8VheL9IzzjBFd+8sknhiMytaERWAyioz/BHHweKBcCUcIvSwq0E7YpigthtRNA1JQyqDZQKag1UuPzR6g4RQwgumKuqG0EhiIX8tzzT4errrwqrJEihgFYsWLlMFp0fYS077XXenOgJFAwRN5A9i+9PNhEEsbAmBAYxpK0+APiBP5wVxpFYuSEzzv/fEejzC2GMImwMaRcn/u4G5TWiQ0K2WCGcojAI6x5ddW1Xa7mChgKrZgMTDV7nEAzdA/CETp6hBouPPK94THlBPv2vdYdcugGk+RwbXdxRsitamNCZyefgSOEB06XGyBwDJlmMzXOaAiZA8onhqkmuEyZ2GqOFABzznPSVQcIljQDOaWLpORhrOZKodpz11hRxDsVDeJJE60B1ebXMzIf7733Xhj24cdhl5TKU08+5nwpLE6gZmQZQ1pODhgODE5AGX2XdRz879ccTYPskL/JUK7oUsGqSZ57sloEPib+gAlkkmOg70MH9sqRuswt8iITMaIzzBNtQIG7X3nlVXf0ueyyXoasjiiqg/BBG04cL/JyMbd6LNUC7oTYvSvCw0If+va7RrV4M2QovpMT1Nr7BqQhlvLE0gUrR8g0ktEiMF4hD2p9Uaq8j5Pwu3KAlKn0v6G/iUCMkdaao0aPNpGJhgZA5dHJia3wmEvWBoNWU44h3X8+/ugT6wEMK+xs1AJ7Gn2BUZ45a6Zz1zhRyASySIkb89Gje3fndlkLatZhEeNgUftJHh8HonKlCgo21HwgxeB217TTuiXKDmPDyD3y8MOqPW/pNnc/qUSuVioa5pnRUavWrHLJSc+eF8tpP1s5yo/lkI7RekJsi00tLtP6kmNkvkDyyBvzvIyXvQATdsuWTearYJguvLCrypVusSNHyRG5RQhQvFatWmOGdBm1WiSNwrywxshYukp7qB+l3AqZeH7gIBs+kAqMaJIuSead9YmOdUyJ8IrvxZ/ZqxjLnpf0cAObuNb0H9inFquFJD9yoGfN9fgTTgiditBxx6TrMHKNJUs4JmNERiwpHkHMvpKWS+VgT5OIxMxGV6Yc2QwZNByzm266Rbnt+iK3fm5Dl+R8EQpsmMtnpCdxoUnnoM8wpn16XyqeQgnX/xOREvAx/xhKAkz0EfK1TRwT0gOMn+u7KoMcaQLtwuJDIIBc8fiYJ/csBPKSY8AgiPieeeYZezp4HLuUTGZSaaGWIy8phkYxwsosVkQ5ornqwdo/9L/xBnuVsRYolhKglFy+IliHBD45rbx6KHBucjH8DTGGkH+qDPewYR96o5M/AiLESMXyEBLQEdqNOVC62VDPFlvaJa/EkEbvMkYkDcVsxRskn1WmfCkzywj1gUHppUhZxVQxFV8WlDtAvYVR3Hh2RFEUoNOXGAYptWNAM1PVO5Yi7vkicODZQr9HaeMBASMgbhiCBHJ2yYVhk9g8Ai/XmL+e4TTxKBUKno68nE9Q8buUewJpIwzAnkB35BnZTJQxPP7EY2Ye47Uz5yjH79Sx58eRP2hd+tpzS2j4OC/kbJ97AYj3JwlTa8+zu9hoTETR3JdokTo9SDkYpieffMJ9fYFUzPRz55Y470D1iVLlWkBOyA6CCfmpWdMmYjdPcb7iXkW1KDgg8Wpiy6ZpU7LZmRu8z9zcyAQmZ/3scwMNC57T4Rw7aLwSaPd0G0NFlRh3EA6YuMwzTFvkI9YXxzKolDbwJpk7b65KTd4RLFTN0NvefbRMizWE5CMh5JC/Y247yIMFRgcVwZDiICCb0VHLsbPlwngt+kx1cbr7rvvk+ZcR0eYKfb+W5YhNiHJn3/FdxgOLkecmSqDU5G1188KgUm5BFIEjcEnPS2zYkd1xglmfefYZkXnqmCmLp71g4VztuRtVi9rdDhAGMeaqYxTB+AariQPEv1tUOkMEBNGPdcYppQQFhch829vX/kLB4tgtXDwnvPjCKypDudjlXX+pfrZKlWpyFss5eigshCmBTLkXz8gLxAenjNpJ5pOocPmyFW4VunDBYjdPoPfqYRmNd959x1EY96cmGla5nTrpD6Jp1poCeZ4XIztSNbpEbtQgshYlFGEizzEnJgMurgMGh57CXAdHCGXOngLWrqNetqztEuWDITxdIMeQnD1IwEQRBynxOiRor3AR5WD1jOhF8uJpIlayh8lXw+69Vd2kblNbVMpwqJ3nRXnh0ePZdhIxdJBVyO8ypu5CDSiV2yaUhdploHvSMzhEoHJEmJT9EI2iExO+B5Er+9Fs6BR55nbdF1liXndqj+CQ8azsX5wGXjw3++D7H350Wgfm8n41e6hVu6YcuzPDSDnZL7/yb0fqfJfrJygA30/yksn+5j2IWegf9sGJk8fdRrWe5m6X9jcGB4SMOlvKGanc2Lplp1GVpN6V7yOXhTRPoH+bFZyBnuUz8//vRjE42Ck8N5KNQCGRJ+lN1hod16tXbzl1TV3dQQ/ryJVR4x6zeKMTAKzrJhv6fuzFDYKaExrK+LZXzpTos5FsIA2JGCNpMUofyaOji5boPhUU7eN84WwwP24RaIUnSjHF0IT94L/AQ8lmiDAdDbjl3UuQBw16UYphlnsX7hN5CGIIXg2LleglJrVEyUzBRHMVOdxgpc0Cx+YBNDk/ZGMUe8zG3IeJSvK23O1D3hgMuF2q8aI901LldN4W2YiIpGTJUm53RsSEgkBREQEnDeuT3rURhoz5Mj+jFAp53KhQomLB86CmCTbcuV27GGoj1wlT052AFCn163e94I5K4cmnnnA0gmdYTV5yIUXSNBu/Qp2bIAOwmCgKPFqEeItKd5gPlAYeFV4iCpPJTzB7FCabAg+Y9/i3833AESklYI/P+V67KFb4zCObEsPrpswiGiQGGdo9BeH3qOPGww8/5DZ9wFnkJajH+vQ//3GLK2pNe6phNrkqNi+bjCLv3/74TbWxL/t5iHohOLjbEpGrBBvGKbDZDDHc+l5zdbj3vns9v0QYMVcZYV0UGBEp75mEJG9zliIDWKrck7U5U3VlwwWjUWw/SN1+qC/NVsSAU1JUxhUBN9OXNdYm5Vlhdf/3v5+rBd5tzj/jULGW0WglMLQgpoNHHMGRNyLaADEg+jMUJ1lzrS6sbv2HseT7sIEh09ERCgW5S4aLZyGfCoJCA3UUcrNmTexIQjRicO4mI7mNuSMR5+Tw8fys025Bevfed1+YIU98wMMP2OlCjlBW5EWBInG0YlpEyigVddHgfNy48U6lkHqpX7+x4NENzoV2EyzPeoN0fPPNNyrhGG6ZLEjhvIwkESkpimuUY4T/gDKLpAuRA6VYcBDI1S5estg9g0GhyO1uUM0nLTxJybz77nv2zsnnRiRHcKmeC6OOoqO2lTrlSX9OUt59uht5l9DehHwEzM08R6cl1rBiQA2By2DjVNEdCccJRVSpYhXlp8bZQeghWO2/iiZALeg4RNR8jeSMyI73WM9SciDYhyhKyIdAgbB2gWuBOPeraB60g1wtfAgccvYf0XgCCePwuSuQ5JIaeSIb9sDq1cqDyYAB71WXPsCh2ibDhAM4b95CyyKRjBET5Ue55n7l0jO1d2Bml9IcwEPAuNDEH2d3zhyRuYRSsI+A7xcvXmKSGGmOVmpSABoT61YnqeXhD97bKHl6yFSoINKQuQN5nFoD4k5SEtTv05WNqJVyKDrJ8QwwTik7w4mnJV4+PcMh2Khmsh91zTjfq1SpqjgRTSSTDeWUKEDRd3DMXhMBCYfcTFfprFgmGPUPAWE0pJF/Eol92m+6Xku1XmzftoPJYwRKGEagZ/L25Bfnah5wRgyL6xIxCMOByyMGdSOv7SKVRZnkqIdHNkwa9d1jA4hUHOz3cAhBgUhH8TnIoBw88JBqlUlPUVEBsShp9MJVMKpxz6Nz8+r5VCOrXtQYbiB3bEFFwfF9+15jZBZyF2uTpLhWKehC9iiNgWBrQ7pq5bJcFABwB628unY91xg13nUSxiNwp05GUgze4zPP/MseVB168cqgsckpKKfYO77EIINII2+NiICoCAtPLgfWY/aho4YFMdgYjgxNLCQLHpgHhExENwmgBsJ+6jg//PBDec9TbbD2KNcIo5gJdU6GP6lOQcA4EBVcckFkB8PVdaN052BRoqGiRR05uRaKUFYqr9FevSxh4tL5BiZZdQkByp2SibvuuNskoz6qhwV2ImLPVP4KLx22GxAQxAc8IJQtueXyWggiN6JwhAaqdGxSISak5obnjg2Vo5GHoMUcOCdlWJL8S8wNYMz+2bUJhY+C5hoWQkVrLKY3Gp1M6Lep9XjgwfuUS7s8bFi7wU0waMJQUFDOiy8+rxaPf4Q6inCuF4sQajlt1zp0oG1eHufzXhDDdIxgLTxcNmSSA8eIF9F6ke/ldZ+iyPPlvVMMzmZJDGk8xUelOClDynrD1CMKoxRnmtpH8gxFBP+P/fkX1x8CdwJ9M/56qp/MFDTFRkGuEGIUAZuasc6bOz9cfW0/PzdymjSrSEhHGMrDqoHEAJBjg5DDuvEHgpwBYPp2ajfiqbIHUP4ffzxcpTl0galih4d7e530LDh+QFcYwQ7tO7hUBUNaQMQoGJM4KpHlHHP2/IxH/4mu+fa774f+/UX+kpwtVxN6lD3yH2tNYy44kjnUJERripGkpOJTdd+h809FoSTI3CHVudXV9zBgfJ4cGkaU0g1kDoOCw4hioKsVefJ4iEDsFexezpJB0Ix33nnL0GAHNX/AQT0guSWP16hxffer/fGHkY6eMJ4JEzuB7onUgE1fe22wD0ggt0nPX7pU1Vdkh+I/KgMV6wgptKfzVl7rCeYKxw1EgygNB6uuap0poflp1Ohw1513qtj96F4BpAAAIABJREFUPEUBs5yvAsoso1NuMHrIDPsSxY5TxPwiT3RJgihHlxyYuzhOOCoVyotIJQOGnuL+7B10Ak0BCugAAhwJykdwXDEERNQ1BBfnE8FykWQGeW/Xpp2dbdAA9ttsGYNtyu3H2u8I99FK7rp+14Yb1AmKaAjiFOgOYwS9+U6oFQ4izhzyuGkzzHla5K01OkN0zV7CoM0TKgLLFtlDudN3ebG6V2HU2Ac4Nu4UJgSPF2VgwKgYUw5zqFO7jk94qaZ8Pjph716xjxXwoFPQxzwDwQboUI0aNRVBtnOem8gZPgrI47cjfgjvixhHgxVeOKsJIpbUmMfoOKZ8MGo1hNK0adPKxgdjVkP9ikk7kP5A3qjVdVMRBSAJe5/1IDVDrS2ODL2wzVcgEtV4mWOcWF6pTrqpfGk05Dg57Ductj5yRs4+q617NS8RWx4jSulbPGUIBBKikTr4uXwldvqC1Mj7+fPjSuealIgjmC2yGA4oKSaIRpXUEpJnxXBygAO91X2giXSEbd2KpUtyKTPAE6X0pacYVhxFRFlDEpGSbD8kJhkGCro7vQl5eOj4wCjupKHNgrBi5dMloDDTdps5VjT8+9+vOv9DjoME7nopdiISlHRSr8iEsEl54OJiKyIAEGLYDJVU3EzeAY8Qb26jioqZ7ISRFRVparJT5BHXwMr7MwwjocEY4z0dPUovx9hXlAJbai/Z1K3kiTDBwLE4BrAuYS/eeP2Njj6efOpJl+2Qm4UYQ7uotdrAGHdOlqAu7Et1iGHuklNVkrydISkJF9E8Ss6n1jin4JT56ag5IWrE6JrEfYR4gUHMXNQfOwQSMqAkDCnPSU4IZjXXgtjkkiJ9bsAjD/l0CxLoK1evMqzLEUivv/66jqn63XARtZDk2jh4AGgLskHt2vUUkaxW3u1JK7da2mwYGaImNiEQ5EqtTVP1cR3wyOPuPAOsmxjPJN/NJkFp81woU4wpa0pESjkO5UYncpQLUXMAxvbcs0/4GiiESiJ5wCZlimA8RnLELsOZ1FLisLTWOlCGwuY3XG8WpWq95DjxeZQ/SoH8EJuJdSutiJIcdZx3GmBHuAoZxjl8RbLKekFOcX20/kvSG5DmMOYY0l4yUORRdymqSvJjbHaIVdmaf9YAhcLpG7SMPFu5Pli7rBnkD3LvGNOkuT/fderBcJrYyUYdioQ33njTUWkNyb0bEQgVoh4TQ4qXTMT1xptvupEKpDmMLY7oFilyPnO5yri4FmmXxDEGQWKeP1SqhHrKK664wtDVt998ZxJLvXpnSEnntwFyjV4K0bE20wuPnudcqdNjyqqz02uvvSqYq5qNOeSMrjqRhygHp4D5J/IB4cExPCWEAbkgx75QUCg5KNeJS+58hJgc0lmzF4b334tROHWUVBEchpVL8wBB4zRFIf8PmQbnkFw7+5m9MXbsOJN82B+QiNYoskY3AMtnyqD5wAgpdUqIqG8l9wwXg7nHkY97VE6MELEKMnq0T6UedJfuR/RYXY4LfJLVmjcafGDk18kZuerGfko13GwDgZ5jr/LMnF51WEp58eKFjsJjK8Uc585B8aYpcsVh27CeMr884Zabb0717C0sxrf4F+pqxfF5OH8Jw99laJJZ1rm4Oi4VF6LBnPA+RDFkG/ki0kLn4bzQX5lnRC6ZZ3Lg5LU7tO/o/VyoUBHLIw0baN3ZUKU1BC9Ep7zP+rB+RJ7xCLfYEAF2L7lx0hh91Z+Z3C9ySaoAucHBxmGC6Edqhv2JXYk6MpaiZEgnMS6gbvYejPEIw/5dVvM3YShWKESjHo9kQy90VYtRCHjA1J99+h/vcfQsDo6PpDQCBZIQS/q4HohnzDlzMEZEs7JFaMzUeHD8QDA6qnoDZ509B/KAHmTPwdJGp4HcomfSli9ZnEvXDKjIv034PfS4qLshPVh2huj0nyMrNTVmAteLlPDaa6/b2nNBs9fsRUfPPdKsY6u6dRJiDNJzzz3jBUWJkJPbuX2XJ5ZTPygOp0F5hA/JC8LOIrJS6y8ZAOcflBN6V3WOKAtqNMmJRWGKJ4Jw8ZgDikF/oki5J9EoL/KH/IiiQPFxIgJRFbk5eukCwQC9cM5hVUFUtTS2Tz/5TxiuYuXnBj7rhRqtjhd0xAGOQ4GvVd0RHnUX0d23KSdJuz1KdFqpbWBsBA8MXdKeFY5GxOcjM5nFiRBzAkUmx5TR5D1CYAn8a0WozYcx4D2ck6RHsXPO+pOwft0rWNfE6D+m9m4QinYI1lq8dJEPEsAxef75F2zM6MoB/AU8RORC31WUS2lR6vHEhqqWEnivRo1q9rqAyNjMRAVsxGsFfdx44002YrFUivx07DDC+DGiCKmdGhSO1hzFSJNy6g4R0k0aJz2LyUXff+8d/vxWOVnUKHMNInhaHfLseOkY/IPKobVVR54syR+5TvfdxAgpZ5XkSSlR8fmjUnbAgTgLGBbnVYDJtYlPt2fUeFHstMyjrIZcEfAmcHhynih/E0FS6sBz9L/xess8ZBJgQ+SxZKkSrtklwsQTZixAkHUk8yABkH6AmMgJObJXqVXSRtEkPOYNQ2VyFvXGwV2nOL2EphoUzCNzjONaratbNAo6g7PAnOLtF5acI1v7BN02F3O0r8pk0vU5yq8cfUs20jWnR2UcPvv8v55X2NtEKMz9O++8a8ixphCZXXIk/fxA1qRcNM8Y0QTuR1HRHo188cDnn7XeIPKCjdtaip00EXOEgwzsT+SJnCKvpDs4x9Plb0ZTYOavTZVraO9IsZ2vqDSWQWSFy9RIgeMdqRv9P9WggzDQRL+4cqEoPgwN0C86hvkiNcCLSB7njxw1CIdhOCERGE1ywCAt5H7J16MUvSdFUmOsRGPVtQ/oVY1BBv7lGTkpa9u2LTYWa9cIaq9VXQ08njBiMUclXZQsVVZKiOfeoHugv9Az00XOAsWgfI5xgu4tVxvAqSJLoezXai4x5G1FQKInM0eUvTToFcHKYmpL71EeRp06Dl9E74L1KUQZHFPywwRFmYpYce6B3/eI7LNTPBZ0Cuxs9gOICEaWph4N6zeyw0efAHKAk8RX6Nuvr86RHWC04/3331fAsDYS9JyGi1B9mnoFYDDRgwV1sED3bhek2M1yUhRpQy6rJfSRdN6Q19+07BUvHts1wtbF+SdKJSpHTwA1E0ShZyKUGwlG6HXXsxMgRa83lcLjx9gKlP16vmq6cV5WrFhtRAm5xaEijWC0ijQZcpziRTidpkFhDDEkPrdUUX6GbCF9EbANMI5ZQ9CxCySLpEyQh9huNDqmVD2YiLV00YJcoBvgEaA8vFOEhaR8QhrBs9hFUbMGM1snRXzwwfs2Rs5/pCLBWHYST9w4kh3P7jssTwXP9E5BNW4UoAdF2IhIUcTkihhEkkfxJpciwFPBkFKMC56P1zdUC0q5BEfYuOejHgpFY++IyXV9UOwKhEGFqOT6SpR7ygtBiVKLyEbCU+d7hOlnq6C7ljr+b5ExZDEYcwkpwD6X9VYeuJFLQk73aZXnBaMNZTlbkQadl4CEaT/2npi9tCqjBCGBPslJcuIKjGBgTW9k/RcVU6pZAYSplJfEMyUCwt/OMzF+csgwKC30scsQSiYyaSO5i+fBUG705i0r5faMC4rxMtevX2vyAhv28See9nPSmq24TszASTpXzkAvsdb4HA0ZMF44OeRKJvyqhuP1arkUiQQ8pUd0c3n00QGaqzOdM3PfYI3FDo5e/O1G3Bo/hBz+ptPP/PkL5SWSG9tlmBXoHPIIXi31Zk3kCRMFVzQqst/NxiO1nWhTDT6kpJlPSk+QkwgRpU6ISf3NxrGwS1lvEIICzEftKLJ3yLBuqlWkWskhM85P673P1FSDZ8OJoPaOTca1gJdQxuTP+ZmWf5df3tvyvno1/T8PxiPMpLTZS8CrEfaKvZJjr179cZ9h3o/rjiFKmIvJ5x3x6XlpXH9c8BMHsUN0oZUfCmerapHbtGktKO8iyxL3e/KJJw0PAjXFfG6OIWfqGXuLgW4oV/dG/qWaDK2inDj+D1IcLHUcW5qOYBRJVVCwDwJFWgIlg8zG4/2ik8cLhQdagvICRnz11Zc9Dx8OG+baSPLv5EVRhugLlDrjwnAxdsNuirAjbB+ZtjRgwTlnHahvri2H9i/lYF9/fbCdpqFD31ezlF7uLMXh3zgCWTK0bqgih48SIBwnTqdCBpmDzXIO/5j4h3N+lMf4FBzXAqtpgSJqehUTGcOf4NzLDNU78opMZ6EMunZCYsQ5hkF78qQOzNDnD6kL2P+pPeMVV/ZyqRV11SAkVYWigepxL5xMoj7mAOfHKQNFQ0CGa7VXFykyrySCC52xOMeY6Kyi0JhWrVu6m89m9RIeN/53G0lqWJF5nEQcGhoy0NoV5Y8RwpkidUTDCcraQAwp1+D8VghMNKigkoImFp06dhaiQHtAOfacRCSH98mnnzT/hYgLvc3eeX3gG6Fa/cqxHM6oAusp2ZWOL5ZZRHu2ic/qxbLDXwE1oqEOaSry93PmLNLeqGJ4nH0e2fs0NSjlzmEbJLtEozizGFeMbioDmwo00HWRJUwHIp4fGSbvTiqhR4+L5KA0sHO1ccNmyzZ9rWfLqUkO4OBvB3kOruIhC1yHns/ckGAQ1cXeJS0BEoNDxDNec81VJvLxjMwvSFUCTbOmpFTSliycb0OKlzJNjFNqoOhMgiGNx4rFjQ90B/HgcxWrQ8iA5MGmoFckN8aQJoeoHlX+kckkujlPOdf+/W+w0qcIH0i3uE7KgNzgrkCy7En/2UgCiG2ieFArFXuv2eEbMU3nyJDmlzKlcwfJ5eTsUjNgYf+65CWy6Pg372OwHOlqosiPIgC8aJhwg5pE0DWEz9Dlg3NOWcy2ymP9NuHX8NwzAxW9PStIrrW7XnicujaQI5HmdEXIb4pwwRmmQFhAdpwMwzFDLizW2MH92dxEpTBHLbSaC88r0KIkxrVSelmA8JxSBvZvIxob1RNVIzzxhA0YZ/p+6hp8FyWPQKDEbtfpInergJ4XBwcAq1J/O04Fx6NG/yIEQF7h8SNutE20ADV+gM7kI4fCaSkIEoYXoaEVIu/jeXMSBnm1czq2D48+8qhJNZGtyxmg0ctDMWJEEUpyCihMnp3jrg6IBs/PnDqD0uXMRJwAPHfyXHfrMPLhwz92xFSzVlU39SAiYF34QwcenANOm+F9FF0sFcJhijkjZApnC+gGRcAztBXxBkN3WM9tnggdk0w2iMQJno/DB9hsrDMQFZF3ZBYCDXLU2xkui0Kh9+51mdeJzY1x4XoovYRqbw/ayjhGyTQMoEctSjk6ixHKTSJRkzeISIEe9TwgC/tEanrg/gfcE7eNDCk1g9Towfil+xjzwXg5LADHqLJkLzKWxWxWNAJp5+KLejgizTGcrT0CeYRn0jO8oaPZMMDwFj788D2Nv5QhaIh+OIigKPFovtghCkPko8BShDgjLCnUYIMUWHOlQCiFYg7maJ2ydKABTca5L46qYUVBpJycQ8RHztOt5OjYQxSi56e5CXoDxAvCzbat62QwslRr+YkbJrwk408fY6D3zKwMGyOc7haqJyb1E43XAefJQCFoWICco2sg4WAEKWkB6iSPh3NPrhD9VUklLhAbGXPC9idVxViA+mJZV4QHOd5t1fIF4eq+N4YHH34wHJfTRokHjF+6LkHc2S/CF+sNOoVjzXoRpNhhUOlKZI7reEjpRNIjMJA5yGG8Dl2HZ4Fz3UlOOn2IYUePG/+bG6WQNisl9MN1m9qntA4EuWEuWsv4btmy3cfUAUfyb4znNOle5hc9jHyf06Gjz6oFKSngHH0es/lJbYAUoneJdkEVyMEjJy4dkhOA85Srpgnkfrl+QfWTThp7MA7YrJMnT1fnsnHmouTJo1plwc/IKtdhf+IQVKxUzQgLjjNcAcxnDIxiB7r/ITNJ1/E+DkNyvCW6HLY4SBPoAaxt+vQCDcO+h0uTXw0a3MhBL5NO7RjJWRJkT723KxL4T3sRuBqDzd7lGiAGkCqvVuTeRigBDiDf4cWzoFewA5QUpi2aPzcX7BcFlRTpY0APawLsiTH52khEHRws/J0KjD+WosNThGEFdIMyMBMKg4bykOIpL09jgqDiRx59KFylKBcPaqKMFodfN2vSzIdLMwiMBUX29Ink+xzai1Anx6rFMw8LhJ9VV4ZXSZCJh+wEMuG1oboImcYcUGwNGJvTx8gNL5JclGtHU23nuD45DTYYOD7KBRYh8ElVwTJXqvaS3w0Z8rqjJiYOY4TH3FF0fCZ1g2DgMWI6f/H5l2H/QTX9rtnYi8V98N6YE6BlyAHMcZLT5ToIRDSefytQxhuZp9EJQGEBpRiSSP3h82biaWNHtm/s2BShE7WLW7YytGjeJLwgB6CSomcEhV6drEsZnfoyWOQQWIk5IiMQSTEPKGeio/eHvmcZ4FxEyipYGzbPu+9+IAhzpEpd6pu4gI247957rcwPybPnHv9jEHQvDGkC6+KF4i1yyDOsSuaFCNu5p907Yq9WRVo1a1QVbPd/YYEIX6APlUUGK12mhMRcbGNF+USj+ZWn7dO7j0lnyEKsZ4tdjchtsf70TsVpMsynnB1ROtEuc+g2ksyXFAddawyzayywr4cP/4/zjLFjSTwPlu8ig/zdWM3CmR8ajdAcgdwfmzRhNPI99k5BOmWlzl7F2JwUlJuQdAoLOiKXm+RmEgg/gXUNLWqxkBnYgY+rkQnEno7qvQpRhfxpA/V/BXZDKaMUqRfFKSEvhuwxbg4lJj/eS3NFRHrCBzpE1AZDztoOG/aBo0Qcva++/tJHdW3ctFVyX8o1sEDMRMZ0IwKKjYaTns+0G4x5fAwyiok1XLp0thysC0Qae9L7k9w0a0EusbYMaUaGzjsWykSOG7IOc4xRZd7ySdkCW65dtzYSa0gX6BpEBMxD13O7ujkDztlIka9GfD/SzRKqqCsPR3NRyjHhtwkus0icrooyjFybXCrOx569u33AAs48kDqpHPKYRHbIKgdWoNNASyJpLBb6I6/olATtgoyCY03U+eabrzmo2CpjgKPE/dFr5LeJRN2YQkaCPUr0A2LF3OOkYUiJHuEEMCc0+wA2ZlzkJmkIgSPHIQZ0XQNy5vjDscqZo88KyXEzE1lMXsoPMQ5XqNsRhmqMjqljDJde2tPySzN9jmOjrSAtKWlO7zSM9k+68qMbNqxzBMo8xPLCw06t0faTe3FfAqm0tNjliMiznPoEly5d3BFZ+bIV7DiVUoQ/b64qLN4ZaucyBkuRhAiaBsRMTrypSlRowPDN15/7JCZe7BFkn7Vnrhmb/4brot/HLmIJU7ewZKqWdXFtkas+/+JL6zQcAxNGFXBgnLkGQRnOHfNSTGgDrRMhWGJove9SyKUhXpAi5aoJIjDy8DgeHfCIGcAr5cC5WZDWl9QlqCqsedJSaQvmzsqlPomzRcHeL1ejZAzXQSXIE4+ZCHXj+s02WsvEcCViiAfAwqiUMUsZMUM+GtgJGU1Oyfhtwh+CER+V4rvMdHJyquShJvw6UQrzLg8AA0qvVEg8PBTGGu8oOaQZaALlSH3mjz/+IKMiOEOeafRsiC6oXYotn2xI7bVwFE/MgaFo2ShEDQgAhpSFoj9mDx3HlJROQEZioUjA08ZqiA6/vVPREeeMrhchAfbfsI8+9Pc6quMKQssmhKyAR/v2W+8qgjjgSAKPFQVA1BXP+INine4TF4gsqT3lu7xvxZeKXjAufBcjkBjk08bWHlp8xbqniPsn3wH6hzw0Z/ak0KdXv/CvZ57y5qXNor1kRdG0W7znnnutBBGuWCqSZo8ZgX/33bfc3Wrzxm3aQKoRFrSBciYKfurpZ8x0gyABRPriwIFWfChiEADWzsY0DtiOButGBHL6CC57xtM8N6wLTEJO6ECZkjfBuaB/LRDKDJXvsFZ1zqjpz5IHmyWopr16Yl4mKDIqdWRN8yBFzvxiSHmm/XpmHDw8RogO5LTJiTuvwfiU32FrUloQ21Lmd1tAFBpKODpCB63E+DcyiOyQiqDOD4i3jRQbUUNCkOP3yYsNTMONJDrnfcpwGGOWPOcjYq2TGkjy5IkxjWur6ZPssgcpTyEawImgOQPPS2kNkSbkGdYMhU8bPXfvETSb5Mw5b5ETly6SjJMTPZGKSGVK7TQyT6+qXpB0A43tX/33YDsENIU/KhgYsg55ueQUFeY7IXkwzqSLmN/XoKOMF3BfWyD7i8S1AE6nx+w68S8AlUsoR4mzF/un7hDMHokdJsHIaBaWEiRVtEy1s7TA4xxbiDsgNkuXztW+66ayhvsNYf5BM3ftPZwM5JR1rF69uuWRNesj+HeFUDaXm6i5PSfQzFZOdaGcOfKURMToO8iGzDVrzThck6nyvEhIiWgROW3QLhyzEpTKSZkiS48OeDhcellPnWDzrVsDxmYPOkNV4yus/HdkYfM9EV90D+SZphcrVy23UWOeygua3KU1WKNnQW5x6kif0FQF9u5byllv27o2tO/Q1QaVfrjU+H755bBQtnwtyyVjh11N29RaIoDS7YtUHSxkIvcqgo3ZlwQMyAn3LSzjGdu/CqLV9yEWfayTqohGkcdI7ttpowqXgcPWIYdVqVbJTjwcBcohC6TnlVFsZr4F80WZz4jvRlr+4Qfs26eyEqoQpJ/dAEJzwzWRc+afzkNGfeRUxEBMkqKfuVh0ZpIGELGxDnoRhLJmzRqGXKvp+eDOfPDhRzrT+DyfIf3Ky68IKVOvYKOUYuJKHtiLoJgcWFFFR/T99NNIrwvOhM80NZIGZI5DIhRMskDe/EpValyvxvY0DSEFxSleVHvwOdCTakISQPrS5s+ZqYg0U17eaCdprxd9m4sj5LbOUjJFlaTeuln1VrL4PysC+04dhuopOsGzS8gzbC57EgwKlqzgB+Cx/v2vV+TS3k3bKTxmYqboSCmEjvIZmhPgzSZ1gMCsqDk2C4uZEGzYCJRMoExQvsCDCSnHrN1UPoMVcjcaRyre+s7bsnA4BIULidigBSJ0x0gCg+Kx46VgGJoKnnrg3vusfB5X9xyIJSwe83CzOmbADCPxDF19vwQTtuOF6mfKcXEvvDDI5BkgJQw57ECo3wnr0X02dV+IAbGRBP1jY2Idg8bnHN2n8s2GpoGlU4YqKtpYuxW7GYkIRq5a33HUIcdmu3INt91ya7hVrdx44QRsE+RcS942naGG6kBfaiFjbSYn56hEQ94nAv7pp8PdVP2viZPdApHrEYkh6NSljhr9k3NtlCd0u1Dt8VynppwZtikV/TN2jATXI+cCpIWyxrudI0UGlT/W7R50H2PXX2pu+Q5NMHBkymstIKwUViTEhsQ5cSQuwcfRI/8DJAchh85XwDcQSTSDlhlq+ighobAbJUupCkeUuWenyleMAtjHjUYfA/Lqq6+6iQWQE944hCs2PE4GUQobhshtuTqzUHdZTdEISp/nZo2T9ATrStSUHCoemYd5lH/XYdUyfhwuffiAjIb2R5IfTdbXBlXXIzdNzg55IocJ+oODRUcvWgISmSGT8VDmHT55B/kk6kKhMl6cKs5d5FzTgkQ/qvEm06ntYyiOOSBy5FSaxx97VB79V4o6ZruJN8xYSCLOEZMjNecAdIS2i/GAChjc5LMSeJfPIScgGyAeDerXVROTl41eQITCcGRLkYHMgBAx59Sy0u0m9s7eG5sPyEgR4RJtY2QhN4KQIMP0sCYyu1lND2pwiITmn1TT5zqomvuBUhB5YdRaqH8vTh/jWymZm/TXZMlPjklUrDmkm2R/2ZmC2+GOSLDliVAjC57ncq9cKU72Is4CBJO+115twtlHKm3iXE2Ox8NZ49B31gqZTq7PHkPOSfVQg83ccVoUUa5bYcqphTWLw8peQbYhBlHGA6rHOa5TdKpLq5bNQk81wUBf/65j6zjQGxShgBxRommiJ3RyTf3sIEfX49DqcuVVWuKmBzqqT8aNeuNM7UGQGdJFGGxkDblzWkT351n5mSi7b99+rqce8sZbRo04MSchNdaUTqsv5n8pkb7QER99/JmP4AN63rULIk+UZ+rBuT/zgnPCvuRnSJORVYuLB9FLzj0pF5xJnaDDGbH8oezMzeY1NgiHHAzQSA7R7FlzpJdGakxNXL8LvO8SmlSqKzbl4XAQDmfIrzxxBTercMMH7IJXOabUMKRUeWB7li1f6n12p/YWhhsExSfkaN7YY+iuJD2FjkybM2t6Ls2EYR8CR16hY8HskWjDWMlpALAFN4qeDVzH+XU/jvzeLaXoBoRRQvBR7kR9pjNLSWDCiDJvufVmn6MINMwAgCI4Y5RNSE9JBokyYrJRplyHiWOjo6iAb/l5gprCo2iPSyDoPgJc6CN99FmglxPQsVOsXUONeBh4MxT1Um4iBUdTdcJ/DC1lOEAc5M2SRuC0pmLcFyl53alzZ+UGB7iwmrZawJJPP/2IjMgD7o5Ts4YYgroPR6XRjopJff/9D23gmVhyNRFyQRhpKiAYSwvEJsA5cLLa3lZ0AhIiAhuf3yUG9TQhyQKRGIGYF0SR8GzksXitW7NA+ZSeyl0+rFZzOslB48MRIOcMlETzcyBA1gKWMRE4CpjInrzSD2r3NkbNxH+WLHBaTwKNAe8xly+9JE9PUcoQlc9QGE6drwlGEshkvoE0EVC8UJizzC3lIkTFoAoY/bKC2lAYGHmio9j9iHKLnTJQVbVOgl4UyRaVHEF6Ysz0zayqSPBmlQdQN2dDqggUQ1pIHiRzDvObfC0KEUO9Qs3JiWzOFSzIcxJR+yQZyUYkIXD4eLpqCZeE93QaB8oDKA4DAuGEiI+8HlA8BimW5qwwlJrXrIXYXiyeYETuJdbyFjKUFw11wiimAxjNLojUydNhSJPOLklEmiA6zAXGZ/gnn5oRTMTgek45nER0RJmsJ/PAcX3/+tfTRmmqS5Gyj0BIYK12lgy7RlTPGKHd6Fiqfe8yAAAgAElEQVSSE+NZ3nxjiAg7f7i5A3V8nHjBfuTZIR8hFzEqkzGRrJFKgHUMVJecmhSPtIq5YOQZ2A5HAg++WbPm4Qkxx7kIkDhntR5WD2BygTgRRFDkKn2CiWSFXD7MWdaS/cAzwCSF6c31MOSrZKRrqwvPgEceVAOCuu7f+raitkWCg89QDh9GP6SadkIuiEZp/r5wwTTJTkPnu0gnmL9AJzQTFqOuSfpdRxJf7A2dnFtMnSlzQd3sggULpR966J5vqexmqohPV6kFZ2/VZg+MJCA5lkn3KGQMmchXIKYfcsxaVn5Nxhi5oSyFMz6ZO0g/vL9DDhQoH/IDYQY0gvKZl14aHBaoJrOWSs5aqyqA6Du225utlNQel+tcIOcXq0BHqOpy/MqpxSI6mT0KDMozwvCtqIAGncO+Ruej52DE15BOW7t2jXUWL3Q/uov5Jg+9Uo0VcL5xNlkLjmtrImImzd85PGCscqJmv2r9YctGm3DShhJiY03lcDH03CM5nIH7xAYpoIqoqoi8xeMwU33U9T66CpnAkcGpvUKRImvCWbLVVWXRrFlLdWUaFf78Y5YizlIuJWItkwNRkDeMIASipUvW6RplfB9ekUwX2xv6oHg5kTiiVJuQ4pg3b46dKRApuD9cl31CugM9x56zIaUQ92sdSwWsChzkLiZ6sCTfAtYOGYnN/PW338l7/a8bGKAgyZ86SYwnrsnCUGJUtogejkF9TIvUvGlze3QOmz3QLf4uJ5PwQpApGudhXTh7QrGFFCAKFso5wgAlHxYWyWQYXihdCr6T/BQPxMPag7RBj6U7SYkDtYiUEBTW/Y/IM+4j1iWKEuGKpSoFwhmKkH8d/4tYycPUKPx+F91u0b3wGF9Wk/QZ038XeeNK06JpFUg+d8SIb31YMc+MV0mkukxdRaCKA2WzUYGynC/VavGcbC7mNqklTUoAmN8IQcRSkqQ8JoG5iXZiNBV/lxIDw0A7RJEvr1rMp556XN2CWlr5A5/hwQEL4nU+o1KK5oqm1kqhAW3lc3SmZtb6HF7lc8896z7BoyWQPXp0i6eRSGhoDIDT8IeULiQxGozjDEBSogFGJGHE8g1ObDGMIyUFzIUxg5xEP1TaolH4nS454fQJjnrjlB8UtVv/yWjAxoTw5oYK2ftd+kBZCc8CJNVB8BYbnTnTVjETtpg8d17M234OmVcUu1wn9VCa0EKdkzgcO5KAonNl6p5+RnbZ0NRPj1dOig0aT7wg9xmZx476JRvcG0cO48fcwEjHqMQWY7GzUYT0dA6m5gPyGesMhIb88qL2GGOPwsCgJusaCX2xZMjGWVEK7c6Gqu/xmjVrnQcEvoZAVFWwFK3gkGO+z5o8+aRqefU+DEYiRgwd+ghniNIsj0/rjegA6XJUXLaUwJtvvq5Uy1TXADaX0QNpeUMHQ1D2gwJnzePB46AfgtU0X8h1khNPcvkedyKNqVSGy5jEFoVA9sQTA7Q3MmT0J8qhUns/zX+G2giSc8PB4PsoXk5HcZ9c/UdET24Wgwd8S+4xHlt1yudqNm3aUKzTTs4D0wDhzbfVhUmRNtdqLiY5sN/3apYCeYd8P8qOcccTomIJVCwbi4QdrwEyATqi+zAWYG1OnjqSjd4q5NI58rocWUcuslevPnqejWHwKy+FM3U2K2mURDFbgIh0McxunkD9ZZwnn5Ws6yAX6Dczx9GBmg/2Eo0f+Dm2FKTmuLL1y7ffjlCDioV2wqjtbqI1Y/5++eVX6bBtitR0mLj3a1HvM47Vo8SKhvwEDDShAJp06kvjQQZhqr/11tuWH5xI4MykNAXHHfYu+qth43pK0fU2l+EHtResICNNegNiEY35f1HetmrVSnZuYSrThxw7EvVioVQDkXwmUh1U2ZONT0rmjbC5AX6sREhOlGGPmmBE61n9jH4kGgURwnbA6/ntt1/NF9gjCJk0DjoYo8z6uj4U6Fv38h7QePZK18dywhisOJhBtmU/6DBGpQD9EG5R32JY5/OECG2RnsL5Bq3EiQDxSTgO6GH32l04b3YuigeBwwix+fCAgRkSZc3v8VhYpIl//Snj8V2oLM9mp2jjXJAIj0HgObH4QEN4QLTYAl5Kmp9HRVvIeTLqVvHsgSSBAA1N6uGgkONds9mxFRAV+B5QzOjRP6dODAju1IMB5AV0AozqI92IUInoUs0YMNxAbwgFh/SSRK4kjLuKEvvARxgcJpmfGzaKTF6K9l8cNMh1aySWMdyPqs8uHhxRK4e9klcqI6NJYwLIRjQ4wHsrI7ycaI28IHPjSdZ/KDigHJ84oGflmRypGsaNXhGKkejLh1FrgxE/MOc4MjRnxlPFGflnvorTa4hwMK+PyEunoQbdNhyJ6lVKm4e2X/fe90A8agnoT4ICnI6yRXFMnz5LyniAGmVf6rMvOdqpc5dOhqiLKG8FI46i8GJyuGhlhuHaIy+Yl5shpAgurC3j5blps0g0CryPE4Qx9VrpptQoY0id1zSaEZ+TNQW9uP32W/1vjg5D0EuX1iHccgga6YB4iCMYO0fq2nsYqwQidSpAjUJ2qGk8ZTY4iGa3yptOnEKUWGQGypi5JvmAIUgUFqxXyDyQiFA6UcHDhq3sdUEp1FCJBeVRMNYxpMmJJEm9KVEjCgRHw4XpQHYQ9xRlFpM3e9jrGlu9JXnwhIuQGCacrSVqIfe02p2xZkQgEMNgDDZUG7Ubb7zRysIRtsZIGRLyUlndV3hB4iggeYEDgOPh91KdXRA29hZ1iC+9PMhQPnkzXi++MNBddx5XIw7WpkJFcRikoE4bSs2ZSVwwHeEfUMajuTQ0jfrTWBLiBv2m2b+UnkDSuvqqy8V6rqdoeYfP84VkRj2lozhdb5fmljVBycdj7zKk6As7T+fmFooKnQuV/DA2yhxI8dxww7VuzE8jB1pN0mO4Veu2JtNweDlK3JG/IhrSBIw/R3n1eAYxx3bhKMR+rRi9pC8wDgN7NjmQA/Y4MHp3OVGviTD5hEqOxv86QfD442q12dmRToI+eDJTrzxGaP4+l5d5slK3IY1n3bImQIXoBGBXdGAiP0RHyDjPjJzg9NFKke+CjJ0p3sV+rT3HX1J1QPQZD/uW46T/rhUEjVzPEgRKD1ry1ugRrkl02P/G/kYVIbKxBzCiXBs9gzHHaMB3uU55QhwSjBnoAvXKNBihNAtEgJRPnboidAmiP6rvBvUhJ9jBdlBaxwsCVYxO/z6kJNZ022SiHVJlLjFIIDCKedFYtYCctmvXVuWKZzu/Om3aFAV8ak0qQ09dPOsL+sa6RaQhInGkaECocMaRMdY5cWq4D/LrNJKMLk7MuWooctttt3q9uS52Btj4rLNa+vnZk+7Kpn3Ky2U1lL+wQD+o6TNeGEl6PGIOwUXI+RBEnK2bt9kbxUJTo4U3lfTjJScABs95bVCmr9SmIf+IR8fEHZYSYGHJUTLQJ1TH2E9Fv2x0jIbb3+GlSQHhjWL8wLXlz7lRNEIOhftPGXGgPLxS98PliCs9EMqORuYoMwcbejlK0nMxabD1IE/QWB0CChubcyC5J8/HGGsL66d29M7b73TP3auvvUYF33MME/1Xhes/yguD6dlH0HdFeWnAxK2VE0HoKHdB4DmWilwuAkYksXr1Knt0KFGULpsjwg0xEmKx//fknDQLK8w9FBrGA8+NF14UsALKJBYDc9KIDJeek1KFnsLzgWiAzTCiq1T2kRx6/aKa0I8b/6s2mOrW5MDgZCRwPN+nU9Q9d98ROnbu6KPqgOzr1KvjcRLF8wIuate+rdsBothcE6mIFrJPQqYg/xU3QGzLBxwH4YPuPtRvxo4uZcM8KTgcDZwODs7G0aLkYsUy3UM5utvvuMVGC8gIiMV9NN1xp77Wi1xwbEJx4pg2gJQtm4zXAZXt0OMTOj2kF/LCQPinIw/yz5YzTqih0D9T507OUBnIGz7vkdydj07T/NIiMDqJxwyjATdCcKtb9wxfc7/yez5WK8U6jfWmahHIuurnyP6Ldb44DhjcEtrQRC3IJsbyn4b0n2xtZPZXMVAhUFDiU0GOH8aXetymQneAtVCC3AMj//TTTwviXOUcDrk95gjoqbeaGFAmhJydstGVA6G2nUSClBe9K5Y2z+/+spKXPr17hRtuvE4lLA9apoB7gR6JSIG9aHhB7aQPVtAYTabROqAXTNjQK4F5nVKRk8T+mqkeww0b1rfRqVu3nhX2rJnTNM9qw6aIievtl6Lbs2uvz6JMoFecW8ZJGQ7kL9isGBuekYM2OP+ToILGBeQs6W0NDIxDTRRLAxKgcAw1TgfOS0SwYnkD5wMDWQL5YqhiK08a6lOnHk+9YV1JL3AAOKSSDz8c6rMu33jjbTUkudrNLLbJWYgF/aSm/o7OmQ8ja46yogGNqADpqHh4h2dNbyZ9zHHWkRnWyvwKzTFzCLGFv5FDjl77j86DzqvvUa/ZvkMnNxLg+Ln/x9adAGw+lu3jf2QZsstOzNh32bNvkS30ttpDJGUtW0mELFlaqFSWohDeomRfJvvOGDvDICKy7+R/fM7rvuZ5en//u9fLPHM/9/39Xt/rOpfjPM7jFHCBVu03dnXDBPzsgJYYjHXyitpprIXZsteldswe4g/gCJAbbSMt2abWK/vZz26eeuQyBUVzis7FE2FXGy92dtiy1muGGQWQWNzUrJJpV/DzTiFY/l6polTr8jwERa0lpa2VFqDBMlSg1Pvo7W9nUbuPABoqZDSg8pnnbJ/QNxakK2dIUHBoeinN5ygb8Dvsvmuy3n3/tnZNpFTkyOnqfIO+f/zjE2vt6RU3EmOeQdZ0oQTRnDqFKg612OaDLo3JHrzv3g957gvSQ6RetElo/WjKqMG8LifK82oK1pbyt4wzO//88yLqncb5OA9OTzyhXkZNY489vll1KY6t4fOpf+Zgc5KiE+LWO+38tUS/R5Q2oh5DBXdZLafhAWukl2VqAfj3i9FoTTbqhsem/eWppNnkCRlqBrg3HbeIruHiVbDOw/adMhBRFie0ZuCAGXM/DBNCggdsIRhPeqG3peUCq3j77bevTMmiI10c8r3vV1SyeKDOr2YYsPc70EaHvREDIBrGBHz33f8MHfr9Q2paDI3NBx7UrP9KOUcPoGDqQf0T1NP7YEWOXXGH8Z07MIz6TZu5CjZvhBxZEafF8U+XgeSTRVDg5jRxr7vOGkM/PPKIouEzALJkRmeRBAcc6mE/OCLw4DzFoEP+sc4MRrF+c2g5njNOP7X6pn4WSTpFfNrLNrLWAjM6PQtEKwpQSBxVw2ZESzkErJkhuclc/Y51JfTMuD8e8Y277rqzaqCcJbgJxGc9GTq1bb9rbdTUKTFtuqkgbDBRIteIDCWQMJWnasj5PodoKPrPU4cJyYH5ztdy0H2voEUv4GKLLlaBnaiag/M8C6qMceBsGK1fh6146623V9QtapWRMkqzRKaSwROZYwgyLIwZTVPGtxFHwFcNImx9vi3o8XetHQcDu6mgcNoy0rdSC+TER6UPETrRa3S9plotOvmdX/3614FtxxbDUA+quqZAbPMME183rTDYkSj5oLuto17kGYCm2XFOD8ojc10pQd37ydwKwlKHynMD6b388os1RFuA5Pfuj+bsukEhTNQZH/jw51ESk426pwoAMS9jJO0bn1XEuJw3a9lG0jXSxiRn2tnqMTbv5zxWYBQEwKBxde7x4+9JUH5PgvcE2tlr6oOu+bXsLcbPC6u72shkJvkMkBuSjJKCZ+rser9g0L40+g8CQfjjj388r2wTQ2i/erEhPkc7CnshwBWkPZegi+A+GUY96v6ukIuC7cDLxoC9PrTXnt8IWrJb8TU4hIVM40FayXO0h3vLU3+mtSb2Qa2VjL0G99UzL6GOBAO9ttxk90yUSfIC9sz/3D+7QP0HSiL4ZIvVoS8MgnjuuX8MGeuZoQ3WX6eg2Y9lELmSmTqu75wu642AtcLyK9ae5WB8htYVQSPou5jK+XkjjlUYNCBCTlYZ2eisy8EHf7euU0YocLvoogszlvHxqkuXhne+Qx82O85ZyxDZZu91LiQXRVqN7fWCAoBy2+AISY+MvdWpGzO8XUPrYW5yfrLERZMIIGvdHFITZ0bhi3zm0wkqIW2eg759+7F3aZAeZT/0f3d2cMH4Aw6D/VBqRtnXSlFaIpWWxo27u2xSH11nnYjDVNCQ75orXRyCH69qI5rkSDMh3WYwPggrDSOT4a7xNoFJkFM42r9GouuPfzy3WjkeDfHCYRJhaok48cTja/PqqaJAwRnVVPssos/xhVcn0j4hrSWbJxvlsPSQNibgB4PWl0hIZZEaGYPxCJz5Vox+jBYBBIvm+p5L9OnffSRZr5spoheVOv+rLCGHpVR3EsVuuulmhbG3LCOklkCXmIIeMke45zf3ToYzTVo9DikijIiYqPV3D/xuDUDeIey1t5MZgXoNy/Zw50jGSZmD5u7TGa8lKzOTVF3Dwx4faMCcPCQjm7GIKQ5SNo01KXEG9Vw4ZR4wWFaGQNVF/6q6Yo0oAqVptidWEefh/Q/ceufQCnGiB2TSwbIJBMDxr8UZPRnnL+L+eCY7HHrY98Pu+2dBZSBW690Zwy0znrx+9qPUef43g8tPPum4GODdqq8NIUgQopa8xze/WfKIb3KigWCsL/bh++/5Nwg7kVvWmuMBNd959x1pfXi4gjKGhwNdMKSFcWGJUpNi+JheBgt8biq9us7xxx1Th0kW0sQYGPCBrmiMVwl/ZP0qgxsgCr4TUuEwMLB69RzmddZet2r2HEGxKMsJGwaQWnX1zj0d5aYTyxGK9Ku/NwYFiUetpUNy2LGenb+naFSZXda/R6SNlJOyRSCrWoPBAZukH12U+unq7zi8KaZI60sMWRNP6DNRmxPyma736KOPCVPz5qp3Y2YyOGqsAg3j1AR8yA/22NZbb1vGDPrBCZchzxrqC8SMb/VRgU/TJZ6uprxMKDlA7RjzJMjS8wnqxFTcYIMNhv6Y1hvzUwl1CKhr/i3W7sCRtrpiG/3XBMEbaac7094S1X9mLc1xFNB+PYzyT6S+x+Dfd29EOlIzMzFJ5jhu/AMVdFoX/ZwMnZuXNQjKpwwRiBPHtrdHEKBkYDJn62nQuJryqaedXs57jjw7tqyymwTomPkTn3gqmb25w5nDmj2gd9X9k/Az7cV+9Hn2p32NBLXuemsl+P9hMa/tQfesLxQsLEjybKusETszsuZdZMw64/oVFQOHHSlbpWBOb5pRrla5QTIgOHgPVyX/+FzfhwTnv3t2hf1PW/jhDHBYYuXlh9bI0AnOS/seqT/oHP3sarvLnoNgIdyoc2pL4kz8N+druLbnSflNMGa9akxf+kIJdnwuZTiInglhJP++sfs3amYs8p19B4IvXkfugSKX8hzHCxplXyUTnkerr7fhDM0JNVESr0moZC6A04NoOkMbb7xRtfWQJbzrznuLD7LooktWonJ7nLRs0vly3R8Mho37LEiD79JT7TnUABM71D6tfxoPwku72DppazTGD6O3avX5jBLFyXva2LdIfwapHT06c39zz85E4/ekv/a+cXcnSJ0sah+XlCNdL9Gu1NxBEWG8FFh0pqTPoDILf3c2/3nn/bHaRWyQ51MntQl3SNvM3nvvWU6GCgitTNfcWKdND9UFaaZ+IE35iDyYkKIjDsBiWxBO1KETNXfCTbU4JIOgdynd/kecaGtJmaJqSb3XFEwKZqq6w+DFUYjyQISLhVBjOK8hveoInL4N4IGricmmF0pt18irf8SJMa7gktNPPb0is12+ukux5JAbts9QafDcBhtsWESZv/7l4gxtPrXo++4JNEbU32I78Fh1DK0Hg5buoXO6vQ4nimJEwbnWVpYAvis8Pr+nD89BnD7UchDK44GN18oszn322aMiaQaNQ0eO0gdF5cRMxB2+snPdp43g2jr0pJ6AJf2POP8dM3ppyy0/UypN2gS2ipIHRELrBYe0UybEfHmrrWpzqY2qR083mEDB6RnR1IUjKBRxwOpcmM73BtKhgQo6EiTob/O82/NtB0iA5j43Dgy1e6D1p/8RdmfeO0daRXy+we960tyjA9Lh8SKKZH/VmibTc7+CKzCPWvgqK3+yIM6WpTXiEBIU9rRnYS/+NiPlxmTaBxTFPqqxdvl7teUSlIhTAxF7yeYRjYoBHLUcQw1kJr1VAEGnJBtdV86Ugd4+o1qc8ueqgUJL9K7lPFTL06CmXHXGvIcBIV7x07QavJIMTLM71qgZrRyC4JNzHRuSkUxZVr11nKvAC5HEfRWxKmfuazEKjB+IT5YqM3WGqVGRsjv99NNKA1l9zMxF0JYh11uHqANpOOGE40uNTCBRAansesD+7eerKYa1Nhivkc602JAD4+re9QeTXkTY0ZtH9UyLkjmcyhkzJ+KfLhn2v+KgMPvdR7VYQatiizgxQQUHMybGzDWZEIMsR7TeWYeEaQOyv/2eLEUPr6yUTXstwzc4sB9HL1x/pAAcFGzq0PkhUt540w357ucqmMLWp8crWz7hhGOrvQXE/PY7Yd3rL816QtKcLc+BvZSV9uCoav95/s5Gd6Qf/qeqpJOQDFBqc6RpOcl5cC7YQKgKJyPqkzU7D9ZDcnNHWu60BK29zlqBZq+vuqlkRnC7woorpASzRhzMHTUNx4uDkEBMHtELSkTsy0UpQyEu/ec/79VoOBkre1pwbuylgFQ9FYGUBODnAvvb2z88+sjSAdjjG7sXqeie9J0bj1bi/rgLuWbPyZljW1sf7buxZc+Ww21CFE1YwdlQuvASnNpDMsleo7VntbqBczlhmgP0n53fV/IcdQFwMlAHP/NcoReCD8M7ulQgeyvYQjJrr1aVtb70iQnxIIYem/5TKN3zzz8zieBUghpqoNnHJYKT/waVzxyfMbIcU8pGbsLwWtH4holG1VAUpB1y2SKH8WpgHi78vmQOv/zlz8sYkM57OQ3Qd911Rwzg7lVbVAOVttsuDEUfceOAi8LPOvP3dfBMvZeaq02BP5FfRMydvWuDF7Ms1wIGJNOlwEwP12HCLNTfKipUi3OT1VYS2KCR/NvDEVX47HkydFh0Y0TYMtFlpCLi/WoK5viBQsFpG2z4qcBD6xTkzJnQ2b3rjruHtspkg83TFgPWuPLKq2vQt8hQJi7i07859u/XlyObLYt8ZbIwmp/o0+AnwYU+wFFZg+qfzMMGx3Cc/tvGA2NVHTGZsqZs2bYmajUhm2z2QDcO2YTHnkitcv1EhbvH8S9cv/Ny3qeGDIpHhlJT3GPPfUuC72OZEMEwNhks2VxTbWGkDNm94IKz63v22//AwIZrhvX4iYgf3Jmhyw8V5L1fJNBsIBuV4XwzGWcRbQId6XVjMFtk92ECmwcL6nb4SXbpHybHqG6rbuz5lCBA/idb1Srh+WoVOjgDwkcnc309pDXkNf2OokPEEWvS9Zyr5pf1gHaAWqrWnGzjsQRaFfVm76y26uplMDhHjq9nCerqZMzASwZmU1oSPXdd4yIeZM9pfG9M36Hap72tiWQbxOOdGFNwUWdaV5tYDm+RWNRWB5rIWMeyFC/QaNXlc+grMM7/+rX5uf1unTFxEdjU7AWF008/cwz6hAp09fDOnuzz2ozB833Lpna1fQKdD5K1g7EwNp2dKWMk9klACDF5b6AsIxuWkU4bh3bPPXfVyLjqrct7nskZQpjRP6wO7nr+kiENF//tr2GDz1VnnyGrXtxBANRExRvpqbXBtOdSc16F+/m/yjzqeTV2rPutbC76ztulxrjN1ltlUPL9dc6cpR3jYJU0DMnG2gV/knnU0gQhkoHbL0h/MkdsUd+J44Cz4XlzKjI649yURQhMcGb2J5m9PSO0IljGoEZoU98jF+iS78y+v/DPfxm6IeUZkLQsZIcdtq2SDqiPnXH7zpyy08ylK9v2Sg+GhtvUWm94z7pqAklIODUUnNMYKP0w+D6XER+Vnui3AncXspD/2SuCQ46tiIb5HqiWvdKQmSlLucz81prPnM8F0SPlkEm8+qqra4C5MsBSESNYI3J65khfEucLobLXz0y9lX12BvkAyAshFgjRXCGcaY/iqM5Oz+5Pf/Lz2stg9PXXX78c1ukRDWmBL+RGwNRm1gqYcTKQogQhoHwdDZxTh2zZpN6rzG8gkOFGKPsgGZIo1L8tQRPUCAxl72PT6+4Mt0RNK2Drq8dubySgtF/GtrMFstGeQCCj9rGa3mcv6m/eZZdd0y62TiGvb6ZF66WUPgSnrZzWnLsAgG8UxEmC2JQ+LKWUjXwJOSo1iI0+vVF52idS0G3akG08EcfCOVE2OiUkBTc/eszobPLHqrb17W/vV7qQxJGRUEgx2YQ90uDEaJH+OdMhFIfVrhSPDc4WhWjKlr3JkmxKeLUMFfZdEE+MuJt+KDUdLTCPTTDGKBs5N4qN9UwymrfLMTZn5BQ3WbaPVERtETzsEuXPAax+uYLbpqiaIKPxcJRtvpa+VwuHMk0G7KCDDqoazj777l2fc3haSDzQoxOZLRID+0B6WrfK0GEvdWJMUdEKbcsfZyDzFANs3Ugk9wXSFM1q/QAJgIAZyJtvubmuhyFlBGDzLQpqESLHJ2sTpXHou+6yc/WKVs00jvr6668rJ75R2gGgAftlvJnsHSXd4WjjoQbTdXKtonkzJ5dddqmhE48/fuj8iDUcfvhRQyf99LgySj9PX+XEiU+FoXh81cMZMNfTNEhzXSGmuR9ZRh+tJKtmjBm+yxNI+H6BEmdrGLaDC4qrvl7ZWf7BhgP/gCtP+dUvh17GxM7PjbjjrKERnhcD3A9DN1qyN4GcNRD0EDFg7MDoso0iPuQgecaTMsJcPiLGVVddU73TNes1z7tLXHpfa7pOX2rW3jN34MBfBNBnm+1jdXgYXQGRz3dOwN9FnMPMzjNn7JQOZs3vP5z7ljUJHjn34lkMXgxKGZWCeZsSDnTDFC3I/2gAACAASURBVJU2FPrDiuQFiyD/r0YUxIsKk30OuTgmDHPn1ahCwwoYHYZzz8Dx9uJ71YvN8MZZDwzNDTf8PcSZUyvINGsRk/uG626s4O6IIw5LhD5rPQ9wJ+arc1WufwCzNgOmpSB7K86uNGkGAVXVsatO3LLunpH3uZLIO6QmsVO/8MXPxVF9Jd89dujioGKEBbCcDYMWhGNxI6o9mpFtkB/7jr0oUfbcy10ZosFRaeF5MIFf9bKHvEKIXoZaIhHZ65irSg3qXD+OTKYAlFINtEiw7hplZYIR55gjvfjiS8qZYzPLFCkP6UMHOYqxfL+eTL+r5OEcd8i71eEG0pW1/3qrhcCiPXxrxOZ1WLwCRA5ZdpZ/68+2dzHEm10LdyUBr+8VxELoDCqQ+Z1zzh8TwIZZn6BAPVcr0woRpbjxxusDx15RdkXf/IJxTM6GEofv/tslF5eMpn3Q+r+j6JOztGGQNoGz8pUzAKl6OgHysmk9MVf00gv+NLRhYPTVomGtLez8/LkE3LWH5Ayyry+GwUtgZa/Ifi619NLR8j0/ClonDg91GOwPdgNSo01IcInAZyj9mOxtyBbovORokww4eEQXTI+qrFJpROCaz3B2PCfnt8inRr8NArp+/u1NiYTAARrwfIQ+DMDYZpsvl+YxJ14ys7EJfqc7/bJ1FQBELCQ+Z5bB2ZzEc6Fs5KHelRRdcVkTN5jinya0l6pMFDBiNET+oLkXY9jOOfvsInVwchMef6Sgxn0zpQJUU8QguHEe9EdDiGnRgpYUcOB0eSDXJeq7p6Jp8KrB2haBcbWRwCU2jMzUIWD8CTV7MIzwPaHOm0JCZelfMbrSbFJhjHFBP4mE6Ch2HFxdgaPUY4c5tscee9RCPPJoO6g2CVks9SQG44TUzMBcejNrUnwgIIsmE0D71mcJJmZEfvKTE8tIMvSiNmolHN5tgX+pP4lobomDFJlTpJGd+ZmHI+qWHRBg9zP3cHGGGsP1HR6akdWiksMoYHj66YkhMK2Yut+aVV+uWk3WSUYrGnVvggTv2SetLndHb9JcSfP4HHT3yvhVG0i+t7Mpf37yidVDeGTqP2BXsyTVo25Izfdz//O5ZA3bFhrgOXZH1lmIbYRZMxavBWp6MWxGz8F7/3bpJdWrKLIUQImqwd2VgYlCC37RUhIBhQRA+0TsHFnt8SANWHqIU54dMhe2a4f5beiCdgeO9aWgExwpmMkaCsAQpKi7cN5e/RD5bxElB/2r9GjecsttVVPy97JgDkEtXRZp/7oPWpruG3pBCAHaZt1feumFashWFjC30pqoN0IXSGRyfPbrEhxBImNENqWCJdLTijjVoVDX5H6q5y0Q4qvJ9rVXXJo6OyNVRKX8niCQ89h88y1rNmYzCPbJ1ENnBJ6+MtkHqU+OQFY2fxwHUs8M+dn7suOBI508BlXtmUrVySefHNWkhWuouizdUIFb4zi3DWOdHVB/uwnUmX3NyHI4/dUzATVTQbUXQ+K59Ci99QC2KU2MV4f5KvNOJmy99S2uvvqacaZY8ncPnXPuOQ3ytlcHGtoyJXCtoLn3Vn4+sqPW5cz0QT5UDjKZQ9UrM7Q5AVQN1Mh94yL0zMOghoMP/s7QF6M/bBSfslUFqbnuqtOpscWIOnfOOJ4Ep7ZwJAYNidfeR3bPefKe2bPW2pm0vsmaPOteA2Uz3TcH6t5H7l/r0ILShlT4PPuWkW4Ze2tzozpk771u5mV+BiWs/ul8pj38XNC/quHlczCQL7s8YvfJrvqeXz2iFGuuuXpxFOicIy0tEGWnRRdduOyessF1148d+tP//rn25KjY+5de+XdKX/MUSQnsuedeexYCcEkkZLfP4PJPZqbv1ddcHdGX71awotTBgSL9yABlas0uZZ5n7Ny304+/ScoF9itb+bX0QL8aWNbEGn6hGMIVOARhUnIJp0EtV02VXRQkURXyO6QIEf4gXbJML6gUO8oWebHb1TWQ4EJQ4xl09b0mI9sUuHwPFTr3edxxPwpi+FbxetSFe6DO7noeUCd2Y1T+u9nOUUWKHemcJ7vrjlsrIwVdibodVhNBesMqkk0XN7Y5tHkcnQj4vvvGV3/b3SGPqC8dcMCBFX1Y3JlSDwQxVoSjVysHpvRdc/EPpP5zXXqetEGAzygkVZE5C9FTbhfY8eduaGQ6DA7HILoHS2INWxRQokVxs7Lj0rgd1NJEMh4K2jYYQwQn2+tRM8hQhHfggQcVXPTtUMJFqqCM72fOI5jt82lENnbt5DAZx469NFHdkqkN3DO0+zd2K31H79EgjCXqIWAUY0FXHTfrd3cMBOMgS2F4OHIZgEBFdMjRT5sG9eMyeeHxNJu7RllmG5YeSD0Q2rZhZm4dGEwGCzYEr6p5qk9fmNalxQNjbbfNdlXTPTW1r7nCQpURWAuHuU8xEUGpR72GTZzD9LO0foyNITjiyGOGvrLj1oGxw6ZMzWTzz2ycdpqDKqjiELsh8Dw6Caf+W+0t9yxafTyOcmIUsES0t91+W9WKQS0MEFShkZwGVPesh+cyftwD1df7m9/8ugIv5AHrs1iyfczb2jellBWDA6LLXnMv9kLvZdWqBWa3h10bNrV77o3nfrc7YIebzN+B6QuGHtBh7f3IgjjOTJZK7EH/GYPTh9CvvfZa5Uj1QhajMRGzDHOkoy7oNr/PAV6Qmttcc89ZKIFakusjcmEgeO8d7Y7J/Qg0NZUj4/V6GKNQA8DzzImALJfZi88FfnJmOXGqRYcd9oNkqA9lqtJMgW1nqKB13uwhrN3pY9hAyp0ENHkCKnq6p4WlTVtVG9obCcammnJUNdhzpEoSRPyRmRhztVPZWsuY25Qn3++5W7MKsqru15x7DQOPU2DkZensRq+LtfdgJjcBCz9/5pnHkj2tVrqmWPlXx/Db29a1TUaS3Q0VusGozRw5SPxXpDXXZo+qMUI3rNVLCbz/GTEIQRFUYsYYR/V+PIAjDj+8zj/hDmfBmZQBVZ09+9x9CTpd/5xpudDW57M/muBD+aDX5Z3dKinEwT0fh6bGJmjhSHsZof+7P+tGpmks7wra8syLOJjPUcZxDS0QaTDllANikXW2p9gVQS5DDj0En7a6YuDvlE7eyPXVKLfYBGsuoFg6meCaa65Wo+7YCaQ0k0zsRY5ptjk+FkdyYuxdFKkMJ8i+pSjFbu4cOFud1ExSnIuvpITAhnqmF4bxa5+afPWZTBjiiP83+gLWU1ZIiOVLQRt23nnHOOx5K1tXwqPTLntGcCTXybnhtrgnTnh6mXF8hsDuC5EDXTJ90+df8OckX7c3lDDBPhva1jaBW7gzAovGmdF+1shYPnNkrXoQ1ZS9qq6FBCLW8Ju775Hsd5X890sV9ION9WT7fvuzzmWSoILZkQTzPZjDepw9o/48J7vjtpvLkXq4oDjY+FxRrZCB1mSMbCqbxgW7eGn8ZZddWi0NDJVJDZhdxx57VC2YiMEUAPBZM+BNW7JnMzYMzVfN2CSs4PUuGH26fVfLnNoBbOQLWSnDVYy1HJJH8pBoATMueptsZBmPOuQ/0hPp9xq8217qqYzioYceWpmFw6cX0HdxWgIImeaWESRYNVi+eYjeZ4QVGEGfHlbvPvvuWxFQ1Qvj+DmIw484vK7rhogYrB2nuFpqEL7fQXUAya1RZLIZRWw0Rx3U0QvMVzBG6brm8C8wesFirjLq4KrF08fJQCAJyITWXXe9qmEg0rwcR+XwgDLBLKBTbEtzBsGzDqfIyobyXYxO9fzVAcXGmynR/7gY4IOrl/fQ3B8Y96s77xBZut/VGp515m/LUdhU6uEt2GmEGBCbjdvaN5rA+/PPP5us+L44zJeKtn9P2JgG/NLM7DMmq55YGrcflmGS1esd1DRuJiaDOT6/d3+Ym4KLxbIGjfH9n4r8GbfpAwvaE6Wpi6mbA/Fwnq/9Qk5vpSjMqMkW2zmBnH1X+zsGkXjFR3LdZ511ZmDdi0vtxZ6renzWh6F0XWpXCE5qo86BZ2J6zJgxGeqb2rPDBjEwKYbhaXVfAgQNs7V/IRAE0gU6Kwd1AUVpPbDfOFJrMbK/0Pd7ZgYznHDiT+t3nquRY6Oqf1aUb4bkmPkXyH59MntjVATER1fNCcqCMIQcM0UMkmB2+eU/MbRNCGLup+pCg7MwRQym6TW/POUXpZSz81d3KuKJMgbx+6WWTFBHECIBL1ILVqd918oMsk+1opZFgMOhFV5tndV5W/bVR/o156Hvt6nNtPph2wMViOV5WH+Gd6WVli+y0+shB2n9UY6QATBi1vmppyfEWc5TqIkshR1o5aOmPy1AtDexxu1b6IByiT5yjONDD/1eSX++mr3BGLZRZhimGNsvFZHF9c6TMzfbrFTP9K//o342/3yjK0BhhGnblgGNM/QyhaW1kQRejNnhwEc60ZHZ56T9OALWnUQ6hGjkO3rbHgEUWbPEoYx2IGVBAFvouZDLUzcG5ZKK1CIFSTFcvJCArDN7QcBgk002LaTsT7G9zrWhFKDd2TPp55yzzysyJNKVkpuX/ffZz25ZEPdVV16deatfjPrZEkVoc9Y4rCNja2h3773XHlVXh97pV7cP1ep3SJCGELdoEgz8EOsAtds1WuDQzYL9CT/kPvkSyZc66zTRQ//CF74YUZj16rmNHXt9wcKCBbZZglbBSGxg802xyQOki38pXeRCAdoQjUoCsn4c7vQzUBpL73/OiCRo+223zzsENa1trwthCPK7xkCVB/L5dKF9nz0O8ve5xRHIPpjstlturB2NGWqiuAzGYRJpidiwXNUqe+qMZQVH/9WvTqm5pIsGPlxu2RUqWlYktxEw6DiBgp4GKj59A1mwawINMBIgJhDSnHOmRmPyQWlQymKnqHqE3wHZuA43adFlR48+OqFdX27C34FiRVjew3l49QKxzwMBMTSgMhEryNC1lXpLDBujcWnqM1+O9J12ie6I99xjz/qsb337WyFjPBNW68+qXuWzXRvnbXPtttsuJTxw1TVXBeLeJ60on6jDpxVlxmRXsvATMl3DZ9vUiBNnnfmH2khzzDlbOdinklEjL6y5xmph3a05tHTqkg7JTImSiN0zDDIhZC6HVuTnHkoZqQKN54ZOCnlGj+0880RQX00rNYCqv1WUHGWkapyeoaT46GT+LDVc4gjfjUrLlltsXnAI+Hq/b32rehUZr6bp25qku4Hw/Y0kE0gpouICBlkbIW3Zsr7h53OAC0qOZdG4jXDD8XamrnF1atLT5hCdkkxfgGJN3RNY3PWtmQzQq6BDVHXi0xizA5aodomJGf8kEPJ7nuvmW2xR0aTswvt71OhzOC9qS8f86NjKdvWSkgej59rreKOSmZVxzL4H14F33Mdnk80wom9maH2bUDRU9Tov+wVU2YNF70ei8mfoBgPPod0VSMqeGx2jzGiMjJhdP8TmZz/7edpSTq5zQU9YYFuzZHOmtgnkOmXO37Mh3cnalSJ+kB5hQQvizWxZU9ft/SbE0NktKba6yubsRtWc2FFVAycP6DNN/hh77XVlVO03JBL9mIzSVVHvgYx4FWyNdFHEGoZde0ZzpJOmMI1wpjKGpmHbnCxnNxLSbvyJ9ney2Kpr5v4WSJApE211RpBrCG5Zi84Opkg1S7JPetsCdvC7wIbTIBRAZYe03/sp/0AgBHg77bTj0P5pEzMfUynJ72l9k2EVozn34sywT1pgfP7TsSlKXJjZjQXapklJDvBABCg9e+zkGUGrxKHWpN7fnWrtlNxvy85bcAepE5jIRJuB9rtgUdCt73QNAn/L4LnKECU8MjNoWpGvUlIhu6rsxjY1aDgkK9C2Vp38W4Kw4EKLZH0mRIlp3RBDN0iZ7fqoM11Wtu2hTNwBtzoHy0W5a8cdd6xnBakjB4sspAxCjk+pDTKm9HXgQQfXc9pn770KqeBY7wmigYH/xYjXcEKfXHW10iB+J/Cp5/S7s35XA9qdC8GHrhBnU4BfnJXwNqApWMz2jHs98qijAuE3zsVrGMyCrNg2AZG1E3ywb+5VkNcEQtrO7/tfBswvyewFhz8KYXTW1MwbQpJyTdYXEimQxDdg33tCB3HQqdA/zXOt1jyIAEd6y03Xf1gQw+ALagZd1Cg8VIosWhtEOU1MuP1ze2C734appR66TdisSy+1bAlea82YKdGdqQ0a2suLJzvqmLOb8l3GiP06DFmMLDKBiy6yeLFRfXbpUubG/FldlNHqm5TBpoohImM01UvciJu12Ww0rRe9r60rlHCiIDUP3As70Ca06URn10SpCaT2lR2/Ug9EUEHpZf/MTF00JBj1u4vSAI0AIlJpi8sxhCodx7ZjDilpPrNJ70zU99VMp+BgGU/XrkZm+gft4bkHsmjHH3d8Re0MZpsm8GKysZBuUtuT1cporBvyjHuSeZtO4Dno+ZJpuh9Zw9VROpFR2ETqkTU7Mr9b8nsi/0qUet/UFFWjPvecsyry/sY396hMa/YY6iuuvDLj7faoSJITJSSuzqBXlNN3yHtdp7V1vJ+652OVmd8WCTIRvAM9YcLjBYtZJ3uEElWrm6UnOYbL+spCBBDbbLtdDZ+Wwet95NREraCfImYh9gygPbJjvtfnqke+9vrLJTXoRQCd01khpYkuIdhJPQyrfajGd376pUXNPoexcbiwiAVpnlUxavOa7WOzV03Oc2G8Vl11pVIWkkkJvpA+vKqHrGCm1t7Ssw8HuQePHR0hlOFMLbv0cpVp96zMmoLGBDLHhfgFhmSwZB+cJahV6WC3iAE8koCNeouJMIQ/DvrOd6tVZ8agQAJG5wH6ou8Pf6CGrZuckW9TkyIPKPg87bTf1PlZ/1PrBU06rpAk6jGGar/zzsvZXzNVIOFn9iCJvW78a2zhoF2h+jzzsj8wLv3cNSOQcI4MoVd3oN15tnUS0aujtvYcyJM9pW2lObhWC6/6c84+B9QJc+9GFUhJae6MB2TUNd3L+MkoaicpsZb8vZIQ/WtCKeqFSgxq8gI3r5ozmgPiGTlvshAiF2BI8GZJ8+XamhNs94bh20tPzba1mmeVwGRB+cd3d3vTz0wrj0TFaMA0h4b4bgITPrs508ZCVetEotSWA3ESKN0REQ41QIbbEHHmWAZlzdz7s88RpWnzOp1f3QKFjoCyYz+cn69+dcdoZW9Vn+McGSfGnjsz96WVUNsY0RH20UCOc1Oz3m+/A8rZcKZsz3XpDkBcEnQdmrLCeSlh7BjYd/311i/tXuL1nw0RaefYRSQ8g68N/3CWVolAiBF4h0X+Uk8vm77gAgtVguJMCAIgVIssEjSquAPEVt4ZOjyCM39Nu9roqAsZPODlGUBPlSX0xXqBldkswbd9VMPTPb38v16nFzD5DgNaXg26pzDBPiETdSlGz9XaVlCcZz5bpujIfHuw3M/5JEcqI+0/5KAwLsk6IYKo44H1FNZBV69Egm2mTH6/7u/XDv3ouGMrAtkmjFUbGSPTlPoiTeQLRQ6tBoBY0QTDu7GxOX7/hz9U5rJlFrzL0DmgahLv5t8dsuntAbDpUonJomKn1mDvQSO4TdQ1c02tkFW7Btkp4+TFyPos8Okhhxxc7EtQFYOlj40j3nnnnesQuN8L0+Zy1DFH19gi+rKnBJq9OMzeJZdasiKf3peob1X7DL1NEQsS0RNpVRgd9uPKK6dnK44XBMeAiMgEKAwC8WRN/8Z/FUMs16g+N/Sf9I3lALyVjY1A0+pTeuxmrgMi26q+3n89VzDsNXGi1t/mYRir9aA3Ofe2qTJkH9TGvffeW8P43SttBjsVe/HW1CTByIz3p2JU9dJOG0fHKfdZjBU0xIl2UoxN5jm7D47UemvObgo3TUpOr5/7fSKQsYZ2+4fz78PiGT7EmW+mHw3z999Zt77p9YwKJEB71bQ+OAgUUBhum9lzfTkyfdWG4Dln7yI1MMD2hgPRxckbspGxTqmvc1QTM6LNd9R4MFhc1TpMrcg15vemyPeAfe1X7TcIV9ocngkUOPfc8xakq8XCGiAdtFdb7GY8mzBB72OkTPRshjhYPyOetCF0kQe/Y1+6bszto446phjD/uyzHWL7WIaIv3B/Silq8R8LxIZchjOwRHqy29SW6atmuWhIfP8TdRYzdDlAPAfXY87j1HH89tsPw0S1DrtF1/inUbO6J0Qj4/UIZyyXwfAISkoiHJJ92QYveB7DEnL2dH9m1rj3jfb5k5aiUKN8RofB+mSUYlxmn4IgC1nJfimvm99RN+savs49A+Yzu8404/ZhnELPcjkd5QWZxIyBKGkN+yC1T9moUVj7BmV5NUQaNm2qiDr4DLCvlwDVs2r1bd81ZWW7NWgiz6wHDe5FsGLv+H29y31gu57hCqiEgwOS0SBunxR8uibn3/nG/u1n4ZWUQnoZS2bUYPR3SloTR2KmoEjWh40rcl5KC2y1ViRZ3fQJorC4n4rKkX1vTWXw1QKo5SbfKVh/N+dz3WSjeniLCZ+1xVz9Xchq7yTY9Dz8nsEWpCNPOeWU2PSVSu3HOaDWJrgw5YquszU1i3WfffcvYqNaqaThqrTc6Dv97JZbliOFLt4YNSK9uQZ6P/DgfZEB3SMwbgT0c78zptXNHpZlus7PpTY6R9jnkBMdGpjvZ515VgaHHDMYvZa2x9Jkn7nKg1A6qmxshuf48sspAyVyBC935nhNK8pztk4bhBS7V0hU/NfkHyE3S7YzzO8BsbACtgFi6VlAQEaVCE7zYT3bVaGo0kUCt4J228ZMvUqhOrABrVgRiZaXKeLsePkOkX3w7oeBA+/M4v+2RmPRRsW+7Q5YxsYwMBQ2pM0CEuxGRqZp419+2ZV5WDcl+tk0Exw2brUS9GYbUaE8CyxK92KAQDGMO1zfYfZ9NpvDY1OBFnsUIbqurCWbQqRlYTxQcKLBrwYzk9wSQfr5jzMWzHsQpqjicMKnRRnl9NNOG/pO5LGornzr298ejMeKlmMMSp8qA3oCMXqANg6R8H88HVGCPFiM05liwNdONjFrnJgInPPUx+fVo2CyZJU5OHlljyerDMshavP35m5kB83jb7wa43B/ZjCeE5bqxBC+VqjNpw1HjUcdsNYw/2sRMJjjI/WeceNvy2DblaJMcmLBjIS3N0jvr+btFVdcPr180erNdXbpRDCXbLIZAFF2YK3BiDCwB3a09if75sawfBk6fV6M+bP5O32t9HS3TrC1YEZcGU/lc7xfj9nSSy2dv58zBAlOlN4yIfmPVs24AqdB+1KvqdlLXU0EcmKepX15X9ZDo7k2HWvmvu0njlT0rp5hn1CcOvP3Z5WxMKdRwOG/63DkfwyUjBbZgjyedRDQfT5G4YUI4btuPcM+G0LgkMp0eyDaA0XRcG8Jkn0jzpBJ01akTxHJDgmkR7f2m/135u9/n+d6diTdVqg6M/IDdEHwhO1YCEyc0mphuf4ksPzxIaetsson632IE0XgyPqCOrdN1vHxBInvZW+qndGnY6g+mvooKcXvhL2KYf39Qw8p9a1/pQ1g5ayhnkTsVqgQowMe58TUuXs/+yRHp29RRsZzDIgXSjkN7hwWweh1Ug61Z1zdHvQ1wKbsYxDLuXHMgwC89FcdjPpMtqSRmRppp43rqqb53Du7Yc+qj1Oh0U6HA8AJXBomOdIUIpu5pRy0Pm9ZYa+D9bKB0ZLF3Ui91vcIzuwh2a33ep/eW3tEdudcy66clRJmyPWxe+5vUs9kzmEf4IHPobVDdlzBWN7XywuFZOST3slng1FxIqo/Ng7DGfPiVFsPdd6Xn3EkLbHIn3NuBaH+cT2uTeCN/Ef+btVVVxlaKaIehHc+GqlKGZq+0hrmHdhzmqmnTYZ3fw2voI38mTBztRetGDY8LsipEagR4H4vtnH0mDHFPTn/t5kIFjiXTXAOBGrIapAjfcLgcMEsYQ3owzGBVf981tlDn00vMb1lpTn7ZMvY0JWSgLABjwfSpae8+BJLFiHyqMC7zuvMSeZmC1pFwMMEmNdfe6smRL2aLN3afeMbe9Sz+1FmDH8006iqrh10jtOGBhwRXsvCEcsRSH4kaklmKs8d5AVLWKDlM7TcuOayn3D1erWEou9hdmkSUfbG68d+KOqtsVgxjtooGBNC0GoJoKjeasCA2EyM8CWXXFp05kUWXaT0M89Js67sbrP0OPocWRS2k4uBdZdiRYylh28z+J7//dMFQ+uts97QLl/7aj3Ud99qUn4Ohfd0Bhtj2CaLxNhls6hNgV4Ytt4o6ztBimjtpa2YmqGfNVWKoZCLMo0+dG837gH3TevhkkIDh5mE8GRqaO7xwDiV6667oUaLmYj+3e9+r+6p10R68NHYwWn/yEZfJzU9g5s9lHnTftDIPlMVXOYhyoo7ycSa+6fVS8IsDFzUI+4+zaSNVWpwpuyAissdt98d+vfdUaBauwbs3hCVJSSjmgJf9aQ2HLrkxiqaHipI+aEQM2yo0047pZwGYfJFFhlTilWLR/GJBKDgCSTUIaliNpfARSNQNEZmMtN8PoFrG9HzfDD1FXUWmpVjxixQWcBfM6ln2+22Cmngy8VcbYe6GVf3LHIvaC9ORw8eFja4voZfJxjrMGlXFekGyWEH14Gym/xXE/OWjRZcS8WnDFhgu7fNa404/aB95BepC1599bX1jBpSYmD18ExKjsZ3M4xIYV5bfXmryvAevP/e+pyuZ4xoIgvpDoHD8az6/pgE8Q4O4Z9SFtA3bU05RPqn3dB6zhjPhou7Lm0fLwU6VnZos1FD3IhymGBNBA7KP/roH9Z+bhKb7xYEa40EqUhSO6RVoY3MCkHG/NHcm0BF9u/sYXYzxlq/BMIlnpJAxRSRcWFt2/M8l/uBHGnd6o6tHJ22hcpOs0dK6k4a1uTwWo9wc7KtftXgz/5Mu8Zql4lrn9cg4uZMW3br/UVOGgSGHSZuvYMt8yPV2GaLtqy3Av58lsD7mYefGVpx3ZWGvnPQARXo6T0HIWrrXU4MoAAAIABJREFUeOyxR4rQprzirJAMFMwJXJSCMLrbPQZdyR5lL7RFTZeM1/0gv3GEYHVqRvZkr336mb1goMJrrxjJB+1o01tKajFOnoMjmkKSrwnLtOCykfj0FadDIUpdBfvm98kBThuH+NEEbjSsoVX2OvsssXBOsdddL8fgvDXYOvX+2GBtRspkBDfWjpQgvki13eQ7tQzp/z/ggIMqIOtTTdTiSaluHe4I4Q9CIODex8JRQU4yuKOmySQzP/kXJ6dT4aIK+r6S0pAymeehJ5dtZJ86i5v4v+vmgBEEzTQVaLomIjNzpeQkcLszhFZqYQuMWai6AI4+5tj6LOdi1nxGMZQD6c4ap0rS1HSbr+f3IaOQny+HPAdd892CnKcffmjoGxGX2TJlOPeJxOUzsN/tCwG0NSsuSZVVWsJTZ7ng/UGbVNuoeS6xs9l3hX+YR1rq9okURCP6D0W0iy22ZMEWb8TBdsqzDcHYyioNzDXDdJksMMboDxMtUM7/1rf2K9kveLj3+qcpVyAWgPtabYyBuDOKSOqC+0bsYMUM+WYk9SOK5tT6Wh0rRepsDGSOYssykNQ3EqX1ae4Mk4cvjrvqymsrcyOvxlBwfhWFZmqHA8yIfDkSeL7D55lwoV4rQ9EKIJtl7Pfee59SPfne975XC3t8GokZ+QZVNUWNTqLosB5IbkwiNFqQ6sqfXHXlguOsBcKNSQ0luJDPbwe6ze4U9aKRd2atf3PwyDmarsmAYc89FkWjJQKhkAazBtpuqD15PgyL3ytHWvWnFv2692ezWa39TzPI2UDy70VB6LEMSAaDLZCawx7f+GZF2iODhNo19svAenWHDtYAKWl/wrT09zat/rqPmWGZ66IDu2uCo43SW4t1V8FNSB5NZ9ZzbHVIO3CqPGNEJL1ylSkyQqZ7qGsO9sDIa0FKezRO1L4Qddo/slEEr04Maq0X2TfRaBbtC14MsD7zt2cOvZmsUwRMLL8Nfm+BgjqLdQMXzZ7WofuzTzzPfffZu5zBE088VvCT90AQRsVgdLLBW2+0tgiBSmfzNcffHLqDTEVJ64GxV4yirKgfVLwCBCsCCZza0wm8ZOYcIgLOwgstWuO72gD1jwztEqjNnhK09F43fAMi+khryCFbbL5ZIwkGPZElgnXdL8Lb2AwNMDZR1M0ZMGBrpJ/5hgyOvjGB2YthUqP3e3FI4LzWRtVINH3eY5vUkYhelpT7tE7lEKte2HqWG6+iOWQve5KTbZ/TsrX+dwLegu79b1CWQM0o1zr4s/eUax04zVIJqn7T9j3lwPO5GK3PxuF8JYprW4Qotuuuu1UJRB1O9mN/HBYdavv5D7//Q+p/qySIfL3qfOrPJbSevalE1SHYPuHG/jJ02/7zXves57Rfk/u2tm0GatOL9Xd9kHjLcBpnoZORTJRpyUMTJVBi8Czk4vPEHj/y8CPlPH3XwwlcBcme/bNR1xJ7sAGIO8RIIHug+PfYqXwJDsC/UooQbFFuWyx9pJ+O8I6Xc+zaICSC8v3227/KGsoXN95wS+qpXxzaKaMlkSZ9N6QMyuKezEL17KBQb+SMy5g9J0PKITUCbc+z203r0gmis882R4KzZ2J7f1OCNwJe7HOBnVFsDz70QL0XxGuIBxvzne98p9jKhgVwhPa6fl/ExtHzjwnCdnCROYndQClPSD/27bfdngB2yYyBfKrs7Uk/+0mtFV6HoIlzd3YETp4PToefIRchRnGgPbEYtkOemz3ZznftScpGohcFdHRwnh/c+clPrl7Ql8ZyEQsDI5pCrpBJXXXVtWWY1Wu0ZhwbJqRDcVBYXiTpHo8D4NwwwQhNm1/35luvT5K3arqmb6eh+vc13/Fru3wtMGgis4gtIFOoCfo8N1VNyIPMzIg3tdSJYedhrMkSNIxzzCILjhBR6OVIkMleTSfAZjQlxoNETlh//XUrO3YfivgG2zJKon71PK/ddtu9IC2zHm+8EZxxRv2uxbahqh6Sf1ybQ9vo2B+EAXvg0J3JHC9I7xOMfoklFqtaFoUW9UiSdGrQXcS5ZzEMpw0KihYgyCAx7EBt111/U0G46NogFbR/clvm/dlojeBgukXLFif1auZn1uiVRMWHH3Ho0Nqrr1GzN6+/4fqqB1jjPfeMvnCa3fWkcXICmMoYB/dX/i67pZMr/B0mKnavWaNPBca2XxA0vAzw3n677UpAu0HrCv6cVluzLu7dyEdpws7e8BJNu3+C6hh+nGnLRsF4LdMT+YI8Zfpq0+qijATN5h50VTCRFyeqfqc1C9py5JFH1UQH9erX8+c+ocWaYeqCmywiSG8m81djBDbZdKNk/uuVbJi2r2WiOepMvJrvn3bAuvVd76aO07MvBqS/eh3dOSAQz2iR7eMEwYNg76qLx1zKRv8apSW10DcChxGQR8yCxqglg9UgD5dm+pJBys6h8omg0ZrKDhx+dVzB2+f+J3OFYzhK2N9s0ILoQzaKU9UjSu5NM/oz0Vp2tn9w+PeLUHdPslGsVVOaoBPYx/7dhPlTp6RnnT/bE2renBjZRS9/7zl4dX3tvn+cmzZfskFlvc2tRBPybO3fem9n+faa8//JRntW6/2VkQ6a+dmM+t78GayrnQVjd8c4AfvlqquuKCdTGWcyntp7qaHSkTUMAwzsXG6yyUZVOiFisMNXtqvAjkMUDNnH2iyoRT0a2JvtWTBwPYcmI7Xf2ZQWdLTywgzJYtXYvPoalPh+Psefa6BC7Iz19fnWo6DD3Mf4cfdVmcSZhFAYd4h05b2CTlnm1mlxGhNHdt5556Xz4IoMlphvIGKTCVV1FjBVaVk/VwjGhp/+VKENG2fKF/Ic+1icltgRGswSjd8nsLj11tuicrdh+BRfLZnJV5Lx9QH1ni0b7Dpdc0HKyXAQRau2GBvNmb+SNRVQ1L3mvNf8WglVYHzPfOZwPfpeEZzI9gXKpW+spSX7l1DFfBHTwc7dO0Et0RXXTymOg65OjcC/e4ZrsUOetYRBK6UAhljHmb89Iz32S8YnPJEe4sOSiCxaREGBhnXUBz5f0FfniX8TWDq3/KH740h70oT74fo7X+Qjmb7lVa02lI1knVhJNtP1cRqyuDXXWqdghQm5cAcULNkiR/NCp69J52jzHNBySe89SL+7a4TdZXYiJRJqXgriMizkk34I1bgwJY0p48C3jfC2RuG33mi6hkZu2YztkI2ICgJ5uFHEJ3VOxCDFZi0QMg8vhKN/Jap+MT+/NREJsfq38l7T7DlLGYzJKlSEkIFOS2M6+bbPf/6LJeJuo+ye6Qa+V/Z20UUXlVwY+LecwsCRtk3Q5i461E39ZtOa+wkWVsPTZ2v8114R9Fc/OCNsZ8Zn/hgrD7LNbWwjhmwM0bIH/XLuz4GXiVtz9T+ZvLqFTTD/fCT02mBgzqCZkfb/wUheL4WYYHrOdw8+YGj1ZB0nZ4bi5VfmsEW5hBHeb/9vJRpbsA6CjT+y/60brNpM+ac7s6eyhtemd7UbUYy/RRLhUsDiDLHyZIdQi8pwB5l2yysGUTjo1V1FH1YrVRty/G6NGesM10YyaxG7580Aaieq2ZTJkMD2IPNVVlm55N4EIJNqozFCb7/xTrGWOYmbYyiJaZQSUeBOGXXLqpo4gOjaiyCC0VPleHIgDbmXwYOnns5+WS4kjBrkEBjOxVlnB76pBrW90Net18X8jCM9L+jN10KwOOt3p1cN1PmYJ8QljEz1/mMS4CilYCpjW3Jgrawyamj/bx9Q/Yy/OfU3IYuNLwUjwW37DjBnEIxktcVwTwq3QqAt0H8TUsFWbJNvKhjNutJgPTvqZAIgBlHdaMedti9ZQDUwpZG77r6zHJ/1Uedq0zPMzQzaU/XhhshUjWhACJt8cuvYQvSWdf63ek8vY3BMnUEpK0WU6qSQGqU1gHVlpm1tO9Q7vL49062/0yc7eJ9rEaS8mMBQqclc5IeS3SiNcIL2MXKLgOfuQIeynTFptVKqmGeeucpW3Zt2IvDuJilZ6e2dcqppimzW0RmCNTJShEyG1335GSdXYiepiesbZuTZVQ4XvGqPN9vBQMexlmDFu7UWjTD1ysCxpgYf2/vC8y+2iUX5fLbkxZxnLTEIZNcHPSADuMP2X6mAaGJqvsiH55xzXiUyRWrEqM6zUB/EVqbfLVBYKOpGG6Tv0xxVZ2ya7HkwMnLa7EHolEtKXS7B8SypPb6UtrzHJjxSe50v8JJ8Wc8qJ8TuCdi9QM/TJJOzDcou5QuGYfvWAvVhCE4FwWPk5++bQ27CF87kDPqB40T5h2JO58zNm1r2FWm3+e3vzixyofYV+/rB++6I1vRuFaDaE08nsIeCam2T6P0ySOJsgafXW3f9Ci7FFljOMlbnhV+T1HghgTXmduqqCbJGJhSus8mitt5Vf0+Kss4WPsq9d9/xIbZlV/t5KAopMrw112yTETxQDsoGKRgi/4jOzEM0828qm2zmUKKj12izkmfbNi0NFspNSZVFFAy3Hi4LUxsjPU//jsyaz3oiWRdhY4YLuUNE3g1Rq5MM9+yYN8e4qCc48G5KvVSGayOKDj1w30ND8rnnXoyznDWN/GnMTqTocIF2taNUxpxN/ocYFdJZm222RfVY6n38eqaQgPb2SrPxiSeeOMiuWtTYs55+sBiNYolm0/ve7x1yYBzyPyvDACeNv9fIosnC/v2fgQHKnNNsVtNDMAddM5agw+hQaD8ybFdkdkaEIkDjiuB33z1+aPToeYo0wOgyilW/rjpOc/DIQBzik3F4NhNnuU6GO/8yfVsgLM9nnnnnSu3vy0VhV3er5u1i9xX0nwPAibVZgW2jOxBo+q9nYsQ9xSYcFcOgr9VUBxn/jNPPEgO+XNVMqs6gFpQDjPVdzmVgeHtwZOMWyYYxGQghFEFoUCurnZ0N2gT7Ax/GKBVEHoTEvqRcI9vUFoIE4Ll0hrfTCt6TXTIIP4z8IcnDxdKSBP5Sj+2EGEGQGxWd0/ecJYbKkOnZY0BkujMlMjUdAsS+8oorF/NQ9k7iQE1R1NzhyQ75D5NLWmDj0P8q6//Tk34+tFEMO8ZgTQmK45o133N+FGGoEwkKGCVkNvtGOWDJ1MH32nvfkqj82yV/K0iuGLS53zbIOEPfE61DP97PvRLwsCbLpeZXQZ52MqIG9d/pwc3vnXP2uUPXjL0mweOClbXpwyZAr2VGC8AfzvpDrdOcIUVRqeI07MGaXhQkR8DYHGATbbG3m4NowvDNKbYAzLO3xmxMG6HVft7gzSYE04OPSedpkJUWpDZIPRuLt0G3Xh1GrfKKvZvvbvXRpon61ANPD62x0RoVgP7lIhJ4hF3a3EvnRl+24APCIGsy9OGFwKtGhtVsUVljjCSuw0fjGOaPMeYQsfKRxiAAyFqCLG1CyhrVvjIoSzwfco9BGIxv1dZHj6k1avbDno72d9axnTv7z+zVjA5MQG19OYuXAnFKEjgIZbfRozPtJ8/6gYcfKI3YVdKOsnkC9/kSlIOD8R2IMfw6JYLHw/an9ez7Qfps32yxg9uF+Kc2TJBGwiFTZHMhX2BVmuftmQ2EULLX9OfKlK2TILOVtFoQ1aHp/jwaazmQfTgDjb/S1Jr6ufd37Guf0+rM2BeV6ZXWbxIlCcEgMPJ+2Tf/A0U7tnTB/1R7/ZXYnnU32zQo6P5DCyeYx9mZkPtw37LvM5KN/uK4Hw/NFWLRsUcdWegVYQhnuH1f+BM579aoZ57D91GbrJmhwX7rjtQaCNZkpK7/3vH3tjFq1beVQ+LD1ZCw+BaPJqjNwiC2dNyMOJnOh1XbgVVrqn0jcJvNd845OXxZkBIMz/QUU9jviqwTHL3o/PnijjXbvKAXWYX6EEyb8dln770Lnn2nBt4O61EOwzltgWuavYJ/NhzWmwcmMwW/aRfh+LF4sYqJN4AH5kjda9H0JmEgq3UNTdYMg/rwWXEwDNZmm36malKijp12+mptOBks7N4Gb8agQS/Drz6ctkVfAoSVV1m+Zh0+nLqG63g0MIT7oXJEIFzWoCZp3dXXsM/mTi3GJlKfdi+yUmOQfv6LXxWs6+CrW6l5Vd2liD/NMFSrSg6oeqiDiTGLjbjffvuWgPMF551fLN8llzToeqGCuxwaRrUbMmSFVrph5JrMGzZjdzhIHePuvTvR/SN1/wIBkBnigCK9QAiZptiCccwaF11LjQwbRKZ9k8p+sYs9V5u/RN9NdxmQIzrByD5uwwoSCea+H06Qx8D4+ycyVWKd1IrnB9W+msHTgUI7SatF4elhjgG8KdnoEYcfUXCuOpDImU6zqNTn23euj0OfPwMUwLovpqVkw0zXWSryZJNl70NSjBk0TcTelpEhdHQaPGdW7Rt5yVI7bNklxsBlygeGozOwAkZrBVZyncdFrOMvEar/5CdXrADB9ai1y5K2iMDEUksuE7Wj40sKk7GBTKjzeDbqpvaLdi4IEiOySfoAF82ZdE0QjRo0EP/jeuizqsc++limJ03X+k69R6+qeuC30zOtNufPBgfQRx6XLFjJwLkqofrBvumTdTiPaoMpGL71T/ZMpKMZbXh0UytzD37ueXc1pN4W04Y7MzPt361/ve0lJKLuSEdmpA0Obo6Zw2XLngwJZbXYIGImdJ/Vj035sRbV1iIAGCAeamde9j9HQmZURgpFM/hckIXtv0b6UH3v/AlyZEh6IzlQbE8Oo99XK/mEPJn7NWRDADpmzOjK+Do8+k7KWoJuAYrSEPTOeYCgQCgE+YJHPZcts9d/KkMLbFktI6mFJoNzltU9sVunTibFwF+QwOyQw46ochZ72siGDwfWXDJ1xgPK8YM/9acLvF57/ZWh2269veqL9i6BGp9jjxXEmn/YcPdYazwIdLoN7I51EopVPfbRAihiaWxzkSZbz3ChNjbjCJSx29N64j6bv6lnXTugfldw5nNIXt6Wdf/1qadVIP218AUoJ0E4J4bT4pdcu/U5++xzhs446RdDx/78Z0NLB94luPDxPLupw0oGl7f+5VYK6q8eyP+3jW+BG7tVQUaCU2cJr+Lmm28Z+sUvfzE02f33jfuwRmLFOcpkpLfgOr2KXVC+6N+J4hkC3rgdhqniPM8tFhfHxOjD8UXLm2QQq5l4V151eUUOIjzGVWQKsqKuI7sw37GPEAI9HBGGrDqU+lc7ZG1RvIgDGCA9eS6+aiyD7EWKjhGrWCwzJaYv8hRFP5OZhjJXfataQ2SmaNVbRvpKRCgiQaaQkTJcW2z+2cps1Z22zRBvzuFL0f9EPKpnXMFwO+A9U24bq0XJbSZegpF85y6RXls1rUF/SL+sRmcb9sEHHm6N5WDM6hXMYYkzlUU2YgJW5hxpo9mioEoH6pLUxOqgF+vCQ2xyWBWpxSnY1NZTZmus17+SLW2x+RaBpneteYNXRHzAJBr1uDXXXn1o67BQGYgOQ5aCTLFn2+b1PHwHo1J9ZVl39/NyxgoxqM+nDeSJx5+s6JlhVf/ZaOMNU5fL6LY4vCKQqPHkf2oHnPLIyM51917PG8IQtZE/sUwgU3qnIRjZW9qDKqpNfcKzfT0qRJSbtCxwVPaZ2vs666zTjPpgnFIJUICO8iwcOjVcClzjAtWZN4t9CSp8O47RfvR+92zvMzgFww5INmAzBIYpBEeB1S6L2AYjt1FatWSYb2vgH9SSZXwyoi5/598OGqj7mpyLCy/6a4lMKF9oYofSIOktlvq5HuhjwkZcaOEFG0qR5zdzJi75DDXgT2/46dS9xlRApD1Hi5aM3NQke0SUrdQiymZM1kpt+rNxvhjUVkLLUinm5B8iBA898nAEKa7Ic3yhSjkc01T2Xj4TxLp2kKhVQ7wZO/a6POPMgEzN6tpItDknoHcs4AbLpac7gWUFSZMU/5qKT2ftthpx+mnz2RWw2BdlhFt7jHvszF/XKpvhCAc+tDnTMriDeugIGPm/HKlnHvUtSl7uR6fAU9FTXipa4Bt8aoPYqLHV1oaJ2WBoM24T2Oe61aDtMb9X4/TyHVpJdsl0pWWTtWkHPPN3ZxUitE3YqwssiNSlV/PdypDApW+W4HzqnIO+dkhIjVvLhY+K1CQn+WSGTrA3gk5OUpkBnKu00wKPKnZURoWBusACTUHo5hD3/L1yBOlOtg3c6hnoiybN99VddypSn8SkEdw+jBbuhUMn/ZwsabgHgVvB37vttmuNg5MRmqs8fdAWc5bVdyUg84QD4gywqRIH9+nFubJPHY4diRp1gmIlW4N/ZPL2mv1pXXriM+k9vf4tmBl4sJFO2HNv6IR1ic0fJC6CNYkQZ1pBcOxLjeSLL2koCQdNyD7tbgmmtL/gJWjFUfP0fLTJNEfa0JyC2X2+YHjA0i73PchG+3X5Wdv7aqRNYc2a6FY5MZrD5UgbLDZVUeMxqAgEi7g5ki7OzJEWGUTWM4gUtMHclhok50lT9KlEBL4YRi36Vz/4Vwxg75HkvLojas7og4ruGWCKJPr1vr7b1+v9FsbPQTIiou5Iaf5yVs0ATlOajSa+2EA2qik2Fb2Ad3I9TX7vqcqAZUt+/s1v7l6ajR4wZ0DqUP1zyy3/pw7Wq6+9HKEJtdSVo7z02ZqmQqpQZgTO8upGoN1PY8qWokkW2OYFoxwYohID+ufop6qVyIrh/J3daCZjyVmBugZRHDo68lWv5xhiLuvuSik2pvtkdLqRodBDZYkCCIH9bbf78tDVV149dGr6YMH0ggQD2z+fLHnWRHF9BFozUPoL+8YlAq0G3ed3trrBk5HhI8XndW9aWxxC0OO8885dTnfT6HhSL+GUBWMFBVfS7pjkPxjXwTMDuwmSwMyvJxDQHO7+9TZ2nVakg2ZU6VgaCvxMMoOHax+0UVKvlMyZRm0HyZf5/E7usS+QE84883dZgzNqhBbiTpM7TEaVYca9tiwYwfxbcgkZ4mxtXGDWZL311qlaCYF3xBJrgM3oO7BpSWfKGDiN6o1LwOAgQlscfP2iAjTRvc9B6jE940sR93B+1OgXDDpAjxet/+NZv7czLFzgYS8xRtZ4ych1LrjAwvXee8Kox1wU5c8dwoVaMZIXCTuSgxMSMO60047pDd6gOAFlBBM9F9Sa/xbAgKEuv+LyEml4IYEGqLKVbLLeWR97Td/zwnHsd+csKc88EsFzDrt6vWkLU6qqGnPLwsHodR7ME9fmMjCObeJQlL1i4DlpELT5nE1PtkFrDXUY1EVHBKndmXYnWh+ZHzZJwuFgtn5cWYzz0PazM6i+7Kw7DxzDjSHYMXyCefZFFlhdALFJMlB7ki3Am7D+hCm0Ro2JsMqtSSwwZccE/Vg5NsH5HJtMUQZH7QdjtTPFnd+eaZsKpDbqnpEjZfkc4kKBGrVsyEiVaLxfLdZ1XnPN34sfov6KBUt4RNAq0OVIBGKeFZa8wM6z+1Y0wEHQ0IzhGt+UFcCfFzTqwZATl8tAjv3T+oET8kB6RAk7cOr2ZmdhW7uq+Qmu2Nk83+bQ2qvBua2NqQfiIx2o99Q5zDNnv5zNkQpQZRE80HJSjZnd/FWDg/skqbJteXV0ozO5/ZS9FMQgknLWEhF7UpLXhUAQvgQzvzn110UM+lQkLzsZTYBgX5YYTvgJ9id0yrPuLPx+ncPOfNh+WZvSoK/ug6mLP3PqaacG2h1/T4KwZsx5e31s4LYnn2wsRXR5EABpKBdesySzcUUbYMwrIytXQ2kTKZl4IkIV/YLrkGzQlNWDRL0K9pii/wy5iBKJDeOQGazq5tXW9g20tOYaa9cD64QV19TqKpxVq7l5yVb9NxKP34WjFyU8zqNHF+q290RPtoTI05jPCH09kRk41O/758Ishg1GpxUD87WIHuzwlZ1SZ1o+Eym+lBrVXiVF5dDZ2O6/q7F0GKtFMK1w7toFFw7ZzjFsjz2OgftEOTDMSyohMtJywHm/Ted3bUABhJ5CG0YW4qHbkK6T428Dik1ciaJPDoMAAuROZGK3NO3PEZjpzNRV9RqCdvwdNZOtvrx11eNKNrFaENoGrow6zsWfpxrVWHe9noFkIishQ6jniizZ+GSlNtMKEXAwqWGB6HcSuC7oTc9hol/X2CLj1utnTWx+hpzROCeQi/oMxSBEIc/MSz9pjShKvc9zVSp4KQFWV6uaLYPN1WRBOXo734uiSIOK2gF9L7Jx1h7NHwT8/e8fVpCVujA4rOnDtjaMdugakqDNRjsSsW37ZP7RY6pFQNbigN1+261FWPE7CyUjmX32uapdy/p1wpiPAhfBUA2vvyRwIjge3M5pOCvbRdf281/8fN7zkWJvywCuvebq1HLOmgRHGSGnnUsjvLYyhm3WyBXOFicP3SCEoq6ptQV0WI6UVmnWDIvzCwlG1XbfyJljJBBNWp27yRCOHXvt0FXZG4tk6g0R8BIPTyAi8+RkXghrft6QblZOw/5TyaIoOBlM0M57NHez2O9Srso6NmUj02DEMrLRll11+Ld6IrE4i5lsak6mlRS5TtARR5p9UnCtTIAedGUgPSttwWk/67VfBX0F+XXj3nV8OdNGcGq/wxEkUEjGpna2doiTj+XcuRb77+kEZtUWErjXuRL4VkCWm4N4IPS4b0EGiBfc6/OQ1owR+1GIYdC4l15+ofqBdS4IEK03FALa9rGPzVw9x84zJup0ZEC1FyY4YfOsP/QL7NuymzZswExRvZhdhlQrIcatZ0QERXDgmXrvWhmpiHC39dZfqklcN0U9CHGGQAdzhAHPOYBxIRZq+siMynLa/mSkpaTkPOTvlDBanZKedRN+GF7/tu7dibbe4OEstO+xsoMcZP7HEUteODp7go0HM7fH1+xFa4FqgbBX1w5oiNQwWWlknVUA6TNrClT2XXfW1rB3eLCd+lCJ/tMOfit23TOSDLGJWoqaqMd7lWi9kUBPwjGphcspxQgbDNlwfZ346vvsB6It55577tAfzj17aLLxcaS9ngEOEnmq6RBhx3adJxNdZIsF4+VCvFcU9ZEsds3LSda0AAAgAElEQVTCjBoLAylKV4t6NQd4Vj2QeTAfzyZ006JRbSvT5/NtkhdKoSMqK1GdsKkwFdUPHk2TtE3AIRBNkOE1vVfTJBqc6ebJufUetmYUp6jNIhqsQd9xdorrnezw54z8MVeRjuQLuZcfHnl4PVSb1X1dfvmV9edNI/QNsgZ1fylkHOL9W2/95Qwt37/e5/NkuL0ZvWpPAyPeHam/4wwYYNf0hS98rtooCC+/nGHGsp4HHriv1HhEp00mzRghA71lb0aTNcNTvZCl3IJsQzszEy1ixAQuvltwQx1op522C8w0X+qB6QPMfd6U/i/R92KLLlLfz7B2pRib2Gd0yEKkW1H8gLre1wwyYQoHg//gQ/eXc3cPApRF87mLR7sYjC77WWqJpSfVG0YlWPE8Ggmh9bK2FiEKI6OqxUJP7Nd32y2w0pgaCVZKMIkc9WeK8gwnxkimv4uej3DR2gqQ06YdWj2Blii/zbocJjK9+44pLOT2MtIphIQLzv9TMre5CtJ5NxrNDSxqr0Jz8gN/L2BoDNwMgE5dcIMNNmywfxzjxMDrjB8nddVV14SI9Hqy18USPKxcIh8ITDXQOecCZGuKECM733zzlsi3ViUMbcjG6DhodVEj/3y+rPZHaRsz6F4blouz/2XLzuES0YT2O8ssnYA2jvOAA/avupy+PQ7c/ciEQZLTTdf0bb/0pS9UQ7o6oGvitDwL66eN5cI//6m+b4mll6hSwHTT5lxnTY1DfDoENVDzEjn3n1p/nSotOPtzzz1HntNz6d+lBJP9mgCmwXyebWDR/8oojE3EI2hO0dobMo6gY0IJlMq+ZQjLaILHB9BaSQz6rMpWujLXiIyI4S5j3pivPUNqCWojOjVj3/7eXuU4Ngy8u3r0q6nz6G285pprB4a7Maqx/2WwziDI1f5RYmE4X03A31CGKcIdGT+02qprVNnkvPMuyHl4tIIY0oqlxxwnC/J+JntaH6bpR8+FDdsUvxao/Q3ZE8A8Gv6EF6Sr3yuIfsKEJ2PHXiuOw2uFDt5R9lO9EbnSfUlSZK+LpJ8SmrLOOmtWmeOmm26usg3eQmtXkmzQglbDTokEITP22Humn15PfGPNenEUnqVMTYJDIGJkC1O1vAwIjSOdaXe0nRBac0KhFVUqatlrn6PK8Sm59P7h/ruuoYaMINANyHtdMKeLwPSE5f862N6b2ksH7sXe6qI+BHbYHS0uPgup0xnrU2y01E2IpKtsHzFNWcBnNhvRyiI9YBCM17kF7ed8XXHZVeEJ/bL22WT33ntXROubZwaj2lj6BO8LJCU6Xu4TKxUuzzG4GVGkm8HalCZjpiKdiNx+8pMfF9PUZ0h9RwcKcUg8dGxIDr5YiQP1HLU3BA74tQhpwUAeRjq5cAbGZBD4tygBXb31WDXKsVcxvmI8uoShaRUOrszZxpPpeHgM4RWBsxiaB6Nu8dMM5Aa9ihYFAX//+/V1/0ZlMeQeyjei9GOTr7ve2ulBPDYHZoZa5NY60ZxZj5hH4undsXp4olo1t6/ssF1Bjd639DJLlnbm3/9+QxRKHk5E+c+CxX1um4ASU0LDsSj9YDOBAtkxgUQOXg4n2va8Yd4aJ7VimKQCEJCxeo5JELREF1pogcxQ/WJFqtZJO02/tiaY3r6jNxy73tqkeV6cN2Wfx0PoGTf+ngRW4yqbAFNxuJ9YYfnQzrM/UgrYbZdd695kb1PnGVm7vqlbdt4OKXa0erq+YfrMa4ZJrG7FuHQIhzNTQ4cWiNTNCIQu9Mk1YPK11lojkG5TqCrDmUXqhAEHlN6mOZVmLEJSFl540QRPQSziSKfKdU4xMPDWlqiCHlLXydg/lzLE2onytY/oZa05q4F0m0jHZDHKT2fw9AV5Vq+GZJI6Zs7F5pttPLRxWgruj4YzROaBBx8KHDh/cQnoOq+YtUJWc42z6ElMLZic46IJRG686cZAtQcn4Fm8HI9n0Mgh5ObCW8h6bvjpjUub99kQ6Yzxg2wYxq3GO0jSCi15Nwo5sg7kizkzcNr9ebZUxXw3w8Kp/CGBL4nCJZddoghoT+WejLBTl330kQeH/p7xZb73U59apxjs9rBzYP89GOMPjsyuqc80QEJWPMmYQiEGLFToivNqDWUAHeJVg3RxRZQa1L6qbuppDnzmwLYPQp7Bz3s2NPh3+8vhjLR0RQevMvT6ScGLWUeBiboaJudsWV82yPcjnSkvlcJPHKmgtpx6Xp6DyEZQwCkwoKBWs3NXW22NQmlkrMoIUJ7ll1+uZh6zg75fj/c/kvkKwBdMwDhHxFgeTt3WXoZ+0LJV63fj3XAjGhJdUa9EQLTW9n85ojxvwXQ5m+yhrlGsp3KnCMaTQEROA3W28YGBQAdZpWfV20hm13eevSbobOShhuYUolN8liiu5fmTwBzpaLvz7E6lE86awxlmYldwl3pv18RuyF3WOvsEgt/ObUPhOuPXZzjz9ov3d0F97/UMO+Tqv1v/rXa55o/6q39PZ/6XdCNeQYIQNW+BaqvV0itXolRiSvdIUD1r5rkj19E8KBU25ye8h8YGb5k3Ba9u29jagw78TqFOSkeT3Z32l0Z1zoaPYeF4ZGoOLAO/4gorBsqaozIxN8qZeFAWA8YMOjVOh1NluKS6MgwG0eYEk32Qm54YYzTXXJk1V7ThdvsO2RaBr9RCQYXzfXz+oeNPOD6qSZekgf2kglGwhtUt62GVTFM7xMPkhZbxdK1MRs+Ds6AcZa9pXnjhn0J+urqiue2226Z6Sd2TzzVzlOGSXTWHMpRC9Y/qZ2ussVr6ZU+vTQY6BmlZK3/Xawgjo6VuVNr1TR6S0z9jCJfOmLItqpkYwWrjkLGIIBjjJHuminLbrXdWvbgN3o4wQ+7bhlEzmzmi1Ootehoxb9WgkUPUDa8NKeTxCRPz7FKbzUOdM2PZVgnxZ7PQwil2gDgZkzYTsrXuaFnqLzXN4Wy/MdjIcxGxp+ULitYq1OEi8Mfrgb5vvOHmDDbfPWSYDXPd6esKA7Qgjxxy/+4HtCDPBCtPxTgcnzYiyj5bZ0g5JMJz0kNaDjywqWyTQ8au0w4gE2UAPNtx48aH/LFUwbSvvpZSAsnCQetKP1ACPhnLGenV1fdLo1g/n8CEzN2oROdT5XsYcmdQyYBA/VzJSmeOoX07ZILVokPKEfkc+/efyYiVDhDETKZBXLsg2a6Tpk3LWdGLNm1N3XmrBDIQU0BKMndtRvrx3O8ncu969GRyGPFIRn/+80WlLKQO5nNkGAz0vGkZW2bpJfO8l8k5m7lqfHpNqzcxQSc0SEA0Z1Rk1EcN9t4kTfaEw51P91drNGhF8dydaQMaDJN/KmjCkUf+MEb7HxFUWXNog/U3qCAPwck12oNkGGUmECNzSJ9LTdXr2X9GsL9sBp3St4fT/ILzsFAbSaVnNJyRUkex/jnR/9Py0gJSmejwR/UgtbnYBjF2jd/25+54B3+ffTYM+Q7eHwNYtctcO9sFMl8pSILs2L5SPxMkyMLBmrISa8YJdBivTVli+LU6GYo+YzktSjt/j+LY3HHOi6fMwJapUa6//rpD666zXtbqmeqRL+GTPD8ZIZlF1yDB0Foka7wwE00eFHBFRMN33X7HnbVXZwk0jCjzwIMPVwYpS65xXQLH2KxKSOIAPr3Rp1M+2qnQk2fS/eCsWZxJlZusVauDtrUYdmxNCKM7s1Ybbb2dTS+gvUYmCR3a9e/uSHs23Z8X+zUq59I1VrCUfcc+S3D65xGuqaRsUEYathUN6RAMj8w0/Yxz4zskaX1YSXeane3fr9V3+m6EWQ7ztZAVOcM2EKBNiPGyt/8ZiJz9U3KcM8+yJhAN6vClwK11zLoUGmKowZS19qeeempkOo8tfogSVBzp7TVGrY0FS00t0Ui1NyR6fSCwnsOtcZz37r16HjRojYGzQY3OceEuiEgDPN9hAmPMi0aevkcbaJoIJEvt387PqYjIbvw9yGXxROVUa9QhLr3simo4P+roIwvH1xDcsuCmAoM95WVBeoRkEUXd3vfyYOCzxedM/d355/8x2r5/DglqyaFP5Ls58K6FW60yE5+O416p4F8G4LwMPQZvg0YvueySjKy6pQyijdYK1O1wdsJFw9M7DNVqjyA/ab86sYkDxKLBSrI9A3RXWnnFgggFMPrYOpnJxle3Ab0xGKJaBx9M8ewzzxX55h+pjRDsBo/7PfXPeRNRcWwbbrhRRVZ6gP8dxqB1qVpoRXgkChMNDkZD2VhIZPrJtOI8lwHdoD91Hq0j4KxV4rzazNMXK+u5/fbbU/8ZM3R0erNAhq+/EY3cCDIg3YB27Z9uiPT82je/ycSIf4f9etBBB5XxxdD16k3qvQ5VMpG5V0HOk08+Xu95Lj1zsoXNM4RctvZGIvNWF21N3/6jy1zKes3ahGYwKlqgZPrT5PcqEibAUMO8M30j/71IjOA8cWrWc5kQ5D4ep9pg6DwTDj17kmOb1ozTXJtaIUhbxI45fOUVeZ5ZYxN0lBUM3Z4rsOD6gUYFMgJMaIAMZ7bAuvgHCy+yaP37O5E0YyCn/WhrrVo2vcMz5vC/kBaZPj/342HnCqZOPvmkBAcXl1HlGDh6GRYCDyesjinTXymBbxtiHOWhZMU9I3VPiE8GZq8eOcA/X3hR2gNOG5pr3rRC5PrUOWdPALFYanebbrJhZQV3hHT4eNS1GA/BzajsE3qztyboowQDOsZ/MEC6KQwJiMJhqLacxtj1/+oZ5YnJoibV1dTHBtllq/sP5NYGbVOTIMdB32h3pN1ZjpQRLKc6aJv5f53poNamhaICqI/U2StpxRDrEIbYPwHt/Sm52M9VwsnzhZhV9hIuQBuS8EohZ90Rs2nsFFKYgP+BPFOQrFmeY8bMV3uF0a0BDGl38ey66DyOhBaN5/IZF6QdyTOc/CMJTnIzxpgtsfhSWf/bYrf+VG0d2njUvUHPAs4JEx4vtTTsYnrnb7z2ZgVTbTB2kwskatBIif/tEDnUVrdsBL2eCLBhXXGs82YmBTQjkIDmcFuNtDvB7mQFFFPiyVT7XHspSbHD/IMMXsDq/eySZ+93in+Tv+/KTpN+Of8BRvV9frdJITZhi55MuZcewHUH7++6Njo423OSBHYhEGUrZEfICc4IjgGkwDbiNCvXs1+qbDEgUcmIs69vTGnquIzBfCGiP0pD1fkwbtydVSP1qiGrMQatTy80bIcnD0OELmKp2lzIPv4etFvkl2wSH9z0K99LJvnzuqlqW8kVvBUDYczYRmkkn/hkJO/yuZT7zQSdb/6PV4Y4f/BrBl7mw/hb9NMzfWXpZCB77rlXq8ukWNxox2Sj2gBxzbQ2sIfCOHZn6l6KcOQ6Bni2wd1Gt5HQMkx7p2x2UAk4kWPCshQVLp6aF6MA1jz9jNNjVDapyfLjw3Y0A9HhEBlZaQ6s1Q1Edm1DDtZ/UiSjJowY4MHvtPP21asHAnSPJYSRTG7eeecME3D5ZKljKiqu2miiHIbP76pN/jtEj9drmkWCkRxsdSbSX6MGouyrZniu1gcOrsm4peaQCJYTF+l6lTC5zTuAVYoS4GdZe/CGfl6QhXskFqG30ffRCPaZXtb0ssuvLnboIYd8J2zUpypSAzkXYS0GtmCQrIvv0pZ0dea9Em3/VtRH5krgRE+5R7LeZw/VRJxsWAGFFiH3DJZhMJ9MuUCkv8giUajKz8pmDoxDV8Tx3dpdTo36z12p9+kXezPqRj24YUDfdU35rhImiFGfIZn+sukVfv110m5TVWZoTZ2BfyULRQZhoDXWT51spOQj84xlMZ6RgOSfgT+RsEBETzw+IQd9+qFNP7NRTZfwYhxM05gm62JaiMhcJmd/nnPuH6u1ZvrpfN47JQHJKHj2Jg4pdcyb2vc/QkD5doZSQzRouyphFCmmBr+3VohXX32p+lPXyD1QQZo1GY3gRFdFPfPc92WZfnNXhFTWDDz+y1N+k/mzVyXjRdoiEYqxmqEDUflZMRnX1HHC/zLxJt/l87UfTUmRKPv8jrvGF1NY2YEDsO/bMOU2ws++K+UrBI3K8poGdOvbSxnp/4cNWszbAfmtztCIWqk/N2fZdHgn/bn+sykoNWi3keb+rzOtd2lbyHe7Bn8vAyH2wZDK6jgnYiOQAyiF7/H8lVzUm/XHk/vTQucMXJNpJOzi2snuXwj8jQ1d95996IyTF5RZPRNEwxB27S3OBS7DTIFttUXpUcUo5Rz+FhQO3LtRoPwdwmSXFZt+hFl9w43XF0v479fdFFu6UNXD/3Th34ZO+skJQ5sFgfhobAy04YWgCeDhVj/O8/ivjK+1JrVz1zSPuyOsBR28Jq3dIKsd2d7Sz2yH5///1rm+o2qkAxQx64HQ1lthWjtjuxZngyN1JgRrPTErZzy49p6NCoL8vd9rSF1DJv17pKhHJwU18ul0heCA2AWy4F33zl63gAZRM5l+1pmwiulgGOg9U4eSTFojAWH8j1ahH2fyko6V6XLWTVYynq7IRr3J+ZW0hCBDyICejwF/IoV5N7vA6AXqAaidBVgoY8KIVDSdSJ8jIjtmQxA+RoiwMKKnlqK/H/HvffPZs1a9EgnG72KucST+XgZAVQmsBBo56pijEoFfWlkP1mnBOkEckDBAlZw+9qLr6vBEf7B1sLNpZRIW2wI9lPrEscf+KCPg7qnMcMc0Mnc1Jwt3XXoaZccmx4OhOBWj1DTOizxlyg66KNXi+y5ZUtcCbnq3HbNvkmVVIxSdp/8VjIBNunFkx9T6kFdIfmHkiXIYO9Gww97k+FKHxcqMAUZ00L5hc001dZxOejefinPx3BTI101rC4YwQ8K5t/qqDdcGg1c/PkOS38dQbUIOw/C4AjzpP8xc2f7YkEJkzuYFitJmjNH0HEFX5mrKFg88YL987/qJjB+uiSkMsQMxy+C97t1+kEGfmI23YTJyU4L+neDsnTdbY77pKdbRAWF0X02wIBtFcBGYMZCuH+S4dLK1UjCK0bcFGa1eG/VdXn/968UJUv5UqErB+5MTom8Qp55dLPA2nBdLkcGbM8zjDD1OgLL6ap8suH2aZNWujWylZ+L7rSlGKqdhv7ea88sV+TsHDiahB9chk8R+BmOq/TdhkckL1vPd9qXgyH3/b3r9nkhbxDxzy15er2k+RTTK+yA2WshkqBeE2HLa6afW7xPhbxT8JiKBwczpCJL0R8+Xeg2okiPV48iRVk9rMiwD7F2/oOXijM1yHxCnqbTaJMCcbdaZismKAPZ4iEVJLauOCCFhDx56RBtMAt5Au87Ou+82rsDIc1cPwqJb5MoAWzbEofYJQP6usuZ6bs6qEWptj3ZjPdKwT8qK2AD3PsnJtq/iWwcJaYM1/48z7b/f6+rOlmxwVJ6T51bBfmzRsp9YqtCvf8T52WdlV7KuEK7lIsiwwQbrlaNlH34SuU3BhLFkRo49+siE2EpjBqcpxGaPb34jwdy8ZaBNg7orE5uIkLweApEatOzceftYAtBNEqwLzDhL825XSR9vObD8rwZS5CYvSSJwyi9+PTQ+hCIc9y23+MzQ4YcdWm0vTz81MQHw/QXzm5bSIdXJYkcaNNnYzD0AacGlPw8L6feMstU7G4JQpZey3wP0oOrbbb37pClBkbXqGWKJUmTTVX18UEryb/ukwqNcB4Sl1z5dEyfLNpXjg1ZlXzvbvUuBYy0oeJA9dzZ4f64+wzV2iLdDvl0YpfXXRrs69vU/aX1DKO1ZOOKqViL2VXubPdp9Sgs2atVq7T7IOp580kk18IEIR7WqSR48o0ceeeDDUi/KmxxmsmUzpPZpIUhg1ZSJYPoa+qXoehU5WpG3L+gqNOqkaqSczrgIqtucYEWLgbj0hc99PkOEd63Fhe27MXUlsniK4iKHplA0bdUDbaojjjiqmt8P/8GhqaGuFMUZTLLWy8QZyCy6ER15mDtsILIv+DZOHQx3T67r7HPOLth0+wguqPe5ZzWMK6+6spRDEEdcG2N+Wvowl1hiyYKotTSQwpMNexUzNe8TOSI2lYqMqSYVybWN2xmwDqMslkDEMssuHTh3xRy+h0oYwLW6JwNxPTgHR7F/6sDn1pfiz2yBxkGxJqjI/jknylGrBBpeI4xc0ZbsmuNtm7e1CIGVsdJ8TheL57x6/bZFphHBf/SxobGB/ETbBrQTRhcseLYLJwJeIj2WZos+l2kNL774aohasxTzWa+dQ0wjmDNsUE17JtPNMG1lLxdfeEFNn9ll973quTNKnTxmHWvEV3ZrwWDJAB6DhISExHlxOKOTIa2XqL16xrKnGElZDwvKecgowMlGt53yy1MqeAPfeCbaYayD9QRf999Vv0GqmDaRvX2NVYup6jtAoeplyA/2jWyt0d1B1E0IXxCnnUUW7+eyGY7aPlL3sp9lta7DcyVr6FDPn/2mVnzzLbcV2Y3YxtNPP1VZp73/QT5/mWSiK4VA5oxpn7A3Dj/88HruC8bRNxEEouatlWe2lCLsGfNkCd7HLVVAM0PabjxzmWXTnn0hGc/NBRFSSNI2sXL2j5f1Z2z+HYKM/347aIm2I/sD5ClQLnZpAplbM7v2/bSaMHp0lDna3lLks0qTF5llwKjuxq+MoavjLGWqLFQ5WwEo5yeT8VibkZ+U/VQG1f7c2bx10SNe5YSrhjUorQycaZnA+u/hOms7C00VDPQtONWy0pR8pimHaSYvJIeiEfY/4y5wMCoQQ5dq2Vm/P6dImVj4BEEKLavWkQTN2RtaqSBH80UTe40Q6xhwz9RQAA51zjhXwaDgTkmgMWlnrB5+Ad7y0WNmQwl04FU0EYe3SpoVf2KzdBjMnyCIVOD9D4wvO8u4u7+uMDXc2dACmv7qjsKyNBJQW6NKaLKfG0kwqFLxKuJEB47Uv70PotXs1mAerbXPP510xKa0fuM2tL0nNr0tqpOGOszfHWlXJvN+zwNqx/9wgPgOzmMnIPVMsWelHWno99iD7KbM5OwOk5NcU98XZXuSHOG/KL3Yp32/eN+rGfhhXZBGya5+P7Nt2QbnHSfFSErB7WQTJjzy4XsxWm9kMouL8TD9kk02UctDKPBubNmozzQo69mK4sxFlOlhLTEkINtrM6rKwQOTMkgODXIOWIhT+0HGFmFEEkpokX3G1cQJWCDpv5sqYxQDRTz5W/vuHwNyc9pP9qqeVr11HizY0QEo4lOcaVPUaVMuRjLBemQiM/VwZQvPBj7Wj6d+RWvW39n0t4eFZ1OCvRA+SK+dG6Fxva+MgpE8erTUgGrTiLap9uSFTNHgBtm6jTwwBkxPGQFZQaj12Vw2x4bJekWqyARtzFEYvXlTZ+LJSD3YPmVAe4apHggiqwXC/UTWYtNNN6uaKAPscytqjLBCiQIMiFnUhd6PMwGzVK9aHE71rOY7PY+XYySeSXZ8+533JKCJ9NbtdxayoObjQKkXG/JujNvtd9xWI9f0FyPCHP6DQ8pxCp5AJqJsm1dEDl3QwkLD9fYbrg65arOh6Wabr75PttYj0mZ4M5Yszued3COSzsMRP3CtE1NrxE7cZONNCwoTxNFBkZ13WBeLTjT4eg7Cr371q8Bl6Y9UL0rUX0FEPrMp6WgDmKqykA7/UwYyU9Gz5LxAZgg8hlo7SCUukfvpNaSeeXYmI2dgL3iO5SDAjgNjJFAwCcNzUAsG/YJhC8JLnfOOO+9OcLJ4oTeUqErDNO+HsCyQIRArpM5pr8kon40TO+GEE2sG5RyBEmU01R9Kpiz7Ri2TmMhKKy1fQd+UMeT2gvMle3w3wWHLsCcm+51Y+5Ts3CLp/10nwvZa0YiViMwRvAw6tmCMsNF2YK9nExwbDbj6amvVddxw0x3VPqA2ah91hace3JSRqoB3OBOalI0OnFvPCGRLzREPamqtODUpo+0tZv0zu3McRn+as2wtXa1m19to6mzmfHAuLcsaDBYobKkx4cuoZy39m5KQfnKQOmjd8ImbIgFnVJ+g3/qxMUhd5ps2xaxZCnGodiNEvjx7+8p8ZcjZcsstW8IuH49DVUu/PX3NRujpo8c3cLvPBunxHrDs16LxPTqJyym/+FkCsGeTlIyrINNZoxPuH3ZN7XXihMer7MAJzx7BFzrIwxnlMDzeBQ7asragoju3Ps2q2jpCxist6pynke9p+zodErFzfq/mwU7KcBu60JnHPseeKB3mQTLRnVvPcLvsoD9X28uAgeva/X53tL1E2GroLXnxPXUNkpjB/urwbv95h3p7FiqgrIAh729BVCMQtaVoA9WhfDPnWdpB3cH7PNfnet4Oinbq6b8pWVyzUDl3UL9ErIK+QHMfuhCZloxG1AGyorwhIyBYDGabf8zoPOAxNSuO88H8ND2CYVHn5EAfiREUGV0avJ8zxUwkwg6GvCIZ3zfD8kSIcGAbU/j9ymaoUMgy9eGVcVVnCJHioehlfue7h7q11G1oXeqXWrd6S22AEpdO1N+hhSJXDBZpJNxr8dSVRB7TxLi8mawFNFfQYxyJiFBErl1BbyBCgc82V/PBQMJ6ZP+SNh9GDDnA+nD26jK+r0c4Mpn/glDKoQq6qb408W6bjJHkfAQPhBW8y+BlGx6T1BFQrFefEQVjCxLVJ5ouY+bI3k8vn8ynP3TfIzLu0WYZquy/D/IzPZq9j1O2og6pdsMJam94KZA+B3j1NVdlnTL6KAfcsN2FF1q4ICkyg8QsZk1mPCGQHx3Xww79XkWmSBgK+Rxp1UizIfWiuQ6s7/k+Pney2kXyPam1gapKtKBl69at6Om5DlkP6JRogP3muWCggtYd4Ab/DcJqcO3AydlHyBpnnPHbCpRkBm9Rl4lxnnIKAhxNH1mtGqQzY0gFDJaGbBrM9u9yy39iaK4cDsa2z4zsvb3WtddMesTdW7Bq9miebdHxO4Ei+6tHw50NXTBzEU7eHTr3nD+GwHVvQXDOkQxawMnpy3b0O8pQ+1QKU5V+l4kXmLsVIYeBWES/nIbzxsIAACAASURBVDOQOvfjz+aVImLNFfUsmdDE9MYxEK+GSFQiKiEjWQdZ0ZV5npzsBmnXILhBaIGxKi3cglebA3wr6+OasXbVVt+LczR84sabbytI64M8D2zm9xv+NTi7zcBVjaxEOSb9Vcu6sxZe9fzUt/Ln1kv635qnlazmOcvavKyRVx+zNtKQ1/kpUZGWtbJhfbRgZSq144YRoi6A7/s5U8+xOwstXjMmeBaIbLvNVmXjEP3sZUmEQE8i4ZpfzDkC7/bJJa0tr5UqurAAoZT55htdWuOCuRf//a+0Ff0ryjxvpQd8mcqM/5lyCRYvVOHMDAzA4v9BAtU55pynBFAkG+7DeWUv+6g2aIznSaGoQavDbPmyO4NMflJGP8KJNkfSgj/PxR6eOTCzOZ2Cp0lTdwZZZ5+4ZF26M/IMO7mnP9de52Tn+v7v2V+HX/28I5kjSUvexyYjFeHneA872RWSrEHPVns23L+3B2bOaK/rdq3rYRi3QcTdCXcf0Rz2R0v3XTtd/33rAkm013+SSTLG1Bkosnxa2i686MIIPowrXyH7nuyxxx4qspFaUF8YC8zYi9B4XFGohuU111irIte26WjKvlkHq2tP2myc8TuBf793yPfKWH4qg3Kl55dddnki/yUz5eKwOM5pS39SJoukUoLuSY9BJdf9/fpis+qzU6TfeaddcsF312R3kfOnPrVhanPrtrqaLCwPGnHEv/v4MJuoQ75dDMB7GU1GtlRhYvgYTb2D4BvBwFNhxYJqwGUeogf469CcF1zAzMF/x4mkrzJRKMdRxpN2q+xgQN4hRD28aXu9pxmSqk8WI9BIsLdarSrfyVjIqEFyTfB8ijinZzIR5/4Y1DB7Q4D6ZGq6BCoIGLTZhU1gYORhaVnUfztSh9q6kNyzHq2pO8FAsguiAKBmNH4ELxKAggcbGUtRg7k+11tiNPv1Tx1CztNPPlN12QP237ecPuiJ8ISaI8ag9hWfIeIueHLBBUuO8b0ii1Faav20wwHAfyrSJ5VXzzKbV5Rtw66cHlgFXhm/PcZY1j0PZPg8I3vuF2mKfi7w8TyRLHw9cm1qHl2tyVq3eZLNuZucs2S0oQUwTyTAw9SmqUqcvpifA+Njv7Rgr8FXvquPW6t2iBpvVxZ6uOTUfjIpmOtB1pOBc0H0MvKjQpnHElxxxRUK1h037t7KNL1kFl/60udzjS2QExge96MflQynLEWWw590VaFZ9MblupBisMtlKx8LBKteNnHi41W6UHOvsVLZVw9Encn615zYCJU34kerVdrrbAAiQheSfzPMRmvPYVMfG3ffQ6UsVWIsUJAEkoJYjrQbZvvaz3pG0qUHO1TbekYHTm+wtm2oQSMkeXVCUc+kht/faqQ+w7npzrag4Dh1P2vtG2rIzXGWbai6qkc70AIuGLg9b+gPtMiz9gHOKVgcyWrOONFt4kztZ86MyhDCFtKZIEHyAUXwXe5XZl3qWUkQXDuylz5pGefnPrdFtJtH1/k2uALiwp5BWJZaaonIB95X36197QdHHF2TeA7+7kE1+KIT99gpe8p+qfJW7see7HXqKi2NeA1D2k2gopMiuwNtDoYgDM5JE4Xp57I7P2hXn9ojM+7DEkb2d/YgpNdJR9ZHR2abPSPt9qSjPd2heS873Gul9Ac6lCvZcb0NiYx28CB469fp3x3m7X/X76fg6AGc+/860kbMoh/ATvqMXift2fctt9xapSMCRdCiKRJ8/SVqeIZNCForSx53z50fEj0nEabg7WGo8zikBXcE79fPp75o9M6YOBUHFzwnqytWbw5qk7hKjTT/gISNMJNh+Jze8/hEDMqRR/5gaN211k6dJgLk2cAK7stGuYUGrDorGItMICEBC4x89N2Dv19kB7R9NwySXXONNcvxgE96xDFyxE+vT3bWYIcZ8BtE/zZPf6Hwg9fuC/39uUSdPr8OVl6XXXr5/8fWnQD8Xo75438O2om0KFrO6bRRaZEWLWiRRJhpBmOZJoyxjWHsaRhbSpkYCUVl+dspEtKitEh7UaQ67ZZSSetgzv/9uu7P9TyPfvM1zTnneb7fz/fzue/rvtb39b4S8q9Shu/d735v1Wwd+kIJO8BlrMbBHhMsxobaOC9rKn2pdshjHIpmRNN6xTgjImxTcm6McbvttjujFJ9bgCzDADZLuk7foPsZbQ5jRqNUow1UG9U+0wxFI+NiVNQcNZx08+2JfgB9XOMX6U3DGGSN9NaaotBKqyZk5P7NvXRwV0u6Q2MyFBwhB2SRFn/nO95WaUdpdoffeuJhXnft9eq5NUNL/Yu67RG0NePjOWqiRw4Co7c0Skc7iX5kRl4byvY7bJ/Mw9OquG99OsLzjF7WnkFgoI8NslrPqHS0yLWi/uqb5aGPlM4AcmVkHraZyOOaWU+j0lbIHugTpiSX4eBIaZVyGanvHpigDl59hPrxJiMgoiuF5P1V6hvRcqeP7FO1gOX+f5k2Mo6hDMfhh3+0Wi6kzAHvoKQRJDgLIj88t1p3tIRxLo466jNl9OmNPyd1r45HUQ9u3zhT+W791puG2IS8OLvfz7i1Jz/5SQEQrVc81BSbFDAyEr+377UueSYOHAdP//VdWc+aNxk5lmHSjkapVb0ssnZXMjKXXnp5MhwDrOF+CpDhubMW3rNS7q/Yt3L92Vqbun2+05p0HVPUWOtVkdGo6z04gurzWfa1PjuNUpsXAZe0l9APCtEBjum2DPvRQyWmuHTa3+KXnc6tNHmVPrSrxRDbewbjYTm3vtvPkVbovwU6HNFpwFf5k9KlPyn4juzKYFRmb/maGOL21C+hazfdbJOZl7/8FXGgfh4k+zcK7LZxaAy1nN0YXmPG9lcBdZH/fwrRAifT/rmfdkaakAYGwT42uIh89nvmG9H+2YON7EiJz/HpdqTWLTr2faDMjWeMXcjf2+nq7Ixrdhawo9OiIc11C0dC4dqdKVLsEkh/viNiz+C8cCYFJmroZLAwIwUSGns6i/KfQFgNaHIPrlHGdnKA+946ozTfmLbcDODlmFpU+JFJb9f5jd6QKeNUdSvb79PywqFF8PONdCIoORX46ken/3CpNBfi5k53EggPIL3kjVINlwXtaoLGpiEX8BKZdn6bIhJ9SHlAdRoYe3Wo0S6+7JLiT6WcRX+nnX5KUlDPnnnNv7xqHKoogjNDKMCg8NiPO+7zpeSPPuoTNZ6NIG6SNpnXv+6N4fQ9ubzDQkAG6UrQdg/ghlIt9pJCRw6kbKd1agOnfqY2thhq5ufA/Z1n6MBQjHq2eKJFZZUfovP6Wej8MAWdcMKJJewUnftzQCgIYKTK6ydaFDH6zqEUxgSV8rFzaDkffu/vokApFMaDAG22+SaJKEIhl6hOXcWg8eZ9tB/uU9tIpUU0ticaABIbkdOoDUOn1t5EwXEyIEet8y34OoMaZdQcWI32NTQ398DrA6Ia/MEjvWZ9RZmU+wAIjIiDEyDlalTXm9/8ppmfxjDcHuIBw7ztoeh07ZCvb5IRfOrsapX2ReRKUNsDrQMahW7wujqqEoIXQw95CFwEWVoN1CXkTdNlk3ACa79aLk7OD5Jy+VgZIEaBUyNar32vFM3wRAGL3P+aSXuqoZKra+Ps4QguOr3Ulu6LnFKK1ewu5Z6/A5jU0AZ15x5QHmVdfKSJrisqgkqt/zenpto7Nm2EA0oWjNs6NGQjBq1jJtKor0/X/psMBMSnF1VbGOQmsJIWMG0WWJduCcCME8m4N/xfmk8t2ISTxWmdIjvXLbmm9nSrrbbOWiSCSOsNMI108hlnnFm0cms9FvPRkB+GdABpbi7i9McESAbBDcFv/TnNBbDL+1epfnDOMv7drHXaXMqQ1llGKD83lEJUOkApowbaRrJI5yujNZr1vThAeijLGZmi0rnVnABDkwPTBOalCKd0wDjv41rNsT0/BTw/amkwjvdW76tIBmhtQs4X2czwRvNMAQgFM8IBY0SenrLS9ttvWwaTEf1CWLr0yLcOgfzUnE8viuSky3UZeCZMWWRpmydtUS0rUvva2y5Nq5YU/8abbFS8yUYF/iHp+GdjzAo+4OoAAYeRH6Mj5+p7o1molPjkHIzzNXRAZxWGnh2Zs64hD/mE9RizQOu8lN4cjkgb13YIxvV0BIz3tsHy3N33WY7SeGM9e0fRDTYa9zHH1/tgg9+RYgUauYdGyPe/2/BW66G9nzJH3SrDWbYvrst2zS95dVQ7HI0RnfcajUEjQ3/WMIV8nr4qhz/f0c/nurKAgpabU7v+59gwKX9nUJCw4LsnnrB0HOT76r8m/nVgGVielobyiy++sNoeNkdkXzXC9N7EiDU82iGWGsKlacL55eHr/cY3v0EcK89Mif8msPqr0x/46U99oqJQoJyvp6fyox87vMBL18ZLe95LXlBMHcVWFE9EQ/rJSae8Lwhe+fLNNtu00kv6+l7xilfUhBob3OldhcFivFGIzuEY3uqIMvzVdrdC9zNCwWjwoKsuWVMqRr2PoFGuOEL1aYm2TWcwePlhD7s3hyFUcFmDQnVOwl6GMpvlYN6fsVcEGAIQmcF990Zh5NasMdDQpnmW1UOkAPhCuSFVKN5W3z1x1DqALciMjxR4Fc/vH5NWerQPwzIciaGL/Ac8A11KkYre1IHVeCCGfQdw1ZhXmbRsatlmoKpPipgpwU6HMUgEVTR+zTVp1wgt2b9l4PkVQXVr39CUzLMG/sFrChmqnsxbdm39vp3OtQeQrLeH8QntIFQ1wgWRG4Ox1VZPSrsNhOh4hvYuHYY+7ITZ937wgx+qtWBIl+Tf5Ew/rbYtNT3zXzkT3ULAMZSyZvDJ6bbbbZO0fVq74ijYo1ZSHEr3KwK3HyPIH8jRAmXk+8e9DEM6I604YWVaQfCipT/1my0OgMj4ssMO/UgBxGAHHh10/E/Cjaw2s05SfYuTArduSiprhncachnpvt7G3VIeAQpTm5fiQrAtolszIDlnzSBvgCPgPVkCZ3LxYojflGjyc9mmj/33xyrqf1qQvQsDGnOfv41RxF+8yiNXyd6uVDNNOVjas3zO9WSWOMhQzffESYEZWHbZFcv4/TH9tyOiEN0NNK5//0XbTFKqlGvVScvIjvS42qLsRtUxJ+U9wEpNyDAJ8LTmk/APx7vrpOTb+bYBUwYGC81sum+qkzLyHRH1GepIbdL5pZ/6q5xZZ9/LWdGk7wX4p7ZOce6cXm1TlGRrPvzhw0LosVEASo+Jk3189SuKPDmgNbQ79yySG1y9Dy05RMYC3PiWt/x7rfGpp55aiHgMWHrYjzrqqMJGvOQl/5CBDhvVPFj6omuufQbKOXAmpuDBfc5/1jYWagHzytSzusS5EX133bHXp+uDnYbtjAF9PIj0pxYW5yEfoi87C9MRqPeR/Tae7msWvZv7Bqz04b4v564pSjs4c34YKd9XNcj86T0CHO/n7JI59qkd16HrpxnDZC//dRAyugoelPrmYBTbU5wnDgC0vmwh9H5+Tqe6BoeT7pXhAhrEMfC6fx20nw2MWnDid761tNCok9ff3q43OLi8VL/jgcnXPyGbDakIaNCN/j7TNcsKtfPlPFeT6aVLNwrfKUVtpiNk6KGHHBSWmn1Sa1lQI6qkr7D2IIp+cejjNknTOQUjbQZR95P0TqlNiD5XWiGE5jEuGHdAovfd92+qh9Iio4JC7zQ/bTDGeo0otepBfWomz9dztjPACIK8E44y5Fl86FX/lmaQhr46NUWAHJB0bR2MsJeoFmijprnkPtddd61SbgAkFLq0JBDJ4x63ZqUqFqbmVTWu3HfxF5vgyXDnexlHfMQ9hcH3qyWXEMd7ls4V3UqltjPQRqAEL9HNmBrxm1w39e/Uw0yKuSOpul8m4mdUKYwaVZfvk01A8PDLq35RmQl1REha3jllRFD9HrBCOnLX1Khf99rXhnXla6VcGCHR7Stf+YqZHbbbvgAxgFdtQKWuMeFQpPoZb0uj/0oBJwEquUdECjxP/XQa38H7RxuFQzKfrm3UssyW/eQnP5FWjAuKtP9Pf8motXiJ0IbPCfsR0NsFkTOk8UM202aVA2B8lfFj6sMiAL2pS+MUqf9xeHimempbmYy66JiGMVqKBqBjpHWnOp09KaXQJOtj8ogJIoY/OPBq28cec2whPa39C6M0ZTR+dMbppVTvzJpTzu7P9TfYYOMYsDPC0PTJUui4mYFxgMzMBCWLnEoKnrFHJAEp6lWZhqJVRMB+38xaSRt7trPPPavOEVT6ZkkBX5mxYGj/1E6LZzZyRZatBedDSt8Z+0kmikAYb5Qo+tKk+38ZHfC4x65Tg9L/PE0NGinNgVegMO8PVkDdv1Np7qtKHVkrMsdw1mhFILzJQWIjRy10RD9DJ44C9HDChuEohT9leNo59hm/muuXNB1Jf6OWB5maOSDT3NDogeStaA3LV0VMIto/x8ndofAEv4rzU4jNnEVoXlkXZ3/vvfcuzuf3vOe9Ve/cLaAtfeeyPmelH72BTe6fo+o8a7mjH+5PRoKe2Wmn7Wf+PrOO10w26OjPfLYyFs9PH/D3oiO1IL7ghX9fz69NaTjqRr6NaJ6OKYdgMkiVBatnGevTsjpU3agB9p/e09Fct4z0PjUitksbXSt0ncKEZD1HEDJ4aI05bN7iNmKdFu5UbpFwQOJOKdNCVNf+zjk+ruvMtJPjWkX6E93YerioD/PqZ6xuhexRpX5laSqdP9KxPt9OxZwDP4Z8dHai79efZHGULwKyyn3OTz8P8v/Rw/pQYMWc6xO/e1IwQO8ux78yOxDK3/3O8UsdRgffizKpVGVuyM1QgG5OtHJLGFOEsRRvCXgpujG2aKTuxt8p4za+R4auTcvL6uEgvfjiCypVYegqgntRGPj9vYEW67Xj6dekiyA71WallzqtQaGIFDzkAC/9oFoHEBZsnShmr732LA+d9+27pf8c5sF8M9KevXhDwHrk2VzPZx1Snl7VYibvekpr+jlDDtAj0rLAzUJTxi8C4+ftULg+RUchqc+VAOU+9DSW0ZuEvgFTvg/CdqQk0rqR6zs8XvYDBZ8cPoNc6dw4GLPeYRRSRUf5DkTYIr0a0YTOLgf8zrRfaBj/deq/1qLnRKp/IXQWpzNCGs1dp0E189MliJntnXT8ge86oCK5H57yw3DAnlP38YqXvzwzPHetSEU0BUjVaUj3C4lHOeFy1U/6wAPj3q5NhCuSRcC/6aabJ32d2Y5mohYCcpBKqMJRFt3jBsmqXr3dDk8uXlIvCpDBllmowcIxBtDg7SACrmGcAQhDGrF9avCMqp7Ju4NUVB7w3pGK521jfBpGtA1pKRBsODlsncltmZqfqqIAeOU/jyHdYPGGiZCXBGT3vkzh2akcRNE+wJeBBSZtcAifnlKF9TIBxH2+973vDaXlCTO77LxjYQ/Wysi1mvkap8EYPiPYPJOSiJo+Z3ikttLDF0eLo0cGOCjOK/k89tjPFTkHvuKLL7m4yAA2DBEBBa3tB5YBUxYFfXNKGFDNHD6ZDdd2Rm/NaLK746gVknIZCoyChbzN9+Znnp1CMt3JIol6ChtQNJRagYbjaS9bZktBc1Yim7P9peOQDmMxvVoJdp2VwaqEADd0Ag/1e8d9BTnsnBcxQQONoHrVBUddGyiNQah+18oe3T3znJSfILuxmS1ZMibgiKCRX6glm0f67KCk3/3u9xW5C6AX9Lus3H9//IhyLK0HeefwoBbkQBmW8ai0TJyXlhqEGIarv/61ryr5Ov30M6qH+znhyH7xizLyMO1FSmquAdzYxm/+WgDdtfw1vV/X+5oH3FmWovenMyHbUNeMUbHe9E074a2LONedyu3aZQNRnUXPZjpTnZIYxDbAZILj2IawwT+NrB3p056sMr7b3vt54xH6Ofsa9D49BIdT78/3VmYj+yGbRd7ado3PDga3yowUGnfoB/ei95Ou8Wp5GL9DrD9xfk89+O18zPWf6jh4REWnr3396yoAkIp3xnBdL/j28d9YagHQ+PUXlCIV0oYAAL8sb1eUIcrxp1RwWfwS9AG4cWoAPaRrRR1VoM5DSF343NVXX5tU8VoVNZ789W/O/NfRn8pkiz2KivC3gYMTnLUBRqLQeMgWpT2VgTS8d/BjTrlrIA0ev3w1EMfzn//cjKr6m4o8RDUWkkIZ53Gg09S15v491/Td3ksrwz7g3tu59jEpZQhuA3u6z7NTxc27O2vgJmXgMKOnawSbH0sn/nXNYI7VxaGQFrbBqOUK+DQxvzDkXmNgc/NZmsmaGmiEznczeNoqoF8R8jsYyNtlEmoEUxQz8m6G/zsnfifpqHCFZn1HWnoIov3sOZINY7/22iUZTJ3B4ZmryVs/+6xzqn/4X171zzNPiyHodJaImMMgc8DbJ+jg88jwR0rqL8UGo5DvntUFn/bUp5XTox67rLaSKdVX9Zise1OIcaCOOOLIAkhR3N3vSSnW4ZnmZBrjpyfZ4fEcnpuhkDbbNRN98OpSjvc/cG8ZBVGc1gdGp74z9yJq773VOsOIDhIIKcvuRZtj1qp9zT3IOACleN9Wodv7r5D1n3LKaWXw3NOtAZapH2veFzU/85lamtaNAxSKt5BcXB3quP86/PCKRhYlmrU36waEIkN0X+QCMcdKnLOs4/ZJZW+/7XalJNWVbB3ykdviIIn+vDiUnFRnxji8wW8qSkKuP1rR0ECunqjo0WkBEJ0aYef+GPkrU8vjpEpz/yB9xr8LMQr5AHLmOI2m/Zw3xrVSbWMI9eD85fGPEkuRWRi7VniBOXDRSPKNSKeM5DzjWQ8wnaMRNY5Zuv3eVp4jozP32QFMmptdWkp96m0vg9GApKkuW6TkFa3NFCpWStZ6a43iXGkBs76UOKJ6WQDctjJUO+bvnEhGRH2aPDG4WjikgE2KOSDOp6yDczxqs3+pmvXx3zyhqFIvSgnggfT8Hv6RD6eOv8mg60z7H3lkjK1XOxIduUGPctI59a175s/TlMp0xmuouuxa8TLfUbiXFaSLEdXXTg659bKHrUfmR29cFg4XXT9auQbZgrVsOWuD2jXU3rrOOriHTtN2pDinc0cU2o6vz/p3gw0xrFkDqXFZFzq+AUacdPfS+93GuFLr2leyqSN9HLTvlOGYi1iHXRgdD0oB41y3nWhD6tqPCtaHrXnDv72xylt4p88J6Oigj/33iEgpNMqs89RCZbyaRgEND/kxdWB4SLfmEOkzBFAYYIGRjqmifXn05hFSTHcWcpNAHfShg2pW32PjRYMSn33O2WEQ2XLmsA8fWt6rFoz14vkadWSSvK0dAJVxvapTZTHAvG2y9gyw42+mBnt+ptdLM/AQDLrFm/mYDF6uWYwiuGw07k+v7kmr1G8U/PzDPDy7uSbd+RFGL+p8ZGErzTlhq5/UvTO0NZ7MT6Z2oao1TALrM/XdFf027dkQ5gbluPd+1XuAOooUfHjXreD1BmKkuSaj1HjgDMaVV15dM0QHAm1pmKUylDr5falgACf7rM6tvcW8RVFSN773dxIo1/IfMMQfk5r6xwzi3jeDo2+N960maVLF7rvtOgZJR2lLDZbnV8N7hzDW/hVxw2j8p1ikJhl3PY4bbrgoRn27EEcg74jnPNUlal3Lwxw1dvd8/oUXzBySiSkAHPpVGRQHoFoecsgpUlG81OuyiZbUWADhyimDfIzMbLTh4qofYpYpJHNqhAwJT1f0Vga3oq0gfWNYuyxQspgD12UDf3aarGRrUnSuBSl7VabmbBmWnBtSrzXPFpDssUnrU2IAKfZmhaw7dO0mQfQWPWQUm6jme9/7fnFWa61wzhwwM0jNvrz197+t7zWwYVHODKBXpx/L4cRKlGyOPvBGnnNAKWQAJmthP8gF7ANjYGKTCHnvvZ5V02seiLF+WJ6HIZX+vSGtUXp0/xiUtfOrmcT+AU5J/7FfVQbIX6Qxi2NXf3TJ+cAM1GSVGCR/dvloNvpoh7BStKM9pk4Tw+aciH1EnPMMbBnNOm11sCf075T6rXM1JLlnB1dTPyeYEa0Wn7lItwBTkaEm7zCMHT6DYXxcsmYQ4bdGgTOMmKJ+nhGCm2ZWsdmvJgGpPT83Ixi16NFPokvfo67KcHBsDzjgneW8qXlqizE5ixxwlpQivH+D7LH0vZ53jq9oZwzD5gwOBrDWRe5/WecgcgCwRjeOCHCkq8kSQ4qcnTFqg8KZt2fVf2xvrFGtycjM2buOKrtfVOqyDSCgo7XkqJehy+8GXWY4aydQ5Py2sSZRsOfz+0ftW0enfu4eB7hvjri+21z86T/fYSar2r6Ml/Nqvd0b+fae3lep5G7RaX3rfqVuCUenx4eRxVI3shMld/+HIfUz+2bWsPOyxRZbVhD4s+BEjjzyEzMLPnfsZ5bi1dw2Y8XWC+il8sRZYK0HbY01JXvV1JFEgBQNi8zbH8I6R8/l5tXSro0icbPYZA477LAaw8VTNlFFaurSS8+fOeCd75l5/vP+poi7LTjChPZqqpl28mRbKKqeUZEKQumBMkb2fONNN5bX7UAo/hNIuWzN7a3kHPBKBZXBHFFqp3s7zevnVWSPQWpDOt/gtvc7jmingecvvgPZNR7wh2Fa24Vub9vP6neTIe01dGsNx14xqFdrQWGVEiglM7V/ZI0Bu6wjxY9HWLRo3ZFKiOocVMAQvaLg+QWiqLRtaoxR9Oo5rjkO2PDC5ntyNdIsv7PG0lb7/u3zZt7872+qebM1GzFesP3ET6tntGuZfo6Rh0fvUDKC6rMiUIrBM+mTpax2SJuL3tNBy0WQc5g5IGVAcz95btEMj/PaoHvf94H318zFRQHvqH8hxRCBlrNUcrugaibLaVXJ964ethfr4ztFCosWrh9u1GcXYECdDhL9niiaMUMyawHMEGNLKVFC/mskeDkvkyFtmZq/Zi1DDvu5555b92zKkL7piy68pAYiiJo4fBQ25QxwBG1LIQARLVq0Xu0XzMBPWDfS7gAAIABJREFUYrAMGadQObNSv0B02sY4KrIKem3J+PVB2UrXbxwsghSiAy6SJC/OHwXgXkWpfkahqBdBo7rfm0P6sWRJesWjlNBwLrcsYo04EdmHa4Pwxkz2mKSOb0yU9NuasTtSxXdm38mnNRqkBg+pPebQTSaulHqn9ij6mjs5Ra7DEW8nZMj3OBMjahvnFDxwMnqTgps9NyMsnT+KdIDCGPIpunwwerdRve0I+bIOBOr8Q27ms3ACfmG+L90knbtsylpatcheGY/oPyUCDqXB6Pvss3cyNn9XpCW4ca2v1LvUuFakf9pv/5nVInuFwYjTCLEuxbrGlLa8N1kKbWnWUE12DB0fWQXndn7mrJykqeWq5bD1kj8blWufOj1bLFQTyCuLXT3J5eTQeYzr5KB7T6d5O+qcbWcpZwhIKXXxvI/RtW9dzuhz0L2kcyl1SH0kNqMtrFOu5RBEHl2HrLYhHWj7aUZy5IRsMtRKGv6swfaTWLgfa9Up3ypJRq677tqGtABPk8y1julUeK/dXOfDnFPWNgMq2xjCA991YLFfcVjxs+8YCsgF/3HgO5f+6qqrioKPR6V2URtRvTjg0bH2DmOxF91WaEkRhYfGtdqhcBXx87lSQDnwiuwDFPOQGM1LZj7/+c9XjUf695f5Pl6cDfjC5z+XgvtaM5cH2ACgIpXVnlXVTSYvize7TA74nwJBdrjuC6UhwRDN8gB51B7YfDkRNFabTUMCjtwBO47c9gBH8bLnPNIHG9SqVaZ9hJUZC6jG0unhuXRwL27byRHNDkUwOzDbVRDIqx0384qD6+eT0ui0cwMlKuJJJNDjnGYb2/MhB9yaqmd6bulywBDPrqYs4rwoh1pKF1Bn4cJ1Ktr8U7xtKW/KlyLU+ykibZJwAikNKQtACS5f/LErjjRg9uufM6ppj913rbScuuZ9qWlDn24UUBhFqi93rAPoeGqA2oCybyIUdbabb76xUsAOg/c4hGquBlbzLEf/LSU2GdJSoPGO814EA7elRqX/8oxQUC5cpKkdCAGv8EjR1ZpPEH8KXXRU0xyCpiyvNAfI/aB9w0ri/m4tZ+7S+rt7qSwIDz+GdPAmz6H8SkYmI9r1pKHk5+SB3PCofx2jdEVScnABasUvfek/luE2jQYhf7UZZU23326HasRX77c3aArJ+I8iy98KmX2xuyQyoUilGPfJ2D+pWL2dgF3wA//wD/9QzoGWCeO7OI+3Rv5F/e10rb/+4uLJNSyaMyGV3BHHanE0nNMiC0k0++sYiZNP/iH8a4YVrD7zqwCLGPLFMfDS8VqGrPl9cVqBZx7ykDEij9Nds0mrRmY6j5asQf5fw6MjXx0pFS91Radz9IscoIEVGW00/w8hQ4Nl/GZyJlvx2fuqq1ZkMbV/MQTOuDM8VbM72qoUKIF3ticjOv11VjG7tlq7nl17OsavKafIdMBJDMKJ3xh6Hgdo+5DMI8C48MJLk6bfI6QxQVnHITKGjjttSLcAYqfUyN/25rfUuYPmZmDpqsri5Rxx7pw/ctjR1Xwj2UbRe+lf9T730UbWng8U6cBW0N0MYhtIny9nxS/LkE58ufm7ffS9AJVejFAjbRvBW6jdav9C1TcHNOp2k/l1R/fF2ZAR8p3Ovu9X2nPmyGT3WTcDEWPoZT3agLuOfzf3roCAc9wp367DNqrZ59WUuxzFeNOlsjUlZ1Pw0vr7/zKkrcNbxjpaRZ/7tdDGfuiQg4vtTrZV7zZM0IIffO/EpSafaMbeKSQHULmVCktqBivKSlHOUg0Qpjx20cwlASrIu28eYFAp6nhX7TQiWsb+D7EK8FO9ajF8n/nMUVVfNQ/0zDODIDzvJ9mMpaFM+0Lg94+q9gCLZ5GkhAvpJbLQ41NUY1pKwsCSOgIaK9GwOhzjoP5EURNO9+n9amFXXvHzwMzfWlMYLLh61f+GWm8M7x1CNL/3TRLJiWlezl7suT6sudx5K9KHBnlc4JQyoJ1+GinegU4bMPE6EOS3NrJcwVqX+s+7pQbVH6o/cUF5WA1i8l33B0iDhakahKMovaBX3Zv5l1DVl6Ye6kVPSL+bV6mWeHsmWgBmiSx41MZ6tREdgmutRyqkKLHys+uvvzG1otVm3vCGf41MPL7IyUXAt4Ui0ti7jSJI1s/hIOSd1uFIaSPyXJTmzckWXBXHye8dmO4PUy8UuVatjRNWNegJWl9pUkxPqWnkYT71qU+FdOGkAqetmJpQDTkwaGFKRw1lCliSAxdD6j2MlVqWQySdum7AI9pEfKf0EDANIwGsZnQaQ+K95dgAP6SeNL/BnSHtdPpwfsae96sPtBqKmpb1eetb315O5KJFi6um7VBLsaPCRDpuQPSJoZ5EPoJw3tn6eubgQiM7UGrN0qvLx5But+2T66s0g//q6isrKldz44hwVnoogTShWnQxxMQIiIrd2yU5G4McfdU6uwVYy35zksvgJUW+wvIj03HO2WdmgtO5QQuvEmdp45y5ewogVrNH88y//u1ttacPf8QqFS2T2eo9zn0UOUnsWXEiV95lABFli9Tr/gonkGsNx2R2Geci0skIzkajLdjTWarzJCVce+/vY4hBo3sbeT1abDiuEyCpMjvzUrsPMqr9zzausmI1fCDrIushIuIcqPubH3vaGWeVY0uGgBHpTAOlUQOS4UaEolo9JwjoT3/yiGQnti0Qk3skK9bF83BmpVu95td3Z7NjUzmB3DLgWq+6faUdPGeM/uo5vx3FtjH072pV4rlMTkgFD7kX+hemghEFtmrgmP3j8NE7RfQ/EXKUzFegM0pNPieadk8yIv13RvTWaSg8p6LoAfOM3WNbnR5TC2FlJAUT2YA+30UVmHMrm0HWq+av/Bj5tTbuu7svGNGO5D1TfVeuNUhZ0ufLsZv3GhH03AhMtmF+MOStbQfoFfzY70mWaadkgpRk7s7zGuC+4IrLL12KQ/KgD304YJ3nFmOQC/FmeJi83JoiEQWlh8fvHKJLQ6bsQvo/vXd4n6MNppUK76/rZQYZI4uXipLP/th/H1FpwqOPOrKAFtenluQalRp+1KqlIOoEUPRVZwEAGSwjvw56mEJeuHBR3Q+QxuWXXx7o+dklXGp4FDlDS2H/PPRbDOyz9t6rNhnidPWkFG0UZdVE5AVb953T9/Z6z1eYD96EjlrrY6X+rDzP+cGp346cJoh6edBjYj2Cc99ZXnNvPmOWmnSnxa5N/+0NN9xUEUl7ipiB0LdBPl+UPl+KX11mxbQISU3dEGPBc/xDwF+/CD2cdJ76snvk2Q1jUFw9Fa3zLCmFW276TXrYNkzq/e2VevWdADsD0PCQ6nt1Xxr1ycaIMs2yfdQs8hJ6GHLU4RMNUexeDh2GLAZtgBJkCBjRuT64EnyRZIyhTMYxxx5btSMHxO/+J44bxVbggCn1J1IRBS0XGkO10eVSI6XMbs89UAiQmEAkokLtJrdHMVCoa6R3svZg2gv3OLx6s3bHs9VhY0gngMz8wzX0+yCrION6CRnG78ZAHnzIodULCCVsD0Q4jKmoF1OOyBAr0+te95rqbzV+8OMZ07T88onSI+/u0Xerm4reRxvWQF3uueeeiXx2L8NE+VXfd5S8dKHnAx60386fyFZtTlRMRrvOS/5HfSitP3lWZk9W4i9/vj98vD8sWjSsP+tl7V3/ggt+WkZk1USyv0pGhCOMnIQBQ2wPqet+C0VbKMhxnr0GonhiJqrIc9TkOlKsdZzqnozZXxlQR4qzSnInq1tncrJ2I39UG1EGtT4/GYc+y10W4mR3u1td40GGtEkhergz4+jq6srQmVWTq377FUJV+tREJhtlotTXquQla1iYgqTHDQ2Xtt9ow00Kme112SWXlawdHvCZrzWIwnnlRELpe8bRvtGzNicHfZ7D6POG1dOhMlBtcKu9aJLFckxrb4fz12naJlSwJgxpp8hbxu3RYK3L9KbIqLVQbuuAw3kfhoeuHyWCbpFpg+U7/IeuUjTJ8W956/2u+8r96qP13da0e1QLrDZl6zyPf3MAYSKULQBZrRM5LSeBIS10/WCWYkg5i5DTbY9a1souaYUqOZkbaD7/nHeQVYs5vdrBb4fz4ESkHNP1kg26N0FdlSCv/tUvUiO9dubv9n1hkGVvj8J5TnGVUiwAJA4vQ8coiVZsitywPjeKdYsttpqtlRZNXOono9g8QCBGzBjhZLGgbH8Sj930EwCWww//2Iweuze98V8rlUbxrh7ycC0NlPJgTIlAlJc2DokD74GuvvqXZRQprbvuuieG9JJq3zj9jB9VW8FjwmLDwy9iA1MRMFhk40VqW+aeF6UpfeOkJiu1GKEA7vGeqg9MLS/WUcQ67qERsvNWeDqEHZ2UUR0Zo+HVTH1fJeCUwaQ4PI/rFfLW6eMt5x1SpDh9Vw5dIWJ/7QYUr8HOEHw8IqxHQCLQtp1+kU2wzrxA6T9Rjxuh7BBnYFzijXFEwPtFJKIvCGmfg9IkjIAq+hs3C5DiHe94ax0mLTOi1YVJ70k3chAKYJI1KVamAHs8JmHDocy7o+gvClLRvXQKpkkRNoyCVzcSUVZrUp5/+C7Daeo6rvv7whe+UDNhvZ/igFjlrUqtqZF4DdkYStZzizDV9DkQ0pEOzJOetGVqjLtV6gxqEeUXA09pIUOQ5h54ACl181/NoZRin9pcpvurVgpRQfZ2pPsGOMM6IXn4aYBvm4cT2YF91atfU84J42XsHTlyb2RLSneX0GReeOHFVfN8/eteV0TpnzvuC4lIv5r6y4aVIgXacz+PSxp9vXUX1jUuu+ziAu3tm5aLSishS7nkooHujGKS3xAlLh9Fw3AphZjcQo44GNaqFexQwgOpuGL27i8xhMorescfkdT+z+KcnhS6weXyHNtkrBeqQyWY4hfN2t5Tg9PHOkBl35s9cd6siT2ynoO0ZbSMjehMOnI43u6jMjRlKJptZqqRTmncijrHt8wa0jYAs1mBPncM8SRHBTKakLkj+zLYrvp6lCxj3+9nxOf857GvKAJljYHaEFlsncEZap8yM4bBc0K23OqJM1tFn9wX9Pe5mVRlqLpMiJKHKI5h3WqrLYtFS+bslJNPDTH9McnMPbFYwih+OkcqmR4gz4N4YqSlS49Ma0T2ODRj0HwCm5oJOyj8OvLsXs9O9/YkFtmJUdscE2JqbeZFpENfjdY7pRd/ugaWom6jom9uTWRNTzpXAHzOkp8vDPDNmaLnpZ27z9MeWYNG4Pp+99IBAr3QQKQmMRF10sv0DR1SBjF/ryxD7lFb4QD3aZ/RXkXORtsVdL2WQy+GnC7CMNbrwZAO2ZvfPjjXzVG6WnZgYolrgKfPFNVp5FkLHzKOS+Noym7tvdczZxYsWfKrqpHut98rqi3gn//5leXpWCx5ZbWYDt1Fg8YGCbGx2iDcVl+SL3Yo3PhQ7sPYjQOLGSk1uWpDWD5oxI+XZ6cHRxoLIf3L99+verE6IgV+6Wb4EeGOh3YY9DESMpETQbRJDD1l8ZP0Z33v+9+rXrfV10B2kNTgRGDNk+GlULLDg3loWmaeX95+T2SxgBqja77cdOgobKPIKmpU5yTjk86vOkMd4gZIjOileUUH4IGRGumP9hIrgouBu1eawvSMCArHQs59KLZRI6X8EJ5j0pC+XQWBQyKlc4J6vime3jopdNuLiqbyHcAQ62V+J/KGdZPOxuQzmFVG6lbdG9jFaLozf5y6cgglGDqp2EplJup8QZrEn5lox33/MUAcM/gAHzbYcIPcb9ivYsyKBJ6MVLvKmPIAzegA3peWl2tS/zbLtg++56PE1eHN4eR9q6tZS+lYxBzdj2bfvff7aUx/z3veU/SFoO8a2f+cve9hA5SNz3rxRkUa1oF8Qjn+5tdpQ/jT/TXyapsosb/kwEEVY3niHPJsPBcD1PLtOUQa/apaTda1MxLtCPXv/dz6Wg8MQJ7TYPjvBgB35Cc/mbrl48pbveWW31XESiGZFoGpSF1UK49a6rPS4G+04CfScy0K5a0bBE9+vL8IM0rO1651XXud9WoyyaqrPmoW8emcUN6PTpnE/bi3oljMPuqD9Ix+LqPQc1y7kb8N0jiv3Siv/Slc21GO3/7Ot1OTvzrkF5vmGe7M2b+yFP5DK4tBTv8yepex+ZRxHpmOYUhFCsOQ2ltnoOv+3bIwuHFHHXIoshGR/hVqt6NReoB1m15tGOv9DM6UupXi7VRv1+CnYHakDeu9I5atz7mmG6i/j78a1M1pXSsI75e97MXFh+08UJ44cO+O0+mzeLoRzng+Ke7fJUPk77IqDJGZt4sWLSzU73UBIr397W8rPApCEvSUBbyBgZj6W2fTsZGnrmMyTJU54dy1E5cbteft1Pl5l1i6xirrQb+N9hGgnRCOTKnd7iMtANgESiowlohteC9Va+62Fc+EGc04uHUjg55d/zJd5YWH2/eJINvZaSCRe2NkZYescVH7VeZnYGmA72AJMKv5LKfQPbmm6zdAiYxygIchjR2IzYF/YHg7HVz6MD+z3j7rnHe/KkPa3AJjHSdHbRK+dug7Cu2z7/sYUv+mJz0XUJ+WMk7EghtvXLLUaLAXvujFVcd4x9vfkh6pHadG5kG/dG8i1Mpj5+ak5BxqNyn9I2W1beo3Dnu/pw3o/BSSPjYeBkX+ta9/vaDgJ6Up+Qtf/EqM+EtqyomHBgwSYVYKaWL+mTOkmmxRVQ2PVnr37LPPreG5Wg2uSyr0pKTKPn30Z2PcNyhkKOXDOKJ/EvERAoIlOlgt3MEOdo0Iy3OtlTT1Fls+se6DJ+Q5pMukx6pvUDok0ddDM+lkCPtQGHJi3VpTwjxFbCDYvhPCWGRRUVwcgMGc9OfqFUOPZ409k+/ldABz8aIeiLHVH6pxG7sNHtmef0eAvfByek59bTzm9dffoHhuCVtdN8Ioinegfd5MUu1A6szqaWp6hFnbAwYbTDs+w8COWYU5LFkb/Wo1YikH18GS8h/I3ABH8vw8Qg6MWq00vdfwTH3XPWUw0OAR/KEsG5QVDxGzDBWfNeWh//jHP64+SgK/WlKv7qWa6xM5j/YK9dCRYWhHCcDNZ9fIc0AR612WXnre855bafw/55lq3mh55KOWVvW6fG9D662/5+hDOsep+//2HLtf+4kMXomCgTMZoia2HHpoUWQiO/A95NkkJYYJhaHamtKIDMz+++9fbSmficz++KwfZx9MXbqzjK6f4+QlD8osqwc8RfHuHJTgPvs8uyLE3/x2jAG0RubH1hD4KIv/MSEoxgsph7XuloTxfAMM1rWh8gVLoUwDF2L8THBC0qCGKmNzzHGfrTUFVFt7rTXq/BlHqMf3nruTSUmkf3dkfaDqRXQDJV9cxRzHooscDmVxmk70fb7bNBue/2TH/iqFO3AEc8a1LOWsFR1yM9K8Pj/x7QJAyUbkg4XqLiDaUJhjwMQw2qOFZi7N7PcjGyVtucwATuWzb/y311dG5oQTvl3nF8iSzlw/qVsEC5/PkO+fX/HLRK07JdO1KNN6zh+p/Jx56HfnUyZI1kG7ksEEwGVa/TjLxhP2msCEzPbATn2xXd/0nG1M/flHjFyTYWmFXwj2yDXdRR+7vr8PEh0ApJSyOPhThM6gNS3fiH4HGGmgnaOvoqsYYXIjY3VzUMVIb+AvEIUgc+f4/vDkU+qzOgfGOZrrCYW0LyyCLFi+nzHeMHSYepMNkKeXGEKOnUwVFL1nYESdTWumPKQ2zPbMB0E1MMkz0Ik1J1i0nGdnuJWmZPjozQJDzZJzzLUQztIp5rnbSWlDOidsxlSObo5yvBOxVrAX3ap2vuD6669Zqhb3yle+Kmjaq+MtvXnmec997mCByBtGw29SalM4XK0oUQguIpI14kn9TB9qI7QalDEM6RDu3uhVgtb6SdoDLIxrfvVr34wR3aoOrIZ5qVrTMLykeQly1zQqf15pmhHpUTDqtYZy7xCawH3Sy8UwfPCgg8tgSzUSNlEodFzN8gs4CjAJeMZBsrFSBUjS137c2uUlUkZrPvYxpVyw41CA4OuEq4kBqhczaYllqun5/kqDd0/T4GgFYFk+qbsbK3LGzCH1sSRrbS0q4ovCv5uTEqEB7DBzVL1LZNrsHEgNvETGVadBC/eIFWvo77LZC21Lez1zr0QLm9UBKWh4FFw7NQMoNRwiTfj6I6WRpDkbYMCONXGz6MVzEHrRBmSn2jjP3DXUeyotlu8qRGxB8DNdpnh6r5+th0qhe24pMHzIi3LgOBWiJCnYhyxbFelEioksRaSRFQAO+3ngge+uyPFx2Y8mkCdTpejitVekM/XZ2kPRtr14TOTF+7TXcI6euecehSwmg92SU7KUNbn3j/fmnh3i+ytCGjSJg6Te3pDd+Ya002ezHqsIb4qwyBxHabvI4MEHHxxH8RtF9/fIkBtQzBxBciVDsO+++xZA4ZyAFv7+BS+oerHa6CEZlzZoIGdmmXQgbCkHSOk6rPml9olnJZW0dRyT8396flKtl1bki3VHuw9wIKcDn7H2IAbW+gwKROxjUXBTrXc+yKLXVkQqPVa2iVMokkyUrrSDb/vE75yUzESQvDEit0RBam3yfo6CsWqyPRTOXNsG2Rs9gx2ldF/pWGe4gJF6HQq8/z4MJil5cKQ6KZQKG6tboG52pPnJUad1K7qaUs11rb7QpB2l/iv6mvfzIoFBvpHrmDi193OeOfOqf355dStcGP5mQC6O9dMzCYa+80ycx8989otJo8eRyPMb7rFsoll1Y/LO0aEPVk9v7z6hsNxl56emZz4E9aFpZCjInTQp0JSuCX+v6Tm5L9GVc9pTWHpko0eAxi+K0dKLQ5d12t56CwY8m+t3O0plb6q22EPPh0NY5wJqeGL4GcjcGOLcR6dG70pGT9aJfqNHfxFHTveFEoOMi3qocyjb4kx1FC3zpYzl59K2t0YPQuNztKtum71THunUM9KSQRYx5t8+KlkW85PpAvvdsuTZOsPhftfOefl9gg5DNTyjNZOdKkcBKlmvdp2F7sWfi+5bBmbb3SbgY2drrG8PX7D23SbaZA4Lrrzi8qVLrrs2UeErY2gePvP60B9BE1YLwaQo2kOvNOWUtlVHcXi+n1TqnfG+dt5px1masgejG5vnsSDWvLQc9h8nFWZckPql2ul6UTIWhdf9jGfsUX2nBKj4YEVVEdAR6keQS8EHfZnfiarOv+CCMkaMFYYRCvwDHzioDicFcNNN12QT1wpJ/BMKxYhPV0Rg8+W8tY6MHsSVilXGBm+8yYYRoEeVslXjkaIi2I/Iz1AhNghL9AW5vPXWWwTcc2N9fosnbjnYcpIalZL0XF5SpQxONf/HcJenHkNpMwrVmM+MqBUf6RgrNDYdCCEtKfmMe7kqbQmLF68fQ/GMSgsqxBfPsJFts543QzeMQiMYp0pt0eQ5EEAov49QG87MyRj9k+rIj6qUvbqEexXBMkyu3ajL8u5ybaAfWYILQ5ZA0F2H8pctkJI2LoyTBdE52qFG+lBNupRnloZ353AyGIcedmilS4BlAB20enS03zl1h4HzxsnwzGsk/ak+jEYRF7D7eOEL/y7R3451gL1Ez31YfP9DE72QRwfM/osOKYGel+r5elD8fEewzwIZ54Bdnvm0nMKnPQ094v1hfXpp8dCi4Wt0tfVEX7h21pThvGwaSfjsAKA4TugAm7lF+5Y0uX3mGFG+AD2//vXNJZ+7BuCizmzcmeEDt99xW2pwW5U81N6LFDl1kQcp9NE+MBSGjNBcFNpZla7nD1affo3ox0SjpN4iF4Woj/xJj385SHvlAXVUEYI1rLmVIdVwNu7PQIVGog6HcPRnjz8HUUOPN2vFz/h3hNgpWoq005a9Bx2Q/j8tMgNuNFLCeVO/j/Pg7xymasWZ6jJDQY5P1H9ToFu6K/9T810UsNqBB7695FUZC9K26v6Rrx2TtaMjRGp/CPnMRRddUs77BRddVr9ftDBAyFzZ9xqQYD92223X8Ek/c+YpAVwC7gB5ItkYjsUAatGVDKk1dzbgGyr9qQczL/vQSF3kCG1M2qC4f3qN/lGjZai7XcR7mtt76NaRHfLw9IGzrQ5PjrqOyZD6+aAPHeW6mio1gSk5/fSlTKKMYF0jz1JGLwvs+3qsWvPlkgmZIb93f23Y3MloN3rIbMnFzzy/LE3JJPxNrt8v++ElinUm9ESXXp9S4D5DNkdpI/2r08CJAYgdGZI553gOgDQfYNRgpVEGGGWIgQtBZjE5fJdeeuFSCv71r/u3Ss9od+AJr5E0EeSnVMZoTKeQmydxolvKxvw845n0p3ktCnAIovPB0Os+BP600PpxKObzQqMmDWLGoQki6kNPf/quxQKjmdn4tWL5z6YThkFw/tsS7Gb6oHz9zDUQ32uded1rX13pg/dnQO5mmdM4jOlNlQpcfrkVo9DQOyXtGCOuvkvg9Hn19AcRmc2g0NR3vI9BUWMaDCIPqbSbyMoQZdH0P77spdXDqjXoUdlQaUQ1WfdfnwO2SGTYhq5ItasGMmb+UVDGe3E0RI6jTrMgqeW1BrIyf18u7QnnnHNeIQXf/ra3JHW4cUXCf4pBKQTwVIvt9MRcBCAtMSD/vPVBGP2XinxE9VJ4o7F6afXePjZCORC1IzKDbGaQ7I+1UZNeJdGWVO4tt9xQ63djAFEI+qVTyYMJPe5z6623KSPK6PX1ll1uDqWszoneDtL0IxmUe1YiNSQPoqbbjbcLDKup3fxJufdoPPI0BgSsO/P4TR5fB/mMM84o5Pl+++0X5ynOQQ6sl1Slta7UWL6fIWU3/NuhMtLK/Q2GlGFwPHtzGrcM96ETpf8+rUDq1QjdocMP/I/3zHw/dc/1A2QrEFnuHjvRw1d6ZDlDUtsUknP0wkSjZOiII46Y+dKXvlRwetOFavJE7gnbDD5TtSORD95eKeqXveQlVQeWCBAJu6ayhrQ7o8HJkFbksGnpMblnKK2B4uSqbGXsAAAgAElEQVRQeM1n6ZrPGtRMREOBjSkYjQxFp7hcnMYHMp7tO9/+7szFF/6kzrN5vVJy99w7UraiPM/YxrGzK+U4lSIaLSgDKDKQpeU45Jl7ndsQFuPWvJC0M1sjYh7qtIyiVO3Em1vXANzJOnK6GUYO2SAgH60V9Z42vtK9k4HlSDqrWv7+48B3JNPzxOzLaDm74cbriqFLNkNE+aTI9sL11yuj5XOcR+1O3//+D9Oq9vsC7aFTvfrqazI04Kdhcjto5vmhMZXutZ/WV69zT4lqHdvZD04qA6pkMdZsrJ3vK+xI9no4CEMvt8J3L34+EOIBkU3p3vlOYBneyZCO1Ht6TJ35Sbd2X6bUbp0h2YYpmu19ojO6BYVBE9z4TmvUtV1pbXq1EcNlwKbvaNxAp67pdOdv5aDNYUd6T9gjzmr3pQqa6HJ/WvMaJ5h791l6vVPVHam3sfRnlekm49kO5nxjOgj/58BGHZEOvT1XVpgfqZYMXnzRT5cuG0V/2GEfDkLy85k68LcVUQm9TQSXbmrhHXRbAwzjwNXIr3igPGxTDxhSEYiN9LvZ/qi6ub9u/xDR2YRTTzklbTFfzqHClhQi7tQzd9xxp/od74TANLTZxjkMAFC8Gzl0ntRV6UG9JsLKMzYIXBqPYaNozs7EDYdnjfRTiqBtqENHYbk+ZhKRLO+dof5NptmvEYNAGVx3zXUloI0KIwTugQAUYCMCoSfzfwK4qZRcFOt16b/ksT3hCRvXjElGfnh3vM7/qedzKDXrM8At8BQcpSuV40VBOWirZz7kQKk+kIOcqSUbLU5byjtrXyAsVwhoqziEs8ed/pxLU3QtaByyRiR3Hx0PXdSnx813qCerWzBien4pwyJpSETqsLtXURH6OWspGqfAMbmA8YuUZAMMPd5mm63r3/cYoj4ND3CflF1xFFd/nsgy6e/UGD999NFhBDqnIjNrcfdUn5pVnHlAjssYWI4/djSlG3XFiGJq+sbXT0g/5lNm9v+nl6d+tf6sQ+f+C8Gbda0oHfF8pYUGq4oUvEiWMuAIuCfvay7lVkCdkq/WnNz/T5NalYJ+9t7PKSIMVICO2sKAD6TBMAqtGiPjWlLyxqRx/J4SRieRKUIIg+xriEBka6zTcF56wLC/S09BUzPWez5j94oCnY9zzz27nIcdd3xKNbhDwxbhQfbtO0nB7rTzjjNbb7nNVB4JuC2/I7tV55nXNtQO15jNOYYc9zMzKn5vrVXPZHOs5arJOvw0veA/+MH3Zy7PcwAQPvKRSempk+ZZRtlkrsRQBna2VmnO42DZaWs4lOZfI3NnU64PMqTzU7Gj5lkUtqOQWlptKqrmrz2hytoA5gxE9mDR6kHh7VAxJJQ5h/g5IaXf/59eWvOIKfDiy46OQvqOJ3nUBxfO7JWJRXenfHRpWltkcIxCdH8XhM0KRzHHU7/3Fk/cauY9735XobivCGWnrMHqCVaaML3rdH02ySDkvtGVnVqtwRh5BmeZzOqJbMRryyYdQMc1OrcnqLSR9b3uj/ygF/X+Qr9C6k5OzvjZSBUXN3L+Tv+412YksnccZqlX1wOWdN6ti/o+nVcBSZwGa865830ye8hSmvavGYtGJmwYQaPoOOe+l3E0PQzQi24hl0qAQz5HitVnfadn1ePOEfbzjnq9FyagnGZnbQoQhmM/F5XOZWvmYSKmFO8QrJHt6J738bPhwC244YZrlrrpf3vjG7MItxUyb4Pwka4WhU+pKCZXn40m5nyo6ANxm0JiJvICtuDNX5D0qg1glCymKGHD9NANBT6/PjJqEh5WmO3GTj/ttJljjjmuohzIrU02fnzV1aQeeTkWk8KwWX4GQWhyh2iGcDOiKORc16ICRIBnv+2tb6pRZ8cee1xtqqjX9wERlEAxWHkOTdEbb7JxRSzqGtJkFSHfFtBH0jKiUmjVSr8AUGQztOgwksUElOcAiRdZAiLYVLyy2gTM8FRr8bN1M3YHOb907iCNCDF9FPImG6W+FZAJ/lo1GACi8sjyPN2riRMXEOVjHzss9cbFhRgjIOoCjO/8RvchIHOINLWX7s2qQxGlImsALIKhxsSPdbJf9rm81xyq4fFnn4pAfnjwojB/5zBclqHt9mPU1PIM6SmWktVPt9NOAdQETCHKxII0i+KOARMZu8bD0mcny3BXemE/koHXPwxwbXEMDYCGterouYW1/3QIRV7WXRsPg2Qg9vHHf6d6Y/fb76UxrJvFCCIZGM6bQ1UTYaSTS8+O2prfa99Rn7noogtTc8xYtiduFodw/QE6onCa8zjXqfpb1ketRfYDMf3uu+0x85gQvr/utW9IDe3CcEhvkXsLkwvSkHi/i8MlvMJyI13FCRDxi1Qo8xOOPz61tc8WCQqjwwBYe3vH43bPrgG5zcl5xSteWVR9fg9QJi38yXDyGjj9xC03K/pEPLhacc6LkTfy7F8y2o5HjxSCIrn7vj+O9qh8F8IQz1OOW2Sbg2BtGNxGR3afoPLBilVaSAtRDAuFt2rkEeHGid/+VoAzN8Q5zLSZ3Je6+EDXS+WOPRjI3EnxRJd0pkDqslqVRjW01dUwipPc/Z8/b6PZ16TmJqRwO1+l+vIz310ynM+U01AAo/H3qvAXwlcqP1mX1Hw3Sb35XeHGfeCBu6s2R38xaPcE8Yrdrd/P0OzwlB2qNkj/aEmS4uw2H9mpyzJjma7cZ5/nBnexVqYdXVMO++LFG0/ArNHz2e1cFTSg35M7LBkdHLX+K9BdriVtWfsyBQQ+05OoGJM2op6J428vu0znGqOEod3wjlq9Wcci3+ezXp1uXRpUkvVTOurWFdcbval/KYMpMOAIqAVrDan0q99nfZWwRL5NHQk74X6brrAoPXPPg8FrhXL0gENlyqSE4VsWJkN5ZShGGe6iEZxkplPNY+rWQPY64J6VHmn6wzne3WRXFjghczzr7TR2pnB+pqbWYOJkH2I2UruD+W60/LmH0mnf/8GJS49Nw/tF6WnDOqFwvFl64TaNQOgTVLDfKAbRASrLPhWheQUavvG4emlG56EL5SsllsXEL0ohUdpzacZhSF3PAyNK8KD6Uj/2sSMKoUoZeb92iadEUIFOzj77rFpIP0fAgOez0kfZeKlDxtuDgijzDG9JtLrFFk9Ms/trC/Dz2c8eF8X30yj8DSoqFDFU/Q9Ha4SAcfVaM/2nJZSJYlZLNGFj5d3B+xeut7C+o1oo8v71Y9AenTSbGqM8PKHaLvM4r7jyZzkwGcg7za3UlmL+JVQwePdmYXfy4sWqO0HtqaMo3t8YeL3nYRwJeI2WiiD/7ne3J/X5wYCqdkpUc30JjRRIj0fqhuiCeVOS82DdfsYZANCxfkgJRkoItH25gvcDCDLabUBFYwOkMlJh9JC/g/erFckGeEldLVy4qJC2YP+7pUbNiP5BjW7qFe3ITmSICUrEQnYw/ByZmZunn/6jAiL0kPFC5k5lhNHmMgdaYwy1qJAhCkg9//bbM03lnvtnXpqWEOUAiqznCJYSmYi229MukNWUTrTGDucFKTFIK2+91dYz6yez4jvcdw2JnxQLWXPfyh0/SgoZrN5s1i+GaOQjHzm8ygqLkuq7/74Avv7nvoocOZMcwSuv/GVlXND6MY54byGT9XBzOqXolQPqjKkB59xYW8rr2muXZAbms2ae89znzNw/9S/ax2uv/VVI0785s0GQ2lulRg+dKOerRYNRP+SQ/0qd+MnVd7rjU7ZPTf1Z1QpV50bPXXn1HA09lSazjOHN1boxtRhYp4F0Hk36y0amWR+p+t8FMUwhOwPW7+ijjyu8w5OfvDX1XManEdJdKhgG7H9ngTH0xCBrmGq1ZdymTMpkLGdTsZ0anhyhbn2ZNZBTQKoc4Pt9rqe6dK12Tg9NvaUczvyPQ0uZyxQde8xni0v81ylbOF8IEESiolsyC6lL6d82yZ0ULNDfc4MQJ5djDYNozzrLmDk7nCvBAKAZDAE58tI/P0gMRieC/8qQ5rOlA4YGn72uvSiaQv3ukyFbOfdj+IIzqQzQGTygSjqJE8agejkzjfxtInoGS8SutCRQ6jTsfIej22qa/9ZzDbKN0dYCNa/vmrw6Z3rbOxEqu+W54Gr8R96s9fwoWgSOXrQy+QEhwkAUDqG6Fx4oYJ2Axdm0J/ORzCMwU7IIEj/35VW1YRm+7GtNJcpawubMH/YOKDkXkQ50eBvS+Vk9lK1jb4Z/13X4fk8Z0k0ev3HGqN0ftp/FxdlpSPbTgkhjUIETzMijaBbnsDaJvQWgVGyI9JWolBcrsqRotVHw0HgTCBt8ro1ppxhKoUeoeCRqcg4sY3rkkUcVCQCAioiTh0tZbZ52mW7XQC0lImMcKOBrrr26vEVSV8Y/hge9nRrTy/f/p0oV35gI4otJIX/3pK9ESa1WqV6e0xj0O9g1xoixNBwnypIulGoVrUn5iVI2Sc3P/fPOFNnVTj3HzakHepmjamOkiTVh/y7RMOpDwB0sNCKoU085Pd+9esHKAZNEd1IehagtzxE5dYxYMaoELBXhwWi0fQ7q+973vmJt4gGvmbWFTmtWDikU6epRzyBTA0RRGy+ymqINaSl74aU2Kcp0KEc9y1xKaeqQllcLzTC8Q+ANLwfSuqToAx8RB0DkDhyGvg/Q5tkBPqk5i0QZk4o8J8rDEjbP8/BRB9b2c/Rnj4rM/CjXGS07yPErxcQbr7ufayuifJcJmhJT0eKgm62pw0QWLrzg4qR0d5l51jOfUcAvzwWqj5RgfmR1Z+qGPNdHJB1MeVZfWJSuw319+gIZxwLymCGb6yAp6BpqGYIYEyk1KFue93Of97zqp/6Pd7879eM7ZrYosow7K4qAdtczy4jZ02vCTLVnUMTV0xr5PDclh7e+9W0ZCr1b3avUF+MGvR3TVsCzHXfcOYbpssqSvOuAA+paPB7pdk7KremdRpjOCTOowZldPt97xZU/r3qtPsgqwWQ9EOCvF4dnn2fvUz3B0JM1fkumScSW/zV5eU/ysHbqrGTV3+kDfy4TY0px3RnqSTzPjC4je0Pq5Eg0EN1bRxEPfdAcqm1MySSdM1DEsgvO0RDZTtWSnZ5N2mm87i1twzJZmPqgrMv8GtYAFc3VtLqdo+Sqvmdw8XpxVilp7E+vykjAf3zZP8boXZs1vqs6BxikC7POyiyyn8PpM6MZO1YGO2cdyd9WaT/jPHiu24IfuDnMRXAmnvUPd47JSHpKK7iI7jCicsGCtMiFN5xxIWvWqMBEUuxaf3J/HSV6T/WN533VWpfrYutqx6xIRpSIcqb93eCDjVO/h1MwHarOywRgbKPg32T2xpSN6PkCHUINa5MpgNhoE+sItaNftXfnmFNZCH5p0zKsQ5eq55MJYDy6pfgHGLS8r2u4A1ipNz0D6KPLGM1CeyfUhg2QjXQPdG3N5E3Ljc2ToREscUBdy/pwsEuOIgeehyEGYEVrqY5q3QeuRkAwnPC+l9ZxzTTXDs1sH/MUmFSChPBU33tXEqZhG+svXm+pFgE1g8vy0GZ6EopqJ8hi6EOTm970CSOKaug6YnN1HA/KQwDsELVdfPFFtRgXh2hBytjsSorSoXXzAzmWgcBy2FnY4U0gaV4x0cTKheQ9+OAPV93TqDXGFrIUbFyEe+QnP1Xe/NpRDAW0ySLqaWWkeGqUuJS0ugJDjuhh0A6mVpVFR9hwesjPjYOyJgwq7x8Jw01RBFB0L3/5flXrdW+8NoIEcdmweNcR1SmA+++6RABXhPHFgTs/Sl0Tvf9E5xS/CFNUau3UwShMAoAIgWfHGHSTfM88rZmXUYKo4jT0H3jA26oX87bf/67uF6oXkEKUS6hc36krI5nnEsUNhB1QQjhUcw+DFk+PXFpz8lkKkxBK9fLWGHI9mK7h3ytGuRByVIQO0nXXXTNzbtKZWoK2TL8t7/fHPz6rnmGvtGTwfCG4m19ZRO5Vk3fyeT2s9sWaHHTQh8MSc1LaOLYsRfvwIFPJiz5fazHYmcbLd1N8N6etRdlhm/RrMtwiuPp9gsanhiloxcjQOqgEY+Tv+eN9MaRjqG9HXX9ORCyiqhRQXh2J6WGzx9/61rcqDbpeMg/aPhg1HLudhRFZ3pj9xs719F33yBoul/LB27MGZ2c4gigsKM3UxRlmSoCTAYB1TZxK13K2/Jtj9P73fyCcuVfHYYvjEfnlNTdpPlDPULqPyZm8tJyTA975rmlvR92I43VPIqGLLrqo1mvlyDe+1ztzXg764EGjRJGyjBSg/VXLYnBRJzIWZKlmmCbC6uzQ8omOSpFn/0UwznFNpsm11fP/FCxAOVXZDy9OmGjGeXRO1lj9sZVxODLEEnouh2JepQxJITXJfta5ATDOX/UGY/XRClWKe3j8DHsBk3IGm+BkGNuRKq5ogIKb3tdk950Grn2fd51O95bpzOcHa5ppUspBy1Urz7bbqmP+R/i4E20nu/Kw9Is7a2ZgnnnmWcFerFotNs4N5jQAJq0Z9N+NyVrtuOMOBbDznDJo9JuhAh1tk7siiZlwJg+dGMjGAIaR8Zs1pJxfpRbRW9a4yhG5UHcwMFzSv86+9bEPrtuIXelj3QzY0HbPwAn7ybgyVsUmVGs9aP7sHeAg/blM7hGIh74op6lqqcMANsho6HyTksZ0mmYnoo+9F8hSic+1ZQPpFdEmXe09Q7eNPkzf3TSC7JA1sod+5x781y011S4T5/fS4BkEcNiifhfZg9dYK73NHBhZNSTy9BtDirLTs4tkRzsOdq2R6qcbG7Rqbf3Oqw1p65/Zfw9LOvaCxNYwk5HVWbDTTjss1ax68cWXz7zu9f+Sye/PrkWzMSK0RydVhg3DZvYkcgvJkKpDjkMSuHIe0u9FovLbDCASdd72c2IE10wBmbGbPQTTXc4PoavgnGvccP1NqR19Zua0U08vA7dpIlwoxM1Sv2Uczz7nnBi9m6rJd6B6x6BchuVn510484L9X5aG3w2jyFatGhoFTSDU4GyoOsU5iQgQQpx22pkB2PAS0wgd4/Sa17wmtaj9c0juriZem8qoSN8QMHU4qUKCbH08zx8iOBq0u6dV1HllWhOggx+V6KcUSPoJnagxLHsAlaSTfH6WaSUbXIFkXlKaogG1OCk+s1v1q0JYW2fXJKCAP49cOSjhCR4PCVr0gxEK+6jmekVSxgScg2Huq95GxpIXLv0oLe3VEe04KOrAyxTaWQ1cdIVY4vrsDYo79315OIxF/jvtvEu1gtwT71JGwPN1Wrum3uQnhnUzFJytTxx5RGqip5VHueJKy5cX72AXqCtRp7o3AZWOYTDK+ZqU/NaJ9Hn55IxXD/L+jD13L4V9cw7tk3K4LKK2o4dlT/tgtNzNPyQNqOn60Vcz2cE9cfzUDwu9C5g0OSTW+Eenn164gc0jVx8O8cKXv/TVAjaNYdnBDUSxSpWvvvqacSzWmm3R2m233apHmsE88TvfrezC9jvsMHnzGe4QGjr3iDs5lyo54ElzPF70ohfNPD7RJkW4TNaEQqle2MinNO5aiUrwD8t+QKozTAgEZGycT8qO8VU3AoATKSLgOPjgD1bN3ouDt0wUew2C5jwBydQIt8xwjYKrVqjqvR61zgLoAF1NYJW7QzohBQqMxvv/8pe/XE4rA6GHuyb+xMnxuiK19JK3ODW+d7SljBJGRciToht7Z/3n6AM7Sq1zo290igxGtDvOTp+h8a9hUP2wjemQAem6oRRLh+Q7Dz/8sAw3WGfmNzeH4xrKWetJ4UOW5gyMM9TTRBZvMBSzVPnq6Rs9O0C5oz7zuZn3/ucBlX2SPfPeR6+ipj1Sg7127mmAygDnEMyP6K9bW8Z1R4uWtRAhNvK2DWnV9HJNa9cGVjRpv+yv7+agueeFOfMMhrPM+MkgAir5nrHGKesEzFaZscmg9/36s89Jt90MR2AAj1yXrpCyrla66OEHgN5yPfgCIDQG1D06/7fednuc5pRNIjccMv3pZqYCqirzea8gQBaQDfLdDGn15kfvPpIjnuyP4INTIJ2tRLXKKqE6zX4hD/GSMXF26BW2yD12+1cPoIeG7nLPiLjn2l/acRlyNg2ht1Ylij1ERb1rCOCCHPalUhUYV573/H1qkXmxY/jv6OGx4E2UjOkHgrOa6vPFg/3GCKkY0oCF1FnQm0k14tgF9JHa0t+ppsg4jR6eucPh364B+CJdsFo8cRHy17/+tRCWH1dCYQKJ9AAlQvFdEqSgkB+vpc8WQjBKd+XcxzOf+cxKw0BJYntx3VIeMcJmCOLx9VwIJWrQeMjuvxWwykte/IIM4D2wnq9o5LInlSrJPenrak+yPZr21GrQeAy+OgEwws9+dvnMGfFgTfawRo9Z08SRUFnFsBHa3rBC0U5N451m6gkyDDXvVT0Wiu0tb/n3QqaKZtdOzySBt0cD+h12pkRjJraruUqPQkNfcP6FJcDbbr/tzBNS925ELKVRqZsIHTARL44HV17aFK3x8ihV63pOHBcHf/2gFHmiDJ+aH4OKGKBr3kMp8qyjgALcKOMVoePwULoIGw499CPJCJyZVPU2VSuFChWxMgQOkL31uR51Z1gB0guHCo+t+iu0a/XdRgFJ+++48w4zF11wYbUQ7Zm9d+BNCdIeMBTF3KSWEd1O/XSTl91pxO+HR9XfoWNFKe7by75RGiY/uA9DnC8KafXBGTJOOWGzkbVZO2MClSDsEQcUwcbPQ6e3QtZ4jz2eUfLrfS944T+UU4NFSlTDyKlR9oxX0fAfsydAQ8/N+LTn/+3fhJmJ0hujrx6W80SOUFcWY0sU7nnnnzfzpQwcxoYFRdrrWKQSUfYi8c6oOG+cXc/6svS9qr0yN/enzsxRE4V5ZjgCMoaRp+i7Crc7kfhnHc3PBKriXJqpyYkCOPNZ5CbAc4Ygn3LKaQFZbZo+yqfX855+2ukVDUEyO9sjUzV6TSsqnVKujEj3HbcyH+8dddbRPD9NfJkQpyNNNwfcbUM7G53m2vN7U3kE16ff+e1hdHvOs/eseaD3JV3pxZnlGKy6ymozVyc1KmqzZg+PXBgMX+QihhuE5OJPue8vf+XLGUP3owyff3964XcPUcOYaCViHfXE8YxN3VjkNnEQnZk2iONcJs2rFOP9MRLNlNZRZ2dUCoQUWUCK4L7ouwH8mSvl2OsG99CB1pEs4wT2XcCdlc5NzbuNdE9WEXn7DG71BlA1J8BooRsEMMXvneesOnTuWVmCASv6zXx/zyx1vwIiLG1eFb2KOKNfpXIHMNUUolFC6GxgdyMUQhkAL4a1CSY867AfwbTEKXx49muuJWiuT9XPBkJ/TINiVBni1l1FLsO4l4M1atXzg77KilQWZESipVcmG1asWttss9VSbCtP2HSTEmwPx8u3MCVMlUtepnoOgWEwCNl8Y5U6FCYEnV9unlo3btNEfwd96EPxihald+7vK+XVntl8b8CG8BzUJKQ8CtyQSPCsgFg+fdTRMQo/DmBnixofxBium1Sr9MWPYwQfF8PSY6qABNSLHp/WHUAUJPo33HBdCZi0HQ1k0TTJF8ghCpnCoORNGOnJAbybZaOAVsgkFffSnrp7tqhSFDw+QtR1Ca0kIvM1EyGIMNT/jjnuc9UiIoqSry9kZHs4WdtKsVR9Z7wM5OakMKTWCfXYRhstykzQV1YtdunSP1dvqQNGMCio5ZZdoRwPjsTPfn7FzKc/9emKpNXfdtl554CbNi+PjsfIueH06K3FP0wR2/dK9eaAMbImt0jPYHMBtBJFi0hFFlLvDgNaSNG+NRTRuleCBwruzwEqSt2kPNflgiD9ZY1Du/xy1HkbV9rMfs8iKidZq2iCIS0nA3OLtP9ylTJdFBlaNe0FGGHIkRYbdcTf3/7bEHycXU7A3/39vnUIKPWlqV/VPZHh1Lo7jVOo6USaUpNFTl4OzoIowZPr0CM4YEh994pZJ56t9hgMNnsnY0PBHP7Rj2YyzRcKmOd8KYEwjhC5XurgorDrkgp+UuRQbdTecyzf/o53zfx9Sg4Mgv23V+gEkW2rQTMe5s2Sr48e/pFqQ7un0uuJ9CdijPuDhhbRGU/1vZO+P/OptA89bu3HVk/r99LHuEqMnzpegabyfOO/QTZgTYCynFt146cnWt4rczTdv9SZ6EIk4cU5GjOJQ3gfxGMpkEnR3B5ZQlruPD1mjTWrdUr0a53srayQ6FbdFBBxePeZ3JF04+g1Vwsf6TLRc6Xap4h36J7x/lKkk0Xs/ZyLLkd/X9VIh/DUPfrrUITjXFXmq60q5TulUa+/7saZXdIydWBQuv/7v/eXTiEXpdRzf5yKR6WtB5hH2cg6yghVu1KBsEIlmOyHwQK+79n7PC99zE9J6eKD1SZD90CzOmMD9DfAOM0kJpqiQ0rJR65kIXx3ZQAKhDTwDOOZJi5v2Q9GJUbU55SXGBfRpmt19Fr4gKlm6vM1Bg2iNfqTkyNDWJSvDIoptNN620/P6bP20X+mvbSjU4QHeQ8dX6Wh/FkRbJxeMu/VIwk5AfRnU64WEOuvnIo/V18to9tAKk6oe+/ywjDSIwKXKRJs9TP2d916a0ZMBluzw5O3K10mePI599ERuzWTiaG7GVLP0eXG0uuTIW0nbX62tM4NXsWK0CNL6OCmWdMlX5/69BFL5bOL8ULBOBcT8vZF3ATD6UEuuPD8UsiGCNcEgFzUA3Wk1vl/NIB+R2k7kJ8NxN/YGQAiaQ/fNz/NMg7NqJ9qGYGg9dBQiIwpxBzig49//BMFrtguwBtgBgAoQKMfRgFqh9l8880q6hSZ7b770+t5iuVlorzbJN8P3HPyyd+vg6Dua56pBcV9KaK5Pr2Rg50nFIGthHmOSVP0GCHPxig2uo0gSYPJ9bvW/envFOWjbftR6rFHHX1MHaLHhnZQP1a/iuGnhGqc9o6WUDXOxGDefvtdxRn85n9/Y93T1QGs6MPisarVmM/55NQLDeM984xE1d/6ZksykvMAACAASURBVPVo7fmMPWd2Tg+hUWiElpLp9hgp6jHyLCngGik10rjeR9FS4BSh+xdt/S6KevtEtJCk6t8O4q5P331mtdSW+3DU/sWQe4/IatQPBrm09Kg2kSM/9clZRiYpRPNuoXhrbNU8RcFBQE5f1G75D6jK9A01UIby1NNOLYACMvrdYwBEf7/NaLFb0p/Jq94xnMMiRAq+OF8RakR5MYwrBtBExqR9GaSO2qSXtPNwErbeestCiZNP964vEGDmR6eflufeNSnThQGsnVQE85COjF8PsaYwySUgFEN/fjIC6jZ77LF7OXHnhhrz1a9+fRnNYnApj3ZE36IJKeGfpdbefYrSh+942zsqMlYiwQBFeZa3XOnuZbM2/1NpYtSTWwbt/vVvnlDKA/hiOCkUxEAnlmKJs1S0i0lDbxqjb98vueTS6kPdb7+XxVF+StWHZQoARijKG5OyrVpp3tP1ykqJIgyIkWVsqu82aXkZEWsMHAJl3/2BUN2f+tRRM1fGCXps2oUWSTfGQWK4pek6mzErDJNOqHNBwU0Gt5CkUy21FNgkPqO9pmPZ+uv/kcodNVbRNVnXouY5Dj3koBj9jYLSXVJVVU5sR8B+T3GTB1GcbAyncjCvYSNK60myADI7eJ6/+MX/b+boz3xm5qtf+VLJguxJGx5r2YCfJgOo1pIYqgJz1RjDMSu2dIGSlb9X+nw4qF1H9Z4eUal01TVH75H18F2yd3QfI0Uvcsy65liAtWK+EhAF1FnAJwHDMNx0Qg8Np4dlqBh5esR9uqZ7cO/VbyqS5kxPGQv3/fC8p6Nh1/V5Bhkj1nyd73rkxPeJhhk7MvRgRiRrM2g5lxZfwBp5JjgNETnSDDZsy+jxEbHiUx/TqApUl7UUNMCUWCPXcU5a5zaYasjUXEQ6m+59sCEd/t+snVzwta9/aWl7ICX008N3tFnRBaUYoQemkU7lMajLKPj2GB9fzpA2OlcakeUHyqFwv5dpHiJayEJFYorFdW1Gh+4FrokXeP/9Y3aha7YHRYGo90FMHnPMsRmmenPYYHYImGjfSj2cn9QWPlzUchQapcQYD0SX6CJclwiMI1xmXJ4WhPHLXvrSMDitUdE24y7dxSitl3tTq1oxZAtjw93jiFoosw77W4A9A2PqO9STkUBoc1Fbkv4UhX02fbK/DtkDvoU//Xm02pSSqP9ndJc0zkxqmGtXKldULdpcnHQq75RR0ycoRw9UUs+Ye7Z2733vQcUm8ppXv7LGM1HKXn9MFAM1O9pOBvCIkpB+t6/6sbo2wMG45567KpVzZpSedLU1tC6chCsyxm2TtPDstNMudZ0/3PGHAuK0l9yOF30nlThqJ8umteX0maOSUfh10tL6wwbDjr63AIUoqRirTpW7Z1FAUfeB12fP1YcdnA0DMtJszcirc++VFO6jH42K8PaAva6d+eWVvyo6PY7XrrtyoqD5RspMBFoOYSI4h6dlTuTBcfhqhihQgItT63zDv/5r9m2T2mO8wu7ttFNPLfJ4ZPHqxe9814GVttthh+2i+O6vyNmLbG+TVLesCqXBkFCm6tKM/Bvf+IYasL7O2uvl/kYfcQE4fFccVMA3L5yujN17//PdGaKw5dQDPCj8xjkL+pBiyP4aKnzEJ44s6stNw+J1+Ef/u+aI6oMu5xSVmRYPabcp2pcRGX2LC6rdx+/JLy9+l112LvS1epXItDNNlO7DE0ka2KDubdAA8FbxcafmxVG5IWhuwCSlk0Z3Wl/X3mDxhoUmvvyynwUg8tuZE78bZzbfa+CE1wOhFZwfjXrWpgysKGCymORnkBaM89Pvm2VMmk3udITqXSOirdaK+m+AXa668uKZA/7j/TP7/s3zyln4378MrADsx3w+Ys49mbdfN92MB/shVTIafKujxHVXzn21xOSsvOMdB6T16EMFWDTMQPDBAAFxddpyyCCcxSPrjHLoGY6uk5benUcWYA1bbis9C5QTpSET0n292mpcg64YI/NmSgbVHwEBGT3OPsMnczj6PYfxM/3Jq3tQ3W8jYke0vFI9m3VoUhrPK8qtAd4iZ2lPzl4Cj67N0l090aXJIDhvg44QF/JAErfh9l1kqB0ZumBEimmzybPiN/B9mOtkJ70f7mLFAP+emGEQo2woW/BA9Pnv6jqCAn8KGpaTZs9n/Jsu9Hkv692R72xNdHJcmg2r6PyrNCc6Vh7NuRKZyhR89Wv/X9VIpa/6htvzabqkkXNHgXVHUnRX1UOz9uunJcR7m8C3e3KkMqHFeG42n6EDFf/hKafOXJz+Nod0j0SmqM0qDZeU6DCmDSse6ZxROxipAd/DC2TQLw5S8VtpZpfSEp2+MmlP3hdPzEExgcChrEgrC0V4pGx2ydQFQJFj0zdLcaJDdA9SV7w1//kMR4HSbyKB+dR7HTm3AREpuD98m5Sn55FqQdQMOcnwon9T4D7rrHMK+ETxYoBxn57JCCaRjWfggHTDtO8gtPrPql82EcD1SUGvG4Mi/X51lJTvAZDZfY9dK+L38j7ZAJ/nOCAe0JqjhtuebRs+h9u1ceUuWYJiceViNTKOzXDiq3+1pGqzpstYP8/fPJqcMo0Tc/s2pozo3/K+E7974synP310fefqMRJaPNTTeO/aA+xlv0av6GAruSujuhyulSJD9lNZACDBgdkxtfxddwtC17R7954DyUG7NAoaalLKhtytH8X924xSm8/EUgooqVreKCUiXXvscccVs5KU/rVLrs1Uos3Se/y6WlPXVh/2LCJgKeyDDjpo5itf/XrkFxJy8EBTtIzoFltsXuhYBoDBda6eGJYwa2os3Fvf9s4a0LBagEhoGX1WhOD8cBgq7ZRrXnrpxUkvbz3z2te8OkZK+jlZA6WWMhJjvVdaabl8x89mPv+5L5Qy23a7Her7f5ApHJ8+/IiZRXHgKkKYUqUd+bedqVTVVFqAi0CAYs2/8Y1vFqnAwQeHqzrPwRCiIZTBGG1TOe+J8m2UOnj3KxeZR9ar04mDLH+kCJUK6BItTs4zh9WeHX/8t2Noflbr5JkouuHYzZ/DicxlcgZE4lNk1lmcikLz+2GER3g6sl3j535UP2VIy0hmwlCe9/xTT5/Z58UvnHnzm94UhUhH/T4O4LiHaj2hLEvZSoWOeZYcMc+LZASrGKNFvz360VjTbh9GMGtwQBytA94ZesGUVK5OlqNKWPmfyJ0+YmTcL0M0HBWo+kEnSl6tUZdL3DqDQVYgYH2eYSbn/qQDlM8EET16UbbBfV199bXRJ4nach58jgGjhzjL41wMZHTr11HCGjgHBlZZxhkTCOmBHhmOYUhkOnrKC33nmp3VFOFK6QIU1Z8TMNP7XbtBT/191mKkuzOOUQcD+W7no9LnYxi77KYaKNlq4Jc/7ScZGiBZ+IBlKrDgfAjYymhO6WTGr+yaWvn080IRM8CilClwHCIzIlOvikzbE/ur343fLzj33DMrIu2cPaPi5oopv5huBivR4Nt9SA0ibuNmI9dMbYS32l/coTLCBtftZnMECRbspAA6LsjEGKlYtSN1TIvX0OoRAS9T6RQe8kixDch4px3k9bU+iJDfmvYD6NMD33VARYA3x2N0f65H0EVnlNph4XHddtvtq9H6B0kF3542iw984H3VH8qQMHoMEAGVlmOoOqVdA7inuuas5p/+onbHnDCkeIPvTl1kzQgvAMOS65dUisvIoF0yGFgU2a0GA4SAXAAF4kBL1hSZKNKe10iAy3PL84js0ZVVnSOHG9hhi9QoRTxrpUYM5ed9Nt7aUObqhJXSjBF1aMhBKyo9tgSIUF900QU1RFxtFqz/sWs9roAWlB2h23777YJ4XlwyUpReSWWpOY66yBzHp8MgsvI6/oQT4pV/uNqApAT1komCfEenbWqCC2ElqBCKoo0CoYxMgBQsBK3DIIVP0NXZtWVdn9pTj2VSuzLMfaU8565P361SuJTonWGpMQ3FWisPlHcaJ46jcnmGVhvOK0VfA7Jj5C+97NLQwu1fbSqMH4cNOlhdlDL7xCc+OXPwh9+TtPkzSskAEakXrxUjCIAkClDPRdZv33cIKlckAFn46le/pjI0ygnkeZAQ4FlOpFEtIY8oZaA/9YabbygaSLXa7i9skg1ybdTWgij/Y445pkBPovVVAojBnAUQ88GDDqkUfw8iqBp8KYVhWKS8O8IbWSGsRsvVWRCFG4mln/wtb35TRbwwCI8rxO3o7xVdNziG7KrVFqhFJFcO8Uy1jHDAjOCTgsPMxYEik5ekDuzF6bAPMBDVMx6noR3gBp50T/GsgR2PUD6F55GpHUCiOcXXrEXVKkO2OOjab3LOV06tEiG9ksBhhxwckpX14nQO2eBodrmm9F0pWsYPZeQwpCJKEStZhh71HTAHDKF71m5xycWXZmjCC2tdlAvUVJ2VvnaXwoYh7alGc6PehnM1ekZ7ohRD2FEiJrZOhzKksoTtRFcfZhZD1CZ7B1Fu/QvEk+9zDzINsonuydlw7S7RiW69hw7uTF4bk65LDt065wx07bSAYmUr8EVnjaKH7khKGLtbG3llFM+/UcobdFkb03a89MWuxPZkvTkWghPPylh2u1pTe/p9rwlb5L8FqeOfd975ld1xfnyXa3StlNwNcNKo+bYedr8xp6O4XoI1B6prg7qgot0JjFRB35TiaEOqd1JflcN1T8Z6eSg3NYwjWDqvwoEZtHg2iaGh2PXqrBqPDIVepz99ziBldRYMHoAXNocnSjBOP/2MojfzINIRJiJsEGCC75Gzp1T8XVrCIjZ5PkNq4Wyw4r0agRrL6alfnZP6k4HUCxNJ9QLzlIo/NunJ93/gA+lt+24902oZiLxXvlPjdTN1SMHw0DdOWg9KUQSgYVpEOb+eO7uQ5dmMlIPmdoZQ+lNT92qrrVJpLgpU7576AsAI1iPGtD8nqh/8wSGmRmqRdS+wQ+X2ByrONShrKWMvkQOOTulfRqqiVinCRC2jBSNIzjgED4/wqg9Kv1LuvPxlHzZmUUp5XJk0m++jyA2VJpxP3GKzMpZLrr2hDLp/PyF1tGo9MVQ7e9qHavTzTcqLBx9BFCXa588d9/k4Lu/JZ7erXlqpZcIponEYhlzNNTV34/NgHVlQYK0bb7ohe7FRZjw+NYCyM0tu3pgMwqL1F8/8JqArStohIA9VD81amQHq+gz/xhtuUoPQe62NV/L9j8z6m+N5cMaWoZIUgfpee6SWqYZvXfGknnvueUlzPqvqoqemFHDQhw6uFiv1TQ4UcI9MjhQ8h4aytR+4VBcmnYsdTA+uYfbf/s6J1cYFXd1ghmrtkdpSY4wXrc4kq7LjTjtmCtPra526tMLdGITy3r9MReefPuqoZCRuScp9wyjMDer8Ll0A0X7JzCc++d8xEqG9zP2Ugsv+MiazkWk5rFGi5alnQkbqzhTgupl4UkQsV/6inFk95fpYGT1lkzYC1pIxAVzpWt2fUpLxc4j9QoZGdn2/yTzt5Pk8x9bvnrzNkwv1++rXvL5qj+tnnbsc43Mj+zM3PKHM50N4bgP40SWWVn6V1SjnbnrmqU7KkDai1HuXXLskjvc705u+V0o5v63zJ1XK0WxjV3zLhV6GuJUOTN88AzGlDuscxCGRpdO+4jvc85XRAeRgp5QBbkrr2p1/uLucMOe5atNThm1k9YxblDIOM1t0nWsykl6cwzYuZLyDCX/v/m/v71Rs115l9yCIZV1EiUX0noi0U8YNIvJn10s9u0jVOshkDQM7ntV9Viozr0YLuy8G0VxScus8eLXTX4EZFjVguum8219ZSWWZnimqxbDHqdW9xpnVneF+rJWAonU5O1FZymnQQUf2w+gPulEBkGwWLIKWSwA4gR+eATJN93IU3K/PNAtTYYMYUjoJ7+J07vw5HLhp+HfNMp0rh7X8lS678MKfLHW4uw7IgIlKO73rIl389j4H5cabbixP0+IzVhq/FaTH+8bNNOBECouwqLfJcQO73JKivYHcv/zllQX+4Z3sHHQpowk5ywus3tVsmIfnPf06np578Z75IfeglgpKK4InBQqMowBtAy7MnFJCxzNxeI8++rP13k2fsEmg+HoP9WMO8A8DxgvlGKDeE+VaYIdZKqvbfEq4IjzQqZSAeoB+NG7gxUnJ4ea1BsAft6dn6t6arHJ3orLVilOVkvYM1srz+Q51TcZbVLQk6UWemu9xeEQ3Dj8QDOO5YgzTyqKs1GYoMqmTotPLZkoXS1Gp/SEVH0aPwR99q5S/WgxDqi/ujqSjpLDXXGv1Ag84SL9IWwtHZs89nxlA0aOrBqiVhNevnaQNfK1LDORySZUSTP/WTmQW50nf/e5Q7GQht6C9hdGYLOis1zdmC/pvRGdNSq9fd5MQFQDPXJC2FnL8gkSiqNlMd1g50aJ98yzqNjzOqsXEefnCF79YgJrjPndcaCJvqd5e+4+T2Jo6nNdnb0TgZ555VsBrF5Ty2n//fwozzdb1WUri1FNOrlYbrTBSZ+8KexEnCYAMTZx93zxUj35PRslctVRV/+ADcXi2LfpMfLqHHfZflS3BM8px8bJeNY0ma7pG+hCtrwHh5P6QREp6nhvsQUYopVHf1j/8kOIGPumkk7MOd4epaeVwZG+en12cdXtCRSCvff0bK0J3LkvGOT1jDOXsy3X1g0tH9j35k1PHmRMdczLcB8KNp8WouuY66ySNOLVLNYiNktWi0xGltdby1QOQyWIhTad0L71B3sgfZ/PDH/5I8drqR265di9o3Dp6GEAW1nGQ27cia101FN9oh2mOX0/MCXEdvcbnnfqjmee8cN8M635DFLZ2DHzRlONIdbeuK9Q2lqwyqCkF5L8FmD+GEJdCldG5/4F7CqQoqyCjpfUI77TnlKECbmkHqyO2zrINcObABAhOpHOtI8pQRkcdkAMjI+DccRi7jaMdEwaCXmUU6LrREzvqjp6rarNTiyKQHqe6+tDzfnqGAWKUGFyOnM+7jijbus+1kgxDWvtcOmcMa5cK9x0VCdd+4RRYeebh6Z+/I7rde10PPuSuZO08j3/fUpSLy8aR3Xyk/6fWHDoZN3k7Hf191pChpAtlISCEe3rQAMlqneMQmDN8e5XwGsWsnEaGZUeRhwisZH/cd9edqye6nKPhvLYBnY1GGcspIm0D22WNkojLLr2ozlZ7vg0eas+Jpe4P1gdyGnk9Nh1c/uKkliz4FpvjV72zhJsH54F7QgyvzY1J0fke6UQL5bPI7vW+yeVbrC222LLQhFVXyHsbWt1heOe1fYcD532VUpyaa6VHvURBjAol67PV/jEx+zAaXd9g1BaGfUT69p4cCFFzscHk+Sw4o+r6vG5r0tNo9MoW+wkll/v0OcYaV28NuY43KgVGQKUwXetRNXtwaZyFjHGLspKatrlPeEIil6SGpHKlU2+LAVbvWpjfWU9GsVM7vfmRo7pn69E1mLum3k/vt5at1ArCHiN93fXXFL8vR0W2QG1s7cD2Cag9+c1vbo1xeEJFUq5JQVBK+hZZRA7F4Osd60voVlkVOcD/FsMORpuf/uSCsPw8ue6bYjHxpmpOU1P9/BFo6jD+zdCSM6P7fh/FZk+2jSGSkcC8s//++wWmv/rMl2IkV047097P3rscEvViKXlRoZTaWT8+O6nbVYq5R2rxox/7eEUf6uCcNSlcDiDgBAJ2yuf4bx1f6f6ttnpSpcD97MzMyn1s9othtd6HHXbYzJe+/JW0Eu1SMiTKBqhZb92FBcDiLZMvoAppNlkDGRby8KZ/f3MZB+9pZ6I9XNkUqXQACmxHd911x8yL/uFFcSqfWuQgvHpZhnKGJq+Ywuc8fPVrXy7AkzS4a1uD61NK2C6oW+/54pe/lbN1Xu5x0ZhtOVnQiuRET7lqDYovlDxFLHvEiA2ju2hRkM/ZC8Tcq682zib+VH3D5uAy1sVCk312VgCQROsdSfo5x046d9Yhzfnx+5ZNTof1LgWZezr00MNmWzlcW1TW5YhBBuBt/7chHbpppNtGJDtHwEDzPsrYvwzlYCz+MyCuLUNdetcdvyuDQjZ9xqpUijqZm+I7DtgQTeRDi5XM9dU6pfMYXt+Y2l6+r7Jnceqki9d6zFq1J5xKBo7RakegDX+l59UsJ6CLAKW7AjgTIlhte+ZEdzQqShNp00HNm9sgR2taznlkZiqhV5BgnQUXqDI5U/eGpxkuoQx77h2+gwGxPwIRa64W3hkMrTc9oNu9yuAUwlfffJxtRllU28T47SgYwCEwwKhFNhg276M7yZj30w0ylcofzoz7pCMBSgVXshNVt8xCd6mL80bO+jk7O9Y6sWqsK5jl++fK7EAqk2PXp0vgTzynei/nt5HEfV8yQ9LRnsN6tm4tRwuD0eTUtawNYzsBLn92+SXZhzE/kJFUl7TxHcZTdCOcHSHvMKpBmcWIiHx84ZVR/m5u9SBgpSl4gxhYGh3lM4wvD0wvou/zoLwYD1k1yyw2cgUF5S1jTC0AlK3aIG+lgUMtNK7p5xaDIpl7z2ie7xqAReaFDDDCSN0weiJQB5hyZfjO/cl55YHz+tHUqfGaQmOx1I1EHowfKjvk/q5HODyHhRdJIE8gfNemTUXLhDaYZlVCZLFGUpYUOkPOwBIoAkq4KGLC3yhjTofvgMyEivR3PX/2yf36HsbdwV0lqWoKgWFyUFyzAAtqFGatBh5+XSJbqFyIWjVLDdCV7sl1UPZh5NksUQ16OzSBIyUznKGqMhGiqW4w+hMHu5No4mtf+0bGdn2n6o3qbO7NcOMRFQzwBqEvNqepJtRUb2PA89LqDwVEorBE3NYHP+yeSdevlKj3NgPWY7xrbmyu8dSn7lzTNNQ+C8CQCNMEkr2ftVeVIT6eOZ/nJ5rFVLNkmmWoLWVRDijj8cgYwr2DTlWWAI4b7UDhew7frj1/2tOeVs94QtV6D606ZM23TLpTZMOzXmedDBNOJGo/7Ru0LPne5alPq336UGgQT0vZYVHSvIA2LYPAWKP/ePmcG4f7rqB5pdSWzvxb0tebPH7TktOqNUnxGz03ATjQNuKk/ubx3yqmLZkeWZhhQDBnLV/DGm685bZqF7POIy04GIMogzKkUrtqgEnhiWDgBKwBRY5q8fUBXKEE/GzqsGgFKUcAG14+hqJ99/3bQidTbgXywCQlSsMEJdKNHIoYRj1zKL/2/uvsxLljQDhOl6U2Lco15eP4E47PfR9RzfVrR6coJY3MxlTjnXTQfIIFMuPabUjnAEkj+SEVTu6vuuqaINtfNbPv3z5/BAM5D8276rIifVFNp3RFpHiFRaIDbJIMVXkkolGWdRDb+BIG2h5RuDIeerah6r06vU5OlV6835qNSGoEAuRnyMCCMqR+p3OAYUE+Y9053X6v/k5GXZec+Hu3o9B3nIA2FJw5EaJRmbKBw1EYxDCVZZr+bf5qdUjke6peOrWfDQOas5d71yOq9U793XrQ/T5PL/q7IIDxXCsyLaMng8a5lH0UGLgn916kE7k+J15k6Gf096jB/qUIGxbmzHif5/Vn6SM+jOy+vagy5qD186eslr8vn/26L3I6OLtxroeTPAbU9T0He2IdRcX0o3Wnf/1bNooTOTgQJkDB5KDZRxm5BqD+VVpXK+jlMaRDFkZN4o4o1e4VmuV9nTZ7/ofdAIYISEPGVyqTIZAmK8M7RaZdU1SPQVJAUNHa+bnPM16M0WVBXQr9ze5T6DbOjaET9UrLVaN4FLUFbSPfDcEUhUXxc6xEFaFOrBX4MaXhpKHHdJMxPYYxVdjW+/XOdx4QFPC36+DqWQRAeMXL9y/h0CaDjcUBoTjMKvXaPFGb9IEak9SY6y1Zck0xQNl4SFApQALjPQ6FaPuJGdNFIAjcAKdAsa5QAtVFcL2HFA/mGM/j8PGWBm9v1jDXU6PGSlKbT6ryf51CujORwx1Zx2pbSb3OvxntVfU5brxhDNVKlTpakPSwA7owkZWozBpRiCNtNDTWYPrIfqbtAROStDZl/tCs6c+DGv1WIrqTT/5hOQIAUHemLcaHPYtD5z9GeHh3Ew1XblbNtUdrAXBYayQRpSgMPkgrx4tf+KKRwQiAjHEFiCF3V131q0opbbrZ46PU1633ALytEuSz2/7kJ4+cOfkHpwR8s7DALb6b8SJvqC6NBMStCqAhpbtFUsjAcBQBxbFz0MnawH4S50ptHbgHUYZeO1ErQnuRKGenIfOiK8+8YxDaHMAfJ6o98D/+s87HY9PvKyVbRCMimDw7j3zdddcuBfibRNMyAnvssVuIGl6YKOjhAVqFdD+OUqN1PaMIkmH5SqgMEcNDVds3z2NttHFdfNFluf8dk5ZfJ8xg3ygqzC1Dpj+byZgmo9AYRRAfxTGoKkcTvUyLc7Tffv8YQOCa4UP+XmpOF1Rda911HjuYy2IknpuxYDvv/JTCKohOvToiKRCdaEtaPwpNKQHXsD3ozFLXtsi/WuIvr7q2FKv3XJjsxiGHHJL1eljO/5hc0pkpzgawVKVss5ZlpIDUClE6R2c3fj9aHsj7RWecM/M3L3vRzOtf+9pyWGSqYvNnr+G7inidYcm9M/LLaAmJ7OKq1i/KGHE+ZFDqJR2cjIto3h1xWulQAUI5QVNE5b7IOmXfqeNxtsY56ZIDPSNjYv0gdDFfeT/OXOskuLCP1qPLXK5D9qtUwKBX5D7wCPqgC6Gbc6VsAvDFaXJvSFZGS9RIVQg2yCIj6T7vzvBy13RGOLVKPpzdyhQUgEh7zegqoKMZUyh43190lJFd50PGEZ5BcITOEmOc7EnpxdyD+/NMuAn8qeWHLvS8w0AOXEZl5HJfnOl2Trrs2IChu6Mbl1s+zi5GsjxWg7bU+LXU/OrqZECi4+hda94ZRuvd9VgZL4HZn/4EdDtHhlHZPVmEAocOtPpoxZpISn522SVyJVM6JJFVRRIDnefma9jvvKi0hZegYb+xkOjAbgg4xDxHsyEXp/XArUDNzQAAIABJREFUaLEW7EqbZDFYc2wa/z9Z9wFoWVWli3qjJCVJlChVRAVEJAiYEBAMoCKYc4s5J+zbffva6rXb2CjmBAoKmBUQEEFyFpSo5CBZcs7U+78x1qyq997G4zl1zt5rzTXDCP/4xxgmYCgBsCBlyvX2QMckZ++4406sIDThyvrXuFgVHeQHEyDm6JoVr4yQE9MdUHDnKTYTUbqFBeY9EGQWz7PUhsthQIogaE8//dRaUEoVKcUCs4hM7qXp0EIhXpoiCYghBKnC7axyBSB44uYJJKagPG9xVD4C6fEYGA4rRQnzAhWL4GFW+7Niy3VJPVD5DRHmxm6Tmj+esVZdNp9N1orysWwKPVq74lIV/c7fSmjwVkNCwbT8a+JlN6cZ7v2JU7HA5q67ToTeiM0GjsmmEwOcu8661feQgulYsI06EalkXKT3XrE8o0hHTq/NztPirWDLmitGl7VFKgAXMTwIy2qonXHKm+y4UkMhlAmYbAXF1qfi8oQeax6T+61vfXNVnRJLI+iVZeNJ2ZvD26YYCV+FOaAEWJRqNB+WWraMEXEe89VEjK6Q1CGMeBgZ79//fkmISVtVjPriSy6q67zmNa8peF6S9//+359K7uNFmadu2LBqvH+xGV6oxG8Cw6HyXnOO7CY+pqG84gO8HhBXNzOPII731+zRB6uubTXjjvVMiD0xQu+zn/1MKWH9aM2l2Kc5H5WvwHuKblwfstWTV1059720hIY4mb1x8UUXJ5+xSwtu8+zn1Z5RfWnUKaXUGlWoJe64qf8mq4mQ9B6e507hEPDCVwgkal32+do+s7tjZKkYZjyjj+uOO+5Q1aV0A4KKaEPGWJbOQ/kxkgnipyR3dqXUvkaMc44YjwxjzOwVIqDvueu+GGYX1nOsl/i6vf+e97x3KvsJSkxfyxifjZK0EKMDqkDD/JKBU8WiqhRWfyyPWaxcg/X/9cm9ukn0LTe1NzPF8EvWiZFN3s2iOZtIVEtE3rjU4vmuu9T54UCsFaPzaeE66KNr/z4QBA4vwpnnWbkuZWhKqy5wTXTHxIeBOr/QOV08eZb+PrzUMvajlIexLHeaLKoay5We02krbbjEKJ/qKY/iCubQWJBDdY9aInur2Mb5j9It+Z5hQSmqKH5ip8Zmry4oT6gObhNzkMWMoUJd2fM6Ga0U9FHJS+lR9iilKc2wYH5M5sTmnTcGovNiXyFiCSdxCgoJyOCR8RQ9WScpVoybsX+McZCYGCZVwATPIz9X/9ryTHsjmzs6wL3JGc6T9UMChThyKITR1gjxdOCqAw0wdnuLkhbKIp8Y7QNF8H0gHblhrdECAtYCQ2SRs/98emRd13M0iWWBTZaUiyzMUi0ryn95T3UmqOIJ+tilSXcU6+mnn1Yl5Z7//OfOt8goP0LBxDTRAK35nrJsxKqkGfC4MMBMhvep4yrvzgNUflI2xM477VSWCqEt93J40N05ol9DIPTmbBbZnfHGqmtAhDrF3NYE4dGHkXAvlm7GxkuspcnfKRol/4bFNiy+hmQV33+sYgbisPJBwQesHkJ/0ZTHk0crvsKyqlys2++K0Fs694nSTB6aMV5/w3XFUKM4xUiNySZg8bPsjGHuunMqxjYaMENGh+B4JIpGcQaEnRsTzL/s8suKbn/DjddV7i44DnmKR+/5ilCQOWFBbpwNZp1BjCx088KoqH6uZY2Li5JHMBSNuFl68sAemx3405/NDgiZx16QFkOBG+sg0lAaFGkTtEZZM/BwNmLgMVWNHsp9VsizEnAFUeXferFuHcX2rjSwfjRzpm6r/VXNfnMYrQuDq4y3HApJ8factTHPuvocffQx8RyXrW5Ey2qXluHbg7quPD4euOcUm3mymHXWTd/Y02JIbbH5FrPXxwNeJUqUgv70pz9dXu22z966hLq4vWdhwEAjwMO9v+6M13d6zemb3vzGuv5en/hk9eVUYYkAMRc8AM/+aBQxuLsaFFfc8e7ywJGpdt/9lfV+KUCe1d4YdVYJQvHeHx/w4xiAXZHF/FOk4mvQkt+kNymvRR7dooFjt0jVq9/85repsvPr6ldKsBAGfVZG/0VoRrOQFjQ6+EeKWrxgtsfLd53dGcNwxeWDYNxy4+wL30zd6xig62VPigOekQYRz0rXG2Uod9klpROn9m4MFWfCHrSvQcZe5sarU386H5UMKYJKBK8wg3SYkbZGuOuSI/7OG1oxa6q4+uAljPDAwue/a8C2I2Acrn9VhP0nEqveffdXVOu5+8Gw8jcDz1pT4fuC7PJFkOIQkDmUvapgSywdD+bRe2Y//t4+s9vueWC2pwbra8xJk/Q4HikI8sDkfAzouh2I5pZ0Qf5WpMNBYeQ5u9qkEVTDq2HMQiwGm7/gxuxd3iXvSsxYSMo8F3SbeQTvDwYueeT3cscHXDxIQP/fOLW5LQ8wMmDIcAoK0QcbnfNB9hob49B6uXfHFTunW2qh+1Ggo2qT9/H4RrNz7SilOlJkZbhFd4ywEBRPkxIeozVHKDXvzgYFbMwUqPu6T8lSTlOUZdckV+sXObblKTmuzaQztG4cB3JULq/nAHHTHSPXdYQKPb/fie+DvildvxPbHrJ/vm6Zxj4KB3Ud6F7nRU4+8bh54x8e1CEe2HnlmpUnKdeoXf7hXbZl31UkeFVSRZB/fvXrX8frWqY8SJbwSIgfg/LAVVIqCzLKbPmsvB9xBfEigeybAgdUW7Iw33glejFSuPrrIXO4bhcu6CTfrt3ZbvYgc9i4FmjEm0xYWfgTnLHwe8sLKyttAWPLyqOB81CHdz1iCuIhLtOHY6ozO91fIH/EN+8I0aq6nhRk3R1jRqku45Zj6gVWRWwS4xR4dz/5nEsto1NCDl55iuI9fu5OKeBBRbYJAV7K8VEk+nw+IR1Vnr5xyErpAFLl1zLXguzgZcXrKXzzBYZliOjAAjJh8DBu5F76DIE02iWZ60vinf94/x8nJvqbItxsuMGGpRTtC59XeJ63IkZWyMXwDBZIutbNmbhKayrY/fG14a3x9ttvlyLqb8lhuKmei/VLgVg3iuKWW1J5KpZ2lYGMMQWedi2pFMrxSamyLyhjKTSdCy2NqUu88UqtqWfjTQgdjP0gF5cAIFS++73vp9DBTwoSFQMmzJQqpLi22GqL8phARJToeRH89sQuL31pBMu68QAPjEf8+/lwNm9RNRUElSFY7R1KXloRBry82E/u9a8VR8Ws5qFXbHQSFAOa/lUqMB1x5OHVZ1dnox122D5wf3Jlq2/q42e//MUvo0BVbUmO5sprzF4cpu0xMSwOOujnVTGrBPVE3x9GZwuJKlVQ52axPIuSgbul1+pbXr9H5UPfd8+ts6232nJ27kVXzn560MHV9F6Iwx5gwFnvjZIf+6EPfaAQGPeQEH9rDBBefPMmkuqW56yqNsX67JzDHgcmZle5sjZS0Rh4UorEpA897NB0Vtm3jMk5gXqREx/NvhuF0xec48nNnvab/XPG6SemgMfOs39L71ce0q1BadyT0RDIo1Gdgg5DMMp69PnOmZcby0PNtR4fiHexx8Vwvum62R+OOjpQ5U0Vu1d1SkWmG6670YkvL8i5H/LHMFoGNQpX6RXl1XR+fimDIkY1ioaVO9baWlXYJi/72AuLF2LDQGe4D0jSZ7wfCagUQMmtxean0/ks49PXaElmngfh0vzb467Xcnm5CR5+uAxX8yWdx8/OHJkr3OP3rscrFdIS22UElLcvbq5jWH434pwjJMcodnZwa0aOLU6F982tDJBlSx44n+Zl8Fl4sA9Wb9zmA5CJZMeAxBmzo1gML9o1EC2NgcwYjOcRXvC84qaQI7WSpdb4YoiS7WTJKGJDDxoL6HugsuZ1fsz0tFNOnK9ITYCNUzGtfNBAB/EIFOlg16YdVl/eI140ygI60Bb66HQeMVgF7nkOg/Y+lLHF8gW2JchZRssvH/gzViehfP31N9VnbIzDcohAqcZm8ovlGtye16DHnBw+iylITnBXoDwbc4xpuOX1bJOH7RkW9jR54ir7ixcRkCAqYxrPPhSwjbFwB4YBMS65ZBdwZlWzNsV6xe5Q4bFKC/+P8FOswQHw+7GoYk8Ki0ulqfhvFD2YlxdK0WB6ViyliGDyVRuGKeWV74elwwyvRryW4cHC2zqlyShbHq8KIejz0ilsKM8NygE7uQYvVBqA+KcD9aRY/WCrvKEOLCjm6jBKjzji8GZZn/3X8nQRyyAL9otrgWqH114M0wkulOQ8Nl7VZ87eGp3urdHlqb6i2MKL0wrtzW98Yw7Kg+VZm3NeoE3ec9uEHgeVoYUhrrk7lGIoQPvlosBHrHf7ZBDQOhFdakFXjQERsXn8HiGiYHbdUXLPX6RbybdSeEH/WePVPNkht7d3f+Ur0wAgeaeZW/loFyb+vFSE51ZRrirLKDP3oQ9/tITjnLlzKnyAReg6i4UJCo2otYxFrffnA2GYq0z13ve8u2KrhKH9OwRozWv+LW4ozv2Rj3wkhJSbZ3vsHgWXuKLuN1ulSPczNn1GCCl/SSWpw4ssdt0111d4Zdtnbzv7dbzU3x96ZAzbjWseF3ikDYv1Mvm/biLNMr/0knOjKF4x222XnWaXC23cdlPFjFdfY62CCg/69RHJIb+qwi+S7RnQlyTG+Ym9PlKFHIb3QzEg2dkn1myVEIjKi0JYyT4nYyjVMsoTgyRfEM54USDhER+TN33BhefN/u9/fT7zflu1abPm9rHX8EB7n7WMQp6TYsE7+eyn/89s8802T8/QK9v4LwXejnjHoNsrEROtnNEYzlXfd/I2zFkhagozzB6eHfOHw8OdOHr27G03n+30oldnf6Tw/L131lkbXqexOA9kHq98CO+FZVB1OKJIjSdjJtOsveL/vHPzKr90yCGyQl7+uelRy+Nz5ku+ZT9bH2iRl3UmKymZnh9FEtKTeVJqxkLB+Kzvrj/Ijs6ZF4OVQmXQUOAvS1EScW5lHp1BMWPzXj2Zs+/FPXmoFNlFgYHJZs8KIXFtHALrySt0f4iN8zwUO+fCWMDHxuPnJvStVZ+zJyqVJ+dx5KMPEtIgPFlD928PU+hRb+WHy6u1J4dhPWR46wnFUKZav9lPXbhB8Z/uDzx4K2UcFNO6FelYz1E7YZEzTju5o80EYlmJSutJQpbsTjh2cLpq7+YCHqTceII4gwB/UIKsTg8s9vm3WJTaJ/GGXp3OMiZkBNmHYhvCdcQ2h7IFAyFOCBwrKs0K8hCUxIknnlSbS71SZeB4vQS9BXS9joc+eX6COKiWtcYiHNdf2GIcgp/5YTOW0LfxwE6TEVFipg5oe+CjViWryoJ0fDQbvjq484LCjovgWC/xtqLFB77w7KMrAsvIAhMEWr7dFmjY79xjeCMspXFfQtfn77gN9H1/FVL4Z+ALMVm/16HFQdkuTFFeiXH34qekYoTqButvUAnZWJlyWittZYoUSG2whoP1qYADYgLvgOIwL3q2HnfC8WUEILhYa4dZfFziN++7WaDDKy9TbPyvPKuuZiR1JiSO6kbSBffFyNReVaHpHe94a0ErTXbqOp/2jYMx4ktKN64VBfmPNBbg4YMXh/Xv8CjzxwvioZpDCtW8Ml4aDpxNh6qZfi2gQh6Il084KNTw/g9+qNZG/Edpu3uiyDH93vjGNxUZiLBjbGkFdlFikmo9b53yfEhhX//GNyt3WSI4k5RSkr7SzOBOE7BHlZy0TldecdXsBfHC/+Vt/1LW74DajNnnKB3PB+Ldd9/9Cg3YNak/Qif/lepFpyfVaMeUS9wm8DOPHRFJ0/VTTzsl3lyKKKTxwr7x5EDuvIVKbZkE/EBY5rNf51VJgRrHpX89Z7bbG14z2zUdYa68TBeamzMXt2TsacQQmO9xS8TA/f0RKUBycbGOKS3jVDGIoPTaIp15dt5555rjiv0V0SqFBqYUrZIJU9ywzmG2ZTV/Vugh57Y8w8gggtq8qSPMSPriF79cZ9CZwTlAYBklSntNu4ZtdRwKw/t1r3vt7N3pL4y/cH9kFANVzucg3VTMPuMtyG+x5I2mZitZV+GhCv8Eocp6MWSrIEm82FVi8P/hiMNm+//4h7OX7/a6wNq71dwXTJ17D2Ss6hBPnW5G3+ZxrslY/IH7hYnKQ160oFvKAfphX16VfS6rQUqGcajdOyeKSe7zX7JGkD8cDWUkfeaCC/5WsmVkBVCcFAOEy89yme1Z8OeIzTIqpZI1j2CJUlzk2iAz8RgpRuvBKbIeXcf38dXEwprLRVbjelQvosgpMuvEM3RfMVbXdxYxeSFkEIoB31LYZH0RnhCLskajBKEzQ+cwjOUD003+PWRdVzRCsOoeq7UXp049iEOu55mM298pZfPpXsbkfGmUIUOiyYOdYTCKewz92EaWwh0L9MF8aJciHVZSaegMsC30TrxlMQ0Gmr/Dx5W+gyXbzKwe358aLBz05uFN0FmBZA886KCCZt74xjfkgIkXhXySB/AwA1JryG2JSdmwUBLkX6IZnB6w4ywpiixmmANlsk844cRSsibfZCCLgBy0hnKAHGZuvrGwEt1DDI4glztlsw6hReA2jAZe6pQAP5cAQFrK77ov54IY6+h6wlJGrAE9GKOWW+NZTD4IhBIXxBYntekpYErXs62QxOsKHORl8Y1J7qlYpHHB9R9MgjEIS/4nQof5kGazDPi7ClLPKdLKQ+lNifpt7aoLSTZvCc+MneXeRRVisU7WVFWrgjLkAC1O0MVitXmsF5jnpuSUHn74YVXAHlP3VVEYfwoR7Kyz/lLeaHyl2f1ydisGusDDnxeBjFxTpJDM3xPznOaT8lklB7ZSLnIQLr/8ylrD1+a622z7rGIkVz9S6wFCKeZkM/dGHGP5NDAnKBWSsD7LZ/6qvV3m2EGhDLFIKXkvHqpNz7N+OPPDA1g6Mc7703fTXFQebu5lLeznj370E5XWhcDU6UVdLnLtsH+3SYH6YYRddsmls0MP/X3q226V6jgvq/k64CcHhOH6h1L+HWuUDK8O65NmL043HulVIEvvXSHpSg66OOJeH/94zk/YmeJ6CBTTAR7eqBQzwuv/fu5zlV6y5zv3nB3w0wMD459Ylv6j8xQCuK+IY3u+41/KUCC0fE7rsv1+uH+akG9SZIoh4IcwL0g18e82FDuZnkfI09cK7NW771rktbvvTB3a/I0HjbC37PKrFgL0m0N5pldWn1p7U1hBvBZCYk/uFXKP+Jr9q9pWxXOzvpopeJ89P5rJy4u21jwxCtRajdxtRTUUglgphSuw6sWCjzoqxShiFK6emDYyHvmg2XTnwy4V2PCyKN+nzj7z6U+F0LZczmhCINmn9rdKRGWsBMItrzxz3tWLFGCINzrlVpqTMgvzwWKuZ/7LqMtY11h5qdl39vnS7Krr7wgp6kORV4sH5r6x5BcFOmK17Tg0X2A4E56TbCVfRr1mDgGCEcVZ2Q/Zd2BH+8Q6ez6vp2U+VwwiJC2GV1f8gSBX4E3EPwqMTBw8F569L04R+TgKG0AS/nrOXyvLAjNXMQ/cAWl+oFoKiPykmI2h5OR0Lu1h4yYb6AvnjGOjfjayjzKcxYKdeCad5tV9o8VgyWGe59iHDF7ylcI052Spuabgr4R8xKg1H5fFqMMvmFOlMG+eH7Ib/InR5cu4KWseu3kejov95pwPpIOSpzi7TnDLG2E08mxU1DLGIhgJV4mfR1aUjpgMxDacQgA78/RToiub3OA1tLyJGz/bfAYxINProzjcnBWiHBPrQm1JlqlWQ6slH3SFPLxScejzlPIH3v++WO5bFzwJ+hyvilfM98AaBuSN8vLWDDwKqhI/BKWNFBdjoWTOivVPQDtoGmpTKgQZy2l4qJT8wNptJGMZOW3DIy1oKPeVGgbWdW8eVtfB7TJ0Q/GCV5ScotRtNoJgBJ+xMcuzrDykMJOnAgxV9D6HtVMCGjav1kjmPe+rZ46g8R0D9Morr6jD52Dcn8op7t3e9SK1OXgB1esy8SsFCLDgbB5xZEJZg3WHFlTIgOgNm/tMUNXdUcR9MDzbQ0Wc0f7KoXTdYwLN//Y3vyuCznMSG2GMnJD8SmxUAqd6JeZgghZVOPEaxK0SPsgy+Q9dfJnEX++N4tLWy8FwuBwI80EovCKElqLE52CvmxzUVjZPKINj7EfxUN71QzEG7gi5AznL+MGCXYWrUZQhqBx0c96oZe9rnvjjotxqrxljfm2NCHZC6JN7fTIx1vPT43TLEhwMn2233abIVKNqkesTdN/77vcLXnz/+99b7feOjNd+QDoKQRgUILj/Prlp3XyYoaXJAHaqeKvrMiC8PvrRj1S8v0ILFBnYEfMlxom1YxS6xr77/jCM+D/Hw9tpttbaa80+/ZkvFOS9+uqrhKXLi4+BmrjEGompb/WsLdP7dMugQn9PbPSgQiagJKPvq/tM6mEKdVivhnmdB0L8mijup4YAsvuuLwkKcWlwGn0c01+1oLUUPQ/DdqOUO7zxtrtn++27/2zNp6xe9xBPr5rPeR+oDny+YSpUIfk84+nPLNZ4IUQ5Hw17tueBdESB+x1FWkouytTLevk3j9jnyCJyRx/iL6aWM4LNasndXT6kRWcSWnJtCI+E6r9+8uNptbdTPDB1vlNCs9a8cxArtsXr5HHmHAhRLea8575io0VG9H5GxgR/ezYeLBmxZC522803zn6w3wGBwV8Sstoza19TpAMlcb5GgZihPPusdNpIER+RIqeQjuuOfqLjue05Ah50ivFcsCIjMkaYfer99vWFF2io/viSSYNV2vBuqiHljCCaLbPMkwL5p6dvDFBG89/CkiYbyUhK2f7ToICyGYx0SqjbknU4DgvWXF566RWV1nQrMlpQSPFsZ5eCJbMr3l5Gk3zhTt1BIGJQCIENJNI1q+RgHAQkKvIB10IXJWMzlpFv37pi0UIhKXsyX942mW8f0UnmY3TbYRRwciBU3mPeh7fs5woJZr3IEOep8nezZuRRZ6q0bGbw1HjzM2jXz4NYNjz7gnZt4IoBTAqt3PpsWC8/L1y83s+LRii6EVf46muuKjahwev3aZJ5FlIPrkjs6/LAgX/607GoDAWNWQgLWeSg3BNRoa0zGn9QmTuP0e9NNDgPpVxqjlQZvxtVQUwMVh/F+rewPAfWbxMhnKwd68VzUX7ysjDExNVYUZ7bpIAxTSbCTEGC8WgUUyCcBznCxDvsZVmCBCMECDtQEfZnleZKjAJrVzxUEYdBTCKkWFJVoBzMG69TKylzZQw8Rh4Tj40AYuldfdXVlViP1WwNEIWM8aGMq1nDDcPZSKutmmIYgfGqZVoUnPxTMHC1gyKYpzjlw1P5R5sOakC58LqklrjepZdekq44BxehAiy5XVpque7D2disV6zaJ8XT6Bj5SDsY3+UjNiziGSuxXRHwB+KJZMPayNdfd0MZPWrO7rLrS2dPS7k9woFVDEIixP6R5+Y98axcx6FTQOLKK66otWEMEVAdN5FgviCp3Xx3bD3Pk6d+NHP6ONJTP84i+3T/z9r8+YnXpoqU5gVnppHC1ls/q6q/PJRCBJSffz+SNWJgECwgspNPPikGzk3Vm1SSub10UAg40qSqd2ksbnm2yEWuj0AnZDA3KInEeMbmMcf+sbrpvOc975kPMRPSzoDXXXd0f8qVVlquurH8LGES6McLXvD88ly/+a3vB1ZPNwx9SqPYmr/waKzwy1Lwe4ViJPPKey46d3O0DhvG4/BC2ys1LZ2OQEhdm4pR4PbdX/HSKPAzIuwfyR7rRuWFKJX3l5J19z1WhoUSdMXmnxRNy4tHS6FBirbaavMY0h+omDeh5NwwDCnEf4axjPWttZx8XekZjL8Smkpx5ny0QHPfR2JIdd4hg1IIaZ8Ub/hLehTbP3PnPiXC+sZCyV73+tcU2oG8+Mgjbcg9Oo178SBF1Ve1lBplrcJTOrzECGqoruFeWDQ42rNVIYZY2tUAOz9DHczvtwPnU6I77LBDGcEFFU68EfNAXnTXnA4RDQE8kDkVrIac4JUx6ryGbBo8DLntZACFB2pl4JGJlJAqajem0xGDt19dqAFPgPwS4zR38n0RuiorIEYwhTe8V+OC9lHuQmXuS4ZSZsbi2Shpshdkq5B/V7h7cPbMKCxn/MwzzixEx7MVF2OCiAehCJlyrcDxUE1GtetWic/A/SVTJ69w3bDC8UpuyN7ovZve1vHOrcmqkSPDWRmesuv4ogsobnueMW7fmFtj9p38qFh4vo/5tazWh2zF2am6w9mD9hvjyr7xnvJSq49tF9JY+By59iJ/PuPUeQbbwq8r4niTeBQLAdTY9SADO07wwrDkq5JE3vNwrEjMOsyn5z73eQUNuZmJQ6KpHqI/3r8eUM+4HdOQWVcP71Ekf7jJtmx5wUlT6CILiiPf0d5drAUbiQLrwgH3VyGIIWxNBuq8RaZQ5Y41m2vFgnoLns79HBhQlMm1oXivYAmHWlcTqyXFoRmeg9HYNHbzMSATYyryRiaYR+iDpUR1OYn3IbZpjKr9+IyxioFYSIJAceiGo/o698VrA9kSEJQI68rPwytpT5kibmWvasrqgYoZBDaWexFOQ2guHgIUskv19wQZy+mcLDoHnddaVm/uf3kOye9SE1bvUIxIGwcDVVyvc8MerPkn2HgPhH57Ni2IGjLsrg+MiPp7ftfF96UC5fAGjnXYVg+558XpJbp64smUPK9dOy7xSPuIB1CePdgvc2XNWas3BJpTQIPXV17MVMmkre9OeK9818ota2FicVx7xEdH2pDxNg1eBaRvF8Homc/crN5H8Rk3o493Q+AQSBTTYYceXjGhN6SM3zKZd+skJvrb3x5SZCVrac7BW8ITvPzqeiJMknlTa9c9KJcPfOB9sw1i1DEOu5F0p01VbdukeMitvCZFPb7yP18pYSkHbrUInzVSTenLX/lG7RVeSadAgOkzD5nP2gNpm4dIQ7C2Uup9POrQjqJ5cCaxAAAgAElEQVT5vX4t9GJelJnBALw2BtMGEaYv32XnWPQ3xEvIvTJ276u6zplX9/nHP1O8RU9SxQYSY7J3vJxdc8GgEcYwfjWK1eoVyzdu6RPOhVQNMWixc/vLsg3DflrIihFSdsI91lA80jUVu3Dufxk287777lddeMCYG4TZv8/ee5dsAQEuHWNRtx4KlSxbNp4ZWdACMl5G7u38Q1AGg9mM2EHd3m9q6+bJp40/BOpPkgbGON86JCvz1oade01FG/KZYuhmzwn1dB9YMdlO5UD2GyiVvUX+DSUwsg0Id3sSjO75OAv2Hoi0iYddNtDeta/NK1mBHIQ4pcym8p+eSLvGclzy/KMikftRStBFITFGnvFSSsOrdD/rf8opWkEmrBcegPny92rnFhkCmqbcEfCcbY4R5WtRr4sRTakzlnmmEB0pTbenQ9NlcbbILVXJhAAvD9nQa3itlPnI9DAG5RiND1Lk34M8NBj6w0v0nDxUzznSXiAV5G4VwgHl1j6YV4qaXOFdcyKGAodAdgqSeuF9zgpJyL4ZoZL6N2h3QBELD6pIERPhgSfWmr0ZrW7iVZMYxcSr+e///nyRPz6UxsisVIpAM2SeCRbm2Wf9NXlXd2exTi9Pcdd4JBtsuMH0QDD3JPIPGPXBMBenotjDIjNZxsCz8TUmgHLq7iutlIaLX1V9olApkYrrBmvHLDUBFnvg6p5DPuL6G6wTtmO6VeSgrrf+erWZ3a88zTwvJeDafva3skgzseasDmOEAGu6rLQpcbw652QxCYsusv7PUrTyqgjVboc1K2UFpiBENWQ29zadkmGjHZ24g3GvELKPKjug4VsTk0BsclC74zvPWoWn5PVG6DAUOh7cLEnenGIQneg8r0oZYkSDcW1uG4g3w2odyc63JF2AVY/R2rTwpp63FHKZhpo8h7+z3gnXpQNtgjlv/uctNSeUxi4vfXGl5djMNrY0HJYfK5aAYZBUKdX855DawD4rn9fYVRYioIopl/8YCx2Dambio49gxHZnEFJwGD3WeByuEZ8n1DR4V95Q6UCvym/O4Xpamho8Nx1YusZnE1GUJjzr7D8H+t0qMFb2R+JpNyYnUT9QAgQywIK1Xz2LOZY3rGmD+fel7rB77PaKV8xeni/GQiFB2feNHIjTi2OnWk2MscMPPyLpNefFmFi+CCKu//x4pb8//MjECP9UQgrTtWM+DUUNpWwfs7LLnypNWpdv2B1cWQqUDG+60agWtOyyS0UhXFeNKF6y8wtmdwQ6vevu21PjWOyPQuDRL1KkwmvCOL7wwotSEi7M/DyHkIwQBYIWlIHQpOSLJZ0QAKIIRaq8IE+eQUxQua69vHQMF2Mb6zaUxIDYhpwyZ91QGht4yUIsjj/2+NneX/taGT4KL2yRfq5Y6553uSrAjusQODVx8Scl1t41UtvwWnTx5Gtm70NQmiVXQf/6uaq7Mc6mcz72PvljPg8P6UiRirWjAMSTOzOhi6wMBWqum7TZ3s5QZLziEWZiUA3FiaXtvPIkGQz2n5goQ0XaFAiy8ountQfNuscVQW0qJz7nUMMASJdHEc82XvPmfQhf0BJyxlxzNECg0ufE2luG3pHfr10/k3fOLKOoCzJQfLMyPsheZV15nYhErkU+24+ce3NqTXEO7oWUJc5O1jBw6AhjYFjJMqC4ESkZSkIeYObBL3E+O4b+4Hylx7gY+aBjbOKe5nE875kpEqSUp7NSDkfOtPuWDI+MNc+jRGD1is7zeh7rzJHzd/NtDR6s6mTt2Q50YSj8gnYHTGqiLXLdIF9gN4MnvJEDWKHD0iLAB7HF+7/3/e/PTksT5He84x2VsK5kYJWNi9IkCG2IY479U7FvTajej+A9XV/kI7ag02miu42IZQ6LxGAryD+NjSVBmILKeDslvKStxPrmOYxyT2OiWHH6NroeZQZCGBvvAaQSJbR4EUliR464L81hf3/YkYHStishKyFf+UCTiVLPylk5xIdHHgtpKoSFp4VRqIHvzSk9uHysQHEwyfi8xq5H2ZCnsYl/YiYTNBSnNk7/uOqagpct6KClU77iVRZRhwzl7zyPNXLoVMPxDBRoH9Tu0sGgYFVRqmAwG0JME5Rr4zl8cv+OPe5PUSK/qiRoG4dnu1wOKQTCQazC0HlJv7HJFxQBJ1QmT6bFTm2qEkhCAzFWVlhh5TxP1/YE72yZ9JDtt39BoRyLIhSBV3i3UbjYlOJclHgZFhSgmqXz47lhIWadhQOsr4NtHXiAj6bqEs+/FWm+HiX4oKoguYZ1BnGsIbspJy9zcPQxx6a92XcKypEyROitu+46JTgH29S9louHpuDCSYF0t0zRhs3ShQfScvFFl5Qnan4wUhkNLHHGFPYwMgVkpmKdZTSsEPj4zJA5Np197CMfLSa1mJ9zVtXDqtKLVnhQk6VnBx98UKU2veH1r829Lq2qMLwoxfzt389/ce/ySHh9zgxS3PDFPaefxxzWg4/XgBIW/GJSoji7jSIol7h+hNhLX7RjSGc3VPF6a4Zlaj8qdVgpSflZzulVUbzOhxZ1auQ6+wSlNZDqxLByXexw1aSk+vz7v/1bxeChHebwnjsRkFS86XVr9mT32F2Yw1H5zTk3XO4Hck6vva4T9yXeI8ddm9SfF79k55Ixt2ZvORvWwjwjKgl/LP0EZJyublVIgJ6jGgRk3y3skY4KRDbl2E/OAqVKBjESL738ktlTI78o6PtiSFBao7nD6Ns6lMD4Pno8M4weiLAmGwdDm/PCaIRayFHuRgKdJrVmFIK9b05KKeY/iF2V5IucGR1ThJCMU55yEbFizMxNTjnnwVm7IWsqDk/hkdGUmb1uzegChr0vShEqZs5Pj8FNvpAViu4IY0HyxEY1gqf0rJMzz5iXrcBZIBcoXvtgwzDJl8g5uSuVuxgVhyelDpz8lje/JYZIN0ARXqo2Zwg+Je8YoC2LqkVc5LWzzmgfhgflyYggl631qF1e4YUobXJ0sP9HDNjzDr1ibzJGKgUn1+gUmM6FHSSrSpOqSlhdV2EY5q5RihW0WwIno/NhP/NAvUYNxyovlQsMJepnaQAuaAA2zEVpifYf//Gf1Uj2f/3rXhU7pGy9hit8RZQISrpybJeE+ajzhZSP17z21Qkub1kwTdXkDczZhmGLhoUHPzYjhWOsBCxrkrDyQDzmCmAHMjHeUY93gRXeLGETjNnlGqyvc1P+i8DGsLwuh/OYY/5Uh4tCWizl8R6Icp+7ztrVSeSylAtcZ711igClLugee+yRA3xNvO6/zO6W+hJYdPsUPV9j9eQiRhjwtt0HIQOlXXFzlpaDa7wOhILdrPxqgZYNb84VRjDWEW8A3w7GGW+jySGxrjNPD2Pn5tBQeKz8xWOIUDzyQsW7/f66FG34wx+ODJv6wGal5veEMqZrwXYRlJXMDQaLcGPRdteRblvl1bHGZnlWXnF+YHWO/CpEsk022ajeZ863SHzsWbEuLSWofbls2uUDt+tdeVM8OpaudSs4kAfAsxJHSzoJ74xSIZwa9kdt75y/xymUWvK0PVLeRTNQ+3fm3Rdv2bP5WV6Ya59y8smzr8Z76Qo8CGiLhcC1Zj2hxs/Pfs62JdyMX+eiQw45rNZq83g5myYuKsVkv31/XCELgqQS7gvu7uLsmwUmlj95ZKpzWfdVV1ktqMylZbW/N0XTpZAUTT9/I+CHRz9LU2KlA7Xf2/dHPyzre7sYc2qYarHm+ivGgAO7Hn/SKYmln1wx1w7JdPil1qjWrF9VTg6CMJ2l+uVQpjzTmp/B3E3ucBTzzfE8QP97vPJleZ7UNs6ZrdSGzMk6iV9hx4LqnpLevwou/OSgn+X5/hEkZ27m6JlZ8y1TYeroKqZSTPqKOz1YxqN9iJTy/NQD/tjHPh5hrTtNcwSGshpwcxto/SzDWGyvpMt9+hOhLVfbHChsgdwjPa5DJ5pPd+cnIQKKvIhpj+t0PrAnZ2DAdaO2+LzHOibbQqjnkIIbY+hG4Y8rlMC+WC5zdbc6tjgfU5zb2KsGb74P2dMhLEUPukMVOBt07gwQ5l4ENpmgqpff8fJGvqQz0tyAzjxwJsk354fyIPd0EbrznlRzC3zt7BQvI3Mmnl6lIsmT3EcpVJ+TmjLitsZJsY2UGYpzu/QDts8vDHlNvFAzDoid7jmUEsXl/cYFifx7Smped901VqxKfWpEcvGlF88uSs61UId8679dcNFs+x1ekFDS8XHAfjD76U/2L2eBgjeeeTkHf849Lwuhab2UqXS+7BscF4bA3SGsQj/HufbsuBfY4JwiKTwFfWdPeB5nzXt5rVuExDSg8KFfPD9j1hoXIXTabwX/Zr7KGFfLOQb60EUVF53OlPsscvqpJ80rmGL6sDcQnmMDgGzceBzQMXiLWSSYHGzwn83wqf/8dMGob3z962c7v2intspjnbo+bwQpAVOMh6iGKVeaq9+EgEcC+byqKmgsvdSyZYmMXKFxzwHnjo05LDPjEM8aDYYJzGFJFNtsihFiF9scQwmbKAfcQvFCCUHMUWkkyEnSCCgTlpWXw8iqQhSykT2bGqvyWY1NBwXzQCE61Mbg/iDaKpYMIogldUNo8tZA/d0VAmvw+DXiHrElzzUOj9zOSvHIgWgIuWN7ReqKUuF13h8PleevowlLjcfQVnsKTMQ44YVrDXb0n44pwo8/2Ghid01Q6pqbytcRZv5u/h+IgdR9Qrvxres9Fi+w4K283N9cUcZqkUqnUSOYdfmcFANgCT45Fasc4OFVVOnAaU+x/qxHpYxkrgj16u8awdUhhNT/jIdfBK1AdsougqzrvdncPNoWfq0bhkJo5ToJME+Tn13XgVf96POf/0LVT4YaMALnJmZeBQKyj8B0xk3giPv8KPWElVl0AJ8WktTygc5+l44wZ6SQu/q+blzVaip3cclKnQEPXxbyEeRguWrD97jy3D74wffPdk26TOVh55ko0nHeKFNOMwgYK/jcdPx429veXMQmTc793hrL3eMRr/mUtWff/2H668argSTcm3068ohrMhZWnDUHtWTTOa/DvtC/u8A74QdSl28p1Wb7dNghmIQdrDMUpEvYdenFRzJm7EprcODBv4jnfMFsw402Lbb985Lrqo8rgxmsyyNgWEuL4cGD79ZZZ93ZO5PO86xnbV2GgPi61/8PNqPwFxpvEUsmPgASH+Ulj1fRCnNtLRjKBHs3cRbyeaiaHFRObwRuGTFZ4zpzE2FNXnVTdCc2bzGNeCCtRIcccraGcF48Mfh77uo2dINkNVIiFvakx/h5ZuSQl1CFKl4KV1TRgAlBIfxHysaYD15jlfhkeGcsZejJd+Q15Yv8GTFBDbMRwqBtVTs2oSDGLllGAanixZC/MilooGJwrpc1GkYtD2+E8I4K+VC98O7juXwV3ZgzJzW6s1/Ge+wN6AvvkyLlYIm3QseM94yQ1m4OfA+ZUjgEY18xli9/5rOz3xx1RD0/eJkB+sijSYUJM//chDVAx3QK/o1QIXltP0GwrLEx2y8qafGQcTnIGy/3JcNHag2HiSw3Nue7uCmZR+/33iIjTTwhnx9pn2X05nxASYtNMBnpI+TgWoucevIJBe0OV7Ws+AlLH3CYiw5mVLm7+eKRVgWJeDVaL3mYT33q07XYz9p6yzAzNw71fMfy6AhE3pKJr5zCLDKSxqEppUbp8KYEyiUVm9Add3hhrIqn1AMOiryDMNhWgxjl++giP4LsLMyqSpFx8dokeRcUPEFGngNk3VZtlxC8X03dWEGPBa4AD4C4uvjyvFKIw823IMqDOQgDDl+40hFBTah6mafBEDOnLBvPRghSml3kogPdYxMP0tWwfCmKJoIlBlbwsLV5pPKs3Fe1IkYIJYaR1wQtqTsIUEvWhj75lFOqC4iDyYMoiDY61uZ4LGzMYuBOsbmuD9qJzRW7KRJR5xdSpATI/UEQHM7aVOXpde3MR6Lo5Ir5+zbbbJ1Y4uYhriwzWy4enr3xxKQ++E5YUl4dNwlhJQxR+6zYgbk+YVL5rRlkE6vSlCDGFth3sBJBmkVIiQEw+uXWNBKCC3mk7uF9lIMDcv75FySh/0sluNaJEr03UJ8YnnidgvVKAhI01p4wOztVnO67L0UGghY8M5Auosb++x8URXrobLOQ5oZCFwsE60JGCBzxKTG8ihfn+tdcc3XBme9657sj1NpzKGNwmluGhf0hvHBqwiN/OPLo6hK0yiorzk5J9xbz4pnnBmpzPQzhVeIJ/iHtB0HzFFs3LqAECPxetxImkzc6rOfab0PRLqSchqb1PvqkYuoZ6/JTiyzK5H6pCTmHFBUlpOuKPbzlFpvH67hk9uezz699xmDW7WPHHbaf6j/HqIi8qIpayIS5VtWljoIT53zDG183e+lLko8bo2AgLbXvJjh+FIYZsO+QR139J1W4SmjWb2vfgBe9F4GGpzIg4g02XCclOTcoJQIxWUL5RuU/i92uklFWrLxzjF7z1PvJV6WslYMRpQxeLvJQQ6d3xSjDS1BW8JF41vMNf0bq1K3Ec5krcUXesvdAncgSPA9/swfA/ZTDaCE2ZHMjZ1371hn34jgMoe7fHJOKS08EJPvCOkl3Y6gMJdyNNpI7nT2OtW7fg4Zd19kvxydnAs/k4IMPrjV917veVfsPtEupT6KhrlmNzXNWORqHHnpoYOgbg7okjz1KV/7v5alnDeFTLWyPVAf77e8OKaUnHvrtVBE78MADStZ3TYJVohRvqBRK12NQep65UcrlkER+kAWeGxQ9OCzGNEhFnmEYq/ad5zGfvsyfanj+zqgmX6FK9r/5Jyd8pkmsy9b76RPtBoVv6K/iIkzGfK0jub9wHunCizJiE/O19ORFuBmLi3XJauAZnX/B+QVbffZz/10pLa961e4VowCDGbQHkZ5C0KyajvF3hMHp+mfHuj7qqKNK6KszasHkPWEd6qzy3Oc+uywMUKcY3rAKq8/hQrDPOCgmcHg/BbNlLKP4Qm3iiYHl3mKSo61TKfg8B2H0qPzIHNA702R5HGbXHYvjuuVFTFDP+HdZcgUvN1wEevQeSqZc/0moDyNllEqjDGrjT4Hs9jZzSOMJYBGD68oCnbo2+LxncU01iivmEwjIvesw5bBJnRGLVvMVJKipMaVGeIB6QCNDlhasU2NtFIKiLdiIp1VeXTN0Wf6EAuHhWb0wD8tbzEZ7WvIFMT43SXoTyKdKf0WpqKXb0L692rWjxrU9J/bm1YG7zRMLnXoB5Q6DpNe865iywJuhGgOkvOLON2S7NFnGryZyTf04EVeyDlIlwLlYguunJ6z5x45lrW+U/p/qElPm1uL65EKDU40bnLRW2p3NnTO3yD8/+/kvqiOPdepWfUaRNm2BrXjU4OsqchECCyhTIQDe8Ic++MHZRk/fuAy1hWOAhow4Yv0YpIoNkOFbbrlFpdpckepHGz51/ZwLsbClZ+tkHLdG+G0SFOTsJNF///v71oFHnpI2VLNQrcZ6Onqu++f694Ifp/eMeretM/y/eK0UnqXypXzk6B5iniErxZgM4xITlvDWJUUy/933PFghHnNA8UJGePPgXYaJQhqELiOX0YWdTdldkBzI96VM4jvf+Y5JoHcrP16UezFMmqDTrM8Fe5Nh1m3MihAoFzrn5tabNZPQhSYpajGaVeTisay08gqBG59ZBhhh/MQYed15qMMApTB5G1NYYoQGHkMqNC+V2pawUWRbsXNzbpAZfY5hWXXK4y1VzjKUImfT+K33UO4UaRGyYvyab46IMVISUo8gMYMsM1rHuRb54/deg4mKWGQu/JvS03lJMQpGl/FpyC5cpTOXjkBVBCfjWSnOgfCdsIJrjhJ69rtWguDkuXPWSTP7g+PsHJYwVWpgv/nNxbMYz+O7OKoQnpZvKkxt9/ztZn8KD0Z/WUpUis7aMd7/GoN0/3Qh2iHe6Fve+pYUCdk3yotBc8/sG9/8xmy//fYtMpC0Pt2Gbk+uuHoD4vEMLhwbBqa4qzSgJz4BwtVpQ4MHAwYfPa7pHK92QtpZMn8UpLMiU0N4wb8ZDGU8ZC6qi9Lk3FgL1+Z01d+nmHoRISeS0uAUlSL9y1lnzBul1Cr2NFnKYxAjsGpgw2sd0CoFxypg9W2y8Uazj+/1v+qg/ed//kdh6SaHIEKcceBAL6wG9yDIQGCnn3F6WT0GKo+nSE1hLLJOhtUnpWbnnV9Y8cCuEtJF6sVJmiCwID9reNRDYXWMspOfTTarzvttHgrPz90HU3wLtAgmQVLp3KThjQ43fsRsxhwM67MOThZ24bJn4z3lDVDsrJs8d0HSU13MoWAr2zPXcL3u27pk1ZMdvQcJ24Zjl5yfBjTWRPcQwr+ae+ce4hnHpoQdwsJKiSFjVfMSXKtFZeeWdo1SMGCL16FIywhBMIryZHkOolFB6Dk4lc4xWb3yPMVCVlh+2RrfFomR1ZzGWvY+TEbe6PxKVpV/uqAACAtQ3OP8C84rhbPyFPPWXHmwN62d3GVt1UZLsXqKgrbyLIVKUsFTYfBJcwx4n3D48f77J459XZEn7FkCWThgTqxsLN02TFKY/5LEc/L+5aoN1BNCREqhiHXXye8vmx2cfFFCahRXd4DEuQYjk6EGYnT4XPuxzJFqL3vs8coQYF5SArdgoszjiH3zRl2P131kCtKfkIpF4rUE7GVXXlqseGO9L4YraM3+vz4x/G22eU6Vw/xG8ihZ7askDtuKshnUo7tRG0z2nwWOGJj2YnmmrXUnBdpbASrxULw8+2z99eaWB8mg6zJsHUeHSDBwnd9GRwj4tMRLxSvK8prMsz2DoWoOwd2MaDngt+tXmxeviBItKz9zoJPMa1/zqtQdfk/lU5unQjDynfJtFujUDKGMqwUGAoXF+GV0Lr1c4oA513cHbuXZdPzuoVz/zCirmwIjb5U4+HJltC0b4x+7XDWumqPJ4AA9S7lCBFSYoiBbDNkoVIiKsn72QRnwUy3skkFR0C7SsqfJkTw/xDh8ig6FJBsge1YKB8dh7bXmFJkLiXE04/a5UQShUuzyGh4QpcmbEg5BtPpnCE8KXYwm26Be+9FZV6hDk21kOqxfe3wY9YiQuBGUj7GTje4vhdCcmfdDgryQyW960xsq7ohzwSA3Ft6cilsQyB8ntRFC8rW9/yf55ueEbXxJ8kDXTFrQBglBrFWxZBkUEEdVwhDNRmx2/3z2oBDr6IkLotzAwYrSe8bhQZIrF8RZ+8c111bDCChaIwY9LyOVxTMzKDB+/WxsoxzgqJLm3/SdeaC/PKf3dXGGOHNSsbKvKWz3F56hD7yq+l3+E3suFu/k5frcIuef+5d54hWEVmPFfdiHyzI8vxFctbAEoQRxm0mc0Gvu3DlpgvzflZP4vve9tzdQbjYKihNYzeqKtZqHKIi1ilkvHRz7otlJKUIgGDyqnrhml6fC8FqsiB7PTtzNgvJqh8ep3FcL5hZO3UC3c6uG9VRKrjZYF54Y/3aPCjTn950+Eap3hP8orl+CKRNCiRFsnpcCrD5+E+TairbLnbUH1PHmkXdqwepg5ZA+VoXdF8QVzGlZNWKUBGqEDZLUtdeGxZuNPRiZNvbSIbg4MIXH5z4WURWpC0NcOiNVb5Tv67ZCKqF0zUwH3/3FFIp5m/8eiSBgWQ+oz1iRRwibaskkBSDPhAVNmYp/UXANsyFqPaG8SClDSFU8AEbOaqmqQ3DaO9q2se78LP5MiLgG5vGwrt0XZEy46LBAefEaCFi9DsWrCgaOB92edxsZYrTJly8lWjYAASgmWoqiJaEfxaIJaYLhxz/+caUOID7YY37GGB1VoBh8DVc9lpzEX1f8ZuMYhvJqQbKEzT77fKMOnhiLuRGH73h1ILncR/wWhMYbG31oL0ztU9WRXvfa11VpwgHpmssRsjBea3phEu2x2hWCsBewF82V/MvLE69ivSN7+KxYEqPspbvsEoF88+x//uer2Tta9kUpZY/1q2HeMR//79/0O9prXeCRluGR57kzxiZv1B4qNnFxJOYVfA0mR0AyV4pzuM9tqQMN8uXl2f9XpP6zcYpBK5sH/iQvIBX2lNid2BWvsZoOyIcN3A9K32GHF8w+/OEPVvGG0SSCzBgG61CmIzZn/p0bf+fpFXoBocF/CBHpHrmZOQe8nXPPPaf+PifxZUTAJydlyZ6pBCDfa0I6ns67OyVhkSWXfPxsu+dtnpMT7/yJvUfujkdakGs+M/JCTXUhNtkLIzQzED65xQrXQ3B4ru5FYDtv4Gw55oyv0TaPgdHkxO764mVtyEOKlJFPrp7557Mrbr1pCrcwshiIw1v3XjwPoSlKi9IrA5f3lO/2+yAVeSbZCqonKfbw29/+tmKRahnjrSghOOrvVmGSpBLq8qVFJY4MpIiy2zolMxmGhVjk96N8p2eBKBXBK4QvjU0oPJXpTk865N7/s3d5yefFIBS/tOdUI7KGziZZZy7FvClI3iIiLHRqKEDPRDeZH8jSqLftGTllZQioyjXB4wwRc+C5hrKtdZkqMblvyf5h+Ga9GRGjat2ISY99ucj55/01HunddbFqHDtBhwa5MIQyNhoFZWIk+0oKHzHCE084KU25jynt/fqQjRwaf/NQBIhFqj6XmUjM1VWTmG/CeU2DRXvssceWJ4sIwiMQvxCTdOK1ixJ/kiwMMnN9RR3KopUjVjFPiqorIg0i0nx4b4pdDoU3CFbGUEImk1iOzcLxpQneXBjmHPNQ9wLzFl7eTC8QRBkkqqTkOYen7ICVkhudXCZlO2oPD8sbnKkWcCWbKz4QoV2bcKJjW1RCnTV4cVAAVU7OPfe8mj+WnDl2DVayw6j4P/jnzlTKYWDQNgt3xRmH1AZv+EMZwlQHytoPIQzyUIxf6S5KQrxQgXTrjCyyURq5g/Xq+bPJGQCdRxYYFmycQzFiOsbpVZaduSuCSytURfGxm1fMfhEWwGwUjzG32Mqs+KrHyu9UreJ/tbsAACAASURBVCjXr//mI7oN6Q5vDyx49l/OKiWDrfmcZz8/Rt/VdV/eH1jy6YFaUecdNvuBsDnwwINme+759jrQ5557foTJmlUz+qKLLq64X6M3iYHn+uIm7oNA4noVF82zrBdG91WBZB3G97z7Xelx+uT5h3UQGFpotxL9Z1IbfpQ+o8b/qjDAMTbPz9o+J3vd2eENizWprQzW9cKAf2kS2FUQ+690RaEA6vwORVogSHv/417DeJqPptSnFrw6DLFYFCkOQPq2Jo71ePNctkpiSIyH7KlHH9MdCdGr05QG+azrxj5cTGNn9Oopnxy5jvDdMAKd0lM4AankV6naBB4UD1s7gg7acNzxJ6S/6XNn73v/e1IkY/PaO2KKlSpUse4m2/XZ0UC6C0WUkbwQylNIhbSVrMfdOQtyfRW8oNDuS09R8K08SXG4ERUwE4U4xUO1vxG4Dj/sd2mscFrqFW81e87ztp+tXN6y8EqUQvZMcym6JObwlJx3578EcX4e8+539nLF7avONQ83Bmy+8/YoU+edQnXWyGLK0WuwdysGraxnnB7zTcGCXHVX4dQ4e9bRPSgOhql9oVa3/HPXXri5gH3PQLS2XhQN9PCKK66s8JpC+QMVG+xYleQa0esex88MCkXJVY/gyIIzU0r0oosvKXTngvOVIVyxGr271zrhIuBPeB7nRZ6nn93Hefe6O/KfZ3v1Vf+o+C0lSKZeedUVpSBlJQw5btye1zmxFoOkOdA7+8fYGAN0gmerfTTJoqEoxykYDliT0HotXAuxiRG91lprF2Lofl4jlr3IH486fB6hLUfHq91/9UK7GbfXUCQuDhIpXD5KlIV6dcgiWJDnnnzqbNOkDVjAV7zi5aG3P7+EjkUai4q5ywoE59owCqvfWK2O1CbVg/SmEiKnp8A34sWS8QIpWp5Je0id2I59BQcX77DY7sFjs1EeysbF6BsKYxwyzzEgxYVjwcOiqJJ25SG2Jztyvfq9ClYvaAc2rumADKHkecrLzjyCKx0UcWR/r3q8k9C5/Y5AnZk3sZJmKyv6nHyrCbJ2H6W7CHeLRIDwUqXknHbaGWGShtQRS9Rh0Jt1WdVLsqE7VtjemXxVcyX2rEE3ViG5bYwO7v2BH3tdJ88uP5vXyifJS24bBYp4gyzmeZ8Qa3rNKJXVggbwjMBFT01c9EnpCIIsZu3sF+xWHnz1lc3nF41Ha0+NjV7hA8o+7yE4pftQuGI43u/foH6EGgxahpjN7iAoSlEKmmefOPrjA+lV/HVaG2MHr5sP7NbvfPc7dZ8ddtixBI0KOVKu7qg8tsWr/RhlZzwOtXQNRKSNN7Knwi7NtQ8//A9hPJ+Qg75lzVeHE5Cv0ud0KqNZoQCxvAhJkHRKhVWI4rWvfW3B3oXw5DViOn72u1G+77AQNH6bylK7plUV7+EnP/3p7Og/HjN729vfVlV6Bov4lNSXdaDviXe6buK8Oiv9Me/jLdtPg7xWymDSkEORLmwU19oPyZHvDf12ZSpzp20cRbq8ri6FsnQ3jB5/p5AU/yC9OCkQRT4ouH+G3XtF6j9/4+tfqQbgR6SIvzgX5rW0KEK1GKoRhC9/+csL4fnGN75dQvc5aVwgF1Q1IikU4qif+MTHSsBWOcqCS3usvgr604Q+RoznHWd7GMYV663YP6g1hnjCB6DeOit5fxcgeWKtj1q1bWyMIhV93kHu9957V2LVJ8z+cNhvZos8cPtsm+12mq2/0WazuetuOFssjkGPq9Mjav6yL0ZrOJC0l309Qk7IRQWlZg4o/gfIi5wtcg78SZZpe+j5zBUPy5khez0bZUHG+Ds0jxJSuAFbFvvWe65JCszKYcuP0MYgKtnrowqRzw0IeRS4cdacYwY6z9PceyYl/MDt8ot/lRj+HUESdtnlpfVMoE8GvJSwNRMP//o3vj77wQ9+EFGSlJU8+x13DIRkFmKpRuvxwHP+Xrnby4pQCk0Du7/kxTvP3vKWt86eGyPqnszRX3J+OQvgYLJemtXV/7iqHASphuZDKcMylGJcQGms54hfNn9hkZq/URfd3JSDkWcaaZHmY8DmrmWuBimLDDb33sNIoc/oG+8f8eqO3UcG/fpXP5u33nrr1wVADAZjke9Qsi2HfSgaKRpekprdCLR1bSb2y1/+cm18k6LZ8Jlnnh1L+cUpzPD2sphADqwJUJ2Hg5f/OtCBOqWaTFN6ozmq+BLatU3h4J4bz4s1MXKs3L8KXOfeYKEbY8mjRYNANcgGg3kWFi7Lt8afQ9hkoWZKLuyBDoFWjX1BplRJvDnJ7V4tRJot24q0i0YMC9/37vTQUotCGE2CbXZ/R8gqZQs+CiRpYc0xiKcOaxaL8gDdiZ9SBAwFypD1dGrKdiFq/ePqa+LJX131aUFXiy3e3ShQ97s3KRi2PbXykqoaVZMUxIuGtY6QsnD5MuMmDAkdEKt/gatYzwws4xfDXHW1Vaq/rMMmNgbScX0F2N1rFLdWTs8cE6qPRMHyqm1EmxDMtuKkuEYMWwsmxgIBIz3otjzz17/xjcpdlF6CLKXm75tDdtCnsWB48aeJdFTEp2n+i/GbTS2H8cADD0yhjA0Tu9+kvHZKrg/RouW9rxf2phzMgRpcmoIaBC2Iy9/9XiH6I4/4Y+KRWxa13/p3a7SGWKWEQFnkMkoV8u+rYkUjdLwn+aJy8BCaEM+GJzoML2tv7OfG8v5u0l3WWXdudd7gif70pwdVkYUHHr5ztuLya8z2jEKVTsI7OSs1gaEDmnaz9N/+9ncVQQ/bkadS+zb7ovJHqYYKW/SeHUqoFClUoFa7X/5m/hglD1RfxoRlsvZd4arb5TkL3aRhOkePqW38cJF85B7r4AOqfc1rX5XayP8oJq++vDrgjPjbWWedHWPwijr/r0h1J3sLEnDoIb+vNKQNN1yviEnIK8b9ute8bvYve76tmOZgzEYdpr6uFW4I7BkvehQqKIUqdp7n8Hzi/I88yHONTMu5uv6Ga8vQ6XDOY0WqWTLVkVo2NAtdp5fxYgg+8QlBKy6/eHbAD/aZ3fvwYrO3ZM7XnpsSmjEkDKzGlL3hHFOiznKRF7P/7Y9GzdpI5ZEy0nEgFLgQ9tCUgexVgEFYgQfJgwZhujYkYoSjlNK8MoiePHDrTznKo6X4eJ8EvhCJakEV1sl9yRufdw4VzoDyUQTj984mpMt7Naaw9z6Z6lDOMlZ4pe1FPp511ll1hqyPUITmCHLG14yXRu798pe/nH3rO98tvsuqMVi7bvAiVdDG9yVjOGHkq9Z20xVpj5ffzg0qQFZfe+31NZ7/+txni5Q02Mzt1DxaBgYCJaUvfHhl0KWtE+9uXXB7GcL0i+cc3qK5I19HsYrBERnP7bpDdo/z4UwOw2xkXZAp5Jt1Y9T6/CAaUaR1rg753a/mWTi1PHk+oyWVOMEI0HJvCbHBDqMgr0mh5G9/53tFclm/6rLGi8kNLw8ksMfuu4Vg8SrHNQuXOEsEiZvbyIfE+kYOeEEKFhicxZUCY4N5GPfH+kLLZjXIoZP7SGh3EetWcixBL/T5rnwxb3bOqWfMdtrt5dVWTaNb9VM9m5eJfkpiI6OrxMJeabNmQwCKIGpod0Ee4hAyJqu6d8SIaM+803osNEOgxh4FhAmHXAXS8ZyD4VteU1X/6W4yNrLFYEjcGmv09ggUeYtywHR9wWQF0epZKU7JsofRPxJPrCoPTRB0b4TOA0QCcU+vrpnrECHDdPzAvYhPcN2w7gui48CUDk4kCFMzh9whBRtqRi3+Cb5FE18lNTYZJQ6+Z6ZElcKTWO5Qe5/5BIvxAMVQGSkOJI9ykB3KQMPizY0pKfPEsgXvYwoOkhs49tUpKbfddtv3XGYvlVEz5YqOdXQAzMWvUnf18COOrIICYFlKFINQfWeevJxLjRN469poEXjgKV8ODiuX0K+G2GE9i/NRwiNvV+I4ZdzdVAjxxbuEYgSEZ7osRuDLX7ZrsRNLWeWryFL5MtaF0R2F+Pfb78cVy9ttt91KUX7+C18umHuNNZ5c9yDk7o0yfuFOO1S8FkTmWXl1asz+7OBf1uEW94ZC9LxMZe3sjGkMCyvS8buhLIaCHd/F0Qkg9+iKS30m6gw+niKVxpa9FbSioDApJxmnTbXnnumtmj1nD48UMffzM+axHGyvU4JggYH1c90xdY1PCUdi7699vcpgIsgxFO8IxHzB+X/PnHw2xvnLKqfwrhiYg/XMCx5GLWHs1bH8Bc89fh6GizN3Q5UO7GpSfk/+tCKeCuTXieowQnmb+Vo+++bvf/9b5cbKJljuSSvN7uBx1t9jZET5CsFAO4QoIDlIRta9GP85j/7tO++8kaolyvvn1Rk3RczLRHIqQlHOE2VE7g7v0bUuuPBvZbRhQ5cXho0LJcz7Ro782HeebxDpRuUjStc8lByLUV78gPx7n69/PejLybN9vrb3bIeclyoxGq9/5ZxpyCFHAXx79NF/LBbta17z6vkw60EH/3y234/2L6SqOwWB/yExKkutlp8fC1/hvI4tZ96LX1DeH4UO+dLHWW31O9MI4KtJodymzhXEU6iLAjUHavSq9YtgJywzvENn1rOOOKj3ek7z7D0QCM86SFnmh1Hge/dXVTmpi7AMZMfn/G1c1/63T0YBiqELil19zNFHznOAWeIEnYD9Oen0IebIIrHAEsFvvOnGYueCX2DWn/vcf8Wz/F0aWLPee0Lc+OmbpCj9C3csgQT6GqXvkA6OPuboUtgsmcsCRwg4u4fN01VIxA7EFh8X5ukFVbRhRZ0/Yolcnrqw4J5h2Y34ItiGxSdeRXHITfJ+VS6232H7Yo+Bb0bctBVqKrLEUzZxc+fOrThLTTiIJ4L14aoSEwExEYsG1Z0l1pOXySymZVcHAqsV3ISJnIkG79h0reKQiwL5xou4KUIExo98YRNLSOZxK2ihaAJjBPFLn8W1E+hnZEhtsSkpnWblTvATq5sHmrtU3JA3Fk9JFSYCocqOZU4pKgpDiBR0W16H2OQE61qznnuxw/uqwojnWy8x6PY8V6yCE9YIQxf5x2atg5/feVG+0kukNGCc1lxPhk6hzSCgWOlg5hG/KQVIEWVsPNKuF6yB9Y+KIMQ70SaO8HnjG95QB6k8IrT9J4hPLSB42fiU8a+jWJCu1kwnkXtS3YWlTrmLdxI82q9tFIZuebEJjIHfeUOYpA6J1mBa0f0kvUUPOfSwdLV4ZhHiqm1W1rXzRZHO0nigWIVBOgLN2wtINDodbRMB8L73vqeqUskDVjpuWLkLK9bbb709fUUPqFKDLw6sRUAhenz+819JDDEkmLwYZrX+udd1191UBKldX7ZLvICNK2arU497Wy97rBXeMIqazQxtGPcd3vB8RVO7Z4J2JyVU78mZKjgxQs8L0sF4EAfuylYY3TEk5ilqkDhh9sS1115X7GQFGpTKfCCVq4ZAai9SXmeThuQY2u/f+tZ367OeH5HQ3sK1OOSQwyvlaIPA184D4s+eb3974MRdp1h9Q/MN47cS8bI/qmXhhCCN5x7xU99LoS6RdJRcE5oiBaeKmWj9lWfr+H0XM/HN2ap6wRXOfzRVzS6Ox3nnbM46G8xWnSqXmePByVCpDaw/yJmefcie8payZ1TLaug4Hmzu3/mRD1VJUXMmr9R+84zy6ykkSrD4F5EJN9/ScVPnmBwZ3V1WW33Vuq6z770LI2c+5x7XhPmKRDTIdcbmZ4X3DzjggEKE5IzSBeDS0TfUmTSGi/5+cXTBDTHsdgw69rSkPi0eHsLeQZG+W/tS+g2j1NjJYuu48047106T6igmvjAKIkUKF0acuJpEhL8glPeVL3+pSg/SOcIyo8CD8weRQMYbXrU5440y5qyx+aLsKFe6jZ7h4K0V9JLXXiGzyAvfebrmyrwN79LeHzWOh/E7yJajs4z3DkVacdJTTj5+HkvGYV8nwtPko2Yf96fjK2Fd42KL+vkvfKEWAQuRdT93ztyy/r+/734VU9tgqrkIUhB83jReISvRA6JeH3bY4aksslFRk7WAAmlZmNEr1AR0EFjMQ01UeaV3FZvT+HR/v/badFfIpBG+SBXzN8oUvEfNx1AFHzgCIA4WGu+KdcLrZRBslHgbJQESMG7QionSq0+ifjF8ywrtvpdeqhY9McIRjDySm/2eFw8KVWOUBSXGAJKlMKuB8WQtIoeArVkv0m0IJUq0BFYMgWpknE0CCi3mcQ4vIV3WfAgelCNBwwsqITZtx/IiMmFiml2qTw9E+bPY1S1gSsjWHLV1qoMF+EaMigwCtSB2yLPDqLO5bdj111+vYt29NsYYFm4s1I4bKJzfnjvv+8ILzyvmNoifUvOZym1t17fGscA7GqxbtYKTIqNnYmB9jODvfu+7TUePRY9Gv1vi7eoxdx/BWJSZ/+oSMkGR1so6/y5J3meceXrR1o3p+hhuCthv9LSUK8z8yF1eIVVtEIHMM7LchbHsddQAd1Fkvo488qgkiX87sd4wNaVwaAIQ71UIYeHI4j1Z21YQ3e7r7ymBhgD3b//6ybBZV0i96BiWVb+1PdGGDqecwhgVPN6TT0n93i2fVfuOQDSub37z22GLHpeUnE3jjQgPRPhHYMrbVNv1otTdfcra3Xh8mexHnrD1bor+lBYyQhFVqaemvu9vLXhQE8z4/4V7xzj9vipM4XnnPEElrI3c0s7jlIaEaY4oJj78cPIF58zeEZJWEeKSO4uZK//TNb0YW9i+t956R5XafNwiWuw9GMTputm3kpSvFmyVT0x+obQLVZtWj2JYJ3tK7V5F/D/+8Y9V5TPPYo9QJNCGYt57rpyR8igmJGgYDoOZL7zhd5Vzmn1Ebl2boiXCRZwDPU3NzSPTnvWcCHGm686kqBRx7t7bZr/+xU9mczfcbPbKV7+hUB40RYqALDAmitSZGAVFiiiXa5ZSzb2QVUC+ZbRHuTEANG6ocUUBLNyv1b43p2QFpUbpkWH2i3NtHuxh5xN5ihzruZnCTRH4lMroqTtirgxTsuDUU08pcudGT31acph/F9m+fTUVuP32GBph5YrRX5c1OiXvE2Jqmbnh7JWvfHmluP0+6NHXs2cXTceulVNAhOJv9vbjQvY7N80Zdp3tGnb5SSedElb2WaUEpXJ1begeYyFsmb8u2fmkajCyXtLUvvudb2bsS8+OP+G48iZxGhiXkC7PQRlSaJQsXcKBcoZHalkxt6fiKgyJ4dVXnDnvNyfdMPyy0lPmduTueq8wBUXsPt3ntZEl8zn2lHkuo+mcv/55novy1LjKWJP+eEusCZtqTg6I9IF9ozAlibupEmAf+9hHsvnXCQx7zmzvvfeplIgttnhmpQ0QfDQ/JXRy6poen64CyCLIFAaFtcutrpzSTHhTq7sWLchUrhUhbxxITzwm9R5ZJ2JR4gCVoJ+/Y2CCJTDpKv0iCsl1HNQnPFGOWlcr8ntQFYVHCHmB61hgNq64JILJ+hG0PGzdPDaJd/0k+YS5Hq+kIDoec/6z8KORLIupY36z8ipYKpSqjTgOkAPHg1tjzUBz2fTGpexdHfxK7tYpo+vbtgBo5UcpsbzNiXtTuBTs6F1ZMSywbsU4k4aReA8LnhJ38Cs1Zz7c1Xm3lCRrUYzQ+MQEkXAYHSsGLrJWDIYuhhF4KVCUzdJNbTMHYoRRyn5XzMJ46ixNh86mBkcNKKs6yy+kSAd82Jo15LY8k5rH5lOay34pyYfNqCydvOFXveqVZQS5N+SgY6KtGBwUXUMwXo/+49EJF2xXh0UeI8KWg22fqCZVKSp5bgeGEFF4G3kHbK3vKK9OBSgVWHjW5tVeE2MDX8+J4egxQNpFaIuCNY/GeNFFf6u532uvj4fduWnNo1fDWFOO4qTMzPfPDv5ZhMzZ2V+bFgTtd3Nzzpy973z3e7Ofp1n0Rs/aPMUjbmuBOSm+0Zauu56kNmv2yH1RMHRlWdWg8skTqbrJ5alNreV4WpMxM2KmrWL7tWCcLdyarduYSkNxi1e5w9EjFIzMg5Pr7O+f3OsTHUbJR+yJK+IBjGYNDD2fV3TE2fCczod8vKelGMaVV14++49PfSYGy+Nn733f+2bPSoedU049OajXl7LmS1WO4Sjn9tKX7jJ7zatfXUgXxTW6RC0MYRv/8IKHAdMQbbmYdfZA4RSe8VwVAxfMvExIUwgzi8Zwsh8rhpb/KPzbbr0xCAOC072z6/5x+Wz1ORvMnrrJM5Nj+2D2ehNq8Aq8RkEG93SdEfoZe588G4ap8UhjIwMpKB4ZxTi8HQqAYX5OoMyVIti1TsS/MIeMGH+jvAh6e9/e04XHfh6yx5ksdCtfjHn8kq2DnJDRmLUUJKV85JFHpPrWOyvs9vcgHjx186xgPQ9NEQPG4nOfw5iZVQ3dz3/hi8V7kbZFpiAAejbnxJq9KtD907PPf5KCDNIcnT1GPK9T3H2gBGLanAHjXjpy4KpwI161x24xnj5exVHoKA4c5AuHxtgZDJ5/pOdAl+irEZIc8WHr6LwYv9dQmPYkpUh2eVGcg4hUoabIG1655zCHZOII03j/IE5WzvOVV146T8DbgCw0r7Q2RQQml/XII4+c/THkDcpKGTrCXg4YKBhZAGwKtjwnOVo+v3HiT+KpBB7l98NYlujObwg8p/EvBthNsagMFOHG4jvEI5ZYfQfTy5GgshEa418i47u5Nomv81Lq7bbg5Mg3tJcFMGm3BS4rtm/BrnKPCJeJcVukiWanumZ1G+GdZcyDVWphbAZ1UV+ZmNXaa68V8seFlVtKJtncXXeT4JKy0fFZJAsbTUHmUS/UwvVGFvxO7UidasSJcw/ShoLh3YkJtwUl/xUJomO/PjfwfvCZ5Glzt2SgFBClA1rvIyhZRPE+XNPGvzNxGhA9T2IUlAcbMwi8p6svhTUdb7ww/yXRyZX6S75uPLHVnrx6Xbs7L6hmNJUii9PDk3aAH3k0MZDAVHcnnUAyOaNik5DHQPc2Fo/al7JpC8cGW5i0EYOwxjBwULqyyb3V1kxSv/xIzMAXvehFBa+CwZ4wFao2ZnNpzg9IG7Of/+Ln1cBdAwNMSUQHVHq9S0FN1sEhkQzunhflQEspAZUq0CAO8qPEd+SQbrrpxgWXunbnQrchskzWE9xFwetAUbHmqcKXe4I1X5e0r6qkJR42NYkeXtGI4f4+HV2OOOIPxW62NiXAM0YCBnv0bymmse+++9aeZhDaE+Ma5nXAxIzBNrYGQabZ5QOmGvEcc8+I82K0Vv7zRLSpX9ZeG8XhO74qBICkx4Cw3yER1fS7Kih14fTa2/nv4gji90X5IQ/p7frSl7yoOiZdFMha+oz7NemllYrxCxHkX3bYbOUVVi10QI7zt4IE/C2e/WZBtPZ45SuKpPIfn/pcznga0Se3WLu0yy8LfL7NtiFZva3Wrtj8FUYYgGEjH8MTrr1HW5VN0d54wZ+8x/xq+RWTw5r1uvKKlDEMAgbaX/nJa2Qe5KUGWck+fzS1X9Wz/mcqT90VL3vDp26c96R1WUG6Tcg0h7xJ4R2euCIozWzWyapjo+M1iI+8UURM1a86DUU3nI7TibFCfHiwfofYyYkhh1eLoWfPVu/jCHlhFPcij5C3GvJMIQo9cONlOy++sIE5IaqUdcU5sGqnvRx33LHlYOgV7KUa1ObZozoY6X7kekhK5D0UjyxEGt3n81+abRrGNYJV7aUyHGdd3D7hPQimseE6YNIX0TL35FVyYMrrn8hxzpPwmk5JXjfffOPsC0FCGfSUvetVTDMGG3RJARP70T4YUKvndD/zY04r5hx9U9WjJrIaWWCOijSbNbMfRptO1zOPzhFv1fyS2dWJK/vP70flqc5wCXkKtHvrLTfOg8kTvFcGfnQzVViuikWpGgxCBAFHCHUpsuDHmYTqHZkJYw08Px6oQshDMbkw9peAtLxPlpbN8YD8vQyE5yhnarjK1YFhyssieNGjwbijPVDHPJqR6X1gOri3jcVLNR7KXPsqNPIRQ7CxseNMmHqy1TQ6G7risCwgccWpJJ/fWQSe8ujGYMwmkGdwyilHB3Zdo5hnYpZFxoiFzrDgPfOmBo4mL3cE+cUnFY2olk0TG7CEE480CraF0nz0c/6hHOxU7GeHVTwJNKVTSROIBjECcxcRa5AspK+0VzsqSC0bkhL4aa21040mgvLmwEibb7ZF4jzd4JySFpNdKYoF+/LhWNijCPdABoZlX954HW59QhvWtn/OOuvPgVXnVHy85qU6kXR8aGEIcSjSIkIFvte8+rzzz62uOg7asekIcXHSISAb79hzzzowbcEru9g1XhHJWNbYrsckJrp1UlOekW4UCHAMAgduHBDr5+eR3A5yPz7VgxgR2267de3tn/38l0kjOTpG4FNr3RyeLlrxuGpADvpnaFIuDqn3EI7gxmuyT7cPy/A9qcjjNfKwh0Ibzw7mPjYFHuSpej+rWKUW1wLt2oeUiDjXgamgpJgDuBPhpkoj5r4KyVdBfw3QxSvnx8mxsxtKtD7Sm7oyjoR/xTy6pFodWMoke28o0/lKtJzPyQvlvebLGS8S1cx+SC9MuYNZA8rLnrr0kksTqtmyvFFpQv87tbaP+P1vyui97tobC5o1H5Qn6NNes3cpUtY9WfL4IEfmSkEJIZif/OTAMD9/UATGD37g3cVG3n//n1YqDYGpsMPfQvpRDGSH7cGQryolf8/dmmhYgSk3eSKllVeeZ7Pvu/cqRZs0iCBQyHy84jJmwupVJxerV1gB0uCDcqsZEoptXBlPaKWQ7TaOh+VKUK5hJJKf9vwoHsDpGIhNxUbz7JXuMqWeGSmn4Mkp42f8ZJp5FRMfOY5DNjG2GXGuc03QG6x9ZVkZdZQCpIZsHGTQsUfJCJ7UyK+U2UChmHcwMTlnHzoDWvbt9MIXljzXzgxyM2fu3OrC0p1f0peTMRr4mKd6aWTvl7+yd3ls8syFZ1rG9fyDYClrZ9FL7mkzyN3pPAAAIABJREFU8bvGciu+Lr1apC+o3GT0QAHdS5hsk+R67xWvVAaHZ+SojYp0p59+WoV15s6dU+Ol8CjCDuetVF2WcH143YO9y2v1zO4/Gq8M2dbE0QXVs0C/dBAnoesstCE5GN/W2t7mNC1y0IEHzPPAhJDKIto97Z7CwuAMpZ+4yhYS9Lh2aM51KDKIlZLq4iFOPuXkii9YBELLjQg50NlOO72wrcYIJgO87LJLy7of/e+wzbwGWcfPDirhIZjsMyZ0MK0q/WAq1Dy6P9wQK9EDnR7FTelj+xJyIFLPsOJKuk1EmcWyZB1W0vTkFZXgy+am2Do9oVNJWJWUkckTI8SY/fkvflnVfCqHLu8xH16Dal1erbKFPIhsDNAiiKcrfTTMBv6rwHrmr8tLdYWYsp6FswqK6+/DC3lGiqP7tybFH/rQB+K9nRem534VS7U5avPl76xP10A3eVCDgFzX1aQy8awJpCpPFmFMkK2/QaoSRYi496rxQP2+5qNZSQ05qxWayxojOeu5QHplBQdeHlbcjdkH55xzdj3n81LOcavQ0kcuFsbwwt5BC25Xi1EQQX1yYif/SFH3F2z3/GpXRiCvEC9Bbc8tE09XHEB5QPFGQo9n6lBiGJ5++plVi/PNb35TjVEcCUzNI7VvRnx7EAQw/RhfyGY8QrDvPl//2uywQw+v1BNjI1zNJwVEmSrDt1yURtcyvaveI0bvb+LJiHPvf+8HQi6SBtMK374dL2vt/n/NmA/+2S8qv+95ifM5nAoBUB7+TlGfdNLJKV+37OzMs/+c/qfHJl749CKmDYgUO1oOpGfcHCN96lJDiOATdFm9x5XXhj16Vtr6jfNBoIJlIT2M0iEMCiafvDnfO6zO11IuU79TtVvllt5TZxuMCfUhNK8MGex/vvLFxLPWTVWzL9S52WefvcP8PL7QIUX+W6hrFyie1aUGrcuK+Zv8Uop66Sj924K28FSeAgWK0PzwRz5ZRJy99vpIhVgOOODAFHD4XQkz6UiXXHzZ7OZ4rG96wxtnLwsBS1jqPilDw/vmnVevWvutvfE+U60clSFl4MpbFT5aO4VGnrTiqpm3W2f3JB4K0ZLyJ79eEYcK02SPbfDUTdOHNTBqPtuNNJRvvL9Sp1yfEnSuPJ9w0EDcBuHpvtyvCVKPxUDvnFrPjalLoTESGajCBhSrs2ZPLUwgwqLFrr07Bnv1SZ7i6z5vjzpv9qJ72uvWgMITPiB7q5lHeWLCaUsUG5nX+fr0vlU17tzz/poc9adVjqrqXlKytth8i5Y32duU4zdTmvKryV/ecYfnBTm4Y77cs/fLQ86+d8bWSZoQpvYpp5xaz1CpI/lbyxr1zTvM1sS0RqrIWXD+eWHc0w2/+fUvCkEAYdMnt+Us4sHY88cdd0IZbHQQJ5DxMlIMN998yzxrN5AYnqMwHOVonUYuaMH+mSt709wNY3jwG7zXNRiPw0B31kb6jHOxSJhW8/Z8+1sL++aN+aK1X/Lil9SBpYww6wzO32h9N3Mhhx+bVm6idjkaSNsAbrbttttOSlh7pw7SojLLV2ItmFBtv1xn5DuVQojysXltQH8zSAqAl7ewK96bVtGCZl/ZRDrK/L3qpKZQc5KSeV6ENmvHmKszwkOtYHh2FF1bIZ2XNmDkbkclNaULE3gmrERW9chhG7Aaa4xCAWVI/XAdAg6MStBScHWIKbUIJfcwVh7EiKEUnDYpUn+3mcRAKbXbb0/X9vyboGCsXJHqHmekYMWo3MG6q2boOXBFwrEpJ0bt6mF/ygOtmFQs6rXWXKsIRD7r8PJE3cezEp08WC/fy0oDN2ecfjtaTfHAG1aeVyQFayfn7dooQ2kbxqGFHoRCDuUyObgjJcEeoPiLhVye1YOzPwTmBFfrb6hl2QkREHvsvnv1qDXHhNRS8RZ4MDQPzxFx7bRYo5smORq5iYVdHV6y4e1DMPFAMwYE7ADZPwxD6IoXdq5OFKBIRk4ZfFifQQ40Uei9vFQdoodK+CRGgmwTbcPwVJRbMXpwtn6U4rDg4DJokFayh40J3+Br++xTzbxHtaK/h/34lDlrlVJxthCJkPkYfvbZwQf9quYF+WIwCHkiFOjyy61Yc/OslGRj5FUagxy68gY6rYiB6KCLb307uX1VmSXGneYSd0lVyftqj02hhFb8ZS71j7k+JafWKk/OGLwYghQKofbKpJq9/rWvn13wtwtmJ514Uqo4vbvid5emaEgxICeiE1h3dFVaJYaEfS8PWSoDZUTJI9NJA6m2cKlvfGsU8Yc+/NFK/scQFRc95phjZ99LqGheiIabJRZNLoGQIRLvDVNavNXv1Jgt46+MQbyG9pLqXGUP2r/IYDff0pAfgaBizfIZU61blOjdieF2yUdz1WEXDPZVVg33Iw0JHnzQXg/xboJtEYh0W0EkFD7wEibyrGQBOTDO+/juLEEHBlvUZ/zc87xEtWgsAzx7W5aDsUkR0e4QTOvcQxnIlZHzyJgcscG7sic1rHAWpnhKybqGkZs/8M/0BIbg3XTDzYHUN62SgljAispTwmKbUo5emI5cnb7X3bU+/ZnPFFyrSlXVEQ5vws5RGUsjcUpJXeOOTf69CsnwQMnToUhpTkq3KkORN7gA+R3jX/U0NcSd2a/v89XZM2Lo3hyIFrQNATNP5CivtetA6x185/wi9GTytts+u67t/HpZa/qHTBjhPN/pGfce3qZr+Zncmq/8c9/i8OR5ui5BF1QZMdVF0i9y3i67vnT2kQ9/pKrnGIwJYhEgDWG6jvzI7rPXzMMi4GQjeRHgw/11cYJsDHAUdRA7xNa1CASoA7p8yD2j6suwkMWXCCpQS0O6bUkisKi5WSWyplzO9lQ75kehOqydJ3ZDKVWLhjGs5qSDoKbno6nVOmBHCtu125LnKYNI2lqXVtPFF8KWzXO678in60PZVUZU/6C4WW5d1KGLG/A2x0FzGGzenhNxx25QbR5H3d6C66IUm+Ub5R4WHPhoiSUDtUbhsyKRiFiQ/cys+hWLOCB2OmfuU4pUw7JdNQUpsEw33nD9ik09lGcnkCl9bFtjr7SJYguLH7VXi0Ak9eHBwDIjD6wo9jFYhpdlvItF6ZA+116nT2Y/ywMRLDbv5SlswKB69rO3qTZvIEjrRdHcFqOAcJBTWjBVcoTvCjvw7e94W9bs2tmv43FQjDtFcK4WgWUtlwhhjNVu75x84qnxTH4Scsb1tT83iSKteEvG++R4jjY6i5vgGJCLayipSMmL1fM8wGjf/8F+sxNOOL4qpxSjNNe37+wl8+KZxUfNSymBTFMXI3h87S8e/kc+8uF6Rt1AnIGyYCEe1c6r43QO5Le+8a1SLi8IFNkswcurcpMcVfsNYajiZvkP0vCMzTaZ/TSpLb875GeBrdLJIvfm+ajhu3kIfeJR9s4OO2zfBKrMj3NXaUkZX8Uhp9rBjE2VYHjwasfiPoAJmZPWq8hgE6rRyqfZv17Gw+jqvd79Ts2zBgM77rjD7N3vfFfFs04745TyjECBkva7mlC8jZwb54sArfKRS6cJQJ7P7zQ7Vw3HWWgiXeYvZB1hhUUTptCTmIG+TwyQQw79faXVfOyjHy6I7zvf/UEU7K1VO5nSvTrFSvzMsMBtQCDz2UEAFGskx+5LlSJtFaFa0vFuvPG6jDsNAp64TBorpMhJ9nWNV/UqEL8KQpFHo35up8FlnFXU/rbsCRWsIFkLUk0W5gOUYsjLOEapwPlKVCEXMPyUu0gR6qLivZjnlMWouWudKAPXLsWUCkhCMaMjlvUbHJORgeE5fMb+qOYKIMlcW+gLWsOgtF952+VsBGK35xnHN1x/w2zrOEK6DTlvZJNylEMeH330MbO9v7pPEScVoGg4uzs82f8F4WecUprkuuIFDE95vqEHMasz0gq0ELW8yM5OIewUIp/fUYGGGH9CCfgSoOBdo7PEs82Rz/uMeaJUjcf96C/34I2Pl7GVgZVn97P3dplHeqGrFI0CQEOOjDllRDpbIwbvnvP1x5ZbbMbAnP3rv36iBLNgtAlTPIFr7s3yJ4fWH+kcJoBVOWJobuCAOxiEgXyqe5KY7MVDKssj/8HzTRrLbTAA52PUFA4SkkTryaKs2EJ+VujA+5p1llq8U9FlYx0x1vIu41Fg4o6uBrxrlhtL2Ua9/97+ufO8YPXdu66D4O3us0JcB+mJZ+IQ1vXyzARqH1DC5cGCIbbeZqtinmrm3BZX9xCtGECuTwCzskaVpV7UiUU4CawJ1C0yj8/YSK1kxXQ7TcWzIkfcFvja/cUVW8jdWxsOgQh5oQyGjHH5rAMG6pKYq/FMm9DUm4W30XBKP9OANMRwylKehECRvyLoKJCGnMEwqcq06Lxi61Jqld+mw4y1yn21/qJgxfuuuCwFqgOV6bxCmIIqkSzsHwddk+CPf+xjs5//8qAwcO8IKe31VbS+8spykO27axMmkIP217+cUxVvGGMYuvJbWc/SUxRasH4894bXuq8oyMqYtt9+uyJz6LQhbQvVn9VLWPD8jaeMrXhtlIffed5mSGN3BmIL1KnKDKjzg/FEGVHWStqF/d85ukoYduyM8MJYPyhKceutt64UFgUbJOGb+5WjlFjwXWP5gTovvJ7nPPfZVWD9vz//5dopG264QSkyZ4cHioi1RRj0T83vKaFNA/9XxZsUi1eNyAtBw5rDap+UykK8vYMP+tns52kDJ3/StTDYCdeql43RWh2BpjxKCiDz4Rmk2TA6l0p8Ezt/lcTSP/iB94epqTnBUrVPl828XRq+ggIYa66Z2OjkERtL9ZAMYQ4r3hxXOkHWYoXlV6p5x2NQZnDh4vHKDyLsIPr99reHzL6cmsnrRPh/6lP/XrG9fb7+zeJhgPqwxZs5/9jshYnRvySEmbn5PRJYwfSIaVX4oNP8lonSlGPMiJgb5R8LtvZ1pqLWY9EUJqm+oKnJaz6cp+Y/t5ENcu0gSp9a+39wAayrc+F9T04c0t/Ujh7hjRG/FBop5n6uNUI64o5krbXDSlWcwnWNlUxyXpSQJEuFyUblOOEyZ0o+KsOQoYQL4DUEP/lJvlc7yxiO9qO45lJh+YOwuyXeLUk1ObHm4mUvf0V5s4cc8ruSc0I2zvcNgbB/lhDFUUcekhjkpkmRDClUKksxxilRjSrSK3nddepskwP2HEOw+x2P+ZrKZuZ35Hs5M/kPulRyOPeSuqaojjOkM4xngKKsES8YCVHBFeeNjOA9e0FJoS/G6hmtA2VrHo3L+zsDIXXcM68cJIaF+fUecLa1omOMg+E7mieYt6FcXdfculaNfeutt5inhdG///snZy/bdZeirXs5COA0gkkdVHmQPE2WzBC6tpbDxaIj8OVCCZDPnTunKMWl8BKPa3gt3dej0R3gTqrNpBchpV8FrYIUeaGmND93ndmuKlOFwSdBRclfFaHhoTA1+7C2d+w9lJYNjSRkY4ohaDmEbXzvPffX2AbEOuJaxmjCVJFZfHGWn6ouYNgwRjUnR5rJ4SmvOlbqQ4+E9ZWkc4IUXAZCEktuFmWnokhvAY2a8JHEL67RdTmnAu6BqaTDCMI7+Kw/c0WwVm/BLHhDl0qKafCcGq9FbJoVk5RXxmJWB1PsswsOYJYF6pWqkvUQWxteh/uKNY5XFQyIYrTxVC9x0JG0ysIVXKq16BZWozg/46NiyvFgeZfKAVa1mzJ4NH2/d3ZJIDfegzQc7EubjddAmZpTsQ+QkAbw73//e8IMP6pitTvuuFOhC0+K0F0m45Q+pewYZvQyaX/F+5aoj8Tm2tZvTnoeWu9heVOElKhKRjx4NUgpTTDW97//w9QsPj1pBM1Mtj4Ni3WRcftJgXipL8Ucz3ryohgbqjcR1m9/+7+k483OtT8JU227qppQ/lVhD15W5vDaGFc/SuoYcbtuBDsmMUW6SowvaRuqU/VBfKR4AQpziGNBF8BjmMSXxArX5JvXCpo1J+DYNYM4ELTYvn5WSpEQ2TDEPgLCPSvumx+qZdjyy1SKmGenUMW96lxl368axUjYeOYOLbQRwbt1LrxK4WVfnXDiKbMvfuG/yjDRwQShoyqQ5Vnl/wnBMKDEKnv/dNwdZM3Dt5+K+PRYcmNDJKOoCwWIYS3VaKIJuGOdMwYtkhNP91P/+Zma5732+lgZSkceccTshMSVnRvELBAxT188721ve2spBPtaNa4mhzU8rXj9TdkLKywfJrDOM1HuvG3PflPOwC03XF2x4kWDdiy55FJVfIHhef/9zmbOb84smTLCMEMelvGUvTSUmOwFwnnE0sjUoTS7OfioC95lRssryvkj1K2tLADnmoId1YigD/fGqHJWLww5ba2EFQphyJqNWOBog1bxytxfXBPcTO7aG0JQYHChr4suurCcEg3PFfm4MPFSZ1WqIsV7/PHHVYbGGqs/pVCTq6+9eva9731/dmKKZmwUtu4deAO9Q8oxYkQ8OZWMVKzqsn5XFFlM3W5GSiFvjE1WS61Ft32z1taL7GY8cVyk6Lz4xS+qlDiVssDZCnQUATBn4bmp9EUfmTd6yndnwF4eRvWIc/Iqq/pWXhSvcyfv1HfGmGde4HkuUSFMe4ciJetAyOLedODob+o6w7NdJLT1eeJ/Wz9ri2zQvWpz8OJs8LsSYBerwNS6KUJkhQgZC1f5NGBe+H82myouevQRdtUcNTfW/qxd6ECmy6aG6u231OYTr6vgrE2ewQ83ecAGFt4h9G8/V4wRdDERB1zfv5FGTMyaifsRSj5DeQx2r3tb2GGR2dx9kHKIMiksdM9JmNto4C9xQJuKMOgE3ofz3P8spqHyfDY/oVF5UGJAYLwIw2p2nLko4ROrDBGlvbfQ2OMxeA6lr4rlZePkbzaP31d+npqaEVRVmSNCRwoLSViHLvPEOmU53xKFhZHJA5Pnag5ZUJong5l01NCEmWVHGWOUovSrlakMmpiIe8rTkvPWSeNycClG1Ty6cYExDoiqBFuek7dV9UHzvA4UyPAJsWbvTQxJTVXJ7Ig/l2dzoswjRCjtyLhywMXSm+ndx856OtTqaiKLtHcxNzlnm6X2aTfYldP5m9/8tmKHvFOCSOuzzTZ7RsGzFClL9JnpEOFFmCC8mceTooDFS7fccssSpLfddvPsS1/6at2H0PWCTMhb5o2BbbCICSxK4+5cowwi3nf+DTIn4N4Yj/nlsdZr/+bwQ2QcpvFcXUdVw4Kk8vziV2Ud8wg15H4kayQmvG2MALmrvHn3MA+nnnpawfFqA4vp8TaOOuqPhXSA5J0zHo5YnHn23MoFinOr0qNBQrXbi6J10K2neFd1G8kiou6D/O3ZW7Imv/7NIbPfH/77aoWFmOe5IUkEXVnYGdfSldPdPUd5Luefd0ExnT/2sY+WoHKmCDdzMbymYuJmrzgnvN1RvtPcOkcEJcVonzub9iuFvbja07lQdVTK5ytcEFSrWL/Zq56L4PuP//N/ynh785veVKUYNZLGumacrRYBLiQhfrtrUqfe/Ka3NnOWYRNFTUZAWxhIqi+BgCE2jBYHjQA/95y/zL737W+Vh73nnu8s7/uOhCVWX23NnL2kmEQgL135tCEZTZV0ZBowbgbPAjGG4U958ayGN4rsOJAe5//OIAPiqIWuTWxQaAxDUveTIfApFQYT48H5lXcKkr46e6OzB5YpWUrJei82L2XZbOCUvsx+HAXezQ2FikDn+S8PudS+xo5H3uEQ+MyWW25dRsP58QS33GLLyk31fGSKNCfdfBghg7DzSNaTbNacHjt493Qx8lxHHfWHhBROm87VaFYhsNDefIVCMs4upiMO+cTaq55NqchPfOLjs1/8MhXLwmXYPIREMmq5PC/5BzFlPI2uV10GtTuOmRP7uGPiaYoRBWsvUI72nbn13KOkIoXsb3TDQLN8fuEuMtWDN+e9yZbtIJn/CokgG9mErNH/+9lPVQlACa+sBx+QC8qa3jEdNMRKHVIXW3YZcFEUTqDEZQKr2dyScMU+0cLLs8HQqu8J0FI8mTiHlfDxaoi0J9SARiytWISU8FTuq94wvQq+zeQQtMpWeWgCZhCWBt4+CrOP/oWjrZnN3KShRaoCy3WBHHmLnnkEsG9PTVDe4PWJFUjlsAiEM0+Psu2qLk1A4AlTnASL8dvQSBQExf05EPaL6/KMCkbNZ6XrgEv43lU7dsrvKwUlTy8HW2f5kYNGWXo+3wk87wPhURp+X/HBxBJt9IKO8v2hQGP/LDJFWJqJEbknoWicqrWABL2M/+ZAxSBFB4Gl2Ip0FO7uwv28hpHXVuX8qm/r4hUruiw5Z/8PW/cBr2dVpQv8i1IFAalKKAkESOi9hipShShVQJqiKNhGHe8d7zg/Z65jm2F0HB1GKYIi9kqRGqQGCL3XhN4EQu+Q+/zXfndyZn7384cnOTnn+953v3uv8qxnPWtiCDzIN7L+c6IOxJHKsmWUNiuHoF+w1FnidPWLCcY+GIb4I49AC+4IXLtTjRwz7/Fnp/28DL2esRbccGzjCjJS/wPVPRsHQqWKNJnn7gD5OX3P5Na2336HcvwiVK0nIEKQ+YrjMxYOwzEGsrHw9O01Jypr8mwZI7KCgiyjyxiZww87bLRPiFA9A+l14zIIlcklsxlqKL/LvMaZqdNDKxA3ROffDRx5ZSb4UFdaOTWuI444rNWQoumrjj81kK4D/kzO0d3pc7UmJVeXfaPEMCn37p49s0032ayUwuji9vvoco+l0hJD6Wih/zPWBEdM60GMcq9PZY/PSu8k8W9D4JG31DZlUdAQQY9rKzLOuDerHW3S6msEhv9cfiaQ/XBerMGyBdk2MRH7x36vcwjFYSCT3jkrnIVn2QVX7DfIT5tTOWT16mzzMtk2q7e1ShiAEMZpWK/f/NY3A0Femv2yQ+q0H61M+LiIwgjkt9pyi2JvC1KOOPwjoyOPPLxm07JxAh/XpfdZMGyeanOkeBlvJct7ZDQjCj7XXTez4M4qnQiUA8OuNjFr955JBQO+XJl76vcLpx8VLI6VDxouSdFWF1W68mfBqmzY2eyBQTunxO2fm8f05pA4PL8jCLv4kksyE3axms+qfKE0gtFsj/sZZ9k9Os+tRNMIYa3O3YiT9oN9LlnQjsNZCOygdBVkZg9hG1ebVBy/5MfZhJqNH79yruHiTHv5bZXwHoyovGfYp0d1226Puf/G+A7snXXl4DbKZC7n7pcJcryUUOzFnnmPten+3Grp2knSZpPMD2qIE/Dtb3+zAuqLAzmTfN126jYVDJEqZHfJHTbiVEMUOVLPqNetfWW//Rt72Z2lc+a8C86sHUWkzuvp5ctOFuzwbRto0IhIvabaWusy2Dv1l7keBLm0Y4/5RMSz957H0HM4RDge2CfDyHNzIk8SgEhBt995e0VBDDknW43AeWMZDMfZ0vYGYzqYHJhsiyP1/Q4huXAOgJCAh8L42Nz+vS+IC+//2SQ+95JsNtHT5ptvUVlpT+M9mH6QGzO3RYut2bwpkICZ34zDklFx5RSSkJncr0W3yKYxyGJphJIkdF1gFtchK2xQbhufJSMQbcPxC8ZIBqFuJbiwOVZLzybnemtqFCIbDgA84dCDVGweBIIu+6U2YHOIbF2LDethg8obxTd07RjMlg05xJn0HmPJCbY5pogRLTOQZaCggy5qjfL71ry1/Kj7NBWeDq8XAjAwnZvk2fzD2qXPPEOHWP/uY48/Uhq9706GRGno+huvr3VzfTYueUVrJiumaKN9QvZJVg6zd+Y1VweuXasgWCSxb//Ld1ITuSVR9bIVeatJ+Z2FFjRMO1FgEWwikJAoGoGot5xw1n7f+4CFrDtCyfHH/yiZaPpcJ2bYeQyzZ0ZRqAn7Nyie4QPH+zcZgfUG6dqTkIsjjzyiehatnzX1O73e0rN318bx/umPf0xb2OU55BPq2kxF+mkmulC9oialxebe1I7XWWfKaFqk1paMcAT9We8zIyxb6MTtt91RmSpEw75UpwNhi5IFKRsFtrUvzNqUPToPMhDGXPYq2K3nKLPL9WKVuz6OcvnlkuEm8Cp2b/YkxGB66lCUnW4OI3zlOFzZLoPujIBc1dP+LjwKLUkyIvu6FKOGfVDQWM6Ss9YJhl2Ewpo2JaQ27UjWwx5UFpyAUM0Zyamd0dYe1QQcmiP1+6/lmTD4yE3KSD864fgY6d9XffjIIw9J7e/eDCs4swy9AM492YNqafvs88GC79TilHv6API5z7bJM+tmbJ7M/MSTTqhywNZbRpQEVJiTIshbZeXI6QWBoRurnePee2fn/UwJmlTXyEGzIUodfU84V+yh63d/9llbh+botPa050OtLIO/Yz+gIGysdQPpQpK22XpqdGJbv3x3GNaXg/TzbX81cmfXpOUwXFc/F35WgAnF6CUzZSG2hEPnqNlRz/PGSH2ef96Fsb+xx9lbhsp72cNKSon5qysBeVQC0HqSfVZrEeFkzKNGgkTmey68GckOJ/vWIC7i/cqWD1mpZ11s37yncoD7MQxl8ZyL4//z+8WL0S/+eM4DwZhlsi5sP3uoxMIOcYzFps3z99WeF7QLKrWusem9/OPvno1r7W1FbG33N9a/0BJJR56jdRgbLFvXXj7y/WK2c6RuYlZmBW66/bajjx310YKSQJEchVRa7+J+UW6x8S36uqlrGeAqKi0Gbz6Q46hFNbx6Hru39WVaHBuRdXpHIuum8drGm3UIVEGeAROdusFu2Cvtz6awAdxoGT39bPnd32RsjzrcXsHzN4riRnegvvr9PhvQ3/uG9+yqFmPjYzgOsl4dSq4NUsQaWUmGjMcJ+GxrZLN08oqNBX4zEYYDY/w4PV8JSpTqSHrnXkpNtnpYU19Ry9JaUYSHSJ/NeTp07UTzWHqiQLWlFlWq1S1dsLhB2iJ4hmbeYczmx7CThYJUsNheT4ar1xQMt9L4VcpYvCO9jQyX7Mr9CXb0Fb4DS3KAIz0/hJGq8Q2GrG+nlFffAAAgAElEQVSa9j21jzbAun9+RwXalJGwWvUA5t5LmzJEGE7b/ECQl0Dl0ZQFGlzXBPXDFI8yzLL52SfjMG8qyHHSGpNTuzt9dFJ6ZDFsJ1AqCjlHpGtDW08GAUohS508ee1kDJnyUxnOIgXZGueHhLRlaO8c/J8yaWh6oL/HhzYEWRqnrDTBaXr2CDVKANZTQGKNZNCMjJ+DWGwXSOmojx5Vz8O1uYZWtpjfvF31wHzvvEzGoFwEPvZcn4wDgupcesl5CTQysqu0pDHF36ieZ+918CEfGh1y0CFVmjj5x6ckE7h0NC3zGgU+s2fNTiZEbWfZItHJkjeMLrLxU33axxIprdizgpZXss9cV69zO5PNqTYqv3tmsOyBVRLIWF/PZIEgDHeldUy/9J8jfqBnDnxmfQggmBd5dIaUl8N8wdSMZGSBvXtLF8NUjjdnlRErAzNMXuLAZHzQgCJlQZQGQ0U1q3EImihL34Mt0JYBNeKeqQuMcZNHDAs1zknr0vE/PKGEWD7z6U/EXr2aXtPfhj/xQBzeqqXnyrgLXA0SQA4jnIDpLft5OOfl1lturfNxUYRAWiI8d7R42o4gH3PHLZjzKTh+fXRJ5CRj1gp6x6NYe8omCYQ2qfm8tKk9+3eElay0Y3072tb2bgg4kKHBrjg3xX7P/RYjO8+k6rNxFNZQF4CWMt9TK9VWQ+QC4aaLNQjoZUITJzZJPJ8n0+zZGENfJYY4UE6iOwq1e3YYK7nVS9u4sxkpLZiK9JfL/pLs/vsJFFatDPKhlGd22XXnwMER4EgJx5mApjXSVGxyd6SxN8hKgsf9D9iv1MqwxLsztyY+1zOsihXQcaiucsRsXJdlhOgJEnzG8YHZzzjzjJq7q/atx3yx3Dff5No9W7aF0yzSV5WpmtoQ2+B73YnaCx1Fsi49iO4taEWaHBwyZ15jP9Ob6ve8lzV03d6jly/KH2VNx4XxNrdDKaLOI478cDkmKXLNqItjNHh3iaTZBxx4QEE8GvAZSjUJ6v8mObiBZaPSgbGI+VkOcgzTE7UcXCpin29UmwQd59VSftBAFiCZWsltMQwo/blBhIKqgSUyp/6hbvaDYPUySX/fM8LIqwd66vJbDqVIsLN9u5JLq002cft+WLuDaOzYJjfWoeASbIix69lwE6YeyFB5mB6Sf7OYvjL2JTo9OP9uWMBOnJsH5HseJIMjegTZPpqsTk3LexvarSYpcBF1CRpez0xF9+q+wCTey8YjDk5MXI2agodNQebR7EYP3O8/l2iXI3w8lH+yiurcfb2LMWkKRfV2NqWnsQ61OdI2aaW/+r+XeEMYju7HZ/mvhCYGwXY9wWpRjc4een0+R73Qc5117z11nzQ6ReP/etx3K+rGmmWcsVOrvlUQemNWt+g7YgsJPlZLzZg60bXXXje65NJLalrN7lHkUpqwR6dP/0sc6RkVCKlvi/od4NY/i6nr8CYLz31BF4j9C2DI/6llUnjSk0i8/oD99q9sujMz+/2D4nppwgk766yzqq45fqUV63zoNV1zyloJNJ4fnXDiSbUf/Y692NGTJ5PBQwQ222KTZEJbxxH8JjNHrxvttsf7Kvq2J1bN+D8ZKoKMWrm+1wZlZS8GU1wKSx7ykHPUWdkyVPfIUDeEoUH11rBBpY2pLqtvUpDqSa3kQuWGQy81o5RtGMtPfeqTgQI3ruieWAHBBoFlNennvTnp6o/GcRgyduWCDnU6UzLSKoPUfmoN+AJUjqJkK4dJOe1cOp9NhYn2sgyOQ+IABfegSCWjq6+6cvQfP/hRfe+o9MPLlkyN+vM551XtjAJSQ2LenqkmHytnal20piF3XZkM3DMTxLznPeDPlFQCT76c99Mmw2m/HolAfemuE+N52eXeNdpxhz1S8ooW97vCxs9+4Vz6kILO0rVPFk/ioE7KgVuv3vpWQb8AYd7zEeBQfks9OIGRlq1ulzwndU2IRk8yTA1aIdeLAwCe7GL0fodt8ZydI5kmjgVH42fs/Qp0hkSGfVSblyBwHI9lj/3tF79UNgRq9GTaZey3BRZoDHQ22ns7R2xpH4xhxB1EZI/MydU7fkvQvEdjb+aLHniOrS2sJ0+cUn+xEfYDP6J0AEFhp38clABTX9vODhml2Ni/ra7Kz1wXFSZ/RzbyXNndTpCzVpygjLIL2/e9aS1cG0fc1ZD8nvVhM6yXoMR+t7fZYnuo11092yJyZe9XG0w2Whwp3HfRPLybw5rcYXTMsZ9M68fC9UA0P4vQ0d63TP1h5cADtySKU8OxiITqwSaazsflTZdcOvWspPOK0w5NETYKRkx9JPh7N0K+dhaVKN1NPZObXl69Mw/X5uM8qx6XbMEDZDj0QS6bTEVq78Cr21x19VXZ2NvXZAgLxZm4YTf5rtQ6etYpk3XQK+4coJbuIM35RGmvfkJBwJCh9YfeIpA2zaIpw3RN3Pm7oUPH5VQG59sbsTV3o57TwpRtiqaqblLkpTjjOCQP0rVbF8GBOsVSWTMqNUWUyLUzfDRi/Y66NAel7iWaxWSeQgc0Yu23p9fMtXs2VdrPn68N8/G6qFe9d+ed6uEzWHr5GNAa5l1TG1q2ZVM3en9zpCLt+Qeg1WBs3MoWhrpWr39U9p86UhfsLlWigeF2fw79HXGY5SyzUc8977ya9uGQgUiWSl9g9RQmyu/PpqlBNcc3IYMSZDqgR9dwbRSDfO7OEbRebfVJGYB+3+jU9L5dmLpKE17AhAypqohdKTGo7eY+vcpw597Vr9WjsazV7NSoGaCddtqpxCEWH1Pf6ZBuO0icT4OAGA7KRdZpSpynEghtUjJ27v1Tn/p8DKTe1NZL3FcXZK3V46WQiPT0qqfJbOx9WfNHjzoyYhUbVI13diDFIEglm2afVI08hveJBE2yGC/nRnbcJ1SUkP1gePqhdx450iYX1+qW1t/ZcNaWWHLx0RVRovnJaaelTn3O6FPHHp167hE1PkzGxAHY/10IoDtSgZFnZk969WDBtTZ5zNZPXUMl0ifd5fTwEBrq4/m0so/zKGPxayQpQbt+HuLVBFjs12ggB+JHevrGN48bPRTj+8mPHVGlHlKTfwzEDp6XyRCChx6ZUAMWZ+9kZ9fMnFlKPkoInB6HZ/OzMcsuu1SVd54OsQ1HZOGFF8ssznOCHC0z2nWXA3KtAoXU2hEJw+JnF+wvQXrd/4BcSA6skb935aWCXvN8S5ks90thqQeLCJnIlIw9o86W9YzIzzj71Q+Z37VPrYdgvLdjNKnAp2qv+T3s7a7Mtf56G5QzEziyXG0wwqIpWd2ddXy0ykIkNL0MwHg+z3udlKFwQ04PYgSSxzaHWFZQlmvrg0dcU00Ly7qeeeZZtUe8t3PSAqPGyh6bjXZHWplyXq5Z+cNzsx9322XXEGG3CA+G1OGrlZmDoMHd7GFpVGcdZI6FWA5+xXpPUDrKWin5tMEXkZ81wCTX3DgXUXUbpBKts/oz+Jzz9V7Yyl7g9j6D1L00p99GDVrzqkundhdH2sTNGezFc4i/8MXPjybEYVa2GONSsE2cqf61rbfZqqLtm6L1OP3Ci4pFeuABB2SzblZsueqhA8Pqwyv6easFyEZEt17NGb2txBK0NNhgam+NULBE1dGQOyxGL/wulwWrKCSb0iY/9dRT4izuLGUN2c3ee6fWlE2DRNDTfYezaY42thzNVLXU2tRDhN4Fn3u9VgaKZ9Op6j3jKCchUob1g6qGyKoMYilzDBqfed+xv9Odi03UnabPr77brGkzDsZAtT7bFk02EQIsR0375NZqVFOeh/pPCS8k2rs/Gc/4HCD1HIbXppGtaRERwWF06hXszNIrZ8zIBj87BJ9pVdfGWi0pPNCUg0MUPkaAAH4l5rkef645lENG2mpYMpxWX+uj3voz7RlIdzjWojPkSL9Z7wmBf2bfP2v0ne98LwbuviAJq7aac5y5Fwfhfq0Jh4poA3rl6LTLIBiIQK2Hz9GywqHNmHF5apGnlXwcKT7ZTnX/lYFLkEBw356qNozWKuVz1UfVavs9EeHfPmWODx/84dHS2WslYp33GLsGDKD+PUbkiRhw6kHPZM7kDiHAFBswwSRof8211BvHj/7lX44r6bs2KLjVAGscXtbT+vcIt77GWYh++5QM0O9WyVZnh9R11lln16QeMyOrdy7r+0hY9/pbizE/BJH9sFcWOARHZdzjyJwp9+Jc1HNPZtf4DGbSGk4fmD7BnsBseiTY1lhj9XqGygb2JUMoW29a1o3FyIGXIEQ+CxzZoa/OVaiAWk9yiQO0vmS1e46x1+NdRxu31lCOmjSUQEPbzusR/JCxyRy92Bd7/LXI/QmWtQ997ev/UmWEjx91aNjF26TVaHbg3z/Udak3EppB9BofBq4eye0j/6nGSxikgsTsd3yIFVK28Zxm5f7nRqxE4Ds5knkvBTa/4059mAskQJ2SSTEhf0UYQlsV27PAwEpHIGTPunA9UhH+BAdbZz22wH2wUxjXjTU/Xwawiaa8WUpw1tbvkH109q0fZ+DnIV8ETqz1WukvbQhO0za2BzFf9ZUi3dGxhjDqQ60zlutVh/U9XAF7X1A1YfUJBfXibVx66aVljz98yCG1P/7+779a4wkFL1TTDN2YV3bLvfn8qSEDaX/hdAWMECZ2vZXmqhWhedKxXz3PnAVrWJKRWSs26vZMVbrz9rvCnv5IErbIQgZxs4/YdLVtz6j5qJQq8r1qNcp/fR9yjL7HSfa6Z68ve97u10uQ4fvQu8ZSb3D4GmklI1iBrNTZuQ25a0lFP08F+WaG3VyL6Eb98P0P3pkZkAeMpoVajnKOKq4W6N4fiIIIY3Hwhw4qOO68c88fvZ5ZhA8F9lhrzbVHhx5+aP0smOUdmSNHyqodpLZRQLZjnYyxNium/oMyr4YgI3Kh+psYAqxBjk/PVDmF6JJWFhUI4qSTTqwonQEVRWy/3ba1WTlL8NlY49E/s5rLE5n0qNDnMaoWxkN2jz3T7I6yOdYG5XIs1q/DZJw6eKE1tMdhJMsqSJnYd97XtZbebu7ffYEHPdDrQojx8ueW1dHnDcw1sJkZKw/f5gXr+bxXo/hSbF2N9rl/PYoCl4mBYN6R+9LrqzXCISxDN8BrYCJRsjo2rdnf/vb3o223m1oEi+eep/ikDSF9fPl3kAw41iikoQO9soKaolNrNJ8R2J2Ka3IIOlzff6aTmQRVZsqClKkR+T5C0I9OOCnP+ekwbqeUg/QZk5JR+n21Fg6wvQfDr11qXNVMNwuUBd7sjsf9Yh7ekr5IcK5MHPxfxipZZtULZfqlPCTTbcop1fwfZy0CtrcQoux16lE7xhkKDvEA+iQIjrTXVLqEopAewUOf242ZGLRL6oiT15pcNTe1JHVjQc2kQNA3hmfw/R/8YF7PMeJFiVXWeVRrbiQbhsCUpA57qfXKAj6YkVJkOxEvbrrpxsgjrleCFMor7nFmMisGBJza5tYODlQgweHn+fW6bquzgcaalJ7fL3gqH+pZYJeD+9+Z8+rnsHhvSNb2QiAyztszYaD6S+bdzpsgOfWqGG/v1WtT/s356plyOz+9VIDR28QNnM/q2c55sNZtUHeTO3w1e5sjZZRL71lrTNAymRznh4REOet3v//D6IoZMyNpt2NkAz+eMzJn9KX//feVva6ZgIBx1z7k+rVU2U+TJ69Rz9kzVHtcviRMg5LFuG4ectXEVVeLDdDP/c44kvtzj9qwghYtvdxoTjIk2r0L57q9ioU/pgxiD9aABhKXeXXmcK+RmmLlfu1Rn82ggyHBkWqeYNnePYHQxx6WmMQgsMCZqCdWDXqoO7cg5O0Fj3oOBtZfe931g+TjEsV5mRJyGwThnNTDwcM+l6PefMvNy66b6qO95V35TJwZggymYrmmm8OnuTF7cHzY7+QYIT4Cm7Wy9yU2slVdEN2h9X3S7HBzQB3d8hVZc0oIbl5s2vve974S+xDUKRPJqJWABBbuRyDh/mTjbJqh5LLPQiOHElMPKAUU7q2vTdWrh3JcJxN5T+iYPaA84Wc5dWUkvsj3rXOrfzfRGZ/fA1H+qDlSRe9hI4viMaaO/eQxia63S3b4dJvUkk3tA2+IcomDLWKfOfOaou1LxW/MXFKbco/0b42L3FRFTQ5nmp9ffUnvTnNaLp4h0iZhnNVqgereE7KJDaK4LerVBO9wG4PFCSm8o37LmucEGl06G/2U1HDOvyB1kDjGzTMc2SQT/ZQWYezLpra4nJu6DMM/tn+1LTxR9MAUqQlR3vFACvKKIWmtOI2e3RQ8GpTbjZJ6yJNPPV6z7oj/O6TVBpH3tUlcv/qo7GKtKHWAgS4MA037A4cokncNMrVWPwqkrh0pPw920DdJF/il9EwyeksnmPDeiF6ugYILchMSkQerBrts/muf3TD8Jru1SESgbyyjj8k4JbBFb5j3sxh5xBnAaG8bjEHda9Vw+mSZdgjGwpsFhYNPB5a2zysCSn5XE/XMCLB7bRp4jWaneZtnn3XuaLVJqxbxpkN6jLN7xaY1T1QmosdwcQ7Jnsn7bhmlkonZLwK15iAXy+G+vg4TNMUzcG2yOaQUl9+IWq2VijIRxmipCamDZ0/21gSCBrJ6DtQMxWp8z75vRr/V65QcCHIUuS5O/pyoLamLgp0nTpxQvXql3hTHYy/PjRoC2NEht5f++Z+/Ue/rd+eXGGo3DVFumZghoGvtI5UJ5l7wF7baZvNIeX620ATqTDLXgz90cGVMsgu/qKSiNYhjtpesUaftl3Mth+pHm1Gw15vUZof0ZcqDwlhQAGe2EfVeG9197111ronR9yzSWna1Igbd3kfqsnaexfLZi+xDE2LoaA7H2ZGNRuyTdXaHX4Fb7TMymg0mfiPOCmJBEcg1vxDCk/comDMBRClD5fMFL7Rdf/3bP9Zkmh2333502x23V32ZY7Em4EDo2IJxjjullPV6HPRFqf9B3MDmm6Z1w3l1X+uss3YFyAWZBznA2TCpxjADwUAJpJeAR3vmRTgcbER3msXVGOrp7EWNDnNfUK2BRCX4AT+zO5wIUmextpPcQK4aCtRINb3u6Ey3FpcI71cf/dB3i7yVz+OMBWJbRaqPvdUGA+GyZkTeve/06RfElm+X5CQ2PASh92bQCBvISRWyl3Pms2kIVFaXv/8hWf5X/v7/pI1s5XLOfYykMoZAa+Y115d4yWAo55njlvW3VznV/MUzWzGELedHb7hy1jZBPe1B9tG6rrfuutUBUF0j+a+mkeVM3ZD6qIzcEAg2B5Kkh7XVT1sm38TmtQy2LhD34s+91tyDY3/vCkbei+NUcngyOsTOSevhnS8g1Etb85CkaIXOdbgYcQ9KJMaIk/OS0k+ZPKl60DDMXICG1UcffbzqdIwZerTRRt74+hg1kcM+++zbRBrywMpBxIFV28vg5DxkBXIFdc6HwajRSvkZD57wuZc+og4VLhkDy2g3SbGFR9/+1rcy/PeKylqn7b1X0fpFwv8TgmTQm+FvEfDrer3yPuoL9UAxPfIzHbJs80IjYp3h5b3O2X6XE/FzrbXGn7sAtCheIf7+TMNYK/UxkyE8ePcrWhHJOHQrRRgbxGJDw99BBg5mr+d6qDa3B29gQKObBwbOQXyDIkicSxXS83P3RcrRwVk12Rkni4zhCh0umftzz71YB5Z03hu5XhvFxjNUeuddMpUnv1eZdP5thQgWYNg2+GWYRjNs+Lr35j/nvebDtpahGXzf4/B8jk18e+rBWnvAJa6Zs/tZpPI4lslTJlfm58VRaHOpHrVkCx3+r6HZBcfdV73K++zzgRIWv/XWm+v9MQztHwZHnZdDFTGDczTlW0uHnKMEQXsGCEQlYj4IZtjTDN/DgUYdlg9M+2AxDh1g/YF9T/QM1DL4fS/P+/eZx7h09h99YKQURBeH/On0aCpbvGL8WzndBcvJcn7ET5Q5GkmjMxj/exYzr4RQzMhAbpq+s2dn3Xdn6lUbjf72Sym9pP6rDqU3FIse67uRvlrvYKu3LdxIW0M2Ona/c1IVVA4N6vVvA9ym7NH7r5sBD1EsdWSEEoO8BbZenpFsfpnsN+xspYYaQRgbwql6caTV5pKgWLCsJaymSVXZpql7NV5CO6f987JA9W+d/EYGs40dZBDJDDZyk73gnIF2H0qriuvhlO+dNTs9zFeOHk/gfeThB1d/6c9//svaT0X4y/t7ZrIZA7MfiyC6+98hCQJ71gxkU3frLT3IRgw85AucDNoUfCk9yJCrbjamZ7T2oOHhg16v5wN562vNqajRQ5JkYjgcZCyth/YiexABr5Cp2ANDrWWPfpaI/YuRO9VvXpNvhsCF8yWEMiGsZSUythtM6rOvCRK0XEo99gS73No65uZ+l0nw/nKVDbZP8qTFiZPjxGWtrtnWcFbYbs/67/7u78JNoTFgNNuLRSxaI1KNnz72mNF//eiEEL5uLyUz2WpD92qDNeSFCMPA27CnoCprpvav59jIzZVWHl92wfNV+103jrQJTfy10Aj3KhjC1Hd9UAP3536sk5efaYTCRUZrx8fcGVSM75rPFm+8HNfWCUmcZ28d8vkIV08F9uUTOjvds2EjxxIsaypUIpSqkVogkTYqsgdHFJpj+7d/+UY5OQ/FhTL6oicPmZEGqxiciigi2kYn1+encX25LBDI0YtTQO7obSlu4IILLijju3YMATivZV85sMXQ1fCs5yztNYxzPpNEH7j5gcCEP/3pT6v1haP68IcPLthQ7dAOmCc/NdRBfX5nizW/2Z1rY151KMkCeXiMcYdU/JtsiHEbi41XxjdoBrtG9a+zMwTd2okobXAHHGTQ6mALVAR3RRq+Ga9qjYhB8jM+w+H08Er4YDBenRY/nLx6H2tRsEaMtTYTa+69S8s319SvEWsXPZ64emkVJ+PmSA3O3oqgfDLZiuCz/qI77+n3OzTbs4cmfTc/C3cNlZ07FLIa7SRps/Fc3ccdOUBIVTY0WJo04xkRHDjt9F/lAGupIHRtnFb62AaBeRJ2ngODgmjkpcbIQE2csFrJ0THGBDisp0hZXeOK1Hw50Vmz763ArNPy7dEqDWRPYjp3aL/asMDuWpmMtIvRw5q1t/bbd58Ic+/5/3Wi9o5XsXSzFGpHv0qjuftdL/BqBRb5d+o5jA2j7tlghnJAzz37YozB2jXm63vfA+8u2fbU8L6lUzqm7oIFao8oU4AfIQ4CvyVDAronClHUmI5Jz/eWUUeSgc4I49Iz2Wwzw8Lbc/DynoLRzgnon/c/2zA8wx5MutPKDPN+xS7Onzl+TlDsqczxYFiUdKsLtclzacL5IcWl7NN7CSuITvbofCIXLRLdatkx29FJe03ruhGXmuh5y5brOuu/xj+o0YUDwYmsnv3omfWpHm8O/YOc91133RGCTNCcwJF33XVvAi21xaVDRttptEaGOPzyl78MmjO7jHxNIcoH7rX3nnFQbe2qx7QQjKxj9qkWmpLnzPXYPzLehXLfJXpCVzYOqMkPprY8CNiXIU+JywtjXLbceSDVDpjzKojR84isY6/WTOhcv/qyMojPA/EKPD3HLh7Qe0FvuD4jAVMznxI4lUyodfQ8nFu/wwl6BiQp1U+32Xqb6s32vpxpV+ZR6rAOMlbiKZA5tm+diJyY4MVGsc1PPTmnrs+5lvx8K4nMKf/xX6NNd5wauPfJSgD22H2PUpv6+je/lXXPuMKwfavtpT3UWg+vsWRQzm3K5CmVNS+ZvW4vyZaVeZ7IYG9BPsEfQcTTKb9wugsGGcAcF0jrU0V49fk90+71eWeIY7QmApKCYHMt7I4158964tV5L/5ubfybYJ1fwxXwnjSneynOe3cpRvc0Lgszl/GiNNPT+IoMk2lYwE+E1KDpvYTYRYLZMAX1BGoBp3kwpRYRCTX9PZsEFjn/gulVizw68LBDywlzkB0+6hJ0DO5pP/tZosD0/oVM8cAD95VMmx6+Yvfl8NqQNh24U7EZG01k9fLL6U9MZqzXzTxKBxrkpd+y+pGyeP8tEuckREaZj9nqUe6xOYg2M9TIslaUVoNzrb0O1B1URSJqitUq0eqfIk5sUlDWWWERCyS23W7rchh+htH30qu5RB7q9OlZmzzQyWuuNTgjmW3qqcMm40z6RIMVMkC3BuF6uKj/+a9Boa3touoLWR/ErDYrNaPNEq32ZmMErYKNMSyzQdUmfxlm6dTUSAlCOBiuBRTcoYruSL1XwbyVTQ/wdmXk87P3uuSqi6VlJ5HvXWH+cTZk4whoUxg6P2PPEGGmZFNyLA4A5y6i7NBzN/Cicw7SvzEYenWppIhGZbeyOtd84YXTK8iT9T0eOA4bE2THuJaOcYyBqJvhrlF6eZZKE+2QtFFOrsE603ImQsKJ9mCiP29OZN615Xdc71+i9nJ+7svL+k5ORuOw0nidE2hK8IeA9WTqv2p2anMvpJd4s003K7WXT2Z2aR8i35xEg1lrKSEC2YuyLPUpGbnovY3qeq0gPA71iRife+6ZHc3fw/J+R0er+LPpVb1m9O/f/ZcilggGPcciSFQ2PvS9DvfTMr+GQFUAE8h0oewTms/OWhtt1cgj83o/KxPP9wbkCktchtCCrwyjiJERtTtDTfWGg2zSe85UZWslwrBUnR+1wxejjNbPWCe89Wi/WiWyb3sG8LbA5G3vtWDPPmB3OIIXgsjIUEnuPZqg/uVoYLNRDz9iDNcbEY7JCL3XXx7tnba+dZLdzJx5dYKBhwq5KU5HbImRXx/4wLRAg1roctaSRcqWBF7jGO7Uz0viMMG6UhjLoRXGMPCedQr8St2sSFRNpECywdh7FZ+gapnt/HLU0De2zs9zoJ6Z8yuz5Dxp19qvnNv9yaYFBYJga6z1w2d4T07UWrINXeGLk6pyR57jQWldBP9yRsXmzXu3rLuVs3rt8M677i7lJze4b5BFSZG/P5sWLg7a72wbktZNGarwxS/8r7ovwSNE4cmK4icAACAASURBVONRmVLq04es7lmdARVwD8Zt+CIQkpHa24QbsHIx5JdOa5yzTxqQvfes2SYj7Zxx1y6I9O/sBP9hvcHdHRVjbzv3pNcz1WvtZXbd96yVpKWvWz/j1r3/OzKTv7M/Xs5UK4k03+HzSjBnUDkaN2XtKXmfll102rpffGtuetJAbck2PvqRI2squocsZa45kdl8jz0W/JhCRPXmZaJC0nsXjP5/7XXXZqzR1hnyvEUZi3JWccbzFXOaEQZ3fePr3x5997vH1UzULudkQZdfboUQii5MFndFbQJwB/F8G09mQibKEPKDDj6gPgMk04gNzS11I1UReTa/aLpv8q52VJnlYDi6YxEJjsXUO9xps3elkuZIW3S56GKt4d3A6T+E7OD+tSl49Qbpdy21TK3xRX+Znsx0fEG7rxjtVKIXre/Wk/Lw3B/jjEij/lLTcwb41EPs99edn43m10W/yC3uV00OVOR9wZHgoAuDAKgp6KXrPatYu4sOw9KLUYhcFQi59kCRQJyCdhK6RKAsyyby+aCPW267uWXcyQJEoAQIfvmrXwV+mjVab4N1y1mDP7wIla8R0XnaxlqBOAzQpb5lwg8icjVzrVbYyAZiWx/wFWfhvR0q5QJOqmQaazhAE/u20WVxWL6V7Qz1KIFiqd4EivUz6lFg5/2iCbpDyEWJBWof9EChH31BTI+gL7744tLwLd3lGFvw+EqJnmVGYL+HAy2aj6mVpRr/4wA9l3XX3aAMNVm244//4ejE9JRusMH6DYIG8Q6Wxno2QezXRruEcIExKXBtUypeKGTozbeiJZtgEsx5zTU31LQT+rcPhIhhfuOxgdbWDRGJiLxnvzRizRAoetaVCeXa3xmo1aum/VT5RW15mDg0nB9OtLewtCSxkYIMWrcjSGl2lmhrK0j9MM+y9XsyWE2ggEi83+ccm6TaYoU+NLlRvZWYlpAutaimMGNdyikFUfBMFs1ael8s33JCuWZOSHDGaD8Xg/wCregY36eeChxZ9d8ICjz4SP7cGNmXXTEzxv/To23C6PUsaxJKUITlk6FBSQQJ+0e9auNIA2LEgk+XColpqewZYxWXjJGuFo7cu/jyqZDKeq3X/Qn8BQi9RursugeBj3qb9W2zfFvWLZCfa8/FdlCLYrwbmWuhIs31EWvshTF1nJTgr5SCCj17qWqCglZ7n83oARAbwJbOTMsbJaBp0z5Q8LXAUt2vadouU0Q9gjIQNMHFHUlWnAuOigjPxPThPhM4/t6w69kTUOrEIFgE9X/0XyeMjvvu9ypo3X+/D9YZrRJX3ge5T/LVnVTzMS0I7/bU9bnuz37mM3XfEBclC3bSXlpOsBt0Z1Yy73422PhlQwIitnLX3XfVeD1BRodp+/139m2NvywYf7GyWd129gHdvcbp9/yMdeslL86zI2Ct5aix0jta56s191njUq8aAGziIW1EkBrRYouZ75ZaZTbOF7/wN+VIO9WdARBNygjnZKL8MkstW46UGopeJBq2tGBXymJjfaEREyKuMWIa48Gr2YgOMEP8H5nXeOpPTgvB6eNFz4aLiyw024NiZDQR168IEuni9ttuL/jmwP0/GGe9eRlf9VGRXt/EVQMdov0uzmAD94zan/tDrah3OJwWrhvOsQ++FjzG2s+KwCyiv4NsSIPRjQXBIUDJ0EiXMRAejt9dasml62GrI60SoX0GqhfpweQebCtwL1kRu/f2e9VXWHqwzcj2iMhDbTAv8fn0RZXhbmxMWb33975gpQczseHMkGJsAk4UHIzprG5VsPPQ71azYLMOarLz1qa0TlHq07pARm+AcD03zpnesoMERfhLJMFOz2SRW2+5I5H/5FIhISzPCWh21x/HmbgXxAGfoS8ZQxT7khav57xKIGHZl0hSUKM2qifwuH/7To0OMz6JAVMXfDxiIBX9D8++xvoNEW8/vDVgoeDzd5RuKCOlLejII46siLMm4xR0Pww3Z+CqzSmHK4ePAYckXJJJI5rUUfo5fcHTyT8+uRSVDgqTfaONNyyilP3v+qEJkAn3571IF4L//yuEKwISsigGeF6gwpnlGRn4vUJk/NYKFKkN5S9pQcHWZagEM08nAJHZe84+m4rPoYceWgHLrFmz63kxMhrptwvbUoYiG7Qn7En3JnOuUX+yeMFWkUpaf3SHmnvmWufAjFGISNaIA7OXCEBYY4bXGj2UNpLm7PpABgS/FifYp5yGv+jVVVerdq7UGl3HnRF9YVQ970IG2Io4Ie11PoMjhZBVoDRAbNrCnHFZ6VNxEM8EmSFO8kqy0AcferRUqNQxnwoy4Nlq62CnDjv0sMqG/nzO2VU/57yphCGjWVddCesn0JEBuu5lg3TJQsHk7Fd/Yo9lDyON9Z7UVuoIeVCP5pC5OCecnxYtzN0meTgM+c57CYo6e1SQ23SSlyiEyz71DKYEPbKu3tPa0st9OKMFleJk2G3ARqtF9jpzd1YyUq2LgkX1Y3tTicfPrRFbe999s9o0JG2ECS7ZSixdZ+sD06aF4LZ1aq6PFFTL3ggMlK44UuMcv/b1r0d16MLRR448tAhYl6f/GOmHgf//9dr3ve7BGW5h36637nplj1bNuYZkQtko4NG91vZzR/a4PcE+yir5pRNPOqkcu5mjnWDaS3Q9CBYMsKudu9GFFxoqMD9I9HzKFuW+CuXL2nfyZO8/7dltQ5EaWtPZw2ru4yatMWkuQ0PlgxMDj+rFmjsXTvxcOYc9dt+pxur4MDfsDbwxmr8hsFh52LaVRaZl4KIcfEZWVoE88mbgVA3PHpxWl5fiBJsGbmuNuTpQy1f/6Z9L6k6EtVmidxv/qiuvHhpzaf4+ViN0ng2JZq3Q2KdN27PmEDLa68ZprZ4F7s6x4EYF7V5qqUi6RYEd8q0MdcjuXIfgQMSuXaQys3xvPsmoOV3f57SK/FFRu40b2Cx0eJ/1UupVplEQ/95qy63mzVH12QyXgyIjUPfr2aT3LYMv8xn6G2tihygqh97PgR9fDLxC81ikpi5CcLvdb7vXagLPn9tMzFEFOaBwQ4+JHngeerw0oyNYyPYb3h+IIpvWL3OkPneBjGorZ2S90hjPaS9OBD3/Q67AyFOAn5DIlKG/9pprRxdm2O8fz/hTTaChOMQQgJlfzL1MDKNaXcXLennmoO6VogAEBWDwVg7BgKNQv1DPQLPvv3Nd5pDOSD0US7XqajEqXnOSfTO2VUsOpM8IdfEN0ByI1c+7x4KEEojZU973b//2i+XErW9p+Q5QZ3GrKnqmupPgKByAy1ITNXZMi8Xqa0yse7z//ociZ/jjoBA31h63zptvvvHokA8fUvJyBTuCSxOkXHLpjJJD1INNfGLGjCsqMAXVt2eYbDnXKuhYNxD4hhuvV/3BYK1775kV4szdyWoY5GcqG2LQZTsOuQhe649sYt9k11PzGXR9/5S6tOvYburWYTVuV60JLyVYAY8xFIxvSfgNSAiSWjm7IXPoxqjIeAKMZJX1P5l7zgAj+dfUl8GGsgnBpX1iQlHVEvN+aqa99lSOpaDhNgCBIwVhc6p+75EwvP3d0AbXZKADCNwzV1OVNan3CdZXXmn8vJm5UDQBprWRJdt3zyZwc20v1ijC9GSO3pyngGPdFl5w0Vq3TTfdqDoP/poMzX2vPmlC1dVBxHSVF0pdl1Mj+G484Bs5u8hi1eOdZyCjImZi1BohEfeK3Tu27NPFGATEslUM+m6LTI+5P72tzr5EoPrwB+SJ0eco1X3tI5mV5ybJYH+vSzuL4SCkIgX/HG0nHHESXfnp3nvvKcfm3EtmtPjYZ8hIa2aYgkAHbE0n+bawnV/KWj8X8RgDO5Q/DjroQyX4goHfeAxNyW38ihnflna0yy+/bPSlL325+rH32nuPcEVuHj2eoKYgZ7rC9s7AMSmVMvYmwemDDz5UwaSynPMkGRKo2ye959NkGk6Oqp7nqrarXv+b3/yuyibEUtgPATd4t69B8VpyY2yUvdm1BFy/LNPazkdaWu8+Z8shdni39/X66r2LKFZ6va3cM7b0V9O7sqBzpfiEGLAOZaNN8PnFMojLLo2pNhqtmdqBm6QwUVBMNr0akTqJetCEtKd43ZPivuLwDdfflA39TOZGatBdsej5mLV6ghATaqpEDlaxzPLQQFHEuEFjRvWA7jRcu3Ei0S8mel8/1PSpGUG1Znqg6IuKxt3YeuutX4aht1O4jg4hswNNwzF9mLluL4FDz15b5tHIDAg7HqKHXVF4/lcDjyuzbVkKxZUF42g6k7UNZm6Q7K0Rqbg8mpXE7cFtAowe5ZNINGIMhEiNyavXI0GpDdpqjL5i8WYjgJJsCJRvUSToy3Mx2mnnQH8vxQE9/EjGv8UJIFp5jrIlUMj06RfnUDRR/YeyaRkw17hO+kf3P3D/iuZeSFCywEJNHKKCiep56xlpY9YVLJ5ngVCGrODZg6UZF3T5q666OprHvym1k3XjoBguvXE2PmKAyTxEIirgyP9s4hWjKdwkt5qB8Jn2mq/6IX2GTJFeJ2aetRdEFKyeA4qwInMAFTY1KOSNJgEInpOdckyCtWWJbRfx4pXKMDbICLZjjzlmND7RJxi6aoV5KA2CIt7Q2gze9vam3nLO2X+uvj39oYy1ZyKD+a/jTxxddv6Fo/W32jRr12DPWbMikJHeur3DIt8mQQtCi7YLgcDVEc1nANX3CTSoH1Y71VCvVI+zj2TJ71kxIulVr3x19GActp49aINnh1hFc3fFGLJ6ZlkHAeDFl1yWP79crU0MzC3Zi8f92/cKAVC7mpbsQiYL3hOkQEq0izVH7rkkAygoutXe60wUtG+rx7Flj4LHvTDI6VC/kvqgdgpnwVovvsQ7CoojC4nN7H3rufhfwbUEztt7tmC1GTzPpmUBw+QYUX8CQ3sUTI4DIEupulTWXtaHyMTIvZBgXx8rKJH05f0hQt0YUhpHvthiaXuosx84PPf+dAyrDMU0H2u/4YbrFZnlyYzYuz/6vBMzBxZiofZZWsuxhfvvt28Fntb51gQsN910SwKxyQkCww5N1CXw1tLS23TUS+3rTjCyBlANDrZpJdNrZS8y+EBwkfcQVAhwrIm9VzKjMdoVGJZTbCU1jGPBq5/xZzbMZ8l67aNirOdzvLrWrpq19eMMcAYuynxRwZCh2bLQZeJclSVA/L+OTjHyHR3wGvuYe35vSFrbJ5tFbnTtfu72EJPWTxZJwMUzxL344x/+VE4f0a5aqhKcv57e9zbdiqa1fvqGsnGO2MTmylKhMq4PH4BtA48LAqANV149o4Iq7Y1a5/y+rPTvvvzlQmMOP/yw4k5YG87Mvm21zGZnfA7Yl5NsbWmt51/gYX2K65P18nv+bi/ar179d/xd8tgETlom6/29j1eXGx232uqrzlUvA5eIqDW/20hz8tCxaVdbfWJFg+KoOVkkxliDL8o008ORuhiG0Ztb1LdHGcXPYdDJLDffbKvRxoG9Hg0M52JNTi9x4Bgymwv84OAawwUGxETEYvvTGWdUxA/iOuzQg2sclc3HoFXmlE3kq0XknLsRYBN9Tod5Oy7e4JYWdTfD2WrDFsjP+yrbBJ9hTv5PWatRVE4YW+zhmjuaDe0/Ds3GUb95PhmMw4+JuqgayRCF6j2bFcalnxdQlMOM8+y6xCU6PrRt+LeaIoMQkM8C294b56huY6Nb7x0zx1O9g7rTCu9erhicYLG7ApGdccafq3kZlR2b+ZprriupM47WJIy1wpLzfArrJ0uXwy/TdP/adhxc4T0YveZ+Bm0AQWHs0eV8ID2XUAd6rKLbjTMPlKTXnOybmkEZB7f7brvV+mPTIlw4rO4docB1Vv9dDIyI0efZ6IIqKIi9dEui4z/+8Q+VuVHykQlUvyGBixjH6g3O5vbSddiYtfOlHWUyDuTKgdHVVG9LOWC7wEDHHnNshlxrpQKvQR268Hxjzo6b2wTfH3307vSJnlPXv00YhQu+3ai92aNFF2/9Zqf/4pepI83JerynkBn3oOeVwb777tmj3XbfZXTggQcWpAdJ+c//PD7w2M25nkmVgbb913Sd8QwY/rXXXqtaCBhLjpXhYJQYC2sgY78nZBA1MTCU9ZXZI48ITrQUffPbx8UhrDr60IcOrAzki1/4u8r8OYRdd92tjFVv8aq60SDNVlKHcdZ9FFg/O3WdOcPVh1sZYuQT44gNa5+45uSa+kM20HW+nr0Ozn488KF7fo/BBQkIXqqevvnToDoK02qjaratbqv9SU+n79sf9ufDCbKhBctH9hIr++FHEcyi4hSj3lorGkxNx5sIzEOBIR8OU5ydWIg8XQIWzwlSgfQI3q2+WZyGMF8POmj/oG171PSrGYEli/2e/asdQzlmxx2mVp3Z/TYlqigdEYrJfl6CfOecyHciaxEPGfpF7aPq6RzEXPwbUZnWziGIauMXa7BErqVsaH7ez8lKeyuHNeUIJDeCOevGbnahC48GzMtp9Ppfk31sbWiuo6u6+b2a15r11f/M1uj7LKg8/6Z89sO0rQhKZap/DULJKWodIfsHFm7s6QwxSF/uSuNbl4QAQmvik2HunnHGWRHE+F2VPaA3DTLFlA9iNGSlHOhjIQh+4fN/E6nSHSt5QwT0/NnACnpffbEGud9+6x3lWLW3sPXOCjESXQDKPdTL7BUBFEfXywqcor3t8z0HZ9PffQWX+zMxEwFlh8C72pf3KKLrcC6aX2g1eUmTr9bM53YRk3Kua6+9xlyGa8qUNWpINuX9hx5+cLRENoqxQQyljbJcvDKaM9j3g2G3mXpwT1JvCyTacNEuAKv2thh3TujdDGAyUbj51G2mjvZ8/56VFfrZdQJhLVfw4huFlds0m4S+j1ovO3MjomcXC48HXT4bqAi84sLV92xGjMPmRBt23Rxjo/DPq/XEMXaR+vbv80eyVeY5sLFscM6PkaZyA9b0Uh/yQkL0s2Au12Bh74yUFpKR9wGXqIO55vbgW3apoZsTvP22OytDWDIEGy/XwZmK9rvh8rXDYQU9Z30QKjBSn0ykz6h6bxEm2NSAXb19lEEQd8yWXCDZ7/IZEIxlzYloG6FMstvu7y9Hpg2jVH+QdeKYZOg9ku7XTNbsvrCoHUQ1MEiEOt0555wXZabrahzcWjH643Og9Nth2alJIBjQuJ0aSFEdlHOkjwuOtAkZdffVae7dUbh28P31199Qke306ZfUtWr+BzuRchPVew+QF7KEYEaWyoFSufFn79OUTIyTg65EvSkG+v3Ze3vu+f4KlKxLOeBcB0RcVqD3UAbEaBvCcMZZvwmsendaSjYrOPGF56PZmbV/MUHS1lttOfrDn86KTOXpaR7fvAJMmTDHJ1u1vo89+kT1x8pkoSagaU6mHcJeFmjEMYjDnhEyUaqQBQhYZE1gYc+Wg4QC3HLzLSXdplVDNtnrZr2BnBFdIHvyO9/5frKTd1XgCSr+Tggh0Jt/+Ie/r+xUOcZzgVJMzGeB3AriT/DXCWXWpxuRykYhLzljoMpZEWbgpFddbY15hqhKGylBvJrzuHjW/clkiQ8/eH8RxmSGbEjl/MP+bmWdJnDfa/8+87nYBoE8pwnCr2CVwEb2I2P/QOr9WLo4GCQkC+XIM/W+fkcmJQO2p9/MRbV5oSE5JZBVMukZLvTKyzNTD+UUboqojFqyOpxr2G677Ue7hMx1Z4RjBEQbR6auAst8xtLD6DIyfIIQZQNlFWUCvfCCA8EjKJkxV+YAYwtW2iSY1jL1Vtbg0axVR6c4WzAvRMf5YZutU00kSsIgIxNkeNbQH7CkM1GciHyvtXwsWb/nPfv3OArtKOyWAJjN3m//fSuoaopSi0ZfeUbrvkim2VpnZlUwcMghB8Xp7VzBNpv7QHgeGMzNUUfs/93jk0g0oZGzw8U45ZSf1jW5d8hiG5H2RiEHAs2Pf+yo8iGUszy3hTkiUF02iH0yO6jLA0HRlAl8zpYZiSgxuT0O/FeZ+OV3pmT6k/q5fYHJjIzl5bpl5pXgZD26o3R/ghLO0/p1YmvZ97yfdRNs9Bopm9elFjvr3LV5Fs1nzFcMKx7Me3faau46gUyXzQOyCRdPZEeZJYpHle4Sh67Ca8EYrQ7gTWoy+fCwyskUPNqkruinnpua2TuzkbBXZ6cP55qZ19aGPTCwokHSaN3qERwCp3zX3WZyvitRRqDjV7MxEt2JUBl7D/OpOBHkJFPsHQI6sW7QAst6RSu92IyK3TFwhqH/e5smMd+Jzq8H6RVboBw8MQrjzKrloGpBzZmCEQ04rqgpn8mYI1phwprKMOve1uitzszAEazw4AQmhCqujyzXeyOsztH2jV8ZYf7r7QndmVZhe1AYwswqMlFIPTaxbNyhwtiTibhPo7Z6LcRDNdvytlvvLIieUdnr/dMqQ1wwB6Yk54y0K0fe6rALlbLVqNiFBNBdh82/xKDsdGsg3etvvK6yurvuvHcYMj0xEmq5ztc8d5q7r6Zes3pFwzIqzkNARBcZlAJiEo2qu9QzD+xJjUn/mucAutUPCYlQz1w6ww9eTyADouWce2tLKZKUlGI2cjK7rtrjPQwGqEHzcdocO2hbRr7HnrsnG9u94LyXQWoxACW20dzpcDAgFUEbXn022faFlcFvFBjYQcYKfTjklftiNJU5dt1t17DSbxydEJlDDgvE1nWC7RNsa+QUgeCDyd4NEUDI0sbQhBgGGDmHnSF8es7Doy9+/svlhGX8XmqeL730fN3H7Fn3lQEV3C2XAElQxABaT0iAc4hNKYJcMQbg3VnjX2e26Mkn/2S0Vxz0tGnvr/5h49m0eOyTBn0BLUhSG1ZzKBk+n3vtAWc3MGUwBI7ZZ36nkWfmBKlKC0YcZCOPOCMNwisVntxX+HejW2+4OoZzTrK7ybEdCeDiNPseb/V5mrOCxDTGFwT7Zt2XQGa55agnva32uXr/A3HK1gAz+encN1b260EdQIDFe4BQxJBbXoM2GGar7Nm9PQL5xUlIAGX9iTvYLwIajnxW1neXKPoQAoBA+B1EsPGxA3tkohDR+xWSSb5zyWVGc554NNeX1pmQwZbJedcSIqumPysYcT/9HpHrCro2KD32pFSIsuacrDPveWGrF6yde7cXShc49+lcOzP92XQSkSDdz7BVWt6sWWemNkj+zTpvPsv71YSgPCI/B8XwHH+RHmiDGrSccDzVv5p7kd3ODmSszrlWCE74AbfedmvxWz772c/UzGDas2Bl57Gcbkhak9dap/affnT76GNHHR0VrLtT509tMc8Gf0Ew+FrW+5NHfyxB4+6DpnLsbq7zlVwj20aS88rM46XaJnAEqbL1S+erVjcTlDwv9V62ma1hr9hLdlbw7KX/k7MUiPRBIL32yT77N/uMfyvVtDwj1+0cdX5MF7P33t6j9516dmPrqxUI5D3GffYzH5+79TZbju6J0PdTJXT+jjK+5LMalPDOumBReyvSvr0iA/6FJqmGVQ/Lm3uQTXIsPX6Jeum6rpiMhTi02hCixdqR3Npzj/dX1KRm44ZMKKlDEqhysRzmFZZfsYy4xXLhagidvAE6ROYBGcko3pE5eaTtijSSDduzUn+Hz/cm70YsagTlTsse60gZVnUYGwuzT3N9fzUYrpFPQBlEyrWtIN2IHEmLcXDWAlFGpKSZ3oOdnbqZLGv9sFH/z5f/d83e9FDHQs8Ncm7ZyVhyRu+Zc1+K69aCQXY511x7TUWGa6a26FCCPvWNYQLffdesbPb7U0fdKWzSAwJ9TKx62+uDkWcwa5wXQ5Y1fjJBDeKEl8jNZziQD4WSf25gINqcoC1QytSpW1VNi3as6BkjVaYoQ9pjj93rQJbSB9hRbSj3ylD4WftivTSPg29nz55VkeNtGQ8mozfz0u8gQWmv8Yz8nveWmbQN2wZ7g3FBc7IO9U3ZqQCQkbUXOVrZyaSQ0o7M1JK0eFW2WmDqvOAlkC6mhcXU+pW+6cszc/LZOX+tgOE941dMZrhyZZtQFuvKOL8VZyvw01/341N+UjW5VVYZXwPAe1RdlPRBx7cNz1afny8v1h2pIIDSjwz0yIwAY/Bkv5yonkKv55ORgvvUBZ2dXTMNA5EKg7XETWKIqqYrOGB8Y2DBV7IqpK7j//OHNdv1iKyDftx/Pe7fUxtctxwHWH3VlSfUuqrPq4E5M702WmFGyUW2/Un39KFkhMsHbl8+CIWla0ejnatCgeP8OBZMWkLzBDq0W7w7a4bVWes//LBz5VwLPCFNAmcZreABtC1rFkgRA1DG8Ltmjsrae49rY+YSPGhwHEdaSkmCZiiVq1PDHSbutHPWROM5Uu9TWVwCEmS8R7OHrgl5zll/Js/cIO9TwhBdPNngm3NTv4xk6uOPPpiZrJGpC/IiYHoxpQ9r4Bnb402OtA1H6IFyOe5CT9qrySIaj0gzOPfljAztW/691+tcX2/lcJZ61sR52vccQGedNvZuE3AvpCPPWyCoxFHiNQkyye8ZmeaeJ6dNj9PtZ1TAhvBzfWr6787+FyQ8kBo90hhpTnCsgRHsDPtXwUCCKJD6zQm2Xaea6xVXXFWfr6/6/vsenDeW7KCUGzbcaKM2lCFntw2wv230i/S277jTDqMd4k+Ql2SifAJSppLZ/UnMfv6LX6T1bWZxKWSTes4pUyFwyq4F7/YG/8WRCkIgZL38xi51NK/PKWVTGmRrLFwEWvKfnyld+KHmak9Zq4aaEBZqTtXL7/qznx/3pS9+aq4fbgOs0/c4zIFsDdFvVW8mRl5bNNqlIqLXAlVdVZCfPs7a+Pmv2FF52K9m06qdkIn63e9+XyoZlGT0FnayipmnWlwYXc5Xs73+P0Z2wQwMBh0tWNFCGz8k6nc9TyYKcgiQAbwWTD22acH2umfbqC2S5khblNLqMvOnttR0moKCscpE1S1bZcRNc2gC4JFBHKjslf7nOm0OLMkOqzEqN4UJ92yyoR5xivw448sCK7LAwAAAIABJREFUaRN4NuLtU8ceW7CbV+9Fclj6tfUH0512j0CLlDJA1mpPZWwDa7sOB+Wxx57Ihm9wuCzPDMzzL7h4tO0224wOO/yQDJNOs3JmmXo/s0Ctvyyhz/jEemVoZLKyudmhw9PSFKVrCQANLxkYTbsIWMvm0UaCxSfYACHLIBEy+gbtJAlBEmPo7yK8SZPWqv5BBCJiEzLqy6P0RKHEszXEWZAkeHsihlP2LNt1zyW1V/My1Vy6dqmJQVGGyd/BXNiGDv9Kyeq233a7RL57FdmIIEUzaGD9BtNHBDrvTcItQg6BnW649KwQgi7PvUV1KHthyRVWLCr+nKci95d1R25gIB/JetMB3mSTzSqydw5Wy8SM50Pc8vKsmohFk5WcH6wNn1s/pYF+4XL8VGk+Eifq+mXo4DPtSupmovEmiyd7e6vqoJtusnkZUHvZuWktJA0yLigq30OqUg7BfdA+8ONTTilDuF7OoWf0gx+Y4/t6qWsZK7b++hsMPYvkCFudtL/KkTI4WcMnMgjbek9OX6wgRFA79tUJW2+LgAGnIkNdKGtx522kHO8avTsZhx7AN5CshrViBJszLsZW9mlTvlGOmJm5rOPHr1BroO5M9g95DUJT/ZgxxK9EfIE9qMA6gQQlIqQmQaeNow7J6FePcPvUIaBuda+WmZrj+mYRuPxZkO/39ZG+J9/76Y9PTDkmfeBvo8f94uiu227JPngs17ZiMZ/VG5dMTbDEKpD6UjZhM3umU0FIvlcljRh/WWmzN/Z8m64Fgu71t7G2QHCEL6GHtMOK/WsLgOaLCPhZI8PcA2ciw2y1x5BAk+UtGbuxScR1ZJTgZYx7DkbpyfrYT/7sWn70w2R/gW3Vv2vaSgJz7Pu/+dznE6A2PVsB3ZxnqBq9UIG84HzRtE0uEzF/wavPdn2vZmqO3mt2z2dYI3btoaAMhnZfdtlVo0984uPl5Gmpe4aVkJkSlN858cQTI+5yYXWBUEGSCQsanEka2ZA/vfs+jy9zFgThbBoHyAZxwHyNAITD7xPC/N3P+1lnA4rXZ7vWRB/EsYFYJMj1DDsq4Ps1+QXUe/THDpvrL8WYykVQCnKRImkb0eIwQq3vJiOSYlA50jPPPLveYI899igquYNjwzsML1cvVVQ94uyuTeakrqY1BlkCaWbhhRatHrfqSUodVh9WRVHD5mJIGV+i36AImaSbR/12LU8n0vASRYMpuypKc5bNOfZsdJ7hHIC8Jo82MBOzkRk9hpqRtdlFkSJMGeByGVS+MI3RbBRQhnoA6EOwIGKShVrY6669oYIGWbXCt8HnsqxVkgnsm6bmrUNWYZBdpxrs2FfH2/v3xmaljXnc7qfVQF6sa/EqdjF4Lt/TjH912K7L5LCDdd3jGnFaHKfDKQhhKMg5PhLRABu/Obe0WKS2I/vjlInpO4h3JqsW0BifJXv1fFq2+2TBSYItBCQOS9TIWPVivmuVffp5kzfUbrGqQcj2kuz85tT63peMyOQUgZasg9PQG+d9ZBxgSw4TIxUkWqP5sg/ARMhRDGcNXc6+43AZdZkJ0pz6C7b44nFOSGNqZfZz8bBjfBv0Zn9nL7whu75udPGF54ahnn7YGER7eGH6sDk4yF0gooW0cyQ7fCkDGHz+epnriFj3M9KHieoZTkz2ep4VILXPme9I2xPmNAQLMmbTLQ455OBk8yuXUIS6HMPzQGrT+lHpXnsPGbmglbMFP9E3rfr6YDgY2sq8wGjZJ8uqj8fRlH5s9rizJ4g97ac/KxUna3/66b+MAbuimPBf/vL/CtFvjYIZXXdHR1wv44fgRSRePYoABXUf+6rfY7/Pnu13YkhF+wmCZafmxN6QZ88wuhfGqDuO4jJQLKpaX5MrlQVr3wIJ+jnkNnKTi4RcxZEyzOzNC0GRrKW2GfU4QVPX31U7szfAjr0k1UmGjUDSatXlxrO3ng76oC6tLq4NkO2i1vbTn55SwcubCcIWfvvckJIuzjNeoAav6ziwDu+md5symIzOWbMGZdDzveYYka3aSECiKbUHIXhDDbdaS7J/BJ/WvAue+DnPl6Mj2PBYeASYy+VIEsB2AXyBWfENgpBAZECjMjJyqohDWkxadtpsrVYX9XdB/xbpLbfmZvtenDnP9JFvvvm2eh/X5NrcI5Rki6zNgVFJ2iCZpcTihRefLV3vEqaRcCXwggY4z+6X07QW9lCrqTY0ATFzxpWX13tCoZxbPBptlNqJ/BybpHXv2pAlvTDEBYRq/Grd5GLZbQx/+8l9Qbk4Q+eoPdcm+8opcpDs5tj2F86wcwGcY/uiI4atfa2pcjXUsJ2NriLViUk+Z9w3vvaVuUgkoDI1yqVyUDGpqim6orXW9+NQ+ztPzsH8xw+OL5HwDx24XzlFfWqiy6pdxsh1QoUHjpU7MzVSF2gUlvfRGqAO62LUQNRfbHz7y/QKdGgGFDnn+RwGQ4WrLhsHoO3G9TjYVEEwT1tDcmPVFdSVIs24yj4a0ciBGZuhjq1VgVDbjMgWiYNk9TBhuzKmhPk5/aot5XoRqDz4d8TJcuQnnHhy9TJxmA6Oxn0Z9uf/5tNloLQEeC0ywAIdUmgGvWXLXvMc/FCHbvW/9hA7g5gaUs9aUcIFK5y9A8MJkszLIIJqM8IYhha0FhOwW2MZE31AfMGY1mLi+q6LmP59MXYTJ5qis2pQhRA3wkgUbQsc1LEEGTZq1fuyyZDRls9eEP35DJtZ9KfGjqmrxrFZDqm6tskbah3qucQVto8spGd2wgkn1jVqGSrJyVqHyPwJ3AjMJ/gQ7NR0+kTALfMCZablJ3tVRnlPHL+ezPfusGPql7uktWXFgivlPfMcW70xVlkTXlggqMer2TczLzprdNstNwS6npMofvLoXcuOTw0/JY53LVHXf2+cPYfv2fm9N/I7SC+bbbZlkaH+9bjv1pqrr2E5d5JZ60Eem4XWI65nR1KSVur+B+wbxvNGtTcNvbf//pr3ui1zGAVtUBwHVzaP9S6IpdbDKHkJ3LrKjdurYCNf7dWGaGQaTOTpfKY62J/POSf3cm9F8J84+qNBLi6M4MmvKzP92FGHh1yzU5GuXE8ribQzwXEp+9CvZbyw1qseFxY7aN2rq4O1wFDQ0sagtRF5QVFSN1b2uPrqqwo2XXWVCUXwsb+wvMe1Abh53m1s34IMcj5D+UIp4epkp9btqZDHBKkQDaUU+07faKt/cqKt79TaNxm45lhb1tvIgr1FpD2jVuN39BGBEPu8F+NMyIA4wdf+6R9rnWXj4+a+Nrrskr9kPyw62i0s6HtnPViiD7I7Tpvz6Ex8Ck7QNHtCMNAlRf1cBfscS84V2+fPjDrHwql5tgJP68pu1n0OhM7ectHreZ51Z532/kZ/b/2aD9TQ7j7azhrYT0ZiUuIigrJmuiLsdXuSEL29KNBEzAE3++xRYG3OmqADrowpRJuF9KZkhIUuMzQ2U3DNLveOiiblqJ0vSdgwU9p7qGned9+95byhMBtssOFo9913q7LE+BVXKcUls4WR5Mhwmut7d/YPRnDV8xPYIDuCc/Wg2yscofsW+LJFrtt1KHP4KhDhGKvvM+tfE3tyVjr824UtuuhM9TXnfbrjlMh0NrTfEZTMCwZP/fF/zuUwfAAKec0hHEMqQoBYNg62yXU1sXGTUc4467yId19S9HHzJtU/9LAVs8nBqEHUYIWM4Iks3I03Xp8ZlCfUgwMniBp23fV9ZfC1D9xz7z1VZ1o1zrUgmmwgh7jE9GsQcOvVdB3GNIF+vZZcIpqquaYeNRCR9irjq/gc49kdqe/1pvPujOpnh0ijOzhGW9R41tlnh7Dx40SAgT3zGduklixaBXPIRrfddmqRE8jGYTOCUtQmDzv8w6OjjjqqDAJWbJGLCiJusED/nIIBsz7dYI2tj7bvt0i5Ba8NaudMGDrO0zNz+EgEvpOcXO4dVAq6pSTEcXFQyC/eD5kMVKMe6r+77ron15v2FGoi2SR9aDhjok0AwcmaMegCoCUCvcs6QN7G2pHIU/chRjA7dQxkmMVSswazTEoAAap3/QyIA0fyDpx5VnozybJxUIQOGIxncg+cZ6szNqGLqqMgSsSwNWguwUgCl+YIFygiiqjbGLGN4pCOPOywyIqFrJZot+ZfYm4LtIbffyvCIItmJN2byYBlEpz7X6afX99bNgHBZP3JgbGRWUwvYvivDQ2f4ZBlCpLs1QkTJ4Q4tnMFld/45jdzDmYkeJnYDE4z12WIhqSjnl235ILDOUE7TEn6QAIz3wf3IaTovySoDmlh942U22iDjepcQg20Zuh7FDRYs0JthmjZc5G5cqSlcVqkJiS5qIflWXdBb72Q//6975dC08c/flRBv9+NkL7g5HORasPQ5Lhcj5druyGTewRdaljFhSiH1AYx1Gfks8fCku67OSn1SFT3xqJlTBm5m2+5sQZaj19x5crO3QPyS9PGbs+tT4gRuMpSTDrhzGQ/F8fuYFALspATkYOeClry3LMvlFPiGGU03reXpMae9+5I+9nr2alnQ/+WnSt2eLLcPfbYdXTM0UcXkuT5z41E4x23G0f4i9Euu+4SvsfujYyZwKwRHhGO2ggvxr6Pj7RO/XqsbYnX536pPVWNt5C3twrx8mdG3deSBx1gV8+xC693PeXe9sFhVY24MrAMos/vQc0kHghDj6ckIVFyDX0g9hNPkArU1x1OSn4O0U+QLIP/0x/Pqt5Wz9r6Q7Eaezp/zmchEe6QkhXhiuUS1NwVHyDoaYPr31aDGSqLF+BUoJIyShCm++JwqWkh8l2b4J1ELHGHfTNvl4Yux81e/+SnpxW0ji3tRZENRK8M5Ny9f889y48oE1kn69InTxVEnfXTBaBXFsGIv7E2PQNtWXHrI7WXBeXWEiLgKxTHSzAhILG2fFv3Sy2gb2NBi2D2neO+PhckJQJWnEdV72zcxbN59MZZfEbLSybmIhdLVlPGMWy8CwIJ0tbdOaxUAsQ2os0FfrNh+qYSHaEvw9bV1O4PhCXKgl+/P+xCIgJYnLtnkTiuhu+3Xqhy9NXLBIZ8pB4MUQDQXx99IxpUQ+kN+n7/tVdE7w3KdfDbRJWm/ek1tk7ZM8OxMNDXvvb1ZNS3VD/jI6kRHXTQgYH11ikqt+jJhl43JJBb0oeGlLPTDu8dHXjQATUqTY9fkQUG4tL/PNj9cHdo4b8TjVpbTjFJy1g2xrB18HJvL8e4uCb1HLVsjlPwQNLLYcIaBAPNSWZJ6ABBCAwsq9EuQkuVMLxITl0M1ONVrT2pR7Z+2reqhcFXzlWLVGt5abXWGzOf9s6IaGyZgcA2OwKGZ1AR3zBainGxD0j/yfRPP/30uhd1G20eao6vxtmqdcqqXJ+vYDLPskhC4LIKjBCi9Ig9U/ey+mqrjw4/4vDRFplVKvNterlN3aleBa+SpotRH2WA9QJzR7MSoROYuCR6q3PyPkhzEydNrmHGv/j5r3MvbY4lpEZgIgvzPkhl78m9Y0B7rhCU3/z2N6MTfnRi/rxsg6VjJJoTnS/yULV55ZHcH0MkWPjYUR9NlL16BTOgMHsAc53BA1nXnMYYgW1DgNG+gz3vPGHBM3Zd+BwMztiqazVRihgFtR3OKAe/iDx5VoxhI+y9PTX9m0cnnnxy9Zseftih9TMnnHRqoRqf+fSnR0dE7o1BeyMN9c7K+RecX6gMkqCRVi/HcFQv5DAeTO9fg3r7q2W0GNFV+wwKIKCFEMnQyEHeetOt1VfNgWMqQ5ia3m8Ldjk0Br1YnQns2B8O0rgvfA6TT5DCtLV0ti7DiVRkLTts21Gmjvb0M9f+7nqbIej/7z6UARhOBKd1U1f+p3/8StmYJ59+Mtd9w2j2vXeOzrvw8tQKVxt9/nOfLbKYqlbLaJthZmd6FlpDLuIcutY3O1Von75xrUeDZKDvQTsYZgaakANiludmYDuFIoGjNemOvpOPlEKceXZHACsYtt+IpFhHddFSSxr+gyJ5poKbLdKDjpmL8OezIRQn/fjUCsAKQs7+lyRwiBSo1JBNZnkmpaJddnnv6NhPHVtn0no5dlV+i+Mq1CrQMb3iFmy9Udnx0vn9CQnCEdGuvfb6JChbxKasFKf6+0I1cVBc225hx9uboN2115lSNf6rr76uAs5NNt60WunAtX0tfB4n61lBxvxHXtH64U4ItjlG92jPeFkHjrLzO9yzf3fdfgbK52tHN/yOe/FZnXjkrI776j/8bSQC5w/1XWxxM9lMBmgGFZPVG7da5qC1OvTh+XdkFcQF5Agi0DKRqdtsV4e3R4WteXWRwLVLVc/oaT/7aY3J2iR9WWAa2cz7dtm5YC7QAhycek/Ngaxh3CA9Y6yoSoQNmEPmZl4IucRkDRkrPB/0ICqsPss4WdlvjTwasjuHuTutHsn3helOtDMg+2KJYC6//PJh0V+oRl6G+fzzLggT7ubqZcMwVOPSJ7ttSC7IHiUtlZpuJxb52mnTVffKmnSHXQe5DvZ8wlSDyHpk36DpmosouxvYzDYQYylqWyISZe4PBKvxnEG/6eab4uhuTtR2bbE8x8cwg7C8b7E845hkNqBc2aR+Rs4LZOaACXaMKHo4gYt5oj2Cb5sQ4+72OJIzRhusv87oK1/5cuYYbp4DzHC34MmroxKcjs86MTC4LB9UCS7kWEoP0wDuIbixpu636vT5qk5byiP5u2xJpugmTA0iiycQ68QOmWOfptKMZnvTpiIzqt7Ghx95IG0898Rx3pEa7jol3Xfl1deOjg/BAhNbsIhlemCgV8hHh99kJOQrRe6XBb7XrC5K/c53/71kL98dFKCExrNn+6s9wwbNgyYxIj/ykSNG0z6wV5G3lDUYKOt1x52312AGNWf9w+pamugRpiaHZOHzCbODumTJ1MAqms6foUDW2llscFQTqHfIi5RU/civVNaMLS+IlV1jahJCIbn52wzDvuSSK2JYNxl9KRKKU6J+c3dIQtdHVYsz44R3SxDhs6vEEYIJYyJ6dx0t8B1bF27w7MAsakpO7AreRfa//WOOLEczafXVqqVMvZyHY1sYSefEf3gZnuVjjz2Z4GdOZaiCixWy5myITIcxr1nGw7X0dR97rvp57+ffGeyQuHpbDU/I+n/0ox9N4/8ZBSd+4fOfK/nAGVddGUcVB5F7hABAQvbea+/RhPAEBA3aRSQLEyZMbJNlSr2tGV6sazaq63P76nl1xacWBDWSDZY2e+E5dkEFwZNgyZr0c2gtvXdnjpbKXBwteJWD8Gx1TfRMS0AGnu+JiZ+ns7t+OAzbZw6r2b72Bna4EYVn/OnMGrAhKMERsZ4CBVmbZ/Y86dIkEhMnBKGJuMKWCWY5RA4VR6I7pFVXnVgkNvaFPSWiX6WX3G9Lpp4px/vjU38SAtKjhYDaU5ukBi0ZcS6sF3EgwSSnrh6+ZoZfcJz2R0+IwNbWTn3VHgJZu0bX4mf9udc9rR270mujrqHXWl2n++yCDp3EZM19HsfK7gpQy45//f9+OfejjzJRUjb6AgsqZDfmkwK+OiAHimQiE7z44ksHGb/HyjCpQ6237pSwrj5aD5Eo93t32rnGOelLtEEsWi8ya1KeNfuumoIhG/3Qhz5UKfiVV15V9b6Pp88ImUO9SetDJ8oUwYTj5oBidERxeovMy3vi8acSNS2SSCoPrKZEvBFHvHxFthYOSQO9HSS5ZJwEg9Ck+5oB8+oZxFgHa8GKZj9ExeNC/PE7l15y0eiUU3+ajZFe2MBv2iR2jErIxuk3c0/WS7+fYdn9AXM+ve7s8zpEMPZgjz3wYyHf5gyanm93vj2o8TulPJR1AI9fcnGk4rJpPE+G0oE2JcRmlRE2GDeTDIImTJw4oaBSrN+uKiODFZ0xuBys93ksLDmkL7qigixOZkKmRVCDOeusc0v5ZK+99qzG+GrKJ+GXaxA4iEbJqPneaYFrTkorgcZ0/aSCgDZaK4w+0NbArASxgSlNGAKDEYOYkMOKqHRHRmJNTk1n3yg0YeVCTzqzteqTtSfJEbaxeRUg5Vkvkl7I52Ikpv/lghBXLigxEA7pXaUd/fzoO9/7z8q4yffVNI0EkLKdqYmWTacoBGBgVqqRPxsY0X4nY3lZ2mbUqzlgBhNr1ceWDxkcqWwVjK4EcuyxR5ehkCUwaoIckCcjVTBn2NJYldpWNtlo43rmhofru34oP1eEwJwjCIIzYS9X1l/nohHzBBOcfKEyWogCdytX6NH0PRkFzeF7MrNT9mHw9b777h0Y99bKAJZNH+fHUp6gRyxA1tvnGW6//XZV92dciV0IakvEH+QLwrbyw7r3oLXagfK96sUeXhyuwIr6mXFglNTodJMa5Zz9vOxMJtr3PLIM1bPbo9513/2PlDGXtduHGL0CQD/v/voDaNyC+Z/r4/9n0NofFA4Bwpf63V7Z054PqUXZceMZvzE64IAPRL94ao3Te2ee6b777F+ozyMPRzQ/pSnBLlRG8CdjxysoCDH7oiNirqeL1zdnaqSaxKNlsxi6HGF3pgIl7yFIrnJFBWYCJ+U232ukmL4/JRH6sjlStXs/72yQb/XSJy9rw+omrOI9nXmOw3sgdTpXAt6nQpKEIugK8FL+qfmkOUugVtfE+UO3TMmBSB6e0pZ9rueU/WaDvDg3ewLPAmnyqplXBgH6VfzB/Zgs1UdtDuwi+Q/aqHwkGaKS9UzsVwlHJEDE4cGWhlx1Amwr9eiRb+0o9kAfYdnQ0YXKuVtHtkSA6VqcS7/jvpWawMCen4DI97rN5kjtGyUHP9/m7DZFtmLu/uA//nWuIdCiaItH7qkUNIZ5ddireoFoqt5yS6YRRIP02RgejkLPJ2LGStEXJT3HMBNeuPueezKCZ7+aTNAZag1uaWw2TlEkcvrpPy9jv/12O9bGOPe8c0sD0qDdXgtgEJ7Iz2i2Z5REJG4IbdxXRtAMPdGWvzsMjL1IXk2JCooHTfLLwRVZc6xNHq0NLC4oM//W6xQ9YrOI/uz3i7wRqFNmdmYkqm5PTYDQ8rQwRPVyahFhSJrAe6tJVrSbr73Xb6yjHAsx9cPtq+vo9HZ/b+w/WdZ8Y+CQkRzT33jJpeZjXpToF1whEyf3mOw0iyVzVqewxq4PlOdzH3wwvVcxaosuipCweA7cvZWxqMXZ5CZy6P1DSLAhp26/TSlRuRd1F/JfDufjaU5/8IGHS2WEWhNYqb1oXYYdmIPh9+9M3/Gpp56WdqAZVRtFUpJVg/F8vvsFNddvxvmofRnIrRZjs1IrQmxTY1lnnXVHHz3yiMDr61UPH4fd7GQf05S1SmZRe012mgNKHPyFOLrrrp05+tNZZ5ZmrNoOFrNAwXr8+/d/WEpE2mL6uov+Z8VA77DDtpn7+cnqu1TPck9go58kmLoj94ZEUc5KRlaGrhONqppYbT4CQ2Oi9tlnv8CFk+sgC360MRGmF4C5z9L6jdNXSlg2bQR65mRZDN8q6fnss3Q5zhoCn89zb0g7NT81n7do1lQ2Kru1B62Rvenz/pq62LtCkpqV2ij96jXXmFSM8z/+8ewiIX3h85+Oc3xrdNxxx4VU93jkEbcYHXH4oXn/N2rf05DeKSWcFtU3x6mOXkHnIL+p11aQPc+R+qnB+FfN39PKPiQ5aH+rVV8VBqfSyFprrp5nvHYF7Ry1Eo9SUQUYqefZt1deObMIXuqkr8WZqGu7Fy9kqaZclf2fexfM/M+MdOzfxzpZjpMhBes5Y8XwVDfLs+E89LgeceSHo/e9VV2rQeobb7xx6fRiWXMegj6okc/oAvUd7XJ9PRNtCUKD3dv5l7VSc2p/95muQbbUiTGdBNPtqPPda8CcYBcPcGY6+Y/RZ78E0EopxGNkkOqLPZv1eT37r+w5exmz+txzzytZTPvb+0l49FPLYAXvlR3nDIOVITFQEfv3wPSub7bZpsXcFbxzPpySAEXAiY39q7DIb73trrz/rOzrFSuQePnlp4OCrV+1cyUdawutxNAlY8hx0jiQda6QoAtK4Vx4sVsdirVenJussWm6j2pvy2Stk5qwn5WB4krojbUPOdo2zHupgoI9/5ZEddJRQwh6TbX18SZYik8a918/+Le5LnpctESrvYS2aw7544loLg18dX0iVMoTCy8si1sgBnLBIrCQMwPBzQxs+Nennx9tGHjvgAP2KTryA/c/XK0MFCzWjB6nyLixCNuBswE8YH/+xS9/kYj+yhjoCZVRXnvdNUU8mbb3tNEH95lWRol6CYIGLVc34nCg1SMo6BNtMmBRBkmU80jGuL2QGgwHqvfxr088VVGhh8K5uocSjGaw1GJikAQOPYqpaKOUaVpjevXVqZsMo5oO/vBhlTkdc8wnUyvbvQKPpm/ZWhUsep/cUAd7gKZ6VN2NS1+PsfXYosDnXl6Ls0eg8rnISo8/8UhtWkNwBQ30h++4I/KM2JCZF7twCGJkAWVhhdsnE5Zp+n2B0NuyRqj6Mv4rr5pRrDqOTlZqszP0rmOZQCrW4sXI4YFIwbvrrjelBoF3kXlGubNGZZRsaYffWi1hiXJO6qM33XR96WLOiOETPcsYOAhRpLXiBDjTefU1Ri/XYWMyhuT63njr9aojrpSePWLs20e2DUNy7OSUEsTP+xW8iMSB8VsM2zdGTyeaffThByoQvO76zGbMgSOUDbJ9IMIHFHoEJF/9v9/Outnfi9XB8xK4ydSfSMCw/PLvGR1y8MG1FghmP/rhj4pkJXNrgU8LnPxO6yFtRVpnyzqCRw3hFniBvp5OvU2Lka96gTkJB18ddvxKK2QmZhiR6p8JFlYan7FqWTftO4vlecs8O4mtiCqVkSCrhOFZZZCWFdpL9mMZ1Zq69GI5UuIVgh4C7H7WWSbjqayyaMhiO4VEsvnmGwXJuDF1q9+WsMenUwcjmC9DO/SQwyrTwbZ2FrWilBxb/FdDYOb30M5bTM6iPEZ5jfo2p4qly4hpv1NCmZGatDKDRkgLAAAgAElEQVSSvdKdbwXOuS9OVMaJIbp0goxHlBxSvkAoezPTqvQFd9GVmlozfEZ97JiySeci9Gvzd++vXW3NNdcq9SaO3FmCwsgYlwqLW2auTefQQz402i6Z+eQE/RjvDyV7AXcvHaiPzXDdPRPtn+37rWsAPNpaM/q/9X0jEMMF8EIK7Flpv/aeHfUAvTRs837Ogrqx77vmcuK4GbFJZCWRhDaMolqbPvV6OVF7QwCHoctpVsY7OIwGpb/akILcn0BHds0hUh+q1qrqo037W0hrF110SaGPa6RmfHdmED8U5wQpENRvt11rQ8OY1VLjc5VnXk/rl2v12YIUXRw6HfASnAW62N7fEBPJC9IbmBfpsQhc+c9ncIpdnUkG6v50UAgmOsPW9wQkta7xbe25LlCO1c8pYfmze9o6Q1E8o3uSDPbfKTtchLK2pv5d0OQ6MLSLaPfHP/xqLqIKOItHPvvPZ6f2d2s10c6d+2rBeDI380fVZ9ZO8Vb0zIK29hX9T6/GSb27xOzBL4Y3XzbUFQ3KBe81SnqDJsGUHjSD6eFddNFf0uf264KHtt1+atVOPLxNNt10dMD++8WwrBxizYsVzVg0RXXRoxvS16aJuJxdDnFBcIxH6VEav5TpEBFYuDvz9GxSNcCNN9y4wdbqgVl8i6kXVpou+oWrMz5dSaTVf96oiRdXpk6CGj818I7NQ9KqR3Y+m9CznkK1CHUNRXwqTfNUftKMDfKFAoyFDsA53k9014ziW9WSckvGxBkaQJVo4UxqURegO/tKNvbCmUJDjYbjAqlaY3/34iRBQjQuQSoFBeUA2KQEFFYK83qDDN3mFGyaGnOXvtGC/5LBmqeKRKE2orgPUtkyGrNgVyL9ZdyyuXoNXY0Y7KNWeEmgbzMKr4hYgbm2WL+c7IpBLtS1wEA9Y3etRTApaNDYttYkb71E/SB7ghYQD0ZO1uVzCzpVR+VEkVr0Ifp9bMk8WxHuM4Gfbrr5hioB+Lv1ATMXqSX3ISIFXYpwP/25L1V2uEraMpqGc5h4uTbtNYyV7FhwYHqMYG5megwnRfWGw5dJ+OGu49xrtAVf5vf1vU1JpLvvvtMqw1SHdYZAw/5joNT3BIaibLXs1RNYWnN7WK8u5rvPQVxrvc8DQzTnVHDY2jgSpMrBsw7uoUfPbaj63IrGOVBGwf42mUYGh1uAMckxGXiARPbJYz422m2XXUY/yUi2k08+NZM6/ibtXJ8Z/fjkUwpyM93G6LwnQxZ773t3HCGPeCgtqGq1aTXtsZyEOv9QoyHIaNliCz600fh6TeA+dWTrovbdITVoxHPhVWCG2tP6kxHUTv/5L0plyHm2v5mX7ijnOdP2QS07bd6r9lg5sFafqgkpUArfM1qNMpkzb9/I5gyBsO5HRyd259yv2iyy5aNJGATkCF6vhZzVA7ruNLvN68GNv3OqMhnfqxYhTKWyjc2JgsChEJzpWHTKWlaJqIKV+slyor2bwfvJoPr9+77JT/aU+qLX2OwYcqWkoK1Ktqim63fYZOtuvyCvYW3PyFSr9+38vlJDOi1I4vQLzw5yuF/ZmxtuvGGejKepXBulHCFzZUvvRqBLMlO8gwSDkCe8CFm9Nj1nDhGSdKoS0U3hnRCs3yYOjQ2AHF6fFj2IlOB3jUlr1jlztpSHuiCCQEIgKptEWG3koNb10c7Km/U9NtoadV/h7DujeBdtqMAwUCQ/Vwz17BNfe3sR2+x3fa737EHOuO9/77i5d6TmcH6UIwjUL7Nc6Mt6MWOgXCzDy+AzOvvtt08alFPQf/2Vqp95E7106j0+rA/nZajp7doE6PpG8YhaZYztg9sFeH/Z5OJhCt8exhgiiixliy02KwxelMxQff7zXygJqRfzAEQARpLdeNN1VSj3/ismW+n6krVRs4A2A+JA19M0PUEzs55UjuORkDz0qrk//albxUksEVWbNo5omVpw72nBkHfU/4zIwlCksYnh+Lvf/75YYPfESYOOd46w82N5X1lg37RYjnphC6PPz96XeoBoXuasj0umh7nqoYDeZMCM282JtKu/Kc/Bpm56wXMrAjSejSC7mu9NN99YAs9vi54o+NvGc0Aq2MmLlBbFH5F6QfelCOXANYabWsAagfdoii6SjKyVjGXWIR9lvbyPaQ+idJANfc7S8EztsrL6PPcGU70R6PSaYt5detmMct6bhFAEmlPrVstbMgEF47Zw5jy2Z5Q6UBnQxqIWECycZ6smYsgwyBxz731ZV5J99k9vCSiDkJr1XBN50tYyN9C3Z8eJknC87voQrJJ9UdRZPM58q622qj1xd7Jba/lyyFX29Hbb7VDjyb4VKPPXp/58tGqCwTp49FpdlzYSGUamIjF+IFqGDHGOkf1vr4Lg23e60VN3vTf74x//8aujqdtuXTq12g7sKQxGsJVAgxEltOC5Ppn6JbF76mAg1Qlx7mAk5LCWyc9Hd8hHel5V989+1lcni6Ug1QO1rnZTtaI8K3XdNn6v1TWVOwxMFzSfeWYUnmLIZH6C5mnT9ko2PzNiHdPjSD9VTuZt+aw9MzHlykD1s7OflQwECDtF4F39Wz2trtN6ZK088zadxxbm6lubC3JcjVgrm4CPkOeXLAvcd+455xYMKbgDtzLKgmcCDH4e4qR2/+orQaISWD+TPVnOcch4K2AfPlMm2/7433W2+7MTTMpKNtq4sTr1eRYqUqpaELZM/Ykd+IevfCXDrvfO+Yxtyd59MsgCxwPVeXvOGaeobFX1RFnh0ENaGW+cPufaWvF6QtEcW9VJB8cuGOImPROJg2voPIt5Rh1rN+/5WPoxe59jl7HjJNgstoMNKwQpX8c6ZLbGv0sYZL2QEWvT2zwaubOdS7bWz2DmG8qhI+A3v/tdlXh22mnHsNqvKLvPgemBFfTutdf7izjEnklQkApxbEzxumj69HJa+0cw33SxX6eLgy1BLmVvV4ymsUSpPjtrSrPcC3rCNmp3bIzZRnz1H/voe30NeitQS9YaT6WTPStYz/337ofed+t3MXzZBNmz+/G7rQd5bvkIZ7uvZS8FurbKSKMTOrddWJivWTRahaLBv2aTrhKodelAlw7bBhGcx27EUPUhXXnDAZea+0APTcP9CoFQb73ltsoqKe0oamOz6iNkQHptxWL1aAwJ6f5s2JNOOjmtJY9WK41i9tWpuTJmmp+3C6xGtcXNPBeixfMpZr/yMow6Y4pyvW4UJNRJUDZHG9OkSZvqx0P1sxwYgkIVrwOBvhZ1m5sCO4DOiEtwMjaP+mtFxIMQtFqBSFGbkEhc6wgo1Fgn0ZHh532z++r+MNUINNwVSNb7iFwdPE6NAWA8vERDnKYI06GvLG2ALBlKhh1hwfu6NlDdNpEB1LAMzycPaCAxp6Wu49+rd0uv0xhafv/9NbKpF4lzkLmuF2ePoanY3zYY9mAMcv4sYr0n9TTOGrT8obT/6J+l3mLzzUkd687Ui8+LAsk551yQNXs8keba5Wy8X/1c6nWtLzTQCMglGbVgYeGUCRjb1i/a7vHmm2/P+74y+mB6LMlITsyB7b1yEAtrUq5+8FhllorYg7ARen6IU6Jnz1CGRxdaRiFYAFXZq4YQq0GpD2640SY1au2SBG3f/NZx1R9nI6nhNgZwC2AaDI3slhpJTJ3rMOCAU+Mo6ufK+JQbrd8R1FwTx7PX3u8PrPuJisoFjEhHnFuraS1SQ79BVrsmA7RHPU/339iIaQ9JzUi9uatylZMaOAdISYw94o3vCzZKRP/l51tWnevRe8dYex6yLD2Bb2TIACi0+vayn/2OANi6eOYM5xUzrh59/Z//b4KQzQui/93v/hDUYckKXicmA90o4/MQxZSEZREY24dlUPMqMZ5tooxWpCG4GFOrtL8lVeXcyqGS9TPBJ20FWU/746k4KW110y+anl7aDesanVmSfZ61YMDItEUWyrQdQVHsSiMWNXZ7PYVhjfx8y0IbisGxyfqsjUCeQ8FGhsrpG5adNygv06ziDJYOovbFv/1C9v02xaZ++KEH69/V2ltLWjPWC8aJzitfDe0uvdUFNNqCoOzzMRKMzYG2nvkGYdtfUW3Lsyu7NWSIrsVnlgJcflZQ8UyysM3DlK1e8gRs3XGySa3Fg/hAuAt5pq0k1ljTVsF7sEElbJNA+8GwZbXSOQumdumL9X6dTawcJkizv54If4IjdS1nn31OKWhtnCCkE4lkdSbHaKFjoyekJsuuSDL0pmMEK7NhuVeSgmGe/YnD4pr0p7O7gvGuSsVum/DS6v0Numaf1Tf9DvvunqzDvHbJQuRaTbMTipSx/LwMtgccYF0/s0WmzECHILPW288VipP1c0/uofgcgyN2Ta6lPiOzJOdqimbALbyGedjz1Knb5ReMMRpXRBNElN7o6pdvj9j4+PTxtALvQ8VclSlxDgtF/5Yz/uo/fqMEG8BUyAFqpmpUIDIO1MW7eRcmEms1y9dT5D4nEPM55YRXy0QRNSwRMbGGz2UKQWeVtlYV8OYiTSqOM8p7YHh1macenVg0i2xMEw1Vr4cfeiRZgZQ+dUlwXgyjjSar8QKrceZafLxAiv19XfOktA1svdU2OWx/Hf36V78pJyH7RIThoPwsIgumZE0yiEMDFfZWiPZQWi2nnKNhzuj/eXEuDaoa6j59nXLoatJ87ld2rJWgkaGwIBuEWgZMtp/o/b7U8Z5LDW6bnXeqiLh6E1N/UHM07mt2ahIgFsX8pUMysv7NqZkF+UiN7dKvaWSbPt/VU1P8zGePKeMherto+l/iRC+oIEE/YHd07oEzq6ktamHgkfxO+z5iVwwQ418b8Y2qg7Igm6bdBjqwM8EDtdCsfa8JLSryR6gZMo3+VYbEmd2Unlbi1ncnkznyyMOrHxMbnBOlU3tmRjzZh5OSPWGa2hNvvNmCJ0OcP/2ZL+b5vH1wOENGMyj31IUPL84f5MWozoPKeipadiqDgrPHkGEwg48OEx1KIEsk5nFjehFB8epoaoPjE4VvuOH6dZ/4AAbXc2pvpj78bpq/i2XItCHKQ3D235mbA0lrOEueubMk0/WyB/XlOcdjX9YVzPtiBQNhNMdAPp1z1pzyQrWPtbdgVGpLkxnKPPT3eSfoCmm5YjlOGF+wmQBGNP/xj32ivu8xNWc6Xy6xQ2Gupd1Py/gLkxUwDpNRFogUHyN+6aWX1pxL+wUjuUQo8j9n1Xl/dk6Uc/IZzyO7DPXF9hntbqtHM7/XM996PPks988JQpb2Spa5SkpEd2XfvAZlqDadcRVQCHT/9V//rXRgoTQl05lkQnbUBz/Y272OZiB5oW1RVquzMFzHWFLT2Ak7bbs0vd/uVF0fUlKJOwxkR59ROrVQqmIXN+EA3/dnQVsnR2prIZJDSGb92KKehc3vhSRMEC6HgH7JjADLvdonfo8zrHY0qFHVBtuc0CLYBaF6Tw2lTy9/ED7v55qujCgC3oJaPptGuP6VBP3IeQJGv9uuPwpQ+Tfi82qjgjDnoCZvpfwg4K3PHoifMlo2yjoSg+mZpcyVvWR/1Hsldq6/2NGD47Te1qR3XvgZzpMovWtw7RyjOmyfumNv1aCMoeOgIWXNUfa6an9efrdDxhWgbLPV5v+PrfsAu7Uszoa9EARCUURRupsuRRFsiCUqInaxEHvvJYmaxC+JiebT+CW2xN7FijUGewMBUUEpYgER6dKLgoCIItn/dc6s2fs1x784Nvvd71rree7nLlOuuWZmtQtQMpQg6OLO8T43CamBJlYNh9CZi05VfGwuPfYE2Vkwu4VURKEQ5NxvUPGb//NtISZtunjSE59YrdRg8U9+0pMrlsaaZ0nNwZqYWTNc10mM9buLT37y0zWxMPfzU74OEcMEidXdL8F+n6UEixmZuGOX8Upeq4RmMZMsqvKEvMfN4lkLfjsIvEpFA8QpVRK5LL0jq7tHCUjlznQn6InCHu3ame0JGaeJ9ztj3zt5pSCYE05IXc5Y/O6lZuetNtukCTrywaJAFZpv2LaF73iiLFVJ9ZQ1ATa/Z2z0KWwBOAX3/VwGiCT/vK3Mmhc4xAskjoyCHYsxJyFbHiL4m06g2G6bFlBD2x6WME+EMp1DxWr81Kc+W8Lr9ttvXZA4+OWsEBR+deXV3QkFSy/TgorOI+/5Yvli72FkUnpdOYp361k8J/jyz2IZSq4nzM0PD+euiT3L0xWvmed2TVWhymhKoQUey+xFQtgaiF+JgVOkhB8Cwm4R5DWvmW8J57wyCp/BJ8btYDuIvM4dd9yphPorX/mqQjakmdwo3riU8S2SV3pQsItyg1sJLF9rvOT8/haB0E+IgBEOeerTnlTpRwTKeWF4nnTSifGkxLpSQSvzvn+YsRL/nSkKf6cdd600DNA78hZYGUGoocbugzj3Go/BuYBYjFGq6IGXM6bV1O8DRYJrITS8X+iFSmL2yvVREKx7sdSuaBQyRdZTgfNTUjbu8MM/X919HvnIR5YHo2NP9e6MJ1HVhvIMz06Bib2SNP+xj34s75+aTkf/uNgjObrmlX6zr0ehjvfVymW8pFYo7t1nKy0Zg3b9IR1kTgwJ6vDPf6FCDQwUAvvGfIZMKWg6z2Rf87C9sEftW9fu+cgAxiPN56vYfuaRzNtpp53LOCTwKSZDoCgoD2EP6/y6172u5I3yp82WZhR27+Wr4hnz0G8Vol7xMxAfNfRW7L/c7jXbY40nOmjVwLk15qUirZ8Valgy0Y2d1zzncvgYU/Fo2LbjHZHPPLlfJE0MuogDMnFEsLt5tWWnWYjQHCUF3nXtKfaAxGn8c9aMiyJqr3jjnLkUaMjnVcgyJ5wXISrIidQVXBEIDE/OmaQUJ05JJhsXJIxiI3twWqRjQdOk5LivrAjy37NZG+eVQuQ4GYvrTfjNuCj1eU3Ky0C/rmceoF3nnHNujQuM7/sgZgz3CYXMMw/jd9KQGiFqBHFi/6Oo17nHPfZdrSvAQSl3hbp9i1i+BkmpSgfozXFDWQ/VwHQJK2FTGbj6pBTGXNjkbppqR/qNKjgszsX6oFjF6mDNByTOhnzhsyySgTZcuzrHxzMmOMBg73vfByO8z614DWWJjAMO4PUdGDbhttvevmIaOhWYdEqUNa3xLqXa5ek6V4/3xXrzMnHyWz0XyEj9R/FUliALCevVeNC8Cf+BaMp6jKL1Ak9SSCxVVpQNBsb0mcrvU0ItPzvklQ6S8Xnfy0EYqM71XIuwqQLkS88DSsBqpBAIF89RHnwWlFAUUxwSU3U0iAIA0YN5UfNBKq7JSACv2+DKCCI2eR4krZNSkeqCeK0KW3t23xEzQnSC2bHckFyMe6x76+4wip9QlpSSl7FRDpV7W4xC6RhV8XbN/vA5wu93EfSgIkUrqiJWlJ347XiZxue64LI18YwydNq7dQ9e1w/0L0w8ngD+vT6SgfnuEoY2ROS4EMN49oxDsc1Phphy98TflaWkwB3EH6Vgxe6736Fgne8df9zi3/7tjZWGooHCrMMczpbzHdsbr6X6XlYcdW181KEHCe64w6ow2Q9JMYVdYsDF48sYGKZf+MLna9/dLmUJVaERq0dyst9Ujdo0RVE6Py7lDrPW6jljLVIQdYhXKG+GgpSJLsbQVjkF9Lv03KQorBVrn9FB4YljbRNDQ4swhiNiEEPkDzf9PvyHeNEg51wPEWnXXXYr+O3Yb4eVmfOMVXnggQ8qQ+joo48ugcSbZxTfJuftoQ85sDyE44/7bnpanrb4i8f+xeKAFMj/YxScszjxqnEXp8h9K9NGp/rvpVcXofU/OdfKYf4swlf8/bQQERFEGIbSusxzPTdDIueFbjb+SivhEReCQ5HWzqv5M18Mu8tDortPCqUT6oqo2Fddn9Wea0VC6YqXirHfKgzXgTs7beeigiuRLDUC0I8TEa/OAc+xWLptnP+JRl1uqPFMyb9RqiVf8hyGOsUtCPSCfYtkF8NyicowgprN3H8PWcbP0+Wki3V0z9KqFVwlGDv0YJ6x6Uf+kp8MO3O5+a1uU8qLPOU4WLspbGD+ZVbIzIBw4Qv4LoPNvDCw5XwrnC92Djp1HnW9Mf5fhanOAVIhThELbdrsD5WH7B/IgOv5M89uPukZHiTodZ6PYjU3xuizlaOKnZ6xDF9k5JO/KXfPImeUUSsf3r4eJey67sW5NK8VA49snTSbGY+5IZfGE17nve9++2rpLKp0oOVfJH0kg7p1GhYj4gwe7WArRu7ibkaY7xIGKevfprV47VUm9pXuLpSUwXkYG/MrX/lqxX5sMvRkbXPumrq1pZCywF3fsvOv1OccK4AS+EmE3Uc/+vHywuSZur/O9KAAgW2VRbQx8xw2zap4YpuHMOT+jALXBClLGfj1r0Plzr2KtaijSWJ84g1VhSmH0AYRS6O0WC0mDGRKaRkncg05ZrPLY+w2UBixgUGw/JaJ8VPr1GHgSYA75Kyy/P1OPHqNN86ty0vit2ccgcIrtin8QTSp5PTcx8b13R1W7ZDDm56S8RbKcstYlfeadBx/f/ywwypurVXXQ9Kp56pAh7xNMDzL9cMhBdjsDJfzopAwRW9ggORZXBNEDcrqeKHD3QQoz1DFMdbEo9b+vok2rWR5DhtEqTJSwJjXB0JUuYUV/NznPreq6sj3ndzUUhS5PmbzKMyWOyG+5fnsM0r94nQCOTl9I09NmzqsaEpY7EmO6pGJqx1+2KcXG8d4aGNvt8Vf/mXKmMUiZXVSooh1DjBPlTd88KMeU3viRS96SRXc9yqPqSr1tOM5irU8q2U7ttKt/l2elFzcZkKqdfzXL31JecYgXgZchUFitJz6kx8vIalb1ne20owhitV8I7qpm8yQ22ijtHTLXNqDUhhKHLdUXgrneGPhCPT5C0cBBBUl6juaV2MaYwxX39iwn0eR6kv5m2vVHo3HmvzjaxO3Ilw1M5AeI99wYn0MuCpXF0/j0sRydQ15UtI/9owV/7Wvf61SKPbe504Vd8areMpTnrTYOfGzb30rDe+Tn4rE9uf3uV9yq8OYlDtciFPQiQh0AnulAvnTilQdJ5w5Z3Co5KT+9dEJMRCIvGaK62r5spl/ays0IjbsjM+rU0ra2y2imXha5kxIYyWKMPNb57LGph9roNPsV2toTtZLHr0YOKNG/HHDGHpX/fqKFKp4QOprP6tS+Ob8tkfX+eeU5uSVrvRIpzDDwK81hiqp2TFc16BkBjouODFjI8CruEqlkzSyNx5/xXar88svi+jpGicm9ovAJ7y0fYwfBFGKgIcm/snIU+jD/rVfrs++cB0OCGeHp4ng5T5SZm6RZzcGitdZ8rP8fajjqdkjUlbwYu6awvbOg/1vXhjpzvCWt9uqEK5K0UnowXWlKLo/kijPmvEmJYWzUKGv7MMmXt6sFOqgmEUszZ8pSuFz5sJzuL5rj8MhBkpnOevmDerDePR5aBiZSE/5PaVc1fsy3jqDSwNm9iwnwzUqJebd73jLasqOMmDhuaCA7IZJ1h83lkB0oGDcJsOXQWRuNNj/eKQ2rH6i8q8m4VhqhNdHPvKRUgasXBO/eyyW/fe/d1nbYKne/M3qLUJA/oC1bMZzk8N2bOIl2iltndSSbbbZNhvjnPIGWPOSzFnHhOV+d98vMa+GeSXxGgdlDlqVB2as/jiEiE1jZYKIVCdhrYsPgiPEfHgRXjYWFio2WdUxrTgLUs0mleNqATqXsvF8i450Y+MP9NIHQ2pFe2nlSeXfvwpMJMZqTr06lQUxZ4NqqA0alrpjQcXdWNE2A3jdSwk+9TilsVSCcNbRs/3X5z6XTan1lrJltyn2G0MJ4/czn/1MlaEDtSOdXB2jAsxiYxTbT04mkoO4VeV+dm9K84BkQ3FNDKxYo0v4jkVqA1Y3hQgFKTWUl99vncOKJLXvvntXk3OdgjrW3bFPY6dEJ9F8nK8irUSwgSY1QNCKTcFqpeUwownWy0Oz/0HiLx/7xKcSG7pD751MMaKUPfIP//CK0Od3qfjOifmcEoEMGk3Xd9xh5zrwr3r1vyzjJ019XyLra4Tymh9KkfJO+zc+2gbE+iUsHpMqQU9/+tNKgBAC+rc6N6zxX0c4bZYiAtLEnLUtYrSq6jM5gDqLqGG9wQapupK5EFMeITnG14wDQ7SJKUEtljFb6+sMWQNF6RseTM/I7E8v5+LKeGPmdN1AeDrbYJgqD6evKgMDjDl1nn1HyhJF7YwyXkC5YPbj4sVT2FsltYHxKT1LL1yC7qpfXV7FE0Cxj3/84wulQEjSEGAIYq1AmivQxKSOp5aXVR5U5rQaZHd6GwhQusSRR36rygJO9yPjolSgPwx+Yx0vt5ViK9KSc5n//VLOUugDGW1k10qlWp9fGi11DnMmysCvMEXvDQYlAh7ljInNqH/e855Xc3x9ULJugyg9CxFNga1+tpWvVqRkXf9de6lik11C1FkrLxUKtfRMR+mSDYyCjveuhWH9TKYN/DnwtmtQpPgu9lSnbwTByH4Dm9q7FEgrj44jl2efF1mj4XY1bedM5MxCKnVpIYvUQed4KXLC6GB4kVXOuvGAcz075UhO7rLLrkVQ4ulxrJwTyr2MUYZ1ZRRcUAUTjM91XUdt5mr6HePXPjcuuadSo4RFyA0esxclP+UAKWjXPvvszg+VWlVzGmU7Ri4ey1SHGlh3Ys8rWbpjKBk3g2W//fZbrPPKf3zZaj335HraLBPMFic36Vi5BttWLssFLLjemtq7FY9cWgBlwdksSrSRYHkN+w1M9YMUA/iv//rvaqHle+eFpbt3mgrf9773jceYh4gVVAXGlYVYxk+qUklV4dmoapMavA7vcovEZlXG8SIIeFkaTT/ykY+o5GoHfGj3rKqy8JaWqeER7FV1I0qr4wMRaol3qIRzZiYcFHv0McfEAj66Avcbx6pnKamxSACCKlC7r4o1V65/boAWz+ho+KSLDRB06mx2Lc8bapM4ALxTh0LwW0++YqXd+LuykBFqtacAACAASURBVHYLrCbOqyOJ/qyEmu9PLJP3LYfrjORpEZb77HPn6qIg57MC5jkEPtN4v64S5yY2d3JtxC1uvWU17mZtNonlpo5TxIiQruFeNm/lZVbFIUKjWaFrEIr1uwABckXBTSDeCA4CoTo21KG5rLxQe2ZVyBz7pSrOvWI4ef7qDBEBemO+b5OvmxzZ9XKPoqln77H4y+DJddZPvqxDfWHiMj9LJ4sfJs9Qb0qHSQ60NQExrReSm64RX/nM5xZ3uFvg2xy+EkYRfAyV22Ztn/u851Qs5twYYewYzcSvuPzKKsxwVNb5S1/6YjGrm0xQhRkLyh2YrcWxKennboHrF50qJs6J3fk3f/vSWvvpgQhVYfnr0XpDlNoOUezNTUgIJUUdVu2wqmLF5QHGAMBOp1AZivblSpJVG5vtCUMOOjzSyAhWpPPqHDn89l4l3+M05PxAPAgy18DatsYlVPP7S8K+ZFyCSHkqv0vvVcrZvQudCKLTsdjAXYWAbFjFLS65+KLFt4/5diqZ7VECPJkAVe3qjvk3Yf/T5AYyDA868MDFdkFM1AMuYywL0Nb92jrSDLZRCsWKlv4VA1JLM5+VB2xeFRp417veHe/ntDKEIB+UqGvb/wzo1kpQ+CVknO/xdoxdCVNnX1oXZmyt4FLJjWKzphPK6nVeFtwoeN+17Quec5pQR3GI8T8xJU+VndTdZgPNKkJm8+Fu9r72HnOvlYq0IGifyb2sq7NUSivjIkedTZ8ZR2Dk6yjKFvB9H+Ex35Mt4LGk9/i3fFmEQo/je/bN5K17v4obxNnRnYiRQobaR/YxZEuJRgVvOB0Mv2Z7Nxt85513rHGeEeIgWaCEpUpB9jllRbFzpIROGNlTdcl47S97x2s6G1HuvkdeUGiT3z+x0umBDFUS471DcovNTRWRr2e9tlP+cp591r7AmKdIhRg9/xgq1teZp3zpponNznz73CBk8zN42H0Q69Z5+1vfmPSXpF3EsjUZ2+UQdFWRZj051NJFPDjPTFUR0ICqQRSrG40HtMbySmzMy8DcdFhQ/o2xhdJ+97shWOxRbE0wn3y+DnqLUVhkwqI3BmWK8Qgu5j05mBJ3WSKSx91jowTWbRiLQQk94ID7F3RjE5hAwqEWqjZPH6zGwAWoxT1TxSjXV+rubWkztUninQeE6cozRabBHrsmljqBMMpEjE9t30rwjbARHAdFUFobRKjbrO71x/zZLgxnvQ3FCwTlxXgoZ22z9APcJaQH1yXsxLTENCkPVHxzwBqV/uE50O67i3yPRWyWUOCl/fyMn5fSoBhtYrFlyv1np59R5Kpatxgsl6QogK4mFePLDJTnxIouglBb0N6zL0oQLCFq9yvLMIoPeQlkZf+wvs2pPeNVNVGTmqOTis4sdw1hDAEHc5cH7jrF5E0lIdcC+Tl87Tn0+lR5tuw5HtI111y1OP20M8qydVgd9H3i1Q5pgrG1vuTwFHH48EcPC3QUKL+Uccfc5DFPw9+HPvRhxSDnqV+Rxt2n/PCUKqxxyinfi0GX1l4FXUcgLefAviakIREMNkUjZq+319L0eikZPOPnv+D5icPuXYbKkJrML6MAue2GKL49Q8whYu0dbQEZYvJsIQAbb5TqUPn9zWN81TzpyZoxjUIo3b5UDuaim0f3nOEhECD+bQ0U+SDweEyVkhLh/OMIHo9n/ZXYMwcUDOHIm6s+sFlTCFSVrMtAGdldkabhWWcac/fe975P6vTuV/Dc8cd/r/gQjDWevprIWm2JyR4ZjgSCE8LSdkmPWRO+WDJe7ZmO/zd7FwxKkXp+IZFpgF37IgbLH+MxXXhRukmFEKet2i0CK4rGi8mXR1pF7pev5RoJnThHPJoRyvYj5MVrDKNpIrA2x3VtWcPKgV8iETxdDH+C29oxhh7z6EdXcQEGySAtrr3SGx2vuwxR3mZ5pSs8UgaseG+tfSM1k8LXKUJd0N4alDG19KxG6DO4yQ5nx/4bdi8vkZygLIzNmjrbauIaC2TNixLWcnDk+8Cpzk8hcnJLs18QD43Nde0tRr/PCI0pIELeTWrKpLAZ73BZxhOsdV964aNgnRW/4zH2mJpwNLmdlLN97Rl6XJtUuOS45LU6O4zl76a9Je+U90kH+NPcgy0KenY9zOJ5Tmdp0oR8xtxND9h2tJqvMYzd0SHGtM5b/uPfVm+5pWTYVE6priJdL1R+pbSHM5I8u8Wtb1v1c1UyknwNIhy4waZvEsEUq5b82jDDeLcGapCEhYG9Nq3JdP9QkFihdROOlIRAhBDjdVMOSud8tULtzTSkn4ZFJbdrVqw5ddVMjHBlbciHQpzCqEUA2DVw3sby3TKmKjYRr/mPiSl1X8DOF/Oe71qIF77wryvv7ylPfUJRvik/h6Up04Tb/xSxp+CaJbRLaN6UXoU2FMvLNbGdeZMWhzAUg7IIV/9GiyFkHz0AO4bbbGX9BzvtxWFB+JqFNSfGKrGZoj4t8No5551TeV3IRZSlgu7uLWYKKlS0esrDbZ7kfpbjHDb3FP9ksFTQnOeSa3geMW5j8Jz2g7hsCQ+KRd6n1BVkIDGWHOZbqTO8uCnWXrrdp3QWuFlDb8oKSsD7HCHVVUm6Hi74H3Rpv3SRjmZ3dj7tHxfnB86XdK5Mmbxh5CUJ2uefd1FZ+Lxpz6NxgLKJ10XwPirEojf/x1sSVz91sdMuKU6d+I0ScoQNC5vlimGIPLJFjBTMTBA4A2hgdTG1EnZFJMocRNA6G+apSWTSbdYKafPgoEkXecxjH1GNGKANcoHNodxQz+zZsKpVdtHoWoEPAmH95EJ6hk1jDErs3zh7pj0hcHkbGQ199j07xaKRm+rMEZIVActz0zdUwRHwnbXTyHvVqu2KU6BTBSP5VyGWKW9Y9aYzhxjPSHzIccIVjLQ2FhnB+Td4rwR2p2iMV04QnXPuz9Lq7cDFHVMJ6yepcHPqqafVOTIfO6eL026phLNDvFBpGD8LUQi0dteUq9xjjzuWwvQScvG8E86ZMnuVU2kdPGl5ro1SjDFnfFeEFPX5L34pzOLDs143r7gpIxLiU05kMcjbS+MoiOEhI4r5Q208W3UZWnquA523kU0ZLwle0JFKUDc39oa85ZtKgUoZxIy/1732rw4oSDPQHQXYx/MseZj9MK85D3Wul/Bu59ePp9h9PI29jPGMs733ngPyxZraI8q2riRBWZchmjUk3fLTurhOsdUzHvvZe3XGl86FOuSe03mYsZPj3i+HSKeeyNP1MtfaDjL6zSuHguz+YciLQirq8VJGXhA280mWeY2H7boT/zQ+io6OUBFuSD/jWUK1eLzqIE/pywkrTUcX+1mM02fMAfRyVeQ/ue15PDsUzDn3Ofek6P9kLfIZn5taxKDb6jyVOR8PtgzWKrO6YRlkVfL03am1i3krJYI3gzRzYQowK/V0fKx0Cbe3S2CYS/6s9CmUADsHxQKUcIkirQNeh69ZnKNE/X5yAS2GeGlVTznxhLrO4R/71OIhj9PJ46BMeAqg5+DttdedKm4qBWToxbPBZ+HrAMYD0QQZaQjcy1uhqFnuoOKqqZv/pLqoqiEmt0V+v8MOq0oQsbwmDkxInXfuLxf/8i+vDTx6xeKQxz22rBkLLVDvHlI8KEaeq3hs5SFWonua8FYRh2srrumavDExVnOrhyfrUOs4czUdVqrNm+TzKGFjl0qEBXjpZReXoD03ikl7M8Hxss5i5boP0sVPIrAw8mwE0BLx5t6eg5IDzfJ8lRnrzeL38QAzdjU6bf5er8mJbFZwMyk78Oc5zD/Pt+C9XJPQsUm9qoRZPFZjA0/zpu+1/70WD7j/A6q8IBgOdOq6005NojcY131LUZSQE1dnfEkHuaYEzs/CpD45RebNNWZh3SN7h3ECHRCvMVbP7IDbqzskjeUF8Qb/4y1vW3wuDM89UxxeOhIvjyIlpyhfn7/4krMi7P6YuVkvKIQC8bcu46EE1lKRELag0o3/bJPFwY95+OKk9EL8aeZdTWI8AM9FWIN0MRhBmq/4P39XxoP0E/ujylkmF3MEYQkGPUnz907Zh4zMnVP2jBBoaz8kq2WCv/tTpOZpBJCHqEo9y9AHT4ZHaiz21rXX/aa6fKyXPMbKM14WR5cP/Os0v/YCG1t7tVfBhQwf6U2MlxF2oFLe5wgQ+2VlXNN1GIPuf/GlZy92323fyttlKDQ5BsKzfmLYO1c3m/33u2fl7yrfdkkM3X1SpnOvPe9Ya+g8FNtzKfCNbcroTd/VSQ8ZhTt7cnoef+ELX1oc9slP1nxBPq7N3gSb2/fIghAFSgnEac+IbVZRhiiNbtfXHvGElKZrzMQRG+atj5XS9bP3oGjgZK9733v/xSFp66fsJFJfx0iX6RLLPN7xRj3jCHCKtJGYlqGEfSm2UqztmY38m799FqrEwFNNqQ2MVsRijBNXR+xbGX6zD3mErkkhNVFtbdtD8nxCefYvw7w7LAW5SAhk88TzefRIqRp/MyQgYEJpSIkFtd9x75ZzJR//WNwD//ZMZMcYBsZArlCe4Fu/dz9ePuU4zov3KDTP2Cksa2PCo3ucI88x/UiFLzz39BVlPLifNDT34YlS3K7p31i+2Lue9eSTT679CP4toufSqze3bRDrhtOdeMqDTkhmndNPPWU1qvvnUrWEZkVWUZ1fRwM3l6h97bXXhzjxhGqRUwzAOqAYX39YU55pDnoHhBufn40xnx16soDzu9/z3iozqPOEajaPeczBGdSGJRRg3bvssnP1e3Sdjm+2F9rFwTuB2YYrwsTSYmJxH3nkUdVsWT3QP4uilTcKktp2223Ky75Vik9jt4JOuy0TGCyti7KAICLtmCgiFtZtks+4YxjBk+5SMZUoR/ebRrAmuUhFxbwl2FPDNwKFZV6WaqwfcCol0PBYILFLryjG2p577rHsKPL7wJanLn6V0oKYszY/djLLmjVno3lmXqPNy0IC7zp75gTca7odDPA3AYihySiSaG6DMARiz7biQU4p2nsf5jrq+XtSbAjr8Twoacpvs1S0EUe7IbV0kdIQRygcG4mnK4VFbHCTjTcreJPHOXT38jQTU12Z/9gCsbt06DMrX5f373mtBZa0KujmlkB0WClDnvYWgW15fLdO4XKWpg5ERW1PdxVQ4+c//5XFW9/6tpp3LwqC8CulkGsWrBUhP0whz125hctXe6OLLtWXXMh7pGm5wyb/lMD+zKc/V/0pO+VJA+gkjgcuf85zn54epo+v1BHP7DxptsBAc9AdUsbbdSH0iLHfijeT3Oj9omQoUfV210s8mPFnPboU4FqSVwveEFGQc7A6l1IdKnHddcntzaAJC3tUYQnzNjVBNWSmPEC8QhCKqZwdxAJh7/IISC/zK1dzr3gTtwv/4Itf+EqNk5JfmaM3Cm8EC2VWMdecGe+5r7PZjc7T0i/KXBWkPXffKzAvDsK11UziTkl/uP2qHco7lOIDnRiZQbmAQ62Z6k3/++U+E9ooZn2+/4XPf37xrve8p+Zu68ix6qBSRVZ6r+EMUHJeIO8xCu2HgRYnTrnSM530lFGCFrcUqUpl2etIT0hsz4yjce8wVSnsa+KRFsIUmHtkozUbiHelIp2ygWudhU7ZESsdL3TeM4a1is85bcNKGON/gogNgtcM1u5c5efJJV2Zd2xthkw05CZnm5HLk4PEUZ47pKAOhaU84BaRW5wJn1OsplokRp4Mr4B+gBzRDRwAOsTvRpE6A+TUhPvMDVk6HqtzjI3se/QEZ4aM8fnqg7p8Fp8bL7yNjybX8ST93jwN0jhFGhpFVRXv2jpvwwmStcHRkcKEOKW61cRmJ4Y6zmHvtUZQhphkDtb55CcOXf3tY45dfP4LaeKaTe4mPiTHcDBlD0pAq3nKY5yNYWCDn88mGw3vM10howlLvMNhUfFKT0meIvKLUlJf/uo3qwj1i1/43IrLiH2CexQTEOdTmN7BIZjdEyTYG6qhn+nmIo3Ci4XN49XN4vIoLaw/sR59+HikKg1RTjbPBYmziGf8BoU+ws/BuDI9+CyGyZ654Mk4cGBo+VEXh2Dx4xQA8HxTDLkK+8cqwz5jGVkMgl6FJFaclAFjxwQm7JxG3lKliSRu6OBTSu65RZS44uXHh5lK+K63bjOFxY0K6suGQPO3MUChlKu0EBaqNBEv1YiUMQQrMwYK98/PjIcp3QfacnDa0+c9hnhR65pxLGOkZaiAXgL9AtquuOLXBcWD58F0O++0axLQ22JHNOOpeBE0Q4yo9wi0Ijm0xU2Z+ax8UKkSrE71Vc8KeWrfxFR32mlVCWiHBJTShBtQ4IZlECCwKQDPYNgmMWdGBrhO6sAb3vDGxLcvKQLXVTkkDplnHu+jY4xLmG4g06WX0EK7oawiXSSWaj/wdil5HVFOTx61/YcpLVa4/z33XzzpSX9RBQMoH8YfaNeagNiVc3O+7JUro3idJ3EggkXj4xYQG9debeiwJmyN8VgGTynSTrWybmK168bzFNu+Lp4oDwtxjGLilSDzVf5mxTSTFhLBp/2fMA6i3uUZxzlBPRQ7acu7yRb+RuLzXARzpTotiSCj6EawWxMKswVkW/i8cN+7a5pO8AxOOPGYwLt7hLeQmtu57u1uK8ywcUojplBExrdvqlnpbkPhQj0K+vNsy9q0+BHea2+xvbZSbkuDepCxjYPiHHXUkYu3v/Nd2fs3lDciZ/rKID47BWYm2MVIqzmFvrGlwLs60MTHmoCzNCQLGuYNdiqMPVxG4dIgQ8YkIxlDT0lK0JOf/KSulBMvX2/Z8Ugpz3mthBFrly3TYuqZVtThdUYcFvde6an73CiQrjwH+u+sCgSxlocpVh8leMklV8T426e6pmBhk+n22bB/q9NU5n8UivE4gzwxCpjxPfmU9h5SFuSL4WT/kkdknPkje6UEtrJKjfWgmPa6CkvG42fphN7noa50QIwDCqpQCGPn/F9eULJhCsgPlD97rrgVy4puE/oaxW2uODGqzll/3vWgQa23eiXGm7Tfsey9rB2DY6oYkeXjNZM/5n2YzfaN39lLqjqtc5d99179y/NPC7y1bUEgBnvzEGW23SZpCqnA799ikAa4RwgSd8vhGIx7XN7xPg1mLIV+2JvHTT6lEr53zEa+S3KKWPHt1SJAXLb49KfTly4kkoMf9bAqyK7coKLvBkwJEf5a6uxSLFZM2SH7dFkuB2pSJQYGJmjFGlngqPKqDv04uXuej3yiTCkq1g6BfH3qkmLkblx9HNMNI7EmRe2xsqqg83JzYLBiuOk6j2EK2mwDQsyic2iNSS6fFB/pBrwscOTWYdSafAQQEBgGJC8B9Aj6ut3Se/p9BK/FFbMqb2IZG2FxjrEi2L8y57SE3TJXrcg1+awiFYQ6DB+cwSjYass0+c372uLNgWRg2Fw8si6GEcjSvLKIkZwqj7UhZYYRhtoDHnBAhH8UTDY9GGa6rrQ13+ziP4Ejl8JvrPDZLz4nb/Gcc84qpcS4UcaPErprquqAzL797e9VUQxC7xEPf0jF0W1gkKQ8PmuvGAc4z7xpQL1r4Lv3BPFQbF1ZScqvy09OYNMolwSSGvHE4Do2Wgcu7zvI5gThSwxQ7LlKm8WwtJ/e/rZ3V3zxTmkh+Mz07PxdhCf28G67KY+3umKv+rrePPeW/kLYSGWKb16CyuG/Y7y/gdi1BjPPxTfoQdQarEwLaWHSieLaoq3r/fx3Y2rnQiEWN0sN1cS5GIbOz/pRiiPcCKzTUuRESGHLeKQE6/Hp0KOMovkVWshGiudxUe1TfT69GGsrhfkog7H6N8p5k8bE6GnkaP4QsBtVLqv4MWb03eLVS71iJCr5eOqpP1ncIlyBfe9219qrxlrVnCrlpYu9D+mwEajmYlS+diEN3S4OKuO5KfWf5Jqv+7fXl2HKoDWnWwmP5PNTnafDCu21MG4n1WM8s1aatTPWQr5lKLYQdpaN4cKUGX3Ewx8WTsXzShDzzq5LCKch+c4hXTlf/1uRDqTr9zzWlRBubry891rod2VMkyItVCfEUHvbex1q26CazeNfMPBwHii9Kkqf8+pZh3xpH/keeeu79oSxDCRMkYI9OSeVuRA5Qmnbk5W2FyifoakO+dRbhyBsmVq6A5m6h/eQfigj8UnrNDDpIJZTrk+nF87B3mFjDzFqIHL7cdqjdZpXQ+L2gLPpPlAtYcOBb63xwMGTRjW6yzUYA645LdbIoSHKVvnZjFlIYmLTxs5ZoqQpYaVM7YvVuyX36zaJ++y8y04VLNcC7CJx0hB0wILijy7Eo7tfUldstqlhO+5z6/n2OggtAz4s+XzfSuHpa666PGSfLeI63796OrY1omD6HyppWIwRWUiLJGQV3VSwR02Mfo0Sfm8bhXrv+9y7yjm156SRchcQbohubV7mTBbs2ouA4QUSeqquYOI26ahhBP0Pb5GSfv4NBnY1CcMUICUlWbkSdS8OMSVwLfo8z9WGNeHG0IHvXtRqJRfhyzL3Xa6/QgeC8LxnkC/IicDYKEqUwmB1s/ZuVGR/SYCgLJrJGu8on+FZjPVfTW5ZsSxWMbPyVFqwOMxdnUQRiMxzrokBu1n15ItFKc83B73goCIVpchGNtR18cwhEijy1qTaEoXFTHlimW6X+DhLc/0czCbSNPmhD38L/mqdlT/NeGxLnvHSMbC2pv0sH/Dbxx4TZXdSExWiYBwkn9k28WdMT8LwqNTyvVk+b1F415p6Y0U66Gj6lLHyj3IbLwpKcKekUyk99qEPfWTxyc98OJ7znQq26TxVq2NM2aOlpHrcfl0x4GUrLv8G/eEDbKXaV4QJAhGjosh4EZA7RygIgbzjHe+pRvH3u19qU0fAqGLE87EvxG2Ra24Xo81BU1JPKzmGgs4uFLJ9wztDAmLl8y5K2Pqv0iw6dkzotyHVJewIK9DmTYHosYkZG6clPICwBP4Ws4V0CCkQhCrJlJcRuFqxhz/c1PFdYYafJq7F6C3YP/usKiVlX0wKySjiOePzd8Ndal1jU7biG4tfuK6L4WuIobn8FQXVyfkVPuLh7JdqVs7FZUEV5H8rmN6F1DequSHcEQJXQp5/qkiXY815md9DA26d+cbYfMOb3lQtIR/wgPvVniOUh+zWApji78pDo6BWQqhrldrEKNsbtrabJYxwTIy8hz7kQdXZZ4cddiiZJDbaBml3gxkjyJytVKr174prNnw7L17pjA3PaW1B+5VEpD5z9q/3mzTYMshz8pJ5pJwQ82Jd7TEyZ+47XtoYDnN/cz/w7xSC8CxdFjVVtrLWfa8mf1Zt9chBRCOylPHCeYAw+Lz7+z7iz0C0nBOFRyblhdKjmMC5yIsUm7PGM564tb3rmYXKKHfjKT7M0tgYj3SM9QkxDpnU83Xoq1PJBnloQ6o9XCjhhCt9fhjEfscAG8ORDJ5c+4q9Qrce8fAHrdYseffdd60JL3c1MIB6kR7GAzqUKhMRyi964QtrIB6i84gaxhv328D9/ovJx/vwh94dSyWFAKKxL01MRH7RP/3j3y4effDBDaWEOYu5CoqTOvD1b3yjevqpRMPSESejzMQVL08vUIJhv3vcM8JxjwicdtNtPAKstqLNJRdResiyFm5PbDpKVIGJdSoF5CfxJn6QRHElCDueE7ZyBJI8TIKOMKeEbkm4xTvfgNJXDek6gXu5df9TjGECmtCh4LzA0RZWbGtTqUMRzBa0Kdq/KmHJY/lR0g/OPef8Il4R3nWgwnqtnLYs2gaBscwL3nL1GV2m6JS3lAftJOFWTEOMYZGuG3i1BLE80Kpwo7ZuIKwcOA3IFaWvTZPxIo9cecXViS9eVs9SDbU3iEeeedgk5I99971Lp+VEid42MCBF7J48BOvVhstayEpQcXVL+SL1eB5vVy/bHGwFGXxa/O+MM39e0D7Dxod0uwdJbn6rLRIv3L8qp2j4/pHUbd0mQpdBx+i6/LIuqv7QsIEf/rCHlWCWjrXlVreJEkmrtzD7dIzZaacdFod+8NDFu9/9vsWd73LnUtqdX9cM0C5amHUqqLnTd1jNZRhUqLTUWOD421desueU78yQFOYo6n2MqVvnvV9eeO7iW4nLq02KUYxQA20588wUeD83BiHYPHtx07QKZKDy7q68Ip5CiqCz5NVrld9KQIADxZ69ivBVbeKMuFGPzk1uBqe0pPJIKKuM/5qgDuL768dCcCZ5lAQBY8Y97B0hhotT1o7gU0rxzF+cE6/58lKw0nq8rG+hCeam6vav9chWCv0hjrQn4w9DJV9Y4p90gx+7RnXSouLJ2GMXxECv/Z6fxYbvmdziLSTCV+/gq0r4g+QIymKa53vGNBW0em5akUBlvEcoNn9iqqLJbdwkJSKPX3z2c4dX2IRBvn7OmnQXYyvClv1YZJM2CCdOOvKsn7fv1Xsd2pO1zH4UVxMrfM3/fVXKqz64UDSkwcoeV5kLYYxXWiz15d8V/pjshrXFGfpZuvF378GugrQ65Rvdr0pzLpXtn6IDbUA7O+ZnKvxQhNXZKnt04opQALKLoiO/7ZH27FsBz5z6zjTKXhkXNG4KRUpWIV6FUiUsU0XebyiPFNro+uKqnVZCwXe1L84RUhnZdUJCbsJjjA/KaxRZeaYZ+2/jQHgWCpbnT4nh7AhZSJm0r+kfSqzXveOV3eqs2d+ew2tCjSBrekltYefAsw+sP3sKguN349map4lHm89BLZoY2L1NPT+Ub52PfPi9q03AJKyCFB1UsbrR9qr9HJ5APgX7+n/7f2sG7uKjSA1mAr5iJf/0z68paJWnQRlQiGfk4D7ykQctXvD859e1EUy8LApYhkehXdO2iUvtkfqnBK2C8HvvvU8VYQcxs855WPvse6fq32hxWMQ8yS4FtpZi/icwyZKaoXVXwctVIk7vuV+mp973im1GkP1ZrnVlrEobc4cIUqcNBn7rbERs14FGMYoJN0nH3cpqnVpYXoIqSyxAChV8jPBj3l3GpQAAIABJREFUM2BGbhbh6dnPyLPpJQlG7i4u3WgafHJdBP9l2YwgM3FOHT3A0t0to3uMViu7xD7UVDUW7F9KFIxY5fkSOyuYrT6vdnFXHvltyELy+eTfik9tnPv/Wcaq1OAOqe7jAGhxJJ/W2nqGJnZ1IfCysKnD4sN0+byGXZQuiwBggVYBgfb0eOUqG/02uWoXXHhBwXyKnks7ESrgQRLC4puEE0MKA/DkH560OOJbx0a5NrxY7a4iWHnM9sVzUlnnPmmrZy5VoroukP80atfV51PpAkOBE8TNRKU8eXrLdIb8xqFV2FtVFIxr/TirCXYGfsABf175iDy6XYPUeLG6xUQJe2vpoBH24uU/S6HtS+PF3j5erLKApyfma0+JsRIUBAq2r/J79i0v34u3C6qv2GAJ3I6N1t4tr76N1BHA1QUFuQRzMYL599n3V4WN6x7Gfnm8O+vWa7duMSmrQXWEJQFyWQp2QHjMMWV1dOroXhWjtUtftndWJKdCFTplZLyWkQdl7RcDPMZVwZcd558mAgNTmsjxugge8kKNa88nJiY8cN+Qc66IkSwmzmi/JLCyea14Fcu/OAidolBxw+WLcVIpWgm3DGQ/io/C8Hnf3zTfPeJbRyxe+7p/r9S9SvXSG5QCLQW5FlmpFJsKcfR+qcYQDOMlGtDeqNAU4/t/Fi95yYsXT3j8IZVqI+2IzGAwqQ082Quu17HdRmPaKFqrTD3OSo/Uvwd5YJfcxIhYKnPXWdm7FJI0c+IaoFYKqGKWOdN+J/w0oTR7baVMLC88sh46BeEBVY5Hai9RZJOySOGByf+YZ2TwIHdRnjxSSovjcXFQuwov5BlXrVrVNdtzToTazgtPALoFbdJiE6GUzrEHrcEosfKic4WuohXFvUT8IEQUt/M3htPAvow5v+tUsi4t6o/ntg6u47P2FFkz1ZlWOn/mvfRexuSZzePE5NcYbkuuhs9pO4mfQSetikGwzic+/oHVbnjTsqv9WAeTL+jfHvRzsexOTo4Qj3TXXbu8UrEfl7UM3cyAe3KuXbz8b/4h/07NRB5lDjAFcvrJP1m86O9eUsxGXtbkLxk0aIiy+vrXv5nSdf+VyiP3KW+LEt4n3tHFl6SqTYLID37IQeUdjqXr+ndKuoyE7Mp7K7hrmSKwhE3WbMyykh34WMraHC3ZvlI0bJRLL7m4ij38MPlwii8MyeLc8y4ouE4OGu9IaTQexNZROJckDobZWlVrIpDEIih0Sg17Ve4ixrAY0q+jwNraDKMyGxWMQfWDBlh55oPBwNMFm7Sy7vy9yy66vOZazElZOArTpsRM/n06ZBC61c2jYqoOXDP4CC6GBusZbKZH50YbRnhnvhk5Ot6vCjNZ7cz1o5j/RLAUbNKuxQj4NT4o57hCSG2pi9VVHDLPjs13adbLnJrr6hiUJ/1ROolc8MvzakMXDT+H3TyaV1WrTko8/apf/WZxl7vtk6T97Rd/93f/WAfAga6SjBHqYqHTQsrhfUr6X0q+diDt46MSStCCz2Gh5Mzj5BGOABsYHJRaubpZhwcd9MAFZEaM9fs/OCGtzdpLVIdYfI2wsV8wXpsp3fHyqryjSHyeWVGC6sGbGKn9DmH5zdXXlmcrLcWY9FrUU5NQs55QArH/m8ozbmRjxjkHuATosq0WaK0s6qxvlXZTizoIi3Pq+vp4Mt7UCy5y1TIOeMqPTskYQ0RLfP60nCPdSq7Ifr0mDGLFDrogeitQln+TvOzJtUnqI/QLBl+m1nTKRTeKZ6YUMlLktSiprP26yukV5LtMM6FE7HmlI7O2EIpNcqZUvlLxTBwa8cznEQ0HGoTeTMioSFURau0trvWmWtF06y9niXchre/a316zeOOb31phJgb9Njk39qnwBwHcxkp7qJ6bd9NG1/I3/Yh1Rn2fIaca2xve+IZCbyhWQpnS9xks6sl5VzfZ/rs8csJeoYCGyetuc95mzWv9x+DTqk8jjWX+bgv7tU3Ai6QYWNcajedVhg+It3gKKWqhM45avPnPmtl35C3lb7zDSkUsozyNo5GMLgQ/ZCNz4vdS8nT50iMX8fIXmQs11zkLag1cFq+ODrB2SnGKrbqHEJczL05e/UfVLc8+Gjbv5HlSwEMkQhQjXRhYsiyEn8Qkyc6JkxZKt5zHzm5oOTokWM/k/lU9TTgr8zeG5sSHh3Rmv/h50Km5trkY1rr78kKN17XJCAjKOod+4B2reZwSuIu9lQtZCF8W8GWBeRBNdj/1qc+kNu5+i7845JA1+WbTVs3nJ36ENPD2d7xj8d+HfXaxY2DajTdJZ4DLr6rN9Xd/97JKXNbWiYJoS7MZkhTp2WefufjX172hJhPhhJWz556ppRpF8NGPfjQ9SndZvOyv/zoe22WVEmHb6dyCQPHnaXXEA/CqYHoWa21OZD4JBgj0q3fm2vdYnOAnZIvOeyJYwTS8iqvjoSOWYMs6+OKWYiAOICYgq3+jIirFq4vwt9kUmVAnshRffu9wqsjEq5y4jNP7R826Y3HKLy2GZ+VHyasKDJg+lBemohQLarNbbF41QW3GEbTX/qbjdWAIMTHejziznDIvB4YXykreLnNiXkCLnQe8RdXmrbzQJWO3LfBlfGZZAm3N4WaR139d7ackD8FSgbD2kM0b+BZjseoTB2qkfHjnxexDVqr0n99V3V9es96WrGj3kYJhE9ukDJB9s/YvecnLQxyI4s0zivt6Efjit+6HrLZ1coNfkOIZ9twxKecI0bCHxdgoHGNY+SoYppy+vpfXve59z5Bg9q29Yr+dkuIOmn4/4AH3K2FMQTuIWy1reNqrt0hJzbKclwbh5rk/ZXfWWWdUmoC5dSaO+97xtf9vE6asDjuYrIwapI6GrhI7jyJtgdqxWpPbaQ19Dru7S3tjnof37L41nzlHCjBQDLxrucP2HcO0ITuJ+OnGFIbumWedGSj64vI8blTIoXLv/tiKg2eZiVk37HBzpL4yz00MnTzo+Gd7UwMNDhpVStLZWsKPoMjqoALBWSJBs2/tR9er3M6sqVCLtfP9nZJwf8hjH1fejUpTlLM0sCpKkT9kjdxxBee7E1K3BBsvq2DKnKmZrxkrbgLD/ROf/OziCyneQLnvknsxPOTLTjx/ZFH3Sl4iWwV/9rOXoZuzhlWO9PaGN7yhSIoQEfMsLqmqzxmnh9Gtr3DGtu/e+5bx34zz1ZVjXOuYXGqOQs3P8hlGcDdT2jnLmWRAlUHbRLghWK71cpsr0Q5PK4rJ2//fnu6s4TTLnqpD9sFApPY6foL9rgKW/W8/tbMTNnoMRj/fJp2LpBZ++9jvLO4bp4ei+0WK9wxELnf/dzlfxXrFis7cOTcUrKYFmLvD95hmJlOjvMJjjNXIw9lrlKTz1vF+RfWvr3F5TcxylP/kx86+mmv4ThuAXYBnZTpeIThLdMI6z3uTSjN7bHLof/rTn9aci/nX3L3uNa9cDaIR/J2WWGMlmLANUnWFhXv66aelpdmhsQquD9X78amxefc6zG7oQjMI32nX+HeLQw/92OJbR3x5ceO1sd43XW/xrOc+b3HwwY+qfDmVeIaFZ+N4eCxMG4Yi/VkKGrz0pS+Klf/zgjblKH78sE+G+HTC4qlPffziYQnyExagPukyKNOU7arb7xi4cK94WruXMrF4rK+GfaMuM2EF8CnJBa6URhAvsWAesCTGb8FcZYIW1Jh5D2R2aYTsxYEff1lwM6VGuYJOKDte8qZRxITk1YF7vSe4r1LMlKDaLN6U+Ar4GJSNTq5t3UZJ+L/wwl9WOos1YOUMW8z83jLsyQuSxP7zQKKEHNj9umu664P4LUY0FvEfbhKruE31g908MVFVXqqlXBQnxbJeIMSGYXnB6uh2NLCk0RJGVBl+nTA/q45oKU6kFxV++mCDRsmYKibO28jcXRklePY5XVVJYQP3QGM39ssTg10bT7t5dXlBKmPREYxK1FGSIM8NCuLcKHWUTymG91FHH7P4ypfTii8WbwPFciubKFDF87OWCq37TtHRo7w9i72MpKI7zySp01KTygESVEnoxBRYOOQvHhsi0V8svhEk5Etf+urioQ89qATDjrGMpzUThWfOldS7NPVorc2tMqcIYsbisNlnfm8PXxwDCHPQOQIzCwloM1bMx1xHOpcDzcsahWPPEYITyx0h2K221sbIhCb+GAWg+AUjbPVqBei1wOti3xTmCMyJ+SnhJjavSfeR3zqqQwzxhJ/6tKdWPvdJJ560uH1gT0jOlI0rMtOS0dmeXns9dd4pzqAP9v2kE5FyiHGdyrWsmRoDoWJ+k6+8hIxLmaoKFG9Nms35559b55ih92dRegcddFCg3jtV+hIIF9zX1dN0qNkk38m5zt5XJ3aMInu6CndgzmesrVDaUFd2lAG21x3vXB1rPnjoR8pQ3muvO5YyYNA2bN2GZFVyWr5KyRbpp+ORUIwR2Jj/PD8OgffB6GKbE2aqYi0xpJ/0xCcVWU3xGOdnSGaF8tSZWlG3uXY55bq8r6pHK6D9IR/13+19l2LOXvesRT6KzBkYfpSzvdD55l23dxQJI5ccmdoA9nxlM+Q8aYvW1+z1L0JlMbI16rhFzvzZlWK1X1oQVsnAeKcMddkC48WN8cVgct6RVxtx60p3rl3pjsuY7tSmnrQVIRAK8PjqWMVZuk/JZ/wIYx8FN9yFqXJkrH6mZJ1PCtgzNLzfxCLXgY6VPFwStXq/dvhnEMsmkrbnO/HkCWsaRyFv73/vW1d7eB8wiYMNe8hqS5TNyNoWK/rwhz+2eN8HP7I4OHHOJz7hiQV52Txu7KaDRxMqlbMVyOPzn/9SihxfX7VmHxLLDEuv+2s2dbsH2ItlcB72He98b2CxIxcHPeiBuc/jImTPD4R1RfL3vlib9JDHPbK8WvcGp/pbn0XsTfmWrHKThD6tNY+4n3uABwe+acLM8l/LXPw+LA3zjDdWNOkIr/IWlhaL9x0CqRvN9OocUFYyL8hG4XGAcHk4lEbBuBGKDAiQF+Ykb3CTYiiGYh7vuiCw8pqRlTYtpSveyPOr/EhwVZTwxhEkLEYWnPiqg7llWHLyEEF3Y12Bwoyb0PKsncO5ttjCkC3KLq4+hXWka8MUvLTMY/NeeR15l6AkwBycK/P8UifMpQpOIO5jQ7sXPwPTCfD/4sxzoji2rhJ+x4fgtcsuO6ZC1tNySLsIAOhRDigv/ocnnVIHWrunvVP55vd/uD7G2Mer1jHQgOIYQ8B3bXrzU6EJ3U5yX7BRw34Nkc5r9hkBZZ1Yqzx493vmM55eh5mV/KIXvzBtwHau8/CLdIdxWO+c+N36S1iIMUUB3jwClcCtvLzc38G3HtZleteCsUFRBAtFrHD8LcP23CMIi++BhKcrkbOjM8pApY1cNA7wu3igzY5MAYiqShMUIzFn+855MUaoBtLRxDR7bruUnH3tbOMD/FZBkHjyNwuK8OQnP3HxgUM/vPhxekfuEMjNWQf9mzuxLeffNUYhl2XPyLRHMzaWvT3Wr94fQgamHRnKZ4Y5v+as20cxwroMZropRTHqkWsOeY0M0B1DFlP5iPG8QeZJEQmCvQgkrpl5uNXS6DYXa/KWy3tOPL+EPoivu5d4Fn8jhyEUnpLQzTtT8P4XqQC1U4oNIPiVmZZxFxdgFGm7u6VgV5KdrBtl1U2185y1F9VNXq/CFMZZDHW53plDz/kvr35V7tWxdnXBu8dxe+xlnI4HXBvbYAiihnZXepatIAchaIh84N753Pw9Xh0PtDIlIl+tJVlSK7ZUkn4m9xnC9rBYqPcmRulnz2GNdLkyVkZE1Y3O9zTMcI/TQ/hTyEP1KL/XK3ZqJCvx55mlDjJsKD5Kkmz0WXuYUjP28RzlsXIqIKLSGMmTh6YVJHmuPy1eAoKR5/R9Z7rrFnT9AnueLqJIjZ8RC+2jSKcgBK98lOPEtc3VeKITsqwYdK5lLugp59xnpk1nlQh0eBxAsIUPqsOp9JWfsVrdePvtbl8EkU9/5jOBEX9efS+f8+xnVDpKtxLqFlJuaMINUDzLrgDj8V4LdikLqgVcd2tvworvTeGG//iPdy6++73v1SE84IAHLv76r15SVuv7PvCBMPw2TwrNk7OZbqzcNMrs4izGRYFS1bjcOm3BWOUsdhOjKLyctGc+4xlZuHQHyCQ1lNH1IyWz+/nmqSjTyFQr1/qJ/kGaWSZKe4vFqZWSJxhBNXAtRWuTEogcP4pSnJPVCwM1x+LHUlyc0fF8hx22EuYxl2OFGwtv0gISGsUKDAvZ/VQFEvelJGvMhbZSiIgSYlXL6W7N0ge2BHSdpKXl24p0cbO2zHE6SvHkPhspyh8m6A3xvtQnVsIQ2/m8c88uRXNNql495jGPScrJnVJR6jNFkiKMtk4O5vbZI1/75pFpxnxGIwOBhbQ6w9p+9atfGePnvFzvkqpTKnWDt79xitj/NsbGfVKhaL0826tf/ZqapynSXcOe9bEGBHrmymsEvt81cWbSW8Yb7XxfHpqiCFdfc1EMnttWz0Ss3L1SaYf3WQSgzPNZgUIpv72DcOyQOHJX/rmwkIYtkqZFMBXBJ1apg+W79hZBMDnKZ531iz4PeV9YgFHAMB3oCLQ7tWYrtpd4fRtAYukFihR0qD6uJQHdN8zYStTZYrBeclEba+LOIF5z4QW+NPfq3NoCtwuhCiLw/RNPrn0pVxRRbQwN3jMlQPkM4lReGoiOIl0y1K2Cz95s2RWoFU4bOpVqxCits596yhXSQCAhiDrEsm72bNVZZvyAXkM8dJaNlQBftcOqkjFaskE3IAwUlb3gdcsgOmLExmM3U8zuj93dhlQXBuh4V+dX/i7nkpLcftVOleP7pjf95+K4bx6x2Gv/e7YHWwn3mKhtQHim/+2RtvJRqL2LG3RTBKGiLq/ZaXV9xswBw4IhIBf+b1728mXZzHiEMVrLUKriGyt3tUNsk7cirXldyp/JFW8npCLNazzPQS089xiQwzKFLDCAzF139mkDo4zjpVFk33IKOFDDSkcA9HL2wLRilgin9pwyk8pnKhWoapX7cibMt+/7u0I92Ude+ByXxFB1Tyx1is38jSKTXtjpb5jdF6xhbvu3MbX8yHc8Q8Zf+yrjcj3P1alNDdd6jcc458C9GrK9WfXe5nRMtaRxAudMDplpPNKRLc6xF0NjENiuTRzD8vGPe/jq/e9172ZRBr/W3NTPBITBmnAKwCBBLJTsxz9+WJXF2jcdLl72spfWg0wpqlnEwZI9tPdNQrZ2QSNTH3GUFkiJ9QYW9RBveON/hiJ9cnD3zeL1brd45StfGYX+m2JyOoA8GDE3LbouzkJeUX1Dz6tr3+Nu+yVu2M3GJdTriCKGJI2CwBBHJSQ3S9zIAa+G3GtiLmITU9JrGQosRd9aqqCYCmhESPDsQrQpaHRpCNSilnDBZOxE+WGQ1QGsTd6Hc42+XmqFeo9n3rkjNQ9Ne18qbBvEZwaa9f4ydlX+4zK9w3enL2gzmJceJgHW57LSYbov9dpnK49Vy7T8XueOdcG7se7lal6WTU74/iRkml+ef2F7BxFiIHeQ4YFpj/W97x23eP3/+9fFXne+S6XXbLPdNouHpcvKF7/8tcVHPvbJVEBitYoF37xizw9PEvvznvucSvFQMOK4fF84gKVrrli15uJ1r3t9PSflV4ngRr1ck/m75E6t0NpX78MuCWj9WKNTsg70ClLUmWT3dKwQv1ZFCzHj858/PHWfH1bM2wtzoEFCBIMcuS6592dVLFyBDULX3rLXp1bowEh+5xmgCEIBM+5K9M6fyTOs1JFJeQnhr6tBTVy3+5m4RpOVOk4s7YVRUkSqrDsGNiFoH/PqxJQ3zjghGhTHMalcdnlISLtWUZONqwXhaQmdNLsb21sMq5Vgs4IbFnN25zyvjMP1LHdcrohcS8Oleb7eWWuMVnpM1hxiMM0A6jNZk5qLpdEgpthEId1sri9GN8H63e98N6GcpyzulSYDagPLO0f4USTDfGy1VaqIbQbKT7w7+7oY5rnGKNJJCRkBW3OYVKWdUmlMpa43vfkti09/9r+ThnO3jHoZN18anf0w45E2gjXGdp/L7lBkn05VH4aBeWyCWBPS5J3vs/edQ9R8QZWgYxRUmhpoqqZqrN2lAVv3JyOkTi1Z5isKOzSZkpEgjQMauAxFuVIRqBqGRc4xD9Axzw2JsN+m3u3Ij4EzxwuzZhTRwMNkt4wCr0YcKKPbVOUjyBLejHtRcsJo7jWKGjGoeS6quilMkjKDqUg2CryJSL+uMY0ROsaSz+CA8Frtbz8zWhFQhXvId/UNvKZSnT01usjPQ0oqdNU5ylnkUFkXBu8oza7i1znPK6HckShDjIU8uaa9ObFUOcvrxMNb/YpXvLyFaF7g0G7DtDwutZG6fiarervtVpWb/bk0jAbbqW36d3/7VwW5eoDp4zaHfiXMQD50RZCBVcEUuh9kU8RaHbbYm9/89hSK/2GE1yZJrt5i8Y//8PcF7WGg/jh9HcVRbr9DugDk4eXIYYddDXLIxtznTvtWp3eJ/OJgmq6uWrVDoLuzQzb4dB1CFTawGkGiDpTAeN8b3b8p5U1VH/JHH/xKCWClchPqALR1ysNkBYOplmqyrc0lQ7iOCri4rD8WeecHjnIdz6kP6lIY/a+/W4m3Uh1rqDyFsYKXNVnnujW6+l1DtPXvKhjhHitaNpXm7by+un4+AwK/PCkdp5yUggKhrXPNz8rfNyRefJeQgDYKfFqeSb4qHny7WJjuAxqVyiQ/WCNt8PunP/OFxSc+8MHFnqlX6+Ahi3hZt1U7bL948YufX+tzXjrZsLxvyJr+PDmYu+yycwmcQ1NYgeeEYDT5wgWl1VgnTaT36v9WsraZBGyC4YrAQnpEUoTqzD7i4Y+s/qjq3WKwEjAXRkEiyXmWhz/0IQUzXp3k8Tveca/FlvFAWePi8CArhQukE01awMSEHEYQFKiJkeGAj8CaNaRImyDRxdpr3quMXOexdu/K9kT89ubrJwc03ASwGuXtdfHFF5Sik0epeIo0HzHHH//0J+WF6tTEKHHvYas6d5ddeuXixpz1G+UoYnXnXDe5o9ns9KIzwBtdqUjH2l+rWLtTT++rJnBV3Fp+cwXU/bubciOj3SjnNff3bIxhhrNzT4nPy/gYFcI/VWxiWYlKcv/DkzuMpIbIBhVBSLKWm4Qkuc1WYcVXAf0oEHHDnF3rwUuUAjVVbWpMeUChCOgAr9c+/uBHPr5497veu7jbPe4ST3ezSsPrPMsO9YB75pnmrHZeKWN5bfys5mIZR/azebXnH/SgAxf3T//TuyTMhAAoFFXFXKppxlqDfc1E/P94pJCwUdAUabNTu43leJajEDtdLcZQnh2hSyaA51Wur2Pz7VF5rdmb+fd4XCvRsOLJRGaLcXI6pLJU7D8IiHKTWk1CWchlNXnHQGJg8CwbEv5dEd6cc8pc0waMeqiNeVYk3gtkC471bJPPumpVd28RevGe14TAENCs7dS/HeU8it9zDoFpDEFr6kyOYTVzOuUAqyPSstj+FGAZz9RnQbnuuU/CPT8Kl+PYb39n8dV0IFtnn733WP2oRz0iD7l9ET7UUC0SyJIksxJepFzESm+dVl7vD/HoS1/5crUTe+ITHr949KMPzuReWJaI7w/hoazWZfx0lASItzdAKyjXtWBVLzb3feOb3paE/VNChd86TL5dQm56Uj08K/yb3/xmEToofIUiMCTl73lIifxb3W6bqrMIgv7yV44ouE0RCBRl5dAEyHmi7gP+5HHwxO9+t7slEL1j94RcpvW4psM4bNYhIxByBY6WW1cRjop7grn8up+LcCEkOlfN78rCq+82uaneW3qqk/hd0MyaE7XW+xrCQRE+loeg5rgEmbhqs2rb4+wx/M/qCMfyOpddLdYRR6QA+/DxAsoyq6ohrrVuoRHfTys5rMktQ1ZiBWLxiSO5mfQNngMrsxr45oDvF+KZdI9K9F8W9qfEbeSjU/3lk5/8TAlsh8nBrjgvYkwgL4dADdv73e9+1UsTbHxV4ilyQt3n8MM/Xx6gwg4rPdESVIyapcHRgrtnbvwhljgPDTEMD8D6yp/cPcng+9z5zhVP9X3ohNxkDQPc/7jjjk/zg28t7po0HGzn7dNc4YAH3C+QrJzo67PnUsw7ytLzGf+QO3zO/pH+oACHszBVWDotqdcWuY+gkB9JcWBmrkQH1oY8lvBfnuu3SeFQ9s+9ushFs8c9G0OJYejaV8Q7hSBBlJChvIQ6nEOKWCUjUPg6vAd9O5cdbNhRGLpmjyGJqOOMlgG5hP8o21Gec75biS6LcyzXohVyd61pBdwtyIb92oKpawLbnxS/z0zqzHT4INxGMYsxa8VGoXo+awWlcL7bgwoqEFnEsMQ4rvSWKG/rX9yHzJFatMOMJzswdsGSmwem/PBHPhrv9G3l6YjJUTzOWRGWlh5mA0m959qg6Agnj3KqT7kP48Db5g/a8qADHpTGB3ftcn3CAYEhrX1XOmpF6jVzWb+oNyxHvzlrsEZZrulhupYP0CVKu1WYe1dsMGcbs9jZlPeoqhDCltzlKi6z3JeTr2kMPC6en65F2wZZmlKlSoIyVMib09Pf2HMKi4hVKod655ypUWzWi3LVBUlqDJ5AE+pixMX4cz+eJtSGwlX5SN/iITVRhmKwKu0p3sCAqnhkedyNmPjsSubuFKAAE5sviplB6zWdvOzDIQa6zsROp3qTz07FJe/5LH02egyELLcfaerb3/724t///Y0VF1/nWc98fPEb7n//+xUMqrellmOVa7TEsQ1qYiNurkKPmrcf+vChixNS4k3LrBe96AWVXE8QDQw8eTkr4aEWhkM5701SKScERCb/5z8/Y/GWt759ce5Pz1jsuu+ei2c/61lVj1SXCtDttfGAOnG44YorkmDOc3CIWHga/kpD+dZRRwXS+k4dJP0eXxGv2aEqn6LiAAAgAElEQVSQdwdugPerG6zWLXiAt3HbWPAOFtze81pkpKku2ScO04KlzlDFL/oYFURTe34s81KR+T2ltTx0CDt1Wvp/Gqe3d7g8L0sIsi3etdBYeZ8EwVJJzIGrw0WI5W8MXCOhyNfNH0xCV70xc8G74JVV/PAmrOD0MYwxQZhSfiCNK359eSDKc8sDskFPOvH4+t5Tn/KkElo2pA37izPPiDdweTz5W1RruCsydyee+IMo2m0KYuMJSKVqJe0g58DkAP93Ogud+pMTF9veftdSyJQ5CMx6XxS4TirOM0L4kSqjJrC998lPfGLZeSh1ddUuzXOt7Xm79ETXCO5lQfflnFRYIWNQYQX5hOf5oAMfFGMxvXSjDBliVe0qypqQNYYtknrFWuZBONTn5RDf5773SqOBPao5AQhXzE4HGE2BHdApquDgOqh3SulC6VIEGs9DgQ/C23ras+ZlBAUFe6swZ2s9kbpq/1j7zo3sGO+kZiF7pPh2BKSuG5ouSNVC5GBEQlmQkKpuctbeWoldyfdTIYsQ0nJLeg7jpO4lrs6ryTWbJhTCSa73B4oHCrWMsc5OnPjRyPgR+qNEK7QAvs2zVM1uRuMSduySnZoZdApIr2PrCkoKMWkUaQkyaXhRttWkQdUlTOH8ByLfP2UFn569wqvxXIScPcNT532UrHGPPJ/cZXPp+uQLZKP/KBWXMeZeZMJuYfiL233u8C+mtOSHiq1MhiAyludWz9bl+vpstgHdLwd4EJ9eM6ERqBPuCALX85/7/DDB71W9kX8XQ6zPf/9hVPHU6zwvu91U6KiUdFnfS+g8Z6qqOC0NspKja2VFoVulSKFNw0IOBwQ/I7JHZSPV4SAo3VYx/Y4rDt7twJxFf7smRcIQcxYYL4o1QDXkVFvTc2LEyAw45JDHFentJ0mTcV+KlpHASLa/i0CWPTUyq2L64ppZS0aoc+McGTu4FhHJz8bHwamWitnP1qo5B133ltyb1LUJnbmHM+bf6rXfPt2/pvg+L3NISFBNn/M7e2d6R9s74zyOvjJeZ8RnxzCxn846+7xKf/pOUn/e+PrXLPa4Y+rPf+oTH1z9d6/458XTklJCwFyRWAoWlgsPbrzW6mw4YLxOF/+PN79j8c1vHR3o4l6Lv/rLFxduLS+IIprGrjORRSte47GtLcnlet3nc4OUdXt/Euq/kWA24saNi9e+5h8qPqW0mGII4pyXXnZlbYDtYi0hqBAY0ir6FTJJIB+dX4745rdysNeJx/Ps5KPtnmtcWLEmhB/W+a4771bpIqrtgMYUN9Ay7qLAZuBKpeaKpJDNgDiDGTv0705cb/r/OmC5Ok/LA1YQKuHUB7BilVGcrW+XB29M0eWBcnimgsn/hneX36oDO57ABNrLQi2iRVdg4e3f+Dv5f/9TsTjeH0KPQ8EjROj6TSrhWDsW/0mBVSRVU2zes+48Lu2mHnjA/eswUMTvfPehi1NSt5SOJiwf9YiHp/bxveqz8nivzQbVe/KKWLJdo/imEvrbbb9jYPajkl/3w8xh6pFmrQt6y1xgLjOOpJTo7CO2vf+99qsmAz9LjHzTFP5X4J/13JbzGubU8nA2e9S0lqeeZxAfu/Tyc/K7TaowwiMe/ohulpC9ZX9BU4q9WEK+S4Ah87i/WE2zPK+Lt3165YgpEGDM3/zGN8vyfvGLXlT727zb3yx31uzu2V/gYS+H1YFGRPCyNsccc3QJqLvd7e6V/+o7oFeVuW7MPu/PrRWEK41PY2IQKO5hrk4PcUg7QEanl5aBnoMnBrIFeTJi5PXxPngRSmIyNBVesfVuyDV5bXAI99IVCJpQNZ9XeEizF0cGtCE5kG6XAKwUGEZC7i89aQrl24tD+jJO8XGCsb0fBV2atcuDb/ZpF1oAHzK21JClBGcMDAkpUsor3nO/e9Qcgxx5RnJLq8CFajyRY5Q5QtYNKVbiGubQs1HMPDH7xedB2IwLiNduu+21+M73vpviDW+pjkRbJw4GQbHtJtY+529pEZeiHp3axKMmWNG/Z/7op4vHPe0pixcGcbFG7q2i2hSM2Cwy6383+26FuGxgXjT7SJFl6cCBdJeCrv4a1m7JiKVipUgbYk2t4jyH81noWvbI7Ev7Q7huYFRzMYpkihkUGSgKESNX2KaKEuS5rvkNdGnzisUzPoXYXNc9hw3ru7xQslMVK+dYZbCKNUY2kTUUVEPUejp3HQPeKSXsj98dEbKitoS8VeTSW0YHcG6MZbxfxoHP67BFZ3VN3S7X6vdFlsrvmpfQDF/vDXI68zYw78ylZxlEVqjB/uSAMAB897AY+1/+1GcXe8a4W+dHJx+3+oUvenFiifdItY57h9Dzw4K+fNDNSw1kEcqCW56wsSoVDTjjjF8s3vyfb4ug/MnikWnO/bKX/XUJqHGJB/YaeLcExuqOQTbJp1vTUFznhAn6qle9Nl5jqvGERSvp9/X//i+BGr9fbFiQLdYZQS4eRBn8KN6BgyyuoiQY6Jnb/cM8x9//1d8unvPXLyzYtmr35sAp7n36z+M15z+KS5k9VpfUmarmFIEyzEFFAi5O/iaBQyH5nHmZYLY+nSw+kPKmmybWFtIDajtlC6Yahu3NCuJlRCASRRDZ8CXAZvPn7bw3CzoQ5kBIaw9IGx8TE7kxAoLwc5LdC/yHjXhDemParKwtm873WZigMA3HlZEDRxAip2f9doilzEi5WVKHGBqn/PCUEnDPftYzS+h9I0rkwx/54GLDjZOPmsOBJXp1KvbcMV1PDoyyPfmUk+O53SHs1jtFiGqsjJiTIuopBXZJ6uPKXazWa7vtGJLSJqXwq6h6ri1+ZnNbV7WGxVNAUX2Yu32bMVSptRWe+vgE4LciQOQ/eW/mnSGo+pbi9qxowqDgeuW/MjaeWwPrffBd/7ik7UwLPPP2/e/HKw/0fXX24t2yf85Juz8dfR6cHEcHyWvWwRwTDISafFGH9Px4tN6/TRS3Nft5CmqAywkE+3NiMoT+FDVpjxEjc63XQbmKdVX6RkhRvKWLIlA2SZEHKV/2NeubQiMgpAhZZy+9fr223Wa75E9+veaA5a/MGxldKWDmDxkoY75+WeXJexWqWHooK5XpPHcLcykwaxuP4w6shHwHjlzDnFwWaShWrz0blEEMVSqVcwEF6ZrPSEhBl3hWy3QtBhIlNV2dtMd76Uv/quQSItxNUeKMcfLG/fZMIQfzeuWvQk7Rz7Su34zgYZLyYnVgUofXmPbca+9AsPstvnHE0VW1SCnFHXaIFxnEC4ejvPQlMjTQbp3rMi7A2w1ZN9GyUYh/+sd/jNLfP9WbYqRHAWm1aD7JC1XKqt3ess7xwOhz3qV2ubZwgnMODhYTLjaycqZBVMhP709rwpYZ7TXb1+B/VeGG1coTNDa9Sn3GGg3Bxv4Z1i0lRi4jBroH9KXaYGbOGEBKyVYxF97zMv+WIWuOfJ7C8fMvk9/POK8c4WXqFh6A+7jvpJJMecJhwUM5yRHGoDXz78l5FbKpAvf5vXExbO3tHRJ2UhTD/SZ/1Fn1Hri+ve0N1yBD5Pjkr44eGoIVw4ATMcq1U444KjetIcv+2+vfGE/9qNKd63z/uKNWf+ELn18ce+z3ylUX2xHc13fUYadMDcSkjuBwhAaf3ip0+h+c8IPF2976nsVPYyk/5uCHL/7yJS+qTTyLZ9LGRS74IJDLKFH/liZzXSCCd7/7A4tjv/O9CDuknXUXr/yHl1ceEep+kwSaPSyeu2EE13fClqogdyZwt93uUJY4bF4sjKegismf3/c+VTXnjKRq3DOHZNNbbLz4RuKsFt9GVVBBfiv48AMfOLRw/kenaISJtQkcXlWfxADOSA9KuUr65lkUOYI2tPZvG0Tx//G3PXeC+yBNY8TYM+abp2PK9vHONk0sS/oEq07BAB4J4e/5tD6bnLCCQTLnKokYy61TGYelrnUWtuYFGY8EaC3R7rD7HSrdhCC0+VjJFGYH9cUloxACuZKeLGPwN69c5aRzzjm3oNstYy1edMkFJczERLeK0ihSQg7NlYnD/du/vymH5zdV7ACT14sQ3zA5togHz3zGE1Lx6nGVJmWDq0Fs/2gz5e+jjj42yuoHi0cd/LBij34t5fN+HiWuQbZYXXWxaYSr15rlKgbM45yY8BqSWntR8nRLYSR/7da3QWbYMRDafSvVoHLKlhT5DUJOg2QME9Hc+i4Ba85Y7sclLmzcDnvVRU689jvf/c7i6KO+k0MsaXudCn8859nPrn3tgDr8lDXvHYEEnGtfTDwFEjBJ4YQaEtKJSTuxfylTip9G3y5KwRgIKJ4QYVvoTV7lKcRg4lXcOmvZcV2eSMoB5qwyVpyh3cI+JsDNt+/6nXJtV2WsYD1nhVBV/OKPeV+szv2EK1Sa8ftqVlH8hYZfV5LaRin2CrUS9WIEFUpTyADW7Nq2hpRewdn6Zi6bSQykO1fx77pGxRT7mbtub8OkNZ9Lz9VzUTyUxq8TVnDWnv/855ZhZ70UIPHcF6SkJwW81x13L5mguEST8jolxvrVE+SmlOUvk+/LOyTYpQDuvfdd00P1B4u3vvM9KQd4dkrg7bKMd6ak4Yr92Mq0QzZddKJ2bxn1551/1uLpT3tGVYGDJJTyildTRe+DVLiPZ2MkTY5thWkqxptWjPHgbkhd7OsTY/TchL5CHpATqVDFeJ6YY84Kz8t4ityT76hLzYuCvDF27FV/qixmzj5oF/PWNayt9yixUazjLbqvzwy0SZH63Zlnnhuoerucu9vUOcMZmJi6swDedQYvCL/BuKR8bRcPFt/hnECjnn/yVM0DJTl9nO3jyg3PXDmP7keGeGbMYH+DfsX+FbF3H+EWZQ6x7a2j5yALXdfPlKtr3ir1fifLxDPTU+aBU1GGTBmbzsHaIiRDyOLA+Zncts+0avxGOBy7xnBf50tf+NRqN/7nf351tZ8Sp5Iw+5jHHFwTwG32ZQu10mIaqGfKdh15xFGJmYZhGcH+iKQPHHLIY2vwJqFK62WR3KdqNyYHdCAAsYlrr706cdF3BNL7YQT6Fmn4++uUh3tWWJ/37rzLbBR4edXYjVcp7nB+rFDK7ceBTyiHpz31qXWgxG4Lr88E+R5h38Xlf1OpDrdIQvyJgQ5PDyzGU4HZw7u3227rlPx66+KYGBR32mv3xXOf86zygMVhqq1TFoVydk0HHnxpceHwBNIlYfqtc2M6uEeBCpLr7uK9jXSvyOG9eeK0u+22e+Cirase6xVXXlXpCdq1UZg2g+uDYFHJHX5eIiVdeVnKqWWzFgQthqHMGygtUIu4HK9Z9xHx3xNTqYYnDVkAcZ0XwVIkkeCpqN8gTs9xy8CDV8ZTJAl467rAEAYPDxzK0z41NVlX7bAq76+7+Jf/+7qqs4kRTZGOkFX0/qJY9ZtussHiNa95dbz/u1eFnJunBJqYzvkRUub/Z8klfee73pU1XJ10hicm5njO4itf/XqMgJ1LmHVh8E7XGYt89hvCF2uX8dM6ta1/AkMhgv1Cv8e+lkcspgm96BSdzvVjQEyu5PQmNY/g6GGXT09O92TVslyty0c/9tFSrN3Ldr3FW97yxlpvMVT7TIUvsc72alKDOR4pD4FwFDNiHEnN8kKZdz8xeYrUvgKZdYu99asykb1CkRL4w01gaKhe5Nk72b87hRCQxx9/Qp0v8XzJ5qcFfl4/Xv5vEk/8xS/OLM9HE+8f/vBHrRyXMGxBuvlPfN25Ur9ZNxXUuTFYO5w/BdabMPSn8cEmslWNXnnTlIxQh/2ERVvGUQhugWORquwHe3Yg8C6m0IKRAjafXRuYsd15mG2YNMrBS21joOvHkk04HU9OpbVbx8C76MILak6322bbPPtZJQ90tVJdiBeKGOee4D/XdQbAvOedp7LSdeXdbJM43dZbbx9FtsniF2GKvu+970uo6Zup971PrSEhWwq0nrUVqX3Zwjax8VT8cb4Zdm+MV7tzGkFU6CJrykDFB3BvIZCuIrRVyQHzwmCyttbRvPw8xrAwxJZhf2OcK9kHZdBS0v6hiBha2tKRk60gpEjdVHme54YJX+c8Mo9c8fMQaRjMGyd+7ty7J/lsXGS2V5PVOp+WYitUiGGb9SHTzZdwV3Vmyjh4hWWgLvM4oYPGo2ToFKaH7PiMPsFk46SyQANB686Z10Me8pCqZHRuMgXI9ol91/sZ47RXm/E1RJ99kT+uM7FSMtWr93PzRmpv5lmGAewzZXwFUqZonSPGqhBnQeH25tKo5xgNWW3D7LNvpyTp//unVy12TP75Ood97H2reXOHJ3/utNN+Vm2okI6mB+UUAzfYUZ5ld2WCR7PzXECqr/g//7Q4JpvutrffenG/sDAPeMD9yyW3uYdl1ZDuH4qwgklmwJ8Kzgz+0xdVtZm9M7AXvOB55UZTKIQY9hlMH9YuSR54oWPJO97xrrKy/uqvXlweBq+psPy8yqPLoXF/m0Q/Sx4aBXF0ys8Rxg7gXnvesfpIvva1b6jFlMIB5n7Mox9Vm8nmcw2vsiIz4awnFG7x2W7ZxsqX9Cyh+7cVj7UAszGvTLxQZZnrYlFvE6htuyQoj0DpeM0Gy+ocm1WlIxauDVFWWLyVs2IZX5rDd4c77L6m/J75R4z57/8+vCzwnXZalaL7XcD8DllTbdUIcbm4t4uH+cUvfz2Gx2n1HLfYbL1A8Y9dPPOZz8g4r09LrbOLLCJlA8pwzDHfrsOBQIOt+s53v7eKsm+ZVIMSGpWqkLSGCLattr5dKOzfT83bFy+eH4+Nt2ev/DoM0ksvu7jmUEmxy8LSVcRdY4BLQ3yQ0yX2LQbbUJB84iWhA0S1Rrl22pRNjF2LxMGi3iVdWe6bXFBIw0pKextIXTe61myZ/sPIKwUXONWhk+bgug7SN79+RDyaLerf9qA+sYyIL33pS4uvZU8rBAKefnT2xL773rnmmCevf66Dd2VIb/YGAUapOjdiqA69vVtpQbF6WeY+x+CxrvYK9rI9az9R4F1sQWywPR2FFkB7lEh7D/FSslZQA3FoyIh0IUoB21hsj1HEyNgjZfCwI085+YcZS0raZZ4pQ4JQSgoiTbF3I8TBlFO+b5pzV5iBt1VrAQEY1qqZHUXahs3NK5bXMWHzM/G+yuWLIVeQet4HqVK6ReLLdbtPrypqVQmk467hHbSC6tJ95o5xLMSCXIhMRI5cGUP57ne/a5Cwg6uRNcY3BGn7bbePN66jyTVh8ofEkv+ki5i/8a7MeVeCuilzeHbt14OzvvaASmMbbrBRUqNuHc80nsfXv1H9eH2fTCqFn7PZ3ujwPW4srsaJJ520+NfXvmbx+GQzmINOd0n+ZgpQ/CbojvDZkUccWQbQnfa+U/KWH1oG9rVxFuwJayC1RLlNxiED4Oijj06XquNjqN41dYJ37s4r12KVJlVtWf5OQwXzbv/4W4EEZTw5LufFCDZ35LTxCqFMUZqJU1abschyKJ2xOSNkUEOi2pI15u8MCiGISULJxFCVv/SsPFEdWhRzqC4xWXu5/vaoc1Mec5wdxevdF0RLmQ0Tl+MCYXS2Jq45aTkUoqbzxulcISCNt2p87k9GOM9DFBpdRdeQM87b1EfwOU4Kg2zCNQiJUvcganTBxJaFH1zDs3dBltvmWjckfe/F9d0qWq+K/6mBiL4YKPRJT3pi3ri4WLHc5mF1zYAKUsOiy4aa2Mkk8PIUNTo+NVVqrgtpR5ztkY98WOVPidtMcBdM5RonnHBiGvAeF6/lohBVbl+s0O222Wnxun99ZQmnjvm0dyGmwhO6JpvNxK6fTSHd5tAPfSqxuT0WL3/ZX5bS1ALNolS9zWU8cSAQh1c80/d/nKT0X8eTM5Hw+ztnQ7/lLe+JFZeO5/E2n/60p1VM7KSTTq7NK7hOGLJoWbtqNoKdP/jBD1XcwgakpPfZd+9iNXs+G2nyoljXNi+IlVVK4Jq32cQEH1judlsqMbZhGQTGy5MG9Yj1WbwLE1u8/LIrqvKUlzFh410dAQIe3zDKHIlFYgHun6IVW8TrJ1zfn/KOoB51fm20swLPPO95z1wc+MD7VRUSFVhAOhfFCMCQlA6FYfeIRz5i8dGPfzJezXGxEHevNaniCBHCcn0xSI8++rshJ9138ap//oc1m8+z7xJCV1nbEVig9E1TSQdt/L3ve38ZGVem5mk1JBcvrlhLQ4aURxUrX8JKBCGGKpjv/vf/82LP3i7esbSmallXAlnOaIgqibH9cUlSgWBUekX2a3sQ/Tr/gvNrbZCJLokH8c1AzbvuElgo+9S++3UIWXpaQmiOidH16U9/rrwbLeFWJab8t3/7N1XVi2eIMcsLJmAd1ImB/SFCrngGuS9P1eeUj5QTJ85jTxMEajBrNl81fKs8W9eengT58khjsG2Y5yL8Ko0krFCCAevc51bFcv9pmpv/IDne1QoqSod1fX08lBNO+H7OzbJJfKagGthXr8hm2XZcscvgSRmZNBVz3R7peJ1tmKyMg7aV3zKh00rbUxvCTFVpWsLUnWPZni2F6u9imWeNwJC8pJLVUaIN91J+jDbdlJq1LabeiEWnnAhFOSdi4gwrfzO87QmG5DURiJtkHRlXl8UzNDde5FqfzTYMxmthnBDU1unUU89Y7Bmjfostt0lHqs8uPpFa384mOLN7WjbzviDZmr/U0c19FK5/1zvfnmL1DymDiQFhP0EPfnbqTxffDxGS53iLyA3rqf74Ix/58FLCrkEOn3TySYuHPPigxV7ZY5oNHBo28YEHHLB41KMeVaEl8lfI5qooZopUU/ReF+vT6UuMMX+klY1SIMcgBUhnPHylJ0fp8PrV5qYEeYtjvDqD5g2cejXPFTM7MllqHJl0/i/PL0KRfr3kKY9ZQwq/ozzt6S99+cvFehfqkgcspaURCPWTNy1FSz8YC+VKSduXk4JCtlOejJJzk5ajoQn5CxmyflX4I4ZNxWcL4QjpMAbk5M1O1gkI1xz4DpTT2LRBFAenB/1e0QxGpbPFqKtskczhtTFcGLSM9IKhE27jOb/uda9drPOhKFJValxcAWtdL3yRpSt2OLGaCbqOJ1qxjwzWJE/+jg3oz6tS1k0JtvIQc4BvH9iUktki5CHYv9w3Wvz0n59VbYi2jkdzxpmnLe58x30XL3/5S6sPp43goaauJKFLwPGaKYpfXnBeYLfPVk2QV7/yFZVXSkCxtFm8xuf+s1i8Q/EI+Xc8SONgjV6Sbu4sojunStNHPvrJxU9jUNz4h6sXBz34UUmZOLC8ZT0mdw0DFHuYtYTccFmU2e577J76v/+VYvqfjseyXsgKd188NIfHWBgi2sgRLOrrqqSjBnATAP6QOO2R3YEmmwnh5KCHHlDGxtkhtei9p7MN+IZAcWA2DtFgVZT3Zz7z34v3vv/QVHpJ04BcxxgOTh6weXSof/SjH+fwXrW4XVUP6frHW4cN6/B/4lOfS7eGb5cCtHYqp1x00VmLxz3uyYvHPfbgeEaXVLs8UDFk4qyzzi4Bj+RwZn5mACmgX/Gy/AGP4iZflDmUM/vogx+6eObTn1Z9Zr8RL87aHfTgh9Ra29T3Se/JzbP5qul7OvmApJRyVHWnCCgIzQglSAv5Lqt35otgQyK6+933q/h9s16jnLLfJnZPgIrh8GxLOFR8rdM8/N53QORSqRxQXizhYWxf/OIXa22HTCbfWIrUfe5973gCxy2O+MYRSzjqisUDoshf8YpXlEAuJZKxM/ywVq11dxuhGKT6rBulfUHt5Z133KnO1rePPbbuVdVmstYPfvCDaww8fgLLITU+nV2sn761lwSqL8+d0okw8LOCIxfGCC2YM/N4ctrQddPhMBWjlK8LZH5Rvue525hskpF90ikuUaI5Ax2uaKKPpvVTa7rr6DYTtQyRylVuJTnoFGOgm1crZN9FGErZlpLp+an86uWrlW6zfC24n9dTsEFHpaoJ3XBp9UQtXoRxdZmTLhHIm2VMNExcReKLjIWFuelijyA2D3nIgxebx5i9MIa28M9m4UVQgKpy7ZiiAZAp8yvsUy3IMseEuywAiM/5559T4a3fp1yjfbfN9ttU27CfRva84x3vTFN0RQ62KCNommGsNB6EYNT4Riyj6PwbzPqDtOfTulCaHcOq6m/Hq75lirE/5jGPCNrx2CJDvuU/31JrIxUPSey7xx5X5LI999ytBP89whJ9RBTvTTci7V2Yxg+g3LQiTM6q/Q0u1k6yW6ml3jfGbfaM+ZyCOZZjCG/jEPEknSexxikIP2vI+IYQ/ioNzLsaVTcQ2GbbbYrDwqDZKfLK9+xZ51aTDc4Itu5PfvSTxS5Jq2QYkMMY55p175rf1T1zDihK3xuY174EMUM1yf9SmhnQxlHGzn5VVspYye+pbDSVrHx3Unrs7ZUpLOSvc0/neY+RcU0U9BSRMEcUPfnMgGOUYT+rr71J5sF88UzlCEv9+dSnP5H0l8M+sJolvGViDZ9NH1CTrhrQd77zncVTkkdowNx8gmncZg87brTfOaiDsasaBBrTwUVsy+YWM/j1+RcthPg3TxcY3WBum8pErB8H5pJLU3/1UQ9dPPDAB3aX9SwWiGOquEwu2YzD4r7nPe9PR5QrF09/yiFluYEg3NfB6JJn3f2BJXP975TKSo3EHC51Fo+JR2QTPyIpHAhFnmWzMCKPjYBzUHWSOe3UkxdPfspzq8G4+O2DH3xg8k7vXpP9+4qt3FDpMA7HBw/9QMVaKdF73COlxnIzyre6UfAeeG5RluDdKjmXuMK/vvb1i1+cdepig3XTDSSffdKT/yJ5uKpKxfJRSq/gia6XarHVCbXpvva1I0K7juLe4lbxUnS7v1lK8R0Uss9TS7gcf/z3q3yhA2vNEI7AeQqBi/9+/LDDil3MC1z/5t3p5sILzy+L+MAD7lew2RZhmsrNsxlZp+//wIcL7t9u+21LkRJ05vbiCB9W9RMCYbE8bxeYk3y8LprwV6gAACAASURBVMzfd6VSDI98x512qSL0hP7LX/ay8o7f8ta3FBFMzeTTfnZaMVornqgsXTzJ6UDy+1RSquB+5gKkut9+91wzH52H2RVarJ+Y3ChRBsbK2qNikFVSEskrHj4BMn0Wp5Hxl2Mxu54/FBzPEiN980D/iFzHpswehQreefOb31DJ9Q6xPckLcdgGehW2EGfFoCacJtnbs/ThpUDWXcMdUJbTOBhPP0seNoHFo1w3nhkUwzkSA3N97GaNsFsQZM6iLBXSZ4xUW7B4cO7H+OKprI53WzFCXYoYKEvo1VjsL+3UultKp1CVmnVY8hpF2l7nslG8FA8Vl0oXroifWvjcy3rMNSa+2QlKpVXrOgXdLr3SUaRV3Lw87VawtZH6Qmu+67PCBuvGaCuvtOK56lqrBQ0NuGGxSyBDxLzbpzjGPfe/exlNZ6uZHENQLO7e+9+r7k+2QH3sBWQrcWvXJPN+Fabv0cd8r0iL0CZIGEj+Vre6zeLchGc++MEP1jlm8FBcgxx4dnunUsgiRynQJHIs1t2MobV+GU9FpMk9x2BRyWvvoGGPfeyjF3eP4qWY3/Sm/ygjYdOweo844ltp53f/4jscf/x36/cPDRS8T0Iu667bReh/lXNWaFzuZx/tG7Tml1E6t1BpLc90XLwmv5d1YE+IB06BeN8f1JHHaA8gDg2cOmtJHol7CgdYT8p/mo+Q73MN3/td6otDzDgODLqCksNnIDukG+626x1KAXF8IG0UFyXqTBqbF8VHNjlf5swcMzYL9g0K5VkZ6OVBRnZ4Pvve5yb+6brlMOTVlap6fxrjEJKGu8OwLAZ0VYMKsSve9g7xio8JpI53gPfAm75Xaj8zWux9RsMJ4aP8+Mc/XKxz+Gc/tro2fzYjKviRRx4ZSHfPsigtni8VW255A58dC9fAJpBsYAY7sC/L/IhvHpMuLt+KwO6YhwfzHQcCzsy8uF9YlkrJ7RJYTdK4DiK63k+NxMHnj0sKjGvvmRqcH/vYJxZf/9wXF0949tMWT3ziIWU1giU7xeZmNSbkDAXsQUbeZxAgH4CbQRE/i3W5QyA63q18KAf4Xe96f202LL13vOt9pVCe9cynVLlBSckHHnhQHdrzE28A790xxcwpmL//h39KnHWP6mpCEf3u979d3D8x4iZhNA2dZVgly5aU6o9+9GPxrk+PpZ+czMA1m21+y2ofhnEqNeWybM4hd5TQi05dlSTx76a/5eGHf2FxmygtxoJalyDFQ/7i0YsHPuCAus95ER4s6pslpaaajv+x+wD+/IxzFh//xGEkWlmVLPEiEYg9XHLWYvfd9k1s+D7xTh9dgpsHuvsd9ii2IYbasd85PvHTrQqO3TkC6wmPf0IMk81iXafZdSxU+8Icq3r0xS99IdWpfly9UO9297sl3vzo8sbEQrFZv5EYketMLMIBZwFicFP+oOXbJ1bhgGFSg3ooj8mfNQ4Ksz3CtU3aCyqv+OJSAOdp5/CIhfi+6wwTcurvHnWUPM8Na7+XJ5Q5P+MXZ5Txoz6zfLbDDvtEsURf9tKX1ffdg0EFOoTqIC9hvtprEtPl2G0eA834xAPtS3OjEb3ygIp+EwbGICZU8xdW5s/OOK2MqW1i3Do32LlaxPEUq7tQYsT2eaWO5PPdnPwPJdxzmCuGCvJHiCgjLHBUoUdFnECO4XnyQgNpUqTLSjitsdYq0ilIX2eWuxndNsjUSr5E+amVMt1F2+ca4302n3dZYiDjc41RuAXvZi86G5zYLpXYrylUUL1SlyxiCtZYZhyM1RaQYndN1pmm33fZ9y4Fm26VEIBCMUoTMrbOzfnwfWVFMWiRvDDINZdXZ3mPO+y5OPHkH1RGwD2S2iBUwws97bQzUvB++/r361//hmpAvlU4A+7ZJJR+dnJoigCYs0FIJnuhni3fMWb33HGHVYu/f8Xf1x4444yfL9773ve2IorM4ZU+5clPrWc8/rhjwpY9I97rY4uNfP318i+D1C3zOu2vUTb2+sbLVA9ni9clx999T00IQDNuMntSHI0Jc5+Mdl/fd8+1xhL5LdbdqY1aYW6Y83xN9rCa1BBILRGheK4pbUUZUEjeELTwbn6Zz1on81OoS/44j56dAjPOyd303hCY3JPspHitF0VqzmcfTk6puOmMudKElgUnRh54j25xD9XzFC4RwmQkGLO+qrIgkPD8+5/+6V+KhwKNFAuGhknzQyql1DlM3/hGSgRSpG7GQ0F2OCoaGMNtv9RGvSSKVfwQAaUtjWZxjcJs+BSUtX4twFgOLGN4czdwvajozj7runJFLejmYTqCWAjI2YisZsdovWWFj8G73QPBCCxzbqpqvPXt782Dbbz4m5f/VT2MALWYgw2sOwbo2CEhlBvq2rg8Ucr2hBNPKCtSoXLxVvl/PAgW2lfi7YGOn/fcZ1fc8Y1viid60AOzOR5YXuku2QgvfMFzi/jDmleJg1dCkb74Rc9bbJtC5hdedEG8mFsVIQD8I4/QqypxxB0wzyDRTybe8qF3vHdxh7vuHYvzzyu2w+Mx1gc+8IDkekaROpDLiiNiXYT8L844O+UPP1eWIYHJuuZ9qDDytKc8OSXUHh427Jcr9QGU6H6U0r5hHWqd9Y+vfFV5a+DkKgOXn1mblZ5RyuwPYdU+KV5uSrHlYKxKEYXLAvkqfPHVrx0ZosSPy4N5dkhKT3j8IYHnT2sDKc8GYdBN5FtHHVkCQY3R3dMyTGzQ3P8qxo0uNqvCRP7qV7+adlY/Ls/gzDPPXJMCM9aiUoS7xnJVLWvSVoYcwMPiiRDADQNTDF0ebRSc/dbtzFrImX+/m7i0a04c0viPCQMPqjHkOBWwqppRDCYEFrWlffd973tveXj6WYo7VxyvcvoU1W8iVLfXSk5paviOsu+YTPKjoT8pY+klD1DMlQFZUHX2yq1jlID3CGkGoHxp3YacjV8nTiquAxVRz5gQZozyxi9LtaPLsn6ucUkgr6vy3TLgIBtgUKES5J2KCXaKRf1daZBtFIwAmlhb14puLsTA5/8fY28Ct+W4tf9fhlTGDFHGngZlKPMcUskYtmGb7YhMiW0eKjIXQpnHEBJKlCkZGpChNMmQQklJkTFi9zu+x7rW89zt/X7+n/+9X2/1DPd9Xed1nms41rGOlT+T0b2daCacCgqTtRvTSaIOGrBn1CKjRlojss7POJl1kZxMN5ymR5fpmfr75dcyUU1HzPulhCdrZN1rz0IVDFy2Ru0ofgPDCTiL+gEHc5Bx0J39UAQsygU4EHgP2BcMKoaf3mA4HKz7TsoU6Xum55pnwlg9iFv9bu9nbgmEs9hnCB6Ek48ggrJCzQi2WDvuKNaTZz5fzx57eFOfG+zUR4wYoVal0Zq4JNsppIGvnXTi8cUuO+8iu/WzEp2R/vqeCrjpszdat3Id2cEmbuNhT5NNcQ2zvphhPXGgZH6HDApEhH2YdpzrSCIlwyY4T5Q0sv8/hRYySeHyA4WModo4T8hyZPdoWDeUIyPTBM6lRMV+xQHTusOZQLT++wVqydG5p5WO98KumZSna4fgCFTL56YT5Gfc76314v1BEznPLtnomhMR5dzhaEGVErbm754XWqIn/AzvjcPFadMn6/KXzjLXjQ9r337f4mf15Hfu3MVkyCYicRJ8YrvYB5xzkJ9thQpsJyTuV9qJnntm4DJugAcCcWOyGK0fC25r166t6m0f6WubWTIQp4ahSUOUvXLWwyyL0SYBwU7TxRAJ83UMB+w3jF5srPJw6IBi+Pgd/mNRgG24YDdBmAYv+rTeHxJFiHCvK6fVQz2U84sjDutYHH30EV5QJtLw3mxiMgQWKBeZaAdnykLC5uN9p06e6mZvICDILUSoQDgdO3YsbujdVxndHJFw/lU8OegZO/C2bffy/TypGuPFF1+gKJeMTbPutGZkFFdfc52yW8hH9WyIKQFBHKgSnErEyMGhDQLDQEYBSeblF18xlNy5cyffJ2SE+mLHfjDhQ2e3RN0/iIBUT46JOgSOFCe1WNHnMzLq6GaSUSzWM1lHvVE8G3rQupx6uuBxDsMivx8C69SJyDTXFARy+ulnOZOBHAVTk3WhsE7WBCRFRLtKrbqi/fdXzaOJx8x9NOlD19u2335HO+wF3y1UZNbC7ReQWNZYHfGOGEdHUAJxiSAKnU6yQyB3MlzWkMHsO+28g5ms9POSyQGDcpAwRB+K3IXzbNtuH31NrUGlWhDPk0iUKHglQ/cB2XD9ONGcPRnGOmrDfM+EGup/1ARL6NKkEAVZMMZDXH5D95ESFKFQxPep+ZDB8XrssYGi4s8o+va9zQQeDFEOLrdZlLGkpxGSBzUrhnqzlig9JWuZfeieabWjAJ1xTgjeXAPVWhD1cg6JcNdTVEyAQy0eeLmuFKBgFPO5X85U77JQD4bIzxYkz+9DkqItAkbjJtqHnJe/CNqofeq+2RcwYlHAMguW/0rnSZ08fFiOWyj/bnS1hqlrR/f/kZGSjAWz10tWjcimrGM4lOiXDiJRZG8J41ohrHyefpPyulPNys4pfqP6hVHPbBpE2A5W78M+Kt/cRhkDv6NqlpCS2Ps7aNYptf/paskyNFwKGKCqhWGeplmXG6l+j6164YURxXpymhje+cq6PlbdD2fYtm1bcxruvfd+BYIzHPBEPR9nGgpOcXsRUFQAJP531HtXUjb3ZdFUfdX9+t1q+cD77rtPZM2PfR/sp3niYjTQfjj79NOLPVrv6vNExgrr/4gjjowyhKUo/xQx8gOT8EiI5nyj2bNCdsj0cGA4x0okgD3H88iaqR0rjF/9LI4HuwpkmnBpknU8pk6/B9eBNj0QGF7sFQh0nGWuhXPEGqMGRr0R7gE9z7ToEfjz3viJdHh8HnVlziBkoxS051pwrjh7JBbXEvyLfee/VENKbk6WHhOt4DqTW8PPUGPlvJO88dlRAlniWivnhFYdznIrcVyeGvy0ppw9YVvNs2KfUArj/fhd68JrLYC1dxLxyRkpRohTQrQCDPCwJm50EkwZddGlFvzONDmpwzX1nr+dZnPxWc8KKDP+HdGsagQYQB36rBfl3/MBRR9WHLQC5aOyDQKGFgaBqOCZZ4eoZjBaTmF3RWnH2jkDZyU8YTKFNr/7/nSzWWymtSSMqggJ9WIkFg6GaAk4KXF1ohIw/LO7XmAImbaKu1SLXUNZ4k47bS8m3SRv3B2l0Yt83OYyqiz+A5qTynXgTLfcsrmhVtjBZKWuwyi6qSXVIEMSi5Q11G9QjBszluNV7KeMlz7KH35caKdRV3NGWQPIK0SRrEmVhAa+mYumqhx1oyr16w4QLDHF9WcK98mahiBGpHhGl86uWWY/FYeDiPx7rcv551/oehIGxgbHxjLE86n/LVKmRTBw1x393bs5WuQkWo722guoWj8j50nwQWROYGCIRrUpDFpCW/Xk2Hmei7TGPwruZA+E5NeartGSnV53/TViwj5VPK2ggP3VQj221FHYh/T1AncxDDbF02PYuZiYGEs9d6j8ZB8Yltw76SjDWIdYA5+dzhRrhlnj+zxzkAz2NVEsCiX8HAGbAzttDCJ7UIK+mlt5zDFHaThzLzs31pXIOHrrYhAATd1kMt9I5MKECdc4Vyy+VBkBdGDXXXY14WOqjDT6t0mUghNAywAvDAbwEb26MAdpLSBQYaYpxgWUh+CNQPC33xZ7Py0U+kJ/IiQQDNVaWntUZ5bKIPyo761kOLdUEjOhKKy6K4zOGoOVi6G3yTfXJ2Fx/lFOLPI+if/sdA2npnODUIQjDYOajsOZZvnv5Rwpv1fCoNWQW5jj+IzSMBMAhCPlfWqGNfiZOiiK6/B/vpdyWovvZZkdAi0hELMQ+qeExJ/rqFYKQkWQO+7tcWptedkToajBw8zmjI8Y8ZKTgN00q/SRRx83efCkf51oOU3kR/9QHZC2MIa8v/76KJMWOZ/0XGN0ea7eZ9pf2R6X+5E/yYy5N+qxBwr96dXrKju+s7p2U332rWJnGWf2MzNfZ6onHWLelT0vVemntVoFX/MePbjjIXZ4s2Z9bYdIAIChb9VqW3E33tF+/Nl93bDdcRh5FnAMMVQ+ROTz67wHATbTtHhfbASODvuSqIQVnow+rach8dItli1xW5r+Ax0gOMT28pmcB8RwmjRtbK4AUGoOa2CsGr9DAMmfZIo43yzD8B48B2rNfI+snf+474SKyTbTeXLfyd3hnnh2occeY92wB7wXvgHbjUMFlSAbpouCbJT2pxYtmkvcpHnR7bwLismqfXLt1N4JCGNyFRl8HQfidWWDSAiaKeFY4YlH74vzow1M1MDFEGWtpZrdAWITcjgZyooiBExVfo6NiYFDDxfnyyHPnsfoE4XwEDABC0Nqb4hAg6azeZbP5LP4Oq8whtCYdfAlrs5ZxrD8oJvbUszU19WC8PCAJ1XHa6qs8DzPtKNNh8+G6IM8GSxPojxu1NBAdZuGTDJ1FXrZtMhEkoalFQF6nJHp9xpaLQ1fCDXTpk7XjMKni6OPOsbtMDBsd5Je61p6cA8//KgWcWU5yobe3NgJekZh/K2u7Aq4ooXqAlwTjfBAazRfU6tFCBvSAZ89+KlnnNVwb9TAnFE7k8KhSe5PtS/Wjek3/PzcuQsMJ20k1KBPn74W2N4BZ+lGc6T0aAZfQ2sy3w72DEHQe4lxip4tDgrDBeR3zdVXy0HPc10CpmPIiUUzPaxXsiUy2Ztu6m2nMWL4i1KHau0IHEhutdVU0Bd0T/2DyBuDwJ9k9GnUkPpLCj29m8mq4xC9K81XDMFll19m4YpBg58qdthuB2evyPE1FWscMgHvFUQbxCxi7JjF0EvDyufy3jxP/kvn6Qy1NA7p2ANaXF6CMUQ+Fvtgc33oAdPuA+GCQ8xeAaGBmPbySy8XDz/0kCElAs3GgswhMMU0EQVNEvBOcha6sZASbEQWzPPaEuwAH2KcyAwQ4WC/+3MMW4YKS/SwzvW6U3eGBcl5wXhMFgw+RyQ4Wgxog3l73BijBGuolmbmoeBnApSlOgfc7+96RpQuVtSz8Xro/nE+llkkO4edazZs6TdxRhUpXzjMGscZ2tL/lyOtyUKZLZvEoho4uMaxptNkn0cAF+pFdrY1JW3vRTsdXGOJIiRU6usylJ/60kw4ilGMnAHqtPyilcvkANiHtWFsK0gl4Gi9x55aQ7FmdU6bCA7FkL/x5utu4WJpqH9x7gbpfH6tIOjkk/+lAHqyRjA+KCLSacUh4jO8LecLCkaGs6rOHEpd1FNHjnzFyMS6UpJKQhXXH5KBMWQdO2NHq+eKqhbB1rXXXq3WsbYOgLp2PbeYrFF4LVTqYa/BZVhXJQKIgld1v9QzfIHtZ301yw4hSjIL7fDI5rCZBGl8/WfV1el9ZU/SU8rXzdCWfYbwmI49HWG2v8DapZ2GQJ7rtcoRMLvWHkfqhESlIZ4BjgoblKRT9msO8IaPAvmT586Z5n1nfz3HDpFzZ+ervZkSns5q5RAJuvEnoGPZS+p+fH0fZ83PZ0CXZZ/0YXnmWfMsNeI0yToJ0NMOANkTeNBKiB4BAYBJStoD+IDLLu/hbHqjjRs60aF0wDWDUq2uAIyyDGuCz2yKjX7ysfuXUbvE+aVjfFk9dTiPjuoBnSloM3RLW9mRsihArDwUsqbKKItFxWGYLl9CVikxxYNFqo2bY8OyQBiWhBb4eRtFMhstGDdF9OAUWgbsLpFdYMwdfsghxUknHe8aKCr/kb4rUzFsDGYu/U7P+YuxTGlUWfggNkSm4rqaPi+p2lwffaV8vUnTzYsLLrjQrLzddmtd3HX3PYLcNjbpZbQ0WSHykImQNeeDoQ7Iz2CAd6CXVDAsFHfWFFUTGqKpIdIaQyT8jpqrgQ854AwYrkUbQEnWyjpFHTkOBNdx9sz6I9tcuOin4rZ+txdPPfR4saWiVuqkfGYaKaIwomPICMgjbqprornb/Xi6Zg4p78caAw2baVmuDWuwWH2ubP7zzu3qAeqs0fZqCp+i34P1Sq8eVPg4YGSZqg3qvVEwMqNZAZalxsr2BZ4zMmsLlYkzMaZRoyo3lwdpgYb6hYKsdrMhxAFtL6eKIYM1S+O2N64h3TBGGF8MJEbd7Ecifm1o3s9wLka1ZKDyNTabNUB53jIiDtr0dwwBcDPvASmNdYGpzsFww7eyQqL2m/rcZFbyoYccVrz3wXh/NqQvIFp+n/2+oQIqMlCQHVi0zsaVIXIP1Ke4rlkSxjBJQ4amqlETB098Dg6Z3/MzUbBXu25tN7ejhkOmijOnZ5pM9HORHz4Vw5lIfC0FLtRjIbthQIHZedURCQR47QdlN+wt+kUzi3BAYYGDgHcjK41skjP5X/6M8IoVt0vLzJJzlXuNz4u9g+YqTjRm7qZNyAzW72v/nbXWaKOpfpVZKEas8vfjc1IAIhxvBkWVwRLvxFm3gHz5it+NoJ+1cz1dexJbxr7GYbo/HVKldHlnzpohEs7H7tGkpzGUeqL2Dr8AMZVxIjzCrN1SutKo3ExQjXXMmHH6jLoWsMGeMYYw+hNjwhB7AQIef49apLRzy+kznP9mMsJ33XWHA//XR72q1rYHbPuQFaS9gk4D3uvdUW8WF1/ZozhB9VIy/z/FaMeYE0whykBQyl7i7PH8UdxCqQonQoDFNdE2E0IfUVsE7WCwAPuTvYxdgmzDCxtALyiJEs6Kn2FNYywdTFl6LQtP0+K90+YS9KVaGGfMkLj2MrYDR03pA4KWEy79h33nfIJewUjnfGEnqbFSIsFx4mxTOAXnlWQuUEDWDTvN+9kxlyVIPjfrowQ8rOm+IkJ51KPOLDrVn6oFh/2ESh0EW77G2UD2899C7qapHQ0da7O2y+zXwg46j+wn7FRDBU60+Kww4vnBy5jpiVHDQTbUJhsnkYShzz0n6a3jLVdF+ruhbp4bWF0RMAcejIgDAgOLzcJNgJdTGwMrD3p9OMbQefzJhtxMVtHXeS8WnM3FYvBgWQRIQ/xJBEHkwuff0f+e4q2xb5gB2lXj2qqElaMkwwMmq/xa0SEKRchVRbtJHNpKqK/6UFNMqThsmUVxrsla50tknakFMyVPdY9EAw46cH+rDj03bLh6Kw/ypn52yAu+dlpm+BPih0e5iRIONEjPF4at5VatTGD4c6l61qSK84OMK3AhMyvJFthIZEG8xwaClLOwz7VasQOZQBlT1m3KNNH3lcG2lPjE0OdeECwxwwPJCTJsuPQf9wvEGigBdQSmjKzmGiWv1ZVJr7fuhkUdiAJl1M8fHMwQ/q/t6Iv1v/76qwV17S54EEWmL511sw+QGMTBpGEl6mUD8oy5N1ABNnhdOVg2/yT1j5E5kimQJWyzjXQp9aHQ32FPA40xHJhAA+hym5bbeB8FXB99b0mG4B7YwNyj1117Lmv1lZBjZfZCtsz6ZWN3pUPI6UbUPZlzC/SEQeS9kWaEjPL888OLRx552BOCZs+ZLUEKdHGJ9jWvUnuYGaRcNy+iXA+Y195LhiZrQGsPAwaYYgFrkTFbOR8xWYYwlSEZcU9IwuEEvhIawnMlACHz5FnNlZGcImh39TXqFtvKGbyhTBp4kv2HZBtkGYK0/wCF6vr+1BkkUHZbGMGmHWkMAAgEN85DbAc2Q3zd/6Z+WtZGw8lldlmiGIZ2I0ANyDwcZc2ziPep/HfWTPMM5sxSvz9OudyXzp51nXE+q7er/+5AoEQY8neS3JTPN502b8d+5r1AeyDvoa515JGHmzRCiaK9hA7ISGaqd3iKjCcdAqwT7TKMzKIsdeyx/xRX4CP9N6Vo3XoPt0QxMIPMlH1K1nbsscc6+O/evbudL3uPST81bURF9V4GzcABdROU20nEvW+lc92z51UeS9ioqpE5Fdwr006wmXzOFVdcavk8RO45F7/8JAKanDGkQIIZhhPgtGghwTZiQ2jvY5/Xl7YtMDd2GBsGj4EMuJ5KXdgV2qdIjupLKIY2K2YToxpFIELAkaQ+zjkPdTX1KodgzE/VvaPY/GwF4ufY23AfQFngkuDYohwS+4d7wKY48FTwCEJEeYpsnroqQUEmPDhhnC6BAX4Fm0DAsNBwbOjr8vNud9R//Cz3wz4AtqW+CpcAm8O5iBFuah8s9+6asskMgwD9arP33qqPDtQc5UEmIXGGv9X4SLSu4fEQ3FD+2lgBOCjhbNWjV3h+yJPLoMpT56TXb1M5AiLcF196yb1y9LixEdYRvMCNAzFxUPHyi37U+CMr3AhK0kNbm8HaDTWWTP2dTPAA2mwguTlutKHUQRaItUmUvlSNzixQOtFKYkgUxhlOvFRMtEbKjOmbfNZs3E4nHadxbXu6wEs/4FYi5XDd00UAYHPgSPOVhy0PFl+PCBxijWq12iBxyIK0Qk2Mjc+8TTbg1i23lkDFg/r5pVJ7Oqa49db+qkMtFty9rzPzUaPe8DQRj30SXItBIKhgDVtu3UIZSz3Dzdtu21Jrp5qh7usnGUukzpLyTxb7hqBD6n5MT+Ghs4m5JnpV+TdEA4zAQ4K1mf+J+H3tVRRp10GzGHHy6KlLdiDKNHwNth8EoJymAoQUjhbyTfx8MCpjXTCIrN8vgpSB0y+99AK3+3z2+SfF99oPBDVbqq7BgUI4HNIGzebM8uSZEUXyPOnBJbL/S9kB4v0c6KqqKtekECag8Z2DSzRIKwjGmekJqwkG2hDdUV03mVZAYgEb85nhHONPoudk3+X0Bp5hCguQ1UCccLuNDi5ZY0qeJZTKzxIwcV+8Jw6pX7/+InAcbqPKfsYg7STWJ8xrHD8BFcQVnhs9nwhvN9IBZf1D2UjBj9CH2vpM2JJ/ilRBtglyQwDK5zCQmgZ2Ml9IDxx21pOMPmtRvwiKbyzYEfgRI2C4XX+3RJ2MKhD4J59+XNazN3FN/gX15U5XttpQh5vzRCADErCC/h79ucpgFEHjcJNcFELr9nQRiZUxZmSLdo01jtSOcvkeUc5RrMQIqQAAIABJREFUCDKEM62skfq8haeuDroyCw2iU8noZedRduHnXNtmn0ZdOybh5D6tYfLmFKDl3r/a2VZAzfHpZunCSCVw5R6wGbSVIL/HC6Z9S7Ukgbqhu/uiNKCxgQQgaO5SMonZpjBWJb9HICUkiADpZM1GbaJ+U/oJn37mWRP4sE0YcrLaDh062PmRhcLIpb0QoRUyM5zFrbfcYrF99nPfvreIHT7E5EJQNiBZGOLoViM0g1jN3mqrg5G8RIkPzH4cUUj2SSFLjuojtdCRFHHeCADS8bAHOEfsKQJRmLacW9psQBKxTU2a0GK2lp0xGs2cPexWkvdYbyBir3uZYTtALcU0srMjiUqcDRwqZ48Akd/DKZH5hoNcalIX9pbnkpKEOF5+NnTZNQ9UdqX63yZshqPka6xbygMmDGx2sGwLgT32gX8jtEGwwM+zZkFQWs1ZvwMtGOz6OeqmwdyvW3Q793yjCQRNHuYtLsVGGwHdry8Uq4GzVD6bFj5Buw8p01+mrGKmHVgLFXw31oPMyeLAmGPHjVVtUs5QNQYK72+8+Xa1w9p0ExEdZs8t1hGW/PdfS4q580J4OF8bKu2FmNGiRVOLGiCMzwguUu1cQMO3JcXZeL0WmDFJb7893rJ2kEI6nXR0cW63c9xDN2/edzYOqJrULdlXCdNmRJyOtPJaHKW64VvzGJV1cPgxaG7odkF6ZWeKEISoXWJgzul2kYQWOpgld3Pf200EQYuR7ORLwT0hOVYOK1YNmIHdB+y3rwMMNiykn4YbqjZRKjUB83LfZO3A6TRLQ34CFs7oKx0CPX78HK06tVZZUYZ9bvHo48/LEHxbNG/WwkxeIFsjBCaNhMQbta2EuaNo/7vvO/oZqZHUQHlpRzFgbC4O72yxGS+88oqiU+dTJBcoIXBtFq6BA0Xtlr5E1hkGLwxSapcw+GgXQeGIDI0aDHJ7HBResFB/UjT5qhrMOTRkzcgvIucHdExEuJkQB7JdsrowwMC1oBfl3NEy28m9gmHIOjw/n4FC7oFgcsfkCmt8as/wdxwWnw/JAIo+0TBtX6hUAbUB65JVd+nSxZrFo8eM9nsDY1MzIevG6TM/FcNCTRhGdbazAKnhpBMGhY3JNUEEwniga8x1YEhZb2BcsgWmx+BMMMScP4wAEmxkD0CGRPhEyBjSHxXE4ny/EeuT+1hLzfvPDR1aPHL3gKL1AdK4blRVTJXDZq0QNyHTwJB4GgaQY8meDzJRmWmWEK79qh1TqE3x3cxG/yfjS5C2FCtKoYXKc2cny/4sAzZTnUqYN+BaOdByI2b2GgFfsIxNatJFJGEp63Xs56jyco2ZLWcWnBB0fD/YuQpAmW2ryTmMkmumWjeqSt8tnOfh9PRvI0ZDkPTWW6OtjXu2RkyuoRr40+JMPP3M0w7C4UMMH/GqMskTNI/5FstxQoC75JJLFXzfJwnLfbxfcAgQEXfcEbH2pcXLIjWRrbIeOK4rrrhCHQAiDGl/wF6fOOH94pJLu1uVaEuRHeEh4PiAmoEvL7300mJHsXKp+2LwV1WAxrQlCG6W2xRK9+SgQYIaG8q5V3lN+D1q+mSuBHTEQjgZyIfcJ2MTuTZsMk6ikfZNalnjxPNM5V6mx5QzuYr2Jpsj++ITRcMO4zwJnhkoQAcIe5C9TAbJmWzZslX5/Cnxqe/eOrZBaOLncngHZQ1+l72QtdrU1iXTzY6RHEOYfakZZLssUjJzqTdzjfu0aWu/MUma5FFP1rlTdo3fI+ieKB1k7CAo0FlnnyP4fpy6Q050sI+doCzg4BdlNGycfpaMfYWRLz+/jHT6W8G7TAzZRdJzKE+MVOREfY8I7SnJ0v24WA3eYpD99vuPily2MJTapKqRM67P1LiOXqmzhhWltsEoprJ+SG0BOOE79SLWqbuGL7B5s8YSIejo7COjmErHB9GCbOC22/qr13Ba0UYs3a5nd7ERIQuCKRtqR8EazHYbHBAPIiHSSviHa+PfdihAXnpApPZoYfL7fGYSn374ga+tYpjv6mtu1Eb7Q8y6A4uhw17wKLUOUlIC0x8+4mXXLglEGK3DRgA+Q1EEvV6mzdBrSqvCQq0xm72eJq4QGXPtTLGYJ7hvTSTd5FDyejn4RF0YEQweBgCYiUCGLO7+B5/QIf3OkRVZ5BJFwRjHrCllz56hsRJGQXfUFSf380U2UCYMum9EIzTGq/waQgnHqi7Y7ZxuFkdYRSPifE0IrwPhK0rjs4Bs50ofuLK/mBrnJoI73fCvz6fmaoa3ImSc+OCnnjYycdIJJxaPP/mkf2YX1XPIMpi2w+HPcU7UhBO6zVIB1xGGdfkpMZXIQ/WzxnC6DhYM0zxobH72HsbrXQUyaP8i20f9g+Z9nOMWW2yl2brnOZslG8291Ux7l/ehHsXzIrsmoif7RXyBgIyasWfOsh90ZgggqCczq3aeCBy/qPabsmdpJEz+gtBB1K7MF8iMRnc+Y2MFGIsVXNDyxLVDtGOWJQEM8O97GmNItrndttsVz6okM1pOYJagwM11rYu0lyGf4YSRZYvaIquYfaN4wEAk7OjKYMWOrrpGak9VBjcxQaZaYKECEvZsTt6pdMzxrGKfVXypet/xtZhGQ7kn3j9hP64vWPjMqYlsNcs1LhE5ky2DgPCVFZ9bfiF+k3c1chTIl0TzPfD6t+IjDarfZ+89zK6nVQP0gOeAM6W3+cCDDhACpWxSxp4ko9O/OruMQY81cPoJKn2deuqp3i84Hcgrxx53gpxIYzsrCHo9e/awgeY6SAh69uzpkV/U5Q899BC9x3G+djgFv8hO9ut/p9CFYYZiGYWG0f942lQ53COUkZ7vDJL3QS0MOURapchMcSojX3vVMpP7qg8dBzLqtTd8T8iIMkeX66C/Gx4J/casbQNlw6wJsDVJAdcOaugg1rKdoFhB1GN/hhiDxlXq/GA7ye5Z1yRU8ezNMRChbs6cr+0UgXTZ55NVkqADoIVEXsj4+FpCsbx/tk7isPgeCRbBOTYdZ0kPJygQLT1cB2pU3BPIDuczuy+MKCph8y7X+0JaooYMEgDChJbxXQp4rFakswaXgg6Ns88+3c+JtZwqTWS0A/j+KYLe+Rw+k38TbIAQ8eK502q4wttjRi3j5tfQQScS/m7hfE8neOXlV9W6INYk4t8FsldrOYo/6MAOxoW5aYQa0M9FWWW4YAso0fu238cbzwOX9eF8CKn9Z4rC33vvQ5E6pgqC+lwSV62Kiy7spsxva4s2EMVEFqV2AEX+jyrzffnVYSrmNi4uuug8wzD05Lk3TgfMOD7QrDK9VEwCbgESSUeamQj3lz9DCm8KtjYNWdRn6tPj55m+gJGJDIaxQr8amsaoX33t9cqm99Mar1Tc3u9uacoe7EgWlSFgF/6eMBMsO+5jHbGeGceGCHZt/QxwyxrSrKUt5g8xPVd2trVStSgATGNe2coBXBd2IDC3kIeTQEIVUxH+Kl58ZYxg9inewEELjyHsuXmWdzTRRhCSg6U2KtM1XAOLkVwYF4wZhf/5yvjPOvMMExtwJHNU9I/MhuHh0feb7VCMTGM/MGuQQAfY+DuJA3ymlg2cC7/P9a+sNWjauJky+TnFB4LBWovGP3Xq5OI7RcUMNaCXk3thvSMLwQlSawY2X551W3mfaUBz/fN73D8HkN9PVm/CSUBy+azJSCGWTZv2nq6hmWujPBemOnDwEDogYqc5n+Bqu+1amlD1g+pH7BWyb0PbYmpyDcyKrK+/M8HHrQEKllZRZsPPLlZNimdIuYPzgxFBRhHDgbQjxhrngLHYbbddlf1G2xmOmWfEn/MlO4jBwBDjuHE8RNscfAIcMhbg4L639nOrRivV1In6MS4w7UMtK5xO7BGgXW+LCmi3/GdmpEZ/a34v91iqGPlb/nZNppkwcOV+zKyy8hlV/y7X4eAjnC5/muPwX17YzpSAI24igqr08uVNBHwfUDB7yhN1tH8ZAOFAWw4CHd727dsXx6n2CRqA4hc604z6YngE5/WmPtdpb29oeBGU7kYGOSvB4P1g55555ukqL4Gw/WSjz145T8EXa/WmJCUfeOA+OcDDfB5qK/CC/3HdddeJbPe6sxr2wJAhzxh2xjlyb9TZYYi/rfIZ+401xfifdtppbg/hHIKWYFPrSeqTBGChYFocKxNsuL9dJVPKmMUJQnwgPFIKYy1aSYkNO8DasPc2Eu+F8XaoJWF3UlTHBKAVw/nnkPDcM0Z54LMwqalsW+F+Mwnh+wQjJEITpfu9idaN1iKum1F+2DmSKZKKRBF5zuxPnpVLR7o27pHWGfY7EC0taoimwIA/5uijvd4EK/xutlRGgMxzmO/f4eu8H46U9WDEIq1LvW+6xXYpUguCmJXlf75VsHG4xGhOMFsXTgjiQWsoyWFP8F70ChOQxhQiTZvRZ7PXIA6uMP6dt/Ru0uOsq/E3IhtRZ3ls4GOaNvCknN1WqtVUFU03R99wM0e21BJop6BHi4XnAbCQaWhZoEzV+Tr1hXyRfZDqDx8+0lks0lYnSiv3iMOP9M1DauGw895D1N6BgTjxhH8W//zn0YYm2AQhIRhzKYFHOL9kBWxCDAwPMhi7UfhepLYArgMKORsIBlhGPglH8Lu8NxsdmJTFp0aGUwQWeWzg425236vNPsVj6oP8Vtng7pqBSRYOa4+WDTNCfbBDx5N0f3epQ20oQ8uQXwwuY5FsJLQOCWVg/JD5Yw4rG4HrJvLxkGMyhTJS5+tAqb8qkkbubx0FMLSSDHtOAY8OMpkStVUcKmOXSi9cLn1ElLyH77Wsa+VzSTYzB5paDM7wiccfVla9ntRcpgm+jeHu1IyiR3cVkwgIrIAMmZDCoYBV+s67H3jiBgETtRAYcQ0VcEF4Iho9udPJuu53g7Wn6+HzdtppB/VutTBESkDFHiJwwMhnjTTrNFxzwH5hTBNyqsyCOFw8wxQPyf2ZLSc5yswkORnMa67pJZmvkYo0G/meiOovufQSC3RwkHk/SELUiyCTceg9Sk+MXNaCNUHdBjibQcY8e4hgjuL1O1mnofdwLSELNKQzbWbAI4+acIJjBr5dtkyIiqBttGypzW28cYPiWBmNvfZWcKozBzTHYcYwYGxgRUJcgwlMBvuxMiLUqVCRoc46YMBjIg6O84hAFI1S+CRq4wnpBmU3INLSqYb3Y3W9pyudaDWEWsK04fRKg6uyRvi95bPSSIDDyeYzy0CPfxPc6lernWNcT/6zhryUX690sDnVp+a9g73MGcTgUSeG5EcGRhZBKQEOAM/t4Yce9Pg5kBUUbq659jqfN84TmdTgQY+79xm+AjVHoNqrNR4NUZH99+/gbJNWCPYwZQyu5ZprrpGy2EtCo7YobrjhehtenAKwPUHdiyOGK8i53fai6zlnGflhWfjMJboOgigc8nsy+CQokBZ3E1cFdAwby7pxdrBPC+Ro3Dup/zGpaKlIjU5EhFZQd2fPUBqgHQUGLIEhLSm/KuFIqHvCxA/dt0oAxsD57NlcVf4gX8sjDNGu9SekTv0Atp5zlD2cnDn+zh7lnHCe8BP8N3PmLKOTiOrz4j4SZchh65xzggyyTewE52j33Xbzz02UQBClN5SqmLwEQkOpIids8XuI1Wyn7grgdRACar6e1aprIuG4SgNVXh01SvDylj4PRry4HwW4v/32p3uMCThwnjxXfB1rS+uiuT4K+L3/SttDMLlAhLIV3h47SvKcgtNUC2VRWmkKCgSSF14Y7npbhw7tXbdKdQkWNZWCMCAc6BAMjuGvbEQW0O0uZYSRRo9FNmFEB5SoecAjT1hzdQ9F311OO0mLXt+QJ+ohd951jyOb22670c4pVZNgs9mZqh5IwR1SCa0HmWHkw+ffbDxrzur+OAgZ/YYGbg08GJMkUH4JhwPMYqhAGRzz+/j5iy+5THq2//QBveyKXspKD/EmfVVkKKCBhBP5fbK62sAnCky2ECMUNiNzARvI2BKs/CqHyOcjeYUD59AaEpYh5sGGSg99WzgKInMRL5SN/CHSxJ+qQ0NoqKesBxHoBd/9rP61160limRYiq5nDYo3qWlqp+WFupPgvWpT5bgzrkfXiLYsG/dmCbOjKTxHtWDWl01LVIuzISJnyEFoXi5S9PalSA5T1JM3w9qtwB2oKXGIWK95asf5QtAK/W49elzujQh6wPOgbkKtkMkw9AUnS5csLYIa9ky0vKTTzMOXWU8lsYznwNfjQGsAAlmevsYe5JDifCCaOaCAbKO9wYBeni9Glb27laAwSB0ELOwbAoMkay1W8EZGRDRfR9E1+5wgiwMNGYvPgJxFMOS9oH+zHtSAIU2wFjff0tc1WYT06fOF9u9MST/L52Swx3QSmsF3lhJUl9NOUVBHf3KoLUEa4pnw+WhFg7AAK/O8Pv/sc4En1KHXlj7woGLQk4NFntvCawtUDzMxoFFMYcB36aSyFhrZZVmbxg9iOOx844Rh/Cvh3XCoMVWGt7UzLeHYCFRL12ieSjhHJ8IEeJQbCPJK5+z3N8xcijCUKapLE/leZaaa59h5aQkjY3eSsVqlRICRW18r4/vs88/MdcCRYLNuvrmPyhAgPEsMNb700ggpet1vUhdB0w03Itu3uoJxGVMx8eEK3HpbX/V93qQA/1g5xJtNMIRoFoFbreLZZ4bq67dKSvQMtemdZFSCdiZsEBAkGttni6mL7OiAAQ95UhKdDkyHmisoFIRiPUH366vEQMZE5sQecoCtz+EaWANY+TnUYgUFMvRxc828HITrd7+XzCnPA6Uj2uBgnr711uu2QTBOybp+0zQs7p9aLC8cKc6/3loxasz2sOI58ty4nmU6m5wD7DJrHYMmQmfYZ0//EZjjF2ZoaABZPeWQGMggJTahga6/6potkK/NwHVwPphyRYCbQTUOkiAGbgwlI+q7iOIkNEziNXnKFPdq07IDTLv11i01onOMzy/JGXVjsv5LLr3cCneepUzyU15zrJuIo9o72C3aoOilhTSI/dtRbYgNG4ZuAOgQ5w7fw/1+KTRghReHD13GIlLDoZeOm9tRUnArrvgfD6i1Kr4eIFESw1hRtrGqiDNAPVhtQLIGHgALiJGtJhCUDia9dz4EjAfZCpDHi2p2Hz16TDFXTNj92+9VdD61sxt3X1UfK1j4rhrai1HFyYQSiNRyfmAafIho83WTDnQ9PMx0aIbEXA+KsVx8L/qMQheVbDPEI7KhPwwwDhXDlpEufyeSGSsloi+VlTRTj+lTTw/x7+69dxtl8J8WEwRhbKBIkofPYccYEvGy0RA5bilRZGpczIyknec7ZTlMT8Cg/aksOCjlUev1hsTw6zpisPmvNoBLVac1JKNJNjAAf1f0RFCymbRw0YAcM258MUbjlnB2G2vsUyiZoFus2q0VX5ZvB3KDPpld2UZgIQw5a+rlXc8+ozheEAfC67NmiTUq6AiICALDBloLrnOBnt0bb77hCQ8/ytGAGKyqHkYkAllvMu2fhTi8/e47bnEha6cmwddxcMgAEmigokJUv6eg3swk+TMUVegdDdgomXmVdWSuI1GFhG95hvG8w+BQrmAteF7UlBkn5yBLz4paJFkwewrG5UMPPSxB+nOKc8871wZtjujwGOJYJ+pyhQk71Mc5bAxopw6UhAu+tr6m2wCX4Ux5rlwPmStTZMgYb5TYOXrRBDwevaagpq56R3n9oQk/GAp6VOvoawSp1NHhGVAzu/ii89XHuKs/H8YhNd4ZquUl4xK28R/a3zhx6rpMPGmqvt/Ro8cWQ4c8Z4cFoYSzmhlEpVPMbJI/CeDISGsCMv4dpCH+z1+3qS9FGAzvhhiCX2VWagdqg1x+Pb5V7Wj9PPVfZpmJMPtPjLYMdum7/QbuV9XX87qqIWoAHCE4ZHAhzrDMfd9HK/hlqtL7mtPa5fQzLZZCwAxEePddd8YAaY85DAH3e+65R9OcHvVQhkGDBro8wc+a2CZ79pUCQkYVQkZEe5szE/ca55dsd4baaBo3qtJQ8HW8Dwj4cSLryDhP0Ki7l9QRsaNQGNi8ZIsgCg0VDE2ZNNGDDzZXX6s5Fy51ibWuzzX8WQZndD2w51AQIzjDwf5oZx3ku5800DzbvRAbAUWh3Ebtlb2A+AmSiZTBuGaU29jjCLVwNkA9CGIRjEn7mecuzhcaziqB6WcJFMhu+ZqfT4kG8T7xb/WYa//iJ3hB7EnSWIrHY9/5Pd6b5AySEAEMylHwD+gQIeC2IILujwQLhjJrx/UB55LBsv/5XX7+8xkzTQzKIRSNVftFH+HiSy9zhwTBKu+V8DJBCQkGyBICHiiVMTGrSokDTpksGk4naBHtRylzGWiXyozPDR0sicClvkFghTmKUuh9Ypj16nJSs+ThYWrRuM6LGh8vDBGHLcUQIO5wUzwEoB4zu0p1o0rjF85KNR5lNIu+/8HUaSKR2/rdWbymKSsHivF6RfeLSuko1T9l7Lh4YEGcJ8aYQ4kzYTpHK7WpsLD5wNORVkJ/bMasR2JEUvkDQ4VzZRF50PxuOt/saw38H5akRoMpWm3bbh89qDmCb54VSaato7+P9RAhfmTDP4cqM6j15SyYdcqQ5/rrr62ab4waI7qnuZk+UO6PqRd8JqIEPGB6lajfzVH9mF7S2hrYTZCCmL4L/ivLuWrz/aToGt3LTeRQJyorfF91aGpjHDIMO9EYmp3VUSXkIx982gwYmqwN7EHKwfyFzNVcxga1FeAg1ge1H7SDgcWADgl0eIbT1Oby5dez9IwCksaB8D7vq55IxLmL5MlayOAAS222WSM/o3feedszFuknRQYw2eGQA1izhJ8dHep9s/6SpKGawCdUshIKZ08mMSmyA+0bO2TNlTRDe0W3sQDBZa8bP/ep2I85g/SNN94SqayDMwfqSp999omMUJWvg1aiqLlr2orujf/Yd1yfSV+KWtmbHEbWY3XBa9YAVsayhkoiZK0ndz7NgQQTh5yJad95YDWZnq4fJATnCvEMyJffx8nSxjBFalvUm/r0udH12LlianI/MTt4vg2n+wBpqNebsU70xdIaxrD5Dz+YWNzY5xoFcg1Uptm4JJTEHrD3s3NKSLY613QQlnAuvYW8KjPR6syU3y9VhUo/Gj8buO5yDjmzVX+nhMky+0kHmX8G6qArKDPQcODLv8guzBwXbEhfJHNHycB69+5tVIHnDxTas8eVxaiRI82HYO/079fPUB2Dr22gZZCnKLMZOHCQzkDT4phjj/H+z1cG66vJVuAcDWtaHSyC8OgXxZlHTzyMbPYgAQ+3mbNLeTYoKfE9M3K1H9ZS6WnCB+8X9YUiNBdsiThMBHt15Czr+lzhSEEUVlT9knnKfCbngusgIKxTm0yrloiNCKv/bWfgZEd7Hjv+zjvj5Vwaen+v6wHy4QS4L64X1S3sIwEgzol2D+/TsoySCAt7LuYHx++xvjgms1f1ntFSGJksDGNgW9jD3HfUM3/1Z+CoOUMEKkxa4Rzi+HkOkINgz2PDUpQB0iUiJXw+nADKgdmvzXNmyAVlsxlCxj4RD4c2IgfaWp+WauN8U+p4Vwl6R2Shuswle8izB9qlLk63CPdOoETWC/OYa0+iGtlooCA10pkulTzz9BPL2CzAi0Bs6Md+qEx0poQCWrfe3fDhbzIiLDAqFsA2vFE4Rwq9wBKrmVFFlIRyiDF0tQiQlWW9kgt3VKf/4M8AFxNFYHi2abWdFnaxNvCTxQsjXpC83emeyoA8H8od6ymyY3MSvaO3CrQMIYD+LwrIPIB8VTpS/s6DI5sGtiQLwHny+ywMmyDYsTjS6FXKzZJOlevlazQnP6Ja6Q5qtN5wo00taLyyMiugg5/VEsKDX9mZcUBX/IU6FwFIgwbridjQRoHDd16rrUVQQKQB1pvrQ3hWS5rJaJajj8iYkZnDCbKO9Cc6w9I6Mb1mNWV/bOZfaEFRVMxnLV1Kb670JfU8Rys7JUtk4wV8FoxKDCcKU2bilQaOAIDNSbbMfcJavrLHZdE3qnXi4NH4DCQ9TbWkwYMHC9ZYxSQhDscCEWy4f9YZx9x+33auuRDtN9DG5D24R/YHBx4iBTUH4EmmypCZ4mxtLMqyQLZtkL0aRtF/3EfS4VMRK+rJtADVTNwIlSD60uiPU+2JHmc9e+otvHjuGY1irAj+yGBAIVhnB3vav5AwIFIx2JyxgOz5dMIYBwzY1pIdo4cWMgOtQbRM8FpF+8ZwlgIj7vviiy4pPpRjq6pq5IkvPKNovUK2klpRZGpAzyjw0DvqfkoZRBPodP+Qyw6SKEjvG693vYlsG9IRiBIwMFAvcCqjq9KYU/v78IMJYm62cIb6oLLumJJRZWedDNyA+muUjKozwzIDLAsAvsZQMYosLCQHvbX0qi50VjvPcKY16WhkkOglL6+QFOzyGgh4OUca3/Jn+GNKx0VgSabHQGuMLc8Upit9uuyvvrf0lkNU7V1OCcc5Q5B3f7FiP9NzRXP31lv7um7IM09nmMiNERqtfe4V312ZNfH35IZwRcmM5/PzlaRB9jTOjZ+hbklAxnBo7BH1PnpcITL99utiIYKSY91402IzoSAgCw4aZfPqCHHiecJdcGkGW6Hf91PQWnAGcNprCI6lT/032Qhq5xh419NpFdR1RC2/vlqjxKqXzUCF63chXMDH3DfBBg4uEp1AnioDnExWcvJLOliz4fW7lHoyYUEilWeFchn7n72eWT3Bf7Lgyag5J++rJkxtP2QdF9k3QDCyJrXsNc+Pz+f7fB6IkRnyWiPOGKghBCe02TfVs0f/gBeSqaBetF2+K3TsnG7nugaao+1iL4VcLAEZrNwtReo68sgj7dT5j1a2uNea2mg41lh/s8iHvzDEY9RwLrQA0N4B3j5GFPrjjj+m2E8NxRGVoWKhfjY13GNcECEIlm1kIRha/s6hp0jLg4+aX0Rn/JckHxSAmBf6lTIeMsF1NVKN6BrHfN99DxTXuxkyAAAgAElEQVQvvDhcrRddNQtwJ7FqZzii4GaAGj0WTREWwgG8JwOs+VpmXFkvS+PKnyh4wAQmsuCh5qHhdwggcCoYIx5QbhbWhOtNw8vvzpDa0dBhzxWHdDxMI9deKt4b/6GIIHuZLAT71yy7cnF5T9ei9PCJKPfbv60O05+Olml9aCIR/iA4ob1JY6fk3bT5eJhAJil0QU2MDbhkya/eEA5e5MR44WyX/MHg8j9kwAXxMAhbETLtJ9wLohpsWmxQBg8x/FfqVGSkMPj0J5kkTmCOgiFID1ts0UyMxd5mShPIAF/CZANOgTn3jYIYnCti7F+L/UjGFDBIY2Xfrdw6QusUz+dXXQfrnOpERMbMd2UeIms8ZfIUz71FXQgDz3Xn0G32XGRoSHLVRMDcO+/H+yasGi0GEeRldoDRATZifcka3adZGmH2EmtP7YR1Z5/gWHgQRPvsI0aZYawxAglVJeEjRcCbipG4ROtPDx/PCcj+LxlBMldY2vVFIhumlpTuPXoKHl/fGSbng/ek75RaMaL3DqbsSErYlFqMoLrQlJWmpwJa+vuI/C++6ELJKrY2sYmMnsPOnkKV6otZnzszwkG4Xq6MY9rUaSZeYJS+lKEZ+PhAQ1MEQ35hDCyv57y49AXV3rH8GS7vf6HddBzORsvr51bSAPP9qJtGHpmOlGAza9x8PeDdIP3lz5Vu0w7bWTGBbvmB7Ame/Y+akETvL8gOurnoX/PMCQqvlKRe69Z7WuLNpC/t0+nax+dpnuzc2TOKoc+/7IyVRCED8Ng7IVea5MV4NnHt6eB9zboeSieVTjPRNycM5e/xfexMPe0NXmSBIE9A0b4j3fukie8VP6ktqk3bfYNlrK9RY3Qdzz8iAp0FSSIAcXBSvn/UjkFkVNrSXxaou4HnDppHRkqmyR4PeybBeQWuOiUOrOAQYLO5VlCWgHpX9/nK68/gImFb2PQ8K+4jodFMWoIdrkxa7wMqxf5MqVf2fKBEGjJfBsf5JzXQIBmqZCUEkEydtiJUwCAzuldUvwsaBsoGeRObzNcJal999RWrz/Gsec+2++xdHCI52UYSNqGFBkfLtXbvfrmSxJkuleSLgJ5zRs2zceOmmvd6mJNK7oGyFBm9yzsKrIB308akI7VeNI40v/G2KPgMEGYUDxfDjbGICAawlRH2/mLm56IJSzZPmxIImPTS/XNawGDPCm5c/KsNd8o/JXmG5l+PNVM0SOTz1Zc45fo2nCxwTjp/5NFHPenln0cd4V4r+t/IPjdYv6GVg6iBpGEDS+c9q1P1cpMlsyoPQLLJMpLkT74GiQoWZZUK3Nm0n/UjBp3jgAkIMHgoC918y+3FTYp0YVl27XahGHW7+H1gpTL8l6kPqZa0ajkIFznFppoiwDotk1LS1lu1cC8gm/EPDQEnG/+PHCBtGVw3GWIwk8mywnSQESG+wGYy3AnkpfONo8Jo44Dr1lFPk54fQQ2Gld+keD9PJB/m6oH1o5M7WpqyOFBqhMDqX331mQ7OuqrZtFc0tpVRBdjK/P7ngs9ffWWkR45to7rmJ/o3G4pnS82BaPpYQWBoe8KGTXlIIlSTCUr4Cqe5mRw8TgHlGKB6si+UsqDHA6NgbJLpFwYtCGsZ/fHM8rkThfL+KfOXEStrRRbLi30XbN8I9jigvIySlD2K1vSVQYaQwT1iaCAd4ezISAn0CPK4bkNYZTabddw0qDgzMnAc3U+UOXRt1EVpk+mmmit6p6ADPyqoI1oHychAwLNUdT0p4E5GTVtXohURidcy3A8bGgmz62+4zqRA6ruuKekM8DsQqXCwMEV53vTvYiBgmE/8aIICvs/dN0vWRtM/92RilKG4FPYIhx4OMc1NOtbo+YxENBxkKA3FD0b2uXxmme+QQQwbN7SYk3QU7U15hvn5NNoZzP7FGDijKkHgoi7MMznr7LOKdurX/EG9z4+q22D69E+EWq3uVhf6/4488ijXt70XFJiQ1aH+wwtNVV7Upasz89J+/F/Os9KJ1jgZIFsUxgIRSaeaNX3eH+dAjc/1WJHHvheCQz3PpQgFUZ99PKl4ecQzRcttdyk6HPiPaBlzHyfrGefdsHCJAOBQWRfib0+7mj9bZ3iWhyFsKtiSkgwazPXVZoXQBMp1nEf4C9g7nE9VVSOjjuwTAi6ms+C4cHx8H4JN1j25B4LSJHQy1Jv7TNg7gwbWh/NrOBteh84KP4fzw0lj57lugmPD7WXikq0wfA5lNK51zNixZsvu07aNZ77S5wsJjEwcBIf3baHgm6y0e/eegnNnuXcfoicJ3fTpn0pQ5bSik7oE+Bx8BNfQo0cP8QfeVXljc29w7DXSnJBYub62bfdxyxJO2gTaivIk6GBlEpZ7gOte4c47bl3WSAVVFpRMM8TkQw4pozIWCDwbLPsPZUA4Crz4DHl29Cp32CGktlhY190khG0iAhFbSfQhZSZqZQFg0JFaf6dpK1CuiZRxrBhN2iXo3Rnw6CNSmhniXq3Nlb3cowZaDC79nJAtMhpwXbEkGfF51bVA/Z0Hys9VZjRRCwxmMV/HEOFMKEy7oE/bi66ZOhYz6Tjs/zzqKAURb1iwfvSLrxU33tnXPV2XXXGlIycYpzMU3SFMvp7qEhZcKMkJuQb0k4L911Gtc8stN9fPKSKSzUGxCLgH0g4GkfVBcCKizyAucQ+w66KuGYLjK7kpnskiSHTpmblFhYNJ9iq8X//h2NkI2p4u+NP7RsY0fvy7bguaBawqY9+hQ1sJWu9iOCSDJ6K8T1W3oKWF6TXUaoDD0CIlokR8f6+99vJEhZwdCFyZMNMEzVXlWolKRykAQ9aOrH+PPfbwmlJTxBp/JrgN5as2YsmyB1h/DiH3vfLKAdF6o5bZAHuSv2ewk4FRJdSSBiANHwcP5wpsnnsiDTVkHaJhDhH7wdJfMirAr99JLMM9x9qP/D7tBFlvTYSF6+Cac+wU70tPLnU4HNiIF0doWlF3PW+N2HLL1i9FEwUpSFoifJEqLLwPgRVOnOgZZIjgMQ5rZERIkjGflFF/TPGBAEEQxfUCdVEz2kBkCUiBZKAx8WIbBQkSUKfhX89imgzseyLe0JQeBMIqC2UQ5YeRYJJQ6QjLP+0bLdrAs+C/mikvZSLtyTGRTS5fD83sKc+r76dEBZLQ5yxLdiP0dSMzjb0fvda8llkjOM40QQWBK+v0vAg02BZIeeYxSAB+nPq7IfodffQxRedTOkFI8HPjIvl99jhnPAU64AhwmMiSM6OszJZ9AXrl3lnOgKISVcqkJvTLn+wllwhKNC6l6QgWgSBxqjgK2NxLfvmxmC7jvsbaUhZqJq6A9g8QPYY7M3Q+Yylsez0MyEmctZVWqlPMli19+81XPBVogQJmWmhwAMgOwuznOmopqyND5b4h4kC23FXnvY6CLqafcD4Q2IEf8aVsGHYqEZ/UQnbnQEnQAdpNZIazFj39ERQRlBJMktVmYMHa4zsIsoOVrzr27K+89+P6alVnwyQt1FWpmTaWQEtTZYj0n/5E24yyULdAim9CPZNkYYyYuffe+6D9BgEehGWCX9YCVOZotY/BvyArpiT1ioJ/etaXIdZfQvHsP4LSKqFsF15wvp8NXAP2Xk1CVoOW1NRIAxb2fpWm6jLUZ4Bq0wAxS44XtH0XjGFkKsqD8UexmpE46yujgshBtMGEGGBfGmTRUs30nXQZJ0kajvzbZsr6MAba5d7YFM5dYBa0u1gLBTTKxdO0i8F/5LFHpNs6VeL5x9nZ8fAwxhySyrpZPuDqQ/dfNRkOTUI26WhT+zGYvNF+kMaYn+Hfz0nJCJiICfXUdB948EGxH18qTjr5OMEGHYuHHxlYvKSesR0kAUYUCCzKJg3DXwNvWWJPDxoIBQEH5tc131wqPrJJRLOs10JEowU3cK3UNALui/eJzEtTXsoitxvSy6CB9ogljPMqi+UoknBPwe5dGqOYBPlA8+frRG48JyI0Bk+3bdum2H6H7YMsVTop6qUooEAK4lBxAGnz4Xntf8B+dqAtNm9uir4jU60fkDHEHQ7PBNUC35HwN1krWQtkCwwAfW9o1bIncNoEZ58ocuQQkB1khsl9BoIQ5AVePO+ovcdg4XSmCfkma7fSYOd+JsLnnlbT+qexIzOg3+4bwdZE6RwuDhDvR1M8gSJZDHVW9gCOlmdTWY/FMfF5G24ILR6iGizw6AklE1hVn9e/f/9imPYRBoSpExgT+motIUmAKoQFg8B94RxADICdXe+TgySyRpQ8gsSoy2AMT+3cuThLAxyYR0qgw9ep01IWYLgD98G1U0LBQSE0YbhOLS3cz5hxo4t773nASlmNdS4xJtZ3Lt121NSBXGsyTJONymzU61zu83SOGP7qNDbT2fL5ZWqbakTuXS4zYH4fQ12NKuGu/bXI9Gh+r6OhyjDX2fv8HMIeG2ndhwx9Oli4gkXXlmoYfeq9FGS8+ea44rRTTna7FfVlzkiqfxEQpIG0zShRn3SYlTXd/FoGcvw7bUic8+jD5dmkHeLrUY5Rr6fOH+/H/qWe63OgZ+J2KByLYFJaYH7QcIh6soP8jLWHCWiEXvFZUStHfzvE6Rmj97Uy0DlyeojZryL9bWatztf5wg5tuEkjyW5u4/0LYZEgm0wv28FgHhO0Q6TxCEYU0HRd8Cv4k33zp67dgVVC1CBlpSPlXPJ3bFSMUgu1I36XYJg/cZARFEXyRM2f9WDPrK+APie3WIxe9gU7xbAKkjr2qRnK+h+av3V1XZOEIlDvxf5T4uDzyKS7d7/K3AAcsIOlMkhLmVTkXAn20X7HLaB1zM+B9EUbZBAtaY2Bu9KzZ3dPpwmCWGgkpCY1LZds5/+Gdl146Ny50zKcATUSspgf5AxQj13ZTNjfymBYB1Bfg5S2SGO8qKGd1+1sb46HHh4ghZ/3LTbwpxzuyqpN/Ofv3wTdqGan98qKixo8/Gq9+07F/qq7woproAXFYdFe4ShOkWUcxJCHqiXjPkjDnxlnc5SyQiZgjH5rrCDCTbU4Wzmi5MUDShWL2Nw18nGVqTgPNyCRoGYTPVUemjTgLnjL2AApMIKM4jNZ98jXXreDgfF+WpdTBZGNLfrfcY+inqP8UEarxsxDBwbhZa1cPRAMLg+rbdu9VOBnXFEdCcK3cyQ9e3aMgluqzUukbbYvhxvozJs3SAdsbt7DYgt8D7YtUTWwDbUKwVM4VRjANPgDCwKNxmzMP4qv1coBksAa7KIWCgruBDFk3jga7h3HExlE6IQ+O2SIHSQ1WQQYOohRjUD3ulJT4dmzIXFCtBYgnUb9nPYQEI2NdEgxwXUF4S75XQdazFKyPKBHpAgP0VgyIOR5MuQ4DJRIeFZJNorAhgAonEc6zAyAuF6ugeg7+oAD7sksJuuklQQQyDn8PtF6TIX5jz7/G0e/fH4jkTyCpCMZRNWMeQ8EGSDseFajrhPjF58rSEjPkn7ozRVUIG9ItklNmwHNHpys2vMF519gtAIW9ZQp0zTPsqMlEUeqf/ovGUqcAb8D9EtGBVkEIghBF4Yi9oegXa0bxhQSyfjxH3gY9HXX9rIC19fS3M3IPqFAkBbk3rAeU8RwrK1snBo2JBK3VenZkY3ffns/vd/7gvI30/1Sky1HA3qTlRCu9kO1IwdpKmFcXGnCswk7VmZriQikT638d/SkRhZjUNgIUgjDh++NkW9cN+fiN9V/+Vn+DnNy/rwFfvYDBz7iwIxsikCJLAuyJGUHShH7a6YynxvjGUPakDPCKwg80VOdGWhlBl2arOo/MgjzPVK39Lpw7ZE9J/qUAYEdiBwE2RBBJQxUZ18qE3F2+Xn4HvwuxENqcYxuAx2gLmioVM+JzB3yGvRAAgv6+9+RtOU3QpkoGf2u89WoUZVspqYM0eYlhIfST0CWv1QHstgoUJZ77703Wqp0TZ4rquBvA6m4HXzQQbbHc+aojMb4PxIQXZudufYe9x/kvxjSwfuhHR4ogcbVlex4nB+BP7XZPLtZNktyICS5DIo3VeDHtZLAQRIj42VSEm1E3PvOO+/m2bC0dIEckgGDrrH3Lrn0Cp2bRT6XcBXYG8SAnG8+ExUlzgaQLWvzxBNP2Ann5qYezTxVSjyndj61OFhkvrVUQrESXKkoBtDiHmUCeJnfSkcam0NOuXGTzZaRMREpwq4kLbe8XznT01AH9TreQb/AxcAQXFFGup5o/bPnfGs1CIr7LozrZWiISET/GdrV5uaAAgkikPCrIqed2rQudhA82Lbt3iZlsOFYDPYl18PCAgvSZHvdDTe71nfJxeeKLPG10/zWisDIYMPJBLSQzM4Qki9chA4RiICIkpCSURK/gzFEigoBcpw3Ti8PFT2VCKtDRqCGxkGA8POzFr2d5MUef/wpOZEPizNOP91w6r333mfyEwfTeqt6fx4ixKja0qtFkUPu1ULwmysj3X333Vx7Jdv+W6PYLGmn63W0bCOW+YEOlwxssGxLzVAZGgw+BBOgECJ1ADcDcDDK9LiWSEoQQQMgPLLGg6QXjKQZIhO8UHSpfEX0FY3TX2rj3n7b7f42mrP0zzIrM4kYwPM4z6lqFxijHlvgT+Aj6tf0LrKpWTfEsKlXLVSr074d9lHmW1c9Xp+bSNFKMpHMP8SJAQ9nFJ9QfKhEBXMwX1mjzKygEsrnZ3gPDnr+TjpSSBWQztZaa3UTjIDHgLcRW4AYhkwlUBO0d2AdInnWI2b1aiKRFZ1qOzuPyRGM/wOSCkMSI+0iY8Cg12aSkPbKWWd3rWaGr1d/HZcJQC1wXuhYp0A+60WGTFmD0Xq8+HyMsUkvel8+G6dBG8Puu+8uFZ2r3br0O4OVtRdcs9LvsO+pdQFt1fZM0t+9ry20LRSAEomRD/0bdOLRxx4rnhr0rA15g4b1vXdrxqzV1D6rHV94Pq7QxqzGmWYAGxq7+arsN8X55L0F87eCwFP9nMNR8f+A8YBDKT0goThlynQp17S0IAEs2HvvuctastgE75uKUkDUK0FvsrXHn1xee8XOLzPS/w7A8ycyAMg9Fdl4tPvEAAiC1rAv7AUEGHhRE+fr7B0L5gsVQf0Kti6BUaqbsWe4F2QleW/2Hi1XkD4zKw8kIPRu/yPH95FQn8UKonbZeVfZDsg9Qlz083yfup/5F25949pgpQqVEepI9veoyma3Skd2oYK01ZTh0ROKE7u59/VSBGrja6ZUwf2QpWJnuC5KCDHDNUp2KMEt0O+x7xL14+zh6KLurt5aJQuQG+mLzrrpJPXhcs88L353LQ0FwOk6y9T+pBzy7vjxxXgF6Ni1Aw7cX10P+wYXRkgO5YyNRCqbN29u0aNnL90jbTUS4ZAdpZ0sSyE8g2xnpOZJnZryFLVik6RkX0CI5sH10avXVVebPIpgh8fuGTHxQVRpJPYz26sS9mctOPcrbLbZxstIY1MVI2psGhVU1uY4UEGEKOudZHWMINP/MBhkFzNmzPJhh0CC06Wexg1x8eDVjHAi6gY+5CGR7dDn87ei5tYH7lucefqplnIiimZhOezuw1JUwxxUIo4LL7rCY35O6XSCWmReLHZTVrXNNlv7gadOb0JvmTFk/SwjiDS6mZGyMEiIUYtqrdpdEk7yIbN5yMh4H7fH6H+vSUVIN+e2g+49rrbecI8eV3gTPPTQAEVNU9zw/LOyE8gtbATDNPpzbenvIgWICDyRKMQAIj+ue6ngHTYW/3F9ROOEu+6as/ERTOIIOBi+GHGrisgA83UCIDbuzz/HwHTkBD/7bJYN72GH/cNqRUR62CpGLuFYAzaKbKPSSHA9FPfpGaXFpYFgTzJFXj/LCHzw4QceakDL09eKbJu3aO75izFNob43NFqmDF7/TrWKltIcPuWUU1yvgxELwQhR8NZing57/nk/axrn+QwOYA3MHr15yQzMQCkPKw6D6+d6U10r7ylGcIWByxmm/AmUGusY9wzEyyHnWVMPZr8yVJj2F7KVDMYwhrkGGK1myqbRQ8ZoZF8djdrQ6KnXsT/IVrt0Od0BGPfVSvuVSTejpGrE59HGRDCBjOYSOYydJUsGEejZIUP9O2SPRNTswblSfeLA0h/5/vsTLGF2o9pgLHAvw82aRC1Ke0J/Mh4Ko0EWnXU665PKufPZSDKaHQ0cJ+RomGqNd99zr+ulfCb3TgtbZriBFNUgt6WnC/hP+yhlB9kjyQZPx5vOi/XOtQ/7lA6Jnwh4NDpq/V3vbwhg557brTjs0EPN0L3//gclaPCKyVr05PbpfaNKDXs6KMLG4LAyIHTWa+SVa+fr5HQl89jzcfk+N5VjBWsYsZlZVzrRdLRhUCOxWCY+SM2/GewgfXI5HhAIfpe1Z99i18gOHbzrTwZ3gy5gW3ix3jEsuq7Z8LSNYAcRK6mzatQR+UwEH+BUUD5YqHveXsTQHJDARBbDyM52o164shwA2RQ2AW4Je5UWmPs0a3mA5uySPZJETJw4yS1o3btf5p5vzig16Lw3yg+cw+zdJAggAP5JgTJTiCCkproRpKXf9XmNhIgwPtB1U+0lCJMIuzDbl8TJLG39r5a4EDh40LFnNGHncgn719e+hZQHMvOpeBQgaNdff71Lg/BSGgkCZn7slVf28qYkMGf/Q96qfCVyxXVb35j6cxm8YRti3J06D7TufdR3vIV6eH9HaYlnTDYO44uQ6S+hAbUyaKyBw/GNLok127yxzgpGOnRBMT5Lfl+ghxeT0sNoy1CV/Y1kmTwUtg9ROBFgQjIYd4woMAF1Gli6MHPZ8JldhFEL6ArnMVUR5pZbNi2OP+444/pE47wHDzuMo8SCRf2/9vo+Tu8Rup86bbqjuv336+B6KoYmYMnA5HPxsmbKv/NQm8Zcbl4MI5E6kX620PD7bPqMOtgca6t2wde/nfeNCEjPKKJZx6IF/SVjyAM6QHXDTp06Fc8PG1HcccddYkPSBE7LUPR98XBrQfYQDEJTPUzXBg3XF9Sm2lRp1H/W5gNmwIjzIiriUJC9eAKDDByvv/6W4zRKEBkpf2daPQd21lffmLELuxiH0PHgg1Vob6X+MlHHcRoy8mSNNn76z9NGuMoyE8g/0zmhApRRJDJYyP7R5jNu3LhSWUXN41qHXxQ0fKYs8+CDDjYk86JKBdTF923fQS1Mu7g+m8+AaJksiOhwWzmVJ594Uk51hsSij4+AoqxXU7sBasSg8jUCjPw+xoBrBe7OQIBnnRH+8uxeTUmRs0nEggARY54QMa1V7M+cXcj7UWtE+i2IWgHbfarAj2sGWlwokhBQbrNmzS1Sz94h+2CkHEgKwSTvx4H/t6BdmIbA7GsqG4Z0htQZr3Ya8MBM3fHvjvezYCLNsOeGuWWJA7q32LmwO+ElcP0DBjziM/GJiEg0mN8iGUdq2KADnEPOmHa3iUxc/3xNXFpTWrHAmozMYv02Uv0MKBjjxhQOpolwmKm/jRg+XGSd+12jhbyCISFQyJr0cn2mWv9wNpmVlo3qYTLK85bnLkxJkIViz4VLq3lVQ73lV8l8EH4/68wuRdeuXY2GeMyfAkSc6ROPDzYD/lA52Esuvbh6H4TZy8+HZMAXaoIAu+zKzNfRQWTd/38z0hqIOibhhBCDBrsLHeJFJsl+99g+QbW0l+Ua4kxDvCBKF3yv0kFz3rCv1DpJbqgJwv6mDPSnlK+Y9MI6gOoQqG8j9SbsgOt0rvkxgCLaqfI6ee7sd0hOZs/LCWGXLr74EmV9EwDRVWJoUHz0zvtFn/59fW5BkXIubFWVeo5VrqBtCkiZ1hnKA4f/47DiCPVbMqUI2Vb6PbErOEn+jrMbow6Bka+NUhDBDOGfnUGfcOJxtpufqy2FDBSUCuRxrmqdF150UfRHK+PM0ht+id894YTjimOOOcacAMpSKEyhFEbGTb2WdSC7jvJAyQj3Hi3sMLEjVibSuvFly9VqvRhRSMnq7rvvVilKffiltniw2PVeDPjQ7+FI430JuLDJwVwmaF9hiy2bizAXhBFqpGhKbi2vPEmQHb8AzIOEFjMQA3oN5lxcFP2X0ce5majJiCRQW9xd2R2GZPiI59VrOUHOYT397J9yePTpFY6AyP5IyTdWRjdlmnoway0rbup9gyNNizxbwSKYb+vIkS364XtJt11Y7CWGbPv2e8uI3C5H0VFF9pgTh4FLB8lnZAadByQp2nntrj/o4fM71KIqod+EA8JYh+PheoCW7tMhXkUEAZznwCcGic07tmizzx5Fr169LNF3xx13OupjI7ktpWRjEhli+BH+d8uP3m8/1RzJNrkO+hAZCA1zjM9bJMPngMMklyCOEPD8qQZuZ1paF74fjFFgVIlCzBLFXpFju3btLF9HOw2biswp6raxEVxTLOvEuT7Z55cBlSFKwTrAgmQxkxSxTps+rVr4HPWe+YJEdhBRickvr4163aQhPotMs72uAQMAV4WSATAiaxF0818k3j3C1w/MSO0QB8PBY2NGAIUxCAPEz2U7Qfb38l5hiBSJKrPLGnIlbM8zhWof9UV6wKgDRzSJo+H51q5Ty4aA/dFE5CsyK64vUZTIcJdZdxhxb6J9gjxqKmRCSGuSIfDi4AHdEfVSniDrvuqqXkZa4npXdFQM+QWCyVFHHW52IXNQQW+QDpw9+5Niz9YH+OfJ9DmwixQYtWvfVkzc6TJMozWdaawnVdx0U29LxKE8xr1Qf4e6CETMucUg1WKNdD2o/hAIVOkeaXSn7ksAyucytYc1IpMFqu+rszXxo7E62xpUoWcaknuUKoJJzp6qzlS9p8q6ES0teK5qI0bGVwPfhpZ1ICu8SRokE3ackepaaVEqa44QrY495kg10Xdz3R21KA920N5FR7V371tM1Orf/9awVSUJr9rR4TQhlVRDu1kqsYVwpur2Mvo5S+ObSEWlc/tvaDd/xpl4xYQcvs7X2EsgUpQ2sC28F3VRWONulVEdLxWRuBKcaZ5D/gyi2B8m1awCZIx6lUHqtGcAACAASURBVOwDvIhN1UJG8Hf3PXe7vLSbkKYgOTLAOkiYlY40URneNwiRMcia58oISIhHvXpd46EM8+XImJGKpvhcoU2pUbtUScEN6it/RORKEoC/Df3T976KROB7eHg5wTE2hHuHUUx55E0hL72uvlblv2+Kemsww7See+4vuuDf0io+3rq4oIkNG2zk7PeF4S+oE6K7EqsWtiPsZRwfLY4Eu7TdMJWKRIQEaNiwYZ6kA0mLc0u3BGcre6HzuSVKZYnBEuFiPYx86lqRMW3Xtp34Pg9HsmG+Cpnr8h0DkZFGcMi6ci5w3qznCnvuufsyao3UZpqotkVdBWIJw61xkBw25MXoISUapDhd6bC4IHqQWqneOXHiZEO9UI6p2QAfWBOy7C/lwyn/EY/irJhUAuGkqqqRWFmTLI/V88rLxWST2Lii4oRoqb9huLv3vNJG8NxuZ2mA7VOqMX1ddFavGO0E3y/8rnoTG7cu2Z2ZyRAoADdwT//tcDObYYGynsriZGMx9+BJN/rsgY8/WUwX1NC588li8A6T6MEokXDaai5hZ38+TEjqXzBAcW41mTDM4IAV6gmjp5a68w47CeqIqTSLBVtxuJH1wjARfWZ2HUQGeg0h1EQgwzp8LwOK3iT2gykse7fZR5J8W7nRns0MnBIwdhgwHKlp7NRTy4wiHahPsl6pvQsMz2u6yFXoDHMAuE72CRMRMNLUZ6nxAjcSOG0up9i+3b4WISCToUQQiktBBAI65V6IiN/QfkK9hIZ4apMYHN6DA8LfcaSG5MoMhecW4h5Rr+GVsBkbPqGxpOnzfTtKGSEORaIM1In49dwD6yh7A4IlQgbSMrxY1jkxZobOy8CRn6PW2lj7jcAqxEiCSczvkMGTIS5csMhZCcb03vvu0T79yucISJ2B26sggKG937xFExk3egC/Nuvwiy++dD3pwgvO8/QQ6n4YCya4NJbzI8vHOX8xc5bGfx1bnNX1bDO852kPgNqsKAONdjNkFJ472TF1HjJdgjqMFoFqPQWxf4igAvwP656eQfYr5D7WD6N4q4TXx4wd731HWxyPwVAcmU5ZDkjj7z1uAxPSlzVfLyFffc/Op8xI/feKjDT4v/SrS9XJNe5AtlAsIjt44IH7fX0QilZR4EMNHwh6oXkVaimTE8mMrzITi6EEldBujcMMRxp7Hnj3/3KktlTlvVZCvbm3ApoOAYc8T0k0yjXgfnCiTHLh/oCf+b0M5LCpyShnD7Gn+ROb+rnOB+P7eHbsxZ01Hm1jBciPPf6Y7OVHxaUaJF6l9hACXZAzfg7o1NOAxEXhBeJgx65zRcDIPmR9CVoRZuBaEEk59bQzjPQNfOwhT/z6RvDrTjvv5ODpMQntIyjCMAcC+5SVjJrj6sVDD97vshucAO5/A+1T0MNTTz3DAdym0v7+XefIsLYyy5kSBXly4CNuSyHDbdSoiYXo+915h0bZDRFfYgOfqQjCQm2L9WVP76xrOv64Y31Pt/Tt64AQEXy3TilBWE18m6y9JrqYz85k03KsIgF1s2abm3vzxltvFEcecaTmj95ezNfe57NSkCKdKWtZk5GG/cmM1O0/d93dz4IMLC4XCrMSdifACwdxI9XHMGzUywarr/JTNXQj6RZ9RN7/Tqe3EdRESwOiA9R36B1EnDmGMyODRstCRLOlHfTXqa8CkzFuDIjvqCMOVSP1v0o9Vw3a1YMLsYe1lXl+X9x1932CEA90VHLGmedoNt2RWtjjFcl/5c2EAc6aENeIAaZgTq1lppSJcGDcT/Qq0vyLXmbg3Cx8ZA5BHIj/VnG9iZ9HG3eIxL8nTfvYD/PVkaPUx/ayILImxXGCppkYAvz2sESvW2whYWSE5/Vw3ROq/QAEAcxHhLWhNgv3QI8ffxIF8V+KUxDbGzLQL3JP2fyMMV4k+JYZeFzv2lrvtm3aKdNoZqYoKkewZMMAhKHAGHpTyQll3ZgsMWvGUbsKiTycLBsP4XRqH6gjoQwClEJdh/UC5qQlgxewz0F6HkTGOJcgeNSI5FNHxfgzzJhmeWDHbTSAGqFsAizWmANobU8FcTDtYo5ozEMkurQKT/lcuNZg8+LAQkM36oMlXZ9osQwSuA4CAuDsyHSDccumJQvgvahVM8HmG9XJc84qRoYaJ4FCrjtw6mujRsrJzFPg1ti1z7qqXaGhS/0UQ291LJRdhOwAWVHjf37Y84b5hws2pTaO4AXPDuLTxpvQCqRpQHKqRNy0oqBxvXmzFm7HaaL1gGH5qTIzMkcyW2QbCQzorW6j/Ua9iXtnAgznhKw0yXFkmd+LDQxUyPc20ShE9tRstfxwLjHK/HumSE9kObCP0SelNxnjT4tM//53OzNCb/kvCxsEI917xqIhEaXnmocDCYca0XtkpWzGhHaDNBfQLj+HEaynvRVIQDwrMnf2ynPPvVA8M/gJkRLbOeCC4AOywHvhMDjr7NkoMaHUFRlxbP4aUf0IyrBB2UeQNVJA5rBjXJBh38rEtbzXOEnx/cps9a8/6TYIgmAKxUDa4t6xKUYGEFzhHtXSBzksy0YEuoixYG/Wls2shGL5Gj2i7C2cLeeKejdKYKOUhXUW52DXXWGzfm3YFZvCPsPeUXKDDY+jYx2xr8gK4kg5a1Xa35tVSedadm2JOALUnrt0Oav4VsFk7xuu0XlYKNRjooVWKElcdjnM2B9NDCTBMbGoDJ5Y5+5XXG7iJJ8HZA0S1a/f7cVTTz3jIIygh7XhbOMf5olxfZZkYP/V6UTZkk8tJMOevrx7d0kFvlVsvFlzIz7Bj2A0Ztg/7g1bs6VsK3rig58a5GcfjN0Y0uF+d6EW7IvmqvmyF9BPhqgUHRvoi9OmtaJ02lu6Hj3ipRcFc1/sIe1zlT3z+5Qeo7QU+4KQ6X8cqT47n/kK519wzjIK9aTSHGQeAA8dUWak4LZT3XJNGYWtNZEA1tbjwslZEDJTbhajh8GJocfbe0TNIrF6p6ohPKQHoXRDuIm9TcTPz8JUXblWfJGazJp6Pxs5/cx11/a0NNNPP/3gzUf6zQs4uHv3HiZogM8fc+zJgtd287QSWgcgeqy5ZmScPHgW2LKEsNj0ObQSYJQ9JUP3h4PkM1Guoe7FKxi/AVclhIPRw0iyIZ4cNKj4ePpnRbduXYvR494t7rrzfrUDNZECR1vBFScUg59+pnjwgUecPXAegR2ttemD/R+vD5ujoeDBFi2aumesmSjsZCJkY7CfcXy/y7jiuJmoYhUffQ0234JF6kvT81lf10yNkYksqyrjEEHPyjbUTsOBRv8T/yl2clCUGRzRGM690ihkxspvwhjEGL/22utiLX/gLGxjCZ3z81MlN8dhYlQRLRjbtFQ/qLKcbD2xYomunfd7xbJdI3zfaPHupH5bJPJQ2YFIA5S6i6Js5Ae5RyQJc4pQqJ3U1Lu5LowLmQ/GFyIChwsDClmO30toJwleSU7C4aKLHHBNkOcwfnyfmhXZO2aWUXQ4na3krGgdoVaKpB41tiFDhxV33Nk/BnnrkBI4nXbaqWaVUooAcgO6I+JeVeuHYQPBeFm9uDjoSaLuU8uk9mh5SwUiBEgEnRhmnDdB13w1yHOftMXQAsHEGMY5wSZ+/z09C7GMeaJ7q5cXmUCLd9AaoT3B/gARYi0ZMGBWsbJi7j/rePPnS2RChmJdjSwEWeCzCTa+FaxH0zwQW32JOnANXD9DBvr3u8uEjI3Ee+C5Jjs/9nRZWywdTf5hB1vhTNMJubYEL4BsEcek/7jeeaWK2LYanD5NvAlIXvRe01J0nGZ2djm9i/ffEomPkGU7Q4HIp+tPLoSzXB/cMH5WLYRM5DOBY6/JQuN6wueuoElXHJPsM61UlOK9Ku8zsxvX4a22VNMnTZZJtsbMT9abvQDBhueAc81MNNeM502wwwuoF7Iaz5E9yWdSJqAElAjeu9KofunlV8Qs3VOZ2a5WzaKDYqHmrdIXCnKHDcGe8bvsN/7dQJwV0CHme+IkDhR7n8+lXxqYduKkCcVll/awvT75lJOcTL348quqR/5TKJIc1tPPiky4gxnq+RxjWhQoW23Z3zMd6GBzcZRofp/4r04erEDJj5a4RAx++5Wgr6FJmief1MnBxhKtG2vTS4LynGO0q/EtJGgJ+VMaYt+5pqprB4njDHPPwP7rqyWPgA3d85C+XOYggi4FhptQVzVhVIjeb3omP8jn7bLLzrrXRRr2/b7GKF5YHHLwoW5Dw+ni1wK6VyDo+c6xV1IgJ9fBnBuSxLXXWXnZD4siysSIY9DZmLwJF/y3CvpLFXXxJtSz6DkkqsEhsvD8DCkzdHSyj3xtIuYqhoqfyZYEFj/gyjDyZKSpVhI6m3KAEkw/WYIH1D9/xmiwUctm3w00oqr/HXfYIJ500gmqnVygLGmN4sqelwkKWV8L8q4dJNNWaGvgs9zgrIs307OUjOPfPFxqumSooXQRMCDGgxoM988iAckQOHjmqf7NnNSPJk1T/90txbt6ANddd7OM7kbOphj0O2jQ08Wdd97r0U1kJ27XAPrxFA3VHdVDykNeVdlMI/VMtdx6K2cbtGCweWCV2jDq4XAtHGQidiAInAetG8xUBH7x6Cd9BhkoEAy1F7trDr9+1S0xMlpkZGQ8bFoyv5jcEFM9YmZkkLTSYNCPRt3viUFPFjOFGFAjR4eW6yUgadd2H9Vh2xvmSQidtaIvkYkjkGxoKZono400YfPmzexkGFGE47PRVtBDfesAKVUBmXIvIBo5bJcaC4EBNxQOMAxmEIyYBoSjDQJWbe0PIE00boNlFxkJ94axIjCgB5k5rmQ8zpiolwodoCbCnub+x4tyv54O5M4772IWOdnmOBkvVILelsAEGSGzEmcJ2eB3zzv3nFCokZHE8VOPdV1W97qq/o4zHTvubUux8UxfeeVVryXIgfeXzta+mks5RU6WdUSsgroUWbgzPq0p458IFFgL2rHelmNr1KhKxqur50pyvowkKdgj0EPQgd8FAsdRYMTNmNfewbDCJ0BHFCOFEw5SCVwHZRsyKrC1EZPYSIaZfcveQ2v5iit6emQgQSjkLTJcznE16lEefPuvMmsjEc1+wxrvFj2d/jk9R2rJCL78LVbklVf1lLZ3ewe8jz/+hBjyrwUcLcPar99tyqSqip9F2INYkns1IOJgpmZgWG2EKlLNvM50Ylnnsj0qlY1sHO05IziIWm7Au/l7+RmeQ6ogyuur7H4lJQV/abxZCEtE7Yx95yEGei8jNTrTHkpRZugwxrEPtG5wdvlMkgECfP6e9pL9j9QjvbRktzBMKa3MpBQAOaa0sZwnnos5K/xdX6cGOvK1kT6XqIvR8w5hh8Da9k3re8ONfbzPsYEn/et4l8ogzxH83XDDTUY/rGpVJhest0dA6v3JDDvL+Z5/3vlCnT4yyvSd4ONrr7vBJQwc3Oefz/S9cGYoGTJ9iEw19GzrGHWE8X/n3fd6zB3rRbsfwW+WYMh0zaJXcMLewWHjP9zdoTVDlJ4zSJCOrcdxYh8IcFHNWqAsOwilUbOn3AGcjIDHVyqvXH7ZpREMKIBLRIxnzXtx3fHcI1DLYCptpoPCTTfdZBnTLzjo3CyOiIg5J1KkUwWCIFquqorBznlYSbtzU4eDpB2B91nirJMXUQuQCuOhWFw2dQpZVxt1XSAGfb5kAxmGfcEF52p8mCY70MRPVilDgKweGoxj9d9hGqz9poT1GY1zpRxYG4kUT9aDfPFF9F83FmFjdxsY1yhKJ8KicI8YAiI1InBqEbnRjZ/rYZGxwIjD2HmTlkxjoKdBqs0OeeyZ4tGhg9Tr9IFaEG4W1NDUvZNd1MYz+aOPVRd7yEeSaBIolBfr6MZ63T8tIECKq8t5MMl9HbXFzJo10xuB+jS9pH/poJIFLNaGp16mMr5rc02abuH3MlRiGFFCDdpQegx+wESYtDSknCBrSp0i1iLkFC3jqJ+pJBjx3EKyLWo+RLTAkvff/4CzNEQEuqomR8CQsBVRLu+FcSZz+lj1CnqCZ+peHhrwqJqb0WQWJA5ZjTqliFI4WPRmCUq4FqDMrVTXZQ8CE6dgBhH8auUYNQIy16ypc7v3VaPLVEsmqnYPlzd3sKIhAyGqDQQeo45qHDDXjeFJaC6hbRjgGOx3RDrAMUKW4vNgKs8QAeippwa77AC8ndODaENaojo27UGHHnqwsz6ySiZYcPg5R9Q9+ftbEvpnH02Y+JFQntmGjTkzv0r2kYCTGif9qkTpZOlk4tQ+mzQlWFrN7ETWC+ESBhijanTEEUe49+4PQfkYdCM9KOcYhYgaeuy71BmmVzFqbTE5R5A3k0KkgAVixLoD5y9SdkNPIc36jGsjGIG8hBO+/sbeniSzntAUsmVYqtxHrmMaGAKVfLlmWj6fcF41Gq3mI8hmfCM4rYcUZTDwBEQB+64gouL44tobegvh+r645aYbBR/uEdyJsr2j0nnmM81ryM8P2xQXlHbKTlH/QbjLTDAC51LiMJYunKpeBDQEKdgP7ydKVZwz2YpVZaNwRh5CX5KEooQi8Qz1R8I2RnsZx8U+hsDH14AieRb1NJ6QF4ESARMOOuZdqv9UAQZ2CiTOJCutHeQysjOgd158LtA7GTy92JwP0EJ6JdFcpt5NixnlGUoB+++3n1GQuqptEtR/8sn04oSTOsu5CaWTrWJaDm15oJQffjhB5QkkB5HHDPSR60j7A1O3luzyRiIKdth3X98fScHjYuKPGfNW0XqvNl7FcWPfsc2zbdHaLZYz3XW3XR2wMqwCwmWfPje5xQuhBcoMBDHBNo7gl3IKxFag2EWsp/wRHAX2cU6XonWTIBUiFbXO/fbv4CRjgmDqKNOR4QbKteeee9qeDpCd+kh+4yq13Oy1196ytz/5c0OZiRnXNQMzbF8hpHBX5TnLfbaCsjdBuyXrz0OXY3wQN5SeOQ8G3+Nn56sR9vuFqvGonmIIy4YDLLsmKoQUwyImYYiNy0aBUYyDhVmWNRM2g+uHWhTm8C2QMz2v25nFoR0P9sHOhl9kCWfO+kI6vI8WHaXCAezTu88txRGCeU89tZN7riZPmWRIEjmxfUS+IXOjFoAjQYgAVhebIeBrkWFkVID2LBStF/fCQlb2HrJxeFg4UhRT+t1wW/HkC88oA55YXH3NddoQ2xYdOx4qzH0LQ9F33XWfhn8/6+I8xt/ZdwmVEUVRn6NGSvRI/yUR4Lfzv5GuZBM/ZDKPJWLiEpgAm6KLWV+C/Th54QzFn1o/Wmp4LkS5xUoceWqbAXnFjNE47DixVBPJ9pDso11eDSrgC66TXsQ1GZ8n6O/BBx70ep2jaTymi+tDuW7IOWRoE6WDySCDMdI37aFaCXUVRDO6djvHTEKiTWqAGGd6S9dVJAn7LnSV1xZEuYf3CHVKyggYA3RjKWmtAZHE8xhX8x7g54joE0KLYG9Z6Pbqxd7EyCYbNFWR+BmIX+wPDAy9fjx/+kdhqtOmZb1NRcVkxAQLtF98/sUMXfO3xdChz/l+o4whTWgdLiB7smqeAf13jRptoj7ZrT3snVoWI6o42OtqziQZOnViVLKYxMIIM9aQ9aBNaTXYhBgB/Z1Ab7W6a7gPkUOMFiovnOSYsW8pW9xELTX/9vr9KBQo2754NgRHGH2cFTJu4RwCbUpNVP4NksDewFDL5XrWLGuEQ069WzMRtSYEzZQXUBgicLr1ttuK519QvVdnlew8hpfHuU8pNdak2qmWqEfWJqlP/UmPr/YoRg+DyHSkqyXrR52dYIHgCFiX5z1HrQkQ3lpu1aosr9TUaKuNWPl5lRlpZqCesOL6aNkPWCIv3D/7J8ll2CWy4mjlC2Jevgwj62djPJ94FUJrWG/66PlZzw1lEDvCGEx2UQBYl7m3+nrC6lnPzyCHsgF7YFO1IwXxElH3QBPYB+FIvw8GLP2P+mwCPp6jS2J65TPmPQn6+B0QQkvl6ZV91shEEjyxr0NUfpnPHlnnzTffrDajt/y+kyTHeqRs6V46kx8pG8WORvDNFBlqkVGywLbgDElQ2krAAbY+ge3BQhFff31UcXPfWx10bK9RmAR7kyZNDhRG10cWBWOd920rZIvy0OTJUyUucq0yVDlVO6novTf5So6UQdsEwJxvBpRT2mKWMeeNshPyfkDC2KlNNm2k9VrPvdwEvqgm0YEyX5mqW+oQMDFfYFOPehw+/MVimkpL1/S6yj25JFc8h6z7VzpSro1n7Tab8vqq97l61JZh2ID8qANCkllXg6IxDGDtiRUbMtQhhfWF6ADEEeAC2KaoTPAAuZmslbHwvOjz5MN4cOtK2aWONgQFdCAKIBpgx8Ci5UiVvrPBaQNo0bxJcblwa64r4SsWiqh54BMDTZSADt+9x7XFrjvvoNFIZ5sVx2dBpgCmIxpmwgVQFYYUmBdIC8OM9iYPgR5RPpvMMXsr7Thl2CqFG3AIbIpXBTcNfnpY0U/Q7ieffFF0+/f5lkw8/PB/uKGeDUUE1k8QNAEtLSgojHAsicaYP4iBAJ79S84ejVngBybpkPmCTAIrNmvawhnOeoKezaTVcmL0BfjG5AzpngZpAfwsgpY4pDktQrUWZWjA0txLGAOavoNIlUID1KJ5ZZbJ3zOLiz5KjTIr1aF4ttQDUZqBxY3jIdLl0OBwup1zttnL/MzpZ5wZGY82JtkWkCki6wd3PNDs3owmGXvFPhotZjBD2qnRub6NLnE5oornjmPj8NUgGJGBupakLDimU4Rh9MzVMivl+/wdeNP3rWgWNiyKJnw961R8j+uGMIEG8Traq1MlTfncULVwaVYiurmspSUTPV2GWmTwAzCsQMfItSFJt8tOu4jw0TAyfz0PavQ4U5SMJk+ZrOz9Y/cLkz1AauBaXLfW/qCnjvmnPCeCBwwgjuojsTQJfDorG61SwIVRIYiiFsrwcCNBMEK1FXDyGURUP0+9N1mQAwidA2sCK8Bk+xBgOCjRD2f9EzEHAjfqkbwXxp0ghrP44MOPFkOeHWqYFbYmDjZ6GWteONMQRAiYOnVNXcLRuhDQ8nlr6v4/Vm36lH+dXJwh7WCM5E8wTlk3lT+4DtaPoIX9m9lv7vN0njZ8LhslmSgz0GyziYosP591rST+ZHbJ9/I/G3T922Up1wO55pUshMBzcSeBM0jqz4LAdTZgQQNBRqtdDZMcUYIk4fGsPMmJbFjBBPaMtY8WPqECOvvsSTJRygBkeKsL2XDTv/5HXRbpSU8ycu2XrKmOHSnPLiQ/Q7GMbA5UJBGdmQp4gV7XV1DOGZ8x4wtJnZ7hfQfrH5H4C/59riHXHwUdPyX0re+tt7vdiyADGwlZMmQ+45zxd5KHI4843MHdY5rZzF5nX1Oq4b5HvSHp1LLswfOn5Qz7wz2h90swxR4CkbOikJwd4+moZ/JCQzlasEJ2tWlVI2ebMwlQVf8EEdhGTptSDCpue0j1C8Icc48b6hxSQ6ZjA0i8ngL55J/suOMOxftCWChJ3tznRreBLdGaIV2b7GvujwCAfclzZkoMQQ/PCrTIMD3WQCNjlrVXjxoGLCeWc9BIrXF0kFxgGRJJUH/xQsgAYQiHq+8HgQIMBHVGCrEYzmBU0vLApI6A1wKfLkxIijE3Hzt7IDrgNAN5VkOFynaJxK6+8rJi2222c+0mIWbYiffdd59/Z7ddd5YDvUz9mO2Kc885y32ekCmoqeC4hwwdYufUXv1WRIS+Ydd+ldXo4MPk5UFyWNkkKRaRExfYmCa46PpxFkRzzNJ86ZWR6p9idM+XxZlnnyMHsKUcf4visH90NMuZhe7b9/big/c/KjZUYX2pp0Moq4AgUx68hpJiw0mut876ioim2ZhCKCFD3UrELnqjeKXcopujISTUDqECM6u10TwgmXxUn0FGwYtrxbBRhOcZZMaQ0ROHj4PKAeNgZaaZzpT1YUNTh6mn4CQEnP9j9tvDAwaYLRlzBhmYHI3y7BmaprfffltHiIMGP+txcTgM6sBt2rZR0LCtA6NQ//ldI9k+MauUyBFDEtq/HNq/IyNT0EWE6Ei77D/NQI2RYkTp9Ndx3UBemfUEWzQEK/gz6oRBNuIghEEI6Ui+7lqz4bKQpQReZ1/SnjNC4hKMHNt9j91URnir+ObbORGw8Rmu3+IQ4sDjAJo1ayom+VEeC+d2Hg9nD5hqoTIDIGIo/qzDSiuHnB8wapDMmLLE3tVEEDvDIA7NlkLUPBmIAw7ooKxtd0GdUf/HifIncD73jIHlUjD63jslxJtnkDPAfkgJxcgcCe4UZcuocR557pYJ1drYEZZnhvfj3CNjh04sCkz91TMNm7mx+hFN3CqflT9cr0q1o/g3rTjqD1fdkPYu7hfWOupYEBT7CL7dU7D690JkWK8UM6h5v3CS/1ML5RpdGkqRiMqfwTlGG04Gk0nOyhpXqljx3olMpYYzfyYCwd4ju8Pgw7IlYGHBWasc/B46tJroxKAE/W4dnZ2sqzHUnq+B+GBbmkp2E5sCcYZ9gA0FkSE4w+alIA2TUti7jEnznFuhKgF/B5ud54ZeNHsYwh52GISHJAdjT5BGUA2CBNLIM2TyDK1Xd9+DLV1WHHiAAkAhX06IBBtjq7Drxx53ovcnWdo3ktH0zGRIoVrv2tpvOVuUtj3en7XAaQHZHtyxoyeuTFLGSUZJ6Yi1Bwnk3IBmmDCo38HxRuAo6FiP2cEI/BAHG5B/gI030BqIva51xKHiiCk7YK+xZ9h9VoXMmWfKfFpsLAgWEqD4DIJUnt8mm23ssY6oiH2vvXeLerJBalbS8yMZyu4Gz5QuIVn2C0SwvOYkufn5jhjxgq0A2SY3RmsIEn70EeHcOGSvjXpN0WxMSGGT0IjLGDFmUFL7GjjwCTPCcJZZFwoCS2RJfDD4Ntkpv2sjp8I8m5sNRz2OzQD8B/bMBZG1nnzSiW51+e67udX1Pcg2AySUD1uN8V/nnntZ0bbdnsWpp3TykXmqcQAAIABJREFUgtOygVGGqg02vrIOL43zwEmOVl2rFUxlDU+xR5nSYUda0z7BelATYTH5najlkDGsUjz97NNq3H28uP++e93E/O8zzi7qq7B/zNFHKBtpb6fEut1x5z2Kzl4qtttGRf//R9d9wFtaFWmj34gSFATJselukiTJGSSaI8YZR1FB5TOHGb9RxwzCGHFERRSzgggIigKCqGRQEQHJ0OSMKCBBEfs+/1q7us9w793+8PTZZ+/3Xe8KFZ56qqrSL9z/8dXwGlQhSVlu1QYbrB+Bu2qK+e8YS2rH5GCuVBuk4McoSlU1bEBjKGsZnJs5ohC83M9BseF4gA6yz44esKMOMS94CMKUk8uB5VH6N4UhnjIzZugaNrN7MTRWTJyMIv1ccrYUpx/3i1c/LTjBMpemYJ0vTCxPvMY6rJ/9seceu1VvW7FPbbwqHYBlXTGzRSbXBu4888xzprGVUUWJMKlKQfGSiHHWOqNKKIBQI/gJLfCZa6ikZF9WKbwcngG7DEVa+3pqSda441EQSN5D9PB7d6kQc6JUQUk3JY5pv1w377qwjW8ow2CjDTeu+ORxxx032XjTjUYIYFr5ZMCUWjelz2TCHXPTGpCnj9mr+AEYr/ZQ/gPPnXvu2WHznhK0ZP3ai55zkJWGUncOhS0apve97WI0YhOztI29DLxpxZXynKZJ/RUHHHq9FFEbs34XN/ayR0oR2ytiVlMvq2vVQm1G6oY+nbTt8K6gOlAqVr05vioezac//dnJTwP1Su4H9YqtPSHz6lXrPIVIsdNB6RCBu1OE4t77b8/8LVXG02aVg/6HyevD9Hzr2948Ktpkj9v3hbVM47B9zf8vRTqeeOGr5mE6BgLU75QXr7wg2swdmK6v3WgO9j5F0T0y24Dv7xPY9n+3GeO1k3U80UZE2vhmwNUc5F4Y1a4hNYXiNL/rrLNuQdnW27xixbr+7JwX+9C5vT1NE26OrHCGODoMPSGuRTPHUm+QKlfNmdGw3P7bOmgIg9o5kNcs1k6JmgOpcsbuxZCUEiOtUTaGa4s/mwdnASJ07jnnpFb0vtl7u1V4hqHPyCOnbw0CZbxDni1RlZbkKFPkjGTnfs0oqre/412FJtArCrjQBdVJSTpbxLG1IDNuyfWQmioGC53UnCA/1TBfKd7yttn/DIWbkp9KKUq3ZKzeGATp8isvTyjlvlRkekZ9X/oOZ+aq5PsvH8Ocsc8Ytq90FZOeAz0Ue/76178xuSme7OcP/kzFq0c/04XFXhrhKOMoz9XhpDqbMxCQRY4++qj5FCexY4IuvujCuPzXF/xF+Ii93XzTQjauRXhyqlSsvAoq/OOKmOGQszy49CaaUGd9ahlWm7kOg7Zso7O6TVyYOfinqs2MOpI2DmWlsztcXezwI6lj++e45pUvlElSEEA/RWkY22+/zeTzn/9S9ZCkcFXHsSnFYMWmeEjIRGutNafwfK+eGL+DosGNrMSyVqd0esIaMaYny/dAE/pjHnPsMZPPfvygyQ9P/Ek23n2TV/7rq+OFpt7uB99XnpfnYRkd8qVDY7EfFhx/gxoPj43SASezvrHwNg8cscvTdwrhaI/RsDyHy2YB2Y1eeeiDA/YW/0Q2qDyoLGArpIJqs+lmQl6ERStHRCNEAbE4n3VQq4h25pv1O6CkERf20wa02RrGUoD7ByHbnHnGmYVaUL68edevw5jxiGNrazU7BQ0wpgn8TfPT9XkplFeX2/M9MJRenMtnIzMYrk0s0vuMrf5JET0awcfzxiylLKuHa17dX9S/O/bUXrW5aU90wKOKwY9C88rkMZB4vV4F8eU/HlwLVIqlvGOFGmLRXpG8aYcftIqIcfzxx1cCPGieN9EVpsroytrzUjphfdOnbVb9dBmd9pb4M2XFCDz11J+XdwM2uiveprg5eE2qlxQXnxshllnVMEB/0zJ2I5Qa0l3gjSKbiT+ZjwieUbh7eKZttPS89HP2z8G+199xeAkDOgd/jjhmkYWKRKhY+Eiqlz4j8V9smpD//OcPSeej06sDEZbx3YntjfHwBIexx9NRu1epOOz79Z+6Xl1fnevbIhgx6AmyTxzw0WrTN/ICF3qY9UAzXuTJ1FYq2bLAehjSpsbZMdv2RLs28gLIdmpQjDjmmD/nb2ZoZ6BRQyG2Udawss8jEXk2yuivGKWlBKbyZEpQctb+HA8TBFq9h6s28sho0MLSeBiQ9hOvzu9SMBDurA10zXc1BPc9XiXE8IakZkEAnRv3EIpgCCPMiQHiA1RYTOZA9oSzCka1lshGYqz2HVIkBd3GZ++d//mfzyd97SeFshjb1ltvM81Jtl9SgjLse2NdJmiKmujKhVaoInJubshBUkk+kHRFxDvyyhkBnyIbjrq46ik/uKCfMcXsc0/MWRc24QyR3+QVdIc3iOGvoTelLnxIFlwTyHrdueumwMMGRUBllOizK3VHYw0eKoMWM5kC50VD+nbaace0hzyt2hcedtiXK0TEgIY2MTKNoeWquRlnu3PkycyBCJW8+dSnDpqvabXqKyw0uDOFpDKLB2eZabxc/RmzEHat1BE5Uk/JQ4JhnpZ2RRtvslGE7Rl5WDmhy0XIgkQGBEkoiDGiuRugjWdheW7ULJy5m+NqG0bpXH7ZlRnkIulA8snEUcJ+rZqoI0Ge0D8r9V4xr+D4JuIN+76uYMprrplX4182imlY+yPnUA/AKu8Wa44wteFAWE9KLdLB9NSOa2EdXspi5FoqZBDGXj6zxBJLZaF+lQpL+6cdz3dKqe2T1js8GWWv1k0wH8FmVmCDM844e3LAAZ+uTTxn7VkRFLdVHVybdquttkhi8XOq+/sowzdo8GKgmM1eYJsWFmODY+omsXkalyihOcOibghiMDOH4rbAIFgxhyKn5N8Uiv9s2MGGHn33CNDuv8kb5IVa45/8+IQUoTh2ijZko2X+5VJi41597VUF22wYVvHu8T53TmnI9bLJrfE/Uv5xEH+GN6AIt3ZeNialpEeniiRvfMM+JURY010SkkfKU2Hl+24lYxdbkLIfHm2RLqYFqj2vl/tWW6ypN1IxjRgRnrUYjbEo/U6RjvDDgJXag+3iC4QVOM+6nJ1cYfv197//fZ0RccGL/3BxdW0Znu0gLhW0muetUo48lHwfQcmeeNe73hWjb7taT9dkUHqGedddU6xKipSScR7MAcUv3Uou6XIxCHlnAyEZNbHtDuNuL2qBB07YZ0+2UWQvjHEhEI446lAqEaxT47XXZ/xtpHkMeDcxT15hDLj8Xxlxf03PzyoTms+CtxfXpCLXw9w/+ecn56x+vgTjuuE3YPjXODMnymIiEBJQ++33xhiOu5fwtz9uDeHqvPPPnZyXjjYnnXRKztG7Uov13wqOa3jtsUr0MSp1qgCaHDTmp9CbqSL2PH97eMTQ7Q+ypHJtp4U8mshmDhqxGAZ5QgA5IwRzG2zG5P3y3hmm2Q/m0P6sblcM22lopfeo+zernAwDtxqHvP2Hklcp1EVxzp27TnmP1Xcz8CIPXrEE5T7BpepZy7/m1SqkcF2gVyEO4ZOrEoY4N6gg6JNzs2w8QIYjlqprF9yZ59e31T2EfcC10swY6lAq5wRkTVarOPTmt7y9DGeIk9xYryIuxtC3P4ej8WhBxRsmHIV82k03nDfy7v0f+GAZi5QhPsjee7826TYHpQPWLWmGsVI8xSuSgfHiKpvqnjxjqS8yR/7l5a+IrrmtIGohvmqTlmtJfbE+98YRkiLJs1w1ubJ/CpzNQ9144w1LcVL+GnaLjSpGf8yxx8bZu6ngYPYWstEvf3lG1fz9+tcPy9NxoCK3YlAWyTHncPTFHYVHoAQta/rMk6nVlzg3nP9IWniR1Y8LI5R7zhsZRdJHArP8UZOrdJMPXp6HvyUJ1GC1vweiBdmymP6RerpKxlEOY6OOGqu8i3VCSuDC8854uQS3TVrQ6TSvVPxQn0S5ocqlObhfOuTTk+WWjbWXxW8lakGPOeZHOZC7RGGdGZz7+FTu/0Tc/+0nP0nR7zmBmHiaFe/I+Fkh4n1+Yj0O62hUMvLqsQxLfHgn1c/zccPiwDLjfS0W5XR6FOl/ffDjKYv1lfLckGrENP7ve99dPVIpXZudwDwo7d/OTB4hz5tBslNSclhBIFwd6X22KyoRA48mkVn8qIVACwyBfmMoWzseQid3E+JduL6Zxu2NGbdFHnTt0WjAveSXdUNquYOEZyvRmdAUaIeA+FLiYL9JUfVZySHlTatCorHAzQnQW1M0dnV1N09stGJFPJvM80g7St5bNvv5v4mQPPHk8lzBQDwZVimyi24Oz3rWM4tU4Tt+srj9jTdUxDCQdRkyA84dFZ9UiBnK398hBtVKKbBvVz7y08YXO+cFSdkgyFrxmCP3rLrRM2Ca2gOZbLHgK5I7yaO/L9ayPFA1SAkTW8eZIZDGnI8KTMMLGrCml/xqMab3vvffJ9uHBGG+u6oUQ3N4xCO1p9oXTqH5ptkzRP03qPvT+OeM6/e4F0BNU04CowzrutNfel80GavQJkoVFF5zOXJC6wxMSVLltY6HqfcZO9YYROi5CJxVVwnRMKQgRs8ZZ50RiOyQKr7hLGDLS5FZLTyE69OEGhP84IM/W/DfbYHyXJO8YbTdEE/jDxdfVN4Gr2Wwj///PdKZynR41wvH3+d6fGawiRt1GMpg5H+OMyKOqCXeKGrRRofz0oZWp2TZN9be34QSyvioqg8Ly1W2N1upMFX9bdqZJP/2eYiaueddEvSUZxOleFzmmOyyx8X47ANQKMKPs+VMcELsFfvCnJLXZyRm7XpK6C0fxV/FWUrRqeWtYE4QMYzbzBMHgUGpnrS0lEI2ch/pMuKQUKyPf3z/ahrPw+SJXX3tdZMdt9+21qqK8efziIL6NJsn52BumsdDrewNylsc823veGcg/McXrLtByoHuESPqu9OiPjw+IS8hjVGE4cFKc1G0xZnZLLn4vw8RUaogmblWGLmcuD/GIBfO0of16quvmuy669PLUJaadWc4E3JK/W5cKj9Z24fyDJxEee361G6ZtDuhqy+kyYh6yV8//LDiIUCVGPGcsEb6rG+l+cUw6EwHz2+87ZwsEqLAfAoM1LhuMPsnPkkc7b5RtzBCzCSzSnioT4wQRQKxGH+LBX16PFB1eAuqrdZpqYOZyaG8WCaDcZvEbYPLgnux9v+ZHDwbrAkNw6qVrqHKRazFCEwwsdqfB6fDBakFQmFBgWHFDb717e9WDE77n5+mrdoH/+t9YXI9e3JS/s0C1plD/IBgEgMdVVwURIhnHIHu/jwiVvJgJnZLsaFYVPZhAWE0G7PNxzI/5ZRTQtX+70ABh2ReVpvsm7JSd6RowQte9fJ4xftUTAcc4fBqOntBPJmXJOfv6YFwt9h8yyKVOGCUWlvM5RWIJ2skm0NCdtUhSIy0leojWbi2lhuetlEI5gFVDcHg5XriCDY86837YBPrASb6/e8vqM3y1HiSbfX3WMZ1hgVtzRWe/sGRPyjBMS9s6stSrm6dHJjd99g9xJAdC8qlxEAiXtYUQoBMhjl97XXzKlZtfyh5x7gRyzQP1XnhhpsqtvbaWKpd2qtrZa6eQ0l5IrtRdjw0UJTN2/0dmyzT0NwQqgsZnNayijJkXzrcYsTuz4r27NVkuXIwR9ywoRyKlEGAxaue56Mh3TlIvOrbYkRCI7qGcOdLl6JD7pru7e5nSGhpuq6TiW4l1oSBqeLUQCBGzLiRGegM71OBEsqNxzfimtOWTaX4Bhu2X80KtQEJW0K2C1a0Jz+MxLG/varwSCleR2whMbC7ibQiauNSDI1BygPibaujrGQhmK9amEVgYSQfdthXq7g+tjyjyVgolhsTe35FvIz3/sd/FOPbewyn0Q1lsfLqqjKW8Ia9XJGNYZD0/pzpafZ7vefbQ58JvfJsR3GKhQVHKsk++7xg1iAlo3RdYn3FDE+f1qnR2Xuq2fu9r9yPo1ANLSrBfyjSVqI9xt5PDa8XkpJn5kkxMtdPKUjeHlRi6exNbc7Mi+vySu+MUt0wYQEIinHykmbPnj1FAR5fsth3yEoefqEZWRMIGaVMTisWYWye1fhB8sMYHTK454pR7mySj58Mg3XevOvK6P+fdN3aZren55xvXsUyNKT/TuqNb7nZ0xKbXTXVyrYqJJASNz4KzP3IGR76fm9+a8nRORn3FUljIvugGj7bcK99Tr5qmAIGnhOjHXS7YYwqCvOM6BnlSRHtnEfjFgpzHYY6YhXSWsUxs5Y4GhAjMDBod7N0yPlDQoXnxSEwZk6fcq4cu09++tNVc5fDcFvyWHk99MLIdJgaxPmH7JLax3m/90HL8GLvbr3VFvO55LwUwob3QnHAqcU7YdP+bvBowk9IDtNygR1AAgTLGb8+e3J6WuUgDRWNP4oAFCYmZ5PYVKwVClbpJn8XNxkSfyS2OjBNpsFKG0m4INxFJy9/2UsrneDeKEVjAFlqe/OLX/wyVWH2SPzu6Mo7fP/7/7Padf0xeaQWQ3wVPIvgw5usiiNTPFsMzP2w4LqWK2HT1H+TBYYWR10x1p14LmHyhGzKn/7sp5ODDjwoNX+/XAJx3ze8sXI6t9tmq6R+7FPpLhiXPv+bFK8nSJ6VJGg1IMdiDEuxD9cC+CneqDGan4bbQCgjrw3paFQuogTATH1YhxI156y7EcOyma6PV+Cws27FngkSxCLC1d9YjmJSDk8LjI4zugZvxrMgi/xPCpgfHQRA3GPnELd4oJoN1PconCmjVuzzgijpSxKruSLpUd4nZRzoDdKyi3AggBlN4hQU9X33PhD45cZUXHlF8sp2r8NBkBWrMfAMo4ogFGstw2fqkdo+rGzWuLADSxnr1nsVz5jCvV01xlyC3SlOwgMiUF7zlDxiz5cAnTJenxCWoBxjRCEF9sUCZ89dK4bUqXmOO8rIGf1Jh1AaqS5t+Iw6x1XgIv+5ToVD4p298hUvSTuoV1ccC4IzYPVRl7a8U4xZccqhXus69XfPFCHk1YSRmUZDex/1hSm0aYwzjYOuuNNx0PLMwc05c4RZk8xAgPRXKabsGwq3YMHAkOVhTVMCoAr21YbxPglCMTdrfuNNN0+OOPKIybHHHFfrv3bmDbFFDJGx/arUqX7Oc55TlXpcFynm7kCLvCtpRK24Z3rDbTB0jmcrAe/P5AcYc8P15lL5Ue85H+2V2xO4AH0fe6C/gxTDQGWEUkydOtLKmgLwPfvYfYWQWtF3Cc5ez5mtCn2mlW1DxiDac5N/TQnOnj0nZL7flME6mLsDMrauxuB+/r1JSnK2p0w+47dcnJzPTVI31v6lhGUiEKqN3AyUY4RFXIPHSeEieZoj+0mhA/NEUX/oQx8p2FiRBfFOrf7WCSpJvp8TAtJBKczhTHfKS88/Q5hhxMikH9hCe7/2tZUitXtkxsFJpXE/6GZZH3kNYs+omy0cUtC4EElkqKpIG264/uTakNpwYO6/X7nFRSvfvOWo2OzvLvhtzYE8WedNfjZvmR658647qpwp4+WiIB46zSBOrRgP3zW++rWvVTjqU+luAwrXlEHetLnvHGzjHN2lBoegZfJwAAeUv8hrX/uq+fen0zq4o/D74Mc6YiydSROfAYmpvuIgIAq4YHV6TyBbHFT1/8989vMpbv7zBKM3y3uxNNIzEyY/uqsP2EwwXoukURlmQHQWY+zC8YMVznOqCkOsqAiqN71x3yJbWHzXsrDXJFZw3nm/iXX/ghTV/lLFQN+V5r8E7RVXXlqeByXpQbEc3Z/X1ELI7yNGKNGYZTbg3T4Q46CNElro0k1GWDLw7Mkp4v6hD3808aCDq8zVG974pjIYXrLXS0O62qqu+Zcs2qzURwWxDBq/wghhztI70w3Uh6S9ioZ2uz+hsRDqBR9hQE8ZrA3D9AHvTvbmpZUMwcDz4oHa3Kj0BByIfXx/JOU3/LNgDLV5JPNL6h7pQHKLrwjj7cLENSVAb7zxJnWfjifqY8nyk1d6xBFHBb7ctuZRJRyGmXQOpe/c/+KLLimYVA7cTTfeWjHHVdOWacPEL16y14tqvIwcoYTK34uBooiGfcKD006v9k2QAUrCz1L6icuNnD4xzwFZYqjyOsQ6G9YTG+lkdeOZCd0NRufIaWawVCwzsJa0m5+nCMdVYRizvi9KDjWo+s/33Ds1ZjruOOquNlu9lWh3pfE7tEXpsm1zsP89RRU22vipwyqHAIiKF1w3ZcoWkD+g4i5rpm6u511yCsf1XjLf7Y11HdruLjJO1mgc3eu8gECR9+/PXuXxM3wZjV4Mr1JUlGhBrJj3D2esmLRR8hmauBTUA/wolseqV4SFJ6KXJCP0hJ/+pLohgfo222yTSpcS65Nr/LL0sax4fs4FNExnl5GvOvLOZ3rb/Qwz35vpjfa5beXaxgOjk0E40+BwPikYMTtGm8bWkCuyz2sUN1+85E2HAFrhEpoVvsje6BaMwiwDolR8YQrlZs+050IxLORYKASTMqiBvClTSAb2vYIexvjrVMByfTFORoXnuCVkLO8ZK6Xpe84JhcsgbhSHVzgaLdxXZ81/jOQiwWVfeU7F76E5jAUecBvQfYY8P1kmN5wSWmONWeXpOXv4Egod8Ai/kpSZpZZ+YlU7G2lwCposUjCvGKeygeB5svWAAw5MGszzYoTOCRLxf0vGC3ORW1UXIOMga8zFNqkHoAvYi1/0wuzF5SeX/fGyytt+ejxjrF2GOEPGs3ZGgnmxln43NggYRq/aw56bx+rnSJNZJF7nHWWUbBTD4xen/SqK9BtBEl8Txvg+RbBVy8D695lph2fI4d6JC392JbhF3v62/eZfEeiK0JsddqvYBNLDCiskTy8KCltU+TbF1ocCmtbPyrXcVPxDvOzAxAMFiddbf52CIbxg324uH1BdUAeN9au1D2Eq4b480RrkcJ/FWC0mj0Xs663pP4f+zON1f4L5kj9eHCvkgqrH+7l4S6zht6ZwMtbjXXenJm3uZyNT9EsEjh7CoFNZRiPeFniepw9aewUNbw6LQ37rKDy9WLyjU045OV3ZPzH5xjcOq1Sfl7/sFUk9WCIFzF+fXKznlNfn3oTdP+Jl0psV7yIc2mKYrkN5EVOvQZd7r07T8O+FieK5Rv7ehBFzxpgxl12bliKlNEA9DbO4vns/Puw447cRRxHrVUoQ1hpNeyQ2mWIIj4UVcVxz0WncrVNFWsCIf5388xNTyP+HiZthHQ9ig3gui7rWVCu1aXkzHsy8eTfW5k4f3KqKQjkhG7m2Q4ORvXHgwrXS9FzitMokoFGHRfH2JkEZQ5ONRmx3wLnN6OV9FPNumgPrWRkfDYs/EDLDbanQJUYL7moF29fBYiQkkcMU1Ve8n+XKgzrxpyeVYi1jgsJBzqkC5gNaL/h0WhpvwOSlJmsdeJWUhsInr3/d3lUi0j2rapVPTT3ByhJ8jEKZCd33UW6lUwYSaDrfq3mYMpH77+2dtLIppST/LudNWktXnBpkKfvV/hupHZ6xYtHJ/fQyL/YVJTrSdlIQIEbRxekrC7XYJUXVpT74KiLRf3/qM1Xz9ampuYwlTtiuv976kxe+MHnXEbjmcWZrv5nP5H69Jq08H6tk+/0+v+LDLQDbCy8DZer5t+cmvOEFTrX/KB+fq/3aXAleeRkSI23DHuocbO/bmzyq7ible6N6EAQo8KOqXJm7Yqnm3Lp+/0fGMRQbUrb/fRc7XA1YBCDeKi+PwnANMLB7+M5oljCrlOoguqm29UD9PhAqxs/ICS6kLMqKIUupQnIw8j2Xa/l75W5mrctgiFFTMdnMGW/Vc+NXKE7y7VSWE2fEgcHkFkozRuilMwk9WimFIaSVfOMb30jFo+eXQf7Wt7+z7keRF6Sc/w2lP5wNRqsUmBWDeNpXuDueZ7vEfUue5+8g+EZfXEvPWuuxww7b1V6+L8aC+RMCVCCDom8Dx9wqai+bY5OksH0/hv8Pv/HdyYf++4Ao+xeWPPXsg3U9apDPzIXu0Ejnq/ceq/33xn33no/YoduLGNQyyyju/bdMdshCgWK5s+CWLqBchAh5WDnxcny80Pu1FPtatLucpuWXS//DDJqCs2AUDtwaM7EqRMTi56IvLlYhZkqR5j/fqQLxlUIzvLjnpILFFpttWZvRJpACwZUHFyM07LPv2zL5cxIjfX8x2MQCXI9wAN/MWnOdssZtqFELmHAYUPJIzLFxBpFDxRX3KaGLEVpe8yC0lFeb+MGvfnXa5AMf+HCKQny5xvrW1+47+cCBB6SI+24lkL3ETcpDoCSnnlNVKZtBzfcb4Ts2RYTtFI8vcsi02wA4spmGKm60BdnEIvPhUNpgYLkBAd1e79msNlihAYGgWaPgSRt09XgMzXBtr8bnOq+Qp1q1kWMIPZDNeVMSt8UcKGDzyJP4/YW/n5z+6zMqdqg+7FLpuoPZelXSRbpbDUPGOkjpuCNUeIpXrBgMtWOIV9JkCH75uNeWFUxYP1z3QQxCvpozZ055qYwAY18mitoBF3PtwgLmbGF+1z+LbSfm49kI/Z5rcTxzZX8TtuLmKO/o+9bS580tJbtoUreqvCWi2hTexUBdKSjEWekPemZY2WIsK2Ve7ksKQyu5VqSdPzk6koQ5jixUyMcoVXf++RdU0ez99//w5BlpjFwGWwSdOR/5kwXsFku+DeGZKEYrl/Yu65C7ciz+ERJYyMJtw2imUq3QQO1RsCeDUwlAaQ2DeMgbtW7DQx+woAby4pj3hKDTcOjchFDOP/+81HP9aVWvIlCXiaDWoWTNlL/jYV559ZWVr3d6StHdGyh/8003rhxbvWgZURUCmL5mKsuZSEmNd8Z/j/Va20AqJZX962UO1I8dZTpHyKorfTWUay9QSLXWGUcrqT5Xj0WOXJdS8317UuNwc1I8CiEWRT+moYlK5cjfKvQxhWqbYDnia6PGbnuc7l2kn5wH2Qe6tvBWGxL2jMOTRex4oXujAAAgAElEQVSZW8+oSIprCtUg1lhH3AeG8bx519baOk8QKvPXzHhnaWYop//dysK8UMY8XC8eplzYw1MylEcnvWTNKE6eKxY/SNgG50gwNhV8uOTSP6agyYkVChIqOzB1kzFoh5IcOb0MAWUcK84bJfkf//6eyc2RNxf+4cK679zwJ9ZLxSU9jOsc53vmcjgII+dTJaKqwsXByPPTZxQow6TS3pJuNkiBIYLmOSAIq66eegTf+m5CdSdNPpwUyz32fGbpl5HqpAjPSANzVmciE53hMBNZNK5F3vaWN803qAcfBJ2m0HKsqCGYHa7kHlYi9ejzWQWv5fhkcKPWYDq/R+isomVY7vmxjx1Yi7zeenOL8kzDV6eOWGXiRIUnIyVMEV1Y+MxGwH8P5b5ipjnJ8OptY4m88IUvymEApYxYHoVx3PHHVd4S/Hzv17958oLnPjNEjv3KkgDl8GRtDPdffoWUauORNnmjlOMgajSMKbZTLN6KUY0YZj17lOlQ8KmpmslaPB7pySefONn/gAOSN/rBgiBNPMUgtsmbLmU9pOl0IQSCIxKrc0BN+YJDPqDbaQx0qkgH5D1gZmPxHzIGQ6eqmEwPrDF2LJHiAqP7bCvPzlNzYFmDd9xxa9b30SpHaG5GTEJxd0XPB1xfnSmm0DNhTPHck82IuapSCdKDDX9hlKiCE5TajjttX9cFd2Iw2j/WfJDHHk3s4tLaOzvlcy9JGbEtt9gqayIxPJZrrE1ej7GeH+o+qIoFTuiVki0FFC8hz0XBek7l7MrDrykeKqbZusZe1UnAb7GUuwBDw5M+615+B32ChhsGay+hIfPF4onXAcp3fB7sppH8hhs+tQ7yEWmnh70OstLOylD6wNV9YiiaB2MfNWtZuSNx37x7dqx33Y7eEDTjxSEhKTYyKP6jElhB6Dn8uZCL11jKki8Pd0REZnpv1f4rb7pv57wND2NULGr4d3xnNIofZKNhfRd5Rt5ydP2jMTgJOs9E+PFunpgawJ5dHVYMTWM0N5ekRutv47Gbz6dtsmnF08TBCMylYnxKgOeFH3HkkbWOr3rlv1The8YObwTRiC89sgQWxngfq0j72Vuh9rO3UmSIee5WxvY2ZMEZ5q3XfOYzM71Hv6vW4z1npbxj5y3j7KILjcSRQV20HapiryhIgJBoLRlc2KetsH2PYnPNhu3bK9UBSTU0xiZCzKjKo7LStGNUZKN7NWTc3nJnLjhnOAnkLePFfbxnDQeL9sEo+tvK43duVT5yb04PAhJZgcVLGRVMWmUep/ImP+3RJuq1AvvBUUeVEtXHE0rJ8200b8Dko2qQ6wmJqch0TKp4aff4K6TFIFeaeY/5HDWT65xHZl6c+KXWkNuHGYzzopavFosMcXWXxWt73fFlPCenqnLUI6egV2edfVZ9RvMJzU4UZlBp7l//9RUl366++tpCQmfNSlWj2XNT1elrkxN+9rMQjQ4Oae5pFeYwN6MS2LQZPW8zh61/n566qSwf71fnnve8+y3zn6LnZ+q+unnBmZlcuW6sioamlo7HwQMlFE3W6CAxLDj49lMCFV515TXVCHiFlZar1lmaDjvcVeJpGrivHnJy0aaKpnpHljs9WJMGanPckLJhOyUv8VVp2n17YjHiCmsE2rPYR6S7gFJ0yo299e3vTS7i3ulZ+C8VUFbMQbqDexaLbrERl5ATV4ImSmp4oAPzrsLPEfqghZkH16FrgV3dSyLQVT1hAXp+1jRrahCYRg4oxVOKCJOvtknp01Kk3qBoCDkv125FWp1YasEGC6u9jYKlKlUH1Ea5DmJR5wk2wxHkNITziKG1UhC8B71wvn3HYZupMDre47lBvV1T1HzxtjwnQXtDYDseqe/+IsiDNAfP66Cz4rTeYkxJALd2DsbvLkilqyc+ZfLCQCbbpXDG5mHOQStGrHDE4Hh7Zso4Tj311IIHxWEIgS3SVYVR5d/gHJ8d5deypvo2ThnNbYg0NC0WX8IoljJvtAWX+xHcoGrPZZxeM+EZh9sc1d4syuioKmU9rkjB+V/HA8cXUIv0mOTWavIuXaCLMDSJh4FYtWRzHcYcJQpq8mJwrZ2UB4QJ7Pijjz46xsllMUj2mLzn3e8uQWMchehUeGJhU/fR7aRxjenPx3hqjySlQZy9wgKY1PZjn7WCKYN+FAw+csLNf5NwhsEx2hvKI4U8mJ/qp5v3kYgQ+XoOh/d0c53DOXNmFxP1T6lsJHcWyxLzXUzsSRGqRWzJ2AgdcLm97ezcG7TBOJbJGhvr8KQHE3acn3FeZkLS4zMLCXsNZTeM67plpCs2odgCTy7zOXgRo7JaVU+aXqO7INkT1dCCUaGP8MxQwDTlA9IDChZqkKa13PLLFucDTIvVLL+SUmmPvQ3a9oT9zTjIKqEOspM32TXFzak96NWhlEZLGppmzLr/KmFPd5qHvVINrvOcFCpCpuuoMIQcd3MY0xSflL0uFckAINtG67XRPtP9BzIzCJqULaPo7OTtf/+II5J5sPlUaT95QV1g32nY1RmtZ83c0RE/OeHEoDgrVhjgO9/53mBpR46YF5wNaT0Y/FABdZe9f2WIitZNjrmm5IvlvA8vUUbEivUZyhRZi8N13XXzar4+/z+HFMqzdaoWaWNpHn524s8SQtq9ZIiqdwwgubKrBn099NCvTn6Rkq+Hf+2L8bDXqwpfnnvUqR7nviFo8rt1QqMbVe+YLNeP9D//813zq0ZuDk1ZqIFyCeBKDo+S4SUS2GKTDQv4qWB8Y9UWcanAOZTlxz52QPWjmzVrBJspLN0s0KqXWJJwURkpHmoVBfh7CTcB+dGV44HyLrCqbAKsXB6KF2iivYmTQmzaffddC6r8wPv+7+R9gVpfmID2HwMlrJe0F/VXpe+oaCSkW4ewhAmrdNTOnYlz90ElgMCtlbAOls7vIzF8vCcvChQodcKztwU/8gf/9+GeKaBtHMKLAhCTLUE5LTfVtTl9vz1l4xEz8gztRbSX3FCwazb2zxIsRVEtxlT7GTGitrJtUvlq7i/eYeOXd5e4asHgFecxtmEljma5id/k4EEk/hjjQZk8AgT9vUryxcvQBB6UIteMIDG2y1N71dy+9GUvDjPz2Wk8vnYdFnsB3OJgEqSEznUhKRFoSFsOO4+U9Ux5emHeOQD+I9hmelfDEh5rWYzsqZfasdNhEI4iCR07s7aIMZ0X6DtlbOUz5rOF1yDI0ViuMYq26wf7q1/9su6n8g7B8uVDv1JeBCOkyCpTDFY3F+QdMRprIS+6jIJSqum7msb0inKskuLh5uS4H/847PNjJ89OyUvpVJsl/iQNirDFXKyUjDJQpqUPH6M8jbsN02G5KXAiXBLjsAy3ET7oPVox2SnT2POMGPNge7tOez8jHDI+O8grf68xgS9dVT7p+WGmSwl7Z3qzrrLKalVkYK0YmFWjNnNtjh+YQnFkgDOlcDvFCiq88Pe/yzqvNtlw402nsdiRltFnoRVon1Fj6fhvE6iaXQnSR97ppgTFxC+vO2GoyLBeYyiHdDr72F689bZbFsQehRJagDZcT3la37si19aYxnQ7RYcXqimFKjztobsueTXibSPuSoDbC+KMLRvE3i/43QUl+BlnlO9M2JJy9bwg9lFtZxhnIEv3QrpxH+mJvqv5Aw+PESrMQjHwSK0BiPje1IKeN29UEfOMyEmMqFIuecZBQBzz7yUcBCW5OVDzUalcx/ATduNwMbBVT1p88VTkypntPHDPXgRI/Upz5oXzIGJHRAkfeeRRZUwPNnqM99yzKrjl37PDiVh55RWiFG/IeP+edLi9qza15+cBkz/OgVKdOBiN2iHKicfagxelIcS+r3997cN7Ul2LXJRyw+gg0+zxx6WJu/MqVPaFQ75c+bGHf/VLyZNPnYPK5hjlAa1dIx4Lf4YsO81Dr5rAUKeM/Z8Iq0ce+c35LG2B3ScsmlyuKvG0VJ5N9/lAUvF0QDuE46iBmZzO9FGsvnnVjFbtXcJ0mSKI3HfvPZNPHPjZiquussqgGC+XSkdK3VVYMi8kpAGv5BBnEGIMLBgbhrV76613ZAOkg3o6QjgUI3ajhNmINehJqq/e79PC69DDDpsc8PGPVLWUu9LrkmK658+BI0OgUkljiSeOXqtDiHSj4Wmj3YJVR3HtEZtUiGL0GWyLpC3iEtCVujO8Rpuz4kfTCZ8JsfWhd89WxNpQub74WwuABZZNpd6Mup9FvsrPYnPySDN/rQx6g/t7e5bes0nGxh9FKzoO4z3fFXNxUBSW7kPUNWsH/KQLij6Rowm7FBLVRPwbjf2qQLtqzCrL6IAgFEmJcGDun1abuiWVmzRJ3/OZe6QG8jPLY3eoOvZbhkfGpran2BKlSRip3ysPbNfkdVlzQgHJwgvRyLiqNmfGwohZOP+jdCDPx8vB6ubIfu+qT/ZTp4u0AOv1a1iKgGq4qee6FWl/hyD+XcZ6VcqObZNUJ+P61Kc/M7k01rNcP4eV0qp9wrAq707x/WUmS07rsBbDM+EBLNWnPS1J48lDJkzk4B6dtntHpdD/oxF+/7Lv6yZvSSeUlSPEOqm/176U5tRoq39PlSrhtKAR9ZTA5nMNB+MGNDQ6YMaFLNPh1f/v5u6tdN2j9yn0Rm6j9fPM9+ZsHvqVwypPW/u8OTGaPKP/Cl6McU5h6sfJ0l98yRELRQp5KPtGne5fnXZa6vSuGdRip+ruQSmNsNHCPNk6D4X6DNi2OQ3NiB6GEqWvklWunX1FpnguBdjxMaxne4eepw0v3UFuuvmG8lgbNWvjoc+48+S+PG4hqt4r1kTI5Z6sfTf8aGPHOXY+fLarpjXjtsg8iEfIanlmxqhXhTp4pEXyHGlVo4H6qDlsLf1uPM4WmeiZnA/zTTbywjgpoFx9PTlF64XYBdpUxpHyhaR1UYmOvwoNdUU0BD3GCr6JCkkM5u+EYAQqVZgFXMrTJU8UNXCvzmNtIx059JEYcxtttHHN9ac/8+kywnmhjCy1Czw3b/zPIUjSOTvvvEMhkc98xu4Fe//0hBOi6K6e7Pu611WIw3ehgkp0UtyKNnTt4Usv+2NCfscXiomxS4ZoW2jdVq90IPOcCntBVis9KHP6mc99vsrhfufbX0t8X/tGVeBGj9P2zku2gHqL96Kz0ihdWdD3lMuiecgip59+8vxLQjP+U0p6FaBFw1a6xehtOD/1MzUR/dvDj5bgAsvS+CwThksnz1t4noXl/u53vx8Y6MYSuA74k3khUayVJJ4JkYRuQ5KygsRLBWLow/1wNgSrSBcIjE6KtGDQbKo1Q8c+97xzwtq9dPLa1+yd7i7HVjeWj33sI5N1Y3Hdk4Ve+ikrVGznlycfH8t/08kKq66VzTYUaZXQpqjipfIMjb/TJZrgQwD3ARLH46X2Rm6Yr2NufSBmxp7aijUfNinP0+e04ZLmQLgMwfS/y9mNeOjI6XLfTrkZpAReglSdoWz9u8qeZTP2xmXtOwiSih0yhorDYg2Mv8r25VoquWi1NGC5G2ssNvOAjYYVZiwOps9YJ8L/lFNPCQPvm3VgEApGwYcHq/oJA+OVr3zZ5KUveUlZsIRY1ays3ZB5yH21OGIln5ciDeBAxT9e9rK9Ql74ZtHQWaN7v+Y11aMQ69v91eLF9kQQMC9gMzEMVa5Y0YSC8IN5GakuA7ZrRdnQeRO42qDy97bu2wtvwd0eaqektNB9QuJ4PGiVtNTZFWv69ne/M/nWd7+atk4jJci+hcAgCQlXPCnjWTrrzvZiBUPuGSAbbbBRwUtgQcJh1ShU+/yUU38e+OyHFat5bkpI7pvyk+utv14pU+OpTj9aZ0mzKSLSQuizHjqvRx9pD1RBAwHTcZ4ZxgsVqVhheAeIRVPvYMH3nfnyaocC9W9z5QXu1THklpvvqFq5Rx99TGD+8yafPPBjEaxbT56shyjiUJaAUrgzxDcxwCckJe7JVYBDQYLUnU33mrvvTvPwlOs87Rcnx8tbZbLdDjsXDPw3MNnUY3LPYSjUYCp+3E0Jmlk/zl5Y09CbPKfzOwgjw8Nuw7JRGtekKPxdedPRbWikw/hexzQhAM67uW8YuAlJxiQ/tWKz/su5cc6a/NLzVt7klAzYSg+86uWaPifPXJELa1nM5bxnX5cMznxUR52pUUE5dGN54ySLQbKu1TV3nQsK1b1Bshtkr90dhO4nUUpktRZjbZi6hrNGVjjrxihUAdmamWdqrqRtue6ckJzIhF4j8/TbMHm7e01B0/m7NCco09PS8YmS3P+A/ZODel6eV9w8hngZM0ErsxZkJEN/7bXXKu7Lc5/7rDT8+F7ipn+Y7LvP68uA9rKePO91k8PueX2Hhyv+bl+AvDUj3yhGvLk1F1vGO/dvBiDRwKC0R8374d/4dj7/h8kxRx+Z91IMooyU4fAIDTViNeqe25ejpG2fjyryMW0sssjxPz5qPkVze0p2jWB7hG008z1/+VPFJf3bAm+5xbaJ6zytGE/YtGAqMVBVbAqqzCY34GWWXboeXO6iiv6gqxWT+mLD3hwB6mGeqM8gckzy1Vgai0UIloUWpa17xKwozBe/+IULoNzy7LKh5ajBvBEYXhriyvve94HKgTtg/4/VPfUh3TBkBw/7ixOPD1wwe7L6WusugMRGtZghMqpazLRjBgFIkYq7NUxE+CJPNJGhYez+3TVa+JrwmfT6Flh+sqKrC0SuhSrf5KrhdY6ap/5t81bgXHJvJqkbApcAaybxtDZoe7/mpA+qtAKKVK6ZAwMOHQc71mvWTLECm7DqHidHTSOAtm7N67gPotWw1oenLXacWslR3O556FcOrb6hoL270sHD9V/+ypdM9nrxXkV9b4+6vEZEtHgDFyX/9IJUNlIL1NgoX8xo6Q8ML9WPWHegNl7D85J4vXmqJREOIMI110iv1iRVuzbFWg2OU3hb7FBrJspyKNKRP0qodS6uZ2jDxvMRhPaqZ/H5UdBboY3B/uv17IPSjB7eSqUWxVBjUDgjzw6bXG6t1A7MUDA0j4WhKL1LAf/5UTzyka0r+BuEuFmMu6enRvStqY5k/Lz4Saj2PIeVYhX/9ne/Ccrytcn5v7toss2Wm6bM5AFlEMpNthaElBhipaVM93IrHM+F6dxeatH389kSyjM8Ul/UlKE8oqmy8rNh1AH7Lgw1OKv2J+4BhaMs6J0pp/aL5A4/O+jDlunryJBFzqtk+uxrQqlSNrL/sbWXCynHuJx/5CzeDuPvkot/P1k+6W4bbrJZPc4jBFM+1Ht8fCcGBMRkWqVoCHGhiBF2qWID+TYo0LirHnC+10SdAfeP9AnfbW5Be4zLTtuSdQiA8hRu8ur6uRSGa7enMgg18iHH+zykJqqVop3mLzpvPZZB4hwVkTDRKTKoi25DxsKbND7eLZnrvUJ1rOsUAWtEBtRpz/mbc208Xee2US2OEKV51lnnlKe+6y671BkfYZ2lFni97XG7tnAOiLPlkDlw5ir9Mc9lHP7jECwTw8k8nRWEkJIFW/c+cib1KOb8rBQj+ROfOChG11n1jGoTDEj5/roX2VWlIhMK+Nd/fWVSazaefFYbyt/9dvKNlO6Tf1w5s0E+tg4BVUMJeermR0qatmrmwTi9f2kcw/N/e37CfS+oIi8ULbQOqvTQQ0EoctYXj8w5/OvfrJSt4447Ontr5NcX2SiyiyItNGGKaNWZkEed7/YeeLTSw6b79cBP7D9/3XXDsi2rZ1L1FjUfxsblfTwtidRw9idkwv5w4SW16DS/cnE2iwTXmS9wLvIByERFDPRoCz2qo6jDGvj4SYO5+M8oziJljEBmWch3Bp593nOfF1h2kwWbo+EN1tMpp/wi/UV3rzG98l/3nuyw3baT9/3nf9Qk+v7SieXa0Gee8uOwuZacbLZ1WqhhG0eQic10Z5qx2YbSsAgmzIsyRRrqmKGJcghbyLSAaUVallxiRxbBNcyjA18bEEO5YKdxKHhplNKIb47WZp0g3qzUzo0ch2/EdRoaaoiyPWDfb6HXh9h9ujzjaDumStEo9g8CNu/iB+IsXoSOilDlRZYHjZQx2HvlCBS8hCG3QtZ8XtXgFBdSDvE5Kcn4pGkLvPb2yvpLqosqLRdddFEC/DcWXDPiUYNR69BVh5is8be/891qZwduUV95jRRveGmapBOec2II8f7kcCrzpfSiMZpT8zgTgjf3jSZUHnHiwebQwW2B2gegBav3W9E2G7r3w0wotYWPn6clTqqKyh45oK7/yU9/anLN1fOKnn+fRtmZNR4ESxt5ApFCjPShrMFiqZakfdOqsboZFErrycErgZ098qQgM4oi3Jp47FGBen+ZFJu1Q/9/zWtePXnO856V+GKqL6W6UKMoco/L/yyvbepF5rAXkkQxem+BIh2CoRXUo/8c+Yw+MwrhLyReVRnF/M35Lxgu+5Dgt26193JuTk6RihtvvGWy5+57VuoXz0AdaF4SpaNdnLQrQlqTaFWNVggSMrybO6pu9ZL57A1XXzb5S/bjUzfZarJUFFrFA/MZCpkyKejRmUoOa5+Zzn2urjXCQUiPGZMc6mrCPH2emXuS4jDHDPv++7jHKOk4CCzDm+v0lvZmeyy+1+ex9mLurT5rk9Q6p7YMNLHcqdHWBLb+nZHovFeqUHXQublkKUiWwwExkroyulOtUrLDuBmrXu5b5JxKKeRgpIFAFLZ161Si2r8Zb8V281khE4rONavEZuaUkvWs7cE3UuacQLb8juDZldTcG0HpzjCUXR+Tn4ITOhqEx9HU3Mt76tvOnRu4P2fhC184ZPKtnHU6YaUoUs8HIn7Xu94zOSd8gx8efVS1MrNGv4lxTb8oDPGJAz6WkoFzi/eCCS9sgI8DhaAcn5IiLcJQnsfY/h6jFur15zhkahcoTN+xcZDwQw+lpVz26dpBxL586GEx8i+enHDCsZOH/hpHsMicoxob0p6zvETXYY4Tdm8MSXO1eMH70NrR5rLOzhcP+dx8npvF13ZG1SDWnkoS3r8zVt6NN9w8+dlPfxZv5Oz6kpcFXnbZaZmpIhUNpioBYaEGMWfpKL3dilx06aWXR5CPhuGggaFkHJgorQLDJsG+byv45sMf/tCCjVEsumkcDzR4bnLWXvnyl9eEfzYY9667PL2aYXtAyc2KI9gIF19wTgWyN8gBrQ3Ae4klPaDSaTUantd0AbpYvA0yM9DczztTWM18j9LscnTVbSYT27AApYjc0oq0cp3kpU5TbIYHNYhKPtMQWh/0VuY2Z5f4aji3BX8frPYG28q2sY1nQFyU62jWjb7ehdvBTLOm5Afe4ygROWJYcrHK+7apsr6sQQiFKkbinxQhYUCUVzwowlMsRQkxSdsaWIN81bV0kLx4NHKTrTuDxp4BESMvqHwjj3nu2nMrtcKcsHoJcwIC/GwvVNm2zAdPgTLteE5bhixvcK9Qwv2pBGSfVQ/KQLPNgmxjqI0cxkPnmPaatMIx7vYGzLlau79OgXDwEaby/vsfmG42F6fAwvqZtxGG4JDrVbp09juy0CphLRJYGwQORapT6qygucrlG3F5BifB5/clMtcMg1//+leTw799ZEHG//6ed05ev89rMi/xQELGQ3CrEnRT6L8Qk0p/GbyDBR5MobsD/vTe2MfTallTWNQztjfPgGpvyvi8FAEwXgLZ3CGMHZH6yzqJ7LPP60Oc2rrm1x41Ryrd8DjF13k/UCNeQRWjxwiPR7pEBCKv57qrr4gCvHOy9XY7l5fQnp/UKnudF1HKO562sZmfbslnXYWbikegTdjUKC7DOPukvaeGOl2n6+pSPvYQCFI6nlibzw2BLN1npMH0q9GNcRZHjLNqFU9z0J0775mzIl/mp/vJ7TQn8mXdu1rv5XOerdNrvO8z7muedUdS3xmDmwzu4iau28Qgz+wck59VID5jYRxTmH1946NY69zkutAS1/Kf+yNWUWpIRa7XJMNR+nJUebJGlGp5q0G5/OTQKD3qffFRYQ7yhsPk5TOe+85A50oacqq+ctihk28nb3PtdVP2Mwrv2ijSLbfYMs0+3js5KyVm/+eQQyaHfOFz9XxfTCF57PinxdBW5H7pwNdCH7qQFZoEuQuKZE+1rC7HDHKZsQtfKZjijNZ+jD6SruNc4M/otb3NNttOPn/IF8L7uCwdro6P4ReCI+MjL8jKo1XQJPyRSvUchLuHkaiyz0dYbjhgzg3PdJGLLrpgPlbWL395Wh0UFrOGqUp8/ehHP073krMjiB7Mhn0gkEPyhHIASvDngN4XFhjLtin6vAgsOLEcECZvdc3k7HDVq5k0Kn8Og7yx2jRhfD0SgfqEIgmMihNiozvssH0N1MsEsQws/JlR5IS5nDuHUszq5njIFCav00OtFuHmpdErZb/E0suO3NfASHo1jp6Kwx2vGGgmhRL1aiXaAqdh3EH8WdjbccEEzoCbmmTQ8ZFKL8jL9W32yoVMXKoFftds9PnuONFCvH8OyHxhy6Y+zA55K9IBxw6PwkHznYUkBPFRJc2GIu3GwV2eS3umZiqXNTpNmyAEXWPASMOrGTjiImUxFxuYJZ/fF3NA82wnnXTy5GdpGHBdvFZegRJfxbaNoQEOFBfXeu2eQP73pLyezY4EoiYyeHPbbbetvFzPIvYhpuGgSKXgLXc/z4a22pPs/Fe/UzgLShtGgZVwIfyn15wZF61YztSC7mdto8Y8e8304PxOOBMQP/vpiSECrTTZYcedJt/81jdLQFCqriefbcmw0xHpZsW7lgO3+OKLVt3g1dLeDzFPzLBCG9OQhVZ/7TWXl5y5Lgs/RpjE9KN++OMIv4cSU35+Gsi/Ku2n1izI+G/Zy4tN48I1H2JAiZEOxGJ0/VkI7c6EfClTMUVFGRbWB/a9Vsye17pKz7BWIMxhDGwQlvHxk+8lBW23XXarGsnrJGZFBhiCs39HzjqvGDFFsf47b7+zckmXimd+b5To3+NJivmaTz2QERPVmbYAACAASURBVBpnR6iD/B9WAH8KwdpL5klK1D8q/jz2OOOVl+QZwe72l1BTe0XWz+comoY9BwdgYcP3gkzzO0KOYhmFLE3zPe3BnofeA4OhP/KO/W3wDhYyPP29z6158jmKCHphfNulLKQx8T7du71Tc8Dbd84pTePwHddeO3umzzPFTME13FsI4pTc5n6uwYHpkE7vYeOwp3i/5qM9X+/jHPQcUcAUbHETYmAzgoxFrmoTPc2vZ7QmCixgCTurmyYOam68Z3xNCv1zDGR568g/xx33o5SSPbh6N1fSVeVfpgJcncFUXspcPX3n7cuIlCpDvuy66y7V+OCaq68q+Fc7u5HHO9gX5HZ70/aG3sYKkth7tySMQoGLP0MawOWjYlFCl9EhS8fA/9KXvzi5ASM5rTjvvuvPNX+cBrH7QvOEBIQNss/ujzG/ZHQffVTKc6qfCjnMuiySUnfzf/vb32VSn5wO43vWB046+eRUy7+kFBVW2mKp8mJipTioRsQLIOiwfBcPXCVNgzVDGd5w/dUZyOr5TjZZJkhS8PZpbwYDF1NlOSotZeK8h1ghDuvw7RmiyW6BzIZlM4Q2KFgTaGxJjK11Y9FYGF7HVamY4gU+sBE1l6akwUMWx0Q+IQsjprRYgskjaE8g6lQzDlt7JUOhDQi3J6nhvf5ZwnqaJtEw4cx6tZ33WQq0rv2/KdTgp6Fox88uVThTaA9lPirJOIA2vsMhjtl5oq1MuhC337vIQnu35mP0IdTlZMQFR2GNYU21sOiC7wL+Xj4nh9QBR/FmRFkD9yD0PBcYU6oBxYx1e20o5Of/5txKeMa2s8a3JDUJY5VVzaOhgNDvNRa2FrOyhi9/+V41PvtATh7Yxn649NJLaz0RcRwA9yZIQHjVbiyCUmHphUXYxRjR0cV0ozymhRagG4wCFrD17qL2qu0QUEMQjty5oTgWCki/t4EyE+b1GV2PrrzqysRJn1Xz9a53/3t1y+BJu+dgvE8C/+6cJPPlS8CsNWvNMi6syTJhsXum9r5ARKUU8syVepN7GxPmI6HjvPzoRz+ZHH/CKYHT95z853vfM5k1O4UgAl9ZG4L5cSk/aG9r+j1q/o5nGgUahnXdzzT24GjiMBTp+FvvQ/ceaMhQdoxgQnyrGNlguAMO+u+y9vWg3C1lHtdZd52xZ0HH+R+iIYE8O02+VawiiCXlC73cG+MIgsPDAGtKJxArXj3xPiEEhjVyonZ1wkgrh/wCviNjmjRmHRHYxOf8JJekGjm/XXt2VOYZSsqaUSTGZE0HFyHG7fQsayVX688wnpLsGIstC5q05HozZcJQzjnjFc4ZJQDbCPA5Y+l4LI/U34XFRovJcX/jMb/WRLiqww5trJOFPjOTEDRSxlautaP8eNeY1O7tb/7bc489w1q9vJ7d3ylBssQ9ux+v7yJNOVtrrrlWGWdtcJgHY+/qQG2k+LtnkFftPak7dAM0Ctpl3BSxe6nPvlYUqbSa74c8xOvUitP5XwgB31jyfIcddsz7j6v0IqlAN954Q0JC10eePzFpjZdUlsbWaV5iL+P0/DnhgOsTMmLrG5NztVoQrco3Vzwo59A+c4baGRGX9Z6aBxjih3zxi5Wio2767bffVZ72fUGxcDdWjKfeoYEHswb6KduLS+U+LWP7vDzCyHr1a/5lPjLQS1/y0ipO/r0jfjD5/QXnRlnK30tD1+SLdgqHDV/klVgCa8+ZXQ/cBZgVdSCozzjznCoZ9vh8zoG4/rKrJi9IxwuxIm40aEvukc2B0cjivSgtbrYIkelNb3xDvQ8etiCUB6F+eyxaCyr2ClI8+eenpXi4WpR3lAEwJ2PZbdedc40tsrH+Upvr4SpHGMw7m+veeLoScBWyV7ChiSU9EQ3hlJUHIiMQpm5+Q6Y+W+SeQHAWquCTeLjYjy1wB7w2vj+ahQ9IU2J6eQika6XbjAM4U4C1x+tvHZcqOnwOwsoZNwILWNWmaOZfw3cU6hifzTMOdCv9QZUfB9e1xEttEO81lNufp1Q9Ayuu1icxGI0KWGWEteo1DuUuIS3cHc/iu9/7dpUJBL/ZyN3bsCzbGGDgWBbnpWnSfntgoOVTC3nbbbecvPrf/q1Y35qqU3Cjafeo7cl4Aw0j9Ky11prpQpRYWv7e8af2RKW9gBORWRhaHV9qIwEsjMBUOc9TY8LfwJINobcR1fPYa23tZypP/17gAWc+9WM9LZVa1KfdJV7ZN775jck3v/GdPN9y5bUxFuzzzTfZsCzwVSM8PO9I+UrHkJwV3ABQW3mPGJvl/Y3uHd3f9O6EVQaZbPESABdedFmxZFfIuXzLW94SYtbzyxMDT7quCi88t0GqGyhFQ7mLLDIKHXAbq4rXdJ+WUqVo81lhB56CsVCcyy+/UpWIY0DxqOyP//rgh4r2L91Fl6dZKQMopqcgP8OZ8r0jQtWcYSaLcy0Rw3u9FLWnFMRKkbKQEZ1nHqs0BufTPRsVujrQnPxAXu3tQba6VvA9kQdlFGZfMYyL/Sp2mWdCcGoF1cXZG+a0D9pQaeJRG1Bd1KM9jWb4ive6Ni/L37qgCeVTjPgYAtUxxzyXcZIqbvmOfeUMUOI6klDixRPJ/mMcN4GoFbnncTY7vuk6TV60hpVCmLn0rGQAA4RivqdIW3qrRrHkuqBaz02hqbYmT9X6ynElS6UidfycorPXXMdzcmTMlXkq6Fc6EF5DlKDn8b59KD3y7JCGzjjjrFKAyrT6KSZqfOQAJV+F/SMDMPw9l9QU6I247vIpqoCRfHvk95577lHhHjUA9trrhWVgMz7PTBnOL335S8XDYLRRbppbGAM589fE4D/9mU+VfNkkxReURlW8Ybsdt699fG/KdtbaR2Yzpo1ndHpaNASo2Qkj3lk1gzcPq/eVr3xlEZbA9LcW6Tadp7JuAyn8R50BrTdnrTm30oE6ZND6A+S7yJE/+O58yvLYY46vLvW0MsWKRTiIOaP7O6sC9KegPHdd2zAFEcCxPq/iiSR9eXHHH/+TCJozCza5Owm2u77g2dU/7orkI3aDcEKOZQlO5rK/9z/eVRMOQmrGHwq2IgDIKjZbV6t4/T5vzsFJjl4Wjcd7S6yJNQKtbRZl/KqwSFnKCkvcdMtNIW7cEdhttWoqaxHAkTOVZB+m9vKG4Fn4XysZStOB65SYASM+XBU4WvA62KXQkDgyXqURKUzWsoWsAvBTD6ihl4aDenHAJsNbfGRBHhoyECJFFTSI9dgHri1sCs+B6dZQLSgajiLQkKhuvfXm2hh9kFUGaeGgLJfrU5RPjLcvbgJ6qXy/bCgC4tIcTPdHIjnkS4dWXiWlTiDyRv4R8hhh6++s0WvioeokAiqZFYv3TW96fWKJiVvkeiO3b9oUeUrKKK8g/74y1u5v06R3xXiqErU9X1n8U+alA0uwmFNxeOzBbo/moHt+ME9X7GmF0iXRGqrqKjMziSE9twMeXdjftRWTMdwdMpU0LMQ4NYMVl/jIRz5engVyFOPP2m+x+UaT2Vk7Vjb4GkGFFyq2S+CPOPG0JmwOfFWZyd+rrF0J05F68Xf5k/kcw0cXjiN+8KPJQyFDvDllMV/28pfUvgY9DcOgC4O0J1ratFzT2tdq8U6LMzQE3M+5aFoODoX+UCkBBq0c303DoiaYv/bVwyd/y3o++1nPHMxHaVi5ppSnQnemsT9zXwogZ+OWxMDJDrVh7005xAfDmhTztv5qY0O2ENmegrxTrRMD3ea5teFzhgh6eZW1Rjnz5sP3unQmxYBlCQ1rZeenvdFM7ma39z5oGLYLzFQ7iXynz7E1KkMgZ+FPKi/lVQZpxuE+xl/easa0ZJ3xodCdJfvS2SbXCG7P7bO8OAqwYrwIliDBKWu6kbCWCa3Ijc+LTHbOnM+bbrq5Whi6pz3fz9kM/KpGlr95RkpEIxHNRTDg3VO8uuKxVR50YYiowkHO19Tg4O2359owtPFBfjD+IVFkBfjZOaLsyWufxa8wHyphKdowN8iEsn37f+LAMvhUJ8KLuD1lS9/85rfU9rTXt41OUcP7yXkGZDZVst72lv1CalqvUmnAyKtVql74B5E53//u9ypL5OUvf2llhDD09TFdI+gPRVrExMw9B+OuGKVkLFlS6XvRC5eFtyOMSD5xHuzp60Jy8ix4II0o+r55W321WdU1x9/b+HZ2/ma/HHzwp+b/9KcnT0477ZdVJBkxpKCiGK8jxYDgXLZgK4NXsH7TVM7/ewTmX3PQHAgTbJF4BeIySy21bFlOH//4QZP742I/fcdtKo57S/rEccs1+R7kh0cC/8xJzPMFC9xoC4jxZ0N0Au4o4LxyUgc2i8f8/cRKz8kEbFtdQv6UnqjnnvvbeKApjB5LDIy4diwThYy3C2Fqq8ABc+bMLgiItUzVzVSkfYBmxk86VtTWcbFs65BHAcSD6p6gnmFm1wqK1O89yYQpOIoirZhc5ofl2kXwW3k7LDxE7xM6vCkL26QH47AxuxRgx1/bc6b41Bj2/D7TFY0q7SK/gzv7nl02r+qcxqOoNBAF3Ke5mQ6Zefeq8odyVTN3lS+M1ZtN861vfyutxX5RLEC5kIL4KtawLEFMQzmAEx+XqiQbp23W61POa9XaT+ZnprdnvVuQUCAgfwbayQkvUEoOM+jf+zpUeBlDPyNrWrMACgY64tqu55Dbx60QCyUo5TXyKRtacr02lvq7rdxmCtdWpNbMfkCqUmt3y623qIP50VT0Ui90wLtRJDkPs2evMdll553KG12uevuuucC7dK9HpmUprY/D+tDDfx0EmygBv/8jLPcKHcQI4kEQ4OaAAPzJiadNbr3j7nQcesZkvze9qbgIvKTK261ONCOVqY3C8UwU6diz/Yxd8ch4qgJQeSKx+GPoXnDBRTVnKjG5/yciCCnvzYP8gLbFv83dGiGGYEG218fYaMIKT4UCUgRAz9H2hO1n0Jz7K+6wbODuOmdSmcDKGaN4omfCVpX6xFtmzJsvucRlKE73KQiva+i2cWqdjds1ZoZxOhbe71GkTWoq7yvnxrOQZ/OiAO0Z//Yc4m1ii1JPLrzoDxVTc19rgxjXisznW5FD0yhD0G3vfWPj+TUpypo2dGx/U0gUr/Ewagryz3fci+Lystb2OAVTjPJf/LL2gXtXLDaGl4pGFQrJe0Jf5qJkBCXNvsqaQ3zaUKB8nWFerHvzdI0DvM6zMxf2xEAn8R7ktEeZTOPLKktRpAyJK1LlbOMYYNi9p5/+61Sg+6+aH14pVAJJCdJxzjnnVus0nV808b7yqitqzDumowtltl64E5wE3j9CKcUrney8c89NKPG68Gp2nGyeFm7IqOZqi5CYVOS7I4xqnIRGGl1LOESpwOXivGl1aRbJOY3QGRyKOJhLnI0u5E92Witwb4W7qijDCM1Bdxi6i6w5a/X5NuTjM2k8yrUCpVgY8IV4zwZhI6Lr3xJvRh3DVUKyANla+NpcWcgWMibZTRd9fHIVs1jHpmDxlw79+mS7bbfIZ5XNUgt3sEcJZdDYW9/6f6Ykjhy4/E0cSfH3u2L1DzbaOPSzZ88KoeWU5JH+fLJLOogosaY3JqWs1OCTwgz+c5Tqlw49PD3prquauO96x9sn+6T34aDRT5nFscwJjM7nnOmR9gEbMaRhoXZ7LAq0fwfV+rsDX57DYzyqgp6mUEgLfszJx8XooEhbGPe8+QxrjvAc6TDio/eUMuji+w4lCBc02wK/LaaGKH2/46Yd9Be7RsiygVcSV+HthpFWsZg8k43verw1EP5dydkc6TPiV7osjOo4PCKKUNzqbW9/dxlX2Tvllelf+5es7Q1J1sdQpdjQ3DX+nZtqN+45s0KP+W/2o73n0P8xzcCly2AXOqDgPqEDa8GyNz+QCnMi9j2uOdIMPIsD4znE4VrRgpgqfWJKHiplMYWpvD9Yf4mrBSrymZnQvjVpQ6c9lQVeaT57ecIgv043k3XWX7u6bXzykyq3/DxCf60qOoDl/HC8r2c9c88wy1NsIPsYb0A1mFZuzoD9xxDxLHLcSmDmPYdVvqy/wX4JkgfzXrFO5f0GcflFUB+5ucsFMn/f/31PEYEwKUct7GFEeM1EWEbFpYUx0W7S4BmFQswnYTE6aCjLKQd2qYp7Hv/jE1J15pmTXdP6DTSr0pW9woCZG89km/Sn7PVAAvJCViH4GV0FrWaPgbDnRQDK+RNf2+xpmy1oj0eh2RuEN4X559yn4nwxViA6rRhd29wJO6i7SkHzBj1bpZoVT2Jh2lqfEXPRhlMbz+KvPE3IG2OOHKJM3ZfAL6VVCNNIEVOcYAFZLfPT12sY1N8YgO5lPIS790CvnUPa8dNenzbeaz/kvp6zi9FXl5lca8Cro8qSsdtj3VfV/SgS8+Z7CEugdhXfoHb/b4QlxK3s444Fj3VnQP21vGe1sZsEtU6MJNXlmlfgWg0pN7GoYv85m8o+kkP273XX3ViOki4xxx+fMphJcfF8inSIh79+nxjYOaOnhwW/x+57pHD8U6sc6VE/PCqy46XVOGHevOsmr3313qWwEGCr6UNCZlIn9Z7W49hcbBFFSj/VPoiyvSsxVHtbfQFr5+zRJX8KwnJD4q9z5vKkUxIRWzmyRWqMZ9BAwHOL/YLuXVscn/xeOsTVxwW14YF6SUerEBqDbuVVVppfQfosyqrxSOfOnZ0DueHkuhBIlgkcu2EU6V1JRHeQ1o61PWfOrIJxxUcMgtCzeOI9NpnFuSuDNSgb+1vf/O7k1vR9lDPIoqQIwFAP5eaz11otFsn2telvS+5cHaB8T0zpqsCCd6Xakk7m66wztzq2v/c/P5pDt/HkHW/fL5DPmjWpDhohq/oOK2HlxKQQXSTLb7vN9pU/OoRilwmkmCPIM0ElPDLxHVfr4HKVP5zmIXYHDHFR/y4CyPQwtnXZsGz/Piy1YWAQkF6qwoA7q1B77jtTWVssAt3Cd8UjG9X7hJpx2cgFJ02JIAg0VdGF4TKjxCBF2jGuOvyZG98tGFR3hijMGs8UmrZBbZiRhD02hsPku5V7GiFYXmvDblk3zdSvDJNulbBQKWKeBcFAUMjx3TzpSOLRilWz1hgynmUQsEZZRQLr0ihPZR61xbs7BR7MEeEN3t5zj92COuxQ162DkP2GgCK9Y+ONNyqyE0u/4KY8s+fWvNdLGUYwKRimY88tDEd8eKwNwdBoiuduRdpGVF1sKkRb4I299LiCjs4864zETnLottomudeXpCPOl8pLWzbVW9QXfSDEhTXWWHXyijSxXmMN1ZlGYQCsXS81Q52hUqSZVx5pxcbyN+vfjbClxkjraTgcxBerLPOy6OSaCKvLLr8qMOTSk2c+a8/JmvGUwFLqG89UmC1Iq3XajGcdex8nYKTTLK4zSPbETenc8UDilxSY880ivzNrZE/suNPO1TrryiuH53BLlDfDee3ElQjWVlpSI8Q61X4lMLWbsy6EFqE95iKpIfHUMMOFeqwJOQI2tlddD0LVaANPtj0994YU3ZEyddIbumdnxxcHYWqwfWeS7HpN27BipHi+zlOuWLr4aOaplWSfO7/Lo/Z5e5Oh6Vm6/J8xUHz+xujz6ngkBWdvda3c3l9+1rNUPG/Il65gZH66BZp59RwUajVziMIwLsYUj58C/GWKZOy1117FgL/s8svq3ArdQRm6UIX5YRyD8rGsZxLveJKg7Y3iLXboCPR5c4rdeM5GydpAbVbxgIFB2nfWeR1pelFqCc9wdk5PecIvfvnLtdcoN+TDN+23X8oC7lw8CArsH/94eHJ10McLUohB43epKsoSSoEZfUhTzGeaoqfZ7WJPSNeYdB6aF10FfeR9OzOn/iJoWRyvuVGWzRmpNoAx4ORhV1eioKajAIMSoiOHGFoKgfAd8wmZ49WP9obCciB56YCjS1Lrjzo/abA8H+HnGRFcYLq/5vDrH7p0aucqPK8CiuIMqk54n+D0UApWgyssOvy+LamCAHPwbQibaaUsgrZnFOEm8SDFO//6wH01CIpbSapZwbSVHvN5whZ54v7cx8YeAmjRyWc/+4XJ5VfOi+X9rlQ9elEREP6SRNwO0g+SQbzkEFhMzorlfY3anWDlIlrkNUqlFT1gCPVMyEyB08UVOum9XfiCieIhdCyiBXBbtc3As9EZEz3JDf12t4uOkTTZqJV4C5/2KDvmUnlQgVfMp3SeVvwUbBMwfIcHwZJiFYs5t+DEsIYuONziTWDgjh36jvUSQOcpgGf/lNwv8Jr3xQyeGOuPIOh+f5oX3JzY84EHHZScystKYCP+PCuVfqwLkk3FuSIUPCv4yXz0fDn08uQwc6+9dt6UrJYiEDncoCfxxNlhBV908SXVPBgBgQCoGq45cATzqISiefGADM2RVCys3W6GPiAoDPPhqc60yFuZN+moIfKZitRe6X3RAncmguCzPGjpYeBrguT97/9QITcMQS68IiYbJWaz7tp6R86fbLTxhgUJjiIKjKtRmQd07gz+9QEe6BBy9hkBisWsIlaFJRJvccjFax5JXiV2+r0RDDyB36b4OeH51sSUnrr+hpmLYVDMRIsK0i20ZWFhBmeBQVYVobJu2PDmbt7184rMwsBWItQ8s9yLZIO4EgSoKgDlO1WjOt/pNWeo8CzPDfxtDndOkf8HMxaJ88YvLsp78Dnf4/0xdFs4lWGf9UaWMQ8g05mcAsK8YGAxwCpaEoEYQ6sNIPvC352hRm/a2G1ostd+FIoZ5CqyxF4zHi8KnRfakDUDwGeqUEX2XAnmGBsQPIrV2e8C9+5jj/Y4OpzgmTsOL6ZeMOnUWKTEPFMzdD2PzxZxZ+rhN0x7fQohQCBaafGY7kgcseOup59+RhyYOyave+2/ZV+sX/PUMsmYKA+M7yY8NhRtz9nb4OsyajIeY2imc58LY2uGMwMdEkJOMKbtkYK6QxZDuFRI4dzAsB/66EfLUXpyyHbmT6z+JSkrul1yOvFNIAtISRsEiXr603cuMql5JF+Mb+QAP6X2qNK1gCaGwik/P6UqZ2237Xa1JmenktP24S5APOWQMso4QBwE3mzFxpNxQp/ZdxRll2W99rp5tYZdqIKT0XMwmn0vjKePcpXTJijPevYz5uvrydvUTPkJ0bq3pXwZy5XV+c/k3SAATbVQsa3kzBHQBmbCxE7XSCkotVu9KFoP3Zi+gXzv+0fGgj9/8tQ04X4wA5fyoD0OK0CMhDCQg2qRddaAq2+V0mMO7xGpP3pIIOI37vMvof6/ryxCi8zTMilN4HFv/A0ejVJXPMBFE7cbwmQAlKOx91CkJSDzvxaYvLQux7cQDhz5Zw0tzCQIzLRs+xoOYZfSqnZa2bDgxlKY0+IFfe1OWWnosD3TgguySBSBZ3TAyvBIoL0tQAey799wWkNJbTX6HZzbUNRyy62wQHgXvp85LMg41pbrE9pgahVHCElpBY9mPaxJW3Y2NULPD9MN4qRs4M0SP3v+85+bROvkEk5z1hzqJtQgt4D5bomSFFcUi2fFj5JoqqEMlisImlL+QxjcCBX2wn77vbGIBgQq5WqDM97M6TIxGOyZqpWaueXNtMJkURNQvCCvJku0seK9grbz7I0utBLtOe0D07+PAzBgUvex7zBST03RdYpzsxBy/iN784+xkNdJo3OvJ6VI+wYbPHWy1eabVXNhZwZpB1pTa1yFOULSiiKA1DxQzSAUAgg0lrBKV6Ex/pH6owk1rzA5vpEi4OI/p/yeGI/i26znzVNOcJv0cdwofVOtt++2scYYsp7DMBhozFCk03hPrueeVTUGpJljglj1pKz5ttvtkLjZiqNw/JS41DCsdKdh4I39pBjLaBE2YpOMt4fiUdv3kITbQkDqriU3BT2Sx7nuOkMpeAaEFF7oVUE9wP4ILe3djQIq2vc9WAaGPp5+GksbaxSUf1NkfV56zfusuJc9Yl/zbryqXCkiTpVhHIhFK1fFRMTEycU1E/7ipfve3xMm4TnjNQwEacmqDrdUlItz5Mx3+syYi8FApxjlS7qOZzMenmpXVmpjzzlvmdPK3nvW6ck5MzphKatpDhS62TSQ7GnZk/qAYrHK852JMvEqygBXBifjZyw7t40utoHhOTv9zt+xWPtzxtaEm+YqWCf/1nEL7O9ZyF9r73yAbz+RtCnEQIpXfPIP4RQ8O6zc3XbdrVC1U089KXW3fzn56mFfqXnA5N0qaIYwDxnC2JR1UV12chY4WF7fD28GQqRpypaBeMkodZ8p2SqTGWXHCRLKwdg1B9bH+2Q+ebRUDEPM3dtStWntnN+On3tW8z/CPAsdpNrnU7SjZMQLX/Sc+aCpFZYbXTSkWTjoWFK8G8zYa4NTw5jlaLoAgdZlxUYyewgj2fyHJwXgxnicq62+cliyGxTlXTI1xiYv5nMHx6u8/JpYHHPrsKwc6I93YcM19CKITBE6tDyoI448enJkWIo77rD15J3veHMspeXj3c5bEHRfPDlJDjDlSnnSkRZl6UzkiCWwdIcHUMKRRT6FbMAaDINm5Dbc2l5mt+oxLw2jOmwzFVfDuQ2XdeeG/t1YKNLyiGQITgP8rtmCfNxvJHi7dhNAfGekQ4wk9Y5H+NkVn3yXJ+qn+FvDwM1MtGkHJT/5odlIVRAgaRIqdzhQyl0hsyhkoE2UQ84LUbf4nghDe4CX2IW7S8hMyQW+v0Z5KinNFcVPKBsHK96LMFZr9zdh+J2eeCLrUHwTg3WUM0sz4kCS557zmzpg737X28PWO7UED2boToF9PM8vIxjMi/1gDT27mNwDIRiJbVFqmMDmrQWqZ6DwC8bKBui5rrjaFFJsw6M9mIZ6x6H533mkbc3XoXG9rBVa/AkpBq45N1j1xAi1b4eIZT4wop+Yca2XvOfnPffZZTSKz4hdigObRwxJ+4/RZFy333FbeTiL6RIUwcyDozD6BUb2fqVSZB4YF3crAB8P9Y7Eqv+SikJd2lEhi72CECBzVK3lzBVFaO29xQAAIABJREFUihCmSDuiX5HjSlmMcpDm3eeci4GEBELOfTbfars0XQiUHthOwfGnBLkqby9GKCNA4QgoVKEYGbti8OZojaQyaD8nZxTBBCHOOfUMDGgvEJ/UDM2WzQdDoir25P7GwVuQXoNFLq5m/hBFhIfMR5X+iwHQ6074IzghKNkv7WFRPs6E520h6f7i7uPcj1leoECrdGCIR4zM/I8wlQ/M+x1M9RTUyNo5i/7+l3hTK8ozzNpfFSKWZ7HXKeZiXuf75Gore4oCIVPs2DN0eT/7oBi305SyDjfZB9a9oV3v+45ewciVzVkxb12hqZnt1sTzlbEsNTDyCGTv+ex140LSpJwZLRXiQfZKxgR0UNYA8qbvMyi8BgdEj+Y/LSBSkeXmj8EorxTKuEzgUcz1s+IcfXz/A4J+JVQQ/oVrXZPqRm9961tTa3m5ZAF8sXKFeYmf/cxnYhheVS3Q5I8i3NkD9MID1ZpQjexwbCLv7rzr9mkO7divDNWnpHEJo7Ohec/+p3vuKr0AUfNaMvCyXNMyKivktMjk2qBdUrW0l0Pc5LjY0y1Lq/569Im9a00ZDxBVjuQie+zx9PnrJYl+uZT7c7H141lIMC5XOpN4z93K/UleXzQB2K0KDtAN/pEpYWXEqBaf/PgnJ0w+94XD0gljrbj3ayRuclt5mggIlWsUj/XaeVdPDjzw01mwFKYPnEuZgqM8PChitbTRWk1nmVhprCk1YT/8kYMSA7lr8tVDD056y5a1ccSIbCSW3GKJNxUpIBYZ607u0nKZyMVTGH9Ado1lT5tqF3cjFnhgwPZkHdYWkA2FFSw5/W4LUaw1lpHf+0C059IxFFahCR+Hc8SjBhsxAj2FAqolj5hfw0dTCJTlJi6rh2ATCHoRja0ZfYN4M/J5R8k0ZcNGmTTvj872vK3AnZlnscgnRakgefFcCE8eG88CKuA6KtfwRHk9y2ajKa4+jJBQ7PN989xWqLF7VmlOlIW9YtMVXT7Gj8+554UhPrBCb7751jqkDpx8Mw3f74qgtenNz6WXXlE1MRHIFGTXrYEQVJTbHhQnveCCC4rYohRke5WMuScmLt4x6C6sbz662EYrxjZqfLc90fZSe91nGlH93mOVaf9e659rzc/Ps846MzHeCyY7bL99zeX7P/DB2rezcw6WzN5ccfmnBGpdt1Kz1kyuJFj24QgCMcX2ht3b/iAsi7UbBKig3r8yNhC/loqnflHNI7aktl1VGi4w+u13ZF6TjrZsDOGfpw61BhAYrYsnkd0e3WuvF02e/7znDfJMlIBKT8NOSHw9Akos+447b6v7SXkr71hYJmuh3unKMXp22Hn3cCRuiQALzBoEYIRvsGuTAjP9N6gRbLd61u76fK9CCekzap0KBsy5lO9rrzinDAmKhDLYPnP3z4RcqhXdFDqz5zqkwWDospaNjICTR6/VYQCIF2uwzWvr82OdFrLdl6h/OyfGvKDAQSnSrgY1SIYDspR9MPgBndDvXt34gSEl7ca8UqT/CNLl/EFWXAOSVChHrj1Y2EOR8qbBmNbcmWjDrj0fCt917IVREWwgbv7dSEgre71/V19tlfKIiyw0LZNHtvhOh5vKKMlY2jD3fQRBpB/7jiKnFNyDLO5zIvXQ84vtujf0R5gIWgVtI2v+kMpbv0+Fo10C32Mlu4ZXyYuMSbqMPfHrxG7f918fLOepoNks3eWJ4b7jne+sf//gB0cW94FMe2rYu7vGS1XTVxs2eZpqdisEs2KMmPsj78jhMgayl+1fOkEv6iWfmLrWiFEKeEzloGu20UWR6vX7SCqAkRNZhno2zwVh2ii5qpCio485pgwm8kc5xDF/OiFpfDCpzyJGYTxvkqIzi7zilS+dr1D4rDVWqeorNGzFAZLrA7O+OQ/A2pwXr1SeoJQTXo4mv1W9KAtmIcApR8Z7/HP6kSrYfeVVV1elpLlrzymFrPUNDS+upFO6TT9Yv7HMEXki2HcKjRmkJ6GWFXXoV76WSXlk8o637VeKtzeI3NUFHlgOc20YUG0eVqFkFlQTXEC6NlDFziieuvZoC+X9ilHlv7H4CwteD0U64qosep/l+TkUNmZ7OD5ThBGKyAGtzRwhld8LnqkxIZVk8zl0+bz/HCjX7JZFvdEtepF8ps21O/biO+bduJAjHIZRPlGcYMR32tIedXUDr0VBum7VpM1nG44YMbd/VD4ewd6ECvdqurzrF6En0N7NSVsqFmUUaNcUtRYOjjypUuJZSwL46hBMTjrppAT8T6t9ITzgRWivGiKYfQJOuSPXJVSfmvqzzw809dznPr/aJvl7sxWrxGPGrXwl61oxDgcGbFTNhOOZdM6u532y5vLxjozdWlE2XdzCnHS8tBVlG1ItzNpgmhkb7T3QBlZDu6VMI0zMj7iO07Vbqvx89WtfT8zm59VbVZ1dPXI3eOo6YbvuMdli080HnJq9yqrGG3AGKNVqlTadX/07B/P04ekhXiRtsH5W3sQyKWxynybqeYiqTJN6t8vGose4R9iz3wgCKEvxB3Lw5da9OoXv5RSed8751QJt9dVWCuFOAvotxYZ09u1rYYSxtxbP+G4OZL35ZG6QJezsZZ8yIGneSiFIYdW6h1Qq3yFkGEW8TCxNBgDiC4VhPUDtCE1QBEqN0KWYsLN9tlnY9qm5sD9cn0BzfehIK84xxhFjHWdyoGXjPIxyfe2BNozrb52jWQUdpgSfro09IO8B+Xt1XG4QZwbbuXgcmafq3TuFRQv6i1PQLQvJEWfO8xDQzocxjmbcT6nz2nLAfNvzZGOHUDyv+/AQu0tMQ/QzlSJj0zM4m42y9NgbdmwCYcdo/e47g/Q48k3NRROmZoaMGmZmSDCMxMnpBfJSxbNOGVrQGDwyq3LrC6VksI/Yo4YUitQfeNCBRR6SLkayXhKexDujSHVKOvbYY2N0Pbkqo11++aUhLe4ZQ3Hp2mdrxkO8JdwKBrazIgTVvZMZXNUY48ZwcGIELL10+vtm3q3/zK5QYqdkiTUztqWfPAy8UfdaNbxHIgvvnqw1Z3Y1W0fa8qwrpQnL+hmTEBM0wvyqsif1ppsIVEWvT3ziY/OxK1dY/slJmJbwr7WTuovBnGPpPikWxaV5MBvfBUwiuIgFOPDn4WFZAAHng/774Gp7teaaqxTziqC8/voQjHLovRziU0/9ZSCxE3NIFT6PVRzSEbKAPNF11p47+d1vfhs495gsyKPJW9snzK6dKh3Eg2sB1oXZufsjiTzwVOUtjr8vFiHAY5ZzxtqhRG1qFVwUZCBUsXCbmOJ7XUavBjlVqsMyi+KN5cKiJnBmKqw+DA5Sw6+8c8Lde7VBs3hdWFtPUsK9BXkv9iAgjVhue7Y+A0ryck9/U0aPpcuKLwg2UEcJtmlB8lLc8ciq1ViMoCZGLR8P3TPwQj2PAu0FDUVgU6Q2hLEq+1UIQ/5NWVW/vxxwHntZs1XfdBBVfNaBx9ClBDRSP/zwb6TqzzVlDCHHqGaFYs6TRzpYLOtxxZVX1fjdY8cddpq86lWvqHSn0cV+FPwGdxG6jKFfp4LQZbm29mPG4tASzP6u5CQvF6rBWzPnkvtVcGFN86q6dGDlRk+hTHPpgHqWrqbjby2kzPljPdTeF61I/d3nXef4H/+42sGJ94jLfOhDH8kchVwUREbHnOc/9xmTTZIOxAMgKPDe5GneGajUNaAFXgQTROLev4j3SnkZtU8JkVvi2VfLPf/L92+P8GWg6XCEHekw20NQHnMvNs1rs/+kLDE8lDh70QufX0VVbkoKgPw8BbcJkkJzcr2rE5fEokX5v/tP9012TVqCGGi1kssZrf6VGLWZY4oUM5eCE0PrakJIL4d//fAive2992uKIObaQjgIZV7GA2noogVFZpwqhN7zZE57j204tqAm+Lsc3ii5N9JVen/aR204trzo9XXGWmEWW3raCq3WYlo43ri6k5L3PZuxMPLKgIl8tP8px1ak7mefM+a8GIwUjr+3J02RdtGLChHkOxSp5+vwCYXcZKVC2zIW92yPtJVjxyn72v7exfL9zatRjz7Xo0pT8jDDPeGsuD5lvX4Yr+Ti9SnL1+fEWXPOKPVGEvQLJSsRFf3dC1tbjNhzOe9g7/sTu2co6sPreqeccsrk7Cgf1br+kQ5Fa6dQhZaEoF29iT/2sY+VF/m2NLQ3D+VNZt8x6OaGwKQ4BsWsTsFqYGbefhlvkad5nvsfTInIyLgll0j1pqkuAGH3q2Pr4vtXpzHLPdnbm4bfITe0jFvnRzpLdNrXDju8cv+hqbxbJVDXjZeMYQx6vvKKq1Oy87hau00jl6zVIp/97H/PvyhB3zlrDbd8LbGFHKQ7UkJpm/R+I7gvv/zKYOdzKpUCKcKioPmPAgyT6lEJstx++22rQ8yPUqB403TzeM2r/608L56ROqs2hMIKUhw+9vEDShFLl1g7lS9uTFxj2223SX/Cy5Jv9OPJEpmUN75h7wSidymWn4NIAFCUNo4H57WxquSSsTgIkxVXTFxCDFDjbjFQbaWmiqbZiWMDL0xD6b+3gmulWsI/18JU5sWZ8Lb4Oo7WbOWGa3kA4oXGSMgSZKo4sZIUR6gDVqy5ofC8OhbbbaI6HaGFRi+0g9yCn2Joy7292VYQrunaxkYwCr5Tij4nRioeqfqMslcqA/G4W/BQSGJMfqe4vMC2zSamND3TH5KMfkV6jD49Rs6t+c7+BxxUucLgYmsinl5GFuUVYS3eclsYrRL39S9VuAD7sdIqIkhYu7Nmza78VPNWSekZv5KBmrdDTQgYz9iJ7eLxSGms0o4T8wTMP4HB4+6mBO19tDA1tkronwqzJhQMY2QhqaD3RB/ImYq0v3t9wg2/OPXUOvhbpuHDl7/8lbAUzwnko4F3GhbPWXMyd/acYr4jVIENraW1cFCtaQn0PHO1giuG7uMS8wR1/rPyc80RQfM3AjIowD3ioVKhdKqoerkRKkV0m8b7ihMg9xc0+XARuMDq73zHO2N03DK5Jx4mkhhj7OHqmKN+9h3VjWfu3HVyDi+eLLP8ypPtq+G2OLN5eVzBscpG6hMr3YgxVhBzPBbt7iTZn332Ocnjvnjy6le/OsUbNq/i5gQ2hKHjd84A4cxgk66Dnc+wGOehC8KPlJCRdqGc6ANlIHl5r8+YvTriV8Oob2XaSEuzS32viX4Fu05hXPKjIWrjsp8ozkYq2uDyHWtVRDn5zEFb6jrCONVB5v46GzwucUKKVPu8/n4zkD2LNCAKo2RE5YPek3SiK0tGOqtdCtReNya/g8+dGWMdToNyq4sXLDtzf3aZwkLipmQzsrrQA8zXnNFF4whRfvaLefSdDkOZoyZamYtuK0dWSEOqHPWpEWk9GzI2Fz4LPbJfKVPQLEh0v//zpgrRCQnZc8/Y8xmTY6MnGGEve8nLJmefc3aqH50dr3LjycrJ9Fh//XWqchM+wQZPXT9zc1UZL9tFR6yQ6w8ZNzqxQBnNv/PRoSfz4jXmYPAkquhNPnPsj36UcMzvg4I9N9eGsC41WX7KIv9bZMdHPvjhqu+rsIMQozQ6qUWMRbwNSh0acOSRR9X677jjTpNFXv6Kl8yXsLvuOmulPdnLKoiLaGRDsPYVikcO6Ly0YdlEOeQhLYDDYWDLpfKF3DmEio02SSL91FttaK2FlonGPLwogvjCC/9QHrAuJHMSU7ryyqvTWeLn4UY9koTcF09e8ILn1WfFTMVvHRgbFEmlobYcuyLHiJFa/DUjjGsjZMJGMXACZcQ+OlbWymshlDe82YbxxsSHgZd7eW+kIEwbb2cMjy3A0IvaRQGq5u2U6VWdcTKnlLU2Ua5HQXbj3CL8RKB2PmjXy3UYvffY2pyerQkInS/XJKWxkUeeaG2cKMhKkC7iQijkUhnyklrAk6A0ETKkIpjTMQYe6yA2VbJ9BDbIY9DQA+mDgpBkMrE/D4QJKlEXk8JWzs/vVQg/9wLZIzBRzOsH2gcb77rrrgs8y8qFy6FQe5P32sKtLWKKwn1+FZjFe8ZE8HaO8oiR6DJ0W3nVrOyy2mPF8jKQjcroC8zZTdxnQvb2pGdsA6XnrWDbfO+xe6YPZo+zhZTvU6RKou2y69NLkei/aD7kt12R1msMy23CMRj7NuXnUOyRJ+RVRxhh9Y6zFXJLPlPs3IxvnZCVNCoWIy2kIUrvTxG6D6dEYKVoERbTvVuwVYrXV5nAqj8yqhV5Hnly5kT1mNfu/drJRoGqGFQqQt2XcMxSEbQXX3JRwVcY/AT7yqvPmayeWrqIhGUw5j9M04eCzBgrxcBbcDakNOkDKQ9V7Eu8S8UlBRegF+ZMuTx7ljImiHh3rTCw6RnCbSwNlGaU0rOXePC+43febHubDdF2nLPXxPdbkbYH2uvZa9voEkHcjHPP1DBnk2mayMNY829nhuHXhDP7CAqyfJScmKi6r8ZcuYuRnc289bnqYJLzZy3IVuiM6ynjaZwQCSlijIyCIKeVynz3vPPOq0IB5HK3unOGzCFPtBVlEdmmHIwmL1GkFDfFWGsSlMc5tQ87y4Ks4WX3/i5ZkOv0vLWyrn3acfJpDHnEqRepaxmHEoLLBR3aasutK63uox/5aMVSV0i4Y/vtd5wskb38gxRecL5fl/3onvOuv7b2xKU5L+Zlq1QN22KzLSpPdNXkrFdJU3JpGlJsXVTjtd2jIwaEzUlayLBveUK+/Sl7/fvfOzL7O952nDqIpnOgucaO6TzGK52XPf7976eC3hlnpsPTjhnHVguKfDB0d00IhwF/XcrfHhNIWlWkRfbbb9/5tO0jjzwwefN+bwrpaNlKsKd1q8JRDjnFgS1HeVKqAtV/z0H2sHPmzK5i9AhFLCNdx1/3ur0D4a67AN9v780DgowvuTi05q23TH3f4yYn/PSUWMZ7RlgPermDvG3+9prX/FvBSbcG0mL5OTzljWXTO2wd66BIeYEIHO6zRhjC5W0Exuxapq10F7jw024mDa1Scm3RDqh0wJdD6KI/hywQATBTgLbn4hp9/ZnxtPp+xtHC18qKXbnmUmGM+c7daVZr0zksyEagPDGT3oyjiMIgLzTk2/T09sq7DF7DzObYoe4u91hyD8Yy5LHz1ghj7YdYjNaLYUORUuygazCjJs1iZ4wBeWEOIGWoTBsl68DJPRUKOOfcsycn/OykPEdyeLNHRp7qI3X9y1KsfsOkYbwo5b923HGHWjPP0tavsmM80JneIaXUa/CXSuBfKHA8K6udQL7iiitr3L0vKuabMWm71PV2G0HoKiztjRpf/RePQdy0LfD2WHod/T7TwFpg9k//0XuQ4AJTnh0vFERm/RR3R8ggIFddablqF/dg0lu2DBS+9mx5pcnzzJp0yUTrXhBR3q8wQlAQ4yJYkZl4omvGO7knHsENgWqlXdibmmnrKoTwwthcZJGRZF+l8zQe9r/8AuaVUgIOf1PSil7y4heWt3x/kKIEPcOyvLlqjxKcayR+CmFiNBHyyy2/Snm9S8WgBdM2iesnP/lJPd9OETa+d2qMCQIe+vCC5z+/4lwUBnjbHK0Rg9l86tpkza0BqBjyAUqz9qDEhtX9nYLwHetOGfh7zVMeys9mszvrDe32+Hod24Du898ZAva1cXnWRnc61aRThjyPz9tnXj7HM3t8kCqYojl1FleLR92VjW4OMUtKF8+L4nJNCpVi5d00NOuMOYP2s3rFHZt3TYUNinhW/IoRYzVXziOv3N94q+akz4zPtfHQ3mjPpWdoT993PdfSgWEZ2+29mTef8ewNc7fX7jred+bISqgEmdgsYZ9rWJmRTjdslLoBMjaM6VcJ0ez/iQPKuNxnnzdWjPGwr301ztILJm/Y9w3VKu2nJ55QfULnXXNtzdU2qb1LLjHqtg7Sg7Px58wBRVr8DEZkxlUEy+zvEXuWNRBZmrPGmfJ3DgSDlTG2Usisx4ZIdN75v81YkqqTcYKm7QGI526771Y9mu0NaZg/ipOIhb510FnIyfVRnp7nmc96RjkGavwed9zxCjKsN59ru+Lyy1TA9QXPe04J0uorarNPc8NM4j0pwWfh4d6E8p0hWoB8Xbg3/VFH/7As7Ze+bK/qcsEdJ8jKE8qiw8hpci48S/zggw+pg4WN9ddYV2uvPXfy3ve8u653440jN2mFQBEC1jcEv+fqK1kILh7w5ggUEyY8SN4t69QBHpYoBu0oM9hKb5ByMLZGZSDv2xwNC/lsK6aFyjOEolyvDxhPcxRtkA8o/3SUe/O99p66Zmh1z+OJTu/Fa0QyYnVSKp7HOByejmV0cQVjtfFtUq++fwuJtrw9AzjKZymUQcwC6yWXr6B46Smqigyvzaas61XbrRQDz0ZD1gHXyQFUS9U1EEF8vpPgCYRbEwv33uyw6H524s8mh331a7Fkh4eF8KI02Gabb1wM3N0TY1sv1hvPuD1QKIbD61ka5nYg/S5lBpwrd/TCC1MyMIobdKg4x5bpds+bAR8qAQkCBXUZR0HruUbD55W+gRxmPsLU45GqWKUcoPUBbXcz745Bm58eV6/jYxVp/95C2efcy8H7Qfoa6jG6SQov/DDW9jUpOCG95Rn/D2P/ATZZVayP2z2iIKAoUZIwZBBBoiTJAgLmnBH0mAPmcECPHrOioiIgmEWPCSMqOUrGgEqOkkQQBMmo83/uWl0zLZe/7/raC2fmfbt3771WrQpPPVW18/ZRKKvEwz2p8iyPDfmn9nEqK67FOXEfogTy3JGVqOXCOA3lRGa/7oqyuCuOHW4B46YMRpDLWJZMBLIbUegoqRIh1cDvOJyg2buiTJyrFcL23CO525VWWHmyayZwgHd1wjE/9WE5R9jIN6azmDq++1OIvniMxzbbbl/RPxjXGppBa9yVKIaBYzAMSeeovebVr6nz2BOLRheg0bTBuW8ZrT64SD9xMumhJsy1kvS5Lv3oWlLXaGe3UaUxW3jBWLxOufSZ7P3yue6q1B28QLuzCERDlfbAuZN355z5O6XK4eQML5I6YTXa1mKl9IV2PegH2NZ9VV/k/JvOc28Y8Rw377dOWKlyppC8rn1WooaF77s4LaMJQWrucxZd33owqNfHIWKUeuILR4w+bMe69cSsk1+NMqaNHaA3wrhiP0/ROmvv+3zW9zciQLa9GNHq6x2I/YZEzc6K+xpkpYEa0EEd/WqCI3LnPGDw7/++99bvdtx+pxpHdswxR4cns1FFpBq0fPf736mm9JxnwdEyabIAhl4rdZ09ONzemRom0BtN8gfs/XB1vZzQyIYI02Fxb32ebkrQYgCB6PIHP/jRZN993x4C3vPzvgdXiaZysd/+9nc1+vFZaU+InQ4hYUy/8bVvVN7b2aW7OAl4HE2K9JxzlllmiXmmmC8VhhRDoZ0UMtHmmz++FCw4hXdss92kiFSDBkoKRLB6WgquECuv7pAyoLC16+Jl2iCwpY1h+NozJAiug014zjm/nrz3Le+arLDm3ERA/5i8Yu8XVkFs1ZpF+VGk1W4rC+VBtW0yTkf0RlgXC92ZEZJYNm7M1JehWEbBebV2nv69FMsU5nXw3I9o02u2ZtShmt/HNiUrFFs3fe/62THbNEXbU+Pa3zGM8ugS08a4rg+SlT+tUWfpoxqP0H88XcaUgkL4wMwFtRNiz8q4umZH4ZUUz+86pzNr8Lvwm3EhvAzHn9OeUY60o2PvFzFUz9rsEWNO4Iwas97ywXI9vhOM53vWjSHU2GFAT7eVt2gdHxEPjof4qte8toSU87JFPDcDeTV95rkvHuVYOZ7s59IRWIeOYgShKJ/wPYynZzZdRj4N65PnpzczWSJ7PFCRj89TLNVjNusjYnJfZKTp/h3ZUFYOkOfs9nHtdc8q7I4srU3D5m0wZ6PTdsYWyNaQM4rRvpyZ8YHQHXvKWTzq5z8rZGSzzTaufqN/yV4gRqmRtv5ku+DFOHWlhCv3P9imeARGADpP+hDjLBDne/6Z/Ls6OhEYuDWOkBf4jAEdqYxhWHnZw4i2YzhyiAyX83vttTcEjlwyXIRXTJ6ayGChEDFwIC679KJimypnsh5/+pP+vYtNVllNUb7OPA8JrH/s5MADPzfZfY9dq4ELZOGxj9mgpndstdWWpYzIg8HkrgEKsz+UkP1qQ2jtBgqTwRhrQLFuruehMIvYlD8ZIPlRa9UkmrEvmgtIRwwD2vvTkWob7vpFXv0ef2/HraLAGX3RUSF5Ked3Cv9LHXgOcsGIMHzQG2UVq8SR81Ly5f4oWQZLucYliaQZJTW14FCySd4ZYMbYVCwRnHtt0pw14mhoYAIFXGut0eBj6Kmxh02gaudijAgb7S87ehx6bMhmy3P9LA7VonpT53+eY/a6dEhHu77Hc3QAwpgxlP69fPSB90GenMcuZ6KnWq/g0YChGaWjjjoqZMTDE6U+dnL0L4/JsIfNU8p4VTgFm6Z0bOvqDXziScfX2VkihlLXo02SX9f73T1BwETBq4bhu+oqqxWZspGFgtajN0Wm98YI09V/iFPI6Cm7dBg0f5GCQEDkoHw8taq/Pu83k3XilAsK6RFEImuvuuAPMexakmq6j/R5erolgX7xhlaO02RPDz30i4VIbLxJBpvvtNN28zBJ9TnU8d/0cWw+A7ZFKPJjPMj2Vhp2MyNUvqWjUWEveEvdoIbyJxx/YoY9n1MLgZqvAw4L3jDFdblJEYXaQCUDxx1/ymS/d+9b5QI88LUjPG7QIip3US5TOcEoB14OA81zEfqDgy38smnevVCYkS0Yo/RlgfAZ+OwlCsPw6qkbD4w+2qiqNfU7EOBsc29/X9D6b+RXCWz/10O9x7+1Txv3x6xr69YNGvweYcrve1SSa3XtGwVvYx1699H5PYeI4Mp71oifGn0nz7lITdhxmIokIG8SCPC+WifdiybFIHbdR4WtJiIDE/lOXrfXjWnLRUAJlqiQgXLAe9+HkkLoSaeRGEeGUn7sk584IJNIdg9Mv+eWaglnAAAgAElEQVRkmdQeWnuwIQU/WJXDcemX77wlkxguC4NOO0AGFJnCIR+EipRXZF/NJYVqnHnmOZPPfPoT5ZnKJ5oMw1A7xKIeipq86knr2vaAM8EjHd55DP+09yk56tKJzp8MiGiBEup0xKwzNP/m85fZSLUhM4X4Z2WWKjm3R9/IMONCahKZ2Q9zRH3P8pmtuHG6HZm0RJkpJ2knwJ/XxzBVT9nsA4V7cdjyEIOFg77clULzO0UNoDbRZqEg8seD1m+izGiBueBVz2BHpsa1mOjV93ehOCyDWPbU8BE23HD9yfJh9i7xcEXpy1dXMDAzYhmn5WFLLFXt3f6U6RlfzyxHSmXDtHF0Rlebu0bg9guKnclzV9gPUkNOIW8MiJy2l5FWPlOwau6ZXDMc93Bqs3cNUXKWIDOuxekcrNgB/XfubjjGw2n2X0W4eV9DwrMokf2dNQ7upYzMlKzl365RXIzcWzmdhcAtVZEfB09jCYr2wuQYv/3tb9ds2jcHQdOw4MQTTygj4nvs35apjz0n8uD8IKo0MgclsSZKxpRZiPD33PMp1V3n2qRQOo1T81vzn/WZdQoa8XKvjIiz73qMXsttf6alYFaOB7s60V7W3BoPwtNou9hQMoShkZY2yIPfclOdN5+FRDRaBSEyt3a77L33cdBNDpNqoS9+8ctfTD6Y6UHbZGyZpiO/CxlthRi6x6W8aufYGk70tddclXabG1RO3uSYu+5JOd6a61THPWtoT4t8FoPZSNxI1wwnqvX4xWnk8MkDPl0VIgImjgg7s1og9CUTrECC1GIflxK9Qw75YpoIXVP6hg0juybH4GJ4qZRYL+kpa22f7AP9pJ/7oYceGh0Ymc3Xz9ls843nedCFY2TUavL+LSJjiEBU3o9GBBF8Qs1TxmQSylPiakx5AAwjUoGuD1hM56bx8Je+/M1ASekosfBSk/99/3uqe4mXhDtIyLUsnMbmFhKb8Mwzzy4FuVJyDmuFaNF9KD0oLwiDl+HHLNQ8mMdOkTAqDNIiiw7IsiPKCrtFDVMj2hGGPxmZjpL7UPWGNMO3+7cynn7mu2p0ToSuYZP2+Agxj4fXPu4hSiIKizJnDORIvSiDYUBHdyEsPteSV2lIxmF2j93Euj/n91VPGIGQV8Hs7FxnC/pgOA8SgUiYwcMs5H065IykSElkzNPDjvP9HB7Q0p9DltCVhRCCNIp0kfovXU0oigHd3FH1wTVaLkp8XtZk0cCmDiRl5rlGQ+jRt7QPo6jpL4EMz/31uWG2nllD3UHFcm3qyXQkUVPMSfpbDC0Dcued9052333XyTvf8c7yRNVtjtFbo8OOw+0A+z6THSgW66OEA/Na/o0idvg9r/1yP2A4DpUXZ0nd2gOh85aHVkitbGcVlH22X7r4nBO5dyZEIJelAclPf/Kz4hfweu+/7+7JDtvtkH0ZdX+6iDEcDcuOUoS/lcJGNgPxXXHFVcXQ7Zz4vXnPvRw5pR4xIsVO1xUre0BealTaTEQ6DM2Ccp52iBo6FiVpR3jppZcVz8GwAH1ON4kTe+qpp5bcGMC0XIz/ppvIWT244HtwpXptsuFa0I/vBtq+IVG33JHSAY6ts3JD0IbiUyRCs1ZdAgPulrsXIdMx2N89/q5TKhS9V+fAKdOGYRfsyYDX7V0zUN1XR21tRBqqbOM6PzKOm9GEPWendY57ZnREmK4hkvG+x4aJyoE/8sgfFNFr+x23q/RB14e2o0seGdcmCEEWnA/pEuftW9/6ViE5e+21VxH5NCpxrjry5jQybtAq99VnyO/dBxnqRhXtZLRD1s/aKEuvT0eczRp3XZ/tfXRtUaXPtRHvyG9Mo1qoegEox9oirSidNWuhMQNm+KabblLP6J45786ByP3UDAN//wf+t5jsT3zirpNvHPHN6r2O3Kr+U6cyo//cjxaLdwceh1jSMQKCDRPJ0jV0EIRwMLlH85t2GoZRfXA1JHlPRrZpmiB3KsUA2douTSO23367yMm/Jldd8adCdvBJPCu9Bi5eLsa9BxYUAhHns3unc4CsDxlD0mMPOFJQ2zkbb7xhnWTlJo/LOKOFF1moLLPNZyBbOFyARUYAWSeRaDc8cOB//evfTD760U+E0rzzZJddd6wm948PNPyzn/2sWJs777xD0eW/9vWvjUOW3/0p0yWq56S+u4bh5oB94pOfnpx00imTnXZ8QjzdDaudFGXIqFo0ilBBL69krRSJ26BrY8AJ07qZWGOaxsJpGch4FF0/iyg9yohaLBGovzfcwZD+J0XZ0F0bznGQKa8Y06nnO6twHQr/tpFyD4y49w4YJt2BsrF1EKazW2H7FB82cHufhNFa9+Fv5exP75n1rBuedJ9NPgKr85TAG4yQA2XDvZcHVzD09AA2uYaikxOVL/R7Eao1oQwJFSM0HIg0owiE5Xpz00tTHoFTcGMMoPtbKt/75zhBpjo8LMahI/QBny4QdGOzeK5nn31usVDtI9a2KBSjWT4RscAaVMvH7Pcuu+xSbFcDgmtKSF4/S1s+DgGHq3NzlA4oR6RArhA45Hrboeka4OHoIFxpRzccG3nThnRnIceOcmadr9lItJ2w/v3fM/DBlIwzzzq7hskvu9zSky9/6cvl7TKuZic+K02611or0FSNFGSEMqc299IwL7YumBvUrsbXLN77EplzLqzXfeDN6pg1EA77VfXckfly7JLPxF6UD8VGHe0myef4TBnSGu49yCOjjhRcu0ilAazh7plxum5Y1qdE+Z0VJGDtMHxfnUkd0j2tqBt9Qdbw/H9KCdBBGfb+6Mwm3SYQvPVvRmmnD0QVvhOU6V4flzOumJ5e4bA544yYP8mq6xYUOo3MOidVKFHku9edMq0ynsi9NQLzuT5HpPdwdt/suf2e7xRl2fx7sKf/WoiXa/u787Vi9tKZUY87mLfLlDOqqxFFiyPhuRrdsCfye/J+nv0JgQShO55zu+23r/Z5P/3ZUaWwn5lRg4Wg5Hs8s3p7+qydPffFUaY/yLXvr9TINL3T57xzlQ0/9/M2WuJZfa73rZwufbCnbNvOG3tODnkbXNfra3aeG5z7mPUeU7lIZ1r05hwKrmq6Swwx3abpioABmvG7NFt569vekfctV9OSOBAQHBEpmBlnZq2115j8ODXZpr9g6L7pja8vA39aYFWwqwDOPQgC3CeujmCu+QXV8AMZtdKAv5285rVvmDx+y83q/Qw7HcbWeM9KK6082efl+6S8a+vijejGJm2laYm1o+dF2NJcjL2Wj97XSKAubFBS60lG52y+2SbzMGnBJ9tsvU0VahuaDXoC63Ydlw/0XL2CxSTio7wo2v33/2Bh/f/93+8sYSQwaM8Pj1KlpBkNCubd735viCJr1xzRZdMB5dZ42gQHkUS92fVhDh6cGjwkJjWoaOKGJDsYyiN0tTBMfJQPjMYMor/zwwLeMZTkKlYPeijquFvnJRMhYivVk1YiZFjNgrkIu3v3asauv7dy7Ei0i3uH9zo6FrXxa4PbRs7B0gDAdUdXjdF8QTTqkHierh2Vi/JSF4ucwPPudmA2siHzcX/qOEftWG3ylFnMW3a4QBYgQAYaCw/T0/v8W/uw+xO12z/7ZqLHYPCOGiyCSPALJorAuWf3z4m5I2xfxrV7EZdii8ID2enP4z48l5zRCSecGIW7ZuXXm7QzOqekhCffaYzS6WHq/SZj0+wEZ02kdnPKpWqKD6UeowJKtI9qEDXi0AvVIXCgNk6LSPd7bAq5GU71qbxkEQPlYy0YV9C50U09gKAaGRQMNvJBHAQvz2ZtHY7apxz+9vqHqAynq5GHVtz9u/45mfp7DCPCmz0+OkPJ5XeRrH7845/URJg1Mgrw5qQteNr/jGxgJK6Z+mnRKIdwODoaeSSvnYjPHqHo+6yQUgejuxM53pccKYLRlO8/H7YeaYwRfbYDx6D6wYAvR071n6mrrv/VcUhKok4DZ9MYtQeV535T+pfKwT49zN5zzv51FMr1k0984mNBqTYvJr02hOQHq1snq1MSuYo2/5g2jlCsvcLad+71xGZ0yhGL4rTO0AM6AizY48GqiX8OKudGvljtcUN37fTVfuU7KXhGpKH5sQcjt91OZxva2chz1oDU805zje5NLrcgSk5oZIdsMRZeayZve9qvTq30EViy+nhHqXuBOAUKlHxHjO7XfSqnEIE615wK1+dIQO4O/OyBxQ94Y+Yluw/RPZRusO1vrfRMG0DPap0YUNf29yLXzJTFNBw9C/m2c28NGt1yD72ulUfVo3ha7tOpl45s2+i2gfWdTTqqfgBTzgQdBP3pfsHdLEalhRywagwGSFOVd7zzXaW3pZU4yhwEUOr6McprxnF71PLLTA7KiEbNHpyjzUMuXD3nRvSrRS09Z3rSv6JzylmX743McjjJ1eikxoFNb+bAxx9NJ6XjA52TSVCuxkOvSmUKBvDaa69T50DHpQsvvGiat/9nIaOcnnvvvm/y69+eVy1yvTYNQrt0bJY52WB8vCCRMsgfSjMnc0IzRu2uyVZRgItGwSz+sNDfk6BdPF4647XWmmtXCCzS4tV3g20Lq7PQWfG+hdC77GJm3DIF5Sie5RHzHoYXuejkk4k2T03jhoc9PBT2/Aw0pyuOsThyaSsn6oSZX3X1lZNvfvNbdVBAB4sFqr3fwOr8e2mlEkg7mLpT6jxP9Opg3DuFtnxPFKXxUvIR/4gXLuIQBVJWQ3EM/aO+dBikkd+kaBlOEWsZsWkfXsLWE2FGdDqdXwoanMl/gnlLIVef2wFTMTBjPFRa+k2NpoVv0pLf91xCAmI6Cs/KdSia0blozCJtJeAzXcrhALj+o2NEeH/yiw6XrlRe7reL2BnIEf2NgQT/yvNrkO5ZRZ5eGspXbVy+D2HG30F+2kTyvsvAeP66NkOfRt41oSbjpKKIfpTiagfgqU99asGAt8VJQkE/7bQzA9efVW0GRUGcpmoxmb2S+1azTD7Wf+x6kzvTrmvtNA0wv3LZ5FkZVeUa1h38g3CkxIIy4p2q222SVrNtkRusq0b7+tJ2xLZwoj+N+snBounDTNE7rO6/CRXWaUwfWZBzKTszk3KcNabWbaQNFgoMjXUbByQsQ9R+ClTzCSSKd797v3i/L61OKupyTz75hMrV7LbrLkWCqFF+McI1faf64d6c4fRXTaH/ELyiPO+alnPdHUVP3gh1M89H9DGcxYo+q39oERfrVXWlFcWKQqedGjiU5VQadA+9GXLGcVnkoQ+Jw/W3iqr22edlRfyTJ9p0083qGvWpXO+XYe3+MrXEF1xw4eR9792/IhzG41WJXsmYWcGcBOQaawxhMIqMcgcJMkT+PuQr8pT1A5mRQbLc523WuWmD0op/RMjDMHZNacPg7QQ1QtLnqP/tg+A6vAWRk2sp8aLvGFL3IGp617v3n2yb9qWHffGQUsj0HeMhP31J/s44uKZz6x4oaZGXblfm7a6//nrRTzsVWnLKKadFuR9fyM4+++xV++Nci66k1Tg75wetsV4iw3aqR8vI++r97Uw0HOs9/j7rTLQh7d/1dSoSFQFH50mpyQfqYOfefYf7b2e9WhqaRRvD6X46zcSBQhQCsa4TtMI6+b1z132O14+j/JCcz29+84jqpezs7p0yF2QgVQoEFILw8NiVfV7+8nrWJR6xeCE1alzJ2Hrrr1MTWTQUQfAZSOI/k8dffoyry/3SgfS3kWucoBVXXLnSKItHz1nHN+375jonb37Lm4K07BGb9ohyVNWIXplnOOvss1KnftLk9W94beqeX1Vzt+kYLS7ZsIemZ/WTn7rn5BX/9YpUE1w52fdN+1aZmJdn2j4BnO+ZE4KB3GuF16KjjTZev4yqbkaIJ3skNzWo0OjXY3xZdzRC+LnyyitK8ayRnKX8FQ/lmngQJnYI39XVecCTTzk7ORO9ExetMTtPf/qTJy9+0YsqL3J+yhwMYkUxNxroorRgUlaB3r3VlltU5ErIecvtiVGmaMt6/ir03TVKqfpS5sGNEro3CokRpCC0W3PY2lDOP0hTRTML9/qRDesXxUHBdsOExuMpkvmRTg4ewyrS4UjoVuOlHMPLvYNCje4ZhKPRmQns4708HPlOL/WahMeac0J6gDdnp1uidUG3e5FbwMAEQ7hv9PFBBro/QjnaBIrSiryStWgjwdPsZtSMsGiMQgMpKsyXM+BBy3vbZwjCncmlag03WhMmQk8UQUk7BD/Pfv0wbbP23nuvGiP2s6N+XgXkNycalft5TPrkLpQI6a7A3H+L40RZYfWRJ2Ogtk1ejgFZWelVDu/VIbQggai/xJgsaD5K5rgM7a0OXHEg/hXHR8mEQ9kErSY0rbrK3KGEHpLOSjn4ozxJr8zA7xm8fd/dppZMySdxGKobVhF3FsDlQ0GPSO/fI9PB/vYahtV78tmKpB5U7PLr4zgsGaeBI/eBdPHiQOySCTHyoqvkeb4VogqW7FZhNz9qSha54fobS87s2YVxRseUlEXSvzrTXhKJUoAiwuolOhVQ91zMdNFnXu4Z12h0x4rBK/Sio9LqSD2/JIZj1MbFexhV94uEBHYEZZKJDTfYaLLHnk+q0gHzijlhnC3KSD73zfvuO9kgMO0l8ex9v71hbMipXDvCUbFtsY6n0Bn59h033pjIr0oVxnxPezm/9A65cBqdel5n7KF6VGcfRTS+rOFU9z+aa4QwBuouhv5o/dmvOtfTNdFMwT0xJksmYHB2EdU0WO8cmTX84Ic+Uq1RD/r8Z2vtrspzI+gh0ag/vDc5/eEEa9YwGuJvmLZxYOGLc3Y4qNITnKG3v/0dNRrSPX7hCwenPd5r03jmWUNX5MxKMXCkzg+5q5iq0/Fqft/N4Nt4+lkbvTZ8/uxUj2frvzvzfX7KkEYmyuhOUQxQKJa2Nekucd7DWTDCTDMP58u/20DboyZAkQGGrdj5Fbkq/+Eg/Csk0uOr3/IqcXBfkjKXG5Jn3mLnnYNsLVYs543jNL98n32KGbty0gKrJoXzi18cVY7uGkmB0IVjOLlBHQYFIGimXDP3hSC5cM7wEnQALky2d96/RrDzxz9eUM9jOhJiooj/1/m+89PF7w9p+IDDU52Oct5Upei09rrXvT451B1Lbj/72c8W6WmDDTeoKJieJXOf/MQnik3NEXzNa16T929fsj4nUyliSOMdJKrwgdSVVrcSk1iUIKz86JSxFDlDl40xtLk7Z/SAbJ4Mj05E9qt8CQWKxLDjTjuUkHzrW/+XcHrTYvEe9YsTJk97yq6Bgd+d8TlLplj78slPfvyzMNy2KM+O0Xp0ZtWdfc658dxPqqLuYQD/VZ4dOjjj47tt3hlpwo388OKXvLCISIuFuLNBmIS8pjHMexSkF3RWEcnoYCTq5DV7dQ61PPRp1Ol9JTTTOstWsqAdi88w8nwo5tH4fkAoPtO1qW1oRW7FRJxOrBi6V8OGwei9Pvf/sGweuAuVX54RHErz8FB5fnJolfP0PTkYlKr8MkhulZB07swmO8xjNJehwmNi/YMXNuIuUXLy1qBuSoD3udrc1UpgKERQDcFgcN3P5YkU7DG4vZmGSE3ax8ld+L4mX3leaMWZZ54eZ+mUirKs4Y9TrH/kkT8ueFYZyq1RpogDCGaUJnkxrmjbbbfJ3m9Zz0bZOBCeFfFJdOlgM7bgfmusjd3JJ59aZVf/KDb1P8rgFxMy/8mTKPcZM2C1pUuBf+6xxoNxdqYF6NZ0lEMNZay9n8ikc92jDnPs04AzRohXAeqUzNMdhapWM2dEBP3gRQwKvq8a8Msf8qQp1Le85Z2ZE7ppGaPt88zu68QoGXn9ZQI9ybeIBnnflC+ZFglgLd+jTnpa+qGuuyLLynvqNrRg4MKIL4ch7ZucB86dpgJqWgrj6bkrDTKITuP/xmcYUf+0JhQ5B+3yS6+YvGe/dyWC2juR9y3lyV+YZhurRPFxwOwTh0ftMWifrF2kDjmKTNkPkpt7pSxFLRQyZ6walBRRKwo80F3N2DS6MTm1f0zbbDo30Cgy7BoN75KXqpWufrEjJVB15fnOIlhNmbjtFDfT11rQZxwPa83wLT5l6CrPYnSQ3KQw/G5E6clLFo8gE1vyDM6EnrPOKbnS2rD1he8xm/e3ce4vveTSKODVk3bacfLtEIs+8L8fifJ9Zco9tsxQh2OzDktNXv/619ZnCZZnYrAuTIRPBkSD1pAuEyS0MfTc1rAIc/lM660qpZoiC82Utq3NjfD3zuWOSSYh53BQKyUQ4wqJ0YhjWvKibpQsMO6+yz3p4sPwrjitp+QwVP7WvjG0+Q7Pjem9dIzXDtvvUA0ODPbeb//3RjfdH9JP0MOs4c15JkNQvMCjT8xgB0Sss9IuUFtMPaB9v33g4DCe1ofhsgbSQwIxiNgYJhC2dsb80XE/T3rlZSFxbbHF1tFNZyT9cEp10jNQw+t9733v5L9e+Yqaq3xkZrdquABm3jpdlzRK+dnPfjo5OXyd1bJ/z4mzg1gnffapT3+6nm+nnXeaPPc5z5ksH0dTiVPIRhvNc3OM2EqhdSMLKG1ZKTNFn/mMZxYTEyPLYq666qNLARaMln9T9A4BD5lHpe5MMb2RaOutt25YWRvO9+QpQJPLFX0bzvr0jHdaJmQXm4fpCPaBu1PQDLZr/zQPI5px3cUD8RrjZsP/HNanyRoE5JOfOrBC/de94TWj7iyDotUq3RvlU9HJPDmXaUQ6NaRd1tJGdeiQoVDbY+vfDUM6iBojx2AyBeYWFt3ol1tGekouaqKRf3c/3y6XKaHPd1UN6BQOxqylXHiEIEJNDRg8MJn3MV4MnRw2z4zQgkQIP/jSz6yX+rvqvZprMCQLIqjBuvY97hPk6DmwBB1QSsH3gODkln2OF9idnJSRiJZvjXL5S3JlD87zPjqwFCiOcndNeS0e81nnnFk1p5fE6zz88C+VkhuF1Jn0EejTXhqttWUge3lZeTWTFRg18Lf3im5FQZ0DawfEs3lx2k6JwfbzZeORUjAGzcv3+LxuPcgBRVbJ+5UYiHDBusbYVe45kbC6RCiLAQd+VzmpRKWzkecsMjFNSk4j0GFYSwFOZWfUa45oT66PIjn//D/GqXtsycZHPvzxKJOz0kJQF6BFJjuHmLfl4zctpYmXQL4eGc9aBEqJyPnYA47jfcq1sg8Uv+iAU4vE9c+01es60q4ZHWS4UUPaStS90XAVj7bRnN53dT6KUennFrR1ZELGcR/+fMONVUf83v33T7S1UYhFl8cBvrLgbEpNSueOO1PzG0RL9OEztydyvTlnnlNEaXPSRJwg02qwn+fpcqMB2Y0I377Zo64L7jpOitNrwNODNDUirQFp98zN+Q7wVF66o88CR9eggpFvtKbuGUfBehbhKAzvSy+7vNaYfHIcL4s8+z6woM82amHP7kr5gxSCCG2MF5O/XTQN2Y8ux+zZUbZYnYccckg5+fqJOwMcui4rA2dCzpS/3B2DfdkVl5Wza3as6Nu9OvfN5nWfgohOA3nmJgJ1Xt/9DhbrgiHc3lPQvIBhmvsfKE2QKrXMev+WIzIcePrY99oD6JWzVnIJ4cmZdd46h80JrjMZ4wuV9D0aut8a9ElDHdHgBz/4oVoro/sMYtgp7UIRFfV1VlK07LJLTfZ6yV4pg7m66jg1iu+GF5wpqA4jeXWGoKyWRkCPiY1BTj3iiP8rR5SDfnt4HSaNbR+j+PigPSefdGp1ULrxz5clePtQ5fMhX1/+8pcrrSg1qQpAW8w9041rlK7dOfnKV76a636r+vHumwk1GkNg1H/sYx+rM/vstNN9ct5Pd+KIzHnCE7aex6LfE8VCAJ75zGfUoTg9/UJ33HH79BXcrthYMGiLRSGDzSj+cSbnhIV5TtXEKaz1Ag2qJ1XuAiIEzSGsIN3YxBujkHmkhFzDb91bvE9UhgWs0TOjYhNPy33YuOVidMF4a621Zv27iDPZ2M8fdEi1oXrVq18x+uFmBqTON6BdRrAji4Y/3N+sguwItAWsFWO/byTlR+6UEe9Zo6LOQQjoqS3DqBDM7sXrUDUU7NB171ifa8+QQhmF9YPS7gB5LvAYb/3ikDn83BpaD383YcW6m4EpKqWgQLLYwa4tv6n9mAid5+oZGWikry4JaTKVGq32aB14hlVNpp9JrHveR0bg5gXGRe65D8tUMXdgSdCuqL4QixhNcAnPk+d3ScopVlttbhlu6IR8OMYcRcIZI0uedW4i4wHXL1Y5os519szDcm6i1Dy3ffdv0EoV8afkAMPV4S2Bjne6RjzIYn5GPkabu9RHJ/qzvox5K47FF1siP4MUgI3Sti1GtI3MrLFpJf9v0C5IbArtzspL/51S1DpMgwaOwbrrrle5sc985sBSxs6XOr5X/tfLKyIX5SHMadPH4FjzP+awyidyHHQrooD8XURfjNy8pwyL3CdYq4yM6HNKvpmiFhyMQQxbkOgdpKRBaPPJPg9sUjF+K0p0/RGxSi9cG5hXucKTnrR7HJ0Vah3PDvKEXU9+KUN7i3zh/DE+8qX4CkvH0FpTkLAonXPj/HZTEc/RbGB7bO/lvloW3B+EpM9wO7sNS/cZrgVx11On2N8b1mwj7N9k3J/uy+xdClj5yu0pP/P98qDOp4iME3tbok7QZBtvn+fQ4HQs+cili9Dnep0C8KdSGXKNbPWNjI08NZ2inve85yZAWbGmmChzYUjB3lcmH+48cohxGJD5lAwxxHSI55vt5tQOf7ObG/5uJ6PPc7FJp5+1Jt7feq4NbOu5XjP7MFsOYx26OUWVzGTfnL1BTEv+dMp09jutLJHPsJTpoAdFRvEg9BJALHrrW99WRk7KDaqx9ZZbxZF9aDF/t01pyuKLp9Y4QcCvfnVaOdNbbW3K2JyqMa9xhOutU7XgV6YkDPln3bXXK5k64FOfCf/mF0EL/lGDUz79qU9VpH1wGiYwiJtsvEmi4G0KOfnu975fjfTf9ta3FG3S078AACAASURBVAdIfv9b3/6/2KCbgg68oapVBAVfSzcjhn2r2DTIjHNrCowAgdF+8pOfUiSyJtDN2e1Ju2S6mELmkWwG6T40+YJbb7258h6rRxkabnp92IM808VSLqHnp8XgBYqmfvijn5TXoacqYbD4lClDiqyk9gcV3YYMz1Anl79Xv9Tzzju3jEJ5Qvmb6FNDYxujbRMv6ZIU7c+N8Ra18JJWyH9yJeelg/93v/eD3N+WEdLnF0vw4Q8bDYjvxv6M8uhi3dlD2Eqxhaoji1ags/9uSLiJSa3AKJIesUYYQUuUcjdqEGmLSEcOZwzgdi2wdJezVNlBDYoNtD4d+eN3XQsnh+ozxk/x4iEHoC8K1mFeOyVA7ovikfjmvYliQMTgqCp9iYMz5kaOfFO/3LtORu6BAR1jlR48Oe/X55VXhhBWdaAS9ybAZ3NqWG6eq9ZPXZEfJpCoPF0U7l2JPD/ysY9MvvyVb6bM46mV/5LPIMB7PHn3OniXBRZxffcrvwr+ITuuYa+ta+WLpk0cyKTWikoGwMXyMcpsNk80t1oiY2QesgLmEe0oizI3V+N3Bt/flfh4XjAcZ877DcO+PkXV8h5gG8/VKMSsIW0l/Z9+Nqs4WxF5Dg6p/To7ZBN9qDdJbZ0IzagozoW9OO64E9M1RZnZ42NQ9677+9NVlyY1ctbkmuwHqHleSllEpKB/Bk6ZzJ1xeikJFs73gzWbVjTuwXPM3+ZqBNKGs/+cbzinRrSM8TQP/JCkAhhXTi5HaURfZo+mfjlnVsSkH+nzn/e8sJBvzPQMAyqkQKIPcs/d9vKclDgZq/j85z+vDJacN3IRRqXIopU1A0FO+0zMOrS+217N1kQ+0Gh60v9UH+rnnqGnAfmO2fdaK9+t/GaZtLcUHCDWQbUoSs09wO7WnyPhVaz6yD6mrvOxUqUekjZJ6qKNW+sZz1FKNs7o17/x9XIo98yAdQbGs94YWcX27b+DuelX81w5H86kfYYuOevdpKJL35pcxPA2EakNa+Wj86Jv/ayj2Y7CuyzONZq05bru3XvpBM5on4d2aLynmcVKy5xn91ZdnOL4qy8FlWr7R2c9JOcYOmgwNlj/pS99WaXnQNpXJ4BCyKLLzgj0+vkMedh4k8el3egXy0Fj7BZOmkQKRF7+4SHlWVPpRxm5zTbNnNw4zddck4Yy+fknDzig9uCjH/lYlVd96lOfTqrp1HJiD/zMZ0JWfMzke9/7Xr1PuvA973lX6VL641e/OqPWC8/GtKNvf/uIkCRPC4/n6eUIMeSCuK9+9et11t7+9rdFhy1faKHf69o05xWvePk8Rewu6oDz0BS6w6fBs5RymL11k/DxeyJ8j8h7efc2wX+S8TbssekxOjoAZd5dFGh3H+lxYBVtJnrSLvCcjFxSx8jTRejw319vvrWiSuUx8i/yXkNwDYNNviCeowOtnZhk/zHHHBtS0i8rcn7+85+fQbG/DxtylNJURBpF3RBXG8dWIrOG9T/9rhVn5aGqccOCDkYDThqRrdxOdQ/Stm1aTuOzDes27Dv7b5+l0Am0dWPEunNSR62EphsvgJ98P0XWTgCvydqDxMfg8AX9WX2nfIJchvKibiJBuctju78ux3G4RHiuu8m0vMS8Pu9ZZ+11R64oB4uXw0gbjyb6oaAHcWkQbSqXld/dFOP5pjfvGyjnjMwa3aeGtdtTF3CwedurpewDPZ6ctALvwdaiV0rW2qgFkyr4SxTX8cefUE6bn0MvGPWnP/Xp1USAsapuTaG3b7fd9kUcuj3wEkOqBaRnq/Zh6nQjf+77UTncmMUMt76fs5HLrPH8/2VIF5irEQV5FdQ9daCQuKQ5lsoZWj9tLX8YJuBpmZSz9DKPnFye+lAkOsb/+S94doryX1Kj1v4Ug3PkkT+q9oz62yJBaMGnfMAzV39Re10oBgJVYbYLcrnFAE60qYY0BrJy+9PkrnQBeNerfzY+26Sp3HvkeaA4YHByAvYeM2q1CfxzCFGgu4+ktGDPPXaviEN0hY1JPuiIP6QM5ur0xTZDllL1jKK8YmZOhzB0lNkzODtCch7cM2MFLsUotWf2vo2q37dD19GXZ5qNtvydLPX0KTLY+cOq/8wayfmNn43IlWyBqo18VBM/pjaBoQdp0L5ekVpgjgAWOcdP6cwt0YWNljSc6v3gV3qQgfnOd75XTS5E6wwPlEXwUOsQo4U9Koq1Xt2IniEdjVPure8fKaZBfHO/PejcGlqTNn5+38Mu+nN+b/3cD90xdNQYoO6aBddO002ewfW7VpWxFJk3ukVn3/yXv07mrjZ3flneaI6wUEWe9JbPLJzz52ytN0W4XviilxQKtFTmI5d9yPeQC+dZhPf3v99anZ7orOVSEXL735OTzbPtuuuuJfe4NwK5DdPSFvKkfE4Fh2tB8egV0eU3vnHEdLpQ9METtpvst99+cZZXqhr273znu0X4etrTnlIoDUMKdtb5CDJwVhxA5UiaN+wRlu/NQUt/FOiX/P3+93+s+aka7Wtm71k5PeDeOW99+1vmCa3lwGzAffenrCVRggOGCrzrrjtVRMErfUQ8qLuzsSANnpgFI6DG3GiasEW8a8oerFUbvcQoL7BRIhCbp2hdKzGsYKH7ueecV4oaK0tjh+pDe9tdBY8+4pEPS4j/qLAcVylG163xggbJICSGXO+XvzwmGPc5RVTi7Vx8yQXxQBerrioIGhTHAyPSWUNaCiX3NBuBzv57wLmDpNSGtD9D2ZRAT8tmuqyl4ab+3m5o0IbXOnrxfgk0+IjBazJBH5aOcHiboBQODQakCNN7elqIw0FoHQT7JrId5K80u8iB9V6UfgdGRA/yRAzQfB5L2j0gHBFmisvAAoOZQUuExN78I8q6oNI8L8b1/YGmHhEvXi5NJEJxy+X4Ls7THyKwXzj4sMkLXvCcKdz9zzp0nkGLNddxP9rZjckbGXk1JWLxVAsiTjTHK2dtvU/ewrXtDwWmtOklqTXdeecdS1ExPKAyqQfCW88Txe01urqk2D0KH8RdQ6nvH3tbBqOMx5CDVsz/r+i0LvgAufHvlhWRI3lhyMCwWgZSBhTvzRn68IIXvKAm4YyXtmOBO2+/OV2Dtpy8/OV7F9HP2TkpTb6/nykV9lEuxliq008/o5QzZ5JRtYbsdxNryoAG+eh+0PXzNpyi2Knj0iMOK686zU3WxBgGdZovdWF5tOrfyzmofOSY6WgAgft4Stra7bHn7slzxdFL2dkdd9xW9bNVrhMZRDSirNtYVjH9lBxjL7tMhYIezzJ4CmSSc4iBbr902qLkfb7P16zj80AEyX12hOi+K6KeymeXfngP5jhnS5lWn5njjz9x8vuwOt+dmkf9w62nqTWuIaqWLtksHZ4eGWf+8hjd+6fd0Zy/vv/O73smhtOz/jLkF7k9Oq/yxgD36CcQvwlK+s/ulNnM9tuz1pQbBLPosc6NdlvFdgi685HvHY7saJ9YqbBClMYat5EncW0sZ9m/fR670YN/u05F4Fk/jpD1ck2RtTXBTyAz7m0gI6MjknI68iUa5YhcEgRqtZx9+lIHJyPmVl5p1WLrcjQ1QDD309lcKrl11/lzSt7WS1ej+/9xb/UkQD5VHsmYqwRZOIjpihmrJlqFgNobueyvfvUraYDytcm6qUuFhn7lK1/LQIZd0hP6wHAnHlFoiZIkqMA222xV83M//OGPFvP2BS983uTHQVaP+Na3k958ZjFyrTc9O1IqcczTI6CHeJx00knznRDXnJP6mXlyYscfd0KFxIs/zHSV5YuGDPYAc6wehiR4Y7nADlq58Rbk9gzjvv66G4rSv1lqzJZNqC434kt50ddenz6e2QhGFMaMfITirTwAYUY5+ClhYJ4fxcuzteEUqjKLe7DwElkYVrxoJg7s/qQnppZr6/J+JfyRjZRbnJhk8gte8LyCdi+48A+J7h5REWkb0vauCVt7sq34Zr3ZVo7+bAislWblHqbNwYfCHJ4hgeoWcw/sktQR7bgW4c5Yt6nSEmVjMjaJiFcLFWBo2kv0PV3jWGPL9M7VmL1qztLEO58hfH3fvqeT/A4AoaaEXKdJGUgVFImodHwuMwDDmia8Jqt4X8NChE7eFaSi40dNmI9huv66qyPoaRgfo/3osHd5lfWMVRwwYF7wn71fccVHV3RYzMgY7Trk2bsFim/U/jH4v08+7TeB6jWSVnN6UyA2rfQ4AdfH2BjbxylBLNJ9R0/fuYlWyIzDRti32GLLKrDW6F/ubrHq6MSZwsZWOoHV+eBiRCOjgRxbJhjTB75aPv7/jUp7LxRzUzKULKV8xRVxNHMGFIt/8EMfqhInSqD3V35G/9n1w2CkaPUeXTNOwQmpN/xpujjd+Oebat/Q/JV7SYuUUaw87Zg/WgaRbE7RkmYS2xQGk4FsY1+R2xTW9XP/gzCUAdIFLFetTkl5XzPRyzhPHUsKXC3e7bfdEMWy6eQ5z3lG0itbRa4y6DtG1D6NnG2IPVNUify2Qe2yjEaFyB8DQr6dC/JQrNTIHNYwtAI5rhU7mXOWGo7s89x5yo5MW85GmkDt+ajDnE2/DEbszfWcajnPOefsck4MXUCaE4WurS49cs2Z4aw5K8pgwJIa6ncLvdYd7qsH1oM8Fe9bEGUdficPR68xWKBuzdyNpHv7O95eOqBnjQ4vaUHzCAatI9HuBey+u7dvl8N0kwT/ZkjbsHczjNmRcA2LNwrUXA0/9zPnyjo2UmAPC51IhEgv0WGNTLbO8ntnbeXYEHqxugPluT/84Q9XLa30G76EtIrcszrTKtNbYqT+bghkilz5oJBE6di/aGQSuUBig5Bgwj/ucdHxsSGixxUywei8885Ozehbq73lfv+9X+kxLGGO+4dCctJlDNoglWjizhlxXn7/+z8UEXLffd8YuHfncnTxhTgMngnMb/9B0F5gZDJoMzGEezJR6YkvHnbIPDf07ZSo1Fih3Dxiy2pRkkgNQtuVVjb8WfulB4W1t0HBZsgTWmdJ7qqnIqxaMAmTbwqrVkSmi4tRQUce+bMI5qax8q8qGrMo8vOfP7S6XswL83BENKNpeHme2QTjhkRQlMT1N/wlB+lhk/9+99snaksJykK5+e9//weBiH8TD+LpkxelJlXxtBmXHIN7cp15FZGO3GQf2vZo/1PE0QeyvfRZYzjbXrCb2NvkHhg9W6M6avhGxOrFGy6vMgqGwHRkRShtht91Z54BlyYfE4/O9xezNMZIP1wN5x0MQujnY8be6M3p4HrxtnqYuEMpcutyHd63iBZRjGPkvgh5Hc7kHZdKlEkRguewan3/ooF25SfBGAhiZtFeffXlNVh6ww03nizxSLmLKVw4jeqw2DRsXzGePPgPI1zZhpeuOFUPlvdCMy5MF5GTAn8qXL81eZSHpPxn6Qg9WPHiiy+vCEd+Qm5mt912KSdJ5ASyMw+VgeLZUj68f83Y6R+TN26raUSh5scBULvnXhmiq67UdDtOYbxqTlut8wxjtyOLNqwPdLj+U+TasuO9NS0oHALzO5G+FHwvs+zygaTWr6Hf+75l30TSOw/HIg4jBjEk4fYwRkH1W8dbftJuu07WTd732jB4UfnV3F16yeWj1jdOSTfVNo93GNIx6BuRpeBce1FOHBbugjZv/WxtaBfUn1Jaow7WeeyIznNxRMoo1c9HjrwYt1FqYxrUXeXc7JUStO132LF6ZjOkDC5lq1MMw4iI1A0VyFw7bn7WqSD33tBiT4qZZZs2gabPdOXnqbZpFNqRbRu1Pu+DmTog63KqOcf5rPN4R9Z9tbmrhwswnL07w/y84c/XDUc5n1tm6eXSKOaqQkh2e9KTSpkiV42GBaMxwOiytmAINj1WRLEsm89uGUdDBCvi3XzzTcvRLYJlHAjEm0NDjDHa7nnJPXdO1HoXSzgPY33JOZRj6XAK2qmwD+6jDWB/r9+3o8EweGZnxO87kq3AZboPHTy0MWzd1TnT7r/r39aBg1s1zVND3cZ8sOwHUU2ZnAETfoadr6Tk8wd9PhUYcdDz/PSK6G/NGE0s8G2esNVoOZgoUN36aEoR1n3kSMchz6nHwUqJUDGcf5Q5oJzVnXbaPuVl7wih6/TkL9862WfvvUvefN9FF12WZgtvyF7fWwRa60kf/fLoX1S5zh7RTyuttEpdj968+a+3lWNlvbuTE8dDMIGrQL9WmVbu333RwzpRzTnoC5+b94X0yNRWria8z/tHFbBWw/McIBvioZYKO02i2OvgdL1fa821qo5mbg7HIAoMQgvFwfJXfkPRfDzdQw/9SjrWrJF82VYxoudOvpykrdKAx67/mOqOM39kURFkdG0BJUXwqzA8DLYbwh598Jx0THn5ZON0h2E8/pn3qU+tptFP2HayaVqu/TEdJzQDkGe4M0X2PRmjD097qrORRv+ulWO/pw9nG+D+OcEroxhl2RFpH+qGgPu9XUdajN1p/rQZvQyl14BbR36hI8xuNdiEJveojR54lYfv+xxgnWO6dZcDz4GwuQrECTkmos+KhodCHNNolMOINhkZBsoeE5qGeyATYDW9bcFft0eIQNEihip4j1GEJjw8jQ1AmM1tacdD7vHwLx9e6QIR1pZbbl15bV6c994QUsXFF18UtvfZ6eV69nT/h9kC1WD8KsFitB8TGdksZB0dj+SqqmF0jD9lu16IBByI45I/NVFFtEA5SEkow+FsGV0nmuHcKC0Z+5lmDHEo7stMzwXrMmpKTatpmfh/GdIHwr+9//3+OgtxYBbPQaVETglMq/Rnndwvuf7IRz9cnq7SMh1i5A05NjfdfGN1dgHb7v6k3crw6Gdq1BRyhyYOkCOF6FIdyFzK0trIkS37zuZ1dOZeGMfO8/U99p/NPh6Gc7TL7GYT4xoD1oU4VEerkiFjqZYo1AnKccs16TSVc7nvm14fx3qbKNorytB2DpAxlfNEHoSSiL47DdDRjjNl7xq27FpGCsu9OfO1P9M6yXY42wB03rBJSw39+nnXXc+HsafQpe/zPQgsjJjoVMTD0YK24RlYD0HEeb85r5Zst912q7pgEK8zIs/NwLWBosCd3zHvd/S3RrICk7v3S6MbTdeSmOXgYfy6P7Woo5xu4aTKLk9El97iiZw4TKImzFf3Lyod/V6NDRvpFutCh3ZDhNZd/myD6rx4f3cnaifG57t0xlr09foa7aj4OYIVxIB+B7fWFKuSr+H8u7Z7NPxE2kewJerUqWzdGNKDvnBQDNgvi8fiJeJ73EaPK11q/N7hhx1az3J5OBqj9zSWvpaL4U3kejUWLVHul770pZS9nBpEbMXJi174ojKo5yd/6Tzsk+YOr371qys/To8xnno/Q1pcmxPqOSEB9IvX37O+ED5pOvXq9kw6k8z5fmUyDClYWZCJOKWUSQtc1zQbNp2NHjvPAzUdHca9dFqDYZTdmcLqOQ/6V1ltHsglF19aDKY1U4Ly4he+JFDussVqG2UhYzF5GSIaP7MJPC5GREJe/dQhMcJnnf2bUm43JmRH++RVKK8YTu9oLG8QMU9MPu/WhNzLLLdUos7np2Y0JBrjsRJFf/e736scByhs5WzemanTM1sV/frue+SQxsT32chyNrron7ci7N/1Z9qIdkJ+VoGKQC18C54IpBsztCLqCTTWZVxrQUOIIajGXiHwDChEkh2EZJO8GC/lEBXlTIeC35y9cljlqETmDo/DxzBqr2gvrbnozL2BaHm+BJxCwxIWlVYklDX0ue45S1j8jMfpuhsFPrkl7G2sa4ZKrReiC1b1wjH+dShzn620e92s13HTNluat/9XyjwIoFQBVrC+vH+6+k8lH0aDPTr5DJH9r887vxwGqYOlYyye9aynF/0cnM8LpJAoo0JMVlujRn1hzIGFebXuGXyqIxfpMT3Iz8gL5Wa9HX4KvrtQ9bxc6/3Q6dBlCvY/OVstL61k2vnq/fV76/yglKsUEzVoq4OrLMcQ4+WWX6mGnZ966smTD6VjDifh5ihQDqx7RKwSIXYekWNlr1/8khdPnrTrboVSID4gLXkPZ1cTB85VQeqJgO6JAe88J0eSdSzjU7UtY6/kWOtV5WtNNFpA/Jr/7NM3gKk9q2eyhg+LAyBy4AzsmNmzSnjWTlnDqnNXK0X/9yAndUY1SZ+JeLputHOj7ouC7zybe+n8XEemnb/rSJNhaCi1HZ5xX+NhOjKdn0udGhr5upK3yIEzQA68hxO7TCoFbs8wDrwABBbvuyrPx2AxHhzYM5MHU+4AfaMDRTNK/i6++LKqS+T0q+mmNzmQy6R0otngntGZcp/XZQYsVO/m6dzVuUFOOIO4EjoiicKVkF0aAucy2V+BBsY3Ih14nGwyms096Y5lfiYC7jVpaJY8+nmvdXETshYD7RqkIn9vZm7rwmb69ncVeShr5zn+mv7YO6Y1npf7GfOlB7omgiSPEKwbwrVQMrVZoGwdyT4SRq3WnsrN8ChsGRIRWVEGlFLM6vrlfHIm6Utn4Lb0nDZSc+1116kWkt8M2vXHCy4KmfEFpZP23++91SbWa//UOr/uta+rFNgtcULoHFN29thjz0oH/SN5Vw6Tl/0gwxA6wYb8f/Uhry5/D690I47AEnEafS9EEEtXVAupGx3egpiqI02N3bxlkm+U2BZdLBuDhVmpJEFYzvN8RponIHScdOLJk2c/+9mTZ6TWdPEo4J620AfAn+bpWQAbc3vYb1USkoNrkYXkV1x5WfVgNBnmswd+ITmW1BVNqdfKcFDuBw1xnHMMYvfBg3je854ZobgjHs2S1f7u3ODdWhtunAgUDKYX4iPixe0SlpchcYRm1ig+EM6djUYb8uoD6Ptno9EWsFmj2++1mJUPKlhtKBsv69AN8W3Y6FM8ymbaOHp2hpSgt3dNuG2oA8DhGOsLKr+7DONo3WW265htCpa95da/lsJ2T4Sf0PuToEMHejZp3xMngPFvGLrJON0b1WEztQG0r3Uarx01H9msGLgRovGMg0XY++V0eLYLUlB9yKGHVQnEvvu+qSARNV16syIOeOm+9JA86x9DPLsyTM9HZ37grrs8sdIF+jiXPOVAeoYiW8UhIAf1bEa5ZX1OS4H1pZdeXnl83jvFZH0YfJ4kJiRnbK00H6/IJrW2FdEbpxZnqD1uvXgrZ5lSBodq0elkh1ljWc84Vdj991l5aJnhBObKafyQfsdmjia9cGqa9l8V58EMT693v/s9Wdvkd0IgAzPa8x6JhRk9xsfdWfeKYchBpNyeFCYhMp/i9mOOPjYe/YbVhAKL3vCJf6QpfRs+9+q6bUQdK5HlgtaVgdsdsvn51gWGqJ+vjOrUoHp0NcBGIBqy/uxMLtmihhRknm7Wnvy54LJxxOt7p5EkWWIEqpRpylT3XHRER1FkteVp1mGdjULbuHIoICUte7PntCLQ6VlyneqIVBD3AiJZ12b6faUI4rB6cTQpdXk1qIbPgHztk2YaHAZIENIR5AcB7i+Z1gNlGM79TL/ZOFAcHetQzQyS9kJQQSp86tOeViQWTpDWmYzycUEaVEpo4OD5RG66idENrus61ss6MvBkw9o5G+TdM7dx7BwrneuzXl0D6uz4XOua2bIga9dGtmXPc/lM50N9DhkR+tOjzHpf1ah/84hvl+zuFh28Rozmhpkohh9z4oknTt4ZApd7Wj4548uCOq21ztrV3e7a5EQN0X7cRhtUS9lHZP2l9jTHuCnsYA6Oc7J2bMWS0e+cHRG9M37ggQfVve0Z0tvtt6cZQxDJ5zz3uaNzUmRSd7DTfvWrcmC3DsnvrhhmqSLEVfsr/0mPaLNKTwhOPG+VzpWhlb4zuCPdraKT7Xs5DbGROsN5kfs5GWsWfgKv1UYtnE3XWi7TVbI5FJdSF9R7cOBLXvKSaqNUHXbuujez3uKB5+DOQqZjEPhttbnyN6CqsXHzJocF7nvlf72yZsS9NiNu5MFgzAzt2NhufDAMqfsAf9x00y1FdHrZ3i9NNPSQyhddFzKLz20ZUgCYQYRmBNVdgXTRk43l6lwRIZw1hLORZ8M9fdBaAbRSbCPZh/yBMF57wN4HHpg1lG1UezP8XgRaUFk2kRElvF1L2rBaRRfIWHkPpec7RKr+5LHyAMFkWGSMnINnk208oWq2LuOF/YeMQzmAcRkmLzBJwWAxJoQWNZzXifbtOp3LLR1ahBW1rmlhVq0GjYtbvOCqjnqqoX2RjsZIqr/ksJ1+xumTG5IvXy19lDGADw8kQ2FsFrKGw667yYUXXlJNNgyW3iqt03j9no/CRcqxr57DvFmy2Tkd9wrGpMApqG7I71nVlBaJIo6MQ0LZgOHcFweAx9lO1KyzZV3KM43xa+eg5aIjpVlEo2WkFjQv7/XqbkH3J4/sX4vkekh430ynlOr4FQYvD/2Tn/xUCtG3qWdtwtBAd4ZjMuq0/1r7m3rvTFe5oByAd0Uhef9PQkTSoUUefPV0eqEMkKiqc5DSijh0SESlZPM/RrSRI/c6YPkpf2BKWKrnnpbDtNPQwwrAZZSTz33py1+qGnM9tX3E+qspNrBAnrogwyh8kWBFURi7+dPf23lp5U82mz/gHFU+s2Dl4WAMRxOsf3edA+vhbJHHvgYd03vUZ7i/BzFy6JMHVSMFir+IfZVOGc6KNIbfm93rxRgUwpGctHSVWkNDNHrARNe/ilpEJiIV54bM1v1joee61ov83hRj/JGPfLyc1w9/5H/nNySBrriXszLYQVQmrVZNUGJ8GHzfjQDTxf/O95CXsa8Uezv0/s1gMnA9As4edi6085wdNLhO56x91qsjf59hUOgB6+D5+uyp5bYHnrfz2GuvvU7BqP/93vdVx6H993t3gpqlavqKcXkQshe/+KXVYAbPQY6eHrCHR8e59hzvetfbKzqEgEECGCwpoWOOPqHKBXfYyTjOlaJL1qruYQcffEiIWl+ZvD49i/fbf7/qo3v7bXdO1kktuTKlmlwz4VNepwAAIABJREFUdWTIz0OU7s0ZlQXysKDb45OzVkWCpYu/wyi6F/qxdEzW3npBBhoJtLZQHU6yteEUzYnXMM/BcGMEH6wrEllqycBhgTR+f/7vC5J9aUoNNkweRJuyalMXz30wHsfUiGGQhtfH+xItuaEa/D2Fyo5Of0mwnnZL2JnCdwwqSmHAYoxFcRrqT4Z04eS1bgpUp9Uadq4I7ffpnHTEN78fJbvE5LnPfkZ5fmussXo1ffjt7y7Mz54dwsqjaiFmIbo2gu3JPlBZzr53VjG2cLVicZ02QmDo9oBFpEMRDOPXlPshgKNHbxvX7r/bRePWn9fDgIKbvJcScu1WCIwi+PWK5HBWS+TFCfF+B86zYLsyUPIRfjdan8VQZ9QctrTDAXpT5E0I7kxugFEBq8rzgN7k5TSq951YpAhjd4aFa296MornISuetWG1XptWhNZI3Zf74WX+JAjE99M8Q/7kuuQUlFDIn2600SZh7q1ch4uR95814XlTHssE8qLAC5LMPVHGhLeVLcgW/dyINs6FgyoHpWbZ6CWfdThEql5SFKJN0eiDROUxQrMs7JLboDBeszm1CtzIZRNvmMgplFvGs/8+fQ/Z1b7vvpCbsJ01g9DdRieXdQJRQRY+9MEPl7ft3srZ5NjUOVrQJL+IaNmne2OUl19huarLBQ+K2p//whcmnXHm5NBDki459+TJ0o9cKc6SNnZpJ5ezJVLyDFXzmzNe83D1d542aZifZ5zWl45evONZus60lHTVpqaJec7e2WmppvXbp9I9RkQAeVDrCuqy3rMM1lZkjJU8sL3j8Y9IcChpEYqxWhzwjjgbbhz6ZRhS6SGOZ/fmrTadud7sHrUeamJRRfqirBkyn2tBWRgcaRP7rZZR+ZRZyXRfRbI5U75ziRg0snpCCGNa1q0aowiKHQ7WpOYzDyhwiYJk/ZzcQgU4M+SZsWRI3//+D9a5+Z/3v6/e1+faGfGd1uKySxGKbqkuUVja5ER+fZR6jIipuzzVOcxn2kkook9+hoBnbTsH3NFnG9p2+Cr9MHXQH1gO0+Sl5mBUOU7e6358v4jM7xp1aBLYSSedHLTxqNThPnGyZ5zjQw89ZLLDDjtVbhkKgxW9XFoE0utIpUqbTBXSKW3n9K9l3C679JJyzESL0NIf/+hnOTNrhR3+nCKuWWsO1QcyKBz56iMf+Ug1uzD/VX/4uSE5efaK3nP2dA6zF2pab/rLDbX39gyycjxHMGumwQh0QkDCsWO4reVoOnFPRcHywZfk3tibTpf5HTi7IlKHpGoQq0PFKjkoG0X5XJNZij+dvOIVe0+elf6ZWJCzo3w0pjazUIf87tozFAoWodqne2uChUjAtfVIlIs4NVDcDzO8VVeec8O45d0oacBKrTROQWejX6gIuRK++cUTU2NF4a691upFWnnPf38wB/meTJB5dvWkBDWIWI47/pS637mB8kayeAFTb9Y4diRZUjhVhP1nRyuzUewDI5PKNcS7ZEhbIWmDOMot0tVo2qihI9TOj7ZC6Lq8AV1hsi5cEFPT1TuKnr23YlVnfYqpN8XnkRQeFacBxAurX3utdep5Lr7komkR/cPKs5ODAV24ZxGl6/T9FtEjCkX0x+PlcYFS5AYcHM/SyXXX5kXKGYhwQcGNSLTxGcZ74fl9l+VAtdz6+S+OzQHbwWrXSLHdwkwl8A5DKydKQGE12ETU695mFavvQHjwuz78lKB2dJwAjHBR+vqpQ+PdMsTeV2PVkntuZwa5px2nbg/oOe4NokHhIB3NjzDJZDt4tSHT6LMcvmm7wPmMqxLflqq6HnQEjPe3OHoUwfLJ69iPr3/jG5Ovfu2Lkw0fm+HDRXQZ/at7covnFpXiEFBaN9/8l8BT2062Dax6QSatOMBSLWRB16dDDj64jLfrN4LgWcpA5gWiaufngbI+H96d3nuXxcxGp5WXi9wrffnoRz862Sb563IaY/jBcPfdt2BmZQ+26PrK6tATp08E0/k6ir/uC3qQc0Cuu2Vmn70udWmEhCF0pvy+W2vaX3ur+Ub1m57mRV27laPnpvzt1/VJNzCeSi+kSDShEXEi7yHGKE9RpkWZKpHC6v3pT4+q/q6Pz1Bq73edMQD7nhoF6JzQj5Qsw8lRZfQuueTSNJhZf3JVlPa73rlf9m+LtKJ7Xck7A+plnxkOevT03AfjuE14HubWisINMBABNZQ4iKCjFrsdSv+mO/zZzRia/evaDX+3PmwJ9fkiT04jev9ujoD3PtBRdvbtkfKXNv6e49xzz6vh3FAlxrQm5GQdjvp5BpJssVWavO8y+Vhk5oQTj4++WqGIf1IRcqDb5lkhSZun/n+55JblT+kHM5F1hvrdb38/eeKuTyxnXhpH0/+f/OwnBSMbR/fud72rBgMwgqecfFoZUKRTgZV0ivPEucbX+OMfz6/yMY5B61gEx56o5TsFAAfnLLmm2teO1pEjjVfbMhPJoJ4dYNGFc1ZbfbV53enjuhuumOy5+zNqoY7+5dE1i/BVr/6vSggTEt57ezcWvoW2O7m0Ii3BiNK+5JILU+D6rcnznvv8KtkAqyCS/Di0ZE3sdbj4wiFfyEHMVPMwoHjeReWOIS5DmgNiUxFjNtn0cWk39ZjJihk55sG0e7JZyiu0oyI8cwMhnp1BxJLW62+wyXyGWkeeswp/FpKdNbazf5+NYBsOGZHm6I3bhKPekI5SZ4eCD2U9oC4KoEZF5VWTFqhNENs0qqdorKufjXqlkRCnKBFoHIweZSSyYjw1U0DPpoSsC0N0XnpeOlRqKd3jtdddU/dsjSg092BdeV7qOzkxPDSDb5FIePCuM+p6EUIWqr/3odf5RYmDNllmVnaepaOy0VlnEFR0TTrsi4eX8hIlbrnl5tX+qw+p8hYGkIenJk87v0EMGiy7PshtTH1O3kNDiWuvvSYH+NdlYKwbKj1C0pVp6vDEeLcX/PEPZUQLSsq1GuLzd9Adh4ci9QLpNpLg36LVjrJLVrKHC0anjWdreWqDW/uZFH/V1GZ76xlrQs3I1UuP/PwXR0/+GiX+jLQfgyC8/W1vr1IApCRyXsOKpw5lDdsuBRkkA6EmUa42cuul4HzXjObSItOos3QnS1eqjTMx6Zw02v52QWxLRJmAxxq6dZ3htE0hvNzTgEXVow7rSVlX8/3p2s+PTPO7isRjkBFsMIhBfS/LWCwwtTnBJdNaf1a/Z+s1poowgK3sGQ/30edlAVHOJJiR5mhD7+8DiYhin9Z/MqLj9wPG7S5g1Ud6OqS+9ROl2+fLvuoXXZ2LArEjzNBnggPGtCFONY6M2E4pTbo1ziSHzcCGv8f402Mg3GfGSR9zmceYMuV18p6F9ExzlaLvxbKfotEuUzksPVrPyUSrrbfZcvLc5PA4xYia1ko5yw9+8MPk0U8PsrZayjmemIbrm+cMTQrdc/2OsvW7tn7VJSpy4z56jT27ffFekLJ/t9H1PjqiHdZu19p73ejdLJzbXAvvcQ79V2SvPDcHojo36TiUntJ6poua3RPGq+AJ8vHjn/y0SIF66R4S5OQrX/5aQbP0w+0xaNVKNXv35+JSvLGQDev05ESY2NE/jx0SjGmgcFkcZpUJWLhvzbk54YSTq/ECgpF2fpy0X0f3kQ06Bspmn8HkbBhkVZCHx4Ptbq9rIEr+tKZ6FzhrZ6fLlNnZ4Gi61frTnfSMUiU9vrfYKsMHYpjpxWOPPW4yJ/0K5/nHFvEGFtPOKoy08wPnfvLjH423+6xiptoEEzI6X1iLGsXcEOmIrqaEE0qnPJnM34xx/GoIJjoWGYjKSyNwiyQn98UQUfT11Ubq0wccGMWdTjQSuVHyC1ef0TF81otSX3zxkIo23ij49xpRzmdW+YT72j2QAe9CHRDG8Smn/qoIHVtutX0Zns6B9aH6f8G5rQz/kyHtz9bNTI1bda+Z5oJaSbUh7brRbnJPGQxhHDWdXRYzIC6diVIvK6+V5+3ItfqXZo3bmNgjz6cL0hgAcFs5Eu2pgwcJZynEulYmRMR5oTTg/WUsIiTuAfGokuoRYESVW6I0wMgOhkNIwHiC6qNEJI9IIbQOLKLPcUhvKaegSmemtXPz12Ba2O/Aj3X7V0hHX0wbrU+FNLN76sC2yV4uWvAQA7riio+uHG0TYIZCHl4ySIuHCFIc//5rIro/VLcgHjAikeHj8+bdH7ju9vL83/H2N4cYd35FFnJ4Dp/IVA5szdXXqNIZinepNMjXOMKru1I5TKbBGPxuUkwp9qlT0FHm/CjVs9XzqYFG8MEXmBqhJsvlZ7Xu2S+tzO66587c22/jJV+XPO56xTj84mGHhYX77bRR27gOvX0r1voMhCz1UbIVUs8iGcpg6LZ9FwEYwm1oxK45B3u/bK/JHUm5mBN6zNHHVO6myitmogx/7zFq1bM3r6rjnhLmuhtSQ7uzMK9yIoae8iQ/CE5qVLfIeQPf7777bjVe7C833VDpGohSw7W+xz3PNmNwL5SUF5nrvFw7kb7bejgjpqXcG+XdDs9wZEaHJ+kjBkBKxHuVdY0yupG3xyWAOtifO2Po5dbtNf1Bifq38hwKVgCwYfrD0m8MLKIeSPA73/5OWlX+JWu8d50zjhiZxHqvulsIT85oQZ/OSe5HREQ3mVZk/BbC2CbpEUtBV/em7BV2KAX/6U8fWB3iTCHRnxYfBdztDFbQkv+qDGSaO67m9hq05OfWCerESOIieLbK2+XnYzSjfsAjzeN7qy1pnqt1XTuE9KWXn5cjo4QpzzHOyOiwVIEN9MT0l9yDaPTyy68oZ8DeXpyRYngJO6Zb0CaZ1gX6t44bxdE79pjjJvu/938q8FksTXbIh71+TNpn6pp3819HwwnntRokZL0vDSnJuEXy9Pfsnc+KOD8cBjCd/+R01xI5shE6FSmdWSWNWnRLujIpsILws6fSVY9//BZxdlJFMtWr7UToUQ5y/uXRx1bdencv4oyQ2U5FsFHkncN1xRVXVu57rfA7lEfNWXe9deZdFNbkW1IkjpH3+c8fGDbtgZOddtypFg8kNeCw9vBGkTe0qA2pL2olPhThgJAoe8L+whe/LJDejpPXvPpVtfDCegJ3cPDzZzz9aWHIXTf5+McPiDeWvF8+ywN1gHipNhIl2gOsscbqlQeTmL8qtWoUy9PTo5FSIkTqVk848aSKbp72jOfOb0H2n4znbBTRC9pC1Pm4jkjbSPS/OxqVW5wVxoZ7hyEdkSVPWW5RBIVQ0ZGdaLCj3CY2yNkMyvedJVAUTXcW8T0Mp4J8G2fqAbYfI91rfulll5TgyPV4ifAbOgZ7USiMNkPqeg5U34/3uUcj3Pr5HbpWbowxz87waWjCMmHcLhrnpkks1T1nvmIe+XKF7UtkwoIc5gWBXjFMR4emxasLVrWzG8Mz89+IQJvQMAtFISVhaMtBHf3LY4t1h/lr7uev4lQ9ec/dAsdtGaWV+srIilIFTUEQ0RjpRdL82vd2rrrq93JwKVayPKDCwapq8kpFrTm42Omg7UYfhtx0YwL3vKDHaxklE1hCwJtvcAvBGE6FdUe+O+300+p71o/hV2j+jne8I9H9CgUv1ZmCYkwjwLqOqDHr1JF/DeTW8SV1c3ynVZMTMkOW/OvwxUGh0A466KD6HjJRDpf2lNMcaBON7F83re9ozne2AR3yPXaoGxoM46Z0YsjeHTEYmNcbpJznxz/5YSKJC8uoLFszcceadv6uzmKuV4Z2qqTBrJzEWQSCnihZidFu3aMMyt/JrVfLi7/7OUNjj0c5zYKWgzgCY/asUrvkwGMAELRwCJRBYR0rHcOWXjntSLFxGexuRqD9HLjxqKN+Uc7aTjvtXNeRQhhOcvKhUyYxclB3GGJARLSmohybvuB03nves1/lxSELoi+lIVIy7/+f91cOGzL0+Pzs1dGVojyOxnVhtKqQEPHWqECM88hJr18buMESHnW+ft+GERvYejO2fu5Mm7YkH1xwegwgPSPSJhd0rvdZy64x73PZ9bz+7XNqNekl/cA17rG/nhPhj9E7KD0KNJd/6V4vrXGcr37N6+pznAolbicG6n3xi19SE4WOOOKIkjXljFWLGrnxPe0AMIbSPtYF0e4Nb3h9ItFnVCDAcZAmtOYcFf0NzIQVoZMX0aln0R1ps802K2PI4Tbk+3dprgGe9V42BqFvDG65pdaS0Se0ODly4jgXJtF4DgjYtRl+MSeU7nmYZzrZPyldO56VLkGbhE3F4xDBELKRlB4diEYOhwIBWZY816ErL6ZgzPEfpT3qKu+f/OZ3v5m87W3vmbzylfvUkNSbU85CIHT9/3CYbJ864OPV8eUrGYm26npr183Lv3oRFoK92tzVKol/Y5LFYC7lLyk6qTZxj8umGMFlzukll11e3/+CF72s4I/OG7SxbKPYMGTf/2xEOms4h3IcbOLZ9/bP+tkdZIdzkInGwoyDHkUWQbaGyEQDUsRo1NFoDJce46+GAu02goMVd3+NnSJMvo+gMKTLB94G6SlJEbEhIIF+CbBDRpA02BgKZE4O7vUFtfhe3+9nPFsjiUSsrq/MqLsoYap5DwShSQTWESsUPM8QiqaaqODeKMpBghjPnfMYSCyGKF4jT18f1kevvGq1HGxoryeXtOJu2LG80nwPgVX8fdQvfllwtbztIyPMCtRB2otHwI39YzA9mygJ3GLmrekNW2VME7m47bZbCoL0GlNuBtIxoLnp+hsHl3tvI2XtqwwmubeWB84CpnrLuF2GDpTSkYucysjY+9G+rxOm1sooNGt75tlnjvaQ8Wat2Ze+/NXJEd/4VuCiLYppfJ9c6XQdxwkb9+Z3DcO2fI38VoxWUiZ/Shck3AWzTsH6mMG/O19v0XVKqSIfde/djjraOWzSjogUJNcOYj3zlEU8IlhWdTDIRTVnp8n38oHH9nzyHpPnJF/LqdWhqs4vOZiiJLPlFO6F40tx+X0zQ8fUkVGbZ7SiZypCXZy/WcfKs3futch6M5BvP0+lm6Z6Cc4+zuSIvMeeD2fP8yj8x5hFmuIkYN5W/jb3j3BJkeoJq35XimLTNDhfOxAj59KZ1nSgyGJ5f8syGV4mZ855+146sB2d7lR6gL/g+S9K84Dz65mdLz87NRHr4V/6cunEe4LI0b8vf/nLS/+emYYlt6snj+Nt+o8otEtt3Kvz6Tutg/W0biB2e+PMjvzzQEqcL+tunaWGPH4Tthq67f2yPm1Q7V2f2Xasu7TG9UC53gNtpH+sC8PWpEVGzSgzzv+LXvTSQrIY2VuSIvA5jHPrCLbVa5rji6fDuH8vBEVn/RWv2Gc6FP6RKaP7eumGww//YjmPasmtZ5VcRm+oLDE68ZR0TBORKzH6XQZgfPKTB0yesO3WqX3eIU0dvlLTYbYKRCsClRpx/+pO5Wu9IASXXnpRZMXAjvCIkr+9I8EBFM/EMeM77c1y4ajMCaV7nht9apKnL3/53vVLChNzsOETi9q1WG1ICeB8hTJVzMOoJJ+Wgz3bZOC+kIJ43m99y7sy4PgDdcgtIPLDF5LU1WP1E5/8+OQnPz5q8p3vH5nFGXWGzeqjABCJllw6/Tpj9MF5OsKoE1wrHoTk89Jpb3djopB/5eDfFGF69jOeU9T1uzGG87/20trIDQU1Xq0oZyPsVlT9ZyuaVjCzjLc+mIRhXA9DUmnIOFgiGgINyuEF//sw8JErHVDTmMXoHrtWbjTpX7gOgJwLzF7EiRDUQ3a7roxyFo1gQWpswGgw5DxnENS4fozDdAKM390U+KS9TQcTOaeVgUPj2Xw/Y61vLGFllHjH1mR+84AImM/p9lFykcCDIa0oPd97/AnHFUNP44Qd43GKKrXrE2lZG99RUXEOj1IcpLTf/uZ3mejzh1KoNbQgcnnJJVfmMGyZdnsb1OG0Hvbi1ED6t6aWVq7Eupjvue12W8dbvSWj2y4PeWOL3IeofNFpx6exJyI/bLyS8X+DfIYzZG0oHJ56K5l2ytxvE1/s6YB387N0B2OMFrCOOu0xoiIRyempS1z8YYsW5HVF5iu+/W3vnCydg0pJjvtoY/zv7OE2KJ2nbwUnZwVeY/hMSzKhhIP8H195NM/ShnX+c0+jU+vZhnb+n9Wvd0TvFcWC2oI4KQl54QteWJGV0XVgOWvxt3jzzFTPwBRZkSeIAYfHd1C6g125VJ0Le89gmBDl7/a9G5G4ZuubWWPZjqufIZGQI3I9Ihkj4fKaoiXD+Y2BSOSJYU8nDD1zd8kxjgWewi3pvDQ6Qo2uOkAThkkf55+GkeqzxvjpB8vIgnLvnzLKpSikVKyDnN13vvv95AYPK1lEMkpcUk6w73bW7BEOw1o509/4+jeqh+/6ieyfEFKZ6obzU7+/TNbh4cm53htHHRzq7Fk355VBK32RczkaMuhUNOaG2jsRqt8z9BwYPy+iDT2tVErKYMr56EYZvecdbPT1rYE1hFQ1elAEx9y7/65KyYno2f4ee+zxVd//1Kc+pZiu8pwcyReluchii2VOa54Nl0Fe9Zprro2BfXEM6VoFx2r1ukHgbfchd7xyIl1TV8iQc/GhNJq3N5/77IFlSDnNhj/ceOPN+ffKk+22367IiLgUHFdtZS+Mc33ggZ+ttBBnUZnRXomSPbOpLp7roiApv//DRYGJl68SHpOVwMfgfxPLNtpo40pB/ulP11WTh+uCznk9fvO0LV111UfP01Lp6SkSFjndHW9/QCMDjmovqw3K8LqHZ9rRWEO7w8gMZUGYQZpYon+77a+18F86/Cu1Ca985StKMJV86M37+UBQ22+73WTnXXaOB3JkwvbvJ3pZfcBBEZbRZD3Fs+n4v3K8nbOTjH5sCBeg4Dn5LsYDAUKbrwfFgz05jfCf85znV/mGsW8+OydeqcivDeLsvc8+Wx/WWUPahnI24mgBHMI6asZEpBWFTokq3fCgWwmCTv2eJ8roVuSWz4t+OkoqGH2ar/IdNrrHGDkoBHZu8qH2SLTGexal+p21FbUjFLlm9wDV6qyJNJi45ZmmWwr27vD+/1rzFx8RGJYxLqZn7s39K5tpA6IMwPpQADwz7EUHU66gPPLKR6VYeuiuuic/Y7BOO+2UycmZZg+Of2nyP1h5an5FHJXTiRN09rlnT84IVPubtAsr2ZvmGinjCy+6NJDadjUblwIDa+uwwjPVsANZR0crLzkp9yNy1URikXyHRthrrjU3h/Ux80ksLa/WmUGfLVci32O254hiFsoDdeTTxnMoHGU5o8kGqP+f8VzvT1/PQdoZZ2HOnJEC6OYXc/Lek08+YXJplIZaupXSk/jgQw6pqPTxIWMhPNTzM8aMNTnJulunVm4tf/9u/AfkTPmrrxXdzQ+KFwTH8zsf9b4WdApBnkKCzeDs76P0Kd77E7kxVO4FnPe+9+1fZQellOMUXXvN1XV/lLx9EZlwdFqGGQCOjAkg0CJGcyjk+wtNAU1KL4mq3BvWp05pw9Ey2WRBX912MCFf3qtRC8Ol8TyIvIdI9BlTu94Rsv30e0EqhOEf9w1nT8T30MCtIm4zMMf6ZNoQFClvXjLOibpZJVZbxnm/IrlB/cKxfOXoREOendMrDXFeSvwuvOiSkJd2qK46zoYBBNbIvYL21UBrnv7O9BE3AebkE0+ZrBBlvXLOtBfeysNirAUd7hm/oCYAZc+qFWHWsaFvzzXQwIXnw6JDny3IcWpoAJZnRDsF144JA+hartnOtLNn/ccZGVGqAKfbAbp3pSF07Q9+cGQ19m/i1Xve8+6qpkAMdTaXDjr0ghe+tMbxkY3SmbkP68KokanLgiiuu85Aavx3cs7y3LmrVe9ptuJG812/fkTxZQ488DN1JnQEwxRm7J7znGcX7MqZpK9A63ocm+oi3TE3VSma3tN5+lpfkA5J55732+iVzdKWc49yRpGhpAeRzTx3nxNDVIYcYqnfUa0cyU1Buz888nvzNthwg8qP1QQIkBQliiU4A1HO/n3WkM5GpZ1DKUUaJeJLKZe/R8DkQa6LJ6azzZNCjGAQ/hzlhixw+RVXTz79mc9N3vfed5bHenjC7uN+dNRk5cC8XUQ+ZqSaKalI9xGTLUND553dHShLA/IcjRzaZcrwn3HmOfGQt6xDXh1Q8rMBof47RPtAo9mHbjbiaIPbn+0/Z6GmBVDloOV3hMtYlhLWQzObYI1dz0Hv0hPv78bxNdx8Cg92QpzA8voqYZ/6PV6df/c0Bu8n6BQXpQVmUWyMPORgQBv8jEDzWjkcvk+OlmBDBkAZrqdDkjIGuTRsQS+GufNOBN2z+R7feWzaAFKOPb1h1jkRhfca+fllgUjU4ikVAOHsvfdeFX0biozZ+4tf/CKCfkk9p0haAwae+99uuyOH5rFpSLBb5Y44ENfnWT3bLZlfywBuGgLH3HSgcUBFo78M0w+kW3muXI+XaoTV4nFgwHcgNM4ZCIzhAd200euDw/FiICmb+lnWAhHFM3UHK7l+L9HU8NoXHbnxSGM1q5gSrzQm6fNDIYM9Kd3zfvfrYj8iRnCK9t//fwJJjXKdatAwTae0nHa+qPtatzEdTl9xa+pZGMVCYEruF4wJrJvNS9QqH9f50fkRXuTUeZxvSKcNG4Yh9Tv5xYdPbkw5hrN2WNp9yidV7W/kQSmcdQWT+t5Fsx6MszpyDjGE6K4QvNRJjhZ2QzFdnfykZzbxhgNQBiTGQ46awVkhBCZ7ORuRDkIR5mUaxye90XkyQ6R7bJrPVMS7xJIVPYvefO9tQWsYcU63l/w3iO7eewx5f/TkqiAE5EuUzWEELdsz47vuvz9oWNIhK+dMXXb5ZTXJymxkr1uTP7svvwcjQhmwcl//htelefsqNZyBk0Cu7DmiJQf4gDTlcB4zznJy4vEnJaqblgNGPhjMpeMIPjznofYtMuWcMnTFoch/PZO0uQ6FNMSRb1kZzpC0wDCy1nmQ+cLazoCI2f3mAFif2XF3/t3pHc4OfQSovmgyAAAgAElEQVQ1KaQmL+fVvzn0n/v8QZPLgiKtHEO2YYhw0CH6D8JkSIMqgze84U01CxhiImUg3wkR2DIdspQKJdVYfaatP8fqrNQtq/t9SkYJcsBOS2P6r8WQPv95z4kj977ik9h7ESKkbKew9U868YQywFJhmkFg9l962RXpxPW0ynHLa/76N78tB1DrwR0SwYo2GXRpR2kx0a9AwH/+Dg1gSx6VFrU6VYHRDUjRMMJrzhVXXFLJP+2oCtq06NVhaOS6+r9Zgzl0PdUyDmpFZdNcSF20vKDh0YtKQZw3ZgqMRvMXpv5NY+DNNtukkvsUivD5onhuoL6ttn58hfeHZ67cReljuVKizBHlLVSHdLFFU6yfhPFDcm0FvTw3D3RXDh3IZs0YaEOT4+hMXviiFxZJySEYrOJ/J4G0cnPPbcD6efq5+3n8OWtEZ9/fn++coWt0zrSVqei74MMcWl5ve3gaNkvy95o1s7Hg1op4HlROiM8ScMJBucD+10k3EUbZRrcT0+0HCa2D0YPDZ3OphFj+lJPTB4IBYlTlUt1rQ9FQCn+nXOWlF8rhcy2H4KLspVczBb3HvSCJeMaGv9VS3p6hvco1/hpP8dYosmelVEWbLjm234bJyjP10niaTNxx5z1BSZ4cpu+TSVlFeA4xYhwFyatcN4PHe5gxUgoyFKfAwHdesn+rVVszTG+9d/UpNn7P5ykH5TjgzeH0jUi6ocIHPzjzFPO+EbWSdgX2A37u8zGfYT0ltnRe7p+JaNxvy8iIdqfdu1g65yJ5vdPPPqNGdT0ubdRAVIce9sXJEV//ViaFbFnQINltCA+5SBmSs0cJtiEp+RwAZr0Gk3iEn21EZ41pj1Tr8qsH5vWauOIzFE1f2joxEtWeLc8GMv/mN75ekCSihrwolMB9ciw4QuDfyjVOXwNCHMiFdRXh0w8cbYbT1A2KS85pdDzLJKhpq0YkLT/r+uwRzciLpYlM0jqcS3KDXT7QMA1OwpbOmt0bZ01agoER7bqvnVPXuFjSC6NhTEpKdGkL9K95+jHHHFP3t99++1eUisEO3r1Xk5SgBctUydS8ya9/e16lmU5I69QLLriwIlMNbU5L6cRKYeI+K3wQDQHOiyJXI47bQJIYULlkdfpnnnXGIBbFOH8lufLMwate5up1OStq77XRWzjyap3JLUPq/uhPDoHXvw+mWDCPteW1oN6ZwMg5ZtCrukLUW3Wsw/llHLu1IDnoul96x88Zb3JS6ESdjwEtW3/14qemJd/m0e8vS5TpOxhE3ecgWAd+7nPVUMTz6FngxYDSZ9Za2u/eyI+IFQSNOduTcjSL//nPj6404Yc++MEiDXHuvQeZyPqfeebpk9e9ft8aOLD99tuGjHhazah+85vfUHIHrTKxCHoJen5W8vrWxedVAZx22hlV2keHKZGBHnqdesqvgvDdHfTz0eWkI8d5Lu0O069+Mueaa66ap+hX94dx8KfHMp0mKABfPpsfbDisT1gvZBmgqQEtw4fYMIV4GwIzd9FD/yXEGIJm8LJ5g0tkALgw+q60HawHiKDrZnTEt78bttwf89CPqoeRM3lolL/SihXT5cXDUAhCdGxfjRo0d7gm0yhu+dsd2ciXTZYIOUV09qA5CCZcdRH3gDtmnYRSQlMPftbzna+gpk5Fh/kPNKq9Tm2c6996B1eIYJRVIp/8m6Jm8AvSClQDGlDX2XkJQjxqtVJDO2Uvu3+GTnTpcyLCgs1i9Lr2VBR3aajfhHu1QCEUrZcoyveIiK09kpPcC0XoOxlFyk7+0feAyRlUjpVm6nIsmnDrcOS9gzY/p8Z7gY5XXHHlOljgSMrU82JFNmxcJQ4xntb+jAi56RcbxCtEaf9NvNcf/vDHhUIwGlh0FMLTnvbUypHINfHifxO2n8YT+pxq7rB+6PIio/umgwkoWHXIyhjkmPSFFlGvEMUlX47NCwFR4hDstRiLj8i1GN9hMFD9HZjRTGTU/WI+jhILL9BuOUL2TxkCdvk0SuouOJRLGagihw3WaBtT12hZGDVsybnFKdJjlI+32mpz4zhePPnA+z8U5blk7mmUQg3y00iZtGwNNn3QDh2Qqq/vmC86IlKCLUc9SIEjVB3OrdxQOb0ViedLwdYNXWsiMi074oTVM4tmppbUZzjCIsxHhjB2ZTrIPO0pTwuU9szIIhLYI/MdQ3+IKt2vPtjWaH5/50S1HIzRf9sM0jHZZSAXafSQPBdZenjSDF4DKs+os+n9DEb1qMcetaSppwykf1sgvSuuuLIcJ0xQBDGf1UUIy/LKqzJ+LiS025JDR4BhPDfeeMOcjSXjNC6W9weWz7UvSh5NvoysYprruPPMZzwz8O9Ak+6PbHBOl10mCv6Wm6qP9M9CdPnFz4+brLraqlmH5crQbhTYUTmh+70h+g3aoGEExMTILojM+enOdsABn65a3623eUI6U505uTRjAx+Vs71sHAnPpVH9ClXaNwh6nIlhSBk9rUVHiYo1H8zwBQZ05HfTCi97cVscYOe6W5NWCVT2QhqHo80gdJ9nMsphLUd6Cm12jTq58/w98o5M2ceOZHV9AqWadqSmmYPt2oykfWU8EYMOOAAkO6cifkPrRYi+V3vSY489pmaG7vXSl5Zz4Tn0IPCnaxx2+JfrOb9w0OfqT+ks/3k+f77oxS+qZ9sjxFk1zWeErPXutB50n9//wQ9C0FwxMPQG1eCHfjsrzRcYZgEKdEH5y+rp263JDdu0+uprBAlLw5TIIARLqc+iCWg4utdee33JCvLRnAgPAn9+cWsJNW/NCzTVAj4UyAIm3/BQbOACFlwboVnmbueYLDjPk3ImyIgmBEJZC1z7ggv/WJDfwossVvi2nBDvh6f67f/7Xn5/TozDYyoxTYG41ppRPGaZ/jNKCVWa1+IAPyoeghzARZcklI+3sUrep1v/gxcKpbvyVcNTn4V52zjORpkPjDhnnQnr07mphi9nr9ckI7nS2VfXG9Y6Z01BhIyoa9Sa5r+hwEbdKSNZezF1UsAYYCVrp05yjG0bBArXkZsoenzyIE0q8nsNuAli9YoMscOhk3Pp4cDqqEDJ3U/TwefpgYRR18U3cqp33RUlkoPtYF0U+riX+szqCZqIgDLbKGy7xaIweNSFBqg51gEqjyZXYWKPgnf1cl//+jfLw2Qo7slIs1133TkDEp5a0RqjCN6BXvj9qiEMrBDnwfe5H4caFN0IQk9A4RB4ZvkQQ3+rH28cON4nY3BlmHhz564cbzht3KY5TgZokcC0aiSrptS9p+7TF9kbLPExkm+0jiuS0lSh+30bA8q9mmuUZ7+gb3TDxm1YGdLF4yDcGhnnjStMJ78rpaTn4C8cMjnm2J/mHJgEgiG9WEXkjJ719NlScJi9U7mwD81c6Ih0GLWGfMvMVppkPoLU+dbpee/mD64Lcu/z7BrtLLO91r4jl6v+kLGFmWQCLlO7x/lbZZWVMpN0+5Ln24rlPViiSruUr1C6ZJQjMcYLjm5Oo//xOC+j89Yg7XHO5LrlPruMrJmjogURoZnHnB6pHk6V67uW/UBc8h0rJyJaNOiK/b0xqAU2/F3aN+belk1E66ydkRQDYwy+K4ZuRvm9/rWvjZJea5S6VNlPnNx8D2KKc/iJQLOU7Hbb7VBEFHAsGdBsw3lceOFFJ3NjZHvW8tprrVtEwAMO+NTknKAxcvtXp/vOKiE6MUSPDLrGKawSMdEoJZ3F4JA4Z5R413MvVKVFIz0xX/9OdUud98hU6ZncH7RgARIAHRvMZ3vbXZY45/7dBrbzoAOGH7wJes8ziky9D9xbZ3EapcoVyzEKlqSbuhsbY0gXnx9n+Y1vfFM5A36nmxFYFbrAGKrQ0IXMmnIC7CNyHpKi37/nv/cvWTroC58vpECusxm7P/rxj5IrPXWyx+7pSx2E4He/+0OQr2dUbv/0088oRvAHPvA/Of+5j/TlPSXIwXFppmCttknrTfbGEPG/RuZEreTlb4WEPKQqJLy0FWS/IFZrp2XkRuF63Boi5pyTTzl+njD3bynytoi8ztqU2pxxRG1A5ew6uoqgtLIWQfH8ZicsdIOGjrI6QiUQV1x5eXWxsElyazblvHPPKeaW0UKYmKKQ6teLlh7477DDDg9D6roaGsyrWziwhDyp8Wq8suUyCNrwXQdq5ZXn1vis4044tRiR2++wUwnSQlGM4/4XdG7xXLOQ9VA8C6LIWei3VnHm1YZ09jNtbNtg9rU7Oq1C+ym84nMYZQxgd2ZpEsuAARWbj3ZnDZNTEurdKAZRZyvuMeT7jtqnbmzQa07Z8NTALiJY73XtJh3Zh0q8T70+B4NgynNhClbeyqQKea4IHKKRQ2OaA49X+ZFoTs2w6xgzRfDMMNWz1j35HHjXff/2fDDufdXb9OCDM8w4CILylQ0y9HqQmP5e8J7JQSsn+uTVqlk1naVh6N4GirtzyWSwx3S5dzNZx0GcM/lD5tQuHIWzwgrLRqZMIlq8WvQZ/P6QRQKzIqzkoqM37ShFWnSRdBoKlDmQhkGIsXaiWXI9Iq2RkBz1lKNXdBuelovZiLQ7I8lLLRYWtXz3RRddPDktDN6HR65NUtFC8IP/++FKd5hJyXB2PkytosMup9SM1PkyJvpl9ESe0/+5hxGpNgKzIO1ScjVNHTivjARnASrhT9/L8WwouIyprvROUJAVTskSSyyecxueA5Zvcn9a2Xkdd+zPq/vSVVdeVWuF/GaNGBAOMqfBz7C4RTeQBnlIMqYrkAYgY8wZEpqZp/dGdpcvEp+IDzuXIrYfztQgDo2orJtrjLKgQWQRDVZjDTnc1BWTT3pLbs162pc7kgKIe1wR4hWXXDC5MGPMNttiyyKn3Zo8vXy9TktKU25LlHthGp2TuTe/5e1FTNlrrxdPHQRrcs3k7tw/At1DIy/0XEGXOYty9foU//yon1fkSj4YsDHqbMzc5AQ9MsS/5TIM3jzm4q7EsXBmO+cpT75Y5fnlmUfLT4iDvbxvOscTM5YBJKcjCh3kuMFWFk0OR6b3RJevP4UwZm0gg4Ve5HoN9/u7tfMfpxu5smvX/e5XyV+C1HcKK1+qQu9bZx3M6kwpV7vo4gsnb9z3zQVvO4eXBUXbfLPNq10o4hW5AdFi7pZeSY2yOaDbb7d91YC+4Y1vLhk57PDDihlOr3WZzDkhK26ZPSM7rvXE9Ps1KUkTlLkZu/iVL38pz/XwyZFHHplWfz+pPLUOYZfHubbGV2cAu/STNpvWc52QnpTKqAM+L4Sk6lCWpYO+QWYeFeidflwh6GgGex84z2im28221LEiwlcHfgZKak9kgQLL5sWDl9uzqLzmnk7StVuzszhH4X1mk8aSKwE5+5wzy5PR/9DkdLkf7aCuTRTE2i8U4VDaYgpAkW0Cfx108OEpzUkzgmUC76UAfW5yZH9MaYRpMA+K4Omo4l7+loXdJszOCwOTWJCX7bPPyNVNawS7pmpWwZXCmRq4jhoe6OF1FNnGstdiNiLt68xeyyEvozZl8sqRNrxbSiFrOIgvY7oFgWtHRAOHJn6AbhnYi9LRyauhmqEkhyffinpESSMqEqlRAGpGO4dZnX1yyAi5n7mnJZM0V+DPYDAsFAXPGMTxmwiiqFX+YuPU0F0X4fzeD74fj2yd1B7vVofStZTs1LBf8FBIJW38/Burs5vEy1tomea17bZPCJNu1fo85SAHt1SUTnvnIDpKoBVCGw5yxihiLtp3qYFLw6bU5UfekVFfMnDjLqmppCjMjKyIIXJVMwaTW/J9D37InCpMf3BCZlF8Kf5470gmvGIGRq6wOuUwVJHlMjxTmW5Iv5m7HZ2WYitot0xP7VFHqcNJVXvKAbp78n9hNcr1YjYyLAd+5rOBvH802er/a+s+4G2rquvxHwwdHk0BAYH36MUO2JWiQiyYmGAXNZY/goqiiV2xBbBFYxRLRGkWUBEriHQFBRQUREV6FZUuHZT/+M65171Xfzl+nu9xyzl7r73WLGOOOWbk5Ex/qf7eaUCBM9qfUcteBrazzflXobk5Ewv49XXw+5o6w6x7yd/et8TsC47GZm0h83JKUz/rHLRcjrSJew0N/7Ug+hXSbqHuZYzWRskcTPGQmdyaYGh5IhNhMjv/4HhrByXgbNSlQO5+FgnJey+9bGQGZQYJ3hhzkGMxfFduuFfGWM5+CurVNwU11lpWW+O3prYfGew4540i9KxXgYDa/6j73zORku64owUf/hJHxAEuiV4rqPi2lJwuCbHIHjSO68tf/Wr9m9bx6/Z+YwRBnh7Zv93mMjulkNVTKxXAum4SlWZZCh7PPvsXs6/m99lMdWTPhbN3bRyEvQ8tWiNOAxzdzOspCIjjLnQvP29d7p99W1yM7AnO1H3V33kuslbrx9H4Gftq3pmCx5sHo03ES60Z0VD5SKDjd0ddn/20jtZQkK3MJKuzfgQZPD+IFFSR1u7Dg/64PsG292E3IAf1/oFx3xl1o6dmXKJ+93MjhvDZSIiSXhRMOQOCZyIJuBzgVQE7kQbXv88+b6oS32c+e2ASsJ9VVmsPCUA/GbKT03B2hBiQGalSYU9vkc95ewTz1dIPPvjg1E1PK2lI3QbQjqOj/V5JpGQxa/Kyl+4edGyXqo/K6q13IRjZowhwf5qGsB96yKFpp/l59Zcu9cIXv+C+vV/3uhIz8EN3Z2NWvDI5lnmDME9ewPYCKfhgNwmSHI3iA9odjtTvMzqjxcNGRxcGuzn+HKYHp3H5xhti8Hw9ZaahXnJ1fpbHN7/u4EMODyHhqlCoXz7bLmwrrRJqXnfn0IP9jHy7Nr1EmF/aXsjIvf4N/1GRze2J4gc8sfDehvkZ9zkM48La73CqY2MNeGzAuX+fxY5MvEUYWsje4fB1jpWRQujxb0LZlUnqf/Mw82/rac1kqzZrMelysC9OHxtDQN1JHcjG82pmabcrubYB4fhvUb5Nrg4pilTr8X1BzfhZPzciT3CV6wZL2RNev0vUCHLZLtE4qTb1I9fBGGhh0VyNdFIOLZH1kBXzb8+xnLUsJxGsjEFvqKkLm4cspI6xTPYTVRQHjopM3Uf+3DsZy/EsxrNxrdbDeyInkfc666yfh7R0bsgGZ9TvyxKMb9t779eUMTkzYvb685ak/nFDoF6Zpd7alReZvZsRWLnGrnlmnmuMF/UmQY7DKGMaLHbRvM8dqj7WauynVpVphwRZnYdZe5dh89orUAMBzixtMZ7dqREjuSYTcbbcaosyIpS7PvGJ/ymInBO5JRmR/cI4OekDWh1BRZ1+wVRzjCofHf8/MlLX3Q62dYPLAU8Zx3AyEJsq4ygXJLsRFM0FlFUvxS8I9Ipdnv9xYowMKTsZ4nN2+5fZSyNT6PnXuMAEJwyoZy4YodPrDFo/+9CZn1OcSqDps25KO8mlyQzsGcGUn/U7ssrBdldiWHnlKFXld6A6nLRA0X4kjqBlxlSpVeN0O5hp5rwFwr6sqVLZ526GUy/1NujXdX+Y/UMCiw03jjIYSNQkJs4rP+kz1kzw+dUjv5FpJN+a7bHHKypTfs9735+pVM+vkpRzxvGp/ZJHXS0Z5CqL1iiY95jMF70tRn+lfO+UtGoI9GSpjXT0yLtFQSHWBUEHOl4+wQllqFWiGLQ0IlTuYdQqR0CwJAGoe7kha+Y9XKPAyHoNMQXrOPR+2xZ3C5W9UGIxxeJNEJ+9P0T0x0SZ0Vc6bGQ9N5rrUyDz6yA9sl+i8+5HNq01zR5C6hFImFYkGPGcsJNd53vf/59FFN1iiy1jS35aAxicHb2mWOCc24NS5tguZCLr75p1D4Cg3/yWt8RxbjF7z77vjKM+ub5HgMFrnzfuU9DuLjs/dbbNttsUm5w+ApYtAttBX/h8subTSnXJvrgw/a0CNiVD7F7kJQx6/B3CM0qF7mEINEDtvJYku10nrZhq1oK2I478ao9Re/vb31qTHG64sbUFq84zRdRlAGozTrVFmzKezsMZDmPuQE8rPhi8A5Ichsa3GQQPmZKSC+1oaaXKAtTEFJ5vzN93x9AY5Crqpe2qKfeYY0+YHZk+08c8JpTlPDzZGQWm1XNginWWTXVHHJc2EVqXp57640Qmr6gZgjRIBzQ4rndhkFDGu+ChblAesMb4mfG94aTmI5hRi5qHhAf1nJFlSMZr4XsxAjJBzlA25XdkjkO8W+Q+6n6iS88EFAaStNk8wEFSWqhTO7LTfm490g3U6XDJamuGXgwg4wYqGvftWsf6qIfqvzRk/fpkcq1PG4HnkB8cLsZu7UCyvndoptWvvtr9Q09/RvrsOkIeB/32HIhVJzKTr/nvoayESGAtRYayQz83sjnXpFZHVcbXrEMZhGS8mH16uJCKTjvtp+nHPLXYgL9KvW7NsOk2iHHxnk9KA7waL8Tj4mQTIBvBFjIatrE9uGXGmS0K0Y3xGe0BC3WRGRb7UnuVjILRUyMr1Eb2NLXGFMqR/7lWWZGzUrW/qTTSLFr/ORGXpjYTgQI04q/33W92bMTs78r7b7vdNpWdHn74l1OnOyqOdbNiPlr3OoP1XHtHlTMcSIr/ru+2Cx0KRguh3d73nU2OPxW0FYmnoUEQF/H6CnyyR8boMh+5TNXjOjD2fb97eUhn2g7e/vY313g1hhbqVDq7eR/XKvsrB18ZL4WnsO+n8V+yKfM2O5BJXSxBjvdWhnC/nLmsQzDjxbAJCFeNo3QPZDDtacRDTrRatHIvo3YPRncNIzPtszk5E6uUb0oKesoOuL6DT1/nCEHcID9njn154QtfWrbrkIMP8sSrB/6ZGRdGuk4isuqqrTnrUeAz/PrXge4jGMDYP+c5zy3i3AfCOLX37S3r7lzeK2NPIiB4aEe/bPpHaVkvk+zYn6iMZe91yaYRDTD0aGdxT2DQoY7GQQ4J0CG1NxxpB+59tqy/s+2M2e+DNzG+1+hW/9zISj07KI/sFUu/CKRBTkoNLw5Zbf+yrNlLIv2H/ONafaZMlgM9Mf3kxOzZfc9eAPHHwOA+3zBwma066Yvzu5tmSph6Jn8juP/gBz9UHIs3vH7vQjXXS+0Si1b2+67MQrWPXvGKlxcqJaN9zWtfW/vmwAMPnH0nE5K2SEulh4Ns+ctfnpUMesdkqQeF2BV7FmKiZwUpQUzUp+5l+g9Yd9hbNh1ysEtg4R3CByjRC+duzz33KEmqmmEXCnjVZKbIeiGUWRBvHrjvrRBikMLSyM4WOsu/7SftDGn0jBUEk4Nl4siFF15Qv+/BjKhJFMG5/LlmZS5dM+mIl18VeHdJBBiOj2LGqZmSsPVWm1Ud4a44oc0SxYOy7gA1p7gvO7KIhBseE5gXvn7rHZ1pL4Texr+HcxwGsDOOhrsWOr+ReY4MaUAewzFXND85kgEFtyhDByFeoy7b8ontsBEdhiMbtHIZ19xM0qpN5GDEYHifMWy2P69VaLwG6aCNbBt2ryGSPwTz+33vroh4/AxH5VD6fMbJHEBR+vnRyIUYoOT/+vzzKuIewtXq5JcHopPBgU8W1o1Bu9og1ojRG4GYjLQOWg686HrNGIJxcDkL98NRFsSYtSGK7t/gWMHE9amJX3bZJTVt4ccZN3VbHDwy0p+y4bdKRrDLLk+NA31isUh9psEGjLfGfhApBugagXewLX19s9zTcqnpMFC1lhNZqGpBcZID7gQlgt0HZD5aDSAdBTnnWsfzG5KP5eX0TCAdZbpRBzgtsLBUDh7HdHdGDXKkKyy70uw7YTPeFqh/q2TNXRu6Zfbh6E/3uK8H1f7vTHC8Gridd6aF8c45jP8rI+3f7LaWsb8RmEoJaFL5YTCKVcuRxngiHw4FID/LefpbPdneg2AdcvAXw6bOnM7IQOphFmxwPHq8XaXzXuPkigzU8KCyxvicdhCmutydeva5lU0uSV/wOWkvMRlknWQMyyy9fBliJLBttnlkGf7K7rNnrcuNNxrFd3NlxiD9Mv5xgi2rOMQwJinTiXcwxR31mNwjyN2zpR0MQQLrKR/RbN35qTuX1KbWCsb/Mwd+quDN3V/6bzVtCgv0nPQmnvOLcwsed74Yek7XWu+eVpA12aQQjH6V2iFY1zNCHgKvWuv1ko3a69ZilfBEZPDVx5n1U/KwZjz9GsnwVq0guJ2cJEIJrNrgpjomJGUgRPZoaep6ZvYfZywIhDywx1lDwbw9xxY7k8N5elbDTvleqZxNqk0CVfbanFFay15rxakJch4RXW3wLZnOYtjn7F99zVUVnBz5jaMLijX6ECKp3/bxj8towF+fX5Cq3swrYld22Xnn+jllAFklCPmQwKmbxNm+JaPTvvH1r3drTa7jsAT0Bx98aJVyTM455OBDMk3mDbPnPf/5s0MPOSTs3Z9Wt4MSIgdOKENSst9+708muk1NTTr+hBMrK2YjkKPcLxs5YG4ERmt5bOQer7o6fJzIpFJ8k6gtlWbh+7AkqZTArDHrymAAovL3cDIDBvTf1S6AZTdHhKGz28dUzCwqGhMRPJBmkK5YC+q9wZ0g3ssjKSXC9JBtgDLkHEPeC6z2s1CoETLcUD2EME7XSqb0wQ99LJ9P+HjL2R8i0/TwhxvltHqikIvqM5YsXlI9Wzbs2g9cr9Qu4hp7FNWo/bJAMm3XDIqb7sXPLHSkA74dznNKMupObcR+z3mnVapEk4MsxxzjXU5uIhrJQr2GExz/9vfQMx41uJEFj9pnSQ9WNDpfA+WU6qBMmZCfbUJBk5SGYR+yaBhpo7fUzzmkXRfStiIy/OMkYrBBGQOtJBrt6VWqk4J4m6QAeltckzEY4tHXOAIGTF3vy1GNoKKg2XyOrAMR4ddh/qqJK/iPYcUyCfegoN/9e/cVvHVlSBCfiQAACTIZyg1xqn5HK4FHuUNIATvuuEMZE1DMeeedW2IPO+zwpDoISgTXXJ0I9kEPDKS0eYlV3xmDuEEYvAhvrKnsTb3QelYjf7Kgm6LT6z0FE3r2hnJNO306rBLNfX0AACAASURBVCEfTa0xAhYs0WJFy0oqgJpaVwbuKgvyXAgVgDzzeSutsEpq+r+Z/fq3F+V+NguaslxBUcclYDjki18s2JJxrrMxBUeyrIUZaRdMa1v+3xlpNYhPDiPXVFmKzHQa1VZBI/B2Ilb5GxLR01NSeyyFm5ak4xDBiVdcfmU5rW+FLensXn99Jjul1rZaiIB/zR65LntplaytPWGweY1IzHlAOBS41eDlBA36eck3cmJGcjnDD33wQ6qnUysVssrKKzVxzU2SfFMekv0WlJjFuDLtC1qa1Pq73t7nrkKHOjc9Mq64HAVr5ozkDwh6XtGqe4UFGncmcBJQXpDnYu8Qqrf2733f+8q4vi9/f+Ggz88++rFPpF/9BQnWn1D1TzqwBB+UXiy4e+YsOKqS04xl1SrkjBvyvuzEhhVUWg/TndZIgsAyCebo9VIzIr+H8/Gg1PkFC20zGw53r6WlnPcScFawHQfItg7xBuMrkaNGIG8dC23IdbTtaRRilJHY3xEYl7OdEEj/HgQfjgk6AC79+lE9rIDDf9aznlUCDHq43TPdXO9LmGH9BLWnRv5Tr6lyne/flUyWjWYTEJ422WSjqnsKRLTLqMMrTcn+jj766Ao+npsh3x/PcJWfhI1b7Sixg+77wdk3EARn9qMf+Ug52s997nNVt+W4T//J6bmvJni9/33vTk1/k9kXvvCFmkeLIPWqaPouXrJkroe/W64aqRzr5FlqzyRhetRRR8cp/3a2VOpG951//q9r+stL0rsj6mFA/5ra44hYHLix4KWWko3Y4546Y2Ms+qH24R6zKEc2ZwOCEhhz3xedcKQMpjE7wyiNeqDIEgQI6hFpwrLvyMYGKS+jNyoH9pKLLq3PxpySjZg/d04iR5HkkiWLYwTXyINk9P+axtwnzdZOvyMHMLJHFzua0UfGWNc9OblhpFpYvWctllH0/SnAGDW7sTl7jbr/tu+9GZ9z0Lga6USOcGARadSKBBpj6LA1YmywYK3b/ADwzjJHljQcluHDjNiY1TiPEAxH2oiA9ZaV6SlTh/PyHLzUuBxArFkRlizogakBIHbQNFb/UAc17cUz5vwcRHvg+hAr/BusU9e7YCLOcKDd4tDZkuvjwExo8byIJDzh8Y+bPSmkI8ZutRhCP8cYXpexafr8TjvtR7MvJtq8Jgbt6kzN8EJxXz+60PQ5CX8PKj5x+wGtG6enV82M1V9nj2MCW/PN40j/EEo98od5qiJcMoJ+r2cw9hSRuXFc056wB1wbuK8Yo7nf6jWdakf+mwFV05puuHtAK3byPLped8+kwUyT139zPgLN76YViGD9lls9uFs44vz23fc9Ve5YksPNOIwAyedWFpX/DXLgXIZVDmd6lX8d/YX2ECfaUGYhMhO8KRhoQYkEnMniRq+qnzPqCzlFn2f31rYkIkiSMf3AB95fUOyNN2meXzVIwwOqteuKtHUQSPC6dyJJMfCebY0nyz0SJOlg1dSjyK7FycoEBW7QkAEVLk67Eih0vGjUCoDsWVkTNZqa2hFnoeZZqFqu3fnFlxj6u4UqTfNhO9ANOzn/61Y1a8oZIU826VK2e8kll5aqziOTCZdARp49+7Dbbs+bXXDhLzPV6vWlzMMxaOmq2mPOcdsHe14g3ejQ8tkfgu8Brcu+te+xa7cnQKT+pH9UkODJYTevutrKJRLguqx3z/AMYgLNilFnh7W3jPY55230gHIAQ6R+oGWuQxa+MEmqxCgX+qdwVEpQf2LBj68vbOfy++BvCIEAUzCjtfHwqAsZ37dNuBTPCAFrUfgHINLFG25c4gq4FbgLZg6/6d//ve7NhJWHRpDE19kE5EbtVCQHlfpwKThx0qCYvp8/6KC0sWwUR71Twfgc64/DMRDkEZ7ncA877LASw/DniCO+Vhmm4Bo5CeKlJeugz3+27l87DRvyT3H+iE7OBwjXfl+YIC1EFQdyiUQHzkdoWmrtdda6z4NZYfmVZvu+5111MeAZkNRcFlYGsA15O4UeTA126ai76za+b/MOMQYLbtOpixotZaOKwJs5G0girDewLapzTT7IA/Q+9yOakPfyMBmzS0OjH5vj5j9HOiqZKaq9bImQBLNlI+6yy5OrkV3z/k6ZUYecAWqhI7z1Q1K/qVqkCRhefS82FNLTCAi6BtWwWTvF+b7a/pludHcPlZFOgufecRjwXqMmZoyJOdWHmJ/hOEG5xg7JBhkAUTIjwYH6GiMkkHAwfEZD5Q3dDvaqz2imb4tv1yXPXUNHmfXfYUQzpOpVNfc01wu27c0QI5M1Ebk6EMZ8tQDDjXXvIAvf83I/NHBt/genJuZe1CHUajfeeNNibqqNMXwOrKjbGnLWJSwgK5j6ahmvm29JET8RJ6UibLrtk01qmXEN9sv3vvPdtDCdVFnbFVdcnYNwZaLKkJ1ioPQg7phM85GP3LaiY4ok10Uu0Au9XZbK4BnNpH8Q/HRWxKqNn9OThsGr/u7w35gg4uGPiPRi7TXtVqn1ZF30wvWzn/pEJ3GSUTdUzx5qWe5Xk3+1gdQz6j/DyXVWOj0QGcQcPjuJnRTRZJXZLxOxU8jZZtvHFrlk1dSeTzjh+PTeHlnXZ48PKbgRSC2si/59Vtr4UB3cXNeA+wes23XSOZGGqZThaz6nPi/G+oK05+iTkxXJkBh+64qJulXIUeuvv0EZ/pItFGAkUDnpxBNKeGOv9GDeEcbrbbfdUmOpyAx62Q8EB7wG+c2UIPNGaebaa6slkxAUjckj66cWpkaGcIJtSbRB0GOfFRkka8oJtZ0S2PdneZY1GLzO7nz/+ECdbs4e4JRG2UQp5i/18/crlSJBhGHRh33py2WkX/KSFxej+93v2nd2Vr7OSZFOXD6lrlIoy2fW4IEqZykRNJmHxnQ7uq5/ul6ZMAeyVQInGbD9JiBxBgmDtJYuqHrVei9OTRYp6O1Zr22b2ukl2yRUgZxVQQRyYweDAsNai+m+xl4c6mZDA9zPazu0jwUzPVlHFst2ZFbuJKloHTGiezpYnElsFQSF0hInRkmONq6ADMFKOyPIWkDYHQsr1OjA7RLoej044itszTcysISNekpUp9Rdff0nId7p3USIFUhqHWJ/ZKSuU5kG4UttdKeddqxWFVnyPoF19cO/5z3vi514eLVXCkzVQV+Xuilnv8er94rD3jKZ6fuq1grdcz+DfNcJ0kTMm7LS0T/e5cokQsoX2pOe/syn3aeP8w/XXjd71ateGZX9V3dKngNQbLJ/6AzLqw9vw1XqGvO1uWElxjzHrkl4eRBD5QZ8WD/pYAfqbBhhhcLBLRKIB7Qsou9+x7B6Q2BZYw2N981oBemREhutHFdEYUXGdFLUNECQepjUzRyUJ6XA/9OzzpjtnH6inXd5einxqA3M+clyprLM8qZtdMpJdrQ/ZmXO1Tf9xCTo4E3akc4L4Y8oc9RS57C2/N49RCHS88rZ6PlUV8RC7D62+wq+AyW1kHRLwGlDaZjTcNmGc8dmtow+j2H3GllvEwu6d6yiqAnSEwWPbLthPfJv3Xsnqrp/HeC0JuT6CnLMv8F2svrlAqPfkRoXOBS9/iFhuFErEm2WUaO/GmPmdzg2Bo5qyMIMuhnMd9W1WYc/hRX7i2iScsZbpaRwg968CHMYJn9WatuHH35E1uK+fO2Sur9HP/oRgW63r3YZLEDR6u8iIXlDMmIH1mBptZIxOo8B5kTJrJ0bB/WztMVsnMNqDc8P23D17Cm1EqjHBulXdX36E9fKdduL1s/vWwt7b5WwLX0OaNtnC/rUbeah9kGfB8lFNSaf7/6bTdmiGYMI1pFujyJ0nsCL1dIQR3JO4MHlA2MuXrykZBKt9wEHHBDHdF4mHT2k4NYK6PK/Fhjpf0/HqgLD/o9pP0/B3wiEGdkWjIAcKcN0gGNdZIkMN6OOKHPTjZR0ls3IsM3CzHxiiCAbVcZgnB2dZplCMTnTNiKg4ig50lNPOWm2f8YjPir9wW8Kk9LkDa8HZioRqNb6lRxlsiuZive5LvuBE1g3Bo1gvDNwfvaDtSvmtD0WR4pJ+4hHbFt1NegKkXHkM3Nj1dA665qy7QpoGyarIs4UbXYAjR2ffZ33c+3OHedwp2Aw563Gk03nwx4x7/Wob34jgZ82mHZQJZeYF4bnUDHrmn9nt9U7aZ5t7FL3fHcgPDIdQaN9hyiFVNN9zB28PTCaywRn/Kw18XepCuX52Hcl0JC91TXiZkkPKFYW7ZyxkdXyUnug+4YHIlfPX1KRdWDvq50nAarywVyQNiVOA9osxCV128EIxnPhYBFDEQOx4G8Lo1pgAy2whgI/IjDq6sao1Ri3rJEpOjJ9gfojt3l4IS5nJtg171jG+cC0/kCqfhC5RgjDi1/84jDyf5pyxw+js/u8svOcLdbvfvsfUCIND404wmGHfSnSju+oOdcHRtzEDNQqKWZdL0lCRrSeM/5SAiN+58Mf/lBdo/Vx1noftA53+4F5pLW3TxMJx/ca8s05fNe7333fccf9ILDEhRU5vOe976wRVbKSYt3lhyzygA2aeMCRtuBzH+C/HYjsw4v5qwYzGHLTJh6bqOS/JtjB5iHq7Og7uASk6zOzIWDcQ3eTMcCK1DLC4WpbcKC9z1mBBT7z2f/Nhr+im9sfve3slS9/+exHP07PaoQaXv7yV7QqSP6Ug5wMzdj0/aWu785npHM3WAX6nv3cZqtqnJOzGlnrCCxquRcc2qpjOEj1UEyJ0QvY00I4F8ZawCEaK8hXz2D+XU4nD9ZB7nFIDbEvrNu2Nux8j+JY9/EzDcnMX89AFZq121CZeaEyYhG3tRRwyI71kSLaUCRyKET8417VpDDdUMex7ESNPUR3xWkzdqBVgUMctX9jusn6BkPzoosvjK7p8dXETX1J3WK3tFC8853vC5x7RggLW4Y4tmVJr6lrqh86iL9Ls3wZiahVEd8Q1aujdv02qkExNjIeBpiRw/AFUdP2RWRAkGEAGEI9zJ45pviaqb/LZv339YG4PGuMRmtWQ7HzKjJKUAXCESBudfuuizZBzb5lZFsMoHU6x5D3+cy0MJByZBCLlrsj97ZiJotcmB66X8922DFCIsly7f8zs7cPTaQvGFohAVjNsa3wb8o4e1vWq8769B9tEEfw1wHwINAN9MgvOMuMDaOmBs2pCyIWL14c2Hy7wJaPLsKWdpa+n3minH9fc03P70RMEsisFYLgYREW93yf99znFCJgLcoB537c84AZu164dGnOIggirYnyrakRf65ZXdb5YfAoKKmdXXHFVaVXi3EseLv/GsYsrt5s6TqhTcSaO8vT+vQR7ux0GEbEpbJZk6OxR5038Oill15SWSmhEfOTP3jAh6vN5Z+jwHXF5Vel7vfLgpR9Fpj6niQLgtSepJMa6bR/unWlBeTZNe+/VqQGMXJdqzpgtxzdUSPGNkivPHREycL+9uwvS02aeA5VMPcJmanAqEoMKRlMz6X6rqvM1PfZ2em8Le62oSb3uZ7qAY9d1RLXAxm6BNbs7C5jjH3MkdbYuHwWQYuhDT6yfXYCcnX11b+vtsWNN86g7CArnqfM1fdXSS37uOOOne2ftdw+yJJg9/fXXFt1TOMSL40NJ+XHJuEJrJr1xwy/LKWCC4NeEmzwEshrgbkj9koZyj75VUo4L3zhC2uN/nO//dL3u22pLEEp2Y3PfLqH3X//+8fO3vSmNxTa6dmwXfYKoiJEzLNamEAutOd9xBrd8EfgtdR+B+x/H4bTXYnMKPHTztx779fWItITLCOfD1olRsmCd/+gHsQ+uHOOMZtjRC6V+ufgdFaJjddqScXcTXYztF+HsbfZwDZqVgru94bNWNMJcsMg3+ojM/A3NSXeDLVaQX+LLXok1qVhcq4baUA06f/9/MGlyPO2t725Nv+hB385xe1TEyC8uwwDWK0MTDlEhuxvM9K/N1DuserC7XmnJLMj3VErHYvc0ct8v2397lQnkf6rI45DLCP388ORDijKRvUe4Bavfs9WBxqO2kYfxndERmVEK4Kab66fg5hlxHmO1n8cDoGIwKll1nqShozMSwvJUKxiZAQ5Im3r6Rq0LRX8U1k06cDbK8vAlqZ7zBH/KlmgGobnyRCopyjm+x2RrIRYJGxSvdotsYbHPe6x1fv7iU98srLOx2bQNeafCBgs9PvUR63f+jlsDNGSxZsUW1SjtOBLfZJhhnLIVK2RQzHW8DeBTR1oawDVqIAmz9Qc27/cd08JQzhAnO0QPjAAuWD8ggjT81e1xUBgCTSxiMGaDKM9ykgwvm1c5kUkxp74WwPehn7UKTkiQQgE4KRTTith9AclegbLqQ294x3viHD2j2YPe/jDqs+u6/k9Xq2f/eQ/x94eznQ4lBRqa+rLFJARcIcqWSujqa4JC3Hxkg1Sr3pY/jykWlmWxBi5pjYoLaphzebFHab0N+9tH0NXQNS1ftkf+uwa3ZhELOKI/ZsNYLy6vID5e085Y1kqZ8uoa973qmvMef5jIDyaqAIdJQGExc0zkFkwhEVLPJwjKI1p6NWQPhx15KxHkSBlfNNitSPpWr/rkI1x6qWrnM+GQEBaBLL6m2lZn3jiiam1/bzq7ODPL33piNxLOAq5js46kyFWz3jzRwQpnu3aa69TKMQ1IU0y+IIGwxQWZ//qabXGVHjsdfteK49gzvOxr1wr3oREQGtIB8x/Kw4isC+bMTnPETiNlq6alzvV5wvCzHV66QLwWlg2si8HX4NOOPszWo3ct2c32vPcY6Nz9xYr1rQV9XQO+1lpDVpnnQ1qVrD9WoSnfBZb/ZnPfj7+5l8rsP1UWNAPycSYffZ54+zM6OOyHWsFwTg94gnrxqlCnNgSGr6ekVouOVD2RKlGRq5cBu3bOlC5Z8LJKmPdlNIE5MJ1IkKZcWqUZ0+XOWP29Kc/fY6wVeSu7Dc+aSCMI0P3HEvEZgpYfL2mptHn/qdnP/u+b33zm0VAcfhFpYhHO0Q5n3G0gArZjPDVaSz2yy5gDEP2YaNPaZ4IAWfuzOrvxbsHXu+hjuzK19wkY4mdtuqqdDi7Pgn+cR2V7ZByy/XA8dVPNNjbkNpoag5hnO0FF0S6K1GxestDUxc9Layuww47fPa29MoiBIjybXKviiriSCkjdVV0kDf+1hmW062MlDOV3s1neAuj67Hgw6nNQ7yJ4qv1o8XAkYscXmQLm9gGHNnnmFrRIskjA2hYaLy/A1tZCeMwMXTnHWlnrl4ld1dMPLW17mcdmVNlyfmeNSsjkAyUJq1niP04Biq7Dtme1+h91VelRnVt2gG8DycrU8Rm5IAZJVmC9/LskBFsQNH1hhsuqfv9y18zLzXOnINVt7gsGe7JmSNrKr0JC0YbPSwanBdccGHBwIvTDsFlyFopKtkfPcUlE0QStNlP+lGRIKo9JwafIXDo1cZl3USpOVj7hmMwo9QaykCWjaKO65WFIyQwRpyidZd5ykh933sL3rTrgICrPJFDN+QJ3b/ftwYCjFFvGYHQyBLtthZfb83c4imAlPJ+Z//iV3Fu16Xda7PqYdO4Di770Ic+1NM3EgBV3c9dFCliyrIUQifHuTBFLZ/asWM54GbIL1MwIZ1X62N0lVF1D49EZwWv+RnXRnSA8o/JTGpsoxWi91fXk/SF2sf2JMO1kO1pfy4bu1K9wNFT7n3bIxbxAewfTnG5ZGaEFBir+69BTejWUjoDU2qFuTE97uBmQUVzJ+yfrG9QnQ1COpMVMnBIQveGjyE8LlWqiZXM0HcN23caVSrWRiE2zfvodWyCXz2TXDfnbuqRnuuzUgIjg2fcn/9+bOzJEUccWYQ5a9Zr090HQ4Kx2fQIPwiBJtWkPzvnEqIhy+JM7WN9jQy+ryEfUc8RzKm32nP2GyJXjzC7XznaIdDQWekgfnYmOQ9JWofJHswX54v8NBznIB1WVj4psPlaqT/RyZ46DqreSX2JrGvs7w8yEhM0X2zsPNcrgzwg9rHFRt/pqjBA+9qwt7GViRjwIwiS9vnpyfA//en/Dd9h+3renr1yxzmR43tdxs+5V0Lz1gZ5SXBkSPi/vexlRVT0/AW+kMj1UrffITwLSkn6yK3NqQk8nWGQP5RE3y14WwYLGj7++OPLiY5kTfAus/WCOvCF1ao1EeVkyO4Vw5oKVSUf2R+CyKVSg7yv5uTll0WT6mDbRAZu333fUVi8A0BC7YYYOzUKfTZVO2UIpgjIRhwKGmOixnBUAyKw0DaMAzRGq4l02lmEWJQbtxEp/+s/dNGD0t2DgW9PpnJg9EgfNXvd618/uyjSVMXaC7SLaYr+7PrvuDNDeLNY1+ShOhxYuyKQ57/guVWzQYWvrDN7y+SMaobtCsq8I10AmZWDGv9XBqkdaX1pgm8HxDsyxnlYdSId5Wf1UI6mf5qj7lUfpgMwVInKWVXdYh7uGzWT8d6d9c+36Cz8nYZ5G85hEJoYg7RgbRvXH8hA9ZJmg4i0fYas1PdkdNbbQS8jl3/7Gc/ptkBu4zPUTzUu+zrIdsx01KRtY260EXm11Qsq5ChlEiZxgHl79FkynOyHPwR2oW6kPgLWlLUyOtja1kIdEzFADWmZCEV3nXjUHe8LJNkKTe5FOYJj1W7QTrzrrl//+tfC7DuzIGX7mZD1c3Z7dsF2FVXGCSyVrKrOQGAkcLWc5Jaqw3XPq3F9RS7IwVTfFhQMw2yf6uXzTCktaTAvEkrBjO3kRiDkZ8YZGeOqxvcrs43Dvi61SfMsl09DPudlfWmIfuaznyl5OfuGke/B370X7esqSwyn6t/5XpXICyXx785iG+lZsdSUXOfrQuTYaacdYiSjcRujIBixFvqyqSr5nZbpawSDkxiklm4FuLZIc64TC5PdYHDHXhR4IKDcfUcCwvAf5p3WfDbt654ZO4LVzdheFITKupEShZj5nsyT8cTapRgkS8HwRWqSUXKkf70n/aX5TMRGvZP6dt1T1wyzxpMzrQB5QtbGeR5nxAI0p6DRH1nhlSk/fPKTB9bIR5Clto7Dv/Sl+j4HyelaT5kie8U+tWIc0f3VCmXRR4kTIItZJZwQTuniiy+KuAmd6o3r/mRvasHekx1sB5Pe0gS0CELOoL3jGq3P6HkuxGnKHi3yPRlYPtCQ4QzHM9EC0ujEJEIzSZf2fu2vc6o9GKN5ID5XXdc90j//7yBHpAyJ4FirlTLikj1eJfvoGc94WjmriwPv/yLi8aQVN81zZNtvj3Oynso5z37282bPee6/zl772r3qPH7qU58O2euvsxdlBKbAifj84sDc+BHaGbWwkAvU04nZi1z0/bTI0NWFfP3qV+fPtMmof/4obTkcYzNwZ0VYMjSFShJpQ+fzaU97WgXzyHNKXaenLcdwcoELWyhRkzh6Bhyroe6Su6fm8yixlf3IGVhqoygbVeaUAw7CXT7R1LnnnhfliL1mu+/+khjY22rjD/montMG4uqGdS8X1NCUnrDuGxsG1/cZv/EwBjuunA0CjdFViSA9NI3JVDF++9vzqsVgOCokkv/6r4+nX+c3s//4jzfNtt1muzl8uov3JhaAkVpuq2carlmKN789/4KMOjomDvjRNWh2zUQmDelM+rSa5W2DQm6njPT/caScJ4G0htK6V3NkfcHJJ4c6rnfhoeyMPHWIPJja9ImgGR2RjM3ksIj+Ri3C973PiBIbwu31/Nv6Z/eLDkPt7+GQx3oPhilH2uze+TamIolknTg9BpCT1Hbk2Q2SQg9SR3TK6Cyj6rK2mK5+r7PhyOklq0H6EIyJ0mUVHAsjwphapuEo9Kh6+VkCB16YcjWlJdm6KM9gY3sNfIu88ID0v1knL5FuE0nmAy8GHbQL1rNuaj9gWwolYLhzz/tNBTBq5i0IvlTV/agcQT9uDrGFoUsDTw7EbZXhcfpk2jS9j3YNUSeoDzMVuW3ttdZJ3/Vm9buY55yxVhqHbNRIe+9HfSc/M5CbDoy6Nuq6fH043crmIQgRFSFIcu0fk/Emc3SoIUaysTe96d+Leay3kjMB0c4FT+J+bRbDO9S+7BBxeFzohMEPAhxZwsf/+yNZm8dUwECwQlDY82C7Ri+jH8SRiiOn5z5KCq4fZ4HO8WDWy8j9DvKg/WvvONt33yW7GXOB65TU+/W5mf+3NVInHeUILVVXpQZvX8pSOIyVo2GrH5kjcqY995pYVTKGwvwhg9iesoNd62016AQPJ+rvYQ/6Wu7JOnDIkAq/AyUS/Bmg8aEPfzRBzsW1J9X0BPDHH39i/cwQnRFoCABdz6oZOccuUvWyf9XFBRrrZjSkOcp/CAEHc10L1rYJGO0V58fvuNdlCx3p7NHet54DkmZP+s/ER5kGetc6yMDjSEcJadireds0D+WyBQJpzr8kX7NHlHm8tzqsz+TYBan+gOYxmfc/4IOtVpS1sXfVOgVcW225ReqYj8rv61VNYBb7tnjxkh5ll/XCR6i9nvNEVxoBTctLwdcJfnv03WUFqz8zimnGq8kqvxZNalkvUtsNCTa0VmHtCqKbx7NMTcx5xMMfOfv2t79VAeDVGXX25CfvWLKCT0qvL+fsc76RTHed1KX5CZNl8EM+/ZnPVHnzVa98RckIOpfWA3ystANBk6mCnTlyJRbkSIFcBBk2nGJa0F366BJxYmGheB944CdmS1Knob7vw8fD8LeL9hrQVRsEuohTpDwdumFMGIRBWqroMJDBLIzgu8MGNVLK594JTsihueSSC6sIPN7bTYogOFJ1tI2WdB9kT9vougdMXuRhwRmyy6+4NJHsZsmkb5p94n8+EePzh9mnPvnJaFk+qJz0wL//8lckg0lQbSIcDbszoNRaIPavz1+piwzjVRDplJnXRTEJk2MdxWhfuzPOx4EYDoSTUVMasxNtZO9pnfztvwfJqt9nGtEV5zlf+5yfcTk+e1xXGY+plrpMBgzI/uagLbBVNp66tMOCeq7+MWrZfhfbsK4jB6iomqorNQAAIABJREFU9bkGCAKCgWDHejtAJPi+k1YVWfYLX/CCMhJqpNXWU7WEDGdOBicr9XkMBiPofQeT9exzfja7LVHqRhk3JerjMNbLJi/1lUTK9ssKK4YQs1JDzDenH1TU7h6shbml9pPSw/HpOzv88K8UHOmhLVpl9aK4PyWHyV5xMFx3K6r8uQSuGcXlTBaJRJwD7z3/lEO8VX5PtCnL4oS9KjINPKzv1706eLJTmQNHWkFQ9Rp2/UpmpAY7+jEbTmtYfQgHjOBUgKI5fYUYL/d+7R9zjxUYNpN6h+23LzjqfzIc2T07H9SdhsRfwZblR7tWL4Kby/4qXMxaxfFwwLL3/ff/wOwfn/aPdb7/lLqja7MHEGa0OTFUBBNGr+mAuJQlBhxaWV/W7orU984PmkUjlSNQphnKMBzCgxIML5tWEMFoO8+/9fct6NKmyH1g7squ5up2BYfeGrtwcUF6D4zQCkjZ+/qZ6ggoLylAaT1hn8Fx3Zln1vM7G642s7X+V0GB6+h1GtmobM3/+lzTRm5loLN/cfbsx6f+pMLsM0KOQkzZZttH1EBu9fMeuM35rFiypXdnLVdK//YWm29ZmZgXJ6vzgDDBeuuvO7sqBCI607Kk2jdqyPrCiWBkH7gOdq4D/y7ljCxZ7dg9EDmpdYvj6ix7+lMx1FBz6jUfXQbdjtgTiyrIMy95guq9l7X2gh5eE8eBMKa8pk1ktC596EMfnn01vaN0bbVI0RveOEiU7FvyIzlC5rOeggyjyNzHnQmanT1B1bci2/eVrxyRuvDjct9LVzkOGkXlSCC2StAddl1wy4E5I7JPwd6PA7PTxGZrnBvkQiULQSfSkZ83pvMD739/2R5rrMvg29/5ThSSDkm75C4TY/sfSvmI7/CzzrWAwYvdEtywEcTyEc88azyRH0VY4qCIOfz7m940W+pBG6x/n4fbY4ZkZ+nFyw3AoF8ZlYe9X7NnZTrEfYsNNtXtCh7N73jgLe/XVOpRQxkF7gEzqlctLGYPxR/vPcYDIR2skMhO5I+sItItndlsHtCZwc9u5CEPeejcddTd5sVw/fzsn+WwLlODn79/zDGlTUvA+Kc/PWv23e9+v+7naYlwQC+gJkXrphHpW+1ItclGYL4xUaWzVWe8fOkEBY1Ies5pZi0G8UNW4TUcaUG1+gxjDOneWjMGrZRHpjYYjmzUM21qNadRY2ZEq/m+DkX34XZm058x6jyd+Q16/TwKUM4+1zRqfguJSwOWd01Yo6PnUz0Xk9jzkTHKMkTJnMBaabjXuoI9+ahHPab2zc9SP/Iz5gsyVpi+IBFOEYGG43StsldsXwEF2FmdTpsDw/6Yxzyu1mapGIRiBlKFck/gb5k9VmOcyp1xkg6zfeqwXJNa7Xe+/b1MTPk281dZFIh43TAcHRyEFZmlGg/K/I7pMX5wiA2UlXxN4Ohg3pRo+eEPe3BlDpdmgK96KRnKm29K/TfGgaF0Dw6S+7k+tRt9uPYtZ6iWemW0Z90DCEwwNITTGxqbCHT53oAxHdJxrvyMLMg9Cy6v/n3G1yUofHAgJHKH1vPBiX6N7jr5pFNyD1vVnkPWYEBs1AoJp/LDIMlV+0O2c0+1yQzJGJW3vvUtJbb++0TsRhQymOp53fOXzAlTcyoHVIZbTnm+r7YMOLGRyfh65tSkkLCsfUG0JRYQ1CLrwgghcFi7OfjUeYrtKUM+kekwwDlzMNuAw/08jVbazr+KgSUOoqXC9++fyRuuAyrx5zw/etB64iEIzrGg7rYYbaSpVfIsrTFUoT43t3VHfk6EzNE2wtbnrNuagiSpC6cNBdv4Bxk6/asM/t4iDkNLFZgRa5uEnfJSwbpZaPvEa7PNNi2ngtux0UZN4Ls6P2ufQUV8BhibPZPZ4hMIOkC4nWl2stLnfB6mtV/ulxYyAjWezciEBow7HOn9asB7c6u8hh1YiJwJQHr+60AGWqjF1wpFmFj7RS7MM7Gf2SaO8ezY2y988eBk5g+rWZ9KQJi5kKctkpVCTbwvRMV7Up1alACtNIGz/s7c+6M7fO4vTw859APFqoWKmYpkr7A32o7wE4jqXB4ehXXeffcX1zm2Xo06nVdtWdoJvafy4+8TCP8he8mZe81r9irJwcdlnB1fJRCFIpGfVd+WZZoYts8++1RNlF0GE7vGSiCsN5RhGrBuLStozb39IHKB733v++YzUmvNWNvQNc0lbyBq+OhH9g9javOGfha0q4DAOvXX7tA/P7LWAbcu3JA+GIOyD2Co2jn8/TsdEYHmRNgFESeK83miPkbQTuh+nVkLVueBjlrZgBUZ8ZNPObEo+js9eadEDNfPTs6UBWL3IrwvfOHQ+r0PHLB/ZRO332HsVw8QLvWRqd9yjp07ak+1Udux6j3zWghvjU05NvGol/q5Ef0VdK43NEbT9wfry8+QoVPUx/7qHst5htyAeztzG2TDhpbHwRhQz/x1zcsDjmtryDtCD2X8e+rE6H/0rGw+fyuiew0tX5koliFyhV7LjSOn5YC1TvLv6v4ekggSfOUFNulN2AzK32eD2piIB6Cvmv+YPYXqf9ddhClQ7UOjn0g7m2afqXO7bu0qDMCGyRAFADfmd637qglAOA6QGFGO76Yf7fvHHFcC+6JXMx53jFzgrYEGN9k4vZhxlCbDCLSQntw3+rzA7sQIPixZsrjIB+opDuqKeRZqH+tn34DnBmMXtCNwkGk5UEvCcGWcsQEZbVnekFFznRybeqN7aRJfoubcr+e4Rsg09qvnIrtuQhNFpJBykHu0NiTAuD4OXFvatjG6zgblHKxdn2MwtFmmgomak1gOqY3qcFS1bypChEC0chEyyBve8PrZi2KMfp8ghLEBR68VB9RZYhxBnKmiy1/j0HxxIDOiSXBdB29NdOIchh3w/I877oeFOsgKOPBClYoo532jGFQZ4bxqDDKR92c0PU91SK03C6cT1dlXU08tzrxM5KIHJJgbI9YqSIlDwBK+6+4gKBFHqHWPVrdsDSPcmtXAhexPIyBxNZw1SmPW238PZyVIkwURJ18m+92ep3v7uYz7QrL5x6ftUm16+p1XX+0Bs4uTJZPJk8mUE81ns1PmkJI0Ne9Sr+0DQ8yRtMjSFi9eXNfPSVj/nkfaXQpdo2wuwEKESUDNKS8X8RPZa/eCQyHaCY7zPoy8puL62lwgNA+ft22eb4kp+cJ8DfGLnrXExfsUcSrPzzNYK9fvGn6ZINp1QrJAvFAZtVH23Vo6T7K/npaScktsbZGXUkMVWCEPCTzdnxFm7kkXxtHf+na1sK237vqzpz39acmEf1+ti0o+1tL5hOJRIBK0cKCXpI5+TcpJ/MEaqWnKPAXvyHFY1uwPlMS97Pef/1k10ne+853pjd6i1p8TdZ2f+uT/1N6EfAoEJTquT1kCEVZytDAxmvdt95Vc5FIbLt6wXYbFnjytv/2yKRnP/uddZ299y5sLmuqJ751ZOrHzkwfms7fukeqsaGFNz7/V/wZTt5h9+UgO9faQTRbFyVmwO6vHknbsMrPLL72kCtAEATg7hseBHxFfZZTZKHcENrEojOb6661fjtLXDZ0dxfrDI0rsYLw84vzbBL8HBQznV5lkQbbDWbWznHtNGWkDPv2jY4Mv3MC+ttCRLoR29YGJmEX91oIDZNiaMt/rNV7WSTZj8oXxUV0/mjeQY4B0Rdf5/b+HlmsmbKEL7XSHNKL350gdXNfNqY1D4nvWdRBnQLt+5tYIkaudOGigltWjo3rVVVeWrujGGSKw9dYPq/oqGS5B2Omnn17vS5VE1JhcfLZk8ca1ScG/DJbnU8zeEEq6hzazbfPs1AUXh9XL2Jxx5hk1+cRhbcdEQu32Gmx+auqfP/jBcSEonT2zOg973KNLls7hR2pQ86V2hKkL1iagTbvTy+caxqumecwxx84WB062tt/ONIqtttw6BnP5ytAelWHDDuRVV11RTGLGz3rXXhRQpu7M2FdLQb5eGYR6aPXg3lu1l4KIE/m69hFA+nxwaSME3XZk3SkHzQt8ZNWQkkLauPB3F1c0/cQnPr4gTQHDEyKOYF7sW9/6rjqnsuYxtcnmHJniVLCo/eWlZWCrtIx87GMfL0dAVIPBb3KWySo3zyj9rBpSDPUZvZsDZen93gFtOZ6c8xY0CEkt98+wuYYfpmFeYEZYnnHzOWZ7DpEPQQgbgbneQ8qb5FZjtrJvliSzUcop3gUWbpUH8pn5ubHflWf8rOe7dlokIFrW0rNhpPWfmhWqxq7uvUbkQmXcox3HAwcDI+5Q5AKNQxX+TEIyjo1T+H2MszrxOmGDyjJBfMf+4IfVGwvKVEMjZn/rrZFCjIE/9rhjCupdLdmkM0kvFgyqhcUeuOTSi2qowoZRghoOD78Ak7TIm3GG1ReqnFHs3/lefM9u2IySsEywV9NYSgAuD/z/cKTFn5iSG7+/MOAXdAjeC0JPUOx6h8qRs0igwu/rZS/Wcp4TlaAKDJLFXR2Y17OQgS6TzNg4SzV3ilgCSC067kt2XY41z0ZQDrHxPAWkBRPnOXKEiEEnnnhyGLrfzDizrWt/CzSOP/6E+ryNMrbs4ksuKtU9jg+X54UveOHsFa98ZSVymyZw00Z3/4ydo8lu/Jp9d2h6mTdMadJZQgL8WsadQdJet/cborz01PzsNXVtHzxgv+J6nBxRH79r/6mBagFjK2uPTwHlyNytHRstkCZjOFcjLV/iNE2LDlqzgW7IRnj729+SKH/H2qAWwoOXKQ6vLDL3xqPFYhTdRXIiHBGWjMRrZK2lsjFtAIbYe4nKC7ePh8VJwK6zgMTt1Q5lmYxGhPbLQHox3ickvQev7LTTDrNNNwrDLw7I7M7fpIi/7baPrGtWx0MsITP3sn97WUVyGJyy71qciaRQf1EvmpxlO7d2SNUA77qnNRqLWrB4vr4Q5u0stKn1XgwJI1Xw2USMaaizCT6Mq8PSKjNZy2l2ZxvBkRUwZPMkrIZqOsL38nvj8zyDcX0LYd2RJftZzpFBcg02LkcEKi1Dp184h9aGN14K7KsmdVUyApD7+RlbtlEc6WMf+4T8+9fVEyqSG20u3su/V84zdW/6ArH5ep/YE0QQbqjrBWVdkufssKkZO9giXpln15vWKOLYKRm/dMTXjgwke2ETMXKdj3nsdrN/+dd/yXVdXe8lyPvJT08vZiS4x0HUgybiH9EqI0jejZbr+nRO8z6XBMpFKvCcsZGvS30SKWfMxAT/q3dyeBxH1bSzf0X16iWYx6TeZLH6AWXWyEoMjJf7qCwi+9WebVGIFhr3ntaFelRnj93QvyhohV7uM392TpU0toggxfWBTjdLvWi1oACvec0+tYao/8Mh+f3aDwPvy2Z1f7bhlbmud77zbRmi/C+VcYFLObAbM8jACDxnWm3SMO4K8mKA1BhrL+f3q346td2UY819caajVl1QXAwj6c4t47C1obH2K2cdOCmB0/pBNohKMNCIaViQAmS9kXpIBXAQqQGFM/o+X/nPAISRIV2X3ldN9tXeMJFGlBBkybfeHoQla6zOVb2XcZgFm2snyR5UW0Qmcsbcx3LJNk2qEQTV9/M8DGjwTGj5kkw12FnGRUj/j2lNAu9eHmIcu/m7BDunnHpKPW98AJ/9wIgRFLM7Dlq7Ff3Wqh3GubofBBwBjCy1920cUCnqNIlzIEYcu++7FmQXr7EGUIsK5KcYfJz9DsrzfBZkqQszW+/hZ+1hpCL7w96fmyMcmHwMs7D/kIH+GOfntVF6i2/JHsHGxR0wFEJGesIJpySAXa1bcvJ+nudQbkLKEUBj+vMFEgEBlZomx3bgpz9dNVDtPtoVd4ivwZa9OGeSkhn7BNExNFzJ0b289KUvLQY1e7V2BFsEcIJKCcRTnvyUKkcddvihCYYz3zX7HBLzsY99rHwBNId9QXxyvj/84Y8kMD+2nDF9XnsF8gRVYf+UO8oLTOW19gnzLxn4/5ORjszIAQFJcV4yvwMP/Fii2a3r4DJKY/RUpb8xdF5aGzp70CM2lG3U+nIA4lTHhqjPqKgQ/NkShAXFTGLQddGxBEYm3RIc/MILf9NwcA4cwXoRI43Pzpj+XM7gRz/6cemjPvFxjy/ZL8QTLw9WVnpR0vxDIihNfuqNYT6uEiUUlPrKmjlSl9TkwTkopK6jIvFJLrD6TREZehGHoxrRytDF9d+jTrrQkd5eGWAMpzl81HGmSTvVi5dgBNxYRiObQaYuMKn6UakbYblODn2KjsaBWPhQx+eNLKQNUrdhDHILw1f1mURaNhajZsMwAkMdiCN1sFtp6uaOttdYVOLvPkPmUK0excA1x7FJNpzVhqGre3/vdcWVl9U9iOxE+eUYtQXEYd6UveR31n/QBkEPLiiyGagba9zvXBgoE8zKGb/tbe8uwtg6kU5DCjAEe7NNt8jBXjy7K47+7LPPSf3p6pImRC4iY7hinj1Dq5binkWa4F2qK8cce0xljYIg+4oRuYzcZBi/AjvQ9eMjUbZkw/XLcNgX4FjzS/3eeWkoR1rbMk6Zkgvo/xnpSZOtM7BqSe61nGwM6hgTaF1E/yPQajGHznYZHM94xQwHcE1XXn1ltS5hF+qBlVWDzK6/4eaCeI2T+2jkztR0Bb6j3Wbu0NcebQnAZoPePTvofz9dEzLsP9dEbAPchbm7ySZLUr8LBB1DusIKcUQhd92bg3H3bTcXGUntavVkdyvEgMtaBE+MTOsqT0S8rCfjJop3TIrIlT91JmJAZY8cmYAVUcnaCLZLTDzPScDmeQ80pwOPeWay/VJoRvW4N7FRC5U2h5VSG+VsOERCGuBY/coJTeYy21GG6l7XoaXafa1IMOVg9LXmmtdOG5Tr0LPpbK8RMtl3Q1SRrZiURciChizncMB+H6rgRlLhXrS6eIarZr8gqpHFXBSZybXCbB3PXN0Yp4ODb11bSluNXoy63ECr2DlZ4qi/c1aQkQqMp6hp1PSGXOF9+d6w5+VwJ4c8HDebDC4fJSuOXb+yQLK4BcXQDfScM2WPfOOoo4poCB5H5rz22j9WT2fb4VuzJx9aNoXEnuCVU/NqkZhGDwd83kHrfRWkHHHEEWUHnvGMZxS0unyeY6tAYdg/qpwt8iklq18kSCOpuPvuuwdqp2R3ca2vRMnEL5m9eip79p7ULu0LPIyLLrq4JszgBRwcotE3j/pKnt06s9fv/foSIJGNqssKst2L9Xd+2Rrwrr50+3UuOUk5RXI3xgEuteGSxRW7jh+oLBOhRT1Ez17eEGNrl6fuGEbTB8q4I8wMspEPZHCHUZ9n7g66udropGIS8khPfZkg0iqEN5usHCmDUpD+PMxJCBkEhcmr3wp8YzizAzZ6TQ1edh2gXFm0hWbcQQjdYtJY/UnJaC5Nf56m8xft/rKKJu+Z6ktVl+h09G+c5Fgbfw9t085Xm3jkemuDLkCCx1SZhY5OtHWPDLhUT5Lppy5o07k+WepgwlUWCxCdhm/31JxlEmH9cW4SzLimweAbjnQclrF5y3nSis3/rIdDJ1NkNFqEOqzPGFibWM3Cmvo51+Rzve5MXy6JLRtSlH1njLHrXjXIgJeaEQjLtB2EI1kpI6IFxUEEsYFbZGgmaAh61JL8N6OBfcsYy3REtmBocmGm/TiMhBi+efS3Zl/7+jcqmn9EaqBrx6kzptAJUM+5ySzR5x1+DtvmL7Wa6htsxSH1HV+jywqaMuFGFq6+MmpF6lxXxhGaEiMiJnatn7YCqZrLKUNZrWouP0oGcm3YuBybVppNE71ap+OPP7EZfgn2/pzA0hlCqlopgUNnHK1IM4zaCGrsRUbKfa2cHk8BJsfTeqX3ls4o+bRdn/lPycSuq2yPAXlfBLvPSA8uIQT21N5pIk0jPk3YAdveNHtwSHj77vvurskFktS7qY6trq1OtGTJ4vr35ZelfzNnc/0NN5mtmMj9lmSs3mPpkF8qY6q17ZpRBc45o/4WhNg36+R8cg6CCKUEjk3w8QCBy/Q7Q/fV/QvYu6zS0LEgtKDNgjfbGI/2OT9j1i07tLwOgzgCrRAE2wUTVG4czwetB7VqeNL6+RwkKw6LwRzDuxFqsMitHBIbRz50ru0vAYE/NI61VvwsE0S0VlF9qkEFWQcGFgnprOg5gy+tpWARVPuXv9xZSnCLVunWwHWCkIBArVeJNUyw+Ji2InloRaK+9653disPEljNgZ3IhspF9gvipNcQTHGWfM/PjilTnqugknPwDGTc9gHHby0FtmwzZSJ21Xnx+QOxgzJ84n8+OfvFub+qwObBW28eyPr64gbs/bo9qwf5gsj3qdnrrHhgyDrW3YvNq1JVSnCSqoUtPDJ+14IBDIbVM66mLOgl9mCdnHGDwAnh+z6Sl+D4CxkxqMa86aabVD+p4KYDr6XLTtDzlQR43hAYiNLrXvuaCnA+/ZnP1ed++MMHVMmEI0VG8pn8hjWwF2WlHGkJn+Q8KduM8qRebsFfJVJVI52yLg+rxzN1BOhVYtrFbLx79s53vLUabREUGJjBNhxFaU7077M0kK7DVQ+8Nt2k9wmGzPv7mBKOryS1e8y8x3BSoziPAfjRj6aHKzXTV+/xytqo1D9sCuQDhh1zjwC/w8Kg/+QnZ9Q9mFbBcbiX733v+zl4twRO+Fw5L6y9pUuur9mwpdTQ2O3cvbSj6pS1Yd+GwCsCkM1WpNWGdsxibafWpAwvm5Vw/YiiHVZRrsy+65SBMVeWAZI8a6ibM/XyPcFL1aQXRHlz0DJGX/1cM/u8hgA2JzmyeUSRVoWJkoqpOfkM9Q/O1Z+arZl7aNLMP5STU0v0njUWKhKNslCwqrV8YGTPZP/QC/Xcn2ZSw2abbTK1AWidkan2Iee0e5jxrNACxsY0FmSC4eA5EiOO7CsjuLBlBWGe1aO267qUWpVHgeEn+oRMbLnV5omGH15sXY7SPekvpJDDOFhfh0ZAyIiBkayl7JnsnAx4u+22rYCCZBgoibH2u+AoGa5RaIUWZP/2s9Wo3+tNcABMeFEFekTEKeIEyss1WM9uO2rN0+YQtKCESgqn1F/7hzqU1UYRZKDmlYJWC6JcrhzhVcmkyccRFjnyyG/U1x+RmvAbXr/PnAzayC7GGR6KTIIYtb13v3PfatMx1uwvOestgXd3ybEtt7x2mrRp5boKmUiGtgKiTYIkBKTSkmVIcm2yIQxKzx90z2ncY/Si2m7OFad2yy23VWmGYg+yWvUE5zNkU+00hwPIGkw90ZxoZUwVAEwwdR01Ah5dEvByf3+WHeVZCZzxJNilO7TGJOADTcqawcn3pcXNWsmU/U1L3Gc4B9aeStcfsw+XCwS4StqluhTiDHamelugYgH3FsmIaDd//vMH1fkirmBdBIL24dFRiPv+99Oz/uhHlSEWNEoO1A3v/4DVa/8v4rjjbF3H7Qli/xBm9hbpR3b+ul/ajNhpelA+fxkIhjF7QSkEZY4TVrszQr3NPjLAvM58st57I2bAYQncq8Q2KXJBv4YtcF0geKiSAJrjEHxaW/+GAo2zVNnxtAedLQxobUCnRoXMYPonPP6xNQZtqIYppa23Ls1u6mURkUgAXtdqPCd5yWpLajEW14PgqLyASXvEkV+c7b/fx5PpGse3UgXW2lLcA7v1H//x70VEw2An/HL22WeXjdkkjhTfwXNbP0GugQZm1kKwLk3Gak/R3NWJsGbKPXvtuUda5A6PvsD3QzL673Atfl5Z77+mRKS0ILATYJkXK+hXR21zjySbpINjneyaOj+GeWWkNqXX3Oy86b99jcHx/WvDqFs9I6q+8qXDqo6AXVfZTQyHFwjKRhhtDj2vsQUIhmgyJzmvgRnnmcimiTDNOOQ0HW4X3JqmDd1QLKHR+MdkD7s97wVpb9k8Tv1tpbErutCn5VUzTCe4cjTrUojRxnBOhrAy3rdmpNNNN/559qo99gwjdHHBia7LZ/dq5Q+fWTDq5Eynrxewy/FPGWn/QhvY/tnWuewsdYjFt7EQIVKK4eeaMdhCFMVgz/dFWGBS46SQahAK/I2gw1Ar2hfMW4esDVE/s16/0RLT2fD8TNhWRelpNoypZwT24GyQgarhOBthtGHYIGUACnJMT28gFb29j47xRtxQO/A7Ijf7wB644He/LWehHeTMM84s444tjYWJdCTgYbSuuw5bb5X6fHJ+1V+aLMbnWBPX43dcI0P26c98oTb/DmHhloRYAgttMuBBzGPsPc9UrycpsiF8oNTgc9RMtFNcM0kBCr4WLVqtgrQfHH9cMovT6n6uuvL3sz32eFUc1LazM6Lz6f4wxjX5P/RhMt0NC3qAhnCUV0YwXVBhjxAY0at21ZXXlAQag3pTMjgGXhBZUG6yjILusNaFYRW0icF6f3GmxZ7O75SKziR2j+3q92Q5rp1coob0p4PAAnt/OTqvL3rxC3M2/5B60adqhiw401o7OxxerW3WU0uC73889aHSUs6acQ4coozBHuFU/b0kBCzXSOTEaLtlwoJdLkHF8jnT1QMeqT83gDDk/j0v++zetIkUqpEssWHfTNjJfsZfkCU5k8smUARdU3Cy72u/+l8y8KrsCaLn7FHXNYvxGQauryMYDcEQSNTyqWdekrJNO44oCsUoVzCDsFesaTKGAnl9u3dN8nEZeTZp+drnbBX2/yqQLNlnDDEnMM9nIMqQiUZr9dCFI6IuBf7VzuF5y7zsZ2cBg9N+R1QTmK4ZB+qErxYFIJyDpYJ4rZ3yhJ8ViFz/pxuqjclLIiKQxmxlJ4vNzSaAwmOe7rdU8znGqErn9K+xISUUEzsyRlUK0p0FCZByiqxM5ukznW/O0vtwntayBWzWquDYeggAnWfXokSBpNWEJKp0vaephZ188smzXXd9ep7nonLwm8WheUaeu/3xD3kGCKSInV5sF16Kz0Zyskdkrp7ZJ9Pj/53vfC/Z7GNKEUkG/bGP/Xc5LcMqBL/qmWzHFqm/Q2PMAUXoOHiWAAAXmklEQVT0YpsOPfTQCDZ8PbyNjVqNKH9cg++rw/9beDHWWyb6ve9+q0TzT4wW74cju3n00d8ure5tQzC00Nsl4AS725fOrNbEETBKGgQ6pUOcNeJI9XQvtXijjQctYfiFdggTVummRQMcASP2/Mg5vTpOCGThQ6uRN4dRxoT55EEgCIAoKkObNHWbhs9xZEekIboi8jhLFwPGEOH5LBE5A8b5ORi+7wI5OtnbN7/59dm73v2eFJtflOHO/1iGV3sOUgFsn+A0yGJEswgWiBqnnvrjkpjaOSLoJ6YHj8biv2UizO2T/mdda/5XWWnBvH+7LOP9hiLSnMe13JPz6gyx4S6GcmQu3V8b3VJ0ejBWOcAclKzdrXkQslSbFgwle18xJJe78rOlwZmCPrjE9TFGZaCz4Rdl8+qtFIWNgeT6LNvZtzrRvffeXc5qZLwMmpdDzpG6hoKWy3DfV1mqw+nl6wyBQcsi6m0euV2tsUDJMxksXkIaxxzz/WxgmqH3lLD8U57y5KpZu+ZdI1qtpuRZmmXJmft9742hq6G6r5Vii5mJgZ0CYzOCHJPDf3Jg1J+cfkYJ1O/81J3LILWK1mp1D9pPwCzec8UVklkns2+lJqzQO+pzGYTLE8X+KE3coKEzzzqzFFTMqqVQ5JAT3bcGDjHygdYU9b8liW4r2Mo+fVBY4a71hhsNQA5cbn/mWRvLtlI+2yG729fVrpK1/jlZ2aJE14w+/NLXRdjzyE0PjV8me1uGwiyqH412hGa4tkSd7x9z7HGl9PKUrMNuu70oWfqmGTLxutlRR32zGs2HetNoF0O0ULNC9gF9v2avV1dd1/YWoIHpnKFrrr06BmjNgjbtO3XM1VaPbm7O6u1hbrvP22KQwYMCJqxME0q8EaUf/XirRSO7xDsKBtZOFYZ9nonfqf7QKi1kJKKAsMQWuldyEPUWlnRqD0/QpX8LigSN16emJiuEhiAfIZHINB9Qk1866HYBNye4kSkgIsmuCd0LutTI7UfOY+ONNq79cfsd+kxXqtmhg0dgL4165V3J+KgoMdDrRED9qNQKoQOPSJ36+utvrj1PmMSYOX2hyhBnn31W3f/ikNmGHRyw6iDiMMKCrMyELvbr0pHAtFc9e9dLCWidOLseiwa16pqu4EPALoAEOUJt2AbnoBGQdlw3JHA97bQf1xl21gg/DFEN58rncJLrJYur4RIpmQiM1M+vTzBIY91+uPyKywqi52ytweJkslclkfryV79SsPWjHrVtfV4NXs91rZp7aJKUYIQ8ZLcuehUymT/qrM495q9r/sqXv5pWtu/WvRl3aBQme/X2t7+tnKja6YWpcz55px2DLF1dJSUDLSQg/iCAmZBkUoxyC1v/1NghUDCWeqMEi4p5DVVV9oFYEq+HSEkY+Jxdn/nMBNSPKslJe3S0M9lXyyYgUy+3zhypZ+IZepUjHRlLG/gpSgZ3ynTyvyq85jAiHqXBY/ae9+w7e3wYVPUGE25so2FXrpYoTUTKIC48GOVAcsBckA1bDjRf8zPzI9qaScvh6DkrEkY2isiZYzM7cZlll0of3L/X9IAXRT/3cYEWOhu6vgk02chUNfy35nDG3aFBQjj5lFNLp/GUTINBnvmvj34ssQBDpb+vYdmFGan7m8tKR9Y5Aoy6opZzKGhXRjptlnK6lZGWN53IPu1kwRvUfqwzIwmGGTUR2Qb1D2v4p2QQokj3dGOMgs0GQsNUdBjWTW8m52wzDoZfPz+tCFGJioGQiS1ZsriyC/cv6h4OUNRavVFZX+8PihPFMdbtXMkK9jgprQNe5djjaK5JDdNBQPhZkqye8MWGydpOT4QI+jNU/ZzAP34fUUcrhAzTcwDPqnmYu6n1xAE+L/Ulhx/URB9UFv6b1GrMAN02kO73j/1BOQhiBGqmHWG3OISX667MLmslCFNPdg8gN3vjt1HEOiU1kJ/9/Jxkk+kVTcC33nqps2bt9LyCHR1WdHfXpm8WbGT/iUQrM0mtVwayarJwerxXhr2MHORwDpjQOcHaBcFZZyQHY7HUXNciSJA97drHLN8uCYBvc74If8cYugeZUcHuCZrsKjU6z8X3ronTY2D1y+63/0fr8/bc8/+r+9jrNXsXbM5g1jCE7IWCH5GechYeF/WYpzxlp2L56ouVxWHsIs2I+sHb9tOlgdRkgq5zmQR2zqdnf2McqE3OkHCkjKB9INgrRGmqx14eA2jd1I3tAc9+3cB96mG3xfjflmykCIlTdlNjxyoTJYXZfdaDOMOBOjdaTdRa7TeOFypDa3dA2LcmaBqsaAG/liEBkBKPOp770qhfAwxyzrzsN73kYOHuRgiZLHvG3umZwD35CrSH1OJ+DVL4TUQhqGc9KaSWlitcpd4LjNx6xCvNfpiM5+ijj67z/4D0kiIgjTGF6udF0Mr2lXQoFzR3xBhJf1OWykzaOHqBUDtQAXtnqvZND0THOWkbUYFbvjcIZ+yS7JE9NCaT5J7atc+rgeWT4IV9qnyB4a6GTJzEvci8MNEN7G7i34VV8hCIKD2ceNIP46x+E3GTHUqlib3lSJ2tkblWPT2/yzYKVNkmNsezwAL2t+DYtX8hCkEHH3zY7J+etWsc5iXpTz0rUOtzalj35Zn25VyqVyLc7b//B6vE81//9ZEK6jhgpCSjHL/y1SMLuve8BMm77rpr1M5M7DmjmL60ew/PEJO3Z4iJnyFw/5u0efINT0/v6l57RSw/QQZeA5soiHXdEFLJIc7JbVlTPBF7Ft/CWgXa3ShDTYYLaFxzQJScpEWU6dSMthhV7D3Qz37/+f6S5/pzFrccKodIxzNe3cMagsmDMVoDb+OckQNATeWg8n7DUQ2HKiO1sD2ap2FLWeZ8b5URVtdnuvme1cT7xn32rs3GqGGdYd6C/RjtUVMxeofk4SMe8dBS1flKoBnMzX3f/e7Zlls/NIfL6KWGc8sxTg5y3NdCZ/p/fW0e2m2G74Bdh6Fs+LWNBEk361utLtlcXStC3Lg3kXZgXKzFmqbQrEI/h6m8KIQIm3DM/xPxW6se2jueXzvS0Zepxunw2AAyQSXolhdjNEBlTUQhTHBFFHn22gvS0ApIjJo6X8/qy9BvNdOwbEElxRwEU+WXOf4HRF1GPePokIJku/+06zNnvwvcBl4699zzy0BvtunmOXgZTp3eUOQQz0f2S0FEvYOx2yJRPcjs5sAsapcrpDa0Q8SqZZt2Jlm4IdrByWD3jZmpiC2eN1REDYqDAN3++LSflEoWxEQtjIyZvrNfpWWHw5ZVPikU+912261IUqTJ7HnsQDCftVBfAlHJQETKxdTLQbs9Q4z1nY41G0Go7E1NX+uNTNT9evacmuft2TIwJs6M82YtXUsRvbA3s/85Os5j1NM5NJAtw7LBBksiqxiN4QjbP+QhW9dnXZbMYd99969Aba2pV9h+8KywHp///OfOXvKiF1UJhDiGTO7KZHQPz0BksNx5kfhDDjMDlsO+KRNX7EXGsaG+FQsFsL43p2arL9X7O1Oun8gGQ3NmCDmeL+UYz9V+ecLjn1DZ4R21dhMJJYFkBX/+FGmmM5cx67gIQiF0CYxkHRU0BerzfmpaGvIFV8oMJrRYO9eptUH2hCBEH1eWRehf9uVZeQ/ITvWlT3XbCn7wGBB1JqfEDrBp5t6C39fIOdD0ry3jI+Fr6EfeYfsdegiBhEIrWm6t20kWJRj7eSEIGLdL5Szb614Coa0fHD3nIBj2pXFggrVlpuzNOD8C72wSmUH7iiOiMevf4H6Z0XVxfAPpcUYGaibo8ip7TIo0/cEnn3pSTa8R24NIOc+lU6pYLXXbYYcEj87I9pn8JXD56RlnzV6y+4tq+pDnjFNg/5qq8qWvfDm8he2qtODzfF+9k5N14QJDaNWoeRf5L+tqbf3pMkYIg3kWAj3CKgcc8KHo4u5UiIw2FwjKM1PGsE/VdAmpuFYlIAEA/obpRYRAHhuCkwDx0EMPKzjbBB3Q9c4771wkpHPP/UXZfA4ZlwEyIwDQv3rUN4+a/fOz/inKd68oJ3l5zorzAc2kJcwHeUYbxu894QmPTyCy9txwjwrK+LLAM3OOtJl0XedrIpCsVHN/iyssV3WNQG/Jip72j0+fvemNr08tL5FLqbosPxWzkQ0iVp7sUXbSB6wVbGRKHO00oqIcJePnVWyrLPZ41RinOeJBb5KeF9jG/+STTpz9939/osgX+rREfOCKVVOraKGIHhPF+KuPYjZekTrWy1/2ovoceDxVnj1f89oyVg3ntkPy/13D6jUYjnShE/1/MtUFP/f3jnRI+MmW7rmnW26GWAWjLXscvvDKCAA4aGskaiWH5xBWLSoO1gNlHJpNJ5ulxztgnyZpFOs3h42wuT5I0mbqUep4JuN4oXf7WdkgKOmURGPGD73//e+tGZvamEbbiDXt0U3zG1hdyHXLcLUZqF8iG3gZtK1JnoFgvAQG9DQ5dbUN9STTXUS2DnqPmQo8GPiJoUDI4IDPCPQKNnr+C55XmSGxgIqii0qfDLv0fJOxiXYX9MyKVH/+87NrFuH5cYrKD6a5bJiD5YUU5fe0LTzpiU+smov3g2KYGfnzRMKMsAjbZA9QEeNCGUj9UXbCwerB7D0JfdEXF1m6OAls4Lv0IyZTFTyo3UJFGCHow3h2TQDr0XajFHBrHJyWHQa7iGOD0JAg8Z7A9DLbW/L8Mc8XJzPbJsMbCFcITh4TUQokj++F7PLmN79jtuNOT6jr6rN1v8qy93jV/5fe0z3KyckujfXipM6LQ7ouEDsnqBZL2q6a6SeJRv1+JRdpRrCaYtYbXIp8UgFf/scpkVEkSP6noFNKAfb0RWHSsyubbrJ5PYvR8uW5LxJYTPcPinfoPBfnhTCLssdPfnJ6BezqYPYtKFddW+uFQMPz33TzjIDMHpEpewmkrSmjyakKJPycbLGemaBg4n54DgLY1jvWCtZnY7CJPQLw85p5JpACiIzn8JsQXhhwkC64X0bJCKsMdX01bSPZR/auiVagZuUUhpfDh4C4DoO6BT0C2xUSFEF/KnlhnLN+PRDDYHk2Y74kUOhLgjXtIwJS9+nzfF2t298FKee8CIYYtRPSa3nSySfVuVorcDL7qOw1WKj2hXPA4X/8Y5+YfT3lgu0j9A7yJ7KPjQuqPSzZ+FEJmj94wAemoCUQdvaja+75tQnekLASlLlH6zHs+SBE4jtAoTyPMRziox/5aMpEGc2W80pykJSnntLzz1eKOasmrnCKHKkgRbngR2FQE7yQIOz6zF3LFxxwwAE141jfqTIIu4McSFSiSY+rlD96/OMfP9v3XfvOLoxjPTrO9A/ZUz8N2fCKtK9hzNMYhgwKKgWNkkm2ARlrp52eXJm7+6ppSZFga3yMw5SBFnO2X9WAaqvne+3oMptUc+4UlX/84x8qNqVNL9ME4XB2qywK9TuLyElyav62cCS71AnGAcf6GGSYYgDnM8ZrQDujlaRo2H4+77NcFoND+frXvhGo85qCTDARywBmUf239orS+4yT4khpL550yo9nO27/2BKX+FbkqBjjt7zl7dHrXDP30LXa8qLFFqoUdQ6unVuTv3OY87Wu+ZrqiAxHpirbrIyjlGxsnoaMC67NOmEf3plo3mbAcFTPAHvZkNijHGkPZe6J9Zitnge4XWTWEoBNDqrsNNffQ7VNykgUm2coir/yqsvrefj3kAUE3ZwZ2v7V6Vl88Yt2r98/71fnFiTr92WYQ+3Ic+RgbESb2X5xEB0W2dQ2aStCljo2Ubj3QWfvoc3XlLOWlXFc//zPz6p7BwG5J7VhThlZglO8lXhCkA+foWnaWCRM1SxPwZy/S42rJrZkTWQj+igZwO8E4jnuuBPKYWG5Mo6bJ7IX1V+WrNdnyZIw/7S2DOOsd07ULdM6PsbG/Rqr9IPjjisJNH2xRBMaRvccM9ShAprW4mQoOEBlCdG5ZyTqd+ghMc3YNUxcuSEwaLFBQ9wJ7NtIDoWrrGF+vzIuUX32hyyzps1cd2ONi+NAbolTBTeeftrplSFfloh86/SF7rzLU+t9IC//ud8Ho4h0YYz1JoW2qOeoke600w6zl7549zLWS+dz63zGMJ4SaU3RvZrSVVddOTs3sPyaaa5fd/2N0keKCZpxe8k6OS7PiXFGgLr7rgjJc6bZ35wDmLv2IjJajKGjJHNsZOh+OatUtXrmIyYqoXMOZ8Czo/78sxhJ9+852N/rJrMAIXsfAv4y/JXjDDbbIn21MWb2yY1FWusM11qOAF1dlKNhsx6TCVCcBflJmaisCRqyeohAHNlAc0aG5p60IXHQDVsHpck6CVjS7VDBuRYQ5K0NElwWHGx+Z/a2z7G/F626Uq3NCHKvTblFyYn4huDIqEGkRxNuIG9zmXG183S7VAXmZZfm+2ndp9opqPrS7ItGY/AhYlNKIKc7AUr/tzgomeqS97rggt8kCzuhnA82uvq5wBuHoDo0sn8FLmeGgf/+2MaV41T/nAxvudWWTr12syLWgHi1Yr0gCEdNj8LAT/Bs/dQV2bnOSLWd4Ao0mRMSMdZhONIO9KJkF3t30EFfSDC/X3EjHpI9veeer66+1mMz91RwJPCFTOBfCExf8pIXFxJ5XjgPv0ugqAXsec99bn3mBz6wX5Ho3vLm/6j/PvGkEypDfXYmgOmJtQ/tsc9+7nOzJ0ZJifCD6TICf3YMeUwt29qcmlIgrsk5554z+/JXjkzQsEFd3/ZBIwRE1WII2m0/2o60DDE/UvBm08wnP1sbdZVpCr30eacdn1QXanFRsR2ihnLRzdUWOIe/zk2qqKwr/9eLyLF2hDVeY6rEgH4qMoT/TxFNF9L1mDX54OoUnX/4wx/UjXHcl1xyaTnSx6duuuEGiwPPnVMYOir0aZm0/oC0Q1CFUacSoV+ZBv7HhiX27H/ZLQdEM/aUieaCRsbps0ZLkHtZeL0LnejCrLXvp9mzTfpoHWIHaJn07iEUDeOh9uR9aHGK0gtGSBZt+kYRiXL/1lK0jOHKKJTcVrIEB019EsvQRuseRapIFItuTUY4DQVOFuZ99HNyjCJABn04c2xQY8tEojbur1P7UM/aMGIEMlJO1yHzzBFwwKPu5+zUHLUZ2JQGCjgMmLzIPNi6SgBXhhHrYHBaDq+1F5V7PwIa/hupYEBUstIbJ7jL+oGdkTj2ePUelRn8KKQxTox0oAZs7PHPfu6givhvSkBi42+z7cPqmfkckalMhPN/aCBMvaleG6X+ZK9iMCIn+KO+CLZzn9aTkz7yyK8nEPt5DwDOWkAMZD/qr/Y3LdwafRZD7G+B0P0Dm+ltG5/LSJlLKQggMbdCxqQRjkAGqykfZfgC/TsT2dfNJAdlNzSKFMWRaw9iLNZPu5e+O0YFnf9hET1/YuA4B9r6efbvetd7S03Kc+WQfI4I+iWB4jAmxYxbpa/UdBLrDNJVDwJ50jWW2YMsoR6/SCC6JKLrGwZOLiWuifh3Q4KV7uddtewF+oDnCDrWnrRmaoOtdgS6T0sSsYy0kKyzzoPq/qAQ3SZya+1bAeSZPzuz2oA4H/VNzxlaYl5tcTCypyETlKwEFtYZS1f2rs2tPn+q87e8XeD3rJ0gQzDgb0o09r59Zx8/LIMKXJ9ggjOCoDHQ4E/7yXsw9s7MRhttkv0YpSyzWhFPsmZDKIHxXRZxb+oDtb/uznu1s0iGWL2hnFrXDvWfCrKtV2tsU4LLlKYgASsuyjUvYOf3WU2gnP+NrG7YS+0vRRDKM7N31wshCkO6iZwTw5QQfc6q5/HHnPEzA/PSrh1MXkmSIJctQtZ8YPbVG/Z5YyFbG2QP3ZRWNO0kiGlb5fy/es9XFRfmeXGm3f7WRCcv6IJgD7S70JEqRZVlrPJG+B2TTKtAj4jEwYd8Mc70iyE9rVv2M7Oyq0cbuUnAZH6u6/thhgec+qPT0hO6Z5ztXkGODq/AEX9k++13jDDK06rX9+NBLBFRX/jC58c+nVOiLdtGAnDbsHKdV8p334rW7/ve954aenFCnO0b9t47QfY2Je14wgknVc/25kFo1FIXZe8dlyRBAKiM+LhktK7LHvr/AVCdZmvCW8VfAAAAAElFTkSuQmCC\\\"}},{\\\"insert\\\":\\\"\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":3,\\\"latex\\\":\\\"y=m\\\\\\\\cdot x+b\\\"},{\\\"type\\\":\\\"plot\\\",\\\"id\\\":4,\\\"latexs\\\":[\\\"y\\\\\\\\left(0\\\\\\\\left[in\\\\\\\\right]\\\\\\\\le x\\\\\\\\le10\\\\\\\\left[in\\\\\\\\right]\\\\\\\\right)=\\\"],\\\"logX\\\":false,\\\"logY\\\":false},{\\\"type\\\":\\\"table\\\",\\\"id\\\":5,\\\"rowLabels\\\":[\\\"Line 1\\\",\\\"Line 2\\\"],\\\"nextRowLabelId\\\":3,\\\"parameterLatexs\\\":[\\\"m\\\",\\\"b\\\"],\\\"nextParameterId\\\":3,\\\"parameterUnitLatexs\\\":[\\\"\\\",\\\"\\\\\\\\left[in\\\\\\\\right]\\\"],\\\"rhsLatexs\\\":[[\\\"2\\\",\\\"10\\\"],[\\\"4\\\",\\\"30\\\"]],\\\"selectedRow\\\":1,\\\"hideUnselected\\\":false,\\\"rowJsons\\\":[]},{\\\"type\\\":\\\"piecewise\\\",\\\"id\\\":9,\\\"parameterLatex\\\":\\\"z\\\",\\\"expressionLatexs\\\":[\\\"2\\\\\\\\left[in\\\\\\\\right]\\\",\\\"4\\\\\\\\left[in\\\\\\\\right]\\\"],\\\"conditionLatexs\\\":[\\\"m>2\\\"]},{\\\"type\\\":\\\"system\\\",\\\"id\\\":16,\\\"parameterListLatex\\\":\\\"s,t\\\",\\\"expressionLatexs\\\":[\\\"s+t=2\\\\\\\\left[in\\\\\\\\right]\\\",\\\"s-t=0\\\\\\\\left[in\\\\\\\\right]\\\"],\\\"selectedSolution\\\":0}],\\\"title\\\":\\\"Test File Save/Open \u03b2\\\",\\\"results\\\":[{\\\"value\\\":\\\"1.8796\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left[ m\\\\\\\\right] \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"userUnitsValueDefined\\\":true,\\\"userUnitsValue\\\":74,\\\"unitsMismatch\\\":false},null,{\\\"value\\\":\\\"\\\",\\\"units\\\":\\\"\\\",\\\"numeric\\\":false,\\\"real\\\":false,\\\"finite\\\":false},[{\\\"plot\\\":true,\\\"data\\\":[{\\\"numericOutput\\\":true,\\\"numericInput\\\":true,\\\"limitsUnitsMatch\\\":true,\\\"input\\\":[0,0.00508,0.01016,0.01524,0.02032,0.025400000000000002,0.030480000000000004,0.03556,0.04064,0.045720000000000004,0.050800000000000005,0.055880000000000006,0.06096000000000001,0.06604,0.07112,0.0762,0.08128,0.08636,0.09144000000000001,0.09652000000000001,0.10160000000000001,0.10668000000000001,0.11176000000000001,0.11684000000000001,0.12192000000000001,0.127,0.13208,0.13716,0.14224,0.14732,0.1524,0.15748,0.16256,0.16764,0.17272,0.1778,0.18288000000000001,0.18796000000000002,0.19304000000000002,0.19812000000000002,0.20320000000000002,0.20828000000000002,0.21336000000000002,0.21844000000000002,0.22352000000000002,0.22860000000000003,0.23368000000000003,0.23876000000000003,0.24384000000000003,0.24892000000000003,0.254],\\\"output\\\":[0.762,0.78232,0.80264,0.82296,0.84328,0.8636,0.88392,0.90424,0.92456,0.94488,0.9652000000000001,0.9855200000000001,1.00584,1.02616,1.04648,1.0668,1.08712,1.10744,1.12776,1.14808,1.1684,1.18872,1.2090400000000001,1.22936,1.2496800000000001,1.27,1.29032,1.31064,1.3309600000000001,1.35128,1.3716,1.39192,1.4122400000000002,1.43256,1.45288,1.4732,1.4935200000000002,1.51384,1.53416,1.55448,1.5748000000000002,1.59512,1.61544,1.63576,1.6560800000000002,1.6764000000000001,1.69672,1.7170400000000001,1.7373600000000002,1.7576800000000001,1.778],\\\"inputReversed\\\":false,\\\"inputUnits\\\":\\\"m\\\",\\\"inputUnitsLatex\\\":\\\"\\\\\\\\left[ m\\\\\\\\right] \\\",\\\"inputName\\\":\\\"x\\\",\\\"outputUnits\\\":\\\"m\\\",\\\"outputUnitsLatex\\\":\\\"\\\\\\\\left[ m\\\\\\\\right] \\\",\\\"outputName\\\":\\\"y\\\",\\\"unitsMismatch\\\":false,\\\"displayInput\\\":[0,0.2,0.4,0.6,0.8,1.0000000000000002,1.2000000000000002,1.4000000000000001,1.6,1.8000000000000003,2.0000000000000004,2.2,2.4000000000000004,2.6,2.8000000000000003,3.0000000000000004,3.2,3.4000000000000004,3.6000000000000005,3.8000000000000007,4.000000000000001,4.2,4.4,4.6000000000000005,4.800000000000001,5,5.2,5.4,5.6000000000000005,5.800000000000001,6.000000000000001,6.2,6.4,6.6000000000000005,6.800000000000001,7.000000000000001,7.200000000000001,7.400000000000001,7.600000000000001,7.800000000000001,8.000000000000002,8.200000000000001,8.4,8.600000000000001,8.8,9.000000000000002,9.200000000000001,9.400000000000002,9.600000000000001,9.8,10],\\\"displayInputUnits\\\":\\\"in\\\",\\\"displayOutput\\\":[0.762,0.78232,0.80264,0.82296,0.84328,0.8636,0.88392,0.90424,0.92456,0.94488,0.9652000000000001,0.9855200000000001,1.00584,1.02616,1.04648,1.0668,1.08712,1.10744,1.12776,1.14808,1.1684,1.18872,1.2090400000000001,1.22936,1.2496800000000001,1.27,1.29032,1.31064,1.3309600000000001,1.35128,1.3716,1.39192,1.4122400000000002,1.43256,1.45288,1.4732,1.4935200000000002,1.51384,1.53416,1.55448,1.5748000000000002,1.59512,1.61544,1.63576,1.6560800000000002,1.6764000000000001,1.69672,1.7170400000000001,1.7373600000000002,1.7576800000000001,1.778],\\\"displayOutputUnits\\\":\\\"m\\\"}]}]],\\\"system_results\\\":[null,null,null,null,null,null,{\\\"error\\\":null,\\\"solutions\\\":{\\\"s\\\":[\\\"\\\\\\\\frac{127}{5000}\\\"],\\\"t\\\":[\\\"\\\\\\\\frac{127}{5000}\\\"]},\\\"selectedSolution\\\":0}],\\\"nextId\\\":21,\\\"sheetId\\\":\\\"{\\\\\\\"0\\\\\\\":3011591337,\\\\\\\"1\\\\\\\":1865626448,\\\\\\\"2\\\\\\\":3190579276,\\\\\\\"3\\\\\\\":1169662171,\\\\\\\"4\\\\\\\":452832443,\\\\\\\"5\\\\\\\":1310852884,\\\\\\\"6\\\\\\\":4246722128,\\\\\\\"7\\\\\\\":3180883348,\\\\\\\"8\\\\\\\":4247230859,\\\\\\\"9\\\\\\\":3900078218}\\\",\\\"insertedSheets\\\":[]}\",\"dataHash\":\"4105338e394edba2e35361e58f4c7cbff7734bbc85d3d9ed4c2b9e8db4853b2b9f30fe11cf82420fb736450335f58c8a69b1f3fc071af24792daa3b86d59a48b\",\"creation\":\"2023-01-16T19:50:36.843Z\",\"creationIp\":\"127.0.0.1\",\"history\":[{\"url\":\"https://engineeringpaper.xyz/#7e84f956bd114cceb8cd0e\",\"hash\":\"7e84f956bd114cceb8cd0e\",\"creation\":\"2023-01-16T19:50:36.843Z\"}]}" }, { "key": "HkHWST4HeBHY8wGx4YMwXh", "value": "{\"title\":\"Data Table Tutorial\",\"data\":\"{\\\"config\\\":{\\\"mathCellConfig\\\":{\\\"symbolicOutput\\\":false,\\\"formatOptions\\\":{\\\"notation\\\":\\\"auto\\\",\\\"precision\\\":15,\\\"lowerExp\\\":-3,\\\"upperExp\\\":5},\\\"showIntermediateResults\\\":false},\\\"customBaseUnits\\\":{\\\"mass\\\":\\\"kg\\\",\\\"length\\\":\\\"m\\\",\\\"time\\\":\\\"s\\\",\\\"current\\\":\\\"A\\\",\\\"temperature\\\":\\\"K\\\",\\\"luminous_intensity\\\":\\\"cd\\\",\\\"amount_of_substance\\\":\\\"mol\\\",\\\"force\\\":\\\"N\\\",\\\"area\\\":\\\"m^2\\\",\\\"volume\\\":\\\"m^3\\\",\\\"energy\\\":\\\"J\\\",\\\"power\\\":\\\"W\\\",\\\"pressure\\\":\\\"Pa\\\",\\\"charge\\\":\\\"C\\\",\\\"capacitance\\\":\\\"F\\\",\\\"electric_potential\\\":\\\"V\\\",\\\"resistance\\\":\\\"ohm\\\",\\\"inductance\\\":\\\"H\\\",\\\"conductance\\\":\\\"S\\\",\\\"magnetic_flux\\\":\\\"Wb\\\",\\\"magnetic_flux_density\\\":\\\"T\\\",\\\"angle\\\":\\\"rad\\\",\\\"information\\\":\\\"b\\\"},\\\"simplifySymbolicExpressions\\\":true,\\\"convertFloatsToFractions\\\":true,\\\"fluidConfig\\\":{\\\"fluid\\\":\\\"Water\\\",\\\"incompMixConc\\\":0.5,\\\"customMixture\\\":[{\\\"fluid\\\":\\\"R32\\\",\\\"moleFraction\\\":0.697615},{\\\"fluid\\\":\\\"R125\\\",\\\"moleFraction\\\":0.302385}]}},\\\"cells\\\":[{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":1,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"A \\\"},{\\\"attributes\\\":{\\\"link\\\":\\\"https://youtu.be/xuNMikNa63U?si=7pq-TB70ZtxS56PI\\\"},\\\"insert\\\":\\\"video data table tutorial\\\"},{\\\"insert\\\":\\\" is also available. The data table cell type makes it easy to work with tabular data in EngineeringPaper.xyz. Data can be imported from Excel, CSV, or other spreadsheet file formats. The data can also be exported as a CSV file. To insert a data table cell, click the data table cell icon \\\"},{\\\"insert\\\":{\\\"image\\\":\\\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAAABHNCSVQICAgIfAhkiAAAAYtJREFUOE+1lb2KwkAUhU82wTSmsLHzJz6DKfUB7GxsFQUrm6S0SWeVJpAqlbWdpa2iIvoMoiJYKPgIuzuzOGTHSSYQvDDF3HvON3duYKJ8/wY+EBphHo9HzOdzPJ/PTEcUCgW0221Uq1VQsOd52O/3yNq8oig4nU7wff8P/Hg8YJomZrNZpo47nQ5utxtlfGUiJZg/BqYzJkE+YL1eT+ghXalWq1EhAxeLRYxGo3TuGFUQBKzCwPl8Hq1WK8aSLj2dTt/BUetyuWTbZrMppMo0rOOo23Ectj0cDkKwTCMEbzYbISyalGmE4N1uxxiNRgPn8xmXy4XmyuUyKpUKcrlc4uFCsG3bzERGsVgsEIYhzQ2HQ7pkIQTz1xwMBuj1epSlqqqMSetCMH/N6/X6NorVasUOIOPiQwjmRaJR8OPiPanA/X4f3W6Xel+jWK/XPOvfPhVY0zSQFQ1d1+VgwzDoI+S6bqJYVrzf73g9Qgr55223W0wmE/ZIywBx9VKphPF4DMuyQMFxwiz5H+WMhYQhc9UwAAAAAElFTkSuQmCC\\\"}},{\\\"insert\\\":\\\". There are two types of columns in a data table, input columns and calculated columns. The first row of a data table contains column names for data columns or query expressions for calculated columns. In the table below, the first two columns are input columns and the last column is a calculated column. The second row contains the units that are applied to every value in the column..\\\\n\\\"}]}},{\\\"type\\\":\\\"dataTable\\\",\\\"id\\\":2,\\\"parameterLatexs\\\":[\\\"Length\\\",\\\"Width\\\",\\\"Area=Length\\\\\\\\cdot Width=\\\"],\\\"nextParameterId\\\":13,\\\"nextInterpolationDefId\\\":2,\\\"nextPolyfitDefId\\\":2,\\\"parameterUnitLatexs\\\":[\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack\\\",\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack\\\",\\\"\\\"],\\\"columnData\\\":[[\\\"10.\\\",\\\"12\\\",\\\"14\\\"],[\\\"20\\\",\\\"22\\\",\\\"24\\\"],[\\\"200\\\",\\\"264\\\",\\\"336\\\"]],\\\"columnIds\\\":[0,1,2],\\\"interpolationDefinitions\\\":[]},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":4,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Each of the columns, input and output, gets assigned to its variable name as a column vector. For example the Length and Area columns are queried below:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":7,\\\"latex\\\":\\\"Length\\\\\\\\:=\\\",\\\"config\\\":null},{\\\"type\\\":\\\"math\\\",\\\"id\\\":8,\\\"latex\\\":\\\"Area=\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":12,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Since the columns get assigned to vectors, functions that operate on vectors (min, max, average, stdev, etc.) can be used on the column variables. For example the maximum Area and the sum of all of the areas can be determined using the following query statements:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":13,\\\"latex\\\":\\\"\\\\\\\\mathrm{min}\\\\\\\\left(Area\\\\\\\\right)=\\\",\\\"config\\\":null},{\\\"type\\\":\\\"math\\\",\\\"id\\\":14,\\\"latex\\\":\\\"\\\\\\\\mathrm{sum}\\\\\\\\left(Area\\\\\\\\right)=\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":17,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"In addition to performing calculations, data tables make it easy to create polynomial least squares fits to data. For example, the following data table fits a line to the provided x and y values. The linear fit can be used by calling the function called Polyfit1 (the function may be renamed by editing the function name field).\\\\n\\\"}]}},{\\\"type\\\":\\\"dataTable\\\",\\\"id\\\":15,\\\"parameterLatexs\\\":[\\\"x_{points}\\\",\\\"y_{points}\\\"],\\\"nextParameterId\\\":13,\\\"nextInterpolationDefId\\\":2,\\\"nextPolyfitDefId\\\":2,\\\"parameterUnitLatexs\\\":[\\\"\\\",\\\"\\\"],\\\"columnData\\\":[[\\\"1\\\",\\\"2\\\",\\\"3\\\",\\\"4\\\",\\\"5\\\",\\\"6\\\",\\\"7\\\",\\\"8\\\",\\\"9\\\",\\\"10\\\"],[\\\"1.82236506\\\",\\\"1.16819656\\\",\\\"1.64634224\\\",\\\"3.7461875\\\",\\\"3.78533977\\\",\\\"6.11934925\\\",\\\"7.92414076\\\",\\\"10.1906023\\\",\\\"9.29269577\\\",\\\"11.37309833\\\"]],\\\"columnIds\\\":[0,1],\\\"interpolationDefinitions\\\":[{\\\"nameLatex\\\":\\\"Polyfit1\\\",\\\"type\\\":\\\"polyfit\\\",\\\"numInputs\\\":1,\\\"inputs\\\":[0],\\\"output\\\":1,\\\"order\\\":1}]},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":19,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"The plot below shows the original points as a scatter plot and the linear fit as a parametric plot (see the \\\"},{\\\"attributes\\\":{\\\"link\\\":\\\"https://engineeringpaper.xyz/32XmqQA442GL8mj8X9uwP3\\\"},\\\"insert\\\":\\\"scatter plots\\\"},{\\\"insert\\\":\\\" and \\\"},{\\\"attributes\\\":{\\\"link\\\":\\\"https://engineeringpaper.xyz/dcM95gSLeCTcbCHtsM4uqq\\\"},\\\"insert\\\":\\\"parametric plots\\\"},{\\\"insert\\\":\\\" tutorials for more information on defining these types of plots).\\\\n\\\"}]}},{\\\"type\\\":\\\"plot\\\",\\\"id\\\":16,\\\"latexs\\\":[\\\"\\\\\\\\left(x_{points},y_{points}\\\\\\\\right)=\\\",\\\"\\\\\\\\left(x,\\\\\\\\mathrm{Polyfit1}\\\\\\\\left(x\\\\\\\\right)\\\\\\\\right)\\\\\\\\:for\\\\\\\\:\\\\\\\\left(1\\\\\\\\le x\\\\\\\\le10\\\\\\\\right)=\\\"],\\\"logX\\\":false,\\\"logY\\\":false,\\\"squareAspectRatio\\\":false},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":20,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"The Polyfit1 function that is created can be called like any other function as shown below:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":21,\\\"latex\\\":\\\"\\\\\\\\mathrm{Polyfit1}\\\\\\\\left(4\\\\\\\\right)=\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":23,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"The polynomial fit expression can be obtained by passing an undefined variable to the Polyfit1 function as shown below:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":18,\\\"latex\\\":\\\"\\\\\\\\mathrm{Polyfit1}\\\\\\\\left(x\\\\\\\\right)=\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":24,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Additionally, linear interpolation between table rows can performed automatically. In the following example, the Interp1 function can be used to provide the absolute viscosity of water as a function of temperature:\\\\n\\\"}]}},{\\\"type\\\":\\\"dataTable\\\",\\\"id\\\":27,\\\"parameterLatexs\\\":[\\\"T_{points}\\\",\\\"\\\\\\\\mu_{points}\\\"],\\\"nextParameterId\\\":13,\\\"nextInterpolationDefId\\\":2,\\\"nextPolyfitDefId\\\":2,\\\"parameterUnitLatexs\\\":[\\\"\\\\\\\\left\\\\\\\\lbrack degC\\\\\\\\right\\\\\\\\rbrack\\\",\\\"\\\\\\\\left\\\\\\\\lbrack cP\\\\\\\\right\\\\\\\\rbrack\\\"],\\\"columnData\\\":[[\\\"0\\\",\\\"20\\\",\\\"50\\\",\\\"100\\\",\\\"200\\\"],[\\\"1.7918\\\",\\\"1.0026\\\",\\\"0.5471\\\",\\\"0.2817\\\",\\\"0.1346\\\"]],\\\"columnIds\\\":[0,1],\\\"interpolationDefinitions\\\":[{\\\"nameLatex\\\":\\\"Interp1\\\",\\\"type\\\":\\\"interpolation\\\",\\\"numInputs\\\":1,\\\"inputs\\\":[0],\\\"output\\\":1,\\\"order\\\":1}]},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":38,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"The viscosity at 10 degrees Celsius between rows 1 and 2 can be obtained by a calling to the Interp1 function as shown below:\\\\n\\\"}]}},{\\\"type\\\":\\\"math\\\",\\\"id\\\":37,\\\"latex\\\":\\\"\\\\\\\\mathrm{Interp1}\\\\\\\\left(10\\\\\\\\left\\\\\\\\lbrack degC\\\\\\\\right\\\\\\\\rbrack\\\\\\\\right.)=\\\\\\\\left\\\\\\\\lbrack cP\\\\\\\\right\\\\\\\\rbrack\\\",\\\"config\\\":null},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":40,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"The following plot shows the points from the viscosity table above along with the Interp1 function showing the linear interpolation:\\\\n\\\"}]}},{\\\"type\\\":\\\"plot\\\",\\\"id\\\":39,\\\"latexs\\\":[\\\"\\\\\\\\left(T_{points},\\\\\\\\mu_{points}\\\\\\\\right)=\\\\\\\\left(\\\\\\\\left\\\\\\\\lbrack degC\\\\\\\\right\\\\\\\\rbrack,\\\\\\\\left\\\\\\\\lbrack cP\\\\\\\\right\\\\\\\\rbrack\\\\\\\\right)\\\",\\\"\\\\\\\\left(T,\\\\\\\\mathrm{Interp1}\\\\\\\\left(T\\\\\\\\right)\\\\\\\\right)\\\\\\\\:for\\\\\\\\:\\\\\\\\left(0\\\\\\\\left\\\\\\\\lbrack degC\\\\\\\\right\\\\\\\\rbrack\\\\\\\\le T\\\\\\\\le200\\\\\\\\left\\\\\\\\lbrack degC\\\\\\\\right\\\\\\\\rbrack\\\\\\\\right)=\\\\\\\\left(\\\\\\\\left\\\\\\\\lbrack degC\\\\\\\\right\\\\\\\\rbrack,\\\\\\\\left\\\\\\\\lbrack cP\\\\\\\\right\\\\\\\\rbrack\\\\\\\\right)\\\"],\\\"logX\\\":false,\\\"logY\\\":false,\\\"squareAspectRatio\\\":false},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":41,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"The range function is useful for initializing sequences of values in a data table. Calling range with one input creates a sequence that starts with 1 and ends with the provided value. Calling range with two inputs uses the first input as the starting value and the second value as the stopping value and increments the values by 1. Finally, calling range with three values uses the inputs as the starting value, stopping value, and increment value, in that order. See the example below:\\\\n\\\"}]}},{\\\"type\\\":\\\"dataTable\\\",\\\"id\\\":42,\\\"parameterLatexs\\\":[\\\"Col1=\\\\\\\\mathrm{range}\\\\\\\\left(5\\\\\\\\right)=\\\",\\\"Col2=\\\\\\\\mathrm{range}\\\\\\\\left(-2,2\\\\\\\\right)\\\",\\\"\\\\\\\\mathrm{range}\\\\\\\\left(0.2,1,0.2\\\\\\\\right)=\\\",\\\"Sum=Col1+Col2\\\"],\\\"nextParameterId\\\":13,\\\"nextInterpolationDefId\\\":2,\\\"nextPolyfitDefId\\\":2,\\\"parameterUnitLatexs\\\":[\\\"\\\",\\\"\\\",\\\"\\\",\\\"\\\"],\\\"columnData\\\":[[\\\"1\\\",\\\"2\\\",\\\"3\\\",\\\"4\\\",\\\"5\\\"],[\\\"-2\\\",\\\"-1\\\",\\\"0\\\",\\\"1\\\",\\\"2\\\"],[\\\"0.2\\\",\\\"0.4\\\",\\\"0.6\\\",\\\"0.8\\\",\\\"1\\\"],[\\\"-1\\\",\\\"1\\\",\\\"3\\\",\\\"5\\\",\\\"7\\\"]],\\\"columnIds\\\":[0,1,2,3],\\\"interpolationDefinitions\\\":[]},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":43,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"In the above example, the first two columns are assigned to the variable names \\\"},{\\\"attributes\\\":{\\\"italic\\\":true},\\\"insert\\\":\\\"Col1\\\"},{\\\"insert\\\":\\\" and \\\"},{\\\"attributes\\\":{\\\"italic\\\":true},\\\"insert\\\":\\\"Col2. \\\"},{\\\"insert\\\":\\\"This allows the sum to be calculated in the last column using these two columns. The third column is set to range(0.2,1,0.2) but is not assigned to a variable so it cannot be used in other calculations. When assigning the calculation to a variable, the trailing equals sign is optional, as shown in the second column.\\\\n\\\"}]}}],\\\"title\\\":\\\"Data Table Tutorial\\\",\\\"results\\\":[null,{\\\"dataTableResult\\\":true,\\\"colData\\\":{\\\"2\\\":{\\\"matrixResult\\\":true,\\\"results\\\":[[{\\\"value\\\":\\\"200.0000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"200.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m^2\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"m^2\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Area_as_variable\\\"}],[{\\\"value\\\":\\\"264.0000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"264.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m^2\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"m^2\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Area_as_variable\\\"}],[{\\\"value\\\":\\\"336.0000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"336.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m^2\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"m^2\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Area_as_variable\\\"}]],\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Area_as_variable\\\"}}},null,{\\\"matrixResult\\\":true,\\\"results\\\":[[{\\\"value\\\":\\\"10.00000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"10\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"m\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Length_as_variable\\\"}],[{\\\"value\\\":\\\"12.00000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"12\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"m\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Length_as_variable\\\"}],[{\\\"value\\\":\\\"14.00000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"14\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"m\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Length_as_variable\\\"}]],\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Length_as_variable\\\"},{\\\"matrixResult\\\":true,\\\"results\\\":[[{\\\"value\\\":\\\"200.0000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"200.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m^2\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"m^2\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Area_as_variable\\\"}],[{\\\"value\\\":\\\"264.0000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"264.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m^2\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"m^2\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Area_as_variable\\\"}],[{\\\"value\\\":\\\"336.0000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"336.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m^2\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"m^2\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Area_as_variable\\\"}]],\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Area_as_variable\\\"},null,{\\\"value\\\":\\\"200.0000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"200.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m^2\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"m^2\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"_Min(Area_as_variable)\\\"},{\\\"value\\\":\\\"800.0000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"800.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"m^2\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"m^2\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack m^2\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"_sum(Area_as_variable)\\\"},null,{\\\"value\\\":\\\"\\\",\\\"symbolicValue\\\":\\\"\\\",\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"numeric\\\":false,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"real\\\":false,\\\"finite\\\":false,\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"\\\"},null,[{\\\"plot\\\":true,\\\"data\\\":[{\\\"isScatter\\\":true,\\\"asLines\\\":false,\\\"numericOutput\\\":true,\\\"numericInput\\\":true,\\\"limitsUnitsMatch\\\":true,\\\"input\\\":[1,2,3,4,5,6,7,8,9,10],\\\"output\\\":[1.82236506,1.16819656,1.64634224,3.7461875,3.78533977,6.11934925,7.92414076,10.1906023,9.29269577,11.37309833],\\\"inputReversed\\\":false,\\\"inputUnits\\\":\\\"\\\",\\\"inputUnitsLatex\\\":\\\"\\\",\\\"inputCustomUnitsDefined\\\":false,\\\"inputCustomUnits\\\":\\\"\\\",\\\"inputCustomUnitsLatex\\\":\\\"\\\",\\\"inputName\\\":\\\"x_points\\\",\\\"inputNameLatex\\\":\\\"x_{points}\\\",\\\"outputUnits\\\":\\\"\\\",\\\"outputUnitsLatex\\\":\\\"\\\",\\\"outputCustomUnitsDefined\\\":false,\\\"outputCustomUnits\\\":\\\"\\\",\\\"outputCustomUnitsLatex\\\":\\\"\\\",\\\"outputName\\\":\\\"y_points\\\",\\\"outputNameLatex\\\":\\\"y_{points}\\\",\\\"isParametric\\\":false}]},{\\\"plot\\\":true,\\\"data\\\":[{\\\"isScatter\\\":false,\\\"numericOutput\\\":true,\\\"numericInput\\\":true,\\\"limitsUnitsMatch\\\":true,\\\"input\\\":[1,1.0909090909090908,1.1818181818181817,1.2727272727272725,1.3636363636363633,1.4545454545454541,1.545454545454545,1.6363636363636358,1.7272727272727266,1.8181818181818175,1.9090909090909083,1.9999999999999991,2.09090909090909,2.1818181818181808,2.2727272727272716,2.3636363636363624,2.4545454545454533,2.545454545454544,2.636363636363635,2.7272727272727257,2.8181818181818166,2.9090909090909074,2.9999999999999982,3.090909090909089,3.18181818181818,3.2727272727272707,3.3636363636363615,3.4545454545454524,3.545454545454543,3.636363636363634,3.727272727272725,3.8181818181818157,3.9090909090909065,3.9999999999999973,4.090909090909088,4.181818181818179,4.27272727272727,4.363636363636361,4.4545454545454515,4.545454545454542,4.636363636363633,4.727272727272724,4.818181818181815,4.909090909090906,4.9999999999999964,5.090909090909087,5.181818181818178,5.272727272727269,5.36363636363636,5.454545454545451,5.545454545454541,5.636363636363632,5.727272727272723,5.818181818181814,5.909090909090905,5.999999999999996,6.090909090909086,6.181818181818177,6.272727272727268,6.363636363636359,6.45454545454545,6.5454545454545405,6.636363636363631,6.727272727272722,6.818181818181813,6.909090909090904,6.999999999999995,7.0909090909090855,7.181818181818176,7.272727272727267,7.363636363636358,7.454545454545449,7.54545454545454,7.6363636363636305,7.727272727272721,7.818181818181812,7.909090909090903,7.999999999999994,8.090909090909085,8.181818181818176,8.272727272727268,8.36363636363636,8.454545454545451,8.545454545454543,8.636363636363635,8.727272727272727,8.818181818181818,8.90909090909091,9.000000000000002,9.090909090909093,9.181818181818185,9.272727272727277,9.363636363636369,9.45454545454546,9.545454545454552,9.636363636363644,9.727272727272736,9.818181818181827,9.909090909090919,10],\\\"output\\\":[0.24090638690908928,0.3513291215977945,0.46175185628649973,0.5721745909752047,0.68259732566391,0.7930200603526152,0.9034427950413204,1.0138655297300256,1.1242882644187309,1.234710999107436,1.3451337337961413,1.4555564684848465,1.5659792031735513,1.6764019378622566,1.7868246725509618,1.897247407239667,2.0076701419283722,2.1180928766170775,2.2285156113057827,2.338938345994488,2.449361080683193,2.5597838153718984,2.6702065500606036,2.780629284749309,2.8910520194380136,3.001474754126719,3.1118974888154245,3.2223202235041297,3.332742958192835,3.44316569288154,3.5535884275702445,3.6640111622589497,3.774433896947655,3.88485663163636,3.9952793663250654,4.105702101013771,4.216124835702476,4.326547570391181,4.436970305079886,4.5473930397685915,4.657815774457297,4.768238509146002,4.878661243834707,4.9890839785234125,5.099506713212118,5.209929447900823,5.320352182589528,5.430774917278233,5.541197651966939,5.651620386655644,5.762043121344349,5.872465856033054,5.9828885907217595,6.093311325410465,6.203734060099169,6.314156794787874,6.4245795294765795,6.535002264165285,6.64542499885399,6.755847733542695,6.8662704682314,6.976693202920106,7.087115937608812,7.197538672297516,7.307961406986222,7.4183841416749265,7.528806876363631,7.639229611052337,7.749652345741041,7.8600750804297475,7.970497815118452,8.080920549807157,8.191343284495861,8.30176601918457,8.412188753873274,8.522611488561978,8.633034223250682,8.74345695793939,8.853879692628094,8.964302427316799,9.074725162005507,9.185147896694211,9.295570631382919,9.405993366071627,9.516416100760331,9.626838835449039,9.737261570137743,9.847684304826451,9.958107039515156,10.068529774203864,10.178952508892568,10.289375243581276,10.39979797826998,10.510220712958688,10.620643447647396,10.7310661823361,10.841488917024808,10.951911651713512,11.06233438640222,11.172757121090914],\\\"inputReversed\\\":false,\\\"inputUnits\\\":\\\"\\\",\\\"inputUnitsLatex\\\":\\\"\\\",\\\"inputCustomUnitsDefined\\\":false,\\\"inputCustomUnits\\\":\\\"\\\",\\\"inputCustomUnitsLatex\\\":\\\"\\\",\\\"inputName\\\":\\\"x\\\",\\\"inputNameLatex\\\":\\\"x\\\",\\\"outputUnits\\\":\\\"\\\",\\\"outputUnitsLatex\\\":\\\"\\\",\\\"outputCustomUnitsDefined\\\":false,\\\"outputCustomUnits\\\":\\\"\\\",\\\"outputCustomUnitsLatex\\\":\\\"\\\",\\\"outputName\\\":\\\"y_1(x)\\\",\\\"outputNameLatex\\\":\\\"y_{1} \\\\\\\\left(x \\\\\\\\right)\\\",\\\"isParametric\\\":true,\\\"parametricErrorMessage\\\":\\\"\\\"}]}],null,{\\\"value\\\":\\\"3.884856631636363744064510683529078960418701171875000000000000000\\\",\\\"symbolicValue\\\":\\\"3.88485663163636\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Polyfit1_as_variable(4)\\\"},null,{\\\"value\\\":\\\"1.2146500815757581559495292822248302400112152099609375 \\\\\\\\cdot x - 0.97374369466666887973360644537024199962615966796875\\\",\\\"symbolicValue\\\":\\\"1.21465008157576 \\\\\\\\cdot x - 0.973743694666669\\\",\\\"numeric\\\":false,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":false,\\\"finite\\\":false,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Polyfit1_as_variable(x_as_variable)\\\"},null,{\\\"value\\\":\\\"\\\",\\\"symbolicValue\\\":\\\"\\\",\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"numeric\\\":false,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"real\\\":false,\\\"finite\\\":false,\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"\\\"},null,{\\\"value\\\":\\\"0.001397199999999999917715820529906523006502538919448852539062500000\\\",\\\"symbolicValue\\\":\\\"\\\\\\\\operatorname{Interp}_{1}{\\\\\\\\left(\\\\\\\\frac{5663}{20} \\\\\\\\right)}\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"kg^1*m^-1*s^-1\\\",\\\"unitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack \\\\\\\\frac{kg}{m\\\\\\\\cdot s}\\\\\\\\right\\\\\\\\rbrack \\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"kg^1*m^-1*s^-1\\\",\\\"customUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack \\\\\\\\frac{kg}{m\\\\\\\\cdot s}\\\\\\\\right\\\\\\\\rbrack \\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Interp1_as_variable(implicit_param__6_0_0)\\\"},null,[{\\\"plot\\\":true,\\\"data\\\":[{\\\"isScatter\\\":true,\\\"asLines\\\":false,\\\"numericOutput\\\":true,\\\"numericInput\\\":true,\\\"limitsUnitsMatch\\\":true,\\\"input\\\":[273.15,293.15,323.15,373.15,473.15],\\\"output\\\":[0.0017918,0.0010026,0.0005471,0.0002817,0.0001346],\\\"inputReversed\\\":false,\\\"inputUnits\\\":\\\"K\\\",\\\"inputUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack K\\\\\\\\right\\\\\\\\rbrack \\\",\\\"inputCustomUnitsDefined\\\":false,\\\"inputCustomUnits\\\":\\\"K\\\",\\\"inputCustomUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack K\\\\\\\\right\\\\\\\\rbrack \\\",\\\"inputName\\\":\\\"T_points\\\",\\\"inputNameLatex\\\":\\\"T_{points}\\\",\\\"outputUnits\\\":\\\"kg^1*m^-1*s^-1\\\",\\\"outputUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack \\\\\\\\frac{kg}{m\\\\\\\\cdot s}\\\\\\\\right\\\\\\\\rbrack \\\",\\\"outputCustomUnitsDefined\\\":false,\\\"outputCustomUnits\\\":\\\"kg^1*m^-1*s^-1\\\",\\\"outputCustomUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack \\\\\\\\frac{kg}{m\\\\\\\\cdot s}\\\\\\\\right\\\\\\\\rbrack \\\",\\\"outputName\\\":\\\"\u03bc_points\\\",\\\"outputNameLatex\\\":\\\"\\\\\\\\mu_{points}\\\",\\\"isParametric\\\":false}]},{\\\"plot\\\":true,\\\"data\\\":[{\\\"isScatter\\\":false,\\\"numericOutput\\\":true,\\\"numericInput\\\":true,\\\"limitsUnitsMatch\\\":true,\\\"input\\\":[273.15,275.170202020202,277.190404040404,279.21060606060604,281.23080808080806,283.2510101010101,285.2712121212121,287.2914141414141,289.31161616161614,291.33181818181816,293.3520202020202,295.3722222222222,297.3924242424242,299.41262626262625,301.43282828282827,303.4530303030303,305.4732323232323,307.49343434343433,309.51363636363635,311.5338383838384,313.5540404040404,315.5742424242424,317.59444444444443,319.61464646464646,321.6348484848485,323.6550505050505,325.6752525252525,327.69545454545454,329.71565656565656,331.7358585858586,333.7560606060606,335.7762626262626,337.79646464646464,339.81666666666666,341.8368686868687,343.8570707070707,345.8772727272727,347.89747474747475,349.91767676767677,351.9378787878788,353.9580808080808,355.97828282828283,357.99848484848485,360.01868686868687,362.0388888888889,364.0590909090909,366.07929292929293,368.09949494949495,370.119696969697,372.139898989899,374.160101010101,376.18030303030304,378.20050505050506,380.2207070707071,382.2409090909091,384.2611111111111,386.28131313131314,388.30151515151516,390.3217171717172,392.3419191919192,394.3621212121212,396.38232323232324,398.40252525252527,400.4227272727273,402.4429292929293,404.4631313131313,406.48333333333335,408.50353535353537,410.5237373737374,412.5439393939394,414.56414141414143,416.58434343434345,418.6045454545455,420.6247474747475,422.6449494949495,424.66515151515154,426.68535353535356,428.7055555555556,430.7257575757576,432.7459595959596,434.76616161616164,436.78636363636366,438.8065656565657,440.8267676767677,442.8469696969697,444.86717171717174,446.88737373737376,448.9075757575758,450.9277777777778,452.9479797979798,454.96818181818185,456.98838383838387,459.0085858585859,461.0287878787879,463.04898989898993,465.06919191919195,467.089393939394,469.109595959596,471.129797979798,473.15],\\\"output\\\":[0.0017918,0.0017120828282828284,0.0016323656565656566,0.001552648484848485,0.001472931313131313,0.0013932141414141413,0.0013134969696969696,0.0012337797979797979,0.001154062626262626,0.0010743454545454542,0.0009995326599326598,0.0009688592592592591,0.0009381858585858585,0.0009075124579124578,0.0008768390572390572,0.0008461656565656564,0.0008154922558922558,0.000784818855218855,0.0007541454545454543,0.0007234720538720537,0.000692798653198653,0.0006621252525252524,0.0006314518518518516,0.000600778451178451,0.0005701050505050502,0.0005444191919191919,0.0005336959595959595,0.0005229727272727272,0.0005122494949494949,0.0005015262626262625,0.0004908030303030302,0.0004800797979797979,0.00046935656565656557,0.0004586333333333332,0.00044791010101010093,0.0004371868686868686,0.0004264636363636363,0.00041574040404040394,0.00040501717171717165,0.0003942939393939393,0.00038357070707070696,0.00037284747474747467,0.0003621242424242423,0.00035140101010100997,0.0003406777777777777,0.00032995454545454533,0.000319231313131313,0.0003085080808080807,0.00029778484848484835,0.00028706161616161605,0.0002802141414141414,0.0002772424242424242,0.00027427070707070707,0.0002712989898989899,0.0002683272727272727,0.00026535555555555555,0.00026238383838383836,0.00025941212121212117,0.00025644040404040403,0.00025346868686868684,0.00025049696969696965,0.0002475252525252525,0.0002445535353535353,0.00024158181818181813,0.00023861010101010097,0.0002356383838383838,0.0002326666666666666,0.00022969494949494945,0.00022672323232323228,0.0002237515151515151,0.00022077979797979793,0.00021780808080808077,0.00021483636363636358,0.0002118646464646464,0.00020889292929292925,0.00020592121212121206,0.0002029494949494949,0.00019997777777777773,0.00019700606060606054,0.00019403434343434338,0.0001910626262626262,0.00018809090909090902,0.00018511919191919186,0.0001821474747474747,0.0001791757575757575,0.00017620404040404034,0.00017323232323232317,0.00017026060606060598,0.00016728888888888882,0.00016431717171717166,0.00016134545454545447,0.0001583737373737373,0.00015540202020202014,0.00015243030303030295,0.00014945858585858578,0.0001464868686868686,0.00014351515151515143,0.00014054343434343427,0.00013757171717171707,0.0001346],\\\"inputReversed\\\":false,\\\"inputUnits\\\":\\\"K\\\",\\\"inputUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack K\\\\\\\\right\\\\\\\\rbrack \\\",\\\"inputCustomUnitsDefined\\\":false,\\\"inputCustomUnits\\\":\\\"K\\\",\\\"inputCustomUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack K\\\\\\\\right\\\\\\\\rbrack \\\",\\\"inputName\\\":\\\"T\\\",\\\"inputNameLatex\\\":\\\"T\\\",\\\"outputUnits\\\":\\\"kg^1*m^-1*s^-1\\\",\\\"outputUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack \\\\\\\\frac{kg}{m\\\\\\\\cdot s}\\\\\\\\right\\\\\\\\rbrack \\\",\\\"outputCustomUnitsDefined\\\":false,\\\"outputCustomUnits\\\":\\\"kg^1*m^-1*s^-1\\\",\\\"outputCustomUnitsLatex\\\":\\\"\\\\\\\\left\\\\\\\\lbrack \\\\\\\\frac{kg}{m\\\\\\\\cdot s}\\\\\\\\right\\\\\\\\rbrack \\\",\\\"outputName\\\":\\\"y_2(T)\\\",\\\"outputNameLatex\\\":\\\"y_{2} \\\\\\\\left(T \\\\\\\\right)\\\",\\\"isParametric\\\":true,\\\"parametricErrorMessage\\\":\\\"\\\"}]}],null,{\\\"dataTableResult\\\":true,\\\"colData\\\":{\\\"0\\\":{\\\"matrixResult\\\":true,\\\"results\\\":[[{\\\"value\\\":\\\"1.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"1\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Col1_as_variable\\\"}],[{\\\"value\\\":\\\"2.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"2\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Col1_as_variable\\\"}],[{\\\"value\\\":\\\"3.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"3\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Col1_as_variable\\\"}],[{\\\"value\\\":\\\"4.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"4\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Col1_as_variable\\\"}],[{\\\"value\\\":\\\"5.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"5\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Col1_as_variable\\\"}]],\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Col1_as_variable\\\"},\\\"1\\\":{\\\"matrixResult\\\":true,\\\"results\\\":[[{\\\"value\\\":\\\"-2.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"-2\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Col2_as_variable\\\"}],[{\\\"value\\\":\\\"-1.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"-1\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Col2_as_variable\\\"}],[{\\\"value\\\":\\\"0\\\",\\\"symbolicValue\\\":\\\"0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Col2_as_variable\\\"}],[{\\\"value\\\":\\\"1.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"1\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Col2_as_variable\\\"}],[{\\\"value\\\":\\\"2.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"2\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Col2_as_variable\\\"}]],\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Col2_as_variable\\\"},\\\"2\\\":{\\\"matrixResult\\\":true,\\\"results\\\":[[{\\\"value\\\":\\\"0.2000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"\\\\\\\\frac{1}{5}\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"_data_table_calc_wrapper(_range(0.2, 1, 0.2))\\\"}],[{\\\"value\\\":\\\"0.4000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"\\\\\\\\frac{2}{5}\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"_data_table_calc_wrapper(_range(0.2, 1, 0.2))\\\"}],[{\\\"value\\\":\\\"0.6000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"\\\\\\\\frac{3}{5}\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"_data_table_calc_wrapper(_range(0.2, 1, 0.2))\\\"}],[{\\\"value\\\":\\\"0.8000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"\\\\\\\\frac{4}{5}\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"_data_table_calc_wrapper(_range(0.2, 1, 0.2))\\\"}],[{\\\"value\\\":\\\"1.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"1\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"_data_table_calc_wrapper(_range(0.2, 1, 0.2))\\\"}]],\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"_data_table_calc_wrapper(_range(0.2, 1, 0.2))\\\"},\\\"3\\\":{\\\"matrixResult\\\":true,\\\"results\\\":[[{\\\"value\\\":\\\"-1.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"-1.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Sum_as_variable\\\"}],[{\\\"value\\\":\\\"1.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"1.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Sum_as_variable\\\"}],[{\\\"value\\\":\\\"3.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"3.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Sum_as_variable\\\"}],[{\\\"value\\\":\\\"5.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"5.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Sum_as_variable\\\"}],[{\\\"value\\\":\\\"7.000000000000000000000000000000000000000000000000000000000000000\\\",\\\"symbolicValue\\\":\\\"7.0\\\",\\\"numeric\\\":true,\\\"units\\\":\\\"\\\",\\\"unitsLatex\\\":\\\"\\\",\\\"real\\\":true,\\\"finite\\\":true,\\\"customUnitsDefined\\\":false,\\\"customUnits\\\":\\\"\\\",\\\"customUnitsLatex\\\":\\\"\\\",\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Sum_as_variable\\\"}]],\\\"isSubResult\\\":false,\\\"subQueryName\\\":\\\"Sum_as_variable\\\"}}},null],\\\"system_results\\\":[null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null],\\\"sub_results\\\":[],\\\"nextId\\\":44,\\\"sheetId\\\":\\\"60f81900-83be-49bd-a656-89383f02a43d\\\",\\\"insertedSheets\\\":[{\\\"title\\\":\\\"Properties of Selected Liquids\\\",\\\"url\\\":\\\"https://engineeringpaper.xyz/EnZhHT9wvsESXvRChZ7TLV\\\",\\\"insertion\\\":\\\"2024-08-08T02:48:30.826Z\\\"}]}\",\"dataHash\":\"647439b34d2ae0efbbf9710c075b50a3f43ba94043db949245f0178701b3eef6ad261f952c6f1fed72afdf9ffe9047316ff45a3db9f2e51695774ad146c59e57\",\"creation\":\"2025-05-22T04:01:44.322Z\",\"creationIp\":\"127.0.0.1\",\"history\":[{\"url\":\"http://localhost:8788/HkHWST4HeBHY8wGx4YMwXh\",\"hash\":\"HkHWST4HeBHY8wGx4YMwXh\",\"creation\":\"2025-05-22T04:01:44.322Z\"},{\"url\":\"http://localhost:8788/YBYcEvYFXViTanjGa6VEdE\",\"hash\":\"YBYcEvYFXViTanjGa6VEdE\",\"creation\":\"2025-05-21T21:21:13.614Z\"},{\"url\":\"Data Table Tutorial\",\"hash\":\"file\",\"creation\":\"2025-05-21T21:11:30.130Z\"},{\"url\":\"https://data-table.engineeringpaper.pages.dev/hnh9wDMhEfXjDPUzpn9cTS\",\"hash\":\"hnh9wDMhEfXjDPUzpn9cTS\",\"creation\":\"2024-08-09T01:58:46.522Z\"},{\"url\":\"https://data-table.engineeringpaper.pages.dev/R6KUyVTzoYms3iwUWLsn5E\",\"hash\":\"R6KUyVTzoYms3iwUWLsn5E\",\"creation\":\"2024-08-08T03:55:02.848Z\"},{\"url\":\"https://data-table.engineeringpaper.pages.dev/Fmtq8NZXZN2nUqYnRjUgPA\",\"hash\":\"Fmtq8NZXZN2nUqYnRjUgPA\",\"creation\":\"2024-08-08T03:48:21.279Z\"},{\"url\":\"Data Table Tutorial\",\"hash\":\"file\",\"creation\":\"2024-08-08T03:17:52.596Z\"}]}" }, { "key": "PaFvsBhgoJdZEEwyBLPnD6", "value": "{\"title\":\"Mechanical Properties of Selected Metals\",\"data\":\"{\\\"cells\\\":[{\\\"type\\\":\\\"table\\\",\\\"id\\\":1,\\\"rowLabels\\\":[\\\"Aluminum Alloys\\\",\\\"Beryllium Copper\\\",\\\"Brass, Bronze\\\",\\\"Copper\\\",\\\"Iron, Cast, Gray\\\",\\\"Iron, Cast, Ductile\\\",\\\"Iron, Cast, Malleable\\\",\\\"Magnesium Alloys\\\",\\\"Nickel Alloys\\\",\\\"Steel, Carbon\\\",\\\"Steel, Alloys\\\",\\\"Steel, Stainless\\\",\\\"Titanium Alloys\\\",\\\"Zinc Alloys\\\"],\\\"rowIds\\\":[1,2,3,4,5,6,7,8,9,10,11,12,13,14],\\\"parameterUnitLatexs\\\":[\\\"\\\\\\\\left[GPa\\\\\\\\right]\\\",\\\"\\\",\\\"\\\\\\\\left[\\\\\\\\frac{kg}{m^{3}}\\\\\\\\right]\\\"],\\\"parameterLatexs\\\":[\\\"E\\\",\\\"v\\\",\\\"\\\\\\\\rho\\\"],\\\"parameterIds\\\":[1,2,3],\\\"rhsLatexs\\\":[[\\\"71.7\\\",\\\"0.34\\\",\\\"2800\\\"],[\\\"127.6\\\",\\\"0.29\\\",\\\"8300\\\"],[\\\"110.3\\\",\\\"0.33\\\",\\\"8600\\\"],[\\\"120.7\\\",\\\"0.35\\\",\\\"8900\\\"],[\\\"103.4\\\",\\\"0.28\\\",\\\"7200\\\"],[\\\"168.9\\\",\\\"0.30\\\",\\\"6900\\\"],[\\\"172.4\\\",\\\"0.30\\\",\\\"7300\\\"],[\\\"44.8\\\",\\\"0.33\\\",\\\"1800\\\"],[\\\"206.8\\\",\\\"0.30\\\",\\\"8300\\\"],[\\\"206.8\\\",\\\"0.28\\\",\\\"7800\\\"],[\\\"206.8\\\",\\\"0.28\\\",\\\"7800\\\"],[\\\"189.6\\\",\\\"0.28\\\",\\\"7800\\\"],[\\\"113.8\\\",\\\"0.34\\\",\\\"4400\\\"],[\\\"82.7\\\",\\\"0.33\\\",\\\"6600\\\"]],\\\"rhsIds\\\":[[\\\"1,1\\\",\\\"1,2\\\",\\\"1,3\\\"],[\\\"2,1\\\",\\\"2,2\\\",\\\"2,3\\\"],[\\\"3,1\\\",\\\"3,2\\\",\\\"3,3\\\"],[\\\"4,1\\\",\\\"4,2\\\",\\\"4,3\\\"],[\\\"5,1\\\",\\\"5,2\\\",\\\"5,3\\\"],[\\\"6,1\\\",\\\"6,2\\\",\\\"6,3\\\"],[\\\"7,1\\\",\\\"7,2\\\",\\\"7,3\\\"],[\\\"8,1\\\",\\\"8,2\\\",\\\"8,3\\\"],[\\\"9,1\\\",\\\"9,2\\\",\\\"9,3\\\"],[\\\"10,1\\\",\\\"10,2\\\",\\\"10,3\\\"],[\\\"11,1\\\",\\\"11,2\\\",\\\"11,3\\\"],[\\\"12,1\\\",\\\"12,2\\\",\\\"12,3\\\"],[\\\"13,1\\\",\\\"13,2\\\",\\\"13,3\\\"],[\\\"14,1\\\",\\\"14,2\\\",\\\"14,3\\\"]],\\\"selectedRow\\\":0,\\\"nextParameterId\\\":4,\\\"nextRowLabelId\\\":15,\\\"rowJsons\\\":[]},{\\\"type\\\":\\\"documentation\\\",\\\"id\\\":2,\\\"json\\\":{\\\"ops\\\":[{\\\"insert\\\":\\\"Source: Norton, R. L. \\\\\\\"\\\"},{\\\"attributes\\\":{\\\"link\\\":\\\"https://www.pearson.com/us/higher-education/program/Norton-Machine-Design-5th-Edition/PGM275676.html\\\"},\\\"insert\\\":\\\"Machine design. A integrated approach, 5th Editi.\\\"},{\\\"insert\\\":\\\"\\\\\\\" (2013).\\\\n\\\"}]}}],\\\"title\\\":\\\"Mechanical Properties of Selected Metals\\\",\\\"results\\\":[],\\\"nextId\\\":4,\\\"sheetId\\\":\\\"{\\\\\\\"0\\\\\\\":865920201,\\\\\\\"1\\\\\\\":3239801977,\\\\\\\"2\\\\\\\":2201017828,\\\\\\\"3\\\\\\\":3940749111,\\\\\\\"4\\\\\\\":2898331458,\\\\\\\"5\\\\\\\":3598727395,\\\\\\\"6\\\\\\\":4040345789,\\\\\\\"7\\\\\\\":161785945,\\\\\\\"8\\\\\\\":1388415113,\\\\\\\"9\\\\\\\":1138923111}\\\"}\",\"dataHash\":\"3bc63ef963bd7d670dc266f78eba22bbe362993b3f393ec04921c94e5b7fe259e7b0caf804a3f83eb8f69e5e571cd2a54f09aa699342e9a5c12cc41f788661bd\",\"creation\":\"2022-06-07T21:04:43.889Z\",\"creationIp\":\"24.178.27.137\",\"history\":[{\"url\":\"https://engineeringpaper.xyz/#PaFvsBhgoJdZEEwyBLPnD6\",\"hash\":\"PaFvsBhgoJdZEEwyBLPnD6\",\"creation\":\"2022-06-07T21:04:43.889591Z\"},{\"url\":\"https://engineeringpaper.xyz/#atxKHN57RD8t5wzFA3Dxen\",\"hash\":\"atxKHN57RD8t5wzFA3Dxen\",\"creation\":\"2022-06-07T21:02:50.182033Z\"},{\"url\":\"https://engineeringpaper.xyz/#BFcTw4EW3a799K2X2eYNyx\",\"hash\":\"BFcTw4EW3a799K2X2eYNyx\",\"creation\":\"2022-06-07T20:39:19.549172Z\"},{\"url\":\"https://engineeringpaper.xyz/#gnZvqQagtSR7qaRLmzH7He\",\"hash\":\"gnZvqQagtSR7qaRLmzH7He\",\"creation\":\"2022-06-07T20:34:29.803698Z\"}]}" } ] ================================================ FILE: tests/spreadsheets/bottle_data.csv ================================================ t,h,d,volume,displacement,mass [mm],[mm],[mm],[mm^3],[mm],[g] 1,8,77.5,575219.2471,1.48225,52.0916 1,3,77.5,626232.6593,3.49115,48.4434 0.25,8,77.5,615034.2578,1.46829,13.2204 0.25,3,77.5,663203.035,3.50871,12.2803 1,5.5,85,735524.7312,2.57754,56.4641 1,5.5,70,483741.1794,2.03223,44.6659 0.25,5.5,85,778792.2632,2.64386,14.3061 0.25,5.5,70,517727.7965,2.07546,11.3433 0.625,8,85,726691.9754,1.6678,36.7517 0.625,8,70,476467.9482,1.3538,28.9612 0.625,3,85,781862.6776,4.03125,34.0365 0.625,3,70,520523.6141,3.02136,27.0462 0.625,5.5,77.5,622206.8094,2.32026,31.7797 ================================================ FILE: tests/spreadsheets/headers_and_units.csv ================================================ col1, ,alpha_1,\sigma_{initial},,col3, [m],[s],,km,,,\left\lbrack K\right\rbrack 4.1,9,1.10E+30,0,,1,4 0,8,-1.20E-30,1,,2,5 3,7,0,2,,3,6 1,0,1,3,,,7 -20.3,-1,2,4,,, ,-2,3,5,,, ,-3,4,6,,, ,-3.4,,7,,, ,,,8,,, ,,,9,,, ,,,cats,,, ,,,10,,, ,,,11,,, ,,,12,,, ,,,13,,, ================================================ FILE: tests/spreadsheets/interpolation_autosort.csv ================================================ Col1,Col2 1,10 3,8 2,9 ================================================ FILE: tests/spreadsheets/interpolation_repeated_input.csv ================================================ Col1,Col2 1,10 3,8 2,9 2,11 ================================================ FILE: tests/spreadsheets/plane_interpolation_no_units.csv ================================================ X,Y,Z 1,1,9.4 1,5,8 7,1,7.9 6,5,6.75 ================================================ FILE: tests/spreadsheets/plane_interpolation_with_units_large_scale.csv ================================================ X,Y,Z [Ym],[ys],[YN] 1,1,9.4 1,5,8 7,1,7.9 6,5,6.75 ================================================ FILE: tests/spreadsheets/plane_interpolation_with_units_small_scale.csv ================================================ X,Y,Z [Ym],,[yN] 1,1,9.4 1,5,8 7,1,7.9 6,5,6.75 ================================================ FILE: tests/test_advanced_assignments.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Check parsing error handling with multiple assignments', async () => { // syntax error with second entry await page.setLatex(0, 'x=5.11,y=6..'); await page.locator('text=Invalid Syntax').waitFor({state: "attached", timeout: 1000}); // unrecognized units await page.setLatex(0, 'x=5.11,y=6[mmm]'); await page.locator('text=Unknown Dimension mmm').waitFor({state: "attached", timeout: 1000}); // assignment to pi await page.setLatex(0, 'x=1,\\pi=2.1'); await page.locator('text=Attempt to reassign reserved variable name pi').waitFor({state: "attached", timeout: 1000}); // assignment to i await page.setLatex(0, 'i=1,y=2.1'); await page.locator('text=Attempt to reassign reserved variable name I').waitFor({state: "attached", timeout: 1000}); // make sure combined query and multiple assignment triggers syntax error await page.setLatex(0, String.raw`s=40\left\lbrack m\right\rbrack,z=30\left\lbrack miles\right\rbrack=`); await page.locator('text=Invalid Syntax').waitFor({state: "attached", timeout: 1000}); // make sure everything still works with valid input await page.setLatex(0, 'x=1,y=2'); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(1).type('x='); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(2).type('y='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent(`#result-value-2`); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); }); test('Test multiple assignment', async () => { // number, number with units, and expression await page.locator('math-field.editable').type('x=2,y=3[m],z=x*y'); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(1).type('x='); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(2).type('y='); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(3).type('z='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent(`#result-value-2`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); content = await page.textContent(`#result-value-3`); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m'); // reverse order and add external dependency later in document await page.setLatex(0, String.raw`z=x\cdot y\cdot s,x=2^{\frac{s}{40\left\lbrack m\right\rbrack}},y=3[m]`); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(4).type('s=40[m]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent(`#result-value-2`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); content = await page.textContent(`#result-value-3`); expect(parseLatexFloat(content)).toBeCloseTo(240, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m^2'); }); test('Check error handling with combined assignment query', async () => { // unrecognized assignment units await page.setLatex(0, 'x=5.11[mmm]='); await page.locator('text=Unknown Dimension mmm').waitFor({state: "attached", timeout: 1000}); // unrecognized query units await page.setLatex(0, 'x=5.11[mm]=[sss]'); await page.locator('text=Unknown Dimension sss').waitFor({state: "attached", timeout: 1000}); // make sure everything still works with valid input await page.setLatex(0, 'x=5.11[mm]=[mm]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(5.11, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('mm'); }); test('Test combined assignment query', async () => { // number, number with units, and expression await page.locator('math-field.editable').type('x=s*20[m]=[cm^2'); await page.locator('math-field.editable').press('Tab'); await page.locator('math-field.editable').type(']'); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(1).type('x='); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(2).type('s=3[m]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(600000, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('cm^2'); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(60, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m^2'); }); ================================================ FILE: tests/test_advanced_var_names.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos, e} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => newSheet(page)); test('Test unicode var', async () => { await page.setLatex(0, String.raw`长度=2`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`长度=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); }); test('Test var with greek subscript', async () => { await page.setLatex(0, String.raw`a_{\omega}=3`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a_{\omega}=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`a_ω=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`a_{ω}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`a^2_ω=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`a_{omega}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-value-5'); expect(content).toBe(String.raw`a_{omega}`, precision); }); test('Test leading digit not valid var name', async () => { await page.setLatex(0, String.raw`1a=`); await expect(page.locator('#cell-0 >> svg.error')).toBeVisible(); }); test('Test leading underscore not valid var name', async () => { await page.setLatex(0, String.raw`_a=`); await expect(page.locator('#cell-0 >> svg.error')).toBeVisible(); }); test('Test trailing underscore not valid var name', async () => { await page.setLatex(0, String.raw`a_=`); await expect(page.locator('#cell-0 >> svg.error')).toBeVisible(); }); test('Test var with embedded greek char', async () => { await page.setLatex(0, String.raw`a\omega b=4`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a\omega b=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`aωb=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`aomegab=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-value-3'); expect(content).toBe(String.raw`aomegab`, precision); }); test('Test single char greek var', async () => { await page.setLatex(0, String.raw`\omega_a=5`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\omega_a=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`ω_a=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`omega_{a}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`omega^2_a=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(25, precision); }); test('Test accent with internal and external subscript', async () => { await page.setLatex(0, String.raw`\vec{a_b}=6`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\vec{a_b}=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\vec{a}_b=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\vec{a}^2_b=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(36, precision); }); test('Test keyboard shortcut for accent', async () => { await page.locator('#cell-0 >> math-field.editable').type('a\\bar=7'); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').type('\\bara'); await page.locator('#cell-1 >> math-field.editable').press('Tab'); await page.locator('#cell-1 >> math-field.editable').type('='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(7, precision); }); test('Test prime with internal and external subscript', async () => { await page.setLatex(0, String.raw`a^{\prime\prime}_2=8`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a^{\prime\prime}_2=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`a_2^{\prime\prime}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); }); test('Test prime keyboard shortcut', async () => { await page.locator('#cell-0 >> math-field.editable').type("a_2"); await page.locator('#cell-0 >> math-field.editable').press("Tab"); await page.locator('#cell-0 >> math-field.editable').type("'''=9, b'=10"); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').type("a'''_2"); await page.locator('#cell-1 >> math-field.editable').press("Tab"); await page.locator('#cell-1 >> math-field.editable').type("+b'+1="); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(20, precision); }); test('Test conversion of accented i or j into \\imath or \\jmath', async () => { await page.locator('#cell-0 >> math-field.editable').type("i\\hat"); await page.locator('#cell-0 >> math-field.editable').press("="); await page.locator('#cell-0 >> math-field.editable').type("11"); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').type("k\\hat"); await page.locator('#cell-1 >> math-field.editable').press("="); await page.locator('#cell-1 >> math-field.editable').type("12"); await page.locator('#add-math-cell').click(); await page.locator('#cell-2 >> math-field.editable').type("j\\hat"); await page.locator('#cell-2 >> math-field.editable').press("="); await page.locator('#add-math-cell').click(); await page.locator('#cell-3 >> math-field.editable').click(); await page.setLatex(3, String.raw`\hat{i}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`\hat{\imath}=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`\hat{k}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(content).toBe(String.raw`\hat{\jmath}`); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(11, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(11, precision); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(12, precision); }); ================================================ FILE: tests/test_basic.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test basic functionality', async () => { // Test basic dimensional analysis and unit conversion await page.type(':nth-match(math-field.editable, 1)', 'x=3[inch]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'y=4[inch]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', 'length=sqrtx^2'); await page.press(':nth-match(math-field.editable, 3)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 3)', '+y^2'); // test using enter key for adding math cell await page.press(':nth-match(math-field.editable, 3)', 'Enter'); await page.type(':nth-match(math-field.editable, 4)', 'length=[inch]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('inch') // test removal of units for query statement to make sure updates happen for(let i = 0; i<6; i++) { await page.press(':nth-match(math-field.editable, 4)', 'Backspace'); } await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(0.127, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m') // delete all cells and test moving cells for(let i=0; i<4; i++) { await page.forceDeleteCell(0); } for (let i=0; i<4; i++) { await page.click('#add-math-cell'); } await page.type(':nth-match(math-field.editable, 1)', '1[mm] = [m]' ); await page.type(':nth-match(math-field.editable, 2)', '2[mm] = [mm]' ); await page.type(':nth-match(math-field.editable, 3)', '3[mm] = [cm]' ); await page.type(':nth-match(math-field.editable, 4)', '4[mm] = [dm]' ); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-units-3'); expect(content).toBe('dm'); await page.click('#up-2'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0') expect(parseLatexFloat(content)).toBeCloseTo(0.001, precision) content = await page.textContent('#result-value-1') expect(parseLatexFloat(content)).toBeCloseTo(0.3, precision) content = await page.textContent('#result-value-2') expect(parseLatexFloat(content)).toBeCloseTo(2, precision) content = await page.textContent('#result-value-3') expect(parseLatexFloat(content)).toBeCloseTo(0.04, precision) await page.click('#down-0'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0') expect(parseLatexFloat(content)).toBeCloseTo(0.3, precision) content = await page.textContent('#result-value-1') expect(parseLatexFloat(content)).toBeCloseTo(0.001, precision) content = await page.textContent('#result-value-2') expect(parseLatexFloat(content)).toBeCloseTo(2, precision) content = await page.textContent('#result-value-3') expect(parseLatexFloat(content)).toBeCloseTo(0.04, precision) // test deleting cells at middle, beginning, and end await page.forceDeleteCell(1); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0') expect(parseLatexFloat(content)).toBeCloseTo(0.3, precision) content = await page.textContent('#result-value-1') expect(parseLatexFloat(content)).toBeCloseTo(2, precision) content = await page.textContent('#result-value-2') expect(parseLatexFloat(content)).toBeCloseTo(0.04, precision) await page.forceDeleteCell(0); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0') expect(parseLatexFloat(content)).toBeCloseTo(2, precision) content = await page.textContent('#result-value-1') expect(parseLatexFloat(content)).toBeCloseTo(0.04, precision) await page.forceDeleteCell(1); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); await page.forceDeleteCell(0); // test exponents await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', '2[mm]^2'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 1)', '+2[mm]^(1+3)^1/2'); for (let i = 0; i<3; i++) { await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); } await page.press(':nth-match(math-field.editable, 1)', '='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(8.0e-6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^2') await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', '2^2'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 2)', '+2^1+3^1/2'); for (let i = 0; i<3; i++) { await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); } await page.press(':nth-match(math-field.editable, 2)', '='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(10.643994170967826, precision); await page.click("#add-math-cell"); await page.type(':nth-match(math-field.editable, 3)', '3^3^3'); await page.press(':nth-match(math-field.editable, 3)', 'ArrowRight'); await page.press(':nth-match(math-field.editable, 3)', 'ArrowRight'); await page.press(':nth-match(math-field.editable, 3)', '='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(7625597484987, 13); await page.forceDeleteCell(0); await page.forceDeleteCell(0); await page.forceDeleteCell(0); // test order of operations await page.click("#add-math-cell"); await page.type(':nth-match(math-field.editable, 1)', '/36^1/2'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 1)', '2'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 1)', '*(1+2)='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); await page.forceDeleteCell(0); // test incompatible units await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', '1[meter] + 2[sec]='); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeVisible(); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', '/0.010[m]*2[mm]'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 2)', '5[sec]'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 2)', '+/(1[inches]/25.4'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 2)', ')*12[mm]'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 2)', '6[sec]'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.press(':nth-match(math-field.editable, 2)', '='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(6e-6, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m^2*s^-1'); await page.type(':nth-match(math-field.editable, 2)', '[/mm^2'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 2)', 'sec'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.press(':nth-match(math-field.editable, 2)', ']'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); await page.press(':nth-match(math-field.editable, 2)', 'ArrowLeft'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowLeft'); for(let i=0; i<3; i++){ await page.press(':nth-match(math-field.editable, 2)', 'Backspace'); } await page.type(':nth-match(math-field.editable, 2)', 'gallon'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-1 >> text=Units Mismatch')).toBeVisible(); await page.forceDeleteCell(0); await page.forceDeleteCell(0); // duplicate assignment detection await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', 'x=1') await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'x=2'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('div.bx--inline-loading__text'); expect(content).toBe('Error: Duplicate assignment of variable x'); await page.forceDeleteCell(0); await page.forceDeleteCell(0); // circular reference detection await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', 'x=y'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'y=z'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', 'z=x'); await expect(page.locator('text=Updating...')).toBeHidden(); content = await page.textContent('div.bx--inline-loading__text'); expect(content).toBe('Error: Circular reference detected'); for(let i=0; i<3; i++){ await page.forceDeleteCell(0); } // test topological sorting await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', 'x=/-b+sqrtb^2'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 1)', '-4*a*c'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 1)', '2*a'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'x=[m]'); // output is tall so button may move if clicked before update is completed // this leads to occasional test failures await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', 'a=1'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 4)', 'b=-5[m]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 5)', 'c=6[m*m]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m') for(let i=0; i<5; i++) { await page.forceDeleteCell(0); } // test pi and Euler's number await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', 'pi='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(3.14159265358979323846264338328, 14); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'e='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(2.71828182845904523536028747135, 14); // The variable name E needs to be remapped internally since E is Euler's number in Sympy await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', 'E=10'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 4)', 'E='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(10, precision); // make sure e, pi, and i cannot be reassigned (should result in syntax error) await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 5)', 'e=20'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 6)', 'pi=30'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 7)', 'i=30'); expect(await page.$eval(':nth-match(math-field.editable, 5)', el => el.classList.contains("parsing-error"))).toBeTruthy(); expect(await page.$eval(':nth-match(math-field.editable, 6)', el => el.classList.contains("parsing-error"))).toBeTruthy(); expect(await page.$eval(':nth-match(math-field.editable, 7)', el => el.classList.contains("parsing-error"))).toBeTruthy(); for (let i=0; i<7; i++) { await page.forceDeleteCell(0); } // test logarithmic functions // first check that paranthesis are required for functions await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', 'ln 20='); expect(await page.$eval(':nth-match(math-field.editable, 1)', el => el.classList.contains("parsing-error"))).toBeTruthy(); await page.forceDeleteCell(0); // now check natural logarithm await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', 'ln(e^2.1'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 1)', ')='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2.1, precision); // make sure that providing inits to input argument to ln results in dimension error await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'ln(5[inches])='); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-1 >> text=Dimension Error: Unitless input and base required for log and ln functions')).toBeVisible(); // check base 10 log await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', 'log(100)='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); // check log with specified base await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 4)', 'log_2'); await page.press(':nth-match(math-field.editable, 4)', 'Tab'); await page.type(':nth-match(math-field.editable, 4)', '8'); await page.press(':nth-match(math-field.editable, 4)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 4)', '='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); // make sure log base is unitless await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 5)', 'log_2[inches]'); await page.press(':nth-match(math-field.editable, 5)', 'Tab'); await page.type(':nth-match(math-field.editable, 5)', '8'); await page.press(':nth-match(math-field.editable, 5)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 5)', '='); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-4 >> text=Dimension Error: Unitless input and base required for log and ln functions')).toBeVisible(); // check log without slash await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 6)', 'log(1000)='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); // stress test automatic back slash insertion await page.click('#add-math-cell'); await page.setLatex(6, String.raw`-1\cdot cos\left(arctan\left(1\right)\cdot 4\right)+\frac{ln\left(e^{log\left(100\right)}\right)^{log\left(100\right)}}{ln\left(e^{2}\right)}=`); await page.keyboard.press('Escape'); // force backslash insertion await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-6'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); for (let i=0; i<7; i++) { await page.forceDeleteCell(0); } // test scientific notation await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', '10e-1[m]+1.E+16*x-1e17[m]=[mm]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'x=1.0e1[m]') await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1000, precision); await page.forceDeleteCell(0); await page.forceDeleteCell(0); // don't attempt unit conversion on result that is not finite await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', '1[m]/0'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 1)', '=[inch]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=User Units Not Supported for Symbolic Results')).toBeVisible(); await page.forceDeleteCell(0); // test abs await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', '|-12[inches]|=[feet]'); //await page.type(':nth-match(math-field.editable, 1)', '12[inches]=[feet]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); await page.forceDeleteCell(0); // test negative exponent for units await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', '1[mm^-2'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight') await page.type(':nth-match(math-field.editable, 1)', ']=[inch^-2'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight') await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(645.16, precision); await page.forceDeleteCell(0); // test units with 1 in the numerator await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', '1[mm^-2'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight') await page.type(':nth-match(math-field.editable, 1)', ']=[inch^-2'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight') await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(645.16, precision); await page.forceDeleteCell(0); // test inverse dimension await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', '1[1/sec'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight') await page.type(':nth-match(math-field.editable, 1)', ']=') await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-units-0'); expect(content).toBe('s^-1') await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', '1[1/sec'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 2)', ']=[min^-1'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.press(':nth-match(math-field.editable, 2)', ']'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(60, precision); await page.forceDeleteCell(0); await page.forceDeleteCell(0); // test divide by zero with substitution (related to sympy issue #21076) await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', '1[meter]/0[foot]'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.press(':nth-match(math-field.editable, 1)', '='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe('\\tilde{\\infty}'); await page.forceDeleteCell(0); // check numerical precision await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', '.1+.2-.3='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe('0'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'x=.1[m]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', 'y=.2[m]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 4)', 'z=.3[m]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 5)', 'x+y-z=[m]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-4'); expect(content).toBe('=0'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 6)', 's=.1[inch]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 7)', 't=.2[inch]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 8)', 'u=.3[inch]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 9)', 's+t-u=[inch]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-8'); expect(content).toBe('=0'); content = await page.textContent('#result-units-8'); expect(content).toBe('inch'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 10)', 'xx=1[inch]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 11)', 'yy=2[inch]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 12)', 'zz=1e-200[inch]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 13)', 'w-yy=[inch]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 14)', 'w=zz+2*xx'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-12'); expect(content).toBe('=1\\times 10^{-200}'); for(let i=0; i<14; i++){ await page.forceDeleteCell(0); } // test unitless result bug when attempting user unit conversion await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', 'x=10[inches]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'y=2'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', 'x/y'); await page.press(':nth-match(math-field.editable, 3)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 3)', '=[inches]'); await page.type(':nth-match(math-field.editable, 2)', '[m]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-2 >> text=Units Mismatch')).toBeVisible(); for(let i=0; i<3; i++){ await page.forceDeleteCell(0); } // test units in exponents await page.click('#add-math-cell'); await page.setLatex(0, String.raw`10\left[inches\right]^{1\left[\frac{m}{sec}\right]\cdot 2\left[\frac{sec}{m}\right]}=\left[inches^2\right]`); await page.click('#add-math-cell'); await page.setLatex(1, String.raw`10\left[inches\right]^{\left(1\left[\frac{m}{sec}\right]\cdot 2\left[\frac{sec}{m}\right]\right)^{2\left[\frac{kelvin}{sec}\right]\cdot 1\left[\frac{sec}{kelvin}\right]}}=\left[inches^4\right]`); await page.click('#add-math-cell'); await page.setLatex(2, String.raw`10^{1\left[\frac{m}{sec}\right]\cdot 2\left[\frac{sec}{m}\right]}=`); await page.click('#add-math-cell'); await page.setLatex(3, String.raw`2^{3\left[sec\right]}=`); await page.click('#add-math-cell'); await page.setLatex(4, String.raw`2^{3^{1\left[m\right]}}=`); await page.click('#add-math-cell'); await page.setLatex(5, String.raw`10\left[miles\right]^{.2\left[\frac{cm}{mm}\right]}=\left[miles^2\right]`); await page.click('#add-math-cell'); await page.setLatex(6, String.raw`10\left[miles\right]^{.2\left[\frac{cm}{sec}\right]}=\left[miles^2\right]`); await page.click('#add-math-cell'); await page.setLatex(7, String.raw`x=10^{1\left[\frac{m}{sec}\right]\cdot 2\left[\frac{sec}{m}\right]}`); await page.click('#add-math-cell'); await page.setLatex(8, String.raw`x=`); await page.click('#add-math-cell'); await page.setLatex(9, String.raw`y=2^{3^{1\left[m\right]}}`); await page.click('#add-math-cell'); await page.setLatex(10, String.raw`y=`); await page.click('#add-math-cell'); await page.setLatex(11, String.raw`\left(2^{2\left[\frac{mm}{mm}\right]+2}\right)^{\frac{1\left[mm\right]}{4\left[mm\right]}+\frac{1}{4}}=`); await page.click('#add-math-cell'); await page.setLatex(12, String.raw`4^{1\left[m\right]\cdot 2\left[m\right]^{-1}}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-units-0'); expect(content).toBe('inches^2') content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(100, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('inches^4') content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(10000, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('') content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(100, precision); await expect(page.locator('#cell-3 >> text=Dimension Error: Exponent Not Dimensionless')).toBeVisible(); await expect(page.locator('#cell-4 >> text=Dimension Error: Exponent Not Dimensionless')).toBeVisible(); content = await page.textContent('#result-units-5'); expect(content).toBe('miles^2'); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(100, precision); await expect(page.locator('#cell-6 >> text=Dimension Error: Exponent Not Dimensionless')).toBeVisible(); content = await page.textContent('#result-units-8'); expect(content).toBe('') content = await page.textContent('#result-value-8'); expect(parseLatexFloat(content)).toBeCloseTo(100, precision); await expect(page.locator('#cell-10 >> text=Dimension Error: Exponent Not Dimensionless')).toBeVisible(); content = await page.textContent('#result-units-11'); expect(content).toBe('') content = await page.textContent('#result-value-11'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-12'); expect(content).toBe('') content = await page.textContent('#result-value-12'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); for (let i=0; i<13; i++) { await page.forceDeleteCell(0); } // make sure that SymPy reserved names get renamed await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', 'Expr='); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'symbols='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe('Expr') content = await page.textContent('#result-value-1'); expect(content).toBe('symbols') await page.forceDeleteCell(0); await page.forceDeleteCell(0); // test virtual keyboard await page.click('#add-math-cell'); await page.click('#add-math-cell'); await page.click('button:has-text("√x​")'); await page.type(':nth-match(math-field.editable,2)', 'x'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 2)', '='); await page.type(':nth-match(math-field.editable, 1)', 'x='); await page.click('button:has-text("π​")'); // make sure keyboard has jumped to cell with focus await page.click('#add-math-cell'); await page.click('button.tab:has-text("f(x)")'); await page.click('button:has-text("cot")'); await page.locator('button').filter({ hasText: '123' }).click(); await page.click('button:has-text("π​")'); await page.type(':nth-match(math-field.editable, 3)', '/4'); await page.press(':nth-match(math-field.editable, 3)', 'ArrowRight'); await page.press(':nth-match(math-field.editable, 3)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 3)', '='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(pi), precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1.0, precision); await page.forceDeleteCell(0); await page.forceDeleteCell(0); await page.forceDeleteCell(0); // test virtual keyboard with selected text await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable,1)', 'pi'); await page.press(':nth-match(math-field.editable,1)', 'Shift+ArrowLeft'); await page.press(':nth-match(math-field.editable,1)', 'Shift+ArrowLeft'); await page.click('button.tab:has-text("f(x)")'); await page.click('button:has-text("cos")'); await page.press(':nth-match(math-field.editable,1)', 'Shift+ArrowLeft'); await page.press(':nth-match(math-field.editable,1)', 'Shift+ArrowLeft'); await page.press(':nth-match(math-field.editable,1)', 'Shift+ArrowLeft'); await page.press(':nth-match(math-field.editable,1)', 'Shift+ArrowLeft'); await page.press(':nth-match(math-field.editable,1)', 'Shift+ArrowLeft'); await page.locator('button').filter({ hasText: '123' }).click(); await page.click('button:has-text("/")'); await page.type(':nth-match(math-field.editable,1)', '2'); await page.press(':nth-match(math-field.editable,1)', 'ArrowRight'); await page.type(':nth-match(math-field.editable,1)', '='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(-0.5, precision); }); test('Test exponents', async () => { await page.setLatex(0, String.raw`1\left[m^{\frac{1}{3}}\right]\cdot 1\left[m^{\frac{2}{3}}\right]=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-units-0'); expect(content).toBe('m'); await page.forceDeleteCell(0); // test single digit exponent followed by a digit await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', '1^2'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 1)', '2='); await page.waitForSelector('text=Updating...', {state: 'detached'}); expect(await page.$eval(':nth-match(math-field.editable, 1)', el => el.classList.contains("parsing-error"))).toBeTruthy(); await page.forceDeleteCell(0); // test negative exponent on number with assigned units await page.click('#add-math-cell'); await page.setLatex(0, String.raw`\frac{1300\left[N\right]\cdot 80\left[mm\right]\cdot 34\left[mm\right]\cdot \frac{1}{2}}{\frac{16\left[mm\right]\cdot 34\left[mm\right]^{3}}{12}}=\left[MPa\right]`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo((1300*80*34*.5)*(12/(16*34**3)), precision); content = await page.textContent('#result-units-0'); expect(content).toBe('MPa'); await page.forceDeleteCell(0); // test variable in exponent await page.click('#add-math-cell'); await page.setLatex(0, String.raw`1^{x}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1.0, precision); }); test('Test function notation with exponents and units', async () => { await page.setLatex(0, String.raw`y\left(x=2\left[inches\right],\ t=3\left[\frac{m}{sec}\right],\ s=1\left[\frac{sec}{m}\right],\ j=2\left[\frac{m}{s}\right],k=1\left[\frac{s}{m}\right]\right)=\left[inches^{9}\right]`); await page.click('#add-math-cell'); await page.setLatex(1, String.raw`y=x^{\left(s\cdot t\right)^{j\cdot k}}`); await page.click('#add-math-cell'); await page.setLatex(2, String.raw`z=2\cdot y\left(x=2\left[inches\right],\ t=2\left[\frac{m}{sec}\right],\ s=1\left[\frac{sec}{m}\right],\ j=2\left[\frac{m}{s}\right],k=1\left[\frac{s}{m}\right]\right)`); await page.click('#add-math-cell'); await page.setLatex(3, String.raw`z=\left[inches^{4}\right]`); await page.click('#add-math-cell'); await page.setLatex(4, String.raw`y\left(x=2\left[inches\right],\ t=3\left[\frac{m}{sec}\right],\ s=1\left[\frac{sec}{m}\right],\ j=2\left[\frac{1}{s}\right],k=1\left[\frac{s}{m}\right]\right)=\left[inches^{9}\right]`); await page.click('#add-math-cell'); await page.setLatex(5, String.raw`y\left(x=2\left[inches\right],\ t=3\left[\frac{1}{sec}\right],\ s=1\left[\frac{sec}{m}\right],\ j=2\left[\frac{m}{s}\right],k=1\left[\frac{s}{m}\right]\right)=\left[inches^{9}\right]`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(512, precision-1); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(32, precision); await expect(page.locator('#cell-4 >> text=Dimension Error: Exponent Not Dimensionless')).toBeVisible(); await expect(page.locator('#cell-5 >> text=Dimension Error: Exponent Not Dimensionless')).toBeVisible(); }); test('Test function notation with exponents and units and nested functions', async () => { await page.setLatex(0, String.raw`t\left(s=y\left(x=2\left\lbrack in\right\rbrack\right)\cdot1\left\lbrack in\right\rbrack\right)=`); await page.click('#add-math-cell'); await page.setLatex(1, String.raw`t=2^{\frac{s}{1\left\lbrack in\right\rbrack}}`); await page.click('#add-math-cell'); await page.setLatex(2, String.raw`y=3^{\frac{x}{1\left\lbrack in\right\rbrack}}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(512, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test zero canceling bug with exponent', async () => { await page.setLatex(0, String.raw`y=\frac{0\left\lbrack m\right\rbrack}{2^{x}}`); await page.click('#add-math-cell'); await page.setLatex(1, String.raw`y\left(x=1\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(0, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); }); test('Test floating point exponent rounding', async () => { // check matching equivalent dims for adding await page.setLatex(0, String.raw`1\left\lbrack m\right\rbrack+1\left\lbrack\frac{N^{\frac13}}{m^{\frac23}}\right\rbrack\cdot1\left\lbrack\frac{m^{\frac53}}{N^{\frac13}}\right\rbrack=`); await page.click('#add-math-cell'); await page.setLatex(1, String.raw`1\left\lbrack kg\cdot s^{.0000000000001}\right\rbrack+2\left\lbrack kg\right\rbrack=`); await page.click('#add-math-cell'); await page.setLatex(2, String.raw`1\left\lbrack kg\cdot s^{.000000000001}\right\rbrack+2\left\lbrack kg\right\rbrack=`); // check matching equivalent dims for sum function await page.click('#add-math-cell'); await page.setLatex(3, String.raw`\mathrm{sum}\left(1\left\lbrack m\right\rbrack,1\left\lbrack\frac{N^{\frac13}}{m^{\frac23}}\right\rbrack\cdot3\left\lbrack\frac{m^{\frac53}}{N^{\frac13}}\right\rbrack\right)=`); await page.click('#add-math-cell'); await page.setLatex(4, String.raw`\mathrm{sum}\left(1\left\lbrack K\cdot s^{.0000000000001}\right\rbrack,4\left\lbrack K\right\rbrack\right)=`); await page.click('#add-math-cell'); await page.setLatex(5, String.raw`\mathrm{sum}\left(1\left\lbrack K\cdot s^{.000000000001}\right\rbrack,4\left\lbrack K\right\rbrack\right)=`); // check small exponent rounding for dimensionless exponent check await page.click('#add-math-cell'); await page.setLatex(6, String.raw`6^{1\left\lbrack s^{.0000000000001}\right\rbrack}=`); await page.click('#add-math-cell'); await page.setLatex(7, String.raw`6^{1\left\lbrack s^{.000000000001}\right\rbrack}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('kg'); await expect(page.locator('#cell-2 >> text=Dimension Error: Only equivalent dimensions can be added or subtracted')).toBeVisible(); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m'); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-units-4'); expect(content).toBe('K'); await expect(page.locator('#cell-5 >> text=Dimension Error: sum function requires that all input values have the same units')).toBeVisible(); content = await page.textContent('#result-value-6'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-6'); expect(content).toBe(''); await expect(page.locator('#cell-7 >> text=Dimension Error: Exponent Not Dimensionless')).toBeVisible(); }); test('Test function notation with integrals', async () => { await page.setLatex(0, String.raw`Ixx=\int _{-\frac{b}{2}}^{\frac{b}{2}}\left(\int _{-\frac{h}{2}}^{\frac{h}{2}}\left(y^{2}\right)\mathrm{d}\left(y\right)\right)\mathrm{d}\left(x\right)`); await page.click('#add-math-cell'); await page.setLatex(1, String.raw`Ixx=`); await page.click('#add-math-cell'); await page.setLatex(2, String.raw`Ixx\left(b=3\left[inch\right],\ h=2\left[inch\right]\right)=\left[inch^{4}\right]`); await page.click('#add-math-cell'); await page.setLatex(3, String.raw`doubleIxx\ =\ 2\cdot Ixx\left(b=6\left[mm\right],\ h=2\left[mm\right]\right)`); await page.click('#add-math-cell'); await page.setLatex(4, String.raw`doubleIxx=\left[mm^{4}\right]`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(content).toBe('\\frac{b \\cdot h^{3}}{12}'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); }); test('Test greek characters as variables', async () => { await page.type(':nth-match(math-field.editable, 1)', 'alpha+beta+gamma+delta+epsilon+zeta+eta+theta+iota+kappa+lambda+' + 'mu+nu+xi+rho+sigma+tau+phi+chi+psi+omega+Gamma+Delta+Theta+Lambda+Xi+Pi+Sigma+Upsilon+Phi+Psi+Omega='); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button.keyboard:has-text("α​")'); await page.type(':nth-match(math-field.editable, 2)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button.keyboard:has-text("β")'); await page.type(':nth-match(math-field.editable, 3)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button.keyboard:has-text("γ")'); await page.type(':nth-match(math-field.editable, 4)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("δ")'); await page.type(':nth-match(math-field.editable, 5)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("ϵ")'); await page.type(':nth-match(math-field.editable, 6)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("ζ")'); await page.type(':nth-match(math-field.editable, 7)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("η")'); await page.type(':nth-match(math-field.editable, 8)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("θ")'); await page.type(':nth-match(math-field.editable, 9)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("ι")'); await page.type(':nth-match(math-field.editable, 10)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("κ")'); await page.type(':nth-match(math-field.editable, 11)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("λ")'); await page.type(':nth-match(math-field.editable, 12)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("μ")'); await page.type(':nth-match(math-field.editable, 13)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("ξ")'); await page.type(':nth-match(math-field.editable, 14)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("ρ")'); await page.type(':nth-match(math-field.editable, 15)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button.keyboard:has-text("σ")'); await page.type(':nth-match(math-field.editable, 16)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("τ")'); await page.type(':nth-match(math-field.editable, 17)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("ν")'); await page.type(':nth-match(math-field.editable, 18)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("ϕ")'); await page.type(':nth-match(math-field.editable, 19)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("χ")'); await page.type(':nth-match(math-field.editable, 20)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("ψ")'); await page.type(':nth-match(math-field.editable, 21)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("ω")'); await page.type(':nth-match(math-field.editable, 22)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click(':nth-match(button.keyboard:has-text("Γ​"), 2)'); await page.type(':nth-match(math-field.editable, 23)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click(':nth-match(button:has-text("Δ"), 2)'); await page.type(':nth-match(math-field.editable, 24)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click(':nth-match(button:has-text("Θ"), 2)'); await page.type(':nth-match(math-field.editable, 25)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click(':nth-match(button:has-text("Λ"), 2)'); await page.type(':nth-match(math-field.editable, 26)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click(':nth-match(button:has-text("Ξ"), 2)'); await page.type(':nth-match(math-field.editable, 27)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click(':nth-match(button:has-text("Π​"), 2)'); await page.type(':nth-match(math-field.editable, 28)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click(':nth-match(button.keyboard:has-text("Σ"), 2)'); await page.type(':nth-match(math-field.editable, 29)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("Υ")'); await page.type(':nth-match(math-field.editable, 30)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click('button:has-text("Φ")'); await page.type(':nth-match(math-field.editable, 31)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click(':nth-match(button:has-text("Ψ"), 2)'); await page.type(':nth-match(math-field.editable, 32)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click("#add-math-cell"); await page.click('button.tab:has-text("αβγ")'); await page.click(':nth-match(button:has-text("Ω"), 2)'); await page.type(':nth-match(math-field.editable, 33)', '=1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(32, precision); }); test('Test variable names with subscripts', async () => { await page.type(':nth-match(math-field.editable, 1)', 'v_initial'); await page.press(':nth-match(math-field.editable, 1)', 'Tab'); await page.type(':nth-match(math-field.editable, 1)', '=10'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'real_root'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 2)', '=2'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', 'b_1'); await page.press(':nth-match(math-field.editable, 3)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 3)', '=2'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 4)', 'real_root'); await page.press(':nth-match(math-field.editable, 4)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 4)', '*v_initial'); await page.press(':nth-match(math-field.editable, 4)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 4)', '*b_1'); await page.press(':nth-match(math-field.editable, 4)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 4)', '='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(40, precision); // check to ensure that invalid variables result in a syntax error await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 5)', '1a='); await page.click('#add-math-cell'); // subscript that begins with number and contains letters now allowed and should not be an error await page.type(':nth-match(math-field.editable, 6)', 'a_1b'); await page.press(':nth-match(math-field.editable, 6)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 6)', '='); await page.click('#add-math-cell'); // This will no longer be an error since multiple greek symbols are now allowed await page.click('button.tab:has-text("αβγ")'); await page.click('button.keyboard:has-text("α​")'); await page.click('button.keyboard:has-text("β")'); await page.type(':nth-match(math-field.editable, 7)', '=1'); // this one should not be an error (greek variable with valid subscript) await page.click('#add-math-cell'); await page.click('button.tab:has-text("αβγ")'); await page.click('button.keyboard:has-text("α​")'); await page.type(':nth-match(math-field.editable, 8)', '_10'); await page.press(':nth-match(math-field.editable, 8)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 8)', '='); // next 2 should be valid as well (letter followed by number for name or subscript) await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 9)', 'a1='); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 10)', 'a_b1'); await page.press(':nth-match(math-field.editable, 10)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 10)', '='); expect(await page.$eval(':nth-match(math-field.editable, 5)', el => el.classList.contains("parsing-error"))).toBeTruthy(); expect(await page.$eval(':nth-match(math-field.editable, 6)', el => el.classList.contains("parsing-error"))).toBeFalsy(); expect(await page.$eval(':nth-match(math-field.editable, 7)', el => el.classList.contains("parsing-error"))).toBeFalsy(); expect(await page.$eval(':nth-match(math-field.editable, 8)', el => el.classList.contains("parsing-error"))).toBeFalsy(); expect(await page.$eval(':nth-match(math-field.editable, 9)', el => el.classList.contains("parsing-error"))).toBeFalsy(); expect(await page.$eval(':nth-match(math-field.editable, 10)', el => el.classList.contains("parsing-error"))).toBeFalsy(); }); test('Make sure results are updating after adding a documentation cell', async () => { await page.type(':nth-match(math-field.editable, 1)', 'x=3'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'x='); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.click('#add-documentation-cell'); await page.type('div.editor div', `Sheet 1\nπ`); await page.press('div.editor div', 'Enter'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(3.0, precision); }); test("Test complicated function evaluation", async () => { await page.setLatex(0, String.raw`volume\ =\ h\cdot area`); await page.click('#add-math-cell'); await page.setLatex(1, String.raw`area=l\cdot w`); await page.click('#add-math-cell'); await page.setLatex(2, String.raw`y=-\frac{g\cdot \sec\left(theta\right)^{2}}{2\cdot InitialVelocity^{2}}\cdot x^{2}+x\cdot \tan\left(theta\right)`); await page.click('#add-math-cell'); await page.setLatex(3, String.raw`g=9.81\left[\frac{m}{sec^{2}}\right]`); await page.click('#add-math-cell'); await page.setLatex(4, String.raw`y\left(theta=45\left[degrees\right],\ InitialVelocity=1200\left[\frac{ft}{sec}\right],\ x=100\left[yards\right]\right)=\left[feet\right]`); await page.click('#add-math-cell'); await page.setLatex(5, String.raw`area=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo((-(9.81*(100/1.09361)**2)/(cos(45*pi/180)**2*2*(1200/3.28084)**2)+ (100/1.09361)*tan(45*(45*pi/180)))*3.28084, 2); content = await page.textContent('#result-value-5'); expect(content).toBe('l \\cdot w'); }); test('Test nested function', async () => { await page.setLatex(0, String.raw`y=x+b`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`s=y\left(x=1\left\lbrack m\right\rbrack\right)`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`s\left(b=3\left\lbrack m\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(4); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); }); test('Test unit exponent rounding', async () => { await page.setLatex(0, String.raw`C=272\cdot \left(\frac{S_{2}}{1e6\left[Pa\right]}\right)^{-.0995}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`S_{1}=400\left[MPa\right]`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`S_{2}=0.5\cdot S_{1}`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`C\cdot \frac{S_{2}}{190\left[MPa\right]}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`C\cdot S_{2}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-units-3'); expect(content).toBe(''); content = await page.textContent('#result-units-4'); expect(content).toBe('Pa'); }); test('Test unit names that contain numbers', async () => { await page.setLatex(0, String.raw`1\left[cmH2O\right]=\left[mmH2O\right]`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`1\left[m2\right]=\left[m^{2}\right]`); await page.waitForSelector('.status-footer', { state: 'detached' }); let content = await page.textContent('#result-value-0'); expect(content).toBe('=10'); content = await page.textContent('#result-units-0'); expect(content).toBe('mmH2O'); content = await page.textContent('#result-value-1'); expect(content).toBe('=1'); content = await page.textContent('#result-units-1'); expect(content).toBe('m^2'); }); test('Test unit cancelling issues', async () => { // subtract one value unitless and the other without units await page.setLatex(0, String.raw`\left(1\left[\frac{m}{m}\right]-1\right)\cdot 1\left[m\right]=`); // subtract two values with units await page.click('#add-math-cell'); await page.setLatex(1, String.raw`5\left[mm\right]-4\left[mm\right]=`); await page.waitForSelector('.status-footer', { state: 'detached' }); let content = await page.textContent('#result-value-0'); expect(content).toBe('0'); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); content = await page.textContent('#result-value-1'); expect(content).toBe('0.001'); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); }); test('Test syntax error Show Error button', async ({ browserName }) => { // add many empty math cells for (let i = 0; i < 20; i++) { await page.locator('math-field.editable').nth(i).press('Enter'); } // add a syntax error to first and last cells await page.setLatex(0, 'x'); await page.setLatex(19, 'x'); // click the show error button to jump to first syntax error await page.locator('text=Show Error').click(); // first cell should now be visible await expect(page.locator('#cell-0 button.bx--tooltip__trigger')).toBeFocused({timeout: 1000}); }); test('Test temperature conversions', async () => { // make sure negative temperatures are converted correctly await page.setLatex(0, '-40[degF]=[degC]'); // test celsius delta await page.locator('#add-math-cell').click(); await page.setLatex(1, '-29[degC] - -30[celsius]=[kelvin]'); // test fahrenheit delta await page.locator('#add-math-cell').click(); await page.setLatex(2, '50[fahrenheit] - 49[degF]='); // test absolute temperature conversion for celsius await page.locator('#add-math-cell').click(); await page.setLatex(3, '10[degC]='); // test absolute temperature conversion for rankine await page.locator('#add-math-cell').click(); await page.setLatex(4, '1[degF]=[degR]'); // test absolute back to celsius await page.locator('#add-math-cell').click(); await page.setLatex(5, '263.15[K]=[degC]'); // test absolute back to fahreinheit await page.locator('#add-math-cell').click(); await page.setLatex(6, '233.15[K]=[degF]'); // make sure derived temp dims treated as deltas await page.locator('#add-math-cell').click(); await page.setLatex(7, String.raw`2\left[\frac{1}{degC}\right]=`); await page.locator('#add-math-cell').click(); await page.setLatex(8, String.raw`1\left[degF\cdot sec\right]=`); await page.waitForSelector('text=Loading Pyodide...', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(-40, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('degC'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('kelvin'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(5/9, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('K'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(283.15, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('K'); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(460.67, precision-1); content = await page.textContent('#result-units-4'); expect(content).toBe('degR'); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(-10, precision); content = await page.textContent('#result-units-5'); expect(content).toBe('degC'); content = await page.textContent('#result-value-6'); expect(parseLatexFloat(content)).toBeCloseTo(-40, precision); content = await page.textContent('#result-units-6'); expect(content).toBe('degF'); content = await page.textContent('#result-value-7'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-7'); expect(content).toBe('K^-1'); content = await page.textContent('#result-value-8'); expect(parseLatexFloat(content)).toBeCloseTo(5/9, precision); content = await page.textContent('#result-units-8'); expect(content).toBe('s^1*K^1'); }); test('Check parsing error handling impact on displayed results', async () => { await page.setLatex(0, 'x=5.11'); await page.locator('#add-math-cell').click() await page.setLatex(1, 'x='); await page.locator('#add-math-cell').click() await page.waitForSelector('.status-footer', { state: 'detached'}); // check query result in cell 1 let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(5.11, precision); // create a syntax error in cell 2, should still see result await page.locator('#cell-2 >> math-field.editable').type('a'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(5.11, precision); // leave cell, result should be made hidden await page.keyboard.press('Escape'); await page.locator('#cell-1 >> math-field:not(.editable)').waitFor({state: "hidden", timeout: 500}); }); test('Test single character square root', async () => { await page.locator('#cell-0 >> math-field.editable').type('sqrt4'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('='); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').type('sqrta'); await page.locator('#cell-1 >> math-field.editable').press('Tab'); await page.locator('#cell-1 >> math-field.editable').type('='); await page.locator('#add-math-cell').click(); await page.locator('#cell-2 >> math-field.editable').type('a=9'); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-value-1'); expect(parseFloat(content)).toBeCloseTo(3, precision); }); test('Test disabling of latex rendering modifiers', async () => { await page.locator('#cell-0 >> math-field.editable').type('a_vertical'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('='); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('a_{vertical}'); }); test('Test inverse', async () => { await page.locator('#cell-0 >> math-field.editable').type('2^-1'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('='); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').type('2[m]^-1'); await page.locator('#cell-1 >> math-field.editable').press('Tab'); await page.locator('#cell-1 >> math-field.editable').type('='); await page.locator('#add-math-cell').click(); await page.locator('#cell-2 >> math-field.editable').type('a^-1'); await page.locator('#cell-2 >> math-field.editable').press('Tab'); await page.locator('#cell-2 >> math-field.editable').type('='); await page.locator('#add-math-cell').click(); await page.locator('#cell-3 >> math-field.editable').type('a=2[m]'); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseFloat(content)).toBeCloseTo(0.5, precision); content = await page.textContent('#result-value-1'); expect(parseFloat(content)).toBeCloseTo(0.5, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m^-1'); content = await page.textContent('#result-value-2'); expect(parseFloat(content)).toBeCloseTo(0.5, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m^-1'); }); test('Negative grouping', async () => { await page.locator('#cell-0 >> math-field.editable').type('a+(b-a)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').type('a-(b-a)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-2 >> math-field.editable').type('a-b-a='); await page.locator('#add-math-cell').click(); await page.locator('#cell-3 >> math-field.editable').type('-a-(b+a)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-4 >> math-field.editable').type('-a+-(b+a)='); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('b'); content = await page.textContent('#result-value-1'); expect(content).toBe('2 \\cdot a - b'); content = await page.textContent('#result-value-2'); expect(content).toBe('- b'); content = await page.textContent('#result-value-3'); expect(content).toBe('- 2 \\cdot a - b'); content = await page.textContent('#result-value-3'); expect(content).toBe('- 2 \\cdot a - b'); }); test('Negative grouping with fractions', async () => { await page.setLatex(0, String.raw`a+\frac{b-a}{1}=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a-\frac{b-a}{1}=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`-a-\frac{b+a}{1}=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`-a+-\frac{b+a}{1}=`); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('b'); content = await page.textContent('#result-value-1'); expect(content).toBe('2 \\cdot a - b'); content = await page.textContent('#result-value-3'); expect(content).toBe('- 2 \\cdot a - b'); content = await page.textContent('#result-value-3'); expect(content).toBe('- 2 \\cdot a - b'); }); test('Negative grouping with fractions with negative denominator', async () => { await page.setLatex(0, String.raw`a+\frac{b-a}{-1}=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a-\frac{b-a}{-1}=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`-a-\frac{b+a}{-1}=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`-a+-\frac{b+a}{-1}=`); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('2 \\cdot a - b'); content = await page.textContent('#result-value-1'); expect(content).toBe('b'); content = await page.textContent('#result-value-3'); expect(content).toBe('b'); content = await page.textContent('#result-value-3'); expect(content).toBe('b'); }); test('Test cell move inlineShortcuts bug', async () => { await page.locator('#add-math-cell').click(); await page.locator('#up-1').click(); await page.locator('#cell-0 >> math-field.editable').type('1[mm]=[mm]'); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('mm'); }); test('Test angular frequency conversions', async () => { await page.setLatex(0, String.raw`1\left\lbrack\frac{rad}{sec}\right\rbrack=\left\lbrack Hz\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`1\left\lbrack rad\right\rbrack\cdot\sqrt{\frac{36\left\lbrack\frac{N}{m}\right\rbrack}{1\left\lbrack kg\right\rbrack}}=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`1\left\lbrack rad\right\rbrack\cdot\sqrt{\frac{36\left\lbrack\frac{N}{m}\right\rbrack}{1\left\lbrack kg\right\rbrack}}=\left\lbrack\frac{cycles}{sec}\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\frac{1}{2\cdot \pi}\cdot\sqrt{\frac{36\left\lbrack\frac{N}{m}\right\rbrack}{1\left\lbrack kg\right\rbrack}}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`1\left\lbrack\frac{rad}{cycle}\right\rbrack\cdot\sqrt{\frac{36\left\lbrack\frac{N}{m}\right\rbrack}{1\left\lbrack kg\right\rbrack}}=`); await page.waitForSelector('.status-footer', { state: 'detached'}); await expect(page.locator("#cell-0 >> text=Units Mismatch")).toBeAttached(); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('s^-1*rad^1'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(3/pi, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('(cycles)/(sec)'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(3/pi, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('s^-1'); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(3/pi, precision); content = await page.textContent('#result-units-4'); expect(content).toBe('s^-1'); }); test('Test cell drag to reorder', async () => { await page.locator('#cell-0 >> math-field.editable').type("0="); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').type("1="); await page.locator('#add-math-cell').click(); await page.locator('#cell-2 >> math-field.editable').type("2="); await page.locator('#add-math-cell').click(); await page.locator('#cell-3 >> math-field.editable').type("3="); await page.locator('#add-math-cell').click(); await page.locator('#cell-4 >> math-field.editable').type("4="); await page.locator('#add-math-cell').click(); await page.locator('#cell-5 >> math-field.editable').type("5="); await page.locator('#add-math-cell').click(); await page.locator('#cell-6 >> math-field.editable').type("6="); await page.locator('#cell-container-0 >> button[title="Drag to Move Cell"]') .dragTo(page.locator('#cell-container-6 >> button[title="Drag to Move Cell"]')); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-value-6'); expect(parseLatexFloat(content)).toBeCloseTo(0, precision); await page.locator('#cell-container-6 >> button[title="Drag to Move Cell"]') .dragTo(page.locator('#cell-container-5 >> button[title="Drag to Move Cell"]')); await page.waitForSelector('.status-footer', { state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(0, precision); content = await page.textContent('#result-value-6'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); await page.locator('#cell-container-5 >> button[title="Drag to Move Cell"]') .dragTo(page.locator('#cell-container-0 >> button[title="Drag to Move Cell"]')); await page.waitForSelector('.status-footer', { state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0, precision); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-value-6'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); await page.locator('#cell-container-1 >> button[title="Drag to Move Cell"]') .dragTo(page.locator('#cell-container-2 >> button[title="Drag to Move Cell"]')); await page.waitForSelector('.status-footer', { state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0, precision); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-value-6'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); }); test.skip('Test zero placeholder', async () => { await page.setLatex(0, String.raw`0=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`0+1=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`0\left\lbrack m\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`0\cdot1\left\lbrack m\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`0\cdot1\left\lbrack m\right\rbrack+1\left\lbrack m\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`x^0=`); await page.locator('#add-math-cell').click(); await page.setLatex(6, String.raw`x^{0\left\lbrack m\right\rbrack}=`); await page.locator('#add-math-cell').click(); await page.setLatex(7, String.raw`x^{0\cdot1\left\lbrack m\right\rbrack}=`); await page.locator('#add-math-cell').click(); await page.setLatex(8, String.raw`\begin{bmatrix}1\\ 0\end{bmatrix}\cdot1\left\lbrack m\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(9, String.raw`1\left\lbrack m\right\rbrack+0=`); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('0'); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent('#result-value-1'); expect(content).toBe('1'); content = await page.textContent('#result-units-1'); expect(content).toBe(''); content = await page.textContent('#result-value-2'); expect(content).toBe('0'); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); content = await page.textContent('#result-value-3'); expect(content).toBe('0'); content = await page.textContent('#result-units-3'); expect(content).toBe('m'); content = await page.textContent('#result-value-4'); expect(content).toBe('1'); content = await page.textContent('#result-units-4'); expect(content).toBe('m'); content = await page.textContent('#result-value-5'); expect(content).toBe('1'); content = await page.textContent('#result-units-5'); expect(content).toBe(''); await expect(page.locator('#cell-6 >> text=Dimension Error: Exponent Not Dimensionless')).toBeVisible(); await expect(page.locator('#cell-7 >> text=Dimension Error: Exponent Not Dimensionless')).toBeVisible(); content = await page.textContent('#result-value-8'); expect(content).toBe(String.raw`\begin{bmatrix} 1\left\lbrack m\right\rbrack \\ 0\left\lbrack m\right\rbrack \end{bmatrix}`); await expect(page.locator('#cell-9 >> text=Dimension Error')).toBeVisible(); }); test('Test factorial function', async () => { await page.setLatex(0, String.raw`4!=`); await page.click('#add-math-cell'); await page.setLatex(1, String.raw`5-4.000!=`); await page.click('#add-math-cell'); await page.setLatex(2, String.raw`\frac{10!}{9!}=`); await page.click('#add-math-cell'); await page.setLatex(3, String.raw`2!\cdot3!=`); await page.click('#add-math-cell'); await page.setLatex(4, String.raw`\left(9-6\right)!=`); await page.click('#add-math-cell'); await page.setLatex(5, String.raw`0!=`); await page.click('#add-math-cell'); await page.setLatex(6, String.raw`a!=`); await page.waitForSelector('.status-footer', { state: 'detached' }); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(24, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(-19, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(10, precision); content = await page.textContent('#result-units-2'); expect(content).toBe(''); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(12, precision); content = await page.textContent('#result-units-3'); expect(content).toBe(''); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-4'); expect(content).toBe(''); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-5'); expect(content).toBe(''); content = await page.textContent('#result-value-6'); expect(content).toBe('a!'); content = await page.textContent('#result-units-6'); expect(content).toBe(''); await page.click('#add-math-cell'); await page.setLatex(7, String.raw`a=4`); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.textContent('#result-value-6'); expect(parseLatexFloat(content)).toBeCloseTo(24, precision); content = await page.textContent('#result-units-6'); expect(content).toBe(''); }); test('Test factorial error check for non integer input', async () => { await page.setLatex(0, String.raw`1.1!=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1.04648584685356, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test factorial error check for negative input', async () => { await page.setLatex(0, String.raw`-1!=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\tilde{\infty}`); }); test('Test factorial error check for input with units', async () => { await page.setLatex(0, String.raw`1[m]!=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeVisible(); }); test('Test units applied to pi', async () => { await page.locator('#cell-0 >> math-field.editable').type("2*pi[rad]=[deg]"); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`2\cdot \pi\left\lbrack rad\right\rbrack=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(360, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('deg'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(2*pi, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('rad'); }); test('Test error if relative temperature applied to pi', async () => { await page.locator('#cell-0 >> math-field.editable').type("pi[degC]="); await expect(page.locator('#cell-0 >> text=Only absolute temperature units may be applied directly to the pi symbol')).toBeVisible(); }); test('Test error units applied to variable name', async () => { await page.locator('#cell-0 >> math-field.editable').type("a[m]="); await expect(page.locator('#cell-0 >> text=Units cannot be applied directly to a variable name')).toBeVisible(); }); test('Test error units applied to variable name then raised to an exponent', async () => { await page.setLatex(0, String.raw`f\left\lbrack m\right\rbrack^2=`); await expect(page.locator('#cell-0 >> text=Units cannot be applied directly to a variable name')).toBeVisible(); }); test('Test slow simplification issue', async ({ browserName }) => { test.skip(browserName === "chromium", "Playwright does not currently support the File System Access API"); // open the sheet that causes the error const path = "tests/test_sheet_slow_simplify.epxyz"; page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(path); }); await page.locator('#open-sheet').click(); await page.waitForTimeout(8000); await page.locator('h3 >> text=Opening File').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('text=Updating...', {state: 'detached', timeout: 120000}); let content = await page.textContent('#result-value-32'); expect(parseLatexFloat(content)).toBeCloseTo(87.033, precision); content = await page.textContent('#result-units-32'); expect(content).toBe('lbf'); }); test('Test units preserved when multiplied by zero', async () => { await page.setLatex(0, String.raw`0\cdot6\left\lbrack lbf\right\rbrack=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('N'); }); ================================================ FILE: tests/test_calc.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('test basic calculus', async () => { // test calculus await page.setLatex(0, String.raw`\int _{0}^{pi}\left(sin\left(t\right)\right)d\left(t\right)=`); await page.click('#add-math-cell'); await page.locator('button').filter({ hasText: 'a^∫Σ' }).click(); await page.click(':nth-match(button.keyboard:has-text("∫"), 2)'); await page.type(':nth-match(math-field.editable, 2)', 'b'); await page.press(':nth-match(math-field.editable, 2)', 'Tab'); await page.type(':nth-match(math-field.editable, 2)', 'a'); await page.press(':nth-match(math-field.editable, 2)', 'Tab'); await page.type(':nth-match(math-field.editable, 2)', 's'); await page.press(':nth-match(math-field.editable, 2)', 'Tab'); await page.type(':nth-match(math-field.editable, 2)', 's'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 2)', '='); await page.click('#add-math-cell'); await page.setLatex(2, String.raw`\int _{-\frac{h}{2}}^{\frac{h}{2}}\left(\int _{-\frac{w}{2}}^{\frac{w}{2}}\left(y^{2}\right)\mathrm{d}\left(x\right)\right)\mathrm{d}\left(y\right)=\left[mm^{4}\right]`); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 4)', 'h=30[mm]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 5)', 'w=10[mm]'); await page.click('#add-math-cell'); await page.setLatex(5, String.raw`func=x^{3}\cdot y^{2}`); await page.click('#add-math-cell'); await page.locator('button').filter({ hasText: 'a^∫Σ' }).click(); await page.locator('button').filter({ hasText: 'd2dx2dx2d2' }).click(); await page.type(':nth-match(math-field.editable, 7)', 'x'); await page.press(':nth-match(math-field.editable, 7)', 'Tab'); await page.locator('button').filter({ hasText: 'dd⁢xdxd' }).click(); await page.type(':nth-match(math-field.editable, 7)', 'y'); await page.press(':nth-match(math-field.editable, 7)', 'Tab'); await page.type(':nth-match(math-field.editable, 7)', 'func'); await page.press(':nth-match(math-field.editable, 7)', 'ArrowRight'); await page.press(':nth-match(math-field.editable, 7)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 7)', '='); await page.click('#add-math-cell'); await page.setLatex(7, String.raw`\frac{d}{d\left(z\right)}\left(\frac{d^{2}}{d\left(r\right)^{2}}\left(3\cdot r^{2}\cdot z\right)\right)=`); await page.click('#add-math-cell'); await page.setLatex(8, String.raw`position=20\left[\frac{m}{sec}\right]\cdot time`); await page.click('#add-math-cell'); await page.setLatex(9, String.raw`velocity=\frac{\mathrm{d}}{\mathrm{d}\left(time\right)}\left(position\right)`); await page.click('#add-math-cell'); await page.setLatex(10, String.raw`velocity=`); await page.click('#add-math-cell'); await page.setLatex(11, String.raw`\int _{ }^{ }\left(1^{x}\right)\mathrm{d}\left(x\right)=`); await page.click('#add-math-cell'); await page.setLatex(12, String.raw`\int _{-2}^{2}\left(x^{3}\cdot \cos\left(\frac{x}{2}\right)+\frac{1}{2}\cdot \sqrt{4-x^{2}}\right)\mathrm{d}\left(x\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-value-1'); expect(content).toBe(`- \\frac{a^{2}}{2} + \\frac{b^{2}}{2}`); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo((10*30**3/12), precision); content = await page.textContent('#result-value-6'); expect(content).toBe('12 \\cdot x \\cdot y'); content = await page.textContent('#result-value-7'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-value-10'); expect(parseLatexFloat(content)).toBeCloseTo(20, precision); content = await page.textContent('#result-units-10'); expect(content).toBe('m^1*s^-1'); content = await page.textContent('#result-value-11'); expect(content).toBe('x'); content = await page.textContent('#result-value-12'); expect(parseLatexFloat(content)).toBeCloseTo(pi, precision); }); test('Test substitution of integration variable', async () => { await page.setLatex(0, String.raw`z_{1}=\int _{ }^{ }\left(x\right)\mathrm{d}\left(x\right)`); await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`z_{2}=\int _{0}^{x}\left(x\right)\mathrm{d}\left(x\right)`); await page.keyboard.press('Shift+Enter'); await page.setLatex(2, String.raw`z_{3}=\int _{0}^{x}\left(x^{s+t}\right)\mathrm{d}\left(x\right)`); await page.keyboard.press('Shift+Enter'); await page.setLatex(3, String.raw`s=2`); await page.keyboard.press('Shift+Enter'); await page.setLatex(4, String.raw`t=-1`); await page.keyboard.press('Shift+Enter'); await page.setLatex(5, String.raw`x=10`); await page.keyboard.press('Shift+Enter'); await page.setLatex(6, String.raw`z_{1}=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(7, String.raw`z_{2}=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(8, String.raw`z_{3}=`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-6'); expect(parseLatexFloat(content)).toBeCloseTo(50, precision); content = await page.textContent('#result-units-6'); expect(content).toBe(''); content = await page.textContent('#result-value-7'); expect(parseLatexFloat(content)).toBeCloseTo(50, precision); content = await page.textContent('#result-units-7'); expect(content).toBe(''); content = await page.textContent('#result-value-8'); expect(parseLatexFloat(content)).toBeCloseTo(50, precision); content = await page.textContent('#result-units-8'); expect(content).toBe(''); }); test('Test substitution of differential variable', async () => { await page.setLatex(0, String.raw`z_{1}=\frac{\mathrm{d}}{\mathrm{d}\left(x\right)}\left(y^{2}\right)`); await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`y=x^{4}`); await page.keyboard.press('Shift+Enter'); await page.setLatex(2, String.raw`x=10`); await page.keyboard.press('Shift+Enter'); await page.setLatex(3, String.raw`z_{1}=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(4, String.raw`z_{2}=\frac{\mathrm{d}}{\mathrm{d}\left(x\right)}\left(y^{s+t}\right)`); await page.keyboard.press('Shift+Enter'); await page.setLatex(5, String.raw`s=1`); await page.keyboard.press('Shift+Enter'); await page.setLatex(6, String.raw`t=1`); await page.keyboard.press('Shift+Enter'); await page.setLatex(7, String.raw`z_{2}=`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(80000000, precision); content = await page.textContent('#result-units-3'); expect(content).toBe(''); content = await page.textContent('#result-value-7'); expect(parseLatexFloat(content)).toBeCloseTo(80000000, precision); content = await page.textContent('#result-units-7'); expect(content).toBe(''); }); test('Test derivative substitution bug #156', async () => { await page.setLatex(0, String.raw`y=20\cdot x`); await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`\frac{\mathrm{d}}{\mathrm{d}\left(x\right)}\left(x\cdot y\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(content).toBe('40 \\cdot x'); }); test('Test integral substitution bug #244', async () => { await page.setLatex(0, String.raw`c=a\left(b=1\right)`); await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`\int_0^1\left(c\cdot x\right)\mathrm{d}\left(x\right)=`); await page.click('#add-piecewise-cell'); await page.locator('#piecewise-parameter-2 math-field.editable').type('a'); await page.locator('#piecewise-expression-2-0 math-field.editable').type('1'); await page.locator('#piecewise-expression-2-1 math-field.editable').type('-1'); await page.locator('#piecewise-condition-2-0 math-field.editable').type('b>=0'); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(0.5, precision); }); test('Test definite integral with numerical limits that have units', async () => { await page.setLatex(0, String.raw`\int_{0\left\lbrack m\right\rbrack}^{1\left\lbrack m\right\rbrack}\left(x\right)\mathrm{d}\left(x\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`\int_0^{1\left\lbrack m\right\rbrack}\left(x\right)\mathrm{d}\left(x\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0.5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^2'); await expect(page.locator("#cell-1 >> text=Dimension Error")).toBeAttached(); }); test('Test units for nth order derivatives', async () => { await page.setLatex(0, String.raw`\frac{\mathrm{d}^2}{\mathrm{d}\left(y\right)^2}\left(1\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`\frac{\mathrm{d}^2}{\mathrm{d}\left(y\right)^2}\left(y^3\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(2, String.raw`y=1\left\lbrack m\right\rbrack`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^-2'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); }); test('Test unitless calculus when operand contains placeholder function', async () => { await page.click('#delete-0'); await page.click('#add-piecewise-cell'); await page.locator('#piecewise-parameter-0 math-field.editable').type('y'); await page.locator('#piecewise-expression-0-0 math-field.editable').type('x+1'); await page.locator('#piecewise-expression-0-1 math-field.editable').type('1-x'); await page.locator('#piecewise-condition-0-0 math-field.editable').type('x<0'); await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`y_{prime}=\frac{\mathrm{d}}{\mathrm{d}\left(x\right)}\left(y\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(2, String.raw`\int_{-1}^1\left(y\right)\mathrm{d}\left(x\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(3, String.raw`y_{prime}\left(x=-.5\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-2'); expect(content).toBe(''); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-3'); expect(content).toBe(''); }); test('Test calculus units when operand contains placeholder function', async () => { await page.click('#delete-0'); await page.click('#add-piecewise-cell'); await page.locator('#piecewise-parameter-0 math-field.editable').type('y'); await page.locator('#piecewise-expression-0-0 math-field.editable').type('x+1[m]'); await page.locator('#piecewise-expression-0-1 math-field.editable').type('1[m]-x'); await page.locator('#piecewise-condition-0-0 math-field.editable').type('x<0[m]'); await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`y_{prime}=\frac{\mathrm{d}}{\mathrm{d}\left(x\right)}\left(y^2\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(2, String.raw`\int_{-1\left\lbrack m\right\rbrack}^{1\left\lbrack m\right\rbrack}\left(y\right)\mathrm{d}\left(x\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(3, String.raw`y_{prime}\left(x=-.5\left\lbrack m\right\rbrack\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(4, String.raw`y_{int}=\int\left(y\right)\mathrm{d}\left(x\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(5, String.raw`y_{int}\left(x=1\left\lbrack m\right\rbrack\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m^2'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m'); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(0.5, precision); content = await page.textContent('#result-units-5'); expect(content).toBe('m^2'); }); test('Test indefinite integral substitution bug #272', async () => { await page.setLatex(0, String.raw`\int\left(-L+S\right)\mathrm{d}\left(S\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\int_0^{S}\left(-L+S\right)\mathrm{d}\left(S\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`S=L`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`- \frac{L^{2}}{2}`); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`- \frac{L^{2}}{2}`); }); test('Test derivative substitution order', async () => { await page.setLatex(0, String.raw`\frac{\mathrm{d}}{\mathrm{d}\left(S\right)}\left(-L^2+S^2\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`S=L`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('2 \\cdot L'); }); test('Test numerical integral and derivative using interpolation function', async () => { await page.setLatex(0, String.raw`\int_{0\left\lbrack in\right\rbrack}^{2\left\lbrack in\right\rbrack}\left(\mathrm{Interp1}\left(S\right)\right)\mathrm{d}\left(S\right)=\left\lbrack in^2\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\frac{\mathrm{d}}{\mathrm{d}\left(S\right)}\left(\mathrm{Interp1}\left(S\right)\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`S=1.5\left\lbrack in\right\rbrack`); await page.locator('#add-data-table-cell').click(); await page.locator('#parameter-units-3-0 >> math-field').type('[in]'); await page.locator('#parameter-units-3-1 >> math-field').type('[in]'); await page.locator('#data-table-input-3-0-0').click(); await page.keyboard.type('0'); await page.keyboard.press('Tab'); await page.keyboard.type('0'); await page.keyboard.press('Enter'); await page.keyboard.type('1'); await page.keyboard.press('Tab'); await page.keyboard.type('1'); await page.keyboard.press('Enter'); await page.keyboard.type('2'); await page.keyboard.press('Tab'); await page.keyboard.type('0'); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.waitForSelector('.status-footer', {state: 'detached', timeout: 240000}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1, 5); content = await page.textContent('#result-units-0'); expect(content).toBe('in^2'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(-1, 9); content = await page.textContent('#result-units-1'); expect(content).toBe(''); }); test('Test derivative dimensional analysis bug', async () => { await page.setLatex(0, String.raw`\frac{\mathrm{d}}{\mathrm{d}\left(x\right)}\left(x+1\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test unitless nested integral in exponent', async () => { await page.setLatex(0, String.raw`2^{\int_{-\frac{h}{2}}^{\frac{h}{2}}\left(\int_{-\frac{w}{2}}^{\frac{w}{2}}\left(y^2\right)\mathrm{d}\left(x\right)\right)\mathrm{d}\left(y\right)}=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, 'h=2'); await page.locator('#add-math-cell').click(); await page.setLatex(2, 'w=3'); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test integral with exponent in upper limit and user function in integrand', async () => { await page.setLatex(0, String.raw`s=t,\:n=3`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\int_0^{n^2}\left(s\left(t=1\right)\right)\mathrm{d}\left(t\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); }); ================================================ FILE: tests/test_checkpoints.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test autosave checkpoints', async ({ browserName }) => { while (!page.url().includes('temp-checkpoint')) { await page.waitForTimeout(200); } // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'New Title'); await page.setLatex(0, '1='); let previousUrl = page.url(); // wait until checkpoint is saved while (page.url() === previousUrl) { await page.waitForTimeout(200); } previousUrl = page.url(); await page.setLatex(0, '2='); // wait until checkpoint is saved while (page.url() === previousUrl) { await page.waitForTimeout(200); } previousUrl = page.url(); await page.click('#add-documentation-cell'); await page.type('div.editor div', `Checkpoint 3`); // wait until checkpoint is saved while (page.url() === previousUrl) { await page.waitForTimeout(200); } previousUrl = page.url(); // will create a new sheet to clear contents // will first dismiss creating new sheet and make sure everything stays the same page.once('dialog', dialog => { dialog.dismiss(); }); await page.locator('#new-sheet').click(); await page.locator('text=Checkpoint 3').waitFor(); // will create a new sheet to clear contents // now accept new sheet and make sure everything is gone page.once('dialog', dialog => { dialog.accept(); }); await page.locator('#new-sheet').click(); await page.locator('text=Checkpoint 3').waitFor({state: 'detached'}); await page.waitForTimeout(500); await page.goBack(); await page.locator('text=Checkpoint 3').waitFor(); await page.waitForTimeout(500); await page.goBack(); // need to go back twice since cancelled new sheet adds additional page to history await page.locator('text=Checkpoint 3').waitFor(); await page.waitForTimeout(500); await page.goBack(); // now we'll hit checkpoint 2 await page.locator('text=Checkpoint 3').waitFor({state: 'detached'}); await page.waitForSelector('.status-footer', { state: 'detached' }); let content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); await page.waitForTimeout(500); await page.goBack(); await page.locator('text=New Title').waitFor(); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); await page.waitForTimeout(500); await page.goBack(); await page.getByRole('heading', { name: 'New Sheet' }).waitFor(); }); ================================================ FILE: tests/test_code_cell.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Scalar any input and unitless output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#cell-0 math-field.editable').type('CodeFunc1(1)='); await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.locator('#add-math-cell').click(); await page.locator('#cell-2 math-field.editable').type('CodeFunc1(2[m])='); await page.locator('#add-math-cell').click(); await page.locator('#cell-3 math-field.editable').type('CodeFunc1(4[m])='); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(`def calculate(input):\nreturn 4*input`); await expect(page.locator('.status-footer')).not.toBeVisible(); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); content = await page.textContent('#result-units-2'); expect(content).toBe(''); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(16, precision); content = await page.textContent('#result-units-3'); expect(content).toBe(''); }); test('Scalar inputs with units on first input and unitless output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field')).toBeVisible({timeout: 4000}); await page.locator('#cell-1 math-field.editable').click({clickCount: 3}); await page.locator('#cell-1 math-field.editable').type('NewFunc([m],[any])=[none]'); await page.locator('#cell-1 math-field.editable').press('Enter'); await page.setLatex(0, String.raw`\mathrm{NewFunc}\left(1,2\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`NewFunc\left(2\left\lbrack km\right\rbrack,3\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\mathrm{NewFunc}\left(4\left\lbrack s\right\rbrack,5\right)=`) await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`\mathrm{NewFunc}\left(5\left\lbrack km\right\rbrack,6\left\lbrack km\right\rbrack\right)=`) await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(`def calculate(input1, input2):\nreturn input1*input2`); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error: Incorrect units for input number 1')).toBeVisible(); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(6000, precision); content = await page.textContent('#result-units-2'); expect(content).toBe(''); await expect(page.locator('#cell-3 >> text=Dimension Error: Incorrect units for input number 1')).toBeVisible(); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(3e7, precision); content = await page.textContent('#result-units-4'); expect(content).toBe(''); }); test('Copy code function name to clipboard', async ({ browserName }) => { test.skip(browserName === "chromium", "Chromium does always support navigator.clipboard.writeText in headless mode"); const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.waitForSelector('.status-footer', {state: 'detached'}); await page.getByLabel('Copy Function Name to').click(); await page.locator('#cell-0 math-field.editable').press(`${modifierKey}+v`); await page.locator('#cell-0 math-field.editable').type('(1)='); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(`def calculate(input):\nreturn 4*input`); await expect(page.locator('.status-footer')).not.toBeVisible(); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Scalar inputs with units on second input and scalar output with units', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack m\right\rbrack\right)=\left\lbrack m\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(1,2\left\lbrack m\right\rbrack\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`NewFunc\left(2\left\lbrack m\right\rbrack,3\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\mathrm{NewFunc}\left(4\left\lbrack s\right\rbrack,5\right)=`) await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`\mathrm{NewFunc}\left(5\left\lbrack m\right\rbrack,6\left\lbrack m\right\rbrack\right)=`) await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(`def calculate(input1, input2):\nreturn input1 + input2`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Scalar inputs without units and unitless matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack none\right\rbrack,\left\lbrack none\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2,3\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` import numpy as np def calculate(input1, input2): return np.ones((int(input1),int(input2))) `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 1 & 1 & 1 \\ 1 & 1 & 1 \end{bmatrix}`); }); test('Scalar inputs without units and scalar unit for matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack none\right\rbrack,\left\lbrack none\right\rbrack\right)=\left\lbrack m\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2,3\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` import numpy as np def calculate(input1, input2): return np.ones((int(input1),int(input2))) `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 1\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack \\ 1\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack \end{bmatrix}`); }); test('Scalar inputs without units and matrix units for matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack none\right\rbrack,\left\lbrack none\right\rbrack\right)=\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack s\right\rbrack & \left\lbrack kg\right\rbrack\\ \left\lbrack K\right\rbrack & \left\lbrack A\right\rbrack & \left\lbrack mol\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2,3\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` import numpy as np def calculate(input1, input2): return np.ones((int(input1),int(input2))) `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 1\left\lbrack m\right\rbrack & 1\left\lbrack s\right\rbrack & 1\left\lbrack kg\right\rbrack \\ 1\left\lbrack K\right\rbrack & 1\left\lbrack A\right\rbrack & 1\left\lbrack mol\right\rbrack \end{bmatrix}`); }); test('Scalar inputs without units and wrong sized matrix units for matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack none\right\rbrack,\left\lbrack none\right\rbrack\right)=\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack s\right\rbrack\\ \left\lbrack K\right\rbrack & \left\lbrack A\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2,3\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` import numpy as np def calculate(input1, input2): return np.ones((int(input1),int(input2))) `); await expect(page.locator('text=Incorrect matrix or vector size for output')).toBeVisible(); }); test('Scalar inputs without units and row matrix units for matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack none\right\rbrack,\left\lbrack none\right\rbrack\right)=\begin{bmatrix}\left\lbrack m\right\rbrack\\ \left\lbrack K\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2,3\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` import numpy as np def calculate(input1, input2): return np.ones((int(input1),int(input2))) `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 1\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack \\ 1\left\lbrack K\right\rbrack & 1\left\lbrack K\right\rbrack & 1\left\lbrack K\right\rbrack \end{bmatrix}`); }); test('Scalar inputs without units and col matrix units for matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack none\right\rbrack,\left\lbrack none\right\rbrack\right)=\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack s\right\rbrack & \left\lbrack K\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2,3\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` import numpy as np def calculate(input1, input2): return np.ones((int(input1),int(input2))) `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 1\left\lbrack m\right\rbrack & 1\left\lbrack s\right\rbrack & 1\left\lbrack K\right\rbrack \\ 1\left\lbrack m\right\rbrack & 1\left\lbrack s\right\rbrack & 1\left\lbrack K\right\rbrack \end{bmatrix}`); }); test('Scalar inputs without units and col matrix units for matrix output and wrong number of columns', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack none\right\rbrack,\left\lbrack none\right\rbrack\right)=\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack s\right\rbrack \end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2,3\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` import numpy as np def calculate(input1, input2): return np.ones((int(input1),int(input2))) `); await expect(page.locator('text=Incorrect matrix or vector size for output')).toBeVisible(); }); test('Scalar inputs without units and matrix units for scalar output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack none\right\rbrack,\left\lbrack none\right\rbrack\right)=\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack s\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2,3\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await expect(page.locator('.status-footer >> text=The code cell function CodeFunc1 returns a scalar when a matrix output was specified')).toBeVisible(); }); test('Scalar and matrix inputs without units and matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2,\begin{bmatrix}1 & 2\\ 3 & 4\\ 5.1 & 6\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 2 & 4 \\ 6 & 8 \\ 10.2 & 12 \end{bmatrix}`); }); test('Scalar and matrix inputs with scalar units spec and matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack m\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack m\right\rbrack & 2\left\lbrack km\right\rbrack\\ 3\left\lbrack m\right\rbrack & 4\left\lbrack m\right\rbrack\\ 5.1\left\lbrack m\right\rbrack & 6\left\lbrack cm\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 2 & 4000 \\ 6 & 8 \\ 10.2 & 0.12 \end{bmatrix}`); }); test('Scalar and matrix inputs with incorrect units and scalar units spec and matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack m\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack m\right\rbrack & 2\left\lbrack km\right\rbrack\\ 3\left\lbrack m\right\rbrack & 4\left\lbrack s\right\rbrack\\ 5.1\left\lbrack m\right\rbrack & 6\left\lbrack cm\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error: Incorrect units for input number 2')).toBeVisible(); }); test('Scalar and matrix inputs with incorrect units and matrix units spec and matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack s\right\rbrack\\ \left\lbrack K\right\rbrack & \left\lbrack kg\right\rbrack\\ \left\lbrack mol\right\rbrack & \left\lbrack A\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1 & 2\\ 3 & 4\\ 5.1 & 6\end{bmatrix}\cdot1\left\lbrack m\right\rbrack\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error: Incorrect units at (row=1, col=2)')).toBeVisible(); }); test('Scalar and matrix inputs with units and matrix units spec and matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack s\right\rbrack\\ \left\lbrack K\right\rbrack & \left\lbrack kg\right\rbrack\\ \left\lbrack mol\right\rbrack & \left\lbrack A\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack km\right\rbrack & 2\left\lbrack us\right\rbrack\\ 3\left\lbrack kK\right\rbrack & 4\left\lbrack kg\right\rbrack\\ 5.1\left\lbrack mol\right\rbrack & 6\left\lbrack A\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 2000 & 4\times 10^{-6} \\ 6000 & 8 \\ 10.2 & 12 \end{bmatrix}`); }); test('Scalar and matrix inputs with units and wrong size matrix units spec and matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack s\right\rbrack\\ \left\lbrack K\right\rbrack & \left\lbrack kg\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack km\right\rbrack & 2\left\lbrack us\right\rbrack\\ 3\left\lbrack kK\right\rbrack & 4\left\lbrack kg\right\rbrack\\ 5.1\left\lbrack mol\right\rbrack & 6\left\lbrack A\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await expect(page.locator('text=Incorrect matrix or vector size for input number 2')).toBeVisible(); }); test('Scalar and matrix inputs with units and row matrix units spec and matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack m\right\rbrack\\ \left\lbrack K\right\rbrack\\ \left\lbrack mol\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack km\right\rbrack & 2\left\lbrack m\right\rbrack\\ 3\left\lbrack kK\right\rbrack & 4\left\lbrack K\right\rbrack\\ 5.1\left\lbrack mol\right\rbrack & 6\left\lbrack mol\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 2000 & 4 \\ 6000 & 8 \\ 10.2 & 12 \end{bmatrix}`); }); test('Scalar and matrix inputs with units and row matrix units spec and matrix output with wrong units', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack m\right\rbrack\\ \left\lbrack K\right\rbrack\\ \left\lbrack mol\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack km\right\rbrack & 2\left\lbrack s\right\rbrack\\ 3\left\lbrack kK\right\rbrack & 4\left\lbrack K\right\rbrack\\ 5.1\left\lbrack mol\right\rbrack & 6\left\lbrack mol\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error: Incorrect units for input number 2')).toBeVisible(); }); test('Scalar and matrix inputs with units and row matrix units spec and matrix output and wrong number of rows', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack m\right\rbrack\\ \left\lbrack K\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack km\right\rbrack & 2\left\lbrack m\right\rbrack\\ 3\left\lbrack kK\right\rbrack & 4\left\lbrack K\right\rbrack\\ 5.1\left\lbrack mol\right\rbrack & 6\left\lbrack mol\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await expect(page.locator('text=Incorrect matrix or vector size for input number 2')).toBeVisible(); }); test('Scalar and matrix inputs with units and col matrix units spec and matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack K\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack km\right\rbrack & 2\left\lbrack K\right\rbrack\\ 3\left\lbrack m\right\rbrack & 4\left\lbrack kK\right\rbrack\\ 5.1\left\lbrack cm\right\rbrack & 6\left\lbrack K\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 2000 & 4 \\ 6 & 8000 \\ 0.102 & 12 \end{bmatrix}`); }); test('Scalar and matrix inputs with units and col matrix units spec and matrix output and wrong units', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack K\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack km\right\rbrack & 2\left\lbrack K\right\rbrack\\ 3\left\lbrack m\right\rbrack & 4\left\lbrack kK\right\rbrack\\ 5.1\left\lbrack cm\right\rbrack & 6\left\lbrack s\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error: Incorrect units for input number 2')).toBeVisible(); }); test('Scalar and symbolic matrix input', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack K\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack km\right\rbrack & 2\left\lbrack K\right\rbrack\\ 3\left\lbrack m\right\rbrack & 4\left\lbrack kK\right\rbrack\\ 5.1\left\lbrack cm\right\rbrack & x\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\operatorname{CodeFunc}_{1}{\left(2,\left[\begin{matrix}1000 & 2\\3 & 4000\\\frac{51}{1000} & x\end{matrix}\right] \right)}`); }); test('Scalar symbolic and numeric matrix input', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack K\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(x,\begin{bmatrix}1\left\lbrack km\right\rbrack & 2\left\lbrack K\right\rbrack\\ 3\left\lbrack m\right\rbrack & 4\left\lbrack kK\right\rbrack\\ 5.1\left\lbrack cm\right\rbrack & 6\left\lbrack K\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\operatorname{CodeFunc}_{1}{\left(x,\left[\begin{matrix}1000 & 2\\3 & 4000\\\frac{51}{1000} & 6\end{matrix}\right] \right)}`); }); test('Scalar and matrix inputs with units and matrix units spec and matrix output with output units', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack s\right\rbrack\\ \left\lbrack K\right\rbrack & \left\lbrack kg\right\rbrack\\ \left\lbrack mol\right\rbrack & \left\lbrack A\right\rbrack\end{bmatrix}\right)=\begin{bmatrix}\left\lbrack m\right\rbrack & \left\lbrack s\right\rbrack\\ \left\lbrack K\right\rbrack & \left\lbrack kg\right\rbrack\\ \left\lbrack mol\right\rbrack & \left\lbrack A\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2,\begin{bmatrix}1\left\lbrack km\right\rbrack & 2\left\lbrack us\right\rbrack\\ 3\left\lbrack K\right\rbrack & 4\left\lbrack kg\right\rbrack\\ 5.1\left\lbrack mol\right\rbrack & 6\left\lbrack A\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 2000\left\lbrack m\right\rbrack & 4\times 10^{-6}\left\lbrack s\right\rbrack \\ 6\left\lbrack K\right\rbrack & 8\left\lbrack kg\right\rbrack \\ 10.2\left\lbrack mol\right\rbrack & 12\left\lbrack A\right\rbrack \end{bmatrix}`); }); test('SymPy mode with scalar symbolic inputs and outputs', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`CodeFunc1\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(x,2\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`2 \cdot x`); }); test('SymPy mode with scalar numeric inputs and outputs', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`CodeFunc1\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(4\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` import sympy as sp def calculate(input): return sp.gamma(input) `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('SymPy mode with scalar inputs and matrix output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`CodeFunc1\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(1,5\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` import sympy as sp def calculate(input1, input2): x = sp.symbols('x') return sp.Matrix(sp.sequence(x**2, (x, input1, input2))).T `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 1 & 4 & 9 & 16 & 25 \end{bmatrix}`); }); test('SymPy mode with matrix inputs and outputs and units', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`CodeFunc1\left(\left\lbrack m\right\rbrack,\begin{bmatrix}\left\lbrack m\right\rbrack\\ \left\lbrack s\right\rbrack\end{bmatrix}\right)=\begin{bmatrix}\left\lbrack m^2\right\rbrack\\ \left\lbrack s\cdot m\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack m\right\rbrack & 2\left\lbrack m\right\rbrack & 3\left\lbrack km\right\rbrack\\ 4\left\lbrack us\right\rbrack & 5\left\lbrack s\right\rbrack & 6\left\lbrack s\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 2\left\lbrack m^2\right\rbrack & 4\left\lbrack m^2\right\rbrack & 6000\left\lbrack m^2\right\rbrack \\ 8\times 10^{-6}\left\lbrack m\cdot s\right\rbrack & 10\left\lbrack m\cdot s\right\rbrack & 12\left\lbrack m\cdot s\right\rbrack \end{bmatrix}`); }); test('SymPy mode with symbolic matrix inputs and outputs', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`CodeFunc1\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(x,\begin{bmatrix}a1 & a2\\ a3 & a4\\ a5 & a6\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); await page.locator('#cell-1 div.cm-content').type(` def calculate(input1, input2): return input1*input2 `); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} a1 \cdot x & a2 \cdot x \\ a3 \cdot x & a4 \cdot x \\ a5 \cdot x & a6 \cdot x \end{bmatrix}`); }); test('Custom dims function with only dims input', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`CodeFunc1\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,3\left\lbrack s\right\rbrack\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input1*input2 def custom_dims(input1, input2): return input1*input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^1*s^1'); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(3\left\lbrack m\right\rbrack,4\left\lbrack s\right\rbrack\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(12, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^1*s^1'); }); test('Custom dims function with dims input and input values and result value', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`CodeFunc1\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,3\left\lbrack s\right\rbrack\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input1*input2 def custom_dims(input1, input2, dim_values): return input1**dim_values["args"][0]*input2**(dim_values["args"][1]+dim_values["result"]) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^2*s^9'); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(3\left\lbrack m\right\rbrack,4\left\lbrack s\right\rbrack\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(12, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^3*s^16'); }); test('Custom dims with dims besides [any] for input', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`CodeFunc1\left(\left\lbrack m\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,3\left\lbrack s\right\rbrack\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input1*input2 def custom_dims(input1, input2, dim_values): return input1**dim_values["args"][0]*input2**(dim_values["args"][1]+dim_values["result"]) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('.status-footer >> text=All inputs and outputs must be of scalar type [any]')).toBeVisible(); }); test('Custom dims with dims besides [any] for output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`CodeFunc1\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack m\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,3\left\lbrack s\right\rbrack\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input1*input2 def custom_dims(input1, input2, dim_values): return input1**dim_values["args"][0]*input2**(dim_values["args"][1]+dim_values["result"]) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('.status-footer >> text=All inputs and outputs must be of scalar type [any]')).toBeVisible(); }); test('Return type of [any] without custom dims function defined', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`CodeFunc1\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,3\left\lbrack s\right\rbrack\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input1*input2 def custom_dims2(input1, input2, dim_values): return input1**dim_values["args"][0]*input2**(dim_values["args"][1]+dim_values["result"]) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error: Return type of [any] only allowed when custom_dims function is defined')).toBeVisible(); }); test('Test input matrix to local unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack in\right\rbrack & \left\lbrack degF\right\rbrack & \left\lbrack us\right\rbrack\\ \left\lbrack m\right\rbrack & \left\lbrack any\right\rbrack & \left\lbrack none\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack m\right\rbrack & 273.15\left\lbrack K\right\rbrack & 1\left\lbrack us\right\rbrack\\ 5.1\left\lbrack m\right\rbrack & 6\left\lbrack km\right\rbrack & 3\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 39.3700787401575 & 31.9999999999999 & 1 \\ 5.1 & 6000 & 3 \end{bmatrix}`); }); test('Test input col matrix to local unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack in\right\rbrack & \left\lbrack degF\right\rbrack & \left\lbrack us\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack m\right\rbrack & 273.15\left\lbrack K\right\rbrack & 1\left\lbrack us\right\rbrack\\ 5\left\lbrack m\right\rbrack & 233.15\left\lbrack K\right\rbrack & 3\left\lbrack s\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 39.3700787401575 & 31.9999999999999 & 1 \\ 196.850393700787 & -40 & 3\times 10^{6} \end{bmatrix}`); }); test('Test input row matrix to local unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack in\right\rbrack\\ \left\lbrack degF\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack m\right\rbrack & 5\left\lbrack m\right\rbrack\\ 273.15\left\lbrack K\right\rbrack & 233.15\left\lbrack K\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 39.3700787401575 & 196.850393700787 \\ 31.9999999999999 & -40 \end{bmatrix}`); }); test('Test local to matrix output unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\begin{bmatrix}\left\lbrack in\right\rbrack & \left\lbrack degF\right\rbrack & \left\lbrack us\right\rbrack\\ \left\lbrack m\right\rbrack & \left\lbrack none\right\rbrack & \left\lbrack none\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}39.3700787401575 & 31.9999999999999 & 1\\ 5.1 & 6000 & 3\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 1\left\lbrack m\right\rbrack & 273.15\left\lbrack K\right\rbrack & 1\times 10^{-6}\left\lbrack s\right\rbrack \\ 5.1\left\lbrack m\right\rbrack & 6000 & 3 \end{bmatrix}`); }); test('Test local to col matrix output unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\begin{bmatrix}\left\lbrack in\right\rbrack & \left\lbrack degF\right\rbrack & \left\lbrack us\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}39.3700787401575 & 31.9999999999999 & 1\\ 12 & -40 & 3\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 1\left\lbrack m\right\rbrack & 273.15\left\lbrack K\right\rbrack & 1\times 10^{-6}\left\lbrack s\right\rbrack \\ 0.3048\left\lbrack m\right\rbrack & 233.15\left\lbrack K\right\rbrack & 3\times 10^{-6}\left\lbrack s\right\rbrack \end{bmatrix}`); }); test('Test local to row matrix output unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\begin{bmatrix}\left\lbrack in\right\rbrack\\ \left\lbrack degF\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1 & 2 & 3\\ 32 & -40 & 0\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 0.0254\left\lbrack m\right\rbrack & 0.0508\left\lbrack m\right\rbrack & 0.0762\left\lbrack m\right\rbrack \\ 273.15\left\lbrack K\right\rbrack & 233.15\left\lbrack K\right\rbrack & 255.372222222222\left\lbrack K\right\rbrack \end{bmatrix}`); }); test('Test input scalar to local unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack degF\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,273.15\left\lbrack K\right\rbrack\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): print(f"local value: {input2}") return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator("#cell-1 >> text=local value: 31.999999999999943")).toBeVisible(); }); test('Test local to output scalar unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack degF\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,32\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): print(f"local value: {input2}") return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(273.15, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('K'); }); test('Test sympy mode input matrix to local unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack in\right\rbrack & \left\lbrack degF\right\rbrack & \left\lbrack us\right\rbrack\\ \left\lbrack m\right\rbrack & \left\lbrack any\right\rbrack & \left\lbrack none\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack m\right\rbrack & 273.15\left\lbrack K\right\rbrack & 1\left\lbrack us\right\rbrack\\ 5.1\left\lbrack m\right\rbrack & 6\left\lbrack km\right\rbrack & 3\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 39.3700787401575 & 31.9999999999999 & 1 \\ 5.1 & 6000 & 3 \end{bmatrix}`); }); test('Test sympy mode input col matrix to local unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack in\right\rbrack & \left\lbrack degF\right\rbrack & \left\lbrack us\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack m\right\rbrack & 273.15\left\lbrack K\right\rbrack & 1\left\lbrack us\right\rbrack\\ 5\left\lbrack m\right\rbrack & 233.15\left\lbrack K\right\rbrack & 3\left\lbrack s\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 39.3700787401575 & 31.9999999999999 & 1 \\ 196.850393700787 & -40.0000000000001 & 3\times 10^{6} \end{bmatrix}`); }); test('Test sympy mode input row matrix to local unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\begin{bmatrix}\left\lbrack in\right\rbrack\\ \left\lbrack degF\right\rbrack\end{bmatrix}\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1\left\lbrack m\right\rbrack & 5\left\lbrack m\right\rbrack\\ 273.15\left\lbrack K\right\rbrack & 233.15\left\lbrack K\right\rbrack\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 39.3700787401575 & 196.850393700787 \\ 31.9999999999999 & -40.0000000000001 \end{bmatrix}`); }); test('Test sympy mode local to matrix output unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\begin{bmatrix}\left\lbrack in\right\rbrack & \left\lbrack degF\right\rbrack & \left\lbrack us\right\rbrack\\ \left\lbrack m\right\rbrack & \left\lbrack none\right\rbrack & \left\lbrack none\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}39.3700787401575 & 31.9999999999999 & 1\\ 5.1 & 6000 & 3\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 1\left\lbrack m\right\rbrack & 273.15\left\lbrack K\right\rbrack & 1\times 10^{-6}\left\lbrack s\right\rbrack \\ 5.1\left\lbrack m\right\rbrack & 6000 & 3 \end{bmatrix}`); }); test('Test sympy mode local to col matrix output unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\begin{bmatrix}\left\lbrack in\right\rbrack & \left\lbrack degF\right\rbrack & \left\lbrack us\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}39.3700787401575 & 31.9999999999999 & 1\\ 12 & -40 & 3\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 1\left\lbrack m\right\rbrack & 273.15\left\lbrack K\right\rbrack & 1\times 10^{-6}\left\lbrack s\right\rbrack \\ 0.3048\left\lbrack m\right\rbrack & 233.15\left\lbrack K\right\rbrack & 3\times 10^{-6}\left\lbrack s\right\rbrack \end{bmatrix}`); }); test('Test sympy mode local to row matrix output unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\begin{bmatrix}\left\lbrack in\right\rbrack\\ \left\lbrack degF\right\rbrack\end{bmatrix}`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,\begin{bmatrix}1 & 2 & 3\\ 32 & -40 & 0\end{bmatrix}\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 0.0254\left\lbrack m\right\rbrack & 0.0508\left\lbrack m\right\rbrack & 0.0762\left\lbrack m\right\rbrack \\ 273.15\left\lbrack K\right\rbrack & 233.15\left\lbrack K\right\rbrack & 255.372222222222\left\lbrack K\right\rbrack \end{bmatrix}`); }); test('Test sympy mode input scalar to local unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack degF\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,273.15\left\lbrack K\right\rbrack\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): print(f"local value: {input2}") return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator("#cell-1 >> text=local value: 31.9999999999999")).toBeVisible(); }); test('Test sympy mode local to output scalar unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack degF\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack,32\right)=`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+a`); await page.locator('#cell-1 div.cm-content').press(`${modifierKey}+x`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input1, input2): print(f"local value: {input2}") return input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(273.15, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('K'); }); test('Test compile error reporting', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\right)=`); await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.locator('#add-code-cell').click(); await page.setLatex(2, String.raw`\mathrm{CodeFunc2}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\mathrm{CodeFunc2}\left(3\right)=`); let editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 2*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); editor = await page.locator('#cell-2 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 3*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-3'); expect(content).toBe(''); await expect(page.locator(".cm-diagnostic")).not.toBeAttached(); editor = await page.locator('#cell-2 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input):- output = 3*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator("#cell-2 >> text=invalid syntax")).toBeVisible(); await expect(page.locator("#cell-1 .cm-diagnostic")).not.toBeAttached(); editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 3*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); editor = await page.locator('#cell-2 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 4*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(12, precision); content = await page.textContent('#result-units-3'); expect(content).toBe(''); await expect(page.locator(".cm-diagnostic")).not.toBeAttached(); }); test('Test runtime error reporting', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\right)=`); await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.locator('#add-code-cell').click(); await page.setLatex(2, String.raw`\mathrm{CodeFunc2}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\mathrm{CodeFunc2}\left(3\right)=`); let editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 2*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); editor = await page.locator('#cell-2 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 3*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-3'); expect(content).toBe(''); await expect(page.locator(".cm-diagnostic")).not.toBeAttached(); editor = await page.locator('#cell-2 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 3*input/0 return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator("#cell-2 >> text=division by zero")).toBeVisible(); await expect(page.locator("#cell-1 .cm-diagnostic")).not.toBeAttached(); editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 3*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); editor = await page.locator('#cell-2 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 4*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(12, precision); content = await page.textContent('#result-units-3'); expect(content).toBe(''); await expect(page.locator(".cm-diagnostic")).not.toBeAttached(); }); test('Test sympy mode runtime error reporting', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(x\right)=`); await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').nth(1).check(); await page.setLatex(2, String.raw`\mathrm{CodeFunc2}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\mathrm{CodeFunc2}\left(y\right)=`); let editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 2*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); editor = await page.locator('#cell-2 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 3*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`2 \cdot x`); content = await page.textContent('#result-value-3'); expect(content).toBe(String.raw`3 \cdot y`); await expect(page.locator(".cm-diagnostic")).not.toBeAttached(); editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 3*input+cats return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator("#cell-1 >> text=name 'cats' is not defined")).toBeVisible(); await expect(page.locator("#cell-2 .cm-diagnostic")).not.toBeAttached(); editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 3*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); editor = await page.locator('#cell-2 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 4*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`3 \cdot x`); content = await page.textContent('#result-value-3'); expect(content).toBe(String.raw`4 \cdot y`); await expect(page.locator(".cm-diagnostic")).not.toBeAttached(); }); test('Test stoud rendering', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\right)=`); await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').nth(1).check(); await page.setLatex(2, String.raw`\mathrm{CodeFunc2}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\mathrm{CodeFunc2}\left(y\right)=`); let editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): print('cats') output = 2*input return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); editor = await page.locator('#cell-2 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): output = 3*input print('dogs') return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent('#result-value-3'); expect(content).toBe(String.raw`3 \cdot y`); await expect(page.locator(".cm-diagnostic")).not.toBeAttached(); await expect(page.locator('#cell-1 pre >> text=cats')).toBeVisible(); await expect(page.locator('#cell-2 pre >> text=dogs')).toBeVisible(); await page.setLatex(3, String.raw`\mathrm{CodeFunc1}\left(3\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-3'); expect(content).toBe(''); await expect(page.locator('#cell-1 pre >> text=cats\ncats')).toBeVisible(); await expect(page.locator('#cell-2 pre >> text=dogs')).not.toBeVisible(); await expect(page.locator(".cm-diagnostic")).not.toBeAttached(); }); test('Test variable number of inputs', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(1\left\lbrack m\right\rbrack,2\left\lbrack m\right\rbrack,1\left\lbrack km\right\rbrack\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(*args): return sum(args) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1003, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test sympy mode variable number of inputs', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(x,y,z\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(*args): return sum(args) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`x + y + z`); }); test('Test variable number of inputs with inconsistent units', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack m\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(1\left\lbrack m\right\rbrack,2\left\lbrack m\right\rbrack,1\left\lbrack s\right\rbrack\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(*args): return sum(args) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error: Incorrect units for input number 3')).toBeVisible(); }); test('Test variable number of inputs with custom_dims without dim_values', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(1\left\lbrack m\right\rbrack,2\left\lbrack m\right\rbrack,3\left\lbrack m\right\rbrack\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(*args): return sum(args) import sympy as sp def custom_dims(*args): return sp.prod(args) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^3'); }); test('Test variable number of inputs with custom_dims with dim_values', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(1\left\lbrack m\right\rbrack,2\left\lbrack m\right\rbrack,3\left\lbrack m\right\rbrack\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(*args): return sum(args) import sympy as sp def custom_dims(*args, dim_values): return sp.prod(args)**dim_values["result"] `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^18'); }); test('Test wrong num of inputs in call', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(1,2\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): return 2*input `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('.status-footer >> text=Number of input arguments provided to code function "CodeFunc1" (2) differs from the number of arguments specified in the code function definition (1)')).toBeVisible(); }); test('Test sympy mode wrong num of inputs in call', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(1,2\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): return 2*input `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('.status-footer >> text=Number of input arguments provided to code function "CodeFunc1" (2) differs from the number of arguments specified in the code function definition (1)')).toBeVisible(); }); test('Test custom_dims utility functions', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(1,2,3\left\lbrack m\right\rbrack,157.48031496063\left\lbrack in\right\rbrack\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy.physics.units.definitions.dimension_definitions as dims def calculate(input1, input2, input3, input4): return input1+input2+input3+input4 def custom_dims(input1, input2, input3, input4): ensure_all_unitless(input1, input2) return ensure_all_equivalent(input3, input4)*dims.length `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(10, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^2'); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(1,2,3\left\lbrack s\right\rbrack,157.48031496063\left\lbrack in\right\rbrack\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error: CodeFunc1 dimension equivalence check has failed')).toBeVisible(); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(1,2\left\lbrack s\right\rbrack,3\left\lbrack m\right\rbrack,157.48031496063\left\lbrack in\right\rbrack\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error: CodeFunc1 dimension unitless check has failed')).toBeVisible(); }); test('Test wrong num of inputs in calculate definition', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\:\left\lbrack any\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): return 2*input def custom_dims(input, dim_values): return input `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('.status-footer >> text=The number of inputs to the provided "calculate" function (1) does not match the number of inputs in the function definition (2)')).toBeVisible(); }); test('Test wrong num of inputs in custom_dims definition', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\left\lbrack m\right\rbrack\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(input): return 2*input def custom_dims(input1, input2, dim_values): return input1*input2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('.status-footer >> text=The number of inputs to the provided "custom_dims" function (2) does not match the number of inputs in the function definition (1)')).toBeVisible(); }); test('Test lambdify input arg unit conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack degF\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`Col2_{2,1}=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(value): return value `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-2-0-0')).toBeFocused(); await page.keyboard.type('233.15'); await page.keyboard.press('Enter'); await page.keyboard.type('273.15'); await page.locator('#parameter-units-2-0 >> math-field').type('[K]'); await page.setLatex(2, String.raw`Col2=\mathrm{CodeFunc1}\left(Col1\right)`, 1); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(32, 12); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test lambdify result conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack degF\right\rbrack`); await page.setLatex(0, String.raw`Col2_{2,1}=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(value): return value `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-2-0-0')).toBeFocused(); await page.keyboard.type('-40'); await page.keyboard.press('Enter'); await page.keyboard.type('32'); await page.setLatex(2, String.raw`Col2=\mathrm{CodeFunc1}\left(Col1\right)`, 1); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(273.15, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('K'); }); test('Test no inputs and output units', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack mm\right\rbrack`); await page.setLatex(0, String.raw`\left(2\cdot\mathrm{CodeFunc1}\left(\right)\right)_{3,1}=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import numpy as np def calculate(): return np.array([1,2,3]) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0.006, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Test sympy mode no inputs and unitless output', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\left(3\cdot\mathrm{CodeFunc1}\left(\right)\right)_{3,1}=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(): return sp.Matrix([1,2,3]) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test automatic module import for libraries other than numpy and sympy', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack K\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` from CoolProp.CoolProp import PropsSI def calculate(): return PropsSI("Tcrit", "Water") `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(647.095999999987, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('K'); }); test('Test top level printing', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(10\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` print('outside') def calculate(value): print(f'inside {value}') output = 2*value return output `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\mathrm{CodeFunc1}\left(20\right)=`); let content = await page.locator('#cell-1 pre').textContent(); expect(content.trim()).toBe(`outside inside 10.0 inside 20.0`); await page.setLatex(2, String.raw`\mathrm{CodeFunc1}\left(15\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); content = await page.locator('#cell-1 pre').textContent(); expect(content.trim()).toBe(`outside inside 10.0 inside 15.0`); }); test('Test syntax errors for reserved function names', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); // built-in function await page.setLatex(1, String.raw`round\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await expect(page.locator('text=Attempt to reassign built-in function name round')).toBeAttached(); // trig function await page.setLatex(1, String.raw`sin\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await expect(page.locator('text=Invalid Syntax')).toBeAttached(); // reserved variables await page.setLatex(1, String.raw`i\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await expect(page.locator('text=i cannot be used as a function name')).toBeAttached(); }); test('Test sympy symbolic manipulation', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Automatically Simplify' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.locator('#add-code-cell').click(); await page.getByLabel('Use SymPy Mode').check(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`factor\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`x^2+5\cdot x+6=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy def calculate(value): return sympy.factor(value) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`x^{2} + 5 \cdot x + 6`); await page.setLatex(0, String.raw`\mathrm{factor}\left(x^2+5\cdot x+6\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\left(x + 2\right) \cdot \left(x + 3\right)`); }); test('Test sympy mode automatic tuple to Matrix conversion', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(x,y\right)_{2,1}=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(value1, value2): return value1, value2 `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('y'); }); test('Test dummy vars in custom funcs when operand contains placeholder function', async () => { await page.click('#delete-0'); await page.click('#add-piecewise-cell'); await page.locator('#piecewise-parameter-0 math-field.editable').type('y'); await page.locator('#piecewise-expression-0-0 math-field.editable').type('x+1[m]'); await page.locator('#piecewise-expression-0-1 math-field.editable').type('1[m]-x'); await page.locator('#piecewise-condition-0-0 math-field.editable').type('x<0[m]'); await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`y_{prime}=\mathrm{der}\left(y^2,\:x,\:1\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(2, String.raw`\mathrm{int}\left(y,-1\left\lbrack m\right\rbrack,\:1\left\lbrack m\right\rbrack,\:x\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(3, String.raw`y_{prime}\left(x=-.5\left\lbrack m\right\rbrack\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(4, String.raw`y_{int}=\mathrm{indefInt}\left(y,\:x\right)=`); await page.keyboard.press('Shift+Enter'); await page.setLatex(5, String.raw`y_{int}\left(x=1\left\lbrack m\right\rbrack\right)=`); await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-6 math-field.editable')).toBeVisible(); await page.setLatex(6, String.raw`\mathrm{der}\left(\left\lbrack any\right\rbrack,\:\left\lbrack dummy\right\rbrack,\:\left\lbrack any\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); let editor = await page.locator('#cell-6 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(operand, var, order): return sp.diff(operand, var, order) def custom_dims(operand, var, order): return operand/var**order `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-7 math-field.editable')).toBeVisible(); await page.setLatex(7, String.raw`\mathrm{indefInt}\left(\left\lbrack any\right\rbrack,\:\left\lbrack dummy\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.getByLabel('Use SymPy Mode').nth(1).check(); editor = await page.locator('#cell-7 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(integrand, var): return sp.Integral(integrand, var) def custom_dims(integrand, var): return integrand * var `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-8 math-field.editable')).toBeVisible(); await page.setLatex(8, String.raw`\mathrm{int}\left(\left\lbrack any\right\rbrack,\:\left\lbrack any\right\rbrack,\:\left\lbrack any\right\rbrack,\:\left\lbrack dummy\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.getByLabel('Use SymPy Mode').nth(2).check(); editor = await page.locator('#cell-8 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(integrand, lower_limit, upper_limit, var): return sp.Integral(integrand, (var, lower_limit, upper_limit)) def dims_transform(integrand, lower_limit, upper_limit, var): return sp.Subs(integrand, var, lower_limit), lower_limit, upper_limit def custom_dims(integrand, lower_limit, upper_limit): ensure_all_equivalent(lower_limit, upper_limit) return integrand * lower_limit `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m^2'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m'); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(0.5, precision); content = await page.textContent('#result-units-5'); expect(content).toBe('m^2'); }); test('Test dummy var with dim_values', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{summation}\left(\left\lbrack any\right\rbrack,\left\lbrack dummy\right\rbrack,\left\lbrack any\right\rbrack,\left\lbrack any\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\mathrm{summation}\left(n\cdot2\left\lbrack m\right\rbrack,\:n,\:1,\:3\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(operand, dummy_var, start, end): return sp.summation(operand, (dummy_var, start, end)) def custom_dims(operand, dummy_var, start, end, dim_values): start_value = dim_values["args"][2] end_value = dim_values["args"][3] return sp.summation(operand, (dummy_var, start_value, end_value)) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(12, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Test dim_values dummy variable and dims_transform', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{int}\left(\left\lbrack any\right\rbrack,\:\left\lbrack any\right\rbrack,\:\left\lbrack any\right\rbrack,\:\left\lbrack dummy\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\mathrm{int}\left(x,0\left\lbrack m\right\rbrack,1\left\lbrack m\right\rbrack,x\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(integrand, lower_limit, upper_limit, var): return sp.Integral(integrand, (var, lower_limit, upper_limit)) def dims_transform(integrand, lower_limit, upper_limit, var): return sp.Subs(integrand, var, lower_limit), lower_limit, upper_limit def custom_dims(integrand, lower_limit, upper_limit, dim_values): ensure_all_equivalent(lower_limit, upper_limit) return (integrand * lower_limit)**dim_values["result"] `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0.5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Test no first var dummy variable error check', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{int}\left(\left\lbrack dummy\right\rbrack,\:\left\lbrack any\right\rbrack,\:\left\lbrack any\right\rbrack,\:\left\lbrack any\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\mathrm{int}\left(x,0\left\lbrack m\right\rbrack,1\left\lbrack m\right\rbrack,x\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(integrand, lower_limit, upper_limit, var): return sp.Integral(integrand, (var, lower_limit, upper_limit)) def dims_transform(integrand, lower_limit, upper_limit, var): return sp.Subs(integrand, var, lower_limit), lower_limit, upper_limit def custom_dims(integrand, lower_limit, upper_limit): ensure_all_equivalent(lower_limit, upper_limit) return (integrand * lower_limit) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('.status-footer >> text=The dummy variable type cannot be the applied to the first function argument')).toBeVisible(); }); test('Test non-variable passed as dummy error detection', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{ℒ}\left(\left\lbrack any\right\rbrack,\left\lbrack dummy\right\rbrack,\left\lbrack dummy\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`H=\mathrm{ℒ}\left(t^4,t,s+1\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(operand, t, s): return sp.laplace_transform(operand, t, s)[0] `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('.status-footer >> text=Only a variable name my be used in the dummy variable position')).toBeVisible(); }); test('Test no dummy output type error check', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{int}\left(\left\lbrack any\right\rbrack,\:\left\lbrack any\right\rbrack,\:\left\lbrack any\right\rbrack,\:\left\lbrack any\right\rbrack\right)=\left\lbrack dummy\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\mathrm{int}\left(x,0\left\lbrack m\right\rbrack,1\left\lbrack m\right\rbrack,x\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(integrand, lower_limit, upper_limit, var): return sp.Integral(integrand, (var, lower_limit, upper_limit)) def dims_transform(integrand, lower_limit, upper_limit, var): return sp.Subs(integrand, var, lower_limit), lower_limit, upper_limit def custom_dims(integrand, lower_limit, upper_limit): ensure_all_equivalent(lower_limit, upper_limit) return (integrand * lower_limit) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('.status-footer >> text=All inputs and outputs must be of scalar type [any] to use the custom_dims function for code cell funciton int')).toBeVisible(); }); test('Test dummy variable without custom dims', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{int}\left(\left\lbrack any\right\rbrack,\:\left\lbrack m\right\rbrack,\:\left\lbrack m\right\rbrack,\:\left\lbrack dummy\right\rbrack\right)=\left\lbrack m^2\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\mathrm{int}\left(x,0\left\lbrack m\right\rbrack,\:1\left\lbrack m\right\rbrack,\:x\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(integrand, lower_limit, upper_limit, var): return sp.Integral(integrand, (var, lower_limit, upper_limit)) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0.5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^2'); }); test('Test require sympy mode for dummy variable mode', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{int}\left(\left\lbrack any\right\rbrack,\:\left\lbrack m\right\rbrack,\:\left\lbrack m\right\rbrack,\:\left\lbrack dummy\right\rbrack\right)=\left\lbrack m^2\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{int}\left(x,0\left\lbrack m\right\rbrack,\:1\left\lbrack m\right\rbrack,\:x\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(integrand, lower_limit, upper_limit, var): return sp.Integral(integrand, (var, lower_limit, upper_limit)) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('.status-footer >> text=Dummy variable type may only be used with SymPy mode')).toBeVisible(); }); test('Test mutliple dummy variables without units', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{ℒ}\left(\left\lbrack any\right\rbrack,\left\lbrack dummy\right\rbrack,\left\lbrack dummy\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`H=\mathrm{ℒ}\left(t^4,t,s\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(operand, t, s): return sp.laplace_transform(operand, t, s)[0] `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`H\left(s=1\right)=`) await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(24, precision); content = await page.textContent('#result-units-2'); expect(content).toBe(''); }); test('Test mutliple dummy variables with units', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{ℒ}\left(\left\lbrack any\right\rbrack,\left\lbrack dummy\right\rbrack,\left\lbrack dummy\right\rbrack\right)=\left\lbrack any\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`H=\mathrm{ℒ}\left(1\left\lbrack\frac{m}{s^5}\right\rbrack\cdot t^4,t,s\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(operand, t, s): return sp.laplace_transform(operand, t, s)[0] def dims_transform(operand, t, s): return sp.Subs(operand, t, 1/s), s def custom_dims(operand, s): return operand*(1/s) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`H\left(s=1\left\lbrack\frac{1}{s}\right\rbrack,\:t=1\left\lbrack s\right\rbrack\right)=`) await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(24, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); }); test('Test dummy variable with missing dummy var in function call', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{int}\left(\left\lbrack any\right\rbrack,\:\left\lbrack m\right\rbrack,\:\left\lbrack m\right\rbrack,\:\left\lbrack dummy\right\rbrack\right)=\left\lbrack m^2\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\mathrm{int}\left(x,0\left\lbrack m\right\rbrack,\:1\left\lbrack m\right\rbrack\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp def calculate(integrand, lower_limit, upper_limit, var): return sp.Integral(integrand, (var, lower_limit, upper_limit)) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('.status-footer >> text=Missing dummy variable for function int')).toBeVisible(); }); test('Test lambdify with multiple inputs', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{Colebrook}\left(\left\lbrack none\right\rbrack,\left\lbrack m\right\rbrack,\left\lbrack m\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`D=0.1022604\left\lbrack m\right\rbrack,\:\epsilon=6.096\times10^{-5}\left\lbrack m\right\rbrack`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` import sympy as sp import math def calculate(Re, D, epsilon): print(Re) # Use Churchill (1977) for an initial guess and for laminar or transition flow A = (-2.457*math.log((7/Re)**0.9+0.27*(epsilon/D)))**16.0 B = (37530/Re)**16.0 f_churchill = 8*((8/Re)**12.0+1/(A+B)**1.5)**(1.0/12.0) if Re < 4000: return f_churchill else: # In turbulent region, use Colebrook equation f = sp.symbols('f') return float(sp.nsolve(1/sp.sqrt(f)-1.74+2*sp.log((2*epsilon)/D + 18.7/(Re*sp.sqrt(f)), 10), f, f_churchill)) `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-2-0-0')).toBeFocused(); await page.keyboard.type('64'); await page.keyboard.press('Enter'); await page.keyboard.type('20000'); await page.setLatex(2, String.raw`Col2=\mathrm{Colebrook}\left(Col1,D,\epsilon\right)=`, 1); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`Col2_{1,1}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`Col2_{2,1}=`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-3'); expect(content).toBe(''); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(0.0271697911785628, precision); content = await page.textContent('#result-units-4'); expect(content).toBe(''); // check code cell evaluation caching await expect(page.locator('#cell-1 >> text=64.0')).toHaveText('64.0\n64.0\n20000.0\n'); }); ================================================ FILE: tests/test_code_cell_rendering.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos, not} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test text rendering without correct output type', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(value): return f"Result: {value}" `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('text=The code cell function CodeFunc1 returns a string value where a numerical value is expected. Specify an output type of [text], [html], or [markdown] to render string output.')).toBeVisible(); }); test('Test text rendering without correct output type in sympy mode', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack none\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(value): return f"Result: {value}" `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('text=The code cell function CodeFunc1 returns a string value where a numerical value is expected. Specify an output type of [text], [html], or [markdown] to render string output.')).toBeVisible(); }); test('Test text rendering', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack text\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(value): return f"Result: {value}" `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('pre >> text=Result: 2.0')).toBeVisible(); }); test('Test text rendering sympy mode', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack text\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(value): return f"Result: {value}" `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('pre >> text=Result: 2')).toBeVisible(); await expect(page.locator('pre >> text=Result: 2.0')).not.toBeVisible(); }); test('Test text rendering with mathjax equation', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack text\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = String.raw` def calculate(value): return rf"Result: $\sqrt{{{value}}}$" `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('#cell-0 msqrt >> text=2.0')).toBeVisible(); // make sure mathjax updates when results change await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(3\right)=`); await expect(page.locator('#cell-0 msqrt >> text=3.0')).toBeVisible(); await expect(page.locator('#cell-0 msqrt >> text=2.0')).not.toBeVisible(); }); test('Test text rendering with mathjax equation in sympy mode', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack text\right\rbrack`); await page.getByLabel('Use SymPy Mode').check(); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = String.raw` def calculate(value): return rf"Result: $\sqrt{{{value}}}$" `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('#cell-0 msqrt >> text=2')).toBeVisible(); await expect(page.locator('#cell-0 msqrt >> text=2.0')).not.toBeVisible(); // make sure mathjax updates when results change await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(3\right)=`); await expect(page.locator('#cell-0 msqrt >> text=3')).toBeVisible(); await expect(page.locator('#cell-0 msqrt >> text=3.0')).not.toBeVisible(); await expect(page.locator('#cell-0 msqrt >> text=2')).not.toBeVisible(); }); test('Test html rendering', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack html\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(value): return f'
{value}
' `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('#cell-0 div.html-test >> text=2.0')).toBeVisible(); }); test('Test html rendering with mathjax equation', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack html\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = String.raw` def calculate(value): return rf'
$$\sqrt{{{value}}}$$
' `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('#cell-0 msqrt >> text=2.0')).toBeVisible(); // make sure mathjax updates when results change await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(3\right)=`); await expect(page.locator('#cell-0 msqrt >> text=3.0')).toBeVisible(); await expect(page.locator('#cell-0 msqrt >> text=2.0')).not.toBeVisible(); }); test('Test markdown rendering with mathjax equation', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack markdown\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(2\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = String.raw` def calculate(value): return rf""" # My Heading ##### My normal text with an inline $\sqrt{{{value}}}$ equation """ `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('#cell-0 h1 >> text=My Heading')).toBeVisible() await expect(page.locator('#cell-0 h5 msqrt >> text=2.0')).toBeVisible(); // make sure mathjax updates when results change await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(3\right)=`); await expect(page.locator('#cell-0 h5 msqrt >> text=3.0')).toBeVisible(); await expect(page.locator('#cell-0 h5 msqrt >> text=2.0')).not.toBeVisible(); }); test('Test drawsvg integration', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack html\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(20\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = String.raw` import drawsvg as draw def calculate(radius): d = draw.Drawing(120, 120, origin='center') square = draw.Rectangle(-50, -50, 100, 100, fill='skyblue', stroke='black') d.append(square) circle = draw.Circle(0, 0, radius, fill='lightgreen', stroke='black') d.append(circle) return d.as_svg() `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('#cell-0 circle[r="20.0"]')).toBeVisible() await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(10\right)=`); await expect(page.locator('#cell-0 circle[r="10.0"]')).toBeVisible() }); test('Test matplotlib rendering and sklearn autoloading', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{CodeFunc1}\left(\left\lbrack any\right\rbrack\right)=\left\lbrack html\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{CodeFunc1}\left(\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = String.raw` import matplotlib import matplotlib.pyplot as plt from sklearn.datasets import make_checkerboard from io import BytesIO import base64 matplotlib.use("AGG") # Generate checkerboard data n_clusters = (4, 3) data, rows, columns = make_checkerboard( shape=(300, 300), n_clusters=n_clusters, noise=10, shuffle=False, random_state=42 ) # Create plot fig, ax = plt.subplots() cax = ax.matshow(data, cmap=plt.cm.Blues) plt.title("Original dataset") # Save plot to PNG in memory with BytesIO() as buf: plt.savefig(buf, format='png', bbox_inches='tight') buf.seek(0) # Encode to base64 img_base64 = base64.b64encode(buf.read()).decode('utf-8') # Create HTML string with embedded image html = f'Plot' plt.close(fig) def calculate(): return html `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await expect(page.locator('#cell-0 img[alt="Plot"]')).toBeVisible({timeout: 100000}) }); test('Test input unit conversions for render code function', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-code-cell').click(); await expect(page.locator('#cell-1 math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{summary1}\left(\left\lbrack MPa\right\rbrack,\:\left\lbrack MPa\right\rbrack\right)=\left\lbrack text\right\rbrack`); await page.setLatex(0, String.raw`\mathrm{summary1}\left(10\cdot10^6\left\lbrack Pa\right\rbrack,\:20\left\lbrack MPa\right\rbrack\right)=`); const editor = await page.locator('#cell-1 div.cm-content'); await editor.evaluate((node) => { const code = ` def calculate(value, threshold): if value > threshold: return f"Fail: Stress of {value} MPa exceeds allowable stress of {threshold} MPa" else: return f"Pass: Stress of {value} MPa is below allowable stress of {threshold} MPa" `; const view = node.cmView.view; view.dispatch({ changes: { from: 0, to: view.state.doc.length, insert: code } }); }); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator('#cell-0 pre >> text=Pass: Stress of 10.0 MPa is below allowable stress of 20.0 MPa')).toBeVisible(); // Remove units and make sure error is generated await page.setLatex(0, String.raw`\mathrm{summary1}\left(10,\:20\left\lbrack MPa\right\rbrack\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator('#cell-0 pre >> text=Dimension Error: Incorrect units for input number 1')).toBeVisible(); }); ================================================ FILE: tests/test_complex.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, complexLatex, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Imaginary numbers without units', async () => { // test complex numbers await page.type(':nth-match(math-field.editable, 1)', '2*sqrt-1'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 1)', '='); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', '3+i^2'); await page.press(':nth-match(math-field.editable, 2)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 2)', '='); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', '2+3*i='); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = complexLatex(await page.textContent('#result-value-0')); expect(content.re).toBeCloseTo(0, precision); expect(content.im).toBeCloseTo(2, precision); content = complexLatex(await page.textContent('#result-value-1')); expect(content.re).toBeCloseTo(2, precision); expect(content.im).toBeCloseTo(0, precision); content = complexLatex(await page.textContent('#result-value-2')); expect(content.re).toBeCloseTo(2, precision); expect(content.im).toBeCloseTo(3, precision); }); test('Imaginary number regression test for #69', async () => { await page.locator('math-field.editable').nth(0).type('test=1+i'); await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`i^{2}\cdot test=`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(content).toBe('-1 - i'); }); test('Test imaginary number unit conversions', async () => { await page.setLatex(0, String.raw`1\left[inch\right]-2\left[inch\right]\cdot i=\left[cm\right]`); await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`\left(60+30\cdot i\right)\cdot 1\left[sec\right]=\left[min\right]`); await page.keyboard.press('Shift+Enter'); await page.setLatex(2, String.raw`1000\left[J\right]\cdot i=\left[kJ\right]`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = complexLatex(await page.textContent('#result-value-0')); expect(content.re).toBeCloseTo(2.54, precision); expect(content.im).toBeCloseTo(-5.08, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('cm'); content = complexLatex(await page.textContent('#result-value-1')); expect(content.re).toBeCloseTo(1, precision); expect(content.im).toBeCloseTo(0.5, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('min'); content = complexLatex(await page.textContent('#result-value-2')); expect(content.re).toBeCloseTo(0.0, precision); expect(content.im).toBeCloseTo(1.0, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('kJ'); // make sure unit inconsistencies cause error await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`1\left[in\right]+i=`); await page.waitForSelector('.status-footer', {state: 'detached'}); await page.locator('#cell-3 >> text=Dimension Error').waitFor({state: 'attached', timeout: 1000}); await page.setLatex(3, String.raw`1+i\cdot 1\left[inch\right]=`); await page.waitForSelector('.status-footer', {state: 'detached'}); await page.locator('#cell-3 >> text=Dimension Error').waitFor({state: 'attached', timeout: 1000}); await page.setLatex(3, String.raw`1\left[inch\right]+i\cdot 1\left[inch\right]=\left[min\right]`); await page.waitForSelector('.status-footer', {state: 'detached'}); await page.locator('#cell-3 >> text=Units Mismatch').waitFor({state: 'attached', timeout: 1000}); }); test('Test angle function', async () => { // angle function // with units await page.setLatex(0, String.raw`\mathrm{angle}\left(1\left[inch\right]+\sqrt{3}\cdot 1\left[inch\right]\cdot i\right)=\left[deg\right]`); // without units await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`\mathrm{angle}\left(1-\sqrt{3}\cdot 1\cdot i\right)=\left[deg\right]`); // inconsistent units await page.keyboard.press('Shift+Enter'); await page.setLatex(2, String.raw`\mathrm{angle}\left(1-\sqrt{3}\cdot 1\left[inch\right]\cdot i\right)=\left[deg\right]`); await page.waitForSelector('.status-footer', {state: 'detached'}); // make sure inconsistent units generates error await page.locator('#cell-2 >> text=Dimension Error').waitFor({state: "attached", timeout: 1000}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(60.0, precision-1); content = await page.textContent('#result-units-0'); expect(content).toBe('deg'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(-60.0, precision-1); content = await page.textContent('#result-units-1'); expect(content).toBe('deg'); }); test('Test real function', async () => { // angle function // with units await page.setLatex(0, String.raw`\mathrm{real}\left(1\left[cc\right]+2\left[ml\right]\cdot i\right)=\left[ml\right]`); // without units await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`\mathrm{real}\left(3+2\cdot i\right)=`); // inconsistent units await page.keyboard.press('Shift+Enter'); await page.setLatex(2, String.raw`\mathrm{real}\left(3\left[cc\right]+2\cdot i\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); // make sure inconsistent units generates error await page.locator('#cell-2 >> text=Dimension Error').waitFor({state: "attached", timeout: 1000}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('ml'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); }); test('Test imag function', async () => { // angle function // with units await page.setLatex(0, String.raw`\mathrm{imag}\left(1\left[cc\right]+2\left[ml\right]\cdot i\right)=\left[ml\right]`); // without units await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`\mathrm{imag}\left(3+2\cdot i\right)=`); // inconsistent units await page.keyboard.press('Shift+Enter'); await page.setLatex(2, String.raw`\mathrm{imag}\left(3+2\left[cc\right]\cdot i\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); // make sure inconsistent units generates error await page.locator('#cell-2 >> text=Dimension Error').waitFor({state: "attached", timeout: 1000}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('ml'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); }); test('Test conj function', async () => { // angle function // with units await page.setLatex(0, String.raw`\mathrm{conj}\left(-1\left[cc\right]+2\left[ml\right]\cdot i\right)=\left[l\right]`); // without units await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`\mathrm{conj}\left(3-2\cdot i\right)=`); // inconsistent units await page.keyboard.press('Shift+Enter'); await page.setLatex(2, String.raw`\mathrm{conj}\left(3\left[cc\right]+2\cdot i\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); // make sure inconsistent units generates error await page.locator('#cell-2 >> text=Dimension Error').waitFor({state: "attached", timeout: 1000}); let content = complexLatex(await page.textContent('#result-value-0')); expect(content.re).toBeCloseTo(-.001, precision); expect(content.im).toBeCloseTo(-.002, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('l'); content = complexLatex(await page.textContent('#result-value-1')); expect(content.re).toBeCloseTo(3, precision); expect(content.im).toBeCloseTo(2, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); }); test('Test abs function with imaginary numbers and units', async () => { // define 2 complex impedance values with units await page.setLatex(0, String.raw`Z_{1}=\frac{1}{i\cdot 1e10\left[\frac{1}{sec}\right]\cdot 1\left[F\right]}`); await page.keyboard.press('Shift+Enter'); await page.setLatex(1, String.raw`Z_{2}=i\cdot 1e10\left[\frac{1}{sec}\right]\cdot 1\left[henry\right]`); // query the abs of a complex expression with units await page.keyboard.press('Shift+Enter'); await page.setLatex(2, String.raw`\left|\frac{Z_{2}}{Z_{1}+Z_{2}}\right|=`); // test case with only imaginary component and units await page.keyboard.press('Shift+Enter'); await page.setLatex(3, String.raw`\left|-1\left[inches\right]\cdot i\right|=\left[cm\right]`); // test case with both imaginary and real part and units await page.keyboard.press('Shift+Enter'); await page.setLatex(4, String.raw`\left|-3\left[inch\right]+4\left[inch\right]\cdot i\right|=\left[inch\right]`); // test case with both imaginary and real part and units await page.keyboard.press('Shift+Enter'); await page.setLatex(5, String.raw`\left|3+4\left[inch\right]\cdot i\right|=`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-2'); expect(content).toBe(''); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(2.54, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('cm'); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-units-4'); expect(content).toBe('inch'); // make sure inconsistent units case generates correct error message await page.locator('#cell-5 >> text=Dimension Error').waitFor({state: "attached", timeout: 1000}); }); ================================================ FILE: tests/test_context_menu.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Context menu copy and select all', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#cell-0 >> math-field.editable').type("1+2="); await page.locator('#cell-0 >> math-field.editable').click({button: "right"}); await page.locator('text=Copy').click(); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').press(modifierKey+"+v");; await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); // need to click to unselect since copy selects all await page.locator('#cell-0 >> math-field.editable').click(); await page.locator('#cell-0 >> math-field.editable').click({button: "right"}); await page.locator('text=Select All').click(); await new Promise((resolver) => setTimeout(resolver, 1000)); await page.locator('#cell-0 >> math-field.editable').type("3+4="); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(7, precision); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); }); test('Open context with menu button', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#cell-0 >> math-field.editable').type("1+2="); await page.locator('button:has-text("≡")').click(); await page.locator('text=Select All').click(); await page.locator('button:has-text("≡")').click(); await page.getByText('Cut', { exact: true }).click(); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').press(modifierKey+"+v");; await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.waitForSelector('#result-value-0', {state: 'detached'}); let content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); }); test('Select all then context menu copy bug on Safari', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#cell-0 >> math-field.editable').type("1+2="); await page.locator('#cell-0 >> math-field.editable').click({button: "right"}); await page.locator('text=Select All').click(); await new Promise((resolver) => setTimeout(resolver, 1000)); await page.locator('#cell-0 >> math-field.editable').click({button: "right"}); await page.locator('text=Copy').click(); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').press(modifierKey+"+v");; await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); }); test('Matrix insert column with context menu', async () => { await page.locator('#cell-0 >> math-field.editable').type('[2,1]'); await page.locator('#cell-0 >> math-field.editable').type('='); await page.locator('#cell-0 >> math-field.editable').press('Enter'); await page.locator('#cell-0 >> math-field.editable').type('a'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('b'); await page.locator('#cell-0 >> math-field.editable').click({button: "right"}); await page.locator('text=Insert Column Right').click(); await new Promise((resolver) => setTimeout(resolver, 1000)); await page.locator('#cell-0 >> math-field.editable').press('Shift+Tab'); await page.locator('#cell-0 >> math-field.editable').type('c'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('d'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a & c \\ b & d \end{bmatrix}`); }); test('Matrix delete row with context menu', async () => { await page.locator('#cell-0 >> math-field.editable').type('[2,1]'); await page.locator('#cell-0 >> math-field.editable').type('='); await page.locator('#cell-0 >> math-field.editable').press('Enter'); await page.locator('#cell-0 >> math-field.editable').type('a'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('b'); await page.locator('#cell-0 >> math-field.editable').click({button: "right"}); await page.locator('text=Delete Row').click(); await new Promise((resolver) => setTimeout(resolver, 1000)); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a \end{bmatrix}`); }); test('Matrix context menu options only visible when in matrix', async () => { await page.locator('#cell-0 >> math-field.editable').type('x='); await page.locator('#cell-0 >> math-field.editable').press('Enter'); await page.locator('#cell-0 >> math-field.editable').type('a'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('b'); await page.locator('#cell-0 >> math-field.editable').click({button: "right"}); await expect(page.locator('text=Insert Column')).not.toBeVisible(); }); ================================================ FILE: tests/test_csv_export_reference_data_table_format.csv ================================================ Col1=pi*range(3),Col2=1e-3*pi*range(3) 3.141592653589793,0.0031415926535897933 6.283185307179586,0.006283185307179587 9.42477796076938,0.00942477796076938 ================================================ FILE: tests/test_custom_base_units.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test custom base units for math cells', async () => { await page.setLatex(0, String.raw`1\left\lbrack kg\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`1\left\lbrack m^2\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`1\left\lbrack kg\cdot m\right\rbrack=`); // make sure cell level output units supersede sheet level selections await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`1\left\lbrack kg\cdot m\right\rbrack=\left\lbrack mg\cdot Mm\right\rbrack`); await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('tab', { name: 'Default Units' }).click(); await page.getByText('Mass').click(); await page.getByRole('option', { name: 'g', exact: true }).click(); await page.getByText('Length').click(); await page.getByRole('option', { name: 'mm', exact: true }).click(); await page.getByText('Area', {exact: true}).click(); await page.getByRole('option', { name: 'km^2', exact: true }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1000, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('g'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(1e-6, precision-2); content = await page.textContent('#result-units-1'); expect(content).toBe('km^2'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1e6, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('g^1*mm^1'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('mg*Mm'); // make sure sheet level settings modified dot is set await expect(page.getByText('Sheet Settings (Modified')).toBeAttached(); // save sheet to database await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); // clear contents by creating a new sheet await page.locator('#new-sheet').click(); // go back to page that was just saved await page.evaluate(() => window.history.back()); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('text=Updating...', {state: 'detached'}); // check that results have not changed and that sheet level modified dot is still set content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1000, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('g'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(1e-6, precision-2); content = await page.textContent('#result-units-1'); expect(content).toBe('km^2'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1e6, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('g^1*mm^1'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('mg*Mm'); await expect(page.getByText('Sheet Settings (Modified')).toBeAttached(); // set sheet wide settings to default await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('button', { name: 'Restore Defaults' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); // sheet wide status dot should be gone await expect(page.getByTitle('Sheet Settings (Modified')).not.toBeVisible(); await page.waitForSelector('text=Updating...', {state: 'detached'}); // output units should return to their default values content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('kg'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision-2); content = await page.textContent('#result-units-1'); expect(content).toBe('m^2'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('kg^1*m^1'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('mg*Mm'); }); test('Test custom base units for plot cells', async () => { await page.setLatex(0, String.raw`y=x`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`y\left(0\left\lbrack kg\right\rbrack\le x\le1000\left\lbrack kg\right\rbrack\right)=`); await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('tab', { name: 'Default Units' }).click(); await page.getByText('Mass').click(); await page.getByRole('option', { name: 'tonne', exact: true }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=tonne')).toBeAttached(); // set sheet wide settings back to default await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('button', { name: 'Restore Defaults' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=tonne')).not.toBeAttached(); }); test('Test custom base units for scatter plot', async () => { await page.setLatex(0, String.raw`y=.001\left\lbrack m\right\rbrack,\:x=1000\left\lbrack kg\right\rbrack`); await page.locator('#add-plot-cell').click(); await page.locator('#cell-1 >> math-field.editable').type("x,y="); await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('tab', { name: 'Default Units' }).click(); await page.getByText('Mass').click(); await page.getByRole('option', { name: 'tonne', exact: true }).click(); await page.getByText('Length').click(); await page.getByRole('option', { name: 'mm', exact: true }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=tonne')).toBeAttached(); await expect(page.locator('svg >> text=mm')).toBeAttached(); // make sure cell level units supersede sheet level selections await page.setLatex(1, String.raw`x,y=\:\left\lbrack g\right\rbrack,\:\left\lbrack km\right\rbrack`, 0); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=tonne')).not.toBeAttached(); await expect(page.locator('svg >> text=mm')).not.toBeAttached(); }); test('Test custom base units with code generation', async () => { await page.setLatex(0, String.raw`y=x`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`y\left(x=10\left\lbrack m\right\rbrack\right)=`); await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('tab', { name: 'Default Units' }).click(); await page.getByText('Length').click(); await page.getByRole('option', { name: 'km', exact: true }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.locator('#code-gen-1').click(); let content = await page.locator('code').textContent(); expect(content).toBe(`def y(x): """ Function 'y' automatically generated by EngineeringPaper.xyz Parameters ---------- x : float 'x' has units of [m]. Returns ------- float Return value has units of [km]. """ result = x return result / 1000 `); await page.keyboard.press('Escape'); }); test('Test cell units supersede with code generation', async () => { await page.setLatex(0, String.raw`y=x`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`y\left(x=1000\left\lbrack m\right\rbrack\right)=\left\lbrack mm\right\rbrack`); await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('tab', { name: 'Default Units' }).click(); await page.getByText('Length').click(); await page.getByRole('option', { name: 'km', exact: true }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.locator('#code-gen-1').click(); let content = await page.locator('code').textContent(); expect(content).toBe(`def y(x): """ Function 'y' automatically generated by EngineeringPaper.xyz Parameters ---------- x : float 'x' has units of [m]. Returns ------- float Return value has units of [mm]. """ result = x return result / 0.001 `); await page.keyboard.press('Escape'); }); test('Test user default config', async () => { await page.setLatex(0, String.raw`1\left\lbrack m\right\rbrack=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('tab', { name: 'Default Units' }).click(); await page.getByRole('button', { name: 'inch-lbm-sec'}).click(); await page.getByRole('tab', { name: 'Set User Default'}).click(); await expect(page.locator('text=The current sheet config differs from the user default config')).toBeAttached(); await page.getByRole('button', { name: "Use This Sheet's Config as the User Default Config"}).click(); await expect(page.locator('text=The current sheet config matches the user default config')).toBeAttached(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1000/25.4, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('in'); // load new sheet and make sure it is using the user default sheet config await newSheet(page); await page.setLatex(0, String.raw`2\left\lbrack m\right\rbrack=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2000/25.4, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('in'); // change this sheet's config and then apply user default config await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('tab', { name: 'Default Units' }).click(); await page.getByRole('button', { name: 'mm-kg-sec'}).click(); await page.getByRole('tab', { name: 'Set User Default'}).click(); await expect(page.locator('text=The current sheet config differs from the user default config')).toBeAttached(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2000, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('mm'); // apply the user default config await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('tab', { name: 'Set User Default'}).click(); await expect(page.locator('text=The current sheet config differs from the user default config')).toBeAttached(); await page.getByRole('button', { name: 'Apply the User Default Config to This Sheet'}).click(); await expect(page.locator('text=The current sheet config matches the user default config')).toBeAttached(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2000/25.4, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('in'); // switch back to the default config and save it as the user default config await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('tab', { name: 'Set User Default'}).click(); await expect(page.locator('text=The current sheet config matches the user default config')).toBeAttached(); await page.getByRole('button', { name: 'Restore Defaults'}).click(); await expect(page.locator('text=The current sheet is using the EngineeringPaper.xyz default config which is different than the user default config')).toBeAttached(); await page.getByRole('button', { name: "Use This Sheet's Config as the User Default Config"}).click(); await expect(page.locator('text=The current sheet config matches the user default config')).toBeAttached(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); // load new sheet and make sure it is using the default sheet config await newSheet(page); await page.setLatex(0, String.raw`3\left\lbrack m\right\rbrack=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); ================================================ FILE: tests/test_data_table.spec.mjs ================================================ import { promises as fs } from 'fs'; import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test table assign no units', async () => { await page.setLatex(0, String.raw`Col1=`); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-1-0-0')).toBeFocused(); await page.keyboard.type('11'); await page.keyboard.press('Enter'); await page.keyboard.type('22'); await page.keyboard.press('Enter'); await page.keyboard.type('0'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 11 \\ 22 \\ 0 \end{bmatrix}`); // add row and make sure the result updates await page.locator("#data-table-input-1-2-0").click(); await page.keyboard.press('Enter'); await page.keyboard.type('33'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 11 \\ 22 \\ 0 \\ 33 \end{bmatrix}`); }); test('Test table assign with units', async () => { await page.setLatex(0, String.raw`Col1=`); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-1-0-0')).toBeFocused(); await page.keyboard.type('11'); await page.keyboard.press('Enter'); await page.keyboard.type('22'); await page.keyboard.press('Enter'); await page.keyboard.type('0'); await page.locator('#parameter-units-1-0 >> math-field').type('[m]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 11\left\lbrack m\right\rbrack \\ 22\left\lbrack m\right\rbrack \\ 0\left\lbrack m\right\rbrack \end{bmatrix}`); // add row and make sure the result updates await page.locator("#data-table-input-1-2-0").click(); await page.keyboard.press('Enter'); await page.keyboard.type('33'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 11\left\lbrack m\right\rbrack \\ 22\left\lbrack m\right\rbrack \\ 0\left\lbrack m\right\rbrack \\ 33\left\lbrack m\right\rbrack \end{bmatrix}`); }); test('Test computed column with and without units and adding/deleting rows/cols', async () => { await page.setLatex(0, String.raw`Col3=`); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-1-0-0')).toBeFocused(); await page.keyboard.type('11'); await page.keyboard.press('Tab'); await page.keyboard.type('44'); await page.keyboard.press('Tab'); await page.keyboard.type('22'); await page.keyboard.press('Tab'); await page.keyboard.type('55'); await page.keyboard.press('Enter'); await page.keyboard.type('0'); await page.locator('#add-col-1').click(); await page.setLatex(1, String.raw`Col1+Col2=`, 2); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('Col3'); content = await page.textContent('#grid-cell-1-0-2'); expect(parseFloat(content)).toBeCloseTo(55, precision); content = await page.textContent('#grid-cell-1-1-2'); expect(parseFloat(content)).toBeCloseTo(77, precision); content = await page.textContent('#grid-cell-1-2-2'); expect(content.trim()).toBe(''); // switch to an assign instead of a query await page.setLatex(1, String.raw`Col3=2\cdot\left(Col1+Col2\right)`, 2); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 110 \\ 154 \end{bmatrix}`); content = await page.textContent('#grid-cell-1-0-2'); expect(parseFloat(content)).toBeCloseTo(110, precision); content = await page.textContent('#grid-cell-1-1-2'); expect(parseFloat(content)).toBeCloseTo(154, precision); content = await page.textContent('#grid-cell-1-2-2'); expect(content.trim()).toBe(''); // switch to an assign plus query await page.setLatex(1, String.raw`Col3=3\cdot\left(Col1+Col2\right)=`, 2); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 165 \\ 231 \end{bmatrix}`); content = await page.textContent('#grid-cell-1-0-2'); expect(parseFloat(content)).toBeCloseTo(165, precision); content = await page.textContent('#grid-cell-1-1-2'); expect(parseFloat(content)).toBeCloseTo(231, precision); content = await page.textContent('#grid-cell-1-2-2'); expect(content.trim()).toBe(''); // add value to last row of second column await page.locator("#data-table-input-1-2-1").type('10'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 165 \\ 231 \\ 30 \end{bmatrix}`); content = await page.textContent('#grid-cell-1-0-2'); expect(parseFloat(content)).toBeCloseTo(165, precision); content = await page.textContent('#grid-cell-1-1-2'); expect(parseFloat(content)).toBeCloseTo(231, precision); content = await page.textContent('#grid-cell-1-2-2'); expect(parseFloat(content)).toBeCloseTo(30, precision); // add units to only first column (should cause dimension error) await page.locator('#parameter-units-1-0 >> math-field').type('[m]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeAttached(); await expect(page.locator('#parameter-name-1-2 >> text=Dimension Error')).toBeAttached(); // add units to second column to fix dimension error await page.locator('#parameter-units-1-1 >> math-field').type('[m]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 165\left\lbrack m\right\rbrack \\ 231\left\lbrack m\right\rbrack \\ 30\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent('#grid-cell-1-0-2'); expect(parseFloat(content)).toBeCloseTo(165, precision); content = await page.textContent('#grid-cell-1-1-2'); expect(parseFloat(content)).toBeCloseTo(231, precision); content = await page.textContent('#grid-cell-1-2-2'); expect(parseFloat(content)).toBeCloseTo(30, precision); await page.locator('#parameter-units-1-2 >> math-field').click({clickCount: 3}); await expect(page.locator('#parameter-units-1-2 >> text=\\left\\lbrack m\\right\\rbrack')).toBeAttached(); // specify custom output units for calculated column await page.setLatex(1, String.raw`Col3=3\cdot\left(Col1+Col2\right)=\left\lbrack mm\right\rbrack`, 2); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 165\left\lbrack m\right\rbrack \\ 231\left\lbrack m\right\rbrack \\ 30\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent('#grid-cell-1-0-2'); expect(parseFloat(content)).toBeCloseTo(165000, precision); content = await page.textContent('#grid-cell-1-1-2'); expect(parseFloat(content)).toBeCloseTo(231000, precision); content = await page.textContent('#grid-cell-1-2-2'); expect(parseFloat(content)).toBeCloseTo(30000, precision); await page.locator('#parameter-units-1-2 >> math-field').click({clickCount: 3}); await expect(page.locator('#parameter-units-1-2 >> text=\\left\\lbrack mm\\right\\rbrack')).toBeAttached(); // update one data table value and make sure results update await page.locator('#data-table-input-1-1-1').click({clickCount: 3}); await page.locator('#data-table-input-1-1-1').type('3'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 165\left\lbrack m\right\rbrack \\ 75\left\lbrack m\right\rbrack \\ 30\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent('#grid-cell-1-0-2'); expect(parseFloat(content)).toBeCloseTo(165000, precision); content = await page.textContent('#grid-cell-1-1-2'); expect(parseFloat(content)).toBeCloseTo(75000, precision); content = await page.textContent('#grid-cell-1-2-2'); expect(parseFloat(content)).toBeCloseTo(30000, precision); await page.locator('#parameter-units-1-2 >> math-field').click({clickCount: 3}); await expect(page.locator('#parameter-units-1-2 >> text=\\left\\lbrack mm\\right\\rbrack')).toBeAttached(); // delete first row await page.locator('#delete-row-1-0').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 75\left\lbrack m\right\rbrack \\ 30\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent('#grid-cell-1-0-2'); expect(parseFloat(content)).toBeCloseTo(75000, precision); content = await page.textContent('#grid-cell-1-1-2'); expect(parseFloat(content)).toBeCloseTo(30000, precision); await expect(page.locator('#grid-cell-1-2-0')).toBeHidden(); await page.locator('#parameter-units-1-2 >> math-field').click({clickCount: 3}); await expect(page.locator('#parameter-units-1-2 >> text=\\left\\lbrack mm\\right\\rbrack')).toBeAttached(); // delete first col await page.locator('#delete-col-1-0').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#parameter-name-1-1 >> text=Some results do not evaluate to a finite real value, which cannot be displayed in a data table')).toBeAttached(); // update calculated column equation to no longer reference missing column await page.setLatex(1, String.raw`Col3=3\cdot Col2=\left\lbrack mm\right\rbrack`, 1); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 9\left\lbrack m\right\rbrack \\ 30\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent('#grid-cell-1-0-1'); expect(parseFloat(content)).toBeCloseTo(9000, precision); content = await page.textContent('#grid-cell-1-1-1'); expect(parseFloat(content)).toBeCloseTo(30000, precision); await expect(page.locator('#grid-cell-1-0-2')).toBeHidden(); await page.locator('#parameter-units-1-1 >> math-field').click({clickCount: 3}); await expect(page.locator('#parameter-units-1-1 >> text=\\left\\lbrack mm\\right\\rbrack')).toBeAttached(); // add text to first column first row data table input to force the vector to be zero size await page.locator('#data-table-input-1-0-0').type('a'); await expect(page.locator('#grid-cell-1-0-0 >> text=Data table must contain numeric values')).toBeAttached(); await expect(page.locator('text=Attempt to use empty column "Col2" in a data table calculation')).toBeAttached(); // update calculation to not use empty column await page.setLatex(1, String.raw`Col3=Col4`, 1); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#parameter-name-1-1 >> text=Some results do not evaluate to a finite real value, which cannot be displayed in a data table')).toBeAttached(); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`Col4`); // add new column and make sure parameter id list updates to include new column await page.locator('#add-col-1').click(); await expect(page.locator('text=Attempt to use empty column "Col4" in a data table calculation')).toBeAttached(); // add value to first entry of new column and make sure everything updates await page.locator('#data-table-input-1-0-2').type('7'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 7 \end{bmatrix}`); content = await page.textContent('#grid-cell-1-0-1'); expect(parseFloat(content)).toBeCloseTo(7, precision); content = await page.textContent('#grid-cell-1-1-1'); expect(content.trim()).toBe(''); }); test('Test auto grow with range output', async () => { await page.setLatex(0, String.raw`Col1=`); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-1-0-0')).toBeAttached(); await expect(page.locator('#data-table-input-1-9-1')).toBeHidden(); await page.setLatex(1, String.raw`Col1=\mathrm{range}\left(10\right)`, 0); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \end{bmatrix}`); await expect(page.locator('#data-table-input-1-9-1')).toBeAttached(); content = await page.textContent('#grid-cell-1-0-0'); expect(parseFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#grid-cell-1-1-0'); expect(parseFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#grid-cell-1-2-0'); expect(parseFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#grid-cell-1-3-0'); expect(parseFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#grid-cell-1-4-0'); expect(parseFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#grid-cell-1-5-0'); expect(parseFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#grid-cell-1-6-0'); expect(parseFloat(content)).toBeCloseTo(7, precision); content = await page.textContent('#grid-cell-1-7-0'); expect(parseFloat(content)).toBeCloseTo(8, precision); content = await page.textContent('#grid-cell-1-8-0'); expect(parseFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#grid-cell-1-9-0'); expect(parseFloat(content)).toBeCloseTo(10, precision); }); test('Test table assign with base temperature units', async () => { await page.setLatex(0, String.raw`Col1=`); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-1-0-0')).toBeFocused(); await page.keyboard.type('0'); await page.keyboard.press('Enter'); await page.keyboard.type('-40'); await page.keyboard.press('Enter'); await page.keyboard.type('100'); await page.locator('#parameter-units-1-0 >> math-field').type('[degC]'); await page.setLatex(1, String.raw`Col1=\left\lbrack degF\right\rbrack`, 1); await page.waitForSelector('div.status-footer', {state: 'detached'}); let content = await page.textContent('#grid-cell-1-0-1'); expect(parseFloat(content)).toBeCloseTo(32, 12); content = await page.textContent('#grid-cell-1-1-1'); expect(parseFloat(content)).toBeCloseTo(-40, precision); content = await page.textContent('#grid-cell-1-2-1'); expect(parseFloat(content)).toBeCloseTo(212, 12); }); test('Test linear interpolation', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.locator('#add-data-table-cell').click(); await page.locator('#add-col-1').click(); await page.locator('#data-table-input-1-0-0').click(); await page.keyboard.type('0'); await page.keyboard.press('Tab'); await page.keyboard.type('0'); await page.keyboard.press('Tab'); await page.keyboard.type('10'); await page.keyboard.press('Enter'); await page.keyboard.type('2'); await page.keyboard.press('Tab'); await page.keyboard.type('4'); await page.keyboard.press('Tab'); await page.keyboard.type('6'); await page.keyboard.press('Enter'); await page.keyboard.type('4'); await page.keyboard.press('Tab'); await page.keyboard.type('16'); await page.keyboard.press('Tab'); await page.keyboard.type('-6'); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.getByLabel('Copy function name to').click(); await page.locator('#cell-0 >> math-field.editable').press(modifierKey+'+v'); await page.locator('#cell-0 >> math-field.editable').type('(1)='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); // change output and make sure result changes await page.locator('#output-radio-1-0-2').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); // change input and make sure result updates await page.locator('#input-radio-1-0-1-0').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); // add units to inputs and outputs await page.locator('#parameter-units-1-1 >> math-field').type('[m]'); await page.locator('#parameter-units-1-2 >> math-field').type('[s]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeAttached(); // update query to fix dimension error await page.locator('#cell-0 >> math-field.editable').click({clickCount: 3}); await page.locator('#cell-0 >> math-field.editable').press(modifierKey+'+v'); await page.locator('#cell-0 >> math-field.editable').type('(2[m])='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('s'); // save sheet to database await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); // clear contents by creating a new sheet await page.locator('#new-sheet').click(); // go back to page that was just saved await page.evaluate(() => window.history.back()); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('s'); // make sure extrapolation generates an error await page.locator('#cell-0 >> math-field.editable').click({clickCount: 3}); await page.locator('#cell-0 >> math-field.editable').press(modifierKey+'+v'); await page.locator('#cell-0 >> math-field.editable').type('(17[m])='); await page.locator('#cell-0 >> math-field.editable').press('Enter'); await expect(page.locator('text=Attempt to extrapolate with the interpolation function')).toBeAttached(); }); test('Test linear interpolation with scaled and offset units', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.locator('#add-data-table-cell').click(); await page.locator('#data-table-input-1-0-0').click(); await page.keyboard.type('0'); await page.keyboard.press('Tab'); await page.keyboard.type('1.7918'); await page.keyboard.press('Enter'); await page.keyboard.type('20'); await page.keyboard.press('Tab'); await page.keyboard.type('1.0026'); await page.keyboard.press('Enter'); await page.keyboard.type('50'); await page.keyboard.press('Tab'); await page.keyboard.type('0.5471'); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.getByLabel('Copy function name to').click(); // add units to inputs and outputs await page.locator('#parameter-units-1-0 >> math-field').type('[degC]'); await page.locator('#parameter-units-1-1 >> math-field').type('[cP]'); await page.locator('#cell-0 >> math-field.editable').press(modifierKey+'+v'); await page.locator('#cell-0 >> math-field.editable').type('(10[degC])=[cP]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1.3972, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('cP'); }); test('Test polyfit (quadratic and linear)', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.locator('#add-data-table-cell').click(); await page.locator('#add-col-1').click(); await page.locator('#data-table-input-1-0-0').click(); await page.keyboard.type('0'); await page.keyboard.press('Tab'); await page.keyboard.type('0'); await page.keyboard.press('Tab'); await page.keyboard.type('10'); await page.keyboard.press('Enter'); await page.keyboard.type('2'); await page.keyboard.press('Tab'); await page.keyboard.type('4'); await page.keyboard.press('Tab'); await page.keyboard.type('6'); await page.keyboard.press('Enter'); await page.keyboard.type('4'); await page.keyboard.press('Tab'); await page.keyboard.type('16'); await page.keyboard.press('Tab'); await page.keyboard.type('-6'); await page.getByRole('button', { name: 'Add Polyfit' }).click(); await page.getByLabel('Order:').fill('2'); await page.getByLabel('Copy function name to').click(); await page.locator('#cell-0 >> math-field.editable').press(modifierKey+'+v'); await page.locator('#cell-0 >> math-field.editable').type('(1.1)='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1.21, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); // change output and make sure result changes await page.locator('#output-radio-1-0-2').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(8.79, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); // change input and order await page.getByLabel('Order:').fill('1'); await page.locator('#input-radio-1-0-1-0').click(); // add units to inputs and outputs await page.locator('#parameter-units-1-1 >> math-field').type('[m]'); await page.locator('#parameter-units-1-2 >> math-field').type('[s]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeAttached(); // update query to fix dimension error await page.locator('#cell-0 >> math-field.editable').click({clickCount: 3}); await page.locator('#cell-0 >> math-field.editable').press(modifierKey+'+v'); await page.locator('#cell-0 >> math-field.editable').type('(2[m])='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('s'); // save sheet to database await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); // clear contents by creating a new sheet await page.locator('#new-sheet').click(); // go back to page that was just saved await page.evaluate(() => window.history.back()); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('s'); // query symbolic version of polyfit await page.locator('#cell-0 >> math-field.editable').click({clickCount: 3}); await page.locator('#cell-0 >> math-field.editable').press(modifierKey+'+v'); await page.locator('#cell-0 >> math-field.editable').type('(x)='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe('10.0 - 1.0 \\cdot x'); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test excel file import with headers and no units', async () => { await page.setLatex(0, String.raw`col1=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`B=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\alpha_1=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\sigma_{initial}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`col3=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`G=`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/headers_no_units.xlsx'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 4.1 \\ 0 \\ 3 \\ 1 \\ -20.3 \end{bmatrix}`); content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\begin{bmatrix} 9 \\ 8 \\ 7 \\ 0 \\ -1 \\ -2 \\ -3 \\ -3.4 \end{bmatrix}`); content = await page.textContent(`#result-value-2`); expect(content).toBe(String.raw`\begin{bmatrix} 1.1\times 10^{30} \\ -1.2\times 10^{-30} \\ 0 \\ 1 \\ 2 \\ 3 \\ 4 \end{bmatrix}`); content = await page.textContent(`#result-value-3`); expect(content).toBe(String.raw`\begin{bmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \end{bmatrix}`); content = await page.textContent(`#result-value-4`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \end{bmatrix}`); content = await page.textContent(`#result-value-5`); expect(content).toBe(String.raw`\begin{bmatrix} 4 \\ 5 \\ 6 \\ 7 \end{bmatrix}`); }); test('Test excel file import with headers and units', async () => { await page.setLatex(0, String.raw`col1=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`B=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\alpha_1=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\sigma_{initial}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`col3=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`G=`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/headers_and_units.xlsx'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('div.status-footer', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 4.1\left\lbrack m\right\rbrack \\ 0\left\lbrack m\right\rbrack \\ 3\left\lbrack m\right\rbrack \\ 1\left\lbrack m\right\rbrack \\ -20.3\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\begin{bmatrix} 9\left\lbrack s\right\rbrack \\ 8\left\lbrack s\right\rbrack \\ 7\left\lbrack s\right\rbrack \\ 0\left\lbrack s\right\rbrack \\ -1\left\lbrack s\right\rbrack \\ -2\left\lbrack s\right\rbrack \\ -3\left\lbrack s\right\rbrack \\ -3.4\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-2`); expect(content).toBe(String.raw`\begin{bmatrix} 1.1\times 10^{30} \\ -1.2\times 10^{-30} \\ 0 \\ 1 \\ 2 \\ 3 \\ 4 \end{bmatrix}`); content = await page.textContent(`#result-value-3`); expect(content).toBe(String.raw`\begin{bmatrix} 0\left\lbrack m\right\rbrack \\ 1000\left\lbrack m\right\rbrack \\ 2000\left\lbrack m\right\rbrack \\ 3000\left\lbrack m\right\rbrack \\ 4000\left\lbrack m\right\rbrack \\ 5000\left\lbrack m\right\rbrack \\ 6000\left\lbrack m\right\rbrack \\ 7000\left\lbrack m\right\rbrack \\ 8000\left\lbrack m\right\rbrack \\ 9000\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-4`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \end{bmatrix}`); content = await page.textContent(`#result-value-5`); expect(content).toBe(String.raw`\begin{bmatrix} 4\left\lbrack K\right\rbrack \\ 5\left\lbrack K\right\rbrack \\ 6\left\lbrack K\right\rbrack \\ 7\left\lbrack K\right\rbrack \end{bmatrix}`); }); test('Test excel file without headers', async () => { await page.setLatex(0, String.raw`A=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`B=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`C=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`D=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`F=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`G=`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/no_headers.xlsx'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 4.1 \\ 0 \\ 3 \\ 1 \\ -20.3 \end{bmatrix}`); content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\begin{bmatrix} 9 \\ 8 \\ 7 \\ 0 \\ -1 \\ -2 \\ -3 \\ -3.4 \end{bmatrix}`); content = await page.textContent(`#result-value-2`); expect(content).toBe(String.raw`\begin{bmatrix} 1.1\times 10^{30} \\ -1.2\times 10^{-30} \\ 0 \\ 1 \\ 2 \\ 3 \\ 4 \end{bmatrix}`); content = await page.textContent(`#result-value-3`); expect(content).toBe(String.raw`\begin{bmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \end{bmatrix}`); content = await page.textContent(`#result-value-4`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \end{bmatrix}`); content = await page.textContent(`#result-value-5`); expect(content).toBe(String.raw`\begin{bmatrix} 4 \\ 5 \\ 6 \\ 7 \end{bmatrix}`); }); test('Test csv file import with headers and units', async () => { await page.setLatex(0, String.raw`col1=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`B=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\alpha_1=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\sigma_{initial}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`col3=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`G=`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/headers_and_units.csv'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('div.status-footer', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 4.1\left\lbrack m\right\rbrack \\ 0\left\lbrack m\right\rbrack \\ 3\left\lbrack m\right\rbrack \\ 1\left\lbrack m\right\rbrack \\ -20.3\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\begin{bmatrix} 9\left\lbrack s\right\rbrack \\ 8\left\lbrack s\right\rbrack \\ 7\left\lbrack s\right\rbrack \\ 0\left\lbrack s\right\rbrack \\ -1\left\lbrack s\right\rbrack \\ -2\left\lbrack s\right\rbrack \\ -3\left\lbrack s\right\rbrack \\ -3.4\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-2`); expect(content).toBe(String.raw`\begin{bmatrix} 1.1\times 10^{30} \\ -1.2\times 10^{-30} \\ 0 \\ 1 \\ 2 \\ 3 \\ 4 \end{bmatrix}`); content = await page.textContent(`#result-value-3`); expect(content).toBe(String.raw`\begin{bmatrix} 0\left\lbrack m\right\rbrack \\ 1000\left\lbrack m\right\rbrack \\ 2000\left\lbrack m\right\rbrack \\ 3000\left\lbrack m\right\rbrack \\ 4000\left\lbrack m\right\rbrack \\ 5000\left\lbrack m\right\rbrack \\ 6000\left\lbrack m\right\rbrack \\ 7000\left\lbrack m\right\rbrack \\ 8000\left\lbrack m\right\rbrack \\ 9000\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-4`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \end{bmatrix}`); content = await page.textContent(`#result-value-5`); expect(content).toBe(String.raw`\begin{bmatrix} 4\left\lbrack K\right\rbrack \\ 5\left\lbrack K\right\rbrack \\ 6\left\lbrack K\right\rbrack \\ 7\left\lbrack K\right\rbrack \end{bmatrix}`); }); test('Test csv export and reload', async () => { await page.setLatex(0, String.raw`col1=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`B=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\alpha_1=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\sigma_{initial}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`col3=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`G=`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/headers_and_units.csv'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 4.1\left\lbrack m\right\rbrack \\ 0\left\lbrack m\right\rbrack \\ 3\left\lbrack m\right\rbrack \\ 1\left\lbrack m\right\rbrack \\ -20.3\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\begin{bmatrix} 9\left\lbrack s\right\rbrack \\ 8\left\lbrack s\right\rbrack \\ 7\left\lbrack s\right\rbrack \\ 0\left\lbrack s\right\rbrack \\ -1\left\lbrack s\right\rbrack \\ -2\left\lbrack s\right\rbrack \\ -3\left\lbrack s\right\rbrack \\ -3.4\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-2`); expect(content).toBe(String.raw`\begin{bmatrix} 1.1\times 10^{30} \\ -1.2\times 10^{-30} \\ 0 \\ 1 \\ 2 \\ 3 \\ 4 \end{bmatrix}`); content = await page.textContent(`#result-value-3`); expect(content).toBe(String.raw`\begin{bmatrix} 0\left\lbrack m\right\rbrack \\ 1000\left\lbrack m\right\rbrack \\ 2000\left\lbrack m\right\rbrack \\ 3000\left\lbrack m\right\rbrack \\ 4000\left\lbrack m\right\rbrack \\ 5000\left\lbrack m\right\rbrack \\ 6000\left\lbrack m\right\rbrack \\ 7000\left\lbrack m\right\rbrack \\ 8000\left\lbrack m\right\rbrack \\ 9000\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-4`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \end{bmatrix}`); content = await page.textContent(`#result-value-5`); expect(content).toBe(String.raw`\begin{bmatrix} 4\left\lbrack K\right\rbrack \\ 5\left\lbrack K\right\rbrack \\ 6\left\lbrack K\right\rbrack \\ 7\left\lbrack K\right\rbrack \end{bmatrix}`); let [download] = await Promise.all([ page.waitForEvent('download'), page.getByRole('button', { name: 'Export CSV' }).click() ]); // open a different file first to make sure results change page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/headers_no_units.xlsx'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('div.status-footer', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 4.1 \\ 0 \\ 3 \\ 1 \\ -20.3 \end{bmatrix}`); content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\begin{bmatrix} 9 \\ 8 \\ 7 \\ 0 \\ -1 \\ -2 \\ -3 \\ -3.4 \end{bmatrix}`); content = await page.textContent(`#result-value-2`); expect(content).toBe(String.raw`\begin{bmatrix} 1.1\times 10^{30} \\ -1.2\times 10^{-30} \\ 0 \\ 1 \\ 2 \\ 3 \\ 4 \end{bmatrix}`); content = await page.textContent(`#result-value-3`); expect(content).toBe(String.raw`\begin{bmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \end{bmatrix}`); content = await page.textContent(`#result-value-4`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \end{bmatrix}`); content = await page.textContent(`#result-value-5`); expect(content).toBe(String.raw`\begin{bmatrix} 4 \\ 5 \\ 6 \\ 7 \end{bmatrix}`); // re-open csv file that was previously saved to make sure results are still the same page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(await download.path()); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); // need to fix latex parameter name since that won't survive the round trip await page.setLatex(6, String.raw`\sigma_{initial}`, 3); await page.waitForSelector('div.status-footer', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 4.1\left\lbrack m\right\rbrack \\ 0\left\lbrack m\right\rbrack \\ 3\left\lbrack m\right\rbrack \\ 1\left\lbrack m\right\rbrack \\ -20.3\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\begin{bmatrix} 9\left\lbrack s\right\rbrack \\ 8\left\lbrack s\right\rbrack \\ 7\left\lbrack s\right\rbrack \\ 0\left\lbrack s\right\rbrack \\ -1\left\lbrack s\right\rbrack \\ -2\left\lbrack s\right\rbrack \\ -3\left\lbrack s\right\rbrack \\ -3.4\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-2`); expect(content).toBe(String.raw`\begin{bmatrix} 1.1\times 10^{30} \\ -1.2\times 10^{-30} \\ 0 \\ 1 \\ 2 \\ 3 \\ 4 \end{bmatrix}`); content = await page.textContent(`#result-value-3`); expect(content).toBe(String.raw`\begin{bmatrix} 0\left\lbrack m\right\rbrack \\ 1000\left\lbrack m\right\rbrack \\ 2000\left\lbrack m\right\rbrack \\ 3000\left\lbrack m\right\rbrack \\ 4000\left\lbrack m\right\rbrack \\ 5000\left\lbrack m\right\rbrack \\ 6000\left\lbrack m\right\rbrack \\ 7000\left\lbrack m\right\rbrack \\ 8000\left\lbrack m\right\rbrack \\ 9000\left\lbrack m\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-4`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \end{bmatrix}`); content = await page.textContent(`#result-value-5`); expect(content).toBe(String.raw`\begin{bmatrix} 4\left\lbrack K\right\rbrack \\ 5\left\lbrack K\right\rbrack \\ 6\left\lbrack K\right\rbrack \\ 7\left\lbrack K\right\rbrack \end{bmatrix}`); }); test('Test fluid function in data table', async () => { await page.setLatex(0, String.raw`\rho_{3,1}=`); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-1-0-0')).toBeFocused(); await page.keyboard.type('.1'); await page.keyboard.press('Enter'); await page.keyboard.type('1'); await page.keyboard.press('Enter'); await page.keyboard.type('1.1'); await page.locator('#parameter-units-1-0 >> math-field').type('[atm]'); await page.setLatex(1, String.raw`P`, 0); await page.setLatex(1, String.raw`\rho=\mathrm{WaterDGivenTP}\left(20\left\lbrack degC\right\rbrack,P\right)`, 1); await page.locator('#add-fluid-cell').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(998.2117920164021, 12); content = await page.textContent('#result-units-0'); expect(content).toBe('kg^1*m^-3'); content = await page.textContent('#grid-cell-1-0-1'); expect(parseFloat(content)).toBeCloseTo(998.16537204293, precision); content = await page.textContent('#grid-cell-1-1-1'); expect(parseFloat(content)).toBeCloseTo(998.207150467928, precision); content = await page.textContent('#grid-cell-1-2-1'); expect(parseFloat(content)).toBeCloseTo(998.211792016402, precision); }); test('Test with function that has custom units function (max)', async () => { await page.setLatex(0, String.raw`Col3_{2,1}=`); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-1-0-0')).toBeFocused(); await page.keyboard.type('1'); await page.keyboard.press('Tab'); await page.keyboard.type('0'); await page.keyboard.press('Enter'); await page.keyboard.type('2'); await page.keyboard.press('Tab'); await page.keyboard.type('4000'); await page.locator('#parameter-units-1-0 >> math-field').type('[m]'); await page.locator('#parameter-units-1-1 >> math-field').type('[mm]'); await page.locator('#add-col-1').click(); await page.setLatex(1, String.raw`Col3=\mathrm{max}\left(Col1,Col2\right)=`, 2); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); content = await page.textContent('#grid-cell-1-0-2'); expect(parseFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#grid-cell-1-1-2'); expect(parseFloat(content)).toBeCloseTo(4, precision); }); test('Test with nested calculated columns', async () => { await page.setLatex(0, String.raw`Col4_{2,1}=`); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-1-0-0')).toBeFocused(); await page.keyboard.type('1'); await page.keyboard.press('Tab'); await page.keyboard.type('.002'); await page.keyboard.press('Enter'); await page.keyboard.type('4'); await page.keyboard.press('Tab'); await page.keyboard.type('.005'); await page.locator('#parameter-units-1-0 >> math-field').type('[m]'); await page.locator('#parameter-units-1-1 >> math-field').type('[km]'); await page.locator('#add-col-1').click(); await page.setLatex(1, String.raw`Col3=Col1+Col2`, 2); await page.locator('#add-col-1').click(); await page.setLatex(1, String.raw`Col4=Col3\cdot Col3`, 3); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(81, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^2'); content = await page.textContent('#grid-cell-1-0-3'); expect(parseFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#grid-cell-1-1-3'); expect(parseFloat(content)).toBeCloseTo(81, precision); // delete third column and check that results update to include variable name for missing Col3 await page.locator('#delete-col-1-2').click(); await page.setLatex(0, String.raw`Col4=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#parameter-name-1-2 >> text=Some results do not evaluate to a finite real value, which cannot be displayed in a data table')).toBeAttached(); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`Col3^{2}`); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test enter handling for first col output', async () => { await page.setLatex(0, String.raw`Col2=`); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-1-0-0')).toBeVisible(); await page.setLatex(1, String.raw`\mathrm{range}\left(1\right)=`, 0); await page.locator('#data-table-input-1-0-1').click(); await page.keyboard.type('11'); await page.keyboard.press('Enter'); await page.keyboard.type('22'); await page.keyboard.press('Enter'); await page.keyboard.type('0'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 11 \\ 22 \\ 0 \end{bmatrix}`); }); test('Test delete blank columns', async () => { await page.setLatex(0, String.raw`Col1=`); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-1-0-0')).toBeAttached(); await page.setLatex(1, String.raw`Col1=\mathrm{range}\left(10\right)`, 0); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \end{bmatrix}`); // shorten range to create blank rows await page.setLatex(1, String.raw`Col1=\mathrm{range}\left(5\right)`, 0); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#data-table-input-1-9-1')).toBeAttached(); await page.locator('#delete-blank-rows-1').click(); await expect(page.locator('#data-table-input-1-5-1')).toBeHidden(); content = await page.textContent('#grid-cell-1-0-0'); expect(parseFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#grid-cell-1-1-0'); expect(parseFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#grid-cell-1-2-0'); expect(parseFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#grid-cell-1-3-0'); expect(parseFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#grid-cell-1-4-0'); expect(parseFloat(content)).toBeCloseTo(5, precision); // make all cells blank and delete blank rows again // shorten range to create blank rows await page.setLatex(1, String.raw`Col1=`, 0); await expect(page.locator('div.data-field >> text=5')).toBeHidden(); await page.locator('#delete-blank-rows-1').click(); await expect(page.locator('#data-table-input-1-1-1')).toBeHidden(); await expect(page.locator('#data-table-input-1-0-1')).toBeAttached(); await expect(page.locator('#delete-blank-rows-1')).toBeHidden(); // make sure one dangling value prevents row deletion await page.locator('#add-row-1').click(); await page.locator('#add-row-1').click(); await page.locator('#add-row-1').click(); await page.locator('#add-row-1').click(); await page.locator('#data-table-input-1-3-1').type('12'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.locator('#delete-blank-rows-1').click(); await expect(page.locator('#data-table-input-1-1-4')).toBeHidden(); content = await page.textContent('#grid-cell-1-3-1'); expect(parseFloat(content)).toBeCloseTo(12, precision); }); test('Test greek character function name', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.locator('#add-data-table-cell').click(); await page.locator('#add-col-1').click(); await page.locator('#data-table-input-1-0-0').click(); await page.keyboard.type('0'); await page.keyboard.press('Tab'); await page.keyboard.type('0'); await page.keyboard.press('Tab'); await page.keyboard.type('10'); await page.keyboard.press('Enter'); await page.keyboard.type('2'); await page.keyboard.press('Tab'); await page.keyboard.type('4'); await page.keyboard.press('Tab'); await page.keyboard.type('6'); await page.keyboard.press('Enter'); await page.keyboard.type('4'); await page.keyboard.press('Tab'); await page.keyboard.type('16'); await page.keyboard.press('Tab'); await page.keyboard.type('-6'); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.locator('#interpolation-name-1-0 >> math-field').click({clickCount: 3}); await page.locator('#interpolation-name-1-0 >> math-field').type('alpha_1'); await page.locator('#cell-0 >> math-field.editable').type('alpha_1'); await page.locator('#cell-0 >> math-field.editable').press('ArrowRight'); await page.locator('#cell-0 >> math-field.editable').type('(1)='); await page.locator('#cell-0 >> math-field.editable').press('Enter'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); await page.locator('#cell-0 >> math-field.editable').type(' '); await page.locator('#cell-0 >> math-field.editable').press('Enter'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test interpolation and polyfit with numerical solve', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.setLatex(0, String.raw`t1=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`t2=`); await page.locator('#add-data-table-cell').click(); await page.locator('#add-col-2').click(); await page.locator('#parameter-units-2-0 >> math-field').type('[s]'); await page.locator('#parameter-units-2-1 >> math-field').type('[m]'); await page.locator('#parameter-units-2-2 >> math-field').type('[m]'); await page.locator('#data-table-input-2-0-0').click(); await page.keyboard.type('0'); await page.keyboard.press('Tab'); await page.keyboard.type('0'); await page.keyboard.press('Tab'); await page.keyboard.type('1'); await page.keyboard.press('Enter'); await page.keyboard.type('1'); await page.keyboard.press('Tab'); await page.keyboard.type('1'); await page.keyboard.press('Tab'); await page.keyboard.type('0'); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.getByRole('button', { name: 'Add Polyfit' }).click(); await page.getByRole('button', { name: 'Add Polyfit' }).click(); await page.locator('#output-radio-2-1-2').click(); await page.locator('#output-radio-2-3-2').click(); await page.locator('#add-system-cell').click(); await page.locator('#system-expression-3-0 math-field.editable').type('Interp1(t1)=Interp2(t1)'); await page.locator('#system-parameterlist-3 math-field.editable').type('t1~0.1[s]'); await page.locator('#add-system-cell').click(); await page.locator('#system-expression-4-0 math-field.editable').type('Interp1(t2)=Interp2(t2)'); await page.locator('#system-parameterlist-4 math-field.editable').type('t2~0.1[s]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0.5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('s'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(0.5, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('s'); }); test('Test factorial function in data table', async () => { await page.setLatex(0, String.raw`Col2=`); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-1-0-0')).toBeFocused(); await page.keyboard.type('1'); await page.keyboard.press('Enter'); await page.keyboard.type('2'); await page.keyboard.press('Enter'); await page.keyboard.type('3.00'); await page.setLatex(1, String.raw`Col2=Col1!=`, 1); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 6 \end{bmatrix}`); }); test('Test data table user function exponent bug', async () => { await page.setLatex(0, String.raw`y=2\left\lbrack m\right\rbrack^{\frac{x}{1\left\lbrack in\right\rbrack}}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`Col2=`); await page.locator('#add-data-table-cell').click(); await expect(page.locator('#data-table-input-2-0-0')).toBeFocused(); await page.keyboard.type('1'); await page.keyboard.press('Enter'); await page.keyboard.type('2'); await page.keyboard.press('Enter'); await page.keyboard.type('3'); await page.locator('#parameter-units-2-0 >> math-field').type('[in]'); await page.setLatex(2, String.raw`Col2=y\left(x=Col1\right)`, 1); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\begin{bmatrix} 2\left\lbrack m\right\rbrack \\ 4\left\lbrack m\right\rbrack \\ 8\left\lbrack m\right\rbrack \end{bmatrix}`); }); test('Test linear interpolation with plotting', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-data-table-cell').click(); await page.locator('#data-table-input-1-0-0').click(); await page.keyboard.type('10'); await page.keyboard.press('Tab'); await page.keyboard.type('1'); await page.keyboard.press('Enter'); await page.keyboard.type('20'); await page.keyboard.press('Tab'); await page.keyboard.type('2'); await page.keyboard.press('Enter'); await page.keyboard.type('30'); await page.keyboard.press('Tab'); await page.keyboard.type('3'); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.getByLabel('Copy function name to').click(); await page.locator('#cell-0 >> math-field.editable').type('(x,'); await page.locator('#cell-0 >> math-field.editable').press(modifierKey+'+v'); await page.locator('#cell-0 >> math-field.editable').type('(x)) for (10<=x<=30)='); await page.locator('#cell-0 >> math-field.editable').press('Enter'); await page.waitForSelector('div.status-footer', {state: 'detached'}); await expect(page.locator('g.trace.scatter')).toBeVisible(); }); test('Test bilinear interpolation', async () => { await page.setLatex(0, String.raw`\mathrm{Interp1}\left(0.5,1.5\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{Interp1}\left(2.25,0.75\right)=`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/multivariable_interpolation_no_units.xlsx'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.getByLabel('Inputs:').fill('2'); await page.getByLabel('Inputs:').press('Enter'); await expect(page.locator('text=2D grid data detected')).toBeVisible(); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(2.75, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); await page.locator('#input-radio-2-0-1-0').check(); await expect(page.locator('text=Attempt to extrapolate with the interpolation function')).toBeAttached(); await page.setLatex(0, String.raw`\mathrm{Interp1}\left(1.5,0.5\right)=`); await page.setLatex(1, String.raw`\mathrm{Interp1}\left(0.75,2.25\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(2.75, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); }); test('Test bilinear interpolation with units large scale output', async () => { await page.setLatex(0, String.raw`\mathrm{Interp1}\left(0.5\left\lbrack Pm\right\rbrack,1.5\left\lbrack fs\right\rbrack\right)=\left\lbrack EN\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{Interp1}\left(2.25\left\lbrack Pm\right\rbrack,0.75\left\lbrack fs\right\rbrack\right)=\left\lbrack EN\right\rbrack`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/multivariable_interpolation_units_large_scale.xlsx'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.getByLabel('Inputs:').fill('2'); await page.getByLabel('Inputs:').press('Enter'); await expect(page.locator('text=2D grid data detected')).toBeVisible(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=Dimension Error')).not.toBeVisible(); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('EN'); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(2.75, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('EN'); await page.setLatex(0, String.raw`\mathrm{Interp1}\left(0.5\left\lbrack Ps\right\rbrack,1.5\left\lbrack fs\right\rbrack\right)=\left\lbrack EN\right\rbrack`); await page.setLatex(1, String.raw`\mathrm{Interp1}\left(2.25\left\lbrack Pm\right\rbrack,0.75\left\lbrack fm\right\rbrack\right)=\left\lbrack EN\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error: Incorrect units for input number 1 of interpolation function Interp1')).toBeVisible(); await expect(page.locator('#cell-1 >> text=Dimension Error: Incorrect units for input number 2 of interpolation function Interp1')).toBeVisible(); }); test('Test bilinear interpolation with units small scale output', async () => { await page.setLatex(0, String.raw`\mathrm{Interp1}\left(0.5\left\lbrack Pm\right\rbrack,1.5\left\lbrack fs\right\rbrack\right)=\left\lbrack aN\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{Interp1}\left(2.25\left\lbrack Pm\right\rbrack,0.75\left\lbrack fs\right\rbrack\right)=\left\lbrack aN\right\rbrack`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/multivariable_interpolation_units_small_scale.xlsx'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.getByLabel('Inputs:').fill('2'); await page.getByLabel('Inputs:').press('Enter'); await expect(page.locator('text=2D grid data detected')).toBeVisible(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=Dimension Error')).not.toBeVisible(); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('aN'); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(2.75, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('aN'); }); test('Test grid data detection', async () => { await page.setLatex(0, String.raw`\mathrm{Interp1}\left(0.5,1.5\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{Interp1}\left(2.25,0.75\right)=`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/multivariable_interpolation_no_units.xlsx'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.getByLabel('Inputs:').fill('2'); await page.getByLabel('Inputs:').press('Enter'); await expect(page.locator('text=2D grid data detected')).toBeVisible(); // delete 2nd row await page.locator('#delete-row-2-1').click(); await expect(page.locator('text=2D grid data detected')).not.toBeVisible(); // add row back at the end (makes sure out of order is okay) await page.locator('#data-table-input-2-10-0').click(); await page.keyboard.press('Enter'); await page.keyboard.type('0.0'); await page.keyboard.press('Tab'); await page.keyboard.type('1.0'); await page.keyboard.press('Tab'); await page.keyboard.type('-2.0'); await expect(page.locator('text=2D grid data detected')).toBeVisible(); // add extra row with duplicate x,y await page.keyboard.press('Enter'); await page.keyboard.type('2'); await page.keyboard.press('Tab'); await page.keyboard.type('0'); await page.keyboard.press('Tab'); await page.keyboard.type('-3.0'); await expect(page.locator('text=2D grid data detected')).not.toBeVisible(); // delete extra row await page.locator('#delete-row-2-12').click(); await expect(page.locator('text=2D grid data detected')).toBeVisible(); // add extra unique x-value await page.locator('#data-table-input-2-1-0').fill('0.00001'); await expect(page.locator('text=2D grid data detected')).not.toBeVisible(); // restore original x-value await page.locator('#data-table-input-2-1-0').fill('0.00'); await expect(page.locator('text=2D grid data detected')).toBeVisible(); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(2.75, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); }); test('Test polyfit with 3 inputs and units', async () => { await page.setLatex(0, String.raw`\mathrm{Polyfit1}\left(.3\left\lbrack mm\right\rbrack,4\left\lbrack mm\right\rbrack,75\left\lbrack mm\right\rbrack\right)=\left\lbrack mm^3\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{Polyfit2}\left(.3\left\lbrack mm\right\rbrack,4\left\lbrack mm\right\rbrack,75\left\lbrack mm\right\rbrack\right)=\left\lbrack mm\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\mathrm{Polyfit3}\left(.3\left\lbrack mm\right\rbrack,4\left\lbrack mm\right\rbrack,75\left\lbrack mm\right\rbrack\right)=`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/bottle_data.csv'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.getByRole('button', { name: 'Add Polyfit' }).click(); await page.getByRole('button', { name: 'Add Polyfit' }).click(); await page.getByRole('button', { name: 'Add Polyfit' }).click(); await page.getByLabel('Inputs:').nth(0).fill('3'); await page.getByLabel('Inputs:').nth(0).press('Enter'); await page.getByLabel('Order:').nth(0).fill('2'); await page.getByLabel('Inputs:').nth(1).fill('3'); await page.getByLabel('Inputs:').nth(1).press('Enter'); await page.getByLabel('Order:').nth(1).fill('2'); await page.locator('#output-radio-3-1-4').click(); await page.getByLabel('Inputs:').nth(2).fill('3'); await page.getByLabel('Inputs:').nth(2).press('Enter'); await page.getByLabel('Order:').nth(2).fill('2'); await page.locator('#output-radio-3-2-5').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=Dimension Error')).not.toBeVisible(); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(609460.419, 4); content = await page.textContent('#result-units-0'); expect(content).toBe('mm^3'); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(2.863537011, 9); content = await page.textContent('#result-units-1'); expect(content).toBe('mm'); content = await page.textContent(`#result-value-2`); expect(parseLatexFloat(content)).toBeCloseTo(14.43641628/1000, 11); content = await page.textContent('#result-units-2'); expect(content).toBe('kg'); await page.setLatex(0, String.raw`\mathrm{Polyfit1}\left(.3\left\lbrack mm\right\rbrack,4,75\left\lbrack mm\right\rbrack\right)=\left\lbrack mm^3\right\rbrack`); await page.setLatex(1, String.raw`\mathrm{Polyfit2}\left(.3\left\lbrack mm\right\rbrack,4\left\lbrack mm\right\rbrack,75\left\lbrack mm\right\rbrack\right)=\left\lbrack s\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error: Incorrect units for input number 2 of interpolation function Polyfit1')).toBeVisible(); await expect(page.locator('#cell-1 >> text=Units Mismatch')).toBeVisible(); }); test('Test non-grid multivariable linear interpolation', async () => { await page.setLatex(0, String.raw`\mathrm{Interp1}\left(1.3,2.6\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{Interp1}\left(5.1,1.1\right)=`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/plane_interpolation_no_units.csv'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.getByLabel('Inputs:').fill('2'); await page.getByLabel('Inputs:').press('Enter'); await expect(page.locator('text=2D grid data detected')).not.toBeVisible(); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(8.765, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(8.34, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); await page.locator('#input-radio-2-0-1-0').check(); await page.waitForSelector('text=Updating...', {state: 'detached'}); // check extrapolation detection await expect(page.locator('text=Attempt to extrapolate with the interpolation function')).toBeVisible(); // delete extrapolated cell and recalculate remaining cell await page.locator('#delete-1').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(8.895, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test non-grid multivariable linear interpolation with units large scale', async () => { await page.setLatex(0, String.raw`\mathrm{Interp1}\left(1.3\left\lbrack Ym\right\rbrack,2.6\left\lbrack ys\right\rbrack\right)=\left\lbrack YN\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{Interp1}\left(5.1\left\lbrack Ym\right\rbrack,1.1\left\lbrack ys\right\rbrack\right)=\left\lbrack YN\right\rbrack`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/plane_interpolation_with_units_large_scale.csv'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.getByLabel('Inputs:').fill('2'); await page.getByLabel('Inputs:').press('Enter'); await expect(page.locator('text=2D grid data detected')).not.toBeVisible(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=Dimension Error')).not.toBeVisible(); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(8.765, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('YN'); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(8.34, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('YN'); // check unit checking await page.setLatex(1, String.raw`\mathrm{Interp1}\left(5.1\times10^{24},1.1\left\lbrack ys\right\rbrack\right)=\left\lbrack YN\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-1 >> text=Dimension Error: Incorrect units for input number 1 of interpolation function Interp1')).toBeVisible(); }); test('Test non-grid multivariable linear interpolation with units small scale', async () => { await page.setLatex(0, String.raw`\mathrm{Interp1}\left(1.3\left\lbrack Ym\right\rbrack,2.6\right)=\left\lbrack yN\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{Interp1}\left(5.1\left\lbrack Ym\right\rbrack,1.1\right)=\left\lbrack yN\right\rbrack`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/plane_interpolation_with_units_small_scale.csv'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await page.getByLabel('Inputs:').fill('2'); await page.getByLabel('Inputs:').press('Enter'); await expect(page.locator('text=2D grid data detected')).not.toBeVisible(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=Dimension Error')).not.toBeVisible(); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(8.765, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('yN'); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(8.34, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('yN'); }); test('Test auto sort for 1D linear interpolation', async () => { await page.setLatex(0, String.raw`Interp1\left(2.25\right)=`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/interpolation_autosort.csv'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await expect(page.locator('text=2D grid data detected')).not.toBeVisible(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=Dimension Error')).not.toBeVisible(); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(8.75, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test 1D linear interpolation error on repeated input', async () => { await page.setLatex(0, String.raw`Interp1\left(2.25\right)=`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/interpolation_repeated_input.csv'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.getByRole('button', { name: 'Add Interpolation' }).click(); await expect(page.locator('text=2D grid data detected')).not.toBeVisible(); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=1D linear interpolation cannot be performed with repeated input values')).toBeVisible(); // delete row with repeated value await page.locator('#delete-row-1-3').click(); await expect(page.locator('text=Dimension Error')).not.toBeVisible(); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(8.75, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test 2D polyfit symbolic expression with known function', async () => { await page.setLatex(0, String.raw`Polyfit1\left(X,Y\right)=`); await page.locator('#add-data-table-cell').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/spreadsheets/polyfit_symbolic.xlsx'); }); await page.getByRole('button', { name: 'Import Spreadsheet' }).click(); await page.waitForSelector('text=Importing spreadsheet from file', {state: 'detached'}); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.getByRole('button', { name: 'Add Polyfit' }).click(); await page.getByLabel('Inputs:').nth(0).fill('2'); await page.getByLabel('Inputs:').nth(0).press('Enter'); await page.getByLabel('Order:').nth(0).fill('2'); await page.getByLabel('Inputs:').nth(0).press('Enter'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`4.00000000000001 \cdot X^{2} + 6.0 \cdot X \cdot Y + 1.99999999999999 \cdot X + 5.00000000000001 \cdot Y^{2} + 2.99999999999999 \cdot Y + 1.0`); }); test('Test preserve output on conversion to input column', async () => { await page.setLatex(0, String.raw`Col1=`); await page.locator('#add-data-table-cell').click(); await page.locator('#parameter-name-1-0 >> math-field').click({clickCount: 3}); await page.locator('#parameter-name-1-0 >> math-field').type('Col1=range(3)'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \end{bmatrix}`); await page.locator('#parameter-name-1-0 >> math-field').click({clickCount: 3}); await page.locator('#parameter-name-1-0 >> math-field').type('Col1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \end{bmatrix}`); await page.locator('#data-table-input-1-2-0').click(); await page.keyboard.press('Enter'); await page.keyboard.type('4'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \\ 4 \end{bmatrix}`); }); test('Test lambdify error handling', async () => { await page.setLatex(0, String.raw`y=\sqrt{x}+\sqrt{a}`); await page.locator('#add-data-table-cell').click(); await page.locator('#parameter-name-1-0 >> math-field').click({clickCount: 3}); await page.locator('#parameter-name-1-0 >> math-field').type('Col1=range(3)'); await page.locator('#parameter-name-1-1 >> math-field').click({clickCount: 3}); await page.locator('#parameter-name-1-1 >> math-field').type('Col2=y(x=Col1)='); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`Col2=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#parameter-name-1-1 >> text=Some results do not evaluate to a finite real value, which cannot be displayed in a data table')).toBeAttached(); let content = await page.textContent(`#result-value-2`); expect(content).toBe(String.raw`\begin{bmatrix} \text{Data Table Calculation Error: Cannot convert expression to float} \end{bmatrix}`); }); test('Test sheet level number formatting', async () => { await page.setLatex(0, String.raw`Col1=`); await page.locator('#add-data-table-cell').click(); await page.locator('#parameter-name-1-0 >> math-field').click({clickCount: 3}); await page.locator('#parameter-name-1-0 >> math-field').type('Col1=1000*range(3)*pi[rad]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 3141.59265358979\left\lbrack rad\right\rbrack \\ 6283.18530717959\left\lbrack rad\right\rbrack \\ 9424.77796076938\left\lbrack rad\right\rbrack \end{bmatrix}`); content = await page.textContent("#grid-cell-1-2-0"); expect(content).toBe('9424.77796076938'); // change sheet level setting number settings and make sure data table rendering updates await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByLabel('Significant Figures').dblclick(); await page.getByLabel('Significant Figures').fill('4'); await page.getByLabel('Positive Exponent Threshold').dblclick(); await page.getByLabel('Positive Exponent Threshold').fill('3'); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('div.status-footer', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 3.142\times 10^{3}\left\lbrack rad\right\rbrack \\ 6.283\times 10^{3}\left\lbrack rad\right\rbrack \\ 9.425\times 10^{3}\left\lbrack rad\right\rbrack \end{bmatrix}`); content = await page.textContent("#grid-cell-1-2-0"); expect(content).toBe('9.425e+3'); // reset to default settings and make sure rendering updates as well await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('button', { name: 'Restore Defaults' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 3141.59265358979\left\lbrack rad\right\rbrack \\ 6283.18530717959\left\lbrack rad\right\rbrack \\ 9424.77796076938\left\lbrack rad\right\rbrack \end{bmatrix}`); content = await page.textContent("#grid-cell-1-2-0"); expect(content).toBe('9424.77796076938'); }); test('Test column level number formatting', async () => { await page.setLatex(0, String.raw`Col2=`); await page.locator('#add-data-table-cell').click(); await page.locator('#parameter-name-1-0 >> math-field').click({clickCount: 3}); await page.locator('#parameter-name-1-0 >> math-field').type('Col1=pi*range(3)'); await page.locator('#parameter-name-1-1 >> math-field').click({clickCount: 3}); await page.locator('#parameter-name-1-1 >> math-field').type('Col2=1e-3*pi*range(3)'); await page.waitForSelector('div.status-footer', {state: 'detached'}); await expect(page.locator('#parameter-units-1-1 >> div.dot')).not.toBeVisible(); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0.00314159265358979 \\ 0.00628318530717959 \\ 0.00942477796076938 \end{bmatrix}`); content = await page.textContent("#grid-cell-1-2-0"); expect(content).toBe('9.42477796076938'); content = await page.textContent("#grid-cell-1-2-1"); expect(content).toBe('0.00942477796076938'); // change column level level setting number settings and make sure data table rendering updates await page.getByRole('button', { name: 'Edit Column Number Format' }).nth(1).click(); await page.getByLabel('Significant Figures').dblclick(); await page.getByLabel('Significant Figures').fill('4'); await page.getByLabel('Negative Exponent Threshold').dblclick(); await page.getByLabel('Negative Exponent Threshold').fill('-2'); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('div.status-footer', {state: 'detached'}); await expect(page.locator('#parameter-units-1-1 >> div.dot')).toBeVisible(); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0.00314159265358979 \\ 0.00628318530717959 \\ 0.00942477796076938 \end{bmatrix}`); content = await page.textContent("#grid-cell-1-2-0"); expect(content).toBe('9.42477796076938'); content = await page.textContent("#grid-cell-1-2-1"); expect(content).toBe('9.425e-3'); // save and reload document to ensure settings persist await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); // clear contents by creating a new sheet await page.locator('#new-sheet').click(); // go back to page that was just saved await page.evaluate(() => window.history.back()); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#parameter-units-1-1 >> div.dot')).toBeVisible(); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0.00314159265358979 \\ 0.00628318530717959 \\ 0.00942477796076938 \end{bmatrix}`); content = await page.textContent("#grid-cell-1-2-0"); expect(content).toBe('9.42477796076938'); content = await page.textContent("#grid-cell-1-2-1"); expect(content).toBe('9.425e-3'); // reset to default column settings and make sure rendering updates as well await page.getByRole('button', { name: 'Edit Column Number Format' }).nth(1).click(); await page.getByRole('button', { name: 'Restore Defaults' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await expect(page.locator('#parameter-units-1-1 >> div.dot')).not.toBeVisible(); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0.00314159265358979 \\ 0.00628318530717959 \\ 0.00942477796076938 \end{bmatrix}`); content = await page.textContent("#grid-cell-1-2-0"); expect(content).toBe('9.42477796076938'); content = await page.textContent("#grid-cell-1-2-1"); expect(content).toBe('0.00942477796076938'); }); test('Test column level number formatting markdown export', async () => { await page.setLatex(0, String.raw`Col2=`); await page.locator('#add-data-table-cell').click(); await page.locator('#parameter-name-1-0 >> math-field').click({clickCount: 3}); await page.locator('#parameter-name-1-0 >> math-field').type('Col1=pi*range(3)'); await page.locator('#parameter-name-1-0 >> math-field').press('Enter'); await page.locator('#parameter-name-1-1 >> math-field').click({clickCount: 3}); await page.locator('#parameter-name-1-1 >> math-field').type('Col2=1e-3*pi*range(3)'); await page.locator('#parameter-name-1-1 >> math-field').press('Enter'); await page.waitForSelector('div.status-footer', {state: 'detached'}); await expect(page.locator('#parameter-units-1-1 >> div.dot')).not.toBeVisible(); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0.00314159265358979 \\ 0.00628318530717959 \\ 0.00942477796076938 \end{bmatrix}`); content = await page.textContent("#grid-cell-1-2-0"); expect(content).toBe('9.42477796076938'); content = await page.textContent("#grid-cell-1-2-1"); expect(content).toBe('0.00942477796076938'); // change column level level setting number settings and make sure data table rendering updates await page.getByRole('button', { name: 'Edit Column Number Format' }).nth(1).click(); await page.getByLabel('Significant Figures').dblclick(); await page.getByLabel('Significant Figures').fill('4'); await page.getByLabel('Negative Exponent Threshold').dblclick(); await page.getByLabel('Negative Exponent Threshold').fill('-2'); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('div.status-footer', {state: 'detached'}); await expect(page.locator('#parameter-units-1-1 >> div.dot')).toBeVisible(); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0.00314159265358979 \\ 0.00628318530717959 \\ 0.00942477796076938 \end{bmatrix}`); content = await page.textContent("#grid-cell-1-2-0"); expect(content).toBe('9.42477796076938'); content = await page.textContent("#grid-cell-1-2-1"); expect(content).toBe('9.425e-3'); // export the sheet as markdown, need to use download event to get the file path that the browser uses const downloadPromise = page.waitForEvent('download'); await page.getByRole('button', { name: 'Save Sheet to File in Various' }).click(); await page.locator('label').filter({ hasText: 'Markdown File' }).locator('span').first().click(); await page.locator('label').filter({ hasText: 'Center equations' }).click(); await page.getByRole('button', { name: 'Save', exact: true }).click(); const download = await downloadPromise; const mdPath = await download.path(); const reference_content = await fs.readFile('./tests/test_md_export_reference_data_table_format.md', 'utf8'); const exported_content = await fs.readFile(mdPath, 'utf8'); expect(exported_content).toBe(reference_content); }); test('Test column level number formatting csv export', async () => { await page.setLatex(0, String.raw`Col2=`); await page.locator('#add-data-table-cell').click(); await page.locator('#parameter-name-1-0 >> math-field').click({clickCount: 3}); await page.locator('#parameter-name-1-0 >> math-field').type('Col1=pi*range(3)'); await page.locator('#parameter-name-1-1 >> math-field').click({clickCount: 3}); await page.locator('#parameter-name-1-1 >> math-field').type('Col2=1e-3*pi*range(3)'); await page.waitForSelector('div.status-footer', {state: 'detached'}); await expect(page.locator('#parameter-units-1-1 >> div.dot')).not.toBeVisible(); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0.00314159265358979 \\ 0.00628318530717959 \\ 0.00942477796076938 \end{bmatrix}`); content = await page.textContent("#grid-cell-1-2-0"); expect(content).toBe('9.42477796076938'); content = await page.textContent("#grid-cell-1-2-1"); expect(content).toBe('0.00942477796076938'); // change column level level setting number settings and make sure data table rendering updates await page.getByRole('button', { name: 'Edit Column Number Format' }).nth(1).click(); await page.getByLabel('Significant Figures').dblclick(); await page.getByLabel('Significant Figures').fill('4'); await page.getByLabel('Negative Exponent Threshold').dblclick(); await page.getByLabel('Negative Exponent Threshold').fill('-2'); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('div.status-footer', {state: 'detached'}); await expect(page.locator('#parameter-units-1-1 >> div.dot')).toBeVisible(); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0.00314159265358979 \\ 0.00628318530717959 \\ 0.00942477796076938 \end{bmatrix}`); content = await page.textContent("#grid-cell-1-2-0"); expect(content).toBe('9.42477796076938'); content = await page.textContent("#grid-cell-1-2-1"); expect(content).toBe('9.425e-3'); // export as csv, number format shouldn't be applied to CSV export let [download] = await Promise.all([ page.waitForEvent('download'), page.getByRole('button', { name: 'Export CSV' }).click() ]); const csvPath = await download.path(); const reference_content = await fs.readFile('./tests/test_csv_export_reference_data_table_format.csv', 'utf8'); const exported_content = await fs.readFile(csvPath, 'utf8'); expect(exported_content).toBe(reference_content); }); ================================================ FILE: tests/test_database.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cos } from 'mathjs'; import { precision, pyodideLoadTimeout, screenshotDir, compareImages, parseLatexFloat } from './utility.mjs'; test('Test database', async ({ page, browserName }) => { page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/images/image_small.jpg'); }); page.setLatex = async function (cellIndex, latex) { await this.evaluate(([cellIndex, latex]) => window.setCellLatex(cellIndex, latex), [cellIndex, latex]); } await page.goto('/'); const width = 1300; const height = 3000; await page.setViewportSize({ width: width, height: height }); // Create a new document to test saving capability await page.locator("text=Accept").click(); // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.type(':nth-match(math-field.editable, 1)', 'x=3'); await page.click('#add-math-cell'); // add inline documentation to second math field await page.locator('math-field.editable').nth(1).click(); await page.locator('text=ABC').nth(0).click(); await page.locator('text=Comment').click(); // enter comment mode await page.locator('math-field.editable').nth(1).type('Inline Documentation'); await page.locator('text=Space').click(); await page.locator('math-field.editable').nth(1).type('Test:'); await page.locator('text=Comment').click(); // exit comment mode await page.locator('math-field.editable').nth(1).type(' cos(x)='); // make sure inline documentation appears correctly await page.locator('text=Inline Documentation Test:').waitFor({state: "attached", timeout: 500}); await page.click('#add-documentation-cell'); await page.type('div.editor div', `Sheet 1\nπ`); await page.press('div.editor div', 'Enter'); await page.click('.ql-image'); // filechooser callback will handle selecting the image // Insert blank math cell between first and second cell. // Ensures that blank cells don't affect sheet solve and that // they are saved an retrieved from the database corectly. await page.locator('#add-math-cell-1').click(); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); // check query result in cell 2 let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(cos(3), precision); await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl1 = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); await page.keyboard.press('Escape'); await page.waitForTimeout(400); // time it takes quill toolbar to disappear await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_screenshot1.png`, fullPage: true }); // Try to save page again, should return the same link as before await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl1Verify = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); expect(sheetUrl1.pathname).toBe(sheetUrl1Verify.pathname); // create and save a second document that has plots await page.click('#new-sheet'); await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); // test plot without units await page.click('#add-documentation-cell'); await page.type('div.editor div', 'Plot with 2 curves and no units'); await page.type(':nth-match(math-field.editable, 1)', 'y=x'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'sigma=-x'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', 'y(-1<=x<=1)='); await page.locator('#add-row-3').click(); await page.type(':nth-match(math-field.editable, 4)', 'sigma(-1 el.value)); await page.click('[aria-label="Close the modal"]'); await page.evaluate(() => window.scrollTo(0, 0)); await page.locator('h1 >> text=Title for testing purposes only').click(); // make sure mouse is not over plot otherwise toolbar appears await page.keyboard.press('Escape'); // unselect title await page.waitForTimeout(500); // keyboard takes .4 sec to disappear await page.screenshot({ path: `${screenshotDir}/${browserName}_screenshot2.png`, fullPage: true }); // reload the first document through a hash update await page.evaluate(hash => { window.history.pushState(null, "", hash); window.dispatchEvent(new PopStateEvent('popstate', null)); }, sheetUrl1.pathname); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForTimeout(500); // navigating is flaky for chromium and webkit await page.evaluate(() => window.history.back()); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForTimeout(500); // navigating is flaky for chromium and webkit // forward again to the first document await page.evaluate(() => window.history.forward()); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); await page.keyboard.press('Escape'); await page.evaluate(() => window.scrollTo(0, 0)); await page.waitForTimeout(500); // keyboard takes .4 sec to disappear await page.screenshot({ path: `${screenshotDir}/${browserName}_screenshot1_check.png`, fullPage: true }); expect(compareImages(`${browserName}_screenshot1.png`, `${browserName}_screenshot1_check.png`)).toEqual(0); // attempt to load a document that doesn't exist await page.goto('/CUsUSuwHkHzNyButyCHEnz'); await page.locator('text=Error retrieving sheet').waitFor({timeout: 5000}); // reload the second document through a page reload (use a hash this time to make sure that works as well for old links) await page.goto(`/#${sheetUrl2.pathname.slice(1)}`); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); await page.keyboard.press('Escape'); await page.waitForTimeout(500); // keyboard takes .4 sec to disappear await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_screenshot2_check.png`, fullPage: true }); if (browserName === "firefox") { // firefox has issues rendering latex for the legend labels expect(compareImages(`${browserName}_screenshot2.png`, `${browserName}_screenshot2_check.png`)).toBeLessThan(50); } else { expect(compareImages(`${browserName}_screenshot2.png`, `${browserName}_screenshot2_check.png`)).toEqual(0); } }); test('Test database consistency', async ({ page, browserName }) => { // retrieve a previously saved document from database and check screenshot await page.goto('/2kftdqNYyiaqAEyhXboNZF'); const width = 1300; const height = 6000; await page.setViewportSize({ width: width, height: height }); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 60000}); await page.locator('text=Accept').click(); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); await page.keyboard.press('Escape'); // unselect all cells await page.waitForTimeout(500); // keyboard takes .4 sec to disappear await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_screenshot_reference_check.png`, fullPage: true }); expect(compareImages(`${browserName}_reference.png`, `${browserName}_screenshot_reference_check.png`)).toEqual(0); }); test('Test presistance of equations and image resize in documentation fields', async ({ page, browserName }) => { page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles('./tests/images/image_smaller.jpg'); }); page.setLatex = async function (cellIndex, latex) { await this.evaluate(([cellIndex, latex]) => window.setCellLatex(cellIndex, latex), [cellIndex, latex]); } await page.goto('/'); // Create a new document to test saving capability await page.locator("text=Accept").click(); // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.setLatex(0, 'x=3') await page.click('#add-math-cell'); await page.setLatex(1, 'cos(x)=') await page.click('#add-documentation-cell'); await page.type('div.editor div', `Sheet 1\nπ`); await page.press('div.editor div', 'Enter'); // add formula await page.getByLabel('formula').click(); await page.getByPlaceholder('e=mc^').fill('\\sqrt{\\Omega}'); await page.getByPlaceholder('e=mc^').press('Enter'); await page.press('div.editor div', 'Enter'); // make sure formula appears in DOM await expect(page.locator("text=√").first()).toBeVisible(); await expect(page.locator("text=Ω").first()).toBeVisible(); // add image await page.getByLabel('image').click(); // resize image await page.locator('#cell-2 img').click(); await expect(page.locator("text=64 × 64")).toBeVisible(); const bounds = await page.locator("div.nwse-resize").nth(1).boundingBox(); const mouseX = bounds.x + bounds.width / 2; const mouseY = bounds.y + bounds.height / 2; await page.locator("div.nwse-resize").nth(1).hover(); await page.mouse.down(); await page.mouse.move(mouseX + 10, mouseY); await page.mouse.up(); await expect(page.locator("text=74 × 74")).toBeVisible(); // unselect image before screenshot await page.locator('text=π').first().click(); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); // check query result in the second cell let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(cos(3), precision); await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl1 = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); await page.keyboard.press('Escape'); await page.waitForTimeout(400); // time it takes quill toolbar to disappear await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_screenshot4.png`, fullPage: true }); // reload the document await page.goto(`/${sheetUrl1.pathname.slice(1)}`); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); await page.keyboard.press('Escape'); await page.evaluate(() => window.scrollTo(0, 0)); await page.waitForTimeout(500); // keyboard takes .4 sec to disappear await page.screenshot({ path: `${screenshotDir}/${browserName}_screenshot4_check.png`, fullPage: true }); expect(compareImages(`${browserName}_screenshot4.png`, `${browserName}_screenshot4_check.png`)).toEqual(0); }); ================================================ FILE: tests/test_ep_custom_units.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test water viscosity from temperature and pressure', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.setLatex(0, String.raw`1\left\lbrack centipoise\right\rbrack=\left\lbrack Pa\cdot s\right\rbrack `); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`1\left\lbrack P\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`1\left\lbrack reyn\right\rbrack=\left\lbrack\frac{lbf\cdot s}{in^2}\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`1\left\lbrack ureyn\right\rbrack=\left\lbrack\frac{lbf\cdot s}{in^2}\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`1\left\lbrack stokes\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`1\left\lbrack cSt\right\rbrack=\left\lbrack\frac{m^2}{s}\right\rbrack `); await page.locator('#add-math-cell').click(); await page.setLatex(6, String.raw`1\left\lbrack kpsi\right\rbrack=\left\lbrack\frac{lbf}{in^2}\right\rbrack `); await page.locator('#add-math-cell').click(); await page.setLatex(7, String.raw`1\left\lbrack Mpsi\right\rbrack=\left\lbrack\frac{lbf}{in^2}\right\rbrack `); await page.locator('#add-math-cell').click(); await page.setLatex(8, String.raw`1\left\lbrack inHg\right\rbrack= `); await page.locator('#add-math-cell').click(); await page.setLatex(9, String.raw`1\left\lbrack ftH2O\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(10, String.raw`1\left\lbrack inH2O\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(11, String.raw`1\left\lbrack Btu\right\rbrack=\left\lbrack BTU\right\rbrack `); await page.locator('#add-math-cell').click(); await page.setLatex(12, String.raw`1\left\lbrack TR\right\rbrack=\left\lbrack\frac{BTU}{hr}\right\rbrack `); await page.locator('#add-math-cell').click(); await page.setLatex(13, String.raw`1\left\lbrack BHP\right\rbrack=\left\lbrack\frac{BTU}{hr}\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(14, String.raw`1\left\lbrack MBH\right\rbrack=\left\lbrack\frac{BTU}{hr}\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(15, String.raw`1\left\lbrack MMBH\right\rbrack=\left\lbrack\frac{BTU}{hr}\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(16, String.raw`1\left\lbrack gf\right\rbrack=\left\lbrack kgf\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0.001, precision); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(0.1, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('kg^1*m^-1*s^-1'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(1e-6, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(1e-4, precision); content = await page.textContent('#result-units-4'); expect(content).toBe('m^2*s^-1'); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(1e-6, precision); content = await page.textContent('#result-value-6'); expect(parseLatexFloat(content)).toBeCloseTo(1000, precision); content = await page.textContent('#result-value-7'); expect(parseLatexFloat(content)).toBeCloseTo(1e6, precision); content = await page.textContent('#result-value-8'); expect(parseLatexFloat(content)).toBeCloseTo(3386.38, precision); content = await page.textContent('#result-units-8'); expect(content).toBe('Pa'); content = await page.textContent('#result-value-9'); expect(parseLatexFloat(content)).toBeCloseTo(2988.98, precision); content = await page.textContent('#result-units-9'); expect(content).toBe('Pa'); content = await page.textContent('#result-value-10'); expect(parseLatexFloat(content)).toBeCloseTo(249.082, precision); content = await page.textContent('#result-units-10'); expect(content).toBe('Pa'); content = await page.textContent('#result-value-11'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-value-12'); expect(parseLatexFloat(content)).toBeCloseTo(12000, precision); content = await page.textContent('#result-value-13'); expect(parseLatexFloat(content)).toBeCloseTo(33479, precision); content = await page.textContent('#result-value-14'); expect(parseLatexFloat(content)).toBeCloseTo(1000, precision); content = await page.textContent('#result-value-16'); expect(parseLatexFloat(content)).toBeCloseTo(1e-3, precision); }); ================================================ FILE: tests/test_file_save_open.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { promises as fs } from 'fs'; import { precision, pyodideLoadTimeout, screenshotDir, compareImages, parseLatexFloat } from './utility.mjs'; test('Test local file save and open', async ({ page, browserName }) => { test.skip(browserName === "chromium", "Playwright does not currently support the File System Access API"); page.forceDeleteCell = async function (index) { await this.evaluate((index) => window.forceDeleteCell(index), index); await this.waitForTimeout(200); } // retrieve a previously saved document from database and check screenshot await page.goto('/7e84f956bd114cceb8cd0e'); const width = 1200; const height = 2000; await page.setViewportSize({ width: width, height: height }); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.locator('text=Accept').click(); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); let content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(74, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('in'); // save await page.locator("h1 >> text=Test File Save").click(); await page.keyboard.press('Escape'); // unselect all cells await page.waitForTimeout(500); // keyboard takes .4 sec to disappear await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_screenshot_file_open_save.png`, fullPage: false }); // save the sheet, need to use download event to get the file path that the browser uses const downloadPromise = page.waitForEvent('download'); await page.locator('#save-sheet').click(); await page.getByRole('button', { name: 'Save', exact: true }).click(); const download = await downloadPromise; const path = await download.path(); // open blank sheet to clear contents await page.evaluate(() => window.forceNoUnsavedChange()); await page.locator('#new-sheet').click(); // open the sheet that was just saved page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(path); }); await page.locator('#open-sheet').click(); await page.locator('h3 >> text=Opening File').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached' }); // make sure equations still evaluate content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(74, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('in'); // Take second screenshot to make sure nothing changed // Click title to make sure mouse is not hovering over file open button await page.locator("h1 >> text=Test File Save").click(); await page.keyboard.press('Escape'); // unselect all cells await page.waitForTimeout(500); // keyboard takes .4 sec to disappear await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_screenshot_file_open_save_check.png`, fullPage: false }); expect(compareImages(`${browserName}_screenshot_file_open_save.png`, `${browserName}_screenshot_file_open_save_check.png`)).toEqual(0); // Attempt to open an image file to make sure there is not a crash and that there is an error message shown page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(`${screenshotDir}/${browserName}_screenshot_file_open_save_check.png`); }); await page.locator('#open-sheet').click(); await page.locator('text=Error parsing input file').waitFor({timeout: 5000}); await page.keyboard.press('Escape'); // test inserting sheet that was just saved into a blank sheet await page.evaluate(() => window.forceNoUnsavedChange()); await page.locator('#new-sheet').click(); await page.forceDeleteCell(0); await page.locator('#insert-sheet').click(); await page.locator('text=Select by File').click(); page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(path); }); await page.locator('text=click to select').click(); await page.locator('h3 >> text=Opening File').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(74, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('in'); }); test('Repeated open failure bug', async ({ page, browserName }) => { test.skip(browserName === "chromium", "Playwright does not currently support the File System Access API"); await page.goto('/'); await page.locator('text=Accept').click(); // open the sheet that causes the error const path = "tests/test_sheet.epxyz"; page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(path); }); await page.locator('#open-sheet').click(); await page.waitForTimeout(8000); await page.locator('h3 >> text=Opening File').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); let content = await page.locator('#result-value-17').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(5+1/3, precision); content = await page.locator('#result-units-17').textContent(); expect(content).toBe('MPa'); // reopen the sheet page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(path); }); await page.locator('#open-sheet').click(); await page.waitForTimeout(8000); await page.locator('h3 >> text=Opening File').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-17').textContent({timeout: 5000}); expect(parseLatexFloat(content)).toBeCloseTo(5+1/3, precision); content = await page.locator('#result-units-17').textContent(); expect(content).toBe('MPa'); }); test('Test opening file with results and syntax error', async ({ page, browserName }) => { test.skip(browserName === "chromium", "Playwright does not currently support the File System Access API"); await page.goto('/'); await page.locator('text=Accept').click(); // open the sheet that causes the error const path = "tests/test_sheet_parsing_error.epxyz"; page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(path); }); await page.locator('#open-sheet').click(); await page.waitForTimeout(8000); await page.locator('h3 >> text=Opening File').waitFor({state: 'detached', timeout: 5000}); await expect(page.locator("text=This field must contain an assignment")).toBeVisible(); // ensure that result is not displayed even though it is in file await page.locator('#result-value-1').waitFor({state: "detached", timeout: 1000}); }); test('Test opening file with incorrect results', async ({ page, browserName }) => { test.skip(browserName === "chromium", "Playwright does not currently support the File System Access API"); await page.goto('/'); await page.locator('text=Accept').click(); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); // open the sheet that causes the error const path = "tests/test_sheet_with_wrong_result.epxyz"; page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(path); }); await page.locator('#open-sheet').click(); await page.waitForTimeout(8000); await page.locator('h3 >> text=Opening File').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); let content = await page.locator('#result-value-3').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(32, precision); content = await page.locator('#result-units-3').textContent(); expect(content).toBe('in^4'); // open sheet a second time to trigger issue since result is cached page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(path); }); await page.locator('#open-sheet').click(); await page.waitForTimeout(8000); await page.locator('h3 >> text=Opening File').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); content = await page.locator('#result-value-3').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(32, precision); content = await page.locator('#result-units-3').textContent(); expect(content).toBe('in^4'); }); test('Test clearing results on valid input after page initial load form file', async ({ page, browserName }) => { test.skip(browserName === "chromium", "Playwright does not currently support the File System Access API"); page.setLatex = async function (cellIndex, latex) { await this.evaluate(([cellIndex, latex]) => window.setCellLatex(cellIndex, latex), [cellIndex, latex]); } await page.goto('/'); await page.locator('text=Accept').click(); // open the sheet that causes the error const path = "tests/test_sheet_with_results.epxyz"; page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(path); }); await page.locator('#open-sheet').click(); await page.locator('h3 >> text=Opening File').waitFor({state: 'detached'}); // wait for results from file to appear let content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); await page.waitForTimeout(500); // change value of initial cell to new valid content, results should be cleared await page.setLatex(0, '1='); // ensure that result is not displayed even though it is in file await page.locator('#cell-0 >> math-field:not(.editable)').waitFor({state: "hidden", timeout: 240000}); // make sure status footer is still visible to ensure results are hidden before calculation is finished await expect(page.locator('.status-footer')).toBeVisible(); // make sure results eventually appear await page.waitForSelector('.status-footer', { state: 'detached', timeout: 240000}); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); }); test('Test file results displayed during recalc but not if sheet edited', async ({ page, browserName }) => { test.skip(browserName === "chromium", "Playwright does not currently support the File System Access API"); page.setLatex = async function (cellIndex, latex) { await this.evaluate(([cellIndex, latex]) => window.setCellLatex(cellIndex, latex), [cellIndex, latex]); } await page.goto('/'); await page.locator('text=Accept').click(); // open the sheet that causes the error const path = "tests/test_sheet_long_calculation.epxyz"; page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(path); }); await page.locator('#open-sheet').click(); await page.waitForTimeout(1000); await page.locator('h3 >> text=Opening File').waitFor({state: 'detached', timeout: 5000}); await expect(page.locator('text=Updating...')).toBeVisible({timeout: pyodideLoadTimeout}); // check that file results are displayed during recalc let content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(0.44005058574493352, precision); // swap cells, make sure results are not displayed until recalc finishes await page.locator('#up-1').click(); await expect(page.locator('#result-value-0')).not.toBeVisible(); // wait for calculation to finish await page.waitForSelector('.status-footer', { state: 'detached', timeout: 240000 }); // make sure result is displayed after calculation content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(0.44005058574493352, precision); }); test('Test markdown export', async ({ page, browserName }) => { test.skip(browserName === "chromium", "Playwright does not currently support the File System Access API"); await page.goto('/'); await page.locator('text=Accept').click(); // open the sheet that causes the error const path = "tests/test_md_export.epxyz"; page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(path); }); await page.locator('#open-sheet').click(); await page.waitForTimeout(8000); await page.locator('h3 >> text=Opening File').waitFor({state: 'detached', timeout: 5000}); await page.locator('#cell-1 img').click(); await page.getByRole("textbox", { name: "Alt Text:" }).fill("image alt text test"); // export the sheet as markdown, need to use download event to get the file path that the browser uses const downloadPromise = page.waitForEvent('download'); await page.getByRole('button', { name: 'Save Sheet to File in Various' }).click(); await page.locator('label').filter({ hasText: 'Markdown File' }).locator('span').first().click(); await page.getByRole('button', { name: 'Save', exact: true }).click(); const download = await downloadPromise; const mdPath = await download.path(); const reference_content = await fs.readFile('./tests/test_md_export_reference.md', 'utf8'); const exported_content = await fs.readFile(mdPath, 'utf8'); expect(exported_content).toBe(reference_content); }); test('Test markdown export with centered equations', async ({ page, browserName }) => { test.skip(browserName === "chromium", "Playwright does not currently support the File System Access API"); await page.goto('/'); await page.locator('text=Accept').click(); // open the sheet that causes the error const path = "tests/test_md_export.epxyz"; page.once('filechooser', async (fileChooser) => { await fileChooser.setFiles(path); }); await page.locator('#open-sheet').click(); await page.waitForTimeout(8000); await page.locator('h3 >> text=Opening File').waitFor({state: 'detached', timeout: 5000}); // export the sheet as markdown, need to use download event to get the file path that the browser uses const downloadPromise = page.waitForEvent('download'); await page.getByRole('button', { name: 'Save Sheet to File in Various' }).click(); await page.locator('label').filter({ hasText: 'Markdown File' }).locator('span').first().click(); await page.locator('label').filter({ hasText: 'Center equations' }).click(); await page.getByRole('button', { name: 'Save', exact: true }).click(); const download = await downloadPromise; const mdPath = await download.path(); const reference_content = await fs.readFile('./tests/test_md_export_reference_centered.md', 'utf8'); const exported_content = await fs.readFile(mdPath, 'utf8'); expect(exported_content).toBe(reference_content); }); test('Test data table initial load detection bug', async ({ page, browserName }) => { await page.goto('/HkHWST4HeBHY8wGx4YMwXh'); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 240000}); await page.locator('text=Accept').click(); await page.waitForSelector('.status-footer', { state: 'detached', timeout: 240000 }); let content = await page.locator('#result-value-3').textContent(); expect(content).toBe(String.raw`\begin{bmatrix} 10\left\lbrack m\right\rbrack \\ 12\left\lbrack m\right\rbrack \\ 14\left\lbrack m\right\rbrack \end{bmatrix}`); await page.waitForTimeout(10500); expect(page.url()).not.toContain('temp-checkpoint'); }); ================================================ FILE: tests/test_fluid_properties.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test water viscosity from temperature and pressure', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-fluid-cell').click(); await page.getByLabel('Output:').selectOption({label: 'V - Viscosity - [Pa s]'}); await page.getByLabel('Copy Function Name to').click(); await page.locator('#cell-0 >> math-field.editable').press(modifierKey+"+v"); await page.locator('#cell-0 >> math-field.editable').type('(20[degC],1[atm])=[Pa*s]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0.00100159614312059, precision); // make sure incorrect input units are detected await page.setLatex(0, String.raw`\mathrm{WaterVGivenTP}\left(300\left\lbrack s\right\rbrack,1\left\lbrack atm\right\rbrack\right)=\left\lbrack mPa\cdot s\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeVisible(); // change to a different valid value and make sure results update await page.setLatex(0, String.raw`\mathrm{WaterVGivenTP}\left(10\left\lbrack degC\right\rbrack,1\left\lbrack atm\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0.00130589966035106, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('kg^1*m^-1*s^-1'); }); test('Test humid air properties 1', async () => { // Calculate values from Trane Psychrometric Chart Problem 1 const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // Wet bulb temp output await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').selectOption('HumidAir'); await page.getByLabel('Output:').selectOption({label: 'Twb - Wet-Bulb Temperature - [K]'}); await page.getByLabel('Input 2:').selectOption({label: 'Rh - Relative humidity in [0, 1]'}); await page.getByLabel('Copy Function Name to').click(); await page.locator('#cell-0 >> math-field.editable').press(modifierKey+"+v"); await page.locator('#cell-0 >> math-field.editable').type('(75[degF],0.5,1[atm])=[degF]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(62.5467059239422, precision); // Humidity ratio output await page.getByLabel('Output:').selectOption({label: 'W - Humidity Ratio (kg water/kg dry air)'}); await page.setLatex(0, String.raw`\mathrm{HumidAirWGivenTRhP}\left(75\left\lbrack degF\right\rbrack,0.5,1\left\lbrack atm\right\rbrack\right)=\left\lbrack\frac{grains}{lbm}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(64.9403915333383, precision); // enthalpy output await page.getByLabel('Output:').selectOption({label: 'H - Mixture enthalpy per mass dry air - [J/kg]'}); await page.setLatex(0, String.raw`\mathrm{HumidAirHGivenTRhP}\left(75\left\lbrack degF\right\rbrack,0.5,1\left\lbrack atm\right\rbrack\right)-\mathrm{HumidAirHGivenTRhP}\left(0\left\lbrack degF\right\rbrack,0,1\left\lbrack atm\right\rbrack\right)=\left\lbrack\frac{BTU}{lbm}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(28.1649758817679, precision); // dew point output await page.getByLabel('Output:').selectOption({label: 'Tdp - Dew-Point Temperature - [K]'}); await page.setLatex(0, String.raw`\mathrm{HumidAirTdpGivenTRhP}\left(75\left\lbrack degF\right\rbrack,0.5,1\left\lbrack atm\right\rbrack\right)=\left\lbrack degF\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(55.1247324833138, precision); // specific volume output await page.getByLabel('Output:').selectOption({label: 'Vda - Mixture volume per mass dry air - [m^3/kg]'}); await page.setLatex(0, String.raw`HumidAirVdaGivenTRhP\left(75\left\lbrack degF\right\rbrack,0.5,1\left\lbrack atm\right\rbrack\right)=\left\lbrack\frac{ft^3}{lbm}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(13.6750924385046, precision); // vapor pressure output await page.getByLabel('Output:').selectOption({label: 'Pw - Partial pressure of water vapor - [Pa]'}); await page.setLatex(0, String.raw`\mathrm{HumidAirPwGivenTRhP}\left(75\left\lbrack degF\right\rbrack,0.5,1\left\lbrack atm\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1489.19377240896, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('Pa'); // percentage humidity output (humidify ratio / humidity ratio at saturation) await page.getByLabel('Output:').selectOption({label: 'W - Humidity Ratio (kg water/kg dry air)'}); await page.setLatex(0, String.raw`\frac{\mathrm{HumidAirWGivenTRhP}\left(75\left\lbrack degF\right\rbrack,0.5,1\left\lbrack atm\right\rbrack\right)}{\mathrm{HumidAirWGivenTRhP}\left(75\left\lbrack degF\right\rbrack,1.0,1\left\lbrack atm\right\rbrack\right)}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0.492541785213707, precision); }); test('Test humid air properties 2', async () => { // Calculate values from Trane Psychrometric Chart Problem 2 const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // Enthalpy (need to get reference first) await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').selectOption('HumidAir'); await page.getByLabel('Input 2:').selectOption({label: 'W - Humidity Ratio (kg water/kg dry air)'}); await page.setLatex(0, String.raw`H_0=\mathrm{HumidAirHGivenTWP}\left(0\left\lbrack degF\right\rbrack,\:0.0,\:1\left\lbrack atm\right\rbrack\right)=\left\lbrack\frac{BTU}{lbm}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(-7.68565359375779, precision); // Now can calculate enthalpy that can compared to the Trane Psychrometric Chart await page.locator('#add-fluid-cell').click(); await page.locator('#fluid-selector-2').selectOption('HumidAir'); await page.locator('#input2-selector-2').selectOption({label: 'Twb - Wet-Bulb Temperature - [K]'}); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\mathrm{HumidAirHGivenTTwbP}\left(83\left\lbrack degF\right\rbrack,60\left\lbrack degF\right\rbrack,1\left\lbrack atm\right\rbrack\right)-H_0=\left\lbrack\frac{BTU}{lbm}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(26.3187274681289, precision); // Humidity ratio output await page.locator('#output-selector-2').selectOption({label: 'W - Humidity Ratio (kg water/kg dry air)'}); await page.setLatex(3, String.raw`\mathrm{HumidAirWGivenTTwbP}\left(83\left\lbrack degF\right\rbrack,60\left\lbrack degF\right\rbrack,1\left\lbrack atm\right\rbrack\right)=\left\lbrack\frac{grains}{lbm}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(40.6835574635305, precision); // Dew point output await page.locator('#output-selector-2').selectOption({label: 'Tdp - Dew-Point Temperature - [K]'}); await page.setLatex(3, String.raw`\mathrm{HumidAirTdpGivenTTwbP}\left(83\left\lbrack degF\right\rbrack,60\left\lbrack degF\right\rbrack,1\left\lbrack atm\right\rbrack\right)=\left\lbrack degF\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(42.7706038210882, precision); // Relative humidity await page.locator('#output-selector-2').selectOption({label: 'Rh - Relative humidity in [0, 1]'}); await page.setLatex(3, String.raw`\mathrm{HumidAirRhGivenTTwbP}\left(83\left\lbrack degF\right\rbrack,60\left\lbrack degF\right\rbrack,1\left\lbrack atm\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(0.242163313963061, precision); content = await page.textContent('#result-units-3'); expect(content).toBe(''); }); test('Test trivial constant', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-fluid-cell').click(); await page.getByLabel('Output:').selectOption({label: 'TCritical - Temperature at the critical point - [K]'}); await page.getByLabel('Copy Constant Name to').click(); await page.locator('#cell-0 >> math-field.editable').press(modifierKey+"+v"); await page.locator('#cell-0 >> math-field.editable').type('=[degC]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(373.945999999987, precision); }); test('Test incompressible fluid', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').selectOption({label: 'Ethanol, liquid phase at 10 bar'}); await page.getByLabel('Copy Function Name to').click(); await page.locator('#cell-0 >> math-field.editable').press(modifierKey+"+v"); await page.locator('#cell-0 >> math-field.editable').type('(20[degC],10[bar])='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(790.547119459927, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('kg^1*m^-3'); }); test('Test incompressible aqueous mass based mixture', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').selectOption({label: 'Ethylene Glycol - aq'}); await page.getByLabel('Output:').selectOption({label: 'C - Mass specific constant pressure specific heat - [J/kg/K]'}); await page.getByLabel('Concentration:').click({clickCount: 3}); await page.getByLabel('Concentration:').fill('0.3'); await page.setLatex(0, String.raw`\mathrm{MEGCGivenTP}\left(20\left\lbrack degC\right\rbrack,1\left\lbrack atm\right\rbrack\right)=\left\lbrack\frac{kJ}{kg\cdot K}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(3.71825101368959, precision); }); test('Test compressible predefined mixture', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').selectOption('R410A.mix'); await page.getByLabel('Output:').selectOption({label: 'T - Temperature - [K]'}); await page.getByLabel('Input 1:').selectOption({label: 'P - Pressure - [Pa]'}); await page.getByLabel('Input 2:').selectOption({label: 'Q - Molar vapor quality - [mol/mol]'}); await page.setLatex(0, String.raw`\mathrm{R410AMixtureTGivenPQ}\left(1\left\lbrack atm\right\rbrack,0\right)=\left\lbrack degC\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(-51.4429025032975, precision); }); test('Test compressible custom mixture', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').selectOption('CustomMixture'); await page.getByLabel('Output:').selectOption({label: 'MolarMass - Molar mass - [kg/mol]'}); await page.getByLabel('Mixture Component 1:').selectOption({label: 'Nitrogen'}); await page.getByLabel('Mole Fraction 1:').click({clickCount: 3}); await page.getByLabel('Mole Fraction 1:').fill('0.7812'); await page.getByLabel('Mixture Component 2:').selectOption({label: 'Argon'}); await page.getByLabel('Mole Fraction 2:').click({clickCount: 3}); await page.getByLabel('Mole Fraction 2:').fill('0.0092'); // should be an error at this point since molar fractions do not add up to 1 await expect(page.locator('text=All mole fractions must add up to 1')).toBeVisible(); await page.locator('#add-row-1').click(); await page.getByLabel('Mixture Component 3:').selectOption({label: 'Oxygen'}); await page.getByLabel('Mole Fraction 3:').click({clickCount: 3}); await page.setLatex(0, String.raw`MixtureMolarMass=\left\lbrack\frac{g}{mol}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(28.958600656, precision); // delete argon and re-add as last component await page.locator('#delete-row-1-1').click(); // should be an error at this point since molar fractions do not add up to 1 await expect(page.locator('text=All mole fractions must add up to 1')).toBeVisible(); // add argon back as last component await page.locator('#add-row-1').click(); await page.getByLabel('Mixture Component 3:').selectOption({label: 'Argon'}); await page.getByLabel('Mole Fraction 3:').click({clickCount: 3}); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(28.958600656, precision); }); test('Test phase output (numerical and text)', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').selectOption('Water'); await page.getByLabel('Output:').selectOption('PHASE'); await page.getByLabel('Input 2:').selectOption({label: 'Q - Molar vapor quality - [mol/mol]'}); await page.setLatex(0, String.raw`\mathrm{WaterPhaseGivenTQ}\left(200\left\lbrack degC\right\rbrack,0\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); await page.locator('#number-format-0').click(); await page.locator('label').filter({ hasText: 'Display Symbolic Results' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe('\\text{twophase}'); }); test('Test custom function name', async () => { await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').selectOption('Water'); await page.getByLabel('Output:').selectOption({label: 'P - Pressure - [Pa]'}); await page.getByLabel('Input 2:').selectOption({label: 'Q - Molar vapor quality - [mol/mol]'}); await page.locator('#cell-1 >> math-field.editable').click({clickCount: 3}); await page.locator('#cell-1 >> math-field.editable').type('PAtTQ'); await page.setLatex(0, String.raw`\mathrm{PAtTQ}\left(100\left\lbrack degC\right\rbrack,0\right)=\left\lbrack atm\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1.00091780567496, precision); // save sheet to database await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); // clear contents by creating a new sheet await page.locator('#new-sheet').click(); // go back to page that was just saved await page.evaluate(() => window.history.back()); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('text=Updating...', {state: 'detached'}); // make sure result has not changed content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1.00091780567496, precision); // make sure function name cannot be reassigned (should generate error) await page.locator('#add-math-cell').click(); await page.locator('#cell-2 >> math-field.editable').type('PAtTQ=10'); await expect(page.locator('text=Duplicate assignment of variable')).toBeVisible(); }); test('Test plot with repeated fluid function call', async () => { await page.locator('#add-fluid-cell').click(); await page.setLatex(0, String.raw`sum\:=\:\mathrm{WaterDGivenTP}\left(T,1\left\lbrack atm\right\rbrack\right)+\mathrm{WaterDGivenTP}\left(T,2\left\lbrack atm\right\rbrack\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`sum\left(300\left\lbrack K\right\rbrack\le T\le330\left\lbrack K\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); // make sure symbolic version of fluid function renders properly let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\operatorname{WaterDGivenTP}{\left(T,101325 \right)} + \operatorname{WaterDGivenTP}{\left(T,202650 \right)}`); // plot should not have an error await page.locator('svg.error').waitFor({state: "detached", timeout: 1000}); }); test('Test sheet level fluid selection', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-fluid-cell').click(); await expect(page.getByLabel('Use sheet fluid')).toHaveCount(1); await page.getByLabel('Use sheet fluid').check(); await page.getByLabel('Fluid:').selectOption({label: 'Ethylene Glycol - aq'}); await page.getByLabel('Output:').selectOption({label: 'C - Mass specific constant pressure specific heat - [J/kg/K]'}); await page.getByLabel('Concentration:').click({clickCount: 3}); await page.getByLabel('Concentration:').fill('0.3'); await page.locator('#add-fluid-cell').click(); await page.locator('#use-sheet-fluid-2').click(); await page.locator('#add-fluid-cell').click(); await page.locator('#add-math-cell').click(); await page.locator('#add-math-cell').click(); await page.setLatex(0, String.raw`\mathrm{CGivenTP}\left(20\left\lbrack degC\right\rbrack,1\left\lbrack atm\right\rbrack\right)=\left\lbrack\frac{kJ}{kg\cdot K}\right\rbrack`); await page.setLatex(4, String.raw`\mathrm{DGivenTP}\left(20\left\lbrack degC\right\rbrack,\:1\left\lbrack atm\right\rbrack\right)=`); await page.setLatex(5, String.raw`\mathrm{WaterDGivenTP}\left(20\left\lbrack degC\right\rbrack,\:1\left\lbrack atm\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(3.71825101368959, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(1038.04550699919, precision); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(998.207150467928, precision); // unlink second fluid cell to sheet (should revert back to water) await page.locator('#use-sheet-fluid-2').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(3.71825101368959, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(998.207150467928, precision); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(998.207150467928, precision); // save sheet to database await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); // clear contents by creating a new sheet await page.locator('#new-sheet').click(); // go back to page that was just saved await page.evaluate(() => window.history.back()); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('text=Updating...', {state: 'detached'}); // make sure results haven't changed content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(3.71825101368959, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(998.207150467928, precision); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(998.207150467928, precision); // change second fluid cell back to using sheet fluid await page.locator('#use-sheet-fluid-2').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(3.71825101368959, precision); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(1038.04550699919, precision); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(998.207150467928, precision); }); test('Test CoolProp exception handling', async () => { await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').selectOption('Water'); await page.getByLabel('Output:').selectOption({label: 'H - Mass specific enthalpy - [J/kg]'}); await page.getByLabel('Input 1:').selectOption({label: 'Q - Molar vapor quality - [mol/mol]'}); await page.locator('#cell-1 >> math-field.editable').click({clickCount: 3}); await page.locator('#cell-1 >> math-field.editable').type('H'); await page.locator('#cell-0 >> math-field.editable').type('H(1.1,1[atm])-H(0,1[atm])=[J/kg'); await expect(page.locator('text=Input vapor quality [Q] must be between 0 and 1')).toBeVisible(); // fix error await page.locator('#cell-0 >> math-field.editable').click({clickCount: 3}); await page.locator('#cell-0 >> math-field.editable').type('H(1,1[atm])-H(0,1[atm])=[J/kg'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2256471.59240673, precision); // regenerate error make sure error message is still there (change input so that result is not cached) await page.locator('#cell-0 >> math-field.editable').click({clickCount: 3}); await page.locator('#cell-0 >> math-field.editable').type('H(1.2,1[atm])-H(0,1[atm])=[J/kg'); await expect(page.locator('text=Input vapor quality [Q] must be between 0 and 1')).toBeVisible(); }); test('Test PropsSI fluid function in numerical solve', async () => { await page.locator('#add-system-cell').click(); await page.locator('#system-expression-1-0 math-field.editable').type('AirSGivenTP(25[degC],1[atm])=AirSGivenHP(h,1[atm])'); await page.locator('#system-parameterlist-1 math-field.editable').type('h~4.2e5[J/kg'); await page.locator('#system-parameterlist-1 math-field.editable').press('ArrowRight'); await page.locator('#system-parameterlist-1 math-field.editable').type(']'); await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').selectOption('Dry Air'); await page.getByLabel('Output:').selectOption({label: 'S - Mass specific entropy - [J/kg/K]'}); await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').nth(1).selectOption('Dry Air'); await page.getByLabel('Output:').nth(1).selectOption({label: 'S - Mass specific entropy - [J/kg/K]'}); await page.getByLabel('Input 1:').nth(1).selectOption({label: 'H - Mass specific enthalpy - [J/kg]'}); await page.setLatex(0, String.raw`h=\left\lbrack\frac{J}{kg}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(4.24436043916502e5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('(J)/(kg)') }); test('Test HAPropsSI fluid function in numerical solve', async () => { await page.locator('#add-system-cell').click(); await page.locator('#system-expression-1-0 math-field.editable').type('HumidAirSGivenTWP(25[degC],0.5,1[atm])=HumidAirSGivenHWP(h,0.5,1[atm])'); await page.locator('#system-parameterlist-1 math-field.editable').type('h~1.2e6[J/kg'); await page.locator('#system-parameterlist-1 math-field.editable').press('ArrowRight'); await page.locator('#system-parameterlist-1 math-field.editable').type(']'); await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').selectOption('Humid Air (Psychrometrics)'); await page.getByLabel('Output:').selectOption({label: 'S - Mixture entropy per mass dry air - [J/kg/K]'}); await page.locator('#add-fluid-cell').click(); await page.getByLabel('Fluid:').nth(1).selectOption('Humid Air (Psychrometrics)'); await page.getByLabel('Output:').nth(1).selectOption({label: 'S - Mixture entropy per mass dry air - [J/kg/K]'}); await page.getByLabel('Input 1:').nth(1).selectOption({label: 'H - Mixture enthalpy per mass dry air - [J/kg]'}); await page.setLatex(0, String.raw`h=\left\lbrack\frac{J}{kg}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1.28835304066939e6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('(J)/(kg)') }); test('Test sheet level compressible custom mixture', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#add-fluid-cell').click(); await page.getByLabel('Use sheet fluid').check(); await page.locator('#add-fluid-cell').click(); await page.getByLabel('Use sheet fluid').nth(1).check(); await page.getByLabel('Fluid:').nth(0).selectOption('CustomMixture'); await page.getByLabel('Output:').nth(0).selectOption({label: 'MolarMass - Molar mass - [kg/mol]'}); await page.getByLabel('Mixture Component 1:').nth(0).selectOption({label: 'Nitrogen'}); await page.getByLabel('Mole Fraction 1:').nth(0).click({clickCount: 3}); await page.getByLabel('Mole Fraction 1:').nth(0).fill('0.7812'); await page.getByLabel('Mixture Component 2:').nth(0).selectOption({label: 'Argon'}); await page.getByLabel('Mole Fraction 2:').nth(0).click({clickCount: 3}); await page.getByLabel('Mole Fraction 2:').nth(0).fill('0.0092'); await expect(page.locator('#cell-2 >> input[type="number"]').nth(0)).toHaveValue('0.7812'); await page.locator('#add-row-1').nth(0).click(); await page.getByLabel('Mixture Component 3:').nth(0).selectOption({label: 'Oxygen'}); await page.getByLabel('Mole Fraction 3:').nth(0).click({clickCount: 3}); await page.getByLabel('Output:').nth(1).selectOption({label: 'TTriplePoint - Temperature at the triple point - [K]'}); await expect(page.getByLabel('Mixture Component 3:').nth(1)).toHaveValue('Oxygen'); await page.setLatex(0, String.raw`MolarMass=\left\lbrack\frac{g}{mol}\right\rbrack`); await page.locator("#add-math-cell").click(); await page.setLatex(3, String.raw`TTriplePoint=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(28.958600656, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(61.498642, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('K'); }); ================================================ FILE: tests/test_functions.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { complex, cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test trigonometric functions', async () => { // test trigonometric functions await page.type(':nth-match(math-field.editable, 1)', 'cos(1)='); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(0.540302305868139717400, precision); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'sin(30[degrees])='); await page.waitForSelector('.status-footer', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(0.5, precision); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', 'sin(1[radians])='); await page.waitForSelector('.status-footer', {state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(0.84147098480789650665, precision); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 4)', 'tan(45[degrees])='); await page.waitForSelector('.status-footer', {state: 'detached'}); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 5)', 'csc(1[sec])='); await page.waitForSelector('.status-footer', {state: 'detached'}); await expect(page.locator('#cell-4 >> text=Dimension Error')).toBeVisible(); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 6)', 'sin(1)='); await page.waitForSelector('.status-footer', {state: 'detached'}); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(0.841470984807896506652502321630, precision); }); test('Test cot, deg conversion with trig functions, and precidence with parens', async () => { await page.setLatex(0, String.raw`N=34`); await page.click('#add-math-cell'); await page.setLatex(1, String.raw`P=12.7\left[mm\right]`); await page.click('#add-math-cell'); await page.setLatex(2, String.raw`P\cdot \left(\cot \left(\frac{180\left[deg\right]}{N}\right)-1\right)-.762\left[mm\right]=\left[mm\right]`); await page.click('#add-math-cell'); await page.setLatex(3, String.raw`P\cdot \left(0.6+\cot \left(\frac{180\left[deg\right]}{N}\right)\right)=\left[mm\right]`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(12.7*(cot(pi/34)-1)-.762, precision-2); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(12.7*(0.6 + cot(pi/34)), precision-2); }); test('Test inverse trig functions', async () => { // check that inverse trig functions only accept unitless input await page.setLatex(0, String.raw`arcsin\left(5\left[meters\right]\right)=`); // make sure units errors are caught await page.click('#add-math-cell'); await page.setLatex(1, String.raw`arccos\left(.1+.2\left[m\right]\right)=`); await page.click('#add-math-cell'); await page.setLatex(2, String.raw`arctan\left(1\right)=\left[deg\right]`); await page.click('#add-math-cell'); await page.setLatex(3, String.raw`\arcsin\left(-\frac{\sqrt{3}\cdot 1\left[m\right]}{2000\left[mm\right]}\right)=`); await page.click('#add-math-cell'); await page.setLatex(4, String.raw`\arccos\left(\frac{1\left[mile\right]}{2\left[mile\right]}+0\right)=\left[deg\right]`); await page.waitForSelector('.status-footer', {state: 'detached'}); // make sure dimension errors are indicated await page.locator('#cell-0 >> text=Dimension Error').waitFor({state: 'attached', timeout: 1000}); await page.locator('#cell-1 >> text=Dimension Error').waitFor({state: 'attached', timeout: 1000}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(45, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('deg'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(-pi/3, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('rad'); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(60, precision-1); content = await page.textContent('#result-units-4'); expect(content).toBe('deg'); }); test('Test min/max functions', async ({ browserName }) => { // Change title await page.locator('math-field.editable').nth(0).type('x='); await page.locator('text=f(x)').click(); await page.locator('text=minmin').click(); await page.locator('math-field.editable').nth(0).type('s,t,-1[mm/s'); await page.locator('math-field.editable').nth(0).press('ArrowRight'); await page.locator('math-field.editable').nth(0).type(']'); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(1).type('2*'); await page.locator('text=maxmax').click(); await page.locator('math-field.editable').nth(1).type('-y/z'); await page.locator('math-field.editable').nth(1).press('ArrowRight'); await page.locator('math-field.editable').nth(1).type(',x'); await page.locator('math-field.editable').nth(1).press('ArrowRight'); await page.locator('math-field.editable').nth(1).type('='); await page.locator('#add-math-cell').click(); await page.setLatex(2, 'y=10\\left[mm\\right]'); await page.locator('#add-math-cell').click(); await page.setLatex(3, 'z=5\\left[sec\\right]'); await page.locator('#add-math-cell').click(); await page.setLatex(4, 's=2\\left[\\frac{m}{sec}\\right]'); await page.locator('#add-math-cell').click(); await page.setLatex(5, 't=2\\left[\\frac{miles}{hour}\\right]'); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(-.002, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m^1*s^-1'); await page.setLatex(2, 'y=-10\\left[mm\\right]'); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(.004, precision); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(6).type('max(-20,-10,-100)='); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(7).type('min(-1)='); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(8).type('min(-1, 10[inches])='); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(9).type('max(-1[feet], 10[inches])=[sec]'); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-6').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(-10, precision); content = await page.locator('#result-value-7').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(-1, precision); await expect(page.locator('#cell-8 >> text=Dimension Error')).toBeVisible(); await expect(page.locator('#cell-9 >> text=Units Mismatch')).toBeVisible(); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(10).type('1[Pa]*min(0,x2)+1[N]='); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(11).type('1[N]*min(0,x2)+1[N]='); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(12).type('1[Pa]*min(0,0)+1[N]='); await page.locator('#add-math-cell').click(); await page.setLatex(13, 'x2=-1\\left[\\frac{m}{m}\\right]') await page.waitForSelector('.status-footer', { state: 'detached' }); await expect(page.locator('#cell-10 >> text=Dimension Error')).toBeVisible(); content = await page.locator('#result-units-11').textContent(); expect(content).toBe('N'); await expect(page.locator('#cell-12 >> text=Dimension Error: Only equivalent dimensions')).toBeVisible(); }); test('Test ceil func', async ({ browserName }) => { await page.locator('#cell-0 >> math-field.editable').type('ceil(1.1)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').type('ceil(1.6)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-2 >> math-field.editable').type('ceil(2.00000)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-3 >> math-field.editable').type('ceil(-2.6)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-4 >> math-field.editable').type('ceil(1[m])='); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('2'); content = await page.textContent('#result-value-1'); expect(content).toBe('2'); content = await page.textContent('#result-value-2'); expect(content).toBe('2'); content = await page.textContent('#result-value-3'); expect(content).toBe('-2'); await expect(page.locator('#cell-4 >> text=Dimension Error')).toBeAttached(); }); test('Test floor func', async ({ browserName }) => { await page.locator('#cell-0 >> math-field.editable').type('floor(1.1)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').type('floor(1.6)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-2 >> math-field.editable').type('floor(1.00000)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-3 >> math-field.editable').type('floor(-0.9)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-4 >> math-field.editable').type('floor(1[m])='); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('1'); content = await page.textContent('#result-value-1'); expect(content).toBe('1'); content = await page.textContent('#result-value-2'); expect(content).toBe('1'); content = await page.textContent('#result-value-3'); expect(content).toBe('-1'); await expect(page.locator('#cell-4 >> text=Dimension Error')).toBeAttached(); }); test('Test round func', async ({ browserName }) => { await page.locator('#cell-0 >> math-field.editable').type('round(1.1)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').type('round(1.6)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-2 >> math-field.editable').type('round(1.00000)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-3 >> math-field.editable').type('round(-0.9)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-4 >> math-field.editable').type('round(-1.1)='); await page.locator('#add-math-cell').click(); await page.locator('#cell-5 >> math-field.editable').type('round(1[m])='); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('1'); content = await page.textContent('#result-value-1'); expect(content).toBe('2'); content = await page.textContent('#result-value-2'); expect(content).toBe('1'); content = await page.textContent('#result-value-3'); expect(content).toBe('-1'); content = await page.textContent('#result-value-4'); expect(content).toBe('-1'); await expect(page.locator('#cell-5 >> text=Dimension Error')).toBeAttached(); }); ================================================ FILE: tests/test_generated_code.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Unitless function', async () => { await page.setLatex(0, String.raw`y=x`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`y\left(x=10\right)=`); await page.locator('#code-gen-1').click(); let content = await page.locator('code').textContent(); expect(content).toBe(`def y(x): """ Function 'y' automatically generated by EngineeringPaper.xyz Parameters ---------- x : float 'x' is unitless. Returns ------- float Return value is unitless. """ result = x return result `); await page.keyboard.press('Escape'); }); test('Function with input and output units', async () => { await page.setLatex(0, String.raw`y=x`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`y\left(x=10\left\lbrack mm\right\rbrack\right)=\left\lbrack mm\right\rbrack`); await page.locator('#code-gen-1').click(); let content = await page.locator('code').textContent(); expect(content).toBe(`def y(x): """ Function 'y' automatically generated by EngineeringPaper.xyz Parameters ---------- x : float 'x' has units of [mm]. Returns ------- float Return value has units of [mm]. """ x = x * 0.001 result = x return result / 0.001 `); await page.keyboard.press('Escape'); }); test('Function with temperature input and output', async () => { await page.setLatex(0, String.raw`y=x`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`y\left(x=-40\left\lbrack degF\right\rbrack\right)=\left\lbrack degF\right\rbrack`); await page.locator('#code-gen-1').click(); let content = await page.locator('code').textContent(); expect(content).toBe(`def y(x): """ Function 'y' automatically generated by EngineeringPaper.xyz Parameters ---------- x : float 'x' has units of [degF]. Returns ------- float Return value has units of [degF]. """ x = (x + 459.67) * 0.5555555555555556 result = x return (result / 0.5555555555555556) - 459.67 `); await page.keyboard.press('Escape'); }); test('Function with temperature input and output, offset only', async () => { await page.setLatex(0, String.raw`y=x`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`y\left(x=-40\left\lbrack degC\right\rbrack\right)=\left\lbrack degC\right\rbrack`); await page.locator('#code-gen-1').click(); let content = await page.locator('code').textContent(); expect(content).toBe(`def y(x): """ Function 'y' automatically generated by EngineeringPaper.xyz Parameters ---------- x : float 'x' has units of [degC]. Returns ------- float Return value has units of [degC]. """ x = x + 273.15 result = x return result - 273.15 `); await page.keyboard.press('Escape'); }); test('Funciton with two inputs', async () => { await page.setLatex(0, String.raw`y=x\cdot z`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`y\left(x=10\left\lbrack m\right\rbrack,\:z=1\left\lbrack sec\right\rbrack\right)=`); await page.locator('#code-gen-1').click(); let content = await page.locator('code').textContent(); expect(content).toBe(`def y(x, z): """ Function 'y' automatically generated by EngineeringPaper.xyz Parameters ---------- x : float 'x' has units of [m]. z : float 'z' has units of [sec]. Returns ------- float Return value has units of [m s]. """ result = x*z return result `); await page.keyboard.press('Escape'); }); test('Function with unitless matrix output', async () => { await page.setLatex(0, String.raw`y=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`y\left(a=1,\:b=2,\:c=3,\:d=4\right)=`); await page.locator('#code-gen-1').click(); let content = await page.locator('code').textContent(); expect(content).toBe(`import numpy def y(a, b, c, d): """ Function 'y' automatically generated by EngineeringPaper.xyz Parameters ---------- a : float 'a' is unitless. b : float 'b' is unitless. c : float 'c' is unitless. d : float 'd' is unitless. Returns ------- numpy.array Return value is a matrix with units [[unitless, unitless], [unitless, unitless]] """ result = numpy.array([[a, b], [c, d]]) return result `); await page.keyboard.press('Escape'); }); test('Function with matrix output with units', async () => { await page.setLatex(0, String.raw`y=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`y\left(a=1\left\lbrack mm\right\rbrack,\:b=1\left\lbrack mm^2\right\rbrack,\:c=1\left\lbrack mm^3\right\rbrack,\:d=1\left\lbrack mm^3\right\rbrack\right)=`); await page.locator('#code-gen-1').click(); let content = await page.locator('code').textContent(); expect(content).toBe(`import numpy def y(a, b, c, d): """ Function 'y' automatically generated by EngineeringPaper.xyz Parameters ---------- a : float 'a' has units of [mm]. b : float 'b' has units of [mm^2]. c : float 'c' has units of [mm^3]. d : float 'd' has units of [mm^3]. Returns ------- numpy.array Return value is a matrix with units [[m, m^2], [m^3, m^3]] """ a = a * 0.001 b = b * 0.000001 c = c * 1e-9 d = d * 1e-9 result = numpy.array([[a, b], [c, d]]) return result `); await page.keyboard.press('Escape'); }); test('Function with matrix output with units and user units', async () => { await page.setLatex(0, String.raw`y=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`y\left(a=1\left\lbrack in\right\rbrack,\:b=2\left\lbrack in\right\rbrack,\:c=3\left\lbrack in\right\rbrack,\:d=4\left\lbrack in\right\rbrack\right)=\left\lbrack in\right\rbrack`); await page.locator('#code-gen-1').click(); let content = await page.locator('code').textContent(); expect(content).toBe(`import numpy def y(a, b, c, d): """ Function 'y' automatically generated by EngineeringPaper.xyz Parameters ---------- a : float 'a' has units of [in]. b : float 'b' has units of [in]. c : float 'c' has units of [in]. d : float 'd' has units of [in]. Returns ------- numpy.array Return value is a matrix with units [[in, in], [in, in]] """ a = a * 0.0254 b = b * 0.0254 c = c * 0.0254 d = d * 0.0254 result = numpy.array([[a, b], [c, d]]) return result / 0.0254 `); await page.keyboard.press('Escape'); }); test('Codegen button appears only when appropriate', async () => { await page.setLatex(0, String.raw`y=x`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`y=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#code-gen-1')).toBeHidden(); await page.setLatex(1, String.raw`y\left(x=z\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#code-gen-1')).toBeHidden(); await page.setLatex(1, String.raw`y\left(x=1,s=t\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#code-gen-1')).toBeHidden(); await page.setLatex(1, String.raw`y\left(x=1\left\lbrack m\right\rbrack\right)=\left\lbrack sec\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#code-gen-1')).toBeHidden(); await page.setLatex(1, String.raw`2\cdot y\left(x=1\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#code-gen-1')).toBeHidden(); await page.setLatex(1, String.raw`y\left(x=1\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#code-gen-1')).toBeVisible(); }); test('Numpy function rewrite fix, sympy #25514', async () => { await page.setLatex(0, String.raw`y=\sec\left(x\right)^2`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`y\left(x=1\right)=`); await page.locator('#code-gen-1').click(); let content = await page.locator('code').textContent(); expect(content).toBe(`import numpy def y(x): """ Function 'y' automatically generated by EngineeringPaper.xyz Parameters ---------- x : float 'x' is unitless. Returns ------- float Return value is unitless. """ result = (numpy.cos(x)**(-1.0))**2 return result `); await page.keyboard.press('Escape'); }); test('Variable name rewriting', async () => { await page.setLatex(0, String.raw`I=Add\cdot\left(x+Add+def\right)`); await page.locator('#add-math-cell').click() await page.setLatex(1, String.raw`I\left(x=1\left\lbrack mm\right\rbrack,\:Add=2\left\lbrack mm\right\rbrack,\:def=3\left\lbrack mm\right\rbrack\right)=`); await page.locator('#code-gen-1').click(); let content = await page.locator('code').textContent(); expect(content).toBe(`def I(x, Add, def_): """ Function 'I' automatically generated by EngineeringPaper.xyz Parameters ---------- x : float 'x' has units of [mm]. Add : float 'Add' has units of [mm]. def_ : float 'def_' has units of [mm]. Returns ------- float Return value has units of [m^2]. """ x = x * 0.001 Add = Add * 0.001 def_ = def_ * 0.001 result = Add*(Add + def_ + x) return result `); await page.keyboard.press('Escape'); }); ================================================ FILE: tests/test_iframe.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { parseLatexFloat, precision, pyodideLoadTimeout } from './utility.mjs'; test('Test sheet in iframe', async ({ page, browserName }) => { await page.goto('/iframe_test.html'); const frame = page.frame('ep-iframe'); await frame.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); await frame.locator('#add-math-cell-0').click(); await frame.locator('math-field.editable').nth(0).type('sigma_max'); await frame.locator('math-field.editable').nth(0).press('Tab'); await frame.locator('math-field.editable').nth(0).type('='); await frame.waitForSelector('.status-footer', { state: 'detached' }); let content = await frame.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(5333333.33333333, precision); }); ================================================ FILE: tests/test_insert_sheet.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test sheet insertion', async ({ browserName }) => { page.setLatex = async function (cellIndex, latex) { await this.evaluate(([cellIndex, latex]) => window.setCellLatex(cellIndex, latex), [cellIndex, latex]); } // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.setLatex(0, 'E='); await page.click('#insert-sheet'); await page.getByLabel('Quick Links').locator('svg').click(); await page.getByLabel('Quick Links').getByText('Mechanical Properties of').click(); await page.getByRole('button', { name: 'Insert', exact: true }).click(); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached' }); let content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(71.7e9, precision); await page.locator('#row-radio-1-1').check(); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(127.6e9, precision); }); test('Test insert using keyboard shortcut using newly saved sheet', async ({ browserName }) => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.type(':nth-match(math-field.editable, 1)', 'x=3'); // save sheet to database await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); await page.keyboard.press('Escape'); // create new sheet await page.locator('#new-sheet').click(); await page.setLatex(0, 'x='); // insert sheet that was just saved await page.keyboard.press(modifierKey+"+Enter"); await page.locator('text=Insert Sheet').click({timeout: 2000, force: true}); await page.locator('input[name="url"]').fill(sheetUrl.href); await page.getByRole('button', { name: 'Insert', exact: true }).click(); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached' }); const content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); }); ================================================ FILE: tests/test_keyboard_shortcuts.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { precision, loadPyodide, newSheet, parseLatexFloat, pyodideLoadTimeout } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test keyboard shortcuts', async ({ browserName }) => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // don't use forceCellDelete function here since we need to test deleting the undo cell at least once await page.locator('#delete-0').click(); await page.locator('#delete-0').click(); // delete twice to delete the undo cell // add math cell with shift-Enter keyboard shortcut with now no cell selected await page.keyboard.press('Shift+Enter'); // add math cell with shift-Enter with first cell selected await page.keyboard.press('Shift+Enter'); // add math cell with Enter shortcut from a math cell await page.keyboard.press('Enter'); // select first cell using modifier-Uparrow shortcut await page.keyboard.press(modifierKey+"+ArrowUp"); await page.keyboard.press(modifierKey+"+ArrowUp"); await page.keyboard.type('x=2'); await page.keyboard.press(modifierKey+"+ArrowDown"); await page.keyboard.type('y=3'); await page.keyboard.press(modifierKey+"+ArrowDown"); await page.keyboard.type('x*y='); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); // make sure delete undo works await page.keyboard.press(modifierKey+"+ArrowUp"); await page.keyboard.press(modifierKey+"+D"); await page.locator('text=Undo Delete', {timeout: 1000}).click({force: true}); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); // use control D to delete and let timer count down to delete await page.keyboard.press(modifierKey+"+D"); await page.locator('text=Undo Delete').waitFor({state: "detached"}); // insert math cell using modifier-Enter await page.keyboard.press(modifierKey+"+Enter"); await page.locator('text=Math Cell').waitFor({timeout: 1000}); await page.keyboard.press('1'); await page.keyboard.type('y=4'); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); // test escape out of insert cell dialog await page.keyboard.press(modifierKey+"+Enter"); await page.locator('text=Math Cell').waitFor({timeout: 1000}); await page.keyboard.press('Escape'); await page.locator('text=Math Cell').waitFor({state: "detached", timeout: 1000}); // test double modifier-D to delete cell await page.keyboard.press(modifierKey+"+D"); await page.keyboard.press(modifierKey+"+D"); // test add system solve cell with insert cell dialog await page.keyboard.press(modifierKey+"+Enter"); await page.locator('text=Math Cell').waitFor({timeout: 1000}); await page.keyboard.press('7'); await page.keyboard.type('8=y'); await page.locator('#system-parameterlist-2 math-field.editable').type('y'); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(16, precision); // test add documentation cell with insert cell dialog await page.keyboard.press(modifierKey+"+Enter"); await page.locator('text=Math Cell').waitFor({timeout: 1000}); await page.keyboard.press('2'); await page.locator('.ql-toolbar').waitFor({timeout: 1000}); // test add plot cell with insert cell dialog await page.keyboard.press(modifierKey+"+Enter"); await page.locator('text=Math Cell').waitFor({timeout: 1000}); await page.keyboard.press('3'); await page.locator('text=log x').waitFor({timeout: 2000}); // test add table await page.keyboard.press(modifierKey+"+Enter"); await page.locator('text=Math Cell').waitFor({timeout: 1000}); await page.keyboard.press('4'); await page.locator('text=Option 1').waitFor({timeout: 1000}); // test add piecewise await page.keyboard.press(modifierKey+"+Enter"); await page.locator('text=Math Cell').waitFor({timeout: 1000}); await page.keyboard.press('6'); await page.locator('text=otherwise').waitFor({timeout: 1000}); // delete piecewise and plot with errors await page.keyboard.press(modifierKey+"+D"); await page.keyboard.press(modifierKey+"+D"); await page.keyboard.press(modifierKey+"+ArrowUp") await page.keyboard.press(modifierKey+"+D"); await page.keyboard.press(modifierKey+"+D"); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(16, precision); }); test('Test math cell undo/redo', async ({ browserName }) => { let modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; if (modifierKey === 'Meta' && browserName === 'chromium') { // Cmd-z not working with Chromium on Mac, need to use Control-z // Cmd-z works correctly on Chrome and Edge on Mac modifierKey = "Control"; } const redoShortcut = modifierKey === "Control" ? "Control+y" : "Meta+Shift+z"; await page.locator('math-field.editable').nth(0).type('x=1000000'); await page.keyboard.press('Shift+Enter'); await page.locator('math-field.editable').nth(1).type('y=1000'); await page.keyboard.press('Shift+Enter'); await page.locator('math-field.editable').nth(2).type('x+y='); await page.waitForSelector('.status-footer', { state: 'detached' }); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1001000, precision); await page.locator('math-field.editable').nth(0).press(modifierKey+'+z'); await page.locator('math-field.editable').nth(1).press(modifierKey+'+z'); await page.waitForSelector('.status-footer', { state: 'detached'}); content = await page.textContent('#result-value-2'); expect(content).toBe('x + y'); await page.locator('math-field.editable').nth(0).press(redoShortcut); await page.locator('math-field.editable').nth(0).press(redoShortcut); // one extra to make sure there isn't a problem with that await page.locator('math-field.editable').nth(1).press(redoShortcut); await page.waitForSelector('.status-footer', { state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1001000, precision); // make sure undo history is truncated after modification await page.locator('math-field.editable').nth(1).press(modifierKey+'+z'); await page.locator('math-field.editable').nth(1).press(modifierKey+'+z'); await page.locator('math-field.editable').nth(1).press(modifierKey+'+z'); await page.locator('math-field.editable').nth(1).type('y=10002'); await page.waitForSelector('.status-footer', { state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1010002, precision); await page.locator('math-field.editable').nth(1).press(redoShortcut); // shouldn't do anything await page.waitForSelector('.status-footer', { state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1010002, precision); // undo everything and redo for (let i = 0; i<10; i++) { await page.locator('math-field.editable').nth(1).press(modifierKey+'+z'); } for (let i = 0; i<10; i++) { await page.locator('math-field.editable').nth(1).press(redoShortcut); } // result should still be the same await page.waitForSelector('.status-footer', { state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(1010002, precision); }); test('Test esc to undo delete', async ({ browserName }) => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#cell-0 >> math-field.editable').type("x+y="); await page.keyboard.press('Enter'); await page.locator('#cell-1 >> math-field.editable').type("x=1"); await page.keyboard.press('Enter'); await page.locator('#cell-2 >> math-field.editable').type("y=2"); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); // test undo delete using escape when delete triggered using keyboard shortcut await page.locator('#cell-1 >> math-field.editable').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeFocused(); await page.keyboard.press(modifierKey+'+D'); await expect(page.locator('text=Undo Delete')).toBeVisible(); await page.keyboard.press('Escape'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); // test undo delete using escape when delete triggered using button await page.locator('#cell-1 >> math-field.editable').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeFocused(); await page.click('#delete-1'); await expect(page.locator('text=Undo Delete')).toBeVisible(); await page.keyboard.press('Escape'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); }); test('Test copy math cell data', async ({ browserName }) => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator("#cell-0 >> math-field.editable").type("sqrt3"); await page.locator("#cell-0 >> math-field.editable").press("Tab"); await page.locator("#cell-0 >> math-field.editable").type("+x/y"); await page.locator("#cell-0 >> math-field.editable").press("Tab"); await page.locator("#cell-0 >> math-field.editable").type("="); // copy math cell contents await page.locator("#cell-0 >> math-field.editable").press(modifierKey+'+a'); await page.locator("#cell-0 >> math-field.editable").press(modifierKey+'+c'); // paste math cell contents await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.locator('h1').press(modifierKey+'+v'); let clipboardContents = await page.locator('h1').textContent(); expect(clipboardContents).toBe(String.raw`\sqrt3+\frac{x}{y}=`); }); test('Make sure documentation insert formula shortcut targets active documentation field', async ({ browserName }) => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // add two documentation cells await page.locator('#add-documentation-cell').click(); await page.locator('#add-documentation-cell').click(); // add content and formula to each one await page.locator('#cell-1 >> .ql-editor').type('documentation field one'); await page.locator('#cell-1 >> .ql-editor').press('Enter'); await page.locator('#cell-1 >> .ql-editor').press(modifierKey+'+e'); await page.getByRole('textbox', { name: 'e=mc^' }).fill('\\alpha'); await page.getByRole('textbox', { name: 'e=mc^' }).press('Enter'); await page.locator('#cell-2 >> .ql-editor').type('documentation field two'); await page.locator('#cell-2 >> .ql-editor').press('Enter'); await page.locator('#cell-2 >> .ql-editor').press(modifierKey+'+e'); await page.getByRole('textbox', { name: 'e=mc^' }).fill('\\beta'); await page.getByRole('textbox', { name: 'e=mc^' }).press('Enter'); // make sure content made it to the correct locations await expect(page.locator('#cell-1 >> text=documentation field one')).toBeVisible(); await expect(page.locator('#cell-1 >> text=α').first()).toBeVisible(); await expect(page.locator('#cell-2 >> text=documentation field two')).toBeVisible(); await expect(page.locator('#cell-2 >> text=β').first()).toBeVisible(); }); test('Test virtual keyboard pererving units tab choice when switching main tab', async () => { await page.locator('button').filter({ hasText: '11' }).click(); await page.getByRole('button', { name: 'Units', exact: true }).click(); await page.getByRole('button', { name: 'Press', exact: true }).click(); await page.locator('button').filter({ hasText: '[M⁢P⁢a]' }).click(); await page.locator('button').filter({ hasText: '123' }).click(); await page.locator('button').filter({ hasText: '==' }).click(); await page.getByRole('button', { name: 'Units', exact: true }).click(); await page.locator('button').filter({ hasText: '[P⁢a]' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(1e6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('Pa'); }); test('Test hide/show virtual keyboard', async () => { await expect(page.locator('#keyboard-tray')).toHaveCSS('height', '200px'); // turn off virtual keyboard await page.locator('#keyboard-hider').click(); await expect(page.locator('#keyboard-hider')).toBeVisible(); await expect(page.locator('#keyboard-tray')).toHaveCSS('height', '1px'); // unselect mathfield and make sure keyboard hider button is not visible await page.keyboard.press('Escape'); await expect(page.locator('#keyboard-hider')).not.toBeVisible(); await expect(page.locator('#keyboard-tray')).toHaveCSS('height', '1px'); // reload sheet and make sure keyboard is still hidden await page.reload(); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout}); await page.locator('#cell-0 >> math-field.editable').click(); await expect(page.locator('#keyboard-hider')).toBeVisible(); await expect(page.locator('#keyboard-tray')).toHaveCSS('height', '1px'); // turn virtual keyboard back on await page.locator('#keyboard-hider').click(); await expect(page.locator('#keyboard-hider')).toBeVisible(); await expect(page.locator('#keyboard-tray')).toHaveCSS('height', '200px'); // unselect mathfield and make sure keyboard hider button is not visible await page.keyboard.press('Escape'); await expect(page.locator('#keyboard-hider')).not.toBeVisible(); await expect(page.locator('#keyboard-tray')).toHaveCSS('height', '1px'); // reload sheet and make sure keyboard is still shows await page.reload(); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout}); await page.locator('#cell-0 >> math-field.editable').click(); await expect(page.locator('#keyboard-hider')).toBeVisible(); await expect(page.locator('#keyboard-tray')).toHaveCSS('height', '200px'); }); ================================================ FILE: tests/test_latex_scientific_notation.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, complexLatex, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test basic latex scientific notation', async () => { await page.setLatex(0, String.raw`3.5\cdot10^3\left\lbrack mm\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`3.5\cdot10^{-10}\left\lbrack mm\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`3.5\times10^{-9}\left\lbrack mm\right\rbrack=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`-3.5 \cdot 10^{10}\left\lbrack mm\right\rbrack=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(3.5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(3.5e-13, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(3.5e-12, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(-3.5e7, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m'); }); test('Test exponent error checking for exponents applied to numbers with units ', async () => { await page.setLatex(0, String.raw`2\cdot10^2\left\lbrack m\right\rbrack^2=`); await expect(page.locator("#cell-0 >> text=Exponent cannot be applied directly to a number with units")).toBeAttached(); await page.setLatex(0, String.raw`2\times10^2\left\lbrack m\right\rbrack^2=`); await expect(page.locator("#cell-0 >> text=Exponent cannot be applied directly to a number with units")).toBeAttached(); await page.setLatex(0, String.raw`\left(2\cdot10^2\left\lbrack m\right\rbrack\right)^2=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(40000, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^2'); }); test('Test latex scientific notation order of operations', async () => { await page.setLatex(0, String.raw`\left(-2\cdot10^4\left\lbrack mm\right\rbrack+2\left\lbrack m\right\rbrack\right)\cdot2=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\left(1\left\lbrack m\right\rbrack-2\cdot10^4\left\lbrack mm\right\rbrack\right)\cdot2=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\left(-\left(4\cdot10^4\left\lbrack m^2\right\rbrack\right)^{\frac12}+2000\left\lbrack mm\right\rbrack\right)\cdot2=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\left(2\cdot10^4\left\lbrack m^2\right\rbrack+20000\left\lbrack m^2\right\rbrack\right)^{\frac12}\cdot2=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`\left(1\left\lbrack m\right\rbrack-4\cdot2\cdot10^4\left\lbrack mm\right\rbrack\right)\cdot2=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`2\cdot10^4\cdot3-10000=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(-36, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(-38, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(-396, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(400, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m'); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(-158, precision); content = await page.textContent('#result-units-4'); expect(content).toBe('m'); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(50000, precision); content = await page.textContent('#result-units-5'); expect(content).toBe(''); }); test('Test latex scientific notation keyboard shortcut and virtual keyboard', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.locator('#cell-0 >> math-field.editable').type("2"); await page.locator('#cell-0 >> math-field.editable').press(`${modifierKey}+e`); await page.locator('#cell-0 >> math-field.editable').type("3"); await page.locator('#cell-0 >> math-field.editable').press("Tab"); await page.locator('#cell-0 >> math-field.editable').type("[mm]="); await page.locator('#add-math-cell').click(); await page.locator('button').filter({ hasText: '⋅10x⋅10x' }).click(); await page.locator('#cell-1 >> math-field.editable').type("-30"); await page.locator('#cell-1 >> math-field.editable').press("Tab"); await page.locator('#cell-1 >> math-field.editable').type("-3"); await page.locator('#cell-1 >> math-field.editable').press("Tab"); await page.locator('#cell-1 >> math-field.editable').type("[km]="); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(-30, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); }); ================================================ FILE: tests/test_matrix_addition.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Matrix addition', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\end{bmatrix}+\begin{bmatrix}5 & 6\\ 7 & 8\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a + 5 & b + 6 \\ c + 7 & d + 8 \end{bmatrix}`); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a=1,b=2,c=3,d=4`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 6 & 8 \\ 10 & 12 \end{bmatrix}`); }); test('Matrix subtraction', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\end{bmatrix}-\begin{bmatrix}5 & 6\\ 7 & 8\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a - 5 & b - 6 \\ c - 7 & d - 8 \end{bmatrix}`); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a=1,b=2,c=3,d=4`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} -4 & -4 \\ -4 & -4 \end{bmatrix}`); }); test('Matrix addition with units', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\end{bmatrix}+\begin{bmatrix}5\left\lbrack m\right\rbrack & 6\left\lbrack s\right\rbrack\\ 7\left\lbrack kg\right\rbrack & 8\left\lbrack radian\right\rbrack\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a + 5 & b + 6 \\ c + 7 & d + 8 \end{bmatrix}`); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a=1\left\lbrack m\right\rbrack,b=2\left\lbrack s\right\rbrack,c=3\left\lbrack kg\right\rbrack,d=4\left\lbrack radian\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 6\left\lbrack m\right\rbrack & 8\left\lbrack s\right\rbrack \\ 10\left\lbrack kg\right\rbrack & 12\left\lbrack rad\right\rbrack \end{bmatrix}`); }); test('Matrix addition with incompatible units', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\end{bmatrix}+\begin{bmatrix}5\left\lbrack m\right\rbrack & 6\left\lbrack s\right\rbrack\\ 7\left\lbrack kg\right\rbrack & 8\left\lbrack radian\right\rbrack\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a + 5 & b + 6 \\ c + 7 & d + 8 \end{bmatrix}`); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a=1\left\lbrack s\right\rbrack,b=2\left\lbrack s\right\rbrack,c=3\left\lbrack kg\right\rbrack,d=4\left\lbrack radian\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeAttached(); }); test('Test subtraction with units', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\end{bmatrix}-\begin{bmatrix}5\left\lbrack m\right\rbrack & 6\left\lbrack s\right\rbrack\\ 7\left\lbrack kg\right\rbrack & 8\left\lbrack radian\right\rbrack\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a - 5 & b - 6 \\ c - 7 & d - 8 \end{bmatrix}`); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a=1\left\lbrack m\right\rbrack,b=2\left\lbrack s\right\rbrack,c=3\left\lbrack kg\right\rbrack,d=4\left\lbrack radian\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} -4\left\lbrack m\right\rbrack & -4\left\lbrack s\right\rbrack \\ -4\left\lbrack kg\right\rbrack & -4\left\lbrack rad\right\rbrack \end{bmatrix}`); }); test('Incompatible size addition', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\\ e & f\end{bmatrix}+\begin{bmatrix}5\left\lbrack m\right\rbrack & 6\left\lbrack s\right\rbrack\\ 7\left\lbrack kg\right\rbrack & 8\left\lbrack radian\right\rbrack\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('.status-footer >> text=ShapeError')).toBeVisible(); }); test('nonsquare addition', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\\ e_0 & f\end{bmatrix}+\begin{bmatrix}1\left\lbrack m\right\rbrack & 2\left\lbrack s\right\rbrack\\ 3\left\lbrack kg\right\rbrack & 4\left\lbrack radian\right\rbrack\\ 5\left\lbrack kelvin\right\rbrack & 6\left\lbrack ampere\right\rbrack\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a + 1 & b + 2 \\ c + 3 & d + 4 \\ e_0 + 5 & f + 6 \end{bmatrix}`); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a=6\left\lbrack m\right\rbrack,\:b=5\left\lbrack s\right\rbrack,\:c=4\left\lbrack kg\right\rbrack,d=3\left\lbrack radian\right\rbrack,e_0=2\left\lbrack K\right\rbrack,f=1\left\lbrack A\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 7\left\lbrack m\right\rbrack & 7\left\lbrack s\right\rbrack \\ 7\left\lbrack kg\right\rbrack & 7\left\lbrack rad\right\rbrack \\ 7\left\lbrack K\right\rbrack & 7\left\lbrack A\right\rbrack \end{bmatrix}`); }); test('Addition with literal and variable matrices', async () => { await page.setLatex(0, String.raw`A+\begin{bmatrix}5\left\lbrack m\right\rbrack & 6\left\lbrack s\right\rbrack\\ 7\left\lbrack kg\right\rbrack & 8\left\lbrack radian\right\rbrack\end{bmatrix}=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`$$ A=\begin{bmatrix}a & b\\ c & d\end{bmatrix} $$`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a + 5 & b + 6 \\ c + 7 & d + 8 \end{bmatrix}`); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`a=1\left\lbrack m\right\rbrack,b=2\left\lbrack s\right\rbrack,c=3\left\lbrack kg\right\rbrack,d=4\left\lbrack radian\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 6\left\lbrack m\right\rbrack & 8\left\lbrack s\right\rbrack \\ 10\left\lbrack kg\right\rbrack & 12\left\lbrack rad\right\rbrack \end{bmatrix}`); }); test('Addition with two variable matrices', async () => { await page.setLatex(0, String.raw`A+B=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`B=\begin{bmatrix}5\left\lbrack m\right\rbrack & 6\left\lbrack s\right\rbrack\\ 7\left\lbrack kg\right\rbrack & 8\left\lbrack radian\right\rbrack\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a + 5 & b + 6 \\ c + 7 & d + 8 \end{bmatrix}`); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`a=1\left\lbrack m\right\rbrack,b=2\left\lbrack s\right\rbrack,c=3\left\lbrack kg\right\rbrack,d=4\left\lbrack radian\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 6\left\lbrack m\right\rbrack & 8\left\lbrack s\right\rbrack \\ 10\left\lbrack kg\right\rbrack & 12\left\lbrack rad\right\rbrack \end{bmatrix}`); }); test('Addition scalar and variable matrix', async () => { // Ideally would generate an error, however sympy generates a symbolic result // sympy won't generate a numerical result so it will be clear to the user what is happening await page.setLatex(0, String.raw`1+A=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}1 & 2\\ 3 & 4\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`1 + \left[\begin{matrix}1 & 2\\3 & 4\end{matrix}\right]`); }); test('Addition scalar and literal matrix', async () => { // Ideally would generate an error, however sympy generates a symbolic result // sympy won't generate a numerical result so it will be clear to the user what is happening await page.setLatex(0, String.raw`1+\begin{bmatrix}1 & 2\\ 3 & 4\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`1 + \left[\begin{matrix}1 & 2\\3 & 4\end{matrix}\right]`); }); ================================================ FILE: tests/test_matrix_calc.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Defininte integral', async () => { await page.setLatex(0, String.raw`\int_0^1\left(\begin{bmatrix}x & x^2\\ x^3 & x^4\end{bmatrix}\right)\mathrm{d}\left(x\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0.5 & 0.333333333333333 \\ 0.25 & 0.2 \end{bmatrix}`); }); test('Indefininte integral', async () => { await page.setLatex(0, String.raw`\int\left(\begin{bmatrix}x & x^2\\ x^3 & x^4\end{bmatrix}\right)\mathrm{d}\left(x\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} \frac{x^{2}}{2} & \frac{x^{3}}{3} \\ \frac{x^{4}}{4} & \frac{x^{5}}{5} \end{bmatrix}`); }); test('Derivative', async () => { await page.setLatex(0, String.raw`\frac{\mathrm{d}}{\mathrm{d}\left(x\right)}\left(\begin{bmatrix}x & x^2\\ x^3 & x^4\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('\\begin{bmatrix} 1 & 2 \\cdot x \\\\ 3 \\cdot x^{2} & 4 \\cdot x^{3} \\end{bmatrix}'); }); ================================================ FILE: tests/test_matrix_determinant.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Determinant of matrix literal using keyboard entry', async () => { await page.locator('#cell-0 >> math-field.editable').type("det([2,2"); await page.locator('#cell-0 >> math-field.editable').press("Enter"); await page.locator('#cell-0 >> math-field.editable').type("1"); await page.locator('#cell-0 >> math-field.editable').press("Tab"); await page.locator('#cell-0 >> math-field.editable').type("2"); await page.locator('#cell-0 >> math-field.editable').press("Tab"); await page.locator('#cell-0 >> math-field.editable').type("3"); await page.locator('#cell-0 >> math-field.editable').press("Tab"); await page.locator('#cell-0 >> math-field.editable').type("4"); await page.locator('#cell-0 >> math-field.editable').press("Tab"); await page.locator('#cell-0 >> math-field.editable').press("Tab"); await page.locator('#cell-0 >> math-field.editable').type("="); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(-2, precision); }); test('Determinant of large matrix with units', async () => { await page.setLatex(0, String.raw`\mathrm{det}\left(\begin{bmatrix}1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^10'); }); test('Determinant of matrix literal with symbolic entries', async () => { await page.setLatex(0, String.raw`\mathrm{det}\left(\begin{bmatrix}a & b\\ c & d\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('a \\cdot d - b \\cdot c'); }); test('Determinant of nonsquare matrix', async () => { await page.setLatex(0, String.raw`\mathrm{det}\left(\begin{bmatrix}1 & 2\\ 3 & 4\\ 5 & 6\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=NonSquareMatrixError')).toBeVisible(); }); test('Determinant of variable matrix', async () => { await page.locator('#cell-0 >> math-field.editable').type("det(A)="); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('a \\cdot d - b \\cdot c'); }); test('Determinant of variable matrix with units', async () => { await page.locator('#cell-0 >> math-field.editable').type("det(A)="); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`a=1\left\lbrack m\right\rbrack,\:b=2\left\lbrack m\right\rbrack,\:c=3\left\lbrack m\right\rbrack,\:d=4\left\lbrack m\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(-2, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^2'); }); test('Determinant of variable matrix consistent mixed units', async () => { await page.locator('#cell-0 >> math-field.editable').type("det(A)="); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`a=1\left\lbrack m\right\rbrack,\:b=2\left\lbrack m^2\right\rbrack,\:c=3\left\lbrack m\right\rbrack,\:d=4\left\lbrack m^2\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(-2, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^3'); }); test('Determinant of variable matrix inconsistent mixed units', async () => { await page.locator('#cell-0 >> math-field.editable').type("det(A)="); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`a=1\left\lbrack m\right\rbrack,\:b=2\left\lbrack m^2\right\rbrack,\:c=3\left\lbrack m\right\rbrack,\:d=4\left\lbrack m^3\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("#cell-0 >> text=Dimension Error")).toBeAttached(); }); ================================================ FILE: tests/test_matrix_functions.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Norm of vector with symbolic entries using all three notations', async () => { await page.setLatex(0, String.raw`||\begin{bmatrix}a\\ b\\ c\end{bmatrix}||=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{norm}\left(\begin{bmatrix}a\\ b\\ c\end{bmatrix}\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\left\Vert\begin{bmatrix}a\\ b\\ c\end{bmatrix}\right\Vert=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\sqrt{\left|{a}\right|^{2} + \left|{b}\right|^{2} + \left|{c}\right|^{2}}`); content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\sqrt{\left|{a}\right|^{2} + \left|{b}\right|^{2} + \left|{c}\right|^{2}}`); content = await page.textContent(`#result-value-2`); expect(content).toBe(String.raw`\sqrt{\left|{a}\right|^{2} + \left|{b}\right|^{2} + \left|{c}\right|^{2}}`); }); test('Norm of row vector with symbolic entries', async () => { await page.setLatex(0, String.raw`\left\Vert\begin{bmatrix}a & b & c\end{bmatrix}\right\Vert=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\sqrt{\left|{a}\right|^{2} + \left|{b}\right|^{2} + \left|{c}\right|^{2}}`); }); test('Norm of row vector with numeric entries', async () => { await page.setLatex(0, String.raw`\left\Vert\begin{bmatrix}1\\ 2\\ 3\end{bmatrix}\right\Vert=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(14), precision); }); test('Norm of row vector with numeric entries and units', async () => { await page.setLatex(0, String.raw`\left\Vert\begin{bmatrix}1000\left\lbrack mm\right\rbrack\\ 2000\left\lbrack mm\right\rbrack\\ 3000\left\lbrack mm\right\rbrack\end{bmatrix}\right\Vert=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(14), precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Norm of row vector with numeric entries and inconsistent units units', async () => { await page.setLatex(0, String.raw`\left\Vert\begin{bmatrix}1000\left\lbrack mm\right\rbrack\\ 2000\left\lbrack mm\right\rbrack\\ 3000\left\lbrack sec\right\rbrack\end{bmatrix}\right\Vert=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("#cell-0 >> text=Dimension Error")).toBeAttached(); }); test('Norm of matrix', async () => { await page.setLatex(0, String.raw`\left\Vert\begin{bmatrix}1\left\lbrack m\right\rbrack & 2\left\lbrack m\right\rbrack\\ 3\left\lbrack m\right\rbrack & 4\left\lbrack m\right\rbrack\\ 5\left\lbrack m\right\rbrack & 6\left\lbrack m\right\rbrack\end{bmatrix}\right\Vert=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(91), precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Norm of scalar', async () => { await page.setLatex(0, String.raw`||v||=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`v=1`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("text=object has no attribute 'norm'")).toBeVisible(); }); test('Norm of variable vector', async () => { await page.setLatex(0, String.raw`||v||=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`v=\begin{bmatrix}a\\ b\\ c\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\sqrt{\left|{a}\right|^{2} + \left|{b}\right|^{2} + \left|{c}\right|^{2}}`); }); test('Test min/max of a col vector', async () => { await page.setLatex(0, String.raw`max\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`min\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`x=\begin{bmatrix}1\\ 2\\ 4\\ 9\\ -1\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(-1, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); }); test('Test min/max of a col vector with units', async () => { await page.setLatex(0, String.raw`max\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`min\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`x=\begin{bmatrix}1\\ 2\\ 4\\ 9\\ -1\end{bmatrix}\cdot1\left\lbrack m\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(-1, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); }); test('Test min/max of a col vector with incompatible units', async () => { await page.setLatex(0, String.raw`max\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`min\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`x=\begin{bmatrix}1\left\lbrack m\right\rbrack\\ 2\left\lbrack m\right\rbrack\\ 4\left\lbrack m\right\rbrack\\ 9\left\lbrack m\right\rbrack\\ -1\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("#cell-0 >> text=Dimension Error")).toBeAttached(); await expect(page.locator("#cell-1 >> text=Dimension Error")).toBeAttached(); }); test('Test min/max of a row vector', async () => { await page.setLatex(0, String.raw`max\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`min\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`x=\begin{bmatrix}9 & 0 & -1 & 4\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(-1, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); }); test('Test min/max of a row vector with units', async () => { await page.setLatex(0, String.raw`max\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`min\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`x=\begin{bmatrix}9\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & -1\left\lbrack m\right\rbrack & 4\left\lbrack m\right\rbrack\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(-1, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); }); test('Test min/max of a row vector with incompatible units', async () => { await page.setLatex(0, String.raw`max\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`min\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`x=\begin{bmatrix}9\left\lbrack s\right\rbrack & 0\left\lbrack m\right\rbrack & -1\left\lbrack m\right\rbrack & 4\left\lbrack m\right\rbrack\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("#cell-0 >> text=Dimension Error")).toBeAttached(); await expect(page.locator("#cell-1 >> text=Dimension Error")).toBeAttached(); }); test('Test min/max of a matrix', async () => { await page.setLatex(0, String.raw`max\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`min\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`x=\begin{bmatrix}-1 & 0\\ 3 & 5\\ 5.5 & 9\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(-1, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); }); test('Test min/max of a matrix with units', async () => { await page.setLatex(0, String.raw`max\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`min\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`x=\begin{bmatrix}-1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 3\left\lbrack m\right\rbrack & 5\left\lbrack m\right\rbrack\\ 5.5\left\lbrack m\right\rbrack & 9\left\lbrack m\right\rbrack\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(-1, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); }); test('Test min/max of a matrix with incompatible units', async () => { await page.setLatex(0, String.raw`max\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`min\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`x=\begin{bmatrix}-1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 3 & 5\left\lbrack m\right\rbrack\\ 5.5\left\lbrack m\right\rbrack & 9\left\lbrack m\right\rbrack\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("#cell-0 >> text=Dimension Error")).toBeAttached(); await expect(page.locator("#cell-1 >> text=Dimension Error")).toBeAttached(); }); test('Test min/max of a symbolic col vector', async () => { await page.setLatex(0, String.raw`max\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`min\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`x=\begin{bmatrix}a\\ b\\ c\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\max\left(a, b, c\right)`); content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\min\left(a, b, c\right)`); }); test('Test range with single argument', async () => { await page.setLatex(0, String.raw`\mathrm{range}\left(5\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \\ 4 \\ 5 \end{bmatrix}`); }); test('Test range with two arguments', async () => { await page.setLatex(0, String.raw`\mathrm{range}\left(-5,4\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} -5 \\ -4 \\ -3 \\ -2 \\ -1 \\ 0 \\ 1 \\ 2 \\ 3 \\ 4 \end{bmatrix}`); }); test('Test range with three arguments', async () => { await page.setLatex(0, String.raw`\mathrm{range}\left(1,2,.1\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 1.1 \\ 1.2 \\ 1.3 \\ 1.4 \\ 1.5 \\ 1.6 \\ 1.7 \\ 1.8 \\ 1.9 \\ 2 \end{bmatrix}`); }); test('Test range with negative step', async () => { await page.setLatex(0, String.raw`\mathrm{range}\left(-1,-2,-.1\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} -1 \\ -1.1 \\ -1.2 \\ -1.3 \\ -1.4 \\ -1.5 \\ -1.6 \\ -1.7 \\ -1.8 \\ -1.9 \\ -2 \end{bmatrix}`); }); test('Test range that includes zero value multiplied by dimensioned value', async () => { await page.setLatex(0, String.raw`\mathrm{range}\left(0,5\right)\cdot1\left\lbrack m\right\rbrack=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0\left\lbrack m\right\rbrack \\ 1\left\lbrack m\right\rbrack \\ 2\left\lbrack m\right\rbrack \\ 3\left\lbrack m\right\rbrack \\ 4\left\lbrack m\right\rbrack \\ 5\left\lbrack m\right\rbrack \end{bmatrix}`); }); test('Test range with consistent units', async () => { await page.setLatex(0, String.raw`\mathrm{range}\left(1\left\lbrack m\right\rbrack,2\left\lbrack m\right\rbrack,1\left\lbrack m\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1\left\lbrack m\right\rbrack \\ 2\left\lbrack m\right\rbrack \end{bmatrix}`); }); test('Test range with inconsistent units', async () => { await page.setLatex(0, String.raw`\mathrm{range}\left(1\left\lbrack m\right\rbrack,2\left\lbrack s\right\rbrack,1\left\lbrack m\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("#cell-0 >> text=Dimension Error")).toBeAttached(); }); test('Test range error handling for empty range', async () => { await page.setLatex(0, String.raw`\mathrm{range}\left(10,0\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("text=Attempt to create empty range")).toBeAttached(); }); test('Test range with expression inputs', async () => { await page.setLatex(0, String.raw`\mathrm{range}\left(start,stop\cdot2,step\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`start=0,\:stop=.5,\:step=.1`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0 \\ 0.1 \\ 0.2 \\ 0.3 \\ 0.4 \\ 0.5 \\ 0.6 \\ 0.7 \\ 0.8 \\ 0.9 \\ 1 \end{bmatrix}`); }); test('Test range that last value not included if that hit by steps', async () => { await page.setLatex(0, String.raw`\mathrm{range}\left(4.99999\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \\ 4 \end{bmatrix}`); }); test('Test count function for column vector', async () => { await page.setLatex(0, String.raw`\mathrm{count}\left(\mathrm{range}\left(4\right)\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test count function for symbolic row vector', async () => { await page.setLatex(0, String.raw`\mathrm{count}\left(\begin{bmatrix}a & b & c\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test count function for matrix with units and substitution', async () => { await page.setLatex(0, String.raw`\mathrm{count}\left(A\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}1 & 2 & 3\\ 4 & 5 & 6\end{bmatrix}\cdot1\left\lbrack m\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test count error handling for non-matrix input', async () => { await page.setLatex(0, String.raw`\mathrm{count}\left(a\right)=`); await expect(page.locator('text=Count function requires a vector or matrix as input')).toBeAttached(); }); test('Test sum function for multiple scalar inputs with units', async () => { await page.setLatex(0, String.raw`\mathrm{sum}\left(1\left\lbrack m\right\rbrack,2\left\lbrack m\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Test sum function for row vector with symbolic values', async () => { await page.setLatex(0, String.raw`\mathrm{sum}\left(\begin{bmatrix}a & b\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('a + b'); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test sum function for column vector with numeric unitless values', async () => { await page.setLatex(0, String.raw`\mathrm{sum}\left(\begin{bmatrix}1\\ 2\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test sum function for matrix', async () => { await page.setLatex(0, String.raw`\mathrm{sum}\left(\begin{bmatrix}1 & 2 & 3\\ 4 & 5 & 6\end{bmatrix}\cdot1\left\lbrack m\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(21, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Test sum function with inconsistent units', async () => { await page.setLatex(0, String.raw`\mathrm{sum}\left(\begin{bmatrix}1\\ 2\left\lbrack m\right\rbrack\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("#cell-0 >> text=Dimension Error")).toBeAttached(); }); test('Test average function for multiple scalar inputs without units', async () => { await page.setLatex(0, String.raw`average\left(1,2,3,4,5\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test average function for matrix with symbolic values', async () => { await page.setLatex(0, String.raw`\mathrm{average}\left(\begin{bmatrix}a & b\\ c & d\\ ee & f\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\frac{a}{6} + \frac{b}{6} + \frac{c}{6} + \frac{d}{6} + \frac{ee}{6} + \frac{f}{6}`); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test average function for column vector with units', async () => { await page.setLatex(0, String.raw`\mathrm{average}\left(\begin{bmatrix}1\\ 2\\ 3\end{bmatrix}\cdot1\left\lbrack m\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Test average function for row vector with units', async () => { await page.setLatex(0, String.raw`\mathrm{average}\left(\begin{bmatrix}1 & 2\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(1.5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test average function with scalar input and inconsistent units', async () => { await page.setLatex(0, String.raw`\mathrm{average}\left(1,2\left\lbrack m\right\rbrack,3,4,5\right)=`); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeAttached(); }); test('Test stdev function for column vector with units', async () => { await page.setLatex(0, String.raw`\mathrm{stdev}\left(\begin{bmatrix}1\\ 2\end{bmatrix}\cdot1\left\lbrack m\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(0.5), precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Test stdevp function for row vector without units', async () => { await page.setLatex(0, String.raw`stdevp\left(\begin{bmatrix}1 & 2\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(0.5, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test stdev function with matrix input', async () => { await page.setLatex(0, String.raw`\mathrm{stdev}\left(\begin{bmatrix}1 & 2 & 3\\ 4 & 5 & 6\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(1.870828693, 9); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test stdevp function with scalar input and units', async () => { await page.setLatex(0, String.raw`stdevp\left(1\left\lbrack m\right\rbrack,2\left\lbrack m\right\rbrack,3\left\lbrack m\right\rbrack,4\left\lbrack m\right\rbrack,5\left\lbrack m\right\rbrack,6\left\lbrack m\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(1.707825128, 9); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Test stdev with only one input value', async () => { await page.setLatex(0, String.raw`\mathrm{stdev}\left(\begin{bmatrix}1\end{bmatrix}\right)=`); await expect(page.locator('text=Must have at least 2 values to estimate standard deviation')).toBeAttached(); }); test('Test numrows and numcols functions', async () => { await page.setLatex(0, String.raw`A=\begin{bmatrix}a & b\\ c & d\\ e & f\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{numrows}\left(A\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\mathrm{numcols}\left(A\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBe(3); content = await page.textContent(`#result-value-2`); expect(parseLatexFloat(content)).toBe(2); }); ================================================ FILE: tests/test_matrix_indexing_and_assembling.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Indexing square and nonsquare matrix literals', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\\ e & f\end{bmatrix}_{1,1}+\begin{bmatrix}a & b\\ c & d\end{bmatrix}_{1,2}+\begin{bmatrix}a & b & c\\ d & e & f\end{bmatrix}_{2,1}+\begin{bmatrix}a & b & c\\ d & e & f\end{bmatrix}_{2,3}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`a + b + d + f`); }); test('Indexing with variable mathematical expression indices', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\\ e & f\end{bmatrix}_{3-2,a3-a2}+\begin{bmatrix}a & b\\ c & d\end{bmatrix}_{a2-1,\frac{a8}{a4}}+\begin{bmatrix}a & b & c\\ d & e & f\end{bmatrix}_{a10\cdot\frac{a2}{a10},\frac42-1}+\begin{bmatrix}a & b & c\\ d & e & f\end{bmatrix}_{a2,a3}=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a1=1,\:a2=2,\:a3=3,\:a4=4,\:a5=5,\:a6=6,a7=7,a8=8,a9=9,a10=10`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`a + b + d + f`); }); test('Indexing variable matrices', async () => { await page.setLatex(0, String.raw`A_{3-2,a3-a2}+B_{a2-1,\frac{a8}{a4}}+C_{a10\cdot\frac{a2}{a10},\frac42-1}+D_{2,3}=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a1=1,\:a2=2,\:a3=3,\:a4=4,\:a5=5,\:a6=6,a7=7,a8=8,a9=9,a10=10`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`A=\begin{bmatrix}a & b\\ c & d\\ e & f\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`B=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`C=\begin{bmatrix}a & b & c\\ d & e & f\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`D=\begin{bmatrix}a & b & c\\ d & e & f\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`a + b + d + f`); }); test('Indexing variable matrices with units', async () => { await page.setLatex(0, String.raw`A_{3-2,a3-a2}+B_{a2-1,\frac{a8}{a4}}+C_{a10\cdot\frac{a2}{a10},\frac42-1}+D_{2,3}=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a1=1,\:a2=2,\:a3=3,\:a4=4,\:a5=5,\:a6=6,a7=7,a8=8,a9=9,a10=10`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`A=\begin{bmatrix}a & b\\ c & d\\ e & f\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`B=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`C=\begin{bmatrix}a & b & c\\ d & e & f\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`D=\begin{bmatrix}a & b & c\\ d & e & f\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(6, String.raw`a=1\left\lbrack m\right\rbrack,\:b=2\left\lbrack m\right\rbrack,\:d=3\left\lbrack m\right\rbrack,\:f=4\left\lbrack m\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(10, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Zero index', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\\ e & f\end{bmatrix}_{0,1}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("text=Matrix indices must evaluate to a finite real integer and be greater than 0")).toBeVisible(); }); test('Negative index', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\\ e & f\end{bmatrix}_{1,-1}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("text=Matrix indices must evaluate to a finite real integer and be greater than 0")).toBeVisible(); }); test('Out of range index', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\\ e & f\end{bmatrix}_{1,3}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("text=Index out of range")).toBeVisible(); }); test('Noninteger index', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\\ e & f\end{bmatrix}_{1,1.1}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator("text=Matrix indices must evaluate to a finite real integer and be greater than 0")).toBeVisible(); }); test('Nonnumeric index', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\\ e & f\end{bmatrix}_{1,z}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`{\left[\begin{matrix}a & b\\c & d\\e & f\end{matrix}\right]}_{0,z - 1}`); }); test('Indexing with expression', async () => { await page.setLatex(0, String.raw`A=\begin{bmatrix}1\left\lbrack m\right\rbrack\\ 2\left\lbrack s\right\rbrack\\ 3\left\lbrack kg\right\rbrack\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A_{\mathrm{count}\left(A\right),1}=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`A_{\mathrm{count}\left(A\right)-1,1}=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`A_{\frac{1\left\lbrack m\right\rbrack}{1\left\lbrack m\right\rbrack},1}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`A_{\frac{1\left\lbrack m\right\rbrack}{1\left\lbrack s\right\rbrack},1}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('kg'); content = await page.textContent(`#result-value-2`); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('s'); content = await page.textContent(`#result-value-3`); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m'); await expect(page.locator('#cell-4 >> text=Matrix indexing value is not dimensionless')).toBeVisible(); }); test('Slicing cols with units', async () => { await page.setLatex(0, String.raw`A=\begin{bmatrix}1 & 2 & 3\\ 4 & 5 & 6\\ 7 & 8 & 9\\ 10 & 11 & 12\end{bmatrix}\cdot1\left\lbrack s\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A_{2,:}=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`A_{2,1:end}=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`A_{end,1:end}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`A_{2,1:2:end}=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`A_{3,end:-1:1}=`); await page.locator('#add-math-cell').click(); await page.setLatex(6, String.raw`A_{3,end:-1:2}=`); await page.locator('#add-math-cell').click(); await page.setLatex(7, String.raw`A_{3,end-1:-1:2}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`\begin{bmatrix} 4\left\lbrack s\right\rbrack & 5\left\lbrack s\right\rbrack & 6\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent('#result-value-2'); expect(content).toBe(String.raw`\begin{bmatrix} 4\left\lbrack s\right\rbrack & 5\left\lbrack s\right\rbrack & 6\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent('#result-value-3'); expect(content).toBe(String.raw`\begin{bmatrix} 10\left\lbrack s\right\rbrack & 11\left\lbrack s\right\rbrack & 12\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent('#result-value-4'); expect(content).toBe(String.raw`\begin{bmatrix} 4\left\lbrack s\right\rbrack & 6\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent('#result-value-5'); expect(content).toBe(String.raw`\begin{bmatrix} 9\left\lbrack s\right\rbrack & 8\left\lbrack s\right\rbrack & 7\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent('#result-value-6'); expect(content).toBe(String.raw`\begin{bmatrix} 9\left\lbrack s\right\rbrack & 8\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-7`); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); content = await page.textContent('#result-units-7'); expect(content).toBe('s'); }); test('Slicing rows with units', async () => { await page.setLatex(0, String.raw`A=\begin{bmatrix}1 & 2 & 3\\ 4 & 5 & 6\\ 7 & 8 & 9\\ 10 & 11 & 12\end{bmatrix}\cdot1\left\lbrack s\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A_{:,2}=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`A_{1:end,2}=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`A_{1:end,end}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`A_{1:2:end,2}=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`A_{end:-1:1,3}=`); await page.locator('#add-math-cell').click(); await page.setLatex(6, String.raw`A_{end-1:-1:2,3}=`); await page.locator('#add-math-cell').click(); await page.setLatex(7, String.raw`A_{end-1:-1:3,3}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`\begin{bmatrix} 2\left\lbrack s\right\rbrack \\ 5\left\lbrack s\right\rbrack \\ 8\left\lbrack s\right\rbrack \\ 11\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent('#result-value-2'); expect(content).toBe(String.raw`\begin{bmatrix} 2\left\lbrack s\right\rbrack \\ 5\left\lbrack s\right\rbrack \\ 8\left\lbrack s\right\rbrack \\ 11\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent('#result-value-3'); expect(content).toBe(String.raw`\begin{bmatrix} 3\left\lbrack s\right\rbrack \\ 6\left\lbrack s\right\rbrack \\ 9\left\lbrack s\right\rbrack \\ 12\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent('#result-value-4'); expect(content).toBe(String.raw`\begin{bmatrix} 2\left\lbrack s\right\rbrack \\ 8\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent('#result-value-5'); expect(content).toBe(String.raw`\begin{bmatrix} 12\left\lbrack s\right\rbrack \\ 9\left\lbrack s\right\rbrack \\ 6\left\lbrack s\right\rbrack \\ 3\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent('#result-value-6'); expect(content).toBe(String.raw`\begin{bmatrix} 9\left\lbrack s\right\rbrack \\ 6\left\lbrack s\right\rbrack \end{bmatrix}`); content = await page.textContent(`#result-value-7`); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-7'); expect(content).toBe('s'); }); test('Assembling matrices', async () => { await page.setLatex(0, String.raw`a=\begin{bmatrix}1\\ 2\end{bmatrix},\:b=\begin{bmatrix}3\\ 4\\ 5\end{bmatrix},A=\begin{bmatrix}1 & 2\\ 3 & 4\end{bmatrix},B=\begin{bmatrix}5 & 6\\ 7 & 8\end{bmatrix},C=\begin{bmatrix}9 & 10\\ 11 & 12\end{bmatrix},D=\begin{bmatrix}13 & 14\\ 15 & 16\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\begin{bmatrix}a\\ b\end{bmatrix}=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\begin{bmatrix}a^{\mathrm{T}} & b^{\mathrm{T}}\end{bmatrix}=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\begin{bmatrix}A & B\\ C & D\end{bmatrix}=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`\begin{bmatrix}A\\ B\end{bmatrix}=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`\begin{bmatrix}C & D\end{bmatrix}=`); await page.locator('#add-math-cell').click(); await page.setLatex(6, String.raw`\begin{bmatrix}A & a\end{bmatrix}=`); await page.locator('#add-math-cell').click(); await page.setLatex(7, String.raw`\begin{bmatrix}A\\ a^{\mathrm{T}}\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ 2 \\ 3 \\ 4 \\ 5 \end{bmatrix}`); content = await page.textContent('#result-value-2'); expect(content).toBe(String.raw`\begin{bmatrix} 1 & 2 & 3 & 4 & 5 \end{bmatrix}`); content = await page.textContent('#result-value-3'); expect(content).toBe(String.raw`\begin{bmatrix} 1 & 2 & 5 & 6 \\ 3 & 4 & 7 & 8 \\ 9 & 10 & 13 & 14 \\ 11 & 12 & 15 & 16 \end{bmatrix}`); content = await page.textContent('#result-value-4'); expect(content).toBe(String.raw`\begin{bmatrix} 1 & 2 \\ 3 & 4 \\ 5 & 6 \\ 7 & 8 \end{bmatrix}`); content = await page.textContent('#result-value-5'); expect(content).toBe(String.raw`\begin{bmatrix} 9 & 10 & 13 & 14 \\ 11 & 12 & 15 & 16 \end{bmatrix}`); content = await page.textContent('#result-value-6'); expect(content).toBe(String.raw`\begin{bmatrix} 1 & 2 & 1 \\ 3 & 4 & 2 \end{bmatrix}`); content = await page.textContent('#result-value-7'); expect(content).toBe(String.raw`\begin{bmatrix} 1 & 2 \\ 3 & 4 \\ 1 & 2 \end{bmatrix}`); // check error for mismatched matrices await page.setLatex(7, String.raw`\begin{bmatrix}a & b\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=mismatched dimensions')).toBeVisible(); }); ================================================ FILE: tests/test_matrix_inverse.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Matrix inverse numeric', async () => { await page.setLatex(0, String.raw`\mathrm{inv}\left(\begin{bmatrix}2 & 3\\ 1 & 2\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 2 & -3 \\ -1 & 2 \end{bmatrix}`); }); test('Matrix inverse numeric with units', async () => { await page.setLatex(0, String.raw`\mathrm{inv}\left(\begin{bmatrix}2\left\lbrack m\right\rbrack & 3\left\lbrack m\right\rbrack\\ 1\left\lbrack m\right\rbrack & 2\left\lbrack m\right\rbrack\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 2\left\lbrack \frac{1}{m}\right\rbrack & -3\left\lbrack \frac{1}{m}\right\rbrack \\ -1\left\lbrack \frac{1}{m}\right\rbrack & 2\left\lbrack \frac{1}{m}\right\rbrack \end{bmatrix}`); }); test('Matrix exponent inverse numeric with units', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}2\left\lbrack m\right\rbrack & 3\left\lbrack m\right\rbrack\\ 1\left\lbrack m\right\rbrack & 2\left\lbrack m\right\rbrack\end{bmatrix}^{-1}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 2\left\lbrack \frac{1}{m}\right\rbrack & -3\left\lbrack \frac{1}{m}\right\rbrack \\ -1\left\lbrack \frac{1}{m}\right\rbrack & 2\left\lbrack \frac{1}{m}\right\rbrack \end{bmatrix}`); }); test('Matrix inverse with variable matrix', async () => { await page.setLatex(0, String.raw`A=\begin{bmatrix}2 & 3\\ 1 & 2\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`inv\left(A\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\begin{bmatrix} 2 & -3 \\ -1 & 2 \end{bmatrix}`); }); test('Matrix exponent inverse with variable matrix', async () => { await page.setLatex(0, String.raw`A=\begin{bmatrix}2 & 3\\ 1 & 2\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A^{-1}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\begin{bmatrix} 2 & -3 \\ -1 & 2 \end{bmatrix}`); }); test('Matrix inverse with mixed units', async () => { await page.setLatex(0, String.raw`\mathrm{inv}\left(\begin{bmatrix}2\left\lbrack m\right\rbrack & 3\left\lbrack s\right\rbrack\\ 1\left\lbrack m\right\rbrack & 2\left\lbrack s\right\rbrack\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 2\left\lbrack \frac{1}{m}\right\rbrack & -3\left\lbrack \frac{1}{m}\right\rbrack \\ -1\left\lbrack \frac{1}{s}\right\rbrack & 2\left\lbrack \frac{1}{s}\right\rbrack \end{bmatrix}`); }); test('Matrix inverse exponent with mixed units', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}2\left\lbrack m\right\rbrack & 3\left\lbrack s\right\rbrack\\ 1\left\lbrack m\right\rbrack & 2\left\lbrack s\right\rbrack\end{bmatrix}^{-1}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 2\left\lbrack \frac{1}{m}\right\rbrack & -3\left\lbrack \frac{1}{m}\right\rbrack \\ -1\left\lbrack \frac{1}{s}\right\rbrack & 2\left\lbrack \frac{1}{s}\right\rbrack \end{bmatrix}`); }); test('Matrix inverse with inconsistent units', async () => { await page.setLatex(0, String.raw`\mathrm{inv}\left(\begin{bmatrix}2\left\lbrack m\right\rbrack & 3\left\lbrack s\right\rbrack\\ 1\left\lbrack s\right\rbrack & 2\left\lbrack s\right\rbrack\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeAttached(); }); test('Matrix inverse exponent with inconsistent units', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}2\left\lbrack m\right\rbrack & 3\left\lbrack s\right\rbrack\\ 1\left\lbrack s\right\rbrack & 2\left\lbrack s\right\rbrack\end{bmatrix}^{-1}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeAttached(); }); test('Inverse for nonsquare matrix', async () => { await page.setLatex(0, String.raw`inv\left(\begin{bmatrix}1 & 2\\ 3 & 4\\ 5 & 6\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('.status-footer >> text=NonSquare')).toBeVisible(); }); test('Inverse for singular matrix', async () => { await page.setLatex(0, String.raw`\mathrm{inv}\left(\begin{bmatrix}1 & 1\\ 1 & 1\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('.status-footer >> text=NonInvertible')).toBeVisible(); }); test('Inverse of symbolic matrix', async () => { await page.setLatex(0, String.raw`\mathrm{inv}\left(\begin{bmatrix}a & b\\ c & d\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('\\begin{bmatrix} \\frac{d}{a \\cdot d - b \\cdot c} & - \\frac{b}{a \\cdot d - b \\cdot c} \\\\ - \\frac{c}{a \\cdot d - b \\cdot c} & \\frac{a}{a \\cdot d - b \\cdot c} \\end{bmatrix}'); }); test('Inverse of large matrix with units', async () => { await page.setLatex(0, String.raw`\left(\begin{bmatrix}1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack\end{bmatrix}\times\begin{bmatrix}1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 0\left\lbrack m\right\rbrack & 1\left\lbrack m\right\rbrack\end{bmatrix}^{-1}\right)^{-1}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 \end{bmatrix}`); }); test('Inverse mixed symbolic units', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}1 & 0\\ -k & k\end{bmatrix}^{-1}\times\begin{bmatrix}1\\ F_2\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 \\ \frac{F_2 + k}{k} \end{bmatrix}`); }); ================================================ FILE: tests/test_matrix_keyboard.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Matrix inverse keyboard entry', async () => { await page.locator('#cell-0 >> math-field.editable').type('1[m]*inv([2,2'); await page.locator('#cell-0 >> math-field.editable').press('Enter'); await page.locator('#cell-0 >> math-field.editable').type('2'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('3'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('1'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('2'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('@'); await page.locator('#cell-0 >> math-field.editable').type('[2,2'); await page.locator('#cell-0 >> math-field.editable').press('Enter'); await page.locator('#cell-0 >> math-field.editable').type('2[m]'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('-3[m]'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('-1[m]'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('2[m]'); await page.locator('#cell-0 >> math-field.editable').press('ArrowRight'); await page.locator('#cell-0 >> math-field.editable').type('^-1'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 & 0 \\ 0 & 1 \end{bmatrix}`); }); test('Matrix keyboard entry for two blank matrices', async () => { await page.locator('#cell-0 >> math-field.editable').type('([1,2]@[2,1])_1,1'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('='); await page.locator('#cell-0 >> math-field.editable').press('Enter'); await page.locator('#cell-0 >> math-field.editable').type('1'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('2'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('3'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('4'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(11, precision); }); test('Matrix virtual keyboard entry', async () => { await page.locator('button').filter({ hasText: '[A]' }).click(); await page.getByRole('button').filter({ hasText: '2×1' }).click(); await page.locator('#cell-0 >> math-field.editable').type('a'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('b'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.getByRole('button').filter({ hasText: 'ATAT' }).click(); await page.getByRole('button').filter({ hasText: '××' }).click(); await page.getByRole('button').filter({ hasText: 'M×N' }).click(); await page.getByRole('button', { name: 'Increment number' }).first().click(); await page.getByRole('button', { name: 'Insert', exact: true }).click(); await page.locator('#cell-0 >> math-field.editable').type('c'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('d'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('\\begin{bmatrix} a \\cdot c + b \\cdot d \\end{bmatrix}'); }); test('Matrix with more than 10 columns', async () => { await page.locator('#cell-0 >> math-field.editable').type('[1,11]'); await page.locator('#cell-0 >> math-field.editable').type('='); await page.locator('#cell-0 >> math-field.editable').press('Enter'); await page.locator('#cell-0 >> math-field.editable').type('a'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('b'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('c'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('d'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('e0'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('f'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('g'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('h'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('i0'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('j'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('k'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a & b & c & d & e0 & f & g & h & i0 & j & k \end{bmatrix}`); }); ================================================ FILE: tests/test_matrix_multiplication.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Square multiplication', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\end{bmatrix}\cdot\begin{bmatrix}5 & 6\\ 7 & 8\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('\\begin{bmatrix} 5 \\cdot a + 7 \\cdot b & 6 \\cdot a + 8 \\cdot b \\\\ 5 \\cdot c + 7 \\cdot d & 6 \\cdot c + 8 \\cdot d \\end{bmatrix}'); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a=1,b=2,c=3,d=4`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 19 & 22 \\ 43 & 50 \end{bmatrix}`); // swap order of multiplication, should not commute await page.setLatex(0, String.raw`\begin{bmatrix}5 & 6\\ 7 & 8\end{bmatrix}\cdot\begin{bmatrix}a & b\\ c & d\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 23 & 34 \\ 31 & 46 \end{bmatrix}`); }); test('Square multiplication with matrix multiplication operator', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\end{bmatrix}\times\begin{bmatrix}5 & 6\\ 7 & 8\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('\\begin{bmatrix} 5 \\cdot a + 7 \\cdot b & 6 \\cdot a + 8 \\cdot b \\\\ 5 \\cdot c + 7 \\cdot d & 6 \\cdot c + 8 \\cdot d \\end{bmatrix}'); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a=1,b=2,c=3,d=4`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 19 & 22 \\ 43 & 50 \end{bmatrix}`); // swap order of multiplication, should not commute await page.setLatex(0, String.raw`\begin{bmatrix}5 & 6\\ 7 & 8\end{bmatrix}\times\begin{bmatrix}a & b\\ c & d\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 23 & 34 \\ 31 & 46 \end{bmatrix}`); }); test('Square variable matrix times literal matrix using matrix multiplication operator', async () => { await page.setLatex(0, String.raw`A\times\begin{bmatrix}5 & 6\\ 7 & 8\end{bmatrix}=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('\\begin{bmatrix} 5 \\cdot a + 7 \\cdot b & 6 \\cdot a + 8 \\cdot b \\\\ 5 \\cdot c + 7 \\cdot d & 6 \\cdot c + 8 \\cdot d \\end{bmatrix}'); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`a=1,b=2,c=3,d=4`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 19 & 22 \\ 43 & 50 \end{bmatrix}`); // swap order of multiplication, should not commute await page.setLatex(0, String.raw`\begin{bmatrix}5 & 6\\ 7 & 8\end{bmatrix}\times A=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 23 & 34 \\ 31 & 46 \end{bmatrix}`); }); test('Square variable matrix times variable matrix using matrix multiplication operator', async () => { await page.setLatex(0, String.raw`A\times B=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`B=\begin{bmatrix}5 & 6\\ 7 & 8\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('\\begin{bmatrix} 5 \\cdot a + 7 \\cdot b & 6 \\cdot a + 8 \\cdot b \\\\ 5 \\cdot c + 7 \\cdot d & 6 \\cdot c + 8 \\cdot d \\end{bmatrix}'); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`a=1,b=2,c=3,d=4`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 19 & 22 \\ 43 & 50 \end{bmatrix}`); // swap order of multiplication, should not commute await page.setLatex(0, String.raw`B\times A=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 23 & 34 \\ 31 & 46 \end{bmatrix}`); }); test('Units with square multiplication', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\end{bmatrix}\cdot\begin{bmatrix}5\left\lbrack kg\right\rbrack & 6\left\lbrack kg\right\rbrack\\ 7\left\lbrack kg\right\rbrack & 8\left\lbrack kg\right\rbrack\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('\\begin{bmatrix} 5 \\cdot a + 7 \\cdot b & 6 \\cdot a + 8 \\cdot b \\\\ 5 \\cdot c + 7 \\cdot d & 6 \\cdot c + 8 \\cdot d \\end{bmatrix}'); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a=1\left\lbrack\frac{1}{m^3}\right\rbrack,b=2\left\lbrack\frac{1}{m^3}\right\rbrack,c=3\left\lbrack\frac{1}{m^3}\right\rbrack,d=4\left\lbrack\frac{1}{m^3}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 19\left\lbrack \frac{kg}{m^{3}}\right\rbrack & 22\left\lbrack \frac{kg}{m^{3}}\right\rbrack \\ 43\left\lbrack \frac{kg}{m^{3}}\right\rbrack & 50\left\lbrack \frac{kg}{m^{3}}\right\rbrack \end{bmatrix}`); }); test('Units with square variable matrix times variable matrix using matrix multiplication operator', async () => { await page.setLatex(0, String.raw`A\times B=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`B=\begin{bmatrix}5\left\lbrack kg\right\rbrack & 6\left\lbrack kg\right\rbrack\\ 7\left\lbrack kg\right\rbrack & 8\left\lbrack kg\right\rbrack\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('\\begin{bmatrix} 5 \\cdot a + 7 \\cdot b & 6 \\cdot a + 8 \\cdot b \\\\ 5 \\cdot c + 7 \\cdot d & 6 \\cdot c + 8 \\cdot d \\end{bmatrix}'); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`a=1\left\lbrack\frac{1}{m^3}\right\rbrack,b=2\left\lbrack\frac{1}{m^3}\right\rbrack,c=3\left\lbrack\frac{1}{m^3}\right\rbrack,d=4\left\lbrack\frac{1}{m^3}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 19\left\lbrack \frac{kg}{m^{3}}\right\rbrack & 22\left\lbrack \frac{kg}{m^{3}}\right\rbrack \\ 43\left\lbrack \frac{kg}{m^{3}}\right\rbrack & 50\left\lbrack \frac{kg}{m^{3}}\right\rbrack \end{bmatrix}`); // swap order of multiplication, should not commute await page.setLatex(0, String.raw`B\times A=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 23\left\lbrack \frac{kg}{m^{3}}\right\rbrack & 34\left\lbrack \frac{kg}{m^{3}}\right\rbrack \\ 31\left\lbrack \frac{kg}{m^{3}}\right\rbrack & 46\left\lbrack \frac{kg}{m^{3}}\right\rbrack \end{bmatrix}`); }); test('Mixed compatible units with square variable matrix times variable matrix using matrix multiplication operator', async () => { await page.setLatex(0, String.raw`A\times B=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`B=\begin{bmatrix}5\left\lbrack kg\right\rbrack & 6\left\lbrack kg\right\rbrack\\ 7\left\lbrack kg\right\rbrack & 8\left\lbrack kg\right\rbrack\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('\\begin{bmatrix} 5 \\cdot a + 7 \\cdot b & 6 \\cdot a + 8 \\cdot b \\\\ 5 \\cdot c + 7 \\cdot d & 6 \\cdot c + 8 \\cdot d \\end{bmatrix}'); // add some numbers for variables that define first matrix await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`a=1\left\lbrack\frac{1}{m^3}\right\rbrack,b=2\left\lbrack\frac{1}{m^3}\right\rbrack,c=3\left\lbrack\frac{1}{m^3}\right\rbrack,d=4\left\lbrack\frac{1}{m^3}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 19\left\lbrack \frac{kg}{m^{3}}\right\rbrack & 22\left\lbrack \frac{kg}{m^{3}}\right\rbrack \\ 43\left\lbrack \frac{kg}{m^{3}}\right\rbrack & 50\left\lbrack \frac{kg}{m^{3}}\right\rbrack \end{bmatrix}`); // swap order of multiplication, should not commute await page.setLatex(0, String.raw`B\times A=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 23\left\lbrack \frac{kg}{m^{3}}\right\rbrack & 34\left\lbrack \frac{kg}{m^{3}}\right\rbrack \\ 31\left\lbrack \frac{kg}{m^{3}}\right\rbrack & 46\left\lbrack \frac{kg}{m^{3}}\right\rbrack \end{bmatrix}`); }); test('Incompatible units with square variable matrix times variable matrix using matrix multiplication operator', async () => { await page.setLatex(0, String.raw`A\times B=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`B=\begin{bmatrix}5\left\lbrack kg\right\rbrack & 6\left\lbrack kg\right\rbrack\\ 7\left\lbrack kg\right\rbrack & 8\left\lbrack kg\right\rbrack\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`a=1\left\lbrack\frac{1}{m^3}\right\rbrack,b=2\left\lbrack\frac{1}{m^3}\right\rbrack,c=3\left\lbrack\frac{1}{m^3}\right\rbrack,d=4\left\lbrack\frac{1}{m^2}\right\rbrack`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeAttached(); }); test('Incompatible multiplication with matrix variables and matrix multiplication operator', async () => { await page.setLatex(0, String.raw`A\times B=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}a & b\\ c & d\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`B=\begin{bmatrix}e_0\\ f\\ g\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('.status-footer >> text=ShapeError')).toBeVisible(); }); test('Incompatible multiplication with matrix literals', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\end{bmatrix}\cdot\begin{bmatrix}e_0\\ f\\ g\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('.status-footer >> text=ShapeError')).toBeVisible(); }); test('Incompatible multiplication with matrix literals and matrix multiplication operator', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a & b\\ c & d\end{bmatrix}\times\begin{bmatrix}e_0\\ f\\ g\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('.status-footer >> text=ShapeError')).toBeVisible(); }); test('Scalar literal times matrix literal', async () => { await page.setLatex(0, String.raw`5\cdot\begin{bmatrix}1 & 2\\ 3 & 4\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 5 & 10 \\ 15 & 20 \end{bmatrix}`); // change order of scalar-matrix multiplication, should commute await page.setLatex(0, String.raw`\begin{bmatrix}1 & 2\\ 3 & 4\end{bmatrix}\cdot 5=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 5 & 10 \\ 15 & 20 \end{bmatrix}`); }); test('Units with scalar literal times matrix literal', async () => { await page.setLatex(0, String.raw`5\left\lbrack s\right\rbrack\cdot\begin{bmatrix}1\left\lbrack m\right\rbrack & 2\left\lbrack kg\right\rbrack\\ 3\left\lbrack radian\right\rbrack & 4\left\lbrack m^2\right\rbrack\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 5\left\lbrack m\cdot s\right\rbrack & 10\left\lbrack kg\cdot s\right\rbrack \\ 15\left\lbrack s\cdot rad\right\rbrack & 20\left\lbrack m^{2}\cdot s\right\rbrack \end{bmatrix}`); // change order of scalar-matrix multiplication, should commute await page.setLatex(0, String.raw`\begin{bmatrix}1\left\lbrack m\right\rbrack & 2\left\lbrack kg\right\rbrack\\ 3\left\lbrack radian\right\rbrack & 4\left\lbrack m^2\right\rbrack\end{bmatrix}\cdot 5\left\lbrack s\right\rbrack=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 5\left\lbrack m\cdot s\right\rbrack & 10\left\lbrack kg\cdot s\right\rbrack \\ 15\left\lbrack s\cdot rad\right\rbrack & 20\left\lbrack m^{2}\cdot s\right\rbrack \end{bmatrix}`); }); test('Variable scalar times variable matrix', async () => { await page.setLatex(0, String.raw`a\cdot A=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`a=5\left\lbrack s\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`A=\begin{bmatrix}1\left\lbrack m\right\rbrack & 2\left\lbrack kg\right\rbrack\\ 3\left\lbrack radian\right\rbrack & 4\left\lbrack m^2\right\rbrack\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 5\left\lbrack m\cdot s\right\rbrack & 10\left\lbrack kg\cdot s\right\rbrack \\ 15\left\lbrack s\cdot rad\right\rbrack & 20\left\lbrack m^{2}\cdot s\right\rbrack \end{bmatrix}`); // change order of scalar-matrix multiplication, should commute await page.setLatex(0, String.raw`A\cdot a=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 5\left\lbrack m\cdot s\right\rbrack & 10\left\lbrack kg\cdot s\right\rbrack \\ 15\left\lbrack s\cdot rad\right\rbrack & 20\left\lbrack m^{2}\cdot s\right\rbrack \end{bmatrix}`); }); test('Cross product with column vectors and variable entries', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a1\\ a2\\ a3\end{bmatrix}\times\begin{bmatrix}b1\\ b2\\ b3\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a2 \cdot b3 - a3 \cdot b2 \\ - a1 \cdot b3 + a3 \cdot b1 \\ a1 \cdot b2 - a2 \cdot b1 \end{bmatrix}`); }); test('Cross product with column vectors and numeric entries', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}1\\ 2\\ 3\end{bmatrix}\times\begin{bmatrix}4\\ 5\\ 6\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} -3 \\ 6 \\ -3 \end{bmatrix}`); }); test('Cross product with column vectors and numeric entries and units', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}1\left\lbrack m\right\rbrack\\ 2\left\lbrack kg\right\rbrack\\ 3\left\lbrack sec\right\rbrack\end{bmatrix}\times\begin{bmatrix}4\left\lbrack m\right\rbrack\\ 5\left\lbrack kg\right\rbrack\\ 6\left\lbrack sec\right\rbrack\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} -3\left\lbrack kg\cdot s\right\rbrack \\ 6\left\lbrack m\cdot s\right\rbrack \\ -3\left\lbrack kg\cdot m\right\rbrack \end{bmatrix}`); }); test('Cross product with column vectors and numeric entries and incompatible units', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}1\left\lbrack m\right\rbrack\\ 2\left\lbrack kg\right\rbrack\\ 3\left\lbrack sec\right\rbrack\end{bmatrix}\times\begin{bmatrix}4\left\lbrack m\right\rbrack\\ 5\left\lbrack kg\right\rbrack\\ 6\left\lbrack m\right\rbrack\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=Dimension Error')).toBeAttached(); }); test('Cross product with row vectors and symbolic values', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a1 & a2 & a3\end{bmatrix}\times\begin{bmatrix}b1 & b2 & b3\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a2 \cdot b3 - a3 \cdot b2 & - a1 \cdot b3 + a3 \cdot b1 & a1 \cdot b2 - a2 \cdot b1 \end{bmatrix}`); }); test('Cross product unit cancellation bug #240', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}1\left\lbrack N\right\rbrack\\ 0\left\lbrack N\right\rbrack\\ 0\left\lbrack N\right\rbrack\end{bmatrix}\times\begin{bmatrix}0\left\lbrack m\right\rbrack\\ 1\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0\left\lbrack J\right\rbrack \\ 0\left\lbrack J\right\rbrack \\ 1\left\lbrack J\right\rbrack \end{bmatrix}`); }); test('Cross product unit cancellation bug #240 with row vectors', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}1\left\lbrack s\right\rbrack\\ 0\left\lbrack s\right\rbrack\\ 0\left\lbrack s\right\rbrack\end{bmatrix}^{\mathrm{T}}\times\begin{bmatrix}0\left\lbrack m\right\rbrack\\ 1\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack\end{bmatrix}^{\mathrm{T}}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 0\left\lbrack m\cdot s\right\rbrack & 0\left\lbrack m\cdot s\right\rbrack & 1\left\lbrack m\cdot s\right\rbrack \end{bmatrix}`); }); test('Cross product with variable column vectors', async () => { await page.setLatex(0, String.raw`v1\times v2=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`v1\:=\:\begin{bmatrix}a1\\ a2\\ a3\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`v2\:=\:\begin{bmatrix}b1\\ b2\\ b3\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} a2 \cdot b3 - a3 \cdot b2 \\ - a1 \cdot b3 + a3 \cdot b1 \\ a1 \cdot b2 - a2 \cdot b1 \end{bmatrix}`); }); test('Dot product with column vectors and symbolic entries', async () => { await page.setLatex(0, String.raw`\mathrm{dot}\left(\begin{bmatrix}a1\\ a2\\ a3\end{bmatrix},\begin{bmatrix}b1\\ b2\\ b3\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`a1 \cdot b1 + a2 \cdot b2 + a3 \cdot b3`); }); test('Dot product with variable column vectors', async () => { await page.setLatex(0, String.raw`\mathrm{dot}\left(v1,v2\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{dot}\left(v1^{\mathrm{T}},v2\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\mathrm{dot}\left(v1,v2^{\mathrm{T}}\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\mathrm{dot}\left(v1^{\mathrm{T}},v2^{\mathrm{T}}\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`v1\:=\:\begin{bmatrix}a1\\ a2\\ a3\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(5, String.raw`v2\:=\:\begin{bmatrix}b1\\ b2\\ b3\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`a1 \cdot b1 + a2 \cdot b2 + a3 \cdot b3`); content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`a1 \cdot b1 + a2 \cdot b2 + a3 \cdot b3`); content = await page.textContent(`#result-value-2`); expect(content).toBe(String.raw`a1 \cdot b1 + a2 \cdot b2 + a3 \cdot b3`); }); test('Dot product with incompatible matrix dimensions', async () => { await page.setLatex(0, String.raw`\mathrm{dot}\left(\begin{bmatrix}a1\\ a2\\ a3\end{bmatrix},\begin{bmatrix}b1\\ b2\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('text=Dimensions incorrect for dot product')).toBeVisible(); }); test('Dot product with column vectors and numeric entries', async () => { await page.setLatex(0, String.raw`\mathrm{dot}\left(\begin{bmatrix}1\\ 2\\ 3\end{bmatrix},\begin{bmatrix}4\\ 5\\ 6\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(32, precision); }); test('Dot product with column vectors and numeric entries with units', async () => { await page.setLatex(0, String.raw`\mathrm{dot}\left(\begin{bmatrix}1\left\lbrack m\right\rbrack\\ 2\left\lbrack m\right\rbrack\\ 3\left\lbrack m\right\rbrack\end{bmatrix},\begin{bmatrix}4\left\lbrack m\right\rbrack\\ 5\left\lbrack m\right\rbrack\\ 6\left\lbrack m\right\rbrack\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(32, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^2'); }); test('Matrix multiplication with cdot multiplication symbol case 1', async () => { await page.setLatex(0, String.raw`A=\begin{bmatrix}1\\ 2\end{bmatrix},\:B=\begin{bmatrix}3 & 4\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A\cdot B=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`\begin{bmatrix} 3 & 4 \\ 6 & 8 \end{bmatrix}`); }); test('Matrix multiplication with cdot multiplication symbol case 2', async () => { await page.setLatex(0, String.raw`C=\begin{bmatrix}1 & 2\end{bmatrix},\:D=\begin{bmatrix}3\\ 4\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`C\cdot D=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`\begin{bmatrix} 11 \end{bmatrix}`); }); test('Matrix multiplication passed as argument to function', async () => { await page.setLatex(0, String.raw`A=\begin{bmatrix}1\\ 2\end{bmatrix},\:B=\begin{bmatrix}3 & 4\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{count}\left(A\times B\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\mathrm{sum}\left(A\times B\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); content = await page.textContent(`#result-value-2`); expect(parseLatexFloat(content)).toBeCloseTo(21, precision); content = await page.textContent('#result-units-2'); expect(content).toBe(''); }); test('Matrix multiplication with cdot symbol passed as argument to function', async () => { await page.setLatex(0, String.raw`A=\begin{bmatrix}1\\ 2\end{bmatrix},\:B=\begin{bmatrix}3 & 4\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\mathrm{count}\left(A\cdot B\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\mathrm{sum}\left(A\cdot B\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-1`); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); content = await page.textContent(`#result-value-2`); expect(parseLatexFloat(content)).toBeCloseTo(21, precision); content = await page.textContent('#result-units-2'); expect(content).toBe(''); }); test('Symbolic matrix multiplication', async () => { await page.setLatex(0, String.raw`A\times B=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`A \cdot B`); }); test('Matrix multiplication with matrix and non-matrix symbol', async () => { await page.setLatex(0, String.raw`A=\begin{bmatrix}a\\ b\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A\times B=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`\begin{bmatrix} B \cdot a \\ B \cdot b \end{bmatrix}`); }); test('Preserve units when vector with zero entries multiplied by scalar with units', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}0\\ 1\end{bmatrix}\cdot1\left\lbrack N\right\rbrack=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 0\left\lbrack N\right\rbrack \\ 1\left\lbrack N\right\rbrack \end{bmatrix}`); }); test('Preserve units when vector with zero entries multiplied by vector with units', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}0\\ 1\end{bmatrix}\cdot\begin{bmatrix}1\left\lbrack N\right\rbrack & 2\left\lbrack N\right\rbrack\end{bmatrix}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\begin{bmatrix} 0\left\lbrack N\right\rbrack & 0\left\lbrack N\right\rbrack \\ 1\left\lbrack N\right\rbrack & 2\left\lbrack N\right\rbrack \end{bmatrix}`); }); ================================================ FILE: tests/test_matrix_transpose.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Matrix transpose numeric using function', async () => { await page.setLatex(0, String.raw`\mathrm{transpose}\left(\begin{bmatrix}1 & 2\\ 3 & 4\end{bmatrix}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1 & 3 \\ 2 & 4 \end{bmatrix}`); }); test('Matrix tranpose with units using transpose notation', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}1\left\lbrack m\right\rbrack & 2\left\lbrack m\right\rbrack\\ 3\left\lbrack m\right\rbrack & 4\left\lbrack m\right\rbrack\end{bmatrix}^{\mathrm{T}}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1\left\lbrack m\right\rbrack & 3\left\lbrack m\right\rbrack \\ 2\left\lbrack m\right\rbrack & 4\left\lbrack m\right\rbrack \end{bmatrix}`); }); test('Matrix transpose with mixed units', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}1\left\lbrack m\right\rbrack & 2\left\lbrack m^2\right\rbrack\\ 3\left\lbrack m^3\right\rbrack & 4\left\lbrack m^4\right\rbrack\end{bmatrix}^{\mathrm{T}}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\begin{bmatrix} 1\left\lbrack m\right\rbrack & 3\left\lbrack m^3\right\rbrack \\ 2\left\lbrack m^2\right\rbrack & 4\left\lbrack m^{4}\right\rbrack \end{bmatrix}`); }); test('Matrix transpose with variable matrix and using keyboard shortcut', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.setLatex(0, String.raw`A=\begin{bmatrix}1 & 2\\ 3 & 4\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.locator('#cell-1 >> math-field.editable').type("A"); await page.locator('#cell-1 >> math-field.editable').press(modifierKey + "+'"); await page.locator('#cell-1 >> math-field.editable').type("="); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-1`); expect(content).toBe(String.raw`\begin{bmatrix} 1 & 3 \\ 2 & 4 \end{bmatrix}`); }); test('Column and row matrix transpose', async () => { await page.setLatex(0, String.raw`\begin{bmatrix}a\\ b\end{bmatrix}^{\mathrm{T}}\times\begin{bmatrix}c & d\end{bmatrix}^{\mathrm{T}}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('\\begin{bmatrix} a \\cdot c + b \\cdot d \\end{bmatrix}'); }); ================================================ FILE: tests/test_md_export.epxyz ================================================ {"data":{"version":20250705,"config":{"mathCellConfig":{"symbolicOutput":false,"showIntermediateResults":false,"formatOptions":{"notation":"auto","precision":15,"lowerExp":-3,"upperExp":5}},"customBaseUnits":{"mass":"kg","length":"m","time":"s","current":"A","temperature":"K","luminous_intensity":"cd","amount_of_substance":"mol","force":"N","area":"m^2","volume":"m^3","energy":"J","power":"W","pressure":"Pa","charge":"C","capacitance":"F","electric_potential":"V","resistance":"ohm","inductance":"H","conductance":"S","magnetic_flux":"Wb","magnetic_flux_density":"T","angle":"rad","information":"b"},"simplifySymbolicExpressions":true,"convertFloatsToFractions":true,"fluidConfig":{"fluid":"Water","incompMixConc":0.5,"customMixture":[{"fluid":"R32","moleFraction":0.697615},{"fluid":"R125","moleFraction":0.302385}]}},"cells":[{"type":"math","id":0,"latex":"x=20\\left\\lbrack m\\right\\rbrack","config":null},{"type":"documentation","id":2,"json":{"ops":[{"insert":"Documentation cell with line of text followed by a scaled image:\n"},{"attributes":{"width":"139"},"insert":{"image":"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAVCAYAAACzK0UYAAAC9klEQVRIS91VTSi7cRz/PFsx2c3sMM3bQXm72cphmry0iZIlB5ILNaXIaTkwudBqJXkpB1bGYYUiOTmYSFmSFMrB2iZzoSk57LHvr/zs2fbsH8f/9/b7vn2e7+f78gj5+fkisojRaERxcTFKS0uRl5eHUCgEr9eLj4+PbGESmyAHMjY2hpGREWi12rRkr6+vmJ+fx+zsbEagxcVF9Pf3c1saiCAIWF1dRU9Pzz+/dHp6GnNzc2l+Z2dnqKmpkQdxu90YHByUBL69veH+/h7V1dVQqVTcJooiWltbcXp6ynU5OTl4eXmBQqFgOqpaUonNZsP6+joPeH9/h91ux/b2NighJZiZmcHw8DD3of4MDQ3xt9lsxt7enrQntbW14sPDA4im6+trlJSUcIfx8XGsrKxIApRKJW5ublBUVMT00WgUZWVlkhin0ykFSXAvEnJzczN2dna4kaZHp9Ph8/MzjfPd3V00NTVxfUVFBcLhMHsTE8RIsgiJUsWNjQ1Gw+joKLcFg0E2qpmko6MDVVVV3NTQ0IBAIMDeV1dXKC8v57bNzU0Ivb29IlWQ+nUZs8soCfDx8RFqtRpPT08Sr87OTgiNjY3i+fk5jo6OYDAYfpOb+RKdGo0G8XgcFosFPp9PQnlhYeHPdB0cHMBkMnEH4vXw8PBXoBMTE3A4HDzm+PgYVqv1B2R5eRl9fX3cgfpDS5kqNFWxWIzNf6pQFVTNt7hcLkxNTf2ADAwMYGFhgTtcXFwgQSWj4Vtyc3Ph9/tRWVnJenB5eYnJyUm2qCS0CslnKNFv1mu+jLRod3d3jN9voT7R1NFe0ARRdfX19dxOm97S0sLedETJL1noY2hKJRvf1taGra0tfhKyNSQSiaC9vR23t7fMraurCx6Ph4c8Pz/zUU47kHQWlpaWoNfrZTH29/fZKUnuS+qe0SB1d3ezHBlPPR1BooZGmra5oKAA1KOTkxPQ4hIFqUIgdXV1XE2MrK2tyYNko+kvNtmf1l+SycX8PyBfZ7U2YFncQMIAAAAASUVORK5CYII="}},{"insert":"\nSentence with formula "},{"insert":{"formula":"\\sqrt{\\Omega}"}},{"insert":" in the middle, followed by equation on its own line:\n"},{"insert":{"formula":"E=\\frac{My}{I}"}},{"insert":"\nWith text after.\nLine of text.\nAnother line of text.\n\n"}]}},{"type":"table","id":3,"rowLabels":["Option 1","Option 2"],"nextRowLabelId":3,"parameterLatexs":["l_1","l_2"],"nextParameterId":3,"parameterUnitLatexs":["\\left\\lbrack mm\\right\\rbrack",""],"rhsLatexs":[["1","2"],["3","4"]],"selectedRow":1,"hideUnselected":false,"rowJsons":[{"ops":[{"insert":{"image":"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAC8AAAAlCAYAAADSvLDKAAADoklEQVRYR9WYX0hTURzHv3duzrnNAmFvwcAHK/IlIpMkISoW9FCLFCN6MOxlGVqQyCgLhylUD1ov0fZgUSI+9Ic9pCyCFCMRMuZTJJgQcz05/+buubdzpVXunkvznp3A+zQY97fP+e73/Z3f7yc5nU4VW/SReOF9BQRdrgJhx3+3RtC0wo7PDX/NJuNssVUYfHhZRm+aHZ8b/pGDYF+hOOWvLhDEFAHKS1TvsRIVRZL2ScxzaF5FCuz4XMrvkhQ8K7GIoaZRvxMFRxeN43PBn6RmvWlg1ugqwTeFr5DNKhJeEuOU5IK/bpdxuohtpmMpFUlVXDppfzcX/NNigt02vTLzVPGaBbHgXPAa8ntqVhvDrG9+EFxZFVeBMiYzrfx+ieBhCRuwl9bmsEFtzoe7Z2ZmUFpaaj5t6m0ErcVs+ECKYFQVo3x5eTkmJibWNTCtfMhOcKJID6ioKipTQNqgNvMqX1tbi0gkwgf/3KnAa9XX4CStzbeW+ErkV3rwWZVd37u7uxEIBMzD26BifJu4atK5JGNAZpfg4eFhVFVVmYevpma9b2BW3rTQ3m9cUDCu6JWXaGVLJpNwOBzm4RtoJ3lZUCeZpp45kJJAGCpUVlYiFov9/saUYe9Qsx5hmDUfqsfTCs4ts/O9oaEBPT09fPBDbgUei5iGbGBFRucaO981cO0Api+p7dSsbw3MOkSbsRdrfPp/gQUJg55obGwMFRUV5uEPWwjuudkXUHBRRpSImarsdjvm5uZgtf6Jv+mcb6JmvWBgVt+8ggRVTsRTU1ODaDS6IfSm4R/Qse8gY+z71+DAe6CWlhZ0dHTwwY+4Vbgs+gvqNe0kWwV2kuFwGHV1debhd9Cx75XB2NdFb8V+g1uRV3Xt/cnJSZSVlZmHP26RcdvNNuT5lIJPBv0IL7zL5UIikdCF2VTOtxbKqHfo4Zfo5FRNJye+dsz4iD6fD4ODg3zwEWrWvQyzjtCt1iWDrRav6tr7wWAQbW1t5uH/x45Go2tfpBdd1sZAU11TP/vJOW32ULM+EbijyYCdod75nOWd6elpeDwe8/CnrATtTjGjXYZq9VdH+Tel1+tFPB5nZl/Oyt+gnaRfUCeZIfuQJri4vFEgv9+Pvr4+HbyiKLnPsP10R7OTsaPJhyEzMR7TrcPdrK1DKBRCc3Oz7me0up+z8o1WGYXiJr91uFHZgo9Z+a4N3NrGIPuZmprKHT6fCucrVs7K5+sH8xlnS8P/BM/nRvyQkecRAAAAAElFTkSuQmCC"}},{"insert":"\n"}]},{"ops":[{"insert":{"image":"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACYAAAApCAYAAABZa1t7AAAEi0lEQVRYR92Yb0hkVRjGnzsz/ttplSKEQjIXNlBQt0Bs0Tb9ICUksojWUv75kizafsmGkiFyW6EBRWpFBxEqhYQtnQ0ixYKEGpp2/JB+UPuQSBlSieiuuTuz3nNv753dornnnJnrzF1YujCM3HvOe5553t95z3tV3G63jvvwUv7Xwt7MVHEux5Wy7z+pDD+rwKoGfKsq+E13wBbHPspheDLTmbIw88SrEZa+MIWihnN1ZCjGX/ZdaTt2StHwca7DPkV3I6UtrMml4m136nzJflHawt7JYjibLebrwj6DJilGTsr8004dL9DcXAePQdrCPnVreMLFp3JD1XD2IHmKc6Hj/RwNT5k2T1rCMijoYp4Y+i8ilOKotRSfIE4DJk7TEnbaweA/Lk7jewcqrqjWhBmcLeXF0xYnbGRkBO3t7RyPHR0dmJ6e5u63Evg9EvA7bzCEdWu1LYucv2ZyXunr69MHBgZii4bDYZSUlHACysvLsb6+zt33ZTM8nyVe/NR16xXkGXJ+2OS8otPV39+P0dFRbG1tcdG2t7dRVFQkXGWWwH9UAP7aIcO5m9bcMgL76eQ4bYbfEEYXhoaG0NPTwwmYn59HU1MTdz+H7A9JwA8Q+O9aBP9lwsEjwCHmWCLTfT4fDEfN1xmy/7IE/IsHDFfVxI4V0E58NVNDY7Z4gyQV1tzcjLm5OU7Y+QwV54+Jg16iHfk7U+CiSvKQQ8cj9P1PUXmMKutJ+pwQIPDfRZTl5WW9rKxMalpBQQH29va45x8QF8/a2FGYF1C8Xm8MftG1sbGB0tJS4bOF4zoeFBwl1veifGTAaHvq6+v12dlZ4aiZmRlhXcuHhq/ykh83qYi8covBd9sJpaqqSg8Gg8IYVOMwODjIPasj8Ack4KcixpgTvM3wSRQIaXc2TULHGhoasLCwwK31BoH/igT8ZML+ZBp+ZTpuUC1YU3WsaQquaQ4c/rs97kRQWltb9cnJSS6epmnIz89HJBLhno0fY6jI4MvBHvU4Nfv2dLIKnY96V1cXt/jKygoqKyuFBvxArXS2oJX+jtJx4Zb1ip/IXWV1dVUvLi7mxkxMTKC7u5u7f5IK42eSVnr8poqRQ+sdRUJhsspvHE9jY2Pc3EYnw8UHxK68/hfDN8wmx2TC6urqEAqFOGHeLBXNkmPkzHWC2gRxss0gey48kqLRaAx8xhg3b4o6ihLBcfIHbZbn9u2rbUJhi4uLqK2t5UQZSTLAF71Dfk3V2hO1J42xciFKpd/vh8fj4YRVKAzjueLFLxP4H9oEvlRYZ2cnpqamOGEvUe/0lqSVfo1a6aDFVtoKd0LHqqursbS0xM2/ROA3SMCvIPDN1duKAMvw7+zsoLCwUDj+cwL/cQH4v9A7ZKOFd8ijCOUcMzqNlpYWLkaid8gvCXyvjeALGevt7cXw8DAn7GFFx4suvnwYA3+kbvX7u13BUVw5UuWX8WXXglbjxKVyc3MTonPTajA7x8UJM85G0SucnQtajRUn7H5JYxz8gUAAbW1tVn/QPR8Xc2x3dxc1NTXC/0/ccwWSBf4Gg63OkRmTeQEAAAAASUVORK5CYII="}},{"insert":"\n"}]}]},{"type":"math","id":9,"latex":"l_2=","config":null},{"type":"math","id":10,"latex":"l_1=\\left\\lbrack m\\right\\rbrack","config":null},{"type":"dataTable","id":4,"parameterLatexs":["Col1","Col2"],"nextParameterId":3,"nextInterpolationDefId":1,"nextPolyfitDefId":1,"parameterUnitLatexs":["","\\left\\lbrack m\\right\\rbrack"],"columnData":[["6","8"],["7","9"]],"columnIds":[0,1],"interpolationDefinitions":[]},{"type":"piecewise","id":5,"parameterLatex":"y","expressionLatexs":["10","2"],"conditionLatexs":["x>20"]},{"type":"system","id":6,"parameterListLatex":"s,t","expressionLatexs":["1\\cdot s+2\\cdot t=10","2\\cdot s-4\\cdot t^2=20"],"selectedSolution":1},{"type":"table","id":11,"rowLabels":["Roller Thrust Bearing","Plain Thrust Bearing (lubricated metal on metal)"],"nextRowLabelId":3,"parameterLatexs":["\\mu_{c}"],"nextParameterId":3,"parameterUnitLatexs":[""],"rhsLatexs":[["0.01"],["0.15"]],"selectedRow":0,"hideUnselected":false,"rowJsons":[]}],"title":"MD Export Test","results":[{"value":"","symbolicValue":"","units":"","unitsLatex":"","numeric":false,"customUnitsDefined":false,"customUnits":"","customUnitsLatex":"","real":false,"finite":false,"isSubResult":false,"subQueryName":""},null,null,{"value":"4.000000000000000000000000000000000000000000000000000000000000000","symbolicValue":"4","numeric":true,"units":"","unitsLatex":"","real":true,"finite":true,"customUnitsDefined":false,"customUnits":"","customUnitsLatex":"","isSubResult":false,"subQueryName":"l_2_as_variable"},{"value":"0.003000000000000000000000000000000000000000000000000000000000000000","symbolicValue":"\\frac{3}{1000}","numeric":true,"units":"m","unitsLatex":"\\left\\lbrack m\\right\\rbrack ","real":true,"finite":true,"customUnitsDefined":false,"customUnits":"m","customUnitsLatex":"\\left\\lbrack m\\right\\rbrack ","isSubResult":false,"subQueryName":"l_1_as_variable"},{"value":"","symbolicValue":"","units":"","unitsLatex":"","numeric":false,"customUnitsDefined":false,"customUnits":"","customUnitsLatex":"","real":false,"finite":false,"isSubResult":false,"subQueryName":""},null,null,null],"system_results":[null,null,null,null,null,null,null,{"error":null,"solutions":{"s":["10","12"],"t":["0","-1"]},"selectedSolution":1},null],"codeCellResults":{},"sub_results":[],"nextId":12,"sheetId":"84adbc70-42dd-4d95-90eb-17907f7e0bc3","insertedSheets":[{"title":"Lead Screw Torque and Efficiency Calculations","url":"file","insertion":"2025-07-07T15:30:20.010Z"}]},"history":[{"url":"MD Export Test","hash":"file","creation":"2025-07-07T15:31:17.440Z"},{"url":"MD Export Test","hash":"file","creation":"2025-02-07T02:04:25.383Z"},{"url":"MD Export Test","hash":"file","creation":"2025-02-06T21:00:55.327Z"},{"url":"New Sheet","hash":"file","creation":"2025-02-05T21:51:30.256Z"},{"url":"https://svelte5.engineeringpaper.pages.dev/aCnRVQoyZmPoxT3bYUNHr7","hash":"aCnRVQoyZmPoxT3bYUNHr7","creation":"2025-02-05T21:40:52.725Z"}]} ================================================ FILE: tests/test_md_export_reference.md ================================================ # MD Export Test $x=20\left\lbrack m\right\rbrack$ Documentation cell with line of text followed by a scaled image: ![image alt text test](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAVCAYAAACzK0UYAAAC9klEQVRIS91VTSi7cRz/PFsx2c3sMM3bQXm72cphmry0iZIlB5ILNaXIaTkwudBqJXkpB1bGYYUiOTmYSFmSFMrB2iZzoSk57LHvr/zs2fbsH8f/9/b7vn2e7+f78gj5+fkisojRaERxcTFKS0uRl5eHUCgEr9eLj4+PbGESmyAHMjY2hpGREWi12rRkr6+vmJ+fx+zsbEagxcVF9Pf3c1saiCAIWF1dRU9Pzz+/dHp6GnNzc2l+Z2dnqKmpkQdxu90YHByUBL69veH+/h7V1dVQqVTcJooiWltbcXp6ynU5OTl4eXmBQqFgOqpaUonNZsP6+joPeH9/h91ux/b2NighJZiZmcHw8DD3of4MDQ3xt9lsxt7enrQntbW14sPDA4im6+trlJSUcIfx8XGsrKxIApRKJW5ublBUVMT00WgUZWVlkhin0ykFSXAvEnJzczN2dna4kaZHp9Ph8/MzjfPd3V00NTVxfUVFBcLhMHsTE8RIsgiJUsWNjQ1Gw+joKLcFg0E2qpmko6MDVVVV3NTQ0IBAIMDeV1dXKC8v57bNzU0Ivb29IlWQ+nUZs8soCfDx8RFqtRpPT08Sr87OTgiNjY3i+fk5jo6OYDAYfpOb+RKdGo0G8XgcFosFPp9PQnlhYeHPdB0cHMBkMnEH4vXw8PBXoBMTE3A4HDzm+PgYVqv1B2R5eRl9fX3cgfpDS5kqNFWxWIzNf6pQFVTNt7hcLkxNTf2ADAwMYGFhgTtcXFwgQSWj4Vtyc3Ph9/tRWVnJenB5eYnJyUm2qCS0CslnKNFv1mu+jLRod3d3jN9voT7R1NFe0ARRdfX19dxOm97S0sLedETJL1noY2hKJRvf1taGra0tfhKyNSQSiaC9vR23t7fMraurCx6Ph4c8Pz/zUU47kHQWlpaWoNfrZTH29/fZKUnuS+qe0SB1d3ezHBlPPR1BooZGmra5oKAA1KOTkxPQ4hIFqUIgdXV1XE2MrK2tyYNko+kvNtmf1l+SycX8PyBfZ7U2YFncQMIAAAAASUVORK5CYII=){width="139px"} Sentence with formula $\sqrt{\Omega}$ in the middle, followed by equation on its own line: $E=\frac{My}{I}$ With text after. Line of text. Another line of text. ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACYAAAApCAYAAABZa1t7AAAEi0lEQVRYR92Yb0hkVRjGnzsz/ttplSKEQjIXNlBQt0Bs0Tb9ICUksojWUv75kizafsmGkiFyW6EBRWpFBxEqhYQtnQ0ixYKEGpp2/JB+UPuQSBlSieiuuTuz3nNv753dornnnJnrzF1YujCM3HvOe5553t95z3tV3G63jvvwUv7Xwt7MVHEux5Wy7z+pDD+rwKoGfKsq+E13wBbHPspheDLTmbIw88SrEZa+MIWihnN1ZCjGX/ZdaTt2StHwca7DPkV3I6UtrMml4m136nzJflHawt7JYjibLebrwj6DJilGTsr8004dL9DcXAePQdrCPnVreMLFp3JD1XD2IHmKc6Hj/RwNT5k2T1rCMijoYp4Y+i8ilOKotRSfIE4DJk7TEnbaweA/Lk7jewcqrqjWhBmcLeXF0xYnbGRkBO3t7RyPHR0dmJ6e5u63Evg9EvA7bzCEdWu1LYucv2ZyXunr69MHBgZii4bDYZSUlHACysvLsb6+zt33ZTM8nyVe/NR16xXkGXJ+2OS8otPV39+P0dFRbG1tcdG2t7dRVFQkXGWWwH9UAP7aIcO5m9bcMgL76eQ4bYbfEEYXhoaG0NPTwwmYn59HU1MTdz+H7A9JwA8Q+O9aBP9lwsEjwCHmWCLTfT4fDEfN1xmy/7IE/IsHDFfVxI4V0E58NVNDY7Z4gyQV1tzcjLm5OU7Y+QwV54+Jg16iHfk7U+CiSvKQQ8cj9P1PUXmMKutJ+pwQIPDfRZTl5WW9rKxMalpBQQH29va45x8QF8/a2FGYF1C8Xm8MftG1sbGB0tJS4bOF4zoeFBwl1veifGTAaHvq6+v12dlZ4aiZmRlhXcuHhq/ykh83qYi8covBd9sJpaqqSg8Gg8IYVOMwODjIPasj8Ack4KcixpgTvM3wSRQIaXc2TULHGhoasLCwwK31BoH/igT8ZML+ZBp+ZTpuUC1YU3WsaQquaQ4c/rs97kRQWltb9cnJSS6epmnIz89HJBLhno0fY6jI4MvBHvU4Nfv2dLIKnY96V1cXt/jKygoqKyuFBvxArXS2oJX+jtJx4Zb1ip/IXWV1dVUvLi7mxkxMTKC7u5u7f5IK42eSVnr8poqRQ+sdRUJhsspvHE9jY2Pc3EYnw8UHxK68/hfDN8wmx2TC6urqEAqFOGHeLBXNkmPkzHWC2gRxss0gey48kqLRaAx8xhg3b4o6ihLBcfIHbZbn9u2rbUJhi4uLqK2t5UQZSTLAF71Dfk3V2hO1J42xciFKpd/vh8fj4YRVKAzjueLFLxP4H9oEvlRYZ2cnpqamOGEvUe/0lqSVfo1a6aDFVtoKd0LHqqursbS0xM2/ROA3SMCvIPDN1duKAMvw7+zsoLCwUDj+cwL/cQH4v9A7ZKOFd8ijCOUcMzqNlpYWLkaid8gvCXyvjeALGevt7cXw8DAn7GFFx4suvnwYA3+kbvX7u13BUVw5UuWX8WXXglbjxKVyc3MTonPTajA7x8UJM85G0SucnQtajRUn7H5JYxz8gUAAbW1tVn/QPR8Xc2x3dxc1NTXC/0/ccwWSBf4Gg63OkRmTeQEAAAAASUVORK5CYII=) $\text{Option 2} \quad \begin{cases} l_1 & = \quad 3 \left\lbrack mm\right\rbrack \\ l_2 & = \quad 4 \end{cases}$ $l_2= 4$ $l_1=\left\lbrack m\right\rbrack =0.003 \left\lbrack m\right\rbrack$ |$Col1$|$Col2$| |:----|:----| ||$\left\lbrack m\right\rbrack$| |6|7| |8|9| $y = \begin{cases} 10 &: \quad x>20 \\ 2 &: \quad \text{otherwise} \end{cases}$ $\text{System} = \begin{cases} 1\cdot s+2\cdot t=10 & \\ 2\cdot s-4\cdot t^2=20 & \end{cases}$ $\text{Solution} = \begin{cases} s & = \quad 12 \\ t & = \quad -1 \end{cases}$ $\text{Roller Thrust Bearing} \quad \mu_{c} = 0.01$ ================================================ FILE: tests/test_md_export_reference_centered.md ================================================ # MD Export Test $$ x=20\left\lbrack m\right\rbrack $$ Documentation cell with line of text followed by a scaled image: ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAVCAYAAACzK0UYAAAC9klEQVRIS91VTSi7cRz/PFsx2c3sMM3bQXm72cphmry0iZIlB5ILNaXIaTkwudBqJXkpB1bGYYUiOTmYSFmSFMrB2iZzoSk57LHvr/zs2fbsH8f/9/b7vn2e7+f78gj5+fkisojRaERxcTFKS0uRl5eHUCgEr9eLj4+PbGESmyAHMjY2hpGREWi12rRkr6+vmJ+fx+zsbEagxcVF9Pf3c1saiCAIWF1dRU9Pzz+/dHp6GnNzc2l+Z2dnqKmpkQdxu90YHByUBL69veH+/h7V1dVQqVTcJooiWltbcXp6ynU5OTl4eXmBQqFgOqpaUonNZsP6+joPeH9/h91ux/b2NighJZiZmcHw8DD3of4MDQ3xt9lsxt7enrQntbW14sPDA4im6+trlJSUcIfx8XGsrKxIApRKJW5ublBUVMT00WgUZWVlkhin0ykFSXAvEnJzczN2dna4kaZHp9Ph8/MzjfPd3V00NTVxfUVFBcLhMHsTE8RIsgiJUsWNjQ1Gw+joKLcFg0E2qpmko6MDVVVV3NTQ0IBAIMDeV1dXKC8v57bNzU0Ivb29IlWQ+nUZs8soCfDx8RFqtRpPT08Sr87OTgiNjY3i+fk5jo6OYDAYfpOb+RKdGo0G8XgcFosFPp9PQnlhYeHPdB0cHMBkMnEH4vXw8PBXoBMTE3A4HDzm+PgYVqv1B2R5eRl9fX3cgfpDS5kqNFWxWIzNf6pQFVTNt7hcLkxNTf2ADAwMYGFhgTtcXFwgQSWj4Vtyc3Ph9/tRWVnJenB5eYnJyUm2qCS0CslnKNFv1mu+jLRod3d3jN9voT7R1NFe0ARRdfX19dxOm97S0sLedETJL1noY2hKJRvf1taGra0tfhKyNSQSiaC9vR23t7fMraurCx6Ph4c8Pz/zUU47kHQWlpaWoNfrZTH29/fZKUnuS+qe0SB1d3ezHBlPPR1BooZGmra5oKAA1KOTkxPQ4hIFqUIgdXV1XE2MrK2tyYNko+kvNtmf1l+SycX8PyBfZ7U2YFncQMIAAAAASUVORK5CYII=){width="139px"} Sentence with formula $\sqrt{\Omega}$ in the middle, followed by equation on its own line: $E=\frac{My}{I}$ With text after. Line of text. Another line of text. ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACYAAAApCAYAAABZa1t7AAAEi0lEQVRYR92Yb0hkVRjGnzsz/ttplSKEQjIXNlBQt0Bs0Tb9ICUksojWUv75kizafsmGkiFyW6EBRWpFBxEqhYQtnQ0ixYKEGpp2/JB+UPuQSBlSieiuuTuz3nNv753dornnnJnrzF1YujCM3HvOe5553t95z3tV3G63jvvwUv7Xwt7MVHEux5Wy7z+pDD+rwKoGfKsq+E13wBbHPspheDLTmbIw88SrEZa+MIWihnN1ZCjGX/ZdaTt2StHwca7DPkV3I6UtrMml4m136nzJflHawt7JYjibLebrwj6DJilGTsr8004dL9DcXAePQdrCPnVreMLFp3JD1XD2IHmKc6Hj/RwNT5k2T1rCMijoYp4Y+i8ilOKotRSfIE4DJk7TEnbaweA/Lk7jewcqrqjWhBmcLeXF0xYnbGRkBO3t7RyPHR0dmJ6e5u63Evg9EvA7bzCEdWu1LYucv2ZyXunr69MHBgZii4bDYZSUlHACysvLsb6+zt33ZTM8nyVe/NR16xXkGXJ+2OS8otPV39+P0dFRbG1tcdG2t7dRVFQkXGWWwH9UAP7aIcO5m9bcMgL76eQ4bYbfEEYXhoaG0NPTwwmYn59HU1MTdz+H7A9JwA8Q+O9aBP9lwsEjwCHmWCLTfT4fDEfN1xmy/7IE/IsHDFfVxI4V0E58NVNDY7Z4gyQV1tzcjLm5OU7Y+QwV54+Jg16iHfk7U+CiSvKQQ8cj9P1PUXmMKutJ+pwQIPDfRZTl5WW9rKxMalpBQQH29va45x8QF8/a2FGYF1C8Xm8MftG1sbGB0tJS4bOF4zoeFBwl1veifGTAaHvq6+v12dlZ4aiZmRlhXcuHhq/ykh83qYi8covBd9sJpaqqSg8Gg8IYVOMwODjIPasj8Ack4KcixpgTvM3wSRQIaXc2TULHGhoasLCwwK31BoH/igT8ZML+ZBp+ZTpuUC1YU3WsaQquaQ4c/rs97kRQWltb9cnJSS6epmnIz89HJBLhno0fY6jI4MvBHvU4Nfv2dLIKnY96V1cXt/jKygoqKyuFBvxArXS2oJX+jtJx4Zb1ip/IXWV1dVUvLi7mxkxMTKC7u5u7f5IK42eSVnr8poqRQ+sdRUJhsspvHE9jY2Pc3EYnw8UHxK68/hfDN8wmx2TC6urqEAqFOGHeLBXNkmPkzHWC2gRxss0gey48kqLRaAx8xhg3b4o6ihLBcfIHbZbn9u2rbUJhi4uLqK2t5UQZSTLAF71Dfk3V2hO1J42xciFKpd/vh8fj4YRVKAzjueLFLxP4H9oEvlRYZ2cnpqamOGEvUe/0lqSVfo1a6aDFVtoKd0LHqqursbS0xM2/ROA3SMCvIPDN1duKAMvw7+zsoLCwUDj+cwL/cQH4v9A7ZKOFd8ijCOUcMzqNlpYWLkaid8gvCXyvjeALGevt7cXw8DAn7GFFx4suvnwYA3+kbvX7u13BUVw5UuWX8WXXglbjxKVyc3MTonPTajA7x8UJM85G0SucnQtajRUn7H5JYxz8gUAAbW1tVn/QPR8Xc2x3dxc1NTXC/0/ccwWSBf4Gg63OkRmTeQEAAAAASUVORK5CYII=) $$ \text{Option 2} \quad \begin{cases} l_1 & = \quad 3 \left\lbrack mm\right\rbrack \\ l_2 & = \quad 4 \end{cases} $$ $$ l_2= 4 $$ $$ l_1=\left\lbrack m\right\rbrack =0.003 \left\lbrack m\right\rbrack $$ |$Col1$|$Col2$| |:----|:----| ||$\left\lbrack m\right\rbrack$| |6|7| |8|9| $$ y = \begin{cases} 10 &: \quad x>20 \\ 2 &: \quad \text{otherwise} \end{cases} $$ $$ \text{System} = \begin{cases} 1\cdot s+2\cdot t=10 & \\ 2\cdot s-4\cdot t^2=20 & \end{cases} $$ $$ \text{Solution} = \begin{cases} s & = \quad 12 \\ t & = \quad -1 \end{cases} $$ $$ \text{Roller Thrust Bearing} \quad \mu_{c} = 0.01 $$ ================================================ FILE: tests/test_md_export_reference_data_table_format.md ================================================ # New Sheet $$ Col2= \begin{bmatrix} 0.00314159265358979 \\ 0.00628318530717959 \\ 0.00942477796076938 \end{bmatrix} $$ |$Col1=\pi\cdot \mathrm{range}\left(3\right)$|$Col2=1e-3\cdot \pi\cdot \mathrm{range}\left(3\right)$| |:----|:----| |3.14159265358979|3.142e-3| |6.28318530717959|6.283e-3| |9.42477796076938|9.425e-3| ================================================ FILE: tests/test_number_format.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test round trip full precision', async () => { // enter 100 significant figures of pi to test round trip precision await page.locator('math-field.editable').type('3.141592653589793238462643383279502884197169399375105820974944592307816406286208998628034825342117068='); // check default precision (15 significant figures) await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('3.14159265358979'); // change to max precision (64 significant figures) await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByLabel('Significant Figures').dblclick(); await page.getByLabel('Significant Figures').fill('64'); await page.getByRole('button', { name: 'Confirm' }).click(); content = await page.textContent(`#result-value-0`); expect(content).toBe('3.141592653589793238462643383279502884197169399375105820974944592'); // change to precision=62 to check rounding await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByLabel('Significant Figures').dblclick(); await page.getByLabel('Significant Figures').fill('62'); await page.getByRole('button', { name: 'Confirm' }).click(); content = await page.textContent(`#result-value-0`); expect(content).toBe('3.1415926535897932384626433832795028841971693993751058209749446'); }); test('Test symbolic format', async () => { // symbolic expression without units await page.locator('math-field.editable').type('2*pi='); // symbolic expression with units await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(1).type('-2[km]*pi='); // symbolic expression square root, fraction, and units await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\frac{-3\left\lbrack mm\right\rbrack}{\sqrt2}=`); // symbolic expression with fractional exponent await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`3.0^{.500}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); // check all values rendered as floating point values first let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2*pi, precision); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(-2000*pi, precision-2); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo((1/1000)*(-3/sqrt(2)), precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(3), precision); // switch to symbolic formatting await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Display Symbolic Results' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); content = await page.textContent('#result-value-0'); expect(content).toBe('2 \\cdot \\pi') content = await page.textContent('#result-value-1'); expect(content).toBe('- 2000 \\cdot \\pi'); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(content).toBe(String.raw`- \frac{3 \cdot \sqrt{2}}{2000}`); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); content = await page.textContent('#result-value-3'); expect(content).toBe(String.raw`\sqrt{3}`); }); test('Test disabling automatic expressions simplification', async () => { // first test that automatic simplification is on by default await page.setLatex(0, String.raw`-F-F_{B}-F_{W}-\frac{F\cdot l_4-F_{B}\cdot l_2+F_{W}\cdot l_3}{l_1+l_2}+\frac{F\cdot l_1+F\cdot l_2+F\cdot l_4+F_{B}\cdot l_1+F_{W}\cdot l_1+F_{W}\cdot l_2+F_{W}\cdot l_3}{l_1+l_2}\ =`); await page.waitForSelector('.status-footer', { state: 'detached'}); // check query result in cell 1 let content = await page.textContent('#result-value-0'); expect(content).toBe('0'); // turn off automatic simplification await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Automatically Simplify Symbolic Expressions' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('.status-footer', { state: 'detached'}); // check query result in cell 1 content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`- F_{B} - F_{W} - F - \frac{- F_{B} \cdot l_2 + F_{W} \cdot l_3 + F \cdot l_4}{l_1 + l_2} + \frac{F_{B} \cdot l_1 + F_{W} \cdot l_1 + F_{W} \cdot l_2 + F_{W} \cdot l_3 + F \cdot l_1 + F \cdot l_2 + F \cdot l_4}{l_1 + l_2}`); }); test('Test auto exponent', async () => { await page.setLatex(0, String.raw`\frac{2}{3}=`); // negative exponent boundary (with units) await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\frac{1 [mm]}{3}=`); // positive exponent boundary with negative number await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\frac{-2000000}{3}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); // check the default number formatting let content = await page.textContent('#result-value-0'); expect(content).toBe('0.666666666666667') content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`3.33333333333333\times 10^{-4}`); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(content).toBe(String.raw`-6.66666666666667\times 10^{5}`); // update auto exponent settings await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('button', { name: 'Decrement number' }).first().click(); // decrease precision await page.getByRole('button', { name: 'Decrement number' }).nth(1).click(); // decrease lower exp threshold await page.getByRole('button', { name: 'Increment number' }).nth(2).click(); // increse upper exp threshold await page.getByRole('button', { name: 'Confirm' }).click(); // check updated output content = await page.textContent('#result-value-0'); expect(content).toBe('0.66666666666667') content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`0.00033333333333333`); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(content).toBe(String.raw`-666666.66666667`); }); test('Test scientific notation', async () => { await page.setLatex(0, String.raw`\frac{2}{3}=`); // negative exponent boundary (with units) await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\frac{1 [mm]}{3}=`); // positive exponent boundary with negative number await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\frac{-2000000}{3}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); // set scientific notation with 5 significant figures await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Scientific' }).locator('span').first().click(); await page.getByLabel('Significant Figures').dblclick(); await page.getByLabel('Significant Figures').fill('5'); await page.getByRole('button', { name: 'Confirm' }).click(); // check output let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`6.6667\times 10^{-1}`) content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`3.3333\times 10^{-4}`); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(content).toBe(String.raw`-6.6667\times 10^{5}`); }); test('Test cell level number format and format save and restore', async () => { await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.setLatex(0, String.raw`\frac{2}{3}=`); // negative exponent boundary (with units) await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\frac{2}{3}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('0.666666666666667'); content = await page.textContent('#result-value-1'); expect(content).toBe('0.666666666666667'); // change significant figures for second cell only await page.locator('#number-format-1').click(); await page.locator('label').filter({ hasText: 'Fixed' }).locator('span').first().click(); await page.getByLabel('Significant Figures After Decimal Point').dblclick(); await page.getByLabel('Significant Figures After Decimal Point').fill('5'); await page.getByRole('button', { name: 'Confirm' }).click(); // make sure status dot appears on second cell number format settings icon await expect(page.locator('#number-format-1 >> div.dot')).toBeVisible(); // make sure the formatting of only the second math cell changes content = await page.textContent('#result-value-0'); expect(content).toBe('0.666666666666667'); content = await page.textContent('#result-value-1'); expect(content).toBe('0.66667'); // change the sheet wide settings await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Fixed' }).locator('span').first().click(); await page.getByLabel('Significant Figures After Decimal Point').dblclick(); await page.getByLabel('Significant Figures After Decimal Point').fill('3'); await page.getByRole('button', { name: 'Confirm' }).click(); // make sure sheet level settings modified dot is set await expect(page.getByText('Sheet Settings (Modified')).toBeAttached(); // make sure the formatting of only the first math cell changes content = await page.textContent('#result-value-0'); expect(content).toBe('0.667'); content = await page.textContent('#result-value-1'); expect(content).toBe('0.66667'); // save sheet to database await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); // clear contents by creating a new sheet await page.locator('#new-sheet').click(); // go back to page that was just saved await page.evaluate(() => window.history.back()); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('text=Updating...', {state: 'detached'}); // make sure dot indicating cell level change is still visible await expect(page.locator('#number-format-1 >> div.dot')).toBeVisible(); // make sure sheet level and cell formatting are still correct content = await page.textContent('#result-value-0'); expect(content).toBe('0.667'); content = await page.textContent('#result-value-1'); expect(content).toBe('0.66667'); // change the cell specific number formatting back to the default await page.locator('#number-format-1').click(); await page.locator('label').filter({ hasText: 'Automatic' }).locator('span').first().click(); await page.getByLabel('Significant Figures').dblclick(); await page.getByLabel('Significant Figures').fill('15'); await page.getByRole('button', { name: 'Confirm' }).click(); // make sure status dot for cell format is removed await expect(page.locator('#number-format-1 >> div.dot')).not.toBeVisible(); // make sure all cells are now using sheet wide format content = await page.textContent('#result-value-0'); expect(content).toBe('0.667'); content = await page.textContent('#result-value-1'); expect(content).toBe('0.667'); // set sheet wide settings to default await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('button', { name: 'Restore Defaults' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); // sheet wide status dot should be gone await expect(page.getByTitle('Sheet Settings (Modified')).not.toBeVisible(); // check for default number formatting for all fields content = await page.textContent('#result-value-0'); expect(content).toBe('0.666666666666667'); content = await page.textContent('#result-value-1'); expect(content).toBe('0.666666666666667'); }); test('Test restore defaults button', async () => { await page.locator('math-field.editable').type('pi='); // change all of the number format settings await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('button', { name: 'Decrement number' }).first().click(); await page.getByRole('button', { name: 'Decrement number' }).first().click(); await page.getByRole('button', { name: 'Increment number' }).nth(2).click(); await page.locator('label').filter({ hasText: 'Fixed' }).locator('span').first().click(); await page.locator('label').filter({ hasText: 'Display Symbolic Results' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); // check that symbolic number formatting is used let content = await page.textContent('#result-value-0'); expect(content).toBe('\\pi'); // reset all of the sheet number format settings to their default values await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('button', { name: 'Restore Defaults' }).click(); content = await page.getByLabel('Significant Figures').inputValue(); expect(content).toBe('15'); content = await page.getByLabel('Negative Exponent Threshold').inputValue(); expect(content).toBe('-3'); content = await page.getByLabel('Positive Exponent Threshold').inputValue(); expect(content).toBe('5'); await page.getByRole('button', { name: 'Confirm' }).click(); // check that the output format is the default for the first cell // verifies that Automatic is set with 15 significant figures content = await page.textContent('#result-value-0'); expect(content).toBe('3.14159265358979'); }); // test fixed notation test('Test fixed notation', async () => { await page.setLatex(0, String.raw`\frac{2}{3}=`); // negative exponent boundary (with units) await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\frac{1 [mm]}{3}=`); // positive exponent boundary with negative number await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\frac{-2000000}{3}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); // set fixed notation with 3 significant figures after decimal point await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Fixed' }).locator('span').first().click(); await page.getByLabel('Significant Figures After Decimal Point').dblclick(); await page.getByLabel('Significant Figures After Decimal Point').fill('3'); await page.getByRole('button', { name: 'Confirm' }).click(); // check output let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`0.667`) content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`0.000`); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(content).toBe('-666666.667'); // test 0 significant figures after decimal point await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByLabel('Significant Figures After Decimal Point').fill('0'); await page.getByRole('button', { name: 'Confirm' }).click(); // check output content = await page.textContent('#result-value-0'); expect(content).toBe('1') content = await page.textContent('#result-value-1'); expect(content).toBe('0'); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(content).toBe('-666667'); }); test('Test engineering notation', async () => { await page.setLatex(0, String.raw`\frac{2}{3}=`); // negative exponent boundary (with units) await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\frac{1 [mm]}{3}=`); // positive exponent boundary with negative number await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\frac{-2000000}{3}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); // set fixed notation with 3 significant figures after decimal point await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Engineering' }).locator('span').first().click(); await page.getByLabel('Significant Figures').dblclick(); await page.getByLabel('Significant Figures').fill('4'); await page.getByRole('button', { name: 'Confirm' }).click(); // check output let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`666.7\times 10^{-3}`) content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`333.3\times 10^{-6}`); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(content).toBe(String.raw`-666.7\times 10^{3}`); // test 1 significant figure await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByLabel('Significant Figures').fill('0'); await page.getByRole('button', { name: 'Confirm' }).click(); // check output content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`700\times 10^{-3}`) content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`300\times 10^{-6}`); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(content).toBe(String.raw`-700\times 10^{3}`); }); test('Test number input validation', async () => { await page.setLatex(0, String.raw`\frac{2}{3}=`); // negative exponent boundary (with units) await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\frac{2}{3}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('0.666666666666667'); content = await page.textContent('#result-value-1'); expect(content).toBe('0.666666666666667'); // enter invalid values for number inputs and check error message await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByLabel('Significant Figures').click(); await page.getByLabel('Significant Figures').press('Backspace'); await page.getByLabel('Significant Figures').press('Backspace'); await expect(page.locator('text=Value must be between 1 and 64')).toBeVisible(); await page.getByLabel('Negative Exponent Threshold').dblclick(); await page.getByLabel('Negative Exponent Threshold').fill('-1'); await expect(page.locator('text=Value must be between -12 and -2')).toBeVisible(); await page.getByLabel('Positive Exponent Threshold').dblclick(); await page.getByLabel('Positive Exponent Threshold').fill('13'); await expect(page.locator('text=Value must be between 2 and 12')).toBeVisible(); await page.getByRole('button', { name: 'Confirm' }).click(); // make sure formatting has not changed (changes to upper and lower limit won't impact results) content = await page.textContent('#result-value-0'); expect(content).toBe('0.666666666666667'); content = await page.textContent('#result-value-1'); expect(content).toBe('0.666666666666667'); // make sure dialog contains default values when blank and nearest boundary when numeric await page.getByRole('button', { name: 'Sheet Settings' }).click(); content = await page.getByLabel('Significant Figures').inputValue(); expect(content).toBe('15'); content = await page.getByLabel('Negative Exponent Threshold').inputValue(); expect(content).toBe('-2'); content = await page.getByLabel('Positive Exponent Threshold').inputValue(); expect(content).toBe('12'); await page.getByRole('button', { name: 'Confirm' }).click(); // make sure formatting has not changed content = await page.textContent('#result-value-0'); expect(content).toBe('0.666666666666667'); content = await page.textContent('#result-value-1'); expect(content).toBe('0.666666666666667'); }); test('Test disabling symbolic number representations', async () => { // display symbolic results await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Display Symbolic Results' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.setLatex(0, String.raw`\sin\left(10\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); // check output let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\sin{\left(10 \right)}`); // turn off automatic simplification await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Preserve Symbolic Representation of Numbers' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); // check output content = await page.textContent('#result-value-0'); expect(content).toBe('-0.5440211108893698134047476618513772816836430129162238915741840126'); }); test('Test default automatic fraction conversion setting', async () => { await page.setLatex(0, String.raw`.125=`); // turn on symbolic results await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Display Symbolic Results' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); // check output let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\frac{1}{8}`); }); test('Test intermediate results rendering edge cases', async () => { await page.setLatex(0, String.raw`a=0\left\lbrack m\right\rbrack,b=2\left\lbrack m\right\rbrack,c=20,d=400,\:a_1=1e10,\:s=t,\:z=1\left\lbrack m\right\rbrack+1\left\lbrack s\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`y1=\int_{a}^{b}\left(x\cdot b\right)\mathrm{d}\left(x\right)\cdot\log_{c}\left(d\right)\cdot\left(\:a_1\:\right)\cdot1^{c}\cdot s\left(t=b\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`y2=\int_a^b\left(x\cdot b\right)\mathrm{d}\left(x\right)\cdot\log_c\left(d\right)\cdot\left(\:a_1\:\right)\cdot1^c\cdot s\left(t=b\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`a=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`a\cdot z=`); // turn on symbolic results await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Show Intermediate Results' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); // check output let content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`\int_{ 0\left\lbrack m\right\rbrack }^{ 2\left\lbrack m\right\rbrack }\left(x\cdot \left( 2\left\lbrack m\right\rbrack \right)\right)\mathrm{d}\left(x\right)\cdot\log_{ 20 }\left( 400 \right)\cdot\left(\: 1\times 10^{10} \:\right)\cdot1^{ 20 }\cdot s\left(t=\left( 2\left\lbrack m\right\rbrack \right)\right) = 1.6\times 10^{11}`); content = await page.textContent('#result-value-2'); expect(content).toBe(String.raw`\int_{ 0\left\lbrack m\right\rbrack }^{ 2\left\lbrack m\right\rbrack }\left(x\cdot \left( 2\left\lbrack m\right\rbrack \right)\right)\mathrm{d}\left(x\right)\cdot\log_{ 20 }\left( 400 \right)\cdot\left(\: 1\times 10^{10} \:\right)\cdot1^{ 20 }\cdot s\left(t=\left( 2\left\lbrack m\right\rbrack \right)\right) = 1.6\times 10^{11}`); content = await page.textContent('#result-value-3'); expect(content).toBe(String.raw`0`); content = await page.textContent('#result-value-4'); expect(content).toBe(String.raw`\left( 0\left\lbrack m\right\rbrack \right)\cdot \left(\text{Dimension Error}\right) = `); // change default units and make sure numbers in intermediate results update to match await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.getByRole('tab', { name: 'Default Units' }).click(); await page.getByRole('button', { name: 'mm-kg-sec' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`\int_{ 0\left\lbrack mm\right\rbrack }^{ 2000\left\lbrack mm\right\rbrack }\left(x\cdot \left( 2000\left\lbrack mm\right\rbrack \right)\right)\mathrm{d}\left(x\right)\cdot\log_{ 20 }\left( 400 \right)\cdot\left(\: 1\times 10^{10} \:\right)\cdot1^{ 20 }\cdot s\left(t=\left( 2000\left\lbrack mm\right\rbrack \right)\right) = 1.6\times 10^{23}`); content = await page.textContent('#result-value-2'); expect(content).toBe(String.raw`\int_{ 0\left\lbrack mm\right\rbrack }^{ 2000\left\lbrack mm\right\rbrack }\left(x\cdot \left( 2000\left\lbrack mm\right\rbrack \right)\right)\mathrm{d}\left(x\right)\cdot\log_{ 20 }\left( 400 \right)\cdot\left(\: 1\times 10^{10} \:\right)\cdot1^{ 20 }\cdot s\left(t=\left( 2000\left\lbrack mm\right\rbrack \right)\right) = 1.6\times 10^{23}`); content = await page.textContent('#result-value-3'); expect(content).toBe(String.raw`0`); content = await page.textContent('#result-value-4'); expect(content).toBe(String.raw`\left( 0\left\lbrack mm\right\rbrack \right)\cdot \left(\text{Dimension Error}\right) = `); }); test('Test intermediate results with symbolic values', async () => { await page.setLatex(0, String.raw`x\cdot y=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`x=3`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`y=\frac18`); // turn on symbolic results await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Show Intermediate Results' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); // check output let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\left( 3 \right)\cdot \left( 0.125 \right) = 0.375`); //change x to a symbolic value await page.setLatex(1, String.raw`x=s`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\left( s \right)\cdot \left( 0.125 \right) = \frac{s}{8}`); // change to symbolic output to make sure it impacts numeric intermediate values await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Display Symbolic Results' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\left( s \right)\cdot \left( \frac{1}{8} \right) = \frac{s}{8}`); }); test('Test intermediate results with only symbolic values', async () => { await page.setLatex(0, String.raw`x\cdot y=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\alpha_1\cdot a=`); // turn on intermediate results await page.getByRole('button', { name: 'Sheet Settings' }).click(); await page.locator('label').filter({ hasText: 'Show Intermediate Results' }).click(); await page.getByRole('button', { name: 'Confirm' }).click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); // there should be no intermediate result let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`x \cdot y`); content = await page.textContent('#result-value-1'); expect(content).toBe(String.raw`a \cdot \alpha_1`); }); ================================================ FILE: tests/test_parse_id_bug.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { precision, pyodideLoadTimeout, compareImages, parseLatexFloat } from './utility.mjs'; test('Test parse id bug', async ({ page, browserName }) => { // deleting cells doesn't force a reparsing of math cells so using cell index as a unique id causes chaos // this will be fixed by using the mathField id as the unique id // this test is to prevent regressions page.setLatex = async function (cellIndex, latex) { await this.evaluate(([cellIndex, latex]) => window.setCellLatex(cellIndex, latex), [cellIndex, latex]); } page.forceDeleteCell = async function (index) { await this.evaluate((index) => window.forceDeleteCell(index), index); await this.waitForTimeout(200); } // const width = 900; // needs to be wider since webkit is not scrolling enough for some clicks // const height = 1280; // await page.setViewportSize({ width: width, height: height }); await page.goto('/DuGYz5Lu7tPdEJ27zAT8bg'); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached'}); await page.locator('h1 >> text=Calculating the Johnson-Euler Buckling Load').waitFor({state: 'visible'}); await page.locator("text=Accept").click(); await page.forceDeleteCell(0); await page.forceDeleteCell(1); await page.forceDeleteCell(2); await page.forceDeleteCell(3); await page.forceDeleteCell(4); await page.type(':nth-match(math-field.editable, 98)', ' '); await page.locator('#add-math-cell').click(); await page.setLatex(18, String.raw`P_{cr}\left(S_{r}=100\right)=`); await page.locator('text=Updating...').waitFor({state: 'detached', timeout: pyodideLoadTimeout}); let content = await page.locator('#result-value-18').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(87008.8224822736, precision); }); ================================================ FILE: tests/test_piecewise_cell.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { precision, loadPyodide, newSheet, screenshotDir, pyodideLoadTimeout, compareImages, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test condition error messages', async ({ browserName }) => { test.skip(browserName === "webkit", "Webkit not working with attribute selector."); await page.forceDeleteCell(0); await page.locator('#add-piecewise-cell').click(); // make sure blank fields provide error message let content = await page.locator('#piecewise-parameter-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('A variable name is required in this field.'); content = await page.locator('#piecewise-expression-0-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain a valid expression or number without an equals sign.'); content = await page.locator('#piecewise-condition-0-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain a condition statement such as x>1. The expression corresponding to the first satisfied condition will be used.'); // check that variables, expressions, and units cause error in condition field await page.locator('#piecewise-condition-0-0 math-field.editable').type('1'); content = await page.locator('#piecewise-condition-0-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain a condition statement such as x>1. The expression corresponding to the first satisfied condition will be used.'); await page.locator('#piecewise-condition-0-0 math-field.editable').click({clickCount: 3}); await page.locator('#piecewise-condition-0-0 math-field.editable').click({clickCount: 3}); content = await page.locator('#piecewise-condition-0-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain a condition statement such as x>1. The expression corresponding to the first satisfied condition will be used.'); await page.locator('#piecewise-condition-0-0 math-field.editable').click({clickCount: 3}); await page.locator('#piecewise-condition-0-0 math-field.editable').type('a='); content = await page.locator('#piecewise-condition-0-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain a condition statement such as x>1. The expression corresponding to the first satisfied condition will be used.'); await page.locator('#piecewise-condition-0-0 math-field.editable').click({clickCount: 3}); await page.locator('#piecewise-condition-0-0 math-field.editable').type('b'); content = await page.locator('#piecewise-condition-0-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain a condition statement such as x>1. The expression corresponding to the first satisfied condition will be used.'); await page.locator('#piecewise-condition-0-0 math-field.editable').click({clickCount: 3}); await page.locator('#piecewise-condition-0-0 math-field.editable').type(' [m]'); content = await page.locator('#piecewise-condition-0-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain a condition statement such as x>1. The expression corresponding to the first satisfied condition will be used.'); }); test('Test piecewise cell functionality', async ({ browserName }) => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; let selectAllCommand = `${modifierKey}+a`; if (modifierKey === 'Meta' && browserName === 'chromium') { // Cmd-a not working with Chromium on Mac, need to use Control-A // Cmd-a works correctly on Chrome and Edge on Mac selectAllCommand = 'Control+a'; } const width = 1300; const height = 2000; await page.setViewportSize({ width: width, height: height }); // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.setLatex(0, 'y(x=0.5[m])='); await page.click('#add-math-cell'); await page.setLatex(1, 'y(x=0[m])='); await page.click('#add-piecewise-cell'); await page.click('#add-math-cell'); await page.setLatex(3, 'y(x=2[m])='); await page.click('#add-math-cell'); await page.setLatex(4, 'y(x=-1[m])='); await page.locator('#piecewise-parameter-2 math-field.editable').type('y'); await page.locator('#piecewise-expression-2-0 math-field.editable').type('x+1[m]'); await page.locator('#piecewise-expression-2-1 math-field.editable').type('0'); await page.locator('#piecewise-condition-2-0 math-field.editable').type('x>=0'); await page.waitForSelector('.status-footer', { state: 'detached' }); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeVisible(); await expect(page.locator('#cell-1 >> text=Dimension Error')).toBeVisible(); await page.locator('#piecewise-expression-2-1 math-field.editable').click({clickCount: 3}); await page.locator('#piecewise-expression-2-1 math-field.editable').type('33[m]'); await page.waitForSelector('.status-footer', { state: 'detached' }); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeVisible(); await expect(page.locator('#cell-1 >> text=Dimension Error')).toBeVisible(); // test GTE await page.locator('#piecewise-condition-2-0 math-field.editable').click({clickCount: 3}); await page.locator('#piecewise-condition-2-0 math-field.editable').type('x>=0[m]'); await page.waitForSelector('.status-footer', { state: 'detached' }); let content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(1.5, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-3').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.locator('#result-units-3').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-4').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-4').textContent(); expect(content).toBe('m'); // Test GT await page.locator('#piecewise-condition-2-0 math-field.editable').click({clickCount: 3}); await page.locator('#piecewise-condition-2-0 math-field.editable').type('x>0[m]'); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(1.5, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-3').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.locator('#result-units-3').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-4').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-4').textContent(); expect(content).toBe('m'); // Test LTE await page.locator('#piecewise-condition-2-0 math-field.editable').press(selectAllCommand ); await page.locator('#piecewise-condition-2-0 math-field.editable').type('x<=0[m]'); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-3').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-3').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-4').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(0, precision); content = await page.locator('#result-units-4').textContent(); expect(content).toBe('m'); // Test LT await page.locator('#piecewise-condition-2-0 math-field.editable').press(selectAllCommand ); await page.locator('#piecewise-condition-2-0 math-field.editable').type('x<0[m]'); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-3').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-3').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-4').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(0, precision); content = await page.locator('#result-units-4').textContent(); expect(content).toBe('m'); // Test chained logical order await page.locator('#piecewise-condition-2-0 math-field.editable').press(selectAllCommand ); await page.locator('#piecewise-condition-2-0 math-field.editable').type('0.5[m]<=x<=3[m]'); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(1.5, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-3').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.locator('#result-units-3').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-4').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-4').textContent(); expect(content).toBe('m'); // Test chained reverse order await page.locator('#piecewise-condition-2-0 math-field.editable').press(selectAllCommand ); await page.locator('#piecewise-condition-2-0 math-field.editable').type('2[m]>=x>=0.5[m]'); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(1.5, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-3').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.locator('#result-units-3').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-4').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-4').textContent(); expect(content).toBe('m'); // Test chained split (first case can never be satisified, everything will fall through to otherwise expression) await page.locator('#piecewise-condition-2-0 math-field.editable').press(selectAllCommand ); await page.locator('#piecewise-condition-2-0 math-field.editable').type('0[m]>x>1[m]'); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-3').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-3').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-4').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(33, precision); content = await page.locator('#result-units-4').textContent(); expect(content).toBe('m'); // add additional rows await page.setLatex(4, 'y(x=-0.5[m])='); // move last test point away from boundary // add row using button await page.locator('#add-row-2').click(); await page.locator('#piecewise-expression-2-0 math-field.editable').press(selectAllCommand ); await page.locator('#piecewise-expression-2-0 math-field.editable').type('x*1[m]'); await page.locator('#piecewise-condition-2-0 math-field.editable').press(selectAllCommand ); await page.locator('#piecewise-condition-2-0 math-field.editable').type('1[m]>=x>=0[m]'); await page.locator('#piecewise-expression-2-1 math-field.editable').type('x^2'); await page.locator('#piecewise-condition-2-1 math-field.editable').type('1[m]=-1[m]'); await page.locator('#piecewise-expression-2-3 math-field.editable').press(selectAllCommand ); await page.locator('#piecewise-expression-2-3 math-field.editable').type('-1[m^2'); await page.locator('#piecewise-expression-2-3 math-field.editable').press('ArrowRight'); await page.locator('#piecewise-expression-2-3 math-field.editable').type(']'); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(0.5, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m^2'); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(0, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m^2'); content = await page.locator('#result-value-3').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.locator('#result-units-3').textContent(); expect(content).toBe('m^2'); content = await page.locator('#result-value-4').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(-.25, precision); content = await page.locator('#result-units-4').textContent(); expect(content).toBe('m^2'); // add a plot await page.keyboard.press('Escape'); await page.click('#add-math-cell'); await page.setLatex(5, String.raw`y\left(-10\left[m\right]\le x\le 10\left[m\right]\right)\ with\ 1000\ points=`); await page.waitForSelector('.status-footer', { state: 'detached' }); // save to database and create a screenshot await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); await page.mouse.move(0,0); await page.keyboard.press('Escape'); await page.waitForTimeout(1000); await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_piecewise_screenshot.png`, fullPage: false }); // clear contents, we'll be creating a new sheet await page.locator('#new-sheet').click(); // retrieve previously saved document from database and check screenshot await page.goto(`${sheetUrl.pathname}`); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); await page.mouse.move(0,0); await page.keyboard.press('Escape'); await page.waitForTimeout(1000); await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_piecewise_screenshot_check.png`, fullPage: false }); // chromium is the only browser that can reproduce pixel perfect on this one // (seems line the exponent rendering changes slightly for firefox and webkit) if (browserName === "chromium") { expect(compareImages(`${browserName}_piecewise_screenshot.png`, `${browserName}_piecewise_screenshot_check.png`)).toEqual(0); } // delete 2 rows and check results await page.locator('#delete-row-2-2').click(); await page.locator('#delete-row-2-0').click(); await page.waitForSelector('.status-footer', { state: 'detached' }); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(-1, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m^2'); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(-1, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m^2'); content = await page.locator('#result-value-3').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.locator('#result-units-3').textContent(); expect(content).toBe('m^2'); content = await page.locator('#result-value-4').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(-1, precision); content = await page.locator('#result-units-4').textContent(); expect(content).toBe('m^2'); }); ================================================ FILE: tests/test_plotting.spec.mjs ================================================ import fs from 'fs'; import path from 'path'; import { test, expect } from '@playwright/test'; import { compareImages, screenshotDir, loadPyodide, newSheet } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test plotting', async ({ browserName }) => { // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); // make sure first empty cell shows informative message await page.waitForSelector('button:has-text("This field must contain an assignment (e.g., x=y*z) or a query (e.g., x=). To delete an unwanted math cell, click the trash can on the right.")'); // test plot without units await page.click('#add-documentation-cell'); await page.type('div.editor div', 'Plot with 2 curves and no units'); await page.setLatex(0, String.raw`y=x^{2}`); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'z=-x'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', 'y(-1<=x<=1)='); await page.locator('#plot-expression-3-0 math-field.editable').press('Enter'); await page.type(':nth-match(math-field.editable, 4)', 'z(-1 { await page.setLatex(0, String.raw`y=1\left[m\right]\cdot x`); await page.click('#add-math-cell'); await page.setLatex(1, String.raw`y\left(0\le x\le 10\right)=\left[m\right]`); await expect(page.locator('div.plot-container')).toBeVisible({timeout: 40000}); await page.waitForSelector('.status-footer', { state: 'detached' }); await expect(() => page.locator('button:has-text("Units Mismatch")').waitFor({timeout: 1000 })) .rejects.toThrow('Timeout'); }); // #73 test('Test plot two curves with compatible x-range units', async ({ browserName }) => { // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); // test plot without units await page.setLatex(0, String.raw`y=x`); await page.click('#add-math-cell'); await page.setLatex(1, String.raw`y\left(0\left[in\right]\le x\le 10\left[m\right]\right)=\left[m\right]`); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.locator('#add-row-1').click(); await page.locator('math-field.editable').nth(2).type('y(0[m]<=x<=10[m])=[m]'); await page.waitForSelector('.status-footer', { state: 'detached' }); await expect(() => page.locator('button:has-text("Units Mismatch")').waitFor({timeout: 1000 })) .rejects.toThrow('Timeout'); }); test('Test plot number of points', async ({ browserName }) => { // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); // test plot without units await page.setLatex(0, 'y=x'); await page.click('#add-math-cell'); await page.setLatex(1, 'z=s^2'); await page.click('#add-math-cell'); await page.locator('math-field.editable').nth(2).type('y(0<=x<=1)='); await expect(page.locator('#cell-2 >> math-field.editable')).toBeVisible(); await expect(page.locator('text=Updating...')).toBeHidden(); await expect(page.locator('g.trace.scatter')).toBeVisible(); let [download] = await Promise.all([ page.waitForEvent('download'), page.locator('.modebar-btn').first().click() ]); const linearImageFile = `${browserName}_screenshot_plot_linear.png`; fs.copyFileSync(await download.path(), path.join(screenshotDir, linearImageFile)); await page.locator('math-field.editable').nth(2).click({clickCount: 3}); await page.locator('math-field.editable').nth(2).type('z(0<=s<=1) with 1 points ='); page.locator('button:has-text("Number of range points must be 2 or greater.")').waitFor({timeout: 1000 }) await page.locator('math-field.editable').nth(2).click({clickCount: 3}); await page.locator('math-field.editable').nth(2).type('z(s=1) with 10 points ='); page.locator('button:has-text("Invalid syntax, cannot specify number of points for function without range parameter.")').waitFor({timeout: 1000 }) await page.locator('math-field.editable').nth(2).click({clickCount: 3}); await page.locator('math-field.editable').nth(2).type('y(x=z(0<=s<=1)with 10 points)='); page.locator('button:has-text("Range may only be specified at top level function.")').waitFor({timeout: 1000 }) // change first equation to a curve await page.setLatex(0, 'y=x^2'); await page.locator('math-field.editable').nth(2).click({clickCount: 3}); await page.locator('math-field.editable').nth(2).type('y(0<=x<=1)='); await page.waitForSelector('.status-footer', { state: 'detached' }); [download] = await Promise.all([ page.waitForEvent('download'), page.locator('.modebar-btn').first().click() ]); const curveImageFile = `${browserName}_screenshot_plot_curve.png`; fs.copyFileSync(await download.path(), path.join(screenshotDir, curveImageFile)); await page.locator('math-field.editable').nth(2).click({clickCount: 3}); await page.locator('math-field.editable').nth(2).type('y(0<=x<=1) with 2 points ='); await page.waitForSelector('.status-footer', { state: 'detached' }); await expect(page.locator('g.trace.scatter')).toBeVisible(); [download] = await Promise.all([ page.waitForEvent('download'), page.locator('.modebar-btn').first().click() ]); const twoPointCurveImageFile = `${browserName}_screenshot_plot_2point_curve.png`; fs.copyFileSync(await download.path(), path.join(screenshotDir, twoPointCurveImageFile)); expect(compareImages(linearImageFile, curveImageFile)).toBeGreaterThan(100); expect(compareImages(linearImageFile, twoPointCurveImageFile)).toEqual(0); }); test('Test plot with undefined endpoint', async ({ browserName }) => { await page.setLatex(0, String.raw`y=\frac{1}{x}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`y\left(0\left[inch\right]\le x\le 10\left[inch\right]\right)=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Results of expression does not evaluate to finite and real numeric values').waitFor({state: 'attached', timeout: 1000}); // change lower limit to be open, which should eliminate the error await page.setLatex(1, String.raw`y\left(0\left[inch\right] { await page.setLatex(0, String.raw`y=x^{1\left[m\right]}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`y\left(0> text=Y-axis dimension error: Exponent Not Dimensionless').waitFor({state: 'attached', timeout: 1000}); // test x-axis units in exponent error handling await page.setLatex(0, String.raw`y=x`); await page.setLatex(1, String.raw`y\left(1^{1\left[foot\right]}> text=X-axis upper and/or lower limit dimension error: Exponent Not Dimensionless').waitFor({state: 'attached', timeout: 1000}); // test x-axis units in exponent error handling await page.setLatex(1, String.raw`y\left(1\left[min\right]+1\left[mile\right]> text=X-axis upper and/or lower limit dimension error').waitFor({state: 'attached', timeout: 1000}); }); test('Test error message when trying to plot more than 4 different y-axis units', async ({ browserName }) => { await page.setLatex(0, String.raw`y0=x`); await page.keyboard.press('Enter'); await page.setLatex(1, String.raw`y1=x^{2}`); await page.keyboard.press('Enter'); await page.setLatex(2, String.raw`y2=x^{3}`); await page.keyboard.press('Enter'); await page.setLatex(3, String.raw`y3=x^{4}`); await page.keyboard.press('Enter'); await page.setLatex(4, String.raw`y4=x^{5}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-5 >> math-field.editable')).toBeVisible(); await page.setLatex(5, String.raw`y0\left(-10\left[cm\right]\le x\le 10\left[cm\right]\right)=`, 0); await page.keyboard.press('Enter'); await page.setLatex(5, String.raw`y1\left(-10\left[mm\right]\le x\le 10\left[mm\right]\right)=`, 1); await page.keyboard.press('Enter'); await page.setLatex(5, String.raw`y2\left(-10\left[mm\right]\le x\le 10\left[mm\right]\right)=`, 2); await page.keyboard.press('Enter'); await page.setLatex(5, String.raw`y3\left(-10\left[mm\right]\le x\le 10\left[mm\right]\right)=`, 3); await page.waitForSelector('.status-footer', { state: 'detached' }); // should be no errors at this point await page.locator('svg.error').waitFor({state: 'detached', timeout: 1000}); // add fifth set of units to trigger error await page.keyboard.press('Enter'); await page.setLatex(5, String.raw`y4\left(-10\left[mm\right]\le x\le 10\left[mm\right]\right)=`, 4); await page.waitForSelector('.status-footer', { state: 'detached'}); await page.locator('#plot-expression-5-4 >> text=Cannot have more than 4 different y-axis units').waitFor({state: 'attached', timeout: 1000}); }); test('Test reversed x-axis limits', async ({ browserName }) => { await page.setLatex(0, String.raw`y=x`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`y\left(10\le x\le -10\right)=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Upper and lower limits of plot range are reversed').waitFor({state: 'attached', timeout: 1000}); }); test('Test lower limit unit cancellation issue', async ({ browserName }) => { await page.setLatex(0, String.raw`y=\left(1-x\right)\cdot 1\left[m\right]`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`y\left(1\le x\le 20\right)=\left[mm\right]`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await expect(page.locator('text="Units Mismatch"')).not.toBeVisible(); }); test('Test copy plot data', async ({ browserName }) => { test.skip(browserName !== "firefox", "Copy-paste test is only working with firefox"); const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.setLatex(0, 'y1=x'); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`y2=1\left[\frac{1}{inch}\right]\cdot x`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-2 >> math-field.editable')).toBeVisible(); await page.locator('#plot-expression-2-0 math-field.editable').type('y1(-10[inch]<=x<=10[inch])with 2 points='); await page.locator('#add-row-2').click(); await page.locator('#plot-expression-2-1 math-field.editable').type('y2(10[inch]<=x<=20[inch])with 2 points='); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('text=Copy Data').click(); await page.locator('text=Copied!').waitFor({state: "attached", timeout: 1000}); await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.locator('h1').press(modifierKey+'+v'); let clipboardContents = await page.locator('h1').textContent(); clipboardContents = clipboardContents.replace(/\s+/g, ''); // remove whitespace expect(clipboardContents).toBe('xy1xy2[inch][m][inch][]-10-0.2541010100.2542020'); }); test('Make sure second curve is plotted if first plot has error', async ({ browserName }) => { test.skip(browserName !== "firefox", "Clipboard only works in firefox when headless"); await page.setLatex(0, String.raw`y=\frac{1}{x}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`y\left(0\le x\le 10\right)=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); // should be no data since only curve has error (divide by zero) await page.locator('text=Copy Data').click(); await page.locator('text=No data to copy').waitFor({state: "attached", timeout: 1000}); // make sure temp text cleared before proceeding await page.locator('text=No data to copy').waitFor({state: "detached", timeout: 5000}) // make a valid second curve await page.locator('#add-row-1').click(); await page.setLatex(1, String.raw`y\left(1\le x\le 10\right)=`, 1); await page.waitForSelector('.status-footer', { state: 'detached'}); //await page.pause(); // should now be data to copy await page.locator('text=Copy Data').click(); await page.locator('text=Copied!').waitFor({state: "attached", timeout: 1000}); }); test('test scatter plot x-y scalar vector mismatch', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ 2\end{bmatrix},\:y=2`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Both the x and y values need to be a scalar value or a vector').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot x-y scalar vector size mismatch', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ 2\end{bmatrix},\:y=\begin{bmatrix}1\\ 2\\ 3\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Both the x and y values need to be either column or row vectors of the same size').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot x matrix but not vector', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1 & 1\\ 2 & 2\end{bmatrix},\:y=\begin{bmatrix}1\\ 2\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Both the x and y values need to be either column or row vectors of the same size').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot y matrix but not vector', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ 2\end{bmatrix},\:y=\begin{bmatrix}1 & 1\\ 2 & 2\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Both the x and y values need to be either column or row vectors of the same size').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot x not a number', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ a\end{bmatrix},\:y=\begin{bmatrix}1\\ 2\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=One or more x values does not evaluate to a finite real value').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot y not a number', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ 2\end{bmatrix},\:y=\begin{bmatrix}1\\ a\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=One or more y values does not evaluate to a finite real value').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot x not finite', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ \frac10\end{bmatrix},\:y=\begin{bmatrix}1\\ 2\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=One or more x values does not evaluate to a finite real value').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot y not finite', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ 2\end{bmatrix},\:y=\begin{bmatrix}1\\ \frac10\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=One or more y values does not evaluate to a finite real value').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot x not real', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ i\end{bmatrix},\:y=\begin{bmatrix}1\\ 3\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=One or more x values does not evaluate to a finite real value').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot y not real', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ 2\end{bmatrix},\:y=\begin{bmatrix}1\\ i\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=One or more y values does not evaluate to a finite real value').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot x has dimension error', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ 2+1\left\lbrack in\right\rbrack\end{bmatrix},\:y=\begin{bmatrix}1\\ 2\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=One or more of the x values has inconsistent units or a dimension error').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot y has dimension error', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ 2\end{bmatrix},\:y=\begin{bmatrix}1\\ 2+1\left\lbrack in\right\rbrack\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=One or more of the y values has inconsistent units or a dimension error').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot x has inconsistent units', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ 2\left\lbrack in\right\rbrack\end{bmatrix},\:y=\begin{bmatrix}1\\ 2\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=One or more of the x values has inconsistent units or a dimension error').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot y has inconsistent units', async ({ browserName }) => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ 2\end{bmatrix},\:y=\begin{bmatrix}1\\ 2\left\lbrack in\right\rbrack\end{bmatrix}`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`x,y=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=One or more of the y values has inconsistent units or a dimension error').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot inconsistent x user unit', async ({ browserName }) => { await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`1\left\lbrack m\right\rbrack,\:2\left\lbrack m\right\rbrack=\left\lbrack s\right\rbrack,\left\lbrack mm\right\rbrack`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=All x-axis units must be compatible').waitFor({state: 'attached', timeout: 1000}); }); test('test scatter plot inconsistent y user unit', async ({ browserName }) => { await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`1\left\lbrack m\right\rbrack,\:2\left\lbrack m\right\rbrack=\left\lbrack mm\right\rbrack,\left\lbrack s\right\rbrack`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Units Mismatch').waitFor({state: 'attached', timeout: 1000}); }); test('Test visual comparison of function plot with identical scatter line plot', async ({ browserName }) => { // create function plot with user units await page.setLatex(0, String.raw`y_1=x_1`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`y_1\left(0\left\lbrack mm\right\rbrack\le x_1\le1\left\lbrack m\right\rbrack\right)=\left\lbrack mm\right\rbrack`, 0); await expect(page.locator('text=Updating...')).toBeHidden(); await expect(page.locator('g.trace.scatter')).toBeVisible(); let [download] = await Promise.all([ page.waitForEvent('download'), page.locator('.modebar-btn').first().click() ]); const linearFunctionImageFile = `${browserName}_screenshot_plot_linear_with_user_units.png`; fs.copyFileSync(await download.path(), path.join(screenshotDir, linearFunctionImageFile)); await page.setLatex(1, String.raw`\begin{bmatrix}0\left\lbrack m\right\rbrack\\ 1\left\lbrack m\right\rbrack\end{bmatrix},\begin{bmatrix}0\left\lbrack m\right\rbrack\\ 1\left\lbrack m\right\rbrack\end{bmatrix}\:as\:lines=\left\lbrack mm\right\rbrack,\:\left\lbrack mm\right\rbrack`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await expect(page.locator('g.trace.scatter')).toBeVisible(); [download] = await Promise.all([ page.waitForEvent('download'), page.locator('.modebar-btn').first().click() ]); const scatterLinesImageFile = `${browserName}_screenshot_plot_scatter_lines_with_user_units.png`; fs.copyFileSync(await download.path(), path.join(screenshotDir, scatterLinesImageFile)); await page.setLatex(1, String.raw`\begin{bmatrix}0\left\lbrack m\right\rbrack\\ 1\left\lbrack m\right\rbrack\end{bmatrix},\begin{bmatrix}0\left\lbrack m\right\rbrack\\ 1\left\lbrack m\right\rbrack\end{bmatrix}=\left\lbrack mm\right\rbrack,\:\left\lbrack mm\right\rbrack `, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await expect(page.locator('g.points>path.point').first()).toBeVisible(); [download] = await Promise.all([ page.waitForEvent('download'), page.locator('.modebar-btn').first().click() ]); const scatterPointsImageFile = `${browserName}_screenshot_plot_scatter_points_with_user_units.png`; fs.copyFileSync(await download.path(), path.join(screenshotDir, scatterPointsImageFile)); expect(compareImages(linearFunctionImageFile, scatterLinesImageFile)).toEqual(0); expect(compareImages(scatterLinesImageFile, scatterPointsImageFile)).toBeGreaterThan(100); }); test('test parametric plot limit units mismatch', async ({ browserName }) => { await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\left(x,x\right)\:for\:\left(-5\left\lbrack in\right\rbrack\le x\le10\left\lbrack s\right\rbrack\right)=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Units of the upper and lower limits do not match').waitFor({state: 'attached', timeout: 1000}); }); test('test parametric plot with non-numeric y-values', async ({ browserName }) => { await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\left(x,y\right)\:for\:\left(-5\le x\le10\right)=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Results of expression does not evaluate to finite and real numeric values').waitFor({state: 'attached', timeout: 1000}); }); test('test parametric plot with non-numeric x-values', async ({ browserName }) => { await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\left(y,x\right)\:for\:\left(-5\le x\le10\right)=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Results of expression does not evaluate to finite and real numeric values').waitFor({state: 'attached', timeout: 1000}); }); test('test parametric plot with non-numeric lower limit', async ({ browserName }) => { await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\left(x,x\right)\:for\:\left(a\le x\le10\right)=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Upper and/or lower limits do not evaluate to a number').waitFor({state: 'attached', timeout: 1000}); }); test('test parametric plot with non-numeric upper limit', async ({ browserName }) => { await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\left(x,x\right)\:for\:\left(0\le x\le b\right)=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Upper and/or lower limits do not evaluate to a number').waitFor({state: 'attached', timeout: 1000}); }); test('test parametric plot with incompatible x-axis user unit', async ({ browserName }) => { await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\left(x,x\right)\:for\:\left(0\left\lbrack m\right\rbrack\le x\le10\left\lbrack m\right\rbrack\right)=\left\lbrack s\right\rbrack,\left\lbrack m\right\rbrack`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=All x-axis units must be compatible').waitFor({state: 'attached', timeout: 1000}); }); test('test parametric plot with incompatible y-axis user unit', async ({ browserName }) => { await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\left(x,x\right)\:for\:\left(0\left\lbrack m\right\rbrack\le x\le10\left\lbrack m\right\rbrack\right)=\left\lbrack m\right\rbrack,\left\lbrack s\right\rbrack`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Units Mismatch').waitFor({state: 'attached', timeout: 1000}); }); test('test parametric plot with limits reversed', async ({ browserName }) => { await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\left(x,x\right)\:for\:\left(10\le x\le-10\right)=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Upper and lower limits of plot range are reversed').waitFor({state: 'attached', timeout: 1000}); }); test('Test visual comparison of function plot with identical parametric plot', async ({ browserName }) => { await page.setLatex(0, String.raw`y=x`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\left(x,y\right)\:for\:\left(0\left\lbrack m\right\rbrack\le x\le10\left\lbrack m\right\rbrack\right)=\left(\left\lbrack mm\right\rbrack,\left\lbrack mm\right\rbrack\right)`, 0); await expect(page.locator('#plot-expression-1-0 math-field.editable')).toBeVisible(); await expect(page.locator('text=Updating...')).toBeHidden(); await expect(page.locator('g.trace.scatter')).toBeVisible(); let [download] = await Promise.all([ page.waitForEvent('download'), page.locator('.modebar-btn').first().click() ]); const linearParametricImageFile = `${browserName}_screenshot_parametric_linear_plot_with_user_units.png`; fs.copyFileSync(await download.path(), path.join(screenshotDir, linearParametricImageFile)); await page.setLatex(1, String.raw`y\left(0\left\lbrack mm\right\rbrack\le x\le10\left\lbrack m\right\rbrack\right)=\left\lbrack mm\right\rbrack`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await expect(page.locator('g.trace.scatter')).toBeVisible(); [download] = await Promise.all([ page.waitForEvent('download'), page.locator('.modebar-btn').first().click() ]); const linearFunctionImageFile = `${browserName}_screenshot_plot_scatter_lines_with_user_units.png`; fs.copyFileSync(await download.path(), path.join(screenshotDir, linearFunctionImageFile)); expect(compareImages(linearParametricImageFile, linearFunctionImageFile)).toEqual(0); }); test('test parametric plot with expressions as inputs', async ({ browserName }) => { await page.setLatex(0, String.raw`y=s,\:x=s^2`); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\left(t\cdot x,\:4\cdot y\right)\:for\:\left(-1\le s\le1\right)\:with\:51\:points=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Results of expression does not evaluate to finite and real numeric values').waitFor({state: 'attached', timeout: 1000}); // fix error and make sure plot is generated await page.setLatex(1, String.raw`\left(2\cdot x,\:4\cdot y\right)\:for\:\left(-1\le s\le1\right)\:with\:51\:points=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('svg.error').waitFor({state: "detached", timeout: 1000}); await expect(page.locator('g.trace.scatter')).toBeVisible(); }); test('test parametric plot with range in x or y expression field', async ({ browserName }) => { await page.setLatex(0, 'y=x'); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.setLatex(1, String.raw`\left(x,y\left(0\le x\le10\right)\right)\:for\:\left(0\le x\le10\right)=`, 0); await page.locator('#plot-expression-1-0 >> text=Range cannot be specified in the x or y expressions for a parametric plot').waitFor({state: 'attached', timeout: 1000}); // fix error and make sure plot is generated await page.setLatex(1, String.raw`\left(x,y\right)\:for\:\left(0\le x\le10\right)=`, 0); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('svg.error').waitFor({state: "detached", timeout: 1000}); await expect(page.locator('g.trace.scatter')).toBeVisible(); }); test('test infinity detection bug', async ({ browserName }) => { await page.click('#add-piecewise-cell'); await page.locator('#piecewise-parameter-1 math-field.editable').type('y'); await page.locator('#piecewise-expression-1-0 math-field.editable').type('1'); await page.locator('#piecewise-expression-1-1 math-field.editable').type('\\inf'); await page.locator('#piecewise-condition-1-0 math-field.editable').type('x<0'); await page.locator('#cell-0 >> math-field.editable').type('y(-1<=x<=0)=') await page.waitForSelector('.status-footer', { state: 'detached' }); await expect(page.locator('#plot-expression-0-0 >> text=Results of expression does not evaluate to finite and real numeric values')).toBeAttached(); }); test('Test log x x-value spacing', async ({ browserName }) => { test.skip(browserName !== "firefox", "Copy-paste test is only working with firefox"); const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.setLatex(0, 'y=-x'); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.locator('#plot-expression-1-0 math-field.editable').type('y(1[in]<=x<=10000[in])with 3 points='); await page.locator('text=log x').click(); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('text=Copy Data').click(); await page.locator('text=Copied!').waitFor({state: "attached", timeout: 1000}); await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.locator('h1').press(modifierKey+'+v'); let clipboardContents = await page.locator('h1').textContent(); clipboardContents = clipboardContents.replace(/\s+/g, ''); // remove whitespace expect(clipboardContents).toBe('xy[in][m]1-0.0254100-2.5410000-254'); }); test('Test log x non-positive limit warning', async ({ browserName }) => { await page.setLatex(0, 'y=-x'); await page.locator('#add-plot-cell').click(); await expect(page.locator('#cell-1 >> math-field.editable')).toBeVisible(); await page.locator('#plot-expression-1-0 math-field.editable').type('y(0<=x<=10000)='); await page.locator('text=log x').click(); await page.waitForSelector('.status-footer', { state: 'detached' }); await page.locator('#plot-expression-1-0 >> text=Lower and/or upper limit less than or equal to zero').waitFor({state: 'attached', timeout: 1000}); }); ================================================ FILE: tests/test_sheet.epxyz ================================================ {"data":{"cells":[{"type":"documentation","id":4,"json":{"ops":[{"insert":"Introduction"},{"attributes":{"header":1},"insert":"\n"},{"insert":"This EngineeringPaper.xyz sheet shows how to calculated the maximum stress and displacement for a cantilever beam loaded by a vertical force at its end. The geometry of the beam is shown in the figure below. The beam has a rectangular cross section with height h and width b. The maximum stress in a cantilever with length much larger than its height is due to bending stress that occurs at the base of the beam. For a downward force, the maximum stress will be a tensile force at the top of the beam and a compressive stress at the bottom of the beam. For beam sections that are symmetric top to bottom, the maximum tensile and compressive stresses will have equal magnitude.\n"},{"insert":{"image":"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAA1oAAAHJCAYAAACcz0haAAAgAElEQVR4XuydB5gTxRvGv+SODgoWEFDAhgiCvSBgQywIUqX3XqWDVBHpXXrvvYMgUqQJKLa/KCiKqCACUgSp6iV3/3k3bm4vJLkkl+SyyTvPcw/KbXZnfjMb5p2vWZJUEzYSIAESIAESIAESIAESIAESIIGgEbBQaAWNJW9EAiRAAiRAAiRAAiRAAiRAAhoBCi0uBBIgARIgARIgARIgARIgARIIMgEKrSAD5e1IgARIgARIgARIgARIgARIgEKLa4AESIAESIAESIAESIAESIAEgkyAQivIQHk7EiABEiABEiABEiABEiABEqDQ4hogARIgARIgARIgARIgARIggSAToNAKMlDejgRIgARIgARIgARIgARIgAQotLgGSIAESIAESIAESIAESIAESCDIBCi0ggyUtyMBEiABEiABEiABEiABEiABCi2uARIgARIgARIgARIgARIgARIIMgEKrSAD5e1IgARIgARIgARIgARIgARIgEKLa4AESIAESIAESIAESIAESIAEgkyAQivIQHk7EiABEiABEiABEiABEiABEqDQ4hogARIgARIgARIgARIgARIggSAToNAKMlDejgRIgARIgARIgARIgARIgAQotLgGSIAESIAESIAESIAESIAESCDIBCi0ggyUtyMBEiABEiABEiABEiABEiABCi2uARIgARIgARIgARIgARIgARIIMgEKrSAD5e1IgARIgARIgARIgARIgARIgEKLa4AESIAESIAESIAESIAESIAEgkyAQivIQHk7EiABEiABEiABEiABEiABEqDQ4hogARIgARIgARIgARIgARIggSAToNAKMlDejgRIgARIgARIgARIgARIgAQotLgGSIAESIAESIAESIAESIAESCDIBCi0ggyUtyMBEiABEiABEiABEiABEiABCi2uARIgARIgARIgARIgARIgARIIMgEKrSAD5e1IgARIgARIgARIgARIgARIgEKLa4AESIAEQkRgxUd22ftNktx8o0jvJvEhekpk3vbfhCS58rfIDVlF4uIskdlJ9ooESIAESIAEQkiAQiuEcHlrEnBHoNlAm1y46PjNvQVFhrRNfQO+bpdd5q1Pct6uR2OrPH6/1XSA539gl7U7ksehDyCDQpA1s9qUZxe5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zSZPnpyhq3hnWJYOeicWQfMkKaGlioLKWr377rt2yimnRFj4XWgddNBBtmvXLicrV6dOnaDFmPlAAAIQgAAEIACBhAkMGzbMLr74YjvhhBPsgw8+SPg8vx6I0PJr5Lzvd1JCS4UulLWaOHGide/ePTI7iZM1a9bY559/bs2bN/f+rPN5WKZMGfvpp5+crFzt2rV95z8OQwACEIAABCAAgXQRQGiliyTjhJ0AQmvvHYDQCvu3AfOHAAQgAAEIQMAl8Morr9gll1xiJ554or3//vuBB0NGK/AhztkEkxJaKnShrNV7771nJ598csRpZYHWrl1rCxcutKOOOipnk0n1wqVKlbJffvnFycrVqlUr1WE4DwIQgAAEIAABCPieAELL9yFkAh4hgNDaGwiElkfuRtyAAAQgAAEIQCDnBF5++WXr16+fnXTSSTZp0qSc+5NpB8hoZZpweMdPSmipoqCyVvqm0zefa8oCrVu3zhYtWmTNmjXzHc0DDjjA8VlZuZo1a/rOfxyGAAQgAAEIQAAC6SIwdOhQ69+/v7N6SauYgm4IraBHOHfzS6vQ+uKLL6xp06a5m02KV3aFlsTiH8svmMoAACAASURBVP7whxRH4TQIQAACEIAABCDgfwIILf/HkBl4gwBCa28cXKH1+OOPmyorHnHEEVajRg1vRAgvIAABCEAAAhCAQBYJILSyCJtLBZpAUkJLpdu1PFAVaFSJxjV36aBfM1qVKlWybdu27RPoatWq2SGHHGKHHnqoNWjQwA4//HDn07BhQ6tSpUqgbwomBwEIQAACEIBAeAm89NJLNmDAAKeVj1r6BN1YOhj0COdufikJLTWvUxM717Svaf369bZ48WJr0qRJ7maT4pUnTJhg77zzjn399df2zTffOP201Fcrlmm+Bx98sCPADjvssH1EWIUKFVL0gtMgAAEIQAACEIBA7gkMGTLELr30UjvllFPs3Xffzb1DGfYAoZVhwCEePimhpdLtylpNnjzZunXrFsGmfU0bNmywJUuW2JFHHul7nD///LMjtiS8NKdly5bZt99+a999952tXr06rggTi3r16ln9+vWdjFjjxo0d8anliHl5eb5nwwQgAAEIQAACEAg2gRdffNEuu+wyO/XUU00vo4NuCK2gRzh380NoJcl+586d9uWXX9pXX33lfCTG9Fm1apXThyueSXjpoyxY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"}},{"attributes":{"header":1},"insert":"\n\n"},{"insert":"Select Beam Material"},{"attributes":{"header":1},"insert":"\n"}]}},{"type":"table","id":5,"rowLabels":["Steel","Aluminum"],"nextRowLabelId":3,"parameterLatexs":["E","\\rho"],"nextParameterId":3,"parameterUnitLatexs":["\\left[GPa\\right]","\\left[\\frac{kg}{m^{3}}\\right]"],"rhsLatexs":[["206.8","7800"],["71.7","2800"]],"selectedRow":1,"rowJsons":[]},{"type":"documentation","id":3,"json":{"ops":[{"insert":"Select Beam Section"},{"attributes":{"header":1},"insert":"\n"}]}},{"type":"table","id":1,"rowLabels":["Filled Circle","Hollow Circle","Ellipse","Rectangle","Hollow Rectangle"],"nextRowLabelId":6,"parameterLatexs":["I_{x}","c","r","r_{1}","r_{2}","a","b","h","b_{1}","h_{1}"],"nextParameterId":6,"parameterUnitLatexs":["","","\\left[mm\\right]","\\left[mm\\right]","\\left[mm\\right]","\\left[mm\\right]","\\left[mm\\right]","\\left[mm\\right]","\\left[mm\\right]","\\left[mm\\right]"],"rhsLatexs":[["\\frac{\\pi}{4}\\cdot r^{4}","r","37.5","","","","","","",""],["\\frac{\\pi}{4}\\cdot\\left(r_{2}^{4}-r_{1}^{4}\\right)","r_{2}","","27.5","37.5","","","","",""],["\\frac{\\pi}{4}\\cdot a\\cdot b^{3}","b","","","","27.5","37.5","","",""],["\\frac{b\\cdot h^{3}}{12}","\\frac{h}{2}","","","","","50","75","",""],["\\frac{b\\cdot h^{3}-b_{1}\\cdot h_{1}^{3}}{12}","\\frac{h}{2}","","","","","50","75","30","55"]],"selectedRow":3,"rowJsons":[{"ops":[{"attributes":{"alt":"Moment of area of a circle.svg","height":"230","width":"230"},"insert":{"image":"https://upload.wikimedia.org/wikipedia/commons/thumb/a/a7/Moment_of_area_of_a_circle.svg/230px-Moment_of_area_of_a_circle.svg.png"}},{"insert":"\n"}]},{"ops":[{"attributes":{"alt":"Moment of area of an annulus.svg","height":"230","width":"230"},"insert":{"image":"https://upload.wikimedia.org/wikipedia/commons/thumb/6/6e/Moment_of_area_of_an_annulus.svg/230px-Moment_of_area_of_an_annulus.svg.png"}},{"insert":"\n"}]},{"ops":[{"attributes":{"alt":"Moment of area of an ellipse.svg","height":"230","width":"230"},"insert":{"image":"https://upload.wikimedia.org/wikipedia/commons/thumb/c/c0/Moment_of_area_of_an_ellipse.svg/230px-Moment_of_area_of_an_ellipse.svg.png"}},{"insert":"\n"}]},{"ops":[{"attributes":{"alt":"Moment of area of a rectangle through the centroid.svg","height":"230","width":"230"},"insert":{"image":"https://upload.wikimedia.org/wikipedia/commons/thumb/8/82/Moment_of_area_of_a_rectangle_through_the_centroid.svg/230px-Moment_of_area_of_a_rectangle_through_the_centroid.svg.png"}},{"insert":"\n"}]},{"ops":[{"attributes":{"alt":"Moment of area of a hollow rectangle.svg","height":"230","width":"230"},"insert":{"image":"https://upload.wikimedia.org/wikipedia/commons/thumb/a/a2/Moment_of_area_of_a_hollow_rectangle.svg/230px-Moment_of_area_of_a_hollow_rectangle.svg.png"}},{"insert":"\n"}]}]},{"type":"documentation","id":2,"json":{"ops":[{"insert":"Source for beam section equations and images: "},{"attributes":{"link":"https://en.wikipedia.org/wiki/List_of_second_moments_of_area"},"insert":"https://en.wikipedia.org/wiki/List_of_second_moments_of_area"},{"insert":"\n"}]}},{"type":"documentation","id":7,"json":{"ops":[{"insert":"Define the Other Beam Parameters"},{"attributes":{"header":1},"insert":"\n"}]}},{"type":"math","id":6,"latex":"l=500\\left[mm\\right]"},{"type":"math","id":8,"latex":"F=500\\left[N\\right]"},{"type":"documentation","id":9,"json":{"ops":[{"insert":"Define the Deflection and Stress Equations"},{"attributes":{"header":1},"insert":"\n"},{"insert":"The maximum displacement of a cantilever beam loaded at its end is defined by [1]:\n"}]}},{"type":"math","id":10,"latex":"y_{max}=-\\frac{F\\cdot l^{3}}{3\\cdot E\\cdot I_{x}}"},{"type":"documentation","id":12,"json":{"ops":[{"insert":"where Ix is the area moment of inertia of the cross section about the x-axis as selected in the table above. The maximum displacement can now be queried:\n"}]}},{"type":"math","id":11,"latex":"y_{max}=\\left[mm\\right]"},{"type":"documentation","id":13,"json":{"ops":[{"insert":"The maximum bending stress in a beam section is given by:\n"}]}},{"type":"math","id":14,"latex":"\\sigma_{max}=\\frac{M\\cdot c}{I_{x}}"},{"type":"documentation","id":15,"json":{"ops":[{"insert":"where M is the bending moment at the section of interest and c is distance from the neutral axis of the beam to the top or bottom of the beam. The maximum moment occurs at the base of the beam and is defined by:\n"}]}},{"type":"math","id":16,"latex":"M=l\\cdot F"},{"type":"documentation","id":17,"json":{"ops":[{"insert":"where l is the length of the beam. Now that everything is defined, the maximum stress can be queried and converted to [MPa] units:\n"}]}},{"type":"math","id":18,"latex":"\\sigma_{max}=\\left[MPa\\right]"},{"type":"documentation","id":20,"json":{"ops":[{"insert":"These results can be compared to the results obtained from a finite element analysis using SolidWorks. The beam has the same dimensions, loading, and material as the rectangular cross-section and the aluminum table options above. The displacement plot is shown below. The maximum displacement magnitude obtained using finite element analysis is .175 [mm], which is close to the .165 [mm] obtained using the equations above.\n"},{"insert":{"image":"data:image/png;base64,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"}},{"insert":"\n\nSimilarly, the maximum stress calculation can be compared to the SolidWorks results. The maximum stress obtained from SolidWorks is 6.5 [MPa] as shown below. Note that this is higher than the 5.3 [MPa] obtained using the beam equation. This is the result of the stress concentration that occurs at the based of the cantilever where it meets the fixed boundary condition. A littler further from the fixed boundary condition, the finite element values are close to the calculated values.\n"},{"insert":{"image":"data:image/png;base64,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"}},{"insert":"\n\n[1] Norton, R. L. \""},{"attributes":{"link":"https://www.pearson.com/us/higher-education/program/Norton-Machine-Design-5th-Edition/PGM275676.html"},"insert":"Machine design. A integrated approach, 5th Editi."},{"insert":"\" (2013).\n"}]}},{"type":"math","id":21,"latex":"y=\\frac{F}{6\\cdot E\\cdot I_{x}}\\cdot\\left(x^{3}-3\\cdot l\\cdot x^{2}\\right)"},{"type":"plot","id":22,"latexs":["y\\left(0\\left[mm\\right]\\le x\\le l\\right)=\\left[mm\\right]"],"logX":false,"logY":false}],"title":"Database Consistency Test 7","results":[null,null,null,null,null,null,{"value":"","units":"","numeric":false,"real":false,"finite":false},{"value":"","units":"","numeric":false,"real":false,"finite":false},null,{"value":"","units":"","numeric":false,"real":false,"finite":false},null,{"value":"-0.000165297794307557","numeric":true,"units":"m","unitsLatex":"\\left[ m\\right] ","real":true,"finite":true,"userUnitsValueDefined":true,"userUnitsValue":-0.165297794307557,"unitsMismatch":false},null,{"value":"","units":"","numeric":false,"real":false,"finite":false},null,{"value":"","units":"","numeric":false,"real":false,"finite":false},null,{"value":"5333333.33333333","numeric":true,"units":"Pa","unitsLatex":"\\left[ Pa\\right] ","real":true,"finite":true,"userUnitsValueDefined":true,"userUnitsValue":5.33333333333333,"unitsMismatch":false},null,{"value":"","units":"","numeric":false,"real":false,"finite":false},[{"plot":true,"data":[{"numericOutput":true,"numericInput":true,"limitsUnitsMatch":true,"input":[0,0.01,0.02,0.03,0.04,0.05,0.060000000000000005,0.07,0.08,0.09,0.09999999999999999,0.10999999999999999,0.11999999999999998,0.12999999999999998,0.13999999999999999,0.15,0.16,0.17,0.18000000000000002,0.19000000000000003,0.20000000000000004,0.21000000000000005,0.22000000000000006,0.23000000000000007,0.24000000000000007,0.25000000000000006,0.26000000000000006,0.2700000000000001,0.2800000000000001,0.2900000000000001,0.3000000000000001,0.3100000000000001,0.3200000000000001,0.3300000000000001,0.34000000000000014,0.35000000000000014,0.36000000000000015,0.37000000000000016,0.38000000000000017,0.3900000000000002,0.4000000000000002,0.4100000000000002,0.4200000000000002,0.4300000000000002,0.4400000000000002,0.45000000000000023,0.46000000000000024,0.47000000000000025,0.48000000000000026,0.49000000000000027,0.5000000000000002],"output":[0,-9.85174854073041e-8,-3.914251769202955e-7,-8.747559274755928e-7,-0.0000015445425900098147,-0.00000239681801745958,-0.000003427615062761507,-0.000004632966578852214,-0.00000600890541866832,-0.000007551464435146442,-0.000009256676481223202,-0.000011120574409835217,-0.000013139191073919105,-0.000015308559326411484,-0.000017624712020248977,-0.0000200836820083682,-0.000022681502143705772,-0.000025414205279198307,-0.000028277824267782427,-0.000031268391962394765,-0.00003438194121597191,-0.0000376145048814505,-0.00004096211581176715,-0.00004442080685985848,-0.00004798661087866111,-0.000051655560721111645,-0.00005542368924014673,-0.00005928702928870295,-0.00006324161371971696,-0.00006728347538612535,-0.00007140864714086476,-0.0000756131618368718,-0.00007989305232708306,-0.0000842443514644352,-0.00008866309210186483,-0.00009314530709230854,-0.00009768702928870298,-0.0001022842915439848,-0.00010693312671109054,-0.00011162956764295686,-0.00011636964719252037,-0.0001211493982127177,-0.00012596485355648542,-0.00013081204607676025,-0.0001356870086264787,-0.00014058577405857753,-0.0001455043752259932,-0.0001504388449816624,-0.00015538521617852174,-0.00016033952166950784,-0.0001652977943075573],"inputReversed":false,"inputUnits":"m","inputUnitsLatex":"\\left[ m\\right] ","inputName":"x","outputUnits":"m","outputUnitsLatex":"\\left[ m\\right] ","outputName":"y","unitsMismatch":false,"displayInput":[0,10,20,30,40,50,60,70,80,90,99.99999999999999,109.99999999999999,119.99999999999999,129.99999999999997,139.99999999999997,150,160,170,180.00000000000003,190.00000000000003,200.00000000000003,210.00000000000006,220.00000000000006,230.00000000000006,240.00000000000006,250.00000000000006,260.00000000000006,270.00000000000006,280.00000000000006,290.00000000000006,300.0000000000001,310.0000000000001,320.0000000000001,330.0000000000001,340.0000000000001,350.0000000000001,360.00000000000017,370.00000000000017,380.00000000000017,390.00000000000017,400.00000000000017,410.00000000000017,420.00000000000017,430.0000000000002,440.0000000000002,450.0000000000002,460.0000000000002,470.0000000000002,480.0000000000002,490.0000000000003,500.0000000000002],"displayInputUnits":"mm","displayOutput":[0,-0.00009851748540730409,-0.0003914251769202955,-0.0008747559274755928,-0.0015445425900098148,-0.00239681801745958,-0.003427615062761507,-0.004632966578852214,-0.00600890541866832,-0.007551464435146442,-0.009256676481223202,-0.011120574409835216,-0.013139191073919105,-0.015308559326411484,-0.017624712020248977,-0.0200836820083682,-0.022681502143705772,-0.025414205279198306,-0.028277824267782425,-0.03126839196239476,-0.034381941215971906,-0.037614504881450496,-0.04096211581176715,-0.044420806859858476,-0.04798661087866111,-0.051655560721111646,-0.05542368924014673,-0.05928702928870295,-0.06324161371971695,-0.06728347538612535,-0.07140864714086476,-0.07561316183687179,-0.07989305232708306,-0.0842443514644352,-0.08866309210186483,-0.09314530709230853,-0.09768702928870297,-0.10228429154398479,-0.10693312671109054,-0.11162956764295685,-0.11636964719252037,-0.1211493982127177,-0.12596485355648543,-0.13081204607676025,-0.1356870086264787,-0.14058577405857753,-0.1455043752259932,-0.1504388449816624,-0.15538521617852175,-0.16033952166950785,-0.16529779430755728],"displayOutputUnits":"mm"}]}]],"system_results":[],"nextId":24,"sheetId":"{\"0\":228456294,\"1\":2090695981,\"2\":4291195441,\"3\":3693821582,\"4\":2989172876,\"5\":1841127001,\"6\":3157897485,\"7\":3586529369,\"8\":1008036957,\"9\":2372012744}","insertedSheets":[]},"history":[{"url":"Database Consistency Test 7","hash":"file","creation":"2023-02-10T04:25:21.891Z"},{"url":"file","hash":"file","creation":"2023-02-09T03:38:57.939Z"},{"url":"file","hash":"file","creation":"2023-02-08T22:52:50.843Z"},{"url":"file","hash":"file","creation":"2023-02-08T22:51:44.723Z"},{"url":"file","hash":"file","creation":"2023-02-08T17:37:00.308Z"},{"url":"https://engineeringpaper.xyz/#2kftdqNYyiaqAEyhXboNZF","hash":"2kftdqNYyiaqAEyhXboNZF","creation":"2022-06-14T15:47:35.455971Z"},{"url":"https://engineeringpaper.xyz/#QsPdmAWHQNwz9rxPrT3PYk","hash":"QsPdmAWHQNwz9rxPrT3PYk","creation":"2022-06-08T20:04:54.562675Z"},{"url":"https://engineeringpaper.xyz/#d5DEM9teTxodvCTwENwErn","hash":"d5DEM9teTxodvCTwENwErn","creation":"2022-06-08T13:11:26.795400Z"},{"url":"https://engineeringpaper.xyz/#bPX72mmrNjVsgZbos25Gkw","hash":"bPX72mmrNjVsgZbos25Gkw","creation":"2022-06-08T12:52:40.806473Z"},{"url":"https://engineeringpaper.xyz/#WWDzaCSbmXrJp2PhyPEbTF","hash":"WWDzaCSbmXrJp2PhyPEbTF","creation":"2022-06-07T21:47:32.771678Z"}]} ================================================ FILE: tests/test_sheet_long_calculation.epxyz ================================================ {"data":{"config":{"mathCellConfig":{"symbolicOutput":false,"formatOptions":{"notation":"auto","precision":15,"lowerExp":-3,"upperExp":5}}},"cells":[{"type":"math","id":0,"latex":"J\\:=\\:\\frac{1}{\\pi}\\cdot\\int_0^{\\pi}\\left(\\cos\\left(n\\cdot\\tau\\:-\\:x\\cdot\\sin\\left(\\tau\\right)\\right)\\right)\\mathrm{d}\\left(\\tau\\right)","config":null},{"type":"math","id":1,"latex":"J\\left(n=1,\\:x=1\\right)=","config":null}],"title":"New Sheet","results":[{"value":"","symbolicValue":"","units":"","unitsLatex":"","numeric":false,"real":false,"finite":false},{"value":"0.4400505857449335159596822037189149131273723019927652511367581718","symbolicValue":"\\frac{\\int\\limits_{0}^{\\pi} \\cos{\\left(\\tau - \\sin{\\left(\\tau \\right)} \\right)}\\, d\\tau}{\\pi}","numeric":true,"units":"","unitsLatex":"","real":true,"finite":true}],"system_results":[],"nextId":8,"sheetId":"7b94cb14-b859-452a-988c-49d373397535","insertedSheets":[]},"history":[{"url":"New Sheet","hash":"file","creation":"2023-06-10T19:43:04.984Z"},{"url":"New Sheet","hash":"file","creation":"2023-06-10T19:42:35.602Z"}]} ================================================ FILE: tests/test_sheet_parsing_error.epxyz ================================================ {"data":{"cells":[{"type":"math","id":0,"latex":"x=5.11"},{"type":"math","id":2,"latex":"x="},{"type":"math","id":1,"latex":"a"}],"title":"New Sheet","results":[{"value":"","units":"","unitsLatex":"","numeric":false,"real":false,"finite":false},{"value":"5.11","numeric":true,"units":"","unitsLatex":"","real":true,"finite":true},{"value":"","units":"","unitsLatex":"","numeric":false,"real":false,"finite":false}],"system_results":[],"nextId":3,"sheetId":"3d542447-c7dc-4b37-950a-22d5c5473893","insertedSheets":[]},"history":[{"url":"New Sheet","hash":"file","creation":"2023-03-10T16:45:15.029Z"},{"url":"New Sheet","hash":"file","creation":"2023-03-10T16:43:50.454Z"},{"url":"http://localhost:8788/NTFzvd6cJxjQ8tWqQLzuy2","hash":"NTFzvd6cJxjQ8tWqQLzuy2","creation":"2023-03-10T16:39:25.698Z"},{"url":"New Sheet","hash":"file","creation":"2023-03-10T16:39:06.660Z"}]} ================================================ FILE: tests/test_sheet_slow_simplify.epxyz ================================================ {"data":{"version":20250705,"config":{"mathCellConfig":{"symbolicOutput":false,"showIntermediateResults":false,"formatOptions":{"notation":"fixed","precision":3,"lowerExp":-3,"upperExp":5}},"customBaseUnits":{"mass":"lbm","length":"in","time":"s","current":"A","temperature":"degR","luminous_intensity":"cd","amount_of_substance":"mol","force":"lbf","area":"in^2","volume":"in^3","energy":"BTU","power":"hp","pressure":"psi","charge":"C","capacitance":"F","electric_potential":"V","resistance":"ohm","inductance":"H","conductance":"S","magnetic_flux":"Wb","magnetic_flux_density":"T","angle":"rad","information":"b"},"simplifySymbolicExpressions":true,"convertFloatsToFractions":true,"fluidConfig":{"fluid":"Water","incompMixConc":0.5,"customMixture":[{"fluid":"R32","moleFraction":0.697615},{"fluid":"R125","moleFraction":0.302385}]}},"cells":[{"type":"documentation","id":84,"json":{"ops":[{"insert":{"image":"data:image/png;base64,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"}},{"insert":"\n"}]}},{"type":"math","id":0,"latex":"\\text{Truss Loads:}\\:\\:\\:\\:F_1=342.8\\left\\lbrack lbf\\right\\rbrack,F_2=272.52\\left\\lbrack lbf\\right\\rbrack,F_3=386.57\\left\\lbrack lbf\\right\\rbrack,F_4=236.22\\left\\lbrack lbf\\right\\rbrack","config":null},{"type":"math","id":3,"latex":"\\text{Bottom Chord: }\\alpha=22.620\\left\\lbrack deg\\right\\rbrack,\\text{Top Chord:}\\beta=36.870\\left\\lbrack deg\\right\\rbrack,\\text{Diagonals:}\\gamma=51.12\\left\\lbrack deg\\right\\rbrack,\\delta=63.798\\left\\lbrack deg\\right\\rbrack","config":null},{"type":"math","id":4,"latex":"\\text{Reactions at Left and Right Supports:}\\:\\:\\:\\:R_{L}=\\frac{2\\cdot F_1+2\\cdot F_2+2\\cdot F_3+F_4}{2}=","config":null},{"type":"math","id":5,"latex":"R_{R}=R_{L}=","config":null},{"type":"documentation","id":11,"json":{"ops":[{"attributes":{"bold":true},"insert":"JOINT A"},{"insert":"\n"}]}},{"type":"system","id":8,"parameterListLatex":"AB,AC","expressionLatexs":["-AB\\cdot\\sin\\left(\\beta\\right)+AC\\cdot\\sin\\left(\\alpha\\right)+R_{L}-F_1=0","-AB\\cdot\\cos\\left(\\beta\\right)+AC\\cdot\\cos\\left(\\alpha\\right)=0"],"selectedSolution":0},{"type":"math","id":9,"latex":"\\text{Compression:}\\:\\:\\:\\:AB=","config":null},{"type":"math","id":10,"latex":"\\text{Tension:}\\:\\:\\:\\:\\:\\:\\:\\:\\:\\:\\:\\:\\:\\:AC=","config":null},{"type":"documentation","id":20,"json":{"ops":[{"attributes":{"bold":true},"insert":"JOINT B"},{"insert":"\n"}]}},{"type":"system","id":21,"parameterListLatex":"BC,BD","expressionLatexs":["AB\\cdot\\sin\\left(\\beta\\right)-F_2-BD\\cdot\\sin\\left(\\beta\\right)+BC\\cdot\\cos\\left(\\beta\\right)=0","AB\\cdot\\cos\\left(\\beta\\right)-BD\\cdot\\cos\\left(\\beta\\right)-BC\\cdot\\sin\\left(\\beta\\right)=0"],"selectedSolution":0},{"type":"math","id":22,"latex":"BC=","config":null},{"type":"math","id":23,"latex":"BD=","config":null},{"type":"documentation","id":32,"json":{"ops":[{"attributes":{"bold":true},"insert":"JOINT C"},{"insert":" Diagonal CD angle from vertical = 36.87 deg\n"}]}},{"type":"system","id":35,"parameterListLatex":"CD,CE","expressionLatexs":["-AC\\cdot\\sin\\left(\\alpha\\right)-BC\\cdot\\cos\\left(\\beta\\right)+CE\\cdot\\sin\\left(\\alpha\\right)+CD\\cdot\\sin\\left(\\gamma\\right)=0","-AC\\cdot\\cos\\left(\\alpha\\right)+BC\\cdot\\sin\\left(\\beta\\right)+CE\\cdot\\cos\\left(\\alpha\\right)+CD\\cdot\\cos\\left(\\gamma\\right)=0"],"selectedSolution":0},{"type":"math","id":36,"latex":"\\text{Tension:}\\:\\:\\:CD=","config":null},{"type":"math","id":37,"latex":"\\text{Tension:}\\:\\:\\:CE=","config":null},{"type":"documentation","id":47,"json":{"ops":[{"attributes":{"bold":true},"insert":"JOINT D"},{"insert":"\n"}]}},{"type":"system","id":49,"parameterListLatex":"DE,DF","expressionLatexs":["BD\\cdot\\sin\\left(\\beta\\right)-F_3-CD\\cdot\\sin\\left(\\gamma\\right)+DE\\cdot\\sin\\left(\\beta\\right)-DF\\cdot\\sin\\left(\\beta\\right)=0","BD\\cdot\\cos\\left(\\beta\\right)-CD\\cdot\\cos\\left(\\gamma\\right)-DE\\cdot\\cos\\left(\\beta\\right)-DF\\cdot\\cos\\left(\\beta\\right)=0"],"selectedSolution":0},{"type":"math","id":50,"latex":"\\text{Compression:}\\:\\:DE=","config":null},{"type":"math","id":51,"latex":"\\text{Compression:}\\:\\:\\:DF=","config":null},{"type":"documentation","id":60,"json":{"ops":[{"attributes":{"bold":true},"insert":"JOINT E"},{"insert":"\n"}]}},{"type":"system","id":61,"parameterListLatex":"EF,EG","expressionLatexs":["-CE\\cdot\\sin\\left(\\alpha\\right)-DE\\cdot\\cos\\left(\\beta\\right)-EF\\cdot\\sin\\left(\\delta\\right)+EG\\cdot\\sin\\left(\\alpha\\right)=0","-CE\\cdot\\cos\\left(\\alpha\\right)+DE\\cdot\\sin\\left(\\beta\\right)-EF\\cdot\\cos\\left(\\delta\\right)+EG\\cdot\\cos\\left(\\alpha\\right)=0"],"selectedSolution":0},{"type":"math","id":62,"latex":"\\text{Compression:}\\:\\:\\:EF=","config":null},{"type":"math","id":63,"latex":"\\text{Tension:}\\:\\:EG=","config":null},{"type":"math","id":68,"latex":"\\text{Vertical force:}\\:\\:\\:EG\\cdot\\sin\\left(\\alpha\\right)=","config":null},{"type":"math","id":69,"latex":"\\text{Horizontal force:}\\:\\:EG\\cdot\\cos\\left(\\alpha\\right)=","config":null},{"type":"math","id":70,"latex":"\\text{Vertical force:}\\:\\:\\:EF\\cdot\\sin\\left(\\delta\\right)=","config":null},{"type":"math","id":71,"latex":"\\text{Horizontal force:}\\:\\:\\:EF\\cdot\\cos\\left(\\delta\\right)=","config":null},{"type":"documentation","id":72,"json":{"ops":[{"attributes":{"bold":true},"insert":"JOINT G"},{"insert":"\n"}]}},{"type":"math","id":76,"latex":"\\text{Tension:}\\:\\:\\:FG=EG\\cdot\\sin\\left(\\alpha\\right)=","config":null},{"type":"documentation","id":77,"json":{"ops":[{"attributes":{"bold":true},"insert":"JOINT F Summation forces =0"},{"insert":"\n"}]}},{"type":"math","id":82,"latex":"DF\\cdot\\sin\\left(\\beta\\right)-F_4-FG+EF\\cdot\\cos\\left(\\delta\\right)=","config":null}],"title":"Scissors Truss Analysis","results":[],"system_results":[null,null,null,null,null,null,{"error":null,"solutions":{"AB":["- \\frac{F_1 \\cdot \\cos{\\left(\\alpha \\right)}}{- \\sin{\\left(\\alpha \\right)} \\cdot \\cos{\\left(\\beta \\right)} + \\sin{\\left(\\beta \\right)} \\cdot \\cos{\\left(\\alpha \\right)}} + \\frac{R_{L} \\cdot \\cos{\\left(\\alpha \\right)}}{- \\sin{\\left(\\alpha \\right)} \\cdot \\cos{\\left(\\beta \\right)} + \\sin{\\left(\\beta \\right)} \\cdot \\cos{\\left(\\alpha \\right)}}"],"AC":["- \\frac{F_1 \\cdot \\cos{\\left(\\beta \\right)}}{- \\sin{\\left(\\alpha \\right)} \\cdot \\cos{\\left(\\beta \\right)} + \\sin{\\left(\\beta \\right)} \\cdot \\cos{\\left(\\alpha \\right)}} + \\frac{R_{L} \\cdot \\cos{\\left(\\beta \\right)}}{- \\sin{\\left(\\alpha \\right)} \\cdot \\cos{\\left(\\beta \\right)} + \\sin{\\left(\\beta \\right)} \\cdot \\cos{\\left(\\alpha \\right)}}"]},"selectedSolution":0},null,null,null,{"error":null,"solutions":{"BC":["\\frac{F_2 \\cdot \\cos{\\left(\\beta \\right)}}{\\sin^{2}{\\left(\\beta \\right)} + \\cos^{2}{\\left(\\beta \\right)}}"],"BD":["\\frac{AB \\cdot \\sin^{2}{\\left(\\beta \\right)}}{\\sin^{2}{\\left(\\beta \\right)} + \\cos^{2}{\\left(\\beta \\right)}} + \\frac{AB \\cdot \\cos^{2}{\\left(\\beta \\right)}}{\\sin^{2}{\\left(\\beta \\right)} + \\cos^{2}{\\left(\\beta \\right)}} - \\frac{F_2 \\cdot \\sin{\\left(\\beta \\right)}}{\\sin^{2}{\\left(\\beta \\right)} + \\cos^{2}{\\left(\\beta \\right)}}"]},"selectedSolution":0},null,null,null,{"error":null,"solutions":{"CD":["\\frac{BC \\cdot \\sin{\\left(\\alpha \\right)} \\cdot \\sin{\\left(\\beta \\right)}}{- \\sin{\\left(\\alpha \\right)} \\cdot \\cos{\\left(\\gamma \\right)} + \\sin{\\left(\\gamma \\right)} \\cdot \\cos{\\left(\\alpha \\right)}} + \\frac{BC \\cdot \\cos{\\left(\\alpha \\right)} \\cdot \\cos{\\left(\\beta \\right)}}{- \\sin{\\left(\\alpha \\right)} \\cdot \\cos{\\left(\\gamma \\right)} + \\sin{\\left(\\gamma \\right)} \\cdot \\cos{\\left(\\alpha \\right)}}"],"CE":["- \\frac{AC \\cdot \\sin{\\left(\\alpha \\right)} \\cdot \\cos{\\left(\\gamma \\right)}}{- \\sin{\\left(\\alpha \\right)} \\cdot \\cos{\\left(\\gamma \\right)} + \\sin{\\left(\\gamma \\right)} \\cdot \\cos{\\left(\\alpha \\right)}} + \\frac{AC \\cdot \\sin{\\left(\\gamma \\right)} \\cdot \\cos{\\left(\\alpha \\right)}}{- \\sin{\\left(\\alpha \\right)} \\cdot \\cos{\\left(\\gamma \\right)} + \\sin{\\left(\\gamma \\right)} \\cdot \\cos{\\left(\\alpha \\right)}} - \\frac{BC \\cdot \\sin{\\left(\\beta \\right)} \\cdot \\sin{\\left(\\gamma \\right)}}{- \\sin{\\left(\\alpha \\right)} \\cdot \\cos{\\left(\\gamma \\right)} + \\sin{\\left(\\gamma \\right)} \\cdot \\cos{\\left(\\alpha \\right)}} - \\frac{BC \\cdot \\cos{\\left(\\beta \\right)} \\cdot \\cos{\\left(\\gamma \\right)}}{- \\sin{\\left(\\alpha \\right)} \\cdot \\cos{\\left(\\gamma \\right)} + \\sin{\\left(\\gamma \\right)} \\cdot \\cos{\\left(\\alpha \\right)}}"]},"selectedSolution":0},null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null],"codeCellResults":{},"sub_results":[],"nextId":123,"sheetId":"61b49a0d-6d15-4a82-a9ae-6f3e1144060d","insertedSheets":[]},"history":[{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-12T20:04:57.921Z"},{"url":"https://engineeringpaper.xyz/uo767Ltca9fZHkAoyapbDi","hash":"uo767Ltca9fZHkAoyapbDi","creation":"2025-08-12T14:04:11.074Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-09T23:32:01.905Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-09T23:19:56.256Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-09T22:59:02.032Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-09T22:35:14.150Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-09T22:03:20.836Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-09T21:13:07.516Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-09T20:49:58.252Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-08T22:48:45.181Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-08T22:46:40.176Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-08T22:38:54.009Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-07T21:24:25.140Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-04T23:40:29.257Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-04T23:40:07.654Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-04T22:58:47.069Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-03T19:52:03.119Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-03T00:49:03.249Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-08-03T00:48:18.601Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-29T14:50:13.834Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-29T14:43:34.477Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-28T20:44:30.125Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-28T20:43:45.927Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-28T20:11:28.646Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-28T15:02:48.116Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-28T14:15:58.661Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-27T21:16:59.948Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-27T01:02:31.945Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T21:20:27.944Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T21:17:21.774Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T21:02:46.269Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T21:01:41.394Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:53:46.505Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:53:05.772Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:50:56.032Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:43:45.090Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:38:24.175Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:37:06.703Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:32:09.711Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:25:38.875Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:24:31.883Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:23:49.132Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:15:43.982Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:14:58.637Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:08:45.012Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:03:04.603Z"},{"url":"Scissors Truss Analysis","hash":"file","creation":"2025-07-26T20:02:01.001Z"}]} ================================================ FILE: tests/test_sheet_with_results.epxyz ================================================ {"data":{"config":{"mathCellConfig":{"symbolicOutput":false,"formatOptions":{"notation":"auto","precision":5,"lowerExp":-3,"upperExp":5},"showIntermediateResults":false},"customBaseUnits":{"mass":"kg","length":"m","time":"s","current":"A","temperature":"K","luminous_intensity":"cd","amount_of_substance":"mol","force":"N","area":"m^2","volume":"m^3","energy":"J","power":"W","pressure":"Pa","charge":"C","capacitance":"F","electric_potential":"V","resistance":"ohm","inductance":"H","conductance":"S","magnetic_flux":"Wb","magnetic_flux_density":"T","angle":"rad","information":"b"},"simplifySymbolicExpressions":true,"convertFloatsToFractions":true,"fluidConfig":{"fluid":"Water","incompMixConc":0.5,"customMixture":[{"fluid":"R32","moleFraction":0.697615},{"fluid":"R125","moleFraction":0.302385}]}},"cells":[{"type":"math","id":65,"latex":"2=","config":null},{"type":"documentation","id":1,"json":{"ops":[{"insert":"This example sheet calculates the contact stress between two spheres in contact. Reference: "},{"attributes":{"link":"https://lccn.loc.gov/2015460223"},"insert":"Norton, "},{"attributes":{"link":"https://lccn.loc.gov/2015460223","italic":true},"insert":"Machine Design,"},{"attributes":{"link":"https://lccn.loc.gov/2015460223"},"insert":" 5th Edition"},{"insert":"\n"},{"insert":{"image":"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAA58AAAFsCAYAAABLiA3iAAAACXBIWXMAABcRAAAXEQHKJvM/AAAAGXRFWHRTb2Z0d2FyZQB3d3cuaW5rc2NhcGUub3Jnm+48GgAAIABJREFUeJzs3Xd8VfX9x/HX52ZB2HuJ7CU4QBSLA/fCragooj+1rtpa21prqx222mFba221Qy2KtqBW60JRlqLFBWhRQPbem2yS+/n9cU5CCDeQhCTnJryfj0cekHPP+NwkhPM538/38zV3R0RERERERKQmxaIOQEREREREROo/JZ8iIiIiIiJS45R8ioiIiIiISI1T8ikiIiIiIiI1TsmniIiIiIiI1DglnyIiIiIiIlLjlHyKiIiIiIhIjVPyKSIiIiIiIjVOyaeIiIiIiIjUOCWfIiIiIiIiUuOUfIqIiIiIiEiNU/IpIiIiIiIiNU7Jp4iIiIiIiNS41KgDEBERERGRwD/NehVBx/DTede4b4g0IJFqpJFPEREREZEkUQR3GUwzmBaD06OOR6Q6KfkUERERERGRGqeyWxERERGROuQ5s6YGKfvbbyFs/4l7vDZiEqkIJZ8iIiIiInWIw4sOhwGdgB1AUZldDGh8GDQFcms7PpHyqOxWRERERKQOGeV+JvAKQBy6j3JvWfojDsOAuSPclXhKUlHyKSIiIiJSxxgMBJaPdt9c9rVUSAP+XPtRieybym5FREREROqQF8xSHI4E3i69fZxZ511wwTXufwZmRhOdSPk08ikiIiIiUofkQF8g08skmEUwLAZDIgpLZL808ikiIiIiUofEYBCAwc+fNft56dccvhNNVCL7p+RTRERERKQOCed7UggdrnNfV7z9WbNpBrOji0xk31R2KyIiIiJStwwE1pZOPENvG8yKIiCRitDIp4iIiIhIXWFmwECH6WVfGuX+YAQRiVSYRj5FREREROqIf0JPoBka4ZQ6SMmniIiIiEgd4bubDWlup9Q5KrsVEREREUlyz5i1isFEoF246cFnze51GHaNe3aUsYlUlJJPEREREZEk1xC27YIzSm8rAL9OiafUIUo+RURERESS3Aj3ImBr1HGIHAjN+RQREREREZEap+RTREREREREapySTxEREREREalxSj5FRERERESkxin5FBERERERkRqn5FNERERERERqnJJPERERERERqXFKPkVERERERKTGKfkUERERERGRGqfkU0RERERERGqckk8RERERERGpcUo+RUREREREpMYp+RQREREREZEap+RTRERERKSW/dPs2H+Zta7scWPNBo81a1sTMYnUNCWfIiIiIiK1zGFNEUyqTAL6rNkgg8evcd9Qk7GJ1BQlnyIiIiIitexq91VArAgmVyQBfdZskMM7DjNqITyRGqHkU0REREQkAgZvAkcUwXtjzNqXt19x4mnQMhYcI1InKfkUEREREYmA704k+6XClEQJaOnEE8jNhndrN0qR6qPkU+odMxtqZrdFHYeIiIjIvuTAB8D28NN+qTAFyCx+3aBrqcQTYNpN7jm1HadIdVHyKfVRW6Bv1EGIiIiI7MtN7rsMJpfa1M9gePEncbinVOJZXKYrUmcp+RQRERERiYjvnVA2d9gI5AGNS79g8FatBSZSA1KjDkBERERE5GBl8JaDB38t2dYmwa5LrnJfWHuRiVQ/jXyKiIiIiEQkXHLli/3tZ/B6LYQjUqOUfIqIiIiIRGvC/nZIUJ4rUuco+RQRERERiVAFEsvcHHivVoIRqUGa8yn10afAyqiDEBEREamIzvDBqmDJlWbl7DJVS6xIfaCRT6l33H2Vu8+MOg4RERGRijjZvbDMkitlqeRW6gUln1LvmNmZZvaTqOMQERERqaj9lN5qiRWpF8zdo45BpNqZmbl+uEVERKSOGGfWsRBWUWrJldDCUe69o4hJpLpp5FPqHTNrAXSJOg4RERGRirrSfQ0wJ8FL++2EK1JXKPmU+mgY8J2ogxARERGppL1Kb7XEitQnSj5FRERERJJAgkQzt4GWWJF6RMmniIiIiEgS6AwfANtKbZo6wj03qnhEqpuSTxERERGRJHCyeyF7LrmiklupV1KjDkDkQJhZOtADaAc0Cj9OBvqa2VVAdvixEVjq7jsiClVERERkvxzeNLgUoEjJp9QzWmpF6gwzawKcFH4cHjPr6+5dvBIj+LFYbH08Hp8LfAW8D0z1oLuciIiISOSeNevgsCYf1tzo3inqeESqk5JPSWpm1g+4yszOxP1ohxQz83bNmsW7t22b0qVNG7q2bk3LJk1olJFB44wMFq5bx6J16xg+aBA78/LILShgR04OyzZtYsXGjSzduDG+cvNmKywqMoCY2cK4+yRgPPCe1gcVERGRKP3RbOMO+PBe9/OjjkWkOqnsVpKOmbUCRprZtcBgA7q1aRM/tmfP2ODu3Tm6WzdrmpmZUt7x/Tt33t8lYgWFhfxvxQo+WbyYTxcv7jln5cqeRfH4rTGzlWb2NPCMuy+svnclIiIiUjELYflmmBV1HCLVTSOfkjTMrB1wp5nd4e4N2jZtGj934MDYhYMHc2jr1hU+z/rt29m0Y0dFktASO/PymPrll7zw4YfxeatWxRwceAP4hbt/VOk3IyIiIlIFZpY+CMYthNd2whhVZEl9ouRTImdmnYH7zOw63NNOOuwwrjnxRI7q0gUzq/T5lm7YwOotWzihb99KHff4O+/QvW1b+nbqxPMzZvDSxx/HCwoLY2Y20d1/oiRUREREDpSZNQaOBfoCfYA+sVisF+6tHBq5+x6ViTGzPCAHWBd3nw8sIOhd8QXwmQcdckXqBCWfEhkzSwNui5k94JB5Qp8+dssZZ9C3Y8daj2Xm0qXc8sQT/Om66xjSqxcAW7OzeX7GDJ57//2i7Pz8GPAs8F1331jrAYqIiEidZGapBM0STzU4FTjWIQUgJRbz9s2be9c2bWLNMzNpmJ5O4wYNyMzIoLCoiNyCArLz88nOz2fzzp0s3bChaHNWVsnUo5hZVtx9GjAVeMfd50TxHkUqSsmnRMLMTjKzv7p734Fdu/o9F11kPdq1q5Zz/2/FChasXctlQ4ZUaP+t2dmM/OMf2bhjB//85jfpUyb53ZadzaNvvcUrn36KmW2Nu38feFJlMCIiIlIeMzsSuDZmdnXcvS1A1zZt4sf06BE7uls3erZvzyGtWpGWsncbi+dnzKBPx44c2aXLXq9l5+ezfONGvlq7lk8XL+ajRYviW7OzY+E1v3T3McA/1c1fkpGST6lVZpYC3GdwX5OGDfnm2WfHLj7mmCqV15Zn2ty5fLJ4MXedv/8Gce7Od8eO5d158wB44+67ad+8ecJ9561ezQMvvxyft3p1DHgV+D9331JtgYuIiEidFt7nXBkz+37c/Qgz88HdujF80CAb2rs3rZo0qdB5tmZn0yAtjYbp6RXaf8mGDbw7dy6vzZoVX75xY8wgDkxw+KW7/7fq70ikein5lFpjZh0N/uVw0rDDDvOfXnqpNc3MrPbrVCb5fHb6dB6eMKHk8w/uv58GaWnl7l8Uj/O3yZN5cupUN1gdd79Mc0FFREQObmaWAYw2s3vcvVu7Zs2KRhx3XMq5AwfSrlmzSp8vt6CA1JSUhKOi+/PlqlW8MWsWr3z6aTxv166YmU1z9wc8WFZOJFJaakVqhZkdEzObEDNr9e1zz+XKoUOtOkc7q2Le6tX8aeLEks8z0tL2mXgCpMRi3HrGGQzq1s1+OG5ch+05Oe+b2c3u/lRNxysiIiLJx8xOi5k9Hnfv1aF58/hVxx/PpUOGpKSnVv02+08TJ3JMjx6cfNhhlT62/yGH0P+QQ/jGWWfFXvjwQ8ZMm3bSzry8k83sXeA2d59b5cBEDlAs6gCk/jOzM2Nm05o3atTiqVtvtZHHH1+tZbZVkVNQwI/GjWNXUVHJtuaVGIUd0rMnz99xR8qAzp1TgCfM7J4aCFNERESSlJkdamYvAZNaNWnS/ZcjR/LKXXfFRh5/PAeSeFaXRhkZXDdsGBN+8IPYzaefTnpq6olm9pmZ/cLMqr/0TKQClHxKjTKzkWb2eocWLTLG3HprSv9DDok6JAB++Z//sHzTpj22VSb5BGjVpAl/ufFGO6FPHwMeNLNHzEz/pkREROo5M7s2ZjY/JRa76NqTTuLl73435cwjjiAW8cP1RDIzMrjptNN48c47Y8f37p0K/ChmNsfMBkUdmxx8dKMsNcbMLjJ4tnvbtilP3nxzSqeWLaMOCYBXZ85kwuzZpKem0qF5c5o3agRAsyrMP22QlsbDo0dz0THHAHwL+FO1BisiIiJJw8wamdkYYEyvDh0yxt1xh33rnHMq3BgoSp1atuSR666z344aReMGDbqa2YdmdnvUccnBRcmn1AgzO83Mxvdo354nb7kl1qZp01q7dr9OnTh34MCEr63YtInH3n6bK4cO5aGrr2bttm0lbcyLk9DKisVi3HvxxZx/9NEAt5rZj6oYuoiIiCQpM+sdM5tpcO2VQ4cy5tZbY93bto06rEo7pX9/xt1xR+zILl1SgUdjZi+qDFdqi5JPqXZmdnTM7JX2zZun/vn662NNGjSo1eu3a9aM8sp7127dykvf+Q53nX8+MxYuJGbGt885h+aNGnEgnXfNjPsuuYQT+/YF+LmZfb3KJxMREZGkEjZOnNEgPb3XQ6NGcdf55yfFvM6qatesGX/7+tft/04+GeBSM5tiZq0iDksOAko+pVqZWZuY2etNMzMb/OWGG2KtK7ieVXX6aOFC/j55csLXhvTqRWZGBoVFRUz8/HOO7dmTQ1u35vLjjqNFFUc+i6XEYvz6qqs4oksXzOxxMzv+gE4oIiIikTOzU2NmU5pmZjZ74qabYqf07x91SNUiJRbj9rPO4qcjRhAzOzZm9oGZHRp1XFK/aZ1PqTYWLJ7yqsViw//29a/bwK5dI4nD3XHY56T/aXPn8t2xY3ngiis4+6ij2JGTw9S5c7lw8OADvv7W7GyufOSR+JasrPVx9yPcfdP+jxIREZFkY2bnmdlLHZo3T/nLjTfGkqV/RXV7b9487v7nP+OFRUVr4+7Hu/vyqGOS+kkjn1Kd7nE477Yzzogs8QTIys9nw/bt+9zntZkzaZSRwcnh08ummZmcdeSR1XL9Fo0a8cuRI2NAezMbqw64IiIidY+ZHW9mL3Zu1Sr29G231WriuXrrVnbk5NTa9U7q14/HbrghlpaS0iFmNsnMWtfaxeWgoptiqRZmNsjM7v9ar15+7bBhkcYyc8kSxk6fXu7r23Ny+O+CBZxx+OE0SEsr2V767wdqULdu3Hz66ebuZwO3VduJRUREpMaZWf+Y2eutGjdOfeyGG1JaNm5cq9efvXQpq7ZsqdVrDuzalYevvTYWM+thZhPNrHbftBwUlHzKATOzmJk93jA93X46YoQl4xpXpb352WcUFBYyfFDNLm91/SmncNghh3jM7EEza1+jFxMREZFqYWZtY2aTGjVo0OTxG29M6dC8ea3HcN6gQRwWwdroQ3r25MeXXWa4DzIYF8yoEqk+Sj6lOnzd3Y/9xplnRtJgqLLemD2bji1aUNOlwTEzfnTxxQY0Bh6q0YuJiIjIATOzmMFzmLX7w+jRKVEtpTLpiy9YuG5dJNcePnAgt5xxBg7DgbsiCULqLSWfckDMrFXM7Fe9O3SIX37ccVGHs19LNmxg7qpVnDdoELXxMK9vx45cdtxxBlxtZtHWI4uIiMj+/Mjh9NvPOsuOirB/xeylS1ldy2W3pV1/yikc16uXW1C9dUJkgUi9U3cXKJJkcWfcvfkPLryQWCz5n2W8PnMmZsbwgQNLtr06cyYffPXVXvumxmK0b9GCwd268bXevat8zdvOPJM3Z8/2rPz8XwAnVvlEIiIiUmPM7ASDnw7t08dHn3jiQV1uGjPj55dfblc88ohty84eb2b93X1b1HFJ3Zf82YIkLTNrGjP75rE9eviRXbpEHc5+xd156/PPOapLFw5ptXsd5aO7d+ekfv2YNGcO7Zo147phw7hu2DDOPPJIvly5ktv/8Q9e/OijKl+3SYMGXHXCCTF3P8HMTqqO9yIiIiLVx8zSzOxvzTIz/f4RIzTVEWjZuDG/uOKKmLt3BH4edTxSPyj5lANxe9y96Y2nnppUv6EbpqXRLDNzr+0fL1rE+u3bOa9Mo6FOLVpQFI8DMLR3b/p16kS/Tp0Y1q8fP7r4YgAmzZlzQDFddfzxNMrIiJvZvQd0IhEREakJd7p7vzuHD09p3qhR1LEkjSE9e3LWUUcBfMPMjo06Hqn7Dqrk08z6mZlKjauBmaXHzO48/NBD/eju3aMOZw9DevXiptNO22v7a7NmkZ6aymmHH77Xa/NXrwagT8eOe2wvTkrTU8v/sVm0bh2PTpzI+n2sLdq4QQOuGDo05u5nmNlRFXojsl9mtvc3U0REpBLMrHPM7CdHdunipaflSOC7w4fTKCPDzexxrV0uB+qg+QEys17Ax8BfVUtRLYbH3VuPHDo06b6W67dvZ+6qVXtsy87PZ9qXX3Jq//40adBgr2Pmr1lDu2bNaFHmaee0uXMBOKV//72O2ZadzS9feYVr/vxnnn73XRqmp+8zrsuPO46YmQPXVvItSQJmdg3wmZldHXUsIiJSp/0Us4Y/uvhi3SIm0LJxY24788yYuw8CLo86HqnbDprk090XAv8Argd+EnE49cHozPT0+LDDDos6jr1k5+ezOStrj23vzJlD3q5de5XcAsTjcRasXUvfUqOeW7OzeW3mTP4+eTIXHH00Fw4evMcxi9ev5+YnnuCoLl3o27EjHZs3p2nDhvuMq03Tpgzu0YOY2SgzSzuAt3jQM7NTgL8Ds4FXIg5HRETqKDPrbGbXnHPkkdajXbuowykxtHdvurZpE3UYJS4bMoR2zZrFY2Y/1uinHIiDrQT1TqAT8BMz2+juf446oLrIzFqa2fAzjzwy1iAt+XKo7m3bUnZdrjdmzaJN06YM6dlzr/2Xb9pEbkEBn69YwQUPPcSuwkI27NhB97ZteeqWW/YqxQVolJHB07fdRnpKCg+8/DJDK9gNd/jAgfbxokWtgTOBN6ry/g52Yanty8Aa4Dx3z9rPISIiIuW5G/e0a4cl12pox/fpE3UIe0hNSWH0SSfFHnrttX7A+ejBr1TRQfXkwt2LgFHAB8AjZnZRxCHVVZe4e9q5STovYs6KFbz08ccln6/ZupXZy5ZxzlFHJVwOZv6aNQD85NJLefWuu3jznnv4yWWXsWTDBqZ8+WXCa7Rv3pwGaWksCxPXvgkS1EROHTCAjLS0OHBF5d+ZmFlXYCKwCzjH3aNZgVtEROo8M2tnZjeeMmAAyTTqCfDChx/y+fLlUYexh4uPOYaWjRqpeaIckIMq+QRw91zgImAusO9JelKe0xqmp8ePStLlVTZnZbF4/fqSz1+fNQt3p7wmAsXJZ99OnUq2nTdwIG2aNuWljz8m7l7utb5KcOy+ZKanc3S3brGY2RkVOkBKmFkr4E2gGXC+u++9OOue+3cws0vM7CYzu9rM+tZKoPWEmbUws6PL+eh8oBOjzCxW6nyNE7zeNnxt3/XsEQuXZ3jHzK6MOhYRqbRR7p5x7UnJtwraaQMG0KtDh6jD2ENGWhpXHn98zN0Hm9mRUccjddNBl3wCuPsmYKC7P29m3zKzvWsxJSEL7hhPHdy9eywlwShisnF33pg9m36dOtGzffuE+8xbvZqWjRvTtmnTkm2xWIxh/fqxJStrr+ZFpZUkrhUc+QQY3KMHcff2ZpZcNTVJLExAXgV6AVe6+4f72LeVmY0HVgP/Bh4CngbmmdknZrb3xF9J5FjgbuAjgvKqu8OPB4A5wFo7sIcoGcCn4cfPErx+ZfhaUrTTDv+veCHBSzHgdKBr7UYkIgfKzK7r3KpVfEDnzlGHspfMjAzSU1KiDmMvwwcOxILmiddEHYvUTcmfPdQQdy8ys0MJbqQmmtkhUcdUR/SLu7cd3KNH1HFUyGfLl7Nq8+aEjYYgSE4Xrl1LvwQjlyf0DQbKps+fX+75569eTdumTWnZeK+Bm3Ids3tpmlMrfJDcCwwFbnP318rbycyaAtOBC4DvAq3dvRnQADgN2A6cU/Ph1n3uPhH4FpACPO/ul4cfZwMDgZbAX6vhUkXAbWaWfHd/e+oLJBoeKQAGA2NqNRoROSBmNtDdB1w4eHBS3gs/+tZbvP/VPgt8ItG+eXOO7taNmNloLV8oVXFQ/9C4+wozu5hgRGWqmZ3s7qujjivJHQ8wOMnW9izP67NmkZqSwllH7l0d8v78+SzZsIEdubkUFhXx0scfc/qAATTNzATg2B49yEhL4505c2jXrBlDe/emffPmJce7OwvWruWorl0rFVPfjh1plJERz87PPwF4/EDeX31nZukESc4vgfnuPnY/hzwA9AMudfeXije6eyEwxcymAt3KXKMhQVLRnqCJ0XR3zyuzzxHAdndfbmbHAT2AJcDH4VzysnE3AE4AOgJbgE/cfX2p1w04MjyPAV8BX7jvrvEO14Pd7u5LE5y/J9DQ3eeU2hYjGK3sBWSF72PTfr5e+3N0+Oes0hvdfamZbQVaHOD5AV4EzgN+CtxQkQPMrBNwHJBJ8HWbXc5+AwgS5c3AFKARwQjlF+6eX+Z8RxG8n6XAbHfPKfV6D6ANkGpmxV8T3H1mgmu2Aw4pe43wtUYESewyd99cansbgocrzQl+Fj4q/bMgIjXiajPzcwcO1NoqlTR80CD7dMmSNgQP0d+OOh6pWw7q5BPA3SeFjYdeYXcCuibquJJYPzPbq5tsMiooLGTynDmc0KfPXut3AmzJzibuzjfPPhuAHbm5pKbu/ieRkZbGjy6+mI07drAjN5eyZcZrtm5lR25upUpuISjp7d6unX2xcmXyrVOTRMLE83lgADBof4lnuP//ESR6LyXaJ7yhX1LqmBOB8UAHoDiZWmVml7n7R6UOfQt428xaAsOBfKAh8L6Zneruu0qdczjwJNCOIPFsDKSY2Wnu/m6YJK4qdc20cJ/3zewCd98anupBoI+Z9SyTlKYRNE2bAowMt/UAXiBItLaG59tlZre5+9Oljj0FuBV42N1n7OvrGSqeKL1HcmdmHYHWwH8rcI79WQv8Efi+mT3k7uWWGoRfu98AdwBxIAdobmavAiOLE8YwuX8U+AaQS9CgaiswlmAUvfjhAWb2GHALwfd0B9AW2Bj+DLwXXvq3BL0CICgFLgmJoHfAp8A9wK8IktsPCdbzfabMW7gR+ANBAro5vP49BMt/pYTXbwm8Z2YXu/uWfX/pRKSqzOycfp060a5Zs6hDqXNO7teP+83c3c9CyadUUlKWGtQ2d38buBDoDEwLb6wksT7tmjUrSk9N/ucWU778kp15eeWW3F5w9NFcN2zYHh+Z6Xv2oBo+cGDJa21KzQkFmBfO90y0FMv+dG3TxggSCz1xTSBMsMYT/Lsc6+47KnDYkQQjW5MreI3WBEu2bAd6u3tLoD9BEvKKmZW9IxkJrCBoeNQY+CbB6ObVpc55JME80yVAT3dvRTA6dyZBklXsQaCNu7d09yZAcSnrA6X2GUMw3/HEMnGcTZAgjQmv2QCYEF7nqPB9NAOeA54o0xSiGzCC4HddRQwkSPBKEsIwAfw54ASjldXhNwTfh1/sZ797gO8QLJvVyN1bEHw9TicYHS82miDxfBBoSvBQ4X7g+wnOOQ04wt0buns7guRxKfBc8Xq87n4xQZXCBne34o9EAYYPLeYRJJ9lXQvMKG6WZWbXhzH+Emgc/rwMBQ4D/rKfr4WIVJGZtXX3fkN69tT/wVXQNDOT3h06YGanRR2L1D1KPkNhAnoRwU3ZVCWgicXM+nVv2zb5ZsCX0rdjR8496ihenzWLppmZ1b5WVk5BATtyc/lixQoAOrZowY7c3H12xS2ra+vWuHtDgnVnpRQzSyEYMboI+I27J2pGk0hxn/y1+9xrt6uBVsA33H0hgLvPBb4dnqvscjjLgTvcPcvd48CfCZoalU4Ov0MwIne5uy8Oz1nk7lPcfUH4edzd/1S6JDacX/k0QRJV7FWC0bqyScx14XUnhZ+PAHoDN7r75+H5cgmS420Ey0sV+wC4mT1H7/ZlEMGcxsfM7K9mNoZgtLMZcLy7VyjR3x933wb8GrjEzI5NtE84sn0X8Gz49SsMj51IkBheV+phzo0ECfN97l4Yfs2fIlimp+y1n3f3L0p9vpwgyT2EoIS7Kp4GTjazkpbgYen2QPacG/ojYJK7/6y4RDcckf4VcGmiLsAiUi1OAeyYJJ5ClL5r1/53itCQnj3N3Y8IH+SKVFjyD1/VInefaGaXEYxcTA5LcNfv77iDhZmlGnQ5tHVy/55p37w5KbEYHy1axIghQ6juUdoHXnqJ5ZuCvKFfp07c/+9/A/C3m27aa+S0PIe2aVP8114EJZhC8DMGjAMuBX7h7vdV4vDi/6kr+nDk6PCYaWW2v0OQQA4G/lZq+6el53e6u5vZCvZ8gDCUYL7gPr+nYVJyG0FJcXHS3B5oY2axMFnKM7NxwCgz+5a7Z1uw3Mx5wO9LxXJ8GO/hZla2lHs7UPL0JRxxq1AHi7DEuCvB78MXCMqMLyJIoP5epiy5OjxKUE77IHsm4cUOJ0h6Y2Z2U5nXWhGMcHYgmLfbB3gtfEhQ2nSCxdFLhHN+rwPOCI9PI2hQBcFI8f+q8F7GEoxiX8Pu0dxrCUqAx4fX7Ugwsj03wfvpTPBwuDdl5tuKSLUYlhqL+RFduiTtyGf3tWuxbt32v2NEBnfvzjPvvWcEPRMSTnURSUTJZxnu/kaYgH4D2Bl1PEmmiUOsediQJ1l9tGgRY997j3g8zvBySm4PxANXHvhyfs12fw2b72u/g4mZZQD/BC4BHqhk4glBSSxUfGmORsDWsgmKu+ebWRbQpMz+WQnOUcieyW4T4IsE+5UIm+DMAJYRJHVrCUYoLyUYbU0lGG2EYJTsVuBi4FmC0t909hw9ax7GcUmCyy0NP6qieL7nm+4+KYz9DWAY8JCZPVe6MZOZtQeuJyj/bQNMcffxFb2Yu+ea2f3AX8wsUfJZXAZdOmEvbRKQEY5+NiPyyisbAAAgAElEQVSYP1nWHtvChx3TCJK8ZwgePGwLz/9w+F4qzd3XmNnbwGgze4DgZ+Rq4D/uvr3M++lJMHqd6P2ISM04vGvbtt4wPT1pk882W7fCmjVQzhrlUTvskJJFIg5HyadUgpLPBNz9deB1Mzs0HHm4MSzHO9g1gWDtqWR2TI8e/O6NN+jSujX9D0nOFXQa7/4alk1wDkrh/MqXCUqhHnD3e6twmvkE5ajnm9mdxWWZ+7AZaG1m6e5enOxhZk0IRtE2ViGGDcCh+9lnFMF8yaHuXvKAK9HcGXf/2MzmEoyaPUuZOYOhjQS/yy8pfb5qUPzkpmTkzd3jZvY8QVnqKcCbpfb/NjDT3V8Iv4arzOzT4vLjCnqSYImcXxK839KKvx9j3P0P+zqJmS0HuiR4qWuZzwcSdAi+zN3/Xer4RMlvZT1NMIo/lGDOaTv2fGhQXHb9qrvfXQ3XE5EKipn179a2bdJOPSvcuZOmOTk0zUr0zDM5tGjUiMYNGhRl5eVpzXKplKT9h5ckOhHM+ZluZkOjDiYJ1Inkc/ayZSxet44LBg+OOpRyZSr5LGsQQfnoHVVMPIs72T5EkHQknCdqZq3Cjq8A7xH8Diw76jQy/PPdKoTxNjCw9HIcCbQHtpVJPDMpUw5aytPAqWZ2NkEp8NNlXn+L4H1ct7/gzKyJmXUPl/zYn6MJRmC/LLP99fDP4WW2P+PuL4R/zyFIsNMqcJ0S4QOD+wje56VlXv6SoET9Wtv/2nL/Bc6xUus3h1/jq8vs1z78c2WZ7YnKG7YBjSvRJOwVds/ZvTaMvWSOrLtvBGYCV2hup0jtMbOWcfcWXXdPf0k6WQsWgDs7v/oK4mVnDySPbm3axMysb9RxSN2ikc99cPcZZnYSwdP9SWZ2he9jgfu6IrxxK6+crCicW5YGmLsXhDdtqYSlbjEzsvOD5esapKWREouRU1BAZno68Xic3HImycfMaJieTmFREXF30lNTydu1i6JyfrFmpKaSmpKy+9zu5BYUJNzXzMhMT6coHmfKnDmkpaRw2oABJXGWd+7cggIaVuLcRfE46amp5O/aRWE5caenppKWkkLerl1khPNNc8qcu9Tda5vwGilAWjjPrwFBaWUieeH3JLUCI3tJz8x6A+e7++/MrJe7r9jvQfv2KMFI0w/N7HCCuXdLCUochxHMs3wYmEqwvuQ9wJ/ChOLT8NjfESwt8koVrv8QQYLzmpndDXxM0Bn3DIIy1I8JEqNrzexnBIlke4J5geV9z58lmD/4DKXmDJYygSAB/Y2ZtSBIDrMJRmAvIFiLtHiZmhEEo4tXECxjsy8DgTmlR4VDHxKM8J4P3F68sUx1yCXA1H0tm7IPzxN0pd2jy2846npn+PqbZvYrgtLlNsAxwBB3L26u9HOC+anTzewRIA/4OrvLbou7g80KX/ulmX2XoNPxKBI/CJhF8Hvzt2b2YRjTCwn2K463eM7u1UAGe87TLfZdglLfyeHPw0KCMuqjgAvcvbwHEiJSdb0BuiRx/4rshQsB8NxccleupGGXRIUc0evatq19uWpVH7Ng3ZWo45G6Qcnnfrj7HDM7nuDm7iUzu8Xdn4w6rgP0NYLukIl8SXBjOoLghukfwF8JbkQbAvxl0iSee/99AL53/vkc26MH3xs7lsduuIH5a9bw0xdfTHjiTi1b8vDo0UyfP59NO3cy4rjj+O1rr/G/FYnzjdvPOouT+vXj7uee4w/XXsuyjRu551//Srhv6yZNeOyGG/ho0SKyCwq46JhjGPff//LJ4sQVfzeddhqnH3449z3/PPePGMHW7GzufKbsknyBxg0a8NQtt/DZsmV8tnw5N5xyCn+bPJnp8xPfV48+6STOGzSIn7/0Et8dPpyieJxvPPXUHvsUFpXcg95AsFzFYIIb3nuBu0k8BwyC5OqvBN/D6eXsUyeEXU1fJ5inN64aEs/iBGUkwajlt9gzwVoD/B14LNw3z8zODLc9TTB6WAS8AdxUJrnfTjCaV9ZOds/PxN3XW7B26GMEJZbF1SULCJJECJK/QQTf6x8TJDxPEvyO+UGC97TGzF4hWMx7XNgZtvTrbmYXEyRc32H3qG+cINEdV2r3fILRuMRPWoBw3uXVBElQczNbDNzu7m+G14ub2X+AEWa2hKAx1FOljh8YHj9q77Pv+dbCWHITvJ8fAsX/2Es3eXrRzC4gaEpUek7kSoKvYfF+i8MHh78i+JpuJvhdtotgnc0N4X6rzew6gu9X8VqmH4TxP8+eX6eXCB4SXEwwkhkjmLNL+D7y2NsYglHUHPYsuS2O892w3Pq3BP8Wip9LrWfvhwwiUj3aAbQts3xasnB3shctKvl85/z5SZt8tmnalLh7JsH9YaL/I0X2YnpQUTHhiMJrBKWBv3b3vW4S6zsz6wPMv+eii7hsyJCowynXtLlz+WTxYu46P3kHDZZt3Milv/89wK3uftCt5xfecL9M8J/Vue5eIx09w+6wLYAcd1+zj/2aA62BjaUawhzotYvPua30siqlXs8k6K661t2r5T/tcAS9M0FitzbBqGWNMrNhBEnnt8LlXmryWm0IRrQ3lU3I93HMM8CZ7t6+zPYUgqVVcsJy2FoXdhduSdAEa3MUMYgcDMxsFDD22dtvp1+n5FvtLG/lSpY89ljJ5w3at6f7HXdEGFH5xkybxqMTJwJ0cPd1UccjdYNGPivI3beGoyTPA3eHNwq31/bNXcSyAHLKKWWViitVDpyoI2e9ZmZfJ1gjczlwlrsvqalrhTfx+72RD5OXCiUwlbj2Ps8ZJpyVacZTkWsWEZSi1jozu4FgnvxNQEszOy1s3lYjwiSx3ETRzC4BJhR35DWza4CrCEe+y5yriODnMTLuvgXYEmUMInVJ+ICvvOHLHe6+zYI1KLe7+y4zK24G1wWCe5l124Jf0e2aNaMoHmdnXh4tGjUiKy+PrLxExQxBz4amDRuyPSeHhunppKemsn77dsobzCkeYd2Wk0PLxo3Jzs9nZ27iZ3OZ6ekULFiwx7a8detYs2IFsQQjtW2aNsXM2JqVRasmTYJ1yHMSP8tsmJ5Os8xMdublkZ6SQkZaGht27CBezhSi1k2akBKLsTkri9ZNmpBbUMD2Mucu2v2euwDrwuaBu9w9x8yKl65KZF04hahB6a7pcnBQ8lkJ4T+miwhunK8lKF2dve+j6pWdsPf8Ram8Ugn8QbOcTziP+BGCpUNmABe5+4Zoo5LqEC4nMpJg/uJfCMra/hlpUMHv6VZmtpZgHdBGBKXNVWpoJSJJ52p2N4gr6zmCe7TvAE+b2VJ2/07qBPDIm2+SmhKslPXn669na3Y242fM4M5zz2XSF1/w6qefJjzxqQMGMOqEExg/Ywan9O9Pr/btuXf8+HL7Vzw8ejSFRUU8MXUqd19wAe/Nm8cLH36YcN8T+/bllHC+Z2kvjB/P50327k/4q6uuomF6Oo+9/Tb3XXopMxYsKJkWVdYxPXpw6xln8PrMmfTp2JFB3brxq//8h23lJKv3jxhB22bNeHjCBB644gpmLlnCU9Om7bHP1uzs4r/eCnxEMG1rOTCRYIpDeUPLtxAsS3YUQR8BOYio7LaKzKyvu88Pb7r+4+6fRB1TTbNA7oWDB2fcd0miJQWTQ10ou33zs8+4d/x4gK+5e73/xWtmbQnmx51EMDfvG+6uIfR6wsxOABqU2fxJdZUwV0XYQfY4gtLmOPC5u+9zDVYRqf/M7B7gwXd+9CNaNk6uRtNFeXl89fOf79Xhtkm/fnQePTqiqMo38fPP+eG4cQDHuftHUccjdYNGPqsoTDw7ADcC3zGzm0p1lKyX3N1jsdii5Rs39o86ln1pkJZG04YNow5jn5ZtLKkWXLCv/eqRewmaJN3u7n+OOhipXu6e+FF7hNw9iz2bEomIQNANvNwO91HKXrgw4dIqWYsW4bt2YWmVWr2qxpWqhDtoqrjkwGmdzwPg7msJWvzPBZ4xs99XYP25Os3d5y3dsKHscgFJ5bhevbj59OpYI77mLNu4kZjZlnCeV71lZiPN7AiCjqPDlHiKiEjEam0KUc7SpayfMIGdX34JpSoNC3eXq+4he0Hi59G+axfZS5fWSIwHInv3vFgln1Jh9TpRqg3uviIsOXsCuBM43MxGJupuWU/M35aTk7IjNzdpRxc37NjBlqws+nbsGHUo5Vq2YUM87v5l1HHUlPAhzIPAXcDL7n4JwTxPERGRKAXJZw03T9w4ZQrZixeT3qoVa15+mbTJk2ly2GHkrV1LSsOGdLzssr2OySq1xMper82fT+PevWsy5Eo7mJsnStVp5LMauHuuu19NsDD6KcBnZnZqxGHVlC8A5q8pd9WKyO3MzWX99simmu1X3q5dLNu0yQjWVK13zKwr8B5B4jmO/a/3KCIiUlu2AeU22qkO7k5Gu3Z0/frX6XjJJfT63vdocMghbJw8mXh+Ph0uvHCvY/LWr2fXtvKbrmeVs7Z4lHbk5mLBnPqsqGORukPJZzVy94cIFoKPA++Y2YNmZvs5rK6ZBvjMJTW2OsYB69GuHcP69Ys6jHJ9tmwZhUVFRvC1rFfMbCTwGUEHu2+4+8jqWsNSRESkGiwCWLmp5grUzIym/Xe3xyjKzyd78WIyDz2UzqNHJ5y7mVNOyW2xgq1byd+QXA3il2/ahJktD5erEqkQJZ/VzN3fI7jx/g/Q1t3dzBpFHFa1cff1MbMFHy9alLRtkr9YuZL/fJK8zYc/CRJ3px4ln2bWxMzGELSyXwEc4+57racoIiISsRVmll+q8V+NKszKYsVTT5GSkUHn664jlp6ecL+dCZZYKSvrq6+qO7wDsnTDhqK4+9yo45C6RclnDXD3Le5+KXCrmQ0GlptZvSk9jLtP+mLVqhqfL1FVm3buZOG6dVGHUa6PFy70mNlcd18fdSzVwcyOBGYBo4E/Acd6PZ7PKiIidZe7x4FFy2pw5LNYUXY2y594AmIxutx4Iynl9MrwXbvIWbZsv+fbmUSltwWFhWzYvj0GJFdGLElPyWcNcvddBHXwq4CxZjbWzJpGHFZ1eDsej9v0JPolWFes376deWvWEHd/K+pYDpSZxcysCUHzBgMucPdvunvefg4VERGJjLt/uWjdunhNrnUfz8tj+T/+gRcV0eX660nJzCx33+wlS/Bdu/bcmGDWVu7y5cTzkuO/2CUbNhB3N5R8SiUp+axh7j4fGAI8AlwNfGlm50cb1QF7K2a25Y3Zs5O29DZZvTl7Nh78sn4u6lgOhJkNAD4gaCi0FOjj7q9HG5WIiEiFzNiZmxtbvL5mCpDi+fksf+op8tev55BRo0ht0qTktV0JGiJmlS25NdtjaZZiXlS0z464tenT3b0/km6dZ0luSj5rgbvnu/u3gTOBAuBVMxtnZu0iDq1K3L0g7v6vGQsXsnmnlnaqjDdmz47HzOa7++yoY6kKM8sws58BM4H+wATA1GxARETqkCmwRwJVbbyoiBVjxlC4cyepjRuz/C9/YdPUqWTNn8/a//yH7ARzO7NKNRuylBQa9epV8nnTI47Yc98kqTr7ZPFiYmYbgXlRxyJ1i5LPWuTuk4ABwK+By4D5ZnZTHe2I+0w8HrcJn30WdRx1xtxVq1iyYUMs7v6PqGOpCjP7GsHczh8Dk4EB7v7ncP6MiIhIXTEnZrbpk8WLq/3Enp9PqxNOoNfdd9Pr+9+nw6WXkrVgARsmTaJxnz40Hzx4j/0Ltm6lIGx+ZCkpHHLVVWS0aFHyepO+fWl7zjkln2d99RU1WS5cEUXxODOXLInH3d/xqIOROkfJZy0L1wT9AfA1gq6gowAzs8Ttz5KUu39sZl/88/33i3YVadCrIsZOn46ZFQBjo46lMsJOto8SlNa0Bq5y93PdfUXEoYmIiFSau3vcfcrHixfHCwoLq/XcscxMmhQvs2JG0wED6HrzzXS//XaaJFgGrmTUMxaj44gRNDnsMLzUmIS70/qkk2h37rlA0D03b/Xqao25sj5bvpzcgoIY4QiySGUo+YyIu38CDAZGAG2ARWb2fTPLiDayinP3Bzbs2JHyxuzkqiDt27EjZx95ZNRh7GHl5s1MmjPH3f1Jd18bdTwVZWanAl8AtxPMU+3v7v+KNioREZED9kJOfn7svXnRVo1mL1gAsRidLr+cZuG9yx4FceHAYqsTT6Td8OFA9KW3E2bPxswKgVciDUTqJCWfEXL3XeFyGw0Jmrb8mqAh0SXRRlZhL8TMFj05ZUq8KJ48lZftmzfn8EMPjTqMPTwxZQoORcBDUcdSEWY2MOxkW0gQ99nuPtrda743vYiISM17NWa29Y1Zs6KLIB4ne9kyDhkxoiTxBBJ2ugVodcIJtBs+PNL1PgsKC3nnf/+Lu/vruieQqlDymQTcfRlwMnAlkAr828ymmdnAKOPaH3cvirs/uGbr1thrUf7yLuPjxYt5aurUqMMosWTDBiZ89pm7+7PuvjTqePbFzDqY2ZPAp8D33f09gk62EyMOTUREpNqEzRPHv79ggW/JyookhpwVK+hw3nk0PeqoPV8oU3ZbWqsTTqD5McdQGFHDx3fnziU7Pz9GHZtCJMlDyWeS8MB4oDfwbWAgMNPMnjGzDtFGt09jzWzOHyZMiG/Lzo46FgAGd+vGNSedFHUYJX79yiuOez5wf9SxlMfM0s3sDmA+cB1Bie1jULJerYiISH0zJh6P20sffxzJxRt26kSzgfseZ7AE/XxaHHssqY0a1VRY+zR+xgyPmW0F3ogkAKnzlHwmGXcvcPdHgL7AUwRrgy4ws+TJpkpx90J3v3Vnbq499s47UYcDQE5BAVuTJBGeMHs2ny5ZYnH3nyXjqKeZxczsSmAB8AdgNjA4LLGtM3NTRUREKsvdPzKz95+dPj2ek59f69e3tLTE2/cx8lkiVvu38J8vX87sZcss7v6wBw/VRSpNyWeScve17n4jQVOiCQSjoKeZ2XfNLJrHXeVw9w+AMS99/LH/b0X0DVA/XbKEp999N+ow2JGTw8NvvBGPmX0F/D7qeEoLk87LgM+AfxHM7bzU3U+uq2uQioiIVJa7/2JnXl7s3xGNfibiCRoOJYO/TprkMbMs4E9RxyJ1l5LPJOfus939CnfPBkYCvwWWmNn3kiwJvdtg8z3/+ld8R25u1LFEzt35yYsv+pbsbIu73+zuBVHHBCVJZ1ugMfBXoAVBJ9v+7v5SpMGJiIjUMnefaGYzn3733XhuQVL8V52w223U/rdiBR8tWmRx90fdfWvU8UjdpeSzDglHQs8DlhN0TU2aJNTdN8bdL1+/bRs/fv75yBdAjtpzH3zAe/PmGXC/u0c+DFtmpPPf7r4DOBPo6e5/VvmMiIgcrNz9x1uzs2NPTEmOZSsrVHZbi+LxOL959VWPme0gySq5pO5R8lnHuPsb7n4seyeh3zez5hHHNtXhwenz5/Ov//43ylAiNWfFCh598003s2nAz6OMxczSwjmdnwEvEIx0jjOzmLvPVNIpIiIHO3efALzyzPTpvmjduqjD2bPsNgm8+NFHzFu92uLuP9DyKnKglHzWUWWS0GUEa4SuNLN2Zhbl9/WnZjbt4Tfe8Glz50YYRjRWbNrEt59+uijuvsndR7p7URRxmFlrM7sHWEIwp7O4vLZ4pDN5FmYVERGJ3h245/361Vc96tHGZCq73ZKVxZ8mToyb2SzgbyUvmNk/zbr/06z7o2YZZY8ba9ZtzzciElDyWceFSegQ4DTg9+6+HnjIzN4ys3Oslv/hu3uRu1/k8MXdzz3nHy1aVJuXj9SWrCy++Y9/FO3Izc2Lu5/t7rX++NTMUs3s78BK4EFgPXAtKq8VEREpl7svj7v/bNbSpTYumaq3Ikw+3Z2f/fvfnpOfj7vfUvqB+j+gdRE8EYfFLeDHpY8ba/azGFyfFDXDknSUfNYT7j7F3X8SfroTOI6gS+58M/uGmTWuxVi2u/s5cfdV33v22fj8NWtq69IAZKSm0rhBg1q95o6cHG598sn46q1b43H3C9x9Vm1d28xSzOxiM7vF3QuBTsCrwAnuPtjdn1HSKSIisl8PmdmUhydMiLZ7f5LM+Rw7fTrvz59vDj9z909Kv/Z/7huvcT+VYL3PO58zOwTgObPbYtD2avf7oohZkp/poUT9FCab1wLfAnoDO4AXgTHA+7VRU2JmfWNm7zdIT2/xh9GjY0d3717Tl4zE+u3bue3JJ+PLN27E4Up3f6E2rmtmfYDRwDVAZ4IS296Aq6xWRESk8sysXcxsTuumTVuN/9a3Yk0zM2s9ho2TJrFx8mQA2p97Li1PPLHWY/hy5Uqu/8tfvMj9XXc/vbxpRM+ZHe5BX4m/GrzvcEkGXDEiomlHkvw08llPuXuWu/8Z6AucC0wFRgHvAYvM7LBaiGF+3P3YvIKC5bc99VT8nf/9r6YvCcDGHTv4qpZGW5du2MB1jz1WtHzTpkKHK2o68TSzFmZ2q5nNAOYDPwRWAV8HBoRlz0o8RUREqsDd18fdR23Yvt3uGTfOdxVFkEOVHvms/auzdts27nzmmaK4+0Z3v3Jf/Suudp/jMA640eHqDLhKiafsi5LPes4Db7r7RQTlmHcQdMldYmajzOw9M7vBzJrW0PWXxN1PiMfjc384bpw//d57NV5CsiM3l7XbttXoNQA++Oorrnv88fimnTuz3P00d3+xpq4VNpJ6HlgLPAZ0BB4A+rr7UHd/wt21wKqIiMgBcve3gbs+XLjQfvrCC8RruUqwdLOO2q5Q3JadzW1PPhnfmp1dEHe/MOwlsk8x+ABIc9g5IknWNZfkpeTzIOJBB9Y/uvup7p4HZAA9gCeAdWb2ipldb2Ztqvm6a+LuJzpM+uObb3LH00/7tuzs6rzEHnq0a8fJh9XcwG5RPM6jb73FHWPGkJOfvzzufry7v1+d1zCzTDO70MyeMrNrgK3AMcB4guZS3dz9Xnf/qjqvKyIiIuDuvwMeeuvzz/nNq6/W7rUj6nabt2sX337mGV+5eXM87n6Zu3+4v2OeMTvd4UKHvxtc/qzZoNqIVeouzfk8yJlZCnAGcCXBsi2tgCJgBvAK8G93X1pN14oBPzT4WasmTfyBK69MGVwD80C/XLmShevXc9HgwdV+7tVbtnDf88/758uXG8G6mTe6+47qOLeZtQbOBy4k+J5kAnnAb9z9J2aWEtXSLQcbM+sMfKOcl5e7++Phfi8DXdy90v/ZmlkzoNDdD+hJTLikTrMEL+0AFgNvHsjPqJmdDxwP/LwqsZpZR4L2/MOAxsA9wOcEDdG+VpGbmzLnaw1sBL7p7n8KtzUAGgLbIl8jQUTqjXDFgCeA66/42tf43vnnE6uFRQQ2TZ3KhrffBqDtWWfR+uSTa/yaO3Jz+fbTT/vny5cD3ODu/9jfMc+ZHePwcCGc55CWBosN/nu1+9k1HrDUWalRByDRCpOZt4C3wkT0RILk50LgIYKb2vvM7C7gI+CjqnZODeci/sLMpm/Jyhp3y9//3v7so47iznPPpVWTJtXyfgA27tzJwrVrq+18AAWFhYx5913+MW1afFdRUSFwp7s/dqDnNbNewAUEX++hQAqwBfg3QfI/0d2zoOR7JbWjI3A3sBnYXua1mcDj1XCNmcCHBHOxD8RGgsTuLILEbku4vRvwJLDZzAa7+8Yqnv80gnL93wJVSZR/BRxN0BxrBbAa6EPQICuvCucrCo8t/X35NvBLggc2Kj8XkWrh7m5mNwMp42fMuHZbTg4/GzGCtJSUmr1wTY98uu9xjdKNE4GbK5J4jjXrF4NHHC66zn1buO1h4Mdjze40eG2U+8Gz3p5UmJJPKREmN9PCjzvN7Ehgi5l1A34T7pZrZh+G+0wlSEYrVd/v7u+aWT/gF2999tmt786bx61nnBG7bMgQ0lOT60fS3Xlv/nx++9pr8TVbt8bMbLK73+7uCyp7rvAJ6gDgFGCgu/8fcDnwC2AZ8CeCJVLeC5dMkejd7+5/jDqIfXH3J8zsPCCLYJS8pOGUmRUC9xI83HgiohCHEDxEebnUtnUEJf+V5u5bq3qsiEhluXuhmf0fsH7i559/f1t2tv/qqqusacOGNXbNmp7zmbd2LRunTKFh585sad6cb02YULRp585Ch8vdvaI1xqcajLzGfUPxhhj8ziHDoB3QqNoDl3ohue70Jam4++fFf7dg/aZTCRKnk4GfhR85YefVacBj7r5l7zMlPPc24HYzeyK3oODx373++nFPTp0av/y442KjTjyRRhkZ1fxuKifuzvvz5/O3yZPj81avjsXMNgB3x+PxZyp6DjNLI0g2jyf4mg0DWocvbzazDgRL37zi7l9U6xuQyJjZUcDZBJ2mY8ACYJyXegJsZt8BmgP9zezucPMydx9fxcsOBD5P0Ok4J/yzWu9ezGwUsAt4k6A8+UhgJcH7nBnu05cg6e0A9Cv1Pksb6+5rwv0vIyjLHQ/cRjBauo6g9P+DUtduSLCE1DvuPsvMTif4twXwXTPbFf79ceBqYIO7/zvBexhNMPXk6ap/JUTkYBCW899tZus+WrTodyP/+MeiX191VcqAzp1r5nqx3S1ZrAaSzwYdO9L6xBNZ/MQTxAoL+SFYHCa2gYwxZs2LRzL35ZpgRYU9XB1M8fhBtQcs9YqST6kQd18NjA0/MLMuBDd8xcnoycCjZjaSICmdBcwO/5zl7pvLOe9nZnY8cNH2nJx7/zZ58sBx//1v0eVf+1rKuQMH0qV160SH1Zht2dlM/N//GD9jRnz5xo3FSeev4+5/c/ec8o4zs0zgCGARQVIxniDxTA932UKwzM00ghHjL0olCqtr5t38P3v3HR5VtbUB/H33pJGQhNATIJCQQAiEkoQWeu+g0hSJBWmKFAFRxIoFlUi/KkVRLxexfYqoVwTRKwpWpNgowgVFpYmAKBBy1vfHmXBDSyPkZGbW73nyBGbOnHknIWHW2WvvrRyyFsD3sLfCMbCLs8kkOzFcDuAAACAASURBVOcoohrBXvCrLOwiCwD8s09A+9/dHhHJc+Kyew5kNOxR83N1BGABeL9wL+Wiboad917Y7a97YLcPj3a3+H4DIAL2a/OHfdElJcfjK8Nu8f8PgOx9ka6HPaJ5M+z28+0A+rnP2UZE1rmPC4Hdynsc9u+XarBX8gbsr2t2e3oggLoAHiV5pn0dODMP9RnYK0YrpVS+iMhMklv2Hzny4k1PP11udLduvLZFC7CI54HyMm+18tfJk3h4/XpsPX0ak4HT5e16oDeA3n5A1hJyI4DVAry1E1h3n27hpoqQFp+qUERkN4AX3B8gGSUiR0gehb2VSycAA7OPJ7kH9hvFHwB8JyL/dBdsf7uLsP8D8H8kux07ceKuRWvWtFy0Zg3qVasmPRo1YpvERFQKv9CaKpfuzxMnsH7bNrzz9df4ZNs2ybIsGnI37KLzuZxzXEmWAxAH+01yHOy5aw3dn10A0mHP1TwF4Fn3a/4cwBbdf9Mj9XIXKjktEJGduTymoYj8mP0XkiEA1sEudNoCgIikk9wB4FMRudQ5n9mLHX2d4zn9AUx0P98kEfnvJT7HhTQGMEZE5rqfMxL2KO9tsBerWA9gPclfAKwWkRE58nWDXXyeqw6A+0XkAfdxZQBsBXA7gCsvFEJEFpOsBHvO5+CcWw6RfBp28X81zm47vhF2Z5tTrchKKQ8lIqtJ1hVgycy33+70wbffyuQ+fRhXuXKRPcdZpWwRj3x+9P33eHT58qx9R44YAHNPAy8K8Dbti6GA/V4mBUAKgTtqAgf/RX4gwGoLePs6ezBCqULT4lMViezWORF5G8DbAECyBuyRiGT35yYArgCwBfYI6gwA15PcCXvE8EcAu0RkNoCnAbT87uefe37z009VH3vzTVQrV85qEhdnGsfGIqFKFURFRMBlCr5b0P6jR/Hjb7/hy5078fmPP8oPe/fCEqEhj1ki7wD40BL5FUBFAPeS/Bj2oky/wp7HkNMfsFfufA/2m/8PReQYgOYFDqZKokYAzl2S+XXYC95cUHbh6S4AK8Ee/V4FYFgBnrcW7BHL/MguPh8iOQX2G4dI2KPvjURkcwGetyB+hj1PGQAgIr+S/Aj2aGNhHQXwSI5z/kHyPdjzRgtMRL5xZxoOd6HpXnV7KIC3ReTnS8iqlPJRIrLffRHttk27dz9wzdy5pQalpXFEx44ILoJpQzm3WimqOZ97Dh7E42++Keu3b6cx5icAN4vIuwCwhOwE+31MuQs8tLwA/QH0N/ax3wFYYQGrjwBrRxdyEUrluzyi+CRZC/bcnbxMB1Ad9iIueXkY9pukK/Jx7P2wr/L3yOO40yLyoLuNtHMex/4lIo+RzG5bzc0REZlBsjPs+YO5OSgic0n2gF3s5eZXEXma5BWw32TnZo+IPENyAPJ+c7lDRP7pzpr9Jvor90cAgGCSD8BuxctupWsBe5uRsy74WfYI02IA3X86dCjip0OH/F/77LMzx/i5XPB3ueAiEejvj1KBgTh+8iQIYP22bTjy9984nZWFLMvC6awsnM7KOreFJdOdz88SCYU9Wjvw7EOwDkAz2AXHStiFRFPYK3XmbMWtCaBmjnaZ90XkI5J3wW4BzM27IrKe5H3Ie//dN2EXvPfkcRxgr5q7Hfmbg7EMdgvwhHwc+0/Ye4+Oycexz8IeCR6Zj2Ofht2meVM+jp0LezXm6/Jx7AzYBdk1F7l/ffZ/wuco8IJDJAcCuAt227U5574yko+5NPk5JodGAE4CqCEip0hWht1J0A92W+zFcga59/strB8vsK3JIdhdAIW1W0Qyz7ntEP43V7owngawlGQjEfka9qrANQDcegnnVEr5OPcijRkkl4rIo0s+/jj9za++sq5OSzODWrZEaFBQoc+ds+02+09WZibkdN5rEUpWFuTU/9aB3HfkCJZ/+SXe3bTJyrIsqybwr3TLyogH/lpKpgD2f1QERmcBT8KeOpSbRACJBrgjAvjrX+Q6AVYTWHGtyHcFe6XKF3nEPp/ufebys/pWJOx5iMvycWwY7Cs5z+TjWD/Y85Dm5nHcKREJdC+s8Wgexx4WkbLuIuyibxDd9opIVZLTYbfS5WabiNQm+aQ7c242ikgjks/Bnm+Vm3Ui0oLkK7Df1OZmlYh0Jvk2gO55HLscwFUAPoaDo4UkT4qIP/Iu/KaJyF0k98EeGc3NPSLyEMljsBdSyc0E9wUGC+cU4BcwEsDzyN+WEtfBHom+4Jzbc/QF8AXs+Xt56QZgF+w26ry0gb0S61f5ODYV9n6Na/NxbCLs+X4r83FsddhtRP93kftnicht2X8h2RT2Nihjcys+z93n0734zSrYBfc/YM9nPAm79fNBAOWz5z8XVdstye2wL1Cl5ritO+zv+3QRmXTO8fNhXww4CLsQu01EPsvl/LNgb7VSQUQOum/7BPYFtE7nHPs8gBYiEpfjtl8ArLhA2+1Z+3ySXAEgSkRSzjnnTADXi0hZ998vtM/nnXBvtZKz7dZ9XwDsf9P/JyK3uL9nKQBiRLcvUkoVEZIdST4qIimB/v7SsnZtNouPR2FWxQ3ZuhXhX+Xnv8zL4iTyvmB+MTthzxVdHQS811/k3K3KlPKMkU/YKyrmdSUGsFu2/i8/x4rIMZL/hD0ylNexWSQXwL3YTm6Huj/PhH21PTfZLXWPwB6Vyc+x98DeliM32W+mxsPe8y8/x94M+81lbrIvt10Pu2UtN9kjF/2RYxEV2O2AMbBHTusCqGuMqS8iJ9yF3xmBgYFWxYoVERERYcLCwhAWFoaIiAhEREQgODgYISEhCAgIQHBwMADA398/+3HYuHEjfvrpJ/Ts2RMnTpwASZx2Xy08deoUMjMzcfTo0TMfx48fx/HjxwMPHTqEI0eOyP79+62jR4+et4mXMeaAZVlpJGfDLiS+hb2wzMWKwOxRpSrIu6DMPkeZ/BzrHuHKz8/EX7C/d/k59jjsfxP5PdbK57F/wv7ZyM+xx2C//vweuz2fxx6FXQhe7Niiahvq6H6uYedseRJ9gWMt5H2xI1ckw2GPuC84565VsBcC6glgUo7jqwI4KSJj3H//C/YczasvJUcJkP21Pu9nx/2z8gzs1bVnwf6aTNXCUylVGLT3RE+AvchgbQC1SNY2xtSyLKs0AJzMzOT733yD978p3EL2nWEvIOGQ32BfsC2MWABXGqDUKeD0A+RyXaxIncsjik+x9zzM79WTzPwe627vyu+xp2CPFhT1sSeRzze+7ha5fLXJFfDYv5HPjdlzW/E1J/eeljVgt9M2dW8/UU9EzlxNK1OmTFZ8fLwrKioKkZGRqFy5MipXrozIyEiUKVOm0G/KY2JiYFnWmYK0gAjAdeLECfz666/49ddf8dtvv2V/VNi5c2ervXv3trYsK/tNrhhjdlmW9TXskb2PAXyZc/RF7KXH86WAxxbkiqK3HmsV4NiC/B4pLMJuLS8NuwjNXhn6Qu2++2B3a5x/EnsbkD9F5GIjtdkauZ/z65w3ikgmydUA+pKME/c2L+45jjlbpSNhLxDm6X5zf46CPX/8XAsA3IH/jXznp+NFKeXjSPrBLjRTsj/cLfxnhjNLly5tRUdHMzo6mtWqVUPVqlURGhp6Sc8b9NlnkLffBv/6C+JyQc7ZA138/YH8vMcxBlZgICzLQmZmJk6dOmV/nDwpWf97HwMClgUcqwAwtHCF55l5oNHAh211r3KVC48oPlXJ5165tjHsYjPNGNPSsqxwAAgICLBiYmIYFxfH2NhYxMbGombNmggPDz9vdLEonDhxAidOnEC5cheaN58/QUFBiImJQUxMzLl3mVOnTmHXrl3YuXMndu7cyR9//DF2x44d1Y8cOdIXAEieNsZ85d5W4xPYLcu/nXsi5ZVehT1n9n13Z0UF2IvdbMH5beVvAZhG8l3YbaHficgs930Z7tsuWHy6r7w3hN3+DACZJOuKyLfnnL8vgBtIvuae75jzHDVg/7x2LcTrLGnWwL6A9hbJT2Ff0Lsru8VZRHaTfAf2vPLXsxdIU0qpnNwLxTWGPV2ktTGmlWVZIQBgjJHq1atLQkKCiY+PR61atVC9enWEhYVd8GL5jh07cOrUKSQmJhY8SEoKPqhTB1WrVkV8fPwlvKKL4tGjR7F7925s374d27ZtM1XWrw+L/eOP/O4Z8xeBdQK8ReC1a3XxNlUAWnyqQiMZC6Ajyd4kO4lIAACUKVPGSkxMNElJSUhKSkJCQoIp5ChkoWzYsAEbNmzA2LF5dRIXTkBAAGrXro3atc9aV8V18OBBfPPNN9i8ebPf5s2bG+/YsaOpiIwHAGPMLhFZBbsgeE90dbiS7ncAr8Bu683NOtjbiwAAROQL93zGCbDb2X+CPUf3bwBDcHZHxHTY82abw973Mue84Ddhz8m8mIqwR/LgztkVdkt7zkWo3nHfVwv2Sru3ZN9BshrsOalXiMjhPF7jRvd5cv6bXYMLd3d8AfeIbw4rcP5831/d58w5F/kT2HuDnmsT7Lnh2U66H3tmhFNEfiaZCrt9uLr7POe+IXwTdvF5bouyUspHubu0UmD/Dm1LMi17VLNcuXJZKSkprrp166JWrVqoWbMmAwMD872h57fffotjx44VrvgEsGLFCqSkpFyu4hNhYWHIfp925NlncSSPwvMAIP8F9v4XWPMJ8OQh4PMLLDqnVJ48YsEhVTKQDIM9p62rMaa7ZVlVAKB8+fJZzZo1czVs2BBJSUmoXIR7XRXG2rVrL2vxmV/Hjx/HN998gy1btuDzzz+Xbdu2UURgjPnbsqzVsOcyvysiuxwNqnwKyQaw54SPzx4Z9AXuBdBqA6glOgdJKZ/l7tRKA9DLGNPfsqxIAChbtqxVv359k5qainr16l2o86lAli9fjmPHjmHw4MKtKTdv3jwkJSWhTZs2l5QjL0cWL8aR5547/w6XC4GJibAaNMCuMmWwbvdufP7551n79u1zAQDJgyLyb9gXGN91bzOnVJ505FPlimQp2AVnf/cv6SBjjCQmJrJFixZISUlBrVq1XDmXBVe2kJAQNG3aFE2bNsXQoUN55MgRfP311/jyyy9Lffzxx90PHz7cCwCMMd+LyMsA/iUieY20KVVoJPvAbicb6p4X+piI3JHX4zyVu4WuBoAOsFuUb9bCUynfQ7Ic7GkIV5FsJyIBfn5+VqNGjZiWlobmzZsjMjLykhaAK2p79+5FpUrnbi1etI6++OJZhacrIgJBjRujVIsWKNW4MRgSAsBeHCDNfcjevXuxbt06rF+/vtymTZsGnz59Ot0Yc5LkKthTRV4v4HZhysfoyKc6D8kQ2CtCDiTZXUQCQ0JCstq0aeNq1aoVkpOTEXQJ+1ddbiVl5DM3lmVh27ZtWLduHdasWWP99NNPBgBcLteXWVlZywC8IiL52fJEqXxx7yn8Es7eSue/IpLX1kkei2Qd2AthCIAlAG7Q4lMp3+Du1uoD4GqSnUXELyIiwmrRooVp1qwZGjdufFnfy1zqyOdNN92Exo0bY+TI/GyRXXBHly3Dkfnz4R8fj6CUFJRKS0NgvXpAAQYTjh8/ji+++ALr16/HunXrrKNHjxqSp0TkHQBLAbx17vZXSunIpwJwZt5DawBDSfYTkaDg4GCrVatWpl27dkhNTXUV57xNb2eMQUJCAhISEjBkyBCzY8cOfPDBB1izZk3yL7/8kgpgujFmnYgshF2I5muVYaUuRkQ+QN5703qbHbC3ovlNf4aU8n7u1Wl7AEgn2VNEAkNDQ7Pat2/vat++PerXr2+MKVEDnI44vWcPXGXLosobb8CEhxf6PCEhIWjbti3atm0Ly7LMV199hffffz/gP//5T++//vrrCmPMcZL/B3urwvf14p8CtPj0eSQrArjOGDPcsqx4f39/q3Xr1qZDhw5o0qRJsS4U5Mvi4uIQFxeHYcOGmW3btmHNmjVcuXJl899//72FMWaee+XUheeuWKqUujj3dlo7nc6hlLq8SFYBMNgYc6tlWVUDAgIkLS2NXbp0QZMmTVx+fvp2Nye/6Gj4RV9o++nCM8agcePGaNy4MSZMmGC++OILfPDBByH/+c9/rj158mQ6yV/c72X+ISI/FemTK4+iP40+yD3K2QHAcJJXiIh/dHS01atXL3Tu3NmEhYU5HfGSBAYGIsQ9T8ET1apVC7Vq1cKwYcPMp59+irfeeqv0p59+OtKyrJtdLtfXlmXNB7BERI47nVUppZRygnuUsxfJ4QC6AGBiYqL07t0bbdu2ZWBgYB5nUJeLv78/0tLSkJaWhnHjxpnVq1fjzTffjNyxY8cdJCeQXA575fHVOhrqe3TOpw8hGQCgj8vluiMrKyvF399fWrRowd69eyM5ORm6aFDJdejQIaxcuRLLly+3fvvtN0PyTxF5FsB00f21lFJK+QiSoQCGGGMmWJZVLTg42OrQoYO54oorEBcX53S8M0r6nE8nbN26FStWrMCqVausEydOGGPMLsuyZsPu7NKpET5Ci08fQDICwEhjzFjLsipVrFjRGjBggOnevbtHjxBezKFDh3D48OES9Z9QUbEsC1988QWWLVsmGzZsIMlMEVkCYIaIfON0PqWUUupycO9PPMYYM8KyrNCaNWtaAwYMMO3bt0dAQIDT8c6jxefFHT9+HKtXr8ZLL71k7d271xhjDlmWNRd2S25ue1wrL6Btt17M/Yv6dpI3iUhwfHy8dc0116BNmzZePeH+yJEj+OWXX7yy+DTGZG/fwh07duCll17yf//992/Iysq6wRizSkQeEZH/OJ1TKaWUKgok6wG4k+RAEfFLTU2Vq6++GikpKd77RgZApUqVUK5cOadjXBYhISHo06cPevXqZdatW4dly5aV3bJly/0kJ5PM7urSPdC9lI58eiGSFQBMIHkbAP9mzZqxf//+SElJcTqaugx+//13LF++HK+++mrWn3/+6QKwDsDd7tVNlVJKKY/j3ippMslrXS4X27dvz0GDBiEmJsbpaPlyqSOf8+bNQ1JSEtq0aVPEyUqmbdu24ZVXXsHq1atFRLJE5EUA94uILhrnZbT49CIkywOYSHIcgMBmzZph6NChXjkCmJsffvgBu3btQrdu3ZyOUqz+/vtvvP7661iyZIl1/PhxQ/J9EblLRD53OptSSimVHyTjAdxLcpAxhr169eLgwYNRoUIFp6MVyKUWn+PHj0dKSgquvfbaIk5Wsv300094/vnnsXr1agDIFJH5AKaJyC8OR1NFxKtbFnwFyQiS00juAXBH8+bNAxYtWoRHH33U5wpPADhw4AC2bdvmdIxiV6pUKQwaNAjLli0zgwcPRmBgYDsAnxljVpBs4HQ+pZRS6mJIViX5LMnvXS7XtT169DAvvvgib7vtNo8rPItCZGSkT77uatWq4e6778Zzzz2Htm3b+pMcRXInyRkkvbMP2cfonE8PRtLA3tdqhmVZ5ZKTk2X48OFISEjQZWt9WFhYGIYNG4YBAwaYZcuW4dVXX+1+6tSpHiSXAJgkIr85nVEppZQCAJKlAUwieTvJwC5duvC6665DVFSU09GKjWVZOHctjsDAwBK5kFJxqVGjBu6//378+OOPfPbZZwM/+eST20gOIXk/7IWJMp3OqApHi08PRbITydkiUic2NtYaM2YMGjRooEWnOiM8PBwjRoxA3759zcKFC7Fy5crBJK8kORXAbBE55XRGpZRSvsl9Ab2v+wJ61eTkZBk1ahRr1qzpdLRisXnzZrz88sv4+eefcerUKezbtw+PP/74mfU5Nm3ahICAALRt29bZoA6rWbMmHn74Yfzwww+YO3du2DfffDPTGHMrycki8orT+VTBaduthyEZT/JlAO+VLl269ujRo7Fw4ULToIF2VaoLK1++PCZPnowFCxawbt26IQAeN8b8QLK/09mUUkr5HpJtSH4N4OWqVatGTZ8+HTNmzCixhefhw4fx9NNP44MPPsCxY8cu6Vwigvnz52PatGkYOHAgnnvuOUyZMgWnT58u9GiviGDr1q144YUX8MEH3rnWYEJCAubNm8e7774bZcuWjQHwsjHmffdqyMqD6MinhyAZBOBukpNcLpffgAEDkJ6eboKDg52OpjxErVq1MHfuXK5ZswZPPfVU9QMHDrxsjHlPREbqkuZKKaUuN/e+448CGBYSEiI33ngjrrzySuNyuZyOlquIiAh0794dY8eOxR9//IH4+HikpKQgLS0NdevWPa9lNjdLlizBW2+9hUWLFqFSpUoA7JVeQ0NDUbly5Xyf5+jRo9iwYQO+/PJLrF+/HgcPHkT//v29eqSUJDp16oTWrVub1157DS+88ELbEydObCT5DwBTRORPpzOqvGnx6QFItjbGLLIsK7558+YyevRo+tJcCFV0SKJDhw5o2bKlefHFF/HPf/6zk2VZ35KcAmCOiGQ5nVEppZT3IZlujJkpIuV69uyJESNGMDQ01OlY+RYdHY3Zs2dj7Nix2Lp1K7Zu3YqlS5eiTJkyaNiwIdLS0pCWlobcXtP+/fvx/PPPY9iwYWcKTwDYvn074uPjQeY+e2rXrl1Yv349vvzyS2zatAmnT58+c1///v0xatSoPM/hDQIDAzFo0CB07tzZzJo1C2vXrh1jjOlDcriIvOd0PpU73WqlBCMZDmAqgNHh4eHWqFGjXF26dHE6Von322+/4cCBA0hKSnI6Som3d+9ePP7447Jx40aS3CwiN4nIl07nUkop5R1IxpJ8WkQ6ValSxZo4caJJTk4u1gzz58/Hxo0bi+RcJ0+exL59+/Dnn+cPshljzoyKZmVlITQ0FOnp6WfuX7x4MZ5//nm88sorZ61kO2zYMCQnJ+Pmm28+c9tNN92EBg0aoH79+meNbl5IxYoVUb58+SJ5fQBw//33n1Ucl3Tr1q3DjBkzrAMHDhgAbwEYKSJ7nc6lLkznfJZQJPsYY34AMKZbt25csmSJFp75VLlyZS0886lKlSqYOXMmx48fj6CgoHok15N8xN3mrZRSShUKbWNJfufn59dh6NCheP7554u98ATsOZFF9eF+bYXKsWHDBsTExJxVeB49ehQ//vgjatWqdcHcTr1GT5KWloYXXnjB9O3bF8aYHsaYb0gOdDqXujBtuy1hSIYCyAAwvEKFCtakSZOQmprqdCyP8vXXX+P777/HoEGDnI7iEYwx6NOnD1q2bGlmzZplPvroo8kkryJ5tYgUzaVipZRSPoNkNMnnRKRd3bp15a677mKVKlUcyzNy5MgiOc+ePXswbty4sxYdCg8PR6NGjZCamooWLVqgbNmyAIDly5eftzjR4cOHzxtRXL16NbKyshAfH3/e8wUGBqJt27Zo27YtLMvC9u3b8dVXX53Xdrt//360adMGt956a5G8Tk8UHByMMWPGoHPnznzkkUfCdu/evYxkHwCjROSw0/nU/2jxWYKQbE5yqYjUuPLKKzFy5EgTFKQDUAWVlJSExMREp2N4nHLlyuHBBx/E+++/jyeeeCL+r7/++pzkHQBmiSdeClVKKVXsSPY3xiwgGZ6eno7rr7+eBVmQp6Tas2fPmQWHateuXagFh+Li4vDll19i3759qFSpErZs2YLXX38dpUqVQtWqVc86tkGDBkhISDjzd2MMateujdq1a2PQoEHnLTj0yiv2riO+XIAC9qq4ixYtMosXL8aLL754NckOJIeIyNtOZ1M2nfNZApD0AzCB5EOhoaFm8uTJJi0tzelYHuuvv/7CyZMnERER4XQUj7Vv3z48/PDDsmnTJpJcIyLX6fwJpZRSF0OyHID5APrGxMRY99xzjympW6cU1OHDh/HSSy+hVq1aSE1NRVhYWJ6PyR75HDx48JnbDh48iIceegjfffcdIiIi0KZNGwQGBmL16tUAgEWLFiEkJAQAMH36dDRo0ACdO3fO87ksy8K2bdvw2WefITo6Gu3atSvkK/UuGzZswCOPPGIdOHCAAOYBuENE/nY6l6/T4tNh7on4/xKRZs2aNZM777yTWjRdmrVr12LDhg0YO3as01E8mmVZWLp0KZ599lkRkT8sy7pRRJY7nUsppVTJQrKpMeZVAFWuvvpqDhkyBP7+/k7HctSmTZtw4sQJNG3a9Lz7Tp06BT8/v1xHTDMyMlCvXj107dr1csb0esePH8esWbPw3nvvwRiz2bKsviKyw+lcvkyLTweR7G6MWepyuUJHjhxp+vbt6xNLZF9uWnwWra1bt2Lq1KnWzz//bAAsAHCriGQ6nUsppZTzSA4nOS80NNTcc889riZNmjgdSanzrFq1ChkZGdapU6f+tizrJhF5yelMvsrzm/A9EElD8gEAb0VGRoYuXLjQ9OvXTwtPVSLVrl0bzzzzjOnQoQMADCe5imRFp3MppZRyDslQkssAzE9KSvJbvHixFp5FaN26dfjvf//rdAyv0alTJyxcuNBER0eXArCM5HySAU7n8kVafBYzkmEAXgNwb/PmzbFgwQITExPjdCylchUUFIR7770XEydOhDGmtTFmE8nmTudSSilV/EgmGWM2khx47bXXYtasWSzKfSYV8MUXX+Cnn35yOoZXiY6Oxvz58417Hu1wl8u1lmTVvB6nipYWn8WIZAP3m/YrBg0ahEceeYSlS5d2OpZS+darVy/Mnj2b4eHhFUiuda+Gq5RSykeQ7GWMWR8cHFxj2rRpGD58OFwul9OxlMqXoKAgTJkyBbfffjuMManGmK9I6pB9MdLis5i49038NCQkJDojIwMjRozI99LcSpUkSUlJWLRokSsxMdEAeJTk0+4Vm5VSSnkxkmMBLK9cuXKpp556yjRvrg0wyjP17NkTc+bMMWFhYeXdF9PTnc7kK7T6KQYkJwB4tXr16gHPPPOMSU1NdTqSVwsICEBwcLDTMbxa+fLlMWfOHPbq1QsARpB8i2So07mUUkoVPZKBJBcDmJWampo9d87pWEpdksTERDzzzDMmPj7eD8DzJB8lqbXRZaar3V5GQ2PDzAAAIABJREFUJF0AZgMYlZKSIg8++CCz929Sylu8+uqrmDdvnpD83rKsbiKyx+lMSimligbJCiTfFJFm/fr1w6hRo7RzqxjMnj0bycnJaNWqldNRvN6JEyfw8MMP46OPPgLJ10XkWt0P9PLR3x6XCcnSAN4AMKpbt254/PHHtfAsJocOHcLOnTudjuEz+vXrh6lTp9LPzy/BGPMFyRSnMymllLp0JGsYY9YZY5refvvtGD16tBaeyusEBQVh6tSpSE9Ph4hcSXI1yQinc3kr/Q1yGZCMJPkJgJ7Dhg3DnXfeCT8/nRJXXI4cOaIrxBWz1q1bY+bMmaZ06dLljTEfkdRdsZVSyoORrGuMWefn5xf7yCOPsGfPnk5H8inJycmoWlUXYi0uJDF06FDceeedINncGLOOZDWnc3kjbbstYiSjjTFrjDExd911V/beiEr5hL1792LixInWr7/+miUig0TkVaczKaWUKhiSzYwx/y5VqlTYY489ZpKSkpyOpFSx+fjjj3H//fdbWVlZv1iW1VFEtjqdyZvoyGcRIhljjPmPn59fzLRp07TwdMjWrVvx7rvvOh3DJ1WpUgVPPvmkiYmJcZF8ieSNTmdSSimVfyT7kPxPuXLlQp966iktPB3y9ttv4/vvv3c6hk9q2bIlMjIyTFBQUJQxZr1uxVK0tPgsIiTrGGPW+fv7Rz/66KOmSRP9d+qU/fv3Y+tWvUjllIiICMydO9ckJCQQwDMkxzidSSmlVN5IDiD5WrVq1fyeeuopV/Xq1Z2O5LMaN26MatW069MpDRs2xNy5c01YWFiYMeZ9kmlOZ/IWWnwWAZLJxpiPg4KCKs6aNcukpOh6K8q3lS5dGrNmzWJycjIAzCI50elMSimlLo7k1SSXxsTEcN68eaZChQpOR/Jp5cuXhy5U6ay4uDj84x//cEVERAQbY94j2cLpTN5Ai89LRLKxMebD0NDQ8Llz55rExESnIylVIgQFBWHatGls3LgxAEwneZfTmZRSSp3PPeK5JDY2lrNmzTLh4eFOR/J5c+fOxccff+x0DJ9XtWpVPPnkk6Z8+fJBJFeRbOt0Jk+nxeclIFnfGPNeWFhY8Lx581xxcXFOR1KqRMkuQNPS0gDgYZLjnM6klFLqf0gOJLm0Zs2aWngqdQGVK1fGvHnzXBUqVAgg+Q7Jdk5n8mRafBYSyXhjzOpSpUqFZWRkuKKjo52OpFSJ5O/vj6lTp6Jp06YCYAbJkU5nUkop9b9W2/j4eM6aNcuEhYU5HUmpEqlSpUqYPXu2q1y5cgHGmLd0DmjhafFZCNnbqQQGBpabOXOmiY+PdzqSUiWauwBlgwYNAOBJkjc5nUkppXwZya4kX6hZsyZmzpxpQkNDnY6kVIkWFRWFuXPnuiIiIoKMMf8mWc/pTJ5Ii88CIlnFvZ1K1GOPPWZq167tdCR1jri4OLRrpx0RJU12C27t2rVBcgHJAU5nUkopX0SyqTHmtcqVK7umT59uSpcu7XQkpTxCVFQUnnjiCRMcHBxijFlNMsbpTJ5Gi88CIFnWGLPG5XJFP/bYY8Y9iqNKmMjISNSvX9/pGOoCQkJCkJGRwRo1aoDkEpK6Ga5SShUjknWNMe+WKVMmcObMmaZs2bJOR1LKo8TExCAjI8MVEBBQwb0NS2WnM3kSLT7ziWQgyTcAxE+dOtW4t5BQJdDGjRvx4osvOh1DXURYWBhmzpxpKlWq5DLGvK5tK0opVTxI1jDGrA4ODg6dMWOGKzIy0ulISnmkOnXq4MEHHzTGmBrGmHdJ6kpd+UQRcTpDiUeSAJ4HkD527FhcddVVTkdSucjMzERWVhaCgoKcjqJy8csvv2DEiBFZf/75537LspqIyM9OZ1JKKW9FMswYs97Pzy9hxowZJikpyelIKheZmZkwxsDlcjkdReVi7dq1uPfee8WyrLUAOonIKaczlXQ68pk/DwFIv/rqq7Xw9ACnT5/G33//7XQMlYeoqCg8/PDDLmNMZWPMCpI66UgppS4Dkn4kXxOROvfff78Wnh7g6NGjOHHihNMxVB5atWqFm2++mQBaA5jtdB5PoMVnHkgOAXBXmzZtMGLECKfjqHz48ssv8cILLzgdQ+VD/fr1MWXKFIpIQ5Ivk/RzOpNSSnmh2SLS8ZZbbmGLFi2czqLy4ZNPPsHu3budjqHyYcCAAejTpw8AjCQ5xuk8JZ0Wn7kg2YHk/MTERGvKlCkwRr9cShW19u3b46abboKIdAMww+k8SinlTUjeBuCW7t27Y8AAXWTcU/Tu3RuJiYlOx1D5NGbMGCQnJwvJmSR7OZ2nJNNq6iJIVjfGvFyhQgVOmzbNBAYGOh1JKa+Vnp6Obt26AcBoktc5nUcppbwByZ4kM5KTk2XChAlOx1EFsH79eh359CB+fn544IEHGBUVBWPMUl1M8eK0+LwAkkEkX3O5XGUeeughV5kyZZyOpJTXGz9+PGJjYy2SC0mmOJ1HKaU8Gck4Y8y/qlSpgqlTp9LPT2c1eJLPP/8ce/bscTqGKoCwsDA89thjplSpUsHGmDd0BdwL0+LzwuaJSMqECRNM7dq1nc6ilFfLzMzEhx9+iMmTJ2PgwIEmNDTUz70FS3mnsymllCdyX0R/xd/fv/RDDz1kQkNDnY6klE+oVq0a7r33XiMisQD+6d4xQ+Wgxec5SN4M4Karrroquw1QKXUZHDx4EIsXL0a/fv1w3333ISYmBl27dsUDDzxgAFQluYykrjGvlFIF96SINJwwYYKJiYlxOotSPqVZs2ZIT08ngF4AtN/9HFp85kCyGcnZdevWtW655Ran46hC8vf3R6lSpZyOoS5iy5YtuO+++zBgwAA899xz+OOPP1CjRg0MGzYMAJCcnIyhQ4dSRDoAeMDZtEop5VlIDgNw41VXXYUuXbo4HUcpn3TjjTeicePGQvJRkm2czlOSUESczlAikAw3xmwJCwuLeuaZZ1zly2vHn1JF5fjx41izZg1ee+017Nq166z7/P398fTTTyMuLu7MbSKCe++9Fx999JEA6Cwiq4s5slJKeRySySTX165d22/evHnG39/f6UiqkGbPno3k5GS0atXK6SiqkP744w8MGTLEOnz48EHLshqIyG9OZyoJdOTzf54UkWqTJ0/WwtPD/f777+cVOMoZe/bswZw5c9C3b19kZGRc8PsycuTIswpPACCJO+64AxUrVhRjzBKd/6mUUrkjGWyMWVa6dGm/qVOnauGplMPKlCmDBx980JCsQPJ5nf9p0+ITAMnBAAb1798fzZo1czqOukSHDx/W5clLAMuycOzYMTRo0ABDhw5F3759UaVKFYSEhJw5pkmTJujbt+8FH1+6dGnce++9BkBFAAuLJ7VSSnmsJyzLip8wYYKpVKmS01nUJWrUqBGqVKnidAx1ierWrYshQ4ZQRDoDuNXpPCWBz7fdkowhuTk6Ojp40aJFJiAgwOlISnmd3377DVOmTMGOHTtQrlw5HDp0COHh4Vi8eDHKlSuX62MXLlyIJUuWAMAIEVlQLIGVUsqDkOwK4J0ePXpw0qRJTsdRSuVgWRbGjRsnmzdvzhSRVBHZ4nQmJ/n0yCdJQ/I5Pz+/4Pvuu08LTy+xdetWrFy50ukYym3Tpk0YOXIk9uzZg8mTJ+PUqVMA7H098yo8AWDIkCGoU6eORXI2yYTLnVcppTwJyQrGmBcqV64st96qAyve4t///jd++OEHp2OoImCMweTJkxkUFORnjPknSZ8uOHy6+ARwl4i0vuWWW0zNmjWdzqKKyP79+/UXdgmxYsUKjB8/Hv7+/pg3bx7atm2LY8eOoXfv3mjbtm2+zuFyuXDPPfeYwMDAAJJLSepO6UopBYC2xQDK33vvvSY4ONjpSKqIJCcna9utF4mMjMS4ceOMZVkNAEx1Oo+TfLb4JJlI8p7U1FS58sornY6jlFc5deoUHn30UWRkZKBu3bpYsGABateujf3796NKlSoo6FZGVapUwejRo42INAIw8fKkVkopj5MuIj2uu+461q1b1+ksqghVrFgRoaGhTsdQRahr167ZF94nkWzqcBzH+GTx6W63XeDv7+83YcIEXXxKqSJ04MABjB49Gv/+97/Rq1cvzJgxAxEREQDsxaDuvvvuQu3D2qNHD6SkpAjJB7T9Vinl60iWN8bMrFGjhpWenu50HFXE5syZg7Vr1zodQxWx8ePHIywszDLGPEPSJ5ek9sniE8AoEWkxcuRIExUV5XQWpbzGpk2bMGzYMOzcuRN33nknJk6cCD+//3XJ1qtXD4mJiYU6N0ncfvvtDAgI8CM5X68aKaV83BwRiZg0aZLJ+XtWKVVyhYeHY9SoUS7LsuoCuN3pPE7wueKTZLQxZlpCQoKl7bZKFZ3s+Z1+fn6YO3cuunXrdt4xLpfrkp4jMjISN9xwgxGR1gBuuqSTKaWUhyLZDcA1ffv21XZbpTxM165dkZqaKiTvJ1nH6TzFzReLz3+QDL7zzjuNMT738pUqcjnndyYmJmLhwoVISLh8XbEDBw5EfHy8ZYyZQVJXY1BK+RSSwcaYpypUqJB10016DU4pT+Tu5HKRfNrXOrl8qvoiOUBEeqanpzMmJsbpOOoyqVmzJtq0aeN0DJ9w7vzOmTNnnpnfebm4XC5MmjTJACgN4InL+mRKKVXyTLUsq/rEiRNdurqtUp6pcuXKuPHGG7M7uW5wOk9x8pnik2QpY0xGZGRk1uDBg52Ooy6jqKgoNGzY0OkYXm/z5s25zu+8nGrVqoWrrrqKAAaQbFUsT6qUUg4jWZvkmNatW6NZs2ZOx1FKXYIBAwagRo0aljHmcZJhTucpLj5TfAK43bKsaqNHj3b5+/vk4lI+Y+PGjVi2bJnTMbzaihUrcNttt8HPzw9z5sy54PzOy+2GG25AaGioGGPmkby0yaRKKeUBSM7y8/NzjRo1yukoSqlL5HK5MHbsWGNZVnkAdzudp7hQRJzOcNmRrEJye8OGDYNmzZrlU33VvigzMxOZmZnQdqSil5mZiRkzZuCdd95B/fr1MXXq1MveZpubN954AzNnzgSAoSLyjGNBlFLqMiPZA8Bb119/PYYMGeJ0HHWZnTx5Ei6Xq9g6ipRzpkyZgk8++SRTROqJyDan81xuvjLy+RjJoDFjxmjh6QOysrKQmZnpdAyvc/DgQYwePRrvvPNOsc3vzEvv3r0RGxtrGWMeIxnuaBillLpMSPobY2aWLVs2a9CgQU7HUcXgr7/+wqlTp5yOoYrBqFGj4HK5/EhmOJ2lOHh98UmyGYBBvXv3ZmxsrNNxVDH44osv8Nxzzzkdw6ts2bIFw4YNw44dO3DHHXcU6/zO3BhjMHr0aGNZVjkAU5zOo5RSl8mtlmXF33LLLa6goCCns6hi8NFHH2HXrl1Ox1DFICoqCgMGDKCI9CLZyek8l5svFJ8zQkJCRFtUlCqcFStWYNy4cTDGYO7cuejevbvTkc6SnJyMli1bguQ4kjWczqOUUkWJZLgx5p46depIx44dnY6jikmfPn2ge7j6jvT0dJQpU8YiOd3bt17x6uKTZHcRaT548GATHq4deUoVRGZmJh577DFkZGSgTp06WLhwIerUKZl7Id98880g6QcfmrCvlPIZ4y3LihgxYoS3vydVOXz66afYs2eP0zFUMQkODkZ6eroRkQYA+jqd53Ly9uLzgbCwMOuKK65wOopSHuXgwYMYM2bMmfmds2bNQtmyZZ2OdVFVq1ZF586dSfJGkrWdzqOUUkWBZHljzPiUlBRp1KiR03FUMfrss8+we/dup2OoYtSnTx9UrFgxi+Q09wV1r+S1xSfJK0Uk9brrrjO66qlS+Zc9v3P79u2YNGlSiZnfmZcbb7wRxhhCRz+VUt7jTsuySg8dOlSHPJXycv7+/rj++utdIhIHwGtXFvPK4pO2ByIiIqzevXs7HUcpj5G9f6cxBnPmzEGPHj2cjpRvlStXRrdu3UhyEMmS2R+slFL5RDKS5Ki0tDRJTEx0Oo5Sqhh0794dVatWtYwxD5IMcDrP5eCVxSeAgSKSdOONN5rAwECns6hi5ufnB/2+F0xmZiYef/xxZGRkICEhAQsXLoQnvtm57rrr4HK5COB+p7MopdQlmgIgUEc9lfIdxhjccMMNxrKsaAA3OJ3ncvC64pOkMcbcX7FiRaukrcqpikfz5s0xcuRIp2N4jOz5nW+//faZ/TtL8vzO3FSqVAm9e/cmgP4kk5zOo5RShUGyIsmhrVq1Ys2aNZ2Oo5QqRh06dEC1atUsY8ydJF1O5ylqXld8AuhhWVbtwYMHG39/f6ezKAccPnwY//3vf52O4RG2bNmC4cOHY/v27bj99tsxceJEePrPzaBBg+ByuQBggtNZlFKqkMaKSOA111zjdA6lVDEzxuCaa64xlmXFwAtXvvW64pPk7aVLl7a6dOnidBTlkEOHDunGzPmQPb+TJObMmYOePXs6HalIVKhQAR07diTJa0lWczqPUkoVBMkQY8wtycnJOtfThzVs2BBVqlRxOoZySJcuXVC+fPksklO8bY8lryo+SaaKSKt+/fqZoKAgp+Moh8TFxaFdu3ZOxyixMjMzMX369DPzOxcsWOCR8ztzc/XVVwOAH4BRDkdRSqmCGmlZVplrr73Wq95wqoJp06YNYmNjnY6hHOLn54d+/fq5RKQ+gPZO5ylKXlV8Apjo5+cnffr0cTqHctC2bdvw3nvvOR2jRMqe3/nWW2+dmd9Zrlw5p2MVudjYWKSkpAjJUSTDnc6jlFL5QdLfGHNbbGyslZKS4nQc5aB3330XW7dudTqGclCfPn0QHBxskbzT6SxFyWuKT5LVSfbr1q0bPXWxFFU09u3bh++//97pGCXON99843XzO3Nz9dVXU0RKAxjidBallMqngZZlVUlPTzde1mmnCqhBgwaIjIx0OoZyUHBwMK688kojIh1J1nc6T1HxmuITwFgArv79+zudQ6kSZ8WKFRg3bpzXze/MTWpqKmJjYy1jzG0k/ZzOo5RSeSF5a0RERFbr1q2djqIcFhkZibCwMKdjKIddddVVcLlcAuBmp7MUFa8oPkmWMsYMadKkCapXr+50HKVKjJzzO2vXru2V8zsvhiQGDBhgLMuqBqCb03mUUio3JBuISNM+ffq4/Pz0epmvmz17NtauXet0DOWw8uXLIy0tjcaY60h6xdUIryg+AfS3LCu8V69eTudQqsQ4ePAgxo4de2Z+56xZs7xyfmdu2rdvj+DgYAvAMKezKKVUHm4xxogvdKYopfKvT58+sCwrGMBgp7MUBa8oPkkOL1OmjNW8eXOnoyhVInz77bcYPnw4tm3b5hPzOy8mMDAQnTp1MiR76LYrSqmSimSoMebaFi1asEKFCk7HUUqVIKmpqahSpYpFcrQ3bLvi8cUnyQQRSevVq5fRNhWlgJUrV2LcuHEA7LYdX7+K3qdPH4iIAXC901mUUuoirrMsK+SKK65wOodSqoQhid69exsRSQDQ0uk8l8rji08Aw0mye/fuTudQJUTNmjXhi4s1ZGVlYf78+XjkkUcQExODp556CnXr1nU6luNq1qyJWrVqiTFmBEmX03mUUupcJIdFRUXp9ipKqQvq3r07/P39LQBDnc5yqTy6+CQZYIy5LiUlRaKiopyOo0qIqKgoNGrUyOkYxeqPP/7A+PHjsXTpUnTu3Blz585FpUqVnI5VYvTq1YuWZVUF0MHpLEoplRPJRBFp0LVrV91eRSl1QWFhYWjRooUh2Z9kiNN5LoVHF58A+liWVa5Xr17621qdsWnTJrz88stOxyg227Ztw/Dhw7FlyxaMGDECU6ZMQWBgoNOxSpQOHTogMDDQAnCj01mUUuoc6YD9e0oppS6mY8eOEJFSAHo7neVSePokyYFBQUFW8+bNPb2IVkWoTp06iIuLczpGsXjvvfeQkZGBUqVKYcaMGWjYsKHTkUqkkJAQtGzZ0qxZs+YKkiEictzpTEopRZLGmEF16tSRqlWr6oV0dcaIESPgculMEfU/zZo1Q2hoqHXs2LFrAbzodJ7C8tiijWRpkj1bt25tdJRH5WRZFrKyspyOcVllz+98+OGHUb16dSxYsEALzzy0a9cOIhIEoIfTWZRSyq2NZVnRXbp00cJTneXvv//G6dOnnY6hShB/f3+0a9fOkOxK0mPnVnls8Qmgt4gEtmvXzukcqoT54osvsHjxYqdjXDZ//PEHJkyYcGZ+57x583R+Zz40a9Yse8/PgU5nUUopt8Eul0vatm3rdA5Vwnz44Yf48ccfnY6hSphOnTpBRFwA+judpbA8ufgcEBwcbDVu3NjpHEoVm+z5nZs3b9b5nQXk7++Pli1bGpI9SYY5nUcp5dtI+htj+jVr1ozh4eFOx1ElzJVXXol69eo5HUOVMElJSahYsaJF8hqnsxSWRxafJMNIdmvTpo3x9/d3Oo5SxeK9997DrbfeipMnT+KJJ57AoEGDnI7kcdq3bw8RCQDg25ufKqVKgjaWZYW3adPG6RyqBPr888+xZ88ep2OoEoYk2rZta0SkOcnKTucpDI8sPmG33AZoy63yBRea3+lrW8kUldTUVISEhGjrrVKqJOhjjJFmzZo5nUOVQOvXr8fu3budjqFKoBYtWgAAAXR3OEqheGzxGRwcrJsxK6935MgRnd9ZhPz9/dGqVStDsgvJUk7nUUr5LmNM7/r160NbbpVSBVG/fn2EhoZaAPo4naUwPK74JOlnjOnSpEkT4+fn6TvFKHVx27dvx7Bhw3R+ZxFr2rQpRCQQgPa6KaUcQbKRZVnRLVu21FVulVIFYoxBWlpa9oX0EKfzFJQnVm/NLcsKa9q0qdM5VAnlcrkQEBDgdIxLsmrVKkyfPh1BQUHIyMhAcnKy05G8RuPGjWGMEcuyugJ4N7+PIxkNoAuA6gBcAHYAeFdE9l6epJ6DZHsA5S5w12kAuwFsEpFC739EsjaA+jluOuk+7/cicqqw583j+d4BcIuIrMzjWANgO4BZIjK3qLMor9UHONM+p5RSBdKyZUusXLkyEEBHAMudzlMQnlh8diOJJk2aOJ1DlVBpaWlIS0tzOkahZGVlYdGiRVi6dCni4+Px8MMP59lm+/XXX+P777+/4H1ly5ZF/fr1ERUVdTnieqTQ0FAkJCTghx9+6AFgXF7Hk/QDkAFgFACBXWhYAGIBBJKcJyJ5nsfLpcD+D7AzgKUAfnLfXgPAVQC2k2wnIvsLef4+AB67wO2/kEwXkTWFPO/FBMD+/p65okzyHgBXiciFJlzHAogo4gzKi5HsVb16dSsqKsrjOtCUUs5r0qQJ/P39rczMzF7wsOLT437pkewRExNjlS9f3ukoqoQ6fPiwR64Qd+TIEUycOBFLly5Fp06d8I9//CNf8ztJ4sSJE5g/fz6+++47hIaGIjQ0FCSxdOlSDB48GB999FExvALP0axZM1qWFUeyZj4OfwbAWABzAVQUkboikgSgPIDhAHx+tRARmQ7gG/dfJ4nIne6PqwFMAZAI4KYieKqGIkIApWEXpMEAXiNZ1JPmvgNQFsCKHLeVg11Mn0VELPexjxdxBuWlSJYVkUZNmzb1uPdgSqmSISgoCElJSTTGdHY6S0F51Mine0nhpObNm+scCXVRhw4dwu7duxEdHe10lHzbvn077r77bhw4cAAjRowo0DYqDRs2xO+//w4A6NKlC1q1anXmvubNm+P666/HG2+8gdatWxd5bk/VtGlTPPvsswDQFcA/LnYcyQ4ArgOwUETG57xPRP4G8CzJ1895jD+AXgCSYLeHfiQi6845ph6ABBF5lWQTAJ0AHAXwgYh8k+O43gAOiMj6C2RrDSBERP6d47bSAHoDqAXgTwDvicjmHPe3gV00LxeR0zlujwbQFMAGESnsruaNAOy7QBvyz+7PQYU873lE5DiAN0nOAnA/7JHXNQBAshrsr0Fl93O/ISL7cj7e3SrbHUBdAIEAfgOwVkSyWwhKwx7JXQdgL8nmAOIB+JPMubH3a7BHwzsC+BbAdyRj3XlWicgf5zxvWQAdAHwhIv/NcXsDAO1hj55uB/CaiPxV2K+PKvHaAqBOp1C5adCggXYtqVwlJydzw4YN1UjGishOp/Pkl6dddesKgNpyq3ITFxeHDh06OB0j31avXo1bb70Vf//9NzIyMgq1f+f27dsBAPHx8WfdXqqUvaCriFx6UC9Sq1YthIeHW7B/p+TmevfnaRc7QEQOZ/+ZZCSADQBeht1uOhLAJySXkHTleNhAAMtI3g27aBoA4CEAG0nm3IN0MID/c7f+nkEyGPao3JU5bmsKu3BZALuwusV9vvtyPNQF4CUAD+R4XBCAN92v8UCO2/9FMtf5jjmOJezi8+sL3J09MvxZfs5VQNmFbgV3jkGwvwYPw56fmwFgR86vqfv1rgXwOuzvUUcAd5+TLxr29zB7cYFrAbQAUArAozk+XLCXu38ZQD/3sX6wv8Y3XiDvUPd9dGcxJJ+G/XUb4878FIBvScYV9IuhPEYHY4wkJSU5nUOVYG3btkXNmvlpzlG+KscFrPZO5igoTys+WwcEBFh169Z1OocqwbZt24ZVq1Y5HSNP2ft3Pvjgg6hWrRoWLFhQ6IWFtm3bhrCwMFSufPZ+w1999RUAQLclOpsxBsnJycYY09o9CnYxjQHsFZFd+Tz1AgA1AXQQkQYiUgN2YXMt7GIwJxfsOZLVRaQB7JbOHbALp2zPwR7B63LOY68AEOa+H+620+UAfgQQKyJN3DnuBXC/e8QT7rmRDwG4k2R2q84sAAkABorI0RzPUQdnL/KTm1gAZWAX3meQbAG74HoLBVjcqQC6uT9/7x5xfBZ2ERnt/hrEwC5G/0WygvvYXgDSALQQkaYi0lpEogFctDVARG6F/bU+KiI1c3xkXuDYbbBHTK8/9z73bR/m+Pd0G+zW7SEiEiMiTWF/L04DWJz/L4PyJMaYjnXq1EFIiMctUqkPp1zWAAAgAElEQVSK0cqVK7F161anY6gSLCEhAaVKlbKgxeflY4xpXadOHfr7+zsdRZVg+/btw3fffed0jFwdOXIEt99+O5YuXYqOHTti3rx55xWOBbF9+/bzRj2/++47LFiwAPXq1UP//v0v8kjflZSUBMuywmC3Xl5MOeQYDcyNe1pADwCLReQ/Oe6aBmArgGEXeNg4ETkEnBlB/SeAeiSz99RZCeAXnF/I3ABgG4DsdtxBACrBXp11v/t8AuAR2KODV+V47IMAPgTwT5LjAIwAcLuIfHXOc9wMe4Q2P7IX4bmS5Cr3x0bYhfStAK5wz428VH1JDid5B8lVsF/XagBbYI8SBwIYnV1Ei8hBABNhF+rZr6Ws+/PhnCcWkY1FkC/bcwAakGyYfQPJxrDnvj6f47hxAN4Skedy5PgZ9r+ZliR1U18vQzLKsqxaqampOn1I5SopKQmRkZFOx1AlmMvlQqNGjYwxppO7A8kjeMycT5Llgf9v787jo6rPPY5/nsmeQFik7LJJapGCS9W2gtati13FXltBUZQqLtelVdzQWiu4cW1rKxRxQypKtS6t19pqQXsFbEXRulShLiyiIrKFLWR77h+/M2EIM0nATGYSvu/Xi9ck5/zO7zyZhDPnOb+NAUOGDGk1b65IMm+//TYTJkzYrfGdyaxatYoNGzbw5ptvMnLkSAA2bdpE586dueiiizjiiCOIxVrVc6YWkdDlbRgheUmmgpDQNMXnCd0pdxjf6e61ZvY8cKqZ5SQsOeJsn6Qn7kPCQ8GuwAp3rzGz+4ALo0lK1ppZb8K4wat9e3/qg4Ea4OSo62ku0D7al0MYAxqPp8bMTiF09fwlofvpbfV/GHfflW6y8Sb7swjJcjfgVsK41+c+zTIr9VxI+Dk3Ae8RWnZvcXc3syHApsQxrpEFhPc6/gt/AlgLvB51K34C+LO7r6D5PEj4+U8D4kntaVHcf4C6hxW9gWVmdmNUph2QB8TvOMuAHcarSqt3NMCBByabNFlkO433lKY48MADWbBgQRfCw803Mh1PU7SmO9JhgGmMhLRmc+bM4bzzzmPLli1Mnjz5UyeeELrcAlxyySU88MADzJgxgxEjRrB06VLWrFmTMvGsrq5Oun1PMXDgQAoLC2sJ15ZU3gEGJLRENiRepjzJvnLC9TZxAdraJGtUxpPJxF/ajKjueMvd6KjczIQyxYSumh0Jk9a0T9j3J+CZeuepjP4BvJGQxO6uAwktifPd/d1ogqSLCa2Ml9QvbGZjzOw3ZnaDmT1iZk29Ez/C3Tu7ex93/4q7X5cwMU8Byd/7bdG/QqhrWRxKWLqlO2HCqWVmNqW5nhxHLa+PAqPMLC/6+xkJPBRNlgTbl3HJIfzOOhESTwgPIaYDG5ojHskqX8rJyfH99tsv03FIlvvNb37DvHnzMh2GZLmhQ+tGx3w5k3HsilbT8gkMMzN0wZbWqLa2ljvuuIP777+fgQMHMmnSpE/VzTZRfLKhz342NG4VFBQwevRoHnvsMWbPns0JJ5xA4j313LlzmT9/Pn369OHf//43BxxwQF2L6Z4kFosxePDg2Msvv9zQNMBPEmamPJ4wUUxDPope+ybZ1x9YF82Qu0vc/U0z+yeh5ey30eucKImKW0lIbK9w97UN1RclWPcQEtS7gCvMbK67109Qd8WBhJlyE5PYeYRW0O+a2TnxfdFswGOAr7p7lZmNIUwM9GlnCfsQ6GZmRfXe5x6ExPOD+IZoRt6fAj81s07Azwndg/9E6Oqcyq4kpzMIY32PI/xuOrNjl9tVhAcGL7t7/fHA0kaZ2RcHDBjgBQUF6sUlDaqtrdVkgdKoffbZh9zcXK+urj4EuDPT8TRFq2n5NLPhffr0qS0tLc10KCK7pLy8vG79zmOOOYYpU6Y0W+IJoeWzpKSEXr161W3Ly8vjsMMO4+OPP+add3ZcOeOZZ57hkksu4bTTTmP8+PFMnz59j20FjcZ99om6siYznZDU/CLZmqBmVmhm8SVYXiUkFKcnzmwbLWPydeCpTxHqvcAXzex0YF+iiYYS/JGQGP2EJOpNqnQRYdKdsYTZeJ8nTMjTtd4xX4yWc2lQtLRJN+pNNhQlm08Skr/Els1aYETCZD0FwGY+vacJrYhj6m3/UfT6VBTvDp970VjbqdG3Df3H/ARoZ2b5DZRJNBdYTnhYcBrwLlC34K67byKMVz3JzHbqX9fIRFjSCkUt4EP3228//W5FpFnk5eVRVlZGtCRYq9AqWj7NLN/MvjBkyBBdsKVVefvtt7nqqqtYtWpVs4zvTGbJkiWUlZXt1L32S1/6Ek8++STPP/88AwduX7Xhuuuuq/t6zZo1dOnShZycHPZECd34v8j29SjruPt6M/s+YVmTV8xsBvACodvrYELL1hbgF1Er3pWE1sTHzexOwkQ3VxO6uP7sU4Q6G/gFYWzmBuCxenE+F53vyijZfZyQ0PUBvhd9PzVaU/RG4DZ3fwTAzEYSxiXONLNvJkwM9FtC4phyxgsz60iYORbCkiadEpeeIcxyO5YwEdF7wIZo/Oe66PgCQmJ23m68J/U9BswHfhXNEbAIOJzQ7fcJwiRLEGb/HQT8GVhK6Kp8EeF9ndtA/fMIye2DZvYPwt/A/7C9q/QOorG+M4FLCQ96r0vSvfnHhDGpL5jZ/wBvAR2A/Qmt7erq07Yc4O75n/vc5zIdh4i0IYMGDbK33nprsJmVJAztyFqtJZkb5O75++67b6bjkFZgwIABHH744ZkOo2585+bNm3d7/c6GrFy5kkWLFrFmzRo6duzI4sWLqaioqNt/yCGHkJeXx3PPPcfixYvZtGnTDsfX1tZy3333cfHFF+/QLXdPEu+qDByQqkw0fnF/wjIexxG6rN5LmGn1D4R1IuNl7yaM7esFPARMI4wbPdzd30qo9gPqtRRGPgFeYvt4zHi96wjJ4JvAr1N03z2LkMQNBe4nJGOXE7oD/z1aK3Q8oQWwbhxm1H33NKALIVGNe5PQmptUlDg+FdX5UnT+WfWK/Q1YSHjf/kJI3uLH5xHey6vcPdn6oIk+is6xJVUBd68mrG96J3A+IfE9lTCp0okJid8CwkOBmwjJ5l2ERP3YhEmHtkbnW5dQ/7OE8bYQEsMT2f4Z+hIJ3XoT3EuYzOpf7DhGN17nW4TJop4FJhBaiqcBRxH+3qRtORRg0KBBmY5DRNqQQYMG4e4xtk/+l9WsNfQnN7PRwMypU6eiNT4l29Uf3zlx4sS0TJc+ffp0Vq5cucO2H//4x3Ts2LHu+zvuuIP33w8NemPHjqVPnz4AuDu//OUvOfjggzniiEZ7VrZpI0aMqFm7du0T7v69xktLczCzUkJSOH0XZ9UVabXMbGZhYeHJTz75ZEwzkEtjbr31Vg466KCseJgu2W3FihWccsopAJe4+y2ZjqcxraLbLTDEzOjXr1+m45BW4NVXX2Xx4sUZWduyvLycn/3sZ7z00kscc8wxXHrppRQWFqblXGeddVajZc48c+elJbdt28aUKVM48sgjOeigVvGQLK3KyspyFi5cqHUPWoiZDSBM8HOFu68ws3OAexNmrRVpk8zswIEDByrxFJFm1bt3b4qKimq3bt2ashdXNmktyefQbt261ZSUlOyZA9Nkl+y7774MGDCgxc/bEuM7P61PPvmEadOmMWbMGHr37s3zzz9PcXEx+++/f6ZDy5h99tmHf/7zn73NrDRaIkPSxMwGEiY4ehu4O+ru3cHdf5vRwETSzMxyzOyz/fv3z3Qo0kqceeaZ5OXlNV5Q9nhmRt++fW3x4sWtYp6AVpF8xmKxA8vKypR4SpO1dHfyOXPmcPPNN5Ofn8/kyZM5+OCDW/T8TVFVVcW4ceOoqanhjTfCOsSbNm1ixowZmQ0sw6IHFQYMIUxYI+nzIWFyp0QVyQqKtDH7uHu+enBJU1VVVRGLxZSASpP079/fFi9evJ+ZxRImDsxKWZ98RrMWds1ES5a0Ti+88AKLFi3iwgsvTPu54uM7H3jgAfbZZ5+0je9sDnl5eTz88MOZDiPrJFxbhqLkM62iWfjezXQcIhkwGNDwIWmyOXPmUFZWljgru0hKffv2xd0Lgb2BZZmOpyFZn3wCnwcy0o1SpCHl5eVce+21vPjii2kf3ynp06dPH3JycrympubzmY5FRNqs/UDJpzTdCSeckOkQpBXp27dv/Mv9yPLkszWMeh8IYTCtSLZ45513GDduHIsWLWLcuHFcffXVSjxbqby8PLp27VoL6AmXiKTLoKKiotq99tor03FIK7Fw4UJWrFjReEERdniwlfXjPltD8tkXoHv37pmOQwSAuXPncu6557Jp0yYmT57MqFGj9th1MtuKXr165cRisX0yHYeItE1mNqh///6mzwppqgULFrB06dJMhyGtRPfu3cnPz68FPpfpWBrTGrrd9i8pKalt165da0iUpQ1LHN85YMAAJk6cSM+ePTMdljSD7t274+59zMy8NSx+LCKtipn179mzpzJPEUmLWCxGt27dWLFiRd/GS2dWa0g+++mCLZlWXl7Oz3/+cxYuXMjRRx/NZZddpm62bUiPHj1w9wKgO2FGVhGRZmFmxUCnbt26ZToUEWnDunfvHlu5cmW/TMfRmKxPPmOx2MAePXoo+ZQmy8nJadapyd955x2uuuoqPvroI8aNG8fIkSPVzbaNSZihuD9KPkWkefUB6Nq1a6bjEJE2rFu3brj73pmOozFZnXyaWQHwmWxdukKy02GHHcZhhx3WLHU988wz3HjjjeTn53PzzTdzyCGHNEu9kl3qJZ8LMhiKiLQ9e4OSTxFJr65du+LuhWbWxd0/yXQ8qWR18kl4WhhTVxXZFevXr2fjxo3svffuP/xxd2bMmMG9996r8Z17gITks18GwxCRtkktnyKSdgnXmD6Aks/d1AOgS5cumY5DWpHVq1ezbNmy3U4+N2/ezKRJk5g/fz5HHXUUl19+ucZ3tnEdO3YkFot5bW2tnnSJSHPbG0KXOJGmGjp0KOr5J7si4RrTB1iUwVAalO3J514AHTp0yHQc0oqUlZVRVla2W8cuX76cCRMmsGLFCkaNGsVZZ52l8Z17ADOjXbt2teXl5XrSJSLNrVtubq63b99eHybSZEcddVSmQ5BWJqGxLqvXp8z25Uu6gJJP2TX/+c9/mDNnzi4ft2DBAs4++2zWrFnDpEmTGDdunBLPPUiHDh2M6IGXiEgz2qt9+/a1mQ5CWpennnqKJUuWZDoMaUXat28f/7JzJuNoTLYnn3sBlJaWZjoOaUU++ugjXn/99SaXd3fuv/9+JkyYwF577cW0adMYNmxYGiOUbNSxY8eYmX0m03GISJvTOXq4JdJkgwcPVldt2SXt27ePN5p0ynQsDWkV3W6VfEq6bN68meuvv5558+Zx2GGHcdVVV1FSUpLpsCQDOnTogJJPEWluZrZXhw4dsv1hv2SZXr16ZToEaWVyc3MpKCioraioUMvnp9ClqKiotjnXbBSJW758OWeffTbz589n1KhRTJo0SYnnHqxDhw64u7rdikizMrMuCd3hRJrktttuY/78+ZkOQ1qZ9u3bO1ne7TbrWz5LS0s900FI27NgwQImTpwIwMSJExk+fHiGI5JMKy0txd2LzKzI3bdmOh4RaTM6KfmUXVVTU0NtrYYKy64pLS2NrV69Wsnnp9CupKRE4ySk2bg7DzzwAHfccQe9e/dm0qRJ9OnTJ9NhSRZIaPVuByj5FJFPzcxygGIlnyLSEkpLS83MsroXV7YnnwX5+fnZ3jVYWonNmzdzww038Nxzz2l8p+wkN7fucpifyThEpE0pBKygoCDTcYjIHqCgoAAzy+rF6bM6+TSzAo33lF3Vv39/iouLd9i2YsUKJkyYwPLlyxk1ahRnnnkmsZiea8h2+fl1OafuEkWkueTBDg+3RETSJsqbsvoherZfDQuVfMqu6t27N7179677Pj6+09257rrrOPzwwzMYnWQrtXyKSBoo+RSRFhPlTVmdPGV104+Z5euCLbvqtdde4w9/+MMO63d27tyZadOmKfGUlNTyKSJpEO4E9SBdRFpAlDdl9UP0bM/sChJuCEWapKysjK5du3L11VdrfKc0WcLNoS46ItJc1PIpu+VHP/qRHlrILmsNLZ+7fTU0szygU4rd1e6+NhrwmuPum82sA6lbFMrdvcLMOkfH5QKdY7FYYW1tLevWrasrmJOTQ2lpKVVVVVRXV1NUVMTmzZuprKxMWnFxcTEFBQVs3LiRdu3a4e5s2LAhadlYLEaHDh2oqqqiqqqK4uJitmzZwrZt25KWLyoqorCwkE2bNtWNMUxVt5nRsWNHqqur2bZtGyUlJWzdupWKiooG6968eTNFRUWYGevXr0/x9kGnTp2oqamhoqKCkpISKioq2Lo1+YSdhYWFde9bYWEhOTk5O7zH9XXs2BF3Z+vWrbtUd0FBAbm5uaxfvx735CvmdOjQAYAtW7bQrl27BusuKCio+53k5eWRl5fHhg0bdpqKfPXq1fz0pz9l1apVnHHGGYwYMYKSkhK2bdvGli1bktadn59f9zvJzc0lLy+P8vJyampqkpYvLS0lJyeH8vJySktLqaysZPPmzQ3WXVFRQSwWIz8/v8G627dvT25ubl3dVVVVbNq0KWnZvLy8uvfNzOr+1qurq5OWb9euXd3P1ljdubm5tG/fvu7vf1frrq6uZuPGjUnLxv8fV1ZWUltbW/f/qKqqqkl119TUUF5e3mDdVVVV1NTU1P0/SnWNKCkpIT8/P/HcRWbWNWlhqHX3T8wsH8h3901mVkqYVCSZje6+1cw6AfGLQ6G7J/9DFJEWZWbFhBmuk9nq7hvNrD1Q4e5VZvYZINUs/J9Erx3cfZ2ZFQHdAV555ZUdrp25ubl1151YLEZOTg5bt25N+VkZvw+oqKigsLCQ6urqlNe0nJwcCgoKmlx3YWEhsVisru6ampqU9z2JdZsZubm5VFRUpFwSJF731q1bKSoqata6CwoK6n62xuqOxWJ175u7k5eXx7Zt21J+Dtevu7a2NuX92q7WnZ+fX/ezFRYWpqx727ZtdZ/D8WVX8vLyqKysTPk5XL/u+L1bMmZW977tat3xCbRS1Q3h/ru2tpbq6mry8/MbrDt+T7dt2zby8/Mxs5T3a8nqjt+3N1Z3Xl4esVis0brdncrKyrq/x8bqrqysJDc3t9G6i4qKAJpUd/waUVlZSU5OTpOvEcuWLcPd86LrT6pptivcvdzM2gGV7l5pZl1I3SN2DVALdErI72rcPXnwjbBUP0SjB5rtD9yVYvcKdx9hZt8E+rr7b83sVmBYivLXuvvjZvYH4GSgL3C/mXUqLi4uyM3NrbuaFBQUbHzwwQcn3XXXXZ9/++23+95www1PnHfeeSe///77Q5JVPHz48D+OHz/++VNPPfX866677q4PP/yw+IYbbrgkWdnc3NyKhx9++GezZs3ad9GiRfvdcsstj1500UUnvvfee19IVv7QQw99csKECX8/44wzzr7oootm5+fn11522WVXpni/ah577LEJjzzySP9nn3320F//+te/Hz9+/PeWLFny5WTlDzjggL9de+21fzvrrLPOOO200/63X79+G88999xrUrx/zJ49e8K8efO6P/roo0dPnTr1d1deeeVxb7zxxleSlR08ePD/XX/99X8+99xzR48YMWLu8OHDPzrppJMmpap76tSp1y5fvrzdPffc853p06fffc011xz7yiuv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"}},{"insert":"\nInputs:"},{"attributes":{"header":2},"insert":"\n"},{"insert":"The radii and material properties for each of spheres are entered below. For positive values of R2, the contact is convex as shown in the figure above. For concave contact (for the case where Sphere 1 is inside of a spherical cup), use negative values for R2. For the contact stress between a sphere and a flat surface, use a very large value for R2 or enter 1/0 to represent infinity (yes, it will actually work, give it a try!).\n"}]}},{"type":"math","id":4,"latex":"\\text{Sphere Radii:}\\:\\:R_1=10\\left\\lbrack mm\\right\\rbrack,\\:R_2=100\\left\\lbrack mm\\right\\rbrack","config":null},{"type":"math","id":5,"latex":"\\text{Sphere Material Properties:}\\:\\:E_1=206.8\\left\\lbrack GPa\\right\\rbrack,\\:\\nu_1=.28,\\:E_2=206.8\\left\\lbrack GPa\\right\\rbrack,\\:\\nu_2=.28","config":null},{"type":"math","id":9,"latex":"\\text{Applied Force:}\\:\\:F=0.5\\left\\lbrack N\\right\\rbrack","config":null},{"type":"math","id":0,"latex":"\\text{Max Contact Pressure:}\\:\\:p_{max}=\\frac32\\cdot\\frac{F}{\\pi\\cdot a^2}=\\left\\lbrack MPa\\right\\rbrack","config":null},{"type":"math","id":6,"latex":"\\text{Material constants for the two spheres:}\\:\\:m_1=\\frac{1-\\nu_1^2}{E_1},\\:\\:m_2=\\frac{1-\\nu_2^2}{E_2}","config":null},{"type":"math","id":7,"latex":"\\text{Geometry Constant:}\\:\\:B=\\frac12\\cdot\\left(\\frac{1}{R_1}+\\frac{1}{R_2}\\right)","config":null},{"type":"math","id":8,"latex":"\\text{Contact-patch radius:}\\:\\:a=\\left(0.375\\cdot\\frac{m_1+m_2}{B}\\cdot F\\right)^{\\frac13}=\\left\\lbrack um\\right\\rbrack","config":null},{"type":"math","id":10,"latex":"\\text{Pressure distribution as a function of x-y position:}\\:\\:p=p_{max}\\cdot\\sqrt{1-\\frac{x^2}{a^2}-\\frac{y^2}{a^2}}","config":null},{"type":"math","id":62,"latex":"p\\left(x=a,\\:y=0\\left\\lbrack mm\\right\\rbrack\\right)=","config":null},{"type":"documentation","id":18,"json":{"ops":[{"insert":"Pressure Distribution Across the Width of the Contact Area"},{"attributes":{"header":2},"insert":"\n"}]}},{"type":"plot","id":13,"latexs":["p\\left(-a {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test subscript and exponent latex variations', async () => { // Latex support a wide variety of syntaxes for subscripts and superscripts. // The main challenges are cases that don't require braces and that reverse the // superscript and subscript order. // all permutations of single char subscripts and superscripts await page.setLatex(0, 'x_a^3='); await page.locator('#add-math-cell').click() await page.setLatex(1, 'x_1^3='); await page.locator('#add-math-cell').click() await page.setLatex(2, 'x_1^b='); await page.locator('#add-math-cell').click() await page.setLatex(3, 'x_a^b='); // same cases with subscripts and superscripts reversed await page.locator('#add-math-cell').click() await page.setLatex(4, 'x^3_a='); await page.locator('#add-math-cell').click() await page.setLatex(5, 'x^3_1='); await page.locator('#add-math-cell').click() await page.setLatex(6, 'x^b_1='); await page.locator('#add-math-cell').click() await page.setLatex(7, 'x^b_a='); // reversed subsdcripts and superscripts with brackets for superscript await page.locator('#add-math-cell').click() await page.setLatex(8, 'x^{3}_a='); await page.locator('#add-math-cell').click() await page.setLatex(9, 'x^{3}_1='); await page.locator('#add-math-cell').click() await page.setLatex(10, 'x^{b}_1='); await page.locator('#add-math-cell').click() await page.setLatex(11, 'x^{b}_a='); // reversed subsdcripts and superscripts with brackets for subscript await page.locator('#add-math-cell').click() await page.setLatex(12, 'x^3_{a}='); await page.locator('#add-math-cell').click() await page.setLatex(13, 'x^3_{1}='); await page.locator('#add-math-cell').click() await page.setLatex(14, 'x^b_{1}='); await page.locator('#add-math-cell').click() await page.setLatex(15, 'x^b_{a}='); // reversed subsdcripts and superscripts with brackets for both sub and superscripts await page.locator('#add-math-cell').click() await page.setLatex(16, 'x^{3}_{a}='); await page.locator('#add-math-cell').click() await page.setLatex(17, 'x^{3}_{1}='); await page.locator('#add-math-cell').click() await page.setLatex(18, 'x^{b}_{1}='); await page.locator('#add-math-cell').click() await page.setLatex(19, 'x^{b}_{a}='); // define parameter values last to ensure topological sorting is working await page.locator('#add-math-cell').click() await page.setLatex(20, 'x_a=2'); await page.locator('#add-math-cell').click() await page.setLatex(21, 'x_1=2'); await page.locator('#add-math-cell').click() await page.setLatex(22, 'b=3'); await page.waitForSelector('.status-footer', { state: 'detached'}); // cells 0-19 should all evaluate to 8 let content; for (let cell=0; cell < 20; cell++) { content = await page.textContent(`#result-value-${cell}`); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); } }); test('Test nth derivative single char exponent combos', async () => { // test detection of msimatched exponents when one is a single char await page.setLatex(0, String.raw`\frac{\mathrm{d}^{20}}{\mathrm{d}\left(x\right)^2}\left(x^2\right)=`); await page.locator('#cell-0 >> text=Invalid differential order combination 20 and 2').waitFor({state: 'attached', timeout: 1000}); await page.setLatex(0, String.raw`\frac{\mathrm{d}^20}{\mathrm{d}\left(x\right)^2}\left(x^2\right)=`); await page.locator('#cell-0 >> text=Invalid Syntax').waitFor({state: 'attached', timeout: 1000}); await page.setLatex(0, String.raw`\frac{\mathrm{d}^2}{\mathrm{d}\left(x\right)^{20}}\left(x^2\right)=`); await page.locator('#cell-0 >> text=Invalid differential order combination 2 and 20').waitFor({state: 'attached', timeout: 1000}); await page.setLatex(0, String.raw`\frac{\mathrm{d}^2}{\mathrm{d}\left(x\right)^20}\left(x^2\right)=`); await page.locator('#cell-0 >> text=Invalid Syntax').waitFor({state: 'attached', timeout: 1000}); // test valid two digit and one digit variations await page.setLatex(0, String.raw`\frac{\mathrm{d}^2}{\mathrm{d}\left(x\right)^2}\left(x^2\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\frac{\mathrm{d}^{10}}{\mathrm{d}\left(x\right)^{10}}\left(x^{10}\right)=`); await page.waitForSelector('.status-footer', { state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(3628800, precision); }); test('Test nth derivative single char exponent one without braces', async () => { await page.setLatex(0, String.raw`\frac{\mathrm{d}^{2}}{\mathrm{d}\left(x\right)^2}\left(x^2\right)=`); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); await page.setLatex(0, String.raw`\frac{\mathrm{d}^{3}}{\mathrm{d}\left(x\right)^2}\left(x^2\right)=`); await expect(page.locator('text=Invalid differential order combination 3 and 2')).toBeVisible(); }); test('Test definite integrals with single char limits', async () => { // Test that double integers for upper limit without braces triggers syntax error await page.setLatex(0, String.raw`\int_0^11\left(x\right)\mathrm{d}\left(x\right)=`); await page.locator('#cell-0 >> text=Invalid Syntax').waitFor({state: 'attached', timeout: 1000}); // test single and double char upper bounds for both numbers and ids await page.setLatex(0, String.raw`\int_0^1\left(x\right)\mathrm{d}\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\int_a^b\left(x\right)\mathrm{d}\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\int_{0.0}^{1.0}\left(x\right)\mathrm{d}\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`\int_{aa}^{bb}\left(x\right)\mathrm{d}\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(4, String.raw`\int_{}^{}\left(1\right)\mathrm{d}\left(x\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(5, 'a=0'); await page.locator('#add-math-cell').click(); await page.setLatex(6, 'b=1'); await page.locator('#add-math-cell').click(); await page.setLatex(7, 'aa=0'); await page.locator('#add-math-cell').click(); await page.setLatex(8, 'bb=1'); await page.waitForSelector('.status-footer', { state: 'detached'}); // cells 0-3 should all evaluate to .5 let content; for (let cell=0; cell < 4; cell++) { content = await page.textContent(`#result-value-${cell}`); expect(parseLatexFloat(content)).toBeCloseTo(0.5, precision); } // cell 4 should be 'x' content = await page.textContent('#result-value-4'); expect(content).toBe('x'); }); test('Test logarithms with single char bases', async () => { // Test that double integers for base without braces triggers syntax error await page.setLatex(0, String.raw`\log_22(8)=`); await page.locator('#cell-0 >> text=Invalid Syntax').waitFor({state: 'attached', timeout: 1000}); // test single and double char base for both numbers and ids await page.setLatex(0, String.raw`\log_2(8)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\log_{20}(8000)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\log_a(8)=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`$$ \log_{aa}(8)= $$`); await page.locator('#add-math-cell').click(); await page.setLatex(4, 'a=2'); await page.locator('#add-math-cell').click(); await page.setLatex(5, 'aa=2'); await page.waitForSelector('.status-footer', { state: 'detached'}); // cells 0-3 should all evaluate to 3 let content; for (let cell=0; cell < 4; cell++) { content = await page.textContent(`#result-value-${cell}`); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); } }); ================================================ FILE: tests/test_sum_and_prod.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos, e} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => newSheet(page)); test('Test finite sum with no units', async () => { await page.setLatex(0, String.raw`\sum_{n=0}^4\left(n\cdot2\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(20, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test finite sum with units', async () => { await page.setLatex(0, String.raw`\sum_{n=1}^3\left(n\cdot2\left\lbrack m\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(12, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Test infinte sum with factorial', async () => { await page.setLatex(0, String.raw`\sum_{n=0}^{\infty}\left(\frac{2}{n!}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(2*e, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test sum over vector without units', async () => { await page.setLatex(0, String.raw`\sum_{n=1}^{\mathrm{count}\left(B\right)}\left(B_{n,1}\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`B=\begin{bmatrix}1\\ 2\\ 3\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test sum over vector with units', async () => { await page.setLatex(0, String.raw`\sum_{n=1}^{\mathrm{count}\left(B\right)}\left(B_{n,1}\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`B=\begin{bmatrix}1\\ 2\\ 3\end{bmatrix}\cdot1\left\lbrack m\right\rbrack=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(6, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m'); }); test('Test sum over vector with inconsistent units', async () => { await page.setLatex(0, String.raw`\sum_{n=1}^3\left(A_{n,1}\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}1\left\lbrack m\right\rbrack\\ 2\left\lbrack s\right\rbrack\\ 3\left\lbrack kg\right\rbrack\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeVisible(); }); test('Test finite sum with limit units', async () => { await page.setLatex(0, String.raw`\sum_{n=1\left\lbrack m\right\rbrack}^{3\left\lbrack m\right\rbrack}\left(n^2\cdot1\left\lbrack m\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeVisible(); }); test('Test product with lower limit units', async () => { await page.setLatex(0, String.raw`\prod_{x=1\left\lbrack m\right\rbrack}^6\left(x\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeVisible(); }); test('Test sum over vector with limit units', async () => { await page.setLatex(0, String.raw`\sum_{n=1\left\lbrack m\right\rbrack}^{3\left\lbrack m\right\rbrack}\left(A_{n,1}\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}1\\ 2\\ 3\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeVisible(); }); test('Test finite sum with dummy variable in exponent', async () => { await page.setLatex(0, String.raw`\sum_{n=1\left\lbrack m\right\rbrack}^{3\left\lbrack m\right\rbrack}\left(2^{n}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-0 >> text=Dimension Error')).toBeVisible(); }); test('Test nested sum', async () => { await page.setLatex(0, String.raw`\sum_{i=1}^{\mathrm{count}\left(A\right)}\left(\sum_{j=1}^{\mathrm{count}\left(B\right)}\left(A_{i,1}\cdot B_{1,j}\right)\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`A=\begin{bmatrix}a\\ b\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`B=\begin{bmatrix}c & d\end{bmatrix}`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`a \cdot c + a \cdot d + b \cdot c + b \cdot d`); }); test('Test product using virtual keyboard', async () => { await page.locator('button').filter({ hasText: 'a^∫Σ' }).click(); await page.locator('button').filter({ hasText: '∏' }).click(); await page.locator('#cell-0 math-field.editable').type('5'); await page.locator('#cell-0 math-field.editable').press('Tab'); await page.locator('#cell-0 math-field.editable').type('i'); await page.locator('#cell-0 math-field.editable').press('Tab'); await page.locator('#cell-0 math-field.editable').type('1'); await page.locator('#cell-0 math-field.editable').press('Tab'); await page.locator('#cell-0 math-field.editable').type('i'); await page.locator('#cell-0 math-field.editable').press('Tab'); await page.locator('#cell-0 math-field.editable').type('='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(120, precision); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); test('Test product with units', async () => { await page.setLatex(0, String.raw`\prod_{x=1}^5\left(x\cdot1\left\lbrack m\right\rbrack\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(120, precision); content = await page.textContent('#result-units-0'); expect(content).toBe('m^5'); }); test('Test product with vector substitution and units', async () => { await page.setLatex(0, String.raw`x=\begin{bmatrix}1\\ 2\\ 3\end{bmatrix}\cdot1\left\lbrack m\right\rbrack,\:y=\begin{bmatrix}4\\ 5\\ 6\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\prod_{i=1}^{count\left(x\right)}\left(x_{i,1}\cdot y_{i,1}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(720, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m^3'); }); test('Test infinite symbolic product', async () => { await page.setLatex(0, String.raw`\prod_{n=1}^{\infty}\left(\frac{1}{x\cdot n}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\prod_{n=1}^{\infty} \frac{1}{n \cdot x}`); }); test('Test infinite symbolic product with reserved variable name', async () => { await page.setLatex(0, String.raw`\prod_{oo=1}^{\infty}\left(\frac{1}{x\cdot oo}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe(String.raw`\prod_{oo=1}^{\infty} \frac{1}{oo \cdot x}`); }); test('Test sum with lower limit that is a number but not an integer', async () => { await page.setLatex(0, String.raw`\sum_{n=1.1}^5\left(n\right)=`); await expect(page.locator('text=Summation upper and lower limits must evalute to an integer or infinity')).toBeVisible(); }); test('Test sum with upper limit that is a number but not an integer', async () => { await page.setLatex(0, String.raw`\sum_{n=1}^{5.1}\left(n\right)=`); await expect(page.locator('text=Summation upper and lower limits must evalute to an integer or infinity')).toBeVisible(); }); test('Test product with lower limit that is a number but not an integer', async () => { await page.setLatex(0, String.raw`\prod_{n=1.1}^5\left(n\right)=`); await expect(page.locator('text=Product upper and lower limits must evalute to an integer or infinity')).toBeVisible(); }); test('Test product with upper limit that is a number but not an integer', async () => { await page.setLatex(0, String.raw`\prod_{n=1}^{5.1}\left(n\right)=`); await expect(page.locator('text=Product upper and lower limits must evalute to an integer or infinity')).toBeVisible(); }); test('Test product with vector substitution and multiple units', async () => { await page.setLatex(0, String.raw`A=\begin{bmatrix}1\left\lbrack m\right\rbrack\\ 5\left\lbrack s\right\rbrack\\ 3\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\prod_{n=1}^3\left(A_{n,1}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(15, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m^1*s^1'); }); test('Test nested product with units', async () => { await page.setLatex(0, String.raw`A=\begin{bmatrix}1\left\lbrack m\right\rbrack & 2\left\lbrack s\right\rbrack\\ 3 & 4\\ 5 & 6\end{bmatrix}`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\prod_{i=1}^{\mathrm{numrows}\left(A\right)}\left(\prod_{j=1}^{\mathrm{numcols}\left(A\right)}\left(A_{i,j}\right)\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(720, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m^1*s^1'); }); test('Test summation and product with subtraction in limit calculation', async () => { await page.setLatex(0, String.raw`C=\begin{bmatrix}1 & 2 & 3\\ 4 & 5 & 6\end{bmatrix}\cdot1\left\lbrack m\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`\sum_{j=1}^{\mathrm{numcols}\left(C\right)-1}\left(C_{2,j}\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`\prod_{j=1}^{\mathrm{numcols}\left(C\right)-1}\left(C_{2,j}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(9, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(20, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m^2'); }); test('Test summation and no evaluation with i as iteration variable', async () => { await page.setLatex(0, String.raw`\sum_{i=1}^{\infty}\left(\frac{1}{i}\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('\\infty'); content = await page.textContent('#result-units-0'); expect(content).toBe(''); }); ================================================ FILE: tests/test_symbolic_expression_error_handling.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { precision, pyodideLoadTimeout, compareImages, parseLatexFloat } from './utility.mjs'; test('Test handling of symbolic expression error', async ({ page, browserName }) => { await page.goto('/AqVAmzYYfKrQkGZ8BvUC7T'); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached'}); await page.locator("text=Accept").click(); await page.locator('text=Updating...').waitFor({state: 'detached', timeout: pyodideLoadTimeout}); let content = await page.locator('#result-value-21').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(57168.5056551697, precision); }); ================================================ FILE: tests/test_syntax_error_messages.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Error message for empty subscript', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // syntax error with second entry await page.locator('#cell-0 >> math-field.editable').type('x_'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('='); await page.locator('text=There is an empty subscript that is causing a syntax error').waitFor({state: "attached", timeout: 1000}); // make sure placeholder gets add when cell loses focus await page.keyboard.press('Escape'); await page.keyboard.press(modifierKey+"+ArrowUp"); await page.locator('#cell-0 >> math-field.editable').type('1'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`x_1`); }); test('Error message for empty superscript', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // syntax error with second entry await page.locator('#cell-0 >> math-field.editable').type('2^'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('='); await page.locator('text=There is an empty superscript that is causing a syntax error').waitFor({state: "attached", timeout: 1000}); // make sure placeholder gets add when cell loses focus await page.keyboard.press('Escape'); await page.keyboard.press(modifierKey+"+ArrowUp"); await page.locator('#cell-0 >> math-field.editable').type('3'); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(parseLatexFloat(content)).toBeCloseTo(8, precision); }); test('Error message for missing multiplication symbol between variable then number', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // variable followed by number await page.locator('#cell-0 >> math-field.editable').type('x_1'); await page.locator('#cell-0 >> math-field.editable').press('Tab'); await page.locator('#cell-0 >> math-field.editable').type('2='); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between number then variable', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // variable followed by number await page.locator('#cell-0 >> math-field.editable').type('2a='); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between variable then variable', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // variable followed by number await page.locator('#cell-0 >> math-field.editable').type('a b ='); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between expression then variable', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // variable followed by number await page.locator('#cell-0 >> math-field.editable').type('(a + b) c ='); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between expression then number', async () => { // variable followed by number await page.locator('#cell-0 >> math-field.editable').type('(a + b) 2 ='); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between expression then number with units', async () => { // variable followed by number await page.locator('#cell-0 >> math-field.editable').type('(a + b) 2 [in]='); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between expression then pi symbol', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; // variable followed by number await page.setLatex(0, String.raw`2\pi=`); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between number then expression', async () => { // variable followed by number await page.locator('#cell-0 >> math-field.editable').type('2(a+b)='); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between number with units then expression', async () => { // variable followed by number await page.locator('#cell-0 >> math-field.editable').type('2[in](a+b)='); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between symbol then expression', async () => { // variable followed by number await page.setLatex(0, String.raw`\pi\left(a+b\right)=`); await page.locator('text=Missing multiplication symbol between pi and opening parenthesis').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between expression then trig function', async () => { // variable followed by number await page.locator('#cell-0 >> math-field.editable').type('(a+b)sin(x)='); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between expression then builtin function', async () => { // variable followed by number await page.locator('#cell-0 >> math-field.editable').type('(a+b)min(1,2)='); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between expression then user function', async () => { // variable followed by number await page.locator('#cell-0 >> math-field.editable').type('(a+b)y(x=2)='); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between expression then indefinite integral', async () => { // variable followed by number await page.setLatex(0, String.raw`a\int\left(x\right)\mathrm{d}\left(x\right)=`); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between expression then definite integral', async () => { // variable followed by number await page.setLatex(0, String.raw`a\int_0^1\left(x\right)\mathrm{d}\left(x\right)=`); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between expression then derivative', async () => { // variable followed by number await page.setLatex(0, String.raw`a\frac{\mathrm{d}}{\mathrm{d}\left(x\right)}\left(x\right)=`); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for missing multiplication symbol between expression then 2nd derivative', async () => { // variable followed by number await page.setLatex(0, String.raw`a\frac{\mathrm{d}^2}{\mathrm{d}\left(x\right)^2}\left(x^2\right)=`); await page.locator('text=Missing multiplication symbol in expression').waitFor({state: "attached", timeout: 1000}); }); test('Error message for empty placeholder', async () => { // variable followed by number await page.locator('#cell-0 >> math-field.editable').type('/'); await page.locator('#cell-0 >> math-field.editable').press('ArrowRight'); await page.locator('#cell-0 >> math-field.editable').press('ArrowRight'); await page.locator('#cell-0 >> math-field.editable').type('='); await page.locator('text=Fill in empty placeholders (delete empty placeholders for unwanted subscripts or exponents)').waitFor({state: "attached", timeout: 1000}); }); test('Error auto correcting of unintended extra mathrm', async () => { const modifierKey = (await page.evaluate('window.modifierKey') )=== "metaKey" ? "Meta" : "Control"; await page.setLatex(0, String.raw`\mathrm{myfunc}\left(1\right)=`); await page.locator('#cell-0 >> math-field.editable').press('Home'); await page.locator('#cell-0 >> math-field.editable').press('ArrowRight'); await page.locator('#cell-0 >> math-field.editable').press('ArrowLeft'); await page.locator('#cell-0 >> math-field.editable').pressSequentially('a*', {delay: 10}); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent(`#result-value-0`); expect(content).toBe('a \\cdot \\operatorname{myfunc}{\\left(1 \\right)}'); await page.setLatex(0, String.raw`\mathrm{myfunc}\left(1\right)=`); await page.locator('#cell-0 >> math-field.editable').press('Home'); await page.locator('#cell-0 >> math-field.editable').press('ArrowRight'); await page.locator('#cell-0 >> math-field.editable').press('ArrowLeft'); await page.locator('#cell-0 >> math-field.editable').pressSequentially('2.0*', {delay: 10}); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`2 \cdot \operatorname{myfunc}{\left(1 \right)}`); await page.setLatex(0, String.raw`\mathrm{myfunc}\left(1\right)=`); await page.locator('#cell-0 >> math-field.editable').press('Home'); await page.locator('#cell-0 >> math-field.editable').press('ArrowRight'); await page.locator('#cell-0 >> math-field.editable').press('ArrowLeft'); await page.locator('#cell-0 >> math-field.editable').pressSequentially('.1+', {delay: 10}); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\operatorname{myfunc}{\left(1 \right)} + \frac{1}{10}`); await page.setLatex(0, String.raw`\mathrm{myfunc}\left(1\right)=`); await page.locator('#cell-0 >> math-field.editable').press('Home'); await page.locator('#cell-0 >> math-field.editable').press('ArrowRight'); await page.locator('#cell-0 >> math-field.editable').press('ArrowLeft'); await page.locator('#cell-0 >> math-field.editable').pressSequentially('-1e10-', {delay: 10}); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`- \operatorname{myfunc}{\left(1 \right)} - 10000000000`); await page.setLatex(0, String.raw`\mathrm{myfunc}\left(1\right)=`); await page.locator('#cell-0 >> math-field.editable').press('Home'); await page.locator('#cell-0 >> math-field.editable').press('ArrowRight'); await page.locator('#cell-0 >> math-field.editable').press('ArrowLeft'); await page.locator('#cell-0 >> math-field.editable').pressSequentially('a/b', {delay: 10}); await page.locator('#cell-0 >> math-field.editable').press('ArrowRight'); await page.locator('#cell-0 >> math-field.editable').pressSequentially('+', {delay: 10}); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\frac{a + b \cdot \operatorname{myfunc}{\left(1 \right)}}{b}`); await page.setLatex(0, String.raw`\mathrm{myfunc}\left(1\right)=`); await page.locator('#cell-0 >> math-field.editable').press('Home'); await page.locator('#cell-0 >> math-field.editable').press('ArrowRight'); await page.locator('#cell-0 >> math-field.editable').press('ArrowLeft'); await page.locator('#cell-0 >> math-field.editable').pressSequentially('a/b', {delay: 10}); await page.locator('#cell-0 >> math-field.editable').press('ArrowRight'); await page.locator('#cell-0 >> math-field.editable').pressSequentially('+', {dela: 10}); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent(`#result-value-0`); expect(content).toBe(String.raw`\frac{a + b \cdot \operatorname{myfunc}{\left(1 \right)}}{b}`); }); ================================================ FILE: tests/test_system_solve.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { cot, pi, sqrt, tan, cos} from 'mathjs'; import { precision, loadPyodide, newSheet, complexLatex, compareImages, pyodideLoadTimeout, screenshotDir, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test equation solving', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await expect(page.locator('#system-expression-0-0 math-field.editable')).toBeVisible(); await page.locator('#system-expression-0-0 math-field.editable').type('(x-2[meters])*(x-4[meters])=0'); await page.locator('#system-parameterlist-0 math-field.editable').type('x'); await page.locator('#add-system-cell').click(); await page.locator('#system-expression-1-0 math-field.editable').type('y-z=0'); await page.locator('#system-expression-1-0 math-field.editable').press('Enter'); await page.locator('#system-expression-1-1 math-field.editable').type('z=10[meters]'); await page.locator('#system-parameterlist-1 math-field.editable').type('y,z'); await page.click('#add-math-cell'); await page.setLatex(2, 'x='); await page.click('#add-math-cell'); await page.setLatex(3, 'y='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(2.0, precision); // first result content = await page.textContent('#result-units-2'); expect(content).toBe('m'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(10.0, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m'); // switch to second result for first system and check await page.locator('#solution-radio-0-1').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(4.0, precision); // second result // update the first system and make sure result updates await page.setLatex(0, String.raw`\left(x-2\left[m\right]\right)\cdot \left(x-6\left[m\right]\right)=0`, 0); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(6.0, precision); // delete first system and make sure result updates await page.forceDeleteCell(0); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(content).toBe('x', precision); for (let i=0; i<3; i++) { await page.forceDeleteCell(0); } await page.locator('#add-system-cell').click(); await page.locator('#system-expression-0-0 math-field.editable').type('8*g+7*o+3*l=3*o+6*g+6*l'); await page.locator('#add-row-0').click(); await page.locator('#system-expression-0-1 math-field.editable').type('g=2*l/3'); await page.locator('#add-row-0').click(); await page.locator('#system-expression-0-2 math-field.editable').type('12*o=3[kg]'); await page.locator('#system-parameterlist-0 math-field.editable').type('l,g,o'); await page.click('#add-math-cell'); await page.setLatex(1, 'l='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(0.6, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('kg'); for (let i=0; i<2; i++) { await page.forceDeleteCell(0); } await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', 'k=1[N/m'); await page.press(':nth-match(math-field.editable, 1)', 'ArrowRight'); await page.type(':nth-match(math-field.editable, 1)', ']'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 2)', 'm=1[kg]'); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 3)', 'x=10[mm]'); await page.click('#add-system-cell'); await page.setLatex(3, String.raw`\frac{1}{2}\cdot k\cdot x^2=\frac{1}{2}\cdot m\cdot v^2`, 0); await page.locator('#system-parameterlist-3 math-field.editable').type('v'); await page.click('#add-math-cell'); await page.setLatex(4, 'v='); await page.click('#add-math-cell'); await page.setLatex(5, String.raw`v=\left[\frac{miles}{hour}\right]`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(-0.01, precision); content = await page.textContent('#result-units-4'); expect(content).toBe('m^1*s^-1'); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(-0.022369362920544027, precision); content = await page.textContent('#result-units-5'); expect(content).toBe('(miles)/(hour)'); // switch to second solution await page.locator('#solution-radio-3-1').click(); await expect(page.locator('text=Updating...')).toBeHidden(); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(0.01, precision); content = await page.textContent('#result-units-4'); expect(content).toBe('m^1*s^-1'); content = await page.textContent('#result-value-5'); expect(parseLatexFloat(content)).toBeCloseTo(0.022369362920544027, precision); content = await page.textContent('#result-units-5'); expect(content).toBe('(miles)/(hour)'); }); test('test underdetermined system that has exact numerical solution', async () => { await page.click('#add-system-cell'); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`g=9.81\left[\frac{m}{sec^{2}}\right]`,0); await page.click('#add-row-0'); await page.setLatex(0, String.raw`h=10\left[ft\right]`, 1); await page.click('#add-row-0'); await page.setLatex(0, String.raw`m\cdot g\cdot h=\frac{1}{2}\cdot m\cdot v^{2}`, 2); await page.locator('#system-parameterlist-0 math-field.editable').type('v,h,g') await page.click('#add-math-cell'); await page.setLatex(1, String.raw`v=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(-sqrt(2*9.81*10*12*25.4/1000), precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m^1*s^-1'); // update previous example to use assignment instead of equality await page.setLatex(0, String.raw`h=\frac{1}{2\cdot g}\cdot v^{2}`, 2); await page.waitForSelector('text=Updating...', {state: 'detached'}); // switch to solution 2 await page.locator('#solution-radio-0-1').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(2*9.81*10*12*25.4/1000), precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m^1*s^-1'); // update previous example to use assignment with m on both sides // leave on second solution await page.setLatex(0, String.raw`m=\frac{1}{2\cdot g\cdot h}\cdot m\cdot v^{2}`, 2); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(2*9.81*10*12*25.4/1000), precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m^1*s^-1'); }); test('Test solving system of 3 equations', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.locator('#system-expression-0-0 math-field.editable').type('x+y=3'); await page.locator('#add-row-0').click(); await page.locator('#system-expression-0-1 math-field.editable').type('y=z-4'); await page.locator('#add-row-0').click(); await page.locator('#system-expression-0-2 math-field.editable').type('z=x^2'); await page.locator('#system-expression-0-2 math-field.editable').press('ArrowRight'); await page.locator('#system-expression-0-2 math-field.editable').type('-3'); await page.locator('#system-parameterlist-0 math-field.editable').type('x,y,z'); await page.click('#add-math-cell'); await page.setLatex(1,'x='); await page.click('#add-math-cell'); await page.setLatex(2,'y='); await page.click('#add-math-cell'); await page.setLatex(3,'z='); await page.waitForSelector('text=Updating...', {state: 'detached'}); // Solution 1 let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(-1/2 + sqrt(41)/2, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(7/2 - sqrt(41)/2, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(15/2 - sqrt(41)/2, precision); // Switch to solution 2 await page.locator('#solution-radio-0-1').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(-sqrt(41)/2 - 1/2, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(41)/2 + 7/2, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(41)/2 + 15/2, precision); }); test("Test case where all solutions don't have results for the same variables", async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`m\cdot g\cdot h=\frac{1}{2}\cdot m\cdot v^{2}`, 0); await page.locator('#system-parameterlist-0 math-field.editable').type('m,v'); await page.click('#add-math-cell'); await page.setLatex(1,'m='); await page.click('#add-math-cell'); await page.setLatex(2, 'v='); await page.waitForSelector('text=Updating...', {state: 'detached'}); // first solution let content = await page.textContent('#result-value-1'); expect(content).toBe('0'); content = await page.textContent('#result-value-2'); expect(content).toBe('v'); // second solution await page.locator('#solution-radio-0-1').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(content).toBe('- \\sqrt{2} \\cdot \\sqrt{g \\cdot h}'); // third solution await page.locator('#solution-radio-0-2').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(content).toBe(`\\sqrt{2} \\cdot \\sqrt{g \\cdot h}`); }); test('Test function notation with equation solving and combined function/assignment and expression as argument for function', async () => { await page.setLatex(0, String.raw`x=s+t`); await page.click('#add-math-cell'); await page.setLatex(1, String.raw`t=25.4\left[mm\right]`); await page.click('#add-math-cell'); await page.setLatex(2, String.raw`x\left(s=1\left[inch\right]\right)=\left[inch\right]`); await page.click('#add-math-cell'); await page.setLatex(3, String.raw`x\left(s=1\right)=`); await page.click('#add-system-cell'); await page.setLatex(4, String.raw`\frac{1}{2}\cdot m\cdot v^{2}=m\cdot g\cdot h`, 0); await page.locator('#system-parameterlist-4 math-field.editable').type('v') await page.click('#add-math-cell'); await page.setLatex(5, String.raw`v=`); await page.click('#add-math-cell'); await page.setLatex(6, String.raw`v\left(g=9.81\left[\frac{m}{sec^{2}}\right],h=2\cdot hh\right)=`); await page.click('#add-math-cell'); await page.setLatex(7, String.raw`hh=1.5\left[mm\right]`); await page.waitForSelector('text=Updating...', {state: 'detached'}); // select second solution to get positive velocity await page.locator('#solution-radio-4-1').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('inch'); await expect(page.locator('#cell-3 >> text=Dimension Error')).toBeVisible(); content = await page.textContent('#result-value-6'); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(2*9.81*.003), precision); content = await page.textContent('#result-units-6'); expect(content).toBe('m^1*s^-1'); }); test('Test system with 5 equations', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`R_{A}+R_{B}-q\cdot l=0`, 0); await page.click("#add-row-0"); await page.setLatex(0, String.raw`M_{A}+R_{B}\cdot l-q\cdot l\cdot \frac{l}{2}=0`, 1); await page.click("#add-row-0"); await page.setLatex(0, String.raw`\delta _{q}=-\frac{q\cdot l^{4}}{8\cdot E\cdot I}`, 2); await page.click("#add-row-0"); await page.setLatex(0, String.raw`\delta _{Rb}=\frac{R_{B}\cdot l^{3}}{3\cdot E\cdot I}`, 3); await page.click("#add-row-0"); await page.setLatex(0, String.raw`\delta _{q}+\delta _{Rb}=0`, 4); await page.locator('#system-parameterlist-0 math-field.editable').type('M_A'); await page.locator('#system-parameterlist-0 math-field.editable').press('ArrowRight'); await page.locator('#system-parameterlist-0 math-field.editable').type(', R_A'); await page.locator('#system-parameterlist-0 math-field.editable').press('ArrowRight'); await page.locator('#system-parameterlist-0 math-field.editable').type(', R_B'); await page.locator('#system-parameterlist-0 math-field.editable').press('ArrowRight'); await page.locator('#system-parameterlist-0 math-field.editable').type(', delta_Rb'); await page.locator('#system-parameterlist-0 math-field.editable').press('ArrowRight'); await page.locator('#system-parameterlist-0 math-field.editable').type(', delta_q'); await page.click("#add-math-cell"); await page.setLatex(1, String.raw`M_{A}=`); await page.click("#add-math-cell"); await page.setLatex(2, String.raw`R_{A}=`); await page.click("#add-math-cell"); await page.setLatex(3, String.raw`R_{B}=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); // check Rb let content = await page.textContent('#result-value-3'); expect(content).toBe(`\\frac{3 \\cdot l \\cdot q}{8}`); // add function query that depends on solution await page.click("#add-math-cell"); await page.setLatex(4, String.raw`R_{B}\left(q=10\left[\frac{N}{m}\right],\ l=1\left[m\right]\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-4'); expect(parseLatexFloat(content)).toBeCloseTo(3.75, precision); content = await page.textContent('#result-units-4'); expect(content).toBe('N'); }); test('Test restarting pyodide on a calculation that has caused sympy to hang', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`\cos\left(x\right)^{x}\cdot \log\left(x\right)=\cosh\left(x^{x}\right)\cdot \sin\left(x\right)\cdot \sinh\left(x\right)\cdot \tan\left(x\right)`, 0); await page.locator('#system-parameterlist-0 math-field.editable').type('x') await page.waitForTimeout(2000); await page.click('text=Restart Pyodide'); await page.forceDeleteCell(0); await page.click('#add-math-cell'); // need to choose a calc that hasn't already been cached await page.type(':nth-match(math-field.editable, 1)', 'zap='); await page.waitForSelector('.status-footer', {state: 'detached'}); let content = await page.textContent('#result-value-0'); expect(content).toBe('zap') // make sure syntax error is still detected after initial parse await page.forceDeleteCell(0); await page.click('#add-math-cell'); await page.type(':nth-match(math-field.editable, 1)', 'x+y='); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.setLatex(0, String.raw`x+y^{ }=`); expect(await page.$eval(':nth-match(math-field.editable, 1)', el => el.classList.contains("parsing-error"))).toBeTruthy(); }); test('Test solve with extra variables', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.type(':nth-match(math-field.editable, 1)', 'a*x+b*x+c=0'); await page.locator('#system-parameterlist-0 math-field.editable').type('x'); await page.click('#add-math-cell'); await page.setLatex(1, 'x='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(content).toBe('- \\frac{c}{a + b}') }); test('Test parser error messages for solve', async () => { await page.setLatex(0, '2\\cdot x=y'); await page.locator('text=Show Error').click(); await page.locator('text=Equality statements are no longer allowed in math cells, use a System Solve Cell instead.').waitFor({state: 'visible', timeout: 1000}); await page.forceDeleteCell(0); await page.locator('#add-system-cell').click(); // make sure a function notation expression is allowed in a system solve cell await page.setLatex(0, String.raw`f\left(x=1\right)=y`, 0); await page.locator('text=Show Error').click(); await page.locator('text=Function syntax is not allowed in a System Solve Cell.').waitFor({state: 'visible', timeout: 1000}); // make sure a function notation expression is also not allowed on the rhs of an assignment await page.setLatex(0, String.raw`x=y\left(z=1\right)`, 0); await page.locator('text=Show Error').click(); await page.locator('text=Function syntax is not allowed in a System Solve Cell.').waitFor({state: 'visible', timeout: 1000}); // make sure a query statement is not allowed in a solve cell expression await page.setLatex(0, String.raw`x=`, 0); await page.locator('text=Show Error').click(); await page.locator('text=An equation is required in this field.').waitFor({state: 'visible', timeout: 1000}); // make sure a query statement is not allowed in a solve cell parameter list await page.setLatex(0, String.raw`x=y`, 0); await page.locator('#system-parameterlist-0 math-field.editable').type('x='); await page.locator('text=Show Error').click(); await page.locator('text=A variable name, or a list of variable names separated by commas, is required in this field (x,y for example). If a numerical solve is required, the variables must be given initial guess values with a tilde (x~1, y~2, for example).').waitFor({state: 'visible', timeout: 1000}); }); test('Test system solve database saving and retrieving', async ({ browserName }) => { const width = 1300; const height = 2000; await page.setViewportSize({ width: width, height: height }); // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); // create system with two equations and two variables to solve for await page.forceDeleteCell(0); await page.locator('#add-system-cell').click(); await page.setLatex(0, String.raw`a\cdot x=y^{2}`, 0); await page.locator('#add-row-0').click(); await page.setLatex(0, String.raw`a=2\left[m\right]`, 1); await page.locator('#system-parameterlist-0 math-field.editable').type('a,y'); // add plot await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`y\left(1\le x\le 10\right)=`); // add query cell to check solve result await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`y\left(x=4\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); // switch to second solution to make sure the choice gets saved to the database await page.locator('#solution-radio-0-1').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(2)*2, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m^0.5'); // save to database and create a screenshot await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); await page.mouse.move(0,0); await page.keyboard.press('Escape'); await page.waitForTimeout(1000); await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_solve_screenshot.png`, fullPage: true }); // clear contents, we'll be creating a new sheet await page.locator('#new-sheet').click(); // retrieve previously saved document from database and check screenshot await page.goto(`${sheetUrl.pathname}`); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); await page.mouse.move(0,0); await page.keyboard.press('Escape'); await page.waitForTimeout(1000); await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_solve_screenshot_check.png`, fullPage: true }); // webkit cannot reproduce pixel perfect on this one // (seems like the exponent rendering changes slightly for webkit) if (browserName === "chromium" || browserName === "firefox") { expect(compareImages(`${browserName}_solve_screenshot.png`, `${browserName}_solve_screenshot_check.png`)).toEqual(0); } content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(sqrt(2)*2, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m^0.5'); // switch back to the first solution and check that result updates await page.locator('#solution-radio-0-0').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(-sqrt(2)*2, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m^0.5'); }); test('Test replacement of placeholder funcs with symbolic and numeric solve', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`\arcsin\left(x\right)=45\left[deg\right]`, 0); await page.locator('#system-parameterlist-0 math-field.editable').type('x'); await page.click('#add-math-cell'); await page.setLatex(1, 'x='); await page.locator('#add-system-cell').click(); await page.setLatex(2, String.raw`\arcsin\left(y\right)=45\left[deg\right]`, 0); await page.locator('#system-parameterlist-2 math-field.editable').type('y~.1'); await page.click('#add-math-cell'); await page.setLatex(3, 'y='); await page.locator('.status-footer').waitFor({state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(1/sqrt(2), precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(1/sqrt(2), precision); }); test('Test numerical equation solving with units', async () => { // System with one equation await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`\left(x-2\left[meters\right]\right)\cdot \left(x-4\left[meters\right]\right)=0\left[m^{2}\right]`, 0); await page.locator('#system-parameterlist-0 math-field.editable').type('x~1.5[m]'); // System with two Equations await page.locator('#add-system-cell').click(); await page.locator('#system-expression-1-0 math-field.editable').type('y-z=0[m]'); await page.locator('#system-expression-1-0 math-field.editable').press('Enter'); await page.locator('#system-expression-1-1 math-field.editable').type('z=10[meters]'); await page.locator('#system-parameterlist-1 math-field.editable').type('y~2[m],z~9[m]'); await page.click('#add-math-cell'); await page.setLatex(2, 'x='); await page.click('#add-math-cell'); await page.setLatex(3, 'y='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(2.0, precision); // first result content = await page.textContent('#result-units-2'); expect(content).toBe('m'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(10.0, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m'); // move initial guess to get second solution for first equation for (let i = 0; i<8; i++) { await page.locator('#system-parameterlist-0 math-field.editable').press('Backspace'); } await page.locator('#system-parameterlist-0 math-field.editable').type('x~10[m]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(4.0, precision); // second result // update the first system and make sure result updates await page.setLatex(0, String.raw`\left(x-2\left[m\right]\right)\cdot \left(x-6\left[m\right]\right)=0\left[m^{2}\right]`, 0); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(6.0, precision); // swap systems and make sure results don't change await page.locator('#up-1').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(6.0, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(10.0, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m'); // delete second system (previously the first) and make sure result updates await page.forceDeleteCell(1); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(content).toBe('x', precision); for (let i=0; i<3; i++) { await page.forceDeleteCell(0); } await page.locator('#add-system-cell').click(); await page.locator('#system-expression-0-0 math-field.editable').type('8*g+7*o+3*l=3*o+6*g+6*l'); await page.locator('#add-row-0').click(); await page.locator('#system-expression-0-1 math-field.editable').type('g=2*l/3'); await page.locator('#add-row-0').click(); await page.locator('#system-expression-0-2 math-field.editable').type('12*o=3[kg]'); await page.locator('#system-parameterlist-0 math-field.editable').type('l~1[kg],g~-1[lb],o~1[kg]'); await page.click('#add-math-cell'); await page.setLatex(1, 'l='); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(0.6, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('kg'); }); test('Test numerical solve error messages', async () => { // Create overdetermined system await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`\left(x-3\right)\cdot \left(x-5\right)=0`, 0); await page.locator('#add-row-0').click(); await page.setLatex(0, String.raw`x=20`, 1); await page.locator('#system-parameterlist-0 math-field.editable').type('x'); await page.locator('button:has-text("≈​")').click(); await page.locator('#system-parameterlist-0 math-field.editable').type('10'); await page.locator('#add-math-cell').click(); await page.setLatex(1, 'x='); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.locator('text=Cannot solve overdetermined system, the number of equations should match the number of unknowns') .waitFor({timeout:200000}); let content = await page.textContent('#result-value-1'); expect(content).toBe('x'); // create well posed system without units await page.locator('#delete-row-0-1').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(5, precision); // LHS and RHS units not match in system equaiton await page.setLatex(0, String.raw`\left(x-3\right)\cdot \left(x-5\right)=0\left[inch\right]`, 0); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.locator('text=Units mismatch in system of equations').waitFor({timeout:500}); await page.locator('text=Error: Units error in System Solve Cell').waitFor({timeout:500}); // shouldn't display results when there is a units error in numerical system solve await page.locator('#result-value-1').waitFor({state: 'detached', timeout: 1000}) // Add units to guess that don't match the equation await page.setLatex(0, String.raw`\left(x-3\right)\cdot \left(x-5\right)=0`, 0); await page.locator('#system-parameterlist-0 math-field.editable').type('[mm]'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.locator('text=Units mismatch in system of equations').waitFor({timeout:500}); await page.locator('text=Error: Units error in System Solve Cell').waitFor({timeout:500}); // shouldn't display results when there is a units error in numerical system solve await page.locator('#result-value-1').waitFor({state: 'detached', timeout: 1000}) // create underdetermined system await page.setLatex(0, String.raw`\left(x-3\right)\cdot \left(y-5\right)=0`, 0); for (let i=0; i<10; i++) { await page.locator('#system-parameterlist-0 math-field.editable').press('Backspace'); } await page.locator('#system-parameterlist-0 math-field.editable').type('x~3, y~5'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.locator('text=Cannot solve underdetermined system, the number of equations should match the number of unknowns') .waitFor({timeout:500}); content = await page.textContent('#result-value-1'); expect(content).toBe('x'); }); test('Test numerical solution variable rendering', async () => { // Create overdetermined system await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`N+\theta =1`, 0); await page.locator('#add-row-0').click(); await page.setLatex(0, String.raw`N-\theta =10`, 1); await page.locator('#system-parameterlist-0 math-field.editable').type('N~1, theta~3'); await page.locator('#add-math-cell').click(); await page.setLatex(1, 'N='); await page.locator('#add-math-cell').click(); await page.setLatex(2, 'theta='); await page.keyboard.press('Escape'); await page.waitForSelector('text=Updating...', {state: 'detached'}); await page.locator('text=ariable').waitFor({state: 'detached', timeout: 1000}); await page.locator('text=theta').waitFor({state: 'detached', timeout: 1000}); await page.locator('div.solution-container >> text=θ').waitFor({timeout: 1000}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(5.5, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(-4.5, precision); }); test('Test handling currently selected solution greater than number of solutions', async () => { await page.setLatex(0, String.raw`x=`); await page.click('#add-system-cell'); await page.setLatex(1, String.raw`x^{4}=4`, 0); await page.locator('#system-parameterlist-1 math-field.editable').type('x') await page.waitForSelector('text=Updating...', {state: 'detached'}); // select fourth solution await page.locator('#solution-radio-1-3').click(); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = complexLatex(await page.textContent('#result-value-0')); expect(content.re).toBeCloseTo(0, precision); expect(content.im).toBeCloseTo(sqrt(2), precision); // change system to only have 2 solutions await page.setLatex(1, String.raw`x^{2}=4`, 0); await page.waitForSelector('text=Updating...', {state: 'detached'}); // make sure first solution is both the selected solution and the displayed solution content = await page.textContent('#result-value-0'); expect(parseLatexFloat(content)).toBeCloseTo(-2, precision); // make sure first solution radio button is selected expect(await page.locator('#solution-radio-1-0').isChecked()).toBeTruthy(); }); test('Test matrix equation solve', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`\begin{bmatrix}1 & 0 & 0\\ 0 & 1 & 0\\ 0 & 0 & 1\end{bmatrix}\times\begin{bmatrix}a\\ b\\ c\end{bmatrix}=\begin{bmatrix}1\\ 2\\ 3\end{bmatrix}`, 0); await page.locator('#system-parameterlist-0 math-field.editable').type('a,b,c'); await page.click('#add-math-cell'); await page.locator('#cell-1 >> math-field.editable').type('a='); await page.click('#add-math-cell'); await page.locator('#cell-2 >> math-field.editable').type('b='); await page.click('#add-math-cell'); await page.locator('#cell-3 >> math-field.editable').type('c='); await page.waitForSelector('text=Updating...', {state: 'detached'}); // make sure first solution is both the selected solution and the displayed solution let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); }); test('Test numerical matrix equation solve', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`\begin{bmatrix}1 & 0 & 0\\ 0 & 1 & 0\\ 0 & 0 & 1\end{bmatrix}\times\begin{bmatrix}a\\ b\\ c\end{bmatrix}=\begin{bmatrix}1\\ 2\\ 3\end{bmatrix}`, 0); await page.locator('#system-parameterlist-0 math-field.editable').type('a~.5,b~.5,c~.5'); await page.click('#add-math-cell'); await page.locator('#cell-1 >> math-field.editable').type('a='); await page.click('#add-math-cell'); await page.locator('#cell-2 >> math-field.editable').type('b='); await page.click('#add-math-cell'); await page.locator('#cell-3 >> math-field.editable').type('c='); await page.waitForSelector('text=Updating...', {state: 'detached'}); // make sure first solution is both the selected solution and the displayed solution let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); }); test('Test determinant equation solve', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`\mathrm{det}\left(\begin{bmatrix}1-a & 0 & 0\\ 0 & 2-a & 0\\ 0 & 0 & 3-a\end{bmatrix}\right)=0`, 0); await page.locator('#system-parameterlist-0 math-field.editable').type('a'); await page.click('#add-math-cell'); await page.locator('#cell-1 >> math-field.editable').type('a='); await page.waitForSelector('text=Updating...', {state: 'detached'}); // make sure first solution is both the selected solution and the displayed solution let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); }); test('Test numerical determinant equation solve', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`\mathrm{det}\left(\begin{bmatrix}1-a & 0 & 0\\ 0 & 2-a & 0\\ 0 & 0 & 3-a\end{bmatrix}\right)=0`, 0); await page.locator('#system-parameterlist-0 math-field.editable').type('a~.7'); await page.click('#add-math-cell'); await page.locator('#cell-1 >> math-field.editable').type('a='); await page.waitForSelector('text=Updating...', {state: 'detached'}); // make sure first solution is both the selected solution and the displayed solution let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); }); test('Test numerical matrix equation solve with units', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`\begin{bmatrix}1\left\lbrack m\right\rbrack & 0 & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 1 & 0\left\lbrack m\right\rbrack\\ 0\left\lbrack m\right\rbrack & 0 & 1\left\lbrack m\right\rbrack\end{bmatrix}\times\begin{bmatrix}a\\ b\\ c\end{bmatrix}=\begin{bmatrix}1\left\lbrack m\right\rbrack\\ 2\left\lbrack m\right\rbrack\\ 3\left\lbrack m\right\rbrack\end{bmatrix}`, 0); await page.locator('#system-parameterlist-0 math-field.editable').type('a~.5,b~.5[m],c~.5'); await page.click('#add-math-cell'); await page.locator('#cell-1 >> math-field.editable').type('b='); await page.waitForSelector('text=Updating...', {state: 'detached'}); // make sure first solution is both the selected solution and the displayed solution let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); }); test('Test zero placeholder numerical with units', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`x+y=5\left\lbrack m\right\rbrack+0\cdot1\left\lbrack m\right\rbrack`, 0); await page.locator('#add-row-0').click(); await page.setLatex(0, String.raw`x-y=1\left\lbrack m\right\rbrack+0\left\lbrack m\right\rbrack`, 1); await page.locator('#system-parameterlist-0 math-field.editable').type('x~0[m],y~0.1[m]'); await page.locator('#add-math-cell').click(); await page.setLatex(1, 'x='); await page.locator('#add-math-cell').click(); await page.setLatex(2, 'y='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); }); test('Test zero placeholder symbolic with units', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`x+y=5\left\lbrack m\right\rbrack+0\cdot1\left\lbrack m\right\rbrack`, 0); await page.locator('#add-row-0').click(); await page.setLatex(0, String.raw`x-y=1\left\lbrack m\right\rbrack+0\left\lbrack m\right\rbrack`, 1); await page.locator('#system-parameterlist-0 math-field.editable').type('x,y'); await page.locator('#add-math-cell').click(); await page.setLatex(1, 'x='); await page.locator('#add-math-cell').click(); await page.setLatex(2, 'y='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-1'); expect(content).toBe('m'); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); }); test('Test zero placeholder numeric without units', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`x+y=5`, 0); await page.locator('#add-row-0').click(); await page.setLatex(0, String.raw`x-y=1+0`, 1); await page.locator('#system-parameterlist-0 math-field.editable').type('x~0,y~0.1'); await page.locator('#add-math-cell').click(); await page.setLatex(1, 'x='); await page.locator('#add-math-cell').click(); await page.setLatex(2, 'y='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-2'); expect(content).toBe(''); }); test('Test zero placeholder symbolic without units', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`x+y=5`, 0); await page.locator('#add-row-0').click(); await page.setLatex(0, String.raw`x-y+0=1`, 1); await page.locator('#system-parameterlist-0 math-field.editable').type('x,y'); await page.locator('#add-math-cell').click(); await page.setLatex(1, 'x='); await page.locator('#add-math-cell').click(); await page.setLatex(2, 'y='); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-1'); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); content = await page.textContent('#result-units-1'); expect(content).toBe(''); content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.textContent('#result-units-2'); expect(content).toBe(''); }); test('Test exponent with units', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`y=2\left\lbrack m\right\rbrack^{x}`, 0);; await page.locator('#system-parameterlist-0 math-field.editable').type('y'); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`y\left(x=2\left\lbrack m\right\rbrack\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`y\left(x=\frac{4\left\lbrack m\right\rbrack}{2\left\lbrack m\right\rbrack}\right)=`); await page.locator('#add-math-cell').click(); await page.setLatex(3, String.raw`y\left(x=2\right)=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); await expect(page.locator('#cell-1 >> text=Dimension Error')).toBeVisible(); // Technically this shouldn't be a dimension error. However, without the placeholder functions // raw sympy is unable to cancel exponent units await expect(page.locator('#cell-2 >> text=Dimension Error')).toBeVisible(); let content = await page.textContent('#result-value-3'); expect(parseLatexFloat(content)).toBeCloseTo(4, precision); content = await page.textContent('#result-units-3'); expect(content).toBe('m^2'); }); test('Test unintentional unit cancelling bug #344', async () => { await page.locator('#add-system-cell').click(); await expect(page.locator('#system-expression-1-0 math-field.editable')).toBeVisible(); await page.forceDeleteCell(0); await page.setLatex(0, String.raw`a+b=c`, 0);; await page.locator('#system-parameterlist-0 math-field.editable').type('a'); await page.locator('#add-math-cell').click(); await page.setLatex(1, String.raw`c=1\left\lbrack m\right\rbrack,b=1\left\lbrack m\right\rbrack`); await page.locator('#add-math-cell').click(); await page.setLatex(2, String.raw`a=`); await page.waitForSelector('text=Updating...', {state: 'detached'}); let content = await page.textContent('#result-value-2'); expect(parseLatexFloat(content)).toBeCloseTo(0, precision); content = await page.textContent('#result-units-2'); expect(content).toBe('m'); }); ================================================ FILE: tests/test_table_cell.spec.mjs ================================================ import { test, expect } from '@playwright/test'; import { precision, loadPyodide, newSheet, pyodideLoadTimeout, compareImages, screenshotDir, parseLatexFloat } from './utility.mjs'; let page; // loading pyodide takes a long time (especially in resource constrained CI environments) // load page once and use for all tests in this file test.beforeAll(async ({ browser }) => {page = await loadPyodide(browser, page);} ); // give each test a blank sheet to start with (this doesn't reload pyodide) test.beforeEach(async () => {await newSheet(page)}); test('Test table types in math cells', async () => { // Only number in math cell should generate a syntax error await page.locator('math-field.editable').nth(0).type('3'); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(1).type('1.0'); let content = await page.locator('#cell-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field must contain an assignment (e.g., x=y*z) or a query (e.g., x=). To delete an unwanted math cell, click the trash can on the right.'); content = await page.locator('#cell-1 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field must contain an assignment (e.g., x=y*z) or a query (e.g., x=). To delete an unwanted math cell, click the trash can on the right.'); // Only units in math cell should generate a syntax error await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(2).type('[inches]'); content = await page.locator('#cell-2 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field must contain an assignment (e.g., x=y*z) or a query (e.g., x=). To delete an unwanted math cell, click the trash can on the right.'); // Only parameter in a math cell should generate a syntax error await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(3).type('a'); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(4).type('aa'); await page.locator('#add-math-cell').click(); await page.locator('math-field.editable').nth(5).type('a_b'); content = await page.locator('#cell-3 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field must contain an assignment (e.g., x=y*z) or a query (e.g., x=). To delete an unwanted math cell, click the trash can on the right.'); content = await page.locator('#cell-4 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field must contain an assignment (e.g., x=y*z) or a query (e.g., x=). To delete an unwanted math cell, click the trash can on the right.'); content = await page.locator('#cell-5 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field must contain an assignment (e.g., x=y*z) or a query (e.g., x=). To delete an unwanted math cell, click the trash can on the right.'); }); test('Test parameter name error messages', async ({ browserName }) => { test.skip(browserName === "webkit", "Webkit not working with attribute selector."); await page.forceDeleteCell(0); await page.locator('#add-table-cell').click(); await page.locator('#add-col-0').click(); await page.locator('#parameter-name-0-0 math-field.editable').click(); for (let i=0; i<5; i++) { await page.keyboard.press('Backspace'); } for (let i=0; i<5; i++) { await page.keyboard.press('Delete'); } await page.locator('#parameter-name-0-0 math-field.editable').type('1'); let content = await page.locator('#parameter-name-0-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('A variable name is required in this field.'); await page.locator('#parameter-name-0-0 math-field.editable').dblclick(); await page.locator('#parameter-name-0-0 math-field.editable').type('a'); await page.locator('#parameter-name-0-1 math-field.editable').dblclick(); await page.locator('#parameter-name-0-1 math-field.editable').type('a=b'); content = await page.locator('#parameter-name-0-1 span[slot="tooltipText"]').textContent(); expect(content).toBe('A variable name is required in this field.'); await page.locator('#parameter-name-0-1 math-field.editable').dblclick(); await page.locator('#parameter-name-0-1 math-field.editable').type('b'); await page.locator('#parameter-name-0-2 math-field.editable').dblclick(); await page.locator('#parameter-name-0-2 math-field.editable').type('a='); content = await page.locator('#parameter-name-0-2 span[slot="tooltipText"]').textContent(); expect(content).toBe('A variable name is required in this field.'); }); test('Test parameter units error messages', async ({ browserName }) => { test.skip(browserName === "webkit", "Webkit not working with attribute selector."); await page.forceDeleteCell(0); await page.locator('#add-table-cell').click(); await page.locator('#add-col-0').click(); await page.locator('#parameter-units-0-0 math-field.editable').type('1'); let content = await page.locator('#parameter-units-0-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain units in square brackets or may be left blank to indicate no units.'); await page.locator('#parameter-units-0-0 math-field.editable').dblclick(); await page.locator('#parameter-units-0-0 math-field.editable').type('[m]'); await page.locator('#parameter-units-0-1 math-field.editable').dblclick(); await page.locator('#parameter-units-0-1 math-field.editable').type('a=b'); content = await page.locator('#parameter-units-0-1 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain units in square brackets or may be left blank to indicate no units.'); await page.locator('#parameter-units-0-1 math-field.editable').dblclick(); await page.locator('#parameter-units-0-1 math-field.editable').type('b'); await page.locator('#parameter-units-0-2 math-field.editable').dblclick(); await page.locator('#parameter-units-0-2 math-field.editable').type('a='); content = await page.locator('#parameter-units-0-2 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain units in square brackets or may be left blank to indicate no units.'); }); test('Test table cell error messages', async ({ browserName }) => { test.skip(browserName === "webkit", "Webkit not working with attribute selector."); await page.forceDeleteCell(0); await page.locator('#add-table-cell').click(); await page.locator('#add-col-0').click(); await page.locator('#parameter-units-0-0 math-field.editable').type('[in]'); await page.locator('#parameter-units-0-1 math-field.editable').type('[m]'); await page.locator('#grid-cell-0-0-0 math-field.editable').type('a'); await page.locator('#grid-cell-0-0-1 math-field.editable').type('b=c'); await page.locator('#grid-cell-0-0-2 math-field.editable').type('c='); await page.locator('#grid-cell-0-1-0 math-field.editable').type('1[in]'); await page.locator('#grid-cell-0-1-1 math-field.editable').type('2'); await page.locator('#grid-cell-0-1-2 math-field.editable').type('[in]'); let content = await page.locator('#grid-cell-0-0-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain a number since units are specified for this column.'); content = await page.locator('#grid-cell-0-0-1 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain a number since units are specified for this column.'); content = await page.locator('#grid-cell-0-0-2 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain a valid expression or number without an equals sign or it may be blank.'); content = await page.locator('#grid-cell-0-1-0 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain a number since units are specified for this column.'); await expect(() => page.locator('#grid-cell-0-1-1 span[slot="tooltipText"]').textContent({timeout: 10})) .rejects.toThrow('Timeout'); content = await page.locator('#grid-cell-0-1-2 span[slot="tooltipText"]').textContent(); expect(content).toBe('This field may only contain a valid expression or number without an equals sign or it may be blank.'); await page.locator('#parameter-units-0-0 math-field.editable').click({clickCount: 3}); await page.locator('#parameter-units-0-0 math-field.editable').type(' '); await expect(() => page.locator('#grid-cell-0-0-0 span[slot="tooltipText"]').textContent({timeout: 10})) .rejects.toThrow('Timeout'); await expect(() => page.locator('#grid-cell-0-1-0 span[slot="tooltipText"]').textContent({timeout: 10})) .rejects.toThrow('Timeout'); await page.locator('#grid-cell-0-0-1 math-field.editable').click({clickCount: 3}); await page.locator('#grid-cell-0-0-1 math-field.editable').type(' '); await expect(() => page.locator('#grid-cell-0-0-1 span[slot="tooltipText"]').textContent({timeout: 10})) .rejects.toThrow('Timeout'); }); test('Test table cell functionality', async ({ browserName }) => { const width = 1300; const height = 2000; await page.setViewportSize({ width: width, height: height }); // Change title await page.getByRole('heading', { name: 'New Sheet' }).click({ clickCount: 3 }); await page.type('text=New Sheet', 'Title for testing purposes only, will be deleted from database automatically'); await page.setLatex(0, 'a_1='); await page.click('#add-math-cell'); await page.setLatex(1, 'alpha='); await page.click('#add-table-cell'); for (let i = 0; i<4; i++) { await page.locator('#parameter-name-2-0 math-field.editable').press('Backspace'); } await page.locator('#parameter-name-2-0 math-field.editable').type('a_1'); for (let i = 0; i<4; i++) { await page.locator('#parameter-name-2-1 math-field.editable').press('Backspace'); } await page.locator('#parameter-name-2-1 math-field.editable').type('alpha'); await page.locator('#parameter-units-2-0 math-field.editable').type('[mm]'); await page.locator('#grid-cell-2-0-0 math-field.editable').type('1000'); await page.keyboard.press('Enter'); await page.keyboard.press('Tab'); await page.keyboard.press('Tab'); await page.keyboard.type('mu'); await page.locator('#row-label-2-0').click({clickCount: 3}); await page.locator('#row-label-2-0').type('Row One'); await page.locator('#row-label-2-1').click({clickCount: 3}); await page.locator('#row-label-2-1').type('Row Two'); await page.locator('#add-row-docs-2').click(); await page.locator('.ql-editor').type('1: one'); await page.click('#add-math-cell'); await page.setLatex(3, 'c='); await page.click('#add-math-cell'); await page.setLatex(4, 'd='); await page.waitForSelector('.status-footer', { state: 'detached' }); let content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-1').textContent(); expect(content).toBe('\\alpha'); content = await page.locator('#result-value-3').textContent(); expect(content).toBe('c'); content = await page.locator('#result-value-4').textContent(); expect(content).toBe('d'); // select second row and verify results update await page.locator('#row-radio-2-1').check(); await page.locator('.ql-editor').type('2: two'); await expect(page.locator('text=Updating...')).toBeHidden(); content = await page.locator('#result-value-0').textContent(); expect(content).toBe('a_1'); content = await page.locator('#result-value-1').textContent(); expect(content).toBe('\\mu'); content = await page.locator('#result-value-3').textContent(); expect(content).toBe('c'); content = await page.locator('#result-value-4').textContent(); expect(content).toBe('d'); // add a third row using Enter key await page.locator('#grid-cell-2-1-0 math-field.editable').press('Enter'); await page.keyboard.press('Tab'); await page.keyboard.type('1'); await page.keyboard.press('Tab'); await page.keyboard.type('2000[mm]'); await page.locator('#row-radio-2-2').check(); await expect(page.locator('text=2: two')).not.toBeVisible(); await page.locator('.ql-editor').type('3: three'); await page.locator('text=Updating...').waitFor({state: 'detached'}); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(.001, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-3').textContent(); expect(content).toBe('c'); content = await page.locator('#result-value-4').textContent(); expect(content).toBe('d'); // add third and fourth columns await page.locator('#add-col-2').click(); for (let i = 0; i<4; i++) { await page.locator('#parameter-name-2-2 math-field.editable').press('Backspace'); } await page.locator('#parameter-name-2-2 math-field.editable').type('c'); await page.locator('#add-col-2').click(); for (let i = 0; i<4; i++) { await page.locator('#parameter-name-2-3 math-field.editable').press('Backspace'); } await page.locator('#parameter-name-2-3 math-field.editable').type('d'); await page.locator('#grid-cell-2-2-2 math-field.editable').type('z'); await page.locator('#grid-cell-2-1-3 math-field.editable').type('3'); await page.locator('text=Updating...').waitFor({state: 'detached'}); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(.001, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-3').textContent(); expect(content).toBe('z'); content = await page.locator('#result-value-4').textContent(); expect(content).toBe('d'); // switch back to second row await page.locator('#row-radio-2-1').check(); await page.locator('text=Updating...').waitFor({state: 'detached'}); content = await page.locator('#result-value-0').textContent(); expect(content).toBe('a_1'); content = await page.locator('#result-value-1').textContent(); expect(content).toBe('\\mu'); content = await page.locator('#result-value-3').textContent(); expect(content).toBe('c'); content = await page.locator('#result-value-4').textContent(); expect(content).toBe('3'); await page.locator('text=2: two').waitFor({state: 'attached'}); // save to database and create a screenshot await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); await page.mouse.move(0,0); await page.keyboard.press('Escape'); await page.waitForTimeout(1000); await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_table_screenshot.png`, fullPage: false }); // clear contents, we'll be creating a new sheet await page.locator('#new-sheet').click(); // retrieve previously saved document from database and check screenshot await page.goto(`${sheetUrl.pathname}`); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); await page.mouse.move(0,0); await page.keyboard.press('Escape'); await page.waitForTimeout(1000); await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_table_screenshot_check.png`, fullPage: false }); expect(compareImages(`${browserName}_table_screenshot.png`, `${browserName}_table_screenshot_check.png`)).toEqual(0); // switch to row 3 await page.locator('#row-radio-2-2').check(); // test the functionality to hide unselected table rows await page.locator('#hide-unselected-rows-2').click(); // results should still be the same as before await page.locator('text=Updating...').waitFor({state: 'detached'}); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(.001, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-3').textContent(); expect(content).toBe('z'); content = await page.locator('#result-value-4').textContent(); expect(content).toBe('d'); await page.locator('text=3: three').waitFor({state: 'attached'}); // make sure row one is no longer visible await expect(() => page.locator('#row-radio-2-0').check({timeout: 10})) .rejects.toThrow('Timeout'); // save to database with unselected rows hidden and make sure it returns the same await page.click('#upload-sheet'); await page.click('text=Confirm'); await page.waitForSelector('#shareable-link'); const sheetUrl2 = new URL(await page.$eval('#shareable-link', el => el.value)); await page.click('[aria-label="Close the modal"]'); await page.keyboard.press('Escape'); await page.waitForTimeout(1000); await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_table_screenshot2.png`, fullPage: false }); // retrieve previously saved document from database and check screenshot await page.goto(`${sheetUrl2.pathname}`); await page.locator('h3 >> text=Retrieving Sheet').waitFor({state: 'detached', timeout: 5000}); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); await page.keyboard.press('Escape'); await page.waitForTimeout(1000); await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_table_screenshot2_check.png`, fullPage: false }); expect(compareImages(`${browserName}_table_screenshot2.png`, `${browserName}_table_screenshot2_check.png`)).toEqual(0); // show all rows again and makesure screenshot matches original await page.locator('#show-all-rows-2').click(); await page.waitForSelector('.status-footer', { state: 'detached' }); // switch back to row 2 await page.locator('#row-radio-2-1').check(); await expect(page.locator('text=Updating...')).toBeHidden(); // results should still be the same as before content = await page.locator('#result-value-0').textContent(); expect(content).toBe('a_1'); content = await page.locator('#result-value-1').textContent(); expect(content).toBe('\\mu'); content = await page.locator('#result-value-3').textContent(); expect(content).toBe('c'); content = await page.locator('#result-value-4').textContent(); expect(content).toBe('3'); await page.locator('text=2: two').waitFor({state: 'attached'}); // take new screenshot, should match first screenshot // makes sure no data was lost when hiding rows, saving to database, and retrieving from database await page.mouse.move(0,0); await page.keyboard.press('Escape'); await page.waitForTimeout(1000); await page.evaluate(() => window.scrollTo(0, 0)); await page.screenshot({ path: `${screenshotDir}/${browserName}_table_screenshot3.png`, fullPage: false }); expect(compareImages(`${browserName}_table_screenshot.png`, `${browserName}_table_screenshot3.png`)).toEqual(0); // delete 2nd row await page.locator('#delete-row-2-1').click(); await page.locator('text=Updating...').waitFor({state: 'detached'}); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(1, precision); content = await page.locator('#result-units-0').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-1').textContent(); expect(content).toBe('\\alpha'); content = await page.locator('#result-value-3').textContent(); expect(content).toBe('c'); content = await page.locator('#result-value-4').textContent(); expect(content).toBe('d'); await page.locator('text=1: one').waitFor({state: 'attached'}); // delete first column and switch to last row await page.locator('#delete-col-2-0').click(); await page.locator('#row-radio-2-1').check(); await expect(page.locator('text=Updating...')).toBeHidden(); content = await page.locator('#result-value-0').textContent(); expect(content).toBe('a_1'); await page.locator('text=Updating...').waitFor({state: 'detached'}); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m'); content = await page.locator('#result-value-3').textContent(); expect(content).toBe('z'); content = await page.locator('#result-value-4').textContent(); expect(content).toBe('d'); await page.locator('text=3: three').waitFor({state: 'attached'}); // make sure negative numbers can be entered for columns with units await page.locator('#parameter-units-2-0 math-field.editable').type('[mm]'); await page.locator('#grid-cell-2-1-0 math-field.editable').click({clickCount: 3}); await page.locator('#grid-cell-2-1-0 math-field.editable').type('-2e3'); await page.locator('text=Updating...').waitFor({state: 'detached'}); content = await page.locator('#result-value-1').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(-2, precision); content = await page.locator('#result-units-1').textContent(); expect(content).toBe('m'); }); test('Test fix for crash when last column deleted', async () => { await page.locator('math-field.editable').nth(0).type('Var2='); await page.locator('#add-table-cell').click(); await page.locator('#grid-cell-1-0-0 math-field.editable').type('1'); await page.locator('#grid-cell-1-0-1 math-field.editable').type('2'); await page.locator('text=Updating...').waitFor({state: 'detached'}); let content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); // delete last column and make sure result updates await page.locator('#delete-col-1-1').click(); // make sure second column is no longer visible (prevents regression for a previous bug) await page.locator('#parameter-units-1-1').waitFor({state: 'detached', timeout: 1000}); await page.locator('text=Updating...').waitFor({state: 'detached'}); content = await page.locator('#result-value-0').textContent(); expect(content).toBe('Var2'); }); test('Test fix for crash when last row selected and not last row deleted', async () => { await page.locator('math-field.editable').nth(0).type('Var1='); await page.locator('#add-table-cell').click(); await page.locator('#grid-cell-1-0-0 math-field.editable').type('1'); await page.locator('#grid-cell-1-1-0 math-field.editable').type('2'); await page.locator('#row-radio-1-1').check(); await page.locator('text=Updating...').waitFor({state: 'detached'}); let content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(2, precision); // delete first row and make sure result updates (selected row should update to first row) await page.locator('#delete-row-1-0').click(); // make sure second row is no longer visible await page.locator('#row-radio-1-1').waitFor({state: 'detached', timeout: 1000}); // enter a value in column 2 to make sure everything is updating as expected await page.locator('#grid-cell-1-0-1 math-field.editable').type('3'); await page.setLatex(0, 'Var2='); await page.locator('text=Updating...').waitFor({state: 'detached'}); content = await page.locator('#result-value-0').textContent(); expect(parseLatexFloat(content)).toBeCloseTo(3, precision); }); ================================================ FILE: tests/utility.mjs ================================================ import fs from 'fs'; import path from 'path'; import { PNG } from 'pngjs'; import { complex } from 'mathjs'; export const pyodideLoadTimeout = 100000; // number of digits of accuracy after decimal point for .toBeCloseTo() calls export const precision = 13; import pixelmatch from 'pixelmatch'; import { expect } from '@playwright/test'; export const screenshotDir = "./tests/images"; export function compareImages(file1, file2) { const img1 = PNG.sync.read(fs.readFileSync(path.join(screenshotDir, file1))); const img2 = PNG.sync.read(fs.readFileSync(path.join(screenshotDir, file2))); const { width, height } = img1; const diff = new PNG({ width, height }); const numDiffPixels = pixelmatch(img1.data, img2.data, diff.data, width, height, { threshold: 0.1 }); const diffOutBuffer = PNG.sync.write(diff); const file1Path = path.parse(file1); fs.writeFileSync(path.join(screenshotDir, `${file1Path.name}_diff.png`), diffOutBuffer); return numDiffPixels; } export async function loadPyodide(browser, page) { page = await browser.newPage(); page.setLatex = async function (cellIndex, latex, subIndex) { await this.evaluate(([cellIndex, latex, subIndex]) => window.setCellLatex(cellIndex, latex, subIndex), [cellIndex, latex, subIndex]); } page.forceDeleteCell = async function (index) { await this.evaluate((index) => window.forceDeleteCell(index), index); await this.waitForTimeout(200); } // reducing animations speeds up tests await page.emulateMedia( { reducedMotion: "reduce" } ); await page.goto('/'); await page.locator('text=Accept').click(); await page.waitForSelector('.status-footer', { state: 'detached', timeout: pyodideLoadTimeout }); return page; } export async function newSheet(page) { await page.keyboard.press('Escape'); await expect(page.locator('#new-sheet')).toBeVisible(); await page.evaluate(() => window.forceNoUnsavedChange()); await page.locator('#new-sheet').click(); await expect(page.locator('#cell-0 math-field.editable')).toHaveCount(1); await page.locator('#cell-0 math-field.editable').click(); } export function complexLatex(input) { const cleanedInput = input.replace('\\cdot','').replace(/^=/, '').replaceAll(' ', ''); return complex(cleanedInput); } export function parseLatexFloat(input) { input = input.replace('\\times', '').replace(/^=/, '').replace('10^{', 'e').replace('}', '').replaceAll(' ', ''); return Number(input); } ================================================ FILE: tsconfig.json ================================================ { "compilerOptions": { "resolveJsonModule": true, "target": "esnext", "strict": false, "verbatimModuleSyntax": true, "isolatedModules": true, "types": ["@types/wicg-file-system-access"], "lib": [ "esnext", "dom" ] }, "extends": "./node_modules/@tsconfig/svelte/tsconfig.json", "include": ["src/**/*"], "exclude": ["node_modules/*", "src/database/_worker.ts"] } ================================================ FILE: vite.config.js ================================================ import { defineConfig } from 'vite'; import { svelte } from '@sveltejs/vite-plugin-svelte'; import { optimizeCss } from 'carbon-preprocess-svelte'; import { viteStaticCopy } from 'vite-plugin-static-copy'; import { VitePWA } from 'vite-plugin-pwa'; import { open } from 'node:fs/promises'; import { join } from 'path'; import { spawn } from 'node:child_process'; import ssri from 'ssri'; // Vite outputs to 'dist' by default, not 'public' const outDir = 'dist'; export default defineConfig(({ command, mode }) => { const isProd = mode === 'production'; return { plugins: [ svelte(), optimizeCss(), // Asset Copying (MathLive / MathJax) viteStaticCopy({ targets: [ { src: 'node_modules/mathlive/dist/fonts/*', dest: 'mathlive/fonts', rename: { stripBase: true } }, { src: 'node_modules/mathlive/dist/sounds/*', dest: 'mathlive/sounds', rename: { stripBase: true } }, { src: 'node_modules/mathjax/es5/tex-svg.js', dest: 'mathjax', rename: { stripBase: true } }, ], }), // Workbox / Service Worker Integration VitePWA({ strategies: 'generateSW', filename: 'serviceworker.js', injectRegister: false, // Assuming you register it manually in main.js manifest: false, workbox: { globDirectory: outDir, globIgnores: [ "_worker.js", "_routes.json", "**/*.{ts,map}", "iframe_test.html", ], globPatterns: [ "**/*.{js,css,html,py,json}", "**/*icon*.{svg,png,ico}", "images/**/*", "pyodide/*", "mathlive/fonts/*", "mathlive/sounds/*", "logo_dark.svg", "print_logo.png", "assets/IBMPlexSans-Light-Latin1*.woff2", "assets/IBMPlexSans-Regular-Latin1*.woff2", "assets/IBMPlexSans-Regular-Greek*.woff2", "assets/IBMPlexSans-SemiBold-Latin1*.woff2", "assets/IBMPlexSans-SemiBoldItalic-Latin1*.woff2", "assets/IBMPlexSans-Italic-Latin1*.woff2", "assets/IBMPlexSans-Italic*.woff2", "assets/IBMPlexSans-Bold-Latin1*.woff2", "assets/IBMPlexSans-Regular-Pi*.woff2", "assets/IBMPlexSans-SemiBoldItalic*.woff2", "assets/IBMPlexSans-Regular*.woff2", "assets/IBMPlexMono-Light-Latin1*.woff2", "assets/IBMPlexMono-Regular-Latin1*.woff2", "assets/IBMPlexSans-Italic-Greek*.woff2", ], navigateFallback: "index.html", navigateFallbackAllowlist: [ /^\/[a-zA-Z0-9]{22}$/, /^\/temp-checkpoint-.*$/, /^\/open_file$/, ], ignoreURLParametersMatching: [/^activation$/, /^modal$/], maximumFileSizeToCacheInBytes: 40 * 1000 ** 2, inlineWorkboxRuntime: true, sourcemap: !isProd, mode: isProd ? "production" : "dev", manifestTransforms: [integrityManifestTransform], } }), watchBrowserWorkersPlugin() ], css: { preprocessorOptions: { scss: { quietDeps: true, silenceDeprecations: ['legacy-js-api', 'import', 'global-builtin'], }, }, }, worker: { format: 'es' }, build: { outDir, sourcemap: !isProd, emptyOutDir: true, // Replaces rollup-plugin-delete }, server: { port: 8788, strictPort: true, }, preview: { port: 8788, strictPort: true, } }; }); function watchBrowserWorkersPlugin() { return { name: 'watch-browser-workers', configureServer(server) { console.log('\n🚀 Starting esbuild for browser workers in watch mode...'); // 1. Spawn the unified esbuild script with the --watch flag appended const workerProcess = spawn('npm', ['run', 'build:workers', '--', '--watch'], { stdio: 'inherit', shell: true }); // 2. Clean up the background process gracefully when you shut down Vite server.httpServer?.once('close', () => { workerProcess.kill(); }); // 3. Watch the entire public folder for changes to the compiled files server.watcher.add('public'); // 4. Listen for changes and force a reload if a worker bundle is updated server.watcher.on('change', (file) => { // Normalize the path check so it catches public/pyodideWorker.js // as well as nested ones like public/parser/parserWorker.js if (file.includes('public') && file.endsWith('Worker.js')) { console.log(`\n🔄 Compiled worker updated: ${file}`); console.log('Forcing browser reload...'); server.ws.send({ type: 'full-reload' }); } }); } } } async function integrityManifestTransform(originalManifest, compilation) { const warnings = []; const manifest = await Promise.all( originalManifest.map(async (entry) => { if (entry.url === "index.html") { // index.html may get transformed by the server so it will not match the integrity check return entry; } const fd = await open(join(outDir, entry.url)); entry.integrity = ( await ssri.fromStream(fd.createReadStream()) ).toString(); return entry; }) ); return { warnings, manifest }; }