.. _user-guide: ๐Ÿ‘ฉโ€๐Ÿ’ป User guide ========== ๐Ÿ“š **Contents:** - :ref:`install` - :ref:`optional` - :ref:`support` - :ref:`getting_started` - :ref:`catalog-section` .. _install: โฌ‡๏ธ Installation -------------- 1. Install scivision via [PyPi](https://pypi.org/project/scivision/): which tends to be the most user-friendly option: ```bash pip install scivision ``` 2. Install scivision from the source code: * Clone scivision source code: ```bash git clone https://github.com/alan-turing-institute/scivision.git ``` * Install scivision and its dependencies: ```bash cd /path/to/my/scivision pip install -v -e . ``` .. _optional: ๐Ÿ”— Optional dependencies -------------- Scivision supports optional dependencies, which are not installed by default. These dependencies are required for certain functionality, such as loading models from certain sources, or loading certain types of data. - `cloud_extra`: install dependencies for loading data or models from cloud storage (e.g. AWS S3 and Google Cloud Storage) To install the optional `cloud_extra` dependencies, run: ```bash pip install scivision[cloud_extra] ``` .. _support: ๐Ÿ“‹ Support table -------------- | Python version | Scivision version | | --- | --- | | <3.7 | no compatible version | | ^3.7 | <0.4 | | ^3.8 | * (any) | | ^3.9 | * (any) | | ^3.10 | >=0.3 | | >=3.11 | >=0.3, untested, but intending to support (bug reports welcome) | Scivision is currently working towards supporting Python >=3.11. .. _getting_started: ๐Ÿงช Getting started --------------- Scivision enables users to quickly find computer vision models that can be run on matching scientific image dataset(s), or find datasets that models can be run on. This can be achieved by running several lines of Python code. The core functionality of the Python package API is documented in the :ref:`api-docs` documentation and a Jupyter notebook demonstrating it can be found [on GitHub](https://github.com/scivision-gallery/scivision-basic-usage-examples/blob/main/how-to-use-scivision.ipynb) or can be interactively run via clicking the following link to Binder: [![badge](https://img.shields.io/badge/Example-notebook-579ACA.svg?logo=)](https://mybinder.org/v2/gh/scivision-gallery/scivision-basic-usage-examples/d208ac0d452e139a90e66e3c3e96dac4ad0e26ce?urlpath=lab%2Ftree%2Fhow-to-use-scivision.ipynb) In brief, the notebook demonstrates the following: 1. Loading a pretrained (ImageNet) model, which was previously added to the scivision catalog with the name "scivision-test-plugin" `model = load_pretrained_model('/path/to/model/repo')` 2. Using the "default" scivision catalog to find a matching dataset, which the loaded model can be run on `default_catalog.compatible_datasources()` 3. Loading the dataset in a format the model can recognise `load_dataset('/path/to/data/repo')` 4. Running the model on the data, performing simple model inference `model.predict()` .. _catalog-section: ๐Ÿ“– Catalog of models and datasets ------------------------------ The models and datasets you find when searching the "default" scivision catalog (that which comes with the package) are loaded from external sources via metadata included in the [GitHub repository](https://github.com/alan-turing-institute/scivision/tree/main/scivision/catalog/data). To understand how these external sources are configured for compatibility with scivision, consult the following sections of this documentation: - :ref:`model-repo-template` - :ref:`data-repo-template` To understand how to contribute new models and data sources to the scivision catalog, check out: - :ref:`extending-the-scivision-catalog`