Metadata-Version: 2.1
Name: fastgenomics
Version: 2.0.2
Summary: FASTGenomics python helper
Home-page: https://github.com/fastgenomics/fastgenomics-py
License: UNKNOWN
Author: FASTGenomics Team
Author-email: contact@fastgenomics.org
Requires-Python: ~=3.6
Description-Content-Type: text/markdown
Classifier: Development Status :: 5 - Production/Stable
Classifier: Environment :: Console
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Science/Research
Classifier: Natural Language :: English
Classifier: Operating System :: MacOS :: MacOS X
Classifier: Operating System :: Microsoft :: Windows
Classifier: Operating System :: POSIX :: Linux
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Topic :: Scientific/Engineering :: Bio-Informatics
Classifier: Topic :: Scientific/Engineering :: Visualization
Classifier: License :: OSI Approved :: MIT License
Requires-Dist: deprecated (~=1.2.4)
Requires-Dist: jsonschema (~=2.6)
Requires-Dist: Jinja2 (~=2.9)
Requires-Dist: get_version (~=2.0.1)
Requires-Dist: setuptools
Requires-Dist: sphinx; extra == "doc"
Requires-Dist: sphinx_rtd_theme; extra == "doc"
Requires-Dist: sphinx-autodoc-typehints; extra == "doc"
Requires-Dist: pytest >=4; extra == "test"
Requires-Dist: anndata >=0.6; extra == "test"
Project-URL: Documentation, https://fastgenomics.readthedocs.io
Provides-Extra: .none
Provides-Extra: doc
Provides-Extra: test

[![pypi-shield]][pypi]
[![travis-shield]][travis]
[![docs-shield]][docs]

[pypi-shield]: https://img.shields.io/pypi/v/fastgenomics.svg
[pypi]: https://pypi.org/project/fastgenomics
[travis-shield]: https://travis-ci.org/FASTGenomics/fastgenomics-py.svg?branch=master
[travis]: https://travis-ci.org/FASTGenomics/fastgenomics-py
[docs-shield]: https://readthedocs.org/projects/fastgenomics/badge/?version=latest
[docs]: http://fastgenomics.readthedocs.io

# About

This python module handles all common interfaces
of your application to the FASTGenomics runtime:

-  Input/Output of files
-  Parameters

and provides some convenience functions.

## Examples

A basic interaction through the `fastgenomics` module looks looks this

``` python
from fastgenomics.process import FGProcess

app_dir = "/app"
data_dir = "/fastgenomics"
fg = FGProcess(app_dir, data_dir)

# access a parameter
fg.parameters["some_parameter"]

# access an input/ouput file
fg.input["some_input_file.txt"].path
fg.output["some_output_file.txt"].path
```

### Consistency checks

The constructor of `FGProcess` will check if all the necessary files
exist and validate if their contents is according to the FASTGenomics
standard.  For example, if you make a mistake in the `manifest.json`
of the app you will get a relevant error when calling `FGProcess`.

### Reading & Writing AnnData
You can also easily load an AnnData object with

``` python
from fastgenomics.external import anndata

# read AnnData
adata = anndata.read_data(
    fg, expr="expression_table", cell_metadata="cell_metadata", gene_metadata="gene_metadata")

# write AnnData
anndata.write_data(
    fg, adata,
    expr="expression_table", cell_metadata="cell_metadata", gene_metadata="gene_metadata")
```

(in the `read_data` the `cell_metadata` and `gene_metadata` are
optional, in the `write_data` all the output names are optional).

_note_ This functionality is kept in a separate submodule, to keep the
dependency on scanpy optional.

### Parameter checks

Aside from accessing the parameters you can also use the following
function to validate if a parameter fulfills some arbitrary
constraints.  The code below raises a `ValueError` when
`some_parameter` is not larger then zero.

``` python
fg.parametres.check(
    "some_parameter",
    lambda x: x > 0,
    'Parameter "some_parameter" must be larger then 0.')
```

### Writing the summary with a jinja2 template
FASTGenomics requires an app to output a `summary.md` file, this file
is typically generated using a [jinja2
template](http://jinja.pocoo.org/).  This module provides the
following utility function for generating a summary file.

``` python
fg.summary.template = "path_to_the_tempalte/summary.md.j2"
fg.summary.write(some_value=1, some_other_value=2)
```

This generates a `summary.md` file in
`"[data_dir]/summary/summary.md"` based on the template in
`fg.summary.template` passing `some_value=1` and `some_other_value=2`
to the template engine.

*Note:* The `fg.summary.write` function appends a `###`-level section
with the parameter values, with which the app was run.

## Internals

The module encapsulates most of its functionality in a single class
`FGProcess(app_dir, data_dir)` that is constructed from two paths:
`app_dir`, where all the necessary app-related files are (most
importantly, the `manifest.json`) and `data_dir`, which points to the
directory structure provided by FASTGenomics.  The class `FGProcess`
has the following attributes

- `app`: contains the interpreted `manifest.json` and the locations of
  app-related files.
- `parameters`: facilitates the access to parameters provided by the
  FASTGenomics runtime.
- `input`, `output`: represents the input and output files provide by
  the FASTGenomics runtime.
- `summary`: handles the `summary.md` rendering.

