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

RF - Input to volume stats scripts #1068

Open
wants to merge 9 commits into
base: master
Choose a base branch
from

Conversation

gabknight
Copy link
Contributor

@gabknight gabknight commented Dec 3, 2024

Quick description

Add new input features to

  • scil_volume_stats_in_labels.py

    • in_map was replaced by the argument group Metrics input options, allowing for a list of metric filenames or a metric folder;
    • if the scripts as multiple input metrics, the output json file has a new top level dict metric;
    • add add_json_args and corresponding formatting to the output json;
    • this PR changes the interface of the script, i.e. it will break other scripts using it.
  • scil_volume_stats_in_ROI.py

    • change the positional argument in_mask to in_rois, allowing for multiple input mask.
    • if the scripts as multiple input ROIs, the output json file has a new top level dict roi_name;

...

Type of change

Check the relevant options.

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to not work as expected)
  • This change requires a documentation update

Provide data, screenshots, command line to test (if relevant)

...

Checklist

  • My code follows the style guidelines of this project (run autopep8)
  • I added relevant citations to scripts, modules and functions docstrings and descriptions
  • I have performed a self-review of my code
  • I have commented my code, particularly in hard-to-understand areas
  • I have made corresponding changes to the documentation
  • My changes generate no new warnings
  • I moved all functions from the script file (except the argparser and main) to scilpy modules
  • I have added tests that prove my fix is effective or that my feature works
  • New and existing unit tests pass locally with my changes

@pep8speaks
Copy link

pep8speaks commented Dec 3, 2024

Hello @gabknight, Thank you for updating !

Line 79:80: E501 line too long (85 > 79 characters)

Line 67:80: E501 line too long (85 > 79 characters)

Comment last updated at 2025-01-08 18:53:16 UTC

@gabknight gabknight requested a review from arnaudbore December 3, 2024 21:11
@gabknight gabknight force-pushed the RF_volume_stats branch 3 times, most recently from 4c185ea to 7079040 Compare December 3, 2024 21:23
@arnaudbore arnaudbore requested a review from frheault December 3, 2024 21:34
Copy link

codecov bot commented Dec 3, 2024

Codecov Report

Attention: Patch coverage is 69.49153% with 18 lines in your changes missing coverage. Please review.

Project coverage is 69.57%. Comparing base (4d2715b) to head (bd62183).
Report is 114 commits behind head on master.

Additional details and impacted files
@@            Coverage Diff             @@
##           master    #1068      +/-   ##
==========================================
+ Coverage   69.41%   69.57%   +0.16%     
==========================================
  Files         447      448       +1     
  Lines       24046    24092      +46     
  Branches     3280     3295      +15     
==========================================
+ Hits        16691    16762      +71     
+ Misses       5960     5936      -24     
+ Partials     1395     1394       -1     
Components Coverage Δ
Scripts 70.30% <69.49%> (+0.02%) ⬆️
Library 68.60% <ø> (+0.34%) ⬆️

@arnaudbore
Copy link
Contributor

@gabknight I gave it a try and there are some errors when I use the metrics_dir.

@gabknight
Copy link
Contributor Author

hmm, it seems the error was unrelated to this PR. Should have tested it though, thanks for checking.

Could you re-test now?

Copy link
Contributor

@EmmaRenauld EmmaRenauld left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code seems ok! Small comment on the --help.

The mask can either be a binary mask, or a weighting mask. If the mask is
a weighting mask it should either contain floats between 0 and 1 or should be
normalized with --normalize_weights. IMPORTANT: if the mask contains weights
The ROIs can either be a binary masks, or a weighting masks. If the ROIs are
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(a binary mask), or (binary masks.)
(a weighting mask) or (weighting masks)

a weighting mask it should either contain floats between 0 and 1 or should be
normalized with --normalize_weights. IMPORTANT: if the mask contains weights
The ROIs can either be a binary masks, or a weighting masks. If the ROIs are
weighting masks it should either contain floats between 0 and 1 or should be
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

weighting masks, they

@@ -11,15 +11,18 @@
"""
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In the description above, can you change input map for input metric (s)?. Then, maybe something like "if more than one metric maps are provided, statistics are computed separately for each".

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.

4 participants