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

Handle None in psm_list['rescoring_features'] #108

Open
rodvrees opened this issue Sep 19, 2024 · 1 comment
Open

Handle None in psm_list['rescoring_features'] #108

rodvrees opened this issue Sep 19, 2024 · 1 comment

Comments

@rodvrees
Copy link
Member

At the moment, psm_utils' PepXMLReader reader passes by default:
rescoring_features = None

This gives the following error in MS2Rescore:

  File "/home/robbe/miniconda3/envs/rescore/lib/python3.10/site-packages/ms2rescore/__main__.py", line 237, in main
    rescore(configuration=config)
  File "/home/robbe/miniconda3/envs/rescore/lib/python3.10/site-packages/ms2rescore/core.py", line 55, in rescore
    psm_list_feature_names = {
  File "/home/robbe/miniconda3/envs/rescore/lib/python3.10/site-packages/ms2rescore/core.py", line 58, in <setcomp>
    for feature_name in psm_list_features.keys()
AttributeError: 'NoneType' object has no attribute 'keys'

None values should thus handle None values as empty lists for correct processing.

@RalfG RalfG transferred this issue from compomics/ms2rescore Dec 4, 2024
@RalfG
Copy link
Member

RalfG commented Dec 4, 2024

To be fixed in PepXMLReader:

rescoring_features=None,

However, ideally, this should also be validated by PSM. The current implementation is a bit ambiguous. The default is dict(), but the type hint Optional allows None:

provenance_data: Optional[Dict[str, str]] = dict()
metadata: Optional[Dict[str, str]] = dict()
rescoring_features: Optional[Dict[str, float]] = dict()

We can change the type hints to remove optional, which might break things downstream that assumed None is an allowed value... What do you think, @paretje?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants