diff --git a/.github/workflows/python-wasm.yml b/.github/workflows/python-wasm.yml index 232d89364..39d64e35f 100644 --- a/.github/workflows/python-wasm.yml +++ b/.github/workflows/python-wasm.yml @@ -25,7 +25,7 @@ jobs: matrix: os: [ubuntu-22.04, windows-2022, macos-14] python-minor-version: [11, 12] - package: [compress-stringify, compare-images, dicom, mesh-io, image-io, downsample] + package: [compress-stringify, compare-images, dicom, mesh-io, image-io, transform-io, downsample] steps: - name: Checkout diff --git a/packages/core/python/itkwasm/itkwasm/__init__.py b/packages/core/python/itkwasm/itkwasm/__init__.py index 52ca8e475..caf4eb3d3 100644 --- a/packages/core/python/itkwasm/itkwasm/__init__.py +++ b/packages/core/python/itkwasm/itkwasm/__init__.py @@ -1,6 +1,6 @@ """itkwasm: Python interface to itk-wasm WebAssembly modules.""" -__version__ = "1.0b180" +__version__ = "1.0b185" from .interface_types import InterfaceTypes from .image import Image, ImageType, ImageRegion diff --git a/packages/core/python/itkwasm/itkwasm/interface_types.py b/packages/core/python/itkwasm/itkwasm/interface_types.py index 6c52b69b2..7346af5a0 100644 --- a/packages/core/python/itkwasm/itkwasm/interface_types.py +++ b/packages/core/python/itkwasm/itkwasm/interface_types.py @@ -9,5 +9,5 @@ class InterfaceTypes(str, Enum): Mesh = "Mesh" PointSet = "PointSet" PolyData = "PolyData" - Transform = "Transform" + TransformList = "TransformList" JsonCompatible = "JsonCompatible" diff --git a/packages/core/python/itkwasm/itkwasm/pipeline.py b/packages/core/python/itkwasm/itkwasm/pipeline.py index 36b5d0c45..3018aef21 100644 --- a/packages/core/python/itkwasm/itkwasm/pipeline.py +++ b/packages/core/python/itkwasm/itkwasm/pipeline.py @@ -22,6 +22,7 @@ from .binary_file import BinaryFile from .image import Image from .mesh import Mesh +from .transform import Transform from .point_set import PointSet from .polydata import PolyData from .json_compatible import JsonCompatible @@ -45,6 +46,8 @@ WasiConfig, Linker, WasmtimeError, + DirPerms, + FilePerms ) # Get the value of the ITKWASM_CACHE_DIR environment variable @@ -83,7 +86,7 @@ def __init__( wasi_config.argv = args for preopen in preopen_directories: - wasi_config.preopen_dir(preopen, preopen) + wasi_config.preopen_dir(preopen, preopen, DirPerms.READ_WRITE, FilePerms.READ_WRITE) store.set_wasi(wasi_config) @@ -299,6 +302,34 @@ def run( "pointData": f"data:application/vnd.itk.address,0:{point_data_ptr}", } ri.set_input_json(point_set_json, index) + elif input_.type == InterfaceTypes.TransformList: + transform_list = input_.data + transform_list_json = [] + for idx, transform in enumerate(transform_list): + if transform.numberOfFixedParameters: + fpv = array_like_to_bytes(transform.fixedParameters) + else: + fpv = bytes([]) + fixed_parameters_ptr = ri.set_input_array(fpv, index, idx * 2) + fixed_parameters = f"data:application/vnd.itk.address,0:{fixed_parameters_ptr}" + if transform.numberOfParameters: + pv = array_like_to_bytes(transform.parameters) + else: + pv = bytes([]) + parameters_ptr = ri.set_input_array(pv, index, idx * 2 + 1) + parameters = f"data:application/vnd.itk.address,0:{parameters_ptr}" + transform_json = { + "transformType": asdict(transform.transformType), + "numberOfFixedParameters": transform.numberOfFixedParameters, + "numberOfParameters": transform.numberOfParameters, + "name": transform.name, + "inputSpaceName": transform.inputSpaceName, + "outputSpaceName": transform.outputSpaceName, + "fixedParameters": fixed_parameters, + "parameters": parameters, + } + transform_list_json.append(transform_json) + ri.set_input_json(transform_list_json, index) elif input_.type == InterfaceTypes.PolyData: polydata = input_.data if polydata.numberOfPoints: @@ -489,6 +520,27 @@ def run( point_set.pointData = buffer_to_numpy_array(point_set.pointSetType.pointPixelComponentType, bytes([])) output_data = PipelineOutput(InterfaceTypes.PointSet, point_set) + elif output.type == InterfaceTypes.TransformList: + transform_list_json = ri.get_output_json(index) + transform_list = [] + for idx, transform_json in enumerate(transform_list_json): + transform = Transform(**transform_json) + if transform.numberOfFixedParameters > 0: + data_ptr = ri.get_output_array_address(0, index, idx * 2) + data_size = ri.get_output_array_size(0, index, idx * 2) + transform.fixedParameters = buffer_to_numpy_array( + transform.transformType.parametersValueType, + ri.wasmtime_lift(data_ptr, data_size), + ) + if transform.numberOfParameters > 0: + data_ptr = ri.get_output_array_address(0, index, idx * 2 + 1) + data_size = ri.get_output_array_size(0, index, idx * 2 + 1) + transform.parameters = buffer_to_numpy_array( + transform.transformType.parametersValueType, + ri.wasmtime_lift(data_ptr, data_size), + ) + transform_list.append(transform) + output_data = PipelineOutput(InterfaceTypes.TransformList, transform_list) elif output.type == InterfaceTypes.PolyData: polydata_json = ri.get_output_json(index) polydata = PolyData(**polydata_json) diff --git a/packages/core/python/itkwasm/itkwasm/pyodide.py b/packages/core/python/itkwasm/itkwasm/pyodide.py index 9ae88bed4..0df0b04c9 100644 --- a/packages/core/python/itkwasm/itkwasm/pyodide.py +++ b/packages/core/python/itkwasm/itkwasm/pyodide.py @@ -5,6 +5,7 @@ from .point_set import PointSet, PointSetType from .mesh import Mesh, MeshType from .polydata import PolyData, PolyDataType +from .transform import Transform, TransformType from .binary_file import BinaryFile from .binary_stream import BinaryStream from .text_file import TextFile @@ -147,6 +148,20 @@ def to_py(js_proxy): if polydata_dict["cellData"] is not None: polydata_dict["cellData"] = buffer_to_numpy_array(cell_pixel_component_type, polydata_dict["cellData"]) return PolyData(**polydata_dict) + elif hasattr(js_proxy, "transformType"): + transform_dict = js_proxy.to_py() + transform_type = TransformType(**transform_dict["transformType"]) + transform_dict["transformType"] = transform_type + parameters_value_type = transform_type.parametersValueType + if transform_dict["fixedParameters"] is not None: + transform_dict["fixedParameters"] = buffer_to_numpy_array( + parameters_value_type, transform_dict["fixedParameters"] + ) + if transform_dict["parameters"] is not None: + transform_dict["parameters"] = buffer_to_numpy_array( + parameters_value_type, transform_dict["parameters"] + ) + return Transform(**transform_dict) elif hasattr(js_proxy, "path") and hasattr(js_proxy, "data") and isinstance(js_proxy.data, str): with open(js_proxy.path, "w") as fp: fp.write(js_proxy.data) @@ -222,6 +237,13 @@ def to_js(py, **kwargs): if polydata_dict["cellData"] is not None: polydata_dict["cellData"] = polydata_dict["cellData"].ravel() return pyodide.ffi.to_js(polydata_dict, dict_converter=js.Object.fromEntries) + elif isinstance(py, Transform): + transform_dict = asdict(py) + if transform_dict["fixedParameters"] is not None: + transform_dict["fixedParameters"] = transform_dict["fixedParameters"].ravel() + if transform_dict["parameters"] is not None: + transform_dict["parameters"] = transform_dict["parameters"].ravel() + return pyodide.ffi.to_js(transform_dict, dict_converter=js.Object.fromEntries) elif isinstance(py, TextStream): text_stream_dict = asdict(py) return pyodide.ffi.to_js(text_stream_dict, dict_converter=js.Object.fromEntries) diff --git a/packages/core/python/itkwasm/itkwasm/transform.py b/packages/core/python/itkwasm/itkwasm/transform.py index 62b7ea645..41ad18a87 100644 --- a/packages/core/python/itkwasm/itkwasm/transform.py +++ b/packages/core/python/itkwasm/itkwasm/transform.py @@ -8,6 +8,8 @@ from numpy import ndarray as ArrayLike import numpy as np +from .float_types import FloatTypes + class TransformParameterizations(str, Enum): Composite = "Composite" Identity = "Identity" @@ -40,9 +42,10 @@ class TransformParameterizations(str, Enum): @dataclass class TransformType: + transformParameterization: TransformParameterizations = TransformParameterizations.Identity + parametersValueType: FloatTypes = FloatTypes.Float64 inputDimension: int = 3 outputDimension: int = 3 - transformParameterization: TransformParameterizations = TransformParameterizations.Identity @dataclass class Transform: diff --git a/packages/core/python/itkwasm/pixi.lock b/packages/core/python/itkwasm/pixi.lock index ddf883db9..f93694185 100644 --- a/packages/core/python/itkwasm/pixi.lock +++ b/packages/core/python/itkwasm/pixi.lock @@ -125,7 +125,7 @@ environments: - pypi: https://files.pythonhosted.org/packages/3c/83/ec3196c360afffbc5b342ead48d1eb7393dd74fa70bca75d33905a86f211/trio-0.27.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/48/be/a9ae5f50cad5b6f85bd2574c2c923730098530096e170c1ce7452394d7aa/trio_websocket-0.11.1-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/ce/d9/5f4c13cecde62396b0d3fe530a50ccea91e7dfc1ccf0e09c228841bb5ba8/urllib3-2.2.3-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/5c/ba/f551b829378d65d0e0494fdb492942a0ed2dc7f40681b2438a47d1f4af86/wasmtime-25.0.0-py3-none-manylinux1_x86_64.whl + - pypi: https://files.pythonhosted.org/packages/5e/24/806c5bd1b5e30c83cc9d182795edebfbfe24483f82fb18823b309a6656b5/wasmtime-27.0.1-py3-none-manylinux1_x86_64.whl - pypi: https://files.pythonhosted.org/packages/5a/84/44687a29792a70e111c5c477230a72c4b957d88d16141199bf9acb7537a3/websocket_client-1.8.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/78/58/e860788190eba3bcce367f74d29c4675466ce8dddfba85f7827588416f01/wsproto-1.2.0-py3-none-any.whl - pypi: . @@ -248,7 +248,7 @@ environments: - pypi: https://files.pythonhosted.org/packages/3c/83/ec3196c360afffbc5b342ead48d1eb7393dd74fa70bca75d33905a86f211/trio-0.27.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/48/be/a9ae5f50cad5b6f85bd2574c2c923730098530096e170c1ce7452394d7aa/trio_websocket-0.11.1-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/ce/d9/5f4c13cecde62396b0d3fe530a50ccea91e7dfc1ccf0e09c228841bb5ba8/urllib3-2.2.3-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/b7/36/5e83b5f7858fe1003cbb89d0d5716f628b9a00fafc3762665f06ca4ef75d/wasmtime-25.0.0-py3-none-manylinux2014_aarch64.whl + - pypi: https://files.pythonhosted.org/packages/3a/57/cd877b4797be239b4433f89a5a85c7bf2c5319dd91c7777b1867bebb664e/wasmtime-27.0.1-py3-none-manylinux2014_aarch64.whl - pypi: https://files.pythonhosted.org/packages/5a/84/44687a29792a70e111c5c477230a72c4b957d88d16141199bf9acb7537a3/websocket_client-1.8.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/78/58/e860788190eba3bcce367f74d29c4675466ce8dddfba85f7827588416f01/wsproto-1.2.0-py3-none-any.whl - pypi: . @@ -356,7 +356,7 @@ environments: - pypi: https://files.pythonhosted.org/packages/3c/83/ec3196c360afffbc5b342ead48d1eb7393dd74fa70bca75d33905a86f211/trio-0.27.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/48/be/a9ae5f50cad5b6f85bd2574c2c923730098530096e170c1ce7452394d7aa/trio_websocket-0.11.1-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/ce/d9/5f4c13cecde62396b0d3fe530a50ccea91e7dfc1ccf0e09c228841bb5ba8/urllib3-2.2.3-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/cc/f0/d415d6b31ba69cfca04b2d5e83fbb5fc05335323712fd91948a1a53d13be/wasmtime-25.0.0-py3-none-macosx_11_0_arm64.whl + - pypi: https://files.pythonhosted.org/packages/6e/d8/38d1af31c1787e09642354c81215920a5bf59722a6786ed7e9622fd1f033/wasmtime-27.0.1-py3-none-macosx_11_0_arm64.whl - pypi: https://files.pythonhosted.org/packages/5a/84/44687a29792a70e111c5c477230a72c4b957d88d16141199bf9acb7537a3/websocket_client-1.8.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/78/58/e860788190eba3bcce367f74d29c4675466ce8dddfba85f7827588416f01/wsproto-1.2.0-py3-none-any.whl - pypi: . @@ -466,7 +466,7 @@ environments: - pypi: https://files.pythonhosted.org/packages/3c/83/ec3196c360afffbc5b342ead48d1eb7393dd74fa70bca75d33905a86f211/trio-0.27.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/48/be/a9ae5f50cad5b6f85bd2574c2c923730098530096e170c1ce7452394d7aa/trio_websocket-0.11.1-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/ce/d9/5f4c13cecde62396b0d3fe530a50ccea91e7dfc1ccf0e09c228841bb5ba8/urllib3-2.2.3-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/1b/21/c0f3e031efe5f009215975eb7dbea86b55a69c4f02420965d1f45f43865e/wasmtime-25.0.0-py3-none-win_amd64.whl + - pypi: https://files.pythonhosted.org/packages/14/6f/f6b99d9ab1511398686e00d2a26371d99a7949531514379d731b3b7e6309/wasmtime-27.0.1-py3-none-win_amd64.whl - pypi: https://files.pythonhosted.org/packages/5a/84/44687a29792a70e111c5c477230a72c4b957d88d16141199bf9acb7537a3/websocket_client-1.8.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/78/58/e860788190eba3bcce367f74d29c4675466ce8dddfba85f7827588416f01/wsproto-1.2.0-py3-none-any.whl - pypi: . @@ -968,7 +968,7 @@ packages: - lz4>=4.3.2 ; extra == 'complete' - dask[array] ; extra == 'dataframe' - pandas>=2.0 ; extra == 'dataframe' - - dask-expr<1.2,>=1.1 ; extra == 'dataframe' + - dask-expr>=1.1,<1.2 ; extra == 'dataframe' - bokeh>=3.1.0 ; extra == 'diagnostics' - jinja2>=2.10.3 ; extra == 'diagnostics' - distributed==2024.11.2 ; extra == 'distributed' @@ -1178,10 +1178,10 @@ packages: - pytest-recording ; extra == 'test' - pytest-rerunfailures ; extra == 'test' - requests ; extra == 'test' - - aiobotocore<3.0.0,>=2.5.4 ; extra == 'test-downstream' + - aiobotocore>=2.5.4,<3.0.0 ; extra == 'test-downstream' - dask-expr ; extra == 'test-downstream' - dask[dataframe,test] ; extra == 'test-downstream' - - moto[server]<5,>4 ; extra == 'test-downstream' + - moto[server]>4,<5 ; extra == 'test-downstream' - pytest-timeout ; extra == 'test-downstream' - xarray ; extra == 'test-downstream' - adlfs ; extra == 'test-full' @@ -1466,7 +1466,7 @@ packages: sha256: 77ff76a995ef40999b96e70abb6ab839d077df2f6127230f36bf9ed24c67473b requires_dist: - attrs>=22.2.0 - - sortedcontainers<3.0.0,>=2.1.0 + - sortedcontainers>=2.1.0,<3.0.0 - exceptiongroup>=1.0.0 ; python_full_version < '3.11' - black>=19.10b0 ; extra == 'all' - click>=7.0 ; extra == 'all' @@ -1824,16 +1824,15 @@ packages: requires_python: '>=3.8' - kind: pypi name: itkwasm - version: 1.0b180 + version: 1.0b183 path: . - sha256: 9d34d23674f0f764ee29b9f6365bf02c13ff249a1a5973ed0253ea3c84814a2a + sha256: f3a2be453630d9e7826f816563f455d922f50f6965deb35e0716814db9270165 requires_dist: - - dask[array]<2025,>=2024.11.2 - importlib-metadata ; python_full_version < '3.10' - numpy - platformdirs ; sys_platform != 'emscripten' - typing-extensions - - wasmtime>=13.0.2 ; sys_platform != 'emscripten' + - wasmtime>=27.0.1 ; sys_platform != 'emscripten' requires_python: '>=3.9' editable: true - kind: conda @@ -3147,7 +3146,7 @@ packages: url: https://files.pythonhosted.org/packages/96/31/6607dab48616902f76885dfcf62c08d929796fc3b2d2318faf9fd54dbed9/pytest_asyncio-0.24.0-py3-none-any.whl sha256: a811296ed596b69bf0b6f3dc40f83bcaf341b155a269052d82efa2b25ac7037b requires_dist: - - pytest<9,>=8.2 + - pytest>=8.2,<9 - sphinx>=5.3 ; extra == 'docs' - sphinx-rtd-theme>=1.0 ; extra == 'docs' - coverage>=6.2 ; extra == 'testing' @@ -3790,8 +3789,8 @@ packages: requires_dist: - brotli>=1.0.9 ; platform_python_implementation == 'CPython' and extra == 'brotli' - brotlicffi>=0.8.0 ; platform_python_implementation != 'CPython' and extra == 'brotli' - - h2<5,>=4 ; extra == 'h2' - - pysocks!=1.5.7,<2.0,>=1.5.6 ; extra == 'socks' + - h2>=4,<5 ; extra == 'h2' + - pysocks>=1.5.6,!=1.5.7,<2.0 ; extra == 'socks' - zstandard>=0.18.0 ; extra == 'zstd' requires_python: '>=3.8' - kind: conda @@ -3954,9 +3953,9 @@ packages: timestamp: 1728400827536 - kind: pypi name: wasmtime - version: 25.0.0 - url: https://files.pythonhosted.org/packages/1b/21/c0f3e031efe5f009215975eb7dbea86b55a69c4f02420965d1f45f43865e/wasmtime-25.0.0-py3-none-win_amd64.whl - sha256: f8a2a213b9179965db2d2eedececd69a37e287e902330509afae51c71a3a6842 + version: 27.0.1 + url: https://files.pythonhosted.org/packages/14/6f/f6b99d9ab1511398686e00d2a26371d99a7949531514379d731b3b7e6309/wasmtime-27.0.1-py3-none-win_amd64.whl + sha256: e691aafe8881a872a69a52822f24c209f54fe6f06154d1dfadd977ee86374169 requires_dist: - importlib-resources>=5.10 - coverage ; extra == 'testing' @@ -3964,12 +3963,12 @@ packages: - pycparser ; extra == 'testing' - pytest-mypy ; extra == 'testing' - componentize-py ; extra == 'testing' - requires_python: '>=3.8' + requires_python: '>=3.9' - kind: pypi name: wasmtime - version: 25.0.0 - url: https://files.pythonhosted.org/packages/5c/ba/f551b829378d65d0e0494fdb492942a0ed2dc7f40681b2438a47d1f4af86/wasmtime-25.0.0-py3-none-manylinux1_x86_64.whl - sha256: b4364e14d44e3b7afe6a40bf608e9d0d2c40b09dece441d20f4f6e31906b729c + version: 27.0.1 + url: https://files.pythonhosted.org/packages/3a/57/cd877b4797be239b4433f89a5a85c7bf2c5319dd91c7777b1867bebb664e/wasmtime-27.0.1-py3-none-manylinux2014_aarch64.whl + sha256: dac4e2232cc44b6bfc290f84ff9244621b7e99ee1da4036afb83113dd93b13bf requires_dist: - importlib-resources>=5.10 - coverage ; extra == 'testing' @@ -3977,12 +3976,12 @@ packages: - pycparser ; extra == 'testing' - pytest-mypy ; extra == 'testing' - componentize-py ; extra == 'testing' - requires_python: '>=3.8' + requires_python: '>=3.9' - kind: pypi name: wasmtime - version: 25.0.0 - url: https://files.pythonhosted.org/packages/b7/36/5e83b5f7858fe1003cbb89d0d5716f628b9a00fafc3762665f06ca4ef75d/wasmtime-25.0.0-py3-none-manylinux2014_aarch64.whl - sha256: a07445073cf36a6e5d1dc28246a897dcbdaa537ba8be8805be65422ecca297eb + version: 27.0.1 + url: https://files.pythonhosted.org/packages/5e/24/806c5bd1b5e30c83cc9d182795edebfbfe24483f82fb18823b309a6656b5/wasmtime-27.0.1-py3-none-manylinux1_x86_64.whl + sha256: 99339ed56b7bc4d280bcb0d5527725a7cfe51c269941cf888f57b46f05c249a6 requires_dist: - importlib-resources>=5.10 - coverage ; extra == 'testing' @@ -3990,12 +3989,12 @@ packages: - pycparser ; extra == 'testing' - pytest-mypy ; extra == 'testing' - componentize-py ; extra == 'testing' - requires_python: '>=3.8' + requires_python: '>=3.9' - kind: pypi name: wasmtime - version: 25.0.0 - url: https://files.pythonhosted.org/packages/cc/f0/d415d6b31ba69cfca04b2d5e83fbb5fc05335323712fd91948a1a53d13be/wasmtime-25.0.0-py3-none-macosx_11_0_arm64.whl - sha256: 5bdf1214ee3ee78a4a8a92da339f4c4c8c109e65af881b37f4adfc05d02af426 + version: 27.0.1 + url: https://files.pythonhosted.org/packages/6e/d8/38d1af31c1787e09642354c81215920a5bf59722a6786ed7e9622fd1f033/wasmtime-27.0.1-py3-none-macosx_11_0_arm64.whl + sha256: 1082442529d06c5c50fb9377dbb599460c175f98ca0d332625bf76661c7309b4 requires_dist: - importlib-resources>=5.10 - coverage ; extra == 'testing' @@ -4003,7 +4002,7 @@ packages: - pycparser ; extra == 'testing' - pytest-mypy ; extra == 'testing' - componentize-py ; extra == 'testing' - requires_python: '>=3.8' + requires_python: '>=3.9' - kind: pypi name: websocket-client version: 1.8.0 @@ -4023,7 +4022,7 @@ packages: url: https://files.pythonhosted.org/packages/78/58/e860788190eba3bcce367f74d29c4675466ce8dddfba85f7827588416f01/wsproto-1.2.0-py3-none-any.whl sha256: b9acddd652b585d75b20477888c56642fdade28bdfd3579aa24a4d2c037dd736 requires_dist: - - h11<1,>=0.9.0 + - h11>=0.9.0,<1 requires_python: '>=3.7.0' - kind: conda name: xz diff --git a/packages/core/python/itkwasm/pyproject.toml b/packages/core/python/itkwasm/pyproject.toml index 9adf2c4e6..d35a961b4 100644 --- a/packages/core/python/itkwasm/pyproject.toml +++ b/packages/core/python/itkwasm/pyproject.toml @@ -33,8 +33,8 @@ dependencies = [ "numpy", "typing_extensions", "platformdirs; sys_platform != \"emscripten\"", - "wasmtime >= 13.0.2; sys_platform != \"emscripten\"", - "importlib_metadata; python_version < \"3.10\"", "dask[array]>=2024.11.2,<2025", + "wasmtime >= 27.0.1; sys_platform != \"emscripten\"", + "importlib_metadata; python_version < \"3.10\"", ] [project.urls] @@ -64,6 +64,7 @@ pyodide-py = ">=0.26.3, <0.27" pytest-pyodide = ">=0.58.3, <0.59" itk = ">=5.4.0" test_accelerator = { path = "test/test-accelerator", editable = true } +dask = { extras = ["array"], version = ">=2024.11.2,<2025" } [tool.pixi.tasks.build] cmd = "hatch build" diff --git a/packages/core/python/itkwasm/test/input/LinearTransform.h5 b/packages/core/python/itkwasm/test/input/LinearTransform.h5 new file mode 100644 index 000000000..aa1d99f26 Binary files /dev/null and b/packages/core/python/itkwasm/test/input/LinearTransform.h5 differ diff --git a/packages/core/python/itkwasm/test/input/transform-read-write-test.wasi.wasm b/packages/core/python/itkwasm/test/input/transform-read-write-test.wasi.wasm new file mode 100755 index 000000000..2e5d2d4fd Binary files /dev/null and b/packages/core/python/itkwasm/test/input/transform-read-write-test.wasi.wasm differ diff --git a/packages/core/python/itkwasm/test/test_pipeline.py b/packages/core/python/itkwasm/test/test_pipeline.py index ace299c01..e92867ce7 100644 --- a/packages/core/python/itkwasm/test/test_pipeline.py +++ b/packages/core/python/itkwasm/test/test_pipeline.py @@ -19,6 +19,10 @@ BinaryFile, Image, Mesh, + Transform, + TransformList, + TransformParameterizations, + FloatTypes, ) test_input_dir = Path(__file__).resolve().parent / "input" @@ -297,3 +301,41 @@ def test_pipeline_write_read_polydata(): assert out_mesh.GetNumberOfPoints() == 2903 assert out_mesh.GetNumberOfCells() == 3263 + +def test_pipeline_write_read_transform(): + pipeline = Pipeline(test_input_dir / "transform-read-write-test.wasi.wasm") + + data = test_input_dir / "LinearTransform.h5" + itk_transform = itk.transformread(data) + itk_transform_list = itk.dict_from_transform(itk_transform) + itkwasm_transform_list = [Transform(**t) for t in itk_transform_list] + + pipeline_inputs = [ + PipelineInput(InterfaceTypes.TransformList, itkwasm_transform_list), + ] + + pipeline_outputs = [ + PipelineOutput(InterfaceTypes.TransformList), + ] + + args = [ + "--memory-io", + "0", + "0", + ] + + outputs = pipeline.run(args, pipeline_outputs, pipeline_inputs) + transform_list = outputs[0].data + + assert len(transform_list) == 1 + transform = transform_list[0] + assert transform.transformType.transformParameterization == TransformParameterizations.Affine + assert transform.transformType.parametersValueType == FloatTypes.Float64 + assert transform.numberOfParameters == 12 + assert transform.numberOfFixedParameters == 3 + np.testing.assert_allclose(transform.fixedParameters, np.array([0.0, 0.0, 0.0])) + np.testing.assert_allclose(transform.parameters, np.array([ + 0.65631490118447, 0.5806583745824385, -0.4817536741017158, + -0.7407986817430222, 0.37486398378429736, -0.5573995934598175, + -0.14306664045479867, 0.7227121458012518, 0.676179776908723, + -65.99999999999997, 69.00000000000004, 32.000000000000036])) \ No newline at end of file diff --git a/packages/core/python/itkwasm/test/test_pyodide.py b/packages/core/python/itkwasm/test/test_pyodide.py index 017748321..e1e851fe5 100644 --- a/packages/core/python/itkwasm/test/test_pyodide.py +++ b/packages/core/python/itkwasm/test/test_pyodide.py @@ -198,6 +198,41 @@ async def test_polydata_conversion(selenium, package_wheel): assert polydata.numberOfPointPixels == polydata_py.numberOfPointPixels assert np.array_equal(polydata.pointData, polydata_py.pointData) +@run_in_pyodide(packages=["micropip", "numpy"]) +async def test_transform_conversion(selenium, package_wheel): + import micropip + + await micropip.install(package_wheel) + + from itkwasm import Transform, TransformType, TransformParameterizations + from itkwasm.pyodide import to_js, to_py + import numpy as np + + dimension = 3 + transform_type = TransformType(TransformParameterizations.Affine) + fixed_parameters = np.array([0.0, 0.0, 0.0]).astype(np.float64) + parameters = np.array([ + 0.65631490118447, 0.5806583745824385, -0.4817536741017158, + -0.7407986817430222, 0.37486398378429736, -0.5573995934598175, + -0.14306664045479867, 0.7227121458012518, 0.676179776908723, + -65.99999999999997, 69.00000000000004, 32.000000000000036]).astype(np.float64) + transform = Transform(transform_type, dimension, 12, fixedParameters=fixed_parameters, parameters=parameters) + transform_list = [transform,] + + transform_list_js = to_js(transform_list) + transform_list_py = to_py(transform_list_js) + + transform_py = transform_list_py[0] + assert transform_py.transformType.transformParameterization == TransformParameterizations.Affine + assert transform_py.numberOfParameters == 12 + assert transform_py.numberOfFixedParameters == 3 + np.testing.assert_allclose(transform_py.fixedParameters, np.array([0.0, 0.0, 0.0])) + np.testing.assert_allclose(transform_py.parameters, np.array([ + 0.65631490118447, 0.5806583745824385, -0.4817536741017158, + -0.7407986817430222, 0.37486398378429736, -0.5573995934598175, + -0.14306664045479867, 0.7227121458012518, 0.676179776908723, + -65.99999999999997, 69.00000000000004, 32.000000000000036])) + print('transform_py', transform_py) @run_in_pyodide(packages=["micropip", "numpy"]) async def test_binary_stream_conversion(selenium, package_wheel): diff --git a/packages/core/typescript/itk-wasm/src/bindgen/python/resources/template.pyproject.toml b/packages/core/typescript/itk-wasm/src/bindgen/python/resources/template.pyproject.toml index 99336c99b..674c57547 100644 --- a/packages/core/typescript/itk-wasm/src/bindgen/python/resources/template.pyproject.toml +++ b/packages/core/typescript/itk-wasm/src/bindgen/python/resources/template.pyproject.toml @@ -19,11 +19,11 @@ classifiers = [ "Intended Audience :: Developers", "Intended Audience :: Science/Research", "Programming Language :: Python :: 3", - "Programming Language :: Python :: 3.8", "Programming Language :: Python :: 3.9", "Programming Language :: Python :: 3.10", "Programming Language :: Python :: 3.11", "Programming Language :: Python :: 3.12", + "Programming Language :: Python :: 3.13", ] keywords = [ "itkwasm", @@ -32,7 +32,7 @@ keywords = [ requires-python = ">=3.8" dependencies = [ - "itkwasm >= 1.0.b171",@bindgenDependencies@ + "itkwasm >= 1.0.b184",@bindgenDependencies@ ] [tool.hatch.version] diff --git a/packages/image-io/pixi.toml b/packages/image-io/pixi.toml index e40eed57c..beb414424 100644 --- a/packages/image-io/pixi.toml +++ b/packages/image-io/pixi.toml @@ -85,6 +85,7 @@ pyodide-py = ">=0.26.3, <0.27" pytest-pyodide = ">=0.58.3, <0.59" itk-webassemblyinterface = ">=1.0b175, <2" itkwasm = ">=1.0b179, <2" +itkwasm-image-io-wasi = { path = "python/itkwasm-image-io-wasi", editable = true } [feature.python.tasks.test-wasi] cmd = "pytest" diff --git a/packages/mesh-io/pixi.toml b/packages/mesh-io/pixi.toml index 21d11abaa..77b297e2a 100644 --- a/packages/mesh-io/pixi.toml +++ b/packages/mesh-io/pixi.toml @@ -85,6 +85,7 @@ pyodide-py = ">=0.26.3, <0.27" pytest-pyodide = ">=0.58.3, <0.59" itk-webassemblyinterface = ">=1.0b175, <2" itkwasm = ">=1.0b179, <2" +itkwasm-mesh-io-wasi = { path = "python/itkwasm-mesh-io-wasi", editable = true } [feature.python.tasks.test-wasi] cmd = "pytest" diff --git a/packages/transform-io/.gitignore b/packages/transform-io/.gitignore index 201ef91f3..ad23cb0ad 100644 --- a/packages/transform-io/.gitignore +++ b/packages/transform-io/.gitignore @@ -4,3 +4,6 @@ wasi-build/ typescript/dist typescript/src/version.ts pyodide/ +python/itkwasm-transform-io-emscripten/dist/ +python/itkwasm-transform-io-wasi/dist/ +python/itkwasm-transform-io/dist/ diff --git a/packages/transform-io/pixi.lock b/packages/transform-io/pixi.lock index 5ef57aa47..3c49798b0 100644 --- a/packages/transform-io/pixi.lock +++ b/packages/transform-io/pixi.lock @@ -472,9 +472,6 @@ environments: - conda: https://conda.anaconda.org/conda-forge/linux-64/zstandard-0.23.0-py312hef9b889_1.conda - conda: https://conda.anaconda.org/conda-forge/linux-64/zstd-1.5.6-ha6fb4c9_0.conda - pypi: https://files.pythonhosted.org/packages/6a/21/5b6702a7f963e95456c0de2d495f67bf5fd62840ac655dc451586d23d39a/attrs-24.2.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/48/41/e1d85ca3cab0b674e277c8c4f678cf66a91cd2cecf93df94353a606fe0db/cloudpickle-3.1.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/2a/72/33ff765a07913cb5061baa94718f3a17003aa29adc89642a68c295d47582/dask-2024.11.2-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/c6/b2/454d6e7f0158951d8a78c2e1eb4f69ae81beb8dca5fee9809c6c99e9d0d0/fsspec-2024.10.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/f1/66/033e58a50fd9ec9df00a8671c74f1f3a320564c6415a4ed82a1c651654ba/greenlet-3.1.1-cp312-cp312-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl - pypi: https://files.pythonhosted.org/packages/13/0e/3f934459c4aab461281ad24b01de08bd612118fbc70ecc7b0fa5ed156a94/hypothesis-6.115.6-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/7e/14/577a2a26c81ab6e2db821d7a5da3c6ff8dbf27ab3d8ebe74a3d4f203ab38/itk-5.4.0-cp311-abi3-manylinux_2_28_x86_64.whl @@ -486,28 +483,25 @@ environments: - pypi: https://files.pythonhosted.org/packages/dc/58/ec1bf790ed9657fd8a651189d40eedd765bf1cd75355ffa3f8f9bd67f4df/itk_registration-5.4.0-cp311-abi3-manylinux_2_28_x86_64.whl - pypi: https://files.pythonhosted.org/packages/1a/e5/94a596fba3dbecdea33059b455294fbfea91fcfc0d6cfd92372e10a6da93/itk_segmentation-5.4.0-cp311-abi3-manylinux_2_28_x86_64.whl - pypi: https://files.pythonhosted.org/packages/a6/3c/ac3bad4ff24fe2b07064be5e44db8f4ed32a4e3708dff084e3b58c5b608c/itk_webassemblyinterface-1.0b175-cp311-abi3-manylinux_2_28_x86_64.whl - - pypi: https://files.pythonhosted.org/packages/bd/a5/329525eeaf0ac895a37b0a498b311e6d2991d47c827804908a815ae088f3/itkwasm-1.0b180-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/db/bc/83e112abc66cd466c6b83f99118035867cecd41802f8d044638aa78a106e/locket-1.0.0-py2.py3-none-any.whl + - pypi: https://files.pythonhosted.org/packages/bc/f3/db24f14dfed1f631e4568440542dce7330b1c17a5c098666164872db4404/itkwasm-1.0b185-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/9b/b4/e3c7e6fab0f77fff6194afa173d1f2342073d91b1d3b4b30b17c3fb4407a/numpy-2.1.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl - pypi: https://files.pythonhosted.org/packages/55/8b/5ab7257531a5d830fc8000c476e63c935488d74609b50f9384a643ec0a62/outcome-1.3.0.post0-py2.py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/71/e7/40fb618334dcdf7c5a316c0e7343c5cd82d3d866edc100d98e29bc945ecd/partd-1.4.2-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/f9/0c/8cde1a86a9a7449a0ba95197f42156198083be1749b717831fba16ab2b5f/playwright-1.48.0-py3-none-manylinux1_x86_64.whl - pypi: https://files.pythonhosted.org/packages/1d/0d/95993c08c721ec68892547f2117e8f9dfbcef2ca71e098533541b4a54d5f/pyee-12.0.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/6f/ec/70457045923b005761b19f78b85b467a64808e886c10c449f7758a1ba5f7/pyodide_py-0.26.3-py3-none-any.whl + - pypi: https://files.pythonhosted.org/packages/2e/4a/970d2604a72e9d44904533b5438135187aa3b08b8d6fc75e5404cd8a1dd1/pyodide_py-0.26.4-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/8d/59/b4572118e098ac8e46e399a1dd0f2d85403ce8bbaad9ec79373ed6badaf9/PySocks-1.7.1-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/96/31/6607dab48616902f76885dfcf62c08d929796fc3b2d2318faf9fd54dbed9/pytest_asyncio-0.24.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/cd/98/7a2d160bd1a997c6fc422647ccf907fcc1b14b8e4a89790fa1427b8f4d16/pytest_pyodide-0.58.3-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/b9/2b/614b4752f2e127db5cc206abc23a8c19678e92b23c3db30fc86ab731d3bd/PyYAML-6.0.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl - pypi: https://files.pythonhosted.org/packages/aa/85/fa44f23dd5d5066a72f7c4304cce4b5ff9a6e7fd92431a48b2c63fbf63ec/selenium-4.25.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/32/46/9cb0e58b2deb7f82b84065f37f3bffeb12413f947f9388e4cac22c4621ce/sortedcontainers-2.4.0-py2.py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/9b/87/ce70db7cae60e67851eb94e1a2127d4abb573d3866d2efd302ceb0d4d2a5/tblib-3.0.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/03/98/eb27cc78ad3af8e302c9d8ff4977f5026676e130d28dd7578132a457170c/toolz-1.0.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/3c/83/ec3196c360afffbc5b342ead48d1eb7393dd74fa70bca75d33905a86f211/trio-0.27.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/48/be/a9ae5f50cad5b6f85bd2574c2c923730098530096e170c1ce7452394d7aa/trio_websocket-0.11.1-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/ce/d9/5f4c13cecde62396b0d3fe530a50ccea91e7dfc1ccf0e09c228841bb5ba8/urllib3-2.2.3-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/5c/ba/f551b829378d65d0e0494fdb492942a0ed2dc7f40681b2438a47d1f4af86/wasmtime-25.0.0-py3-none-manylinux1_x86_64.whl + - pypi: https://files.pythonhosted.org/packages/5e/24/806c5bd1b5e30c83cc9d182795edebfbfe24483f82fb18823b309a6656b5/wasmtime-27.0.1-py3-none-manylinux1_x86_64.whl - pypi: https://files.pythonhosted.org/packages/5a/84/44687a29792a70e111c5c477230a72c4b957d88d16141199bf9acb7537a3/websocket_client-1.8.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/78/58/e860788190eba3bcce367f74d29c4675466ce8dddfba85f7827588416f01/wsproto-1.2.0-py3-none-any.whl + - pypi: python/itkwasm-transform-io-wasi linux-aarch64: - conda: https://conda.anaconda.org/conda-forge/linux-aarch64/_openmp_mutex-4.5-2_gnu.tar.bz2 - conda: https://conda.anaconda.org/conda-forge/noarch/anyio-4.6.2.post1-pyhd8ed1ab_0.conda @@ -620,9 +614,6 @@ environments: - conda: https://conda.anaconda.org/conda-forge/linux-aarch64/zstandard-0.23.0-py312hb698573_1.conda - conda: https://conda.anaconda.org/conda-forge/linux-aarch64/zstd-1.5.6-h02f22dd_0.conda - pypi: https://files.pythonhosted.org/packages/6a/21/5b6702a7f963e95456c0de2d495f67bf5fd62840ac655dc451586d23d39a/attrs-24.2.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/48/41/e1d85ca3cab0b674e277c8c4f678cf66a91cd2cecf93df94353a606fe0db/cloudpickle-3.1.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/2a/72/33ff765a07913cb5061baa94718f3a17003aa29adc89642a68c295d47582/dask-2024.11.2-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/c6/b2/454d6e7f0158951d8a78c2e1eb4f69ae81beb8dca5fee9809c6c99e9d0d0/fsspec-2024.10.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/66/d4/c8c04958870f482459ab5956c2942c4ec35cac7fe245527f1039837c17a9/greenlet-3.1.1-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl - pypi: https://files.pythonhosted.org/packages/13/0e/3f934459c4aab461281ad24b01de08bd612118fbc70ecc7b0fa5ed156a94/hypothesis-6.115.6-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/8a/a0/732ddb5575a5be47d1088def8b1db91c799263a8d583181341271a4f6e6d/itk-5.4.0-cp311-abi3-manylinux_2_28_aarch64.whl @@ -634,28 +625,25 @@ environments: - pypi: https://files.pythonhosted.org/packages/e7/f0/a21ddf56263ad6c5f87164032aaeb2235ee2de688cb8a8eeec01a5f01bd7/itk_registration-5.4.0-cp311-abi3-manylinux_2_28_aarch64.whl - pypi: https://files.pythonhosted.org/packages/79/b9/ba9598bb8b7ee3962980d481065a58f75569c5a2df1d01520083288894b0/itk_segmentation-5.4.0-cp311-abi3-manylinux_2_28_aarch64.whl - pypi: https://files.pythonhosted.org/packages/f2/f5/cd8ed297bd1b9f816d7492bfa857c53bd8fd68aefc2aa9bef7a0d5a61d85/itk_webassemblyinterface-1.0b175-cp311-abi3-manylinux_2_28_aarch64.whl - - pypi: https://files.pythonhosted.org/packages/bd/a5/329525eeaf0ac895a37b0a498b311e6d2991d47c827804908a815ae088f3/itkwasm-1.0b180-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/db/bc/83e112abc66cd466c6b83f99118035867cecd41802f8d044638aa78a106e/locket-1.0.0-py2.py3-none-any.whl + - pypi: https://files.pythonhosted.org/packages/bc/f3/db24f14dfed1f631e4568440542dce7330b1c17a5c098666164872db4404/itkwasm-1.0b185-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/c4/a7/af3329fda3c3ec31d9b650e42bbcd3422fc62a765cbb1405fde4177a0996/numpy-2.1.2-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl - pypi: https://files.pythonhosted.org/packages/55/8b/5ab7257531a5d830fc8000c476e63c935488d74609b50f9384a643ec0a62/outcome-1.3.0.post0-py2.py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/71/e7/40fb618334dcdf7c5a316c0e7343c5cd82d3d866edc100d98e29bc945ecd/partd-1.4.2-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/31/dc/121be574222fc74d12ac42921728fb6ba8ac17264a1fdab1993263389082/playwright-1.48.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl - pypi: https://files.pythonhosted.org/packages/1d/0d/95993c08c721ec68892547f2117e8f9dfbcef2ca71e098533541b4a54d5f/pyee-12.0.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/6f/ec/70457045923b005761b19f78b85b467a64808e886c10c449f7758a1ba5f7/pyodide_py-0.26.3-py3-none-any.whl + - pypi: https://files.pythonhosted.org/packages/2e/4a/970d2604a72e9d44904533b5438135187aa3b08b8d6fc75e5404cd8a1dd1/pyodide_py-0.26.4-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/8d/59/b4572118e098ac8e46e399a1dd0f2d85403ce8bbaad9ec79373ed6badaf9/PySocks-1.7.1-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/96/31/6607dab48616902f76885dfcf62c08d929796fc3b2d2318faf9fd54dbed9/pytest_asyncio-0.24.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/cd/98/7a2d160bd1a997c6fc422647ccf907fcc1b14b8e4a89790fa1427b8f4d16/pytest_pyodide-0.58.3-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/c3/93/9916574aa8c00aa06bbac729972eb1071d002b8e158bd0e83a3b9a20a1f7/PyYAML-6.0.2-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl - pypi: https://files.pythonhosted.org/packages/aa/85/fa44f23dd5d5066a72f7c4304cce4b5ff9a6e7fd92431a48b2c63fbf63ec/selenium-4.25.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/32/46/9cb0e58b2deb7f82b84065f37f3bffeb12413f947f9388e4cac22c4621ce/sortedcontainers-2.4.0-py2.py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/9b/87/ce70db7cae60e67851eb94e1a2127d4abb573d3866d2efd302ceb0d4d2a5/tblib-3.0.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/03/98/eb27cc78ad3af8e302c9d8ff4977f5026676e130d28dd7578132a457170c/toolz-1.0.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/3c/83/ec3196c360afffbc5b342ead48d1eb7393dd74fa70bca75d33905a86f211/trio-0.27.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/48/be/a9ae5f50cad5b6f85bd2574c2c923730098530096e170c1ce7452394d7aa/trio_websocket-0.11.1-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/ce/d9/5f4c13cecde62396b0d3fe530a50ccea91e7dfc1ccf0e09c228841bb5ba8/urllib3-2.2.3-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/b7/36/5e83b5f7858fe1003cbb89d0d5716f628b9a00fafc3762665f06ca4ef75d/wasmtime-25.0.0-py3-none-manylinux2014_aarch64.whl + - pypi: https://files.pythonhosted.org/packages/3a/57/cd877b4797be239b4433f89a5a85c7bf2c5319dd91c7777b1867bebb664e/wasmtime-27.0.1-py3-none-manylinux2014_aarch64.whl - pypi: https://files.pythonhosted.org/packages/5a/84/44687a29792a70e111c5c477230a72c4b957d88d16141199bf9acb7537a3/websocket_client-1.8.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/78/58/e860788190eba3bcce367f74d29c4675466ce8dddfba85f7827588416f01/wsproto-1.2.0-py3-none-any.whl + - pypi: python/itkwasm-transform-io-wasi osx-arm64: - conda: https://conda.anaconda.org/conda-forge/noarch/anyio-4.6.2.post1-pyhd8ed1ab_0.conda - conda: https://conda.anaconda.org/conda-forge/noarch/backports-1.0-pyhd8ed1ab_4.conda @@ -751,9 +739,6 @@ environments: - conda: https://conda.anaconda.org/conda-forge/osx-arm64/zstandard-0.23.0-py312h15fbf35_1.conda - conda: https://conda.anaconda.org/conda-forge/osx-arm64/zstd-1.5.6-hb46c0d2_0.conda - pypi: https://files.pythonhosted.org/packages/6a/21/5b6702a7f963e95456c0de2d495f67bf5fd62840ac655dc451586d23d39a/attrs-24.2.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/48/41/e1d85ca3cab0b674e277c8c4f678cf66a91cd2cecf93df94353a606fe0db/cloudpickle-3.1.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/2a/72/33ff765a07913cb5061baa94718f3a17003aa29adc89642a68c295d47582/dask-2024.11.2-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/c6/b2/454d6e7f0158951d8a78c2e1eb4f69ae81beb8dca5fee9809c6c99e9d0d0/fsspec-2024.10.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/7d/ec/bad1ac26764d26aa1353216fcbfa4670050f66d445448aafa227f8b16e80/greenlet-3.1.1-cp312-cp312-macosx_11_0_universal2.whl - pypi: https://files.pythonhosted.org/packages/13/0e/3f934459c4aab461281ad24b01de08bd612118fbc70ecc7b0fa5ed156a94/hypothesis-6.115.6-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/0b/dc/c0c76414440ea1520b496801b9ee82f7cfbe5c4c1643e1e82c383897b3ae/itk-5.4.0-cp311-abi3-macosx_11_0_arm64.whl @@ -765,28 +750,25 @@ environments: - pypi: https://files.pythonhosted.org/packages/88/99/3db052a349efaf1ddbb51252e7e4c7a6a10ed5b3b87e2076afb622b711fd/itk_registration-5.4.0-cp311-abi3-macosx_11_0_arm64.whl - pypi: https://files.pythonhosted.org/packages/3a/92/7d32413898fe4068f0b2da97ab783057e6af84123aa6c54af3706476fed9/itk_segmentation-5.4.0-cp311-abi3-macosx_11_0_arm64.whl - pypi: https://files.pythonhosted.org/packages/77/66/73fa21a0439eacae5156c73611b35eec2c9c3d83ae4f987754043fce1d67/itk_webassemblyinterface-1.0b175-cp311-abi3-macosx_11_0_arm64.whl - - pypi: https://files.pythonhosted.org/packages/bd/a5/329525eeaf0ac895a37b0a498b311e6d2991d47c827804908a815ae088f3/itkwasm-1.0b180-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/db/bc/83e112abc66cd466c6b83f99118035867cecd41802f8d044638aa78a106e/locket-1.0.0-py2.py3-none-any.whl + - pypi: https://files.pythonhosted.org/packages/bc/f3/db24f14dfed1f631e4568440542dce7330b1c17a5c098666164872db4404/itkwasm-1.0b185-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/b0/29/cb48a402ea879e645b16218718f3f7d9588a77d674a9dcf22e4c43487636/numpy-2.1.2-cp312-cp312-macosx_11_0_arm64.whl - pypi: https://files.pythonhosted.org/packages/55/8b/5ab7257531a5d830fc8000c476e63c935488d74609b50f9384a643ec0a62/outcome-1.3.0.post0-py2.py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/71/e7/40fb618334dcdf7c5a316c0e7343c5cd82d3d866edc100d98e29bc945ecd/partd-1.4.2-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/64/41/d77c47743800fbeb86657611e651e56a17cbb4ebfefa1da0318dc39092df/playwright-1.48.0-py3-none-macosx_11_0_arm64.whl - pypi: https://files.pythonhosted.org/packages/1d/0d/95993c08c721ec68892547f2117e8f9dfbcef2ca71e098533541b4a54d5f/pyee-12.0.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/6f/ec/70457045923b005761b19f78b85b467a64808e886c10c449f7758a1ba5f7/pyodide_py-0.26.3-py3-none-any.whl + - pypi: https://files.pythonhosted.org/packages/2e/4a/970d2604a72e9d44904533b5438135187aa3b08b8d6fc75e5404cd8a1dd1/pyodide_py-0.26.4-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/8d/59/b4572118e098ac8e46e399a1dd0f2d85403ce8bbaad9ec79373ed6badaf9/PySocks-1.7.1-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/96/31/6607dab48616902f76885dfcf62c08d929796fc3b2d2318faf9fd54dbed9/pytest_asyncio-0.24.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/cd/98/7a2d160bd1a997c6fc422647ccf907fcc1b14b8e4a89790fa1427b8f4d16/pytest_pyodide-0.58.3-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/a8/0c/38374f5bb272c051e2a69281d71cba6fdb983413e6758b84482905e29a5d/PyYAML-6.0.2-cp312-cp312-macosx_11_0_arm64.whl - pypi: https://files.pythonhosted.org/packages/aa/85/fa44f23dd5d5066a72f7c4304cce4b5ff9a6e7fd92431a48b2c63fbf63ec/selenium-4.25.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/32/46/9cb0e58b2deb7f82b84065f37f3bffeb12413f947f9388e4cac22c4621ce/sortedcontainers-2.4.0-py2.py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/9b/87/ce70db7cae60e67851eb94e1a2127d4abb573d3866d2efd302ceb0d4d2a5/tblib-3.0.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/03/98/eb27cc78ad3af8e302c9d8ff4977f5026676e130d28dd7578132a457170c/toolz-1.0.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/3c/83/ec3196c360afffbc5b342ead48d1eb7393dd74fa70bca75d33905a86f211/trio-0.27.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/48/be/a9ae5f50cad5b6f85bd2574c2c923730098530096e170c1ce7452394d7aa/trio_websocket-0.11.1-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/ce/d9/5f4c13cecde62396b0d3fe530a50ccea91e7dfc1ccf0e09c228841bb5ba8/urllib3-2.2.3-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/cc/f0/d415d6b31ba69cfca04b2d5e83fbb5fc05335323712fd91948a1a53d13be/wasmtime-25.0.0-py3-none-macosx_11_0_arm64.whl + - pypi: https://files.pythonhosted.org/packages/6e/d8/38d1af31c1787e09642354c81215920a5bf59722a6786ed7e9622fd1f033/wasmtime-27.0.1-py3-none-macosx_11_0_arm64.whl - pypi: https://files.pythonhosted.org/packages/5a/84/44687a29792a70e111c5c477230a72c4b957d88d16141199bf9acb7537a3/websocket_client-1.8.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/78/58/e860788190eba3bcce367f74d29c4675466ce8dddfba85f7827588416f01/wsproto-1.2.0-py3-none-any.whl + - pypi: python/itkwasm-transform-io-wasi win-64: - conda: https://conda.anaconda.org/conda-forge/noarch/anyio-4.6.2.post1-pyhd8ed1ab_0.conda - conda: https://conda.anaconda.org/conda-forge/noarch/backports-1.0-pyhd8ed1ab_4.conda @@ -887,9 +869,6 @@ environments: - conda: https://conda.anaconda.org/conda-forge/win-64/zstandard-0.23.0-py312h7606c53_1.conda - conda: https://conda.anaconda.org/conda-forge/win-64/zstd-1.5.6-h0ea2cb4_0.conda - pypi: https://files.pythonhosted.org/packages/6a/21/5b6702a7f963e95456c0de2d495f67bf5fd62840ac655dc451586d23d39a/attrs-24.2.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/48/41/e1d85ca3cab0b674e277c8c4f678cf66a91cd2cecf93df94353a606fe0db/cloudpickle-3.1.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/2a/72/33ff765a07913cb5061baa94718f3a17003aa29adc89642a68c295d47582/dask-2024.11.2-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/c6/b2/454d6e7f0158951d8a78c2e1eb4f69ae81beb8dca5fee9809c6c99e9d0d0/fsspec-2024.10.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/43/21/a5d9df1d21514883333fc86584c07c2b49ba7c602e670b174bd73cfc9c7f/greenlet-3.1.1-cp312-cp312-win_amd64.whl - pypi: https://files.pythonhosted.org/packages/13/0e/3f934459c4aab461281ad24b01de08bd612118fbc70ecc7b0fa5ed156a94/hypothesis-6.115.6-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/e6/05/b876851fc885a3e3cb85f4167bcbc35020da23b98d50da3947041fc82224/itk-5.4.0-cp311-abi3-win_amd64.whl @@ -901,28 +880,25 @@ environments: - pypi: https://files.pythonhosted.org/packages/89/f6/686c2d2650065495720889c2e6ebcf6af2e5c2692fc6d8768793b08c641a/itk_registration-5.4.0-cp311-abi3-win_amd64.whl - pypi: https://files.pythonhosted.org/packages/77/8d/916c078544ac29a5ac215d2e5a2b07c9314b515b63136be92d6856a41f55/itk_segmentation-5.4.0-cp311-abi3-win_amd64.whl - pypi: https://files.pythonhosted.org/packages/6c/cf/af6554bd0fd831ba2f8ed7840904a1b0828b1ea348b5000b78ad34c5688f/itk_webassemblyinterface-1.0b175-cp311-abi3-win_amd64.whl - - pypi: https://files.pythonhosted.org/packages/bd/a5/329525eeaf0ac895a37b0a498b311e6d2991d47c827804908a815ae088f3/itkwasm-1.0b180-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/db/bc/83e112abc66cd466c6b83f99118035867cecd41802f8d044638aa78a106e/locket-1.0.0-py2.py3-none-any.whl + - pypi: https://files.pythonhosted.org/packages/bc/f3/db24f14dfed1f631e4568440542dce7330b1c17a5c098666164872db4404/itkwasm-1.0b185-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/4c/79/73735a6a5dad6059c085f240a4e74c9270feccd2bc66e4d31b5ca01d329c/numpy-2.1.2-cp312-cp312-win_amd64.whl - pypi: https://files.pythonhosted.org/packages/55/8b/5ab7257531a5d830fc8000c476e63c935488d74609b50f9384a643ec0a62/outcome-1.3.0.post0-py2.py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/71/e7/40fb618334dcdf7c5a316c0e7343c5cd82d3d866edc100d98e29bc945ecd/partd-1.4.2-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/45/88/b6459c93a8bc0b96e7a33b6744bbef2740a0b78b0534542a037d220427f0/playwright-1.48.0-py3-none-win_amd64.whl - pypi: https://files.pythonhosted.org/packages/1d/0d/95993c08c721ec68892547f2117e8f9dfbcef2ca71e098533541b4a54d5f/pyee-12.0.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/6f/ec/70457045923b005761b19f78b85b467a64808e886c10c449f7758a1ba5f7/pyodide_py-0.26.3-py3-none-any.whl + - pypi: https://files.pythonhosted.org/packages/2e/4a/970d2604a72e9d44904533b5438135187aa3b08b8d6fc75e5404cd8a1dd1/pyodide_py-0.26.4-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/8d/59/b4572118e098ac8e46e399a1dd0f2d85403ce8bbaad9ec79373ed6badaf9/PySocks-1.7.1-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/96/31/6607dab48616902f76885dfcf62c08d929796fc3b2d2318faf9fd54dbed9/pytest_asyncio-0.24.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/cd/98/7a2d160bd1a997c6fc422647ccf907fcc1b14b8e4a89790fa1427b8f4d16/pytest_pyodide-0.58.3-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/0c/e8/4f648c598b17c3d06e8753d7d13d57542b30d56e6c2dedf9c331ae56312e/PyYAML-6.0.2-cp312-cp312-win_amd64.whl - pypi: https://files.pythonhosted.org/packages/aa/85/fa44f23dd5d5066a72f7c4304cce4b5ff9a6e7fd92431a48b2c63fbf63ec/selenium-4.25.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/32/46/9cb0e58b2deb7f82b84065f37f3bffeb12413f947f9388e4cac22c4621ce/sortedcontainers-2.4.0-py2.py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/9b/87/ce70db7cae60e67851eb94e1a2127d4abb573d3866d2efd302ceb0d4d2a5/tblib-3.0.0-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/03/98/eb27cc78ad3af8e302c9d8ff4977f5026676e130d28dd7578132a457170c/toolz-1.0.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/3c/83/ec3196c360afffbc5b342ead48d1eb7393dd74fa70bca75d33905a86f211/trio-0.27.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/48/be/a9ae5f50cad5b6f85bd2574c2c923730098530096e170c1ce7452394d7aa/trio_websocket-0.11.1-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/ce/d9/5f4c13cecde62396b0d3fe530a50ccea91e7dfc1ccf0e09c228841bb5ba8/urllib3-2.2.3-py3-none-any.whl - - pypi: https://files.pythonhosted.org/packages/1b/21/c0f3e031efe5f009215975eb7dbea86b55a69c4f02420965d1f45f43865e/wasmtime-25.0.0-py3-none-win_amd64.whl + - pypi: https://files.pythonhosted.org/packages/14/6f/f6b99d9ab1511398686e00d2a26371d99a7949531514379d731b3b7e6309/wasmtime-27.0.1-py3-none-win_amd64.whl - pypi: https://files.pythonhosted.org/packages/5a/84/44687a29792a70e111c5c477230a72c4b957d88d16141199bf9acb7537a3/websocket_client-1.8.0-py3-none-any.whl - pypi: https://files.pythonhosted.org/packages/78/58/e860788190eba3bcce367f74d29c4675466ce8dddfba85f7827588416f01/wsproto-1.2.0-py3-none-any.whl + - pypi: python/itkwasm-transform-io-wasi packages: - kind: conda name: _libgcc_mutex @@ -1332,12 +1308,6 @@ packages: - pkg:pypi/click?source=hash-mapping size: 85051 timestamp: 1692312207348 -- kind: pypi - name: cloudpickle - version: 3.1.0 - url: https://files.pythonhosted.org/packages/48/41/e1d85ca3cab0b674e277c8c4f678cf66a91cd2cecf93df94353a606fe0db/cloudpickle-3.1.0-py3-none-any.whl - sha256: fe11acda67f61aaaec473e3afe030feb131d78a43461b718185363384f1ba12e - requires_python: '>=3.8' - kind: conda name: colorama version: 0.4.6 @@ -1401,38 +1371,6 @@ packages: - pkg:pypi/cryptography?source=hash-mapping size: 1480456 timestamp: 1729287055014 -- kind: pypi - name: dask - version: 2024.11.2 - url: https://files.pythonhosted.org/packages/2a/72/33ff765a07913cb5061baa94718f3a17003aa29adc89642a68c295d47582/dask-2024.11.2-py3-none-any.whl - sha256: 6115c4b76015e8d9d9c2922b6a0a1c850e283fb7fee74eebbd2e28e9c117c30d - requires_dist: - - click>=8.1 - - cloudpickle>=3.0.0 - - fsspec>=2021.9.0 - - packaging>=20.0 - - partd>=1.4.0 - - pyyaml>=5.3.1 - - toolz>=0.10.0 - - importlib-metadata>=4.13.0 ; python_full_version < '3.12' - - numpy>=1.24 ; extra == 'array' - - dask[array,dataframe,diagnostics,distributed] ; extra == 'complete' - - pyarrow>=14.0.1 ; extra == 'complete' - - lz4>=4.3.2 ; extra == 'complete' - - dask[array] ; extra == 'dataframe' - - pandas>=2.0 ; extra == 'dataframe' - - dask-expr<1.2,>=1.1 ; extra == 'dataframe' - - bokeh>=3.1.0 ; extra == 'diagnostics' - - jinja2>=2.10.3 ; extra == 'diagnostics' - - distributed==2024.11.2 ; extra == 'distributed' - - pandas[test] ; extra == 'test' - - pytest ; extra == 'test' - - pytest-cov ; extra == 'test' - - pytest-rerunfailures ; extra == 'test' - - pytest-timeout ; extra == 'test' - - pytest-xdist ; extra == 'test' - - pre-commit ; extra == 'test' - requires_python: '>=3.10' - kind: conda name: dbus version: 1.13.6 @@ -1637,115 +1575,6 @@ packages: purls: [] size: 642092 timestamp: 1694617858496 -- kind: pypi - name: fsspec - version: 2024.10.0 - url: https://files.pythonhosted.org/packages/c6/b2/454d6e7f0158951d8a78c2e1eb4f69ae81beb8dca5fee9809c6c99e9d0d0/fsspec-2024.10.0-py3-none-any.whl - sha256: 03b9a6785766a4de40368b88906366755e2819e758b83705c88cd7cb5fe81871 - requires_dist: - - adlfs ; extra == 'abfs' - - adlfs ; extra == 'adl' - - pyarrow>=1 ; extra == 'arrow' - - dask ; extra == 'dask' - - distributed ; extra == 'dask' - - pre-commit ; extra == 'dev' - - ruff ; extra == 'dev' - - numpydoc ; extra == 'doc' - - sphinx ; extra == 'doc' - - sphinx-design ; extra == 'doc' - - sphinx-rtd-theme ; extra == 'doc' - - yarl ; extra == 'doc' - - dropbox ; extra == 'dropbox' - - dropboxdrivefs ; extra == 'dropbox' - - requests ; extra == 'dropbox' - - adlfs ; extra == 'full' - - aiohttp!=4.0.0a0,!=4.0.0a1 ; extra == 'full' - - dask ; extra == 'full' - - distributed ; extra == 'full' - - dropbox ; extra == 'full' - - dropboxdrivefs ; extra == 'full' - - fusepy ; extra == 'full' - - gcsfs ; extra == 'full' - - libarchive-c ; extra == 'full' - - ocifs ; extra == 'full' - - panel ; extra == 'full' - - paramiko ; extra == 'full' - - pyarrow>=1 ; extra == 'full' - - pygit2 ; extra == 'full' - - requests ; extra == 'full' - - s3fs ; extra == 'full' - - smbprotocol ; extra == 'full' - - tqdm ; extra == 'full' - - fusepy ; extra == 'fuse' - - gcsfs ; extra == 'gcs' - - pygit2 ; extra == 'git' - - requests ; extra == 'github' - - gcsfs ; extra == 'gs' - - panel ; extra == 'gui' - - pyarrow>=1 ; extra == 'hdfs' - - aiohttp!=4.0.0a0,!=4.0.0a1 ; extra == 'http' - - libarchive-c ; extra == 'libarchive' - - ocifs ; extra == 'oci' - - s3fs ; extra == 's3' - - paramiko ; extra == 'sftp' - - smbprotocol ; extra == 'smb' - - paramiko ; extra == 'ssh' - - aiohttp!=4.0.0a0,!=4.0.0a1 ; extra == 'test' - - numpy ; extra == 'test' - - pytest ; extra == 'test' - - pytest-asyncio!=0.22.0 ; extra == 'test' - - pytest-benchmark ; extra == 'test' - - pytest-cov ; extra == 'test' - - pytest-mock ; extra == 'test' - - pytest-recording ; extra == 'test' - - pytest-rerunfailures ; extra == 'test' - - requests ; extra == 'test' - - aiobotocore<3.0.0,>=2.5.4 ; extra == 'test-downstream' - - dask-expr ; extra == 'test-downstream' - - dask[dataframe,test] ; extra == 'test-downstream' - - moto[server]<5,>4 ; extra == 'test-downstream' - - pytest-timeout ; extra == 'test-downstream' - - xarray ; extra == 'test-downstream' - - adlfs ; extra == 'test-full' - - aiohttp!=4.0.0a0,!=4.0.0a1 ; extra == 'test-full' - - cloudpickle ; extra == 'test-full' - - dask ; extra == 'test-full' - - distributed ; extra == 'test-full' - - dropbox ; extra == 'test-full' - - dropboxdrivefs ; extra == 'test-full' - - fastparquet ; extra == 'test-full' - - fusepy ; extra == 'test-full' - - gcsfs ; extra == 'test-full' - - jinja2 ; extra == 'test-full' - - kerchunk ; extra == 'test-full' - - libarchive-c ; extra == 'test-full' - - lz4 ; extra == 'test-full' - - notebook ; extra == 'test-full' - - numpy ; extra == 'test-full' - - ocifs ; extra == 'test-full' - - pandas ; extra == 'test-full' - - panel ; extra == 'test-full' - - paramiko ; extra == 'test-full' - - pyarrow ; extra == 'test-full' - - pyarrow>=1 ; extra == 'test-full' - - pyftpdlib ; extra == 'test-full' - - pygit2 ; extra == 'test-full' - - pytest ; extra == 'test-full' - - pytest-asyncio!=0.22.0 ; extra == 'test-full' - - pytest-benchmark ; extra == 'test-full' - - pytest-cov ; extra == 'test-full' - - pytest-mock ; extra == 'test-full' - - pytest-recording ; extra == 'test-full' - - pytest-rerunfailures ; extra == 'test-full' - - python-snappy ; extra == 'test-full' - - requests ; extra == 'test-full' - - smbprotocol ; extra == 'test-full' - - tqdm ; extra == 'test-full' - - urllib3 ; extra == 'test-full' - - zarr ; extra == 'test-full' - - zstandard ; extra == 'test-full' - - tqdm ; extra == 'tqdm' - requires_python: '>=3.8' - kind: pypi name: greenlet version: 3.1.1 @@ -2465,17 +2294,26 @@ packages: requires_python: '>=3.8' - kind: pypi name: itkwasm - version: 1.0b180 - url: https://files.pythonhosted.org/packages/bd/a5/329525eeaf0ac895a37b0a498b311e6d2991d47c827804908a815ae088f3/itkwasm-1.0b180-py3-none-any.whl - sha256: d2ca6988f64ba779679981b73164dfdc3adbc06eb52f235dca4092ce390d6ebe + version: 1.0b185 + url: https://files.pythonhosted.org/packages/bc/f3/db24f14dfed1f631e4568440542dce7330b1c17a5c098666164872db4404/itkwasm-1.0b185-py3-none-any.whl + sha256: 5d976f244f645e8c1700d59a32dd4461f9ade152693b64d6ebefdfe6b97a2413 requires_dist: - - dask[array]<2025,>=2024.11.2 - importlib-metadata ; python_full_version < '3.10' - numpy - platformdirs ; sys_platform != 'emscripten' - typing-extensions - - wasmtime>=13.0.2 ; sys_platform != 'emscripten' + - wasmtime>=27.0.1 ; sys_platform != 'emscripten' + requires_python: '>=3.9' +- kind: pypi + name: itkwasm-transform-io-wasi + version: 0.1.1 + path: python/itkwasm-transform-io-wasi + sha256: 21ef72cc91a6d86bbd3bd2382298a91ac15c667baac37e946c4e112f76234bac + requires_dist: + - importlib-resources + - itkwasm>=1.0b185 requires_python: '>=3.9' + editable: true - kind: conda name: jaraco.classes version: 3.4.0 @@ -3929,12 +3767,6 @@ packages: purls: [] size: 60963 timestamp: 1727963148474 -- kind: pypi - name: locket - version: 1.0.0 - url: https://files.pythonhosted.org/packages/db/bc/83e112abc66cd466c6b83f99118035867cecd41802f8d044638aa78a106e/locket-1.0.0-py2.py3-none-any.whl - sha256: b6c819a722f7b6bd955b80781788e4a66a55628b858d347536b7e81325a3a5e3 - requires_python: '>=2.7,!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*' - kind: conda name: m2w64-gcc-libgfortran version: 5.3.0 @@ -4471,19 +4303,6 @@ packages: - pkg:pypi/packaging?source=hash-mapping size: 50290 timestamp: 1718189540074 -- kind: pypi - name: partd - version: 1.4.2 - url: https://files.pythonhosted.org/packages/71/e7/40fb618334dcdf7c5a316c0e7343c5cd82d3d866edc100d98e29bc945ecd/partd-1.4.2-py3-none-any.whl - sha256: 978e4ac767ec4ba5b86c6eaa52e5a2a3bc748a2ca839e8cc798f1cc6ce6efb0f - requires_dist: - - locket - - toolz - - numpy>=1.20.0 ; extra == 'complete' - - pandas>=1.3 ; extra == 'complete' - - pyzmq ; extra == 'complete' - - blosc ; extra == 'complete' - requires_python: '>=3.9' - kind: conda name: pathspec version: 0.12.1 @@ -4969,9 +4788,9 @@ packages: timestamp: 1714846885370 - kind: pypi name: pyodide-py - version: 0.26.3 - url: https://files.pythonhosted.org/packages/6f/ec/70457045923b005761b19f78b85b467a64808e886c10c449f7758a1ba5f7/pyodide_py-0.26.3-py3-none-any.whl - sha256: b63b6847c8906aa8f3c17df362135d0407aabf1d4b023557aed721d822e347a8 + version: 0.26.4 + url: https://files.pythonhosted.org/packages/2e/4a/970d2604a72e9d44904533b5438135187aa3b08b8d6fc75e5404cd8a1dd1/pyodide_py-0.26.4-py3-none-any.whl + sha256: a5bc814aba54a25f3292b91de44ff05629c941d5c27483f43d9e85775a6bf158 requires_python: '>=3.12' - kind: pypi name: pysocks @@ -5232,30 +5051,6 @@ packages: - pkg:pypi/pywin32-ctypes?source=hash-mapping size: 57449 timestamp: 1727282288065 -- kind: pypi - name: pyyaml - version: 6.0.2 - url: https://files.pythonhosted.org/packages/0c/e8/4f648c598b17c3d06e8753d7d13d57542b30d56e6c2dedf9c331ae56312e/PyYAML-6.0.2-cp312-cp312-win_amd64.whl - sha256: 7e7401d0de89a9a855c839bc697c079a4af81cf878373abd7dc625847d25cbd8 - requires_python: '>=3.8' -- kind: pypi - name: pyyaml - version: 6.0.2 - url: https://files.pythonhosted.org/packages/a8/0c/38374f5bb272c051e2a69281d71cba6fdb983413e6758b84482905e29a5d/PyYAML-6.0.2-cp312-cp312-macosx_11_0_arm64.whl - sha256: ce826d6ef20b1bc864f0a68340c8b3287705cae2f8b4b1d932177dcc76721725 - requires_python: '>=3.8' -- kind: pypi - name: pyyaml - version: 6.0.2 - url: https://files.pythonhosted.org/packages/b9/2b/614b4752f2e127db5cc206abc23a8c19678e92b23c3db30fc86ab731d3bd/PyYAML-6.0.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl - sha256: 80bab7bfc629882493af4aa31a4cfa43a4c57c83813253626916b8c7ada83476 - requires_python: '>=3.8' -- kind: pypi - name: pyyaml - version: 6.0.2 - url: https://files.pythonhosted.org/packages/c3/93/9916574aa8c00aa06bbac729972eb1071d002b8e158bd0e83a3b9a20a1f7/PyYAML-6.0.2-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl - sha256: 1f71ea527786de97d1a0cc0eacd1defc0985dcf6b3f17bb77dcfc8c34bec4dc5 - requires_python: '>=3.8' - kind: conda name: readline version: '8.2' @@ -5561,12 +5356,6 @@ packages: - pkg:pypi/tomlkit?source=hash-mapping size: 37279 timestamp: 1723631592742 -- kind: pypi - name: toolz - version: 1.0.0 - url: https://files.pythonhosted.org/packages/03/98/eb27cc78ad3af8e302c9d8ff4977f5026676e130d28dd7578132a457170c/toolz-1.0.0-py3-none-any.whl - sha256: 292c8f1c4e7516bf9086f8850935c799a874039c8bcf959d47b600e4c44a6236 - requires_python: '>=3.8' - kind: pypi name: trio version: 0.27.0 @@ -5825,9 +5614,9 @@ packages: timestamp: 1728400827536 - kind: pypi name: wasmtime - version: 25.0.0 - url: https://files.pythonhosted.org/packages/1b/21/c0f3e031efe5f009215975eb7dbea86b55a69c4f02420965d1f45f43865e/wasmtime-25.0.0-py3-none-win_amd64.whl - sha256: f8a2a213b9179965db2d2eedececd69a37e287e902330509afae51c71a3a6842 + version: 27.0.1 + url: https://files.pythonhosted.org/packages/14/6f/f6b99d9ab1511398686e00d2a26371d99a7949531514379d731b3b7e6309/wasmtime-27.0.1-py3-none-win_amd64.whl + sha256: e691aafe8881a872a69a52822f24c209f54fe6f06154d1dfadd977ee86374169 requires_dist: - importlib-resources>=5.10 - coverage ; extra == 'testing' @@ -5835,12 +5624,12 @@ packages: - pycparser ; extra == 'testing' - pytest-mypy ; extra == 'testing' - componentize-py ; extra == 'testing' - requires_python: '>=3.8' + requires_python: '>=3.9' - kind: pypi name: wasmtime - version: 25.0.0 - url: https://files.pythonhosted.org/packages/5c/ba/f551b829378d65d0e0494fdb492942a0ed2dc7f40681b2438a47d1f4af86/wasmtime-25.0.0-py3-none-manylinux1_x86_64.whl - sha256: b4364e14d44e3b7afe6a40bf608e9d0d2c40b09dece441d20f4f6e31906b729c + version: 27.0.1 + url: https://files.pythonhosted.org/packages/3a/57/cd877b4797be239b4433f89a5a85c7bf2c5319dd91c7777b1867bebb664e/wasmtime-27.0.1-py3-none-manylinux2014_aarch64.whl + sha256: dac4e2232cc44b6bfc290f84ff9244621b7e99ee1da4036afb83113dd93b13bf requires_dist: - importlib-resources>=5.10 - coverage ; extra == 'testing' @@ -5848,12 +5637,12 @@ packages: - pycparser ; extra == 'testing' - pytest-mypy ; extra == 'testing' - componentize-py ; extra == 'testing' - requires_python: '>=3.8' + requires_python: '>=3.9' - kind: pypi name: wasmtime - version: 25.0.0 - url: https://files.pythonhosted.org/packages/b7/36/5e83b5f7858fe1003cbb89d0d5716f628b9a00fafc3762665f06ca4ef75d/wasmtime-25.0.0-py3-none-manylinux2014_aarch64.whl - sha256: a07445073cf36a6e5d1dc28246a897dcbdaa537ba8be8805be65422ecca297eb + version: 27.0.1 + url: https://files.pythonhosted.org/packages/5e/24/806c5bd1b5e30c83cc9d182795edebfbfe24483f82fb18823b309a6656b5/wasmtime-27.0.1-py3-none-manylinux1_x86_64.whl + sha256: 99339ed56b7bc4d280bcb0d5527725a7cfe51c269941cf888f57b46f05c249a6 requires_dist: - importlib-resources>=5.10 - coverage ; extra == 'testing' @@ -5861,12 +5650,12 @@ packages: - pycparser ; extra == 'testing' - pytest-mypy ; extra == 'testing' - componentize-py ; extra == 'testing' - requires_python: '>=3.8' + requires_python: '>=3.9' - kind: pypi name: wasmtime - version: 25.0.0 - url: https://files.pythonhosted.org/packages/cc/f0/d415d6b31ba69cfca04b2d5e83fbb5fc05335323712fd91948a1a53d13be/wasmtime-25.0.0-py3-none-macosx_11_0_arm64.whl - sha256: 5bdf1214ee3ee78a4a8a92da339f4c4c8c109e65af881b37f4adfc05d02af426 + version: 27.0.1 + url: https://files.pythonhosted.org/packages/6e/d8/38d1af31c1787e09642354c81215920a5bf59722a6786ed7e9622fd1f033/wasmtime-27.0.1-py3-none-macosx_11_0_arm64.whl + sha256: 1082442529d06c5c50fb9377dbb599460c175f98ca0d332625bf76661c7309b4 requires_dist: - importlib-resources>=5.10 - coverage ; extra == 'testing' @@ -5874,7 +5663,7 @@ packages: - pycparser ; extra == 'testing' - pytest-mypy ; extra == 'testing' - componentize-py ; extra == 'testing' - requires_python: '>=3.8' + requires_python: '>=3.9' - kind: pypi name: websocket-client version: 1.8.0 diff --git a/packages/transform-io/pixi.toml b/packages/transform-io/pixi.toml index 56f983bfe..e6f8f6f6f 100644 --- a/packages/transform-io/pixi.toml +++ b/packages/transform-io/pixi.toml @@ -81,10 +81,11 @@ pytest = ">=8.3.3,<9" pillow = ">=10.4.0,<12" [feature.python.pypi-dependencies] -pyodide-py = ">=0.26.3, <0.27" +pyodide-py = ">=0.26.4, <0.27" pytest-pyodide = ">=0.58.3, <0.59" itk-webassemblyinterface = ">=1.0b175, <2" -itkwasm = ">=1.0b180, <2" +itkwasm = ">=1.0b185, <2" +itkwasm-transform-io-wasi = { path = "python/itkwasm-transform-io-wasi", editable = true } [feature.python.tasks.test-wasi] cmd = "pytest" @@ -92,7 +93,7 @@ cwd = "python/itkwasm-transform-io-wasi" description = "Run tests for itkwasm-transform-io-wasi" [feature.python.tasks.download-pyodide] -cmd = '''curl -L https://github.com/pyodide/pyodide/releases/download/0.26.3/pyodide-0.26.3.tar.bz2 -o pyodide.tar.bz2 && +cmd = '''curl -L https://github.com/pyodide/pyodide/releases/download/0.26.4/pyodide-0.26.4.tar.bz2 -o pyodide.tar.bz2 && tar xjf pyodide.tar.bz2 && rm pyodide.tar.bz2''' outputs = ["pyodide"] diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/__init__.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/__init__.py index 73df3a55c..ad54fe823 100644 --- a/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/__init__.py +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/__init__.py @@ -1,7 +1,8 @@ -# Generated file. To retain edits, remove this comment. - """itkwasm-transform-io-emscripten: Input and output for scientific and medical coordinate transform file formats. Emscripten implementation.""" +from .read_transform_async import read_transform_async +from .write_transform_async import write_transform_async + from .hdf5_read_transform_async import hdf5_read_transform_async from .hdf5_write_transform_async import hdf5_write_transform_async from .mat_read_transform_async import mat_read_transform_async diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/_version.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/_version.py index 3dc1f76bc..485f44ac2 100644 --- a/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/_version.py +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/_version.py @@ -1 +1 @@ -__version__ = "0.1.0" +__version__ = "0.1.1" diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/extension_to_transform_io.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/extension_to_transform_io.py new file mode 100644 index 000000000..76f705b4e --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/extension_to_transform_io.py @@ -0,0 +1,12 @@ +from collections import OrderedDict + +extension_to_transform_io = OrderedDict([ + ("h5", "hdf5"), + ("hdf5", "hdf5"), + ("txt", "txt"), + ("mat", "mat"), + ("xfm", "mnc"), + ("iwt", "wasm"), + ("iwt.cbor", "wasm"), + ("iwt.cbor.zst", "wasmZstd"), +]) diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/js_package.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/js_package.py index 57c176bba..a17265d05 100644 --- a/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/js_package.py +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/js_package.py @@ -3,6 +3,6 @@ from itkwasm.pyodide import JsPackageConfig, JsPackage from ._version import __version__ -default_js_module = """data:text/javascript;base64,var ct=Object.defineProperty;var ut=(A,e)=>{for(var t in e)ct(A,t,{get:e[t],enumerable:!0})};var Et="0.1.1",kA=Et;var Qt={Int8:"int8",UInt8:"uint8",Int16:"int16",UInt16:"uint16",Int32:"int32",UInt32:"uint32",Int64:"int64",UInt64:"uint64",SizeValueType:"uint64",IdentifierType:"uint64",IndexValueType:"int64",OffsetValueType:"int64"},F=Qt;var pt={Float32:"float32",Float64:"float64",SpacePrecisionType:"float64"},M=pt;function mt(A,e){let t=null;switch(A){case F.UInt8:{t=new Uint8Array(e);break}case F.Int8:{t=new Int8Array(e);break}case F.UInt16:{t=new Uint16Array(e);break}case F.Int16:{t=new Int16Array(e);break}case F.UInt32:{t=new Uint32Array(e);break}case F.Int32:{t=new Int32Array(e);break}case F.UInt64:{typeof globalThis.BigUint64Array=="function"?t=new BigUint64Array(e):t=new Uint8Array(e);break}case F.Int64:{typeof globalThis.BigInt64Array=="function"?t=new BigInt64Array(e):t=new Uint8Array(e);break}case M.Float32:{t=new Float32Array(e);break}case M.Float64:{t=new Float64Array(e);break}case"null":{t=null;break}case null:{t=null;break}default:throw new Error("Type is not supported as a TypedArray")}return t}var L=mt;var dt={TextFile:"TextFile",BinaryFile:"BinaryFile",TextStream:"TextStream",BinaryStream:"BinaryStream",Image:"Image",PointSet:"PointSet",Mesh:"Mesh",PolyData:"PolyData",TransformList:"TransformList",JsonCompatible:"JsonCompatible"},E=dt;var ie=Symbol("Comlink.proxy"),yt=Symbol("Comlink.endpoint"),NA=Symbol("Comlink.releaseProxy"),FA=Symbol("Comlink.finalizer"),IA=Symbol("Comlink.thrown"),ae=A=>typeof A=="object"&&A!==null||typeof A=="function",ht={canHandle:A=>ae(A)&&A[ie],serialize(A){let{port1:e,port2:t}=new MessageChannel;return Ie(A,e),[t,[t]]},deserialize(A){return A.start(),TA(A)}},wt={canHandle:A=>ae(A)&&IA in A,serialize({value:A}){let e;return A instanceof Error?e={isError:!0,value:{message:A.message,name:A.name,stack:A.stack}}:e={isError:!1,value:A},[e,[]]},deserialize(A){throw A.isError?Object.assign(new Error(A.value.message),A.value):A.value}},se=new Map([["proxy",ht],["throw",wt]]);function Dt(A,e){for(let t of A)if(e===t||t==="*"||t instanceof RegExp&&t.test(e))return!0;return!1}function Ie(A,e=globalThis,t=["*"]){e.addEventListener("message",function r(n){if(!n||!n.data)return;if(!Dt(t,n.origin)){console.warn(`Invalid origin '${n.origin}' for comlink proxy`);return}let{id:o,type:i,path:B}=Object.assign({path:[]},n.data),u=(n.data.argumentList||[]).map(H),C;try{let s=B.slice(0,-1).reduce((c,I)=>c[I],A),a=B.reduce((c,I)=>c[I],A);switch(i){case"GET":C=a;break;case"SET":s[B.slice(-1)[0]]=H(n.data.value),C=!0;break;case"APPLY":C=a.apply(s,u);break;case"CONSTRUCT":{let c=new a(...u);C=Ft(c)}break;case"ENDPOINT":{let{port1:c,port2:I}=new MessageChannel;Ie(A,I),C=LA(c,[c])}break;case"RELEASE":C=void 0;break;default:return}}catch(s){C={value:s,[IA]:0}}Promise.resolve(C).catch(s=>({value:s,[IA]:0})).then(s=>{let[a,c]=CA(s);e.postMessage(Object.assign(Object.assign({},a),{id:o}),c),i==="RELEASE"&&(e.removeEventListener("message",r),ge(e),FA in A&&typeof A[FA]=="function"&&A[FA]())}).catch(s=>{let[a,c]=CA({value:new TypeError("Unserializable return value"),[IA]:0});e.postMessage(Object.assign(Object.assign({},a),{id:o}),c)})}),e.start&&e.start()}function St(A){return A.constructor.name==="MessagePort"}function ge(A){St(A)&&A.close()}function TA(A,e){return UA(A,[],e)}function sA(A){if(A)throw new Error("Proxy has been released and is not useable")}function Be(A){return Y(A,{type:"RELEASE"}).then(()=>{ge(A)})}var gA=new WeakMap,BA="FinalizationRegistry"in globalThis&&new FinalizationRegistry(A=>{let e=(gA.get(A)||0)-1;gA.set(A,e),e===0&&Be(A)});function Rt(A,e){let t=(gA.get(e)||0)+1;gA.set(e,t),BA&&BA.register(A,e,A)}function bt(A){BA&&BA.unregister(A)}function UA(A,e=[],t=function(){}){let r=!1,n=new Proxy(t,{get(o,i){if(sA(r),i===NA)return()=>{bt(n),Be(A),r=!0};if(i==="then"){if(e.length===0)return{then:()=>n};let B=Y(A,{type:"GET",path:e.map(u=>u.toString())}).then(H);return B.then.bind(B)}return UA(A,[...e,i])},set(o,i,B){sA(r);let[u,C]=CA(B);return Y(A,{type:"SET",path:[...e,i].map(s=>s.toString()),value:u},C).then(H)},apply(o,i,B){sA(r);let u=e[e.length-1];if(u===yt)return Y(A,{type:"ENDPOINT"}).then(H);if(u==="bind")return UA(A,e.slice(0,-1));let[C,s]=ne(B);return Y(A,{type:"APPLY",path:e.map(a=>a.toString()),argumentList:C},s).then(H)},construct(o,i){sA(r);let[B,u]=ne(i);return Y(A,{type:"CONSTRUCT",path:e.map(C=>C.toString()),argumentList:B},u).then(H)}});return Rt(n,A),n}function kt(A){return Array.prototype.concat.apply([],A)}function ne(A){let e=A.map(CA);return[e.map(t=>t[0]),kt(e.map(t=>t[1]))]}var Ce=new WeakMap;function LA(A,e){return Ce.set(A,e),A}function Ft(A){return Object.assign(A,{[ie]:!0})}function CA(A){for(let[e,t]of se)if(t.canHandle(A)){let[r,n]=t.serialize(A);return[{type:"HANDLER",name:e,value:r},n]}return[{type:"RAW",value:A},Ce.get(A)||[]]}function H(A){switch(A.type){case"HANDLER":return se.get(A.name).deserialize(A.value);case"RAW":return A.value}}function Y(A,e,t){return new Promise(r=>{let n=Ut();A.addEventListener("message",function o(i){!i.data||!i.data.id||i.data.id!==n||(A.removeEventListener("message",o),r(i.data))}),A.start&&A.start(),A.postMessage(Object.assign({id:n},e),t)})}function Ut(){return new Array(4).fill(0).map(()=>Math.floor(Math.random()*Number.MAX_SAFE_INTEGER).toString(16)).join("-")}function Z(A,e){return function(){return A.apply(e,arguments)}}var{toString:Nt}=Object.prototype,{getPrototypeOf:OA}=Object,fA=(A=>e=>{let t=Nt.call(e);return A[t]||(A[t]=t.slice(8,-1).toLowerCase())})(Object.create(null)),P=A=>(A=A.toLowerCase(),e=>fA(e)===A),cA=A=>e=>typeof e===A,{isArray:q}=Array,X=cA("undefined");function Tt(A){return A!==null&&!X(A)&&A.constructor!==null&&!X(A.constructor)&&T(A.constructor.isBuffer)&&A.constructor.isBuffer(A)}var ue=P("ArrayBuffer");function Lt(A){let e;return typeof ArrayBuffer<"u"&&ArrayBuffer.isView?e=ArrayBuffer.isView(A):e=A&&A.buffer&&ue(A.buffer),e}var Pt=cA("string"),T=cA("function"),Ee=cA("number"),uA=A=>A!==null&&typeof A=="object",Gt=A=>A===!0||A===!1,lA=A=>{if(fA(A)!=="object")return!1;let e=OA(A);return(e===null||e===Object.prototype||Object.getPrototypeOf(e)===null)&&!(Symbol.toStringTag in A)&&!(Symbol.iterator in A)},Ot=P("Date"),xt=P("File"),Jt=P("Blob"),Wt=P("FileList"),Ht=A=>uA(A)&&T(A.pipe),Mt=A=>{let e;return A&&(typeof FormData=="function"&&A instanceof FormData||T(A.append)&&((e=fA(A))==="formdata"||e==="object"&&T(A.toString)&&A.toString()==="[object FormData]"))},Yt=P("URLSearchParams"),qt=A=>A.trim?A.trim():A.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"");function $(A,e,{allOwnKeys:t=!1}={}){if(A===null||typeof A>"u")return;let r,n;if(typeof A!="object"&&(A=[A]),q(A))for(r=0,n=A.length;r<n;r++)e.call(null,A[r],r,A);else{let o=t?Object.getOwnPropertyNames(A):Object.keys(A),i=o.length,B;for(r=0;r<i;r++)B=o[r],e.call(null,A[B],B,A)}}function Qe(A,e){e=e.toLowerCase();let t=Object.keys(A),r=t.length,n;for(;r-- >0;)if(n=t[r],e===n.toLowerCase())return n;return null}var pe=typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:global,me=A=>!X(A)&&A!==pe;function GA(){let{caseless:A}=me(this)&&this||{},e={},t=(r,n)=>{let o=A&&Qe(e,n)||n;lA(e[o])&&lA(r)?e[o]=GA(e[o],r):lA(r)?e[o]=GA({},r):q(r)?e[o]=r.slice():e[o]=r};for(let r=0,n=arguments.length;r<n;r++)arguments[r]&&$(arguments[r],t);return e}var Kt=(A,e,t,{allOwnKeys:r}={})=>($(e,(n,o)=>{t&&T(n)?A[o]=Z(n,t):A[o]=n},{allOwnKeys:r}),A),jt=A=>(A.charCodeAt(0)===65279&&(A=A.slice(1)),A),vt=(A,e,t,r)=>{A.prototype=Object.create(e.prototype,r),A.prototype.constructor=A,Object.defineProperty(A,"super",{value:e.prototype}),t&&Object.assign(A.prototype,t)},_t=(A,e,t,r)=>{let n,o,i,B={};if(e=e||{},A==null)return e;do{for(n=Object.getOwnPropertyNames(A),o=n.length;o-- >0;)i=n[o],(!r||r(i,A,e))&&!B[i]&&(e[i]=A[i],B[i]=!0);A=t!==!1&&OA(A)}while(A&&(!t||t(A,e))&&A!==Object.prototype);return e},zt=(A,e,t)=>{A=String(A),(t===void 0||t>A.length)&&(t=A.length),t-=e.length;let r=A.indexOf(e,t);return r!==-1&&r===t},Vt=A=>{if(!A)return null;if(q(A))return A;let e=A.length;if(!Ee(e))return null;let t=new Array(e);for(;e-- >0;)t[e]=A[e];return t},Zt=(A=>e=>A&&e instanceof A)(typeof Uint8Array<"u"&&OA(Uint8Array)),Xt=(A,e)=>{let r=(A&&A[Symbol.iterator]).call(A),n;for(;(n=r.next())&&!n.done;){let o=n.value;e.call(A,o[0],o[1])}},$t=(A,e)=>{let t,r=[];for(;(t=A.exec(e))!==null;)r.push(t);return r},Ar=P("HTMLFormElement"),er=A=>A.toLowerCase().replace(/[-_\s]([a-z\d])(\w*)/g,function(t,r,n){return r.toUpperCase()+n}),fe=(({hasOwnProperty:A})=>(e,t)=>A.call(e,t))(Object.prototype),tr=P("RegExp"),de=(A,e)=>{let t=Object.getOwnPropertyDescriptors(A),r={};$(t,(n,o)=>{let i;(i=e(n,o,A))!==!1&&(r[o]=i||n)}),Object.defineProperties(A,r)},rr=A=>{de(A,(e,t)=>{if(T(A)&&["arguments","caller","callee"].indexOf(t)!==-1)return!1;let r=A[t];if(T(r)){if(e.enumerable=!1,"writable"in e){e.writable=!1;return}e.set||(e.set=()=>{throw Error("Can not rewrite read-only method '"+t+"'")})}})},or=(A,e)=>{let t={},r=n=>{n.forEach(o=>{t[o]=!0})};return q(A)?r(A):r(String(A).split(e)),t},nr=()=>{},ir=(A,e)=>(A=+A,Number.isFinite(A)?A:e),PA="abcdefghijklmnopqrstuvwxyz",ce="0123456789",ye={DIGIT:ce,ALPHA:PA,ALPHA_DIGIT:PA+PA.toUpperCase()+ce},ar=(A=16,e=ye.ALPHA_DIGIT)=>{let t="",{length:r}=e;for(;A--;)t+=e[Math.random()*r|0];return t};function sr(A){return!!(A&&T(A.append)&&A[Symbol.toStringTag]==="FormData"&&A[Symbol.iterator])}var Ir=A=>{let e=new Array(10),t=(r,n)=>{if(uA(r)){if(e.indexOf(r)>=0)return;if(!("toJSON"in r)){e[n]=r;let o=q(r)?[]:{};return $(r,(i,B)=>{let u=t(i,n+1);!X(u)&&(o[B]=u)}),e[n]=void 0,o}}return r};return t(A,0)},gr=P("AsyncFunction"),Br=A=>A&&(uA(A)||T(A))&&T(A.then)&&T(A.catch),g={isArray:q,isArrayBuffer:ue,isBuffer:Tt,isFormData:Mt,isArrayBufferView:Lt,isString:Pt,isNumber:Ee,isBoolean:Gt,isObject:uA,isPlainObject:lA,isUndefined:X,isDate:Ot,isFile:xt,isBlob:Jt,isRegExp:tr,isFunction:T,isStream:Ht,isURLSearchParams:Yt,isTypedArray:Zt,isFileList:Wt,forEach:$,merge:GA,extend:Kt,trim:qt,stripBOM:jt,inherits:vt,toFlatObject:_t,kindOf:fA,kindOfTest:P,endsWith:zt,toArray:Vt,forEachEntry:Xt,matchAll:$t,isHTMLForm:Ar,hasOwnProperty:fe,hasOwnProp:fe,reduceDescriptors:de,freezeMethods:rr,toObjectSet:or,toCamelCase:er,noop:nr,toFiniteNumber:ir,findKey:Qe,global:pe,isContextDefined:me,ALPHABET:ye,generateString:ar,isSpecCompliantForm:sr,toJSONObject:Ir,isAsyncFn:gr,isThenable:Br};function K(A,e,t,r,n){Error.call(this),Error.captureStackTrace?Error.captureStackTrace(this,this.constructor):this.stack=new Error().stack,this.message=A,this.name="AxiosError",e&&(this.code=e),t&&(this.config=t),r&&(this.request=r),n&&(this.response=n)}g.inherits(K,Error,{toJSON:function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:g.toJSONObject(this.config),code:this.code,status:this.response&&this.response.status?this.response.status:null}}});var he=K.prototype,we={};["ERR_BAD_OPTION_VALUE","ERR_BAD_OPTION","ECONNABORTED","ETIMEDOUT","ERR_NETWORK","ERR_FR_TOO_MANY_REDIRECTS","ERR_DEPRECATED","ERR_BAD_RESPONSE","ERR_BAD_REQUEST","ERR_CANCELED","ERR_NOT_SUPPORT","ERR_INVALID_URL"].forEach(A=>{we[A]={value:A}});Object.defineProperties(K,we);Object.defineProperty(he,"isAxiosError",{value:!0});K.from=(A,e,t,r,n,o)=>{let i=Object.create(he);return g.toFlatObject(A,i,function(u){return u!==Error.prototype},B=>B!=="isAxiosError"),K.call(i,A.message,e,t,r,n),i.cause=A,i.name=A.name,o&&Object.assign(i,o),i};var p=K;var EA=null;function xA(A){return g.isPlainObject(A)||g.isArray(A)}function Se(A){return g.endsWith(A,"[]")?A.slice(0,-2):A}function De(A,e,t){return A?A.concat(e).map(function(n,o){return n=Se(n),!t&&o?"["+n+"]":n}).join(t?".":""):e}function Cr(A){return g.isArray(A)&&!A.some(xA)}var lr=g.toFlatObject(g,{},null,function(e){return/^is[A-Z]/.test(e)});function fr(A,e,t){if(!g.isObject(A))throw new TypeError("target must be an object");e=e||new(EA||FormData),t=g.toFlatObject(t,{metaTokens:!0,dots:!1,indexes:!1},!1,function(f,Q){return!g.isUndefined(Q[f])});let r=t.metaTokens,n=t.visitor||s,o=t.dots,i=t.indexes,u=(t.Blob||typeof Blob<"u"&&Blob)&&g.isSpecCompliantForm(e);if(!g.isFunction(n))throw new TypeError("visitor must be a function");function C(l){if(l===null)return"";if(g.isDate(l))return l.toISOString();if(!u&&g.isBlob(l))throw new p("Blob is not supported. Use a Buffer instead.");return g.isArrayBuffer(l)||g.isTypedArray(l)?u&&typeof Blob=="function"?new Blob([l]):Buffer.from(l):l}function s(l,f,Q){let m=l;if(l&&!Q&&typeof l=="object"){if(g.endsWith(f,"{}"))f=r?f:f.slice(0,-2),l=JSON.stringify(l);else if(g.isArray(l)&&Cr(l)||(g.isFileList(l)||g.endsWith(f,"[]"))&&(m=g.toArray(l)))return f=Se(f),m.forEach(function(N,ft){!(g.isUndefined(N)||N===null)&&e.append(i===!0?De([f],ft,o):i===null?f:f+"[]",C(N))}),!1}return xA(l)?!0:(e.append(De(Q,f,o),C(l)),!1)}let a=[],c=Object.assign(lr,{defaultVisitor:s,convertValue:C,isVisitable:xA});function I(l,f){if(!g.isUndefined(l)){if(a.indexOf(l)!==-1)throw Error("Circular reference detected in "+f.join("."));a.push(l),g.forEach(l,function(m,U){(!(g.isUndefined(m)||m===null)&&n.call(e,m,g.isString(U)?U.trim():U,f,c))===!0&&I(m,f?f.concat(U):[U])}),a.pop()}}if(!g.isObject(A))throw new TypeError("data must be an object");return I(A),e}var O=fr;function Re(A){let e={"!":"%21","'":"%27","(":"%28",")":"%29","~":"%7E","%20":"+","%00":"\0"};return encodeURIComponent(A).replace(/[!'()~]|%20|%00/g,function(r){return e[r]})}function be(A,e){this._pairs=[],A&&O(A,this,e)}var ke=be.prototype;ke.append=function(e,t){this._pairs.push([e,t])};ke.toString=function(e){let t=e?function(r){return e.call(this,r,Re)}:Re;return this._pairs.map(function(n){return t(n[0])+"="+t(n[1])},"").join("&")};var QA=be;function cr(A){return encodeURIComponent(A).replace(/%3A/gi,":").replace(/%24/g,"$").replace(/%2C/gi,",").replace(/%20/g,"+").replace(/%5B/gi,"[").replace(/%5D/gi,"]")}function AA(A,e,t){if(!e)return A;let r=t&&t.encode||cr,n=t&&t.serialize,o;if(n?o=n(e,t):o=g.isURLSearchParams(e)?e.toString():new QA(e,t).toString(r),o){let i=A.indexOf("#");i!==-1&&(A=A.slice(0,i)),A+=(A.indexOf("?")===-1?"?":"&")+o}return A}var JA=class{constructor(){this.handlers=[]}use(e,t,r){return this.handlers.push({fulfilled:e,rejected:t,synchronous:r?r.synchronous:!1,runWhen:r?r.runWhen:null}),this.handlers.length-1}eject(e){this.handlers[e]&&(this.handlers[e]=null)}clear(){this.handlers&&(this.handlers=[])}forEach(e){g.forEach(this.handlers,function(r){r!==null&&e(r)})}},WA=JA;var pA={silentJSONParsing:!0,forcedJSONParsing:!0,clarifyTimeoutError:!1};var Fe=typeof URLSearchParams<"u"?URLSearchParams:QA;var Ue=typeof FormData<"u"?FormData:null;var Ne=typeof Blob<"u"?Blob:null;var Te={isBrowser:!0,classes:{URLSearchParams:Fe,FormData:Ue,Blob:Ne},protocols:["http","https","file","blob","url","data"]};var HA={};ut(HA,{hasBrowserEnv:()=>Le,hasStandardBrowserEnv:()=>ur,hasStandardBrowserWebWorkerEnv:()=>Er});var Le=typeof window<"u"&&typeof document<"u",ur=(A=>Le&&["ReactNative","NativeScript","NS"].indexOf(A)<0)(typeof navigator<"u"&&navigator.product),Er=typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope&&typeof self.importScripts=="function";var b={...HA,...Te};function MA(A,e){return O(A,new b.classes.URLSearchParams,Object.assign({visitor:function(t,r,n,o){return b.isNode&&g.isBuffer(t)?(this.append(r,t.toString("base64")),!1):o.defaultVisitor.apply(this,arguments)}},e))}function Qr(A){return g.matchAll(/\w+|\[(\w*)]/g,A).map(e=>e[0]==="[]"?"":e[1]||e[0])}function pr(A){let e={},t=Object.keys(A),r,n=t.length,o;for(r=0;r<n;r++)o=t[r],e[o]=A[o];return e}function mr(A){function e(t,r,n,o){let i=t[o++];if(i==="__proto__")return!0;let B=Number.isFinite(+i),u=o>=t.length;return i=!i&&g.isArray(n)?n.length:i,u?(g.hasOwnProp(n,i)?n[i]=[n[i],r]:n[i]=r,!B):((!n[i]||!g.isObject(n[i]))&&(n[i]=[]),e(t,r,n[i],o)&&g.isArray(n[i])&&(n[i]=pr(n[i])),!B)}if(g.isFormData(A)&&g.isFunction(A.entries)){let t={};return g.forEachEntry(A,(r,n)=>{e(Qr(r),n,t,0)}),t}return null}var mA=mr;function dr(A,e,t){if(g.isString(A))try{return(e||JSON.parse)(A),g.trim(A)}catch(r){if(r.name!=="SyntaxError")throw r}return(t||JSON.stringify)(A)}var YA={transitional:pA,adapter:["xhr","http"],transformRequest:[function(e,t){let r=t.getContentType()||"",n=r.indexOf("application/json")>-1,o=g.isObject(e);if(o&&g.isHTMLForm(e)&&(e=new FormData(e)),g.isFormData(e))return n?JSON.stringify(mA(e)):e;if(g.isArrayBuffer(e)||g.isBuffer(e)||g.isStream(e)||g.isFile(e)||g.isBlob(e))return e;if(g.isArrayBufferView(e))return e.buffer;if(g.isURLSearchParams(e))return t.setContentType("application/x-www-form-urlencoded;charset=utf-8",!1),e.toString();let B;if(o){if(r.indexOf("application/x-www-form-urlencoded")>-1)return MA(e,this.formSerializer).toString();if((B=g.isFileList(e))||r.indexOf("multipart/form-data")>-1){let u=this.env&&this.env.FormData;return O(B?{"files[]":e}:e,u&&new u,this.formSerializer)}}return o||n?(t.setContentType("application/json",!1),dr(e)):e}],transformResponse:[function(e){let t=this.transitional||YA.transitional,r=t&&t.forcedJSONParsing,n=this.responseType==="json";if(e&&g.isString(e)&&(r&&!this.responseType||n)){let i=!(t&&t.silentJSONParsing)&&n;try{return JSON.parse(e)}catch(B){if(i)throw B.name==="SyntaxError"?p.from(B,p.ERR_BAD_RESPONSE,this,null,this.response):B}}return e}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,maxBodyLength:-1,env:{FormData:b.classes.FormData,Blob:b.classes.Blob},validateStatus:function(e){return e>=200&&e<300},headers:{common:{Accept:"application/json, text/plain, */*","Content-Type":void 0}}};g.forEach(["delete","get","head","post","put","patch"],A=>{YA.headers[A]={}});var j=YA;var yr=g.toObjectSet(["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"]),Pe=A=>{let e={},t,r,n;return A&&A.split(`
`).forEach(function(i){n=i.indexOf(":"),t=i.substring(0,n).trim().toLowerCase(),r=i.substring(n+1).trim(),!(!t||e[t]&&yr[t])&&(t==="set-cookie"?e[t]?e[t].push(r):e[t]=[r]:e[t]=e[t]?e[t]+", "+r:r)}),e};var Ge=Symbol("internals");function eA(A){return A&&String(A).trim().toLowerCase()}function dA(A){return A===!1||A==null?A:g.isArray(A)?A.map(dA):String(A)}function hr(A){let e=Object.create(null),t=/([^\s,;=]+)\s*(?:=\s*([^,;]+))?/g,r;for(;r=t.exec(A);)e[r[1]]=r[2];return e}var wr=A=>/^[-_a-zA-Z0-9^`|~,!#$%&'*+.]+$/.test(A.trim());function qA(A,e,t,r,n){if(g.isFunction(r))return r.call(this,e,t);if(n&&(e=t),!!g.isString(e)){if(g.isString(r))return e.indexOf(r)!==-1;if(g.isRegExp(r))return r.test(e)}}function Dr(A){return A.trim().toLowerCase().replace(/([a-z\d])(\w*)/g,(e,t,r)=>t.toUpperCase()+r)}function Sr(A,e){let t=g.toCamelCase(" "+e);["get","set","has"].forEach(r=>{Object.defineProperty(A,r+t,{value:function(n,o,i){return this[r].call(this,e,n,o,i)},configurable:!0})})}var v=class{constructor(e){e&&this.set(e)}set(e,t,r){let n=this;function o(B,u,C){let s=eA(u);if(!s)throw new Error("header name must be a non-empty string");let a=g.findKey(n,s);(!a||n[a]===void 0||C===!0||C===void 0&&n[a]!==!1)&&(n[a||u]=dA(B))}let i=(B,u)=>g.forEach(B,(C,s)=>o(C,s,u));return g.isPlainObject(e)||e instanceof this.constructor?i(e,t):g.isString(e)&&(e=e.trim())&&!wr(e)?i(Pe(e),t):e!=null&&o(t,e,r),this}get(e,t){if(e=eA(e),e){let r=g.findKey(this,e);if(r){let n=this[r];if(!t)return n;if(t===!0)return hr(n);if(g.isFunction(t))return t.call(this,n,r);if(g.isRegExp(t))return t.exec(n);throw new TypeError("parser must be boolean|regexp|function")}}}has(e,t){if(e=eA(e),e){let r=g.findKey(this,e);return!!(r&&this[r]!==void 0&&(!t||qA(this,this[r],r,t)))}return!1}delete(e,t){let r=this,n=!1;function o(i){if(i=eA(i),i){let B=g.findKey(r,i);B&&(!t||qA(r,r[B],B,t))&&(delete r[B],n=!0)}}return g.isArray(e)?e.forEach(o):o(e),n}clear(e){let t=Object.keys(this),r=t.length,n=!1;for(;r--;){let o=t[r];(!e||qA(this,this[o],o,e,!0))&&(delete this[o],n=!0)}return n}normalize(e){let t=this,r={};return g.forEach(this,(n,o)=>{let i=g.findKey(r,o);if(i){t[i]=dA(n),delete t[o];return}let B=e?Dr(o):String(o).trim();B!==o&&delete t[o],t[B]=dA(n),r[B]=!0}),this}concat(...e){return this.constructor.concat(this,...e)}toJSON(e){let t=Object.create(null);return g.forEach(this,(r,n)=>{r!=null&&r!==!1&&(t[n]=e&&g.isArray(r)?r.join(", "):r)}),t}[Symbol.iterator](){return Object.entries(this.toJSON())[Symbol.iterator]()}toString(){return Object.entries(this.toJSON()).map(([e,t])=>e+": "+t).join(`
`)}get[Symbol.toStringTag](){return"AxiosHeaders"}static from(e){return e instanceof this?e:new this(e)}static concat(e,...t){let r=new this(e);return t.forEach(n=>r.set(n)),r}static accessor(e){let r=(this[Ge]=this[Ge]={accessors:{}}).accessors,n=this.prototype;function o(i){let B=eA(i);r[B]||(Sr(n,i),r[B]=!0)}return g.isArray(e)?e.forEach(o):o(e),this}};v.accessor(["Content-Type","Content-Length","Accept","Accept-Encoding","User-Agent","Authorization"]);g.reduceDescriptors(v.prototype,({value:A},e)=>{let t=e[0].toUpperCase()+e.slice(1);return{get:()=>A,set(r){this[t]=r}}});g.freezeMethods(v);var k=v;function tA(A,e){let t=this||j,r=e||t,n=k.from(r.headers),o=r.data;return g.forEach(A,function(B){o=B.call(t,o,n.normalize(),e?e.status:void 0)}),n.normalize(),o}function rA(A){return!!(A&&A.__CANCEL__)}function Oe(A,e,t){p.call(this,A??"canceled",p.ERR_CANCELED,e,t),this.name="CanceledError"}g.inherits(Oe,p,{__CANCEL__:!0});var x=Oe;function KA(A,e,t){let r=t.config.validateStatus;!t.status||!r||r(t.status)?A(t):e(new p("Request failed with status code "+t.status,[p.ERR_BAD_REQUEST,p.ERR_BAD_RESPONSE][Math.floor(t.status/100)-4],t.config,t.request,t))}var xe=b.hasStandardBrowserEnv?{write(A,e,t,r,n,o){let i=[A+"="+encodeURIComponent(e)];g.isNumber(t)&&i.push("expires="+new Date(t).toGMTString()),g.isString(r)&&i.push("path="+r),g.isString(n)&&i.push("domain="+n),o===!0&&i.push("secure"),document.cookie=i.join("; ")},read(A){let e=document.cookie.match(new RegExp("(^|;\\s*)("+A+")=([^;]*)"));return e?decodeURIComponent(e[3]):null},remove(A){this.write(A,"",Date.now()-864e5)}}:{write(){},read(){return null},remove(){}};function jA(A){return/^([a-z][a-z\d+\-.]*:)?\/\//i.test(A)}function vA(A,e){return e?A.replace(/\/?\/$/,"")+"/"+e.replace(/^\/+/,""):A}function oA(A,e){return A&&!jA(e)?vA(A,e):e}var Je=b.hasStandardBrowserEnv?function(){let e=/(msie|trident)/i.test(navigator.userAgent),t=document.createElement("a"),r;function n(o){let i=o;return e&&(t.setAttribute("href",i),i=t.href),t.setAttribute("href",i),{href:t.href,protocol:t.protocol?t.protocol.replace(/:$/,""):"",host:t.host,search:t.search?t.search.replace(/^\?/,""):"",hash:t.hash?t.hash.replace(/^#/,""):"",hostname:t.hostname,port:t.port,pathname:t.pathname.charAt(0)==="/"?t.pathname:"/"+t.pathname}}return r=n(window.location.href),function(i){let B=g.isString(i)?n(i):i;return B.protocol===r.protocol&&B.host===r.host}}():function(){return function(){return!0}}();function _A(A){let e=/^([-+\w]{1,25})(:?\/\/|:)/.exec(A);return e&&e[1]||""}function Rr(A,e){A=A||10;let t=new Array(A),r=new Array(A),n=0,o=0,i;return e=e!==void 0?e:1e3,function(u){let C=Date.now(),s=r[o];i||(i=C),t[n]=u,r[n]=C;let a=o,c=0;for(;a!==n;)c+=t[a++],a=a%A;if(n=(n+1)%A,n===o&&(o=(o+1)%A),C-i<e)return;let I=s&&C-s;return I?Math.round(c*1e3/I):void 0}}var We=Rr;function He(A,e){let t=0,r=We(50,250);return n=>{let o=n.loaded,i=n.lengthComputable?n.total:void 0,B=o-t,u=r(B),C=o<=i;t=o;let s={loaded:o,total:i,progress:i?o/i:void 0,bytes:B,rate:u||void 0,estimated:u&&i&&C?(i-o)/u:void 0,event:n};s[e?"download":"upload"]=!0,A(s)}}var br=typeof XMLHttpRequest<"u",Me=br&&function(A){return new Promise(function(t,r){let n=A.data,o=k.from(A.headers).normalize(),{responseType:i,withXSRFToken:B}=A,u;function C(){A.cancelToken&&A.cancelToken.unsubscribe(u),A.signal&&A.signal.removeEventListener("abort",u)}let s;if(g.isFormData(n)){if(b.hasStandardBrowserEnv||b.hasStandardBrowserWebWorkerEnv)o.setContentType(!1);else if((s=o.getContentType())!==!1){let[f,...Q]=s?s.split(";").map(m=>m.trim()).filter(Boolean):[];o.setContentType([f||"multipart/form-data",...Q].join("; "))}}let a=new XMLHttpRequest;if(A.auth){let f=A.auth.username||"",Q=A.auth.password?unescape(encodeURIComponent(A.auth.password)):"";o.set("Authorization","Basic "+btoa(f+":"+Q))}let c=oA(A.baseURL,A.url);a.open(A.method.toUpperCase(),AA(c,A.params,A.paramsSerializer),!0),a.timeout=A.timeout;function I(){if(!a)return;let f=k.from("getAllResponseHeaders"in a&&a.getAllResponseHeaders()),m={data:!i||i==="text"||i==="json"?a.responseText:a.response,status:a.status,statusText:a.statusText,headers:f,config:A,request:a};KA(function(N){t(N),C()},function(N){r(N),C()},m),a=null}if("onloadend"in a?a.onloadend=I:a.onreadystatechange=function(){!a||a.readyState!==4||a.status===0&&!(a.responseURL&&a.responseURL.indexOf("file:")===0)||setTimeout(I)},a.onabort=function(){a&&(r(new p("Request aborted",p.ECONNABORTED,A,a)),a=null)},a.onerror=function(){r(new p("Network Error",p.ERR_NETWORK,A,a)),a=null},a.ontimeout=function(){let Q=A.timeout?"timeout of "+A.timeout+"ms exceeded":"timeout exceeded",m=A.transitional||pA;A.timeoutErrorMessage&&(Q=A.timeoutErrorMessage),r(new p(Q,m.clarifyTimeoutError?p.ETIMEDOUT:p.ECONNABORTED,A,a)),a=null},b.hasStandardBrowserEnv&&(B&&g.isFunction(B)&&(B=B(A)),B||B!==!1&&Je(c))){let f=A.xsrfHeaderName&&A.xsrfCookieName&&xe.read(A.xsrfCookieName);f&&o.set(A.xsrfHeaderName,f)}n===void 0&&o.setContentType(null),"setRequestHeader"in a&&g.forEach(o.toJSON(),function(Q,m){a.setRequestHeader(m,Q)}),g.isUndefined(A.withCredentials)||(a.withCredentials=!!A.withCredentials),i&&i!=="json"&&(a.responseType=A.responseType),typeof A.onDownloadProgress=="function"&&a.addEventListener("progress",He(A.onDownloadProgress,!0)),typeof A.onUploadProgress=="function"&&a.upload&&a.upload.addEventListener("progress",He(A.onUploadProgress)),(A.cancelToken||A.signal)&&(u=f=>{a&&(r(!f||f.type?new x(null,A,a):f),a.abort(),a=null)},A.cancelToken&&A.cancelToken.subscribe(u),A.signal&&(A.signal.aborted?u():A.signal.addEventListener("abort",u)));let l=_A(c);if(l&&b.protocols.indexOf(l)===-1){r(new p("Unsupported protocol "+l+":",p.ERR_BAD_REQUEST,A));return}a.send(n||null)})};var zA={http:EA,xhr:Me};g.forEach(zA,(A,e)=>{if(A){try{Object.defineProperty(A,"name",{value:e})}catch{}Object.defineProperty(A,"adapterName",{value:e})}});var Ye=A=>`- ${A}`,kr=A=>g.isFunction(A)||A===null||A===!1,yA={getAdapter:A=>{A=g.isArray(A)?A:[A];let{length:e}=A,t,r,n={};for(let o=0;o<e;o++){t=A[o];let i;if(r=t,!kr(t)&&(r=zA[(i=String(t)).toLowerCase()],r===void 0))throw new p(`Unknown adapter '${i}'`);if(r)break;n[i||"#"+o]=r}if(!r){let o=Object.entries(n).map(([B,u])=>`adapter ${B} `+(u===!1?"is not supported by the environment":"is not available in the build")),i=e?o.length>1?`since :
`+o.map(Ye).join(`
`):" "+Ye(o[0]):"as no adapter specified";throw new p("There is no suitable adapter to dispatch the request "+i,"ERR_NOT_SUPPORT")}return r},adapters:zA};function VA(A){if(A.cancelToken&&A.cancelToken.throwIfRequested(),A.signal&&A.signal.aborted)throw new x(null,A)}function hA(A){return VA(A),A.headers=k.from(A.headers),A.data=tA.call(A,A.transformRequest),["post","put","patch"].indexOf(A.method)!==-1&&A.headers.setContentType("application/x-www-form-urlencoded",!1),yA.getAdapter(A.adapter||j.adapter)(A).then(function(r){return VA(A),r.data=tA.call(A,A.transformResponse,r),r.headers=k.from(r.headers),r},function(r){return rA(r)||(VA(A),r&&r.response&&(r.response.data=tA.call(A,A.transformResponse,r.response),r.response.headers=k.from(r.response.headers))),Promise.reject(r)})}var qe=A=>A instanceof k?{...A}:A;function G(A,e){e=e||{};let t={};function r(C,s,a){return g.isPlainObject(C)&&g.isPlainObject(s)?g.merge.call({caseless:a},C,s):g.isPlainObject(s)?g.merge({},s):g.isArray(s)?s.slice():s}function n(C,s,a){if(g.isUndefined(s)){if(!g.isUndefined(C))return r(void 0,C,a)}else return r(C,s,a)}function o(C,s){if(!g.isUndefined(s))return r(void 0,s)}function i(C,s){if(g.isUndefined(s)){if(!g.isUndefined(C))return r(void 0,C)}else return r(void 0,s)}function B(C,s,a){if(a in e)return r(C,s);if(a in A)return r(void 0,C)}let u={url:o,method:o,data:o,baseURL:i,transformRequest:i,transformResponse:i,paramsSerializer:i,timeout:i,timeoutMessage:i,withCredentials:i,withXSRFToken:i,adapter:i,responseType:i,xsrfCookieName:i,xsrfHeaderName:i,onUploadProgress:i,onDownloadProgress:i,decompress:i,maxContentLength:i,maxBodyLength:i,beforeRedirect:i,transport:i,httpAgent:i,httpsAgent:i,cancelToken:i,socketPath:i,responseEncoding:i,validateStatus:B,headers:(C,s)=>n(qe(C),qe(s),!0)};return g.forEach(Object.keys(Object.assign({},A,e)),function(s){let a=u[s]||n,c=a(A[s],e[s],s);g.isUndefined(c)&&a!==B||(t[s]=c)}),t}var wA="1.6.8";var ZA={};["object","boolean","number","function","string","symbol"].forEach((A,e)=>{ZA[A]=function(r){return typeof r===A||"a"+(e<1?"n ":" ")+A}});var Ke={};ZA.transitional=function(e,t,r){function n(o,i){return"[Axios v"+wA+"] Transitional option '"+o+"'"+i+(r?". "+r:"")}return(o,i,B)=>{if(e===!1)throw new p(n(i," has been removed"+(t?" in "+t:"")),p.ERR_DEPRECATED);return t&&!Ke[i]&&(Ke[i]=!0,console.warn(n(i," has been deprecated since v"+t+" and will be removed in the near future"))),e?e(o,i,B):!0}};function Fr(A,e,t){if(typeof A!="object")throw new p("options must be an object",p.ERR_BAD_OPTION_VALUE);let r=Object.keys(A),n=r.length;for(;n-- >0;){let o=r[n],i=e[o];if(i){let B=A[o],u=B===void 0||i(B,o,A);if(u!==!0)throw new p("option "+o+" must be "+u,p.ERR_BAD_OPTION_VALUE);continue}if(t!==!0)throw new p("Unknown option "+o,p.ERR_BAD_OPTION)}}var DA={assertOptions:Fr,validators:ZA};var J=DA.validators,_=class{constructor(e){this.defaults=e,this.interceptors={request:new WA,response:new WA}}async request(e,t){try{return await this._request(e,t)}catch(r){if(r instanceof Error){let n;Error.captureStackTrace?Error.captureStackTrace(n={}):n=new Error;let o=n.stack?n.stack.replace(/^.+\n/,""):"";r.stack?o&&!String(r.stack).endsWith(o.replace(/^.+\n.+\n/,""))&&(r.stack+=`
`+o):r.stack=o}throw r}}_request(e,t){typeof e=="string"?(t=t||{},t.url=e):t=e||{},t=G(this.defaults,t);let{transitional:r,paramsSerializer:n,headers:o}=t;r!==void 0&&DA.assertOptions(r,{silentJSONParsing:J.transitional(J.boolean),forcedJSONParsing:J.transitional(J.boolean),clarifyTimeoutError:J.transitional(J.boolean)},!1),n!=null&&(g.isFunction(n)?t.paramsSerializer={serialize:n}:DA.assertOptions(n,{encode:J.function,serialize:J.function},!0)),t.method=(t.method||this.defaults.method||"get").toLowerCase();let i=o&&g.merge(o.common,o[t.method]);o&&g.forEach(["delete","get","head","post","put","patch","common"],l=>{delete o[l]}),t.headers=k.concat(i,o);let B=[],u=!0;this.interceptors.request.forEach(function(f){typeof f.runWhen=="function"&&f.runWhen(t)===!1||(u=u&&f.synchronous,B.unshift(f.fulfilled,f.rejected))});let C=[];this.interceptors.response.forEach(function(f){C.push(f.fulfilled,f.rejected)});let s,a=0,c;if(!u){let l=[hA.bind(this),void 0];for(l.unshift.apply(l,B),l.push.apply(l,C),c=l.length,s=Promise.resolve(t);a<c;)s=s.then(l[a++],l[a++]);return s}c=B.length;let I=t;for(a=0;a<c;){let l=B[a++],f=B[a++];try{I=l(I)}catch(Q){f.call(this,Q);break}}try{s=hA.call(this,I)}catch(l){return Promise.reject(l)}for(a=0,c=C.length;a<c;)s=s.then(C[a++],C[a++]);return s}getUri(e){e=G(this.defaults,e);let t=oA(e.baseURL,e.url);return AA(t,e.params,e.paramsSerializer)}};g.forEach(["delete","get","head","options"],function(e){_.prototype[e]=function(t,r){return this.request(G(r||{},{method:e,url:t,data:(r||{}).data}))}});g.forEach(["post","put","patch"],function(e){function t(r){return function(o,i,B){return this.request(G(B||{},{method:e,headers:r?{"Content-Type":"multipart/form-data"}:{},url:o,data:i}))}}_.prototype[e]=t(),_.prototype[e+"Form"]=t(!0)});var nA=_;var XA=class A{constructor(e){if(typeof e!="function")throw new TypeError("executor must be a function.");let t;this.promise=new Promise(function(o){t=o});let r=this;this.promise.then(n=>{if(!r._listeners)return;let o=r._listeners.length;for(;o-- >0;)r._listeners[o](n);r._listeners=null}),this.promise.then=n=>{let o,i=new Promise(B=>{r.subscribe(B),o=B}).then(n);return i.cancel=function(){r.unsubscribe(o)},i},e(function(o,i,B){r.reason||(r.reason=new x(o,i,B),t(r.reason))})}throwIfRequested(){if(this.reason)throw this.reason}subscribe(e){if(this.reason){e(this.reason);return}this._listeners?this._listeners.push(e):this._listeners=[e]}unsubscribe(e){if(!this._listeners)return;let t=this._listeners.indexOf(e);t!==-1&&this._listeners.splice(t,1)}static source(){let e;return{token:new A(function(n){e=n}),cancel:e}}},je=XA;function $A(A){return function(t){return A.apply(null,t)}}function Ae(A){return g.isObject(A)&&A.isAxiosError===!0}var ee={Continue:100,SwitchingProtocols:101,Processing:102,EarlyHints:103,Ok:200,Created:201,Accepted:202,NonAuthoritativeInformation:203,NoContent:204,ResetContent:205,PartialContent:206,MultiStatus:207,AlreadyReported:208,ImUsed:226,MultipleChoices:300,MovedPermanently:301,Found:302,SeeOther:303,NotModified:304,UseProxy:305,Unused:306,TemporaryRedirect:307,PermanentRedirect:308,BadRequest:400,Unauthorized:401,PaymentRequired:402,Forbidden:403,NotFound:404,MethodNotAllowed:405,NotAcceptable:406,ProxyAuthenticationRequired:407,RequestTimeout:408,Conflict:409,Gone:410,LengthRequired:411,PreconditionFailed:412,PayloadTooLarge:413,UriTooLong:414,UnsupportedMediaType:415,RangeNotSatisfiable:416,ExpectationFailed:417,ImATeapot:418,MisdirectedRequest:421,UnprocessableEntity:422,Locked:423,FailedDependency:424,TooEarly:425,UpgradeRequired:426,PreconditionRequired:428,TooManyRequests:429,RequestHeaderFieldsTooLarge:431,UnavailableForLegalReasons:451,InternalServerError:500,NotImplemented:501,BadGateway:502,ServiceUnavailable:503,GatewayTimeout:504,HttpVersionNotSupported:505,VariantAlsoNegotiates:506,InsufficientStorage:507,LoopDetected:508,NotExtended:510,NetworkAuthenticationRequired:511};Object.entries(ee).forEach(([A,e])=>{ee[e]=A});var ve=ee;function _e(A){let e=new nA(A),t=Z(nA.prototype.request,e);return g.extend(t,nA.prototype,e,{allOwnKeys:!0}),g.extend(t,e,null,{allOwnKeys:!0}),t.create=function(n){return _e(G(A,n))},t}var D=_e(j);D.Axios=nA;D.CanceledError=x;D.CancelToken=je;D.isCancel=rA;D.VERSION=wA;D.toFormData=O;D.AxiosError=p;D.Cancel=D.CanceledError;D.all=function(e){return Promise.all(e)};D.spread=$A;D.isAxiosError=Ae;D.mergeConfig=G;D.AxiosHeaders=k;D.formToJSON=A=>mA(g.isHTMLForm(A)?new FormData(A):A);D.getAdapter=yA.getAdapter;D.HttpStatusCode=ve;D.default=D;var z=D;var{Axios:Ba,AxiosError:Ca,CanceledError:la,isCancel:fa,CancelToken:ca,VERSION:ua,all:Ea,Cancel:Qa,isAxiosError:pa,spread:ma,toFormData:da,AxiosHeaders:ya,HttpStatusCode:ha,formToJSON:wa,getAdapter:Da,mergeConfig:Sa}=z;async function Ur(A,e){let t=A,r=null;if(t==null)r=new Worker(new URL("./web-workers/itk-wasm-pipeline.worker.js",import.meta.url),{type:"module"});else if(t.startsWith("http")){let n=await z.get(t,{responseType:"blob",params:e}),o=URL.createObjectURL(n.data);r=new Worker(o,{type:"module"})}else r=new Worker(t,{type:"module"});return r}var iA=Ur;function ze(A){let e=TA(A),t=A;return t.terminated=!1,t.workerProxy=e,t.originalTerminate=t.terminate,t.terminate=()=>{t.terminated=!0,t.workerProxy[NA](),t.originalTerminate()},{workerProxy:e,worker:t}}async function Nr(A,e,t){let r;if(A!=null){let o=A;return o.workerProxy!==void 0?(r=o.workerProxy,{workerProxy:r,worker:o}):ze(A)}let n=await iA(e,t);return ze(n)}var Ve=Nr;async function Tr(A,e,t){let r="unknown";typeof A!="string"?r=A.href:A.startsWith("http")?r=A:r=typeof e<"u"?`${e}/${A}`:A,r.endsWith(".js")&&(r=r.substring(0,r.length-3)),r.endsWith(".wasm")&&(r=r.substring(0,r.length-5));let n=`${r}.wasm`,i=(await z.get(n,{responseType:"arraybuffer",params:t})).data;return(await import(`${r}.js`)).default({wasmBinary:i})}var Ze=Tr;var Xe=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,5,1,96,0,1,123,3,2,1,0,10,10,1,8,0,65,0,253,15,253,98,11]));var et=typeof globalThis.SharedArrayBuffer=="function",$e=new TextEncoder,At=new TextDecoder("utf-8");function Lr(A,e){let t={flags:"r",encoding:"binary"},r=A.fs_open(e,t.flags),o=A.fs_stat(e).size,i=null;et?i=new SharedArrayBuffer(o):i=new ArrayBuffer(o);let B=new Uint8Array(i);return A.fs_read(r,B,0,o,0),A.fs_close(r),B}function tt(A,e,t){let r=null;et?r=new SharedArrayBuffer(t):r=new ArrayBuffer(t);let n=new Uint8Array(r),o=new Uint8Array(A.HEAPU8.buffer,e,t);return n.set(o),n}function S(A,e,t,r){let n=0;return e!==null&&(n=A.ccall("itk_wasm_input_array_alloc","number",["number","number","number","number"],[0,t,r,e.buffer.byteLength]),A.HEAPU8.set(new Uint8Array(e.buffer),n)),n}function W(A,e,t){let r=JSON.stringify(e),n=A.lengthBytesUTF8(r)+1,o=A.ccall("itk_wasm_input_json_alloc","number",["number","number","number"],[0,t,n]);A.stringToUTF8(r,o,n)}function R(A,e,t,r){let n=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,e,t]),o=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,e,t]),i=tt(A,n,o);return L(r,i.buffer)}function aA(A,e){let t=A.ccall("itk_wasm_output_json_address","number",["number","number"],[0,e]),r=A.UTF8ToString(t);return JSON.parse(r)}function Pr(A,e,t,r){r!=null&&r.length>0&&r.forEach(function(C,s){switch(C.type){case E.TextStream:{let a=$e.encode(C.data.data),c=S(A,a,s,0),I={size:a.buffer.byteLength,data:`data:application/vnd.itk.address,0:${c}`};W(A,I,s);break}case E.JsonCompatible:{let a=$e.encode(JSON.stringify(C.data)),c=S(A,a,s,0),I={size:a.buffer.byteLength,data:`data:application/vnd.itk.address,0:${c}`};W(A,I,s);break}case E.BinaryStream:{let a=C.data.data,c=S(A,a,s,0),I={size:a.buffer.byteLength,data:`data:application/vnd.itk.address,0:${c}`};W(A,I,s);break}case E.TextFile:{A.fs_writeFile(C.data.path,C.data.data);break}case E.BinaryFile:{A.fs_writeFile(C.data.path,C.data.data);break}case E.Image:{let a=C.data,c=S(A,a.data,s,0),I=S(A,a.direction,s,1),l=typeof a.metadata?.entries<"u"?Array.from(a.metadata.entries()):[],f={imageType:a.imageType,name:a.name,origin:a.origin,spacing:a.spacing,direction:`data:application/vnd.itk.address,0:${I}`,size:a.size,data:`data:application/vnd.itk.address,0:${c}`,metadata:l};W(A,f,s);break}case E.Mesh:{let a=C.data,c=S(A,a.points,s,0),I=S(A,a.cells,s,1),l=S(A,a.pointData,s,2),f=S(A,a.cellData,s,3),Q={meshType:a.meshType,name:a.name,numberOfPoints:a.numberOfPoints,points:`data:application/vnd.itk.address,0:${c}`,numberOfCells:a.numberOfCells,cells:`data:application/vnd.itk.address,0:${I}`,cellBufferSize:a.cellBufferSize,numberOfPointPixels:a.numberOfPointPixels,pointData:`data:application/vnd.itk.address,0:${l}`,numberOfCellPixels:a.numberOfCellPixels,cellData:`data:application/vnd.itk.address,0:${f}`};W(A,Q,s);break}case E.PointSet:{let a=C.data,c=S(A,a.points,s,0),I=S(A,a.pointData,s,1),l={pointSetType:a.pointSetType,name:a.name,numberOfPoints:a.numberOfPoints,points:`data:application/vnd.itk.address,0:${c}`,numberOfPointPixels:a.numberOfPointPixels,pointData:`data:application/vnd.itk.address,0:${I}`};W(A,l,s);break}case E.TransformList:{let a=C.data,c=[];a.forEach((I,l)=>{let Q=`data:application/vnd.itk.address,0:${S(A,I.fixedParameters,s,l*2)}`,U=`data:application/vnd.itk.address,0:${S(A,I.parameters,s,l*2+1)}`,N={transformType:I.transformType,numberOfFixedParameters:I.numberOfFixedParameters,numberOfParameters:I.numberOfParameters,name:I.name,inputSpaceName:I.inputSpaceName,outputSpaceName:I.outputSpaceName,parameters:U,fixedParameters:Q};c.push(N)}),W(A,c,s);break}case E.PolyData:{let a=C.data,c=S(A,a.points,s,0),I=S(A,a.vertices,s,1),l=S(A,a.lines,s,2),f=S(A,a.polygons,s,3),Q=S(A,a.triangleStrips,s,4),m=S(A,a.pointData,s,5),U=S(A,a.pointData,s,6),N={polyDataType:a.polyDataType,name:a.name,numberOfPoints:a.numberOfPoints,points:`data:application/vnd.itk.address,0:${c}`,verticesBufferSize:a.verticesBufferSize,vertices:`data:application/vnd.itk.address,0:${I}`,linesBufferSize:a.linesBufferSize,lines:`data:application/vnd.itk.address,0:${l}`,polygonsBufferSize:a.polygonsBufferSize,polygons:`data:application/vnd.itk.address,0:${f}`,triangleStripsBufferSize:a.triangleStripsBufferSize,triangleStrips:`data:application/vnd.itk.address,0:${Q}`,numberOfPointPixels:a.numberOfPointPixels,pointData:`data:application/vnd.itk.address,0:${m}`,numberOfCellPixels:a.numberOfCellPixels,cellData:`data:application/vnd.itk.address,0:${U}`};W(A,N,s);break}default:throw Error("Unsupported input InterfaceType")}}),A.resetModuleStdout(),A.resetModuleStderr();let n=A.stackSave(),o=0;try{o=A.callMain(e.slice())}catch(C){throw typeof C=="number"&&(console.log("Exception while running pipeline:"),console.log("stdout:",A.getModuleStdout()),console.error("stderr:",A.getModuleStderr()),typeof A.getExceptionMessage<"u"?console.error("exception:",A.getExceptionMessage(C)):console.error("Build module in Debug mode for exception message information.")),C}finally{A.stackRestore(n)}let i=A.getModuleStdout(),B=A.getModuleStderr(),u=[];return t!=null&&t.length>0&&o===0&&t.forEach(function(C,s){let a=null;switch(C.type){case E.TextStream:{let I=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,s,0]),l=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,s,0]),f=new Uint8Array(A.HEAPU8.buffer,I,l);a={data:At.decode(f)};break}case E.JsonCompatible:{let I=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,s,0]),l=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,s,0]),f=new Uint8Array(A.HEAPU8.buffer,I,l);a=JSON.parse(At.decode(f));break}case E.BinaryStream:{let I=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,s,0]),l=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,s,0]);a={data:tt(A,I,l)};break}case E.TextFile:{a={path:C.data.path,data:A.fs_readFile(C.data.path,{encoding:"utf8"})};break}case E.BinaryFile:{a={path:C.data.path,data:Lr(A,C.data.path)};break}case E.Image:{let I=aA(A,s);I.data=R(A,s,0,I.imageType.componentType),I.direction=R(A,s,1,M.Float64),I.metadata=new Map(I.metadata),a=I;break}case E.Mesh:{let I=aA(A,s);I.numberOfPoints>0?I.points=R(A,s,0,I.meshType.pointComponentType):I.points=L(I.meshType.pointComponentType,new ArrayBuffer(0)),I.numberOfCells>0?I.cells=R(A,s,1,I.meshType.cellComponentType):I.cells=L(I.meshType.cellComponentType,new ArrayBuffer(0)),I.numberOfPointPixels>0?I.pointData=R(A,s,2,I.meshType.pointPixelComponentType):I.pointData=L(I.meshType.pointPixelComponentType,new ArrayBuffer(0)),I.numberOfCellPixels>0?I.cellData=R(A,s,3,I.meshType.cellPixelComponentType):I.cellData=L(I.meshType.cellPixelComponentType,new ArrayBuffer(0)),a=I;break}case E.PointSet:{let I=aA(A,s);I.numberOfPoints>0?I.points=R(A,s,0,I.pointSetType.pointComponentType):I.points=L(I.pointSetType.pointComponentType,new ArrayBuffer(0)),I.numberOfPointPixels>0?I.pointData=R(A,s,1,I.pointSetType.pointPixelComponentType):I.pointData=L(I.pointSetType.pointPixelComponentType,new ArrayBuffer(0)),a=I;break}case E.TransformList:{let I=aA(A,s);I.forEach((l,f)=>{l.numberOfFixedParameters>0&&(I[f].fixedParameters=R(A,s,f*2,l.transformType.parametersValueType)),l.numberOfFixedParameters>0&&(I[f].parameters=R(A,s,f*2+1,l.transformType.parametersValueType))}),a=I;break}case E.PolyData:{let I=aA(A,s);I.numberOfPoints>0?I.points=R(A,s,0,M.Float32):I.points=new Float32Array,I.verticesBufferSize>0?I.vertices=R(A,s,1,F.UInt32):I.vertices=new Uint32Array,I.linesBufferSize>0?I.lines=R(A,s,2,F.UInt32):I.lines=new Uint32Array,I.polygonsBufferSize>0?I.polygons=R(A,s,3,F.UInt32):I.polygons=new Uint32Array,I.triangleStripsBufferSize>0?I.triangleStrips=R(A,s,4,F.UInt32):I.triangleStrips=new Uint32Array,I.numberOfPointPixels>0?I.pointData=R(A,s,5,I.polyDataType.pointPixelComponentType):I.pointData=L(I.polyDataType.pointPixelComponentType,new ArrayBuffer(0)),I.numberOfCellPixels>0?I.cellData=R(A,s,6,I.polyDataType.cellPixelComponentType):I.cellData=L(I.polyDataType.cellPixelComponentType,new ArrayBuffer(0)),a=I;break}default:throw Error("Unsupported output InterfaceType")}let c={type:C.type,data:a};u.push(c)}),{returnValue:o,stdout:i,stderr:B,outputs:u}}var rt=Pr;var Gr=typeof globalThis.SharedArrayBuffer<"u";function Or(A,e){if(A==null)return[];let t=[];for(let r=0;r<A.length;r++){let n=xr(A[r],e);n!==null&&t.push(n)}return t}function xr(A,e){if(A==null)return null;let t=null;return A.buffer!==void 0?t=A.buffer:A.byteLength!==void 0&&(t=A),Gr&&t instanceof SharedArrayBuffer?null:e?t:t.slice(0)}var ot=Or;function Jr(A){return[A.data,A.direction]}var nt=Jr;function Wr(A){return[A.points,A.pointData,A.cells,A.cellData]}var it=Wr;function Hr(A){return[A.points,A.vertices,A.lines,A.polygons,A.triangleStrips,A.pointData,A.cellData]}var at=Hr;var Mr;function SA(){return Mr}var Yr;function st(){return Yr}var qr;function RA(){return qr}var te=new Map;function Kr(){let A=RA();return typeof A>"u"&&(A=null),A}function It(){let A=SA();return typeof A>"u"&&(A=new URL("/pipelines",document.location.origin).href),A}function bA(){let A=st();return typeof A>"u"&&(A={}),A}async function jr(A,e,t){let r=A,n=A;if(typeof A!="string"&&(r=new URL(A.href),n=r.href),te.has(n))return te.get(n);{let o=await Ze(A,e?.toString()??It(),t??bA());return te.set(n,o),o}}async function vr(A,e,t,r,n){if(!await Xe()){let Q="WebAssembly SIMD support is required -- please update your browser.";throw alert(Q),new Error(Q)}let o=n?.webWorker??null;if(o===!1){let Q=await jr(A.toString(),n?.pipelineBaseUrl,n?.pipelineQueryParams??bA());return rt(Q,e,t,r)}let i=o,B=n?.pipelineWorkerUrl??Kr(),u=typeof B!="string"&&typeof B?.href<"u"?B.href:B,{workerProxy:C,worker:s}=await Ve(i,u,n?.pipelineQueryParams??bA());i=s;let a=[];r!=null&&r.length>0&&r.forEach(function(Q){if(Q.type===E.BinaryStream){let m=Q.data.data;a.push(m)}else if(Q.type===E.BinaryFile){let m=Q.data.data;a.push(m)}else if(Q.type===E.Image){let m=Q.data;m.data!==null&&a.push(...nt(m))}else if(Q.type===E.Mesh){let m=Q.data;a.push(...it(m))}else if(Q.type===E.PolyData){let m=Q.data;a.push(...at(m))}});let c=n?.pipelineBaseUrl??It(),I=typeof c!="string"&&typeof c?.href<"u"?c.href:c,l=r!=null?LA(r,ot(a,n?.noCopy)):null,f=await C.runPipeline(A.toString(),I,e,t,l,n?.pipelineQueryParams??bA());return{returnValue:f.returnValue,stdout:f.stdout,stderr:f.stderr,outputs:f.outputs,webWorker:i}}var y=vr;var _r=null;function gt(){return _r}var re,zr=`https://cdn.jsdelivr.net/npm/@itk-wasm/transform-io@${kA}/dist/pipelines`;function us(A){re=A}function h(){if(typeof re<"u")return re;let A=SA();return typeof A<"u"?A:zr}var oe,Vr=null;function Bt(A){oe=A}function d(){if(typeof oe<"u")return oe;let A=RA();return typeof A<"u"?A:Vr}var V=null;async function Ct(){let A=d(),e=typeof A!="string"&&typeof A?.href<"u"?A.href:A;V=await iA(e)}function hs(A){V=A}async function w(){if(V!==null)return V.terminated&&await Ct(),V;let A=gt();return A!==null?A:(await Ct(),V)}async function Zr(A,e={}){let t=[{type:E.JsonCompatible},{type:E.TransformList}],r=A;if(A instanceof File){let Q=await A.arrayBuffer();r={path:A.name,data:new Uint8Array(Q)}}let n=[{type:E.BinaryFile,data:r}],o=[],i=r.path;o.push(i),o.push("0"),o.push("1"),o.push("--memory-io"),e.floatParameters&&e.floatParameters&&o.push("--float-parameters");let C="hdf5-read-transform",s=e?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:l}=await y(C,o,t,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:e?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldRead:l[0]?.data,transform:l[1]?.data}}var Xr=Zr;async function $r(A,e,t={}){let r=[{type:E.JsonCompatible},{type:E.BinaryFile,data:{path:e,data:new Uint8Array}}],n=[{type:E.TransformList,data:A}],o=[];o.push("0"),o.push("0");let u=e;o.push(u),o.push("--memory-io"),t.floatParameters&&t.floatParameters&&o.push("--float-parameters"),t.useCompression&&t.useCompression&&o.push("--use-compression");let C="hdf5-write-transform",s=t?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:l}=await y(C,o,r,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:t?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldWrite:l[0]?.data,serializedTransform:l[1]?.data}}var Ao=$r;async function eo(A,e={}){let t=[{type:E.JsonCompatible},{type:E.TransformList}],r=A;if(A instanceof File){let Q=await A.arrayBuffer();r={path:A.name,data:new Uint8Array(Q)}}let n=[{type:E.BinaryFile,data:r}],o=[],i=r.path;o.push(i),o.push("0"),o.push("1"),o.push("--memory-io"),e.floatParameters&&e.floatParameters&&o.push("--float-parameters");let C="mat-read-transform",s=e?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:l}=await y(C,o,t,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:e?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldRead:l[0]?.data,transform:l[1]?.data}}var to=eo;async function ro(A,e,t={}){let r=[{type:E.JsonCompatible},{type:E.BinaryFile,data:{path:e,data:new Uint8Array}}],n=[{type:E.TransformList,data:A}],o=[];o.push("0"),o.push("0");let u=e;o.push(u),o.push("--memory-io"),t.floatParameters&&t.floatParameters&&o.push("--float-parameters"),t.useCompression&&t.useCompression&&o.push("--use-compression");let C="mat-write-transform",s=t?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:l}=await y(C,o,r,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:t?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldWrite:l[0]?.data,serializedTransform:l[1]?.data}}var oo=ro;async function no(A,e={}){let t=[{type:E.JsonCompatible},{type:E.TransformList}],r=A;if(A instanceof File){let Q=await A.arrayBuffer();r={path:A.name,data:new Uint8Array(Q)}}let n=[{type:E.BinaryFile,data:r}],o=[],i=r.path;o.push(i),o.push("0"),o.push("1"),o.push("--memory-io"),e.floatParameters&&e.floatParameters&&o.push("--float-parameters");let C="mnc-read-transform",s=e?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:l}=await y(C,o,t,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:e?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldRead:l[0]?.data,transform:l[1]?.data}}var io=no;async function ao(A,e,t={}){let r=[{type:E.JsonCompatible},{type:E.BinaryFile,data:{path:e,data:new Uint8Array}}],n=[{type:E.TransformList,data:A}],o=[];o.push("0"),o.push("0");let u=e;o.push(u),o.push("--memory-io"),t.floatParameters&&t.floatParameters&&o.push("--float-parameters"),t.useCompression&&t.useCompression&&o.push("--use-compression");let C="mnc-write-transform",s=t?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:l}=await y(C,o,r,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:t?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldWrite:l[0]?.data,serializedTransform:l[1]?.data}}var so=ao;async function Io(A,e={}){let t=[{type:E.JsonCompatible},{type:E.TransformList}],r=A;if(A instanceof File){let Q=await A.arrayBuffer();r={path:A.name,data:new Uint8Array(Q)}}let n=[{type:E.BinaryFile,data:r}],o=[],i=r.path;o.push(i),o.push("0"),o.push("1"),o.push("--memory-io"),e.floatParameters&&e.floatParameters&&o.push("--float-parameters");let C="txt-read-transform",s=e?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:l}=await y(C,o,t,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:e?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldRead:l[0]?.data,transform:l[1]?.data}}var go=Io;async function Bo(A,e,t={}){let r=[{type:E.JsonCompatible},{type:E.BinaryFile,data:{path:e,data:new Uint8Array}}],n=[{type:E.TransformList,data:A}],o=[];o.push("0"),o.push("0");let u=e;o.push(u),o.push("--memory-io"),t.floatParameters&&t.floatParameters&&o.push("--float-parameters"),t.useCompression&&t.useCompression&&o.push("--use-compression");let C="txt-write-transform",s=t?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:l}=await y(C,o,r,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:t?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldWrite:l[0]?.data,serializedTransform:l[1]?.data}}var Co=Bo;async function lo(A,e={}){let t=[{type:E.JsonCompatible},{type:E.TransformList}],r=A;if(A instanceof File){let Q=await A.arrayBuffer();r={path:A.name,data:new Uint8Array(Q)}}let n=[{type:E.BinaryFile,data:r}],o=[],i=r.path;o.push(i),o.push("0"),o.push("1"),o.push("--memory-io"),e.floatParameters&&e.floatParameters&&o.push("--float-parameters");let C="wasm-read-transform",s=e?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:l}=await y(C,o,t,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:e?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldRead:l[0]?.data,transform:l[1]?.data}}var fo=lo;async function co(A,e,t={}){let r=[{type:E.JsonCompatible},{type:E.BinaryFile,data:{path:e,data:new Uint8Array}}],n=[{type:E.TransformList,data:A}],o=[];o.push("0"),o.push("0");let u=e;o.push(u),o.push("--memory-io"),t.floatParameters&&t.floatParameters&&o.push("--float-parameters"),t.useCompression&&t.useCompression&&o.push("--use-compression");let C="wasm-write-transform",s=t?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:l}=await y(C,o,r,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:t?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldWrite:l[0]?.data,serializedTransform:l[1]?.data}}var uo=co;async function Eo(A,e={}){let t=[{type:E.JsonCompatible},{type:E.TransformList}],r=A;if(A instanceof File){let Q=await A.arrayBuffer();r={path:A.name,data:new Uint8Array(Q)}}let n=[{type:E.BinaryFile,data:r}],o=[],i=r.path;o.push(i),o.push("0"),o.push("1"),o.push("--memory-io"),e.floatParameters&&e.floatParameters&&o.push("--float-parameters");let C="wasm-zstd-read-transform",s=e?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:l}=await y(C,o,t,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:e?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldRead:l[0]?.data,transform:l[1]?.data}}var Qo=Eo;async function po(A,e,t={}){let r=[{type:E.JsonCompatible},{type:E.BinaryFile,data:{path:e,data:new Uint8Array}}],n=[{type:E.TransformList,data:A}],o=[];o.push("0"),o.push("0");let u=e;o.push(u),o.push("--memory-io"),t.floatParameters&&t.floatParameters&&o.push("--float-parameters"),t.useCompression&&t.useCompression&&o.push("--use-compression");let C="wasm-zstd-write-transform",s=t?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:l}=await y(C,o,r,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:t?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldWrite:l[0]?.data,serializedTransform:l[1]?.data}}var mo=po;var lt='data:text/javascript;charset=utf-8,var II=Object.defineProperty;var eI=(A,t)=>{for(var I in t)II(A,I,{get:t[I],enumerable:!0})};var vA=Symbol("Comlink.proxy"),gI=Symbol("Comlink.endpoint"),rI=Symbol("Comlink.releaseProxy"),pA=Symbol("Comlink.finalizer"),gA=Symbol("Comlink.thrown"),$A=A=>typeof A=="object"&&A!==null||typeof A=="function",oI={canHandle:A=>$A(A)&&A[vA],serialize(A){let{port1:t,port2:I}=new MessageChannel;return CA(A,t),[I,[I]]},deserialize(A){return A.start(),sI(A)}},iI={canHandle:A=>$A(A)&&gA in A,serialize({value:A}){let t;return A instanceof Error?t={isError:!0,value:{message:A.message,name:A.name,stack:A.stack}}:t={isError:!1,value:A},[t,[]]},deserialize(A){throw A.isError?Object.assign(new Error(A.value.message),A.value):A.value}},At=new Map([["proxy",oI],["throw",iI]]);function CI(A,t){for(let I of A)if(t===I||I==="*"||I instanceof RegExp&&I.test(t))return!0;return!1}function CA(A,t=globalThis,I=["*"]){t.addEventListener("message",function e(g){if(!g||!g.data)return;if(!CI(I,g.origin)){console.warn(`Invalid origin \'${g.origin}\' for comlink proxy`);return}let{id:r,type:o,path:n}=Object.assign({path:[]},g.data),c=(g.data.argumentList||[]).map(M),Q;try{let B=n.slice(0,-1).reduce((f,s)=>f[s],A),i=n.reduce((f,s)=>f[s],A);switch(o){case"GET":Q=i;break;case"SET":B[n.slice(-1)[0]]=M(g.data.value),Q=!0;break;case"APPLY":Q=i.apply(B,c);break;case"CONSTRUCT":{let f=new i(...c);Q=EI(f)}break;case"ENDPOINT":{let{port1:f,port2:s}=new MessageChannel;CA(A,s),Q=FA(f,[f])}break;case"RELEASE":Q=void 0;break;default:return}}catch(B){Q={value:B,[gA]:0}}Promise.resolve(Q).catch(B=>({value:B,[gA]:0})).then(B=>{let[i,f]=iA(B);t.postMessage(Object.assign(Object.assign({},i),{id:r}),f),o==="RELEASE"&&(t.removeEventListener("message",e),tt(t),pA in A&&typeof A[pA]=="function"&&A[pA]())}).catch(B=>{let[i,f]=iA({value:new TypeError("Unserializable return value"),[gA]:0});t.postMessage(Object.assign(Object.assign({},i),{id:r}),f)})}),t.start&&t.start()}function BI(A){return A.constructor.name==="MessagePort"}function tt(A){BI(A)&&A.close()}function sI(A,t){return SA(A,[],t)}function eA(A){if(A)throw new Error("Proxy has been released and is not useable")}function It(A){return q(A,{type:"RELEASE"}).then(()=>{tt(A)})}var rA=new WeakMap,oA="FinalizationRegistry"in globalThis&&new FinalizationRegistry(A=>{let t=(rA.get(A)||0)-1;rA.set(A,t),t===0&&It(A)});function nI(A,t){let I=(rA.get(t)||0)+1;rA.set(t,I),oA&&oA.register(A,t,A)}function QI(A){oA&&oA.unregister(A)}function SA(A,t=[],I=function(){}){let e=!1,g=new Proxy(I,{get(r,o){if(eA(e),o===rI)return()=>{QI(g),It(A),e=!0};if(o==="then"){if(t.length===0)return{then:()=>g};let n=q(A,{type:"GET",path:t.map(c=>c.toString())}).then(M);return n.then.bind(n)}return SA(A,[...t,o])},set(r,o,n){eA(e);let[c,Q]=iA(n);return q(A,{type:"SET",path:[...t,o].map(B=>B.toString()),value:c},Q).then(M)},apply(r,o,n){eA(e);let c=t[t.length-1];if(c===gI)return q(A,{type:"ENDPOINT"}).then(M);if(c==="bind")return SA(A,t.slice(0,-1));let[Q,B]=_A(n);return q(A,{type:"APPLY",path:t.map(i=>i.toString()),argumentList:Q},B).then(M)},construct(r,o){eA(e);let[n,c]=_A(o);return q(A,{type:"CONSTRUCT",path:t.map(Q=>Q.toString()),argumentList:n},c).then(M)}});return nI(g,A),g}function aI(A){return Array.prototype.concat.apply([],A)}function _A(A){let t=A.map(iA);return[t.map(I=>I[0]),aI(t.map(I=>I[1]))]}var et=new WeakMap;function FA(A,t){return et.set(A,t),A}function EI(A){return Object.assign(A,{[vA]:!0})}function iA(A){for(let[t,I]of At)if(I.canHandle(A)){let[e,g]=I.serialize(A);return[{type:"HANDLER",name:t,value:e},g]}return[{type:"RAW",value:A},et.get(A)||[]]}function M(A){switch(A.type){case"HANDLER":return At.get(A.name).deserialize(A.value);case"RAW":return A.value}}function q(A,t,I){return new Promise(e=>{let g=cI();A.addEventListener("message",function r(o){!o.data||!o.data.id||o.data.id!==g||(A.removeEventListener("message",r),e(o.data))}),A.start&&A.start(),A.postMessage(Object.assign({id:g},t),I)})}function cI(){return new Array(4).fill(0).map(()=>Math.floor(Math.random()*Number.MAX_SAFE_INTEGER).toString(16)).join("-")}function W(A,t){return function(){return A.apply(t,arguments)}}var{toString:fI}=Object.prototype,{getPrototypeOf:UA}=Object,sA=(A=>t=>{let I=fI.call(t);return A[I]||(A[I]=I.slice(8,-1).toLowerCase())})(Object.create(null)),U=A=>(A=A.toLowerCase(),t=>sA(t)===A),nA=A=>t=>typeof t===A,{isArray:K}=Array,Z=nA("undefined");function lI(A){return A!==null&&!Z(A)&&A.constructor!==null&&!Z(A.constructor)&&N(A.constructor.isBuffer)&&A.constructor.isBuffer(A)}var it=U("ArrayBuffer");function DI(A){let t;return typeof ArrayBuffer<"u"&&ArrayBuffer.isView?t=ArrayBuffer.isView(A):t=A&&A.buffer&&it(A.buffer),t}var uI=nA("string"),N=nA("function"),Ct=nA("number"),QA=A=>A!==null&&typeof A=="object",hI=A=>A===!0||A===!1,BA=A=>{if(sA(A)!=="object")return!1;let t=UA(A);return(t===null||t===Object.prototype||Object.getPrototypeOf(t)===null)&&!(Symbol.toStringTag in A)&&!(Symbol.iterator in A)},dI=U("Date"),yI=U("File"),wI=U("Blob"),mI=U("FileList"),pI=A=>QA(A)&&N(A.pipe),SI=A=>{let t;return A&&(typeof FormData=="function"&&A instanceof FormData||N(A.append)&&((t=sA(A))==="formdata"||t==="object"&&N(A.toString)&&A.toString()==="[object FormData]"))},FI=U("URLSearchParams"),RI=A=>A.trim?A.trim():A.replace(/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g,"");function V(A,t,{allOwnKeys:I=!1}={}){if(A===null||typeof A>"u")return;let e,g;if(typeof A!="object"&&(A=[A]),K(A))for(e=0,g=A.length;e<g;e++)t.call(null,A[e],e,A);else{let r=I?Object.getOwnPropertyNames(A):Object.keys(A),o=r.length,n;for(e=0;e<o;e++)n=r[e],t.call(null,A[n],n,A)}}function Bt(A,t){t=t.toLowerCase();let I=Object.keys(A),e=I.length,g;for(;e-- >0;)if(g=I[e],t===g.toLowerCase())return g;return null}var st=typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:global,nt=A=>!Z(A)&&A!==st;function NA(){let{caseless:A}=nt(this)&&this||{},t={},I=(e,g)=>{let r=A&&Bt(t,g)||g;BA(t[r])&&BA(e)?t[r]=NA(t[r],e):BA(e)?t[r]=NA({},e):K(e)?t[r]=e.slice():t[r]=e};for(let e=0,g=arguments.length;e<g;e++)arguments[e]&&V(arguments[e],I);return t}var NI=(A,t,I,{allOwnKeys:e}={})=>(V(t,(g,r)=>{I&&N(g)?A[r]=W(g,I):A[r]=g},{allOwnKeys:e}),A),UI=A=>(A.charCodeAt(0)===65279&&(A=A.slice(1)),A),GI=(A,t,I,e)=>{A.prototype=Object.create(t.prototype,e),A.prototype.constructor=A,Object.defineProperty(A,"super",{value:t.prototype}),I&&Object.assign(A.prototype,I)},kI=(A,t,I,e)=>{let g,r,o,n={};if(t=t||{},A==null)return t;do{for(g=Object.getOwnPropertyNames(A),r=g.length;r-- >0;)o=g[r],(!e||e(o,A,t))&&!n[o]&&(t[o]=A[o],n[o]=!0);A=I!==!1&&UA(A)}while(A&&(!I||I(A,t))&&A!==Object.prototype);return t},LI=(A,t,I)=>{A=String(A),(I===void 0||I>A.length)&&(I=A.length),I-=t.length;let e=A.indexOf(t,I);return e!==-1&&e===I},JI=A=>{if(!A)return null;if(K(A))return A;let t=A.length;if(!Ct(t))return null;let I=new Array(t);for(;t-- >0;)I[t]=A[t];return I},HI=(A=>t=>A&&t instanceof A)(typeof Uint8Array<"u"&&UA(Uint8Array)),YI=(A,t)=>{let e=(A&&A[Symbol.iterator]).call(A),g;for(;(g=e.next())&&!g.done;){let r=g.value;t.call(A,r[0],r[1])}},bI=(A,t)=>{let I,e=[];for(;(I=A.exec(t))!==null;)e.push(I);return e},MI=U("HTMLFormElement"),qI=A=>A.toLowerCase().replace(/[-_\\s]([a-z\\d])(\\w*)/g,function(I,e,g){return e.toUpperCase()+g}),rt=(({hasOwnProperty:A})=>(t,I)=>A.call(t,I))(Object.prototype),KI=U("RegExp"),Qt=(A,t)=>{let I=Object.getOwnPropertyDescriptors(A),e={};V(I,(g,r)=>{let o;(o=t(g,r,A))!==!1&&(e[r]=o||g)}),Object.defineProperties(A,e)},OI=A=>{Qt(A,(t,I)=>{if(N(A)&&["arguments","caller","callee"].indexOf(I)!==-1)return!1;let e=A[I];if(N(e)){if(t.enumerable=!1,"writable"in t){t.writable=!1;return}t.set||(t.set=()=>{throw Error("Can not rewrite read-only method \'"+I+"\'")})}})},TI=(A,t)=>{let I={},e=g=>{g.forEach(r=>{I[r]=!0})};return K(A)?e(A):e(String(A).split(t)),I},PI=()=>{},xI=(A,t)=>(A=+A,Number.isFinite(A)?A:t),RA="abcdefghijklmnopqrstuvwxyz",ot="0123456789",at={DIGIT:ot,ALPHA:RA,ALPHA_DIGIT:RA+RA.toUpperCase()+ot},jI=(A=16,t=at.ALPHA_DIGIT)=>{let I="",{length:e}=t;for(;A--;)I+=t[Math.random()*e|0];return I};function WI(A){return!!(A&&N(A.append)&&A[Symbol.toStringTag]==="FormData"&&A[Symbol.iterator])}var ZI=A=>{let t=new Array(10),I=(e,g)=>{if(QA(e)){if(t.indexOf(e)>=0)return;if(!("toJSON"in e)){t[g]=e;let r=K(e)?[]:{};return V(e,(o,n)=>{let c=I(o,g+1);!Z(c)&&(r[n]=c)}),t[g]=void 0,r}}return e};return I(A,0)},VI=U("AsyncFunction"),XI=A=>A&&(QA(A)||N(A))&&N(A.then)&&N(A.catch),C={isArray:K,isArrayBuffer:it,isBuffer:lI,isFormData:SI,isArrayBufferView:DI,isString:uI,isNumber:Ct,isBoolean:hI,isObject:QA,isPlainObject:BA,isUndefined:Z,isDate:dI,isFile:yI,isBlob:wI,isRegExp:KI,isFunction:N,isStream:pI,isURLSearchParams:FI,isTypedArray:HI,isFileList:mI,forEach:V,merge:NA,extend:NI,trim:RI,stripBOM:UI,inherits:GI,toFlatObject:kI,kindOf:sA,kindOfTest:U,endsWith:LI,toArray:JI,forEachEntry:YI,matchAll:bI,isHTMLForm:MI,hasOwnProperty:rt,hasOwnProp:rt,reduceDescriptors:Qt,freezeMethods:OI,toObjectSet:TI,toCamelCase:qI,noop:PI,toFiniteNumber:xI,findKey:Bt,global:st,isContextDefined:nt,ALPHABET:at,generateString:jI,isSpecCompliantForm:WI,toJSONObject:ZI,isAsyncFn:VI,isThenable:XI};function O(A,t,I,e,g){Error.call(this),Error.captureStackTrace?Error.captureStackTrace(this,this.constructor):this.stack=new Error().stack,this.message=A,this.name="AxiosError",t&&(this.code=t),I&&(this.config=I),e&&(this.request=e),g&&(this.response=g)}C.inherits(O,Error,{toJSON:function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:C.toJSONObject(this.config),code:this.code,status:this.response&&this.response.status?this.response.status:null}}});var Et=O.prototype,ct={};["ERR_BAD_OPTION_VALUE","ERR_BAD_OPTION","ECONNABORTED","ETIMEDOUT","ERR_NETWORK","ERR_FR_TOO_MANY_REDIRECTS","ERR_DEPRECATED","ERR_BAD_RESPONSE","ERR_BAD_REQUEST","ERR_CANCELED","ERR_NOT_SUPPORT","ERR_INVALID_URL"].forEach(A=>{ct[A]={value:A}});Object.defineProperties(O,ct);Object.defineProperty(Et,"isAxiosError",{value:!0});O.from=(A,t,I,e,g,r)=>{let o=Object.create(Et);return C.toFlatObject(A,o,function(c){return c!==Error.prototype},n=>n!=="isAxiosError"),O.call(o,A.message,t,I,e,g),o.cause=A,o.name=A.name,r&&Object.assign(o,r),o};var l=O;var aA=null;function GA(A){return C.isPlainObject(A)||C.isArray(A)}function lt(A){return C.endsWith(A,"[]")?A.slice(0,-2):A}function ft(A,t,I){return A?A.concat(t).map(function(g,r){return g=lt(g),!I&&r?"["+g+"]":g}).join(I?".":""):t}function zI(A){return C.isArray(A)&&!A.some(GA)}var _I=C.toFlatObject(C,{},null,function(t){return/^is[A-Z]/.test(t)});function vI(A,t,I){if(!C.isObject(A))throw new TypeError("target must be an object");t=t||new(aA||FormData),I=C.toFlatObject(I,{metaTokens:!0,dots:!1,indexes:!1},!1,function(E,u){return!C.isUndefined(u[E])});let e=I.metaTokens,g=I.visitor||B,r=I.dots,o=I.indexes,c=(I.Blob||typeof Blob<"u"&&Blob)&&C.isSpecCompliantForm(t);if(!C.isFunction(g))throw new TypeError("visitor must be a function");function Q(a){if(a===null)return"";if(C.isDate(a))return a.toISOString();if(!c&&C.isBlob(a))throw new l("Blob is not supported. Use a Buffer instead.");return C.isArrayBuffer(a)||C.isTypedArray(a)?c&&typeof Blob=="function"?new Blob([a]):Buffer.from(a):a}function B(a,E,u){let y=a;if(a&&!u&&typeof a=="object"){if(C.endsWith(E,"{}"))E=e?E:E.slice(0,-2),a=JSON.stringify(a);else if(C.isArray(a)&&zI(a)||(C.isFileList(a)||C.endsWith(E,"[]"))&&(y=C.toArray(a)))return E=lt(E),y.forEach(function(R,tI){!(C.isUndefined(R)||R===null)&&t.append(o===!0?ft([E],tI,r):o===null?E:E+"[]",Q(R))}),!1}return GA(a)?!0:(t.append(ft(u,E,r),Q(a)),!1)}let i=[],f=Object.assign(_I,{defaultVisitor:B,convertValue:Q,isVisitable:GA});function s(a,E){if(!C.isUndefined(a)){if(i.indexOf(a)!==-1)throw Error("Circular reference detected in "+E.join("."));i.push(a),C.forEach(a,function(y,F){(!(C.isUndefined(y)||y===null)&&g.call(t,y,C.isString(F)?F.trim():F,E,f))===!0&&s(y,E?E.concat(F):[F])}),i.pop()}}if(!C.isObject(A))throw new TypeError("data must be an object");return s(A),t}var J=vI;function Dt(A){let t={"!":"%2521","\'":"%2527","(":"%2528",")":"%2529","~":"%257E","%2520":"+","%2500":"\\0"};return encodeURIComponent(A).replace(/[!\'()~]|%2520|%2500/g,function(e){return t[e]})}function ut(A,t){this._pairs=[],A&&J(A,this,t)}var ht=ut.prototype;ht.append=function(t,I){this._pairs.push([t,I])};ht.toString=function(t){let I=t?function(e){return t.call(this,e,Dt)}:Dt;return this._pairs.map(function(g){return I(g[0])+"="+I(g[1])},"").join("&")};var EA=ut;function $I(A){return encodeURIComponent(A).replace(/%253A/gi,":").replace(/%2524/g,"$").replace(/%252C/gi,",").replace(/%2520/g,"+").replace(/%255B/gi,"[").replace(/%255D/gi,"]")}function X(A,t,I){if(!t)return A;let e=I&&I.encode||$I,g=I&&I.serialize,r;if(g?r=g(t,I):r=C.isURLSearchParams(t)?t.toString():new EA(t,I).toString(e),r){let o=A.indexOf("%23");o!==-1&&(A=A.slice(0,o)),A+=(A.indexOf("?")===-1?"?":"&")+r}return A}var kA=class{constructor(){this.handlers=[]}use(t,I,e){return this.handlers.push({fulfilled:t,rejected:I,synchronous:e?e.synchronous:!1,runWhen:e?e.runWhen:null}),this.handlers.length-1}eject(t){this.handlers[t]&&(this.handlers[t]=null)}clear(){this.handlers&&(this.handlers=[])}forEach(t){C.forEach(this.handlers,function(e){e!==null&&t(e)})}},LA=kA;var cA={silentJSONParsing:!0,forcedJSONParsing:!0,clarifyTimeoutError:!1};var dt=typeof URLSearchParams<"u"?URLSearchParams:EA;var yt=typeof FormData<"u"?FormData:null;var wt=typeof Blob<"u"?Blob:null;var mt={isBrowser:!0,classes:{URLSearchParams:dt,FormData:yt,Blob:wt},protocols:["http","https","file","blob","url","data"]};var JA={};eI(JA,{hasBrowserEnv:()=>pt,hasStandardBrowserEnv:()=>Ae,hasStandardBrowserWebWorkerEnv:()=>te});var pt=typeof window<"u"&&typeof document<"u",Ae=(A=>pt&&["ReactNative","NativeScript","NS"].indexOf(A)<0)(typeof navigator<"u"&&navigator.product),te=typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope&&typeof self.importScripts=="function";var m={...JA,...mt};function HA(A,t){return J(A,new m.classes.URLSearchParams,Object.assign({visitor:function(I,e,g,r){return m.isNode&&C.isBuffer(I)?(this.append(e,I.toString("base64")),!1):r.defaultVisitor.apply(this,arguments)}},t))}function Ie(A){return C.matchAll(/\\w+|\\[(\\w*)]/g,A).map(t=>t[0]==="[]"?"":t[1]||t[0])}function ee(A){let t={},I=Object.keys(A),e,g=I.length,r;for(e=0;e<g;e++)r=I[e],t[r]=A[r];return t}function ge(A){function t(I,e,g,r){let o=I[r++];if(o==="__proto__")return!0;let n=Number.isFinite(+o),c=r>=I.length;return o=!o&&C.isArray(g)?g.length:o,c?(C.hasOwnProp(g,o)?g[o]=[g[o],e]:g[o]=e,!n):((!g[o]||!C.isObject(g[o]))&&(g[o]=[]),t(I,e,g[o],r)&&C.isArray(g[o])&&(g[o]=ee(g[o])),!n)}if(C.isFormData(A)&&C.isFunction(A.entries)){let I={};return C.forEachEntry(A,(e,g)=>{t(Ie(e),g,I,0)}),I}return null}var fA=ge;function re(A,t,I){if(C.isString(A))try{return(t||JSON.parse)(A),C.trim(A)}catch(e){if(e.name!=="SyntaxError")throw e}return(I||JSON.stringify)(A)}var YA={transitional:cA,adapter:["xhr","http"],transformRequest:[function(t,I){let e=I.getContentType()||"",g=e.indexOf("application/json")>-1,r=C.isObject(t);if(r&&C.isHTMLForm(t)&&(t=new FormData(t)),C.isFormData(t))return g?JSON.stringify(fA(t)):t;if(C.isArrayBuffer(t)||C.isBuffer(t)||C.isStream(t)||C.isFile(t)||C.isBlob(t))return t;if(C.isArrayBufferView(t))return t.buffer;if(C.isURLSearchParams(t))return I.setContentType("application/x-www-form-urlencoded;charset=utf-8",!1),t.toString();let n;if(r){if(e.indexOf("application/x-www-form-urlencoded")>-1)return HA(t,this.formSerializer).toString();if((n=C.isFileList(t))||e.indexOf("multipart/form-data")>-1){let c=this.env&&this.env.FormData;return J(n?{"files[]":t}:t,c&&new c,this.formSerializer)}}return r||g?(I.setContentType("application/json",!1),re(t)):t}],transformResponse:[function(t){let I=this.transitional||YA.transitional,e=I&&I.forcedJSONParsing,g=this.responseType==="json";if(t&&C.isString(t)&&(e&&!this.responseType||g)){let o=!(I&&I.silentJSONParsing)&&g;try{return JSON.parse(t)}catch(n){if(o)throw n.name==="SyntaxError"?l.from(n,l.ERR_BAD_RESPONSE,this,null,this.response):n}}return t}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,maxBodyLength:-1,env:{FormData:m.classes.FormData,Blob:m.classes.Blob},validateStatus:function(t){return t>=200&&t<300},headers:{common:{Accept:"application/json, text/plain, */*","Content-Type":void 0}}};C.forEach(["delete","get","head","post","put","patch"],A=>{YA.headers[A]={}});var T=YA;var oe=C.toObjectSet(["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"]),St=A=>{let t={},I,e,g;return A&&A.split(`%0A`).forEach(function(o){g=o.indexOf(":"),I=o.substring(0,g).trim().toLowerCase(),e=o.substring(g+1).trim(),!(!I||t[I]&&oe[I])&&(I==="set-cookie"?t[I]?t[I].push(e):t[I]=[e]:t[I]=t[I]?t[I]+", "+e:e)}),t};var Ft=Symbol("internals");function z(A){return A&&String(A).trim().toLowerCase()}function lA(A){return A===!1||A==null?A:C.isArray(A)?A.map(lA):String(A)}function ie(A){let t=Object.create(null),I=/([^\\s,;=]+)\\s*(?:=\\s*([^,;]+))?/g,e;for(;e=I.exec(A);)t[e[1]]=e[2];return t}var Ce=A=>/^[-_a-zA-Z0-9^`|~,!%23$%&\'*+.]+$/.test(A.trim());function bA(A,t,I,e,g){if(C.isFunction(e))return e.call(this,t,I);if(g&&(t=I),!!C.isString(t)){if(C.isString(e))return t.indexOf(e)!==-1;if(C.isRegExp(e))return e.test(t)}}function Be(A){return A.trim().toLowerCase().replace(/([a-z\\d])(\\w*)/g,(t,I,e)=>I.toUpperCase()+e)}function se(A,t){let I=C.toCamelCase(" "+t);["get","set","has"].forEach(e=>{Object.defineProperty(A,e+I,{value:function(g,r,o){return this[e].call(this,t,g,r,o)},configurable:!0})})}var P=class{constructor(t){t&&this.set(t)}set(t,I,e){let g=this;function r(n,c,Q){let B=z(c);if(!B)throw new Error("header name must be a non-empty string");let i=C.findKey(g,B);(!i||g[i]===void 0||Q===!0||Q===void 0&&g[i]!==!1)&&(g[i||c]=lA(n))}let o=(n,c)=>C.forEach(n,(Q,B)=>r(Q,B,c));return C.isPlainObject(t)||t instanceof this.constructor?o(t,I):C.isString(t)&&(t=t.trim())&&!Ce(t)?o(St(t),I):t!=null&&r(I,t,e),this}get(t,I){if(t=z(t),t){let e=C.findKey(this,t);if(e){let g=this[e];if(!I)return g;if(I===!0)return ie(g);if(C.isFunction(I))return I.call(this,g,e);if(C.isRegExp(I))return I.exec(g);throw new TypeError("parser must be boolean|regexp|function")}}}has(t,I){if(t=z(t),t){let e=C.findKey(this,t);return!!(e&&this[e]!==void 0&&(!I||bA(this,this[e],e,I)))}return!1}delete(t,I){let e=this,g=!1;function r(o){if(o=z(o),o){let n=C.findKey(e,o);n&&(!I||bA(e,e[n],n,I))&&(delete e[n],g=!0)}}return C.isArray(t)?t.forEach(r):r(t),g}clear(t){let I=Object.keys(this),e=I.length,g=!1;for(;e--;){let r=I[e];(!t||bA(this,this[r],r,t,!0))&&(delete this[r],g=!0)}return g}normalize(t){let I=this,e={};return C.forEach(this,(g,r)=>{let o=C.findKey(e,r);if(o){I[o]=lA(g),delete I[r];return}let n=t?Be(r):String(r).trim();n!==r&&delete I[r],I[n]=lA(g),e[n]=!0}),this}concat(...t){return this.constructor.concat(this,...t)}toJSON(t){let I=Object.create(null);return C.forEach(this,(e,g)=>{e!=null&&e!==!1&&(I[g]=t&&C.isArray(e)?e.join(", "):e)}),I}[Symbol.iterator](){return Object.entries(this.toJSON())[Symbol.iterator]()}toString(){return Object.entries(this.toJSON()).map(([t,I])=>t+": "+I).join(`%0A`)}get[Symbol.toStringTag](){return"AxiosHeaders"}static from(t){return t instanceof this?t:new this(t)}static concat(t,...I){let e=new this(t);return I.forEach(g=>e.set(g)),e}static accessor(t){let e=(this[Ft]=this[Ft]={accessors:{}}).accessors,g=this.prototype;function r(o){let n=z(o);e[n]||(se(g,o),e[n]=!0)}return C.isArray(t)?t.forEach(r):r(t),this}};P.accessor(["Content-Type","Content-Length","Accept","Accept-Encoding","User-Agent","Authorization"]);C.reduceDescriptors(P.prototype,({value:A},t)=>{let I=t[0].toUpperCase()+t.slice(1);return{get:()=>A,set(e){this[I]=e}}});C.freezeMethods(P);var p=P;function _(A,t){let I=this||T,e=t||I,g=p.from(e.headers),r=e.data;return C.forEach(A,function(n){r=n.call(I,r,g.normalize(),t?t.status:void 0)}),g.normalize(),r}function v(A){return!!(A&&A.__CANCEL__)}function Rt(A,t,I){l.call(this,A??"canceled",l.ERR_CANCELED,t,I),this.name="CanceledError"}C.inherits(Rt,l,{__CANCEL__:!0});var H=Rt;function MA(A,t,I){let e=I.config.validateStatus;!I.status||!e||e(I.status)?A(I):t(new l("Request failed with status code "+I.status,[l.ERR_BAD_REQUEST,l.ERR_BAD_RESPONSE][Math.floor(I.status/100)-4],I.config,I.request,I))}var Nt=m.hasStandardBrowserEnv?{write(A,t,I,e,g,r){let o=[A+"="+encodeURIComponent(t)];C.isNumber(I)&&o.push("expires="+new Date(I).toGMTString()),C.isString(e)&&o.push("path="+e),C.isString(g)&&o.push("domain="+g),r===!0&&o.push("secure"),document.cookie=o.join("; ")},read(A){let t=document.cookie.match(new RegExp("(^|;\\\\s*)("+A+")=([^;]*)"));return t?decodeURIComponent(t[3]):null},remove(A){this.write(A,"",Date.now()-864e5)}}:{write(){},read(){return null},remove(){}};function qA(A){return/^([a-z][a-z\\d+\\-.]*:)?\\/\\//i.test(A)}function KA(A,t){return t?A.replace(/\\/?\\/$/,"")+"/"+t.replace(/^\\/+/,""):A}function $(A,t){return A&&!qA(t)?KA(A,t):t}var Ut=m.hasStandardBrowserEnv?function(){let t=/(msie|trident)/i.test(navigator.userAgent),I=document.createElement("a"),e;function g(r){let o=r;return t&&(I.setAttribute("href",o),o=I.href),I.setAttribute("href",o),{href:I.href,protocol:I.protocol?I.protocol.replace(/:$/,""):"",host:I.host,search:I.search?I.search.replace(/^\\?/,""):"",hash:I.hash?I.hash.replace(/^%23/,""):"",hostname:I.hostname,port:I.port,pathname:I.pathname.charAt(0)==="/"?I.pathname:"/"+I.pathname}}return e=g(window.location.href),function(o){let n=C.isString(o)?g(o):o;return n.protocol===e.protocol&&n.host===e.host}}():function(){return function(){return!0}}();function OA(A){let t=/^([-+\\w]{1,25})(:?\\/\\/|:)/.exec(A);return t&&t[1]||""}function ne(A,t){A=A||10;let I=new Array(A),e=new Array(A),g=0,r=0,o;return t=t!==void 0?t:1e3,function(c){let Q=Date.now(),B=e[r];o||(o=Q),I[g]=c,e[g]=Q;let i=r,f=0;for(;i!==g;)f+=I[i++],i=i%A;if(g=(g+1)%A,g===r&&(r=(r+1)%A),Q-o<t)return;let s=B&&Q-B;return s?Math.round(f*1e3/s):void 0}}var Gt=ne;function kt(A,t){let I=0,e=Gt(50,250);return g=>{let r=g.loaded,o=g.lengthComputable?g.total:void 0,n=r-I,c=e(n),Q=r<=o;I=r;let B={loaded:r,total:o,progress:o?r/o:void 0,bytes:n,rate:c||void 0,estimated:c&&o&&Q?(o-r)/c:void 0,event:g};B[t?"download":"upload"]=!0,A(B)}}var Qe=typeof XMLHttpRequest<"u",Lt=Qe&&function(A){return new Promise(function(I,e){let g=A.data,r=p.from(A.headers).normalize(),{responseType:o,withXSRFToken:n}=A,c;function Q(){A.cancelToken&&A.cancelToken.unsubscribe(c),A.signal&&A.signal.removeEventListener("abort",c)}let B;if(C.isFormData(g)){if(m.hasStandardBrowserEnv||m.hasStandardBrowserWebWorkerEnv)r.setContentType(!1);else if((B=r.getContentType())!==!1){let[E,...u]=B?B.split(";").map(y=>y.trim()).filter(Boolean):[];r.setContentType([E||"multipart/form-data",...u].join("; "))}}let i=new XMLHttpRequest;if(A.auth){let E=A.auth.username||"",u=A.auth.password?unescape(encodeURIComponent(A.auth.password)):"";r.set("Authorization","Basic "+btoa(E+":"+u))}let f=$(A.baseURL,A.url);i.open(A.method.toUpperCase(),X(f,A.params,A.paramsSerializer),!0),i.timeout=A.timeout;function s(){if(!i)return;let E=p.from("getAllResponseHeaders"in i&&i.getAllResponseHeaders()),y={data:!o||o==="text"||o==="json"?i.responseText:i.response,status:i.status,statusText:i.statusText,headers:E,config:A,request:i};MA(function(R){I(R),Q()},function(R){e(R),Q()},y),i=null}if("onloadend"in i?i.onloadend=s:i.onreadystatechange=function(){!i||i.readyState!==4||i.status===0&&!(i.responseURL&&i.responseURL.indexOf("file:")===0)||setTimeout(s)},i.onabort=function(){i&&(e(new l("Request aborted",l.ECONNABORTED,A,i)),i=null)},i.onerror=function(){e(new l("Network Error",l.ERR_NETWORK,A,i)),i=null},i.ontimeout=function(){let u=A.timeout?"timeout of "+A.timeout+"ms exceeded":"timeout exceeded",y=A.transitional||cA;A.timeoutErrorMessage&&(u=A.timeoutErrorMessage),e(new l(u,y.clarifyTimeoutError?l.ETIMEDOUT:l.ECONNABORTED,A,i)),i=null},m.hasStandardBrowserEnv&&(n&&C.isFunction(n)&&(n=n(A)),n||n!==!1&&Ut(f))){let E=A.xsrfHeaderName&&A.xsrfCookieName&&Nt.read(A.xsrfCookieName);E&&r.set(A.xsrfHeaderName,E)}g===void 0&&r.setContentType(null),"setRequestHeader"in i&&C.forEach(r.toJSON(),function(u,y){i.setRequestHeader(y,u)}),C.isUndefined(A.withCredentials)||(i.withCredentials=!!A.withCredentials),o&&o!=="json"&&(i.responseType=A.responseType),typeof A.onDownloadProgress=="function"&&i.addEventListener("progress",kt(A.onDownloadProgress,!0)),typeof A.onUploadProgress=="function"&&i.upload&&i.upload.addEventListener("progress",kt(A.onUploadProgress)),(A.cancelToken||A.signal)&&(c=E=>{i&&(e(!E||E.type?new H(null,A,i):E),i.abort(),i=null)},A.cancelToken&&A.cancelToken.subscribe(c),A.signal&&(A.signal.aborted?c():A.signal.addEventListener("abort",c)));let a=OA(f);if(a&&m.protocols.indexOf(a)===-1){e(new l("Unsupported protocol "+a+":",l.ERR_BAD_REQUEST,A));return}i.send(g||null)})};var TA={http:aA,xhr:Lt};C.forEach(TA,(A,t)=>{if(A){try{Object.defineProperty(A,"name",{value:t})}catch{}Object.defineProperty(A,"adapterName",{value:t})}});var Jt=A=>`- ${A}`,ae=A=>C.isFunction(A)||A===null||A===!1,DA={getAdapter:A=>{A=C.isArray(A)?A:[A];let{length:t}=A,I,e,g={};for(let r=0;r<t;r++){I=A[r];let o;if(e=I,!ae(I)&&(e=TA[(o=String(I)).toLowerCase()],e===void 0))throw new l(`Unknown adapter \'${o}\'`);if(e)break;g[o||"%23"+r]=e}if(!e){let r=Object.entries(g).map(([n,c])=>`adapter ${n} `+(c===!1?"is not supported by the environment":"is not available in the build")),o=t?r.length>1?`since :%0A`+r.map(Jt).join(`%0A`):" "+Jt(r[0]):"as no adapter specified";throw new l("There is no suitable adapter to dispatch the request "+o,"ERR_NOT_SUPPORT")}return e},adapters:TA};function PA(A){if(A.cancelToken&&A.cancelToken.throwIfRequested(),A.signal&&A.signal.aborted)throw new H(null,A)}function uA(A){return PA(A),A.headers=p.from(A.headers),A.data=_.call(A,A.transformRequest),["post","put","patch"].indexOf(A.method)!==-1&&A.headers.setContentType("application/x-www-form-urlencoded",!1),DA.getAdapter(A.adapter||T.adapter)(A).then(function(e){return PA(A),e.data=_.call(A,A.transformResponse,e),e.headers=p.from(e.headers),e},function(e){return v(e)||(PA(A),e&&e.response&&(e.response.data=_.call(A,A.transformResponse,e.response),e.response.headers=p.from(e.response.headers))),Promise.reject(e)})}var Ht=A=>A instanceof p?{...A}:A;function k(A,t){t=t||{};let I={};function e(Q,B,i){return C.isPlainObject(Q)&&C.isPlainObject(B)?C.merge.call({caseless:i},Q,B):C.isPlainObject(B)?C.merge({},B):C.isArray(B)?B.slice():B}function g(Q,B,i){if(C.isUndefined(B)){if(!C.isUndefined(Q))return e(void 0,Q,i)}else return e(Q,B,i)}function r(Q,B){if(!C.isUndefined(B))return e(void 0,B)}function o(Q,B){if(C.isUndefined(B)){if(!C.isUndefined(Q))return e(void 0,Q)}else return e(void 0,B)}function n(Q,B,i){if(i in t)return e(Q,B);if(i in A)return e(void 0,Q)}let c={url:r,method:r,data:r,baseURL:o,transformRequest:o,transformResponse:o,paramsSerializer:o,timeout:o,timeoutMessage:o,withCredentials:o,withXSRFToken:o,adapter:o,responseType:o,xsrfCookieName:o,xsrfHeaderName:o,onUploadProgress:o,onDownloadProgress:o,decompress:o,maxContentLength:o,maxBodyLength:o,beforeRedirect:o,transport:o,httpAgent:o,httpsAgent:o,cancelToken:o,socketPath:o,responseEncoding:o,validateStatus:n,headers:(Q,B)=>g(Ht(Q),Ht(B),!0)};return C.forEach(Object.keys(Object.assign({},A,t)),function(B){let i=c[B]||g,f=i(A[B],t[B],B);C.isUndefined(f)&&i!==n||(I[B]=f)}),I}var hA="1.6.8";var xA={};["object","boolean","number","function","string","symbol"].forEach((A,t)=>{xA[A]=function(e){return typeof e===A||"a"+(t<1?"n ":" ")+A}});var Yt={};xA.transitional=function(t,I,e){function g(r,o){return"[Axios v"+hA+"] Transitional option \'"+r+"\'"+o+(e?". "+e:"")}return(r,o,n)=>{if(t===!1)throw new l(g(o," has been removed"+(I?" in "+I:"")),l.ERR_DEPRECATED);return I&&!Yt[o]&&(Yt[o]=!0,console.warn(g(o," has been deprecated since v"+I+" and will be removed in the near future"))),t?t(r,o,n):!0}};function Ee(A,t,I){if(typeof A!="object")throw new l("options must be an object",l.ERR_BAD_OPTION_VALUE);let e=Object.keys(A),g=e.length;for(;g-- >0;){let r=e[g],o=t[r];if(o){let n=A[r],c=n===void 0||o(n,r,A);if(c!==!0)throw new l("option "+r+" must be "+c,l.ERR_BAD_OPTION_VALUE);continue}if(I!==!0)throw new l("Unknown option "+r,l.ERR_BAD_OPTION)}}var dA={assertOptions:Ee,validators:xA};var Y=dA.validators,x=class{constructor(t){this.defaults=t,this.interceptors={request:new LA,response:new LA}}async request(t,I){try{return await this._request(t,I)}catch(e){if(e instanceof Error){let g;Error.captureStackTrace?Error.captureStackTrace(g={}):g=new Error;let r=g.stack?g.stack.replace(/^.+\\n/,""):"";e.stack?r&&!String(e.stack).endsWith(r.replace(/^.+\\n.+\\n/,""))&&(e.stack+=`%0A`+r):e.stack=r}throw e}}_request(t,I){typeof t=="string"?(I=I||{},I.url=t):I=t||{},I=k(this.defaults,I);let{transitional:e,paramsSerializer:g,headers:r}=I;e!==void 0&&dA.assertOptions(e,{silentJSONParsing:Y.transitional(Y.boolean),forcedJSONParsing:Y.transitional(Y.boolean),clarifyTimeoutError:Y.transitional(Y.boolean)},!1),g!=null&&(C.isFunction(g)?I.paramsSerializer={serialize:g}:dA.assertOptions(g,{encode:Y.function,serialize:Y.function},!0)),I.method=(I.method||this.defaults.method||"get").toLowerCase();let o=r&&C.merge(r.common,r[I.method]);r&&C.forEach(["delete","get","head","post","put","patch","common"],a=>{delete r[a]}),I.headers=p.concat(o,r);let n=[],c=!0;this.interceptors.request.forEach(function(E){typeof E.runWhen=="function"&&E.runWhen(I)===!1||(c=c&&E.synchronous,n.unshift(E.fulfilled,E.rejected))});let Q=[];this.interceptors.response.forEach(function(E){Q.push(E.fulfilled,E.rejected)});let B,i=0,f;if(!c){let a=[uA.bind(this),void 0];for(a.unshift.apply(a,n),a.push.apply(a,Q),f=a.length,B=Promise.resolve(I);i<f;)B=B.then(a[i++],a[i++]);return B}f=n.length;let s=I;for(i=0;i<f;){let a=n[i++],E=n[i++];try{s=a(s)}catch(u){E.call(this,u);break}}try{B=uA.call(this,s)}catch(a){return Promise.reject(a)}for(i=0,f=Q.length;i<f;)B=B.then(Q[i++],Q[i++]);return B}getUri(t){t=k(this.defaults,t);let I=$(t.baseURL,t.url);return X(I,t.params,t.paramsSerializer)}};C.forEach(["delete","get","head","options"],function(t){x.prototype[t]=function(I,e){return this.request(k(e||{},{method:t,url:I,data:(e||{}).data}))}});C.forEach(["post","put","patch"],function(t){function I(e){return function(r,o,n){return this.request(k(n||{},{method:t,headers:e?{"Content-Type":"multipart/form-data"}:{},url:r,data:o}))}}x.prototype[t]=I(),x.prototype[t+"Form"]=I(!0)});var AA=x;var jA=class A{constructor(t){if(typeof t!="function")throw new TypeError("executor must be a function.");let I;this.promise=new Promise(function(r){I=r});let e=this;this.promise.then(g=>{if(!e._listeners)return;let r=e._listeners.length;for(;r-- >0;)e._listeners[r](g);e._listeners=null}),this.promise.then=g=>{let r,o=new Promise(n=>{e.subscribe(n),r=n}).then(g);return o.cancel=function(){e.unsubscribe(r)},o},t(function(r,o,n){e.reason||(e.reason=new H(r,o,n),I(e.reason))})}throwIfRequested(){if(this.reason)throw this.reason}subscribe(t){if(this.reason){t(this.reason);return}this._listeners?this._listeners.push(t):this._listeners=[t]}unsubscribe(t){if(!this._listeners)return;let I=this._listeners.indexOf(t);I!==-1&&this._listeners.splice(I,1)}static source(){let t;return{token:new A(function(g){t=g}),cancel:t}}},bt=jA;function WA(A){return function(I){return A.apply(null,I)}}function ZA(A){return C.isObject(A)&&A.isAxiosError===!0}var VA={Continue:100,SwitchingProtocols:101,Processing:102,EarlyHints:103,Ok:200,Created:201,Accepted:202,NonAuthoritativeInformation:203,NoContent:204,ResetContent:205,PartialContent:206,MultiStatus:207,AlreadyReported:208,ImUsed:226,MultipleChoices:300,MovedPermanently:301,Found:302,SeeOther:303,NotModified:304,UseProxy:305,Unused:306,TemporaryRedirect:307,PermanentRedirect:308,BadRequest:400,Unauthorized:401,PaymentRequired:402,Forbidden:403,NotFound:404,MethodNotAllowed:405,NotAcceptable:406,ProxyAuthenticationRequired:407,RequestTimeout:408,Conflict:409,Gone:410,LengthRequired:411,PreconditionFailed:412,PayloadTooLarge:413,UriTooLong:414,UnsupportedMediaType:415,RangeNotSatisfiable:416,ExpectationFailed:417,ImATeapot:418,MisdirectedRequest:421,UnprocessableEntity:422,Locked:423,FailedDependency:424,TooEarly:425,UpgradeRequired:426,PreconditionRequired:428,TooManyRequests:429,RequestHeaderFieldsTooLarge:431,UnavailableForLegalReasons:451,InternalServerError:500,NotImplemented:501,BadGateway:502,ServiceUnavailable:503,GatewayTimeout:504,HttpVersionNotSupported:505,VariantAlsoNegotiates:506,InsufficientStorage:507,LoopDetected:508,NotExtended:510,NetworkAuthenticationRequired:511};Object.entries(VA).forEach(([A,t])=>{VA[t]=A});var Mt=VA;function qt(A){let t=new AA(A),I=W(AA.prototype.request,t);return C.extend(I,AA.prototype,t,{allOwnKeys:!0}),C.extend(I,t,null,{allOwnKeys:!0}),I.create=function(g){return qt(k(A,g))},I}var h=qt(T);h.Axios=AA;h.CanceledError=H;h.CancelToken=bt;h.isCancel=v;h.VERSION=hA;h.toFormData=J;h.AxiosError=l;h.Cancel=h.CanceledError;h.all=function(t){return Promise.all(t)};h.spread=WA;h.isAxiosError=ZA;h.mergeConfig=k;h.AxiosHeaders=p;h.formToJSON=A=>fA(C.isHTMLForm(A)?new FormData(A):A);h.getAdapter=DA.getAdapter;h.HttpStatusCode=Mt;h.default=h;var yA=h;var{Axios:io,AxiosError:Co,CanceledError:Bo,isCancel:so,CancelToken:no,VERSION:Qo,all:ao,Cancel:Eo,isAxiosError:co,spread:fo,toFormData:lo,AxiosHeaders:Do,HttpStatusCode:uo,formToJSON:ho,getAdapter:yo,mergeConfig:wo}=yA;var tA,L,zA,XA={env:{emscripten_notify_memory_growth:function(A){zA=new Uint8Array(L.exports.memory.buffer)}}},wA=class{init(){return tA||(typeof fetch<"u"?tA=fetch("data:application/wasm;base64,"+Kt).then(t=>t.arrayBuffer()).then(t=>WebAssembly.instantiate(t,XA)).then(this._init):tA=WebAssembly.instantiate(Buffer.from(Kt,"base64"),XA).then(this._init),tA)}_init(t){L=t.instance,XA.env.emscripten_notify_memory_growth(0)}decode(t,I=0){if(!L)throw new Error("ZSTDDecoder: Await .init() before decoding.");let e=t.byteLength,g=L.exports.malloc(e);zA.set(t,g),I=I||Number(L.exports.ZSTD_findDecompressedSize(g,e));let r=L.exports.malloc(I),o=L.exports.ZSTD_decompress(r,I,g,e),n=zA.slice(r,r+o);return L.exports.free(g),L.exports.free(r),n}},Kt="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IARrdnE2AgAgARAPGiAAIAJBCGo2AgQLzgEBBn9Bun8hCgJAIAIoAgQiCCACKAIAIglqIg0gASAAa0sNAEFsIQogCSAEIAMoAgAiC2tLDQAgACAJaiIEIAIoAggiDGshAiAAIAFBIGsiACALIAlBABAgIAMgCSALajYCAAJAAkAgBCAFayAMTwRAIAIhBQwBCyAMIAQgBmtLDQIgByAHIAIgBWsiAmoiASAIak8EQCAEIAEgCBAKGgwCCyACIAhqIQggBCABQQAgAmsQCiACayEECyAEIAAgBSAIQQEQIAsgDSEKCyAKC8cEAQJ/IAAgA2ohBgJAIANBB0wEQANAIAAgBk8NAiAAIAItAAA6AAAgAEEBaiEAIAJBAWohAgwACwALIARBAUYEQAJAIAAgAmsiBUEHTQRAIAAgAi0AADoAACAAIAItAAE6AAEgACACLQACOgACIAAgAi0AAzoAAyAAIAIgBUECdCIFQcAeaigCAGoiAigAADYABCACIAVB4B5qKAIAayECDAELIAAgAikAADcAAAsgAkEIaiECIABBCGohAAsgASAGTwRAIAAgA2ohASAEQQFHIAAgAmtBD0pyRQRAA0AgACACKQAANwAAIAJBCGohAiAAQQhqIgAgAUkNAAwDCwALIAAgAikAADcAACAAIAIpAAg3AAggA0ERSQ0BIABBEGohAANAIAAgAikAEDcAACAAIAIpABg3AAggACACKQAgNwAQIAAgAikAKDcAGCACQSBqIQIgAEEgaiIAIAFJDQALDAELAkAgACABSwRAIAAhAQwBCyABIABrIQUCQCAEQQFHIAAgAmtBD0pyRQRAIAIhAwNAIAAgAykAADcAACADQQhqIQMgAEEIaiIAIAFJDQALDAELIAAgAikAADcAACAAIAIpAAg3AAggBUERSA0AIABBEGohACACIQMDQCAAIAMpABA3AAAgACADKQAYNwAIIAAgAykAIDcAECAAIAMpACg3ABggA0EgaiEDIABBIGoiACABSQ0ACwsgAiAFaiECCwNAIAEgBk8NASABIAItAAA6AAAgAUEBaiEBIAJBAWohAgwACwALC64HAgV/AX4jAEGAAWsiESQAIBEgAzYCfEF/IQ8CQAJAAkACQAJAIAIOBAEAAwIECyAGRQRAQbh/IQ8MBAtBbCEPIAUtAAAiAiADSw0DIAggAkEC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IAggH2shBgNAAkAgBiAPTgRAQQAhAwNAIANBA0YNAiAFIANBAnQiAmpBrNABaiACIARqKAJkNgIAIANBAWohAwwACwALAkACQAJAIAQoAtwBIgMgBEHwAGogBkEHcUEMbGoiCCgCACIMaiIQIBdLDQAgByAIKAIEIgsgDGoiCmogIUsNACAKQSBqIBYgB2tNDQELIAQgCCgCCDYCKCAEIAgpAgA3AyAgByAWIARBIGogBEHcAWogFyASIBggGhAfIQoMAQsgByAMaiECIAgoAgghCCAHIAMpAAA3AAAgByADKQAINwAIAkAgDEERSQ0AIAcgAykAEDcAECAHIAMpABg3ABggDEEQa0ERSA0AIANBEGohAyAHQSBqIQwDQCAMIAMpABA3AAAgDCADKQAYNwAIIAwgAykAIDcAECAMIAMpACg3ABggA0EgaiEDIAxBIGoiDCACSQ0ACwsgAiAIayEDIAQgEDYC3AEgAiASayAISQRAIAggAiAYa0sNByAaIBogAyASayIDaiIMIAtqTwRAIAIgDCALEAoaDAILIAMgC2ohCyACIAxBACADaxAKIANrIQIgEiEDCyAIQRBPBEAgAiADKQAANwAAIAIgAykACDcACCALQRFIDQEgAiALaiEIIAJBEGohAgNAIAIgAykAEDcAACACIAMpABg3AAggAiADKQAgNwAQIAIgAykAKDcAGCADQSBqIQMgAkEgaiICIAhJDQALDAELAkAgCEEHTQRAIAIgAy0AADoAACACIAMtAAE6AAEgAiADLQACOgACIAIgAy0AAzoAAyACIAMgCEECdCIIQcAeaigCAGoiAygAADYABCADIAhB4B5qKAIAayEDDAELIAIgAykAADcAAAsgC0EJSQ0AIAIgC2ohDCACQQhqIgggA0EIaiIDa0EPTARAA0AgCCADKQAANwAAIANBCGohAyAIQQhqIgggDEkNAAwCCwALIAggAykAADcAACAIIAMpAAg3AAggC0EZSA0AIAJBGGohAgNAIAIgAykAEDcAACACIAMpABg3AAggAiADKQAgNwAQIAIgAykAKDcAGCADQSBqIQMgAkEgaiICIAxJDQALCyAKQYh/SwRAIAohCQwGBSAGQQFqIQYgByAKaiEHDAILAAsLIAQoAtwBIQMLQbp/IQkgFyADayICIBYgB2tLDQIgBwR/IAcgAyACEAIgAmoFQQALIA5rIQkMAgsgBUEANgKc6wELIAQgBSgC8OoBIgM2AtwBIAkgDmohDCADIAUoAoDrAWohEAJAIA9FBEAgDiEGDAELIAUoArjpASENIAUoArTpASETIAUoArDpASESIAVBATYChOoBQQAhAwNAIANBA0cEQCAEIANBAnQiAmogAiAFakGs0AFqKAIANgKcASADQQFqIQMMAQsLQWwhCSAEQfAAaiICIAcgBhANQYh/Sw0BIDEgAiAFKAIAEB4gMCACIAUoAggQHiAvIAIgBSgCBBAeIAxBIGshGCAOIQYDQCAEKAKIASAEKAKEAUEDdGopAgAiQKciCkEQdiIZQf8BcSELIAQoApgBIAQoApQBQQN0aikCACJBpyIWQRB2Ih9B/wFxIRogBCgCkAEgBCgCjAFBA3RqKQIAIkJCIIinIQcgQUIgiCBAQiCIpyEDAkAgQkIQiKciCEH/AXEiAkECTwRAAkAgAkEZSSA/QoGAgBBUckUEQCAEQSAgBCgCdCIIayIRIAIgAiARSxsiFyAIajYCdCAHIAQoAnAgCHRBACAXa3YgAiAXayIXdGohCCAEQfAAahAPGiACIBFNDQEgBCAEKAJ0IgIgF2o2AnQgBCgCcCACdEEAIBdrdiAIaiEIDAELIAQgAiAEKAJ0IhFqNgJ0IAQoAnAgEXRBACAIa3YgB2ohCCAEQfAAahAPGgsgBCkCnAEhRCAEIAg2ApwBIAQgRDcCoAEMAQsCQCACRQRAIAMEQCAEKAKcASEIDAMLIAQoAqABIQgMAQsgBCAEKAJ0IgJBAWo2AnQCfyAHIANFaiAEKAJwIAJ0QR92aiICQQNGBEAgBCgCnAFBAWsMAQsgAkECdCAEaigCnAELIgdFIAdqIQggAkEBRwRAIAQgBCgCoAE2AqQBCwsgBCAEKAKcATYCoAEgBCAINgKcAQunIQIgQUKAgPwHg1BFBEAgBCAEKAJ0IgcgGmo2AnQgBCgCcCAHdEEAIB9rdiACaiECCyALIBpqQRRPBEAgBEHwAGoQDxoLIEBCgID8B4NQRQRAIAQgBCgCdCIHIAtqNgJ0IAQoAnAgB3RBACAZa3YgA2ohAwsgBEHwAGoQDxogBCAEKAJwIgdBACAKQRh2IgsgBCgCdGoiGmt2IAtBAnRBoB1qKAIAcSAKQf//A3FqNgKEASAEIBogFkEYdiIKaiILNgJ0IAQgCkECdEGgHWooAgAgB0EAIAtrdnEgFkH//wNxajYClAEgBEHwAGoQDxogBCBCpyIHQRh2IgogBCgCdGoiCzYCdCAEIApBAnRBoB1qKAIAIAQoAnBBACALa3ZxIAdB//8DcWo2AowBIAQgAzYCOCAEIAI2AjwgBCAINgJAAkACQAJAIAQoAtwBIgsgA2oiFiAQSw0AIAYgAiADaiIKaiAYSw0AIApBIGogDCAGa00NAQsgBCAEQUBrKAIANgIIIAQgBCkDODcDACAGIAwgBCAEQdwBaiAQIBIgEyANEB8hCgwBCyADIAZqIQcgBiALKQAANwAAIAYgCykACDcACAJAIANBEUkNACAGIAspABA3ABAgBiALKQAYNwAYIANBEGtBEUgNACALQRBqIQMgBkEgaiELA0AgCyADKQAQNwAAIAsgAykAGDcACCALIAMpACA3ABAgCyADKQAoNwAYIANBIGohAyALQSBqIgsgB0kNAAsLIAcgCGshAyAEIBY2AtwBIAcgEmsgCEkEQCAIIAcgE2tLDQQgDSANIAMgEmsiA2oiCyACak8EQCAHIAsgAhAKGgwCCyAHIAtBACADaxAKIAQgAiADaiICNgI8IANrIQcgEiEDCyAIQRBPBEAgByADKQAANwAAIAcgAykACDcACCACQRFIDQEgAiAHaiEIIAdBEGohAgNAIAIgAykAEDcAACACIAMpABg3AAggAiADKQAgNwAQIAIgAykAKDcAGCADQSBqIQMgAkEgaiICIAhJDQALDAELAkAgCEEHTQRAIAcgAy0AADoAACAHIAMtAAE6AAEgByADLQACOgACIAcgAy0AAzoAAyAHIAMgCEECdCIIQcAeaigCAGoiAygAADYABCADIAhB4B5qKAIAayEDDAELIAcgAykAADcAAAsgAkEJSQ0AIAIgB2ohCyAHQQhqIgggA0EIaiIDa0EPTARAA0AgCCADKQAANwAAIANBCGohAyAIQQhqIgggC0kNAAwCCwALIAggAykAADcAACAIIAMpAAg3AAggAkEZSA0AIAdBGGohAgNAIAIgAykAEDcAACACIAMpABg3AAggAiADKQAgNwAQIAIgAykAKDcAGCADQSBqIQMgAkEgaiICIAtJDQALCyAKQYh/SwRAIAohCQwDCyAGIApqIQYgBEHwAGoQDyEDIA9B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";var Ot=new wA,Tt=!1;async function ce(A,t,I){let e=null;typeof A!="string"?e=A.href:A.startsWith("http")?e=A:e=`${t}/${A}`,e.endsWith(".js")&&(e=e.substring(0,e.length-3)),e.endsWith(".wasm")&&(e=e.substring(0,e.length-5));let g=`${e}.wasm`,r=await yA.get(`${g}.zst`,{responseType:"arraybuffer",params:I});Tt||(await Ot.init(),Tt=!0);let n=Ot.decode(new Uint8Array(r.data)).buffer;return(await import(`${e}.js`)).default({wasmBinary:n})}var Pt=ce;var mA=new Map;async function fe(A,t,I){let e=A,g=A,r=null;return typeof A!="string"&&(e=new URL(A.href),g=e.href),mA.has(g)?r=await mA.get(g):(mA.set(g,Pt(e,t,I)),r=await mA.get(g)),r}var xt=fe;var le={TextFile:"TextFile",BinaryFile:"BinaryFile",TextStream:"TextStream",BinaryStream:"BinaryStream",Image:"Image",PointSet:"PointSet",Mesh:"Mesh",PolyData:"PolyData",TransformList:"TransformList",JsonCompatible:"JsonCompatible"},D=le;var De={Int8:"int8",UInt8:"uint8",Int16:"int16",UInt16:"uint16",Int32:"int32",UInt32:"uint32",Int64:"int64",UInt64:"uint64",SizeValueType:"uint64",IdentifierType:"uint64",IndexValueType:"int64",OffsetValueType:"int64"},S=De;var ue={Float32:"float32",Float64:"float64",SpacePrecisionType:"float64"},j=ue;function he(A,t){let I=null;switch(A){case S.UInt8:{I=new Uint8Array(t);break}case S.Int8:{I=new Int8Array(t);break}case S.UInt16:{I=new Uint16Array(t);break}case S.Int16:{I=new Int16Array(t);break}case S.UInt32:{I=new Uint32Array(t);break}case S.Int32:{I=new Int32Array(t);break}case S.UInt64:{typeof globalThis.BigUint64Array=="function"?I=new BigUint64Array(t):I=new Uint8Array(t);break}case S.Int64:{typeof globalThis.BigInt64Array=="function"?I=new BigInt64Array(t):I=new Uint8Array(t);break}case j.Float32:{I=new Float32Array(t);break}case j.Float64:{I=new Float64Array(t);break}case"null":{I=null;break}case null:{I=null;break}default:throw new Error("Type is not supported as a TypedArray")}return I}var G=he;var Zt=typeof globalThis.SharedArrayBuffer=="function",jt=new TextEncoder,Wt=new TextDecoder("utf-8");function de(A,t){let I={flags:"r",encoding:"binary"},e=A.fs_open(t,I.flags),r=A.fs_stat(t).size,o=null;Zt?o=new SharedArrayBuffer(r):o=new ArrayBuffer(r);let n=new Uint8Array(o);return A.fs_read(e,n,0,r,0),A.fs_close(e),n}function Vt(A,t,I){let e=null;Zt?e=new SharedArrayBuffer(I):e=new ArrayBuffer(I);let g=new Uint8Array(e),r=new Uint8Array(A.HEAPU8.buffer,t,I);return g.set(r),g}function d(A,t,I,e){let g=0;return t!==null&&(g=A.ccall("itk_wasm_input_array_alloc","number",["number","number","number","number"],[0,I,e,t.buffer.byteLength]),A.HEAPU8.set(new Uint8Array(t.buffer),g)),g}function b(A,t,I){let e=JSON.stringify(t),g=A.lengthBytesUTF8(e)+1,r=A.ccall("itk_wasm_input_json_alloc","number",["number","number","number"],[0,I,g]);A.stringToUTF8(e,r,g)}function w(A,t,I,e){let g=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,t,I]),r=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,t,I]),o=Vt(A,g,r);return G(e,o.buffer)}function IA(A,t){let I=A.ccall("itk_wasm_output_json_address","number",["number","number"],[0,t]),e=A.UTF8ToString(I);return JSON.parse(e)}function ye(A,t,I,e){e!=null&&e.length>0&&e.forEach(function(Q,B){switch(Q.type){case D.TextStream:{let i=jt.encode(Q.data.data),f=d(A,i,B,0),s={size:i.buffer.byteLength,data:`data:application/vnd.itk.address,0:${f}`};b(A,s,B);break}case D.JsonCompatible:{let i=jt.encode(JSON.stringify(Q.data)),f=d(A,i,B,0),s={size:i.buffer.byteLength,data:`data:application/vnd.itk.address,0:${f}`};b(A,s,B);break}case D.BinaryStream:{let i=Q.data.data,f=d(A,i,B,0),s={size:i.buffer.byteLength,data:`data:application/vnd.itk.address,0:${f}`};b(A,s,B);break}case D.TextFile:{A.fs_writeFile(Q.data.path,Q.data.data);break}case D.BinaryFile:{A.fs_writeFile(Q.data.path,Q.data.data);break}case D.Image:{let i=Q.data,f=d(A,i.data,B,0),s=d(A,i.direction,B,1),a=typeof i.metadata?.entries<"u"?Array.from(i.metadata.entries()):[],E={imageType:i.imageType,name:i.name,origin:i.origin,spacing:i.spacing,direction:`data:application/vnd.itk.address,0:${s}`,size:i.size,data:`data:application/vnd.itk.address,0:${f}`,metadata:a};b(A,E,B);break}case D.Mesh:{let i=Q.data,f=d(A,i.points,B,0),s=d(A,i.cells,B,1),a=d(A,i.pointData,B,2),E=d(A,i.cellData,B,3),u={meshType:i.meshType,name:i.name,numberOfPoints:i.numberOfPoints,points:`data:application/vnd.itk.address,0:${f}`,numberOfCells:i.numberOfCells,cells:`data:application/vnd.itk.address,0:${s}`,cellBufferSize:i.cellBufferSize,numberOfPointPixels:i.numberOfPointPixels,pointData:`data:application/vnd.itk.address,0:${a}`,numberOfCellPixels:i.numberOfCellPixels,cellData:`data:application/vnd.itk.address,0:${E}`};b(A,u,B);break}case D.PointSet:{let i=Q.data,f=d(A,i.points,B,0),s=d(A,i.pointData,B,1),a={pointSetType:i.pointSetType,name:i.name,numberOfPoints:i.numberOfPoints,points:`data:application/vnd.itk.address,0:${f}`,numberOfPointPixels:i.numberOfPointPixels,pointData:`data:application/vnd.itk.address,0:${s}`};b(A,a,B);break}case D.TransformList:{let i=Q.data,f=[];i.forEach((s,a)=>{let u=`data:application/vnd.itk.address,0:${d(A,s.fixedParameters,B,a*2)}`,F=`data:application/vnd.itk.address,0:${d(A,s.parameters,B,a*2+1)}`,R={transformType:s.transformType,numberOfFixedParameters:s.numberOfFixedParameters,numberOfParameters:s.numberOfParameters,name:s.name,inputSpaceName:s.inputSpaceName,outputSpaceName:s.outputSpaceName,parameters:F,fixedParameters:u};f.push(R)}),b(A,f,B);break}case D.PolyData:{let i=Q.data,f=d(A,i.points,B,0),s=d(A,i.vertices,B,1),a=d(A,i.lines,B,2),E=d(A,i.polygons,B,3),u=d(A,i.triangleStrips,B,4),y=d(A,i.pointData,B,5),F=d(A,i.pointData,B,6),R={polyDataType:i.polyDataType,name:i.name,numberOfPoints:i.numberOfPoints,points:`data:application/vnd.itk.address,0:${f}`,verticesBufferSize:i.verticesBufferSize,vertices:`data:application/vnd.itk.address,0:${s}`,linesBufferSize:i.linesBufferSize,lines:`data:application/vnd.itk.address,0:${a}`,polygonsBufferSize:i.polygonsBufferSize,polygons:`data:application/vnd.itk.address,0:${E}`,triangleStripsBufferSize:i.triangleStripsBufferSize,triangleStrips:`data:application/vnd.itk.address,0:${u}`,numberOfPointPixels:i.numberOfPointPixels,pointData:`data:application/vnd.itk.address,0:${y}`,numberOfCellPixels:i.numberOfCellPixels,cellData:`data:application/vnd.itk.address,0:${F}`};b(A,R,B);break}default:throw Error("Unsupported input InterfaceType")}}),A.resetModuleStdout(),A.resetModuleStderr();let g=A.stackSave(),r=0;try{r=A.callMain(t.slice())}catch(Q){throw typeof Q=="number"&&(console.log("Exception while running pipeline:"),console.log("stdout:",A.getModuleStdout()),console.error("stderr:",A.getModuleStderr()),typeof A.getExceptionMessage<"u"?console.error("exception:",A.getExceptionMessage(Q)):console.error("Build module in Debug mode for exception message information.")),Q}finally{A.stackRestore(g)}let o=A.getModuleStdout(),n=A.getModuleStderr(),c=[];return I!=null&&I.length>0&&r===0&&I.forEach(function(Q,B){let i=null;switch(Q.type){case D.TextStream:{let s=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,B,0]),a=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,B,0]),E=new Uint8Array(A.HEAPU8.buffer,s,a);i={data:Wt.decode(E)};break}case D.JsonCompatible:{let s=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,B,0]),a=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,B,0]),E=new Uint8Array(A.HEAPU8.buffer,s,a);i=JSON.parse(Wt.decode(E));break}case D.BinaryStream:{let s=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,B,0]),a=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,B,0]);i={data:Vt(A,s,a)};break}case D.TextFile:{i={path:Q.data.path,data:A.fs_readFile(Q.data.path,{encoding:"utf8"})};break}case D.BinaryFile:{i={path:Q.data.path,data:de(A,Q.data.path)};break}case D.Image:{let s=IA(A,B);s.data=w(A,B,0,s.imageType.componentType),s.direction=w(A,B,1,j.Float64),s.metadata=new Map(s.metadata),i=s;break}case D.Mesh:{let s=IA(A,B);s.numberOfPoints>0?s.points=w(A,B,0,s.meshType.pointComponentType):s.points=G(s.meshType.pointComponentType,new ArrayBuffer(0)),s.numberOfCells>0?s.cells=w(A,B,1,s.meshType.cellComponentType):s.cells=G(s.meshType.cellComponentType,new ArrayBuffer(0)),s.numberOfPointPixels>0?s.pointData=w(A,B,2,s.meshType.pointPixelComponentType):s.pointData=G(s.meshType.pointPixelComponentType,new ArrayBuffer(0)),s.numberOfCellPixels>0?s.cellData=w(A,B,3,s.meshType.cellPixelComponentType):s.cellData=G(s.meshType.cellPixelComponentType,new ArrayBuffer(0)),i=s;break}case D.PointSet:{let s=IA(A,B);s.numberOfPoints>0?s.points=w(A,B,0,s.pointSetType.pointComponentType):s.points=G(s.pointSetType.pointComponentType,new ArrayBuffer(0)),s.numberOfPointPixels>0?s.pointData=w(A,B,1,s.pointSetType.pointPixelComponentType):s.pointData=G(s.pointSetType.pointPixelComponentType,new ArrayBuffer(0)),i=s;break}case D.TransformList:{let s=IA(A,B);s.forEach((a,E)=>{a.numberOfFixedParameters>0&&(s[E].fixedParameters=w(A,B,E*2,a.transformType.parametersValueType)),a.numberOfFixedParameters>0&&(s[E].parameters=w(A,B,E*2+1,a.transformType.parametersValueType))}),i=s;break}case D.PolyData:{let s=IA(A,B);s.numberOfPoints>0?s.points=w(A,B,0,j.Float32):s.points=new Float32Array,s.verticesBufferSize>0?s.vertices=w(A,B,1,S.UInt32):s.vertices=new Uint32Array,s.linesBufferSize>0?s.lines=w(A,B,2,S.UInt32):s.lines=new Uint32Array,s.polygonsBufferSize>0?s.polygons=w(A,B,3,S.UInt32):s.polygons=new Uint32Array,s.triangleStripsBufferSize>0?s.triangleStrips=w(A,B,4,S.UInt32):s.triangleStrips=new Uint32Array,s.numberOfPointPixels>0?s.pointData=w(A,B,5,s.polyDataType.pointPixelComponentType):s.pointData=G(s.polyDataType.pointPixelComponentType,new ArrayBuffer(0)),s.numberOfCellPixels>0?s.cellData=w(A,B,6,s.polyDataType.cellPixelComponentType):s.cellData=G(s.polyDataType.cellPixelComponentType,new ArrayBuffer(0)),i=s;break}default:throw Error("Unsupported output InterfaceType")}let f={type:Q.type,data:i};c.push(f)}),{returnValue:r,stdout:o,stderr:n,outputs:c}}var Xt=ye;var we=typeof globalThis.SharedArrayBuffer<"u";function me(A,t){if(A==null)return[];let I=[];for(let e=0;e<A.length;e++){let g=pe(A[e],t);g!==null&&I.push(g)}return I}function pe(A,t){if(A==null)return null;let I=null;return A.buffer!==void 0?I=A.buffer:A.byteLength!==void 0&&(I=A),we&&I instanceof SharedArrayBuffer?null:t?I:I.slice(0)}var zt=me;function Se(A){return[A.data,A.direction]}var _t=Se;function Fe(A){return[A.points,A.pointData,A.cells,A.cellData]}var vt=Fe;function Re(A){return[A.points,A.vertices,A.lines,A.polygons,A.triangleStrips,A.pointData,A.cellData]}var $t=Re;async function Ne(A,t,I,e){let g=Xt(A,t,I,e),r=[];return g.outputs.forEach(function(o){if(o.type===D.BinaryStream||o.type===D.BinaryFile){let n=o.data;r.push(n)}else if(o.type===D.Image){let n=o.data;r.push(..._t(n))}else if(o.type===D.Mesh){let n=o.data;r.push(...vt(n))}else if(o.type===D.PolyData){let n=o.data;r.push(...$t(n))}}),FA(g,zt(r,!0))}var AI=Ne;var Ue={runPipeline:async function(A,t,I,e,g,r){let o=await xt(A,t,r);return await AI(o,I,e,g)}};CA(Ue);%0A/*! Bundled license information:%0A%0Acomlink/dist/esm/comlink.mjs:%0A  (**%0A   * @license%0A   * Copyright 2019 Google LLC%0A   * SPDX-License-Identifier: Apache-2.0%0A   *)%0A*/%0A';Bt(lt);export{w as getDefaultWebWorker,d as getPipelineWorkerUrl,h as getPipelinesBaseUrl,Xr as hdf5ReadTransform,Ao as hdf5WriteTransform,to as matReadTransform,oo as matWriteTransform,io as mncReadTransform,so as mncWriteTransform,hs as setDefaultWebWorker,Bt as setPipelineWorkerUrl,us as setPipelinesBaseUrl,go as txtReadTransform,Co as txtWriteTransform,kA as version,fo as wasmReadTransform,uo as wasmWriteTransform,Qo as wasmZstdReadTransform,mo as wasmZstdWriteTransform};
/*! Bundled license information:

comlink/dist/esm/comlink.mjs:
  (**
   * @license
   * Copyright 2019 Google LLC
   * SPDX-License-Identifier: Apache-2.0
   *)
*/
""" +default_js_module = """data:text/javascript;base64,var Ut=Object.defineProperty;var Nt=(A,e)=>{for(var t in e)Ut(A,t,{get:e[t],enumerable:!0})};var Tt="0.1.1",TA=Tt;var Lt={Int8:"int8",UInt8:"uint8",Int16:"int16",UInt16:"uint16",Int32:"int32",UInt32:"uint32",Int64:"int64",UInt64:"uint64",SizeValueType:"uint64",IdentifierType:"uint64",IndexValueType:"int64",OffsetValueType:"int64"},F=Lt;var Pt={Float32:"float32",Float64:"float64",SpacePrecisionType:"float64"},H=Pt;function Gt(A,e){let t=null;switch(A){case F.UInt8:{t=new Uint8Array(e);break}case F.Int8:{t=new Int8Array(e);break}case F.UInt16:{t=new Uint16Array(e);break}case F.Int16:{t=new Int16Array(e);break}case F.UInt32:{t=new Uint32Array(e);break}case F.Int32:{t=new Int32Array(e);break}case F.UInt64:{typeof globalThis.BigUint64Array=="function"?t=new BigUint64Array(e):t=new Uint8Array(e);break}case F.Int64:{typeof globalThis.BigInt64Array=="function"?t=new BigInt64Array(e):t=new Uint8Array(e);break}case H.Float32:{t=new Float32Array(e);break}case H.Float64:{t=new Float64Array(e);break}case"null":{t=null;break}case null:{t=null;break}default:throw new Error("Type is not supported as a TypedArray")}return t}var L=Gt;function Ot(A){let e=A.slice((A.lastIndexOf(".")-1>>>0)+2);if(e.toLowerCase()==="gz"){let t=A.slice(0,-3).lastIndexOf(".");e=A.slice((t-1>>>0)+2)}else if(e.toLowerCase()==="cbor"){let t=A.slice(0,-5).lastIndexOf(".");e=A.slice((t-1>>>0)+2)}else if(e.toLowerCase()==="zst"){let t=A.slice(0,-10).lastIndexOf(".");e=A.slice((t-1>>>0)+2)}else if(e.toLowerCase()==="zip"){let t=A.slice(0,-4).lastIndexOf(".");e=A.slice((t-1>>>0)+2)}return e}var AA=Ot;var xt={TextFile:"TextFile",BinaryFile:"BinaryFile",TextStream:"TextStream",BinaryStream:"BinaryStream",Image:"Image",PointSet:"PointSet",Mesh:"Mesh",PolyData:"PolyData",TransformList:"TransformList",JsonCompatible:"JsonCompatible"},E=xt;var ye=Symbol("Comlink.proxy"),Wt=Symbol("Comlink.endpoint"),GA=Symbol("Comlink.releaseProxy"),LA=Symbol("Comlink.finalizer"),CA=Symbol("Comlink.thrown"),he=A=>typeof A=="object"&&A!==null||typeof A=="function",Jt={canHandle:A=>he(A)&&A[ye],serialize(A){let{port1:e,port2:t}=new MessageChannel;return De(A,e),[t,[t]]},deserialize(A){return A.start(),OA(A)}},Mt={canHandle:A=>he(A)&&CA in A,serialize({value:A}){let e;return A instanceof Error?e={isError:!0,value:{message:A.message,name:A.name,stack:A.stack}}:e={isError:!1,value:A},[e,[]]},deserialize(A){throw A.isError?Object.assign(new Error(A.value.message),A.value):A.value}},we=new Map([["proxy",Jt],["throw",Mt]]);function Ht(A,e){for(let t of A)if(e===t||t==="*"||t instanceof RegExp&&t.test(e))return!0;return!1}function De(A,e=globalThis,t=["*"]){e.addEventListener("message",function r(n){if(!n||!n.data)return;if(!Ht(t,n.origin)){console.warn(`Invalid origin '${n.origin}' for comlink proxy`);return}let{id:o,type:i,path:l}=Object.assign({path:[]},n.data),u=(n.data.argumentList||[]).map(M),B;try{let s=l.slice(0,-1).reduce((c,I)=>c[I],A),a=l.reduce((c,I)=>c[I],A);switch(i){case"GET":B=a;break;case"SET":s[l.slice(-1)[0]]=M(n.data.value),B=!0;break;case"APPLY":B=a.apply(s,u);break;case"CONSTRUCT":{let c=new a(...u);B=vt(c)}break;case"ENDPOINT":{let{port1:c,port2:I}=new MessageChannel;De(A,I),B=xA(c,[c])}break;case"RELEASE":B=void 0;break;default:return}}catch(s){B={value:s,[CA]:0}}Promise.resolve(B).catch(s=>({value:s,[CA]:0})).then(s=>{let[a,c]=uA(s);e.postMessage(Object.assign(Object.assign({},a),{id:o}),c),i==="RELEASE"&&(e.removeEventListener("message",r),Se(e),LA in A&&typeof A[LA]=="function"&&A[LA]())}).catch(s=>{let[a,c]=uA({value:new TypeError("Unserializable return value"),[CA]:0});e.postMessage(Object.assign(Object.assign({},a),{id:o}),c)})}),e.start&&e.start()}function Yt(A){return A.constructor.name==="MessagePort"}function Se(A){Yt(A)&&A.close()}function OA(A,e){return PA(A,[],e)}function BA(A){if(A)throw new Error("Proxy has been released and is not useable")}function Re(A){return Y(A,{type:"RELEASE"}).then(()=>{Se(A)})}var fA=new WeakMap,cA="FinalizationRegistry"in globalThis&&new FinalizationRegistry(A=>{let e=(fA.get(A)||0)-1;fA.set(A,e),e===0&&Re(A)});function qt(A,e){let t=(fA.get(e)||0)+1;fA.set(e,t),cA&&cA.register(A,e,A)}function Kt(A){cA&&cA.unregister(A)}function PA(A,e=[],t=function(){}){let r=!1,n=new Proxy(t,{get(o,i){if(BA(r),i===GA)return()=>{Kt(n),Re(A),r=!0};if(i==="then"){if(e.length===0)return{then:()=>n};let l=Y(A,{type:"GET",path:e.map(u=>u.toString())}).then(M);return l.then.bind(l)}return PA(A,[...e,i])},set(o,i,l){BA(r);let[u,B]=uA(l);return Y(A,{type:"SET",path:[...e,i].map(s=>s.toString()),value:u},B).then(M)},apply(o,i,l){BA(r);let u=e[e.length-1];if(u===Wt)return Y(A,{type:"ENDPOINT"}).then(M);if(u==="bind")return PA(A,e.slice(0,-1));let[B,s]=de(l);return Y(A,{type:"APPLY",path:e.map(a=>a.toString()),argumentList:B},s).then(M)},construct(o,i){BA(r);let[l,u]=de(i);return Y(A,{type:"CONSTRUCT",path:e.map(B=>B.toString()),argumentList:l},u).then(M)}});return qt(n,A),n}function jt(A){return Array.prototype.concat.apply([],A)}function de(A){let e=A.map(uA);return[e.map(t=>t[0]),jt(e.map(t=>t[1]))]}var be=new WeakMap;function xA(A,e){return be.set(A,e),A}function vt(A){return Object.assign(A,{[ye]:!0})}function uA(A){for(let[e,t]of we)if(t.canHandle(A)){let[r,n]=t.serialize(A);return[{type:"HANDLER",name:e,value:r},n]}return[{type:"RAW",value:A},be.get(A)||[]]}function M(A){switch(A.type){case"HANDLER":return we.get(A.name).deserialize(A.value);case"RAW":return A.value}}function Y(A,e,t){return new Promise(r=>{let n=_t();A.addEventListener("message",function o(i){!i.data||!i.data.id||i.data.id!==n||(A.removeEventListener("message",o),r(i.data))}),A.start&&A.start(),A.postMessage(Object.assign({id:n},e),t)})}function _t(){return new Array(4).fill(0).map(()=>Math.floor(Math.random()*Number.MAX_SAFE_INTEGER).toString(16)).join("-")}function eA(A,e){return function(){return A.apply(e,arguments)}}var{toString:zt}=Object.prototype,{getPrototypeOf:MA}=Object,QA=(A=>e=>{let t=zt.call(e);return A[t]||(A[t]=t.slice(8,-1).toLowerCase())})(Object.create(null)),P=A=>(A=A.toLowerCase(),e=>QA(e)===A),pA=A=>e=>typeof e===A,{isArray:q}=Array,tA=pA("undefined");function Zt(A){return A!==null&&!tA(A)&&A.constructor!==null&&!tA(A.constructor)&&T(A.constructor.isBuffer)&&A.constructor.isBuffer(A)}var Ne=P("ArrayBuffer");function Vt(A){let e;return typeof ArrayBuffer<"u"&&ArrayBuffer.isView?e=ArrayBuffer.isView(A):e=A&&A.buffer&&Ne(A.buffer),e}var Xt=pA("string"),T=pA("function"),Te=pA("number"),mA=A=>A!==null&&typeof A=="object",$t=A=>A===!0||A===!1,EA=A=>{if(QA(A)!=="object")return!1;let e=MA(A);return(e===null||e===Object.prototype||Object.getPrototypeOf(e)===null)&&!(Symbol.toStringTag in A)&&!(Symbol.iterator in A)},Ar=P("Date"),er=P("File"),tr=P("Blob"),rr=P("FileList"),or=A=>mA(A)&&T(A.pipe),nr=A=>{let e;return A&&(typeof FormData=="function"&&A instanceof FormData||T(A.append)&&((e=QA(A))==="formdata"||e==="object"&&T(A.toString)&&A.toString()==="[object FormData]"))},ir=P("URLSearchParams"),ar=A=>A.trim?A.trim():A.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"");function rA(A,e,{allOwnKeys:t=!1}={}){if(A===null||typeof A>"u")return;let r,n;if(typeof A!="object"&&(A=[A]),q(A))for(r=0,n=A.length;r<n;r++)e.call(null,A[r],r,A);else{let o=t?Object.getOwnPropertyNames(A):Object.keys(A),i=o.length,l;for(r=0;r<i;r++)l=o[r],e.call(null,A[l],l,A)}}function Le(A,e){e=e.toLowerCase();let t=Object.keys(A),r=t.length,n;for(;r-- >0;)if(n=t[r],e===n.toLowerCase())return n;return null}var Pe=typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:global,Ge=A=>!tA(A)&&A!==Pe;function JA(){let{caseless:A}=Ge(this)&&this||{},e={},t=(r,n)=>{let o=A&&Le(e,n)||n;EA(e[o])&&EA(r)?e[o]=JA(e[o],r):EA(r)?e[o]=JA({},r):q(r)?e[o]=r.slice():e[o]=r};for(let r=0,n=arguments.length;r<n;r++)arguments[r]&&rA(arguments[r],t);return e}var sr=(A,e,t,{allOwnKeys:r}={})=>(rA(e,(n,o)=>{t&&T(n)?A[o]=eA(n,t):A[o]=n},{allOwnKeys:r}),A),Ir=A=>(A.charCodeAt(0)===65279&&(A=A.slice(1)),A),gr=(A,e,t,r)=>{A.prototype=Object.create(e.prototype,r),A.prototype.constructor=A,Object.defineProperty(A,"super",{value:e.prototype}),t&&Object.assign(A.prototype,t)},lr=(A,e,t,r)=>{let n,o,i,l={};if(e=e||{},A==null)return e;do{for(n=Object.getOwnPropertyNames(A),o=n.length;o-- >0;)i=n[o],(!r||r(i,A,e))&&!l[i]&&(e[i]=A[i],l[i]=!0);A=t!==!1&&MA(A)}while(A&&(!t||t(A,e))&&A!==Object.prototype);return e},Br=(A,e,t)=>{A=String(A),(t===void 0||t>A.length)&&(t=A.length),t-=e.length;let r=A.indexOf(e,t);return r!==-1&&r===t},Cr=A=>{if(!A)return null;if(q(A))return A;let e=A.length;if(!Te(e))return null;let t=new Array(e);for(;e-- >0;)t[e]=A[e];return t},fr=(A=>e=>A&&e instanceof A)(typeof Uint8Array<"u"&&MA(Uint8Array)),cr=(A,e)=>{let r=(A&&A[Symbol.iterator]).call(A),n;for(;(n=r.next())&&!n.done;){let o=n.value;e.call(A,o[0],o[1])}},ur=(A,e)=>{let t,r=[];for(;(t=A.exec(e))!==null;)r.push(t);return r},Er=P("HTMLFormElement"),Qr=A=>A.toLowerCase().replace(/[-_\s]([a-z\d])(\w*)/g,function(t,r,n){return r.toUpperCase()+n}),Fe=(({hasOwnProperty:A})=>(e,t)=>A.call(e,t))(Object.prototype),pr=P("RegExp"),Oe=(A,e)=>{let t=Object.getOwnPropertyDescriptors(A),r={};rA(t,(n,o)=>{let i;(i=e(n,o,A))!==!1&&(r[o]=i||n)}),Object.defineProperties(A,r)},mr=A=>{Oe(A,(e,t)=>{if(T(A)&&["arguments","caller","callee"].indexOf(t)!==-1)return!1;let r=A[t];if(T(r)){if(e.enumerable=!1,"writable"in e){e.writable=!1;return}e.set||(e.set=()=>{throw Error("Can not rewrite read-only method '"+t+"'")})}})},dr=(A,e)=>{let t={},r=n=>{n.forEach(o=>{t[o]=!0})};return q(A)?r(A):r(String(A).split(e)),t},yr=()=>{},hr=(A,e)=>(A=+A,Number.isFinite(A)?A:e),WA="abcdefghijklmnopqrstuvwxyz",Ue="0123456789",xe={DIGIT:Ue,ALPHA:WA,ALPHA_DIGIT:WA+WA.toUpperCase()+Ue},wr=(A=16,e=xe.ALPHA_DIGIT)=>{let t="",{length:r}=e;for(;A--;)t+=e[Math.random()*r|0];return t};function Dr(A){return!!(A&&T(A.append)&&A[Symbol.toStringTag]==="FormData"&&A[Symbol.iterator])}var Sr=A=>{let e=new Array(10),t=(r,n)=>{if(mA(r)){if(e.indexOf(r)>=0)return;if(!("toJSON"in r)){e[n]=r;let o=q(r)?[]:{};return rA(r,(i,l)=>{let u=t(i,n+1);!tA(u)&&(o[l]=u)}),e[n]=void 0,o}}return r};return t(A,0)},Rr=P("AsyncFunction"),br=A=>A&&(mA(A)||T(A))&&T(A.then)&&T(A.catch),g={isArray:q,isArrayBuffer:Ne,isBuffer:Zt,isFormData:nr,isArrayBufferView:Vt,isString:Xt,isNumber:Te,isBoolean:$t,isObject:mA,isPlainObject:EA,isUndefined:tA,isDate:Ar,isFile:er,isBlob:tr,isRegExp:pr,isFunction:T,isStream:or,isURLSearchParams:ir,isTypedArray:fr,isFileList:rr,forEach:rA,merge:JA,extend:sr,trim:ar,stripBOM:Ir,inherits:gr,toFlatObject:lr,kindOf:QA,kindOfTest:P,endsWith:Br,toArray:Cr,forEachEntry:cr,matchAll:ur,isHTMLForm:Er,hasOwnProperty:Fe,hasOwnProp:Fe,reduceDescriptors:Oe,freezeMethods:mr,toObjectSet:dr,toCamelCase:Qr,noop:yr,toFiniteNumber:hr,findKey:Le,global:Pe,isContextDefined:Ge,ALPHABET:xe,generateString:wr,isSpecCompliantForm:Dr,toJSONObject:Sr,isAsyncFn:Rr,isThenable:br};function K(A,e,t,r,n){Error.call(this),Error.captureStackTrace?Error.captureStackTrace(this,this.constructor):this.stack=new Error().stack,this.message=A,this.name="AxiosError",e&&(this.code=e),t&&(this.config=t),r&&(this.request=r),n&&(this.response=n)}g.inherits(K,Error,{toJSON:function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:g.toJSONObject(this.config),code:this.code,status:this.response&&this.response.status?this.response.status:null}}});var We=K.prototype,Je={};["ERR_BAD_OPTION_VALUE","ERR_BAD_OPTION","ECONNABORTED","ETIMEDOUT","ERR_NETWORK","ERR_FR_TOO_MANY_REDIRECTS","ERR_DEPRECATED","ERR_BAD_RESPONSE","ERR_BAD_REQUEST","ERR_CANCELED","ERR_NOT_SUPPORT","ERR_INVALID_URL"].forEach(A=>{Je[A]={value:A}});Object.defineProperties(K,Je);Object.defineProperty(We,"isAxiosError",{value:!0});K.from=(A,e,t,r,n,o)=>{let i=Object.create(We);return g.toFlatObject(A,i,function(u){return u!==Error.prototype},l=>l!=="isAxiosError"),K.call(i,A.message,e,t,r,n),i.cause=A,i.name=A.name,o&&Object.assign(i,o),i};var p=K;var dA=null;function HA(A){return g.isPlainObject(A)||g.isArray(A)}function He(A){return g.endsWith(A,"[]")?A.slice(0,-2):A}function Me(A,e,t){return A?A.concat(e).map(function(n,o){return n=He(n),!t&&o?"["+n+"]":n}).join(t?".":""):e}function kr(A){return g.isArray(A)&&!A.some(HA)}var Fr=g.toFlatObject(g,{},null,function(e){return/^is[A-Z]/.test(e)});function Ur(A,e,t){if(!g.isObject(A))throw new TypeError("target must be an object");e=e||new(dA||FormData),t=g.toFlatObject(t,{metaTokens:!0,dots:!1,indexes:!1},!1,function(f,Q){return!g.isUndefined(Q[f])});let r=t.metaTokens,n=t.visitor||s,o=t.dots,i=t.indexes,u=(t.Blob||typeof Blob<"u"&&Blob)&&g.isSpecCompliantForm(e);if(!g.isFunction(n))throw new TypeError("visitor must be a function");function B(C){if(C===null)return"";if(g.isDate(C))return C.toISOString();if(!u&&g.isBlob(C))throw new p("Blob is not supported. Use a Buffer instead.");return g.isArrayBuffer(C)||g.isTypedArray(C)?u&&typeof Blob=="function"?new Blob([C]):Buffer.from(C):C}function s(C,f,Q){let m=C;if(C&&!Q&&typeof C=="object"){if(g.endsWith(f,"{}"))f=r?f:f.slice(0,-2),C=JSON.stringify(C);else if(g.isArray(C)&&kr(C)||(g.isFileList(C)||g.endsWith(f,"[]"))&&(m=g.toArray(C)))return f=He(f),m.forEach(function(N,Ft){!(g.isUndefined(N)||N===null)&&e.append(i===!0?Me([f],Ft,o):i===null?f:f+"[]",B(N))}),!1}return HA(C)?!0:(e.append(Me(Q,f,o),B(C)),!1)}let a=[],c=Object.assign(Fr,{defaultVisitor:s,convertValue:B,isVisitable:HA});function I(C,f){if(!g.isUndefined(C)){if(a.indexOf(C)!==-1)throw Error("Circular reference detected in "+f.join("."));a.push(C),g.forEach(C,function(m,U){(!(g.isUndefined(m)||m===null)&&n.call(e,m,g.isString(U)?U.trim():U,f,c))===!0&&I(m,f?f.concat(U):[U])}),a.pop()}}if(!g.isObject(A))throw new TypeError("data must be an object");return I(A),e}var O=Ur;function Ye(A){let e={"!":"%21","'":"%27","(":"%28",")":"%29","~":"%7E","%20":"+","%00":"\0"};return encodeURIComponent(A).replace(/[!'()~]|%20|%00/g,function(r){return e[r]})}function qe(A,e){this._pairs=[],A&&O(A,this,e)}var Ke=qe.prototype;Ke.append=function(e,t){this._pairs.push([e,t])};Ke.toString=function(e){let t=e?function(r){return e.call(this,r,Ye)}:Ye;return this._pairs.map(function(n){return t(n[0])+"="+t(n[1])},"").join("&")};var yA=qe;function Nr(A){return encodeURIComponent(A).replace(/%3A/gi,":").replace(/%24/g,"$").replace(/%2C/gi,",").replace(/%20/g,"+").replace(/%5B/gi,"[").replace(/%5D/gi,"]")}function oA(A,e,t){if(!e)return A;let r=t&&t.encode||Nr,n=t&&t.serialize,o;if(n?o=n(e,t):o=g.isURLSearchParams(e)?e.toString():new yA(e,t).toString(r),o){let i=A.indexOf("#");i!==-1&&(A=A.slice(0,i)),A+=(A.indexOf("?")===-1?"?":"&")+o}return A}var YA=class{constructor(){this.handlers=[]}use(e,t,r){return this.handlers.push({fulfilled:e,rejected:t,synchronous:r?r.synchronous:!1,runWhen:r?r.runWhen:null}),this.handlers.length-1}eject(e){this.handlers[e]&&(this.handlers[e]=null)}clear(){this.handlers&&(this.handlers=[])}forEach(e){g.forEach(this.handlers,function(r){r!==null&&e(r)})}},qA=YA;var hA={silentJSONParsing:!0,forcedJSONParsing:!0,clarifyTimeoutError:!1};var je=typeof URLSearchParams<"u"?URLSearchParams:yA;var ve=typeof FormData<"u"?FormData:null;var _e=typeof Blob<"u"?Blob:null;var ze={isBrowser:!0,classes:{URLSearchParams:je,FormData:ve,Blob:_e},protocols:["http","https","file","blob","url","data"]};var KA={};Nt(KA,{hasBrowserEnv:()=>Ze,hasStandardBrowserEnv:()=>Tr,hasStandardBrowserWebWorkerEnv:()=>Lr});var Ze=typeof window<"u"&&typeof document<"u",Tr=(A=>Ze&&["ReactNative","NativeScript","NS"].indexOf(A)<0)(typeof navigator<"u"&&navigator.product),Lr=typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope&&typeof self.importScripts=="function";var b={...KA,...ze};function jA(A,e){return O(A,new b.classes.URLSearchParams,Object.assign({visitor:function(t,r,n,o){return b.isNode&&g.isBuffer(t)?(this.append(r,t.toString("base64")),!1):o.defaultVisitor.apply(this,arguments)}},e))}function Pr(A){return g.matchAll(/\w+|\[(\w*)]/g,A).map(e=>e[0]==="[]"?"":e[1]||e[0])}function Gr(A){let e={},t=Object.keys(A),r,n=t.length,o;for(r=0;r<n;r++)o=t[r],e[o]=A[o];return e}function Or(A){function e(t,r,n,o){let i=t[o++];if(i==="__proto__")return!0;let l=Number.isFinite(+i),u=o>=t.length;return i=!i&&g.isArray(n)?n.length:i,u?(g.hasOwnProp(n,i)?n[i]=[n[i],r]:n[i]=r,!l):((!n[i]||!g.isObject(n[i]))&&(n[i]=[]),e(t,r,n[i],o)&&g.isArray(n[i])&&(n[i]=Gr(n[i])),!l)}if(g.isFormData(A)&&g.isFunction(A.entries)){let t={};return g.forEachEntry(A,(r,n)=>{e(Pr(r),n,t,0)}),t}return null}var wA=Or;function xr(A,e,t){if(g.isString(A))try{return(e||JSON.parse)(A),g.trim(A)}catch(r){if(r.name!=="SyntaxError")throw r}return(t||JSON.stringify)(A)}var vA={transitional:hA,adapter:["xhr","http"],transformRequest:[function(e,t){let r=t.getContentType()||"",n=r.indexOf("application/json")>-1,o=g.isObject(e);if(o&&g.isHTMLForm(e)&&(e=new FormData(e)),g.isFormData(e))return n?JSON.stringify(wA(e)):e;if(g.isArrayBuffer(e)||g.isBuffer(e)||g.isStream(e)||g.isFile(e)||g.isBlob(e))return e;if(g.isArrayBufferView(e))return e.buffer;if(g.isURLSearchParams(e))return t.setContentType("application/x-www-form-urlencoded;charset=utf-8",!1),e.toString();let l;if(o){if(r.indexOf("application/x-www-form-urlencoded")>-1)return jA(e,this.formSerializer).toString();if((l=g.isFileList(e))||r.indexOf("multipart/form-data")>-1){let u=this.env&&this.env.FormData;return O(l?{"files[]":e}:e,u&&new u,this.formSerializer)}}return o||n?(t.setContentType("application/json",!1),xr(e)):e}],transformResponse:[function(e){let t=this.transitional||vA.transitional,r=t&&t.forcedJSONParsing,n=this.responseType==="json";if(e&&g.isString(e)&&(r&&!this.responseType||n)){let i=!(t&&t.silentJSONParsing)&&n;try{return JSON.parse(e)}catch(l){if(i)throw l.name==="SyntaxError"?p.from(l,p.ERR_BAD_RESPONSE,this,null,this.response):l}}return e}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,maxBodyLength:-1,env:{FormData:b.classes.FormData,Blob:b.classes.Blob},validateStatus:function(e){return e>=200&&e<300},headers:{common:{Accept:"application/json, text/plain, */*","Content-Type":void 0}}};g.forEach(["delete","get","head","post","put","patch"],A=>{vA.headers[A]={}});var j=vA;var Wr=g.toObjectSet(["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"]),Ve=A=>{let e={},t,r,n;return A&&A.split(`
`).forEach(function(i){n=i.indexOf(":"),t=i.substring(0,n).trim().toLowerCase(),r=i.substring(n+1).trim(),!(!t||e[t]&&Wr[t])&&(t==="set-cookie"?e[t]?e[t].push(r):e[t]=[r]:e[t]=e[t]?e[t]+", "+r:r)}),e};var Xe=Symbol("internals");function nA(A){return A&&String(A).trim().toLowerCase()}function DA(A){return A===!1||A==null?A:g.isArray(A)?A.map(DA):String(A)}function Jr(A){let e=Object.create(null),t=/([^\s,;=]+)\s*(?:=\s*([^,;]+))?/g,r;for(;r=t.exec(A);)e[r[1]]=r[2];return e}var Mr=A=>/^[-_a-zA-Z0-9^`|~,!#$%&'*+.]+$/.test(A.trim());function _A(A,e,t,r,n){if(g.isFunction(r))return r.call(this,e,t);if(n&&(e=t),!!g.isString(e)){if(g.isString(r))return e.indexOf(r)!==-1;if(g.isRegExp(r))return r.test(e)}}function Hr(A){return A.trim().toLowerCase().replace(/([a-z\d])(\w*)/g,(e,t,r)=>t.toUpperCase()+r)}function Yr(A,e){let t=g.toCamelCase(" "+e);["get","set","has"].forEach(r=>{Object.defineProperty(A,r+t,{value:function(n,o,i){return this[r].call(this,e,n,o,i)},configurable:!0})})}var v=class{constructor(e){e&&this.set(e)}set(e,t,r){let n=this;function o(l,u,B){let s=nA(u);if(!s)throw new Error("header name must be a non-empty string");let a=g.findKey(n,s);(!a||n[a]===void 0||B===!0||B===void 0&&n[a]!==!1)&&(n[a||u]=DA(l))}let i=(l,u)=>g.forEach(l,(B,s)=>o(B,s,u));return g.isPlainObject(e)||e instanceof this.constructor?i(e,t):g.isString(e)&&(e=e.trim())&&!Mr(e)?i(Ve(e),t):e!=null&&o(t,e,r),this}get(e,t){if(e=nA(e),e){let r=g.findKey(this,e);if(r){let n=this[r];if(!t)return n;if(t===!0)return Jr(n);if(g.isFunction(t))return t.call(this,n,r);if(g.isRegExp(t))return t.exec(n);throw new TypeError("parser must be boolean|regexp|function")}}}has(e,t){if(e=nA(e),e){let r=g.findKey(this,e);return!!(r&&this[r]!==void 0&&(!t||_A(this,this[r],r,t)))}return!1}delete(e,t){let r=this,n=!1;function o(i){if(i=nA(i),i){let l=g.findKey(r,i);l&&(!t||_A(r,r[l],l,t))&&(delete r[l],n=!0)}}return g.isArray(e)?e.forEach(o):o(e),n}clear(e){let t=Object.keys(this),r=t.length,n=!1;for(;r--;){let o=t[r];(!e||_A(this,this[o],o,e,!0))&&(delete this[o],n=!0)}return n}normalize(e){let t=this,r={};return g.forEach(this,(n,o)=>{let i=g.findKey(r,o);if(i){t[i]=DA(n),delete t[o];return}let l=e?Hr(o):String(o).trim();l!==o&&delete t[o],t[l]=DA(n),r[l]=!0}),this}concat(...e){return this.constructor.concat(this,...e)}toJSON(e){let t=Object.create(null);return g.forEach(this,(r,n)=>{r!=null&&r!==!1&&(t[n]=e&&g.isArray(r)?r.join(", "):r)}),t}[Symbol.iterator](){return Object.entries(this.toJSON())[Symbol.iterator]()}toString(){return Object.entries(this.toJSON()).map(([e,t])=>e+": "+t).join(`
`)}get[Symbol.toStringTag](){return"AxiosHeaders"}static from(e){return e instanceof this?e:new this(e)}static concat(e,...t){let r=new this(e);return t.forEach(n=>r.set(n)),r}static accessor(e){let r=(this[Xe]=this[Xe]={accessors:{}}).accessors,n=this.prototype;function o(i){let l=nA(i);r[l]||(Yr(n,i),r[l]=!0)}return g.isArray(e)?e.forEach(o):o(e),this}};v.accessor(["Content-Type","Content-Length","Accept","Accept-Encoding","User-Agent","Authorization"]);g.reduceDescriptors(v.prototype,({value:A},e)=>{let t=e[0].toUpperCase()+e.slice(1);return{get:()=>A,set(r){this[t]=r}}});g.freezeMethods(v);var k=v;function iA(A,e){let t=this||j,r=e||t,n=k.from(r.headers),o=r.data;return g.forEach(A,function(l){o=l.call(t,o,n.normalize(),e?e.status:void 0)}),n.normalize(),o}function aA(A){return!!(A&&A.__CANCEL__)}function $e(A,e,t){p.call(this,A??"canceled",p.ERR_CANCELED,e,t),this.name="CanceledError"}g.inherits($e,p,{__CANCEL__:!0});var x=$e;function zA(A,e,t){let r=t.config.validateStatus;!t.status||!r||r(t.status)?A(t):e(new p("Request failed with status code "+t.status,[p.ERR_BAD_REQUEST,p.ERR_BAD_RESPONSE][Math.floor(t.status/100)-4],t.config,t.request,t))}var At=b.hasStandardBrowserEnv?{write(A,e,t,r,n,o){let i=[A+"="+encodeURIComponent(e)];g.isNumber(t)&&i.push("expires="+new Date(t).toGMTString()),g.isString(r)&&i.push("path="+r),g.isString(n)&&i.push("domain="+n),o===!0&&i.push("secure"),document.cookie=i.join("; ")},read(A){let e=document.cookie.match(new RegExp("(^|;\\s*)("+A+")=([^;]*)"));return e?decodeURIComponent(e[3]):null},remove(A){this.write(A,"",Date.now()-864e5)}}:{write(){},read(){return null},remove(){}};function ZA(A){return/^([a-z][a-z\d+\-.]*:)?\/\//i.test(A)}function VA(A,e){return e?A.replace(/\/?\/$/,"")+"/"+e.replace(/^\/+/,""):A}function sA(A,e){return A&&!ZA(e)?VA(A,e):e}var et=b.hasStandardBrowserEnv?function(){let e=/(msie|trident)/i.test(navigator.userAgent),t=document.createElement("a"),r;function n(o){let i=o;return e&&(t.setAttribute("href",i),i=t.href),t.setAttribute("href",i),{href:t.href,protocol:t.protocol?t.protocol.replace(/:$/,""):"",host:t.host,search:t.search?t.search.replace(/^\?/,""):"",hash:t.hash?t.hash.replace(/^#/,""):"",hostname:t.hostname,port:t.port,pathname:t.pathname.charAt(0)==="/"?t.pathname:"/"+t.pathname}}return r=n(window.location.href),function(i){let l=g.isString(i)?n(i):i;return l.protocol===r.protocol&&l.host===r.host}}():function(){return function(){return!0}}();function XA(A){let e=/^([-+\w]{1,25})(:?\/\/|:)/.exec(A);return e&&e[1]||""}function qr(A,e){A=A||10;let t=new Array(A),r=new Array(A),n=0,o=0,i;return e=e!==void 0?e:1e3,function(u){let B=Date.now(),s=r[o];i||(i=B),t[n]=u,r[n]=B;let a=o,c=0;for(;a!==n;)c+=t[a++],a=a%A;if(n=(n+1)%A,n===o&&(o=(o+1)%A),B-i<e)return;let I=s&&B-s;return I?Math.round(c*1e3/I):void 0}}var tt=qr;function rt(A,e){let t=0,r=tt(50,250);return n=>{let o=n.loaded,i=n.lengthComputable?n.total:void 0,l=o-t,u=r(l),B=o<=i;t=o;let s={loaded:o,total:i,progress:i?o/i:void 0,bytes:l,rate:u||void 0,estimated:u&&i&&B?(i-o)/u:void 0,event:n};s[e?"download":"upload"]=!0,A(s)}}var Kr=typeof XMLHttpRequest<"u",ot=Kr&&function(A){return new Promise(function(t,r){let n=A.data,o=k.from(A.headers).normalize(),{responseType:i,withXSRFToken:l}=A,u;function B(){A.cancelToken&&A.cancelToken.unsubscribe(u),A.signal&&A.signal.removeEventListener("abort",u)}let s;if(g.isFormData(n)){if(b.hasStandardBrowserEnv||b.hasStandardBrowserWebWorkerEnv)o.setContentType(!1);else if((s=o.getContentType())!==!1){let[f,...Q]=s?s.split(";").map(m=>m.trim()).filter(Boolean):[];o.setContentType([f||"multipart/form-data",...Q].join("; "))}}let a=new XMLHttpRequest;if(A.auth){let f=A.auth.username||"",Q=A.auth.password?unescape(encodeURIComponent(A.auth.password)):"";o.set("Authorization","Basic "+btoa(f+":"+Q))}let c=sA(A.baseURL,A.url);a.open(A.method.toUpperCase(),oA(c,A.params,A.paramsSerializer),!0),a.timeout=A.timeout;function I(){if(!a)return;let f=k.from("getAllResponseHeaders"in a&&a.getAllResponseHeaders()),m={data:!i||i==="text"||i==="json"?a.responseText:a.response,status:a.status,statusText:a.statusText,headers:f,config:A,request:a};zA(function(N){t(N),B()},function(N){r(N),B()},m),a=null}if("onloadend"in a?a.onloadend=I:a.onreadystatechange=function(){!a||a.readyState!==4||a.status===0&&!(a.responseURL&&a.responseURL.indexOf("file:")===0)||setTimeout(I)},a.onabort=function(){a&&(r(new p("Request aborted",p.ECONNABORTED,A,a)),a=null)},a.onerror=function(){r(new p("Network Error",p.ERR_NETWORK,A,a)),a=null},a.ontimeout=function(){let Q=A.timeout?"timeout of "+A.timeout+"ms exceeded":"timeout exceeded",m=A.transitional||hA;A.timeoutErrorMessage&&(Q=A.timeoutErrorMessage),r(new p(Q,m.clarifyTimeoutError?p.ETIMEDOUT:p.ECONNABORTED,A,a)),a=null},b.hasStandardBrowserEnv&&(l&&g.isFunction(l)&&(l=l(A)),l||l!==!1&&et(c))){let f=A.xsrfHeaderName&&A.xsrfCookieName&&At.read(A.xsrfCookieName);f&&o.set(A.xsrfHeaderName,f)}n===void 0&&o.setContentType(null),"setRequestHeader"in a&&g.forEach(o.toJSON(),function(Q,m){a.setRequestHeader(m,Q)}),g.isUndefined(A.withCredentials)||(a.withCredentials=!!A.withCredentials),i&&i!=="json"&&(a.responseType=A.responseType),typeof A.onDownloadProgress=="function"&&a.addEventListener("progress",rt(A.onDownloadProgress,!0)),typeof A.onUploadProgress=="function"&&a.upload&&a.upload.addEventListener("progress",rt(A.onUploadProgress)),(A.cancelToken||A.signal)&&(u=f=>{a&&(r(!f||f.type?new x(null,A,a):f),a.abort(),a=null)},A.cancelToken&&A.cancelToken.subscribe(u),A.signal&&(A.signal.aborted?u():A.signal.addEventListener("abort",u)));let C=XA(c);if(C&&b.protocols.indexOf(C)===-1){r(new p("Unsupported protocol "+C+":",p.ERR_BAD_REQUEST,A));return}a.send(n||null)})};var $A={http:dA,xhr:ot};g.forEach($A,(A,e)=>{if(A){try{Object.defineProperty(A,"name",{value:e})}catch{}Object.defineProperty(A,"adapterName",{value:e})}});var nt=A=>`- ${A}`,jr=A=>g.isFunction(A)||A===null||A===!1,SA={getAdapter:A=>{A=g.isArray(A)?A:[A];let{length:e}=A,t,r,n={};for(let o=0;o<e;o++){t=A[o];let i;if(r=t,!jr(t)&&(r=$A[(i=String(t)).toLowerCase()],r===void 0))throw new p(`Unknown adapter '${i}'`);if(r)break;n[i||"#"+o]=r}if(!r){let o=Object.entries(n).map(([l,u])=>`adapter ${l} `+(u===!1?"is not supported by the environment":"is not available in the build")),i=e?o.length>1?`since :
`+o.map(nt).join(`
`):" "+nt(o[0]):"as no adapter specified";throw new p("There is no suitable adapter to dispatch the request "+i,"ERR_NOT_SUPPORT")}return r},adapters:$A};function Ae(A){if(A.cancelToken&&A.cancelToken.throwIfRequested(),A.signal&&A.signal.aborted)throw new x(null,A)}function RA(A){return Ae(A),A.headers=k.from(A.headers),A.data=iA.call(A,A.transformRequest),["post","put","patch"].indexOf(A.method)!==-1&&A.headers.setContentType("application/x-www-form-urlencoded",!1),SA.getAdapter(A.adapter||j.adapter)(A).then(function(r){return Ae(A),r.data=iA.call(A,A.transformResponse,r),r.headers=k.from(r.headers),r},function(r){return aA(r)||(Ae(A),r&&r.response&&(r.response.data=iA.call(A,A.transformResponse,r.response),r.response.headers=k.from(r.response.headers))),Promise.reject(r)})}var it=A=>A instanceof k?{...A}:A;function G(A,e){e=e||{};let t={};function r(B,s,a){return g.isPlainObject(B)&&g.isPlainObject(s)?g.merge.call({caseless:a},B,s):g.isPlainObject(s)?g.merge({},s):g.isArray(s)?s.slice():s}function n(B,s,a){if(g.isUndefined(s)){if(!g.isUndefined(B))return r(void 0,B,a)}else return r(B,s,a)}function o(B,s){if(!g.isUndefined(s))return r(void 0,s)}function i(B,s){if(g.isUndefined(s)){if(!g.isUndefined(B))return r(void 0,B)}else return r(void 0,s)}function l(B,s,a){if(a in e)return r(B,s);if(a in A)return r(void 0,B)}let u={url:o,method:o,data:o,baseURL:i,transformRequest:i,transformResponse:i,paramsSerializer:i,timeout:i,timeoutMessage:i,withCredentials:i,withXSRFToken:i,adapter:i,responseType:i,xsrfCookieName:i,xsrfHeaderName:i,onUploadProgress:i,onDownloadProgress:i,decompress:i,maxContentLength:i,maxBodyLength:i,beforeRedirect:i,transport:i,httpAgent:i,httpsAgent:i,cancelToken:i,socketPath:i,responseEncoding:i,validateStatus:l,headers:(B,s)=>n(it(B),it(s),!0)};return g.forEach(Object.keys(Object.assign({},A,e)),function(s){let a=u[s]||n,c=a(A[s],e[s],s);g.isUndefined(c)&&a!==l||(t[s]=c)}),t}var bA="1.6.8";var ee={};["object","boolean","number","function","string","symbol"].forEach((A,e)=>{ee[A]=function(r){return typeof r===A||"a"+(e<1?"n ":" ")+A}});var at={};ee.transitional=function(e,t,r){function n(o,i){return"[Axios v"+bA+"] Transitional option '"+o+"'"+i+(r?". "+r:"")}return(o,i,l)=>{if(e===!1)throw new p(n(i," has been removed"+(t?" in "+t:"")),p.ERR_DEPRECATED);return t&&!at[i]&&(at[i]=!0,console.warn(n(i," has been deprecated since v"+t+" and will be removed in the near future"))),e?e(o,i,l):!0}};function vr(A,e,t){if(typeof A!="object")throw new p("options must be an object",p.ERR_BAD_OPTION_VALUE);let r=Object.keys(A),n=r.length;for(;n-- >0;){let o=r[n],i=e[o];if(i){let l=A[o],u=l===void 0||i(l,o,A);if(u!==!0)throw new p("option "+o+" must be "+u,p.ERR_BAD_OPTION_VALUE);continue}if(t!==!0)throw new p("Unknown option "+o,p.ERR_BAD_OPTION)}}var kA={assertOptions:vr,validators:ee};var W=kA.validators,_=class{constructor(e){this.defaults=e,this.interceptors={request:new qA,response:new qA}}async request(e,t){try{return await this._request(e,t)}catch(r){if(r instanceof Error){let n;Error.captureStackTrace?Error.captureStackTrace(n={}):n=new Error;let o=n.stack?n.stack.replace(/^.+\n/,""):"";r.stack?o&&!String(r.stack).endsWith(o.replace(/^.+\n.+\n/,""))&&(r.stack+=`
`+o):r.stack=o}throw r}}_request(e,t){typeof e=="string"?(t=t||{},t.url=e):t=e||{},t=G(this.defaults,t);let{transitional:r,paramsSerializer:n,headers:o}=t;r!==void 0&&kA.assertOptions(r,{silentJSONParsing:W.transitional(W.boolean),forcedJSONParsing:W.transitional(W.boolean),clarifyTimeoutError:W.transitional(W.boolean)},!1),n!=null&&(g.isFunction(n)?t.paramsSerializer={serialize:n}:kA.assertOptions(n,{encode:W.function,serialize:W.function},!0)),t.method=(t.method||this.defaults.method||"get").toLowerCase();let i=o&&g.merge(o.common,o[t.method]);o&&g.forEach(["delete","get","head","post","put","patch","common"],C=>{delete o[C]}),t.headers=k.concat(i,o);let l=[],u=!0;this.interceptors.request.forEach(function(f){typeof f.runWhen=="function"&&f.runWhen(t)===!1||(u=u&&f.synchronous,l.unshift(f.fulfilled,f.rejected))});let B=[];this.interceptors.response.forEach(function(f){B.push(f.fulfilled,f.rejected)});let s,a=0,c;if(!u){let C=[RA.bind(this),void 0];for(C.unshift.apply(C,l),C.push.apply(C,B),c=C.length,s=Promise.resolve(t);a<c;)s=s.then(C[a++],C[a++]);return s}c=l.length;let I=t;for(a=0;a<c;){let C=l[a++],f=l[a++];try{I=C(I)}catch(Q){f.call(this,Q);break}}try{s=RA.call(this,I)}catch(C){return Promise.reject(C)}for(a=0,c=B.length;a<c;)s=s.then(B[a++],B[a++]);return s}getUri(e){e=G(this.defaults,e);let t=sA(e.baseURL,e.url);return oA(t,e.params,e.paramsSerializer)}};g.forEach(["delete","get","head","options"],function(e){_.prototype[e]=function(t,r){return this.request(G(r||{},{method:e,url:t,data:(r||{}).data}))}});g.forEach(["post","put","patch"],function(e){function t(r){return function(o,i,l){return this.request(G(l||{},{method:e,headers:r?{"Content-Type":"multipart/form-data"}:{},url:o,data:i}))}}_.prototype[e]=t(),_.prototype[e+"Form"]=t(!0)});var IA=_;var te=class A{constructor(e){if(typeof e!="function")throw new TypeError("executor must be a function.");let t;this.promise=new Promise(function(o){t=o});let r=this;this.promise.then(n=>{if(!r._listeners)return;let o=r._listeners.length;for(;o-- >0;)r._listeners[o](n);r._listeners=null}),this.promise.then=n=>{let o,i=new Promise(l=>{r.subscribe(l),o=l}).then(n);return i.cancel=function(){r.unsubscribe(o)},i},e(function(o,i,l){r.reason||(r.reason=new x(o,i,l),t(r.reason))})}throwIfRequested(){if(this.reason)throw this.reason}subscribe(e){if(this.reason){e(this.reason);return}this._listeners?this._listeners.push(e):this._listeners=[e]}unsubscribe(e){if(!this._listeners)return;let t=this._listeners.indexOf(e);t!==-1&&this._listeners.splice(t,1)}static source(){let e;return{token:new A(function(n){e=n}),cancel:e}}},st=te;function re(A){return function(t){return A.apply(null,t)}}function oe(A){return g.isObject(A)&&A.isAxiosError===!0}var ne={Continue:100,SwitchingProtocols:101,Processing:102,EarlyHints:103,Ok:200,Created:201,Accepted:202,NonAuthoritativeInformation:203,NoContent:204,ResetContent:205,PartialContent:206,MultiStatus:207,AlreadyReported:208,ImUsed:226,MultipleChoices:300,MovedPermanently:301,Found:302,SeeOther:303,NotModified:304,UseProxy:305,Unused:306,TemporaryRedirect:307,PermanentRedirect:308,BadRequest:400,Unauthorized:401,PaymentRequired:402,Forbidden:403,NotFound:404,MethodNotAllowed:405,NotAcceptable:406,ProxyAuthenticationRequired:407,RequestTimeout:408,Conflict:409,Gone:410,LengthRequired:411,PreconditionFailed:412,PayloadTooLarge:413,UriTooLong:414,UnsupportedMediaType:415,RangeNotSatisfiable:416,ExpectationFailed:417,ImATeapot:418,MisdirectedRequest:421,UnprocessableEntity:422,Locked:423,FailedDependency:424,TooEarly:425,UpgradeRequired:426,PreconditionRequired:428,TooManyRequests:429,RequestHeaderFieldsTooLarge:431,UnavailableForLegalReasons:451,InternalServerError:500,NotImplemented:501,BadGateway:502,ServiceUnavailable:503,GatewayTimeout:504,HttpVersionNotSupported:505,VariantAlsoNegotiates:506,InsufficientStorage:507,LoopDetected:508,NotExtended:510,NetworkAuthenticationRequired:511};Object.entries(ne).forEach(([A,e])=>{ne[e]=A});var It=ne;function gt(A){let e=new IA(A),t=eA(IA.prototype.request,e);return g.extend(t,IA.prototype,e,{allOwnKeys:!0}),g.extend(t,e,null,{allOwnKeys:!0}),t.create=function(n){return gt(G(A,n))},t}var D=gt(j);D.Axios=IA;D.CanceledError=x;D.CancelToken=st;D.isCancel=aA;D.VERSION=bA;D.toFormData=O;D.AxiosError=p;D.Cancel=D.CanceledError;D.all=function(e){return Promise.all(e)};D.spread=re;D.isAxiosError=oe;D.mergeConfig=G;D.AxiosHeaders=k;D.formToJSON=A=>wA(g.isHTMLForm(A)?new FormData(A):A);D.getAdapter=SA.getAdapter;D.HttpStatusCode=It;D.default=D;var z=D;var{Axios:ka,AxiosError:Fa,CanceledError:Ua,isCancel:Na,CancelToken:Ta,VERSION:La,all:Pa,Cancel:Ga,isAxiosError:Oa,spread:xa,toFormData:Wa,AxiosHeaders:Ja,HttpStatusCode:Ma,formToJSON:Ha,getAdapter:Ya,mergeConfig:qa}=z;async function _r(A,e){let t=A,r=null;if(t==null)r=new Worker(new URL("./web-workers/itk-wasm-pipeline.worker.js",import.meta.url),{type:"module"});else if(t.startsWith("http")){let n=await z.get(t,{responseType:"blob",params:e}),o=URL.createObjectURL(n.data);r=new Worker(o,{type:"module"})}else r=new Worker(t,{type:"module"});return r}var gA=_r;function lt(A){let e=OA(A),t=A;return t.terminated=!1,t.workerProxy=e,t.originalTerminate=t.terminate,t.terminate=()=>{t.terminated=!0,t.workerProxy[GA](),t.originalTerminate()},{workerProxy:e,worker:t}}async function zr(A,e,t){let r;if(A!=null){let o=A;return o.workerProxy!==void 0?(r=o.workerProxy,{workerProxy:r,worker:o}):lt(A)}let n=await gA(e,t);return lt(n)}var Bt=zr;async function Zr(A,e,t){let r="unknown";typeof A!="string"?r=A.href:A.startsWith("http")?r=A:r=typeof e<"u"?`${e}/${A}`:A,r.endsWith(".js")&&(r=r.substring(0,r.length-3)),r.endsWith(".wasm")&&(r=r.substring(0,r.length-5));let n=`${r}.wasm`,i=(await z.get(n,{responseType:"arraybuffer",params:t})).data;return(await import(`${r}.js`)).default({wasmBinary:i})}var Ct=Zr;var ft=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,5,1,96,0,1,123,3,2,1,0,10,10,1,8,0,65,0,253,15,253,98,11]));var Et=typeof globalThis.SharedArrayBuffer=="function",ct=new TextEncoder,ut=new TextDecoder("utf-8");function Vr(A,e){let t={flags:"r",encoding:"binary"},r=A.fs_open(e,t.flags),o=A.fs_stat(e).size,i=null;Et?i=new SharedArrayBuffer(o):i=new ArrayBuffer(o);let l=new Uint8Array(i);return A.fs_read(r,l,0,o,0),A.fs_close(r),l}function Qt(A,e,t){let r=null;Et?r=new SharedArrayBuffer(t):r=new ArrayBuffer(t);let n=new Uint8Array(r),o=new Uint8Array(A.HEAPU8.buffer,e,t);return n.set(o),n}function S(A,e,t,r){let n=0;return e!==null&&(n=A.ccall("itk_wasm_input_array_alloc","number",["number","number","number","number"],[0,t,r,e.buffer.byteLength]),A.HEAPU8.set(new Uint8Array(e.buffer),n)),n}function J(A,e,t){let r=JSON.stringify(e),n=A.lengthBytesUTF8(r)+1,o=A.ccall("itk_wasm_input_json_alloc","number",["number","number","number"],[0,t,n]);A.stringToUTF8(r,o,n)}function R(A,e,t,r){let n=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,e,t]),o=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,e,t]),i=Qt(A,n,o);return L(r,i.buffer)}function lA(A,e){let t=A.ccall("itk_wasm_output_json_address","number",["number","number"],[0,e]),r=A.UTF8ToString(t);return JSON.parse(r)}function Xr(A,e,t,r){r!=null&&r.length>0&&r.forEach(function(B,s){switch(B.type){case E.TextStream:{let a=ct.encode(B.data.data),c=S(A,a,s,0),I={size:a.buffer.byteLength,data:`data:application/vnd.itk.address,0:${c}`};J(A,I,s);break}case E.JsonCompatible:{let a=ct.encode(JSON.stringify(B.data)),c=S(A,a,s,0),I={size:a.buffer.byteLength,data:`data:application/vnd.itk.address,0:${c}`};J(A,I,s);break}case E.BinaryStream:{let a=B.data.data,c=S(A,a,s,0),I={size:a.buffer.byteLength,data:`data:application/vnd.itk.address,0:${c}`};J(A,I,s);break}case E.TextFile:{A.fs_writeFile(B.data.path,B.data.data);break}case E.BinaryFile:{A.fs_writeFile(B.data.path,B.data.data);break}case E.Image:{let a=B.data,c=S(A,a.data,s,0),I=S(A,a.direction,s,1),C=typeof a.metadata?.entries<"u"?Array.from(a.metadata.entries()):[],f={imageType:a.imageType,name:a.name,origin:a.origin,spacing:a.spacing,direction:`data:application/vnd.itk.address,0:${I}`,size:a.size,data:`data:application/vnd.itk.address,0:${c}`,metadata:C};J(A,f,s);break}case E.Mesh:{let a=B.data,c=S(A,a.points,s,0),I=S(A,a.cells,s,1),C=S(A,a.pointData,s,2),f=S(A,a.cellData,s,3),Q={meshType:a.meshType,name:a.name,numberOfPoints:a.numberOfPoints,points:`data:application/vnd.itk.address,0:${c}`,numberOfCells:a.numberOfCells,cells:`data:application/vnd.itk.address,0:${I}`,cellBufferSize:a.cellBufferSize,numberOfPointPixels:a.numberOfPointPixels,pointData:`data:application/vnd.itk.address,0:${C}`,numberOfCellPixels:a.numberOfCellPixels,cellData:`data:application/vnd.itk.address,0:${f}`};J(A,Q,s);break}case E.PointSet:{let a=B.data,c=S(A,a.points,s,0),I=S(A,a.pointData,s,1),C={pointSetType:a.pointSetType,name:a.name,numberOfPoints:a.numberOfPoints,points:`data:application/vnd.itk.address,0:${c}`,numberOfPointPixels:a.numberOfPointPixels,pointData:`data:application/vnd.itk.address,0:${I}`};J(A,C,s);break}case E.TransformList:{let a=B.data,c=[];a.forEach((I,C)=>{let Q=`data:application/vnd.itk.address,0:${S(A,I.fixedParameters,s,C*2)}`,U=`data:application/vnd.itk.address,0:${S(A,I.parameters,s,C*2+1)}`,N={transformType:I.transformType,numberOfFixedParameters:I.numberOfFixedParameters,numberOfParameters:I.numberOfParameters,name:I.name,inputSpaceName:I.inputSpaceName,outputSpaceName:I.outputSpaceName,parameters:U,fixedParameters:Q};c.push(N)}),J(A,c,s);break}case E.PolyData:{let a=B.data,c=S(A,a.points,s,0),I=S(A,a.vertices,s,1),C=S(A,a.lines,s,2),f=S(A,a.polygons,s,3),Q=S(A,a.triangleStrips,s,4),m=S(A,a.pointData,s,5),U=S(A,a.pointData,s,6),N={polyDataType:a.polyDataType,name:a.name,numberOfPoints:a.numberOfPoints,points:`data:application/vnd.itk.address,0:${c}`,verticesBufferSize:a.verticesBufferSize,vertices:`data:application/vnd.itk.address,0:${I}`,linesBufferSize:a.linesBufferSize,lines:`data:application/vnd.itk.address,0:${C}`,polygonsBufferSize:a.polygonsBufferSize,polygons:`data:application/vnd.itk.address,0:${f}`,triangleStripsBufferSize:a.triangleStripsBufferSize,triangleStrips:`data:application/vnd.itk.address,0:${Q}`,numberOfPointPixels:a.numberOfPointPixels,pointData:`data:application/vnd.itk.address,0:${m}`,numberOfCellPixels:a.numberOfCellPixels,cellData:`data:application/vnd.itk.address,0:${U}`};J(A,N,s);break}default:throw Error("Unsupported input InterfaceType")}}),A.resetModuleStdout(),A.resetModuleStderr();let n=A.stackSave(),o=0;try{o=A.callMain(e.slice())}catch(B){throw typeof B=="number"&&(console.log("Exception while running pipeline:"),console.log("stdout:",A.getModuleStdout()),console.error("stderr:",A.getModuleStderr()),typeof A.getExceptionMessage<"u"?console.error("exception:",A.getExceptionMessage(B)):console.error("Build module in Debug mode for exception message information.")),B}finally{A.stackRestore(n)}let i=A.getModuleStdout(),l=A.getModuleStderr(),u=[];return t!=null&&t.length>0&&o===0&&t.forEach(function(B,s){let a=null;switch(B.type){case E.TextStream:{let I=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,s,0]),C=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,s,0]),f=new Uint8Array(A.HEAPU8.buffer,I,C);a={data:ut.decode(f)};break}case E.JsonCompatible:{let I=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,s,0]),C=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,s,0]),f=new Uint8Array(A.HEAPU8.buffer,I,C);a=JSON.parse(ut.decode(f));break}case E.BinaryStream:{let I=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,s,0]),C=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,s,0]);a={data:Qt(A,I,C)};break}case E.TextFile:{a={path:B.data.path,data:A.fs_readFile(B.data.path,{encoding:"utf8"})};break}case E.BinaryFile:{a={path:B.data.path,data:Vr(A,B.data.path)};break}case E.Image:{let I=lA(A,s);I.data=R(A,s,0,I.imageType.componentType),I.direction=R(A,s,1,H.Float64),I.metadata=new Map(I.metadata),a=I;break}case E.Mesh:{let I=lA(A,s);I.numberOfPoints>0?I.points=R(A,s,0,I.meshType.pointComponentType):I.points=L(I.meshType.pointComponentType,new ArrayBuffer(0)),I.numberOfCells>0?I.cells=R(A,s,1,I.meshType.cellComponentType):I.cells=L(I.meshType.cellComponentType,new ArrayBuffer(0)),I.numberOfPointPixels>0?I.pointData=R(A,s,2,I.meshType.pointPixelComponentType):I.pointData=L(I.meshType.pointPixelComponentType,new ArrayBuffer(0)),I.numberOfCellPixels>0?I.cellData=R(A,s,3,I.meshType.cellPixelComponentType):I.cellData=L(I.meshType.cellPixelComponentType,new ArrayBuffer(0)),a=I;break}case E.PointSet:{let I=lA(A,s);I.numberOfPoints>0?I.points=R(A,s,0,I.pointSetType.pointComponentType):I.points=L(I.pointSetType.pointComponentType,new ArrayBuffer(0)),I.numberOfPointPixels>0?I.pointData=R(A,s,1,I.pointSetType.pointPixelComponentType):I.pointData=L(I.pointSetType.pointPixelComponentType,new ArrayBuffer(0)),a=I;break}case E.TransformList:{let I=lA(A,s);I.forEach((C,f)=>{C.numberOfFixedParameters>0&&(I[f].fixedParameters=R(A,s,f*2,C.transformType.parametersValueType)),C.numberOfFixedParameters>0&&(I[f].parameters=R(A,s,f*2+1,C.transformType.parametersValueType))}),a=I;break}case E.PolyData:{let I=lA(A,s);I.numberOfPoints>0?I.points=R(A,s,0,H.Float32):I.points=new Float32Array,I.verticesBufferSize>0?I.vertices=R(A,s,1,F.UInt32):I.vertices=new Uint32Array,I.linesBufferSize>0?I.lines=R(A,s,2,F.UInt32):I.lines=new Uint32Array,I.polygonsBufferSize>0?I.polygons=R(A,s,3,F.UInt32):I.polygons=new Uint32Array,I.triangleStripsBufferSize>0?I.triangleStrips=R(A,s,4,F.UInt32):I.triangleStrips=new Uint32Array,I.numberOfPointPixels>0?I.pointData=R(A,s,5,I.polyDataType.pointPixelComponentType):I.pointData=L(I.polyDataType.pointPixelComponentType,new ArrayBuffer(0)),I.numberOfCellPixels>0?I.cellData=R(A,s,6,I.polyDataType.cellPixelComponentType):I.cellData=L(I.polyDataType.cellPixelComponentType,new ArrayBuffer(0)),a=I;break}default:throw Error("Unsupported output InterfaceType")}let c={type:B.type,data:a};u.push(c)}),{returnValue:o,stdout:i,stderr:l,outputs:u}}var pt=Xr;var $r=typeof globalThis.SharedArrayBuffer<"u";function Ao(A,e){if(A==null)return[];let t=[];for(let r=0;r<A.length;r++){let n=eo(A[r],e);n!==null&&t.push(n)}return t}function eo(A,e){if(A==null)return null;let t=null;return A.buffer!==void 0?t=A.buffer:A.byteLength!==void 0&&(t=A),$r&&t instanceof SharedArrayBuffer?null:e?t:t.slice(0)}var mt=Ao;function to(A){return[A.data,A.direction]}var dt=to;function ro(A){return[A.points,A.pointData,A.cells,A.cellData]}var yt=ro;function oo(A){return[A.points,A.vertices,A.lines,A.polygons,A.triangleStrips,A.pointData,A.cellData]}var ht=oo;var no;function FA(){return no}var io;function wt(){return io}var ao;function UA(){return ao}var ie=new Map;function so(){let A=UA();return typeof A>"u"&&(A=null),A}function Dt(){let A=FA();return typeof A>"u"&&(A=new URL("/pipelines",document.location.origin).href),A}function NA(){let A=wt();return typeof A>"u"&&(A={}),A}async function Io(A,e,t){let r=A,n=A;if(typeof A!="string"&&(r=new URL(A.href),n=r.href),ie.has(n))return ie.get(n);{let o=await Ct(A,e?.toString()??Dt(),t??NA());return ie.set(n,o),o}}async function go(A,e,t,r,n){if(!await ft()){let Q="WebAssembly SIMD support is required -- please update your browser.";throw alert(Q),new Error(Q)}let o=n?.webWorker??null;if(o===!1){let Q=await Io(A.toString(),n?.pipelineBaseUrl,n?.pipelineQueryParams??NA());return pt(Q,e,t,r)}let i=o,l=n?.pipelineWorkerUrl??so(),u=typeof l!="string"&&typeof l?.href<"u"?l.href:l,{workerProxy:B,worker:s}=await Bt(i,u,n?.pipelineQueryParams??NA());i=s;let a=[];r!=null&&r.length>0&&r.forEach(function(Q){if(Q.type===E.BinaryStream){let m=Q.data.data;a.push(m)}else if(Q.type===E.BinaryFile){let m=Q.data.data;a.push(m)}else if(Q.type===E.Image){let m=Q.data;m.data!==null&&a.push(...dt(m))}else if(Q.type===E.Mesh){let m=Q.data;a.push(...yt(m))}else if(Q.type===E.PolyData){let m=Q.data;a.push(...ht(m))}});let c=n?.pipelineBaseUrl??Dt(),I=typeof c!="string"&&typeof c?.href<"u"?c.href:c,C=r!=null?xA(r,mt(a,n?.noCopy)):null,f=await B.runPipeline(A.toString(),I,e,t,C,n?.pipelineQueryParams??NA());return{returnValue:f.returnValue,stdout:f.stdout,stderr:f.stderr,outputs:f.outputs,webWorker:i}}var y=go;var lo=null;function St(){return lo}var Bo=new Map([]),Z=Bo;var Co=new Map([["h5","hdf5"],["hdf5","hdf5"],["txt","txt"],["mat","mat"],["xfm","mnc"],["iwt","wasm"],["iwt.cbor","wasm"],["iwt.cbor.zst","wasm-zstd"]]),V=Co;var ae,fo=`https://cdn.jsdelivr.net/npm/@itk-wasm/transform-io@${TA}/dist/pipelines`;function Gs(A){ae=A}function h(){if(typeof ae<"u")return ae;let A=FA();return typeof A<"u"?A:fo}var se,co=null;function Rt(A){se=A}function d(){if(typeof se<"u")return se;let A=UA();return typeof A<"u"?A:co}var X=null;async function bt(){let A=d(),e=typeof A!="string"&&typeof A?.href<"u"?A.href:A;X=await gA(e)}function Ys(A){X=A}async function w(){if(X!==null)return X.terminated&&await bt(),X;let A=St();return A!==null?A:(await bt(),X)}async function uo(A,e={}){let t=[{type:E.JsonCompatible},{type:E.TransformList}],r=A;if(A instanceof File){let Q=await A.arrayBuffer();r={path:A.name,data:new Uint8Array(Q)}}let n=[{type:E.BinaryFile,data:r}],o=[],i=r.path;o.push(i),o.push("0"),o.push("1"),o.push("--memory-io"),e.floatParameters&&e.floatParameters&&o.push("--float-parameters");let B="hdf5-read-transform",s=e?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:C}=await y(B,o,t,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:e?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldRead:C[0]?.data,transform:C[1]?.data}}var Ie=uo;async function Eo(A,e,t={}){let r=[{type:E.JsonCompatible},{type:E.BinaryFile,data:{path:e,data:new Uint8Array}}],n=[{type:E.TransformList,data:A}],o=[];o.push("0"),o.push("0");let u=e;o.push(u),o.push("--memory-io"),t.floatParameters&&t.floatParameters&&o.push("--float-parameters"),t.useCompression&&t.useCompression&&o.push("--use-compression");let B="hdf5-write-transform",s=t?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:C}=await y(B,o,r,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:t?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldWrite:C[0]?.data,serializedTransform:C[1]?.data}}var ge=Eo;async function Qo(A,e={}){let t=[{type:E.JsonCompatible},{type:E.TransformList}],r=A;if(A instanceof File){let Q=await A.arrayBuffer();r={path:A.name,data:new Uint8Array(Q)}}let n=[{type:E.BinaryFile,data:r}],o=[],i=r.path;o.push(i),o.push("0"),o.push("1"),o.push("--memory-io"),e.floatParameters&&e.floatParameters&&o.push("--float-parameters");let B="mat-read-transform",s=e?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:C}=await y(B,o,t,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:e?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldRead:C[0]?.data,transform:C[1]?.data}}var le=Qo;async function po(A,e,t={}){let r=[{type:E.JsonCompatible},{type:E.BinaryFile,data:{path:e,data:new Uint8Array}}],n=[{type:E.TransformList,data:A}],o=[];o.push("0"),o.push("0");let u=e;o.push(u),o.push("--memory-io"),t.floatParameters&&t.floatParameters&&o.push("--float-parameters"),t.useCompression&&t.useCompression&&o.push("--use-compression");let B="mat-write-transform",s=t?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:C}=await y(B,o,r,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:t?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldWrite:C[0]?.data,serializedTransform:C[1]?.data}}var Be=po;async function mo(A,e={}){let t=[{type:E.JsonCompatible},{type:E.TransformList}],r=A;if(A instanceof File){let Q=await A.arrayBuffer();r={path:A.name,data:new Uint8Array(Q)}}let n=[{type:E.BinaryFile,data:r}],o=[],i=r.path;o.push(i),o.push("0"),o.push("1"),o.push("--memory-io"),e.floatParameters&&e.floatParameters&&o.push("--float-parameters");let B="mnc-read-transform",s=e?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:C}=await y(B,o,t,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:e?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldRead:C[0]?.data,transform:C[1]?.data}}var Ce=mo;async function yo(A,e,t={}){let r=[{type:E.JsonCompatible},{type:E.BinaryFile,data:{path:e,data:new Uint8Array}}],n=[{type:E.TransformList,data:A}],o=[];o.push("0"),o.push("0");let u=e;o.push(u),o.push("--memory-io"),t.floatParameters&&t.floatParameters&&o.push("--float-parameters"),t.useCompression&&t.useCompression&&o.push("--use-compression");let B="mnc-write-transform",s=t?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:C}=await y(B,o,r,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:t?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldWrite:C[0]?.data,serializedTransform:C[1]?.data}}var fe=yo;async function ho(A,e={}){let t=[{type:E.JsonCompatible},{type:E.TransformList}],r=A;if(A instanceof File){let Q=await A.arrayBuffer();r={path:A.name,data:new Uint8Array(Q)}}let n=[{type:E.BinaryFile,data:r}],o=[],i=r.path;o.push(i),o.push("0"),o.push("1"),o.push("--memory-io"),e.floatParameters&&e.floatParameters&&o.push("--float-parameters");let B="txt-read-transform",s=e?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:C}=await y(B,o,t,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:e?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldRead:C[0]?.data,transform:C[1]?.data}}var ce=ho;async function wo(A,e,t={}){let r=[{type:E.JsonCompatible},{type:E.BinaryFile,data:{path:e,data:new Uint8Array}}],n=[{type:E.TransformList,data:A}],o=[];o.push("0"),o.push("0");let u=e;o.push(u),o.push("--memory-io"),t.floatParameters&&t.floatParameters&&o.push("--float-parameters"),t.useCompression&&t.useCompression&&o.push("--use-compression");let B="txt-write-transform",s=t?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:C}=await y(B,o,r,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:t?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldWrite:C[0]?.data,serializedTransform:C[1]?.data}}var ue=wo;async function Do(A,e={}){let t=[{type:E.JsonCompatible},{type:E.TransformList}],r=A;if(A instanceof File){let Q=await A.arrayBuffer();r={path:A.name,data:new Uint8Array(Q)}}let n=[{type:E.BinaryFile,data:r}],o=[],i=r.path;o.push(i),o.push("0"),o.push("1"),o.push("--memory-io"),e.floatParameters&&e.floatParameters&&o.push("--float-parameters");let B="wasm-read-transform",s=e?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:C}=await y(B,o,t,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:e?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldRead:C[0]?.data,transform:C[1]?.data}}var Ee=Do;async function So(A,e,t={}){let r=[{type:E.JsonCompatible},{type:E.BinaryFile,data:{path:e,data:new Uint8Array}}],n=[{type:E.TransformList,data:A}],o=[];o.push("0"),o.push("0");let u=e;o.push(u),o.push("--memory-io"),t.floatParameters&&t.floatParameters&&o.push("--float-parameters"),t.useCompression&&t.useCompression&&o.push("--use-compression");let B="wasm-write-transform",s=t?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:C}=await y(B,o,r,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:t?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldWrite:C[0]?.data,serializedTransform:C[1]?.data}}var Qe=So;async function Ro(A,e={}){let t=[{type:E.JsonCompatible},{type:E.TransformList}],r=A;if(A instanceof File){let Q=await A.arrayBuffer();r={path:A.name,data:new Uint8Array(Q)}}let n=[{type:E.BinaryFile,data:r}],o=[],i=r.path;o.push(i),o.push("0"),o.push("1"),o.push("--memory-io"),e.floatParameters&&e.floatParameters&&o.push("--float-parameters");let B="wasm-zstd-read-transform",s=e?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:C}=await y(B,o,t,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:e?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldRead:C[0]?.data,transform:C[1]?.data}}var pe=Ro;async function bo(A,e,t={}){let r=[{type:E.JsonCompatible},{type:E.BinaryFile,data:{path:e,data:new Uint8Array}}],n=[{type:E.TransformList,data:A}],o=[];o.push("0"),o.push("0");let u=e;o.push(u),o.push("--memory-io"),t.floatParameters&&t.floatParameters&&o.push("--float-parameters"),t.useCompression&&t.useCompression&&o.push("--use-compression");let B="wasm-zstd-write-transform",s=t?.webWorker;s===void 0&&(s=await w());let{webWorker:a,returnValue:c,stderr:I,outputs:C}=await y(B,o,r,n,{pipelineBaseUrl:h(),pipelineWorkerUrl:d(),webWorker:s,noCopy:t?.noCopy});if(c!==0&&I!=="")throw new Error(I);return{webWorker:a,couldWrite:C[0]?.data,serializedTransform:C[1]?.data}}var me=bo;var ko=new Map([["hdf5",[Ie,ge]],["mat",[le,Be]],["mnc",[Ce,fe]],["txt",[ce,ue]],["wasm",[Ee,Qe]],["wasmZstd",[pe,me]]]),$=ko;async function Fo(A,e={}){let t=A.type??"",r=A.name??A.path??"fileName",n=AA(r).toLowerCase(),o=e?.webWorker,i=A;if(A instanceof Blob){let I=await A.arrayBuffer();i={path:A.name,data:new Uint8Array(I)}}let l=null;if(t&&Z.has(t))l=Z.get(t);else if(V.has(n))l=V.get(n);else for(let I of $.values())if(I[0]!==null){let{webWorker:C,couldRead:f,transform:Q}=await I[0]({path:i.path,data:i.data.slice()},{floatParameters:e.floatParameters,webWorker:o,noCopy:e?.noCopy});if(o=C,f)return{webWorker:o,transform:Q}}if(!l)throw Error("Could not find IO for: "+r);let B=$.get(l)[0],{webWorker:s,couldRead:a,transform:c}=await B(i,{floatParameters:e.floatParameters,webWorker:o,noCopy:e?.noCopy});if(o=s,!a)throw Error("Could not read: "+r);return{webWorker:o,transform:c}}var Uo=Fo;async function No(A,e,t={}){let r=A,n=t.mimeType,o=AA(e).toLowerCase(),i=t.webWorker,l=null;if(typeof n<"u"&&Z.has(n))l=Z.get(n);else if(V.has(o))l=V.get(o);else for(let C of $.values())if(C[1]!==null){let{webWorker:f,couldWrite:Q,serializedTransform:m}=await C[1](r,e,t);if(i=f,Q)return{webWorker:i,serializedTransform:m}}if(!l)throw Error("Could not find IO for: "+e);let B=$.get(l)[1],{webWorker:s,couldWrite:a,serializedTransform:c}=await B(r,e,t);if(i=s,!a)throw Error("Could not write: "+e);return{webWorker:i,serializedTransform:c}}var To=No;var kt='data:text/javascript;charset=utf-8,var II=Object.defineProperty;var eI=(A,t)=>{for(var I in t)II(A,I,{get:t[I],enumerable:!0})};var vA=Symbol("Comlink.proxy"),gI=Symbol("Comlink.endpoint"),rI=Symbol("Comlink.releaseProxy"),pA=Symbol("Comlink.finalizer"),gA=Symbol("Comlink.thrown"),$A=A=>typeof A=="object"&&A!==null||typeof A=="function",oI={canHandle:A=>$A(A)&&A[vA],serialize(A){let{port1:t,port2:I}=new MessageChannel;return CA(A,t),[I,[I]]},deserialize(A){return A.start(),sI(A)}},iI={canHandle:A=>$A(A)&&gA in A,serialize({value:A}){let t;return A instanceof Error?t={isError:!0,value:{message:A.message,name:A.name,stack:A.stack}}:t={isError:!1,value:A},[t,[]]},deserialize(A){throw A.isError?Object.assign(new Error(A.value.message),A.value):A.value}},At=new Map([["proxy",oI],["throw",iI]]);function CI(A,t){for(let I of A)if(t===I||I==="*"||I instanceof RegExp&&I.test(t))return!0;return!1}function CA(A,t=globalThis,I=["*"]){t.addEventListener("message",function e(g){if(!g||!g.data)return;if(!CI(I,g.origin)){console.warn(`Invalid origin \'${g.origin}\' for comlink proxy`);return}let{id:r,type:o,path:n}=Object.assign({path:[]},g.data),c=(g.data.argumentList||[]).map(M),Q;try{let B=n.slice(0,-1).reduce((f,s)=>f[s],A),i=n.reduce((f,s)=>f[s],A);switch(o){case"GET":Q=i;break;case"SET":B[n.slice(-1)[0]]=M(g.data.value),Q=!0;break;case"APPLY":Q=i.apply(B,c);break;case"CONSTRUCT":{let f=new i(...c);Q=EI(f)}break;case"ENDPOINT":{let{port1:f,port2:s}=new MessageChannel;CA(A,s),Q=FA(f,[f])}break;case"RELEASE":Q=void 0;break;default:return}}catch(B){Q={value:B,[gA]:0}}Promise.resolve(Q).catch(B=>({value:B,[gA]:0})).then(B=>{let[i,f]=iA(B);t.postMessage(Object.assign(Object.assign({},i),{id:r}),f),o==="RELEASE"&&(t.removeEventListener("message",e),tt(t),pA in A&&typeof A[pA]=="function"&&A[pA]())}).catch(B=>{let[i,f]=iA({value:new TypeError("Unserializable return value"),[gA]:0});t.postMessage(Object.assign(Object.assign({},i),{id:r}),f)})}),t.start&&t.start()}function BI(A){return A.constructor.name==="MessagePort"}function tt(A){BI(A)&&A.close()}function sI(A,t){return SA(A,[],t)}function eA(A){if(A)throw new Error("Proxy has been released and is not useable")}function It(A){return q(A,{type:"RELEASE"}).then(()=>{tt(A)})}var rA=new WeakMap,oA="FinalizationRegistry"in globalThis&&new FinalizationRegistry(A=>{let t=(rA.get(A)||0)-1;rA.set(A,t),t===0&&It(A)});function nI(A,t){let I=(rA.get(t)||0)+1;rA.set(t,I),oA&&oA.register(A,t,A)}function QI(A){oA&&oA.unregister(A)}function SA(A,t=[],I=function(){}){let e=!1,g=new Proxy(I,{get(r,o){if(eA(e),o===rI)return()=>{QI(g),It(A),e=!0};if(o==="then"){if(t.length===0)return{then:()=>g};let n=q(A,{type:"GET",path:t.map(c=>c.toString())}).then(M);return n.then.bind(n)}return SA(A,[...t,o])},set(r,o,n){eA(e);let[c,Q]=iA(n);return q(A,{type:"SET",path:[...t,o].map(B=>B.toString()),value:c},Q).then(M)},apply(r,o,n){eA(e);let c=t[t.length-1];if(c===gI)return q(A,{type:"ENDPOINT"}).then(M);if(c==="bind")return SA(A,t.slice(0,-1));let[Q,B]=_A(n);return q(A,{type:"APPLY",path:t.map(i=>i.toString()),argumentList:Q},B).then(M)},construct(r,o){eA(e);let[n,c]=_A(o);return q(A,{type:"CONSTRUCT",path:t.map(Q=>Q.toString()),argumentList:n},c).then(M)}});return nI(g,A),g}function aI(A){return Array.prototype.concat.apply([],A)}function _A(A){let t=A.map(iA);return[t.map(I=>I[0]),aI(t.map(I=>I[1]))]}var et=new WeakMap;function FA(A,t){return et.set(A,t),A}function EI(A){return Object.assign(A,{[vA]:!0})}function iA(A){for(let[t,I]of At)if(I.canHandle(A)){let[e,g]=I.serialize(A);return[{type:"HANDLER",name:t,value:e},g]}return[{type:"RAW",value:A},et.get(A)||[]]}function M(A){switch(A.type){case"HANDLER":return At.get(A.name).deserialize(A.value);case"RAW":return A.value}}function q(A,t,I){return new Promise(e=>{let g=cI();A.addEventListener("message",function r(o){!o.data||!o.data.id||o.data.id!==g||(A.removeEventListener("message",r),e(o.data))}),A.start&&A.start(),A.postMessage(Object.assign({id:g},t),I)})}function cI(){return new Array(4).fill(0).map(()=>Math.floor(Math.random()*Number.MAX_SAFE_INTEGER).toString(16)).join("-")}function W(A,t){return function(){return A.apply(t,arguments)}}var{toString:fI}=Object.prototype,{getPrototypeOf:UA}=Object,sA=(A=>t=>{let I=fI.call(t);return A[I]||(A[I]=I.slice(8,-1).toLowerCase())})(Object.create(null)),U=A=>(A=A.toLowerCase(),t=>sA(t)===A),nA=A=>t=>typeof t===A,{isArray:K}=Array,Z=nA("undefined");function lI(A){return A!==null&&!Z(A)&&A.constructor!==null&&!Z(A.constructor)&&N(A.constructor.isBuffer)&&A.constructor.isBuffer(A)}var it=U("ArrayBuffer");function DI(A){let t;return typeof ArrayBuffer<"u"&&ArrayBuffer.isView?t=ArrayBuffer.isView(A):t=A&&A.buffer&&it(A.buffer),t}var uI=nA("string"),N=nA("function"),Ct=nA("number"),QA=A=>A!==null&&typeof A=="object",hI=A=>A===!0||A===!1,BA=A=>{if(sA(A)!=="object")return!1;let t=UA(A);return(t===null||t===Object.prototype||Object.getPrototypeOf(t)===null)&&!(Symbol.toStringTag in A)&&!(Symbol.iterator in A)},dI=U("Date"),yI=U("File"),wI=U("Blob"),mI=U("FileList"),pI=A=>QA(A)&&N(A.pipe),SI=A=>{let t;return A&&(typeof FormData=="function"&&A instanceof FormData||N(A.append)&&((t=sA(A))==="formdata"||t==="object"&&N(A.toString)&&A.toString()==="[object FormData]"))},FI=U("URLSearchParams"),RI=A=>A.trim?A.trim():A.replace(/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g,"");function V(A,t,{allOwnKeys:I=!1}={}){if(A===null||typeof A>"u")return;let e,g;if(typeof A!="object"&&(A=[A]),K(A))for(e=0,g=A.length;e<g;e++)t.call(null,A[e],e,A);else{let r=I?Object.getOwnPropertyNames(A):Object.keys(A),o=r.length,n;for(e=0;e<o;e++)n=r[e],t.call(null,A[n],n,A)}}function Bt(A,t){t=t.toLowerCase();let I=Object.keys(A),e=I.length,g;for(;e-- >0;)if(g=I[e],t===g.toLowerCase())return g;return null}var st=typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:global,nt=A=>!Z(A)&&A!==st;function NA(){let{caseless:A}=nt(this)&&this||{},t={},I=(e,g)=>{let r=A&&Bt(t,g)||g;BA(t[r])&&BA(e)?t[r]=NA(t[r],e):BA(e)?t[r]=NA({},e):K(e)?t[r]=e.slice():t[r]=e};for(let e=0,g=arguments.length;e<g;e++)arguments[e]&&V(arguments[e],I);return t}var NI=(A,t,I,{allOwnKeys:e}={})=>(V(t,(g,r)=>{I&&N(g)?A[r]=W(g,I):A[r]=g},{allOwnKeys:e}),A),UI=A=>(A.charCodeAt(0)===65279&&(A=A.slice(1)),A),GI=(A,t,I,e)=>{A.prototype=Object.create(t.prototype,e),A.prototype.constructor=A,Object.defineProperty(A,"super",{value:t.prototype}),I&&Object.assign(A.prototype,I)},kI=(A,t,I,e)=>{let g,r,o,n={};if(t=t||{},A==null)return t;do{for(g=Object.getOwnPropertyNames(A),r=g.length;r-- >0;)o=g[r],(!e||e(o,A,t))&&!n[o]&&(t[o]=A[o],n[o]=!0);A=I!==!1&&UA(A)}while(A&&(!I||I(A,t))&&A!==Object.prototype);return t},LI=(A,t,I)=>{A=String(A),(I===void 0||I>A.length)&&(I=A.length),I-=t.length;let e=A.indexOf(t,I);return e!==-1&&e===I},JI=A=>{if(!A)return null;if(K(A))return A;let t=A.length;if(!Ct(t))return null;let I=new Array(t);for(;t-- >0;)I[t]=A[t];return I},HI=(A=>t=>A&&t instanceof A)(typeof Uint8Array<"u"&&UA(Uint8Array)),YI=(A,t)=>{let e=(A&&A[Symbol.iterator]).call(A),g;for(;(g=e.next())&&!g.done;){let r=g.value;t.call(A,r[0],r[1])}},bI=(A,t)=>{let I,e=[];for(;(I=A.exec(t))!==null;)e.push(I);return e},MI=U("HTMLFormElement"),qI=A=>A.toLowerCase().replace(/[-_\\s]([a-z\\d])(\\w*)/g,function(I,e,g){return e.toUpperCase()+g}),rt=(({hasOwnProperty:A})=>(t,I)=>A.call(t,I))(Object.prototype),KI=U("RegExp"),Qt=(A,t)=>{let I=Object.getOwnPropertyDescriptors(A),e={};V(I,(g,r)=>{let o;(o=t(g,r,A))!==!1&&(e[r]=o||g)}),Object.defineProperties(A,e)},OI=A=>{Qt(A,(t,I)=>{if(N(A)&&["arguments","caller","callee"].indexOf(I)!==-1)return!1;let e=A[I];if(N(e)){if(t.enumerable=!1,"writable"in t){t.writable=!1;return}t.set||(t.set=()=>{throw Error("Can not rewrite read-only method \'"+I+"\'")})}})},TI=(A,t)=>{let I={},e=g=>{g.forEach(r=>{I[r]=!0})};return K(A)?e(A):e(String(A).split(t)),I},PI=()=>{},xI=(A,t)=>(A=+A,Number.isFinite(A)?A:t),RA="abcdefghijklmnopqrstuvwxyz",ot="0123456789",at={DIGIT:ot,ALPHA:RA,ALPHA_DIGIT:RA+RA.toUpperCase()+ot},jI=(A=16,t=at.ALPHA_DIGIT)=>{let I="",{length:e}=t;for(;A--;)I+=t[Math.random()*e|0];return I};function WI(A){return!!(A&&N(A.append)&&A[Symbol.toStringTag]==="FormData"&&A[Symbol.iterator])}var ZI=A=>{let t=new Array(10),I=(e,g)=>{if(QA(e)){if(t.indexOf(e)>=0)return;if(!("toJSON"in e)){t[g]=e;let r=K(e)?[]:{};return V(e,(o,n)=>{let c=I(o,g+1);!Z(c)&&(r[n]=c)}),t[g]=void 0,r}}return e};return I(A,0)},VI=U("AsyncFunction"),XI=A=>A&&(QA(A)||N(A))&&N(A.then)&&N(A.catch),C={isArray:K,isArrayBuffer:it,isBuffer:lI,isFormData:SI,isArrayBufferView:DI,isString:uI,isNumber:Ct,isBoolean:hI,isObject:QA,isPlainObject:BA,isUndefined:Z,isDate:dI,isFile:yI,isBlob:wI,isRegExp:KI,isFunction:N,isStream:pI,isURLSearchParams:FI,isTypedArray:HI,isFileList:mI,forEach:V,merge:NA,extend:NI,trim:RI,stripBOM:UI,inherits:GI,toFlatObject:kI,kindOf:sA,kindOfTest:U,endsWith:LI,toArray:JI,forEachEntry:YI,matchAll:bI,isHTMLForm:MI,hasOwnProperty:rt,hasOwnProp:rt,reduceDescriptors:Qt,freezeMethods:OI,toObjectSet:TI,toCamelCase:qI,noop:PI,toFiniteNumber:xI,findKey:Bt,global:st,isContextDefined:nt,ALPHABET:at,generateString:jI,isSpecCompliantForm:WI,toJSONObject:ZI,isAsyncFn:VI,isThenable:XI};function O(A,t,I,e,g){Error.call(this),Error.captureStackTrace?Error.captureStackTrace(this,this.constructor):this.stack=new Error().stack,this.message=A,this.name="AxiosError",t&&(this.code=t),I&&(this.config=I),e&&(this.request=e),g&&(this.response=g)}C.inherits(O,Error,{toJSON:function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:C.toJSONObject(this.config),code:this.code,status:this.response&&this.response.status?this.response.status:null}}});var Et=O.prototype,ct={};["ERR_BAD_OPTION_VALUE","ERR_BAD_OPTION","ECONNABORTED","ETIMEDOUT","ERR_NETWORK","ERR_FR_TOO_MANY_REDIRECTS","ERR_DEPRECATED","ERR_BAD_RESPONSE","ERR_BAD_REQUEST","ERR_CANCELED","ERR_NOT_SUPPORT","ERR_INVALID_URL"].forEach(A=>{ct[A]={value:A}});Object.defineProperties(O,ct);Object.defineProperty(Et,"isAxiosError",{value:!0});O.from=(A,t,I,e,g,r)=>{let o=Object.create(Et);return C.toFlatObject(A,o,function(c){return c!==Error.prototype},n=>n!=="isAxiosError"),O.call(o,A.message,t,I,e,g),o.cause=A,o.name=A.name,r&&Object.assign(o,r),o};var l=O;var aA=null;function GA(A){return C.isPlainObject(A)||C.isArray(A)}function lt(A){return C.endsWith(A,"[]")?A.slice(0,-2):A}function ft(A,t,I){return A?A.concat(t).map(function(g,r){return g=lt(g),!I&&r?"["+g+"]":g}).join(I?".":""):t}function zI(A){return C.isArray(A)&&!A.some(GA)}var _I=C.toFlatObject(C,{},null,function(t){return/^is[A-Z]/.test(t)});function vI(A,t,I){if(!C.isObject(A))throw new TypeError("target must be an object");t=t||new(aA||FormData),I=C.toFlatObject(I,{metaTokens:!0,dots:!1,indexes:!1},!1,function(E,u){return!C.isUndefined(u[E])});let e=I.metaTokens,g=I.visitor||B,r=I.dots,o=I.indexes,c=(I.Blob||typeof Blob<"u"&&Blob)&&C.isSpecCompliantForm(t);if(!C.isFunction(g))throw new TypeError("visitor must be a function");function Q(a){if(a===null)return"";if(C.isDate(a))return a.toISOString();if(!c&&C.isBlob(a))throw new l("Blob is not supported. Use a Buffer instead.");return C.isArrayBuffer(a)||C.isTypedArray(a)?c&&typeof Blob=="function"?new Blob([a]):Buffer.from(a):a}function B(a,E,u){let y=a;if(a&&!u&&typeof a=="object"){if(C.endsWith(E,"{}"))E=e?E:E.slice(0,-2),a=JSON.stringify(a);else if(C.isArray(a)&&zI(a)||(C.isFileList(a)||C.endsWith(E,"[]"))&&(y=C.toArray(a)))return E=lt(E),y.forEach(function(R,tI){!(C.isUndefined(R)||R===null)&&t.append(o===!0?ft([E],tI,r):o===null?E:E+"[]",Q(R))}),!1}return GA(a)?!0:(t.append(ft(u,E,r),Q(a)),!1)}let i=[],f=Object.assign(_I,{defaultVisitor:B,convertValue:Q,isVisitable:GA});function s(a,E){if(!C.isUndefined(a)){if(i.indexOf(a)!==-1)throw Error("Circular reference detected in "+E.join("."));i.push(a),C.forEach(a,function(y,F){(!(C.isUndefined(y)||y===null)&&g.call(t,y,C.isString(F)?F.trim():F,E,f))===!0&&s(y,E?E.concat(F):[F])}),i.pop()}}if(!C.isObject(A))throw new TypeError("data must be an object");return s(A),t}var J=vI;function Dt(A){let t={"!":"%2521","\'":"%2527","(":"%2528",")":"%2529","~":"%257E","%2520":"+","%2500":"\\0"};return encodeURIComponent(A).replace(/[!\'()~]|%2520|%2500/g,function(e){return t[e]})}function ut(A,t){this._pairs=[],A&&J(A,this,t)}var ht=ut.prototype;ht.append=function(t,I){this._pairs.push([t,I])};ht.toString=function(t){let I=t?function(e){return t.call(this,e,Dt)}:Dt;return this._pairs.map(function(g){return I(g[0])+"="+I(g[1])},"").join("&")};var EA=ut;function $I(A){return encodeURIComponent(A).replace(/%253A/gi,":").replace(/%2524/g,"$").replace(/%252C/gi,",").replace(/%2520/g,"+").replace(/%255B/gi,"[").replace(/%255D/gi,"]")}function X(A,t,I){if(!t)return A;let e=I&&I.encode||$I,g=I&&I.serialize,r;if(g?r=g(t,I):r=C.isURLSearchParams(t)?t.toString():new EA(t,I).toString(e),r){let o=A.indexOf("%23");o!==-1&&(A=A.slice(0,o)),A+=(A.indexOf("?")===-1?"?":"&")+r}return A}var kA=class{constructor(){this.handlers=[]}use(t,I,e){return this.handlers.push({fulfilled:t,rejected:I,synchronous:e?e.synchronous:!1,runWhen:e?e.runWhen:null}),this.handlers.length-1}eject(t){this.handlers[t]&&(this.handlers[t]=null)}clear(){this.handlers&&(this.handlers=[])}forEach(t){C.forEach(this.handlers,function(e){e!==null&&t(e)})}},LA=kA;var cA={silentJSONParsing:!0,forcedJSONParsing:!0,clarifyTimeoutError:!1};var dt=typeof URLSearchParams<"u"?URLSearchParams:EA;var yt=typeof FormData<"u"?FormData:null;var wt=typeof Blob<"u"?Blob:null;var mt={isBrowser:!0,classes:{URLSearchParams:dt,FormData:yt,Blob:wt},protocols:["http","https","file","blob","url","data"]};var JA={};eI(JA,{hasBrowserEnv:()=>pt,hasStandardBrowserEnv:()=>Ae,hasStandardBrowserWebWorkerEnv:()=>te});var pt=typeof window<"u"&&typeof document<"u",Ae=(A=>pt&&["ReactNative","NativeScript","NS"].indexOf(A)<0)(typeof navigator<"u"&&navigator.product),te=typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope&&typeof self.importScripts=="function";var m={...JA,...mt};function HA(A,t){return J(A,new m.classes.URLSearchParams,Object.assign({visitor:function(I,e,g,r){return m.isNode&&C.isBuffer(I)?(this.append(e,I.toString("base64")),!1):r.defaultVisitor.apply(this,arguments)}},t))}function Ie(A){return C.matchAll(/\\w+|\\[(\\w*)]/g,A).map(t=>t[0]==="[]"?"":t[1]||t[0])}function ee(A){let t={},I=Object.keys(A),e,g=I.length,r;for(e=0;e<g;e++)r=I[e],t[r]=A[r];return t}function ge(A){function t(I,e,g,r){let o=I[r++];if(o==="__proto__")return!0;let n=Number.isFinite(+o),c=r>=I.length;return o=!o&&C.isArray(g)?g.length:o,c?(C.hasOwnProp(g,o)?g[o]=[g[o],e]:g[o]=e,!n):((!g[o]||!C.isObject(g[o]))&&(g[o]=[]),t(I,e,g[o],r)&&C.isArray(g[o])&&(g[o]=ee(g[o])),!n)}if(C.isFormData(A)&&C.isFunction(A.entries)){let I={};return C.forEachEntry(A,(e,g)=>{t(Ie(e),g,I,0)}),I}return null}var fA=ge;function re(A,t,I){if(C.isString(A))try{return(t||JSON.parse)(A),C.trim(A)}catch(e){if(e.name!=="SyntaxError")throw e}return(I||JSON.stringify)(A)}var YA={transitional:cA,adapter:["xhr","http"],transformRequest:[function(t,I){let e=I.getContentType()||"",g=e.indexOf("application/json")>-1,r=C.isObject(t);if(r&&C.isHTMLForm(t)&&(t=new FormData(t)),C.isFormData(t))return g?JSON.stringify(fA(t)):t;if(C.isArrayBuffer(t)||C.isBuffer(t)||C.isStream(t)||C.isFile(t)||C.isBlob(t))return t;if(C.isArrayBufferView(t))return t.buffer;if(C.isURLSearchParams(t))return I.setContentType("application/x-www-form-urlencoded;charset=utf-8",!1),t.toString();let n;if(r){if(e.indexOf("application/x-www-form-urlencoded")>-1)return HA(t,this.formSerializer).toString();if((n=C.isFileList(t))||e.indexOf("multipart/form-data")>-1){let c=this.env&&this.env.FormData;return J(n?{"files[]":t}:t,c&&new c,this.formSerializer)}}return r||g?(I.setContentType("application/json",!1),re(t)):t}],transformResponse:[function(t){let I=this.transitional||YA.transitional,e=I&&I.forcedJSONParsing,g=this.responseType==="json";if(t&&C.isString(t)&&(e&&!this.responseType||g)){let o=!(I&&I.silentJSONParsing)&&g;try{return JSON.parse(t)}catch(n){if(o)throw n.name==="SyntaxError"?l.from(n,l.ERR_BAD_RESPONSE,this,null,this.response):n}}return t}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,maxBodyLength:-1,env:{FormData:m.classes.FormData,Blob:m.classes.Blob},validateStatus:function(t){return t>=200&&t<300},headers:{common:{Accept:"application/json, text/plain, */*","Content-Type":void 0}}};C.forEach(["delete","get","head","post","put","patch"],A=>{YA.headers[A]={}});var T=YA;var oe=C.toObjectSet(["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"]),St=A=>{let t={},I,e,g;return A&&A.split(`%0A`).forEach(function(o){g=o.indexOf(":"),I=o.substring(0,g).trim().toLowerCase(),e=o.substring(g+1).trim(),!(!I||t[I]&&oe[I])&&(I==="set-cookie"?t[I]?t[I].push(e):t[I]=[e]:t[I]=t[I]?t[I]+", "+e:e)}),t};var Ft=Symbol("internals");function z(A){return A&&String(A).trim().toLowerCase()}function lA(A){return A===!1||A==null?A:C.isArray(A)?A.map(lA):String(A)}function ie(A){let t=Object.create(null),I=/([^\\s,;=]+)\\s*(?:=\\s*([^,;]+))?/g,e;for(;e=I.exec(A);)t[e[1]]=e[2];return t}var Ce=A=>/^[-_a-zA-Z0-9^`|~,!%23$%&\'*+.]+$/.test(A.trim());function bA(A,t,I,e,g){if(C.isFunction(e))return e.call(this,t,I);if(g&&(t=I),!!C.isString(t)){if(C.isString(e))return t.indexOf(e)!==-1;if(C.isRegExp(e))return e.test(t)}}function Be(A){return A.trim().toLowerCase().replace(/([a-z\\d])(\\w*)/g,(t,I,e)=>I.toUpperCase()+e)}function se(A,t){let I=C.toCamelCase(" "+t);["get","set","has"].forEach(e=>{Object.defineProperty(A,e+I,{value:function(g,r,o){return this[e].call(this,t,g,r,o)},configurable:!0})})}var P=class{constructor(t){t&&this.set(t)}set(t,I,e){let g=this;function r(n,c,Q){let B=z(c);if(!B)throw new Error("header name must be a non-empty string");let i=C.findKey(g,B);(!i||g[i]===void 0||Q===!0||Q===void 0&&g[i]!==!1)&&(g[i||c]=lA(n))}let o=(n,c)=>C.forEach(n,(Q,B)=>r(Q,B,c));return C.isPlainObject(t)||t instanceof this.constructor?o(t,I):C.isString(t)&&(t=t.trim())&&!Ce(t)?o(St(t),I):t!=null&&r(I,t,e),this}get(t,I){if(t=z(t),t){let e=C.findKey(this,t);if(e){let g=this[e];if(!I)return g;if(I===!0)return ie(g);if(C.isFunction(I))return I.call(this,g,e);if(C.isRegExp(I))return I.exec(g);throw new TypeError("parser must be boolean|regexp|function")}}}has(t,I){if(t=z(t),t){let e=C.findKey(this,t);return!!(e&&this[e]!==void 0&&(!I||bA(this,this[e],e,I)))}return!1}delete(t,I){let e=this,g=!1;function r(o){if(o=z(o),o){let n=C.findKey(e,o);n&&(!I||bA(e,e[n],n,I))&&(delete e[n],g=!0)}}return C.isArray(t)?t.forEach(r):r(t),g}clear(t){let I=Object.keys(this),e=I.length,g=!1;for(;e--;){let r=I[e];(!t||bA(this,this[r],r,t,!0))&&(delete this[r],g=!0)}return g}normalize(t){let I=this,e={};return C.forEach(this,(g,r)=>{let o=C.findKey(e,r);if(o){I[o]=lA(g),delete I[r];return}let n=t?Be(r):String(r).trim();n!==r&&delete I[r],I[n]=lA(g),e[n]=!0}),this}concat(...t){return this.constructor.concat(this,...t)}toJSON(t){let I=Object.create(null);return C.forEach(this,(e,g)=>{e!=null&&e!==!1&&(I[g]=t&&C.isArray(e)?e.join(", "):e)}),I}[Symbol.iterator](){return Object.entries(this.toJSON())[Symbol.iterator]()}toString(){return Object.entries(this.toJSON()).map(([t,I])=>t+": "+I).join(`%0A`)}get[Symbol.toStringTag](){return"AxiosHeaders"}static from(t){return t instanceof this?t:new this(t)}static concat(t,...I){let e=new this(t);return I.forEach(g=>e.set(g)),e}static accessor(t){let e=(this[Ft]=this[Ft]={accessors:{}}).accessors,g=this.prototype;function r(o){let n=z(o);e[n]||(se(g,o),e[n]=!0)}return C.isArray(t)?t.forEach(r):r(t),this}};P.accessor(["Content-Type","Content-Length","Accept","Accept-Encoding","User-Agent","Authorization"]);C.reduceDescriptors(P.prototype,({value:A},t)=>{let I=t[0].toUpperCase()+t.slice(1);return{get:()=>A,set(e){this[I]=e}}});C.freezeMethods(P);var p=P;function _(A,t){let I=this||T,e=t||I,g=p.from(e.headers),r=e.data;return C.forEach(A,function(n){r=n.call(I,r,g.normalize(),t?t.status:void 0)}),g.normalize(),r}function v(A){return!!(A&&A.__CANCEL__)}function Rt(A,t,I){l.call(this,A??"canceled",l.ERR_CANCELED,t,I),this.name="CanceledError"}C.inherits(Rt,l,{__CANCEL__:!0});var H=Rt;function MA(A,t,I){let e=I.config.validateStatus;!I.status||!e||e(I.status)?A(I):t(new l("Request failed with status code "+I.status,[l.ERR_BAD_REQUEST,l.ERR_BAD_RESPONSE][Math.floor(I.status/100)-4],I.config,I.request,I))}var Nt=m.hasStandardBrowserEnv?{write(A,t,I,e,g,r){let o=[A+"="+encodeURIComponent(t)];C.isNumber(I)&&o.push("expires="+new Date(I).toGMTString()),C.isString(e)&&o.push("path="+e),C.isString(g)&&o.push("domain="+g),r===!0&&o.push("secure"),document.cookie=o.join("; ")},read(A){let t=document.cookie.match(new RegExp("(^|;\\\\s*)("+A+")=([^;]*)"));return t?decodeURIComponent(t[3]):null},remove(A){this.write(A,"",Date.now()-864e5)}}:{write(){},read(){return null},remove(){}};function qA(A){return/^([a-z][a-z\\d+\\-.]*:)?\\/\\//i.test(A)}function KA(A,t){return t?A.replace(/\\/?\\/$/,"")+"/"+t.replace(/^\\/+/,""):A}function $(A,t){return A&&!qA(t)?KA(A,t):t}var Ut=m.hasStandardBrowserEnv?function(){let t=/(msie|trident)/i.test(navigator.userAgent),I=document.createElement("a"),e;function g(r){let o=r;return t&&(I.setAttribute("href",o),o=I.href),I.setAttribute("href",o),{href:I.href,protocol:I.protocol?I.protocol.replace(/:$/,""):"",host:I.host,search:I.search?I.search.replace(/^\\?/,""):"",hash:I.hash?I.hash.replace(/^%23/,""):"",hostname:I.hostname,port:I.port,pathname:I.pathname.charAt(0)==="/"?I.pathname:"/"+I.pathname}}return e=g(window.location.href),function(o){let n=C.isString(o)?g(o):o;return n.protocol===e.protocol&&n.host===e.host}}():function(){return function(){return!0}}();function OA(A){let t=/^([-+\\w]{1,25})(:?\\/\\/|:)/.exec(A);return t&&t[1]||""}function ne(A,t){A=A||10;let I=new Array(A),e=new Array(A),g=0,r=0,o;return t=t!==void 0?t:1e3,function(c){let Q=Date.now(),B=e[r];o||(o=Q),I[g]=c,e[g]=Q;let i=r,f=0;for(;i!==g;)f+=I[i++],i=i%A;if(g=(g+1)%A,g===r&&(r=(r+1)%A),Q-o<t)return;let s=B&&Q-B;return s?Math.round(f*1e3/s):void 0}}var Gt=ne;function kt(A,t){let I=0,e=Gt(50,250);return g=>{let r=g.loaded,o=g.lengthComputable?g.total:void 0,n=r-I,c=e(n),Q=r<=o;I=r;let B={loaded:r,total:o,progress:o?r/o:void 0,bytes:n,rate:c||void 0,estimated:c&&o&&Q?(o-r)/c:void 0,event:g};B[t?"download":"upload"]=!0,A(B)}}var Qe=typeof XMLHttpRequest<"u",Lt=Qe&&function(A){return new Promise(function(I,e){let g=A.data,r=p.from(A.headers).normalize(),{responseType:o,withXSRFToken:n}=A,c;function Q(){A.cancelToken&&A.cancelToken.unsubscribe(c),A.signal&&A.signal.removeEventListener("abort",c)}let B;if(C.isFormData(g)){if(m.hasStandardBrowserEnv||m.hasStandardBrowserWebWorkerEnv)r.setContentType(!1);else if((B=r.getContentType())!==!1){let[E,...u]=B?B.split(";").map(y=>y.trim()).filter(Boolean):[];r.setContentType([E||"multipart/form-data",...u].join("; "))}}let i=new XMLHttpRequest;if(A.auth){let E=A.auth.username||"",u=A.auth.password?unescape(encodeURIComponent(A.auth.password)):"";r.set("Authorization","Basic "+btoa(E+":"+u))}let f=$(A.baseURL,A.url);i.open(A.method.toUpperCase(),X(f,A.params,A.paramsSerializer),!0),i.timeout=A.timeout;function s(){if(!i)return;let E=p.from("getAllResponseHeaders"in i&&i.getAllResponseHeaders()),y={data:!o||o==="text"||o==="json"?i.responseText:i.response,status:i.status,statusText:i.statusText,headers:E,config:A,request:i};MA(function(R){I(R),Q()},function(R){e(R),Q()},y),i=null}if("onloadend"in i?i.onloadend=s:i.onreadystatechange=function(){!i||i.readyState!==4||i.status===0&&!(i.responseURL&&i.responseURL.indexOf("file:")===0)||setTimeout(s)},i.onabort=function(){i&&(e(new l("Request aborted",l.ECONNABORTED,A,i)),i=null)},i.onerror=function(){e(new l("Network Error",l.ERR_NETWORK,A,i)),i=null},i.ontimeout=function(){let u=A.timeout?"timeout of "+A.timeout+"ms exceeded":"timeout exceeded",y=A.transitional||cA;A.timeoutErrorMessage&&(u=A.timeoutErrorMessage),e(new l(u,y.clarifyTimeoutError?l.ETIMEDOUT:l.ECONNABORTED,A,i)),i=null},m.hasStandardBrowserEnv&&(n&&C.isFunction(n)&&(n=n(A)),n||n!==!1&&Ut(f))){let E=A.xsrfHeaderName&&A.xsrfCookieName&&Nt.read(A.xsrfCookieName);E&&r.set(A.xsrfHeaderName,E)}g===void 0&&r.setContentType(null),"setRequestHeader"in i&&C.forEach(r.toJSON(),function(u,y){i.setRequestHeader(y,u)}),C.isUndefined(A.withCredentials)||(i.withCredentials=!!A.withCredentials),o&&o!=="json"&&(i.responseType=A.responseType),typeof A.onDownloadProgress=="function"&&i.addEventListener("progress",kt(A.onDownloadProgress,!0)),typeof A.onUploadProgress=="function"&&i.upload&&i.upload.addEventListener("progress",kt(A.onUploadProgress)),(A.cancelToken||A.signal)&&(c=E=>{i&&(e(!E||E.type?new H(null,A,i):E),i.abort(),i=null)},A.cancelToken&&A.cancelToken.subscribe(c),A.signal&&(A.signal.aborted?c():A.signal.addEventListener("abort",c)));let a=OA(f);if(a&&m.protocols.indexOf(a)===-1){e(new l("Unsupported protocol "+a+":",l.ERR_BAD_REQUEST,A));return}i.send(g||null)})};var TA={http:aA,xhr:Lt};C.forEach(TA,(A,t)=>{if(A){try{Object.defineProperty(A,"name",{value:t})}catch{}Object.defineProperty(A,"adapterName",{value:t})}});var Jt=A=>`- ${A}`,ae=A=>C.isFunction(A)||A===null||A===!1,DA={getAdapter:A=>{A=C.isArray(A)?A:[A];let{length:t}=A,I,e,g={};for(let r=0;r<t;r++){I=A[r];let o;if(e=I,!ae(I)&&(e=TA[(o=String(I)).toLowerCase()],e===void 0))throw new l(`Unknown adapter \'${o}\'`);if(e)break;g[o||"%23"+r]=e}if(!e){let r=Object.entries(g).map(([n,c])=>`adapter ${n} `+(c===!1?"is not supported by the environment":"is not available in the build")),o=t?r.length>1?`since :%0A`+r.map(Jt).join(`%0A`):" "+Jt(r[0]):"as no adapter specified";throw new l("There is no suitable adapter to dispatch the request "+o,"ERR_NOT_SUPPORT")}return e},adapters:TA};function PA(A){if(A.cancelToken&&A.cancelToken.throwIfRequested(),A.signal&&A.signal.aborted)throw new H(null,A)}function uA(A){return PA(A),A.headers=p.from(A.headers),A.data=_.call(A,A.transformRequest),["post","put","patch"].indexOf(A.method)!==-1&&A.headers.setContentType("application/x-www-form-urlencoded",!1),DA.getAdapter(A.adapter||T.adapter)(A).then(function(e){return PA(A),e.data=_.call(A,A.transformResponse,e),e.headers=p.from(e.headers),e},function(e){return v(e)||(PA(A),e&&e.response&&(e.response.data=_.call(A,A.transformResponse,e.response),e.response.headers=p.from(e.response.headers))),Promise.reject(e)})}var Ht=A=>A instanceof p?{...A}:A;function k(A,t){t=t||{};let I={};function e(Q,B,i){return C.isPlainObject(Q)&&C.isPlainObject(B)?C.merge.call({caseless:i},Q,B):C.isPlainObject(B)?C.merge({},B):C.isArray(B)?B.slice():B}function g(Q,B,i){if(C.isUndefined(B)){if(!C.isUndefined(Q))return e(void 0,Q,i)}else return e(Q,B,i)}function r(Q,B){if(!C.isUndefined(B))return e(void 0,B)}function o(Q,B){if(C.isUndefined(B)){if(!C.isUndefined(Q))return e(void 0,Q)}else return e(void 0,B)}function n(Q,B,i){if(i in t)return e(Q,B);if(i in A)return e(void 0,Q)}let c={url:r,method:r,data:r,baseURL:o,transformRequest:o,transformResponse:o,paramsSerializer:o,timeout:o,timeoutMessage:o,withCredentials:o,withXSRFToken:o,adapter:o,responseType:o,xsrfCookieName:o,xsrfHeaderName:o,onUploadProgress:o,onDownloadProgress:o,decompress:o,maxContentLength:o,maxBodyLength:o,beforeRedirect:o,transport:o,httpAgent:o,httpsAgent:o,cancelToken:o,socketPath:o,responseEncoding:o,validateStatus:n,headers:(Q,B)=>g(Ht(Q),Ht(B),!0)};return C.forEach(Object.keys(Object.assign({},A,t)),function(B){let i=c[B]||g,f=i(A[B],t[B],B);C.isUndefined(f)&&i!==n||(I[B]=f)}),I}var hA="1.6.8";var xA={};["object","boolean","number","function","string","symbol"].forEach((A,t)=>{xA[A]=function(e){return typeof e===A||"a"+(t<1?"n ":" ")+A}});var Yt={};xA.transitional=function(t,I,e){function g(r,o){return"[Axios v"+hA+"] Transitional option \'"+r+"\'"+o+(e?". "+e:"")}return(r,o,n)=>{if(t===!1)throw new l(g(o," has been removed"+(I?" in "+I:"")),l.ERR_DEPRECATED);return I&&!Yt[o]&&(Yt[o]=!0,console.warn(g(o," has been deprecated since v"+I+" and will be removed in the near future"))),t?t(r,o,n):!0}};function Ee(A,t,I){if(typeof A!="object")throw new l("options must be an object",l.ERR_BAD_OPTION_VALUE);let e=Object.keys(A),g=e.length;for(;g-- >0;){let r=e[g],o=t[r];if(o){let n=A[r],c=n===void 0||o(n,r,A);if(c!==!0)throw new l("option "+r+" must be "+c,l.ERR_BAD_OPTION_VALUE);continue}if(I!==!0)throw new l("Unknown option "+r,l.ERR_BAD_OPTION)}}var dA={assertOptions:Ee,validators:xA};var Y=dA.validators,x=class{constructor(t){this.defaults=t,this.interceptors={request:new LA,response:new LA}}async request(t,I){try{return await this._request(t,I)}catch(e){if(e instanceof Error){let g;Error.captureStackTrace?Error.captureStackTrace(g={}):g=new Error;let r=g.stack?g.stack.replace(/^.+\\n/,""):"";e.stack?r&&!String(e.stack).endsWith(r.replace(/^.+\\n.+\\n/,""))&&(e.stack+=`%0A`+r):e.stack=r}throw e}}_request(t,I){typeof t=="string"?(I=I||{},I.url=t):I=t||{},I=k(this.defaults,I);let{transitional:e,paramsSerializer:g,headers:r}=I;e!==void 0&&dA.assertOptions(e,{silentJSONParsing:Y.transitional(Y.boolean),forcedJSONParsing:Y.transitional(Y.boolean),clarifyTimeoutError:Y.transitional(Y.boolean)},!1),g!=null&&(C.isFunction(g)?I.paramsSerializer={serialize:g}:dA.assertOptions(g,{encode:Y.function,serialize:Y.function},!0)),I.method=(I.method||this.defaults.method||"get").toLowerCase();let o=r&&C.merge(r.common,r[I.method]);r&&C.forEach(["delete","get","head","post","put","patch","common"],a=>{delete r[a]}),I.headers=p.concat(o,r);let n=[],c=!0;this.interceptors.request.forEach(function(E){typeof E.runWhen=="function"&&E.runWhen(I)===!1||(c=c&&E.synchronous,n.unshift(E.fulfilled,E.rejected))});let Q=[];this.interceptors.response.forEach(function(E){Q.push(E.fulfilled,E.rejected)});let B,i=0,f;if(!c){let a=[uA.bind(this),void 0];for(a.unshift.apply(a,n),a.push.apply(a,Q),f=a.length,B=Promise.resolve(I);i<f;)B=B.then(a[i++],a[i++]);return B}f=n.length;let s=I;for(i=0;i<f;){let a=n[i++],E=n[i++];try{s=a(s)}catch(u){E.call(this,u);break}}try{B=uA.call(this,s)}catch(a){return Promise.reject(a)}for(i=0,f=Q.length;i<f;)B=B.then(Q[i++],Q[i++]);return B}getUri(t){t=k(this.defaults,t);let I=$(t.baseURL,t.url);return X(I,t.params,t.paramsSerializer)}};C.forEach(["delete","get","head","options"],function(t){x.prototype[t]=function(I,e){return this.request(k(e||{},{method:t,url:I,data:(e||{}).data}))}});C.forEach(["post","put","patch"],function(t){function I(e){return function(r,o,n){return this.request(k(n||{},{method:t,headers:e?{"Content-Type":"multipart/form-data"}:{},url:r,data:o}))}}x.prototype[t]=I(),x.prototype[t+"Form"]=I(!0)});var AA=x;var jA=class A{constructor(t){if(typeof t!="function")throw new TypeError("executor must be a function.");let I;this.promise=new Promise(function(r){I=r});let e=this;this.promise.then(g=>{if(!e._listeners)return;let r=e._listeners.length;for(;r-- >0;)e._listeners[r](g);e._listeners=null}),this.promise.then=g=>{let r,o=new Promise(n=>{e.subscribe(n),r=n}).then(g);return o.cancel=function(){e.unsubscribe(r)},o},t(function(r,o,n){e.reason||(e.reason=new H(r,o,n),I(e.reason))})}throwIfRequested(){if(this.reason)throw this.reason}subscribe(t){if(this.reason){t(this.reason);return}this._listeners?this._listeners.push(t):this._listeners=[t]}unsubscribe(t){if(!this._listeners)return;let I=this._listeners.indexOf(t);I!==-1&&this._listeners.splice(I,1)}static source(){let t;return{token:new A(function(g){t=g}),cancel:t}}},bt=jA;function WA(A){return function(I){return A.apply(null,I)}}function ZA(A){return C.isObject(A)&&A.isAxiosError===!0}var VA={Continue:100,SwitchingProtocols:101,Processing:102,EarlyHints:103,Ok:200,Created:201,Accepted:202,NonAuthoritativeInformation:203,NoContent:204,ResetContent:205,PartialContent:206,MultiStatus:207,AlreadyReported:208,ImUsed:226,MultipleChoices:300,MovedPermanently:301,Found:302,SeeOther:303,NotModified:304,UseProxy:305,Unused:306,TemporaryRedirect:307,PermanentRedirect:308,BadRequest:400,Unauthorized:401,PaymentRequired:402,Forbidden:403,NotFound:404,MethodNotAllowed:405,NotAcceptable:406,ProxyAuthenticationRequired:407,RequestTimeout:408,Conflict:409,Gone:410,LengthRequired:411,PreconditionFailed:412,PayloadTooLarge:413,UriTooLong:414,UnsupportedMediaType:415,RangeNotSatisfiable:416,ExpectationFailed:417,ImATeapot:418,MisdirectedRequest:421,UnprocessableEntity:422,Locked:423,FailedDependency:424,TooEarly:425,UpgradeRequired:426,PreconditionRequired:428,TooManyRequests:429,RequestHeaderFieldsTooLarge:431,UnavailableForLegalReasons:451,InternalServerError:500,NotImplemented:501,BadGateway:502,ServiceUnavailable:503,GatewayTimeout:504,HttpVersionNotSupported:505,VariantAlsoNegotiates:506,InsufficientStorage:507,LoopDetected:508,NotExtended:510,NetworkAuthenticationRequired:511};Object.entries(VA).forEach(([A,t])=>{VA[t]=A});var Mt=VA;function qt(A){let t=new AA(A),I=W(AA.prototype.request,t);return C.extend(I,AA.prototype,t,{allOwnKeys:!0}),C.extend(I,t,null,{allOwnKeys:!0}),I.create=function(g){return qt(k(A,g))},I}var h=qt(T);h.Axios=AA;h.CanceledError=H;h.CancelToken=bt;h.isCancel=v;h.VERSION=hA;h.toFormData=J;h.AxiosError=l;h.Cancel=h.CanceledError;h.all=function(t){return Promise.all(t)};h.spread=WA;h.isAxiosError=ZA;h.mergeConfig=k;h.AxiosHeaders=p;h.formToJSON=A=>fA(C.isHTMLForm(A)?new FormData(A):A);h.getAdapter=DA.getAdapter;h.HttpStatusCode=Mt;h.default=h;var yA=h;var{Axios:io,AxiosError:Co,CanceledError:Bo,isCancel:so,CancelToken:no,VERSION:Qo,all:ao,Cancel:Eo,isAxiosError:co,spread:fo,toFormData:lo,AxiosHeaders:Do,HttpStatusCode:uo,formToJSON:ho,getAdapter:yo,mergeConfig:wo}=yA;var tA,L,zA,XA={env:{emscripten_notify_memory_growth:function(A){zA=new Uint8Array(L.exports.memory.buffer)}}},wA=class{init(){return tA||(typeof fetch<"u"?tA=fetch("data:application/wasm;base64,"+Kt).then(t=>t.arrayBuffer()).then(t=>WebAssembly.instantiate(t,XA)).then(this._init):tA=WebAssembly.instantiate(Buffer.from(Kt,"base64"),XA).then(this._init),tA)}_init(t){L=t.instance,XA.env.emscripten_notify_memory_growth(0)}decode(t,I=0){if(!L)throw new Error("ZSTDDecoder: Await .init() before decoding.");let e=t.byteLength,g=L.exports.malloc(e);zA.set(t,g),I=I||Number(L.exports.ZSTD_findDecompressedSize(g,e));let r=L.exports.malloc(I),o=L.exports.ZSTD_decompress(r,I,g,e),n=zA.slice(r,r+o);return L.exports.free(g),L.exports.free(r),n}},Kt="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IARrdnE2AgAgARAPGiAAIAJBCGo2AgQLzgEBBn9Bun8hCgJAIAIoAgQiCCACKAIAIglqIg0gASAAa0sNAEFsIQogCSAEIAMoAgAiC2tLDQAgACAJaiIEIAIoAggiDGshAiAAIAFBIGsiACALIAlBABAgIAMgCSALajYCAAJAAkAgBCAFayAMTwRAIAIhBQwBCyAMIAQgBmtLDQIgByAHIAIgBWsiAmoiASAIak8EQCAEIAEgCBAKGgwCCyACIAhqIQggBCABQQAgAmsQCiACayEECyAEIAAgBSAIQQEQIAsgDSEKCyAKC8cEAQJ/IAAgA2ohBgJAIANBB0wEQANAIAAgBk8NAiAAIAItAAA6AAAgAEEBaiEAIAJBAWohAgwACwALIARBAUYEQAJAIAAgAmsiBUEHTQRAIAAgAi0AADoAACAAIAItAAE6AAEgACACLQACOgACIAAgAi0AAzoAAyAAIAIgBUECdCIFQcAeaigCAGoiAigAADYABCACIAVB4B5qKAIAayECDAELIAAgAikAADcAAAsgAkEIaiECIABBCGohAAsgASAGTwRAIAAgA2ohASAEQQFHIAAgAmtBD0pyRQRAA0AgACACKQAANwAAIAJBCGohAiAAQQhqIgAgAUkNAAwDCwALIAAgAikAADcAACAAIAIpAAg3AAggA0ERSQ0BIABBEGohAANAIAAgAikAEDcAACAAIAIpABg3AAggACACKQAgNwAQIAAgAikAKDcAGCACQSBqIQIgAEEgaiIAIAFJDQALDAELAkAgACABSwRAIAAhAQwBCyABIABrIQUCQCAEQQFHIAAgAmtBD0pyRQRAIAIhAwNAIAAgAykAADcAACADQQhqIQMgAEEIaiIAIAFJDQALDAELIAAgAikAADcAACAAIAIpAAg3AAggBUERSA0AIABBEGohACACIQMDQCAAIAMpABA3AAAgACADKQAYNwAIIAAgAykAIDcAECAAIAMpACg3ABggA0EgaiEDIABBIGoiACABSQ0ACwsgAiAFaiECCwNAIAEgBk8NASABIAItAAA6AAAgAUEBaiEBIAJBAWohAgwACwALC64HAgV/AX4jAEGAAWsiESQAIBEgAzYCfEF/IQ8CQAJAAkACQAJAIAIOBAEAAwIECyAGRQRAQbh/IQ8MBAtBbCEPIAUtAAAiAiADSw0DIAggAkEC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IAggH2shBgNAAkAgBiAPTgRAQQAhAwNAIANBA0YNAiAFIANBAnQiAmpBrNABaiACIARqKAJkNgIAIANBAWohAwwACwALAkACQAJAIAQoAtwBIgMgBEHwAGogBkEHcUEMbGoiCCgCACIMaiIQIBdLDQAgByAIKAIEIgsgDGoiCmogIUsNACAKQSBqIBYgB2tNDQELIAQgCCgCCDYCKCAEIAgpAgA3AyAgByAWIARBIGogBEHcAWogFyASIBggGhAfIQoMAQsgByAMaiECIAgoAgghCCAHIAMpAAA3AAAgByADKQAINwAIAkAgDEERSQ0AIAcgAykAEDcAECAHIAMpABg3ABggDEEQa0ERSA0AIANBEGohAyAHQSBqIQwDQCAMIAMpABA3AAAgDCADKQAYNwAIIAwgAykAIDcAECAMIAMpACg3ABggA0EgaiEDIAxBIGoiDCACSQ0ACwsgAiAIayEDIAQgEDYC3AEgAiASayAISQRAIAggAiAYa0sNByAaIBogAyASayIDaiIMIAtqTwRAIAIgDCALEAoaDAILIAMgC2ohCyACIAxBACADaxAKIANrIQIgEiEDCyAIQRBPBEAgAiADKQAANwAAIAIgAykACDcACCALQRFIDQEgAiALaiEIIAJBEGohAgNAIAIgAykAEDcAACACIAMpABg3AAggAiADKQAgNwAQIAIgAykAKDcAGCADQSBqIQMgAkEgaiICIAhJDQALDAELAkAgCEEHTQRAIAIgAy0AADoAACACIAMtAAE6AAEgAiADLQACOgACIAIgAy0AAzoAAyACIAMgCEECdCIIQcAeaigCAGoiAygAADYABCADIAhB4B5qKAIAayEDDAELIAIgAykAADcAAAsgC0EJSQ0AIAIgC2ohDCACQQhqIgggA0EIaiIDa0EPTARAA0AgCCADKQAANwAAIANBCGohAyAIQQhqIgggDEkNAAwCCwALIAggAykAADcAACAIIAMpAAg3AAggC0EZSA0AIAJBGGohAgNAIAIgAykAEDcAACACIAMpABg3AAggAiADKQAgNwAQIAIgAykAKDcAGCADQSBqIQMgAkEgaiICIAxJDQALCyAKQYh/SwRAIAohCQwGBSAGQQFqIQYgByAKaiEHDAILAAsLIAQoAtwBIQMLQbp/IQkgFyADayICIBYgB2tLDQIgBwR/IAcgAyACEAIgAmoFQQALIA5rIQkMAgsgBUEANgKc6wELIAQgBSgC8OoBIgM2AtwBIAkgDmohDCADIAUoAoDrAWohEAJAIA9FBEAgDiEGDAELIAUoArjpASENIAUoArTpASETIAUoArDpASESIAVBATYChOoBQQAhAwNAIANBA0cEQCAEIANBAnQiAmogAiAFakGs0AFqKAIANgKcASADQQFqIQMMAQsLQWwhCSAEQfAAaiICIAcgBhANQYh/Sw0BIDEgAiAFKAIAEB4gMCACIAUoAggQHiAvIAIgBSgCBBAeIAxBIGshGCAOIQYDQCAEKAKIASAEKAKEAUEDdGopAgAiQKciCkEQdiIZQf8BcSELIAQoApgBIAQoApQBQQN0aikCACJBpyIWQRB2Ih9B/wFxIRogBCgCkAEgBCgCjAFBA3RqKQIAIkJCIIinIQcgQUIgiCBAQiCIpyEDAkAgQkIQiKciCEH/AXEiAkECTwRAAkAgAkEZSSA/QoGAgBBUckUEQCAEQSAgBCgCdCIIayIRIAIgAiARSxsiFyAIajYCdCAHIAQoAnAgCHRBACAXa3YgAiAXayIXdGohCCAEQfAAahAPGiACIBFNDQEgBCAEKAJ0IgIgF2o2AnQgBCgCcCACdEEAIBdrdiAIaiEIDAELIAQgAiAEKAJ0IhFqNgJ0IAQoAnAgEXRBACAIa3YgB2ohCCAEQfAAahAPGgsgBCkCnAEhRCAEIAg2ApwBIAQgRDcCoAEMAQsCQCACRQRAIAMEQCAEKAKcASEIDAMLIAQoAqABIQgMAQsgBCAEKAJ0IgJBAWo2AnQCfyAHIANFaiAEKAJwIAJ0QR92aiICQQNGBEAgBCgCnAFBAWsMAQsgAkECdCAEaigCnAELIgdFIAdqIQggAkEBRwRAIAQgBCgCoAE2AqQBCwsgBCAEKAKcATYCoAEgBCAINgKcAQunIQIgQUKAgPwHg1BFBEAgBCAEKAJ0IgcgGmo2AnQgBCgCcCAHdEEAIB9rdiACaiECCyALIBpqQRRPBEAgBEHwAGoQDxoLIEBCgID8B4NQRQRAIAQgBCgCdCIHIAtqNgJ0IAQoAnAgB3RBACAZa3YgA2ohAwsgBEHwAGoQDxogBCAEKAJwIgdBACAKQRh2IgsgBCgCdGoiGmt2IAtBAnRBoB1qKAIAcSAKQf//A3FqNgKEASAEIBogFkEYdiIKaiILNgJ0IAQgCkECdEGgHWooAgAgB0EAIAtrdnEgFkH//wNxajYClAEgBEHwAGoQDxogBCBCpyIHQRh2IgogBCgCdGoiCzYCdCAEIApBAnRBoB1qKAIAIAQoAnBBACALa3ZxIAdB//8DcWo2AowBIAQgAzYCOCAEIAI2AjwgBCAINgJAAkACQAJAIAQoAtwBIgsgA2oiFiAQSw0AIAYgAiADaiIKaiAYSw0AIApBIGogDCAGa00NAQsgBCAEQUBrKAIANgIIIAQgBCkDODcDACAGIAwgBCAEQdwBaiAQIBIgEyANEB8hCgwBCyADIAZqIQcgBiALKQAANwAAIAYgCykACDcACAJAIANBEUkNACAGIAspABA3ABAgBiALKQAYNwAYIANBEGtBEUgNACALQRBqIQMgBkEgaiELA0AgCyADKQAQNwAAIAsgAykAGDcACCALIAMpACA3ABAgCyADKQAoNwAYIANBIGohAyALQSBqIgsgB0kNAAsLIAcgCGshAyAEIBY2AtwBIAcgEmsgCEkEQCAIIAcgE2tLDQQgDSANIAMgEmsiA2oiCyACak8EQCAHIAsgAhAKGgwCCyAHIAtBACADaxAKIAQgAiADaiICNgI8IANrIQcgEiEDCyAIQRBPBEAgByADKQAANwAAIAcgAykACDcACCACQRFIDQEgAiAHaiEIIAdBEGohAgNAIAIgAykAEDcAACACIAMpABg3AAggAiADKQAgNwAQIAIgAykAKDcAGCADQSBqIQMgAkEgaiICIAhJDQALDAELAkAgCEEHTQRAIAcgAy0AADoAACAHIAMtAAE6AAEgByADLQACOgACIAcgAy0AAzoAAyAHIAMgCEECdCIIQcAeaigCAGoiAygAADYABCADIAhB4B5qKAIAayEDDAELIAcgAykAADcAAAsgAkEJSQ0AIAIgB2ohCyAHQQhqIgggA0EIaiIDa0EPTARAA0AgCCADKQAANwAAIANBCGohAyAIQQhqIgggC0kNAAwCCwALIAggAykAADcAACAIIAMpAAg3AAggAkEZSA0AIAdBGGohAgNAIAIgAykAEDcAACACIAMpABg3AAggAiADKQAgNwAQIAIgAykAKDcAGCADQSBqIQMgAkEgaiICIAtJDQALCyAKQYh/SwRAIAohCQwDCyAGIApqIQYgBEHwAGoQDyEDIA9B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";var Ot=new wA,Tt=!1;async function ce(A,t,I){let e=null;typeof A!="string"?e=A.href:A.startsWith("http")?e=A:e=`${t}/${A}`,e.endsWith(".js")&&(e=e.substring(0,e.length-3)),e.endsWith(".wasm")&&(e=e.substring(0,e.length-5));let g=`${e}.wasm`,r=await yA.get(`${g}.zst`,{responseType:"arraybuffer",params:I});Tt||(await Ot.init(),Tt=!0);let n=Ot.decode(new Uint8Array(r.data)).buffer;return(await import(`${e}.js`)).default({wasmBinary:n})}var Pt=ce;var mA=new Map;async function fe(A,t,I){let e=A,g=A,r=null;return typeof A!="string"&&(e=new URL(A.href),g=e.href),mA.has(g)?r=await mA.get(g):(mA.set(g,Pt(e,t,I)),r=await mA.get(g)),r}var xt=fe;var le={TextFile:"TextFile",BinaryFile:"BinaryFile",TextStream:"TextStream",BinaryStream:"BinaryStream",Image:"Image",PointSet:"PointSet",Mesh:"Mesh",PolyData:"PolyData",TransformList:"TransformList",JsonCompatible:"JsonCompatible"},D=le;var De={Int8:"int8",UInt8:"uint8",Int16:"int16",UInt16:"uint16",Int32:"int32",UInt32:"uint32",Int64:"int64",UInt64:"uint64",SizeValueType:"uint64",IdentifierType:"uint64",IndexValueType:"int64",OffsetValueType:"int64"},S=De;var ue={Float32:"float32",Float64:"float64",SpacePrecisionType:"float64"},j=ue;function he(A,t){let I=null;switch(A){case S.UInt8:{I=new Uint8Array(t);break}case S.Int8:{I=new Int8Array(t);break}case S.UInt16:{I=new Uint16Array(t);break}case S.Int16:{I=new Int16Array(t);break}case S.UInt32:{I=new Uint32Array(t);break}case S.Int32:{I=new Int32Array(t);break}case S.UInt64:{typeof globalThis.BigUint64Array=="function"?I=new BigUint64Array(t):I=new Uint8Array(t);break}case S.Int64:{typeof globalThis.BigInt64Array=="function"?I=new BigInt64Array(t):I=new Uint8Array(t);break}case j.Float32:{I=new Float32Array(t);break}case j.Float64:{I=new Float64Array(t);break}case"null":{I=null;break}case null:{I=null;break}default:throw new Error("Type is not supported as a TypedArray")}return I}var G=he;var Zt=typeof globalThis.SharedArrayBuffer=="function",jt=new TextEncoder,Wt=new TextDecoder("utf-8");function de(A,t){let I={flags:"r",encoding:"binary"},e=A.fs_open(t,I.flags),r=A.fs_stat(t).size,o=null;Zt?o=new SharedArrayBuffer(r):o=new ArrayBuffer(r);let n=new Uint8Array(o);return A.fs_read(e,n,0,r,0),A.fs_close(e),n}function Vt(A,t,I){let e=null;Zt?e=new SharedArrayBuffer(I):e=new ArrayBuffer(I);let g=new Uint8Array(e),r=new Uint8Array(A.HEAPU8.buffer,t,I);return g.set(r),g}function d(A,t,I,e){let g=0;return t!==null&&(g=A.ccall("itk_wasm_input_array_alloc","number",["number","number","number","number"],[0,I,e,t.buffer.byteLength]),A.HEAPU8.set(new Uint8Array(t.buffer),g)),g}function b(A,t,I){let e=JSON.stringify(t),g=A.lengthBytesUTF8(e)+1,r=A.ccall("itk_wasm_input_json_alloc","number",["number","number","number"],[0,I,g]);A.stringToUTF8(e,r,g)}function w(A,t,I,e){let g=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,t,I]),r=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,t,I]),o=Vt(A,g,r);return G(e,o.buffer)}function IA(A,t){let I=A.ccall("itk_wasm_output_json_address","number",["number","number"],[0,t]),e=A.UTF8ToString(I);return JSON.parse(e)}function ye(A,t,I,e){e!=null&&e.length>0&&e.forEach(function(Q,B){switch(Q.type){case D.TextStream:{let i=jt.encode(Q.data.data),f=d(A,i,B,0),s={size:i.buffer.byteLength,data:`data:application/vnd.itk.address,0:${f}`};b(A,s,B);break}case D.JsonCompatible:{let i=jt.encode(JSON.stringify(Q.data)),f=d(A,i,B,0),s={size:i.buffer.byteLength,data:`data:application/vnd.itk.address,0:${f}`};b(A,s,B);break}case D.BinaryStream:{let i=Q.data.data,f=d(A,i,B,0),s={size:i.buffer.byteLength,data:`data:application/vnd.itk.address,0:${f}`};b(A,s,B);break}case D.TextFile:{A.fs_writeFile(Q.data.path,Q.data.data);break}case D.BinaryFile:{A.fs_writeFile(Q.data.path,Q.data.data);break}case D.Image:{let i=Q.data,f=d(A,i.data,B,0),s=d(A,i.direction,B,1),a=typeof i.metadata?.entries<"u"?Array.from(i.metadata.entries()):[],E={imageType:i.imageType,name:i.name,origin:i.origin,spacing:i.spacing,direction:`data:application/vnd.itk.address,0:${s}`,size:i.size,data:`data:application/vnd.itk.address,0:${f}`,metadata:a};b(A,E,B);break}case D.Mesh:{let i=Q.data,f=d(A,i.points,B,0),s=d(A,i.cells,B,1),a=d(A,i.pointData,B,2),E=d(A,i.cellData,B,3),u={meshType:i.meshType,name:i.name,numberOfPoints:i.numberOfPoints,points:`data:application/vnd.itk.address,0:${f}`,numberOfCells:i.numberOfCells,cells:`data:application/vnd.itk.address,0:${s}`,cellBufferSize:i.cellBufferSize,numberOfPointPixels:i.numberOfPointPixels,pointData:`data:application/vnd.itk.address,0:${a}`,numberOfCellPixels:i.numberOfCellPixels,cellData:`data:application/vnd.itk.address,0:${E}`};b(A,u,B);break}case D.PointSet:{let i=Q.data,f=d(A,i.points,B,0),s=d(A,i.pointData,B,1),a={pointSetType:i.pointSetType,name:i.name,numberOfPoints:i.numberOfPoints,points:`data:application/vnd.itk.address,0:${f}`,numberOfPointPixels:i.numberOfPointPixels,pointData:`data:application/vnd.itk.address,0:${s}`};b(A,a,B);break}case D.TransformList:{let i=Q.data,f=[];i.forEach((s,a)=>{let u=`data:application/vnd.itk.address,0:${d(A,s.fixedParameters,B,a*2)}`,F=`data:application/vnd.itk.address,0:${d(A,s.parameters,B,a*2+1)}`,R={transformType:s.transformType,numberOfFixedParameters:s.numberOfFixedParameters,numberOfParameters:s.numberOfParameters,name:s.name,inputSpaceName:s.inputSpaceName,outputSpaceName:s.outputSpaceName,parameters:F,fixedParameters:u};f.push(R)}),b(A,f,B);break}case D.PolyData:{let i=Q.data,f=d(A,i.points,B,0),s=d(A,i.vertices,B,1),a=d(A,i.lines,B,2),E=d(A,i.polygons,B,3),u=d(A,i.triangleStrips,B,4),y=d(A,i.pointData,B,5),F=d(A,i.pointData,B,6),R={polyDataType:i.polyDataType,name:i.name,numberOfPoints:i.numberOfPoints,points:`data:application/vnd.itk.address,0:${f}`,verticesBufferSize:i.verticesBufferSize,vertices:`data:application/vnd.itk.address,0:${s}`,linesBufferSize:i.linesBufferSize,lines:`data:application/vnd.itk.address,0:${a}`,polygonsBufferSize:i.polygonsBufferSize,polygons:`data:application/vnd.itk.address,0:${E}`,triangleStripsBufferSize:i.triangleStripsBufferSize,triangleStrips:`data:application/vnd.itk.address,0:${u}`,numberOfPointPixels:i.numberOfPointPixels,pointData:`data:application/vnd.itk.address,0:${y}`,numberOfCellPixels:i.numberOfCellPixels,cellData:`data:application/vnd.itk.address,0:${F}`};b(A,R,B);break}default:throw Error("Unsupported input InterfaceType")}}),A.resetModuleStdout(),A.resetModuleStderr();let g=A.stackSave(),r=0;try{r=A.callMain(t.slice())}catch(Q){throw typeof Q=="number"&&(console.log("Exception while running pipeline:"),console.log("stdout:",A.getModuleStdout()),console.error("stderr:",A.getModuleStderr()),typeof A.getExceptionMessage<"u"?console.error("exception:",A.getExceptionMessage(Q)):console.error("Build module in Debug mode for exception message information.")),Q}finally{A.stackRestore(g)}let o=A.getModuleStdout(),n=A.getModuleStderr(),c=[];return I!=null&&I.length>0&&r===0&&I.forEach(function(Q,B){let i=null;switch(Q.type){case D.TextStream:{let s=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,B,0]),a=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,B,0]),E=new Uint8Array(A.HEAPU8.buffer,s,a);i={data:Wt.decode(E)};break}case D.JsonCompatible:{let s=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,B,0]),a=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,B,0]),E=new Uint8Array(A.HEAPU8.buffer,s,a);i=JSON.parse(Wt.decode(E));break}case D.BinaryStream:{let s=A.ccall("itk_wasm_output_array_address","number",["number","number","number"],[0,B,0]),a=A.ccall("itk_wasm_output_array_size","number",["number","number","number"],[0,B,0]);i={data:Vt(A,s,a)};break}case D.TextFile:{i={path:Q.data.path,data:A.fs_readFile(Q.data.path,{encoding:"utf8"})};break}case D.BinaryFile:{i={path:Q.data.path,data:de(A,Q.data.path)};break}case D.Image:{let s=IA(A,B);s.data=w(A,B,0,s.imageType.componentType),s.direction=w(A,B,1,j.Float64),s.metadata=new Map(s.metadata),i=s;break}case D.Mesh:{let s=IA(A,B);s.numberOfPoints>0?s.points=w(A,B,0,s.meshType.pointComponentType):s.points=G(s.meshType.pointComponentType,new ArrayBuffer(0)),s.numberOfCells>0?s.cells=w(A,B,1,s.meshType.cellComponentType):s.cells=G(s.meshType.cellComponentType,new ArrayBuffer(0)),s.numberOfPointPixels>0?s.pointData=w(A,B,2,s.meshType.pointPixelComponentType):s.pointData=G(s.meshType.pointPixelComponentType,new ArrayBuffer(0)),s.numberOfCellPixels>0?s.cellData=w(A,B,3,s.meshType.cellPixelComponentType):s.cellData=G(s.meshType.cellPixelComponentType,new ArrayBuffer(0)),i=s;break}case D.PointSet:{let s=IA(A,B);s.numberOfPoints>0?s.points=w(A,B,0,s.pointSetType.pointComponentType):s.points=G(s.pointSetType.pointComponentType,new ArrayBuffer(0)),s.numberOfPointPixels>0?s.pointData=w(A,B,1,s.pointSetType.pointPixelComponentType):s.pointData=G(s.pointSetType.pointPixelComponentType,new ArrayBuffer(0)),i=s;break}case D.TransformList:{let s=IA(A,B);s.forEach((a,E)=>{a.numberOfFixedParameters>0&&(s[E].fixedParameters=w(A,B,E*2,a.transformType.parametersValueType)),a.numberOfFixedParameters>0&&(s[E].parameters=w(A,B,E*2+1,a.transformType.parametersValueType))}),i=s;break}case D.PolyData:{let s=IA(A,B);s.numberOfPoints>0?s.points=w(A,B,0,j.Float32):s.points=new Float32Array,s.verticesBufferSize>0?s.vertices=w(A,B,1,S.UInt32):s.vertices=new Uint32Array,s.linesBufferSize>0?s.lines=w(A,B,2,S.UInt32):s.lines=new Uint32Array,s.polygonsBufferSize>0?s.polygons=w(A,B,3,S.UInt32):s.polygons=new Uint32Array,s.triangleStripsBufferSize>0?s.triangleStrips=w(A,B,4,S.UInt32):s.triangleStrips=new Uint32Array,s.numberOfPointPixels>0?s.pointData=w(A,B,5,s.polyDataType.pointPixelComponentType):s.pointData=G(s.polyDataType.pointPixelComponentType,new ArrayBuffer(0)),s.numberOfCellPixels>0?s.cellData=w(A,B,6,s.polyDataType.cellPixelComponentType):s.cellData=G(s.polyDataType.cellPixelComponentType,new ArrayBuffer(0)),i=s;break}default:throw Error("Unsupported output InterfaceType")}let f={type:Q.type,data:i};c.push(f)}),{returnValue:r,stdout:o,stderr:n,outputs:c}}var Xt=ye;var we=typeof globalThis.SharedArrayBuffer<"u";function me(A,t){if(A==null)return[];let I=[];for(let e=0;e<A.length;e++){let g=pe(A[e],t);g!==null&&I.push(g)}return I}function pe(A,t){if(A==null)return null;let I=null;return A.buffer!==void 0?I=A.buffer:A.byteLength!==void 0&&(I=A),we&&I instanceof SharedArrayBuffer?null:t?I:I.slice(0)}var zt=me;function Se(A){return[A.data,A.direction]}var _t=Se;function Fe(A){return[A.points,A.pointData,A.cells,A.cellData]}var vt=Fe;function Re(A){return[A.points,A.vertices,A.lines,A.polygons,A.triangleStrips,A.pointData,A.cellData]}var $t=Re;async function Ne(A,t,I,e){let g=Xt(A,t,I,e),r=[];return g.outputs.forEach(function(o){if(o.type===D.BinaryStream||o.type===D.BinaryFile){let n=o.data;r.push(n)}else if(o.type===D.Image){let n=o.data;r.push(..._t(n))}else if(o.type===D.Mesh){let n=o.data;r.push(...vt(n))}else if(o.type===D.PolyData){let n=o.data;r.push(...$t(n))}}),FA(g,zt(r,!0))}var AI=Ne;var Ue={runPipeline:async function(A,t,I,e,g,r){let o=await xt(A,t,r);return await AI(o,I,e,g)}};CA(Ue);%0A/*! Bundled license information:%0A%0Acomlink/dist/esm/comlink.mjs:%0A  (**%0A   * @license%0A   * Copyright 2019 Google LLC%0A   * SPDX-License-Identifier: Apache-2.0%0A   *)%0A*/%0A';Rt(kt);export{w as getDefaultWebWorker,d as getPipelineWorkerUrl,h as getPipelinesBaseUrl,Ie as hdf5ReadTransform,ge as hdf5WriteTransform,le as matReadTransform,Be as matWriteTransform,Ce as mncReadTransform,fe as mncWriteTransform,Uo as readTransform,Ys as setDefaultWebWorker,Rt as setPipelineWorkerUrl,Gs as setPipelinesBaseUrl,ce as txtReadTransform,ue as txtWriteTransform,TA as version,Ee as wasmReadTransform,Qe as wasmWriteTransform,pe as wasmZstdReadTransform,me as wasmZstdWriteTransform,To as writeTransform};
/*! Bundled license information:

comlink/dist/esm/comlink.mjs:
  (**
   * @license
   * Copyright 2019 Google LLC
   * SPDX-License-Identifier: Apache-2.0
   *)
*/
""" default_config = JsPackageConfig(default_js_module) js_package = JsPackage(default_config) diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/read_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/read_transform_async.py new file mode 100644 index 000000000..235c874b7 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/read_transform_async.py @@ -0,0 +1,87 @@ +import os +from typing import Optional, Union +from pathlib import Path + +from itkwasm import ( + TransformList, + BinaryFile, +) + +from .js_package import js_package + +from itkwasm.pyodide import ( + to_js, + to_py, + js_resources +) + +from .extension_to_transform_io import extension_to_transform_io +from .transform_io_index import transform_io_index + +async def read_transform_async( + serialized_transform: os.PathLike, + float_parameters: bool = False, +) -> TransformList: + """Read an transform file format and convert it to the itk-wasm file format + + :param serialized_transform: Input transform serialized in the file format + :type serialized_transform: os.PathLike + + :param float_parameters: Use float for the parameter value type. The default is double. + :type float_parameters: bool + + :return: Output transform + :rtype: TransformList + """ + js_module = await js_package.js_module + web_worker = js_resources.web_worker + + kwargs = {} + if float_parameters: + kwargs["floatParameters"] = to_js(float_parameters) + + extension = ''.join(Path(serialized_transform).suffixes) + + io = None + if extension in extension_to_transform_io: + func = f"{extension_to_transform_io[extension]}ReadTransform" + io = getattr(js_module, func) + else: + for ioname in transform_io_index: + func = f"{ioname}ReadTransform" + io = getattr(js_module, func) + outputs = await io(to_js(BinaryFile(serialized_transform)), webWorker=web_worker, noCopy=True, **kwargs) + outputs_object_map = outputs.as_object_map() + web_worker = outputs_object_map['webWorker'] + js_resources.web_worker = web_worker + could_read = to_py(outputs_object_map['couldRead']) + if could_read: + transform = to_py(outputs_object_map['transform']) + return transform + + if io is None: + raise RuntimeError(f"Could not find an transform reader for {extension}") + + outputs = await io(to_js(BinaryFile(serialized_transform)), webWorker=web_worker, noCopy=True, **kwargs) + outputs_object_map = outputs.as_object_map() + web_worker = outputs_object_map['webWorker'] + could_read = to_py(outputs_object_map['couldRead']) + + if not could_read: + raise RuntimeError(f"Could not read {serialized_transform}") + + js_resources.web_worker = web_worker + + transform = to_py(outputs_object_map['transform']) + + return transform + +async def transformread_async( + serialized_transform: os.PathLike, + float_parameters: bool = False, +) -> TransformList: + return await read_transform_async(serialized_transform, float_parameters=float_parameters) + +transformread_async.__doc__ = f"""{read_transform_async.__doc__} + Alias for read_transform_async. + """ diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/transform_io_index.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/transform_io_index.py new file mode 100644 index 000000000..1f186a8dc --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/transform_io_index.py @@ -0,0 +1,9 @@ +transform_io_index = [ + 'hdf5', + 'mat', + 'mnc', + 'txt', + 'wasm', + 'wasm_ztd', +] + diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/write_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/write_transform_async.py new file mode 100644 index 000000000..296d4c952 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/itkwasm_transform_io_emscripten/write_transform_async.py @@ -0,0 +1,94 @@ +import os +import importlib +from pathlib import Path +from typing import Optional, Union + +from itkwasm import TransformList, PixelTypes, IntTypes, FloatTypes, BinaryFile + +from itkwasm.pyodide import ( + to_js, + to_py, + js_resources +) + +from .js_package import js_package + +from .extension_to_transform_io import extension_to_transform_io +from .transform_io_index import transform_io_index + +async def write_transform_async( + transform: TransformList, + serialized_transform: os.PathLike, + float_parameters: bool = False, + use_compression: bool = False, +) -> None: + """Write an itk-wasm TransformList to an transform file format. + + :param transform: Input transform + :type transform: TransformList + + :param serialized_transform: Output transform serialized in the file format. + :type serialized_transform: str + + :param float_parameters: Use float for the parameter value type. The default is double. + :type float_parameters: bool + + :param use_compression: Use compression in the written file + :type use_compression: bool + + :param serialized_transform: Input transform serialized in the file format + :type serialized_transform: os.PathLike + """ + js_module = await js_package.js_module + web_worker = js_resources.web_worker + + kwargs = {} + if float_parameters: + kwargs["floatParameters"] = to_js(float_parameters) + if use_compression: + kwargs["useCompression"] = to_js(use_compression) + + extension = ''.join(Path(serialized_transform).suffixes) + + io = None + if extension in extension_to_transform_io: + func = f"{extension_to_transform_io[extension]}WriteTransform" + io = getattr(js_module, func) + else: + for ioname in transform_io_index: + func = f"{ioname}WriteTransform" + io = getattr(js_module, func) + outputs = await io(to_js(transform), to_js(serialized_transform), webWorker=web_worker, noCopy=True, **kwargs) + outputs_object_map = outputs.as_object_map() + web_worker = outputs_object_map['webWorker'] + js_resources.web_worker = web_worker + could_write = to_py(outputs_object_map['couldWrite']) + if could_write: + to_py(outputs_object_map['serializedTransform']) + return + + if io is None: + raise RuntimeError(f"Could not find an transform writer for {extension}") + + outputs = await io(to_js(transform), to_js(serialized_transform), webWorker=web_worker, noCopy=True, **kwargs) + outputs_object_map = outputs.as_object_map() + web_worker = outputs_object_map['webWorker'] + js_resources.web_worker = web_worker + could_write = to_py(outputs_object_map['couldWrite']) + + if not could_write: + raise RuntimeError(f"Could not write {serialized_transform}") + + to_py(outputs_object_map['serializedTransform']) + +async def transformwrite_async( + transform: TransformList, + serialized_transform: os.PathLike, + float_parameters: bool = False, + use_compression: bool = False, +) -> None: + return write_transform_async(transform, serialized_transform, float_parameters=float_parameters, use_compression=use_compression) + +transformwrite_async.__doc__ = f"""{write_transform_async.__doc__} + Alias for write_transform. + """ diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/pyproject.toml b/packages/transform-io/python/itkwasm-transform-io-emscripten/pyproject.toml index 772c2d9ee..204c9960a 100644 --- a/packages/transform-io/python/itkwasm-transform-io-emscripten/pyproject.toml +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/pyproject.toml @@ -5,7 +5,7 @@ build-backend = "hatchling.build" [project] name = "itkwasm-transform-io-emscripten" readme = "README.md" -license = "Apache-2.0" +license-expression = "Apache-2.0" dynamic = ["version"] description = "Input and output for scientific and medical coordinate transform file formats." classifiers = [ @@ -19,11 +19,11 @@ classifiers = [ "Intended Audience :: Developers", "Intended Audience :: Science/Research", "Programming Language :: Python :: 3", - "Programming Language :: Python :: 3.8", "Programming Language :: Python :: 3.9", "Programming Language :: Python :: 3.10", "Programming Language :: Python :: 3.11", "Programming Language :: Python :: 3.12", + "Programming Language :: Python :: 3.13", ] keywords = [ "itkwasm", @@ -31,9 +31,9 @@ keywords = [ "emscripten", ] -requires-python = ">=3.8" +requires-python = ">=3.9" dependencies = [ - "itkwasm >= 1.0.b171", + "itkwasm >= 1.0.b185", ] [tool.hatch.version] diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/__init__.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/__init__.py new file mode 100644 index 000000000..e69de29bb diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/fixtures.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/fixtures.py new file mode 100644 index 000000000..597cf189a --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/fixtures.py @@ -0,0 +1,25 @@ +import pytest +import sys +import glob + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from itkwasm_transform_io_emscripten import __version__ as test_package_version + +@pytest.fixture +def package_wheel(): + return f"itkwasm_transform_io_emscripten-{test_package_version}-py3-none-any.whl" + +@pytest.fixture +def input_data(): + from pathlib import Path + input_base_path = Path(__file__).parent.parent.parent.parent / 'test' / 'data' / 'input' + test_files = list(input_base_path.glob('*')) + data = {} + for test_file in test_files: + with open(test_file, 'rb') as f: + data[test_file.name] = f.read() + return data \ No newline at end of file diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_hdf5_read_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_hdf5_read_transform_async.py new file mode 100644 index 000000000..0650fbe42 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_hdf5_read_transform_async.py @@ -0,0 +1,58 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_hdf5_read_transform_async(selenium, package_wheel, input_data): + import micropip + await micropip.install(package_wheel) + + from pathlib import Path + + import numpy as np + from itkwasm import TransformParameterizations, FloatTypes + + from itkwasm_transform_io_emscripten import hdf5_read_transform_async, hdf5_write_transform_async + + def write_input_data_to_fs(input_data, filename): + with open(filename, 'wb') as fp: + fp.write(input_data[filename]) + + def verify_test_linear_transform(transform_list): + assert len(transform_list) == 1 + transform = transform_list[0] + assert transform.transformType.transformParameterization == TransformParameterizations.Affine + assert transform.transformType.parametersValueType == FloatTypes.Float64 + assert transform.numberOfParameters == 12 + assert transform.numberOfFixedParameters == 3 + np.testing.assert_allclose(transform.fixedParameters, np.array([0.0, 0.0, 0.0])) + np.testing.assert_allclose(transform.parameters, np.array([ + 0.65631490118447, 0.5806583745824385, -0.4817536741017158, + -0.7407986817430222, 0.37486398378429736, -0.5573995934598175, + -0.14306664045479867, 0.7227121458012518, 0.676179776908723, + -65.99999999999997, 69.00000000000004, 32.000000000000036])) + + test_file_path = 'LinearTransform.h5' + write_input_data_to_fs(input_data, test_file_path) + + assert Path(test_file_path).exists() + + could_read, transform = await hdf5_read_transform_async(test_file_path) + assert could_read + verify_test_linear_transform(transform) + + test_output_file_path = 'out-LinearTransform.h5' + + use_compression = False + could_write = await hdf5_write_transform_async(transform, test_output_file_path, use_compression) + assert could_write + + could_read, transform = await hdf5_read_transform_async(test_output_file_path) + assert could_read + verify_test_linear_transform(transform) diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_hdf5_write_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_hdf5_write_transform_async.py new file mode 100644 index 000000000..2e71e02a9 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_hdf5_write_transform_async.py @@ -0,0 +1,18 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_hdf5_write_transform_async(selenium, package_wheel): + import micropip + await micropip.install(package_wheel) + + from itkwasm_transform_io_emscripten import hdf5_write_transform_async + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_mat_read_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_mat_read_transform_async.py new file mode 100644 index 000000000..6077969a9 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_mat_read_transform_async.py @@ -0,0 +1,18 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_mat_read_transform_async(selenium, package_wheel): + import micropip + await micropip.install(package_wheel) + + from itkwasm_transform_io_emscripten import mat_read_transform_async + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_mat_write_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_mat_write_transform_async.py new file mode 100644 index 000000000..8ea910537 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_mat_write_transform_async.py @@ -0,0 +1,18 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_mat_write_transform_async(selenium, package_wheel): + import micropip + await micropip.install(package_wheel) + + from itkwasm_transform_io_emscripten import mat_write_transform_async + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_mnc_read_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_mnc_read_transform_async.py new file mode 100644 index 000000000..3cb4e29df --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_mnc_read_transform_async.py @@ -0,0 +1,18 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_mnc_read_transform_async(selenium, package_wheel): + import micropip + await micropip.install(package_wheel) + + from itkwasm_transform_io_emscripten import mnc_read_transform_async + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_mnc_write_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_mnc_write_transform_async.py new file mode 100644 index 000000000..0a2276375 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_mnc_write_transform_async.py @@ -0,0 +1,18 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_mnc_write_transform_async(selenium, package_wheel): + import micropip + await micropip.install(package_wheel) + + from itkwasm_transform_io_emscripten import mnc_write_transform_async + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_read_write_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_read_write_transform_async.py new file mode 100644 index 000000000..cd9f9622d --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_read_write_transform_async.py @@ -0,0 +1,58 @@ +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +import pytest +from pytest_pyodide import run_in_pyodide +from .fixtures import package_wheel, input_data + +@pytest.mark.driver_timeout(30) +@run_in_pyodide(packages=['micropip', 'numpy']) +async def test_read_write_mesh_async(selenium, package_wheel, input_data): + import micropip + await micropip.install(package_wheel) + def write_input_data_to_fs(input_data, filename): + with open(filename, 'wb') as fp: + fp.write(input_data[filename]) + + from pathlib import Path + + from itkwasm import TransformParameterizations, FloatTypes + import numpy as np + + from itkwasm_transform_io_emscripten import read_transform_async, write_transform_async + + def write_input_data_to_fs(input_data, filename): + with open(filename, 'wb') as fp: + fp.write(input_data[filename]) + + def verify_test_linear_transform(transform_list): + assert len(transform_list) == 1 + transform = transform_list[0] + assert transform.transformType.transformParameterization == TransformParameterizations.Affine + assert transform.transformType.parametersValueType == FloatTypes.Float64 + assert transform.numberOfParameters == 12 + assert transform.numberOfFixedParameters == 3 + np.testing.assert_allclose(transform.fixedParameters, np.array([0.0, 0.0, 0.0])) + np.testing.assert_allclose(transform.parameters, np.array([ + 0.65631490118447, 0.5806583745824385, -0.4817536741017158, + -0.7407986817430222, 0.37486398378429736, -0.5573995934598175, + -0.14306664045479867, 0.7227121458012518, 0.676179776908723, + -65.99999999999997, 69.00000000000004, 32.000000000000036])) + + test_file_path = 'LinearTransform.h5' + write_input_data_to_fs(input_data, test_file_path) + + assert Path(test_file_path).exists() + + transform = await read_transform_async(test_file_path) + verify_test_linear_transform(transform) + + test_output_file_path = 'out-LinearTransform.h5' + + use_compression = False + await write_transform_async(transform, test_output_file_path, use_compression) + + transform = await read_transform_async(test_output_file_path) + verify_test_linear_transform(transform) diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_txt_read_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_txt_read_transform_async.py new file mode 100644 index 000000000..d2adba9d9 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_txt_read_transform_async.py @@ -0,0 +1,18 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_txt_read_transform_async(selenium, package_wheel): + import micropip + await micropip.install(package_wheel) + + from itkwasm_transform_io_emscripten import txt_read_transform_async + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_txt_write_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_txt_write_transform_async.py new file mode 100644 index 000000000..3da486d23 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_txt_write_transform_async.py @@ -0,0 +1,18 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_txt_write_transform_async(selenium, package_wheel): + import micropip + await micropip.install(package_wheel) + + from itkwasm_transform_io_emscripten import txt_write_transform_async + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_wasm_read_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_wasm_read_transform_async.py new file mode 100644 index 000000000..2ce4fb8d7 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_wasm_read_transform_async.py @@ -0,0 +1,18 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_wasm_read_transform_async(selenium, package_wheel): + import micropip + await micropip.install(package_wheel) + + from itkwasm_transform_io_emscripten import wasm_read_transform_async + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_wasm_write_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_wasm_write_transform_async.py new file mode 100644 index 000000000..46006152d --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_wasm_write_transform_async.py @@ -0,0 +1,18 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_wasm_write_transform_async(selenium, package_wheel): + import micropip + await micropip.install(package_wheel) + + from itkwasm_transform_io_emscripten import wasm_write_transform_async + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_wasm_zstd_read_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_wasm_zstd_read_transform_async.py new file mode 100644 index 000000000..be9b399b7 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_wasm_zstd_read_transform_async.py @@ -0,0 +1,18 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_wasm_zstd_read_transform_async(selenium, package_wheel): + import micropip + await micropip.install(package_wheel) + + from itkwasm_transform_io_emscripten import wasm_zstd_read_transform_async + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_wasm_zstd_write_transform_async.py b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_wasm_zstd_write_transform_async.py new file mode 100644 index 000000000..3314dcf08 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-emscripten/tests/test_wasm_zstd_write_transform_async.py @@ -0,0 +1,18 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_wasm_zstd_write_transform_async(selenium, package_wheel): + import micropip + await micropip.install(package_wheel) + + from itkwasm_transform_io_emscripten import wasm_zstd_write_transform_async + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/__init__.py b/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/__init__.py index 443124ad4..070a258ed 100644 --- a/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/__init__.py +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/__init__.py @@ -1,7 +1,8 @@ -# Generated file. To retain edits, remove this comment. - """itkwasm-transform-io-wasi: Input and output for scientific and medical coordinate transform file formats. WASI implementation.""" +from .read_transform import read_transform, transformread +from .write_transform import write_transform, transformwrite + from .hdf5_read_transform import hdf5_read_transform from .hdf5_write_transform import hdf5_write_transform from .mat_read_transform import mat_read_transform diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/_version.py b/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/_version.py index 3dc1f76bc..485f44ac2 100644 --- a/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/_version.py +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/_version.py @@ -1 +1 @@ -__version__ = "0.1.0" +__version__ = "0.1.1" diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/extension_to_transform_io.py b/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/extension_to_transform_io.py new file mode 100644 index 000000000..f90774811 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/extension_to_transform_io.py @@ -0,0 +1,12 @@ +from collections import OrderedDict + +extension_to_transform_io = OrderedDict([ + ("h5", "hdf5"), + ("hdf5", "hdf5"), + ("txt", "txt"), + ("mat", "mat"), + ("xfm", "mnc"), + ("iwt", "wasm"), + ("iwt.cbor", "wasm"), + ("iwt.cbor.zst", "wasm-zstd"), +]) diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/read_transform.py b/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/read_transform.py new file mode 100644 index 000000000..c921515b7 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/read_transform.py @@ -0,0 +1,61 @@ +import os +import importlib +from pathlib import Path + +from itkwasm import TransformList + +from .extension_to_transform_io import extension_to_transform_io +from .transform_io_index import transform_io_index + +def read_transform( + serialized_transform: os.PathLike, + float_parameters: bool = False, +) -> TransformList: + """Read a transform file format and convert it to the ITK-Wasm file format. + + :param serialized_transform: Input transform serialized in the file format + :type serialized_transform: os.PathLike + + :param float_parameters: Use float for the parameter value type. The default is double. + :type float_parameters: bool + + :return: Output transform + :rtype: TransformList + """ + extension = ''.join(Path(serialized_transform).suffixes) + + io = None + if extension in extension_to_transform_io: + func = f"{extension_to_transform_io[extension]}_read_transform" + mod_name = f"itkwasm_transform_io_wasi.{func}" + mod = importlib.import_module(mod_name) + io = getattr(mod, func) + else: + for ioname in transform_io_index: + func = f"{ioname}_read_transform" + mod_name = f"itkwasm_transform_io_wasi.{func}" + mod = importlib.import_module(mod_name) + io = getattr(mod, func) + could_read, transform = io(serialized_transform, float_parameters=float_parameters) + if could_read: + return transform + + if io is None: + raise RuntimeError(f"Could not find an transform reader for {extension}") + + could_read, transform = io(serialized_transform, float_parameters=float_parameters) + if not could_read: + raise RuntimeError(f"Could not read {serialized_transform}") + + return transform + + +def transformread( + serialized_transform: os.PathLike, + float_parameters: bool = False, +) -> TransformList: + return read_transform(serialized_transform, float_parameters=float_parameters) + +transformread.__doc__ = f"""{read_transform.__doc__} + Alias for read_transform. + """ \ No newline at end of file diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/transform_io_index.py b/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/transform_io_index.py new file mode 100644 index 000000000..1f186a8dc --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/transform_io_index.py @@ -0,0 +1,9 @@ +transform_io_index = [ + 'hdf5', + 'mat', + 'mnc', + 'txt', + 'wasm', + 'wasm_ztd', +] + diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/write_transform.py b/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/write_transform.py new file mode 100644 index 000000000..23782dedc --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/itkwasm_transform_io_wasi/write_transform.py @@ -0,0 +1,68 @@ +import os +import importlib +from pathlib import Path + +from itkwasm import TransformList + +from .extension_to_transform_io import extension_to_transform_io +from .transform_io_index import transform_io_index + +def write_transform( + transform: TransformList, + serialized_transform: os.PathLike, + float_parameters: bool = False, + use_compression: bool = False, +) -> None: + """Write an itk-wasm TransformList to an transform file format. + + :param transform: Input transform + :type transform: TransformList + + :param serialized_transform: Output transform serialized in the file format. + :type serialized_transform: str + + :param float_parameters: Use float for the parameter value type. The default is double. + :type float_parameters: bool + + :param use_compression: Use compression in the written file + :type use_compression: bool + + :param serialized_transform: Input transform serialized in the file format + :type serialized_transform: os.PathLike + """ + extension = ''.join(Path(serialized_transform).suffixes) + + io = None + if extension in extension_to_transform_io: + func = f"{extension_to_transform_io[extension]}_write_transform" + mod_name = f"itkwasm_transform_io_wasi.{func}" + mod = importlib.import_module(mod_name) + io = getattr(mod, func) + else: + for ioname in transform_io_index: + func = f"{ioname}_write_transform" + mod_name = f"itkwasm_transform_io_wasi.{func}" + mod = importlib.import_module(mod_name) + io = getattr(mod, func) + could_write = io(transform, serialized_transform, float_parameters=float_parameters, use_compression=use_compression) + if could_write: + return + + if io is None: + raise RuntimeError(f"Could not find an transform writer for {extension}") + + could_write = io(transform, serialized_transform, float_parameters=float_parameters, use_compression=use_compression) + if not could_write: + raise RuntimeError(f"Could not write {serialized_transform}") + +def transformwrite( + transform: TransformList, + serialized_transform: os.PathLike, + float_parameters: bool = False, + use_compression: bool = False, +) -> None: + return write_transform(transform, serialized_transform, float_parameters=float_parameters, use_compression=use_compression) + +transformwrite.__doc__ = f"""{write_transform.__doc__} + Alias for write_transform. + """ \ No newline at end of file diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/pyproject.toml b/packages/transform-io/python/itkwasm-transform-io-wasi/pyproject.toml index 956bef031..638af7acb 100644 --- a/packages/transform-io/python/itkwasm-transform-io-wasi/pyproject.toml +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/pyproject.toml @@ -5,7 +5,7 @@ build-backend = "hatchling.build" [project] name = "itkwasm-transform-io-wasi" readme = "README.md" -license = "Apache-2.0" +license-expression = "Apache-2.0" dynamic = ["version"] description = "Input and output for scientific and medical coordinate transform file formats." classifiers = [ @@ -19,11 +19,11 @@ classifiers = [ "Intended Audience :: Developers", "Intended Audience :: Science/Research", "Programming Language :: Python :: 3", - "Programming Language :: Python :: 3.8", "Programming Language :: Python :: 3.9", "Programming Language :: Python :: 3.10", "Programming Language :: Python :: 3.11", "Programming Language :: Python :: 3.12", + "Programming Language :: Python :: 3.13", ] keywords = [ "itkwasm", @@ -31,9 +31,9 @@ keywords = [ "wasi", ] -requires-python = ">=3.8" +requires-python = ">=3.9" dependencies = [ - "itkwasm >= 1.0.b171", + "itkwasm >= 1.0.b185", "importlib_resources", ] diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/common.py b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/common.py index 3a182e694..11ebafc53 100644 --- a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/common.py +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/common.py @@ -1,6 +1,23 @@ from pathlib import Path +import numpy as np + +from itkwasm import TransformList, TransformParameterizations, FloatTypes test_input_path = Path(__file__).parent / ".." / ".." / ".." / "test" / "data" / "input" test_baseline_path = Path(__file__).parent / ".." / ".." / ".." / "test" / "data" / "baseline" -test_output_path = Path(__file__).parent / ".." / ".." / ".." / "test" / "data" / "output" / "python" -test_output_path.mkdir(parents=True, exist_ok=True) \ No newline at end of file +test_output_path = Path(__file__).parent / ".." / ".." / ".." / "test" / "data" / "output" / "python-wasi" +test_output_path.mkdir(parents=True, exist_ok=True) + +def verify_test_linear_transform(transform_list: TransformList): + assert len(transform_list) == 1 + transform = transform_list[0] + assert transform.transformType.transformParameterization == TransformParameterizations.Affine + assert transform.transformType.parametersValueType == FloatTypes.Float64 + assert transform.numberOfParameters == 12 + assert transform.numberOfFixedParameters == 3 + np.testing.assert_allclose(transform.fixedParameters, np.array([0.0, 0.0, 0.0])) + np.testing.assert_allclose(transform.parameters, np.array([ + 0.65631490118447, 0.5806583745824385, -0.4817536741017158, + -0.7407986817430222, 0.37486398378429736, -0.5573995934598175, + -0.14306664045479867, 0.7227121458012518, 0.676179776908723, + -65.99999999999997, 69.00000000000004, 32.000000000000036])) diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_hdf5_read_transform.py b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_hdf5_read_transform.py index be2fc2f9f..b7b01c621 100644 --- a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_hdf5_read_transform.py +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_hdf5_read_transform.py @@ -1,8 +1,12 @@ -# Generated file. To retain edits, remove this comment. +from pathlib import Path from itkwasm_transform_io_wasi import hdf5_read_transform -from .common import test_input_path, test_output_path +from .common import test_input_path, test_output_path, verify_test_linear_transform + +test_input_file_path = test_input_path / "LinearTransform.h5" def test_hdf5_read_transform(): - pass + could_read, transform_list = hdf5_read_transform(test_input_file_path) + assert could_read + verify_test_linear_transform(transform_list) diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_hdf5_write_transform.py b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_hdf5_write_transform.py index 9768c6f47..34fcb2e76 100644 --- a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_hdf5_write_transform.py +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_hdf5_write_transform.py @@ -1,8 +1,14 @@ -# Generated file. To retain edits, remove this comment. +from itkwasm_transform_io_wasi import hdf5_read_transform, hdf5_write_transform -from itkwasm_transform_io_wasi import hdf5_write_transform +from .common import test_input_path, test_output_path, verify_test_linear_transform -from .common import test_input_path, test_output_path +test_input_file_path = test_input_path / "LinearTransform.h5" +test_output_file_path = test_output_path / "hdf5-test-write-LinearTransform.h5" def test_hdf5_write_transform(): - pass + could_read, transform_list = hdf5_read_transform(test_input_file_path) + assert could_read + could_write = hdf5_write_transform(transform_list, test_output_file_path) + assert could_write + could_read, transform_list = hdf5_read_transform(test_output_file_path) + verify_test_linear_transform(transform_list) diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_mat_read_transform.py b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_mat_read_transform.py index bdd4db8fa..887441605 100644 --- a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_mat_read_transform.py +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_mat_read_transform.py @@ -1,8 +1,10 @@ -# Generated file. To retain edits, remove this comment. - from itkwasm_transform_io_wasi import mat_read_transform -from .common import test_input_path, test_output_path +from .common import test_input_path, verify_test_linear_transform + +test_input_file_path = test_input_path / "LinearTransform.mat" def test_mat_read_transform(): - pass + could_read, transform_list = mat_read_transform(test_input_file_path) + assert could_read + verify_test_linear_transform(transform_list) diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_mat_write_transform.py b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_mat_write_transform.py index bf9368a22..5f4116efc 100644 --- a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_mat_write_transform.py +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_mat_write_transform.py @@ -1,8 +1,14 @@ -# Generated file. To retain edits, remove this comment. +from itkwasm_transform_io_wasi import mat_read_transform, mat_write_transform -from itkwasm_transform_io_wasi import mat_write_transform +from .common import test_input_path, test_output_path, verify_test_linear_transform -from .common import test_input_path, test_output_path +test_input_file_path = test_input_path / "LinearTransform.mat" +test_output_file_path = test_output_path / "mat-test-write-LinearTransform.mat" def test_mat_write_transform(): - pass + could_read, transform_list = mat_read_transform(test_input_file_path) + assert could_read + could_write = mat_write_transform(transform_list, test_output_file_path) + assert could_write + could_read, transform_list = mat_read_transform(test_output_file_path) + verify_test_linear_transform(transform_list) \ No newline at end of file diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_read_write_transform.py b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_read_write_transform.py new file mode 100644 index 000000000..ef8ec0a93 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_read_write_transform.py @@ -0,0 +1,36 @@ +from itkwasm import IntTypes, FloatTypes +import numpy as np + +from itkwasm_transform_io_wasi import read_transform, transformread, write_transform, transformwrite + +from .common import test_input_path, test_output_path, verify_test_linear_transform +verify_transform = verify_test_linear_transform + +test_input_file_path = test_input_path / "LinearTransform.h5" +test_output_file_path = test_output_path / "read-write-LinearTransform.h5" + +def test_read_transform(): + transform = read_transform(test_input_file_path) + verify_transform(transform) + +def test_transformread(): + transform = transformread(test_input_file_path) + verify_transform(transform) + +def test_write_transform(): + transform = read_transform(test_input_file_path) + + use_compression = False + write_transform(transform, test_output_file_path, use_compression=use_compression) + + transform = read_transform(test_output_file_path) + verify_transform(transform) + +def test_transformwrite(): + transform = transformread(test_input_file_path) + + use_compression = False + transformwrite(transform, test_output_file_path, use_compression=use_compression) + + transform = transformread(test_output_file_path) + verify_transform(transform) diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_txt_read_transform.py b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_txt_read_transform.py index 29bd598ea..b3c78baf9 100644 --- a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_txt_read_transform.py +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_txt_read_transform.py @@ -1,8 +1,10 @@ -# Generated file. To retain edits, remove this comment. - from itkwasm_transform_io_wasi import txt_read_transform -from .common import test_input_path, test_output_path +from .common import test_input_path, verify_test_linear_transform + +test_input_file_path = test_input_path / "LinearTransform.txt" def test_txt_read_transform(): - pass + could_read, transform_list = txt_read_transform(test_input_file_path) + assert could_read + verify_test_linear_transform(transform_list) \ No newline at end of file diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_txt_write_transform.py b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_txt_write_transform.py index c4428dca8..3f75b63db 100644 --- a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_txt_write_transform.py +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_txt_write_transform.py @@ -1,8 +1,14 @@ -# Generated file. To retain edits, remove this comment. +from itkwasm_transform_io_wasi import txt_read_transform, txt_write_transform -from itkwasm_transform_io_wasi import txt_write_transform +from .common import test_input_path, test_output_path, verify_test_linear_transform -from .common import test_input_path, test_output_path +test_input_file_path = test_input_path / "LinearTransform.txt" +test_output_file_path = test_output_path / "txt-test-write-LinearTransform.txt" def test_txt_write_transform(): - pass + could_read, transform_list = txt_read_transform(test_input_file_path) + assert could_read + could_write = txt_write_transform(transform_list, test_output_file_path) + assert could_write + could_read, transform_list = txt_read_transform(test_output_file_path) + verify_test_linear_transform(transform_list) \ No newline at end of file diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_wasm_read_transform.py b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_wasm_read_transform.py index 3d185a5c9..028475f9a 100644 --- a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_wasm_read_transform.py +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_wasm_read_transform.py @@ -1,8 +1,10 @@ -# Generated file. To retain edits, remove this comment. - from itkwasm_transform_io_wasi import wasm_read_transform -from .common import test_input_path, test_output_path +from .common import test_input_path, verify_test_linear_transform + +test_input_file_path = test_input_path / "LinearTransform.iwt.cbor" def test_wasm_read_transform(): - pass + could_read, transform_list = wasm_read_transform(test_input_file_path) + assert could_read + verify_test_linear_transform(transform_list) \ No newline at end of file diff --git a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_wasm_write_transform.py b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_wasm_write_transform.py index ae66c2406..90e69f070 100644 --- a/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_wasm_write_transform.py +++ b/packages/transform-io/python/itkwasm-transform-io-wasi/tests/test_wasm_write_transform.py @@ -1,8 +1,14 @@ -# Generated file. To retain edits, remove this comment. +from itkwasm_transform_io_wasi import wasm_read_transform, wasm_write_transform -from itkwasm_transform_io_wasi import wasm_write_transform +from .common import test_input_path, test_output_path, verify_test_linear_transform -from .common import test_input_path, test_output_path +test_input_file_path = test_input_path / "LinearTransform.iwt.cbor" +test_output_file_path = test_output_path / "wasm-test-write-LinearTransform.iwt.cbor" def test_wasm_write_transform(): - pass + could_read, transform_list = wasm_read_transform(test_input_file_path) + assert could_read + could_write = wasm_write_transform(transform_list, test_output_file_path) + assert could_write + could_read, transform_list = wasm_read_transform(test_output_file_path) + verify_test_linear_transform(transform_list) \ No newline at end of file diff --git a/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/__init__.py b/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/__init__.py index 2d82258a2..d733ccf6b 100644 --- a/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/__init__.py +++ b/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/__init__.py @@ -1,7 +1,10 @@ -# Generated file. To retain edits, remove this comment. - """itkwasm-transform-io: Input and output for scientific and medical coordinate transform file formats.""" +from .read_transform_async import read_transform_async, transformread_async +from .read_transform import read_transform, transformread +from .write_transform_async import write_transform_async, transformwrite_async +from .write_transform import write_transform, transformwrite + from .hdf5_read_transform_async import hdf5_read_transform_async from .hdf5_read_transform import hdf5_read_transform from .hdf5_write_transform_async import hdf5_write_transform_async diff --git a/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/_version.py b/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/_version.py index 3dc1f76bc..485f44ac2 100644 --- a/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/_version.py +++ b/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/_version.py @@ -1 +1 @@ -__version__ = "0.1.0" +__version__ = "0.1.1" diff --git a/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/read_transform.py b/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/read_transform.py new file mode 100644 index 000000000..68f6731fc --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/read_transform.py @@ -0,0 +1,36 @@ +import os +from typing import Optional, Union + +from itkwasm import ( + environment_dispatch, + TransformList, +) + +def read_transform( + serialized_transform: os.PathLike, + float_parameters: bool = False, +) -> TransformList: + """Read a transform file format and convert it to the ITK-Wasm file format + + :param serialized_transform: Input transform serialized in the file format + :type serialized_transform: os.PathLike + + :param float_parameters: Use float for the parameter value type. The default is double. + :type float_parameters: bool + + :return: Output transform + :rtype: TransformList + """ + func = environment_dispatch("itkwasm_transform_io", "read_transform") + output = func(serialized_transform, float_parameters=float_parameters) + return output + +def transformread( + serialized_transform: os.PathLike, + float_parameters: bool = False, +) -> TransformList: + return read_transform(serialized_transform, float_parameters=float_parameters) + +transformread.__doc__ = f"""{read_transform.__doc__} + Alias for read_transform. + """ \ No newline at end of file diff --git a/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/read_transform_async.py b/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/read_transform_async.py new file mode 100644 index 000000000..2cffceb92 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/read_transform_async.py @@ -0,0 +1,36 @@ +import os +from typing import Optional, Union + +from itkwasm import ( + environment_dispatch, + TransformList, +) + +async def read_transform_async( + serialized_transform: os.PathLike, + float_parameters: bool = False, +) -> TransformList: + """Read an transform file format and convert it to the ITK-Wasm file format. + + :param serialized_transform: Input transform serialized in the file format + :type serialized_transform: os.PathLike + + :param float_parameters: Use float for the parameter value type. The default is double. + :type float_parameters: bool + + :return: Output transform + :rtype: TransformList + """ + func = environment_dispatch("itkwasm_transform_io", "read_transform_async") + output = await func(serialized_transform, float_parameters=float_parameters) + return output + +async def transformread_async( + serialized_transform: os.PathLike, + float_parameters: bool = False, +) -> TransformList: + return await read_transform_async(serialized_transform, float_parameters=float_parameters) + +transformread_async.__doc__ = f"""{read_transform_async.__doc__} + Alias for read_transform. + """ \ No newline at end of file diff --git a/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/write_transform.py b/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/write_transform.py new file mode 100644 index 000000000..20ce71cd0 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/write_transform.py @@ -0,0 +1,43 @@ +import os +from typing import Dict, Tuple, Optional, List, Any + +from itkwasm import ( + environment_dispatch, + TransformList, +) + +def write_transform( + transform: TransformList, + serialized_transform: str, + float_parameters: bool = False, + use_compression: bool = False, +) -> None: + """Write an ITK-Wasm file format converted to a transform file format + + :param transform: Input transform + :type transform: TransformList + + :param serialized_transform: Output transform serialized in the file format. + :type serialized_transform: str + + :param float_parameters: Use float for the parameter value type. The default is double. + :type float_parameters: bool + + :param use_compression: Use compression in the written file + :type use_compression: bool + """ + func = environment_dispatch("itkwasm_transform_io", "write_transform") + func(transform, serialized_transform, float_parameters=float_parameters, use_compression=use_compression) + return + +def transformwrite( + transform: TransformList, + serialized_transform: os.PathLike, + float_parameters: bool = False, + use_compression: bool = False, +) -> None: + return write_transform(transform, serialized_transform, float_parameters=float_parameters, use_compression=use_compression) + +transformwrite.__doc__ = f"""{write_transform.__doc__} + Alias for write_transform. + """ \ No newline at end of file diff --git a/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/write_transform_async.py b/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/write_transform_async.py new file mode 100644 index 000000000..0a2e96ad2 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/itkwasm_transform_io/write_transform_async.py @@ -0,0 +1,43 @@ +import os +from typing import Dict, Tuple, Optional, List, Any + +from itkwasm import ( + environment_dispatch, + TransformList, +) + +async def write_transform_async( + transform: TransformList, + serialized_transform: str, + float_parameters: bool = False, + use_compression: bool = False, +) -> None: + """Write an ITK-Wasm file format converted to a transform file format. + + :param transform: Input transform + :type transform: TransformList + + :param serialized_transform: Output transform serialized in the file format. + :type serialized_transform: str + + :param float_parameters: Only write transform metadata -- do not write pixel data. + :type float_parameters: bool + + :param use_compression: Use compression in the written file + :type use_compression: bool + """ + func = environment_dispatch("itkwasm_transform_io", "write_transform_async") + await func(transform, serialized_transform, float_parameters=float_parameters, use_compression=use_compression) + return + +async def transformwrite_async( + transform: TransformList, + serialized_transform: os.PathLike, + float_parameters: bool = False, + use_compression: bool = False, +) -> None: + return await write_transform_async(transform, serialized_transform, float_parameters=float_parameters, use_compression=use_compression) + +transformwrite_async.__doc__ = f"""{write_transform_async.__doc__} + Alias for write_transform. + """ \ No newline at end of file diff --git a/packages/transform-io/python/itkwasm-transform-io/pyproject.toml b/packages/transform-io/python/itkwasm-transform-io/pyproject.toml index e8e4d26ab..f84172e65 100644 --- a/packages/transform-io/python/itkwasm-transform-io/pyproject.toml +++ b/packages/transform-io/python/itkwasm-transform-io/pyproject.toml @@ -5,7 +5,7 @@ build-backend = "hatchling.build" [project] name = "itkwasm-transform-io" readme = "README.md" -license = "Apache-2.0" +license-expression = "Apache-2.0" dynamic = ["version"] description = "Input and output for scientific and medical coordinate transform file formats." classifiers = [ @@ -19,11 +19,11 @@ classifiers = [ "Intended Audience :: Developers", "Intended Audience :: Science/Research", "Programming Language :: Python :: 3", - "Programming Language :: Python :: 3.8", "Programming Language :: Python :: 3.9", "Programming Language :: Python :: 3.10", "Programming Language :: Python :: 3.11", "Programming Language :: Python :: 3.12", + "Programming Language :: Python :: 3.13", ] keywords = [ "itkwasm", @@ -32,9 +32,9 @@ keywords = [ "emscripten", ] -requires-python = ">=3.8" +requires-python = ">=3.9" dependencies = [ - "itkwasm >= 1.0.b171", + "itkwasm >= 1.0.b185", "itkwasm-transform-io-wasi; sys_platform != \"emscripten\"", "itkwasm-transform-io-emscripten; sys_platform == \"emscripten\"", diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/__init__.py b/packages/transform-io/python/itkwasm-transform-io/tests/__init__.py new file mode 100644 index 000000000..e69de29bb diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/common.py b/packages/transform-io/python/itkwasm-transform-io/tests/common.py new file mode 100644 index 000000000..95b199562 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/common.py @@ -0,0 +1,23 @@ +from pathlib import Path +import numpy as np + +from itkwasm import TransformList, TransformParameterizations, FloatTypes + +test_input_path = Path(__file__).parent / ".." / ".." / ".." / "test" / "data" / "input" +test_baseline_path = Path(__file__).parent / ".." / ".." / ".." / "test" / "data" / "baseline" +test_output_path = Path(__file__).parent / ".." / ".." / ".." / "test" / "data" / "output" / "python-dispatch" +test_output_path.mkdir(parents=True, exist_ok=True) + +def verify_test_linear_transform(transform_list: TransformList): + assert len(transform_list) == 1 + transform = transform_list[0] + assert transform.transformType.transformParameterization == TransformParameterizations.Affine + assert transform.transformType.parametersValueType == FloatTypes.Float64 + assert transform.numberOfParameters == 12 + assert transform.numberOfFixedParameters == 3 + np.testing.assert_allclose(transform.fixedParameters, np.array([0.0, 0.0, 0.0])) + np.testing.assert_allclose(transform.parameters, np.array([ + 0.65631490118447, 0.5806583745824385, -0.4817536741017158, + -0.7407986817430222, 0.37486398378429736, -0.5573995934598175, + -0.14306664045479867, 0.7227121458012518, 0.676179776908723, + -65.99999999999997, 69.00000000000004, 32.000000000000036])) diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/fixtures.py b/packages/transform-io/python/itkwasm-transform-io/tests/fixtures.py new file mode 100644 index 000000000..cda5dbaf3 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/fixtures.py @@ -0,0 +1,29 @@ +import pytest +import sys +import glob + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from itkwasm_transform_io import __version__ as test_package_version + +@pytest.fixture +def package_wheel(): + return f"itkwasm_transform_io-{test_package_version}-py3-none-any.whl" + +@pytest.fixture +def emscripten_package_wheel(): + return f"itkwasm_transform_io_emscripten-{test_package_version}-py3-none-any.whl" + +@pytest.fixture +def input_data(): + from pathlib import Path + input_base_path = Path(__file__).parent.parent.parent.parent / 'test' / 'data' / 'input' + test_files = list(input_base_path.glob('*')) + data = {} + for test_file in test_files: + with open(test_file, 'rb') as f: + data[test_file.name] = f.read() + return data diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_hdf5_read_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_hdf5_read_transform.py new file mode 100644 index 000000000..c4ec0fc4b --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_hdf5_read_transform.py @@ -0,0 +1,12 @@ +from pathlib import Path + +from itkwasm_transform_io import hdf5_read_transform + +from .common import test_input_path, test_output_path, verify_test_linear_transform + +test_input_file_path = test_input_path / "LinearTransform.h5" + +def test_hdf5_read_transform(): + could_read, transform_list = hdf5_read_transform(test_input_file_path) + assert could_read + verify_test_linear_transform(transform_list) diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_hdf5_read_transform_async.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_hdf5_read_transform_async.py new file mode 100644 index 000000000..9d6e0c66d --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_hdf5_read_transform_async.py @@ -0,0 +1,59 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import package_wheel, input_data, emscripten_package_wheel + +@run_in_pyodide(packages=['micropip']) +async def test_hdf5_read_transform_async(selenium, package_wheel, emscripten_package_wheel, input_data): + import micropip + await micropip.install(emscripten_package_wheel) + await micropip.install(package_wheel) + + from pathlib import Path + + import numpy as np + from itkwasm import TransformParameterizations, FloatTypes + + from itkwasm_transform_io import hdf5_read_transform_async, hdf5_write_transform_async + + def write_input_data_to_fs(input_data, filename): + with open(filename, 'wb') as fp: + fp.write(input_data[filename]) + + def verify_test_linear_transform(transform_list): + assert len(transform_list) == 1 + transform = transform_list[0] + assert transform.transformType.transformParameterization == TransformParameterizations.Affine + assert transform.transformType.parametersValueType == FloatTypes.Float64 + assert transform.numberOfParameters == 12 + assert transform.numberOfFixedParameters == 3 + np.testing.assert_allclose(transform.fixedParameters, np.array([0.0, 0.0, 0.0])) + np.testing.assert_allclose(transform.parameters, np.array([ + 0.65631490118447, 0.5806583745824385, -0.4817536741017158, + -0.7407986817430222, 0.37486398378429736, -0.5573995934598175, + -0.14306664045479867, 0.7227121458012518, 0.676179776908723, + -65.99999999999997, 69.00000000000004, 32.000000000000036])) + + test_file_path = 'LinearTransform.h5' + write_input_data_to_fs(input_data, test_file_path) + + assert Path(test_file_path).exists() + + could_read, transform = await hdf5_read_transform_async(test_file_path) + assert could_read + verify_test_linear_transform(transform) + + test_output_file_path = 'out-LinearTransform.h5' + + use_compression = False + could_write = await hdf5_write_transform_async(transform, test_output_file_path, use_compression) + assert could_write + + could_read, transform = await hdf5_read_transform_async(test_output_file_path) + assert could_read + verify_test_linear_transform(transform) diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_hdf5_write_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_hdf5_write_transform.py new file mode 100644 index 000000000..a86b38c8e --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_hdf5_write_transform.py @@ -0,0 +1,14 @@ +from itkwasm_transform_io import hdf5_read_transform, hdf5_write_transform + +from .common import test_input_path, test_output_path, verify_test_linear_transform + +test_input_file_path = test_input_path / "LinearTransform.h5" +test_output_file_path = test_output_path / "hdf5-test-write-LinearTransform.h5" + +def test_hdf5_write_transform(): + could_read, transform_list = hdf5_read_transform(test_input_file_path) + assert could_read + could_write = hdf5_write_transform(transform_list, test_output_file_path) + assert could_write + could_read, transform_list = hdf5_read_transform(test_output_file_path) + verify_test_linear_transform(transform_list) diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_mat_read_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_mat_read_transform.py new file mode 100644 index 000000000..9994ba7fb --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_mat_read_transform.py @@ -0,0 +1,19 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import emscripten_package_wheel, package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_mat_read_transform(selenium, package_wheel, emscripten_package_wheel): + import micropip + await micropip.install(emscripten_package_wheel) + await micropip.install(package_wheel) + + from itkwasm_transform_io import mat_read_transform + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_mat_write_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_mat_write_transform.py new file mode 100644 index 000000000..a35eee18d --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_mat_write_transform.py @@ -0,0 +1,19 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import emscripten_package_wheel, package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_mat_write_transform(selenium, package_wheel, emscripten_package_wheel): + import micropip + await micropip.install(emscripten_package_wheel) + await micropip.install(package_wheel) + + from itkwasm_transform_io import mat_write_transform + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_mnc_read_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_mnc_read_transform.py new file mode 100644 index 000000000..3f140fdbd --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_mnc_read_transform.py @@ -0,0 +1,19 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import emscripten_package_wheel, package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_mnc_read_transform(selenium, package_wheel, emscripten_package_wheel): + import micropip + await micropip.install(emscripten_package_wheel) + await micropip.install(package_wheel) + + from itkwasm_transform_io import mnc_read_transform + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_mnc_write_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_mnc_write_transform.py new file mode 100644 index 000000000..e48b67705 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_mnc_write_transform.py @@ -0,0 +1,19 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import emscripten_package_wheel, package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_mnc_write_transform(selenium, package_wheel, emscripten_package_wheel): + import micropip + await micropip.install(emscripten_package_wheel) + await micropip.install(package_wheel) + + from itkwasm_transform_io import mnc_write_transform + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_read_write_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_read_write_transform.py new file mode 100644 index 000000000..bfd006a7e --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_read_write_transform.py @@ -0,0 +1,36 @@ +from itkwasm import IntTypes, FloatTypes +import numpy as np + +from itkwasm_transform_io import read_transform, transformread, write_transform, transformwrite + +from .common import test_input_path, test_output_path, verify_test_linear_transform +verify_transform = verify_test_linear_transform + +test_input_file_path = test_input_path / "LinearTransform.h5" +test_output_file_path = test_output_path / "read-write-LinearTransform.h5" + +def test_read_transform(): + transform = read_transform(test_input_file_path) + verify_transform(transform) + +def test_transformread(): + transform = transformread(test_input_file_path) + verify_transform(transform) + +def test_write_transform(): + transform = read_transform(test_input_file_path) + + use_compression = False + write_transform(transform, test_output_file_path, use_compression=use_compression) + + transform = read_transform(test_output_file_path) + verify_transform(transform) + +def test_transformwrite(): + transform = transformread(test_input_file_path) + + use_compression = False + transformwrite(transform, test_output_file_path, use_compression=use_compression) + + transform = transformread(test_output_file_path) + verify_transform(transform) diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_read_write_transform_async.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_read_write_transform_async.py new file mode 100644 index 000000000..4cd1443ce --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_read_write_transform_async.py @@ -0,0 +1,59 @@ +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +import pytest +from pytest_pyodide import run_in_pyodide +from .fixtures import package_wheel, input_data, emscripten_package_wheel + +@pytest.mark.driver_timeout(30) +@run_in_pyodide(packages=['micropip', 'numpy']) +async def test_read_write_mesh_async(selenium, package_wheel, emscripten_package_wheel, input_data): + import micropip + await micropip.install(emscripten_package_wheel) + await micropip.install(package_wheel) + def write_input_data_to_fs(input_data, filename): + with open(filename, 'wb') as fp: + fp.write(input_data[filename]) + + from pathlib import Path + + from itkwasm import TransformParameterizations, FloatTypes + import numpy as np + + from itkwasm_transform_io import read_transform_async, write_transform_async + + def write_input_data_to_fs(input_data, filename): + with open(filename, 'wb') as fp: + fp.write(input_data[filename]) + + def verify_test_linear_transform(transform_list): + assert len(transform_list) == 1 + transform = transform_list[0] + assert transform.transformType.transformParameterization == TransformParameterizations.Affine + assert transform.transformType.parametersValueType == FloatTypes.Float64 + assert transform.numberOfParameters == 12 + assert transform.numberOfFixedParameters == 3 + np.testing.assert_allclose(transform.fixedParameters, np.array([0.0, 0.0, 0.0])) + np.testing.assert_allclose(transform.parameters, np.array([ + 0.65631490118447, 0.5806583745824385, -0.4817536741017158, + -0.7407986817430222, 0.37486398378429736, -0.5573995934598175, + -0.14306664045479867, 0.7227121458012518, 0.676179776908723, + -65.99999999999997, 69.00000000000004, 32.000000000000036])) + + test_file_path = 'LinearTransform.h5' + write_input_data_to_fs(input_data, test_file_path) + + assert Path(test_file_path).exists() + + transform = await read_transform_async(test_file_path) + verify_test_linear_transform(transform) + + test_output_file_path = 'out-LinearTransform.h5' + + use_compression = False + await write_transform_async(transform, test_output_file_path, use_compression) + + transform = await read_transform_async(test_output_file_path) + verify_test_linear_transform(transform) diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_txt_read_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_txt_read_transform.py new file mode 100644 index 000000000..73cf1e646 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_txt_read_transform.py @@ -0,0 +1,19 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import emscripten_package_wheel, package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_txt_read_transform(selenium, package_wheel, emscripten_package_wheel): + import micropip + await micropip.install(emscripten_package_wheel) + await micropip.install(package_wheel) + + from itkwasm_transform_io import txt_read_transform + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_txt_write_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_txt_write_transform.py new file mode 100644 index 000000000..980dccfea --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_txt_write_transform.py @@ -0,0 +1,19 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import emscripten_package_wheel, package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_txt_write_transform(selenium, package_wheel, emscripten_package_wheel): + import micropip + await micropip.install(emscripten_package_wheel) + await micropip.install(package_wheel) + + from itkwasm_transform_io import txt_write_transform + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_wasm_read_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_wasm_read_transform.py new file mode 100644 index 000000000..f4d825e23 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_wasm_read_transform.py @@ -0,0 +1,19 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import emscripten_package_wheel, package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_wasm_read_transform(selenium, package_wheel, emscripten_package_wheel): + import micropip + await micropip.install(emscripten_package_wheel) + await micropip.install(package_wheel) + + from itkwasm_transform_io import wasm_read_transform + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_wasm_write_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_wasm_write_transform.py new file mode 100644 index 000000000..8e0458262 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_wasm_write_transform.py @@ -0,0 +1,19 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import emscripten_package_wheel, package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_wasm_write_transform(selenium, package_wheel, emscripten_package_wheel): + import micropip + await micropip.install(emscripten_package_wheel) + await micropip.install(package_wheel) + + from itkwasm_transform_io import wasm_write_transform + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_wasm_zstd_read_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_wasm_zstd_read_transform.py new file mode 100644 index 000000000..50466c5c7 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_wasm_zstd_read_transform.py @@ -0,0 +1,19 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import emscripten_package_wheel, package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_wasm_zstd_read_transform(selenium, package_wheel, emscripten_package_wheel): + import micropip + await micropip.install(emscripten_package_wheel) + await micropip.install(package_wheel) + + from itkwasm_transform_io import wasm_zstd_read_transform + + # Write your test code here diff --git a/packages/transform-io/python/itkwasm-transform-io/tests/test_wasm_zstd_write_transform.py b/packages/transform-io/python/itkwasm-transform-io/tests/test_wasm_zstd_write_transform.py new file mode 100644 index 000000000..2e5c5e133 --- /dev/null +++ b/packages/transform-io/python/itkwasm-transform-io/tests/test_wasm_zstd_write_transform.py @@ -0,0 +1,19 @@ +import pytest +import sys + +if sys.version_info < (3,10): + pytest.skip("Skipping pyodide tests on older Python", allow_module_level=True) + +from pytest_pyodide import run_in_pyodide + +from .fixtures import emscripten_package_wheel, package_wheel, input_data + +@run_in_pyodide(packages=['micropip']) +async def test_wasm_zstd_write_transform(selenium, package_wheel, emscripten_package_wheel): + import micropip + await micropip.install(emscripten_package_wheel) + await micropip.install(package_wheel) + + from itkwasm_transform_io import wasm_zstd_write_transform + + # Write your test code here