Metadata-Version: 2.1
Name: scCellFie
Version: 0.3.0
Summary: A tool for studying metabolic tasks from single-cell and spatial transcriptomics
Home-page: https://github.com/earmingol/scCellFie
Author: Erick Armingol
Author-email: erickarmingol@gmail.com
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Description-Content-Type: text/x-rst
License-File: LICENSE.txt
Requires-Dist: scanpy
Requires-Dist: numpy
Requires-Dist: pandas
Requires-Dist: cobra
Requires-Dist: tqdm
Requires-Dist: scipy
Requires-Dist: anndata
Requires-Dist: squidpy
Requires-Dist: networkx
Requires-Dist: geopandas
Requires-Dist: esda

|PYPI| |Issues| |Codecov| |Downloads|

.. |PYPI| image:: https://badge.fury.io/py/sccellfie.svg
   :target: https://pypi.org/project/sccellfie/

.. |Issues| image:: https://github.com/earmingol/scCellFie/actions/workflows/tests.yml/badge.svg
   :alt: test-sccellfie

.. |Codecov| image:: https://codecov.io/gh/earmingol/scCellFie/graph/badge.svg?token=22NENAKNKI
   :target: https://codecov.io/gh/earmingol/scCellFie

.. |Downloads| image:: https://pepy.tech/badge/sccellfie/month
   :target: https://pepy.tech/project/sccellfie


Metabolic activity from single-cell and spatial transcriptomics with scCellFie
-----------------------------------------------------------------------------------------

scCellFie is a computational tool for studying metabolic tasks using Python, inspired by the original implementation of
`CellFie <https://github.com/LewisLabUCSD/CellFie>`_, another tool originally developed in MATLAB by the `Lewis Lab <https://lewislab.ucsd.edu/>`_. This version is designed to be
compatible with single-cell and spatial data analysis using Scanpy, while including a series of improvements and new analyses.

.. image:: https://github.com/earmingol/scCellFie/blob/main/scCellFie-Logo.png?raw=true
   :alt: Logo
   :width: 350
   :height: 188.31
   :align: center


Installation
------------

To install scCellFie, use pip::

    pip install sccellfie

Features
--------

- **Single cell and spatial data analysis:** Tailored for analysis of metabolic
  tasks using fully single cell resolution and in space.

- **Speed:** This implementation further leverages the original CellFie. It is now memory
  efficient and run much faster! A dataset of ~70k single cells can be analyzed in ~5 min.

- **New analyses:** From marker selection of relevant metabolic tasks to integration with
  inference of cell-cell communication.

- **User-friendly:** Python-based for easier use and integration into existing workflows.

- **Scanpy compatibility:** Fully integrated with Scanpy, the popular single cell
  analysis toolkit.

- **Organisms:** Metabolic database and analysis available for human and mouse.

Quick start
-----------
A quick example of how to use scCellFie with a single-cell dataset and generate results::

        import sccellfie
        import scanpy as sc

        # Load the dataset
        adata = sc.read(filename='BALF-COVID19.h5ad',
                        backup_url='https://zenodo.org/record/7535867/files/BALF-COVID19-Liao_et_al-NatMed-2020.h5ad')

        # Run one-command scCellFie pipeline
        results = sccellfie.run_sccellfie_pipeline(adata,
                                                   organism='human',
                                                   sccellfie_data_folder=None,
                                                   n_counts_col='n_counts',
                                                   process_by_group=False,
                                                   groupby=None,
                                                   neighbors_key='neighbors',
                                                   n_neighbors=10,
                                                   batch_key='sample',
                                                   threshold_key='sccellfie_threshold',
                                                   smooth_cells=True,
                                                   alpha=0.33,
                                                   chunk_size=5000,
                                                   disable_pbar=False,
                                                   save_folder=None,
                                                   save_filename=None
                                                  )

To access metabolic activities, we need to inspect `results['adata']`:

- The processed single-cell data is located in the AnnData object `results['adata']`.
- The reaction activities for each cell are located in the AnnData object `results['adata'].reactions`.
- The metabolic task activities for each cell are located in the AnnData object `results['adata'].metabolic_tasks`.

In particular:

- `results['adata']`: contains gene expression in `.X`.
- `results['adata'].layers['gene_scores']`: contains gene scores as in the original CellFie paper.
- `results['adata'].uns['Rxn-Max-Genes']`: contains determinant genes for each reaction per cell.
- `results['adata'].reactions`: contains reaction scores in `.X` so every scanpy function can be used on this object to visualize or compare values.
- `results['adata'].metabolic_tasks`: contains metabolic task scores in `.X` so every scanpy function can be used on this object to visualize or compare values.

Other keys in the `results` dictionary are associated with the scCellFie database and are already filtered for the elements present
in the dataset (`'gpr_rules'`, `'task_by_gene'`, `'rxn_by_gene'`, `'task_by_rxn'`, `'rxn_info'`, `'task_info'`, `'thresholds'`, `'organism'`).

How to cite
-----------

*Preprint is coming soon!*

Acknowledgments
---------------

This implementation is inspired by the original `CellFie tool <https://github.com/LewisLabUCSD/CellFie>`_ developed by
the `Lewis Lab <https://lewislab.ucsd.edu/>`_. Please consider citing their work if you find this tool useful:

- **Model-based assessment of mammalian cell metabolic functionalities using omics data**.
  *Cell Reports Methods, 2021*. https://doi.org/10.1016/j.crmeth.2021.100040

- **ImmCellFie: A user-friendly web-based platform to infer metabolic function from omics data**.
  *STAR Protocols, 2023*. https://doi.org/10.1016/j.xpro.2023.102069

- **Inferring secretory and metabolic pathway activity from omic data with secCellFie**.
  *Metabolic Engineering, 2024*. https://doi.org/10.1016/j.ymben.2023.12.006
