Changelog#
1.7.3 (26.05.2026)#
Fixed top-level
import cornetoinliana/method/fun/_causalnet.pywhich caused ReadTheDocs builds to fail (no module named liana.method) becausecornetois an optional dependency not installed in the doc environment. Removed the top-level import and the now-unnecessarycorneto.*type annotations from function signatures; runtime loading already used_check_if_installed("corneto").Updated
inflow_score.ipynbto use the newtarget_organism='mouse'parameter forli.rs.get_hcop_orthologsinstead of the defunct EBI FTPurl.
1.7.2 (14.05.2026)#
Fixed
get_hcop_orthologsto use the HGNC Google Cloud Storage bucket instead of the defunct EBI FTP mirror, resolving 404 errors in CI.Added
target_organismparameter (default"mouse") toget_hcop_orthologs, enabling homology mapping to any of the 19 species available in the HCOP database.Updated documentation notebook (
prior_knowledge.ipynb) to use the newtarget_organismAPI.Updated
sc_multi.ipynbmetabolite-receptor section for decoupler v2: renamedpd_net/t_netcolumns tosource/target/weightand removed deprecatedsource/target/weight/min_nkwargs fromestimate_metalinks(replaced bytmin).Standardized all public docstrings to NumPy format and added type annotations across public modules (#219).
Added mypy type-checking to pre-commit hooks (
--no-strict-optional --ignore-missing-imports).Added
build.yamlCI workflow: validates the package build withuv build+twine check --stricton every push and pull request.Renamed
.github/workflows/main.yml→test.yml.
1.7.1 (24.01.2026)#
Fixed issue with Metalinks download due to User-Agent restrictions.
Added scanpy version compatibility using getattr to handle both _set_default_colors_for_categorical_obs (old) and set_default_colors_for_categorical_obs (new).
1.7.0 (07.01.2026)#
Inflow implementation and tutorial #221 by @AtheerAS
Global specificity calculation #221 by @AtheerAS
The integration of spatial proximity weighting into scoring and permutation-based p-value calculations, new user-facing parameters for spatial analysis, and enhancements to the documentation to reflect these features. #222. The main cell-cell communication pipeline (
liana_pipe) and scoring methods now support spatial proximity weighting. This includes new arguments (spatial_key,spatial_kwargs) and logic to compute and merge spatial proximity scores into LR (ligand-receptor) results, and to adjust permutation-based p-value calculations accordingly. (src/liana/method/sc/_liana_pipe.py)Expanded docstrings and parameter documentation to cover new spatial analysis arguments, including detailed descriptions of spatial proximity options and kernel/bandwidth settings.
Updated the notebook index and documentation to reference new spatial analysis notebooks, such as
inflow_score.ipynb.Bumped the package version to 1.7.0 across configuration files, and updated dependencies for
decoupler.Added Python 3.13 support in classifiers. #216
Added Installation instructions in
installation.md. #217Properly check if a passed (cell type) labels in plotting are a string #220
Fixed an issue where MetalinksDB download would fail due to User-Agent restrictions.
1.6.1 (28.09.2025)#
Comply with AnnData CSR matrix changes
Bump Python version to <=3.13
1.6.0 (09.07.2025)#
1.5.1 (13.02.2025)#
liana will now require Python >= 3.10
Removed AnnData upper version restrictions
Merged PR #161 for numpy2.0 compatibility
Minor documentation improvements for circle_plot.
1.5.0 (17.01.2025)#
New
circle_plotis now available (Merged #139). Thanks to @WeipengMO.Update bivariate metrics to no longer save in place but rather return the AnnData
Issue related to .A for a csr_matrix after a certain scipy version #155, #135
Removed inplace paramter from
li.mt.bivariateRelated to #147. It will now by default return an AnnData object.
1.4.0 (02.09.2024)#
Now published at Nat Cell Bio.
Correctly referred to PK tutorial for orthology conversion
- Added batch_key and min_var_nbatches to control te way batches
are selected in li.multi.lrs_to_views. This might result in minor
differences of how many interactions are considered per view, as I also
changed the order of filtering.
Changed
max_neighboursinli.ut.spatial_neighborsto be a fixed number (default=100), rather than a fraction of the spots as this was making RAM explode for large spatial formats.
1.3.0 (12.07.2024)#
Minor improvements to documentation, specifically changed to the furo theme. Resolved issues with latex not being rendered and plot sizes being off.
An exception will now be reaised if
nz_propis too high inli.mt.bivariate. #121Updated MetalinksDB to v0.4.5 (the latest version of the MetalinksDB paper), extended to also include production-degradation information.
Fixed some edgecases where an external
resourceorinteractionscan have duplicated entries, also resolving a pandas name index issue (#120)Added simple tutorial how to process multi-omics and multi-modal (e.g. metabolite inference) data with LIANA+. #41 #124
1.2.1 (11.06.2024)#
Added +1 to the max_neighbours to account for the spot itself in the spatial connectivities.
Replaced Squidpy’s neighbourhood graph with liana’s radial basis kernel, but with a fixed number of neighbours for each spot. This does not account for edges, but differences are minimal does not require squidpy as a dependency. One can easily replace it on demand. (# saezlab/liana-py#112)
Fixed Python version range between 3.8 and 3.12 (Merged #112)
Improved the Differential Expression Vignette be more explicit about the causal subnetwork search results (related to #66)
1.2.0 (24.05.2024)#
- Added inbuilt orthology conversion functions to convert between
species in the ligand-receptor resources (addressing #76) These include:
li.rs.get_hcop_orthology to obtain a dataframe of orthologs from
[HCOP](https://www.genenames.org/tools/hcop/),
li.rs.translate_column to translate a single column in a dataframe,
and li.rs.translate_resource as a simple wrapper from the latter
function to be applied on dataframes.
Merged #109 to address a backward compatibility issue with plotnine’s facets.
Updated MOFAcell & MOFAtalk tutorials, by making some parameters a bit more explicit (#102), and using decoupler’s association plot to do ANOVA + plot metadata associations.
The mean rank returned by
rank_aggregatewhenaggregate_metod= ‘mean’ is now normalized by the total number of interactions.Fixed a minor logic issue when calculating analytical p-values for Moran’s R
1.1.0 (12.04.2024)#
Added a check for the subset of cell types in li.multi.dea_to_lr. Related to #92.
Split Local and Global Bivariate metrics. Specifically, I reworked completely the underlying code, though the API should remain relatively unchanged. With the exceptions of: 1)
lr_bivaris now removed andbivarhas been renamed tobivariate. This allowed me to remove a lot of redundancies between the two functions. 2)nz_thresholdhas been renamed tonz_propfor consistency withexpr_propin the remainder of the package. Related to #44.li.mt.bivariateparametermod_addedhas been renamed tokey_addeddue to this now refer to both.obsmand.mod- depedening whether an AnnData or MuData object is passed.Added Global [Lee’s statistic](https://onlinelibrary.wiley.com/doi/abs/10.1111/gean.12106), along with a note on weighted product that upon z-scaling it is equivalent to Lee’s local statistic.
The Global [L statistic](https://onlinelibrary.wiley.com/doi/abs/10.1111/gean.12106) and Global [Moran’s R](https://www.nature.com/articles/s41467-023-39608-w) are themselves basically identical. See Eq.22 from Lee and Eq.1 in Supps of SpatialDM.
Changed the
li.mt.bivarparameterfunction_nametolocal_namefor consistency and to avoid ambiguity with the newly-addedglobal_nameparameter.Added
bumpversionto manage versioning. Related to #73.Added
max_runsandstable_runsparameters to enable the inference of robust causal networks with CORNETO. Related to #82.Optimized MISTy such that the matrix multiplication by weights is done only once, rather than for each target. Users can now obtain the weighted matrix via the
misty.get_weighted_matrixfunction.MISTy models are now passed externally, rather than being hardcoded. This allows for more flexibility in the models used. As an example, I also added a RobustLinearModel from statsmodels. Related to #74.
Removed forced conversion to sparse csr_matrix matrices in MISTy. Related to #57.
1.0.5 (25.02.2024)#
Added ScSeqComm Method, implemented by @BaldanMatt (#68)
- Added functions to query a metabolite-receptor interactions database
([MetalinksDB](biocypher/metalinks)), including:
=> li.rs.get_metalinks to get the database =>
li.rs.get_metalinks_values to get the distinct annotation values of
the database => describe_metalinks to get a description of the
database
Added a metabolite-mediated CCC tutorial in spatially-resolved multi-omics data (#45).
Changed hardcoded constants to be defined in [constants.py]{#constants.py}
Excluded CellChat from the default
rank_aggregatemethodFixed return logic of SpatialBivariate
li.mt.process_scoresis now exported toli.mtChanged the default
max_neighboursinli.ut.spatial_neighborsto 1/10 of the number of spots.
1.0.4 (17.01.2024)#
Moved the Global score summaries of
SpatialBivariatefrom .uns to .vardf_to_lrwill now also return the expression and proportion of expression for the interactionsli.multi.nfmwill now also accept a DataFrame as inputFiltered putative interactions in the Consensus resource, mostly such coming from CellTalkDB.
Changed
filter_lambdaparameter tofilter_funfor consistency and now any function can be passed to be applied as a row-wise filter.Global results of
SpatialBivariatewill now be saved to.varAdded
li.ut.interpolate_adatautility function to interpolate the data to a common space.MISTy will also work with directly non-aligned data with spatial connectivities from one modality to the other being passed via
obsmrather thanobsp. Making use ofli.ut.spatial_neighborsby passing reference coordinates.Fixed a bug where
li.ut.obsm_to_adatawould assign var as a method rather than DataFrameFixed a bug where p-values for Global Moran’s were not calculated correctly.
Enabled
cell_pairsof interest to be passed to single-cell methods.Enabled Parallelization of Permutation-based methods.
Local categories will now be only calculated for positive interactions (not non-ambigous as before).
Names of source and target panels can now be passed to
li.pl.tileplot.li.rs.explode_complexesis now consistently exported toli.rs(as previous versions)li.mt.find_causalnet: changed the noise assigned to nodes to be proportional to the minimum penalty of the model. Also, added noise to the edges to avoid multiple solutions to the same problem.
1.0.3 (06.11.2023)#
Added
filterbyandfilter_lambdaparameters toli.pl.interactionsandli.pl.target_metricsto allow filtering of interactions and metrics, respectively.Removed unnecessary
statparameter fromli.pl.contributionsAdded tests to ensure both
lr_bivarand single-cell methods throw an exception when the resource is not covered by the data.estimate_elbowwill add the errors and the number of patterns to.unswhen inplace is True.When
groupbyorsample_keyare not categorical liana will now print a warning before converting them to categorical. Related to #28Various documentation improvements, including using
docrepto ensure consistency.__version__will now correctly reflect the version in pyproject.tomlExported repeated value definitions to
_constants.pyRenamed some
*_separatorcolumns to*_sepfor consistency.Added
li.ut.query_bandwidthto query the bandwidth of the spatial connectivities (used in spatial bivariate tutorial)Added pre-commit hooks adapted from scverse’s cookiecutter.
1.0.2 (13.10.2023)#
Added as
seedparam tofind_causalnet, used to a small amount of noise to the nodes in to avoid obtaining multiple solutions to the same problem when multiple equal solutions are possible.Updated
installation.rstto refer topip install liana[common]andliana[full]for extended installations.Fixed a bug which would cause
bivarto crash when an AnnData object was passed
Merged #61 including the following:
Added
standardizeparameter to spatial_neighbors, used to standardize the spatial connectivities such that each spot’s proximity weights to 1. Required for non-standardized metrics (such asproduct)Fixed edge case in
assert_coveredto handle interactions not present inadatanor the resource.
- Added simple product (scores ranging from -inf, +inf) and norm_product (scores ranging from -1, +1). The former is a simple product of x and y, while the latter standardized each variable to be between 0 and 1, following weighing by spatial proximity, and then multiplies them. Essentially, it diminishes the effect of spatial proximity on the score, while still taking it into account. We observed that this is useful for e.g. border zones.
1.0.1 Stable Release (30.09.2023)#
Bumped CORNETO version and it’s now installed via PyPI.
1.0.0a2 (19.09.2023)#
Interactions names in
tileplotanddotplotwill now be sorted according toorderbywhen used; related to #55Added
filter_view_markersfunction to filter view markers considered background in MOFAcellular tutorialAdded
keep_statsparameter toadata_to_viewsto enable pseudobulk stats to be kept.Replace
intra_groupbyandextra_groupbywithmaskbyin misty. The spots will now only be filtered according tomaskby, such that both intra and extra both contain the same spots. The extra views are multiplied by the spatial connectivities prior to masking and the model being fitMerge MOFAcell improvements; related to #42 and #29
Targets with zero variance will no longer be modeled by misty.
Resolve #46 - refactored misty’s pipeline
Resolved logging and package import verbosity issues related to #43
Iternal .obs[‘label’] placeholder renamed to the less generic .obs[‘@label’]; related to #53
Minor Readme & tutorial text improvements.
1.0.0a1 Biorxiv (30.07.2023)#
positive_onlyin bivariate metrics was renamed tomask_negativeswill now mask only negative-negative/low-low interactions, and not negative-positive interactions.Replaced MSigDB with transcription factor activities in MISTy’s tutorial
Enable sorting according to ascending order in misty-related plots
Enable
cmapto be passed to tileplot & dotplotsMinor Readme & tutorial improvements.
1.0.0a0 (27.07.2023)#
LIANA becomes LIANA+.
Major changes have been made to the repository, however the API visible
to the user should be largely consistent with previous versions, except
minor exceptions: - li.fun.generate_lr_geneset is now called via
li.rs.generate_lr_geneset
the old ‘li.funcomics’ model is now renamed to something more general:
li.utilsget_factor_scoresandget_variable_loadingswere moved toli.utils
LIANA+ includes the following new features:
Spatial#
A sklearn-based implementation to learn spatially-informed multi-view models, i.e. [MISTy](https://genomebiology.biomedcentral.com/articles/10.1186/s13059-022-02663-5) models.
A new tutorial that shows how to use LIANA+ to build and run MISTy models.
Five vectorized local spatially-informed bivariate clustering and similarity metrics, such as [Moran’s R](https://www.biorxiv.org/content/10.1101/2022.08.19.504616v1.full), Cosine, Jaccard, Pearson, Spearman. As well as a numba-compiled [Masked Spearman](https://www.nature.com/articles/s41592-020-0885-x) local score.
- A new tutorial that shows how to use LIANA+ to compute spatially-informed bivariate metrics, permutations-based p-values, interaction categoriez, as well as how to summarize those into patterns using NMF.
- A radial basis kernel is implemented to calculate spot/cell
connectivities (spatial connectivities); this is used by the
spatially-informed bivariate metrics and MISTy. It mirrors
[squidpy’s](https://squidpy.readthedocs.io/en/stable/)
sq.gr.spatial_neighbors function, and is hence interchangeable with
it.
Handling multiple modalities#
- LIANA+ will now work with multi-modal data, i.e. it additionally support MuData objects as well as AnnData objects. The API visible to the user is the same, but the underlying implementation is different.
These come with a new tutorial that shows how to use LIANA+ with multi-modal (CITE-Seq) data, along with inbuilt transformations.
The same API is also adapted by the local bivariate metrics, i.e. they can also be used with multi-modal data.
Multi-conditions#
- A utility function has been added that will take any dataframe with various statistics and append it to information from AnnData objects; thus creating a multi-condition dataframe in the format of LIANA.
A new tutorial that shows how to use PyDESeq2 together with this utility function has been added, essentially a tutorial on “Hypothesis-driven CCC”.
Visualizations#
A tileplot (
li.pl.tileplot) has been added to better visualize ligands and receptors independently.MISTy-related visualizations have been added to vislualize view contributions and performance, and interaction coefficients/importances.
A simple plot
li.pl.connectivityis added to show spatial connectivities
Others#
A Causal Network inference function has been added to infer downstream signalling networks. This is currently placed in the tutorial with PyDESeq2.
An elbow approximation approach has been added to the NMF module, to help with the selection of the number of patterns.
Various utility functions to simplify AnnData extraction/conversion, Matrix transformations, etc (added to
li.ut)
Note: this is just an overview of the new features, for details please refer to the tutorials, API, and documentation.
0.1.9 (06.06.2023)#
Fixed issues with deprecated params of pandas.DataFrame.to_csv & .assert_frame_equal in tests
multi.get_variable_loadingswill now return all factorsAdded source & target params to
fun.generate_lr_geneset
- - Refactored
sc._Method._get_means_perms& related scoring functions to be more efficient. Nonecan now be passed to n_perms to avoid permutations - these are only relevant if specificity is assumed to be relevant.
LIANA’s aggregate method can now be customized to include any method of choice (added an example to basic_usage).
Removed ‘Steady’ aggregation from rank_aggregate
Changed deprecated np.float to np.float32 in
liana_pipe, relevant for CellChatmat_max.Method results will now be ordered by magnitude, if available, if not specificity is used.
Added
ligand_complexandreceptor_complexfiltering to liana’s dotplotMOFAcellular will now work only with decoupler>=1.4.0 which implements edgeR-like filtering for the views.
0.1.8 (24.03.2023)#
Removed walrus operator to support Python 3.7
Added a tutorial that shows the repurposed use of MOFA with liana to obtain intercellular communication programmes, inspired by Tensor-cell2cell
Added a tutorial that shows the repurposed use of MOFA to the analysis of multicellular programmes as in Ramirez et al., 2023
Added
key_addedparameter to save liana results to anyadata.uns``slot, anduns_keyto use liana results from anyadata.uns`` slotinplacenow works as intended (i.e. only writes toadata.unsifinplaceis True).
0.1.7 (08.02.2023)#
Fixed an edge case where subunits within the same complex with identical values resulted in duplicates. These are now arbitrarily removed according to random order.
All methods’ complexes will now be re-assembled according to the closest stat to expression that each method uses, e.g.
cellchatwill usetrimeansand the restmeans.Added a basic liana to Tensor-cell2cell tutorial as a solution to liana issue #5
Updated the basic tutorial
Referred to CCC chapter from Theis’ best-practices book
0.1.6 (23.01.2023)#
Fixed issue with duplicate subunits for non-expressed LRs when
return_all_lrsis Truemin_propwhen working withreturn_all_lrsis now filled with 0sAdded
by_samplefunction to class Method that returns a long-format dataframe of ligand-receptors, for each sampleAdded
dotplot_by_samplefunction to visualize ligand-receptor interactions across samplesRefractored preprocessing of
dotplotanddotplot_by_sampleto a separate functionChanged “pvals” of geometric_mean method to “gmean_pvals” for consistency
to_tensor_c2cutility function to convert a long-format dataframe of ligand-receptor interactions by sample to Tensor-cell2cell tensor.Added a list to track the instances of
MethodMetaclassAdded
generate_lr_genesetfunction to generate a geneset of ligand-receptors for different prior knowledge databases
0.1.5 (11.01.2023)#
Hotfix
return_all_lrsspecificity_rank being assigned to NaNAdd test to check that
specificity_rankoflrs_to_keepis equal to min(specificity_rank)
0.1.4 (11.01.2023)#
rank_aggregatewill now sort interactions according tomagnitude_rank.Fixed
SettingWithCopyWarningwarning whenreturn_all_lrsis TrueMinor text improvements to the basic tutorial notebook
Removed ‘Print’ from a verbose print message in
_choose_mtx_rep
0.1.3 (07.12.2022)#
Added
supp_columnsparameter to allow any column from liana to be returned.Added
return_all_lrsparameter to allow all interactions to be returned with alrs_to_filterflag for the interaction that do not pass theexpr_prop, and each of those interactions is assigned to the worst present score from the ones that do pass the threshold.Fixed a bug where an exception was not thrown by
assert_coveredRaise explicit exceptions as text in multiple places.
Changed cellphonedb p-values column name from “pvals” to “cellphone_pvals”.
0.1.2#
Added CellChat and GeometricMean methods
0.1.1#
Add progress bar to permutations
Deal with adata copies to optimize RAM
change copy to inplace, and assign to uns, rather than return adata
remove unnecessary filtering in [pre]{#pre} + extend units tests
0.1.0#
Restructure API further
Submit to PIP
0.0.3#
Added a filter according to
min_cellsper cell identityprep_check_adata will now assert that
groupbyexistsextended test_pre.py tests
restructured the API to be more scverse-like
0.0.2#
Added
dotplotas a visualization optionAdded
basic_usagetutorial
0.0.1#
First release alpha version of liana-py
- Re-implementations of:
CellPhoneDB
NATMI
SingleCellSignalR
Connectome
logFC
Robust aggregate rank
Ligand-receptor resources as generated via OmniPathR.