Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ir.tl.chain_qc doesn't mark cells with no IR #452

Open
a-munoz-rojas opened this issue Sep 18, 2023 · 2 comments · May be fixed by #463
Open

ir.tl.chain_qc doesn't mark cells with no IR #452

a-munoz-rojas opened this issue Sep 18, 2023 · 2 comments · May be fixed by #463
Assignees
Labels
bug Something isn't working

Comments

@a-munoz-rojas
Copy link

Describe the bug
'ir.tl.chain_qc' states that it should mark cells that don't have any detected immune receptor (as stated in the docs). In the new data structures, this information should be in the "airr:recepetor_type", etc slots, annotated as "no IR". However when you run this function, cells that are lacking and IR are just annotated with nan values, so you can't see how many cells don't have an associated IR when plotting.

To Reproduce

import muon as mu
import scirpy as ir

mdata = ir.datasets.wu2020_3k()
adata = mdata['gex'].copy()
adata_tcr = mdata['airr'].copy() 
adata_tcr = adata_tcr[0:-100,:].copy() #artificially remove tcr info from last 100 cells

mdata = mu.MuData({"gex": adata, "airr": adata_tcr})
ir.pp.index_chains(mdata)
ir.tl.chain_qc(mdata)

mdata.obs["airr:receptor_subtype"].tail() #visualize the info on last cells - they are stored as nans

#plot the subtypes
_ = ir.pl.group_abundance(
    mdata, groupby="airr:receptor_subtype", target_col="gex:source"
)

Expected behaviour
Cells with no IR should be annotated as "no IR", according to docs (https://scirpy.scverse.org/en/latest/generated/scirpy.tl.chain_qc.html)

System

  • OS: macOSX 13.5.2
  • Python version 3.11
  • Versions of libraries involved: scirpy 0.13.1, scanpy 1.9.5, muon 0.1.5

Additional context

@a-munoz-rojas a-munoz-rojas added the bug Something isn't working label Sep 18, 2023
@grst
Copy link
Collaborator

grst commented Sep 20, 2023

Hi,

thanks for reporting this!
I believe the reason is that chain_qc operates on the mdata["airr"] slot which obviously only contains cells with a receptor. Writing back the information to mdata.obs coerces nan for cells that are not in mdata["airr"].

It should be possible to fix this pretty easily.

@grst grst self-assigned this Nov 5, 2023
@grst grst linked a pull request Nov 8, 2023 that will close this issue
3 tasks
@grst
Copy link
Collaborator

grst commented Nov 8, 2023

I fixed the chain_qc function to also compute values for cells not in the AIRR modality in #463. But plotting the result requires changes to the group_abundance function that I'll tackle together with overhauling completely how barplots are generated (which is planned for a while, see #232)

@grst grst added this to scirpy-dev May 28, 2024
@grst grst moved this to In progress in scirpy-dev May 28, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
Status: In progress
Development

Successfully merging a pull request may close this issue.

2 participants