pod5Viewer


Namepod5Viewer JSON
Version 1.1.2 PyPI version JSON
download
home_pagehttps://github.com/dietvin/pod5Viewer
SummaryGUI for inspecting ONT pod5 files
upload_time2024-12-17 11:43:24
maintainerNone
docs_urlNone
authorVincent Dietrich
requires_python<3.13,>3.9
licenseLICENSE
keywords
VCS
bugtrack_url
requirements numpy pod5 pyside6 matplotlib
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ![header](./images/github_header.png)

The pod5Viewer is a Python application that provides a graphical user interface for viewing and navigating through POD5 files. It allows users to open multiple POD5 files, explore their contents, and display detailed data for selected read IDs.

[![License: GPL v3](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](http://www.gnu.org/licenses/gpl-3.0) [![Contributor Covenant](https://img.shields.io/badge/Contributor%20Covenant-2.1-4baaaa.svg)](CODE_OF_CONDUCT.md) [![pod5viewer](https://snapcraft.io/pod5viewer/badge.svg)](https://snapcraft.io/pod5viewer) ![GitHub Release](https://img.shields.io/github/v/release/dietvin/pod5Viewer) ![PyPI - Version](https://img.shields.io/pypi/v/pod5Viewer) ![GitHub Downloads (all assets, all releases)](https://img.shields.io/github/downloads/dietvin/pod5Viewer/total)

## Table of Contents

- [Table of Contents](#table-of-contents)
- [Installation and requirements](#installation-and-requirements)
  - [Windows](#windows)
  - [Linux](#linux)
  - [OS-independent](#os-independent)
  - [Dependencies](#dependencies)
- [Usage](#usage)
  - [Open and inspecting pod5 files](#open-and-inspecting-pod5-files)
  - [Filtering for specific reads](#filtering-for-specific-reads)
  - [Viewing signals](#viewing-signals)
  - [Plotting signals](#plotting-signals)
  - [Exporting reads](#exporting-reads)
  - [Shortcuts](#shortcuts)
- [License](#license)
- [How to cite](#how-to-cite)

## Installation and requirements

### Windows

For Windows systems the pod5Viewer can be installed conveniently via the installer. The installer can be downloaded here:

[pod5Viewer-1.1.1-Setup.exe](https://github.com/dietvin/pod5Viewer/releases/download/1.1.2/pod5Viewer-1.1.2-Setup.exe "Download pod5Viewer Windows installer") 

After downloading the installer and following the steps provided, the pod5Viewer can be accessed and opened from the start menu or the desktop shortcut. It also sets the pod5Viewer as the standard application to open POD5 files, so it is possible to open a file by simply clicking on it.

**Note**: When running the installer a the Windows defender might open the Window `Windows protected your PC`. To continue the installation, press `More Info` and `Run anyway`.

### Linux
On Linux systems the pod5Viewer can be installed via [snap](https://snapcraft.io/docs/installing-snapd). To install the package run the following command:
```bash
sudo snap install --edge pod5viewer 
```
Afterwards the pod5Viewer can be opened from the command line via `pod5viewer` or like any other installed GUI application.

The Snap installation should work on all x86 based systems. We tested the installation on:
- Ubuntu 24.04
- Ubuntu 22.04
- Linux Mint 21.3
- Linux Mint 20.3
- Debian 12

### OS-independent

The pod5Viewer can be installed via the Python packaging index using `pip`.

Note that when installing the pod5Viewer via pip, it can only be started from the command line. It is not possible to open POD5 files directly from a file browser.

Here we recommend installing the pod5Viewer into a fresh virtual environment via [Conda](https://docs.anaconda.com/miniconda/) or a similar environment manager:

```bash
conda create -n p5v python==3.10
conda activate p5v
```

With the virtual environment active, the pod5Viewer can be installed via pip:

```bash
pip install pod5Viewer
```

To start the pod5Viewer from a python environment type:

```bash
pod5Viewer
```

Optionally specify one or more path(s) to POD5 file(s) to open these directly:

```bash
pod5Viewer file1.pod5 file2.pod5
```

---

Alternatively, the pod5Viewer can be installed from source:

```bash
git clone https://github.com/dietvin/pod5Viewer.git
cd pod5Viewer
pip install .
```

### Dependencies

The pod5Viewer is built in Python (v3.10.0) and relies on the following packages:

- numpy (v1.26.4)
- pod5 (v0.3.10)
- pyside6 (v6.5.2)
- matplotlib (v3.9.2)

The compliation for Windows was performed using the pyinstaller (v6.8.0) and the Windows installer was created using the Inno Setup Compiler (v6.3.1).

## Usage

![overview](./images/pod5Viewer_overview.png)

### Open and inspecting pod5 files

In the pod5Viewer open files from the menu bar in the top via `File > Open file(s)...` (individual file(s)) or `File > Open directory` (all files in a directory). All opened files are shown in the left panel. Expanding an entry shows all reads in a given file by their read ID. Opened files and reads can be sorted alphabetically in ascending or descending order using the respective buttons above the panel. Specific read IDs can be searched using the search bar. Typing a search query updates the panel to show fitting reads in real-time. The button next to the search bar clears a given search query. 

A single click on a read ID opens the entry as a preview (i.e. it gets overwritten once another entry is selected). A double click opens it permanently, so multiple reads can be opened at the same time. Tabs can be closed via the `X` symbol. A tab shows all attributes stored in a pod5 file as key-value pairs. Nested information can be expanded. Values can be selected via double-click and copied to the clipboard.

Opened files and reads can be cleared from the window through `File > Clear`. To exit the app use  `File > Exit`.

![file navigation](./images/pod5viewer_file_navigator.gif)

### Filtering for specific reads

To enable the user to focus on a specific subset of reads in given POD5 files, reads can be filtered to a subset. To activate this feature navigate to `File > Filter reads...`. This opens a new window containing a text browser, in which read IDs can be inserted. Here one read ID must be given per line. Alternatively, read IDs can be loaded from a text file, again containing one read ID per line. Press the `Load IDs from file...` button to select a file for filtering. After loading, the contents of the file are shown in the text browser. Press `Done` to submit given read IDs for filtering. Afterwards, only reads that are found in the given set are shown. 

To clear the subset, reopen the window, press `Clear` and `Done`. Afterwards all read IDs are shown again.

![read filter](./images/pod5Viewer_read_filter.gif)


### Viewing signals

Individual current measurement can be inspected via `View > View signal`. This shows the current values in chunks. Use the scroll bar to scroll through chunks. 

![read filter](./images/pod5Viewer_view_data.png)


### Plotting signals

To plot the current measurements select `View > Plot signal...`, `View > Plot pA signal...`. Signals can be plotted for a single read (`Focussed read...`) or all opened reads (`All open reads...`). When selecting a option, a new window open showing the selected data as a line plot. The window contains the figure itself in the upper-left section, the legend containing each shown read ID in the upper-right section and a navigation section in the lower part of the window. 

The navigation section shows a rough map of the whole figure and allows for selection of specific intervals. The user can select an interval by pressing on the start coordinate in the navigation map and dragging the cursor to the wanted end coordinate. When releasing the mouse button, the figure gets updated to show the new interval. For more fine-tuned zooming, two input fields are given below the map. In these the user can type a start and end value and press `Zoom` to focus on the provided interval specifically. Zooming can be resetted via the `Reset zoom` button. This restores the plot to the initial state.

When multiple signals are shown, individual ones can be hidden/shown by unchecking/checking the corresponding checkbox in the legend.

To switch to plotting the normalized signals select `Data > Show normalized data` in the menu. To revert back to the non-normalized signals, press `Data > Show data`.

The current view can be exported to a vector graphic (SVG) by pressing `Export > Export current view...`. This opens a file browser where an export path can be selected.

For faster performance and responsiveness of the window, long signals are subset to a maximum of 10000 measurements per signal at any given point. When subsetting, the data is split into 10000 bins, for each of which the median value is calculated. The label above the navigation section indicates whether subsetting is performed in the section that is currently shown, and if so how many measurements are contained in one bin. This way, the resolution of the shown data increases dynamically with higher zoom levels, providing the best performance with the least amount of information loss.

![file navigation](./images/pod5viewer_plot_data.gif)


### Exporting reads

Either all opened reads (`All opened reads...`) or only the currently focused one (`Current read...`) can be exported to JSON format using `File > Export all info`. When exporting, the user selects an output file or directory in the file browser, where a JSON file is created for each exported read with the read-id as the file name.

The measurements of a read can be exported isolated from the remaining data of a given read through the `Export signal` menu. The values can be exported to a `.npy` Numpy file for further processing in a `Numpy` environment. Alternatively, they can be written to a text file, where each line contains one measurement.

### Shortcuts

Various keyboard shortcuts are available, allowing for all actions to be performed without a mouse. The following shortcuts are implemented:

- Ctrl+O: Open file(s)
- Ctrl+D: Open directory
- Ctrl+S: Export current read
- Ctrl+A: Export all opened reads
- Ctrl+Backspace: Clear viewer
- Ctrl+Q: Exit application

Navigation:

- Tab: Switch between file navigator and data viewer
- Ctrl+Tab: Cycle through tabs in the data viewer
- Ctrl+W: Close the current tab in the data viewer

Menu navigation:

- Alt & F: Open the file menu
- Alt & V: Open the view menu
- Alt & H: Open the help menu

View signal window:

- Pagedown: Scroll down (large steps)
- Pageup: Scroll up (large steps)
- Arrow down: Scroll down
- Arrow up: Scroll up

## License

This project is licensed under the GPL3.0 License. See the [LICENSE](./LICENSE) file for details.

## How to cite

DOI: [https://doi.org/10.1093/bioinformatics/btae665](https://doi.org/10.1093/bioinformatics/btae665)

If you use this tool in your work, we would be really happy if you cite us:
```
@article{10.1093/bioinformatics/btae665,
    author = {Dietrich, Vincent and Alagna, Nicolò and Helm, Mark and Gerber, Susanne and Butto, Tamer},
    title = {Pod5Viewer: a GUI for inspecting raw nanopore sequencing data},
    journal = {Bioinformatics},
    pages = {btae665},
    year = {2024},
    month = {12},
    issn = {1367-4811},
    doi = {10.1093/bioinformatics/btae665},
    url = {https://doi.org/10.1093/bioinformatics/btae665},
    eprint = {https://academic.oup.com/bioinformatics/article/40/12/btae665/7915477},
}
```

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/dietvin/pod5Viewer",
    "name": "pod5Viewer",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<3.13,>3.9",
    "maintainer_email": null,
    "keywords": null,
    "author": "Vincent Dietrich",
    "author_email": "dietricv@uni-mainz.de",
    "download_url": "https://files.pythonhosted.org/packages/71/2f/b86542219035995976ad71d3a45eca3ce20a156e44bc406de5fc9f844283/pod5viewer-1.1.2.tar.gz",
    "platform": null,
    "description": "![header](./images/github_header.png)\n\nThe pod5Viewer is a Python application that provides a graphical user interface for viewing and navigating through POD5 files. It allows users to open multiple POD5 files, explore their contents, and display detailed data for selected read IDs.\n\n[![License: GPL v3](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](http://www.gnu.org/licenses/gpl-3.0) [![Contributor Covenant](https://img.shields.io/badge/Contributor%20Covenant-2.1-4baaaa.svg)](CODE_OF_CONDUCT.md) [![pod5viewer](https://snapcraft.io/pod5viewer/badge.svg)](https://snapcraft.io/pod5viewer) ![GitHub Release](https://img.shields.io/github/v/release/dietvin/pod5Viewer) ![PyPI - Version](https://img.shields.io/pypi/v/pod5Viewer) ![GitHub Downloads (all assets, all releases)](https://img.shields.io/github/downloads/dietvin/pod5Viewer/total)\n\n## Table of Contents\n\n- [Table of Contents](#table-of-contents)\n- [Installation and requirements](#installation-and-requirements)\n  - [Windows](#windows)\n  - [Linux](#linux)\n  - [OS-independent](#os-independent)\n  - [Dependencies](#dependencies)\n- [Usage](#usage)\n  - [Open and inspecting pod5 files](#open-and-inspecting-pod5-files)\n  - [Filtering for specific reads](#filtering-for-specific-reads)\n  - [Viewing signals](#viewing-signals)\n  - [Plotting signals](#plotting-signals)\n  - [Exporting reads](#exporting-reads)\n  - [Shortcuts](#shortcuts)\n- [License](#license)\n- [How to cite](#how-to-cite)\n\n## Installation and requirements\n\n### Windows\n\nFor Windows systems the pod5Viewer can be installed conveniently via the installer. The installer can be downloaded here:\n\n[pod5Viewer-1.1.1-Setup.exe](https://github.com/dietvin/pod5Viewer/releases/download/1.1.2/pod5Viewer-1.1.2-Setup.exe \"Download pod5Viewer Windows installer\") \n\nAfter downloading the installer and following the steps provided, the pod5Viewer can be accessed and opened from the start menu or the desktop shortcut. It also sets the pod5Viewer as the standard application to open POD5 files, so it is possible to open a file by simply clicking on it.\n\n**Note**: When running the installer a the Windows defender might open the Window `Windows protected your PC`. To continue the installation, press `More Info` and `Run anyway`.\n\n### Linux\nOn Linux systems the pod5Viewer can be installed via [snap](https://snapcraft.io/docs/installing-snapd). To install the package run the following command:\n```bash\nsudo snap install --edge pod5viewer \n```\nAfterwards the pod5Viewer can be opened from the command line via `pod5viewer` or like any other installed GUI application.\n\nThe Snap installation should work on all x86 based systems. We tested the installation on:\n- Ubuntu 24.04\n- Ubuntu 22.04\n- Linux Mint 21.3\n- Linux Mint 20.3\n- Debian 12\n\n### OS-independent\n\nThe pod5Viewer can be installed via the Python packaging index using `pip`.\n\nNote that when installing the pod5Viewer via pip, it can only be started from the command line. It is not possible to open POD5 files directly from a file browser.\n\nHere we recommend installing the pod5Viewer into a fresh virtual environment via [Conda](https://docs.anaconda.com/miniconda/) or a similar environment manager:\n\n```bash\nconda create -n p5v python==3.10\nconda activate p5v\n```\n\nWith the virtual environment active, the pod5Viewer can be installed via pip:\n\n```bash\npip install pod5Viewer\n```\n\nTo start the pod5Viewer from a python environment type:\n\n```bash\npod5Viewer\n```\n\nOptionally specify one or more path(s) to POD5 file(s) to open these directly:\n\n```bash\npod5Viewer file1.pod5 file2.pod5\n```\n\n---\n\nAlternatively, the pod5Viewer can be installed from source:\n\n```bash\ngit clone https://github.com/dietvin/pod5Viewer.git\ncd pod5Viewer\npip install .\n```\n\n### Dependencies\n\nThe pod5Viewer is built in Python (v3.10.0) and relies on the following packages:\n\n- numpy (v1.26.4)\n- pod5 (v0.3.10)\n- pyside6 (v6.5.2)\n- matplotlib (v3.9.2)\n\nThe compliation for Windows was performed using the pyinstaller (v6.8.0) and the Windows installer was created using the Inno Setup Compiler (v6.3.1).\n\n## Usage\n\n![overview](./images/pod5Viewer_overview.png)\n\n### Open and inspecting pod5 files\n\nIn the pod5Viewer open files from the menu bar in the top via `File > Open file(s)...` (individual file(s)) or `File > Open directory` (all files in a directory). All opened files are shown in the left panel. Expanding an entry shows all reads in a given file by their read ID. Opened files and reads can be sorted alphabetically in ascending or descending order using the respective buttons above the panel. Specific read IDs can be searched using the search bar. Typing a search query updates the panel to show fitting reads in real-time. The button next to the search bar clears a given search query. \n\nA single click on a read ID opens the entry as a preview (i.e. it gets overwritten once another entry is selected). A double click opens it permanently, so multiple reads can be opened at the same time. Tabs can be closed via the `X` symbol. A tab shows all attributes stored in a pod5 file as key-value pairs. Nested information can be expanded. Values can be selected via double-click and copied to the clipboard.\n\nOpened files and reads can be cleared from the window through `File > Clear`. To exit the app use  `File > Exit`.\n\n![file navigation](./images/pod5viewer_file_navigator.gif)\n\n### Filtering for specific reads\n\nTo enable the user to focus on a specific subset of reads in given POD5 files, reads can be filtered to a subset. To activate this feature navigate to `File > Filter reads...`. This opens a new window containing a text browser, in which read IDs can be inserted. Here one read ID must be given per line. Alternatively, read IDs can be loaded from a text file, again containing one read ID per line. Press the `Load IDs from file...` button to select a file for filtering. After loading, the contents of the file are shown in the text browser. Press `Done` to submit given read IDs for filtering. Afterwards, only reads that are found in the given set are shown. \n\nTo clear the subset, reopen the window, press `Clear` and `Done`. Afterwards all read IDs are shown again.\n\n![read filter](./images/pod5Viewer_read_filter.gif)\n\n\n### Viewing signals\n\nIndividual current measurement can be inspected via `View > View signal`. This shows the current values in chunks. Use the scroll bar to scroll through chunks. \n\n![read filter](./images/pod5Viewer_view_data.png)\n\n\n### Plotting signals\n\nTo plot the current measurements select `View > Plot signal...`, `View > Plot pA signal...`. Signals can be plotted for a single read (`Focussed read...`) or all opened reads (`All open reads...`). When selecting a option, a new window open showing the selected data as a line plot. The window contains the figure itself in the upper-left section, the legend containing each shown read ID in the upper-right section and a navigation section in the lower part of the window. \n\nThe navigation section shows a rough map of the whole figure and allows for selection of specific intervals. The user can select an interval by pressing on the start coordinate in the navigation map and dragging the cursor to the wanted end coordinate. When releasing the mouse button, the figure gets updated to show the new interval. For more fine-tuned zooming, two input fields are given below the map. In these the user can type a start and end value and press `Zoom` to focus on the provided interval specifically. Zooming can be resetted via the `Reset zoom` button. This restores the plot to the initial state.\n\nWhen multiple signals are shown, individual ones can be hidden/shown by unchecking/checking the corresponding checkbox in the legend.\n\nTo switch to plotting the normalized signals select `Data > Show normalized data` in the menu. To revert back to the non-normalized signals, press `Data > Show data`.\n\nThe current view can be exported to a vector graphic (SVG) by pressing `Export > Export current view...`. This opens a file browser where an export path can be selected.\n\nFor faster performance and responsiveness of the window, long signals are subset to a maximum of 10000 measurements per signal at any given point. When subsetting, the data is split into 10000 bins, for each of which the median value is calculated. The label above the navigation section indicates whether subsetting is performed in the section that is currently shown, and if so how many measurements are contained in one bin. This way, the resolution of the shown data increases dynamically with higher zoom levels, providing the best performance with the least amount of information loss.\n\n![file navigation](./images/pod5viewer_plot_data.gif)\n\n\n### Exporting reads\n\nEither all opened reads (`All opened reads...`) or only the currently focused one (`Current read...`) can be exported to JSON format using `File > Export all info`. When exporting, the user selects an output file or directory in the file browser, where a JSON file is created for each exported read with the read-id as the file name.\n\nThe measurements of a read can be exported isolated from the remaining data of a given read through the `Export signal` menu. The values can be exported to a `.npy` Numpy file for further processing in a `Numpy` environment. Alternatively, they can be written to a text file, where each line contains one measurement.\n\n### Shortcuts\n\nVarious keyboard shortcuts are available, allowing for all actions to be performed without a mouse. The following shortcuts are implemented:\n\n- Ctrl+O: Open file(s)\n- Ctrl+D: Open directory\n- Ctrl+S: Export current read\n- Ctrl+A: Export all opened reads\n- Ctrl+Backspace: Clear viewer\n- Ctrl+Q: Exit application\n\nNavigation:\n\n- Tab: Switch between file navigator and data viewer\n- Ctrl+Tab: Cycle through tabs in the data viewer\n- Ctrl+W: Close the current tab in the data viewer\n\nMenu navigation:\n\n- Alt & F: Open the file menu\n- Alt & V: Open the view menu\n- Alt & H: Open the help menu\n\nView signal window:\n\n- Pagedown: Scroll down (large steps)\n- Pageup: Scroll up (large steps)\n- Arrow down: Scroll down\n- Arrow up: Scroll up\n\n## License\n\nThis project is licensed under the GPL3.0 License. See the [LICENSE](./LICENSE) file for details.\n\n## How to cite\n\nDOI: [https://doi.org/10.1093/bioinformatics/btae665](https://doi.org/10.1093/bioinformatics/btae665)\n\nIf you use this tool in your work, we would be really happy if you cite us:\n```\n@article{10.1093/bioinformatics/btae665,\n    author = {Dietrich, Vincent and Alagna, Nicol\u00f2 and Helm, Mark and Gerber, Susanne and Butto, Tamer},\n    title = {Pod5Viewer: a GUI for inspecting raw nanopore sequencing data},\n    journal = {Bioinformatics},\n    pages = {btae665},\n    year = {2024},\n    month = {12},\n    issn = {1367-4811},\n    doi = {10.1093/bioinformatics/btae665},\n    url = {https://doi.org/10.1093/bioinformatics/btae665},\n    eprint = {https://academic.oup.com/bioinformatics/article/40/12/btae665/7915477},\n}\n```\n",
    "bugtrack_url": null,
    "license": "LICENSE",
    "summary": "GUI for inspecting ONT pod5 files",
    "version": "1.1.2",
    "project_urls": {
        "Homepage": "https://github.com/dietvin/pod5Viewer"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "4ee450df65496f9cee40421764e92b93fb7e1fdbf8bce8aa3a69ff2620863844",
                "md5": "9f726b1d214c00ec604e8052695faf2d",
                "sha256": "e4ed7c357b0e779bd91a755ac6a93b1ea833d8a6c0b7d4dd1f456c35e65725aa"
            },
            "downloads": -1,
            "filename": "pod5Viewer-1.1.2-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "9f726b1d214c00ec604e8052695faf2d",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<3.13,>3.9",
            "size": 144327,
            "upload_time": "2024-12-17T11:43:21",
            "upload_time_iso_8601": "2024-12-17T11:43:21.730838Z",
            "url": "https://files.pythonhosted.org/packages/4e/e4/50df65496f9cee40421764e92b93fb7e1fdbf8bce8aa3a69ff2620863844/pod5Viewer-1.1.2-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "712fb86542219035995976ad71d3a45eca3ce20a156e44bc406de5fc9f844283",
                "md5": "056288b6407b7f816a1849de616504aa",
                "sha256": "173112ab9788ebf37e15fbee64d5f793843da13330f756811a5e92e72f079daa"
            },
            "downloads": -1,
            "filename": "pod5viewer-1.1.2.tar.gz",
            "has_sig": false,
            "md5_digest": "056288b6407b7f816a1849de616504aa",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<3.13,>3.9",
            "size": 143340,
            "upload_time": "2024-12-17T11:43:24",
            "upload_time_iso_8601": "2024-12-17T11:43:24.558283Z",
            "url": "https://files.pythonhosted.org/packages/71/2f/b86542219035995976ad71d3a45eca3ce20a156e44bc406de5fc9f844283/pod5viewer-1.1.2.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-12-17 11:43:24",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "dietvin",
    "github_project": "pod5Viewer",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [
        {
            "name": "numpy",
            "specs": [
                [
                    "==",
                    "1.26.4"
                ]
            ]
        },
        {
            "name": "pod5",
            "specs": [
                [
                    "==",
                    "0.3.10"
                ]
            ]
        },
        {
            "name": "pyside6",
            "specs": [
                [
                    "==",
                    "6.5.2"
                ]
            ]
        },
        {
            "name": "matplotlib",
            "specs": [
                [
                    "==",
                    "3.9.2"
                ]
            ]
        }
    ],
    "lcname": "pod5viewer"
}
        
Elapsed time: 0.38077s