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

Make it possible to pass raw values #10 #14

Merged
merged 22 commits into from
Dec 12, 2023

Conversation

aj26git
Copy link
Collaborator

@aj26git aj26git commented Apr 4, 2023

This adds support for passing external data as json files (latest_model_metrics_json, previous_model_metrics_json). These need to be in the format that Iris expects:

"molprobity": {"model_wide": {"summary": {"cbeta_deviations": 0.0, "clashscore": 4.5, "ramachandran_outliers": 0.0, "ramachandran_favoured": 97.13, "rms_bonds": 0.009, "rms_angles": 1.15, "rotamer_outliers": 0.0, "molprobity_score": 1.38}}, "A": {"2": {"clash": 2, "c-beta": null, "nqh_flips": null, "omega": null, "ramachandran": 2, "rotamer": 2, "cmo": null}, "3": {"clash": 2, "c-beta": null, "nqh_flips": null, "omega": null, "ramachandran": 2, "rotamer": 2, "cmo": null}, ...
"rama_z": {"A": {"2": -0.899166, "3": 0.109762, "4": -0.051125, ....
"map_fit": [3.2, {"A": {"1": [0.581, null, null], "2": [0.647, null, null], ...

The map_fit scores (or density_scores) include a triplet of residue_fit, mainchain_fit and sidechain_fit scores. The mainchain and sidechain scores are null/None in the above example. When calculated internally in Iris, they hold non-null values. Chains with all null scores need to be removed from display - this needs to be added.

The last few commits include options to choose the CONTINUOUS_METRICS , DISCRETE_METRICS and RESIDUE_VIEW_BARS for display (arguments continuous_metrics_to_display, discrete_metrics_to_display and residue_bars_to_display). We can also choose which metrics to display using the new argumentsdiscrete_metrics_to_display and continuous_metrics_to_display, useful especially because not all metrics calculated/supplied are displayed by default.
For example, continuous_metrics_to_display = ["Avg. B", "Std. B", "Res. Fit", "Main Fit", "Rama Z", "Rota Z"]
residue_bars_to_display = ["Res. Fit", "Main Fit"]

Also added are options to provide percentile values or similar calculated externally, using arguments:
data_with_percentiles : list of metrics for which the json data file includes percentiles as well . e.g. data_with_percentiles=["map_fit"]
percentile_bar_label : axis label for the percentile bars (RESIDUE_VIEW_BARS). "Percentiles" by default. e.g. percentile_bar_label="Z-scores"
percentile_bar_range: y limits for the RESIDUE_VIEW_BARS. [0,100] if not provided. e.g. percentile_bar_range = [-5,5]

The Iris plot below shows a custom display with externally supplied metric data calculated using CCP-EM pipeliner, generated with display options:
continuous_metrics_to_display = ["Avg. B", "Std. B", "Res. Fit", "Main Fit", "Rama Z", "Rota Z"]
data_with_percentiles=["map_fit"]
residue_bars_to_display = ["Res. Fit", "Main Fit"]
percentile_bar_label="Z-scores"
percentile_bar_range=[min of Z-score data, max of Z-score data]
image

@aj26git aj26git requested a review from AliDariusKhan April 4, 2023 10:47
@aj26git aj26git self-assigned this Apr 4, 2023
@AliDariusKhan
Copy link
Contributor

I see that we've integrated changes from #4 into this pull request. That PR has a different purpose to this one, and I'm not sure why they shouldn't be kept separate.

Furthermore, that PR has intentionally not been merged (even though it is complete) because it will currently produce faulty results due to a bug in CCP4i2. Therefore, if we decide to merge other changes and release a new version of iris validation for CCP4i2, we would also have to include this rotamer Z score implementation before the corresponding bug has been resolved in CCP4i2.

@aj26git
Copy link
Collaborator Author

aj26git commented Jul 12, 2023

I see that we've integrated changes from #4 into this pull request. That PR has a different purpose to this one, and I'm not sure why they shouldn't be kept separate.

Furthermore, that PR has intentionally not been merged (even though it is complete) because it will currently produce faulty results due to a bug in CCP4i2. Therefore, if we decide to merge other changes and release a new version of iris validation for CCP4i2, we would also have to include this rotamer Z score implementation before the corresponding bug has been resolved in CCP4i2.

I thought we discussed this when I was there and the PR on rotamer Z score was waiting to be merged pending review. and it is better to merge that here to avoid major merge conflicts later. But perhaps I misunderstood and I am happy to go back a few commits . I didnt know about the rotamer Z issue with CCP4i2. I will make the changes and let you know and if you are happy with the other things, this can be merged.

aj26git added 2 commits July 21, 2023 09:05
…cation-with-tortoize-z' into Make-it-possible-to-pass-raw-values-#10"

This reverts commit 0da2dea, reversing
changes made to ae5790a.
@aj26git
Copy link
Collaborator Author

aj26git commented Jul 21, 2023

Hi Ali,

I have now reverted the changes from the merge . Please take a look and merge if you are happy

iris_validation/graphics/panel.py Outdated Show resolved Hide resolved
iris_validation/graphics/panel.py Outdated Show resolved Hide resolved
iris_validation/metrics/__init__.py Show resolved Hide resolved
iris_validation/metrics/chain.py Outdated Show resolved Hide resolved
iris_validation/metrics/chain.py Outdated Show resolved Hide resolved
iris_validation/metrics/chain.py Outdated Show resolved Hide resolved
iris_validation/__init__.py Outdated Show resolved Hide resolved
@AliDariusKhan AliDariusKhan merged commit e3b4aed into master Dec 12, 2023
@AliDariusKhan AliDariusKhan deleted the Make-it-possible-to-pass-raw-values-#10 branch December 12, 2023 12:05
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

Successfully merging this pull request may close these issues.

2 participants